stanislav-web / phalcon-uploader
Phalcon files uploader. Handling and downloading files for Phalcon projects. Allowed multiple files download, filters etc...
Installs: 32 100
Dependents: 3
Suggesters: 5
Security: 0
Stars: 64
Watchers: 6
Forks: 11
Open Issues: 3
Language:HTML
Requires
- php: >=5.4.0
This package is not auto-updated.
Last update: 2024-12-21 17:07:04 UTC
README
Description
Handling and downloading files for Phalcon projects. Allowed multiple files, filters etc.... (Currently under TDD)
Change Log
[v 1.4-beta] 2015-05-28
- ability to download files to a dynamically created directory (by [Mahdi-Mohammadi](https://github.com/Mahdi-Mohammadi))
[v 1.3-beta] 2015-05-07
- it support Phalcon 2.0
[v 1.2-beta] 2015-05-07
- ability to use closure (anonimous function) for generate uploaded file name
[v 1.1-beta] 2015-02-23
- ability to delete files after downloading ($uploader->truncate())
[v 1.0-beta] 2015-01-10
- added validator (sizes, extensions, mime types, directory upload)
- added filters (sanitize filename pre save, hash filename)
Compatible
- PSR-0, PSR-1, PSR-2, PSR-4 Standards
System requirements
- PHP 5.4.x >
- Phalcon extension 1.3.x
Install
First update your dependencies through composer. Add to your composer.json:
"require": { "stanislav-web/phalcon-uploader": "1.*", }
Then run to update dependency and autoloader
php composer.phar update php composer.phar install
or just
php composer.phar require stanislav-web/phalcon-uploader dev-master
(Do not forget to include the composer autoloader)
Or manual require in your loader service
$loader->registerNamespaces([ 'Uploader\Uploader' => 'path to src' ]);
You can create an injectable service
$di->set('uploader', '\Uploader\Uploader');
Usage
Simple usage
<?php if($this->request->hasFiles() !== false) { // get uploader service $uploader = $this->di->get('uploader'); // setting up uloader rules $uploader->setRules([ 'directory' => '/files', //or 'dynamic' => '/files/'.$part.'/'.$userId, // added v1.4-beta ]); // or use constructor if you don't use service $uploader = new \Uploader\Uploader(([ 'directory' => '/files', //or 'dynamic' => '/files/'.$part.'/'.$userId, // added v1.4-beta ]); }
Filters
<?php if($this->request->hasFiles() !== false) { // get uploader service or \Uploader\Uploader $uploader = $this->di->get('uploader'); // setting up uloader rules $uploader->setRules([ 'directory' => '/files', //or 'dynamic' => '/files/'.$part.'/'.$userId, // added v1.4-beta 'minsize' => 1000, // bytes 'maxsize' => 1000000,// bytes 'mimes' => [ // any allowed mime types 'image/gif', 'image/jpeg', 'image/png', ], 'extensions' => [ // any allowed extensions 'gif', 'jpeg', 'jpg', 'png', ], 'sanitize' => true // escape file & translate to latin 'hash' => 'md5' // save file as hash (default md5) you can use ANY function to handle filename ]); }
Full Handle
<?php if($this->request->hasFiles() !== false) { // get uploader service or \Uploader\Uploader $uploader = $this->di->get('uploader'); // setting up uloader rules $uploader->setRules([ 'directory' => '/files', //or 'dynamic' => '/files/'.$part.'/'.$userId, // added v1.4-beta 'minsize' => 1000, // bytes 'maxsize' => 1000000,// bytes 'mimes' => [ // any allowed mime types 'image/gif', 'image/jpeg', 'image/png', ], 'extensions' => [ // any allowed extensions 'gif', 'jpeg', 'jpg', 'png', ], 'sanitize' => true 'hash' => 'md5' ]); if($uploader->isValid() === true) { $uploader->move(); // upload files array result $uploader->getInfo() // var dump to see upload files } else { $uploader->getErrors(); // var_dump errors } } // you always can remove all files uploaded by one iteration $uploader->truncate(); // added 1.1
Unit Test
Also available in /phpunit directory. Run command to start
php build/phpunit.phar --configuration phpunit.xml.dist --coverage-text
Read logs from phpunit/log
##Issues