changeset 275:801790c81f20 iiif

configuration options of IIIF
author Sebastien Jodogne <s.jodogne@gmail.com>
date Wed, 12 Jul 2023 12:35:04 +0200
parents 2805246064aa
children ef8a673b5fb9
files ViewerPlugin/IIIF.cpp ViewerPlugin/OrthancExplorer.js ViewerPlugin/Plugin.cpp
diffstat 3 files changed, 47 insertions(+), 25 deletions(-) [+]
line wrap: on
line diff
--- a/ViewerPlugin/IIIF.cpp	Wed Jul 12 11:24:56 2023 +0200
+++ b/ViewerPlugin/IIIF.cpp	Wed Jul 12 12:35:04 2023 +0200
@@ -445,7 +445,7 @@
 
   const std::string sopClassUid = Orthanc::Toolbox::StripSpaces(oneInstance[SOP_CLASS_UID].asString());
 
-  const std::string base = iiifPublicUrl_ + seriesId;
+  const std::string base = iiifPublicUrl_ + "series/" + seriesId;
 
   Json::Value manifest;
   manifest["@context"] = "http://iiif.io/api/presentation/3/context.json";
@@ -613,7 +613,7 @@
 
   OrthancPlugins::RegisterRestCallback<ServeIIIFTiledImageInfo>("/wsi/iiif/tiles/([0-9a-f-]+)/info.json", true);
   OrthancPlugins::RegisterRestCallback<ServeIIIFTiledImageTile>("/wsi/iiif/tiles/([0-9a-f-]+)/([0-9a-z,:]+)/([0-9a-z,!:]+)/([0-9,!]+)/([a-z]+)\\.([a-z]+)", true);
-  OrthancPlugins::RegisterRestCallback<ServeIIIFManifest>("/wsi/iiif/([0-9a-f-]+)/manifest.json", true);
+  OrthancPlugins::RegisterRestCallback<ServeIIIFManifest>("/wsi/iiif/series/([0-9a-f-]+)/manifest.json", true);
   OrthancPlugins::RegisterRestCallback<ServeIIIFFrameInfo>("/wsi/iiif/frames/([0-9a-f-]+)/([0-9]+)/info.json", true);
   OrthancPlugins::RegisterRestCallback<ServeIIIFFrameImage>("/wsi/iiif/frames/([0-9a-f-]+)/([0-9]+)/full/max/0/default.jpg", true);
 }
--- a/ViewerPlugin/OrthancExplorer.js	Wed Jul 12 11:24:56 2023 +0200
+++ b/ViewerPlugin/OrthancExplorer.js	Wed Jul 12 12:35:04 2023 +0200
@@ -74,7 +74,7 @@
         }
       }
 
