pulumi-azure-native 2.43.1__py3-none-any.whl → 2.44.0__py3-none-any.whl

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.

Potentially problematic release.


This version of pulumi-azure-native might be problematic. Click here for more details.

Files changed (171) hide show
  1. pulumi_azure_native/__init__.py +69 -2
  2. pulumi_azure_native/appcomplianceautomation/__init__.py +14 -0
  3. pulumi_azure_native/appcomplianceautomation/_enums.py +125 -0
  4. pulumi_azure_native/appcomplianceautomation/_inputs.py +40 -0
  5. pulumi_azure_native/appcomplianceautomation/evidence.py +363 -0
  6. pulumi_azure_native/appcomplianceautomation/get_evidence.py +198 -0
  7. pulumi_azure_native/appcomplianceautomation/get_provider_action_collection_count.py +75 -0
  8. pulumi_azure_native/appcomplianceautomation/get_provider_action_overview_status.py +76 -0
  9. pulumi_azure_native/appcomplianceautomation/get_report.py +4 -0
  10. pulumi_azure_native/appcomplianceautomation/get_report_scoping_questions.py +76 -0
  11. pulumi_azure_native/appcomplianceautomation/get_scoping_configuration.py +146 -0
  12. pulumi_azure_native/appcomplianceautomation/get_webhook.py +289 -0
  13. pulumi_azure_native/appcomplianceautomation/list_provider_action_in_use_storage_accounts.py +76 -0
  14. pulumi_azure_native/appcomplianceautomation/outputs.py +226 -0
  15. pulumi_azure_native/appcomplianceautomation/report.py +5 -1
  16. pulumi_azure_native/appcomplianceautomation/scoping_configuration.py +206 -0
  17. pulumi_azure_native/appcomplianceautomation/v20221116preview/report.py +1 -1
  18. pulumi_azure_native/appcomplianceautomation/v20240627/__init__.py +22 -0
  19. pulumi_azure_native/appcomplianceautomation/v20240627/_enums.py +144 -0
  20. pulumi_azure_native/appcomplianceautomation/v20240627/_inputs.py +215 -0
  21. pulumi_azure_native/appcomplianceautomation/v20240627/evidence.py +361 -0
  22. pulumi_azure_native/appcomplianceautomation/v20240627/get_evidence.py +196 -0
  23. pulumi_azure_native/appcomplianceautomation/v20240627/get_provider_action_collection_count.py +73 -0
  24. pulumi_azure_native/appcomplianceautomation/v20240627/get_provider_action_overview_status.py +74 -0
  25. pulumi_azure_native/appcomplianceautomation/v20240627/get_report.py +296 -0
  26. pulumi_azure_native/appcomplianceautomation/v20240627/get_report_scoping_questions.py +74 -0
  27. pulumi_azure_native/appcomplianceautomation/v20240627/get_scoping_configuration.py +144 -0
  28. pulumi_azure_native/appcomplianceautomation/v20240627/get_webhook.py +287 -0
  29. pulumi_azure_native/appcomplianceautomation/v20240627/list_provider_action_in_use_storage_accounts.py +74 -0
  30. pulumi_azure_native/appcomplianceautomation/v20240627/outputs.py +720 -0
  31. pulumi_azure_native/appcomplianceautomation/v20240627/report.py +387 -0
  32. pulumi_azure_native/appcomplianceautomation/v20240627/scoping_configuration.py +204 -0
  33. pulumi_azure_native/appcomplianceautomation/v20240627/webhook.py +447 -0
  34. pulumi_azure_native/appcomplianceautomation/webhook.py +449 -0
  35. pulumi_azure_native/devhub/__init__.py +5 -0
  36. pulumi_azure_native/devhub/_inputs.py +190 -0
  37. pulumi_azure_native/devhub/get_git_hub_o_auth.py +2 -2
  38. pulumi_azure_native/devhub/get_iac_profile.py +322 -0
  39. pulumi_azure_native/devhub/get_workflow.py +2 -2
  40. pulumi_azure_native/devhub/iac_profile.py +539 -0
  41. pulumi_azure_native/devhub/outputs.py +229 -0
  42. pulumi_azure_native/devhub/v20221011preview/workflow.py +1 -1
  43. pulumi_azure_native/devhub/v20230801/workflow.py +1 -1
  44. pulumi_azure_native/devhub/v20240501preview/__init__.py +15 -0
  45. pulumi_azure_native/devhub/v20240501preview/_enums.py +146 -0
  46. pulumi_azure_native/devhub/v20240501preview/_inputs.py +427 -0
  47. pulumi_azure_native/devhub/v20240501preview/get_git_hub_o_auth.py +91 -0
  48. pulumi_azure_native/devhub/v20240501preview/get_iac_profile.py +320 -0
  49. pulumi_azure_native/devhub/v20240501preview/get_workflow.py +489 -0
  50. pulumi_azure_native/devhub/v20240501preview/iac_profile.py +537 -0
  51. pulumi_azure_native/devhub/v20240501preview/outputs.py +654 -0
  52. pulumi_azure_native/devhub/v20240501preview/workflow.py +915 -0
  53. pulumi_azure_native/devhub/workflow.py +3 -3
  54. pulumi_azure_native/hybridcompute/__init__.py +3 -0
  55. pulumi_azure_native/hybridcompute/gateway.py +5 -1
  56. pulumi_azure_native/hybridcompute/get_gateway.py +4 -0
  57. pulumi_azure_native/hybridcompute/get_license.py +2 -2
  58. pulumi_azure_native/hybridcompute/get_license_profile.py +2 -2
  59. pulumi_azure_native/hybridcompute/get_machine.py +2 -2
  60. pulumi_azure_native/hybridcompute/get_machine_extension.py +2 -2
  61. pulumi_azure_native/hybridcompute/get_machine_run_command.py +2 -2
  62. pulumi_azure_native/hybridcompute/get_private_endpoint_connection.py +2 -2
  63. pulumi_azure_native/hybridcompute/get_private_link_scope.py +2 -2
  64. pulumi_azure_native/hybridcompute/license.py +3 -3
  65. pulumi_azure_native/hybridcompute/license_profile.py +3 -3
  66. pulumi_azure_native/hybridcompute/machine.py +3 -3
  67. pulumi_azure_native/hybridcompute/machine_extension.py +3 -3
  68. pulumi_azure_native/hybridcompute/machine_run_command.py +3 -3
  69. pulumi_azure_native/hybridcompute/private_endpoint_connection.py +3 -3
  70. pulumi_azure_native/hybridcompute/private_link_scope.py +3 -3
  71. pulumi_azure_native/hybridcompute/v20200802/machine.py +1 -1
  72. pulumi_azure_native/hybridcompute/v20200815preview/machine.py +1 -1
  73. pulumi_azure_native/hybridcompute/v20200815preview/machine_extension.py +1 -1
  74. pulumi_azure_native/hybridcompute/v20200815preview/private_endpoint_connection.py +1 -1
  75. pulumi_azure_native/hybridcompute/v20200815preview/private_link_scope.py +1 -1
  76. pulumi_azure_native/hybridcompute/v20220510preview/machine.py +1 -1
  77. pulumi_azure_native/hybridcompute/v20220510preview/machine_extension.py +1 -1
  78. pulumi_azure_native/hybridcompute/v20221227/machine.py +1 -1
  79. pulumi_azure_native/hybridcompute/v20221227/machine_extension.py +1 -1
  80. pulumi_azure_native/hybridcompute/v20221227/private_endpoint_connection.py +1 -1
  81. pulumi_azure_native/hybridcompute/v20221227/private_link_scope.py +1 -1
  82. pulumi_azure_native/hybridcompute/v20230620preview/license.py +1 -1
  83. pulumi_azure_native/hybridcompute/v20230620preview/license_profile.py +1 -1
  84. pulumi_azure_native/hybridcompute/v20230620preview/machine.py +1 -1
  85. pulumi_azure_native/hybridcompute/v20230620preview/machine_extension.py +1 -1
  86. pulumi_azure_native/hybridcompute/v20230620preview/private_endpoint_connection.py +1 -1
  87. pulumi_azure_native/hybridcompute/v20230620preview/private_link_scope.py +1 -1
  88. pulumi_azure_native/hybridcompute/v20231003preview/license.py +1 -1
  89. pulumi_azure_native/hybridcompute/v20231003preview/license_profile.py +1 -1
  90. pulumi_azure_native/hybridcompute/v20231003preview/machine.py +1 -1
  91. pulumi_azure_native/hybridcompute/v20231003preview/machine_extension.py +1 -1
  92. pulumi_azure_native/hybridcompute/v20231003preview/machine_run_command.py +1 -1
  93. pulumi_azure_native/hybridcompute/v20231003preview/private_endpoint_connection.py +1 -1
  94. pulumi_azure_native/hybridcompute/v20231003preview/private_link_scope.py +1 -1
  95. pulumi_azure_native/hybridcompute/v20240331preview/gateway.py +1 -1
  96. pulumi_azure_native/hybridcompute/v20240331preview/license.py +1 -1
  97. pulumi_azure_native/hybridcompute/v20240331preview/license_profile.py +1 -1
  98. pulumi_azure_native/hybridcompute/v20240331preview/machine.py +1 -1
  99. pulumi_azure_native/hybridcompute/v20240331preview/machine_extension.py +1 -1
  100. pulumi_azure_native/hybridcompute/v20240331preview/machine_run_command.py +1 -1
  101. pulumi_azure_native/hybridcompute/v20240331preview/private_endpoint_connection.py +1 -1
  102. pulumi_azure_native/hybridcompute/v20240331preview/private_link_scope.py +1 -1
  103. pulumi_azure_native/hybridcompute/v20240520preview/__init__.py +26 -0
  104. pulumi_azure_native/hybridcompute/v20240520preview/_enums.py +172 -0
  105. pulumi_azure_native/hybridcompute/v20240520preview/_inputs.py +1408 -0
  106. pulumi_azure_native/hybridcompute/v20240520preview/gateway.py +311 -0
  107. pulumi_azure_native/hybridcompute/v20240520preview/get_gateway.py +209 -0
  108. pulumi_azure_native/hybridcompute/v20240520preview/get_license.py +196 -0
  109. pulumi_azure_native/hybridcompute/v20240520preview/get_license_profile.py +357 -0
  110. pulumi_azure_native/hybridcompute/v20240520preview/get_machine.py +591 -0
  111. pulumi_azure_native/hybridcompute/v20240520preview/get_machine_extension.py +162 -0
  112. pulumi_azure_native/hybridcompute/v20240520preview/get_machine_run_command.py +318 -0
  113. pulumi_azure_native/hybridcompute/v20240520preview/get_private_endpoint_connection.py +136 -0
  114. pulumi_azure_native/hybridcompute/v20240520preview/get_private_link_scope.py +157 -0
  115. pulumi_azure_native/hybridcompute/v20240520preview/license.py +321 -0
  116. pulumi_azure_native/hybridcompute/v20240520preview/license_profile.py +500 -0
  117. pulumi_azure_native/hybridcompute/v20240520preview/machine.py +850 -0
  118. pulumi_azure_native/hybridcompute/v20240520preview/machine_extension.py +274 -0
  119. pulumi_azure_native/hybridcompute/v20240520preview/machine_run_command.py +587 -0
  120. pulumi_azure_native/hybridcompute/v20240520preview/outputs.py +3204 -0
  121. pulumi_azure_native/hybridcompute/v20240520preview/private_endpoint_connection.py +215 -0
  122. pulumi_azure_native/hybridcompute/v20240520preview/private_link_scope.py +253 -0
  123. pulumi_azure_native/pulumi-plugin.json +1 -1
  124. pulumi_azure_native/scvmm/get_guest_agent.py +2 -2
  125. pulumi_azure_native/scvmm/get_vm_instance_guest_agent.py +0 -4
  126. pulumi_azure_native/scvmm/guest_agent.py +2 -2
  127. pulumi_azure_native/scvmm/v20231007/__init__.py +2 -2
  128. pulumi_azure_native/scvmm/v20231007/_enums.py +49 -4
  129. pulumi_azure_native/scvmm/v20231007/_inputs.py +56 -145
  130. pulumi_azure_native/scvmm/v20231007/cloud.py +6 -6
  131. pulumi_azure_native/scvmm/v20231007/get_cloud.py +10 -10
  132. pulumi_azure_native/scvmm/v20231007/{get_vm_instance_guest_agent.py → get_guest_agent.py} +16 -16
  133. pulumi_azure_native/scvmm/v20231007/get_inventory_item.py +4 -4
  134. pulumi_azure_native/scvmm/v20231007/get_virtual_machine_instance.py +4 -4
  135. pulumi_azure_native/scvmm/v20231007/get_vmm_server.py +6 -6
  136. pulumi_azure_native/scvmm/v20231007/{vm_instance_guest_agent.py → guest_agent.py} +18 -18
  137. pulumi_azure_native/scvmm/v20231007/inventory_item.py +5 -5
  138. pulumi_azure_native/scvmm/v20231007/outputs.py +96 -100
  139. pulumi_azure_native/scvmm/v20231007/virtual_machine_instance.py +19 -19
  140. pulumi_azure_native/scvmm/v20231007/vmm_server.py +13 -13
  141. pulumi_azure_native/scvmm/vm_instance_guest_agent.py +0 -4
  142. pulumi_azure_native/storage/v20230501/_enums.py +2 -0
  143. pulumi_azure_native/verifiedid/__init__.py +18 -0
  144. pulumi_azure_native/verifiedid/authority.py +234 -0
  145. pulumi_azure_native/verifiedid/get_authority.py +159 -0
  146. pulumi_azure_native/verifiedid/outputs.py +125 -0
  147. pulumi_azure_native/verifiedid/v20240126preview/__init__.py +10 -0
  148. pulumi_azure_native/verifiedid/v20240126preview/authority.py +232 -0
  149. pulumi_azure_native/verifiedid/v20240126preview/get_authority.py +157 -0
  150. pulumi_azure_native/verifiedid/v20240126preview/outputs.py +125 -0
  151. pulumi_azure_native/virtualmachineimages/__init__.py +3 -0
  152. pulumi_azure_native/virtualmachineimages/get_trigger.py +2 -2
  153. pulumi_azure_native/virtualmachineimages/get_virtual_machine_image_template.py +2 -2
  154. pulumi_azure_native/virtualmachineimages/trigger.py +3 -3
  155. pulumi_azure_native/virtualmachineimages/v20220701/trigger.py +1 -1
  156. pulumi_azure_native/virtualmachineimages/v20220701/virtual_machine_image_template.py +1 -1
  157. pulumi_azure_native/virtualmachineimages/v20230701/trigger.py +1 -1
  158. pulumi_azure_native/virtualmachineimages/v20230701/virtual_machine_image_template.py +1 -1
  159. pulumi_azure_native/virtualmachineimages/v20240201/__init__.py +14 -0
  160. pulumi_azure_native/virtualmachineimages/v20240201/_enums.py +60 -0
  161. pulumi_azure_native/virtualmachineimages/v20240201/_inputs.py +1895 -0
  162. pulumi_azure_native/virtualmachineimages/v20240201/get_trigger.py +162 -0
  163. pulumi_azure_native/virtualmachineimages/v20240201/get_virtual_machine_image_template.py +352 -0
  164. pulumi_azure_native/virtualmachineimages/v20240201/outputs.py +2401 -0
  165. pulumi_azure_native/virtualmachineimages/v20240201/trigger.py +235 -0
  166. pulumi_azure_native/virtualmachineimages/v20240201/virtual_machine_image_template.py +619 -0
  167. pulumi_azure_native/virtualmachineimages/virtual_machine_image_template.py +3 -3
  168. {pulumi_azure_native-2.43.1.dist-info → pulumi_azure_native-2.44.0.dist-info}/METADATA +1 -1
  169. {pulumi_azure_native-2.43.1.dist-info → pulumi_azure_native-2.44.0.dist-info}/RECORD +171 -97
  170. {pulumi_azure_native-2.43.1.dist-info → pulumi_azure_native-2.44.0.dist-info}/WHEEL +0 -0
  171. {pulumi_azure_native-2.43.1.dist-info → pulumi_azure_native-2.44.0.dist-info}/top_level.txt +0 -0
