2020-08-11 14:26:16 +00:00
|
|
|
package biz.nellemann.hmci
|
|
|
|
|
|
|
|
import biz.nellemann.hmci.pojo.PcmData
|
|
|
|
import groovy.json.JsonSlurper
|
|
|
|
import groovy.util.logging.Slf4j
|
|
|
|
|
|
|
|
import java.time.Instant
|
|
|
|
import java.time.format.DateTimeFormatter
|
|
|
|
import java.time.format.DateTimeParseException
|
|
|
|
|
|
|
|
@Slf4j
|
2020-08-13 15:50:26 +00:00
|
|
|
abstract class MetaSystem {
|
2020-08-11 14:26:16 +00:00
|
|
|
|
|
|
|
protected PcmData metrics
|
|
|
|
|
|
|
|
void processMetrics(String json) {
|
|
|
|
def pcmMap = new JsonSlurper().parseText(json)
|
|
|
|
metrics = new PcmData(pcmMap as Map)
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
Instant getTimestamp() {
|
|
|
|
|
2020-08-14 07:34:44 +00:00
|
|
|
String timestamp = metrics.systemUtil.utilSamples.first().sampleInfo.timeStamp
|
2020-08-11 14:26:16 +00:00
|
|
|
Instant instant
|
|
|
|
try {
|
2020-08-14 07:34:44 +00:00
|
|
|
log.debug("getTimeStamp() - PMC Timestamp: " + timestamp)
|
2020-08-11 14:26:16 +00:00
|
|
|
DateTimeFormatter dateTimeFormatter = DateTimeFormatter.ofPattern("yyyy-MM-dd'T'HH:mm:ss[XXX][X]");
|
2020-08-14 07:34:44 +00:00
|
|
|
instant = Instant.from(dateTimeFormatter.parse(timestamp))
|
|
|
|
log.debug("getTimestamp() - Instant: " + instant.toString())
|
2020-08-11 14:26:16 +00:00
|
|
|
} catch(DateTimeParseException e) {
|
2020-08-14 07:34:44 +00:00
|
|
|
log.warn("getTimestamp() - parse error: " + timestamp)
|
2020-08-11 14:26:16 +00:00
|
|
|
}
|
2020-08-14 07:34:44 +00:00
|
|
|
|
|
|
|
return instant ?: Instant.now()
|
2020-08-11 14:26:16 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
}
|