pulumi-gcp 8.28.0a1745598508__py3-none-any.whl → 8.29.0a1746076904__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.
Files changed (78) hide show
  1. pulumi_gcp/__init__.py +88 -0
  2. pulumi_gcp/accesscontextmanager/_inputs.py +399 -0
  3. pulumi_gcp/accesscontextmanager/gcp_user_access_binding.py +54 -0
  4. pulumi_gcp/accesscontextmanager/outputs.py +369 -0
  5. pulumi_gcp/alloydb/_inputs.py +47 -1
  6. pulumi_gcp/alloydb/outputs.py +61 -3
  7. pulumi_gcp/apigee/keystores_aliases_self_signed_cert.py +8 -2
  8. pulumi_gcp/applicationintegration/client.py +34 -12
  9. pulumi_gcp/artifactregistry/outputs.py +2 -2
  10. pulumi_gcp/certificateauthority/_inputs.py +32 -0
  11. pulumi_gcp/certificateauthority/ca_pool.py +2 -0
  12. pulumi_gcp/certificateauthority/outputs.py +22 -0
  13. pulumi_gcp/clouddeploy/_inputs.py +0 -6
  14. pulumi_gcp/clouddeploy/delivery_pipeline.py +84 -77
  15. pulumi_gcp/clouddeploy/outputs.py +0 -4
  16. pulumi_gcp/cloudrunv2/_inputs.py +3 -3
  17. pulumi_gcp/cloudrunv2/outputs.py +4 -4
  18. pulumi_gcp/colab/runtime_template.py +3 -3
  19. pulumi_gcp/compute/__init__.py +7 -0
  20. pulumi_gcp/compute/_inputs.py +809 -1
  21. pulumi_gcp/compute/backend_service.py +89 -0
  22. pulumi_gcp/compute/firewall_policy_with_rules.py +2 -2
  23. pulumi_gcp/compute/get_backend_service.py +12 -1
  24. pulumi_gcp/compute/get_storage_pool_iam_policy.py +183 -0
  25. pulumi_gcp/compute/get_storage_pool_types.py +268 -0
  26. pulumi_gcp/compute/outputs.py +743 -3
  27. pulumi_gcp/compute/resource_policy_attachment.py +476 -0
  28. pulumi_gcp/compute/storage_pool.py +1045 -0
  29. pulumi_gcp/compute/storage_pool_iam_binding.py +1088 -0
  30. pulumi_gcp/compute/storage_pool_iam_member.py +1088 -0
  31. pulumi_gcp/compute/storage_pool_iam_policy.py +907 -0
  32. pulumi_gcp/config/__init__.pyi +2 -0
  33. pulumi_gcp/config/vars.py +4 -0
  34. pulumi_gcp/container/_inputs.py +63 -3
  35. pulumi_gcp/container/outputs.py +70 -6
  36. pulumi_gcp/dataproc/get_metastore_service.py +12 -1
  37. pulumi_gcp/dataproc/metastore_service.py +61 -0
  38. pulumi_gcp/datastream/connection_profile.py +40 -0
  39. pulumi_gcp/discoveryengine/_inputs.py +38 -0
  40. pulumi_gcp/discoveryengine/chat_engine.py +6 -4
  41. pulumi_gcp/discoveryengine/outputs.py +26 -0
  42. pulumi_gcp/firebaserules/_inputs.py +6 -6
  43. pulumi_gcp/firebaserules/outputs.py +4 -4
  44. pulumi_gcp/gkebackup/__init__.py +2 -0
  45. pulumi_gcp/gkebackup/backup_channel.py +737 -0
  46. pulumi_gcp/gkebackup/restore_channel.py +737 -0
  47. pulumi_gcp/gkehub/_inputs.py +208 -0
  48. pulumi_gcp/gkehub/outputs.py +171 -1
  49. pulumi_gcp/healthcare/pipeline_job.py +2 -2
  50. pulumi_gcp/iap/__init__.py +4 -0
  51. pulumi_gcp/iap/_inputs.py +130 -0
  52. pulumi_gcp/iap/get_web_cloud_run_service_iam_policy.py +183 -0
  53. pulumi_gcp/iap/outputs.py +76 -0
  54. pulumi_gcp/iap/web_cloud_run_service_iam_binding.py +1089 -0
  55. pulumi_gcp/iap/web_cloud_run_service_iam_member.py +1089 -0
  56. pulumi_gcp/iap/web_cloud_run_service_iam_policy.py +908 -0
  57. pulumi_gcp/kms/key_ring_import_job.py +7 -7
  58. pulumi_gcp/managedkafka/connect_cluster.py +8 -4
  59. pulumi_gcp/managedkafka/connector.py +8 -4
  60. pulumi_gcp/monitoring/uptime_check_config.py +49 -0
  61. pulumi_gcp/networkconnectivity/internal_range.py +82 -0
  62. pulumi_gcp/projects/_inputs.py +0 -6
  63. pulumi_gcp/projects/api_key.py +28 -0
  64. pulumi_gcp/projects/outputs.py +0 -4
  65. pulumi_gcp/provider.py +20 -0
  66. pulumi_gcp/pulumi-plugin.json +1 -1
  67. pulumi_gcp/redis/get_instance.py +12 -1
  68. pulumi_gcp/redis/instance.py +61 -0
  69. pulumi_gcp/sql/_inputs.py +86 -6
  70. pulumi_gcp/sql/outputs.py +156 -12
  71. pulumi_gcp/storage/__init__.py +1 -0
  72. pulumi_gcp/storage/_inputs.py +457 -0
  73. pulumi_gcp/storage/batch_operations_job.py +776 -0
  74. pulumi_gcp/storage/outputs.py +403 -0
  75. {pulumi_gcp-8.28.0a1745598508.dist-info → pulumi_gcp-8.29.0a1746076904.dist-info}/METADATA +1 -1
  76. {pulumi_gcp-8.28.0a1745598508.dist-info → pulumi_gcp-8.29.0a1746076904.dist-info}/RECORD +78 -64
  77. {pulumi_gcp-8.28.0a1745598508.dist-info → pulumi_gcp-8.29.0a1746076904.dist-info}/WHEEL +1 -1
  78. {pulumi_gcp-8.28.0a1745598508.dist-info → pulumi_gcp-8.29.0a1746076904.dist-info}/top_level.txt +0 -0
