Subversion Repositories eFlore/Applications.cel

Rev

Go to most recent revision | Details | 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);
40
		$ids_observations_filtrees = $this->filtrerObsUtilisateur($ids_observations, $id_utilisateur);
41
		if (empty($ids_images_filtrees) || empty($ids_observations_filtrees)) {
42
			die('err');
43
		}
416 aurelien 44
 
2447 jpm 45
		$values = array();
46
		foreach ($ids_images_filtrees as $id_img) {
47
			foreach ($ids_observations_filtrees as $id_obs) {
48
				$values[] = "($id_img, $id_obs, NOW())";
416 aurelien 49
			}
50
		}
2447 jpm 51
		$clauseValues = implode(',', $values);
52
		$requete = 'INSERT INTO cel_images (id_image, ce_observation, date_liaison) '.
53
			"VALUES $clauseValues ".
54
			'ON DUPLICATE KEY UPDATE ce_observation = VALUES(ce_observation), date_liaison = NOW() '.
55
			' -- ' . __FILE__ . ':' . __LINE__;
56
		$resultat = Cel::db()->executer($requete);
57
		if ($resultat) {
58
			exit('OK');
59
		}
60
		exit(); // peut-être qu'aucune mise à jour n'a eu lieu (ON DUPLICATE KEY)
416 aurelien 61
	}
62
 
898 aurelien 63
	/**
2447 jpm 64
	 * 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 65
	 * uid[0] : utilisateur obligatoire
2447 jpm 66
	 * uid[1] : id_observation=valeur ou bien id_image=valeur
67
	 */
68
	public function getElement($uid) {
416 aurelien 69
		// Controle detournement utilisateur
70
		$this->controleUtilisateur($uid[0]);
71
 
2447 jpm 72
		if ($uid) {
416 aurelien 73
			$param = $uid[1] ;
1308 aurelien 74
			//TODO utiliser le GET plutôt pour récuperer id image ou observation
2447 jpm 75
			list($field, $value) = explode('=', $param);
76
			$valueP = Cel::db()->proteger($value);
416 aurelien 77
 
2447 jpm 78
			if ($field == 'id_observation') {
79
				$requete = 'SELECT id_image, hauteur , largeur '.
80
					'FROM cel_images '.
81
					"WHERE ce_observation = $valueP ".
82
					' -- '.__FILE__.':'.__LINE__;
83
			} else if ($field == 'id_image') {
84
				$requete = 'SELECT co.* '.
85
					'FROM cel_obs AS co INNER JOIN cel_images AS ci ON (co.id_observation = ci.ce_observation) '.
86
					"WHERE id_image = $valueP ".
87
					' -- '.__FILE__.':'.__LINE__;
416 aurelien 88
			}
89
		}
2447 jpm 90
		$resultats = Cel::db()->requeter($requete);
416 aurelien 91
 
898 aurelien 92
		$liaisons = array();
2447 jpm 93
		if (is_array($resultats) && count($resultats) > 0) {
94
			$liaisons = $resultats;
95
			if ($field == 'id_image') {
96
				foreach ($liaisons as &$liaison) {
1351 aurelien 97
					$liaison['ce_zone_geo'] = $this->convertirCodeZoneGeoVersCodeInsee($liaison['ce_zone_geo']);
98
				}
99
			}
2447 jpm 100
		}
1014 aurelien 101
		$this->envoyerJson($liaisons);
102
		return true;
416 aurelien 103
	}
104
 
2447 jpm 105
	public function updateElement($uid, $pairs) {
416 aurelien 106
 
107
	}
108
 
898 aurelien 109
	/**
2447 jpm 110
	 * Supprimme une ou plusieurs liaisons entre images et observations
898 aurelien 111
	 * uid[0] : utilisateur obligatoire
112
	 * uid[1] : identifiant(s) image(s) obligatoire(s)
113
	 * uid[2] : identifiant(s) observations
114
	 */
2447 jpm 115
	public function deleteElement($uid) {
898 aurelien 116
	 	// Controle detournement utilisateur
416 aurelien 117
		$this->controleUtilisateur($uid[0]);
2456 jpm 118
		$id_utilisateur = $uid[0];
1767 raphael 119
		$ids_images = self::filterInt($uid[1]);
120
		$ids_observations = self::filterInt($uid[2]);
2456 jpm 121
		if (empty($ids_images) || empty($ids_observations) || ! $id_utilisateur) {
2447 jpm 122
			die('err');
123
		}
124
		$ids_images_filtrees = $this->filtrerImgUtilisateur($ids_images, $id_utilisateur);
125
		$ids_observations_filtrees = $this->filtrerObsUtilisateur($ids_observations, $id_utilisateur);
416 aurelien 126
 
2447 jpm 127
		if (empty($ids_images_filtrees) || empty($ids_observations_filtrees)) {
128
			die('err');
129
		}
416 aurelien 130
 
2447 jpm 131
		$idsImgConcat = implode(',', $ids_images_filtrees);
132
		$idsObsConcat = implode(',', $ids_observations_filtrees);
133
		$requete = 'UPDATE cel_images '.
134
			'SET ce_observation = NULL '.
135
			"WHERE id_image IN ($idsImgConcat) AND ce_observation IN ($idsObsConcat)".
136
			' -- '.__FILE__.':'.__LINE__;
137
		$resultats = Cel::db()->executer($requete);
138
		if ($resultats) {
139
			exit('OK');
140
		}
141
		die('err');
142
	}
416 aurelien 143
 
2447 jpm 144
	private function filtrerImgUtilisateur($ids_images, $id_utilisateur) {
145
		$idsImgConcat = implode(',', $ids_images);
146
		$requete = 'SELECT id_image '.
147
			'FROM cel_images '.
148
			"WHERE id_image IN ($idsImgConcat) ".
149
			"AND ce_utilisateur = $id_utilisateur ".
150
			' -- '.__FILE__.':'.__LINE__;
151
		$resultats = Cel::db()->requeter($requete);
152
		return array_map(array(__CLASS__, 'getRequeteVal'), $resultats);
153
	}
416 aurelien 154
 
2447 jpm 155
	private function filtrerObsUtilisateur($ids_observations, $id_utilisateur) {
156
		$idsObsConcat = implode(',', $ids_observations);
157
		$requete = 'SELECT id_observation '.
158
			'FROM cel_obs '.
159
			"WHERE id_observation IN ($idsObsConcat) ".
160
			"AND ce_utilisateur = $id_utilisateur ".
161
			' -- '.__FILE__.':'.__LINE__;
162
		$resultats = Cel::db()->requeter($requete);
163
		return array_map(array(__CLASS__, 'getRequeteVal'), $resultats);
416 aurelien 164
	}
165
 
1767 raphael 166
	static function filterInt($str_liste) {
167
		return array_filter(array_map('intval', explode(',', $str_liste)));
168
	}
169
 
170
	// extrait la première valeur d'un tableau, utile pour renvoyer un tableau de simple valeur
171
	// à partir d'une requête effectuée sur un seul champ.
172
	static function getRequeteVal($arr) {
173
		return array_shift($arr);
174
	}
2447 jpm 175
}