dnet-hadoop/dhp-workflows/dhp-broker-events/src/main/java/eu/dnetlib/dhp/broker/oa/matchers/simple/EnrichMissingOpenAccess.java

50 lines
1.3 KiB
Java
Raw Normal View History

2020-05-15 12:25:37 +02:00
package eu.dnetlib.dhp.broker.oa.matchers.simple;
2020-05-15 12:25:37 +02:00
import java.util.Arrays;
import java.util.List;
import java.util.stream.Collectors;
import eu.dnetlib.broker.objects.Instance;
import eu.dnetlib.dhp.broker.model.Topic;
import eu.dnetlib.dhp.broker.oa.matchers.UpdateMatcher;
2020-05-15 12:25:37 +02:00
import eu.dnetlib.dhp.broker.oa.util.BrokerConstants;
import eu.dnetlib.dhp.broker.oa.util.ConversionUtils;
2020-06-11 11:25:18 +02:00
import eu.dnetlib.dhp.broker.oa.util.aggregators.withRels.ResultWithRelations;
2020-05-15 12:25:37 +02:00
2020-06-11 11:25:18 +02:00
public class EnrichMissingOpenAccess extends UpdateMatcher<Instance> {
2020-05-15 12:25:37 +02:00
public EnrichMissingOpenAccess() {
2020-06-12 09:47:55 +02:00
super(true,
i -> Topic.ENRICH_MISSING_OA_VERSION,
(p, i) -> p.getInstances().add(i),
Instance::getUrl);
2020-05-15 12:25:37 +02:00
}
@Override
2020-06-12 09:47:55 +02:00
protected List<Instance> findDifferences(final ResultWithRelations source,
final ResultWithRelations target) {
2020-05-15 12:25:37 +02:00
final long count = target
2020-06-11 11:25:18 +02:00
.getResult()
2020-05-15 12:25:37 +02:00
.getInstance()
.stream()
.map(i -> i.getAccessright().getClassid())
.filter(right -> right.equals(BrokerConstants.OPEN_ACCESS))
.count();
2020-06-10 12:11:16 +02:00
if (count > 0) {
return Arrays.asList();
}
2020-05-15 12:25:37 +02:00
return source
2020-06-11 11:25:18 +02:00
.getResult()
2020-05-15 12:25:37 +02:00
.getInstance()
.stream()
.filter(i -> i.getAccessright().getClassid().equals(BrokerConstants.OPEN_ACCESS))
.map(ConversionUtils::oafInstanceToBrokerInstances)
.flatMap(List::stream)
2020-05-15 12:25:37 +02:00
.collect(Collectors.toList());
}
}