startsevdenis / fm-elfinder-bundle
ElFinder bundle, adds ElFinder file manager to your Symfony2 project
Installs: 159
Dependents: 0
Suggesters: 0
Security: 0
Stars: 0
Watchers: 1
Forks: 128
Type:symfony-bundle
Requires
- php: >=5.3.9
- components/elfinder: ~2.0
- helios-ag/fm-elfinder-php-connector: ~2.0
- symfony/form: ~2.4|~3.0
- symfony/framework-bundle: ~2.4|~3.0
- symfony/twig-bundle: ~2.4|~3.0
Requires (Dev)
- matthiasnoback/symfony-config-test: ~1
- matthiasnoback/symfony-dependency-injection-test: ~0.7
- satooshi/php-coveralls: dev-master
- symfony/finder: ~2.4|3.0
- symfony/phpunit-bridge: ~2.7|~3.0
Suggests
- egeloen/ckeditor-bundle: CKEditor Bundle by Egeloen
- helios-ag/fm-summernote-bundle: Summernote Bundle by me
- helios-ag/fm-tinymce-bundle: TinyMCE Bundle by me
README
ElFinder integration in Symfony2
Code Quality Assurance
elFinder is an open-source file manager for web, written in JavaScript using jQuery UI. Creation is inspired by simplicity and convenience of Finder program used in Mac OS X operating system.
Recommended bundles to use with:
Table of contents
Installation
Step 1: Installation
Version 6 (Symfony 3 Compatible):
Add FMElFinderBundle to your composer.json
{ "require": { "helios-ag/fm-elfinder-bundle": "~6", } }
Version 5:
Add FMElfinderBundle to your composer.json:
{ "require": { "helios-ag/fm-elfinder-bundle": "~5", } }
also add component-dir under config node of composer.json
{ "config": { "component-dir": "web/assets" } }
Version 4:
This version doesn't use component library
composer require helios-ag/fm-elfinder-bundle: "~4.0"
For Symfony =<2.3 use version ~2.3
composer require helios-ag/fm-elfinder-bundle: "~2.3"
Now tell composer to download the bundle by running the command:
composer update helios-ag/fm-elfinder-bundle
Step 2: Enable the bundle
Enable the bundle in the kernel:
<?php // app/AppKernel.php public function registerBundles() { $bundles = array( // ... new FM\ElfinderBundle\FMElfinderBundle(), ); }
Step 3: Import FMElfinderBundle routing file
# app/config/routing.yml elfinder: resource: "@FMElfinderBundle/Resources/config/routing.yml"
Step 4: Configure your application's security.yml
Secure ElFinder with access_control:
# app/config/security.yml security: //.... access_control: - { path: ^/efconnect, role: ROLE_USER } - { path: ^/elfinder, role: ROLE_USER }
Step 5: Install assets
Install and dump assets via symfony built-in command:
app/console assets:install web
Basic configuration
Add configuration options to your config.yml
fm_elfinder: instances: default: locale: %locale% # defaults to current request locale editor: ckeditor # other options are tinymce, tinymce4, fm_tinymce, form, simple, custom #editor_template: set custom template for your editor # default null #path_prefix: / # for setting custom assets path prefix, useful for non vhost configurations, i.e. http://127.0.0.1/mysite/ #fullscreen: true|false # defaults true, applies to simple and ckeditor editors #theme: smoothness # jquery theme, default is 'smoothness' include_assets: true # disable if you want to handle loading of the javascript and css assets yourself #visible_mime_types: ['image/png', 'image/jpg', 'image/jpeg'] # only show these mime types, defaults to show all connector: #debug: true|false # defaults to false roots: # at least one root must be defined uploads: #show_hidden: true|false # defaults to false, hide files that driver: LocalFileSystem path: uploads upload_allow: ['image/png', 'image/jpg', 'image/jpeg'] upload_deny: ['all'] upload_max_size: 2M #attributes: example of setting attributes permission # - { pattern: '/(.*?)/', read: true, write: false, locked: true }
- default - instance of elfinder, can be used to define multiple configurations of ElFinder, allows simultaneous configuration for different types of WYSIWYG editors in your project
- path - define root directory for the files inside web/ directory, default is "uploads". Make sure to set proper write/read permissions to this directory.
- url - url to be prefixed to image path, for displaying. Can be either absolute or relative. If relative, it will be prefixed with the applications base-url. If left blank, url will be the base-url, append with the value of the 'path' parameter
- driver - can be LocalFileSystem, FTP or MySQL2, currently supported only LocalFileSystem, default is LocalFileSystem
- locale - locale determines, which language, ElFinder will use, to translate user interface, default is current request locale
- cors_support - allows cross domain responses handling (default false)
- editor - determines what template to render, to be compatible with WYSIWYG web editor, currently supported options are: "ckeditor" (to use with IvoryCKEditorBundle or TrsteelCkeditorBundle), "fm_tinymce" for tinymce4 (to use with FMTinyMCEBundle), "form" for form type, "simple" for standalone and "custom" for custom template. How to configure CKEDitor and TinyMCE to work with this bundle, will be explained further in this document.
- editor_template - define template to render editor is set to "custom".
- connector - root node for defining options for elfinder root directories.
- roots - define "virtual directories" that reflect directories in your project.
- path_prefix - path prefix with relative_path enabled, default is slash ('/')
- show_hidden - show files and folders that starts from . (dot)
- driver - driver type, LocalFileSystem, Dropbox, FTP
- volume_id - (optional) can be used to force a volume id when mounting volume (default auto-increments). If provided, it must be an integer bigger than 0.
- alias - directory alias
- path - directory that contains files
- upload_allow: ['image/png', 'image/jpg', 'image/jpeg']
- upload_deny: ['all']
- upload_max_size: 2M
You can see the full list of roots options here. To use them, convert camelCased option name to under_scored name.
Use multiple upload folder by instance
You can set multiple upload root folder by instance configuration.
If you have configured your instance with /uploads
path, you can provide
an additional folder as a home folder (e.g. for a multi-users application) when accessing to the instance URL :
/elfinder/{instance}/{homeFolder}
or /efconnect/{instance}/{homeFolder}
For example, accessing to /elfinder/acmeInstance/bob
URL will open up elfinder with
/uploads/bob
as root directory which only contains Bob's files.
Then, accessing to /elfinder/acmeInstance/alice
URL will re-use your instance,
but open up elfinder with /uploads/alice
folder as root directory, containing only Alice's files.
To use this feature, you must provide the instance name in the URL, and of course be sure to set proper write/read permissions on home folders.
Note: this feature is only available with LocalFileSystem
driver.