2020-11-05 16:58:23 +00:00
|
|
|
const ntpClient = require('./vendor/ntp-client');
|
2021-01-22 17:41:11 +00:00
|
|
|
import Logger from './Logger';
|
2020-09-08 23:57:48 +01:00
|
|
|
const Mutex = require('async-mutex').Mutex;
|
|
|
|
|
2020-09-09 00:34:27 +01:00
|
|
|
let nextSyncTime = 0;
|
2020-09-08 23:57:48 +01:00
|
|
|
let timeOffset = 0;
|
2020-09-09 10:56:17 +01:00
|
|
|
let logger = new Logger();
|
|
|
|
|
2020-09-08 23:57:48 +01:00
|
|
|
const fetchingTimeMutex = new Mutex();
|
|
|
|
|
|
|
|
const server = {
|
|
|
|
domain: 'pool.ntp.org',
|
|
|
|
port: 123,
|
|
|
|
};
|
|
|
|
|
2020-11-12 19:13:28 +00:00
|
|
|
async function networkTime(): Promise<Date> {
|
|
|
|
return new Promise(function(resolve: Function, reject: Function) {
|
|
|
|
ntpClient.getNetworkTime(server.domain, server.port, function(error: any, date: Date) {
|
2020-09-08 23:57:48 +01:00
|
|
|
if (error) {
|
|
|
|
reject(error);
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
resolve(date);
|
|
|
|
});
|
|
|
|
});
|
|
|
|
}
|
|
|
|
|
|
|
|
function shouldSyncTime() {
|
2020-09-09 00:34:27 +01:00
|
|
|
return !nextSyncTime || Date.now() > nextSyncTime;
|
2020-09-08 23:57:48 +01:00
|
|
|
}
|
|
|
|
|
2020-11-12 19:13:28 +00:00
|
|
|
export function setLogger(v: any) {
|
2020-09-09 10:56:17 +01:00
|
|
|
logger = v;
|
|
|
|
}
|
|
|
|
|
2020-11-12 19:13:28 +00:00
|
|
|
export default async function(): Promise<Date> {
|
2020-09-08 23:57:48 +01:00
|
|
|
if (shouldSyncTime()) {
|
|
|
|
const release = await fetchingTimeMutex.acquire();
|
|
|
|
|
|
|
|
try {
|
|
|
|
if (shouldSyncTime()) {
|
|
|
|
const date = await networkTime();
|
2020-09-09 00:34:27 +01:00
|
|
|
nextSyncTime = Date.now() + 60 * 1000;
|
2020-09-08 23:57:48 +01:00
|
|
|
timeOffset = date.getTime() - Date.now();
|
|
|
|
}
|
2020-09-09 00:34:27 +01:00
|
|
|
} catch (error) {
|
2020-09-09 10:56:17 +01:00
|
|
|
logger.warn('Could not get NTP time - falling back to device time:', error);
|
|
|
|
// Fallback to device time since
|
2020-09-09 00:34:27 +01:00
|
|
|
// most of the time it's actually correct
|
|
|
|
nextSyncTime = Date.now() + 20 * 1000;
|
|
|
|
timeOffset = 0;
|
2020-09-08 23:57:48 +01:00
|
|
|
} finally {
|
|
|
|
release();
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
return new Date(Date.now() + timeOffset);
|
|
|
|
}
|