alarams graph link broken
this change also has a fair bit of pep8 cleanup Change-Id: I469246014a45c62150ec6841d2001523f11a6063 Closes-Bug: #1437457
This commit is contained in:
parent
6096575e27
commit
7b4c0a78e8
78
ChangeLog
78
ChangeLog
@ -1,6 +1,84 @@
|
|||||||
CHANGES
|
CHANGES
|
||||||
=======
|
=======
|
||||||
|
|
||||||
|
* Allow dynamic dashboard links
|
||||||
|
|
||||||
|
1.0.24
|
||||||
|
------
|
||||||
|
|
||||||
|
* correct tokens present in url requests
|
||||||
|
|
||||||
|
1.0.23
|
||||||
|
------
|
||||||
|
|
||||||
|
* Fixed display of HTTP exceptions
|
||||||
|
* Format timestamp to be easier to read and sortable
|
||||||
|
|
||||||
|
1.0.22
|
||||||
|
------
|
||||||
|
|
||||||
|
* Handle api returning dict rather than list
|
||||||
|
* Reformat info so it displays well with older horizon versions
|
||||||
|
* move alarm defintion name to be second column since it is useful to recognize alarm
|
||||||
|
* Added Pagerduty to Notification UI
|
||||||
|
* Added a config file for documentation generation using Markdown and readthedocs.org
|
||||||
|
|
||||||
|
1.0.21
|
||||||
|
------
|
||||||
|
|
||||||
|
* Clear leftover text when focus moves from dimension chooser
|
||||||
|
* Add general alarm information to top of alarm history
|
||||||
|
* Adding common alarm metrics dimensions to state change history
|
||||||
|
* Since API does not support actions_enabled on create, don't show in form
|
||||||
|
* Change layout of alarmdef detail to match the latest horizon CSS
|
||||||
|
* Show dashboard buttons on the same line
|
||||||
|
|
||||||
|
1.0.20
|
||||||
|
------
|
||||||
|
|
||||||
|
* Sort alarms by status initially
|
||||||
|
* Show label with status icon. Improves sorting as well
|
||||||
|
* Modify README to include steps to set up dev environment
|
||||||
|
* Outputting common dimensions for multiple metrics
|
||||||
|
* Added a button for the Monasca Health dashboard https://blueprints.launchpad.net/monasca/+spec/monitoring-of-monitoring
|
||||||
|
* Fix filter action logic to allow server side filtering in future
|
||||||
|
* Fixed a dead link in the documentation to alarm expressions. Changed it to the github repo docs
|
||||||
|
* Remove some old unused code
|
||||||
|
|
||||||
|
1.0.19
|
||||||
|
------
|
||||||
|
|
||||||
|
* Allow edits to threshold value
|
||||||
|
* Use relative path from overview to alarm drill down
|
||||||
|
* Add support for non-default WSGIScriptAlias
|
||||||
|
* Ensure that dimensions do not extend beyond field
|
||||||
|
* Backout change for dimension length. No break characters
|
||||||
|
* Allow bulk delete of notifications
|
||||||
|
* Fix layout of metrics with long dimension
|
||||||
|
* Adding option to select WEBHOOK notification
|
||||||
|
|
||||||
|
1.0.18
|
||||||
|
------
|
||||||
|
|
||||||
|
* Cleanup up templates and docs for forms
|
||||||
|
* Fix validation of notification fields
|
||||||
|
* Clean up some small changes
|
||||||
|
|
||||||
|
1.0.17
|
||||||
|
------
|
||||||
|
|
||||||
|
* Pass in monasca-api endpoint to grafana
|
||||||
|
* Only show panesl when the service is in catalog
|
||||||
|
* Pare down requirements.txt to minimum
|
||||||
|
* Added monasca-ui permissions policy
|
||||||
|
* Moved files for better egg packaging
|
||||||
|
|
||||||
|
1.0.16
|
||||||
|
------
|
||||||
|
|
||||||
|
* Allow service type to be customized
|
||||||
|
* Fix bug where we were not saving threshold values in expression editor
|
||||||
|
|
||||||
1.0.15
|
1.0.15
|
||||||
------
|
------
|
||||||
|
|
||||||
|
@ -17,14 +17,17 @@
|
|||||||
import logging
|
import logging
|
||||||
|
|
||||||
from django.core import urlresolvers
|
from django.core import urlresolvers
|
||||||
|
from django.core.urlresolvers import reverse_lazy
|
||||||
from django import template
|
from django import template
|
||||||
from django.utils.translation import ugettext_lazy as _ # noqa
|
from django.utils.translation import ugettext_lazy as _ # noqa
|
||||||
|
|
||||||
from horizon import tables
|
from horizon import tables
|
||||||
|
|
||||||
from monitoring.alarms import constants
|
from monitoring.alarms import constants
|
||||||
|
from monitoring.overview import constants as ov_constants
|
||||||
from monitoring import api
|
from monitoring import api
|
||||||
|
|
||||||
|
|
||||||
LOG = logging.getLogger(__name__)
|
LOG = logging.getLogger(__name__)
|
||||||
|
|
||||||
|
|
||||||
@ -78,15 +81,19 @@ def show_metric_dimensions(data):
|
|||||||
commondimensions = data['metrics'][0]['dimensions']
|
commondimensions = data['metrics'][0]['dimensions']
|
||||||
for metric in data['metrics'][1:]:
|
for metric in data['metrics'][1:]:
|
||||||
for k in commondimensions.keys():
|
for k in commondimensions.keys():
|
||||||
if k not in metric['dimensions'].keys() or commondimensions[k] != metric['dimensions'][k]:
|
if k not in metric['dimensions'].keys() or \
|
||||||
|
commondimensions[k] != metric['dimensions'][k]:
|
||||||
del commondimensions[k]
|
del commondimensions[k]
|
||||||
return ','.join(["%s=%s" % (n, v) for n,v in commondimensions.items()])
|
return ','.join(["%s=%s" % (n, v) for n, v
|
||||||
|
in commondimensions.items()])
|
||||||
else:
|
else:
|
||||||
return ','.join(["%s=%s" % (n, v) for n,v in data['metrics'][0]['dimensions'].items()])
|
return ','.join(["%s=%s" % (n, v) for n, v
|
||||||
|
in data['metrics'][0]['dimensions'].items()])
|
||||||
|
|
||||||
|
|
||||||
def get_service(data):
|
def get_service(data):
|
||||||
if len(data['metrics']) == 1 and 'service' in data['metrics'][0]['dimensions']:
|
if len(data['metrics']) == 1 and 'service'in\
|
||||||
|
data['metrics'][0]['dimensions']:
|
||||||
return data['metrics'][0]['dimensions']['service']
|
return data['metrics'][0]['dimensions']['service']
|
||||||
else:
|
else:
|
||||||
return ''
|
return ''
|
||||||
@ -99,7 +106,8 @@ class ShowAlarmHistory(tables.LinkAction):
|
|||||||
|
|
||||||
def get_link_url(self, datum):
|
def get_link_url(self, datum):
|
||||||
return urlresolvers.reverse(constants.URL_PREFIX + 'history',
|
return urlresolvers.reverse(constants.URL_PREFIX + 'history',
|
||||||
args=(datum['alarm_definition']['id'], datum['id'], ))
|
args=(datum['alarm_definition']['id'],
|
||||||
|
datum['id'], ))
|
||||||
|
|
||||||
def allowed(self, request, datum=None):
|
def allowed(self, request, datum=None):
|
||||||
return True
|
return True
|
||||||
@ -147,12 +155,12 @@ class GraphMetric(tables.LinkAction):
|
|||||||
def get_link_url(self, datum):
|
def get_link_url(self, datum):
|
||||||
name = datum['metrics'][0]['name']
|
name = datum['metrics'][0]['name']
|
||||||
threshold = datum['metrics']
|
threshold = datum['metrics']
|
||||||
token = self.table.request.user.token.id
|
endpoint = str(reverse_lazy(ov_constants.URL_PREFIX + 'proxy'))
|
||||||
endpoint = api.monitor.monasca_endpoint(self.table.request)
|
endpoint = self.table.request.build_absolute_uri(endpoint)
|
||||||
self.attrs['target'] = '_blank'
|
self.attrs['target'] = '_blank'
|
||||||
url = '/static/grafana/index.html#/dashboard/script/detail.js'
|
url = '/static/grafana/index.html#/dashboard/script/detail.js'
|
||||||
query = "?token=%s&name=%s&threshold=%s&api=%s" % \
|
query = "?name=%s&threshold=%s&api=%s" % \
|
||||||
(token, name, threshold, endpoint)
|
(name, threshold, endpoint)
|
||||||
return url + query
|
return url + query
|
||||||
|
|
||||||
def allowed(self, request, datum=None):
|
def allowed(self, request, datum=None):
|
||||||
@ -164,8 +172,9 @@ class ShowAlarmDefinition(tables.LinkAction):
|
|||||||
verbose_name = _("Show Alarm Definition")
|
verbose_name = _("Show Alarm Definition")
|
||||||
|
|
||||||
def get_link_url(self, datum=None):
|
def get_link_url(self, datum=None):
|
||||||
return urlresolvers.reverse_lazy('horizon:monitoring:alarmdefs:alarm_detail',
|
url = 'horizon:monitoring:alarmdefs:alarm_detail'
|
||||||
args=(datum['alarm_definition']['id'],))
|
args = (datum['alarm_definition']['id'],)
|
||||||
|
return urlresolvers.reverse_lazy(url, args=args)
|
||||||
|
|
||||||
|
|
||||||
class DeleteAlarm(tables.DeleteAction):
|
class DeleteAlarm(tables.DeleteAction):
|
||||||
@ -191,11 +200,13 @@ class AlarmsFilterAction(tables.FilterAction):
|
|||||||
|
|
||||||
class AlarmsTable(tables.DataTable):
|
class AlarmsTable(tables.DataTable):
|
||||||
state = tables.Column(transform=show_severity, verbose_name=_('Status'),
|
state = tables.Column(transform=show_severity, verbose_name=_('Status'),
|
||||||
status_choices={(show_status('OK'), True)},
|
status_choices={(show_status('OK'), True)},
|
||||||
filters=[show_status, template.defaultfilters.safe])
|
filters=[show_status, template.defaultfilters.safe])
|
||||||
name = tables.Column(transform=show_def_name, verbose_name=_('Name'))
|
name = tables.Column(transform=show_def_name, verbose_name=_('Name'))
|
||||||
metrics = tables.Column(transform=show_metric_name, verbose_name=_('Metric Name'))
|
metrics = tables.Column(transform=show_metric_name,
|
||||||
dimensions = tables.Column(transform=show_metric_dimensions, verbose_name=_('Metric Dimensions'))
|
verbose_name=_('Metric Name'))
|
||||||
|
dimensions = tables.Column(transform=show_metric_dimensions,
|
||||||
|
verbose_name=_('Metric Dimensions'))
|
||||||
|
|
||||||
def get_object_id(self, obj):
|
def get_object_id(self, obj):
|
||||||
return obj['id']
|
return obj['id']
|
||||||
@ -213,7 +224,7 @@ class AlarmsTable(tables.DataTable):
|
|||||||
)
|
)
|
||||||
table_actions = (AlarmsFilterAction,
|
table_actions = (AlarmsFilterAction,
|
||||||
DeleteAlarm,
|
DeleteAlarm,
|
||||||
)
|
)
|
||||||
|
|
||||||
|
|
||||||
def show_timestamp(data):
|
def show_timestamp(data):
|
||||||
@ -221,10 +232,12 @@ def show_timestamp(data):
|
|||||||
|
|
||||||
|
|
||||||
class AlarmHistoryTable(tables.DataTable):
|
class AlarmHistoryTable(tables.DataTable):
|
||||||
timestamp = tables.Column(transform=show_timestamp, verbose_name=_('Timestamp'))
|
timestamp = tables.Column(transform=show_timestamp,
|
||||||
|
verbose_name=_('Timestamp'))
|
||||||
old_state = tables.Column('old_state', verbose_name=_('Old State'))
|
old_state = tables.Column('old_state', verbose_name=_('Old State'))
|
||||||
new_state = tables.Column('new_state', verbose_name=_('New State'))
|
new_state = tables.Column('new_state', verbose_name=_('New State'))
|
||||||
alarmDimensions = tables.Column(transform=show_metric_dimensions, verbose_name=_('Alarm Metric Dimensions'))
|
alarmDimensions = tables.Column(transform=show_metric_dimensions,
|
||||||
|
verbose_name=_('Alarm Metric Dimensions'))
|
||||||
reason = tables.Column('reason', verbose_name=_('Reason'))
|
reason = tables.Column('reason', verbose_name=_('Reason'))
|
||||||
# reason_data = tables.Column('reason_data', verbose_name=_('Reason Data'))
|
# reason_data = tables.Column('reason_data', verbose_name=_('Reason Data'))
|
||||||
|
|
||||||
|
@ -1 +1,2 @@
|
|||||||
python-monascaclient
|
python-monascaclient
|
||||||
|
django<1.8
|
Loading…
Reference in New Issue
Block a user