Subversion Repositories eFlore/Applications.cel

Rev

Rev 2465 | Go to most recent revision | Only display areas with differences | Ignore whitespace | Details | Blame | Last modification | View Log | RSS feed

Rev 2465 Rev 2468
1
<?php
1
<?php
2
// declare(encoding='UTF-8');
2
// declare(encoding='UTF-8');
3
/**
3
/**
4
 * Service de liaisons d'images à des observations
4
 * Service de liaisons d'images à des observations
5
 * Cas d'utilisation :
5
 * Cas d'utilisation :
6
 * 2: Le service lie une ou plusieurs images à une observation
6
 * 2: Le service lie une ou plusieurs images à une observation
7
 * 3: Le service renvoie l'observation liée à une image
7
 * 3: Le service renvoie l'observation liée à une image
8
 *
8
 *
9
 * @internal   Mininum PHP version : 5.2
9
 * @internal   Mininum PHP version : 5.2
10
 * @category   CEL
10
 * @category   CEL
11
 * @package    Services
11
 * @package    Services
12
 * @subpackage Images
12
 * @subpackage Images
13
 * @version    0.1
13
 * @version    0.1
14
 * @author     Mathias CHOUET <mathias@tela-botanica.org>
14
 * @author     Mathias CHOUET <mathias@tela-botanica.org>
15
 * @author     Jean-Pascal MILCENT <jpm@tela-botanica.org>
15
 * @author     Jean-Pascal MILCENT <jpm@tela-botanica.org>
16
 * @author     Aurelien PERONNET <aurelien@tela-botanica.org>
16
 * @author     Aurelien PERONNET <aurelien@tela-botanica.org>
17
 * @license    GPL v3 <http://www.gnu.org/licenses/gpl.txt>
17
 * @license    GPL v3 <http://www.gnu.org/licenses/gpl.txt>
18
 * @license    CECILL v2 <http://www.cecill.info/licences/Licence_CeCILL_V2-en.txt>
18
 * @license    CECILL v2 <http://www.cecill.info/licences/Licence_CeCILL_V2-en.txt>
19
 * @copyright  1999-2014 Tela Botanica <accueil@tela-botanica.org>
19
 * @copyright  1999-2014 Tela Botanica <accueil@tela-botanica.org>
20
 */
20
 */
