0
0
Fork 0
mirror of https://github.com/alerta/alerta-contrib.git synced 2025-03-16 21:43:30 +00:00
alerta_alerta-contrib/plugins/alertops/alerta_alertops.py
Nick Satterly 4d0961a003
Run pylint in build pipeline (#312)
* Run pylint in build pipeline

* Only report on pylint errors and fix them
2020-02-19 22:45:42 +01:00

77 lines
2.5 KiB
Python

import logging
import os
import re
import requests
from alerta.exceptions import RejectException
from alerta.plugins import PluginBase
try:
from alerta.plugins import app # alerta >= 5.0
except ImportError:
from alerta.app import app # alerta < 5.0
from alerta.plugins import PluginBase
LOG = logging.getLogger('alerta.plugins')
ALERTOPS_URL = os.environ.get('ALERTOPS_URL') or app.config['ALERTOPS_URL']
DASHBOARD_URL = os.environ.get('DASHBOARD_URL') or app.config['DASHBOARD_URL']
class TriggerEvent(PluginBase):
def pre_receive(self, alert, **kwargs):
return alert
@staticmethod
def _event_type(severity):
if severity in ['cleared', 'normal', 'ok']:
return "close"
else:
return "open"
def post_receive(self, alert, **kwargs):
if alert.repeat:
return
message = "%s: %s alert for %s - %s" %( alert.environment, alert.severity.capitalize(), ','.join(alert.service), alert.resource)
payload = {
"source_id": alert.id,
"source_status": TriggerEvent._event_type(alert.severity),
"description": message,
"resource": alert.resource,
"source": "alerta",
"source_url": '%s/#/alert/%s' % (DASHBOARD_URL, alert.id),
"details": alert.get_body(history=False)}
LOG.debug('AlertOps Payload: %s', payload)
try:
r = requests.post(ALERTOPS_URL, json=payload, timeout=2)
except Exception as e:
raise RuntimeError("AlertOps connection error: %s" % e)
LOG.debug('AlertOps response: %s - %s' % (r.status_code, r.text))
return
def status_change(self, alert, status, text, **kwargs):
if status not in ['ack', 'assign']:
return
message = "%s: %s alert for %s - %s" %( alert.environment, alert.severity.capitalize(), ','.join(alert.service), alert.resource)
payload = {
"source_id": alert.id,
"source_status": TriggerEvent._event_type(alert.severity),
"description": message,
"resource": alert.resource,
"source": "alerta",
"source_url": '%s/#/alert/%s' % (DASHBOARD_URL, alert.id),
"details": alert.get_body(history=False)}
try:
r = requests.post(ALERTOPS_URL, json=payload, timeout=2)
except Exception as e:
raise RuntimeError("AlertOps connection error: %s" % e)
LOG.debug('AlertOps response: %s - %s' % (r.status_code, r.text))