Package Data | |
---|---|
Maintainer Username: | zorx |
Maintainer Contact: | github@nilsplaschke.de (Nils Plaschke) |
Package Create Date: | 2016-04-18 |
Package Last Update: | 2016-06-04 |
Language: | PHP |
License: | Apache2 |
Last Refreshed: | 2024-12-22 03:01:32 |
Package Statistics | |
---|---|
Total Downloads: | 1,345 |
Monthly Downloads: | 0 |
Daily Downloads: | 0 |
Total Stars: | 1 |
Total Watchers: | 3 |
Total Forks: | 0 |
Total Open Issues: | 0 |
#Zipper
This is a simple Wrapper around the ZipArchive methods with some handy functions.
##Installation
composer.json
"chumper/zipper": "0.6.x"
"chumper/zipper": "0.5.x"
Run composer update
Go to app/config/app.php
'Chumper\Zipper\ZipperServiceProvider'
'Zipper' => 'Chumper\Zipper\Zipper'
You can now access Zipper with the Zipper
alias.
##Simple example
$files = glob('public/files/*');
Zipper::make('public/test.zip')->add($files);
test.zip
in the project route folder but in the example above we changed it to project_route/public/
.####Another example
$zipper = new \Chumper\Zipper\Zipper;
$zipper->make('test.zip')->folder('test')->add('composer.json');
$zipper->zip('test.zip')->folder('test')->add('composer.json','test');
$zipper->remove('composer.lock');
$zipper->folder('mySuperPackage')->add(
array(
'vendor',
'composer.json'
),
);
$zipper->getFileContent('mySuperPackage/composer.json');
$zipper->make('test.zip')->extractTo('',array('mySuperPackage/composer.json'),Zipper::WHITELIST);
You can easily chain most functions, except getFileContent
, getStatus
, close
and extractTo
which must come at the end of the chain.
The main reason I wrote this little package is the extractTo
method since it allows you to be very flexible when extracting zips. So you can for example implement an update method which will just override the changed files.
##Functions
make($pathToFile)
Create
or Open
a zip archive; if the file does not exists it will create a new one.
It will return the Zipper instance so you can chain easily.
add($files/folder)
You can add and array of Files, or a Folder which all the files in that folder will then be added, so from the first example we could instead do something like $files = 'public/files/';
.
addString($filename, $content)
add a single file to the zip by specifying a name and content as strings.
remove($file/s)
removes a single file or an array of files from the zip.
folder($folder)
Specify a folder to 'add files to' or 'remove files from' from the zip, example
Zipper::make('test.zip')->folder('test')->add('composer.json');
Zipper::make('test.zip')->folder('test')->remove('composer.json');
home()
Resets the folder pointer.
zip($fileName)
Uses the ZipRepository for file handling.
getFileContent($filePath)
get the content of a file in the zip. This will return the content or false.
getStatus()
get the opening status of the zip as integer.
close()
closes the zip and writes all changes.
extractTo($path)
Extracts the content of the zip archive to the specified location, for example
Zipper::make('test.zip')->folder('test')->extractTo('foo');
This will go into the folder test
in the zip file and extract the content of that folder only to the folder foo
, this is equal to using the Zipper::WHITELIST
.
This command is really nice to get just a part of the zip file, you can also pass a 2nd & 3rd param to specify a single or an array of files that will be
white listed
Zipper::WHITELIST
Zipper::make('test.zip')->extractTo('public', array('vendor'), Zipper::WHITELIST);
Which will extract the test.zip
into the public
folder but only the folder vendor
inside the zip will be extracted.
or black listed
Zipper::BLACKLIST
Zipper::make('test.zip')->extractTo('public', array('vendor'), Zipper::BLACKLIST);
Which will extract the test.zip
into the public
folder except the folder vendor
inside the zip will not be extracted.
##Development
Maybe it is a good idea to add other compression functions like rar, phar or bzip2 etc... Everything is setup for that, if you want just fork and develop further.
If you need other functions or got errors, please leave an issue on github.