@@ -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 | } |