Subversion Repositories Sites.obs-saisons.fr

Rev

Rev 41 | Rev 210 | Go to most recent revision | Details | Compare with Previous | Last modification | View Log | RSS feed

Rev Author Line No. Line
31 aurelien 1
<?php
2
 
3
class OdsIndividu extends JRestService {
4
 
33 aurelien 5
	const PREFIXE = 'get';
6
 
31 aurelien 7
	/**
8
     * Méthode appelée avec une requête de type GET.
9
     *
10
     */
11
    function getElement($param = array()) {
33 aurelien 12
 
13
    	$type = $param[0];
31 aurelien 14
 
33 aurelien 15
    	if ($type == '*' || is_numeric($type)) {
16
            $info = $this->getElementParDefaut($param);
17
        } else {
18
            $methode = self::PREFIXE.$type;
19
            if (method_exists($this, $methode)) {
20
                array_shift($param);
21
                $info = $this->$methode($param);
22
            } else {
23
                $this->messages[] = "Le type d'information demandé '$type' n'est pas disponible.";
24
            }
25
        }
31 aurelien 26
 
27
        // Envoi sur la sortie standard
28
        $this->envoyer($info);
29
    }
30
 
31
    /**
32
     * Méthode appelée pour ajouter un élément.
33
     */
34
    public function createElement($params) {
33 aurelien 35
 
36
        $elements_requis = array('id_participant','id_espece','id_station','individu_nom');
37
 
38
    	foreach($elements_requis as $requis) {
39
    		if(!isset($params[$requis])) {
40
    			//$erreurs[$requis] = 'erreur ';
41
    		}
42
    	}
43
 
44
    	if(!empty($erreurs)) {
45
    		$this->envoyer($erreurs);
46
    	}
47
 
48
    	$id_participant = $params['id_participant'];
49
 
50
    	$requete_creation_individu = 'INSERT INTO ods_individus '.
51
					'(oi_ce_espece, oi_ce_station, oi_nom) '.
52
					'VALUES ('.
53
							$this->proteger($params['id_espece']).','.
54
							$this->proteger($params['id_station']).','.
55
							$this->proteger($params['individu_nom']).')';
56
		$creation_individu = $this->executerRequeteSimple($requete_creation_individu);
57
 
46 aurelien 58
 
59
    	if(!$creation_individu) {
60
    		$retour['erreurs'] = 'erreur d\'insertion';
61
    	} else {
62
    		$retour['id_nouvel_individu'] = $this->renvoyerDernierIdInsere();
33 aurelien 63
    	}
64
 
46 aurelien 65
    	$this->envoyer($retour);
31 aurelien 66
    }
67
 
68
    /**
69
     * Méthode appelée pour mettre à jour un élément
70
     */
71
    public function updateElement($uid, $params)    {
72
        //Mise à jour de la personne
73
        // Identification de l'utilisateur
74
        list($id_utilisateur, $id_session) = $this->getIdentification($params);
75
 
76
        // Contrôle du non détournement de l'utilisateur
77
        if ($this->etreAutorise($id_utilisateur)) {
78
            try {
79
 
80
            } catch (PDOException $e) {
81
                $messages[] = sprintf($this->getTxt('sql_erreur'), $e->getFile(), $e->getLine(), $e->getMessage(), $requete);
82
            }
83
        }
84
 
85
        $this->envoyer();
86
    }
87
 
88
    /**
89
     * Méthode appelée pour supprimer un élément
90
     */
91
    public function deleteElement($uid) {
92
        // Vérification de la présence des id passés par l'url
93
        if (!isset($uid[0]) || !isset($uid[1])) {
94
            $this->messages[] = "Identifiant d'utilisateur ou de personne manquant. Vous ne devriez pas avoir accès à ce service.";
95
        } else {
96
            list($id_utilisateur, $id_session) = $this->getIdentification($uid[0]);
97
 
98
            // Contrôle du non détournement de l'utilisateur
99
            if ($this->etreAutorise($id_utilisateur)) {
100
                // Récupération des id passés par l'url
101
                $identifiants = explode(',', rtrim($uid[1], ','));
102
                if (count($identifiants) == 0) {
103
                    $this->messages[] = "Aucun enregistrement n'a été supprimé.";
104
                } else {
105
                    foreach ($identifiants as $id_personne) {
106
                        try {
107
                        } catch (PDOException $e) {
108
                            $this->messages[] = sprintf($this->getTxt('sql_erreur'), $e->getFile(), $e->getLine(), $e->getMessage(), $requete);
109
                        }
110
                    }
111
                }
112
            }
113
        }
114
 
115
        // Envoie sur la sortie standard
116
        $this->envoyer();
117
    }
118
 
41 aurelien 119
    private function getElementParDefaut($params) {
120
    	return $this->getInformationsIndividu($params);
121
    }
122
 
33 aurelien 123
    private function getInformationsIndividu($params) {
124
 
125
    	$id_individu = $params[0];
126
 
41 aurelien 127
    	$requete_informations_individu = 'SELECT * FROM ods_individus '.
33 aurelien 128
								'WHERE oi_id_individu = '.$this->proteger($id_individu);
129
 
41 aurelien 130
    	$informations_individu = $this->executerRequete($requete_informations_individu);
131
 
132
    	if(!empty($informations_individu)) {
133
    		$informations_individu_formatees = $this->formaterTableauIndividuPourEnvoi($informations_individu[0]);
134
    	}
135
 
136
    	return $informations_individu_formatees;
137
 
33 aurelien 138
    }
139
 
140
    private function getIndividusPourStation($params) {
141
 
142
    	$id_station = $params[0];
31 aurelien 143
 
33 aurelien 144
		$requete_individus_station = 'SELECT * FROM ods_individus '.
145
									 'WHERE oi_ce_station = '.$this->proteger($id_station);
146
    	$liste_individus_pour_station = $this->executerRequete($requete_individus_station);
147
 
148
    	foreach($liste_individus_pour_station as &$individu_pour_station) {
149
 
150
    		$individu_pour_station = $this->formaterTableauIndividuPourEnvoi($individu_pour_station);
151
    	}
152
 
153
    	return $liste_individus_pour_station;
31 aurelien 154
    }
33 aurelien 155
 
156
	private function getIndividusPourStationPourEspece($params) {
157
 
158
    	$id_station = $params[0];
159
    	$id_espece = $params[1];
160
 
161
		$requete_individus_station_espece = 'SELECT * FROM ods_individus '.
162
									 'WHERE oi_ce_station = '.$this->proteger($id_station).' '.
163
									 'AND oi_ce_espece ='.$this->proteger($id_espece);
164
 
165
    	$liste_individus_pour_station_pour_espece = $this->executerRequete($requete_individus_station_espece);
166
 
167
		foreach($liste_individus_pour_station_pour_espece as &$individu_pour_station_pour_espece) {
168
 
169
    		$individu_pour_station_pour_espece = $this->formaterTableauIndividuPourEnvoi($individu_pour_station_pour_espece);
170
    	}
171
 
172
    	return $liste_individus_pour_station_pour_espece;
173
    }
174
 
175
	private function formaterTableauIndividuPourEnvoi($individu) {
176
 
177
    	return array(
41 aurelien 178
    	    'id_individu' => $individu['oi_id_individu'],
33 aurelien 179
            'id_espece' => $individu['oi_ce_espece'],
180
            'id_station' => $individu['oi_ce_station'],
181
    	    'nom' => $individu['oi_nom']
182
        );
183
 
184
    }
31 aurelien 185
}
186
?>