forked from antonis.lempesis/dnet-hadoop
avoid NPEs
This commit is contained in:
parent
74b185d07b
commit
7c3041b276
|
@ -941,28 +941,36 @@ public class GraphCleaningFunctions extends CleaningFunctions {
|
||||||
}
|
}
|
||||||
|
|
||||||
private static Qualifier getMetaResourceType(final List<Instance> instances, final VocabularyGroup vocs) {
|
private static Qualifier getMetaResourceType(final List<Instance> instances, final VocabularyGroup vocs) {
|
||||||
|
return Optional
|
||||||
|
.ofNullable(instances)
|
||||||
|
.map(ii -> {
|
||||||
|
if (vocs.vocabularyExists(OPENAIRE_META_RESOURCE_TYPE)) {
|
||||||
|
Optional<InstanceTypeMapping> itm = ii
|
||||||
|
.stream()
|
||||||
|
.filter(Objects::nonNull)
|
||||||
|
.flatMap(
|
||||||
|
i -> Optional
|
||||||
|
.ofNullable(i.getInstanceTypeMapping())
|
||||||
|
.map(Collection::stream)
|
||||||
|
.orElse(Stream.empty()))
|
||||||
|
.filter(t -> OPENAIRE_COAR_RESOURCE_TYPES_3_1.equals(t.getVocabularyName()))
|
||||||
|
.findFirst();
|
||||||
|
|
||||||
if (vocs.vocabularyExists(OPENAIRE_META_RESOURCE_TYPE)) {
|
if (!itm.isPresent() || Objects.isNull(itm.get().getTypeCode())) {
|
||||||
Optional<InstanceTypeMapping> itm = instances
|
return null;
|
||||||
.stream()
|
} else {
|
||||||
.flatMap(
|
final String typeCode = itm.get().getTypeCode();
|
||||||
i -> Optional.ofNullable(i.getInstanceTypeMapping()).map(Collection::stream).orElse(Stream.empty()))
|
return Optional
|
||||||
.filter(t -> OPENAIRE_COAR_RESOURCE_TYPES_3_1.equals(t.getVocabularyName()))
|
.ofNullable(vocs.lookupTermBySynonym(OPENAIRE_META_RESOURCE_TYPE, typeCode))
|
||||||
.findFirst();
|
.orElseThrow(
|
||||||
|
() -> new IllegalStateException("unable to find a synonym for '" + typeCode + "' in " +
|
||||||
if (!itm.isPresent() || Objects.isNull(itm.get().getTypeCode())) {
|
OPENAIRE_META_RESOURCE_TYPE));
|
||||||
return null;
|
}
|
||||||
} else {
|
} else {
|
||||||
final String typeCode = itm.get().getTypeCode();
|
throw new IllegalStateException("vocabulary '" + OPENAIRE_META_RESOURCE_TYPE + "' not available");
|
||||||
return Optional
|
}
|
||||||
.ofNullable(vocs.lookupTermBySynonym(OPENAIRE_META_RESOURCE_TYPE, typeCode))
|
})
|
||||||
.orElseThrow(
|
.orElse(null);
|
||||||
() -> new IllegalStateException("unable to find a synonym for '" + typeCode + "' in " +
|
|
||||||
OPENAIRE_META_RESOURCE_TYPE));
|
|
||||||
}
|
|
||||||
} else {
|
|
||||||
throw new IllegalStateException("vocabulary '" + OPENAIRE_META_RESOURCE_TYPE + "' not available");
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue