makinacorpus / files
File manager with path abstraction and file registry, storage solution.
Installs: 1 055
Dependents: 1
Suggesters: 0
Security: 0
Stars: 0
Watchers: 3
Forks: 0
Open Issues: 0
Requires
- php: >=8.0
- ramsey/uuid: ^4
- symfony/filesystem: ^5.4|^6.0
- symfony/finder: ^5.4|^6.0
- symfony/http-foundation: ^5.4|^6.0
Requires (Dev)
- friendsofphp/php-cs-fixer: ^2.16
- makinacorpus/goat-query: ^2.1.1
- phpunit/phpunit: ^9.2
- symfony/config: ^5.4|^6.0
- symfony/console: ^5.4|^6.0
- symfony/dependency-injection: ^5.4|^6.0
- symfony/framework-bundle: ^5.4|^6.0
- symfony/http-kernel: ^5.4|^6.0
- symfony/mime: ^5.4|^6.0
- symfony/yaml: ^5.4|^6.0
- twig/twig: ^3.1
Conflicts
This package is auto-updated.
Last update: 2025-01-08 16:27:48 UTC
README
This bundle provides various helpers for managing files in Symfony:
-
Provides a
FileManager
object which provides primitives for managing files identified with custom logical schemes (such aspublic://image/foo.png
) transparently handling physical real paths. -
Provides a PHP StreamWrapper implementation for transparent usage of the custom URI schemes.
-
File index storage interface with advanced features.
-
SQL index implementation with transaction support without destructive rollbacks operations and delayed real file deletion operation.
Setup
Installation
First start with:
composer require makinacorpus/files
Then register the bundle to Symfony in config/bundles.php
:
<?php return [ /// ... Your other bundles... MakinaCorpus\Files\Bridge\Symfony\FilesBundle::class => ['all' => true], ];
Then proceed with configuration.
Basic configuration
Everything should be auto-configured if you follow the rest of this section.
Custom schemes configuration
Each custom scheme is tied to a custom folder, allowing you to store protocol relative URI in your database instead of absolute path, making the application portable and migrable easily.
Per default, the bundle offers three schemes:
private://
for files that should not be accessible via the HTTPd which will default to%kernel.project_dir/var/private/%
,public://
for files that will be freely visible via the HTTPd, which will default to%kernel.project_dir/public/files/
,temporary://
for temporary files, which will default to PHP configured temporary folder,upload://
for chunked file upload, which defaults totemporary://filechunk/
webroot://
for files that are in the public directory, will default to%kernel.project_dir/public
,
Only the temporary one cannot be configured, all others can be set via
the following .env
file variables:
FILE_PRIVATE_DIR="%kernel.project_dir%/var/private"
FILE_PUBLIC_DIR="%kernel.project_dir%/public/files"
FILE_UPLOAD_DIR="%kernel.project_dir%/var/tmp/upload"
FILE_WEBROOT_DIR="%kernel.project_dir%/public"
Usage
File manager API
Documentation will come soon.
File storage API
Documentation will come soon.
Notes about migration from makinacorpus/filechunk-bundle
-
Environment variables remain the same.
-
MakinaCorpus\FilechunkBundle\FileManager
becomesMakinaCorpus\Files\FileManager
, a class alias will be registered to allow a smooth migration. -
You MUST upgrade
makinacorpus/filechunk-bundle
to version>= 3
if you want to keep the chunked file upload widget in order to avoid conflicts.
Credits
This code includes sligthly modified code from Drupal 8.x https://www.drupal.org
project, located in the ./StreamWrapper
directory, all credits to their
original authors.
All remaining code is an original creation of Makina Corpus https://www.makina-corpus.com