1
0
mirror of https://github.com/Unleash/unleash.git synced 2025-01-06 00:07:44 +01:00
unleash.unleash/lib/db/client-strategy-store.js

87 lines
2.2 KiB
JavaScript
Raw Normal View History

2016-11-02 23:17:28 +01:00
'use strict';
const COLUMNS = ['app_name', 'strategies'];
const TABLE = 'client_strategies';
const mapRow = (row) => ({
appName: row.app_name,
strategies: row.strategies,
});
class ClientStrategyStore {
constructor (db) {
this.db = db;
}
updateRow (appName, strategies) {
return this.db(TABLE)
2016-11-02 23:17:28 +01:00
.where('app_name', appName) // eslint-disable-line
.update({
strategies: JSON.stringify(strategies),
updated_at: 'now()', // eslint-disable-line
});
}
insertNewRow (appName, strategies) {
return this.db(TABLE).insert({
2016-11-02 23:17:28 +01:00
app_name: appName, // eslint-disable-line
strategies: JSON.stringify(strategies),
});
}
insert (appName, strategies) {
return this.db(TABLE)
2016-11-02 23:17:28 +01:00
.count('*')
.where('app_name', appName)
.map(row => ({ count: row.count }))
.then(rows => {
2016-11-02 23:24:23 +01:00
if (rows[0].count > 0) {
return this.updateRow(appName, strategies);
2016-11-02 23:24:23 +01:00
} else {
return this.insertNewRow(appName, strategies);
2016-11-02 23:24:23 +01:00
}
2016-11-02 23:17:28 +01:00
});
}
getAll () {
return this.db
2016-11-02 23:17:28 +01:00
.select(COLUMNS)
.from(TABLE)
.map(mapRow);
}
getByAppName (appName) {
return this.db
.select('strategies')
.where('app_name', appName)
.from(TABLE)
2016-12-05 15:50:34 +01:00
.map((row) => row.strategies)
.then(arr => arr[0]);
}
/**
* Could also be done in SQL:
* (not sure if it is faster though)
*
* SELECT app_name from (
* SELECT app_name, json_array_elements(strategies)::text as strategyName from client_strategies
* ) as foo
* WHERE foo.strategyName = '"other"';
*/
getAppsForStrategy (strategyName) {
return this.getAll()
.then(apps => apps
.filter(app => app.strategies.includes(strategyName))
.map(app => app.appName));
}
getApplications () {
return this.db
.select('app_name')
.from(TABLE)
.map((row) => row.app_name);
}
2016-11-02 23:17:28 +01:00
};
module.exports = ClientStrategyStore;