mirror of
https://github.com/filegator/filegator.git
synced 2025-10-24 11:26:20 +02:00
56 lines
1.6 KiB
Markdown
56 lines
1.6 KiB
Markdown
---
|
|
currentMenu: router
|
|
---
|
|
|
|
## Router service
|
|
|
|
Router service is using well-known [FastRoute](https://github.com/nikic/FastRoute) library. There is no need to change this service unless you're extending the script.
|
|
|
|
The router uses unique query parameter `?r=` to pass the route info. Because of this feature, this (single-page) application does not require rewrite rules, .htaccess or similar tweaks.
|
|
|
|
Example routes:
|
|
|
|
- `http://example.com/?r=/some/route¶m1=val1¶m2=val2`
|
|
- `http://example.com/?r=/user/{user_id}¶m1=val1`
|
|
|
|
|
|
## Routes file
|
|
|
|
Routes file is located here `backend/Controllers/routes.php` Each route in the routes array looks like this:
|
|
|
|
|
|
```
|
|
[
|
|
'route' => [
|
|
'GET', '/download/{path_encoded}', '\Filegator\Controllers\DownloadController@download',
|
|
],
|
|
'roles' => [
|
|
'guest', 'user', 'admin',
|
|
],
|
|
'permissions' => [
|
|
'download',
|
|
],
|
|
],
|
|
```
|
|
|
|
As you can in the example, you can assign required user roles and permissions for each route.
|
|
|
|
## Controllers
|
|
|
|
Since FileGator is using an awesome dependency injection [container](https://github.com/PHP-DI/PHP-DI) you can type-hint dependencies directly in your controllers.
|
|
|
|
You can also mix route parameters and dependencies in any order like in this example:
|
|
|
|
```
|
|
|
|
public function __construct(Config $config, Session $session, AuthInterface $auth, Filesystem $storage)
|
|
{
|
|
// ...
|
|
}
|
|
|
|
public function download($path_encoded, Request $request, Response $response, StreamedResponse $streamedResponse)
|
|
{
|
|
// ...
|
|
}
|
|
```
|