/**
  * Ajouter un événement à la BDD
  * 
  * @param string $type             Type (adresse ou personne)
  * @param array  $arrayNewAdresses Contenu lié
  * 
  * @return void
  * */
 function addEvent($type = "adresse", $arrayNewAdresses = array())
 {
     // ******************************************************
     // ensuite on ajoute l'evenement
     // ******************************************************
     $evenement = new archiEvenement();
     $idEvenementGroupeAdresses = 0;
     $idSousEvenement = 0;
     if ($type == "personne") {
         $linkTable = "_personneEvenement";
         $field = "idPersonne";
     } else {
         $linkTable = "_adresseEvenement";
         $field = "idAdresse";
     }
     $table = array('table' => $linkTable, 'field' => $field);
     //debug($arrayNewAdresses);
     //$arrayRetourEvenementNouveauDossier=$evenement->ajouterEvenementNouveauDossier();
     foreach ($arrayNewAdresses as $newAddress) {
         if (isset($newAddress['newAdresse']) && !empty($newAddress['newAdresse']) || $newAddress['newAdresse'] == 1) {
             //debug("full ajout");
             $arrayRetourEvenementNouveauDossier = $evenement->ajouterEvenementNouveauDossier();
         } else {
             //debug("ajout simple id : ".$newAddress['idAdresse']);
             $arrayRetourEvenementNouveauDossier = $evenement->ajouterEvenementNouveauDossier($newAddress['idAdresse']);
         }
     }
     //debug($arrayRetourEvenementNouveauDossier);
     // s'il n'y a pas eu d'erreurs ,  on peut faire l'ajout des liaisons entre evenement et adresses
     if (count($arrayRetourEvenementNouveauDossier['errors']) == 0 && count($arrayNewAdresses) > 0) {
         $idEvenementGroupeAdresses = $arrayRetourEvenementNouveauDossier['idEvenementGroupeAdresse'];
         $idSousEvenement = $arrayRetourEvenementNouveauDossier['idSousEvenement'];
         // liaison entre les adresses et l'evenement groupe d'adresses
         $resSupp = $this->connexionBdd->requete("delete from {$linkTable} where idEvenement = '" . $idEvenementGroupeAdresses . "'");
         // on rend la liste des identifiants unique
         $arrayNewIdAdresses = array();
         foreach ($arrayNewAdresses as $indice => $value) {
             $arrayNewIdAdresses[] = $value['idAdresse'];
         }
         $arrayNewIdAdresses = array_unique($arrayNewIdAdresses);
         foreach ($arrayNewIdAdresses as $indice => $idAdresse) {
             $reqLiaisons = "INSERT INTO {$linkTable} ({$field}, idEvenement)\n                                VALUES ('" . $idAdresse . "', '" . $idEvenementGroupeAdresses . "')\n                ";
             //debug($reqLiaisons);
             $resLiaisons = $this->connexionBdd->requete($reqLiaisons);
         }
         // on relie l'evenement pere (groupe d'adresse ) à l'evenement fils
         if (isset($newAddress['newAdresse']) && !empty($newAddress['newAdresse']) || $newAddress['newAdresse'] == 1) {
             $sqlAssociationNettoie = "delete from _evenementEvenement where idEvenement = '" . $arrayRetourEvenementNouveauDossier['idEvenementGroupeAdresse'] . "'";
             //debug($sqlAssociationNettoie);
             $resAssociationNettoie = $this->connexionBdd->requete($sqlAssociationNettoie);
         }
         $sqlAssociation = "insert into _evenementEvenement (idEvenement,idEvenementAssocie) values ('" . $arrayRetourEvenementNouveauDossier['idEvenementGroupeAdresse'] . "','" . $arrayRetourEvenementNouveauDossier['idSousEvenement'] . "')";
         //debug($sqlAssociation);
         $resAssociation = $this->connexionBdd->requete($sqlAssociation);
         if ($type == "personne") {
         } else {
             // *************************************************************************************************************************************************************
             // envoi d'un mail aux administrateur pour la moderation
             $utilisateur = new archiUtilisateur();
             $message = "L'utilisateur suivant a créé un nouveau dossier : ";
             $message .= $utilisateur->getMailUtilisateur($this->session->getFromSession('utilisateurConnecte' . $this->idSite)) . "<br>";
             $message .= "<a href='" . $this->creerUrl('', '', array('archiAffichage' => 'adresseDetail', 'archiIdAdresse' => $arrayNewIdAdresses[0], 'archiIdEvenementGroupeAdresse' => $idEvenementGroupeAdresses)) . "'>lien vers l'article</a><br>";
             $message .= "Adresses liées au nouveau dossier :<br>";
             $i = 0;
             $adressePourSujetMail = "";
             foreach ($arrayNewAdresses as $indice => $value) {
                 if ($i == 0) {
                     $adressePourSujetMail = $this->getIntituleAdresseFrom($value['idAdresse'], 'idAdresse');
                 }
                 if ($value['newAdresse'] == true) {
                     // cette adresse a été créée avec le dossier
                     $message .= "<a href='" . $this->creerUrl('', '', array('archiAffichage' => 'adresseDetail', 'archiIdEvenementGroupeAdresse' => $idEvenementGroupeAdresses, 'archiIdAdresse' => $value['idAdresse'])) . "'>" . $this->getIntituleAdresseFrom($value['idAdresse'], 'idAdresse') . " (nouvelle adresse)</a><br>";
                 } else {
                     /* cette adresse a été créée précédemment
                      * et est utilisée sur ce dossier
                      * */
                     $message .= "<a href='" . $this->creerUrl('', '', array('archiAffichage' => 'adresseDetail', 'archiIdEvenementGroupeAdresse' => $idEvenementGroupeAdresses, 'archiIdAdresse' => $value['idAdresse'])) . "'>" . $this->getIntituleAdresseFrom($value['idAdresse'], 'idAdresse') . " (cette adresse existait déjà " . "avant la création du dossier)" . "</a><br>";
                 }
             }
             $mail = new mailObject();
             $mail->sendMailToAdministrators($mail->getSiteMail(), "archi-strasbourg.org : " . "un utilisateur a créé un nouveau dossier - " . $adressePourSujetMail, $message, " and alerteMail='1' ", true);
             $u = new archiUtilisateur();
             $u->ajouteMailEnvoiRegroupesAdministrateurs(array('contenu' => $message, 'idTypeMailRegroupement' => 3, 'criteres' => " and alerteMail='1' "));
             /* envoi mail aussi au moderateur si ajout
              * sur adresse de ville que celui ci modere
              * */
             $arrayListeModerateurs = $u->getArrayIdModerateursActifsFromVille($this->variablesPost['ville'], array("sqlWhere" => " AND alerteMail='1' "));
             if (count($arrayListeModerateurs) > 0) {
                 foreach ($arrayListeModerateurs as $indice => $idModerateur) {
                     if ($this->session->getFromSession("utilisateurConnecte" . $this->idSite) != $idModerateur) {
                         $mailModerateur = $u->getMailUtilisateur($idModerateur);
                         if ($u->isMailEnvoiImmediat($idModerateur)) {
                             $mail->sendMail($mail->getSiteMail(), $mailModerateur, "archi-strasbourg.org : " . "un utilisateur a créé un nouveau dossier - " . $adressePourSujetMail, $message, true);
                         } else {
                             // envoi regroupé
                             $u->ajouteMailEnvoiRegroupes(array('contenu' => $message, 'idDestinataire' => $idModerateur, 'idTypeMailRegroupement' => 3));
                         }
                     }
                 }
             }
         }
         //echo $retourEvenement["html"];
         if ($type == "personne") {
             header("Location: " . $this->creerUrl('', '', array('archiAffichage' => 'evenementListe', 'selection' => "personne", 'id' => $idAdresse), false, false));
         } else {
             header("Location: " . $this->creerUrl('', '', array('archiAffichage' => 'adresseDetail', 'archiIdEvenementGroupeAdresse' => $idEvenementGroupeAdresses, 'archiIdAdresse' => $value['idAdresse']), false, false));
         }
     }
 }
 public function enregistreCommentaire()
 {
     $auth = new archiAuthentification();
     $fieldsCommentaires = $this->getCommentairesFields();
     $formulaire = new formGenerator();
     if ($auth->estConnecte()) {
         unset($fieldsCommentaires['captcha']);
     }
     $error = $formulaire->getArrayFromPost($fieldsCommentaires);
     if (count($error) == 0) {
         $idUtilisateur = 0;
         if ($auth->estConnecte()) {
             $idUtilisateur = $auth->getIdUtilisateur();
             // suite au SPAM mise en place d'un champ CommentaireValide 0/1 (by fabien 13/01/2012)
             $CommentaireValide = 1;
             $user = new archiUtilisateur();
             $userInfos = $user->getArrayInfosFromUtilisateur($idUtilisateur);
         } else {
             $CommentaireValide = 0;
         }
         // enregistrement du nouveau commentaire
         //$req = "insert into commentaires (nom,prenom,email,commentaire,idEvenementGroupeAdresse,date,idUtilisateur) values (\"".addslashes(strip_tags($this->variablesPost['nom']))."\",\"".addslashes(strip_tags($this->variablesPost['prenom']))."\",\"".addslashes(strip_tags($this->variablesPost['email']))."\",\"".addslashes(strip_tags($this->variablesPost['commentaire']))."\",'".$this->variablesPost['idEvenementGroupeAdresse']."',now(),'".$idUtilisateur."')";
         $nom = $auth->estConnecte() ? $userInfos["nom"] : $this->variablesPost['nom'];
         $prenom = $auth->estConnecte() ? $userInfos["prenom"] : $this->variablesPost['prenom'];
         $email = $auth->estConnecte() ? $user->getMailUtilisateur($idUtilisateur) : $this->variablesPost['email'];
         $uniqid = uniqid(null, true);
         $req = "INSERT INTO commentaires (nom, prenom, email, commentaire, idEvenementGroupeAdresse, date, idUtilisateur, CommentaireValide, uniqid) VALUES ('" . mysql_real_escape_string(strip_tags($nom)) . "', '" . mysql_real_escape_string(strip_tags($prenom)) . "', '" . mysql_real_escape_string(strip_tags($email)) . "', '" . mysql_real_escape_string(strip_tags($this->variablesPost['commentaire'])) . "', '" . mysql_real_escape_string($this->variablesPost['idEvenementGroupeAdresse']) . "', now(), '" . mysql_real_escape_string($idUtilisateur) . "'," . mysql_real_escape_string($CommentaireValide) . ", '" . mysql_real_escape_string($uniqid) . "')";
         $res = $this->connexionBdd->requete($req);
         $idCommentaire = mysql_insert_id();
         // retour a l'affichage de l'adresse
         $idAdresse = $this->getIdAdresseFromIdEvenementGroupeAdresse($this->variablesPost['idEvenementGroupeAdresse']);
         // ************************************************************************************************************************************************
         // envoi d'un mail a tous les participants pour le groupe d'adresse
         // ************************************************************************************************************************************************
         $mail = new mailObject();
         $utilisateur = new archiUtilisateur();
         $arrayUtilisateurs = $utilisateur->getParticipantsCommentaires($this->variablesPost['idEvenementGroupeAdresse']);
         $arrayCreatorAdresse = $utilisateur->getCreatorsFromAdresseFrom($this->variablesPost['idEvenementGroupeAdresse'], 'idEvenementGroupeAdresse');
         $arrayUtilisateurs = array_merge($arrayUtilisateurs, $arrayCreatorAdresse);
         $arrayUtilisateurs = array_unique($arrayUtilisateurs);
         $intituleAdresse = $this->getIntituleAdresseFrom($idAdresse, 'idAdresse');
         foreach ($arrayUtilisateurs as $indice => $idUtilisateurAdresse) {
             if ($idUtilisateurAdresse != $auth->getIdUtilisateur()) {
                 $infosUtilisateur = $utilisateur->getArrayInfosFromUtilisateur($idUtilisateurAdresse);
                 if ($infosUtilisateur['alerteCommentaires'] == '1' && $infosUtilisateur['compteActif'] == '1' && $infosUtilisateur['idProfil'] != '4') {
                     $message = "Un utilisateur a ajouté un commentaire sur une adresse ou vous avez participé.";
                     $message .= "Pour vous rendre sur l'adresse : <a href='" . $this->creerUrl('', '', array('archiAffichage' => 'adresseDetail', 'archiIdAdresse' => $idAdresse, 'archiIdEvenementGroupeAdresse' => $this->variablesPost['idEvenementGroupeAdresse'])) . '#commentaireAdresse' . $idCommentaire . "'>" . $intituleAdresse . "</a><br>";
                     $message .= $this->getMessageDesabonnerAlerteMail();
                     $mail->sendMail($mail->getSiteMail(), $infosUtilisateur['mail'], 'Ajout d\'un commentaire sur une adresse sur laquelle vous avez participé.', $message, true);
                 }
             }
         }
         // ************************************************************************************************************************************************
         // envoi d'un mail aux administrateur pour la moderation
         $message = "Merci d'avoir laissé un commentaire sur Archi-Strasbourg.<br>";
         $message .= "Afin qu'il soit publié, merci de le valider en cliquant sur ";
         $message .= "<a href='" . $this->getUrlRacine() . "script/validateEmail.php?uniqid=" . urlencode($uniqid) . "'>ce lien</a>.<br>";
         $message .= "<br/>Cordialement,</br>";
         $mail = new mailObject();
         $envoyeur['envoyeur'] = $mail->getSiteMail();
         $envoyeur['replyTo'] = strip_tags($this->variablesPost['email']);
         $u = new archiUtilisateur();
         if (!$CommentaireValide) {
             $mail->sendMail($envoyeur['envoyeur'], $this->variablesPost['email'], 'Votre commentaire sur Archi-Strasbourg', $message, true);
         } else {
             $message = "Un utilisateur a ajouté un commentaire sur archiV2 : <br>";
             $message .= "nom ou pseudo : " . strip_tags($this->variablesPost['nom']) . "<br>";
             $message .= "prenom : " . strip_tags($this->variablesPost['prenom']) . "<br>";
             $message .= "email : " . strip_tags($this->variablesPost['email']) . "<br>";
             $message .= "commentaire : " . stripslashes(strip_tags($this->variablesPost['commentaire'])) . "<br>";
             $message .= "<a href='" . $this->creerUrl('', '', array('archiAffichage' => 'adresseDetail', 'archiIdEvenementGroupeAdresse' => $this->variablesPost['idEvenementGroupeAdresse'], 'archiIdAdresse' => $idAdresse)) . '#commentaireAdresse' . $idCommentaire . "'>" . $intituleAdresse . "</a><br>";
             $mail->sendMailToAdministrators($envoyeur, 'Un utilisateur a ajouté un commentaire', $message, " AND alerteCommentaires='1' ", true, true);
             // envoi mail aussi au moderateur si ajout sur adresse de ville que celui ci modere
             $arrayVilles = array();
             $arrayVilles[] = $this->getIdVilleFrom($idAdresse, 'idAdresse');
             $arrayVilles = array_unique($arrayVilles);
             $arrayListeModerateurs = $u->getArrayIdModerateursActifsFromVille($arrayVilles[0], array("sqlWhere" => " AND alerteCommentaires='1' "));
             if (count($arrayListeModerateurs) > 0) {
                 foreach ($arrayListeModerateurs as $indice => $idModerateur) {
                     if ($auth->getIdUtilisateur() != $idModerateur) {
                         $mailModerateur = $u->getMailUtilisateur($idModerateur);
                         $mail->sendMail($mail->getSiteMail(), $mailModerateur, 'Un utilisateur a ajouté un commentaire', $message, true);
                     }
                 }
             }
         }
         // remise a zero des variables en post sinon on va reafficher les infos
         $_POST['commentaire'] = "";
         $_POST['email'] = "";
         $_POST['nom'] = "";
         $_POST['prenom'] = "";
         $this->variablesGet['archiIdEvenementGroupeAdresse'] = $this->variablesPost['idEvenementGroupeAdresse'];
         $idAdresse = $this->getIdAdresseFromIdEvenementGroupeAdresse($this->variablesGet['archiIdEvenementGroupeAdresse']);
         $this->messages->addConfirmation("Commentaire enregistré !");
         $this->messages->display();
         header("Location: " . $this->creerUrl('', '', array('archiAffichage' => 'adresseDetail', 'archiIdAdresse' => $idAdresse, 'archiIdEvenementGroupeAdresse' => $this->variablesGet['archiIdEvenementGroupeAdresse']), false, false) . '#commentaireAdresse' . $idCommentaire);
     } else {
         $this->messages->addError("Il y a une erreur dans le formulaire.");
         $this->messages->display();
         echo $this->getListeCommentaires($this->variablesPost['idEvenementGroupeAdresse']);
         echo $this->getFormulaireCommentaires($this->variablesPost['idEvenementGroupeAdresse'], $fieldsCommentaires);
     }
 }
 public function ajouter()
 {
     // ON LOCK LA TABLE historique image pour qu'il n'y ai pas d'ajout d'image qui se chevauche entre utilisateur
     $this->connexionBdd->getLock(array('historiqueImage'));
     $dateDuJour = date("Y-m-d");
     $listeIdNouvellesImages = array();
     // ce tableau contient la liste des idImages des nouvelles photos ajoutée,  ce tableau est simplement transmis au formulaire de modification qui s'affiche a la fin de l'ajout
     $rapportTransfert = array();
     // ce tableau contient le resultat du retour de la fonction de redimensionnement ,  ok ou pas
     // creation des repertoires datés
     if (!is_dir($this->getCheminPhysiqueImage("mini") . $dateDuJour)) {
         mkdir($this->getCheminPhysiqueImage("originaux") . $dateDuJour);
         chmod($this->getCheminPhysiqueImage("originaux") . $dateDuJour, 0777);
         mkdir($this->getCheminPhysiqueImage("mini") . $dateDuJour);
         chmod($this->getCheminPhysiqueImage("mini") . $dateDuJour, 0777);
         mkdir($this->getCheminPhysiqueImage("moyen") . $dateDuJour);
         chmod($this->getCheminPhysiqueImage("moyen") . $dateDuJour, 0777);
         mkdir($this->getCheminPhysiqueImage("grand") . $dateDuJour);
         chmod($this->getCheminPhysiqueImage("grand") . $dateDuJour, 0777);
     }
     // ************************************************************************************************************************************************************************************
     if (isset($this->variablesPost['typeAjout']) && $this->variablesPost['typeAjout'] == 'simple') {
         // *******************************************************************************************************************************************************************************
         if (isset($_FILES['fichier']['name']) && $_FILES['fichier']['error'] == UPLOAD_ERR_OK && isset($this->variablesPost['idCourant']) && isset($this->variablesPost['liaisonImage'])) {
             // on analyse le nom de fichier pour voir s'il y a une date a extraire et a inclure dans la base de données
             $dateCliche = "0000-00-00";
             $dateObj = new dateObject();
             $retourAnalyseNomFichier = $dateObj->extractDateFromString($_FILES['fichier']['name']);
             if ($retourAnalyseNomFichier['isDate']) {
                 $dateCliche = $retourAnalyseNomFichier["dateExtracted"];
             }
             // creation d'un nouvel id d'image
             // recuperation de l'id le plus haut
             $this->idImage = $nouveauIdImage = $this->getNewIdImage();
             $listeIdNouvellesImages[] = $nouveauIdImage;
             $authentifie = new archiAuthentification();
             if (extension_loaded('gd')) {
                 // nommage de l'image en fonction de l'id
                 // recuperation du type de fichier
                 // et conversion en jpg s'il le faut
                 // ajout d'un nouvel id dans l'historique image
                 $resAjout = $this->connexionBdd->requete('
                     insert into historiqueImage (idImage, dateUpload, dateCliche, idUtilisateur)
                     values ("' . $nouveauIdImage . '",  "' . $dateDuJour . '",  "' . $dateCliche . '",  "' . $authentifie->getIdUtilisateur() . '")
                     ');
                 $nouvelIdHistoriqueImage = mysql_insert_id();
                 $erreurRedimension = false;
                 // conversion en jpeg quelque soit le format géré
                 // 1- l'image est sauvegardee tel quel  (0 pour le redimensionnement)
                 if (!$this->redimension($_FILES['fichier']['tmp_name'], pia_substr(strtolower($_FILES['fichier']['name']), -3), $this->getCheminPhysiqueImage("originaux") . $dateDuJour . "/" . $nouvelIdHistoriqueImage . ".jpg", 0)) {
                     $erreurRedimension = true;
                 }
                 // 2- redimensionnement au format mini
                 if (!$this->redimension($_FILES['fichier']['tmp_name'], pia_substr(strtolower($_FILES['fichier']['name']), -3), $this->getCheminPhysiqueImage("mini") . $dateDuJour . "/" . $nouvelIdHistoriqueImage . ".jpg", $this->getFormatImageMini())) {
                     $erreurRedimension = true;
                 }
                 // 3- redimensionnement au format moyen
                 if (!$this->redimension($_FILES['fichier']['tmp_name'], pia_substr(strtolower($_FILES['fichier']['name']), -3), $this->getCheminPhysiqueImage("moyen") . $dateDuJour . "/" . $nouvelIdHistoriqueImage . ".jpg", $this->getFormatImageMoyen())) {
                     $erreurRedimension = true;
                 }
                 // 4- redimensionnement au format grand
                 if (!$this->redimension($_FILES['fichier']['tmp_name'], pia_substr(strtolower($_FILES['fichier']['name']), -3), $this->getCheminPhysiqueImage("grand") . $dateDuJour . "/" . $nouvelIdHistoriqueImage . ".jpg", $this->getFormatImageGrand())) {
                     $erreurRedimension = true;
                 }
                 unlink($_FILES['fichier']['tmp_name']);
                 $rapportTransfert[$nouveauIdImage] = array("erreurRedimension" => $erreurRedimension);
                 // ajout a la table _adresseImage
                 switch ($this->variablesPost['liaisonImage']) {
                     case 'adresse':
                         $resLiaison = $this->connexionBdd->requete('insert into _adresseImage (idImage, idAdresse, seSitue, prisDepuis, etage, hauteur) values ("' . $nouveauIdImage . '",  "' . $this->variablesPost['idCourant'] . '",  0,  0,  0,  0)');
                         break;
                     case 'evenement':
                         $resLiaison = $this->connexionBdd->requete('insert into _evenementImage (idImage, idEvenement) values ("' . $nouveauIdImage . '",  "' . $this->variablesPost['idCourant'] . '")');
                         break;
                     default:
                         // cas ou l'on upload simplement dans la bibliotheque des images sans préciser si l'image concerne un evenement ou une adresse
                         break;
                 }
             } else {
                 echo "Il s'est produit une erreur lors de l'upload,  la session est terminée ou la bibliothèque gd n'est pas installé sur le serveur.<br>";
             }
         } else {
             switch ($_FILES['fichier']['error']) {
                 case 0:
                     echo "Aucune erreur détectée";
                     break;
                 case 1:
                     echo "Erreur lors de l'upload : archiImage::ajouter() : Taille du fichier trop importante (php.ini)";
                     break;
                 case 2:
                     echo "Erreur lors de l'upload : archiImage::ajouter() : Taille du fichier trop importante (formulaire html)";
                     break;
                 case 3:
                     echo "Erreur lors de l'upload : archiImage::ajouter() : Téléchargement partiel.";
                     break;
                 case 4:
                     echo "Erreur lors de l'upload : archiImage::ajouter() : Aucun fichier n'a été téléchargé";
                     break;
                 case 6:
                     echo "Erreur lors de l'upload : archiImage::ajouter() : Un dossier temporaire est manquant";
                     break;
                 case 7:
                     echo "Erreur lors de l'upload : archiImage::ajouter() : Echec de l'écriture sur le disque";
                     break;
                 case 8:
                     echo "Erreur lors de l'upload : archiImage::ajouter() : Une extension PHP a annulé l'upload";
                     break;
                 default:
                     echo "Erreur lors de l'upload : archiImage::ajouter() ";
                     break;
             }
             echo "<br/>";
         }
         // *******************************************************************************************************************************************************************************
     } elseif (isset($this->variablesPost['typeAjout']) && $this->variablesPost['typeAjout'] == 'multi') {
         // *******************************************************************************************************************************************************************************
         // traitement des fichiers uploades par FTP
         if (isset($this->variablesPost['idCourant']) && isset($this->variablesPost['liaisonImage'])) {
             //echo "cheminUploadMultiple=".$this->variablesPost["cheminUploadMultiple"]."<br>";
             //echo "idCourant=".$this->variablesPost["idCourant"]."<br>";
             //echo "liaisonImage=".$this->variablesPost["liaisonImage"]."<br>";
             $repertoireUpload = $this->variablesPost["cheminUploadMultiple"];
             // conversion des noms de fichier en utf8 de tout le repertoire
             exec("convmv -f iso-8859-1 -t utf-8 -r " . $this->getCheminPhysique() . "/images/uploadMultiple/" . $repertoireUpload . "/* --notest", $retourExec);
             $authentifie = new archiAuthentification();
             $nbSuppression = 0;
             if ($directory = opendir($this->getCheminPhysique() . "/images/uploadMultiple/" . $repertoireUpload)) {
                 // parcours du repertoire
                 while ($fichier = readdir($directory)) {
                     if ($fichier != "." && $fichier != ".." && !is_dir($fichier)) {
                         // on analyse le nom de fichier pour voir s'il y a une date a extraire et a inclure dans la base de données
                         $dateCliche = "0000-00-00";
                         $dateObj = new dateObject();
                         $retourAnalyseNomFichier = $dateObj->extractDateFromString($fichier);
                         if ($retourAnalyseNomFichier['isDate']) {
                             $dateCliche = $retourAnalyseNomFichier["dateExtracted"];
                         }
                         // recuperation de l'id le plus haut ( on le fait a chaque fois pour etre sur de ne pas
                         $nouveauIdImage = $this->getNewIdImage();
                         // tableau transmis a la fonction de modifications pour savoir quelles ont ete les nouvelles images ajoutees
                         $listeIdNouvellesImages[] = $nouveauIdImage;
                         if (extension_loaded('gd')) {
                             $resAjout = $this->connexionBdd->requete('
                                 insert into historiqueImage (idImage, dateUpload, dateCliche, idUtilisateur,  idSource)
                                 values ("' . $nouveauIdImage . '",  "' . $dateDuJour . '",  "' . $dateCliche . '",  "' . $authentifie->getIdUtilisateur() . '",  0)
                                 ');
                             $nouvelIdHistoriqueImage = mysql_insert_id();
                             // on ajoute le chemin de l'image uploadee du repertoire uploadMultiple pour pouvoir regenerer les fichiers a partir de celle ci ,  au cas ou des images redimensionnees sont corrompues
                             // les images uploadees ne seront donc plus effacees
                             $reqAjoutImageUploadee = "\n                                    INSERT INTO imagesUploadeesPourRegeneration\n                                        (idImage, idHistoriqueImage, cheminImageUploadee)\n                                    VALUES ('" . $nouveauIdImage . "',  '" . $nouvelIdHistoriqueImage . "', \"" . $repertoireUpload . "/" . $fichier . "\") ";
                             $resAjoutImageUploadee = $this->connexionBdd->requete($reqAjoutImageUploadee);
                             //redimensionnement
                             //echo "debug ".$fichier." ==> ".pia_substr(strtolower($fichier),  -3)."<br>";
                             // originaux
                             $erreurRedimension = false;
                             if (!$this->redimension($this->getCheminPhysique() . "/images/uploadMultiple/" . $repertoireUpload . "/" . $fichier, pia_substr(strtolower($fichier), -3), $this->getCheminPhysiqueImage("originaux") . $dateDuJour . "/" . $nouvelIdHistoriqueImage . ".jpg", 0)) {
                                 $erreurRedimension = true;
                             }
                             //mini
                             if (!$this->redimension($this->getCheminPhysique() . "/images/uploadMultiple/" . $repertoireUpload . "/" . $fichier, pia_substr(strtolower($fichier), -3), $this->getCheminPhysiqueImage("mini") . $dateDuJour . "/" . $nouvelIdHistoriqueImage . ".jpg", $this->getFormatImageMini())) {
                                 $erreurRedimension = true;
                             }
                             //moyen
                             if (!$this->redimension($this->getCheminPhysique() . "/images/uploadMultiple/" . $repertoireUpload . "/" . $fichier, pia_substr(strtolower($fichier), -3), $this->getCheminPhysiqueImage("moyen") . $dateDuJour . "/" . $nouvelIdHistoriqueImage . ".jpg", $this->getFormatImageMoyen())) {
                                 $erreurRedimension = true;
                             }
                             //grand
                             if (!$this->redimension($this->getCheminPhysique() . "/images/uploadMultiple/" . $repertoireUpload . "/" . $fichier, pia_substr(strtolower($fichier), -3), $this->getCheminPhysiqueImage("grand") . $dateDuJour . "/" . $nouvelIdHistoriqueImage . ".jpg", $this->getFormatImageGrand())) {
                                 $erreurRedimension = true;
                             }
                             //unlink($this->getCheminPhysique()."/images/uploadMultiple/".$repertoireUpload."/".$fichier);
                             // suppression des fichiers du repertoire upload ,  suppression du repertoire
                             $nbSuppression++;
                             $rapportTransfert[$nouveauIdImage] = array("erreurRedimension" => $erreurRedimension);
                             // ajout a la table _adresseImage
                             switch ($this->variablesPost['liaisonImage']) {
                                 case 'adresse':
                                     $resLiaison = $this->connexionBdd->requete('insert into _adresseImage (idImage, idAdresse, description, seSitue, prisDepuis, etage, hauteur) values ("' . $nouveauIdImage . '",  "' . $this->variablesPost['idCourant'] . '",  "",  0,  0,  0,  0)');
                                     break;
                                 case 'evenement':
                                     $resLiaison = $this->connexionBdd->requete('insert into _evenementImage (idImage, idEvenement) values ("' . $nouveauIdImage . '",  "' . $this->variablesPost['idCourant'] . '")');
                                     break;
                                 default:
                                     break;
                             }
                         }
                     }
                 }
             }
             if ($nbSuppression > 0) {
                 // on supprime le repertoire (si des fichiers ont ete ajoutés)
                 //rmdir($this->getCheminPhysique()."/images/uploadMultiple/".$repertoireUpload);
             }
         }
     }
     //$this->afficherListe($id ,  $type)
     // on libere la table
     $this->connexionBdd->freeLock(array('historiqueImage'));
     // envoi du mail au administrateur
     $message = "De nouvelles images ont été uploadées : <br>";
     $intituleAdresse = "";
     switch ($this->variablesPost['liaisonImage']) {
         case 'evenement':
             $a = new archiAdresse();
             $reqAdresse = $a->getIdAdressesFromIdEvenement(array('idEvenement' => $this->variablesPost['idCourant']));
             $resAdresse = $this->connexionBdd->requete($reqAdresse);
             $fetchAdresse = mysql_fetch_assoc($resAdresse);
             // on prend la premiere adresse qui vient
             $intituleAdresse = $a->getIntituleAdresseFrom($fetchAdresse['idAdresse'], 'idAdresse');
             foreach ($listeIdNouvellesImages as $idImageNouvelle) {
                 $msgErreur = "";
                 if ($rapportTransfert[$idImageNouvelle]['erreurRedimension'] == true) {
                     $msgErreur = " ATTENTION : il y a eu un problème avec cette image (format incorrect) ";
                 }
                 $message .= "<a href='" . $this->creerUrl('', 'imageDetail', array('archiIdImage' => $idImageNouvelle, 'archiRetourAffichage' => 'evenement', 'archiRetourIdName' => 'idEvenement', 'archiRetourIdValue' => $this->getIdEvenementGroupeAdresseFromImage(array('idImage' => $idImageNouvelle)))) . "'>Image " . $idImageNouvelle . "</a>{$msgErreur}<br>";
             }
             $evenement = new archiEvenement();
             $idEvenementGroupeAdresse = $evenement->getIdEvenementGroupeAdresseFromIdEvenement($this->variablesPost['idCourant']);
             $message .= "<a href='" . $this->creerUrl('', '', array('archiAffichage' => 'adresseDetail', 'archiIdEvenementGroupeAdresse' => $idEvenementGroupeAdresse, 'archiIdAdresse' => $fetchAdresse['idAdresse'])) . "'>" . $intituleAdresse . "</a><br>";
             break;
         case 'adresse':
             $a = new archiAdresse();
             $intituleAdresse = $a->getIntituleAdresseFrom($this->variablesPost['idCourant'], 'idAdresse');
             foreach ($listeIdNouvellesImages as $idImageNouvelle) {
                 $msgErreur = "";
                 if ($rapportTransfert[$idImageNouvelle]['erreurRedimension'] == true) {
                     $msgErreur = " ATTENTION : il y a eu un problème avec cette image (format incorrect) ";
                 }
                 $message .= "<a href='" . $this->creerUrl('', 'imageDetail', array('archiIdImage' => $idImageNouvelle, 'archiRetourAffichage' => 'evenement', 'archiRetourIdName' => 'idEvenement', 'archiRetourIdValue' => $this->getIdEvenementGroupeAdresseFromImage(array('idImage' => $idImageNouvelle)))) . "'>Image " . $idImageNouvelle . "</a>{$msgErreur}<br>";
             }
             $arrayUrl = array();
             if (isset($idImageNouvelle)) {
                 $idEvenementGroupeAdresse = $this->getIdEvenementGroupeAdresseFromImage(array('idImage' => $idImageNouvelle));
                 $arrayUrl = array('archiIdEvenementGroupeAdresse' => $idEvenementGroupeAdresse);
             }
             $message .= "<a href='" . $this->creerUrl('', '', array_merge($arrayUrl, array('archiAffichage' => 'adresseDetail', 'archiIdAdresse' => $this->variablesPost['idCourant']))) . "'>" . $intituleAdresse . "</a><br>";
             break;
         default:
             $message .= "De nouvelle images ont été ajoutées à la bibliothèque :<br>";
             foreach ($listeIdNouvellesImages as $idImageNouvelle) {
                 $msgErreur = "";
                 if ($rapportTransfert[$idImageNouvelle]['erreurRedimension'] == true) {
                     $msgErreur = " ATTENTION : il y a eu un problème avec cette image (format incorrect) ";
                 }
                 $message .= "<a href='" . $this->creerUrl('', 'imageDetail', array('archiIdImage' => $idImageNouvelle, 'archiRetourAffichage' => 'evenement', 'archiRetourIdName' => 'idEvenement', 'archiRetourIdValue' => $this->getIdEvenementGroupeAdresseFromImage(array('idImage' => $idImageNouvelle)))) . "'>Image " . $idImageNouvelle . "</a>{$msgErreur}<br>";
             }
             break;
     }
     $mail = new mailObject();
     // recuperation des infos sur l'utilisateur qui fais la modif
     $utilisateur = new archiUtilisateur();
     $arrayInfosUtilisateur = $utilisateur->getArrayInfosFromUtilisateur($this->session->getFromSession('utilisateurConnecte' . $this->idSite));
     $message .= "<br>" . $arrayInfosUtilisateur['nom'] . " - " . $arrayInfosUtilisateur['prenom'] . " - " . $arrayInfosUtilisateur['mail'] . "<br>";
     $mail->sendMailToAdministrators($mail->getSiteMail(), 'Nouvelles images ajoutées - ' . $intituleAdresse, $message, " AND alerteAdresses = '1' ", true);
     $utilisateur->ajouteMailEnvoiRegroupesAdministrateurs(array('contenu' => $message, 'idTypeMailRegroupement' => 13, 'criteres' => " and alerteAdresses='1' "));
     // ************************************************************************************************************************************************
     // envoi d'un mail pour l'auteur de l'adresse
     // ************************************************************************************************************************************************
     $mail = new mailObject();
     $utilisateur = new archiUtilisateur();
     $auth = new archiAuthentification();
     $arrayUtilisateurs = $utilisateur->getCreatorsFromAdresseFrom($this->variablesPost['idCourant'], 'idEvenement');
     // a modifier quand on pourra ajouter des photos sur une adresse
     $adresse = new archiAdresse();
     $intituleAdresse = $adresse->getIntituleAdresseFrom($this->variablesPost['idCourant'], 'idEvenement');
     $evenement = new archiEvenement();
     foreach ($arrayUtilisateurs as $indice => $idUtilisateurAdresse) {
         if ($idUtilisateurAdresse != $auth->getIdUtilisateur()) {
             $infosUtilisateur = $utilisateur->getArrayInfosFromUtilisateur($idUtilisateurAdresse);
             if ($infosUtilisateur['alerteAdresses'] == '1' && $infosUtilisateur['compteActif'] == '1' && $infosUtilisateur['idProfil'] != '4') {
                 $messageIntro = "Un utilisateur a ajouté une ou plusieurs images sur une adresse dont vous êtes l'auteur.<br>";
                 $idEvenementGroupeAdresse = $evenement->getIdEvenementGroupeAdresseFromIdEvenement($this->variablesPost['idCourant']);
                 $adresse = new archiAdresse();
                 $reqAdresses = $adresse->getIdAdressesFromIdEvenement(array('idEvenement' => $this->variablesPost['idCourant']));
                 $resAdresses = $this->connexionBdd->requete($reqAdresses);
                 $fetchAdresses = mysql_fetch_assoc($resAdresses);
                 $message = "Pour vous rendre sur l'évènement : <a href='" . $this->creerUrl('', '', array('archiAffichage' => 'adresseDetail', 'archiIdAdresse' => $fetchAdresses['idAdresse'], 'archiIdEvenementGroupeAdresse' => $idEvenementGroupeAdresse)) . "'>" . $intituleAdresse . "</a><br>";
                 $messageFin = $this->getMessageDesabonnerAlerteMail();
                 if ($utilisateur->isMailEnvoiImmediat($idUtilisateurAdresse)) {
                     $mail->sendMail($mail->getSiteMail(), $infosUtilisateur['mail'], 'Ajout de photos sur une adresse dont vous êtes l\'auteur.', $messageIntro . $message . $messageFin, true);
                 } else {
                     $utilisateur->ajouteMailEnvoiRegroupes(array('contenu' => $message, 'idDestinataire' => $idUtilisateurAdresse, 'idTypeMailRegroupement' => 13));
                 }
             }
         }
     }
     // ************************************************************************************************************************************************
     // *************************************************************************************************************************************************************
     // envoi mail aussi au moderateur si ajout sur adresse de ville que celui ci modere
     $u = new archiUtilisateur();
     $arrayVilles = array();
     $arrayVilles[] = $adresse->getIdVilleFrom($this->variablesPost['idCourant'], 'idEvenement');
     $arrayVilles = array_unique($arrayVilles);
     $arrayListeModerateurs = $u->getArrayIdModerateursActifsFromVille($arrayVilles[0], array("sqlWhere" => " AND alerteAdresses='1' "));
     if (count($arrayListeModerateurs) > 0) {
         foreach ($arrayListeModerateurs as $indice => $idModerateur) {
             if ($idModerateur != $this->session->getFromSession('utilisateurConnecte' . $this->idSite)) {
                 if ($u->isMailEnvoiImmediat($idModerateur)) {
                     $mailModerateur = $u->getMailUtilisateur($idModerateur);
                     $mail->sendMail($mail->getSiteMail(), $mailModerateur, 'Nouvelles images ajoutées -' . $intituleAdresse, $message, true);
                 } else {
                     $u->ajouteMailEnvoiRegroupes(array('contenu' => $message, 'idDestinataire' => $idModerateur, 'idTypeMailRegroupement' => 13));
                 }
             }
         }
     }
     // *************************************************************************************************************************************************************
     // on appelle le formulaire permettant de mettre a jour les infos concernant les photos
     echo $this->afficherFormulaireModification(0, '', $listeIdNouvellesImages);
 }