pulumi-gcp 8.36.0a1751060819__py3-none-any.whl → 8.37.0a1751903932__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 (64) hide show
  1. pulumi_gcp/__init__.py +24 -0
  2. pulumi_gcp/apihub/__init__.py +1 -0
  3. pulumi_gcp/apihub/_inputs.py +675 -0
  4. pulumi_gcp/apihub/outputs.py +567 -0
  5. pulumi_gcp/apihub/plugin.py +1146 -0
  6. pulumi_gcp/bigqueryanalyticshub/data_exchange.py +7 -7
  7. pulumi_gcp/bigqueryanalyticshub/listing.py +7 -7
  8. pulumi_gcp/cloudidentity/group_membership.py +47 -0
  9. pulumi_gcp/cloudidentity/outputs.py +11 -0
  10. pulumi_gcp/cloudrunv2/_inputs.py +65 -9
  11. pulumi_gcp/cloudrunv2/job.py +44 -0
  12. pulumi_gcp/cloudrunv2/outputs.py +73 -8
  13. pulumi_gcp/cloudrunv2/service.py +0 -2
  14. pulumi_gcp/cloudrunv2/worker_pool.py +18 -20
  15. pulumi_gcp/compute/__init__.py +1 -0
  16. pulumi_gcp/compute/_inputs.py +763 -6
  17. pulumi_gcp/compute/disk.py +35 -28
  18. pulumi_gcp/compute/firewall_policy_rule.py +207 -0
  19. pulumi_gcp/compute/get_instance_group_manager.py +12 -1
  20. pulumi_gcp/compute/get_region_disk.py +12 -1
  21. pulumi_gcp/compute/instance_group_manager.py +165 -14
  22. pulumi_gcp/compute/network.py +56 -0
  23. pulumi_gcp/compute/network_firewall_policy.py +68 -0
  24. pulumi_gcp/compute/network_firewall_policy_with_rules.py +61 -0
  25. pulumi_gcp/compute/outputs.py +604 -4
  26. pulumi_gcp/compute/region_disk.py +114 -0
  27. pulumi_gcp/compute/region_network_firewall_policy.py +90 -0
  28. pulumi_gcp/compute/region_network_firewall_policy_with_rules.py +109 -0
  29. pulumi_gcp/compute/wire_group.py +751 -0
  30. pulumi_gcp/container/_inputs.py +135 -16
  31. pulumi_gcp/container/cluster.py +54 -0
  32. pulumi_gcp/container/get_cluster.py +12 -1
  33. pulumi_gcp/container/node_pool.py +14 -0
  34. pulumi_gcp/container/outputs.py +222 -12
  35. pulumi_gcp/diagflow/__init__.py +1 -0
  36. pulumi_gcp/diagflow/_inputs.py +431 -0
  37. pulumi_gcp/diagflow/cx_generative_settings.py +625 -0
  38. pulumi_gcp/diagflow/outputs.py +370 -0
  39. pulumi_gcp/dns/record_set.py +4 -2
  40. pulumi_gcp/firestore/database.py +0 -9
  41. pulumi_gcp/iam/_inputs.py +36 -0
  42. pulumi_gcp/iam/outputs.py +38 -0
  43. pulumi_gcp/iam/workload_identity_pool_managed_identity.py +88 -2
  44. pulumi_gcp/kms/autokey_config.py +28 -0
  45. pulumi_gcp/kms/get_autokey_config.py +12 -1
  46. pulumi_gcp/memorystore/get_instance.py +12 -1
  47. pulumi_gcp/memorystore/instance.py +49 -0
  48. pulumi_gcp/monitoring/metric_descriptor.py +55 -57
  49. pulumi_gcp/notebooks/instance.py +8 -8
  50. pulumi_gcp/pulumi-plugin.json +1 -1
  51. pulumi_gcp/redis/get_instance.py +12 -1
  52. pulumi_gcp/redis/instance.py +44 -0
  53. pulumi_gcp/secretmanager/get_regional_secret.py +12 -1
  54. pulumi_gcp/secretmanager/outputs.py +7 -0
  55. pulumi_gcp/secretmanager/regional_secret.py +38 -2
  56. pulumi_gcp/spanner/_inputs.py +24 -1
  57. pulumi_gcp/spanner/outputs.py +17 -1
  58. pulumi_gcp/storage/_inputs.py +43 -3
  59. pulumi_gcp/storage/outputs.py +53 -3
  60. pulumi_gcp/workbench/instance.py +2 -0
  61. {pulumi_gcp-8.36.0a1751060819.dist-info → pulumi_gcp-8.37.0a1751903932.dist-info}/METADATA +1 -1
  62. {pulumi_gcp-8.36.0a1751060819.dist-info → pulumi_gcp-8.37.0a1751903932.dist-info}/RECORD +64 -61
  63. {pulumi_gcp-8.36.0a1751060819.dist-info → pulumi_gcp-8.37.0a1751903932.dist-info}/WHEEL +0 -0
  64. {pulumi_gcp-8.36.0a1751060819.dist-info → pulumi_gcp-8.37.0a1751903932.dist-info}/top_level.txt +0 -0
