mirror of
https://github.com/status-im/consul.git
synced 2025-01-09 13:26:07 +00:00
96 lines
3.3 KiB
JavaScript
96 lines
3.3 KiB
JavaScript
import Service, { inject as service } from '@ember/service';
|
|
import { get } from '@ember/object';
|
|
|
|
export default Service.extend({
|
|
datacenters: service('repository/dc'),
|
|
services: service('repository/service'),
|
|
namespaces: service('repository/nspace'),
|
|
intentions: service('repository/intention'),
|
|
intention: service('repository/intention'),
|
|
kv: service('repository/kv'),
|
|
token: service('repository/token'),
|
|
policies: service('repository/policy'),
|
|
policy: service('repository/policy'),
|
|
roles: service('repository/role'),
|
|
|
|
oidc: service('repository/oidc-provider'),
|
|
type: service('data-source/protocols/http/blocking'),
|
|
source: function(src, configuration) {
|
|
// TODO: Consider adding/requiring nspace, dc, model, action, ...rest
|
|
const [, nspace, dc, model, ...rest] = src.split('/');
|
|
// TODO: Consider throwing if we have an empty nspace or dc
|
|
// we are going to use '*' for 'all' when we need that
|
|
// and an empty value is the same as 'default'
|
|
// reasoning for potentially doing it here is, uri's should
|
|
// always be complete, they should never have things like '///model'
|
|
let find;
|
|
const repo = this[model];
|
|
if (repo.shouldReconcile(src)) {
|
|
configuration.createEvent = function(result = {}, configuration) {
|
|
const event = {
|
|
type: 'message',
|
|
data: result,
|
|
};
|
|
repo.reconcile(get(event, 'data.meta'));
|
|
return event;
|
|
};
|
|
}
|
|
let method, slug;
|
|
switch (model) {
|
|
case 'datacenters':
|
|
case 'namespaces':
|
|
find = configuration => repo.findAll(configuration);
|
|
break;
|
|
case 'token':
|
|
find = configuration => repo.self(rest[1], dc);
|
|
break;
|
|
case 'services':
|
|
case 'roles':
|
|
case 'policies':
|
|
find = configuration => repo.findAllByDatacenter(dc, nspace, configuration);
|
|
break;
|
|
case 'policy':
|
|
find = configuration => repo.findBySlug(rest[0], dc, nspace, configuration);
|
|
break;
|
|
case 'intentions':
|
|
[method, ...slug] = rest;
|
|
switch (method) {
|
|
case 'for-service':
|
|
// TODO: Are we going to need to encode/decode here...?
|
|
find = configuration => repo.findByService(slug.join('/'), dc, nspace, configuration);
|
|
break;
|
|
default:
|
|
find = configuration => repo.findAllByDatacenter(dc, nspace, configuration);
|
|
break;
|
|
}
|
|
break;
|
|
case 'intention':
|
|
// TODO: Are we going to need to encode/decode here...?
|
|
slug = rest.join('/');
|
|
if (slug) {
|
|
find = configuration => repo.findBySlug(slug, dc, nspace, configuration);
|
|
} else {
|
|
find = configuration =>
|
|
Promise.resolve(repo.create({ Datacenter: dc, Namespace: nspace }));
|
|
}
|
|
break;
|
|
case 'oidc':
|
|
[method, ...slug] = rest;
|
|
switch (method) {
|
|
case 'providers':
|
|
find = configuration => repo.findAllByDatacenter(dc, nspace, configuration);
|
|
break;
|
|
case 'provider':
|
|
find = configuration => repo.findBySlug(slug[0], dc, nspace);
|
|
break;
|
|
case 'authorize':
|
|
find = configuration =>
|
|
repo.authorize(slug[0], slug[1], slug[2], dc, nspace, configuration);
|
|
break;
|
|
}
|
|
break;
|
|
}
|
|
return this.type.source(find, configuration);
|
|
},
|
|
});
|