- Added an event manager for Lean's route dispatching
This commit is contained in:
		
							parent
							
								
									f0082bf0a9
								
							
						
					
					
						commit
						8390506361
					
				| @ -1,17 +1,77 @@ | |||||||
| <?php | <?php | ||||||
| 
 | 
 | ||||||
|  | use Picea\Picea; | ||||||
| use function DI\autowire, DI\create, DI\get; | use function DI\autowire, DI\create, DI\get; | ||||||
| 
 | 
 | ||||||
| use Lean\Lean; | use Lean\{ Lean, Routing, Event\RoutingCompileRoutes, Event\RoutingMapRoutes }; | ||||||
| use Mcnd\Event; | use Mcnd\Event; | ||||||
|  | use Taxus\Taxus; | ||||||
|  | use Storage\Session; | ||||||
|  | use Notes\Route\Attribute\Method\Route; | ||||||
|  | use Notes\Security\SecurityHandler; | ||||||
|  | use Psr\Container\ContainerInterface; | ||||||
|  | use Psr\Http\Message\{ ResponseInterface, ServerRequestInterface }; | ||||||
| 
 | 
 | ||||||
| return [ | return [ | ||||||
|     Event\EventManager::class => autowire(Event\EventManager::class), |     Event\EventManager::class => autowire(Event\EventManager::class), | ||||||
| 
 | 
 | ||||||
|     Event\EventMiddleware::class => function($c) { |     Event\EventMiddleware::class => function($c) { | ||||||
|         $mw = new Event\EventMiddleware($c, $c->get(Event\EventManager::class)); |         $mw = new Event\EventMiddleware($c, $c->get(Event\EventManager::class)); | ||||||
|  |         $mw->fromAttributes($c->get(Notes\Event\EventFetcher::class)); | ||||||
|  |         $mw->fromDefinition($c->get(Event\EventDefinition::class)); | ||||||
| 
 | 
 | ||||||
|         return $mw->fromAttributes($c->get(Notes\Event\EventFetcher::class)); |         return $mw; | ||||||
|  |     }, | ||||||
|  | 
 | ||||||
|  |     Event\EventDefinition::class => function($c) { | ||||||
|  |         return new Event\EventDefinition([ | ||||||
|  |             new class() implements RoutingCompileRoutes { | ||||||
|  |                 public function execute(Routing $routing, Route|\Notes\Route\Annotation\Method\Route $attribute) : void | ||||||
|  |                 { | ||||||
|  |                     if (null !== ($name = $attribute->name ?? null)) { | ||||||
|  |                         $routing->extension->registerRoute($name, $attribute->getRoute(), $attribute->class, $attribute->classMethod, $attribute->methods ?? (array)$attribute->method); | ||||||
|  |                     } | ||||||
|  |                 } | ||||||
|  |             }, | ||||||
|  | 
 | ||||||
|  |             new class() implements RoutingMapRoutes { | ||||||
|  |                 public function execute(Routing $routing, ContainerInterface $container, ServerRequestInterface & $request, Route|\Notes\Route\Annotation\Method\Route $attribute) : void | ||||||
|  |                 { | ||||||
|  |                     $class = $attribute->class; | ||||||
|  |                     $method = $attribute->classMethod; | ||||||
|  | 
 | ||||||
|  |                     $request = $request->withAttribute('lean.route', $attribute); | ||||||
|  | 
 | ||||||
|  |                     # Checking if user needs to be logged
 | ||||||
|  |                     if ( $container->has(SecurityHandler::class) ){ | ||||||
|  |                         if ( $redirect = $container->get(SecurityHandler::class)->verify($class, $method) ) { | ||||||
|  |                             if ( empty($object->user) || ! $object->user->logged ) { | ||||||
|  |                                 $routing->session->set('redirectedFrom', (string) $request->getUri()); | ||||||
|  |                                 $routing->response = $redirect; | ||||||
|  | 
 | ||||||
|  |                                 return; | ||||||
|  |                             } | ||||||
|  |                         } | ||||||
|  | 
 | ||||||
|  |                         if ( $container->has(Taxus::class) ) { | ||||||
|  |                             if ( $forbidden = $container->get(SecurityHandler::class)->taxus($class, $method, $object->user ?? null) ) { | ||||||
|  |                                 $routing->response = $forbidden; | ||||||
|  | 
 | ||||||
|  |                                 return; | ||||||
|  |                             } | ||||||
|  |                         } | ||||||
|  |                     } | ||||||
|  | 
 | ||||||
|  |                     if ($container->has(Picea::class)) { | ||||||
|  |                         $container->get(Picea::class)->globalVariables['route'] = $attribute; | ||||||
|  |                     } | ||||||
|  | 
 | ||||||
|  |                     if ($container->has(Session::class)) { | ||||||
|  |                         $container->get(Session::class)->set("lean.route", $attribute); | ||||||
|  |                     } | ||||||
|  |                 } | ||||||
|  |             }, | ||||||
|  |         ]); | ||||||
|     }, |     }, | ||||||
| 
 | 
 | ||||||
|     Notes\Event\EventFetcher::class => function($c) { |     Notes\Event\EventFetcher::class => function($c) { | ||||||
|  | |||||||
							
								
								
									
										3
									
								
								skeleton/meta/definitions/env/prod.php
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										3
									
								
								skeleton/meta/definitions/env/prod.php
									
									
									
									
										vendored
									
									
								
							| @ -2,11 +2,8 @@ | |||||||
| 
 | 
 | ||||||
| use Picea\Picea; | use Picea\Picea; | ||||||
| 
 | 
 | ||||||
| #use CSLSJ\Debogueur\DebogueurMiddleware;
 |  | ||||||
| use Negundo\Client\{ NegundoMiddleware, SoftwareConfig }; | use Negundo\Client\{ NegundoMiddleware, SoftwareConfig }; | ||||||
| 
 | 
 | ||||||
| use |  | ||||||
| 
 |  | ||||||
| use Laminas\Diactoros\Response\HtmlResponse; | use Laminas\Diactoros\Response\HtmlResponse; | ||||||
| 
 | 
 | ||||||
| use Psr\Http\Server\MiddlewareInterface, | use Psr\Http\Server\MiddlewareInterface, | ||||||
|  | |||||||
| @ -29,8 +29,6 @@ new class(dirname(__DIR__)) extends \Lean\Kernel { | |||||||
| 
 | 
 | ||||||
|     protected function serviceContainer() : self |     protected function serviceContainer() : self | ||||||
|     { |     { | ||||||
|         # $this->container->get(ConnectionAdapter::class);
 |  | ||||||
| 
 |  | ||||||
|         return parent::serviceContainer(); |         return parent::serviceContainer(); | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|  | |||||||
							
								
								
									
										0
									
								
								skeleton/var/tmp/.gitkeep
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										0
									
								
								skeleton/var/tmp/.gitkeep
									
									
									
									
									
										Normal file
									
								
							| @ -92,7 +92,7 @@ trait ControllerTrait { | |||||||
|         return new HtmlResponse($html, $code, $headers); |         return new HtmlResponse($html, $code, $headers); | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     public static function renderJson(/*\JsonSerializable|array*/ $data, int $code = 200, array $headers = []) : ResponseInterface |     public static function renderJson(mixed $data, int $code = 200, array $headers = []) : ResponseInterface | ||||||
|     { |     { | ||||||
|         return new JsonResponse($data, $code, $headers); |         return new JsonResponse($data, $code, $headers); | ||||||
|     } |     } | ||||||
|  | |||||||
							
								
								
									
										10
									
								
								src/Event/RoutingCompileRoutes.php
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										10
									
								
								src/Event/RoutingCompileRoutes.php
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,10 @@ | |||||||
|  | <?php | ||||||
|  | 
 | ||||||
|  | namespace Lean\Event; | ||||||
|  | 
 | ||||||
|  | use Lean\Routing; | ||||||
|  | use Notes\Route\Attribute\Method\Route; | ||||||
|  | 
 | ||||||
|  | interface RoutingCompileRoutes { | ||||||
|  |     public function execute(Routing $routing, Route|\Notes\Route\Annotation\Method\Route $attribute) : void; | ||||||
|  | } | ||||||
							
								
								
									
										12
									
								
								src/Event/RoutingMapRoutes.php
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										12
									
								
								src/Event/RoutingMapRoutes.php
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,12 @@ | |||||||
|  | <?php | ||||||
|  | 
 | ||||||
|  | namespace Lean\Event; | ||||||
|  | 
 | ||||||
|  | use Lean\Routing; | ||||||
|  | use Notes\Route\Attribute\Method\Route; | ||||||
|  | use Psr\Container\ContainerInterface; | ||||||
|  | use Psr\Http\Message\{ ResponseInterface, ServerRequestInterface }; | ||||||
|  | 
 | ||||||
|  | interface RoutingMapRoutes { | ||||||
|  |     public function execute(Routing $routing, ContainerInterface $container, ServerRequestInterface & $request, Route|\Notes\Route\Annotation\Method\Route $attribute) : void; | ||||||
|  | } | ||||||
| @ -24,58 +24,34 @@ use Picea\Picea, | |||||||
| use Storage\Cookie, | use Storage\Cookie, | ||||||
|     Storage\Session; |     Storage\Session; | ||||||
| 
 | 
 | ||||||
|  | use Mcnd\Event\EventManager; | ||||||
|  | 
 | ||||||
| use function DI\autowire, DI\create; | use function DI\autowire, DI\create; | ||||||
| 
 | 
 | ||||||
| class Routing { | class Routing { | ||||||
| 
 | 
 | ||||||
|     public Annotation $selectedRoute; |     public Annotation $selectedRoute; | ||||||
| 
 | 
 | ||||||
|     protected Session $session; |     public ResponseInterface $response; | ||||||
| 
 |  | ||||||
|     protected Cookie $cookie; |  | ||||||
| 
 |  | ||||||
|     protected UrlExtension $extension; |  | ||||||
| 
 |  | ||||||
|     protected RouteFetcher $fetcher; |  | ||||||
| 
 |  | ||||||
|     protected SecurityHandler $security; |  | ||||||
| 
 |  | ||||||
|     protected LanguageHandler $language; |  | ||||||
| 
 |  | ||||||
|     protected Taxus $taxus; |  | ||||||
| 
 |  | ||||||
|     protected Router $router; |  | ||||||
| 
 | 
 | ||||||
|     public function __construct( |     public function __construct( | ||||||
|         Session $session, |         public Session $session, | ||||||
|         Cookie $cookie, |         public Cookie $cookie, | ||||||
|         UrlExtension $extension, |         public UrlExtension $extension, | ||||||
|         Router $router, |         public Router $router, | ||||||
|         RouteFetcher $routeFetcher, |         public RouteFetcher $fetcher, | ||||||
|         SecurityHandler $security, |         public SecurityHandler $security, | ||||||
|         LanguageHandler $language, |         public LanguageHandler $language, | ||||||
|         Taxus $taxus |         public Taxus $taxus, | ||||||
|     ) |         public EventManager $eventManager, | ||||||
|     { |     ) { } | ||||||
|         $this->session = $session; |  | ||||||
|         $this->cookie = $cookie; |  | ||||||
|         $this->extension = $extension; |  | ||||||
|         $this->fetcher = $routeFetcher; |  | ||||||
|         $this->security = $security; |  | ||||||
|         $this->language = $language; |  | ||||||
|         $this->router = $router; |  | ||||||
|         $this->taxus = $taxus; |  | ||||||
|     }  |  | ||||||
| 
 | 
 | ||||||
|     public function registerRoute(ContainerInterface $container, string $urlBase) { |     public function registerRoute(ContainerInterface $container, string $urlBase) { | ||||||
|         $this->router->group(rtrim($urlBase, "/"), function (RouteGroup $route) use ($container) { |         $this->router->group(rtrim($urlBase, "/"), function (RouteGroup $route) use ($container) { | ||||||
| 
 |  | ||||||
|             foreach($this->fetcher->compile() as $annotation) { |             foreach($this->fetcher->compile() as $annotation) { | ||||||
|                 # Register routes to the UrlExtension from picea (handling url, route and asset extensions)
 |                 $this->eventManager->execute(Event\RoutingCompileRoutes::class, $this, $annotation); | ||||||
|                 if ( null !== ( $name = $annotation->name ?? null ) ) { |  | ||||||
|                     $this->extension->registerRoute($name, $annotation->getRoute(), $annotation->class, $annotation->classMethod, $annotation->methods ?? (array) $annotation->method); |  | ||||||
|                 } |  | ||||||
| 
 | 
 | ||||||
|  |                 /* @deprecated annotation->method will become standard when using native attributes */ | ||||||
|                 foreach((array) ( $annotation->method ?? $annotation->methods ) as $method) { |                 foreach((array) ( $annotation->method ?? $annotation->methods ) as $method) { | ||||||
|                     # Mapping every URLs from annotations in searched folders (Api, Controller, etc...)
 |                     # Mapping every URLs from annotations in searched folders (Api, Controller, etc...)
 | ||||||
|                     $route->map(strtoupper($method), $annotation->getRoute(), function (ServerRequestInterface $request, array $arguments) use ( |                     $route->map(strtoupper($method), $annotation->getRoute(), function (ServerRequestInterface $request, array $arguments) use ( | ||||||
| @ -84,34 +60,13 @@ class Routing { | |||||||
|                     { |                     { | ||||||
|                         $class = $annotation->class;     |                         $class = $annotation->class;     | ||||||
|                         $method = $annotation->classMethod; |                         $method = $annotation->classMethod; | ||||||
| 
 |  | ||||||
|                         # $container->set($class, autowire($class)->method($method, $request));
 |  | ||||||
| 
 |  | ||||||
|                         $object = $container->get($class); |                         $object = $container->get($class); | ||||||
| 
 | 
 | ||||||
|                         # Checking if user needs to be logged
 |                         $this->eventManager->execute(Event\RoutingMapRoutes::class, $this, $container, $request, $annotation); | ||||||
|                         if ( ( $redirect = $this->security->verify($class, $method) ) && ( empty($object->user) || ! $object->user->logged ) ) { |  | ||||||
|                             $this->session->redirectedFrom = (string) $request->getUri(); |  | ||||||
| 
 |  | ||||||
|                             return $redirect; |  | ||||||
|                         } |  | ||||||
| 
 |  | ||||||
|                         if ( $forbidden = $this->security->taxus($class, $method, $object->user ?? null) ) { |  | ||||||
|                             return $forbidden; |  | ||||||
|                         } |  | ||||||
| 
 |  | ||||||
|                         # @TODO of course, this as to go ; moving to a simple callback method soon which can then be fed by Picea
 |  | ||||||
|                         if ( $container->has(Picea::class) ) { |  | ||||||
|                             $container->get(Picea::class)->globalVariables['route'] = $annotation; |  | ||||||
|                         } |  | ||||||
| 
 |  | ||||||
|                         $request = $request->withAttribute('lean.route', $annotation); |  | ||||||
| 
 |  | ||||||
|                         $this->session->set("lean.route", $annotation); |  | ||||||
| 
 | 
 | ||||||
|                         $container->set(ServerRequestInterface::class, $request); |                         $container->set(ServerRequestInterface::class, $request); | ||||||
| 
 | 
 | ||||||
|                         return $object->$method($request, $arguments); |                         return $this->response ?? $object->$method($request, $arguments); | ||||||
|                     }); |                     }); | ||||||
|                 } |                 } | ||||||
|             } |             } | ||||||
|  | |||||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user