Subversion Repositories eFlore/Applications.cel

Rev

Rev 1180 | Rev 2129 | Go to most recent revision | Only display areas with differences | Ignore whitespace | Details | Blame | Last modification | View Log | RSS feed

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