mirror of
https://github.com/Unleash/unleash.git
synced 2025-01-01 00:08:27 +01:00
92eda2660e
It will always reject if the feature is not found, not resolve to null.
69 lines
1.7 KiB
JavaScript
69 lines
1.7 KiB
JavaScript
var eventStore = require('./eventStore');
|
|
var eventType = require('./eventType');
|
|
var logger = require('./logger');
|
|
var knex = require('./dbPool');
|
|
var FEATURE_COLUMNS = ['name', 'description', 'enabled', 'strategy_name', 'parameters'];
|
|
|
|
eventStore.on(eventType.featureCreated, function (event) {
|
|
knex('features')
|
|
.insert(eventToRow(event))
|
|
.catch(function (err) {
|
|
logger.error('Could not insert feature, error was: ', err);
|
|
});
|
|
});
|
|
|
|
eventStore.on(eventType.featureUpdated, function (event) {
|
|
knex('features')
|
|
.where({name: event.data.name})
|
|
.update(eventToRow(event))
|
|
.catch(function (err) {
|
|
logger.error('Could not update feature, error was: ', err);
|
|
});
|
|
});
|
|
|
|
function getFeatures() {
|
|
return knex
|
|
.select(FEATURE_COLUMNS)
|
|
.from('features')
|
|
.orderBy('created_at', 'desc')
|
|
.map(rowToFeature);
|
|
}
|
|
|
|
function getFeature(name) {
|
|
return knex
|
|
.first(FEATURE_COLUMNS)
|
|
.from('features')
|
|
.where({name: name})
|
|
.then(rowToFeature);
|
|
}
|
|
|
|
function rowToFeature(row) {
|
|
if (!row) {
|
|
throw new Error('invalid row');
|
|
}
|
|
|
|
return {
|
|
name: row.name,
|
|
description: row.description,
|
|
enabled: row.enabled > 0,
|
|
strategy: row.strategy_name, // jshint ignore: line
|
|
parameters: row.parameters
|
|
};
|
|
}
|
|
|
|
function eventToRow(event) {
|
|
return {
|
|
name: event.data.name,
|
|
description: event.data.description,
|
|
enabled: event.data.enabled ? 1 : 0,
|
|
strategy_name: event.data.strategy, // jshint ignore: line
|
|
parameters: event.data.parameters
|
|
};
|
|
}
|
|
|
|
module.exports = {
|
|
getFeatures: getFeatures,
|
|
getFeature: getFeature
|
|
};
|
|
|