WIP: Extend the AriadnePlus KB with info about country #5

Draft
alessia.bardi wants to merge 5 commits from country into master
12 changed files with 167 additions and 17 deletions

View File

@ -10,7 +10,7 @@
<groupId>eu.dnetlib</groupId> <groupId>eu.dnetlib</groupId>
<artifactId>dnet-ariadneplus-graphdb-publisher</artifactId> <artifactId>dnet-ariadneplus-graphdb-publisher</artifactId>
<packaging>jar</packaging> <packaging>jar</packaging>
<version>4.2.1-SNAPSHOT</version> <version>4.2.1-COUNTRY-SNAPSHOT</version>
<scm> <scm>
<developerConnection>scm:svn:https://svn.driver.research-infrastructures.eu/driver/dnet50/modules/dnet-ariadneplus-graphdb-publisher/trunk</developerConnection> <developerConnection>scm:svn:https://svn.driver.research-infrastructures.eu/driver/dnet50/modules/dnet-ariadneplus-graphdb-publisher/trunk</developerConnection>
<url>https://github.com/spring-projects/spring-boot/spring-boot-starter-parent/dnet-ariadneplus-graphdb-publisher</url> <url>https://github.com/spring-projects/spring-boot/spring-boot-starter-parent/dnet-ariadneplus-graphdb-publisher</url>

View File

@ -36,6 +36,7 @@ public class AriadnePlusEntry {
private String wasCreated; private String wasCreated;
private List<DigitalImage> digitalImage; private List<DigitalImage> digitalImage;
private List<String> otherId; private List<String> otherId;
private List<CountryInfo> country;
private transient String uniqueIsPartOf; private transient String uniqueIsPartOf;
private transient String typeURI; private transient String typeURI;
@ -318,4 +319,12 @@ public class AriadnePlusEntry {
} }
this.otherId.add(otherId); this.otherId.add(otherId);
} }
public List<CountryInfo> getCountry() {
return country;
}
public void setCountry(List<CountryInfo> country) {
this.country = country;
}
} }

View File

@ -0,0 +1,31 @@
package eu.dnetlib.ariadneplus.elasticsearch.model;
import com.google.gson.Gson;
public class CountryInfo {
private String id;
private String name;
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 CountryInfo() {
}
public static CountryInfo fromJson(String json){
return new Gson().fromJson(json, CountryInfo.class);
}
}

View File

@ -308,6 +308,21 @@ class.map.specifications={\
}\ }\
}\ }\
},\ },\
"CountryInfo": {\
"class_type": "prototype",\
"mappings": {\
"https://www.ariadne-infrastructure.eu/property/country": {\
"class_field": "Id",\
"substring": "no",\
"element_type": "java.lang.String"\
},\
"https://www.ariadne-infrastructure.eu/property/name": {\
"class_field": "Name",\
"substring": "no",\
"element_type": "java.lang.String"\
}\
}\
},\
"AriadnePlusEntry": {\ "AriadnePlusEntry": {\
"class_type": "unique",\ "class_type": "unique",\
"mappings": {\ "mappings": {\
@ -476,8 +491,12 @@ class.map.specifications={\
"class_field": "DigitalImage",\ "class_field": "DigitalImage",\
"substring": "no",\ "substring": "no",\
"external_reference": "DigitalImage"\ "external_reference": "DigitalImage"\
},\
"https://www.ariadne-infrastructure.eu/property/country": {\
"class_field": "Country",\
"substring": "no",\
"external_reference": "CountryInfo"\
}\ }\
}\ }\
}\ }\
} }

View File

