Laravel ZIP file content validator
Custom Laravel validation rule for checking ZIP file content.
zipextension enabled
You can install the package via composer:
composer require orkhanahmadov/laravel-zip-validator
Use
ZipContentrule with list of required files.
use Orkhanahmadov\ZipValidator\Rules\ZipContent;public function rules() { return [ 'file' => [ 'required', 'file', 'mimes:zip', new ZipContent('thumb.jpg', 'assets/logo.png'), ], ]; }
Pass list of required files/folders to the constructor of the validator.
You can pass files as different constructor arguments or as array. If files are nested inside folders, pass relative path to file.
Validator will fail if any of the passed files does not exist in ZIP archive.
Validator also allows checking maximum size of each file inside ZIP archive.
Simply pass file name as array key and maximum size as value:
php new ZipContent(['thumb.jpg' => 100000]);
Validator in above example will look for
thumb.jpgfile with maximum size of 100000 bytes (100KB).
You can also mix multiple files with name-only or name+size validation:
php new ZipContent(['thumb.jpg' => 100000, 'logo.png']);
You can also pass multiple files with
|symbol, if any of them exist in ZIP file validator will succeed.
php new ZipContent('thumb.jpg|thumb.png|thumb.svg');
Validator in above example will look if
thumb.jpgor
thumb.pngor
thumb.svgfile exists in ZIP.
Of course, you can also validate file size with "OR" validation:
php new ZipContent(['thumb.jpg|thumb.png' => 100000]);
Above example will look if
thumb.jpgor
thumb.pngfile exists in ZIP and its file size is not bigger than 100000 bytes (100KB).
Important to keep in mind that when using "OR" validation with additional file size validation, validator will compare file size with the first matching element in ZIP archive.
By default, validator only checks if file with given name exists, it will return true even if file with matching name is empty (has size of 0 bytes).
You can pass array of files as first argument and
falseas second argument to constructor if you want validator to reject files with 0 bytes.
php new ZipContent(['thumb.jpg', 'style.css'], false);
composer test
Please see CHANGELOG for more information what has changed recently.
Please see CONTRIBUTING for details.
If you discover any security related issues, please email [email protected] instead of using the issue tracker.
The MIT License (MIT). Please see License File for more information.