diff options
Diffstat (limited to 'app/controllers/contact.controller.php')
-rw-r--r-- | app/controllers/contact.controller.php | 47 |
1 files changed, 47 insertions, 0 deletions
diff --git a/app/controllers/contact.controller.php b/app/controllers/contact.controller.php index 60f5f08..803a67c 100644 --- a/app/controllers/contact.controller.php +++ b/app/controllers/contact.controller.php @@ -1,3 +1,50 @@ <?php +if ($_SERVER['REQUEST_METHOD'] === 'POST') { + + $form = new Form(); + + $form->name = $name = $_POST['26471'] ?? null; + $form->email = $email = $_POST['26472'] ?? null; + $form->message = $message = $_POST['26478'] ?? null; + $form->spam = $spam = $_POST['agree'] ?? false; + + if ($form->isEmpty()) { + include '../app/views/contact.view.php'; + return; + } + + if ($form->isSpam()) { + error_log('Contact Form Spam: Error 403'); + return http_response_code(403); + } + + if ($form->isEmailValid() === false) { + $emailError = 'Invalid email: ' . "\r" . '<b>'. $email . '</b>'; + include '../app/views/contact.view.php'; + return; + } + + $formSuccess = true; + + $name = null; + $email = null; + $message = null; + $spam = false; + + include '../app/views/contact.view.php'; + fastcgi_finish_request(); + + $contact['database']->insert( + 'contactform', [ + 'name' => $form->name, + 'email' => $form->email, + 'message' => $form->message, + ] + ); + + $form->isSubmit(); + return; +} + require '../app/views/contact.view.php'; |