mirror of
https://github.com/status-im/consul.git
synced 2025-01-24 04:31:12 +00:00
53b30dda4d
* ui: Use `X-Range` header/meta to decide whether to reconcile or not Previously we used a `shouldReconcile` method in order to decide whether a response should trigger a reconciliation of the frontend ember-data 'source of truth' or not. It's a lot nicer/clearer if this 'flag' can be set alongside the HTTP request information, moreover we almost have the same functionality in `If-Range`/`Partial Content` HTTP functionality. Here we partly follow this HTTP semantics but use a custom `X-Range` header instead.
146 lines
4.8 KiB
JavaScript
146 lines
4.8 KiB
JavaScript
import Service, { inject as service } from '@ember/service';
|
|
import { get } from '@ember/object';
|
|
|
|
export default Service.extend({
|
|
datacenters: service('repository/dc'),
|
|
nodes: service('repository/node'),
|
|
node: service('repository/node'),
|
|
gateways: service('repository/service'),
|
|
services: service('repository/service'),
|
|
service: service('repository/service'),
|
|
['service-instance']: service('repository/service'),
|
|
proxies: service('repository/proxy'),
|
|
['proxy-instance']: service('repository/proxy'),
|
|
['discovery-chain']: service('repository/discovery-chain'),
|
|
coordinates: service('repository/coordinate'),
|
|
sessions: service('repository/session'),
|
|
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 'action': nspace, dc, model, action, ...rest
|
|
const [, nspace, dc, model, ...rest] = src.split('/').map(decodeURIComponent);
|
|
// nspaces can be filled, blank or *
|
|
// so we might get urls like //dc/services
|
|
let find;
|
|
const repo = this[model];
|
|
configuration.createEvent = function(result = {}, configuration) {
|
|
const event = {
|
|
type: 'message',
|
|
data: result,
|
|
};
|
|
const meta = get(event, 'data.meta') || {};
|
|
if (typeof meta.range === 'undefined') {
|
|
repo.reconcile(meta);
|
|
}
|
|
return event;
|
|
};
|
|
let method, slug;
|
|
switch (model) {
|
|
case 'datacenters':
|
|
case 'namespaces':
|
|
find = configuration => repo.findAll(configuration);
|
|
break;
|
|
case 'services':
|
|
case 'nodes':
|
|
case 'roles':
|
|
case 'policies':
|
|
find = configuration => repo.findAllByDatacenter(dc, nspace, configuration);
|
|
break;
|
|
case 'intentions':
|
|
[method, ...slug] = rest;
|
|
switch (method) {
|
|
case 'for-service':
|
|
find = configuration => repo.findByService(slug, dc, nspace, configuration);
|
|
break;
|
|
default:
|
|
find = configuration => repo.findAllByDatacenter(dc, nspace, configuration);
|
|
break;
|
|
}
|
|
break;
|
|
case 'coordinates':
|
|
[method, ...slug] = rest;
|
|
switch (method) {
|
|
case 'for-node':
|
|
find = configuration => repo.findAllByNode(slug, dc, configuration);
|
|
break;
|
|
}
|
|
break;
|
|
case 'proxies':
|
|
[method, ...slug] = rest;
|
|
switch (method) {
|
|
case 'for-service':
|
|
find = configuration => repo.findAllBySlug(slug, dc, nspace, configuration);
|
|
break;
|
|
}
|
|
break;
|
|
case 'gateways':
|
|
[method, ...slug] = rest;
|
|
switch (method) {
|
|
case 'for-service':
|
|
find = configuration => repo.findGatewayBySlug(slug, dc, nspace, configuration);
|
|
break;
|
|
}
|
|
break;
|
|
case 'sessions':
|
|
[method, ...slug] = rest;
|
|
switch (method) {
|
|
case 'for-node':
|
|
find = configuration => repo.findByNode(slug, dc, nspace, configuration);
|
|
break;
|
|
}
|
|
break;
|
|
case 'token':
|
|
find = configuration => repo.self(rest[1], dc);
|
|
break;
|
|
case 'service':
|
|
case 'discovery-chain':
|
|
case 'node':
|
|
find = configuration => repo.findBySlug(rest[0], dc, nspace, configuration);
|
|
break;
|
|
case 'service-instance':
|
|
case 'proxy-instance':
|
|
// id, node, service
|
|
find = configuration =>
|
|
repo.findInstanceBySlug(rest[0], rest[1], rest[2], dc, nspace, configuration);
|
|
break;
|
|
case 'policy':
|
|
case 'kv':
|
|
case 'intention':
|
|
slug = rest[0];
|
|
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);
|
|
},
|
|
});
|