| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990 |
- # Copyright 2014 Baidu, 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.
- """
- This module provide base class for BCE service clients.
- """
- from __future__ import absolute_import
- import copy
- from builtins import str, bytes
- import baidubce
- from baidubce import bce_client_configuration
- from baidubce.exception import BceClientError
- from baidubce.auth import bce_v1_signer
- from baidubce.http import handler
- from baidubce.http import bce_http_client
- class BceBaseClient(object):
- """
- TODO: add docstring
- """
- def __init__(self, config, region_supported=True):
- """
- :param config: the client configuration. The constructor makes a copy of this parameter so
- that it is safe to change the configuration after then.
- :type config: BceClientConfiguration
- :param region_supported: true if this client supports region.
- :type region_supported: bool
- """
- self.service_id = self._compute_service_id()
- self.region_supported = region_supported
- # just for debug
- self.config = copy.deepcopy(bce_client_configuration.DEFAULT_CONFIG)
- if config is not None:
- self.config.merge_non_none_values(config)
- if self.config.endpoint is None:
- self.config.endpoint = self._compute_endpoint()
- def _compute_service_id(self):
- return self.__module__.split('.')[2]
- def _compute_endpoint(self):
- if self.config.endpoint:
- return self.config.endpoint
- if self.region_supported:
- return b'%s://%s.%s.%s' % (
- self.config.protocol,
- self.service_id,
- self.config.region,
- baidubce.DEFAULT_SERVICE_DOMAIN)
- else:
- return b'%s://%s.%s' % (
- self.config.protocol,
- self.service_id,
- baidubce.DEFAULT_SERVICE_DOMAIN)
- def _send_request(self, http_method, path, headers=None, params=None, body=None):
- return bce_http_client.send_request(
- self.config, bce_v1_signer.sign, [handler.parse_error, handler.parse_json],
- http_method, path, body, headers, params)
- def _get_config(self, apiDict, apiName):
- return copy.deepcopy(apiDict[apiName])
- def _add_header(self, apiConfig, key, value):
- self._set_if_nonnull(apiConfig["headers"], key, value)
- def _add_query(self, apiConfig, key, value):
- # key-only query parameter's value is "" and can satisfy non-null
- self._set_if_nonnull(apiConfig["queries"], key, value)
- def _add_path_param(self, apiConfig, key, value):
- if value is None:
- raise BceClientError(b"Path param can't be none.")
- apiConfig["path"] = apiConfig["path"].replace("[" + key + "]", value)
- def _set_if_nonnull(self, params, param_name=None, value=None):
- if value is not None:
- params[param_name] = value
|