Subversion Repositories eFlore/Applications.del

Rev

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

Rev 2020 Rev 2021
1
<?php
1
<?php
2
/**
2
/**
3
 * Statistiques par année sur l'utilisation de Identiplante / Pictoflora
3
 * Statistiques par année sur l'utilisation de Identiplante / Pictoflora
4
 *
4
 *
5
 * @see Documentation : <http://www.tela-botanica.org/wikini/DevInformatiques/wakka.php?wiki=AppliDelStats>
5
 * @see Documentation : <http://www.tela-botanica.org/wikini/DevInformatiques/wakka.php?wiki=AppliDelStats>
6
 *
6
 *
7
 * @category   DEL
7
 * @category   DEL
8
 * @package    Services
8
 * @package    Services
9
 * @subpackage Statistiques
9
 * @subpackage Statistiques
10
 * @version    0.1
10
 * @version    0.1
11
 * @author     Mathias CHOUET <mathias@tela-botanica.org>
11
 * @author     Mathias CHOUET <mathias@tela-botanica.org>
12
 * @author     Jean-Pascal MILCENT <jpm@tela-botanica.org>
12
 * @author     Jean-Pascal MILCENT <jpm@tela-botanica.org>
13
 * @author     Aurelien PERONNET <aurelien@tela-botanica.org>
13
 * @author     Aurelien PERONNET <aurelien@tela-botanica.org>
14
 * @license    GPL v3 <http://www.gnu.org/licenses/gpl.txt>
14
 * @license    GPL v3 <http://www.gnu.org/licenses/gpl.txt>
15
 * @license    CECILL v2 <http://www.cecill.info/licences/Licence_CeCILL_V2-en.txt>
15
 * @license    CECILL v2 <http://www.cecill.info/licences/Licence_CeCILL_V2-en.txt>
16
 * @copyright  1999-2014 Tela Botanica <accueil@tela-botanica.org>
16
 * @copyright  1999-2014 Tela Botanica <accueil@tela-botanica.org>
17
 */
17
 */
