Source code for azure.mgmt.resource.resources.v2017_05_10.models._models_py3

# 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 msrest.serialization import Model
from msrest.exceptions import HttpOperationError


[docs]class AliasPathType(Model): """The type of the paths for alias. . :param path: The path of an alias. :type path: str :param api_versions: The API versions. :type api_versions: list[str] """ _attribute_map = { 'path': {'key': 'path', 'type': 'str'}, 'api_versions': {'key': 'apiVersions', 'type': '[str]'}, } def __init__(self, *, path: str=None, api_versions=None, **kwargs) -> None: super(AliasPathType, self).__init__(**kwargs) self.path = path self.api_versions = api_versions
[docs]class AliasType(Model): """The alias type. . :param name: The alias name. :type name: str :param paths: The paths for an alias. :type paths: list[~azure.mgmt.resource.resources.v2017_05_10.models.AliasPathType] """ _attribute_map = { 'name': {'key': 'name', 'type': 'str'}, 'paths': {'key': 'paths', 'type': '[AliasPathType]'}, } def __init__(self, *, name: str=None, paths=None, **kwargs) -> None: super(AliasType, self).__init__(**kwargs) self.name = name self.paths = paths
[docs]class BasicDependency(Model): """Deployment dependency information. :param id: The ID of the dependency. :type id: str :param resource_type: The dependency resource type. :type resource_type: str :param resource_name: The dependency resource name. :type resource_name: str """ _attribute_map = { 'id': {'key': 'id', 'type': 'str'}, 'resource_type': {'key': 'resourceType', 'type': 'str'}, 'resource_name': {'key': 'resourceName', 'type': 'str'}, } def __init__(self, *, id: str=None, resource_type: str=None, resource_name: str=None, **kwargs) -> None: super(BasicDependency, self).__init__(**kwargs) self.id = id self.resource_type = resource_type self.resource_name = resource_name
class CloudError(Model): """An error response for a resource management request. :param error: :type error: ~azure.mgmt.resource.resources.v2017_05_10.models.ErrorResponse """ _attribute_map = { 'error': {'key': 'error', 'type': 'ErrorResponse'}, } def __init__(self, *, error=None, **kwargs) -> None: super(CloudError, self).__init__(**kwargs) self.error = error class CloudErrorException(HttpOperationError): """Server responsed with exception of type: 'CloudError'. :param deserialize: A deserializer :param response: Server response to be deserialized. """ def __init__(self, deserialize, response, *args): super(CloudErrorException, self).__init__(deserialize, response, 'CloudError', *args)
[docs]class DebugSetting(Model): """DebugSetting. :param detail_level: Specifies the type of information to log for debugging. The permitted values are none, requestContent, responseContent, or both requestContent and responseContent separated by a comma. The default is none. When setting this value, carefully consider the type of information you are passing in during deployment. By logging information about the request or response, you could potentially expose sensitive data that is retrieved through the deployment operations. :type detail_level: str """ _attribute_map = { 'detail_level': {'key': 'detailLevel', 'type': 'str'}, } def __init__(self, *, detail_level: str=None, **kwargs) -> None: super(DebugSetting, self).__init__(**kwargs) self.detail_level = detail_level
[docs]class Dependency(Model): """Deployment dependency information. :param depends_on: The list of dependencies. :type depends_on: list[~azure.mgmt.resource.resources.v2017_05_10.models.BasicDependency] :param id: The ID of the dependency. :type id: str :param resource_type: The dependency resource type. :type resource_type: str :param resource_name: The dependency resource name. :type resource_name: str """ _attribute_map = { 'depends_on': {'key': 'dependsOn', 'type': '[BasicDependency]'}, 'id': {'key': 'id', 'type': 'str'}, 'resource_type': {'key': 'resourceType', 'type': 'str'}, 'resource_name': {'key': 'resourceName', 'type': 'str'}, } def __init__(self, *, depends_on=None, id: str=None, resource_type: str=None, resource_name: str=None, **kwargs) -> None: super(Dependency, self).__init__(**kwargs) self.depends_on = depends_on self.id = id self.resource_type = resource_type self.resource_name = resource_name
[docs]class Deployment(Model): """Deployment operation parameters. All required parameters must be populated in order to send to Azure. :param properties: Required. The deployment properties. :type properties: ~azure.mgmt.resource.resources.v2017_05_10.models.DeploymentProperties """ _validation = { 'properties': {'required': True}, } _attribute_map = { 'properties': {'key': 'properties', 'type': 'DeploymentProperties'}, } def __init__(self, *, properties, **kwargs) -> None: super(Deployment, self).__init__(**kwargs) self.properties = properties
[docs]class DeploymentExportResult(Model): """The deployment export result. . :param template: The template content. :type template: object """ _attribute_map = { 'template': {'key': 'template', 'type': 'object'}, } def __init__(self, *, template=None, **kwargs) -> None: super(DeploymentExportResult, self).__init__(**kwargs) self.template = template
[docs]class DeploymentExtended(Model): """Deployment information. 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: The ID of the deployment. :vartype id: str :param name: Required. The name of the deployment. :type name: str :param properties: Deployment properties. :type properties: ~azure.mgmt.resource.resources.v2017_05_10.models.DeploymentPropertiesExtended """ _validation = { 'id': {'readonly': True}, 'name': {'required': True}, } _attribute_map = { 'id': {'key': 'id', 'type': 'str'}, 'name': {'key': 'name', 'type': 'str'}, 'properties': {'key': 'properties', 'type': 'DeploymentPropertiesExtended'}, } def __init__(self, *, name: str, properties=None, **kwargs) -> None: super(DeploymentExtended, self).__init__(**kwargs) self.id = None self.name = name self.properties = properties
[docs]class DeploymentExtendedFilter(Model): """Deployment filter. :param provisioning_state: The provisioning state. :type provisioning_state: str """ _attribute_map = { 'provisioning_state': {'key': 'provisioningState', 'type': 'str'}, } def __init__(self, *, provisioning_state: str=None, **kwargs) -> None: super(DeploymentExtendedFilter, self).__init__(**kwargs) self.provisioning_state = provisioning_state
[docs]class DeploymentOperation(Model): """Deployment operation information. Variables are only populated by the server, and will be ignored when sending a request. :ivar id: Full deployment operation ID. :vartype id: str :ivar operation_id: Deployment operation ID. :vartype operation_id: str :param properties: Deployment properties. :type properties: ~azure.mgmt.resource.resources.v2017_05_10.models.DeploymentOperationProperties """ _validation = { 'id': {'readonly': True}, 'operation_id': {'readonly': True}, } _attribute_map = { 'id': {'key': 'id', 'type': 'str'}, 'operation_id': {'key': 'operationId', 'type': 'str'}, 'properties': {'key': 'properties', 'type': 'DeploymentOperationProperties'}, } def __init__(self, *, properties=None, **kwargs) -> None: super(DeploymentOperation, self).__init__(**kwargs) self.id = None self.operation_id = None self.properties = properties
[docs]class DeploymentOperationProperties(Model): """Deployment operation properties. Variables are only populated by the server, and will be ignored when sending a request. :ivar provisioning_state: The state of the provisioning. :vartype provisioning_state: str :ivar timestamp: The date and time of the operation. :vartype timestamp: datetime :ivar service_request_id: Deployment operation service request id. :vartype service_request_id: str :ivar status_code: Operation status code. :vartype status_code: str :ivar status_message: Operation status message. :vartype status_message: object :ivar target_resource: The target resource. :vartype target_resource: ~azure.mgmt.resource.resources.v2017_05_10.models.TargetResource :ivar request: The HTTP request message. :vartype request: ~azure.mgmt.resource.resources.v2017_05_10.models.HttpMessage :ivar response: The HTTP response message. :vartype response: ~azure.mgmt.resource.resources.v2017_05_10.models.HttpMessage """ _validation = { 'provisioning_state': {'readonly': True}, 'timestamp': {'readonly': True}, 'service_request_id': {'readonly': True}, 'status_code': {'readonly': True}, 'status_message': {'readonly': True}, 'target_resource': {'readonly': True}, 'request': {'readonly': True}, 'response': {'readonly': True}, } _attribute_map = { 'provisioning_state': {'key': 'provisioningState', 'type': 'str'}, 'timestamp': {'key': 'timestamp', 'type': 'iso-8601'}, 'service_request_id': {'key': 'serviceRequestId', 'type': 'str'}, 'status_code': {'key': 'statusCode', 'type': 'str'}, 'status_message': {'key': 'statusMessage', 'type': 'object'}, 'target_resource': {'key': 'targetResource', 'type': 'TargetResource'}, 'request': {'key': 'request', 'type': 'HttpMessage'}, 'response': {'key': 'response', 'type': 'HttpMessage'}, } def __init__(self, **kwargs) -> None: super(DeploymentOperationProperties, self).__init__(**kwargs) self.provisioning_state = None self.timestamp = None self.service_request_id = None self.status_code = None self.status_message = None self.target_resource = None self.request = None self.response = None
[docs]class DeploymentProperties(Model): """Deployment properties. All required parameters must be populated in order to send to Azure. :param template: The template content. You use this element when you want to pass the template syntax directly in the request rather than link to an existing template. It can be a JObject or well-formed JSON string. Use either the templateLink property or the template property, but not both. :type template: object :param template_link: The URI of the template. Use either the templateLink property or the template property, but not both. :type template_link: ~azure.mgmt.resource.resources.v2017_05_10.models.TemplateLink :param parameters: Name and value pairs that define the deployment parameters for the template. You use this element when you want to provide the parameter values directly in the request rather than link to an existing parameter file. Use either the parametersLink property or the parameters property, but not both. It can be a JObject or a well formed JSON string. :type parameters: object :param parameters_link: The URI of parameters file. You use this element to link to an existing parameters file. Use either the parametersLink property or the parameters property, but not both. :type parameters_link: ~azure.mgmt.resource.resources.v2017_05_10.models.ParametersLink :param mode: Required. The mode that is used to deploy resources. This value can be either Incremental or Complete. In Incremental mode, resources are deployed without deleting existing resources that are not included in the template. In Complete mode, resources are deployed and existing resources in the resource group that are not included in the template are deleted. Be careful when using Complete mode as you may unintentionally delete resources. Possible values include: 'Incremental', 'Complete' :type mode: str or ~azure.mgmt.resource.resources.v2017_05_10.models.DeploymentMode :param debug_setting: The debug setting of the deployment. :type debug_setting: ~azure.mgmt.resource.resources.v2017_05_10.models.DebugSetting """ _validation = { 'mode': {'required': True}, } _attribute_map = { 'template': {'key': 'template', 'type': 'object'}, 'template_link': {'key': 'templateLink', 'type': 'TemplateLink'}, 'parameters': {'key': 'parameters', 'type': 'object'}, 'parameters_link': {'key': 'parametersLink', 'type': 'ParametersLink'}, 'mode': {'key': 'mode', 'type': 'DeploymentMode'}, 'debug_setting': {'key': 'debugSetting', 'type': 'DebugSetting'}, } def __init__(self, *, mode, template=None, template_link=None, parameters=None, parameters_link=None, debug_setting=None, **kwargs) -> None: super(DeploymentProperties, self).__init__(**kwargs) self.template = template self.template_link = template_link self.parameters = parameters self.parameters_link = parameters_link self.mode = mode self.debug_setting = debug_setting
[docs]class DeploymentPropertiesExtended(Model): """Deployment properties with additional details. Variables are only populated by the server, and will be ignored when sending a request. :ivar provisioning_state: The state of the provisioning. :vartype provisioning_state: str :ivar correlation_id: The correlation ID of the deployment. :vartype correlation_id: str :ivar timestamp: The timestamp of the template deployment. :vartype timestamp: datetime :param outputs: Key/value pairs that represent deployment output. :type outputs: object :param providers: The list of resource providers needed for the deployment. :type providers: list[~azure.mgmt.resource.resources.v2017_05_10.models.Provider] :param dependencies: The list of deployment dependencies. :type dependencies: list[~azure.mgmt.resource.resources.v2017_05_10.models.Dependency] :param template: The template content. Use only one of Template or TemplateLink. :type template: object :param template_link: The URI referencing the template. Use only one of Template or TemplateLink. :type template_link: ~azure.mgmt.resource.resources.v2017_05_10.models.TemplateLink :param parameters: Deployment parameters. Use only one of Parameters or ParametersLink. :type parameters: object :param parameters_link: The URI referencing the parameters. Use only one of Parameters or ParametersLink. :type parameters_link: ~azure.mgmt.resource.resources.v2017_05_10.models.ParametersLink :param mode: The deployment mode. Possible values are Incremental and Complete. Possible values include: 'Incremental', 'Complete' :type mode: str or ~azure.mgmt.resource.resources.v2017_05_10.models.DeploymentMode :param debug_setting: The debug setting of the deployment. :type debug_setting: ~azure.mgmt.resource.resources.v2017_05_10.models.DebugSetting """ _validation = { 'provisioning_state': {'readonly': True}, 'correlation_id': {'readonly': True}, 'timestamp': {'readonly': True}, } _attribute_map = { 'provisioning_state': {'key': 'provisioningState', 'type': 'str'}, 'correlation_id': {'key': 'correlationId', 'type': 'str'}, 'timestamp': {'key': 'timestamp', 'type': 'iso-8601'}, 'outputs': {'key': 'outputs', 'type': 'object'}, 'providers': {'key': 'providers', 'type': '[Provider]'}, 'dependencies': {'key': 'dependencies', 'type': '[Dependency]'}, 'template': {'key': 'template', 'type': 'object'}, 'template_link': {'key': 'templateLink', 'type': 'TemplateLink'}, 'parameters': {'key': 'parameters', 'type': 'object'}, 'parameters_link': {'key': 'parametersLink', 'type': 'ParametersLink'}, 'mode': {'key': 'mode', 'type': 'DeploymentMode'}, 'debug_setting': {'key': 'debugSetting', 'type': 'DebugSetting'}, } def __init__(self, *, outputs=None, providers=None, dependencies=None, template=None, template_link=None, parameters=None, parameters_link=None, mode=None, debug_setting=None, **kwargs) -> None: super(DeploymentPropertiesExtended, self).__init__(**kwargs) self.provisioning_state = None self.correlation_id = None self.timestamp = None self.outputs = outputs self.providers = providers self.dependencies = dependencies self.template = template self.template_link = template_link self.parameters = parameters self.parameters_link = parameters_link self.mode = mode self.debug_setting = debug_setting
[docs]class DeploymentValidateResult(Model): """Information from validate template deployment response. :param error: Validation error. :type error: ~azure.mgmt.resource.resources.v2017_05_10.models.ResourceManagementErrorWithDetails :param properties: The template deployment properties. :type properties: ~azure.mgmt.resource.resources.v2017_05_10.models.DeploymentPropertiesExtended """ _attribute_map = { 'error': {'key': 'error', 'type': 'ResourceManagementErrorWithDetails'}, 'properties': {'key': 'properties', 'type': 'DeploymentPropertiesExtended'}, } def __init__(self, *, error=None, properties=None, **kwargs) -> None: super(DeploymentValidateResult, self).__init__(**kwargs) self.error = error self.properties = properties
[docs]class ErrorAdditionalInfo(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) -> None: super(ErrorAdditionalInfo, self).__init__(**kwargs) self.type = None self.info = None
[docs]class ErrorResponse(Model): """The resource management error response. 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.resource.resources.v2017_05_10.models.ErrorResponse] :ivar additional_info: The error additional info. :vartype additional_info: list[~azure.mgmt.resource.resources.v2017_05_10.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': '[ErrorResponse]'}, 'additional_info': {'key': 'additionalInfo', 'type': '[ErrorAdditionalInfo]'}, } def __init__(self, **kwargs) -> None: super(ErrorResponse, self).__init__(**kwargs) self.code = None self.message = None self.target = None self.details = None self.additional_info = None
[docs]class ExportTemplateRequest(Model): """Export resource group template request parameters. :param resources: The IDs of the resources to filter the export by. To export all resources, supply an array with single entry '*'. :type resources: list[str] :param options: The export template options. A CSV-formatted list containing zero or more of the following: 'IncludeParameterDefaultValue', 'IncludeComments', 'SkipResourceNameParameterization', 'SkipAllParameterization' :type options: str """ _attribute_map = { 'resources': {'key': 'resources', 'type': '[str]'}, 'options': {'key': 'options', 'type': 'str'}, } def __init__(self, *, resources=None, options: str=None, **kwargs) -> None: super(ExportTemplateRequest, self).__init__(**kwargs) self.resources = resources self.options = options
[docs]class Resource(Model): """Basic set of the resource properties. Variables are only populated by the server, and will be ignored when sending a request. :ivar id: Resource ID :vartype id: str :ivar name: Resource name :vartype name: str :ivar type: Resource type :vartype type: str :param location: Resource location :type location: str :param tags: Resource tags :type tags: dict[str, str] """ _validation = { 'id': {'readonly': True}, 'name': {'readonly': True}, 'type': {'readonly': True}, } _attribute_map = { 'id': {'key': 'id', 'type': 'str'}, 'name': {'key': 'name', 'type': 'str'}, 'type': {'key': 'type', 'type': 'str'}, 'location': {'key': 'location', 'type': 'str'}, 'tags': {'key': 'tags', 'type': '{str}'}, } def __init__(self, *, location: str=None, tags=None, **kwargs) -> None: super(Resource, self).__init__(**kwargs) self.id = None self.name = None self.type = None self.location = location self.tags = tags
[docs]class GenericResource(Resource): """Resource information. Variables are only populated by the server, and will be ignored when sending a request. :ivar id: Resource ID :vartype id: str :ivar name: Resource name :vartype name: str :ivar type: Resource type :vartype type: str :param location: Resource location :type location: str :param tags: Resource tags :type tags: dict[str, str] :param plan: The plan of the resource. :type plan: ~azure.mgmt.resource.resources.v2017_05_10.models.Plan :param properties: The resource properties. :type properties: object :param kind: The kind of the resource. :type kind: str :param managed_by: ID of the resource that manages this resource. :type managed_by: str :param sku: The SKU of the resource. :type sku: ~azure.mgmt.resource.resources.v2017_05_10.models.Sku :param identity: The identity of the resource. :type identity: ~azure.mgmt.resource.resources.v2017_05_10.models.Identity """ _validation = { 'id': {'readonly': True}, 'name': {'readonly': True}, 'type': {'readonly': True}, 'kind': {'pattern': r'^[-\w\._,\(\)]+$'}, } _attribute_map = { 'id': {'key': 'id', 'type': 'str'}, 'name': {'key': 'name', 'type': 'str'}, 'type': {'key': 'type', 'type': 'str'}, 'location': {'key': 'location', 'type': 'str'}, 'tags': {'key': 'tags', 'type': '{str}'}, 'plan': {'key': 'plan', 'type': 'Plan'}, 'properties': {'key': 'properties', 'type': 'object'}, 'kind': {'key': 'kind', 'type': 'str'}, 'managed_by': {'key': 'managedBy', 'type': 'str'}, 'sku': {'key': 'sku', 'type': 'Sku'}, 'identity': {'key': 'identity', 'type': 'Identity'}, } def __init__(self, *, location: str=None, tags=None, plan=None, properties=None, kind: str=None, managed_by: str=None, sku=None, identity=None, **kwargs) -> None: super(GenericResource, self).__init__(location=location, tags=tags, **kwargs) self.plan = plan self.properties = properties self.kind = kind self.managed_by = managed_by self.sku = sku self.identity = identity
[docs]class GenericResourceExpanded(GenericResource): """Resource information. Variables are only populated by the server, and will be ignored when sending a request. :ivar id: Resource ID :vartype id: str :ivar name: Resource name :vartype name: str :ivar type: Resource type :vartype type: str :param location: Resource location :type location: str :param tags: Resource tags :type tags: dict[str, str] :param plan: The plan of the resource. :type plan: ~azure.mgmt.resource.resources.v2017_05_10.models.Plan :param properties: The resource properties. :type properties: object :param kind: The kind of the resource. :type kind: str :param managed_by: ID of the resource that manages this resource. :type managed_by: str :param sku: The SKU of the resource. :type sku: ~azure.mgmt.resource.resources.v2017_05_10.models.Sku :param identity: The identity of the resource. :type identity: ~azure.mgmt.resource.resources.v2017_05_10.models.Identity :ivar created_time: The created time of the resource. This is only present if requested via the $expand query parameter. :vartype created_time: datetime :ivar changed_time: The changed time of the resource. This is only present if requested via the $expand query parameter. :vartype changed_time: datetime :ivar provisioning_state: The provisioning state of the resource. This is only present if requested via the $expand query parameter. :vartype provisioning_state: str """ _validation = { 'id': {'readonly': True}, 'name': {'readonly': True}, 'type': {'readonly': True}, 'kind': {'pattern': r'^[-\w\._,\(\)]+$'}, 'created_time': {'readonly': True}, 'changed_time': {'readonly': True}, 'provisioning_state': {'readonly': True}, } _attribute_map = { 'id': {'key': 'id', 'type': 'str'}, 'name': {'key': 'name', 'type': 'str'}, 'type': {'key': 'type', 'type': 'str'}, 'location': {'key': 'location', 'type': 'str'}, 'tags': {'key': 'tags', 'type': '{str}'}, 'plan': {'key': 'plan', 'type': 'Plan'}, 'properties': {'key': 'properties', 'type': 'object'}, 'kind': {'key': 'kind', 'type': 'str'}, 'managed_by': {'key': 'managedBy', 'type': 'str'}, 'sku': {'key': 'sku', 'type': 'Sku'}, 'identity': {'key': 'identity', 'type': 'Identity'}, 'created_time': {'key': 'createdTime', 'type': 'iso-8601'}, 'changed_time': {'key': 'changedTime', 'type': 'iso-8601'}, 'provisioning_state': {'key': 'provisioningState', 'type': 'str'}, } def __init__(self, *, location: str=None, tags=None, plan=None, properties=None, kind: str=None, managed_by: str=None, sku=None, identity=None, **kwargs) -> None: super(GenericResourceExpanded, self).__init__(location=location, tags=tags, plan=plan, properties=properties, kind=kind, managed_by=managed_by, sku=sku, identity=identity, **kwargs) self.created_time = None self.changed_time = None self.provisioning_state = None
[docs]class GenericResourceFilter(Model): """Resource filter. :param resource_type: The resource type. :type resource_type: str :param tagname: The tag name. :type tagname: str :param tagvalue: The tag value. :type tagvalue: str """ _attribute_map = { 'resource_type': {'key': 'resourceType', 'type': 'str'}, 'tagname': {'key': 'tagname', 'type': 'str'}, 'tagvalue': {'key': 'tagvalue', 'type': 'str'}, } def __init__(self, *, resource_type: str=None, tagname: str=None, tagvalue: str=None, **kwargs) -> None: super(GenericResourceFilter, self).__init__(**kwargs) self.resource_type = resource_type self.tagname = tagname self.tagvalue = tagvalue
[docs]class HttpMessage(Model): """HTTP message. :param content: HTTP message content. :type content: object """ _attribute_map = { 'content': {'key': 'content', 'type': 'object'}, } def __init__(self, *, content=None, **kwargs) -> None: super(HttpMessage, self).__init__(**kwargs) self.content = content
[docs]class Identity(Model): """Identity for the resource. Variables are only populated by the server, and will be ignored when sending a request. :ivar principal_id: The principal ID of resource identity. :vartype principal_id: str :ivar tenant_id: The tenant ID of resource. :vartype tenant_id: str :param type: The identity type. Possible values include: 'SystemAssigned' :type type: str or ~azure.mgmt.resource.resources.v2017_05_10.models.ResourceIdentityType """ _validation = { 'principal_id': {'readonly': True}, 'tenant_id': {'readonly': True}, } _attribute_map = { 'principal_id': {'key': 'principalId', 'type': 'str'}, 'tenant_id': {'key': 'tenantId', 'type': 'str'}, 'type': {'key': 'type', 'type': 'ResourceIdentityType'}, } def __init__(self, *, type=None, **kwargs) -> None: super(Identity, self).__init__(**kwargs) self.principal_id = None self.tenant_id = None self.type = type
[docs]class Plan(Model): """Plan for the resource. :param name: The plan ID. :type name: str :param publisher: The publisher ID. :type publisher: str :param product: The offer ID. :type product: str :param promotion_code: The promotion code. :type promotion_code: str :param version: The plan's version. :type version: str """ _attribute_map = { 'name': {'key': 'name', 'type': 'str'}, 'publisher': {'key': 'publisher', 'type': 'str'}, 'product': {'key': 'product', 'type': 'str'}, 'promotion_code': {'key': 'promotionCode', 'type': 'str'}, 'version': {'key': 'version', 'type': 'str'}, } def __init__(self, *, name: str=None, publisher: str=None, product: str=None, promotion_code: str=None, version: str=None, **kwargs) -> None: super(Plan, self).__init__(**kwargs) self.name = name self.publisher = publisher self.product = product self.promotion_code = promotion_code self.version = version
[docs]class Provider(Model): """Resource provider information. Variables are only populated by the server, and will be ignored when sending a request. :ivar id: The provider ID. :vartype id: str :param namespace: The namespace of the resource provider. :type namespace: str :ivar registration_state: The registration state of the provider. :vartype registration_state: str :ivar resource_types: The collection of provider resource types. :vartype resource_types: list[~azure.mgmt.resource.resources.v2017_05_10.models.ProviderResourceType] """ _validation = { 'id': {'readonly': True}, 'registration_state': {'readonly': True}, 'resource_types': {'readonly': True}, } _attribute_map = { 'id': {'key': 'id', 'type': 'str'}, 'namespace': {'key': 'namespace', 'type': 'str'}, 'registration_state': {'key': 'registrationState', 'type': 'str'}, 'resource_types': {'key': 'resourceTypes', 'type': '[ProviderResourceType]'}, } def __init__(self, *, namespace: str=None, **kwargs) -> None: super(Provider, self).__init__(**kwargs) self.id = None self.namespace = namespace self.registration_state = None self.resource_types = None
[docs]class ProviderResourceType(Model): """Resource type managed by the resource provider. :param resource_type: The resource type. :type resource_type: str :param locations: The collection of locations where this resource type can be created. :type locations: list[str] :param aliases: The aliases that are supported by this resource type. :type aliases: list[~azure.mgmt.resource.resources.v2017_05_10.models.AliasType] :param api_versions: The API version. :type api_versions: list[str] :param properties: The properties. :type properties: dict[str, str] """ _attribute_map = { 'resource_type': {'key': 'resourceType', 'type': 'str'}, 'locations': {'key': 'locations', 'type': '[str]'}, 'aliases': {'key': 'aliases', 'type': '[AliasType]'}, 'api_versions': {'key': 'apiVersions', 'type': '[str]'}, 'properties': {'key': 'properties', 'type': '{str}'}, } def __init__(self, *, resource_type: str=None, locations=None, aliases=None, api_versions=None, properties=None, **kwargs) -> None: super(ProviderResourceType, self).__init__(**kwargs) self.resource_type = resource_type self.locations = locations self.aliases = aliases self.api_versions = api_versions self.properties = properties
[docs]class ResourceGroup(Model): """Resource group information. 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: The ID of the resource group. :vartype id: str :param name: The name of the resource group. :type name: str :param properties: :type properties: ~azure.mgmt.resource.resources.v2017_05_10.models.ResourceGroupProperties :param location: Required. The location of the resource group. It cannot be changed after the resource group has been created. It must be one of the supported Azure locations. :type location: str :param managed_by: The ID of the resource that manages this resource group. :type managed_by: str :param tags: The tags attached to the resource group. :type tags: dict[str, str] """ _validation = { 'id': {'readonly': True}, 'location': {'required': True}, } _attribute_map = { 'id': {'key': 'id', 'type': 'str'}, 'name': {'key': 'name', 'type': 'str'}, 'properties': {'key': 'properties', 'type': 'ResourceGroupProperties'}, 'location': {'key': 'location', 'type': 'str'}, 'managed_by': {'key': 'managedBy', 'type': 'str'}, 'tags': {'key': 'tags', 'type': '{str}'}, } def __init__(self, *, location: str, name: str=None, properties=None, managed_by: str=None, tags=None, **kwargs) -> None: super(ResourceGroup, self).__init__(**kwargs) self.id = None self.name = name self.properties = properties self.location = location self.managed_by = managed_by self.tags = tags
[docs]class ResourceGroupExportResult(Model): """Resource group export result. :param template: The template content. :type template: object :param error: The error. :type error: ~azure.mgmt.resource.resources.v2017_05_10.models.ResourceManagementErrorWithDetails """ _attribute_map = { 'template': {'key': 'template', 'type': 'object'}, 'error': {'key': 'error', 'type': 'ResourceManagementErrorWithDetails'}, } def __init__(self, *, template=None, error=None, **kwargs) -> None: super(ResourceGroupExportResult, self).__init__(**kwargs) self.template = template self.error = error
[docs]class ResourceGroupFilter(Model): """Resource group filter. :param tag_name: The tag name. :type tag_name: str :param tag_value: The tag value. :type tag_value: str """ _attribute_map = { 'tag_name': {'key': 'tagName', 'type': 'str'}, 'tag_value': {'key': 'tagValue', 'type': 'str'}, } def __init__(self, *, tag_name: str=None, tag_value: str=None, **kwargs) -> None: super(ResourceGroupFilter, self).__init__(**kwargs) self.tag_name = tag_name self.tag_value = tag_value
[docs]class ResourceGroupPatchable(Model): """Resource group information. :param name: The name of the resource group. :type name: str :param properties: :type properties: ~azure.mgmt.resource.resources.v2017_05_10.models.ResourceGroupProperties :param managed_by: The ID of the resource that manages this resource group. :type managed_by: str :param tags: The tags attached to the resource group. :type tags: dict[str, str] """ _attribute_map = { 'name': {'key': 'name', 'type': 'str'}, 'properties': {'key': 'properties', 'type': 'ResourceGroupProperties'}, 'managed_by': {'key': 'managedBy', 'type': 'str'}, 'tags': {'key': 'tags', 'type': '{str}'}, } def __init__(self, *, name: str=None, properties=None, managed_by: str=None, tags=None, **kwargs) -> None: super(ResourceGroupPatchable, self).__init__(**kwargs) self.name = name self.properties = properties self.managed_by = managed_by self.tags = tags
[docs]class ResourceGroupProperties(Model): """The resource group properties. Variables are only populated by the server, and will be ignored when sending a request. :ivar provisioning_state: The provisioning state. :vartype provisioning_state: str """ _validation = { 'provisioning_state': {'readonly': True}, } _attribute_map = { 'provisioning_state': {'key': 'provisioningState', 'type': 'str'}, } def __init__(self, **kwargs) -> None: super(ResourceGroupProperties, self).__init__(**kwargs) self.provisioning_state = None
[docs]class ResourceManagementErrorWithDetails(Model): """The detailed error message of resource management. Variables are only populated by the server, and will be ignored when sending a request. :ivar code: The error code returned when exporting the template. :vartype code: str :ivar message: The error message describing the export error. :vartype message: str :ivar target: The target of the error. :vartype target: str :ivar details: Validation error. :vartype details: list[~azure.mgmt.resource.resources.v2017_05_10.models.ResourceManagementErrorWithDetails] """ _validation = { 'code': {'readonly': True}, 'message': {'readonly': True}, 'target': {'readonly': True}, 'details': {'readonly': True}, } _attribute_map = { 'code': {'key': 'code', 'type': 'str'}, 'message': {'key': 'message', 'type': 'str'}, 'target': {'key': 'target', 'type': 'str'}, 'details': {'key': 'details', 'type': '[ResourceManagementErrorWithDetails]'}, } def __init__(self, **kwargs) -> None: super(ResourceManagementErrorWithDetails, self).__init__(**kwargs) self.code = None self.message = None self.target = None self.details = None
[docs]class ResourceProviderOperationDisplayProperties(Model): """Resource provider operation's display properties. :param publisher: Operation description. :type publisher: str :param provider: Operation provider. :type provider: str :param resource: Operation resource. :type resource: str :param operation: The operation name. :type operation: str :param description: Operation description. :type description: str """ _attribute_map = { 'publisher': {'key': 'publisher', 'type': 'str'}, 'provider': {'key': 'provider', 'type': 'str'}, 'resource': {'key': 'resource', 'type': 'str'}, 'operation': {'key': 'operation', 'type': 'str'}, 'description': {'key': 'description', 'type': 'str'}, } def __init__(self, *, publisher: str=None, provider: str=None, resource: str=None, operation: str=None, description: str=None, **kwargs) -> None: super(ResourceProviderOperationDisplayProperties, self).__init__(**kwargs) self.publisher = publisher self.provider = provider self.resource = resource self.operation = operation self.description = description
[docs]class ResourcesMoveInfo(Model): """Parameters of move resources. :param resources: The IDs of the resources. :type resources: list[str] :param target_resource_group: The target resource group. :type target_resource_group: str """ _attribute_map = { 'resources': {'key': 'resources', 'type': '[str]'}, 'target_resource_group': {'key': 'targetResourceGroup', 'type': 'str'}, } def __init__(self, *, resources=None, target_resource_group: str=None, **kwargs) -> None: super(ResourcesMoveInfo, self).__init__(**kwargs) self.resources = resources self.target_resource_group = target_resource_group
[docs]class Sku(Model): """SKU for the resource. :param name: The SKU name. :type name: str :param tier: The SKU tier. :type tier: str :param size: The SKU size. :type size: str :param family: The SKU family. :type family: str :param model: The SKU model. :type model: str :param capacity: The SKU capacity. :type capacity: int """ _attribute_map = { 'name': {'key': 'name', 'type': 'str'}, 'tier': {'key': 'tier', 'type': 'str'}, 'size': {'key': 'size', 'type': 'str'}, 'family': {'key': 'family', 'type': 'str'}, 'model': {'key': 'model', 'type': 'str'}, 'capacity': {'key': 'capacity', 'type': 'int'}, } def __init__(self, *, name: str=None, tier: str=None, size: str=None, family: str=None, model: str=None, capacity: int=None, **kwargs) -> None: super(Sku, self).__init__(**kwargs) self.name = name self.tier = tier self.size = size self.family = family self.model = model self.capacity = capacity
[docs]class SubResource(Model): """Sub-resource. :param id: Resource ID :type id: str """ _attribute_map = { 'id': {'key': 'id', 'type': 'str'}, } def __init__(self, *, id: str=None, **kwargs) -> None: super(SubResource, self).__init__(**kwargs) self.id = id
[docs]class TagCount(Model): """Tag count. :param type: Type of count. :type type: str :param value: Value of count. :type value: int """ _attribute_map = { 'type': {'key': 'type', 'type': 'str'}, 'value': {'key': 'value', 'type': 'int'}, } def __init__(self, *, type: str=None, value: int=None, **kwargs) -> None: super(TagCount, self).__init__(**kwargs) self.type = type self.value = value
[docs]class TagDetails(Model): """Tag details. Variables are only populated by the server, and will be ignored when sending a request. :ivar id: The tag ID. :vartype id: str :param tag_name: The tag name. :type tag_name: str :param count: The total number of resources that use the resource tag. When a tag is initially created and has no associated resources, the value is 0. :type count: ~azure.mgmt.resource.resources.v2017_05_10.models.TagCount :param values: The list of tag values. :type values: list[~azure.mgmt.resource.resources.v2017_05_10.models.TagValue] """ _validation = { 'id': {'readonly': True}, } _attribute_map = { 'id': {'key': 'id', 'type': 'str'}, 'tag_name': {'key': 'tagName', 'type': 'str'}, 'count': {'key': 'count', 'type': 'TagCount'}, 'values': {'key': 'values', 'type': '[TagValue]'}, } def __init__(self, *, tag_name: str=None, count=None, values=None, **kwargs) -> None: super(TagDetails, self).__init__(**kwargs) self.id = None self.tag_name = tag_name self.count = count self.values = values
[docs]class TagValue(Model): """Tag information. Variables are only populated by the server, and will be ignored when sending a request. :ivar id: The tag ID. :vartype id: str :param tag_value: The tag value. :type tag_value: str :param count: The tag value count. :type count: ~azure.mgmt.resource.resources.v2017_05_10.models.TagCount """ _validation = { 'id': {'readonly': True}, } _attribute_map = { 'id': {'key': 'id', 'type': 'str'}, 'tag_value': {'key': 'tagValue', 'type': 'str'}, 'count': {'key': 'count', 'type': 'TagCount'}, } def __init__(self, *, tag_value: str=None, count=None, **kwargs) -> None: super(TagValue, self).__init__(**kwargs) self.id = None self.tag_value = tag_value self.count = count
[docs]class TargetResource(Model): """Target resource. :param id: The ID of the resource. :type id: str :param resource_name: The name of the resource. :type resource_name: str :param resource_type: The type of the resource. :type resource_type: str """ _attribute_map = { 'id': {'key': 'id', 'type': 'str'}, 'resource_name': {'key': 'resourceName', 'type': 'str'}, 'resource_type': {'key': 'resourceType', 'type': 'str'}, } def __init__(self, *, id: str=None, resource_name: str=None, resource_type: str=None, **kwargs) -> None: super(TargetResource, self).__init__(**kwargs) self.id = id self.resource_name = resource_name self.resource_type = resource_type
[docs]class TemplateHashResult(Model): """Result of the request to calculate template hash. It contains a string of minified template and its hash. :param minified_template: The minified template string. :type minified_template: str :param template_hash: The template hash. :type template_hash: str """ _attribute_map = { 'minified_template': {'key': 'minifiedTemplate', 'type': 'str'}, 'template_hash': {'key': 'templateHash', 'type': 'str'}, } def __init__(self, *, minified_template: str=None, template_hash: str=None, **kwargs) -> None: super(TemplateHashResult, self).__init__(**kwargs) self.minified_template = minified_template self.template_hash = template_hash