Subversion Repositories Applications.annuaire

Rev

Rev 99 | Rev 120 | 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) {

                // ajout de l'url de l'appli
                $donnees['base_url'] = new Url(Config::get('base_url_application'));
                                
                $donnees['base_url_styles'] = new Url(Config::get('base_url_styles'));
                
                $donnees['url_cette_page'] = $_SERVER['SERVER_NAME'].$_SERVER['REQUEST_URI'];

                //ajout des variables d'identification
                $donnees['est_admin'] = Registre::getInstance()->get('est_admin');
                $donnees['identification_id'] = Registre::getInstance()->get('identification_id');
                $donnees['identification_mail'] = Registre::getInstance()->get('identification_mail');

                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;
        }

        /**
     * Fonction d'affichage par défaut
     */
    public function executerActionParDefaut() {

        if(Registre::getInstance()->get('est_admin')) {
                        $data = array();
                        $index_annuaire = $this->getVue('index_annuaire', $data);

                        return $index_annuaire;
        } else {
                        return $this->afficherFicheUtilisateur(Registre::getInstance()->get('identification_id'));
        }
    }

/**-------- 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_annuaire, $numero_page = 1, $taille_page = 50) {

                $this->chargerModele('AnnuaireModele');
                $annuaire = $this->AnnuaireModele->chargerAnnuaire($id_annuaire);
                $data['erreurs'] = array();
                $tableau_mappage = $this->obtenirChampsMappageAnnuaire($id_annuaire);
                $champ_id_annuaire = $tableau_mappage[0]['champ_id'];

                $resultat_recherche = $this->AnnuaireModele->chargerAnnuaireListeInscrits($id_annuaire, $numero_page, $taille_page);    
                                                
                $nb_resultats = $resultat_recherche['total'];
                $resultat_recherche = $resultat_recherche['resultat'];
                
                $resultats = array();
                foreach($resultat_recherche as $resultat) {
                        $id_utilisateur = $resultat[$champ_id_annuaire];
                        $resultats[$id_utilisateur] = $this->obtenirValeursUtilisateur($id_annuaire, $id_utilisateur);
                }

                // on renvoie une liste identique à celle de la liste des inscrits
                $donnees['resultats_recherche'] = $resultats;
                $donnees['tableau_mappage'] = $tableau_mappage[1];
                $donnees['id_annuaire'] = $id_annuaire;
                $donnees['nb_resultats'] = $nb_resultats;
                $url_pagination = new URL(Registre::getInstance()->get('base_url_application'));
                $url_pagination->setVariableRequete('m','annuaire_inscrits');
                $url_pagination->setVariableRequete('id_annuaire',$id_annuaire);

                $donnees['pagination'] = $this->paginer($numero_page,$taille_page,$nb_resultats,$url_pagination, array());

                // S'il existe une page de résultats spécifique à l'annuaire pour la recherche

                if($this->templateExiste($annuaire['informations']['aa_code'].'_resultat_recherche', Config::get('dossier_squelettes_annuaires'))) {
                        // on l'affiche
                        $annuaires_inscrits = $this->getVue(Config::get('dossier_squelettes_annuaires').$annuaire['informations']['aa_code'].'_resultat_recherche', $donnees);
                } else {
                        // sinon on prend celle par défaut
                        $annuaires_inscrits = $this->getVue(Config::get('dossier_squelettes_annuaires').'resultat_recherche', $donnees);
                }

                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) {

                // 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;

                if(isset($donnees['amc_ce_template_affichage'])) {
                        $nom_type_champ = $donnees['amc_ce_template_affichage'];
                } else {
                        $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']);
                
                $valeurs_mappees = array();
                $valeurs_a_inserer = array();

                $tableau_mappage = $this->obtenirChampsMappageAnnuaire($id_annuaire);

                $verificateur = new VerificationControleur();

                $valeurs_collectees = $verificateur->collecterValeurInscription($valeurs, $tableau_mappage);
                
                $valeurs_mappees = $valeurs_collectees['valeurs_mappees'];
                $valeurs_a_inserer = $valeurs_collectees['valeurs_a_inserer'];

                // 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 ;

                $this->chargerModele('DonneeTemporaireModele');
                                
                $code_confirmation = $this->DonneeTemporaireModele->stockerDonneeTemporaire($valeurs_a_inserer);
                
                $mail = $valeurs_mappees[$tableau_mappage[1]['champ_mail']]['valeur'];
                $nom = $valeurs_mappees[$tableau_mappage[1]['champ_nom']]['valeur'];
                $prenom = $valeurs_mappees[$tableau_mappage[1]['champ_prenom']]['valeur'];


                $this->envoyerMailConfirmationInscription($mail,
                                                                                                        $nom,
                                                                                                        $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('DonneeTemporaireModele');
                $valeurs = $this->DonneeTemporaireModele->chargerDonneeTemporaire($identifiant);

                if(!$valeurs || count($valeurs) == 0) {
                        // TODO afficher vue en cas d'echec
                }

                $this->chargerModele('AnnuaireModele');

                $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['password_'.$tableau_mappage[1]['champ_pass']];

                $nom = $valeurs['text_'.$tableau_mappage[1]['champ_nom']];
                $prenom = $valeurs['text_'.$tableau_mappage[1]['champ_prenom']];
                $mail = $mail_nouvel_inscrit;
                $pass = $valeurs['password_'.$tableau_mappage[1]['champ_pass']];
                $pays = $valeurs['select_'.$tableau_mappage[1]['champ_pays']];

                // 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;
                        }
                }

                if(isset($valeurs_mappees[$tableau_mappage[0]['champ_pays']])) {
                        $pays = $valeurs_mappees[$tableau_mappage[0]['champ_pays']];
                        $valeurs_metadonnees[$tableau_mappage[1]['champ_pays']] = $pays;
                        $pays = $this->MetadonneeModele->renvoyerCorrespondanceAbreviationId($pays);
                        $valeurs_mappees[$tableau_mappage[0]['champ_pays']] = $pays;
                }

                // obtenir l'id du nouvel arrivant en faisant un select sur le mail qui doit être unique
                $id_nouvel_inscrit = $this->AnnuaireModele->ajouterInscriptionDansAnnuaireMappe($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.
                                // La transaction du pauvre en quelque sorte
                                $this->MetadonneeModele->supprimerValeursMetadonneesParIdEnregistrementLie($id_nouvel_inscrit);
                                return false;
                        }
                }

                        $appli_controleur = new ApplicationExterneControleur();

                        $params = array (
                                'id_utilisateur' => $id_nouvel_inscrit,
                                'prenom' => $prenom,
                                'nom' => $nom,
                                'mail' => $mail,
                                'pass' => $pass,
                                'pays' => $pays,
                                'nouveau_pass' => '',
                                'nouveau_mail' => ''
                        );

                // on crée un controleur qui appelle les webservice pour chaque application externe
                $resumes_controleur = new ApplicationExterneControleur();
                $resumes_controleur->ajouterInscription($id_nouvel_inscrit, $params);

                // 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->loggerUtilisateur($mail, $pass);

                // 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);
                }
        }

        /**
         * 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);

                $donnees['id_annuaire'] = $id_annuaire;
                $donnees['id_utilisateur'] = $id_utilisateur;
                
                $verificateur = new VerificationControleur();
                
                $champs = $this->obtenirValeursUtilisateur($id_annuaire, $id_utilisateur);

                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;

                /*if(Registre::getInstance()->get('est_admin')) {
                        $donnees['formulaire_blocage'] = $this->getVue(Config::get('dossier_squelettes_elements').'blocage',$donnees);
                }*/

                $fiche_inscrit = $this->getVue(Config::get('dossier_squelettes_fiches').$annuaire['informations']['aa_code'].'_fiche',$donnees);

                return $fiche_inscrit;
        }

        /** 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');
                $annuaire = $this->AnnuaireModele->chargerAnnuaire($id_annuaire);
                $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;
                $donnees['mail_utilisateur'] = $mail_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['informations']['aa_code'].'_carte_id',$donnees);

                $fiche_contrib = $this->getVue(Config::get('dossier_squelettes_fiches').$annuaire['informations']['aa_code'].'_resume',$donnees);

                return $fiche_contrib;
        }

        public function gererInscriptionExterne($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);
                }

                $mail_utilisateur = $this->AnnuaireModele->obtenirMailParId($id_annuaire,$id_utilisateur);

                // on crée un controleur appelle les hooks de résumé pour chaque application externe
                $resumes_controleur = new ApplicationExterneControleur();

                $donnees['champs'] = $champs;
                $donnees['resumes'] = $resumes_controleur->gererInscription($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_gestion_inscription',$donnees);

                return $fiche_contrib;
        }

        public function afficherFormulaireModificationInscription($id_annuaire, $id_utilisateur, $erreurs = array()) {
                
                $this->chargerModele('AnnuaireModele');
                $annuaire = $this->AnnuaireModele->chargerAnnuaire($id_annuaire);
                
                $donnees['aa_id_annuaire'] = $id_annuaire;
                
                $this->chargerModele('MetadonneeModele');
                $champ_metadonnees = $this->MetadonneeModele->chargerListeMetadonneeAnnuaire($id_annuaire);
                $valeurs_metadonnees = $this->obtenirValeursUtilisateur($id_annuaire, $id_utilisateur);
                
                // 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($champ_metadonnees as $champ_metadonnee) {

                        $id_champ = $champ_metadonnee['amc_id_champ'];
                        $nom_champ = $champ_metadonnee['amc_abreviation'];
                        
                        if(isset($valeurs_metadonnees[$nom_champ])) {
                                $champ_metadonnee['valeur_defaut'] = $valeurs_metadonnees[$nom_champ];
                        }

                        $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,$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);
                }


                if(isset($valeurs_mappees[$tableau_mappage[0]['champ_pays']])) {
                        $pays = $valeurs_mappees[$tableau_mappage[0]['champ_pays']];
                        $valeurs_metadonnees[$tableau_mappage[1]['champ_pays']] = $pays;
                        $pays = $this->MetadonneeModele->renvoyerCorrespondanceAbreviationId($pays);
                        $valeurs_mappees[$tableau_mappage[0]['champ_pays']] = $pays;
                }


                $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);

                // Si le mail a changé alors il faut appeler les applications externes pour modification
                if($ancien_mail != $mail_utilisateur || $tentative_changemement_mdp) {

                        $nom = $valeurs['text_'.$tableau_mappage[1]['champ_nom']];
                        $prenom = $valeurs['text_'.$tableau_mappage[1]['champ_prenom']];
                        $ancien_mail = $ancien_mail;
                        $mail = $mail_utilisateur;
                        $pass = $valeurs['password_'.$tableau_mappage[1]['champ_pass']];

                        $appli_controleur = new ApplicationExterneControleur();

                        $params = array (
                                'id_utilisateur' => $id_utilisateur,
                                'prenom' => $prenom,
                                'nom' => $nom,
                                'mail' => $mail,
                                'pass' => $pass,
                                'pays' => $pays,
                                'nouveau_pass' => $pass,
                                'nouveau_mail' => $nouveau_mail
                        );

                        $appli_controleur->modifierInscription($id_utilisateur, $params);

                        // pour qu'ils lancent les procédures de désinscription associées
                        $lettre_controleur = new LettreControleur();
                        $lettre_controleur->modificationInscriptionLettreActualite($ancien_mail, $nouveau_mail);
                }

                // 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
                                $this->MetadonneeModele->modifierValeurMetadonnee($id_champ,$id_utilisateur,$valeur);

                        } 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 {
                                        return false;
                                }
                        }
                }

                return $this->afficherFicheUtilisateur($id_annuaire, $id_utilisateur);
        }

        public function estAbonneLettreActualite($id_annuaire, $id_utilisateur) {

                $annuaire_modele = $this->getModele('AnnuaireModele');
                $champs_description = $annuaire_modele->obtenirChampsDescriptionAnnuaire($id_annuaire);

                $valeur = $annuaire_modele->obtenirValeurChampAnnuaireMappe($id_annuaire, $id_utilisateur, 'champ_lettre');

                return $valeur;
        }

        public function abonnerDesabonnerLettreActualite($id_annuaire, $id_utilisateur, $abonner = true) {

                $annuaire_modele = $this->getModele('AnnuaireModele');
                $champs_description = $annuaire_modele->obtenirChampsDescriptionAnnuaire($id_annuaire);

                $mail_utilisateur = $annuaire_modele->obtenirMailParId($id_annuaire, $id_utilisateur);

                $champ_lettre = $champs_description[0]['champ_lettre'];

                if($abonner) {
                        $valeur = 'on';
                } else {
                        $valeur = '0';
                }

                $verificateur = new VerificationControleur();
                $valeur_modif = $verificateur->remplacerValeurChampPourModification($id_annuaire, $id_utilisateur, 'lettre', $valeur, $mail_utilisateur);


                $annuaire_modele = $this->getModele('AnnuaireModele');
                $valeur_modif = $annuaire_modele->modifierValeurChampAnnuaireMappe($id_annuaire, $id_utilisateur, $champ_lettre, $valeur_modif);
                //$this->chargerModele('MetadonneeModele');
                //$this->MetadonneeModele->modifierValeurMetadonnee($champ_lettre,$id_utilisateur,$valeur_modif);

                return $valeur_modif;
        }

        public function bloquerDebloquerUtilisateur($id_annuaire, $id_utilisateur, $bloquer = true) {

                $annuaire_modele = $this->getModele('AnnuaireModele');
                $champs_description = $annuaire_modele->obtenirChampsDescriptionAnnuaire($id_annuaire);

                $valeur = '0';

                if($bloquer) {
                        $valeur = '1';
                }

                $metadonne_modele = $this->getModele('MetadonneeModele');
                $metadonne_modele->modifierValeurMetadonnee($champs_description[1]['champ_statut'],$id_utilisateur,$valeur);

                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'] = 'Erreur lors de la suppression de l\'inscription ';

                        return $this->getVue(Config::get('dossier_squelettes_elements').'erreurs',$donnees);
                }

                $params = array (
                                'id_utilisateur' => $id_utilisateur,
                                'prenom' => '',
                                'nom' => '',
                                'mail' => $mail_utilisateur,
                                'pass' => '',
                                'pays' => '',
                                'nouveau_pass' => '',
                                'nouveau_mail' => ''
                        );

                // on appelle les controleur de lettre actu et d'applications externes
                $appli_controleur = new ApplicationExterneControleur();
                $appli_controleur->supprimerInscription($id_utilisateur, $params);

                // 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) {

                        $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
         */
        public function rechercherInscrit($id_annuaire,$valeurs_recherchees, $exclusive = true) {

                $this->chargerModele('AnnuaireModele');
                $annuaire = $this->AnnuaireModele->chargerAnnuaire($id_annuaire, true);

                if(isset($_GET['numero_page'])) {
                        $numero_page = $_GET['numero_page'];
                } else {
                        $numero_page = 1;
                }

                if(isset($_GET['taille_page'])) {
                        $taille_page = $_GET['taille_page'];
                } else {
                        $taille_page = 50;
                }

                $tableau_mappage = $this->AnnuaireModele->obtenirChampsMappageAnnuaire($id_annuaire);

                $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]);
                }
                
                //Debug::printr($valeurs_recherchees);

                $admin = Registre::getInstance()->get('est_admin');

                //if(!$admin) {
                //      $champs_blocage = $this->AnnuaireModele->obtenirChampsDescriptionAnnuaire($id_annuaire);
                //      $valeurs_recherchees[$champs_blocage[1]['champ_statut']] = '0';
                //}

                $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'];
                
                $resultats = array();
                foreach($resultat_recherche as $resultat) {
                        $id_utilisateur = $resultat[$champ_id_annuaire];
                        $resultats[$id_utilisateur] = $this->obtenirValeursUtilisateur($id_annuaire, $id_utilisateur);
                }

                // on renvoie une liste identique à celle de la liste des inscrits
                $donnees['resultats_recherche'] = $resultats;
                $donnees['tableau_mappage'] = $tableau_mappage[1];
                $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);

                // S'il existe une page de résultats spécifique à l'annuaire pour la recherche
                if($this->templateExiste($annuaire['informations']['aa_code'].'_resultat_recherche', Config::get('dossier_squelettes_annuaires'))) {
                        // on l'affiche
                        $vue_resultat_recherche = $this->getVue(Config::get('dossier_squelettes_annuaires').$annuaire['informations']['aa_code'].'_resultat_recherche', $donnees);

                } else {
                        // sinon on prend celle par défaut
                        $vue_resultat_recherche = $this->getVue(Config::get('dossier_squelettes_annuaires').'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) {

                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'];
                $champ_critere = $tableau_mappage[0]['champ_pays'];

                if(isset($valeurs_recherchees['departement'])) {
                        $valeur = $valeurs_recherchees['departement'];
                        $champ_critere = $tableau_mappage[0]['champ_code_postal'];
                }

                $resultat_annuaire_mappe = $this->AnnuaireModele->rechercherInscritDansAnnuaireMappeParChamp($id_annuaire, $champ_critere, $valeur, true, $numero_page, $taille_page);

                $resultat_recherche = $resultat_annuaire_mappe;
                
                $nb_resultats = $resultat_recherche['total'];
                $resultat_recherche = $resultat_recherche['resultat'];
                
                $resultats = array();
                foreach($resultat_recherche as $resultat) {
                        $id_utilisateur = $resultat[$champ_id_annuaire];
                        $resultats[$id_utilisateur] = $this->obtenirValeursUtilisateur($id_annuaire, $id_utilisateur);
                }

                // on renvoie une liste identique à celle de la liste des inscrits
                $donnees['resultats_recherche'] = $resultats;
                $donnees['tableau_mappage'] = $tableau_mappage[1];
                $donnees['id_annuaire'] = $id_annuaire;
                $donnees['nb_resultats'] = $nb_resultats;
                
                //Debug::printr($resultat_annuaire_mappe);

                $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);

                // S'il existe une page de résultats spécifique à l'annuaire pour la recherche
                if($this->templateExiste($annuaire['informations']['aa_code'].'_resultat_recherche', Config::get('dossier_squelettes_annuaires'))) {
                        // on l'affiche
                        $vue_resultat_recherche = $this->getVue(Config::get('dossier_squelettes_annuaires').$annuaire['informations']['aa_code'].'_resultat_recherche', $donnees);

                } else {
                        // sinon on prend celle par défaut
                        $vue_resultat_recherche = $this->getVue(Config::get('dossier_squelettes_annuaires').'resultat_recherche', $donnees);
                }
                
                return $vue_resultat_recherche;
        }


