X-Git-Url: https://osm.etsi.org/gitweb/?a=blobdiff_plain;f=plugins%2FOpenStack%2FAodh%2Fplugin_instance.py;h=847d44b342fc95faf12887fc68720a6d9b8fc3c0;hb=bb3c5edd63c1356813a712499dc15bdd91038536;hp=364a12e560d4b1bf460f8e250a5ca8838989db3f;hpb=c27631994b5cc72c2ce2ba0107b9178af6f73662;p=osm%2FMON.git diff --git a/plugins/OpenStack/Aodh/plugin_instance.py b/plugins/OpenStack/Aodh/plugin_instance.py index 364a12e..847d44b 100644 --- a/plugins/OpenStack/Aodh/plugin_instance.py +++ b/plugins/OpenStack/Aodh/plugin_instance.py @@ -1,20 +1,43 @@ +# Copyright 2017 Intel Research and Development Ireland Limited +# ************************************************************* + +# This file is part of OSM Monitoring module +# All Rights Reserved to Intel Corporation + +# 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. + +# For those usages not covered by the Apache License, Version 2.0 please +# contact: helena.mcgough@intel.com or adrian.hoban@intel.com +## """Aodh plugin for the OSM monitoring module.""" import logging as log -#import sys - -#path = "/home/stack/MON" -#if path not in sys.path: -# sys.path.append(path) from plugins.OpenStack.Aodh.alarming import Alarming +from plugins.OpenStack.Aodh.notifier import Notifier from plugins.OpenStack.settings import Config +__author__ = "Helena McGough" + def register_plugin(): """Register the plugin.""" + # Initialize configuration and notifications config = Config.instance() - instance = Plugin(config=config) + notifier = Notifier.instance() + + # Intialize plugin + instance = Plugin(config=config, notifier=notifier) instance.config() instance.alarm() @@ -22,11 +45,12 @@ def register_plugin(): class Plugin(object): """Aodh plugin for OSM MON.""" - def __init__(self, config): + def __init__(self, config, notifier): """Plugin instance.""" log.info("Initialze the plugin instance.") self._config = config - self._alarm = Alarming() + self._alarming = Alarming() + self._notifier = notifier def config(self): """Configure plugin.""" @@ -36,6 +60,13 @@ class Plugin(object): def alarm(self): """Allow alarm info to be received from Aodh.""" log.info("Begin alarm functionality.") - self._alarm.alarming() + self._alarming.alarming() + + def notify(self): + """Send notifications to the SO.""" + # TODO(mcgoughh): Run simultaneously so that notifications + # can be sent while messages are being consumed + log.info("Sending Openstack notifications to the SO.") + self._notifier.notify(self._alarming) register_plugin()