mirror of
https://github.com/phpbb/phpbb.git
synced 2025-04-09 02:12:44 +02:00
[ticket/15305] Add streams
PHPBB3-15305
This commit is contained in:
parent
c17db782f8
commit
8ffb14b305
@ -736,6 +736,8 @@ $lang = array_merge($lang, array(
|
||||
'STORAGE_CANNOT_RENAME' => 'Can not rename file or folder.',
|
||||
'STORAGE_CANNOT_COPY' => 'Can not copy file or folder.',
|
||||
'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',
|
||||
'TERMS_USE' => 'Terms of use',
|
||||
|
@ -84,4 +84,26 @@ interface adapter_interface
|
||||
* When the file cannot be copied
|
||||
*/
|
||||
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);
|
||||
}
|
||||
}
|
||||
|
||||
/**
|
||||
* {@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);
|
||||
}
|
||||
|
||||
/**
|
||||
* 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);
|
||||
}
|
||||
}
|
||||
|
Loading…
x
Reference in New Issue
Block a user