Skip to content

Commit

Permalink
fix: match should return Route class instance
Browse files Browse the repository at this point in the history
  • Loading branch information
papac committed Dec 13, 2024
1 parent 10efe0a commit cce9076
Show file tree
Hide file tree
Showing 9 changed files with 91 additions and 94 deletions.
4 changes: 2 additions & 2 deletions .github/workflows/tests.yml
Original file line number Diff line number Diff line change
Expand Up @@ -41,7 +41,7 @@ jobs:
extensions: dom, curl, libxml, mbstring, zip, pcntl, pdo, mysql, sqlite, pdo_sqlite, bcmath, soap, intl, gd, exif, iconv, imagick, redis
coverage: none

- run: docker run --net=host -p 21:21 -e FTP_USER=$FTP_USER -e FTP_PASS=$FTP_PASSWORD -e PASV_ADDRESS=127.0.0.1 -e PASV_MIN_PORT=21100 -e PASV_MAX_PORT=21110 -d --name ftp -v $(pwd)/:/ftp/$FTP_USER --restart=always fauria/vsftpd
- run: docker run --net=host -p 21:21 -e FTP_USER=$FTP_USER -e FTP_PASS=$FTP_PASSWORD -e PASV_ADDRESS=127.0.0.1 -e PASV_MIN_PORT=21100 -e PASV_MAX_PORT=21110 -d --name ftp -v $(pwd)/:/home/vsftpd fauria/vsftpd
- run: docker run -p 1080:1080 -p 1025:1025 -d --name maildev soulteary/maildev
- run: docker run -p 6379:6379 -d --name redis redis
- run: docker run -p 5432:5432 --name postgres -e POSTGRES_PASSWORD=postgres -e POSTGRES_DB=postgres -e POSTGRES_PASSWORD=postgres -d postgis/postgis
Expand All @@ -57,7 +57,7 @@ jobs:
${{ runner.os }}-php-${{ hashFiles('**/composer.lock') }}
- name: Copy the php ini config
run: cp php.dist.ini php.ini
run: sudo cp php.dist.ini php.ini

- name: Install dependencies
run: composer update --prefer-dist --no-interaction
Expand Down
16 changes: 4 additions & 12 deletions src/Router/Route.php
Original file line number Diff line number Diff line change
Expand Up @@ -13,7 +13,7 @@ class Route
/**
* The callback has launched if the url of the query has matched.
*
* @var callable
* @var mixed
*/
private mixed $cb;

Expand Down Expand Up @@ -70,7 +70,7 @@ class Route
* Route constructor
*
* @param string $path
* @param callable $cb
* @param mixed $cb
*
* @throws
*/
Expand Down Expand Up @@ -124,11 +124,7 @@ public function middleware(array|string $middleware): Route
return $this;
}

if (!isset($this->cb['middleware'])) {
$this->cb['middleware'] = $middleware;
} else {
$this->cb['middleware'] = array_merge((array) $this->cb['middleware'], $middleware);
}
$this->cb['middleware'] = !isset($this->cb['middleware']) ? $middleware : array_merge((array) $this->cb['middleware'], $middleware);

