diff --git a/.gitignore b/.gitignore index 2ab5b9dc..2f81771c 100644 --- a/.gitignore +++ b/.gitignore @@ -112,3 +112,7 @@ venv.bak/ # Debug *.stackdump examples/debug +bdd/ +.version + +scripts/gen-apis.sh diff --git a/.travis.yml b/.travis.yml index 8bd1a95d..6f13dd71 100644 --- a/.travis.yml +++ b/.travis.yml @@ -15,6 +15,7 @@ install: pip install -e .[ci] script: - make lint - make test-cov + - make release-check after_success: - bash <(curl -s https://codecov.io/bash) diff --git a/Makefile b/Makefile index bd8d15b5..85b2d163 100644 --- a/Makefile +++ b/Makefile @@ -78,13 +78,14 @@ clean-test: rm -f .coverage rm -fr htmlcov/ -gen: - ucloud-model sdk apis \ - --lang python3 \ - --type=public \ - --template ${UCLOUD_TEMPLATE_PATH}/scripts-api.tpl \ - --output ./scripts/gen-services.sh - ucloud-model sdk tests \ - --lang python3 \ - --template ${UCLOUD_TEMPLATE_PATH}/scripts-test.tpl \ - --output ./scripts/gen-tests.sh +version: + @python -c 'from ucloud.version import version; print(version)' + +codegen: + @bash ./scripts/codegen.sh + +release-check: + @python scripts/release.py --dry-run + +release: + @python scripts/release.py diff --git a/docs/conf.py b/docs/conf.py index dbead573..848c6f1d 100644 --- a/docs/conf.py +++ b/docs/conf.py @@ -17,9 +17,9 @@ # -- Project information ----------------------------------------------------- -project = 'ucloud-sdk-python3' -copyright = '2019, ucloud' -author = 'ucloud' +project = "ucloud-sdk-python3" +copyright = "2019, ucloud" +author = "ucloud" # -- General configuration --------------------------------------------------- @@ -28,14 +28,14 @@ # extensions coming with Sphinx (named 'sphinx.ext.*') or your custom # ones. extensions = [ - 'sphinx.ext.autodoc', - 'sphinx.ext.doctest', - 'sphinx.ext.todo', - 'sphinx.ext.viewcode', + "sphinx.ext.autodoc", + "sphinx.ext.doctest", + "sphinx.ext.todo", + "sphinx.ext.viewcode", ] # Add any paths that contain templates here, relative to this directory. -templates_path = ['_templates'] +templates_path = ["_templates"] # List of patterns, relative to source directory, that match files and # directories to ignore when looking for source files. @@ -48,9 +48,9 @@ # The theme to use for HTML and HTML Help pages. See the documentation for # a list of builtin themes. # -html_theme = 'alabaster' +html_theme = "alabaster" # Add any paths that contain custom static files (such as style sheets) here, # relative to this directory. They are copied after the builtin static files, # so a file named "default.css" will overwrite the builtin "default.css". -html_static_path = ['_static'] +html_static_path = ["_static"] diff --git a/docs/services.rst b/docs/services.rst index 7bdabca8..59d8fb53 100644 --- a/docs/services.rst +++ b/docs/services.rst @@ -1,12 +1,6 @@ UCloud SDK Services =================== -PathX ------ - -.. autoclass:: ucloud.services.pathx.client.PathXClient - :members: - StepFlow -------- @@ -19,6 +13,12 @@ UAccount .. autoclass:: ucloud.services.uaccount.client.UAccountClient :members: +UCDN +---- + +.. autoclass:: ucloud.services.ucdn.client.UCDNClient + :members: + UDB --- @@ -67,9 +67,9 @@ UPHost .. autoclass:: ucloud.services.uphost.client.UPHostClient :members: -VPC ---- +USMS +---- -.. autoclass:: ucloud.services.vpc.client.VPCClient +.. autoclass:: ucloud.services.usms.client.USMSClient :members: diff --git a/scripts/codegen.sh b/scripts/codegen.sh new file mode 100644 index 00000000..5f5a0cfa --- /dev/null +++ b/scripts/codegen.sh @@ -0,0 +1,17 @@ +#!/usr/bin/env bash + +#set -u +set -e + +if [ -n "$PRODUCT" ]; then + ucloud-model sync --lang python --product "$PRODUCT" + ucloud-model sdk apis --type public --product "$PRODUCT" --lang python --template "$U_MODEL_HOME"/providers/python/templates/scripts-api.tpl --output scripts/gen-apis.sh + bash ./scripts/gen-apis.sh +fi + +if [ -n "$TEST" ]; then + IFS=',' read -ra TL <<< "$TEST" + for i in "${TL[@]}"; do + ucloud-model sdk test --name "$i" --lang python --template "$U_MODEL_HOME"/providers/python/templates/testing.tpl --output tests/test_services/test_set_"$i".py + done +fi diff --git a/scripts/gen-services.sh b/scripts/gen-services.sh deleted file mode 100644 index 3e7c4381..00000000 --- a/scripts/gen-services.sh +++ /dev/null @@ -1,116 +0,0 @@ -#!/usr/bin/env bash - -# Code is generated by ucloud-model, DO NOT EDIT IT. - -ucloud-model sdk apis --lang python3 --type public --template ../ucloud-api-model-v2/apisdk/lang/python/templates/clients.tpl --output ./ucloud/client.py -ucloud-model sdk apis --lang python3 --type public --template ../ucloud-api-model-v2/apisdk/lang/python/templates/docs.tpl --output ./docs/services.rst - - -mkdir -p ./ucloud/services/pathx/schemas -touch ./ucloud/services/pathx/__init__.py -touch ./ucloud/services/pathx/schemas/__init__.py -ucloud-model sdk apis --lang python3 --product PathX --type public --template ../ucloud-api-model-v2/apisdk/lang/python/templates/schema.tpl --output ./ucloud/services/pathx/schemas/apis.py -ucloud-model sdk apis --lang python3 --product PathX --type public --template ../ucloud-api-model-v2/apisdk/lang/python/templates/model.tpl --output ./ucloud/services/pathx/schemas/models.py -ucloud-model sdk apis --lang python3 --product PathX --type public --template ../ucloud-api-model-v2/apisdk/lang/python/templates/client.tpl --output ./ucloud/services/pathx/client.py -black ucloud/services/pathx -python -m ucloud.services.pathx.client - -mkdir -p ./ucloud/services/stepflow/schemas -touch ./ucloud/services/stepflow/__init__.py -touch ./ucloud/services/stepflow/schemas/__init__.py -ucloud-model sdk apis --lang python3 --product StepFlow --type public --template ../ucloud-api-model-v2/apisdk/lang/python/templates/schema.tpl --output ./ucloud/services/stepflow/schemas/apis.py -ucloud-model sdk apis --lang python3 --product StepFlow --type public --template ../ucloud-api-model-v2/apisdk/lang/python/templates/model.tpl --output ./ucloud/services/stepflow/schemas/models.py -ucloud-model sdk apis --lang python3 --product StepFlow --type public --template ../ucloud-api-model-v2/apisdk/lang/python/templates/client.tpl --output ./ucloud/services/stepflow/client.py -black ucloud/services/stepflow -python -m ucloud.services.stepflow.client - -mkdir -p ./ucloud/services/uaccount/schemas -touch ./ucloud/services/uaccount/__init__.py -touch ./ucloud/services/uaccount/schemas/__init__.py -ucloud-model sdk apis --lang python3 --product UAccount --type public --template ../ucloud-api-model-v2/apisdk/lang/python/templates/schema.tpl --output ./ucloud/services/uaccount/schemas/apis.py -ucloud-model sdk apis --lang python3 --product UAccount --type public --template ../ucloud-api-model-v2/apisdk/lang/python/templates/model.tpl --output ./ucloud/services/uaccount/schemas/models.py -ucloud-model sdk apis --lang python3 --product UAccount --type public --template ../ucloud-api-model-v2/apisdk/lang/python/templates/client.tpl --output ./ucloud/services/uaccount/client.py -black ucloud/services/uaccount -python -m ucloud.services.uaccount.client - -mkdir -p ./ucloud/services/udb/schemas -touch ./ucloud/services/udb/__init__.py -touch ./ucloud/services/udb/schemas/__init__.py -ucloud-model sdk apis --lang python3 --product UDB --type public --template ../ucloud-api-model-v2/apisdk/lang/python/templates/schema.tpl --output ./ucloud/services/udb/schemas/apis.py -ucloud-model sdk apis --lang python3 --product UDB --type public --template ../ucloud-api-model-v2/apisdk/lang/python/templates/model.tpl --output ./ucloud/services/udb/schemas/models.py -ucloud-model sdk apis --lang python3 --product UDB --type public --template ../ucloud-api-model-v2/apisdk/lang/python/templates/client.tpl --output ./ucloud/services/udb/client.py -black ucloud/services/udb -python -m ucloud.services.udb.client - -mkdir -p ./ucloud/services/udpn/schemas -touch ./ucloud/services/udpn/__init__.py -touch ./ucloud/services/udpn/schemas/__init__.py -ucloud-model sdk apis --lang python3 --product UDPN --type public --template ../ucloud-api-model-v2/apisdk/lang/python/templates/schema.tpl --output ./ucloud/services/udpn/schemas/apis.py -ucloud-model sdk apis --lang python3 --product UDPN --type public --template ../ucloud-api-model-v2/apisdk/lang/python/templates/model.tpl --output ./ucloud/services/udpn/schemas/models.py -ucloud-model sdk apis --lang python3 --product UDPN --type public --template ../ucloud-api-model-v2/apisdk/lang/python/templates/client.tpl --output ./ucloud/services/udpn/client.py -black ucloud/services/udpn -python -m ucloud.services.udpn.client - -mkdir -p ./ucloud/services/udisk/schemas -touch ./ucloud/services/udisk/__init__.py -touch ./ucloud/services/udisk/schemas/__init__.py -ucloud-model sdk apis --lang python3 --product UDisk --type public --template ../ucloud-api-model-v2/apisdk/lang/python/templates/schema.tpl --output ./ucloud/services/udisk/schemas/apis.py -ucloud-model sdk apis --lang python3 --product UDisk --type public --template ../ucloud-api-model-v2/apisdk/lang/python/templates/model.tpl --output ./ucloud/services/udisk/schemas/models.py -ucloud-model sdk apis --lang python3 --product UDisk --type public --template ../ucloud-api-model-v2/apisdk/lang/python/templates/client.tpl --output ./ucloud/services/udisk/client.py -black ucloud/services/udisk -python -m ucloud.services.udisk.client - -mkdir -p ./ucloud/services/uhost/schemas -touch ./ucloud/services/uhost/__init__.py -touch ./ucloud/services/uhost/schemas/__init__.py -ucloud-model sdk apis --lang python3 --product UHost --type public --template ../ucloud-api-model-v2/apisdk/lang/python/templates/schema.tpl --output ./ucloud/services/uhost/schemas/apis.py -ucloud-model sdk apis --lang python3 --product UHost --type public --template ../ucloud-api-model-v2/apisdk/lang/python/templates/model.tpl --output ./ucloud/services/uhost/schemas/models.py -ucloud-model sdk apis --lang python3 --product UHost --type public --template ../ucloud-api-model-v2/apisdk/lang/python/templates/client.tpl --output ./ucloud/services/uhost/client.py -black ucloud/services/uhost -python -m ucloud.services.uhost.client - -mkdir -p ./ucloud/services/ulb/schemas -touch ./ucloud/services/ulb/__init__.py -touch ./ucloud/services/ulb/schemas/__init__.py -ucloud-model sdk apis --lang python3 --product ULB --type public --template ../ucloud-api-model-v2/apisdk/lang/python/templates/schema.tpl --output ./ucloud/services/ulb/schemas/apis.py -ucloud-model sdk apis --lang python3 --product ULB --type public --template ../ucloud-api-model-v2/apisdk/lang/python/templates/model.tpl --output ./ucloud/services/ulb/schemas/models.py -ucloud-model sdk apis --lang python3 --product ULB --type public --template ../ucloud-api-model-v2/apisdk/lang/python/templates/client.tpl --output ./ucloud/services/ulb/client.py -black ucloud/services/ulb -python -m ucloud.services.ulb.client - -mkdir -p ./ucloud/services/umem/schemas -touch ./ucloud/services/umem/__init__.py -touch ./ucloud/services/umem/schemas/__init__.py -ucloud-model sdk apis --lang python3 --product UMem --type public --template ../ucloud-api-model-v2/apisdk/lang/python/templates/schema.tpl --output ./ucloud/services/umem/schemas/apis.py -ucloud-model sdk apis --lang python3 --product UMem --type public --template ../ucloud-api-model-v2/apisdk/lang/python/templates/model.tpl --output ./ucloud/services/umem/schemas/models.py -ucloud-model sdk apis --lang python3 --product UMem --type public --template ../ucloud-api-model-v2/apisdk/lang/python/templates/client.tpl --output ./ucloud/services/umem/client.py -black ucloud/services/umem -python -m ucloud.services.umem.client - -mkdir -p ./ucloud/services/unet/schemas -touch ./ucloud/services/unet/__init__.py -touch ./ucloud/services/unet/schemas/__init__.py -ucloud-model sdk apis --lang python3 --product UNet --type public --template ../ucloud-api-model-v2/apisdk/lang/python/templates/schema.tpl --output ./ucloud/services/unet/schemas/apis.py -ucloud-model sdk apis --lang python3 --product UNet --type public --template ../ucloud-api-model-v2/apisdk/lang/python/templates/model.tpl --output ./ucloud/services/unet/schemas/models.py -ucloud-model sdk apis --lang python3 --product UNet --type public --template ../ucloud-api-model-v2/apisdk/lang/python/templates/client.tpl --output ./ucloud/services/unet/client.py -black ucloud/services/unet -python -m ucloud.services.unet.client - -mkdir -p ./ucloud/services/uphost/schemas -touch ./ucloud/services/uphost/__init__.py -touch ./ucloud/services/uphost/schemas/__init__.py -ucloud-model sdk apis --lang python3 --product UPHost --type public --template ../ucloud-api-model-v2/apisdk/lang/python/templates/schema.tpl --output ./ucloud/services/uphost/schemas/apis.py -ucloud-model sdk apis --lang python3 --product UPHost --type public --template ../ucloud-api-model-v2/apisdk/lang/python/templates/model.tpl --output ./ucloud/services/uphost/schemas/models.py -ucloud-model sdk apis --lang python3 --product UPHost --type public --template ../ucloud-api-model-v2/apisdk/lang/python/templates/client.tpl --output ./ucloud/services/uphost/client.py -black ucloud/services/uphost -python -m ucloud.services.uphost.client - -mkdir -p ./ucloud/services/vpc/schemas -touch ./ucloud/services/vpc/__init__.py -touch ./ucloud/services/vpc/schemas/__init__.py -ucloud-model sdk apis --lang python3 --product VPC --type public --template ../ucloud-api-model-v2/apisdk/lang/python/templates/schema.tpl --output ./ucloud/services/vpc/schemas/apis.py -ucloud-model sdk apis --lang python3 --product VPC --type public --template ../ucloud-api-model-v2/apisdk/lang/python/templates/model.tpl --output ./ucloud/services/vpc/schemas/models.py -ucloud-model sdk apis --lang python3 --product VPC --type public --template ../ucloud-api-model-v2/apisdk/lang/python/templates/client.tpl --output ./ucloud/services/vpc/client.py -black ucloud/services/vpc -python -m ucloud.services.vpc.client - diff --git a/scripts/gen-tests.sh b/scripts/gen-tests.sh deleted file mode 100644 index 543bc542..00000000 --- a/scripts/gen-tests.sh +++ /dev/null @@ -1,247 +0,0 @@ -#!/usr/bin/env bash - -# Code is generated by ucloud-model, DO NOT EDIT IT. - - -ucloud-model sdk test \ - --lang python3 \ - --template ../ucloud-api-model-v2/apisdk/lang/python/templates/testing.tpl \ - --output tests/test_services/test_set_113.py \ - --name 113 - -ucloud-model sdk test \ - --lang python3 \ - --template ../ucloud-api-model-v2/apisdk/lang/python/templates/testing.tpl \ - --output tests/test_services/test_set_179.py \ - --name 179 - -ucloud-model sdk test \ - --lang python3 \ - --template ../ucloud-api-model-v2/apisdk/lang/python/templates/testing.tpl \ - --output tests/test_services/test_set_181.py \ - --name 181 - -ucloud-model sdk test \ - --lang python3 \ - --template ../ucloud-api-model-v2/apisdk/lang/python/templates/testing.tpl \ - --output tests/test_services/test_set_207.py \ - --name 207 - -ucloud-model sdk test \ - --lang python3 \ - --template ../ucloud-api-model-v2/apisdk/lang/python/templates/testing.tpl \ - --output tests/test_services/test_set_227.py \ - --name 227 - -ucloud-model sdk test \ - --lang python3 \ - --template ../ucloud-api-model-v2/apisdk/lang/python/templates/testing.tpl \ - --output tests/test_services/test_set_230.py \ - --name 230 - -ucloud-model sdk test \ - --lang python3 \ - --template ../ucloud-api-model-v2/apisdk/lang/python/templates/testing.tpl \ - --output tests/test_services/test_set_242.py \ - --name 242 - -ucloud-model sdk test \ - --lang python3 \ - --template ../ucloud-api-model-v2/apisdk/lang/python/templates/testing.tpl \ - --output tests/test_services/test_set_245.py \ - --name 245 - -ucloud-model sdk test \ - --lang python3 \ - --template ../ucloud-api-model-v2/apisdk/lang/python/templates/testing.tpl \ - --output tests/test_services/test_set_255.py \ - --name 255 - -ucloud-model sdk test \ - --lang python3 \ - --template ../ucloud-api-model-v2/apisdk/lang/python/templates/testing.tpl \ - --output tests/test_services/test_set_268.py \ - --name 268 - -ucloud-model sdk test \ - --lang python3 \ - --template ../ucloud-api-model-v2/apisdk/lang/python/templates/testing.tpl \ - --output tests/test_services/test_set_279.py \ - --name 279 - -ucloud-model sdk test \ - --lang python3 \ - --template ../ucloud-api-model-v2/apisdk/lang/python/templates/testing.tpl \ - --output tests/test_services/test_set_283.py \ - --name 283 - -ucloud-model sdk test \ - --lang python3 \ - --template ../ucloud-api-model-v2/apisdk/lang/python/templates/testing.tpl \ - --output tests/test_services/test_set_286.py \ - --name 286 - -ucloud-model sdk test \ - --lang python3 \ - --template ../ucloud-api-model-v2/apisdk/lang/python/templates/testing.tpl \ - --output tests/test_services/test_set_289.py \ - --name 289 - -ucloud-model sdk test \ - --lang python3 \ - --template ../ucloud-api-model-v2/apisdk/lang/python/templates/testing.tpl \ - --output tests/test_services/test_set_293.py \ - --name 293 - -ucloud-model sdk test \ - --lang python3 \ - --template ../ucloud-api-model-v2/apisdk/lang/python/templates/testing.tpl \ - --output tests/test_services/test_set_302.py \ - --name 302 - -ucloud-model sdk test \ - --lang python3 \ - --template ../ucloud-api-model-v2/apisdk/lang/python/templates/testing.tpl \ - --output tests/test_services/test_set_330.py \ - --name 330 - -ucloud-model sdk test \ - --lang python3 \ - --template ../ucloud-api-model-v2/apisdk/lang/python/templates/testing.tpl \ - --output tests/test_services/test_set_333.py \ - --name 333 - -ucloud-model sdk test \ - --lang python3 \ - --template ../ucloud-api-model-v2/apisdk/lang/python/templates/testing.tpl \ - --output tests/test_services/test_set_448.py \ - --name 448 - -ucloud-model sdk test \ - --lang python3 \ - --template ../ucloud-api-model-v2/apisdk/lang/python/templates/testing.tpl \ - --output tests/test_services/test_set_449.py \ - --name 449 - -ucloud-model sdk test \ - --lang python3 \ - --template ../ucloud-api-model-v2/apisdk/lang/python/templates/testing.tpl \ - --output tests/test_services/test_set_471.py \ - --name 471 - -ucloud-model sdk test \ - --lang python3 \ - --template ../ucloud-api-model-v2/apisdk/lang/python/templates/testing.tpl \ - --output tests/test_services/test_set_488.py \ - --name 488 - -ucloud-model sdk test \ - --lang python3 \ - --template ../ucloud-api-model-v2/apisdk/lang/python/templates/testing.tpl \ - --output tests/test_services/test_set_489.py \ - --name 489 - -ucloud-model sdk test \ - --lang python3 \ - --template ../ucloud-api-model-v2/apisdk/lang/python/templates/testing.tpl \ - --output tests/test_services/test_set_490.py \ - --name 490 - -ucloud-model sdk test \ - --lang python3 \ - --template ../ucloud-api-model-v2/apisdk/lang/python/templates/testing.tpl \ - --output tests/test_services/test_set_491.py \ - --name 491 - -ucloud-model sdk test \ - --lang python3 \ - --template ../ucloud-api-model-v2/apisdk/lang/python/templates/testing.tpl \ - --output tests/test_services/test_set_499.py \ - --name 499 - -ucloud-model sdk test \ - --lang python3 \ - --template ../ucloud-api-model-v2/apisdk/lang/python/templates/testing.tpl \ - --output tests/test_services/test_set_503.py \ - --name 503 - -ucloud-model sdk test \ - --lang python3 \ - --template ../ucloud-api-model-v2/apisdk/lang/python/templates/testing.tpl \ - --output tests/test_services/test_set_687.py \ - --name 687 - -ucloud-model sdk test \ - --lang python3 \ - --template ../ucloud-api-model-v2/apisdk/lang/python/templates/testing.tpl \ - --output tests/test_services/test_set_867.py \ - --name 867 - -ucloud-model sdk test \ - --lang python3 \ - --template ../ucloud-api-model-v2/apisdk/lang/python/templates/testing.tpl \ - --output tests/test_services/test_set_1073.py \ - --name 1073 - -ucloud-model sdk test \ - --lang python3 \ - --template ../ucloud-api-model-v2/apisdk/lang/python/templates/testing.tpl \ - --output tests/test_services/test_set_1201.py \ - --name 1201 - -ucloud-model sdk test \ - --lang python3 \ - --template ../ucloud-api-model-v2/apisdk/lang/python/templates/testing.tpl \ - --output tests/test_services/test_set_1202.py \ - --name 1202 - -ucloud-model sdk test \ - --lang python3 \ - --template ../ucloud-api-model-v2/apisdk/lang/python/templates/testing.tpl \ - --output tests/test_services/test_set_1203.py \ - --name 1203 - -ucloud-model sdk test \ - --lang python3 \ - --template ../ucloud-api-model-v2/apisdk/lang/python/templates/testing.tpl \ - --output tests/test_services/test_set_2117.py \ - --name 2117 - -ucloud-model sdk test \ - --lang python3 \ - --template ../ucloud-api-model-v2/apisdk/lang/python/templates/testing.tpl \ - --output tests/test_services/test_set_2174.py \ - --name 2174 - -ucloud-model sdk test \ - --lang python3 \ - --template ../ucloud-api-model-v2/apisdk/lang/python/templates/testing.tpl \ - --output tests/test_services/test_set_2377.py \ - --name 2377 - -ucloud-model sdk test \ - --lang python3 \ - --template ../ucloud-api-model-v2/apisdk/lang/python/templates/testing.tpl \ - --output tests/test_services/test_set_2457.py \ - --name 2457 - -ucloud-model sdk test \ - --lang python3 \ - --template ../ucloud-api-model-v2/apisdk/lang/python/templates/testing.tpl \ - --output tests/test_services/test_set_2935.py \ - --name 2935 - -ucloud-model sdk test \ - --lang python3 \ - --template ../ucloud-api-model-v2/apisdk/lang/python/templates/testing.tpl \ - --output tests/test_services/test_set_3278.py \ - --name 3278 - -ucloud-model sdk test \ - --lang python3 \ - --template ../ucloud-api-model-v2/apisdk/lang/python/templates/testing.tpl \ - --output tests/test_services/test_set_3279.py \ - --name 3279 - - -black tests/test_services/* diff --git a/scripts/release.py b/scripts/release.py new file mode 100644 index 00000000..84855a96 --- /dev/null +++ b/scripts/release.py @@ -0,0 +1,161 @@ +import logging +import subprocess +import copy +from datetime import datetime + +import ucloud.version + + +logger = logging.getLogger(__name__) + + +def shell(cmd): + print(cmd) + p = subprocess.check_output(cmd) + return p.decode().strip() + + +class Bumper: + def __init__(self, version): + self.version = version + versioned = version.split('.') + if len(versioned) != 3: + raise ValueError('invalid version {}'.format(version)) + + major, minor, patch = versioned + self.major = int(major) + self.minor = int(minor) + self.patch = int(patch) + + def bump_major(self): + clone = copy.deepcopy(self) + clone.major += 1 + clone.minor = 0 + clone.patch = 0 + return clone + + def bump_minor(self): + clone = copy.deepcopy(self) + clone.minor += 1 + clone.patch = 0 + return clone + + def bump_patch(self): + clone = copy.deepcopy(self) + clone.patch += 1 + return clone + + +class StepWriteChangelog: + classifier_tokens = ['FEATURES', 'ENHANCEMENTS', 'BUG FIXES'] + + def __init__(self, changelog_file='CHANGELOG.md', is_prerelease=True, is_dry_run=True): + self.state = '' + self.logs = {} + self.changelog_file = changelog_file + self.is_prerelease = is_prerelease + self.is_dry_run = is_dry_run + + @staticmethod + def get_git_logs(): + version = shell('git describe --tags --abbrev=0') + commit_sha = shell('git show-ref -s {}'.format(version)) + return shell('git log --format=%B {}..HEAD'.format(commit_sha)) + + def get_change_logs(self): + logs = {} + for line in self.get_git_logs().split('\n'): + line = line.strip() + if not line: + continue + + if line.strip(':') in self.classifier_tokens: + self.state = line + logs.setdefault(line, []) + continue + + if line.startswith('- ') and self.state: + logs[self.state].append(line) + else: + logger.warning('ignore changelog: {}'.format(line)) + + return logs + + def write_changelog(self, logs): + buffer_lines = [] + should_bump = None + + # render change logs + for i, token in enumerate(self.classifier_tokens): + items = logs.get(token) + if not items: + continue + + buffer_lines.append(token) + for item in items: + buffer_lines.append('- ' + item) + + if should_bump is None: + should_bump = i + + if should_bump is None: + raise ValueError('no content should be release') + + # auto increase version number + bumper = Bumper(ucloud.version.version) + if should_bump == 0: + if not self.is_prerelease: + bumper = bumper.bump_major() + else: + bumper = bumper.bump_minor() + elif should_bump == 1: + bumper = bumper.bump_minor() + else: + bumper = bumper.bump_patch() + + if not self.is_dry_run: + # insert change logs at the begin of changelog file + with open('CHANGELOG.md', 'rw') as f: + content = f.read() + f.write('\n\n'.join([ + '## {} ({})'.format(bumper.version, datetime.now().date().isoformat()), + '\n'.join(buffer_lines), + content, + ])) + + return bumper.version + + def write_version(self, version): + version_code = 'version = "{}"'.format(version) + if self.is_dry_run: + print(version_code) + return + + with open('./ucloud/version.py', 'w') as f: + f.write(version_code) + + +def main(): + import argparse + + parser = argparse.ArgumentParser(description='Process some integers.') + parser.add_argument('--changelog-file', default='CHANGELOG.md', + help='the file path of changelog file') + parser.add_argument('--production', default=False, action='store_true', help='is prerelease') + parser.add_argument('--dry-run', default=False, action='store_true', help='is dry run') + + args = parser.parse_args() + print(args) + + step1 = StepWriteChangelog( + changelog_file=args.changelog_file, + is_dry_run=args.dry_run, + is_prerelease=not args.production, + ) + logs = step1.get_change_logs() + version = step1.write_changelog(logs) + step1.write_version(version) + + +if __name__ == '__main__': + main() diff --git a/setup.py b/setup.py index 7de0d470..6ba5febd 100644 --- a/setup.py +++ b/setup.py @@ -30,10 +30,9 @@ PY3 = sys.version_info[0] == 3 and sys.version_info[1] >= 5 if not PY3: - raise NotImplementedError(( - "ucloud-sdk-python3 should be used in 3.5 " - "and above of python interpreter" - )) + raise NotImplementedError( + ("ucloud-sdk-python3 should be used in 3.5 " "and above of python interpreter") + ) def load_version(): @@ -60,17 +59,13 @@ def load_requirements(requirements_file): dependencies = load_requirements("requirements.txt") -dependencies_test = dependencies + [ - 'flake8>=3.6.0', - 'pytest', - 'pytest-cov', -] +dependencies_test = dependencies + ["flake8>=3.6.0", "pytest", "pytest-cov"] -dependencies_doc = dependencies + ['sphinx'] +dependencies_doc = dependencies + ["sphinx"] dependencies_ci = list(set(dependencies_test + dependencies_doc)) -dependencies_dev = list(set(dependencies_ci + ['black'])) +dependencies_dev = list(set(dependencies_ci + ["black"])) def do_setup(): @@ -78,7 +73,7 @@ def do_setup(): name="ucloud-sdk-python3", description="UCloud Service Development Kit - Python", long_description=load_long_description(), - long_description_content_type='text/markdown', + long_description_content_type="text/markdown", license="Apache License 2.0", version=load_version(), packages=find_packages(exclude=["tests*"]), diff --git a/tests/test_services/test_set_4079.py b/tests/test_services/test_set_4079.py new file mode 100644 index 00000000..42b0dce0 --- /dev/null +++ b/tests/test_services/test_set_4079.py @@ -0,0 +1,288 @@ +""" Code is generated by ucloud-model, DO NOT EDIT IT. """ + +import pytest +import logging + +from ucloud.core import exc +from ucloud.testing import env, funcs, op, utest + +logger = logging.getLogger(__name__) + + +scenario = utest.Scenario(4079) + + +@pytest.mark.skipif(env.is_ut(), reason=env.get_skip_reason()) +def test_set_4079(client: utest.Client, variables: dict): + scenario.initial(variables) + + scenario.variables[ + "file" + ] = "" + scenario.variables["phonenumber"] = "" + scenario.variables["templateid0"] = "" + scenario.variables["sigid0"] = "" + + scenario.run(client) + + +@scenario.step( + max_retries=3, + retry_interval=1, + startup_delay=0, + fast_fail=True, + validators=lambda variables: [ + ("str_eq", "RetCode", 0), + ("str_eq", "Action", "CreateUSMSSignatureResponse"), + ], + action="CreateUSMSSignature", +) +def create_usms_signature_00(client: utest.Client, variables: dict): + d = { + "SigType": 0, + "SigPurpose": 0, + "SigContent": "test", + "File": variables.get("file"), + "Description": "test-sdk", + "CertificateType": 0, + } + + try: + resp = client.usms().create_usms_signature(d) + except exc.RetCodeException as e: + resp = e.json() + + variables["SigId"] = utest.value_at_path(resp, "SigId") + return resp + + +@scenario.step( + max_retries=3, + retry_interval=1, + startup_delay=0, + fast_fail=True, + validators=lambda variables: [ + ("str_eq", "RetCode", 0), + ("str_eq", "Action", "QueryUSMSSignatureResponse"), + ], + action="QueryUSMSSignature", +) +def query_usms_signature_01(client: utest.Client, variables: dict): + d = {"SigId": variables.get("SigId")} + + try: + resp = client.usms().query_usms_signature(d) + except exc.RetCodeException as e: + resp = e.json() + + return resp + + +@scenario.step( + max_retries=3, + retry_interval=1, + startup_delay=0, + fast_fail=True, + validators=lambda variables: [ + ("str_eq", "RetCode", 0), + ("str_eq", "Action", "UpdateUSMSSignatureResponse"), + ], + action="UpdateUSMSSignature", +) +def update_usms_signature_02(client: utest.Client, variables: dict): + d = { + "SigType": 0, + "SigPurpose": 0, + "SigId": variables.get("SigId"), + "SigContent": "test-sig-update", + "File": variables.get("file"), + } + + try: + resp = client.usms().update_usms_signature(d) + except exc.RetCodeException as e: + resp = e.json() + + return resp + + +@scenario.step( + max_retries=3, + retry_interval=1, + startup_delay=0, + fast_fail=False, + validators=lambda variables: [ + ("str_eq", "RetCode", 0), + ("str_eq", "Action", "DeleteUSMSSignatureResponse"), + ], + action="DeleteUSMSSignature", +) +def delete_usms_signature_03(client: utest.Client, variables: dict): + d = {"SigIds": [variables.get("SigId")]} + + try: + resp = client.usms().delete_usms_signature(d) + except exc.RetCodeException as e: + resp = e.json() + + return resp + + +@scenario.step( + max_retries=3, + retry_interval=1, + startup_delay=0, + fast_fail=False, + validators=lambda variables: [ + ("str_eq", "RetCode", 0), + ("str_eq", "Action", "CreateUSMSTemplateResponse"), + ], + action="CreateUSMSTemplate", +) +def create_usms_template_04(client: utest.Client, variables: dict): + d = { + "Zone": variables.get("Zone"), + "TemplateName": "test-sdk-template", + "Template": "this is a sdk template", + "Region": variables.get("Region"), + "Purpose": 1, + } + + try: + resp = client.usms().create_usms_template(d) + except exc.RetCodeException as e: + resp = e.json() + + variables["TemplateId"] = utest.value_at_path(resp, "TemplateId") + return resp + + +@scenario.step( + max_retries=3, + retry_interval=1, + startup_delay=0, + fast_fail=False, + validators=lambda variables: [ + ("str_eq", "RetCode", 0), + ("str_eq", "Action", "QueryUSMSTemplateResponse"), + ], + action="QueryUSMSTemplate", +) +def query_usms_template_05(client: utest.Client, variables: dict): + d = {"TemplateId": variables.get("TemplateId")} + + try: + resp = client.usms().query_usms_template(d) + except exc.RetCodeException as e: + resp = e.json() + + return resp + + +@scenario.step( + max_retries=3, + retry_interval=1, + startup_delay=0, + fast_fail=False, + validators=lambda variables: [ + ("str_eq", "RetCode", 0), + ("str_eq", "Action", "UpdateUSMSTemplateResponse"), + ], + action="UpdateUSMSTemplate", +) +def update_usms_template_06(client: utest.Client, variables: dict): + d = { + "Zone": variables.get("Zone"), + "TemplateId": variables.get("TemplateId"), + "Template": "test-sdk-template-update", + "Region": variables.get("Region"), + } + + try: + resp = client.usms().update_usms_template(d) + except exc.RetCodeException as e: + resp = e.json() + + return resp + + +@scenario.step( + max_retries=3, + retry_interval=1, + startup_delay=0, + fast_fail=False, + validators=lambda variables: [ + ("str_eq", "RetCode", 0), + ("str_eq", "Action", "DeleteUSMSTemplateResponse"), + ], + action="DeleteUSMSTemplate", +) +def delete_usms_template_07(client: utest.Client, variables: dict): + d = { + "Zone": variables.get("Zone"), + "TemplateIds": [variables.get("TemplateId")], + "Region": variables.get("Region"), + } + + try: + resp = client.usms().delete_usms_template(d) + except exc.RetCodeException as e: + resp = e.json() + + return resp + + +@scenario.step( + max_retries=3, + retry_interval=1, + startup_delay=0, + fast_fail=False, + validators=lambda variables: [ + ("str_eq", "RetCode", 0), + ("str_eq", "Action", "SendUSMSMessageResponse"), + ], + action="SendUSMSMessage", +) +def send_usms_message_08(client: utest.Client, variables: dict): + d = { + "Zone": variables.get("Zone"), + "TemplateId": variables.get("templateid0"), + "SigContent": variables.get("sigid0"), + "Region": variables.get("Region"), + "PhoneNumbers": [variables.get("phonenumber")], + "TemplateParams": ["101010"], + } + + try: + resp = client.usms().send_usms_message(d) + except exc.RetCodeException as e: + resp = e.json() + + variables["SessionNo"] = utest.value_at_path(resp, "SessionNo") + return resp + + +@scenario.step( + max_retries=3, + retry_interval=1, + startup_delay=0, + fast_fail=False, + validators=lambda variables: [ + ("str_eq", "RetCode", 0), + ("str_eq", "Action", "GetUSMSSendReceiptResponse"), + ], + action="GetUSMSSendReceipt", +) +def get_usms_send_receipt_09(client: utest.Client, variables: dict): + d = { + "Zone": variables.get("Zone"), + "SessionNoSet": [variables.get("SessionNo")], + "Region": variables.get("Region"), + } + + try: + resp = client.usms().get_usms_send_receipt(d) + except exc.RetCodeException as e: + resp = e.json() + + return resp diff --git a/tests/test_services/test_set_4140.py b/tests/test_services/test_set_4140.py new file mode 100644 index 00000000..0afd8e3e --- /dev/null +++ b/tests/test_services/test_set_4140.py @@ -0,0 +1,600 @@ +""" Code is generated by ucloud-model, DO NOT EDIT IT. """ + +import pytest +import logging + +from ucloud.core import exc +from ucloud.testing import env, funcs, op, utest + +logger = logging.getLogger(__name__) + + +scenario = utest.Scenario(4140) + + +@pytest.mark.skipif(env.is_ut(), reason=env.get_skip_reason()) +def test_set_4140(client: utest.Client, variables: dict): + scenario.initial(variables) + + scenario.variables["BucketName_test"] = funcs.concat( + "ucdntest-", funcs.get_timestamp(10) + ) + scenario.variables["time_granule_type"] = 1 + + scenario.run(client) + + +@scenario.step( + max_retries=3, + retry_interval=1, + startup_delay=0, + fast_fail=False, + validators=lambda variables: [ + ("str_eq", "RetCode", 0), + ("str_eq", "Action", "CreateBucketResponse"), + ], + action="CreateBucket", +) +def create_bucket_00(client: utest.Client, variables: dict): + d = { + "Region": variables.get("Region"), + "BucketName": variables.get("BucketName_test"), + } + + try: + resp = client.invoke("CreateBucket", d) + except exc.RetCodeException as e: + resp = e.json() + + return resp + + +@scenario.step( + max_retries=3, + retry_interval=1, + startup_delay=0, + fast_fail=False, + validators=lambda variables: [ + ("str_eq", "RetCode", 0), + ("str_eq", "Action", "StartUcdnTestDomainResponse"), + ], + action="StartUcdnTestDomain", +) +def start_ucdn_test_domain_01(client: utest.Client, variables: dict): + d = { + "Region": variables.get("Region"), + "BucketName": variables.get("BucketName_test"), + } + + try: + resp = client.invoke("StartUcdnTestDomain", d) + except exc.RetCodeException as e: + resp = e.json() + + variables["domainId"] = utest.value_at_path(resp, "DomainId") + return resp + + +@scenario.step( + max_retries=3, + retry_interval=1, + startup_delay=3, + fast_fail=True, + validators=lambda variables: [ + ("str_eq", "RetCode", 0), + ("str_eq", "Action", "DescribeUcdnDomainResponse"), + ("str_eq", "DomainSet.0.ChannelType", "ucdn"), + ( + "str_eq", + "DomainSet.0.Domain", + funcs.concat( + variables.get("BucketName_test"), ".ufile.ucloud.com.cn" + ), + ), + ("str_eq", "DomainSet.0.DomainId", variables.get("domainId")), + ("str_eq", "DomainSet.0.Status", "check"), + ], + action="DescribeUcdnDomain", +) +def describe_ucdn_domain_02(client: utest.Client, variables: dict): + d = {"DomainId": [variables.get("domainId")]} + + try: + resp = client.ucdn().describe_ucdn_domain(d) + except exc.RetCodeException as e: + resp = e.json() + + return resp + + +@scenario.step( + max_retries=30, + retry_interval=10, + startup_delay=200, + fast_fail=True, + validators=lambda variables: [ + ("str_eq", "RetCode", 0), + ("str_eq", "Action", "DescribeUcdnDomainResponse"), + ("str_eq", "DomainSet.0.ChannelType", "ucdn"), + ( + "str_eq", + "DomainSet.0.Domain", + funcs.concat( + variables.get("BucketName_test"), ".ufile.ucloud.com.cn" + ), + ), + ("str_eq", "DomainSet.0.DomainId", variables.get("domainId")), + ("str_eq", "DomainSet.0.Status", "enable"), + ], + action="DescribeUcdnDomain", +) +def describe_ucdn_domain_03(client: utest.Client, variables: dict): + d = {"DomainId": [variables.get("domainId")]} + + try: + resp = client.ucdn().describe_ucdn_domain(d) + except exc.RetCodeException as e: + resp = e.json() + + variables["domain"] = utest.value_at_path(resp, "DomainSet.0.Domain") + return resp + + +@scenario.step( + max_retries=3, + retry_interval=1, + startup_delay=0, + fast_fail=False, + validators=lambda variables: [ + ("str_eq", "RetCode", 0), + ("str_eq", "Action", "BatchDescribeNewUcdnDomainResponse"), + ], + action="BatchDescribeNewUcdnDomain", +) +def batch_describe_new_ucdn_domain_04(client: utest.Client, variables: dict): + d = {} + + try: + resp = client.ucdn().batch_describe_new_ucdn_domain(d) + except exc.RetCodeException as e: + resp = e.json() + + return resp + + +@scenario.step( + max_retries=3, + retry_interval=1, + startup_delay=0, + fast_fail=False, + validators=lambda variables: [ + ("str_eq", "RetCode", 0), + ("str_eq", "Action", "GetNewUcdnDomainHttpCodeV2Response"), + ], + action="GetNewUcdnDomainHttpCodeV2", +) +def get_new_ucdn_domain_http_code_v2_05(client: utest.Client, variables: dict): + d = { + "Type": variables.get("time_granule_type"), + "EndTime": funcs.get_timestamp(10), + "BeginTime": funcs.get_timestamp(10) - 10000, + } + + try: + resp = client.ucdn().get_new_ucdn_domain_http_code_v2(d) + except exc.RetCodeException as e: + resp = e.json() + + return resp + + +@scenario.step( + max_retries=3, + retry_interval=1, + startup_delay=0, + fast_fail=False, + validators=lambda variables: [ + ("str_eq", "RetCode", 0), + ("str_eq", "Action", "GetNewUcdnDomainHitRateResponse"), + ], + action="GetNewUcdnDomainHitRate", +) +def get_new_ucdn_domain_hit_rate_06(client: utest.Client, variables: dict): + d = { + "Type": variables.get("time_granule_type"), + "EndTime": funcs.get_timestamp(10), + "BeginTime": funcs.get_timestamp(10) - 1000, + } + + try: + resp = client.ucdn().get_new_ucdn_domain_hit_rate(d) + except exc.RetCodeException as e: + resp = e.json() + + return resp + + +@scenario.step( + max_retries=3, + retry_interval=1, + startup_delay=0, + fast_fail=False, + validators=lambda variables: [ + ("str_eq", "RetCode", 0), + ("str_eq", "Action", "GetNewUcdnDomainHttpCodeResponse"), + ], + action="GetNewUcdnDomainHttpCode", +) +def get_new_ucdn_domain_http_code_07(client: utest.Client, variables: dict): + d = { + "Type": variables.get("time_granule_type"), + "EndTime": funcs.get_timestamp(10), + "BeginTime": funcs.get_timestamp(10) - 10000, + } + + try: + resp = client.ucdn().get_new_ucdn_domain_http_code(d) + except exc.RetCodeException as e: + resp = e.json() + + return resp + + +@scenario.step( + max_retries=3, + retry_interval=1, + startup_delay=0, + fast_fail=False, + validators=lambda variables: [ + ("str_eq", "RetCode", 0), + ("str_eq", "Action", "PrefetchNewUcdnDomainCacheResponse"), + ], + action="PrefetchNewUcdnDomainCache", +) +def prefetch_new_ucdn_domain_cache_08(client: utest.Client, variables: dict): + d = {"UrlList": [funcs.concat("http://", variables.get("domain"), "/")]} + + try: + resp = client.ucdn().prefetch_new_ucdn_domain_cache(d) + except exc.RetCodeException as e: + resp = e.json() + + variables["PrefetchCache_TaskId"] = utest.value_at_path(resp, "TaskId") + return resp + + +@scenario.step( + max_retries=3, + retry_interval=1, + startup_delay=0, + fast_fail=False, + validators=lambda variables: [ + ("str_eq", "RetCode", 0), + ("str_eq", "Action", "DescribeNewUcdnPrefetchCacheTaskResponse"), + ], + action="DescribeNewUcdnPrefetchCacheTask", +) +def describe_new_ucdn_prefetch_cache_task_09( + client: utest.Client, variables: dict +): + d = {"TaskId": [variables.get("PrefetchCache_TaskId")]} + + try: + resp = client.ucdn().describe_new_ucdn_prefetch_cache_task(d) + except exc.RetCodeException as e: + resp = e.json() + + return resp + + +@scenario.step( + max_retries=3, + retry_interval=1, + startup_delay=0, + fast_fail=False, + validators=lambda variables: [ + ("str_eq", "RetCode", 0), + ("str_eq", "Action", "DescribeNewUcdnRefreshCacheTaskResponse"), + ], + action="DescribeNewUcdnRefreshCacheTask", +) +def describe_new_ucdn_refresh_cache_task_10( + client: utest.Client, variables: dict +): + d = {"TaskId": [variables.get("PrefetchCache_TaskId")]} + + try: + resp = client.ucdn().describe_new_ucdn_refresh_cache_task(d) + except exc.RetCodeException as e: + resp = e.json() + + return resp + + +@scenario.step( + max_retries=3, + retry_interval=1, + startup_delay=0, + fast_fail=False, + validators=lambda variables: [ + ("str_eq", "RetCode", 0), + ("str_eq", "Action", "RefreshNewUcdnDomainCacheResponse"), + ], + action="RefreshNewUcdnDomainCache", +) +def refresh_new_ucdn_domain_cache_11(client: utest.Client, variables: dict): + d = { + "UrlList": [funcs.concat("http://", variables.get("domain"), "/")], + "Type": "file", + } + + try: + resp = client.ucdn().refresh_new_ucdn_domain_cache(d) + except exc.RetCodeException as e: + resp = e.json() + + return resp + + +@scenario.step( + max_retries=3, + retry_interval=1, + startup_delay=0, + fast_fail=False, + validators=lambda variables: [ + ("str_eq", "RetCode", 0), + ("str_eq", "Action", "GetNewUcdnDomainBandwidthResponse"), + ], + action="GetNewUcdnDomainBandwidth", +) +def get_new_ucdn_domain_bandwidth_12(client: utest.Client, variables: dict): + d = {"Type": variables.get("time_granule_type")} + + try: + resp = client.ucdn().get_new_ucdn_domain_bandwidth(d) + except exc.RetCodeException as e: + resp = e.json() + + return resp + + +@scenario.step( + max_retries=3, + retry_interval=1, + startup_delay=0, + fast_fail=False, + validators=lambda variables: [ + ("str_eq", "RetCode", 0), + ("str_eq", "Action", "GetUcdnPassBandwidthResponse"), + ], + action="GetUcdnPassBandwidth", +) +def get_ucdn_pass_bandwidth_13(client: utest.Client, variables: dict): + d = {"Type": variables.get("time_granule_type")} + + try: + resp = client.ucdn().get_ucdn_pass_bandwidth(d) + except exc.RetCodeException as e: + resp = e.json() + + return resp + + +@scenario.step( + max_retries=3, + retry_interval=1, + startup_delay=0, + fast_fail=False, + validators=lambda variables: [ + ("str_eq", "RetCode", 0), + ("str_eq", "Action", "GetUcdnDomainRequestNumV2Response"), + ], + action="GetUcdnDomainRequestNumV2", +) +def get_ucdn_domain_request_num_v2_14(client: utest.Client, variables: dict): + d = { + "Type": variables.get("time_granule_type"), + "EndTime": funcs.get_timestamp(10), + "DomainId": [variables.get("domainId")], + "BeginTime": funcs.get_timestamp(10) - 1000, + } + + try: + resp = client.ucdn().get_ucdn_domain_request_num_v2(d) + except exc.RetCodeException as e: + resp = e.json() + + return resp + + +@scenario.step( + max_retries=3, + retry_interval=1, + startup_delay=0, + fast_fail=False, + validators=lambda variables: [ + ("str_eq", "RetCode", 0), + ("str_eq", "Action", "GetUcdnDomainLogResponse"), + ], + action="GetUcdnDomainLog", +) +def get_ucdn_domain_log_15(client: utest.Client, variables: dict): + d = { + "Type": variables.get("time_granule_type"), + "DomainId": [variables.get("domainId")], + } + + try: + resp = client.ucdn().get_ucdn_domain_log(d) + except exc.RetCodeException as e: + resp = e.json() + + return resp + + +@scenario.step( + max_retries=3, + retry_interval=1, + startup_delay=0, + fast_fail=False, + validators=lambda variables: [ + ("str_eq", "RetCode", 0), + ("str_eq", "Action", "GetUcdnTrafficResponse"), + ], + action="GetUcdnTraffic", +) +def get_ucdn_traffic_16(client: utest.Client, variables: dict): + d = {} + + try: + resp = client.ucdn().get_ucdn_traffic(d) + except exc.RetCodeException as e: + resp = e.json() + + return resp + + +@scenario.step( + max_retries=3, + retry_interval=1, + startup_delay=0, + fast_fail=False, + validators=lambda variables: [ + ("str_eq", "RetCode", 0), + ("str_eq", "Action", "GetUcdnDomainTrafficResponse"), + ], + action="GetUcdnDomainTraffic", +) +def get_ucdn_domain_traffic_17(client: utest.Client, variables: dict): + d = {"AccountType": "top"} + + try: + resp = client.ucdn().get_ucdn_domain_traffic(d) + except exc.RetCodeException as e: + resp = e.json() + + return resp + + +@scenario.step( + max_retries=3, + retry_interval=1, + startup_delay=0, + fast_fail=False, + validators=lambda variables: [ + ("str_eq", "RetCode", 0), + ("str_eq", "Action", "GetUcdnDomainPrefetchEnableResponse"), + ("str_eq", "Enable", 1), + ], + action="GetUcdnDomainPrefetchEnable", +) +def get_ucdn_domain_prefetch_enable_18(client: utest.Client, variables: dict): + d = {"DomainId": variables.get("domainId")} + + try: + resp = client.ucdn().get_ucdn_domain_prefetch_enable(d) + except exc.RetCodeException as e: + resp = e.json() + + return resp + + +@scenario.step( + max_retries=3, + retry_interval=1, + startup_delay=0, + fast_fail=False, + validators=lambda variables: [ + ("str_eq", "RetCode", 0), + ("str_eq", "Action", "SwitchUcdnChargeTypeResponse"), + ], + action="SwitchUcdnChargeType", +) +def switch_ucdn_charge_type_19(client: utest.Client, variables: dict): + d = {"ChargeType": "traffic"} + + try: + resp = client.ucdn().switch_ucdn_charge_type(d) + except exc.RetCodeException as e: + resp = e.json() + + return resp + + +@scenario.step( + max_retries=3, + retry_interval=1, + startup_delay=0, + fast_fail=False, + validators=lambda variables: [ + ("str_eq", "RetCode", 0), + ("str_eq", "Action", "StopUcdnTestDomainResponse"), + ], + action="StopUcdnTestDomain", +) +def stop_ucdn_test_domain_20(client: utest.Client, variables: dict): + d = { + "Region": variables.get("Region"), + "BucketName": variables.get("BucketName_test"), + } + + try: + resp = client.invoke("StopUcdnTestDomain", d) + except exc.RetCodeException as e: + resp = e.json() + + return resp + + +@scenario.step( + max_retries=3, + retry_interval=1, + startup_delay=0, + fast_fail=False, + validators=lambda variables: [ + ("str_eq", "RetCode", 0), + ("str_eq", "Action", "DescribeUcdnDomainResponse"), + ("str_eq", "DomainSet.0.ChannelType", "ucdn"), + ( + "str_eq", + "DomainSet.0.Domain", + funcs.concat( + variables.get("BucketName_test"), ".ufile.ucloud.com.cn" + ), + ), + ("str_eq", "DomainSet.0.DomainId", variables.get("domainId")), + ("str_eq", "DomainSet.0.Status", "deleteing"), + ], + action="DescribeUcdnDomain", +) +def describe_ucdn_domain_21(client: utest.Client, variables: dict): + d = {"DomainId": [variables.get("domainId")]} + + try: + resp = client.ucdn().describe_ucdn_domain(d) + except exc.RetCodeException as e: + resp = e.json() + + return resp + + +@scenario.step( + max_retries=10, + retry_interval=10, + startup_delay=120, + fast_fail=False, + validators=lambda variables: [ + ("str_eq", "RetCode", 0), + ("str_eq", "Action", "DeleteBucketResponse"), + ], + action="DeleteBucket", +) +def delete_bucket_22(client: utest.Client, variables: dict): + d = {"BucketName": variables.get("BucketName_test")} + + try: + resp = client.invoke("DeleteBucket", d) + except exc.RetCodeException as e: + resp = e.json() + + return resp diff --git a/ucloud/_compat.py b/ucloud/_compat.py new file mode 100644 index 00000000..62fed4c1 --- /dev/null +++ b/ucloud/_compat.py @@ -0,0 +1,21 @@ +from ucloud.core import client + + +class CompactClient(client.Client): + def __init__(self, config: dict, transport=None, middleware=None): + self._config = config + super(CompactClient, self).__init__(config, transport, middleware) + + def pathx(self): + from ucloud.services.pathx.client import PathXClient + + return PathXClient( + self._config, self.transport, self.middleware, self.logger + ) + + def vpc(self): + from ucloud.services.vpc.client import VPCClient + + return VPCClient( + self._config, self.transport, self.middleware, self.logger + ) diff --git a/ucloud/client.py b/ucloud/client.py index 9b3428d8..1126a980 100644 --- a/ucloud/client.py +++ b/ucloud/client.py @@ -1,93 +1,93 @@ -""" Code is generated by ucloud-model, DO NOT EDIT IT. """ - -from ucloud.core import client - - -class Client(client.Client): - def __init__(self, config: dict, transport=None, middleware=None): - self._config = config - super(Client, self).__init__(config, transport, middleware) - - def pathx(self): - from ucloud.services.pathx.client import PathXClient - - return PathXClient( - self._config, self.transport, self.middleware, self.logger - ) - - def stepflow(self): - from ucloud.services.stepflow.client import StepFlowClient - - return StepFlowClient( - self._config, self.transport, self.middleware, self.logger - ) - - def uaccount(self): - from ucloud.services.uaccount.client import UAccountClient - - return UAccountClient( - self._config, self.transport, self.middleware, self.logger - ) - - def udb(self): - from ucloud.services.udb.client import UDBClient - - return UDBClient( - self._config, self.transport, self.middleware, self.logger - ) - - def udpn(self): - from ucloud.services.udpn.client import UDPNClient - - return UDPNClient( - self._config, self.transport, self.middleware, self.logger - ) - - def udisk(self): - from ucloud.services.udisk.client import UDiskClient - - return UDiskClient( - self._config, self.transport, self.middleware, self.logger - ) - - def uhost(self): - from ucloud.services.uhost.client import UHostClient - - return UHostClient( - self._config, self.transport, self.middleware, self.logger - ) - - def ulb(self): - from ucloud.services.ulb.client import ULBClient - - return ULBClient( - self._config, self.transport, self.middleware, self.logger - ) - - def umem(self): - from ucloud.services.umem.client import UMemClient - - return UMemClient( - self._config, self.transport, self.middleware, self.logger - ) - - def unet(self): - from ucloud.services.unet.client import UNetClient - - return UNetClient( - self._config, self.transport, self.middleware, self.logger - ) - - def uphost(self): - from ucloud.services.uphost.client import UPHostClient - - return UPHostClient( - self._config, self.transport, self.middleware, self.logger - ) - - def vpc(self): - from ucloud.services.vpc.client import VPCClient - - return VPCClient( - self._config, self.transport, self.middleware, self.logger - ) +""" Code is generated by ucloud-model, DO NOT EDIT IT. """ + +from ucloud._compat import CompactClient + + +class Client(CompactClient): + def __init__(self, config: dict, transport=None, middleware=None): + self._config = config + super(Client, self).__init__(config, transport, middleware) + + def stepflow(self): + from ucloud.services.stepflow.client import StepFlowClient + + return StepFlowClient( + self._config, self.transport, self.middleware, self.logger + ) + + def uaccount(self): + from ucloud.services.uaccount.client import UAccountClient + + return UAccountClient( + self._config, self.transport, self.middleware, self.logger + ) + + def ucdn(self): + from ucloud.services.ucdn.client import UCDNClient + + return UCDNClient( + self._config, self.transport, self.middleware, self.logger + ) + + def udb(self): + from ucloud.services.udb.client import UDBClient + + return UDBClient( + self._config, self.transport, self.middleware, self.logger + ) + + def udpn(self): + from ucloud.services.udpn.client import UDPNClient + + return UDPNClient( + self._config, self.transport, self.middleware, self.logger + ) + + def udisk(self): + from ucloud.services.udisk.client import UDiskClient + + return UDiskClient( + self._config, self.transport, self.middleware, self.logger + ) + + def uhost(self): + from ucloud.services.uhost.client import UHostClient + + return UHostClient( + self._config, self.transport, self.middleware, self.logger + ) + + def ulb(self): + from ucloud.services.ulb.client import ULBClient + + return ULBClient( + self._config, self.transport, self.middleware, self.logger + ) + + def umem(self): + from ucloud.services.umem.client import UMemClient + + return UMemClient( + self._config, self.transport, self.middleware, self.logger + ) + + def unet(self): + from ucloud.services.unet.client import UNetClient + + return UNetClient( + self._config, self.transport, self.middleware, self.logger + ) + + def uphost(self): + from ucloud.services.uphost.client import UPHostClient + + return UPHostClient( + self._config, self.transport, self.middleware, self.logger + ) + + def usms(self): + from ucloud.services.usms.client import USMSClient + + return USMSClient( + self._config, self.transport, self.middleware, self.logger + ) diff --git a/ucloud/core/client/_cfg.py b/ucloud/core/client/_cfg.py index 81984732..8629057d 100644 --- a/ucloud/core/client/_cfg.py +++ b/ucloud/core/client/_cfg.py @@ -5,7 +5,7 @@ class ConfigSchema(schema.Schema): fields = { - "region": fields.Str(required=True), + "region": fields.Str(), "project_id": fields.Str(), "base_url": fields.Str(default="https://api.ucloud.cn"), "user_agent": fields.Str(), @@ -46,7 +46,7 @@ class Config: def __init__( self, - region: str, + region: str = None, project_id: str = None, base_url: str = "https://api.ucloud.cn", user_agent: str = None, diff --git a/ucloud/core/client/_client.py b/ucloud/core/client/_client.py index d4a270f8..a2394744 100644 --- a/ucloud/core/client/_client.py +++ b/ucloud/core/client/_client.py @@ -130,4 +130,6 @@ def _build_user_agent(self) -> str: return user_agent def __repr__(self): - return '<{}("{}")>'.format(self.__class__.__name__, self.config.region) + return '<{}(region="{}")>'.format( + self.__class__.__name__, self.config.region + ) diff --git a/ucloud/services/ucdn/__init__.py b/ucloud/services/ucdn/__init__.py new file mode 100644 index 00000000..e69de29b diff --git a/ucloud/services/ucdn/client.py b/ucloud/services/ucdn/client.py new file mode 100644 index 00000000..9e135267 --- /dev/null +++ b/ucloud/services/ucdn/client.py @@ -0,0 +1,681 @@ +""" Code is generated by ucloud-model, DO NOT EDIT IT. """ + +import typing + + +from ucloud.core.client import Client +from ucloud.services.ucdn.schemas import apis + + +class UCDNClient(Client): + def __init__( + self, config: dict, transport=None, middleware=None, logger=None + ): + super(UCDNClient, self).__init__(config, transport, middleware, logger) + + def batch_describe_new_ucdn_domain( + self, req: typing.Optional[dict] = None, **kwargs + ) -> dict: + """ BatchDescribeNewUcdnDomain - 批量获取加速域名配置 + + **Request** + + - **ProjectId** (str) - (Config) 项目ID。不填写为默认项目,子帐号必须填写。 请参考 `GetProjectList接口 `_ + - **ChannelType** (str) - 渠道ucdn、ufile、uvideo + - **DomainId** (list) - 域名id,创建域名时生成的资源id,默认获取账号下的所有域名信息,n为自然数 + - **Limit** (int) - 返回数据长度,如果制定了Offset,则默认20,否则默认全部,非负整数 + - **Offset** (int) - 数据偏移量,默认0,非负整数 + + **Response** + + - **Arrearage** (list) - 标识欠费的数组,数组含有下列元素值, 1=国内流量有欠费 2=国外流量有欠费 3=国内带宽有欠费 4=国外带宽有欠费 + - **ChargeType** (int) - 当前计费方式,10=流量付费 20=带宽日峰值 30=按月后付费 + - **DomainList** (list) - 见 **DomainInfo** 模型定义 + - **LastChargeType** (int) - 表示最后一次切换的计费方式,10=流量付费 20=带宽日峰值 30=按月后付费 40=未选择计费方式 + - **MaxDomainNum** (int) - 最大域名数量,默认20 + - **TotalCount** (int) - 满足条件的域名个数 + - **Vip** (str) - vip标示,yes-是 no-否 + + **Response Model** + + **AccessConf** + + - **IpBlacklist** (str) - 多个ip用逗号隔开 + + **CacheConf** + + - **CacheBehavior** (bool) - 是否缓存,true为缓存,false为不缓存。为false的情况下,CacheTTL和CacheUnit强制不生效 + - **CacheTTL** (int) - 缓存时间 + - **CacheUnit** (str) - 缓存时间的单位。sec(秒),min(分钟),hour(小时),day(天) + - **Description** (str) - 缓存规则描述 + - **FollowOriginRule** (bool) - 是否优先遵循源站头部缓存策略,false为不优先遵循源站,true为优先遵循源站缓存头部。默认为false + - **HttpCodePattern** (str) - 状态码默认情况只缓存200类状态码,支持正则 + - **IgnoreQueryString** (bool) - 是否忽略参数缓存(false为不忽略,true为忽略,默认为false) + - **PathPattern** (str) - 路径模式,支持正则 + + **DomainInfo** + + - **AccessConf** (dict) - 见 **AccessConf** 模型定义 + - **AreaCode** (str) - 查询带宽区域 cn代表国内 abroad代表海外 不填默认为全部区域 + - **CacheConf** (list) - 见 **CacheConf** 模型定义 + - **CacheHost** (str) - 缓存Host,不同的域名可以配置为同一个CacheHost来实现缓存共享,默认为加速域名 + - **CdnProtocol** (str) - 加速类型http,http|https + - **CdnType** (str) - 加速域名的业务类型,web代表网站,stream代表视频,download代表下载。 + - **CertName** (str) - 证书名称 + - **Cname** (str) - cdn域名。创建加速域名生成的cdn域名,用于设置CNAME记录 + - **CreateTime** (int) - 域名创建的时间。格式:时间戳 + - **Domain** (str) - 域名,用户创建加速的域名 + - **DomainId** (str) - 域名id,创建域名时生成的id + - **HttpsStatusAbroad** (str) - 国外https状态 enableing-开启中 fail-开启失败 enable-启用 disable-未启用 + - **HttpsStatusCn** (str) - 国内https状态 enableing-开启中 fail-开启失败 enable-启用 disable-未启用 + - **NullRefer** (bool) - ReferType为白名单时,NullRefer为false代表不允许NULL refer访问,为true代表允许Null refer访问 + - **OriginHost** (str) - 回源Http请求头部Host,默认是加速域名 + - **OriginIp** (list) - 源站ip即cdn服务器回源访问的ip地址。支持多个源站ip,多个源站ip,可表述为如:[1.1.1.1,2.2.2.2] + - **OriginPort** (int) - 回源端口 + - **OriginProtocol** (str) - 源站协议http,http|https 默认http + - **ReferList** (list) - Refer列表,支持正则表达式 + - **ReferStatus** (bool) - refer配置开关,true打开,false关闭 + - **ReferType** (int) - 0白名单,1黑名单 + - **Status** (str) - 创建的加速域名的当前的状态。check代表审核中,checkSuccess代表审核通过,checkFail代表审核失败,enable代表加速中,disable代表停止加速,delete代表删除加速 enableing代表正在开启加速,disableing代表正在停止加速中,deleteing代表删除中 + - **Tag** (str) - 业务组,默认为Default + - **TestUrl** (str) - 测试url,用于域名创建加速时的测试 + - **ValidTime** (int) - 开始分配Cname时间。格式:时间戳 + + """ + # build request + d = {"ProjectId": self.config.project_id} + req and d.update(req) + d = apis.BatchDescribeNewUcdnDomainRequestSchema().dumps(d) + + resp = self.invoke("BatchDescribeNewUcdnDomain", d, **kwargs) + return apis.BatchDescribeNewUcdnDomainResponseSchema().loads(resp) + + def describe_new_ucdn_prefetch_cache_task( + self, req: typing.Optional[dict] = None, **kwargs + ) -> dict: + """ DescribeNewUcdnPrefetchCacheTask - 获取预取任务状态 + + **Request** + + - **ProjectId** (str) - (Config) 项目ID。不填写为默认项目,子帐号必须填写。 请参考 `GetProjectList接口 `_ + - **BeginTime** (int) - 查询的起始时间,格式为Unix Timestamp。如果有EndTime,BeginTime必须赋值 + - **EndTime** (int) - 查询的结束时间,格式为Unix Timestamp。EndTime默认为当前时间,BeginTime默认为当前时间前一天时间。 + - **Limit** (int) - 返回数据长度,默认全部,自然数 + - **Offset** (int) - 数据偏移量,默认为0,自然数 + - **Status** (str) - 需要获取的内容预热的状态,枚举值:success:成功;wait:等待处理;process:正在处理;failure:失败; unknow:未知,默认选择所有状态 + - **TaskId** (list) - 提交任务时返回的任务ID + + **Response** + + - **TaskList** (list) - 见 **TaskInfo** 模型定义 + - **TotalCount** (int) - 预热任务的总数 + + **Response Model** + + **UrlProgressInfo** + + - **CreateTime** (int) - 刷新任务创建的时间。格式为Unix Timestamp + - **FinishTime** (int) - 任务完成时间。格式为Unix Timestamp + - **Progress** (int) - 刷新进度,单位% + - **Status** (str) - 刷新任务的当前状态,枚举值:success:成功;wait:排队中;process:处理中;failure:失败; unknow:未知 + - **Url** (str) - 刷新的单条url + + **TaskInfo** + + - **CreateTime** (int) - 刷新任务创建的时间。格式为Unix Timestamp + - **Status** (str) - 刷新任务的当前状态,枚举值:success:成功;wait:排队中;process:处理中;failure:失败; unknow:未知 + - **TaskId** (str) - 提交任务时返回的任务ID + - **Type** (str) - file/dir 刷新任务会返回Type,预取任务没有 + - **UrlLists** (list) - 见 **UrlProgressInfo** 模型定义 + + """ + # build request + d = {"ProjectId": self.config.project_id} + req and d.update(req) + d = apis.DescribeNewUcdnPrefetchCacheTaskRequestSchema().dumps(d) + + resp = self.invoke("DescribeNewUcdnPrefetchCacheTask", d, **kwargs) + return apis.DescribeNewUcdnPrefetchCacheTaskResponseSchema().loads(resp) + + def describe_new_ucdn_refresh_cache_task( + self, req: typing.Optional[dict] = None, **kwargs + ) -> dict: + """ DescribeNewUcdnRefreshCacheTask - 获取域名刷新任务状态 + + **Request** + + - **ProjectId** (str) - (Config) 项目ID。不填写为默认项目,子帐号必须填写。 请参考 `GetProjectList接口 `_ + - **BeginTime** (int) - 查询的起始时间,格式为Unix Timestamp。如果有EndTime,BeginTime必须赋值 + - **EndTime** (int) - 查询的结束时间,格式为Unix Timestamp。EndTime默认为当前时间,BeginTime默认为当前时间前一天时间。 + - **Limit** (int) - 返回数据长度,默认全部,自然数 + - **Offset** (int) - 数据偏移量,默认为0,自然数 + - **Status** (str) - 需要获取的内容刷新的状态,枚举值:success:成功;wait:等待处理;process:正在处理;failure:失败; unknow:未知,默认选择所有状态 + - **TaskId** (list) - 提交任务时返回的任务ID + + **Response** + + - **TaskList** (list) - 见 **TaskInfo** 模型定义 + - **TotalCount** (int) - 刷新任务的总数 + + **Response Model** + + **UrlProgressInfo** + + - **CreateTime** (int) - 刷新任务创建的时间。格式为Unix Timestamp + - **FinishTime** (int) - 任务完成时间。格式为Unix Timestamp + - **Progress** (int) - 刷新进度,单位% + - **Status** (str) - 刷新任务的当前状态,枚举值:success:成功;wait:排队中;process:处理中;failure:失败; unknow:未知 + - **Url** (str) - 刷新的单条url + + **TaskInfo** + + - **CreateTime** (int) - 刷新任务创建的时间。格式为Unix Timestamp + - **Status** (str) - 刷新任务的当前状态,枚举值:success:成功;wait:排队中;process:处理中;failure:失败; unknow:未知 + - **TaskId** (str) - 提交任务时返回的任务ID + - **Type** (str) - file/dir 刷新任务会返回Type,预取任务没有 + - **UrlLists** (list) - 见 **UrlProgressInfo** 模型定义 + + """ + # build request + d = {"ProjectId": self.config.project_id} + req and d.update(req) + d = apis.DescribeNewUcdnRefreshCacheTaskRequestSchema().dumps(d) + + resp = self.invoke("DescribeNewUcdnRefreshCacheTask", d, **kwargs) + return apis.DescribeNewUcdnRefreshCacheTaskResponseSchema().loads(resp) + + def get_new_ucdn_domain_bandwidth( + self, req: typing.Optional[dict] = None, **kwargs + ) -> dict: + """ GetNewUcdnDomainBandwidth - 获取域名带宽数据 + + **Request** + + - **ProjectId** (str) - (Config) 项目ID。不填写为默认项目,子帐号必须填写。 请参考 `GetProjectList接口 `_ + - **Type** (int) - (Required) 时间粒度(0表示按照5分钟粒度,1表示按照1小时粒度,2表示按照一天的粒度) + - **Areacode** (str) - 查询带宽区域 cn代表国内 abroad代表海外 不填默认为全部区域 + - **BeginTime** (int) - 查询的起始时间,格式为Unix Timestamp。如果有EndTime,BeginTime必须赋值。如没有赋值,则返回缺少参 数错误,如果没有EndTime,BeginTime也可以不赋值,EndTime默认当前时间,BeginTime 默认前一天的当前时间。 + - **DomainId** (list) - 域名id,创建域名时生成的id。默认全部域名 + - **EndTime** (int) - 查询的结束时间,格式为Unix Timestamp。EndTime默认为当前时间,BeginTime默认为当前时间前一天时间。 + + **Response** + + - **BandwidthList** (list) - 见 **BandwidthInfo** 模型定义 + - **Traffic** (str) - 从起始时间到结束时间内的所使用的CDN总流量,单位GB + + **Response Model** + + **BandwidthInfo** + + - **CdnBandwidth** (str) - 返回值返回指定时间区间内CDN的带宽峰值,单位Mbps(如果请求参数Type为0,则Value是五分钟粒度的带宽值,如果Type为1,则Value是1小时的带宽峰值,如果Type为2,则Value是一天内的带宽峰值) + - **Time** (int) - 带宽获取的时间点。格式:时间戳 + + """ + # build request + d = {"ProjectId": self.config.project_id} + req and d.update(req) + d = apis.GetNewUcdnDomainBandwidthRequestSchema().dumps(d) + + resp = self.invoke("GetNewUcdnDomainBandwidth", d, **kwargs) + return apis.GetNewUcdnDomainBandwidthResponseSchema().loads(resp) + + def get_new_ucdn_domain_hit_rate( + self, req: typing.Optional[dict] = None, **kwargs + ) -> dict: + """ GetNewUcdnDomainHitRate - 获取域名命中率 + + **Request** + + - **ProjectId** (str) - (Config) 项目ID。不填写为默认项目,子帐号必须填写。 请参考 `GetProjectList接口 `_ + - **Type** (int) - (Required) 时间粒度(0表示按照5分钟粒度,1表示按照1小时粒度,2表示按照一天的粒度) + - **Areacode** (str) - 查询带宽区域 cn代表国内 abroad代表海外,只支持国内 + - **BeginTime** (int) - 查询的起始时间,格式为Unix Timestamp。如果有EndTime,BeginTime必须赋值。如没有赋值,则返回缺少参 数错误,如果没有EndTime,BeginTime也可以不赋值,EndTime默认当前时间,BeginTime 默认前一天的当前时间。 + - **DomainId** (list) - 域名id,创建域名时生成的id。默认全部域名 + - **EndTime** (int) - 查询的结束时间,格式为Unix Timestamp。EndTime默认为当前时间,BeginTime默认为当前时间前一天时间。 + + **Response** + + - **HitRateList** (list) - 见 **HitRateInfo** 模型定义 + + **Response Model** + + **HitRateInfo** + + - **FlowHitRate** (float) - 流量命中率,单位% + - **RequestHitRate** (float) - 请求数命中率,单位% + - **Time** (int) - 带宽获取的时间点。格式:时间戳 + + """ + # build request + d = {"ProjectId": self.config.project_id} + req and d.update(req) + d = apis.GetNewUcdnDomainHitRateRequestSchema().dumps(d) + + resp = self.invoke("GetNewUcdnDomainHitRate", d, **kwargs) + return apis.GetNewUcdnDomainHitRateResponseSchema().loads(resp) + + def get_new_ucdn_domain_http_code( + self, req: typing.Optional[dict] = None, **kwargs + ) -> dict: + """ GetNewUcdnDomainHttpCode - 获取域名状态码监控 + + **Request** + + - **ProjectId** (str) - (Config) 项目ID。不填写为默认项目,子帐号必须填写。 请参考 `GetProjectList接口 `_ + - **Type** (int) - (Required) 时间粒度(0表示按照5分钟粒度,1表示按照1小时粒度,2表示按照一天的粒度) + - **Areacode** (str) - 查询带宽区域 cn代表国内 abroad代表海外,只支持国内 + - **BeginTime** (int) - 查询的起始时间,格式为Unix Timestamp。如果有EndTime,BeginTime必须赋值。如没有赋值,则返回缺少参 数错误,如果没有EndTime,BeginTime也可以不赋值,EndTime默认当前时间,BeginTime 默认前一天的当前时间。 + - **DomainId** (list) - 域名id,创建域名时生成的id。默认全部域名 + - **EndTime** (int) - 查询的结束时间,格式为Unix Timestamp。EndTime默认为当前时间,BeginTime默认为当前时间前一天时间。 + + **Response** + + - **HttpCodeDetail** (list) - 见 **HttpCodeInfo** 模型定义 + + **Response Model** + + **HttpCodeInfo** + + - **HttpFiveXX** (int) - 5xx数量 + - **HttpFourXX** (int) - 4xx数量 + - **HttpOneXX** (int) - 1xx数量 + - **HttpThreeXX** (int) - 3xx数量 + - **HttpTwoXX** (int) - 2xx数量 + - **Time** (int) - 带宽获取的时间点。格式:时间戳 + + """ + # build request + d = {"ProjectId": self.config.project_id} + req and d.update(req) + d = apis.GetNewUcdnDomainHttpCodeRequestSchema().dumps(d) + + resp = self.invoke("GetNewUcdnDomainHttpCode", d, **kwargs) + return apis.GetNewUcdnDomainHttpCodeResponseSchema().loads(resp) + + def get_new_ucdn_domain_http_code_v2( + self, req: typing.Optional[dict] = None, **kwargs + ) -> dict: + """ GetNewUcdnDomainHttpCodeV2 - 获取域名详细状态码监控 + + **Request** + + - **ProjectId** (str) - (Config) 项目ID。不填写为默认项目,子帐号必须填写。 请参考 `GetProjectList接口 `_ + - **BeginTime** (int) - (Required) 查询的起始时间,格式为Unix Timestamp。 + - **EndTime** (int) - (Required) 查询的结束时间,格式为Unix Timestamp。 + - **Type** (int) - (Required) 时间粒度(0表示按照5分钟粒度,1表示按照1小时粒度,2表示按照一天粒度,3表示按照一分钟粒度) + - **Areacode** (str) - 查询带宽区域 cn代表国内 abroad代表海外,只支持国内 + - **DomainId** (list) - 域名id,创建域名时生成的id。默认全部域名 + + **Response** + + - **HttpCodeV2Detail** (list) - 见 **HttpCodeV2Detail** 模型定义 + + **Response Model** + + **HttpCodeV2Detail** + + - **Http100** (int) - http100数量 + - **Http101** (int) - http101数量 + - **Http102** (int) - http102数量 + - **Http200** (int) - http200数量 + - **Http201** (int) - http201数量 + - **Http202** (int) - http202数量 + - **Http203** (int) - http203数量 + - **Http204** (int) - http204数量 + - **Http205** (int) - http205数量 + - **Http206** (int) - http206数量 + - **Http207** (int) - http207数量 + - **Http300** (int) - http300数量 + - **Http301** (int) - http301数量 + - **Http302** (int) - http302数量 + - **Http303** (int) - http303数量 + - **Http304** (int) - http304数量 + - **Http305** (int) - http305数量 + - **Http306** (int) - http306数量 + - **Http307** (int) - http307数量 + - **Http400** (int) - http400数量 + - **Http401** (int) - http401数量 + - **Http402** (int) - http402数量 + - **Http403** (int) - http403数量 + - **Http404** (int) - http404数量 + - **Http405** (int) - http405数量 + - **Http406** (int) - http406数量 + - **Http407** (int) - http407数量 + - **Http408** (int) - http408数量 + - **Http409** (int) - http409数量 + - **Http410** (int) - http410数量 + - **Http411** (int) - http411数量 + - **Http412** (int) - http412数量 + - **Http413** (int) - http413数量 + - **Http414** (int) - http414数量 + - **Http415** (int) - http415数量 + - **Http416** (int) - http416数量 + - **Http417** (int) - http417数量 + - **Http418** (int) - http418数量 + - **Http421** (int) - http421数量 + - **Http422** (int) - http422数量 + - **Http423** (int) - http423数量 + - **Http424** (int) - http424数量 + - **Http425** (int) - http425数量 + - **Http426** (int) - http426数量 + - **Http449** (int) - http449数量 + - **Http451** (int) - http451数量 + - **Http500** (int) - http500数量 + - **Http501** (int) - http501数量 + - **Http502** (int) - http502数量 + - **Http503** (int) - http503数量 + - **Http504** (int) - http504数量 + - **Http505** (int) - http505数量 + - **Http506** (int) - http506数量 + - **Http507** (int) - http507数量 + - **Http509** (int) - http509数量 + - **Http510** (int) - http510数量 + - **Time** (int) - 时间 + + """ + # build request + d = {"ProjectId": self.config.project_id} + req and d.update(req) + d = apis.GetNewUcdnDomainHttpCodeV2RequestSchema().dumps(d) + + resp = self.invoke("GetNewUcdnDomainHttpCodeV2", d, **kwargs) + return apis.GetNewUcdnDomainHttpCodeV2ResponseSchema().loads(resp) + + def get_new_ucdn_domain_request_num( + self, req: typing.Optional[dict] = None, **kwargs + ) -> dict: + """ GetNewUcdnDomainRequestNum - 获取域名请求数 + + **Request** + + - **ProjectId** (str) - (Config) 项目ID。不填写为默认项目,子帐号必须填写。 请参考 `GetProjectList接口 `_ + - **Type** (int) - (Required) 时间粒度(0表示按照5分钟粒度,1表示按照1小时粒度,2表示按照一天的粒度) + - **Areacode** (str) - 查询区域 cn代表国内 abroad代表海外,只支持国内 + - **BeginTime** (int) - 查询的起始时间,格式为Unix Timestamp。如果有EndTime,BeginTime必须赋值。如没有赋值,则返回缺少参 数错误,如果没有EndTime,BeginTime也可以不赋值,EndTime默认当前时间,BeginTime 默认前一天的当前时间。 + - **DomainId** (list) - 域名id,创建域名时生成的id。默认全部域名 + - **EndTime** (int) - 查询的结束时间,格式为Unix Timestamp。EndTime默认为当前时间,BeginTime默认为当前时间前一天时间。 + + **Response** + + - **RequestList** (list) - 见 **RequestInfo** 模型定义 + + **Response Model** + + **RequestInfo** + + - **CdnRequest** (float) - 返回值返回指定时间区间内的cdn收到的请求次数之和 + - **OriginRequest** (float) - 返回值返回指定时间区间内的cdn回源的请求次数之和 + - **Time** (int) - 带宽获取的时间点。格式:时间戳 + + """ + # build request + d = {"ProjectId": self.config.project_id} + req and d.update(req) + d = apis.GetNewUcdnDomainRequestNumRequestSchema().dumps(d) + + resp = self.invoke("GetNewUcdnDomainRequestNum", d, **kwargs) + return apis.GetNewUcdnDomainRequestNumResponseSchema().loads(resp) + + def get_ucdn_domain_log( + self, req: typing.Optional[dict] = None, **kwargs + ) -> dict: + """ GetUcdnDomainLog - 获取加速域名原始日志 + + **Request** + + - **ProjectId** (str) - (Config) 项目ID。不填写为默认项目,子帐号必须填写。 请参考 `GetProjectList接口 `_ + - **BeginTime** (int) - 查询的起始时间,格式为Unix Timestamp。如果有EndTime,BeginTime必须赋值。 + - **DomainId** (list) - 域名ID,创建加速域名时生成。默认全部域名 + - **EndTime** (int) - 查询的结束时间,格式为Unix Timestamp。EndTime默认为当前时间,BeginTime默认为当前时间前一天时间。 + - **Type** (int) - 查询粒度 0=default(没有粒度) 1=按小时 2=按天 + + **Response** + + - **LogSet** (list) - 见 **LogSetList** 模型定义 + + **Response Model** + + **LogSetInfo** + + - **AbroadLog** (list) - 国外日志url列表 + - **CnLog** (list) - 国内日志url列表 + - **Time** (int) - 日志时间UnixTime + + **LogSetList** + + - **Domain** (str) - 域名 + - **Logs** (list) - 见 **LogSetInfo** 模型定义 + + """ + # build request + d = {"ProjectId": self.config.project_id} + req and d.update(req) + d = apis.GetUcdnDomainLogRequestSchema().dumps(d) + + resp = self.invoke("GetUcdnDomainLog", d, **kwargs) + return apis.GetUcdnDomainLogResponseSchema().loads(resp) + + def get_ucdn_domain_prefetch_enable( + self, req: typing.Optional[dict] = None, **kwargs + ) -> dict: + """ GetUcdnDomainPrefetchEnable - 获取域名预取开启状态 + + **Request** + + - **ProjectId** (str) - (Config) 项目ID。不填写为默认项目,子帐号必须填写。 请参考 `GetProjectList接口 `_ + - **DomainId** (str) - (Required) 域名ID,创建加速域名时生成。 + + **Response** + + - **Enable** (int) - 0表示该域名未开启预取,1表示该域名已开启预取 + + """ + # build request + d = {"ProjectId": self.config.project_id} + req and d.update(req) + d = apis.GetUcdnDomainPrefetchEnableRequestSchema().dumps(d) + + resp = self.invoke("GetUcdnDomainPrefetchEnable", d, **kwargs) + return apis.GetUcdnDomainPrefetchEnableResponseSchema().loads(resp) + + def get_ucdn_domain_request_num_v2( + self, req: typing.Optional[dict] = None, **kwargs + ) -> dict: + """ GetUcdnDomainRequestNumV2 - 获取域名请求数 + + **Request** + + - **ProjectId** (str) - (Config) 项目ID。不填写为默认项目,子帐号必须填写。 请参考 `GetProjectList接口 `_ + - **BeginTime** (int) - (Required) 查询的起始时间,格式为Unix Timestamp + - **EndTime** (int) - (Required) 查询的结束时间,格式为Unix Timestamp + - **Type** (int) - (Required) 时间粒度(0表示按照5分钟粒度,1表示按照1小时粒度,2表示按照一天的粒度, 3=按1分钟) + - **Areacode** (str) - 查询区域 cn代表国内 abroad代表海外,只支持国内 + - **DomainId** (list) - 域名id,创建域名时生成的id。默认全部域名 + + **Response** + + - **RequestList** (list) - 见 **RequestInfo** 模型定义 + + **Response Model** + + **RequestInfo** + + - **CdnRequest** (float) - 返回值返回指定时间区间内的cdn收到的请求次数之和 + - **OriginRequest** (float) - 返回值返回指定时间区间内的cdn回源的请求次数之和 + - **Time** (int) - 带宽获取的时间点。格式:时间戳 + + """ + # build request + d = {"ProjectId": self.config.project_id} + req and d.update(req) + d = apis.GetUcdnDomainRequestNumV2RequestSchema().dumps(d) + + resp = self.invoke("GetUcdnDomainRequestNumV2", d, **kwargs) + return apis.GetUcdnDomainRequestNumV2ResponseSchema().loads(resp) + + def get_ucdn_domain_traffic( + self, req: typing.Optional[dict] = None, **kwargs + ) -> dict: + """ GetUcdnDomainTraffic - 获取加速域名流量使用信息 + + **Request** + + - **ProjectId** (str) - (Config) 项目ID。不填写为默认项目,子帐号必须填写。 请参考 `GetProjectList接口 `_ + - **Areacode** (str) - 查询流量区域 cn代表国内 abroad代表海外,默认全部区域。 + - **BeginTime** (int) - 查询的起始时间,格式为Unix Timestamp。如果有EndTime,BeginTime必须赋值。 + - **DomainId** (list) - 域名ID,创建加速域名时生成。默认全部域名 + - **EndTime** (int) - 查询的结束时间,格式为Unix Timestamp。EndTime默认为当前时间,BeginTime默认为当前时间前一天时间。 + + **Response** + + - **TrafficSet** (list) - 见 **UcdnDomainTrafficSet** 模型定义 + + **Response Model** + + **UcdnDomainTrafficSet** + + - **Time** (int) - 流量获取的时间点,格式为Unix Timestamp + - **Value** (float) - 查询每日流量总值,单位:GB + + """ + # build request + d = {"ProjectId": self.config.project_id} + req and d.update(req) + d = apis.GetUcdnDomainTrafficRequestSchema().dumps(d) + + resp = self.invoke("GetUcdnDomainTraffic", d, **kwargs) + return apis.GetUcdnDomainTrafficResponseSchema().loads(resp) + + def get_ucdn_pass_bandwidth( + self, req: typing.Optional[dict] = None, **kwargs + ) -> dict: + """ GetUcdnPassBandwidth - 获取回源带宽数据(cdn回客户源站部分) + + **Request** + + - **ProjectId** (str) - (Config) 项目ID。不填写为默认项目,子帐号必须填写。 请参考 `GetProjectList接口 `_ + - **Type** (int) - (Required) 时间粒度(0表示按照5分钟粒度,1表示按照1小时粒度,2表示按照一天的粒度) + - **Areacode** (str) - 查询带宽区域 cn代表国内 abroad代表海外,只支持国内 + - **BeginTime** (int) - 查询的起始时间,格式为Unix Timestamp。如果有EndTime,BeginTime必须赋值。如没有赋值,则返回缺少参 数错误,如果没有EndTime,BeginTime也可以不赋值,EndTime默认当前时间,BeginTime 默认前一天的当前时间。 + - **DomainId** (list) - 域名id,创建域名时生成的id。默认全部域名 + - **EndTime** (int) - 查询的结束时间,格式为Unix Timestamp。EndTime默认为当前时间,BeginTime默认为当前时间前一天时间。 + + **Response** + + - **BandwidthDetail** (list) - 见 **BandwidthInfoDetail** 模型定义 + + **Response Model** + + **BandwidthInfoDetail** + + - **Bandwidth** (float) - 返回值带宽值数据。 + - **Time** (int) - 宽获取的时间点。格式:时间戳 + + """ + # build request + d = {"ProjectId": self.config.project_id} + req and d.update(req) + d = apis.GetUcdnPassBandwidthRequestSchema().dumps(d) + + resp = self.invoke("GetUcdnPassBandwidth", d, **kwargs) + return apis.GetUcdnPassBandwidthResponseSchema().loads(resp) + + def get_ucdn_traffic( + self, req: typing.Optional[dict] = None, **kwargs + ) -> dict: + """ GetUcdnTraffic - 获取流量信息 + + **Request** + + - **ProjectId** (str) - (Config) 项目ID。不填写为默认项目,子帐号必须填写。 请参考 `GetProjectList接口 `_ + + **Response** + + - **TrafficSet** (list) - 见 **TrafficSet** 模型定义 + + **Response Model** + + **TrafficSet** + + - **Areacode** (str) - 购买流量的区域, cn: 国内; abroad: 国外 + - **TrafficLeft** (str) - Areacode区域内总剩余流量, 单位GB + - **TrafficTotal** (str) - Areacode区域内总购买流量, 单位GB + - **TrafficUsed** (str) - Areacode区域内总使用流量, 单位GB + + """ + # build request + d = {"ProjectId": self.config.project_id} + req and d.update(req) + d = apis.GetUcdnTrafficRequestSchema().dumps(d) + + resp = self.invoke("GetUcdnTraffic", d, **kwargs) + return apis.GetUcdnTrafficResponseSchema().loads(resp) + + def prefetch_new_ucdn_domain_cache( + self, req: typing.Optional[dict] = None, **kwargs + ) -> dict: + """ PrefetchNewUcdnDomainCache - 提交预取任务 + + **Request** + + - **ProjectId** (str) - (Config) 项目ID。不填写为默认项目,子帐号必须填写。 请参考 `GetProjectList接口 `_ + - **UrlList** (list) - (Required) 预热URL列表,n从自然数0开始。UrlList.n字段必须以”http://域名/”开始。目录要以”/”结尾, 如刷新目录a下所有文件,格式为:http://abc.ucloud.cn/a/;如刷新文件目录a下面img.png文件, 格式为http://abc.ucloud.cn/a/img.png。请正确提交需要刷新的域名 + + **Response** + + - **TaskId** (str) - 本次提交url对应的任务id + + """ + # build request + d = {"ProjectId": self.config.project_id} + req and d.update(req) + d = apis.PrefetchNewUcdnDomainCacheRequestSchema().dumps(d) + + resp = self.invoke("PrefetchNewUcdnDomainCache", d, **kwargs) + return apis.PrefetchNewUcdnDomainCacheResponseSchema().loads(resp) + + def refresh_new_ucdn_domain_cache( + self, req: typing.Optional[dict] = None, **kwargs + ) -> dict: + """ RefreshNewUcdnDomainCache - 刷新缓存 + + **Request** + + - **ProjectId** (str) - (Config) 项目ID。不填写为默认项目,子帐号必须填写。 请参考 `GetProjectList接口 `_ + - **Type** (str) - (Required) 刷新类型,file代表文件刷新,dir 代表路径刷新 + - **UrlList** (list) - (Required) 刷新多个URL列表时,一次最多提交30个。必须以”http://域名/”开始。目录要以”/”结尾, 如刷新目录a下所有文件,格式为:http://abc.ucloud.cn/a/;如刷新文件目录a下面img.png文件, 格式为http://abc.ucloud.cn/a/img.png。请正确提交需要刷新的域名 + + **Response** + + - **TaskId** (str) - 本次提交url对应的任务id + + """ + # build request + d = {"ProjectId": self.config.project_id} + req and d.update(req) + d = apis.RefreshNewUcdnDomainCacheRequestSchema().dumps(d) + + resp = self.invoke("RefreshNewUcdnDomainCache", d, **kwargs) + return apis.RefreshNewUcdnDomainCacheResponseSchema().loads(resp) + + def switch_ucdn_charge_type( + self, req: typing.Optional[dict] = None, **kwargs + ) -> dict: + """ SwitchUcdnChargeType - 切换账号计费方式 + + **Request** + + - **ProjectId** (str) - (Config) 项目ID。不填写为默认项目,子帐号必须填写。 请参考 `GetProjectList接口 `_ + - **ChargeType** (str) - (Required) 计费方式。traffic代表按流量包计费,bandwidth按带宽付费 + + **Response** + + + """ + # build request + d = {"ProjectId": self.config.project_id} + req and d.update(req) + d = apis.SwitchUcdnChargeTypeRequestSchema().dumps(d) + + resp = self.invoke("SwitchUcdnChargeType", d, **kwargs) + return apis.SwitchUcdnChargeTypeResponseSchema().loads(resp) diff --git a/ucloud/services/ucdn/schemas/__init__.py b/ucloud/services/ucdn/schemas/__init__.py new file mode 100644 index 00000000..e69de29b diff --git a/ucloud/services/ucdn/schemas/apis.py b/ucloud/services/ucdn/schemas/apis.py new file mode 100644 index 00000000..5be59d6e --- /dev/null +++ b/ucloud/services/ucdn/schemas/apis.py @@ -0,0 +1,536 @@ +""" Code is generated by ucloud-model, DO NOT EDIT IT. """ + +from ucloud.core.typesystem import schema, fields +from ucloud.services.ucdn.schemas import models + + +""" UCDN API Schema +""" + + +""" +API: BatchDescribeNewUcdnDomain + +批量获取加速域名配置 +""" + + +class BatchDescribeNewUcdnDomainRequestSchema(schema.RequestSchema): + """ BatchDescribeNewUcdnDomain - 批量获取加速域名配置 + """ + + fields = { + "ChannelType": fields.Str(required=False, dump_to="ChannelType"), + "DomainId": fields.List(fields.Str()), + "Limit": fields.Int(required=False, dump_to="Limit"), + "Offset": fields.Int(required=False, dump_to="Offset"), + "ProjectId": fields.Str(required=False, dump_to="ProjectId"), + } + + +class BatchDescribeNewUcdnDomainResponseSchema(schema.ResponseSchema): + """ BatchDescribeNewUcdnDomain - 批量获取加速域名配置 + """ + + fields = { + "Arrearage": fields.List( + fields.Str(), required=False, load_from="Arrearage" + ), + "ChargeType": fields.Int(required=False, load_from="ChargeType"), + "DomainList": fields.List( + models.DomainInfoSchema(), required=False, load_from="DomainList" + ), + "LastChargeType": fields.Int( + required=False, load_from="LastChargeType" + ), + "MaxDomainNum": fields.Int(required=False, load_from="MaxDomainNum"), + "TotalCount": fields.Int(required=False, load_from="TotalCount"), + "Vip": fields.Str(required=False, load_from="Vip"), + } + + +""" +API: DescribeNewUcdnPrefetchCacheTask + +获取预取任务状态 +""" + + +class DescribeNewUcdnPrefetchCacheTaskRequestSchema(schema.RequestSchema): + """ DescribeNewUcdnPrefetchCacheTask - 获取预取任务状态 + """ + + fields = { + "BeginTime": fields.Int(required=False, dump_to="BeginTime"), + "EndTime": fields.Int(required=False, dump_to="EndTime"), + "Limit": fields.Int(required=False, dump_to="Limit"), + "Offset": fields.Int(required=False, dump_to="Offset"), + "ProjectId": fields.Str(required=False, dump_to="ProjectId"), + "Status": fields.Str(required=False, dump_to="Status"), + "TaskId": fields.List(fields.Str()), + } + + +class DescribeNewUcdnPrefetchCacheTaskResponseSchema(schema.ResponseSchema): + """ DescribeNewUcdnPrefetchCacheTask - 获取预取任务状态 + """ + + fields = { + "TaskList": fields.List( + models.TaskInfoSchema(), required=False, load_from="TaskList" + ), + "TotalCount": fields.Int(required=False, load_from="TotalCount"), + } + + +""" +API: DescribeNewUcdnRefreshCacheTask + +获取域名刷新任务状态 +""" + + +class DescribeNewUcdnRefreshCacheTaskRequestSchema(schema.RequestSchema): + """ DescribeNewUcdnRefreshCacheTask - 获取域名刷新任务状态 + """ + + fields = { + "BeginTime": fields.Int(required=False, dump_to="BeginTime"), + "EndTime": fields.Int(required=False, dump_to="EndTime"), + "Limit": fields.Int(required=False, dump_to="Limit"), + "Offset": fields.Int(required=False, dump_to="Offset"), + "ProjectId": fields.Str(required=False, dump_to="ProjectId"), + "Status": fields.Str(required=False, dump_to="Status"), + "TaskId": fields.List(fields.Str()), + } + + +class DescribeNewUcdnRefreshCacheTaskResponseSchema(schema.ResponseSchema): + """ DescribeNewUcdnRefreshCacheTask - 获取域名刷新任务状态 + """ + + fields = { + "TaskList": fields.List( + models.TaskInfoSchema(), required=False, load_from="TaskList" + ), + "TotalCount": fields.Int(required=False, load_from="TotalCount"), + } + + +""" +API: GetNewUcdnDomainBandwidth + +获取域名带宽数据 +""" + + +class GetNewUcdnDomainBandwidthRequestSchema(schema.RequestSchema): + """ GetNewUcdnDomainBandwidth - 获取域名带宽数据 + """ + + fields = { + "Areacode": fields.Str(required=False, dump_to="Areacode"), + "BeginTime": fields.Int(required=False, dump_to="BeginTime"), + "DomainId": fields.List(fields.Str()), + "EndTime": fields.Int(required=False, dump_to="EndTime"), + "ProjectId": fields.Str(required=False, dump_to="ProjectId"), + "Type": fields.Int(required=True, dump_to="Type"), + } + + +class GetNewUcdnDomainBandwidthResponseSchema(schema.ResponseSchema): + """ GetNewUcdnDomainBandwidth - 获取域名带宽数据 + """ + + fields = { + "BandwidthList": fields.List( + models.BandwidthInfoSchema(), + required=False, + load_from="BandwidthList", + ), + "Traffic": fields.Str(required=False, load_from="Traffic"), + } + + +""" +API: GetNewUcdnDomainHitRate + +获取域名命中率 +""" + + +class GetNewUcdnDomainHitRateRequestSchema(schema.RequestSchema): + """ GetNewUcdnDomainHitRate - 获取域名命中率 + """ + + fields = { + "Areacode": fields.Str(required=False, dump_to="Areacode"), + "BeginTime": fields.Int(required=False, dump_to="BeginTime"), + "DomainId": fields.List(fields.Str()), + "EndTime": fields.Int(required=False, dump_to="EndTime"), + "ProjectId": fields.Str(required=False, dump_to="ProjectId"), + "Type": fields.Int(required=True, dump_to="Type"), + } + + +class GetNewUcdnDomainHitRateResponseSchema(schema.ResponseSchema): + """ GetNewUcdnDomainHitRate - 获取域名命中率 + """ + + fields = { + "HitRateList": fields.List( + models.HitRateInfoSchema(), required=False, load_from="HitRateList" + ) + } + + +""" +API: GetNewUcdnDomainHttpCode + +获取域名状态码监控 +""" + + +class GetNewUcdnDomainHttpCodeRequestSchema(schema.RequestSchema): + """ GetNewUcdnDomainHttpCode - 获取域名状态码监控 + """ + + fields = { + "Areacode": fields.Str(required=False, dump_to="Areacode"), + "BeginTime": fields.Int(required=False, dump_to="BeginTime"), + "DomainId": fields.List(fields.Str()), + "EndTime": fields.Int(required=False, dump_to="EndTime"), + "ProjectId": fields.Str(required=False, dump_to="ProjectId"), + "Type": fields.Int(required=True, dump_to="Type"), + } + + +class GetNewUcdnDomainHttpCodeResponseSchema(schema.ResponseSchema): + """ GetNewUcdnDomainHttpCode - 获取域名状态码监控 + """ + + fields = { + "HttpCodeDetail": fields.List( + models.HttpCodeInfoSchema(), + required=False, + load_from="HttpCodeDetail", + ) + } + + +""" +API: GetNewUcdnDomainHttpCodeV2 + +获取域名详细状态码监控 +""" + + +class GetNewUcdnDomainHttpCodeV2RequestSchema(schema.RequestSchema): + """ GetNewUcdnDomainHttpCodeV2 - 获取域名详细状态码监控 + """ + + fields = { + "Areacode": fields.Str(required=False, dump_to="Areacode"), + "BeginTime": fields.Int(required=True, dump_to="BeginTime"), + "DomainId": fields.List(fields.Str()), + "EndTime": fields.Int(required=True, dump_to="EndTime"), + "ProjectId": fields.Str(required=False, dump_to="ProjectId"), + "Type": fields.Int(required=True, dump_to="Type"), + } + + +class GetNewUcdnDomainHttpCodeV2ResponseSchema(schema.ResponseSchema): + """ GetNewUcdnDomainHttpCodeV2 - 获取域名详细状态码监控 + """ + + fields = { + "HttpCodeV2Detail": fields.List( + models.HttpCodeV2DetailSchema(), + required=False, + load_from="HttpCodeV2Detail", + ) + } + + +""" +API: GetNewUcdnDomainRequestNum + +获取域名请求数 +""" + + +class GetNewUcdnDomainRequestNumRequestSchema(schema.RequestSchema): + """ GetNewUcdnDomainRequestNum - 获取域名请求数 + """ + + fields = { + "Areacode": fields.Str(required=False, dump_to="Areacode"), + "BeginTime": fields.Int(required=False, dump_to="BeginTime"), + "DomainId": fields.List(fields.Str()), + "EndTime": fields.Int(required=False, dump_to="EndTime"), + "ProjectId": fields.Str(required=False, dump_to="ProjectId"), + "Type": fields.Int(required=True, dump_to="Type"), + } + + +class GetNewUcdnDomainRequestNumResponseSchema(schema.ResponseSchema): + """ GetNewUcdnDomainRequestNum - 获取域名请求数 + """ + + fields = { + "RequestList": fields.List( + models.RequestInfoSchema(), required=False, load_from="RequestList" + ) + } + + +""" +API: GetUcdnDomainLog + +获取加速域名原始日志 +""" + + +class GetUcdnDomainLogRequestSchema(schema.RequestSchema): + """ GetUcdnDomainLog - 获取加速域名原始日志 + """ + + fields = { + "BeginTime": fields.Int(required=False, dump_to="BeginTime"), + "DomainId": fields.List(fields.Str()), + "EndTime": fields.Int(required=False, dump_to="EndTime"), + "ProjectId": fields.Str(required=False, dump_to="ProjectId"), + "Type": fields.Int(required=False, dump_to="Type"), + } + + +class GetUcdnDomainLogResponseSchema(schema.ResponseSchema): + """ GetUcdnDomainLog - 获取加速域名原始日志 + """ + + fields = { + "LogSet": fields.List( + models.LogSetListSchema(), required=False, load_from="LogSet" + ) + } + + +""" +API: GetUcdnDomainPrefetchEnable + +获取域名预取开启状态 +""" + + +class GetUcdnDomainPrefetchEnableRequestSchema(schema.RequestSchema): + """ GetUcdnDomainPrefetchEnable - 获取域名预取开启状态 + """ + + fields = { + "DomainId": fields.Str(required=True, dump_to="DomainId"), + "ProjectId": fields.Str(required=False, dump_to="ProjectId"), + } + + +class GetUcdnDomainPrefetchEnableResponseSchema(schema.ResponseSchema): + """ GetUcdnDomainPrefetchEnable - 获取域名预取开启状态 + """ + + fields = {"Enable": fields.Int(required=False, load_from="Enable")} + + +""" +API: GetUcdnDomainRequestNumV2 + +获取域名请求数 +""" + + +class GetUcdnDomainRequestNumV2RequestSchema(schema.RequestSchema): + """ GetUcdnDomainRequestNumV2 - 获取域名请求数 + """ + + fields = { + "Areacode": fields.Str(required=False, dump_to="Areacode"), + "BeginTime": fields.Int(required=True, dump_to="BeginTime"), + "DomainId": fields.List(fields.Str()), + "EndTime": fields.Int(required=True, dump_to="EndTime"), + "ProjectId": fields.Str(required=False, dump_to="ProjectId"), + "Type": fields.Int(required=True, dump_to="Type"), + } + + +class GetUcdnDomainRequestNumV2ResponseSchema(schema.ResponseSchema): + """ GetUcdnDomainRequestNumV2 - 获取域名请求数 + """ + + fields = { + "RequestList": fields.List( + models.RequestInfoSchema(), required=False, load_from="RequestList" + ) + } + + +""" +API: GetUcdnDomainTraffic + +获取加速域名流量使用信息 +""" + + +class GetUcdnDomainTrafficRequestSchema(schema.RequestSchema): + """ GetUcdnDomainTraffic - 获取加速域名流量使用信息 + """ + + fields = { + "Areacode": fields.Str(required=False, dump_to="Areacode"), + "BeginTime": fields.Int(required=False, dump_to="BeginTime"), + "DomainId": fields.List(fields.Str()), + "EndTime": fields.Int(required=False, dump_to="EndTime"), + "ProjectId": fields.Str(required=False, dump_to="ProjectId"), + } + + +class GetUcdnDomainTrafficResponseSchema(schema.ResponseSchema): + """ GetUcdnDomainTraffic - 获取加速域名流量使用信息 + """ + + fields = { + "TrafficSet": fields.List( + models.UcdnDomainTrafficSetSchema(), + required=False, + load_from="TrafficSet", + ) + } + + +""" +API: GetUcdnPassBandwidth + +获取回源带宽数据(cdn回客户源站部分) +""" + + +class GetUcdnPassBandwidthRequestSchema(schema.RequestSchema): + """ GetUcdnPassBandwidth - 获取回源带宽数据(cdn回客户源站部分) + """ + + fields = { + "Areacode": fields.Str(required=False, dump_to="Areacode"), + "BeginTime": fields.Int(required=False, dump_to="BeginTime"), + "DomainId": fields.List(fields.Str()), + "EndTime": fields.Int(required=False, dump_to="EndTime"), + "ProjectId": fields.Str(required=False, dump_to="ProjectId"), + "Type": fields.Int(required=True, dump_to="Type"), + } + + +class GetUcdnPassBandwidthResponseSchema(schema.ResponseSchema): + """ GetUcdnPassBandwidth - 获取回源带宽数据(cdn回客户源站部分) + """ + + fields = { + "BandwidthDetail": fields.List( + models.BandwidthInfoDetailSchema(), + required=False, + load_from="BandwidthDetail", + ) + } + + +""" +API: GetUcdnTraffic + +获取流量信息 +""" + + +class GetUcdnTrafficRequestSchema(schema.RequestSchema): + """ GetUcdnTraffic - 获取流量信息 + """ + + fields = {"ProjectId": fields.Str(required=False, dump_to="ProjectId")} + + +class GetUcdnTrafficResponseSchema(schema.ResponseSchema): + """ GetUcdnTraffic - 获取流量信息 + """ + + fields = { + "TrafficSet": fields.List( + models.TrafficSetSchema(), required=False, load_from="TrafficSet" + ) + } + + +""" +API: PrefetchNewUcdnDomainCache + +提交预取任务 +""" + + +class PrefetchNewUcdnDomainCacheRequestSchema(schema.RequestSchema): + """ PrefetchNewUcdnDomainCache - 提交预取任务 + """ + + fields = { + "ProjectId": fields.Str(required=False, dump_to="ProjectId"), + "UrlList": fields.List(fields.Str()), + } + + +class PrefetchNewUcdnDomainCacheResponseSchema(schema.ResponseSchema): + """ PrefetchNewUcdnDomainCache - 提交预取任务 + """ + + fields = {"TaskId": fields.Str(required=False, load_from="TaskId")} + + +""" +API: RefreshNewUcdnDomainCache + +刷新缓存 +""" + + +class RefreshNewUcdnDomainCacheRequestSchema(schema.RequestSchema): + """ RefreshNewUcdnDomainCache - 刷新缓存 + """ + + fields = { + "ProjectId": fields.Str(required=False, dump_to="ProjectId"), + "Type": fields.Str(required=True, dump_to="Type"), + "UrlList": fields.List(fields.Str()), + } + + +class RefreshNewUcdnDomainCacheResponseSchema(schema.ResponseSchema): + """ RefreshNewUcdnDomainCache - 刷新缓存 + """ + + fields = {"TaskId": fields.Str(required=False, load_from="TaskId")} + + +""" +API: SwitchUcdnChargeType + +切换账号计费方式 +""" + + +class SwitchUcdnChargeTypeRequestSchema(schema.RequestSchema): + """ SwitchUcdnChargeType - 切换账号计费方式 + """ + + fields = { + "ChargeType": fields.Str(required=True, dump_to="ChargeType"), + "ProjectId": fields.Str(required=False, dump_to="ProjectId"), + } + + +class SwitchUcdnChargeTypeResponseSchema(schema.ResponseSchema): + """ SwitchUcdnChargeType - 切换账号计费方式 + """ + + fields = {} diff --git a/ucloud/services/ucdn/schemas/models.py b/ucloud/services/ucdn/schemas/models.py new file mode 100644 index 00000000..6ab893a1 --- /dev/null +++ b/ucloud/services/ucdn/schemas/models.py @@ -0,0 +1,265 @@ +""" Code is generated by ucloud-model, DO NOT EDIT IT. """ + +from ucloud.core.typesystem import schema, fields + + +class CacheConfSchema(schema.ResponseSchema): + """ CacheConf - 缓存配置 + """ + + fields = { + "CacheBehavior": fields.Bool(required=False, load_from="CacheBehavior"), + "CacheTTL": fields.Int(required=False, load_from="CacheTTL"), + "CacheUnit": fields.Str(required=False, load_from="CacheUnit"), + "Description": fields.Str(required=False, load_from="Description"), + "FollowOriginRule": fields.Bool( + required=False, load_from="FollowOriginRule" + ), + "HttpCodePattern": fields.Str( + required=False, load_from="HttpCodePattern" + ), + "IgnoreQueryString": fields.Bool( + required=False, load_from="IgnoreQueryString" + ), + "PathPattern": fields.Str(required=False, load_from="PathPattern"), + } + + +class AccessConfSchema(schema.ResponseSchema): + """ AccessConf - 访问控制 + """ + + fields = { + "IpBlacklist": fields.Str(required=False, load_from="IpBlacklist") + } + + +class DomainInfoSchema(schema.ResponseSchema): + """ DomainInfo - 域名配置 + """ + + fields = { + "AccessConf": AccessConfSchema(), + "AreaCode": fields.Str(required=False, load_from="AreaCode"), + "CacheConf": fields.List(CacheConfSchema()), + "CacheHost": fields.Str(required=False, load_from="CacheHost"), + "CdnProtocol": fields.Str(required=False, load_from="CdnProtocol"), + "CdnType": fields.Str(required=True, load_from="CdnType"), + "CertName": fields.Str(required=False, load_from="CertName"), + "Cname": fields.Str(required=False, load_from="Cname"), + "CreateTime": fields.Int(required=False, load_from="CreateTime"), + "Domain": fields.Str(required=False, load_from="Domain"), + "DomainId": fields.Str(required=False, load_from="DomainId"), + "HttpsStatusAbroad": fields.Str( + required=False, load_from="HttpsStatusAbroad" + ), + "HttpsStatusCn": fields.Str(required=False, load_from="HttpsStatusCn"), + "NullRefer": fields.Bool(required=False, load_from="NullRefer"), + "OriginHost": fields.Str(required=False, load_from="OriginHost"), + "OriginIp": fields.List(fields.Str()), + "OriginPort": fields.Int(required=False, load_from="OriginPort"), + "OriginProtocol": fields.Str( + required=False, load_from="OriginProtocol" + ), + "ReferList": fields.List(fields.Str()), + "ReferStatus": fields.Bool(required=False, load_from="ReferStatus"), + "ReferType": fields.Int(required=False, load_from="ReferType"), + "Status": fields.Str(required=False, load_from="Status"), + "Tag": fields.Str(required=False, load_from="Tag"), + "TestUrl": fields.Str(required=True, load_from="TestUrl"), + "ValidTime": fields.Int(required=False, load_from="ValidTime"), + } + + +class UrlProgressInfoSchema(schema.ResponseSchema): + """ UrlProgressInfo - UrlProgressInfo + """ + + fields = { + "CreateTime": fields.Int(required=False, load_from="CreateTime"), + "FinishTime": fields.Int(required=False, load_from="FinishTime"), + "Progress": fields.Int(required=False, load_from="Progress"), + "Status": fields.Str(required=False, load_from="Status"), + "Url": fields.Str(required=False, load_from="Url"), + } + + +class TaskInfoSchema(schema.ResponseSchema): + """ TaskInfo - 预取刷新的任务信息 + """ + + fields = { + "CreateTime": fields.Int(required=False, load_from="CreateTime"), + "Status": fields.Str(required=False, load_from="Status"), + "TaskId": fields.Str(required=False, load_from="TaskId"), + "Type": fields.Str(required=False, load_from="Type"), + "UrlLists": fields.List(UrlProgressInfoSchema()), + } + + +class BandwidthInfoSchema(schema.ResponseSchema): + """ BandwidthInfo - BandwidthInfo + """ + + fields = { + "CdnBandwidth": fields.Str(required=False, load_from="CdnBandwidth"), + "Time": fields.Int(required=False, load_from="Time"), + } + + +class HitRateInfoSchema(schema.ResponseSchema): + """ HitRateInfo - HitRateInfo + """ + + fields = { + "FlowHitRate": fields.Float(required=False, load_from="FlowHitRate"), + "RequestHitRate": fields.Float( + required=False, load_from="RequestHitRate" + ), + "Time": fields.Int(required=False, load_from="Time"), + } + + +class HttpCodeInfoSchema(schema.ResponseSchema): + """ HttpCodeInfo - HttpCodeInfo + """ + + fields = { + "HttpFiveXX": fields.Int(required=False, load_from="HttpFiveXX"), + "HttpFourXX": fields.Int(required=False, load_from="HttpFourXX"), + "HttpOneXX": fields.Int(required=False, load_from="HttpOneXX"), + "HttpThreeXX": fields.Int(required=False, load_from="HttpThreeXX"), + "HttpTwoXX": fields.Int(required=False, load_from="HttpTwoXX"), + "Time": fields.Int(required=False, load_from="Time"), + } + + +class HttpCodeV2DetailSchema(schema.ResponseSchema): + """ HttpCodeV2Detail - HTTP状态码详细信息 + """ + + fields = { + "Http100": fields.Int(required=False, load_from="Http100"), + "Http101": fields.Int(required=False, load_from="Http101"), + "Http102": fields.Int(required=False, load_from="Http102"), + "Http200": fields.Int(required=False, load_from="Http200"), + "Http201": fields.Int(required=False, load_from="Http201"), + "Http202": fields.Int(required=False, load_from="Http202"), + "Http203": fields.Int(required=False, load_from="Http203"), + "Http204": fields.Int(required=False, load_from="Http204"), + "Http205": fields.Int(required=False, load_from="Http205"), + "Http206": fields.Int(required=False, load_from="Http206"), + "Http207": fields.Int(required=False, load_from="Http207"), + "Http300": fields.Int(required=False, load_from="Http300"), + "Http301": fields.Int(required=False, load_from="Http301"), + "Http302": fields.Int(required=False, load_from="Http302"), + "Http303": fields.Int(required=False, load_from="Http303"), + "Http304": fields.Int(required=False, load_from="Http304"), + "Http305": fields.Int(required=False, load_from="Http305"), + "Http306": fields.Int(required=False, load_from="Http306"), + "Http307": fields.Int(required=False, load_from="Http307"), + "Http400": fields.Int(required=False, load_from="Http400"), + "Http401": fields.Int(required=False, load_from="Http401"), + "Http402": fields.Int(required=False, load_from="Http402"), + "Http403": fields.Int(required=False, load_from="Http403"), + "Http404": fields.Int(required=False, load_from="Http404"), + "Http405": fields.Int(required=False, load_from="Http405"), + "Http406": fields.Int(required=False, load_from="Http406"), + "Http407": fields.Int(required=False, load_from="Http407"), + "Http408": fields.Int(required=False, load_from="Http408"), + "Http409": fields.Int(required=False, load_from="Http409"), + "Http410": fields.Int(required=False, load_from="Http410"), + "Http411": fields.Int(required=False, load_from="Http411"), + "Http412": fields.Int(required=False, load_from="Http412"), + "Http413": fields.Int(required=False, load_from="Http413"), + "Http414": fields.Int(required=False, load_from="Http414"), + "Http415": fields.Int(required=False, load_from="Http415"), + "Http416": fields.Int(required=False, load_from="Http416"), + "Http417": fields.Int(required=False, load_from="Http417"), + "Http418": fields.Int(required=False, load_from="Http418"), + "Http421": fields.Int(required=False, load_from="Http421"), + "Http422": fields.Int(required=False, load_from="Http422"), + "Http423": fields.Int(required=False, load_from="Http423"), + "Http424": fields.Int(required=False, load_from="Http424"), + "Http425": fields.Int(required=False, load_from="Http425"), + "Http426": fields.Int(required=False, load_from="Http426"), + "Http449": fields.Int(required=False, load_from="Http449"), + "Http451": fields.Int(required=False, load_from="Http451"), + "Http500": fields.Int(required=False, load_from="Http500"), + "Http501": fields.Int(required=False, load_from="Http501"), + "Http502": fields.Int(required=False, load_from="Http502"), + "Http503": fields.Int(required=False, load_from="Http503"), + "Http504": fields.Int(required=False, load_from="Http504"), + "Http505": fields.Int(required=False, load_from="Http505"), + "Http506": fields.Int(required=False, load_from="Http506"), + "Http507": fields.Int(required=False, load_from="Http507"), + "Http509": fields.Int(required=False, load_from="Http509"), + "Http510": fields.Int(required=False, load_from="Http510"), + "Time": fields.Int(required=True, load_from="Time"), + } + + +class RequestInfoSchema(schema.ResponseSchema): + """ RequestInfo - RequestInfo + """ + + fields = { + "CdnRequest": fields.Float(required=False, load_from="CdnRequest"), + "OriginRequest": fields.Float( + required=False, load_from="OriginRequest" + ), + "Time": fields.Int(required=False, load_from="Time"), + } + + +class LogSetInfoSchema(schema.ResponseSchema): + """ LogSetInfo - 日志信息 + """ + + fields = { + "AbroadLog": fields.List(fields.Str()), + "CnLog": fields.List(fields.Str()), + "Time": fields.Int(required=False, load_from="Time"), + } + + +class LogSetListSchema(schema.ResponseSchema): + """ LogSetList - 日志信息列表 + """ + + fields = { + "Domain": fields.Str(required=False, load_from="Domain"), + "Logs": fields.List(LogSetInfoSchema()), + } + + +class UcdnDomainTrafficSetSchema(schema.ResponseSchema): + """ UcdnDomainTrafficSet - GetUcdnDomainTraffic + """ + + fields = { + "Time": fields.Int(required=False, load_from="Time"), + "Value": fields.Float(required=False, load_from="Value"), + } + + +class BandwidthInfoDetailSchema(schema.ResponseSchema): + """ BandwidthInfoDetail - 带宽值信息模型(时间-带宽) + """ + + fields = { + "Bandwidth": fields.Float(required=True, load_from="Bandwidth"), + "Time": fields.Int(required=True, load_from="Time"), + } + + +class TrafficSetSchema(schema.ResponseSchema): + """ TrafficSet - GetUcdnTraffic + """ + + fields = { + "Areacode": fields.Str(required=False, load_from="Areacode"), + "TrafficLeft": fields.Str(required=False, load_from="TrafficLeft"), + "TrafficTotal": fields.Str(required=False, load_from="TrafficTotal"), + "TrafficUsed": fields.Str(required=False, load_from="TrafficUsed"), + } diff --git a/ucloud/services/uphost/client.py b/ucloud/services/uphost/client.py index 54ba57c8..2efca4ec 100644 --- a/ucloud/services/uphost/client.py +++ b/ucloud/services/uphost/client.py @@ -1,398 +1,398 @@ -""" Code is generated by ucloud-model, DO NOT EDIT IT. """ - -import typing - - -from ucloud.core.client import Client -from ucloud.services.uphost.schemas import apis - - -class UPHostClient(Client): - def __init__( - self, config: dict, transport=None, middleware=None, logger=None - ): - super(UPHostClient, self).__init__( - config, transport, middleware, logger - ) - - def create_phost(self, req: typing.Optional[dict] = None, **kwargs) -> dict: - """ CreatePHost - 指定数据中心,根据资源使用量创建指定数量的UPHost物理云主机实例。 - - **Request** - - - **ProjectId** (str) - (Config) 项目ID。不填写为默认项目,子帐号必须填写。 请参考 `GetProjectList接口 `_ - - **Region** (str) - (Config) 地域。 参见 `地域和可用区列表 `_ - - **ImageId** (str) - (Required) 镜像ID。 请通过 [DescribePHostImage]获取 - - **Password** (str) - (Required) 密码(密码需使用base64进行编码) - - **Zone** (str) - (Required) 可用区。参见 `可用区列表 `_ - - **ChargeType** (str) - 计费模式,枚举值为:year, 按年付费; month,按月付费;dynamic,按需付费,(需开启权限) trial, 试用(需开启权限)。默认为按月付费 - - **Cluster** (str) - 网络环境,可选千兆:1G ,万兆:10G, 默认1G - - **Count** (int) - 购买数量,默认为1,(暂不支持) - - **CouponId** (str) - 代金券 - - **Name** (str) - 物理机名称,默认为phost - - **Quantity** (str) - 购买时长,默认为1,范围[1-10] - - **Raid** (str) - Raid配置,默认Raid10 支持:Raid0、Raid1、Raid5、Raid10,NoRaid - - **Remark** (str) - 物理机备注,默认为空 - - **SecurityGroupId** (str) - 防火墙Id,默认:Web推荐防火墙。如何查询SecurityGroupId请参见 `DescribeSecurityGroup `_ - - **SubnetId** (str) - 子网ID,不填为默认,VPC2.0下需要填写此字段。 - - **Tag** (str) - 业务组,默认为default - - **Type** (str) - 物理机类型,默认为:db-2(基础型-SAS-V3) - - **VPCId** (str) - VPC ID,不填为默认,VPC2.0下需要填写此字段。 - - **Response** - - - **PHostId** (list) - PHost的资源ID数组 - - """ - # build request - d = {"ProjectId": self.config.project_id, "Region": self.config.region} - req and d.update(req) - d = apis.CreatePHostRequestSchema().dumps(d) - - resp = self.invoke("CreatePHost", d, **kwargs) - return apis.CreatePHostResponseSchema().loads(resp) - - def describe_phost( - self, req: typing.Optional[dict] = None, **kwargs - ) -> dict: - """ DescribePHost - 获取物理机详细信息 - - **Request** - - - **ProjectId** (str) - (Config) 项目ID。不填写为默认项目,子帐号必须填写。 请参考 `GetProjectList接口 `_ - - **Region** (str) - (Config) 地域。 参见 `地域和可用区列表 `_ - - **Limit** (int) - 返回数据长度,默认为20 - - **Offset** (int) - 数据偏移量,默认为0 - - **PHostId** (list) - PHost资源ID,若为空,则返回当前Region所有PHost。 - - **Zone** (str) - 可用区。参见 `可用区列表 `_ - - **Response** - - - **PHostSet** (list) - 见 **PHostSet** 模型定义 - - **TotalCount** (int) - 满足条件的PHost总数 - - **Response Model** - - **PHostDiskSet** - - - **Count** (int) - 磁盘数量 - - **IOCap** (int) - 磁盘IO性能,单位MB/s(待废弃) - - **Name** (str) - 磁盘名称,sys/data - - **Space** (int) - 单盘大小,单位GB - - **Type** (str) - 磁盘属性 - - **PHostCPUSet** - - - **CoreCount** (int) - CPU核数 - - **Count** (int) - CPU个数 - - **Frequence** (float) - CPU主频 - - **Model** (str) - CPU型号 - - **PHostIPSet** - - - **Bandwidth** (int) - IP对应带宽,单位Mb,内网IP不显示带宽信息 - - **IPAddr** (str) - IP地址, - - **IPId** (str) - IP资源ID(内网IP无资源ID)(待废弃) - - **MACAddr** (str) - MAC地址 - - **OperatorName** (str) - 国际: Internation, BGP: BGP, 内网: Private - - **SubnetId** (str) - 子网ID - - **VPCId** (str) - VPC ID - - **PHostSet** - - - **AutoRenew** (str) - 自动续费 - - **CPUSet** (list) - 见 **PHostCPUSet** 模型定义 - - **ChargeType** (str) - 计费模式,枚举值为: Year,按年付费; Month,按月付费; Dynamic,按需付费(需开启权限); Trial,试用(需开启权限)默认为月付 - - **Cluster** (str) - 网络环境。枚举值:千兆:1G ,万兆:10G - - **Components** (str) - 组件信息(暂不支持) - - **CreateTime** (int) - 创建时间 - - **DiskSet** (list) - 见 **PHostDiskSet** 模型定义 - - **ExpireTime** (int) - 到期时间 - - **IPSet** (list) - 见 **PHostIPSet** 模型定义 - - **ImageName** (str) - 镜像名称 - - **IsSupportKVM** (str) - 是否支持紧急登录 - - **Memory** (int) - 内存大小,单位:MB - - **Name** (str) - 物理机名称 - - **OSType** (str) - 操作系统类型 - - **OSname** (str) - 操作系统名称 - - **PHostId** (str) - PHost资源ID - - **PHostType** (str) - 物理机类型,参见DescribePHostMachineType返回值 - - **PMStatus** (str) - 物理云主机状态。枚举值:\\ > 初始化:Initializing; \\ > 启动中:Starting; \\ > 运行中:Running;\\ > 关机中:Stopping; \\ > 安装失败:InstallFailed; \\ > 重启中:Rebooting;\\ > 关机:Stopped; - - **PowerState** (str) - 电源状态,on 或 off - - **RaidSupported** (str) - 是否支持Raid。枚举值:Yes:支持;No:不支持。 - - **Remark** (str) - 物理机备注 - - **SN** (str) - 物理机序列号 - - **Tag** (str) - 业务组 - - **Zone** (str) - 可用区,参见 `可用区列表 `_ - - """ - # build request - d = {"ProjectId": self.config.project_id, "Region": self.config.region} - req and d.update(req) - d = apis.DescribePHostRequestSchema().dumps(d) - - resp = self.invoke("DescribePHost", d, **kwargs) - return apis.DescribePHostResponseSchema().loads(resp) - - def describe_phost_image( - self, req: typing.Optional[dict] = None, **kwargs - ) -> dict: - """ DescribePHostImage - 获取物理云主机镜像列表 - - **Request** - - - **ProjectId** (str) - (Config) 项目ID。不填写为默认项目,子帐号必须填写。 请参考 `GetProjectList接口 `_ - - **Region** (str) - (Config) 地域。 参见 `地域和可用区列表 `_ - - **Zone** (str) - (Required) 可用区。参见 `可用区列表 `_ - - **ImageId** (list) - 镜像ID - - **ImageType** (str) - 镜像类别,枚举为:Base,标准镜像;默认为标准镜像。 - - **Limit** (int) - 返回数据长度,默认为20 - - **Offset** (int) - 数据偏移量,默认为0 - - **Response** - - - **ImageSet** (list) - 见 **PHostImageSet** 模型定义 - - **TotalCount** (int) - 满足条件的镜像总数 - - **Response Model** - - **PHostImageSet** - - - **ImageId** (str) - 镜像ID - - **ImageName** (str) - 镜像名称 - - **OsName** (str) - 操作系统名称 - - **OsType** (str) - 操作系统类型 - - """ - # build request - d = {"ProjectId": self.config.project_id, "Region": self.config.region} - req and d.update(req) - d = apis.DescribePHostImageRequestSchema().dumps(d) - - resp = self.invoke("DescribePHostImage", d, **kwargs) - return apis.DescribePHostImageResponseSchema().loads(resp) - - def describe_phost_tags( - self, req: typing.Optional[dict] = None, **kwargs - ) -> dict: - """ DescribePHostTags - 获取物理机tag列表(业务组) - - **Request** - - - **ProjectId** (str) - (Config) 项目ID。不填写为默认项目,子帐号必须填写。 请参考 `GetProjectList接口 `_ - - **Region** (str) - (Config) 地域。 参见 `地域和可用区列表 `_ - - **Zone** (str) - 可用区。参见 `可用区列表 `_ - - **Response** - - - **TagSet** (list) - 见 **PHostTagSet** 模型定义 - - **TotalCount** (int) - Tag的个数 - - **Response Model** - - **PHostTagSet** - - - **Tag** (str) - 业务组名称 - - **TotalCount** (int) - 该业务组中包含的主机个数 - - """ - # build request - d = {"ProjectId": self.config.project_id, "Region": self.config.region} - req and d.update(req) - d = apis.DescribePHostTagsRequestSchema().dumps(d) - - resp = self.invoke("DescribePHostTags", d, **kwargs) - return apis.DescribePHostTagsResponseSchema().loads(resp) - - def get_phost_price( - self, req: typing.Optional[dict] = None, **kwargs - ) -> dict: - """ GetPHostPrice - 获取物理机价格列表 - - **Request** - - - **ProjectId** (str) - (Config) 项目ID。不填写为默认项目,子帐号必须填写。 请参考 `GetProjectList接口 `_ - - **Region** (str) - (Config) 地域。 参见 `地域和可用区列表 `_ - - **ChargeType** (str) - (Required) 计费模式,枚举值为: Year/Month/Trial/Dynamic - - **Count** (int) - (Required) 购买数量,范围[1-5] - - **Quantity** (int) - (Required) 购买时长,1-10个月或1-10年 - - **Cluster** (str) - 网络环境,可选千兆:1G ,万兆:10G - - **Type** (str) - 默认为:DB(数据库型) - - **Zone** (str) - 可用区。参见 `可用区列表 `_ - - **Response** - - - **PriceSet** (list) - 见 **PHostPriceSet** 模型定义 - - **Response Model** - - **PHostPriceSet** - - - **ChargeType** (str) - Year/Month/Trial/Dynamic - - **Price** (float) - 价格, 单位:元, 保留小数点后两位有效数字 - - """ - # build request - d = {"ProjectId": self.config.project_id, "Region": self.config.region} - req and d.update(req) - d = apis.GetPHostPriceRequestSchema().dumps(d) - - resp = self.invoke("GetPHostPrice", d, **kwargs) - return apis.GetPHostPriceResponseSchema().loads(resp) - - def modify_phost_info( - self, req: typing.Optional[dict] = None, **kwargs - ) -> dict: - """ ModifyPHostInfo - 更改物理机信息 - - **Request** - - - **ProjectId** (str) - (Config) 项目ID。不填写为默认项目,子帐号必须填写。 请参考 `GetProjectList接口 `_ - - **Region** (str) - (Config) 地域。 参见 `地域和可用区列表 `_ - - **PHostId** (str) - (Required) 物理机资源ID - - **Name** (str) - 物理机名称,默认不更改 - - **Remark** (str) - 物理机备注,默认不更改 - - **Tag** (str) - 业务组,默认不更改 - - **Zone** (str) - 可用区。参见 `可用区列表 `_ - - **Response** - - - **PHostId** (str) - PHost 的资源ID - - """ - # build request - d = {"ProjectId": self.config.project_id, "Region": self.config.region} - req and d.update(req) - d = apis.ModifyPHostInfoRequestSchema().dumps(d) - - resp = self.invoke("ModifyPHostInfo", d, **kwargs) - return apis.ModifyPHostInfoResponseSchema().loads(resp) - - def poweroff_phost( - self, req: typing.Optional[dict] = None, **kwargs - ) -> dict: - """ PoweroffPHost - 断电物理云主机 - - **Request** - - - **ProjectId** (str) - (Config) 项目ID。不填写为默认项目,子帐号必须填写。 请参考 `GetProjectList接口 `_ - - **Region** (str) - (Config) 地域。 参见 `地域和可用区列表 `_ - - **PHostId** (str) - (Required) PHost资源ID - - **Zone** (str) - 可用区。参见 `可用区列表 `_ - - **Response** - - - **PHostId** (str) - PHost 的资源ID - - """ - # build request - d = {"ProjectId": self.config.project_id, "Region": self.config.region} - req and d.update(req) - d = apis.PoweroffPHostRequestSchema().dumps(d) - - resp = self.invoke("PoweroffPHost", d, **kwargs) - return apis.PoweroffPHostResponseSchema().loads(resp) - - def reboot_phost(self, req: typing.Optional[dict] = None, **kwargs) -> dict: - """ RebootPHost - 重启物理机 - - **Request** - - - **ProjectId** (str) - (Config) 项目ID。不填写为默认项目,子帐号必须填写。 请参考 `GetProjectList接口 `_ - - **Region** (str) - (Config) 地域。 参见 `地域和可用区列表 `_ - - **PHostId** (str) - (Required) PHost资源ID - - **Zone** (str) - 可用区。参见 `可用区列表 `_ - - **Response** - - - **PHostId** (str) - PHost 的资源ID - - """ - # build request - d = {"ProjectId": self.config.project_id, "Region": self.config.region} - req and d.update(req) - d = apis.RebootPHostRequestSchema().dumps(d) - - resp = self.invoke("RebootPHost", d, **kwargs) - return apis.RebootPHostResponseSchema().loads(resp) - - def reinstall_phost( - self, req: typing.Optional[dict] = None, **kwargs - ) -> dict: - """ ReinstallPHost - 重装物理机操作系统 - - **Request** - - - **ProjectId** (str) - (Config) 项目ID。不填写为默认项目,子帐号必须填写。 请参考 `GetProjectList接口 `_ - - **Region** (str) - (Config) 地域。 参见 `地域和可用区列表 `_ - - **PHostId** (str) - (Required) PHost资源ID - - **Password** (str) - (Required) 密码 - - **Zone** (str) - (Required) 可用区。参见 `可用区列表 `_ - - **ImageId** (str) - 镜像Id,参考镜像列表,默认使用原镜像 - - **Name** (str) - 物理机名称,默认不更改 - - **Raid** (str) - 不保留数据盘重装,可选Raid - - **Remark** (str) - 物理机备注,默认为不更改。 - - **ReserveDisk** (str) - 是否保留数据盘,保留:Yes,不报留:No, 默认:Yes - - **Tag** (str) - 业务组,默认不更改。 - - **Response** - - - **PHostId** (str) - PHost 的资源ID - - """ - # build request - d = {"ProjectId": self.config.project_id, "Region": self.config.region} - req and d.update(req) - d = apis.ReinstallPHostRequestSchema().dumps(d) - - resp = self.invoke("ReinstallPHost", d, **kwargs) - return apis.ReinstallPHostResponseSchema().loads(resp) - - def start_phost(self, req: typing.Optional[dict] = None, **kwargs) -> dict: - """ StartPHost - 启动物理机 - - **Request** - - - **ProjectId** (str) - (Config) 项目ID。不填写为默认项目,子帐号必须填写。 请参考 `GetProjectList接口 `_ - - **Region** (str) - (Config) 地域。 参见 `地域和可用区列表 `_ - - **PHostId** (str) - (Required) PHost资源ID - - **Zone** (str) - 可用区。参见 `可用区列表 `_ - - **Response** - - - **PHostId** (str) - PHost 的资源ID - - """ - # build request - d = {"ProjectId": self.config.project_id, "Region": self.config.region} - req and d.update(req) - d = apis.StartPHostRequestSchema().dumps(d) - - resp = self.invoke("StartPHost", d, **kwargs) - return apis.StartPHostResponseSchema().loads(resp) - - def terminate_phost( - self, req: typing.Optional[dict] = None, **kwargs - ) -> dict: - """ TerminatePHost - 删除物理云主机 - - **Request** - - - **ProjectId** (str) - (Config) 项目ID。不填写为默认项目,子帐号必须填写。 请参考 `GetProjectList接口 `_ - - **Region** (str) - (Config) 地域。 参见 `地域和可用区列表 `_ - - **PHostId** (str) - (Required) PHost资源ID - - **ReleaseEIP** (bool) - 是否释放绑定的EIP。true: 解绑EIP后,并释放;其他值或不填:解绑EIP。 - - **Zone** (str) - 可用区。参见 `可用区列表 `_ - - **Response** - - - **PHostId** (str) - PHost 的资源ID - - """ - # build request - d = {"ProjectId": self.config.project_id, "Region": self.config.region} - req and d.update(req) - d = apis.TerminatePHostRequestSchema().dumps(d) - - resp = self.invoke("TerminatePHost", d, **kwargs) - return apis.TerminatePHostResponseSchema().loads(resp) +""" Code is generated by ucloud-model, DO NOT EDIT IT. """ + +import typing + + +from ucloud.core.client import Client +from ucloud.services.uphost.schemas import apis + + +class UPHostClient(Client): + def __init__( + self, config: dict, transport=None, middleware=None, logger=None + ): + super(UPHostClient, self).__init__( + config, transport, middleware, logger + ) + + def create_phost(self, req: typing.Optional[dict] = None, **kwargs) -> dict: + """ CreatePHost - 指定数据中心,根据资源使用量创建指定数量的UPHost物理云主机实例。 + + **Request** + + - **ProjectId** (str) - (Config) 项目ID。不填写为默认项目,子帐号必须填写。 请参考 `GetProjectList接口 `_ + - **Region** (str) - (Config) 地域。 参见 `地域和可用区列表 `_ + - **ImageId** (str) - (Required) 镜像ID。 请通过 [DescribePHostImage]获取 + - **Password** (str) - (Required) 密码(密码需使用base64进行编码) + - **Zone** (str) - (Required) 可用区。参见 `可用区列表 `_ + - **ChargeType** (str) - 计费模式,枚举值为:year, 按年付费; month,按月付费;dynamic,按需付费,(需开启权限) trial, 试用(需开启权限)。默认为按月付费 + - **Cluster** (str) - 网络环境,可选千兆:1G ,万兆:10G, 默认1G + - **Count** (int) - 购买数量,默认为1,(暂不支持) + - **CouponId** (str) - 代金券 + - **Name** (str) - 物理机名称,默认为phost + - **Quantity** (str) - 购买时长,默认为1,范围[1-10] + - **Raid** (str) - Raid配置,默认Raid10 支持:Raid0、Raid1、Raid5、Raid10,NoRaid + - **Remark** (str) - 物理机备注,默认为空 + - **SecurityGroupId** (str) - 防火墙Id,默认:Web推荐防火墙。如何查询SecurityGroupId请参见 `DescribeSecurityGroup `_ + - **SubnetId** (str) - 子网ID,不填为默认,VPC2.0下需要填写此字段。 + - **Tag** (str) - 业务组,默认为default + - **Type** (str) - 物理机类型,默认为:db-2(基础型-SAS-V3) + - **VPCId** (str) - VPC ID,不填为默认,VPC2.0下需要填写此字段。 + + **Response** + + - **PHostId** (list) - PHost的资源ID数组 + + """ + # build request + d = {"ProjectId": self.config.project_id, "Region": self.config.region} + req and d.update(req) + d = apis.CreatePHostRequestSchema().dumps(d) + + resp = self.invoke("CreatePHost", d, **kwargs) + return apis.CreatePHostResponseSchema().loads(resp) + + def describe_phost( + self, req: typing.Optional[dict] = None, **kwargs + ) -> dict: + """ DescribePHost - 获取物理机详细信息 + + **Request** + + - **ProjectId** (str) - (Config) 项目ID。不填写为默认项目,子帐号必须填写。 请参考 `GetProjectList接口 `_ + - **Region** (str) - (Config) 地域。 参见 `地域和可用区列表 `_ + - **Limit** (int) - 返回数据长度,默认为20 + - **Offset** (int) - 数据偏移量,默认为0 + - **PHostId** (list) - PHost资源ID,若为空,则返回当前Region所有PHost。 + - **Zone** (str) - 可用区。参见 `可用区列表 `_ + + **Response** + + - **PHostSet** (list) - 见 **PHostSet** 模型定义 + - **TotalCount** (int) - 满足条件的PHost总数 + + **Response Model** + + **PHostCPUSet** + + - **CoreCount** (int) - CPU核数 + - **Count** (int) - CPU个数 + - **Frequence** (float) - CPU主频 + - **Model** (str) - CPU型号 + + **PHostDiskSet** + + - **Count** (int) - 磁盘数量 + - **IOCap** (int) - 磁盘IO性能,单位MB/s(待废弃) + - **Name** (str) - 磁盘名称,sys/data + - **Space** (int) - 单盘大小,单位GB + - **Type** (str) - 磁盘属性 + + **PHostIPSet** + + - **Bandwidth** (int) - IP对应带宽,单位Mb,内网IP不显示带宽信息 + - **IPAddr** (str) - IP地址, + - **IPId** (str) - IP资源ID(内网IP无资源ID)(待废弃) + - **MACAddr** (str) - MAC地址 + - **OperatorName** (str) - 国际: Internation, BGP: BGP, 内网: Private + - **SubnetId** (str) - 子网ID + - **VPCId** (str) - VPC ID + + **PHostSet** + + - **AutoRenew** (str) - 自动续费 + - **CPUSet** (dict) - 见 **PHostCPUSet** 模型定义 + - **ChargeType** (str) - 计费模式,枚举值为: Year,按年付费; Month,按月付费; Dynamic,按需付费(需开启权限); Trial,试用(需开启权限)默认为月付 + - **Cluster** (str) - 网络环境。枚举值:千兆:1G ,万兆:10G + - **Components** (str) - 组件信息(暂不支持) + - **CreateTime** (int) - 创建时间 + - **DiskSet** (list) - 见 **PHostDiskSet** 模型定义 + - **ExpireTime** (int) - 到期时间 + - **IPSet** (list) - 见 **PHostIPSet** 模型定义 + - **ImageName** (str) - 镜像名称 + - **IsSupportKVM** (str) - 是否支持紧急登录 + - **Memory** (int) - 内存大小,单位:MB + - **Name** (str) - 物理机名称 + - **OSType** (str) - 操作系统类型 + - **OSname** (str) - 操作系统名称 + - **PHostId** (str) - PHost资源ID + - **PHostType** (str) - 物理机类型,参见DescribePHostMachineType返回值 + - **PMStatus** (str) - 物理云主机状态。枚举值:\\ > 初始化:Initializing; \\ > 启动中:Starting; \\ > 运行中:Running;\\ > 关机中:Stopping; \\ > 安装失败:InstallFailed; \\ > 重启中:Rebooting;\\ > 关机:Stopped; + - **PowerState** (str) - 电源状态,on 或 off + - **RaidSupported** (str) - 是否支持Raid。枚举值:Yes:支持;No:不支持。 + - **Remark** (str) - 物理机备注 + - **SN** (str) - 物理机序列号 + - **Tag** (str) - 业务组 + - **Zone** (str) - 可用区,参见 `可用区列表 `_ + + """ + # build request + d = {"ProjectId": self.config.project_id, "Region": self.config.region} + req and d.update(req) + d = apis.DescribePHostRequestSchema().dumps(d) + + resp = self.invoke("DescribePHost", d, **kwargs) + return apis.DescribePHostResponseSchema().loads(resp) + + def describe_phost_image( + self, req: typing.Optional[dict] = None, **kwargs + ) -> dict: + """ DescribePHostImage - 获取物理云主机镜像列表 + + **Request** + + - **ProjectId** (str) - (Config) 项目ID。不填写为默认项目,子帐号必须填写。 请参考 `GetProjectList接口 `_ + - **Region** (str) - (Config) 地域。 参见 `地域和可用区列表 `_ + - **Zone** (str) - (Required) 可用区。参见 `可用区列表 `_ + - **ImageId** (list) - 镜像ID + - **ImageType** (str) - 镜像类别,枚举为:Base,标准镜像;默认为标准镜像。 + - **Limit** (int) - 返回数据长度,默认为20 + - **Offset** (int) - 数据偏移量,默认为0 + + **Response** + + - **ImageSet** (list) - 见 **PHostImageSet** 模型定义 + - **TotalCount** (int) - 满足条件的镜像总数 + + **Response Model** + + **PHostImageSet** + + - **ImageId** (str) - 镜像ID + - **ImageName** (str) - 镜像名称 + - **OsName** (str) - 操作系统名称 + - **OsType** (str) - 操作系统类型 + + """ + # build request + d = {"ProjectId": self.config.project_id, "Region": self.config.region} + req and d.update(req) + d = apis.DescribePHostImageRequestSchema().dumps(d) + + resp = self.invoke("DescribePHostImage", d, **kwargs) + return apis.DescribePHostImageResponseSchema().loads(resp) + + def describe_phost_tags( + self, req: typing.Optional[dict] = None, **kwargs + ) -> dict: + """ DescribePHostTags - 获取物理机tag列表(业务组) + + **Request** + + - **ProjectId** (str) - (Config) 项目ID。不填写为默认项目,子帐号必须填写。 请参考 `GetProjectList接口 `_ + - **Region** (str) - (Config) 地域。 参见 `地域和可用区列表 `_ + - **Zone** (str) - 可用区。参见 `可用区列表 `_ + + **Response** + + - **TagSet** (list) - 见 **PHostTagSet** 模型定义 + - **TotalCount** (int) - Tag的个数 + + **Response Model** + + **PHostTagSet** + + - **Tag** (str) - 业务组名称 + - **TotalCount** (int) - 该业务组中包含的主机个数 + + """ + # build request + d = {"ProjectId": self.config.project_id, "Region": self.config.region} + req and d.update(req) + d = apis.DescribePHostTagsRequestSchema().dumps(d) + + resp = self.invoke("DescribePHostTags", d, **kwargs) + return apis.DescribePHostTagsResponseSchema().loads(resp) + + def get_phost_price( + self, req: typing.Optional[dict] = None, **kwargs + ) -> dict: + """ GetPHostPrice - 获取物理机价格列表 + + **Request** + + - **ProjectId** (str) - (Config) 项目ID。不填写为默认项目,子帐号必须填写。 请参考 `GetProjectList接口 `_ + - **Region** (str) - (Config) 地域。 参见 `地域和可用区列表 `_ + - **ChargeType** (str) - (Required) 计费模式,枚举值为: Year/Month/Trial/Dynamic + - **Count** (int) - (Required) 购买数量,范围[1-5] + - **Quantity** (int) - (Required) 购买时长,1-10个月或1-10年 + - **Cluster** (str) - 网络环境,可选千兆:1G ,万兆:10G + - **Type** (str) - 默认为:DB(数据库型) + - **Zone** (str) - 可用区。参见 `可用区列表 `_ + + **Response** + + - **PriceSet** (list) - 见 **PHostPriceSet** 模型定义 + + **Response Model** + + **PHostPriceSet** + + - **ChargeType** (str) - Year/Month/Trial/Dynamic + - **Price** (float) - 价格, 单位:元, 保留小数点后两位有效数字 + + """ + # build request + d = {"ProjectId": self.config.project_id, "Region": self.config.region} + req and d.update(req) + d = apis.GetPHostPriceRequestSchema().dumps(d) + + resp = self.invoke("GetPHostPrice", d, **kwargs) + return apis.GetPHostPriceResponseSchema().loads(resp) + + def modify_phost_info( + self, req: typing.Optional[dict] = None, **kwargs + ) -> dict: + """ ModifyPHostInfo - 更改物理机信息 + + **Request** + + - **ProjectId** (str) - (Config) 项目ID。不填写为默认项目,子帐号必须填写。 请参考 `GetProjectList接口 `_ + - **Region** (str) - (Config) 地域。 参见 `地域和可用区列表 `_ + - **PHostId** (str) - (Required) 物理机资源ID + - **Name** (str) - 物理机名称,默认不更改 + - **Remark** (str) - 物理机备注,默认不更改 + - **Tag** (str) - 业务组,默认不更改 + - **Zone** (str) - 可用区。参见 `可用区列表 `_ + + **Response** + + - **PHostId** (str) - PHost 的资源ID + + """ + # build request + d = {"ProjectId": self.config.project_id, "Region": self.config.region} + req and d.update(req) + d = apis.ModifyPHostInfoRequestSchema().dumps(d) + + resp = self.invoke("ModifyPHostInfo", d, **kwargs) + return apis.ModifyPHostInfoResponseSchema().loads(resp) + + def poweroff_phost( + self, req: typing.Optional[dict] = None, **kwargs + ) -> dict: + """ PoweroffPHost - 断电物理云主机 + + **Request** + + - **ProjectId** (str) - (Config) 项目ID。不填写为默认项目,子帐号必须填写。 请参考 `GetProjectList接口 `_ + - **Region** (str) - (Config) 地域。 参见 `地域和可用区列表 `_ + - **PHostId** (str) - (Required) PHost资源ID + - **Zone** (str) - 可用区。参见 `可用区列表 `_ + + **Response** + + - **PHostId** (str) - PHost 的资源ID + + """ + # build request + d = {"ProjectId": self.config.project_id, "Region": self.config.region} + req and d.update(req) + d = apis.PoweroffPHostRequestSchema().dumps(d) + + resp = self.invoke("PoweroffPHost", d, **kwargs) + return apis.PoweroffPHostResponseSchema().loads(resp) + + def reboot_phost(self, req: typing.Optional[dict] = None, **kwargs) -> dict: + """ RebootPHost - 重启物理机 + + **Request** + + - **ProjectId** (str) - (Config) 项目ID。不填写为默认项目,子帐号必须填写。 请参考 `GetProjectList接口 `_ + - **Region** (str) - (Config) 地域。 参见 `地域和可用区列表 `_ + - **PHostId** (str) - (Required) PHost资源ID + - **Zone** (str) - 可用区。参见 `可用区列表 `_ + + **Response** + + - **PHostId** (str) - PHost 的资源ID + + """ + # build request + d = {"ProjectId": self.config.project_id, "Region": self.config.region} + req and d.update(req) + d = apis.RebootPHostRequestSchema().dumps(d) + + resp = self.invoke("RebootPHost", d, **kwargs) + return apis.RebootPHostResponseSchema().loads(resp) + + def reinstall_phost( + self, req: typing.Optional[dict] = None, **kwargs + ) -> dict: + """ ReinstallPHost - 重装物理机操作系统 + + **Request** + + - **ProjectId** (str) - (Config) 项目ID。不填写为默认项目,子帐号必须填写。 请参考 `GetProjectList接口 `_ + - **Region** (str) - (Config) 地域。 参见 `地域和可用区列表 `_ + - **PHostId** (str) - (Required) PHost资源ID + - **Password** (str) - (Required) 密码 + - **Zone** (str) - (Required) 可用区。参见 `可用区列表 `_ + - **ImageId** (str) - 镜像Id,参考镜像列表,默认使用原镜像 + - **Name** (str) - 物理机名称,默认不更改 + - **Raid** (str) - 不保留数据盘重装,可选Raid + - **Remark** (str) - 物理机备注,默认为不更改。 + - **ReserveDisk** (str) - 是否保留数据盘,保留:Yes,不报留:No, 默认:Yes + - **Tag** (str) - 业务组,默认不更改。 + + **Response** + + - **PHostId** (str) - PHost 的资源ID + + """ + # build request + d = {"ProjectId": self.config.project_id, "Region": self.config.region} + req and d.update(req) + d = apis.ReinstallPHostRequestSchema().dumps(d) + + resp = self.invoke("ReinstallPHost", d, **kwargs) + return apis.ReinstallPHostResponseSchema().loads(resp) + + def start_phost(self, req: typing.Optional[dict] = None, **kwargs) -> dict: + """ StartPHost - 启动物理机 + + **Request** + + - **ProjectId** (str) - (Config) 项目ID。不填写为默认项目,子帐号必须填写。 请参考 `GetProjectList接口 `_ + - **Region** (str) - (Config) 地域。 参见 `地域和可用区列表 `_ + - **PHostId** (str) - (Required) PHost资源ID + - **Zone** (str) - 可用区。参见 `可用区列表 `_ + + **Response** + + - **PHostId** (str) - PHost 的资源ID + + """ + # build request + d = {"ProjectId": self.config.project_id, "Region": self.config.region} + req and d.update(req) + d = apis.StartPHostRequestSchema().dumps(d) + + resp = self.invoke("StartPHost", d, **kwargs) + return apis.StartPHostResponseSchema().loads(resp) + + def terminate_phost( + self, req: typing.Optional[dict] = None, **kwargs + ) -> dict: + """ TerminatePHost - 删除物理云主机 + + **Request** + + - **ProjectId** (str) - (Config) 项目ID。不填写为默认项目,子帐号必须填写。 请参考 `GetProjectList接口 `_ + - **Region** (str) - (Config) 地域。 参见 `地域和可用区列表 `_ + - **PHostId** (str) - (Required) PHost资源ID + - **ReleaseEIP** (bool) - 是否释放绑定的EIP。true: 解绑EIP后,并释放;其他值或不填:解绑EIP。 + - **Zone** (str) - 可用区。参见 `可用区列表 `_ + + **Response** + + - **PHostId** (str) - PHost 的资源ID + + """ + # build request + d = {"ProjectId": self.config.project_id, "Region": self.config.region} + req and d.update(req) + d = apis.TerminatePHostRequestSchema().dumps(d) + + resp = self.invoke("TerminatePHost", d, **kwargs) + return apis.TerminatePHostResponseSchema().loads(resp) diff --git a/ucloud/services/uphost/schemas/models.py b/ucloud/services/uphost/schemas/models.py index 5761488f..efbe9d2e 100644 --- a/ucloud/services/uphost/schemas/models.py +++ b/ucloud/services/uphost/schemas/models.py @@ -3,15 +3,18 @@ from ucloud.core.typesystem import schema, fields -class PHostCPUSetSchema(schema.ResponseSchema): - """ PHostCPUSet - DescribePHost +class PHostIPSetSchema(schema.ResponseSchema): + """ PHostIPSet - DescribePHost """ fields = { - "CoreCount": fields.Int(required=False, load_from="CoreCount"), - "Count": fields.Int(required=False, load_from="Count"), - "Frequence": fields.Float(required=False, load_from="Frequence"), - "Model": fields.Str(required=False, load_from="Model"), + "Bandwidth": fields.Int(required=False, load_from="Bandwidth"), + "IPAddr": fields.Str(required=False, load_from="IPAddr"), + "IPId": fields.Str(required=False, load_from="IPId"), + "MACAddr": fields.Str(required=False, load_from="MACAddr"), + "OperatorName": fields.Str(required=False, load_from="OperatorName"), + "SubnetId": fields.Str(required=False, load_from="SubnetId"), + "VPCId": fields.Str(required=False, load_from="VPCId"), } @@ -28,18 +31,15 @@ class PHostDiskSetSchema(schema.ResponseSchema): } -class PHostIPSetSchema(schema.ResponseSchema): - """ PHostIPSet - DescribePHost +class PHostCPUSetSchema(schema.ResponseSchema): + """ PHostCPUSet - DescribePHost """ fields = { - "Bandwidth": fields.Int(required=False, load_from="Bandwidth"), - "IPAddr": fields.Str(required=False, load_from="IPAddr"), - "IPId": fields.Str(required=False, load_from="IPId"), - "MACAddr": fields.Str(required=False, load_from="MACAddr"), - "OperatorName": fields.Str(required=False, load_from="OperatorName"), - "SubnetId": fields.Str(required=False, load_from="SubnetId"), - "VPCId": fields.Str(required=False, load_from="VPCId"), + "CoreCount": fields.Int(required=False, load_from="CoreCount"), + "Count": fields.Int(required=False, load_from="Count"), + "Frequence": fields.Float(required=False, load_from="Frequence"), + "Model": fields.Str(required=False, load_from="Model"), } @@ -49,7 +49,7 @@ class PHostSetSchema(schema.ResponseSchema): fields = { "AutoRenew": fields.Str(required=False, load_from="AutoRenew"), - "CPUSet": fields.List(PHostCPUSetSchema()), + "CPUSet": PHostCPUSetSchema(), "ChargeType": fields.Str(required=False, load_from="ChargeType"), "Cluster": fields.Str(required=False, load_from="Cluster"), "Components": fields.Str(required=False, load_from="Components"), diff --git a/ucloud/services/usms/__init__.py b/ucloud/services/usms/__init__.py new file mode 100644 index 00000000..e69de29b diff --git a/ucloud/services/usms/client.py b/ucloud/services/usms/client.py new file mode 100644 index 00000000..ace721fb --- /dev/null +++ b/ucloud/services/usms/client.py @@ -0,0 +1,334 @@ +""" Code is generated by ucloud-model, DO NOT EDIT IT. """ + +import typing + + +from ucloud.core.client import Client +from ucloud.services.usms.schemas import apis + + +class USMSClient(Client): + def __init__( + self, config: dict, transport=None, middleware=None, logger=None + ): + super(USMSClient, self).__init__(config, transport, middleware, logger) + + def create_usms_signature( + self, req: typing.Optional[dict] = None, **kwargs + ) -> dict: + """ CreateUSMSSignature - 调用接口CreateUSMSSignature申请短信签名 + + **Request** + + - **ProjectId** (str) - (Config) 项目ID,不填写为默认项目,子帐号必须填写。 请参考 `GetProjectList接口 `_ + - **CertificateType** (int) - (Required) 签名的资质证明文件类型,需与签名类型保持一致,说明如下:0-三证合一/企业营业执照/组织机构代码证书/社会信用代码证书;1-应用商店后台开发者管理截图;2-备案服务商的备案成功截图(含域名,网站名称,备案号);3-公众号或小程序的管理界面截图;4-商标注册证书;5-组织机构代码证书、社会信用代码证书; + - **Description** (str) - (Required) 短信签名申请原因 + - **File** (str) - (Required) 短信签名的资质证明文件,需先进行base64编码格式转换,此处填写转换后的字符串。文件大小不超过4 MB + - **SigContent** (str) - (Required) 短信签名名称;长度为2-12个字符, 可包含中文、数字和符号;无需填写【】或[],系统会自动添加 + - **SigPurpose** (int) - (Required) 签名用途,0-自用,1-他用; + - **SigType** (int) - (Required) 签名类型,说明如下:0-公司或企业的全称或简称;1-App应用的全称或简称;2-工信部备案网站的全称或简称;3-公众号或小程序的全称或简称;4-商标名的全称或简称;5-政府/机关事业单位/其他单位的全称或简称; + - **ProxyFile** (str) - 短信签名授权委托文件,需先进行base64编码格式转换,此处填写转换后的字符串。文件大小不超过4 MB;当您是代理并使用第三方的签名时(也即SigPurpose为1-他用),该项为必填项; + + **Response** + + - **Message** (str) - 返回状态码描述,如果操作成功,默认返回为空 + - **SigContent** (str) - 短信签名名称 + - **SigId** (str) - 短信签名ID(短信签名申请时的工单ID) + + """ + # build request + d = {"ProjectId": self.config.project_id} + req and d.update(req) + d = apis.CreateUSMSSignatureRequestSchema().dumps(d) + + # build options + kwargs["max_retries"] = 0 # ignore retry when api is not idempotent + + resp = self.invoke("CreateUSMSSignature", d, **kwargs) + return apis.CreateUSMSSignatureResponseSchema().loads(resp) + + def create_usms_template( + self, req: typing.Optional[dict] = None, **kwargs + ) -> dict: + """ CreateUSMSTemplate - 调用接口CreateUSMSTemplate申请短信模板 + + **Request** + + - **ProjectId** (str) - (Config) 项目ID,不填写为默认项目,子帐号必须填写。 请参考 `GetProjectList接口 `_ + - **Region** (str) - (Config) 地域。 参见 `地域和可用区列表 `_ + - **Purpose** (int) - (Required) 短信模板用途类型:1-验证码类短信模板;2-系统通知类短信模板;3-会员推广类短信模板; + - **Template** (str) - (Required) 短信模板内容,说明如下:字数不超过500,每个中文、符号、英文、数组等都计为一个字;模板中的变量填写格式:{N},其中N为大于1的整数,有多个参数时,建议N从1开始顺次,例如:{1}、{2}等;短信模板禁止仅包括变量的情况; + - **TemplateName** (str) - (Required) 短信模板名称,不超过32个字符,每个中文、符号、英文、数字等都计为1个字。 + - **Remark** (str) - 短信模板申请原因说明,字数不超过128,每个中文、符号、英文、数字等都计为1个字。 + - **UnsubscribeInfo** (str) - 当Purpose为3时,也即会员推广类短信模板,该项必填。枚举值:TD退订、回T退订、回N退订、回TD退订、退订回T、退订回D、退订回TD、退订回复T、退订回复D、退订回复N、退订回复TD、拒收回T + - **Zone** (str) - 可用区。参见 `可用区列表 `_ + + **Response** + + - **Message** (str) - 返回状态码描述,如果操作成功,默认返回为空 + - **TemplateId** (str) - 短信模板ID(短信模板申请时的工单ID) + + """ + # build request + d = {"ProjectId": self.config.project_id, "Region": self.config.region} + req and d.update(req) + d = apis.CreateUSMSTemplateRequestSchema().dumps(d) + + # build options + kwargs["max_retries"] = 0 # ignore retry when api is not idempotent + + resp = self.invoke("CreateUSMSTemplate", d, **kwargs) + return apis.CreateUSMSTemplateResponseSchema().loads(resp) + + def delete_usms_signature( + self, req: typing.Optional[dict] = None, **kwargs + ) -> dict: + """ DeleteUSMSSignature - 调用接口DeleteUSMSSignature删除短信签名 + + **Request** + + - **ProjectId** (str) - (Config) 项目ID,不填写为默认项目,子帐号必须填写。 请参考 `GetProjectList接口 `_ + - **SigIds** (list) - (Required) 签名ID(也即短信签名申请时的工单ID),支持以数组的方式,举例,以SigIds.0、SigIds.1...SigIds.N方式传入 + + **Response** + + - **Message** (str) - 返回状态码描述,如果操作成功,默认返回为空 + + """ + # build request + d = {"ProjectId": self.config.project_id} + req and d.update(req) + d = apis.DeleteUSMSSignatureRequestSchema().dumps(d) + + resp = self.invoke("DeleteUSMSSignature", d, **kwargs) + return apis.DeleteUSMSSignatureResponseSchema().loads(resp) + + def delete_usms_template( + self, req: typing.Optional[dict] = None, **kwargs + ) -> dict: + """ DeleteUSMSTemplate - 调用接口DeleteUSMSTemplate删除短信模板 + + **Request** + + - **ProjectId** (str) - (Config) 项目ID。不填写为默认项目,子帐号必须填写。 请参考 `GetProjectList接口 `_ + - **Region** (str) - (Config) 地域。 参见 `地域和可用区列表 `_ + - **TemplateIds** (list) - (Required) 模板ID(也即短信模板申请时的工单ID),支持以数组的方式,举例,以TemplateIds.0、TemplateIds.1...TemplateIds.N方式传入 + - **Zone** (str) - 可用区。参见 `可用区列表 `_ + + **Response** + + - **Message** (str) - 返回状态码描述,如果操作成功,默认返回为空 + + """ + # build request + d = {"ProjectId": self.config.project_id, "Region": self.config.region} + req and d.update(req) + d = apis.DeleteUSMSTemplateRequestSchema().dumps(d) + + resp = self.invoke("DeleteUSMSTemplate", d, **kwargs) + return apis.DeleteUSMSTemplateResponseSchema().loads(resp) + + def get_usms_send_receipt( + self, req: typing.Optional[dict] = None, **kwargs + ) -> dict: + """ GetUSMSSendReceipt - 获取短信发送回执信息。下游服务提供商回执信息返回会有一定延时,建议发送完短信以后,5-10分钟后再调用该接口拉取回执信息。若超过12小时未返回,则请联系技术支持确认原因 + + **Request** + + - **ProjectId** (str) - (Config) 项目ID。不填写为默认项目,子帐号必须填写。 请参考 `GetProjectList接口 `_ + - **Region** (str) - (Config) 地域。 参见 `地域和可用区列表 `_ + - **SessionNoSet** (list) - (Required) 发送短信时返回的SessionNo集合,SessionNoSet.0,SessionNoSet.1....格式 + - **Zone** (str) - 可用区。参见 `可用区列表 `_ + + **Response** + + - **Data** (list) - 见 **ReceiptPerSession** 模型定义 + - **Message** (str) - 错误描述 + + **Response Model** + + **ReceiptPerPhone** + + - **CostCount** (int) - 消耗短信条数 + - **Phone** (str) - 手机号码 + - **ReceiptDesc** (str) - 回执结果描述 + - **ReceiptResult** (str) - 回执结果 + - **ReceiptTime** (int) - 回执返回时间 + + **ReceiptPerSession** + + - **ReceiptSet** (list) - 见 **ReceiptPerPhone** 模型定义 + - **SessionNo** (str) - 发送短信时返回的SessionNo + + """ + # build request + d = {"ProjectId": self.config.project_id, "Region": self.config.region} + req and d.update(req) + d = apis.GetUSMSSendReceiptRequestSchema().dumps(d) + + resp = self.invoke("GetUSMSSendReceipt", d, **kwargs) + return apis.GetUSMSSendReceiptResponseSchema().loads(resp) + + def query_usms_signature( + self, req: typing.Optional[dict] = None, **kwargs + ) -> dict: + """ QueryUSMSSignature - 调用接口QueryUSMSSignature查询短信签名申请状态 + + **Request** + + - **ProjectId** (str) - (Config) 项目ID。不填写为默认项目,子帐号必须填写。 请参考 `GetProjectList接口 `_ + - **SigContent** (str) - 签名内容;签名ID和签名至少需填写1项; + - **SigId** (str) - 已申请的短信签名ID(短信签名申请时的工单ID);签名ID和签名至少需填写1项; + + **Response** + + - **Data** (dict) - 见 **OutSignature** 模型定义 + - **Message** (str) - 发生错误时,表示具体错误描述 + + **Response Model** + + **OutSignature** + + - **ErrDesc** (str) - 签名审核失败原因 + - **SigContent** (str) - 签名内容 + - **SigId** (str) - 签名ID + - **Status** (int) - 签名状态。0-待审核 1-审核中 2-审核通过 3-审核未通过 4-被禁用 + + """ + # build request + d = {"ProjectId": self.config.project_id} + req and d.update(req) + d = apis.QueryUSMSSignatureRequestSchema().dumps(d) + + resp = self.invoke("QueryUSMSSignature", d, **kwargs) + return apis.QueryUSMSSignatureResponseSchema().loads(resp) + + def query_usms_template( + self, req: typing.Optional[dict] = None, **kwargs + ) -> dict: + """ QueryUSMSTemplate - 调用接口QueryUSMSTemplate查询短信模板申请状态 + + **Request** + + - **ProjectId** (str) - (Config) 项目ID。不填写为默认项目,子帐号必须填写。 请参考 `GetProjectList接口 `_ + - **TemplateId** (str) - (Required) 模板ID + + **Response** + + - **Data** (dict) - 见 **OutTemplate** 模型定义 + - **Message** (str) - 当RetCode不为0时,Message中显示具体错误描述 + + **Response Model** + + **OutTemplate** + + - **CreateTime** (int) - 创建时间 + - **ErrDesc** (str) - 审核失败原因 + - **Purpose** (int) - 模板类型,选项:1-验证码类 2-通知类 3-会员推广类 + - **Remark** (str) - 模板说明 + - **Status** (int) - 短信模板状态;状态说明:0-待审核,1-审核中,2-审核通过,3-审核未通过,4-被禁用 + - **Template** (str) - 短信模板内容 + - **TemplateId** (str) - 短信模板ID + - **TemplateName** (str) - 短信模板名称 + - **UnsubscribeInfo** (str) - 退订信息;一般填写方式“回T退订”,当purpose为3(也即会员推广类)时,为必填项 + + """ + # build request + d = {"ProjectId": self.config.project_id} + req and d.update(req) + d = apis.QueryUSMSTemplateRequestSchema().dumps(d) + + resp = self.invoke("QueryUSMSTemplate", d, **kwargs) + return apis.QueryUSMSTemplateResponseSchema().loads(resp) + + def send_usms_message( + self, req: typing.Optional[dict] = None, **kwargs + ) -> dict: + """ SendUSMSMessage - 发送短信息。短信字数超过70个后,按照每66个进行切割(因为要加上1/3), 2/3)等字样,占用4个字长)。短信最大长度不能超过600个字。每个汉字、数字、字母、字符都按一个字计 + + **Request** + + - **ProjectId** (str) - (Config) 项目ID。不填写为默认项目,子帐号必须填写。 请参考 `GetProjectList接口 `_ + - **Region** (str) - (Config) 地域。 参见 `地域和可用区列表 `_ + - **PhoneNumbers** (list) - (Required) 电话号码数组,电话号码格式为(60)1xxxxxxxx,()中为国际长途区号(如中国为86或0086,两种格式都支持),后面为电话号码.若不传入国际区号,如1851623xxxx,则默认为国内手机号 + - **TemplateId** (str) - (Required) 模板ID。若指定的模板ID审核未通过(status不等于2)则不允许发送 + - **TemplateParams** (list) - (Required) 模板参数数组,以TempalteParams.0,TempalteParams.1.。。格式。若模板ID指定的模板无可变参数,则不传入该参数。模板参数个数与模板不匹配,则不允许发送 + - **SigContent** (str) - 使用的签名,如果不输入则使用默认签名,若没有申请默认签名不允许发送;若输入的签名没有申请,则无法发送 + - **Zone** (str) - 可用区。参见 `可用区列表 `_ + + **Response** + + - **Action** (str) - 操作名称 + - **Message** (str) - 发生错误时表示错误描述 + - **RetCode** (int) - 返回码 + - **SessionNo** (str) - 本次提交发送的短信的唯一ID,可根据该值查询本次发送的短信列表 + + """ + # build request + d = {"ProjectId": self.config.project_id, "Region": self.config.region} + req and d.update(req) + d = apis.SendUSMSMessageRequestSchema().dumps(d) + + # build options + kwargs["max_retries"] = 0 # ignore retry when api is not idempotent + + resp = self.invoke("SendUSMSMessage", d, **kwargs) + return apis.SendUSMSMessageResponseSchema().loads(resp) + + def update_usms_signature( + self, req: typing.Optional[dict] = None, **kwargs + ) -> dict: + """ UpdateUSMSSignature - 调用接口UpdateUSMSSignature修改未通过审核的短信签名,并重新提交审核 + + **Request** + + - **ProjectId** (str) - (Config) 项目ID,不填写为默认项目,子帐号必须填写。 请参考 `GetProjectList接口 `_ + - **File** (str) - (Required) 短信签名的资质证明文件,需先进行base64编码格式转换,此处填写转换后的字符串。文件大小不超过4 MB + - **SigContent** (str) - (Required) 新的短信签名名称;长度为2-12个字符, 可包含中文、数字和符号;无需填写【】或[],系统会自动添加 + - **SigId** (str) - (Required) 签名ID(也即短信签名申请时的工单ID),支持以数组的方式,举例,以SigIds.0、SigIds.1...SigIds.N方式传入 + - **SigPurpose** (int) - (Required) 签名用途,0-自用,1-他用; + - **SigType** (int) - (Required) 签名类型,说明如下:0-公司或企业的全称或简称;1-App应用的全称或简称;2-工信部备案网站的全称或简称;3-公众号或小程序的全称或简称;4-商标名的全称或简称;5-政府/机关事业单位/其他单位的全称或简称; + - **CertificateType** (int) - 签名的资质证明文件类型,需与签名类型保持一致,说明如下:0-三证合一/企业营业执照/组织机构代码证书/社会信用代码证书;1-应用商店后台开发者管理截图;2-备案服务商的备案成功截图(含域名,网站名称,备案号);3-公众号或小程序的管理界面截图;4-商标注册证书;5-组织机构代码证书、社会信用代码证书; + - **ProxyFile** (str) - 短信签名授权委托文件,需先进行base64编码格式转换,此处填写转换后的字符串。文件大小不超过4 MB;当您是代理并使用第三方的签名时(也即SigPurpose为1-他用),该项为必填项; + + **Response** + + - **Message** (str) - 返回状态码描述,如果操作成功,默认返回为空 + + """ + # build request + d = {"ProjectId": self.config.project_id} + req and d.update(req) + d = apis.UpdateUSMSSignatureRequestSchema().dumps(d) + + resp = self.invoke("UpdateUSMSSignature", d, **kwargs) + return apis.UpdateUSMSSignatureResponseSchema().loads(resp) + + def update_usms_template( + self, req: typing.Optional[dict] = None, **kwargs + ) -> dict: + """ UpdateUSMSTemplate - 调用接口UpdateUSMSTemplate修改未通过审核的短信模板,并重新提交审核 + + **Request** + + - **ProjectId** (str) - (Config) 项目ID。不填写为默认项目,子帐号必须填写。 请参考 `GetProjectList接口 `_ + - **Region** (str) - (Config) 地域。 参见 `地域和可用区列表 `_ + - **Template** (str) - (Required) 新的模板内容。模板名称和模板内容必须提供一个,否则会报错。小于等于600个字 + - **TemplateId** (str) - (Required) 短信模板ID + - **Remark** (str) - 短信模板申请原因说明,字数不超过128,每个中文、符号、英文、数字等都计为1个字。 + - **TemplateName** (str) - 新的模板名称。小于等于32个字,每个中文、英文、数组、符合都计为一个字 + - **UnsubscribeInfo** (str) - 当Purpose为3时,也即会员推广类短信模板,该项必填。枚举值:TD退订、回T退订、回N退订、回TD退订、退订回T、退订回D、退订回TD、退订回复T、退订回复D、退订回复N、退订回复TD、拒收回T + - **Zone** (str) - 可用区。参见 `可用区列表 `_ + + **Response** + + - **Message** (str) - 发生错误时表示错误描述 + + """ + # build request + d = {"ProjectId": self.config.project_id, "Region": self.config.region} + req and d.update(req) + d = apis.UpdateUSMSTemplateRequestSchema().dumps(d) + + resp = self.invoke("UpdateUSMSTemplate", d, **kwargs) + return apis.UpdateUSMSTemplateResponseSchema().loads(resp) diff --git a/ucloud/services/usms/schemas/__init__.py b/ucloud/services/usms/schemas/__init__.py new file mode 100644 index 00000000..e69de29b diff --git a/ucloud/services/usms/schemas/apis.py b/ucloud/services/usms/schemas/apis.py new file mode 100644 index 00000000..e966547b --- /dev/null +++ b/ucloud/services/usms/schemas/apis.py @@ -0,0 +1,311 @@ +""" Code is generated by ucloud-model, DO NOT EDIT IT. """ + +from ucloud.core.typesystem import schema, fields +from ucloud.services.usms.schemas import models + + +""" USMS API Schema +""" + + +""" +API: CreateUSMSSignature + +调用接口CreateUSMSSignature申请短信签名 +""" + + +class CreateUSMSSignatureRequestSchema(schema.RequestSchema): + """ CreateUSMSSignature - 调用接口CreateUSMSSignature申请短信签名 + """ + + fields = { + "CertificateType": fields.Int(required=True, dump_to="CertificateType"), + "Description": fields.Str(required=True, dump_to="Description"), + "File": fields.Str(required=True, dump_to="File"), + "ProjectId": fields.Str(required=True, dump_to="ProjectId"), + "ProxyFile": fields.Str(required=False, dump_to="ProxyFile"), + "SigContent": fields.Str(required=True, dump_to="SigContent"), + "SigPurpose": fields.Int(required=True, dump_to="SigPurpose"), + "SigType": fields.Int(required=True, dump_to="SigType"), + } + + +class CreateUSMSSignatureResponseSchema(schema.ResponseSchema): + """ CreateUSMSSignature - 调用接口CreateUSMSSignature申请短信签名 + """ + + fields = { + "Message": fields.Str(required=True, load_from="Message"), + "SigContent": fields.Str(required=False, load_from="SigContent"), + "SigId": fields.Str(required=False, load_from="SigId"), + } + + +""" +API: CreateUSMSTemplate + +调用接口CreateUSMSTemplate申请短信模板 +""" + + +class CreateUSMSTemplateRequestSchema(schema.RequestSchema): + """ CreateUSMSTemplate - 调用接口CreateUSMSTemplate申请短信模板 + """ + + fields = { + "ProjectId": fields.Str(required=True, dump_to="ProjectId"), + "Purpose": fields.Int(required=True, dump_to="Purpose"), + "Region": fields.Str(required=False, dump_to="Region"), + "Remark": fields.Str(required=False, dump_to="Remark"), + "Template": fields.Str(required=True, dump_to="Template"), + "TemplateName": fields.Str(required=True, dump_to="TemplateName"), + "UnsubscribeInfo": fields.Str( + required=False, dump_to="UnsubscribeInfo" + ), + "Zone": fields.Str(required=False, dump_to="Zone"), + } + + +class CreateUSMSTemplateResponseSchema(schema.ResponseSchema): + """ CreateUSMSTemplate - 调用接口CreateUSMSTemplate申请短信模板 + """ + + fields = { + "Message": fields.Str(required=True, load_from="Message"), + "TemplateId": fields.Str(required=True, load_from="TemplateId"), + } + + +""" +API: DeleteUSMSSignature + +调用接口DeleteUSMSSignature删除短信签名 +""" + + +class DeleteUSMSSignatureRequestSchema(schema.RequestSchema): + """ DeleteUSMSSignature - 调用接口DeleteUSMSSignature删除短信签名 + """ + + fields = { + "ProjectId": fields.Str(required=True, dump_to="ProjectId"), + "SigIds": fields.List(fields.Str()), + } + + +class DeleteUSMSSignatureResponseSchema(schema.ResponseSchema): + """ DeleteUSMSSignature - 调用接口DeleteUSMSSignature删除短信签名 + """ + + fields = {"Message": fields.Str(required=True, load_from="Message")} + + +""" +API: DeleteUSMSTemplate + +调用接口DeleteUSMSTemplate删除短信模板 +""" + + +class DeleteUSMSTemplateRequestSchema(schema.RequestSchema): + """ DeleteUSMSTemplate - 调用接口DeleteUSMSTemplate删除短信模板 + """ + + fields = { + "ProjectId": fields.Str(required=True, dump_to="ProjectId"), + "Region": fields.Str(required=False, dump_to="Region"), + "TemplateIds": fields.List(fields.Str()), + "Zone": fields.Str(required=False, dump_to="Zone"), + } + + +class DeleteUSMSTemplateResponseSchema(schema.ResponseSchema): + """ DeleteUSMSTemplate - 调用接口DeleteUSMSTemplate删除短信模板 + """ + + fields = {"Message": fields.Str(required=True, load_from="Message")} + + +""" +API: GetUSMSSendReceipt + +获取短信发送回执信息。下游服务提供商回执信息返回会有一定延时,建议发送完短信以后,5-10分钟后再调用该接口拉取回执信息。若超过12小时未返回,则请联系技术支持确认原因 +""" + + +class GetUSMSSendReceiptRequestSchema(schema.RequestSchema): + """ GetUSMSSendReceipt - 获取短信发送回执信息。下游服务提供商回执信息返回会有一定延时,建议发送完短信以后,5-10分钟后再调用该接口拉取回执信息。若超过12小时未返回,则请联系技术支持确认原因 + """ + + fields = { + "ProjectId": fields.Str(required=False, dump_to="ProjectId"), + "Region": fields.Str(required=False, dump_to="Region"), + "SessionNoSet": fields.List(fields.Str()), + "Zone": fields.Str(required=False, dump_to="Zone"), + } + + +class GetUSMSSendReceiptResponseSchema(schema.ResponseSchema): + """ GetUSMSSendReceipt - 获取短信发送回执信息。下游服务提供商回执信息返回会有一定延时,建议发送完短信以后,5-10分钟后再调用该接口拉取回执信息。若超过12小时未返回,则请联系技术支持确认原因 + """ + + fields = { + "Data": fields.List( + models.ReceiptPerSessionSchema(), required=True, load_from="Data" + ), + "Message": fields.Str(required=True, load_from="Message"), + } + + +""" +API: QueryUSMSSignature + +调用接口QueryUSMSSignature查询短信签名申请状态 +""" + + +class QueryUSMSSignatureRequestSchema(schema.RequestSchema): + """ QueryUSMSSignature - 调用接口QueryUSMSSignature查询短信签名申请状态 + """ + + fields = { + "ProjectId": fields.Str(required=False, dump_to="ProjectId"), + "SigContent": fields.Str(required=False, dump_to="SigContent"), + "SigId": fields.Str(required=False, dump_to="SigId"), + } + + +class QueryUSMSSignatureResponseSchema(schema.ResponseSchema): + """ QueryUSMSSignature - 调用接口QueryUSMSSignature查询短信签名申请状态 + """ + + fields = { + "Data": models.OutSignatureSchema(), + "Message": fields.Str(required=True, load_from="Message"), + } + + +""" +API: QueryUSMSTemplate + +调用接口QueryUSMSTemplate查询短信模板申请状态 +""" + + +class QueryUSMSTemplateRequestSchema(schema.RequestSchema): + """ QueryUSMSTemplate - 调用接口QueryUSMSTemplate查询短信模板申请状态 + """ + + fields = { + "ProjectId": fields.Str(required=True, dump_to="ProjectId"), + "TemplateId": fields.Str(required=True, dump_to="TemplateId"), + } + + +class QueryUSMSTemplateResponseSchema(schema.ResponseSchema): + """ QueryUSMSTemplate - 调用接口QueryUSMSTemplate查询短信模板申请状态 + """ + + fields = { + "Data": models.OutTemplateSchema(), + "Message": fields.Str(required=False, load_from="Message"), + } + + +""" +API: SendUSMSMessage + +发送短信息。短信字数超过70个后,按照每66个进行切割(因为要加上1/3), 2/3)等字样,占用4个字长)。短信最大长度不能超过600个字。每个汉字、数字、字母、字符都按一个字计 +""" + + +class SendUSMSMessageRequestSchema(schema.RequestSchema): + """ SendUSMSMessage - 发送短信息。短信字数超过70个后,按照每66个进行切割(因为要加上1/3), 2/3)等字样,占用4个字长)。短信最大长度不能超过600个字。每个汉字、数字、字母、字符都按一个字计 + """ + + fields = { + "PhoneNumbers": fields.List(fields.Str()), + "ProjectId": fields.Str(required=False, dump_to="ProjectId"), + "Region": fields.Str(required=False, dump_to="Region"), + "SigContent": fields.Str(required=False, dump_to="SigContent"), + "TemplateId": fields.Str(required=True, dump_to="TemplateId"), + "TemplateParams": fields.List(fields.Str()), + "Zone": fields.Str(required=False, dump_to="Zone"), + } + + +class SendUSMSMessageResponseSchema(schema.ResponseSchema): + """ SendUSMSMessage - 发送短信息。短信字数超过70个后,按照每66个进行切割(因为要加上1/3), 2/3)等字样,占用4个字长)。短信最大长度不能超过600个字。每个汉字、数字、字母、字符都按一个字计 + """ + + fields = { + "Action": fields.Str(required=True, load_from="Action"), + "Message": fields.Str(required=True, load_from="Message"), + "RetCode": fields.Int(required=True, load_from="RetCode"), + "SessionNo": fields.Str(required=False, load_from="SessionNo"), + } + + +""" +API: UpdateUSMSSignature + +调用接口UpdateUSMSSignature修改未通过审核的短信签名,并重新提交审核 +""" + + +class UpdateUSMSSignatureRequestSchema(schema.RequestSchema): + """ UpdateUSMSSignature - 调用接口UpdateUSMSSignature修改未通过审核的短信签名,并重新提交审核 + """ + + fields = { + "CertificateType": fields.Int( + required=False, dump_to="CertificateType" + ), + "File": fields.Str(required=True, dump_to="File"), + "ProjectId": fields.Str(required=True, dump_to="ProjectId"), + "ProxyFile": fields.Str(required=False, dump_to="ProxyFile"), + "SigContent": fields.Str(required=True, dump_to="SigContent"), + "SigId": fields.Str(required=True, dump_to="SigId"), + "SigPurpose": fields.Int(required=True, dump_to="SigPurpose"), + "SigType": fields.Int(required=True, dump_to="SigType"), + } + + +class UpdateUSMSSignatureResponseSchema(schema.ResponseSchema): + """ UpdateUSMSSignature - 调用接口UpdateUSMSSignature修改未通过审核的短信签名,并重新提交审核 + """ + + fields = {"Message": fields.Str(required=True, load_from="Message")} + + +""" +API: UpdateUSMSTemplate + +调用接口UpdateUSMSTemplate修改未通过审核的短信模板,并重新提交审核 +""" + + +class UpdateUSMSTemplateRequestSchema(schema.RequestSchema): + """ UpdateUSMSTemplate - 调用接口UpdateUSMSTemplate修改未通过审核的短信模板,并重新提交审核 + """ + + fields = { + "ProjectId": fields.Str(required=True, dump_to="ProjectId"), + "Region": fields.Str(required=False, dump_to="Region"), + "Remark": fields.Str(required=False, dump_to="Remark"), + "Template": fields.Str(required=True, dump_to="Template"), + "TemplateId": fields.Str(required=True, dump_to="TemplateId"), + "TemplateName": fields.Str(required=False, dump_to="TemplateName"), + "UnsubscribeInfo": fields.Str( + required=False, dump_to="UnsubscribeInfo" + ), + "Zone": fields.Str(required=False, dump_to="Zone"), + } + + +class UpdateUSMSTemplateResponseSchema(schema.ResponseSchema): + """ UpdateUSMSTemplate - 调用接口UpdateUSMSTemplate修改未通过审核的短信模板,并重新提交审核 + """ + + fields = {"Message": fields.Str(required=True, load_from="Message")} diff --git a/ucloud/services/usms/schemas/models.py b/ucloud/services/usms/schemas/models.py new file mode 100644 index 00000000..02183df0 --- /dev/null +++ b/ucloud/services/usms/schemas/models.py @@ -0,0 +1,57 @@ +""" Code is generated by ucloud-model, DO NOT EDIT IT. """ + +from ucloud.core.typesystem import schema, fields + + +class ReceiptPerPhoneSchema(schema.ResponseSchema): + """ ReceiptPerPhone - 每个目的手机号的发送回执信息 + """ + + fields = { + "CostCount": fields.Int(required=True, load_from="CostCount"), + "Phone": fields.Str(required=True, load_from="Phone"), + "ReceiptDesc": fields.Str(required=True, load_from="ReceiptDesc"), + "ReceiptResult": fields.Str(required=True, load_from="ReceiptResult"), + "ReceiptTime": fields.Int(required=True, load_from="ReceiptTime"), + } + + +class ReceiptPerSessionSchema(schema.ResponseSchema): + """ ReceiptPerSession - 每个提交的回执结果集合 + """ + + fields = { + "ReceiptSet": fields.List(ReceiptPerPhoneSchema()), + "SessionNo": fields.Str(required=True, load_from="SessionNo"), + } + + +class OutSignatureSchema(schema.ResponseSchema): + """ OutSignature - 短信签名 + """ + + fields = { + "ErrDesc": fields.Str(required=True, load_from="ErrDesc"), + "SigContent": fields.Str(required=True, load_from="SigContent"), + "SigId": fields.Str(required=True, load_from="SigId"), + "Status": fields.Int(required=True, load_from="Status"), + } + + +class OutTemplateSchema(schema.ResponseSchema): + """ OutTemplate - 短信模板 + """ + + fields = { + "CreateTime": fields.Int(required=True, load_from="CreateTime"), + "ErrDesc": fields.Str(required=True, load_from="ErrDesc"), + "Purpose": fields.Int(required=True, load_from="Purpose"), + "Remark": fields.Str(required=True, load_from="Remark"), + "Status": fields.Int(required=True, load_from="Status"), + "Template": fields.Str(required=True, load_from="Template"), + "TemplateId": fields.Str(required=True, load_from="TemplateId"), + "TemplateName": fields.Str(required=True, load_from="TemplateName"), + "UnsubscribeInfo": fields.Str( + required=True, load_from="UnsubscribeInfo" + ), + } diff --git a/ucloud/testing/funcs.py b/ucloud/testing/funcs.py index 44b54111..832fdf36 100644 --- a/ucloud/testing/funcs.py +++ b/ucloud/testing/funcs.py @@ -63,6 +63,6 @@ def get_timestamp(length=13): :return: """ if isinstance(length, int) and 0 < length < 17: - return float("{:.6f}".format(time.time()).replace(".", "")[:length]) + return int("{:.6f}".format(time.time()).replace(".", "")[:length]) raise ValueError("timestamp length can only between 0 and 16.") diff --git a/ucloud/version.py b/ucloud/version.py index 5140fa1d..aaf05b32 100644 --- a/ucloud/version.py +++ b/ucloud/version.py @@ -1 +1 @@ -version = "0.4.0" +version = "0.6.0"