@@ -25,6 +25,7 @@ class GcpUserAccessBindingArgs:
25
25
  group_key: pulumi.Input[builtins.str],
26
26
  organization_id: pulumi.Input[builtins.str],
27
27
  access_levels: Optional[pulumi.Input[builtins.str]] = None,
28
+ scoped_access_settings: Optional[pulumi.Input[Sequence[pulumi.Input['GcpUserAccessBindingScopedAccessSettingArgs']]]] = None,
28
29
  session_settings: Optional[pulumi.Input['GcpUserAccessBindingSessionSettingsArgs']] = None):
29
30
  """
30
31
  The set of arguments for constructing a GcpUserAccessBinding resource.
@@ -34,6 +35,8 @@ class GcpUserAccessBindingArgs:
34
35
 
35
36
  - - -
36
37
  :param pulumi.Input[builtins.str] access_levels: Optional. Access level that a user must have to be granted access. Only one access level is supported, not multiple. This repeated field must have exactly one element. Example: "accessPolicies/9522/accessLevels/device_trusted"
38
+ :param pulumi.Input[Sequence[pulumi.Input['GcpUserAccessBindingScopedAccessSettingArgs']]] scoped_access_settings: Optional. A list of scoped access settings that set this binding's restrictions on a subset of applications.
39
+ Structure is documented below.
37
40
  :param pulumi.Input['GcpUserAccessBindingSessionSettingsArgs'] session_settings: Optional. The Google Cloud session length (GCSL) policy for the group key.
38
41
  Structure is documented below.
39
42
  """
@@ -41,6 +44,8 @@ class GcpUserAccessBindingArgs:
41
44
  pulumi.set(__self__, "organization_id", organization_id)
42
45
  if access_levels is not None:
43
46
  pulumi.set(__self__, "access_levels", access_levels)
47
+ if scoped_access_settings is not None:
48
+ pulumi.set(__self__, "scoped_access_settings", scoped_access_settings)
44
49
  if session_settings is not None:
45
50
  pulumi.set(__self__, "session_settings", session_settings)
46
51
 
@@ -83,6 +88,19 @@ class GcpUserAccessBindingArgs:
83
88
  def access_levels(self, value: Optional[pulumi.Input[builtins.str]]):
84
89
  pulumi.set(self, "access_levels", value)
85
90
 
91
+ @property
92
+ @pulumi.getter(name="scopedAccessSettings")
93
+ def scoped_access_settings(self) -> Optional[pulumi.Input[Sequence[pulumi.Input['GcpUserAccessBindingScopedAccessSettingArgs']]]]:
94
+ """
95
+ Optional. A list of scoped access settings that set this binding's restrictions on a subset of applications.
96
+ Structure is documented below.
97
+ """
98
+ return pulumi.get(self, "scoped_access_settings")
99
+
100
+ @scoped_access_settings.setter
101
+ def scoped_access_settings(self, value: Optional[pulumi.Input[Sequence[pulumi.Input['GcpUserAccessBindingScopedAccessSettingArgs']]]]):
102
+ pulumi.set(self, "scoped_access_settings", value)
103
+
86
104
  @property
87
105
  @pulumi.getter(name="sessionSettings")
88
106
  def session_settings(self) -> Optional[pulumi.Input['GcpUserAccessBindingSessionSettingsArgs']]:
@@ -104,6 +122,7 @@ class _GcpUserAccessBindingState:
104
122
  group_key: Optional[pulumi.Input[builtins.str]] = None,
105
123
  name: Optional[pulumi.Input[builtins.str]] = None,
106
124
  organization_id: Optional[pulumi.Input[builtins.str]] = None,
125
+ scoped_access_settings: Optional[pulumi.Input[Sequence[pulumi.Input['GcpUserAccessBindingScopedAccessSettingArgs']]]] = None,
107
126
  session_settings: Optional[pulumi.Input['GcpUserAccessBindingSessionSettingsArgs']] = None):
108
127
  """
109
128
  Input properties used for looking up and filtering GcpUserAccessBinding resources.
@@ -114,6 +133,8 @@ class _GcpUserAccessBindingState:
114
133
 
115
134
 
116
135
  - - -
136
+ :param pulumi.Input[Sequence[pulumi.Input['GcpUserAccessBindingScopedAccessSettingArgs']]] scoped_access_settings: Optional. A list of scoped access settings that set this binding's restrictions on a subset of applications.
137
+ Structure is documented below.
117
138
  :param pulumi.Input['GcpUserAccessBindingSessionSettingsArgs'] session_settings: Optional. The Google Cloud session length (GCSL) policy for the group key.
118
139
  Structure is documented below.
119
140
  """
@@ -125,6 +146,8 @@ class _GcpUserAccessBindingState:
125
146
  pulumi.set(__self__, "name", name)
126
147
  if organization_id is not None:
127
148
  pulumi.set(__self__, "organization_id", organization_id)
149
+ if scoped_access_settings is not None:
150
+ pulumi.set(__self__, "scoped_access_settings", scoped_access_settings)
128
151
  if session_settings is not None:
129
152
  pulumi.set(__self__, "session_settings", session_settings)
130
153
 
@@ -179,6 +202,19 @@ class _GcpUserAccessBindingState:
179
202
  def organization_id(self, value: Optional[pulumi.Input[builtins.str]]):
180
203
  pulumi.set(self, "organization_id", value)
181
204
 
