consul/ui/javascripts/app/models.js

261 lines
6.8 KiB
JavaScript
Raw Normal View History

2014-04-25 13:49:36 -04:00
//
// A Consul service.
//
App.Service = Ember.Object.extend({
//
// The number of failing checks within the service.
//
failingChecks: function() {
// If the service was returned from `/v1/internal/ui/services`
// then we have a aggregated value which we can just grab
2014-04-30 14:02:20 -04:00
if (this.get('ChecksCritical') != undefined) {
return (this.get('ChecksCritical') + this.get('ChecksWarning'))
// Otherwise, we need to filter the child checks by both failing
// states
2014-04-30 14:02:20 -04:00
} else {
2014-06-03 13:53:22 -04:00
var checks = this.get('Checks');
return (checks.filterBy('Status', 'critical').get('length') +
checks.filterBy('Status', 'warning').get('length'))
2014-04-30 14:02:20 -04:00
}
2014-04-29 15:24:32 -04:00
}.property('Checks'),
2014-04-25 13:49:36 -04:00
//
// The number of passing checks within the service.
//
passingChecks: function() {
// If the service was returned from `/v1/internal/ui/services`
// then we have a aggregated value which we can just grab
2014-04-30 14:02:20 -04:00
if (this.get('ChecksPassing') != undefined) {
return this.get('ChecksPassing')
// Otherwise, we need to filter the child checks by both failing
// states
2014-04-30 14:02:20 -04:00
} else {
return this.get('Checks').filterBy('Status', 'passing').get('length');
}
2014-04-29 15:24:32 -04:00
}.property('Checks'),
2014-04-25 13:49:36 -04:00
//
// The formatted message returned for the user which represents the
// number of checks failing or passing. Returns `1 passing` or `2 failing`
//
checkMessage: function() {
if (this.get('hasFailingChecks') === false) {
return this.get('passingChecks') + ' passing';
} else {
return this.get('failingChecks') + ' failing';
}
2014-04-29 15:24:32 -04:00
}.property('Checks'),
2014-04-25 13:49:36 -04:00
nodes: function() {
return (this.get('Nodes'))
}.property('Nodes'),
2014-04-25 13:49:36 -04:00
//
// Boolean of whether or not there are failing checks in the service.
// This is used to set color backgrounds and so on.
//
hasFailingChecks: function() {
return (this.get('failingChecks') > 0);
}.property('Checks'),
2014-06-03 13:53:22 -04:00
//
// Key used for filtering through an array of this model, i.e s
// searching
//
filterKey: function() {
return this.get('Name')
2014-06-03 13:53:22 -04:00
}.property('Name'),
2014-04-25 13:49:36 -04:00
});
//
// A Consul Node
//
App.Node = Ember.Object.extend({
//
// The number of failing checks within the service.
//
failingChecks: function() {
var checks = this.get('Checks');
// We view both warning and critical as failing
return (checks.filterBy('Status', 'critical').get('length') +
checks.filterBy('Status', 'warning').get('length'))
}.property('Checks'),
2014-04-25 13:49:36 -04:00
//
// The number of passing checks within the service.
//
passingChecks: function() {
return this.get('Checks').filterBy('Status', 'passing').get('length');
2014-04-29 15:24:32 -04:00
}.property('Checks'),
2014-04-25 13:49:36 -04:00
//
// The formatted message returned for the user which represents the
// number of checks failing or passing. Returns `1 passing` or `2 failing`
//
checkMessage: function() {
if (this.get('hasFailingChecks') === false) {
return this.get('passingChecks') + ' passing';
} else {
return this.get('failingChecks') + ' failing';
}
2014-04-29 15:24:32 -04:00
}.property('Checks'),
2014-04-25 13:49:36 -04:00
//
// Boolean of whether or not there are failing checks in the service.
// This is used to set color backgrounds and so on.
//
hasFailingChecks: function() {
return (this.get('failingChecks') > 0);
}.property('Checks'),
//
// The number of services on the node
//
numServices: function() {
return (this.get('Services').length)
}.property('Services'),
// The number of services on the node
//
services: function() {
return (this.get('Services'))
}.property('Services'),
filterKey: function() {
return this.get('Node')
}.property('Node'),
2014-06-03 13:53:22 -04:00
//
// Returns a combined and distinct list of the tags on the services
// running on the node
//
nodeTags: function() {
var tags = [];
// Collect the services tags
this.get('Services').map(function(Service){
tags.push(Service.Tags)
})
// strip nulls
tags = tags.filter(function(n){ return n != undefined });
// only keep unique tags and convert to comma sep
return tags.uniq().join(', ')
}.property('Services')
2014-04-25 13:49:36 -04:00
});
2014-04-29 13:06:26 -04:00
//
// A key/value object
//
App.Key = Ember.Object.extend(Ember.Validations.Mixin, {
// Validates using the Ember.Valdiations library
validations: {
Key: { presence: true }
},
// Boolean if the key is valid
2014-04-30 15:02:31 -04:00
keyValid: Ember.computed.empty('errors.Key'),
// Boolean if the value is valid
2014-04-30 15:02:31 -04:00
valueValid: Ember.computed.empty('errors.Value'),
// The key with the parent removed.
// This is only for display purposes, and used for
// showing the key name inside of a nested key.
2014-04-30 15:02:31 -04:00
keyWithoutParent: function() {
return (this.get('Key').replace(this.get('parentKey'), ''));
}.property('Key'),
2014-04-30 12:15:54 -04:00
// Boolean if the key is a "folder" or not, i.e is a nested key
// that feels like a folder. Used for UI
2014-04-29 13:06:26 -04:00
isFolder: function() {
if (this.get('Key') === undefined) {
return false;
};
2014-05-04 23:05:00 +02:00
return (this.get('Key').slice(-1) === '/')
2014-04-30 16:30:14 -04:00
}.property('Key'),
2014-06-06 12:21:36 -04:00
// Boolean if the key is locked or now
isLocked: function() {
if (!this.get('Session')) {
return false;
} else {
return true;
}
}.property('Session'),
// Determines what route to link to. If it's a folder,
// it will link to kv.show. Otherwise, kv.edit
2014-04-29 16:32:38 -04:00
linkToRoute: function() {
2014-05-04 23:05:00 +02:00
if (this.get('Key').slice(-1) === '/') {
2014-04-29 16:32:38 -04:00
return 'kv.show'
} else {
return 'kv.edit'
}
2014-04-30 15:02:31 -04:00
}.property('Key'),
2014-04-29 16:32:38 -04:00
// The base64 decoded value of the key.
// if you set on this key, it will update
// the key.Value
2014-04-30 16:30:14 -04:00
valueDecoded: function(key, value) {
// setter
2014-04-30 16:30:14 -04:00
if (arguments.length > 1) {
this.set('Value', value);
2014-04-30 18:31:45 -04:00
return value;
2014-04-30 16:30:14 -04:00
}
// getter
// If the value is null, we don't
// want to try and base64 decode it, so just return
2014-04-30 16:30:14 -04:00
if (this.get('Value') === null) {
return "";
}
// base64 decode the value
2014-04-30 16:30:14 -04:00
return window.atob(this.get('Value'));
}.property('Value'),
// An array of the key broken up by the /
2014-04-29 14:49:07 -04:00
keyParts: function() {
2014-04-30 15:02:31 -04:00
var key = this.get('Key');
2014-04-29 13:34:13 -04:00
// If the key is a folder, remove the last
// slash to split properly
2014-04-29 14:49:07 -04:00
if (key.slice(-1) == "/") {
key = key.substring(0, key.length - 1);
}
2014-04-29 14:49:07 -04:00
return key.split('/');
2014-04-30 15:02:31 -04:00
}.property('Key'),
2014-04-29 14:49:07 -04:00
// The parent Key is the key one level above this.Key
// key: baz/bar/foobar/
// grandParent: baz/bar/
2014-04-29 14:49:07 -04:00
parentKey: function() {
2014-04-29 15:24:32 -04:00
var parts = this.get('keyParts').toArray();
2014-04-29 14:49:07 -04:00
// Remove the last item, essentially going up a level
// in hiearchy
2014-04-29 14:49:07 -04:00
parts.pop();
return parts.join("/") + "/";
2014-04-30 15:02:31 -04:00
}.property('Key'),
2014-04-29 14:49:07 -04:00
// The grandParent Key is the key two levels above this.Key
// key: baz/bar/foobar/
// grandParent: baz/
2014-04-29 14:49:07 -04:00
grandParentKey: function() {
2014-04-29 15:24:32 -04:00
var parts = this.get('keyParts').toArray();
2014-04-29 13:34:13 -04:00
// Remove the last two items, jumping two levels back
2014-04-29 14:49:07 -04:00
parts.pop();
parts.pop();
2014-04-29 13:06:26 -04:00
2014-04-29 14:49:07 -04:00
return parts.join("/") + "/";
2014-04-30 15:02:31 -04:00
}.property('Key')
2014-04-29 13:06:26 -04:00
});