2019-07-19 11:31:23 +02:00
|
|
|
package eu.dnetlib.repo.manager.service;
|
|
|
|
|
2022-11-30 19:58:08 +01:00
|
|
|
import eu.dnetlib.enabling.datasources.common.AggregationInfo;
|
2023-02-15 17:31:13 +01:00
|
|
|
import eu.dnetlib.repo.manager.domain.MetricsNumbers;
|
2022-12-01 14:19:29 +01:00
|
|
|
import eu.dnetlib.repo.manager.domain.RepositorySnippet;
|
|
|
|
import eu.dnetlib.repo.manager.domain.RepositorySummaryInfo;
|
2019-11-28 12:25:56 +01:00
|
|
|
import eu.dnetlib.repo.manager.domain.broker.BrowseEntry;
|
2022-08-05 10:48:16 +02:00
|
|
|
import eu.dnetlib.repo.manager.exception.BrokerException;
|
|
|
|
import eu.dnetlib.repo.manager.exception.RepositoryServiceException;
|
2022-11-30 19:58:08 +01:00
|
|
|
import eu.dnetlib.repo.manager.utils.DateUtils;
|
2023-01-11 17:50:31 +01:00
|
|
|
import org.slf4j.Logger;
|
|
|
|
import org.slf4j.LoggerFactory;
|
2019-07-19 11:31:23 +02:00
|
|
|
import org.springframework.beans.factory.annotation.Autowired;
|
|
|
|
import org.springframework.stereotype.Service;
|
|
|
|
|
|
|
|
import java.util.ArrayList;
|
|
|
|
import java.util.List;
|
|
|
|
|
|
|
|
@Service("dashboardService")
|
|
|
|
public class DashboardServiceImpl implements DashboardService {
|
|
|
|
|
2023-01-11 17:50:31 +01:00
|
|
|
private static final Logger logger = LoggerFactory.getLogger(DashboardServiceImpl.class);
|
2019-07-19 11:31:23 +02:00
|
|
|
|
|
|
|
@Autowired
|
|
|
|
private RepositoryService repositoryService;
|
|
|
|
|
2022-12-14 16:08:11 +01:00
|
|
|
@Autowired
|
|
|
|
private AggregationService aggregationService;
|
|
|
|
|
2019-07-19 11:31:23 +02:00
|
|
|
@Autowired
|
|
|
|
private BrokerService brokerService;
|
|
|
|
|
|
|
|
@Override
|
2019-07-25 13:54:21 +02:00
|
|
|
public List<RepositorySummaryInfo> getRepositoriesSummaryInfo(String userEmail,
|
|
|
|
String page,
|
2021-07-21 13:51:18 +02:00
|
|
|
String size) {
|
2019-07-19 11:31:23 +02:00
|
|
|
|
|
|
|
List<RepositorySummaryInfo> repositorySummaryInfoList = new ArrayList<>();
|
|
|
|
|
2019-07-25 13:54:21 +02:00
|
|
|
try {
|
2021-07-21 13:51:18 +02:00
|
|
|
List<RepositorySnippet> repositoriesOfUser = repositoryService.getRepositoriesSnippetsOfUser(userEmail, page, size);
|
2023-02-02 17:54:46 +01:00
|
|
|
for (RepositorySnippet repository : repositoriesOfUser)
|
|
|
|
{
|
|
|
|
String repoId = repository.getId();
|
|
|
|
String repoOfficialName = repository.getOfficialname();
|
|
|
|
|
2021-07-21 13:51:18 +02:00
|
|
|
RepositorySummaryInfo repositorySummaryInfo = new RepositorySummaryInfo();
|
2023-02-02 17:54:46 +01:00
|
|
|
repositorySummaryInfo.setId(repoId);
|
|
|
|
repositorySummaryInfo.setRepositoryName(repoOfficialName);
|
2021-07-21 13:51:18 +02:00
|
|
|
repositorySummaryInfo.setLogoURL(repository.getLogoUrl());
|
|
|
|
|
|
|
|
//TODO getRepositoryAggregations returns only the 20 more recent items. Is it positive that we will find an indexed version there?
|
2023-02-02 17:54:46 +01:00
|
|
|
boolean isIndexedVersionFound = false;
|
2021-07-21 13:51:18 +02:00
|
|
|
long start = System.currentTimeMillis();
|
2023-02-02 17:54:46 +01:00
|
|
|
List<AggregationInfo> aggregationInfoList = aggregationService.getRepositoryAggregations(repoId, 0, 20);
|
2022-12-01 17:37:03 +01:00
|
|
|
for (AggregationInfo aggregationInfo : aggregationInfoList) {
|
|
|
|
if (aggregationInfo.isIndexedVersion()) {
|
|
|
|
repositorySummaryInfo.setRecordsCollected(aggregationInfo.getNumberOfRecords());
|
|
|
|
repositorySummaryInfo.setLastIndexedVersion(DateUtils.toDate(aggregationInfo.getDate()));
|
2023-02-02 17:54:46 +01:00
|
|
|
isIndexedVersionFound = true;
|
2021-07-21 13:51:18 +02:00
|
|
|
break;
|
2019-07-25 13:54:21 +02:00
|
|
|
}
|
2021-07-21 13:51:18 +02:00
|
|
|
}
|
|
|
|
long end = System.currentTimeMillis();
|
2023-02-02 17:54:46 +01:00
|
|
|
if ( isIndexedVersionFound )
|
|
|
|
logger.debug("Got repo aggregations in " + (end - start) + "ms");
|
|
|
|
else
|
|
|
|
logger.warn("Could not find repo aggregations, after " + (end - start) + "ms!");
|
2019-07-19 11:31:23 +02:00
|
|
|
|
2021-07-21 13:51:18 +02:00
|
|
|
try {
|
2023-02-15 17:31:13 +01:00
|
|
|
MetricsNumbers metricsNumbers = repositoryService.getMetricsInfoForRepository(repoId).getMetricsNumbers();
|
|
|
|
repositorySummaryInfo.setTotalDownloads(metricsNumbers.getTotalDownloads());
|
|
|
|
repositorySummaryInfo.setTotalViews(metricsNumbers.getTotalViews());
|
2021-07-21 13:51:18 +02:00
|
|
|
} catch (RepositoryServiceException e) {
|
2023-02-02 17:54:46 +01:00
|
|
|
logger.error("Exception getting metrics info for repository: {}, {} ", repoId, repoOfficialName, e);
|
2021-07-21 13:51:18 +02:00
|
|
|
}
|
2019-07-19 11:31:23 +02:00
|
|
|
|
2021-07-21 13:51:18 +02:00
|
|
|
try {
|
2023-02-02 17:54:46 +01:00
|
|
|
List<BrowseEntry> events = brokerService.getTopicsForDatasource(repoOfficialName);
|
2021-07-21 13:51:18 +02:00
|
|
|
Long totalEvents = 0L;
|
|
|
|
for (BrowseEntry browseEntry : events)
|
|
|
|
totalEvents += browseEntry.getSize();
|
|
|
|
repositorySummaryInfo.setEnrichmentEvents(totalEvents);
|
|
|
|
} catch (BrokerException e) {
|
2023-02-02 17:54:46 +01:00
|
|
|
logger.error("Exception getting broker events for repository: {}, {} ", repoId, repoOfficialName, e);
|
2019-07-25 13:54:21 +02:00
|
|
|
}
|
2019-07-19 11:31:23 +02:00
|
|
|
|
2021-07-21 13:51:18 +02:00
|
|
|
repositorySummaryInfoList.add(repositorySummaryInfo);
|
|
|
|
}
|
2019-07-25 13:54:21 +02:00
|
|
|
} catch (Exception e) {
|
|
|
|
logger.error("Something baad happened!", e);
|
|
|
|
}
|
2019-07-19 11:31:23 +02:00
|
|
|
|
|
|
|
return repositorySummaryInfoList;
|
|
|
|
}
|
|
|
|
}
|