mirror of
https://github.com/Unleash/unleash.git
synced 2024-12-22 19:07:54 +01:00
Check if strategy exsit before deleting it
This commit is contained in:
parent
23e9475ca7
commit
0552e588ae
@ -5,6 +5,7 @@ var strategyDb = require('./strategyDb');
|
|||||||
var logger = require('./logger');
|
var logger = require('./logger');
|
||||||
var NameExistsError = require('./error/NameExistsError');
|
var NameExistsError = require('./error/NameExistsError');
|
||||||
var ValidationError = require('./error/ValidationError');
|
var ValidationError = require('./error/ValidationError');
|
||||||
|
var NotFoundError = require('./error/NotFoundError');
|
||||||
var validateRequest = require('./error/validateRequest');
|
var validateRequest = require('./error/validateRequest');
|
||||||
var extractUser = require('./extractUser');
|
var extractUser = require('./extractUser');
|
||||||
|
|
||||||
@ -23,15 +24,28 @@ module.exports = function (app) {
|
|||||||
});
|
});
|
||||||
|
|
||||||
app.delete('/strategies/:name', function (req, res) {
|
app.delete('/strategies/:name', function (req, res) {
|
||||||
eventStore.create({
|
var strategyName = req.params.name;
|
||||||
|
|
||||||
|
strategyDb.getStrategy(strategyName)
|
||||||
|
.then(function() {
|
||||||
|
return eventStore.create({
|
||||||
type: eventType.strategyDeleted,
|
type: eventType.strategyDeleted,
|
||||||
createdBy: extractUser(req),
|
createdBy: extractUser(req),
|
||||||
data: {
|
data: {
|
||||||
name: req.params.name
|
name: strategyName
|
||||||
}
|
}
|
||||||
|
});
|
||||||
})
|
})
|
||||||
.then(function () { res.status(200).end(); })
|
.then(function() {
|
||||||
.catch(function () { res.status(500).end(); });
|
res.status(200).end();
|
||||||
|
})
|
||||||
|
.catch(NotFoundError, function() {
|
||||||
|
res.status(404).end();
|
||||||
|
})
|
||||||
|
.catch(function(err) {
|
||||||
|
logger.error('Could not delete strategy='+strategyName, err);
|
||||||
|
res.status(500).end();
|
||||||
|
});
|
||||||
});
|
});
|
||||||
|
|
||||||
app.post('/strategies', function (req, res) {
|
app.post('/strategies', function (req, res) {
|
||||||
|
@ -2,6 +2,7 @@ var eventStore = require('./eventStore');
|
|||||||
var eventType = require('./eventType');
|
var eventType = require('./eventType');
|
||||||
var logger = require('./logger');
|
var logger = require('./logger');
|
||||||
var knex = require('./dbPool');
|
var knex = require('./dbPool');
|
||||||
|
var NotFoundError = require('./error/NotFoundError');
|
||||||
var STRATEGY_COLUMNS = ['name', 'description', 'parameters_template'];
|
var STRATEGY_COLUMNS = ['name', 'description', 'parameters_template'];
|
||||||
|
|
||||||
eventStore.on(eventType.strategyCreated, function (event) {
|
eventStore.on(eventType.strategyCreated, function (event) {
|
||||||
@ -35,7 +36,7 @@ function getStrategy(name) {
|
|||||||
|
|
||||||
function rowToStrategy(row) {
|
function rowToStrategy(row) {
|
||||||
if (!row) {
|
if (!row) {
|
||||||
throw new Error('invalid row');
|
throw new NotFoundError('No strategy found');
|
||||||
}
|
}
|
||||||
|
|
||||||
return {
|
return {
|
||||||
|
@ -55,7 +55,14 @@ describe('The strategy api', function () {
|
|||||||
|
|
||||||
it('deletes a new strategy', function (done) {
|
it('deletes a new strategy', function (done) {
|
||||||
request
|
request
|
||||||
.delete('/strategies/deletable')
|
.delete('/strategies/usersWithEmail')
|
||||||
.expect(200, done);
|
.expect(200, done);
|
||||||
});
|
});
|
||||||
|
|
||||||
|
it('can\'t delete a strategy that dose not exist', function(done) {
|
||||||
|
request
|
||||||
|
.delete('/strategies/unknown')
|
||||||
|
.expect(404, done);
|
||||||
|
});
|
||||||
|
|
||||||
});
|
});
|
Loading…
Reference in New Issue
Block a user