@@ -78,6 +78,12 @@ __all__ = [
78
78
  'CxFlowTransitionRouteTriggerFulfillmentMessageTelephonyTransferCall',
79
79
  'CxFlowTransitionRouteTriggerFulfillmentMessageText',
80
80
  'CxFlowTransitionRouteTriggerFulfillmentSetParameterAction',
81
+ 'CxGenerativeSettingsFallbackSettings',
82
+ 'CxGenerativeSettingsFallbackSettingsPromptTemplate',
83
+ 'CxGenerativeSettingsGenerativeSafetySettings',
84
+ 'CxGenerativeSettingsGenerativeSafetySettingsBannedPhrase',
85
+ 'CxGenerativeSettingsKnowledgeConnectorSettings',
86
+ 'CxGenerativeSettingsLlmModelSettings',
81
87
  'CxIntentParameter',
82
88
  'CxIntentTrainingPhrase',
83
89
  'CxIntentTrainingPhrasePart',
@@ -3912,6 +3918,370 @@ class CxFlowTransitionRouteTriggerFulfillmentSetParameterAction(dict):
3912
3918
  return pulumi.get(self, "value")
3913
3919
 
3914
3920
 
3921
+ @pulumi.output_type
3922
+ class CxGenerativeSettingsFallbackSettings(dict):
3923
+ @staticmethod
3924
+ def __key_warning(key: str):
3925
+ suggest = None
3926
+ if key == "promptTemplates":
3927
+ suggest = "prompt_templates"
3928
+ elif key == "selectedPrompt":
3929
+ suggest = "selected_prompt"
3930
+
3931
+ if suggest:
3932
+ pulumi.log.warn(f"Key '{key}' not found in CxGenerativeSettingsFallbackSettings. Access the value via the '{suggest}' property getter instead.")
3933
+
3934
+ def __getitem__(self, key: str) -> Any:
3935
+ CxGenerativeSettingsFallbackSettings.__key_warning(key)
3936
+ return super().__getitem__(key)
3937
+
3938
+ def get(self, key: str, default = None) -> Any:
3939
+ CxGenerativeSettingsFallbackSettings.__key_warning(key)
3940
+ return super().get(key, default)
3941
+
3942
+ def __init__(__self__, *,
3943
+ prompt_templates: Optional[Sequence['outputs.CxGenerativeSettingsFallbackSettingsPromptTemplate']] = None,
3944
+ selected_prompt: Optional[builtins.str] = None):
3945
+ """
3946
+ :param Sequence['CxGenerativeSettingsFallbackSettingsPromptTemplateArgs'] prompt_templates: Stored prompts that can be selected, for example default templates like "conservative" or "chatty", or user defined ones.
3947
+ Structure is documented below.
3948
+ :param builtins.str selected_prompt: Display name of the selected prompt.
3949
+ """
3950
+ if prompt_templates is not None:
3951
+ pulumi.set(__self__, "prompt_templates", prompt_templates)
3952
+ if selected_prompt is not None:
3953
+ pulumi.set(__self__, "selected_prompt", selected_prompt)
3954
+
3955
+ @property
3956
+ @pulumi.getter(name="promptTemplates")
3957
+ def prompt_templates(self) -> Optional[Sequence['outputs.CxGenerativeSettingsFallbackSettingsPromptTemplate']]:
3958
+ """
3959
+ Stored prompts that can be selected, for example default templates like "conservative" or "chatty", or user defined ones.
3960
+ Structure is documented below.
3961
+ """
3962
+ return pulumi.get(self, "prompt_templates")
3963
+
3964
+ @property
3965
+ @pulumi.getter(name="selectedPrompt")
3966
+ def selected_prompt(self) -> Optional[builtins.str]:
3967
+ """
3968
+ Display name of the selected prompt.
3969
+ """
3970
+ return pulumi.get(self, "selected_prompt")
3971
+
3972
+
3973
+ @pulumi.output_type
3974
+ class CxGenerativeSettingsFallbackSettingsPromptTemplate(dict):
3975
+ @staticmethod
3976
+ def __key_warning(key: str):
3977
+ suggest = None
3978
+ if key == "displayName":
3979
+ suggest = "display_name"
3980
+ elif key == "promptText":
3981
+ suggest = "prompt_text"
3982
+
3983
+ if suggest:
3984
+ pulumi.log.warn(f"Key '{key}' not found in CxGenerativeSettingsFallbackSettingsPromptTemplate. Access the value via the '{suggest}' property getter instead.")
3985
+
3986
+ def __getitem__(self, key: str) -> Any:
3987
+ CxGenerativeSettingsFallbackSettingsPromptTemplate.__key_warning(key)
3988
+ return super().__getitem__(key)
3989
+
3990
+ def get(self, key: str, default = None) -> Any:
3991
+ CxGenerativeSettingsFallbackSettingsPromptTemplate.__key_warning(key)
3992
+ return super().get(key, default)
3993
+
3994
+ def __init__(__self__, *,
3995
+ display_name: Optional[builtins.str] = None,
3996
+ frozen: Optional[builtins.bool] = None,
3997
+ prompt_text: Optional[builtins.str] = None):
3998
+ """
3999
+ :param builtins.str display_name: Prompt name.
4000
+ :param builtins.bool frozen: If the flag is true, the prompt is frozen and cannot be modified by users.
4001
+ :param builtins.str prompt_text: Prompt text that is sent to a LLM on no-match default, placeholders are filled downstream. For example: "Here is a conversation $conversation, a response is: "
4002
+ """
4003
+ if display_name is not None:
4004
+ pulumi.set(__self__, "display_name", display_name)
4005
+ if frozen is not None:
4006
+ pulumi.set(__self__, "frozen", frozen)
4007
+ if prompt_text is not None:
4008
+ pulumi.set(__self__, "prompt_text", prompt_text)
4009
+
4010
+ @property
4011
+ @pulumi.getter(name="displayName")
4012
+ def display_name(self) -> Optional[builtins.str]:
4013
+ """
4014
+ Prompt name.
4015
+ """
4016
+ return pulumi.get(self, "display_name")
4017
+
4018
+ @property
4019
+ @pulumi.getter
4020
+ def frozen(self) -> Optional[builtins.bool]:
4021
+ """
4022
+ If the flag is true, the prompt is frozen and cannot be modified by users.
4023
+ """
4024
+ return pulumi.get(self, "frozen")
4025
+
4026
+ @property
4027
+ @pulumi.getter(name="promptText")
4028
+ def prompt_text(self) -> Optional[builtins.str]:
4029
+ """
4030
+ Prompt text that is sent to a LLM on no-match default, placeholders are filled downstream. For example: "Here is a conversation $conversation, a response is: "
4031
+ """
4032
+ return pulumi.get(self, "prompt_text")
4033
+
4034
+
4035
+ @pulumi.output_type
4036
+ class CxGenerativeSettingsGenerativeSafetySettings(dict):
4037
+ @staticmethod
4038
+ def __key_warning(key: str):
4039
+ suggest = None
4040
+ if key == "bannedPhrases":
4041
+ suggest = "banned_phrases"
4042
+ elif key == "defaultBannedPhraseMatchStrategy":
4043
+ suggest = "default_banned_phrase_match_strategy"
4044
+
4045
+ if suggest:
4046
+ pulumi.log.warn(f"Key '{key}' not found in CxGenerativeSettingsGenerativeSafetySettings. Access the value via the '{suggest}' property getter instead.")
4047
+
4048
+ def __getitem__(self, key: str) -> Any:
4049
+ CxGenerativeSettingsGenerativeSafetySettings.__key_warning(key)
4050
+ return super().__getitem__(key)
4051
+
4052
+ def get(self, key: str, default = None) -> Any:
4053
+ CxGenerativeSettingsGenerativeSafetySettings.__key_warning(key)
4054
+ return super().get(key, default)
4055
+
4056
+ def __init__(__self__, *,
4057
+ banned_phrases: Optional[Sequence['outputs.CxGenerativeSettingsGenerativeSafetySettingsBannedPhrase']] = None,
4058
+ default_banned_phrase_match_strategy: Optional[builtins.str] = None):
4059
+ """
4060
+ :param Sequence['CxGenerativeSettingsGenerativeSafetySettingsBannedPhraseArgs'] banned_phrases: Banned phrases for generated text.
4061
+ Structure is documented below.
4062
+ :param builtins.str default_banned_phrase_match_strategy: Optional. Default phrase match strategy for banned phrases.
4063
+ See [PhraseMatchStrategy](https://cloud.google.com/dialogflow/cx/docs/reference/rest/v3/GenerativeSettings#phrasematchstrategy) for valid values.
4064
+ """
4065
+ if banned_phrases is not None:
4066
+ pulumi.set(__self__, "banned_phrases", banned_phrases)
4067
+ if default_banned_phrase_match_strategy is not None:
4068
+ pulumi.set(__self__, "default_banned_phrase_match_strategy", default_banned_phrase_match_strategy)
4069
+
4070
+ @property
4071
+ @pulumi.getter(name="bannedPhrases")
4072
+ def banned_phrases(self) -> Optional[Sequence['outputs.CxGenerativeSettingsGenerativeSafetySettingsBannedPhrase']]:
4073
+ """
4074
+ Banned phrases for generated text.
4075
+ Structure is documented below.
4076
+ """
4077
+ return pulumi.get(self, "banned_phrases")
4078
+
4079
+ @property
4080
+ @pulumi.getter(name="defaultBannedPhraseMatchStrategy")
4081
+ def default_banned_phrase_match_strategy(self) -> Optional[builtins.str]:
4082
+ """
4083
+ Optional. Default phrase match strategy for banned phrases.
4084
+ See [PhraseMatchStrategy](https://cloud.google.com/dialogflow/cx/docs/reference/rest/v3/GenerativeSettings#phrasematchstrategy) for valid values.
4085
+ """
4086
+ return pulumi.get(self, "default_banned_phrase_match_strategy")
4087
+
4088
+
4089
+ @pulumi.output_type
4090
+ class CxGenerativeSettingsGenerativeSafetySettingsBannedPhrase(dict):
4091
+ @staticmethod
4092
+ def __key_warning(key: str):
4093
+ suggest = None
4094
+ if key == "languageCode":
4095
+ suggest = "language_code"
4096
+
4097
+ if suggest:
4098
+ pulumi.log.warn(f"Key '{key}' not found in CxGenerativeSettingsGenerativeSafetySettingsBannedPhrase. Access the value via the '{suggest}' property getter instead.")
4099
+
4100
+ def __getitem__(self, key: str) -> Any:
4101
+ CxGenerativeSettingsGenerativeSafetySettingsBannedPhrase.__key_warning(key)
4102
+ return super().__getitem__(key)
4103
+
4104
+ def get(self, key: str, default = None) -> Any:
4105
+ CxGenerativeSettingsGenerativeSafetySettingsBannedPhrase.__key_warning(key)
4106
+ return super().get(key, default)
4107
+
4108
+ def __init__(__self__, *,
4109
+ language_code: builtins.str,
4110
+ text: builtins.str):
4111
+ """
4112
+ :param builtins.str language_code: Language code of the phrase.
4113
+ :param builtins.str text: Text input which can be used for prompt or banned phrases.
4114
+ """
4115
+ pulumi.set(__self__, "language_code", language_code)
4116
+ pulumi.set(__self__, "text", text)
4117
+
4118
+ @property
4119
+ @pulumi.getter(name="languageCode")
4120
+ def language_code(self) -> builtins.str:
4121
+ """
4122
+ Language code of the phrase.
4123
+ """
4124
+ return pulumi.get(self, "language_code")
4125
+
4126
+ @property
4127
+ @pulumi.getter
4128
+ def text(self) -> builtins.str:
4129
+ """
4130
+ Text input which can be used for prompt or banned phrases.
4131
+ """
4132
+ return pulumi.get(self, "text")
4133
+
4134
+
4135
+ @pulumi.output_type
4136
+ class CxGenerativeSettingsKnowledgeConnectorSettings(dict):
4137
+ @staticmethod
4138
+ def __key_warning(key: str):
4139
+ suggest = None
4140
+ if key == "agentIdentity":
4141
+ suggest = "agent_identity"
4142
+ elif key == "agentScope":
4143
+ suggest = "agent_scope"
4144
+ elif key == "businessDescription":
4145
+ suggest = "business_description"
4146
+ elif key == "disableDataStoreFallback":
4147
+ suggest = "disable_data_store_fallback"
4148
+
4149
+ if suggest:
4150
+ pulumi.log.warn(f"Key '{key}' not found in CxGenerativeSettingsKnowledgeConnectorSettings. Access the value via the '{suggest}' property getter instead.")
4151
+
4152
+ def __getitem__(self, key: str) -> Any:
4153
+ CxGenerativeSettingsKnowledgeConnectorSettings.__key_warning(key)
4154
+ return super().__getitem__(key)
4155
+
4156
+ def get(self, key: str, default = None) -> Any:
4157
+ CxGenerativeSettingsKnowledgeConnectorSettings.__key_warning(key)
4158
+ return super().get(key, default)
4159
+
4160
+ def __init__(__self__, *,
4161
+ agent: Optional[builtins.str] = None,
4162
+ agent_identity: Optional[builtins.str] = None,
4163
+ agent_scope: Optional[builtins.str] = None,
4164
+ business: Optional[builtins.str] = None,
4165
+ business_description: Optional[builtins.str] = None,
4166
+ disable_data_store_fallback: Optional[builtins.bool] = None):
4167
+ """
4168
+ :param builtins.str agent: Name of the virtual agent. Used for LLM prompt. Can be left empty.
4169
+ :param builtins.str agent_identity: Identity of the agent, e.g. "virtual agent", "AI assistant".
4170
+ :param builtins.str agent_scope: Agent scope, e.g. "Example company website", "internal Example company website for employees", "manual of car owner".
4171
+ :param builtins.str business: Name of the company, organization or other entity that the agent represents. Used for knowledge connector LLM prompt and for knowledge search.
4172
+ :param builtins.str business_description: Company description, used for LLM prompt, e.g. "a family company selling freshly roasted coffee beans".``
4173
+ :param builtins.bool disable_data_store_fallback: Whether to disable fallback to Data Store search results (in case the LLM couldn't pick a proper answer). Per default the feature is enabled.
4174
+ """
4175
+ if agent is not None:
4176
+ pulumi.set(__self__, "agent", agent)
4177
+ if agent_identity is not None:
4178
+ pulumi.set(__self__, "agent_identity", agent_identity)
4179
+ if agent_scope is not None:
4180
+ pulumi.set(__self__, "agent_scope", agent_scope)
4181
+ if business is not None:
4182
+ pulumi.set(__self__, "business", business)
4183
+ if business_description is not None:
4184
+ pulumi.set(__self__, "business_description", business_description)
4185
+ if disable_data_store_fallback is not None:
4186
+ pulumi.set(__self__, "disable_data_store_fallback", disable_data_store_fallback)
4187
+
4188
+ @property
4189
+ @pulumi.getter
4190
+ def agent(self) -> Optional[builtins.str]:
4191
+ """
4192
+ Name of the virtual agent. Used for LLM prompt. Can be left empty.
4193
+ """
4194
+ return pulumi.get(self, "agent")
4195
+
4196
+ @property
4197
+ @pulumi.getter(name="agentIdentity")
4198
+ def agent_identity(self) -> Optional[builtins.str]:
4199
+ """
4200
+ Identity of the agent, e.g. "virtual agent", "AI assistant".
4201
+ """
4202
+ return pulumi.get(self, "agent_identity")
4203
+
4204
+ @property
4205
+ @pulumi.getter(name="agentScope")
4206
+ def agent_scope(self) -> Optional[builtins.str]:
4207
+ """
4208
+ Agent scope, e.g. "Example company website", "internal Example company website for employees", "manual of car owner".
4209
+ """
4210
+ return pulumi.get(self, "agent_scope")
4211
+
4212
+ @property
4213
+ @pulumi.getter
4214
+ def business(self) -> Optional[builtins.str]:
4215
+ """
4216
+ Name of the company, organization or other entity that the agent represents. Used for knowledge connector LLM prompt and for knowledge search.
4217
+ """
4218
+ return pulumi.get(self, "business")
4219
+
4220
+ @property
4221
+ @pulumi.getter(name="businessDescription")
4222
+ def business_description(self) -> Optional[builtins.str]:
4223
+ """
4224
+ Company description, used for LLM prompt, e.g. "a family company selling freshly roasted coffee beans".``
4225
+ """
4226
+ return pulumi.get(self, "business_description")
4227
+
4228
+ @property
4229
+ @pulumi.getter(name="disableDataStoreFallback")
4230
+ def disable_data_store_fallback(self) -> Optional[builtins.bool]:
4231
+ """
4232
+ Whether to disable fallback to Data Store search results (in case the LLM couldn't pick a proper answer). Per default the feature is enabled.
4233
+ """
4234
+ return pulumi.get(self, "disable_data_store_fallback")
4235
+
4236
+
4237
+ @pulumi.output_type
4238
+ class CxGenerativeSettingsLlmModelSettings(dict):
4239
+ @staticmethod
4240
+ def __key_warning(key: str):
4241
+ suggest = None
4242
+ if key == "promptText":
4243
+ suggest = "prompt_text"
4244
+
4245
+ if suggest:
4246
+ pulumi.log.warn(f"Key '{key}' not found in CxGenerativeSettingsLlmModelSettings. Access the value via the '{suggest}' property getter instead.")
4247
+
4248
+ def __getitem__(self, key: str) -> Any:
4249
+ CxGenerativeSettingsLlmModelSettings.__key_warning(key)
4250
+ return super().__getitem__(key)
4251
+
4252
+ def get(self, key: str, default = None) -> Any:
4253
+ CxGenerativeSettingsLlmModelSettings.__key_warning(key)
4254
+ return super().get(key, default)
4255
+
4256
+ def __init__(__self__, *,
4257
+ model: Optional[builtins.str] = None,
4258
+ prompt_text: Optional[builtins.str] = None):
4259
+ """
4260
+ :param builtins.str model: The selected LLM model.
4261
+ :param builtins.str prompt_text: The custom prompt to use.
4262
+ """
4263
+ if model is not None:
4264
+ pulumi.set(__self__, "model", model)
4265
+ if prompt_text is not None:
4266
+ pulumi.set(__self__, "prompt_text", prompt_text)
4267
+
4268
+ @property
4269
+ @pulumi.getter
4270
+ def model(self) -> Optional[builtins.str]:
4271
+ """
4272
+ The selected LLM model.
4273
+ """
4274
+ return pulumi.get(self, "model")
4275
+
4276
+ @property
4277
+ @pulumi.getter(name="promptText")
4278
+ def prompt_text(self) -> Optional[builtins.str]:
4279
+ """
4280
+ The custom prompt to use.
4281
+ """
4282
+ return pulumi.get(self, "prompt_text")
4283
+
4284
+
3915
4285
  @pulumi.output_type
3916
4286
  class CxIntentParameter(dict):
3917
4287
  @staticmethod
@@ -431,7 +431,8 @@ class RecordSet(pulumi.CustomResource):
431
431
 
432
432
  prod = gcp.dns.ManagedZone("prod",
433
433
  name="prod-zone",
434
- dns_name="prod.mydomain.com.")
434
+ dns_name="prod.mydomain.com.",
435
+ visibility="private")
435
436
  prod_region_backend_service = gcp.compute.RegionBackendService("prod",
436
437
  name="prod-backend",
437
438
  region="us-central1")
