2024-07-10 18:28:19 +05:45
|
|
|
Usage with FlySystem
|
|
|
|
===============
|
|
|
|
|
|
|
|
For saving or uploading the generated zip, you can use the
|
|
|
|
`Flysystem <https://flysystem.thephpleague.com>`_ package, and its many
|
|
|
|
adapters.
|
|
|
|
|
|
|
|
For that you will need to provide another stream than the ``php://output``
|
|
|
|
default one, and pass it to Flysystem ``putStream`` method.
|
|
|
|
|
|
|
|
.. code-block:: php
|
|
|
|
|
|
|
|
// Open Stream only once for read and write since it's a memory stream and
|
|
|
|
// the content is lost when closing the stream / opening another one
|
|
|
|
$tempStream = fopen('php://memory', 'w+');
|
|
|
|
|
|
|
|
// Create Zip Archive
|
2024-09-29 16:59:27 +05:45
|
|
|
$zipStream = new ZipStream(
|
|
|
|
outputStream: $tempStream,
|
|
|
|
outputName: 'test.zip',
|
|
|
|
);
|
2024-07-10 18:28:19 +05:45
|
|
|
$zipStream->addFile('test.txt', 'text');
|
|
|
|
$zipStream->finish();
|
|
|
|
|
2024-09-29 16:59:27 +05:45
|
|
|
// Store File
|
|
|
|
// (see Flysystem documentation, and all its framework integration)
|
|
|
|
// Can be any adapter (AWS, Google, Ftp, etc.)
|
|
|
|
$adapter = new Local(__DIR__.'/path/to/folder');
|
2024-07-10 18:28:19 +05:45
|
|
|
$filesystem = new Filesystem($adapter);
|
|
|
|
|
2024-09-29 16:59:27 +05:45
|
|
|
$filesystem->writeStream('test.zip', $tempStream)
|
2024-07-10 18:28:19 +05:45
|
|
|
|
|
|
|
// Close Stream
|
2024-09-29 16:59:27 +05:45
|
|
|
fclose($tempStream);
|