21
class InventoryImageLink extends Cel {
21
class InventoryImageLink extends Cel {
22
 
22
 
23
	public function createElement($pairs) {
23
	public function createElement($pairs) {
24
		// Controle detournement utilisateur
24
		// Controle detournement utilisateur
25
		$this->controleUtilisateur($pairs['ce_utilisateur']);
25
		$this->controleUtilisateur($pairs['ce_utilisateur']);
26
		$id_utilisateur = $pairs['ce_utilisateur'];
26
		$id_utilisateur = $pairs['ce_utilisateur'];
27
 
27
 
28
		if (!isset($pairs['id_image'])) {
28
		if (!isset($pairs['id_image'])) {
29
			die('err');
29
			die('err');
30
		}
30
		}
31
 
31
 
32
		// filtrage des entiers
32
		// filtrage des entiers
33
		$ids_observations = self::filterInt($pairs['id_observation']);
33
		$ids_observations = self::filterInt($pairs['id_observation']);
34
		$ids_images = self::filterInt($pairs['id_image']);
34
		$ids_images = self::filterInt($pairs['id_image']);
35
		if (empty($ids_images) || empty($ids_observations)) {
35
		if (empty($ids_images) || empty($ids_observations)) {
36
			die('err');
36
			die('err');
37
		}
37
		}
38
		// filtrage des entiers à partir des ids existant réellement en DB
38
		// filtrage des entiers à partir des ids existant réellement en DB
39
		$ids_images_filtrees = $this->filtrerImgUtilisateur($ids_images, $id_utilisateur);
39
		$ids_images_filtrees = $this->filtrerImgUtilisateur($ids_images, $id_utilisateur);
40
		$infos_observations_filtrees = $this->filtrerObsUtilisateur($ids_observations, $id_utilisateur);
40
		$infos_observations_filtrees = $this->filtrerObsUtilisateur($ids_observations, $id_utilisateur);
41
		$ids_observations_filtrees = self::extraireValeurs($infos_observations_filtrees, 'id_observation');
41
		$ids_observations_filtrees = self::extraireValeurs($infos_observations_filtrees, 'id_observation');
42
		if (empty($ids_images_filtrees) || empty($ids_observations_filtrees)) {
42
		if (empty($ids_images_filtrees) || empty($ids_observations_filtrees)) {
43
			die('err');
43
			die('err');
44
		}
44
		}
45
 
45
 
46
		$values = array();
46
		$values = array();
47
		foreach ($ids_images_filtrees as $id_img) {
47
		foreach ($ids_images_filtrees as $id_img) {
48
			foreach ($infos_observations_filtrees as $infos_obs) {
48
			foreach ($infos_observations_filtrees as $infos_obs) {
49
				$id_obs = $infos_obs['id_observation'];
49
				$id_obs = $infos_obs['id_observation'];
50
				$dateTransmission = ($infos_obs['date_transmission'] != '') ? $infos_obs['date_transmission'] : 'NULL' ;
50
				$dateTransmission = ($infos_obs['date_transmission'] != '') ? Cel::db()->proteger($infos_obs['date_transmission']) : 'NULL' ;
51
				$transmission = $infos_obs['transmission'];
51
				$transmission = $infos_obs['transmission'];
52
				$values[] = "($id_img, $id_obs, NOW(), $dateTransmission, $transmission)";
52
				$values[] = "($id_img, $id_obs, NOW(), $dateTransmission, $transmission)";
53
			}
53
			}
54
		}
54
		}
55
		$clauseValues = implode(',', $values);
55
		$clauseValues = implode(',', $values);
56
		$requete = 'INSERT INTO cel_images (id_image, ce_observation, date_liaison, date_transmission, transmission) '.
56
		$requete = 'INSERT INTO cel_images (id_image, ce_observation, date_liaison, date_transmission, transmission) '.
57
			"VALUES $clauseValues ".
57
			"VALUES $clauseValues ".
58
			'ON DUPLICATE KEY UPDATE '.
58
			'ON DUPLICATE KEY UPDATE '.
59
			'	ce_observation = VALUES(ce_observation), '.
59
			'	ce_observation = VALUES(ce_observation), '.
60
			'	date_liaison = NOW(), '.
60
			'	date_liaison = NOW(), '.
61
			'	date_transmission = VALUES(date_transmission), '.
61
			'	date_transmission = VALUES(date_transmission), '.
62
			'	transmission = VALUES(transmission) '.
62
			'	transmission = VALUES(transmission) '.
63
			' -- ' . __FILE__ . ':' . __LINE__;
63
			' -- ' . __FILE__ . ':' . __LINE__;
64
		$resultat = Cel::db()->executer($requete);
64
		$resultat = Cel::db()->executer($requete);
65
		if ($resultat) {
65
		if ($resultat) {
66
			exit('OK');
66
			exit('OK');
67
		}
67
		}
68
		exit(); // peut-être qu'aucune mise à jour n'a eu lieu (ON DUPLICATE KEY)
68
		exit(); // peut-être qu'aucune mise à jour n'a eu lieu (ON DUPLICATE KEY)
69
	}
69
	}
70
 
70
 
71
	/**
71
	/**
72
	 * Retourne les identifiants des images liées à une observation ou l'identifiant de l'obs liée à une image, suivant le paramètre :
72
	 * Retourne les identifiants des images liées à une observation ou l'identifiant de l'obs liée à une image, suivant le paramètre :
73
	 * uid[0] : utilisateur obligatoire
73
	 * uid[0] : utilisateur obligatoire
74
	 * uid[1] : id_observation=valeur ou bien id_image=valeur
74
	 * uid[1] : id_observation=valeur ou bien id_image=valeur
75
	 */
75
	 */
76
	public function getElement($uid) {
76
	public function getElement($uid) {
77
		// Controle detournement utilisateur
77
		// Controle detournement utilisateur
78
		$this->controleUtilisateur($uid[0]);
78
		$this->controleUtilisateur($uid[0]);
79
 
79
 
80
		if ($uid) {
80
		if ($uid) {
81
			$param = $uid[1] ;
81
			$param = $uid[1] ;
82
			//TODO utiliser le GET plutôt pour récuperer id image ou observation
82
			//TODO utiliser le GET plutôt pour récuperer id image ou observation
83
			list($field, $value) = explode('=', $param);
83
			list($field, $value) = explode('=', $param);
84
			$valueP = Cel::db()->proteger($value);
84
			$valueP = Cel::db()->proteger($value);
85
 
85
 
86
			if ($field == 'id_observation') {
86
			if ($field == 'id_observation') {
87
				$requete = 'SELECT id_image, hauteur , largeur '.
87
				$requete = 'SELECT id_image, hauteur , largeur '.
88
					'FROM cel_images '.
88
					'FROM cel_images '.
89
					"WHERE ce_observation = $valueP ".
89
					"WHERE ce_observation = $valueP ".
90
					' -- '.__FILE__.':'.__LINE__;
90
					' -- '.__FILE__.':'.__LINE__;
91
			} else if ($field == 'id_image') {
91
			} else if ($field == 'id_image') {
92
				$requete = 'SELECT co.* '.
92
				$requete = 'SELECT co.* '.
93
					'FROM cel_obs AS co INNER JOIN cel_images AS ci ON (co.id_observation = ci.ce_observation) '.
93
					'FROM cel_obs AS co INNER JOIN cel_images AS ci ON (co.id_observation = ci.ce_observation) '.
94
					"WHERE id_image = $valueP ".
94
					"WHERE id_image = $valueP ".
95
					' -- '.__FILE__.':'.__LINE__;
95
					' -- '.__FILE__.':'.__LINE__;
96
			}
96
			}
97
		}
97
		}
98
		$resultats = Cel::db()->requeter($requete);
98
		$resultats = Cel::db()->requeter($requete);
99
 
99
 
100
		$liaisons = array();
100
		$liaisons = array();
101
		if (is_array($resultats) && count($resultats) > 0) {
101
		if (is_array($resultats) && count($resultats) > 0) {
102
			$liaisons = $resultats;
102
			$liaisons = $resultats;
103
			if ($field == 'id_image') {
103
			if ($field == 'id_image') {
104
				foreach ($liaisons as &$liaison) {
104
				foreach ($liaisons as &$liaison) {
105
					$liaison['ce_zone_geo'] = $this->convertirCodeZoneGeoVersCodeInsee($liaison['ce_zone_geo']);
105
					$liaison['ce_zone_geo'] = $this->convertirCodeZoneGeoVersCodeInsee($liaison['ce_zone_geo']);
106
				}
106
				}
107
			}
107
			}
108
		}
108
		}
109
		$this->envoyerJson($liaisons);
109
		$this->envoyerJson($liaisons);
110
		return true;
110
		return true;
111
	}
111
	}
112
 
112
 
113
	public function updateElement($uid, $pairs) {
113
	public function updateElement($uid, $pairs) {
114
 
114
 
115
	}
115
	}
116
 
116
 
117
	/**
117
	/**
118
	 * Supprimme une ou plusieurs liaisons entre images et observations
118
	 * Supprimme une ou plusieurs liaisons entre images et observations
119
	 * uid[0] : utilisateur obligatoire
119
	 * uid[0] : utilisateur obligatoire
120
	 * uid[1] : identifiant(s) image(s) obligatoire(s)
120
	 * uid[1] : identifiant(s) image(s) obligatoire(s)
121
	 * uid[2] : identifiant(s) observations
121
	 * uid[2] : identifiant(s) observations
122
	 */
122
	 */
123
	public function deleteElement($uid) {
123
	public function deleteElement($uid) {
124
	 	// Controle detournement utilisateur
124
	 	// Controle detournement utilisateur
125
		$this->controleUtilisateur($uid[0]);
125
		$this->controleUtilisateur($uid[0]);
126
		$id_utilisateur = $uid[0];
126
		$id_utilisateur = $uid[0];
127
		$ids_images = self::filterInt($uid[1]);
127
		$ids_images = self::filterInt($uid[1]);
128
		$ids_observations = self::filterInt($uid[2]);
128
		$ids_observations = self::filterInt($uid[2]);
129
		if (empty($ids_images) || empty($ids_observations) || ! $id_utilisateur) {
129
		if (empty($ids_images) || empty($ids_observations) || ! $id_utilisateur) {
130
			die('err');
130
			die('err');
131
		}
131
		}
132
		$ids_images_filtrees = $this->filtrerImgUtilisateur($ids_images, $id_utilisateur);
132
		$ids_images_filtrees = $this->filtrerImgUtilisateur($ids_images, $id_utilisateur);
133
		$infos_observations_filtrees = $this->filtrerObsUtilisateur($ids_observations, $id_utilisateur);
133
		$infos_observations_filtrees = $this->filtrerObsUtilisateur($ids_observations, $id_utilisateur);
134
		$ids_observations_filtrees = self::extraireValeurs($infos_observations_filtrees, 'id_observation');
134
		$ids_observations_filtrees = self::extraireValeurs($infos_observations_filtrees, 'id_observation');
135
		if (empty($ids_images_filtrees) || empty($ids_observations_filtrees)) {
135
		if (empty($ids_images_filtrees) || empty($ids_observations_filtrees)) {
136
			die('err');
136
			die('err');
137
		}
137
		}
138
 
138
 
139
		$idsImgConcat = implode(',', $ids_images_filtrees);
139
		$idsImgConcat = implode(',', $ids_images_filtrees);
140
		$idsObsConcat = implode(',', $ids_observations_filtrees);
140
		$idsObsConcat = implode(',', $ids_observations_filtrees);
141
		$requete = 'UPDATE cel_images '.
141
		$requete = 'UPDATE cel_images '.
142
			'SET ce_observation = NULL, date_liaison = NULL, date_transmission = NULL, transmission = 0 '.
142
			'SET ce_observation = NULL, date_liaison = NULL, date_transmission = NULL, transmission = 0 '.
143
			"WHERE id_image IN ($idsImgConcat) AND ce_observation IN ($idsObsConcat)".
143
			"WHERE id_image IN ($idsImgConcat) AND ce_observation IN ($idsObsConcat)".
144
			' -- '.__FILE__.':'.__LINE__;
144
			' -- '.__FILE__.':'.__LINE__;
145
		$resultats = Cel::db()->executer($requete);
145
		$resultats = Cel::db()->executer($requete);
146
		($resultats) ? exit('OK') : die('err');
146
		($resultats) ? exit('OK') : die('err');
147
	}
147
	}
148
 
148
 
149
	private function filtrerImgUtilisateur($ids_images, $id_utilisateur) {
149
	private function filtrerImgUtilisateur($ids_images, $id_utilisateur) {
150
		$idsImgConcat = implode(',', $ids_images);
150
		$idsImgConcat = implode(',', $ids_images);
151
		$requete = 'SELECT id_image '.
151
		$requete = 'SELECT id_image '.
152
			'FROM cel_images '.
152
			'FROM cel_images '.
153
			"WHERE id_image IN ($idsImgConcat) ".
153
			"WHERE id_image IN ($idsImgConcat) ".
154
			"AND ce_utilisateur = $id_utilisateur ".
154
			"AND ce_utilisateur = $id_utilisateur ".
155
			' -- '.__FILE__.':'.__LINE__;
155
			' -- '.__FILE__.':'.__LINE__;
156
		$resultats = Cel::db()->requeter($requete);
156
		$resultats = Cel::db()->requeter($requete);
157
		return self::extraireValeurs($resultats, 'id_image');
157
		return self::extraireValeurs($resultats, 'id_image');
158
	}
158
	}
159
 
159
 
160
	private function filtrerObsUtilisateur($ids_observations, $id_utilisateur) {
160
	private function filtrerObsUtilisateur($ids_observations, $id_utilisateur) {
161
		$idsObsConcat = implode(',', $ids_observations);
161
		$idsObsConcat = implode(',', $ids_observations);
162
		$requete = 'SELECT id_observation, transmission, date_transmission '.
162
		$requete = 'SELECT id_observation, transmission, date_transmission '.
163
			'FROM cel_obs '.
163
			'FROM cel_obs '.
164
			"WHERE id_observation IN ($idsObsConcat) ".
164
			"WHERE id_observation IN ($idsObsConcat) ".
165
			"AND ce_utilisateur = $id_utilisateur ".
165
			"AND ce_utilisateur = $id_utilisateur ".
166
			' -- '.__FILE__.':'.__LINE__;
166
			' -- '.__FILE__.':'.__LINE__;
167
		$resultats = Cel::db()->requeter($requete);
167
		$resultats = Cel::db()->requeter($requete);
168
		$valeurs = (is_array($resultats) && count($resultats) > 0) ? $resultats : array();
168
		$valeurs = (is_array($resultats) && count($resultats) > 0) ? $resultats : array();
169
		return $valeurs;
169
		return $valeurs;
170
	}
170
	}
171
 
171
 
172
	private static function filterInt($str_liste) {
172
	private static function filterInt($str_liste) {
173
		return array_filter(array_map('intval', explode(',', $str_liste)));
173
		return array_filter(array_map('intval', explode(',', $str_liste)));
174
	}
174
	}
175
 
175
 
176
	/**
176
	/**
177
	 * Extrait les valeurs d'un champ donné. Utile pour renvoyer un tableau de simples valeurs
177
	 * Extrait les valeurs d'un champ donné. Utile pour renvoyer un tableau de simples valeurs
178
	 * à partir des résultats d'une requête effectuée sur un seul champ.
178
	 * à partir des résultats d'une requête effectuée sur un seul champ.
179
	 */
179
	 */
180
	private static function extraireValeurs($resultats, $champNom) {
180
	private static function extraireValeurs($resultats, $champNom) {
181
		$valeurs = array();
181
		$valeurs = array();
182
		if (is_array($resultats) && count($resultats) > 0) {
182
		if (is_array($resultats) && count($resultats) > 0) {
183
			foreach ($resultats as $infos) {
183
			foreach ($resultats as $infos) {
184
				$valeurs[] = $infos[$champNom];
184
				$valeurs[] = $infos[$champNom];
185
			}
185
			}
186
		}
186
		}
187
		return $valeurs;
187
		return $valeurs;
188
	}
188
	}
189
}
189
}