Subversion Repositories eFlore/Applications.cel

Rev

Rev 2468 | Details | Compare with Previous | Last modification | View Log | RSS feed

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