2014-11-13 09:56:24 +01:00
|
|
|
# Copyright 2015 Hewlett-Packard Development Company, L.P.
|
|
|
|
#
|
|
|
|
# Author: Endre Karlson <endre.karlson@hp.com>
|
|
|
|
#
|
|
|
|
# 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.
|
2016-05-06 18:10:53 -03:00
|
|
|
from keystoneauth1 import adapter
|
2014-11-13 09:56:24 +01:00
|
|
|
|
|
|
|
from designateclient import exceptions
|
|
|
|
from designateclient.v2.blacklists import BlacklistController
|
|
|
|
from designateclient.v2.limits import LimitController
|
|
|
|
from designateclient.v2.nameservers import NameServerController
|
2016-06-14 17:09:45 -07:00
|
|
|
from designateclient.v2.pools import PoolController
|
2016-06-28 19:15:57 +01:00
|
|
|
from designateclient.v2.quotas import QuotasController
|
2014-11-13 09:56:24 +01:00
|
|
|
from designateclient.v2.recordsets import RecordSetController
|
|
|
|
from designateclient.v2.reverse import FloatingIPController
|
2016-02-24 13:11:08 +01:00
|
|
|
from designateclient.v2.service_statuses import ServiceStatusesController
|
2014-11-13 09:56:24 +01:00
|
|
|
from designateclient.v2.tlds import TLDController
|
2017-07-07 14:00:17 +02:00
|
|
|
from designateclient.v2.tsigkeys import TSIGKeysController
|
2014-11-13 09:56:24 +01:00
|
|
|
from designateclient.v2.zones import ZoneController
|
2016-03-22 17:08:18 -05:00
|
|
|
from designateclient.v2.zones import ZoneExportsController
|
|
|
|
from designateclient.v2.zones import ZoneImportsController
|
2020-04-26 20:25:50 +03:00
|
|
|
from designateclient.v2.zones import ZoneShareController
|
2014-11-13 09:56:24 +01:00
|
|
|
from designateclient.v2.zones import ZoneTransfersController
|
|
|
|
from designateclient import version
|
2021-02-02 07:37:43 +01:00
|
|
|
from oslo_utils import importutils
|
|
|
|
|
|
|
|
osprofiler_web = importutils.try_import("osprofiler.web")
|
2014-11-13 09:56:24 +01:00
|
|
|
|
|
|
|
|
|
|
|
class DesignateAdapter(adapter.LegacyJsonAdapter):
|
2017-04-19 10:19:46 +01:00
|
|
|
"""Adapter around LegacyJsonAdapter.
|
|
|
|
|
2015-07-02 15:59:39 +01:00
|
|
|
The user can pass a timeout keyword that will apply only to
|
|
|
|
the Designate Client, in order:
|
2017-04-19 10:19:46 +01:00
|
|
|
|
|
|
|
- timeout keyword passed to ``request()``
|
|
|
|
- timeout attribute on keystone session
|
2014-11-13 09:56:24 +01:00
|
|
|
"""
|
2015-07-02 15:59:39 +01:00
|
|
|
def __init__(self, *args, **kwargs):
|
|
|
|
self.timeout = kwargs.pop('timeout', None)
|
2016-06-28 13:18:51 +01:00
|
|
|
self.all_projects = kwargs.pop('all_projects', False)
|
|
|
|
self.edit_managed = kwargs.pop('edit_managed', False)
|
2022-03-26 01:43:28 +05:30
|
|
|
self.hard_delete = kwargs.pop('hard_delete', False)
|
2016-06-28 13:18:51 +01:00
|
|
|
self.sudo_project_id = kwargs.pop('sudo_project_id', None)
|
2015-07-02 15:59:39 +01:00
|
|
|
super(self.__class__, self).__init__(*args, **kwargs)
|
|
|
|
|
2014-11-13 09:56:24 +01:00
|
|
|
def request(self, *args, **kwargs):
|
|
|
|
kwargs.setdefault('raise_exc', False)
|
|
|
|
|
2015-07-02 15:59:39 +01:00
|
|
|
if self.timeout is not None:
|
|
|
|
kwargs.setdefault('timeout', self.timeout)
|
|
|
|
|
2016-06-28 13:18:51 +01:00
|
|
|
kwargs.setdefault('headers', {})
|
|
|
|
|
|
|
|
if self.all_projects:
|
|
|
|
kwargs['headers'].setdefault(
|
|
|
|
'X-Auth-All-Projects',
|
2016-10-26 22:03:05 +02:00
|
|
|
str(self.all_projects)
|
2016-06-28 13:18:51 +01:00
|
|
|
)
|
|
|
|
|
|
|
|
if self.edit_managed:
|
|
|
|
kwargs['headers'].setdefault(
|
|
|
|
'X-Designate-Edit-Managed-Records',
|
2016-12-09 20:15:16 +01:00
|
|
|
str(self.edit_managed)
|
2016-06-28 13:18:51 +01:00
|
|
|
)
|
|
|
|
|
2022-03-26 01:43:28 +05:30
|
|
|
if self.hard_delete:
|
|
|
|
kwargs['headers'].setdefault(
|
|
|
|
'X-Designate-Hard-Delete',
|
|
|
|
str(self.hard_delete)
|
|
|
|
)
|
|
|
|
|
2016-06-28 13:18:51 +01:00
|
|
|
if self.sudo_project_id is not None:
|
|
|
|
kwargs['headers'].setdefault(
|
|
|
|
'X-Auth-Sudo-Project-ID',
|
|
|
|
self.sudo_project_id
|
|
|
|
)
|
|
|
|
|
|
|
|
kwargs['headers'].setdefault(
|
2014-11-13 09:56:24 +01:00
|
|
|
'Content-Type', 'application/json')
|
2015-07-02 15:59:39 +01:00
|
|
|
|
2021-02-02 07:37:43 +01:00
|
|
|
if osprofiler_web:
|
|
|
|
kwargs['headers'].update(osprofiler_web.get_trace_id_headers())
|
|
|
|
|
2015-07-02 15:59:39 +01:00
|
|
|
response, body = super(self.__class__, self).request(*args, **kwargs)
|
2014-11-13 09:56:24 +01:00
|
|
|
|
|
|
|
# Decode is response, if possible
|
|
|
|
try:
|
|
|
|
response_payload = response.json()
|
|
|
|
except ValueError:
|
|
|
|
response_payload = {}
|
2016-03-22 17:08:18 -05:00
|
|
|
body = response.text
|
2014-11-13 09:56:24 +01:00
|
|
|
|
|
|
|
if response.status_code == 400:
|
|
|
|
raise exceptions.BadRequest(**response_payload)
|
|
|
|
elif response.status_code in (401, 403):
|
|
|
|
raise exceptions.Forbidden(**response_payload)
|
|
|
|
elif response.status_code == 404:
|
|
|
|
raise exceptions.NotFound(**response_payload)
|
|
|
|
elif response.status_code == 409:
|
|
|
|
raise exceptions.Conflict(**response_payload)
|
2017-01-31 19:00:20 +00:00
|
|
|
elif response.status_code == 413:
|
|
|
|
raise exceptions.OverQuota(**response_payload)
|
2014-11-13 09:56:24 +01:00
|
|
|
elif response.status_code >= 500:
|
|
|
|
raise exceptions.Unknown(**response_payload)
|
|
|
|
return response, body
|
|
|
|
|
|
|
|
|
|
|
|
class Client(object):
|
|
|
|
def __init__(self, region_name=None, endpoint_type='publicURL',
|
|
|
|
extensions=None, service_type='dns', service_name=None,
|
2015-07-02 15:59:39 +01:00
|
|
|
http_log_debug=False, session=None, auth=None, timeout=None,
|
2016-06-28 13:18:51 +01:00
|
|
|
endpoint_override=None, all_projects=False,
|
2022-03-26 01:43:28 +05:30
|
|
|
edit_managed=False, hard_delete=False, sudo_project_id=None):
|
2015-07-02 15:59:39 +01:00
|
|
|
if session is None:
|
|
|
|
raise ValueError("A session instance is required")
|
|
|
|
|
2014-11-13 09:56:24 +01:00
|
|
|
self.session = DesignateAdapter(
|
|
|
|
session,
|
|
|
|
auth=auth,
|
|
|
|
region_name=region_name,
|
|
|
|
service_type=service_type,
|
|
|
|
interface=endpoint_type.rstrip('URL'),
|
|
|
|
user_agent='python-designateclient-%s' % version.version_info,
|
2015-07-02 15:59:39 +01:00
|
|
|
version=('2'),
|
|
|
|
endpoint_override=endpoint_override,
|
2016-06-28 13:18:51 +01:00
|
|
|
timeout=timeout,
|
|
|
|
all_projects=all_projects,
|
|
|
|
edit_managed=edit_managed,
|
2022-03-26 01:43:28 +05:30
|
|
|
hard_delete=hard_delete,
|
2016-06-28 13:18:51 +01:00
|
|
|
sudo_project_id=sudo_project_id
|
2015-07-02 15:59:39 +01:00
|
|
|
)
|
2014-11-13 09:56:24 +01:00
|
|
|
|
|
|
|
self.blacklists = BlacklistController(self)
|
|
|
|
self.floatingips = FloatingIPController(self)
|
|
|
|
self.limits = LimitController(self)
|
|
|
|
self.nameservers = NameServerController(self)
|
|
|
|
self.recordsets = RecordSetController(self)
|
2016-02-24 13:11:08 +01:00
|
|
|
self.service_statuses = ServiceStatusesController(self)
|
2014-11-13 09:56:24 +01:00
|
|
|
self.tlds = TLDController(self)
|
|
|
|
self.zones = ZoneController(self)
|
|
|
|
self.zone_transfers = ZoneTransfersController(self)
|
2016-03-22 17:08:18 -05:00
|
|
|
self.zone_exports = ZoneExportsController(self)
|
|
|
|
self.zone_imports = ZoneImportsController(self)
|
2020-04-26 20:25:50 +03:00
|
|
|
self.zone_share = ZoneShareController(self)
|
2016-06-14 17:09:45 -07:00
|
|
|
self.pools = PoolController(self)
|
2016-06-28 19:15:57 +01:00
|
|
|
self.quotas = QuotasController(self)
|
2017-07-07 14:00:17 +02:00
|
|
|
self.tsigkeys = TSIGKeysController(self)
|