2020-06-10 19:39:53 +02:00
|
|
|
package eu.dnetlib.ariadneplus.reader.utils;
|
|
|
|
|
|
|
|
import java.time.LocalDate;
|
2021-01-26 16:39:47 +01:00
|
|
|
import java.time.Year;
|
2020-11-30 13:27:28 +01:00
|
|
|
import java.time.ZoneId;
|
|
|
|
import java.time.ZonedDateTime;
|
2020-06-10 19:39:53 +02:00
|
|
|
import java.time.format.DateTimeFormatter;
|
2020-07-13 11:03:21 +02:00
|
|
|
import java.time.format.DateTimeFormatterBuilder;
|
2020-11-30 13:27:28 +01:00
|
|
|
import java.time.format.TextStyle;
|
2020-07-13 11:03:21 +02:00
|
|
|
import java.time.temporal.ChronoField;
|
2020-11-30 13:27:28 +01:00
|
|
|
import java.util.Collections;
|
|
|
|
import java.util.Locale;
|
2020-06-10 19:39:53 +02:00
|
|
|
|
|
|
|
public class ESUtils {
|
|
|
|
private static DateTimeFormatter originalRecordDateFormatter = DateTimeFormatter.ofPattern("dd MMM yyyy");
|
|
|
|
private static DateTimeFormatter elasticSearchDateFormatter = DateTimeFormatter.ofPattern("yyyy-MM-dd");
|
2020-11-30 13:27:28 +01:00
|
|
|
private static ZoneId preferredZone = ZoneId.of("Europe/London");
|
|
|
|
private static DateTimeFormatter BST_FORMATTER = new DateTimeFormatterBuilder()
|
|
|
|
.appendPattern("EEE MMM dd HH:mm:ss ")
|
|
|
|
.appendZoneText(TextStyle.SHORT, Collections.singleton(preferredZone))
|
|
|
|
.appendPattern(" yyyy")
|
|
|
|
.toFormatter(Locale.ROOT);
|
2020-07-13 11:03:21 +02:00
|
|
|
private static DateTimeFormatter yearOnlyDateFormatter = new DateTimeFormatterBuilder()
|
2021-01-26 16:39:47 +01:00
|
|
|
.appendPattern("yyyy").toFormatter();
|
2020-06-10 19:39:53 +02:00
|
|
|
|
2020-10-13 00:31:17 +02:00
|
|
|
public static String getESFormatDate(String originalDate) {
|
2020-09-07 15:37:40 +02:00
|
|
|
try{
|
|
|
|
LocalDate parsedDate = LocalDate.parse(originalDate, elasticSearchDateFormatter);
|
2020-07-13 11:03:21 +02:00
|
|
|
return parsedDate.format(elasticSearchDateFormatter);
|
2020-09-07 15:37:40 +02:00
|
|
|
} catch(Exception e){
|
|
|
|
try {
|
2021-01-26 16:39:47 +01:00
|
|
|
Year year = Year.parse(originalDate);
|
|
|
|
return year.format(yearOnlyDateFormatter);
|
|
|
|
} catch (Exception e0) {
|
2020-10-13 00:31:17 +02:00
|
|
|
try {
|
2021-01-26 16:39:47 +01:00
|
|
|
LocalDate parsedDate = LocalDate.parse(originalDate, originalRecordDateFormatter);
|
2020-10-13 00:31:17 +02:00
|
|
|
return parsedDate.format(elasticSearchDateFormatter);
|
2021-01-26 16:39:47 +01:00
|
|
|
} catch (Exception e1) {
|
2020-11-30 13:27:28 +01:00
|
|
|
try {
|
2021-01-26 16:39:47 +01:00
|
|
|
LocalDate parsedDate = LocalDate.parse(originalDate.substring(0, 10), elasticSearchDateFormatter);
|
|
|
|
return parsedDate.format(elasticSearchDateFormatter);
|
|
|
|
} catch (Exception e2) {
|
|
|
|
try {
|
|
|
|
return parseBST(originalDate);
|
|
|
|
} catch (Exception e3) {
|
|
|
|
return "0000";
|
|
|
|
}
|
2020-11-30 13:27:28 +01:00
|
|
|
}
|
2020-10-13 00:31:17 +02:00
|
|
|
}
|
2020-09-07 15:37:40 +02:00
|
|
|
}
|
2020-07-13 11:03:21 +02:00
|
|
|
}
|
2020-06-10 19:39:53 +02:00
|
|
|
}
|
2020-11-30 13:27:28 +01:00
|
|
|
|
|
|
|
private static String parseBST(String BSTDate) {
|
|
|
|
ZonedDateTime zd = ZonedDateTime.parse(BSTDate, BST_FORMATTER);
|
|
|
|
return zd.format(elasticSearchDateFormatter);
|
|
|
|
}
|
2020-06-10 19:39:53 +02:00
|
|
|
}
|