@@ -710,7 +711,8 @@ class RecordSet(pulumi.CustomResource):
710
711
 
711
712
  prod = gcp.dns.ManagedZone("prod",
712
713
  name="prod-zone",
713
- dns_name="prod.mydomain.com.")
714
+ dns_name="prod.mydomain.com.",
715
+ visibility="private")
714
716
  prod_region_backend_service = gcp.compute.RegionBackendService("prod",
715
717
  name="prod-backend",
716
718
  region="us-central1")
@@ -82,9 +82,6 @@ class DatabaseArgs:
82
82
  pulumi.set(__self__, "database_edition", database_edition)
83
83
  if delete_protection_state is not None:
84
84
  pulumi.set(__self__, "delete_protection_state", delete_protection_state)
85
- if deletion_policy is not None:
86
- warnings.warn("""`deletion_policy` is deprecated and will be removed in a future major release. Use `delete_protection_state` instead.""", DeprecationWarning)
87
- pulumi.log.warn("""deletion_policy is deprecated: `deletion_policy` is deprecated and will be removed in a future major release. Use `delete_protection_state` instead.""")
88
85
  if deletion_policy is not None:
89
86
  pulumi.set(__self__, "deletion_policy", deletion_policy)
90
87
  if name is not None:
@@ -190,7 +187,6 @@ class DatabaseArgs:
190
187
 
