@@ -4,7 +4,7 @@ discard block |
||
4 | 4 | |
5 | 5 | use Exception; |
6 | 6 | |
7 | -class Router{ |
|
7 | +class Router { |
|
8 | 8 | use Helper, CheckTrait; |
9 | 9 | |
10 | 10 | private static $instance = null; |
@@ -21,7 +21,7 @@ discard block |
||
21 | 21 | |
22 | 22 | public static function create(): Router |
23 | 23 | { |
24 | - if(!self::getInstance()->instanced){ |
|
24 | + if (!self::getInstance()->instanced) { |
|
25 | 25 | self::getInstance()->checkConfig(); |
26 | 26 | self::getInstance()->import(ROUTER_CONFIG['path']); |
27 | 27 | self::getInstance()->instanced = true; |
@@ -68,12 +68,12 @@ discard block |
||
68 | 68 | return self::getInstance()->set($uri, $walking, $protocol); |
69 | 69 | } |
70 | 70 | |
71 | - public function set($url ,$walking , string $protocol): Router |
|
71 | + public function set($url, $walking, string $protocol): Router |
|
72 | 72 | { |
73 | - $url = (substr($url,0,1) !=='/' and strlen($url) > 0) ? "/{$url}" : $url; |
|
73 | + $url = (substr($url, 0, 1) !== '/' and strlen($url) > 0) ? "/{$url}" : $url; |
|
74 | 74 | |
75 | - foreach($this->routers as $key => $value){ |
|
76 | - if( md5($this->prefix . $value['url'] . $value['protocol'] ) === md5( $url . $protocol ) ){ |
|
75 | + foreach ($this->routers as $key => $value) { |
|
76 | + if (md5($this->prefix.$value['url'].$value['protocol']) === md5($url.$protocol)) { |
|
77 | 77 | throw new Exception("There is already a route with the url {$url} and with the {$protocol} protocol configured."); |
78 | 78 | } |
79 | 79 | } |
@@ -93,9 +93,9 @@ discard block |
||
93 | 93 | return self::getInstance(); |
94 | 94 | } |
95 | 95 | |
96 | - public static function group(string $prefix,$callback): Router |
|
96 | + public static function group(string $prefix, $callback): Router |
|
97 | 97 | { |
98 | - self::getInstance()->prefix = (substr($prefix,0,1) !== '/') ? "/{$prefix}" : $prefix; |
|
98 | + self::getInstance()->prefix = (substr($prefix, 0, 1) !== '/') ? "/{$prefix}" : $prefix; |
|
99 | 99 | self::getInstance()->group = sha1(date('d/m/Y h:m:i')); |
100 | 100 | $callback(); |
101 | 101 | self::getInstance()->group = null; |
@@ -106,14 +106,14 @@ discard block |
||
106 | 106 | |
107 | 107 | public static function name(string $name): Router |
108 | 108 | { |
109 | - if(self::getInstance()->lastReturn){ |
|
109 | + if (self::getInstance()->lastReturn) { |
|
110 | 110 | throw new Exception("There is no reason to call a {$name} route group."); |
111 | 111 | } |
112 | 112 | |
113 | 113 | $currentRoute = end(self::getInstance()->routers); |
114 | 114 | |
115 | - foreach(self::getInstance()->routers as $key => $value){ |
|
116 | - if(array_key_exists($name, self::getInstance()->routers)){ |
|
115 | + foreach (self::getInstance()->routers as $key => $value) { |
|
116 | + if (array_key_exists($name, self::getInstance()->routers)) { |
|
117 | 117 | throw new Exception("There is already a route with the name {$name} configured."); |
118 | 118 | } |
119 | 119 | } |
@@ -129,15 +129,15 @@ discard block |
||
129 | 129 | |
130 | 130 | private function byName(?string $routName) |
131 | 131 | { |
132 | - if(!is_null($routName)){ |
|
132 | + if (!is_null($routName)) { |
|
133 | 133 | $currentProtocol = $this->getProtocol(); |
134 | 134 | |
135 | 135 | $this->checkName($routName); |
136 | 136 | |
137 | 137 | $route = $this->routers[$routName]; |
138 | 138 | |
139 | - if(!$this->checkProtocol($route['protocol'], $currentProtocol)){ |
|
140 | - throw new Exception('Page not found.',404); |
|
139 | + if (!$this->checkProtocol($route['protocol'], $currentProtocol)) { |
|
140 | + throw new Exception('Page not found.', 404); |
|
141 | 141 | } |
142 | 142 | |
143 | 143 | $this->checkFiltering($route); |
@@ -155,23 +155,23 @@ discard block |
||
155 | 155 | |
156 | 156 | $currentProtocol = $instance->getInstance()->getProtocol(); |
157 | 157 | |
158 | - foreach(array_reverse($instance->getInstance()->routers) as $r => $route){ |
|
158 | + foreach (array_reverse($instance->getInstance()->routers) as $r => $route) { |
|
159 | 159 | |
160 | 160 | $instance->getInstance()->currentRoute = $route; |
161 | 161 | |
162 | - if(!$instance->getInstance()->checkProtocol($route['protocol'], $currentProtocol)){ |
|
162 | + if (!$instance->getInstance()->checkProtocol($route['protocol'], $currentProtocol)) { |
|
163 | 163 | continue; |
164 | 164 | } |
165 | 165 | |
166 | 166 | $instance->getInstance()->hasProtocol($route, $currentProtocol); |
167 | 167 | |
168 | - $routeLoop = $instance->getInstance()->explodeRoute( (substr($route['url'],strlen($route['url'])-1,1) === '/') , $route['url']); |
|
168 | + $routeLoop = $instance->getInstance()->explodeRoute((substr($route['url'], strlen($route['url'])-1, 1) === '/'), $route['url']); |
|
169 | 169 | |
170 | 170 | $_SERVER['REQUEST_URI'] = (array_key_exists('REQUEST_URI', $_SERVER)) ? $_SERVER['REQUEST_URI'] : ''; |
171 | 171 | |
172 | - $routeRequest = $instance->getInstance()->explodeRoute((substr($_SERVER['REQUEST_URI'],strlen($_SERVER['REQUEST_URI'])-1,1) === '/') , $_SERVER['REQUEST_URI']); |
|
172 | + $routeRequest = $instance->getInstance()->explodeRoute((substr($_SERVER['REQUEST_URI'], strlen($_SERVER['REQUEST_URI'])-1, 1) === '/'), $_SERVER['REQUEST_URI']); |
|
173 | 173 | |
174 | - if($instance->getInstance()->checkNumparams($routeLoop, $routeRequest) || !$instance->getInstance()->checkParameters($routeLoop, $routeRequest)){ |
|
174 | + if ($instance->getInstance()->checkNumparams($routeLoop, $routeRequest) || !$instance->getInstance()->checkParameters($routeLoop, $routeRequest)) { |
|
175 | 175 | continue; |
176 | 176 | } |
177 | 177 | |
@@ -183,18 +183,18 @@ discard block |
||
183 | 183 | |
184 | 184 | $instance->getInstance()->currentRoute = null; |
185 | 185 | |
186 | - throw new Exception('Page not found.',404); |
|
186 | + throw new Exception('Page not found.', 404); |
|
187 | 187 | } |
188 | 188 | |
189 | 189 | public static function filter($filters): Router |
190 | 190 | { |
191 | - if(self::getInstance()->lastReturn !== null){ |
|
191 | + if (self::getInstance()->lastReturn !== null) { |
|
192 | 192 | $currentGroup = end(self::getInstance()->routers)['group']; |
193 | 193 | |
194 | 194 | foreach (self::getInstance()->routers as $key => $value) { |
195 | 195 | |
196 | - if($value['group'] === $currentGroup){ |
|
197 | - $currentRoute = self::getInstance()->addFilter(self::getInstance()->routers[$key],$filters); |
|
196 | + if ($value['group'] === $currentGroup) { |
|
197 | + $currentRoute = self::getInstance()->addFilter(self::getInstance()->routers[$key], $filters); |
|
198 | 198 | self::getInstance()->routers[$key] = $currentRoute; |
199 | 199 | } |
200 | 200 | |
@@ -205,24 +205,24 @@ discard block |
||
205 | 205 | return self::getInstance(); |
206 | 206 | } |
207 | 207 | |
208 | - self::getInstance()->routers[count(self::getInstance()->routers)-1] = self::getInstance()->addFilter(end(self::getInstance()->routers),$filters); |
|
208 | + self::getInstance()->routers[count(self::getInstance()->routers)-1] = self::getInstance()->addFilter(end(self::getInstance()->routers), $filters); |
|
209 | 209 | return self::getInstance(); |
210 | 210 | } |
211 | 211 | |
212 | 212 | public static function addFilter(array $route, $filter): array |
213 | 213 | { |
214 | - if(is_null($route['filters'])){ |
|
214 | + if (is_null($route['filters'])) { |
|
215 | 215 | $route['filters'] = $filter; |
216 | 216 | return $route; |
217 | 217 | } |
218 | 218 | |
219 | 219 | $filters = (is_array($filter)) ? $filter : [0 => $filter]; |
220 | 220 | |
221 | - if(is_array($route['filters'])){ |
|
221 | + if (is_array($route['filters'])) { |
|
222 | 222 | foreach ($route['filters'] as $key => $value) { |
223 | 223 | $filters[] = $value; |
224 | 224 | } |
225 | - }else{ |
|
225 | + }else { |
|
226 | 226 | $filters[] = $route['filters']; |
227 | 227 | } |
228 | 228 |
@@ -2,7 +2,7 @@ discard block |
||
2 | 2 | |
3 | 3 | namespace HnrAzevedo\Router; |
4 | 4 | |
5 | -trait Helper{ |
|
5 | +trait Helper { |
|
6 | 6 | use CheckTrait, ControllerTrait; |
7 | 7 | |
8 | 8 | private $currentRoute = null; |
@@ -25,7 +25,7 @@ discard block |
||
25 | 25 | protected function getProtocol(): string |
26 | 26 | { |
27 | 27 | $protocol = ((isset($_SERVER['HTTP_X_REQUESTED_WITH']) && strtolower($_SERVER['HTTP_X_REQUESTED_WITH']) == 'xmlhttprequest')) ? 'ajax' : 'get'; |
28 | - $protocol = (array_key_existS('HTTP_REQUESTED_METHOD',$_SERVER)) ? strtolower($_SERVER['HTTP_REQUESTED_METHOD']) : $protocol; |
|
28 | + $protocol = (array_key_existS('HTTP_REQUESTED_METHOD', $_SERVER)) ? strtolower($_SERVER['HTTP_REQUESTED_METHOD']) : $protocol; |
|
29 | 29 | |
30 | 30 | return $protocol; |
31 | 31 | } |
@@ -43,18 +43,18 @@ discard block |
||
43 | 43 | protected function import(string $path) |
44 | 44 | { |
45 | 45 | foreach (scandir($path) as $routeFile) { |
46 | - if(pathinfo($path.DIRECTORY_SEPARATOR.$routeFile, PATHINFO_EXTENSION) === 'php'){ |
|
47 | - require_once($path. DIRECTORY_SEPARATOR .$routeFile); |
|
46 | + if (pathinfo($path.DIRECTORY_SEPARATOR.$routeFile, PATHINFO_EXTENSION) === 'php') { |
|
47 | + require_once($path.DIRECTORY_SEPARATOR.$routeFile); |
|
48 | 48 | } |
49 | 49 | } |
50 | 50 | } |
51 | 51 | |
52 | - protected function ControllerForm($controller, string $method, array $values){ |
|
52 | + protected function ControllerForm($controller, string $method, array $values) { |
|
53 | 53 | $this->checkRole(); |
54 | 54 | $method = ($method !== 'method') ? $method : $this->getData()['POST']['role']; |
55 | 55 | $data = (!is_null($values)) ? json_decode($values['data'], true) : null; |
56 | 56 | |
57 | - call_user_func_array([$controller,$method], $data); |
|
57 | + call_user_func_array([$controller, $method], $data); |
|
58 | 58 | } |
59 | 59 | |
60 | 60 | protected function Controller(string $controll): void |
@@ -62,7 +62,7 @@ discard block |
||
62 | 62 | $data = $this->getData(); |
63 | 63 | |
64 | 64 | foreach ($data['GET'] as $name => $value) { |
65 | - $controll = str_replace('{'.$name.'}',$value,$controll); |
|
65 | + $controll = str_replace('{'.$name.'}', $value, $controll); |
|
66 | 66 | } |
67 | 67 | |
68 | 68 | $this->checkControllsettable($controll); |
@@ -71,32 +71,32 @@ discard block |
||
71 | 71 | |
72 | 72 | $this->checkControllmethod($controll); |
73 | 73 | |
74 | - $controller = ROUTER_CONFIG['controller.namespace'].'\\'. ucfirst(explode(':',$controll)[0]); |
|
74 | + $controller = ROUTER_CONFIG['controller.namespace'].'\\'.ucfirst(explode(':', $controll)[0]); |
|
75 | 75 | $controller = new $controller(); |
76 | - $method = explode(':',$controll)[1]; |
|
76 | + $method = explode(':', $controll)[1]; |
|
77 | 77 | |
78 | - if( ($this->getProtocol() == 'form') ){ |
|
78 | + if (($this->getProtocol() == 'form')) { |
|
79 | 79 | $this->ControllerForm($controller, $method, $data['POST']); |
80 | 80 | }else { |
81 | - $data = (array_key_exists('data',$data['POST'])) ? json_decode($data['POST']['data'], true) : $data['GET']; |
|
82 | - call_user_func_array([$controller,$method], $data); |
|
81 | + $data = (array_key_exists('data', $data['POST'])) ? json_decode($data['POST']['data'], true) : $data['GET']; |
|
82 | + call_user_func_array([$controller, $method], $data); |
|
83 | 83 | } |
84 | 84 | |
85 | 85 | } |
86 | 86 | |
87 | 87 | protected function explodeRoute(bool $bar, string $url): array |
88 | 88 | { |
89 | - return explode( '/', $bar ? substr($url, 0, -1) : $url ); |
|
89 | + return explode('/', $bar ? substr($url, 0, -1) : $url); |
|
90 | 90 | } |
91 | 91 | |
92 | 92 | protected function toHiking($walking) |
93 | 93 | { |
94 | - if(is_string($walking)){ |
|
94 | + if (is_string($walking)) { |
|
95 | 95 | $this->Controller($walking); |
96 | 96 | return true; |
97 | 97 | } |
98 | 98 | |
99 | - call_user_func_array($walking,$this->getData()['GET']); |
|
99 | + call_user_func_array($walking, $this->getData()['GET']); |
|
100 | 100 | } |
101 | 101 | |
102 | 102 | } |