Subversion Repositories eFlore/Applications.del

Rev

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

Rev 1871 Rev 1881
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 $conteneur;
28
	private $conteneur;
29
	private $bdd;
29
	private $bdd;
30
	private $filtrage;
30
	private $filtrage;
31
	private $sql;
31
	private $sql;
32
	private $navigation;
32
	private $navigation;
33
	private $paramsFiltres = array();
33
	private $paramsFiltres = array();
34
	private $mappings = array();
34
	private $mappings = array();
35
	private $idsImagesOrdonnees = array();
35
	private $idsImagesOrdonnees = array();
-
 
36
	private $infosImages = array();
36
	private $infosImagesOrdonnees = array();
37
	private $infosImagesOrdonnees = array();
37
 
38
 
38
	public function __construct(Conteneur $conteneur) {
39
	public function __construct(Conteneur $conteneur) {
39
		$this->conteneur = $conteneur;
40
		$this->conteneur = $conteneur;
40
		$this->bdd = $this->conteneur->getBdd();
41
		$this->bdd = $this->conteneur->getBdd();
41
		$this->filtrage = $this->conteneur->getParametresFiltrage();
42
		$this->filtrage = $this->conteneur->getParametresFiltrage();
42
		$this->sql = $this->conteneur->getSql();
43
		$this->sql = $this->conteneur->getSql();
43
		$this->navigation = $this->conteneur->getNavigation();
44
		$this->navigation = $this->conteneur->getNavigation();
44
 
45
 
45
		$this->mappings['observations'] = $this->conteneur->getParametreTableau('observations.mapping');
46
		$this->mappings['observations'] = $this->conteneur->getParametreTableau('observations.mapping');
46
		$this->mappings['images'] = $this->conteneur->getParametreTableau('images.mapping');
47
		$this->mappings['images'] = $this->conteneur->getParametreTableau('images.mapping');
47
	}
48
	}
48
 
49
 
49
	public function consulter($ressources, $parametres) {
50
	public function consulter($ressources, $parametres) {
50
		$this->paramsFiltres = $this->filtrage->filtrerUrlParamsAppliImg();
51
		$this->paramsFiltres = $this->filtrage->filtrerUrlParamsAppliImg();
51
		$this->sql->setAppli(Sql::APPLI_IMG);
52
		$this->sql->setAppli(Sql::APPLI_IMG);
52
		$this->sql->setParametres($this->paramsFiltres);
53
		$this->sql->setParametres($this->paramsFiltres);
53
		$this->sql->ajouterContraintes();
54
		$this->sql->ajouterContraintes();
54
		$this->sql->ajouterConstrainteAppliImg();
55
		$this->sql->ajouterConstrainteAppliImg();
55
		$this->sql->definirOrdreSqlAppliImg();
56
		$this->sql->definirOrdreSqlAppliImg();
56
 
57
 
57
		$this->idsImagesOrdonnees = $this->getIdImages();
58
		$this->idsImagesOrdonnees = $this->getIdImages();
58
		$this->navigation->setTotal($this->sql->getTotalLignesTrouvees());
59
		$this->navigation->setTotal($this->sql->getTotalLignesTrouvees());
59
 
60
 
60
		// Ce n'est pas la peine de continuer s'il n'y a pas eu de résultats
61
		// Ce n'est pas la peine de continuer s'il n'y a pas eu de résultats
61
		$resultat = new ResultatService();
62
		$resultat = new ResultatService();
62
		$resultat->corps = array('entete' => $this->navigation->getEntete(), 'resultats' => array());
63
		$resultat->corps = array('entete' => $this->navigation->getEntete(), 'resultats' => array());
63
		if (count($this->idsImagesOrdonnees) > 0) {
64
		if (count($this->idsImagesOrdonnees) > 0) {
64
			$this->infosImagesOrdonnees = $this->getInfosImages();
65
			$this->infosImages = $this->getInfosImages();
65
			$images = $this->reformaterImagesDoubleIndex();
66
			$this->infosImagesOrdonnees = $this->formaterImages();
66
 
67
 
67
			// Chargement des votes pour ces images et pour *tous* les protocoles
68
			// Chargement des votes pour ces images et pour *tous* les protocoles
68
			$votes = $this->sql->getVotesDesImages($this->idsImagesOrdonnees);
69
			$votes = $this->sql->getVotesDesImages($this->idsImagesOrdonnees);
69
			if ($votes) {
70
			if ($votes) {
70
				// ATTENTION : $images est récupéré par référence !
71
				// ATTENTION : $images est récupéré par référence !
71
				$this->sql->ajouterInfosVotesProtocoles($votes, $images);
72
				$this->sql->ajouterInfosVotesProtocoles($votes, $this->infosImagesOrdonnees);
72
			}
73
			}
73
 
74
 
74
			$resultat->corps = array(
75
			$resultat->corps = array(
75
				'entete' => $this->navigation->getEntete(),
76
				'entete' => $this->navigation->getEntete(),
76
				'resultats' => array_values($images));
77
				'resultats' => array_values($this->infosImagesOrdonnees));
77
		}
78
		}
78
		return $resultat;
79
		return $resultat;
79
	}
80
	}