191
188
  @property
192
189
  @pulumi.getter(name="deletionPolicy")
193
- @_utilities.deprecated("""`deletion_policy` is deprecated and will be removed in a future major release. Use `delete_protection_state` instead.""")
194
190
  def deletion_policy(self) -> Optional[pulumi.Input[builtins.str]]:
195
191
  return pulumi.get(self, "deletion_policy")
196
192
 
@@ -334,9 +330,6 @@ class _DatabaseState:
334
330
  pulumi.set(__self__, "database_edition", database_edition)
335
331
  if delete_protection_state is not None:
336
332
  pulumi.set(__self__, "delete_protection_state", delete_protection_state)
337
- if deletion_policy is not None:
338
- warnings.warn("""`deletion_policy` is deprecated and will be removed in a future major release. Use `delete_protection_state` instead.""", DeprecationWarning)
339
- pulumi.log.warn("""deletion_policy is deprecated: `deletion_policy` is deprecated and will be removed in a future major release. Use `delete_protection_state` instead.""")
340
333
  if deletion_policy is not None:
341
334
  pulumi.set(__self__, "deletion_policy", deletion_policy)
342
335
  if earliest_version_time is not None:
@@ -439,7 +432,6 @@ class _DatabaseState:
439
432
 
440
433
  @property
