mirror of
https://github.com/status-im/consul.git
synced 2025-01-25 05:00:32 +00:00
04bd576179
When the Consul serf health check is failing, this means that the health checks registered with the agent may no longer be correct. Therefore we show a notice to the user when we detect that the serf health check is failing both for the health check listing for nodes and for service instances. There were a few little things we fixed up whilst we were here: - We use our @replace decorator to replace an empty Type with serf in the model. - We noticed that ServiceTags can be null, so we replace that with an empty array. - We added docs for both our Notice component and the Consul::HealthCheck::List component. Notice now defaults to @type=info.
44 lines
1.2 KiB
JavaScript
44 lines
1.2 KiB
JavaScript
import Fragment from 'ember-data-model-fragments/fragment';
|
|
import { array } from 'ember-data-model-fragments/attributes';
|
|
import { attr } from '@ember-data/model';
|
|
import { computed } from '@ember/object';
|
|
import { replace, nullValue } from 'consul-ui/decorators/replace';
|
|
|
|
export const schema = {
|
|
Status: {
|
|
allowedValues: ['passing', 'warning', 'critical'],
|
|
},
|
|
Type: {
|
|
allowedValues: ['serf', 'script', 'http', 'tcp', 'ttl', 'docker', 'grpc', 'alias'],
|
|
},
|
|
};
|
|
|
|
export default class HealthCheck extends Fragment {
|
|
@attr('string') Name;
|
|
@attr('string') CheckID;
|
|
// an empty Type means its the Consul serf Check
|
|
@replace('', 'serf') @attr('string') Type;
|
|
@attr('string') Status;
|
|
@attr('string') Notes;
|
|
@attr('string') Output;
|
|
@attr('string') ServiceName;
|
|
@attr('string') ServiceID;
|
|
@attr('string') Node;
|
|
@nullValue([]) @array('string') ServiceTags;
|
|
@attr() Definition; // {}
|
|
|
|
// Exposed is only set correct if this Check is accessed via instance.MeshChecks
|
|
// essentially this is a lazy MeshHealthCheckModel
|
|
@attr('boolean') Exposed;
|
|
|
|
@computed('ServiceID')
|
|
get Kind() {
|
|
return this.ServiceID === '' ? 'node' : 'service';
|
|
}
|
|
|
|
@computed('Type')
|
|
get Exposable() {
|
|
return ['http', 'grpc'].includes(this.Type);
|
|
}
|
|
}
|