pulumi-alicloud 3.73.0a1736850863__py3-none-any.whl → 3.74.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-alicloud might be problematic. Click here for more details.

Files changed (123) hide show
  1. pulumi_alicloud/__init__.py +139 -0
  2. pulumi_alicloud/alb/__init__.py +2 -0
  3. pulumi_alicloud/alb/_inputs.py +913 -250
  4. pulumi_alicloud/alb/a_script.py +116 -98
  5. pulumi_alicloud/alb/get_server_groups.py +55 -25
  6. pulumi_alicloud/alb/listener.py +269 -174
  7. pulumi_alicloud/alb/load_balancer.py +239 -118
  8. pulumi_alicloud/alb/load_balancer_access_log_config_attachment.py +303 -0
  9. pulumi_alicloud/alb/load_balancer_zone_shifted_attachment.py +303 -0
  10. pulumi_alicloud/alb/outputs.py +720 -222
  11. pulumi_alicloud/alb/server_group.py +532 -122
  12. pulumi_alicloud/alikafka/instance.py +188 -70
  13. pulumi_alicloud/amqp/instance.py +77 -28
  14. pulumi_alicloud/bastionhost/_inputs.py +40 -38
  15. pulumi_alicloud/bastionhost/get_instances.py +6 -22
  16. pulumi_alicloud/bastionhost/outputs.py +60 -49
  17. pulumi_alicloud/cen/_inputs.py +34 -0
  18. pulumi_alicloud/cen/instance_grant.py +4 -0
  19. pulumi_alicloud/cen/outputs.py +37 -0
  20. pulumi_alicloud/cen/transit_router_multicast_domain.py +123 -36
  21. pulumi_alicloud/cloudcontrol/__init__.py +12 -0
  22. pulumi_alicloud/cloudcontrol/get_prices.py +199 -0
  23. pulumi_alicloud/cloudcontrol/get_products.py +187 -0
  24. pulumi_alicloud/cloudcontrol/get_resource_types.py +178 -0
  25. pulumi_alicloud/cloudcontrol/outputs.py +688 -0
  26. pulumi_alicloud/cloudcontrol/resource.py +407 -0
  27. pulumi_alicloud/cms/_inputs.py +21 -15
  28. pulumi_alicloud/cms/alarm.py +7 -7
  29. pulumi_alicloud/cms/outputs.py +14 -10
  30. pulumi_alicloud/cs/_inputs.py +349 -1
  31. pulumi_alicloud/cs/get_edge_kubernetes_clusters.py +4 -2
  32. pulumi_alicloud/cs/get_managed_kubernetes_clusters.py +2 -0
  33. pulumi_alicloud/cs/kubernetes.py +29 -29
  34. pulumi_alicloud/cs/managed_kubernetes.py +137 -47
  35. pulumi_alicloud/cs/node_pool.py +77 -2
  36. pulumi_alicloud/cs/outputs.py +265 -1
  37. pulumi_alicloud/dataworks/__init__.py +4 -0
  38. pulumi_alicloud/dataworks/_inputs.py +1534 -0
  39. pulumi_alicloud/dataworks/di_alarm_rule.py +708 -0
  40. pulumi_alicloud/dataworks/di_job.py +1005 -0
  41. pulumi_alicloud/dataworks/dw_resource_group.py +703 -0
  42. pulumi_alicloud/dataworks/network.py +331 -0
  43. pulumi_alicloud/dataworks/outputs.py +1247 -0
  44. pulumi_alicloud/dcdn/waf_rule.py +14 -14
  45. pulumi_alicloud/dfs/file_system.py +62 -23
  46. pulumi_alicloud/dfs/mount_point.py +48 -22
  47. pulumi_alicloud/dns/get_alidns_domains.py +7 -2
  48. pulumi_alicloud/dns/outputs.py +8 -0
  49. pulumi_alicloud/ecs/ecs_launch_template.py +122 -0
  50. pulumi_alicloud/ecs/ecs_network_interface.py +14 -14
  51. pulumi_alicloud/ecs/ecs_session_manager_status.py +18 -18
  52. pulumi_alicloud/ecs/instance.py +7 -7
  53. pulumi_alicloud/ecs/launch_template.py +88 -0
  54. pulumi_alicloud/esa/__init__.py +3 -0
  55. pulumi_alicloud/esa/_inputs.py +81 -0
  56. pulumi_alicloud/esa/http_request_header_modification_rule.py +531 -0
  57. pulumi_alicloud/esa/list.py +361 -0
  58. pulumi_alicloud/esa/outputs.py +48 -0
  59. pulumi_alicloud/esa/page.py +376 -0
  60. pulumi_alicloud/esa/rate_plan_instance.py +63 -7
  61. pulumi_alicloud/ess/get_scaling_groups.py +64 -10
  62. pulumi_alicloud/ess/get_scaling_rules.py +74 -10
  63. pulumi_alicloud/ess/outputs.py +357 -17
  64. pulumi_alicloud/eventbridge/get_service.py +2 -6
  65. pulumi_alicloud/fc/_inputs.py +75 -75
  66. pulumi_alicloud/fc/custom_domain.py +2 -2
  67. pulumi_alicloud/fc/function.py +32 -4
  68. pulumi_alicloud/fc/outputs.py +50 -50
  69. pulumi_alicloud/fc/v2_function.py +20 -0
  70. pulumi_alicloud/fc/v3_function.py +53 -6
  71. pulumi_alicloud/hbr/__init__.py +1 -0
  72. pulumi_alicloud/hbr/cross_account.py +338 -0
  73. pulumi_alicloud/ims/oidc_provider.py +28 -0
  74. pulumi_alicloud/kms/__init__.py +1 -0
  75. pulumi_alicloud/kms/get_instances.py +160 -0
  76. pulumi_alicloud/kms/instance.py +0 -60
  77. pulumi_alicloud/kms/outputs.py +19 -0
  78. pulumi_alicloud/log/resource_record.py +42 -26
  79. pulumi_alicloud/maxcompute/__init__.py +5 -0
  80. pulumi_alicloud/maxcompute/_inputs.py +615 -42
  81. pulumi_alicloud/maxcompute/outputs.py +486 -28
  82. pulumi_alicloud/maxcompute/project.py +63 -31
  83. pulumi_alicloud/maxcompute/quota_plan.py +412 -0
  84. pulumi_alicloud/maxcompute/quota_schedule.py +260 -0
  85. pulumi_alicloud/maxcompute/role.py +423 -0
  86. pulumi_alicloud/maxcompute/role_user_attachment.py +368 -0
  87. pulumi_alicloud/maxcompute/tunnel_quota_timer.py +287 -0
  88. pulumi_alicloud/message/service_queue.py +106 -59
  89. pulumi_alicloud/message/service_topic.py +182 -37
  90. pulumi_alicloud/mongodb/account.py +138 -163
  91. pulumi_alicloud/oos/secret_parameter.py +84 -9
  92. pulumi_alicloud/oss/bucket.py +1 -1
  93. pulumi_alicloud/oss/bucket_policy.py +2 -4
  94. pulumi_alicloud/oss/bucket_referer.py +2 -4
  95. pulumi_alicloud/oss/get_buckets.py +16 -2
  96. pulumi_alicloud/oss/outputs.py +18 -17
  97. pulumi_alicloud/pulumi-plugin.json +1 -1
  98. pulumi_alicloud/rds/instance.py +68 -0
  99. pulumi_alicloud/sae/application.py +84 -7
  100. pulumi_alicloud/sls/collection_policy.py +2 -2
  101. pulumi_alicloud/vpc/__init__.py +6 -0
  102. pulumi_alicloud/vpc/get_ipam_ipam_pool_allocations.py +295 -0
  103. pulumi_alicloud/vpc/get_ipam_ipam_pool_cidrs.py +196 -0
  104. pulumi_alicloud/vpc/get_ipam_ipam_pools.py +353 -0
  105. pulumi_alicloud/vpc/get_ipam_ipam_scopes.py +333 -0
  106. pulumi_alicloud/vpc/get_ipam_ipams.py +291 -0
  107. pulumi_alicloud/vpc/get_networks.py +3 -0
  108. pulumi_alicloud/vpc/ipam_ipam_pool.py +47 -0
  109. pulumi_alicloud/vpc/ipam_ipam_scope.py +47 -0
  110. pulumi_alicloud/vpc/ipam_service.py +144 -0
  111. pulumi_alicloud/vpc/ipv4_cidr_block.py +162 -51
  112. pulumi_alicloud/vpc/nat_gateway.py +145 -7
  113. pulumi_alicloud/vpc/outputs.py +777 -0
  114. pulumi_alicloud/vpc/snat_entry.py +107 -48
  115. pulumi_alicloud/vpn/_inputs.py +96 -72
  116. pulumi_alicloud/vpn/connection.py +24 -28
  117. pulumi_alicloud/vpn/outputs.py +64 -48
  118. pulumi_alicloud/yundun/_inputs.py +26 -24
  119. pulumi_alicloud/yundun/outputs.py +37 -22
  120. {pulumi_alicloud-3.73.0a1736850863.dist-info → pulumi_alicloud-3.74.0.dist-info}/METADATA +1 -1
  121. {pulumi_alicloud-3.73.0a1736850863.dist-info → pulumi_alicloud-3.74.0.dist-info}/RECORD +123 -95
  122. {pulumi_alicloud-3.73.0a1736850863.dist-info → pulumi_alicloud-3.74.0.dist-info}/WHEEL +0 -0
  123. {pulumi_alicloud-3.73.0a1736850863.dist-info → pulumi_alicloud-3.74.0.dist-info}/top_level.txt +0 -0
