Subversion Repositories eFlore/Applications.cel

Rev

Rev 423 | Rev 848 | Go to most recent revision | Show entire file | Regard 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
 
-
 
6
/**
-
 
7
 * Liste les date de releves par utilisateur
-
 
8
 * 
-
 
9
 * uid[0] : utilisateur obligatoire
-
 
10
 * uid[1] : si absent : valeur 'all' (annee)
-
 
11
 * uid[2] : si absent : valeur 'all' (mois)
-
 
12
 * uid[3] : si absent : valeur 'all' (jour)
Line 5... Line -...
5
 
-
 
6
// Liste les date de releves par utilisateur
13
 **/ 
7
 
-
 
8
 
-
 
9
Class InventoryDateList extends DBAccessor {
-
 
10
 
-
 
11
 
-
 
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
	
Line 26... Line 18...
26
			// uid[3] : si absent : valeur 'all' (jour)
18
 
Line -... Line 19...
-
 
19
	function getElement($uid){
-
 
20
		
-
 
21
		   // Controle detournement utilisateur 
27
 
22
		    session_start();
Line 28... Line -...
28
		   // Controle detournement utilisateur 
-
 
29
		    session_start();
-
 
30
		    
23
		 	$this->controleUtilisateur($uid[0]);
31
		 	$this->controleUtilisateur($uid[0]);
-
 
32
		
-
 
33
			$DB=$this->connectDB($this->config,'database_cel');
-
 
34
			
-
 
Line -... Line 24...
-
 
24
		 	
Line 35... Line 25...
35
			$select = "date_observation" ;
25
			$condition_requete = $this->traiterParametresEtConstruireRequete($uid);
36
			 
26
		
37
			if (!isset($uid[1]) || $uid[1]=="" || $uid[1]=="all" ) {
-
 
38
				$uid[1]="all";
-
 
39
				if ($select=="") $select="year(date_observation) ";
-
 
40
			}
-
 
41
			else {
-
 
Line 42... Line -...
42
				$query_year=" AND year(date_observation)='".$DB->escapeSimple($uid[1])."' ";
-
 
43
			}
-
 
44
			
-
 
45
			
-
 
46
			if (!isset($uid[2]) || $uid[2]=="" || $uid[2]=="all" ) {
27
		   	$requete_liste_dates = 'SELECT DISTINCT '.
47
				$uid[2]="all";
-
 
48
				if ($select=="") $select="month(date_observation) ";
28
	    			'date_observation AS id '.
Line -... Line 29...
-
 
29
	           		'FROM cel_inventory WHERE '.$condition_requete.' '.
Line -... Line 30...
-
 
30
	           		'ORDER BY date_observation'; 		
49
			}
31
	        	           		
-
 
32
		    $liste_dates = $this->executerRequete($requete_liste_dates);
Line -... Line 33...
-
 
33
		    		    
-
 
34
	        $liste_dates = $this->formaterListeResultats($liste_dates);
-
 
35
		
-
 
36
			$output = json_encode($liste_dates);
-
 
37
			print($output);
Line -... Line 38...
-
 
38
			
-
 
39
			return true;	
Line 50... Line -...
50
			else {
-
 
51
				$query_month=" AND month(date_observation)='".$DB->escapeSimple($uid[2])."' ";
-
 
52
			}
-
 
53
 
-
 
54
			if (!isset($uid[3]) || $uid[3]=="" || $uid[3]=="all" ) {
40
	}
55
				$uid[3]="all";
41
	
56
				if ($select=="") $select="day(date_observation) ";
-
 
Line -... Line 42...
-
 
42
	private function formaterListeResultats($liste_dates) {
Line 57... Line 43...
57
			}
43
		
Line -... Line 44...
-
 
44
		if (!$liste_dates) {
-
 
45
    	    $liste_dates = array();
58
			else {
46
        }
59
				$query_day=" AND day(date_observation)='".$DB->escapeSimple($uid[3])."' ";
47
        	
-
 
48
    	foreach($liste_dates as &$date) {
60
			}
49
    		$date_heures = split(' ',$date['id']);
61
			
-
 
62
		
-
 
63
			$value=array();
50
    		if(count($date_heures) > 1) {
Line 64... Line -...
64
	
-
 
65
		
-
 
66
		
-
 
67
		   	$query="SELECT DISTINCT ".
51
    			$date = $date_heures[0];
68
	    			$select. " AS id" .
-
 
69
	           		" FROM cel_inventory WHERE identifiant='".$DB->escapeSimple($uid[0])."' " .
-
 
70
	            	$query_year.
52
    		}
Line 71... Line -...
71
	            	$query_month.
-
 
-
 
53
    		
-
 
54
    		$date = $date;
72
	            	$query_day.
55
        }
73
	           		" ORDER BY ".$select; 		
56
        
Line 74... Line 57...
74
	           		
57
        return $liste_dates;
75
		
58
	}