From 94e80ef9ebaa20a02488284a7705b8b123aa48f0 Mon Sep 17 00:00:00 2001 From: Ben Major Date: Fri, 3 Jan 2020 17:15:10 +0000 Subject: [PATCH] Add support for dynamic routes Replaces Slim route regex to regular PRCE so that `ignore` and `path` directives can be specified as dynamic route patterns. --- src/JwtAuthentication/RequestPathRule.php | 15 +++++++++++++-- 1 file changed, 13 insertions(+), 2 deletions(-) diff --git a/src/JwtAuthentication/RequestPathRule.php b/src/JwtAuthentication/RequestPathRule.php index a73ac99..bf8c475 100644 --- a/src/JwtAuthentication/RequestPathRule.php +++ b/src/JwtAuthentication/RequestPathRule.php @@ -59,11 +59,17 @@ public function __invoke(ServerRequestInterface $request): bool { $uri = "/" . $request->getUri()->getPath(); $uri = preg_replace("#/+#", "/", $uri); + /* If request path is matches ignore should not authenticate. */ foreach ((array)$this->options["ignore"] as $ignore) { $ignore = rtrim($ignore, "/"); - if (!!preg_match("@^{$ignore}(/.*)?$@", $uri)) { + + # Fix for dynamic routes: + $ignore = preg_replace('({(.*):(.*)})', '($2)', $ignore, -1); + $ignore = preg_replace('({(.*)})', '(.*)', $ignore, -1); + + if (!!preg_match("@^$ignore(/.*)?$@", $uri)) { return false; } } @@ -71,7 +77,12 @@ public function __invoke(ServerRequestInterface $request): bool /* Otherwise check if path matches and we should authenticate. */ foreach ((array)$this->options["path"] as $path) { $path = rtrim($path, "/"); - if (!!preg_match("@^{$path}(/.*)?$@", $uri)) { + + # Fix for dynamic routes: + $path = preg_replace('({(.*):(.*)})', '($2)', $path, -1); + $path = preg_replace('({(.*)})', '(.*)', $path, -1); + + if (!!preg_match("@^$path(/.*)?$@", $uri)) { return true; } }