Browse Source

Issue #1848 EmitFileEvent.php: Call to undefined function getFileUri() (#838)

Explicitly check for function before it is called.
pull/841/head
Alexander O'Neill 3 years ago committed by GitHub
parent
commit
492be9fdef
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
  1. 24
      src/Plugin/Action/EmitFileEvent.php

24
src/Plugin/Action/EmitFileEvent.php

@ -105,18 +105,22 @@ class EmitFileEvent extends EmitEvent {
* {@inheritdoc} * {@inheritdoc}
*/ */
protected function generateData(EntityInterface $entity) { protected function generateData(EntityInterface $entity) {
$uri = $entity->getFileUri();
$scheme = StreamWrapperManager::getScheme($uri);
$flysystem_config = Settings::get('flysystem');
$data = parent::generateData($entity); $data = parent::generateData($entity);
if (isset($flysystem_config[$scheme]) && $flysystem_config[$scheme]['driver'] == 'fedora') {
// Fdora $uri for files may contain ':///' so we need to replace // This function is called on Media and File entity types.
// the three / with two. if (method_exists($entity, 'getFileUri')) {
if (strpos($uri, $scheme . ':///') !== FALSE) { $uri = $entity->getFileUri();
$uri = str_replace($scheme . ':///', $scheme . '://', $uri); $scheme = StreamWrapperManager::getScheme($uri);
$flysystem_config = Settings::get('flysystem');
if (isset($flysystem_config[$scheme]) && $flysystem_config[$scheme]['driver'] == 'fedora') {
// Fdora $uri for files may contain ':///' so we need to replace
// the three / with two.
if (strpos($uri, $scheme . ':///') !== FALSE) {
$uri = str_replace($scheme . ':///', $scheme . '://', $uri);
}
$data['fedora_uri'] = str_replace("$scheme://", $flysystem_config[$scheme]['config']['root'], $uri);
} }
$data['fedora_uri'] = str_replace("$scheme://", $flysystem_config[$scheme]['config']['root'], $uri);
} }
return $data; return $data;
} }

Loading…
Cancel
Save