forked from DSpace/DSpace
-
Notifications
You must be signed in to change notification settings - Fork 73
Expand file tree
/
Copy pathUpdateCrisMetricsInSolrDocService.java
More file actions
81 lines (72 loc) · 3.37 KB
/
UpdateCrisMetricsInSolrDocService.java
File metadata and controls
81 lines (72 loc) · 3.37 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
/**
* The contents of this file are subject to the license and copyright
* detailed in the LICENSE and NOTICE files at the root of the source
* tree and available online at
*
* http://www.dspace.org/license/
*/
package org.dspace.metrics;
import java.sql.SQLException;
import java.util.List;
import java.util.UUID;
import org.apache.commons.lang3.StringUtils;
import org.apache.logging.log4j.LogManager;
import org.apache.logging.log4j.Logger;
import org.apache.solr.client.solrj.impl.BaseHttpSolrClient.RemoteSolrException;
import org.dspace.app.metrics.CrisMetrics;
import org.dspace.app.metrics.service.CrisMetricsService;
import org.dspace.app.metrics.service.CrisMetricsServiceImpl;
import org.dspace.core.Context;
import org.dspace.discovery.IndexingService;
import org.dspace.discovery.SearchServiceException;
import org.dspace.scripts.handler.DSpaceRunnableHandler;
import org.dspace.services.ConfigurationService;
import org.dspace.utils.DSpace;
/**
* @author Mykhaylo Boychuk (mykhaylo.boychuk at 4science.it)
*/
public class UpdateCrisMetricsInSolrDocService {
private static final Logger log = LogManager.getLogger(UpdateCrisMetricsInSolrDocService.class);
private ConfigurationService configurationService = new DSpace().getConfigurationService();
private CrisMetricsService crisMetricsService = new DSpace().getServiceManager().getServiceByName(
CrisMetricsServiceImpl.class.getName(), CrisMetricsServiceImpl.class);
private IndexingService crisIndexingService = new DSpace().getServiceManager().getServiceByName(
IndexingService.class.getName(), IndexingService.class);
public void performUpdate(Context context, DSpaceRunnableHandler handler, boolean optimize) {
performUpdate(context, handler, optimize, null);
}
public void performUpdate(Context context, DSpaceRunnableHandler handler, boolean optimize, UUID resourceUuid) {
try {
int offset = 0;
int limit = configurationService.getIntProperty("metrics.indexer.page", 1000);
handler.logInfo("Metric update start");
List<CrisMetrics> metrics;
while (!(metrics = (resourceUuid == null
? crisMetricsService.findAllLast(context, limit, offset)
: crisMetricsService.findLastMetricsByResourceId(context, resourceUuid, limit, offset)
)).isEmpty()) {
for (CrisMetrics metric : metrics) {
try {
crisIndexingService.updateMetrics(context, metric);
} catch (RemoteSolrException rse) {
if (StringUtils.containsIgnoreCase(rse.getMessage(), "Did not find child ID Item-")) {
log.error(rse.getMessage());
} else {
throw rse;
}
}
}
offset += limit;
}
handler.logInfo("Metric update end");
if (optimize) {
handler.logInfo("Starting solr optimization");
crisIndexingService.optimize();
handler.logInfo("Solr optimization performed");
}
} catch (SQLException | SearchServiceException e) {
log.error(e.getMessage(), e);
throw new RuntimeException(e.getMessage(), e);
}
}
}