/** ---------------------------------    Fonction d'extraction d'informations utilisées par les web services -------------------------------------------*/

        public function obtenirIdParMail($id_annuaire, $mail_utilisateur) {
                
                $this->chargerModele('AnnuaireModele');
                $id = $this->AnnuaireModele->obtenirIdParMail('1',$mail_utilisateur);
                
                return $id;
        }
        
        public function utilisateurExiste($id_annuaire,$id, $utilise_mail = true) {

                $this->chargerModele('AnnuaireModele');

                if($utilise_mail) {
                        $existe = $this->AnnuaireModele->utilisateurExisteParMail($id_annuaire,$id);
                } else {
                        $existe = $this->AnnuaireModele->utilisateurExisteParId($id_annuaire,$id);
                }

                return $existe;
        }

        public function obtenirInfosUtilisateurOpenId($id_annuaire,$id, $mail = true) {

                $this->chargerModele('AnnuaireModele');

                if($mail) {
                        $id = $this->AnnuaireModele->obtenirIdParMail($id_annuaire,$id);
                }

                $champs_mappage = $this->AnnuaireModele->obtenirChampsMappageAnnuaire($id_annuaire);

                $valeurs = $this->AnnuaireModele->obtenirValeursUtilisateur($id_annuaire,$id, $champs_mappage[0]);

                // TODO: valeurs incomplètes, voir ce qu'on renvoie obligatoirement
                // et ce qu'on ne renvoie pas
                $valeurs_open_id = array('fullname' => $valeurs[$champs_mappage[0]['champ_nom']].' '.$valeurs[$champs_mappage[0]['champ_prenom']],
                           'nickname' => $valeurs[$champs_mappage[0]['champ_nom']],
                           'dob' => '25/10/1984',
                           'email' => $valeurs[$champs_mappage[0]['champ_mail']],
                           'gender' => 'M',
                           'postcode' => $valeurs[$champs_mappage[0]['champ_code_postal']],
                           'country' => 'FR',
                           'language' => 'fr',
                           'timezone' => 'Europe/Paris');

                return $valeurs_open_id;
        }

        public function comparerIdentifiantMotDePasse($id_annuaire,$id_utilisateur,$mot_de_passe, $utilise_mail = true, $mdp_deja_crypte = true) {

                $this->chargerModele('AnnuaireModele');

                if($utilise_mail) {
                        $id_utilisateur = $this->AnnuaireModele->obtenirIdParMail($id_annuaire,$id_utilisateur);
                }

                if(!$mdp_deja_crypte) {
                        $mot_de_passe = VerificationControleur::encrypterMotDePasseStatic($mot_de_passe);
                }

                return $this->AnnuaireModele->comparerIdentifiantMotDePasse($id_annuaire,$id_utilisateur,$mot_de_passe);
        }


