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
927 aurelien 2
// ATTENTION ! Classe compatible uniquement avec nouveau format de bdd du cel //
3
 
416 aurelien 4
/**
927 aurelien 5
* PHP Version 5
6
*
7
* @category  PHP
8
* @package   jrest
9
* @author    Aurelien Peronnet <aurelien@tela-botanica.org>
10
* @copyright 2010 Tela-Botanica
11
* @license   http://www.cecill.info/licences/Licence_CeCILL_V2-fr.txt Licence CECILL
12
* @version   SVN: <svn_id>
13
* @link      /doc/jrest/
14
*/
15
 
16
/**
17
* Service recherche  et ajout d'image a partir de divers critères
18
* in=utf8
19
* out=utf8
20
*
21
*/
758 aurelien 22
class InventoryImage extends Cel {
620 aurelien 23
 
24
	/**
927 aurelien 25
	* Méthode appelée avec une requête de type GET.
26
	* Renvoie les infos sur l'image correspondant à l'id passé en parametre
27
	* @param int uid[0] : utilisateur obligatoire
28
	* @param int uid[1] : identifiant image obligatoire
620 aurelien 29
	*/
30
	public function getElement($uid)
927 aurelien 31
	{
416 aurelien 32
		// Controle detournement utilisateur
620 aurelien 33
	   	$this->controleUtilisateur($uid[0]);
927 aurelien 34
 
35
	   	if(!isset($uid[0]) || !isset($uid[1])) {
36
	   		return;
37
	   	}
38
 
39
	   	$chercheur_image = new RechercheImage($this->config);
40
 
41
	   	$parametres = array('ordre' => $uid[1]);
42
 
43
	   	$retour = null;
44
	   	$image_recherchee = $chercheur_image->rechercherImages($uid[0], $parametres, 0, 1);
45
	   	if(count($image_recherchee) > 0) {
46
	   		$retour = $image_recherchee[0];
47
	   	}
1014 aurelien 48
 
49
		$this->envoyerJson($retour);
50
		return true;
416 aurelien 51
	}
52
 
620 aurelien 53
	/**
927 aurelien 54
	* Méthode appelée avec une requête de type POST avec un identifiant d'image.
55
	* Met a jour l'image correspondant à l'id passé en paramètre avec les valeurs passées dans le post
56
	*
57
	* @param int $uid[0] identifiant utilisateur
58
	* @param int $uid[1] ordre de l'image relatif à l'utilisateur
59
	* @param pairs array tableau contenant les valeurs de metadonnées à modifier
620 aurelien 60
	*/
61
	public function updateElement($uid,$pairs)
416 aurelien 62
	{
63
		// Controle detournement utilisateur
64
		$this->controleUtilisateur($uid[0]);
620 aurelien 65
 
927 aurelien 66
		if(count($pairs) == 0 || !isset($uid[1])) {
67
			return;
68
		}
620 aurelien 69
 
927 aurelien 70
		$gestionnaire_image = new GestionImage($this->config);
71
		$resultat_mise_a_jour = $gestionnaire_image->modifierImage($uid[0],$uid[1],$pairs);
620 aurelien 72
 
73
		$retour = false;
663 aurelien 74
		if ($resultat_mise_a_jour) {
620 aurelien 75
			$retour = 'OK';
76
		}
77
 
78
		$this->envoyer($retour);
79
	}
80
 
81
	/**
927 aurelien 82
	* Méthode appelée avec une requête de type PUT.
83
	* Stocke une image, crée ses miniatures et enregistre ses informations
84
	* Renvoie l'identifiant d'image nouvellement crée en cas de succès
85
	*
86
	* @param $pairs array tableau contenant les valeurs de metadonnées à ajouter
620 aurelien 87
	*/
416 aurelien 88
	function createElement($pairs)
89
	{
90
		// Controle detournement utilisateur
927 aurelien 91
		$this->controleUtilisateur($pairs['ce_utilisateur']);
620 aurelien 92
 
632 aurelien 93
		foreach ($_FILES as $file) {
416 aurelien 94
			$infos_fichier = $file ;
95
		}
607 aurelien 96
 
927 aurelien 97
		$gestionnaire_image = new GestionImage($this->config);
98
		$id_utilisateur = $pairs['ce_utilisateur'];
99
 
970 aurelien 100
		if ($gestionnaire_image->ajouterImage($id_utilisateur, $infos_fichier)) {
620 aurelien 101
 
102
			// l'upload demande de court-circuiter le fonctionnement normal de JREST
103
			// en quittant directement après l'envoi
104
			$this->envoyerMessageCreationEffectuee();
105
			exit;
106
		}
107
	}
108
 
109
	private function envoyerMessageCreationEffectuee() {
110
 
111
		header('HTTP/1.0 200 Created');
632 aurelien 112
		echo 'OK';
620 aurelien 113
		exit() ;
114
	}
416 aurelien 115
 
620 aurelien 116
	/**
927 aurelien 117
	* Méthode appelée avec une requête de type DELETE.
118
	* Supprime les infos sur l'image et le fichier correspondant à l'ordre passé en parametre
119
	* Supporte la suppression multiple en passant plusieurs numéros séparés par des virgules
120
    *
121
    * @param int uid[0] id utilisateur
122
	* @param string uid[1] : ordre(s) image(s) obligatoire(s) séparés par des virgules
123
	*
620 aurelien 124
	*/
416 aurelien 125
	function deleteElement($uid){
126
 
620 aurelien 127
	 	// Controle detournement utilisateur
416 aurelien 128
		$this->controleUtilisateur($uid[0]);
129
 
663 aurelien 130
		if (!isset($uid[1]) || !$this->EstUneSuiteIdentifiantsImage($uid[1])) {
620 aurelien 131
			return;
416 aurelien 132
		}
620 aurelien 133
 
927 aurelien 134
		$ordres_images = explode(',',$uid[1]);
416 aurelien 135
 
927 aurelien 136
	    $gestionnaire_image = new GestionImage($this->config);
137
	    $suppression_image = $gestionnaire_image->supprimerImage($uid[0], $ordres_images);
416 aurelien 138
 
620 aurelien 139
		$this->envoyer('OK');
416 aurelien 140
	}
620 aurelien 141
 
142
	private function estUneSuiteIdentifiantsImage($chaine) {
143
 
144
		// un ensemble d'identifiants est une suite d'identifiants séparés par des virgules
145
		// sans virgule terminale
146
		$reg_exp = "/^(([0-9])+,)*([0-9])+$/";
147
 
927 aurelien 148
		return preg_match($reg_exp, $chaine);
620 aurelien 149
	}
416 aurelien 150
}
151
?>