18
class StatistiquesParAnnee {
18
class StatistiquesParAnnee {
19
 
19
 
20
	private $conteneur;
20
	private $conteneur;
21
	private $contexte;
21
	private $contexte;
22
	private $navigation;
22
	private $navigation;
23
	private $bdd;
23
	private $bdd;
24
 
24
 
25
	private $annee = null;
25
	private $annee = null;
26
	private $type = 'tout';
26
	private $type = 'tout';
27
	private $methode = '';
27
	private $methode = '';
28
 
28
 
29
	public function __construct(Conteneur $conteneur = null) {
29
	public function __construct(Conteneur $conteneur = null) {
30
		$this->conteneur = $conteneur == null ? new Conteneur() : $conteneur;
30
		$this->conteneur = $conteneur == null ? new Conteneur() : $conteneur;
31
		$this->contexte = $conteneur->getContexte();
31
		$this->contexte = $conteneur->getContexte();
32
		$this->navigation = $conteneur->getNavigation();
32
		$this->navigation = $conteneur->getNavigation();
33
		$this->bdd = $this->conteneur->getBdd();
33
		$this->bdd = $this->conteneur->getBdd();
34
	}
34
	}
35
 
35
 
36
	public function consulter() {
36
	public function consulter() {
37
		$this->intitialiserParametresEtRessources();
37
		$this->intitialiserParametresEtRessources();
38
		$this->verifierPreRequis();
38
		$this->verifierPreRequis();
39
 
39
 
40
		$resultat = new ResultatService();
40
		$resultat = new ResultatService();
41
		$resultat->corps = call_user_func(array($this, $this->methode));
41
		$resultat->corps = call_user_func(array($this, $this->methode));
42
		return $resultat;
42
		return $resultat;
43
	}
43
	}
44
 
44
 
45
	private function intitialiserParametresEtRessources() {
45
	private function intitialiserParametresEtRessources() {
46
		$this->type = $this->contexte->getRessource(2) != null ? $this->contexte->getRessource(2) : $this->type;
46
		$this->type = $this->contexte->getRessource(2) != null ? $this->contexte->getRessource(2) : $this->type;
47
		$this->methode = $this->obtenirNomMethode($this->type);
47
		$this->methode = $this->obtenirNomMethode($this->type);
48
		$this->annee =(int) $this->contexte->getQS('annee') != null ? intval($this->contexte->getQS('annee')) : null;
48
		$this->annee =(int) $this->contexte->getQS('annee') != null ? intval($this->contexte->getQS('annee')) : null;
49
	}
49
	}
50
 
50
 
51
	private function verifierPreRequis() {
51
	private function verifierPreRequis() {
52
		$erreurs = array();
52
		$erreurs = array();
53
 
53
 
54
		if ($this->annee != null && !is_int($this->annee)) {
54
		if ($this->annee != null && !is_int($this->annee)) {
55
			$erreurs[] = "Le paramètre 'annee' doit être un entier.";
55
			$erreurs[] = "Le paramètre 'annee' doit être un entier.";
56
		}
56
		}
57
		if (method_exists($this, $this->obtenirNomMethode($this->type)) === false) {
57
		if (method_exists($this, $this->obtenirNomMethode($this->type)) === false) {
58
			$erreurs[] = "Les stats de type '{$this->type}' n'existent pas.";
58
			$erreurs[] = "Les stats de type '{$this->type}' n'existent pas.";
59
		}
59
		}
60
		if (!empty($erreurs)) {
60
		if (!empty($erreurs)) {
61
			$msg = "Erreur de configuration :\n".implode("\n", $erreurs)."\n\n".Statistiques::getDoc();
61
			$msg = "Erreur de configuration :\n".implode("\n", $erreurs)."\n\n".Statistiques::getDoc();
62
			throw new Exception($msg, RestServeur::HTTP_CODE_MAUVAISE_REQUETE);
62
			throw new Exception($msg, RestServeur::HTTP_CODE_MAUVAISE_REQUETE);
63
		}
63
		}
64
	}
64
	}
65
 
65
 
66
	/**
66
	/**
67
	 * Ouh la jolie méthode magique !!
67
	 * Ouh la jolie méthode magique !!
68
	 * @param unknown $mot
68
	 * @param unknown $mot
69
	 * @return string
69
	 * @return string
70
	 */
70
	 */
71
	private function obtenirNomMethode($mot) {
71
	private function obtenirNomMethode($mot) {
72
		$classeNom = 'get'.str_replace(' ', '', ucwords(strtolower(str_replace('-', ' ', $mot))));
72
		$classeNom = 'get'.str_replace(' ', '', ucwords(strtolower(str_replace('-', ' ', $mot))));
73
		return $classeNom;
73
		return $classeNom;
74
	}
74
	}
75
 
75
 
76
	/**
76
	/**
77
	 * Statistiques sur les observations
77
	 * Statistiques sur les observations
78
	 * "MPM" = moyenne par mois
78
	 * "MPM" = moyenne par mois
79
	 * "TC" = tag à déterminer ou certitude incertaine
79
	 * "TC" = tag à déterminer ou certitude incertaine
80
	 * - Nombre d'observations au total
80
	 * - Nombre d'observations au total
81
	 * - Nombre d'obs sans identification (ou tag ou certitude)
81
	 * - Nombre d'obs sans identification (ou tag ou certitude)
82
	 * - Nombre d'obs sans identification
82
	 * - Nombre d'obs sans identification
83
	 * - Nombre d'obs avec tag à déterminer ou certitude incertaine
83
	 * - Nombre d'obs avec tag à déterminer ou certitude incertaine
84
	 * - Nombre d'obs avec tag à déterminer ou certitude incertaine et retenue
84
	 * - Nombre d'obs avec tag à déterminer ou certitude incertaine et retenue
85
	 * - Nombre d'obs avec tag à déterminer ou certitude incertaine et avec consensus
85
	 * - Nombre d'obs avec tag à déterminer ou certitude incertaine et avec consensus
86
	 * - Nombre d'obs avec tag à déterminer ou certitude incertaine et avec consensus mais non validées
86
	 * - Nombre d'obs avec tag à déterminer ou certitude incertaine et avec consensus mais non validées
87
	 * - Nombre d'observations ayant une proposition retenue (parmi les observations de l'année)
87
	 * - Nombre d'observations ayant une proposition retenue (parmi les observations de l'année)
88
	 * - Nombre d'observations ayant une proposition retenue ou en consensus (parmi les observations de l'année)
88
	 * - Nombre d'observations ayant une proposition retenue ou en consensus (parmi les observations de l'année)
89
	 */
89
	 */
90
	private function getObservations() {
90
	private function getObservations() {
-
 
91
		$nbObsTotal = $this->getNbObsTotal();
-
 
92
		$nbObsSansIdentOuTC = $this->getNbObsSansIdentOuTC();
-
 
93
		$nbObsSansIdent = $this->getNbObsSansIdent();
-
 
94
		$nbObsTC = $this->getNbObsTC();
-
 
95
		$nbObsTCRetenue = $this->getNbObsTCRetenue();
-
 
96
		$nbObsTCConsensus = $this->getNbObsTCConsensus();
-
 
97
		$nbObsTCConsensusNonValide = $this->getNbObsTCConsensusNonValide();
-
 
98
		$nbPropositionsRetenuesObsAnnee = $this->getNbPropositionsRetenuesObsAnnee();
-
 
99
		$nbPropositionsConsensusObsAnnee = $this->getNbPropositionsConsensusObsAnnee();
91
		return array(
100
		return array(
92
			'nbObsTotal' => $this->getNbObsTotal(),
101
			'nbObsTotal' => $nbObsTotal,
93
			'nbObsTotalMPM' => $this->getNbObsTotal(true),
102
			'nbObsTotalMPM' => $this->getNbObsTotal(true),
94
			'nbObsSansIdentOuTC' => $this->getNbObsSansIdentOuTC(),
103
			'nbObsSansIdentOuTC' => $nbObsSansIdentOuTC,
95
			'nbObsSansIdentOuTCMPM' => $this->getNbObsSansIdentOuTC(true),
104
			'nbObsSansIdentOuTCMPM' => $this->getNbObsSansIdentOuTC(true),
-
 
105
			'nbObsSansIdentOuTCPC' => round(($nbObsSansIdentOuTC / $nbObsTotal) * 100, 2),
96
			'nbObsSansIdent' => $this->getNbObsSansIdent(),
106
			'nbObsSansIdent' => $nbObsSansIdent,
97
			'nbObsSansIdentMPM' => $this->getNbObsSansIdent(true),
107
			'nbObsSansIdentMPM' => $this->getNbObsSansIdent(true),
-
 
108
			'nbObsSansIdentPC' => round(($nbObsSansIdent / $nbObsTotal) * 100, 2),
98
			'nbObsTC' => $this->getNbObsTC(),
109
			'nbObsTC' => $nbObsTC,
99
			'nbObsTCMPM' => $this->getNbObsTC(true),
110
			'nbObsTCMPM' => $this->getNbObsTC(true),
-
 
111
			'nbObsTCPC' => round(($nbObsTC / $nbObsTotal) * 100, 2),
100
			'nbObsTCRetenue' => $this->getNbObsTCRetenue(),
112
			'nbObsTCRetenue' => $nbObsTCRetenue,
101
			'nbObsTCRetenueMPM' => $this->getNbObsTCRetenue(true),
113
			'nbObsTCRetenueMPM' => $this->getNbObsTCRetenue(true),
-
 
114
			'nbObsTCRetenuePC' => round(($nbObsTCRetenue / $nbObsTotal) * 100, 2),
102
			'nbObsTCConsensus' => $this->getNbObsTCConsensus(),
115
			'nbObsTCConsensus' => $nbObsTCConsensus,
103
			'nbObsTCConsensusMPM' => $this->getNbObsTCConsensus(true),
116
			'nbObsTCConsensusMPM' => $this->getNbObsTCConsensus(true),
-
 
117
			'nbObsTCConsensusPC' => round(($nbObsTCConsensus / $nbObsTotal) * 100, 2),
104
			'nbObsTCConsensusNonValide' => $this->getNbObsTCConsensusNonValide(),
118
			'nbObsTCConsensusNonValide' => $nbObsTCConsensusNonValide,
105
			'nbObsTCConsensusNonValideMPM' => $this->getNbObsTCConsensusNonValide(true),
119
			'nbObsTCConsensusNonValideMPM' => $this->getNbObsTCConsensusNonValide(true),
-
 
120
			'nbObsTCConsensusNonValidePC' => round(($nbObsTCConsensusNonValide / $nbObsTotal) * 100, 2),
106
			'nbPropositionsRetenuesObsAnnee' => $this->getNbPropositionsRetenuesObsAnnee(),
121
			'nbPropositionsRetenuesObsAnnee' => $nbPropositionsRetenuesObsAnnee,
107
			'nbPropositionsRetenuesObsAnneeMPM' => $this->getNbPropositionsRetenuesObsAnnee(true),
122
			'nbPropositionsRetenuesObsAnneeMPM' => $this->getNbPropositionsRetenuesObsAnnee(true),
-
 
123
			'nbPropositionsRetenuesObsAnneePC' => round(($nbPropositionsRetenuesObsAnnee / $nbObsTotal) * 100, 2),
108
			'nbPropositionsConsensusObsAnnee' => $this->getNbPropositionsConsensusObsAnnee(),
124
			'nbPropositionsConsensusObsAnnee' => $nbPropositionsConsensusObsAnnee,
109
			'nbPropositionsConsensusObsAnneeMPM' => $this->getNbPropositionsConsensusObsAnnee(true),
125
			'nbPropositionsConsensusObsAnneeMPM' => $this->getNbPropositionsConsensusObsAnnee(true),
-
 
126
			'nbPropositionsConsensusObsAnneePC' => round(($nbPropositionsConsensusObsAnnee / $nbObsTotal) * 100, 2),
110
		);
127
		);
111
	}
128
	}
112
 
129
 
113
	/**
130
	/**
114
	 * Nombre d'observations au total
131
	 * Nombre d'observations au total
115
	 */
132
	 */
116
	private function getNbObsTotal($mpm=false) {
133
	private function getNbObsTotal($mpm=false) {
117
		$requete = "SELECT COUNT(id_observation) AS nb_total FROM del_observation";
134
		$requete = "SELECT COUNT(id_observation) AS nb_total FROM del_observation";
118
		if ($this->annee != null) {
135
		if ($this->annee != null) {
119
			$requete .= ' WHERE YEAR(date_transmission) = ' . $this->annee;
136
			$requete .= ' WHERE YEAR(date_transmission) = ' . $this->annee;
120
		}
137
		}
121
		if ($mpm) {
138
		if ($mpm) {
122
			$requete = $this->encapsulerMPM($requete, 'date_transmission');
139
			$requete = $this->encapsulerMPM($requete, 'date_transmission');
123
		}
140
		}
124
		$resultat = $this->bdd->recupererTous($requete);
141
		$resultat = $this->bdd->recupererTous($requete);
125
		return intval(array_pop($resultat[0]));
142
		return intval(array_pop($resultat[0]));
126
	}
143
	}
127
 
144
 
128
	/**
145
	/**
129
	 * Nombre d'obs sans identification (ou tag ou certitude)
146
	 * Nombre d'obs sans identification (ou tag ou certitude)
130
	 */
147
	 */
131
	private function getNbObsSansIdentOuTC($mpm=false) {
148
	private function getNbObsSansIdentOuTC($mpm=false) {
132
		$requete = "SELECT COUNT(id_observation) AS nb_total FROM del_observation WHERE";
149
		$requete = "SELECT COUNT(id_observation) AS nb_total FROM del_observation WHERE";
133
		if ($this->annee != null) {
150
		if ($this->annee != null) {
134
			$requete .= ' YEAR(date_transmission) = ' . $this->annee . " AND";
151
			$requete .= ' YEAR(date_transmission) = ' . $this->annee . " AND";
135
		}
152
		}
136
		$requete .= " (mots_cles_texte LIKE '%determiner%' OR nom_sel_nn = '' OR nom_sel_nn IS NULL OR certitude IN ('aDeterminer','douteux'))";
153
		$requete .= " (mots_cles_texte LIKE '%determiner%' OR nom_sel_nn = '' OR nom_sel_nn IS NULL OR certitude IN ('aDeterminer','douteux'))";
137
		if ($mpm) {
154
		if ($mpm) {
138
			$requete = $this->encapsulerMPM($requete, 'date_transmission');
155
			$requete = $this->encapsulerMPM($requete, 'date_transmission');
139
		}
156
		}
140
		$resultat = $this->bdd->recupererTous($requete);
157
		$resultat = $this->bdd->recupererTous($requete);
141
		return intval(array_pop($resultat[0]));
158
		return intval(array_pop($resultat[0]));
142
	}
159
	}
143
 
160
 
144
	/**
161
	/**
145
	 * Nombre d'obs sans identification
162
	 * Nombre d'obs sans identification
146
	 */
163
	 */
147
	private function getNbObsSansIdent($mpm=false) {
164
	private function getNbObsSansIdent($mpm=false) {
148
		$requete = "SELECT COUNT(id_observation) AS nb_total FROM del_observation WHERE";
165
		$requete = "SELECT COUNT(id_observation) AS nb_total FROM del_observation WHERE";
149
		if ($this->annee != null) {
166
		if ($this->annee != null) {
150
			$requete .= ' YEAR(date_transmission) = ' . $this->annee . " AND";
167
			$requete .= ' YEAR(date_transmission) = ' . $this->annee . " AND";
151
		}
168
		}
152
		$requete .= " nom_sel_nn = '' OR nom_sel_nn IS NULL";
169
		$requete .= " nom_sel_nn = '' OR nom_sel_nn IS NULL";
153
		if ($mpm) {
170
		if ($mpm) {
154
			$requete = $this->encapsulerMPM($requete, 'date_transmission');
171
			$requete = $this->encapsulerMPM($requete, 'date_transmission');
155
		}
172
		}
156
		$resultat = $this->bdd->recupererTous($requete);
173
		$resultat = $this->bdd->recupererTous($requete);
157
		return intval(array_pop($resultat[0]));
174
		return intval(array_pop($resultat[0]));
158
	}
175
	}
159
 
176
 
160
	/**
177
	/**
161
	 * Nombre d'obs avec tag à déterminer ou certitude incertaine
178
	 * Nombre d'obs avec tag à déterminer ou certitude incertaine
162
	 */
179
	 */
163
	private function getNbObsTC($mpm=false) {
180
	private function getNbObsTC($mpm=false) {
164
		$requete = "SELECT COUNT(id_observation) AS nb_total FROM del_observation WHERE";
181
		$requete = "SELECT COUNT(id_observation) AS nb_total FROM del_observation WHERE";
165
		if ($this->annee != null) {
182
		if ($this->annee != null) {
166
			$requete .= ' YEAR(date_transmission) = ' . $this->annee . " AND";
183
			$requete .= ' YEAR(date_transmission) = ' . $this->annee . " AND";
167
		}
184
		}
168
		$requete .= " (mots_cles_texte LIKE '%determiner%' OR certitude IN ('aDeterminer','douteux'))";
185
		$requete .= " (mots_cles_texte LIKE '%determiner%' OR certitude IN ('aDeterminer','douteux'))";
169
		if ($mpm) {
186
		if ($mpm) {
170
			$requete = $this->encapsulerMPM($requete, 'date_transmission');
187
			$requete = $this->encapsulerMPM($requete, 'date_transmission');
171
		}
188
		}
172
		$resultat = $this->bdd->recupererTous($requete);
189
		$resultat = $this->bdd->recupererTous($requete);
173
		return intval(array_pop($resultat[0]));
190
		return intval(array_pop($resultat[0]));
174
	}
191
	}
175
 
192
 
176
	/**
193
	/**
177
	 * Nombre d'obs avec tag à déterminer ou certitude incertaine et retenue
194
	 * Nombre d'obs avec tag à déterminer ou certitude incertaine et retenue
178
	 */
195
	 */
179
	private function getNbObsTCRetenue($mpm=false) {
196
	private function getNbObsTCRetenue($mpm=false) {
180
		$requete = "SELECT COUNT(*) AS nb_total FROM del_commentaire WHERE proposition_retenue = 1 AND ce_observation IN (SELECT id_observation FROM del_observation WHERE";
197
		$requete = "SELECT COUNT(*) AS nb_total FROM del_commentaire WHERE proposition_retenue = 1 AND ce_observation IN (SELECT id_observation FROM del_observation WHERE";
181
		if ($this->annee != null) {
198
		if ($this->annee != null) {
182
			$requete .= ' YEAR(date_transmission) = ' . $this->annee . " AND";
199
			$requete .= ' YEAR(date_transmission) = ' . $this->annee . " AND";
183
		}
200
		}
184
		$requete .= " (certitude IN ('aDeterminer','douteux')))";
201
		$requete .= " (certitude IN ('aDeterminer','douteux')))";
185
		if ($mpm) {
202
		if ($mpm) {
186
			// @TODO vérifier que grouper sur "date" est pertinent
203
			// @TODO vérifier que grouper sur "date" est pertinent
187
			// date_transmission n'est pas dispo pour grouper ici :-/
204
			// date_transmission n'est pas dispo pour grouper ici :-/
188
			$requete = $this->encapsulerMPM($requete);
205
			$requete = $this->encapsulerMPM($requete);
189
		}
206
		}
190
		$resultat = $this->bdd->recupererTous($requete);
207
		$resultat = $this->bdd->recupererTous($requete);
191
		return intval(array_pop($resultat[0]));
208
		return intval(array_pop($resultat[0]));
192
	}
209
	}
193
 
210
 
194
	/**
211
	/**
195
	 * Nombre d'obs avec tag à déterminer ou certitude incertaine et avec consensus
212
	 * Nombre d'obs avec tag à déterminer ou certitude incertaine et avec consensus
196
	 */
213
	 */
197
	private function getNbObsTCConsensus($mpm=false) {
214
	private function getNbObsTCConsensus($mpm=false) {
198
		$requete = "SELECT COUNT(id_observation) AS nb_total FROM del_observation WHERE";
215
		$requete = "SELECT COUNT(id_observation) AS nb_total FROM del_observation WHERE";
199
		if ($this->annee != null) {
216
		if ($this->annee != null) {
200
			$requete .= ' YEAR(date_transmission) = ' . $this->annee . " AND";
217
			$requete .= ' YEAR(date_transmission) = ' . $this->annee . " AND";
201
		}
218
		}
202
		$requete .= " (mots_cles_texte LIKE '%determiner%' OR certitude IN ('aDeterminer','douteux')) AND id_observation IN"
219
		$requete .= " (mots_cles_texte LIKE '%determiner%' OR certitude IN ('aDeterminer','douteux')) AND id_observation IN"
203
			. " (SELECT ce_observation FROM del_commentaire WHERE proposition_initiale = 1" 
220
			. " (SELECT ce_observation FROM del_commentaire WHERE proposition_initiale = 1" 
204
			. " AND nom_sel_nn != 0"
221
			. " AND nom_sel_nn != 0"
205
			. " AND nom_sel_nn IS NOT NULL"
222
			. " AND nom_sel_nn IS NOT NULL"
206
			. " AND id_commentaire IN (SELECT ce_proposition FROM del_commentaire_vote dcv";
223
			. " AND id_commentaire IN (SELECT ce_proposition FROM del_commentaire_vote dcv";
207
		if ($this->annee != null) {
224
		if ($this->annee != null) {
208
			$requete .= ' WHERE YEAR(date) <= ' . $this->annee;
225
			$requete .= ' WHERE YEAR(date) <= ' . $this->annee;
209
		}
226
		}
210
		$requete .= " GROUP BY ce_proposition HAVING SUM(CASE"
227
		$requete .= " GROUP BY ce_proposition HAVING SUM(CASE"
211
			. " WHEN valeur = 1 AND dcv.ce_utilisateur REGEXP '^-?[0-9]+$' != 0 THEN 3"
228
			. " WHEN valeur = 1 AND dcv.ce_utilisateur REGEXP '^-?[0-9]+$' != 0 THEN 3"
212
			. " WHEN valeur = 0 AND dcv.ce_utilisateur REGEXP '^-?[0-9]+$' != 0 THEN -3"
229
			. " WHEN valeur = 0 AND dcv.ce_utilisateur REGEXP '^-?[0-9]+$' != 0 THEN -3"
213
			. " WHEN valeur = 1 AND dcv.ce_utilisateur REGEXP '^-?[0-9]+$' = 0 THEN 1"
230
			. " WHEN valeur = 1 AND dcv.ce_utilisateur REGEXP '^-?[0-9]+$' = 0 THEN 1"
214
			. " WHEN valeur = 0 AND dcv.ce_utilisateur REGEXP '^-?[0-9]+$' = 0 THEN -1"
231
			. " WHEN valeur = 0 AND dcv.ce_utilisateur REGEXP '^-?[0-9]+$' = 0 THEN -1"
215
		. " END) >= 4))";
232
		. " END) >= 4))";
216
		if ($mpm) {
233
		if ($mpm) {
217
			$requete = $this->encapsulerMPM($requete, 'date_transmission');
234
			$requete = $this->encapsulerMPM($requete, 'date_transmission');
218
		}
235
		}
219
		$resultat = $this->bdd->recupererTous($requete);
236
		$resultat = $this->bdd->recupererTous($requete);
220
		return intval(array_pop($resultat[0]));
237
		return intval(array_pop($resultat[0]));
221
	}
238
	}
222
 
239
 
223
	/**
240
	/**
224
	 * Nombre d'obs avec tag à déterminer ou certitude incertaine et avec consensus mais non validées
241
	 * Nombre d'obs avec tag à déterminer ou certitude incertaine et avec consensus mais non validées
225
	 */
242
	 */
226
	private function getNbObsTCConsensusNonValide($mpm=false) {
243
	private function getNbObsTCConsensusNonValide($mpm=false) {
227
		$requete = "SELECT COUNT(id_observation) AS nb_total FROM del_observation WHERE";
244
		$requete = "SELECT COUNT(id_observation) AS nb_total FROM del_observation WHERE";
228
		if ($this->annee != null) {
245
		if ($this->annee != null) {
229
			$requete .= ' YEAR(date_transmission) = ' . $this->annee . " AND";
246
			$requete .= ' YEAR(date_transmission) = ' . $this->annee . " AND";
230
		}
247
		}
231
		$requete .= " (mots_cles_texte LIKE '%determiner%' OR certitude IN ('aDeterminer','douteux')) AND id_observation IN"
248
		$requete .= " (mots_cles_texte LIKE '%determiner%' OR certitude IN ('aDeterminer','douteux')) AND id_observation IN"
232
			. " (SELECT ce_observation FROM del_commentaire WHERE proposition_initiale = 1 AND proposition_retenue = 0" 
249
			. " (SELECT ce_observation FROM del_commentaire WHERE proposition_initiale = 1 AND proposition_retenue = 0" 
233
			. " AND nom_sel_nn != 0"
250
			. " AND nom_sel_nn != 0"
234
			. " AND nom_sel_nn IS NOT NULL"
251
			. " AND nom_sel_nn IS NOT NULL"
235
			. " AND id_commentaire IN (SELECT ce_proposition FROM del_commentaire_vote dcv";
252
			. " AND id_commentaire IN (SELECT ce_proposition FROM del_commentaire_vote dcv";
236
		if ($this->annee != null) {
253
		if ($this->annee != null) {
237
			$requete .= ' WHERE YEAR(date) <= ' . $this->annee;
254
			$requete .= ' WHERE YEAR(date) <= ' . $this->annee;
238
		}
255
		}
239
		$requete .= " GROUP BY ce_proposition HAVING SUM(CASE"
256
		$requete .= " GROUP BY ce_proposition HAVING SUM(CASE"
240
			. " WHEN valeur = 1 AND dcv.ce_utilisateur REGEXP '^-?[0-9]+$' != 0 THEN 3"
257
			. " WHEN valeur = 1 AND dcv.ce_utilisateur REGEXP '^-?[0-9]+$' != 0 THEN 3"
241
			. " WHEN valeur = 0 AND dcv.ce_utilisateur REGEXP '^-?[0-9]+$' != 0 THEN -3"
258
			. " WHEN valeur = 0 AND dcv.ce_utilisateur REGEXP '^-?[0-9]+$' != 0 THEN -3"
242
			. " WHEN valeur = 1 AND dcv.ce_utilisateur REGEXP '^-?[0-9]+$' = 0 THEN 1"
259
			. " WHEN valeur = 1 AND dcv.ce_utilisateur REGEXP '^-?[0-9]+$' = 0 THEN 1"
243
			. " WHEN valeur = 0 AND dcv.ce_utilisateur REGEXP '^-?[0-9]+$' = 0 THEN -1"
260
			. " WHEN valeur = 0 AND dcv.ce_utilisateur REGEXP '^-?[0-9]+$' = 0 THEN -1"
244
		. " END) >= 4))";
261
		. " END) >= 4))";
245
		if ($mpm) {
262
		if ($mpm) {
246
			$requete = $this->encapsulerMPM($requete, 'date_transmission');
263
			$requete = $this->encapsulerMPM($requete, 'date_transmission');
247
		}
264
		}
248
		$resultat = $this->bdd->recupererTous($requete);
265
		$resultat = $this->bdd->recupererTous($requete);
249
		return intval(array_pop($resultat[0]));
266
		return intval(array_pop($resultat[0]));
250
	}
267
	}
251
 
268
 
252
	/**
269
	/**
253
	 * Statistiques sur les propositions, les commentaires et les votes
270
	 * Statistiques sur les propositions, les commentaires et les votes
254
	 * "MPM" = moyenne par mois
271
	 * "MPM" = moyenne par mois
255
	 * - Nombre de votes
272
	 * - Nombre de votes
256
	 * - Nombre de commentaires
273
	 * - Nombre de commentaires
257
	 * - Nombre d'actions par jour
274
	 * - Nombre d'actions par jour
258
	 * - Nombres de propositions sur toutes les obs
275
	 * - Nombres de propositions sur toutes les obs
259
	 * - Nombre d'observations ayant une proposition retenue (parmi toutes les observations)
276
	 * - Nombre d'observations ayant une proposition retenue (parmi toutes les observations)
260
	 * - Nombre d'observations ayant une proposition retenue ou en consensus (parmi toutes les observations)
277
	 * - Nombre d'observations ayant une proposition retenue ou en consensus (parmi toutes les observations)
261
	 * - Nombre de propositions sur les obs d'une année
278
	 * - Nombre de propositions sur les obs d'une année
262
	 */
279
	 */
263
	private function getPropositions() {
280
	private function getPropositions() {
264
		return array(
281
		return array(
265
			'nbVotes' => $this->getNbVotes(),
282
			'nbVotes' => $this->getNbVotes(),
266
			'nbVotesMPM' => $this->getNbVotes(true),
283
			'nbVotesMPM' => $this->getNbVotes(true),
267
			'nbMoyenActionsParJour' => $this->getNbMoyenActionsParJour(),
284
			'nbMoyenActionsParJour' => $this->getNbMoyenActionsParJour(),
268
			'nbCommentaires' => $this->getNbCommentaires(),
285
			'nbCommentaires' => $this->getNbCommentaires(),
269
			'nbCommentairesMPM' => $this->getNbCommentaires(true),
286
			'nbCommentairesMPM' => $this->getNbCommentaires(true),
270
			'nbPropositionsToutesObs' => $this->getNbPropositionsToutesObs(),
287
			'nbPropositionsToutesObs' => $this->getNbPropositionsToutesObs(),
271
			'nbPropositionsToutesObsMPM' => $this->getNbPropositionsToutesObs(true),
288
			'nbPropositionsToutesObsMPM' => $this->getNbPropositionsToutesObs(true),
272
			'nbPropositionsRetenuesToutesObs' => $this->getNbPropositionsRetenuesToutesObs(),
289
			'nbPropositionsRetenuesToutesObs' => $this->getNbPropositionsRetenuesToutesObs(),
273
			'nbPropositionsRetenuesToutesObsMPM' => $this->getNbPropositionsRetenuesToutesObs(true),
290
			'nbPropositionsRetenuesToutesObsMPM' => $this->getNbPropositionsRetenuesToutesObs(true),
274
			'nbPropositionsConsensusToutesObs' => $this->getNbPropositionsConsensusToutesObs(),
291
			'nbPropositionsConsensusToutesObs' => $this->getNbPropositionsConsensusToutesObs(),
275
			'nbPropositionsConsensusToutesObsMPM' => $this->getNbPropositionsConsensusToutesObs(true),
292
			'nbPropositionsConsensusToutesObsMPM' => $this->getNbPropositionsConsensusToutesObs(true),
276
			'nbPropositionsObsAnnee' => $this->getNbPropositionsObsAnnee(),
293
			'nbPropositionsObsAnnee' => $this->getNbPropositionsObsAnnee(),
277
			'nbPropositionsObsAnneeMPM' => $this->getNbPropositionsObsAnnee(true),
294
			'nbPropositionsObsAnneeMPM' => $this->getNbPropositionsObsAnnee(true),
278
		);
295
		);
279
	}
296
	}
280
 
297
 
281
	/**
298
	/**
282
	 * Nombre moyen d'actions par jour (commentaire, proposition, vote)
299
	 * Nombre moyen d'actions par jour (commentaire, proposition, vote)
283
	 */
300
	 */
284
	private function getNbMoyenActionsParJour() {
301
	private function getNbMoyenActionsParJour() {
285
		$requete = "SELECT (SELECT (SELECT count(*) FROM del_commentaire";
302
		$requete = "SELECT (SELECT (SELECT count(*) FROM del_commentaire";
286
		if ($this->annee != null) {
303
		if ($this->annee != null) {
287
			$requete .= ' WHERE YEAR(date) = ' . $this->annee;
304
			$requete .= ' WHERE YEAR(date) = ' . $this->annee;
288
		}
305
		}
289
		$requete .= ") +  (SELECT count(*) FROM del_commentaire_vote";
306
		$requete .= ") +  (SELECT count(*) FROM del_commentaire_vote";
290
		if ($this->annee != null) {
307
		if ($this->annee != null) {
291
			$requete .= ' WHERE YEAR(date) = ' . $this->annee;
308
			$requete .= ' WHERE YEAR(date) = ' . $this->annee;
292
		}
309
		}
293
		$requete .= ") +  (SELECT count(*) FROM del_commentaire";
310
		$requete .= ") +  (SELECT count(*) FROM del_commentaire";
294
		if ($this->annee != null) {
311
		if ($this->annee != null) {
295
			$requete .= ' WHERE YEAR(date_validation) = ' . $this->annee;
312
			$requete .= ' WHERE YEAR(date_validation) = ' . $this->annee;
296
		}
313
		}
297
		$requete .= ")) / (";
314
		$requete .= ")) / (";
298
		if ($this->annee != null) {
315
		if ($this->annee != null) {
299
			$requete .= "SELECT IF( YEAR(CURDATE()) = " . $this->annee . ", DAYOFYEAR(CURDATE()), 365) ";
316
			$requete .= "SELECT IF( YEAR(CURDATE()) = " . $this->annee . ", DAYOFYEAR(CURDATE()), 365) ";
300
		} else {
317
		} else {
301
			$requete .= "365";
318
			$requete .= "365";
302
		}
319
		}
303
		$requete .= ")";
320
		$requete .= ")";
304
		$resultat = $this->bdd->recupererTous($requete);
321
		$resultat = $this->bdd->recupererTous($requete);
305
		return intval(array_pop($resultat[0]));
322
		return intval(array_pop($resultat[0]));
306
	}
323
	}
307
 
324
 
308
	/**
325
	/**
309
	 * Nombre de propositions faites sur toutes les observations (hors initiales)
326
	 * Nombre de propositions faites sur toutes les observations (hors initiales)
310
	 */
327
	 */
311
	private function getNbPropositionsToutesObs($mpm=false) {
328
	private function getNbPropositionsToutesObs($mpm=false) {
312
		$requete = "SELECT COUNT(DISTINCT id_commentaire) AS nb_total FROM del_commentaire WHERE";
329
		$requete = "SELECT COUNT(DISTINCT id_commentaire) AS nb_total FROM del_commentaire WHERE";
313
		if ($this->annee != null) {
330
		if ($this->annee != null) {
314
			$requete .= ' YEAR(date) = ' . $this->annee . " AND";
331
			$requete .= ' YEAR(date) = ' . $this->annee . " AND";
315
		}
332
		}
316
		$requete .= " (nom_sel_nn IS NOT NULL OR nom_sel_nn != '') AND proposition_initiale = 0";
333
		$requete .= " (nom_sel_nn IS NOT NULL OR nom_sel_nn != '') AND proposition_initiale = 0";
317
		if ($mpm) {
334
		if ($mpm) {
318
			$requete = $this->encapsulerMPM($requete);
335
			$requete = $this->encapsulerMPM($requete);
319
		}
336
		}
320
		$resultat = $this->bdd->recupererTous($requete);
337
		$resultat = $this->bdd->recupererTous($requete);
321
		return intval(array_pop($resultat[0]));
338
		return intval(array_pop($resultat[0]));
322
	}
339
	}
323
 
340
 
324
	/**
341
	/**
325
	 * Nombre d'observations ayant une proposition retenue (parmi toutes les observations)
342
	 * Nombre d'observations ayant une proposition retenue (parmi toutes les observations)
326
	 */
343
	 */
327
	private function getNbPropositionsRetenuesToutesObs($mpm=false) {
344
	private function getNbPropositionsRetenuesToutesObs($mpm=false) {
328
		$requete = "SELECT COUNT(DISTINCT ce_observation) AS nb_total FROM del_commentaire WHERE";
345
		$requete = "SELECT COUNT(DISTINCT ce_observation) AS nb_total FROM del_commentaire WHERE";
329
		if ($this->annee != null) {
346
		if ($this->annee != null) {
330
			$requete .= ' YEAR(date) = ' . $this->annee . " AND";
347
			$requete .= ' YEAR(date) = ' . $this->annee . " AND";
331
		}
348
		}
332
		$requete .= " proposition_retenue = 1";
349
		$requete .= " proposition_retenue = 1";
333
		if ($mpm) {
350
		if ($mpm) {
334
			$requete = $this->encapsulerMPM($requete);
351
			$requete = $this->encapsulerMPM($requete);
335
		}
352
		}
336
		$resultat = $this->bdd->recupererTous($requete);
353
		$resultat = $this->bdd->recupererTous($requete);
337
		return intval(array_pop($resultat[0]));
354
		return intval(array_pop($resultat[0]));
338
	}
355
	}
339
 
356
 
340
	/**
357
	/**
341
	 * Nombre d'observations ayant une proposition retenue ou en consensus (parmi toutes les observations)
358
	 * Nombre d'observations ayant une proposition retenue ou en consensus (parmi toutes les observations)
342
	 */
359
	 */
343
	private function getNbPropositionsConsensusToutesObs($mpm=false) {
360
	private function getNbPropositionsConsensusToutesObs($mpm=false) {
344
		$requete = "SELECT COUNT(DISTINCT ce_observation) AS nb_total FROM del_commentaire dc WHERE"
361
		$requete = "SELECT COUNT(DISTINCT ce_observation) AS nb_total FROM del_commentaire dc WHERE"
345
			. " dc.proposition_retenue = 1"
362
			. " dc.proposition_retenue = 1"
346
			. " OR (dc.proposition_initiale = 1" 
363
			. " OR (dc.proposition_initiale = 1" 
347
			. " AND dc.nom_sel_nn != 0"
364
			. " AND dc.nom_sel_nn != 0"
348
			. " AND dc.nom_sel_nn IS NOT NULL" 
365
			. " AND dc.nom_sel_nn IS NOT NULL" 
349
			. " AND dc.id_commentaire IN"
366
			. " AND dc.id_commentaire IN"
350
				. " (SELECT ce_proposition FROM del_commentaire_vote dcv WHERE";
367
				. " (SELECT ce_proposition FROM del_commentaire_vote dcv WHERE";
351
				if ($this->annee != null) {
368
				if ($this->annee != null) {
352
					$requete .= " year(date) < " . $this->annee . " AND";
369
					$requete .= " year(date) < " . $this->annee . " AND";
353
				}
370
				}
354
				$requete .= " ce_proposition NOT IN (SELECT ce_proposition FROM del_commentaire_vote dcv";
371
				$requete .= " ce_proposition NOT IN (SELECT ce_proposition FROM del_commentaire_vote dcv";
355
				if ($this->annee != null) { 
372
				if ($this->annee != null) { 
356
					$requete .= " WHERE year(date) < " . ($this->annee - 1);
373
					$requete .= " WHERE year(date) < " . ($this->annee - 1);
357
				}
374
				}
358
				$requete .= " GROUP BY ce_proposition"
375
				$requete .= " GROUP BY ce_proposition"
359
					. " HAVING SUM(CASE"
376
					. " HAVING SUM(CASE"
360
						. " WHEN valeur = 1 AND dcv.ce_utilisateur REGEXP '^-?[0-9]+$' != 0 THEN 3" 
377
						. " WHEN valeur = 1 AND dcv.ce_utilisateur REGEXP '^-?[0-9]+$' != 0 THEN 3" 
361
						. " WHEN valeur = 0 AND dcv.ce_utilisateur REGEXP '^-?[0-9]+$' != 0 THEN -3" 
378
						. " WHEN valeur = 0 AND dcv.ce_utilisateur REGEXP '^-?[0-9]+$' != 0 THEN -3" 
362
						. " WHEN valeur = 1 AND dcv.ce_utilisateur REGEXP '^-?[0-9]+$' = 0 THEN 1"
379
						. " WHEN valeur = 1 AND dcv.ce_utilisateur REGEXP '^-?[0-9]+$' = 0 THEN 1"
363
						. " WHEN valeur = 0 AND dcv.ce_utilisateur REGEXP '^-?[0-9]+$' = 0 THEN -1"
380
						. " WHEN valeur = 0 AND dcv.ce_utilisateur REGEXP '^-?[0-9]+$' = 0 THEN -1"
364
					. " END) >= 4)"
381
					. " END) >= 4)"
365
				. " GROUP BY ce_proposition"
382
				. " GROUP BY ce_proposition"
366
				. " HAVING SUM(CASE"
383
				. " HAVING SUM(CASE"
367
					. " WHEN valeur = 1 AND dcv.ce_utilisateur REGEXP '^-?[0-9]+$' != 0 THEN 3"
384
					. " WHEN valeur = 1 AND dcv.ce_utilisateur REGEXP '^-?[0-9]+$' != 0 THEN 3"
368
					. " WHEN valeur = 0 AND dcv.ce_utilisateur REGEXP '^-?[0-9]+$' != 0 THEN -3"
385
					. " WHEN valeur = 0 AND dcv.ce_utilisateur REGEXP '^-?[0-9]+$' != 0 THEN -3"
369
					. " WHEN valeur = 1 AND dcv.ce_utilisateur REGEXP '^-?[0-9]+$' = 0 THEN 1"
386
					. " WHEN valeur = 1 AND dcv.ce_utilisateur REGEXP '^-?[0-9]+$' = 0 THEN 1"
370
					. " WHEN valeur = 0 AND dcv.ce_utilisateur REGEXP '^-?[0-9]+$' = 0 THEN -1"
387
					. " WHEN valeur = 0 AND dcv.ce_utilisateur REGEXP '^-?[0-9]+$' = 0 THEN -1"
371
				. " END) >= 4"
388
				. " END) >= 4"
372
			. " )"
389
			. " )"
373
		. " )";
390
		. " )";
374
		if ($mpm) {
391
		if ($mpm) {
375
			$requete = $this->encapsulerMPM($requete);
392
			$requete = $this->encapsulerMPM($requete);
376
		}
393
		}
377
		$resultat = $this->bdd->recupererTous($requete);
394
		$resultat = $this->bdd->recupererTous($requete);
378
		return intval(array_pop($resultat[0]));
395
		return intval(array_pop($resultat[0]));
379
	}
396
	}
380
 
397
 
381
	/**
398
	/**
382
	 * Nombre d'observations ayant une proposition retenue (parmi les observations de l'année)
399
	 * Nombre d'observations ayant une proposition retenue (parmi les observations de l'année)
383
	 */
400
	 */
384
	private function getNbPropositionsObsAnnee($mpm=false) {
401
	private function getNbPropositionsObsAnnee($mpm=false) {
385
		if ($this->annee == null) {
402
		if ($this->annee == null) {
386
			return null;
403
			return null;
387
		}
404
		}
388
		$requete = "SELECT COUNT(DISTINCT ce_observation) AS nb_total FROM del_commentaire WHERE YEAR(date) = " . $this->annee . " AND "
405
		$requete = "SELECT COUNT(DISTINCT ce_observation) AS nb_total FROM del_commentaire WHERE YEAR(date) = " . $this->annee . " AND "
389
			. "(nom_sel_nn IS NOT NULL OR nom_sel_nn != '') AND proposition_initiale = 0 AND ce_observation in"
406
			. "(nom_sel_nn IS NOT NULL OR nom_sel_nn != '') AND proposition_initiale = 0 AND ce_observation in"
390
			. " (SELECT id_observation FROM del_observation WHERE year(date_transmission) = " . $this->annee . ")";
407
			. " (SELECT id_observation FROM del_observation WHERE year(date_transmission) = " . $this->annee . ")";
391
		if ($mpm) {
408
		if ($mpm) {
392
			$requete = $this->encapsulerMPM($requete);
409
			$requete = $this->encapsulerMPM($requete);
393
		}
410
		}
394
		$resultat = $this->bdd->recupererTous($requete);
411
		$resultat = $this->bdd->recupererTous($requete);
395
		return intval(array_pop($resultat[0]));
412
		return intval(array_pop($resultat[0]));
396
	}
413
	}
397
 
414
 
398
	/**
415
	/**
399
	 * Nombre d'observations ayant une proposition retenue ou en consensus (parmi les observations de l'année)
416
	 * Nombre d'observations ayant une proposition retenue ou en consensus (parmi les observations de l'année)
400
	 */
417
	 */
401
	private function getNbPropositionsRetenuesObsAnnee($mpm=false) {
418
	private function getNbPropositionsRetenuesObsAnnee($mpm=false) {
-
 
419
		$requete = "SELECT COUNT(DISTINCT ce_observation) AS nb_total FROM del_commentaire WHERE ";
402
		if ($this->annee == null) {
420
		if ($this->annee != null) {
403
			return null;
421
			$requete .= "YEAR(date) = " . $this->annee . " AND ";
404
		}
422
		}
405
		$requete = "SELECT COUNT(DISTINCT ce_observation) AS nb_total FROM del_commentaire WHERE YEAR(date) = " . $this->annee . " AND "
423
		$requete .= "proposition_retenue = 1 AND ce_observation in (SELECT id_observation FROM del_observation ";
-
 
424
		if ($this->annee != null) {
406
			. "proposition_retenue = 1 AND ce_observation in (SELECT id_observation FROM del_observation WHERE year(date_transmission) = " . $this->annee . ")";
425
			$requete .= "WHERE year(date_transmission) = " . $this->annee;
-
 
426
		} 
-
 
427
		$requete .= ")";
407
		if ($mpm) {
428
		if ($mpm) {
408
			$requete = $this->encapsulerMPM($requete);
429
			$requete = $this->encapsulerMPM($requete);
409
		}
430
		}
410
		$resultat = $this->bdd->recupererTous($requete);
431
		$resultat = $this->bdd->recupererTous($requete);
411
		return intval(array_pop($resultat[0]));
432
		return intval(array_pop($resultat[0]));
412
	}
433
	}
413
 
434
 
414
	/**
435
	/**
415
	 * Nombre de proposition en consensus faites sur les observations d'une année
436
	 * Nombre de proposition en consensus faites sur les observations d'une année
416
	 */
437
	 */
417
	private function getNbPropositionsConsensusObsAnnee($mpm=false) {
438
	private function getNbPropositionsConsensusObsAnnee($mpm=false) {
418
		if ($this->annee == null) {
-
 
419
			return null;
-
 
420
		}
-
 
421
		$requete = "SELECT COUNT(DISTINCT ce_observation) AS nb_total FROM del_commentaire dc WHERE ce_observation in ("
439
		$requete = "SELECT COUNT(DISTINCT ce_observation) AS nb_total FROM del_commentaire dc WHERE ce_observation in ("
-
 
440
			. " SELECT id_observation FROM del_observation ";
-
 
441
		if ($this->annee != null) {
422
			. " SELECT id_observation FROM del_observation WHERE year(date_transmission) = " . $this->annee . ") AND ("
442
			$requete .= "WHERE year(date_transmission) = " . $this->annee ;
-
 
443
		}
-
 
444
		$requete .= ") AND ("
423
			. " dc.proposition_retenue = 1 OR (dc.proposition_initiale = 1"
445
			. " dc.proposition_retenue = 1 OR (dc.proposition_initiale = 1"
424
			. " AND dc.nom_sel_nn != 0 AND dc.nom_sel_nn IS NOT NULL AND dc.id_commentaire IN" 
446
			. " AND dc.nom_sel_nn != 0 AND dc.nom_sel_nn IS NOT NULL AND dc.id_commentaire IN" 
425
				. " (SELECT ce_proposition FROM del_commentaire_vote dcv"
447
				. " (SELECT ce_proposition FROM del_commentaire_vote dcv";
-
 
448
			if ($this->annee != null) {
426
				. " WHERE year(date) <= " . $this->annee 
449
				$requete .= " WHERE year(date) <= " . $this->annee;
-
 
450
			} 
427
				. " GROUP BY ce_proposition"
451
			$requete .= " GROUP BY ce_proposition"
428
				. " HAVING SUM(CASE"
452
				. " HAVING SUM(CASE"
429
					. " WHEN valeur = 1 AND dcv.ce_utilisateur REGEXP '^-?[0-9]+$' != 0 THEN 3"
453
					. " WHEN valeur = 1 AND dcv.ce_utilisateur REGEXP '^-?[0-9]+$' != 0 THEN 3"
430
					. " WHEN valeur = 0 AND dcv.ce_utilisateur REGEXP '^-?[0-9]+$' != 0 THEN -3"
454
					. " WHEN valeur = 0 AND dcv.ce_utilisateur REGEXP '^-?[0-9]+$' != 0 THEN -3"
431
					. " WHEN valeur = 1 AND dcv.ce_utilisateur REGEXP '^-?[0-9]+$' = 0 THEN 1"
455
					. " WHEN valeur = 1 AND dcv.ce_utilisateur REGEXP '^-?[0-9]+$' = 0 THEN 1"
432
					. " WHEN valeur = 0 AND dcv.ce_utilisateur REGEXP '^-?[0-9]+$' = 0 THEN -1"
456
					. " WHEN valeur = 0 AND dcv.ce_utilisateur REGEXP '^-?[0-9]+$' = 0 THEN -1"
433
				. " END) >= 4)"
457
				. " END) >= 4)"
434
			. "))";
458
			. "))";
435
		if ($mpm) {
459
		if ($mpm) {
436
			$requete = $this->encapsulerMPM($requete);
460
			$requete = $this->encapsulerMPM($requete);
437
		}
461
		}
438
		$resultat = $this->bdd->recupererTous($requete);
462
		$resultat = $this->bdd->recupererTous($requete);
439
		return intval(array_pop($resultat[0]));
463
		return intval(array_pop($resultat[0]));
440
	}
464
	}
441
 
465
 
442
	/**
466
	/**
443
	 * Nombre de votes
467
	 * Nombre de votes
444
	 */
468
	 */
445
	private function getNbVotes($mpm=false) {
469
	private function getNbVotes($mpm=false) {
446
		$requete = "SELECT COUNT(DISTINCT id_vote) AS nb_total FROM del_commentaire_vote";
470
		$requete = "SELECT COUNT(DISTINCT id_vote) AS nb_total FROM del_commentaire_vote";
447
		if ($this->annee != null) {
471
		if ($this->annee != null) {
448
			$requete .= ' WHERE YEAR(date) = ' . $this->annee;
472
			$requete .= ' WHERE YEAR(date) = ' . $this->annee;
449
		}
473
		}
450
		if ($mpm) {
474
		if ($mpm) {
451
			$requete = $this->encapsulerMPM($requete);
475
			$requete = $this->encapsulerMPM($requete);
452
		}
476
		}
453
		$resultat = $this->bdd->recupererTous($requete);
477
		$resultat = $this->bdd->recupererTous($requete);
454
		return intval(array_pop($resultat[0]));
478
		return intval(array_pop($resultat[0]));
455
	}
479
	}
456
 
480
 
457
	/**
481
	/**
458
	 * Nombre de commentaires
482
	 * Nombre de commentaires
459
	 */
483
	 */
460
	private function getNbCommentaires($mpm=false) {
484
	private function getNbCommentaires($mpm=false) {
461
		$requete = "SELECT COUNT(DISTINCT id_commentaire) AS nb_total FROM del_commentaire WHERE ce_proposition != '' AND (nom_sel IS NULL OR nom_sel = '')";
485
		$requete = "SELECT COUNT(DISTINCT id_commentaire) AS nb_total FROM del_commentaire WHERE ce_proposition != '' AND (nom_sel IS NULL OR nom_sel = '')";
462
		if ($this->annee != null) {
486
		if ($this->annee != null) {
463
			$requete .= ' AND YEAR(date) = ' . $this->annee;
487
			$requete .= ' AND YEAR(date) = ' . $this->annee;
464
		}
488
		}
465
		if ($mpm) {
489
		if ($mpm) {
466
			$requete = $this->encapsulerMPM($requete);
490
			$requete = $this->encapsulerMPM($requete);
467
		}
491
		}
468
		$resultat = $this->bdd->recupererTous($requete);
492
		$resultat = $this->bdd->recupererTous($requete);
469
		return intval(array_pop($resultat[0]));
493
		return intval(array_pop($resultat[0]));
470
	}
494
	}
471
 
495
 
472
	/**
496
	/**
473
	 * Statistiques sur les utilisateurs d'Identiplante
497
	 * Statistiques sur les utilisateurs d'Identiplante
474
	 * "AF" = ayant fait un(e)
498
	 * "AF" = ayant fait un(e)
475
	 * "MPM" = moyenne par mois
499
	 * "MPM" = moyenne par mois
476
	 * - Nombre total d'utilisateurs
500
	 * - Nombre total d'utilisateurs
477
	 * - Nombre d'utilisateurs ayant fait une proposition
501
	 * - Nombre d'utilisateurs ayant fait une proposition
478
	 * - Nombre d'utilisateurs identifiés ayant fait un vote
502
	 * - Nombre d'utilisateurs identifiés ayant fait un vote
479
	 * - Nombre d'utilisateurs anonymes ayant fait un vote
503
	 * - Nombre d'utilisateurs anonymes ayant fait un vote
480
	 * - Nombre d'utilisateurs ayant fait un commentaire
504
	 * - Nombre d'utilisateurs ayant fait un commentaire
481
	 * - Nombre d'utilisateurs ayant fait une action
505
	 * - Nombre d'utilisateurs ayant fait une action
482
	 */
506
	 */
483
	private function getUtilisateursIp() {
507
	private function getUtilisateursIp() {
484
		return array(
508
		return array(
485
			'nbUtilisateursTotal' => $this->getNbUtilisateursIpTotal(),
509
			'nbUtilisateursTotal' => $this->getNbUtilisateursIpTotal(),
486
			'nbUtilisateursAFProposition' => $this->getNbUtilisateursAFProposition(),
510
			'nbUtilisateursAFProposition' => $this->getNbUtilisateursAFProposition(),
487
			'nbUtilisateursAFCommentaire' => $this->getNbUtilisateursAFCommentaire(),
511
			'nbUtilisateursAFCommentaire' => $this->getNbUtilisateursAFCommentaire(),
488
			'nbUtilisateursAFVote' => $this->getNbUtilisateursAFVote(),
512
			'nbUtilisateursAFVote' => $this->getNbUtilisateursAFVote(),
489
			'nbUtilisateursAnonymesAFVote' => $this->getNbUtilisateursAnonymesAFVote(),
513
			'nbUtilisateursAnonymesAFVote' => $this->getNbUtilisateursAnonymesAFVote(),
490
			'nbUtilisateursAFAction' => $this->getNbUtilisateursAFAction(),
514
			'nbUtilisateursAFAction' => $this->getNbUtilisateursAFAction(),
491
			'nbUtilisateursAFPropositionMPM' => $this->getNbUtilisateursAFProposition(true),
515
			'nbUtilisateursAFPropositionMPM' => $this->getNbUtilisateursAFProposition(true),
492
			'nbUtilisateursAFCommentaireMPM' => $this->getNbUtilisateursAFCommentaire(true),
516
			'nbUtilisateursAFCommentaireMPM' => $this->getNbUtilisateursAFCommentaire(true),
493
			'nbUtilisateursAFVoteMPM' => $this->getNbUtilisateursAFVote(true),
517
			'nbUtilisateursAFVoteMPM' => $this->getNbUtilisateursAFVote(true),
494
			'nbUtilisateursAnonymesAFVoteMPM' => $this->getNbUtilisateursAnonymesAFVote(true),
518
			'nbUtilisateursAnonymesAFVoteMPM' => $this->getNbUtilisateursAnonymesAFVote(true),
495
			'nbUtilisateursAFActionMPM' => $this->getNbUtilisateursAFActionMPM()
519
			'nbUtilisateursAFActionMPM' => $this->getNbUtilisateursAFActionMPM()
496
		);
520
		);
497
	}
521
	}
498
 
522
 
499
	/**
523
	/**
500
	 * Nombre total d'utilisateurs d'Identiplante
524
	 * Nombre total d'utilisateurs d'Identiplante
501
	 */
525
	 */
502
	private function getNbUtilisateursIpTotal() {
526
	private function getNbUtilisateursIpTotal() {
503
		$requete = "SELECT COUNT(DISTINCT ce_utilisateur) AS nb_total  FROM del_commentaire";
527
		$requete = "SELECT COUNT(DISTINCT ce_utilisateur) AS nb_total  FROM del_commentaire";
504
		if ($this->annee != null) {
528
		if ($this->annee != null) {
505
			$requete .= ' WHERE YEAR(date) = ' . $this->annee;
529
			$requete .= ' WHERE YEAR(date) = ' . $this->annee;
506
		}
530
		}
507
		$resultat = $this->bdd->recupererTous($requete);
531
		$resultat = $this->bdd->recupererTous($requete);
508
		return intval(array_pop($resultat[0]));
532
		return intval(array_pop($resultat[0]));
509
	}
533
	}
510
 
534
 
511
	/**
535
	/**
512
	 * Nombre d'utilisateurs d'Identiplante ayant fait au moins une proposition
536
	 * Nombre d'utilisateurs d'Identiplante ayant fait au moins une proposition
513
	 */
537
	 */
514
	private function getNbUtilisateursAFProposition($mpm=false) {
538
	private function getNbUtilisateursAFProposition($mpm=false) {
515
		$requete = "SELECT COUNT(DISTINCT utilisateur_courriel) AS nb_total FROM del_commentaire WHERE ce_proposition = '' AND nom_sel IS NOT NULL AND nom_sel != ''";
539
		$requete = "SELECT COUNT(DISTINCT utilisateur_courriel) AS nb_total FROM del_commentaire WHERE ce_proposition = '' AND nom_sel IS NOT NULL AND nom_sel != ''";
516
		if ($this->annee != null) {
540
		if ($this->annee != null) {
517
			$requete .= ' AND YEAR(date) = ' . $this->annee;
541
			$requete .= ' AND YEAR(date) = ' . $this->annee;
518
		}
542
		}
519
		if ($mpm) {
543
		if ($mpm) {
520
			$requete = $this->encapsulerMPM($requete);
544
			$requete = $this->encapsulerMPM($requete);
521
		}
545
		}
522
		$resultat = $this->bdd->recupererTous($requete);
546
		$resultat = $this->bdd->recupererTous($requete);
523
		return intval(array_pop($resultat[0]));
547
		return intval(array_pop($resultat[0]));
524
	}
548
	}
525
 
549
 
526
	/**
550
	/**
527
	 * Nombre d'utilisateurs d'Identiplante ayant fait au moins un commentaire
551
	 * Nombre d'utilisateurs d'Identiplante ayant fait au moins un commentaire
528
	 */
552
	 */
529
	private function getNbUtilisateursAFCommentaire($mpm=false) {
553
	private function getNbUtilisateursAFCommentaire($mpm=false) {
530
		$requete = "SELECT COUNT(DISTINCT utilisateur_courriel) AS nb_total FROM del_commentaire WHERE ce_proposition != '' AND (nom_sel IS NULL OR nom_sel = '')";
554
		$requete = "SELECT COUNT(DISTINCT utilisateur_courriel) AS nb_total FROM del_commentaire WHERE ce_proposition != '' AND (nom_sel IS NULL OR nom_sel = '')";
531
		if ($this->annee != null) {
555
		if ($this->annee != null) {
532
			$requete .= ' AND YEAR(date) = ' . $this->annee;
556
			$requete .= ' AND YEAR(date) = ' . $this->annee;
533
		}
557
		}
534
		if ($mpm) {
558
		if ($mpm) {
535
			$requete = $this->encapsulerMPM($requete);
559
			$requete = $this->encapsulerMPM($requete);
536
		}
560
		}
537
		$resultat = $this->bdd->recupererTous($requete);
561
		$resultat = $this->bdd->recupererTous($requete);
538
		return intval(array_pop($resultat[0]));
562
		return intval(array_pop($resultat[0]));
539
	}
563
	}
540
 
564
 
541
	/**
565
	/**
542
	 * Nombre d'utilisateurs d'Identiplante identifiés prenant part aux votes
566
	 * Nombre d'utilisateurs d'Identiplante identifiés prenant part aux votes
543
	 */
567
	 */
544
	private function getNbUtilisateursAFVote($mpm=false) {
568
	private function getNbUtilisateursAFVote($mpm=false) {
545
		$requete = "SELECT COUNT(DISTINCT ce_utilisateur) AS nb_total FROM del_commentaire_vote WHERE ce_utilisateur REGEXP '^-?[0-9]+$'";
569
		$requete = "SELECT COUNT(DISTINCT ce_utilisateur) AS nb_total FROM del_commentaire_vote WHERE ce_utilisateur REGEXP '^-?[0-9]+$'";
546
		if ($this->annee != null) {
570
		if ($this->annee != null) {
547
			$requete .= ' AND YEAR(date) = ' . $this->annee;
571
			$requete .= ' AND YEAR(date) = ' . $this->annee;
548
		}
572
		}
549
		if ($mpm) {
573
		if ($mpm) {
550
			$requete = $this->encapsulerMPM($requete);
574
			$requete = $this->encapsulerMPM($requete);
551
		}
575
		}
552
		$resultat = $this->bdd->recupererTous($requete);
576
		$resultat = $this->bdd->recupererTous($requete);
553
		return intval(array_pop($resultat[0]));
577
		return intval(array_pop($resultat[0]));
554
	}
578
	}
555
 
579
 
556
	/**
580
	/**
557
	 * Nombre d'utilisateurs d'Identiplante anonymes prenant part aux votes
581
	 * Nombre d'utilisateurs d'Identiplante anonymes prenant part aux votes
558
	 */
582
	 */
559
	private function getNbUtilisateursAnonymesAFVote($mpm=false) {
583
	private function getNbUtilisateursAnonymesAFVote($mpm=false) {
560
		$requete = "SELECT COUNT(DISTINCT ce_utilisateur) AS nb_total FROM del_commentaire_vote WHERE ce_utilisateur NOT REGEXP '^-?[0-9]+$'";
584
		$requete = "SELECT COUNT(DISTINCT ce_utilisateur) AS nb_total FROM del_commentaire_vote WHERE ce_utilisateur NOT REGEXP '^-?[0-9]+$'";
561
		if ($this->annee != null) {
585
		if ($this->annee != null) {
562
			$requete .= ' AND YEAR(date) = ' . $this->annee;
586
			$requete .= ' AND YEAR(date) = ' . $this->annee;
563
		}
587
		}
564
		if ($mpm) {
588
		if ($mpm) {
565
			$requete = $this->encapsulerMPM($requete);
589
			$requete = $this->encapsulerMPM($requete);
566
		}
590
		}
567
		$resultat = $this->bdd->recupererTous($requete);
591
		$resultat = $this->bdd->recupererTous($requete);
568
		return intval(array_pop($resultat[0]));
592
		return intval(array_pop($resultat[0]));
569
	}
593
	}
570
 
594
 
571
	/**
595
	/**
572
	 * Nombre d'utilisateurs d'Identiplante ayant fait une action (commentaire, vote, proposition)
596
	 * Nombre d'utilisateurs d'Identiplante ayant fait une action (commentaire, vote, proposition)
573
	 */
597
	 */
574
	private function getNbUtilisateursAFAction() {
598
	private function getNbUtilisateursAFAction() {
575
		$requete = "SELECT COUNT(*) AS nb_total FROM (SELECT ce_utilisateur FROM del_commentaire_vote";
599
		$requete = "SELECT COUNT(*) AS nb_total FROM (SELECT ce_utilisateur FROM del_commentaire_vote";
576
		if ($this->annee != null) {
600
		if ($this->annee != null) {
577
			$requete .= ' WHERE YEAR(date) = ' . $this->annee;
601
			$requete .= ' WHERE YEAR(date) = ' . $this->annee;
578
		}
602
		}
579
		$requete .= " UNION SELECT ce_utilisateur FROM del_commentaire";
603
		$requete .= " UNION SELECT ce_utilisateur FROM del_commentaire";
580
		if ($this->annee != null) {
604
		if ($this->annee != null) {
581
			$requete .= ' WHERE YEAR(date) = ' . $this->annee;
605
			$requete .= ' WHERE YEAR(date) = ' . $this->annee;
582
		}
606
		}
583
		$requete .= " ) AS action";
607
		$requete .= " ) AS action";
584
		$resultat = $this->bdd->recupererTous($requete);
608
		$resultat = $this->bdd->recupererTous($requete);
585
		return intval(array_pop($resultat[0]));
609
		return intval(array_pop($resultat[0]));
586
	}
610
	}
587
 
611
 
588
	/**
612
	/**
589
	 * Moyenne par mois du nombre d'utilisateurs d'Identiplante ayant fait une action
613
	 * Moyenne par mois du nombre d'utilisateurs d'Identiplante ayant fait une action
590
	 * (commentaire, vote, proposition) -> n'est pas encapsulable par encapsulerMPM()
614
	 * (commentaire, vote, proposition) -> n'est pas encapsulable par encapsulerMPM()
591
	 */
615
	 */
592
	private function getNbUtilisateursAFActionMPM() {
616
	private function getNbUtilisateursAFActionMPM() {
593
		$requete = "SELECT avg(nb_total) FROM (SELECT count(*) as nb_total FROM"
617
		$requete = "SELECT avg(nb_total) FROM (SELECT count(*) as nb_total FROM"
594
			. " (SELECT * FROM (SELECT ce_utilisateur, date FROM del_commentaire_vote";
618
			. " (SELECT * FROM (SELECT ce_utilisateur, date FROM del_commentaire_vote";
595
		if ($this->annee != null) {
619
		if ($this->annee != null) {
596
			$requete .= ' WHERE YEAR(date) = ' . $this->annee;
620
			$requete .= ' WHERE YEAR(date) = ' . $this->annee;
597
		}
621
		}
598
		$requete .= " UNION SELECT ce_utilisateur, date FROM del_commentaire";
622
		$requete .= " UNION SELECT ce_utilisateur, date FROM del_commentaire";
599
		if ($this->annee != null) {
623
		if ($this->annee != null) {
600
			$requete .= ' WHERE YEAR(date) = ' . $this->annee;
624
			$requete .= ' WHERE YEAR(date) = ' . $this->annee;
601
		}
625
		}
602
		$requete .= " ) AS action GROUP BY ce_utilisateur) AS utildate GROUP BY CONCAT(year(date),month(date))) as truc";
626
		$requete .= " ) AS action GROUP BY ce_utilisateur) AS utildate GROUP BY CONCAT(year(date),month(date))) as truc";
603
		$resultat = $this->bdd->recupererTous($requete);
627
		$resultat = $this->bdd->recupererTous($requete);
604
		return intval(array_pop($resultat[0]));
628
		return intval(array_pop($resultat[0]));
605
	}
629
	}
606
 
630
 
607
	/**
631
	/**
608
	 * Liste des utilisateurs dont les propositions ont été votées positivement
632
	 * Liste des utilisateurs dont les propositions ont été votées positivement
609
	 */
633
	 */
610
	private function getListeMeilleursProposeurs() {
634
	private function getListeMeilleursProposeurs() {
611
		$liste = array();
635
		$liste = array();
612
		$requete = "SELECT * FROM (SELECT utilisateur_courriel, ce_utilisateur, count(prop) as nb_prop"
636
		$requete = "SELECT * FROM (SELECT utilisateur_courriel, ce_utilisateur, count(prop) as nb_prop"
613
			. " FROM (SELECT ce_proposition as prop, COUNT(DISTINCT id_vote) AS nb_vote FROM del_commentaire_vote where";
637
			. " FROM (SELECT ce_proposition as prop, COUNT(DISTINCT id_vote) AS nb_vote FROM del_commentaire_vote where";
614
		if ($this->annee != null) {
638
		if ($this->annee != null) {
615
			$requete .= " year(date) = " . $this->annee . " AND";
639
			$requete .= " year(date) = " . $this->annee . " AND";
616
		}
640
		}
617
		$requete .= " valeur = 1 GROUP BY ce_proposition) AS vote, del_commentaire WHERE nb_vote > 3 AND prop = id_commentaire AND ce_utilisateur != 0 GROUP BY ce_utilisateur)"
641
		$requete .= " valeur = 1 GROUP BY ce_proposition) AS vote, del_commentaire WHERE nb_vote > 3 AND prop = id_commentaire AND ce_utilisateur != 0 GROUP BY ce_utilisateur)"
618
			. " AS utlisateurs WHERE nb_prop > 10 ORDER BY nb_prop  DESC LIMIT 20";
642
			. " AS utlisateurs WHERE nb_prop > 10 ORDER BY nb_prop  DESC LIMIT 20";
619
		$resultat = $this->bdd->recupererTous($requete);
643
		$resultat = $this->bdd->recupererTous($requete);
620
 
644
 
621
		// Formatage de la liste avec les intitulés des utilisateurs
645
		// Formatage de la liste avec les intitulés des utilisateurs
622
		$ids = array_column($resultat, 'ce_utilisateur');
646
		$ids = array_column($resultat, 'ce_utilisateur');
623
		$ids = array_filter($ids, 'is_numeric'); // on oublie les ids de session et autres facéties
647
		$ids = array_filter($ids, 'is_numeric'); // on oublie les ids de session et autres facéties
624
		$infosUtilisateurs = $this->recupererIntitulesUtilisateursParIds($ids, true);
648
		$infosUtilisateurs = $this->recupererIntitulesUtilisateursParIds($ids, true);
625
		foreach ($resultat as &$util) {
649
		foreach ($resultat as &$util) {
626
			$ce = $util['ce_utilisateur'];
650
			$ce = $util['ce_utilisateur'];
627
			$util['intitule'] = isset($infosUtilisateurs[$ce]['intitule']) ? $infosUtilisateurs[$ce]['intitule'] : null;
651
			$util['intitule'] = isset($infosUtilisateurs[$ce]['intitule']) ? $infosUtilisateurs[$ce]['intitule'] : null;
628
		}
652
		}
629
 
653
 
630
		return array(
654
		return array(
631
				'liste' => $resultat
655
				'liste' => $resultat
632
		);
656
		);
633
	}
657
	}
634
 
658
 
635
	/**
659
	/**
636
	 * Liste des utilisateurs ayant fait le plus de votes positifs
660
	 * Liste des utilisateurs ayant fait le plus de votes positifs
637
	 * @TODO et le plus de votes sur des propositions retenues (ou ayant atteint un consensus)
661
	 * @TODO et le plus de votes sur des propositions retenues (ou ayant atteint un consensus)
638
	 */
662
	 */
639
	private function getListeMeilleursVoteurs() {
663
	private function getListeMeilleursVoteurs() {
640
		$liste = array();
664
		$liste = array();
641
		$requete = "SELECT * FROM (SELECT courriel, ce_utilisateur, COUNT(DISTINCT id_vote) AS nombre FROM del_commentaire_vote, del_utilisateur where";
665
		$requete = "SELECT * FROM (SELECT courriel, ce_utilisateur, COUNT(DISTINCT id_vote) AS nombre FROM del_commentaire_vote, del_utilisateur where";
642
		if ($this->annee != null) {
666
		if ($this->annee != null) {
643
			$requete .= " year(date) = " . $this->annee . " AND";
667
			$requete .= " year(date) = " . $this->annee . " AND";
644
		}
668
		}
645
		$requete .= " ce_utilisateur = id_utilisateur AND valeur = 1 GROUP BY ce_utilisateur) AS utilisateurs WHERE nombre > 100 ORDER BY nombre DESC LIMIT 20";
669
		$requete .= " ce_utilisateur = id_utilisateur AND valeur = 1 GROUP BY ce_utilisateur) AS utilisateurs WHERE nombre > 100 ORDER BY nombre DESC LIMIT 20";
646
		$resultat = $this->bdd->recupererTous($requete);
670
		$resultat = $this->bdd->recupererTous($requete);
647
 
671
 
648
		// Formatage de la liste avec les intitulés des utilisateurs
672
		// Formatage de la liste avec les intitulés des utilisateurs
649
		$ids = array_column($resultat, 'ce_utilisateur');
673
		$ids = array_column($resultat, 'ce_utilisateur');
650
		$ids = array_filter($ids, 'is_numeric'); // on oublie les ids de session et autres facéties
674
		$ids = array_filter($ids, 'is_numeric'); // on oublie les ids de session et autres facéties
651
		$infosUtilisateurs = $this->recupererIntitulesUtilisateursParIds($ids, true);
675
		$infosUtilisateurs = $this->recupererIntitulesUtilisateursParIds($ids, true);
652
		foreach ($resultat as &$util) {
676
		foreach ($resultat as &$util) {
653
			$ce = $util['ce_utilisateur'];
677
			$ce = $util['ce_utilisateur'];
654
			$util['intitule'] = isset($infosUtilisateurs[$ce]['intitule']) ? $infosUtilisateurs[$ce]['intitule'] : null;
678
			$util['intitule'] = isset($infosUtilisateurs[$ce]['intitule']) ? $infosUtilisateurs[$ce]['intitule'] : null;
655
		}
679
		}
656
 
680
 
657
		return array(
681
		return array(
658
				'liste' => $resultat
682
				'liste' => $resultat
659
		);
683
		);
660
	}
684
	}
661
 
685
 
662
	/**
686
	/**
663
	 * Liste des utilisateurs ayant fait au moins une proposition par mois toute l'année
687
	 * Liste des utilisateurs ayant fait au moins une proposition par mois toute l'année
664
	 */
688
	 */
665
	private function getListeProposeursReguliers() {
689
	private function getListeProposeursReguliers() {
666
		$liste = array();
690
		$liste = array();
667
		$requete = "SELECT cal.nbmois, SUM(somme) / cal.nbmois as moyenne, ce_utilisateur, utilisateur_courriel FROM (SELECT count(*) as somme,"
691
		$requete = "SELECT cal.nbmois, SUM(somme) / cal.nbmois as moyenne, ce_utilisateur, utilisateur_courriel FROM (SELECT count(*) as somme,"
668
			. " CONCAT(YEAR(date),'-',MONTH(date)) as anneemois, ce_utilisateur, utilisateur_courriel, id_commentaire FROM del_commentaire"
692
			. " CONCAT(YEAR(date),'-',MONTH(date)) as anneemois, ce_utilisateur, utilisateur_courriel, id_commentaire FROM del_commentaire"
669
			. " WHERE ce_proposition = '' AND nom_sel_nn != '' AND nom_sel_nn IS NOT NULL";
693
			. " WHERE ce_proposition = '' AND nom_sel_nn != '' AND nom_sel_nn IS NOT NULL";
670
		if ($this->annee != null) {
694
		if ($this->annee != null) {
671
			$requete .= " AND year(date) = " . $this->annee;
695
			$requete .= " AND year(date) = " . $this->annee;
672
		}
696
		}
673
		$requete .= "  GROUP BY anneemois, ce_utilisateur, utilisateur_courriel) as ppm, (SELECT count(distinct CONCAT(YEAR(date),'-',MONTH(date))) as nbmois FROM del_commentaire WHERE";
697
		$requete .= "  GROUP BY anneemois, ce_utilisateur, utilisateur_courriel) as ppm, (SELECT count(distinct CONCAT(YEAR(date),'-',MONTH(date))) as nbmois FROM del_commentaire WHERE";
674
		if ($this->annee != null) {
698
		if ($this->annee != null) {
675
			$requete .= " year(date) = " . $this->annee . " AND";
699
			$requete .= " year(date) = " . $this->annee . " AND";
676
		}
700
		}
677
		$requete .= " ce_proposition = '' AND nom_sel_nn != '' AND nom_sel_nn IS NOT NULL) as cal GROUP BY ce_utilisateur, utilisateur_courriel HAVING SUM(somme) / cal.nbmois >= 1"
701
		$requete .= " ce_proposition = '' AND nom_sel_nn != '' AND nom_sel_nn IS NOT NULL) as cal GROUP BY ce_utilisateur, utilisateur_courriel HAVING SUM(somme) / cal.nbmois >= 1"
678
			. " ORDER BY moyenne DESC"; // @ TODO limite ?
702
			. " ORDER BY moyenne DESC"; // @ TODO limite ?
679
		$resultat = $this->bdd->recupererTous($requete);
703
		$resultat = $this->bdd->recupererTous($requete);
680
 
704
 
681
		// Formatage de la liste avec les intitulés des utilisateurs
705
		// Formatage de la liste avec les intitulés des utilisateurs
682
		$ids = array_column($resultat, 'ce_utilisateur');
706
		$ids = array_column($resultat, 'ce_utilisateur');
683
		$ids = array_filter($ids, 'is_numeric'); // on oublie les ids de session et autres facéties
707
		$ids = array_filter($ids, 'is_numeric'); // on oublie les ids de session et autres facéties
684
		$infosUtilisateurs = $this->recupererIntitulesUtilisateursParIds($ids, true);
708
		$infosUtilisateurs = $this->recupererIntitulesUtilisateursParIds($ids, true);
685
		foreach ($resultat as &$util) {
709
		foreach ($resultat as &$util) {
686
			$ce = $util['ce_utilisateur'];
710
			$ce = $util['ce_utilisateur'];
687
			$util['intitule'] = isset($infosUtilisateurs[$ce]['intitule']) ? $infosUtilisateurs[$ce]['intitule'] : null;
711
			$util['intitule'] = isset($infosUtilisateurs[$ce]['intitule']) ? $infosUtilisateurs[$ce]['intitule'] : null;
688
		}
712
		}
689
 
713
 
690
		return array(
714
		return array(
691
			'liste' => $resultat
715
			'liste' => $resultat
692
		);
716
		);
693
	}
717
	}
694
 
718
 
695
	/**
719
	/**
696
	 * Statistiques sur Sauvages de ma Rue (Sdmr)
720
	 * Statistiques sur Sauvages de ma Rue (Sdmr)
697
	 * "MPM" = moyenne par mois
721
	 * "MPM" = moyenne par mois
698
	 * - Nombre total d'observations sdmr
722
	 * - Nombre total d'observations sdmr
699
	 * - Nombre d'observations Sauvages de PACA
723
	 * - Nombre d'observations Sauvages de PACA
700
	 */
724
	 */
701
	private function getSdmr() {
725
	private function getSdmr() {
702
		return array(
726
		return array(
703
			'nbObsSdmrTotal' => $this->getNbObsSdmrTotal(),
727
			'nbObsSdmrTotal' => $this->getNbObsSdmrTotal(),
704
			'nbObsSdmrTotalMPM' => $this->getNbObsSdmrTotal(true),
728
			'nbObsSdmrTotalMPM' => $this->getNbObsSdmrTotal(true),
705
			'nbObsSdmrPACA' => $this->getNbObsSdmrPACA(),
729
			'nbObsSdmrPACA' => $this->getNbObsSdmrPACA(),
706
			'nbObsSdmrPACAMPM' => $this->getNbObsSdmrPACA(true)
730
			'nbObsSdmrPACAMPM' => $this->getNbObsSdmrPACA(true)
707
		);
731
		);
708
	}
732
	}
709
 
733
 
710
	/**
734
	/**
711
	 * Nombre total d'observations Sauvages de ma Rue
735
	 * Nombre total d'observations Sauvages de ma Rue
712
	 */
736
	 */
713
	private function getNbObsSdmrTotal($mpm=false) {
737
	private function getNbObsSdmrTotal($mpm=false) {
714
		$requete = "SELECT COUNT(DISTINCT ce_observation) as nb_total FROM del_commentaire WHERE";
738
		$requete = "SELECT COUNT(DISTINCT ce_observation) as nb_total FROM del_commentaire WHERE";
715
		if ($this->annee != null) {
739
		if ($this->annee != null) {
716
			$requete .= ' YEAR(date) <= ' . $this->annee . ' AND';
740
			$requete .= ' YEAR(date) <= ' . $this->annee . ' AND';
717
		}
741
		}
718
		$requete .= " ce_observation in (SELECT id_observation FROM del_observation WHERE mots_cles_texte like '%sauvages%')";
742
		$requete .= " ce_observation in (SELECT id_observation FROM del_observation WHERE mots_cles_texte like '%sauvages%')";
719
		if ($mpm) {
743
		if ($mpm) {
720
			$requete = $this->encapsulerMPM($requete);
744
			$requete = $this->encapsulerMPM($requete);
721
		}
745
		}
722
		$resultat = $this->bdd->recupererTous($requete);
746
		$resultat = $this->bdd->recupererTous($requete);
723
		return intval(array_pop($resultat[0]));
747
		return intval(array_pop($resultat[0]));
724
	}
748
	}
725
 
749
 
726
	/**
750
	/**
727
	 * Nombre total d'observations Sauvages de ma Rue en PACA
751
	 * Nombre total d'observations Sauvages de ma Rue en PACA
728
	 */
752
	 */
729
	private function getNbObsSdmrPACA($mpm=false) {
753
	private function getNbObsSdmrPACA($mpm=false) {
730
		$requete = "SELECT COUNT(DISTINCT ce_observation) as nb_total FROM del_commentaire WHERE";
754
		$requete = "SELECT COUNT(DISTINCT ce_observation) as nb_total FROM del_commentaire WHERE";
731
		if ($this->annee != null) {
755
		if ($this->annee != null) {
732
			$requete .= ' YEAR(date) <= ' . $this->annee . ' AND';
756
			$requete .= ' YEAR(date) <= ' . $this->annee . ' AND';
733
		}
757
		}
734
		$requete .= " ce_observation in (SELECT id_observation FROM del_observation"
758
		$requete .= " ce_observation in (SELECT id_observation FROM del_observation"
735
			. " WHERE SUBSTR(ce_zone_geo, 9 , 2) IN (13,04,05,06,83,84) AND mots_cles_texte like '%sauvages%')";
759
			. " WHERE SUBSTR(ce_zone_geo, 9 , 2) IN (13,04,05,06,83,84) AND mots_cles_texte like '%sauvages%')";
736
		if ($mpm) {
760
		if ($mpm) {
737
			$requete = $this->encapsulerMPM($requete);
761
			$requete = $this->encapsulerMPM($requete);
738
		}
762
		}
739
		$resultat = $this->bdd->recupererTous($requete);
763
		$resultat = $this->bdd->recupererTous($requete);
740
		return intval(array_pop($resultat[0]));
764
		return intval(array_pop($resultat[0]));
741
	}
765
	}
742
 
766
 
743
	/**
767
	/**
744
	 * Statistiques sur les images de Pictoflora
768
	 * Statistiques sur les images de Pictoflora
745
	 * "MPM" = Moyenne par mois
769
	 * "MPM" = Moyenne par mois
746
	 *  - Nombre total d'images
770
	 *  - Nombre total d'images
747
	 *  - Nombre d'images ayant au moins un mot-clé
771
	 *  - Nombre d'images ayant au moins un mot-clé
748
	 *  - Nombre d'images ayant au moins un vote
772
	 *  - Nombre d'images ayant au moins un vote
749
	 *  - Nombre d'images de l'année ayant au moins un mot-clé
773
	 *  - Nombre d'images de l'année ayant au moins un mot-clé
750
	 *  - Nombre d'images de l'année ayant au moins un vote
774
	 *  - Nombre d'images de l'année ayant au moins un vote
751
	 */
775
	 */
752
	private function getImages() {
776
	private function getImages() {
753
		return array(
777
		return array(
754
			'nbImagesTotal' => $this->getNbImagesTotal(),
778
			'nbImagesTotal' => $this->getNbImagesTotal(),
755
			'nbImagesTotalMPM' => $this->getNbImagesTotal(true),
779
			'nbImagesTotalMPM' => $this->getNbImagesTotal(true),
756
			'nbImagesAyantTag' => $this->getNbImagesAyantTag(),
780
			'nbImagesAyantTag' => $this->getNbImagesAyantTag(),
757
			'nbImagesAyantTagMPM' => $this->getNbImagesAyantTag(true),
781
			'nbImagesAyantTagMPM' => $this->getNbImagesAyantTag(true),
758
			'nbImagesAyantVote' => $this->getNbImagesAyantVote(),
782
			'nbImagesAyantVote' => $this->getNbImagesAyantVote(),
759
			'nbImagesAyantVoteMPM' => $this->getNbImagesAyantVote(true),
783
			'nbImagesAyantVoteMPM' => $this->getNbImagesAyantVote(true),
760
			'nbImagesAnneeAyantTag' => $this->getNbImagesAnneeAyantTag(),
784
			'nbImagesAnneeAyantTag' => $this->getNbImagesAnneeAyantTag(),
761
			'nbImagesAnneeAyantTagMPM' => $this->getNbImagesAnneeAyantTag(true),
785
			'nbImagesAnneeAyantTagMPM' => $this->getNbImagesAnneeAyantTag(true),
762
			'nbImagesAnneeAyantVote' => $this->getNbImagesAnneeAyantVote(),
786
			'nbImagesAnneeAyantVote' => $this->getNbImagesAnneeAyantVote(),
763
			'nbImagesAnneeAyantVoteMPM' => $this->getNbImagesAnneeAyantVote(true),
787
			'nbImagesAnneeAyantVoteMPM' => $this->getNbImagesAnneeAyantVote(true),
764
		);
788
		);
765
	}
789
	}
766
 
790
 
767
	/**
791
	/**
768
	 * Nombre total d'images Pictoflora
792
	 * Nombre total d'images Pictoflora
769
	 */
793
	 */
770
	private function getNbImagesTotal($mpm=false) {
794
	private function getNbImagesTotal($mpm=false) {
771
		$requete = "SELECT COUNT(*) AS nb_total FROM del_image";
795
		$requete = "SELECT COUNT(*) AS nb_total FROM del_image";
772
		if ($this->annee != null) {
796
		if ($this->annee != null) {
773
			$requete .= ' WHERE YEAR(date_transmission) = ' . $this->annee;
797
			$requete .= ' WHERE YEAR(date_transmission) = ' . $this->annee;
774
		}
798
		}
775
		if ($mpm) {
799
		if ($mpm) {
776
			$requete = $this->encapsulerMPM($requete, 'date_transmission');
800
			$requete = $this->encapsulerMPM($requete, 'date_transmission');
777
		}
801
		}
778
		$resultat = $this->bdd->recupererTous($requete);
802
		$resultat = $this->bdd->recupererTous($requete);
779
		return intval(array_pop($resultat[0]));
803
		return intval(array_pop($resultat[0]));
780
	}
804
	}
781
 
805
 
782
	/**
806
	/**
783
	 * Nombre total d'images Pictoflora ayant au moins un mot-clé
807
	 * Nombre total d'images Pictoflora ayant au moins un mot-clé
784
	 */
808
	 */
785
	private function getNbImagesAyantTag($mpm=false) {
809
	private function getNbImagesAyantTag($mpm=false) {
786
		$requete = "SELECT COUNT(DISTINCT ce_image) AS nb_total FROM del_image_tag";
810
		$requete = "SELECT COUNT(DISTINCT ce_image) AS nb_total FROM del_image_tag";
787
		if ($this->annee != null) {
811
		if ($this->annee != null) {
788
			$requete .= ' WHERE YEAR(date) = ' . $this->annee;
812
			$requete .= ' WHERE YEAR(date) = ' . $this->annee;
789
		}
813
		}
790
		if ($mpm) {
814
		if ($mpm) {
791
			$requete = $this->encapsulerMPM($requete);
815
			$requete = $this->encapsulerMPM($requete);
792
		}
816
		}
793
		$resultat = $this->bdd->recupererTous($requete);
817
		$resultat = $this->bdd->recupererTous($requete);
794
		return intval(array_pop($resultat[0]));
818
		return intval(array_pop($resultat[0]));
795
	}
819
	}
796
 
820
 
797
	/**
821
	/**
798
	 * Nombre total d'images Pictoflora ayant au moins un vote
822
	 * Nombre total d'images Pictoflora ayant au moins un vote
799
	 */
823
	 */
800
	private function getNbImagesAyantVote($mpm=false) {
824
	private function getNbImagesAyantVote($mpm=false) {
801
		$requete = "SELECT COUNT(DISTINCT ce_image) AS nb_total FROM del_image_vote";
825
		$requete = "SELECT COUNT(DISTINCT ce_image) AS nb_total FROM del_image_vote";
802
		if ($this->annee != null) {
826
		if ($this->annee != null) {
803
			$requete .= ' WHERE YEAR(date) = ' . $this->annee;
827
			$requete .= ' WHERE YEAR(date) = ' . $this->annee;
804
		}
828
		}
805
		if ($mpm) {
829
		if ($mpm) {
806
			$requete = $this->encapsulerMPM($requete);
830
			$requete = $this->encapsulerMPM($requete);
807
		}
831
		}
808
		$resultat = $this->bdd->recupererTous($requete);
832
		$resultat = $this->bdd->recupererTous($requete);
809
		return intval(array_pop($resultat[0]));
833
		return intval(array_pop($resultat[0]));
810
	}
834
	}
811
 
835
 
812
	/**
836
	/**
813
	 * Nombre total d'images Pictoflora de l'année ayant au moins un mot-clé
837
	 * Nombre total d'images Pictoflora de l'année ayant au moins un mot-clé
814
	 */
838
	 */
815
	private function getNbImagesAnneeAyantTag($mpm=false) {
839
	private function getNbImagesAnneeAyantTag($mpm=false) {
816
		if ($this->annee == null) {
840
		if ($this->annee == null) {
817
			return null;
841
			return null;
818
		}
842
		}
819
		$requete = "SELECT COUNT(DISTINCT ce_image) AS nb_total FROM del_image_tag WHERE YEAR(date) = " . $this->annee
843
		$requete = "SELECT COUNT(DISTINCT ce_image) AS nb_total FROM del_image_tag WHERE YEAR(date) = " . $this->annee
820
			. " AND ce_image IN (SELECT id_image FROM del_image WHERE year(date_transmission) = " . $this->annee . ")";
844
			. " AND ce_image IN (SELECT id_image FROM del_image WHERE year(date_transmission) = " . $this->annee . ")";
821
		if ($mpm) {
845
		if ($mpm) {
822
			$requete = $this->encapsulerMPM($requete);
846
			$requete = $this->encapsulerMPM($requete);
823
		}
847
		}
824
		$resultat = $this->bdd->recupererTous($requete);
848
		$resultat = $this->bdd->recupererTous($requete);
825
		return intval(array_pop($resultat[0]));
849
		return intval(array_pop($resultat[0]));
826
	}
850
	}
827
 
851
 
828
	/**
852
	/**
829
	 * Nombre total d'images Pictoflora de l'année ayant au moins un vote
853
	 * Nombre total d'images Pictoflora de l'année ayant au moins un vote
830
	 */
854
	 */
831
	private function getNbImagesAnneeAyantVote($mpm=false) {
855
	private function getNbImagesAnneeAyantVote($mpm=false) {
832
		if ($this->annee == null) {
856
		if ($this->annee == null) {
833
			return null;
857
			return null;
834
		}
858
		}
835
		$requete = "SELECT COUNT(DISTINCT ce_image) AS nb_total FROM del_image_vote WHERE YEAR(date) = " . $this->annee
859
		$requete = "SELECT COUNT(DISTINCT ce_image) AS nb_total FROM del_image_vote WHERE YEAR(date) = " . $this->annee
836
			. " AND ce_image IN (SELECT id_image FROM del_image WHERE year(date_transmission) = " . $this->annee . ")";
860
			. " AND ce_image IN (SELECT id_image FROM del_image WHERE year(date_transmission) = " . $this->annee . ")";
837
		if ($mpm) {
861
		if ($mpm) {
838
			$requete = $this->encapsulerMPM($requete);
862
			$requete = $this->encapsulerMPM($requete);
839
		}
863
		}
840
		$resultat = $this->bdd->recupererTous($requete);
864
		$resultat = $this->bdd->recupererTous($requete);
841
		return intval(array_pop($resultat[0]));
865
		return intval(array_pop($resultat[0]));
842
	}
866
	}
843
 
867
 
844
	/**
868
	/**
845
	 * Statistiques sur les votes et mots-clés (tags) de Pictoflora
869
	 * Statistiques sur les votes et mots-clés (tags) de Pictoflora
846
	 * "MPM" = moyenne par mois
870
	 * "MPM" = moyenne par mois
847
	 * - Nombre total de votes
871
	 * - Nombre total de votes
848
	 * - Nombre total de mots clés
872
	 * - Nombre total de mots clés
849
	 * - Nombre d'images ayant le mot-clé "defiPhoto"
873
	 * - Nombre d'images ayant le mot-clé "defiPhoto"
850
	 */
874
	 */
851
	private function getTagsVotes() {
875
	private function getTagsVotes() {
852
		return array(
876
		return array(
853
			'nbTagsTotal' => $this->getNbTagsTotal(),
877
			'nbTagsTotal' => $this->getNbTagsTotal(),
854
			'nbTagsTotalMPM' => $this->getNbTagsTotal(true),
878
			'nbTagsTotalMPM' => $this->getNbTagsTotal(true),
855
			'nbVotesTotal' => $this->getNbVotesTotal(),
879
			'nbVotesTotal' => $this->getNbVotesTotal(),
856
			'nbVotesTotalMPM' => $this->getNbVotesTotal(true),
880
			'nbVotesTotalMPM' => $this->getNbVotesTotal(true),
857
			// devra être paramétré par une liste de mots-clés
881
			// devra être paramétré par une liste de mots-clés
858
			//'nbImagesTagDP' => $this->getNbImagesTagDP(),
882
			//'nbImagesTagDP' => $this->getNbImagesTagDP(),
859
			//'nbImagesTagDPMPM' => $this->getNbImagesTagDP(true)
883
			//'nbImagesTagDPMPM' => $this->getNbImagesTagDP(true)
860
		);
884
		);
861
	}
885
	}
862
 
886
 
863
	/**
887
	/**
864
	 * Nombre total de mots clés Pictoflora
888
	 * Nombre total de mots clés Pictoflora
865
	 */
889
	 */
866
	private function getNbTagsTotal($mpm=false) {
890
	private function getNbTagsTotal($mpm=false) {
867
		$requete = "SELECT COUNT(*) AS nb_total FROM del_image_tag";
891
		$requete = "SELECT COUNT(*) AS nb_total FROM del_image_tag";
868
		if ($this->annee != null) {
892
		if ($this->annee != null) {
869
			$requete .= ' WHERE YEAR(date) = ' . $this->annee;
893
			$requete .= ' WHERE YEAR(date) = ' . $this->annee;
870
		}
894
		}
871
		if ($mpm) {
895
		if ($mpm) {
872
			$requete = $this->encapsulerMPM($requete);
896
			$requete = $this->encapsulerMPM($requete);
873
		}
897
		}
874
		$resultat = $this->bdd->recupererTous($requete);
898
		$resultat = $this->bdd->recupererTous($requete);
875
		return intval(array_pop($resultat[0]));
899
		return intval(array_pop($resultat[0]));
876
	}
900
	}
877
 
901
 
878
	/**
902
	/**
879
	 * Nombre total de votes Pictoflora
903
	 * Nombre total de votes Pictoflora
880
	 */
904
	 */
881
	private function getNbVotesTotal($mpm=false) {
905
	private function getNbVotesTotal($mpm=false) {
882
		$requete = "SELECT COUNT(*) AS nb_total FROM del_image_vote";
906
		$requete = "SELECT COUNT(*) AS nb_total FROM del_image_vote";
883
		if ($this->annee != null) {
907
		if ($this->annee != null) {
884
			$requete .= ' WHERE YEAR(date) = ' . $this->annee;
908
			$requete .= ' WHERE YEAR(date) = ' . $this->annee;
885
		}
909
		}
886
		if ($mpm) {
910
		if ($mpm) {
887
			$requete = $this->encapsulerMPM($requete);
911
			$requete = $this->encapsulerMPM($requete);
888
		}
912
		}
889
		$resultat = $this->bdd->recupererTous($requete);
913
		$resultat = $this->bdd->recupererTous($requete);
890
		return intval(array_pop($resultat[0]));
914
		return intval(array_pop($resultat[0]));
891
	}
915
	}
892
 
916
 
893
	/**
917
	/**
894
	 * Statistiques sur les utilisateurs de Pictoflora
918
	 * Statistiques sur les utilisateurs de Pictoflora
895
	 * "MPM" = Moyenne par mois
919
	 * "MPM" = Moyenne par mois
896
	 * "AF" = Ayant fait
920
	 * "AF" = Ayant fait
897
	 * - Nombre d'utilisateurs ayant ajouté un mot-clé
921
	 * - Nombre d'utilisateurs ayant ajouté un mot-clé
898
	 * - Nombre d'utilisateurs ayant voté
922
	 * - Nombre d'utilisateurs ayant voté
899
	 * - Nombre d'utilisateurs ayant fait une action
923
	 * - Nombre d'utilisateurs ayant fait une action
900
	 */
924
	 */
901
	private function getUtilisateursPf() {
925
	private function getUtilisateursPf() {
902
		return array(
926
		return array(
903
			'nbUtilisateursAFTag' => $this->getNbUtilisateursPfAFTag(),
927
			'nbUtilisateursAFTag' => $this->getNbUtilisateursPfAFTag(),
904
			'nbUtilisateursAFTagMPM' => $this->getNbUtilisateursPfAFTag(true),
928
			'nbUtilisateursAFTagMPM' => $this->getNbUtilisateursPfAFTag(true),
905
			'nbUtilisateursAFVote' => $this->getNbUtilisateursPfAFVote(),
929
			'nbUtilisateursAFVote' => $this->getNbUtilisateursPfAFVote(),
906
			'nbUtilisateursAFVoteMPM' => $this->getNbUtilisateursPfAFVote(true),
930
			'nbUtilisateursAFVoteMPM' => $this->getNbUtilisateursPfAFVote(true),
907
			'nbUtilisateursAFAction' => $this->getNbUtilisateursPfAFAction(),
931
			'nbUtilisateursAFAction' => $this->getNbUtilisateursPfAFAction(),
908
			'nbUtilisateursAFActionMPM' => $this->getNbUtilisateursPfAFActionMPM()
932
			'nbUtilisateursAFActionMPM' => $this->getNbUtilisateursPfAFActionMPM()
909
		);
933
		);
910
	}
934
	}
911
 
935
 
912
	/**
936
	/**
913
	 * Nombre d'utilisateurs ayant ajouté un mot-clé
937
	 * Nombre d'utilisateurs ayant ajouté un mot-clé
914
	 */
938
	 */
915
	private function getNbUtilisateursPfAFTag($mpm=false) {
939
	private function getNbUtilisateursPfAFTag($mpm=false) {
916
		$requete = "SELECT COUNT(DISTINCT ce_utilisateur) AS nb_total FROM del_image_tag";
940
		$requete = "SELECT COUNT(DISTINCT ce_utilisateur) AS nb_total FROM del_image_tag";
917
		if ($this->annee != null) {
941
		if ($this->annee != null) {
918
			$requete .= ' WHERE YEAR(date) = ' . $this->annee;
942
			$requete .= ' WHERE YEAR(date) = ' . $this->annee;
919
		}
943
		}
920
		if ($mpm) {
944
		if ($mpm) {
921
			$requete = $this->encapsulerMPM($requete);
945
			$requete = $this->encapsulerMPM($requete);
922
		}
946
		}
923
		$resultat = $this->bdd->recupererTous($requete);
947
		$resultat = $this->bdd->recupererTous($requete);
924
		return intval(array_pop($resultat[0]));
948
		return intval(array_pop($resultat[0]));
925
	}
949
	}
926
 
950
 
927
	/**
951
	/**
928
	 * Nombre d'utilisateurs ayant fait un vote
952
	 * Nombre d'utilisateurs ayant fait un vote
929
	 */
953
	 */
930
	private function getNbUtilisateursPfAFVote($mpm=false) {
954
	private function getNbUtilisateursPfAFVote($mpm=false) {
931
		$requete = "SELECT COUNT(DISTINCT ce_utilisateur) AS nb_total FROM del_image_vote";
955
		$requete = "SELECT COUNT(DISTINCT ce_utilisateur) AS nb_total FROM del_image_vote";
932
		if ($this->annee != null) {
956
		if ($this->annee != null) {
933
			$requete .= ' WHERE YEAR(date) = ' . $this->annee;
957
			$requete .= ' WHERE YEAR(date) = ' . $this->annee;
934
		}
958
		}
935
		if ($mpm) {
959
		if ($mpm) {
936
			$requete = $this->encapsulerMPM($requete);
960
			$requete = $this->encapsulerMPM($requete);
937
		}
961
		}
938
		$resultat = $this->bdd->recupererTous($requete);
962
		$resultat = $this->bdd->recupererTous($requete);
939
		return intval(array_pop($resultat[0]));
963
		return intval(array_pop($resultat[0]));
940
	}
964
	}
941
 
965
 
942
	/**
966
	/**
943
	 * Nombre d'utilisateurs ayant fait une action
967
	 * Nombre d'utilisateurs ayant fait une action
944
	 */
968
	 */
945
	private function getNbUtilisateursPfAFAction() {
969
	private function getNbUtilisateursPfAFAction() {
946
		$requete = "SELECT COUNT(*) AS nb_total FROM (SELECT ce_utilisateur FROM del_image_tag";
970
		$requete = "SELECT COUNT(*) AS nb_total FROM (SELECT ce_utilisateur FROM del_image_tag";
947
		if ($this->annee != null) {
971
		if ($this->annee != null) {
948
			$requete .= ' WHERE YEAR(date) = ' . $this->annee;
972
			$requete .= ' WHERE YEAR(date) = ' . $this->annee;
949
		}
973
		}
950
		$requete .= " UNION SELECT ce_utilisateur FROM del_image_vote";
974
		$requete .= " UNION SELECT ce_utilisateur FROM del_image_vote";
951
		if ($this->annee != null) {
975
		if ($this->annee != null) {
952
			$requete .= ' WHERE YEAR(date) = ' . $this->annee;
976
			$requete .= ' WHERE YEAR(date) = ' . $this->annee;
953
		}
977
		}
954
		$requete .= ") AS action";
978
		$requete .= ") AS action";
955
		$resultat = $this->bdd->recupererTous($requete);
979
		$resultat = $this->bdd->recupererTous($requete);
956
		return intval(array_pop($resultat[0]));
980
		return intval(array_pop($resultat[0]));
957
	}
981
	}
958
 
982
 
959
	/**
983
	/**
960
	 * Moyenne par mois du nombre d'utilisateurs ayant fait une action
984
	 * Moyenne par mois du nombre d'utilisateurs ayant fait une action
961
	 * -> n'est pas encapsulable par encapsulerMPM()
985
	 * -> n'est pas encapsulable par encapsulerMPM()
962
	 */
986
	 */
963
	private function getNbUtilisateursPfAFActionMPM() {
987
	private function getNbUtilisateursPfAFActionMPM() {
964
		$requete = "SELECT avg(nb_total) FROM (SELECT COUNT(*) AS nb_total FROM (SELECT * FROM (SELECT ce_utilisateur, date FROM del_image_tag";
988
		$requete = "SELECT avg(nb_total) FROM (SELECT COUNT(*) AS nb_total FROM (SELECT * FROM (SELECT ce_utilisateur, date FROM del_image_tag";
965
		if ($this->annee != null) {
989
		if ($this->annee != null) {
966
			$requete .= ' WHERE YEAR(date) = ' . $this->annee;
990
			$requete .= ' WHERE YEAR(date) = ' . $this->annee;
967
		}
991
		}
968
		$requete .= " UNION SELECT ce_utilisateur, date FROM del_image_vote";
992
		$requete .= " UNION SELECT ce_utilisateur, date FROM del_image_vote";
969
		if ($this->annee != null) {
993
		if ($this->annee != null) {
970
			$requete .= ' WHERE YEAR(date) = ' . $this->annee;
994
			$requete .= ' WHERE YEAR(date) = ' . $this->annee;
971
		}
995
		}
972
		$requete .= ") AS action GROUP BY ce_utilisateur) AS utildate GROUP BY CONCAT(year(date),month(date))) as truc";
996
		$requete .= ") AS action GROUP BY ce_utilisateur) AS utildate GROUP BY CONCAT(year(date),month(date))) as truc";
973
		$resultat = $this->bdd->recupererTous($requete);
997
		$resultat = $this->bdd->recupererTous($requete);
974
		return intval(array_pop($resultat[0]));
998
		return intval(array_pop($resultat[0]));
975
	}
999
	}
976
 
1000
 
977
	/**
1001
	/**
978
	 * Liste des mots-clés les plus fréquents
1002
	 * Liste des mots-clés les plus fréquents
979
	 */
1003
	 */
980
	private function getListeMeilleursTags() {
1004
	private function getListeMeilleursTags() {
981
		$liste = array();
1005
		$liste = array();
982
		$requete = "SELECT count(*) as occurrences, tag FROM del_image_tag";
1006
		$requete = "SELECT count(*) as occurrences, tag FROM del_image_tag";
983
		if ($this->annee != null) {
1007
		if ($this->annee != null) {
984
			$requete .= " WHERE YEAR(date) = " . $this->annee;
1008
			$requete .= " WHERE YEAR(date) = " . $this->annee;
985
		}
1009
		}
986
		$requete .= " GROUP BY tag ORDER BY occurrences DESC LIMIT 20";
1010
		$requete .= " GROUP BY tag ORDER BY occurrences DESC LIMIT 20";
987
		$resultat = $this->bdd->recupererTous($requete);
1011
		$resultat = $this->bdd->recupererTous($requete);
988
		return array(
1012
		return array(
989
				'liste' => $resultat
1013
				'liste' => $resultat
990
		);
1014
		);
991
	}
1015
	}
992
 
1016
 
993
	/**
1017
	/**
994
	 * Liste des utilisateurs ayant ajouté le plus de mots-clés
1018
	 * Liste des utilisateurs ayant ajouté le plus de mots-clés
995
	 */
1019
	 */
996
	private function getListeMeilleursTagueurs() {
1020
	private function getListeMeilleursTagueurs() {
997
		$resultat = array();
1021
		$resultat = array();
998
		$requete = "SELECT count(*) as nombre, IF (ce_utilisateur REGEXP '^-?[0-9]+$', ce_utilisateur, null) as ce_util FROM del_image_tag";
1022
		$requete = "SELECT count(*) as nombre, IF (ce_utilisateur REGEXP '^-?[0-9]+$', ce_utilisateur, null) as ce_util FROM del_image_tag";
999
		if ($this->annee != null) {
1023
		if ($this->annee != null) {
1000
			$requete .= " WHERE year(date) = " . $this->annee;
1024
			$requete .= " WHERE year(date) = " . $this->annee;
1001
		}
1025
		}
1002
		$requete .= " GROUP BY ce_util ORDER BY nombre DESC LIMIT 20";
1026
		$requete .= " GROUP BY ce_util ORDER BY nombre DESC LIMIT 20";
1003
		$resultat = $this->bdd->recupererTous($requete);
1027
		$resultat = $this->bdd->recupererTous($requete);
1004
 
1028
 
1005
		// Formatage de la liste avec les intitulés des utilisateurs
1029
		// Formatage de la liste avec les intitulés des utilisateurs
1006
		$ids = array_column($resultat, 'ce_util');
1030
		$ids = array_column($resultat, 'ce_util');
1007
		$ids = array_filter($ids, 'is_numeric'); // on oublie les ids de session et autres facéties
1031
		$ids = array_filter($ids, 'is_numeric'); // on oublie les ids de session et autres facéties
1008
		$infosUtilisateurs = $this->recupererIntitulesUtilisateursParIds($ids, true);
1032
		$infosUtilisateurs = $this->recupererIntitulesUtilisateursParIds($ids, true);
1009
		foreach ($resultat as &$util) {
1033
		foreach ($resultat as &$util) {
1010
			$ce = $util['ce_util'];
1034
			$ce = $util['ce_util'];
1011
			$util['intitule'] = isset($infosUtilisateurs[$ce]['intitule']) ? $infosUtilisateurs[$ce]['intitule'] : null;
1035
			$util['intitule'] = isset($infosUtilisateurs[$ce]['intitule']) ? $infosUtilisateurs[$ce]['intitule'] : null;
1012
		}
1036
		}
1013
 
1037
 
1014
		return array(
1038
		return array(
1015
				'liste' => $resultat
1039
				'liste' => $resultat
1016
		);
1040
		);
1017
	}
1041
	}
1018
 
1042
 
1019
	/**
1043
	/**
1020
	 * Encapsule une reqûete de comptage dans un autre morceau de requête
1044
	 * Encapsule une reqûete de comptage dans un autre morceau de requête
1021
	 * afin de calculer la moyenne par mois
1045
	 * afin de calculer la moyenne par mois
1022
	 * @param string $requete count() qui doit renvoyer une colonne 'nb_total'
1046
	 * @param string $requete count() qui doit renvoyer une colonne 'nb_total'
1023
	 */
1047
	 */
1024
	protected function encapsulerMPM($requete, $colonne="date") {
1048
	protected function encapsulerMPM($requete, $colonne="date") {
1025
		$requeteEncapsulee = "SELECT AVG(nb_total) as moyenne FROM ("
1049
		$requeteEncapsulee = "SELECT AVG(nb_total) as moyenne FROM ("
1026
			. $requete
1050
			. $requete
1027
			. " GROUP BY CONCAT(year($colonne),month($colonne)) ) AS nombre";
1051
			. " GROUP BY CONCAT(year($colonne),month($colonne)) ) AS nombre";
1028
		return $requeteEncapsulee;
1052
		return $requeteEncapsulee;
1029
	}
1053
	}
1030
 
1054
 
1031
	/**
1055
	/**
1032
	 * Prend en paramêtre un tableau d'identifiants utilisateurs et retourne après avoir interrogé un
1056
	 * Prend en paramêtre un tableau d'identifiants utilisateurs et retourne après avoir interrogé un
1033
	 * webservice de l'annuaire un tableau avec en clé l'id et en valeur l'intitulé
1057
	 * webservice de l'annuaire un tableau avec en clé l'id et en valeur l'intitulé
1034
	 * @param array $ids un tableau d'ids
1058
	 * @param array $ids un tableau d'ids
1035
	 */
1059
	 */
1036
	protected function recupererIntitulesUtilisateursParIds(array $ids) {
1060
	protected function recupererIntitulesUtilisateursParIds(array $ids) {
1037
		$service = "utilisateur/infos-par-id/" . implode(',', $ids);
1061
		$service = "utilisateur/infos-par-id/" . implode(',', $ids);
1038
		$url = $this->conteneur->getParametre('urlServiceBaseAnnuaire') . $service;
1062
		$url = $this->conteneur->getParametre('urlServiceBaseAnnuaire') . $service;
1039
		//echo "URL: $url\n\n";
1063
		//echo "URL: $url\n\n";
1040
		$json = $this->conteneur->getRestClient()->consulter($url);
1064
		$json = $this->conteneur->getRestClient()->consulter($url);
1041
		$resultat = json_decode($json, true);
1065
		$resultat = json_decode($json, true);
1042
		return $resultat;
1066
		return $resultat;
1043
	}
1067
	}
1044
}
1068
}