Subversion Repositories eFlore/Applications.cel

Rev

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

Rev Author Line No. Line
416 aurelien 1
<?php
898 aurelien 2
// ATTENTION ! Classe compatible uniquement avec nouveau format de bdd du cel //
3
/**
4
* PHP Version 5
5
*
6
* @category  PHP
7
* @package   jrest
8
* @author    Aurélien Peronnet <aurelien@tela-botanica.org>
1767 raphael 9
* @author    Raphaël Droz <raphael@tela-botanica.org>
10
* @copyright 2010,2013 Tela-Botanica
898 aurelien 11
* @license   http://www.cecill.info/licences/Licence_CeCILL_V2-fr.txt Licence CECILL
12
* @version   SVN: <svn_id>
13
* @link      /doc/jrest/
14
*/
416 aurelien 15
 
16
/**
898 aurelien 17
* InventoryImageLink.php
18
*
19
* in : utf8
20
* out : utf8
21
*
22
* Cas d'utilisation :
23
* Service de liaisons d'images à des observations
24
*
25
* 2: Le service lie une ou plusieurs images à une ou plusieurs observations
26
* 3: Le service renvoie les observations liées à une image
27
*/
28
class InventoryImageLink extends Cel {
416 aurelien 29
 
30
	function createElement($pairs)
31
	{
32
		// Controle detournement utilisateur
898 aurelien 33
		$this->controleUtilisateur($pairs['ce_utilisateur']);
1761 raphael 34
		if(!isset($pairs['id_image'])) exit;
416 aurelien 35
 
1767 raphael 36
		$utilisateur = $pairs['ce_utilisateur'] ;
416 aurelien 37
 
1767 raphael 38
		// filtrage des entiers
39
		$ids_observations = self::filterInt($pairs['id_observation']);
40
		$ids_images = self::filterInt($pairs['id_image']);
41
		if(empty($ids_images) || empty($ids_observations)) die('err');
416 aurelien 42
 
1767 raphael 43
		// filtrage des entiers à partir des ids existant réellement en DB
44
		$ids_observations = array_map(array(__CLASS__, 'getRequeteVal'),
45
									  Cel::db()->requeter(sprintf("SELECT id_observation FROM cel_obs WHERE id_observation IN (%s) AND ce_utilisateur = %d",
46
																  implode(',', $ids_observations),
47
																  $utilisateur)));
48
		$ids_images = array_map(array(__CLASS__, 'getRequeteVal'),
49
								Cel::db()->requeter(sprintf("SELECT id_image FROM cel_images WHERE id_image IN (%s) AND ce_utilisateur = %d",
50
															implode(',', $ids_images),
51
															$utilisateur)));
416 aurelien 52
 
1767 raphael 53
		if(empty($ids_images) || empty($ids_observations)) die('err');
416 aurelien 54
 
1767 raphael 55
		$requete_creation_lien = 'INSERT INTO cel_obs_images (id_image, id_observation, date_liaison) VALUES %s ON DUPLICATE KEY UPDATE id_image = id_image' . ' -- ' . __FILE__ . ':' . __LINE__;
56
		$update = Array();
57
		foreach($ids_images as $image) {
58
			foreach($ids_observations as $observation) {
59
				$update[] = "($image, $observation, NOW())";
416 aurelien 60
			}
61
		}
1767 raphael 62
		$resultat_creation_lien = Cel::db()->executer(sprintf($requete_creation_lien, implode(',', $update)));
63
		if ($resultat_creation_lien) die("OK");
64
		exit; // peut-être qu'aucune mise à jour n'a eu lieu (ON DUPLICATE KEY)
416 aurelien 65
	}
66
 
898 aurelien 67
	/**
68
	 * renvoie les numeros des images liées à une observation ou l'inverse, suivant le paramètre
69
	 * uid[0] : utilisateur obligatoire
70
	 * uid[1] : ordre_observation=valeur ou bien id_image=valeur
71
	 *
72
	 */
416 aurelien 73
	function getElement($uid)
74
	{
75
		// Controle detournement utilisateur
76
		$this->controleUtilisateur($uid[0]);
77
 
78
		if($uid) {
79
 
80
			$param = $uid[1] ;
1308 aurelien 81
			//TODO utiliser le GET plutôt pour récuperer id image ou observation
996 aurelien 82
			$tab_param = explode('=',$param) ;
416 aurelien 83
 
84
			$field = $tab_param[0] ;
85
			$value = $tab_param[1] ;
86
 
898 aurelien 87
			$requete_selection_liaison = "" ;
416 aurelien 88
 
898 aurelien 89
			if ($field == 'id_observation')
416 aurelien 90
			{
898 aurelien 91
				$column = 'id_image' ;
974 aurelien 92
				$requete_selection_liaison = 'SELECT id_image, hauteur , largeur '.
93
						 'FROM cel_images '.
94
						 'WHERE id_image IN ( '.
95
						 	'SELECT id_image '.
96
							'FROM cel_obs_images '.
1765 raphael 97
							'WHERE id_observation = '.Cel::db()->proteger($value).' '.
974 aurelien 98
						 ')';
416 aurelien 99
			}
100
			else
101
			{
898 aurelien 102
				$column = 'id_observation' ;
1765 raphael 103
				$requete_selection_liaison = 'SELECT * from cel_obs WHERE id_observation IN (SELECT '.$column.' FROM cel_obs_images WHERE '.$field.' = '.Cel::db()->proteger($value).') ' ;
416 aurelien 104
			}
105
 
106
		}
107
 
1765 raphael 108
		$resultat_selection_liaison = Cel::db()->requeter($requete_selection_liaison);
898 aurelien 109
 
110
		$liaisons = array();
111
        if (is_array($resultat_selection_liaison) && count($resultat_selection_liaison) > 0) {
112
			$liaisons = $resultat_selection_liaison;
1351 aurelien 113
			if($field == 'id_image') {
114
				foreach($liaisons as &$liaison) {
115
					$liaison['ce_zone_geo'] = $this->convertirCodeZoneGeoVersCodeInsee($liaison['ce_zone_geo']);
116
				}
117
			}
898 aurelien 118
        }
416 aurelien 119
 
1014 aurelien 120
		$this->envoyerJson($liaisons);
121
		return true;
416 aurelien 122
	}
123
 
124
	function updateElement($uid,$pairs)
125
	{
126
 
127
	}
128
 
898 aurelien 129
	/**
130
	 * Supprimme une ou plusieurs liaisons entre images et observations
131
	 * uid[0] : utilisateur obligatoire
132
	 * uid[1] : identifiant(s) image(s) obligatoire(s)
133
	 * uid[2] : identifiant(s) observations
134
	 *
135
	 */
1767 raphael 136
	function deleteElement($uid) {
898 aurelien 137
	 	// Controle detournement utilisateur
416 aurelien 138
		$this->controleUtilisateur($uid[0]);
1767 raphael 139
		$id = $uid[0];
416 aurelien 140
 
1767 raphael 141
		$ids_images = self::filterInt($uid[1]);
142
		$ids_observations = self::filterInt($uid[2]);
416 aurelien 143
 
1767 raphael 144
		if(empty($ids_images) || empty($ids_observations) || ! $id) die('err');
416 aurelien 145
 
146
 
1767 raphael 147
		$ids_images = array_map(array(__CLASS__, 'getRequeteVal'),
148
								Cel::db()->requeter(sprintf("SELECT id_image FROM cel_images WHERE id_image IN (%s) AND ce_utilisateur = %d",
149
															implode(',', $ids_images),
150
															$id)));
151
		$ids_observations = array_map(array(__CLASS__, 'getRequeteVal'),
152
									  Cel::db()->requeter(sprintf("SELECT id_observation FROM cel_obs WHERE id_observation IN (%s) AND ce_utilisateur = %d",
153
																  implode(',', $ids_observations),
154
																  $id)));
416 aurelien 155
 
1767 raphael 156
		if(empty($ids_images) || empty($ids_observations)) die('err');
416 aurelien 157
 
1767 raphael 158
 
159
		$resultat_suppression_lien = Cel::db()->executer(sprintf("DELETE FROM cel_obs_images WHERE id_image IN (%s) AND id_observation IN (%s)",
160
																implode(',', $ids_images),
161
																implode(',', $ids_observations)));
162
 
163
		if ($resultat_suppression_lien) die('OK');
164
		die;
416 aurelien 165
	}
166
 
1767 raphael 167
	static function filterInt($str_liste) {
168
		return array_filter(array_map('intval', explode(',', $str_liste)));
169
	}
170
 
171
	// extrait la première valeur d'un tableau, utile pour renvoyer un tableau de simple valeur
172
	// à partir d'une requête effectuée sur un seul champ.
173
	static function getRequeteVal($arr) {
174
		return array_shift($arr);
175
	}
176
 
416 aurelien 177
}
178
?>