1033 lines
87 KiB
HTML
Raw Normal View History

2023-07-04 08:03:36 +03:00
<!DOCTYPE html>
<html lang="en" >
<head>
<meta charset="utf-8">
<meta name="viewport" content="width=device-width, initial-scale=1, shrink-to-fit=no">
<meta property="og:title" content="October, 2022" />
<meta property="og:description" content="2022-10-01
Start a harvest on AReS last night
Yesterday I realized how to use GraphicsMagick with im4java and I want to re-visit some of my thumbnail tests
I&rsquo;m also interested in libvips support via jVips, though last time I checked it was only for Java 8
I filed an issue to ask about Java 11&#43; support
" />
<meta property="og:type" content="article" />
<meta property="og:url" content="https://alanorth.github.io/cgspace-notes/2022-10/" />
<meta property="article:published_time" content="2022-10-01T19:45:36+03:00" />
<meta property="article:modified_time" content="2023-04-18T11:08:15-07:00" />
<meta name="twitter:card" content="summary"/>
<meta name="twitter:title" content="October, 2022"/>
<meta name="twitter:description" content="2022-10-01
Start a harvest on AReS last night
Yesterday I realized how to use GraphicsMagick with im4java and I want to re-visit some of my thumbnail tests
I&rsquo;m also interested in libvips support via jVips, though last time I checked it was only for Java 8
I filed an issue to ask about Java 11&#43; support
"/>
2024-08-28 11:35:05 +03:00
<meta name="generator" content="Hugo 0.133.1">
2023-07-04 08:03:36 +03:00
<script type="application/ld+json">
{
"@context": "http://schema.org",
"@type": "BlogPosting",
"headline": "October, 2022",
"url": "https://alanorth.github.io/cgspace-notes/2022-10/",
"wordCount": "3768",
"datePublished": "2022-10-01T19:45:36+03:00",
"dateModified": "2023-04-18T11:08:15-07:00",
"author": {
"@type": "Person",
"name": "Alan Orth"
},
"keywords": "Notes"
}
</script>
<link rel="canonical" href="https://alanorth.github.io/cgspace-notes/2022-10/">
<title>October, 2022 | CGSpace Notes</title>
<!-- combined, minified CSS -->
<link href="https://alanorth.github.io/cgspace-notes/css/style.c6ba80bc50669557645abe05f86b73cc5af84408ed20f1551a267bc19ece8228.css" rel="stylesheet" integrity="sha256-xrqAvFBmlVdkWr4F&#43;GtzzFr4RAjtIPFVGiZ7wZ7Ogig=" crossorigin="anonymous">
<!-- minified Font Awesome for SVG icons -->
<script defer src="https://alanorth.github.io/cgspace-notes/js/fontawesome.min.f5072c55a0721857184db93a50561d7dc13975b4de2e19db7f81eb5f3fa57270.js" integrity="sha256-9QcsVaByGFcYTbk6UFYdfcE5dbTeLhnbf4HrXz&#43;lcnA=" crossorigin="anonymous"></script>
<!-- RSS 2.0 feed -->
</head>
<body>
<div class="blog-masthead">
<div class="container">
<nav class="nav blog-nav">
<a class="nav-link " href="https://alanorth.github.io/cgspace-notes/">Home</a>
</nav>
</div>
</div>
<header class="blog-header">
<div class="container">
<h1 class="blog-title" dir="auto"><a href="https://alanorth.github.io/cgspace-notes/" rel="home">CGSpace Notes</a></h1>
<p class="lead blog-description" dir="auto">Documenting day-to-day work on the <a href="https://cgspace.cgiar.org">CGSpace</a> repository.</p>
</div>
</header>
<div class="container">
<div class="row">
<div class="col-sm-8 blog-main">
<article class="blog-post">
<header>
<h2 class="blog-post-title" dir="auto"><a href="https://alanorth.github.io/cgspace-notes/2022-10/">October, 2022</a></h2>
<p class="blog-post-meta">
<time datetime="2022-10-01T19:45:36+03:00">Sat Oct 01, 2022</time>
in
<span class="fas fa-folder" aria-hidden="true"></span>&nbsp;<a href="/categories/notes/" rel="category tag">Notes</a>
</p>
</header>
<h2 id="2022-10-01">2022-10-01</h2>
<ul>
<li>Start a harvest on AReS last night</li>
<li>Yesterday I realized how to use <a href="https://im4java.sourceforge.net/docs/dev-guide.html">GraphicsMagick with im4java</a> and I want to re-visit some of my thumbnail tests
<ul>
<li>I&rsquo;m also interested in libvips support via jVips, though last time I checked it was only for Java 8</li>
<li>I filed <a href="https://github.com/criteo/JVips/issues/141">an issue to ask about Java 11+ support</a></li>
</ul>
</li>
</ul>
<h2 id="2022-10-03">2022-10-03</h2>
<ul>
<li>Make two pull requests for DSpace 7.x
<ul>
<li><a href="https://github.com/DSpace/DSpace/pull/8503">Update PDFBox dependency to version 2.0.27</a></li>
<li><a href="https://github.com/DSpace/DSpace/pull/8504">Update Apache commons-dbcp2 and commons-pool2 dependencies</a></li>
</ul>
</li>
<li>Udana had asked me about their RSS feed and it not showing the latest publications in his email inbox
<ul>
<li>He is using this feed from FeedBurner: <a href="https://feeds.feedburner.com/iwmi-cgspace">https://feeds.feedburner.com/iwmi-cgspace</a></li>
<li>I don&rsquo;t have access to the FeedBurner configuration, but I looked at the <a href="https://gist.github.com/alanorth/0c518fc571f450f8cc353c42cbdd277c">raw feed</a> and see it&rsquo;s just getting all the items in the IWMI community</li>
<li>This OpenSearch query should do the same: <code>https://cgspace.cgiar.org/open-search/discover?scope=10568/16814&amp;query=*&amp;sort_by=3&amp;order=DESC</code></li>
<li>The <code>sort_by=3</code> corresponds to <code>webui.itemlist.sort-option.3 = dateaccessioned:dc.date.accessioned:date</code> in dspace.cfg</li>
</ul>
</li>
<li>Peter sent me a CSV file a few days ago that he was unable to upload to CGSpace
<ul>
<li>The stacktrace from the error he was getting was:</li>
</ul>
</li>
</ul>
<div class="highlight"><pre tabindex="0" style="color:#f8f8f2;background-color:#272822;-moz-tab-size:4;-o-tab-size:4;tab-size:4;"><code class="language-console" data-lang="console"><span style="display:flex;"><span>Java stacktrace: java.lang.ClassCastException: org.apache.cocoon.servlet.multipart.PartInMemory cannot be cast to org.dspace.app.xmlui.cocoon.servlet.multipart.DSpacePartOnDisk
</span></span><span style="display:flex;"><span> at org.dspace.app.xmlui.aspect.administrative.FlowMetadataImportUtils.processUploadCSV(FlowMetadataImportUtils.java:116)
</span></span><span style="display:flex;"><span> at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
</span></span><span style="display:flex;"><span> at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:62)
</span></span><span style="display:flex;"><span> at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)
</span></span><span style="display:flex;"><span> at java.lang.reflect.Method.invoke(Method.java:498)
</span></span><span style="display:flex;"><span> at org.mozilla.javascript.MemberBox.invoke(MemberBox.java:155)
</span></span><span style="display:flex;"><span> at org.mozilla.javascript.NativeJavaMethod.call(NativeJavaMethod.java:243)
</span></span><span style="display:flex;"><span> at org.mozilla.javascript.Interpreter.interpretLoop(Interpreter.java:3237)
</span></span><span style="display:flex;"><span> at org.mozilla.javascript.Interpreter.interpret(Interpreter.java:2394)
</span></span><span style="display:flex;"><span> at org.mozilla.javascript.InterpretedFunction.call(InterpretedFunction.java:162)
</span></span><span style="display:flex;"><span> at org.mozilla.javascript.ContextFactory.doTopCall(ContextFactory.java:393)
</span></span><span style="display:flex;"><span> at org.mozilla.javascript.ScriptRuntime.doTopCall(ScriptRuntime.java:2834)
</span></span><span style="display:flex;"><span> at org.mozilla.javascript.InterpretedFunction.call(InterpretedFunction.java:160)
</span></span><span style="display:flex;"><span> at org.mozilla.javascript.Context.call(Context.java:538)
</span></span><span style="display:flex;"><span> at org.mozilla.javascript.ScriptableObject.callMethod(ScriptableObject.java:1833)
</span></span><span style="display:flex;"><span> at org.mozilla.javascript.ScriptableObject.callMethod(ScriptableObject.java:1803)
</span></span><span style="display:flex;"><span> at org.apache.cocoon.components.flow.javascript.fom.FOM_JavaScriptInterpreter.handleContinuation(FOM_JavaScriptInterpreter.java:698)
</span></span><span style="display:flex;"><span> at org.apache.cocoon.components.treeprocessor.sitemap.CallFunctionNode.invoke(CallFunctionNode.java:94)
</span></span><span style="display:flex;"><span> at org.apache.cocoon.components.treeprocessor.AbstractParentProcessingNode.invokeNodes(AbstractParentProcessingNode.java:55)
</span></span><span style="display:flex;"><span> at org.apache.cocoon.components.treeprocessor.sitemap.MatchNode.invoke(MatchNode.java:87)
</span></span><span style="display:flex;"><span> at org.apache.cocoon.components.treeprocessor.AbstractParentProcessingNode.invokeNodes(AbstractParentProcessingNode.java:55)
</span></span><span style="display:flex;"><span> at org.apache.cocoon.components.treeprocessor.sitemap.MatchNode.invoke(MatchNode.java:87)
</span></span><span style="display:flex;"><span> at org.apache.cocoon.components.treeprocessor.AbstractParentProcessingNode.invokeNodes(AbstractParentProcessingNode.java:78)
</span></span><span style="display:flex;"><span> at org.apache.cocoon.components.treeprocessor.sitemap.SelectNode.invoke(SelectNode.java:82)
</span></span><span style="display:flex;"><span> at org.apache.cocoon.components.treeprocessor.AbstractParentProcessingNode.invokeNodes(AbstractParentProcessingNode.java:78)
</span></span><span style="display:flex;"><span> at org.apache.cocoon.components.treeprocessor.sitemap.PipelineNode.invoke(PipelineNode.java:143)
</span></span><span style="display:flex;"><span> at org.apache.cocoon.components.treeprocessor.AbstractParentProcessingNode.invokeNodes(AbstractParentProcessingNode.java:78)
</span></span><span style="display:flex;"><span> at org.apache.cocoon.components.treeprocessor.sitemap.PipelinesNode.invoke(PipelinesNode.java:81)
</span></span><span style="display:flex;"><span> at org.apache.cocoon.components.treeprocessor.ConcreteTreeProcessor.process(ConcreteTreeProcessor.java:239)
</span></span><span style="display:flex;"><span> at org.apache.cocoon.components.treeprocessor.ConcreteTreeProcessor.buildPipeline(ConcreteTreeProcessor.java:186)
</span></span><span style="display:flex;"><span> at org.apache.cocoon.components.treeprocessor.TreeProcessor.buildPipeline(TreeProcessor.java:260)
</span></span><span style="display:flex;"><span> at org.apache.cocoon.components.treeprocessor.sitemap.MountNode.invoke(MountNode.java:107)
</span></span><span style="display:flex;"><span> at org.apache.cocoon.components.treeprocessor.AbstractParentProcessingNode.invokeNodes(AbstractParentProcessingNode.java:78)
</span></span><span style="display:flex;"><span> at org.apache.cocoon.components.treeprocessor.sitemap.SelectNode.invoke(SelectNode.java:87)
</span></span><span style="display:flex;"><span> at org.apache.cocoon.components.treeprocessor.AbstractParentProcessingNode.invokeNodes(AbstractParentProcessingNode.java:55)
</span></span><span style="display:flex;"><span> at org.apache.cocoon.components.treeprocessor.sitemap.MatchNode.invoke(MatchNode.java:87)
</span></span><span style="display:flex;"><span> at org.apache.cocoon.components.treeprocessor.AbstractParentProcessingNode.invokeNodes(AbstractParentProcessingNode.java:78)
</span></span><span style="display:flex;"><span> at org.apache.cocoon.components.treeprocessor.sitemap.PipelineNode.invoke(PipelineNode.java:143)
</span></span><span style="display:flex;"><span> at org.apache.cocoon.components.treeprocessor.AbstractParentProcessingNode.invokeNodes(AbstractParentProcessingNode.java:78)
</span></span><span style="display:flex;"><span> at org.apache.cocoon.components.treeprocessor.sitemap.PipelinesNode.invoke(PipelinesNode.java:81)
</span></span><span style="display:flex;"><span> at org.apache.cocoon.components.treeprocessor.ConcreteTreeProcessor.process(ConcreteTreeProcessor.java:239)
</span></span><span style="display:flex;"><span> at org.apache.cocoon.components.treeprocessor.ConcreteTreeProcessor.buildPipeline(ConcreteTreeProcessor.java:186)
</span></span><span style="display:flex;"><span> at org.apache.cocoon.components.treeprocessor.TreeProcessor.buildPipeline(TreeProcessor.java:260)
</span></span><span style="display:flex;"><span> at org.apache.cocoon.components.treeprocessor.sitemap.MountNode.invoke(MountNode.java:107)
</span></span><span style="display:flex;"><span> at org.apache.cocoon.components.treeprocessor.AbstractParentProcessingNode.invokeNodes(AbstractParentProcessingNode.java:55)
</span></span><span style="display:flex;"><span> at org.apache.cocoon.components.treeprocessor.sitemap.MatchNode.invoke(MatchNode.java:87)
</span></span><span style="display:flex;"><span> at org.apache.cocoon.components.treeprocessor.AbstractParentProcessingNode.invokeNodes(AbstractParentProcessingNode.java:78)
</span></span><span style="display:flex;"><span> at org.apache.cocoon.components.treeprocessor.sitemap.PipelineNode.invoke(PipelineNode.java:143)
</span></span><span style="display:flex;"><span> at org.apache.cocoon.components.treeprocessor.AbstractParentProcessingNode.invokeNodes(AbstractParentProcessingNode.java:78)
</span></span><span style="display:flex;"><span> at org.apache.cocoon.components.treeprocessor.sitemap.PipelinesNode.invoke(PipelinesNode.java:81)
</span></span><span style="display:flex;"><span> at org.apache.cocoon.components.treeprocessor.ConcreteTreeProcessor.process(ConcreteTreeProcessor.java:239)
</span></span><span style="display:flex;"><span> at org.apache.cocoon.components.treeprocessor.ConcreteTreeProcessor.buildPipeline(ConcreteTreeProcessor.java:186)
</span></span><span style="display:flex;"><span> at org.apache.cocoon.components.treeprocessor.TreeProcessor.buildPipeline(TreeProcessor.java:260)
</span></span><span style="display:flex;"><span> at org.apache.cocoon.components.source.impl.SitemapSource.init(SitemapSource.java:277)
</span></span><span style="display:flex;"><span> at org.apache.cocoon.components.source.impl.SitemapSource.&lt;init&gt;(SitemapSource.java:148)
</span></span><span style="display:flex;"><span> at org.apache.cocoon.components.source.impl.SitemapSourceFactory.getSource(SitemapSourceFactory.java:62)
</span></span><span style="display:flex;"><span> at org.apache.cocoon.components.source.CocoonSourceResolver.resolveURI(CocoonSourceResolver.java:153)
</span></span><span style="display:flex;"><span> at org.apache.cocoon.components.source.CocoonSourceResolver.resolveURI(CocoonSourceResolver.java:183)
</span></span><span style="display:flex;"><span> at org.apache.cocoon.generation.FileGenerator.setup(FileGenerator.java:99)
</span></span><span style="display:flex;"><span> at org.dspace.app.xmlui.cocoon.AspectGenerator.setup(AspectGenerator.java:81)
</span></span><span style="display:flex;"><span> at sun.reflect.GeneratedMethodAccessor255.invoke(Unknown Source)
</span></span><span style="display:flex;"><span> at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)
</span></span><span style="display:flex;"><span> at java.lang.reflect.Method.invoke(Method.java:498)
</span></span><span style="display:flex;"><span> at org.apache.cocoon.core.container.spring.avalon.PoolableProxyHandler.invoke(PoolableProxyHandler.java:71)
</span></span><span style="display:flex;"><span> at com.sun.proxy.$Proxy190.setup(Unknown Source)
</span></span><span style="display:flex;"><span> at org.apache.cocoon.components.pipeline.AbstractProcessingPipeline.setupPipeline(AbstractProcessingPipeline.java:343)
</span></span><span style="display:flex;"><span> at org.apache.cocoon.components.pipeline.impl.AbstractCachingProcessingPipeline.setupPipeline(AbstractCachingProcessingPipeline.java:710)
</span></span><span style="display:flex;"><span> at org.apache.cocoon.components.pipeline.AbstractProcessingPipeline.preparePipeline(AbstractProcessingPipeline.java:466)
</span></span><span style="display:flex;"><span> at org.apache.cocoon.components.pipeline.AbstractProcessingPipeline.prepareInternal(AbstractProcessingPipeline.java:480)
</span></span><span style="display:flex;"><span> at sun.reflect.GeneratedMethodAccessor267.invoke(Unknown Source)
</span></span><span style="display:flex;"><span> at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)
</span></span><span style="display:flex;"><span> at java.lang.reflect.Method.invoke(Method.java:498)
</span></span><span style="display:flex;"><span> at org.apache.cocoon.core.container.spring.avalon.PoolableProxyHandler.invoke(PoolableProxyHandler.java:71)
</span></span><span style="display:flex;"><span> at com.sun.proxy.$Proxy189.prepareInternal(Unknown Source)
</span></span><span style="display:flex;"><span> at org.apache.cocoon.components.source.impl.SitemapSource.init(SitemapSource.java:292)
</span></span><span style="display:flex;"><span> at org.apache.cocoon.components.source.impl.SitemapSource.&lt;init&gt;(SitemapSource.java:148)
</span></span><span style="display:flex;"><span> at org.apache.cocoon.components.source.impl.SitemapSourceFactory.getSource(SitemapSourceFactory.java:62)
</span></span><span style="display:flex;"><span> at org.apache.cocoon.components.source.CocoonSourceResolver.resolveURI(CocoonSourceResolver.java:153)
</span></span><span style="display:flex;"><span> at org.apache.cocoon.components.source.CocoonSourceResolver.resolveURI(CocoonSourceResolver.java:183)
</span></span><span style="display:flex;"><span> at org.apache.cocoon.generation.FileGenerator.setup(FileGenerator.java:99)
</span></span><span style="display:flex;"><span> at org.dspace.app.xmlui.cocoon.AspectGenerator.setup(AspectGenerator.java:81)
</span></span><span style="display:flex;"><span> at sun.reflect.GeneratedMethodAccessor255.invoke(Unknown Source)
</span></span><span style="display:flex;"><span> at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)
</span></span><span style="display:flex;"><span> at java.lang.reflect.Method.invoke(Method.java:498)
</span></span><span style="display:flex;"><span> at org.apache.cocoon.core.container.spring.avalon.PoolableProxyHandler.invoke(PoolableProxyHandler.java:71)
</span></span><span style="display:flex;"><span> at com.sun.proxy.$Proxy190.setup(Unknown Source)
</span></span><span style="display:flex;"><span> at org.apache.cocoon.components.pipeline.AbstractProcessingPipeline.setupPipeline(AbstractProcessingPipeline.java:343)
</span></span><span style="display:flex;"><span> at org.apache.cocoon.components.pipeline.impl.AbstractCachingProcessingPipeline.setupPipeline(AbstractCachingProcessingPipeline.java:710)
</span></span><span style="display:flex;"><span> at org.apache.cocoon.components.pipeline.AbstractProcessingPipeline.preparePipeline(AbstractProcessingPipeline.java:466)
</span></span><span style="display:flex;"><span> at org.apache.cocoon.components.pipeline.AbstractProcessingPipeline.prepareInternal(AbstractProcessingPipeline.java:480)
</span></span><span style="display:flex;"><span> at sun.reflect.GeneratedMethodAccessor267.invoke(Unknown Source)
</span></span><span style="display:flex;"><span> at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)
</span></span><span style="display:flex;"><span> at java.lang.reflect.Method.invoke(Method.java:498)
</span></span><span style="display:flex;"><span> at org.apache.cocoon.core.container.spring.avalon.PoolableProxyHandler.invoke(PoolableProxyHandler.java:71)
</span></span><span style="display:flex;"><span> at com.sun.proxy.$Proxy189.prepareInternal(Unknown Source)
</span></span><span style="display:flex;"><span> at org.apache.cocoon.components.source.impl.SitemapSource.init(SitemapSource.java:292)
</span></span><span style="display:flex;"><span> at org.apache.cocoon.components.source.impl.SitemapSource.&lt;init&gt;(SitemapSource.java:148)
</span></span><span style="display:flex;"><span> at org.apache.cocoon.components.source.impl.SitemapSourceFactory.getSource(SitemapSourceFactory.java:62)
</span></span><span style="display:flex;"><span> at org.apache.cocoon.components.source.CocoonSourceResolver.resolveURI(CocoonSourceResolver.java:153)
</span></span><span style="display:flex;"><span> at org.apache.cocoon.components.source.CocoonSourceResolver.resolveURI(CocoonSourceResolver.java:183)
</span></span><span style="display:flex;"><span> at org.apache.cocoon.generation.FileGenerator.setup(FileGenerator.java:99)
</span></span><span style="display:flex;"><span> at org.dspace.app.xmlui.cocoon.AspectGenerator.setup(AspectGenerator.java:81)
</span></span><span style="display:flex;"><span> at sun.reflect.GeneratedMethodAccessor255.invoke(Unknown Source)
</span></span><span style="display:flex;"><span> at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)
</span></span><span style="display:flex;"><span> at java.lang.reflect.Method.invoke(Method.java:498)
</span></span><span style="display:flex;"><span> at org.apache.cocoon.core.container.spring.avalon.PoolableProxyHandler.invoke(PoolableProxyHandler.java:71)
</span></span><span style="display:flex;"><span> at com.sun.proxy.$Proxy190.setup(Unknown Source)
</span></span><span style="display:flex;"><span> at org.apache.cocoon.components.pipeline.AbstractProcessingPipeline.setupPipeline(AbstractProcessingPipeline.java:343)
</span></span><span style="display:flex;"><span> at org.apache.cocoon.components.pipeline.impl.AbstractCachingProcessingPipeline.setupPipeline(AbstractCachingProcessingPipeline.java:710)
</span></span><span style="display:flex;"><span> at org.apache.cocoon.components.pipeline.AbstractProcessingPipeline.preparePipeline(AbstractProcessingPipeline.java:466)
</span></span><span style="display:flex;"><span> at org.apache.cocoon.components.pipeline.AbstractProcessingPipeline.prepareInternal(AbstractProcessingPipeline.java:480)
</span></span><span style="display:flex;"><span> at sun.reflect.GeneratedMethodAccessor267.invoke(Unknown Source)
</span></span><span style="display:flex;"><span> at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)
</span></span><span style="display:flex;"><span> at java.lang.reflect.Method.invoke(Method.java:498)
</span></span><span style="display:flex;"><span> at org.apache.cocoon.core.container.spring.avalon.PoolableProxyHandler.invoke(PoolableProxyHandler.java:71)
</span></span><span style="display:flex;"><span> at com.sun.proxy.$Proxy189.prepareInternal(Unknown Source)
</span></span><span style="display:flex;"><span> at org.apache.cocoon.components.source.impl.SitemapSource.init(SitemapSource.java:292)
</span></span><span style="display:flex;"><span> at org.apache.cocoon.components.source.impl.SitemapSource.&lt;init&gt;(SitemapSource.java:148)
</span></span><span style="display:flex;"><span> at org.apache.cocoon.components.source.impl.SitemapSourceFactory.getSource(SitemapSourceFactory.java:62)
</span></span><span style="display:flex;"><span> at org.apache.cocoon.components.source.CocoonSourceResolver.resolveURI(CocoonSourceResolver.java:153)
</span></span><span style="display:flex;"><span> at org.apache.cocoon.components.source.CocoonSourceResolver.resolveURI(CocoonSourceResolver.java:183)
</span></span><span style="display:flex;"><span> at org.apache.cocoon.generation.FileGenerator.setup(FileGenerator.java:99)
</span></span><span style="display:flex;"><span> at org.dspace.app.xmlui.cocoon.AspectGenerator.setup(AspectGenerator.java:81)
</span></span><span style="display:flex;"><span> at sun.reflect.GeneratedMethodAccessor255.invoke(Unknown Source)
</span></span><span style="display:flex;"><span> at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)
</span></span><span style="display:flex;"><span> at java.lang.reflect.Method.invoke(Method.java:498)
</span></span><span style="display:flex;"><span> at org.apache.cocoon.core.container.spring.avalon.PoolableProxyHandler.invoke(PoolableProxyHandler.java:71)
</span></span><span style="display:flex;"><span> at com.sun.proxy.$Proxy190.setup(Unknown Source)
</span></span><span style="display:flex;"><span> at org.apache.cocoon.components.pipeline.AbstractProcessingPipeline.setupPipeline(AbstractProcessingPipeline.java:343)
</span></span><span style="display:flex;"><span> at org.apache.cocoon.components.pipeline.impl.AbstractCachingProcessingPipeline.setupPipeline(AbstractCachingProcessingPipeline.java:710)
</span></span><span style="display:flex;"><span> at org.apache.cocoon.components.pipeline.AbstractProcessingPipeline.preparePipeline(AbstractProcessingPipeline.java:466)
</span></span><span style="display:flex;"><span> at org.apache.cocoon.components.pipeline.AbstractProcessingPipeline.prepareInternal(AbstractProcessingPipeline.java:480)
</span></span><span style="display:flex;"><span> at sun.reflect.GeneratedMethodAccessor267.invoke(Unknown Source)
</span></span><span style="display:flex;"><span> at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)
</span></span><span style="display:flex;"><span> at java.lang.reflect.Method.invoke(Method.java:498)
</span></span><span style="display:flex;"><span> at org.apache.cocoon.core.container.spring.avalon.PoolableProxyHandler.invoke(PoolableProxyHandler.java:71)
</span></span><span style="display:flex;"><span> at com.sun.proxy.$Proxy189.prepareInternal(Unknown Source)
</span></span><span style="display:flex;"><span> at org.apache.cocoon.components.source.impl.SitemapSource.init(SitemapSource.java:292)
</span></span><span style="display:flex;"><span> at org.apache.cocoon.components.source.impl.SitemapSource.&lt;init&gt;(SitemapSource.java:148)
</span></span><span style="display:flex;"><span> at org.apache.cocoon.components.source.impl.SitemapSourceFactory.getSource(SitemapSourceFactory.java:62)
</span></span><span style="display:flex;"><span> at org.apache.cocoon.components.source.CocoonSourceResolver.resolveURI(CocoonSourceResolver.java:153)
</span></span><span style="display:flex;"><span> at org.apache.cocoon.components.source.CocoonSourceResolver.resolveURI(CocoonSourceResolver.java:183)
</span></span><span style="display:flex;"><span> at org.apache.cocoon.generation.FileGenerator.setup(FileGenerator.java:99)
</span></span><span style="display:flex;"><span> at org.dspace.app.xmlui.cocoon.AspectGenerator.setup(AspectGenerator.java:81)
</span></span><span style="display:flex;"><span> at sun.reflect.GeneratedMethodAccessor255.invoke(Unknown Source)
</span></span><span style="display:flex;"><span> at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)
</span></span><span style="display:flex;"><span> at java.lang.reflect.Method.invoke(Method.java:498)
</span></span><span style="display:flex;"><span> at org.apache.cocoon.core.container.spring.avalon.PoolableProxyHandler.invoke(PoolableProxyHandler.java:71)
</span></span><span style="display:flex;"><span> at com.sun.proxy.$Proxy190.setup(Unknown Source)
</span></span><span style="display:flex;"><span> at org.apache.cocoon.components.pipeline.AbstractProcessingPipeline.setupPipeline(AbstractProcessingPipeline.java:343)
</span></span><span style="display:flex;"><span> at org.apache.cocoon.components.pipeline.impl.AbstractCachingProcessingPipeline.setupPipeline(AbstractCachingProcessingPipeline.java:710)
</span></span><span style="display:flex;"><span> at org.apache.cocoon.components.pipeline.AbstractProcessingPipeline.preparePipeline(AbstractProcessingPipeline.java:466)
</span></span><span style="display:flex;"><span> at org.apache.cocoon.components.pipeline.AbstractProcessingPipeline.prepareInternal(AbstractProcessingPipeline.java:480)
</span></span><span style="display:flex;"><span> at sun.reflect.GeneratedMethodAccessor267.invoke(Unknown Source)
</span></span><span style="display:flex;"><span> at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)
</span></span><span style="display:flex;"><span> at java.lang.reflect.Method.invoke(Method.java:498)
</span></span><span style="display:flex;"><span> at org.apache.cocoon.core.container.spring.avalon.PoolableProxyHandler.invoke(PoolableProxyHandler.java:71)
</span></span><span style="display:flex;"><span> at com.sun.proxy.$Proxy189.prepareInternal(Unknown Source)
</span></span><span style="display:flex;"><span> at org.apache.cocoon.components.source.impl.SitemapSource.init(SitemapSource.java:292)
</span></span><span style="display:flex;"><span> at org.apache.cocoon.components.source.impl.SitemapSource.&lt;init&gt;(SitemapSource.java:148)
</span></span><span style="display:flex;"><span> at org.apache.cocoon.components.source.impl.SitemapSourceFactory.getSource(SitemapSourceFactory.java:62)
</span></span><span style="display:flex;"><span> at org.apache.cocoon.components.source.CocoonSourceResolver.resolveURI(CocoonSourceResolver.java:153)
</span></span><span style="display:flex;"><span> at org.apache.cocoon.components.source.CocoonSourceResolver.resolveURI(CocoonSourceResolver.java:183)
</span></span><span style="display:flex;"><span> at org.apache.cocoon.generation.FileGenerator.setup(FileGenerator.java:99)
</span></span><span style="display:flex;"><span> at org.dspace.app.xmlui.cocoon.AspectGenerator.setup(AspectGenerator.java:81)
</span></span><span style="display:flex;"><span> at sun.reflect.GeneratedMethodAccessor255.invoke(Unknown Source)
</span></span><span style="display:flex;"><span> at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)
</span></span><span style="display:flex;"><span> at java.lang.reflect.Method.invoke(Method.java:498)
</span></span><span style="display:flex;"><span> at org.apache.cocoon.core.container.spring.avalon.PoolableProxyHandler.invoke(PoolableProxyHandler.java:71)
</span></span><span style="display:flex;"><span> at com.sun.proxy.$Proxy190.setup(Unknown Source)
</span></span><span style="display:flex;"><span> at org.apache.cocoon.components.pipeline.AbstractProcessingPipeline.setupPipeline(AbstractProcessingPipeline.java:343)
</span></span><span style="display:flex;"><span> at org.apache.cocoon.components.pipeline.impl.AbstractCachingProcessingPipeline.setupPipeline(AbstractCachingProcessingPipeline.java:710)
</span></span><span style="display:flex;"><span> at org.apache.cocoon.components.pipeline.AbstractProcessingPipeline.preparePipeline(AbstractProcessingPipeline.java:466)
</span></span><span style="display:flex;"><span> at org.apache.cocoon.components.pipeline.AbstractProcessingPipeline.prepareInternal(AbstractProcessingPipeline.java:480)
</span></span><span style="display:flex;"><span> at sun.reflect.GeneratedMethodAccessor267.invoke(Unknown Source)
</span></span><span style="display:flex;"><span> at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)
</span></span><span style="display:flex;"><span> at java.lang.reflect.Method.invoke(Method.java:498)
</span></span><span style="display:flex;"><span> at org.apache.cocoon.core.container.spring.avalon.PoolableProxyHandler.invoke(PoolableProxyHandler.java:71)
</span></span><span style="display:flex;"><span> at com.sun.proxy.$Proxy189.prepareInternal(Unknown Source)
</span></span><span style="display:flex;"><span> at org.apache.cocoon.components.source.impl.SitemapSource.init(SitemapSource.java:292)
</span></span><span style="display:flex;"><span> at org.apache.cocoon.components.source.impl.SitemapSource.&lt;init&gt;(SitemapSource.java:148)
</span></span><span style="display:flex;"><span> at org.apache.cocoon.components.source.impl.SitemapSourceFactory.getSource(SitemapSourceFactory.java:62)
</span></span><span style="display:flex;"><span> at org.apache.cocoon.components.source.CocoonSourceResolver.resolveURI(CocoonSourceResolver.java:153)
</span></span><span style="display:flex;"><span> at org.apache.cocoon.components.source.CocoonSourceResolver.resolveURI(CocoonSourceResolver.java:183)
</span></span><span style="display:flex;"><span> at org.apache.cocoon.generation.FileGenerator.setup(FileGenerator.java:99)
</span></span><span style="display:flex;"><span> at org.dspace.app.xmlui.cocoon.AspectGenerator.setup(AspectGenerator.java:81)
</span></span><span style="display:flex;"><span> at sun.reflect.GeneratedMethodAccessor255.invoke(Unknown Source)
</span></span><span style="display:flex;"><span> at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)
</span></span><span style="display:flex;"><span> at java.lang.reflect.Method.invoke(Method.java:498)
</span></span><span style="display:flex;"><span> at org.apache.cocoon.core.container.spring.avalon.PoolableProxyHandler.invoke(PoolableProxyHandler.java:71)
</span></span><span style="display:flex;"><span> at com.sun.proxy.$Proxy190.setup(Unknown Source)
</span></span><span style="display:flex;"><span> at org.apache.cocoon.components.pipeline.AbstractProcessingPipeline.setupPipeline(AbstractProcessingPipeline.java:343)
</span></span><span style="display:flex;"><span> at org.apache.cocoon.components.pipeline.impl.AbstractCachingProcessingPipeline.setupPipeline(AbstractCachingProcessingPipeline.java:710)
</span></span><span style="display:flex;"><span> at org.apache.cocoon.components.pipeline.AbstractProcessingPipeline.preparePipeline(AbstractProcessingPipeline.java:466)
</span></span><span style="display:flex;"><span> at org.apache.cocoon.components.pipeline.AbstractProcessingPipeline.prepareInternal(AbstractProcessingPipeline.java:480)
</span></span><span style="display:flex;"><span> at sun.reflect.GeneratedMethodAccessor267.invoke(Unknown Source)
</span></span><span style="display:flex;"><span> at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)
</span></span><span style="display:flex;"><span> at java.lang.reflect.Method.invoke(Method.java:498)
</span></span><span style="display:flex;"><span> at org.apache.cocoon.core.container.spring.avalon.PoolableProxyHandler.invoke(PoolableProxyHandler.java:71)
</span></span><span style="display:flex;"><span> at com.sun.proxy.$Proxy189.prepareInternal(Unknown Source)
</span></span><span style="display:flex;"><span> at org.apache.cocoon.components.source.impl.SitemapSource.init(SitemapSource.java:292)
</span></span><span style="display:flex;"><span> at org.apache.cocoon.components.source.impl.SitemapSource.&lt;init&gt;(SitemapSource.java:148)
</span></span><span style="display:flex;"><span> at org.apache.cocoon.components.source.impl.SitemapSourceFactory.getSource(SitemapSourceFactory.java:62)
</span></span><span style="display:flex;"><span> at org.apache.cocoon.components.source.CocoonSourceResolver.resolveURI(CocoonSourceResolver.java:153)
</span></span><span style="display:flex;"><span> at org.apache.cocoon.components.source.CocoonSourceResolver.resolveURI(CocoonSourceResolver.java:183)
</span></span><span style="display:flex;"><span> at org.apache.cocoon.generation.FileGenerator.setup(FileGenerator.java:99)
</span></span><span style="display:flex;"><span> at org.dspace.app.xmlui.cocoon.AspectGenerator.setup(AspectGenerator.java:81)
</span></span><span style="display:flex;"><span> at sun.reflect.GeneratedMethodAccessor255.invoke(Unknown Source)
</span></span><span style="display:flex;"><span> at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)
</span></span><span style="display:flex;"><span> at java.lang.reflect.Method.invoke(Method.java:498)
</span></span><span style="display:flex;"><span> at org.apache.cocoon.core.container.spring.avalon.PoolableProxyHandler.invoke(PoolableProxyHandler.java:71)
</span></span><span style="display:flex;"><span> at com.sun.proxy.$Proxy190.setup(Unknown Source)
</span></span><span style="display:flex;"><span> at org.apache.cocoon.components.pipeline.AbstractProcessingPipeline.setupPipeline(AbstractProcessingPipeline.java:343)
</span></span><span style="display:flex;"><span> at org.apache.cocoon.components.pipeline.impl.AbstractCachingProcessingPipeline.setupPipeline(AbstractCachingProcessingPipeline.java:710)
</span></span><span style="display:flex;"><span> at org.apache.cocoon.components.pipeline.AbstractProcessingPipeline.preparePipeline(AbstractProcessingPipeline.java:466)
</span></span><span style="display:flex;"><span> at org.apache.cocoon.components.pipeline.AbstractProcessingPipeline.prepareInternal(AbstractProcessingPipeline.java:480)
</span></span><span style="display:flex;"><span> at sun.reflect.GeneratedMethodAccessor267.invoke(Unknown Source)
</span></span><span style="display:flex;"><span> at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)
</span></span><span style="display:flex;"><span> at java.lang.reflect.Method.invoke(Method.java:498)
</span></span><span style="display:flex;"><span> at org.apache.cocoon.core.container.spring.avalon.PoolableProxyHandler.invoke(PoolableProxyHandler.java:71)
</span></span><span style="display:flex;"><span> at com.sun.proxy.$Proxy189.prepareInternal(Unknown Source)
</span></span><span style="display:flex;"><span> at org.apache.cocoon.components.source.impl.SitemapSource.init(SitemapSource.java:292)
</span></span><span style="display:flex;"><span> at org.apache.cocoon.components.source.impl.SitemapSource.&lt;init&gt;(SitemapSource.java:148)
</span></span><span style="display:flex;"><span> at org.apache.cocoon.components.source.impl.SitemapSourceFactory.getSource(SitemapSourceFactory.java:62)
</span></span><span style="display:flex;"><span> at org.apache.cocoon.components.source.CocoonSourceResolver.resolveURI(CocoonSourceResolver.java:153)
</span></span><span style="display:flex;"><span> at org.apache.cocoon.components.source.CocoonSourceResolver.resolveURI(CocoonSourceResolver.java:183)
</span></span><span style="display:flex;"><span> at org.apache.cocoon.generation.FileGenerator.setup(FileGenerator.java:99)
</span></span><span style="display:flex;"><span> at sun.reflect.GeneratedMethodAccessor255.invoke(Unknown Source)
</span></span><span style="display:flex;"><span> at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)
</span></span><span style="display:flex;"><span> at java.lang.reflect.Method.invoke(Method.java:498)
</span></span><span style="display:flex;"><span> at org.apache.cocoon.core.container.spring.avalon.PoolableProxyHandler.invoke(PoolableProxyHandler.java:71)
</span></span><span style="display:flex;"><span> at com.sun.proxy.$Proxy190.setup(Unknown Source)
</span></span><span style="display:flex;"><span> at org.apache.cocoon.components.pipeline.AbstractProcessingPipeline.setupPipeline(AbstractProcessingPipeline.java:343)
</span></span><span style="display:flex;"><span> at org.apache.cocoon.components.pipeline.impl.AbstractCachingProcessingPipeline.setupPipeline(AbstractCachingProcessingPipeline.java:710)
</span></span><span style="display:flex;"><span> at org.apache.cocoon.components.pipeline.AbstractProcessingPipeline.preparePipeline(AbstractProcessingPipeline.java:466)
</span></span><span style="display:flex;"><span> at org.apache.cocoon.components.pipeline.AbstractProcessingPipeline.process(AbstractProcessingPipeline.java:411)
</span></span><span style="display:flex;"><span> at sun.reflect.GeneratedMethodAccessor331.invoke(Unknown Source)
</span></span><span style="display:flex;"><span> at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)
</span></span><span style="display:flex;"><span> at java.lang.reflect.Method.invoke(Method.java:498)
</span></span><span style="display:flex;"><span> at org.apache.cocoon.core.container.spring.avalon.PoolableProxyHandler.invoke(PoolableProxyHandler.java:71)
</span></span><span style="display:flex;"><span> at com.sun.proxy.$Proxy189.process(Unknown Source)
</span></span><span style="display:flex;"><span> at org.apache.cocoon.components.treeprocessor.sitemap.SerializeNode.invoke(SerializeNode.java:147)
</span></span><span style="display:flex;"><span> at org.apache.cocoon.components.treeprocessor.AbstractParentProcessingNode.invokeNodes(AbstractParentProcessingNode.java:55)
</span></span><span style="display:flex;"><span> at org.apache.cocoon.components.treeprocessor.sitemap.MatchNode.invoke(MatchNode.java:87)
</span></span><span style="display:flex;"><span> at org.apache.cocoon.components.treeprocessor.AbstractParentProcessingNode.invokeNodes(AbstractParentProcessingNode.java:78)
</span></span><span style="display:flex;"><span> at org.apache.cocoon.components.treeprocessor.sitemap.PipelineNode.invoke(PipelineNode.java:143)
</span></span><span style="display:flex;"><span> at org.apache.cocoon.components.treeprocessor.AbstractParentProcessingNode.invokeNodes(AbstractParentProcessingNode.java:78)
</span></span><span style="display:flex;"><span> at org.apache.cocoon.components.treeprocessor.sitemap.PipelinesNode.invoke(PipelinesNode.java:81)
</span></span><span style="display:flex;"><span> at org.apache.cocoon.components.treeprocessor.ConcreteTreeProcessor.process(ConcreteTreeProcessor.java:239)
</span></span><span style="display:flex;"><span> at org.apache.cocoon.components.treeprocessor.ConcreteTreeProcessor.process(ConcreteTreeProcessor.java:171)
</span></span><span style="display:flex;"><span> at org.apache.cocoon.components.treeprocessor.TreeProcessor.process(TreeProcessor.java:247)
</span></span><span style="display:flex;"><span> at org.apache.cocoon.components.treeprocessor.sitemap.MountNode.invoke(MountNode.java:117)
</span></span><span style="display:flex;"><span> at org.apache.cocoon.components.treeprocessor.AbstractParentProcessingNode.invokeNodes(AbstractParentProcessingNode.java:55)
</span></span><span style="display:flex;"><span> at org.apache.cocoon.components.treeprocessor.sitemap.MatchNode.invoke(MatchNode.java:87)
</span></span><span style="display:flex;"><span> at org.apache.cocoon.components.treeprocessor.AbstractParentProcessingNode.invokeNodes(AbstractParentProcessingNode.java:78)
</span></span><span style="display:flex;"><span> at org.apache.cocoon.components.treeprocessor.sitemap.PipelineNode.invoke(PipelineNode.java:143)
</span></span><span style="display:flex;"><span> at org.apache.cocoon.components.treeprocessor.AbstractParentProcessingNode.invokeNodes(AbstractParentProcessingNode.java:78)
</span></span><span style="display:flex;"><span> at org.apache.cocoon.components.treeprocessor.sitemap.PipelinesNode.invoke(PipelinesNode.java:81)
</span></span><span style="display:flex;"><span> at org.apache.cocoon.components.treeprocessor.ConcreteTreeProcessor.process(ConcreteTreeProcessor.java:239)
</span></span><span style="display:flex;"><span> at org.apache.cocoon.components.treeprocessor.ConcreteTreeProcessor.process(ConcreteTreeProcessor.java:171)
</span></span><span style="display:flex;"><span> at org.apache.cocoon.components.treeprocessor.TreeProcessor.process(TreeProcessor.java:247)
</span></span><span style="display:flex;"><span> at org.apache.cocoon.components.treeprocessor.sitemap.MountNode.invoke(MountNode.java:117)
</span></span><span style="display:flex;"><span> at org.apache.cocoon.components.treeprocessor.AbstractParentProcessingNode.invokeNodes(AbstractParentProcessingNode.java:78)
</span></span><span style="display:flex;"><span> at org.apache.cocoon.components.treeprocessor.sitemap.PipelineNode.invoke(PipelineNode.java:143)
</span></span><span style="display:flex;"><span> at org.apache.cocoon.components.treeprocessor.AbstractParentProcessingNode.invokeNodes(AbstractParentProcessingNode.java:78)
</span></span><span style="display:flex;"><span> at org.apache.cocoon.components.treeprocessor.sitemap.PipelinesNode.invoke(PipelinesNode.java:81)
</span></span><span style="display:flex;"><span> at org.apache.cocoon.components.treeprocessor.ConcreteTreeProcessor.process(ConcreteTreeProcessor.java:239)
</span></span><span style="display:flex;"><span> at org.apache.cocoon.components.treeprocessor.ConcreteTreeProcessor.process(ConcreteTreeProcessor.java:171)
</span></span><span style="display:flex;"><span> at org.apache.cocoon.components.treeprocessor.TreeProcessor.process(TreeProcessor.java:247)
</span></span><span style="display:flex;"><span> at org.apache.cocoon.servlet.RequestProcessor.process(RequestProcessor.java:351)
</span></span><span style="display:flex;"><span> at org.apache.cocoon.servlet.RequestProcessor.service(RequestProcessor.java:169)
</span></span><span style="display:flex;"><span> at org.apache.cocoon.sitemap.SitemapServlet.service(SitemapServlet.java:84)
</span></span><span style="display:flex;"><span> at javax.servlet.http.HttpServlet.service(HttpServlet.java:728)
</span></span><span style="display:flex;"><span> at org.apache.cocoon.servletservice.ServletServiceContext$PathDispatcher.forward(ServletServiceContext.java:468)
</span></span><span style="display:flex;"><span> at org.apache.cocoon.servletservice.ServletServiceContext$PathDispatcher.forward(ServletServiceContext.java:443)
</span></span><span style="display:flex;"><span> at org.apache.cocoon.servletservice.spring.ServletFactoryBean$ServiceInterceptor.invoke(ServletFactoryBean.java:264)
</span></span><span style="display:flex;"><span> at org.springframework.aop.framework.ReflectiveMethodInvocation.proceed(ReflectiveMethodInvocation.java:172)
</span></span><span style="display:flex;"><span> at org.springframework.aop.framework.JdkDynamicAopProxy.invoke(JdkDynamicAopProxy.java:204)
</span></span><span style="display:flex;"><span> at com.sun.proxy.$Proxy186.service(Unknown Source)
</span></span><span style="display:flex;"><span> at org.dspace.springmvc.CocoonView.render(CocoonView.java:113)
</span></span><span style="display:flex;"><span> at org.springframework.web.servlet.DispatcherServlet.render(DispatcherServlet.java:1216)
</span></span><span style="display:flex;"><span> at org.springframework.web.servlet.DispatcherServlet.processDispatchResult(DispatcherServlet.java:1001)
</span></span><span style="display:flex;"><span> at org.springframework.web.servlet.DispatcherServlet.doDispatch(DispatcherServlet.java:945)
</span></span><span style="display:flex;"><span> at org.springframework.web.servlet.DispatcherServlet.doService(DispatcherServlet.java:867)
</span></span><span style="display:flex;"><span> at org.springframework.web.servlet.FrameworkServlet.processRequest(FrameworkServlet.java:951)
</span></span><span style="display:flex;"><span> at org.springframework.web.servlet.FrameworkServlet.doPost(FrameworkServlet.java:853)
</span></span><span style="display:flex;"><span> at javax.servlet.http.HttpServlet.service(HttpServlet.java:647)
</span></span><span style="display:flex;"><span> at org.springframework.web.servlet.FrameworkServlet.service(FrameworkServlet.java:827)
</span></span><span style="display:flex;"><span> at javax.servlet.http.HttpServlet.service(HttpServlet.java:728)
</span></span><span style="display:flex;"><span> at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:303)
</span></span><span style="display:flex;"><span> at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:208)
</span></span><span style="display:flex;"><span> at org.dspace.app.xmlui.cocoon.SetCharacterEncodingFilter.doFilter(SetCharacterEncodingFilter.java:113)
</span></span><span style="display:flex;"><span> at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:241)
</span></span><span style="display:flex;"><span> at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:208)
</span></span><span style="display:flex;"><span> at org.dspace.app.xmlui.cocoon.DSpaceCocoonServletFilter.doFilter(DSpaceCocoonServletFilter.java:160)
</span></span><span style="display:flex;"><span> at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:241)
</span></span><span style="display:flex;"><span> at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:208)
</span></span><span style="display:flex;"><span> at org.dspace.app.xmlui.cocoon.servlet.multipart.DSpaceMultipartFilter.doFilter(DSpaceMultipartFilter.java:119)
</span></span><span style="display:flex;"><span> at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:241)
</span></span><span style="display:flex;"><span> at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:208)
</span></span><span style="display:flex;"><span> at org.apache.tomcat.websocket.server.WsFilter.doFilter(WsFilter.java:52)
</span></span><span style="display:flex;"><span> at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:241)
</span></span><span style="display:flex;"><span> at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:208)
</span></span><span style="display:flex;"><span> at org.dspace.utils.servlet.DSpaceWebappServletFilter.doFilter(DSpaceWebappServletFilter.java:78)
</span></span><span style="display:flex;"><span> at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:241)
</span></span><span style="display:flex;"><span> at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:208)
</span></span><span style="display:flex;"><span> at org.apache.catalina.core.StandardWrapperValve.invoke(StandardWrapperValve.java:219)
</span></span><span style="display:flex;"><span> at org.apache.catalina.core.StandardContextValve.invoke(StandardContextValve.java:110)
</span></span><span style="display:flex;"><span> at org.apache.catalina.authenticator.AuthenticatorBase.invoke(AuthenticatorBase.java:492)
</span></span><span style="display:flex;"><span> at org.apache.catalina.core.StandardHostValve.invoke(StandardHostValve.java:165)
</span></span><span style="display:flex;"><span> at org.apache.catalina.valves.ErrorReportValve.invoke(ErrorReportValve.java:104)
</span></span><span style="display:flex;"><span> at org.apache.catalina.valves.CrawlerSessionManagerValve.invoke(CrawlerSessionManagerValve.java:235)
</span></span><span style="display:flex;"><span> at org.apache.catalina.valves.AccessLogValve.invoke(AccessLogValve.java:1025)
</span></span><span style="display:flex;"><span> at org.apache.catalina.core.StandardEngineValve.invoke(StandardEngineValve.java:116)
</span></span><span style="display:flex;"><span> at org.apache.catalina.connector.CoyoteAdapter.service(CoyoteAdapter.java:451)
</span></span><span style="display:flex;"><span> at org.apache.coyote.http11.AbstractHttp11Processor.process(AbstractHttp11Processor.java:1201)
</span></span><span style="display:flex;"><span> at org.apache.coyote.AbstractProtocol$AbstractConnectionHandler.process(AbstractProtocol.java:654)
</span></span><span style="display:flex;"><span> at org.apache.tomcat.util.net.JIoEndpoint$SocketProcessor.run(JIoEndpoint.java:317)
</span></span><span style="display:flex;"><span> at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1149)
</span></span><span style="display:flex;"><span> at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:624)
</span></span><span style="display:flex;"><span> at org.apache.tomcat.util.threads.TaskThread$WrappingRunnable.run(TaskThread.java:61)
</span></span><span style="display:flex;"><span> at java.lang.Thread.run(Thread.java:750)
</span></span></code></pre></div><ul>
<li>So this is a broken side effect from the <code>org.apache.cocoon.uploads.autosave=false</code> change I made a few weeks ago
<ul>
<li>Importing the CSV via the command line works fine</li>
</ul>
</li>
</ul>
<h2 id="2022-10-04">2022-10-04</h2>
<ul>
<li>I stumbled across more low-quality thumbnails on CGSpace
<ul>
<li>Some have the description &ldquo;Generated Thumbnail&rdquo;, and others are manually uploaded &ldquo;.jpg.jpg&rdquo; ones&hellip;</li>
<li>I want to develop some more thumbnail fixer scripts to the cgspace-java-helpers suite:
<ul>
<li>If an item has an <code>IM Thumbnail</code> and a <code>Generated Thumbnail</code> in the <code>THUMBNAIL</code> bundle, remove the <code>Generated Thumbnail</code></li>
<li>If an item has a PDF bitstream and a JPG bitstream with description /thumbnail/ in the ORIGINAL bundle, remove the /thumbnail/ bitstream in the ORIGINAL bundle and try to remove the /thumbnail/.jpg bitstream in the THUMBNAIL bundle</li>
</ul>
</li>
</ul>
</li>
</ul>
<h2 id="2022-10-05">2022-10-05</h2>
<ul>
<li>I updated the <a href="https://github.com/ilri/cgspace-java-helpers">cgspace-java-helpers</a> to include a new <code>FixLowQualityThumbnails</code> script to detect the low-quality thumbnails I found above</li>
<li>Add missing ORCID identifier for an Alliance author</li>
<li>I&rsquo;ve been running the <code>dspace cleanup -v</code> script every few weeks or months on CGSpace and assuming it finished successfully because I didn&rsquo;t get a error on the stdout/stderr, but today I noticed that the script keeps saying it is deleting the same bitstreams
<ul>
<li>I looked in dspace.log and found the error I used to see a lot:</li>
</ul>
</li>
</ul>
<div class="highlight"><pre tabindex="0" style="color:#f8f8f2;background-color:#272822;-moz-tab-size:4;-o-tab-size:4;tab-size:4;"><code class="language-console" data-lang="console"><span style="display:flex;"><span>Caused by: org.postgresql.util.PSQLException: ERROR: update or delete on table &#34;bitstream&#34; violates foreign key constraint &#34;bundle_primary_bitstream_id_fkey&#34; on table &#34;bundle&#34;
</span></span><span style="display:flex;"><span> Detail: Key (uuid)=(99b76ee4-15c6-458c-a940-866148bc7dee) is still referenced from table &#34;bundle&#34;.
</span></span></code></pre></div><ul>
<li>If I mark the primary bitstream as null manually the cleanup script continues until it finds a few more
<ul>
<li>I ended up with a long list of UUIDs to fix before the script would complete:</li>
</ul>
</li>
</ul>
<div class="highlight"><pre tabindex="0" style="color:#f8f8f2;background-color:#272822;-moz-tab-size:4;-o-tab-size:4;tab-size:4;"><code class="language-console" data-lang="console"><span style="display:flex;"><span>$ psql -d dspace -c <span style="color:#e6db74">&#34;update bundle set primary_bitstream_id=NULL where primary_bitstream_id in (&#39;b76d41c0-0a02-4f53-bfde-a840ccfff903&#39;,&#39;1981efaa-eadb-46cd-9d7b-12d7a8cff4c4&#39;,&#39;97a8b1fa-3c12-4122-9c7b-fc2a3eaf570d&#39;,&#39;99b76ee4-15c6-458c-a940-866148bc7dee&#39;,&#39;f330fc22-a787-46e2-b8d0-64cc3e166124&#39;,&#39;592f4a0d-1ed5-4663-be0e-958c0d3e653b&#39;,&#39;e73b3178-8f29-42bc-bfd1-1a454903343c&#39;,&#39;e3a5f592-ac23-4934-a2b2-26735fac0c4f&#39;,&#39;73f4ff6c-6679-44e8-8cbd-9f28a1df6927&#39;,&#39;11c9a75c-17a6-4966-a4e8-a473010eb34c&#39;,&#39;155faf93-92c5-4c17-866e-1db50b1f9687&#39;,&#39;8e073e9e-ab54-4d99-971a-66de073d51e3&#39;,&#39;76ddd62c-6499-4a8c-beea-3fc8c60200d8&#39;,&#39;2850fcc9-f450-430a-9317-c42def74e813&#39;,&#39;8fef3198-2aea-4bd8-aeab-bf5fccb46e42&#39;,&#39;9e3c3528-e20f-4da3-a0bd-ae9b8515b770&#39;)&#34;</span>
</span></span></code></pre></div><h2 id="2022-10-06">2022-10-06</h2>
<ul>
<li>I finished running the cleanup script on CGSpace and the before and after on the number of bitstreams is interesting:</li>
</ul>
<div class="highlight"><pre tabindex="0" style="color:#f8f8f2;background-color:#272822;-moz-tab-size:4;-o-tab-size:4;tab-size:4;"><code class="language-console" data-lang="console"><span style="display:flex;"><span>$ find /home/cgspace.cgiar.org/assetstore -type f | wc -l
</span></span><span style="display:flex;"><span>181094
</span></span><span style="display:flex;"><span>$ find /home/cgspace.cgiar.org/assetstore -type f | wc -l
</span></span><span style="display:flex;"><span>178329
</span></span></code></pre></div><ul>
<li>So that cleaned up ~2,700 bitstreams!</li>
<li>Interesting, someone on the DSpace Slack mentioned this as being a known issue with discussion, reproducers, and a pull request: <a href="https://github.com/DSpace/DSpace/issues/7348">https://github.com/DSpace/DSpace/issues/7348</a></li>
<li>I am having an issue with the new FixLowQualityThumbnails script on some communities like 10568/117865 and 10568/97114
<ul>
<li>For some reason it doesn&rsquo;t descend into the collections</li>
<li>Also, my old FixJpgJpgThumbnails doesn&rsquo;t either&hellip; weird</li>
<li>I might have to resort to getting a list of collections and doing it that way:</li>
</ul>
</li>
</ul>
<div class="highlight"><pre tabindex="0" style="color:#f8f8f2;background-color:#272822;-moz-tab-size:4;-o-tab-size:4;tab-size:4;"><code class="language-console" data-lang="console"><span style="display:flex;"><span>$ psql -h localhost -U postgres -d dspacetest -c <span style="color:#e6db74">&#39;SELECT ds6_collection2collectionhandle(uuid) FROM collection WHERE uuid in (SELECT uuid FROM collection);&#39;</span> |
</span></span><span style="display:flex;"><span> sed 1,2d |
</span></span><span style="display:flex;"><span> tac |
</span></span><span style="display:flex;"><span> sed 1,3d &gt; /tmp/collections
</span></span></code></pre></div><ul>
<li>Strange, I don&rsquo;t think doing it by collections is actually working because it says it&rsquo;s replacing the bitstreams, but it doesn&rsquo;t actually do it
<ul>
<li>I don&rsquo;t have time to figure out what&rsquo;s happening, because I see &ldquo;update_item&rdquo; in dspace.log when the script says it&rsquo;s doing it, but it doesn&rsquo;t do it</li>
<li>I might just extract a list of items that have .jpg.jpg thumbnails from the database and run the script through item mode</li>
<li>There might be a problem with the context commit logic&hellip;?</li>
</ul>
</li>
<li>I exported a list of items that have .jpg.jpg thumbnails on CGSpace:</li>
</ul>
<div class="highlight"><pre tabindex="0" style="color:#f8f8f2;background-color:#272822;-moz-tab-size:4;-o-tab-size:4;tab-size:4;"><code class="language-console" data-lang="console"><span style="display:flex;"><span>$ psql -h localhost -p <span style="color:#ae81ff">5432</span> -U postgres -d dspacetest -c <span style="color:#e6db74">&#34;SELECT ds6_bitstream2itemhandle(dspace_object_id) FROM metadatavalue WHERE text_value ~ &#39;.*\.(jpg|jpeg|JPG|JPEG)\.(jpg|jpeg|JPG|JPEG)&#39; AND dspace_object_id IS NOT NULL;&#34;</span> |
</span></span><span style="display:flex;"><span> sed 1,2d |
</span></span><span style="display:flex;"><span> tac |
</span></span><span style="display:flex;"><span> sed 1,3d |
</span></span><span style="display:flex;"><span> grep -v &#39;&#39; |
</span></span><span style="display:flex;"><span> sort -u |
</span></span><span style="display:flex;"><span> sed &#39;s/ //&#39; &gt; /tmp/jpgjpg-handles.txt
</span></span></code></pre></div><ul>
<li>I restarted DSpace Test because it had high load since yesterday and I don&rsquo;t know why</li>
<li>Run <code>check-duplicates.py</code> on the 1642 MARLO Innovations to try to include matches from the OICRs we uploaded last month
<ul>
<li>Then I processed those matches like I did with the OICRs themselves last month, and then cleaned them one last time with csv-metadata-quality, created a SAF bundle, and uploaded them to CGSpace</li>
<li>BTW this bumps CGSpace over 100,000 items&hellip;</li>
<li>Then I did the same for the 749 MARLO MELIAs and imported them to CGSpace</li>
</ul>
</li>
<li>Meeting about CG Core types with Abenet, Marie-Angelique, Sara, Margarita, and Valentina</li>
<li>I made some minor logic changes to the FixJpgJpgThumbnails script in cgspace-java-helpers
<ul>
<li>Now it checks to make sure the bitstream description is not empty or null, and also excludes Maps (in addition to Infographics) since those are likely to be JPEG files in the ORIGINAL bundle on purpose</li>
</ul>
</li>
</ul>
<h2 id="2022-10-07">2022-10-07</h2>
<ul>
<li>I did the matching and cleaning on the 512 MARLO Policies and uploaded them to CGSpace</li>
<li>I sent a list of the IDs and Handles for all four groups of MARLO items to Jose so he can do the redirects on their server:</li>
</ul>
<div class="highlight"><pre tabindex="0" style="color:#f8f8f2;background-color:#272822;-moz-tab-size:4;-o-tab-size:4;tab-size:4;"><code class="language-console" data-lang="console"><span style="display:flex;"><span>$ wc -l /tmp/*mappings.csv
</span></span><span style="display:flex;"><span> 1643 /tmp/crp-innovation-mappings.csv
</span></span><span style="display:flex;"><span> 750 /tmp/crp-melia-mappings.csv
</span></span><span style="display:flex;"><span> 683 /tmp/crp-oicr-mappings.csv
</span></span><span style="display:flex;"><span> 513 /tmp/crp-policy-mappings.csv
</span></span><span style="display:flex;"><span> 3589 total
</span></span></code></pre></div><ul>
<li>I fixed the mysterious issue with my cgspace-java-helpers scripts not working on communities and collections
<ul>
<li>It was because the code wasn&rsquo;t committing the context!</li>
<li>I ran both <code>FixJpgJpgThumbnails</code> and <code>FixLowQualityThumbnails</code> on a dozen or so large collections on CGSpace and processed about 1,200 low-quality thumbnails</li>
</ul>
</li>
<li>I did a complete re-sync of CGSpace to DSpace Test</li>
</ul>
<h2 id="2022-10-08">2022-10-08</h2>
<ul>
<li>Start a harvest on AReS</li>
<li>Experiment with PDF thumbnails in ImageMagick again, I found an <a href="https://legacy.imagemagick.org/Usage/thumbnails/">interesting reference on their legacy website</a> saying we can use <code>-unsharp</code> after <code>-thumbnail</code> to make them less blurry
<ul>
<li>There are a few examples for unsharp values (starting from a DSpace default of a flattened JPEG from the PDF, then the thumbnail in a second operation:</li>
</ul>
</li>
</ul>
<div class="highlight"><pre tabindex="0" style="color:#f8f8f2;background-color:#272822;-moz-tab-size:4;-o-tab-size:4;tab-size:4;"><code class="language-console" data-lang="console"><span style="display:flex;"><span>$ convert <span style="color:#e6db74">&#39;10568-103447.pdf[0]&#39;</span> -flatten 10568-103447-dspace-step1.pdf.jpg
</span></span><span style="display:flex;"><span>$ convert 10568-103447-dspace-step1.pdf.jpg -thumbnail 600x600 -unsharp 0x.5 10568-103447-dspace-step2-600-unsharp.pdf.jpg
</span></span><span style="display:flex;"><span>$ convert 10568-103447-dspace-step1.pdf.jpg -thumbnail 600x600 -unsharp 2x0.5+0.7+0 10568-103447-dspace-step2-600-unsharp2.pdf.jpg
</span></span><span style="display:flex;"><span>$ convert 10568-103447-dspace-step1.pdf.jpg -thumbnail 600x600 -unsharp 0x0.75+0.75+0.008 10568-103447-dspace-step2-600-unsharp3.pdf.jpg
</span></span><span style="display:flex;"><span>$ convert 10568-103447-dspace-step1.pdf.jpg -thumbnail 600x600 -unsharp 1.5x1+0.7+0.02 10568-103447-dspace-step2-600-unsharp4.pdf.jpg
</span></span></code></pre></div><ul>
<li>I merged all the changes from <code>6_x-dev</code> to <code>6_x-prod</code> after having run them on DSpace Test for the last ten days</li>
</ul>
<h2 id="2022-10-11">2022-10-11</h2>
<ul>
<li>I put together the microsite for improving DSpace PDF thumbnails: <a href="https://github.com/alanorth/improved-dspace-thumbnails/">https://github.com/alanorth/improved-dspace-thumbnails/</a>
<ul>
<li>I need to make the pull request to DSpace</li>
</ul>
</li>
<li>I also discussed the thumbnails with Dani in Addis</li>
</ul>
<h2 id="2022-10-12">2022-10-12</h2>
<ul>
<li>I submitted a pull request to DSpace 7 for the <code>-unsharp 0x0.5</code> change: <a href="https://github.com/DSpace/DSpace/pull/8515">https://github.com/DSpace/DSpace/pull/8515</a></li>
<li>I did some tests on CGSpace and verified that MEL will indeed need admin permissions on every collection that they want to map to</li>
<li>I had a call with Salem and he asked me about redirecting from some CRP duplicates that exist in both MELSpace and CGSpace
<ul>
<li>We decided that the only way is to use an HTTP 301 redirect in the nginx web server, but I said that I&rsquo;d check with CNRI to see if there was a way to do this within the Handle system</li>
</ul>
</li>
</ul>
<h2 id="2022-10-13">2022-10-13</h2>
<ul>
<li>Disable the REST API cache on CGSpace temporarily to see if that fixes a strange problem we are seeing with listing publications on ilri.org</li>
<li>Meeting with MEL, MARLO, and CG Core people to continue discussing <code>dcterms.type</code></li>
<li>I added the new MEL account to all the appropriate authorizations for Initiatives that ICARDA is involved in on CGSpace
<ul>
<li>I still have to add the few that WorldFish is involved in</li>
</ul>
</li>
</ul>
<h2 id="2022-10-14">2022-10-14</h2>
<ul>
<li>Abenet finalized adding the MEL user to all initiative collections on CGSpace</li>
<li>Re-sync CGSpace to DSpace Test to get the new MEL user and authorizations</li>
<li>I checked ilri.org and I see more publications for 2021 and earlier
<ul>
<li>The results are still strange though because I only see a few for each year</li>
</ul>
</li>
</ul>
<h2 id="2022-10-15">2022-10-15</h2>
<ul>
<li>I&rsquo;m going to turn the REST API cache on CGSpace back on to see if the ilri.org publications thing gets broken again</li>
<li>Start a harvest on AReS</li>
</ul>
<h2 id="2022-10-16">2022-10-16</h2>
<ul>
<li>The harvest on AReS finished but somehow there are 10,000 less items than the previous indexing&hellip; hmmm
<ul>
<li>I don&rsquo;t see any hits from MELSpace there so I will start another harvest&hellip;</li>
<li>After starting the harvesting the load on the server went up to 20 and UptimeRobot said CGSpace was down for three hours, sigh</li>
<li>I stopped the harvesting and the load went down immediately</li>
<li>I am trying to find a pattern with the load on Sundays</li>
</ul>
</li>
<li>I see this in the AReS backend logs:</li>
</ul>
<div class="highlight"><pre tabindex="0" style="color:#f8f8f2;background-color:#272822;-moz-tab-size:4;-o-tab-size:4;tab-size:4;"><code class="language-console" data-lang="console"><span style="display:flex;"><span>[Nest] 1 - 10/16/2022, 6:42:04 PM [HarvesterService] Starting Harvest =&gt;0
</span></span><span style="display:flex;"><span>[Nest] 1 - 10/16/2022, 6:42:07 PM [HarvesterService] Starting Harvest =&gt;101555
</span></span><span style="display:flex;"><span>[Nest] 1 - 10/16/2022, 6:42:10 PM [HarvesterService] Starting Harvest =&gt;4936
</span></span></code></pre></div><ul>
<li>Which means MELSpace is having some issue</li>
<li>I&rsquo;m not sure what was going on on CGSpace yesterday, but the load was indeed very high according to Munin:</li>
</ul>
<p><img src="/cgspace-notes/2022/10/cpu-day.png" alt="CGSpace CPU load day"></p>
<ul>
<li>The pattern is clear on Sundays if you look at the past month:</li>
</ul>
<p><img src="/cgspace-notes/2022/10/cpu-month.png" alt="CGSpace CPU load month"></p>
<ul>
<li>I have yet to find an increased nginx request pattern correlating with the increased load, but looking back on the last year it seems something started happening around March, 2022, and also I start seeing CPU steal in July (red coming from the top of the graph):</li>
</ul>
<p><img src="/cgspace-notes/2022/10/cpu-year.png" alt="CGSpace CPU load year"></p>
<ul>
<li>The amount of CPU steal is very low if I look at it now, around 1 or 2 percent, but what&rsquo;s happening now reminds me of the mysterious load problems I had in 2019-03 that were due to CPU steal</li>
<li>Salem said there was an issue with the sitemaps on MELSpace so that&rsquo;s why it wasn&rsquo;t working in AReS
<ul>
<li>Load on CGSpace is low in the evening so I&rsquo;ll start a new AReS harvest</li>
</ul>
</li>
</ul>
<h2 id="2022-10-18">2022-10-18</h2>
<ul>
<li>Start mapping the Initiative names on CGSpace to tne new short names from Enrico&rsquo;s spreadsheet</li>
<li>Then I will update them for existing CGSpace items:</li>
</ul>
<div class="highlight"><pre tabindex="0" style="color:#f8f8f2;background-color:#272822;-moz-tab-size:4;-o-tab-size:4;tab-size:4;"><code class="language-console" data-lang="console"><span style="display:flex;"><span>$ ./ilri/fix-metadata-values.py -i 2022-10-18-update-initiatives.csv -db dspace -u dspace -p <span style="color:#e6db74">&#39;fuuu&#39;</span> -f cg.contributor.initiative -m <span style="color:#ae81ff">258</span> -t correct -d -n
</span></span></code></pre></div><ul>
<li>And later in the controlled vocabulary</li>
<li>Apply some corrections to a few hundred items on CGSpace for Peter</li>
<li>Meeting with Abenet, Sara, and Valentina about CG Core types
<ul>
<li>We finished going over our list and agreed to send a message to concerned parties in our organizations for feedback by November 4th</li>
<li>Next week we will continue doing the definitions</li>
</ul>
</li>
<li>Re-sync CGSpace to DSpace Test to get the latest Initiatives changes
<ul>
<li>I also need to re-create the CIAT/Alliance TIP accounts so they can continue testing</li>
<li>I re-created the <a href="mailto:tip-submit@cgiar.org">tip-submit@cgiar.org</a> and <a href="mailto:tip-approve@cgiar.org">tip-approve@cgiar.org</a> account on DSpace Test</li>
<li>According to my notes:
<ul>
<li>A user must be in the collection admin group in order to deposit via the REST API (not in the collection&rsquo;s &ldquo;Submit&rdquo; group, which is for normal submission)</li>
<li>A user must be in the collection&rsquo;s &ldquo;Accept/Reject/Edit Metadata&rdquo; step in order to see and approve the item in the DSpace workflow</li>
</ul>
</li>
<li>I created a new &ldquo;TIP test&rdquo; collection under Alliance&rsquo;s community and added the users accordingly</li>
<li>I think I&rsquo;ll be able to just add these two submit/approve users to the Alliance Admins and Alliance Editors groups once we&rsquo;re ready</li>
</ul>
</li>
</ul>
<h2 id="2022-10-19">2022-10-19</h2>
<ul>
<li>I submitted a <a href="https://bugs.ghostscript.com/show_bug.cgi?id=705994">bug report for the two-page portrait layout of some PDF thumbnails</a> on Ghostscript&rsquo;s bug tracker
<ul>
<li>For reference, the thumbnail for PDFs like in <a href="https://hdl.handle.net/10568/116598">10568/116598</a> looks like this:</li>
</ul>
</li>
</ul>
<p><img src="/cgspace-notes/2022/10/gs-10568-116598.pdf.jpg" alt="gs thumbnail"></p>
<ul>
<li>In other news, I see <code>pdftocairo</code> from the poppler package produces a similar, though slightly prettier version of the thumbnail of that PDF:</li>
</ul>
<p><img src="'/cgspace-notes/2022/10/pdftocairo-10568-116598.pdf.jpg" alt="pdftocairo thumbnail"></p>
<ul>
<li>I used the command:</li>
</ul>
<div class="highlight"><pre tabindex="0" style="color:#f8f8f2;background-color:#272822;-moz-tab-size:4;-o-tab-size:4;tab-size:4;"><code class="language-console" data-lang="console"><span style="display:flex;"><span>$ pdftocairo -jpeg -singlefile -f <span style="color:#ae81ff">1</span> -l <span style="color:#ae81ff">1</span> -scale-to-x <span style="color:#ae81ff">640</span> -scale-to-y -1 10568-116598.pdf thumb
</span></span></code></pre></div><ul>
<li>The Ghostscript developers responded in a few minutes (!) and explained that PDFs can contain many different &ldquo;boxes&rdquo;:</li>
</ul>
<blockquote>
<p>PDF files can have multiple different &lsquo;Box&rsquo; values; ArtBox, BleedBox, CropBox, MediaBox and TrimBox. The MediaBox is required the other boxes are optional, a given PDF page description must contain the MediaBox and may contain any or all of the others.</p>
<p>By default Ghostscript uses the MediaBox to determine the size of the media. Other PDF consumers may exhibit other behaviours.</p>
<p>The pages in your PDF file contain all of the Boxes. In the majority of cases the Boxes all contain the same values (which makes their inclusion pointless of course). But for page 1 they differ:</p>
<p>/CropBox[594.375 0.0 1190.55 839.176]
/MediaBox[0.0 0.0 1190.55 841.89]</p>
<p>You can tell Ghostscript to use a different Box value for the media by using one of -dUseArtBox, -dUseBleedBox, -dUseCropBox, -dUseTrim,Box. If I specify -dUseCropBox then the file is rendered as you expect.</p>
</blockquote>
<ul>
<li>I confirm that adding <code>-define pdf:use-cropbox=true</code> to the ImageMagick command produces a better thumbnail in this case
<ul>
<li>We can check the boxes in a PDF using <code>pdfinfo</code> from the poppler package:</li>
</ul>
</li>
</ul>
<div class="highlight"><pre tabindex="0" style="color:#f8f8f2;background-color:#272822;-moz-tab-size:4;-o-tab-size:4;tab-size:4;"><code class="language-console" data-lang="console"><span style="display:flex;"><span>$ pdfinfo -box data/10568-116598.pdf
</span></span><span style="display:flex;"><span>Creator: Adobe InDesign 17.0 (Macintosh)
</span></span><span style="display:flex;"><span>Producer: Adobe PDF Library 16.0.3
</span></span><span style="display:flex;"><span>CreationDate: Tue Dec 7 12:44:46 2021 EAT
</span></span><span style="display:flex;"><span>ModDate: Tue Dec 7 15:37:58 2021 EAT
</span></span><span style="display:flex;"><span>Custom Metadata: no
</span></span><span style="display:flex;"><span>Metadata Stream: yes
</span></span><span style="display:flex;"><span>Tagged: no
</span></span><span style="display:flex;"><span>UserProperties: no
</span></span><span style="display:flex;"><span>Suspects: no
</span></span><span style="display:flex;"><span>Form: none
</span></span><span style="display:flex;"><span>JavaScript: no
</span></span><span style="display:flex;"><span>Pages: 17
</span></span><span style="display:flex;"><span>Encrypted: no
</span></span><span style="display:flex;"><span>Page size: 596.175 x 839.176 pts
</span></span><span style="display:flex;"><span>Page rot: 0
</span></span><span style="display:flex;"><span>MediaBox: 0.00 0.00 1190.55 841.89
</span></span><span style="display:flex;"><span>CropBox: 594.38 0.00 1190.55 839.18
</span></span><span style="display:flex;"><span>BleedBox: 594.38 0.00 1190.55 839.18
</span></span><span style="display:flex;"><span>TrimBox: 594.38 0.00 1190.55 839.18
</span></span><span style="display:flex;"><span>ArtBox: 594.38 0.00 1190.55 839.18
</span></span><span style="display:flex;"><span>File size: 572600 bytes
</span></span><span style="display:flex;"><span>Optimized: no
</span></span><span style="display:flex;"><span>PDF version: 1.6
</span></span></code></pre></div><ul>
<li>In this case the MediaBox is a strange size, and we should use the CropBox
<ul>
<li>I wonder if we can check that from DSpace&hellip;</li>
</ul>
</li>
<li>Apply some corrections from Peter on CGSpace</li>
<li>Meeting with Leroy, Daniel, Francesca, and Maria from Alliance to review their TIP tool and talk about next steps
<ul>
<li>We asked them to do some real submissions (as opposed to &ldquo;I like coffee&rdquo; etc) to test the full breadth of the metadata and controlled vocabularies</li>
</ul>
</li>
<li>Minor work on the CG Core Types spreadsheet to clear up some of the actions and incorporate some of Peter&rsquo;s feedback</li>
<li>After looking at the request patterns in nginx on CGSpace for the past few weeks I see nothing that would explain the high loads we see several times per week (especially Sundays!)
<ul>
<li>So I suspect there is a noisy neighbor, and actually I do see some non-trivial amount of CPU steal in my Munin graphs and <code>iostat</code></li>
<li>I asked Linode to move the instance elsewhere</li>
</ul>
</li>
</ul>
<h2 id="2022-10-22">2022-10-22</h2>
<ul>
<li>Start a harvest on AReS</li>
</ul>
<h2 id="2022-10-24">2022-10-24</h2>
<ul>
<li>Peter sent me some corrections for affiliations:</li>
</ul>
<div class="highlight"><pre tabindex="0" style="color:#f8f8f2;background-color:#272822;-moz-tab-size:4;-o-tab-size:4;tab-size:4;"><code class="language-console" data-lang="console"><span style="display:flex;"><span>$ cat 2022-10-24-affiliations.csv
</span></span><span style="display:flex;"><span>cg.contributor.affiliation,correct
</span></span><span style="display:flex;"><span>Wageningen University and Research Centre,Wageningen University &amp; Research
</span></span><span style="display:flex;"><span>Wageningen University and Research,Wageningen University &amp; Research
</span></span><span style="display:flex;"><span>Wageningen University,Wageningen University &amp; Research
</span></span><span style="display:flex;"><span>$ ./ilri/fix-metadata-values.py -i 2022-10-24-affiliations.csv -db dspace -u dspace -p <span style="color:#e6db74">&#39;fuuu&#39;</span> -f cg.contributor.affiliation -m <span style="color:#ae81ff">211</span> -t correct -d
</span></span></code></pre></div><ul>
<li>Add ORCID identifier for Claudia Arndt on CGSpace and tag her existing items</li>
<li>Linode responded to my request last week and said they don&rsquo;t think that the culprit here is CPU steal, but that they would move us to another host anyways
<ul>
<li>I still need to check the Munin graphs</li>
</ul>
</li>
</ul>
<h2 id="2022-10-25">2022-10-25</h2>
<ul>
<li>Upload some changes to items on CGSpace for Peter</li>
<li>Start a full Discovery index on CGSpace:</li>
</ul>
<div class="highlight"><pre tabindex="0" style="color:#f8f8f2;background-color:#272822;-moz-tab-size:4;-o-tab-size:4;tab-size:4;"><code class="language-console" data-lang="console"><span style="display:flex;"><span>$ time chrt -b <span style="color:#ae81ff">0</span> ionice -c2 -n7 nice -n19 dspace index-discovery -b
</span></span><span style="display:flex;"><span><span style="color:#960050;background-color:#1e0010">
</span></span></span><span style="display:flex;"><span><span style="color:#960050;background-color:#1e0010"></span>real 226m40.463s
</span></span><span style="display:flex;"><span>user 132m6.511s
</span></span><span style="display:flex;"><span>sys 3m15.077s
</span></span></code></pre></div><h2 id="2022-10-26">2022-10-26</h2>
<ul>
<li>We published the <a href="https://hdl.handle.net/10568/125167">infographic</a> and <a href="https://www.ilri.org/news/celebrating-open-access-cgspace">blog post</a> to mark CGSpace&rsquo;s 100,000th item
<ul>
<li>I generated a high-quality thumbnail using ImageMagick in order to Tweet it:</li>
</ul>
</li>
</ul>
<div class="highlight"><pre tabindex="0" style="color:#f8f8f2;background-color:#272822;-moz-tab-size:4;-o-tab-size:4;tab-size:4;"><code class="language-console" data-lang="console"><span style="display:flex;"><span>$ convert -density <span style="color:#ae81ff">144</span> 10568-125167.pdf<span style="color:#ae81ff">\[</span>0<span style="color:#ae81ff">\]</span> -thumbnail x1200 /tmp/10568-125167.pdf.png
</span></span><span style="display:flex;"><span>$ pngquant /tmp/10568-125167.pdf.png
</span></span></code></pre></div><ul>
<li>Spent some time looking at the MediaBox / CropBox thing in DSpace&rsquo;s <code>ImageMagickThumbnailFilter.java</code>
<ul>
<li>We need to make sure to put <code>-define pdf:use-cropbox=true</code> before we specify the input file or else it will not have any effect</li>
</ul>
</li>
</ul>
<h2 id="2022-10-27">2022-10-27</h2>
<ul>
<li>I found out that we can use <a href="https://pdfcpu.io/boxes/boxes_remove.html#examples">pdfcpu to remove the CropBox from a PDF</a> for testing:</li>
</ul>
<div class="highlight"><pre tabindex="0" style="color:#f8f8f2;background-color:#272822;-moz-tab-size:4;-o-tab-size:4;tab-size:4;"><code class="language-console" data-lang="console"><span style="display:flex;"><span>$ pdfcpu box rem -- <span style="color:#e6db74">&#34;crop&#34;</span> in.pdf out.pdf
</span></span></code></pre></div><ul>
<li>I filed <a href="https://github.com/DSpace/DSpace/issues/8549">an issue on DSpace</a> for the ImageMagick <code>CropBox</code> problem
<ul>
<li>I decided that this is a bug that should be fixed separately from the &ldquo;improving thumbnail quality&rdquo; issue</li>
<li>I made <a href="https://github.com/DSpace/DSpace/pull/8550">a pull request</a> to fix the <code>CropBox</code> issue</li>
</ul>
</li>
<li>I did more work on my <a href="https://github.com/alanorth/improved-dspace-thumbnails/">improved-dspace-thumbnails</a> microsite to complement the DSpace thumbnail pull requests
<ul>
<li>I am updating it to recommend using the PDF cropbox and &ldquo;supersampling&rdquo; with a higher density than 72</li>
<li>I measured execution time of ImageMagick with <code>time</code> and found that the higher-density mode takes about five times longer on average</li>
<li>I measured the <a href="https://stackoverflow.com/a/131346">maximum heap memory of ImageMagick with Valgrind and Massif</a>:</li>
</ul>
</li>
</ul>
<div class="highlight"><pre tabindex="0" style="color:#f8f8f2;background-color:#272822;-moz-tab-size:4;-o-tab-size:4;tab-size:4;"><code class="language-console" data-lang="console"><span style="display:flex;"><span>$ valgrind --tool<span style="color:#f92672">=</span>massif magick convert ...
</span></span></code></pre></div><ul>
<li>Then I checked the results for each set of default DSpace thumbnail runs and &ldquo;improved&rdquo; thumbnail runs using <code>ms_print</code> (hacky way to get the max heap, I know):</li>
</ul>
<div class="highlight"><pre tabindex="0" style="color:#f8f8f2;background-color:#272822;-moz-tab-size:4;-o-tab-size:4;tab-size:4;"><code class="language-console" data-lang="console"><span style="display:flex;"><span>$ <span style="color:#66d9ef">for</span> file in memory-dspace/massif.out.49*; <span style="color:#66d9ef">do</span> ms_print <span style="color:#e6db74">&#34;</span>$file<span style="color:#e6db74">&#34;</span> | grep -A1 <span style="color:#e6db74">&#34; MB&#34;</span> | tail -n1 | sed <span style="color:#e6db74">&#39;s/\^.*//&#39;</span>; <span style="color:#66d9ef">done</span>
</span></span><span style="display:flex;"><span>15.87
</span></span><span style="display:flex;"><span>16.06
</span></span><span style="display:flex;"><span>21.26
</span></span><span style="display:flex;"><span>15.88
</span></span><span style="display:flex;"><span>20.01
</span></span><span style="display:flex;"><span>15.85
</span></span><span style="display:flex;"><span>20.06
</span></span><span style="display:flex;"><span>16.04
</span></span><span style="display:flex;"><span>15.87
</span></span><span style="display:flex;"><span>15.87
</span></span><span style="display:flex;"><span>20.02
</span></span><span style="display:flex;"><span>15.87
</span></span><span style="display:flex;"><span>15.86
</span></span><span style="display:flex;"><span>19.92
</span></span><span style="display:flex;"><span>10.89
</span></span><span style="display:flex;"><span>$ <span style="color:#66d9ef">for</span> file in memory-improved/massif.out.5*; <span style="color:#66d9ef">do</span> ms_print <span style="color:#e6db74">&#34;</span>$file<span style="color:#e6db74">&#34;</span> | grep -A1 <span style="color:#e6db74">&#34; MB&#34;</span> | tail -n1 | sed <span style="color:#e6db74">&#39;s/\^.*//&#39;</span>; <span style="color:#66d9ef">done</span>
</span></span><span style="display:flex;"><span>245.3
</span></span><span style="display:flex;"><span>245.5
</span></span><span style="display:flex;"><span>298.6
</span></span><span style="display:flex;"><span>245.3
</span></span><span style="display:flex;"><span>306.8
</span></span><span style="display:flex;"><span>245.2
</span></span><span style="display:flex;"><span>306.9
</span></span><span style="display:flex;"><span>245.5
</span></span><span style="display:flex;"><span>245.2
</span></span><span style="display:flex;"><span>245.3
</span></span><span style="display:flex;"><span>306.8
</span></span><span style="display:flex;"><span>245.3
</span></span><span style="display:flex;"><span>244.9
</span></span><span style="display:flex;"><span>306.3
</span></span><span style="display:flex;"><span>165.6
</span></span></code></pre></div><ul>
<li>Ouch, this shows that it takes about <em>fifteen times</em> more memory to do the &ldquo;4x&rdquo; density of 288!
<ul>
<li>It seems more reasonable to use a &ldquo;2x&rdquo; density of 144:</li>
</ul>
</li>
</ul>
<div class="highlight"><pre tabindex="0" style="color:#f8f8f2;background-color:#272822;-moz-tab-size:4;-o-tab-size:4;tab-size:4;"><code class="language-console" data-lang="console"><span style="display:flex;"><span>$ <span style="color:#66d9ef">for</span> file in memory-improved-144/*; <span style="color:#66d9ef">do</span> ms_print <span style="color:#e6db74">&#34;</span>$file<span style="color:#e6db74">&#34;</span> | grep -A1 <span style="color:#e6db74">&#34; MB&#34;</span> | tail -n1 | sed <span style="color:#e6db74">&#39;s/\^.*//&#39;</span>; <span style="color:#66d9ef">done</span>
</span></span><span style="display:flex;"><span>61.80
</span></span><span style="display:flex;"><span>62.00
</span></span><span style="display:flex;"><span>76.76
</span></span><span style="display:flex;"><span>61.82
</span></span><span style="display:flex;"><span>77.43
</span></span><span style="display:flex;"><span>61.77
</span></span><span style="display:flex;"><span>77.48
</span></span><span style="display:flex;"><span>61.98
</span></span><span style="display:flex;"><span>61.76
</span></span><span style="display:flex;"><span>61.81
</span></span><span style="display:flex;"><span>77.44
</span></span><span style="display:flex;"><span>61.81
</span></span><span style="display:flex;"><span>61.69
</span></span><span style="display:flex;"><span>77.16
</span></span><span style="display:flex;"><span>41.84
</span></span></code></pre></div><ul>
<li>There&rsquo;s a really cool visualizer called massif-visualizer, but it isn&rsquo;t easy to parse</li>
</ul>
<h2 id="2022-10-28">2022-10-28</h2>
<ul>
<li>I finalized the code for the ImageMagick density change and made a <a href="https://github.com/DSpace/DSpace/pull/8553">pull request</a> against DSpace 7.x</li>
</ul>
<h2 id="2022-10-29">2022-10-29</h2>
<ul>
<li>Start a harvest on AReS</li>
</ul>
<h2 id="2022-10-31">2022-10-31</h2>
<ul>
<li>Tag version 6.1 of cgspace-java-helpers: <a href="https://github.com/ilri/cgspace-java-helpers/releases/tag/v6.1">https://github.com/ilri/cgspace-java-helpers/releases/tag/v6.1</a>
<ul>
<li>I also pushed a more recent <code>6.1-SNAPSHOT</code> version to Maven Central via OSSRH</li>
<li>I should probably push a non SNAPSHOT but I don&rsquo;t have time to figure that out in Maven</li>
</ul>
</li>
<li>Add some new items on CGSpace and update others for Peter</li>
<li>Email Mishell from CIP about their <a href="https://cgspace.cgiar.org/handle/10568/125218">old theses</a> which are using Creative Commons licenses
<ul>
<li>They said it&rsquo;s OK so I updated all sixteen items in that collection</li>
</ul>
</li>
<li>Move the &ldquo;MEL submissions&rdquo; collection on CGSpace from ICARDA&rsquo;s community to the Initiatives community</li>
<li>Meeting with Peter and Abenet about ongoing CGSpace action points</li>
<li>I created the authorizations for Alliance&rsquo;s TIP tool to submit on CGSpace</li>
</ul>
<!-- raw HTML omitted -->
</article>
</div> <!-- /.blog-main -->
<aside class="col-sm-3 ml-auto blog-sidebar">
<section class="sidebar-module">
<h4>Recent Posts</h4>
<ol class="list-unstyled">
2025-01-03 12:37:39 +03:00
<li><a href="/cgspace-notes/2025-01/">January, 2025</a></li>
2024-12-04 16:27:49 +03:00
<li><a href="/cgspace-notes/2024-12/">December, 2024</a></li>
2024-11-19 10:40:23 +03:00
<li><a href="/cgspace-notes/2024-11/">November, 2024</a></li>
2024-10-03 11:51:44 +03:00
<li><a href="/cgspace-notes/2024-10/">October, 2024</a></li>
2024-09-09 10:20:09 +03:00
<li><a href="/cgspace-notes/2024-09/">September, 2024</a></li>
2023-07-04 08:03:36 +03:00
</ol>
</section>
<section class="sidebar-module">
<h4>Links</h4>
<ol class="list-unstyled">
<li><a href="https://cgspace.cgiar.org">CGSpace</a></li>
<li><a href="https://dspacetest.cgiar.org">DSpace Test</a></li>
<li><a href="https://github.com/ilri/DSpace">CGSpace @ GitHub</a></li>
</ol>
</section>
</aside>
</div> <!-- /.row -->
</div> <!-- /.container -->
<footer class="blog-footer">
<p dir="auto">
Blog template created by <a href="https://twitter.com/mdo">@mdo</a>, ported to Hugo by <a href='https://twitter.com/mralanorth'>@mralanorth</a>.
</p>
<p>
<a href="#">Back to top</a>
</p>
</footer>
</body>
</html>