Rev 34 | Rev 65 | Go to most recent revision | Blame | Compare with Previous | Last modification | View Log | RSS feed
<?php
/**
* PHP Version 5
*
* @category PHP
* @package annuaire
* @author aurelien <aurelien@tela-botanica.org>
* @copyright 2010 Tela-Botanica
* @license http://www.cecill.info/licences/Licence_CeCILL_V2-fr.txt Licence CECILL
* @version SVN: <svn_id>
* @link /doc/annuaire/
*/
class AnnuaireControleur extends Controleur {
/**
* (fonction héritée de la classe Controleur)
* Avant chaque chargement de vue, on ajoute l'url de la page dans
* les variables à insérer.
* @param Array $donnes les données à insérer dans la vue
* @return Array $donnees les données modifiées
*/
public function preTraiterDonnees($donnees) {
$donnees['base_url'] = new Url(Registre::getInstance()->get('base_url_application'));
return $donnees;
}
/**
* Fonction affichant la vue par défaut, ici le menu principal
* @return String la vue contenant le menu
*/
public function index() {
$data = array();
$index_annuaire = $this->getVue('index_annuaire', $data);
return $index_annuaire;
}
/**-------- Fonctions de gestion des annuaires --------------------------------*/
/**
* Charge la vue contenant la liste des annuaires gérés par l'application
* @return string la vue contenant la liste des annuaires
*/
public function chargerListeAnnuaire() {
$this->chargerModele('AnnuaireModele');
$data['erreurs'] = null;
$data['annuaires'] = $this->AnnuaireModele->chargerListeAnnuaire();
$liste_annu = $this->getVue(Config::get('dossier_squelettes_annuaires').'liste_annu', $data);
return $liste_annu;
}
/**
* Charge la vue contenant les informations d'un annuaire donné en paramètre
* @param int $id l'identifiant de l'annuaire
* @return string la vue contenant les informations sur l'annuaire
*/
public function chargerAnnuaire($id) {
$this->chargerModele('AnnuaireModele');
$this->chargerModele('MetadonneeModele');
$data['erreurs'] = array();
$data['champs_mappage'] = $this->AnnuaireModele->obtenirChampsMappageAnnuaire($id);
$data['annuaire'] = $this->AnnuaireModele->chargerAnnuaire($id, true);
$data['metadonnees'] = $this->MetadonneeModele->chargerListeMetadonneeAnnuaire($id);
$annuaire = $this->getVue(Config::get('dossier_squelettes_annuaires').'annuaire', $data);
return $annuaire;
}
/**
* Charge et affiche la liste des inscrits à un annuaire donné en paramètre
* @param $id int l'identifiant de l'annuaire
* @return string la vue contenant les inscrits à l'annuaire
*/
public function chargerAnnuaireListeInscrits($id, $numero_page = 1, $taille_page = 50) {
$this->chargerModele('AnnuaireModele');
$data['erreurs'] = array();
$data['champs'] = $this->obtenirChampsMappageAnnuaire($id);
$total_inscrits = $this->AnnuaireModele->chargerNombreAnnuaireListeInscrits($id);
$data['annuaire'] = $this->AnnuaireModele->chargerAnnuaireListeInscrits($id, $data['champs'][0], $numero_page, $taille_page);
$url_pagination = new URL(Registre::getInstance()->get('base_url_application'));
$url_pagination->setVariableRequete('m','annuaire_inscrits');
$url_pagination->setVariableRequete('id_annuaire',$id);
$data['pagination'] = $this->paginer($numero_page,$taille_page,$total_inscrits,$url_pagination);
$annuaires_inscrits = $this->getVue(Config::get('dossier_squelettes_annuaires').'annuaire_inscrits', $data);
return $annuaires_inscrits;
}
/**-------- Fonctions d'affichage du formulaire de saisie d'un champ de metadonnée suivant le type de champ---------*/
/**
* Affiche le formulaire d'inscription pour un annuaire donné
* @param int $id_annuaire l'identifiant de l'annuaire pour lequel on veut afficher le formulaire
* @param Array $donnees le tableau de données pour préremplir le formulaire si besoin (en cas de retour erreur)
*/
public function afficherFormulaireInscription($id_annuaire, $donnees=array()) {
$this->chargerModele('AnnuaireModele');
$annuaire = $this->AnnuaireModele->chargerAnnuaire($id_annuaire, false);
$this->chargerModele('MetadonneeModele');
$donnees['aa_id_annuaire'] = $id_annuaire;
$metadonnees = $this->MetadonneeModele->chargerListeMetadonneeAnnuaire($id_annuaire);
// TODO: ceci charge toutes les métadonnées, voir si l'on ne peut pas parser le formulaire
// pour ne charger que ce qui est nécéssaire
foreach($metadonnees as $metadonnee) {
$id_champ = $metadonnee['amc_id_champ'];
$type_champ = $metadonnee['amc_ce_template_affichage'];
$nom_champ = $metadonnee['amc_abreviation'];
$metadonnee['aa_id_annuaire'] = $id_annuaire;
if(isset($donnees['erreurs'])) {
$metadonnee['erreurs'] = $donnees['erreurs'];
}
if(isset($donnees[$type_champ.'_'.$id_champ])) {
$metadonnee['valeur_defaut']['amv_valeur'] = $donnees[$type_champ.'_'.$id_champ];
}
// on charge le formulaire d'affichage de chacune des métadonnées
$donnees['champs'][$nom_champ] = $this->afficherFormulaireChampMetadonnees($id_champ,$metadonnee);
}
// si le formulaire existe, on le charge
if(!$this->templateExiste($annuaire['informations']['aa_code'].'_inscription','formulaires/')) {
$formulaire_inscription = $this->genererFormulaireInscription($donnees);
} else {
// sinon on en génère un qui contient tous les champs
$formulaire_inscription = $this->GetVue(Config::get('dossier_squelettes_formulaires').$annuaire['informations']['aa_code'].'_inscription',$donnees);
}
return $formulaire_inscription;
}
/**
* Charge et affiche le champ correspondant à la modification ou l'ajout d'un champ de metadonnée
* @param int $id_champ l'identifiant du champ demandé
* @return string la vue contenant le champ de formulaire correspondant
*/
public function afficherFormulaireChampMetadonnees($id_champ, $donnees=array()) {
// si le champ est restreint à une valeur de liste
if($donnees['amc_ce_ontologie'] != 0) {
$this->chargerModele('OntologieModele');
$donnees['liste_valeurs'] = $this->OntologieModele->chargerListeOntologie($donnees['amc_ce_ontologie']);
}
$donnees['amc_id_champ'] = $id_champ;
$this->chargerModele('MetadonneeModele');
$nom_type_champ = $this->MetadonneeModele->renvoyerTypeAffichageParId($donnees['amc_ce_type_affichage']);
return $this->getVue(Config::get('dossier_squelettes_champs').$nom_type_champ,$donnees);
}
/**-------- Fonctions d'inscription -------------------------------------------------------------------------------*/
/**
* Lors d'une tentative d'inscription, ajoute les infos dans la table d'inscription
* temporaire et envoie le mail contenant le lien de confirmation si tout s'est bien passé
* @param Array $valeurs les valeurs à ajouter
* @return string la vue contenant la confirmation de l'inscription
*/
public function ajouterInscriptionTemporaire($valeurs) {
$this->chargerModele('MetadonneeModele');
$id_annuaire = $valeurs['aa_id_annuaire'];
unset($valeurs['aa_id_annuaire']);
$tableau_mappage = $this->obtenirChampsMappageAnnuaire($id_annuaire);
$valeurs_mappees = array();
$valeurs_a_inserer = array();
$verificateur = new VerificationControleur();
// on itère sur le tableau de valeur pour récupérer les champs de mappage;
foreach($valeurs as $nom_champ => $valeur) {
// pour chaque valeur
// on extrait l'id du champ
$ids_champ = mb_split("_",$nom_champ, 3);
if(count($ids_champ) == 3) {
$type = $ids_champ[0];
$id_champ = $ids_champ[2];
$condition = $ids_champ[1];
// cas de la checkbox qui devrait être là mais pas cochée
if($condition == 'hidden' && !isset($valeurs[$type.'_'.$id_champ])) {
// dans ce cas là on fabrique une valeur vide
$valeurs[$type.'_'.$id_champ] = 0;
}
} else {
$type = $ids_champ[0];
$condition = false;
$id_champ = $ids_champ[1];
}
// Si le champ fait partie des champs mappés
$cle_champ = array_search($id_champ, $tableau_mappage[1]);
// on ajoute sa clé correspondante dans le tableau des champs mappés
// qui sont les champs à vérifier
if($condition) {
$condition = $valeurs[$type.'_'.$id_champ];
$valeurs_mappees[$id_champ] = array('valeur' => $valeur, 'type' => $type, 'condition' => $condition);
} else {
//$valeurs_mappees[$cle_champ] = $valeur;
$valeurs_mappees[$id_champ] = array('valeur' => $valeur, 'type' => $type, 'condition' => false);
}
if(!$condition) {
$valeurs_a_inserer[$nom_champ] = $valeur;
}
}
// vérification des champs minimaux : nom, prénom, mail, mot de passe
if($erreurs = $verificateur->verifierErreursChampsSelonType($id_annuaire,$valeurs_mappees, $tableau_mappage)) {
$valeurs['erreurs'] = $erreurs;
return $this->afficherFormulaireInscription($id_annuaire, $valeurs);
}
$valeurs_a_inserer['aa_id_annuaire'] = $id_annuaire ;
$code_confirmation = $this->InsererDansTableTemporaireEtCreerCodeConfirmationInscription($valeurs_a_inserer);
$this->envoyerMailConfirmationInscription($valeurs_mappees['champ_mail'],
$valeurs_mappees['champ_nom'],
$valeurs_mappees['champ_prenom'],
$code_confirmation);
// Si tout s'est bien passé, on affiche la page de confirmation
return $this->getVue(Config::get('dossier_squelettes_annuaires').'annuaire_inscription_reussie',array());
}
/**
* Ajoute une nouvelle inscription à un annuaire à partir de données d'une table temporaire.
* Typiquement, on déclenche cette fonction en cliquant sur le lien contenu dans le mail de confirmation
* @param int $indentifant L'identifant de session d'une tentative d'inscription
*/
public function ajouterNouvelleInscription($identifiant) {
$this->chargerModele('AnnuaireModele');
$valeurs = $this->AnnuaireModele->chargerDonneesInscriptionTemporaire($identifiant);
if(!$valeurs || count($valeurs) == 0) {
// TODO afficher vue en cas d'echec
}
$id_annuaire = $valeurs['aa_id_annuaire'];
unset($valeurs['aa_id_annuaire']);
$this->chargerModele('MetadonneeModele');
$verificateur = new VerificationControleur();
$tableau_mappage = $this->obtenirChampsMappageAnnuaire($id_annuaire);
$valeurs_mappees = array();
$valeurs_metadonnees = array();
$mail_nouvel_inscrit = $valeurs['mail_'.$tableau_mappage[1]['champ_mail']];
$pass_nouvel_inscrit = $valeurs['pass_'.$tableau_mappage[1]['champ_pass']];
// on itère sur le tableau de valeur pour récupérer les métadonnées;
foreach($valeurs as $nom_champ => $valeur) {
// pour chaque valeur
// on extrait l'id du champ
$ids_champ = mb_split("_",$nom_champ, 2);
$type = $ids_champ[0];
$condition = false;
$id_champ = $ids_champ[1];
// on fait des vérifications et des remplacements sur certaines valeurs
$valeur = $verificateur->remplacerValeurChampPourInsertion($type,$valeur,$mail_nouvel_inscrit);
// Si le champ fait partie des champs mappés
$cle_champ = array_search($id_champ, $tableau_mappage[1]);
if($cle_champ) {
// on ajoute sa clé correspondante dans l'annuaire mappé et sa valeur dans le tableau des champs mappés
$valeurs_mappees[$tableau_mappage[0][$cle_champ]] = $valeur;
// et on supprime sa valeur du tableau de valeurs pour ne pas la retrouver lors
// de l'insertion des métadonnées
unset($valeurs[$nom_champ]);
} else {
$valeurs_metadonnees[$nom_champ] = $valeur;
}
}
// obtenir l'id du nouvel arrivant en faisant un select sur le mail qui doit être unique
$id_nouvel_inscrit = $this->ajouterNouvelleInscriptionDansAnnuaireMappe($id_annuaire,$valeurs_mappees, $tableau_mappage[0]);
// les champs de metadonnees arrivent avec un identifiant sous la forme type_condition_id
foreach($valeurs_metadonnees as $nom_champ => $valeur) {
// pour chaque valeur
// on extrait l'id du champ
$ids_champ = mb_split("_",$nom_champ);
$id_champ = $ids_champ[count($ids_champ) - 1];
// Si l'insertion dans la base a réussi
if($this->MetadonneeModele->ajouterNouvelleValeurMetadonnee($id_champ,$id_nouvel_inscrit,$valeur)) {
// on continue
} else {
// Si une des insertions échoue, on supprime les méta valeurs déjà entrées.
$this->MetadonneeModele->supprimerValeursMetadonneesParIdEnregistrementLie($id_nouvel_inscrit);
return false;
}
}
//TODO: gérer le cas de spip et de wikini par un multimapping des champs
//TODO: voir openid
// TODO appel des plugins d'inscription
// Si tout a réussi on supprime les données d'inscription temporaire
$this->AnnuaireModele->supprimerDonneesInscriptionTemporaire($identifiant);
$annuaire = $this->AnnuaireModele->chargerAnnuaire($id_annuaire, false);
// Identifier l'utilisateur !
//$identificateur = new IdentificationControleur();
//$identificateur->fabriquerCookie($mail_nouvel_inscrit, $pass_nouvel_inscrit, false);
//$identificateur->loggerUtilisateurParCookie();
// S'il existe une page d'accueil spécifique à l'annuaire pour la confirmation d'inscription
if($this->templateExiste($annuaire['informations']['aa_code'].'_inscription_confirmation', Config::get('dossier_squelettes_annuaires'))) {
// on l'affiche
$donnees = array('id_utilisateur' => $id_nouvel_inscrit, 'id_annuaire' => $id_annuaire);
return $this->getVue(Config::get('dossier_squelettes_annuaires').$annuaire['informations']['aa_code'].'_inscription_confirmation', $donnees);
} else {
// sinon on le redirige
return $this->afficherFicheUtilisateur($id_annuaire, $id_nouvel_inscrit);
}
}
/**
* Ajoute un nouvel inscrit dans l'annuaire mappé donné en paramètre.
* En cas de succès, renvoie l'identifiant du nouvel inscrit qui sera
* utilisé pour insérer les métadonnées liées
*
* @param int $id_annuaire identifiant de l'annuaire auquel sera lié le nouvel inscrit
* @param Array $valeurs_mappees Tableau contenant les valeurs à insérer et ayant comme clés des noms de colonnes
* @param Array $noms_champs Tableau contenant les noms des champs à insérer
* @return int l'identifiant unique du nouvel inscrit
*/
public function ajouterNouvelleInscriptionDansAnnuaireMappe($id_annuaire,$valeurs_mappees, $noms_champs) {
$this->chargerModele('AnnuaireModele');
$resultat = $this->AnnuaireModele->ajouterInscriptionDansAnnuaireMappe($id_annuaire, $valeurs_mappees, $noms_champs);
return $resultat;
}
public function afficherFormulaireIdentification($donnees = array()) {
return $this->getVue(Config::get('dossier_squelettes_formulaires').'identification', $donnees);
}
/**
* Affiche la fiche principale d'un utilisateur
* @param int $id_annuaire l'identifiant de l'annuaire
* @param int $id_utilisateur l'identifiant de l'utilisateur
* @return string la vue contenant la fiche utilisateur
*/
public function afficherFicheUtilisateur($id_annuaire, $id_utilisateur) {
// Chargement des informations de l'utilisateur dans la table annuaire principale
$this->chargerModele('AnnuaireModele');
$annuaire = $this->AnnuaireModele->chargerAnnuaire($id_annuaire);
$tableau_mappage = $this->obtenirChampsMappageAnnuaire($id_annuaire);
$tableau_valeurs = $this->AnnuaireModele->obtenirValeursUtilisateur($id_annuaire, $id_utilisateur,$tableau_mappage[0]);
// chargement des métadonnées associées à l'utilisateur
$this->chargerModele('MetadonneeModele');
$champs_metadonnees= $this->MetadonneeModele->chargerListeValeursMetadonneesUtilisateur($id_annuaire, $id_utilisateur);
$verificateur = new VerificationControleur();
// on vérifie s'il existe un type d'affichage particulier pour les colonnes de l'annuaire mappé
foreach($tableau_mappage[0] as $cle => $nom_champ) {
$valeur = $tableau_valeurs[$nom_champ] ;
if(isset($tableau_mappage[1][$cle])) {
$tableau_valeurs[$cle] = array('amv_valeur' => $valeur,'amc_id_champ' => $tableau_mappage[1][$cle]);
$type_affichage = $this->MetadonneeModele->renvoyerTypeAffichagePourColonne($tableau_mappage[1][$cle]);
if($type_affichage) {
$tableau_valeurs[$cle]['amc_ce_type_affichage'] = $type_affichage;
}
} else {
$tableau_valeurs[$cle] = $valeur;
}
unset($tableau_valeurs[$nom_champ]);
}
$donnees['id_annuaire'] = $id_annuaire;
$donnees['id_utilisateur'] = $id_utilisateur;
$champs = array_merge($tableau_valeurs, $champs_metadonnees);
foreach($champs as $cle => $champ) {
if(is_array($champ) && isset($champ['amc_ce_type_affichage'])) {
$type = $champ['amc_ce_type_affichage'];
} else {
$type = false;
}
// on remplace les valeurs de certains champs pour l'affichage (ex: checkbox cochée de se transforme en oui )
$champs[$cle] = $verificateur->verifierEtRemplacerValeurChampPourAffichage($type,$champ ,$id_annuaire);
}
$donnees['champs'] = $champs;
$annuaire_inscrits = $this->getVue(Config::get('dossier_squelettes_fiches').$annuaire['informations']['aa_code'].'_fiche',$donnees);
return $annuaire_inscrits;
}
/** Affiche le resumé des contributions d'un utilisateur
* @param int $id_annuaire l'identifiant de l'annuaire
* @param int $id_utilisateur l'identifiant de l'utilisateur
* @return string la vue contenant les contributions utilisateur
*/
public function afficherFicheResumeUtilisateur($id_annuaire, $id_utilisateur) {
$this->chargerModele('AnnuaireModele');
$tableau_mappage = $this->obtenirChampsMappageAnnuaire($id_annuaire);
$tableau_valeurs = $this->AnnuaireModele->obtenirValeursUtilisateur($id_annuaire, $id_utilisateur,$tableau_mappage[0]);
$this->chargerModele('MetadonneeModele');
$champs_metadonnees= $this->MetadonneeModele->chargerListeValeursMetadonneesUtilisateur($id_annuaire, $id_utilisateur);
$verificateur = new VerificationControleur();
// on vérifie s'il existe un type d'affichage particulier pour les colonnes de l'annuaire mappé
foreach($tableau_mappage[0] as $cle => $nom_champ) {
$valeur = $tableau_valeurs[$nom_champ] ;
if(isset($tableau_mappage[1][$cle])) {
$tableau_valeurs[$cle] = array('amv_valeur' => $valeur,'amc_id_champ' => $tableau_mappage[1][$cle]);
$type_affichage = $this->MetadonneeModele->renvoyerTypeAffichagePourColonne($tableau_mappage[1][$cle]);
if($type_affichage) {
$tableau_valeurs[$cle]['amc_ce_type_affichage'] = $type_affichage;
}
} else {
$tableau_valeurs[$cle] = $valeur;
}
unset($tableau_valeurs[$nom_champ]);
}
$mail_utilisateur = $this->AnnuaireModele->obtenirMailParId($id_annuaire,$id_utilisateur);
$donnees['id_annuaire'] = $id_annuaire;
$donnees['id_utilisateur'] = $id_utilisateur;
$champs = array_merge($tableau_valeurs, $champs_metadonnees);
foreach($champs as $cle => $champ) {
if(is_array($champ) && isset($champ['amc_ce_type_affichage'])) {
$type = $champ['amc_ce_type_affichage'];
} else {
$type = false;
}
$champs[$cle] = $verificateur->verifierEtRemplacerValeurChampPourAffichage($type,$champ ,$id_annuaire);
}
$url_modification_profil = new Url(Config::get('base_url_application'));
$url_modification_profil->setVariableRequete('m','annuaire_formulaire_modification_inscription');
$url_modification_profil->setVariableRequete('id_annuaire',$id_annuaire);
$url_modification_profil->setVariableRequete('id_utilisateur',$id_utilisateur);
$url_oubli_mdp = new Url(Config::get('base_url_application'));
$url_oubli_mdp->setVariableRequete('m','annuaire_afficher_formulaire_oubli_mdp');
$url_oubli_mdp->setVariableRequete('id_annuaire',$id_annuaire);
$url_oubli_mdp->setVariableRequete('id_utilisateur',$id_utilisateur);
$donnees['url_oubli_mdp'] = $url_oubli_mdp;
$donnees['url_modification_profil'] = $url_modification_profil;
$donnees['champs'] = $champs;
// on crée un controleur appelle les hooks de résumé pour chaque application externe
$resumes_controleur = new ApplicationExterneControleur();
$donnees['resumes'] = $resumes_controleur->obtenirResume($id_utilisateur,$mail_utilisateur);
$donnees['carte_id'] = $this->getVue(Config::get('dossier_squelettes_fiches').'annuaire_tela_inscrits_carte_id',$donnees);
$fiche_contrib = $this->getVue(Config::get('dossier_squelettes_fiches').'annuaire_tela_inscrits_resume',$donnees);
return $fiche_contrib;
}
public function afficherFormulaireModificationInscription($id_annuaire, $id_utilisateur, $erreurs = array()) {
$this->chargerModele('AnnuaireModele');
$annuaire = $this->AnnuaireModele->chargerAnnuaire($id_annuaire, false);
$this->chargerModele('MetadonneeModele');
$donnees['aa_id_annuaire'] = $id_annuaire;
$metadonnees = $this->MetadonneeModele->chargerListeMetadonneeAnnuaire($id_annuaire);
$tableau_mappage = $this->obtenirChampsMappageAnnuaire($id_annuaire);
$valeurs_annuaire = $this->AnnuaireModele->obtenirValeursUtilisateur($id_annuaire, $id_utilisateur,$tableau_mappage[0]);
$valeurs_metadonnees= $this->MetadonneeModele->chargerListeValeursMetadonneesUtilisateur($id_annuaire, $id_utilisateur);
foreach($tableau_mappage[0] as $cle => $nom_champ) {
$valeur = $valeurs_annuaire[$nom_champ] ;
if($cle != 'champ_id') {
$valeurs_metadonnees[$metadonnees[$tableau_mappage[1][$cle]]['amc_abreviation']] = array('amv_valeur' => $valeur,'amc_id_champ' => $tableau_mappage[1][$cle]) ;
}
}
// TODO: ceci charge toutes les métadonnées, voir si l'on ne peut pas parser le formulaire
// pour ne charger que ce qui est nécéssaire
foreach($metadonnees as $metadonnee) {
$id_champ = $metadonnee['amc_id_champ'];
$nom_champ = $metadonnee['amc_abreviation'];
if(isset($valeurs_metadonnees[$nom_champ])) {
$metadonnee['valeur_defaut'] = $valeurs_metadonnees[$nom_champ];
}
$metadonnee['aa_id_annuaire'] = $id_annuaire;
// on charge le formulaire d'affichage de chacune des métadonnées
$donnees['champs'][$nom_champ] = $this->afficherFormulaireChampMetadonnees($id_champ,$metadonnee);
}
$donnees['id_utilisateur'] = $id_utilisateur;
$donnees['erreurs'] = $erreurs;
// le nom du formulaire d'inscription est le même que le code de l'annuaire du genre code_annuaire_inscription
if(!$this->formulaireExiste($annuaire['informations']['aa_code'])) {
$formulaire_inscription = $this->genererFormulaireInscription($donnees);
} else {
$formulaire_inscription = $this->GetVue(Config::get('dossier_squelettes_formulaires').$annuaire['informations']['aa_code'].'_modification',$donnees);
}
return $formulaire_inscription;
}
public function modifierInscription($valeurs) {
$this->chargerModele('MetadonneeModele');
$id_utilisateur = $valeurs['id_utilisateur'];
unset($valeurs['id_utilisateur']);
$id_annuaire = $valeurs['aa_id_annuaire'];
unset($valeurs['aa_id_annuaire']);
$this->chargerModele('MetadonneeModele');
$tableau_mappage = $this->obtenirChampsMappageAnnuaire($id_annuaire);
$mail_utilisateur = $this->AnnuaireModele->obtenirMailParId($id_annuaire, $id_utilisateur);
$ancien_mail = $mail_utilisateur;
$verificateur = new VerificationControleur();
$valeurs_mappees = array();
$valeurs_metadonnees = array();
$erreurs = array();
// on itère sur le tableau de valeur pour récupérer les métadonnées
// et les valeurs
foreach($valeurs as $nom_champ => $valeur) {
// pour chaque valeur
// on extrait l'id du champ
$ids_champ = mb_split("_",$nom_champ);
$confirmation = false;
$valeur_a_ignorer = false;
// l'identifiant du champ est la dernière valeur du tableau
if(count($ids_champ) == 3) {
$type = $ids_champ[0];
$id_champ = $ids_champ[2];
$condition = $ids_champ[1];
} else {
$type = $ids_champ[0];
$condition = false;
$id_champ = $ids_champ[1];
}
if($type == 'checkbox' && $condition != 'hidden') {
// on récupère la valeur
$nom_champ = $type.'_'.$id_champ;
$valeur = $valeurs[$type.'_'.$id_champ];
}
// cas de la checkbox qui devrait être là mais pas cochée
if($condition == 'hidden') {
if(!isset($valeurs[$type.'_'.$id_champ])) {
// dans ce cas là on fabrique une valeur qui vaut 0
$nom_champ = $type.'_'.$id_champ;
$valeur = '0';
} else {
// sinon la valeur a déjà été traitée et doit être ignorée
$valeur_a_ignorer = true;
}
}
if($type == 'mail') {
$mail_utilisateur = $valeur;
}
// cas du changement de mot de passe
if($type == 'password') {
if($condition == 'conf') {
$valeur_a_ignorer = true;
}
$tentative_changemement_mdp = false;
if(isset($valeurs[$type.'_conf_'.$id_champ]) && trim($valeurs[$type.'_conf_'.$id_champ]) != '') {
$tentative_changemement_mdp = true;
} else {
$valeur_a_ignorer = true;
}
if($tentative_changemement_mdp) {
$confirmation = $valeurs[$type.'_conf_'.$id_champ];
}
}
// Si la valeur n'est présente dans le formulaire que pour des raisons de vérification
// on passe à l'iteration suivante
if($valeur_a_ignorer) {
continue;
}
$verification = $verificateur->verifierErreurChampModification($id_annuaire, $id_utilisateur, $type , $valeur, $confirmation);
if($verification[0] == false) {
$erreurs[$type.'_'.$id_champ] = $verification[1];
}
// on fait des vérifications et des remplacements sur certaines valeurs
// et quelques fois des actions externes
$valeur = $verificateur->remplacerValeurChampPourModification($id_annuaire, $id_utilisateur, $type, $valeur, $mail_utilisateur);
// Si le champ fait partie des champs mappés
$cle_champ = array_search($id_champ, $tableau_mappage[1]);
if($cle_champ) {
// on ajoute sa clé correspondante dans l'annuaire mappé et sa valeur dans le tableau des champs mappés
$valeurs_mappees[$tableau_mappage[0][$cle_champ]] = $valeur;
} else {
// sinon, il est stocké dans les valeurs de metadonnées
$valeurs_metadonnees[$id_champ] = $valeur;
}
}
if(count($erreurs) > 0) {
return $this->afficherFormulaireModificationInscription($id_annuaire,$id_utilisateur,$erreurs);
}
$this->chargerModele('AnnuaireModele');
$modification_annuaire = $this->AnnuaireModele->modifierInscriptionDansAnnuaireMappe($id_annuaire, $id_utilisateur ,$valeurs_mappees, $tableau_mappage[0]);
$nouveau_mail = $this->AnnuaireModele->obtenirMailParId($id_annuaire, $id_utilisateur);
$changement_mail = false;
// Si le mail a changé alors il faut appeler les applications externes pour modification
if($ancien_mail != $mail_utilisateur) {
$changement_mail = true;
$appli_controleur = new ApplicationExterneControleur();
$appli_controleur->modifierInscription($id_utilisateur, $mail_utilisateur);
}
// les champs arrivent avec un identifiant sous la forme type_xxx_id
foreach($valeurs_metadonnees as $id_champ => $valeur) {
// S'il existe déjà une valeur de metadonnée pour cette colonne et cet utilisateur
// car on a pu ajouter de nouveaux champs entre temps
if($this->MetadonneeModele->valeurExiste($id_champ,$id_utilisateur)) {
// On se contente de la modifier
if($this->MetadonneeModele->modifierValeurMetadonnee($id_champ,$id_utilisateur,$valeur)) {
} else {
return false;
}
} else {
// S'il n'existe pas de valeur, on ajoute une nouvelle ligne à la table de valeurs de meta données
if($this->MetadonneeModele->ajouterNouvelleValeurMetadonnee($id_champ,$id_utilisateur,$valeur)) {
// Si l'insertion a réussi, on continue
} else {
// TODO: lever exception
return false;
}
}
}
return $this->afficherFicheUtilisateur($id_annuaire, $id_utilisateur);
}
/**
* Affiche le formulaire permettant d'entrer un mail et de recevoir le mot de passe
* associé sur cette adresse
* @param int $id_annuaire l'identifiant de l'annuaire associé
*/
public function afficherFormulaireOubliMotDePasse($id_annuaire) {
$donnees['aa_id_annuaire'] = $id_annuaire;
return $this->getVue(Config::get('dossier_squelettes_formulaires').'oubli_mdp',$donnees);
}
/**
* Supprime l'ancien mot de passe d'un utilisateur et crée un nouveau mot de passe
* aléatoire qui sera envoyé par mail
* @param int $id_annuaire l'identifiant de l'annuaire associé
* @param int $mail le mail auquel on envoie le mot de passe
*
*/
public function reinitialiserMotDePasse($id_annuaire, $mail) {
$this->chargerModele('AnnuaireModele');
$verificateur = new VerificationControleur('VerificationControleur');
$donnees = array();
if(!$verificateur->mailValide($mail) || !$this->AnnuaireModele->utilisateurExisteParMail($id_annuaire,$mail)) {
$donnees['erreurs']['mail'] = 'Cet utilisateur n\'existe pas';
$donnees['aa_id_annuaire'] = $id_annuaire;
return $this->getVue(Config::get('dossier_squelettes_formulaires').'oubli_mdp',$donnees);
}
$nouveau_mdp = $this->AnnuaireModele->reinitialiserMotDePasse($id_annuaire, $mail);
if(!$nouveau_mdp) {
$donnees['erreurs']['mdp'] = 'Impossible de générer un nouveau mot de passe';
$donnees['aa_id_annuaire'] = $id_annuaire;
return $this->getVue('oubli_mdp',$donnees);
}
$donnees['nouveau_mdp'] = $nouveau_mdp;
return $this->envoyerMailOubliMdp($id_annuaire,$mail , $nouveau_mdp);
}
/**
* Supprime l'inscription d'un utilisateur dans un annuaire donné
* @param int $id_annuaire l'identifiant de l'annuaire associé
* @param int $id_utilisateur l'identifiant de l'utilisateur à supprimer
*/
public function supprimerInscription($id_annuaire, $id_utilisateur) {
$this->chargerModele('AnnuaireModele');
$champs_mappage = $this->obtenirChampsMappageAnnuaire($id_annuaire);
$suppression_inscription = $this->AnnuaireModele->supprimerInscriptionDansAnnuaireMappe($id_annuaire, $id_utilisateur);
$mail_utilisateur = $this->AnnuaireModele->obtenirMailParId($id_utilisateur);
$donnees = array('erreurs' => array());
$this->chargerModele('MetadonneeModele');
$suppression_metadonnees = $this->MetadonneeModele->supprimerValeursMetadonneesParIdEnregistrementLie($id_utilisateur);
if(!$suppression_inscription || !$suppression_metadonnees) {
$donnees['erreurs']['inscription'] = $suppression_inscription;
$donnees['erreurs']['metadonnees'] = $suppression_metadonnees;
$donnees['erreurs']['titre'] = 'Impossible de supprimer l\'inscription ';
return $this->getVue(Config::get('dossier_squelettes_elements').'erreurs',$donnees);
}
// on appelle les controleur de lettre actu et d'applications externes
$appli_controleur = new ApplicationExterneControleur();
$appli_controleur->supprimerInscription($id_utilisateur, $mail_utilisateur);
// pour qu'ils lancent les procédures de désinscription associées
$lettre_controleur = new LettreControleur();
$lettre_controleur->desinscriptionLettreActualite($mail_utilisateur);
return $this->index();
}
/**
* Affiche le formulaire de recherche pour un annuaire donné ou en génère un à la volée
* @param int $id_annuaire l'identifiant de l'annuaire
* @param array $donnees des données utilisées pour pré remplir le formulaire
* @return string le html contenant le formulaire de recherche
*/
public function afficherFormulaireRecherche($id_annuaire, $donnees = array()) {
$this->chargerModele('AnnuaireModele');
$annuaire = $this->AnnuaireModele->chargerAnnuaire($id_annuaire, false);
$this->chargerModele('MetadonneeModele');
$metadonnees = $this->MetadonneeModele->chargerListeMetadonneeAnnuaire($id_annuaire);
$donnees['aa_id_annuaire'] = $id_annuaire;
// TODO: ceci charge toutes les métadonnées, voir si l'on ne peut pas parser le formulaire
// pour ne charger que ce qui est nécéssaire
foreach($metadonnees as $nom_champ => $metadonnee) {
//echo $nom_champ;
$id_champ = $metadonnee['amc_id_champ'];
$type_champ = $metadonnee['amc_ce_template_affichage'];
$nom_champ = $metadonnee['amc_abreviation'];
if(isset($donnees[$type_champ.'_'.$id_champ])) {
$metadonnee['valeur_defaut']['amv_valeur'] = $donnees[$type_champ.'_'.$id_champ];
}
$metadonnee['aa_id_annuaire'] = $id_annuaire;
// on charge le formulaire d'affichage de chacune des métadonnées
$donnees['champs'][$nom_champ] = $this->afficherFormulaireChampMetadonnees($id_champ,$metadonnee);
}
// Si le formulaire spécifique à l'annuaire existe, on l'affiche
if(!$this->templateExiste($annuaire['informations']['aa_code'].'_recherche','/formulaires/')) {
$formulaire_recherche = $this->genererFormulaireRecherche($donnees);
} else {
// Sinon on prend celui par defaut
$formulaire_recherche = $this->GetVue(Config::get('dossier_squelettes_formulaires').$annuaire['informations']['aa_code'].'_recherche',$donnees);
}
return $formulaire_recherche;
}
/**
* Recherche un ou plusieurs inscrits selon les valeurs passées en paramètres, qui peuvent êtres des valeurs
* dans l'annuaire mappé ou bien des valeurs de metadonnées
* @param int $id_annuaire l'identifiant de l'annuaire
* @param array $valeurs_recherchees les valeurs à rechercher
* @param boolean $exclusive indique si la recherche si fait sur tous les critères ou bien sur au moins un
* @param int $numero_page le numero de page demandé
* @param int $taille_page la taille de page
*/
public function rechercherInscrit($id_annuaire,$valeurs_recherchees, $exclusive = true, $numero_page = 1, $taille_page = 50) {
$this->chargerModele('AnnuaireModele');
$annuaire = $this->AnnuaireModele->chargerAnnuaire($id_annuaire, true);
if(isset($_GET['numero_page'])) {
$numero_page = $_GET['numero_page'];
}
if(isset($_GET['taille_page'])) {
$taille_page = $_GET['taille_page'];
}
$tableau_mappage = $this->AnnuaireModele->obtenirChampsMappageAnnuaire($id_annuaire);
//$valeurs_get = array('m' => $_GET['m']);
//$valeurs_get = array_merge($valeurs_get, $valeurs_recherchees);
$valeurs_mappees = array();
$valeurs = array();
// on itère sur le tableau de valeur pour récupérer les métadonnées;
foreach($valeurs_recherchees as $nom_champ => $valeur) {
// pour chaque valeur
// on extrait l'id du champ
$ids_champ = mb_split("_",$nom_champ);
if(count($ids_champ) == 2) {
// l'identifiant du champ est la dernière valeur du tableau
$type = $ids_champ[0];
$id_champ = $ids_champ[1];
// Si le champ fait partie des champs mappés
$cle_champ = array_search($id_champ, $tableau_mappage[1]);
if($cle_champ) {
// on ajoute sa clé correspondante dans l'annuaire mappé et sa valeur dans le tableau des champs mappés
$valeurs_mappees[$tableau_mappage[0][$cle_champ]] = $valeur;
// et on supprime sa valeur du tableau de valeurs pour ne pas la retrouver lors
// de l'insertion des métadonnées
} else {
$valeurs_recherchees[$id_champ] = $valeur;
}
// on retire la valeur du tableau pour ne pas la retrouver dans les deux recherches
$valeurs_get[$nom_champ] = $valeur;
}
unset($valeurs_recherchees[$nom_champ]);
}
$champ_id_annuaire = $tableau_mappage[0]['champ_id'];
// on recherche dans les métadonnées
$this->chargerModele('MetadonneeModele');
// le résultat est un ensemble d'identifiants
$resultat_metadonnees = $this->MetadonneeModele->rechercherDansValeurMetadonnees($id_annuaire,$valeurs_recherchees, $exclusive);
// on recherche les infos dans la table annuaire mappée
// en incluant ou excluant les id déjà trouvées dans les metadonnées
// suivant le critères d'exclusivité ou non
$resultat_annuaire_mappe = $this->AnnuaireModele->rechercherInscritDansAnnuaireMappe($id_annuaire,$valeurs_mappees, $resultat_metadonnees, $exclusive, $numero_page, $taille_page);
$resultat_recherche = $resultat_annuaire_mappe['resultat'];
$nb_resultats = $resultat_annuaire_mappe['total'];
// on renvoie une liste identique à celle de la liste des inscrits
$donnees['resultats_recherche'] = $resultat_recherche;
$donnees['tableau_mappage'] = $tableau_mappage[0];
$donnees['id_annuaire'] = $id_annuaire;
$donnees['nb_resultats'] = $nb_resultats;
$url_base = new URL(Registre::getInstance()->get('base_url_application'));
$url_pagination = clone($url_base);
$valeurs_get['id_annuaire'] = $id_annuaire;
$valeurs_get['m'] = $_GET['m'];
$donnees['pagination'] = $this->paginer($numero_page,$taille_page,$nb_resultats,$url_pagination, $valeurs_get);
$vue_resultat_recherche = $this->getVue(Config::get('dossier_squelettes_annuaires').'annuaire_resultat_recherche', $donnees);
return $this->afficherFormulaireRecherche($id_annuaire, $valeurs_get).$vue_resultat_recherche;
}
/** Recherche un ou plusieurs inscrits selon des indications géographiques, qui peuvent êtres des valeurs
* dans l'annuaire mappé ou bien des valeurs de metadonnées
* @param int $id_annuaire l'identifiant de l'annuaire
* @param array $valeurs_recherchees les valeurs à rechercher
* @param boolean $exclusive indique si la recherche si fait sur tous les critères ou bien sur au moins un
* @param int $numero_page le numero de page demandé
* @param int $taille_page la taille de page
*/
public function rechercherInscritParlocalisation($id_annuaire,$valeurs_recherchees, $numero_page = 1, $taille_page = 50) {
if(isset($_GET['taille_page'])) {
$taille_page = $_GET['taille_page'];
} else {
$taille_page = 50;
}
if(isset($_GET['numero_page'])) {
$numero_page = $_GET['numero_page'];
} else {
$numero_page = 1;
}
$this->chargerModele('AnnuaireModele');
$annuaire = $this->AnnuaireModele->chargerAnnuaire($id_annuaire, true);
$tableau_mappage = $this->AnnuaireModele->obtenirChampsMappageAnnuaire($id_annuaire);
$valeurs_get = $valeurs_recherchees;
$valeurs_mappees = array();
$valeurs = array();
$champ_id_annuaire = $tableau_mappage[0]['champ_id'];
$valeur = $valeurs_recherchees['pays'];
//Debug::printr($valeurs_get);
$champ_critere = 'U_COUNTRY';
$resultat_annuaire_mappe = $this->AnnuaireModele->rechercherInscritDansAnnuaireMappeParChamp($id_annuaire, $champ_critere, $valeur, true, $taille_page, $numero_page);
/*
// on recherche dans les métadonnées
$this->chargerModele('MetadonneeModele');
// le résultat est un ensemble d'identifiants
$resultat_metadonnees = $this->MetadonneeModele->rechercherDansValeurMetadonnees($id_annuaire,$valeurs_recherchees, false);
*/
// on recherche les infos dans la table annuaire mappée
// en incluant ou excluant les id déjà trouvées dans les metadonnées
// suivant le critères d'exclusivité ou non
//$resultat_annuaire_mappe = $this->AnnuaireModele->rechercherInscritDansAnnuaireMappe($id_annuaire,$valeurs_mappees, $resultat_metadonnees, $exclusive);
$resultat_recherche = $resultat_annuaire_mappe;
$nb_resultats = $resultat_recherche['total'];
$inscrits_resultats = $resultat_recherche['resultat'];
// on renvoie une liste identique à celle de la liste des inscrits
$donnees['resultats_recherche'] = $inscrits_resultats;
$donnees['tableau_mappage'] = $tableau_mappage[0];
$donnees['id_annuaire'] = $id_annuaire;
$donnees['nb_resultats'] = $nb_resultats;
//Debug::printr($donnees['resultats_recherche']);
$url_base = new URL(Registre::getInstance()->get('base_url_application'));
$url_pagination = new URL($url_base);
$donnees['pagination'] = $this->paginer($numero_page,$taille_page,$nb_resultats,$url_pagination, $valeurs_get);
$vue_resultat_recherche = $this->getVue(Config::get('dossier_squelettes_annuaires').'annuaire_resultat_recherche', $donnees);
return $vue_resultat_recherche;
}
/** --------------------------------- Fonction privées -------------------------------------------*/
/**
* En cas de tentative d'inscription, envoie un mail contenant un lien de confirmation à l'utilisateur
* @param string $adresse_mail adresse mail
* @param string $nom nom
* @param string $prenom prénom
* @param string $code_confirmation_inscription code de confirmation à inclure dans le mail
*
* @return boolean le succès ou l'échec de l'envoi du mail
*/
private function envoyerMailConfirmationInscription($adresse_mail, $nom, $prenom, $code_confirmation_inscription) {
$base_url = clone(Registre::getInstance()->get('base_url_application'));
$base_url->setVariableRequete('m','annuaire_inscription_confirmation');
$base_url->setVariableRequete('id',$code_confirmation_inscription);
$donnees = array('nom' => $nom, 'prenom' => $prenom, 'lien_confirmation_inscription' => $base_url->getURL());
$contenu_mail = $this->getVue(Config::get('dossier_squelettes_mails').'mail_confirmation_inscription',$donnees);
// Pour envoyer un mail HTML, l'en-tête Content-type doit être défini
$entetes = 'MIME-Version: 1.0' . "\r\n";
$entetes .= 'Content-type: text/html; charset='.Config::get('appli_encodage'). "\r\n";
// En-têtes additionnels
$entetes .= 'To: '.$adresse_mail."\r\n";
$entetes .= 'From: '.Config::get('adresse_mail_annuaire')."\r\n";
return mail($adresse_mail,'Inscription à l\'annuaire',$contenu_mail, $entetes);
}
/** En cas d'oubli de mot de passe, régénère le mot de passe et envoie un mail à l'utilisateur
* @param int $id_annuaire l'identifiant d'annuaire
* @param string $adresse_mail adresse mail
* @return boolean le succès ou l'échec de l'envoi du mail
*/
private function envoyerMailOubliMdp($id_annuaire,$mail, $nouveau_mdp) {
$base_url = clone(Registre::getInstance()->get('base_url_application'));
$base_url->setVariableRequete('m','annuaire_fiche_utilisateur_consultation');
$base_url->setVariableRequete('id',1);
$donnees['nouveau_mdp'] = $nouveau_mdp;
$donnees['lien_profil'] = $base_url;
$contenu_mail = $this->getVue(Config::get('dossier_squelettes_mails').'mail_oubli_mdp',$donnees);
// Pour envoyer un mail HTML, l'en-tête Content-type doit être défini
$entetes = 'MIME-Version: 1.0' . "\r\n";
$entetes .= 'Content-type: text/html; charset='.Config::get('appli_encodage'). "\r\n";
// En-têtes additionnels
$entetes .= 'To: '.$mail."\r\n";
$entetes .= 'From: '.Config::get('adresse_mail_annuaire')."\r\n";
return mail($mail,'Inscription à l\'annuaire',$contenu_mail, $entetes);
}
/**
* Insère les données dans la table d'inscription temporaire et crée un code de confirmation (à insérer dans le mail)
* @param Array $valeurs les valeurs à insérer
*/
private function InsererDansTableTemporaireEtCreerCodeConfirmationInscription($valeurs) {
// Le code de confirmation est constitué des 8 premiers caractères de l'identifiant de session
$code_confirmation = substr(session_id(), 0, 8) ;
$this->chargerModele('AnnuaireModele');
if(!$this->AnnuaireModele->ajouterNouvelleInscriptionTemporaire($code_confirmation, $valeurs)) {
return false;
}
return $code_confirmation;
}
/**--------------------------- Fonctions de vérification et de correspondance des champs --------------------*/
/**
* Renvoie les champs de mappage correspondant à un annuaire donné
* @param int $id_annuaire l'indentifant de l'annuaire pour lequel on veut ces informations
* @return Array un tableau de mappage des champs
*
*/
private function obtenirChampsMappageAnnuaire($id_annuaire) {
$this->chargerModele('AnnuaireModele');
$tableau_mappage = $this->AnnuaireModele->obtenirChampsMappageAnnuaire($id_annuaire);
return $tableau_mappage;
}
/**
* Renvoie le formulaire demandé s'il existe, sinon faux
* @param string $nom_formulaire le nom du formulaire demandé (qui est normalement le code d'un annuaire)
* @return boolean true si le formulaire existe, false sinon
*/
private function formulaireExiste($nom_formulaire) {
return $this->templateExiste($nom_formulaire.'_inscription', Config::get('dossier_squelettes_formulaires'));
}
/**
* Renvoie le template demandé s'il existe, sinon faux
* @param string $nom_formulaire le nom du formulaire demandé (qui est normalement le code d'un annuaire)
* @param string $dossier le nom du dossier sous dossier demandé
* @return boolean true si le formulaire existe, false sinon
*/
private function templateExiste($nom_template, $dossier = '/') {
return file_exists(Config::get('chemin_squelettes').$dossier.$nom_template.'.tpl.html');
}
/**
* Renvoie un formulaire d'inscription minimal auto-généré
* @param string $donnees les donnée à inclure dans le formulaire
* @return string la vue contenant le formulaire généré
*/
private function genererFormulaireInscription($donnees) {
$formulaire_modele = $this->getVue(Config::get('dossier_squelettes_formulaires').'inscription',$donnees);
if($formulaire_modele) {
return $formulaire_modele;
} else {
trigger_error("impossible de trouver le squelette de référence pour le formulaire");
}
return false;
}
/**
* Renvoie un formulaire d'inscription minimal auto-généré
* @param string $donnees les donnée à inclure dans le formulaire
* @return string la vue contenant le formulaire généré
*/
private function genererFormulaireRecherche($donnees) {
$formulaire_modele = $this->getVue(Config::get('dossier_squelettes_formulaires').'recherche',$donnees);
if($formulaire_modele) {
return $formulaire_modele;
} else {
trigger_error("impossible de trouver le squelette de référence pour le formulaire");
}
return false;
}
/**
* Renvoie le template de pagination, considérant des éléments donnés en paramètre
* @param int $numero_page le numéro de page en cours
* @param int $taille_page la taille de page
* @param int $total le nombre total de pages
* @param object $url_base l'url de base de la page
* @param array $valeurs les valeurs à concatener à l'url
* @return string le html contenu la template de pagination rempli avec les infos
*/
private function paginer($numero_page = 1, $taille_page = 50, $total, $url_base, $valeurs) {
// TODO, faire plus complexe, tri alphabétique etc...
$page_precedente = $numero_page-1;
$page_suivante = $numero_page+1;
if($taille_page <= 0) {
$taille_page = 1;
}
$nombre_pages = round($total/$taille_page,'PHP_ROUND_HALF_DOWN') ;
foreach($valeurs as $cle => $variable) {
$url_base->setVariableRequete($cle,$variable);
}
if($numero_page < 2) {
$page_precedente = false;
$url_page_precedente = '';
} else {
$url_page_prec = clone($url_base);
$url_page_prec->setVariableRequete('numero_page',($page_precedente));
$url_page_prec->setVariableRequete('taille_page',($taille_page));
$url_page_precedente = $url_page_prec->getUrl();
}
if($taille_page*($numero_page) >= $total) {
$page_suivante = false;
$url_page_suivante = '';
} else {
$url_page_suiv = clone($url_base);
$url_page_suiv->setVariableRequete('numero_page',($page_suivante));
$url_page_suiv->setVariableRequete('taille_page',($taille_page));
$url_page_suivante = $url_page_suiv->getUrl();
}
$urls_pages = array();
for($i = 1; $i <= $nombre_pages ; $i++) {
$url_page_prev = clone($url_base);
$url_page_prev->setVariableRequete('numero_page',($i));
$url_page_prev->setVariableRequete('taille_page',($taille_page));
$url_pages[$i] = $url_page_prev->getUrl();
}
$donnees = array('url_pages' => $url_pages, 'numero_page' => $numero_page,
'page_precedente' => $page_precedente, 'page_suivante' => $page_suivante,
'url_page_precedente' => $url_page_precedente, 'url_page_suivante' => $url_page_suivante,
'nombre_pages' => $nombre_pages, 'taille_page' => $taille_page);
$donnees['base_url_pagination'] = $url_base;
return $this->getVue(Config::get('dossier_squelettes_elements').'pagination',$donnees);
}
/** --- Fonction pour les images ------------------------------------------------------------------------*/
public function afficherFormulaireUploadImage($id_annuaire,$id_utilisateur, $donnees = array()) {
$donnees['aa_id_annuaire'] = $id_annuaire;
$donnees['id_utilisateur'] = $id_utilisateur;
$donnees['amc_nom'] = 'Avatar';
$this->chargerModele('AnnuaireModele');
$id_champ_image = $this->AnnuaireModele->obtenirChampAvatar($id_annuaire);
if(!$id_champ_image) {
$donnees['erreurs'] = 'Aucun champ n\'est défini pour l\'image de profil';
return $this->getVue(Config::get('dossier_squelettes_elements').'erreurs',$donnees);
}
$donnees['amc_id_champ'] = $id_champ_image;
return $this->getVue(Config::get('dossier_squelettes_champs').'image',$donnees);
}
/**
* Ajoute une image uploadée à travers le formulaire
*
*/
public function ajouterImageUtilisateur($id_annuaire, $id_utilisateur, $fichier_a_stocker, $retourner_booleen = false) {
$donnees = array('erreurs' => array());
foreach($fichier_a_stocker as $nom_champ => $fichier) {
$ids_champ = mb_split("_",$nom_champ, 3);
if(count($ids_champ) == 2) {
$type = $ids_champ[0];
$id_champ = $ids_champ[1];
} else {
trigger_error('Ce champ n\'est pas relié à un annuaire');
return false;
}
$this->chargerModele('ImageModele');
$format_accepte = $this->ImageModele->verifierFormat($fichier['name']);
if(!$format_accepte) {
$donnees['erreurs'][$id_champ] = 'Cette extension de fichier n\'est pas prise en charge';
return $this->afficherFormulaireUploadImage($id_annuaire, $id_utilisateur,$id_champ,$donnees);
}
$stockage_image = $this->ImageModele->stockerFichier($id_annuaire, $id_utilisateur, $fichier);
$this->chargerModele('MetadonneeModele');
if($stockage_image && $this->MetadonneeModele->ajouterNouvelleValeurMetadonnee($id_champ,$id_utilisateur,$stockage_image)) {
} else {
$donnees['erreurs'][$id_champ] = 'Problème durant le stockage de l\'image';
return $this->afficherFormulaireUploadImage($id_annuaire, $id_utilisateur,$id_champ,$donnees);
}
}
if($retourner_booleen) {
return true;
} else {
return $this->afficherFicheUtilisateur($id_annuaire, $id_utilisateur) ;
}
}
public function chargerNombreAnnuaireListeInscritsParPays($id_annuaire, $id_zones) {
$annuaire_modele = $this->getModele('AnnuaireModele');
return $annuaire_modele->chargerNombreAnnuaireListeInscritsParPays($id_annuaire, $id_zones);
}
public function chargerNombreAnnuaireListeInscritsParDepartement($id_annuaire) {
$this->chargerModele('AnnuaireModele');
return $this->AnnuaireModele->chargerNombreAnnuaireListeInscritsParDepartement($id_annuaire);
}
}
?>