Browse Source

Catch Flysystem exceptions and report (#762)

pull/763/head
Jared Whiklo 5 years ago committed by GitHub
parent
commit
2a1024c19a
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
  1. 31
      src/Flysystem/Fedora.php

31
src/Flysystem/Fedora.php

@ -10,6 +10,7 @@ use Drupal\flysystem\Plugin\FlysystemPluginInterface;
use Drupal\flysystem\Plugin\FlysystemUrlTrait; use Drupal\flysystem\Plugin\FlysystemUrlTrait;
use Drupal\islandora\Flysystem\Adapter\FedoraAdapter; use Drupal\islandora\Flysystem\Adapter\FedoraAdapter;
use Drupal\jwt\Authentication\Provider\JwtAuth; use Drupal\jwt\Authentication\Provider\JwtAuth;
use GuzzleHttp\Exception\ConnectException;
use GuzzleHttp\HandlerStack; use GuzzleHttp\HandlerStack;
use GuzzleHttp\Client; use GuzzleHttp\Client;
use Islandora\Chullo\IFedoraApi; use Islandora\Chullo\IFedoraApi;
@ -123,20 +124,28 @@ class Fedora implements FlysystemPluginInterface, ContainerFactoryPluginInterfac
*/ */
public function ensure($force = FALSE) { public function ensure($force = FALSE) {
// Check fedora root for sanity. // Check fedora root for sanity.
$response = $this->fedora->getResourceHeaders(''); try {
$response = $this->fedora->getResourceHeaders('');
if ($response->getStatusCode() != 200) { $statusCode = $response->getStatusCode();
return [[ $message = '%url returned %status';
'severity' => RfcLogLevel::ERROR, }
'message' => '%url returned %status', catch (ConnectException $e) {
'context' => [ // Fedora is unavailable.
'%url' => $this->fedora->getBaseUri(), $message = '%url is unavailable, cannot connect.';
'%status' => $response->getStatusCode(), $statusCode = 500;
}
if ($statusCode != 200) {
return [
[
'severity' => RfcLogLevel::ERROR,
'message' => $message,
'context' => [
'%url' => $this->fedora->getBaseUri(),
'%status' => $statusCode,
],
], ],
],
]; ];
} }
return []; return [];
} }

Loading…
Cancel
Save