205
+ @property
206
+ @pulumi.getter(name="scopedAccessSettings")
207
+ def scoped_access_settings(self) -> Optional[pulumi.Input[Sequence[pulumi.Input['GcpUserAccessBindingScopedAccessSettingArgs']]]]:
208
+ """
209
+ Optional. A list of scoped access settings that set this binding's restrictions on a subset of applications.
210
+ Structure is documented below.
211
+ """
212
+ return pulumi.get(self, "scoped_access_settings")
213
+
214
+ @scoped_access_settings.setter
215
+ def scoped_access_settings(self, value: Optional[pulumi.Input[Sequence[pulumi.Input['GcpUserAccessBindingScopedAccessSettingArgs']]]]):
216
+ pulumi.set(self, "scoped_access_settings", value)
217
+
182
218
  @property
183
219
  @pulumi.getter(name="sessionSettings")
184
220
  def session_settings(self) -> Optional[pulumi.Input['GcpUserAccessBindingSessionSettingsArgs']]:
@@ -201,6 +237,7 @@ class GcpUserAccessBinding(pulumi.CustomResource):
201
237
  access_levels: Optional[pulumi.Input[builtins.str]] = None,
202
238
  group_key: Optional[pulumi.Input[builtins.str]] = None,
203
239
  organization_id: Optional[pulumi.Input[builtins.str]] = None,
240
+ scoped_access_settings: Optional[pulumi.Input[Sequence[pulumi.Input[Union['GcpUserAccessBindingScopedAccessSettingArgs', 'GcpUserAccessBindingScopedAccessSettingArgsDict']]]]] = None,
204
241
  session_settings: Optional[pulumi.Input[Union['GcpUserAccessBindingSessionSettingsArgs', 'GcpUserAccessBindingSessionSettingsArgsDict']]] = None,
205
242
  __props__=None):
206
243
  """
@@ -273,6 +310,8 @@ class GcpUserAccessBinding(pulumi.CustomResource):
273
310
 
274
311
 
275
312
  - - -
313
+ :param pulumi.Input[Sequence[pulumi.Input[Union['GcpUserAccessBindingScopedAccessSettingArgs', 'GcpUserAccessBindingScopedAccessSettingArgsDict']]]] scoped_access_settings: Optional. A list of scoped access settings that set this binding's restrictions on a subset of applications.
314
+ Structure is documented below.
276
315
  :param pulumi.Input[Union['GcpUserAccessBindingSessionSettingsArgs', 'GcpUserAccessBindingSessionSettingsArgsDict']] session_settings: Optional. The Google Cloud session length (GCSL) policy for the group key.
277
316
  Structure is documented below.
278
317
  """
@@ -362,6 +401,7 @@ class GcpUserAccessBinding(pulumi.CustomResource):
362
401
  access_levels: Optional[pulumi.Input[builtins.str]] = None,
363
402
  group_key: Optional[pulumi.Input[builtins.str]] = None,
364
403
  organization_id: Optional[pulumi.Input[builtins.str]] = None,
404
+ scoped_access_settings: Optional[pulumi.Input[Sequence[pulumi.Input[Union['GcpUserAccessBindingScopedAccessSettingArgs', 'GcpUserAccessBindingScopedAccessSettingArgsDict']]]]] = None,
365
405
  session_settings: Optional[pulumi.Input[Union['GcpUserAccessBindingSessionSettingsArgs', 'GcpUserAccessBindingSessionSettingsArgsDict']]] = None,
366
406
  __props__=None):
367
407
  opts = pulumi.ResourceOptions.merge(_utilities.get_resource_opts_defaults(), opts)
@@ -379,6 +419,7 @@ class GcpUserAccessBinding(pulumi.CustomResource):
379
419
  if organization_id is None and not opts.urn:
380
420
  raise TypeError("Missing required property 'organization_id'")
381
421
  __props__.__dict__["organization_id"] = organization_id
422
+ __props__.__dict__["scoped_access_settings"] = scoped_access_settings
382
423
  __props__.__dict__["session_settings"] = session_settings
383
424
  __props__.__dict__["name"] = None
384
425
  super(GcpUserAccessBinding, __self__).__init__(
@@ -395,6 +436,7 @@ class GcpUserAccessBinding(pulumi.CustomResource):
395
436
  group_key: Optional[pulumi.Input[builtins.str]] = None,
396
437
  name: Optional[pulumi.Input[builtins.str]] = None,
397
438
  organization_id: Optional[pulumi.Input[builtins.str]] = None,
439
+ scoped_access_settings: Optional[pulumi.Input[Sequence[pulumi.Input[Union['GcpUserAccessBindingScopedAccessSettingArgs', 'GcpUserAccessBindingScopedAccessSettingArgsDict']]]]] = None,
398
440
  session_settings: Optional[pulumi.Input[Union['GcpUserAccessBindingSessionSettingsArgs', 'GcpUserAccessBindingSessionSettingsArgsDict']]] = None) -> 'GcpUserAccessBinding':
399
441
  """
400
442
  Get an existing GcpUserAccessBinding resource's state with the given name, id, and optional extra
@@ -410,6 +452,8 @@ class GcpUserAccessBinding(pulumi.CustomResource):
410
452
 
411
453
 
412
454
  - - -
455
+ :param pulumi.Input[Sequence[pulumi.Input[Union['GcpUserAccessBindingScopedAccessSettingArgs', 'GcpUserAccessBindingScopedAccessSettingArgsDict']]]] scoped_access_settings: Optional. A list of scoped access settings that set this binding's restrictions on a subset of applications.
456
+ Structure is documented below.
413
457
  :param pulumi.Input[Union['GcpUserAccessBindingSessionSettingsArgs', 'GcpUserAccessBindingSessionSettingsArgsDict']] session_settings: Optional. The Google Cloud session length (GCSL) policy for the group key.
414
458
  Structure is documented below.
415
459
  """
@@ -421,6 +465,7 @@ class GcpUserAccessBinding(pulumi.CustomResource):
421
465
  __props__.__dict__["group_key"] = group_key
422
466
  __props__.__dict__["name"] = name
