101 lines
3.3 KiB
PHP
101 lines
3.3 KiB
PHP
<?php
|
|
date_default_timezone_set('Europe/Oslo');
|
|
setlocale(LC_ALL, 'nb_NO');
|
|
require __DIR__ . '/../../../src/_autoload.php';
|
|
require __DIR__ . '/../../../sql_config.php';
|
|
$pdo = new \PDO($dbDsn, $dbUser, $dbPass);
|
|
$pdo->setAttribute(PDO::ATTR_ERRMODE, PDO::ERRMODE_EXCEPTION);
|
|
$userManager = new \pvv\admin\UserManager($pdo);
|
|
|
|
require_once(__DIR__ . '/../../../vendor/simplesamlphp/simplesamlphp/lib/_autoload.php');
|
|
$as = new SimpleSAML_Auth_Simple('default-sp');
|
|
$as->requireAuth();
|
|
$attrs = $as->getAttributes();
|
|
$uname = $attrs['uid'][0];
|
|
|
|
if(!$userManager->hasGroup($uname, 'aktiviteter')){
|
|
echo 'Her har du ikke lov\'t\'å\'værra!!!';
|
|
exit();
|
|
}
|
|
|
|
if((!isset($_POST['title']))
|
|
or (!isset($_POST['desc']))
|
|
or (!isset($_POST['organiser']))
|
|
or (!isset($_POST['location']))
|
|
or (!isset($_POST['start_mon']))
|
|
or (!isset($_POST['start_day']))
|
|
or (!isset($_POST['start_time']))
|
|
or (!isset($_POST['lasts_hours']))
|
|
or (!isset($_POST['lasts_minutes']))) {
|
|
header('Location: ' . $_SERVER['HTTP_REFERER']);
|
|
exit();
|
|
}
|
|
|
|
$id = 0;
|
|
if(isset($_POST['id'])){
|
|
$id = $_POST['id'];
|
|
}
|
|
|
|
$title = $_POST['title'];
|
|
$desc = $_POST['desc'];
|
|
//$start = $_POST['start'];
|
|
//$stop = $_POST['end'];
|
|
$organiser = $_POST['organiser'];
|
|
$location = $_POST['location'];
|
|
|
|
$date_part_start_mon = $_POST['start_mon'];
|
|
$date_part_start_day = $_POST['start_day'];
|
|
$date_part_start_time = $_POST['start_time'];
|
|
$date_part_lasts_hours = $_POST['lasts_hours'];
|
|
$date_part_lasts_minutes = $_POST['lasts_minutes'];
|
|
|
|
if (strlen($date_part_start_day) < 2) {
|
|
$date_part_start_day = "0";
|
|
}
|
|
|
|
$start = ($date_part_start_mon . "-" . $date_part_start_day . " " . $date_part_start_time);
|
|
if (sizeof(explode(":", $date_part_start_time))==2) {
|
|
$start .= ":00";
|
|
}
|
|
|
|
$start_date = DateTimeImmutable::createFromFormat('Y-m-d H:i:s', $start);
|
|
$stop_date = $start_date->add(new DateInterval('PT' . $date_part_lasts_hours . 'H' . $date_part_lasts_minutes . 'M'));
|
|
$start = $start_date->format('Y-m-d H:i:s');
|
|
$stop = $stop_date->format('Y-m-d H:i:s');
|
|
|
|
if ($start_date >= $stop_date) {
|
|
echo 'Invalid dates. End date must come after the start date!';
|
|
exit();
|
|
}
|
|
|
|
$statement;
|
|
if($id == 0){
|
|
$query = 'INSERT INTO events (name, start, stop, organiser, location, description) VALUES (:title, :start, :stop, :organiser, :loc, :desc)';
|
|
$statement = $pdo->prepare($query);
|
|
|
|
$statement->bindParam(':title', $title, PDO::PARAM_STR);
|
|
$statement->bindParam(':desc', $desc, PDO::PARAM_STR);
|
|
$statement->bindParam(':start', $start, PDO::PARAM_STR);
|
|
$statement->bindParam(':stop', $stop, PDO::PARAM_STR);
|
|
$statement->bindParam(':organiser', $organiser, PDO::PARAM_STR);
|
|
$statement->bindParam(':loc', $location, PDO::PARAM_STR);
|
|
}else{
|
|
$query = 'UPDATE events SET name=:title, start=:start, stop=:stop, organiser=:organiser, location=:loc, description=:desc WHERE id=:id';
|
|
$statement = $pdo->prepare($query);
|
|
|
|
$statement->bindParam(':title', $title, PDO::PARAM_STR);
|
|
$statement->bindParam(':desc', $desc, PDO::PARAM_STR);
|
|
$statement->bindParam(':start', $start, PDO::PARAM_STR);
|
|
$statement->bindParam(':stop', $stop, PDO::PARAM_STR);
|
|
$statement->bindParam(':organiser', $organiser, PDO::PARAM_STR);
|
|
$statement->bindParam(':loc', $location, PDO::PARAM_STR);
|
|
$statement->bindParam(':id', $id, PDO::PARAM_INT);
|
|
}
|
|
|
|
$statement->execute();
|
|
|
|
header('Location: .');
|
|
?>
|
|
|
|
<a href=".?page=1">Om du ikke ble automatisk omdirigert tilbake klikk her</a>
|