- Fixed issue with parsing parameters on some occasion.
- Optimisations.
This commit is contained in:
Simon Sessingø
2017-11-27 02:03:12 +01:00
parent bdfc36ed5c
commit efd5159604
7 changed files with 33 additions and 26 deletions
+8 -8
View File
@@ -6,14 +6,14 @@ class Uri
{ {
private $originalUrl; private $originalUrl;
private $data = [ private $data = [
'scheme' => '', 'scheme' => null,
'host' => '', 'host' => null,
'port' => '', 'port' => null,
'user' => '', 'user' => null,
'pass' => '', 'pass' => null,
'path' => '', 'path' => null,
'query' => '', 'query' => null,
'fragment' => '', 'fragment' => null,
]; ];
public function __construct($url) public function __construct($url)
+11 -8
View File
@@ -57,7 +57,7 @@ abstract class LoadableRoute extends Route implements ILoadableRoute
return null; return null;
} }
return (preg_match($this->regex, $request->getHost() . $url) !== 0); return (preg_match($this->regex, $request->getHost() . $url) > 0);
} }
/** /**
@@ -74,7 +74,7 @@ abstract class LoadableRoute extends Route implements ILoadableRoute
$regex = sprintf(static::PARAMETERS_REGEX_FORMAT, $this->paramModifiers[0], $this->paramOptionalSymbol, $this->paramModifiers[1]); $regex = sprintf(static::PARAMETERS_REGEX_FORMAT, $this->paramModifiers[0], $this->paramOptionalSymbol, $this->paramModifiers[1]);
if (preg_match_all('/' . $regex . '/u', $this->url, $matches) === 1) { if (preg_match_all('/' . $regex . '/u', $this->url, $matches) > 0) {
$this->parameters = array_fill_keys($matches[1], null); $this->parameters = array_fill_keys($matches[1], null);
} }
} }
@@ -124,7 +124,7 @@ abstract class LoadableRoute extends Route implements ILoadableRoute
for ($i = $max; $i >= 0; $i--) { for ($i = $max; $i >= 0; $i--) {
$param = $keys[$i]; $param = $keys[$i];
if ($parameters === '' || (is_array($parameters) && count($parameters) === 0)) { if ($parameters === '' || (is_array($parameters) === true && count($parameters) === 0)) {
$value = ''; $value = '';
} else { } else {
$p = (array)$parameters; $p = (array)$parameters;
@@ -229,15 +229,18 @@ abstract class LoadableRoute extends Route implements ILoadableRoute
*/ */
public function setSettings(array $values, $merge = false) public function setSettings(array $values, $merge = false)
{ {
if (isset($values['as'])) { if (isset($values['as']) === true) {
$name = $values['as'];
if ($this->name !== null && $merge !== false) { if ($this->name !== null && $merge !== false) {
$this->setName($values['as'] . '.' . $this->name); $name .= '.' . $this->name;
} else {
$this->setName($values['as']);
} }
$this->setName($name);
} }
if (isset($values['prefix'])) { if (isset($values['prefix']) === true) {
$this->setUrl($values['prefix'] . $this->getUrl()); $this->setUrl($values['prefix'] . $this->getUrl());
} }
+2 -2
View File
@@ -117,7 +117,7 @@ abstract class Route implements IRoute
// Ensures that hostnames/domains will work with parameters // Ensures that hostnames/domains will work with parameters
$url = '/' . ltrim($url, '/'); $url = '/' . ltrim($url, '/');
if (preg_match_all('/' . $regex . '/u', $route, $parameters) !== 0) { if (preg_match_all('/' . $regex . '/u', $route, $parameters) > 0) {
$urlParts = preg_split('/((\-?\/?)\{[^}]+\})/', rtrim($route, '/')); $urlParts = preg_split('/((\-?\/?)\{[^}]+\})/', rtrim($route, '/'));
@@ -155,7 +155,7 @@ abstract class Route implements IRoute
$urlRegex = preg_quote($route, '/'); $urlRegex = preg_quote($route, '/');
} }
if (preg_match(sprintf($this->urlRegex, $urlRegex), $url, $matches) === 1) { if (preg_match(sprintf($this->urlRegex, $urlRegex), $url, $matches) > 0) {
$values = []; $values = [];
@@ -1,4 +1,5 @@
<?php <?php
namespace Pecee\SimpleRouter\Route; namespace Pecee\SimpleRouter\Route;
use Pecee\Http\Request; use Pecee\Http\Request;
@@ -168,7 +169,7 @@ class RouteController extends LoadableRoute implements IControllerRoute
*/ */
public function setSettings(array $values, $merge = false) public function setSettings(array $values, $merge = false)
{ {
if (isset($values['names'])) { if (isset($values['names']) === true) {
$this->names = $values['names']; $this->names = $values['names'];
} }
+6 -3
View File
@@ -159,11 +159,14 @@ class RouteGroup extends Route implements IGroupRoute
} }
if (isset($values['as']) === true) { if (isset($values['as']) === true) {
$name = $values['as'];
if ($this->name !== null && $merge !== false) { if ($this->name !== null && $merge !== false) {
$this->name = $values['as'] . '.' . $this->name; $name .= '.' . $this->name;
} else {
$this->name = $values['as'];
} }
$this->name = $name;
} }
parent::setSettings($values, $merge); parent::setSettings($values, $merge);
@@ -206,11 +206,11 @@ class RouteResource extends LoadableRoute implements IControllerRoute
*/ */
public function setSettings(array $values, $merge = false) public function setSettings(array $values, $merge = false)
{ {
if (isset($values['names'])) { if (isset($values['names']) === true) {
$this->names = $values['names']; $this->names = $values['names'];
} }
if (isset($values['methods'])) { if (isset($values['methods']) === true) {
$this->methodNames = $values['methods']; $this->methodNames = $values['methods'];
} }
+2 -2
View File
@@ -285,7 +285,7 @@ class Router
} }
if ($routeNotAllowed === true) { if ($routeNotAllowed === true) {
$message = sprintf('Route "%s" or method "%s" not allowed.', $this->request->getUri()->getPath(), $this->request->getMethod()); $message = sprintf('Route "%s" or method "%s" not allowed.', $this->request->getUri()->getPath(), $this->request->getMethod());
$this->handleException(new HttpException($message, 403)); $this->handleException(new HttpException($message, 403));
} }
@@ -497,7 +497,7 @@ class Router
$route = $this->processedRoutes[$i]; $route = $this->processedRoutes[$i];
/* Check if the route contains the name/alias */ /* Check if the route contains the name/alias */
if ($route->hasName($controller)) { if ($route->hasName($controller) === true) {
return $route->findUrl($method, $parameters, $name) . $this->arrayToParams($getParams); return $route->findUrl($method, $parameters, $name) . $this->arrayToParams($getParams);
} }