mirror of
				https://github.com/Unleash/unleash.git
				synced 2025-10-27 11:02:16 +01:00 
			
		
		
		
	chore(modernize): Use base controller for all client controllers
This commit is contained in:
		
							parent
							
								
									9eb0d2e535
								
							
						
					
					
						commit
						2ce0f074bb
					
				@ -49,11 +49,7 @@ module.exports = function(config) {
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    // Setup API routes
 | 
			
		||||
    const middleware = new IndexRouter(config);
 | 
			
		||||
    if (!middleware) {
 | 
			
		||||
        throw new Error('Routes invalid');
 | 
			
		||||
    }
 | 
			
		||||
    app.use(`${baseUriPath}/`, middleware.router());
 | 
			
		||||
    app.use(`${baseUriPath}/`, new IndexRouter(config).router);
 | 
			
		||||
 | 
			
		||||
    if (process.env.NODE_ENV !== 'production') {
 | 
			
		||||
        app.use(errorHandler());
 | 
			
		||||
 | 
			
		||||
@ -201,6 +201,7 @@ test('invalid feature names should not pass validation', t => {
 | 
			
		||||
    );
 | 
			
		||||
});
 | 
			
		||||
 | 
			
		||||
// Make sure current UI works. Should align on joi errors in future.
 | 
			
		||||
test('invalid feature names should have error msg', t => {
 | 
			
		||||
    t.plan(1);
 | 
			
		||||
    const { request, base } = getSetup();
 | 
			
		||||
 | 
			
		||||
@ -16,10 +16,10 @@ class AdminApi extends Controller {
 | 
			
		||||
        const stores = config.stores;
 | 
			
		||||
 | 
			
		||||
        this.app.get('/', this.index);
 | 
			
		||||
        this.app.use('/features', new FeatureController(stores).router());
 | 
			
		||||
        this.app.use('/archive', new ArchiveController(stores).router());
 | 
			
		||||
        this.app.use('/features', new FeatureController(stores).router);
 | 
			
		||||
        this.app.use('/archive', new ArchiveController(stores).router);
 | 
			
		||||
        this.app.use('/strategies', strategies.router(config));
 | 
			
		||||
        this.app.use('/events', new EventController(stores).router());
 | 
			
		||||
        this.app.use('/events', new EventController(stores).router);
 | 
			
		||||
        this.app.use('/metrics', metrics.router(config));
 | 
			
		||||
        this.app.use('/user', user.router(config));
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
@ -1,24 +1,18 @@
 | 
			
		||||
'use strict';
 | 
			
		||||
 | 
			
		||||
const { Router } = require('express');
 | 
			
		||||
const { register: prometheusRegister } = require('prom-client');
 | 
			
		||||
const Controller = require('./controller');
 | 
			
		||||
 | 
			
		||||
class BackstageController {
 | 
			
		||||
class BackstageController extends Controller {
 | 
			
		||||
    constructor(config) {
 | 
			
		||||
        const router = Router();
 | 
			
		||||
        super();
 | 
			
		||||
 | 
			
		||||
        if (config.serverMetrics) {
 | 
			
		||||
            router.get('/prometheus', (req, res) => {
 | 
			
		||||
            this.get('/prometheus', (req, res) => {
 | 
			
		||||
                res.set('Content-Type', prometheusRegister.contentType);
 | 
			
		||||
                res.end(prometheusRegister.metrics());
 | 
			
		||||
            });
 | 
			
		||||
        }
 | 
			
		||||
 | 
			
		||||
        this.app = router;
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    router() {
 | 
			
		||||
        return this.app;
 | 
			
		||||
    }
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
@ -1,18 +1,17 @@
 | 
			
		||||
'use strict';
 | 
			
		||||
 | 
			
		||||
const { Router } = require('express');
 | 
			
		||||
const Controller = require('../controller');
 | 
			
		||||
const { filter } = require('./util');
 | 
			
		||||
 | 
			
		||||
const version = 1;
 | 
			
		||||
 | 
			
		||||
class FeatureController {
 | 
			
		||||
class FeatureController extends Controller {
 | 
			
		||||
    constructor({ featureToggleStore }) {
 | 
			
		||||
        const router = Router();
 | 
			
		||||
        this._router = router;
 | 
			
		||||
        super();
 | 
			
		||||
        this.toggleStore = featureToggleStore;
 | 
			
		||||
 | 
			
		||||
        router.get('/', (req, res) => this.getAll(req, res));
 | 
			
		||||
        router.get('/:featureName', this.getFeatureToggle.bind(this));
 | 
			
		||||
        this.get('/', this.getAll);
 | 
			
		||||
        this.get('/:featureName', this.getFeatureToggle);
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    async getAll(req, res) {
 | 
			
		||||
@ -33,10 +32,6 @@ class FeatureController {
 | 
			
		||||
            res.status(404).json({ error: 'Could not find feature' });
 | 
			
		||||
        }
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    router() {
 | 
			
		||||
        return this._router;
 | 
			
		||||
    }
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
module.exports = FeatureController;
 | 
			
		||||
 | 
			
		||||
@ -1,31 +1,26 @@
 | 
			
		||||
'use strict';
 | 
			
		||||
 | 
			
		||||
const { Router } = require('express');
 | 
			
		||||
const Controller = require('../controller');
 | 
			
		||||
const FeatureController = require('./feature.js');
 | 
			
		||||
const MetricsController = require('./metrics.js');
 | 
			
		||||
const RegisterController = require('./register.js');
 | 
			
		||||
const apiDef = require('./api-def.json');
 | 
			
		||||
 | 
			
		||||
class ClientApi {
 | 
			
		||||
class ClientApi extends Controller {
 | 
			
		||||
    constructor(config) {
 | 
			
		||||
        const router = Router();
 | 
			
		||||
        this._router = router;
 | 
			
		||||
        super();
 | 
			
		||||
 | 
			
		||||
        const stores = config.stores;
 | 
			
		||||
 | 
			
		||||
        router.get('/', this.index);
 | 
			
		||||
        router.use('/features', new FeatureController(stores).router());
 | 
			
		||||
        router.use('/metrics', new MetricsController(stores).router());
 | 
			
		||||
        router.use('/register', new RegisterController(stores).router());
 | 
			
		||||
        this.get('/', this.index);
 | 
			
		||||
        this.use('/features', new FeatureController(stores).router);
 | 
			
		||||
        this.use('/metrics', new MetricsController(stores).router);
 | 
			
		||||
        this.use('/register', new RegisterController(stores).router);
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    index(req, res) {
 | 
			
		||||
        res.json(apiDef);
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    router() {
 | 
			
		||||
        return this._router;
 | 
			
		||||
    }
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
module.exports = ClientApi;
 | 
			
		||||
 | 
			
		||||
@ -1,19 +1,18 @@
 | 
			
		||||
'use strict';
 | 
			
		||||
 | 
			
		||||
const { Router } = require('express');
 | 
			
		||||
const joi = require('joi');
 | 
			
		||||
const logger = require('../../logger')('client-api/metrics.js');
 | 
			
		||||
 | 
			
		||||
const Controller = require('../controller');
 | 
			
		||||
const { clientMetricsSchema } = require('./metrics-schema');
 | 
			
		||||
 | 
			
		||||
class ClientMetricsController {
 | 
			
		||||
class ClientMetricsController extends Controller {
 | 
			
		||||
    constructor({ clientMetricsStore, clientInstanceStore }) {
 | 
			
		||||
        const router = Router();
 | 
			
		||||
        super();
 | 
			
		||||
        this.clientMetricsStore = clientMetricsStore;
 | 
			
		||||
        this.clientInstanceStore = clientInstanceStore;
 | 
			
		||||
        this._router = router;
 | 
			
		||||
 | 
			
		||||
        router.post('/', (req, res) => this.registerMetrics(req, res));
 | 
			
		||||
        this.post('/', this.registerMetrics);
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    async registerMetrics(req, res) {
 | 
			
		||||
@ -40,10 +39,6 @@ class ClientMetricsController {
 | 
			
		||||
            res.status(500).end();
 | 
			
		||||
        }
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    router() {
 | 
			
		||||
        return this._router;
 | 
			
		||||
    }
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
module.exports = ClientMetricsController;
 | 
			
		||||
 | 
			
		||||
@ -1,19 +1,18 @@
 | 
			
		||||
'use strict';
 | 
			
		||||
 | 
			
		||||
const { Router } = require('express');
 | 
			
		||||
const joi = require('joi');
 | 
			
		||||
const logger = require('../../logger')('/client-api/register.js');
 | 
			
		||||
 | 
			
		||||
const Controller = require('../controller');
 | 
			
		||||
const { clientRegisterSchema: schema } = require('./register-schema');
 | 
			
		||||
 | 
			
		||||
class RegisterController {
 | 
			
		||||
class RegisterController extends Controller {
 | 
			
		||||
    constructor({ clientInstanceStore, clientApplicationsStore }) {
 | 
			
		||||
        const router = Router();
 | 
			
		||||
        this._router = router;
 | 
			
		||||
        super();
 | 
			
		||||
        this.clientInstanceStore = clientInstanceStore;
 | 
			
		||||
        this.clientApplicationsStore = clientApplicationsStore;
 | 
			
		||||
 | 
			
		||||
        router.post('/', (req, res) => this.handleRegister(req, res));
 | 
			
		||||
        this.post('/', this.handleRegister);
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    async handleRegister(req, res) {
 | 
			
		||||
@ -41,10 +40,6 @@ class RegisterController {
 | 
			
		||||
            return res.status(500).end();
 | 
			
		||||
        }
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    router() {
 | 
			
		||||
        return this._router;
 | 
			
		||||
    }
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
module.exports = RegisterController;
 | 
			
		||||
 | 
			
		||||
@ -26,7 +26,11 @@ class Controller {
 | 
			
		||||
        this.app.delete(path, handler.bind(this));
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    router() {
 | 
			
		||||
    use(path, router) {
 | 
			
		||||
        this.app.use(path, router);
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    get router() {
 | 
			
		||||
        return this.app;
 | 
			
		||||
    }
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
@ -1,16 +1,14 @@
 | 
			
		||||
'use strict';
 | 
			
		||||
 | 
			
		||||
const { Router } = require('express');
 | 
			
		||||
const logger = require('../logger')('health-check.js');
 | 
			
		||||
const Controller = require('./controller');
 | 
			
		||||
 | 
			
		||||
class HealthCheckController {
 | 
			
		||||
class HealthCheckController extends Controller {
 | 
			
		||||
    constructor(config) {
 | 
			
		||||
        const app = Router();
 | 
			
		||||
 | 
			
		||||
        this.app = app;
 | 
			
		||||
        super();
 | 
			
		||||
        this.db = config.stores.db;
 | 
			
		||||
 | 
			
		||||
        app.get('/', (req, res) => this.index(req, res));
 | 
			
		||||
        this.get('/', (req, res) => this.index(req, res));
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    async index(req, res) {
 | 
			
		||||
@ -22,10 +20,6 @@ class HealthCheckController {
 | 
			
		||||
            res.status(500).json({ health: 'BAD' });
 | 
			
		||||
        }
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    router() {
 | 
			
		||||
        return this.app;
 | 
			
		||||
    }
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
module.exports = HealthCheckController;
 | 
			
		||||
 | 
			
		||||
@ -1,36 +1,32 @@
 | 
			
		||||
'use strict';
 | 
			
		||||
 | 
			
		||||
const { Router } = require('express');
 | 
			
		||||
const AdminApi = require('./admin-api');
 | 
			
		||||
const ClientApi = require('./client-api');
 | 
			
		||||
const FeatureController = require('./client-api/feature.js');
 | 
			
		||||
 | 
			
		||||
const Controller = require('./controller');
 | 
			
		||||
const HealthCheckController = require('./health-check');
 | 
			
		||||
const BackstageCTR = require('./backstage.js');
 | 
			
		||||
const api = require('./api-def');
 | 
			
		||||
 | 
			
		||||
class IndexRouter {
 | 
			
		||||
class IndexRouter extends Controller {
 | 
			
		||||
    constructor(config) {
 | 
			
		||||
        const router = Router();
 | 
			
		||||
        this._router = router;
 | 
			
		||||
 | 
			
		||||
        router.use('/health', new HealthCheckController(config).router());
 | 
			
		||||
        router.use('/internal-backstage', new BackstageCTR(config).router());
 | 
			
		||||
        router.get(api.uri, (req, res) => res.json(api));
 | 
			
		||||
        router.use(api.links.admin.uri, new AdminApi(config).router());
 | 
			
		||||
        router.use(api.links.client.uri, new ClientApi(config).router());
 | 
			
		||||
        super();
 | 
			
		||||
        this.use('/health', new HealthCheckController(config).router);
 | 
			
		||||
        this.use('/internal-backstage', new BackstageCTR(config).router);
 | 
			
		||||
        this.get(api.uri, this.index);
 | 
			
		||||
        this.use(api.links.admin.uri, new AdminApi(config).router);
 | 
			
		||||
        this.use(api.links.client.uri, new ClientApi(config).router);
 | 
			
		||||
 | 
			
		||||
        // legacy support (remove in 4.x)
 | 
			
		||||
        if (config.enableLegacyRoutes) {
 | 
			
		||||
            router.use(
 | 
			
		||||
                '/api/features',
 | 
			
		||||
                new FeatureController(config.stores).router()
 | 
			
		||||
            );
 | 
			
		||||
            const featureController = new FeatureController(config.stores);
 | 
			
		||||
            this.use('/api/features', featureController.router);
 | 
			
		||||
        }
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    router() {
 | 
			
		||||
        return this._router;
 | 
			
		||||
    index(req, res) {
 | 
			
		||||
        res.json(api);
 | 
			
		||||
    }
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
		Loading…
	
		Reference in New Issue
	
	Block a user