forked from D-Net/dnet-hadoop
expand the instance level fulltext in the XML records
This commit is contained in:
parent
8c63e4a864
commit
a72b9e96ac
|
@ -57,6 +57,8 @@ public class XmlInstance implements Serializable {
|
||||||
// typed results
|
// typed results
|
||||||
private String processingchargecurrency;
|
private String processingchargecurrency;
|
||||||
|
|
||||||
|
private String fulltext;
|
||||||
|
|
||||||
private Qualifier refereed; // peer-review status
|
private Qualifier refereed; // peer-review status
|
||||||
|
|
||||||
public String getUrl() {
|
public String getUrl() {
|
||||||
|
@ -162,4 +164,12 @@ public class XmlInstance implements Serializable {
|
||||||
public void setRefereed(Qualifier refereed) {
|
public void setRefereed(Qualifier refereed) {
|
||||||
this.refereed = refereed;
|
this.refereed = refereed;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public String getFulltext() {
|
||||||
|
return fulltext;
|
||||||
|
}
|
||||||
|
|
||||||
|
public void setFulltext(String fulltext) {
|
||||||
|
this.fulltext = fulltext;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -1309,6 +1309,9 @@ public class XmlRecordFactory implements Serializable {
|
||||||
.map(d -> XmlSerializationUtils.asXmlElement("license", d))
|
.map(d -> XmlSerializationUtils.asXmlElement("license", d))
|
||||||
.collect(Collectors.toList()));
|
.collect(Collectors.toList()));
|
||||||
}
|
}
|
||||||
|
if (StringUtils.isNotBlank(instance.getFulltext())) {
|
||||||
|
fields.add(XmlSerializationUtils.asXmlElement("fulltext", instance.getFulltext()));
|
||||||
|
}
|
||||||
|
|
||||||
children
|
children
|
||||||
.add(
|
.add(
|
||||||
|
@ -1459,6 +1462,9 @@ public class XmlRecordFactory implements Serializable {
|
||||||
Optional
|
Optional
|
||||||
.ofNullable(i.getDistributionlocation())
|
.ofNullable(i.getDistributionlocation())
|
||||||
.ifPresent(dl -> instance.getDistributionlocation().add(dl));
|
.ifPresent(dl -> instance.getDistributionlocation().add(dl));
|
||||||
|
Optional
|
||||||
|
.ofNullable(i.getFulltext())
|
||||||
|
.ifPresent(instance::setFulltext);
|
||||||
});
|
});
|
||||||
|
|
||||||
if (instance.getHostedby().size() > 1
|
if (instance.getHostedby().size() > 1
|
||||||
|
|
|
@ -47,8 +47,6 @@ public class XmlRecordFactoryTest {
|
||||||
|
|
||||||
final String xml = xmlRecordFactory.build(new JoinedEntity<>(p));
|
final String xml = xmlRecordFactory.build(new JoinedEntity<>(p));
|
||||||
|
|
||||||
System.out.println(xml);
|
|
||||||
|
|
||||||
assertNotNull(xml);
|
assertNotNull(xml);
|
||||||
|
|
||||||
final Document doc = new SAXReader().read(new StringReader(xml));
|
final Document doc = new SAXReader().read(new StringReader(xml));
|
||||||
|
@ -92,6 +90,12 @@ public class XmlRecordFactoryTest {
|
||||||
|
|
||||||
assertEquals("EOSC::Jupyter Notebook", doc.valueOf("//*[local-name() = 'result']/eoscifguidelines/@code"));
|
assertEquals("EOSC::Jupyter Notebook", doc.valueOf("//*[local-name() = 'result']/eoscifguidelines/@code"));
|
||||||
|
|
||||||
|
assertEquals(2, Integer.parseInt(doc.valueOf("count(//*[local-name() = 'result']/fulltext)")));
|
||||||
|
|
||||||
|
assertEquals(
|
||||||
|
"https://osf.io/preprints/socarxiv/7vgtu/download",
|
||||||
|
doc.valueOf("//*[local-name() = 'result']/fulltext[1]"));
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
|
|
|
@ -485,10 +485,14 @@
|
||||||
},
|
},
|
||||||
"extraInfo": [],
|
"extraInfo": [],
|
||||||
"format": [],
|
"format": [],
|
||||||
"fulltext": [],
|
"fulltext": [
|
||||||
|
{ "value" : "https://osf.io/preprints/socarxiv/7vgtu/download" },
|
||||||
|
{ "value" : "https://osf.io/preprints/socarxiv/7vgtu/download2" }
|
||||||
|
],
|
||||||
"id": "50|CSC_________::0000ec4dd9df012feaafa77e71a0fb4c",
|
"id": "50|CSC_________::0000ec4dd9df012feaafa77e71a0fb4c",
|
||||||
"instance": [
|
"instance": [
|
||||||
{
|
{
|
||||||
|
"fulltext" : "https://osf.io/preprints/socarxiv/7vgtu/download",
|
||||||
"measures": [
|
"measures": [
|
||||||
{
|
{
|
||||||
"id": "influence",
|
"id": "influence",
|
||||||
|
|
Loading…
Reference in New Issue