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