Subversion Repositories eFlore/Applications.del

Rev

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

Rev 1840 Rev 1845
1
<?php
1
<?php
2
// declare(encoding='UTF-8');
2
// declare(encoding='UTF-8');
3
/**
3
/**
4
 * Listes des images avec leurs infos liées.
4
 * Listes des images avec leurs infos liées.
5
 *
5
 *
6
 * del/services/0.1/images?navigation.depart=0&navigation.limite=12&tri=votes&ordre=desc
6
 * del/services/0.1/images?navigation.depart=0&navigation.limite=12&tri=votes&ordre=desc
7
 * del/services/0.1/images?navigation.depart=0&navigation.limite=12&tri=votes&ordre=desc&masque=plop
7
 * del/services/0.1/images?navigation.depart=0&navigation.limite=12&tri=votes&ordre=desc&masque=plop
8
 * del/services/0.1/images?navigation.depart=0&navigation.limite=12&tri=votes&ordre=desc&protocole=3
8
 * del/services/0.1/images?navigation.depart=0&navigation.limite=12&tri=votes&ordre=desc&protocole=3
9
 * del/services/0.1/images?navigation.depart=0&navigation.limite=12&tri=votes&ordre=desc&protocole=3&masque=plop
9
 * del/services/0.1/images?navigation.depart=0&navigation.limite=12&tri=votes&ordre=desc&protocole=3&masque=plop
10
 *
10
 *
11
 * @category   DEL
11
 * @category   DEL
12
 * @package    Services
12
 * @package    Services
13
 * @subpackage Images
13
 * @subpackage Images
14
 * @version    0.1
14
 * @version    0.1
15
 * @author     Mathias CHOUET <mathias@tela-botanica.org>
15
 * @author     Mathias CHOUET <mathias@tela-botanica.org>
16
 * @author     Jean-Pascal MILCENT <jpm@tela-botanica.org>
16
 * @author     Jean-Pascal MILCENT <jpm@tela-botanica.org>
17
 * @author     Aurelien PERONNET <aurelien@tela-botanica.org>
17
 * @author     Aurelien PERONNET <aurelien@tela-botanica.org>
18
 * @license    GPL v3 <http://www.gnu.org/licenses/gpl.txt>
18
 * @license    GPL v3 <http://www.gnu.org/licenses/gpl.txt>
19
 * @license    CECILL v2 <http://www.cecill.info/licences/Licence_CeCILL_V2-en.txt>
19
 * @license    CECILL v2 <http://www.cecill.info/licences/Licence_CeCILL_V2-en.txt>
20
 * @copyright  1999-2014 Tela Botanica <accueil@tela-botanica.org>
20
 * @copyright  1999-2014 Tela Botanica <accueil@tela-botanica.org>
21
 */
21
 */
22
 
22
 