/** ---------------------------------    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) {

                $url_cette_page = 'http://'.$_SERVER['SERVER_NAME'].$_SERVER['REQUEST_URI'];
                $base_url = new URL($url_cette_page);
                $base_url->setVariablesRequete(array());
                $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);

        }


/**--------------------------- 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();
                }

                $url_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(), 'aa_id_annuaire' => $id_annuaire);

                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($this->MetadonneeModele->valeurExiste($id_champ,$id_utilisateur)) {
                                // On se contente de la modifier
                                if($stockage_image && $this->MetadonneeModele->modifierValeurMetadonnee($id_champ,$id_utilisateur,$id_utilisateur)) {

                                } else {
                                        $donnees['erreurs'][$id_champ] = 'Problème durant le stockage de l\'image';
                                        return $this->afficherFormulaireUploadImage($id_annuaire, $id_utilisateur,$id_champ,$donnees);
                                }

                        } else {
                                // S'il n'existe pas de valeur, on ajoute une nouvelle ligne à la table de valeurs de meta données
                                if($stockage_image && $this->MetadonneeModele->ajouterNouvelleValeurMetadonnee($id_champ,$id_utilisateur,$id_utilisateur)) {
                                        // Si l'insertion a réussi, on continue
                                } 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 obtenirValeursUtilisateur($id_annuaire, $id_utilisateur) {
                
                $this->chargerModele('AnnuaireModele');
                $annuaire = $this->AnnuaireModele->chargerAnnuaire($id_annuaire, false);

                $this->chargerModele('MetadonneeModele');

                $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) {

                        if($cle != 'champ_id') {

                                $nom_champ_formulaire = $metadonnees[$tableau_mappage[1][$cle]]['amc_abreviation'];
                                $valeur = $valeurs_annuaire[$nom_champ] ;
                                
                                if(isset($valeurs_metadonnees[$nom_champ_formulaire])) {
                                        if(isset($valeurs_metadonnees[$nom_champ_formulaire]['amv_valeur']) && $valeurs_metadonnees[$nom_champ_formulaire]['amv_valeur'] != '') {
                                                $valeur = $valeurs_metadonnees[$nom_champ_formulaire]['amv_valeur'];
                                        } 
                                        $informations_champ = array('amv_valeur' => $valeur,'amc_id_champ' => $tableau_mappage[1][$cle]) ;
                                        $valeurs_metadonnees[$nom_champ_formulaire] = array_merge($valeurs_metadonnees[$nom_champ_formulaire],$informations_champ);
                                } else {
                                        $informations_champ = array('amv_valeur' => $valeur,'amc_id_champ' => $tableau_mappage[1][$cle]) ;
                                        $valeurs_metadonnees[$nom_champ_formulaire] = $informations_champ;
                                }
                        }
                }
                
                return $valeurs_metadonnees;
        }
        
        public function obtenirTableauDerniersInscrits($id_annuaire, $limite = '20') {
                
                // 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);
                $this->chargerModele('AnnuaireModele');
                $tableau_ids = $this->AnnuaireModele->obtenirTableauIdsUtilisateurs($id_annuaire, $tableau_mappage[0]);
                
                $derniers_inscrits = array();
                
                foreach($tableau_ids as $id) {
                        
                        $id_utilisateur = $id[$tableau_mappage[0][champ_id]];
                        $derniers_inscrits[$id_utilisateur] = $this->obtenirValeursUtilisateur($id_annuaire, $id_utilisateur);
                }
                
                return $derniers_inscrits;
        }

        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);
        }
}
?>