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

45 lines
1.3 KiB
Java
Raw Normal View History

package eu.dnetlib.dhp.broker.oa.matchers.relatedProjects;
import java.util.List;
import java.util.Set;
import java.util.stream.Collectors;
import eu.dnetlib.dhp.broker.model.Topic;
import eu.dnetlib.dhp.broker.oa.matchers.UpdateMatcher;
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.RelatedProject;
import eu.dnetlib.dhp.broker.oa.util.aggregators.withRels.ResultWithRelations;
import eu.dnetlib.dhp.schema.oaf.Project;
2020-06-11 11:25:18 +02:00
public class EnrichMoreProject extends UpdateMatcher<eu.dnetlib.broker.objects.Project> {
public EnrichMoreProject() {
2020-06-12 09:47:55 +02:00
super(true,
prj -> Topic.ENRICH_MORE_PROJECT,
(p, prj) -> p.getProjects().add(prj),
prj -> prj.getFunder() + "::" + prj.getFundingProgram() + prj.getCode());
}
@Override
2020-06-12 09:47:55 +02:00
protected List<eu.dnetlib.broker.objects.Project> findDifferences(final ResultWithRelations source,
final ResultWithRelations target) {
2020-06-08 08:32:22 +02:00
final Set<String> existingProjects = source
2020-06-11 11:25:18 +02:00
.getProjects()
.stream()
2020-06-11 11:25:18 +02:00
.map(RelatedProject::getRelProject)
.map(Project::getId)
.collect(Collectors.toSet());
2020-06-08 08:32:22 +02:00
return target
2020-06-11 11:25:18 +02:00
.getProjects()
.stream()
2020-06-11 11:25:18 +02:00
.map(RelatedProject::getRelProject)
.filter(p -> !existingProjects.contains(p.getId()))
.map(ConversionUtils::oafProjectToBrokerProject)
.collect(Collectors.toList());
}
}