return $this;
}
Expand All @@ -142,11 +138,7 @@ public function middleware(array|string $middleware): Route
*/
public function where(array|string $where, $regex_constraint = null): Route
{
if (is_array($where)) {
$other_rule = $where;
} else {
$other_rule = [$where => $regex_constraint];
}
$other_rule = is_array($where) ? $where : [$where => $regex_constraint];

$this->with = array_merge($this->with, $other_rule);

Expand Down
60 changes: 31 additions & 29 deletions src/Router/Router.php
Original file line number Diff line number Diff line change
Expand Up @@ -162,11 +162,7 @@ public function middleware(array|string $middlewares): Router
$collection = [];

foreach ($middlewares as $middleware) {
if (class_exists($middleware, true)) {
$collection[] = [new $middleware(), 'process'];
} else {
$collection[] = $middleware;
}
$collection[] = class_exists($middleware, true) ? [new $middleware(), 'process'] : $middleware;
}

return new Router($this->method, $this->magic_method, $this->base_route, $collection);
Expand Down Expand Up @@ -341,66 +337,72 @@ public function code(int $code, callable|array|string $cb): Router
* @param callable|string|array $cb
* @return Router
*/
public function match(array $methods, string $path, callable|string|array $cb): Router
public function match(array $methods, string $path, callable|string|array $cb): Route
{
foreach ($methods as $method) {
if ($this->method == strtoupper($method)) {
$this->pushHttpVerb(strtoupper($method), $path, $cb);
}
}
$methods = array_map('strtoupper', $methods);

return $this;
return $this->pushHttpVerb($methods, $path, $cb);
}

/**
* Add other HTTP verbs [PUT, DELETE, UPDATE, HEAD, PATCH]
*
* @param string $method
* @param string|array $methods
* @param string $path
* @param callable|array|string $cb
* @return Route
*/
private function pushHttpVerb(string $method, string $path, callable|string|array $cb): Route
private function pushHttpVerb(string|array $methods, string $path, callable|string|array $cb): Route
{
if ($this->magic_method) {
$methods = (array) $methods;

if (!$this->magic_method) {
return $this->routeLoader($methods, $path, $cb);
}

foreach ($methods as $key => $method) {
if ($this->magic_method === $method) {
$method = $this->magic_method;
$methods[$key] = $this->magic_method;
}
}

return $this->routeLoader($method, $path, $cb);
return $this->routeLoader($methods, $path, $cb);
}

/**
* Start loading a route.
*
* @param string $method
* @param string|array $method
* @param string $path
* @param Callable|string|array $cb
* @param callable|string|array $cb
* @return Route
*/
private function routeLoader(string $method, string $path, callable|string|array $cb): Route
private function routeLoader(string|array $methods, string $path, callable|string|array $cb): Route
{
$methods = (array) $methods;

$path = '/' . trim($path, '/');

// We build the original path based on the Router loader
$path = $this->base_route . $this->prefix . $path;

// We define the current route and current method
$this->current = ['path' => $path, 'method' => $method];

// We add the new route
$route = new Route($path, $cb);

$route->middleware($this->middlewares);

static::$routes[$method][] = $route;
foreach ($methods as $method) {
static::$routes[$method][] = $route;

// We define the current route and current method
$this->current = ['path' => $path, 'method' => $method];

if (
$this->auto_csrf === true
&& in_array($method, ['POST', 'DELETE', 'PUT'])
) {
$route->middleware('csrf');
if (
$this->auto_csrf === true
&& in_array($method, ['POST', 'DELETE', 'PUT'])
) {
$route->middleware('csrf');
}
}

return $route;
Expand Down
4 changes: 2 additions & 2 deletions tests/Auth/AuthenticationTest.php
Original file line number Diff line number Diff line change
Expand Up @@ -105,7 +105,7 @@ public function test_attempt_login_with_jwt_provider()
$this->assertInstanceOf(Authentication::class, $user);
$this->assertTrue($auth->check());
$this->assertEquals($auth->id(), $user->id);
$this->assertRegExp("/^([a-zA-Z0-9_-]+\.){2}[a-zA-Z0-9_-]+$/", $token);
$this->assertMatchesRegularExpression("/^([a-zA-Z0-9_-]+\.){2}[a-zA-Z0-9_-]+$/", $token);
}

public function test_direct_login_with_jwt_provider()
Expand All @@ -119,7 +119,7 @@ public function test_direct_login_with_jwt_provider()
$this->assertTrue($auth->check());
$this->assertInstanceOf(Authentication::class, $user);
$this->assertEquals($auth->id(), $user->id);
$this->assertRegExp("/^([a-zA-Z0-9_-]+\.){2}[a-zA-Z0-9_-]+$/", $token);
$this->assertMatchesRegularExpression("/^([a-zA-Z0-9_-]+\.){2}[a-zA-Z0-9_-]+$/", $token);
}

public function test_attempt_login_with_jwt_provider_fail()
Expand Down
2 changes: 1 addition & 1 deletion tests/Config/stubs/storage.php
Original file line number Diff line number Diff line change
Expand Up @@ -23,7 +23,7 @@
*/
'ftp' => [
"driver" => "ftp",
'hostname' => app_env('FTP_HOST', 'localhost'),
'hostname' => app_env('FTP_HOST', '127.0.0.1'),
'password' => app_env('FTP_PASSWORD', 'password'),
'username' => app_env('FTP_USERNAME', 'username'),
'port' => app_env('FTP_PORT', 21),
Expand Down
8 changes: 4 additions & 4 deletions tests/Console/GeneratorBasicTest.php
Original file line number Diff line number Diff line change
Expand Up @@ -16,8 +16,8 @@ public function test_generate_stubs()
]);

$this->assertNotNull($content);
$this->assertRegExp("@\nnamespace\sGenerator\\\Testing;\n@", $content);
$this->assertRegExp("@\nclass\sCreateUserCommand\sextends\sConsoleCommand\n@", $content);
$this->assertMatchesRegularExpression("@\nnamespace\sGenerator\\\Testing;\n@", $content);
$this->assertMatchesRegularExpression("@\nclass\sCreateUserCommand\sextends\sConsoleCommand\n@", $content);
}

public function test_generate_stub_without_data()
Expand All @@ -26,8 +26,8 @@ public function test_generate_stub_without_data()
$content = $generator->makeStubContent('command', []);

$this->assertNotNull($content);
$this->assertRegExp("@\nnamespace\s\{baseNamespace\}\{namespace\};\n@", $content);
$this->assertRegExp("@\nclass\s\{className\}\sextends\sConsoleCommand\n@", $content);
$this->assertMatchesRegularExpression("@\nnamespace\s\{baseNamespace\}\{namespace\};\n@", $content);
$this->assertMatchesRegularExpression("@\nclass\s\{className\}\sextends\sConsoleCommand\n@", $content);
}

public function test_generate_by_writing_file()
Expand Down
Loading

0 comments on commit cce9076

Please sign in to comment.