423
467
  __props__.__dict__["organization_id"] = organization_id
468
+ __props__.__dict__["scoped_access_settings"] = scoped_access_settings
424
469
  __props__.__dict__["session_settings"] = session_settings
425
470
  return GcpUserAccessBinding(resource_name, opts=opts, __props__=__props__)
426
471
 
@@ -459,6 +504,15 @@ class GcpUserAccessBinding(pulumi.CustomResource):
459
504
  """
460
505
  return pulumi.get(self, "organization_id")
461
506
 
507
+ @property
508
+ @pulumi.getter(name="scopedAccessSettings")
509
+ def scoped_access_settings(self) -> pulumi.Output[Optional[Sequence['outputs.GcpUserAccessBindingScopedAccessSetting']]]:
510
+ """
511
+ Optional. A list of scoped access settings that set this binding's restrictions on a subset of applications.
512
+ Structure is documented below.
513
+ """
514
+ return pulumi.get(self, "scoped_access_settings")
515
+
462
516
  @property
463
517
  @pulumi.getter(name="sessionSettings")
464
518
  def session_settings(self) -> pulumi.Output[Optional['outputs.GcpUserAccessBindingSessionSettings']]:
@@ -40,6 +40,13 @@ __all__ = [
40
40
  'AccessLevelsAccessLevelCustomExpr',
41
41
  'AccessPolicyIamBindingCondition',
42
42
  'AccessPolicyIamMemberCondition',
43
+ 'GcpUserAccessBindingScopedAccessSetting',
44
+ 'GcpUserAccessBindingScopedAccessSettingActiveSettings',
45
+ 'GcpUserAccessBindingScopedAccessSettingActiveSettingsSessionSettings',
46
+ 'GcpUserAccessBindingScopedAccessSettingDryRunSettings',
47
+ 'GcpUserAccessBindingScopedAccessSettingScope',
48
+ 'GcpUserAccessBindingScopedAccessSettingScopeClientScope',
49
+ 'GcpUserAccessBindingScopedAccessSettingScopeClientScopeRestrictedClientApplication',
43
50
  'GcpUserAccessBindingSessionSettings',
44
51
  'ServicePerimeterDryRunEgressPolicyEgressFrom',
45
52
  'ServicePerimeterDryRunEgressPolicyEgressFromSource',
@@ -1657,6 +1664,368 @@ class AccessPolicyIamMemberCondition(dict):
1657
1664
  return pulumi.get(self, "description")
1658
1665
 
1659
1666
 
1667
+ @pulumi.output_type
1668
+ class GcpUserAccessBindingScopedAccessSetting(dict):
1669
+ @staticmethod
1670
+ def __key_warning(key: str):
1671
+ suggest = None
1672
+ if key == "activeSettings":
1673
+ suggest = "active_settings"
1674
+ elif key == "dryRunSettings":
1675
+ suggest = "dry_run_settings"
1676
+
1677
+ if suggest:
1678
+ pulumi.log.warn(f"Key '{key}' not found in GcpUserAccessBindingScopedAccessSetting. Access the value via the '{suggest}' property getter instead.")
1679
+
1680
+ def __getitem__(self, key: str) -> Any:
1681
+ GcpUserAccessBindingScopedAccessSetting.__key_warning(key)
1682
+ return super().__getitem__(key)
1683
+
1684
+ def get(self, key: str, default = None) -> Any:
1685
+ GcpUserAccessBindingScopedAccessSetting.__key_warning(key)
1686
+ return super().get(key, default)
1687
+
1688
+ def __init__(__self__, *,
1689
+ active_settings: Optional['outputs.GcpUserAccessBindingScopedAccessSettingActiveSettings'] = None,
1690
+ dry_run_settings: Optional['outputs.GcpUserAccessBindingScopedAccessSettingDryRunSettings'] = None,
1691
+ scope: Optional['outputs.GcpUserAccessBindingScopedAccessSettingScope'] = None):
1692
+ """
1693
+ :param 'GcpUserAccessBindingScopedAccessSettingActiveSettingsArgs' active_settings: Optional. Access settings for this scoped access settings. This field may be empty if dryRunSettings is set.
1694
+ Structure is documented below.
1695
+ :param 'GcpUserAccessBindingScopedAccessSettingDryRunSettingsArgs' dry_run_settings: Optional. Dry-run access settings for this scoped access settings. This field may be empty if activeSettings is set. Cannot contain session settings.
1696
+ Structure is documented below.
1697
+ :param 'GcpUserAccessBindingScopedAccessSettingScopeArgs' scope: Optional. Application, etc. to which the access settings will be applied to. Implicitly, this is the scoped access settings key; as such, it must be unique and non-empty.
1698
+ Structure is documented below.
1699
+ """
1700
+ if active_settings is not None:
1701
+ pulumi.set(__self__, "active_settings", active_settings)
1702
+ if dry_run_settings is not None:
1703
+ pulumi.set(__self__, "dry_run_settings", dry_run_settings)
1704
+ if scope is not None:
1705
+ pulumi.set(__self__, "scope", scope)
1706
+
1707
+ @property
1708
+ @pulumi.getter(name="activeSettings")
1709
+ def active_settings(self) -> Optional['outputs.GcpUserAccessBindingScopedAccessSettingActiveSettings']:
1710
+ """
1711
+ Optional. Access settings for this scoped access settings. This field may be empty if dryRunSettings is set.
1712
+ Structure is documented below.
1713
+ """
1714
+ return pulumi.get(self, "active_settings")
1715
+
1716
+ @property
1717
+ @pulumi.getter(name="dryRunSettings")
1718
+ def dry_run_settings(self) -> Optional['outputs.GcpUserAccessBindingScopedAccessSettingDryRunSettings']:
1719
+ """
1720
+ Optional. Dry-run access settings for this scoped access settings. This field may be empty if activeSettings is set. Cannot contain session settings.
1721
+ Structure is documented below.
1722
+ """
1723
+ return pulumi.get(self, "dry_run_settings")
1724
+
1725
+ @property
1726
+ @pulumi.getter
1727
+ def scope(self) -> Optional['outputs.GcpUserAccessBindingScopedAccessSettingScope']:
1728
+ """
1729
+ Optional. Application, etc. to which the access settings will be applied to. Implicitly, this is the scoped access settings key; as such, it must be unique and non-empty.
1730
+ Structure is documented below.
1731
+ """
1732
+ return pulumi.get(self, "scope")
1733
+
1734
+
1735
+ @pulumi.output_type
1736
+ class GcpUserAccessBindingScopedAccessSettingActiveSettings(dict):
1737
+ @staticmethod
1738
+ def __key_warning(key: str):
1739
+ suggest = None
1740
+ if key == "accessLevels":
1741
+ suggest = "access_levels"
1742
+ elif key == "sessionSettings":
1743
+ suggest = "session_settings"
1744
+
1745
+ if suggest:
1746
+ pulumi.log.warn(f"Key '{key}' not found in GcpUserAccessBindingScopedAccessSettingActiveSettings. Access the value via the '{suggest}' property getter instead.")
1747
+
1748
+ def __getitem__(self, key: str) -> Any:
1749
+ GcpUserAccessBindingScopedAccessSettingActiveSettings.__key_warning(key)
1750
+ return super().__getitem__(key)
1751
+
1752
+ def get(self, key: str, default = None) -> Any:
1753
+ GcpUserAccessBindingScopedAccessSettingActiveSettings.__key_warning(key)
1754
+ return super().get(key, default)
1755
+
1756
+ def __init__(__self__, *,
1757
+ access_levels: Optional[Sequence[builtins.str]] = None,
1758
+ session_settings: Optional['outputs.GcpUserAccessBindingScopedAccessSettingActiveSettingsSessionSettings'] = None):
1759
+ """
1760
+ :param Sequence[builtins.str] access_levels: Optional. Access level that a user must have to be granted access. Only one access level is supported, not multiple. This repeated field must have exactly one element. Example: "accessPolicies/9522/accessLevels/device_trusted"
1761
+ :param 'GcpUserAccessBindingScopedAccessSettingActiveSettingsSessionSettingsArgs' session_settings: Optional. Session settings applied to user access on a given AccessScope.
1762
+ Structure is documented below.
1763
+ """
1764
+ if access_levels is not None:
1765
+ pulumi.set(__self__, "access_levels", access_levels)
1766
+ if session_settings is not None:
1767
+ pulumi.set(__self__, "session_settings", session_settings)
1768
+
1769
+ @property
1770
+ @pulumi.getter(name="accessLevels")
1771
+ def access_levels(self) -> Optional[Sequence[builtins.str]]:
1772
+ """
1773
+ Optional. Access level that a user must have to be granted access. Only one access level is supported, not multiple. This repeated field must have exactly one element. Example: "accessPolicies/9522/accessLevels/device_trusted"
1774
+ """
1775
+ return pulumi.get(self, "access_levels")
1776
+
1777
+ @property
1778
+ @pulumi.getter(name="sessionSettings")
1779
+ def session_settings(self) -> Optional['outputs.GcpUserAccessBindingScopedAccessSettingActiveSettingsSessionSettings']:
1780
+ """
1781
+ Optional. Session settings applied to user access on a given AccessScope.
1782
+ Structure is documented below.
1783
+ """
1784
+ return pulumi.get(self, "session_settings")
1785
+
1786
+
1787
+ @pulumi.output_type
1788
+ class GcpUserAccessBindingScopedAccessSettingActiveSettingsSessionSettings(dict):
1789
+ @staticmethod
1790
+ def __key_warning(key: str):
1791
+ suggest = None
1792
+ if key == "maxInactivity":
1793
+ suggest = "max_inactivity"
1794
+ elif key == "sessionLength":
1795
+ suggest = "session_length"
1796
+ elif key == "sessionLengthEnabled":
1797
+ suggest = "session_length_enabled"
1798
+ elif key == "sessionReauthMethod":
1799
+ suggest = "session_reauth_method"
1800
+ elif key == "useOidcMaxAge":
1801
+ suggest = "use_oidc_max_age"
1802
+
1803
+ if suggest:
1804
+ pulumi.log.warn(f"Key '{key}' not found in GcpUserAccessBindingScopedAccessSettingActiveSettingsSessionSettings. Access the value via the '{suggest}' property getter instead.")
1805
+
1806
+ def __getitem__(self, key: str) -> Any:
1807
+ GcpUserAccessBindingScopedAccessSettingActiveSettingsSessionSettings.__key_warning(key)
1808
+ return super().__getitem__(key)
1809
+
1810
+ def get(self, key: str, default = None) -> Any:
1811
+ GcpUserAccessBindingScopedAccessSettingActiveSettingsSessionSettings.__key_warning(key)
1812
+ return super().get(key, default)
1813
+
1814
+ def __init__(__self__, *,
1815
+ max_inactivity: Optional[builtins.str] = None,
1816
+ session_length: Optional[builtins.str] = None,
1817
+ session_length_enabled: Optional[builtins.bool] = None,
1818
+ session_reauth_method: Optional[builtins.str] = None,
1819
+ use_oidc_max_age: Optional[builtins.bool] = None):
1820
+ """
1821
+ :param builtins.str max_inactivity: Optional. How long a user is allowed to take between actions before a new access token must be issued. Only set for Google Cloud apps.
1822
+ :param builtins.str session_length: Optional. The session length. Setting this field to zero is equal to disabling session. Also can set infinite session by flipping the enabled bit to false below. If useOidcMaxAge is true, for OIDC apps, the session length will be the minimum of this field and OIDC max_age param.
1823
+ :param builtins.bool session_length_enabled: Optional. This field enables or disables Google Cloud session length. When false, all fields set above will be disregarded and the session length is basically infinite.
1824
+ :param builtins.str session_reauth_method: Optional. The session challenges proposed to users when the Google Cloud session length is up.
1825
+ Possible values are: `LOGIN`, `SECURITY_KEY`, `PASSWORD`.
1826
+ :param builtins.bool use_oidc_max_age: Optional. Only useful for OIDC apps. When false, the OIDC max_age param, if passed in the authentication request will be ignored. When true, the re-auth period will be the minimum of the sessionLength field and the max_age OIDC param.
1827
+ """
1828
+ if max_inactivity is not None:
1829
+ pulumi.set(__self__, "max_inactivity", max_inactivity)
1830
+ if session_length is not None:
1831
+ pulumi.set(__self__, "session_length", session_length)
1832
+ if session_length_enabled is not None:
1833
+ pulumi.set(__self__, "session_length_enabled", session_length_enabled)
1834
+ if session_reauth_method is not None:
1835
+ pulumi.set(__self__, "session_reauth_method", session_reauth_method)
1836
+ if use_oidc_max_age is not None:
1837
+ pulumi.set(__self__, "use_oidc_max_age", use_oidc_max_age)
1838
+
1839
+ @property
1840
+ @pulumi.getter(name="maxInactivity")
1841
+ def max_inactivity(self) -> Optional[builtins.str]:
1842
+ """
1843
+ Optional. How long a user is allowed to take between actions before a new access token must be issued. Only set for Google Cloud apps.
1844
+ """
1845
+ return pulumi.get(self, "max_inactivity")
1846
+
1847
+ @property
1848
+ @pulumi.getter(name="sessionLength")
1849
+ def session_length(self) -> Optional[builtins.str]:
1850
+ """
1851
+ Optional. The session length. Setting this field to zero is equal to disabling session. Also can set infinite session by flipping the enabled bit to false below. If useOidcMaxAge is true, for OIDC apps, the session length will be the minimum of this field and OIDC max_age param.
1852
+ """
1853
+ return pulumi.get(self, "session_length")
1854
+
1855
+ @property
1856
+ @pulumi.getter(name="sessionLengthEnabled")
1857
+ def session_length_enabled(self) -> Optional[builtins.bool]:
1858
+ """
1859
+ Optional. This field enables or disables Google Cloud session length. When false, all fields set above will be disregarded and the session length is basically infinite.
1860
+ """
1861
+ return pulumi.get(self, "session_length_enabled")
1862
+
1863
+ @property
1864
+ @pulumi.getter(name="sessionReauthMethod")
1865
+ def session_reauth_method(self) -> Optional[builtins.str]:
1866
+ """
1867
+ Optional. The session challenges proposed to users when the Google Cloud session length is up.
1868
+ Possible values are: `LOGIN`, `SECURITY_KEY`, `PASSWORD`.
1869
+ """
1870
+ return pulumi.get(self, "session_reauth_method")
1871
+
1872
+ @property
1873
+ @pulumi.getter(name="useOidcMaxAge")
1874
+ def use_oidc_max_age(self) -> Optional[builtins.bool]:
1875
+ """
1876
+ Optional. Only useful for OIDC apps. When false, the OIDC max_age param, if passed in the authentication request will be ignored. When true, the re-auth period will be the minimum of the sessionLength field and the max_age OIDC param.
1877
+ """
1878
+ return pulumi.get(self, "use_oidc_max_age")
1879
+
1880
+
1881
+ @pulumi.output_type
1882
+ class GcpUserAccessBindingScopedAccessSettingDryRunSettings(dict):
1883
+ @staticmethod
1884
+ def __key_warning(key: str):
1885
+ suggest = None
1886
+ if key == "accessLevels":
1887
+ suggest = "access_levels"
1888
+
1889
+ if suggest:
1890
+ pulumi.log.warn(f"Key '{key}' not found in GcpUserAccessBindingScopedAccessSettingDryRunSettings. Access the value via the '{suggest}' property getter instead.")
1891
+
1892
+ def __getitem__(self, key: str) -> Any:
1893
+ GcpUserAccessBindingScopedAccessSettingDryRunSettings.__key_warning(key)
1894
+ return super().__getitem__(key)
1895
+
1896
+ def get(self, key: str, default = None) -> Any:
1897
+ GcpUserAccessBindingScopedAccessSettingDryRunSettings.__key_warning(key)
1898
+ return super().get(key, default)
1899
+
1900
+ def __init__(__self__, *,
1901
+ access_levels: Optional[builtins.str] = None):
1902
+ """
1903
+ :param builtins.str access_levels: Optional. Access level that a user must have to be granted access. Only one access level is supported, not multiple. This repeated field must have exactly one element. Example: "accessPolicies/9522/accessLevels/device_trusted"
1904
+ """
1905
+ if access_levels is not None:
1906
+ pulumi.set(__self__, "access_levels", access_levels)
1907
+
1908
+ @property
1909
+ @pulumi.getter(name="accessLevels")
1910
+ def access_levels(self) -> Optional[builtins.str]:
1911
+ """
1912
+ Optional. Access level that a user must have to be granted access. Only one access level is supported, not multiple. This repeated field must have exactly one element. Example: "accessPolicies/9522/accessLevels/device_trusted"
1913
+ """
1914
+ return pulumi.get(self, "access_levels")
1915
+
1916
+
1917
+ @pulumi.output_type
1918
+ class GcpUserAccessBindingScopedAccessSettingScope(dict):
1919
+ @staticmethod
1920
+ def __key_warning(key: str):
1921
+ suggest = None
1922
+ if key == "clientScope":
1923
+ suggest = "client_scope"
1924
+
1925
+ if suggest:
1926
+ pulumi.log.warn(f"Key '{key}' not found in GcpUserAccessBindingScopedAccessSettingScope. Access the value via the '{suggest}' property getter instead.")
1927
+
1928
+ def __getitem__(self, key: str) -> Any:
1929
+ GcpUserAccessBindingScopedAccessSettingScope.__key_warning(key)
1930
+ return super().__getitem__(key)
1931
+
1932
+ def get(self, key: str, default = None) -> Any:
1933
+ GcpUserAccessBindingScopedAccessSettingScope.__key_warning(key)
1934
+ return super().get(key, default)
1935
+
1936
+ def __init__(__self__, *,
1937
+ client_scope: Optional['outputs.GcpUserAccessBindingScopedAccessSettingScopeClientScope'] = None):
1938
+ """
1939
+ :param 'GcpUserAccessBindingScopedAccessSettingScopeClientScopeArgs' client_scope: Optional. Client scope for this access scope.
1940
+ Structure is documented below.
1941
+ """
1942
+ if client_scope is not None:
1943
+ pulumi.set(__self__, "client_scope", client_scope)
1944
+
1945
+ @property
1946
+ @pulumi.getter(name="clientScope")
1947
+ def client_scope(self) -> Optional['outputs.GcpUserAccessBindingScopedAccessSettingScopeClientScope']:
1948
+ """
1949
+ Optional. Client scope for this access scope.
1950
+ Structure is documented below.
1951
+ """
1952
+ return pulumi.get(self, "client_scope")
1953
+
1954
+
1955
+ @pulumi.output_type
1956
+ class GcpUserAccessBindingScopedAccessSettingScopeClientScope(dict):
1957
+ @staticmethod
1958
+ def __key_warning(key: str):
1959
+ suggest = None
1960
+ if key == "restrictedClientApplication":
1961
+ suggest = "restricted_client_application"
1962
+
1963
+ if suggest:
1964
+ pulumi.log.warn(f"Key '{key}' not found in GcpUserAccessBindingScopedAccessSettingScopeClientScope. Access the value via the '{suggest}' property getter instead.")
1965
+
1966
+ def __getitem__(self, key: str) -> Any:
1967
+ GcpUserAccessBindingScopedAccessSettingScopeClientScope.__key_warning(key)
1968
+ return super().__getitem__(key)
1969
+
1970
+ def get(self, key: str, default = None) -> Any:
1971
+ GcpUserAccessBindingScopedAccessSettingScopeClientScope.__key_warning(key)
1972
+ return super().get(key, default)
1973
+
1974
+ def __init__(__self__, *,
1975
+ restricted_client_application: Optional['outputs.GcpUserAccessBindingScopedAccessSettingScopeClientScopeRestrictedClientApplication'] = None):
1976
+ """
1977
+ :param 'GcpUserAccessBindingScopedAccessSettingScopeClientScopeRestrictedClientApplicationArgs' restricted_client_application: Optional. The application that is subject to this binding's scope.
1978
+ Structure is documented below.
1979
+ """
1980
+ if restricted_client_application is not None:
1981
+ pulumi.set(__self__, "restricted_client_application", restricted_client_application)
1982
+
1983
+ @property
1984
+ @pulumi.getter(name="restrictedClientApplication")
1985
+ def restricted_client_application(self) -> Optional['outputs.GcpUserAccessBindingScopedAccessSettingScopeClientScopeRestrictedClientApplication']:
1986
+ """
1987
+ Optional. The application that is subject to this binding's scope.
1988
+ Structure is documented below.
1989
+ """
1990
+ return pulumi.get(self, "restricted_client_application")
1991
+
1992
+
1993
+ @pulumi.output_type
1994
+ class GcpUserAccessBindingScopedAccessSettingScopeClientScopeRestrictedClientApplication(dict):
1995
+ @staticmethod
1996
+ def __key_warning(key: str):
1997
+ suggest = None
1998
+ if key == "clientId":
1999
+ suggest = "client_id"
2000
+
2001
+ if suggest:
2002
+ pulumi.log.warn(f"Key '{key}' not found in GcpUserAccessBindingScopedAccessSettingScopeClientScopeRestrictedClientApplication. Access the value via the '{suggest}' property getter instead.")
2003
+
2004
+ def __getitem__(self, key: str) -> Any:
2005
+ GcpUserAccessBindingScopedAccessSettingScopeClientScopeRestrictedClientApplication.__key_warning(key)
2006
+ return super().__getitem__(key)
2007
+
2008
+ def get(self, key: str, default = None) -> Any:
2009
+ GcpUserAccessBindingScopedAccessSettingScopeClientScopeRestrictedClientApplication.__key_warning(key)
2010
+ return super().get(key, default)
2011
+
2012
+ def __init__(__self__, *,
2013
+ client_id: Optional[builtins.str] = None):
2014
+ """
2015
+ :param builtins.str client_id: The OAuth client ID of the application.
2016
+ """
2017
+ if client_id is not None:
2018
+ pulumi.set(__self__, "client_id", client_id)
2019
+
2020
+ @property
2021
+ @pulumi.getter(name="clientId")
2022
+ def client_id(self) -> Optional[builtins.str]:
2023
+ """
2024
+ The OAuth client ID of the application.
2025
+ """
2026
+ return pulumi.get(self, "client_id")
2027
+
2028
+
1660
2029
  @pulumi.output_type
1661
2030
  class GcpUserAccessBindingSessionSettings(dict):
1662
2031
  @staticmethod
@@ -1804,18 +1804,30 @@ if not MYPY:
1804
1804
  """