441
434
  @pulumi.getter(name="deletionPolicy")
442
- @_utilities.deprecated("""`deletion_policy` is deprecated and will be removed in a future major release. Use `delete_protection_state` instead.""")
443
435
  def deletion_policy(self) -> Optional[pulumi.Input[builtins.str]]:
444
436
  return pulumi.get(self, "deletion_policy")
445
437
 
@@ -1251,7 +1243,6 @@ class Database(pulumi.CustomResource):
1251
1243
 
1252
1244
  @property
1253
1245
  @pulumi.getter(name="deletionPolicy")
1254
- @_utilities.deprecated("""`deletion_policy` is deprecated and will be removed in a future major release. Use `delete_protection_state` instead.""")
1255
1246
  def deletion_policy(self) -> pulumi.Output[Optional[builtins.str]]:
1256
1247
  return pulumi.get(self, "deletion_policy")
1257
1248
 
pulumi_gcp/iam/_inputs.py CHANGED
@@ -80,6 +80,8 @@ __all__ = [
80
80
  'WorkloadIdentityPoolInlineTrustConfigAdditionalTrustBundleArgsDict',
81
81
  'WorkloadIdentityPoolInlineTrustConfigAdditionalTrustBundleTrustAnchorArgs',
82
82
  'WorkloadIdentityPoolInlineTrustConfigAdditionalTrustBundleTrustAnchorArgsDict',
83
+ 'WorkloadIdentityPoolManagedIdentityAttestationRuleArgs',
84
+ 'WorkloadIdentityPoolManagedIdentityAttestationRuleArgsDict',
83
85
  'WorkloadIdentityPoolNamespaceOwnerServiceArgs',
84
86
  'WorkloadIdentityPoolNamespaceOwnerServiceArgsDict',
85
87
  'WorkloadIdentityPoolProviderAwsArgs',
@@ -2594,6 +2596,40 @@ class WorkloadIdentityPoolInlineTrustConfigAdditionalTrustBundleTrustAnchorArgs:
2594
2596
  pulumi.set(self, "pem_certificate", value)
2595
2597
 
2596
2598
 
2599
+ if not MYPY:
2600
+ class WorkloadIdentityPoolManagedIdentityAttestationRuleArgsDict(TypedDict):
2601
+ google_cloud_resource: pulumi.Input[builtins.str]
2602
+ """
2603
+ A single workload operating on Google Cloud. For example:
2604
+ `//compute.googleapis.com/projects/123/uid/zones/us-central1-a/instances/12345678`.
2605
+ """
2606
+ elif False:
2607
+ WorkloadIdentityPoolManagedIdentityAttestationRuleArgsDict: TypeAlias = Mapping[str, Any]
2608
+
2609
+ @pulumi.input_type
2610
+ class WorkloadIdentityPoolManagedIdentityAttestationRuleArgs:
2611
+ def __init__(__self__, *,
2612
+ google_cloud_resource: pulumi.Input[builtins.str]):
2613
+ """
2614
+ :param pulumi.Input[builtins.str] google_cloud_resource: A single workload operating on Google Cloud. For example:
2615
+ `//compute.googleapis.com/projects/123/uid/zones/us-central1-a/instances/12345678`.
2616
+ """
2617
+ pulumi.set(__self__, "google_cloud_resource", google_cloud_resource)
2618
+
2619
+ @property
2620
+ @pulumi.getter(name="googleCloudResource")
2621
+ def google_cloud_resource(self) -> pulumi.Input[builtins.str]:
2622
+ """
2623
+ A single workload operating on Google Cloud. For example:
2624
+ `//compute.googleapis.com/projects/123/uid/zones/us-central1-a/instances/12345678`.
2625
+ """
2626
+ return pulumi.get(self, "google_cloud_resource")
2627
+
2628
+ @google_cloud_resource.setter
2629
+ def google_cloud_resource(self, value: pulumi.Input[builtins.str]):
2630
+ pulumi.set(self, "google_cloud_resource", value)
2631
+
2632
+
2597
2633
  if not MYPY:
2598
2634
  class WorkloadIdentityPoolNamespaceOwnerServiceArgsDict(TypedDict):
2599
2635
  principal_subject: NotRequired[pulumi.Input[builtins.str]]
pulumi_gcp/iam/outputs.py CHANGED
@@ -49,6 +49,7 @@ __all__ = [
49
49
  'WorkloadIdentityPoolInlineTrustConfig',
50
50
  'WorkloadIdentityPoolInlineTrustConfigAdditionalTrustBundle',
51
51
  'WorkloadIdentityPoolInlineTrustConfigAdditionalTrustBundleTrustAnchor',
52
+ 'WorkloadIdentityPoolManagedIdentityAttestationRule',
52
53
  'WorkloadIdentityPoolNamespaceOwnerService',
53
54
  'WorkloadIdentityPoolProviderAws',
54
55
  'WorkloadIdentityPoolProviderOidc',
@@ -1968,6 +1969,43 @@ class WorkloadIdentityPoolInlineTrustConfigAdditionalTrustBundleTrustAnchor(dict
1968
1969
  return pulumi.get(self, "pem_certificate")
1969
1970
 
1970
1971
 
1972
+ @pulumi.output_type
1973
+ class WorkloadIdentityPoolManagedIdentityAttestationRule(dict):
1974
+ @staticmethod
1975
+ def __key_warning(key: str):
1976
+ suggest = None
1977
+ if key == "googleCloudResource":
1978
+ suggest = "google_cloud_resource"
1979
+
1980
+ if suggest:
1981
+ pulumi.log.warn(f"Key '{key}' not found in WorkloadIdentityPoolManagedIdentityAttestationRule. Access the value via the '{suggest}' property getter instead.")
1982
+
1983
+ def __getitem__(self, key: str) -> Any:
1984
+ WorkloadIdentityPoolManagedIdentityAttestationRule.__key_warning(key)
1985
+ return super().__getitem__(key)
1986
+
1987
+ def get(self, key: str, default = None) -> Any:
1988
+ WorkloadIdentityPoolManagedIdentityAttestationRule.__key_warning(key)
1989
+ return super().get(key, default)
1990
+
1991
+ def __init__(__self__, *,
1992
+ google_cloud_resource: builtins.str):
1993
+ """
1994
+ :param builtins.str google_cloud_resource: A single workload operating on Google Cloud. For example:
1995
+ `//compute.googleapis.com/projects/123/uid/zones/us-central1-a/instances/12345678`.
1996
+ """
1997
+ pulumi.set(__self__, "google_cloud_resource", google_cloud_resource)
1998
+
1999
+ @property
2000
+ @pulumi.getter(name="googleCloudResource")
2001
+ def google_cloud_resource(self) -> builtins.str:
2002
+ """
2003
+ A single workload operating on Google Cloud. For example:
2004
+ `//compute.googleapis.com/projects/123/uid/zones/us-central1-a/instances/12345678`.
2005
+ """
2006
+ return pulumi.get(self, "google_cloud_resource")
2007
+
2008
+
1971
2009
  @pulumi.output_type
1972
2010
  class WorkloadIdentityPoolNamespaceOwnerService(dict):
1973
2011
  @staticmethod