From dba24b8c18aed84a71c3169b2df5598d62deab06 Mon Sep 17 00:00:00 2001 From: polo Date: Sun, 17 Aug 2025 19:46:20 +0200 Subject: =?UTF-8?q?classe=20FormValidation=20et=20am=C3=A9lioration=20des?= =?UTF-8?q?=20envois=20d'e-mail?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- src/controller/ContactFormController.php | 40 ++++++++++++++++++++++++++++++-- 1 file changed, 38 insertions(+), 2 deletions(-) (limited to 'src/controller/ContactFormController.php') diff --git a/src/controller/ContactFormController.php b/src/controller/ContactFormController.php index 9d62a77..dcea868 100644 --- a/src/controller/ContactFormController.php +++ b/src/controller/ContactFormController.php @@ -27,17 +27,53 @@ class ContactFormController } die; } + static public function sendVisitorEmail(EntityManager $entityManager, array $json): void + { + $form = new FormValidation($json, 'email'); + + $error = ''; + if($form->validate()){ + // destinataire = e-mail par défaut dans config.ini OU choisi par l'utilisateur + $form_data = $entityManager->find('App\Entity\NodeData', $json['id']); + if($form_data === null){ + http_response_code(500); + echo json_encode(['success' => false, 'error' => 'server_error']); + die; + } + $recipient = $form_data->getData()['email'] ?? Config::$email_dest; + + if(!EmailService::send($entityManager, $recipient, true, $form->getField('name'), $form->getField('email'), $form->getField('message'))){ + $error = 'email_not_sent'; + } + } + else{ + $error = $form->getErrors()[0]; // la 1ère erreur sera affichée + } + + if(empty($error)){ + echo json_encode(['success' => true]); + } + else{ + echo json_encode(['success' => false, 'error' => $error]); + } + die; + } static public function sendTestEmail(EntityManager $entityManager, array $json): void { // destinataire = e-mail par défaut dans config.ini OU choisi par l'utilisateur $form_data = $entityManager->find('App\Entity\NodeData', $json['id']); + if($form_data === null){ + http_response_code(500); + echo json_encode(['success' => false, 'error' => 'server_error']); + die; + } $recipient = $form_data->getData()['email'] ?? Config::$email_dest; - if(EmailController::send($recipient, false, 'nom du visiteur', 'adresse@du_visiteur.fr', "TEST d'un envoi d'e-mail depuis le site web")){ + if(EmailService::send($entityManager, $recipient, false, 'nom du visiteur', 'adresse@du_visiteur.fr', "TEST d'un envoi d'e-mail depuis le site web")){ echo json_encode(['success' => true]); } else{ - echo json_encode(['success' => false]); + echo json_encode(['success' => false, 'error' => 'email_not_sent']); } die; } -- cgit v1.2.3