@@ -0,0 +1,412 @@
1
+ # coding=utf-8
2
+ # *** WARNING: this file was generated by the Pulumi Terraform Bridge (tfgen) Tool. ***
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 sys
8
+ import pulumi
9
+ import pulumi.runtime
10
+ from typing import Any, Mapping, Optional, Sequence, Union, overload
11
+ if sys.version_info >= (3, 11):
12
+ from typing import NotRequired, TypedDict, TypeAlias
13
+ else:
14
+ from typing_extensions import NotRequired, TypedDict, TypeAlias
15
+ from .. import _utilities
16
+ from . import outputs
17
+ from ._inputs import *
18
+
19
+ __all__ = ['QuotaPlanArgs', 'QuotaPlan']
20
+
21
+ @pulumi.input_type
22
+ class QuotaPlanArgs:
23
+ def __init__(__self__, *,
24
+ nickname: pulumi.Input[str],
25
+ plan_name: pulumi.Input[str],
26
+ is_effective: Optional[pulumi.Input[bool]] = None,
27
+ quota: Optional[pulumi.Input['QuotaPlanQuotaArgs']] = None):
28
+ """
29
+ The set of arguments for constructing a QuotaPlan resource.
30
+ :param pulumi.Input[str] nickname: Quota Name
31
+ :param pulumi.Input[str] plan_name: The Quota plan name. Start with a letter, containing letters, numbers, and underscores (_). It is no more than 64 characters long.
32
+ :param pulumi.Input[bool] is_effective: Whether to take effect immediately. “Valid values: true”
33
+ .> **NOTE:** when other quota plans in the same quota group take effect, the effective quota group will become invalid. That is, IsEffective will become false. The effective quota plan cannot be deleted.
34
+ :param pulumi.Input['QuotaPlanQuotaArgs'] quota: Quota property See `quota` below.
35
+ """
36
+ pulumi.set(__self__, "nickname", nickname)
37
+ pulumi.set(__self__, "plan_name", plan_name)
38
+ if is_effective is not None:
39
+ pulumi.set(__self__, "is_effective", is_effective)
40
+ if quota is not None:
41
+ pulumi.set(__self__, "quota", quota)
42
+
43
+ @property
44
+ @pulumi.getter
45
+ def nickname(self) -> pulumi.Input[str]:
46
+ """
47
+ Quota Name
48
+ """
49
+ return pulumi.get(self, "nickname")
50
+
51
+ @nickname.setter
52
+ def nickname(self, value: pulumi.Input[str]):
53
+ pulumi.set(self, "nickname", value)
54
+
55
+ @property
56
+ @pulumi.getter(name="planName")
57
+ def plan_name(self) -> pulumi.Input[str]:
58
+ """
59
+ The Quota plan name. Start with a letter, containing letters, numbers, and underscores (_). It is no more than 64 characters long.
60
+ """
61
+ return pulumi.get(self, "plan_name")
62
+
63
+ @plan_name.setter
64
+ def plan_name(self, value: pulumi.Input[str]):
65
+ pulumi.set(self, "plan_name", value)
66
+
67
+ @property
68
+ @pulumi.getter(name="isEffective")
69
+ def is_effective(self) -> Optional[pulumi.Input[bool]]:
70
+ """
71
+ Whether to take effect immediately. “Valid values: true”
72
+ .> **NOTE:** when other quota plans in the same quota group take effect, the effective quota group will become invalid. That is, IsEffective will become false. The effective quota plan cannot be deleted.
73
+ """
74
+ return pulumi.get(self, "is_effective")
75
+
76
+ @is_effective.setter
77
+ def is_effective(self, value: Optional[pulumi.Input[bool]]):
78
+ pulumi.set(self, "is_effective", value)
79
+
80
+ @property
81
+ @pulumi.getter
82
+ def quota(self) -> Optional[pulumi.Input['QuotaPlanQuotaArgs']]:
83
+ """
84
+ Quota property See `quota` below.
85
+ """
86
+ return pulumi.get(self, "quota")
87
+
88
+ @quota.setter
89
+ def quota(self, value: Optional[pulumi.Input['QuotaPlanQuotaArgs']]):
90
+ pulumi.set(self, "quota", value)
91
+
92
+
93
+ @pulumi.input_type
94
+ class _QuotaPlanState:
95
+ def __init__(__self__, *,
96
+ is_effective: Optional[pulumi.Input[bool]] = None,
97
+ nickname: Optional[pulumi.Input[str]] = None,
98
+ plan_name: Optional[pulumi.Input[str]] = None,
99
+ quota: Optional[pulumi.Input['QuotaPlanQuotaArgs']] = None):
100
+ """
101
+ Input properties used for looking up and filtering QuotaPlan resources.
102
+ :param pulumi.Input[bool] is_effective: Whether to take effect immediately. “Valid values: true”
103
+ .> **NOTE:** when other quota plans in the same quota group take effect, the effective quota group will become invalid. That is, IsEffective will become false. The effective quota plan cannot be deleted.
104
+ :param pulumi.Input[str] nickname: Quota Name
105
+ :param pulumi.Input[str] plan_name: The Quota plan name. Start with a letter, containing letters, numbers, and underscores (_). It is no more than 64 characters long.
106
+ :param pulumi.Input['QuotaPlanQuotaArgs'] quota: Quota property See `quota` below.
107
+ """
108
+ if is_effective is not None:
109
+ pulumi.set(__self__, "is_effective", is_effective)
110
+ if nickname is not None:
111
+ pulumi.set(__self__, "nickname", nickname)
112
+ if plan_name is not None:
113
+ pulumi.set(__self__, "plan_name", plan_name)
114
+ if quota is not None:
115
+ pulumi.set(__self__, "quota", quota)
116
+
117
+ @property
118
+ @pulumi.getter(name="isEffective")
119
+ def is_effective(self) -> Optional[pulumi.Input[bool]]:
120
+ """
121
+ Whether to take effect immediately. “Valid values: true”
122
+ .> **NOTE:** when other quota plans in the same quota group take effect, the effective quota group will become invalid. That is, IsEffective will become false. The effective quota plan cannot be deleted.
123
+ """
124
+ return pulumi.get(self, "is_effective")
125
+
126
+ @is_effective.setter
127
+ def is_effective(self, value: Optional[pulumi.Input[bool]]):
128
+ pulumi.set(self, "is_effective", value)
129
+
130
+ @property
131
+ @pulumi.getter
132
+ def nickname(self) -> Optional[pulumi.Input[str]]:
133
+ """
134
+ Quota Name
135
+ """
136
+ return pulumi.get(self, "nickname")
137
+
138
+ @nickname.setter
139
+ def nickname(self, value: Optional[pulumi.Input[str]]):
140
+ pulumi.set(self, "nickname", value)
141
+
142
+ @property
143
+ @pulumi.getter(name="planName")
144
+ def plan_name(self) -> Optional[pulumi.Input[str]]:
145
+ """
146
+ The Quota plan name. Start with a letter, containing letters, numbers, and underscores (_). It is no more than 64 characters long.
147
+ """
148
+ return pulumi.get(self, "plan_name")
149
+
150
+ @plan_name.setter
151
+ def plan_name(self, value: Optional[pulumi.Input[str]]):
152
+ pulumi.set(self, "plan_name", value)
153
+
154
+ @property
155
+ @pulumi.getter
156
+ def quota(self) -> Optional[pulumi.Input['QuotaPlanQuotaArgs']]:
157
+ """
158
+ Quota property See `quota` below.
159
+ """
160
+ return pulumi.get(self, "quota")
161
+
162
+ @quota.setter
163
+ def quota(self, value: Optional[pulumi.Input['QuotaPlanQuotaArgs']]):
164
+ pulumi.set(self, "quota", value)
165
+
166
+
167
+ class QuotaPlan(pulumi.CustomResource):
168
+ @overload
169
+ def __init__(__self__,
170
+ resource_name: str,
171
+ opts: Optional[pulumi.ResourceOptions] = None,
172
+ is_effective: Optional[pulumi.Input[bool]] = None,
173
+ nickname: Optional[pulumi.Input[str]] = None,
174
+ plan_name: Optional[pulumi.Input[str]] = None,
175
+ quota: Optional[pulumi.Input[Union['QuotaPlanQuotaArgs', 'QuotaPlanQuotaArgsDict']]] = None,
176
+ __props__=None):
177
+ """
178
+ Provides a Max Compute Quota Plan resource.
179
+
180
+ For information about Max Compute Quota Plan and how to use it, see [What is Quota Plan](https://www.alibabacloud.com/help/en/).
181
+
182
+ > **NOTE:** Available since v1.242.0.
183
+
184
+ ## Example Usage
185
+
186
+ Basic Usage
187
+
188
+ ```python
189
+ import pulumi
190
+ import pulumi_alicloud as alicloud
191
+
192
+ config = pulumi.Config()
193
+ name = config.get("name")
194
+ if name is None:
195
+ name = "terraform-example"
196
+ elastic_reserved_cu = config.get("elasticReservedCu")
197
+ if elastic_reserved_cu is None:
198
+ elastic_reserved_cu = "50"
199
+ default = alicloud.maxcompute.QuotaPlan("default",
200
+ nickname="os_terrform_p",
201
+ quota={
202
+ "parameter": {
203
+ "elastic_reserved_cu": elastic_reserved_cu,
204
+ },
205
+ "sub_quota_info_lists": [
206
+ {
207
+ "nick_name": "sub_quota",
208
+ "parameter": {
209
+ "min_cu": 0,
210
+ "max_cu": 20,
211
+ "elastic_reserved_cu": elastic_reserved_cu,
212
+ },
213
+ },
214
+ {
215
+ "nick_name": "os_terrform",
216
+ "parameter": {
217
+ "min_cu": 50,
218
+ "max_cu": 50,
219
+ "elastic_reserved_cu": 0,
220
+ },
221
+ },
222
+ ],
223
+ },
224
+ plan_name="quota_plan")
225
+ ```
226
+
227
+ ## Import
228
+
229
+ Max Compute Quota Plan can be imported using the id, e.g.
230
+
231
+ ```sh
232
+ $ pulumi import alicloud:maxcompute/quotaPlan:QuotaPlan example <nickname>:<plan_name>
233
+ ```
234
+
235
+ :param str resource_name: The name of the resource.
236
+ :param pulumi.ResourceOptions opts: Options for the resource.
237
+ :param pulumi.Input[bool] is_effective: Whether to take effect immediately. “Valid values: true”
238
+ .> **NOTE:** when other quota plans in the same quota group take effect, the effective quota group will become invalid. That is, IsEffective will become false. The effective quota plan cannot be deleted.
239
+ :param pulumi.Input[str] nickname: Quota Name
240
+ :param pulumi.Input[str] plan_name: The Quota plan name. Start with a letter, containing letters, numbers, and underscores (_). It is no more than 64 characters long.
241
+ :param pulumi.Input[Union['QuotaPlanQuotaArgs', 'QuotaPlanQuotaArgsDict']] quota: Quota property See `quota` below.
242
+ """
243
+ ...
244
+ @overload
245
+ def __init__(__self__,
246
+ resource_name: str,
247
+ args: QuotaPlanArgs,
248
+ opts: Optional[pulumi.ResourceOptions] = None):
249
+ """
250
+ Provides a Max Compute Quota Plan resource.
251
+
252
+ For information about Max Compute Quota Plan and how to use it, see [What is Quota Plan](https://www.alibabacloud.com/help/en/).
253
+
254
+ > **NOTE:** Available since v1.242.0.
255
+
256
+ ## Example Usage
257
+
258
+ Basic Usage
259
+
260
+ ```python
261
+ import pulumi
262
+ import pulumi_alicloud as alicloud
263
+
264
+ config = pulumi.Config()
265
+ name = config.get("name")
266
+ if name is None:
267
+ name = "terraform-example"
268
+ elastic_reserved_cu = config.get("elasticReservedCu")
269
+ if elastic_reserved_cu is None:
270
+ elastic_reserved_cu = "50"
271
+ default = alicloud.maxcompute.QuotaPlan("default",
272
+ nickname="os_terrform_p",
273
+ quota={
274
+ "parameter": {
275
+ "elastic_reserved_cu": elastic_reserved_cu,
276
+ },
277
+ "sub_quota_info_lists": [
278
+ {
279
+ "nick_name": "sub_quota",
280
+ "parameter": {
281
+ "min_cu": 0,
282
+ "max_cu": 20,
283
+ "elastic_reserved_cu": elastic_reserved_cu,
284
+ },
285
+ },
286
+ {
287
+ "nick_name": "os_terrform",
288
+ "parameter": {
289
+ "min_cu": 50,
290
+ "max_cu": 50,
291
+ "elastic_reserved_cu": 0,
292
+ },
293
+ },
294
+ ],
295
+ },
296
+ plan_name="quota_plan")
297
+ ```
298
+
299
+ ## Import
300
+
301
+ Max Compute Quota Plan can be imported using the id, e.g.
302
+
303
+ ```sh
304
+ $ pulumi import alicloud:maxcompute/quotaPlan:QuotaPlan example <nickname>:<plan_name>
305
+ ```
306
+
307
+ :param str resource_name: The name of the resource.
308
+ :param QuotaPlanArgs args: The arguments to use to populate this resource's properties.
309
+ :param pulumi.ResourceOptions opts: Options for the resource.
310
+ """
311
+ ...
312
+ def __init__(__self__, resource_name: str, *args, **kwargs):
313
+ resource_args, opts = _utilities.get_resource_args_opts(QuotaPlanArgs, pulumi.ResourceOptions, *args, **kwargs)
314
+ if resource_args is not None:
315
+ __self__._internal_init(resource_name, opts, **resource_args.__dict__)
316
+ else:
317
+ __self__._internal_init(resource_name, *args, **kwargs)
318
+
319
+ def _internal_init(__self__,
320
+ resource_name: str,
321
+ opts: Optional[pulumi.ResourceOptions] = None,
322
+ is_effective: Optional[pulumi.Input[bool]] = None,
323
+ nickname: Optional[pulumi.Input[str]] = None,
324
+ plan_name: Optional[pulumi.Input[str]] = None,
325
+ quota: Optional[pulumi.Input[Union['QuotaPlanQuotaArgs', 'QuotaPlanQuotaArgsDict']]] = None,
326
+ __props__=None):
327
+ opts = pulumi.ResourceOptions.merge(_utilities.get_resource_opts_defaults(), opts)
328
+ if not isinstance(opts, pulumi.ResourceOptions):
329
+ raise TypeError('Expected resource options to be a ResourceOptions instance')
330
+ if opts.id is None:
331
+ if __props__ is not None:
332
+ raise TypeError('__props__ is only valid when passed in combination with a valid opts.id to get an existing resource')
333
+ __props__ = QuotaPlanArgs.__new__(QuotaPlanArgs)
334
+
335
+ __props__.__dict__["is_effective"] = is_effective
336
+ if nickname is None and not opts.urn:
337
+ raise TypeError("Missing required property 'nickname'")
338
+ __props__.__dict__["nickname"] = nickname
339
+ if plan_name is None and not opts.urn:
340
+ raise TypeError("Missing required property 'plan_name'")
341
+ __props__.__dict__["plan_name"] = plan_name
342
+ __props__.__dict__["quota"] = quota
343
+ super(QuotaPlan, __self__).__init__(
344
+ 'alicloud:maxcompute/quotaPlan:QuotaPlan',
345
+ resource_name,
346
+ __props__,
347
+ opts)
348
+
349
+ @staticmethod
350
+ def get(resource_name: str,
351
+ id: pulumi.Input[str],
352
+ opts: Optional[pulumi.ResourceOptions] = None,
353
+ is_effective: Optional[pulumi.Input[bool]] = None,
354
+ nickname: Optional[pulumi.Input[str]] = None,
355
+ plan_name: Optional[pulumi.Input[str]] = None,
356
+ quota: Optional[pulumi.Input[Union['QuotaPlanQuotaArgs', 'QuotaPlanQuotaArgsDict']]] = None) -> 'QuotaPlan':
357
+ """
358
+ Get an existing QuotaPlan resource's state with the given name, id, and optional extra
359
+ properties used to qualify the lookup.
360
+
361
+ :param str resource_name: The unique name of the resulting resource.
362
+ :param pulumi.Input[str] id: The unique provider ID of the resource to lookup.
363
+ :param pulumi.ResourceOptions opts: Options for the resource.
364
+ :param pulumi.Input[bool] is_effective: Whether to take effect immediately. “Valid values: true”
365
+ .> **NOTE:** when other quota plans in the same quota group take effect, the effective quota group will become invalid. That is, IsEffective will become false. The effective quota plan cannot be deleted.
366
+ :param pulumi.Input[str] nickname: Quota Name
367
+ :param pulumi.Input[str] plan_name: The Quota plan name. Start with a letter, containing letters, numbers, and underscores (_). It is no more than 64 characters long.
368
+ :param pulumi.Input[Union['QuotaPlanQuotaArgs', 'QuotaPlanQuotaArgsDict']] quota: Quota property See `quota` below.
369
+ """
370
+ opts = pulumi.ResourceOptions.merge(opts, pulumi.ResourceOptions(id=id))
371
+
372
+ __props__ = _QuotaPlanState.__new__(_QuotaPlanState)
373
+
374
+ __props__.__dict__["is_effective"] = is_effective
375
+ __props__.__dict__["nickname"] = nickname
376
+ __props__.__dict__["plan_name"] = plan_name
377
+ __props__.__dict__["quota"] = quota
378
+ return QuotaPlan(resource_name, opts=opts, __props__=__props__)
379
+
380
+ @property
381
+ @pulumi.getter(name="isEffective")
382
+ def is_effective(self) -> pulumi.Output[Optional[bool]]:
383
+ """
384
+ Whether to take effect immediately. “Valid values: true”
385
+ .> **NOTE:** when other quota plans in the same quota group take effect, the effective quota group will become invalid. That is, IsEffective will become false. The effective quota plan cannot be deleted.
386
+ """
387
+ return pulumi.get(self, "is_effective")
388
+
389
+ @property
390
+ @pulumi.getter
391
+ def nickname(self) -> pulumi.Output[str]:
392
+ """
393
+ Quota Name
394
+ """
395
+ return pulumi.get(self, "nickname")
396
+
397
+ @property
398
+ @pulumi.getter(name="planName")
399
+ def plan_name(self) -> pulumi.Output[str]:
400
+ """
401
+ The Quota plan name. Start with a letter, containing letters, numbers, and underscores (_). It is no more than 64 characters long.
402
+ """
403
+ return pulumi.get(self, "plan_name")
404
+
405
+ @property
406
+ @pulumi.getter
407
+ def quota(self) -> pulumi.Output[Optional['outputs.QuotaPlanQuota']]:
408
+ """
409
+ Quota property See `quota` below.
410
+ """
411
+ return pulumi.get(self, "quota")
412
+
@@ -0,0 +1,260 @@
1
+ # coding=utf-8
2
+ # *** WARNING: this file was generated by the Pulumi Terraform Bridge (tfgen) Tool. ***
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 sys
8
+ import pulumi
9
+ import pulumi.runtime
10
+ from typing import Any, Mapping, Optional, Sequence, Union, overload
11
+ if sys.version_info >= (3, 11):
12
+ from typing import NotRequired, TypedDict, TypeAlias
13
+ else:
14
+ from typing_extensions import NotRequired, TypedDict, TypeAlias
15
+ from .. import _utilities
16
+ from . import outputs
17
+ from ._inputs import *
18
+
19
+ __all__ = ['QuotaScheduleArgs', 'QuotaSchedule']
20
+
21
+ @pulumi.input_type
22
+ class QuotaScheduleArgs:
23
+ def __init__(__self__, *,
24
+ nickname: pulumi.Input[str],
25
+ timezone: pulumi.Input[str],
26
+ schedule_lists: Optional[pulumi.Input[Sequence[pulumi.Input['QuotaScheduleScheduleListArgs']]]] = None):
27
+ """
28
+ The set of arguments for constructing a QuotaSchedule resource.
29
+ :param pulumi.Input[str] nickname: The nickname of level-1 compute quota.
30
+ :param pulumi.Input[str] timezone: Time zone, reference value: UTC +8
31
+ :param pulumi.Input[Sequence[pulumi.Input['QuotaScheduleScheduleListArgs']]] schedule_lists: schedule list See `schedule_list` below.
32
+ """
33
+ pulumi.set(__self__, "nickname", nickname)
34
+ pulumi.set(__self__, "timezone", timezone)
35
+ if schedule_lists is not None:
36
+ pulumi.set(__self__, "schedule_lists", schedule_lists)
37
+
38
+ @property
39
+ @pulumi.getter
40
+ def nickname(self) -> pulumi.Input[str]:
41
+ """
42
+ The nickname of level-1 compute quota.
43
+ """
44
+ return pulumi.get(self, "nickname")
45
+
46
+ @nickname.setter
47
+ def nickname(self, value: pulumi.Input[str]):
48
+ pulumi.set(self, "nickname", value)
49
+
50
+ @property
51
+ @pulumi.getter
52
+ def timezone(self) -> pulumi.Input[str]:
53
+ """
54
+ Time zone, reference value: UTC +8
55
+ """
56
+ return pulumi.get(self, "timezone")
57
+
58
+ @timezone.setter
59
+ def timezone(self, value: pulumi.Input[str]):
60
+ pulumi.set(self, "timezone", value)
61
+
62
+ @property
63
+ @pulumi.getter(name="scheduleLists")
64
+ def schedule_lists(self) -> Optional[pulumi.Input[Sequence[pulumi.Input['QuotaScheduleScheduleListArgs']]]]:
65
+ """
66
+ schedule list See `schedule_list` below.
67
+ """
68
+ return pulumi.get(self, "schedule_lists")
69
+
70
+ @schedule_lists.setter
71
+ def schedule_lists(self, value: Optional[pulumi.Input[Sequence[pulumi.Input['QuotaScheduleScheduleListArgs']]]]):
72
+ pulumi.set(self, "schedule_lists", value)
73
+
74
+
75
+ @pulumi.input_type
76
+ class _QuotaScheduleState:
77
+ def __init__(__self__, *,
78
+ nickname: Optional[pulumi.Input[str]] = None,
79
+ schedule_lists: Optional[pulumi.Input[Sequence[pulumi.Input['QuotaScheduleScheduleListArgs']]]] = None,
80
+ timezone: Optional[pulumi.Input[str]] = None):
81
+ """
82
+ Input properties used for looking up and filtering QuotaSchedule resources.
83
+ :param pulumi.Input[str] nickname: The nickname of level-1 compute quota.
84
+ :param pulumi.Input[Sequence[pulumi.Input['QuotaScheduleScheduleListArgs']]] schedule_lists: schedule list See `schedule_list` below.
85
+ :param pulumi.Input[str] timezone: Time zone, reference value: UTC +8
86
+ """
87
+ if nickname is not None:
88
+ pulumi.set(__self__, "nickname", nickname)
89
+ if schedule_lists is not None:
90
+ pulumi.set(__self__, "schedule_lists", schedule_lists)
91
+ if timezone is not None:
92
+ pulumi.set(__self__, "timezone", timezone)
93
+
94
+ @property
95
+ @pulumi.getter
96
+ def nickname(self) -> Optional[pulumi.Input[str]]:
97
+ """
98
+ The nickname of level-1 compute quota.
99
+ """
100
+ return pulumi.get(self, "nickname")
101
+
102
+ @nickname.setter
103
+ def nickname(self, value: Optional[pulumi.Input[str]]):
104
+ pulumi.set(self, "nickname", value)
105
+
106
+ @property
107
+ @pulumi.getter(name="scheduleLists")
108
+ def schedule_lists(self) -> Optional[pulumi.Input[Sequence[pulumi.Input['QuotaScheduleScheduleListArgs']]]]:
109
+ """
110
+ schedule list See `schedule_list` below.
111
+ """
112
+ return pulumi.get(self, "schedule_lists")
113
+
114
+ @schedule_lists.setter
115
+ def schedule_lists(self, value: Optional[pulumi.Input[Sequence[pulumi.Input['QuotaScheduleScheduleListArgs']]]]):
116
+ pulumi.set(self, "schedule_lists", value)
117
+
118
+ @property
119
+ @pulumi.getter
120
+ def timezone(self) -> Optional[pulumi.Input[str]]:
121
+ """
122
+ Time zone, reference value: UTC +8
123
+ """
124
+ return pulumi.get(self, "timezone")
125
+
126
+ @timezone.setter
127
+ def timezone(self, value: Optional[pulumi.Input[str]]):
128
+ pulumi.set(self, "timezone", value)
129
+
130
+
131
+ class QuotaSchedule(pulumi.CustomResource):
132
+ @overload
133
+ def __init__(__self__,
134
+ resource_name: str,
135
+ opts: Optional[pulumi.ResourceOptions] = None,
136
+ nickname: Optional[pulumi.Input[str]] = None,
137
+ schedule_lists: Optional[pulumi.Input[Sequence[pulumi.Input[Union['QuotaScheduleScheduleListArgs', 'QuotaScheduleScheduleListArgsDict']]]]] = None,
138
+ timezone: Optional[pulumi.Input[str]] = None,
139
+ __props__=None):
140
+ """
141
+ ## Import
142
+
143
+ Max Compute Quota Schedule can be imported using the id, e.g.
144
+
145
+ ```sh
146
+ $ pulumi import alicloud:maxcompute/quotaSchedule:QuotaSchedule example <nickname>:<timezone>
147
+ ```
148
+
149
+ :param str resource_name: The name of the resource.
150
+ :param pulumi.ResourceOptions opts: Options for the resource.
151
+ :param pulumi.Input[str] nickname: The nickname of level-1 compute quota.
152
+ :param pulumi.Input[Sequence[pulumi.Input[Union['QuotaScheduleScheduleListArgs', 'QuotaScheduleScheduleListArgsDict']]]] schedule_lists: schedule list See `schedule_list` below.
153
+ :param pulumi.Input[str] timezone: Time zone, reference value: UTC +8
154
+ """
155
+ ...
156
+ @overload
157
+ def __init__(__self__,
158
+ resource_name: str,
159
+ args: QuotaScheduleArgs,
160
+ opts: Optional[pulumi.ResourceOptions] = None):
161
+ """
162
+ ## Import
163
+
164
+ Max Compute Quota Schedule can be imported using the id, e.g.
165
+
166
+ ```sh
167
+ $ pulumi import alicloud:maxcompute/quotaSchedule:QuotaSchedule example <nickname>:<timezone>
168
+ ```
169
+
170
+ :param str resource_name: The name of the resource.
171
+ :param QuotaScheduleArgs args: The arguments to use to populate this resource's properties.
172
+ :param pulumi.ResourceOptions opts: Options for the resource.
173
+ """
174
+ ...
175
+ def __init__(__self__, resource_name: str, *args, **kwargs):
176
+ resource_args, opts = _utilities.get_resource_args_opts(QuotaScheduleArgs, pulumi.ResourceOptions, *args, **kwargs)
177
+ if resource_args is not None:
178
+ __self__._internal_init(resource_name, opts, **resource_args.__dict__)
179
+ else:
180
+ __self__._internal_init(resource_name, *args, **kwargs)
181
+
182
+ def _internal_init(__self__,
183
+ resource_name: str,
184
+ opts: Optional[pulumi.ResourceOptions] = None,
185
+ nickname: Optional[pulumi.Input[str]] = None,
186
+ schedule_lists: Optional[pulumi.Input[Sequence[pulumi.Input[Union['QuotaScheduleScheduleListArgs', 'QuotaScheduleScheduleListArgsDict']]]]] = None,
187
+ timezone: Optional[pulumi.Input[str]] = None,
188
+ __props__=None):
189
+ opts = pulumi.ResourceOptions.merge(_utilities.get_resource_opts_defaults(), opts)
190
+ if not isinstance(opts, pulumi.ResourceOptions):
191
+ raise TypeError('Expected resource options to be a ResourceOptions instance')
192
+ if opts.id is None:
193
+ if __props__ is not None:
194
+ raise TypeError('__props__ is only valid when passed in combination with a valid opts.id to get an existing resource')
195
+ __props__ = QuotaScheduleArgs.__new__(QuotaScheduleArgs)
196
+
197
+ if nickname is None and not opts.urn:
198
+ raise TypeError("Missing required property 'nickname'")
199
+ __props__.__dict__["nickname"] = nickname
200
+ __props__.__dict__["schedule_lists"] = schedule_lists
201
+ if timezone is None and not opts.urn:
202
+ raise TypeError("Missing required property 'timezone'")
203
+ __props__.__dict__["timezone"] = timezone
204
+ super(QuotaSchedule, __self__).__init__(
205
+ 'alicloud:maxcompute/quotaSchedule:QuotaSchedule',
206
+ resource_name,
207
+ __props__,
208
+ opts)
209
+
210
+ @staticmethod
211
+ def get(resource_name: str,
212
+ id: pulumi.Input[str],
213
+ opts: Optional[pulumi.ResourceOptions] = None,
214
+ nickname: Optional[pulumi.Input[str]] = None,
215
+ schedule_lists: Optional[pulumi.Input[Sequence[pulumi.Input[Union['QuotaScheduleScheduleListArgs', 'QuotaScheduleScheduleListArgsDict']]]]] = None,
216
+ timezone: Optional[pulumi.Input[str]] = None) -> 'QuotaSchedule':
217
+ """
218
+ Get an existing QuotaSchedule resource's state with the given name, id, and optional extra
219
+ properties used to qualify the lookup.
220
+
221
+ :param str resource_name: The unique name of the resulting resource.
222
+ :param pulumi.Input[str] id: The unique provider ID of the resource to lookup.
223
+ :param pulumi.ResourceOptions opts: Options for the resource.
224
+ :param pulumi.Input[str] nickname: The nickname of level-1 compute quota.
225
+ :param pulumi.Input[Sequence[pulumi.Input[Union['QuotaScheduleScheduleListArgs', 'QuotaScheduleScheduleListArgsDict']]]] schedule_lists: schedule list See `schedule_list` below.
226
+ :param pulumi.Input[str] timezone: Time zone, reference value: UTC +8
227
+ """
228
+ opts = pulumi.ResourceOptions.merge(opts, pulumi.ResourceOptions(id=id))
229
+
230
+ __props__ = _QuotaScheduleState.__new__(_QuotaScheduleState)
231
+
232
+ __props__.__dict__["nickname"] = nickname
233
+ __props__.__dict__["schedule_lists"] = schedule_lists
234
+ __props__.__dict__["timezone"] = timezone
235
+ return QuotaSchedule(resource_name, opts=opts, __props__=__props__)
236
+
237
+ @property
238
+ @pulumi.getter
239
+ def nickname(self) -> pulumi.Output[str]:
240
+ """
241
+ The nickname of level-1 compute quota.
242
+ """
243
+ return pulumi.get(self, "nickname")
244
+
245
+ @property
246
+ @pulumi.getter(name="scheduleLists")
247
+ def schedule_lists(self) -> pulumi.Output[Optional[Sequence['outputs.QuotaScheduleScheduleList']]]:
248
+ """
249
+ schedule list See `schedule_list` below.
250
+ """
251
+ return pulumi.get(self, "schedule_lists")
252
+
253
+ @property
254
+ @pulumi.getter
255
+ def timezone(self) -> pulumi.Output[str]:
256
+ """
257
+ Time zone, reference value: UTC +8
258
+ """
259
+ return pulumi.get(self, "timezone")
260
+