mirror of
https://github.com/phpbb/phpbb.git
synced 2025-08-01 22:40:39 +02:00
[ticket/15305] Add streams
PHPBB3-15305
This commit is contained in:
@@ -736,6 +736,8 @@ $lang = array_merge($lang, array(
|
|||||||
'STORAGE_CANNOT_RENAME' => 'Can not rename file or folder.',
|
'STORAGE_CANNOT_RENAME' => 'Can not rename file or folder.',
|
||||||
'STORAGE_CANNOT_COPY' => 'Can not copy file or folder.',
|
'STORAGE_CANNOT_COPY' => 'Can not copy file or folder.',
|
||||||
'STORAGE_CANNOT_CREATE_DIR' => 'Can not create directory.',
|
'STORAGE_CANNOT_CREATE_DIR' => 'Can not create directory.',
|
||||||
|
'STORAGE_CANNOT_OPEN_FILE' => 'Can not open file.',
|
||||||
|
'STORAGE_CANNOT_CREATE_FILE' => 'Can not create file.',
|
||||||
|
|
||||||
'TB' => 'TB',
|
'TB' => 'TB',
|
||||||
'TERMS_USE' => 'Terms of use',
|
'TERMS_USE' => 'Terms of use',
|
||||||
|
@@ -84,4 +84,26 @@ interface adapter_interface
|
|||||||
* When the file cannot be copied
|
* When the file cannot be copied
|
||||||
*/
|
*/
|
||||||
public function copy($path_orig, $path_dest);
|
public function copy($path_orig, $path_dest);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Reads a file as a stream.
|
||||||
|
*
|
||||||
|
* @param string $path File to read
|
||||||
|
*
|
||||||
|
* @throws \phpbb\storage\exception\exception When cannot open file
|
||||||
|
*
|
||||||
|
* @return resource Returns a file pointer
|
||||||
|
*/
|
||||||
|
public function read_stream($path);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Writes a new file using a stream.
|
||||||
|
*
|
||||||
|
* @param string $path The target file
|
||||||
|
* @param resource $resource The resource
|
||||||
|
*
|
||||||
|
* @throws \phpbb\storage\exception\exception When target file exists
|
||||||
|
* When target file cannot be created
|
||||||
|
*/
|
||||||
|
public function write_stream($path, $resource);
|
||||||
}
|
}
|
||||||
|
@@ -195,4 +195,39 @@ class local implements adapter_interface
|
|||||||
$this->create_dir($path);
|
$this->create_dir($path);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* {@inheritdoc}
|
||||||
|
*/
|
||||||
|
public function read_stream($path)
|
||||||
|
{
|
||||||
|
$stream = @fopen($path, 'rb');
|
||||||
|
|
||||||
|
if (!$stream)
|
||||||
|
{
|
||||||
|
throw new exception('STORAGE_CANNOT_OPEN_FILE', $path);
|
||||||
|
}
|
||||||
|
|
||||||
|
return $stream;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* {@inheritdoc}
|
||||||
|
*/
|
||||||
|
public function write_stream($path, $resource)
|
||||||
|
{
|
||||||
|
if ($this->exists($path))
|
||||||
|
{
|
||||||
|
throw new exception('STORAGE_FILE_EXISTS', $path);
|
||||||
|
}
|
||||||
|
|
||||||
|
$stream = @fopen($path, 'w+b');
|
||||||
|
|
||||||
|
if (!$stream)
|
||||||
|
{
|
||||||
|
throw new exception('STORAGE_CANNOT_CREATE_FILE', $path);
|
||||||
|
}
|
||||||
|
|
||||||
|
stream_copy_to_stream($resource, $stream);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
@@ -140,4 +140,32 @@ class storage
|
|||||||
{
|
{
|
||||||
$this->get_adapter()->copy($path_orig, $path_dest);
|
$this->get_adapter()->copy($path_orig, $path_dest);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Reads a file as a stream.
|
||||||
|
*
|
||||||
|
* @param string $path File to read
|
||||||
|
*
|
||||||
|
* @throws \phpbb\storage\exception\exception When cannot open file
|
||||||
|
*
|
||||||
|
* @return resource Returns a file pointer
|
||||||
|
*/
|
||||||
|
public function read_stream($path)
|
||||||
|
{
|
||||||
|
$this->get_adapter()->read_stream($path);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Writes a new file using a stream.
|
||||||
|
*
|
||||||
|
* @param string $path The target file
|
||||||
|
* @param resource $resource The resource
|
||||||
|
*
|
||||||
|
* @throws \phpbb\storage\exception\exception When target file exists
|
||||||
|
* When target file cannot be created
|
||||||
|
*/
|
||||||
|
public function write_stream($path, $resource)
|
||||||
|
{
|
||||||
|
$this->get_adapter()->write_stream($path, $resource);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
Reference in New Issue
Block a user