0
0
mirror of https://github.com/anthonyaxenov/iptv.git synced 2024-11-21 13:04:43 +00:00

Вынес роуты в отдельный файл

This commit is contained in:
Anthony Axenov 2024-09-15 18:00:02 +08:00
parent 8483dc586e
commit f0cfe4eda7
Signed by: anthony
GPG Key ID: EA9EC32FF7CCD4EC
3 changed files with 24 additions and 48 deletions

View File

@ -5,12 +5,9 @@ declare(strict_types=1);
namespace App\Core; namespace App\Core;
use App\Controllers\AjaxController; use App\Controllers\AjaxController;
use App\Controllers\HomeController;
use App\Controllers\PlaylistController;
use App\Extensions\TwigFunctions; use App\Extensions\TwigFunctions;
use Flight; use Flight;
use Illuminate\Support\Arr; use Illuminate\Support\Arr;
use Symfony\Component\Dotenv\Dotenv;
use Twig\Environment; use Twig\Environment;
use Twig\Extension\DebugExtension; use Twig\Extension\DebugExtension;
use Twig\Loader\FilesystemLoader; use Twig\Loader\FilesystemLoader;
@ -20,16 +17,6 @@ use Twig\Loader\FilesystemLoader;
*/ */
final class Bootstrapper final class Bootstrapper
{ {
/**
* Загружает env-переменные
*
* @return void
*/
public static function bootEnv(): void
{
(new Dotenv())->loadEnv(root_path() . '/.env');
}
/** /**
* Загружает конфигурацию приложения в контейнер * Загружает конфигурацию приложения в контейнер
* *
@ -45,7 +32,7 @@ final class Bootstrapper
} }
/** /**
* Загружает шаблонизатор и его расщирения * Загружает шаблонизатор и его расширения
* *
* @return void * @return void
*/ */
@ -72,33 +59,9 @@ final class Bootstrapper
*/ */
public static function bootRoutes(): void public static function bootRoutes(): void
{ {
Flight::route( $routes = require_once config_path('routes.php');
'GET /', foreach ($routes as $route => $handler) {
fn() => (new HomeController())->index() Flight::route($route, $handler);
); }
Flight::route(
'GET /page/@page:[0-9]+',
fn($page) => (new HomeController())->index((int)$page)
);
Flight::route(
'GET /faq',
fn() => (new HomeController())->faq()
);
Flight::route(
'GET /@id:[a-zA-Z0-9_-]+',
fn($id) => (new PlaylistController())->download($id)
);
Flight::route(
'GET /?[a-zA-Z0-9_-]+',
fn($id) => (new PlaylistController())->download($id)
);
Flight::route(
'GET /@id:[a-zA-Z0-9_-]+/details',
fn($id) => (new PlaylistController())->details($id)
);
Flight::route(
'GET /@id:[a-zA-Z0-9_-]+/json',
fn($id) => (new PlaylistController())->json($id)
);
} }
} }

16
src/config/routes.php Normal file
View File

@ -0,0 +1,16 @@
<?php
declare(strict_types=1);
use App\Controllers\HomeController;
use App\Controllers\PlaylistController;
return [
'GET /' => (new HomeController())->index(...),
'GET /page/@page:[0-9]+' => (new HomeController())->index(...),
'GET /faq' => (new HomeController())->faq(...),
'GET /@id:[a-zA-Z0-9_-]+' => (new PlaylistController())->download(...),
'GET /?[a-zA-Z0-9_-]+' => (new PlaylistController())->download(...),
'GET /@id:[a-zA-Z0-9_-]+/details' => (new PlaylistController())->details(...),
'GET /@id:[a-zA-Z0-9_-]+/json' => (new PlaylistController())->json(...),
];

View File

@ -3,6 +3,7 @@
declare(strict_types=1); declare(strict_types=1);
use App\Core\Bootstrapper; use App\Core\Bootstrapper;
use Symfony\Component\Dotenv\Dotenv;
/* /*
|-------------------------------------------------------------------------- |--------------------------------------------------------------------------
@ -14,7 +15,7 @@ use App\Core\Bootstrapper;
require '../vendor/autoload.php'; require '../vendor/autoload.php';
// load .env parameters // load .env parameters
Bootstrapper::bootEnv(); (new Dotenv())->loadEnv(root_path() . '/.env');
// set up framework according to its config // set up framework according to its config
Bootstrapper::bootSettings(); Bootstrapper::bootSettings();
@ -25,9 +26,5 @@ Bootstrapper::bootTwig();
// set up routes defined in config file // set up routes defined in config file
Bootstrapper::bootRoutes(); Bootstrapper::bootRoutes();
/* // start application
|--------------------------------------------------------------------------
| Start application
|--------------------------------------------------------------------------
*/
Flight::start(); Flight::start();