@@ -0,0 +1,3204 @@
1
+ # coding=utf-8
2
+ # *** WARNING: this file was generated by pulumi-language-python. ***
3
+ # *** Do not edit by hand unless you're certain you know what you are doing! ***
4
+
5
+ import copy
6
+ import warnings
7
+ import pulumi
8
+ import pulumi.runtime
9
+ from typing import Any, Mapping, Optional, Sequence, Union, overload
10
+ from ... import _utilities
11
+ from . import outputs
12
+ from ._enums import *
13
+
14
+ __all__ = [
15
+ 'AgentConfigurationResponse',
16
+ 'AgentUpgradeResponse',
17
+ 'CloudMetadataResponse',
18
+ 'ConfigurationExtensionResponse',
19
+ 'ErrorAdditionalInfoResponse',
20
+ 'ErrorDetailResponse',
21
+ 'EsuKeyResponse',
22
+ 'ExtensionsResourceStatusResponse',
23
+ 'HybridComputePrivateLinkScopePropertiesResponse',
24
+ 'IdentityResponse',
25
+ 'IpAddressResponse',
26
+ 'LicenseDetailsResponse',
27
+ 'LicenseProfileMachineInstanceViewEsuPropertiesResponse',
28
+ 'LicenseProfileMachineInstanceViewResponse',
29
+ 'LicenseResponse',
30
+ 'LocationDataResponse',
31
+ 'MachineExtensionInstanceViewResponse',
32
+ 'MachineExtensionInstanceViewResponseStatus',
33
+ 'MachineExtensionPropertiesResponse',
34
+ 'MachineExtensionResponse',
35
+ 'MachineRunCommandInstanceViewResponse',
36
+ 'MachineRunCommandScriptSourceResponse',
37
+ 'NetworkInterfaceResponse',
38
+ 'NetworkProfileResponse',
39
+ 'OSProfileResponse',
40
+ 'OSProfileResponseLinuxConfiguration',
41
+ 'OSProfileResponseWindowsConfiguration',
42
+ 'PatchSettingsResponseStatus',
43
+ 'PrivateEndpointConnectionDataModelResponse',
44
+ 'PrivateEndpointConnectionPropertiesResponse',
45
+ 'PrivateEndpointPropertyResponse',
46
+ 'PrivateLinkServiceConnectionStatePropertyResponse',
47
+ 'ProductFeatureResponse',
48
+ 'RunCommandInputParameterResponse',
49
+ 'RunCommandManagedIdentityResponse',
50
+ 'ServiceStatusResponse',
51
+ 'ServiceStatusesResponse',
52
+ 'SubnetResponse',
53
+ 'SystemDataResponse',
54
+ 'VolumeLicenseDetailsResponse',
55
+ ]
56
+
57
+ @pulumi.output_type
58
+ class AgentConfigurationResponse(dict):
59
+ """
60
+ Configurable properties that the user can set locally via the azcmagent config command, or remotely via ARM.
61
+ """
62
+ @staticmethod
63
+ def __key_warning(key: str):
64
+ suggest = None
65
+ if key == "configMode":
66
+ suggest = "config_mode"
67
+ elif key == "extensionsAllowList":
68
+ suggest = "extensions_allow_list"
69
+ elif key == "extensionsBlockList":
70
+ suggest = "extensions_block_list"
71
+ elif key == "extensionsEnabled":
72
+ suggest = "extensions_enabled"
73
+ elif key == "guestConfigurationEnabled":
74
+ suggest = "guest_configuration_enabled"
75
+ elif key == "incomingConnectionsPorts":
76
+ suggest = "incoming_connections_ports"
77
+ elif key == "proxyBypass":
78
+ suggest = "proxy_bypass"
79
+ elif key == "proxyUrl":
80
+ suggest = "proxy_url"
81
+
82
+ if suggest:
83
+ pulumi.log.warn(f"Key '{key}' not found in AgentConfigurationResponse. Access the value via the '{suggest}' property getter instead.")
84
+
85
+ def __getitem__(self, key: str) -> Any:
86
+ AgentConfigurationResponse.__key_warning(key)
87
+ return super().__getitem__(key)
88
+
89
+ def get(self, key: str, default = None) -> Any:
90
+ AgentConfigurationResponse.__key_warning(key)
91
+ return super().get(key, default)
92
+
93
+ def __init__(__self__, *,
94
+ config_mode: str,
95
+ extensions_allow_list: Sequence['outputs.ConfigurationExtensionResponse'],
96
+ extensions_block_list: Sequence['outputs.ConfigurationExtensionResponse'],
97
+ extensions_enabled: str,
98
+ guest_configuration_enabled: str,
99
+ incoming_connections_ports: Sequence[str],
100
+ proxy_bypass: Sequence[str],
101
+ proxy_url: str):
102
+ """
103
+ Configurable properties that the user can set locally via the azcmagent config command, or remotely via ARM.
104
+ :param str config_mode: Name of configuration mode to use. Modes are pre-defined configurations of security controls, extension allowlists and guest configuration, maintained by Microsoft.
105
+ :param Sequence['ConfigurationExtensionResponse'] extensions_allow_list: Array of extensions that are allowed to be installed or updated.
106
+ :param Sequence['ConfigurationExtensionResponse'] extensions_block_list: Array of extensions that are blocked (cannot be installed or updated)
107
+ :param str extensions_enabled: Specifies whether the extension service is enabled or disabled.
108
+ :param str guest_configuration_enabled: Specified whether the guest configuration service is enabled or disabled.
109
+ :param Sequence[str] incoming_connections_ports: Specifies the list of ports that the agent will be able to listen on.
110
+ :param Sequence[str] proxy_bypass: List of service names which should not use the specified proxy server.
111
+ :param str proxy_url: Specifies the URL of the proxy to be used.
112
+ """
113
+ pulumi.set(__self__, "config_mode", config_mode)
114
+ pulumi.set(__self__, "extensions_allow_list", extensions_allow_list)
115
+ pulumi.set(__self__, "extensions_block_list", extensions_block_list)
116
+ pulumi.set(__self__, "extensions_enabled", extensions_enabled)
117
+ pulumi.set(__self__, "guest_configuration_enabled", guest_configuration_enabled)
118
+ pulumi.set(__self__, "incoming_connections_ports", incoming_connections_ports)
119
+ pulumi.set(__self__, "proxy_bypass", proxy_bypass)
120
+ pulumi.set(__self__, "proxy_url", proxy_url)
121
+
122
+ @property
123
+ @pulumi.getter(name="configMode")
124
+ def config_mode(self) -> str:
125
+ """
126
+ Name of configuration mode to use. Modes are pre-defined configurations of security controls, extension allowlists and guest configuration, maintained by Microsoft.
127
+ """
128
+ return pulumi.get(self, "config_mode")
129
+
130
+ @property
131
+ @pulumi.getter(name="extensionsAllowList")
132
+ def extensions_allow_list(self) -> Sequence['outputs.ConfigurationExtensionResponse']:
133
+ """
134
+ Array of extensions that are allowed to be installed or updated.
135
+ """
136
+ return pulumi.get(self, "extensions_allow_list")
137
+
138
+ @property
139
+ @pulumi.getter(name="extensionsBlockList")
140
+ def extensions_block_list(self) -> Sequence['outputs.ConfigurationExtensionResponse']:
141
+ """
142
+ Array of extensions that are blocked (cannot be installed or updated)
143
+ """
144
+ return pulumi.get(self, "extensions_block_list")
145
+
146
+ @property
147
+ @pulumi.getter(name="extensionsEnabled")
148
+ def extensions_enabled(self) -> str:
149
+ """
150
+ Specifies whether the extension service is enabled or disabled.
151
+ """
152
+ return pulumi.get(self, "extensions_enabled")
153
+
154
+ @property
155
+ @pulumi.getter(name="guestConfigurationEnabled")
156
+ def guest_configuration_enabled(self) -> str:
157
+ """
158
+ Specified whether the guest configuration service is enabled or disabled.
159
+ """
160
+ return pulumi.get(self, "guest_configuration_enabled")
161
+
162
+ @property
163
+ @pulumi.getter(name="incomingConnectionsPorts")
164
+ def incoming_connections_ports(self) -> Sequence[str]:
165
+ """
166
+ Specifies the list of ports that the agent will be able to listen on.
167
+ """
168
+ return pulumi.get(self, "incoming_connections_ports")
169
+
170
+ @property
171
+ @pulumi.getter(name="proxyBypass")
172
+ def proxy_bypass(self) -> Sequence[str]:
173
+ """
174
+ List of service names which should not use the specified proxy server.
175
+ """
176
+ return pulumi.get(self, "proxy_bypass")
177
+
178
+ @property
179
+ @pulumi.getter(name="proxyUrl")
180
+ def proxy_url(self) -> str:
181
+ """
182
+ Specifies the URL of the proxy to be used.
183
+ """
184
+ return pulumi.get(self, "proxy_url")
185
+
186
+
187
+ @pulumi.output_type
188
+ class AgentUpgradeResponse(dict):
189
+ """
190
+ The info w.r.t Agent Upgrade.
191
+ """
192
+ @staticmethod
193
+ def __key_warning(key: str):
194
+ suggest = None
195
+ if key == "lastAttemptDesiredVersion":
196
+ suggest = "last_attempt_desired_version"
197
+ elif key == "lastAttemptMessage":
198
+ suggest = "last_attempt_message"
199
+ elif key == "lastAttemptStatus":
200
+ suggest = "last_attempt_status"
201
+ elif key == "lastAttemptTimestamp":
202
+ suggest = "last_attempt_timestamp"
203
+ elif key == "correlationId":
204
+ suggest = "correlation_id"
205
+ elif key == "desiredVersion":
206
+ suggest = "desired_version"
207
+ elif key == "enableAutomaticUpgrade":
208
+ suggest = "enable_automatic_upgrade"
209
+
210
+ if suggest:
211
+ pulumi.log.warn(f"Key '{key}' not found in AgentUpgradeResponse. Access the value via the '{suggest}' property getter instead.")
212
+
213
+ def __getitem__(self, key: str) -> Any:
214
+ AgentUpgradeResponse.__key_warning(key)
215
+ return super().__getitem__(key)
216
+
217
+ def get(self, key: str, default = None) -> Any:
218
+ AgentUpgradeResponse.__key_warning(key)
219
+ return super().get(key, default)
220
+
221
+ def __init__(__self__, *,
222
+ last_attempt_desired_version: str,
223
+ last_attempt_message: str,
224
+ last_attempt_status: str,
225
+ last_attempt_timestamp: str,
226
+ correlation_id: Optional[str] = None,
227
+ desired_version: Optional[str] = None,
228
+ enable_automatic_upgrade: Optional[bool] = None):
229
+ """
230
+ The info w.r.t Agent Upgrade.
231
+ :param str last_attempt_desired_version: Specifies the version of the last attempt
232
+ :param str last_attempt_message: Failure message of last upgrade attempt if any.
233
+ :param str last_attempt_status: Specifies the status of Agent Upgrade.
234
+ :param str last_attempt_timestamp: Timestamp of last upgrade attempt
235
+ :param str correlation_id: The correlation ID passed in from RSM per upgrade.
236
+ :param str desired_version: Specifies the version info w.r.t AgentUpgrade for the machine.
237
+ :param bool enable_automatic_upgrade: Specifies if RSM should try to upgrade this machine
238
+ """
239
+ pulumi.set(__self__, "last_attempt_desired_version", last_attempt_desired_version)
240
+ pulumi.set(__self__, "last_attempt_message", last_attempt_message)
241
+ pulumi.set(__self__, "last_attempt_status", last_attempt_status)
242
+ pulumi.set(__self__, "last_attempt_timestamp", last_attempt_timestamp)
243
+ if correlation_id is not None:
244
+ pulumi.set(__self__, "correlation_id", correlation_id)
245
+ if desired_version is not None:
246
+ pulumi.set(__self__, "desired_version", desired_version)
247
+ if enable_automatic_upgrade is not None:
248
+ pulumi.set(__self__, "enable_automatic_upgrade", enable_automatic_upgrade)
249
+
250
+ @property
251
+ @pulumi.getter(name="lastAttemptDesiredVersion")
252
+ def last_attempt_desired_version(self) -> str:
253
+ """
254
+ Specifies the version of the last attempt
255
+ """
256
+ return pulumi.get(self, "last_attempt_desired_version")
257
+
258
+ @property
259
+ @pulumi.getter(name="lastAttemptMessage")
260
+ def last_attempt_message(self) -> str:
261
+ """
262
+ Failure message of last upgrade attempt if any.
263
+ """
264
+ return pulumi.get(self, "last_attempt_message")
265
+
266
+ @property
267
+ @pulumi.getter(name="lastAttemptStatus")
268
+ def last_attempt_status(self) -> str:
269
+ """
270
+ Specifies the status of Agent Upgrade.
271
+ """
272
+ return pulumi.get(self, "last_attempt_status")
273
+
274
+ @property
275
+ @pulumi.getter(name="lastAttemptTimestamp")
276
+ def last_attempt_timestamp(self) -> str:
277
+ """
278
+ Timestamp of last upgrade attempt
279
+ """
280
+ return pulumi.get(self, "last_attempt_timestamp")
281
+
282
+ @property
283
+ @pulumi.getter(name="correlationId")
284
+ def correlation_id(self) -> Optional[str]:
285
+ """
286
+ The correlation ID passed in from RSM per upgrade.
287
+ """
288
+ return pulumi.get(self, "correlation_id")
289
+
290
+ @property
291
+ @pulumi.getter(name="desiredVersion")
292
+ def desired_version(self) -> Optional[str]:
293
+ """
294
+ Specifies the version info w.r.t AgentUpgrade for the machine.
295
+ """
296
+ return pulumi.get(self, "desired_version")
297
+
298
+ @property
299
+ @pulumi.getter(name="enableAutomaticUpgrade")
300
+ def enable_automatic_upgrade(self) -> Optional[bool]:
301
+ """
302
+ Specifies if RSM should try to upgrade this machine
303
+ """
304
+ return pulumi.get(self, "enable_automatic_upgrade")
305
+
306
+
307
+ @pulumi.output_type
308
+ class CloudMetadataResponse(dict):
309
+ """
310
+ The metadata of the cloud environment (Azure/GCP/AWS/OCI...).
311
+ """
312
+ def __init__(__self__, *,
313
+ provider: str):
314
+ """
315
+ The metadata of the cloud environment (Azure/GCP/AWS/OCI...).
316
+ :param str provider: Specifies the cloud provider (Azure/AWS/GCP...).
317
+ """
318
+ pulumi.set(__self__, "provider", provider)
319
+
320
+ @property
321
+ @pulumi.getter
322
+ def provider(self) -> str:
323
+ """
324
+ Specifies the cloud provider (Azure/AWS/GCP...).
325
+ """
326
+ return pulumi.get(self, "provider")
327
+
328
+
329
+ @pulumi.output_type
330
+ class ConfigurationExtensionResponse(dict):
331
+ """
332
+ Describes properties that can identify extensions.
333
+ """
334
+ def __init__(__self__, *,
335
+ publisher: str,
336
+ type: str):
337
+ """
338
+ Describes properties that can identify extensions.
339
+ :param str publisher: Publisher of the extension.
340
+ :param str type: Type of the extension.
341
+ """
342
+ pulumi.set(__self__, "publisher", publisher)
343
+ pulumi.set(__self__, "type", type)
344
+
345
+ @property
346
+ @pulumi.getter
347
+ def publisher(self) -> str:
348
+ """
349
+ Publisher of the extension.
350
+ """
351
+ return pulumi.get(self, "publisher")
352
+
353
+ @property
354
+ @pulumi.getter
355
+ def type(self) -> str:
356
+ """
357
+ Type of the extension.
358
+ """
359
+ return pulumi.get(self, "type")
360
+
361
+
362
+ @pulumi.output_type
363
+ class ErrorAdditionalInfoResponse(dict):
364
+ """
365
+ The resource management error additional info.
366
+ """
367
+ def __init__(__self__, *,
368
+ info: Any,
369
+ type: str):
370
+ """
371
+ The resource management error additional info.
372
+ :param Any info: The additional info.
373
+ :param str type: The additional info type.
374
+ """
375
+ pulumi.set(__self__, "info", info)
376
+ pulumi.set(__self__, "type", type)
377
+
378
+ @property
379
+ @pulumi.getter
380
+ def info(self) -> Any:
381
+ """
382
+ The additional info.
383
+ """
384
+ return pulumi.get(self, "info")
385
+
386
+ @property
387
+ @pulumi.getter
388
+ def type(self) -> str:
389
+ """
390
+ The additional info type.
391
+ """
392
+ return pulumi.get(self, "type")
393
+
394
+
395
+ @pulumi.output_type
396
+ class ErrorDetailResponse(dict):
397
+ """
398
+ The error detail.
399
+ """
400
+ @staticmethod
401
+ def __key_warning(key: str):
402
+ suggest = None
403
+ if key == "additionalInfo":
404
+ suggest = "additional_info"
405
+
406
+ if suggest:
407
+ pulumi.log.warn(f"Key '{key}' not found in ErrorDetailResponse. Access the value via the '{suggest}' property getter instead.")
408
+
409
+ def __getitem__(self, key: str) -> Any:
410
+ ErrorDetailResponse.__key_warning(key)
411
+ return super().__getitem__(key)
412
+
413
+ def get(self, key: str, default = None) -> Any:
414
+ ErrorDetailResponse.__key_warning(key)
415
+ return super().get(key, default)
416
+
417
+ def __init__(__self__, *,
418
+ additional_info: Sequence['outputs.ErrorAdditionalInfoResponse'],
419
+ code: str,
420
+ details: Sequence['outputs.ErrorDetailResponse'],
421
+ message: str,
422
+ target: str):
423
+ """
424
+ The error detail.
425
+ :param Sequence['ErrorAdditionalInfoResponse'] additional_info: The error additional info.
426
+ :param str code: The error code.
427
+ :param Sequence['ErrorDetailResponse'] details: The error details.
428
+ :param str message: The error message.
429
+ :param str target: The error target.
430
+ """
431
+ pulumi.set(__self__, "additional_info", additional_info)
432
+ pulumi.set(__self__, "code", code)
433
+ pulumi.set(__self__, "details", details)
434
+ pulumi.set(__self__, "message", message)
435
+ pulumi.set(__self__, "target", target)
436
+
437
+ @property
438
+ @pulumi.getter(name="additionalInfo")
439
+ def additional_info(self) -> Sequence['outputs.ErrorAdditionalInfoResponse']:
440
+ """
441
+ The error additional info.
442
+ """
443
+ return pulumi.get(self, "additional_info")
444
+
445
+ @property
446
+ @pulumi.getter
447
+ def code(self) -> str:
448
+ """
449
+ The error code.
450
+ """
451
+ return pulumi.get(self, "code")
452
+
453
+ @property
454
+ @pulumi.getter
455
+ def details(self) -> Sequence['outputs.ErrorDetailResponse']:
456
+ """
457
+ The error details.
458
+ """
459
+ return pulumi.get(self, "details")
460
+
461
+ @property
462
+ @pulumi.getter
463
+ def message(self) -> str:
464
+ """
465
+ The error message.
466
+ """
467
+ return pulumi.get(self, "message")
468
+
469
+ @property
470
+ @pulumi.getter
471
+ def target(self) -> str:
472
+ """
473
+ The error target.
474
+ """
475
+ return pulumi.get(self, "target")
476
+
477
+
478
+ @pulumi.output_type
479
+ class EsuKeyResponse(dict):
480
+ """
481
+ ESU key
482
+ """
483
+ @staticmethod
484
+ def __key_warning(key: str):
485
+ suggest = None
486
+ if key == "licenseStatus":
487
+ suggest = "license_status"
488
+
489
+ if suggest:
490
+ pulumi.log.warn(f"Key '{key}' not found in EsuKeyResponse. Access the value via the '{suggest}' property getter instead.")
491
+
492
+ def __getitem__(self, key: str) -> Any:
493
+ EsuKeyResponse.__key_warning(key)
494
+ return super().__getitem__(key)
495
+
496
+ def get(self, key: str, default = None) -> Any:
497
+ EsuKeyResponse.__key_warning(key)
498
+ return super().get(key, default)
499
+
500
+ def __init__(__self__, *,
501
+ license_status: Optional[int] = None,
502
+ sku: Optional[str] = None):
503
+ """
504
+ ESU key
505
+ :param int license_status: The current status of the license profile key. Represented by the same integer value that is presented on the machine itself when querying the license key status.
506
+ :param str sku: SKU number.
507
+ """
508
+ if license_status is not None:
509
+ pulumi.set(__self__, "license_status", license_status)
510
+ if sku is not None:
511
+ pulumi.set(__self__, "sku", sku)
512
+
513
+ @property
514
+ @pulumi.getter(name="licenseStatus")
515
+ def license_status(self) -> Optional[int]:
516
+ """
517
+ The current status of the license profile key. Represented by the same integer value that is presented on the machine itself when querying the license key status.
518
+ """
519
+ return pulumi.get(self, "license_status")
520
+
521
+ @property
522
+ @pulumi.getter
523
+ def sku(self) -> Optional[str]:
524
+ """
525
+ SKU number.
526
+ """
527
+ return pulumi.get(self, "sku")
528
+
529
+
530
+ @pulumi.output_type
531
+ class ExtensionsResourceStatusResponse(dict):
532
+ """
533
+ Instance view status.
534
+ """
535
+ @staticmethod
536
+ def __key_warning(key: str):
537
+ suggest = None
538
+ if key == "displayStatus":
539
+ suggest = "display_status"
540
+
541
+ if suggest:
542
+ pulumi.log.warn(f"Key '{key}' not found in ExtensionsResourceStatusResponse. Access the value via the '{suggest}' property getter instead.")
543
+
544
+ def __getitem__(self, key: str) -> Any:
545
+ ExtensionsResourceStatusResponse.__key_warning(key)
546
+ return super().__getitem__(key)
547
+
548
+ def get(self, key: str, default = None) -> Any:
549
+ ExtensionsResourceStatusResponse.__key_warning(key)
550
+ return super().get(key, default)
551
+
552
+ def __init__(__self__, *,
553
+ code: Optional[str] = None,
554
+ display_status: Optional[str] = None,
555
+ level: Optional[str] = None,
556
+ message: Optional[str] = None,
557
+ time: Optional[str] = None):
558
+ """
559
+ Instance view status.
560
+ :param str code: The status code.
561
+ :param str display_status: The short localizable label for the status.
562
+ :param str level: The level code.
563
+ :param str message: The detailed status message, including for alerts and error messages.
564
+ :param str time: The time of the status.
565
+ """
566
+ if code is not None:
567
+ pulumi.set(__self__, "code", code)
568
+ if display_status is not None:
569
+ pulumi.set(__self__, "display_status", display_status)
570
+ if level is not None:
571
+ pulumi.set(__self__, "level", level)
572
+ if message is not None:
573
+ pulumi.set(__self__, "message", message)
574
+ if time is not None:
575
+ pulumi.set(__self__, "time", time)
576
+
577
+ @property
578
+ @pulumi.getter
579
+ def code(self) -> Optional[str]:
580
+ """
581
+ The status code.
582
+ """
583
+ return pulumi.get(self, "code")
584
+
585
+ @property
586
+ @pulumi.getter(name="displayStatus")
587
+ def display_status(self) -> Optional[str]:
588
+ """
589
+ The short localizable label for the status.
590
+ """
591
+ return pulumi.get(self, "display_status")
592
+
593
+ @property
594
+ @pulumi.getter
595
+ def level(self) -> Optional[str]:
596
+ """
597
+ The level code.
598
+ """
599
+ return pulumi.get(self, "level")
600
+
601
+ @property
602
+ @pulumi.getter
603
+ def message(self) -> Optional[str]:
604
+ """
605
+ The detailed status message, including for alerts and error messages.
606
+ """
607
+ return pulumi.get(self, "message")
608
+
609
+ @property
610
+ @pulumi.getter
611
+ def time(self) -> Optional[str]:
612
+ """
613
+ The time of the status.
614
+ """
615
+ return pulumi.get(self, "time")
616
+
617
+
618
+ @pulumi.output_type
619
+ class HybridComputePrivateLinkScopePropertiesResponse(dict):
620
+ """
621
+ Properties that define a Azure Arc PrivateLinkScope resource.
622
+ """
623
+ @staticmethod
624
+ def __key_warning(key: str):
625
+ suggest = None
626
+ if key == "privateEndpointConnections":
627
+ suggest = "private_endpoint_connections"
628
+ elif key == "privateLinkScopeId":
629
+ suggest = "private_link_scope_id"
630
+ elif key == "provisioningState":
631
+ suggest = "provisioning_state"
632
+ elif key == "publicNetworkAccess":
633
+ suggest = "public_network_access"
634
+
635
+ if suggest:
636
+ pulumi.log.warn(f"Key '{key}' not found in HybridComputePrivateLinkScopePropertiesResponse. Access the value via the '{suggest}' property getter instead.")
637
+
638
+ def __getitem__(self, key: str) -> Any:
639
+ HybridComputePrivateLinkScopePropertiesResponse.__key_warning(key)
640
+ return super().__getitem__(key)
641
+
642
+ def get(self, key: str, default = None) -> Any:
643
+ HybridComputePrivateLinkScopePropertiesResponse.__key_warning(key)
644
+ return super().get(key, default)
645
+
646
+ def __init__(__self__, *,
647
+ private_endpoint_connections: Sequence['outputs.PrivateEndpointConnectionDataModelResponse'],
648
+ private_link_scope_id: str,
649
+ provisioning_state: str,
650
+ public_network_access: Optional[str] = None):
651
+ """
652
+ Properties that define a Azure Arc PrivateLinkScope resource.
653
+ :param Sequence['PrivateEndpointConnectionDataModelResponse'] private_endpoint_connections: The collection of associated Private Endpoint Connections.
654
+ :param str private_link_scope_id: The Guid id of the private link scope.
655
+ :param str provisioning_state: Current state of this PrivateLinkScope: whether or not is has been provisioned within the resource group it is defined. Users cannot change this value but are able to read from it. Values will include Provisioning ,Succeeded, Canceled and Failed.
656
+ :param str public_network_access: Indicates whether machines associated with the private link scope can also use public Azure Arc service endpoints.
657
+ """
658
+ pulumi.set(__self__, "private_endpoint_connections", private_endpoint_connections)
659
+ pulumi.set(__self__, "private_link_scope_id", private_link_scope_id)
660
+ pulumi.set(__self__, "provisioning_state", provisioning_state)
661
+ if public_network_access is not None:
662
+ pulumi.set(__self__, "public_network_access", public_network_access)
663
+
664
+ @property
665
+ @pulumi.getter(name="privateEndpointConnections")
666
+ def private_endpoint_connections(self) -> Sequence['outputs.PrivateEndpointConnectionDataModelResponse']:
667
+ """
668
+ The collection of associated Private Endpoint Connections.
669
+ """
670
+ return pulumi.get(self, "private_endpoint_connections")
671
+
672
+ @property
673
+ @pulumi.getter(name="privateLinkScopeId")
674
+ def private_link_scope_id(self) -> str:
675
+ """
676
+ The Guid id of the private link scope.
677
+ """
678
+ return pulumi.get(self, "private_link_scope_id")
679
+
680
+ @property
681
+ @pulumi.getter(name="provisioningState")
682
+ def provisioning_state(self) -> str:
683
+ """
684
+ Current state of this PrivateLinkScope: whether or not is has been provisioned within the resource group it is defined. Users cannot change this value but are able to read from it. Values will include Provisioning ,Succeeded, Canceled and Failed.
685
+ """
686
+ return pulumi.get(self, "provisioning_state")
687
+
688
+ @property
689
+ @pulumi.getter(name="publicNetworkAccess")
690
+ def public_network_access(self) -> Optional[str]:
691
+ """
692
+ Indicates whether machines associated with the private link scope can also use public Azure Arc service endpoints.
693
+ """
694
+ return pulumi.get(self, "public_network_access")
695
+
696
+
697
+ @pulumi.output_type
698
+ class IdentityResponse(dict):
699
+ """
700
+ Identity for the resource.
701
+ """
702
+ @staticmethod
703
+ def __key_warning(key: str):
704
+ suggest = None
705
+ if key == "principalId":
706
+ suggest = "principal_id"
707
+ elif key == "tenantId":
708
+ suggest = "tenant_id"
709
+
710
+ if suggest:
711
+ pulumi.log.warn(f"Key '{key}' not found in IdentityResponse. Access the value via the '{suggest}' property getter instead.")
712
+
713
+ def __getitem__(self, key: str) -> Any:
714
+ IdentityResponse.__key_warning(key)
715
+ return super().__getitem__(key)
716
+
717
+ def get(self, key: str, default = None) -> Any:
718
+ IdentityResponse.__key_warning(key)
719
+ return super().get(key, default)
720
+
721
+ def __init__(__self__, *,
722
+ principal_id: str,
723
+ tenant_id: str,
724
+ type: Optional[str] = None):
725
+ """
726
+ Identity for the resource.
727
+ :param str principal_id: The principal ID of resource identity.
728
+ :param str tenant_id: The tenant ID of resource.
729
+ :param str type: The identity type.
730
+ """
731
+ pulumi.set(__self__, "principal_id", principal_id)
732
+ pulumi.set(__self__, "tenant_id", tenant_id)
733
+ if type is not None:
734
+ pulumi.set(__self__, "type", type)
735
+
736
+ @property
737
+ @pulumi.getter(name="principalId")
738
+ def principal_id(self) -> str:
739
+ """
740
+ The principal ID of resource identity.
741
+ """
742
+ return pulumi.get(self, "principal_id")
743
+
744
+ @property
745
+ @pulumi.getter(name="tenantId")
746
+ def tenant_id(self) -> str:
747
+ """
748
+ The tenant ID of resource.
749
+ """
750
+ return pulumi.get(self, "tenant_id")
751
+
752
+ @property
753
+ @pulumi.getter
754
+ def type(self) -> Optional[str]:
755
+ """
756
+ The identity type.
757
+ """
758
+ return pulumi.get(self, "type")
759
+
760
+
761
+ @pulumi.output_type
762
+ class IpAddressResponse(dict):
763
+ """
764
+ Describes properties of the IP address.
765
+ """
766
+ @staticmethod
767
+ def __key_warning(key: str):
768
+ suggest = None
769
+ if key == "ipAddressVersion":
770
+ suggest = "ip_address_version"
771
+
772
+ if suggest:
773
+ pulumi.log.warn(f"Key '{key}' not found in IpAddressResponse. Access the value via the '{suggest}' property getter instead.")
774
+
775
+ def __getitem__(self, key: str) -> Any:
776
+ IpAddressResponse.__key_warning(key)
777
+ return super().__getitem__(key)
778
+
779
+ def get(self, key: str, default = None) -> Any:
780
+ IpAddressResponse.__key_warning(key)
781
+ return super().get(key, default)
782
+
783
+ def __init__(__self__, *,
784
+ subnet: 'outputs.SubnetResponse',
785
+ address: Optional[str] = None,
786
+ ip_address_version: Optional[str] = None):
787
+ """
788
+ Describes properties of the IP address.
789
+ :param 'SubnetResponse' subnet: The subnet to which this IP address belongs.
790
+ :param str address: Represents the IP Address.
791
+ :param str ip_address_version: Represents the Ip Address Version.
792
+ """
793
+ pulumi.set(__self__, "subnet", subnet)
794
+ if address is not None:
795
+ pulumi.set(__self__, "address", address)
796
+ if ip_address_version is not None:
797
+ pulumi.set(__self__, "ip_address_version", ip_address_version)
798
+
799
+ @property
800
+ @pulumi.getter
801
+ def subnet(self) -> 'outputs.SubnetResponse':
802
+ """
803
+ The subnet to which this IP address belongs.
804
+ """
805
+ return pulumi.get(self, "subnet")
806
+
807
+ @property
808
+ @pulumi.getter
809
+ def address(self) -> Optional[str]:
810
+ """
811
+ Represents the IP Address.
812
+ """
813
+ return pulumi.get(self, "address")
814
+
815
+ @property
816
+ @pulumi.getter(name="ipAddressVersion")
817
+ def ip_address_version(self) -> Optional[str]:
818
+ """
819
+ Represents the Ip Address Version.
820
+ """
821
+ return pulumi.get(self, "ip_address_version")
822
+
823
+
824
+ @pulumi.output_type
825
+ class LicenseDetailsResponse(dict):
826
+ """
827
+ Describes the properties of a License.
828
+ """
829
+ @staticmethod
830
+ def __key_warning(key: str):
831
+ suggest = None
832
+ if key == "assignedLicenses":
833
+ suggest = "assigned_licenses"
834
+ elif key == "immutableId":
835
+ suggest = "immutable_id"
836
+ elif key == "volumeLicenseDetails":
837
+ suggest = "volume_license_details"
838
+
839
+ if suggest:
840
+ pulumi.log.warn(f"Key '{key}' not found in LicenseDetailsResponse. Access the value via the '{suggest}' property getter instead.")
841
+
842
+ def __getitem__(self, key: str) -> Any:
843
+ LicenseDetailsResponse.__key_warning(key)
844
+ return super().__getitem__(key)
845
+
846
+ def get(self, key: str, default = None) -> Any:
847
+ LicenseDetailsResponse.__key_warning(key)
848
+ return super().get(key, default)
849
+
850
+ def __init__(__self__, *,
851
+ assigned_licenses: int,
852
+ immutable_id: str,
853
+ edition: Optional[str] = None,
854
+ processors: Optional[int] = None,
855
+ state: Optional[str] = None,
856
+ target: Optional[str] = None,
857
+ type: Optional[str] = None,
858
+ volume_license_details: Optional[Sequence['outputs.VolumeLicenseDetailsResponse']] = None):
859
+ """
860
+ Describes the properties of a License.
861
+ :param int assigned_licenses: Describes the number of assigned licenses.
862
+ :param str immutable_id: Describes the immutable id.
863
+ :param str edition: Describes the edition of the license. The values are either Standard or Datacenter.
864
+ :param int processors: Describes the number of processors.
865
+ :param str state: Describes the state of the license.
866
+ :param str target: Describes the license target server.
867
+ :param str type: Describes the license core type (pCore or vCore).
868
+ :param Sequence['VolumeLicenseDetailsResponse'] volume_license_details: A list of volume license details.
869
+ """
870
+ pulumi.set(__self__, "assigned_licenses", assigned_licenses)
871
+ pulumi.set(__self__, "immutable_id", immutable_id)
872
+ if edition is not None:
873
+ pulumi.set(__self__, "edition", edition)
874
+ if processors is not None:
875
+ pulumi.set(__self__, "processors", processors)
876
+ if state is not None:
877
+ pulumi.set(__self__, "state", state)
878
+ if target is not None:
879
+ pulumi.set(__self__, "target", target)
880
+ if type is not None:
881
+ pulumi.set(__self__, "type", type)
882
+ if volume_license_details is not None:
883
+ pulumi.set(__self__, "volume_license_details", volume_license_details)
884
+
885
+ @property
886
+ @pulumi.getter(name="assignedLicenses")
887
+ def assigned_licenses(self) -> int:
888
+ """
889
+ Describes the number of assigned licenses.
890
+ """
891
+ return pulumi.get(self, "assigned_licenses")
892
+
893
+ @property
894
+ @pulumi.getter(name="immutableId")
895
+ def immutable_id(self) -> str:
896
+ """
897
+ Describes the immutable id.
898
+ """
899
+ return pulumi.get(self, "immutable_id")
900
+
901
+ @property
902
+ @pulumi.getter
903
+ def edition(self) -> Optional[str]:
904
+ """
905
+ Describes the edition of the license. The values are either Standard or Datacenter.
906
+ """
907
+ return pulumi.get(self, "edition")
908
+
909
+ @property
910
+ @pulumi.getter
911
+ def processors(self) -> Optional[int]:
912
+ """
913
+ Describes the number of processors.
914
+ """
915
+ return pulumi.get(self, "processors")
916
+
917
+ @property
918
+ @pulumi.getter
919
+ def state(self) -> Optional[str]:
920
+ """
921
+ Describes the state of the license.
922
+ """
923
+ return pulumi.get(self, "state")
924
+
925
+ @property
926
+ @pulumi.getter
927
+ def target(self) -> Optional[str]:
928
+ """
929
+ Describes the license target server.
930
+ """
931
+ return pulumi.get(self, "target")
932
+
933
+ @property
934
+ @pulumi.getter
935
+ def type(self) -> Optional[str]:
936
+ """
937
+ Describes the license core type (pCore or vCore).
938
+ """
939
+ return pulumi.get(self, "type")
940
+
941
+ @property
942
+ @pulumi.getter(name="volumeLicenseDetails")
943
+ def volume_license_details(self) -> Optional[Sequence['outputs.VolumeLicenseDetailsResponse']]:
944
+ """
945
+ A list of volume license details.
946
+ """
947
+ return pulumi.get(self, "volume_license_details")
948
+
949
+
950
+ @pulumi.output_type
951
+ class LicenseProfileMachineInstanceViewEsuPropertiesResponse(dict):
952
+ """
953
+ Properties for the Machine ESU profile.
954
+ """
955
+ @staticmethod
956
+ def __key_warning(key: str):
957
+ suggest = None
958
+ if key == "assignedLicenseImmutableId":
959
+ suggest = "assigned_license_immutable_id"
960
+ elif key == "esuEligibility":
961
+ suggest = "esu_eligibility"
962
+ elif key == "esuKeyState":
963
+ suggest = "esu_key_state"
964
+ elif key == "esuKeys":
965
+ suggest = "esu_keys"
966
+ elif key == "serverType":
967
+ suggest = "server_type"
968
+ elif key == "assignedLicense":
969
+ suggest = "assigned_license"
970
+ elif key == "licenseAssignmentState":
971
+ suggest = "license_assignment_state"
972
+
973
+ if suggest:
974
+ pulumi.log.warn(f"Key '{key}' not found in LicenseProfileMachineInstanceViewEsuPropertiesResponse. Access the value via the '{suggest}' property getter instead.")
975
+
976
+ def __getitem__(self, key: str) -> Any:
977
+ LicenseProfileMachineInstanceViewEsuPropertiesResponse.__key_warning(key)
978
+ return super().__getitem__(key)
979
+
980
+ def get(self, key: str, default = None) -> Any:
981
+ LicenseProfileMachineInstanceViewEsuPropertiesResponse.__key_warning(key)
982
+ return super().get(key, default)
983
+
984
+ def __init__(__self__, *,
985
+ assigned_license_immutable_id: str,
986
+ esu_eligibility: str,
987
+ esu_key_state: str,
988
+ esu_keys: Sequence['outputs.EsuKeyResponse'],
989
+ server_type: str,
990
+ assigned_license: Optional['outputs.LicenseResponse'] = None,
991
+ license_assignment_state: Optional[str] = None):
992
+ """
993
+ Properties for the Machine ESU profile.
994
+ :param str assigned_license_immutable_id: The guid id of the license.
995
+ :param str esu_eligibility: Indicates the eligibility state of Esu.
996
+ :param str esu_key_state: Indicates whether there is an ESU Key currently active for the machine.
997
+ :param Sequence['EsuKeyResponse'] esu_keys: The list of ESU keys.
998
+ :param str server_type: The type of the Esu servers.
999
+ :param 'LicenseResponse' assigned_license: The assigned license resource.
1000
+ :param str license_assignment_state: Describes the license assignment state (Assigned or NotAssigned).
1001
+ """
1002
+ pulumi.set(__self__, "assigned_license_immutable_id", assigned_license_immutable_id)
1003
+ pulumi.set(__self__, "esu_eligibility", esu_eligibility)
1004
+ pulumi.set(__self__, "esu_key_state", esu_key_state)
1005
+ pulumi.set(__self__, "esu_keys", esu_keys)
1006
+ pulumi.set(__self__, "server_type", server_type)
1007
+ if assigned_license is not None:
1008
+ pulumi.set(__self__, "assigned_license", assigned_license)
1009
+ if license_assignment_state is not None:
1010
+ pulumi.set(__self__, "license_assignment_state", license_assignment_state)
1011
+
1012
+ @property
1013
+ @pulumi.getter(name="assignedLicenseImmutableId")
1014
+ def assigned_license_immutable_id(self) -> str:
1015
+ """
1016
+ The guid id of the license.
1017
+ """
1018
+ return pulumi.get(self, "assigned_license_immutable_id")
1019
+
1020
+ @property
1021
+ @pulumi.getter(name="esuEligibility")
1022
+ def esu_eligibility(self) -> str:
1023
+ """
1024
+ Indicates the eligibility state of Esu.
1025
+ """
1026
+ return pulumi.get(self, "esu_eligibility")
1027
+
1028
+ @property
1029
+ @pulumi.getter(name="esuKeyState")
1030
+ def esu_key_state(self) -> str:
1031
+ """
1032
+ Indicates whether there is an ESU Key currently active for the machine.
1033
+ """
1034
+ return pulumi.get(self, "esu_key_state")
1035
+
1036
+ @property
1037
+ @pulumi.getter(name="esuKeys")
1038
+ def esu_keys(self) -> Sequence['outputs.EsuKeyResponse']:
1039
+ """
1040
+ The list of ESU keys.
1041
+ """
1042
+ return pulumi.get(self, "esu_keys")
1043
+
1044
+ @property
1045
+ @pulumi.getter(name="serverType")
1046
+ def server_type(self) -> str:
1047
+ """
1048
+ The type of the Esu servers.
1049
+ """
1050
+ return pulumi.get(self, "server_type")
1051
+
1052
+ @property
1053
+ @pulumi.getter(name="assignedLicense")
1054
+ def assigned_license(self) -> Optional['outputs.LicenseResponse']:
1055
+ """
1056
+ The assigned license resource.
1057
+ """
1058
+ return pulumi.get(self, "assigned_license")
1059
+
1060
+ @property
1061
+ @pulumi.getter(name="licenseAssignmentState")
1062
+ def license_assignment_state(self) -> Optional[str]:
1063
+ """
1064
+ Describes the license assignment state (Assigned or NotAssigned).
1065
+ """
1066
+ return pulumi.get(self, "license_assignment_state")
1067
+
1068
+
1069
+ @pulumi.output_type
1070
+ class LicenseProfileMachineInstanceViewResponse(dict):
1071
+ """
1072
+ License Profile Instance View in Machine Properties.
1073
+ """
1074
+ @staticmethod
1075
+ def __key_warning(key: str):
1076
+ suggest = None
1077
+ if key == "billingEndDate":
1078
+ suggest = "billing_end_date"
1079
+ elif key == "billingStartDate":
1080
+ suggest = "billing_start_date"
1081
+ elif key == "disenrollmentDate":
1082
+ suggest = "disenrollment_date"
1083
+ elif key == "enrollmentDate":
1084
+ suggest = "enrollment_date"
1085
+ elif key == "licenseChannel":
1086
+ suggest = "license_channel"
1087
+ elif key == "licenseStatus":
1088
+ suggest = "license_status"
1089
+ elif key == "esuProfile":
1090
+ suggest = "esu_profile"
1091
+ elif key == "productFeatures":
1092
+ suggest = "product_features"
1093
+ elif key == "productType":
1094
+ suggest = "product_type"
1095
+ elif key == "softwareAssuranceCustomer":
1096
+ suggest = "software_assurance_customer"
1097
+ elif key == "subscriptionStatus":
1098
+ suggest = "subscription_status"
1099
+
1100
+ if suggest:
1101
+ pulumi.log.warn(f"Key '{key}' not found in LicenseProfileMachineInstanceViewResponse. Access the value via the '{suggest}' property getter instead.")
1102
+
1103
+ def __getitem__(self, key: str) -> Any:
1104
+ LicenseProfileMachineInstanceViewResponse.__key_warning(key)
1105
+ return super().__getitem__(key)
1106
+
1107
+ def get(self, key: str, default = None) -> Any:
1108
+ LicenseProfileMachineInstanceViewResponse.__key_warning(key)
1109
+ return super().get(key, default)
1110
+
1111
+ def __init__(__self__, *,
1112
+ billing_end_date: str,
1113
+ billing_start_date: str,
1114
+ disenrollment_date: str,
1115
+ enrollment_date: str,
1116
+ error: 'outputs.ErrorDetailResponse',
1117
+ license_channel: str,
1118
+ license_status: str,
1119
+ esu_profile: Optional['outputs.LicenseProfileMachineInstanceViewEsuPropertiesResponse'] = None,
1120
+ product_features: Optional[Sequence['outputs.ProductFeatureResponse']] = None,
1121
+ product_type: Optional[str] = None,
1122
+ software_assurance_customer: Optional[bool] = None,
1123
+ subscription_status: Optional[str] = None):
1124
+ """
1125
+ License Profile Instance View in Machine Properties.
1126
+ :param str billing_end_date: The timestamp in UTC when the billing ends.
1127
+ :param str billing_start_date: The timestamp in UTC when the billing starts.
1128
+ :param str disenrollment_date: The timestamp in UTC when the user disenrolled the feature.
1129
+ :param str enrollment_date: The timestamp in UTC when the user enrolls the feature.
1130
+ :param 'ErrorDetailResponse' error: The errors that were encountered during the feature enrollment or disenrollment.
1131
+ :param str license_channel: Indicates the license channel.
1132
+ :param str license_status: Indicates the license status of the OS.
1133
+ :param 'LicenseProfileMachineInstanceViewEsuPropertiesResponse' esu_profile: Properties for the Machine ESU profile.
1134
+ :param Sequence['ProductFeatureResponse'] product_features: The list of product features.
1135
+ :param str product_type: Indicates the product type of the license.
1136
+ :param bool software_assurance_customer: Specifies if this machine is licensed as part of a Software Assurance agreement.
1137
+ :param str subscription_status: Indicates the subscription status of the product.
1138
+ """
1139
+ pulumi.set(__self__, "billing_end_date", billing_end_date)
1140
+ pulumi.set(__self__, "billing_start_date", billing_start_date)
1141
+ pulumi.set(__self__, "disenrollment_date", disenrollment_date)
1142
+ pulumi.set(__self__, "enrollment_date", enrollment_date)
1143
+ pulumi.set(__self__, "error", error)
1144
+ pulumi.set(__self__, "license_channel", license_channel)
1145
+ pulumi.set(__self__, "license_status", license_status)
1146
+ if esu_profile is not None:
1147
+ pulumi.set(__self__, "esu_profile", esu_profile)
1148
+ if product_features is not None:
1149
+ pulumi.set(__self__, "product_features", product_features)
1150
+ if product_type is not None:
1151
+ pulumi.set(__self__, "product_type", product_type)
1152
+ if software_assurance_customer is not None:
1153
+ pulumi.set(__self__, "software_assurance_customer", software_assurance_customer)
1154
+ if subscription_status is not None:
1155
+ pulumi.set(__self__, "subscription_status", subscription_status)
1156
+
1157
+ @property
1158
+ @pulumi.getter(name="billingEndDate")
1159
+ def billing_end_date(self) -> str:
1160
+ """
1161
+ The timestamp in UTC when the billing ends.
1162
+ """
1163
+ return pulumi.get(self, "billing_end_date")
1164
+
1165
+ @property
1166
+ @pulumi.getter(name="billingStartDate")
1167
+ def billing_start_date(self) -> str:
1168
+ """
1169
+ The timestamp in UTC when the billing starts.
1170
+ """
1171
+ return pulumi.get(self, "billing_start_date")
1172
+
1173
+ @property
1174
+ @pulumi.getter(name="disenrollmentDate")
1175
+ def disenrollment_date(self) -> str:
1176
+ """
1177
+ The timestamp in UTC when the user disenrolled the feature.
1178
+ """
1179
+ return pulumi.get(self, "disenrollment_date")
1180
+
1181
+ @property
1182
+ @pulumi.getter(name="enrollmentDate")
1183
+ def enrollment_date(self) -> str:
1184
+ """
1185
+ The timestamp in UTC when the user enrolls the feature.
1186
+ """
1187
+ return pulumi.get(self, "enrollment_date")
1188
+
1189
+ @property
1190
+ @pulumi.getter
1191
+ def error(self) -> 'outputs.ErrorDetailResponse':
1192
+ """
1193
+ The errors that were encountered during the feature enrollment or disenrollment.
1194
+ """
1195
+ return pulumi.get(self, "error")
1196
+
1197
+ @property
1198
+ @pulumi.getter(name="licenseChannel")
1199
+ def license_channel(self) -> str:
1200
+ """
1201
+ Indicates the license channel.
1202
+ """
1203
+ return pulumi.get(self, "license_channel")
1204
+
1205
+ @property
1206
+ @pulumi.getter(name="licenseStatus")
1207
+ def license_status(self) -> str:
1208
+ """
1209
+ Indicates the license status of the OS.
1210
+ """
1211
+ return pulumi.get(self, "license_status")
1212
+
1213
+ @property
1214
+ @pulumi.getter(name="esuProfile")
1215
+ def esu_profile(self) -> Optional['outputs.LicenseProfileMachineInstanceViewEsuPropertiesResponse']:
1216
+ """
1217
+ Properties for the Machine ESU profile.
1218
+ """
1219
+ return pulumi.get(self, "esu_profile")
1220
+
1221
+ @property
1222
+ @pulumi.getter(name="productFeatures")
1223
+ def product_features(self) -> Optional[Sequence['outputs.ProductFeatureResponse']]:
1224
+ """
1225
+ The list of product features.
1226
+ """
1227
+ return pulumi.get(self, "product_features")
1228
+
1229
+ @property
1230
+ @pulumi.getter(name="productType")
1231
+ def product_type(self) -> Optional[str]:
1232
+ """
1233
+ Indicates the product type of the license.
1234
+ """
1235
+ return pulumi.get(self, "product_type")
1236
+
1237
+ @property
1238
+ @pulumi.getter(name="softwareAssuranceCustomer")
1239
+ def software_assurance_customer(self) -> Optional[bool]:
1240
+ """
1241
+ Specifies if this machine is licensed as part of a Software Assurance agreement.
1242
+ """
1243
+ return pulumi.get(self, "software_assurance_customer")
1244
+
1245
+ @property
1246
+ @pulumi.getter(name="subscriptionStatus")
1247
+ def subscription_status(self) -> Optional[str]:
1248
+ """
1249
+ Indicates the subscription status of the product.
1250
+ """
1251
+ return pulumi.get(self, "subscription_status")
1252
+
1253
+
1254
+ @pulumi.output_type
1255
+ class LicenseResponse(dict):
1256
+ """
1257
+ Describes a license in a hybrid machine.
1258
+ """
1259
+ @staticmethod
1260
+ def __key_warning(key: str):
1261
+ suggest = None
1262
+ if key == "provisioningState":
1263
+ suggest = "provisioning_state"
1264
+ elif key == "systemData":
1265
+ suggest = "system_data"
1266
+ elif key == "licenseDetails":
1267
+ suggest = "license_details"
1268
+ elif key == "licenseType":
1269
+ suggest = "license_type"
1270
+ elif key == "tenantId":
1271
+ suggest = "tenant_id"
1272
+
1273
+ if suggest:
1274
+ pulumi.log.warn(f"Key '{key}' not found in LicenseResponse. Access the value via the '{suggest}' property getter instead.")
1275
+
1276
+ def __getitem__(self, key: str) -> Any:
1277
+ LicenseResponse.__key_warning(key)
1278
+ return super().__getitem__(key)
1279
+
1280
+ def get(self, key: str, default = None) -> Any:
1281
+ LicenseResponse.__key_warning(key)
1282
+ return super().get(key, default)
1283
+
1284
+ def __init__(__self__, *,
1285
+ id: str,
1286
+ location: str,
1287
+ name: str,
1288
+ provisioning_state: str,
1289
+ system_data: 'outputs.SystemDataResponse',
1290
+ type: str,
1291
+ license_details: Optional['outputs.LicenseDetailsResponse'] = None,
1292
+ license_type: Optional[str] = None,
1293
+ tags: Optional[Mapping[str, str]] = None,
1294
+ tenant_id: Optional[str] = None):
1295
+ """
1296
+ Describes a license in a hybrid machine.
1297
+ :param str id: Fully qualified resource ID for the resource. Ex - /subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/{resourceProviderNamespace}/{resourceType}/{resourceName}
1298
+ :param str location: The geo-location where the resource lives
1299
+ :param str name: The name of the resource
1300
+ :param str provisioning_state: The provisioning state, which only appears in the response.
1301
+ :param 'SystemDataResponse' system_data: Azure Resource Manager metadata containing createdBy and modifiedBy information.
1302
+ :param str type: The type of the resource. E.g. "Microsoft.Compute/virtualMachines" or "Microsoft.Storage/storageAccounts"
1303
+ :param 'LicenseDetailsResponse' license_details: Describes the properties of a License.
1304
+ :param str license_type: The type of the license resource.
1305
+ :param Mapping[str, str] tags: Resource tags.
1306
+ :param str tenant_id: Describes the tenant id.
1307
+ """
1308
+ pulumi.set(__self__, "id", id)
1309
+ pulumi.set(__self__, "location", location)
1310
+ pulumi.set(__self__, "name", name)
1311
+ pulumi.set(__self__, "provisioning_state", provisioning_state)
1312
+ pulumi.set(__self__, "system_data", system_data)
1313
+ pulumi.set(__self__, "type", type)
1314
+ if license_details is not None:
1315
+ pulumi.set(__self__, "license_details", license_details)
1316
+ if license_type is not None:
1317
+ pulumi.set(__self__, "license_type", license_type)
1318
+ if tags is not None:
1319
+ pulumi.set(__self__, "tags", tags)
1320
+ if tenant_id is not None:
1321
+ pulumi.set(__self__, "tenant_id", tenant_id)
1322
+
1323
+ @property
1324
+ @pulumi.getter
1325
+ def id(self) -> str:
1326
+ """
1327
+ Fully qualified resource ID for the resource. Ex - /subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/{resourceProviderNamespace}/{resourceType}/{resourceName}
1328
+ """
1329
+ return pulumi.get(self, "id")
1330
+
1331
+ @property
1332
+ @pulumi.getter
1333
+ def location(self) -> str:
1334
+ """
1335
+ The geo-location where the resource lives
1336
+ """
1337
+ return pulumi.get(self, "location")
1338
+
1339
+ @property
1340
+ @pulumi.getter
1341
+ def name(self) -> str:
1342
+ """
1343
+ The name of the resource
1344
+ """
1345
+ return pulumi.get(self, "name")
1346
+
1347
+ @property
1348
+ @pulumi.getter(name="provisioningState")
1349
+ def provisioning_state(self) -> str:
1350
+ """
1351
+ The provisioning state, which only appears in the response.
1352
+ """
1353
+ return pulumi.get(self, "provisioning_state")
1354
+
1355
+ @property
1356
+ @pulumi.getter(name="systemData")
1357
+ def system_data(self) -> 'outputs.SystemDataResponse':
1358
+ """
1359
+ Azure Resource Manager metadata containing createdBy and modifiedBy information.
1360
+ """
1361
+ return pulumi.get(self, "system_data")
1362
+
1363
+ @property
1364
+ @pulumi.getter
1365
+ def type(self) -> str:
1366
+ """
1367
+ The type of the resource. E.g. "Microsoft.Compute/virtualMachines" or "Microsoft.Storage/storageAccounts"
1368
+ """
1369
+ return pulumi.get(self, "type")
1370
+
1371
+ @property
1372
+ @pulumi.getter(name="licenseDetails")
1373
+ def license_details(self) -> Optional['outputs.LicenseDetailsResponse']:
1374
+ """
1375
+ Describes the properties of a License.
1376
+ """
1377
+ return pulumi.get(self, "license_details")
1378
+
1379
+ @property
1380
+ @pulumi.getter(name="licenseType")
1381
+ def license_type(self) -> Optional[str]:
1382
+ """
1383
+ The type of the license resource.
1384
+ """
1385
+ return pulumi.get(self, "license_type")
1386
+
1387
+ @property
1388
+ @pulumi.getter
1389
+ def tags(self) -> Optional[Mapping[str, str]]:
1390
+ """
1391
+ Resource tags.
1392
+ """
1393
+ return pulumi.get(self, "tags")
1394
+
1395
+ @property
1396
+ @pulumi.getter(name="tenantId")
1397
+ def tenant_id(self) -> Optional[str]:
1398
+ """
1399
+ Describes the tenant id.
1400
+ """
1401
+ return pulumi.get(self, "tenant_id")
1402
+
1403
+
1404
+ @pulumi.output_type
1405
+ class LocationDataResponse(dict):
1406
+ """
1407
+ Metadata pertaining to the geographic location of the resource.
1408
+ """
1409
+ @staticmethod
1410
+ def __key_warning(key: str):
1411
+ suggest = None
1412
+ if key == "countryOrRegion":
1413
+ suggest = "country_or_region"
1414
+
1415
+ if suggest:
1416
+ pulumi.log.warn(f"Key '{key}' not found in LocationDataResponse. Access the value via the '{suggest}' property getter instead.")
1417
+
1418
+ def __getitem__(self, key: str) -> Any:
1419
+ LocationDataResponse.__key_warning(key)
1420
+ return super().__getitem__(key)
1421
+
1422
+ def get(self, key: str, default = None) -> Any:
1423
+ LocationDataResponse.__key_warning(key)
1424
+ return super().get(key, default)
1425
+
1426
+ def __init__(__self__, *,
1427
+ name: str,
1428
+ city: Optional[str] = None,
1429
+ country_or_region: Optional[str] = None,
1430
+ district: Optional[str] = None):
1431
+ """
1432
+ Metadata pertaining to the geographic location of the resource.
1433
+ :param str name: A canonical name for the geographic or physical location.
1434
+ :param str city: The city or locality where the resource is located.
1435
+ :param str country_or_region: The country or region where the resource is located
1436
+ :param str district: The district, state, or province where the resource is located.
1437
+ """
1438
+ pulumi.set(__self__, "name", name)
1439
+ if city is not None:
1440
+ pulumi.set(__self__, "city", city)
1441
+ if country_or_region is not None:
1442
+ pulumi.set(__self__, "country_or_region", country_or_region)
1443
+ if district is not None:
1444
+ pulumi.set(__self__, "district", district)
1445
+
1446
+ @property
1447
+ @pulumi.getter
1448
+ def name(self) -> str:
1449
+ """
1450
+ A canonical name for the geographic or physical location.
1451
+ """
1452
+ return pulumi.get(self, "name")
1453
+
1454
+ @property
1455
+ @pulumi.getter
1456
+ def city(self) -> Optional[str]:
1457
+ """
1458
+ The city or locality where the resource is located.
1459
+ """
1460
+ return pulumi.get(self, "city")
1461
+
1462
+ @property
1463
+ @pulumi.getter(name="countryOrRegion")
1464
+ def country_or_region(self) -> Optional[str]:
1465
+ """
1466
+ The country or region where the resource is located
1467
+ """
1468
+ return pulumi.get(self, "country_or_region")
1469
+
1470
+ @property
1471
+ @pulumi.getter
1472
+ def district(self) -> Optional[str]:
1473
+ """
1474
+ The district, state, or province where the resource is located.
1475
+ """
1476
+ return pulumi.get(self, "district")
1477
+
1478
+
1479
+ @pulumi.output_type
1480
+ class MachineExtensionInstanceViewResponse(dict):
1481
+ """
1482
+ Describes the Machine Extension Instance View.
1483
+ """
1484
+ @staticmethod
1485
+ def __key_warning(key: str):
1486
+ suggest = None
1487
+ if key == "typeHandlerVersion":
1488
+ suggest = "type_handler_version"
1489
+
1490
+ if suggest:
1491
+ pulumi.log.warn(f"Key '{key}' not found in MachineExtensionInstanceViewResponse. Access the value via the '{suggest}' property getter instead.")
1492
+
1493
+ def __getitem__(self, key: str) -> Any:
1494
+ MachineExtensionInstanceViewResponse.__key_warning(key)
1495
+ return super().__getitem__(key)
1496
+
1497
+ def get(self, key: str, default = None) -> Any:
1498
+ MachineExtensionInstanceViewResponse.__key_warning(key)
1499
+ return super().get(key, default)
1500
+
1501
+ def __init__(__self__, *,
1502
+ name: Optional[str] = None,
1503
+ status: Optional['outputs.MachineExtensionInstanceViewResponseStatus'] = None,
1504
+ type: Optional[str] = None,
1505
+ type_handler_version: Optional[str] = None):
1506
+ """
1507
+ Describes the Machine Extension Instance View.
1508
+ :param str name: The machine extension name.
1509
+ :param 'MachineExtensionInstanceViewResponseStatus' status: Instance view status.
1510
+ :param str type: Specifies the type of the extension; an example is "CustomScriptExtension".
1511
+ :param str type_handler_version: Specifies the version of the script handler.
1512
+ """
1513
+ if name is not None:
1514
+ pulumi.set(__self__, "name", name)
1515
+ if status is not None:
1516
+ pulumi.set(__self__, "status", status)
1517
+ if type is not None:
1518
+ pulumi.set(__self__, "type", type)
1519
+ if type_handler_version is not None:
1520
+ pulumi.set(__self__, "type_handler_version", type_handler_version)
1521
+
1522
+ @property
1523
+ @pulumi.getter
1524
+ def name(self) -> Optional[str]:
1525
+ """
1526
+ The machine extension name.
1527
+ """
1528
+ return pulumi.get(self, "name")
1529
+
1530
+ @property
1531
+ @pulumi.getter
1532
+ def status(self) -> Optional['outputs.MachineExtensionInstanceViewResponseStatus']:
1533
+ """
1534
+ Instance view status.
1535
+ """
1536
+ return pulumi.get(self, "status")
1537
+
1538
+ @property
1539
+ @pulumi.getter
1540
+ def type(self) -> Optional[str]:
1541
+ """
1542
+ Specifies the type of the extension; an example is "CustomScriptExtension".
1543
+ """
1544
+ return pulumi.get(self, "type")
1545
+
1546
+ @property
1547
+ @pulumi.getter(name="typeHandlerVersion")
1548
+ def type_handler_version(self) -> Optional[str]:
1549
+ """
1550
+ Specifies the version of the script handler.
1551
+ """
1552
+ return pulumi.get(self, "type_handler_version")
1553
+
1554
+
1555
+ @pulumi.output_type
1556
+ class MachineExtensionInstanceViewResponseStatus(dict):
1557
+ """
1558
+ Instance view status.
1559
+ """
1560
+ @staticmethod
1561
+ def __key_warning(key: str):
1562
+ suggest = None
1563
+ if key == "displayStatus":
1564
+ suggest = "display_status"
1565
+
1566
+ if suggest:
1567
+ pulumi.log.warn(f"Key '{key}' not found in MachineExtensionInstanceViewResponseStatus. Access the value via the '{suggest}' property getter instead.")
1568
+
1569
+ def __getitem__(self, key: str) -> Any:
1570
+ MachineExtensionInstanceViewResponseStatus.__key_warning(key)
1571
+ return super().__getitem__(key)
1572
+
1573
+ def get(self, key: str, default = None) -> Any:
1574
+ MachineExtensionInstanceViewResponseStatus.__key_warning(key)
1575
+ return super().get(key, default)
1576
+
1577
+ def __init__(__self__, *,
1578
+ code: Optional[str] = None,
1579
+ display_status: Optional[str] = None,
1580
+ level: Optional[str] = None,
1581
+ message: Optional[str] = None,
1582
+ time: Optional[str] = None):
1583
+ """
1584
+ Instance view status.
1585
+ :param str code: The status code.
1586
+ :param str display_status: The short localizable label for the status.
1587
+ :param str level: The level code.
1588
+ :param str message: The detailed status message, including for alerts and error messages.
1589
+ :param str time: The time of the status.
1590
+ """
1591
+ if code is not None:
1592
+ pulumi.set(__self__, "code", code)
1593
+ if display_status is not None:
1594
+ pulumi.set(__self__, "display_status", display_status)
1595
+ if level is not None:
1596
+ pulumi.set(__self__, "level", level)
1597
+ if message is not None:
1598
+ pulumi.set(__self__, "message", message)
1599
+ if time is not None:
1600
+ pulumi.set(__self__, "time", time)
1601
+
1602
+ @property
1603
+ @pulumi.getter
1604
+ def code(self) -> Optional[str]:
1605
+ """
1606
+ The status code.
1607
+ """
1608
+ return pulumi.get(self, "code")
1609
+
1610
+ @property
1611
+ @pulumi.getter(name="displayStatus")
1612
+ def display_status(self) -> Optional[str]:
1613
+ """
1614
+ The short localizable label for the status.
1615
+ """
1616
+ return pulumi.get(self, "display_status")
1617
+
1618
+ @property
1619
+ @pulumi.getter
1620
+ def level(self) -> Optional[str]:
1621
+ """
1622
+ The level code.
1623
+ """
1624
+ return pulumi.get(self, "level")
1625
+
1626
+ @property
1627
+ @pulumi.getter
1628
+ def message(self) -> Optional[str]:
1629
+ """
1630
+ The detailed status message, including for alerts and error messages.
1631
+ """
1632
+ return pulumi.get(self, "message")
1633
+
1634
+ @property
1635
+ @pulumi.getter
1636
+ def time(self) -> Optional[str]:
1637
+ """
1638
+ The time of the status.
1639
+ """
1640
+ return pulumi.get(self, "time")
1641
+
1642
+
1643
+ @pulumi.output_type
1644
+ class MachineExtensionPropertiesResponse(dict):
1645
+ """
1646
+ Describes the properties of a Machine Extension.
1647
+ """
1648
+ @staticmethod
1649
+ def __key_warning(key: str):
1650
+ suggest = None
1651
+ if key == "provisioningState":
1652
+ suggest = "provisioning_state"
1653
+ elif key == "autoUpgradeMinorVersion":
1654
+ suggest = "auto_upgrade_minor_version"
1655
+ elif key == "enableAutomaticUpgrade":
1656
+ suggest = "enable_automatic_upgrade"
1657
+ elif key == "forceUpdateTag":
1658
+ suggest = "force_update_tag"
1659
+ elif key == "instanceView":
1660
+ suggest = "instance_view"
1661
+ elif key == "protectedSettings":
1662
+ suggest = "protected_settings"
1663
+ elif key == "typeHandlerVersion":
1664
+ suggest = "type_handler_version"
1665
+
1666
+ if suggest:
1667
+ pulumi.log.warn(f"Key '{key}' not found in MachineExtensionPropertiesResponse. Access the value via the '{suggest}' property getter instead.")
1668
+
1669
+ def __getitem__(self, key: str) -> Any:
1670
+ MachineExtensionPropertiesResponse.__key_warning(key)
1671
+ return super().__getitem__(key)
1672
+
1673
+ def get(self, key: str, default = None) -> Any:
1674
+ MachineExtensionPropertiesResponse.__key_warning(key)
1675
+ return super().get(key, default)
1676
+
1677
+ def __init__(__self__, *,
1678
+ provisioning_state: str,
1679
+ auto_upgrade_minor_version: Optional[bool] = None,
1680
+ enable_automatic_upgrade: Optional[bool] = None,
1681
+ force_update_tag: Optional[str] = None,
1682
+ instance_view: Optional['outputs.MachineExtensionInstanceViewResponse'] = None,
1683
+ protected_settings: Optional[Any] = None,
1684
+ publisher: Optional[str] = None,
1685
+ settings: Optional[Any] = None,
1686
+ type: Optional[str] = None,
1687
+ type_handler_version: Optional[str] = None):
1688
+ """
1689
+ Describes the properties of a Machine Extension.
1690
+ :param str provisioning_state: The provisioning state, which only appears in the response.
1691
+ :param bool auto_upgrade_minor_version: Indicates whether the extension should use a newer minor version if one is available at deployment time. Once deployed, however, the extension will not upgrade minor versions unless redeployed, even with this property set to true.
1692
+ :param bool enable_automatic_upgrade: Indicates whether the extension should be automatically upgraded by the platform if there is a newer version available.
1693
+ :param str force_update_tag: How the extension handler should be forced to update even if the extension configuration has not changed.
1694
+ :param 'MachineExtensionInstanceViewResponse' instance_view: The machine extension instance view.
1695
+ :param Any protected_settings: The extension can contain either protectedSettings or protectedSettingsFromKeyVault or no protected settings at all.
1696
+ :param str publisher: The name of the extension handler publisher.
1697
+ :param Any settings: Json formatted public settings for the extension.
1698
+ :param str type: Specifies the type of the extension; an example is "CustomScriptExtension".
1699
+ :param str type_handler_version: Specifies the version of the script handler.
1700
+ """
1701
+ pulumi.set(__self__, "provisioning_state", provisioning_state)
1702
+ if auto_upgrade_minor_version is not None:
1703
+ pulumi.set(__self__, "auto_upgrade_minor_version", auto_upgrade_minor_version)
1704
+ if enable_automatic_upgrade is not None:
1705
+ pulumi.set(__self__, "enable_automatic_upgrade", enable_automatic_upgrade)
1706
+ if force_update_tag is not None:
1707
+ pulumi.set(__self__, "force_update_tag", force_update_tag)
1708
+ if instance_view is not None:
1709
+ pulumi.set(__self__, "instance_view", instance_view)
1710
+ if protected_settings is not None:
1711
+ pulumi.set(__self__, "protected_settings", protected_settings)
1712
+ if publisher is not None:
1713
+ pulumi.set(__self__, "publisher", publisher)
1714
+ if settings is not None:
1715
+ pulumi.set(__self__, "settings", settings)
1716
+ if type is not None:
1717
+ pulumi.set(__self__, "type", type)
1718
+ if type_handler_version is not None:
1719
+ pulumi.set(__self__, "type_handler_version", type_handler_version)
1720
+
1721
+ @property
1722
+ @pulumi.getter(name="provisioningState")
1723
+ def provisioning_state(self) -> str:
1724
+ """
1725
+ The provisioning state, which only appears in the response.
1726
+ """
1727
+ return pulumi.get(self, "provisioning_state")
1728
+
1729
+ @property
1730
+ @pulumi.getter(name="autoUpgradeMinorVersion")
1731
+ def auto_upgrade_minor_version(self) -> Optional[bool]:
1732
+ """
1733
+ Indicates whether the extension should use a newer minor version if one is available at deployment time. Once deployed, however, the extension will not upgrade minor versions unless redeployed, even with this property set to true.
1734
+ """
1735
+ return pulumi.get(self, "auto_upgrade_minor_version")
1736
+
1737
+ @property
1738
+ @pulumi.getter(name="enableAutomaticUpgrade")
1739
+ def enable_automatic_upgrade(self) -> Optional[bool]:
1740
+ """
1741
+ Indicates whether the extension should be automatically upgraded by the platform if there is a newer version available.
1742
+ """
1743
+ return pulumi.get(self, "enable_automatic_upgrade")
1744
+
1745
+ @property
1746
+ @pulumi.getter(name="forceUpdateTag")
1747
+ def force_update_tag(self) -> Optional[str]:
1748
+ """
1749
+ How the extension handler should be forced to update even if the extension configuration has not changed.
1750
+ """
1751
+ return pulumi.get(self, "force_update_tag")
1752
+
1753
+ @property
1754
+ @pulumi.getter(name="instanceView")
1755
+ def instance_view(self) -> Optional['outputs.MachineExtensionInstanceViewResponse']:
1756
+ """
1757
+ The machine extension instance view.
1758
+ """
1759
+ return pulumi.get(self, "instance_view")
1760
+
1761
+ @property
1762
+ @pulumi.getter(name="protectedSettings")
1763
+ def protected_settings(self) -> Optional[Any]:
1764
+ """
1765
+ The extension can contain either protectedSettings or protectedSettingsFromKeyVault or no protected settings at all.
1766
+ """
1767
+ return pulumi.get(self, "protected_settings")
1768
+
1769
+ @property
1770
+ @pulumi.getter
1771
+ def publisher(self) -> Optional[str]:
1772
+ """
1773
+ The name of the extension handler publisher.
1774
+ """
1775
+ return pulumi.get(self, "publisher")
1776
+
1777
+ @property
1778
+ @pulumi.getter
1779
+ def settings(self) -> Optional[Any]:
1780
+ """
1781
+ Json formatted public settings for the extension.
1782
+ """
1783
+ return pulumi.get(self, "settings")
1784
+
1785
+ @property
1786
+ @pulumi.getter
1787
+ def type(self) -> Optional[str]:
1788
+ """
1789
+ Specifies the type of the extension; an example is "CustomScriptExtension".
1790
+ """
1791
+ return pulumi.get(self, "type")
1792
+
1793
+ @property
1794
+ @pulumi.getter(name="typeHandlerVersion")
1795
+ def type_handler_version(self) -> Optional[str]:
1796
+ """
1797
+ Specifies the version of the script handler.
1798
+ """
1799
+ return pulumi.get(self, "type_handler_version")
1800
+
1801
+
1802
+ @pulumi.output_type
1803
+ class MachineExtensionResponse(dict):
1804
+ """
1805
+ Describes a Machine Extension.
1806
+ """
1807
+ @staticmethod
1808
+ def __key_warning(key: str):
1809
+ suggest = None
1810
+ if key == "systemData":
1811
+ suggest = "system_data"
1812
+
1813
+ if suggest:
1814
+ pulumi.log.warn(f"Key '{key}' not found in MachineExtensionResponse. Access the value via the '{suggest}' property getter instead.")
1815
+
1816
+ def __getitem__(self, key: str) -> Any:
1817
+ MachineExtensionResponse.__key_warning(key)
1818
+ return super().__getitem__(key)
1819
+
1820
+ def get(self, key: str, default = None) -> Any:
1821
+ MachineExtensionResponse.__key_warning(key)
1822
+ return super().get(key, default)
1823
+
1824
+ def __init__(__self__, *,
1825
+ id: str,
1826
+ location: str,
1827
+ name: str,
1828
+ system_data: 'outputs.SystemDataResponse',
1829
+ type: str,
1830
+ properties: Optional['outputs.MachineExtensionPropertiesResponse'] = None,
1831
+ tags: Optional[Mapping[str, str]] = None):
1832
+ """
1833
+ Describes a Machine Extension.
1834
+ :param str id: Fully qualified resource ID for the resource. Ex - /subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/{resourceProviderNamespace}/{resourceType}/{resourceName}
1835
+ :param str location: The geo-location where the resource lives
1836
+ :param str name: The name of the resource
1837
+ :param 'SystemDataResponse' system_data: Azure Resource Manager metadata containing createdBy and modifiedBy information.
1838
+ :param str type: The type of the resource. E.g. "Microsoft.Compute/virtualMachines" or "Microsoft.Storage/storageAccounts"
1839
+ :param 'MachineExtensionPropertiesResponse' properties: Describes Machine Extension Properties.
1840
+ :param Mapping[str, str] tags: Resource tags.
1841
+ """
1842
+ pulumi.set(__self__, "id", id)
1843
+ pulumi.set(__self__, "location", location)
1844
+ pulumi.set(__self__, "name", name)
1845
+ pulumi.set(__self__, "system_data", system_data)
1846
+ pulumi.set(__self__, "type", type)
1847
+ if properties is not None:
1848
+ pulumi.set(__self__, "properties", properties)
1849
+ if tags is not None:
1850
+ pulumi.set(__self__, "tags", tags)
1851
+
1852
+ @property
1853
+ @pulumi.getter
1854
+ def id(self) -> str:
1855
+ """
1856
+ Fully qualified resource ID for the resource. Ex - /subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/{resourceProviderNamespace}/{resourceType}/{resourceName}
1857
+ """
1858
+ return pulumi.get(self, "id")
1859
+
1860
+ @property
1861
+ @pulumi.getter
1862
+ def location(self) -> str:
1863
+ """
1864
+ The geo-location where the resource lives
1865
+ """
1866
+ return pulumi.get(self, "location")
1867
+
1868
+ @property
1869
+ @pulumi.getter
1870
+ def name(self) -> str:
1871
+ """
1872
+ The name of the resource
1873
+ """
1874
+ return pulumi.get(self, "name")
1875
+
1876
+ @property
1877
+ @pulumi.getter(name="systemData")
1878
+ def system_data(self) -> 'outputs.SystemDataResponse':
1879
+ """
1880
+ Azure Resource Manager metadata containing createdBy and modifiedBy information.
1881
+ """
1882
+ return pulumi.get(self, "system_data")
1883
+
1884
+ @property
1885
+ @pulumi.getter
1886
+ def type(self) -> str:
1887
+ """
1888
+ The type of the resource. E.g. "Microsoft.Compute/virtualMachines" or "Microsoft.Storage/storageAccounts"
1889
+ """
1890
+ return pulumi.get(self, "type")
1891
+
1892
+ @property
1893
+ @pulumi.getter
1894
+ def properties(self) -> Optional['outputs.MachineExtensionPropertiesResponse']:
1895
+ """
1896
+ Describes Machine Extension Properties.
1897
+ """
1898
+ return pulumi.get(self, "properties")
1899
+
1900
+ @property
1901
+ @pulumi.getter
1902
+ def tags(self) -> Optional[Mapping[str, str]]:
1903
+ """
1904
+ Resource tags.
1905
+ """
1906
+ return pulumi.get(self, "tags")
1907
+
1908
+
1909
+ @pulumi.output_type
1910
+ class MachineRunCommandInstanceViewResponse(dict):
1911
+ """
1912
+ The instance view of a machine run command.
1913
+ """
1914
+ @staticmethod
1915
+ def __key_warning(key: str):
1916
+ suggest = None
1917
+ if key == "endTime":
1918
+ suggest = "end_time"
1919
+ elif key == "executionMessage":
1920
+ suggest = "execution_message"
1921
+ elif key == "executionState":
1922
+ suggest = "execution_state"
1923
+ elif key == "exitCode":
1924
+ suggest = "exit_code"
1925
+ elif key == "startTime":
1926
+ suggest = "start_time"
1927
+
1928
+ if suggest:
1929
+ pulumi.log.warn(f"Key '{key}' not found in MachineRunCommandInstanceViewResponse. Access the value via the '{suggest}' property getter instead.")
1930
+
1931
+ def __getitem__(self, key: str) -> Any:
1932
+ MachineRunCommandInstanceViewResponse.__key_warning(key)
1933
+ return super().__getitem__(key)
1934
+
1935
+ def get(self, key: str, default = None) -> Any:
1936
+ MachineRunCommandInstanceViewResponse.__key_warning(key)
1937
+ return super().get(key, default)
1938
+
1939
+ def __init__(__self__, *,
1940
+ end_time: Optional[str] = None,
1941
+ error: Optional[str] = None,
1942
+ execution_message: Optional[str] = None,
1943
+ execution_state: Optional[str] = None,
1944
+ exit_code: Optional[int] = None,
1945
+ output: Optional[str] = None,
1946
+ start_time: Optional[str] = None,
1947
+ statuses: Optional[Sequence['outputs.ExtensionsResourceStatusResponse']] = None):
1948
+ """
1949
+ The instance view of a machine run command.
1950
+ :param str end_time: Script end time.
1951
+ :param str error: Script error stream.
1952
+ :param str execution_message: Communicate script configuration errors or execution messages.
1953
+ :param str execution_state: Script execution status.
1954
+ :param int exit_code: Exit code returned from script execution.
1955
+ :param str output: Script output stream.
1956
+ :param str start_time: Script start time.
1957
+ :param Sequence['ExtensionsResourceStatusResponse'] statuses: The status information.
1958
+ """
1959
+ if end_time is not None:
1960
+ pulumi.set(__self__, "end_time", end_time)
1961
+ if error is not None:
1962
+ pulumi.set(__self__, "error", error)
1963
+ if execution_message is not None:
1964
+ pulumi.set(__self__, "execution_message", execution_message)
1965
+ if execution_state is not None:
1966
+ pulumi.set(__self__, "execution_state", execution_state)
1967
+ if exit_code is not None:
1968
+ pulumi.set(__self__, "exit_code", exit_code)
1969
+ if output is not None:
1970
+ pulumi.set(__self__, "output", output)
1971
+ if start_time is not None:
1972
+ pulumi.set(__self__, "start_time", start_time)
1973
+ if statuses is not None:
1974
+ pulumi.set(__self__, "statuses", statuses)
1975
+
1976
+ @property
1977
+ @pulumi.getter(name="endTime")
1978
+ def end_time(self) -> Optional[str]:
1979
+ """
1980
+ Script end time.
1981
+ """
1982
+ return pulumi.get(self, "end_time")
1983
+
1984
+ @property
1985
+ @pulumi.getter
1986
+ def error(self) -> Optional[str]:
1987
+ """
1988
+ Script error stream.
1989
+ """
1990
+ return pulumi.get(self, "error")
1991
+
1992
+ @property
1993
+ @pulumi.getter(name="executionMessage")
1994
+ def execution_message(self) -> Optional[str]:
1995
+ """
1996
+ Communicate script configuration errors or execution messages.
1997
+ """
1998
+ return pulumi.get(self, "execution_message")
1999
+
2000
+ @property
2001
+ @pulumi.getter(name="executionState")
2002
+ def execution_state(self) -> Optional[str]:
2003
+ """
2004
+ Script execution status.
2005
+ """
2006
+ return pulumi.get(self, "execution_state")
2007
+
2008
+ @property
2009
+ @pulumi.getter(name="exitCode")
2010
+ def exit_code(self) -> Optional[int]:
2011
+ """
2012
+ Exit code returned from script execution.
2013
+ """
2014
+ return pulumi.get(self, "exit_code")
2015
+
2016
+ @property
2017
+ @pulumi.getter
2018
+ def output(self) -> Optional[str]:
2019
+ """
2020
+ Script output stream.
2021
+ """
2022
+ return pulumi.get(self, "output")
2023
+
2024
+ @property
2025
+ @pulumi.getter(name="startTime")
2026
+ def start_time(self) -> Optional[str]:
2027
+ """
2028
+ Script start time.
2029
+ """
2030
+ return pulumi.get(self, "start_time")
2031
+
2032
+ @property
2033
+ @pulumi.getter
2034
+ def statuses(self) -> Optional[Sequence['outputs.ExtensionsResourceStatusResponse']]:
2035
+ """
2036
+ The status information.
2037
+ """
2038
+ return pulumi.get(self, "statuses")
2039
+
2040
+
2041
+ @pulumi.output_type
2042
+ class MachineRunCommandScriptSourceResponse(dict):
2043
+ """
2044
+ Describes the script sources for run command. Use only one of script, scriptUri, commandId.
2045
+ """
2046
+ @staticmethod
2047
+ def __key_warning(key: str):
2048
+ suggest = None
2049
+ if key == "commandId":
2050
+ suggest = "command_id"
2051
+ elif key == "scriptUri":
2052
+ suggest = "script_uri"
2053
+ elif key == "scriptUriManagedIdentity":
2054
+ suggest = "script_uri_managed_identity"
2055
+
2056
+ if suggest:
2057
+ pulumi.log.warn(f"Key '{key}' not found in MachineRunCommandScriptSourceResponse. Access the value via the '{suggest}' property getter instead.")
2058
+
2059
+ def __getitem__(self, key: str) -> Any:
2060
+ MachineRunCommandScriptSourceResponse.__key_warning(key)
2061
+ return super().__getitem__(key)
2062
+
2063
+ def get(self, key: str, default = None) -> Any:
2064
+ MachineRunCommandScriptSourceResponse.__key_warning(key)
2065
+ return super().get(key, default)
2066
+
2067
+ def __init__(__self__, *,
2068
+ command_id: Optional[str] = None,
2069
+ script: Optional[str] = None,
2070
+ script_uri: Optional[str] = None,
2071
+ script_uri_managed_identity: Optional['outputs.RunCommandManagedIdentityResponse'] = None):
2072
+ """
2073
+ Describes the script sources for run command. Use only one of script, scriptUri, commandId.
2074
+ :param str command_id: Specifies the commandId of predefined built-in script.
2075
+ :param str script: Specifies the script content to be executed on the machine.
2076
+ :param str script_uri: Specifies the script download location. It can be either SAS URI of an Azure storage blob with read access or public URI.
2077
+ :param 'RunCommandManagedIdentityResponse' script_uri_managed_identity: User-assigned managed identity that has access to scriptUri in case of Azure storage blob. Use an empty object in case of system-assigned identity. Make sure the Azure storage blob exists, and managed identity has been given access to blob's container with 'Storage Blob Data Reader' role assignment. In case of user-assigned identity, make sure you add it under VM's identity. For more info on managed identity and Run Command, refer https://aka.ms/ManagedIdentity and https://aka.ms/RunCommandManaged.
2078
+ """
2079
+ if command_id is not None:
2080
+ pulumi.set(__self__, "command_id", command_id)
2081
+ if script is not None:
2082
+ pulumi.set(__self__, "script", script)
2083
+ if script_uri is not None:
2084
+ pulumi.set(__self__, "script_uri", script_uri)
2085
+ if script_uri_managed_identity is not None:
2086
+ pulumi.set(__self__, "script_uri_managed_identity", script_uri_managed_identity)
2087
+
2088
+ @property
2089
+ @pulumi.getter(name="commandId")
2090
+ def command_id(self) -> Optional[str]:
2091
+ """
2092
+ Specifies the commandId of predefined built-in script.
2093
+ """
2094
+ return pulumi.get(self, "command_id")
2095
+
2096
+ @property
2097
+ @pulumi.getter
2098
+ def script(self) -> Optional[str]:
2099
+ """
2100
+ Specifies the script content to be executed on the machine.
2101
+ """
2102
+ return pulumi.get(self, "script")
2103
+
2104
+ @property
2105
+ @pulumi.getter(name="scriptUri")
2106
+ def script_uri(self) -> Optional[str]:
2107
+ """
2108
+ Specifies the script download location. It can be either SAS URI of an Azure storage blob with read access or public URI.
2109
+ """
2110
+ return pulumi.get(self, "script_uri")
2111
+
2112
+ @property
2113
+ @pulumi.getter(name="scriptUriManagedIdentity")
2114
+ def script_uri_managed_identity(self) -> Optional['outputs.RunCommandManagedIdentityResponse']:
2115
+ """
2116
+ User-assigned managed identity that has access to scriptUri in case of Azure storage blob. Use an empty object in case of system-assigned identity. Make sure the Azure storage blob exists, and managed identity has been given access to blob's container with 'Storage Blob Data Reader' role assignment. In case of user-assigned identity, make sure you add it under VM's identity. For more info on managed identity and Run Command, refer https://aka.ms/ManagedIdentity and https://aka.ms/RunCommandManaged.
2117
+ """
2118
+ return pulumi.get(self, "script_uri_managed_identity")
2119
+
2120
+
2121
+ @pulumi.output_type
2122
+ class NetworkInterfaceResponse(dict):
2123
+ """
2124
+ Describes a network interface.
2125
+ """
2126
+ @staticmethod
2127
+ def __key_warning(key: str):
2128
+ suggest = None
2129
+ if key == "ipAddresses":
2130
+ suggest = "ip_addresses"
2131
+
2132
+ if suggest:
2133
+ pulumi.log.warn(f"Key '{key}' not found in NetworkInterfaceResponse. Access the value via the '{suggest}' property getter instead.")
2134
+
2135
+ def __getitem__(self, key: str) -> Any:
2136
+ NetworkInterfaceResponse.__key_warning(key)
2137
+ return super().__getitem__(key)
2138
+
2139
+ def get(self, key: str, default = None) -> Any:
2140
+ NetworkInterfaceResponse.__key_warning(key)
2141
+ return super().get(key, default)
2142
+
2143
+ def __init__(__self__, *,
2144
+ ip_addresses: Optional[Sequence['outputs.IpAddressResponse']] = None):
2145
+ """
2146
+ Describes a network interface.
2147
+ :param Sequence['IpAddressResponse'] ip_addresses: The list of IP addresses in this interface.
2148
+ """
2149
+ if ip_addresses is not None:
2150
+ pulumi.set(__self__, "ip_addresses", ip_addresses)
2151
+
2152
+ @property
2153
+ @pulumi.getter(name="ipAddresses")
2154
+ def ip_addresses(self) -> Optional[Sequence['outputs.IpAddressResponse']]:
2155
+ """
2156
+ The list of IP addresses in this interface.
2157
+ """
2158
+ return pulumi.get(self, "ip_addresses")
2159
+
2160
+
2161
+ @pulumi.output_type
2162
+ class NetworkProfileResponse(dict):
2163
+ """
2164
+ Describes the network information on this machine.
2165
+ """
2166
+ @staticmethod
2167
+ def __key_warning(key: str):
2168
+ suggest = None
2169
+ if key == "networkInterfaces":
2170
+ suggest = "network_interfaces"
2171
+
2172
+ if suggest:
2173
+ pulumi.log.warn(f"Key '{key}' not found in NetworkProfileResponse. Access the value via the '{suggest}' property getter instead.")
2174
+
2175
+ def __getitem__(self, key: str) -> Any:
2176
+ NetworkProfileResponse.__key_warning(key)
2177
+ return super().__getitem__(key)
2178
+
2179
+ def get(self, key: str, default = None) -> Any:
2180
+ NetworkProfileResponse.__key_warning(key)
2181
+ return super().get(key, default)
2182
+
2183
+ def __init__(__self__, *,
2184
+ network_interfaces: Optional[Sequence['outputs.NetworkInterfaceResponse']] = None):
2185
+ """
2186
+ Describes the network information on this machine.
2187
+ :param Sequence['NetworkInterfaceResponse'] network_interfaces: The list of network interfaces.
2188
+ """
2189
+ if network_interfaces is not None:
2190
+ pulumi.set(__self__, "network_interfaces", network_interfaces)
2191
+
2192
+ @property
2193
+ @pulumi.getter(name="networkInterfaces")
2194
+ def network_interfaces(self) -> Optional[Sequence['outputs.NetworkInterfaceResponse']]:
2195
+ """
2196
+ The list of network interfaces.
2197
+ """
2198
+ return pulumi.get(self, "network_interfaces")
2199
+
2200
+
2201
+ @pulumi.output_type
2202
+ class OSProfileResponse(dict):
2203
+ """
2204
+ Specifies the operating system settings for the hybrid machine.
2205
+ """
2206
+ @staticmethod
2207
+ def __key_warning(key: str):
2208
+ suggest = None
2209
+ if key == "computerName":
2210
+ suggest = "computer_name"
2211
+ elif key == "linuxConfiguration":
2212
+ suggest = "linux_configuration"
2213
+ elif key == "windowsConfiguration":
2214
+ suggest = "windows_configuration"
2215
+
2216
+ if suggest:
2217
+ pulumi.log.warn(f"Key '{key}' not found in OSProfileResponse. Access the value via the '{suggest}' property getter instead.")
2218
+
2219
+ def __getitem__(self, key: str) -> Any:
2220
+ OSProfileResponse.__key_warning(key)
2221
+ return super().__getitem__(key)
2222
+
2223
+ def get(self, key: str, default = None) -> Any:
2224
+ OSProfileResponse.__key_warning(key)
2225
+ return super().get(key, default)
2226
+
2227
+ def __init__(__self__, *,
2228
+ computer_name: str,
2229
+ linux_configuration: Optional['outputs.OSProfileResponseLinuxConfiguration'] = None,
2230
+ windows_configuration: Optional['outputs.OSProfileResponseWindowsConfiguration'] = None):
2231
+ """
2232
+ Specifies the operating system settings for the hybrid machine.
2233
+ :param str computer_name: Specifies the host OS name of the hybrid machine.
2234
+ :param 'OSProfileResponseLinuxConfiguration' linux_configuration: Specifies the linux configuration for update management.
2235
+ :param 'OSProfileResponseWindowsConfiguration' windows_configuration: Specifies the windows configuration for update management.
2236
+ """
2237
+ pulumi.set(__self__, "computer_name", computer_name)
2238
+ if linux_configuration is not None:
2239
+ pulumi.set(__self__, "linux_configuration", linux_configuration)
2240
+ if windows_configuration is not None:
2241
+ pulumi.set(__self__, "windows_configuration", windows_configuration)
2242
+
2243
+ @property
2244
+ @pulumi.getter(name="computerName")
2245
+ def computer_name(self) -> str:
2246
+ """
2247
+ Specifies the host OS name of the hybrid machine.
2248
+ """
2249
+ return pulumi.get(self, "computer_name")
2250
+
2251
+ @property
2252
+ @pulumi.getter(name="linuxConfiguration")
2253
+ def linux_configuration(self) -> Optional['outputs.OSProfileResponseLinuxConfiguration']:
2254
+ """
2255
+ Specifies the linux configuration for update management.
2256
+ """
2257
+ return pulumi.get(self, "linux_configuration")
2258
+
2259
+ @property
2260
+ @pulumi.getter(name="windowsConfiguration")
2261
+ def windows_configuration(self) -> Optional['outputs.OSProfileResponseWindowsConfiguration']:
2262
+ """
2263
+ Specifies the windows configuration for update management.
2264
+ """
2265
+ return pulumi.get(self, "windows_configuration")
2266
+
2267
+
2268
+ @pulumi.output_type
2269
+ class OSProfileResponseLinuxConfiguration(dict):
2270
+ """
2271
+ Specifies the linux configuration for update management.
2272
+ """
2273
+ @staticmethod
2274
+ def __key_warning(key: str):
2275
+ suggest = None
2276
+ if key == "assessmentMode":
2277
+ suggest = "assessment_mode"
2278
+ elif key == "enableHotpatching":
2279
+ suggest = "enable_hotpatching"
2280
+ elif key == "patchMode":
2281
+ suggest = "patch_mode"
2282
+
2283
+ if suggest:
2284
+ pulumi.log.warn(f"Key '{key}' not found in OSProfileResponseLinuxConfiguration. Access the value via the '{suggest}' property getter instead.")
2285
+
2286
+ def __getitem__(self, key: str) -> Any:
2287
+ OSProfileResponseLinuxConfiguration.__key_warning(key)
2288
+ return super().__getitem__(key)
2289
+
2290
+ def get(self, key: str, default = None) -> Any:
2291
+ OSProfileResponseLinuxConfiguration.__key_warning(key)
2292
+ return super().get(key, default)
2293
+
2294
+ def __init__(__self__, *,
2295
+ status: 'outputs.PatchSettingsResponseStatus',
2296
+ assessment_mode: Optional[str] = None,
2297
+ enable_hotpatching: Optional[bool] = None,
2298
+ patch_mode: Optional[str] = None):
2299
+ """
2300
+ Specifies the linux configuration for update management.
2301
+ :param 'PatchSettingsResponseStatus' status: Status of the hotpatch capability enrollment or disenrollment.
2302
+ :param str assessment_mode: Specifies the assessment mode.
2303
+ :param bool enable_hotpatching: Captures the hotpatch capability enrollment intent of the customers, which enables customers to patch their Windows machines without requiring a reboot.
2304
+ :param str patch_mode: Specifies the patch mode.
2305
+ """
2306
+ pulumi.set(__self__, "status", status)
2307
+ if assessment_mode is not None:
2308
+ pulumi.set(__self__, "assessment_mode", assessment_mode)
2309
+ if enable_hotpatching is not None:
2310
+ pulumi.set(__self__, "enable_hotpatching", enable_hotpatching)
2311
+ if patch_mode is not None:
2312
+ pulumi.set(__self__, "patch_mode", patch_mode)
2313
+
2314
+ @property
2315
+ @pulumi.getter
2316
+ def status(self) -> 'outputs.PatchSettingsResponseStatus':
2317
+ """
2318
+ Status of the hotpatch capability enrollment or disenrollment.
2319
+ """
2320
+ return pulumi.get(self, "status")
2321
+
2322
+ @property
2323
+ @pulumi.getter(name="assessmentMode")
2324
+ def assessment_mode(self) -> Optional[str]:
2325
+ """
2326
+ Specifies the assessment mode.
2327
+ """
2328
+ return pulumi.get(self, "assessment_mode")
2329
+
2330
+ @property
2331
+ @pulumi.getter(name="enableHotpatching")
2332
+ def enable_hotpatching(self) -> Optional[bool]:
2333
+ """
2334
+ Captures the hotpatch capability enrollment intent of the customers, which enables customers to patch their Windows machines without requiring a reboot.
2335
+ """
2336
+ return pulumi.get(self, "enable_hotpatching")
2337
+
2338
+ @property
2339
+ @pulumi.getter(name="patchMode")
2340
+ def patch_mode(self) -> Optional[str]:
2341
+ """
2342
+ Specifies the patch mode.
2343
+ """
2344
+ return pulumi.get(self, "patch_mode")
2345
+
2346
+
2347
+ @pulumi.output_type
2348
+ class OSProfileResponseWindowsConfiguration(dict):
2349
+ """
2350
+ Specifies the windows configuration for update management.
2351
+ """
2352
+ @staticmethod
2353
+ def __key_warning(key: str):
2354
+ suggest = None
2355
+ if key == "assessmentMode":
2356
+ suggest = "assessment_mode"
2357
+ elif key == "enableHotpatching":
2358
+ suggest = "enable_hotpatching"
2359
+ elif key == "patchMode":
2360
+ suggest = "patch_mode"
2361
+
2362
+ if suggest:
2363
+ pulumi.log.warn(f"Key '{key}' not found in OSProfileResponseWindowsConfiguration. Access the value via the '{suggest}' property getter instead.")
2364
+
2365
+ def __getitem__(self, key: str) -> Any:
2366
+ OSProfileResponseWindowsConfiguration.__key_warning(key)
2367
+ return super().__getitem__(key)
2368
+
2369
+ def get(self, key: str, default = None) -> Any:
2370
+ OSProfileResponseWindowsConfiguration.__key_warning(key)
2371
+ return super().get(key, default)
2372
+
2373
+ def __init__(__self__, *,
2374
+ status: 'outputs.PatchSettingsResponseStatus',
2375
+ assessment_mode: Optional[str] = None,
2376
+ enable_hotpatching: Optional[bool] = None,
2377
+ patch_mode: Optional[str] = None):
2378
+ """
2379
+ Specifies the windows configuration for update management.
2380
+ :param 'PatchSettingsResponseStatus' status: Status of the hotpatch capability enrollment or disenrollment.
2381
+ :param str assessment_mode: Specifies the assessment mode.
2382
+ :param bool enable_hotpatching: Captures the hotpatch capability enrollment intent of the customers, which enables customers to patch their Windows machines without requiring a reboot.
2383
+ :param str patch_mode: Specifies the patch mode.
2384
+ """
2385
+ pulumi.set(__self__, "status", status)
2386
+ if assessment_mode is not None:
2387
+ pulumi.set(__self__, "assessment_mode", assessment_mode)
2388
+ if enable_hotpatching is not None:
2389
+ pulumi.set(__self__, "enable_hotpatching", enable_hotpatching)
2390
+ if patch_mode is not None:
2391
+ pulumi.set(__self__, "patch_mode", patch_mode)
2392
+
2393
+ @property
2394
+ @pulumi.getter
2395
+ def status(self) -> 'outputs.PatchSettingsResponseStatus':
2396
+ """
2397
+ Status of the hotpatch capability enrollment or disenrollment.
2398
+ """
2399
+ return pulumi.get(self, "status")
2400
+
2401
+ @property
2402
+ @pulumi.getter(name="assessmentMode")
2403
+ def assessment_mode(self) -> Optional[str]:
2404
+ """
2405
+ Specifies the assessment mode.
2406
+ """
2407
+ return pulumi.get(self, "assessment_mode")
2408
+
2409
+ @property
2410
+ @pulumi.getter(name="enableHotpatching")
2411
+ def enable_hotpatching(self) -> Optional[bool]:
2412
+ """
2413
+ Captures the hotpatch capability enrollment intent of the customers, which enables customers to patch their Windows machines without requiring a reboot.
2414
+ """
2415
+ return pulumi.get(self, "enable_hotpatching")
2416
+
2417
+ @property
2418
+ @pulumi.getter(name="patchMode")
2419
+ def patch_mode(self) -> Optional[str]:
2420
+ """
2421
+ Specifies the patch mode.
2422
+ """
2423
+ return pulumi.get(self, "patch_mode")
2424
+
2425
+
2426
+ @pulumi.output_type
2427
+ class PatchSettingsResponseStatus(dict):
2428
+ """
2429
+ Status of the hotpatch capability enrollment or disenrollment.
2430
+ """
2431
+ @staticmethod
2432
+ def __key_warning(key: str):
2433
+ suggest = None
2434
+ if key == "hotpatchEnablementStatus":
2435
+ suggest = "hotpatch_enablement_status"
2436
+
2437
+ if suggest:
2438
+ pulumi.log.warn(f"Key '{key}' not found in PatchSettingsResponseStatus. Access the value via the '{suggest}' property getter instead.")
2439
+
2440
+ def __getitem__(self, key: str) -> Any:
2441
+ PatchSettingsResponseStatus.__key_warning(key)
2442
+ return super().__getitem__(key)
2443
+
2444
+ def get(self, key: str, default = None) -> Any:
2445
+ PatchSettingsResponseStatus.__key_warning(key)
2446
+ return super().get(key, default)
2447
+
2448
+ def __init__(__self__, *,
2449
+ error: 'outputs.ErrorDetailResponse',
2450
+ hotpatch_enablement_status: Optional[str] = None):
2451
+ """
2452
+ Status of the hotpatch capability enrollment or disenrollment.
2453
+ :param 'ErrorDetailResponse' error: The errors that were encountered during the hotpatch capability enrollment or disenrollment.
2454
+ :param str hotpatch_enablement_status: Indicates the current status of the hotpatch being enabled or disabled.
2455
+ """
2456
+ pulumi.set(__self__, "error", error)
2457
+ if hotpatch_enablement_status is not None:
2458
+ pulumi.set(__self__, "hotpatch_enablement_status", hotpatch_enablement_status)
2459
+
2460
+ @property
2461
+ @pulumi.getter
2462
+ def error(self) -> 'outputs.ErrorDetailResponse':
2463
+ """
2464
+ The errors that were encountered during the hotpatch capability enrollment or disenrollment.
2465
+ """
2466
+ return pulumi.get(self, "error")
2467
+
2468
+ @property
2469
+ @pulumi.getter(name="hotpatchEnablementStatus")
2470
+ def hotpatch_enablement_status(self) -> Optional[str]:
2471
+ """
2472
+ Indicates the current status of the hotpatch being enabled or disabled.
2473
+ """
2474
+ return pulumi.get(self, "hotpatch_enablement_status")
2475
+
2476
+
2477
+ @pulumi.output_type
2478
+ class PrivateEndpointConnectionDataModelResponse(dict):
2479
+ """
2480
+ The Data Model for a Private Endpoint Connection associated with a Private Link Scope
2481
+ """
2482
+ def __init__(__self__, *,
2483
+ id: str,
2484
+ name: str,
2485
+ type: str,
2486
+ properties: Optional['outputs.PrivateEndpointConnectionPropertiesResponse'] = None):
2487
+ """
2488
+ The Data Model for a Private Endpoint Connection associated with a Private Link Scope
2489
+ :param str id: The ARM Resource Id of the Private Endpoint.
2490
+ :param str name: The Name of the Private Endpoint.
2491
+ :param str type: Azure resource type
2492
+ :param 'PrivateEndpointConnectionPropertiesResponse' properties: The Private Endpoint Connection properties.
2493
+ """
2494
+ pulumi.set(__self__, "id", id)
2495
+ pulumi.set(__self__, "name", name)
2496
+ pulumi.set(__self__, "type", type)
2497
+ if properties is not None:
2498
+ pulumi.set(__self__, "properties", properties)
2499
+
2500
+ @property
2501
+ @pulumi.getter
2502
+ def id(self) -> str:
2503
+ """
2504
+ The ARM Resource Id of the Private Endpoint.
2505
+ """
2506
+ return pulumi.get(self, "id")
2507
+
2508
+ @property
2509
+ @pulumi.getter
2510
+ def name(self) -> str:
2511
+ """
2512
+ The Name of the Private Endpoint.
2513
+ """
2514
+ return pulumi.get(self, "name")
2515
+
2516
+ @property
2517
+ @pulumi.getter
2518
+ def type(self) -> str:
2519
+ """
2520
+ Azure resource type
2521
+ """
2522
+ return pulumi.get(self, "type")
2523
+
2524
+ @property
2525
+ @pulumi.getter
2526
+ def properties(self) -> Optional['outputs.PrivateEndpointConnectionPropertiesResponse']:
2527
+ """
2528
+ The Private Endpoint Connection properties.
2529
+ """
2530
+ return pulumi.get(self, "properties")
2531
+
2532
+
2533
+ @pulumi.output_type
2534
+ class PrivateEndpointConnectionPropertiesResponse(dict):
2535
+ """
2536
+ Properties of a private endpoint connection.
2537
+ """
2538
+ @staticmethod
2539
+ def __key_warning(key: str):
2540
+ suggest = None
2541
+ if key == "groupIds":
2542
+ suggest = "group_ids"
2543
+ elif key == "provisioningState":
2544
+ suggest = "provisioning_state"
2545
+ elif key == "privateEndpoint":
2546
+ suggest = "private_endpoint"
2547
+ elif key == "privateLinkServiceConnectionState":
2548
+ suggest = "private_link_service_connection_state"
2549
+
2550
+ if suggest:
2551
+ pulumi.log.warn(f"Key '{key}' not found in PrivateEndpointConnectionPropertiesResponse. Access the value via the '{suggest}' property getter instead.")
2552
+
2553
+ def __getitem__(self, key: str) -> Any:
2554
+ PrivateEndpointConnectionPropertiesResponse.__key_warning(key)
2555
+ return super().__getitem__(key)
2556
+
2557
+ def get(self, key: str, default = None) -> Any:
2558
+ PrivateEndpointConnectionPropertiesResponse.__key_warning(key)
2559
+ return super().get(key, default)
2560
+
2561
+ def __init__(__self__, *,
2562
+ group_ids: Sequence[str],
2563
+ provisioning_state: str,
2564
+ private_endpoint: Optional['outputs.PrivateEndpointPropertyResponse'] = None,
2565
+ private_link_service_connection_state: Optional['outputs.PrivateLinkServiceConnectionStatePropertyResponse'] = None):
2566
+ """
2567
+ Properties of a private endpoint connection.
2568
+ :param Sequence[str] group_ids: List of group IDs.
2569
+ :param str provisioning_state: State of the private endpoint connection.
2570
+ :param 'PrivateEndpointPropertyResponse' private_endpoint: Private endpoint which the connection belongs to.
2571
+ :param 'PrivateLinkServiceConnectionStatePropertyResponse' private_link_service_connection_state: Connection state of the private endpoint connection.
2572
+ """
2573
+ pulumi.set(__self__, "group_ids", group_ids)
2574
+ pulumi.set(__self__, "provisioning_state", provisioning_state)
2575
+ if private_endpoint is not None:
2576
+ pulumi.set(__self__, "private_endpoint", private_endpoint)
2577
+ if private_link_service_connection_state is not None:
2578
+ pulumi.set(__self__, "private_link_service_connection_state", private_link_service_connection_state)
2579
+
2580
+ @property
2581
+ @pulumi.getter(name="groupIds")
2582
+ def group_ids(self) -> Sequence[str]:
2583
+ """
2584
+ List of group IDs.
2585
+ """
2586
+ return pulumi.get(self, "group_ids")
2587
+
2588
+ @property
2589
+ @pulumi.getter(name="provisioningState")
2590
+ def provisioning_state(self) -> str:
2591
+ """
2592
+ State of the private endpoint connection.
2593
+ """
2594
+ return pulumi.get(self, "provisioning_state")
2595
+
2596
+ @property
2597
+ @pulumi.getter(name="privateEndpoint")
2598
+ def private_endpoint(self) -> Optional['outputs.PrivateEndpointPropertyResponse']:
2599
+ """
2600
+ Private endpoint which the connection belongs to.
2601
+ """
2602
+ return pulumi.get(self, "private_endpoint")
2603
+
2604
+ @property
2605
+ @pulumi.getter(name="privateLinkServiceConnectionState")
2606
+ def private_link_service_connection_state(self) -> Optional['outputs.PrivateLinkServiceConnectionStatePropertyResponse']:
2607
+ """
2608
+ Connection state of the private endpoint connection.
2609
+ """
2610
+ return pulumi.get(self, "private_link_service_connection_state")
2611
+
2612
+
2613
+ @pulumi.output_type
2614
+ class PrivateEndpointPropertyResponse(dict):
2615
+ """
2616
+ Private endpoint which the connection belongs to.
2617
+ """
2618
+ def __init__(__self__, *,
2619
+ id: Optional[str] = None):
2620
+ """
2621
+ Private endpoint which the connection belongs to.
2622
+ :param str id: Resource id of the private endpoint.
2623
+ """
2624
+ if id is not None:
2625
+ pulumi.set(__self__, "id", id)
2626
+
2627
+ @property
2628
+ @pulumi.getter
2629
+ def id(self) -> Optional[str]:
2630
+ """
2631
+ Resource id of the private endpoint.
2632
+ """
2633
+ return pulumi.get(self, "id")
2634
+
2635
+
2636
+ @pulumi.output_type
2637
+ class PrivateLinkServiceConnectionStatePropertyResponse(dict):
2638
+ """
2639
+ State of the private endpoint connection.
2640
+ """
2641
+ @staticmethod
2642
+ def __key_warning(key: str):
2643
+ suggest = None
2644
+ if key == "actionsRequired":
2645
+ suggest = "actions_required"
2646
+
2647
+ if suggest:
2648
+ pulumi.log.warn(f"Key '{key}' not found in PrivateLinkServiceConnectionStatePropertyResponse. Access the value via the '{suggest}' property getter instead.")
2649
+
2650
+ def __getitem__(self, key: str) -> Any:
2651
+ PrivateLinkServiceConnectionStatePropertyResponse.__key_warning(key)
2652
+ return super().__getitem__(key)
2653
+
2654
+ def get(self, key: str, default = None) -> Any:
2655
+ PrivateLinkServiceConnectionStatePropertyResponse.__key_warning(key)
2656
+ return super().get(key, default)
2657
+
2658
+ def __init__(__self__, *,
2659
+ actions_required: str,
2660
+ description: str,
2661
+ status: str):
2662
+ """
2663
+ State of the private endpoint connection.
2664
+ :param str actions_required: The actions required for private link service connection.
2665
+ :param str description: The private link service connection description.
2666
+ :param str status: The private link service connection status.
2667
+ """
2668
+ pulumi.set(__self__, "actions_required", actions_required)
2669
+ pulumi.set(__self__, "description", description)
2670
+ pulumi.set(__self__, "status", status)
2671
+
2672
+ @property
2673
+ @pulumi.getter(name="actionsRequired")
2674
+ def actions_required(self) -> str:
2675
+ """
2676
+ The actions required for private link service connection.
2677
+ """
2678
+ return pulumi.get(self, "actions_required")
2679
+
2680
+ @property
2681
+ @pulumi.getter
2682
+ def description(self) -> str:
2683
+ """
2684
+ The private link service connection description.
2685
+ """
2686
+ return pulumi.get(self, "description")
2687
+
2688
+ @property
2689
+ @pulumi.getter
2690
+ def status(self) -> str:
2691
+ """
2692
+ The private link service connection status.
2693
+ """
2694
+ return pulumi.get(self, "status")
2695
+
2696
+
2697
+ @pulumi.output_type
2698
+ class ProductFeatureResponse(dict):
2699
+ """
2700
+ Product Feature
2701
+ """
2702
+ @staticmethod
2703
+ def __key_warning(key: str):
2704
+ suggest = None
2705
+ if key == "billingEndDate":
2706
+ suggest = "billing_end_date"
2707
+ elif key == "billingStartDate":
2708
+ suggest = "billing_start_date"
2709
+ elif key == "disenrollmentDate":
2710
+ suggest = "disenrollment_date"
2711
+ elif key == "enrollmentDate":
2712
+ suggest = "enrollment_date"
2713
+ elif key == "subscriptionStatus":
2714
+ suggest = "subscription_status"
2715
+
2716
+ if suggest:
2717
+ pulumi.log.warn(f"Key '{key}' not found in ProductFeatureResponse. Access the value via the '{suggest}' property getter instead.")
2718
+
2719
+ def __getitem__(self, key: str) -> Any:
2720
+ ProductFeatureResponse.__key_warning(key)
2721
+ return super().__getitem__(key)
2722
+
2723
+ def get(self, key: str, default = None) -> Any:
2724
+ ProductFeatureResponse.__key_warning(key)
2725
+ return super().get(key, default)
2726
+
2727
+ def __init__(__self__, *,
2728
+ billing_end_date: str,
2729
+ billing_start_date: str,
2730
+ disenrollment_date: str,
2731
+ enrollment_date: str,
2732
+ error: 'outputs.ErrorDetailResponse',
2733
+ name: Optional[str] = None,
2734
+ subscription_status: Optional[str] = None):
2735
+ """
2736
+ Product Feature
2737
+ :param str billing_end_date: The timestamp in UTC when the billing ends.
2738
+ :param str billing_start_date: The timestamp in UTC when the billing starts.
2739
+ :param str disenrollment_date: The timestamp in UTC when the user disenrolled the feature.
2740
+ :param str enrollment_date: The timestamp in UTC when the user enrolls the feature.
2741
+ :param 'ErrorDetailResponse' error: The errors that were encountered during the feature enrollment or disenrollment.
2742
+ :param str name: Product feature name.
2743
+ :param str subscription_status: Indicates the current status of the product features.
2744
+ """
2745
+ pulumi.set(__self__, "billing_end_date", billing_end_date)
2746
+ pulumi.set(__self__, "billing_start_date", billing_start_date)
2747
+ pulumi.set(__self__, "disenrollment_date", disenrollment_date)
2748
+ pulumi.set(__self__, "enrollment_date", enrollment_date)
2749
+ pulumi.set(__self__, "error", error)
2750
+ if name is not None:
2751
+ pulumi.set(__self__, "name", name)
2752
+ if subscription_status is not None:
2753
+ pulumi.set(__self__, "subscription_status", subscription_status)
2754
+
2755
+ @property
2756
+ @pulumi.getter(name="billingEndDate")
2757
+ def billing_end_date(self) -> str:
2758
+ """
2759
+ The timestamp in UTC when the billing ends.
2760
+ """
2761
+ return pulumi.get(self, "billing_end_date")
2762
+
2763
+ @property
2764
+ @pulumi.getter(name="billingStartDate")
2765
+ def billing_start_date(self) -> str:
2766
+ """
2767
+ The timestamp in UTC when the billing starts.
2768
+ """
2769
+ return pulumi.get(self, "billing_start_date")
2770
+
2771
+ @property
2772
+ @pulumi.getter(name="disenrollmentDate")
2773
+ def disenrollment_date(self) -> str:
2774
+ """
2775
+ The timestamp in UTC when the user disenrolled the feature.
2776
+ """
2777
+ return pulumi.get(self, "disenrollment_date")
2778
+
2779
+ @property
2780
+ @pulumi.getter(name="enrollmentDate")
2781
+ def enrollment_date(self) -> str:
2782
+ """
2783
+ The timestamp in UTC when the user enrolls the feature.
2784
+ """
2785
+ return pulumi.get(self, "enrollment_date")
2786
+
2787
+ @property
2788
+ @pulumi.getter
2789
+ def error(self) -> 'outputs.ErrorDetailResponse':
2790
+ """
2791
+ The errors that were encountered during the feature enrollment or disenrollment.
2792
+ """
2793
+ return pulumi.get(self, "error")
2794
+
2795
+ @property
2796
+ @pulumi.getter
2797
+ def name(self) -> Optional[str]:
2798
+ """
2799
+ Product feature name.
2800
+ """
2801
+ return pulumi.get(self, "name")
2802
+
2803
+ @property
2804
+ @pulumi.getter(name="subscriptionStatus")
2805
+ def subscription_status(self) -> Optional[str]:
2806
+ """
2807
+ Indicates the current status of the product features.
2808
+ """
2809
+ return pulumi.get(self, "subscription_status")
2810
+
2811
+
2812
+ @pulumi.output_type
2813
+ class RunCommandInputParameterResponse(dict):
2814
+ """
2815
+ Describes the properties of a run command parameter.
2816
+ """
2817
+ def __init__(__self__, *,
2818
+ name: str,
2819
+ value: str):
2820
+ """
2821
+ Describes the properties of a run command parameter.
2822
+ :param str name: The run command parameter name.
2823
+ :param str value: The run command parameter value.
2824
+ """
2825
+ pulumi.set(__self__, "name", name)
2826
+ pulumi.set(__self__, "value", value)
2827
+
2828
+ @property
2829
+ @pulumi.getter
2830
+ def name(self) -> str:
2831
+ """
2832
+ The run command parameter name.
2833
+ """
2834
+ return pulumi.get(self, "name")
2835
+
2836
+ @property
2837
+ @pulumi.getter
2838
+ def value(self) -> str:
2839
+ """
2840
+ The run command parameter value.
2841
+ """
2842
+ return pulumi.get(self, "value")
2843
+
2844
+
2845
+ @pulumi.output_type
2846
+ class RunCommandManagedIdentityResponse(dict):
2847
+ """
2848
+ Contains clientId or objectId (use only one, not both) of a user-assigned managed identity that has access to storage blob used in Run Command. Use an empty RunCommandManagedIdentity object in case of system-assigned identity. Make sure the Azure storage blob exists in case of scriptUri, and managed identity has been given access to blob's container with 'Storage Blob Data Reader' role assignment with scriptUri blob and 'Storage Blob Data Contributor' for Append blobs(outputBlobUri, errorBlobUri). In case of user assigned identity, make sure you add it under VM's identity. For more info on managed identity and Run Command, refer https://aka.ms/ManagedIdentity and https://aka.ms/RunCommandManaged.
2849
+ """
2850
+ @staticmethod
2851
+ def __key_warning(key: str):
2852
+ suggest = None
2853
+ if key == "clientId":
2854
+ suggest = "client_id"
2855
+ elif key == "objectId":
2856
+ suggest = "object_id"
2857
+
2858
+ if suggest:
2859
+ pulumi.log.warn(f"Key '{key}' not found in RunCommandManagedIdentityResponse. Access the value via the '{suggest}' property getter instead.")
2860
+
2861
+ def __getitem__(self, key: str) -> Any:
2862
+ RunCommandManagedIdentityResponse.__key_warning(key)
2863
+ return super().__getitem__(key)
2864
+
2865
+ def get(self, key: str, default = None) -> Any:
2866
+ RunCommandManagedIdentityResponse.__key_warning(key)
2867
+ return super().get(key, default)
2868
+
2869
+ def __init__(__self__, *,
2870
+ client_id: Optional[str] = None,
2871
+ object_id: Optional[str] = None):
2872
+ """
2873
+ Contains clientId or objectId (use only one, not both) of a user-assigned managed identity that has access to storage blob used in Run Command. Use an empty RunCommandManagedIdentity object in case of system-assigned identity. Make sure the Azure storage blob exists in case of scriptUri, and managed identity has been given access to blob's container with 'Storage Blob Data Reader' role assignment with scriptUri blob and 'Storage Blob Data Contributor' for Append blobs(outputBlobUri, errorBlobUri). In case of user assigned identity, make sure you add it under VM's identity. For more info on managed identity and Run Command, refer https://aka.ms/ManagedIdentity and https://aka.ms/RunCommandManaged.
2874
+ :param str client_id: Client Id (GUID value) of the user-assigned managed identity. ObjectId should not be used if this is provided.
2875
+ :param str object_id: Object Id (GUID value) of the user-assigned managed identity. ClientId should not be used if this is provided.
2876
+ """
2877
+ if client_id is not None:
2878
+ pulumi.set(__self__, "client_id", client_id)
2879
+ if object_id is not None:
2880
+ pulumi.set(__self__, "object_id", object_id)
2881
+
2882
+ @property
2883
+ @pulumi.getter(name="clientId")
2884
+ def client_id(self) -> Optional[str]:
2885
+ """
2886
+ Client Id (GUID value) of the user-assigned managed identity. ObjectId should not be used if this is provided.
2887
+ """
2888
+ return pulumi.get(self, "client_id")
2889
+
2890
+ @property
2891
+ @pulumi.getter(name="objectId")
2892
+ def object_id(self) -> Optional[str]:
2893
+ """
2894
+ Object Id (GUID value) of the user-assigned managed identity. ClientId should not be used if this is provided.
2895
+ """
2896
+ return pulumi.get(self, "object_id")
2897
+
2898
+
2899
+ @pulumi.output_type
2900
+ class ServiceStatusResponse(dict):
2901
+ """
2902
+ Describes the status and behavior of a service.
2903
+ """
2904
+ @staticmethod
2905
+ def __key_warning(key: str):
2906
+ suggest = None
2907
+ if key == "startupType":
2908
+ suggest = "startup_type"
2909
+
2910
+ if suggest:
2911
+ pulumi.log.warn(f"Key '{key}' not found in ServiceStatusResponse. Access the value via the '{suggest}' property getter instead.")
2912
+
2913
+ def __getitem__(self, key: str) -> Any:
2914
+ ServiceStatusResponse.__key_warning(key)
2915
+ return super().__getitem__(key)
2916
+
2917
+ def get(self, key: str, default = None) -> Any:
2918
+ ServiceStatusResponse.__key_warning(key)
2919
+ return super().get(key, default)
2920
+
2921
+ def __init__(__self__, *,
2922
+ startup_type: Optional[str] = None,
2923
+ status: Optional[str] = None):
2924
+ """
2925
+ Describes the status and behavior of a service.
2926
+ :param str startup_type: The behavior of the service when the Arc-enabled machine starts up.
2927
+ :param str status: The current status of the service.
2928
+ """
2929
+ if startup_type is not None:
2930
+ pulumi.set(__self__, "startup_type", startup_type)
2931
+ if status is not None:
2932
+ pulumi.set(__self__, "status", status)
2933
+
2934
+ @property
2935
+ @pulumi.getter(name="startupType")
2936
+ def startup_type(self) -> Optional[str]:
2937
+ """
2938
+ The behavior of the service when the Arc-enabled machine starts up.
2939
+ """
2940
+ return pulumi.get(self, "startup_type")
2941
+
2942
+ @property
2943
+ @pulumi.getter
2944
+ def status(self) -> Optional[str]:
2945
+ """
2946
+ The current status of the service.
2947
+ """
2948
+ return pulumi.get(self, "status")
2949
+
2950
+
2951
+ @pulumi.output_type
2952
+ class ServiceStatusesResponse(dict):
2953
+ """
2954
+ Reports the state and behavior of dependent services.
2955
+ """
2956
+ @staticmethod
2957
+ def __key_warning(key: str):
2958
+ suggest = None
2959
+ if key == "extensionService":
2960
+ suggest = "extension_service"
2961
+ elif key == "guestConfigurationService":
2962
+ suggest = "guest_configuration_service"
2963
+
2964
+ if suggest:
2965
+ pulumi.log.warn(f"Key '{key}' not found in ServiceStatusesResponse. Access the value via the '{suggest}' property getter instead.")
2966
+
2967
+ def __getitem__(self, key: str) -> Any:
2968
+ ServiceStatusesResponse.__key_warning(key)
2969
+ return super().__getitem__(key)
2970
+
2971
+ def get(self, key: str, default = None) -> Any:
2972
+ ServiceStatusesResponse.__key_warning(key)
2973
+ return super().get(key, default)
2974
+
2975
+ def __init__(__self__, *,
2976
+ extension_service: Optional['outputs.ServiceStatusResponse'] = None,
2977
+ guest_configuration_service: Optional['outputs.ServiceStatusResponse'] = None):
2978
+ """
2979
+ Reports the state and behavior of dependent services.
2980
+ :param 'ServiceStatusResponse' extension_service: The state of the extension service on the Arc-enabled machine.
2981
+ :param 'ServiceStatusResponse' guest_configuration_service: The state of the guest configuration service on the Arc-enabled machine.
2982
+ """
2983
+ if extension_service is not None:
2984
+ pulumi.set(__self__, "extension_service", extension_service)
2985
+ if guest_configuration_service is not None:
2986
+ pulumi.set(__self__, "guest_configuration_service", guest_configuration_service)
2987
+
2988
+ @property
2989
+ @pulumi.getter(name="extensionService")
2990
+ def extension_service(self) -> Optional['outputs.ServiceStatusResponse']:
2991
+ """
2992
+ The state of the extension service on the Arc-enabled machine.
2993
+ """
2994
+ return pulumi.get(self, "extension_service")
2995
+
2996
+ @property
2997
+ @pulumi.getter(name="guestConfigurationService")
2998
+ def guest_configuration_service(self) -> Optional['outputs.ServiceStatusResponse']:
2999
+ """
3000
+ The state of the guest configuration service on the Arc-enabled machine.
3001
+ """
3002
+ return pulumi.get(self, "guest_configuration_service")
3003
+
3004
+
3005
+ @pulumi.output_type
3006
+ class SubnetResponse(dict):
3007
+ """
3008
+ Describes the subnet.
3009
+ """
3010
+ @staticmethod
3011
+ def __key_warning(key: str):
3012
+ suggest = None
3013
+ if key == "addressPrefix":
3014
+ suggest = "address_prefix"
3015
+
3016
+ if suggest:
3017
+ pulumi.log.warn(f"Key '{key}' not found in SubnetResponse. Access the value via the '{suggest}' property getter instead.")
3018
+
3019
+ def __getitem__(self, key: str) -> Any:
3020
+ SubnetResponse.__key_warning(key)
3021
+ return super().__getitem__(key)
3022
+
3023
+ def get(self, key: str, default = None) -> Any:
3024
+ SubnetResponse.__key_warning(key)
3025
+ return super().get(key, default)
3026
+
3027
+ def __init__(__self__, *,
3028
+ address_prefix: Optional[str] = None):
3029
+ """
3030
+ Describes the subnet.
3031
+ :param str address_prefix: Represents address prefix.
3032
+ """
3033
+ if address_prefix is not None:
3034
+ pulumi.set(__self__, "address_prefix", address_prefix)
3035
+
3036
+ @property
3037
+ @pulumi.getter(name="addressPrefix")
3038
+ def address_prefix(self) -> Optional[str]:
3039
+ """
3040
+ Represents address prefix.
3041
+ """
3042
+ return pulumi.get(self, "address_prefix")
3043
+
3044
+
3045
+ @pulumi.output_type
3046
+ class SystemDataResponse(dict):
3047
+ """
3048
+ Metadata pertaining to creation and last modification of the resource.
3049
+ """
3050
+ @staticmethod
3051
+ def __key_warning(key: str):
3052
+ suggest = None
3053
+ if key == "createdAt":
3054
+ suggest = "created_at"
3055
+ elif key == "createdBy":
3056
+ suggest = "created_by"
3057
+ elif key == "createdByType":
3058
+ suggest = "created_by_type"
3059
+ elif key == "lastModifiedAt":
3060
+ suggest = "last_modified_at"
3061
+ elif key == "lastModifiedBy":
3062
+ suggest = "last_modified_by"
3063
+ elif key == "lastModifiedByType":
3064
+ suggest = "last_modified_by_type"
3065
+
3066
+ if suggest:
3067
+ pulumi.log.warn(f"Key '{key}' not found in SystemDataResponse. Access the value via the '{suggest}' property getter instead.")
3068
+
3069
+ def __getitem__(self, key: str) -> Any:
3070
+ SystemDataResponse.__key_warning(key)
3071
+ return super().__getitem__(key)
3072
+
3073
+ def get(self, key: str, default = None) -> Any:
3074
+ SystemDataResponse.__key_warning(key)
3075
+ return super().get(key, default)
3076
+
3077
+ def __init__(__self__, *,
3078
+ created_at: Optional[str] = None,
3079
+ created_by: Optional[str] = None,
3080
+ created_by_type: Optional[str] = None,
3081
+ last_modified_at: Optional[str] = None,
3082
+ last_modified_by: Optional[str] = None,
3083
+ last_modified_by_type: Optional[str] = None):
3084
+ """
3085
+ Metadata pertaining to creation and last modification of the resource.
3086
+ :param str created_at: The timestamp of resource creation (UTC).
3087
+ :param str created_by: The identity that created the resource.
3088
+ :param str created_by_type: The type of identity that created the resource.
3089
+ :param str last_modified_at: The timestamp of resource last modification (UTC)
3090
+ :param str last_modified_by: The identity that last modified the resource.
3091
+ :param str last_modified_by_type: The type of identity that last modified the resource.
3092
+ """
3093
+ if created_at is not None:
3094
+ pulumi.set(__self__, "created_at", created_at)
3095
+ if created_by is not None:
3096
+ pulumi.set(__self__, "created_by", created_by)
3097
+ if created_by_type is not None:
3098
+ pulumi.set(__self__, "created_by_type", created_by_type)
3099
+ if last_modified_at is not None:
3100
+ pulumi.set(__self__, "last_modified_at", last_modified_at)
3101
+ if last_modified_by is not None:
3102
+ pulumi.set(__self__, "last_modified_by", last_modified_by)
3103
+ if last_modified_by_type is not None:
3104
+ pulumi.set(__self__, "last_modified_by_type", last_modified_by_type)
3105
+
3106
+ @property
3107
+ @pulumi.getter(name="createdAt")
3108
+ def created_at(self) -> Optional[str]:
3109
+ """
3110
+ The timestamp of resource creation (UTC).
3111
+ """
3112
+ return pulumi.get(self, "created_at")
3113
+
3114
+ @property
3115
+ @pulumi.getter(name="createdBy")
3116
+ def created_by(self) -> Optional[str]:
3117
+ """
3118
+ The identity that created the resource.
3119
+ """
3120
+ return pulumi.get(self, "created_by")
3121
+
3122
+ @property
3123
+ @pulumi.getter(name="createdByType")
3124
+ def created_by_type(self) -> Optional[str]:
3125
+ """
3126
+ The type of identity that created the resource.
3127
+ """
3128
+ return pulumi.get(self, "created_by_type")
3129
+
3130
+ @property
3131
+ @pulumi.getter(name="lastModifiedAt")
3132
+ def last_modified_at(self) -> Optional[str]:
3133
+ """
3134
+ The timestamp of resource last modification (UTC)
3135
+ """
3136
+ return pulumi.get(self, "last_modified_at")
3137
+
3138
+ @property
3139
+ @pulumi.getter(name="lastModifiedBy")
3140
+ def last_modified_by(self) -> Optional[str]:
3141
+ """
3142
+ The identity that last modified the resource.
3143
+ """
3144
+ return pulumi.get(self, "last_modified_by")
3145
+
3146
+ @property
3147
+ @pulumi.getter(name="lastModifiedByType")
3148
+ def last_modified_by_type(self) -> Optional[str]:
3149
+ """
3150
+ The type of identity that last modified the resource.
3151
+ """
3152
+ return pulumi.get(self, "last_modified_by_type")
3153
+
3154
+
3155
+ @pulumi.output_type
3156
+ class VolumeLicenseDetailsResponse(dict):
3157
+ @staticmethod
3158
+ def __key_warning(key: str):
3159
+ suggest = None
3160
+ if key == "invoiceId":
3161
+ suggest = "invoice_id"
3162
+ elif key == "programYear":
3163
+ suggest = "program_year"
3164
+
3165
+ if suggest:
3166
+ pulumi.log.warn(f"Key '{key}' not found in VolumeLicenseDetailsResponse. Access the value via the '{suggest}' property getter instead.")
3167
+
3168
+ def __getitem__(self, key: str) -> Any:
3169
+ VolumeLicenseDetailsResponse.__key_warning(key)
3170
+ return super().__getitem__(key)
3171
+
3172
+ def get(self, key: str, default = None) -> Any:
3173
+ VolumeLicenseDetailsResponse.__key_warning(key)
3174
+ return super().get(key, default)
3175
+
3176
+ def __init__(__self__, *,
3177
+ invoice_id: Optional[str] = None,
3178
+ program_year: Optional[str] = None):
3179
+ """
3180
+ :param str invoice_id: The invoice id for the volume license.
3181
+ :param str program_year: Describes the program year the volume license is for.
3182
+ """
3183
+ if invoice_id is not None:
3184
+ pulumi.set(__self__, "invoice_id", invoice_id)
3185
+ if program_year is not None:
3186
+ pulumi.set(__self__, "program_year", program_year)
3187
+
3188
+ @property
3189
+ @pulumi.getter(name="invoiceId")
3190
+ def invoice_id(self) -> Optional[str]:
3191
+ """
3192
+ The invoice id for the volume license.
3193
+ """
3194
+ return pulumi.get(self, "invoice_id")
3195
+
3196
+ @property
3197
+ @pulumi.getter(name="programYear")
3198
+ def program_year(self) -> Optional[str]:
3199
+ """
3200
+ Describes the program year the volume license is for.
3201
+ """
3202
+ return pulumi.get(self, "program_year")
3203
+
3204
+