Subversion Repositories eFlore/Applications.del

Compare Revisions

Ignore whitespace Rev 2008 → Rev 2009

/branches/v1.7-oxygene/services/modules/0.1/statistiques/StatistiquesParAnnee.php
54,11 → 54,9
if ($this->annee != null && !is_int($this->annee)) {
$erreurs[] = "Le paramètre 'annee' doit être un entier.";
}
 
if (method_exists($this, $this->obtenirNomMethode($this->type)) === false) {
$erreurs[] = "Les stats de type '{$this->type}' n'existent pas.";
}
 
if (!empty($erreurs)) {
$msg = "Erreur de configuration :\n".implode("\n", $erreurs)."\n\n".Statistiques::getDoc();
throw new Exception($msg, RestServeur::HTTP_CODE_MAUVAISE_REQUETE);
65,11 → 63,32
}
}
 
/**
* Ouh la jolie méthode magique !!
* @param unknown $mot
* @return string
*/
private function obtenirNomMethode($mot) {
$classeNom = 'get'.str_replace(' ', '', ucwords(strtolower(str_replace('-', ' ', $mot))));
return $classeNom;
}
 
/**
* Prend en paramêtre un tableau de courriels et retourne après avoir intérogé un service we de l'annuaire
* une tableau avec en clé le courriel et en valeur, un tableau associatif :
* - nom : le nom de l'utilisateur
* - prenom : le prénom de l'utilisateur.
* @TODO ne gère pas le pseudo, qui devrait être retourné en lieu et place des nom / prénom s'il est utilisé et renseigné
* @param array $courriels un tableau de courriels pour lesquels il faut recherche le prénom et nom.
*/
protected function recupererUtilisateursNomPrenom(Array $courriels) {
// Récupération des données au format Json
$service = "utilisateur/prenom-nom-par-courriel/".implode(',', $courriels);
$url = sprintf($this->config['chemins']['baseURLServicesAnnuaireTpl'], $service);
$json = $this->getDao()->consulter($url);
return (array) json_decode($json);
}
 
// retourne toutes les stats pour l'année spécifiée
private function getTout() {
$obsIdentifieesFinAnneePlus = $this->getPourcentageObsIdentifieesFinAnneePlus();
299,4 → 318,263
);
return $retour;
}
 
/**
* Statistiques sur les propositions et les votes
* - Nombre de proposition faites (au total et sur les derniers 15 jours)
* - Nombre de propositions validées(au total et sur le dernier mois)
* - Nombres de votes (au total et sur les derniers 15 jours)
*/
private function getPropositions() {
$nbPropositions = $this->getNbPropositions();
$nbPropositionsValidees = $this->getNbPropositionsValidees();
$votes = $this->getNbVotes();
return array(
'annee' => $this->annee,
'nbPropositionsTotal' => $nbPropositions[0],
'nbPropositions15J' => $nbPropositions[1],
'nbPropositionsValidees' => $nbPropositionsValidees[0],
'nbPropositionsValidees15J' => $nbPropositionsValidees[1],
'nbVotes' => $votes[0],
'nbVotes15J' => $votes[1]
);
}
 
/**
* @TODO Nombre de proposition faites (au total et sur les derniers 15 jours)
* @REFLEXION retourner un array ? Si on demande une année spécifique, comment calculer
* l'activité des 15 derniers jours (on met la case à null ?)
*/
private function getNbPropositionsTotal() {
$requete = "";
$resultat = $this->bdd->recupererTous($requete);
return intval($resultat[0][0]);
}
 
/**
* @TODO Nombre de proposition validées (au total et sur les derniers 15 jours)
* @REFLEXION retourner un array ? Si on demande une année spécifique, comment calculer
* l'activité des 15 derniers jours (on met la case à null ?)
*/
private function getNbPropositionsValidees() {
$requete = "";
$resultat = $this->bdd->recupererTous($requete);
return intval($resultat[0][0]);
}
 
/**
* @TODO Nombre de votes (au total et sur les derniers 15 jours)
* @REFLEXION retourner un array ? Si on demande une année spécifique, comment calculer
* l'activité des 15 derniers jours (on met la case à null ?)
*/
private function getNbVotes() {
$requete = "";
$resultat = $this->bdd->recupererTous($requete);
return intval($resultat[0][0]);
}
 
/**
* Statistiques sur les utilisateurs d'Identiplante
* - Nombre total d'utilisateurs
* - Nombre d'utilisateurs réguliers
* - Nombre d'utilisateurs prenant part aux votes
* - Nombre de participants actifs pour le mois, la semaine, l'année
*/
private function getUtilisateursIp() {
return array(
'annee' => $this->annee,
'nbUtilisateursTotal' => $this->getNbUtilisateursIpTotal(),
'nbUtilisateursReguliers' => $this->getNbUtilisateursIpReguliers(),
'nbUtilisateursVotant' => $this->getNbUtilisateursIpVotant(),
'nbUtilisateursActifs' => $this->getNbUtilisateursIpActifs(),
);
}
 
/**
* @TODO Nombre total d'utilisateurs d'Identiplante
* @REFLEXION est-ce le même nombre que les utilisateurs d'Identiplante ?
*/
private function getNbUtilisateursIpTotal() {
$requete = "";
$resultat = $this->bdd->recupererTous($requete);
return intval($resultat[0][0]);
}
 
/**
* @TODO Nombre d'utilisateurs réguliers d'Identiplante
* @REFLEXION quelle différence avec getNbUtilisateursIpActifs() ?
*/
private function getNbUtilisateursIpReguliers() {
$requete = "";
$resultat = $this->bdd->recupererTous($requete);
return intval($resultat[0][0]);
}
 
