Subversion Repositories eFlore/Applications.cel

Rev

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

Rev 2456 Rev 2461
Line 35... Line 35...
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
		$ids_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
		if (empty($ids_images_filtrees) || empty($ids_observations_filtrees)) {
42
		if (empty($ids_images_filtrees) || empty($ids_observations_filtrees)) {
42
			die('err');
43
			die('err');
43
		}
44
		}
Line 44... Line 45...
44
 
45
 
45
		$values = array();
46
		$values = array();
46
		foreach ($ids_images_filtrees as $id_img) {
47
		foreach ($ids_images_filtrees as $id_img) {
-
 
48
			foreach ($infos_observations_filtrees as $infos_obs) {
-
 
49
				$id_obs = $infos_obs['id_observation'];
-
 
50
				$dateTransmission = $infos_obs['date_transmission'];
47
			foreach ($ids_observations_filtrees as $id_obs) {
51
				$transmission = $infos_obs['transmission'];
48
				$values[] = "($id_img, $id_obs, NOW())";
52
				$values[] = "($id_img, $id_obs, NOW(), $dateTransmission, $transmission)";
49
			}
53
			}
50
		}
54
		}
51
		$clauseValues = implode(',', $values);
55
		$clauseValues = implode(',', $values);
52
		$requete = 'INSERT INTO cel_images (id_image, ce_observation, date_liaison) '.
56
		$requete = 'INSERT INTO cel_images (id_image, ce_observation, date_liaison, date_transmission, transmission) '.
-
 
57
			"VALUES $clauseValues ".
53
			"VALUES $clauseValues ".
58
			'ON DUPLICATE KEY UPDATE '.
-
 
59
			'	ce_observation = VALUES(ce_observation), '.
-
 
60
			'	date_liaison = NOW(), '.
-
 
61
			'	date_transmission = VALUES(date_tranmission), '.
54
			'ON DUPLICATE KEY UPDATE ce_observation = VALUES(ce_observation), date_liaison = NOW() '.
62
			'	transmission = VALUES(tranmission) '.
55
			' -- ' . __FILE__ . ':' . __LINE__;
63
			' -- ' . __FILE__ . ':' . __LINE__;
56
		$resultat = Cel::db()->executer($requete);
64
		$resultat = Cel::db()->executer($requete);
57
		if ($resultat) {
65
		if ($resultat) {
58
			exit('OK');
66
			exit('OK');
Line 120... Line 128...
120
		$ids_observations = self::filterInt($uid[2]);
128
		$ids_observations = self::filterInt($uid[2]);
121
		if (empty($ids_images) || empty($ids_observations) || ! $id_utilisateur) {
129
		if (empty($ids_images) || empty($ids_observations) || ! $id_utilisateur) {
122
			die('err');
130
			die('err');
123
		}
131
		}
124
		$ids_images_filtrees = $this->filtrerImgUtilisateur($ids_images, $id_utilisateur);
132
		$ids_images_filtrees = $this->filtrerImgUtilisateur($ids_images, $id_utilisateur);
125
		$ids_observations_filtrees = $this->filtrerObsUtilisateur($ids_observations, $id_utilisateur);
133
		$infos_observations_filtrees = $this->filtrerObsUtilisateur($ids_observations, $id_utilisateur);
126
 
-
 
-
 
134
		$ids_observations_filtrees = self::extraireValeurs($infos_observations_filtrees, 'id_observation');
127
		if (empty($ids_images_filtrees) || empty($ids_observations_filtrees)) {
135
		if (empty($ids_images_filtrees) || empty($ids_observations_filtrees)) {
128
			die('err');
136
			die('err');
129
		}
137
		}
Line 130... Line 138...
130
 
138
 
131
		$idsImgConcat = implode(',', $ids_images_filtrees);
139
		$idsImgConcat = implode(',', $ids_images_filtrees);
132
		$idsObsConcat = implode(',', $ids_observations_filtrees);
140
		$idsObsConcat = implode(',', $ids_observations_filtrees);
133
		$requete = 'UPDATE cel_images '.
141
		$requete = 'UPDATE cel_images '.
134
			'SET ce_observation = NULL '.
142
			'SET ce_observation = NULL, date_liaison = NULL, date_transmission = NULL, transmission = 0 '.
135
			"WHERE id_image IN ($idsImgConcat) AND ce_observation IN ($idsObsConcat)".
143
			"WHERE id_image IN ($idsImgConcat) AND ce_observation IN ($idsObsConcat)".
136
			' -- '.__FILE__.':'.__LINE__;
144
			' -- '.__FILE__.':'.__LINE__;
137
		$resultats = Cel::db()->executer($requete);
145
		$resultats = Cel::db()->executer($requete);
138
		if ($resultats) {
-
 
139
			exit('OK');
-
 
140
		}
-
 
141
		die('err');
146
		($resultats) ? exit('OK') : die('err');
Line 142... Line 147...
142
	}
147
	}
