Files
python-observabilityclient/observabilityclient/v1/base.py
Martin Mágr 5007047162 Deprecate disable-rbac option
This patch makes --disable-rbac flag NOOP.

Depends-On: I598fd222f7e41e80ad9fc7f0008c965190255b05
Change-Id: I01f0096d4fcfd0ce4bea2e1ee0d16ad2fccc841f
2025-05-29 11:34:38 +02:00

92 lines
2.8 KiB
Python

# Copyright 2022 Red Hat, Inc.
#
# 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.
#
import argparse
import sys
from osc_lib.command import command
from observabilityclient.i18n import _
class DeprecatedNOOPAction(argparse.Action):
def __init__(self, *args, **kwargs):
kwargs['help'] = f"[DEPRECATED] {kwargs['help']}" \
if 'help' in kwargs else \
"[DEPRECATED]"
kwargs['required'] = False
kwargs['nargs'] = 0
super().__init__(*args, **kwargs)
def __call__(self, parser, namespace, values, option_string=None):
if option_string is not None:
print(f"Note: {option_string} is deprecated option, "
"has no effect and is a subject for removal "
"in future OpenStack release.", file=sys.stderr)
class ObservabilityBaseCommand(command.Command):
"""Base class for metric commands."""
def get_parser(self, prog_name):
parser = super().get_parser(prog_name)
parser.add_argument(
'--disable-rbac',
action=DeprecatedNOOPAction,
default=True,
help=_("Disable rbac injection")
)
return parser
class Manager(object):
"""Base class for the python api."""
DEFAULT_HEADERS = {
"Accept": "application/json",
}
def __init__(self, client):
self.client = client
self.prom = client.prometheus_client
def _set_default_headers(self, kwargs):
headers = kwargs.get('headers', {})
for k, v in self.DEFAULT_HEADERS.items():
if k not in headers:
headers[k] = v
kwargs['headers'] = headers
return kwargs
def _get(self, *args, **kwargs):
self._set_default_headers(kwargs)
return self.client.api.get(*args, **kwargs)
def _post(self, *args, **kwargs):
self._set_default_headers(kwargs)
return self.client.api.post(*args, **kwargs)
def _put(self, *args, **kwargs):
self._set_default_headers(kwargs)
return self.client.api.put(*args, **kwargs)
def _patch(self, *args, **kwargs):
self._set_default_headers(kwargs)
return self.client.api.patch(*args, **kwargs)
def _delete(self, *args, **kwargs):
self._set_default_headers(kwargs)
return self.client.api.delete(*args, **kwargs)