mirror of
https://github.com/silverstripe/silverstripe-framework
synced 2024-10-22 12:05:37 +00:00
DOC Explain how to configure a low level application middleware (#9504)
This commit is contained in:
parent
7dc6b36c16
commit
10efe79b93
@ -118,6 +118,40 @@ SilverStripe\Control\Director:
|
||||
Controller: %$SpecialRouteMiddleware
|
||||
```
|
||||
|
||||
## Application middleware
|
||||
|
||||
Some use cases will require a middleware to run before the Silverstripe CMS has been fully bootstrapped (e.g.: Updating
|
||||
the HTTPRequest before Silverstripe CMS routes it to a controller). This can be achieved by editing the Silverstripe
|
||||
CMS entry point file.
|
||||
|
||||
This file will be located in your own codebase at `public/index.php`, or directly in your project root at `index.php`
|
||||
if your project doesn't use the public web root. Find the line that instantiate `HTTPApplication`. Call the
|
||||
`addMiddleware` method on the `HTTPApplication` instance and pass it an instance of your middleware. This must be done
|
||||
before the request is handled.
|
||||
|
||||
```php
|
||||
// Default application
|
||||
$kernel = new CoreKernel(BASE_PATH);
|
||||
$app = new HTTPApplication($kernel);
|
||||
|
||||
$app->addMiddleware(new MyApplicationMiddleware());
|
||||
|
||||
$response = $app->handle($request);
|
||||
$response->output();
|
||||
```
|
||||
|
||||
Beware that by this point, the Silverstripe framework features you normally rely on won't be
|
||||
available in your middleware or in `index.php` because they won't have been initialised yet. (e.g.: ORM, Injector, services configured by Injector)
|
||||
|
||||
For example, Silverstripe's autoloading functionality won't work in `index.php`. So you might have to take additional
|
||||
steps to load your custom middleware class.
|
||||
|
||||
[Configuring autoloading in your `composer.json` file](https://getcomposer.org/doc/04-schema.md#autoload) is the best
|
||||
way to achieve this. Remember to call `composer dump-autoload` to regenerate your autoloader.
|
||||
|
||||
Alternatively, you can manually include the file containing your custom middleware with a `require` call. e.g.:
|
||||
`require __DIR__.'/../app/src/MyApplicationMiddleware.php';`
|
||||
|
||||
## API Documentation
|
||||
|
||||
* [Built-in Middleware](/developer_guides/controllers/builtin_middlewares)
|
||||
|
Loading…
x
Reference in New Issue
Block a user