summaryrefslogtreecommitdiff
path: root/public
diff options
context:
space:
mode:
authorDavid T. Sadler <davidtsadler@googlemail.com>2021-10-13 21:51:07 +0100
committerDavid T. Sadler <davidtsadler@googlemail.com>2021-10-13 21:51:07 +0100
commitcbaedbc5251f3b127bd81242d1344c0cd3e56e0c (patch)
treef76273742992d8f06983fd5d6fef37efc85a2c07 /public
parent2ab5661583d74b03c86bb4f437616bb634d9c4fc (diff)
Implemente redirects
Diffstat (limited to 'public')
-rw-r--r--public/add/index.php33
-rw-r--r--public/create/index.php23
-rw-r--r--public/delete/confirm/index.php31
-rw-r--r--public/delete/index.php20
-rw-r--r--public/edit/index.php16
-rw-r--r--public/store/index.php33
-rw-r--r--public/update/index.php35
7 files changed, 142 insertions, 49 deletions
diff --git a/public/add/index.php b/public/add/index.php
deleted file mode 100644
index 11ce9bb..0000000
--- a/public/add/index.php
+++ /dev/null
@@ -1,33 +0,0 @@
-<?php
-
-declare(strict_types=1);
-
-use DTS\Bookmark;
-use DTS\BookmarkRepository;
-use DTS\Template;
-use function DTS\Functions\respondAndExit;
-
-require_once(__DIR__.'/../../autoload.php');
-
-$config = require_once(__DIR__.'/../../config.php');
-
-$bookmarks = new BookmarkRepository($config['path_to_repository']);
-
-$template = new Template($config['path_to_templates']);
-
-if ('POST' === filter_input(INPUT_SERVER, 'REQUEST_METHOD')) {
- $bookmark = new Bookmark(
- bin2hex(random_bytes(32)),
- $_POST['url'],
- $_POST['title'],
- $_POST['tag'],
- date('Y-m-d H:i:s'),
- true,
- );
-
- $bookmarks->add($bookmark);
-}
-
-$html = $template->render('add');
-
-respondAndExit(200, 'OK', $html);
diff --git a/public/create/index.php b/public/create/index.php
new file mode 100644
index 0000000..00ce794
--- /dev/null
+++ b/public/create/index.php
@@ -0,0 +1,23 @@
+<?php
+
+declare(strict_types=1);
+
+use DTS\Bookmark;
+use DTS\Template;
+use function DTS\Functions\respondAndExit;
+
+require_once(__DIR__.'/../../autoload.php');
+
+$config = require_once(__DIR__.'/../../config.php');
+
+if (filter_input(INPUT_SERVER, 'REQUEST_METHOD') !== 'GET') {
+ respondAndExit(405, 'Method Not Allowed');
+}
+
+$template = new Template($config['path_to_templates']);
+
+$bookmark = new Bookmark();
+
+$html = $template->render('create', compact('bookmark'));
+
+respondAndExit(200, 'OK', $html);
diff --git a/public/delete/confirm/index.php b/public/delete/confirm/index.php
new file mode 100644
index 0000000..6636fe9
--- /dev/null
+++ b/public/delete/confirm/index.php
@@ -0,0 +1,31 @@
+<?php
+
+declare(strict_types=1);
+
+use DTS\BookmarkRepository;
+use DTS\Template;
+use function DTS\Functions\respondAndExit;
+
+require_once(__DIR__.'/../../../autoload.php');
+
+$config = require_once(__DIR__.'/../../../config.php');
+
+if (filter_input(INPUT_SERVER, 'REQUEST_METHOD') !== 'GET') {
+ respondAndExit(405, 'Method Not Allowed');
+}
+
+$id = filter_input(INPUT_GET, 'id');
+
+$bookmarks = new BookmarkRepository($config['path_to_repository']);
+
+$template = new Template($config['path_to_templates']);
+
+$bookmark = $bookmarks->find($id);
+
+if ($bookmark === null) {
+ respondAndExit(404, 'Not Found');
+}
+
+$html = $template->render('confirm_deletion', compact('bookmark'));
+
+respondAndExit(200, 'OK', $html);
diff --git a/public/delete/index.php b/public/delete/index.php
index 1b2484d..e07129a 100644
--- a/public/delete/index.php
+++ b/public/delete/index.php
@@ -3,25 +3,29 @@
declare(strict_types=1);
use DTS\BookmarkRepository;
-use DTS\Template;
use function DTS\Functions\respondAndExit;
+use function DTS\Functions\redirectAndExit;
require_once(__DIR__.'/../../autoload.php');
$config = require_once(__DIR__.'/../../config.php');
-$bookmarks = new BookmarkRepository($config['path_to_repository']);
+if (filter_input(INPUT_SERVER, 'REQUEST_METHOD') !== 'POST') {
+ respondAndExit(405, 'Method Not Allowed');
+}
-$template = new Template($config['path_to_templates']);
+$id = filter_input(INPUT_POST, 'id');
-$id = filter_input(INPUT_GET, 'id') ?? filter_input(INPUT_POST, 'id') ?? null;
+$bookmarks = new BookmarkRepository($config['path_to_repository']);
$bookmark = $bookmarks->find($id);
-if ('POST' === filter_input(INPUT_SERVER, 'REQUEST_METHOD')) {
- $bookmarks->delete($bookmark);
+if ($bookmark === null) {
+ respondAndExit(404, 'Not Found');
}
-$html = $template->render('delete', compact('bookmark'));
+if (!$bookmarks->delete($bookmark)) {
+ respondAndExit(500, 'Internal Server Error');
+}
-respondAndExit(200, 'OK', $html);
+redirectAndExit('/');
diff --git a/public/edit/index.php b/public/edit/index.php
index 65b3fa5..9d3d4c0 100644
--- a/public/edit/index.php
+++ b/public/edit/index.php
@@ -10,20 +10,20 @@ require_once(__DIR__.'/../../autoload.php');
$config = require_once(__DIR__.'/../../config.php');
+if (filter_input(INPUT_SERVER, 'REQUEST_METHOD') !== 'GET') {
+ respondAndExit(405, 'Method Not Allowed');
+}
+
+$id = filter_input(INPUT_GET, 'id');
+
$bookmarks = new BookmarkRepository($config['path_to_repository']);
$template = new Template($config['path_to_templates']);
-$id = filter_input(INPUT_GET, 'id') ?? filter_input(INPUT_POST, 'id') ?? null;
-
$bookmark = $bookmarks->find($id);
-if ('POST' === filter_input(INPUT_SERVER, 'REQUEST_METHOD')) {
- $bookmark->url = $_POST['url'];
- $bookmark->title = $_POST['title'];
- $bookmark->tag = $_POST['tag'];
-
- $bookmarks->update($bookmark);
+if ($bookmark === null) {
+ respondAndExit(404, 'Not Found');
}
$html = $template->render('edit', compact('bookmark'));
diff --git a/public/store/index.php b/public/store/index.php
new file mode 100644
index 0000000..2a84c59
--- /dev/null
+++ b/public/store/index.php
@@ -0,0 +1,33 @@
+<?php
+
+declare(strict_types=1);
+
+use DTS\Bookmark;
+use DTS\BookmarkRepository;
+use function DTS\Functions\respondAndExit;
+use function DTS\Functions\redirectAndExit;
+
+require_once(__DIR__.'/../../autoload.php');
+
+$config = require_once(__DIR__.'/../../config.php');
+
+if (filter_input(INPUT_SERVER, 'REQUEST_METHOD') !== 'POST') {
+ respondAndExit(405, 'Method Not Allowed');
+}
+
+$bookmarks = new BookmarkRepository($config['path_to_repository']);
+
+$bookmark = new Bookmark();
+
+$bookmark->id = bin2hex(random_bytes(32));
+$bookmark->url = $_POST['url'];
+$bookmark->title = $_POST['title'];
+$bookmark->tag = $_POST['tag'];
+$bookmark->addedAt = date('Y-m-d H:i:s');
+$bookmark->unread = true;
+
+if (!$bookmarks->add($bookmark)) {
+ respondAndExit(500, 'Internal Server Error');
+}
+
+redirectAndExit('/');
diff --git a/public/update/index.php b/public/update/index.php
new file mode 100644
index 0000000..fa6b482
--- /dev/null
+++ b/public/update/index.php
@@ -0,0 +1,35 @@
+<?php
+
+declare(strict_types=1);
+
+use DTS\BookmarkRepository;
+use function DTS\Functions\respondAndExit;
+use function DTS\Functions\redirectAndExit;
+
+require_once(__DIR__.'/../../autoload.php');
+
+$config = require_once(__DIR__.'/../../config.php');
+
+if (filter_input(INPUT_SERVER, 'REQUEST_METHOD') !== 'POST') {
+ respondAndExit(405, 'Method Not Allowed');
+}
+
+$id = filter_input(INPUT_POST, 'id');
+
+$bookmarks = new BookmarkRepository($config['path_to_repository']);
+
+$bookmark = $bookmarks->find($id);
+
+if ($bookmark === null) {
+ respondAndExit(404, 'Not Found');
+}
+
+$bookmark->url = $_POST['url'];
+$bookmark->title = $_POST['title'];
+$bookmark->tag = $_POST['tag'];
+
+if (!$bookmarks->update($bookmark)) {
+ respondAndExit(500, 'Internal Server Error');
+}
+
+redirectAndExit('/');