From be9936bf1ef5d3aaab756a7b45c563f8132ce150 Mon Sep 17 00:00:00 2001 From: nruest Date: Wed, 16 Aug 2023 20:46:42 -0400 Subject: [PATCH] Allow OSD to show on restricted paged objects. - Alternate implementation of https://github.com/Islandora/openseadragon/pull/51 - Resolves https://github.com/yorkulibraries/york_drupal_theme/issues/78 --- openseadragon.module | 4 +++- src/IIIFManifestParser.php | 15 +++++++++++++-- 2 files changed, 16 insertions(+), 3 deletions(-) diff --git a/openseadragon.module b/openseadragon.module index 161e42d..caff59b 100644 --- a/openseadragon.module +++ b/openseadragon.module @@ -89,6 +89,7 @@ function template_preprocess_openseadragon_formatter(&$variables) { $variables['#attached']['library'] = [ 'openseadragon/init', ]; + $access_token = \Drupal::service('jwt.authentication.jwt')->generateToken(); $variables['#attached']['drupalSettings']['openseadragon'][$openseadragon_viewer_id] = [ 'basePath' => Url::fromUri($iiif_address), 'fitToAspectRatio' => $viewer_settings['fit_to_aspect_ratio'], @@ -110,11 +111,12 @@ function template_preprocess_openseadragon_formatter(&$variables) { * Implements template_preprocess_HOOK(). */ function template_preprocess_openseadragon_iiif_manifest_block(&$variables) { + $access_token = \Drupal::service('jwt.authentication.jwt')->generateToken(); $cache_meta = CacheableMetadata::createFromRenderArray($variables); // Get the tile sources from the manifest. $parser = \Drupal::service('openseadragon.manifest_parser'); - $tile_sources = $parser->getTileSources($variables['iiif_manifest_url']); + $tile_sources = $parser->getTileSources($variables['iiif_manifest_url'], $access_token); if (empty($tile_sources)) { $cache_meta->applyTo($variables); diff --git a/src/IIIFManifestParser.php b/src/IIIFManifestParser.php index fc98f6a..e360aef 100644 --- a/src/IIIFManifestParser.php +++ b/src/IIIFManifestParser.php @@ -64,11 +64,13 @@ public function __construct( * * @param string $manifest_url * The location of the IIIF manifest, which can include tokens. + * @param string $access_token + * The JWT Access token. * * @return array * The URLs of all the tile sources in a manifest. */ - public function getTileSources($manifest_url) { + public function getTileSources($manifest_url, $access_token = NULL) { // Try to construct the URL out of a tokenized string // if the node is available. @@ -85,7 +87,16 @@ public function getTileSources($manifest_url) { try { // Request the manifest. - $manifest_response = $this->httpClient->get($manifest_url); + if (empty($access_token)) { + $manifest_response = $this->httpClient->get($manifest_url); + } + else { + $manifest_response = $this->httpClient->request('GET', $manifest_url, [ + 'headers' => [ + 'Authorization' => 'Bearer ' . $access_token, + ], + ]); + } // Decode the manifest json. $manifest_string = (string) $manifest_response->getBody();