00cc2527e3
Includes missing configuration options for notifiers in generated config file. Change-Id: I06e6d51bca3b180768bc8c71ff10c9f6e69c5e8b Story: #2003793 Task: #26506
109 lines
3.6 KiB
Python
109 lines
3.6 KiB
Python
# (C) Copyright 2015,2016 Hewlett Packard Enterprise Development LP
|
|
# Copyright 2017 Fujitsu LIMITED
|
|
#
|
|
# Licensed under the Apache License, Version 2.0 (the "License");
|
|
# you may not use this file except in compliance with the License.
|
|
# You may obtain a copy of the License at
|
|
#
|
|
# http://www.apache.org/licenses/LICENSE-2.0
|
|
#
|
|
# Unless required by applicable law or agreed to in writing, software
|
|
# distributed under the License is distributed on an "AS IS" BASIS,
|
|
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or
|
|
# implied.
|
|
# See the License for the specific language governing permissions and
|
|
# limitations under the License.
|
|
|
|
import requests
|
|
import ujson as json
|
|
|
|
from debtcollector import removals
|
|
from oslo_config import cfg
|
|
|
|
from monasca_notification.common import utils
|
|
from monasca_notification.plugins import abstract_notifier
|
|
|
|
CONF = cfg.CONF
|
|
|
|
|
|
class WebhookNotifier(abstract_notifier.AbstractNotifier):
|
|
|
|
type = 'webhook'
|
|
|
|
def __init__(self, log):
|
|
super(WebhookNotifier, self).__init__()
|
|
self._log = log
|
|
|
|
@removals.remove(
|
|
message='Configuration of notifier is available through oslo.cfg',
|
|
version='1.9.0',
|
|
removal_version='3.0.0'
|
|
)
|
|
def config(self, config_dict):
|
|
pass
|
|
|
|
@property
|
|
def statsd_name(self):
|
|
return 'sent_webhook_count'
|
|
|
|
def send_notification(self, notification):
|
|
"""Send the notification via webhook
|
|
Posts on the given url
|
|
"""
|
|
|
|
body = {'alarm_id': notification.alarm_id,
|
|
'alarm_definition_id': notification.raw_alarm['alarmDefinitionId'],
|
|
'alarm_name': notification.alarm_name,
|
|
'alarm_description': notification.raw_alarm['alarmDescription'],
|
|
'alarm_timestamp': notification.alarm_timestamp,
|
|
'state': notification.state,
|
|
'old_state': notification.raw_alarm['oldState'],
|
|
'message': notification.message,
|
|
'tenant_id': notification.tenant_id,
|
|
'metrics': notification.metrics}
|
|
|
|
headers = {'content-type': 'application/json'}
|
|
|
|
# Checks if keystone authentication is enabled and adds authentication
|
|
# token to the request headers
|
|
if CONF.keystone.auth_required:
|
|
auth_token = utils.get_auth_token()
|
|
headers = {'content-type': 'application/json',
|
|
'X-Auth-Token': auth_token}
|
|
|
|
url = notification.address
|
|
|
|
try:
|
|
# Posting on the given URL
|
|
result = requests.post(url=url,
|
|
data=json.dumps(body),
|
|
headers=headers,
|
|
timeout=CONF.webhook_notifier.timeout)
|
|
|
|
if result.status_code in range(200, 300):
|
|
self._log.info("Notification successfully posted.")
|
|
return True
|
|
else:
|
|
self._log.error("Received an HTTP code {} when trying to post on URL {}."
|
|
.format(result.status_code, url))
|
|
return False
|
|
except Exception:
|
|
self._log.exception("Error trying to post on URL {}".format(url))
|
|
return False
|
|
|
|
webhook_notifier_group = cfg.OptGroup(name='%s_notifier' % WebhookNotifier.type)
|
|
webhook_notifier_opts = [
|
|
cfg.IntOpt(name='timeout', default=5, min=1)
|
|
]
|
|
|
|
|
|
def register_opts(conf):
|
|
conf.register_group(webhook_notifier_group)
|
|
conf.register_opts(webhook_notifier_opts, group=webhook_notifier_group)
|
|
|
|
|
|
def list_opts():
|
|
return {
|
|
webhook_notifier_group: webhook_notifier_opts
|
|
}
|