abstract class LocalReadOnlyStream in System stream wrapper 8
Defines a read-only Drupal stream wrapper base class for local files.
This class extends the complete stream wrapper implementation in LocalStream. URIs such as "public://example.txt" are expanded to a normal filesystem path such as "sites/default/files/example.txt" and then PHP filesystem functions are invoked.
Drupal\Core\StreamWrapper\LocalReadOnlyStream implementations need to implement at least the getDirectoryPath() and getExternalUrl() methods.
Hierarchy
- class \Drupal\system_stream_wrapper\StreamWrapper\StreamWrapperBase implements StreamWrapperInterface- class \Drupal\system_stream_wrapper\StreamWrapper\LocalStream uses LocalStreamTrait- class \Drupal\system_stream_wrapper\StreamWrapper\LocalReadOnlyStream
 
 
- class \Drupal\system_stream_wrapper\StreamWrapper\LocalStream uses LocalStreamTrait
Expanded class hierarchy of LocalReadOnlyStream
File
- src/StreamWrapper/ LocalReadOnlyStream.php, line 16 
Namespace
Drupal\system_stream_wrapper\StreamWrapperView source
abstract class LocalReadOnlyStream extends LocalStream {
  /**
   * Support for fopen(), file_get_contents(), etc.
   *
   * Any write modes will be rejected, as this is a read-only stream wrapper.
   *
   * @param string $uri
   *   A string containing the URI to the file to open.
   * @param int $mode
   *   The file mode, only strict readonly modes are supported.
   * @param int $options
   *   A bit mask of STREAM_USE_PATH and STREAM_REPORT_ERRORS.
   * @param string $opened_path
   *   A string containing the path actually opened.
   *
   * @return bool
   *   TRUE if $mode denotes a readonly mode and the file was opened
   *   successfully, FALSE otherwise.
   *
   * @see http://php.net/manual/streamwrapper.stream-open.php
   */
  public function stream_open($uri, $mode, $options, &$opened_path) {
    if (!in_array($mode, array(
      'r',
      'rb',
      'rt',
    ))) {
      if ($options & STREAM_REPORT_ERRORS) {
        trigger_error('stream_open() write modes not supported for read-only stream wrappers', E_USER_WARNING);
      }
      return FALSE;
    }
    return parent::stream_open($uri, $mode, $options, $opened_path);
  }
  /**
   * Support for flock().
   *
   * An exclusive lock attempt will be rejected, as this is a read-only stream
   * wrapper.
   *
   * @param int $operation
   *   One of the following:
   *   - LOCK_SH to acquire a shared lock (reader).
   *   - LOCK_EX to acquire an exclusive lock (writer).
   *   - LOCK_UN to release a lock (shared or exclusive).
   *   - LOCK_NB added as a bitmask if you don't want flock() to block while
   *     locking (not supported on Windows).
   *
   * @return bool
   *   Return FALSE for an exclusive lock (writer), as this is a read-only
   *   stream wrapper.  Return the result of flock() for other valid operations.
   *   Defaults to TRUE if an invalid operation is passed.
   *
   * @see http://php.net/manual/streamwrapper.stream-lock.php
   */
  public function stream_lock($operation) {
    // Disallow exclusive lock or non-blocking lock requests
    if (in_array($operation, array(
      LOCK_EX,
      LOCK_EX | LOCK_NB,
    ))) {
      trigger_error('stream_lock() exclusive lock operations not supported for read-only stream wrappers', E_USER_WARNING);
      return FALSE;
    }
    if (in_array($operation, array(
      LOCK_SH,
      LOCK_UN,
      LOCK_SH | LOCK_NB,
    ))) {
      return flock($this->handle, $operation);
    }
    return TRUE;
  }
  /**
   * Support for fwrite(), file_put_contents() etc.
   *
   * Data will not be written as this is a read-only stream wrapper.
   *
   * @param string $data
   *   The string to be written.
   *
   * @return bool
   *   FALSE as data will not be written.
   *
   * @see http://php.net/manual/en/streamwrapper.stream-write.php
   */
  public function stream_write($data) {
    trigger_error('stream_write() not supported for read-only stream wrappers', E_USER_WARNING);
    return FALSE;
  }
  /**
   * Support for fflush().
   *
   * Nothing will be output to the file, as this is a read-only stream wrapper.
   * However as stream_flush is called during stream_close we should not trigger
   * an error.
   *
   * @return bool
   *   FALSE, as no data will be stored.
   *
   * @see http://php.net/manual/streamwrapper.stream-flush.php
   */
  public function stream_flush() {
    return FALSE;
  }
  /**
   * {@inheritdoc}
   *
   * Does not change meta data as this is a read-only stream wrapper.
   */
  public function stream_metadata($uri, $option, $value) {
    trigger_error('stream_metadata() not supported for read-only stream wrappers', E_USER_WARNING);
    return FALSE;
  }
  /**
   * {@inheritdoc}
   */
  public function stream_truncate($new_size) {
    trigger_error('stream_truncate() not supported for read-only stream wrappers', E_USER_WARNING);
    return FALSE;
  }
  /**
   * Support for unlink().
   *
   * The file will not be deleted from the stream as this is a read-only stream
   * wrapper.
   *
   * @param string $uri
   *   A string containing the uri to the resource to delete.
   *
   * @return bool
   *   TRUE so that file_delete() will remove db reference to file. File is not
   *   actually deleted.
   *
   * @see http://php.net/manual/en/streamwrapper.unlink.php
   */
  public function unlink($uri) {
    trigger_error('unlink() not supported for read-only stream wrappers', E_USER_WARNING);
    return TRUE;
  }
  /**
   * Support for rename().
   *
   * The file will not be renamed as this is a read-only stream wrapper.
   *
   * @param string $from_uri,
   *   The uri to the file to rename.
   * @param string $to_uri
   *   The new uri for file.
   *
   * @return bool
   *   FALSE as file will never be renamed.
   *
   * @see http://php.net/manual/en/streamwrapper.rename.php
   */
  public function rename($from_uri, $to_uri) {
    trigger_error('rename() not supported for read-only stream wrappers', E_USER_WARNING);
    return FALSE;
  }
  /**
   * Support for mkdir().
   *
   * Directory will never be created as this is a read-only stream wrapper.
   *
   * @param string $uri
   *   A string containing the URI to the directory to create.
   * @param int $mode
   *   Permission flags - see mkdir().
   * @param int $options
   *   A bit mask of STREAM_REPORT_ERRORS and STREAM_MKDIR_RECURSIVE.
   *
   * @return bool
   *   FALSE as directory will never be created.
   *
   * @see http://php.net/manual/en/streamwrapper.mkdir.php
   */
  public function mkdir($uri, $mode, $options) {
    trigger_error('mkdir() not supported for read-only stream wrappers', E_USER_WARNING);
    return FALSE;
  }
  /**
   * Support for rmdir().
   *
   * Directory will never be deleted as this is a read-only stream wrapper.
   *
   * @param string $uri
   *   A string containing the URI to the directory to delete.
   * @param int $options
   *   A bit mask of STREAM_REPORT_ERRORS.
   *
   * @return bool
   *   FALSE as directory will never be deleted.
   *
   * @see http://php.net/manual/en/streamwrapper.rmdir.php
   */
  public function rmdir($uri, $options) {
    trigger_error('rmdir() not supported for read-only stream wrappers', E_USER_WARNING);
    return FALSE;
  }
}Members
| Name   | Modifiers | Type | Description | Overrides | 
|---|---|---|---|---|
| LocalReadOnlyStream:: | public | function | Support for mkdir(). Overrides LocalStream:: | |
| LocalReadOnlyStream:: | public | function | Support for rename(). Overrides LocalStream:: | |
| LocalReadOnlyStream:: | public | function | Support for rmdir(). Overrides LocalStream:: | |
| LocalReadOnlyStream:: | public | function | Support for fflush(). Overrides LocalStream:: | |
| LocalReadOnlyStream:: | public | function | Support for flock(). Overrides LocalStream:: | |
| LocalReadOnlyStream:: | public | function | Does not change meta data as this is a read-only stream wrapper. Overrides LocalStream:: | |
| LocalReadOnlyStream:: | public | function | Support for fopen(), file_get_contents(), etc. Overrides LocalStream:: | |
| LocalReadOnlyStream:: | public | function | Truncate stream. Overrides LocalStream:: | |
| LocalReadOnlyStream:: | public | function | Support for fwrite(), file_put_contents() etc. Overrides LocalStream:: | |
| LocalReadOnlyStream:: | public | function | Support for unlink(). Overrides LocalStream:: | |
| LocalStream:: | public | function | Support for closedir(). Overrides PhpStreamWrapperInterface:: | |
| LocalStream:: | public | function | Support for opendir(). Overrides PhpStreamWrapperInterface:: | |
| LocalStream:: | public | function | Support for readdir(). Overrides PhpStreamWrapperInterface:: | |
| LocalStream:: | public | function | Support for rewinddir(). Overrides PhpStreamWrapperInterface:: | |
| LocalStream:: | abstract protected | function | Gets the path that the wrapper is responsible for. | 3 | 
| LocalStream:: | protected | function | Returns the canonical absolute path of the URI, if possible. | |
| LocalStream:: | public static | function | Returns the type of stream wrapper. Overrides StreamWrapperInterface:: | 1 | 
| LocalStream:: | public | function | Returns canonical, absolute path of the resource. Overrides StreamWrapperInterface:: | |
| LocalStream:: | public | function | Retrieve the underlying stream resource. Overrides PhpStreamWrapperInterface:: | |
| LocalStream:: | public | function | Support for fclose(). Overrides PhpStreamWrapperInterface:: | |
| LocalStream:: | public | function | Support for feof(). Overrides PhpStreamWrapperInterface:: | |
| LocalStream:: | public | function | Support for fread(), file_get_contents() etc. Overrides PhpStreamWrapperInterface:: | |
| LocalStream:: | public | function | Seeks to specific location in a stream. Overrides PhpStreamWrapperInterface:: | |
| LocalStream:: | public | function | Since Windows systems do not allow it and it is not needed for most use
cases anyway, this method is not supported on local files and will trigger
an error and return false. If needed, custom subclasses can provide
OS-specific implementations for… Overrides PhpStreamWrapperInterface:: | |
| LocalStream:: | public | function | Support for fstat(). Overrides PhpStreamWrapperInterface:: | |
| LocalStream:: | public | function | Support for ftell(). Overrides PhpStreamWrapperInterface:: | |
| LocalStream:: | public | function | Support for stat(). Overrides PhpStreamWrapperInterface:: | |
| LocalStreamTrait:: | public | function | Gets the name of the directory from a given path. | 1 | 
| LocalStreamTrait:: | protected | function | Returns the local writable target of the resource within the stream. | 1 | 
| StreamWrapperBase:: | public | property | Stream context resource. | |
| StreamWrapperBase:: | public | property | A generic resource handle. | |
| StreamWrapperBase:: | protected | property | Instance URI (stream). | |
| StreamWrapperBase:: | function | Returns the stream resource URI. Overrides StreamWrapperInterface:: | ||
| StreamWrapperBase:: | function | Sets the absolute stream resource URI. Overrides StreamWrapperInterface:: | ||
| StreamWrapperInterface:: | constant | A filter that matches all wrappers. | ||
| StreamWrapperInterface:: | public | function | Returns the description of the stream wrapper for use in the UI. | 6 | 
| StreamWrapperInterface:: | public | function | Returns a web accessible URL for the resource. | 6 | 
| StreamWrapperInterface:: | public | function | Returns the name of the stream wrapper for use in the UI. | 6 | 
| StreamWrapperInterface:: | constant | Defines the stream wrapper bit flag for a hidden file. | ||
| StreamWrapperInterface:: | constant | Refers to a local file system location. | ||
| StreamWrapperInterface:: | constant | Hidden, readable and writable using local files. | ||
| StreamWrapperInterface:: | constant | Visible, readable and writable using local files. | ||
| StreamWrapperInterface:: | constant | This is the default 'type' flag. This does not include StreamWrapperInterface::LOCAL, because PHP grants a greater trust level to local files (for example, they can be used in an "include" statement, regardless of the… | ||
| StreamWrapperInterface:: | constant | Wrapper is readable (almost always true). | ||
| StreamWrapperInterface:: | constant | Visible and read-only. | ||
| StreamWrapperInterface:: | constant | Exposed in the UI and potentially web accessible. | ||
| StreamWrapperInterface:: | constant | Wrapper is writable. | ||
| StreamWrapperInterface:: | constant | Visible, readable and writable. | 
