diff --git a/dhp-workflows/dhp-doiboost/pom.xml b/dhp-workflows/dhp-doiboost/pom.xml
index 06f57de6bd..01ac60b3a5 100644
--- a/dhp-workflows/dhp-doiboost/pom.xml
+++ b/dhp-workflows/dhp-doiboost/pom.xml
@@ -4,7 +4,7 @@
dhp-workflows
eu.dnetlib.dhp
- 1.1.7-SNAPSHOT
+ 1.2.1-SNAPSHOT
4.0.0
diff --git a/dhp-workflows/dhp-doiboost/src/main/java/eu/dnetlib/doiboost/orcid/OrcidDownloader.java b/dhp-workflows/dhp-doiboost/src/main/java/eu/dnetlib/doiboost/orcid/OrcidDownloader.java
index 7163257f6c..e1c39f7a51 100644
--- a/dhp-workflows/dhp-doiboost/src/main/java/eu/dnetlib/doiboost/orcid/OrcidDownloader.java
+++ b/dhp-workflows/dhp-doiboost/src/main/java/eu/dnetlib/doiboost/orcid/OrcidDownloader.java
@@ -1,6 +1,6 @@
+
package eu.dnetlib.doiboost.orcid;
-import eu.dnetlib.dhp.application.ArgumentApplicationParser;
import java.io.BufferedReader;
import java.io.IOException;
import java.io.InputStreamReader;
@@ -9,6 +9,7 @@ import java.text.SimpleDateFormat;
import java.util.Arrays;
import java.util.Date;
import java.util.List;
+
import org.apache.commons.io.IOUtils;
import org.apache.hadoop.conf.Configuration;
import org.apache.hadoop.fs.FSDataInputStream;
@@ -22,158 +23,162 @@ import org.apache.http.impl.client.CloseableHttpClient;
import org.apache.http.impl.client.HttpClients;
import org.mortbay.log.Log;
+import eu.dnetlib.dhp.application.ArgumentApplicationParser;
+
public class OrcidDownloader extends OrcidDSManager {
- static final int REQ_LIMIT = 24;
- static final int REQ_MAX_TEST = 100;
- static final int RECORD_PARSED_COUNTER_LOG_INTERVAL = 50000;
- static final String DATE_FORMAT = "yyyy-MM-dd HH:mm:ss.";
- static final String lastUpdate = "2019-09-30 00:00:00.000000";
- private String lambdaFileName;
- private String outputPath;
- private String token;
+ static final int REQ_LIMIT = 24;
+ static final int REQ_MAX_TEST = 100;
+ static final int RECORD_PARSED_COUNTER_LOG_INTERVAL = 50000;
+ static final String DATE_FORMAT = "yyyy-MM-dd HH:mm:ss.";
+ static final String lastUpdate = "2019-09-30 00:00:00.000000";
+ private String lambdaFileName;
+ private String outputPath;
+ private String token;
- public static void main(String[] args) throws IOException, Exception {
- OrcidDownloader orcidDownloader = new OrcidDownloader();
- orcidDownloader.loadArgs(args);
- orcidDownloader.parseLambdaFile();
- }
+ public static void main(String[] args) throws IOException, Exception {
+ OrcidDownloader orcidDownloader = new OrcidDownloader();
+ orcidDownloader.loadArgs(args);
+ orcidDownloader.parseLambdaFile();
+ }
- private String downloadRecord(String orcidId) throws Exception {
- try (CloseableHttpClient client = HttpClients.createDefault()) {
- HttpGet httpGet = new HttpGet("https://api.orcid.org/v3.0/" + orcidId + "/record");
- httpGet.addHeader("Accept", "application/vnd.orcid+xml");
- httpGet.addHeader("Authorization", String.format("Bearer %s", token));
- CloseableHttpResponse response = client.execute(httpGet);
- if (response.getStatusLine().getStatusCode() != 200) {
- Log.warn(
- "Downloading " + orcidId + " status code: " + response.getStatusLine().getStatusCode());
- return new String("");
- }
- return IOUtils.toString(response.getEntity().getContent());
+ private String downloadRecord(String orcidId) throws Exception {
+ try (CloseableHttpClient client = HttpClients.createDefault()) {
+ HttpGet httpGet = new HttpGet("https://api.orcid.org/v3.0/" + orcidId + "/record");
+ httpGet.addHeader("Accept", "application/vnd.orcid+xml");
+ httpGet.addHeader("Authorization", String.format("Bearer %s", token));
+ CloseableHttpResponse response = client.execute(httpGet);
+ if (response.getStatusLine().getStatusCode() != 200) {
+ Log
+ .warn(
+ "Downloading " + orcidId + " status code: " + response.getStatusLine().getStatusCode());
+ return new String("");
+ }
+ return IOUtils.toString(response.getEntity().getContent());
- } catch (Throwable e) {
- Log.warn("Downloading " + orcidId, e);
- }
- return new String("");
- }
+ } catch (Throwable e) {
+ Log.warn("Downloading " + orcidId, e);
+ }
+ return new String("");
+ }
- public void parseLambdaFile() throws Exception {
- int parsedRecordsCounter = 0;
- int downloadedRecordsCounter = 0;
- int savedRecordsCounter = 0;
- long startDownload = 0;
- Configuration conf = initConfigurationObject();
- FileSystem fs = initFileSystemObject(conf);
- String lambdaFileUri = hdfsServerUri.concat(hdfsOrcidDefaultPath).concat(lambdaFileName);
- Path hdfsreadpath = new Path(lambdaFileUri);
- FSDataInputStream lambdaFileStream = fs.open(hdfsreadpath);
- Path hdfsoutputPath =
- new Path(
- hdfsServerUri
- .concat(hdfsOrcidDefaultPath)
- .concat(outputPath)
- .concat("orcid_records.seq"));
+ public void parseLambdaFile() throws Exception {
+ int parsedRecordsCounter = 0;
+ int downloadedRecordsCounter = 0;
+ int savedRecordsCounter = 0;
+ long startDownload = 0;
+ Configuration conf = initConfigurationObject();
+ FileSystem fs = initFileSystemObject(conf);
+ String lambdaFileUri = hdfsServerUri.concat(hdfsOrcidDefaultPath).concat(lambdaFileName);
+ Path hdfsreadpath = new Path(lambdaFileUri);
+ FSDataInputStream lambdaFileStream = fs.open(hdfsreadpath);
+ Path hdfsoutputPath = new Path(
+ hdfsServerUri
+ .concat(hdfsOrcidDefaultPath)
+ .concat(outputPath)
+ .concat("orcid_records.seq"));
- try (SequenceFile.Writer writer =
- SequenceFile.createWriter(
- conf,
- SequenceFile.Writer.file(hdfsoutputPath),
- SequenceFile.Writer.keyClass(Text.class),
- SequenceFile.Writer.valueClass(Text.class))) {
+ try (SequenceFile.Writer writer = SequenceFile
+ .createWriter(
+ conf,
+ SequenceFile.Writer.file(hdfsoutputPath),
+ SequenceFile.Writer.keyClass(Text.class),
+ SequenceFile.Writer.valueClass(Text.class))) {
- try (BufferedReader br = new BufferedReader(new InputStreamReader(lambdaFileStream))) {
- String line;
- int nReqTmp = 0;
- startDownload = System.currentTimeMillis();
- long startReqTmp = System.currentTimeMillis();
- while ((line = br.readLine()) != null) {
- parsedRecordsCounter++;
- // skip headers line
- if (parsedRecordsCounter == 1) {
- continue;
- }
- String[] values = line.split(",");
- List recordInfo = Arrays.asList(values);
- if (isModified(recordInfo.get(3))) {
- String record = downloadRecord(recordInfo.get(0));
- downloadedRecordsCounter++;
- if (!record.isEmpty()) {
- String compressRecord = ArgumentApplicationParser.compressArgument(record);
- final Text key = new Text(recordInfo.get(0));
- final Text value = new Text(compressRecord);
+ try (BufferedReader br = new BufferedReader(new InputStreamReader(lambdaFileStream))) {
+ String line;
+ int nReqTmp = 0;
+ startDownload = System.currentTimeMillis();
+ long startReqTmp = System.currentTimeMillis();
+ while ((line = br.readLine()) != null) {
+ parsedRecordsCounter++;
+ // skip headers line
+ if (parsedRecordsCounter == 1) {
+ continue;
+ }
+ String[] values = line.split(",");
+ List recordInfo = Arrays.asList(values);
+ if (isModified(recordInfo.get(3))) {
+ String record = downloadRecord(recordInfo.get(0));
+ downloadedRecordsCounter++;
+ if (!record.isEmpty()) {
+ String compressRecord = ArgumentApplicationParser.compressArgument(record);
+ final Text key = new Text(recordInfo.get(0));
+ final Text value = new Text(compressRecord);
- try {
- writer.append(key, value);
- savedRecordsCounter++;
- } catch (IOException e) {
- Log.debug("Writing to sequence file: " + e.getMessage());
- Log.debug(e);
- throw new RuntimeException(e);
- }
- }
- }
- long endReq = System.currentTimeMillis();
- nReqTmp++;
- if (nReqTmp == REQ_LIMIT) {
- long reqSessionDuration = endReq - startReqTmp;
- if (reqSessionDuration <= 1000) {
- Log.warn(
- "\nreqSessionDuration: "
- + reqSessionDuration
- + " nReqTmp: "
- + nReqTmp
- + " wait ....");
- Thread.sleep(1000 - reqSessionDuration);
- } else {
- nReqTmp = 0;
- startReqTmp = System.currentTimeMillis();
- }
- }
+ try {
+ writer.append(key, value);
+ savedRecordsCounter++;
+ } catch (IOException e) {
+ Log.debug("Writing to sequence file: " + e.getMessage());
+ Log.debug(e);
+ throw new RuntimeException(e);
+ }
+ }
+ }
+ long endReq = System.currentTimeMillis();
+ nReqTmp++;
+ if (nReqTmp == REQ_LIMIT) {
+ long reqSessionDuration = endReq - startReqTmp;
+ if (reqSessionDuration <= 1000) {
+ Log
+ .warn(
+ "\nreqSessionDuration: "
+ + reqSessionDuration
+ + " nReqTmp: "
+ + nReqTmp
+ + " wait ....");
+ Thread.sleep(1000 - reqSessionDuration);
+ } else {
+ nReqTmp = 0;
+ startReqTmp = System.currentTimeMillis();
+ }
+ }
- // if (parsedRecordsCounter>REQ_MAX_TEST) {
- // break;
- // }
- if ((parsedRecordsCounter % RECORD_PARSED_COUNTER_LOG_INTERVAL) == 0) {
- Log.info("Current record parsed: " + parsedRecordsCounter);
- Log.info("Current record downloaded: " + downloadedRecordsCounter);
- Log.info("Current record saved: " + savedRecordsCounter);
- }
- }
- long endDownload = System.currentTimeMillis();
- long downloadTime = endDownload - startDownload;
- Log.info("Download time: " + ((downloadTime / 1000) / 60) + " minutes");
- }
- }
- lambdaFileStream.close();
- Log.info("Download started at: " + new Date(startDownload).toString());
- Log.info("Parsed Records Counter: " + parsedRecordsCounter);
- Log.info("Downloaded Records Counter: " + downloadedRecordsCounter);
- Log.info("Saved Records Counter: " + savedRecordsCounter);
- }
+ // if (parsedRecordsCounter>REQ_MAX_TEST) {
+ // break;
+ // }
+ if ((parsedRecordsCounter % RECORD_PARSED_COUNTER_LOG_INTERVAL) == 0) {
+ Log.info("Current record parsed: " + parsedRecordsCounter);
+ Log.info("Current record downloaded: " + downloadedRecordsCounter);
+ Log.info("Current record saved: " + savedRecordsCounter);
+ }
+ }
+ long endDownload = System.currentTimeMillis();
+ long downloadTime = endDownload - startDownload;
+ Log.info("Download time: " + ((downloadTime / 1000) / 60) + " minutes");
+ }
+ }
+ lambdaFileStream.close();
+ Log.info("Download started at: " + new Date(startDownload).toString());
+ Log.info("Parsed Records Counter: " + parsedRecordsCounter);
+ Log.info("Downloaded Records Counter: " + downloadedRecordsCounter);
+ Log.info("Saved Records Counter: " + savedRecordsCounter);
+ }
- private void loadArgs(String[] args) throws IOException, Exception {
- final ArgumentApplicationParser parser =
- new ArgumentApplicationParser(
- IOUtils.toString(
- OrcidDownloader.class.getResourceAsStream(
- "/eu/dnetlib/dhp/doiboost/download_orcid_data.json")));
- parser.parseArgument(args);
+ private void loadArgs(String[] args) throws IOException, Exception {
+ final ArgumentApplicationParser parser = new ArgumentApplicationParser(
+ IOUtils
+ .toString(
+ OrcidDownloader.class
+ .getResourceAsStream(
+ "/eu/dnetlib/dhp/doiboost/download_orcid_data.json")));
+ parser.parseArgument(args);
- hdfsServerUri = parser.get("hdfsServerUri");
- Log.info("HDFS URI: " + hdfsServerUri);
- hdfsOrcidDefaultPath = parser.get("hdfsOrcidDefaultPath");
- Log.info("Default Path: " + hdfsOrcidDefaultPath);
- lambdaFileName = parser.get("lambdaFileName");
- Log.info("Lambda File Name: " + lambdaFileName);
- outputPath = parser.get("outputPath");
- Log.info("Output Data: " + outputPath);
- token = parser.get("token");
- }
+ hdfsServerUri = parser.get("hdfsServerUri");
+ Log.info("HDFS URI: " + hdfsServerUri);
+ hdfsOrcidDefaultPath = parser.get("hdfsOrcidDefaultPath");
+ Log.info("Default Path: " + hdfsOrcidDefaultPath);
+ lambdaFileName = parser.get("lambdaFileName");
+ Log.info("Lambda File Name: " + lambdaFileName);
+ outputPath = parser.get("outputPath");
+ Log.info("Output Data: " + outputPath);
+ token = parser.get("token");
+ }
- private boolean isModified(String modifiedDate) throws ParseException {
- Date modifiedDateDt = new SimpleDateFormat(DATE_FORMAT).parse(modifiedDate);
- Date lastUpdateDt = new SimpleDateFormat(DATE_FORMAT).parse(lastUpdate);
- return modifiedDateDt.after(lastUpdateDt);
- }
+ private boolean isModified(String modifiedDate) throws ParseException {
+ Date modifiedDateDt = new SimpleDateFormat(DATE_FORMAT).parse(modifiedDate);
+ Date lastUpdateDt = new SimpleDateFormat(DATE_FORMAT).parse(lastUpdate);
+ return modifiedDateDt.after(lastUpdateDt);
+ }
}
diff --git a/dhp-workflows/dhp-doiboost/src/test/java/eu/dnetlib/doiboost/mag/MAGMappingTest.scala b/dhp-workflows/dhp-doiboost/src/test/java/eu/dnetlib/doiboost/mag/MAGMappingTest.scala
index ce26071b90..f60e10cf5b 100644
--- a/dhp-workflows/dhp-doiboost/src/test/java/eu/dnetlib/doiboost/mag/MAGMappingTest.scala
+++ b/dhp-workflows/dhp-doiboost/src/test/java/eu/dnetlib/doiboost/mag/MAGMappingTest.scala
@@ -16,7 +16,7 @@ class MAGMappingTest {
val mapper = new ObjectMapper()
- @Test
+ //@Test
def testMAGCSV(): Unit = {
val conf: SparkConf = new SparkConf()
@@ -31,7 +31,7 @@ class MAGMappingTest {
import spark.implicits._
val d: Dataset[Papers] = spark.read.load("/data/doiboost/mag/datasets/Papers").as[Papers]
logger.info(s"Total number of element: ${d.where(col("Doi").isNotNull).count()}")
- implicit val mapEncoder = org.apache.spark.sql.Encoders.kryo[Papers]
+ //implicit val mapEncoder = org.apache.spark.sql.Encoders.bean[Papers]
val result: RDD[Papers] = d.where(col("Doi").isNotNull).rdd.map { p: Papers => Tuple2(p.Doi, p) }.reduceByKey {case (p1:Papers, p2:Papers) =>
var r = if (p1==null) p2 else p1
if (p1!=null && p2!=null ) if (p1.CreatedDate.before(p2.CreatedDate))