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

42 lines
1.1 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.List;
import java.util.Set;
import java.util.stream.Collectors;
2020-06-22 08:51:31 +02:00
import eu.dnetlib.broker.objects.OaBrokerInstance;
import eu.dnetlib.broker.objects.OaBrokerMainEntity;
2020-05-15 12:25:37 +02:00
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;
2020-06-22 08:51:31 +02:00
public class EnrichMoreOpenAccess extends UpdateMatcher<OaBrokerInstance> {
2020-05-15 12:25:37 +02:00
public EnrichMoreOpenAccess() {
2020-06-26 11:20:45 +02:00
super(20,
2020-06-12 09:47:55 +02:00
i -> Topic.ENRICH_MORE_OA_VERSION,
(p, i) -> p.getInstances().add(i),
2020-06-22 08:51:31 +02:00
OaBrokerInstance::getUrl);
2020-05-15 12:25:37 +02:00
}
@Override
2020-06-22 08:51:31 +02:00
protected List<OaBrokerInstance> findDifferences(final OaBrokerMainEntity source,
final OaBrokerMainEntity target) {
2020-05-15 12:25:37 +02:00
final Set<String> urls = target
2020-06-16 12:34:13 +02:00
.getInstances()
2020-05-15 12:25:37 +02:00
.stream()
2020-06-16 12:34:13 +02:00
.filter(i -> i.getLicense().equals(BrokerConstants.OPEN_ACCESS))
2020-05-15 12:25:37 +02:00
.map(i -> i.getUrl())
.collect(Collectors.toSet());
return source
2020-06-16 12:34:13 +02:00
.getInstances()
2020-05-15 12:25:37 +02:00
.stream()
2020-06-16 12:34:13 +02:00
.filter(i -> i.getLicense().equals(BrokerConstants.OPEN_ACCESS))
2020-05-15 12:25:37 +02:00
.filter(i -> !urls.contains(i.getUrl()))
.collect(Collectors.toList());
}
}