1 |
<?php
|
1 |
<?php
|
2 |
// declare(encoding='UTF-8');
|
2 |
// declare(encoding='UTF-8');
|
3 |
/**
|
3 |
/**
|
4 |
* Web service récupèrant toutes les observations et, pour chacune d'elle, les images qui lui sont associées.
|
4 |
* Web service récupèrant toutes les observations et, pour chacune d'elle, les images qui lui sont associées.
|
5 |
*
|
5 |
*
|
6 |
* ATTENTION : le web service commence par récupérer seulement les id des obs (1er requete SQL), puis dans une
|
6 |
* ATTENTION : le web service commence par récupérer seulement les id des obs (1er requete SQL), puis dans une
|
7 |
* deuxième requête SQL récupère les informations complémentaires. Il s'avère qu'en procédant ainsi le web service
|
7 |
* deuxième requête SQL récupère les informations complémentaires. Il s'avère qu'en procédant ainsi le web service
|
8 |
* est 3 fois plus rapide !
|
8 |
* est 3 fois plus rapide !
|
9 |
*
|
9 |
*
|
10 |
* @category DEL
|
10 |
* @category DEL
|
11 |
* @package Services
|
11 |
* @package Services
|
12 |
* @subpackage Observations
|
12 |
* @subpackage Observations
|
13 |
* @version 0.1
|
13 |
* @version 0.1
|
14 |
* @author Mathias CHOUET <mathias@tela-botanica.org>
|
14 |
* @author Mathias CHOUET <mathias@tela-botanica.org>
|
15 |
* @author Jean-Pascal MILCENT <jpm@tela-botanica.org>
|
15 |
* @author Jean-Pascal MILCENT <jpm@tela-botanica.org>
|
16 |
* @author Aurelien PERONNET <aurelien@tela-botanica.org>
|
16 |
* @author Aurelien PERONNET <aurelien@tela-botanica.org>
|
17 |
* @license GPL v3 <http://www.gnu.org/licenses/gpl.txt>
|
17 |
* @license GPL v3 <http://www.gnu.org/licenses/gpl.txt>
|
18 |
* @license CECILL v2 <http://www.cecill.info/licences/Licence_CeCILL_V2-en.txt>
|
18 |
* @license CECILL v2 <http://www.cecill.info/licences/Licence_CeCILL_V2-en.txt>
|
19 |
* @copyright 1999-2014 Tela Botanica <accueil@tela-botanica.org>
|
19 |
* @copyright 1999-2014 Tela Botanica <accueil@tela-botanica.org>
|
20 |
*/
|
20 |
*/
|
21 |
class ListeObservations {
|
21 |
class ListeObservations {
|
22 |
|
22 |
|
23 |
private $conteneur;
|
23 |
private $conteneur;
|
24 |
private $bdd;
|
24 |
private $bdd;
|
25 |
private $navigation;
|
25 |
private $navigation;
|
26 |
private $filtrage;
|
26 |
private $filtrage;
|
27 |
private $sql;
|
27 |
private $sql;
|
28 |
|
28 |
|
29 |
private $mappings = array();
|
29 |
private $mappings = array();
|
30 |
private $paramsFiltres = array();
|
30 |
private $paramsFiltres = array();
|
31 |
|
31 |
|
32 |
private $idsObsOrdonnees = array();
|
32 |
private $idsObsOrdonnees = array();
|
33 |
private $infosObs = array();
|
33 |
private $infosObs = array();
|
34 |
private $infosObsOrdonnee = array();
|
34 |
private $infosObsOrdonnee = array();
|
35 |
|
35 |
|
36 |
|
36 |
|
37 |
public function __construct(Conteneur $conteneur) {
|
37 |
public function __construct(Conteneur $conteneur) {
|
38 |
$this->conteneur = $conteneur;
|
38 |
$this->conteneur = $conteneur;
|
39 |
$this->conteneur->chargerConfiguration('config_departements_bruts.ini');
|
39 |
$this->conteneur->chargerConfiguration('config_departements_bruts.ini');
|
40 |
|
40 |
|
41 |
$this->bdd = $this->conteneur->getBdd();
|
41 |
$this->bdd = $this->conteneur->getBdd();
|
42 |
$this->filtrage = $this->conteneur->getParametresFiltrage();
|
42 |
$this->filtrage = $this->conteneur->getParametresFiltrage();
|
43 |
$this->sql = $this->conteneur->getSql();
|
43 |
$this->sql = $this->conteneur->getSql();
|
44 |
$this->navigation = $this->conteneur->getNavigation();
|
44 |
$this->navigation = $this->conteneur->getNavigation();
|
45 |
|
45 |
|
46 |
$this->mappings['votes'] = $this->conteneur->getParametreTableau('votes.mapping');
|
46 |
$this->mappings['votes'] = $this->conteneur->getParametreTableau('votes.mapping');
|
47 |
$this->mappings['commentaires'] = $this->conteneur->getParametreTableau('commentaires.mapping');
|
47 |
$this->mappings['commentaires'] = $this->conteneur->getParametreTableau('commentaires.mapping');
|
48 |
}
|
48 |
}
|
49 |
|
49 |
|
50 |
public function consulter($ressources, $parametres) {
|
50 |
public function consulter($ressources, $parametres) {
|
51 |
$this->paramsFiltres = $this->filtrage->filtrerUrlParamsAppliObs();
|
51 |
$this->paramsFiltres = $this->filtrage->filtrerUrlParamsAppliObs();
|
52 |
$this->sql->setAppli(Sql::APPLI_OBS);
|
52 |
$this->sql->setAppli(Sql::APPLI_OBS);
|
53 |
$this->sql->setParametres($this->paramsFiltres);
|
53 |
$this->sql->setParametres($this->paramsFiltres);
|
54 |
$this->sql->ajouterContraintes();
|
54 |
$this->sql->ajouterContraintes();
|
55 |
$this->sql->ajouterConstrainteAppliObs();
|
55 |
$this->sql->ajouterConstrainteAppliObs();
|
56 |
$this->sql->definirOrdreSqlAppliObs();
|
56 |
$this->sql->definirOrdreSqlAppliObs();
|
57 |
|
57 |
|
58 |
$this->idsObsOrdonnees = $this->getIdObs();
|
58 |
$this->idsObsOrdonnees = $this->getIdObs();
|
59 |
$this->navigation->setTotal($this->sql->getTotalLignesTrouvees());
|
59 |
$this->navigation->setTotal($this->sql->getTotalLignesTrouvees());
|
60 |
|
60 |
|
61 |
// 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
|
62 |
$resultat = new ResultatService();
|
62 |
$resultat = new ResultatService();
|
63 |
$resultat->corps = array('entete' => $this->navigation->getEntete(), 'resultats' => array());
|
63 |
$resultat->corps = array('entete' => $this->navigation->getEntete(), 'resultats' => array());
|
64 |
if (count($this->idsObsOrdonnees) > 0) {
|
64 |
if (count($this->idsObsOrdonnees) > 0) {
|
65 |
|
65 |
|
66 |
// 2) récupération des données nécessaires pour ces observations (obs + images)
|
66 |
// 2) récupération des données nécessaires pour ces observations (obs + images)
|
67 |
$this->infosObs = $this->getInfosObs();
|
67 |
$this->infosObs = $this->getInfosObs();
|
68 |
// 3) suppression, merge des données en tableau assez représentatif du futur JSON en output
|
68 |
// 3) suppression, merge des données en tableau assez représentatif du futur JSON en output
|
69 |
$this->infosObsOrdonnees = $this->formaterObservations();
|
69 |
$this->infosObsOrdonnees = $this->formaterObservations();
|
70 |
// 4) Ajouter commentaires + votes à $this->infosObsOrdonnees
|
70 |
// 4) Ajouter commentaires + votes à $this->infosObsOrdonnees
|
71 |
$this->chargerDeterminations();
|
71 |
$this->chargerDeterminations();
|
72 |
|
72 |
|
73 |
$resultat->corps = array(
|
73 |
$resultat->corps = array(
|
74 |
'entete' => $this->navigation->getEntete(),
|
74 |
'entete' => $this->navigation->getEntete(),
|
75 |
// 5) Applatissage du tableau afin de garder l'ordre de tri
|
75 |
// 5) Applatissage du tableau afin de garder l'ordre de tri
|
76 |
// (qui n'est pas garanti dans un objet json)
|
76 |
// (qui n'est pas garanti dans un objet json)
|
77 |
'resultats' => array_values($this->infosObsOrdonnees));
|
77 |
'resultats' => array_values($this->infosObsOrdonnees));
|
78 |
}
|
78 |
}
|
79 |
return $resultat;
|
79 |
return $resultat;
|
80 |
}
|
80 |
}
|
81 |
|
81 |
|
82 |
// SQL helpers
|
82 |
// SQL helpers
|
83 |
/*
|
83 |
/*
|
84 |
* Retourne une liste ordonnée d'id d'observation correspondant aux critères
|
84 |
* Retourne une liste ordonnée d'id d'observation correspondant aux critères
|
85 |
* passés dans p et aux clauses where/join présentes dans le tableau $req
|
85 |
* passés dans p et aux clauses where/join présentes dans le tableau $req
|
86 |
*
|
86 |
*
|
87 |
* @param p: $params (filtrés sauf escape-string)
|
87 |
* @param p: $params (filtrés sauf escape-string)
|
88 |
* @param req: le tableau représentant les composants de la requete SQL
|
88 |
* @param req: le tableau représentant les composants de la requete SQL
|
89 |
* @param db: l'instance de db
|
89 |
* @param db: l'instance de db
|
90 |
*/
|
90 |
*/
|
91 |
private function getIdObs() {
|
91 |
private function getIdObs() {
|
92 |
$requete = 'SELECT SQL_CALC_FOUND_ROWS id_observation '.
|
92 |
$requete = 'SELECT SQL_CALC_FOUND_ROWS id_observation '.
|
93 |
'FROM del_observation AS do '.
|
93 |
'FROM del_observation AS do '.
|
94 |
$this->sql->getJoin().
|
94 |
$this->sql->getJoin().
|
95 |
'WHERE '.$this->sql->getWhere().
|
95 |
'WHERE '.$this->sql->getWhere().
|
96 |
$this->sql->getGroupBy().
|
96 |
$this->sql->getGroupBy().
|
97 |
$this->sql->getOrderBy().
|
97 |
$this->sql->getOrderBy().
|
98 |
$this->sql->getLimit().
|
98 |
$this->sql->getLimit().
|
99 |
' -- '.__FILE__.':'.__LINE__;
|
99 |
' -- '.__FILE__.':'.__LINE__;
|
100 |
//Debug::printr($requete);
|
100 |
//Debug::printr($requete);
|
101 |
$resultats = $this->bdd->recupererTous($requete);
|
101 |
$resultats = $this->bdd->recupererTous($requete);
|
102 |
|
102 |
|
103 |
$idObs = array();
|
103 |
$idObs = array();
|
104 |
if ($resultats !== false ) {
|
104 |
if ($resultats !== false ) {
|
105 |
foreach ($resultats as $resultat) {
|
105 |
foreach ($resultats as $resultat) {
|
106 |
$idObs[] = $resultat['id_observation'];
|
106 |
$idObs[] = $resultat['id_observation'];
|
107 |
}
|
107 |
}
|
108 |
}
|
108 |
}
|
109 |
return $idObs;
|
109 |
return $idObs;
|
110 |
}
|
110 |
}
|
111 |
|
111 |
|
112 |
/**
|
112 |
/**
|
113 |
* Après avoir récupérer seulement les ids dans une première requête, nous récupérons maintenant les infos.
|
113 |
* Après avoir récupérer seulement les ids dans une première requête, nous récupérons maintenant les infos.
|
114 |
* Le web service est ainsi 3 fois plus rapide.
|
114 |
* Le web service est ainsi 3 fois plus rapide.
|
115 |
*/
|
115 |
*/
|
116 |
private function getInfosObs() {
|
116 |
private function getInfosObs() {
|
117 |
$idsObsConcat = implode(',', $this->idsObsOrdonnees);
|
117 |
$idsObsConcat = implode(',', $this->idsObsOrdonnees);
|
118 |
$requete = "SELECT id_observation, nom_sel AS `determination.ns`, nt AS `determination.nt`, ".
|
118 |
$requete = "SELECT id_observation, nom_sel AS `determination.ns`, nt AS `determination.nt`, ".
|
119 |
'nom_sel_nn AS `determination.nn`, famille AS `determination.famille`, '.
|
119 |
'nom_sel_nn AS `determination.nn`, famille AS `determination.famille`, '.
|
120 |
'nom_referentiel AS `determination.referentiel`, ce_zone_geo AS id_zone_geo, '.
|
120 |
'nom_referentiel AS `determination.referentiel`, ce_zone_geo AS id_zone_geo, pays, '.
|
121 |
'zone_geo, lieudit, station, milieu, date_observation, do.mots_cles_texte, '.
|
121 |
'zone_geo, lieudit, station, milieu, date_observation, do.mots_cles_texte, '.
|
122 |
'do.date_transmission, do.commentaire, '.
|
122 |
'do.date_transmission, do.commentaire, '.
|
123 |
'do.ce_utilisateur AS `auteur.id`, do.prenom_utilisateur AS `auteur.prenom`, '.
|
123 |
'do.ce_utilisateur AS `auteur.id`, do.prenom_utilisateur AS `auteur.prenom`, '.
|
124 |
'do.nom_utilisateur AS `auteur.nom`, do.courriel_utilisateur AS `auteur.courriel`, '.
|
124 |
'do.nom_utilisateur AS `auteur.nom`, do.courriel_utilisateur AS `auteur.courriel`, '.
|
125 |
'id_image, date_prise_de_vue AS `date`, hauteur, largeur, nom_original '.
|
125 |
'id_image, date_prise_de_vue AS `date`, hauteur, largeur, nom_original '.
|
126 |
'FROM del_observation AS do '.
|
126 |
'FROM del_observation AS do '.
|
127 |
' LEFT JOIN del_image AS di ON (do.id_observation = di.ce_observation) '.
|
127 |
' LEFT JOIN del_image AS di ON (do.id_observation = di.ce_observation) '.
|
128 |
"WHERE id_observation IN ($idsObsConcat) ".
|
128 |
"WHERE id_observation IN ($idsObsConcat) ".
|
129 |
' -- '.__FILE__.':'.__LINE__;
|
129 |
' -- '.__FILE__.':'.__LINE__;
|
130 |
//Debug::printr($requete);
|
130 |
//Debug::printr($requete);
|
131 |
return $this->bdd->recupererTous($requete);
|
131 |
return $this->bdd->recupererTous($requete);
|
132 |
}
|
132 |
}
|
133 |
|
133 |
|
134 |
/**
|
134 |
/**
|
135 |
* Les informations étant extraites d'une vue dont les infos des obs sont dupliquées pour chaque image,
|
135 |
* Les informations étant extraites d'une vue dont les infos des obs sont dupliquées pour chaque image,
|
136 |
* il nous faut maintenant récupérer qu'une seule fois les données d'observations et y intégrer les données
|
136 |
* il nous faut maintenant récupérer qu'une seule fois les données d'observations et y intégrer les données
|
137 |
* des images.
|
137 |
* des images.
|
138 |
*/
|
138 |
*/
|
139 |
private function formaterObservations() {
|
139 |
private function formaterObservations() {
|
140 |
$observations = array_map('array_filter', $this->infosObs);
|
140 |
$observations = array_map('array_filter', $this->infosObs);
|
141 |
$obsFormatees = array_flip($this->idsObsOrdonnees);// Permet de garder l'ordre de sortie !
|
141 |
$obsFormatees = array_flip($this->idsObsOrdonnees);// Permet de garder l'ordre de sortie !
|
142 |
foreach ($observations as &$obs) {
|
142 |
foreach ($observations as &$obs) {
|
143 |
$this->nettoyerAuteur($obs);
|
143 |
$this->nettoyerAuteur($obs);
|
144 |
|
144 |
|
145 |
$id = $obs['id_observation'];
|
145 |
$id = $obs['id_observation'];
|
146 |
// ATTENTION : la requête retourne de nombreuses lignes avec les mêmes données (test de l'existence nécessaire)
|
146 |
// ATTENTION : la requête retourne de nombreuses lignes avec les mêmes données (test de l'existence nécessaire)
|
147 |
if (is_array($obsFormatees[$id]) === false) {
|
147 |
if (is_array($obsFormatees[$id]) === false) {
|
148 |
$obsFormatees[$id] = $obs;
|
148 |
$obsFormatees[$id] = $obs;
|
149 |
}
|
149 |
}
|
150 |
$obsFormatees[$id]['images'][] = $this->extraireInfosImage($obs);
|
150 |
$obsFormatees[$id]['images'][] = $this->extraireInfosImage($obs);
|
151 |
}
|
151 |
}
|
152 |
return $obsFormatees;
|
152 |
return $obsFormatees;
|
153 |
}
|
153 |
}
|
154 |
|
154 |
|
155 |
private function nettoyerAuteur(&$obs) {
|
155 |
private function nettoyerAuteur(&$obs) {
|
156 |
// car auteur.id peut être un email, un hash, ou un annuaire_tela.U_ID
|
156 |
// car auteur.id peut être un email, un hash, ou un annuaire_tela.U_ID
|
157 |
// mais dans les deux premiers cas SELECT courriel AS observateur fait déjà l'affaire
|
157 |
// mais dans les deux premiers cas SELECT courriel AS observateur fait déjà l'affaire
|
158 |
if (!isset($obs['auteur.id']) || !is_numeric($obs['auteur.id'])) {
|
158 |
if (!isset($obs['auteur.id']) || !is_numeric($obs['auteur.id'])) {
|
159 |
$obs['auteur.id'] = "0";
|
159 |
$obs['auteur.id'] = "0";
|
160 |
}
|
160 |
}
|
161 |
if (!isset($obs['auteur.nom'])) {
|
161 |
if (!isset($obs['auteur.nom'])) {
|
162 |
$obs['auteur.nom'] = '[inconnu]';
|
162 |
$obs['auteur.nom'] = '[inconnu]';
|
163 |
}
|
163 |
}
|
164 |
}
|
164 |
}
|
165 |
|
165 |
|
166 |
private function extraireInfosImage(&$obs) {
|
166 |
private function extraireInfosImage(&$obs) {
|
167 |
$champsImageAffichables = array('id_image', 'date', 'hauteur' , 'largeur', 'nom_original');
|
167 |
$champsImageAffichables = array('id_image', 'date', 'hauteur' , 'largeur', 'nom_original');
|
168 |
$image = array_intersect_key($obs, array_flip($champsImageAffichables));
|
168 |
$image = array_intersect_key($obs, array_flip($champsImageAffichables));
|
169 |
$urlImgTpl = $this->conteneur->getParametre('cel_img_url_tpl');
|
169 |
$urlImgTpl = $this->conteneur->getParametre('cel_img_url_tpl');
|
170 |
$image['binaire.href'] = sprintf($urlImgTpl, $image['id_image'], 'XL');
|
170 |
$image['binaire.href'] = sprintf($urlImgTpl, $image['id_image'], 'XL');
|
171 |
|
171 |
|
172 |
unset($obs['id_image'], $obs['date'], $obs['hauteur'], $obs['largeur'], $obs['nom_original']);
|
172 |
unset($obs['id_image'], $obs['date'], $obs['hauteur'], $obs['largeur'], $obs['nom_original']);
|
173 |
return $image;
|
173 |
return $image;
|
174 |
}
|
174 |
}
|
175 |
|
175 |
|
176 |
/**
|
176 |
/**
|
177 |
* Récupérer toutes les déterminations et le nombre de commentaire au total
|
177 |
* Récupérer toutes les déterminations et le nombre de commentaire au total
|
178 |
* @param array $observations la liste des observations à mettre à jour
|
178 |
* @param array $observations la liste des observations à mettre à jour
|
179 |
*/
|
179 |
*/
|
180 |
private function chargerDeterminations() {
|
180 |
private function chargerDeterminations() {
|
181 |
$idObsConcat = implode(',', $this->idsObsOrdonnees);
|
181 |
$idObsConcat = implode(',', $this->idsObsOrdonnees);
|
182 |
$requete = 'SELECT * '.
|
182 |
$requete = 'SELECT * '.
|
183 |
'FROM del_commentaire AS dc '.
|
183 |
'FROM del_commentaire AS dc '.
|
184 |
'WHERE dc.nom_sel IS NOT NULL '.
|
184 |
'WHERE dc.nom_sel IS NOT NULL '.
|
185 |
"AND ce_observation IN ($idObsConcat) ".
|
185 |
"AND ce_observation IN ($idObsConcat) ".
|
186 |
'-- '.__FILE__.':'.__LINE__;
|
186 |
'-- '.__FILE__.':'.__LINE__;
|
187 |
|
187 |
|
188 |
$commentaires = $this->chargerNombreCommentaireObs();
|
188 |
$commentaires = $this->chargerNombreCommentaireObs();
|
189 |
|
189 |
|
190 |
$propositions = $this->bdd->recupererTous($requete);
|
190 |
$propositions = $this->bdd->recupererTous($requete);
|
191 |
if ($propositions) {
|
191 |
if ($propositions) {
|
192 |
foreach ($propositions as $proposition) {
|
192 |
foreach ($propositions as $proposition) {
|
193 |
$idObs = $proposition['ce_observation'];
|
193 |
$idObs = $proposition['ce_observation'];
|
194 |
$idComment = $proposition['id_commentaire'];
|
194 |
$idComment = $proposition['id_commentaire'];
|
195 |
$comment = $this->formaterDetermination($idComment, $proposition);
|
195 |
$comment = $this->formaterDetermination($idComment, $proposition);
|
196 |
if ($comment) {
|
196 |
if ($comment) {
|
197 |
$this->infosObsOrdonnees[$idObs]['commentaires'][$idComment] = $comment;
|
197 |
$this->infosObsOrdonnees[$idObs]['commentaires'][$idComment] = $comment;
|
198 |
}
|
198 |
}
|
199 |
$this->infosObsOrdonnees[$idObs]['nb_commentaires'] = isset($commentaires[$idObs]) ? $commentaires[$idObs] : 0;
|
199 |
$this->infosObsOrdonnees[$idObs]['nb_commentaires'] = isset($commentaires[$idObs]) ? $commentaires[$idObs] : 0;
|
200 |
}
|
200 |
}
|
201 |
}
|
201 |
}
|
202 |
}
|
202 |
}
|
203 |
|
203 |
|
204 |
private function formaterDetermination($propositionId, $propositionInfos) {
|
204 |
private function formaterDetermination($propositionId, $propositionInfos) {
|
205 |
if (!$propositionInfos) return NULL;
|
205 |
if (!$propositionInfos) return NULL;
|
206 |
|
206 |
|
207 |
$propositionFormatee = array();
|
207 |
$propositionFormatee = array();
|
208 |
foreach ($this->mappings['commentaires'] as $nomChamp => $nomAttributJson) {
|
208 |
foreach ($this->mappings['commentaires'] as $nomChamp => $nomAttributJson) {
|
209 |
if (isset($propositionInfos[$nomChamp])) {
|
209 |
if (isset($propositionInfos[$nomChamp])) {
|
210 |
$propositionFormatee[$nomAttributJson] = $propositionInfos[$nomChamp];
|
210 |
$propositionFormatee[$nomAttributJson] = $propositionInfos[$nomChamp];
|
211 |
}
|
211 |
}
|
212 |
}
|
212 |
}
|
213 |
|
213 |
|
214 |
// Charger les votes sur les déterminations
|
214 |
// Charger les votes sur les déterminations
|
215 |
$requete = "SELECT * FROM del_commentaire_vote WHERE ce_proposition = $propositionId".
|
215 |
$requete = "SELECT * FROM del_commentaire_vote WHERE ce_proposition = $propositionId".
|
216 |
'-- '.__FILE__.':'.__LINE__;
|
216 |
'-- '.__FILE__.':'.__LINE__;
|
217 |
$resultatsVotes = $this->bdd->recupererTous($requete);
|
217 |
$resultatsVotes = $this->bdd->recupererTous($requete);
|
218 |
foreach ($resultatsVotes as $vote) {
|
218 |
foreach ($resultatsVotes as $vote) {
|
219 |
$propositionFormatee['votes'][$vote['id_vote']] = $this->formaterVote($vote);
|
219 |
$propositionFormatee['votes'][$vote['id_vote']] = $this->formaterVote($vote);
|
220 |
}
|
220 |
}
|
221 |
|
221 |
|
222 |
$propositionFormatee['nb_commentaires'] = $this->chargerNombreCommentaire($propositionId);
|
222 |
$propositionFormatee['nb_commentaires'] = $this->chargerNombreCommentaire($propositionId);
|
223 |
|
223 |
|
224 |
return $propositionFormatee;
|
224 |
return $propositionFormatee;
|
225 |
}
|
225 |
}
|
226 |
|
226 |
|
227 |
/**
|
227 |
/**
|
228 |
* Formater un vote en fonction du fichier de configuration config_votes.ini
|
228 |
* Formater un vote en fonction du fichier de configuration config_votes.ini
|
229 |
* @param $votes array()
|
229 |
* @param $votes array()
|
230 |
*/
|
230 |
*/
|
231 |
private function formaterVote($vote) {
|
231 |
private function formaterVote($vote) {
|
232 |
$voteFormate = array();
|
232 |
$voteFormate = array();
|
233 |
foreach ($vote as $nomChamp => $valeur) {
|
233 |
foreach ($vote as $nomChamp => $valeur) {
|
234 |
$voteFormate[$this->mappings['votes'][$nomChamp]] = $valeur;
|
234 |
$voteFormate[$this->mappings['votes'][$nomChamp]] = $valeur;
|
235 |
}
|
235 |
}
|
236 |
return $voteFormate;
|
236 |
return $voteFormate;
|
237 |
}
|
237 |
}
|
238 |
|
238 |
|
239 |
private function chargerNombreCommentaireObs() {
|
239 |
private function chargerNombreCommentaireObs() {
|
240 |
$idObsConcat = implode(',', $this->idsObsOrdonnees);
|
240 |
$idObsConcat = implode(',', $this->idsObsOrdonnees);
|
241 |
$requete = 'SELECT ce_observation, COUNT( id_commentaire ) AS nb '.
|
241 |
$requete = 'SELECT ce_observation, COUNT( id_commentaire ) AS nb '.
|
242 |
'FROM del_commentaire '.
|
242 |
'FROM del_commentaire '.
|
243 |
"WHERE ce_observation IN ($idObsConcat) ".
|
243 |
"WHERE ce_observation IN ($idObsConcat) ".
|
244 |
'GROUP BY ce_observation '.
|
244 |
'GROUP BY ce_observation '.
|
245 |
'-- '.__FILE__.':'.__LINE__;
|
245 |
'-- '.__FILE__.':'.__LINE__;
|
246 |
$commentaires = $this->bdd->recupererTous($requete);
|
246 |
$commentaires = $this->bdd->recupererTous($requete);
|
247 |
|
247 |
|
248 |
$commentaires_par_obs = array();
|
248 |
$commentaires_par_obs = array();
|
249 |
foreach($commentaires as $commentaire) {
|
249 |
foreach($commentaires as $commentaire) {
|
250 |
$commentaires_par_obs[$commentaire['ce_observation']] = $commentaire['nb'];
|
250 |
$commentaires_par_obs[$commentaire['ce_observation']] = $commentaire['nb'];
|
251 |
}
|
251 |
}
|
252 |
|
252 |
|
253 |
return $commentaires_par_obs;
|
253 |
return $commentaires_par_obs;
|
254 |
}
|
254 |
}
|
255 |
|
255 |
|
256 |
private function chargerNombreCommentaire($propositionId) {
|
256 |
private function chargerNombreCommentaire($propositionId) {
|
257 |
$requete = 'SELECT COUNT( id_commentaire ) AS nb '.
|
257 |
$requete = 'SELECT COUNT( id_commentaire ) AS nb '.
|
258 |
'FROM del_commentaire '.
|
258 |
'FROM del_commentaire '.
|
259 |
"WHERE ce_proposition = $propositionId ".
|
259 |
"WHERE ce_proposition = $propositionId ".
|
260 |
'GROUP BY ce_proposition '.
|
260 |
'GROUP BY ce_proposition '.
|
261 |
'-- '.__FILE__.':'.__LINE__;
|
261 |
'-- '.__FILE__.':'.__LINE__;
|
262 |
$commentaires = $this->bdd->recuperer($requete);
|
262 |
$commentaires = $this->bdd->recuperer($requete);
|
263 |
return $commentaires ? $commentaires['nb'] : 0;
|
263 |
return $commentaires ? $commentaires['nb'] : 0;
|
264 |
}
|
264 |
}
|
265 |
}
|
265 |
}
|