-      if (${SERVE_IIIF}) {
+      if (${ENABLE_IIIF}) {
         var b = $('<a>')
             .attr('data-role', 'button')
             .attr('href', '#')
@@ -90,7 +90,7 @@
         b.click(function(e) {
           if ($.mobile.pageData) {
             e.preventDefault();
-            var url = new URL('${IIIF_PUBLIC_URL}' + seriesId + '/manifest.json', window.location.href);
+            var url = new URL('../wsi/iiif/series/' + seriesId + '/manifest.json', window.location.href);
             navigator.clipboard.writeText(url.href);
             $(e.target).closest('li').buttonMarkup({ icon: 'check' });
           }
@@ -110,7 +110,7 @@
         b.insertAfter($('#series-info'));
         b.click(function() {
           if ($.mobile.pageData) {
-            window.open('../wsi/app/mirador.html?iiif-content=../iiif/' + seriesId + '/manifest.json');
+            window.open('../wsi/app/mirador.html?iiif-content=../iiif/series/' + seriesId + '/manifest.json');
           }
         });
       }
--- a/ViewerPlugin/Plugin.cpp	Wed Jul 12 11:24:56 2023 +0200
+++ b/ViewerPlugin/Plugin.cpp	Wed Jul 12 12:35:04 2023 +0200
@@ -293,15 +293,23 @@
     OrthancPlugins::RegisterRestCallback<ServePyramid>("/wsi/pyramids/([0-9a-f-]+)", true);
     OrthancPlugins::RegisterRestCallback<ServeTile>("/wsi/tiles/([0-9a-f-]+)/([0-9-]+)/([0-9-]+)/([0-9-]+)", true);
 
-    bool serveMirador;
-    bool serveOpenSeadragon;
-    bool serveIIIF = true;  // TODO => CONFIG
+    OrthancPlugins::OrthancConfiguration mainConfiguration;
+
+    OrthancPlugins::OrthancConfiguration wsiConfiguration;
+    mainConfiguration.GetSection(wsiConfiguration, "WholeSlideImaging");
+
+    const bool enableIIIF = wsiConfiguration.GetBooleanValue("EnableIIIF", true);
+    bool serveMirador = false;
+    bool serveOpenSeadragon = false;
     std::string iiifPublicUrl;
 
-    if (serveIIIF)
+    if (enableIIIF)
     {
-      // TODO => CONFIG
-      iiifPublicUrl = "http://localhost:8042/wsi/iiif";
+      if (!wsiConfiguration.LookupStringValue(iiifPublicUrl, "OrthancPublicURL"))
+      {
+        unsigned int port = mainConfiguration.GetUnsignedIntegerValue("HttpPort", 8042);
+        iiifPublicUrl = "http://localhost:" + boost::lexical_cast<std::string>(port) + "/";
+      }
 
       if (iiifPublicUrl.empty() ||
           iiifPublicUrl[iiifPublicUrl.size() - 1] != '/')
@@ -309,26 +317,41 @@
         iiifPublicUrl += "/";
       }
 
-      InitializeIIIF(iiifPublicUrl);
-      SetIIIFForcePowersOfTwoScaleFactors(true);  // TODO => CONFIG
+      iiifPublicUrl += "wsi/iiif/";
 
-      serveMirador = true;  // TODO => CONFIG
-      serveOpenSeadragon = true;  // TODO => CONFIG
+      InitializeIIIF(iiifPublicUrl);
+
+      serveMirador = wsiConfiguration.GetBooleanValue("ServeMirador", false);
+      serveOpenSeadragon = wsiConfiguration.GetBooleanValue("ServeOpenSeadragon", false);
 
-      if (serveMirador)
+      bool value;
+      if (wsiConfiguration.LookupBooleanValue(value, "ForcePowersOfTwoScaleFactors"))
       {
-        OrthancPlugins::RegisterRestCallback<ServeFile>("/wsi/app/(mirador.html)", true);
+        SetIIIFForcePowersOfTwoScaleFactors(value);
       }
-
-      if (serveOpenSeadragon)
+      else
       {
-        OrthancPlugins::RegisterRestCallback<ServeFile>("/wsi/app/(openseadragon.html)", true);
+        /**
+         * By default, compatibility mode is disabled. However, if
+         * Mirador or OSD are enabled, compatibility mode is
+         * automatically enabled to enhance user experience, at least
+         * until issue 2379 of OSD is solved:
+         * https://github.com/openseadragon/openseadragon/issues/2379
+         **/
+        SetIIIFForcePowersOfTwoScaleFactors(serveMirador || serveOpenSeadragon);
       }
     }
-    else
+
+    LOG(WARNING) << "Support of IIIF is " << (enableIIIF ? "enabled" : "disabled") << " in the whole-slide imaging plugin";
+
+    if (serveMirador)
     {
-      serveMirador = false;
-      serveOpenSeadragon = false;
+      OrthancPlugins::RegisterRestCallback<ServeFile>("/wsi/app/(mirador.html)", true);
+    }
+
+    if (serveOpenSeadragon)
+    {
+      OrthancPlugins::RegisterRestCallback<ServeFile>("/wsi/app/(openseadragon.html)", true);
     }
 
     {
@@ -338,10 +361,9 @@
       Orthanc::EmbeddedResources::GetFileResource(explorer, Orthanc::EmbeddedResources::ORTHANC_EXPLORER);
 
       std::map<std::string, std::string> dictionary;
-      dictionary["SERVE_IIIF"] = (serveIIIF ? "true" : "false");
+      dictionary["ENABLE_IIIF"] = (enableIIIF ? "true" : "false");
       dictionary["SERVE_MIRADOR"] = (serveMirador ? "true" : "false");
       dictionary["SERVE_OPEN_SEADRAGON"] = (serveOpenSeadragon ? "true" : "false");
-      dictionary["IIIF_PUBLIC_URL"] = iiifPublicUrl;
       explorer = Orthanc::Toolbox::SubstituteVariables(explorer, dictionary);
 
       OrthancPluginExtendOrthancExplorer(OrthancPlugins::GetGlobalContext(), explorer.c_str());