@ -95,6 +95,9 @@ CONSTRUCT {
?descriptionInfo aoprop:text ?description . ?descriptionInfo aoprop:text ?description .
?descriptionInfo aoprop:lang ?descriptionLang . ?descriptionInfo aoprop:lang ?descriptionLang .
%record aoprop:language ?language . %record aoprop:language ?language .
%record aoprop:country ?country .
?country aoprop:id ?country .
?country aoprop:name ?countryName .
} }
where { where {
graph <https://ariadne-infrastructure.eu/api_________::ariadne_plus::%datasource::%collectionId> { graph <https://ariadne-infrastructure.eu/api_________::ariadne_plus::%datasource::%collectionId> {
@ -121,6 +124,10 @@ where {
optional { optional {
%record aocat:has_landing_page / rdfs:label ?landingPage . %record aocat:has_landing_page / rdfs:label ?landingPage .
} }
optional {
%record aocat:has_country ?country .
?country rdfs:label ?countryName .
}
BIND (IRI(concat( "https://ariadne-infrastructure.eu/TextLang/",SHA1(STR(?description)))) as ?descriptionInfo) BIND (IRI(concat( "https://ariadne-infrastructure.eu/TextLang/",SHA1(STR(?description)))) as ?descriptionInfo)
BIND (LANG(?description) as ?descriptionLang) BIND (LANG(?description) as ?descriptionLang)
BIND (IRI(concat( "https://ariadne-infrastructure.eu/TextLang/",SHA1(STR(?title)))) as ?titleInfo) BIND (IRI(concat( "https://ariadne-infrastructure.eu/TextLang/",SHA1(STR(?title)))) as ?titleInfo)

View File

@ -100,6 +100,9 @@ CONSTRUCT {
%record aoprop:image ?primaryVisualComponent . %record aoprop:image ?primaryVisualComponent .
?primaryVisualComponent aoprop:primaryVisualComponent ?primaryVisualComponent . ?primaryVisualComponent aoprop:primaryVisualComponent ?primaryVisualComponent .
?primaryVisualComponent aoprop:visualComponent ?visualComponent . ?primaryVisualComponent aoprop:visualComponent ?visualComponent .
%record aoprop:country ?country .
?country aoprop:id ?country .
?country aoprop:name ?countryName .
} }
where { where {
graph <https://ariadne-infrastructure.eu/api_________::ariadne_plus::%datasource::%collectionId> { graph <https://ariadne-infrastructure.eu/api_________::ariadne_plus::%datasource::%collectionId> {
@ -134,6 +137,10 @@ where {
%record aocat:has_spatial_precision / aocat:has_unit / skos:prefLabel ?spatialPrecisionUnit . %record aocat:has_spatial_precision / aocat:has_unit / skos:prefLabel ?spatialPrecisionUnit .
%record aocat:has_spatial_precision / aocat:has_value ?spatialPrecisionValue . %record aocat:has_spatial_precision / aocat:has_value ?spatialPrecisionValue .
} }
optional {
%record aocat:has_country ?country .
?country rdfs:label ?countryName .
}
BIND (IRI(concat( "https://ariadne-infrastructure.eu/TextLang/",SHA1(STR(?description)))) as ?descriptionInfo) BIND (IRI(concat( "https://ariadne-infrastructure.eu/TextLang/",SHA1(STR(?description)))) as ?descriptionInfo)
BIND (LANG(?description) as ?descriptionLang) BIND (LANG(?description) as ?descriptionLang)
BIND (IRI(concat( "https://ariadne-infrastructure.eu/TextLang/",SHA1(STR(?title)))) as ?titleInfo) BIND (IRI(concat( "https://ariadne-infrastructure.eu/TextLang/",SHA1(STR(?title)))) as ?titleInfo)

View File

@ -8,16 +8,11 @@ import eu.dnetlib.ariadneplus.publisher.AriadnePlusPublisherException;
import eu.dnetlib.ariadneplus.reader.ResourceManager; import eu.dnetlib.ariadneplus.reader.ResourceManager;
import eu.dnetlib.ariadneplus.reader.RunSPARQLQueryService; import eu.dnetlib.ariadneplus.reader.RunSPARQLQueryService;
import eu.dnetlib.ariadneplus.reader.json.ParseRDFJSON; import eu.dnetlib.ariadneplus.reader.json.ParseRDFJSON;
import org.apache.commons.compress.utils.Lists;
import org.apache.commons.io.IOUtils; import org.apache.commons.io.IOUtils;
import org.eclipse.rdf4j.RDF4JException; import org.eclipse.rdf4j.RDF4JException;
import org.eclipse.rdf4j.model.IRI; import org.eclipse.rdf4j.model.IRI;
import org.eclipse.rdf4j.model.Resource; import org.eclipse.rdf4j.model.Resource;
import org.eclipse.rdf4j.model.ValueFactory; import org.eclipse.rdf4j.model.ValueFactory;
import org.eclipse.rdf4j.query.GraphQuery;
import org.eclipse.rdf4j.query.GraphQueryResult;
import org.eclipse.rdf4j.query.QueryLanguage;
import org.eclipse.rdf4j.query.QueryResults;
import org.eclipse.rdf4j.repository.Repository; import org.eclipse.rdf4j.repository.Repository;
import org.eclipse.rdf4j.repository.RepositoryConnection; import org.eclipse.rdf4j.repository.RepositoryConnection;
import org.eclipse.rdf4j.repository.RepositoryResult; import org.eclipse.rdf4j.repository.RepositoryResult;
@ -26,18 +21,13 @@ import org.eclipse.rdf4j.repository.util.Repositories;
import org.junit.Ignore; import org.junit.Ignore;
import org.junit.Test; import org.junit.Test;
import org.springframework.core.io.ClassPathResource; import org.springframework.core.io.ClassPathResource;
import java.io.BufferedReader; import java.io.BufferedReader;
import java.io.InputStreamReader; import java.io.InputStreamReader;
import java.nio.charset.StandardCharsets; import java.nio.charset.StandardCharsets;
import java.nio.file.Files;
import java.nio.file.Paths;
import java.util.ArrayList;
import java.util.Arrays; import java.util.Arrays;
import java.util.List; import java.util.List;
import java.util.Properties; import java.util.Properties;
import java.util.stream.Collectors;
import java.util.stream.Stream;
/** /**
* @author enrico.ottonello * @author enrico.ottonello
@ -625,6 +615,16 @@ public class GraphDbReaderAndESIndexTest {
readAndIndexTest(isRecord, recordId, datasource, collectionId); readAndIndexTest(isRecord, recordId, datasource, collectionId);
} }
@Test
public void uploadWithCountryTest() throws Exception {
boolean isRecord = false;
String recordId = "https://ariadne-infrastructure.eu/aocat/Collection/INFN/8AF9C287-9CBD-32DC-9B18-0C0EFD85BAFB";
String datasource = "infn";
String apiId = "firenze";
readAndIndexTest(isRecord, recordId, datasource, apiId);
}
private class CollectionData { private class CollectionData {
String URI_ID; String URI_ID;
String id; String id;

View File

@ -2,17 +2,16 @@ package eu.dnetlib.ariadneplus.reader.json;
import eu.dnetlib.ariadneplus.elasticsearch.model.AriadnePlusEntry; import eu.dnetlib.ariadneplus.elasticsearch.model.AriadnePlusEntry;
import eu.dnetlib.ariadneplus.reader.ResourceManager; import eu.dnetlib.ariadneplus.reader.ResourceManager;
import eu.dnetlib.ariadneplus.reader.utils.PropertiesMap;
import net.minidev.json.parser.ParseException; import net.minidev.json.parser.ParseException;
import org.apache.commons.io.IOUtils; import org.apache.commons.io.IOUtils;
import org.junit.Assert; import org.junit.Assert;
import org.junit.Before; import org.junit.Before;
import org.junit.BeforeClass;
import org.junit.Test; import org.junit.Test;
import org.springframework.core.io.ClassPathResource; import org.springframework.core.io.ClassPathResource;
import java.io.IOException; import java.io.IOException;
import java.lang.reflect.InvocationTargetException; import java.lang.reflect.InvocationTargetException;
import java.util.LinkedHashMap;
public class ParseRDFJsonTest { public class ParseRDFJsonTest {
@ -128,6 +127,22 @@ public class ParseRDFJsonTest {
} }
} }
@Test
public void testCountryInCollection() throws ParseException {
String collectionJson = getFromClasspath("eu/dnetlib/ariadneplus/reader/json/collection.json");
parser.setCollection(true);
int res = parser.parse(collectionJson);
Assert.assertNotEquals(-1, res);
boolean hasCountry = false;
while(parser.hasNextElement()){
LinkedHashMap element = parser.getNextElement();
System.out.println(element);
hasCountry = element.containsKey("https://www.ariadne-infrastructure.eu/property/country");
}
Assert.assertTrue(hasCountry);
}
private String getFromClasspath(String s) { private String getFromClasspath(String s) {
try { try {
final ClassPathResource resource = new ClassPathResource(s); final ClassPathResource resource = new ClassPathResource(s);

View File

@ -111,6 +111,12 @@
"type" : "uri" "type" : "uri"
} }
], ],
"https://www.ariadne-infrastructure.eu/property/country" : [
{
"value" : "http://www.wikidata.org/entity/Q38",
"type" : "uri"
}
],
"https://www.ariadne-infrastructure.eu/property/resourceType" : [ "https://www.ariadne-infrastructure.eu/property/resourceType" : [
{ {
"value" : "Collection", "value" : "Collection",
@ -172,5 +178,14 @@
"lang" : "en" "lang" : "en"
} }
] ]
},
"http://www.wikidata.org/entity/Q38" : {
"https://www.ariadne-infrastructure.eu/property/name" : [
{
"value" : "Italy",
"type" : "literal"
}
]
} }
} }

View File

@ -165,6 +165,13 @@
"type" : "literal", "type" : "literal",
"datatype" : "http://www.w3.org/2001/XMLSchema#dateTime" "datatype" : "http://www.w3.org/2001/XMLSchema#dateTime"
} }
],
"https://www.ariadne-infrastructure.eu/property/rdfType" : [
{
"value" : "Record",
"type" : "literal",
"datatype" : "http://www.w3.org/2001/XMLSchema#string"
}
] ]
} }
} }

View File

@ -290,6 +290,21 @@
} }
} }
}, },
"CountryInfo": {
"class_type": "prototype",
"mappings": {
"https://www.ariadne-infrastructure.eu/property/country": {
"class_field": "Id",
"substring": "no",
"element_type": "java.lang.String"
},
"https://www.ariadne-infrastructure.eu/property/name": {
"class_field": "Name",
"substring": "no",
"element_type": "java.lang.String"
}
}
},
"AriadnePlusEntry": { "AriadnePlusEntry": {
"class_type": "unique", "class_type": "unique",
"mappings": { "mappings": {
@ -423,6 +438,12 @@
"substring": "no", "substring": "no",
"element_type": "java.lang.String" "element_type": "java.lang.String"
}, },
"https://www.ariadne-infrastructure.eu/property/otherId": {
"class_field": "OtherId",
"class_type": "prototype",
"substring": "no",
"element_type": "java.lang.String"
},
"https://www.ariadne-infrastructure.eu/property/temporal": { "https://www.ariadne-infrastructure.eu/property/temporal": {
"class_field": "Temporal", "class_field": "Temporal",
"substring": "no", "substring": "no",
@ -452,6 +473,11 @@
"class_field": "DigitalImage", "class_field": "DigitalImage",
"substring": "no", "substring": "no",
"external_reference": "DigitalImage" "external_reference": "DigitalImage"
},
"https://www.ariadne-infrastructure.eu/property/country": {
"class_field": "Country",
"substring": "no",
"external_reference": "CountryInfo"
} }
} }
} }

View File

@ -204,6 +204,12 @@
"type" : "uri" "type" : "uri"
} }
], ],
"https://www.ariadne-infrastructure.eu/property/country" : [
{
"value" : "http://www.wikidata.org/entity/Q38",
"type" : "uri"
}
],
"https://www.ariadne-infrastructure.eu/property/rdfType" : [ "https://www.ariadne-infrastructure.eu/property/rdfType" : [
{ {
"value" : "Collection", "value" : "Collection",
@ -317,6 +323,14 @@
"value" : "https://ariadne-infrastructure.eu/aocat/Time-Span/25162", "value" : "https://ariadne-infrastructure.eu/aocat/Time-Span/25162",
"type" : "uri" "type" : "uri"
} }
],
"http://www.wikidata.org/entity/Q38" : {
"https://www.ariadne-infrastructure.eu/property/name": [
{
"value": "Italy",
"type": "literal"
}
] ]
} }
} }
}