diff --git a/.github/CODEOWNERS b/.github/CODEOWNERS
index 6a60837b4f6..5789e31ffab 100644
--- a/.github/CODEOWNERS
+++ b/.github/CODEOWNERS
@@ -62,6 +62,8 @@
/src/healthcareapis/ @fengzhou-msft
+/src/healthbot/ @guy-microsoft
+
/src/hack/ @geektrainer
/src/internet-analyzer/ @jsntcy
diff --git a/src/healthbot/HISTORY.rst b/src/healthbot/HISTORY.rst
new file mode 100644
index 00000000000..1c139576ba0
--- /dev/null
+++ b/src/healthbot/HISTORY.rst
@@ -0,0 +1,8 @@
+.. :changelog:
+
+Release History
+===============
+
+0.1.0
+++++++
+* Initial release.
diff --git a/src/healthbot/README.md b/src/healthbot/README.md
new file mode 100644
index 00000000000..fe2f7295565
--- /dev/null
+++ b/src/healthbot/README.md
@@ -0,0 +1,33 @@
+# Azure CLI healthbot Extension #
+This is the extension for healthbot.
+The Azure Health Bot service empowers healthcare organizations to build and deploy an AI-powered, compliant, conversational healthcare experience at scale.
+The service combines built-in medical intelligence with natural language capabilities, extensibility tools and compliance constructs, allowing healthcare organizations such as Providers, Payers, Pharma, HMOs, Telehealth to give people access to trusted and relevant healthcare services and information.
+
+### How to use ###
+Install this extension using the below CLI command
+```
+az extension add --name healthbot
+```
+
+### Included Features ###
+#### healthbot ####
+##### Create #####
+```
+az healthbot create --name "samplebotname" --location "East US" --sku "F0" --resource-group "healthbotClient"
+```
+##### Show #####
+```
+az healthbot show --name "samplebotname" --resource-group "healthbotClient"
+```
+##### List #####
+```
+az healthbot list --resource-group "OneResourceGroupName"
+```
+##### Update #####
+```
+az healthbot update --name "samplebotname" --sku "F0" --resource-group "healthbotClient"
+```
+##### Delete #####
+```
+az healthbot delete --name "samplebotname" --resource-group "healthbotClient"
+```
\ No newline at end of file
diff --git a/src/healthbot/azext_healthbot/__init__.py b/src/healthbot/azext_healthbot/__init__.py
new file mode 100644
index 00000000000..87fd2372742
--- /dev/null
+++ b/src/healthbot/azext_healthbot/__init__.py
@@ -0,0 +1,50 @@
+# --------------------------------------------------------------------------
+# Copyright (c) Microsoft Corporation. All rights reserved.
+# Licensed under the MIT License. See License.txt in the project root for
+# license information.
+#
+# Code generated by Microsoft (R) AutoRest Code Generator.
+# Changes may cause incorrect behavior and will be lost if the code is
+# regenerated.
+# --------------------------------------------------------------------------
+
+from azure.cli.core import AzCommandsLoader
+from azext_healthbot.generated._help import helps # pylint: disable=unused-import
+try:
+ from azext_healthbot.manual._help import helps # pylint: disable=reimported
+except ImportError:
+ pass
+
+
+class HealthbotClientCommandsLoader(AzCommandsLoader):
+
+ def __init__(self, cli_ctx=None):
+ from azure.cli.core.commands import CliCommandType
+ from azext_healthbot.generated._client_factory import cf_healthbot_cl
+ healthbot_custom = CliCommandType(
+ operations_tmpl='azext_healthbot.custom#{}',
+ client_factory=cf_healthbot_cl)
+ parent = super(HealthbotClientCommandsLoader, self)
+ parent.__init__(cli_ctx=cli_ctx, custom_command_type=healthbot_custom)
+
+ def load_command_table(self, args):
+ from azext_healthbot.generated.commands import load_command_table
+ load_command_table(self, args)
+ try:
+ from azext_healthbot.manual.commands import load_command_table as load_command_table_manual
+ load_command_table_manual(self, args)
+ except ImportError:
+ pass
+ return self.command_table
+
+ def load_arguments(self, command):
+ from azext_healthbot.generated._params import load_arguments
+ load_arguments(self, command)
+ try:
+ from azext_healthbot.manual._params import load_arguments as load_arguments_manual
+ load_arguments_manual(self, command)
+ except ImportError:
+ pass
+
+
+COMMAND_LOADER_CLS = HealthbotClientCommandsLoader
diff --git a/src/healthbot/azext_healthbot/action.py b/src/healthbot/azext_healthbot/action.py
new file mode 100644
index 00000000000..d95d53bf711
--- /dev/null
+++ b/src/healthbot/azext_healthbot/action.py
@@ -0,0 +1,17 @@
+# --------------------------------------------------------------------------
+# Copyright (c) Microsoft Corporation. All rights reserved.
+# Licensed under the MIT License. See License.txt in the project root for
+# license information.
+#
+# Code generated by Microsoft (R) AutoRest Code Generator.
+# Changes may cause incorrect behavior and will be lost if the code is
+# regenerated.
+# --------------------------------------------------------------------------
+# pylint: disable=wildcard-import
+# pylint: disable=unused-wildcard-import
+
+from .generated.action import * # noqa: F403
+try:
+ from .manual.action import * # noqa: F403
+except ImportError:
+ pass
diff --git a/src/healthbot/azext_healthbot/azext_metadata.json b/src/healthbot/azext_healthbot/azext_metadata.json
new file mode 100644
index 00000000000..cfc30c747c7
--- /dev/null
+++ b/src/healthbot/azext_healthbot/azext_metadata.json
@@ -0,0 +1,4 @@
+{
+ "azext.isExperimental": true,
+ "azext.minCliCoreVersion": "2.15.0"
+}
\ No newline at end of file
diff --git a/src/healthbot/azext_healthbot/custom.py b/src/healthbot/azext_healthbot/custom.py
new file mode 100644
index 00000000000..dbe9d5f9742
--- /dev/null
+++ b/src/healthbot/azext_healthbot/custom.py
@@ -0,0 +1,17 @@
+# --------------------------------------------------------------------------
+# Copyright (c) Microsoft Corporation. All rights reserved.
+# Licensed under the MIT License. See License.txt in the project root for
+# license information.
+#
+# Code generated by Microsoft (R) AutoRest Code Generator.
+# Changes may cause incorrect behavior and will be lost if the code is
+# regenerated.
+# --------------------------------------------------------------------------
+# pylint: disable=wildcard-import
+# pylint: disable=unused-wildcard-import
+
+from .generated.custom import * # noqa: F403
+try:
+ from .manual.custom import * # noqa: F403
+except ImportError:
+ pass
diff --git a/src/healthbot/azext_healthbot/generated/__init__.py b/src/healthbot/azext_healthbot/generated/__init__.py
new file mode 100644
index 00000000000..c9cfdc73e77
--- /dev/null
+++ b/src/healthbot/azext_healthbot/generated/__init__.py
@@ -0,0 +1,12 @@
+# coding=utf-8
+# --------------------------------------------------------------------------
+# Copyright (c) Microsoft Corporation. All rights reserved.
+# Licensed under the MIT License. See License.txt in the project root for
+# license information.
+#
+# Code generated by Microsoft (R) AutoRest Code Generator.
+# Changes may cause incorrect behavior and will be lost if the code is
+# regenerated.
+# --------------------------------------------------------------------------
+
+__path__ = __import__('pkgutil').extend_path(__path__, __name__)
diff --git a/src/healthbot/azext_healthbot/generated/_client_factory.py b/src/healthbot/azext_healthbot/generated/_client_factory.py
new file mode 100644
index 00000000000..1bf018adaa1
--- /dev/null
+++ b/src/healthbot/azext_healthbot/generated/_client_factory.py
@@ -0,0 +1,20 @@
+# --------------------------------------------------------------------------
+# Copyright (c) Microsoft Corporation. All rights reserved.
+# Licensed under the MIT License. See License.txt in the project root for
+# license information.
+#
+# Code generated by Microsoft (R) AutoRest Code Generator.
+# Changes may cause incorrect behavior and will be lost if the code is
+# regenerated.
+# --------------------------------------------------------------------------
+
+
+def cf_healthbot_cl(cli_ctx, *_):
+ from azure.cli.core.commands.client_factory import get_mgmt_service_client
+ from azext_healthbot.vendored_sdks.healthbot import HealthbotClient
+ return get_mgmt_service_client(cli_ctx,
+ HealthbotClient)
+
+
+def cf_bot(cli_ctx, *_):
+ return cf_healthbot_cl(cli_ctx).bots
diff --git a/src/healthbot/azext_healthbot/generated/_help.py b/src/healthbot/azext_healthbot/generated/_help.py
new file mode 100644
index 00000000000..14da801aca8
--- /dev/null
+++ b/src/healthbot/azext_healthbot/generated/_help.py
@@ -0,0 +1,80 @@
+# --------------------------------------------------------------------------
+# Copyright (c) Microsoft Corporation. All rights reserved.
+# Licensed under the MIT License. See License.txt in the project root for
+# license information.
+#
+# Code generated by Microsoft (R) AutoRest Code Generator.
+# Changes may cause incorrect behavior and will be lost if the code is
+# regenerated.
+# --------------------------------------------------------------------------
+# pylint: disable=too-many-lines
+
+from knack.help_files import helps
+
+
+helps['healthbot'] = """
+ type: group
+ short-summary: Manage bot with healthbot
+"""
+
+helps['healthbot list'] = """
+ type: command
+ short-summary: "Returns all the resources of a particular type belonging to a resource group And Returns all the \
+resources of a particular type belonging to a subscription."
+ examples:
+ - name: List Bots by Resource Group
+ text: |-
+ az healthbot list --resource-group "OneResourceGroupName"
+ - name: List Bots by Subscription
+ text: |-
+ az healthbot list
+"""
+
+helps['healthbot show'] = """
+ type: command
+ short-summary: "Get a HealthBot."
+ examples:
+ - name: ResourceInfoGet
+ text: |-
+ az healthbot show --name "samplebotname" --resource-group "healthbotClient"
+"""
+
+helps['healthbot create'] = """
+ type: command
+ short-summary: "Create a new HealthBot."
+ examples:
+ - name: BotCreate
+ text: |-
+ az healthbot create --name "samplebotname" --location "East US" --sku "F0" --resource-group \
+"healthbotClient"
+"""
+
+helps['healthbot update'] = """
+ type: command
+ short-summary: "Patch a HealthBot."
+ examples:
+ - name: BotUpdate
+ text: |-
+ az healthbot update --bot-name "samplebotname" --name "F0" --resource-group "healthbotClient"
+"""
+
+helps['healthbot delete'] = """
+ type: command
+ short-summary: "Delete a HealthBot."
+ examples:
+ - name: BotDelete
+ text: |-
+ az healthbot delete --name "samplebotname" --resource-group "healthbotClient"
+"""
+
+helps['healthbot wait'] = """
+ type: command
+ short-summary: Place the CLI in a waiting state until a condition of the healthbot is met.
+ examples:
+ - name: Pause executing next line of CLI script until the healthbot is successfully created.
+ text: |-
+ az healthbot wait --name "samplebotname" --resource-group "healthbotClient" --created
+ - name: Pause executing next line of CLI script until the healthbot is successfully deleted.
+ text: |-
+ az healthbot wait --name "samplebotname" --resource-group "healthbotClient" --deleted
+"""
diff --git a/src/healthbot/azext_healthbot/generated/_params.py b/src/healthbot/azext_healthbot/generated/_params.py
new file mode 100644
index 00000000000..71c4f46116c
--- /dev/null
+++ b/src/healthbot/azext_healthbot/generated/_params.py
@@ -0,0 +1,56 @@
+# --------------------------------------------------------------------------
+# Copyright (c) Microsoft Corporation. All rights reserved.
+# Licensed under the MIT License. See License.txt in the project root for
+# license information.
+#
+# Code generated by Microsoft (R) AutoRest Code Generator.
+# Changes may cause incorrect behavior and will be lost if the code is
+# regenerated.
+# --------------------------------------------------------------------------
+# pylint: disable=too-many-lines
+# pylint: disable=too-many-statements
+
+from azure.cli.core.commands.parameters import (
+ tags_type,
+ get_enum_type,
+ resource_group_name_type,
+ get_location_type
+)
+from azure.cli.core.commands.validators import get_default_location_from_resource_group
+
+
+def load_arguments(self, _):
+
+ with self.argument_context('healthbot list') as c:
+ c.argument('resource_group_name', resource_group_name_type)
+
+ with self.argument_context('healthbot show') as c:
+ c.argument('resource_group_name', resource_group_name_type)
+ c.argument('bot_name', options_list=['--name', '-n', '--bot-name'], type=str, help='The name of the Bot '
+ 'resource.', id_part='name')
+
+ with self.argument_context('healthbot create') as c:
+ c.argument('resource_group_name', resource_group_name_type)
+ c.argument('bot_name', options_list=['--name', '-n', '--bot-name'], type=str, help='The name of the Bot resource.')
+ c.argument('tags', tags_type)
+ c.argument('location', arg_type=get_location_type(self.cli_ctx), required=False,
+ validator=get_default_location_from_resource_group)
+ c.argument('sku', arg_type=get_enum_type(['F0', 'S1', 'C0']), help='The name of the HealthBot SKU',
+ arg_group='Sku')
+
+ with self.argument_context('healthbot update') as c:
+ c.argument('resource_group_name', resource_group_name_type)
+ c.argument('bot_name', options_list=['--name', '-n', '--bot-name'], type=str, help='The name of the Bot resource.', id_part='name')
+ c.argument('tags', tags_type)
+ c.argument('sku', arg_type=get_enum_type(['F0', 'S1', 'C0']), help='The name of the HealthBot SKU',
+ arg_group='Sku')
+
+ with self.argument_context('healthbot delete') as c:
+ c.argument('resource_group_name', resource_group_name_type)
+ c.argument('bot_name', options_list=['--name', '-n', '--bot-name'], type=str, help='The name of the Bot '
+ 'resource.', id_part='name')
+
+ with self.argument_context('healthbot wait') as c:
+ c.argument('resource_group_name', resource_group_name_type)
+ c.argument('bot_name', options_list=['--name', '-n', '--bot-name'], type=str, help='The name of the Bot '
+ 'resource.', id_part='name')
diff --git a/src/healthbot/azext_healthbot/generated/_validators.py b/src/healthbot/azext_healthbot/generated/_validators.py
new file mode 100644
index 00000000000..b33a44c1ebf
--- /dev/null
+++ b/src/healthbot/azext_healthbot/generated/_validators.py
@@ -0,0 +1,9 @@
+# --------------------------------------------------------------------------
+# Copyright (c) Microsoft Corporation. All rights reserved.
+# Licensed under the MIT License. See License.txt in the project root for
+# license information.
+#
+# Code generated by Microsoft (R) AutoRest Code Generator.
+# Changes may cause incorrect behavior and will be lost if the code is
+# regenerated.
+# --------------------------------------------------------------------------
diff --git a/src/healthbot/azext_healthbot/generated/action.py b/src/healthbot/azext_healthbot/generated/action.py
new file mode 100644
index 00000000000..b49bfaeeefe
--- /dev/null
+++ b/src/healthbot/azext_healthbot/generated/action.py
@@ -0,0 +1,10 @@
+# --------------------------------------------------------------------------
+# Copyright (c) Microsoft Corporation. All rights reserved.
+# Licensed under the MIT License. See License.txt in the project root for
+# license information.
+#
+# Code generated by Microsoft (R) AutoRest Code Generator.
+# Changes may cause incorrect behavior and will be lost if the code is
+# regenerated.
+# --------------------------------------------------------------------------
+# pylint: disable=protected-access
diff --git a/src/healthbot/azext_healthbot/generated/commands.py b/src/healthbot/azext_healthbot/generated/commands.py
new file mode 100644
index 00000000000..8d6e3785df6
--- /dev/null
+++ b/src/healthbot/azext_healthbot/generated/commands.py
@@ -0,0 +1,28 @@
+# --------------------------------------------------------------------------
+# Copyright (c) Microsoft Corporation. All rights reserved.
+# Licensed under the MIT License. See License.txt in the project root for
+# license information.
+#
+# Code generated by Microsoft (R) AutoRest Code Generator.
+# Changes may cause incorrect behavior and will be lost if the code is
+# regenerated.
+# --------------------------------------------------------------------------
+# pylint: disable=too-many-statements
+# pylint: disable=too-many-locals
+
+from azure.cli.core.commands import CliCommandType
+
+
+def load_command_table(self, _):
+
+ from azext_healthbot.generated._client_factory import cf_bot
+ healthbot_bot = CliCommandType(
+ operations_tmpl='azext_healthbot.vendored_sdks.healthbot.operations._bots_operations#BotsOperations.{}',
+ client_factory=cf_bot)
+ with self.command_group('healthbot', healthbot_bot, client_factory=cf_bot, is_experimental=True) as g:
+ g.custom_command('list', 'healthbot_list')
+ g.custom_show_command('show', 'healthbot_show')
+ g.custom_command('create', 'healthbot_create', supports_no_wait=True)
+ g.custom_command('update', 'healthbot_update')
+ g.custom_command('delete', 'healthbot_delete', supports_no_wait=True, confirmation=True)
+ g.custom_wait_command('wait', 'healthbot_show')
diff --git a/src/healthbot/azext_healthbot/generated/custom.py b/src/healthbot/azext_healthbot/generated/custom.py
new file mode 100644
index 00000000000..469d339e352
--- /dev/null
+++ b/src/healthbot/azext_healthbot/generated/custom.py
@@ -0,0 +1,69 @@
+# --------------------------------------------------------------------------
+# Copyright (c) Microsoft Corporation. All rights reserved.
+# Licensed under the MIT License. See License.txt in the project root for
+# license information.
+#
+# Code generated by Microsoft (R) AutoRest Code Generator.
+# Changes may cause incorrect behavior and will be lost if the code is
+# regenerated.
+# --------------------------------------------------------------------------
+# pylint: disable=too-many-lines
+
+from azure.cli.core.util import sdk_no_wait
+
+
+def healthbot_list(client,
+ resource_group_name=None):
+ if resource_group_name:
+ return client.list_by_resource_group(resource_group_name=resource_group_name)
+ return client.list()
+
+
+def healthbot_show(client,
+ resource_group_name,
+ bot_name):
+ return client.get(resource_group_name=resource_group_name,
+ bot_name=bot_name)
+
+
+def healthbot_create(client,
+ resource_group_name,
+ bot_name,
+ location,
+ sku,
+ tags=None,
+ no_wait=False):
+ parameters = {}
+ parameters['tags'] = tags
+ parameters['location'] = location
+ parameters['sku'] = {}
+ parameters['sku']['name'] = sku
+ return sdk_no_wait(no_wait,
+ client.begin_create,
+ resource_group_name=resource_group_name,
+ bot_name=bot_name,
+ parameters=parameters)
+
+
+def healthbot_update(client,
+ resource_group_name,
+ bot_name,
+ tags=None,
+ sku=None):
+ parameters = {}
+ parameters['tags'] = tags
+ parameters['sku'] = {}
+ parameters['sku']['name'] = sku
+ return client.update(resource_group_name=resource_group_name,
+ bot_name=bot_name,
+ parameters=parameters)
+
+
+def healthbot_delete(client,
+ resource_group_name,
+ bot_name,
+ no_wait=False):
+ return sdk_no_wait(no_wait,
+ client.begin_delete,
+ resource_group_name=resource_group_name,
+ bot_name=bot_name)
diff --git a/src/healthbot/azext_healthbot/manual/__init__.py b/src/healthbot/azext_healthbot/manual/__init__.py
new file mode 100644
index 00000000000..c9cfdc73e77
--- /dev/null
+++ b/src/healthbot/azext_healthbot/manual/__init__.py
@@ -0,0 +1,12 @@
+# coding=utf-8
+# --------------------------------------------------------------------------
+# Copyright (c) Microsoft Corporation. All rights reserved.
+# Licensed under the MIT License. See License.txt in the project root for
+# license information.
+#
+# Code generated by Microsoft (R) AutoRest Code Generator.
+# Changes may cause incorrect behavior and will be lost if the code is
+# regenerated.
+# --------------------------------------------------------------------------
+
+__path__ = __import__('pkgutil').extend_path(__path__, __name__)
diff --git a/src/healthbot/azext_healthbot/tests/__init__.py b/src/healthbot/azext_healthbot/tests/__init__.py
new file mode 100644
index 00000000000..70488e93851
--- /dev/null
+++ b/src/healthbot/azext_healthbot/tests/__init__.py
@@ -0,0 +1,116 @@
+# coding=utf-8
+# --------------------------------------------------------------------------
+# Copyright (c) Microsoft Corporation. All rights reserved.
+# Licensed under the MIT License. See License.txt in the project root for
+# license information.
+#
+# Code generated by Microsoft (R) AutoRest Code Generator.
+# Changes may cause incorrect behavior and will be lost if the code is
+# regenerated.
+# --------------------------------------------------------------------------
+import inspect
+import logging
+import os
+import sys
+import traceback
+import datetime as dt
+
+from azure.core.exceptions import AzureError
+from azure.cli.testsdk.exceptions import CliTestError, CliExecutionError, JMESPathCheckAssertionError
+
+
+logger = logging.getLogger('azure.cli.testsdk')
+logger.addHandler(logging.StreamHandler())
+__path__ = __import__('pkgutil').extend_path(__path__, __name__)
+exceptions = []
+test_map = dict()
+SUCCESSED = "successed"
+FAILED = "failed"
+
+
+def try_manual(func):
+ def import_manual_function(origin_func):
+ from importlib import import_module
+ decorated_path = inspect.getfile(origin_func).lower()
+ module_path = __path__[0].lower()
+ if not decorated_path.startswith(module_path):
+ raise Exception("Decorator can only be used in submodules!")
+ manual_path = os.path.join(
+ decorated_path[module_path.rfind(os.path.sep) + 1:])
+ manual_file_path, manual_file_name = os.path.split(manual_path)
+ module_name, _ = os.path.splitext(manual_file_name)
+ manual_module = "..manual." + \
+ ".".join(manual_file_path.split(os.path.sep) + [module_name, ])
+ return getattr(import_module(manual_module, package=__name__), origin_func.__name__)
+
+ def get_func_to_call():
+ func_to_call = func
+ try:
+ func_to_call = import_manual_function(func)
+ logger.info("Found manual override for %s(...)", func.__name__)
+ except (ImportError, AttributeError):
+ pass
+ return func_to_call
+
+ def wrapper(*args, **kwargs):
+ func_to_call = get_func_to_call()
+ logger.info("running %s()...", func.__name__)
+ try:
+ test_map[func.__name__] = dict()
+ test_map[func.__name__]["result"] = SUCCESSED
+ test_map[func.__name__]["error_message"] = ""
+ test_map[func.__name__]["error_stack"] = ""
+ test_map[func.__name__]["error_normalized"] = ""
+ test_map[func.__name__]["start_dt"] = dt.datetime.utcnow()
+ ret = func_to_call(*args, **kwargs)
+ except (AssertionError, AzureError, CliTestError, CliExecutionError, SystemExit,
+ JMESPathCheckAssertionError) as e:
+ use_exception_cache = os.getenv("TEST_EXCEPTION_CACHE")
+ if use_exception_cache is None or use_exception_cache.lower() != "true":
+ raise
+ test_map[func.__name__]["end_dt"] = dt.datetime.utcnow()
+ test_map[func.__name__]["result"] = FAILED
+ test_map[func.__name__]["error_message"] = str(e).replace("\r\n", " ").replace("\n", " ")[:500]
+ test_map[func.__name__]["error_stack"] = traceback.format_exc().replace(
+ "\r\n", " ").replace("\n", " ")[:500]
+ logger.info("--------------------------------------")
+ logger.info("step exception: %s", e)
+ logger.error("--------------------------------------")
+ logger.error("step exception in %s: %s", func.__name__, e)
+ logger.info(traceback.format_exc())
+ exceptions.append((func.__name__, sys.exc_info()))
+ else:
+ test_map[func.__name__]["end_dt"] = dt.datetime.utcnow()
+ return ret
+
+ if inspect.isclass(func):
+ return get_func_to_call()
+ return wrapper
+
+
+def calc_coverage(filename):
+ filename = filename.split(".")[0]
+ coverage_name = filename + "_coverage.md"
+ with open(coverage_name, "w") as f:
+ f.write("|Scenario|Result|ErrorMessage|ErrorStack|ErrorNormalized|StartDt|EndDt|\n")
+ total = len(test_map)
+ covered = 0
+ for k, v in test_map.items():
+ if not k.startswith("step_"):
+ total -= 1
+ continue
+ if v["result"] == SUCCESSED:
+ covered += 1
+ f.write("|{step_name}|{result}|{error_message}|{error_stack}|{error_normalized}|{start_dt}|"
+ "{end_dt}|\n".format(step_name=k, **v))
+ f.write("Coverage: {}/{}\n".format(covered, total))
+ print("Create coverage\n", file=sys.stderr)
+
+
+def raise_if():
+ if exceptions:
+ if len(exceptions) <= 1:
+ raise exceptions[0][1][1]
+ message = "{}\nFollowed with exceptions in other steps:\n".format(str(exceptions[0][1][1]))
+ message += "\n".join(["{}: {}".format(h[0], h[1][1]) for h in exceptions[1:]])
+ raise exceptions[0][1][0](message).with_traceback(exceptions[0][1][2])
diff --git a/src/healthbot/azext_healthbot/tests/latest/__init__.py b/src/healthbot/azext_healthbot/tests/latest/__init__.py
new file mode 100644
index 00000000000..c9cfdc73e77
--- /dev/null
+++ b/src/healthbot/azext_healthbot/tests/latest/__init__.py
@@ -0,0 +1,12 @@
+# coding=utf-8
+# --------------------------------------------------------------------------
+# Copyright (c) Microsoft Corporation. All rights reserved.
+# Licensed under the MIT License. See License.txt in the project root for
+# license information.
+#
+# Code generated by Microsoft (R) AutoRest Code Generator.
+# Changes may cause incorrect behavior and will be lost if the code is
+# regenerated.
+# --------------------------------------------------------------------------
+
+__path__ = __import__('pkgutil').extend_path(__path__, __name__)
diff --git a/src/healthbot/azext_healthbot/tests/latest/example_steps.py b/src/healthbot/azext_healthbot/tests/latest/example_steps.py
new file mode 100644
index 00000000000..51959a29e34
--- /dev/null
+++ b/src/healthbot/azext_healthbot/tests/latest/example_steps.py
@@ -0,0 +1,79 @@
+# --------------------------------------------------------------------------
+# Copyright (c) Microsoft Corporation. All rights reserved.
+# Licensed under the MIT License. See License.txt in the project root for
+# license information.
+#
+# Code generated by Microsoft (R) AutoRest Code Generator.
+# Changes may cause incorrect behavior and will be lost if the code is
+# regenerated.
+# --------------------------------------------------------------------------
+
+
+from .. import try_manual
+
+
+# EXAMPLE: /Bots/put/BotCreate
+@try_manual
+def step_create(test, rg, rg_2, checks=None):
+ if checks is None:
+ checks = []
+ test.cmd('az healthbot create '
+ '--name "{myBot}" '
+ '--location "eastus" '
+ '--sku "F0" '
+ '--resource-group "{rg}"',
+ checks=checks)
+
+
+# EXAMPLE: /Bots/get/List Bots by Resource Group
+@try_manual
+def step_list(test, rg, rg_2, checks=None):
+ if checks is None:
+ checks = []
+ test.cmd('az healthbot list '
+ '--resource-group "{rg}"',
+ checks=checks)
+
+
+# EXAMPLE: /Bots/get/List Bots by Subscription
+@try_manual
+def step_list2(test, rg, rg_2, checks=None):
+ if checks is None:
+ checks = []
+ test.cmd('az healthbot list '
+ '-g ""',
+ checks=checks)
+
+
+# EXAMPLE: /Bots/get/ResourceInfoGet
+@try_manual
+def step_show(test, rg, rg_2, checks=None):
+ if checks is None:
+ checks = []
+ test.cmd('az healthbot show '
+ '--name "{myBot}" '
+ '--resource-group "{rg}"',
+ checks=checks)
+
+
+# EXAMPLE: /Bots/patch/BotUpdate
+@try_manual
+def step_update(test, rg, rg_2, checks=None):
+ if checks is None:
+ checks = []
+ test.cmd('az healthbot update '
+ '--name "{myBot}" '
+ '--sku "F0" '
+ '--resource-group "{rg}"',
+ checks=checks)
+
+
+# EXAMPLE: /Bots/delete/BotDelete
+@try_manual
+def step_delete(test, rg, rg_2, checks=None):
+ if checks is None:
+ checks = []
+ test.cmd('az healthbot delete -y '
+ '--name "{myBot}" '
+ '--resource-group "{rg}"',
+ checks=checks)
diff --git a/src/healthbot/azext_healthbot/tests/latest/recordings/test_healthbot_Scenario.yaml b/src/healthbot/azext_healthbot/tests/latest/recordings/test_healthbot_Scenario.yaml
new file mode 100644
index 00000000000..0a3afb1c080
--- /dev/null
+++ b/src/healthbot/azext_healthbot/tests/latest/recordings/test_healthbot_Scenario.yaml
@@ -0,0 +1,490 @@
+interactions:
+- request:
+ body: '{"location": "eastus", "sku": {"name": "F0"}}'
+ headers:
+ Accept:
+ - application/json
+ Accept-Encoding:
+ - gzip, deflate
+ CommandName:
+ - healthbot create
+ Connection:
+ - keep-alive
+ Content-Length:
+ - '45'
+ Content-Type:
+ - application/json
+ ParameterSetName:
+ - --name --location --sku --resource-group
+ User-Agent:
+ - AZURECLI/2.18.0 azsdk-python-mgmt-healthbot/2020-10-20-preview Python/3.8.7
+ (Windows-10-10.0.19041-SP0)
+ method: PUT
+ uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/clitest000001/providers/Microsoft.HealthBot/healthBots/samplebotname?api-version=2020-12-08
+ response:
+ body:
+ string: '{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/clitest000001/providers/Microsoft.HealthBot/healthBots/samplebotname","name":"samplebotname","type":"Microsoft.HealthBot/healthBots","sku":{"name":"F0"},"location":"eastus","systemData":{"createdBy":"guepsh@microsoft.com","createdByType":"User","createdAt":"2021-02-07T12:08:39.8022985Z","lastModifiedBy":"guepsh@microsoft.com","lastModifiedByType":"User","lastModifiedAt":"2021-02-07T12:08:39.8022985Z"},"properties":{"provisioningState":"Accepted"}}'
+ headers:
+ azure-asyncoperation:
+ - https://management.azure.com/providers/Microsoft.HealthBot/locations/EASTUS/operationStatuses/887e298d-4e9c-4764-86f5-86878dbdb038?api-version=2020-12-08
+ cache-control:
+ - no-cache
+ content-length:
+ - '532'
+ content-type:
+ - application/json; charset=utf-8
+ date:
+ - Sun, 07 Feb 2021 12:08:42 GMT
+ etag:
+ - '"a5040722-0000-0100-0000-601fd8490000"'
+ expires:
+ - '-1'
+ pragma:
+ - no-cache
+ request-context:
+ - appId=cid-v1:39ac773f-9efe-42dd-90ba-3ebab16f6587
+ server:
+ - Kestrel
+ set-cookie:
+ - admin.healthbot.sid=1612699722.129.36.709883; Max-Age=3600; Path=/; Secure;
+ HttpOnly
+ strict-transport-security:
+ - max-age=31536000; includeSubDomains
+ x-content-type-options:
+ - nosniff
+ x-dns-prefetch-control:
+ - 'off'
+ x-download-options:
+ - noopen
+ x-frame-options:
+ - SAMEORIGIN
+ x-ms-ratelimit-remaining-subscription-writes:
+ - '1199'
+ x-xss-protection:
+ - 1; mode=block
+ status:
+ code: 201
+ message: Created
+- request:
+ body: null
+ headers:
+ Accept:
+ - '*/*'
+ Accept-Encoding:
+ - gzip, deflate
+ CommandName:
+ - healthbot create
+ Connection:
+ - keep-alive
+ Cookie:
+ - admin.healthbot.sid=1612699722.129.36.709883
+ ParameterSetName:
+ - --name --location --sku --resource-group
+ User-Agent:
+ - AZURECLI/2.18.0 azsdk-python-mgmt-healthbot/2020-10-20-preview Python/3.8.7
+ (Windows-10-10.0.19041-SP0)
+ method: GET
+ uri: https://management.azure.com/providers/Microsoft.HealthBot/locations/EASTUS/operationStatuses/887e298d-4e9c-4764-86f5-86878dbdb038?api-version=2020-12-08
+ response:
+ body:
+ string: '{"id":"/providers/Microsoft.HealthBot/locations/EASTUS/operationStatuses/887e298d-4e9c-4764-86f5-86878dbdb038","name":"887e298d-4e9c-4764-86f5-86878dbdb038","resourceId":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/clitest000001/providers/Microsoft.HealthBot/healthBots/samplebotname","status":"Working","startTime":"2021-02-07T12:08:40.8645764Z"}'
+ headers:
+ cache-control:
+ - no-cache
+ content-length:
+ - '377'
+ content-type:
+ - application/json; charset=utf-8
+ date:
+ - Sun, 07 Feb 2021 12:09:13 GMT
+ etag:
+ - '"ba014ee7-0000-0100-0000-601fd84a0000"'
+ expires:
+ - '-1'
+ pragma:
+ - no-cache
+ server:
+ - Kestrel
+ strict-transport-security:
+ - max-age=31536000; includeSubDomains
+ transfer-encoding:
+ - chunked
+ vary:
+ - Accept-Encoding
+ x-content-type-options:
+ - nosniff
+ status:
+ code: 200
+ message: OK
+- request:
+ body: null
+ headers:
+ Accept:
+ - '*/*'
+ Accept-Encoding:
+ - gzip, deflate
+ CommandName:
+ - healthbot create
+ Connection:
+ - keep-alive
+ Cookie:
+ - admin.healthbot.sid=1612699722.129.36.709883
+ ParameterSetName:
+ - --name --location --sku --resource-group
+ User-Agent:
+ - AZURECLI/2.18.0 azsdk-python-mgmt-healthbot/2020-10-20-preview Python/3.8.7
+ (Windows-10-10.0.19041-SP0)
+ method: GET
+ uri: https://management.azure.com/providers/Microsoft.HealthBot/locations/EASTUS/operationStatuses/887e298d-4e9c-4764-86f5-86878dbdb038?api-version=2020-12-08
+ response:
+ body:
+ string: '{"id":"/providers/Microsoft.HealthBot/locations/EASTUS/operationStatuses/887e298d-4e9c-4764-86f5-86878dbdb038","name":"887e298d-4e9c-4764-86f5-86878dbdb038","resourceId":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/clitest000001/providers/Microsoft.HealthBot/healthBots/samplebotname","status":"Succeeded","startTime":"2021-02-07T12:08:40.8645764Z","endTime":"2021-02-07T12:09:21.0870864Z","properties":null}'
+ headers:
+ cache-control:
+ - no-cache
+ content-length:
+ - '438'
+ content-type:
+ - application/json; charset=utf-8
+ date:
+ - Sun, 07 Feb 2021 12:09:43 GMT
+ etag:
+ - '"ba01f8ec-0000-0100-0000-601fd8710000"'
+ expires:
+ - '-1'
+ pragma:
+ - no-cache
+ server:
+ - Kestrel
+ strict-transport-security:
+ - max-age=31536000; includeSubDomains
+ transfer-encoding:
+ - chunked
+ vary:
+ - Accept-Encoding
+ x-content-type-options:
+ - nosniff
+ status:
+ code: 200
+ message: OK
+- request:
+ body: null
+ headers:
+ Accept:
+ - '*/*'
+ Accept-Encoding:
+ - gzip, deflate
+ CommandName:
+ - healthbot create
+ Connection:
+ - keep-alive
+ Cookie:
+ - admin.healthbot.sid=1612699722.129.36.709883
+ ParameterSetName:
+ - --name --location --sku --resource-group
+ User-Agent:
+ - AZURECLI/2.18.0 azsdk-python-mgmt-healthbot/2020-10-20-preview Python/3.8.7
+ (Windows-10-10.0.19041-SP0)
+ method: GET
+ uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/clitest000001/providers/Microsoft.HealthBot/healthBots/samplebotname?api-version=2020-12-08
+ response:
+ body:
+ string: '{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/clitest000001/providers/Microsoft.HealthBot/healthBots/samplebotname","name":"samplebotname","type":"Microsoft.HealthBot/healthBots","sku":{"name":"F0"},"location":"eastus","systemData":{"createdBy":"guepsh@microsoft.com","createdByType":"User","createdAt":"2021-02-07T12:08:39.8022985Z","lastModifiedBy":"6db4d6bb-6649-4dc2-84b7-0b5c6894031e","lastModifiedByType":"Application","lastModifiedAt":"2021-02-07T12:08:42.7186314Z"},"properties":{"provisioningState":"Succeeded","botManagementPortalLink":"https://us.healthbot.microsoft.com/account/samplebotname-vc5optp"}}'
+ headers:
+ cache-control:
+ - no-cache
+ content-length:
+ - '649'
+ content-type:
+ - application/json; charset=utf-8
+ date:
+ - Sun, 07 Feb 2021 12:09:43 GMT
+ etag:
+ - '"a5048422-0000-0100-0000-601fd8710000"'
+ expires:
+ - '-1'
+ pragma:
+ - no-cache
+ server:
+ - Kestrel
+ strict-transport-security:
+ - max-age=31536000; includeSubDomains
+ transfer-encoding:
+ - chunked
+ vary:
+ - Accept-Encoding
+ x-content-type-options:
+ - nosniff
+ status:
+ code: 200
+ message: OK
+- request:
+ body: null
+ headers:
+ Accept:
+ - application/json
+ Accept-Encoding:
+ - gzip, deflate
+ CommandName:
+ - healthbot list
+ Connection:
+ - keep-alive
+ ParameterSetName:
+ - --resource-group
+ User-Agent:
+ - AZURECLI/2.18.0 azsdk-python-mgmt-healthbot/2020-10-20-preview Python/3.8.7
+ (Windows-10-10.0.19041-SP0)
+ method: GET
+ uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/clitest000001/providers/Microsoft.HealthBot/healthBots?api-version=2020-12-08
+ response:
+ body:
+ string: '{"value":[{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/clitest000001/providers/Microsoft.HealthBot/healthBots/samplebotname","name":"samplebotname","type":"Microsoft.HealthBot/healthBots","sku":{"name":"F0"},"location":"eastus","systemData":{"createdBy":"guepsh@microsoft.com","createdByType":"User","createdAt":"2021-02-07T12:08:39.8022985Z","lastModifiedBy":"6db4d6bb-6649-4dc2-84b7-0b5c6894031e","lastModifiedByType":"Application","lastModifiedAt":"2021-02-07T12:08:42.7186314Z"},"properties":{"provisioningState":"Succeeded","botManagementPortalLink":"https://us.healthbot.microsoft.com/account/samplebotname-vc5optp"}}]}'
+ headers:
+ cache-control:
+ - no-cache
+ content-length:
+ - '661'
+ content-type:
+ - application/json; charset=utf-8
+ date:
+ - Sun, 07 Feb 2021 12:09:46 GMT
+ expires:
+ - '-1'
+ pragma:
+ - no-cache
+ server:
+ - Kestrel
+ strict-transport-security:
+ - max-age=31536000; includeSubDomains
+ transfer-encoding:
+ - chunked
+ vary:
+ - Accept-Encoding
+ x-content-type-options:
+ - nosniff
+ status:
+ code: 200
+ message: OK
+- request:
+ body: null
+ headers:
+ Accept:
+ - application/json
+ Accept-Encoding:
+ - gzip, deflate
+ CommandName:
+ - healthbot list
+ Connection:
+ - keep-alive
+ ParameterSetName:
+ - -g
+ User-Agent:
+ - AZURECLI/2.18.0 azsdk-python-mgmt-healthbot/2020-10-20-preview Python/3.8.7
+ (Windows-10-10.0.19041-SP0)
+ method: GET
+ uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.HealthBot/healthBots?api-version=2020-12-08
+ response:
+ body:
+ string: '{"value":[{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/clitest000001/providers/Microsoft.HealthBot/healthBots/samplebotname","name":"samplebotname","type":"Microsoft.HealthBot/healthBots","sku":{"name":"F0"},"location":"eastus","systemData":{"createdBy":"guepsh@microsoft.com","createdByType":"User","createdAt":"2021-02-07T12:08:39.8022985Z","lastModifiedBy":"6db4d6bb-6649-4dc2-84b7-0b5c6894031e","lastModifiedByType":"Application","lastModifiedAt":"2021-02-07T12:08:42.7186314Z"},"properties":{"provisioningState":"Succeeded","botManagementPortalLink":"https://us.healthbot.microsoft.com/account/samplebotname-vc5optp"}}]}'
+ headers:
+ cache-control:
+ - no-cache
+ content-length:
+ - '661'
+ content-type:
+ - application/json; charset=utf-8
+ date:
+ - Sun, 07 Feb 2021 12:09:47 GMT
+ expires:
+ - '-1'
+ pragma:
+ - no-cache
+ server:
+ - Kestrel
+ strict-transport-security:
+ - max-age=31536000; includeSubDomains
+ transfer-encoding:
+ - chunked
+ vary:
+ - Accept-Encoding
+ x-content-type-options:
+ - nosniff
+ status:
+ code: 200
+ message: OK
+- request:
+ body: null
+ headers:
+ Accept:
+ - application/json
+ Accept-Encoding:
+ - gzip, deflate
+ CommandName:
+ - healthbot show
+ Connection:
+ - keep-alive
+ ParameterSetName:
+ - --name --resource-group
+ User-Agent:
+ - AZURECLI/2.18.0 azsdk-python-mgmt-healthbot/2020-10-20-preview Python/3.8.7
+ (Windows-10-10.0.19041-SP0)
+ method: GET
+ uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/clitest000001/providers/Microsoft.HealthBot/healthBots/samplebotname?api-version=2020-12-08
+ response:
+ body:
+ string: '{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/clitest000001/providers/Microsoft.HealthBot/healthBots/samplebotname","name":"samplebotname","type":"Microsoft.HealthBot/healthBots","sku":{"name":"F0"},"location":"eastus","systemData":{"createdBy":"guepsh@microsoft.com","createdByType":"User","createdAt":"2021-02-07T12:08:39.8022985Z","lastModifiedBy":"6db4d6bb-6649-4dc2-84b7-0b5c6894031e","lastModifiedByType":"Application","lastModifiedAt":"2021-02-07T12:08:42.7186314Z"},"properties":{"provisioningState":"Succeeded","botManagementPortalLink":"https://us.healthbot.microsoft.com/account/samplebotname-vc5optp"}}'
+ headers:
+ cache-control:
+ - no-cache
+ content-length:
+ - '649'
+ content-type:
+ - application/json; charset=utf-8
+ date:
+ - Sun, 07 Feb 2021 12:09:47 GMT
+ etag:
+ - '"a5048422-0000-0100-0000-601fd8710000"'
+ expires:
+ - '-1'
+ pragma:
+ - no-cache
+ server:
+ - Kestrel
+ strict-transport-security:
+ - max-age=31536000; includeSubDomains
+ transfer-encoding:
+ - chunked
+ vary:
+ - Accept-Encoding
+ x-content-type-options:
+ - nosniff
+ status:
+ code: 200
+ message: OK
+- request:
+ body: '{"sku": {"name": "F0"}}'
+ headers:
+ Accept:
+ - application/json
+ Accept-Encoding:
+ - gzip, deflate
+ CommandName:
+ - healthbot update
+ Connection:
+ - keep-alive
+ Content-Length:
+ - '23'
+ Content-Type:
+ - application/json
+ ParameterSetName:
+ - --name --sku --resource-group
+ User-Agent:
+ - AZURECLI/2.18.0 azsdk-python-mgmt-healthbot/2020-10-20-preview Python/3.8.7
+ (Windows-10-10.0.19041-SP0)
+ method: PATCH
+ uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/clitest000001/providers/Microsoft.HealthBot/healthBots/samplebotname?api-version=2020-12-08
+ response:
+ body:
+ string: '{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/clitest000001/providers/Microsoft.HealthBot/healthBots/samplebotname","name":"samplebotname","type":"Microsoft.HealthBot/healthBots","sku":{"name":"F0"},"location":"eastus","systemData":{"createdBy":"guepsh@microsoft.com","createdByType":"User","createdAt":"2021-02-07T12:08:39.8022985Z","lastModifiedBy":"guepsh@microsoft.com","lastModifiedByType":"User","lastModifiedAt":"2021-02-07T12:09:50.1683896Z"},"properties":{"provisioningState":"Succeeded","botManagementPortalLink":"https://us.healthbot.microsoft.com/account/samplebotname-vc5optp"}}'
+ headers:
+ cache-control:
+ - no-cache
+ content-length:
+ - '626'
+ content-type:
+ - application/json; charset=utf-8
+ date:
+ - Sun, 07 Feb 2021 12:09:55 GMT
+ etag:
+ - '"a504ee22-0000-0100-0000-601fd8900000"'
+ expires:
+ - '-1'
+ pragma:
+ - no-cache
+ request-context:
+ - appId=cid-v1:39ac773f-9efe-42dd-90ba-3ebab16f6587
+ server:
+ - Kestrel
+ set-cookie:
+ - admin.healthbot.sid=1612699792.768.35.914638; Max-Age=3600; Path=/; Secure;
+ HttpOnly
+ strict-transport-security:
+ - max-age=31536000; includeSubDomains
+ transfer-encoding:
+ - chunked
+ vary:
+ - Accept-Encoding
+ x-content-type-options:
+ - nosniff
+ x-dns-prefetch-control:
+ - 'off'
+ x-download-options:
+ - noopen
+ x-frame-options:
+ - SAMEORIGIN
+ x-ms-ratelimit-remaining-subscription-writes:
+ - '1199'
+ x-xss-protection:
+ - 1; mode=block
+ status:
+ code: 200
+ message: OK
+- request:
+ body: null
+ headers:
+ Accept:
+ - application/json
+ Accept-Encoding:
+ - gzip, deflate
+ CommandName:
+ - healthbot delete
+ Connection:
+ - keep-alive
+ Content-Length:
+ - '0'
+ ParameterSetName:
+ - -y --name --resource-group
+ User-Agent:
+ - AZURECLI/2.18.0 azsdk-python-mgmt-healthbot/2020-10-20-preview Python/3.8.7
+ (Windows-10-10.0.19041-SP0)
+ method: DELETE
+ uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/clitest000001/providers/Microsoft.HealthBot/healthBots/samplebotname?api-version=2020-12-08
+ response:
+ body:
+ string: ''
+ headers:
+ cache-control:
+ - no-cache
+ content-length:
+ - '0'
+ date:
+ - Sun, 07 Feb 2021 12:10:02 GMT
+ expires:
+ - '-1'
+ pragma:
+ - no-cache
+ request-context:
+ - appId=cid-v1:39ac773f-9efe-42dd-90ba-3ebab16f6587
+ server:
+ - Kestrel
+ set-cookie:
+ - admin.healthbot.sid=1612699799.23.35.293330; Max-Age=3600; Path=/; Secure;
+ HttpOnly
+ strict-transport-security:
+ - max-age=31536000; includeSubDomains
+ x-content-type-options:
+ - nosniff
+ x-dns-prefetch-control:
+ - 'off'
+ x-download-options:
+ - noopen
+ x-frame-options:
+ - SAMEORIGIN
+ x-ms-ratelimit-remaining-subscription-deletes:
+ - '14999'
+ x-xss-protection:
+ - 1; mode=block
+ status:
+ code: 200
+ message: OK
+version: 1
diff --git a/src/healthbot/azext_healthbot/tests/latest/test_healthbot_scenario.py b/src/healthbot/azext_healthbot/tests/latest/test_healthbot_scenario.py
new file mode 100644
index 00000000000..69218418e98
--- /dev/null
+++ b/src/healthbot/azext_healthbot/tests/latest/test_healthbot_scenario.py
@@ -0,0 +1,84 @@
+# --------------------------------------------------------------------------
+# Copyright (c) Microsoft Corporation. All rights reserved.
+# Licensed under the MIT License. See License.txt in the project root for
+# license information.
+#
+# Code generated by Microsoft (R) AutoRest Code Generator.
+# Changes may cause incorrect behavior and will be lost if the code is
+# regenerated.
+# --------------------------------------------------------------------------
+
+import os
+from azure.cli.testsdk import ScenarioTest
+from azure.cli.testsdk import ResourceGroupPreparer
+from .example_steps import step_create
+from .example_steps import step_list
+from .example_steps import step_list2
+from .example_steps import step_show
+from .example_steps import step_update
+from .example_steps import step_delete
+from .. import (
+ try_manual,
+ raise_if,
+ calc_coverage
+)
+
+
+TEST_DIR = os.path.abspath(os.path.join(os.path.abspath(__file__), '..'))
+
+
+# Env setup_scenario
+@try_manual
+def setup_scenario(test, rg, rg_2):
+ pass
+
+
+# Env cleanup_scenario
+@try_manual
+def cleanup_scenario(test, rg, rg_2):
+ pass
+
+
+# Testcase: Scenario
+@try_manual
+def call_scenario(test, rg, rg_2):
+ setup_scenario(test, rg, rg_2)
+ step_create(test, rg, rg_2, checks=[
+ test.check("name", "{myBot}", case_sensitive=False),
+ test.check("location", "eastus", case_sensitive=False),
+ test.check("sku.name", "F0", case_sensitive=False),
+ ])
+ step_list(test, rg, rg_2, checks=[])
+ step_list2(test, rg, rg_2, checks=[
+ test.check('length(@)', 1),
+ ])
+ step_show(test, rg, rg_2, checks=[
+ test.check("name", "{myBot}", case_sensitive=False),
+ test.check("location", "eastus", case_sensitive=False),
+ test.check("sku.name", "F0", case_sensitive=False),
+ ])
+ step_update(test, rg, rg_2, checks=[
+ test.check("name", "{myBot}", case_sensitive=False),
+ test.check("location", "eastus", case_sensitive=False),
+ test.check("sku.name", "F0", case_sensitive=False),
+ ])
+ step_delete(test, rg, rg_2, checks=[])
+ cleanup_scenario(test, rg, rg_2)
+
+
+# Test class for Scenario
+@try_manual
+class HealthbotScenarioTest(ScenarioTest):
+
+ def __init__(self, *args, **kwargs):
+ super(HealthbotScenarioTest, self).__init__(*args, **kwargs)
+ self.kwargs.update({
+ 'myBot': 'samplebotname',
+ })
+
+ @ResourceGroupPreparer(name_prefix='clitest', random_name_length=20, key='rg', parameter_name='rg')
+ @ResourceGroupPreparer(name_prefix='clitest', random_name_length=20, key='rg_2', parameter_name='rg_2')
+ def test_healthbot_Scenario(self, rg, rg_2):
+ call_scenario(self, rg, rg_2)
+ calc_coverage(__file__)
+ raise_if()
diff --git a/src/healthbot/azext_healthbot/vendored_sdks/__init__.py b/src/healthbot/azext_healthbot/vendored_sdks/__init__.py
new file mode 100644
index 00000000000..c9cfdc73e77
--- /dev/null
+++ b/src/healthbot/azext_healthbot/vendored_sdks/__init__.py
@@ -0,0 +1,12 @@
+# coding=utf-8
+# --------------------------------------------------------------------------
+# Copyright (c) Microsoft Corporation. All rights reserved.
+# Licensed under the MIT License. See License.txt in the project root for
+# license information.
+#
+# Code generated by Microsoft (R) AutoRest Code Generator.
+# Changes may cause incorrect behavior and will be lost if the code is
+# regenerated.
+# --------------------------------------------------------------------------
+
+__path__ = __import__('pkgutil').extend_path(__path__, __name__)
diff --git a/src/healthbot/azext_healthbot/vendored_sdks/healthbot/__init__.py b/src/healthbot/azext_healthbot/vendored_sdks/healthbot/__init__.py
new file mode 100644
index 00000000000..c151f5dea0d
--- /dev/null
+++ b/src/healthbot/azext_healthbot/vendored_sdks/healthbot/__init__.py
@@ -0,0 +1,19 @@
+# coding=utf-8
+# --------------------------------------------------------------------------
+# Copyright (c) Microsoft Corporation. All rights reserved.
+# Licensed under the MIT License. See License.txt in the project root for license information.
+# Code generated by Microsoft (R) AutoRest Code Generator.
+# Changes may cause incorrect behavior and will be lost if the code is regenerated.
+# --------------------------------------------------------------------------
+
+from ._healthbot_client import HealthbotClient
+from ._version import VERSION
+
+__version__ = VERSION
+__all__ = ['HealthbotClient']
+
+try:
+ from ._patch import patch_sdk # type: ignore
+ patch_sdk()
+except ImportError:
+ pass
diff --git a/src/healthbot/azext_healthbot/vendored_sdks/healthbot/_configuration.py b/src/healthbot/azext_healthbot/vendored_sdks/healthbot/_configuration.py
new file mode 100644
index 00000000000..d958b83043a
--- /dev/null
+++ b/src/healthbot/azext_healthbot/vendored_sdks/healthbot/_configuration.py
@@ -0,0 +1,71 @@
+# coding=utf-8
+# --------------------------------------------------------------------------
+# Copyright (c) Microsoft Corporation. All rights reserved.
+# Licensed under the MIT License. See License.txt in the project root for license information.
+# Code generated by Microsoft (R) AutoRest Code Generator.
+# Changes may cause incorrect behavior and will be lost if the code is regenerated.
+# --------------------------------------------------------------------------
+
+from typing import TYPE_CHECKING
+
+from azure.core.configuration import Configuration
+from azure.core.pipeline import policies
+from azure.mgmt.core.policies import ARMHttpLoggingPolicy
+
+from ._version import VERSION
+
+if TYPE_CHECKING:
+ # pylint: disable=unused-import,ungrouped-imports
+ from typing import Any
+
+ from azure.core.credentials import TokenCredential
+
+
+class HealthbotClientConfiguration(Configuration):
+ """Configuration for HealthbotClient.
+
+ Note that all parameters used to create this instance are saved as instance
+ attributes.
+
+ :param credential: Credential needed for the client to connect to Azure.
+ :type credential: ~azure.core.credentials.TokenCredential
+ :param subscription_id: Azure Subscription ID.
+ :type subscription_id: str
+ """
+
+ def __init__(
+ self,
+ credential, # type: "TokenCredential"
+ subscription_id, # type: str
+ **kwargs # type: Any
+ ):
+ # type: (...) -> None
+ if credential is None:
+ raise ValueError("Parameter 'credential' must not be None.")
+ if subscription_id is None:
+ raise ValueError("Parameter 'subscription_id' must not be None.")
+ super(HealthbotClientConfiguration, self).__init__(**kwargs)
+
+ self.credential = credential
+ self.subscription_id = subscription_id
+ self.api_version = "2020-12-08"
+ self.credential_scopes = kwargs.pop('credential_scopes', ['https://management.azure.com/.default'])
+ kwargs.setdefault('sdk_moniker', 'mgmt-healthbot/{}'.format(VERSION))
+ self._configure(**kwargs)
+
+ def _configure(
+ self,
+ **kwargs # type: Any
+ ):
+ # type: (...) -> None
+ self.user_agent_policy = kwargs.get('user_agent_policy') or policies.UserAgentPolicy(**kwargs)
+ self.headers_policy = kwargs.get('headers_policy') or policies.HeadersPolicy(**kwargs)
+ self.proxy_policy = kwargs.get('proxy_policy') or policies.ProxyPolicy(**kwargs)
+ self.logging_policy = kwargs.get('logging_policy') or policies.NetworkTraceLoggingPolicy(**kwargs)
+ self.http_logging_policy = kwargs.get('http_logging_policy') or ARMHttpLoggingPolicy(**kwargs)
+ self.retry_policy = kwargs.get('retry_policy') or policies.RetryPolicy(**kwargs)
+ self.custom_hook_policy = kwargs.get('custom_hook_policy') or policies.CustomHookPolicy(**kwargs)
+ self.redirect_policy = kwargs.get('redirect_policy') or policies.RedirectPolicy(**kwargs)
+ self.authentication_policy = kwargs.get('authentication_policy')
+ if self.credential and not self.authentication_policy:
+ self.authentication_policy = policies.BearerTokenCredentialPolicy(self.credential, *self.credential_scopes, **kwargs)
diff --git a/src/healthbot/azext_healthbot/vendored_sdks/healthbot/_healthbot_client.py b/src/healthbot/azext_healthbot/vendored_sdks/healthbot/_healthbot_client.py
new file mode 100644
index 00000000000..489c41688b2
--- /dev/null
+++ b/src/healthbot/azext_healthbot/vendored_sdks/healthbot/_healthbot_client.py
@@ -0,0 +1,74 @@
+# coding=utf-8
+# --------------------------------------------------------------------------
+# Copyright (c) Microsoft Corporation. All rights reserved.
+# Licensed under the MIT License. See License.txt in the project root for license information.
+# Code generated by Microsoft (R) AutoRest Code Generator.
+# Changes may cause incorrect behavior and will be lost if the code is regenerated.
+# --------------------------------------------------------------------------
+
+from typing import TYPE_CHECKING
+
+from azure.mgmt.core import ARMPipelineClient
+from msrest import Deserializer, Serializer
+
+if TYPE_CHECKING:
+ # pylint: disable=unused-import,ungrouped-imports
+ from typing import Any, Optional
+
+ from azure.core.credentials import TokenCredential
+
+from ._configuration import HealthbotClientConfiguration
+from .operations import BotsOperations
+from .operations import Operations
+from . import models
+
+
+class HealthbotClient(object):
+ """Microsoft Healthcare Bot is a cloud platform that empowers developers in Healthcare organizations to build and deploy their compliant, AI-powered virtual health assistants and health bots, that help them improve processes and reduce costs.
+
+ :ivar bots: BotsOperations operations
+ :vartype bots: azure.mgmt.healthbot.operations.BotsOperations
+ :ivar operations: Operations operations
+ :vartype operations: azure.mgmt.healthbot.operations.Operations
+ :param credential: Credential needed for the client to connect to Azure.
+ :type credential: ~azure.core.credentials.TokenCredential
+ :param subscription_id: Azure Subscription ID.
+ :type subscription_id: str
+ :param str base_url: Service URL
+ :keyword int polling_interval: Default waiting time between two polls for LRO operations if no Retry-After header is present.
+ """
+
+ def __init__(
+ self,
+ credential, # type: "TokenCredential"
+ subscription_id, # type: str
+ base_url=None, # type: Optional[str]
+ **kwargs # type: Any
+ ):
+ # type: (...) -> None
+ if not base_url:
+ base_url = 'https://management.azure.com'
+ self._config = HealthbotClientConfiguration(credential, subscription_id, **kwargs)
+ self._client = ARMPipelineClient(base_url=base_url, config=self._config, **kwargs)
+
+ client_models = {k: v for k, v in models.__dict__.items() if isinstance(v, type)}
+ self._serialize = Serializer(client_models)
+ self._deserialize = Deserializer(client_models)
+
+ self.bots = BotsOperations(
+ self._client, self._config, self._serialize, self._deserialize)
+ self.operations = Operations(
+ self._client, self._config, self._serialize, self._deserialize)
+
+ def close(self):
+ # type: () -> None
+ self._client.close()
+
+ def __enter__(self):
+ # type: () -> HealthbotClient
+ self._client.__enter__()
+ return self
+
+ def __exit__(self, *exc_details):
+ # type: (Any) -> None
+ self._client.__exit__(*exc_details)
diff --git a/src/healthbot/azext_healthbot/vendored_sdks/healthbot/_version.py b/src/healthbot/azext_healthbot/vendored_sdks/healthbot/_version.py
new file mode 100644
index 00000000000..af172383ece
--- /dev/null
+++ b/src/healthbot/azext_healthbot/vendored_sdks/healthbot/_version.py
@@ -0,0 +1,9 @@
+# coding=utf-8
+# --------------------------------------------------------------------------
+# Copyright (c) Microsoft Corporation. All rights reserved.
+# Licensed under the MIT License. See License.txt in the project root for license information.
+# Code generated by Microsoft (R) AutoRest Code Generator.
+# Changes may cause incorrect behavior and will be lost if the code is regenerated.
+# --------------------------------------------------------------------------
+
+VERSION = "2020-10-20-preview"
diff --git a/src/healthbot/azext_healthbot/vendored_sdks/healthbot/aio/__init__.py b/src/healthbot/azext_healthbot/vendored_sdks/healthbot/aio/__init__.py
new file mode 100644
index 00000000000..dbe9e167a47
--- /dev/null
+++ b/src/healthbot/azext_healthbot/vendored_sdks/healthbot/aio/__init__.py
@@ -0,0 +1,10 @@
+# coding=utf-8
+# --------------------------------------------------------------------------
+# Copyright (c) Microsoft Corporation. All rights reserved.
+# Licensed under the MIT License. See License.txt in the project root for license information.
+# Code generated by Microsoft (R) AutoRest Code Generator.
+# Changes may cause incorrect behavior and will be lost if the code is regenerated.
+# --------------------------------------------------------------------------
+
+from ._healthbot_client import HealthbotClient
+__all__ = ['HealthbotClient']
diff --git a/src/healthbot/azext_healthbot/vendored_sdks/healthbot/aio/_configuration.py b/src/healthbot/azext_healthbot/vendored_sdks/healthbot/aio/_configuration.py
new file mode 100644
index 00000000000..dc1fc0a1a89
--- /dev/null
+++ b/src/healthbot/azext_healthbot/vendored_sdks/healthbot/aio/_configuration.py
@@ -0,0 +1,67 @@
+# coding=utf-8
+# --------------------------------------------------------------------------
+# Copyright (c) Microsoft Corporation. All rights reserved.
+# Licensed under the MIT License. See License.txt in the project root for license information.
+# Code generated by Microsoft (R) AutoRest Code Generator.
+# Changes may cause incorrect behavior and will be lost if the code is regenerated.
+# --------------------------------------------------------------------------
+
+from typing import Any, TYPE_CHECKING
+
+from azure.core.configuration import Configuration
+from azure.core.pipeline import policies
+from azure.mgmt.core.policies import ARMHttpLoggingPolicy
+
+from .._version import VERSION
+
+if TYPE_CHECKING:
+ # pylint: disable=unused-import,ungrouped-imports
+ from azure.core.credentials_async import AsyncTokenCredential
+
+
+class HealthbotClientConfiguration(Configuration):
+ """Configuration for HealthbotClient.
+
+ Note that all parameters used to create this instance are saved as instance
+ attributes.
+
+ :param credential: Credential needed for the client to connect to Azure.
+ :type credential: ~azure.core.credentials_async.AsyncTokenCredential
+ :param subscription_id: Azure Subscription ID.
+ :type subscription_id: str
+ """
+
+ def __init__(
+ self,
+ credential: "AsyncTokenCredential",
+ subscription_id: str,
+ **kwargs: Any
+ ) -> None:
+ if credential is None:
+ raise ValueError("Parameter 'credential' must not be None.")
+ if subscription_id is None:
+ raise ValueError("Parameter 'subscription_id' must not be None.")
+ super(HealthbotClientConfiguration, self).__init__(**kwargs)
+
+ self.credential = credential
+ self.subscription_id = subscription_id
+ self.api_version = "2020-12-08"
+ self.credential_scopes = kwargs.pop('credential_scopes', ['https://management.azure.com/.default'])
+ kwargs.setdefault('sdk_moniker', 'mgmt-healthbot/{}'.format(VERSION))
+ self._configure(**kwargs)
+
+ def _configure(
+ self,
+ **kwargs: Any
+ ) -> None:
+ self.user_agent_policy = kwargs.get('user_agent_policy') or policies.UserAgentPolicy(**kwargs)
+ self.headers_policy = kwargs.get('headers_policy') or policies.HeadersPolicy(**kwargs)
+ self.proxy_policy = kwargs.get('proxy_policy') or policies.ProxyPolicy(**kwargs)
+ self.logging_policy = kwargs.get('logging_policy') or policies.NetworkTraceLoggingPolicy(**kwargs)
+ self.http_logging_policy = kwargs.get('http_logging_policy') or ARMHttpLoggingPolicy(**kwargs)
+ self.retry_policy = kwargs.get('retry_policy') or policies.AsyncRetryPolicy(**kwargs)
+ self.custom_hook_policy = kwargs.get('custom_hook_policy') or policies.CustomHookPolicy(**kwargs)
+ self.redirect_policy = kwargs.get('redirect_policy') or policies.AsyncRedirectPolicy(**kwargs)
+ self.authentication_policy = kwargs.get('authentication_policy')
+ if self.credential and not self.authentication_policy:
+ self.authentication_policy = policies.AsyncBearerTokenCredentialPolicy(self.credential, *self.credential_scopes, **kwargs)
diff --git a/src/healthbot/azext_healthbot/vendored_sdks/healthbot/aio/_healthbot_client.py b/src/healthbot/azext_healthbot/vendored_sdks/healthbot/aio/_healthbot_client.py
new file mode 100644
index 00000000000..fcd160d1e5e
--- /dev/null
+++ b/src/healthbot/azext_healthbot/vendored_sdks/healthbot/aio/_healthbot_client.py
@@ -0,0 +1,68 @@
+# coding=utf-8
+# --------------------------------------------------------------------------
+# Copyright (c) Microsoft Corporation. All rights reserved.
+# Licensed under the MIT License. See License.txt in the project root for license information.
+# Code generated by Microsoft (R) AutoRest Code Generator.
+# Changes may cause incorrect behavior and will be lost if the code is regenerated.
+# --------------------------------------------------------------------------
+
+from typing import Any, Optional, TYPE_CHECKING
+
+from azure.mgmt.core import AsyncARMPipelineClient
+from msrest import Deserializer, Serializer
+
+if TYPE_CHECKING:
+ # pylint: disable=unused-import,ungrouped-imports
+ from azure.core.credentials_async import AsyncTokenCredential
+
+from ._configuration import HealthbotClientConfiguration
+from .operations import BotsOperations
+from .operations import Operations
+from .. import models
+
+
+class HealthbotClient(object):
+ """Microsoft Healthcare Bot is a cloud platform that empowers developers in Healthcare organizations to build and deploy their compliant, AI-powered virtual health assistants and health bots, that help them improve processes and reduce costs.
+
+ :ivar bots: BotsOperations operations
+ :vartype bots: azure.mgmt.healthbot.aio.operations.BotsOperations
+ :ivar operations: Operations operations
+ :vartype operations: azure.mgmt.healthbot.aio.operations.Operations
+ :param credential: Credential needed for the client to connect to Azure.
+ :type credential: ~azure.core.credentials_async.AsyncTokenCredential
+ :param subscription_id: Azure Subscription ID.
+ :type subscription_id: str
+ :param str base_url: Service URL
+ :keyword int polling_interval: Default waiting time between two polls for LRO operations if no Retry-After header is present.
+ """
+
+ def __init__(
+ self,
+ credential: "AsyncTokenCredential",
+ subscription_id: str,
+ base_url: Optional[str] = None,
+ **kwargs: Any
+ ) -> None:
+ if not base_url:
+ base_url = 'https://management.azure.com'
+ self._config = HealthbotClientConfiguration(credential, subscription_id, **kwargs)
+ self._client = AsyncARMPipelineClient(base_url=base_url, config=self._config, **kwargs)
+
+ client_models = {k: v for k, v in models.__dict__.items() if isinstance(v, type)}
+ self._serialize = Serializer(client_models)
+ self._deserialize = Deserializer(client_models)
+
+ self.bots = BotsOperations(
+ self._client, self._config, self._serialize, self._deserialize)
+ self.operations = Operations(
+ self._client, self._config, self._serialize, self._deserialize)
+
+ async def close(self) -> None:
+ await self._client.close()
+
+ async def __aenter__(self) -> "HealthbotClient":
+ await self._client.__aenter__()
+ return self
+
+ async def __aexit__(self, *exc_details) -> None:
+ await self._client.__aexit__(*exc_details)
diff --git a/src/healthbot/azext_healthbot/vendored_sdks/healthbot/aio/operations/__init__.py b/src/healthbot/azext_healthbot/vendored_sdks/healthbot/aio/operations/__init__.py
new file mode 100644
index 00000000000..214402239a8
--- /dev/null
+++ b/src/healthbot/azext_healthbot/vendored_sdks/healthbot/aio/operations/__init__.py
@@ -0,0 +1,15 @@
+# coding=utf-8
+# --------------------------------------------------------------------------
+# Copyright (c) Microsoft Corporation. All rights reserved.
+# Licensed under the MIT License. See License.txt in the project root for license information.
+# Code generated by Microsoft (R) AutoRest Code Generator.
+# Changes may cause incorrect behavior and will be lost if the code is regenerated.
+# --------------------------------------------------------------------------
+
+from ._bots_operations import BotsOperations
+from ._operations import Operations
+
+__all__ = [
+ 'BotsOperations',
+ 'Operations',
+]
diff --git a/src/healthbot/azext_healthbot/vendored_sdks/healthbot/aio/operations/_bots_operations.py b/src/healthbot/azext_healthbot/vendored_sdks/healthbot/aio/operations/_bots_operations.py
new file mode 100644
index 00000000000..8f82635ce8c
--- /dev/null
+++ b/src/healthbot/azext_healthbot/vendored_sdks/healthbot/aio/operations/_bots_operations.py
@@ -0,0 +1,550 @@
+# coding=utf-8
+# --------------------------------------------------------------------------
+# Copyright (c) Microsoft Corporation. All rights reserved.
+# Licensed under the MIT License. See License.txt in the project root for license information.
+# Code generated by Microsoft (R) AutoRest Code Generator.
+# Changes may cause incorrect behavior and will be lost if the code is regenerated.
+# --------------------------------------------------------------------------
+from typing import Any, AsyncIterable, Callable, Dict, Generic, Optional, TypeVar, Union
+import warnings
+
+from azure.core.async_paging import AsyncItemPaged, AsyncList
+from azure.core.exceptions import ClientAuthenticationError, HttpResponseError, ResourceExistsError, ResourceNotFoundError, map_error
+from azure.core.pipeline import PipelineResponse
+from azure.core.pipeline.transport import AsyncHttpResponse, HttpRequest
+from azure.core.polling import AsyncLROPoller, AsyncNoPolling, AsyncPollingMethod
+from azure.mgmt.core.exceptions import ARMErrorFormat
+from azure.mgmt.core.polling.async_arm_polling import AsyncARMPolling
+
+from ... import models
+
+T = TypeVar('T')
+ClsType = Optional[Callable[[PipelineResponse[HttpRequest, AsyncHttpResponse], T, Dict[str, Any]], Any]]
+
+class BotsOperations:
+ """BotsOperations async operations.
+
+ You should not instantiate this class directly. Instead, you should create a Client instance that
+ instantiates it for you and attaches it as an attribute.
+
+ :ivar models: Alias to model classes used in this operation group.
+ :type models: ~azure.mgmt.healthbot.models
+ :param client: Client for service requests.
+ :param config: Configuration of service client.
+ :param serializer: An object model serializer.
+ :param deserializer: An object model deserializer.
+ """
+
+ models = models
+
+ def __init__(self, client, config, serializer, deserializer) -> None:
+ self._client = client
+ self._serialize = serializer
+ self._deserialize = deserializer
+ self._config = config
+
+ async def _create_initial(
+ self,
+ resource_group_name: str,
+ bot_name: str,
+ parameters: "models.HealthBot",
+ **kwargs
+ ) -> "models.HealthBot":
+ cls = kwargs.pop('cls', None) # type: ClsType["models.HealthBot"]
+ error_map = {
+ 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError
+ }
+ error_map.update(kwargs.pop('error_map', {}))
+ api_version = "2020-12-08"
+ content_type = kwargs.pop("content_type", "application/json")
+ accept = "application/json"
+
+ # Construct URL
+ url = self._create_initial.metadata['url'] # type: ignore
+ path_format_arguments = {
+ 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'),
+ 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=64, min_length=2, pattern=r'^[a-zA-Z0-9][a-zA-Z0-9_.-]*$'),
+ 'botName': self._serialize.url("bot_name", bot_name, 'str', max_length=64, min_length=2, pattern=r'^[a-zA-Z0-9][a-zA-Z0-9_.-]*$'),
+ }
+ url = self._client.format_url(url, **path_format_arguments)
+
+ # Construct parameters
+ query_parameters = {} # type: Dict[str, Any]
+ query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str')
+
+ # Construct headers
+ header_parameters = {} # type: Dict[str, Any]
+ header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str')
+ header_parameters['Accept'] = self._serialize.header("accept", accept, 'str')
+
+ body_content_kwargs = {} # type: Dict[str, Any]
+ body_content = self._serialize.body(parameters, 'HealthBot')
+ body_content_kwargs['content'] = body_content
+ request = self._client.put(url, query_parameters, header_parameters, **body_content_kwargs)
+ pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs)
+ response = pipeline_response.http_response
+
+ if response.status_code not in [200, 201]:
+ map_error(status_code=response.status_code, response=response, error_map=error_map)
+ error = self._deserialize(models.Error, response)
+ raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat)
+
+ if response.status_code == 200:
+ deserialized = self._deserialize('HealthBot', pipeline_response)
+
+ if response.status_code == 201:
+ deserialized = self._deserialize('HealthBot', pipeline_response)
+
+ if cls:
+ return cls(pipeline_response, deserialized, {})
+
+ return deserialized
+ _create_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.HealthBot/healthBots/{botName}'} # type: ignore
+
+ async def begin_create(
+ self,
+ resource_group_name: str,
+ bot_name: str,
+ parameters: "models.HealthBot",
+ **kwargs
+ ) -> AsyncLROPoller["models.HealthBot"]:
+ """Create a new HealthBot.
+
+ :param resource_group_name: The name of the Bot resource group in the user subscription.
+ :type resource_group_name: str
+ :param bot_name: The name of the Bot resource.
+ :type bot_name: str
+ :param parameters: The parameters to provide for the created bot.
+ :type parameters: ~azure.mgmt.healthbot.models.HealthBot
+ :keyword callable cls: A custom type or function that will be passed the direct response
+ :keyword str continuation_token: A continuation token to restart a poller from a saved state.
+ :keyword polling: True for ARMPolling, False for no polling, or a
+ polling object for personal polling strategy
+ :paramtype polling: bool or ~azure.core.polling.AsyncPollingMethod
+ :keyword int polling_interval: Default waiting time between two polls for LRO operations if no Retry-After header is present.
+ :return: An instance of AsyncLROPoller that returns either HealthBot or the result of cls(response)
+ :rtype: ~azure.core.polling.AsyncLROPoller[~azure.mgmt.healthbot.models.HealthBot]
+ :raises ~azure.core.exceptions.HttpResponseError:
+ """
+ polling = kwargs.pop('polling', True) # type: Union[bool, AsyncPollingMethod]
+ cls = kwargs.pop('cls', None) # type: ClsType["models.HealthBot"]
+ lro_delay = kwargs.pop(
+ 'polling_interval',
+ self._config.polling_interval
+ )
+ cont_token = kwargs.pop('continuation_token', None) # type: Optional[str]
+ if cont_token is None:
+ raw_result = await self._create_initial(
+ resource_group_name=resource_group_name,
+ bot_name=bot_name,
+ parameters=parameters,
+ cls=lambda x,y,z: x,
+ **kwargs
+ )
+
+ kwargs.pop('error_map', None)
+ kwargs.pop('content_type', None)
+
+ def get_long_running_output(pipeline_response):
+ deserialized = self._deserialize('HealthBot', pipeline_response)
+
+ if cls:
+ return cls(pipeline_response, deserialized, {})
+ return deserialized
+
+ path_format_arguments = {
+ 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'),
+ 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=64, min_length=2, pattern=r'^[a-zA-Z0-9][a-zA-Z0-9_.-]*$'),
+ 'botName': self._serialize.url("bot_name", bot_name, 'str', max_length=64, min_length=2, pattern=r'^[a-zA-Z0-9][a-zA-Z0-9_.-]*$'),
+ }
+
+ if polling is True: polling_method = AsyncARMPolling(lro_delay, lro_options={'final-state-via': 'azure-async-operation'}, path_format_arguments=path_format_arguments, **kwargs)
+ elif polling is False: polling_method = AsyncNoPolling()
+ else: polling_method = polling
+ if cont_token:
+ return AsyncLROPoller.from_continuation_token(
+ polling_method=polling_method,
+ continuation_token=cont_token,
+ client=self._client,
+ deserialization_callback=get_long_running_output
+ )
+ else:
+ return AsyncLROPoller(self._client, raw_result, get_long_running_output, polling_method)
+ begin_create.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.HealthBot/healthBots/{botName}'} # type: ignore
+
+ async def get(
+ self,
+ resource_group_name: str,
+ bot_name: str,
+ **kwargs
+ ) -> "models.HealthBot":
+ """Get a HealthBot.
+
+ :param resource_group_name: The name of the Bot resource group in the user subscription.
+ :type resource_group_name: str
+ :param bot_name: The name of the Bot resource.
+ :type bot_name: str
+ :keyword callable cls: A custom type or function that will be passed the direct response
+ :return: HealthBot, or the result of cls(response)
+ :rtype: ~azure.mgmt.healthbot.models.HealthBot
+ :raises: ~azure.core.exceptions.HttpResponseError
+ """
+ cls = kwargs.pop('cls', None) # type: ClsType["models.HealthBot"]
+ error_map = {
+ 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError
+ }
+ error_map.update(kwargs.pop('error_map', {}))
+ api_version = "2020-12-08"
+ accept = "application/json"
+
+ # Construct URL
+ url = self.get.metadata['url'] # type: ignore
+ path_format_arguments = {
+ 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'),
+ 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=64, min_length=2, pattern=r'^[a-zA-Z0-9][a-zA-Z0-9_.-]*$'),
+ 'botName': self._serialize.url("bot_name", bot_name, 'str', max_length=64, min_length=2, pattern=r'^[a-zA-Z0-9][a-zA-Z0-9_.-]*$'),
+ }
+ url = self._client.format_url(url, **path_format_arguments)
+
+ # Construct parameters
+ query_parameters = {} # type: Dict[str, Any]
+ query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str')
+
+ # Construct headers
+ header_parameters = {} # type: Dict[str, Any]
+ header_parameters['Accept'] = self._serialize.header("accept", accept, 'str')
+
+ request = self._client.get(url, query_parameters, header_parameters)
+ pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs)
+ response = pipeline_response.http_response
+
+ if response.status_code not in [200]:
+ map_error(status_code=response.status_code, response=response, error_map=error_map)
+ error = self._deserialize(models.Error, response)
+ raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat)
+
+ deserialized = self._deserialize('HealthBot', pipeline_response)
+
+ if cls:
+ return cls(pipeline_response, deserialized, {})
+
+ return deserialized
+ get.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.HealthBot/healthBots/{botName}'} # type: ignore
+
+ async def update(
+ self,
+ resource_group_name: str,
+ bot_name: str,
+ parameters: "models.HealthBotUpdateParameters",
+ **kwargs
+ ) -> "models.HealthBot":
+ """Patch a HealthBot.
+
+ :param resource_group_name: The name of the Bot resource group in the user subscription.
+ :type resource_group_name: str
+ :param bot_name: The name of the Bot resource.
+ :type bot_name: str
+ :param parameters: The parameters to provide for the required bot.
+ :type parameters: ~azure.mgmt.healthbot.models.HealthBotUpdateParameters
+ :keyword callable cls: A custom type or function that will be passed the direct response
+ :return: HealthBot, or the result of cls(response)
+ :rtype: ~azure.mgmt.healthbot.models.HealthBot
+ :raises: ~azure.core.exceptions.HttpResponseError
+ """
+ cls = kwargs.pop('cls', None) # type: ClsType["models.HealthBot"]
+ error_map = {
+ 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError
+ }
+ error_map.update(kwargs.pop('error_map', {}))
+ api_version = "2020-12-08"
+ content_type = kwargs.pop("content_type", "application/json")
+ accept = "application/json"
+
+ # Construct URL
+ url = self.update.metadata['url'] # type: ignore
+ path_format_arguments = {
+ 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'),
+ 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=64, min_length=2, pattern=r'^[a-zA-Z0-9][a-zA-Z0-9_.-]*$'),
+ 'botName': self._serialize.url("bot_name", bot_name, 'str', max_length=64, min_length=2, pattern=r'^[a-zA-Z0-9][a-zA-Z0-9_.-]*$'),
+ }
+ url = self._client.format_url(url, **path_format_arguments)
+
+ # Construct parameters
+ query_parameters = {} # type: Dict[str, Any]
+ query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str')
+
+ # Construct headers
+ header_parameters = {} # type: Dict[str, Any]
+ header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str')
+ header_parameters['Accept'] = self._serialize.header("accept", accept, 'str')
+
+ body_content_kwargs = {} # type: Dict[str, Any]
+ body_content = self._serialize.body(parameters, 'HealthBotUpdateParameters')
+ body_content_kwargs['content'] = body_content
+ request = self._client.patch(url, query_parameters, header_parameters, **body_content_kwargs)
+ pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs)
+ response = pipeline_response.http_response
+
+ if response.status_code not in [200, 201]:
+ map_error(status_code=response.status_code, response=response, error_map=error_map)
+ error = self._deserialize(models.Error, response)
+ raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat)
+
+ if response.status_code == 200:
+ deserialized = self._deserialize('HealthBot', pipeline_response)
+
+ if response.status_code == 201:
+ deserialized = self._deserialize('HealthBot', pipeline_response)
+
+ if cls:
+ return cls(pipeline_response, deserialized, {})
+
+ return deserialized
+ update.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.HealthBot/healthBots/{botName}'} # type: ignore
+
+ async def _delete_initial(
+ self,
+ resource_group_name: str,
+ bot_name: str,
+ **kwargs
+ ) -> None:
+ cls = kwargs.pop('cls', None) # type: ClsType[None]
+ error_map = {
+ 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError
+ }
+ error_map.update(kwargs.pop('error_map', {}))
+ api_version = "2020-12-08"
+ accept = "application/json"
+
+ # Construct URL
+ url = self._delete_initial.metadata['url'] # type: ignore
+ path_format_arguments = {
+ 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'),
+ 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=64, min_length=2, pattern=r'^[a-zA-Z0-9][a-zA-Z0-9_.-]*$'),
+ 'botName': self._serialize.url("bot_name", bot_name, 'str', max_length=64, min_length=2, pattern=r'^[a-zA-Z0-9][a-zA-Z0-9_.-]*$'),
+ }
+ url = self._client.format_url(url, **path_format_arguments)
+
+ # Construct parameters
+ query_parameters = {} # type: Dict[str, Any]
+ query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str')
+
+ # Construct headers
+ header_parameters = {} # type: Dict[str, Any]
+ header_parameters['Accept'] = self._serialize.header("accept", accept, 'str')
+
+ request = self._client.delete(url, query_parameters, header_parameters)
+ pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs)
+ response = pipeline_response.http_response
+
+ if response.status_code not in [200, 202, 204]:
+ map_error(status_code=response.status_code, response=response, error_map=error_map)
+ error = self._deserialize(models.Error, response)
+ raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat)
+
+ if cls:
+ return cls(pipeline_response, None, {})
+
+ _delete_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.HealthBot/healthBots/{botName}'} # type: ignore
+
+ async def begin_delete(
+ self,
+ resource_group_name: str,
+ bot_name: str,
+ **kwargs
+ ) -> AsyncLROPoller[None]:
+ """Delete a HealthBot.
+
+ :param resource_group_name: The name of the Bot resource group in the user subscription.
+ :type resource_group_name: str
+ :param bot_name: The name of the Bot resource.
+ :type bot_name: str
+ :keyword callable cls: A custom type or function that will be passed the direct response
+ :keyword str continuation_token: A continuation token to restart a poller from a saved state.
+ :keyword polling: True for ARMPolling, False for no polling, or a
+ polling object for personal polling strategy
+ :paramtype polling: bool or ~azure.core.polling.AsyncPollingMethod
+ :keyword int polling_interval: Default waiting time between two polls for LRO operations if no Retry-After header is present.
+ :return: An instance of AsyncLROPoller that returns either None or the result of cls(response)
+ :rtype: ~azure.core.polling.AsyncLROPoller[None]
+ :raises ~azure.core.exceptions.HttpResponseError:
+ """
+ polling = kwargs.pop('polling', True) # type: Union[bool, AsyncPollingMethod]
+ cls = kwargs.pop('cls', None) # type: ClsType[None]
+ lro_delay = kwargs.pop(
+ 'polling_interval',
+ self._config.polling_interval
+ )
+ cont_token = kwargs.pop('continuation_token', None) # type: Optional[str]
+ if cont_token is None:
+ raw_result = await self._delete_initial(
+ resource_group_name=resource_group_name,
+ bot_name=bot_name,
+ cls=lambda x,y,z: x,
+ **kwargs
+ )
+
+ kwargs.pop('error_map', None)
+ kwargs.pop('content_type', None)
+
+ def get_long_running_output(pipeline_response):
+ if cls:
+ return cls(pipeline_response, None, {})
+
+ path_format_arguments = {
+ 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'),
+ 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=64, min_length=2, pattern=r'^[a-zA-Z0-9][a-zA-Z0-9_.-]*$'),
+ 'botName': self._serialize.url("bot_name", bot_name, 'str', max_length=64, min_length=2, pattern=r'^[a-zA-Z0-9][a-zA-Z0-9_.-]*$'),
+ }
+
+ if polling is True: polling_method = AsyncARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs)
+ elif polling is False: polling_method = AsyncNoPolling()
+ else: polling_method = polling
+ if cont_token:
+ return AsyncLROPoller.from_continuation_token(
+ polling_method=polling_method,
+ continuation_token=cont_token,
+ client=self._client,
+ deserialization_callback=get_long_running_output
+ )
+ else:
+ return AsyncLROPoller(self._client, raw_result, get_long_running_output, polling_method)
+ begin_delete.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.HealthBot/healthBots/{botName}'} # type: ignore
+
+ def list_by_resource_group(
+ self,
+ resource_group_name: str,
+ **kwargs
+ ) -> AsyncIterable["models.BotResponseList"]:
+ """Returns all the resources of a particular type belonging to a resource group.
+
+ :param resource_group_name: The name of the Bot resource group in the user subscription.
+ :type resource_group_name: str
+ :keyword callable cls: A custom type or function that will be passed the direct response
+ :return: An iterator like instance of either BotResponseList or the result of cls(response)
+ :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.healthbot.models.BotResponseList]
+ :raises: ~azure.core.exceptions.HttpResponseError
+ """
+ cls = kwargs.pop('cls', None) # type: ClsType["models.BotResponseList"]
+ error_map = {
+ 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError
+ }
+ error_map.update(kwargs.pop('error_map', {}))
+ api_version = "2020-12-08"
+ accept = "application/json"
+
+ def prepare_request(next_link=None):
+ # Construct headers
+ header_parameters = {} # type: Dict[str, Any]
+ header_parameters['Accept'] = self._serialize.header("accept", accept, 'str')
+
+ if not next_link:
+ # Construct URL
+ url = self.list_by_resource_group.metadata['url'] # type: ignore
+ path_format_arguments = {
+ 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=64, min_length=2, pattern=r'^[a-zA-Z0-9][a-zA-Z0-9_.-]*$'),
+ 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'),
+ }
+ url = self._client.format_url(url, **path_format_arguments)
+ # Construct parameters
+ query_parameters = {} # type: Dict[str, Any]
+ query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str')
+
+ request = self._client.get(url, query_parameters, header_parameters)
+ else:
+ url = next_link
+ query_parameters = {} # type: Dict[str, Any]
+ request = self._client.get(url, query_parameters, header_parameters)
+ return request
+
+ async def extract_data(pipeline_response):
+ deserialized = self._deserialize('BotResponseList', pipeline_response)
+ list_of_elem = deserialized.value
+ if cls:
+ list_of_elem = cls(list_of_elem)
+ return deserialized.next_link or None, AsyncList(list_of_elem)
+
+ async def get_next(next_link=None):
+ request = prepare_request(next_link)
+
+ pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs)
+ response = pipeline_response.http_response
+
+ if response.status_code not in [200]:
+ error = self._deserialize(models.Error, response)
+ map_error(status_code=response.status_code, response=response, error_map=error_map)
+ raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat)
+
+ return pipeline_response
+
+ return AsyncItemPaged(
+ get_next, extract_data
+ )
+ list_by_resource_group.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.HealthBot/healthBots'} # type: ignore
+
+ def list(
+ self,
+ **kwargs
+ ) -> AsyncIterable["models.BotResponseList"]:
+ """Returns all the resources of a particular type belonging to a subscription.
+
+ :keyword callable cls: A custom type or function that will be passed the direct response
+ :return: An iterator like instance of either BotResponseList or the result of cls(response)
+ :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.healthbot.models.BotResponseList]
+ :raises: ~azure.core.exceptions.HttpResponseError
+ """
+ cls = kwargs.pop('cls', None) # type: ClsType["models.BotResponseList"]
+ error_map = {
+ 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError
+ }
+ error_map.update(kwargs.pop('error_map', {}))
+ api_version = "2020-12-08"
+ accept = "application/json"
+
+ def prepare_request(next_link=None):
+ # Construct headers
+ header_parameters = {} # type: Dict[str, Any]
+ header_parameters['Accept'] = self._serialize.header("accept", accept, 'str')
+
+ if not next_link:
+ # Construct URL
+ url = self.list.metadata['url'] # type: ignore
+ path_format_arguments = {
+ 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'),
+ }
+ url = self._client.format_url(url, **path_format_arguments)
+ # Construct parameters
+ query_parameters = {} # type: Dict[str, Any]
+ query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str')
+
+ request = self._client.get(url, query_parameters, header_parameters)
+ else:
+ url = next_link
+ query_parameters = {} # type: Dict[str, Any]
+ request = self._client.get(url, query_parameters, header_parameters)
+ return request
+
+ async def extract_data(pipeline_response):
+ deserialized = self._deserialize('BotResponseList', pipeline_response)
+ list_of_elem = deserialized.value
+ if cls:
+ list_of_elem = cls(list_of_elem)
+ return deserialized.next_link or None, AsyncList(list_of_elem)
+
+ async def get_next(next_link=None):
+ request = prepare_request(next_link)
+
+ pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs)
+ response = pipeline_response.http_response
+
+ if response.status_code not in [200]:
+ error = self._deserialize(models.Error, response)
+ map_error(status_code=response.status_code, response=response, error_map=error_map)
+ raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat)
+
+ return pipeline_response
+
+ return AsyncItemPaged(
+ get_next, extract_data
+ )
+ list.metadata = {'url': '/subscriptions/{subscriptionId}/providers/Microsoft.HealthBot/healthBots'} # type: ignore
diff --git a/src/healthbot/azext_healthbot/vendored_sdks/healthbot/aio/operations/_operations.py b/src/healthbot/azext_healthbot/vendored_sdks/healthbot/aio/operations/_operations.py
new file mode 100644
index 00000000000..57c308c8fe1
--- /dev/null
+++ b/src/healthbot/azext_healthbot/vendored_sdks/healthbot/aio/operations/_operations.py
@@ -0,0 +1,105 @@
+# coding=utf-8
+# --------------------------------------------------------------------------
+# Copyright (c) Microsoft Corporation. All rights reserved.
+# Licensed under the MIT License. See License.txt in the project root for license information.
+# Code generated by Microsoft (R) AutoRest Code Generator.
+# Changes may cause incorrect behavior and will be lost if the code is regenerated.
+# --------------------------------------------------------------------------
+from typing import Any, AsyncIterable, Callable, Dict, Generic, Optional, TypeVar
+import warnings
+
+from azure.core.async_paging import AsyncItemPaged, AsyncList
+from azure.core.exceptions import ClientAuthenticationError, HttpResponseError, ResourceExistsError, ResourceNotFoundError, map_error
+from azure.core.pipeline import PipelineResponse
+from azure.core.pipeline.transport import AsyncHttpResponse, HttpRequest
+from azure.mgmt.core.exceptions import ARMErrorFormat
+
+from ... import models
+
+T = TypeVar('T')
+ClsType = Optional[Callable[[PipelineResponse[HttpRequest, AsyncHttpResponse], T, Dict[str, Any]], Any]]
+
+class Operations:
+ """Operations async operations.
+
+ You should not instantiate this class directly. Instead, you should create a Client instance that
+ instantiates it for you and attaches it as an attribute.
+
+ :ivar models: Alias to model classes used in this operation group.
+ :type models: ~azure.mgmt.healthbot.models
+ :param client: Client for service requests.
+ :param config: Configuration of service client.
+ :param serializer: An object model serializer.
+ :param deserializer: An object model deserializer.
+ """
+
+ models = models
+
+ def __init__(self, client, config, serializer, deserializer) -> None:
+ self._client = client
+ self._serialize = serializer
+ self._deserialize = deserializer
+ self._config = config
+
+ def list(
+ self,
+ **kwargs
+ ) -> AsyncIterable["models.AvailableOperations"]:
+ """Lists all the available HealthBot operations.
+
+ :keyword callable cls: A custom type or function that will be passed the direct response
+ :return: An iterator like instance of either AvailableOperations or the result of cls(response)
+ :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.healthbot.models.AvailableOperations]
+ :raises: ~azure.core.exceptions.HttpResponseError
+ """
+ cls = kwargs.pop('cls', None) # type: ClsType["models.AvailableOperations"]
+ error_map = {
+ 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError
+ }
+ error_map.update(kwargs.pop('error_map', {}))
+ api_version = "2020-12-08"
+ accept = "application/json"
+
+ def prepare_request(next_link=None):
+ # Construct headers
+ header_parameters = {} # type: Dict[str, Any]
+ header_parameters['Accept'] = self._serialize.header("accept", accept, 'str')
+
+ if not next_link:
+ # Construct URL
+ url = self.list.metadata['url'] # type: ignore
+ # Construct parameters
+ query_parameters = {} # type: Dict[str, Any]
+ query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str')
+
+ request = self._client.get(url, query_parameters, header_parameters)
+ else:
+ url = next_link
+ query_parameters = {} # type: Dict[str, Any]
+ request = self._client.get(url, query_parameters, header_parameters)
+ return request
+
+ async def extract_data(pipeline_response):
+ deserialized = self._deserialize('AvailableOperations', pipeline_response)
+ list_of_elem = deserialized.value
+ if cls:
+ list_of_elem = cls(list_of_elem)
+ return deserialized.next_link or None, AsyncList(list_of_elem)
+
+ async def get_next(next_link=None):
+ request = prepare_request(next_link)
+
+ pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs)
+ response = pipeline_response.http_response
+
+ if response.status_code not in [200]:
+ error = self._deserialize(models.Error, response)
+ map_error(status_code=response.status_code, response=response, error_map=error_map)
+ raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat)
+
+ return pipeline_response
+
+ return AsyncItemPaged(
+ get_next, extract_data
+ )
+ list.metadata = {'url': '/providers/Microsoft.HealthBot/operations'} # type: ignore
diff --git a/src/healthbot/azext_healthbot/vendored_sdks/healthbot/models/__init__.py b/src/healthbot/azext_healthbot/vendored_sdks/healthbot/models/__init__.py
new file mode 100644
index 00000000000..ad76102b936
--- /dev/null
+++ b/src/healthbot/azext_healthbot/vendored_sdks/healthbot/models/__init__.py
@@ -0,0 +1,65 @@
+# coding=utf-8
+# --------------------------------------------------------------------------
+# Copyright (c) Microsoft Corporation. All rights reserved.
+# Licensed under the MIT License. See License.txt in the project root for license information.
+# Code generated by Microsoft (R) AutoRest Code Generator.
+# Changes may cause incorrect behavior and will be lost if the code is regenerated.
+# --------------------------------------------------------------------------
+
+try:
+ from ._models_py3 import AvailableOperations
+ from ._models_py3 import BotResponseList
+ from ._models_py3 import Error
+ from ._models_py3 import ErrorAdditionalInfo
+ from ._models_py3 import Errorautogenerated
+ from ._models_py3 import HealthBot
+ from ._models_py3 import HealthBotProperties
+ from ._models_py3 import HealthBotUpdateParameters
+ from ._models_py3 import OperationDetail
+ from ._models_py3 import OperationDisplay
+ from ._models_py3 import Resource
+ from ._models_py3 import Sku
+ from ._models_py3 import SystemData
+ from ._models_py3 import TrackedResource
+ from ._models_py3 import ValidationResult
+except (SyntaxError, ImportError):
+ from ._models import AvailableOperations # type: ignore
+ from ._models import BotResponseList # type: ignore
+ from ._models import Error # type: ignore
+ from ._models import ErrorAdditionalInfo # type: ignore
+ from ._models import Errorautogenerated # type: ignore
+ from ._models import HealthBot # type: ignore
+ from ._models import HealthBotProperties # type: ignore
+ from ._models import HealthBotUpdateParameters # type: ignore
+ from ._models import OperationDetail # type: ignore
+ from ._models import OperationDisplay # type: ignore
+ from ._models import Resource # type: ignore
+ from ._models import Sku # type: ignore
+ from ._models import SystemData # type: ignore
+ from ._models import TrackedResource # type: ignore
+ from ._models import ValidationResult # type: ignore
+
+from ._healthbot_client_enums import (
+ IdentityType,
+ SkuName,
+)
+
+__all__ = [
+ 'AvailableOperations',
+ 'BotResponseList',
+ 'Error',
+ 'ErrorAdditionalInfo',
+ 'Errorautogenerated',
+ 'HealthBot',
+ 'HealthBotProperties',
+ 'HealthBotUpdateParameters',
+ 'OperationDetail',
+ 'OperationDisplay',
+ 'Resource',
+ 'Sku',
+ 'SystemData',
+ 'TrackedResource',
+ 'ValidationResult',
+ 'IdentityType',
+ 'SkuName',
+]
diff --git a/src/healthbot/azext_healthbot/vendored_sdks/healthbot/models/_healthbot_client_enums.py b/src/healthbot/azext_healthbot/vendored_sdks/healthbot/models/_healthbot_client_enums.py
new file mode 100644
index 00000000000..e08d83568cb
--- /dev/null
+++ b/src/healthbot/azext_healthbot/vendored_sdks/healthbot/models/_healthbot_client_enums.py
@@ -0,0 +1,44 @@
+# coding=utf-8
+# --------------------------------------------------------------------------
+# Copyright (c) Microsoft Corporation. All rights reserved.
+# Licensed under the MIT License. See License.txt in the project root for license information.
+# Code generated by Microsoft (R) AutoRest Code Generator.
+# Changes may cause incorrect behavior and will be lost if the code is regenerated.
+# --------------------------------------------------------------------------
+
+from enum import Enum, EnumMeta
+from six import with_metaclass
+
+class _CaseInsensitiveEnumMeta(EnumMeta):
+ def __getitem__(self, name):
+ return super().__getitem__(name.upper())
+
+ def __getattr__(cls, name):
+ """Return the enum member matching `name`
+ We use __getattr__ instead of descriptors or inserting into the enum
+ class' __dict__ in order to support `name` and `value` being both
+ properties for enum members (which live in the class' __dict__) and
+ enum members themselves.
+ """
+ try:
+ return cls._member_map_[name.upper()]
+ except KeyError:
+ raise AttributeError(name)
+
+
+class IdentityType(with_metaclass(_CaseInsensitiveEnumMeta, str, Enum)):
+ """The type of identity that creates/modifies resources
+ """
+
+ USER = "User"
+ APPLICATION = "Application"
+ MANAGED_IDENTITY = "ManagedIdentity"
+ KEY = "Key"
+
+class SkuName(with_metaclass(_CaseInsensitiveEnumMeta, str, Enum)):
+ """The name of the HealthBot SKU
+ """
+
+ F0 = "F0"
+ S1 = "S1"
+ C0 = "C0"
diff --git a/src/healthbot/azext_healthbot/vendored_sdks/healthbot/models/_models.py b/src/healthbot/azext_healthbot/vendored_sdks/healthbot/models/_models.py
new file mode 100644
index 00000000000..815f08e205c
--- /dev/null
+++ b/src/healthbot/azext_healthbot/vendored_sdks/healthbot/models/_models.py
@@ -0,0 +1,504 @@
+# coding=utf-8
+# --------------------------------------------------------------------------
+# Copyright (c) Microsoft Corporation. All rights reserved.
+# Licensed under the MIT License. See License.txt in the project root for license information.
+# Code generated by Microsoft (R) AutoRest Code Generator.
+# Changes may cause incorrect behavior and will be lost if the code is regenerated.
+# --------------------------------------------------------------------------
+
+from azure.core.exceptions import HttpResponseError
+import msrest.serialization
+
+
+class AvailableOperations(msrest.serialization.Model):
+ """Available operations of the service.
+
+ :param value: Collection of available operation details.
+ :type value: list[~azure.mgmt.healthbot.models.OperationDetail]
+ :param next_link: URL client should use to fetch the next page (per server side paging).
+ It's null for now, added for future use.
+ :type next_link: str
+ """
+
+ _attribute_map = {
+ 'value': {'key': 'value', 'type': '[OperationDetail]'},
+ 'next_link': {'key': 'nextLink', 'type': 'str'},
+ }
+
+ def __init__(
+ self,
+ **kwargs
+ ):
+ super(AvailableOperations, self).__init__(**kwargs)
+ self.value = kwargs.get('value', None)
+ self.next_link = kwargs.get('next_link', None)
+
+
+class BotResponseList(msrest.serialization.Model):
+ """The list of Healthbot operation response.
+
+ Variables are only populated by the server, and will be ignored when sending a request.
+
+ :ivar next_link: The link used to get the next page of bot service resources.
+ :vartype next_link: str
+ :ivar value: Gets the list of Healthbot results and their properties.
+ :vartype value: list[~azure.mgmt.healthbot.models.HealthBot]
+ """
+
+ _validation = {
+ 'next_link': {'readonly': True},
+ 'value': {'readonly': True},
+ }
+
+ _attribute_map = {
+ 'next_link': {'key': 'nextLink', 'type': 'str'},
+ 'value': {'key': 'value', 'type': '[HealthBot]'},
+ }
+
+ def __init__(
+ self,
+ **kwargs
+ ):
+ super(BotResponseList, self).__init__(**kwargs)
+ self.next_link = None
+ self.value = None
+
+
+class Error(msrest.serialization.Model):
+ """The resource management error response.
+
+ :param error: The error object.
+ :type error: ~azure.mgmt.healthbot.models.Errorautogenerated
+ """
+
+ _attribute_map = {
+ 'error': {'key': 'error', 'type': 'Errorautogenerated'},
+ }
+
+ def __init__(
+ self,
+ **kwargs
+ ):
+ super(Error, self).__init__(**kwargs)
+ self.error = kwargs.get('error', None)
+
+
+class ErrorAdditionalInfo(msrest.serialization.Model):
+ """The resource management error additional info.
+
+ Variables are only populated by the server, and will be ignored when sending a request.
+
+ :ivar type: The additional info type.
+ :vartype type: str
+ :ivar info: The additional info.
+ :vartype info: object
+ """
+
+ _validation = {
+ 'type': {'readonly': True},
+ 'info': {'readonly': True},
+ }
+
+ _attribute_map = {
+ 'type': {'key': 'type', 'type': 'str'},
+ 'info': {'key': 'info', 'type': 'object'},
+ }
+
+ def __init__(
+ self,
+ **kwargs
+ ):
+ super(ErrorAdditionalInfo, self).__init__(**kwargs)
+ self.type = None
+ self.info = None
+
+
+class Errorautogenerated(msrest.serialization.Model):
+ """The error object.
+
+ Variables are only populated by the server, and will be ignored when sending a request.
+
+ :ivar code: The error code.
+ :vartype code: str
+ :ivar message: The error message.
+ :vartype message: str
+ :ivar target: The error target.
+ :vartype target: str
+ :ivar details: The error details.
+ :vartype details: list[~azure.mgmt.healthbot.models.Error]
+ :ivar additional_info: The error additional info.
+ :vartype additional_info: list[~azure.mgmt.healthbot.models.ErrorAdditionalInfo]
+ """
+
+ _validation = {
+ 'code': {'readonly': True},
+ 'message': {'readonly': True},
+ 'target': {'readonly': True},
+ 'details': {'readonly': True},
+ 'additional_info': {'readonly': True},
+ }
+
+ _attribute_map = {
+ 'code': {'key': 'code', 'type': 'str'},
+ 'message': {'key': 'message', 'type': 'str'},
+ 'target': {'key': 'target', 'type': 'str'},
+ 'details': {'key': 'details', 'type': '[Error]'},
+ 'additional_info': {'key': 'additionalInfo', 'type': '[ErrorAdditionalInfo]'},
+ }
+
+ def __init__(
+ self,
+ **kwargs
+ ):
+ super(Errorautogenerated, self).__init__(**kwargs)
+ self.code = None
+ self.message = None
+ self.target = None
+ self.details = None
+ self.additional_info = None
+
+
+class Resource(msrest.serialization.Model):
+ """The resource model definition for a ARM tracked top level resource.
+
+ Variables are only populated by the server, and will be ignored when sending a request.
+
+ :ivar id: Fully qualified resource Id for the resource.
+ :vartype id: str
+ :ivar name: The name of the resource.
+ :vartype name: str
+ :ivar type: The type of the resource.
+ :vartype type: str
+ :ivar system_data: Metadata pertaining to creation and last modification of the resource.
+ :vartype system_data: ~azure.mgmt.healthbot.models.SystemData
+ """
+
+ _validation = {
+ 'id': {'readonly': True},
+ 'name': {'readonly': True},
+ 'type': {'readonly': True},
+ 'system_data': {'readonly': True},
+ }
+
+ _attribute_map = {
+ 'id': {'key': 'id', 'type': 'str'},
+ 'name': {'key': 'name', 'type': 'str'},
+ 'type': {'key': 'type', 'type': 'str'},
+ 'system_data': {'key': 'systemData', 'type': 'SystemData'},
+ }
+
+ def __init__(
+ self,
+ **kwargs
+ ):
+ super(Resource, self).__init__(**kwargs)
+ self.id = None
+ self.name = None
+ self.type = None
+ self.system_data = None
+
+
+class TrackedResource(Resource):
+ """The resource model definition for a ARM tracked top level resource.
+
+ Variables are only populated by the server, and will be ignored when sending a request.
+
+ All required parameters must be populated in order to send to Azure.
+
+ :ivar id: Fully qualified resource Id for the resource.
+ :vartype id: str
+ :ivar name: The name of the resource.
+ :vartype name: str
+ :ivar type: The type of the resource.
+ :vartype type: str
+ :ivar system_data: Metadata pertaining to creation and last modification of the resource.
+ :vartype system_data: ~azure.mgmt.healthbot.models.SystemData
+ :param tags: A set of tags. Resource tags.
+ :type tags: dict[str, str]
+ :param location: Required. The geo-location where the resource lives.
+ :type location: str
+ """
+
+ _validation = {
+ 'id': {'readonly': True},
+ 'name': {'readonly': True},
+ 'type': {'readonly': True},
+ 'system_data': {'readonly': True},
+ 'location': {'required': True},
+ }
+
+ _attribute_map = {
+ 'id': {'key': 'id', 'type': 'str'},
+ 'name': {'key': 'name', 'type': 'str'},
+ 'type': {'key': 'type', 'type': 'str'},
+ 'system_data': {'key': 'systemData', 'type': 'SystemData'},
+ 'tags': {'key': 'tags', 'type': '{str}'},
+ 'location': {'key': 'location', 'type': 'str'},
+ }
+
+ def __init__(
+ self,
+ **kwargs
+ ):
+ super(TrackedResource, self).__init__(**kwargs)
+ self.tags = kwargs.get('tags', None)
+ self.location = kwargs['location']
+
+
+class HealthBot(TrackedResource):
+ """HealthBot resource definition.
+
+ Variables are only populated by the server, and will be ignored when sending a request.
+
+ All required parameters must be populated in order to send to Azure.
+
+ :ivar id: Fully qualified resource Id for the resource.
+ :vartype id: str
+ :ivar name: The name of the resource.
+ :vartype name: str
+ :ivar type: The type of the resource.
+ :vartype type: str
+ :ivar system_data: Metadata pertaining to creation and last modification of the resource.
+ :vartype system_data: ~azure.mgmt.healthbot.models.SystemData
+ :param tags: A set of tags. Resource tags.
+ :type tags: dict[str, str]
+ :param location: Required. The geo-location where the resource lives.
+ :type location: str
+ :param sku: Required. SKU of the HealthBot.
+ :type sku: ~azure.mgmt.healthbot.models.Sku
+ :param properties: The set of properties specific to Healthbot resource.
+ :type properties: ~azure.mgmt.healthbot.models.HealthBotProperties
+ """
+
+ _validation = {
+ 'id': {'readonly': True},
+ 'name': {'readonly': True},
+ 'type': {'readonly': True},
+ 'system_data': {'readonly': True},
+ 'location': {'required': True},
+ 'sku': {'required': True},
+ }
+
+ _attribute_map = {
+ 'id': {'key': 'id', 'type': 'str'},
+ 'name': {'key': 'name', 'type': 'str'},
+ 'type': {'key': 'type', 'type': 'str'},
+ 'system_data': {'key': 'systemData', 'type': 'SystemData'},
+ 'tags': {'key': 'tags', 'type': '{str}'},
+ 'location': {'key': 'location', 'type': 'str'},
+ 'sku': {'key': 'sku', 'type': 'Sku'},
+ 'properties': {'key': 'properties', 'type': 'HealthBotProperties'},
+ }
+
+ def __init__(
+ self,
+ **kwargs
+ ):
+ super(HealthBot, self).__init__(**kwargs)
+ self.sku = kwargs['sku']
+ self.properties = kwargs.get('properties', None)
+
+
+class HealthBotProperties(msrest.serialization.Model):
+ """The properties of a HealthBot. The Health Bot Service is a cloud platform that empowers developers in Healthcare organizations to build and deploy their compliant, AI-powered virtual health assistants and health bots, that help them improve processes and reduce costs.
+
+ Variables are only populated by the server, and will be ignored when sending a request.
+
+ :ivar provisioning_state: The provisioning state of the Healthbot resource.
+ :vartype provisioning_state: str
+ :ivar bot_management_portal_link: The link.
+ :vartype bot_management_portal_link: str
+ """
+
+ _validation = {
+ 'provisioning_state': {'readonly': True},
+ 'bot_management_portal_link': {'readonly': True},
+ }
+
+ _attribute_map = {
+ 'provisioning_state': {'key': 'provisioningState', 'type': 'str'},
+ 'bot_management_portal_link': {'key': 'botManagementPortalLink', 'type': 'str'},
+ }
+
+ def __init__(
+ self,
+ **kwargs
+ ):
+ super(HealthBotProperties, self).__init__(**kwargs)
+ self.provisioning_state = None
+ self.bot_management_portal_link = None
+
+
+class HealthBotUpdateParameters(msrest.serialization.Model):
+ """Parameters for updating a HealthBot.
+
+ :param tags: A set of tags. Tags for a HealthBot.
+ :type tags: dict[str, str]
+ :param sku: SKU of the HealthBot.
+ :type sku: ~azure.mgmt.healthbot.models.Sku
+ """
+
+ _attribute_map = {
+ 'tags': {'key': 'tags', 'type': '{str}'},
+ 'sku': {'key': 'sku', 'type': 'Sku'},
+ }
+
+ def __init__(
+ self,
+ **kwargs
+ ):
+ super(HealthBotUpdateParameters, self).__init__(**kwargs)
+ self.tags = kwargs.get('tags', None)
+ self.sku = kwargs.get('sku', None)
+
+
+class OperationDetail(msrest.serialization.Model):
+ """Operation detail payload.
+
+ :param name: Name of the operation.
+ :type name: str
+ :param is_data_action: Indicates whether the operation is a data action.
+ :type is_data_action: bool
+ :param display: Display of the operation.
+ :type display: ~azure.mgmt.healthbot.models.OperationDisplay
+ :param origin: Origin of the operation.
+ :type origin: str
+ :param properties: Additional properties.
+ :type properties: object
+ """
+
+ _attribute_map = {
+ 'name': {'key': 'name', 'type': 'str'},
+ 'is_data_action': {'key': 'isDataAction', 'type': 'bool'},
+ 'display': {'key': 'display', 'type': 'OperationDisplay'},
+ 'origin': {'key': 'origin', 'type': 'str'},
+ 'properties': {'key': 'properties', 'type': 'object'},
+ }
+
+ def __init__(
+ self,
+ **kwargs
+ ):
+ super(OperationDetail, self).__init__(**kwargs)
+ self.name = kwargs.get('name', None)
+ self.is_data_action = kwargs.get('is_data_action', None)
+ self.display = kwargs.get('display', None)
+ self.origin = kwargs.get('origin', None)
+ self.properties = kwargs.get('properties', None)
+
+
+class OperationDisplay(msrest.serialization.Model):
+ """Operation display payload.
+
+ :param provider: Resource provider of the operation.
+ :type provider: str
+ :param resource: Resource of the operation.
+ :type resource: str
+ :param operation: Localized friendly name for the operation.
+ :type operation: str
+ :param description: Localized friendly description for the operation.
+ :type description: str
+ """
+
+ _attribute_map = {
+ 'provider': {'key': 'provider', 'type': 'str'},
+ 'resource': {'key': 'resource', 'type': 'str'},
+ 'operation': {'key': 'operation', 'type': 'str'},
+ 'description': {'key': 'description', 'type': 'str'},
+ }
+
+ def __init__(
+ self,
+ **kwargs
+ ):
+ super(OperationDisplay, self).__init__(**kwargs)
+ self.provider = kwargs.get('provider', None)
+ self.resource = kwargs.get('resource', None)
+ self.operation = kwargs.get('operation', None)
+ self.description = kwargs.get('description', None)
+
+
+class Sku(msrest.serialization.Model):
+ """The resource model definition representing SKU.
+
+ All required parameters must be populated in order to send to Azure.
+
+ :param name: Required. The name of the HealthBot SKU. Possible values include: "F0", "S1",
+ "C0".
+ :type name: str or ~azure.mgmt.healthbot.models.SkuName
+ """
+
+ _validation = {
+ 'name': {'required': True},
+ }
+
+ _attribute_map = {
+ 'name': {'key': 'name', 'type': 'str'},
+ }
+
+ def __init__(
+ self,
+ **kwargs
+ ):
+ super(Sku, self).__init__(**kwargs)
+ self.name = kwargs['name']
+
+
+class SystemData(msrest.serialization.Model):
+ """Read only system data.
+
+ :param created_by: The identity that created the resource.
+ :type created_by: str
+ :param created_by_type: The type of identity that created the resource. Possible values
+ include: "User", "Application", "ManagedIdentity", "Key".
+ :type created_by_type: str or ~azure.mgmt.healthbot.models.IdentityType
+ :param created_at: The timestamp of resource creation (UTC).
+ :type created_at: ~datetime.datetime
+ :param last_modified_by: The identity that last modified the resource.
+ :type last_modified_by: str
+ :param last_modified_by_type: The type of identity that last modified the resource. Possible
+ values include: "User", "Application", "ManagedIdentity", "Key".
+ :type last_modified_by_type: str or ~azure.mgmt.healthbot.models.IdentityType
+ :param last_modified_at: The timestamp of resource last modification (UTC).
+ :type last_modified_at: ~datetime.datetime
+ """
+
+ _attribute_map = {
+ 'created_by': {'key': 'createdBy', 'type': 'str'},
+ 'created_by_type': {'key': 'createdByType', 'type': 'str'},
+ 'created_at': {'key': 'createdAt', 'type': 'iso-8601'},
+ 'last_modified_by': {'key': 'lastModifiedBy', 'type': 'str'},
+ 'last_modified_by_type': {'key': 'lastModifiedByType', 'type': 'str'},
+ 'last_modified_at': {'key': 'lastModifiedAt', 'type': 'iso-8601'},
+ }
+
+ def __init__(
+ self,
+ **kwargs
+ ):
+ super(SystemData, self).__init__(**kwargs)
+ self.created_by = kwargs.get('created_by', None)
+ self.created_by_type = kwargs.get('created_by_type', None)
+ self.created_at = kwargs.get('created_at', None)
+ self.last_modified_by = kwargs.get('last_modified_by', None)
+ self.last_modified_by_type = kwargs.get('last_modified_by_type', None)
+ self.last_modified_at = kwargs.get('last_modified_at', None)
+
+
+class ValidationResult(msrest.serialization.Model):
+ """The response returned from validation process.
+
+ :param status: The status code of the response validation.
+ :type status: str
+ """
+
+ _attribute_map = {
+ 'status': {'key': 'status', 'type': 'str'},
+ }
+
+ def __init__(
+ self,
+ **kwargs
+ ):
+ super(ValidationResult, self).__init__(**kwargs)
+ self.status = kwargs.get('status', None)
diff --git a/src/healthbot/azext_healthbot/vendored_sdks/healthbot/models/_models_py3.py b/src/healthbot/azext_healthbot/vendored_sdks/healthbot/models/_models_py3.py
new file mode 100644
index 00000000000..a292b226c6a
--- /dev/null
+++ b/src/healthbot/azext_healthbot/vendored_sdks/healthbot/models/_models_py3.py
@@ -0,0 +1,547 @@
+# coding=utf-8
+# --------------------------------------------------------------------------
+# Copyright (c) Microsoft Corporation. All rights reserved.
+# Licensed under the MIT License. See License.txt in the project root for license information.
+# Code generated by Microsoft (R) AutoRest Code Generator.
+# Changes may cause incorrect behavior and will be lost if the code is regenerated.
+# --------------------------------------------------------------------------
+
+import datetime
+from typing import Dict, List, Optional, Union
+
+from azure.core.exceptions import HttpResponseError
+import msrest.serialization
+
+from ._healthbot_client_enums import *
+
+
+class AvailableOperations(msrest.serialization.Model):
+ """Available operations of the service.
+
+ :param value: Collection of available operation details.
+ :type value: list[~azure.mgmt.healthbot.models.OperationDetail]
+ :param next_link: URL client should use to fetch the next page (per server side paging).
+ It's null for now, added for future use.
+ :type next_link: str
+ """
+
+ _attribute_map = {
+ 'value': {'key': 'value', 'type': '[OperationDetail]'},
+ 'next_link': {'key': 'nextLink', 'type': 'str'},
+ }
+
+ def __init__(
+ self,
+ *,
+ value: Optional[List["OperationDetail"]] = None,
+ next_link: Optional[str] = None,
+ **kwargs
+ ):
+ super(AvailableOperations, self).__init__(**kwargs)
+ self.value = value
+ self.next_link = next_link
+
+
+class BotResponseList(msrest.serialization.Model):
+ """The list of Healthbot operation response.
+
+ Variables are only populated by the server, and will be ignored when sending a request.
+
+ :ivar next_link: The link used to get the next page of bot service resources.
+ :vartype next_link: str
+ :ivar value: Gets the list of Healthbot results and their properties.
+ :vartype value: list[~azure.mgmt.healthbot.models.HealthBot]
+ """
+
+ _validation = {
+ 'next_link': {'readonly': True},
+ 'value': {'readonly': True},
+ }
+
+ _attribute_map = {
+ 'next_link': {'key': 'nextLink', 'type': 'str'},
+ 'value': {'key': 'value', 'type': '[HealthBot]'},
+ }
+
+ def __init__(
+ self,
+ **kwargs
+ ):
+ super(BotResponseList, self).__init__(**kwargs)
+ self.next_link = None
+ self.value = None
+
+
+class Error(msrest.serialization.Model):
+ """The resource management error response.
+
+ :param error: The error object.
+ :type error: ~azure.mgmt.healthbot.models.Errorautogenerated
+ """
+
+ _attribute_map = {
+ 'error': {'key': 'error', 'type': 'Errorautogenerated'},
+ }
+
+ def __init__(
+ self,
+ *,
+ error: Optional["Errorautogenerated"] = None,
+ **kwargs
+ ):
+ super(Error, self).__init__(**kwargs)
+ self.error = error
+
+
+class ErrorAdditionalInfo(msrest.serialization.Model):
+ """The resource management error additional info.
+
+ Variables are only populated by the server, and will be ignored when sending a request.
+
+ :ivar type: The additional info type.
+ :vartype type: str
+ :ivar info: The additional info.
+ :vartype info: object
+ """
+
+ _validation = {
+ 'type': {'readonly': True},
+ 'info': {'readonly': True},
+ }
+
+ _attribute_map = {
+ 'type': {'key': 'type', 'type': 'str'},
+ 'info': {'key': 'info', 'type': 'object'},
+ }
+
+ def __init__(
+ self,
+ **kwargs
+ ):
+ super(ErrorAdditionalInfo, self).__init__(**kwargs)
+ self.type = None
+ self.info = None
+
+
+class Errorautogenerated(msrest.serialization.Model):
+ """The error object.
+
+ Variables are only populated by the server, and will be ignored when sending a request.
+
+ :ivar code: The error code.
+ :vartype code: str
+ :ivar message: The error message.
+ :vartype message: str
+ :ivar target: The error target.
+ :vartype target: str
+ :ivar details: The error details.
+ :vartype details: list[~azure.mgmt.healthbot.models.Error]
+ :ivar additional_info: The error additional info.
+ :vartype additional_info: list[~azure.mgmt.healthbot.models.ErrorAdditionalInfo]
+ """
+
+ _validation = {
+ 'code': {'readonly': True},
+ 'message': {'readonly': True},
+ 'target': {'readonly': True},
+ 'details': {'readonly': True},
+ 'additional_info': {'readonly': True},
+ }
+
+ _attribute_map = {
+ 'code': {'key': 'code', 'type': 'str'},
+ 'message': {'key': 'message', 'type': 'str'},
+ 'target': {'key': 'target', 'type': 'str'},
+ 'details': {'key': 'details', 'type': '[Error]'},
+ 'additional_info': {'key': 'additionalInfo', 'type': '[ErrorAdditionalInfo]'},
+ }
+
+ def __init__(
+ self,
+ **kwargs
+ ):
+ super(Errorautogenerated, self).__init__(**kwargs)
+ self.code = None
+ self.message = None
+ self.target = None
+ self.details = None
+ self.additional_info = None
+
+
+class Resource(msrest.serialization.Model):
+ """The resource model definition for a ARM tracked top level resource.
+
+ Variables are only populated by the server, and will be ignored when sending a request.
+
+ :ivar id: Fully qualified resource Id for the resource.
+ :vartype id: str
+ :ivar name: The name of the resource.
+ :vartype name: str
+ :ivar type: The type of the resource.
+ :vartype type: str
+ :ivar system_data: Metadata pertaining to creation and last modification of the resource.
+ :vartype system_data: ~azure.mgmt.healthbot.models.SystemData
+ """
+
+ _validation = {
+ 'id': {'readonly': True},
+ 'name': {'readonly': True},
+ 'type': {'readonly': True},
+ 'system_data': {'readonly': True},
+ }
+
+ _attribute_map = {
+ 'id': {'key': 'id', 'type': 'str'},
+ 'name': {'key': 'name', 'type': 'str'},
+ 'type': {'key': 'type', 'type': 'str'},
+ 'system_data': {'key': 'systemData', 'type': 'SystemData'},
+ }
+
+ def __init__(
+ self,
+ **kwargs
+ ):
+ super(Resource, self).__init__(**kwargs)
+ self.id = None
+ self.name = None
+ self.type = None
+ self.system_data = None
+
+
+class TrackedResource(Resource):
+ """The resource model definition for a ARM tracked top level resource.
+
+ Variables are only populated by the server, and will be ignored when sending a request.
+
+ All required parameters must be populated in order to send to Azure.
+
+ :ivar id: Fully qualified resource Id for the resource.
+ :vartype id: str
+ :ivar name: The name of the resource.
+ :vartype name: str
+ :ivar type: The type of the resource.
+ :vartype type: str
+ :ivar system_data: Metadata pertaining to creation and last modification of the resource.
+ :vartype system_data: ~azure.mgmt.healthbot.models.SystemData
+ :param tags: A set of tags. Resource tags.
+ :type tags: dict[str, str]
+ :param location: Required. The geo-location where the resource lives.
+ :type location: str
+ """
+
+ _validation = {
+ 'id': {'readonly': True},
+ 'name': {'readonly': True},
+ 'type': {'readonly': True},
+ 'system_data': {'readonly': True},
+ 'location': {'required': True},
+ }
+
+ _attribute_map = {
+ 'id': {'key': 'id', 'type': 'str'},
+ 'name': {'key': 'name', 'type': 'str'},
+ 'type': {'key': 'type', 'type': 'str'},
+ 'system_data': {'key': 'systemData', 'type': 'SystemData'},
+ 'tags': {'key': 'tags', 'type': '{str}'},
+ 'location': {'key': 'location', 'type': 'str'},
+ }
+
+ def __init__(
+ self,
+ *,
+ location: str,
+ tags: Optional[Dict[str, str]] = None,
+ **kwargs
+ ):
+ super(TrackedResource, self).__init__(**kwargs)
+ self.tags = tags
+ self.location = location
+
+
+class HealthBot(TrackedResource):
+ """HealthBot resource definition.
+
+ Variables are only populated by the server, and will be ignored when sending a request.
+
+ All required parameters must be populated in order to send to Azure.
+
+ :ivar id: Fully qualified resource Id for the resource.
+ :vartype id: str
+ :ivar name: The name of the resource.
+ :vartype name: str
+ :ivar type: The type of the resource.
+ :vartype type: str
+ :ivar system_data: Metadata pertaining to creation and last modification of the resource.
+ :vartype system_data: ~azure.mgmt.healthbot.models.SystemData
+ :param tags: A set of tags. Resource tags.
+ :type tags: dict[str, str]
+ :param location: Required. The geo-location where the resource lives.
+ :type location: str
+ :param sku: Required. SKU of the HealthBot.
+ :type sku: ~azure.mgmt.healthbot.models.Sku
+ :param properties: The set of properties specific to Healthbot resource.
+ :type properties: ~azure.mgmt.healthbot.models.HealthBotProperties
+ """
+
+ _validation = {
+ 'id': {'readonly': True},
+ 'name': {'readonly': True},
+ 'type': {'readonly': True},
+ 'system_data': {'readonly': True},
+ 'location': {'required': True},
+ 'sku': {'required': True},
+ }
+
+ _attribute_map = {
+ 'id': {'key': 'id', 'type': 'str'},
+ 'name': {'key': 'name', 'type': 'str'},
+ 'type': {'key': 'type', 'type': 'str'},
+ 'system_data': {'key': 'systemData', 'type': 'SystemData'},
+ 'tags': {'key': 'tags', 'type': '{str}'},
+ 'location': {'key': 'location', 'type': 'str'},
+ 'sku': {'key': 'sku', 'type': 'Sku'},
+ 'properties': {'key': 'properties', 'type': 'HealthBotProperties'},
+ }
+
+ def __init__(
+ self,
+ *,
+ location: str,
+ sku: "Sku",
+ tags: Optional[Dict[str, str]] = None,
+ properties: Optional["HealthBotProperties"] = None,
+ **kwargs
+ ):
+ super(HealthBot, self).__init__(tags=tags, location=location, **kwargs)
+ self.sku = sku
+ self.properties = properties
+
+
+class HealthBotProperties(msrest.serialization.Model):
+ """The properties of a HealthBot. The Health Bot Service is a cloud platform that empowers developers in Healthcare organizations to build and deploy their compliant, AI-powered virtual health assistants and health bots, that help them improve processes and reduce costs.
+
+ Variables are only populated by the server, and will be ignored when sending a request.
+
+ :ivar provisioning_state: The provisioning state of the Healthbot resource.
+ :vartype provisioning_state: str
+ :ivar bot_management_portal_link: The link.
+ :vartype bot_management_portal_link: str
+ """
+
+ _validation = {
+ 'provisioning_state': {'readonly': True},
+ 'bot_management_portal_link': {'readonly': True},
+ }
+
+ _attribute_map = {
+ 'provisioning_state': {'key': 'provisioningState', 'type': 'str'},
+ 'bot_management_portal_link': {'key': 'botManagementPortalLink', 'type': 'str'},
+ }
+
+ def __init__(
+ self,
+ **kwargs
+ ):
+ super(HealthBotProperties, self).__init__(**kwargs)
+ self.provisioning_state = None
+ self.bot_management_portal_link = None
+
+
+class HealthBotUpdateParameters(msrest.serialization.Model):
+ """Parameters for updating a HealthBot.
+
+ :param tags: A set of tags. Tags for a HealthBot.
+ :type tags: dict[str, str]
+ :param sku: SKU of the HealthBot.
+ :type sku: ~azure.mgmt.healthbot.models.Sku
+ """
+
+ _attribute_map = {
+ 'tags': {'key': 'tags', 'type': '{str}'},
+ 'sku': {'key': 'sku', 'type': 'Sku'},
+ }
+
+ def __init__(
+ self,
+ *,
+ tags: Optional[Dict[str, str]] = None,
+ sku: Optional["Sku"] = None,
+ **kwargs
+ ):
+ super(HealthBotUpdateParameters, self).__init__(**kwargs)
+ self.tags = tags
+ self.sku = sku
+
+
+class OperationDetail(msrest.serialization.Model):
+ """Operation detail payload.
+
+ :param name: Name of the operation.
+ :type name: str
+ :param is_data_action: Indicates whether the operation is a data action.
+ :type is_data_action: bool
+ :param display: Display of the operation.
+ :type display: ~azure.mgmt.healthbot.models.OperationDisplay
+ :param origin: Origin of the operation.
+ :type origin: str
+ :param properties: Additional properties.
+ :type properties: object
+ """
+
+ _attribute_map = {
+ 'name': {'key': 'name', 'type': 'str'},
+ 'is_data_action': {'key': 'isDataAction', 'type': 'bool'},
+ 'display': {'key': 'display', 'type': 'OperationDisplay'},
+ 'origin': {'key': 'origin', 'type': 'str'},
+ 'properties': {'key': 'properties', 'type': 'object'},
+ }
+
+ def __init__(
+ self,
+ *,
+ name: Optional[str] = None,
+ is_data_action: Optional[bool] = None,
+ display: Optional["OperationDisplay"] = None,
+ origin: Optional[str] = None,
+ properties: Optional[object] = None,
+ **kwargs
+ ):
+ super(OperationDetail, self).__init__(**kwargs)
+ self.name = name
+ self.is_data_action = is_data_action
+ self.display = display
+ self.origin = origin
+ self.properties = properties
+
+
+class OperationDisplay(msrest.serialization.Model):
+ """Operation display payload.
+
+ :param provider: Resource provider of the operation.
+ :type provider: str
+ :param resource: Resource of the operation.
+ :type resource: str
+ :param operation: Localized friendly name for the operation.
+ :type operation: str
+ :param description: Localized friendly description for the operation.
+ :type description: str
+ """
+
+ _attribute_map = {
+ 'provider': {'key': 'provider', 'type': 'str'},
+ 'resource': {'key': 'resource', 'type': 'str'},
+ 'operation': {'key': 'operation', 'type': 'str'},
+ 'description': {'key': 'description', 'type': 'str'},
+ }
+
+ def __init__(
+ self,
+ *,
+ provider: Optional[str] = None,
+ resource: Optional[str] = None,
+ operation: Optional[str] = None,
+ description: Optional[str] = None,
+ **kwargs
+ ):
+ super(OperationDisplay, self).__init__(**kwargs)
+ self.provider = provider
+ self.resource = resource
+ self.operation = operation
+ self.description = description
+
+
+class Sku(msrest.serialization.Model):
+ """The resource model definition representing SKU.
+
+ All required parameters must be populated in order to send to Azure.
+
+ :param name: Required. The name of the HealthBot SKU. Possible values include: "F0", "S1",
+ "C0".
+ :type name: str or ~azure.mgmt.healthbot.models.SkuName
+ """
+
+ _validation = {
+ 'name': {'required': True},
+ }
+
+ _attribute_map = {
+ 'name': {'key': 'name', 'type': 'str'},
+ }
+
+ def __init__(
+ self,
+ *,
+ name: Union[str, "SkuName"],
+ **kwargs
+ ):
+ super(Sku, self).__init__(**kwargs)
+ self.name = name
+
+
+class SystemData(msrest.serialization.Model):
+ """Read only system data.
+
+ :param created_by: The identity that created the resource.
+ :type created_by: str
+ :param created_by_type: The type of identity that created the resource. Possible values
+ include: "User", "Application", "ManagedIdentity", "Key".
+ :type created_by_type: str or ~azure.mgmt.healthbot.models.IdentityType
+ :param created_at: The timestamp of resource creation (UTC).
+ :type created_at: ~datetime.datetime
+ :param last_modified_by: The identity that last modified the resource.
+ :type last_modified_by: str
+ :param last_modified_by_type: The type of identity that last modified the resource. Possible
+ values include: "User", "Application", "ManagedIdentity", "Key".
+ :type last_modified_by_type: str or ~azure.mgmt.healthbot.models.IdentityType
+ :param last_modified_at: The timestamp of resource last modification (UTC).
+ :type last_modified_at: ~datetime.datetime
+ """
+
+ _attribute_map = {
+ 'created_by': {'key': 'createdBy', 'type': 'str'},
+ 'created_by_type': {'key': 'createdByType', 'type': 'str'},
+ 'created_at': {'key': 'createdAt', 'type': 'iso-8601'},
+ 'last_modified_by': {'key': 'lastModifiedBy', 'type': 'str'},
+ 'last_modified_by_type': {'key': 'lastModifiedByType', 'type': 'str'},
+ 'last_modified_at': {'key': 'lastModifiedAt', 'type': 'iso-8601'},
+ }
+
+ def __init__(
+ self,
+ *,
+ created_by: Optional[str] = None,
+ created_by_type: Optional[Union[str, "IdentityType"]] = None,
+ created_at: Optional[datetime.datetime] = None,
+ last_modified_by: Optional[str] = None,
+ last_modified_by_type: Optional[Union[str, "IdentityType"]] = None,
+ last_modified_at: Optional[datetime.datetime] = None,
+ **kwargs
+ ):
+ super(SystemData, self).__init__(**kwargs)
+ self.created_by = created_by
+ self.created_by_type = created_by_type
+ self.created_at = created_at
+ self.last_modified_by = last_modified_by
+ self.last_modified_by_type = last_modified_by_type
+ self.last_modified_at = last_modified_at
+
+
+class ValidationResult(msrest.serialization.Model):
+ """The response returned from validation process.
+
+ :param status: The status code of the response validation.
+ :type status: str
+ """
+
+ _attribute_map = {
+ 'status': {'key': 'status', 'type': 'str'},
+ }
+
+ def __init__(
+ self,
+ *,
+ status: Optional[str] = None,
+ **kwargs
+ ):
+ super(ValidationResult, self).__init__(**kwargs)
+ self.status = status
diff --git a/src/healthbot/azext_healthbot/vendored_sdks/healthbot/operations/__init__.py b/src/healthbot/azext_healthbot/vendored_sdks/healthbot/operations/__init__.py
new file mode 100644
index 00000000000..214402239a8
--- /dev/null
+++ b/src/healthbot/azext_healthbot/vendored_sdks/healthbot/operations/__init__.py
@@ -0,0 +1,15 @@
+# coding=utf-8
+# --------------------------------------------------------------------------
+# Copyright (c) Microsoft Corporation. All rights reserved.
+# Licensed under the MIT License. See License.txt in the project root for license information.
+# Code generated by Microsoft (R) AutoRest Code Generator.
+# Changes may cause incorrect behavior and will be lost if the code is regenerated.
+# --------------------------------------------------------------------------
+
+from ._bots_operations import BotsOperations
+from ._operations import Operations
+
+__all__ = [
+ 'BotsOperations',
+ 'Operations',
+]
diff --git a/src/healthbot/azext_healthbot/vendored_sdks/healthbot/operations/_bots_operations.py b/src/healthbot/azext_healthbot/vendored_sdks/healthbot/operations/_bots_operations.py
new file mode 100644
index 00000000000..59741a657d6
--- /dev/null
+++ b/src/healthbot/azext_healthbot/vendored_sdks/healthbot/operations/_bots_operations.py
@@ -0,0 +1,562 @@
+# coding=utf-8
+# --------------------------------------------------------------------------
+# Copyright (c) Microsoft Corporation. All rights reserved.
+# Licensed under the MIT License. See License.txt in the project root for license information.
+# Code generated by Microsoft (R) AutoRest Code Generator.
+# Changes may cause incorrect behavior and will be lost if the code is regenerated.
+# --------------------------------------------------------------------------
+from typing import TYPE_CHECKING
+import warnings
+
+from azure.core.exceptions import ClientAuthenticationError, HttpResponseError, ResourceExistsError, ResourceNotFoundError, map_error
+from azure.core.paging import ItemPaged
+from azure.core.pipeline import PipelineResponse
+from azure.core.pipeline.transport import HttpRequest, HttpResponse
+from azure.core.polling import LROPoller, NoPolling, PollingMethod
+from azure.mgmt.core.exceptions import ARMErrorFormat
+from azure.mgmt.core.polling.arm_polling import ARMPolling
+
+from .. import models
+
+if TYPE_CHECKING:
+ # pylint: disable=unused-import,ungrouped-imports
+ from typing import Any, Callable, Dict, Generic, Iterable, Optional, TypeVar, Union
+
+ T = TypeVar('T')
+ ClsType = Optional[Callable[[PipelineResponse[HttpRequest, HttpResponse], T, Dict[str, Any]], Any]]
+
+class BotsOperations(object):
+ """BotsOperations operations.
+
+ You should not instantiate this class directly. Instead, you should create a Client instance that
+ instantiates it for you and attaches it as an attribute.
+
+ :ivar models: Alias to model classes used in this operation group.
+ :type models: ~azure.mgmt.healthbot.models
+ :param client: Client for service requests.
+ :param config: Configuration of service client.
+ :param serializer: An object model serializer.
+ :param deserializer: An object model deserializer.
+ """
+
+ models = models
+
+ def __init__(self, client, config, serializer, deserializer):
+ self._client = client
+ self._serialize = serializer
+ self._deserialize = deserializer
+ self._config = config
+
+ def _create_initial(
+ self,
+ resource_group_name, # type: str
+ bot_name, # type: str
+ parameters, # type: "models.HealthBot"
+ **kwargs # type: Any
+ ):
+ # type: (...) -> "models.HealthBot"
+ cls = kwargs.pop('cls', None) # type: ClsType["models.HealthBot"]
+ error_map = {
+ 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError
+ }
+ error_map.update(kwargs.pop('error_map', {}))
+ api_version = "2020-12-08"
+ content_type = kwargs.pop("content_type", "application/json")
+ accept = "application/json"
+
+ # Construct URL
+ url = self._create_initial.metadata['url'] # type: ignore
+ path_format_arguments = {
+ 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'),
+ 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=64, min_length=2, pattern=r'^[a-zA-Z0-9][a-zA-Z0-9_.-]*$'),
+ 'botName': self._serialize.url("bot_name", bot_name, 'str', max_length=64, min_length=2, pattern=r'^[a-zA-Z0-9][a-zA-Z0-9_.-]*$'),
+ }
+ url = self._client.format_url(url, **path_format_arguments)
+
+ # Construct parameters
+ query_parameters = {} # type: Dict[str, Any]
+ query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str')
+
+ # Construct headers
+ header_parameters = {} # type: Dict[str, Any]
+ header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str')
+ header_parameters['Accept'] = self._serialize.header("accept", accept, 'str')
+
+ body_content_kwargs = {} # type: Dict[str, Any]
+ body_content = self._serialize.body(parameters, 'HealthBot')
+ body_content_kwargs['content'] = body_content
+ request = self._client.put(url, query_parameters, header_parameters, **body_content_kwargs)
+ pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs)
+ response = pipeline_response.http_response
+
+ if response.status_code not in [200, 201]:
+ map_error(status_code=response.status_code, response=response, error_map=error_map)
+ error = self._deserialize(models.Error, response)
+ raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat)
+
+ if response.status_code == 200:
+ deserialized = self._deserialize('HealthBot', pipeline_response)
+
+ if response.status_code == 201:
+ deserialized = self._deserialize('HealthBot', pipeline_response)
+
+ if cls:
+ return cls(pipeline_response, deserialized, {})
+
+ return deserialized
+ _create_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.HealthBot/healthBots/{botName}'} # type: ignore
+
+ def begin_create(
+ self,
+ resource_group_name, # type: str
+ bot_name, # type: str
+ parameters, # type: "models.HealthBot"
+ **kwargs # type: Any
+ ):
+ # type: (...) -> LROPoller["models.HealthBot"]
+ """Create a new HealthBot.
+
+ :param resource_group_name: The name of the Bot resource group in the user subscription.
+ :type resource_group_name: str
+ :param bot_name: The name of the Bot resource.
+ :type bot_name: str
+ :param parameters: The parameters to provide for the created bot.
+ :type parameters: ~azure.mgmt.healthbot.models.HealthBot
+ :keyword callable cls: A custom type or function that will be passed the direct response
+ :keyword str continuation_token: A continuation token to restart a poller from a saved state.
+ :keyword polling: True for ARMPolling, False for no polling, or a
+ polling object for personal polling strategy
+ :paramtype polling: bool or ~azure.core.polling.PollingMethod
+ :keyword int polling_interval: Default waiting time between two polls for LRO operations if no Retry-After header is present.
+ :return: An instance of LROPoller that returns either HealthBot or the result of cls(response)
+ :rtype: ~azure.core.polling.LROPoller[~azure.mgmt.healthbot.models.HealthBot]
+ :raises ~azure.core.exceptions.HttpResponseError:
+ """
+ polling = kwargs.pop('polling', True) # type: Union[bool, PollingMethod]
+ cls = kwargs.pop('cls', None) # type: ClsType["models.HealthBot"]
+ lro_delay = kwargs.pop(
+ 'polling_interval',
+ self._config.polling_interval
+ )
+ cont_token = kwargs.pop('continuation_token', None) # type: Optional[str]
+ if cont_token is None:
+ raw_result = self._create_initial(
+ resource_group_name=resource_group_name,
+ bot_name=bot_name,
+ parameters=parameters,
+ cls=lambda x,y,z: x,
+ **kwargs
+ )
+
+ kwargs.pop('error_map', None)
+ kwargs.pop('content_type', None)
+
+ def get_long_running_output(pipeline_response):
+ deserialized = self._deserialize('HealthBot', pipeline_response)
+
+ if cls:
+ return cls(pipeline_response, deserialized, {})
+ return deserialized
+
+ path_format_arguments = {
+ 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'),
+ 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=64, min_length=2, pattern=r'^[a-zA-Z0-9][a-zA-Z0-9_.-]*$'),
+ 'botName': self._serialize.url("bot_name", bot_name, 'str', max_length=64, min_length=2, pattern=r'^[a-zA-Z0-9][a-zA-Z0-9_.-]*$'),
+ }
+
+ if polling is True: polling_method = ARMPolling(lro_delay, lro_options={'final-state-via': 'azure-async-operation'}, path_format_arguments=path_format_arguments, **kwargs)
+ elif polling is False: polling_method = NoPolling()
+ else: polling_method = polling
+ if cont_token:
+ return LROPoller.from_continuation_token(
+ polling_method=polling_method,
+ continuation_token=cont_token,
+ client=self._client,
+ deserialization_callback=get_long_running_output
+ )
+ else:
+ return LROPoller(self._client, raw_result, get_long_running_output, polling_method)
+ begin_create.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.HealthBot/healthBots/{botName}'} # type: ignore
+
+ def get(
+ self,
+ resource_group_name, # type: str
+ bot_name, # type: str
+ **kwargs # type: Any
+ ):
+ # type: (...) -> "models.HealthBot"
+ """Get a HealthBot.
+
+ :param resource_group_name: The name of the Bot resource group in the user subscription.
+ :type resource_group_name: str
+ :param bot_name: The name of the Bot resource.
+ :type bot_name: str
+ :keyword callable cls: A custom type or function that will be passed the direct response
+ :return: HealthBot, or the result of cls(response)
+ :rtype: ~azure.mgmt.healthbot.models.HealthBot
+ :raises: ~azure.core.exceptions.HttpResponseError
+ """
+ cls = kwargs.pop('cls', None) # type: ClsType["models.HealthBot"]
+ error_map = {
+ 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError
+ }
+ error_map.update(kwargs.pop('error_map', {}))
+ api_version = "2020-12-08"
+ accept = "application/json"
+
+ # Construct URL
+ url = self.get.metadata['url'] # type: ignore
+ path_format_arguments = {
+ 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'),
+ 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=64, min_length=2, pattern=r'^[a-zA-Z0-9][a-zA-Z0-9_.-]*$'),
+ 'botName': self._serialize.url("bot_name", bot_name, 'str', max_length=64, min_length=2, pattern=r'^[a-zA-Z0-9][a-zA-Z0-9_.-]*$'),
+ }
+ url = self._client.format_url(url, **path_format_arguments)
+
+ # Construct parameters
+ query_parameters = {} # type: Dict[str, Any]
+ query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str')
+
+ # Construct headers
+ header_parameters = {} # type: Dict[str, Any]
+ header_parameters['Accept'] = self._serialize.header("accept", accept, 'str')
+
+ request = self._client.get(url, query_parameters, header_parameters)
+ pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs)
+ response = pipeline_response.http_response
+
+ if response.status_code not in [200]:
+ map_error(status_code=response.status_code, response=response, error_map=error_map)
+ error = self._deserialize(models.Error, response)
+ raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat)
+
+ deserialized = self._deserialize('HealthBot', pipeline_response)
+
+ if cls:
+ return cls(pipeline_response, deserialized, {})
+
+ return deserialized
+ get.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.HealthBot/healthBots/{botName}'} # type: ignore
+
+ def update(
+ self,
+ resource_group_name, # type: str
+ bot_name, # type: str
+ parameters, # type: "models.HealthBotUpdateParameters"
+ **kwargs # type: Any
+ ):
+ # type: (...) -> "models.HealthBot"
+ """Patch a HealthBot.
+
+ :param resource_group_name: The name of the Bot resource group in the user subscription.
+ :type resource_group_name: str
+ :param bot_name: The name of the Bot resource.
+ :type bot_name: str
+ :param parameters: The parameters to provide for the required bot.
+ :type parameters: ~azure.mgmt.healthbot.models.HealthBotUpdateParameters
+ :keyword callable cls: A custom type or function that will be passed the direct response
+ :return: HealthBot, or the result of cls(response)
+ :rtype: ~azure.mgmt.healthbot.models.HealthBot
+ :raises: ~azure.core.exceptions.HttpResponseError
+ """
+ cls = kwargs.pop('cls', None) # type: ClsType["models.HealthBot"]
+ error_map = {
+ 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError
+ }
+ error_map.update(kwargs.pop('error_map', {}))
+ api_version = "2020-12-08"
+ content_type = kwargs.pop("content_type", "application/json")
+ accept = "application/json"
+
+ # Construct URL
+ url = self.update.metadata['url'] # type: ignore
+ path_format_arguments = {
+ 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'),
+ 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=64, min_length=2, pattern=r'^[a-zA-Z0-9][a-zA-Z0-9_.-]*$'),
+ 'botName': self._serialize.url("bot_name", bot_name, 'str', max_length=64, min_length=2, pattern=r'^[a-zA-Z0-9][a-zA-Z0-9_.-]*$'),
+ }
+ url = self._client.format_url(url, **path_format_arguments)
+
+ # Construct parameters
+ query_parameters = {} # type: Dict[str, Any]
+ query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str')
+
+ # Construct headers
+ header_parameters = {} # type: Dict[str, Any]
+ header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str')
+ header_parameters['Accept'] = self._serialize.header("accept", accept, 'str')
+
+ body_content_kwargs = {} # type: Dict[str, Any]
+ body_content = self._serialize.body(parameters, 'HealthBotUpdateParameters')
+ body_content_kwargs['content'] = body_content
+ request = self._client.patch(url, query_parameters, header_parameters, **body_content_kwargs)
+ pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs)
+ response = pipeline_response.http_response
+
+ if response.status_code not in [200, 201]:
+ map_error(status_code=response.status_code, response=response, error_map=error_map)
+ error = self._deserialize(models.Error, response)
+ raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat)
+
+ if response.status_code == 200:
+ deserialized = self._deserialize('HealthBot', pipeline_response)
+
+ if response.status_code == 201:
+ deserialized = self._deserialize('HealthBot', pipeline_response)
+
+ if cls:
+ return cls(pipeline_response, deserialized, {})
+
+ return deserialized
+ update.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.HealthBot/healthBots/{botName}'} # type: ignore
+
+ def _delete_initial(
+ self,
+ resource_group_name, # type: str
+ bot_name, # type: str
+ **kwargs # type: Any
+ ):
+ # type: (...) -> None
+ cls = kwargs.pop('cls', None) # type: ClsType[None]
+ error_map = {
+ 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError
+ }
+ error_map.update(kwargs.pop('error_map', {}))
+ api_version = "2020-12-08"
+ accept = "application/json"
+
+ # Construct URL
+ url = self._delete_initial.metadata['url'] # type: ignore
+ path_format_arguments = {
+ 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'),
+ 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=64, min_length=2, pattern=r'^[a-zA-Z0-9][a-zA-Z0-9_.-]*$'),
+ 'botName': self._serialize.url("bot_name", bot_name, 'str', max_length=64, min_length=2, pattern=r'^[a-zA-Z0-9][a-zA-Z0-9_.-]*$'),
+ }
+ url = self._client.format_url(url, **path_format_arguments)
+
+ # Construct parameters
+ query_parameters = {} # type: Dict[str, Any]
+ query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str')
+
+ # Construct headers
+ header_parameters = {} # type: Dict[str, Any]
+ header_parameters['Accept'] = self._serialize.header("accept", accept, 'str')
+
+ request = self._client.delete(url, query_parameters, header_parameters)
+ pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs)
+ response = pipeline_response.http_response
+
+ if response.status_code not in [200, 202, 204]:
+ map_error(status_code=response.status_code, response=response, error_map=error_map)
+ error = self._deserialize(models.Error, response)
+ raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat)
+
+ if cls:
+ return cls(pipeline_response, None, {})
+
+ _delete_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.HealthBot/healthBots/{botName}'} # type: ignore
+
+ def begin_delete(
+ self,
+ resource_group_name, # type: str
+ bot_name, # type: str
+ **kwargs # type: Any
+ ):
+ # type: (...) -> LROPoller[None]
+ """Delete a HealthBot.
+
+ :param resource_group_name: The name of the Bot resource group in the user subscription.
+ :type resource_group_name: str
+ :param bot_name: The name of the Bot resource.
+ :type bot_name: str
+ :keyword callable cls: A custom type or function that will be passed the direct response
+ :keyword str continuation_token: A continuation token to restart a poller from a saved state.
+ :keyword polling: True for ARMPolling, False for no polling, or a
+ polling object for personal polling strategy
+ :paramtype polling: bool or ~azure.core.polling.PollingMethod
+ :keyword int polling_interval: Default waiting time between two polls for LRO operations if no Retry-After header is present.
+ :return: An instance of LROPoller that returns either None or the result of cls(response)
+ :rtype: ~azure.core.polling.LROPoller[None]
+ :raises ~azure.core.exceptions.HttpResponseError:
+ """
+ polling = kwargs.pop('polling', True) # type: Union[bool, PollingMethod]
+ cls = kwargs.pop('cls', None) # type: ClsType[None]
+ lro_delay = kwargs.pop(
+ 'polling_interval',
+ self._config.polling_interval
+ )
+ cont_token = kwargs.pop('continuation_token', None) # type: Optional[str]
+ if cont_token is None:
+ raw_result = self._delete_initial(
+ resource_group_name=resource_group_name,
+ bot_name=bot_name,
+ cls=lambda x,y,z: x,
+ **kwargs
+ )
+
+ kwargs.pop('error_map', None)
+ kwargs.pop('content_type', None)
+
+ def get_long_running_output(pipeline_response):
+ if cls:
+ return cls(pipeline_response, None, {})
+
+ path_format_arguments = {
+ 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'),
+ 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=64, min_length=2, pattern=r'^[a-zA-Z0-9][a-zA-Z0-9_.-]*$'),
+ 'botName': self._serialize.url("bot_name", bot_name, 'str', max_length=64, min_length=2, pattern=r'^[a-zA-Z0-9][a-zA-Z0-9_.-]*$'),
+ }
+
+ if polling is True: polling_method = ARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs)
+ elif polling is False: polling_method = NoPolling()
+ else: polling_method = polling
+ if cont_token:
+ return LROPoller.from_continuation_token(
+ polling_method=polling_method,
+ continuation_token=cont_token,
+ client=self._client,
+ deserialization_callback=get_long_running_output
+ )
+ else:
+ return LROPoller(self._client, raw_result, get_long_running_output, polling_method)
+ begin_delete.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.HealthBot/healthBots/{botName}'} # type: ignore
+
+ def list_by_resource_group(
+ self,
+ resource_group_name, # type: str
+ **kwargs # type: Any
+ ):
+ # type: (...) -> Iterable["models.BotResponseList"]
+ """Returns all the resources of a particular type belonging to a resource group.
+
+ :param resource_group_name: The name of the Bot resource group in the user subscription.
+ :type resource_group_name: str
+ :keyword callable cls: A custom type or function that will be passed the direct response
+ :return: An iterator like instance of either BotResponseList or the result of cls(response)
+ :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.healthbot.models.BotResponseList]
+ :raises: ~azure.core.exceptions.HttpResponseError
+ """
+ cls = kwargs.pop('cls', None) # type: ClsType["models.BotResponseList"]
+ error_map = {
+ 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError
+ }
+ error_map.update(kwargs.pop('error_map', {}))
+ api_version = "2020-12-08"
+ accept = "application/json"
+
+ def prepare_request(next_link=None):
+ # Construct headers
+ header_parameters = {} # type: Dict[str, Any]
+ header_parameters['Accept'] = self._serialize.header("accept", accept, 'str')
+
+ if not next_link:
+ # Construct URL
+ url = self.list_by_resource_group.metadata['url'] # type: ignore
+ path_format_arguments = {
+ 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=64, min_length=2, pattern=r'^[a-zA-Z0-9][a-zA-Z0-9_.-]*$'),
+ 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'),
+ }
+ url = self._client.format_url(url, **path_format_arguments)
+ # Construct parameters
+ query_parameters = {} # type: Dict[str, Any]
+ query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str')
+
+ request = self._client.get(url, query_parameters, header_parameters)
+ else:
+ url = next_link
+ query_parameters = {} # type: Dict[str, Any]
+ request = self._client.get(url, query_parameters, header_parameters)
+ return request
+
+ def extract_data(pipeline_response):
+ deserialized = self._deserialize('BotResponseList', pipeline_response)
+ list_of_elem = deserialized.value
+ if cls:
+ list_of_elem = cls(list_of_elem)
+ return deserialized.next_link or None, iter(list_of_elem)
+
+ def get_next(next_link=None):
+ request = prepare_request(next_link)
+
+ pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs)
+ response = pipeline_response.http_response
+
+ if response.status_code not in [200]:
+ error = self._deserialize(models.Error, response)
+ map_error(status_code=response.status_code, response=response, error_map=error_map)
+ raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat)
+
+ return pipeline_response
+
+ return ItemPaged(
+ get_next, extract_data
+ )
+ list_by_resource_group.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.HealthBot/healthBots'} # type: ignore
+
+ def list(
+ self,
+ **kwargs # type: Any
+ ):
+ # type: (...) -> Iterable["models.BotResponseList"]
+ """Returns all the resources of a particular type belonging to a subscription.
+
+ :keyword callable cls: A custom type or function that will be passed the direct response
+ :return: An iterator like instance of either BotResponseList or the result of cls(response)
+ :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.healthbot.models.BotResponseList]
+ :raises: ~azure.core.exceptions.HttpResponseError
+ """
+ cls = kwargs.pop('cls', None) # type: ClsType["models.BotResponseList"]
+ error_map = {
+ 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError
+ }
+ error_map.update(kwargs.pop('error_map', {}))
+ api_version = "2020-12-08"
+ accept = "application/json"
+
+ def prepare_request(next_link=None):
+ # Construct headers
+ header_parameters = {} # type: Dict[str, Any]
+ header_parameters['Accept'] = self._serialize.header("accept", accept, 'str')
+
+ if not next_link:
+ # Construct URL
+ url = self.list.metadata['url'] # type: ignore
+ path_format_arguments = {
+ 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'),
+ }
+ url = self._client.format_url(url, **path_format_arguments)
+ # Construct parameters
+ query_parameters = {} # type: Dict[str, Any]
+ query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str')
+
+ request = self._client.get(url, query_parameters, header_parameters)
+ else:
+ url = next_link
+ query_parameters = {} # type: Dict[str, Any]
+ request = self._client.get(url, query_parameters, header_parameters)
+ return request
+
+ def extract_data(pipeline_response):
+ deserialized = self._deserialize('BotResponseList', pipeline_response)
+ list_of_elem = deserialized.value
+ if cls:
+ list_of_elem = cls(list_of_elem)
+ return deserialized.next_link or None, iter(list_of_elem)
+
+ def get_next(next_link=None):
+ request = prepare_request(next_link)
+
+ pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs)
+ response = pipeline_response.http_response
+
+ if response.status_code not in [200]:
+ error = self._deserialize(models.Error, response)
+ map_error(status_code=response.status_code, response=response, error_map=error_map)
+ raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat)
+
+ return pipeline_response
+
+ return ItemPaged(
+ get_next, extract_data
+ )
+ list.metadata = {'url': '/subscriptions/{subscriptionId}/providers/Microsoft.HealthBot/healthBots'} # type: ignore
diff --git a/src/healthbot/azext_healthbot/vendored_sdks/healthbot/operations/_operations.py b/src/healthbot/azext_healthbot/vendored_sdks/healthbot/operations/_operations.py
new file mode 100644
index 00000000000..30dd159582b
--- /dev/null
+++ b/src/healthbot/azext_healthbot/vendored_sdks/healthbot/operations/_operations.py
@@ -0,0 +1,110 @@
+# coding=utf-8
+# --------------------------------------------------------------------------
+# Copyright (c) Microsoft Corporation. All rights reserved.
+# Licensed under the MIT License. See License.txt in the project root for license information.
+# Code generated by Microsoft (R) AutoRest Code Generator.
+# Changes may cause incorrect behavior and will be lost if the code is regenerated.
+# --------------------------------------------------------------------------
+from typing import TYPE_CHECKING
+import warnings
+
+from azure.core.exceptions import ClientAuthenticationError, HttpResponseError, ResourceExistsError, ResourceNotFoundError, map_error
+from azure.core.paging import ItemPaged
+from azure.core.pipeline import PipelineResponse
+from azure.core.pipeline.transport import HttpRequest, HttpResponse
+from azure.mgmt.core.exceptions import ARMErrorFormat
+
+from .. import models
+
+if TYPE_CHECKING:
+ # pylint: disable=unused-import,ungrouped-imports
+ from typing import Any, Callable, Dict, Generic, Iterable, Optional, TypeVar
+
+ T = TypeVar('T')
+ ClsType = Optional[Callable[[PipelineResponse[HttpRequest, HttpResponse], T, Dict[str, Any]], Any]]
+
+class Operations(object):
+ """Operations operations.
+
+ You should not instantiate this class directly. Instead, you should create a Client instance that
+ instantiates it for you and attaches it as an attribute.
+
+ :ivar models: Alias to model classes used in this operation group.
+ :type models: ~azure.mgmt.healthbot.models
+ :param client: Client for service requests.
+ :param config: Configuration of service client.
+ :param serializer: An object model serializer.
+ :param deserializer: An object model deserializer.
+ """
+
+ models = models
+
+ def __init__(self, client, config, serializer, deserializer):
+ self._client = client
+ self._serialize = serializer
+ self._deserialize = deserializer
+ self._config = config
+
+ def list(
+ self,
+ **kwargs # type: Any
+ ):
+ # type: (...) -> Iterable["models.AvailableOperations"]
+ """Lists all the available HealthBot operations.
+
+ :keyword callable cls: A custom type or function that will be passed the direct response
+ :return: An iterator like instance of either AvailableOperations or the result of cls(response)
+ :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.healthbot.models.AvailableOperations]
+ :raises: ~azure.core.exceptions.HttpResponseError
+ """
+ cls = kwargs.pop('cls', None) # type: ClsType["models.AvailableOperations"]
+ error_map = {
+ 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError
+ }
+ error_map.update(kwargs.pop('error_map', {}))
+ api_version = "2020-12-08"
+ accept = "application/json"
+
+ def prepare_request(next_link=None):
+ # Construct headers
+ header_parameters = {} # type: Dict[str, Any]
+ header_parameters['Accept'] = self._serialize.header("accept", accept, 'str')
+
+ if not next_link:
+ # Construct URL
+ url = self.list.metadata['url'] # type: ignore
+ # Construct parameters
+ query_parameters = {} # type: Dict[str, Any]
+ query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str')
+
+ request = self._client.get(url, query_parameters, header_parameters)
+ else:
+ url = next_link
+ query_parameters = {} # type: Dict[str, Any]
+ request = self._client.get(url, query_parameters, header_parameters)
+ return request
+
+ def extract_data(pipeline_response):
+ deserialized = self._deserialize('AvailableOperations', pipeline_response)
+ list_of_elem = deserialized.value
+ if cls:
+ list_of_elem = cls(list_of_elem)
+ return deserialized.next_link or None, iter(list_of_elem)
+
+ def get_next(next_link=None):
+ request = prepare_request(next_link)
+
+ pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs)
+ response = pipeline_response.http_response
+
+ if response.status_code not in [200]:
+ error = self._deserialize(models.Error, response)
+ map_error(status_code=response.status_code, response=response, error_map=error_map)
+ raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat)
+
+ return pipeline_response
+
+ return ItemPaged(
+ get_next, extract_data
+ )
+ list.metadata = {'url': '/providers/Microsoft.HealthBot/operations'} # type: ignore
diff --git a/src/healthbot/azext_healthbot/vendored_sdks/healthbot/py.typed b/src/healthbot/azext_healthbot/vendored_sdks/healthbot/py.typed
new file mode 100644
index 00000000000..e5aff4f83af
--- /dev/null
+++ b/src/healthbot/azext_healthbot/vendored_sdks/healthbot/py.typed
@@ -0,0 +1 @@
+# Marker file for PEP 561.
\ No newline at end of file
diff --git a/src/healthbot/report.md b/src/healthbot/report.md
new file mode 100644
index 00000000000..9612fb1f423
--- /dev/null
+++ b/src/healthbot/report.md
@@ -0,0 +1,100 @@
+# Azure CLI Module Creation Report
+
+## EXTENSION
+|CLI Extension|Command Groups|
+|---------|------------|
+|az healthbot|[groups](#CommandGroups)
+
+## GROUPS
+### Command groups in `az healthbot` extension
+|CLI Command Group|Group Swagger name|Commands|
+|---------|------------|--------|
+|az healthbot|Bots|[commands](#CommandsInBots)|
+
+## COMMANDS
+### Commands in `az healthbot` group
+|CLI Command|Operation Swagger name|Parameters|Examples|
+|---------|------------|--------|-----------|
+|[az healthbot list](#BotsListByResourceGroup)|ListByResourceGroup|[Parameters](#ParametersBotsListByResourceGroup)|[Example](#ExamplesBotsListByResourceGroup)|
+|[az healthbot list](#BotsList)|List|[Parameters](#ParametersBotsList)|[Example](#ExamplesBotsList)|
+|[az healthbot show](#BotsGet)|Get|[Parameters](#ParametersBotsGet)|[Example](#ExamplesBotsGet)|
+|[az healthbot create](#BotsCreate)|Create|[Parameters](#ParametersBotsCreate)|[Example](#ExamplesBotsCreate)|
+|[az healthbot update](#BotsUpdate)|Update|[Parameters](#ParametersBotsUpdate)|[Example](#ExamplesBotsUpdate)|
+|[az healthbot delete](#BotsDelete)|Delete|[Parameters](#ParametersBotsDelete)|[Example](#ExamplesBotsDelete)|
+
+
+## COMMAND DETAILS
+
+### group `az healthbot`
+#### Command `az healthbot list`
+
+##### Example
+```
+az healthbot list --resource-group "OneResourceGroupName"
+```
+##### Parameters
+|Option|Type|Description|Path (SDK)|Swagger name|
+|------|----|-----------|----------|------------|
+|**--resource-group-name**|string|The name of the Bot resource group in the user subscription.|resource_group_name|resourceGroupName|
+
+#### Command `az healthbot list`
+
+##### Example
+```
+az healthbot list
+```
+##### Parameters
+|Option|Type|Description|Path (SDK)|Swagger name|
+|------|----|-----------|----------|------------|
+#### Command `az healthbot show`
+
+##### Example
+```
+az healthbot show --name "samplebotname" --resource-group "healthbotClient"
+```
+##### Parameters
+|Option|Type|Description|Path (SDK)|Swagger name|
+|------|----|-----------|----------|------------|
+|**--resource-group-name**|string|The name of the Bot resource group in the user subscription.|resource_group_name|resourceGroupName|
+|**--bot-name**|string|The name of the Bot resource.|bot_name|botName|
+
+#### Command `az healthbot create`
+
+##### Example
+```
+az healthbot create --name "samplebotname" --location "East US" --sku "F0" --resource-group "healthbotClient"
+```
+##### Parameters
+|Option|Type|Description|Path (SDK)|Swagger name|
+|------|----|-----------|----------|------------|
+|**--resource-group-name**|string|The name of the Bot resource group in the user subscription.|resource_group_name|resourceGroupName|
+|**--bot-name**|string|The name of the Bot resource.|bot_name|botName|
+|**--location**|string|The geo-location where the resource lives|location|location|
+|**--sku**|sealed-choice|The name of the HealthBot SKU|
+|**--tags**|dictionary|Resource tags.|tags|tags|
+
+#### Command `az healthbot update`
+
+##### Example
+```
+az healthbot update --name "samplebotname" --sku "F0" --resource-group "healthbotClient"
+```
+##### Parameters
+|Option|Type|Description|Path (SDK)|Swagger name|
+|------|----|-----------|----------|------------|
+|**--resource-group-name**|string|The name of the Bot resource group in the user subscription.|resource_group_name|resourceGroupName|
+|**--bot-name**|string|The name of the Bot resource.|bot_name|botName|
+|**--tags**|dictionary|Tags for a HealthBot.|tags|tags|
+|**--sku**|sealed-choice|The name of the HealthBot SKU|
+
+#### Command `az healthbot delete`
+
+##### Example
+```
+az healthbot delete --name "samplebotname" --resource-group "healthbotClient"
+```
+##### Parameters
+|Option|Type|Description|Path (SDK)|Swagger name|
+|------|----|-----------|----------|------------|
+|**--resource-group-name**|string|The name of the Bot resource group in the user subscription.|resource_group_name|resourceGroupName|
+|**--bot-name**|string|The name of the Bot resource.|bot_name|botName|
diff --git a/src/healthbot/setup.cfg b/src/healthbot/setup.cfg
new file mode 100644
index 00000000000..2fdd96e5d39
--- /dev/null
+++ b/src/healthbot/setup.cfg
@@ -0,0 +1 @@
+#setup.cfg
\ No newline at end of file
diff --git a/src/healthbot/setup.py b/src/healthbot/setup.py
new file mode 100644
index 00000000000..9e41c201422
--- /dev/null
+++ b/src/healthbot/setup.py
@@ -0,0 +1,58 @@
+#!/usr/bin/env python
+
+# --------------------------------------------------------------------------------------------
+# Copyright (c) Microsoft Corporation. All rights reserved.
+# Licensed under the MIT License. See License.txt in the project root for license information.
+# --------------------------------------------------------------------------------------------
+
+
+from codecs import open
+from setuptools import setup, find_packages
+
+# HISTORY.rst entry.
+VERSION = '0.1.0'
+try:
+ from azext_healthbot.manual.version import VERSION
+except ImportError:
+ pass
+
+# The full list of classifiers is available at
+# https://pypi.python.org/pypi?%3Aaction=list_classifiers
+CLASSIFIERS = [
+ 'Development Status :: 4 - Beta',
+ 'Intended Audience :: Developers',
+ 'Intended Audience :: System Administrators',
+ 'Programming Language :: Python',
+ 'Programming Language :: Python :: 3',
+ 'Programming Language :: Python :: 3.6',
+ 'Programming Language :: Python :: 3.7',
+ 'Programming Language :: Python :: 3.8',
+ 'License :: OSI Approved :: MIT License',
+]
+
+DEPENDENCIES = []
+
+try:
+ from azext_healthbot.manual.dependency import DEPENDENCIES
+except ImportError:
+ pass
+
+with open('README.md', 'r', encoding='utf-8') as f:
+ README = f.read()
+with open('HISTORY.rst', 'r', encoding='utf-8') as f:
+ HISTORY = f.read()
+
+setup(
+ name='healthbot',
+ version=VERSION,
+ description='Microsoft Azure Command-Line Tools HealthbotClient Extension',
+ author='Microsoft Corporation',
+ author_email='azpycli@microsoft.com',
+ url='https://github.com/Azure/azure-cli-extensions/tree/master/src/healthbot',
+ long_description=README + '\n\n' + HISTORY,
+ license='MIT',
+ classifiers=CLASSIFIERS,
+ packages=find_packages(),
+ install_requires=DEPENDENCIES,
+ package_data={'azext_healthbot': ['azext_metadata.json']},
+)