2021-12-10 10:12:27 +00:00
|
|
|
# coding: utf-8
|
|
|
|
|
|
|
|
from __future__ import absolute_import
|
|
|
|
|
|
|
|
import importlib
|
2023-11-16 09:47:10 +00:00
|
|
|
import warnings
|
2021-12-10 10:12:27 +00:00
|
|
|
|
|
|
|
from huaweicloudsdkcore.client import Client, ClientBuilder
|
|
|
|
from huaweicloudsdkcore.utils import http_utils
|
|
|
|
from huaweicloudsdkcore.sdk_stream_request import SdkStreamRequest
|
2023-11-16 09:47:10 +00:00
|
|
|
try:
|
|
|
|
from huaweicloudsdkcore.invoker.invoker import AsyncInvoker
|
|
|
|
except ImportError as e:
|
|
|
|
warnings.warn(str(e) + ", please check if you are using the same versions of 'huaweicloudsdkcore' and 'huaweicloudsdkhilens'")
|
2021-12-10 10:12:27 +00:00
|
|
|
|
|
|
|
|
|
|
|
class HiLensAsyncClient(Client):
|
|
|
|
def __init__(self):
|
|
|
|
super(HiLensAsyncClient, self).__init__()
|
|
|
|
self.model_package = importlib.import_module("huaweicloudsdkhilens.v1.model")
|
|
|
|
|
|
|
|
@classmethod
|
|
|
|
def new_builder(cls, clazz=None):
|
2023-10-19 08:19:16 +00:00
|
|
|
if not clazz:
|
|
|
|
client_builder = ClientBuilder(cls)
|
|
|
|
else:
|
|
|
|
if clazz.__name__ != "HiLensAsyncClient":
|
|
|
|
raise TypeError("client type error, support client type is HiLensAsyncClient")
|
|
|
|
client_builder = ClientBuilder(clazz)
|
2021-12-10 10:12:27 +00:00
|
|
|
|
2023-10-19 08:19:16 +00:00
|
|
|
|
2021-12-10 10:12:27 +00:00
|
|
|
|
2023-10-19 08:19:16 +00:00
|
|
|
return client_builder
|
2021-12-10 10:12:27 +00:00
|
|
|
|
|
|
|
def list_device_alarms_async(self, request):
|
|
|
|
"""获取设备告警列表
|
|
|
|
|
|
|
|
获取设备告警列表
|
2022-04-21 12:03:46 +00:00
|
|
|
|
2022-11-30 08:59:35 +00:00
|
|
|
Please refer to HUAWEI cloud API Explorer for details.
|
2021-12-10 10:12:27 +00:00
|
|
|
|
2022-11-17 12:13:53 +00:00
|
|
|
|
2022-04-21 12:03:46 +00:00
|
|
|
:param request: Request instance for ListDeviceAlarms
|
|
|
|
:type request: :class:`huaweicloudsdkhilens.v1.ListDeviceAlarmsRequest`
|
|
|
|
:rtype: :class:`huaweicloudsdkhilens.v1.ListDeviceAlarmsResponse`
|
2021-12-10 10:12:27 +00:00
|
|
|
"""
|
2023-11-16 09:47:10 +00:00
|
|
|
http_info = self._list_device_alarms_http_info(request)
|
|
|
|
return self._call_api(**http_info)
|
|
|
|
|
|
|
|
def list_device_alarms_async_invoker(self, request):
|
|
|
|
http_info = self._list_device_alarms_http_info(request)
|
|
|
|
return AsyncInvoker(self, http_info)
|
|
|
|
|
|
|
|
def _list_device_alarms_http_info(self, request):
|
|
|
|
http_info = {
|
|
|
|
"method": "GET",
|
|
|
|
"resource_path": "/v1/{project_id}/alarm-manager/alarms",
|
|
|
|
"request_type": request.__class__.__name__,
|
|
|
|
"response_type": "ListDeviceAlarmsResponse"
|
|
|
|
}
|
2021-12-10 10:12:27 +00:00
|
|
|
|
2023-05-11 09:07:48 +00:00
|
|
|
local_var_params = {attr: getattr(request, attr) for attr in request.attribute_map if hasattr(request, attr)}
|
2021-12-10 10:12:27 +00:00
|
|
|
|
2022-11-17 12:13:53 +00:00
|
|
|
cname = None
|
|
|
|
|
2021-12-10 10:12:27 +00:00
|
|
|
collection_formats = {}
|
|
|
|
|
|
|
|
path_params = {}
|
|
|
|
|
|
|
|
query_params = []
|
|
|
|
if 'offset' in local_var_params:
|
|
|
|
query_params.append(('offset', local_var_params['offset']))
|
|
|
|
if 'limit' in local_var_params:
|
|
|
|
query_params.append(('limit', local_var_params['limit']))
|
|
|
|
if 'device_id' in local_var_params:
|
|
|
|
query_params.append(('device_id', local_var_params['device_id']))
|
|
|
|
|
|
|
|
header_params = {}
|
|
|
|
|
|
|
|
form_params = {}
|
|
|
|
|
2023-11-16 09:47:10 +00:00
|
|
|
body = None
|
2021-12-10 10:12:27 +00:00
|
|
|
if isinstance(request, SdkStreamRequest):
|
2023-11-16 09:47:10 +00:00
|
|
|
body = request.get_file_stream()
|
2021-12-10 10:12:27 +00:00
|
|
|
|
|
|
|
response_headers = []
|
|
|
|
|
|
|
|
header_params['Content-Type'] = http_utils.select_header_content_type(
|
|
|
|
['application/json'])
|
|
|
|
|
|
|
|
auth_settings = []
|
|
|
|
|
2023-11-16 09:47:10 +00:00
|
|
|
http_info["cname"] = cname
|
|
|
|
http_info["collection_formats"] = collection_formats
|
|
|
|
http_info["path_params"] = path_params
|
|
|
|
http_info["query_params"] = query_params
|
|
|
|
http_info["header_params"] = header_params
|
|
|
|
http_info["post_params"] = form_params
|
|
|
|
http_info["body"] = body
|
|
|
|
http_info["response_headers"] = response_headers
|
|
|
|
|
|
|
|
return http_info
|
2021-12-10 10:12:27 +00:00
|
|
|
|
|
|
|
def list_devices_async(self, request):
|
2022-10-27 10:20:54 +00:00
|
|
|
"""获取基础版设备列表
|
2021-12-10 10:12:27 +00:00
|
|
|
|
2022-10-27 10:20:54 +00:00
|
|
|
获取基础版设备列表
|
2022-04-21 12:03:46 +00:00
|
|
|
|
2022-11-30 08:59:35 +00:00
|
|
|
Please refer to HUAWEI cloud API Explorer for details.
|
2021-12-10 10:12:27 +00:00
|
|
|
|
2022-11-17 12:13:53 +00:00
|
|
|
|
2022-04-21 12:03:46 +00:00
|
|
|
:param request: Request instance for ListDevices
|
|
|
|
:type request: :class:`huaweicloudsdkhilens.v1.ListDevicesRequest`
|
|
|
|
:rtype: :class:`huaweicloudsdkhilens.v1.ListDevicesResponse`
|
2021-12-10 10:12:27 +00:00
|
|
|
"""
|
2023-11-16 09:47:10 +00:00
|
|
|
http_info = self._list_devices_http_info(request)
|
|
|
|
return self._call_api(**http_info)
|
|
|
|
|
|
|
|
def list_devices_async_invoker(self, request):
|
|
|
|
http_info = self._list_devices_http_info(request)
|
|
|
|
return AsyncInvoker(self, http_info)
|
|
|
|
|
|
|
|
def _list_devices_http_info(self, request):
|
|
|
|
http_info = {
|
|
|
|
"method": "GET",
|
|
|
|
"resource_path": "/v2/{project_id}/device-manager/devices",
|
|
|
|
"request_type": request.__class__.__name__,
|
|
|
|
"response_type": "ListDevicesResponse"
|
|
|
|
}
|
2023-05-11 09:07:48 +00:00
|
|
|
|
|
|
|
local_var_params = {attr: getattr(request, attr) for attr in request.attribute_map if hasattr(request, attr)}
|
2021-12-10 10:12:27 +00:00
|
|
|
|
2022-11-17 12:13:53 +00:00
|
|
|
cname = None
|
|
|
|
|
2021-12-10 10:12:27 +00:00
|
|
|
collection_formats = {}
|
|
|
|
|
|
|
|
path_params = {}
|
|
|
|
|
|
|
|
query_params = []
|
|
|
|
if 'offset' in local_var_params:
|
|
|
|
query_params.append(('offset', local_var_params['offset']))
|
|
|
|
if 'limit' in local_var_params:
|
|
|
|
query_params.append(('limit', local_var_params['limit']))
|
|
|
|
if 'name' in local_var_params:
|
|
|
|
query_params.append(('name', local_var_params['name']))
|
|
|
|
|
|
|
|
header_params = {}
|
|
|
|
|
|
|
|
form_params = {}
|
|
|
|
|
2023-11-16 09:47:10 +00:00
|
|
|
body = None
|
2021-12-10 10:12:27 +00:00
|
|
|
if isinstance(request, SdkStreamRequest):
|
2023-11-16 09:47:10 +00:00
|
|
|
body = request.get_file_stream()
|
2021-12-10 10:12:27 +00:00
|
|
|
|
|
|
|
response_headers = []
|
|
|
|
|
|
|
|
header_params['Content-Type'] = http_utils.select_header_content_type(
|
|
|
|
['application/json'])
|
|
|
|
|
|
|
|
auth_settings = []
|
|
|
|
|
2023-11-16 09:47:10 +00:00
|
|
|
http_info["cname"] = cname
|
|
|
|
http_info["collection_formats"] = collection_formats
|
|
|
|
http_info["path_params"] = path_params
|
|
|
|
http_info["query_params"] = query_params
|
|
|
|
http_info["header_params"] = header_params
|
|
|
|
http_info["post_params"] = form_params
|
|
|
|
http_info["body"] = body
|
|
|
|
http_info["response_headers"] = response_headers
|
|
|
|
|
|
|
|
return http_info
|
|
|
|
|
|
|
|
def _call_api(self, **kwargs):
|
|
|
|
try:
|
|
|
|
kwargs["async_request"] = True
|
|
|
|
return self.do_http_request(**kwargs)
|
|
|
|
except TypeError:
|
|
|
|
import inspect
|
|
|
|
params = inspect.signature(self.do_http_request).parameters
|
|
|
|
http_info = {param_name: kwargs.get(param_name) for param_name in params if param_name in kwargs}
|
|
|
|
return self.do_http_request(**http_info)
|
2021-12-10 10:12:27 +00:00
|
|
|
|
|
|
|
def call_api(self, resource_path, method, path_params=None, query_params=None, header_params=None, body=None,
|
2022-11-17 12:13:53 +00:00
|
|
|
post_params=None, cname=None, response_type=None, response_headers=None, auth_settings=None,
|
2021-12-10 10:12:27 +00:00
|
|
|
collection_formats=None, request_type=None):
|
|
|
|
"""Makes the HTTP request and returns deserialized data.
|
|
|
|
|
|
|
|
:param resource_path: Path to method endpoint.
|
|
|
|
:param method: Method to call.
|
|
|
|
:param path_params: Path parameters in the url.
|
|
|
|
:param query_params: Query parameters in the url.
|
|
|
|
:param header_params: Header parameters to be
|
|
|
|
placed in the request header.
|
|
|
|
:param body: Request body.
|
2022-11-17 12:13:53 +00:00
|
|
|
:param post_params: Request post form parameters,
|
2021-12-10 10:12:27 +00:00
|
|
|
for `application/x-www-form-urlencoded`, `multipart/form-data`.
|
2022-11-17 12:13:53 +00:00
|
|
|
:param cname: Used for obs endpoint.
|
|
|
|
:param auth_settings: Auth Settings names for the request.
|
2021-12-10 10:12:27 +00:00
|
|
|
:param response_type: Response data type.
|
|
|
|
:param response_headers: Header should be added to response data.
|
|
|
|
:param collection_formats: dict of collection formats for path, query,
|
|
|
|
header, and post parameters.
|
|
|
|
:param request_type: Request data type.
|
|
|
|
:return:
|
|
|
|
Return the response directly.
|
|
|
|
"""
|
|
|
|
return self.do_http_request(
|
|
|
|
method=method,
|
|
|
|
resource_path=resource_path,
|
|
|
|
path_params=path_params,
|
|
|
|
query_params=query_params,
|
|
|
|
header_params=header_params,
|
|
|
|
body=body,
|
|
|
|
post_params=post_params,
|
2022-11-17 12:13:53 +00:00
|
|
|
cname=cname,
|
2021-12-10 10:12:27 +00:00
|
|
|
response_type=response_type,
|
|
|
|
response_headers=response_headers,
|
|
|
|
collection_formats=collection_formats,
|
|
|
|
request_type=request_type,
|
2023-11-16 09:47:10 +00:00
|
|
|
async_request=True)
|