Subversion Repositories eFlore/Applications.cel

Rev

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

Rev 423 Rev 757
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 de releves 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)
8
 
-
 
9
Class InventoryDateList extends DBAccessor {
-
 
10
 
-
 
Line 11... Line 13...
11
 
13
 **/ 
12
	var $config;
-
 
13
	
-
 
14
	function InventoryDateList($config) {
-
 
Line 15... Line 14...
15
 
14
class InventoryDateList extends Cel {
Line 16... Line -...
16
		$this->config=$config;
-
 
17
	}
-
 
18
	
-
 
19
 
-
 
20
	function getElement($uid){
-
 
21
		
-
 
22
 
15
	
23
			// uid[0] : utilisateur obligatoire
16
	private $correspondance_fonction = array(1 => 'year', 2 => 'month', 3 => 'day');
24
			// uid[1] : si absent : valeur 'all' (annee)
-
 
25
			// uid[2] : si absent : valeur 'all' (mois)
17
	
-
 
18
 
-
 
19
	function getElement($uid){
Line 26... Line 20...
26
			// uid[3] : si absent : valeur 'all' (jour)
20
		
27
 
-
 
28
		   // Controle detournement utilisateur 
21
		   // Controle detournement utilisateur 
29
		    session_start();
-
 
30
		    
22
		    session_start();
31
		 	$this->controleUtilisateur($uid[0]);
-
 
32
		
23
		 	$this->controleUtilisateur($uid[0]);
33
			$DB=$this->connectDB($this->config,'database_cel');
-
 
34
			
-
 
35
			$select = "date_observation" ;
-
 
36
			 
-
 
37
			if (!isset($uid[1]) || $uid[1]=="" || $uid[1]=="all" ) {
24
		 	
-
 
25
			$condition_requete = $this->traiterParametresEtConstruireRequete($uid);
38
				$uid[1]="all";
26
		
39
				if ($select=="") $select="year(date_observation) ";
-
 
40
			}
-
 
41
			else {
27
		   	$requete_liste_dates = 'SELECT DISTINCT '.
42
				$query_year=" AND year(date_observation)='".$DB->escapeSimple($uid[1])."' ";
-
 
43
			}
-
 
44
			
-
 
45
			
-
 
46
			if (!isset($uid[2]) || $uid[2]=="" || $uid[2]=="all" ) {
28
	    			'date_observation AS id '.
47
				$uid[2]="all";
29
	           		'FROM cel_inventory WHERE '.$condition_requete.' '.
48
				if ($select=="") $select="month(date_observation) ";
30
	           		'ORDER BY date_observation'; 		
49
			}
-
 
50
			else {
-
 
51
				$query_month=" AND month(date_observation)='".$DB->escapeSimple($uid[2])."' ";
-
 
52
			}
-
 
53
 
-
 
Line -... Line 31...
-
 
31
	        	           		
-
 
32
		    $liste_dates = $this->executerRequete($requete_liste_dates);
-
 
33
		    		    
-
 
34
	        $liste_dates = $this->formaterListeResultats($liste_dates);
Line -... Line 35...
-
 
35
		
-
 
36
			$output = json_encode($liste_dates);
-
 
37
			print($output);
-
 
38
			
-
 
39
			return true;	
-
 
40
	}
-
 
41
	
-
 
42
	private function formaterListeResultats($liste_dates) {
-
 
43
		
-
 
44
		if (!$liste_dates) {
54
			if (!isset($uid[3]) || $uid[3]=="" || $uid[3]=="all" ) {
45
    	    $liste_dates = array();
-
 
46
        }
-
 
47
        	
-
 
48
    	foreach($liste_dates as &$date) {
-
 
49
    		$date_heures = split(' ',$date['id']);
Line -... Line 50...
-
 
50
    		if(count($date_heures) > 1) {
Line -... Line 51...
-
 
51
    			$date = $date_heures[0];
Line 55... Line 52...
55
				$uid[3]="all";
52
    		}
56
				if ($select=="") $select="day(date_observation) ";
-
 
57
			}
53
    		
58
			else {
-
 
59
				$query_day=" AND day(date_observation)='".$DB->escapeSimple($uid[3])."' ";
-
 
60
			}
-
 
61
			
-
 
62
		
-
 
63
			$value=array();
-
 
64
	
54
    		$date = $date;
65
		
-
 
66
		
55
        }
67
		   	$query="SELECT DISTINCT ".
56
        
68
	    			$select. " AS id" .
57
        return $liste_dates;
69
	           		" FROM cel_inventory WHERE identifiant='".$DB->escapeSimple($uid[0])."' " .
-
 
70
	            	$query_year.
-
 
71
	            	$query_month.
58
	}
Line 72... Line -...
72
	            	$query_day.
-
 
73
	           		" ORDER BY ".$select; 		
-
 
74
	           		
-
 
75
		
59
	
76
		    $res =& $DB->query($query);
-
 
77
		    
-
 
78
	        if (DB::isError($res)) {
60
	private function traiterParametresEtConstruireRequete($params) {
Line 79... Line -...
79
    	        die($res->getMessage());
-
 
-
 
61
		
-
 
62
		$requete_condition = ' identifiant = '.$this->proteger($params[0]);
80
        	}
63
		
81
	        while ($row =& $res->fetchrow(DB_FETCHMODE_ASSOC)) {
64
		$taille_tableau_parametres = count($params);
Line 82... Line 65...
82
	        	 $value[]=array($row['id']);
65
		for($i=1; $i <= $taille_tableau_parametres; $i++) {
83
    	    }
66
			if($this->estUnParametreDate($params[$i])) {