/**
* @TODO Nombre d'utilisateurs d'Identiplante prenant part aux votes
*/
private function getNbUtilisateursIpVotant() {
$requete = "";
$resultat = $this->bdd->recupererTous($requete);
return intval($resultat[0][0]);
}
 
/**
* @TODO Nombre de participants actifs à Identiplante (pour le mois, la semaine, l'année)
* @REFLEXION retourner un array ? Si on demande une année spécifique, comment calculer
* l'activité du mois et de la semaine (on met la case à null ?)
*/
private function getNbUtilisateursIpActifs() {
$requete = "";
$resultat = $this->bdd->recupererTous($requete);
return intval($resultat[0][0]);
}
 
/**
* @TODO Liste des utilisateurs ayant fait le plus de propositions, et
* le plus de propositions retenues (ou ayant atteint un consensus)
*/
private function getListeMeilleursProposeurs() {
$liste = array();
$requete = "";
$resultat = $this->bdd->recupererTous($requete);
// Formater liste (récupérer les pseudos des gens dans l'annuaire etc. => voir widget CEL stats)
// => faut-il le faire ici ou dans le widget ? :-/ plutôt ici non ?
// ...
 
return array(
'annee' => $this->annee,
'listeMeilleursProposeurs' => $liste[0],
'listeMeilleursProposeursAyantEteRetenus' => $liste[1]
);
}
 
/**
* @TODO Liste des utilisateurs ayant fait le plus de votes, et le plus
* de votes sur des propositions retenues (ou ayant atteint un consensus)
*/
private function getListeMeilleursVoteurs() {
$liste = array();
$requete = "";
$resultat = $this->bdd->recupererTous($requete);
// Formater liste (récupérer les pseudos des gens dans l'annuaire etc. => voir service CEL stats)
// => faut-il le faire ici ou dans le widget ? :-/ plutôt ici non ?
// ...
 
return array(
'annee' => $this->annee,
'listeMeilleursVoteurs' => $liste[0],
'listeMeilleursVoteursSurPropositionsRetenues' => $liste[1]
);
}
 
/**
* @TODO Statistiques sur les images de Pictoflora
* @REFLEXION aucune idée de ce qu'on met dedans
*/
private function getImages() {
return array(
'annee' => $this->annee
);
}
 
/**
* @TODO Statistiques sur les mots-clés de Pictoflora
* @REFLEXION aucune idée de ce qu'on met dedans
*/
private function getTags() {
return array(
'annee' => $this->annee
);
}
 
/**
* @TODO Statistiques sur les utilisateurs de Pictoflora
* - Nombre total d'utilisateurs
* - Nombre d'utilisateurs réguliers
* - Nombre d'utilisateurs prenant part au taggage ?
* - Nombre de participants actifs pour le mois, la semaine, l'année
*/
private function getUtilisateursPf() {
return array(
'annee' => $this->annee,
'nbUtilisateursTotal' => $this->getNbUtilisateursPfTotal(),
'nbUtilisateursReguliers' => $this->getNbUtilisateursPfReguliers(),
'nbUtilisateursVotant' => $this->getNbUtilisateursPfTaggant(),
'nbUtilisateursActifs' => $this->getNbUtilisateursPfActifs(),
);
}
 
/**
* @TODO Nombre total d'utilisateurs de Pictoflora
* @REFLEXION est-ce le même nombre que les utilisateurs d'Identiplante ?
*/
private function getNbUtilisateursPfTotal() {
$requete = "";
$resultat = $this->bdd->recupererTous($requete);
return intval($resultat[0][0]);
}
 
/**
* @TODO Nombre d'utilisateurs réguliers de Pictoflora
* @REFLEXION quelle différence avec getNbUtilisateursPfActifs() ?
*/
private function getNbUtilisateursPfReguliers() {
$requete = "";
$resultat = $this->bdd->recupererTous($requete);
return intval($resultat[0][0]);
}
 
/**
* @TODO Nombre d'utilisateurs de Pictoflora prenant part aux votes
*/
private function getNbUtilisateursPfTaggant() {
$requete = "";
$resultat = $this->bdd->recupererTous($requete);
return intval($resultat[0][0]);
}
 
/**
* @TODO Nombre de participants à Pictoflora actifs (pour le mois, la semaine, l'année)
* @REFLEXION retourner un array ? Si on demande une année spécifique, comment calculer
* l'activité du mois et de la semaine (on met la case à null ?)
*/
private function getNbUtilisateursPfActifs() {
$requete = "";
$resultat = $this->bdd->recupererTous($requete);
return intval($resultat[0][0]);
}
 
/**
* @TODO Liste des mots-clés les plus fréquents
*/
private function getListeMeilleursTags() {
$liste = array();
$requete = "";
$resultat = $this->bdd->recupererTous($requete);
// Formater liste
// ...
 
return array(
'annee' => $this->annee,
'listeMeilleursTags' => $liste
);
}
 
/**
* @TODO Liste des utilisateurs ayant ajouté le plus de mots-clés
*/
private function getListeMeilleursTagueurs() {
$liste = array();
$requete = "";
$resultat = $this->bdd->recupererTous($requete);
// Formater liste (récupérer les pseudos des gens dans l'annuaire etc. => voir service CEL stats)
// => faut-il le faire ici ou dans le widget ? :-/ plutôt ici non ?
// ...
 
return array(
'annee' => $this->annee,
'listeMeilleursTagueurs' => $liste
);
}
}