Skip to content
Browse files

Fix identifier for bitstreams in OAI ETDMS format

We were getting a double-prepended https:// on the identifier URL, which
was not good.

We were also getting a link to /jspui/, which resolved, but presumably
won't in the glorious future when we migrate to a different front-end,
so point at the neutral /dspace/ instead.

Signed-off-by: Dan Scott <>
  • Loading branch information
dbs committed Dec 13, 2019
1 parent fb087d6 commit 9171de2d41d2a60b8474bc4838be587ea2d4cb92
Showing with 36 additions and 1 deletion.
  1. +36 −1 dspace/config/crosswalks/oai/metadataFormats/oai_etdms.xsl
@@ -83,7 +83,9 @@
<xsl:for-each select="doc:metadata/doc:element[@name='bundles']/doc:element/doc:field[text()='ORIGINAL']">
<xsl:for-each select="../doc:element[@name='bitstreams']/doc:element">
<xsl:value-of select="concat('https://', doc:field[@name='url']/text())"/>
<xsl:call-template name="replace-jspui">
<xsl:with-param name="text" select="doc:field[@name='url']/text()" />
<xsl:value-of select="doc:field[@name='format']/text()" />
@@ -140,4 +142,37 @@
<!-- XSLT 1.0 does not have a replace() function for strings -->
<!-- workaround from -->
<xsl:template name="string-replace-all">
<xsl:param name="text" />
<xsl:param name="replace" />
<xsl:param name="by" />
<xsl:when test="$text = '' or $replace = ''or not($replace)" >
<!-- Prevent this routine from hanging -->
<xsl:value-of select="$text" />
<xsl:when test="contains($text, $replace)">
<xsl:value-of select="substring-before($text,$replace)" />
<xsl:value-of select="$by" />
<xsl:call-template name="string-replace-all">
<xsl:with-param name="text" select="substring-after($text,$replace)" />
<xsl:with-param name="replace" select="$replace" />
<xsl:with-param name="by" select="$by" />
<xsl:value-of select="$text" />
<xsl:template name="replace-jspui">
<xsl:param name="text" />
<xsl:call-template name="string-replace-all">
<xsl:with-param name="text" select="$text" />
<xsl:with-param name="replace" select="'/jspui/'" />
<xsl:with-param name="by" select="'/dspace/'" />

0 comments on commit 9171de2

Please sign in to comment.
You can’t perform that action at this time.