1
0
Fork 0
This repository has been archived on 2024-02-17. You can view files and clone it, but cannot push or open issues or pull requests.
Accommodation_Management/controller/accomodation.php
2021-01-14 19:01:32 +01:00

98 lines
No EOL
4.8 KiB
PHP

<?php
if ($_SESSION['USER']->isLoggedIn() && $_SESSION['USER']->getType() == 'AccomodationOwner') {
$accomodationType = ['Hôtel', 'Gîte', 'Camping', 'Villa en location'];
$alert = '';
$availableServices = AccomodationServices::getAll();
$re_name = '/^[a-zA-Z -\'?*éàèôê0-9"()+&]{1,}$/';
$re_cp = '/[0-9]{5}/';
if (isset($path[1])) {
switch ($path[1]) {
case 'add':
if (!$_SESSION['USER']->getAccomodationId() && $_SESSION['USER']->getType() == 'AccomodationOwner') {
/*
* Creating Accomodation
*/
if (isset(
$_POST['accomodationName'],
$_POST['postalCode'],
$_POST['address'],
$_POST['accomodationType']
)) {
/*
* Checking inputs
*/
if (!preg_match($re_name, $_POST['accomodationName']) || !preg_match($re_cp, $_POST['postalCode']) || ((isset($_POST["accomodationService"]) && gettype($_POST['accomodationService']) === 'array' && array_diff($_POST["accomodationService"], $availableServices)))) {
$alert = alert('danger', 'Le formulaire est invalide');
} else {
if (Accomodation::insertUser($_SESSION['USER'], array(
"name" => $_POST['accomodationName'],
"address" => $_POST['address'],
"postalCode" => $_POST['postalCode'],
"type" => $_POST['accomodationType'])) != false) {
/*
* Update users information
*/
$_SESSION['USER']->refresh();
/*
* Insert ok
*/
$accomodation = Accomodation::fetchByUser($_SESSION['USER']);
$accomodation->setServices($_POST["accomodationService"]);
$alert = alert('success', 'Ajout du logement réussi.');
} else {
$alert = alert('danger', 'Erreur lors de l\'insertion du logement.');
}
}
}
$services = AccomodationServices::fetch();
require_once(VIEW_PATH . $path[1] . '_' . $path[0] . '.php');
} else {
redirect();
}
break;
case 'edit':
if ($_SESSION['USER']->getAccomodationId()) {
$accomodation = Accomodation::fetchByUser($_SESSION['USER']);
if (isset(
$_POST['accomodationName'],
$_POST['postalCode'],
$_POST['address'],
$_POST['accomodationType']
)) {
if (!preg_match($re_name, $_POST['accomodationName']) || !preg_match($re_cp, $_POST['postalCode']) || ((isset($_POST["accomodationService"]) && gettype($_POST['accomodationService']) === 'array' && array_diff($_POST["accomodationService"], $availableServices)))) {
$alert = alert('danger', 'Le formulaire est invalide');
} else {
Accomodation::update(array(
"name" => $_POST['accomodationName'],
"address" => $_POST['address'],
"postalCode" => $_POST['postalCode'],
"type" => $_POST['accomodationType']), array(['id','=',$accomodation->getId()]));
$accomodation = Accomodation::fetchByUser($_SESSION['USER']);
$accomodation->setServices($_POST["accomodationService"]);
$alert = alert('success', 'Le logement a été modifié.');
}
$accomodation->setServices($_POST["accomodationService"]);
}
$services = AccomodationServices::fetch();
require_once(VIEW_PATH . $path[1] . '_' . $path[0] . '.php');
} else {
redirect();
}
break;
case 'date':
require_once(VIEW_PATH . $path[1] . '_' . $path[0] . '.php');
break;
default:
redirect();
}
} else {
redirect();
}
} else {
redirect('login');
}