1805
1805
  The number of CPU's in the VM instance.
1806
1806
  """
1807
+ machine_type: NotRequired[pulumi.Input[builtins.str]]
1808
+ """
1809
+ Machine type of the VM instance.
1810
+ E.g. "n2-highmem-4", "n2-highmem-8", "c4a-highmem-4-lssd".
1811
+ `cpu_count` must match the number of vCPUs in the machine type.
1812
+ """
1807
1813
  elif False:
1808
1814
  InstanceMachineConfigArgsDict: TypeAlias = Mapping[str, Any]
1809
1815
 
1810
1816
  @pulumi.input_type
1811
1817
  class InstanceMachineConfigArgs:
1812
1818
  def __init__(__self__, *,
1813
- cpu_count: Optional[pulumi.Input[builtins.int]] = None):
1819
+ cpu_count: Optional[pulumi.Input[builtins.int]] = None,
1820
+ machine_type: Optional[pulumi.Input[builtins.str]] = None):
1814
1821
  """
1815
1822
  :param pulumi.Input[builtins.int] cpu_count: The number of CPU's in the VM instance.
1823
+ :param pulumi.Input[builtins.str] machine_type: Machine type of the VM instance.
1824
+ E.g. "n2-highmem-4", "n2-highmem-8", "c4a-highmem-4-lssd".
1825
+ `cpu_count` must match the number of vCPUs in the machine type.
1816
1826
  """
1817
1827
  if cpu_count is not None:
1818
1828
  pulumi.set(__self__, "cpu_count", cpu_count)
1829
+ if machine_type is not None:
1830
+ pulumi.set(__self__, "machine_type", machine_type)
1819
1831
 
1820
1832
  @property
1821
1833
  @pulumi.getter(name="cpuCount")
@@ -1829,6 +1841,20 @@ class InstanceMachineConfigArgs:
1829
1841
  def cpu_count(self, value: Optional[pulumi.Input[builtins.int]]):
1830
1842
  pulumi.set(self, "cpu_count", value)
1831
1843
 
1844
+ @property
1845
+ @pulumi.getter(name="machineType")
1846
+ def machine_type(self) -> Optional[pulumi.Input[builtins.str]]:
1847
+ """
1848
+ Machine type of the VM instance.
1849
+ E.g. "n2-highmem-4", "n2-highmem-8", "c4a-highmem-4-lssd".
1850
+ `cpu_count` must match the number of vCPUs in the machine type.
1851
+ """
1852
+ return pulumi.get(self, "machine_type")
1853
+
1854
+ @machine_type.setter
1855
+ def machine_type(self, value: Optional[pulumi.Input[builtins.str]]):
1856
+ pulumi.set(self, "machine_type", value)
1857
+
1832
1858
 
1833
1859
  if not MYPY:
1834
1860
  class InstanceNetworkConfigArgsDict(TypedDict):
@@ -1951,6 +1977,10 @@ class InstanceNetworkConfigAuthorizedExternalNetworkArgs:
1951
1977
 
1952
1978
  if not MYPY:
1953
1979
  class InstanceObservabilityConfigArgsDict(TypedDict):
1980
+ assistive_experiences_enabled: NotRequired[pulumi.Input[builtins.bool]]
1981
+ """
1982
+ Whether assistive experiences are enabled for this AlloyDB instance.
1983
+ """
1954
1984
  enabled: NotRequired[pulumi.Input[builtins.bool]]
1955
1985
  """
