diff --git a/CHANGES.md b/CHANGES.md
new file mode 100644
index 0000000..e229bec
--- /dev/null
+++ b/CHANGES.md
@@ -0,0 +1,16 @@
+
+
+## Changelog
+
+| **Version** | **Changes** | **Readiness** |
+|---|---|---|
+| 2.7.14 | [Graph model]
Relation types are now inspired by the Datacite definitions https://schema.datacite.org/meta/kernel-4.4/doc/DataCite-MetadataKernel_v4.4.pdf
The changes involve the values stored in `relation.subRelType` and `relation.relClass`:
Updated the casing of the following terms (`relation.relClass`):
1. `isSupplementTo -> IsSupplementTo` / `isSupplementedBy -> IsSupplementedBy`
2. `isPartOf -> IsPartOf` / `hasPart -> HasPart`
3. `cites -> Cites` / `isCitedBy -> IsCitedBy`
4. `reviews -> Reviews` / `isReviewedBy -> IsReviewedBy`
Added the following terms [`subRelType: relClass / relClass (inverse)`]:
1. `relationship: References / IsReferencedBy`
2. `relationship: IsIdenticalTo`
3. `relationship: IsContinuedBy / Continues`
4. `relationship: IsDocumentedBy / Documents`
5. `relationship: Documents / IsDocumentedBy`
6. `relationship: IsCompiledBy / Compiles`
7. `version: IsPreviousVersionOf / IsNewVersionOf`
8. `version: IsSourceOf / IsDerivedFrom`
9. `version: IsVariantFormOf / IsOriginalFormOf`
10. `version: IsObsoletedBy / Obsoletes`
11. `version: IsVersionOf / HasVersion` | beta |
+| 2.6.14 | [Scholexplorer]
1. Added model classes for Scholexplorer, package `eu.dnetlib.dhp.schema.sx` | production |
+| 2.6.13 | 1. `Result.mergeFrom` handles field `dateOfAcceptance` | production |
+| 2.5.12 | 1. delegating the date parsing to https://github.com/sisyphsu/dateparser | production |
+| 2.5.[11-9] | 1. support for more date formats
2. enable the possibility to extend the date formats used to parse `Relation.validationDate` | production |
+| 2.4.8 | 1. added constant for ORCID datasource name | production |
+| 2.4.7 | refactoring | production |
+| 2.3.6 | [Aggregation]
1. introduced MetadataStoreManager (MdSM) model classes| production |
+| 2.2.5 | [Graph model]
1. introduced fields `Instance.pid` and `Instance.alternateIdentifier`
2. `LicenseComparator` renamed as `AccessRightComparator`
3. introduced `AccessRight` model class defining the `OpenAccessRoute` field to keep track of the OpenAccess color at the `Instance` level
4. `ExternalReference` cleanup (removed description, added alternateLabel(s))
5. added several ModelConstants
[Aggregation]
7. introduced MDStore record model classes
8. Introduced ORCID specific model classes | production |
+| 2.2.4 | 1. ORCID specific model classes backported in the version used in PROD
2. added constant for dnet:externalReference_typologies
3. added constant for ORCID datasource name
4. `Result.mergeFrom` handles field `dateOfAcceptance` | production |
diff --git a/README.md b/README.md
index 7431cda..52fe9a4 100644
--- a/README.md
+++ b/README.md
@@ -2,10 +2,11 @@ Description of the project
--------------------------
This project defines **object schemas** of the OpenAIRE main entities and the relationships that intercur among them.
Namely it defines the model for
-
-- **research product (result)** which subclasses in publication, dataset, other research product, software
-- **data source** object describing the data provider (institutional repository, aggregators, cris systems)
-- **organization** research bodies managing a data source or participating to a research project
-- **project** research project
+
+- the graph internal representation, defined under the package `eu.dnetlib.dhp.schema.oaf`
+- the public graph dump representations, defined under the package `eu.dnetlib.dhp.schema.dump.oaf`
+- the scholexplorer content representation, defined under the package `eu.dnetlib.dhp.schema.sx`
+- the contents acquired from the netadata aggregation subsystem, defined under the package `eu.dnetlib.dhp.schema.mdstore`
+- the ORCID common schemas, defined under the package `eu.dnetlib.dhp.schema.orcid`
Te serialization of such objects (data store files) are used to pass data between workflow nodes in the processing pipeline.
diff --git a/pom.xml b/pom.xml
index ed53320..f0b6783 100644
--- a/pom.xml
+++ b/pom.xml
@@ -5,7 +5,7 @@
eu.dnetlib.dhp
dhp-schemas
jar
- 2.6.14-SNAPSHOT
+ 2.7.15-SNAPSHOT
diff --git a/src/main/java/eu/dnetlib/dhp/schema/common/ModelConstants.java b/src/main/java/eu/dnetlib/dhp/schema/common/ModelConstants.java
index ddb80ee..b5535fa 100644
--- a/src/main/java/eu/dnetlib/dhp/schema/common/ModelConstants.java
+++ b/src/main/java/eu/dnetlib/dhp/schema/common/ModelConstants.java
@@ -55,54 +55,82 @@ public class ModelConstants {
public static final String SOFTWARE_RESULTTYPE_CLASSID = "software";
public static final String ORP_RESULTTYPE_CLASSID = "other";
- public static final String RESULT_RESULT = "resultResult";
+ public static final String RESULT_RESULT = "resultResult"; // relType
/**
* @deprecated Use {@link ModelConstants#RELATIONSHIP} instead.
*/
@Deprecated
- public static final String PUBLICATION_DATASET = "publicationDataset";
- public static final String IS_RELATED_TO = "isRelatedTo";
- public static final String SUPPLEMENT = "supplement";
- public static final String IS_SUPPLEMENT_TO = "isSupplementTo";
- public static final String IS_SUPPLEMENTED_BY = "isSupplementedBy";
- public static final String PART = "part";
- public static final String IS_PART_OF = "isPartOf";
- public static final String HAS_PART = "hasPart";
- public static final String RELATIONSHIP = "relationship";
- public static final String CITATION = "citation";
- public static final String CITES = "cites";
- public static final String IS_CITED_BY = "isCitedBy";
- public static final String REVIEW = "review"; // subreltype
- public static final String REVIEWS = "reviews";
- public static final String IS_REVIEWED_BY = "isReviewedBy";
+ public static final String PUBLICATION_DATASET = "publicationDataset"; // subreltype
- public static final String RESULT_PROJECT = "resultProject";
- public static final String OUTCOME = "outcome";
+ public static final String SUPPLEMENT = "supplement"; // subreltype
+ public static final String IS_SUPPLEMENT_TO = "IsSupplementTo";
+ public static final String IS_SUPPLEMENTED_BY = "IsSupplementedBy";
+
+ public static final String PART = "part"; // subreltype
+ public static final String IS_PART_OF = "IsPartOf";
+ public static final String HAS_PART = "HasPart";
+
+ public static final String RELATIONSHIP = "relationship"; // subreltype
+
+ public static final String IS_RELATED_TO = "isRelatedTo";
+ public static final String IS_IDENTICAL_TO = "IsIdenticalTo";
+
+ public static final String REFERENCES = "References";
+ public static final String IS_REFERENCED_BY = "IsReferencedBy";
+ public static final String CONTINUES = "Continues";
+ public static final String IS_CONTINUED_BY = "IsContinuedBy";
+ public static final String DOCUMENTS = "Documents";
+ public static final String IS_DOCUMENTED_BY = "IsDocumentedBy";
+ public static final String IS_SOURCE_OF = "IsSourceOf";
+ public static final String IS_DERIVED_FROM = "IsDerivedFrom";
+ public static final String COMPILES = "Compiles";
+ public static final String IS_COMPILED_BY = "IsCompiledBy";
+
+ public static final String CITATION = "citation"; // subreltype
+ public static final String CITES = "Cites";
+ public static final String IS_CITED_BY = "IsCitedBy";
+
+ public static final String REVIEW = "review"; // subreltype
+ public static final String REVIEWS = "Reviews";
+ public static final String IS_REVIEWED_BY = "IsReviewedBy";
+
+ public static final String VERSION = "version"; // subreltype
+ public static final String IS_VERSION_OF = "IsVersionOf";
+ public static final String HAS_VERSION = "HasVersion";
+ public static final String IS_PREVIOUS_VERSION_OF = "IsPreviousVersionOf";
+ public static final String IS_NEW_VERSION_OF = "IsNewVersionOf";
+ public static final String IS_VARIANT_FORM_OF = "IsVariantFormOf";
+ public static final String IS_ORIGINAL_FORM_OF = "IsOriginalFormOf";
+ public static final String IS_OBSOLETED_BY = "IsObsoletedBy";
+ public static final String OBSOLETES = "Obsoletes";
+
+ public static final String RESULT_PROJECT = "resultProject"; // relType
+ public static final String OUTCOME = "outcome"; // subreltype
public static final String IS_PRODUCED_BY = "isProducedBy";
public static final String PRODUCES = "produces";
- public static final String DATASOURCE_ORGANIZATION = "datasourceOrganization";
- public static final String PROVISION = "provision";
+ public static final String DATASOURCE_ORGANIZATION = "datasourceOrganization"; // relType
+ public static final String PROVISION = "provision"; // subreltype
public static final String IS_PROVIDED_BY = "isProvidedBy";
public static final String PROVIDES = "provides";
- public static final String PROJECT_ORGANIZATION = "projectOrganization";
- public static final String PARTICIPATION = "participation";
+ public static final String PROJECT_ORGANIZATION = "projectOrganization"; // relType
+ public static final String PARTICIPATION = "participation"; // subreltype
public static final String HAS_PARTICIPANT = "hasParticipant";
public static final String IS_PARTICIPANT = "isParticipant";
- public static final String RESULT_ORGANIZATION = "resultOrganization";
- public static final String AFFILIATION = "affiliation";
+ public static final String RESULT_ORGANIZATION = "resultOrganization"; // relType
+ public static final String AFFILIATION = "affiliation"; // subreltype
public static final String IS_AUTHOR_INSTITUTION_OF = "isAuthorInstitutionOf";
public static final String HAS_AUTHOR_INSTITUTION = "hasAuthorInstitution";
- public static final String ORG_ORG_RELTYPE = "organizationOrganization";
+ public static final String ORG_ORG_RELTYPE = "organizationOrganization"; // relType
- public static final String DEDUP = "dedup";
+ public static final String DEDUP = "dedup"; // subreltype
public static final String MERGES = "merges";
public static final String IS_MERGED_IN = "isMergedIn";
- public static final String SIMILARITY = "similarity";
+ public static final String SIMILARITY = "similarity"; // subreltype
public static final String IS_SIMILAR_TO = "isSimilarTo";
public static final String IS_DIFFERENT_FROM = "isDifferentFrom";
diff --git a/src/main/java/eu/dnetlib/dhp/schema/oaf/utils/CleaningFunctions.java b/src/main/java/eu/dnetlib/dhp/schema/oaf/utils/CleaningFunctions.java
index 56ee75a..183214c 100644
--- a/src/main/java/eu/dnetlib/dhp/schema/oaf/utils/CleaningFunctions.java
+++ b/src/main/java/eu/dnetlib/dhp/schema/oaf/utils/CleaningFunctions.java
@@ -46,18 +46,27 @@ public class CleaningFunctions {
* @return the PID containing the normalised value.
*/
public static StructuredProperty normalizePidValue(StructuredProperty pid) {
- String value = Optional
- .ofNullable(pid.getValue())
- .map(String::trim)
- .orElseThrow(() -> new IllegalArgumentException("PID value cannot be empty"));
- switch (pid.getQualifier().getClassid()) {
+ pid.setValue(
+ normalizePidValue(
+ pid.getQualifier().getClassid(),
+ pid.getValue()));
- // TODO add cleaning for more PID types as needed
- case "doi":
- pid.setValue(value.toLowerCase().replaceFirst(DOI_PREFIX_REGEX, DOI_PREFIX));
- break;
- }
return pid;
}
+ public static String normalizePidValue(String pidType, String pidValue) {
+ String value = Optional
+ .ofNullable(pidValue)
+ .map(String::trim)
+ .orElseThrow(() -> new IllegalArgumentException("PID value cannot be empty"));
+
+ switch (pidType) {
+
+ // TODO add cleaning for more PID types as needed
+ case "doi":
+ return value.toLowerCase().replaceFirst(DOI_PREFIX_REGEX, DOI_PREFIX);
+ }
+ return value;
+ }
+
}
diff --git a/src/main/java/eu/dnetlib/dhp/schema/oaf/utils/IdentifierFactory.java b/src/main/java/eu/dnetlib/dhp/schema/oaf/utils/IdentifierFactory.java
index 43cdbc1..d0baec5 100644
--- a/src/main/java/eu/dnetlib/dhp/schema/oaf/utils/IdentifierFactory.java
+++ b/src/main/java/eu/dnetlib/dhp/schema/oaf/utils/IdentifierFactory.java
@@ -164,9 +164,7 @@ public class IdentifierFactory implements Serializable {
.stream()
// filter away PIDs provided by a DS that is not considered an authority for the
// given PID Type
- .filter(p -> {
- return shouldFilterPid(collectedFrom, p, mapHandles);
- })
+ .filter(p -> shouldFilterPid(collectedFrom, p, mapHandles))
.map(CleaningFunctions::normalizePidValue)
.filter(CleaningFunctions::pidFilter))
.orElse(Stream.empty());
@@ -193,13 +191,17 @@ public class IdentifierFactory implements Serializable {
}
private static String idFromPid(T entity, StructuredProperty s, boolean md5) {
+ return idFromPid(ModelSupport.getIdPrefix(entity.getClass()), s.getQualifier().getClassid(), s.getValue(), md5);
+ }
+
+ public static String idFromPid(String numericPrefix, String pidType, String pidValue, boolean md5) {
return new StringBuilder()
- .append(ModelSupport.getIdPrefix(entity.getClass()))
- .append(ID_PREFIX_SEPARATOR)
- .append(createPrefix(s.getQualifier().getClassid()))
- .append(ID_SEPARATOR)
- .append(md5 ? md5(s.getValue()) : s.getValue())
- .toString();
+ .append(numericPrefix)
+ .append(ID_PREFIX_SEPARATOR)
+ .append(createPrefix(pidType))
+ .append(ID_SEPARATOR)
+ .append(md5 ? md5(pidValue) : pidValue)
+ .toString();
}
// create the prefix (length = 12)
diff --git a/src/main/java/eu/dnetlib/dhp/schema/scholexplorer/DLIDataset.java b/src/main/java/eu/dnetlib/dhp/schema/scholexplorer/DLIDataset.java
deleted file mode 100644
index 421b4ec..0000000
--- a/src/main/java/eu/dnetlib/dhp/schema/scholexplorer/DLIDataset.java
+++ /dev/null
@@ -1,89 +0,0 @@
-
-package eu.dnetlib.dhp.schema.scholexplorer;
-
-import java.util.ArrayList;
-import java.util.HashMap;
-import java.util.List;
-import java.util.Map;
-
-import org.apache.commons.lang3.StringUtils;
-
-import eu.dnetlib.dhp.schema.oaf.Dataset;
-import eu.dnetlib.dhp.schema.oaf.OafEntity;
-
-public class DLIDataset extends Dataset {
-
- private String originalObjIdentifier;
-
- private List dlicollectedfrom;
-
- private String completionStatus;
-
- public String getCompletionStatus() {
- return completionStatus;
- }
-
- public void setCompletionStatus(String completionStatus) {
- this.completionStatus = completionStatus;
- }
-
- public List getDlicollectedfrom() {
- return dlicollectedfrom;
- }
-
- public void setDlicollectedfrom(List dlicollectedfrom) {
- this.dlicollectedfrom = dlicollectedfrom;
- }
-
- public String getOriginalObjIdentifier() {
- return originalObjIdentifier;
- }
-
- public void setOriginalObjIdentifier(String originalObjIdentifier) {
- this.originalObjIdentifier = originalObjIdentifier;
- }
-
- @Override
- public void mergeFrom(OafEntity e) {
- super.mergeFrom(e);
- DLIDataset p = (DLIDataset) e;
- if (StringUtils.isBlank(completionStatus) && StringUtils.isNotBlank(p.completionStatus))
- completionStatus = p.completionStatus;
- if ("complete".equalsIgnoreCase(p.completionStatus))
- completionStatus = "complete";
- dlicollectedfrom = mergeProvenance(dlicollectedfrom, p.getDlicollectedfrom());
- }
-
- private List mergeProvenance(
- final List a, final List b) {
- Map result = new HashMap<>();
- if (a != null)
- a
- .forEach(
- p -> {
- if (p != null && StringUtils.isNotBlank(p.getId()) && result.containsKey(p.getId())) {
- if ("incomplete".equalsIgnoreCase(result.get(p.getId()).getCompletionStatus())
- && StringUtils.isNotBlank(p.getCompletionStatus())) {
- result.put(p.getId(), p);
- }
-
- } else if (p != null && p.getId() != null && !result.containsKey(p.getId()))
- result.put(p.getId(), p);
- });
- if (b != null)
- b
- .forEach(
- p -> {
- if (p != null && StringUtils.isNotBlank(p.getId()) && result.containsKey(p.getId())) {
- if ("incomplete".equalsIgnoreCase(result.get(p.getId()).getCompletionStatus())
- && StringUtils.isNotBlank(p.getCompletionStatus())) {
- result.put(p.getId(), p);
- }
-
- } else if (p != null && p.getId() != null && !result.containsKey(p.getId()))
- result.put(p.getId(), p);
- });
-
- return new ArrayList<>(result.values());
- }
-}
diff --git a/src/main/java/eu/dnetlib/dhp/schema/scholexplorer/DLIPublication.java b/src/main/java/eu/dnetlib/dhp/schema/scholexplorer/DLIPublication.java
deleted file mode 100644
index c899a89..0000000
--- a/src/main/java/eu/dnetlib/dhp/schema/scholexplorer/DLIPublication.java
+++ /dev/null
@@ -1,87 +0,0 @@
-
-package eu.dnetlib.dhp.schema.scholexplorer;
-
-import java.io.Serializable;
-import java.util.*;
-
-import org.apache.commons.lang3.StringUtils;
-
-import eu.dnetlib.dhp.schema.oaf.OafEntity;
-import eu.dnetlib.dhp.schema.oaf.Publication;
-
-public class DLIPublication extends Publication implements Serializable {
-
- private String originalObjIdentifier;
-
- private List dlicollectedfrom;
-
- private String completionStatus;
-
- public String getCompletionStatus() {
- return completionStatus;
- }
-
- public void setCompletionStatus(String completionStatus) {
- this.completionStatus = completionStatus;
- }
-
- public List getDlicollectedfrom() {
- return dlicollectedfrom;
- }
-
- public void setDlicollectedfrom(List dlicollectedfrom) {
- this.dlicollectedfrom = dlicollectedfrom;
- }
-
- public String getOriginalObjIdentifier() {
- return originalObjIdentifier;
- }
-
- public void setOriginalObjIdentifier(String originalObjIdentifier) {
- this.originalObjIdentifier = originalObjIdentifier;
- }
-
- @Override
- public void mergeFrom(OafEntity e) {
- super.mergeFrom(e);
- DLIPublication p = (DLIPublication) e;
- if (StringUtils.isBlank(completionStatus) && StringUtils.isNotBlank(p.completionStatus))
- completionStatus = p.completionStatus;
- if ("complete".equalsIgnoreCase(p.completionStatus))
- completionStatus = "complete";
- dlicollectedfrom = mergeProvenance(dlicollectedfrom, p.getDlicollectedfrom());
- }
-
- private List mergeProvenance(
- final List a, final List b) {
- Map result = new HashMap<>();
- if (a != null)
- a
- .forEach(
- p -> {
- if (p != null && StringUtils.isNotBlank(p.getId()) && result.containsKey(p.getId())) {
- if ("incomplete".equalsIgnoreCase(result.get(p.getId()).getCompletionStatus())
- && StringUtils.isNotBlank(p.getCompletionStatus())) {
- result.put(p.getId(), p);
- }
-
- } else if (p != null && p.getId() != null && !result.containsKey(p.getId()))
- result.put(p.getId(), p);
- });
- if (b != null)
- b
- .forEach(
- p -> {
- if (p != null && StringUtils.isNotBlank(p.getId()) && result.containsKey(p.getId())) {
- if ("incomplete".equalsIgnoreCase(result.get(p.getId()).getCompletionStatus())
- && StringUtils.isNotBlank(p.getCompletionStatus())) {
- result.put(p.getId(), p);
- }
-
- } else if (p != null && p.getId() != null && !result.containsKey(p.getId()))
- result.put(p.getId(), p);
- });
-
- return new ArrayList<>(result.values());
- }
-}
diff --git a/src/main/java/eu/dnetlib/dhp/schema/scholexplorer/DLIUnknown.java b/src/main/java/eu/dnetlib/dhp/schema/scholexplorer/DLIUnknown.java
deleted file mode 100644
index 5da5994..0000000
--- a/src/main/java/eu/dnetlib/dhp/schema/scholexplorer/DLIUnknown.java
+++ /dev/null
@@ -1,132 +0,0 @@
-
-package eu.dnetlib.dhp.schema.scholexplorer;
-
-import java.io.Serializable;
-import java.util.*;
-import java.util.stream.Collectors;
-
-import org.apache.commons.lang3.StringUtils;
-
-import eu.dnetlib.dhp.schema.oaf.Oaf;
-import eu.dnetlib.dhp.schema.oaf.StructuredProperty;
-
-public class DLIUnknown extends Oaf implements Serializable {
-
- private String id;
-
- private List pid;
-
- private String dateofcollection;
-
- private String dateoftransformation;
-
- private List dlicollectedfrom;
-
- private String completionStatus = "incomplete";
-
- public String getCompletionStatus() {
- return completionStatus;
- }
-
- public void setCompletionStatus(String completionStatus) {
- this.completionStatus = completionStatus;
- }
-
- public List getDlicollectedfrom() {
- return dlicollectedfrom;
- }
-
- public void setDlicollectedfrom(List dlicollectedfrom) {
- this.dlicollectedfrom = dlicollectedfrom;
- }
-
- public String getId() {
- return id;
- }
-
- public void setId(String id) {
- this.id = id;
- }
-
- public List getPid() {
- return pid;
- }
-
- public void setPid(List pid) {
- this.pid = pid;
- }
-
- public String getDateofcollection() {
- return dateofcollection;
- }
-
- public void setDateofcollection(String dateofcollection) {
- this.dateofcollection = dateofcollection;
- }
-
- public String getDateoftransformation() {
- return dateoftransformation;
- }
-
- public void setDateoftransformation(String dateoftransformation) {
- this.dateoftransformation = dateoftransformation;
- }
-
- public void mergeFrom(DLIUnknown p) {
- if ("complete".equalsIgnoreCase(p.completionStatus))
- completionStatus = "complete";
- dlicollectedfrom = mergeProvenance(dlicollectedfrom, p.getDlicollectedfrom());
- if (StringUtils.isEmpty(id) && StringUtils.isNoneEmpty(p.getId()))
- id = p.getId();
- if (StringUtils.isEmpty(dateofcollection) && StringUtils.isNoneEmpty(p.getDateofcollection()))
- dateofcollection = p.getDateofcollection();
-
- if (StringUtils.isEmpty(dateoftransformation) && StringUtils.isNoneEmpty(p.getDateoftransformation()))
- dateofcollection = p.getDateoftransformation();
- pid = mergeLists(pid, p.getPid());
- }
-
- protected List mergeLists(final List... lists) {
-
- return Arrays
- .stream(lists)
- .filter(Objects::nonNull)
- .flatMap(List::stream)
- .filter(Objects::nonNull)
- .distinct()
- .collect(Collectors.toList());
- }
-
- private List mergeProvenance(
- final List a, final List b) {
- Map result = new HashMap<>();
- if (a != null)
- a
- .forEach(
- p -> {
- if (p != null && StringUtils.isNotBlank(p.getId()) && result.containsKey(p.getId())) {
- if ("incomplete".equalsIgnoreCase(result.get(p.getId()).getCompletionStatus())
- && StringUtils.isNotBlank(p.getCompletionStatus())) {
- result.put(p.getId(), p);
- }
-
- } else if (p != null && p.getId() != null && !result.containsKey(p.getId()))
- result.put(p.getId(), p);
- });
- if (b != null)
- b
- .forEach(
- p -> {
- if (p != null && StringUtils.isNotBlank(p.getId()) && result.containsKey(p.getId())) {
- if ("incomplete".equalsIgnoreCase(result.get(p.getId()).getCompletionStatus())
- && StringUtils.isNotBlank(p.getCompletionStatus())) {
- result.put(p.getId(), p);
- }
-
- } else if (p != null && p.getId() != null && !result.containsKey(p.getId()))
- result.put(p.getId(), p);
- });
-
- return new ArrayList<>(result.values());
- }
-}
diff --git a/src/main/java/eu/dnetlib/dhp/schema/scholexplorer/ProvenaceInfo.java b/src/main/java/eu/dnetlib/dhp/schema/scholexplorer/ProvenaceInfo.java
deleted file mode 100644
index b1188f0..0000000
--- a/src/main/java/eu/dnetlib/dhp/schema/scholexplorer/ProvenaceInfo.java
+++ /dev/null
@@ -1,47 +0,0 @@
-
-package eu.dnetlib.dhp.schema.scholexplorer;
-
-import java.io.Serializable;
-
-public class ProvenaceInfo implements Serializable {
-
- private String id;
-
- private String name;
-
- private String completionStatus;
-
- private String collectionMode = "collected";
-
- public String getId() {
- return id;
- }
-
- public void setId(String id) {
- this.id = id;
- }
-
- public String getName() {
- return name;
- }
-
- public void setName(String name) {
- this.name = name;
- }
-
- public String getCompletionStatus() {
- return completionStatus;
- }
-
- public void setCompletionStatus(String completionStatus) {
- this.completionStatus = completionStatus;
- }
-
- public String getCollectionMode() {
- return collectionMode;
- }
-
- public void setCollectionMode(String collectionMode) {
- this.collectionMode = collectionMode;
- }
-}
diff --git a/src/main/java/eu/dnetlib/dhp/schema/scholexplorer/OafUtils.scala b/src/main/java/eu/dnetlib/dhp/schema/sx/OafUtils.scala
similarity index 98%
rename from src/main/java/eu/dnetlib/dhp/schema/scholexplorer/OafUtils.scala
rename to src/main/java/eu/dnetlib/dhp/schema/sx/OafUtils.scala
index b0cd344..b34a951 100644
--- a/src/main/java/eu/dnetlib/dhp/schema/scholexplorer/OafUtils.scala
+++ b/src/main/java/eu/dnetlib/dhp/schema/sx/OafUtils.scala
@@ -1,4 +1,4 @@
-package eu.dnetlib.dhp.schema.scholexplorer
+package eu.dnetlib.dhp.schema.sx
import eu.dnetlib.dhp.schema.common.ModelConstants
import eu.dnetlib.dhp.schema.oaf.{AccessRight, DataInfo, Field, KeyValue, Qualifier, StructuredProperty}
diff --git a/src/main/java/eu/dnetlib/dhp/schema/sx/scholix/Scholix.java b/src/main/java/eu/dnetlib/dhp/schema/sx/scholix/Scholix.java
new file mode 100644
index 0000000..ca01cb5
--- /dev/null
+++ b/src/main/java/eu/dnetlib/dhp/schema/sx/scholix/Scholix.java
@@ -0,0 +1,77 @@
+
+package eu.dnetlib.dhp.schema.sx.scholix;
+
+import java.io.Serializable;
+import java.util.List;
+
+public class Scholix implements Serializable {
+ private String publicationDate;
+
+ private List publisher;
+
+ private List linkprovider;
+
+ private ScholixRelationship relationship;
+
+ private ScholixResource source;
+
+ private ScholixResource target;
+
+ private String identifier;
+
+ public String getPublicationDate() {
+ return publicationDate;
+ }
+
+ public void setPublicationDate(String publicationDate) {
+ this.publicationDate = publicationDate;
+ }
+
+ public List getPublisher() {
+ return publisher;
+ }
+
+ public void setPublisher(List publisher) {
+ this.publisher = publisher;
+ }
+
+ public List getLinkprovider() {
+ return linkprovider;
+ }
+
+ public void setLinkprovider(List linkprovider) {
+ this.linkprovider = linkprovider;
+ }
+
+ public ScholixRelationship getRelationship() {
+ return relationship;
+ }
+
+ public void setRelationship(ScholixRelationship relationship) {
+ this.relationship = relationship;
+ }
+
+ public ScholixResource getSource() {
+ return source;
+ }
+
+ public void setSource(ScholixResource source) {
+ this.source = source;
+ }
+
+ public ScholixResource getTarget() {
+ return target;
+ }
+
+ public void setTarget(ScholixResource target) {
+ this.target = target;
+ }
+
+ public String getIdentifier() {
+ return identifier;
+ }
+
+ public void setIdentifier(String identifier) {
+ this.identifier = identifier;
+ }
+}
diff --git a/src/main/java/eu/dnetlib/dhp/schema/sx/scholix/ScholixCollectedFrom.java b/src/main/java/eu/dnetlib/dhp/schema/sx/scholix/ScholixCollectedFrom.java
new file mode 100644
index 0000000..e8e4551
--- /dev/null
+++ b/src/main/java/eu/dnetlib/dhp/schema/sx/scholix/ScholixCollectedFrom.java
@@ -0,0 +1,45 @@
+
+package eu.dnetlib.dhp.schema.sx.scholix;
+
+import java.io.Serializable;
+
+public class ScholixCollectedFrom implements Serializable {
+
+ private ScholixEntityId provider;
+ private String provisionMode;
+ private String completionStatus;
+
+ public ScholixCollectedFrom() {
+ }
+
+ public ScholixCollectedFrom(
+ ScholixEntityId provider, String provisionMode, String completionStatus) {
+ this.provider = provider;
+ this.provisionMode = provisionMode;
+ this.completionStatus = completionStatus;
+ }
+
+ public ScholixEntityId getProvider() {
+ return provider;
+ }
+
+ public void setProvider(ScholixEntityId provider) {
+ this.provider = provider;
+ }
+
+ public String getProvisionMode() {
+ return provisionMode;
+ }
+
+ public void setProvisionMode(String provisionMode) {
+ this.provisionMode = provisionMode;
+ }
+
+ public String getCompletionStatus() {
+ return completionStatus;
+ }
+
+ public void setCompletionStatus(String completionStatus) {
+ this.completionStatus = completionStatus;
+ }
+}
diff --git a/src/main/java/eu/dnetlib/dhp/schema/sx/scholix/ScholixEntityId.java b/src/main/java/eu/dnetlib/dhp/schema/sx/scholix/ScholixEntityId.java
new file mode 100644
index 0000000..e4bcee3
--- /dev/null
+++ b/src/main/java/eu/dnetlib/dhp/schema/sx/scholix/ScholixEntityId.java
@@ -0,0 +1,34 @@
+
+package eu.dnetlib.dhp.schema.sx.scholix;
+
+import java.io.Serializable;
+import java.util.List;
+
+public class ScholixEntityId implements Serializable {
+ private String name;
+ private List identifiers;
+
+ public ScholixEntityId() {
+ }
+
+ public ScholixEntityId(String name, List identifiers) {
+ this.name = name;
+ this.identifiers = identifiers;
+ }
+
+ public String getName() {
+ return name;
+ }
+
+ public void setName(String name) {
+ this.name = name;
+ }
+
+ public List getIdentifiers() {
+ return identifiers;
+ }
+
+ public void setIdentifiers(List identifiers) {
+ this.identifiers = identifiers;
+ }
+}
diff --git a/src/main/java/eu/dnetlib/dhp/schema/sx/scholix/ScholixIdentifier.java b/src/main/java/eu/dnetlib/dhp/schema/sx/scholix/ScholixIdentifier.java
new file mode 100644
index 0000000..8fc8b08
--- /dev/null
+++ b/src/main/java/eu/dnetlib/dhp/schema/sx/scholix/ScholixIdentifier.java
@@ -0,0 +1,59 @@
+
+package eu.dnetlib.dhp.schema.sx.scholix;
+
+import java.io.Serializable;
+import java.util.Objects;
+
+public class ScholixIdentifier implements Serializable {
+ private String identifier;
+ private String schema;
+ private String url;
+
+ public ScholixIdentifier() {
+ }
+
+ public ScholixIdentifier(String identifier, String schema, String url) {
+ this.identifier = identifier;
+ this.schema = schema;
+ this.url = url;
+ }
+
+
+ public String getUrl() {
+ return url;
+ }
+
+ public void setUrl(String url) {
+ this.url = url;
+ }
+
+
+ @Override
+ public boolean equals(Object o) {
+ if (this == o) return true;
+ if (o == null || getClass() != o.getClass()) return false;
+ ScholixIdentifier that = (ScholixIdentifier) o;
+ return identifier.equals(that.identifier) && schema.equals(that.schema);
+ }
+
+ @Override
+ public int hashCode() {
+ return Objects.hash(identifier, schema);
+ }
+
+ public String getIdentifier() {
+ return identifier;
+ }
+
+ public void setIdentifier(String identifier) {
+ this.identifier = identifier;
+ }
+
+ public String getSchema() {
+ return schema;
+ }
+
+ public void setSchema(String schema) {
+ this.schema = schema;
+ }
+}
diff --git a/src/main/java/eu/dnetlib/dhp/schema/sx/scholix/ScholixRelationship.java b/src/main/java/eu/dnetlib/dhp/schema/sx/scholix/ScholixRelationship.java
new file mode 100644
index 0000000..b2e0e3f
--- /dev/null
+++ b/src/main/java/eu/dnetlib/dhp/schema/sx/scholix/ScholixRelationship.java
@@ -0,0 +1,43 @@
+
+package eu.dnetlib.dhp.schema.sx.scholix;
+
+import java.io.Serializable;
+
+public class ScholixRelationship implements Serializable {
+ private String name;
+ private String schema;
+ private String inverse;
+
+ public ScholixRelationship() {
+ }
+
+ public ScholixRelationship(String name, String schema, String inverse) {
+ this.name = name;
+ this.schema = schema;
+ this.inverse = inverse;
+ }
+
+ public String getName() {
+ return name;
+ }
+
+ public void setName(String name) {
+ this.name = name;
+ }
+
+ public String getSchema() {
+ return schema;
+ }
+
+ public void setSchema(String schema) {
+ this.schema = schema;
+ }
+
+ public String getInverse() {
+ return inverse;
+ }
+
+ public void setInverse(String inverse) {
+ this.inverse = inverse;
+ }
+}
diff --git a/src/main/java/eu/dnetlib/dhp/schema/sx/scholix/ScholixResource.java b/src/main/java/eu/dnetlib/dhp/schema/sx/scholix/ScholixResource.java
new file mode 100644
index 0000000..569b1f3
--- /dev/null
+++ b/src/main/java/eu/dnetlib/dhp/schema/sx/scholix/ScholixResource.java
@@ -0,0 +1,90 @@
+
+package eu.dnetlib.dhp.schema.sx.scholix;
+
+import java.io.Serializable;
+import java.util.List;
+
+public class ScholixResource implements Serializable {
+
+ private List identifier;
+ private String dnetIdentifier;
+ private String objectType;
+ private String objectSubType;
+ private String title;
+ private List creator;
+ private String publicationDate;
+ private List publisher;
+ private List collectedFrom;
+
+ public List getIdentifier() {
+ return identifier;
+ }
+
+ public void setIdentifier(List identifier) {
+ this.identifier = identifier;
+ }
+
+ public String getDnetIdentifier() {
+ return dnetIdentifier;
+ }
+
+ public void setDnetIdentifier(String dnetIdentifier) {
+ this.dnetIdentifier = dnetIdentifier;
+ }
+
+ public String getObjectType() {
+ return objectType;
+ }
+
+ public void setObjectType(String objectType) {
+ this.objectType = objectType;
+ }
+
+ public String getObjectSubType() {
+ return objectSubType;
+ }
+
+ public void setObjectSubType(String objectSubType) {
+ this.objectSubType = objectSubType;
+ }
+
+ public String getTitle() {
+ return title;
+ }
+
+ public void setTitle(String title) {
+ this.title = title;
+ }
+
+ public List getCreator() {
+ return creator;
+ }
+
+ public void setCreator(List creator) {
+ this.creator = creator;
+ }
+
+ public String getPublicationDate() {
+ return publicationDate;
+ }
+
+ public void setPublicationDate(String publicationDate) {
+ this.publicationDate = publicationDate;
+ }
+
+ public List getPublisher() {
+ return publisher;
+ }
+
+ public void setPublisher(List publisher) {
+ this.publisher = publisher;
+ }
+
+ public List getCollectedFrom() {
+ return collectedFrom;
+ }
+
+ public void setCollectedFrom(List collectedFrom) {
+ this.collectedFrom = collectedFrom;
+ }
+}
diff --git a/src/main/java/eu/dnetlib/dhp/schema/sx/summary/CollectedFromType.java b/src/main/java/eu/dnetlib/dhp/schema/sx/summary/CollectedFromType.java
new file mode 100644
index 0000000..61df72f
--- /dev/null
+++ b/src/main/java/eu/dnetlib/dhp/schema/sx/summary/CollectedFromType.java
@@ -0,0 +1,58 @@
+
+package eu.dnetlib.dhp.schema.sx.summary;
+
+import java.io.Serializable;
+import java.util.Objects;
+
+public class CollectedFromType implements Serializable {
+
+ private String datasourceName;
+ private String datasourceId;
+ private String completionStatus;
+
+ public CollectedFromType() {
+ }
+
+ public CollectedFromType(String datasourceName, String datasourceId, String completionStatus) {
+ this.datasourceName = datasourceName;
+ this.datasourceId = datasourceId;
+ this.completionStatus = completionStatus;
+ }
+
+ @Override
+ public boolean equals(Object o) {
+ if (this == o) return true;
+ if (o == null || getClass() != o.getClass()) return false;
+ CollectedFromType that = (CollectedFromType) o;
+ return Objects.equals(datasourceName, that.datasourceName) && Objects.equals(datasourceId, that.datasourceId);
+ }
+
+ @Override
+ public int hashCode() {
+ return Objects.hash(datasourceName, datasourceId);
+ }
+
+ public String getDatasourceName() {
+ return datasourceName;
+ }
+
+ public void setDatasourceName(String datasourceName) {
+ this.datasourceName = datasourceName;
+ }
+
+ public String getDatasourceId() {
+ return datasourceId;
+ }
+
+ public void setDatasourceId(String datasourceId) {
+ this.datasourceId = datasourceId;
+ }
+
+ public String getCompletionStatus() {
+ return completionStatus;
+ }
+
+ public void setCompletionStatus(String completionStatus) {
+ this.completionStatus = completionStatus;
+ }
+}
diff --git a/src/main/java/eu/dnetlib/dhp/schema/sx/summary/SchemeValue.java b/src/main/java/eu/dnetlib/dhp/schema/sx/summary/SchemeValue.java
new file mode 100644
index 0000000..a58bc26
--- /dev/null
+++ b/src/main/java/eu/dnetlib/dhp/schema/sx/summary/SchemeValue.java
@@ -0,0 +1,33 @@
+
+package eu.dnetlib.dhp.schema.sx.summary;
+
+import java.io.Serializable;
+
+public class SchemeValue implements Serializable {
+ private String scheme;
+ private String value;
+
+ public SchemeValue() {
+ }
+
+ public SchemeValue(String scheme, String value) {
+ this.scheme = scheme;
+ this.value = value;
+ }
+
+ public String getScheme() {
+ return scheme;
+ }
+
+ public void setScheme(String scheme) {
+ this.scheme = scheme;
+ }
+
+ public String getValue() {
+ return value;
+ }
+
+ public void setValue(String value) {
+ this.value = value;
+ }
+}
diff --git a/src/main/java/eu/dnetlib/dhp/schema/sx/summary/ScholixSummary.java b/src/main/java/eu/dnetlib/dhp/schema/sx/summary/ScholixSummary.java
new file mode 100644
index 0000000..8da25dc
--- /dev/null
+++ b/src/main/java/eu/dnetlib/dhp/schema/sx/summary/ScholixSummary.java
@@ -0,0 +1,140 @@
+
+package eu.dnetlib.dhp.schema.sx.summary;
+
+import java.io.Serializable;
+import java.util.List;
+
+import com.fasterxml.jackson.annotation.JsonProperty;
+
+import eu.dnetlib.dhp.schema.sx.scholix.ScholixIdentifier;
+
+public class ScholixSummary implements Serializable {
+ private String id;
+ private List localIdentifier;
+ private Typology typology;
+ private String subType;
+ private List title;
+ private List author;
+ private List date;
+ private String description;
+ private List subject;
+ private List publisher;
+ private long relatedPublications;
+ private long relatedDatasets;
+ private long relatedUnknown;
+ private List datasources;
+
+ public String getId() {
+ return id;
+ }
+
+ public void setId(String id) {
+ this.id = id;
+ }
+
+ public List getLocalIdentifier() {
+ return localIdentifier;
+ }
+
+ public void setLocalIdentifier(List localIdentifier) {
+ this.localIdentifier = localIdentifier;
+ }
+
+ public Typology getTypology() {
+ return typology;
+ }
+
+ public void setTypology(Typology typology) {
+ this.typology = typology;
+ }
+
+ public List getTitle() {
+ return title;
+ }
+
+ public void setTitle(List title) {
+ this.title = title;
+ }
+
+ public List getAuthor() {
+ return author;
+ }
+
+ public void setAuthor(List author) {
+ this.author = author;
+ }
+
+ public List getDate() {
+ return date;
+ }
+
+ public void setDate(List date) {
+ this.date = date;
+ }
+
+ @JsonProperty("abstract")
+ public String getDescription() {
+ return description;
+ }
+
+ @JsonProperty("abstract")
+ public void setDescription(String description) {
+ this.description = description;
+ }
+
+ public List getSubject() {
+ return subject;
+ }
+
+ public void setSubject(List subject) {
+ this.subject = subject;
+ }
+
+ public List getPublisher() {
+ return publisher;
+ }
+
+ public void setPublisher(List publisher) {
+ this.publisher = publisher;
+ }
+
+ public long getRelatedPublications() {
+ return relatedPublications;
+ }
+
+ public void setRelatedPublications(long relatedPublications) {
+ this.relatedPublications = relatedPublications;
+ }
+
+ public long getRelatedDatasets() {
+ return relatedDatasets;
+ }
+
+ public void setRelatedDatasets(long relatedDatasets) {
+ this.relatedDatasets = relatedDatasets;
+ }
+
+ public long getRelatedUnknown() {
+ return relatedUnknown;
+ }
+
+ public void setRelatedUnknown(long relatedUnknown) {
+ this.relatedUnknown = relatedUnknown;
+ }
+
+ public List getDatasources() {
+ return datasources;
+ }
+
+ public void setDatasources(List datasources) {
+ this.datasources = datasources;
+ }
+
+ public String getSubType() {
+ return subType;
+ }
+
+ public void setSubType(String subType) {
+ this.subType = subType;
+ }
+}
diff --git a/src/main/java/eu/dnetlib/dhp/schema/sx/summary/Typology.java b/src/main/java/eu/dnetlib/dhp/schema/sx/summary/Typology.java
new file mode 100644
index 0000000..e39f312
--- /dev/null
+++ b/src/main/java/eu/dnetlib/dhp/schema/sx/summary/Typology.java
@@ -0,0 +1,8 @@
+
+package eu.dnetlib.dhp.schema.sx.summary;
+
+import java.io.Serializable;
+
+public enum Typology implements Serializable {
+ dataset, publication, unknown
+}
diff --git a/src/test/java/eu/dnetlib/dhp/schema/scholexplorer/DLItest.java b/src/test/java/eu/dnetlib/dhp/schema/scholexplorer/DLItest.java
deleted file mode 100644
index 16ce152..0000000
--- a/src/test/java/eu/dnetlib/dhp/schema/scholexplorer/DLItest.java
+++ /dev/null
@@ -1,84 +0,0 @@
-
-package eu.dnetlib.dhp.schema.scholexplorer;
-
-import java.io.IOException;
-import java.util.Arrays;
-import java.util.Collections;
-
-import org.junit.jupiter.api.Test;
-
-import com.fasterxml.jackson.core.JsonProcessingException;
-import com.fasterxml.jackson.databind.DeserializationFeature;
-import com.fasterxml.jackson.databind.ObjectMapper;
-import com.fasterxml.jackson.databind.SerializationFeature;
-
-import eu.dnetlib.dhp.schema.common.ModelConstants;
-import eu.dnetlib.dhp.schema.oaf.Qualifier;
-import eu.dnetlib.dhp.schema.oaf.StructuredProperty;
-
-public class DLItest {
-
- @Test
- public void testMergePublication() throws JsonProcessingException {
- DLIPublication a1 = new DLIPublication();
- a1.setPid(Arrays.asList(createSP("123456", "pdb", ModelConstants.DNET_PID_TYPES)));
- a1.setTitle(Collections.singletonList(createSP("Un Titolo", "title", "dnetTitle")));
- a1.setDlicollectedfrom(Arrays.asList(createCollectedFrom("znd", "Zenodo", "complete")));
- a1.setCompletionStatus("complete");
-
- DLIPublication a = new DLIPublication();
- a
- .setPid(
- Arrays
- .asList(
- createSP("10.11", "doi", ModelConstants.DNET_PID_TYPES),
- createSP("123456", "pdb", ModelConstants.DNET_PID_TYPES)));
- a.setTitle(Collections.singletonList(createSP("A Title", "title", "dnetTitle")));
- a
- .setDlicollectedfrom(
- Arrays
- .asList(
- createCollectedFrom("dct", "datacite", "complete"),
- createCollectedFrom("dct", "datacite", "incomplete")));
- a.setCompletionStatus("incomplete");
-
- a.mergeFrom(a1);
-
- ObjectMapper mapper = new ObjectMapper();
- System.out.println(mapper.writeValueAsString(a));
- }
-
- @Test
- public void testDeserialization() throws IOException {
-
- final String json = "{\"dataInfo\":{\"invisible\":false,\"inferred\":null,\"deletedbyinference\":false,\"trust\":\"0.9\",\"inferenceprovenance\":null,\"provenanceaction\":null},\"lastupdatetimestamp\":null,\"id\":\"60|bd9352547098929a394655ad1a44a479\",\"originalId\":[\"bd9352547098929a394655ad1a44a479\"],\"collectedfrom\":[{\"key\":\"dli_________::datacite\",\"value\":\"Datasets in Datacite\",\"dataInfo\":null,\"blank\":false}],\"pid\":[{\"value\":\"10.7925/DRS1.DUCHAS_5078760\",\"qualifier\":{\"classid\":\"doi\",\"classname\":\"doi\",\"schemeid\":\"dnet:pid_types\",\"schemename\":\"dnet:pid_types\",\"blank\":false},\"dataInfo\":null}],\"dateofcollection\":\"2020-01-09T08:29:31.885Z\",\"dateoftransformation\":null,\"extraInfo\":null,\"oaiprovenance\":null,\"author\":[{\"fullname\":\"Cathail, S. Ó\",\"name\":null,\"surname\":null,\"rank\":null,\"pid\":null,\"affiliation\":null},{\"fullname\":\"Donnell, Breda Mc\",\"name\":null,\"surname\":null,\"rank\":null,\"pid\":null,\"affiliation\":null},{\"fullname\":\"Ireland. Department of Arts, Culture, and the Gaeltacht\",\"name\":null,\"surname\":null,\"rank\":null,\"pid\":null,\"affiliation\":null},{\"fullname\":\"University College Dublin\",\"name\":null,\"surname\":null,\"rank\":null,\"pid\":null,\"affiliation\":null},{\"fullname\":\"National Folklore Foundation\",\"name\":null,\"surname\":null,\"rank\":null,\"pid\":null,\"affiliation\":null},{\"fullname\":\"Cathail, S. Ó\",\"name\":null,\"surname\":null,\"rank\":null,\"pid\":null,\"affiliation\":null},{\"fullname\":\"Donnell, Breda Mc\",\"name\":null,\"surname\":null,\"rank\":null,\"pid\":null,\"affiliation\":null}],\"resulttype\":null,\"language\":null,\"country\":null,\"subject\":[{\"value\":\"Recreation\",\"qualifier\":{\"classid\":\"dnet:subject\",\"classname\":\"dnet:subject\",\"schemeid\":\"unknown\",\"schemename\":\"unknown\",\"blank\":false},\"dataInfo\":null},{\"value\":\"Entertainments and recreational activities\",\"qualifier\":{\"classid\":\"dnet:subject\",\"classname\":\"dnet:subject\",\"schemeid\":\"unknown\",\"schemename\":\"unknown\",\"blank\":false},\"dataInfo\":null},{\"value\":\"Siamsaíocht agus caitheamh aimsire\",\"qualifier\":{\"classid\":\"dnet:subject\",\"classname\":\"dnet:subject\",\"schemeid\":\"unknown\",\"schemename\":\"unknown\",\"blank\":false},\"dataInfo\":null}],\"title\":[{\"value\":\"Games We Play\",\"qualifier\":null,\"dataInfo\":null}],\"relevantdate\":[{\"value\":\"1938-09-28\",\"qualifier\":{\"classid\":\"date\",\"classname\":\"date\",\"schemeid\":\"dnet::date\",\"schemename\":\"dnet::date\",\"blank\":false},\"dataInfo\":null}],\"description\":[{\"value\":\"Story collected by Breda Mc Donnell, a student at Tenure school (Tinure, Co. Louth) (no informant identified).\",\"dataInfo\":null}],\"dateofacceptance\":null,\"publisher\":{\"value\":\"University College Dublin\",\"dataInfo\":null},\"embargoenddate\":null,\"source\":null,\"fulltext\":null,\"format\":null,\"contributor\":null,\"resourcetype\":null,\"coverage\":null,\"refereed\":null,\"context\":null,\"processingchargeamount\":null,\"processingchargecurrency\":null,\"externalReference\":null,\"instance\":[],\"storagedate\":null,\"device\":null,\"size\":null,\"version\":null,\"lastmetadataupdate\":null,\"metadataversionnumber\":null,\"geolocation\":null,\"dlicollectedfrom\":[{\"id\":\"dli_________::datacite\",\"name\":\"Datasets in Datacite\",\"completionStatus\":\"complete\",\"collectionMode\":\"resolved\"}],\"completionStatus\":\"complete\"}";
-
- ObjectMapper mapper = new ObjectMapper();
- mapper.configure(DeserializationFeature.FAIL_ON_UNKNOWN_PROPERTIES, false);
- DLIDataset dliDataset = mapper.readValue(json, DLIDataset.class);
- mapper.enable(SerializationFeature.INDENT_OUTPUT);
- System.out.println(mapper.writeValueAsString(dliDataset));
- }
-
- private ProvenaceInfo createCollectedFrom(
- final String id, final String name, final String completionStatus) {
- ProvenaceInfo p = new ProvenaceInfo();
- p.setId(id);
- p.setName(name);
- p.setCompletionStatus(completionStatus);
- return p;
- }
-
- private StructuredProperty createSP(
- final String value, final String className, final String schemeName) {
- StructuredProperty p = new StructuredProperty();
- p.setValue(value);
- Qualifier schema = new Qualifier();
- schema.setClassname(className);
- schema.setClassid(className);
- schema.setSchemename(schemeName);
- schema.setSchemeid(schemeName);
- p.setQualifier(schema);
- return p;
- }
-}