From ed1f744e1cf0045540c2e6349cc7dcc5031c8652 Mon Sep 17 00:00:00 2001
From: filippo.bertilotti <filippobertilotti@gmail.com>
Date: Tue, 14 May 2024 11:38:23 +0200
Subject: [PATCH]  (parte 86)

---
 src/Framework/Dispatcher.php |   27 +++++++++++++++++++++++++--
 1 files changed, 25 insertions(+), 2 deletions(-)

diff --git a/src/Framework/Dispatcher.php b/src/Framework/Dispatcher.php
index 88d7791..351366c 100644
--- a/src/Framework/Dispatcher.php
+++ b/src/Framework/Dispatcher.php
@@ -3,6 +3,7 @@
 namespace Framework;
 
 use ReflectionMethod;
+use ReflectionClass;
 
 class Dispatcher {
     public function __construct(private Router $router) { }
@@ -18,9 +19,8 @@
         $action = $params["action"];
 
         $controller = $this->getControllerName($params);
-        exit($controller);
 
-        $controller_object = new $controller;
+        $controller_object = $this->getObject($controller);
 
         $args = $this->getActionArguments($controller, $action, $params);
 
@@ -43,7 +43,30 @@
         $controller = $params["controller"];
         $controller = str_replace("-", "", ucwords(strtolower($controller), "-"));
         $namespace = "App\Controllers";
+
+        if(array_key_exists("namespace", $params)) {
+            $namespace .= "\\" . $params["namespace"];
+        }
+
         return $namespace . "\\" . $controller;
 
     }
+
+    private function getObject(string $class_name):object {
+        $reflector = new ReflectionClass($class_name);
+        $contructor = $reflector->getConstructor();
+
+        $dependencies = [];
+        
+        if($contructor === null) {
+            return new $class_name();
+        }
+
+        foreach($contructor->getParameters() as $param) {
+            $type = (string) $param->getType();
+            $dependencies[] = $this->getObject($type);
+        }
+        
+        return new $class_name(...$dependencies);
+    }
 }
\ No newline at end of file

--
Gitblit v1.8.0