96 lines
2.7 KiB
PHP
96 lines
2.7 KiB
PHP
<?php
|
|
require_once 'ZipInterface.php';
|
|
class PhpZipProxyException extends Exception
|
|
{ }
|
|
/**
|
|
* Proxy class for the PHP Zip Extension
|
|
* You need PHP 5.2 at least
|
|
* You need Zip Extension or PclZip library
|
|
* Encoding : ISO-8859-1
|
|
* Last commit by $Author: neveldo $
|
|
* Date - $Date: 2009-05-29 10:05:11 +0200 (ven., 29 mai 2009) $
|
|
* SVN Revision - $Rev: 28 $
|
|
* Id : $Id: odf.php 28 2009-05-29 08:05:11Z neveldo $
|
|
*
|
|
* @copyright GPL License 2008 - Julien Pauli - Cyril PIERRE de GEYER - Anaska (http://www.anaska.com)
|
|
* @license http://www.gnu.org/copyleft/gpl.html GPL License
|
|
* @version 1.3
|
|
*/
|
|
|
|
class PhpZipProxy implements ZipInterface
|
|
{
|
|
protected $zipArchive;
|
|
protected $filename;
|
|
/**
|
|
* Class constructor
|
|
*
|
|
* @throws PhpZipProxyException
|
|
*/
|
|
public function __construct()
|
|
{
|
|
if (! class_exists('ZipArchive')) {
|
|
throw new PhpZipProxyException('Zip extension not loaded - check your php settings, PHP5.2 minimum with zip extension
|
|
is required for using PhpZipProxy'); ;
|
|
}
|
|
$this->zipArchive = new ZipArchive();
|
|
}
|
|
/**
|
|
* Open a Zip archive
|
|
*
|
|
* @param string $filename the name of the archive to open
|
|
* @return true if openning has succeeded
|
|
*/
|
|
public function open($filename)
|
|
{
|
|
$this->filename = $filename;
|
|
return $this->zipArchive->open($filename, ZIPARCHIVE::CREATE);
|
|
}
|
|
/**
|
|
* Retrieve the content of a file within the archive from its name
|
|
*
|
|
* @param string $name the name of the file to extract
|
|
* @return the content of the file in a string
|
|
*/
|
|
public function getFromName($name)
|
|
{
|
|
return $this->zipArchive->getFromName($name);
|
|
}
|
|
/**
|
|
* Add a file within the archive from a string
|
|
*
|
|
* @param string $localname the local path to the file in the archive
|
|
* @param string $contents the content of the file
|
|
* @return true if the file has been successful added
|
|
*/
|
|
public function addFromString($localname, $contents)
|
|
{
|
|
if (file_exists($this->filename) && !is_writable($this->filename)) {
|
|
return false;
|
|
}
|
|
return $this->zipArchive->addFromString($localname, $contents);
|
|
}
|
|
/**
|
|
* Add a file within the archive from a file
|
|
*
|
|
* @param string $filename the path to the file we want to add
|
|
* @param string $localname the local path to the file in the archive
|
|
* @return true if the file has been successful added
|
|
*/
|
|
public function addFile($filename, $localname = null)
|
|
{
|
|
if ((file_exists($this->filename) && !is_writable($this->filename))
|
|
|| !file_exists($filename)) {
|
|
return false;
|
|
}
|
|
return $this->zipArchive->addFile($filename, $localname);
|
|
}
|
|
/**
|
|
* Close the Zip archive
|
|
* @return true
|
|
*/
|
|
public function close()
|
|
{
|
|
return $this->zipArchive->close();
|
|
}
|
|
}
|
|
?>
|