2016-06-18 21:53:18 +02:00
|
|
|
'use strict';
|
2016-10-26 10:43:11 +02:00
|
|
|
|
2017-06-28 10:17:14 +02:00
|
|
|
const {
|
|
|
|
STRATEGY_CREATED,
|
|
|
|
STRATEGY_DELETED,
|
|
|
|
STRATEGY_UPDATED,
|
2019-03-13 19:10:13 +01:00
|
|
|
STRATEGY_IMPORT,
|
|
|
|
DROP_STRATEGIES,
|
2017-06-28 10:17:14 +02:00
|
|
|
} = require('../event-type');
|
2017-08-04 16:03:15 +02:00
|
|
|
const logger = require('../logger')('strategy-store.js');
|
2016-10-27 20:51:21 +02:00
|
|
|
const NotFoundError = require('../error/notfound-error');
|
2017-06-28 21:10:43 +02:00
|
|
|
const STRATEGY_COLUMNS = ['name', 'description', 'parameters', 'built_in'];
|
2016-11-05 10:16:48 +01:00
|
|
|
const TABLE = 'strategies';
|
2014-11-17 22:39:04 +01:00
|
|
|
|
2016-11-05 10:16:48 +01:00
|
|
|
class StrategyStore {
|
2017-06-28 10:17:14 +02:00
|
|
|
constructor(db, eventStore) {
|
2016-11-05 10:16:48 +01:00
|
|
|
this.db = db;
|
2017-06-28 10:17:14 +02:00
|
|
|
eventStore.on(STRATEGY_CREATED, event =>
|
|
|
|
this._createStrategy(event.data)
|
|
|
|
);
|
|
|
|
eventStore.on(STRATEGY_UPDATED, event =>
|
|
|
|
this._updateStrategy(event.data)
|
|
|
|
);
|
2019-03-13 19:10:13 +01:00
|
|
|
eventStore.on(STRATEGY_DELETED, event =>
|
|
|
|
this._deleteStrategy(event.data)
|
|
|
|
);
|
|
|
|
eventStore.on(STRATEGY_IMPORT, event =>
|
|
|
|
this._importStrategy(event.data)
|
|
|
|
);
|
|
|
|
eventStore.on(DROP_STRATEGIES, () => this._dropStrategies());
|
2016-11-05 10:16:48 +01:00
|
|
|
}
|
2014-12-08 20:56:22 +01:00
|
|
|
|
2017-06-28 10:17:14 +02:00
|
|
|
getStrategies() {
|
2016-11-05 10:16:48 +01:00
|
|
|
return this.db
|
2016-05-01 22:53:09 +02:00
|
|
|
.select(STRATEGY_COLUMNS)
|
2016-11-05 10:16:48 +01:00
|
|
|
.from(TABLE)
|
2016-12-10 12:12:00 +01:00
|
|
|
.orderBy('name', 'asc')
|
2016-11-05 10:16:48 +01:00
|
|
|
.map(this.rowToStrategy);
|
2016-05-01 22:53:09 +02:00
|
|
|
}
|
|
|
|
|
2019-03-14 17:56:02 +01:00
|
|
|
getEditableStrategies() {
|
|
|
|
return this.db
|
|
|
|
.select(STRATEGY_COLUMNS)
|
|
|
|
.from(TABLE)
|
|
|
|
.where({ built_in: 0 }) // eslint-disable-line
|
|
|
|
.orderBy('name', 'asc')
|
|
|
|
.map(this.rowToEditableStrategy);
|
|
|
|
}
|
|
|
|
|
2017-06-28 10:17:14 +02:00
|
|
|
getStrategy(name) {
|
2016-11-05 10:16:48 +01:00
|
|
|
return this.db
|
2016-05-01 22:53:09 +02:00
|
|
|
.first(STRATEGY_COLUMNS)
|
2016-11-05 10:16:48 +01:00
|
|
|
.from(TABLE)
|
2016-06-18 21:53:18 +02:00
|
|
|
.where({ name })
|
2016-11-05 10:16:48 +01:00
|
|
|
.then(this.rowToStrategy);
|
2016-05-01 22:53:09 +02:00
|
|
|
}
|
2014-11-17 22:39:04 +01:00
|
|
|
|
2017-06-28 10:17:14 +02:00
|
|
|
rowToStrategy(row) {
|
2016-05-01 22:53:09 +02:00
|
|
|
if (!row) {
|
|
|
|
throw new NotFoundError('No strategy found');
|
|
|
|
}
|
|
|
|
return {
|
|
|
|
name: row.name,
|
2017-06-28 21:10:43 +02:00
|
|
|
editable: row.built_in !== 1,
|
2016-05-01 22:53:09 +02:00
|
|
|
description: row.description,
|
2016-12-12 17:09:44 +01:00
|
|
|
parameters: row.parameters,
|
2016-05-01 22:53:09 +02:00
|
|
|
};
|
2014-11-17 22:39:04 +01:00
|
|
|
}
|
|
|
|
|
2019-03-14 17:56:02 +01:00
|
|
|
rowToEditableStrategy(row) {
|
|
|
|
if (!row) {
|
|
|
|
throw new NotFoundError('No strategy found');
|
|
|
|
}
|
|
|
|
return {
|
|
|
|
name: row.name,
|
|
|
|
description: row.description,
|
|
|
|
parameters: row.parameters,
|
|
|
|
};
|
|
|
|
}
|
|
|
|
|
2017-06-28 10:17:14 +02:00
|
|
|
eventDataToRow(data) {
|
2016-05-01 22:53:09 +02:00
|
|
|
return {
|
|
|
|
name: data.name,
|
|
|
|
description: data.description,
|
2016-12-12 17:09:44 +01:00
|
|
|
parameters: JSON.stringify(data.parameters),
|
2016-05-01 22:53:09 +02:00
|
|
|
};
|
|
|
|
}
|
|
|
|
|
2017-06-28 10:17:14 +02:00
|
|
|
_createStrategy(data) {
|
2016-11-05 10:16:48 +01:00
|
|
|
this.db(TABLE)
|
|
|
|
.insert(this.eventDataToRow(data))
|
2017-06-28 10:17:14 +02:00
|
|
|
.catch(err =>
|
|
|
|
logger.error('Could not insert strategy, error was: ', err)
|
|
|
|
);
|
2016-05-01 22:53:09 +02:00
|
|
|
}
|
2016-12-17 12:31:23 +01:00
|
|
|
|
2017-06-28 10:17:14 +02:00
|
|
|
_updateStrategy(data) {
|
2016-12-17 12:31:23 +01:00
|
|
|
this.db(TABLE)
|
|
|
|
.where({ name: data.name })
|
|
|
|
.update(this.eventDataToRow(data))
|
2017-06-28 10:17:14 +02:00
|
|
|
.catch(err =>
|
|
|
|
logger.error('Could not update strategy, error was: ', err)
|
|
|
|
);
|
2016-12-17 12:31:23 +01:00
|
|
|
}
|
2019-03-13 19:10:13 +01:00
|
|
|
|
|
|
|
_deleteStrategy({ name }) {
|
|
|
|
return this.db(TABLE)
|
|
|
|
.where({ name })
|
|
|
|
.del()
|
|
|
|
.catch(err => {
|
|
|
|
logger.error('Could not delete strategy, error was: ', err);
|
|
|
|
});
|
|
|
|
}
|
|
|
|
|
|
|
|
_importStrategy(data) {
|
2019-03-14 17:56:02 +01:00
|
|
|
const rowData = this.eventDataToRow(data);
|
|
|
|
return this.db(TABLE)
|
|
|
|
.where({ name: rowData.name, built_in: 0 }) // eslint-disable-line
|
|
|
|
.update(rowData)
|
|
|
|
.then(result =>
|
|
|
|
result === 0 ? this.db(TABLE).insert(rowData) : result
|
|
|
|
)
|
2019-03-13 19:10:13 +01:00
|
|
|
.catch(err =>
|
|
|
|
logger.error('Could not import strategy, error was: ', err)
|
|
|
|
);
|
|
|
|
}
|
|
|
|
|
|
|
|
_dropStrategies() {
|
|
|
|
return this.db(TABLE)
|
|
|
|
.where({ built_in: 0 }) // eslint-disable-line
|
|
|
|
.delete()
|
|
|
|
.catch(err =>
|
|
|
|
logger.error('Could not drop strategies, error was: ', err)
|
|
|
|
);
|
|
|
|
}
|
2017-06-28 10:17:14 +02:00
|
|
|
}
|
2014-11-17 22:39:04 +01:00
|
|
|
|
2016-11-05 10:16:48 +01:00
|
|
|
module.exports = StrategyStore;
|