mirror of
https://github.com/Unleash/unleash.git
synced 2025-01-25 00:07:47 +01:00
ccaab0c47b
Instead of instructing users to do static calls in to Unleash, she should instead be allwed to specify the log provider as an option to Unleash. This commit introduces the "getLogger" option, a function responsible for creating a logger.
106 lines
2.7 KiB
JavaScript
106 lines
2.7 KiB
JavaScript
/* eslint camelcase: "off" */
|
|
'use strict';
|
|
|
|
const COLUMNS = [
|
|
'app_name',
|
|
'instance_id',
|
|
'sdk_version',
|
|
'client_ip',
|
|
'last_seen',
|
|
'created_at',
|
|
];
|
|
const TABLE = 'client_instances';
|
|
|
|
const ONE_DAY = 24 * 61 * 60 * 1000;
|
|
|
|
const mapRow = row => ({
|
|
appName: row.app_name,
|
|
instanceId: row.instance_id,
|
|
sdkVersion: row.sdk_version,
|
|
clientIp: row.client_ip,
|
|
lastSeen: row.last_seen,
|
|
createdAt: row.created_at,
|
|
});
|
|
|
|
class ClientInstanceStore {
|
|
constructor(db, getLogger) {
|
|
this.db = db;
|
|
this.logger = getLogger('client-instance-store.js');
|
|
const clearer = () => this._removeInstancesOlderThanTwoDays();
|
|
setTimeout(clearer, 10).unref();
|
|
setInterval(clearer, ONE_DAY).unref();
|
|
}
|
|
|
|
_removeInstancesOlderThanTwoDays() {
|
|
this.db(TABLE)
|
|
.whereRaw("created_at < now() - interval '2 days'")
|
|
.del()
|
|
.then(
|
|
res => res > 0 && this.logger.info(`Deleted ${res} instances`)
|
|
);
|
|
}
|
|
|
|
updateRow(details) {
|
|
return this.db(TABLE)
|
|
.where('app_name', details.appName)
|
|
.where('instance_id', details.instanceId)
|
|
.update({
|
|
last_seen: 'now()',
|
|
client_ip: details.clientIp,
|
|
sdk_version: details.sdkVersion,
|
|
});
|
|
}
|
|
|
|
insertNewRow(details) {
|
|
return this.db(TABLE).insert({
|
|
app_name: details.appName,
|
|
instance_id: details.instanceId,
|
|
sdk_version: details.sdkVersion,
|
|
client_ip: details.clientIp,
|
|
});
|
|
}
|
|
|
|
insert(details) {
|
|
return this.db(TABLE)
|
|
.count('*')
|
|
.where('app_name', details.appName)
|
|
.where('instance_id', details.instanceId)
|
|
.map(row => ({ count: row.count }))
|
|
.then(rows => {
|
|
if (rows[0].count > 0) {
|
|
return this.updateRow(details);
|
|
} else {
|
|
return this.insertNewRow(details);
|
|
}
|
|
});
|
|
}
|
|
|
|
getAll() {
|
|
return this.db
|
|
.select(COLUMNS)
|
|
.from(TABLE)
|
|
.orderBy('last_seen', 'desc')
|
|
.map(mapRow);
|
|
}
|
|
|
|
getByAppName(appName) {
|
|
return this.db
|
|
.select()
|
|
.from(TABLE)
|
|
.where('app_name', appName)
|
|
.orderBy('last_seen', 'desc')
|
|
.map(mapRow);
|
|
}
|
|
|
|
getApplications() {
|
|
return this.db
|
|
.distinct('app_name')
|
|
.select(['app_name'])
|
|
.from(TABLE)
|
|
.orderBy('app_name', 'desc')
|
|
.map(mapRow);
|
|
}
|
|
}
|
|
|
|
module.exports = ClientInstanceStore;
|