1956
1986
  Observability feature status for an instance.
@@ -1989,6 +2019,7 @@ elif False:
1989
2019
  @pulumi.input_type
1990
2020
  class InstanceObservabilityConfigArgs:
1991
2021
  def __init__(__self__, *,
2022
+ assistive_experiences_enabled: Optional[pulumi.Input[builtins.bool]] = None,
1992
2023
  enabled: Optional[pulumi.Input[builtins.bool]] = None,
1993
2024
  max_query_string_length: Optional[pulumi.Input[builtins.int]] = None,
1994
2025
  preserve_comments: Optional[pulumi.Input[builtins.bool]] = None,
@@ -1998,6 +2029,7 @@ class InstanceObservabilityConfigArgs:
1998
2029
  track_wait_event_types: Optional[pulumi.Input[builtins.bool]] = None,
1999
2030
  track_wait_events: Optional[pulumi.Input[builtins.bool]] = None):
2000
2031
  """
2032
+ :param pulumi.Input[builtins.bool] assistive_experiences_enabled: Whether assistive experiences are enabled for this AlloyDB instance.
2001
2033
  :param pulumi.Input[builtins.bool] enabled: Observability feature status for an instance.
2002
2034
  :param pulumi.Input[builtins.int] max_query_string_length: Query string length. The default value is 10240. Any integer between 1024 and 100000 is considered valid.
2003
2035
  :param pulumi.Input[builtins.bool] preserve_comments: Preserve comments in the query string.
@@ -2007,6 +2039,8 @@ class InstanceObservabilityConfigArgs:
2007
2039
  :param pulumi.Input[builtins.bool] track_wait_event_types: Record wait event types during query execution for an instance.
2008
2040
  :param pulumi.Input[builtins.bool] track_wait_events: Record wait events during query execution for an instance.
2009
2041
  """
