-
Notifications
You must be signed in to change notification settings - Fork 21
Expand file tree
/
Copy pathBasicRouter.php
More file actions
125 lines (107 loc) · 3.32 KB
/
BasicRouter.php
File metadata and controls
125 lines (107 loc) · 3.32 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
<?php
declare(strict_types=1);
namespace Lit\Voltage;
use Lit\Voltage\Interfaces\RouterStubResolverInterface;
use Psr\Http\Message\ServerRequestInterface;
/**
* Basic router implementation that do strict match against method & path
*/
class BasicRouter extends AbstractRouter
{
protected $mounts = [];
protected $routes = [];
protected $autoSlash = true;
protected $methodNotAllowed;
/**
* @param RouterStubResolverInterface $stubResolver The stub resolver.
* @param mixed $notFound Stub when route is not found.
* @param mixed $methodNotAllowed Stub when route exists but method is mismatch.
*/
public function __construct(RouterStubResolverInterface $stubResolver, $notFound = null, $methodNotAllowed = null)
{
parent::__construct($stubResolver, $notFound);
$this->methodNotAllowed = $methodNotAllowed ?: $notFound;
}
protected function findStub(ServerRequestInterface $request)
{
$method = strtolower($request->getMethod());
$path = $request->getUri()->getPath();
$path = self::autoPrependSlash($path);
$routes = $this->routes;
if (isset($routes[$path][$method])) {
return $routes[$path][$method];
} elseif (isset($routes[$path]) && isset($this->methodNotAllowed)) {
return $this->methodNotAllowed;
} else {
return $this->notFound;
}
}
/**
* Register a route
*
* @param string $method The HTTP method.
* @param string $path The full URI path.
* @param mixed $routeStub The route.
* @return $this
*/
public function register(string $method, string $path, $routeStub): BasicRouter
{
$this->routes[$path][strtolower($method)] = $routeStub;
return $this;
}
/**
* Register a GET route
*
* @param string $path The full URI path.
* @param mixed $routeStub The route.
* @return $this
*/
public function get(string $path, $routeStub): BasicRouter
{
return $this->register('get', $path, $routeStub);
}
/**
* Register a POST route
*
* @param string $path The full URI path.
* @param mixed $routeStub The route.
* @return $this
*/
public function post(string $path, $routeStub): BasicRouter
{
return $this->register('post', $path, $routeStub);
}
/**
* Register a PUT route
*
* @param string $path The full URI path.
* @param mixed $routeStub The route.
* @return $this
*/
public function put(string $path, $routeStub): BasicRouter
{
return $this->register('put', $path, $routeStub);
}
/**
* Register a DELETE route
*
* @param string $path The full URI path.
* @param mixed $routeStub The route.
* @return $this
*/
public function delete(string $path, $routeStub): BasicRouter
{
return $this->register('delete', $path, $routeStub);
}
/**
* Register a PATCH route
*
* @param string $path The full URI path.
* @param mixed $routeStub The route.
* @return $this
*/
public function patch(string $path, $routeStub): BasicRouter
{
return $this->register('patch', $path, $routeStub);
}
}