From 61ad98a6e2914578cae32f249d2b496892c0f10b Mon Sep 17 00:00:00 2001 From: filippo.bertilotti <filippobertilotti@gmail.com> Date: Mon, 27 May 2024 10:44:00 +0200 Subject: [PATCH] aggiunto controllo sul metodo post in modo da non poter raggiungere la route destroy utilizzando il get (parte 144) --- src/Framework/Dispatcher.php | 27 ++++++++++++++++++++++----- 1 files changed, 22 insertions(+), 5 deletions(-) diff --git a/src/Framework/Dispatcher.php b/src/Framework/Dispatcher.php index 486b3b0..c1a07dd 100644 --- a/src/Framework/Dispatcher.php +++ b/src/Framework/Dispatcher.php @@ -2,22 +2,26 @@ namespace Framework; +use Framework\Exceptions\PageNotFoundException; use ReflectionMethod; class Dispatcher { - public function __construct(private Router $router) { } + public function __construct(private Router $router, + private Container $container) { } - public function handle(string $path) { - $params = $this->router->match($path); + public function handle(string $path, $method) { + $params = $this->router->match($path, $method); if($params === false) { - exit("No routes matched"); + throw new PageNotFoundException("No route matched for '$path' with method '$method'"); } $controller = "App\Controllers\\" . ucwords($params["controller"]); $action = $params["action"]; - $controller_object = new $controller; + $controller = $this->getControllerName($params); + + $controller_object = $this->container->get($controller); $args = $this->getActionArguments($controller, $action, $params); @@ -35,4 +39,17 @@ return($args); } + + private function getControllerName(array $params): string { + $controller = $params["controller"]; + $controller = str_replace("-", "", ucwords(strtolower($controller), "-")); + $namespace = "App\Controllers"; + + if(array_key_exists("namespace", $params)) { + $namespace .= "\\" . $params["namespace"]; + } + + return $namespace . "\\" . $controller; + + } } \ No newline at end of file -- Gitblit v1.8.0