2042
+ if assistive_experiences_enabled is not None:
2043
+ pulumi.set(__self__, "assistive_experiences_enabled", assistive_experiences_enabled)
2010
2044
  if enabled is not None:
2011
2045
  pulumi.set(__self__, "enabled", enabled)
2012
2046
  if max_query_string_length is not None:
@@ -2024,6 +2058,18 @@ class InstanceObservabilityConfigArgs:
2024
2058
  if track_wait_events is not None:
2025
2059
  pulumi.set(__self__, "track_wait_events", track_wait_events)
2026
2060
 
2061
+ @property
2062
+ @pulumi.getter(name="assistiveExperiencesEnabled")
2063
+ def assistive_experiences_enabled(self) -> Optional[pulumi.Input[builtins.bool]]:
2064
+ """
2065
+ Whether assistive experiences are enabled for this AlloyDB instance.
2066
+ """
2067
+ return pulumi.get(self, "assistive_experiences_enabled")
2068
+
2069
+ @assistive_experiences_enabled.setter
2070
+ def assistive_experiences_enabled(self, value: Optional[pulumi.Input[builtins.bool]]):
2071
+ pulumi.set(self, "assistive_experiences_enabled", value)
2072
+
2027
2073
  @property
2028
2074
  @pulumi.getter
2029
2075
  def enabled(self) -> Optional[pulumi.Input[builtins.bool]]: