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

46 lines
1.2 KiB
Java
Raw Normal View History

package eu.dnetlib.dhp.broker.oa.matchers.relatedProjects;
2020-07-01 08:42:39 +02:00
import java.util.ArrayList;
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.OaBrokerMainEntity;
import eu.dnetlib.broker.objects.OaBrokerProject;
import eu.dnetlib.dhp.broker.model.Topic;
import eu.dnetlib.dhp.broker.oa.matchers.UpdateMatcher;
2020-07-01 08:42:39 +02:00
import eu.dnetlib.dhp.broker.oa.util.BrokerConstants;
2020-06-22 08:51:31 +02:00
public class EnrichMoreProject extends UpdateMatcher<OaBrokerProject> {
public EnrichMoreProject() {
2020-06-26 11:20:45 +02:00
super(20,
2020-06-12 09:47:55 +02:00
prj -> Topic.ENRICH_MORE_PROJECT,
(p, prj) -> p.getProjects().add(prj),
2020-07-03 11:48:12 +02:00
prj -> prj.getOpenaireId());
}
@Override
2020-06-22 08:51:31 +02:00
protected List<OaBrokerProject> findDifferences(final OaBrokerMainEntity source,
final OaBrokerMainEntity target) {
2020-07-07 15:37:13 +02:00
if (target.getProjects().size() >= BrokerConstants.MAX_LIST_SIZE) {
return new ArrayList<>();
}
2020-07-01 08:42:39 +02:00
2020-06-16 12:34:13 +02:00
final Set<String> existingProjects = target
2020-06-11 11:25:18 +02:00
.getProjects()
.stream()
2020-07-03 11:48:12 +02:00
.map(p -> p.getOpenaireId())
.collect(Collectors.toSet());
2020-06-16 12:34:13 +02:00
return source
2020-06-11 11:25:18 +02:00
.getProjects()
.stream()
2020-07-03 11:48:12 +02:00
.filter(p -> !existingProjects.contains(p.getOpenaireId()))
.collect(Collectors.toList());
}
}