143
 
148
 
144
	private function filtrerImgUtilisateur($ids_images, $id_utilisateur) {
149
	private function filtrerImgUtilisateur($ids_images, $id_utilisateur) {
145
		$idsImgConcat = implode(',', $ids_images);
150
		$idsImgConcat = implode(',', $ids_images);
146
		$requete = 'SELECT id_image '.
151
		$requete = 'SELECT id_image '.
147
			'FROM cel_images '.
152
			'FROM cel_images '.
148
			"WHERE id_image IN ($idsImgConcat) ".
153
			"WHERE id_image IN ($idsImgConcat) ".
149
			"AND ce_utilisateur = $id_utilisateur ".
154
			"AND ce_utilisateur = $id_utilisateur ".
150
			' -- '.__FILE__.':'.__LINE__;
155
			' -- '.__FILE__.':'.__LINE__;
151
		$resultats = Cel::db()->requeter($requete);
156
		$resultats = Cel::db()->requeter($requete);
Line 152... Line 157...
152
		return array_map(array(__CLASS__, 'getRequeteVal'), $resultats);
157
		return self::extraireValeurs($resultats, 'id_image');
153
	}
158
	}
154
 
159
 
155
	private function filtrerObsUtilisateur($ids_observations, $id_utilisateur) {
160
	private function filtrerObsUtilisateur($ids_observations, $id_utilisateur) {
156
		$idsObsConcat = implode(',', $ids_observations);
161
		$idsObsConcat = implode(',', $ids_observations);
157
		$requete = 'SELECT id_observation '.
162
		$requete = 'SELECT id_observation, transmission, date_transmission '.
158
			'FROM cel_obs '.
163
			'FROM cel_obs '.
159
			"WHERE id_observation IN ($idsObsConcat) ".
164
			"WHERE id_observation IN ($idsObsConcat) ".
160
			"AND ce_utilisateur = $id_utilisateur ".
165
			"AND ce_utilisateur = $id_utilisateur ".
-
 
166
			' -- '.__FILE__.':'.__LINE__;
161
			' -- '.__FILE__.':'.__LINE__;
167
		$resultats = Cel::db()->requeter($requete);
Line 162... Line 168...
162
		$resultats = Cel::db()->requeter($requete);
168
		$valeurs = (is_array($resultats) && count($resultats) > 0) ? $resultats : array();
163
		return array_map(array(__CLASS__, 'getRequeteVal'), $resultats);
169
		return $valeurs;
164
	}
170
	}
Line -... Line 171...
-
 
171
 
165
 
172
	private static function filterInt($str_liste) {
166
	static function filterInt($str_liste) {
173
		return array_filter(array_map('intval', explode(',', $str_liste)));
-
 
174
	}
167
		return array_filter(array_map('intval', explode(',', $str_liste)));
175
 
-
 
176
	/**
-
 
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.
-
 
179
	 */
-
 
180
	private static function extraireValeurs($resultats, $champNom) {
-
 
181
		$valeurs = array();
168
	}
182
		if (is_array($resultats) && count($resultats) > 0) {
169
 
183
			foreach ($resultats as $infos) {
170
	// extrait la première valeur d'un tableau, utile pour renvoyer un tableau de simple valeur
184
				$valeurs = $infos[$champNom];
171
	// à partir d'une requête effectuée sur un seul champ.
185
			}