Freddy fe728855ed
Add DC and NS support for Envoy metrics (#9207)
This PR updates the tags that we generate for Envoy stats.

Several of these come with breaking changes, since we can't keep two stats prefixes for a filter.
2020-11-16 16:37:19 -07:00

28 lines
886 B
JavaScript

import Component from '@glimmer/component';
import { tracked } from '@glimmer/tracking';
import { action } from '@ember/object';
export default class TopologyMetricsStats extends Component {
@tracked stats = null;
@tracked hasLoaded = false;
@action
statsUpdate(event) {
if (this.args.endpoint == 'summary-for-service') {
// For the main service there is just one set of stats.
this.stats = event.data.stats;
} else {
// For up/downstreams we need to pull out the stats for the service we
// represent.
if ((this.args.nspace || '').length === 0) {
this.args.nspace = 'default';
}
let entity = `${this.args.item}.${this.args.nspace}.${this.args.dc}`;
this.stats = event.data.stats[entity];
}
// Limit to 4 metrics for now.
this.stats = (this.stats || []).slice(0, 4);
this.hasLoaded = true;
}
}