From ae61bee2726b93bb6cc2c152ff448760365f4e9d Mon Sep 17 00:00:00 2001 From: Skylear Date: Fri, 16 Jul 2021 12:51:23 -0500 Subject: [PATCH] =?UTF-8?q?=F0=9F=9A=A7=20Attempt=20to=20fix=20overlap=20b?= =?UTF-8?q?y=20making=20constraints=20route-specific?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- src/Splashsky/Router.php | 26 +++++++++++++++++--------- 1 file changed, 17 insertions(+), 9 deletions(-) diff --git a/src/Splashsky/Router.php b/src/Splashsky/Router.php index 5dc6139..46eaa3d 100644 --- a/src/Splashsky/Router.php +++ b/src/Splashsky/Router.php @@ -5,11 +5,11 @@ namespace Splashsky; class Router { private static array $routes = []; - private static array $constraints = []; private static $pathNotFound; private static $methodNotAllowed; private static string $defaultConstraint = '([\w\-]+)'; private static string $currentPrefix = ''; + private static string $lastInsertedRoute = ''; /** * A quick static function to register a route in the router. Used by the shorthand methods as well. @@ -26,12 +26,17 @@ class Router $route = self::$currentPrefix.$route; } - self::$routes[] = [ - 'route' => self::trimRoute($route), + $trimmed = self::trimRoute($route); + + self::$routes[$trimmed] = [ + 'route' => $trimmed, 'action' => $action, - 'methods' => $methods + 'methods' => $methods, + 'constraints' => [] ]; + self::$lastInsertedRoute = $trimmed; + return new self; } @@ -136,15 +141,17 @@ class Router */ public static function with(string|array $parameter, string $constraint = '') { + $last = self::$lastInsertedRoute; + if (is_array($parameter)) { foreach ($parameter as $param => $constraint) { - self::$constraints[$param] = $constraint; + self::$routes[$last]['constraints'][$param] = $constraint; } return new self; } - self::$constraints[$parameter] = $constraint; + self::$routes[$last]['constraints'][$parameter] = $constraint; return new self; } @@ -157,7 +164,8 @@ class Router */ private static function tokenize(string $uri) { - $constraints = array_keys(self::$constraints); + $constraints = self::$routes[$uri]['constraints']; + $constraintKeys = array_keys($constraints); preg_match_all('/(?:{([\w\-]+)})+/', $uri, $matches); $matches = $matches[1]; @@ -165,9 +173,9 @@ class Router foreach ($matches as $match) { $pattern = '{'.$match.'}'; - if (in_array($match, $constraints)) { + if (in_array($match, $constraintKeys)) { // Do some voodoo to allow users to use parentheses in their constraints if they want - $constraint = '('.rtrim(ltrim(trim(self::$constraints[$match]), '('), ')').')'; + $constraint = '('.rtrim(ltrim(trim($constraints[$match]), '('), ')').')'; $uri = str_replace($pattern, $constraint, $uri); } else {