getCode(); if ($exception instanceof ApiError) Response::apiError($exception->getMessage(), $code); else Response::response()->httpCode(is_int($code) ? $code : 500)->json(["message" => $exception->getMessage()]); }); // CORS SimpleRouter::options('/', function () { Response::response() ->header("Access-Control-Allow-Origin: *") ->header("Access-Control-Allow-Methods: *") ->header("Access-Control-Allow-Headers: *"); })->setMatch('/(.+)/is'); // Index SimpleRouter::all("/", function () { Response::redirect("docs", 301); }); /* * Open */ // Login SimpleRouter::post("/login", [Api\Login\Login::class, "post"]); // Register and confirm SimpleRouter::post("/register", [Api\Register\Register::class, "post"]); SimpleRouter::patch("/register", [Api\Register\Register::class, "patch"]); /* * Optional Auth */ SimpleRouter::group(["middleware" => Khofmann\Auth\OptAuth::class], function () { // List posts SimpleRouter::get("/posts", [Api\Posts\Posts::class, "get"]); }); /* * Normal Auth */ SimpleRouter::group(["middleware" => Khofmann\Auth\Auth::class], function () { // Logout SimpleRouter::post("/logout", [Api\Logout\Logout::class, "post"]); // Get user SimpleRouter::get("/user/{id}", [Api\User\User::class, "get"]); // Update self SimpleRouter::patch("/user/self", [Api\User\User::class, "patchSelf"]); // Update post SimpleRouter::patch("/post/{id}", [Api\Post\Post::class, "patch"]); // Create post SimpleRouter::post("/posts", [Api\Posts\Posts::class, "post"]); }); /* * Admin Auth */ SimpleRouter::group(["middleware" => Khofmann\Auth\AdminAuth::class], function () { // List users SimpleRouter::get("/users", [Api\Users\Users::class, "get"]); // Update user SimpleRouter::patch("/user/{id}", [Api\User\User::class, "patch"]); // Delete user SimpleRouter::delete("/user/{id}", [Api\User\User::class, "delete"]); // Delete post SimpleRouter::delete("/post/{id}", [Api\Post\Post::class, "delete"]); });