mirror of
https://github.com/skipperbent/simple-php-router.git
synced 2026-06-14 09:43:42 +03:00
- Updated `helpers.php` and helpers example in documentation. - MalformedUrlException is now handled properly by Router to avoid phpStorm syntax highlights in routes. - Added `getUrlCopy` to `Request` class, used to clone the current route (to keep domain etc.) - `setUrl` in `Request` are now strict and requires `Url` object and no longer accepts strings. - Renamed `hasRewrite` property to `hasPendingRewrite` in `Request` class. - Renamed `hasRewrite` and `setHasRewrite` methods to `hasPendingRewrite` and `setHasPendingRewrite` in `Request` class. - Added better usage of `Url` class. When calling `url` you can now use the methods on the `Url` class to filter params, get relative/absolute url etc. See documentation for more info. - Renamed `get` method to `getValue` in `InputHandler` class. - Renamed `getObject` to `get` and removed `$defaultValue` argument in `InputHandler` class. - Optimized `InputHandler` class. - Fixed issue with `$token` not being proper string in `BaseCsrfVerifier` when token is not found. - Added php.ini configuration settings to `setcookie` in `CookieTokenProvider` for improved security. - Added `$router` parameter to `boot` method in `IRouterBootManager` which allows for further manipulation of the router within the bootmanager. - Renamed `$processingRoute` property to `$isProcessingRoute` in `Router` class. - Fixed `reset` method not resetting CSRF-verifier in `Router` class. - Moved `arrayToParams` helper-method from `Router` to `Url` class. - Began to add Event-functionality to router. - Added `addEventHandler` method to `SimpleRouter` class. - Moved `Pecee\SimpleRouter\Handler\CallbackExceptionHandler` to `Pecee\SimpleRouter\Handlers\CallbackExceptionHandler`. - Moved `Pecee\SimpleRouter\Handler\IExceptionHandler` to `Pecee\SimpleRouter\Handlers\IExceptionHandler`. - Added Events section to documentation. - Added more information on url-handling in documentation. - Optimisations.
93 lines
2.2 KiB
PHP
93 lines
2.2 KiB
PHP
<?php
|
|
|
|
use Pecee\SimpleRouter\SimpleRouter as Router;
|
|
use \Pecee\Http\Url;
|
|
use \Pecee\Http\Response;
|
|
use \Pecee\Http\Request;
|
|
|
|
/**
|
|
* Get url for a route by using either name/alias, class or method name.
|
|
*
|
|
* The name parameter supports the following values:
|
|
* - Route name
|
|
* - Controller/resource name (with or without method)
|
|
* - Controller class name
|
|
*
|
|
* When searching for controller/resource by name, you can use this syntax "route.name@method".
|
|
* You can also use the same syntax when searching for a specific controller-class "MyController@home".
|
|
* If no arguments is specified, it will return the url for the current loaded route.
|
|
*
|
|
* @param string|null $name
|
|
* @param string|array|null $parameters
|
|
* @param array|null $getParams
|
|
* @return \Pecee\Http\Url
|
|
* @throws \InvalidArgumentException
|
|
*/
|
|
function url(?string $name = null, $parameters = null, ?array $getParams = null): Url
|
|
{
|
|
return Router::getUrl($name, $parameters, $getParams);
|
|
}
|
|
|
|
/**
|
|
* @return \Pecee\Http\Response
|
|
*/
|
|
function response(): Response
|
|
{
|
|
return Router::response();
|
|
}
|
|
|
|
/**
|
|
* @return \Pecee\Http\Request
|
|
*/
|
|
function request(): Request
|
|
{
|
|
return Router::request();
|
|
}
|
|
|
|
/**
|
|
* Get input class
|
|
* @param string|null $index Parameter index name
|
|
* @param string|null $defaultValue Default return value
|
|
* @param string|array|null $methods Default method
|
|
* @return \Pecee\Http\Input\InputHandler|\Pecee\Http\Input\IInputItem|string
|
|
*/
|
|
function input($index = null, $defaultValue = null, $methods = null)
|
|
{
|
|
if ($index !== null) {
|
|
|
|
if ($defaultValue !== null) {
|
|
return request()->getInputHandler()->getValue($index, $defaultValue, $methods);
|
|
}
|
|
|
|
return request()->getInputHandler()->get($index, $methods);
|
|
}
|
|
|
|
return request()->getInputHandler();
|
|
}
|
|
|
|
/**
|
|
* @param string $url
|
|
* @param int|null $code
|
|
*/
|
|
function redirect(string $url, ?int $code = null): void
|
|
{
|
|
if ($code !== null) {
|
|
response()->httpCode($code);
|
|
}
|
|
|
|
response()->redirect($url);
|
|
}
|
|
|
|
/**
|
|
* Get current csrf-token
|
|
* @return string|null
|
|
*/
|
|
function csrf_token(): ?string
|
|
{
|
|
$baseVerifier = Router::router()->getCsrfVerifier();
|
|
if ($baseVerifier !== null) {
|
|
return $baseVerifier->getTokenProvider()->getToken();
|
|
}
|
|
|
|
return null;
|
|
} |