0
0
Fork 0
mirror of https://github.com/alerta/alerta.git synced 2025-01-24 09:19:40 +00:00
alerta_alerta/alerta/plugins/__init__.py

88 lines
2.7 KiB
Python

import abc
import logging
import os
from typing import TYPE_CHECKING, Any, Optional
if TYPE_CHECKING:
from alerta.models.alert import Alert # noqa
LOG = logging.getLogger('alerta.plugins')
class PluginBase(metaclass=abc.ABCMeta):
def __init__(self, name=None):
self.name = name or self.__module__
if self.__doc__:
LOG.info(f'\n{self.__doc__}\n')
@abc.abstractmethod
def pre_receive(self, alert: 'Alert', **kwargs) -> 'Alert':
"""
Pre-process an alert based on alert properties or reject it
by raising RejectException or BlackoutPeriod.
"""
raise NotImplementedError
@abc.abstractmethod
def post_receive(self, alert: 'Alert', **kwargs) -> Optional['Alert']:
"""Send an alert to another service or notify users."""
raise NotImplementedError
@abc.abstractmethod
def status_change(self, alert: 'Alert', status: str, text: str, **kwargs) -> Any:
"""Trigger integrations based on status changes."""
raise NotImplementedError
def take_action(self, alert: 'Alert', action: str, text: str, **kwargs) -> Any:
"""
Trigger integrations based on external actions. (optional)
Pre-trigger, eg. this triggers before the status are updated.
"""
raise NotImplementedError
def post_action(self, alert: 'Alert', action: str, text: str, **kwargs) -> Any:
"""
Trigger integrations based on external actions. (optional)
Post-trigger, eg. after the status is updated"""
raise NotImplementedError
def take_note(self, alert: 'Alert', text: Optional[str], **kwargs) -> Any:
"""Trigger integrations based on notes. (optional)"""
raise NotImplementedError
def delete(self, alert: 'Alert', **kwargs) -> bool:
"""Trigger integrations when an alert is deleted. (optional)"""
raise NotImplementedError
@staticmethod
def get_config(key, default=None, type=None, **kwargs):
if key in os.environ:
rv = os.environ[key]
if type == bool:
return rv.lower() in ['yes', 'on', 'true', 't', '1']
elif type == list:
return rv.split(',')
elif type is not None:
try:
rv = type(rv)
except ValueError:
rv = default
return rv
try:
rv = kwargs['config'].get(key, default)
except KeyError:
rv = default
return rv
class FakeApp:
def init_app(self):
from alerta.app import config
self.config = config.get_user_config()
app = FakeApp() # used for plugin config only (deprecated, use kwargs['config'] or get_config(..., **kwargs))