page: indicate repost status in http redirects
[minimedit.git] / login / index.php
index 4ecee456f8d77f52dcdbb8c751521cfa875d3377..85dc2f54a3cd893d5a55e9b30318eb377753b09f 100644 (file)
@@ -1,4 +1,5 @@
 <?php
+if ($Page->api) return;
 $message = NULL;
 
 if (isset($_POST['mail'])) {
@@ -41,35 +42,24 @@ if (!$User or !$User->login) {
                if (empty($message)) http_response_code(403);
                $target = ltrim($_REQUEST['goto'], '/');
                $target = new ArchiveArticle("$target.html");
-
-               if ($target and $target->handler == 'melding') {
-                       $caller = $Page;
-                       $Page = $target;
-                       ob_start();
-                       include "./{$target->handler}/index.php";
-                       ob_end_clean();
-                       $Page = $caller;
-               }
+               $target->index; # run forbidden handler to determine metadata
 
                if ($target->title) {
                        $Page->title .= ' voor ' . $target->title;
                }
-               if ($target->image) {
-                       $Page->image = $target->image;
-               }
+               $Page->image = $target->image;
+               $Page->teaser = $target->teaser;
        }
        ob_start();
        require_once 'login/form.inc.php';
        $Page->raw = ob_get_clean();
-       $Place['warn'] = $message;
+       $Page->place['warn'] = $message;
        return TRUE;
 }
 
 if (isset($_REQUEST['goto'])) {
        $target = ltrim($_REQUEST['goto'], '/');
-       header("Location: /$target");
-       http_response_code(302);
-       exit;
+       abort("/$target", '303 Return');
 }
 
 if (isset($Page->raw)) {