mirror of
https://github.com/skipperbent/simple-php-router.git
synced 2026-06-17 08:47:52 +00:00
Merge pull request #327 from skipperbent/v3-development
Version 3.4.6.4
This commit is contained in:
@@ -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)
|
||||||
|
|||||||
@@ -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']);
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
if (isset($values['prefix'])) {
|
$this->setName($name);
|
||||||
|
}
|
||||||
|
|
||||||
|
if (isset($values['prefix']) === true) {
|
||||||
$this->setUrl($values['prefix'] . $this->getUrl());
|
$this->setUrl($values['prefix'] . $this->getUrl());
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
@@ -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'];
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
@@ -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'];
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
@@ -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);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
Reference in New Issue
Block a user