23
//restore_error_handler();
23
//restore_error_handler();
24
//restore_exception_handler();
24
//restore_exception_handler();
25
//error_reporting(E_ALL);
25
//error_reporting(E_ALL);
26
class ListeImages {
26
class ListeImages {
27
 
27
 
28
	private $ressources = array();
28
	private $ressources = array();
29
	private $parametres = array();
29
	private $parametres = array();
30
	private $conteneur;
30
	private $conteneur;
31
	private $bdd;
31
	private $bdd;
32
	private $filtrage;
32
	private $filtrage;
33
	private $sql;
33
	private $sql;
34
	private $navigation;
34
	private $navigation;
35
	private $paramsFiltres = array();
35
	private $paramsFiltres = array();
36
	private $mappings = array();
36
	private $mappings = array();
37
 
37
 
38
	public function __construct(Conteneur $conteneur) {
38
	public function __construct(Conteneur $conteneur) {
39
		$this->conteneur = $conteneur;
39
		$this->conteneur = $conteneur;
40
		$this->bdd = $this->conteneur->getBdd();
40
		$this->bdd = $this->conteneur->getBdd();
41
		$this->filtrage = $this->conteneur->getParametresFiltrage();
41
		$this->filtrage = $this->conteneur->getParametresFiltrage();
42
		$this->sql = $this->conteneur->getSql();
42
		$this->sql = $this->conteneur->getSql();
43
		$this->navigation = $this->conteneur->getNavigation();
43
		$this->navigation = $this->conteneur->getNavigation();
44
 
44
 
45
		$this->mappings['observations'] = $this->conteneur->getParametreTableau('observations.mapping');
45
		$this->mappings['observations'] = $this->conteneur->getParametreTableau('observations.mapping');
46
		$this->mappings['images'] = $this->conteneur->getParametreTableau('images.mapping');
46
		$this->mappings['images'] = $this->conteneur->getParametreTableau('images.mapping');
47
	}
47
	}
48
 
48
 
49
	public function consulter($ressources, $parametres) {
49
	public function consulter($ressources, $parametres) {
50
		$this->ressources = $ressources;
50
		$this->ressources = $ressources;
51
		$this->parametres = $parametres;
51
		$this->parametres = $parametres;
52
 
52
 
53
		$this->paramsFiltres = $this->filtrage->filtrerUrlParamsAppliImg();
53
		$this->paramsFiltres = $this->filtrage->filtrerUrlParamsAppliImg();
54
		$this->sql->setParametres($this->paramsFiltres);
54
		$this->sql->setParametres($this->paramsFiltres);
55
		$this->sql->ajouterContraintes();
55
		$this->sql->ajouterContraintes();
56
		$this->sql->ajouterConstrainteAppliImg();
56
		$this->sql->ajouterConstrainteAppliImg();
57
		$this->sql->definirOrdreSqlAppliImg();
57
		$this->sql->definirOrdreSqlAppliImg();
58
 
58
 
59
		$idImgs = $this->getIdImages();
59
		$idImgs = $this->getIdImages();
60
		$this->navigation->setTotal($this->getTotal());
60
		$this->navigation->setTotal($this->sql->getTotalLignesTrouvees());
61
 
61
 
62
		// Ce n'est pas la peine de continuer s'il n'y a pas eu de résultats
62
		// Ce n'est pas la peine de continuer s'il n'y a pas eu de résultats
63
		$resultat = new ResultatService();
63
		$resultat = new ResultatService();
64
		$resultat->corps = array('entete' => $this->navigation->getEntete(), 'resultats' => array());
64
		$resultat->corps = array('entete' => $this->navigation->getEntete(), 'resultats' => array());
65
		if (count($idImgs) > 0) {
65
		if (count($idImgs) > 0) {
66
			$liaisons = $this->getInfosImages($idImgs);
66
			$liaisons = $this->getInfosImages($idImgs);
67
			list($images, $images_indexe_par_id_image) = $this->reformaterImagesDoubleIndex($liaisons);
67
			list($images, $images_indexe_par_id_image) = $this->reformaterImagesDoubleIndex($liaisons);
68
 
68
 
69
			// Chargement des votes pour ces images et pour *tous* les protocoles
69
			// Chargement des votes pour ces images et pour *tous* les protocoles
70
			$votes = $this->sql->getVotesDesImages($idImgs);
70
			$votes = $this->sql->getVotesDesImages($idImgs);
71
			if ($votes) {
71
			if ($votes) {
72
				// ATTENTION : $images_indexe_par_id_image est lié par référence à $images !
72
				// ATTENTION : $images_indexe_par_id_image est lié par référence à $images !
73
				$this->sql->ajouterInfosVotesProtocoles($votes, $images_indexe_par_id_image);
73
				$this->sql->ajouterInfosVotesProtocoles($votes, $images_indexe_par_id_image);
74
			}
74
			}
75
 
75
 
76
			$resultat->corps = array(
76
			$resultat->corps = array(
77
				'entete' => $this->navigation->getEntete(),
77
				'entete' => $this->navigation->getEntete(),
78
				'resultats' => $images);
78
				'resultats' => $images);
79
		}
79
		}
80
		return $resultat;
80
		return $resultat;
81
	}
81
	}
82
 
82
 
83
	private function getIdImages() {
83
	private function getIdImages() {
84
		$requete = 'SELECT SQL_CALC_FOUND_ROWS id_image '.
84
		$requete = 'SELECT SQL_CALC_FOUND_ROWS id_image '.
85
			'FROM v_del_image AS vdi '.
85
			'FROM v_del_image AS vdi '.
86
			$this->sql->getJoin().
86
			$this->sql->getJoin().
87
			'WHERE '.$this->sql->getWhere().
87
			'WHERE '.$this->sql->getWhere().
88
			$this->sql->getGroupBy().
88
			$this->sql->getGroupBy().
89
			$this->sql->getOrderBy().
89
			$this->sql->getOrderBy().
90
			$this->sql->getLimit().
90
			$this->sql->getLimit().
91
			' -- '.__FILE__.':'.__LINE__;
91
			' -- '.__FILE__.':'.__LINE__;
92
 
92
 
93
		$resultats = $this->bdd->recupererTous($requete);
93
		$resultats = $this->bdd->recupererTous($requete);
94
		$idImgs = array();
94
		$idImgs = array();
95
		if ($resultats !== false ) {
95
		if ($resultats !== false ) {
96
			foreach ($resultats as $resultat) {
96
			foreach ($resultats as $resultat) {
97
				$idImgs[] = $resultat['id_image'];
97
				$idImgs[] = $resultat['id_image'];
98
			}
98
			}
99
		}
99
		}
100
		return $idImgs;
100
		return $idImgs;
101
	}
101
	}
102
 
-
 
103
	private function getTotal() {
-
 
104
		$resultat = $this->bdd->recuperer('SELECT FOUND_ROWS() AS nbre');
-
 
105
		return intval($resultat['nbre']);
-
 
106
	}
-
 
107
 
102
 
108
	private function getInfosImages($idImgs) {
103
	private function getInfosImages($idImgs) {
109
		$obsChamps = $this->sql->getAliasDesChamps($this->mappings['observations']);
104
		$obsChamps = $this->sql->getAliasDesChamps($this->mappings['observations']);
110
		$imgChamps = $this->sql->getAliasDesChamps($this->mappings['images']);
105
		$imgChamps = $this->sql->getAliasDesChamps($this->mappings['images']);
111
		$idImgsConcat = implode(',', $idImgs);
106
		$idImgsConcat = implode(',', $idImgs);
112
 
107
 
113
		$requete = "SELECT CONCAT(id_image, '-', id_observation) AS jsonindex, $obsChamps, $imgChamps ".
108
		$requete = "SELECT CONCAT(id_image, '-', id_observation) AS jsonindex, $obsChamps, $imgChamps ".
114
			'FROM v_del_image '.
109
			'FROM v_del_image '.
115
			"WHERE id_image IN ($idImgsConcat) ".
110
			"WHERE id_image IN ($idImgsConcat) ".
116
			"ORDER BY FIELD(id_image, $idImgsConcat) ". // important car MySQL ne conserve par l'ordre du IN()
111
			"ORDER BY FIELD(id_image, $idImgsConcat) ". // important car MySQL ne conserve par l'ordre du IN()
117
			'-- '.__FILE__.':'.__LINE__;
112
			'-- '.__FILE__.':'.__LINE__;
118
 
113
 
119
		return $this->bdd->recupererTous($requete);
114
		return $this->bdd->recupererTous($requete);
120
	}
115
	}
121
 
116
 
122
	// cf Observation::reformateObservationSimpleIndex() et ListeObservations::reformateObservation()
117
	// cf Observation::reformateObservationSimpleIndex() et ListeObservations::reformateObservation()
123
	// (trop de variétés de formatage, à unifier côté client pour unifier côté backend ...)
118
	// (trop de variétés de formatage, à unifier côté client pour unifier côté backend ...)
124
	private function reformaterImagesDoubleIndex($imagesInfos) {
119
	private function reformaterImagesDoubleIndex($imagesInfos) {
125
		$urlImgTpl = $this->conteneur->getParametre('cel_img_url_tpl');
120
		$urlImgTpl = $this->conteneur->getParametre('cel_img_url_tpl');
126
		$imageFormat = isset($this->paramsFiltres['format']) ? $this->paramsFiltres['format'] : 'XL';
121
		$imageFormat = isset($this->paramsFiltres['format']) ? $this->paramsFiltres['format'] : 'XL';
127
		$obs_merged = $obs_keyed_by_id_image = array();
122
		$obs_merged = $obs_keyed_by_id_image = array();
128
		foreach ($imagesInfos as $infos) {
123
		foreach ($imagesInfos as $infos) {
129
			// ceci nous complique la tâche pour le reste du processing...
124
			// ceci nous complique la tâche pour le reste du processing...
130
			$id = $infos['jsonindex'];
125
			$id = $infos['jsonindex'];
131
			// ainsi nous utilisons deux tableaux: le final, indexé par couple d'id(image-obs)
126
			// ainsi nous utilisons deux tableaux: le final, indexé par couple d'id(image-obs)
132
			// et celui indexé par simple id_image qui est fort utile pour mapVotesToImages()
127
			// et celui indexé par simple id_image qui est fort utile pour mapVotesToImages()
133
			// mais tout deux partage leur référence à "protocole"
128
			// mais tout deux partage leur référence à "protocole"
134
			$image = array(
129
			$image = array(
135
				'id_image' => $infos['id_image'],
130
				'id_image' => $infos['id_image'],
136
				'binaire.href' => sprintf($urlImgTpl, $infos['id_image'], $imageFormat),
131
				'binaire.href' => sprintf($urlImgTpl, $infos['id_image'], $imageFormat),
137
				'mots_cles_texte' => @$infos['mots_cles_texte_img'], // @, peut avoir été filtré par array_map() ci-dessus
132
				'mots_cles_texte' => @$infos['mots_cles_texte_img'], // @, peut avoir été filtré par array_map() ci-dessus
138
			);
133
			);
139
			
134
 
140
			unset($infos['id_image'], $infos['mots_cles_texte_img'], $infos['jsonindex']);
135
			unset($infos['id_image'], $infos['mots_cles_texte_img'], $infos['jsonindex']);
141
			if (!isset($obs_merged[$id])) {
136
			if (!isset($obs_merged[$id])) {
142
				$obs_merged[$id] = $image;
137
				$obs_merged[$id] = $image;
143
			}
138
			}
144
			$obs_merged[$id]['observation'] = $infos;
139
			$obs_merged[$id]['observation'] = $infos;
145
			$obs_merged[$id]['protocoles_votes'] = array();
140
			$obs_merged[$id]['protocoles_votes'] = array();
146
 
141
 
147
			$obs_keyed_by_id_image[$image['id_image']]['protocoles_votes'] =& $obs_merged[$id]['protocoles_votes'];
142
			$obs_keyed_by_id_image[$image['id_image']]['protocoles_votes'] =& $obs_merged[$id]['protocoles_votes'];
148
		}
143
		}
149
 
144
 
150
		return array($obs_merged, $obs_keyed_by_id_image);
145
		return array($obs_merged, $obs_keyed_by_id_image);
151
	}
146
	}
152
 
147
 
153
	/**
148
	/**
154
	 * Supprime une image directement dans le CEL en faisant un appel à un web service du CEL.
149
	 * Supprime une image directement dans le CEL en faisant un appel à un web service du CEL.
155
	 * Utilisé uniquement par les admins.
150
	 * Utilisé uniquement par les admins.
156
	 *
151
	 *
157
	 * @param array		$ressources tableau des informations contenues dans l'url après le nom du service
152
	 * @param array		$ressources tableau des informations contenues dans l'url après le nom du service
158
	 * @param array		$parametres contenu du post
153
	 * @param array		$parametres contenu du post
159
	 * @return mixed	Chaine "OK" (en majuscule) en cas de succès, booléen "false" en cas d'échec
154
	 * @return mixed	Chaine "OK" (en majuscule) en cas de succès, booléen "false" en cas d'échec
160
	 */
155
	 */
161
	public function supprimer($ressources) {
156
	public function supprimer($ressources) {
162
		$controlAcces = $this->conteneur->getControleAcces();
157
		$controlAcces = $this->conteneur->getControleAcces();
163
		$controlAcces->etreUtilisateurAvecDroitAdmin();
158
		$controlAcces->etreUtilisateurAvecDroitAdmin();
164
 
159
 
165
		$urlServiceBase = $this->conteneur->getParametre('urlServiceCelImage');
160
		$urlServiceBase = $this->conteneur->getParametre('urlServiceCelImage');
166
		$idImage = $ressources[0];
161
		$idImage = $ressources[0];
167
		$url = $urlServiceBase.$idImage;
162
		$url = $urlServiceBase.$idImage;
168
 
163
 
169
		$clientHttp = $this->conteneur->getRestClient();
164
		$clientHttp = $this->conteneur->getRestClient();
170
		$retourCel = $clientHttp->supprimer($url);
165
		$retourCel = $clientHttp->supprimer($url);
171
		$retour = preg_match('/^OK$/i', $retourCel) ? 'OK' : false;
166
		$retour = preg_match('/^OK$/i', $retourCel) ? 'OK' : false;
172
		return $retour;
167
		return $retour;
173
	}
168
	}
174
}
169
}