1
0
mirror of https://github.com/Unleash/unleash.git synced 2025-01-06 00:07:44 +01:00

Introduces the /api path.

Some endpoints are provided on both / and /api
to support older clients.

Closes #162
This commit is contained in:
Ivar 2016-11-09 22:31:49 +01:00
parent eab0de78e5
commit 7ae2b4b65d
8 changed files with 37 additions and 25 deletions

View File

@ -12,7 +12,7 @@ const path = require('path');
module.exports = function (config) { module.exports = function (config) {
const app = express(); const app = express();
const router = express.Router(); // eslint-disable-line new-cap
const baseUriPath = config.baseUriPath || ''; const baseUriPath = config.baseUriPath || '';
const publicFolder = config.publicFolder; const publicFolder = config.publicFolder;
@ -37,7 +37,13 @@ module.exports = function (config) {
})); }));
// Setup API routes // Setup API routes
routes.create(router, config); const apiRouter = express.Router(); // eslint-disable-line new-cap
routes.createAPI(apiRouter, config);
app.use(`${baseUriPath}/api/`, apiRouter);
// Setup deprecated routes
const router = express.Router(); // eslint-disable-line new-cap
routes.createLegacy(router, config);
app.use(baseUriPath, router); app.use(baseUriPath, router);
if (process.env.NODE_ENV !== 'production') { if (process.env.NODE_ENV !== 'production') {

View File

@ -1,10 +1,16 @@
'use strict'; 'use strict';
exports.create = function (app, config) {
require('./event')(app, config); exports.createAPI = function (router, config) {
require('./feature')(app, config); require('./event')(router, config);
require('./feature-archive')(app, config); require('./feature')(router, config);
require('./strategy')(app, config); require('./feature-archive')(router, config);
require('./health-check')(app, config); require('./strategy')(router, config);
require('./metrics')(app, config); require('./health-check')(router, config);
require('./metrics')(router, config);
};
exports.createLegacy = function (router, config) {
require('./feature')(router, config);
require('./health-check')(router, config);
}; };

View File

@ -1,6 +1,6 @@
--create new client_strategies table --create new client_strategies table
CREATE TABLE client_strategies ( CREATE TABLE client_strategies (
app_name varchar(255) PRIMARY KEY NOT NULL, app_name varchar(255) PRIMARY KEY NOT NULL,
updated_at timestamp default now(), r timestamp default now(),
strategies json strategies json
); );

View File

@ -5,14 +5,14 @@ const request = require('./test-helper').request;
describe('The event api', () => { describe('The event api', () => {
it('returns events', done => { it('returns events', done => {
request request
.get('/events') .get('/api/events')
.expect('Content-Type', /json/) .expect('Content-Type', /json/)
.expect(200, done); .expect(200, done);
}); });
it('returns events given a name', done => { it('returns events given a name', done => {
request request
.get('/events/myname') .get('/api/events/myname')
.expect('Content-Type', /json/) .expect('Content-Type', /json/)
.expect(200, done); .expect(200, done);
}); });

View File

@ -58,7 +58,7 @@ describe('The features api', () => {
.set('Content-Type', 'application/json') .set('Content-Type', 'application/json')
.end(() => { .end(() => {
request request
.get('/events') .get('/api/events')
.end((err, res) => { .end((err, res) => {
assert.equal(res.body.events[0].createdBy, 'ivaosthu'); assert.equal(res.body.events[0].createdBy, 'ivaosthu');
done(); done();

View File

@ -16,7 +16,7 @@ describe('The archive features api', () => {
it('returns three archived toggles', done => { it('returns three archived toggles', done => {
request request
.get('/archive/features') .get('/api/archive/features')
.expect('Content-Type', /json/) .expect('Content-Type', /json/)
.expect(200) .expect(200)
.end((err, res) => { .end((err, res) => {
@ -27,7 +27,7 @@ describe('The archive features api', () => {
it('revives a feature by name', done => { it('revives a feature by name', done => {
request request
.post('/archive/revive') .post('/api/archive/revive')
.send({ name: 'featureArchivedX' }) .send({ name: 'featureArchivedX' })
.set('Content-Type', 'application/json') .set('Content-Type', 'application/json')
.expect(200, done); .expect(200, done);
@ -35,7 +35,7 @@ describe('The archive features api', () => {
it('must set name when reviving toggle', done => { it('must set name when reviving toggle', done => {
request request
.post('/archive/revive') .post('/api/archive/revive')
.send({ name: '' }) .send({ name: '' })
.expect(400, done); .expect(400, done);
}); });

View File

@ -12,28 +12,28 @@ describe('The strategy api', () => {
it('gets all strategies', done => { it('gets all strategies', done => {
request request
.get('/strategies') .get('/api/strategies')
.expect('Content-Type', /json/) .expect('Content-Type', /json/)
.expect(200, done); .expect(200, done);
}); });
it('gets a strategy by name', done => { it('gets a strategy by name', done => {
request request
.get('/strategies/default') .get('/api/strategies/default')
.expect('Content-Type', /json/) .expect('Content-Type', /json/)
.expect(200, done); .expect(200, done);
}); });
it('cant get a strategy by name that dose not exist', done => { it('cant get a strategy by name that dose not exist', done => {
request request
.get('/strategies/mystrategy') .get('/api/strategies/mystrategy')
.expect('Content-Type', /json/) .expect('Content-Type', /json/)
.expect(404, done); .expect(404, done);
}); });
it('creates a new strategy', done => { it('creates a new strategy', done => {
request request
.post('/strategies') .post('/api/strategies')
.send({ name: 'myCustomStrategy', description: 'Best strategy ever.' }) .send({ name: 'myCustomStrategy', description: 'Best strategy ever.' })
.set('Content-Type', 'application/json') .set('Content-Type', 'application/json')
.expect(201, done); .expect(201, done);
@ -41,7 +41,7 @@ describe('The strategy api', () => {
it('requires new strategies to have a name', done => { it('requires new strategies to have a name', done => {
request request
.post('/strategies') .post('/api/strategies')
.send({ name: '' }) .send({ name: '' })
.set('Content-Type', 'application/json') .set('Content-Type', 'application/json')
.expect(400, done); .expect(400, done);
@ -49,7 +49,7 @@ describe('The strategy api', () => {
it('refuses to create a strategy with an existing name', done => { it('refuses to create a strategy with an existing name', done => {
request request
.post('/strategies') .post('/api/strategies')
.send({ name: 'default' }) .send({ name: 'default' })
.set('Content-Type', 'application/json') .set('Content-Type', 'application/json')
.expect(403, done); .expect(403, done);
@ -57,13 +57,13 @@ describe('The strategy api', () => {
it('deletes a new strategy', done => { it('deletes a new strategy', done => {
request request
.delete('/strategies/usersWithEmail') .delete('/api/strategies/usersWithEmail')
.expect(200, done); .expect(200, done);
}); });
it('can\'t delete a strategy that dose not exist', done => { it('can\'t delete a strategy that dose not exist', done => {
request request
.delete('/strategies/unknown') .delete('/api/strategies/unknown')
.expect(404, done); .expect(404, done);
}); });
}); });

View File

@ -33,7 +33,7 @@ describe('Unit: The strategies api', () => {
it('should add version numbers for /stategies', (done) => { it('should add version numbers for /stategies', (done) => {
request request
.get('/strategies') .get('/api/strategies')
.expect('Content-Type', /json/) .expect('Content-Type', /json/)
.expect(200) .expect(200)
.end((err, res) => { .end((err, res) => {