blob: d1b408b478df404cd70458f17ca94e76a4f62657 [file] [log] [blame]
Benjamin Diaza97bdb32019-04-10 15:22:22 -03001# -*- coding: utf-8 -*-
2
3# Copyright 2018 Whitestack, LLC
4# *************************************************************
5
6# This file is part of OSM Monitoring module
7# All Rights Reserved to Whitestack, LLC
8
9# Licensed under the Apache License, Version 2.0 (the "License"); you may
10# not use this file except in compliance with the License. You may obtain
11# a copy of the License at
12
13# http://www.apache.org/licenses/LICENSE-2.0
14
15# Unless required by applicable law or agreed to in writing, software
16# distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
17# WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
18# License for the specific language governing permissions and limitations
19# under the License.
20# For those usages not covered by the Apache License, Version 2.0 please
21# contact: bdiaz@whitestack.com or glavado@whitestack.com
22##
Benjamin Diaza97bdb32019-04-10 15:22:22 -030023import logging
Benjamin Diaza97bdb32019-04-10 15:22:22 -030024
Benjamin Diaza97bdb32019-04-10 15:22:22 -030025from osm_mon.core.common_db import CommonDbClient
26from osm_mon.core.config import Config
almagia1b7145f2019-11-30 03:56:04 +010027from osm_mon.core.models import Alarm
Benjamin Diaza97bdb32019-04-10 15:22:22 -030028
29log = logging.getLogger(__name__)
30
31
32class ServerService:
Benjamin Diaza97bdb32019-04-10 15:22:22 -030033 def __init__(self, config: Config):
34 self.common_db = CommonDbClient(config)
35
garciadeblas8e4179f2021-05-14 16:47:03 +020036 def create_alarm(
37 self,
38 name: str,
39 threshold: float,
40 operation: str,
41 severity: str,
42 statistic: str,
43 metric_name: str,
Atul Agarwal927a5842021-03-18 07:54:40 +000044 action: str,
garciadeblas8e4179f2021-05-14 16:47:03 +020045 tags: dict,
46 ) -> Alarm:
palsusc811d682021-02-09 17:03:49 +000047 log.debug("create_alarm")
garciadeblas8e4179f2021-05-14 16:47:03 +020048 alarm = Alarm(
Atul Agarwal927a5842021-03-18 07:54:40 +000049 name, severity, threshold, operation, statistic, metric_name, action, tags
garciadeblas8e4179f2021-05-14 16:47:03 +020050 )
almagia1b7145f2019-11-30 03:56:04 +010051 self.common_db.create_alarm(alarm)
palsusc811d682021-02-09 17:03:49 +000052 log.info("Alarm %s created", alarm.name)
almagia1b7145f2019-11-30 03:56:04 +010053 return alarm
Benjamin Diaza97bdb32019-04-10 15:22:22 -030054
garciadeblas8e4179f2021-05-14 16:47:03 +020055 def delete_alarm(self, alarm_uuid: str) -> None:
palsusc811d682021-02-09 17:03:49 +000056 log.debug("delete_alarm")
almagia1b7145f2019-11-30 03:56:04 +010057 self.common_db.delete_alarm(alarm_uuid)
palsusc811d682021-02-09 17:03:49 +000058 log.info("Alarm %s is deleted", alarm_uuid)
bravof088fbd32021-05-10 11:05:20 -040059
60 def populate_prometheus(self):
61 # This method can be executed infinite number of times
62 # without side-effects.
bravofbabd6362021-11-22 10:26:50 -030063 log.info("Setting up MON Exporter in prometheus")
64 result = self.common_db.common_db.set_one(
bravof088fbd32021-05-10 11:05:20 -040065 "prometheus_jobs", {"job_name": "mon_exporter"}, {
66 "job_name": "mon_exporter",
67 "static_configs": [
68 {
69 "targets": [
70 "mon:8000"
71 ]
72 }
73 ]
74 },
75 fail_on_empty=False,
76 upsert=True
77 )
bravofbabd6362021-11-22 10:26:50 -030078 log.info("Prometheus Jobs added > {}".format(result))