80
 
81
 
81
	private function getIdImages() {
82
	private function getIdImages() {
82
		$requete = 'SELECT SQL_CALC_FOUND_ROWS id_image '.
83
		$requete = 'SELECT SQL_CALC_FOUND_ROWS id_image '.
83
			'FROM del_image AS di '.
84
			'FROM del_image AS di '.
84
			$this->sql->getJoin().
85
			$this->sql->getJoin().
85
			'WHERE '.$this->sql->getWhere().
86
			'WHERE '.$this->sql->getWhere().
86
			$this->sql->getGroupBy().
87
			$this->sql->getGroupBy().
87
			$this->sql->getOrderBy().
88
			$this->sql->getOrderBy().
88
			$this->sql->getLimit().
89
			$this->sql->getLimit().
89
			' -- '.__FILE__.':'.__LINE__;
90
			' -- '.__FILE__.':'.__LINE__;
90
		//Debug::printr($requete);
91
		//Debug::printr($requete);
91
		$resultats = $this->bdd->recupererTous($requete);
92
		$resultats = $this->bdd->recupererTous($requete);
92
		$idImgs = array();
93
		$idImgs = array();
93
		if ($resultats !== false ) {
94
		if ($resultats !== false ) {
94
			foreach ($resultats as $resultat) {
95
			foreach ($resultats as $resultat) {
95
				$idImgs[] = $resultat['id_image'];
96
				$idImgs[] = $resultat['id_image'];
96
			}
97
			}
97
		}
98
		}
98
		return $idImgs;
99
		return $idImgs;
99
	}
100
	}
100
 
101
 
101
	private function getInfosImages() {
102
	private function getInfosImages() {
102
		$obsChamps = $this->sql->getAliasDesChamps($this->mappings['observations'], null, 'do');
103
		$obsChamps = $this->sql->getAliasDesChamps($this->mappings['observations'], null, 'do');
103
		$imgChamps = $this->sql->getAliasDesChamps($this->mappings['images'], null, 'di');
104
		$imgChamps = $this->sql->getAliasDesChamps($this->mappings['images'], null, 'di');
104
		$idImgsConcat = implode(',', $this->idsImagesOrdonnees);
105
		$idImgsConcat = implode(',', $this->idsImagesOrdonnees);
105
 
106
 
106
		$requete = "SELECT $obsChamps, $imgChamps ".
107
		$requete = "SELECT $obsChamps, $imgChamps ".
107
			'FROM del_image AS di '.
108
			'FROM del_image AS di '.
108
			'	LEFT JOIN del_observation AS do ON (di.ce_observation = do.id_observation) '.
109
			'	LEFT JOIN del_observation AS do ON (di.ce_observation = do.id_observation) '.
109
			"WHERE di.id_image IN ($idImgsConcat) ".
110
			"WHERE di.id_image IN ($idImgsConcat) ".
110
			'-- '.__FILE__.':'.__LINE__;
111
			'-- '.__FILE__.':'.__LINE__;
111
		//Debug::printr($requete);
112
		//Debug::printr($requete);
112
		return $this->bdd->recupererTous($requete);
113
		return $this->bdd->recupererTous($requete);
113
	}
114
	}
114
 
115
 
115
	// cf Observation::reformateObservationSimpleIndex() et ListeObservations::reformateObservation()
116
	// cf Observation::reformateObservationSimpleIndex() et ListeObservations::reformateObservation()
116
	// (trop de variétés de formatage, à unifier côté client pour unifier côté backend ...)
117
	// (trop de variétés de formatage, à unifier côté client pour unifier côté backend ...)
