mirror of
https://github.com/status-im/consul.git
synced 2025-01-27 14:05:45 +00:00
6589cbbd0d
* ui: Add the most basic workspace root in /ui * We already have a LICENSE file in the repository root * Change directory path in build scripts ui-v2 -> ui * Make yarn install flags configurable from elsewhere * Minimal workspace root makefile * Call the new docker specific target * Update yarn in the docker build image * Reconfigure the netlify target and move to the higher makefile * Move ui-v2 -> ui/packages/consul-ui * Change repo root to refleect new folder structure * Temporarily don't hoist consul-api-double * Fixup CI configuration * Fixup lint errors * Fixup Netlify target
74 lines
2.3 KiB
JavaScript
74 lines
2.3 KiB
JavaScript
import RepositoryService from 'consul-ui/services/repository';
|
|
import { inject as service } from '@ember/service';
|
|
import { env } from 'consul-ui/env';
|
|
|
|
// meta is used by DataSource to configure polling. The interval controls how
|
|
// long between each poll to the metrics provider. TODO - make this configurable
|
|
// in the UI settings.
|
|
const meta = {
|
|
interval: env('CONSUL_METRICS_POLL_INTERVAL') || 10000,
|
|
};
|
|
|
|
export default RepositoryService.extend({
|
|
cfg: service('ui-config'),
|
|
error: null,
|
|
|
|
init: function() {
|
|
this._super(...arguments);
|
|
const uiCfg = this.cfg.get();
|
|
// Inject whether or not the proxy is enabled as an option into the opaque
|
|
// JSON options the user provided.
|
|
const opts = uiCfg.metrics_provider_options || {};
|
|
opts.metrics_proxy_enabled = uiCfg.metrics_proxy_enabled;
|
|
// Inject the base app URL
|
|
const provider = uiCfg.metrics_provider || 'prometheus';
|
|
|
|
try {
|
|
this.provider = window.consul.getMetricsProvider(provider, opts);
|
|
} catch (e) {
|
|
this.error = new Error(`metrics provider not initialized: ${e}`);
|
|
// Show the user the error once for debugging their provider outside UI
|
|
// Dev.
|
|
console.error(this.error); // eslint-disable-line no-console
|
|
}
|
|
},
|
|
|
|
findServiceSummary: function(protocol, slug, dc, nspace, configuration = {}) {
|
|
if (this.error) {
|
|
return Promise.reject(this.error);
|
|
}
|
|
const promises = [
|
|
// TODO: support namespaces in providers
|
|
this.provider.serviceRecentSummarySeries(slug, protocol, {}),
|
|
this.provider.serviceRecentSummaryStats(slug, protocol, {}),
|
|
];
|
|
return Promise.all(promises).then(function(results) {
|
|
return {
|
|
meta: meta,
|
|
series: results[0],
|
|
stats: results[1].stats,
|
|
};
|
|
});
|
|
},
|
|
|
|
findUpstreamSummary: function(slug, dc, nspace, configuration = {}) {
|
|
if (this.error) {
|
|
return Promise.reject(this.error);
|
|
}
|
|
return this.provider.upstreamRecentSummaryStats(slug, {}).then(function(result) {
|
|
result.meta = meta;
|
|
return result;
|
|
});
|
|
},
|
|
|
|
findDownstreamSummary: function(slug, dc, nspace, configuration = {}) {
|
|
if (this.error) {
|
|
return Promise.reject(this.error);
|
|
}
|
|
return this.provider.downstreamRecentSummaryStats(slug, {}).then(function(result) {
|
|
result.meta = meta;
|
|
return result;
|
|
});
|
|
},
|
|
});
|