4438b8fd55
This commit enables the check of new pylint/pep8 violations. PYLINT - All convention related checks, except: - missing-class-docstring - missing-function-docstring - missing-module-docstring - consider-using-f-string - invalid-name - import-outside-toplevel - too-many-lines - consider-iterating-dictionary - unnecessary-lambda-assignment PEP8: - E117: over-indented - E123: closing bracket does not match indentation of opening bracket's line - E125: continuation line with the same indent as the next logical line - E305: expected 2 blank lines after class or function definition - E402: module level import not at top of file - E501: line too long - H216: flag use of third party mock Test Plan: 1. Perform `tox` command - Pass in py39, pylint, pep8 Closes-bug: 2033294 Change-Id: I635df8e809905cff582bd9d5eb57b91133560cf9 Signed-off-by: Hugo Brito <hugo.brito@windriver.com>
89 lines
3.1 KiB
Python
89 lines
3.1 KiB
Python
# Copyright (c) 2017 Ericsson AB.
|
|
# Copyright (c) 2017-2022, 2024 Wind River Systems, Inc.
|
|
# All Rights Reserved.
|
|
#
|
|
# 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.
|
|
#
|
|
|
|
from oslo_log import log as logging
|
|
from pecan import expose
|
|
|
|
from dcmanager.api.controllers import restcomm
|
|
from dcmanager.api.policies import alarm_manager as alarm_manager_policy
|
|
from dcmanager.api import policy
|
|
from dcmanager.common import consts
|
|
from dcmanager.db import api as db_api
|
|
|
|
LOG = logging.getLogger(__name__)
|
|
|
|
|
|
class SubcloudAlarmController(object):
|
|
VERSION_ALIASES = {
|
|
'Newton': '1.0',
|
|
}
|
|
|
|
def __init__(self, *args, **kwargs):
|
|
super(SubcloudAlarmController, self).__init__(*args, **kwargs)
|
|
|
|
# to do the version compatibility for future purpose
|
|
def _determine_version_cap(self, target):
|
|
version_cap = 1.0
|
|
return version_cap
|
|
|
|
@expose(generic=True, template='json')
|
|
def index(self):
|
|
# Route the request to specific methods with parameters
|
|
pass
|
|
|
|
def _get_alarm_aggregates(self):
|
|
summary = []
|
|
context = restcomm.extract_context_from_environ()
|
|
alarms = db_api.subcloud_alarms_get_all(context)
|
|
for alarm in alarms:
|
|
alarm_dict = {'region_name': alarm['name'],
|
|
'uuid': alarm['uuid'],
|
|
'critical_alarms': alarm['critical_alarms'],
|
|
'major_alarms': alarm['major_alarms'],
|
|
'minor_alarms': alarm['minor_alarms'],
|
|
'warnings': alarm['warnings'],
|
|
'cloud_status': alarm['cloud_status']}
|
|
summary.append(alarm_dict)
|
|
return {'alarm_summary': summary}
|
|
|
|
@index.when(method='GET', template='json')
|
|
def get(self):
|
|
"""Get List of alarm summarys
|
|
|
|
"""
|
|
policy.authorize(alarm_manager_policy.POLICY_ROOT % "get", {},
|
|
restcomm.extract_credentials_for_policy())
|
|
return self._get_alarm_aggregates()
|
|
|
|
def _get_alarm_summary(self):
|
|
alarms = self._get_alarm_aggregates()
|
|
summary = {consts.ALARM_CRITICAL_STATUS: 0,
|
|
consts.ALARM_DEGRADED_STATUS: 0,
|
|
consts.ALARM_OK_STATUS: 0}
|
|
for alarm in alarms['alarm_summary']:
|
|
summary[alarm['cloud_status']] += 1
|
|
return summary
|
|
|
|
@index.when(method='summary', template='json')
|
|
def summary(self):
|
|
"""Get an agregate of all subcloud status
|
|
|
|
"""
|
|
policy.authorize(alarm_manager_policy.POLICY_ROOT % "get", {},
|
|
restcomm.extract_credentials_for_policy())
|
|
return self._get_alarm_summary()
|