phapi / middleware-file-handler
Middleware responsible for handling files received from and sent to the client
Installs: 1 293
Dependents: 0
Suggesters: 0
Security: 0
Stars: 0
Watchers: 1
Forks: 0
Open Issues: 0
Requires
- php: >=5.6.0
- league/flysystem: 1.*
Requires (Dev)
- mockery/mockery: 0.9.*
- phpunit/phpunit: 4.8.10
- squizlabs/php_codesniffer: 2.*
This package is not auto-updated.
Last update: 2021-02-05 23:00:14 UTC
README
Please note that this package is still a work in progress and that the implementation might change at any time and that the documentation might be out of date.
File Handler is a middleware preparing the Phapi Framework for handling client request for both uploading and downloading files. It acts like a modified version of a serializer but without the serialization functionality. It registers the supported mime types and makes sure uploaded files are of a mime type that is allowed as well as checking the file size of the uploaded file.
The package also contains an Endpoint that handles both PUT (for uploading files) and GET (for downloading files) requests. The Endpoint depends on league/flysystem for handling the interaction with the file storage.
Installation
This middleware is not included by default in the Phapi Framework but if you need to install it it's available to install via Packagist and Composer.
$ php composer.phar require phapi/middleware-file-handler:1.*
Configuration
The configuration can be a little bit tricky. The phapi-configuration repo has all the configuration added in the right order and place. You can use the repo to start a new project or use it as a reference while updating your existing project. Below is a list of what you need to add to your configuration to get the File handler middleware to work.
configuration/settings.php
Add the following lines to your settings (example) file and configure your list of routes and configuration for each route:
<?php /* * File handler configuration, add an array for each route you want to have. * The file handler requires the FlySystem package, link: http://flysystem.thephpleague.com/ * * Each route has the following configuration options: * 'route', the route itself (don't forget that the route has to be included in the main route table as well) * 'maxFileSize', (optional) the maximum allowed file size * 'mimeTypes', an array with the list of allowed mime types * 'flySystemAdapter', use the adapter that matches your environment */ $container['fileHandlerConfiguration'] = function () { return [ /* Example: [ 'route' => '/user/avatar/{id}/{fileName}', // Complete route 'maxFileSize' => 1024000, // In bytes 'mimeTypes' => [ 'image/gif', 'image/png', 'image/jpg', 'image/jpeg' ], 'flySystemAdapter' => new League\Flysystem\Adapter\Local('/path/to/file/storage/') ]*/ ]; }; // Create the Fly system file system $container['flySystem'] = function ($container) { return new \League\Flysystem\Filesystem( $container['fileHandledConfiguration']['flySystemAdapter'] ); };
configuration/middleware.php
Add the following two lines to your configuration (example) to add the middleware to the middleware pipeline:
The first line should be added right after the regular serializers
and must be added before the FormatNegotiation
middleware.
<?php $pipeline->pipe(new \Phapi\Middleware\FileHandler\FileReader($container['fileHandlerConfiguration']));
The second line must be added between the Route
and PostBox
middleware.
<?php $pipeline->pipe(new \Phapi\Middleware\FileHandler\FileUploader($container['fileHandlerConfiguration']));
configuration/routes.php
The last step is to add a new route to your route table (example:
<?php $routes = [ '/user/avatar/{id}/{fileName}' => '\\Phapi\\Endpoint\\File', ];
Usage
Some things to consider:
- It's important that you set the set
memory_limit
high enough to be able to handle large files. Uploading files will NOT be affected by eitherpost_max_size
orupload_max_filesize
since we are using PUT method instead of POST. - The included File endpoint expects the route to have a variable last in the string and that variable will be used as the file name. In the example above we have two variables, id and file name, both will be used when the file is saved to storage. If the Flysystem configuration says that a file should be saved to
/www/files/
the file will be saved to/www/files/{id}/{filename}
. - The File endpoint will save the file to the designated place and that's it. So a good strategy is to create a separate endpoint that gets called before the File endpoint with information about the file. That endpoint should save the information and return the designated url where the file should be PUT.
Phapi
This middleware is a Phapi package used by the Phapi Framework. The middleware are also PSR-7 compliant and implements the Phapi Middleware Contract.
License
Serializer JSON is licensed under the MIT License - see the license.md file for details
Contribute
Contribution, bug fixes etc are always welcome.