Subversion Repositories eFlore/Applications.cel

Rev

Rev 660 | Rev 848 | Go to most recent revision | Show entire file | Ignore whitespace | Details | Blame | Last modification | View Log | RSS feed

Rev 660 Rev 756
Line 1... Line 1...
1
<?php
1
<?php
Line 2... Line 2...
2
 
2
 
3
// in : utf8
3
// in : utf8
Line -... Line 4...
-
 
4
// out : utf8
4
// out : utf8
5
 
5
 
6
/**
-
 
7
 * Liste les date des images par utilisateur
-
 
8
 * 
-
 
9
 * uid[0] : utilisateur obligatoire
-
 
10
 * uid[1] : si absent : valeur 'all' (annee)
6
// Liste les date de releves par utilisateur
11
 * uid[2] : si absent : valeur 'all' (mois)
7
 
12
 * uid[3] : si absent : valeur 'all' (jour)
Line -... Line 13...
-
 
13
 **/ 
-
 
14
class ImageDateList extends Cel {
-
 
15
	
8
 
16
	private $correspondance_fonction = array(1 => 'year', 2 => 'month', 3 => 'day');
Line 9... Line -...
9
Class ImageDateList extends Cel {
-
 
10
	
-
 
11
	function getElement($uid){
-
 
12
		
-
 
13
 
-
 
14
			// uid[0] : utilisateur obligatoire
-
 
15
			// uid[1] : si absent : valeur 'all' (annee)
17
	
16
			// uid[2] : si absent : valeur 'all' (mois)
18
 
17
			// uid[3] : si absent : valeur 'all' (jour)
-
 
18
 
19
	function getElement($uid){
19
		   // Controle detournement utilisateur 
20
		
20
		    session_start();
21
		   // Controle detournement utilisateur 
21
		    
22
		    session_start();
22
		 	$this->controleUtilisateur($uid[0]);
23
		 	$this->controleUtilisateur($uid[0]);
23
					
24
		 	
24
			$select = "ci_meta_date" ;
25
			$condition_requete = $this->traiterParametresEtConstruireRequete($uid);
25
			 
-
 
26
			if (!isset($uid[1]) || $uid[1]=="" || $uid[1]=="all" ) {
-
 
27
				$uid[1]="all";
26
		
28
				if ($select=="") $select="year(ci_meta_date) ";
-
 
29
			}
27
		   	$requete_liste_dates = 'SELECT DISTINCT '.
-
 
28
	    			'ci_meta_date AS id '.
30
			else {
29
	           		'FROM cel_images WHERE '.$condition_requete.' '.
31
				$query_year=" AND year(ci_meta_date)='".$this->bdd->quote($uid[1])."' ";
-
 
32
			}
-
 
33
			
30
	           		'ORDER BY ci_meta_date';
34
			
-
 
35
			if (!isset($uid[2]) || $uid[2]=="" || $uid[2]=="all" ) {
-
 
36
				$uid[2]="all";
-
 
37
				if ($select=="") $select="month(ci_meta_date) ";
-
 
38
			}
31
	        	           		
39
			else {
32
		    $liste_dates = $this->executerRequete($requete_liste_dates);
40
				$query_month=" AND month(ci_meta_date)='".$this->bdd->quote($uid[2])."' ";
33
		    		    
41
			}
-
 
42
 
-
 
43
			if (!isset($uid[3]) || $uid[3]=="" || $uid[3]=="all" ) {
-
 
44
				$uid[3]="all";
-
 
45
				if ($select=="") $select="day(ci_meta_date) ";
-
 
Line -... Line 34...
-
 
34
	        $liste_dates = $this->formaterListeResultats($liste_dates);
-
 
35
		
-
 
36
			$output = json_encode($liste_dates);
-
 
37
			print($output);
Line -... Line 38...
-
 
38
			
46
			}
39
			return true;	
-
 
40
	}
-
 
41
	
-
 
42
	private function formaterListeResultats($liste_dates) {
-
 
43
		
-
 
44
		if (!$liste_dates) {
-
 
45
    	    $liste_dates = array();
-
 
46
        }
-
 
47
        	
-
 
48
    	foreach($liste_dates as &$date) {
-
 
49
    		
-
 
50
    		if($date['id'] == null || trim($date['id']) == '' || $date['id'] == 'null') {
-
 
51
    			$date = '0000-00-00';
-
 
52
    		} else { 	
-
 
53
	    		$date_heures = split(' ',$date['id']);
-
 
54
	    		if(count($date_heures) > 1) {
-
 
55
	    			$date = $date_heures[0];
-
 
56
	    		} else {
-
 
57
	    			$date = $date['id'];
Line -... Line 58...
-
 
58
	    		}
Line -... Line 59...
-
 
59
    		}
Line 47... Line -...
47
			else {
-
 
48
				$query_day=" AND day(ci_meta_date)='".$this->bdd->quote($uid[3])."' ";
-
 
49
			}
-
 
50
			
-
 
51
		
-
 
52
			$value=array();
-
 
53
	
60
        }
54
		
-
 
55
		
-
 
56
		   	$query="SELECT DISTINCT ".
61
        
57
	    			$select. " AS id" .
-
 
58
	           		" FROM cel_images WHERE ci_ce_utilisateur=".$this->bdd->quote($uid[0])." " .
62
        return $liste_dates;
59
	            	$query_year.
63
	}
60
	            	$query_month.
64
	
61
	            	$query_day.
65
	private function traiterParametresEtConstruireRequete($params) {
62
	           		" ORDER BY ".$select; 		
-
 
63
	           		
66
		
Line 64... Line -...
64
		
-
 
65
		    $res = $this->executerRequete($query);
-
 
66
		    
-
 
67
		    foreach($res as $date_obs) {
67
		$requete_condition = ' ci_ce_utilisateur = '.$this->proteger($params[0]);
68
		    	 if($date_obs['id'] == null || $date_obs['id'] == 'null') {
-
 
69
		    	 	$date_obs['id']="0000-00-00";
-
 
70
		    	 } 
68
		
Line 71... Line -...
71
	        	 $value[]=array($date_obs['id']);
-
 
-
 
69
		$taille_tableau_parametres = count($params);
-
 
70
		for($i=1; $i <= $taille_tableau_parametres; $i++) {
72
    	    }
71
			if($this->estUnParametreDate($params[$i])) {
73
		
72
				$fonction_date = $this->correspondance_fonction[$i]; 
Line 74... Line 73...
74
			$output = json_encode($value);
73
				$requete_condition .= ' AND '.$fonction_date.'(ci_meta_date) = '.$this->proteger($params[$i]);
75
			print($output);
74
			}