117
	private function reformaterImagesDoubleIndex() {
118
	private function formaterImages() {
118
		$urlImgTpl = $this->conteneur->getParametre('cel_img_url_tpl');
119
		$urlImgTpl = $this->conteneur->getParametre('cel_img_url_tpl');
119
		$imageFormat = isset($this->paramsFiltres['format']) ? $this->paramsFiltres['format'] : 'XL';
120
		$imageFormat = isset($this->paramsFiltres['format']) ? $this->paramsFiltres['format'] : 'XL';
120
		$obs_merged = array_flip($this->idsImagesOrdonnees);
121
		$obsFormatees = array_flip($this->idsImagesOrdonnees);// Permet de garder l'ordre de sortie !
121
		foreach ($this->infosImagesOrdonnees as $infos) {
122
		foreach ($this->infosImages as $infos) {
122
			$id = $infos['id_image'];
123
			$id = $infos['id_image'];
123
			// ainsi nous utilisons deux tableaux: le final, indexé par couple d'id(image-obs)
124
			// ainsi nous utilisons deux tableaux: le final, indexé par couple d'id(image-obs)
124
			// et celui indexé par simple id_image qui est fort utile pour mapVotesToImages()
125
			// et celui indexé par simple id_image qui est fort utile pour mapVotesToImages()
125
			// mais tout deux partage leur référence à "protocole"
126
			// mais tout deux partage leur référence à "protocole"
126
			$image = array(
127
			$image = array(
127
				'id_image' => $id,
128
				'id_image' => $id,
128
				'binaire.href' => sprintf($urlImgTpl, $infos['id_image'], $imageFormat),
129
				'binaire.href' => sprintf($urlImgTpl, $infos['id_image'], $imageFormat),
129
				'mots_cles_texte' => isset($infos['mots_cles_texte']) ? $infos['mots_cles_texte'] : null,
130
				'mots_cles_texte' => isset($infos['mots_cles_texte']) ? $infos['mots_cles_texte'] : null,
130
			);
131
			);
131
			unset($infos['id_image'], $infos['mots_cles_texte']);
132
			unset($infos['id_image'], $infos['mots_cles_texte']);
132
 
133
 
133
			$obs_merged[$id] = $image;
134
			$obsFormatees[$id] = $image;
134
			$obs_merged[$id]['observation'] = $infos;
135
			$obsFormatees[$id]['observation'] = $infos;
135
			$obs_merged[$id]['protocoles_votes'] = array();
136
			$obsFormatees[$id]['protocoles_votes'] = array();
136
		}
137
		}
137
		return $obs_merged;
138
		return $obsFormatees;
138
	}
139
	}
139
 
140
 
140
	/**
141
	/**
141
	 * Supprime une image directement dans le CEL en faisant un appel à un web service du CEL.
142
	 * Supprime une image directement dans le CEL en faisant un appel à un web service du CEL.
142
	 * Utilisé uniquement par les admins.
143
	 * Utilisé uniquement par les admins.
143
	 *
144
	 *
144
	 * @param array		$ressources tableau des informations contenues dans l'url après le nom du service
145
	 * @param array		$ressources tableau des informations contenues dans l'url après le nom du service
145
	 * @param array		$parametres contenu du post
146
	 * @param array		$parametres contenu du post
146
	 * @return mixed	Chaine "OK" (en majuscule) en cas de succès, booléen "false" en cas d'échec
147
	 * @return mixed	Chaine "OK" (en majuscule) en cas de succès, booléen "false" en cas d'échec
147
	 */
148
	 */
148
	public function supprimer($ressources) {
149
	public function supprimer($ressources) {
149
		$controlAcces = $this->conteneur->getControleAcces();
150
		$controlAcces = $this->conteneur->getControleAcces();
150
		$controlAcces->etreUtilisateurAvecDroitAdmin();
151
		$controlAcces->etreUtilisateurAvecDroitAdmin();
151
 
152
 
152
		$urlServiceBase = $this->conteneur->getParametre('urlServiceCelImage');
153
		$urlServiceBase = $this->conteneur->getParametre('urlServiceCelImage');
153
		$idImage = $ressources[0];
154
		$idImage = $ressources[0];
154
		$url = $urlServiceBase.$idImage;
155
		$url = $urlServiceBase.$idImage;
155
 
156
 
156
		$clientHttp = $this->conteneur->getRestClient();
157
		$clientHttp = $this->conteneur->getRestClient();
157
		$retourCel = $clientHttp->supprimer($url);
158
		$retourCel = $clientHttp->supprimer($url);
158
		$retour = preg_match('/^OK$/i', $retourCel) ? 'OK' : false;
159
		$retour = preg_match('/^OK$/i', $retourCel) ? 'OK' : false;
159
		return $retour;
160
		return $retour;
160
	}
161
	}
161
}
162
}