pulumi-snowflake 0.56.0a1721200104__py3-none-any.whl → 0.56.0a1721667766__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 (62) hide show
  1. pulumi_snowflake/__init__.py +66 -217
  2. pulumi_snowflake/_inputs.py +10145 -1557
  3. pulumi_snowflake/_utilities.py +3 -4
  4. pulumi_snowflake/api_authentication_integration_with_authorization_code_grant.py +688 -0
  5. pulumi_snowflake/api_authentication_integration_with_client_credentials.py +641 -0
  6. pulumi_snowflake/api_authentication_integration_with_jwt_bearer.py +676 -0
  7. pulumi_snowflake/cortex_search_service.py +563 -0
  8. pulumi_snowflake/database.py +854 -232
  9. pulumi_snowflake/database_old.py +556 -0
  10. pulumi_snowflake/external_oauth_integration.py +562 -534
  11. pulumi_snowflake/failover_group.py +2 -2
  12. pulumi_snowflake/get_cortex_search_services.py +197 -0
  13. pulumi_snowflake/get_databases.py +71 -62
  14. pulumi_snowflake/get_security_integrations.py +122 -0
  15. pulumi_snowflake/get_warehouses.py +66 -18
  16. pulumi_snowflake/grant_privileges_to_database_role.py +0 -4
  17. pulumi_snowflake/managed_account.py +7 -7
  18. pulumi_snowflake/oauth_integration.py +4 -0
  19. pulumi_snowflake/oauth_integration_for_custom_clients.py +936 -0
  20. pulumi_snowflake/oauth_integration_for_partner_applications.py +580 -0
  21. pulumi_snowflake/outputs.py +12987 -2857
  22. pulumi_snowflake/pulumi-plugin.json +1 -1
  23. pulumi_snowflake/saml2_integration.py +971 -0
  24. pulumi_snowflake/saml_integration.py +4 -0
  25. pulumi_snowflake/scim_integration.py +255 -105
  26. pulumi_snowflake/secondary_database.py +1059 -0
  27. pulumi_snowflake/sequence.py +6 -6
  28. pulumi_snowflake/shared_database.py +914 -0
  29. pulumi_snowflake/tag_association.py +38 -38
  30. pulumi_snowflake/user_password_policy_attachment.py +32 -0
  31. pulumi_snowflake/warehouse.py +143 -120
  32. {pulumi_snowflake-0.56.0a1721200104.dist-info → pulumi_snowflake-0.56.0a1721667766.dist-info}/METADATA +1 -1
  33. {pulumi_snowflake-0.56.0a1721200104.dist-info → pulumi_snowflake-0.56.0a1721667766.dist-info}/RECORD +35 -50
  34. {pulumi_snowflake-0.56.0a1721200104.dist-info → pulumi_snowflake-0.56.0a1721667766.dist-info}/WHEEL +1 -1
  35. pulumi_snowflake/account_grant.py +0 -319
  36. pulumi_snowflake/database_grant.py +0 -471
  37. pulumi_snowflake/external_table_grant.py +0 -666
  38. pulumi_snowflake/failover_group_grant.py +0 -368
  39. pulumi_snowflake/file_format_grant.py +0 -611
  40. pulumi_snowflake/function_grant.py +0 -721
  41. pulumi_snowflake/grant_privileges_to_role.py +0 -821
  42. pulumi_snowflake/integration_grant.py +0 -416
  43. pulumi_snowflake/masking_policy_grant.py +0 -518
  44. pulumi_snowflake/materialized_view_grant.py +0 -665
  45. pulumi_snowflake/pipe_grant.py +0 -563
  46. pulumi_snowflake/procedure_grant.py +0 -721
  47. pulumi_snowflake/resource_monitor_grant.py +0 -363
  48. pulumi_snowflake/role_grants.py +0 -340
  49. pulumi_snowflake/role_ownership_grant.py +0 -329
  50. pulumi_snowflake/row_access_policy_grant.py +0 -516
  51. pulumi_snowflake/schema_grant.py +0 -603
  52. pulumi_snowflake/sequence_grant.py +0 -611
  53. pulumi_snowflake/stage_grant.py +0 -611
  54. pulumi_snowflake/stream_grant.py +0 -611
  55. pulumi_snowflake/table_grant.py +0 -653
  56. pulumi_snowflake/tag_grant.py +0 -508
  57. pulumi_snowflake/task_grant.py +0 -611
  58. pulumi_snowflake/user_grant.py +0 -370
  59. pulumi_snowflake/user_ownership_grant.py +0 -275
  60. pulumi_snowflake/view_grant.py +0 -685
  61. pulumi_snowflake/warehouse_grant.py +0 -416
  62. {pulumi_snowflake-0.56.0a1721200104.dist-info → pulumi_snowflake-0.56.0a1721667766.dist-info}/top_level.txt +0 -0
@@ -0,0 +1,914 @@
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 pulumi
8
+ import pulumi.runtime
9
+ from typing import Any, Mapping, Optional, Sequence, Union, overload
10
+ from . import _utilities
11
+
12
+ __all__ = ['SharedDatabaseArgs', 'SharedDatabase']
13
+
14
+ @pulumi.input_type
15
+ class SharedDatabaseArgs:
16
+ def __init__(__self__, *,
17
+ from_share: pulumi.Input[str],
18
+ catalog: Optional[pulumi.Input[str]] = None,
19
+ comment: Optional[pulumi.Input[str]] = None,
20
+ default_ddl_collation: Optional[pulumi.Input[str]] = None,
21
+ enable_console_output: Optional[pulumi.Input[bool]] = None,
22
+ external_volume: Optional[pulumi.Input[str]] = None,
23
+ log_level: Optional[pulumi.Input[str]] = None,
24
+ name: Optional[pulumi.Input[str]] = None,
25
+ quoted_identifiers_ignore_case: Optional[pulumi.Input[bool]] = None,
26
+ replace_invalid_characters: Optional[pulumi.Input[bool]] = None,
27
+ storage_serialization_policy: Optional[pulumi.Input[str]] = None,
28
+ suspend_task_after_num_failures: Optional[pulumi.Input[int]] = None,
29
+ task_auto_retry_attempts: Optional[pulumi.Input[int]] = None,
30
+ trace_level: Optional[pulumi.Input[str]] = None,
31
+ user_task_managed_initial_warehouse_size: Optional[pulumi.Input[str]] = None,
32
+ user_task_minimum_trigger_interval_in_seconds: Optional[pulumi.Input[int]] = None,
33
+ user_task_timeout_ms: Optional[pulumi.Input[int]] = None):
34
+ """
35
+ The set of arguments for constructing a SharedDatabase resource.
36
+ :param pulumi.Input[str] from_share: A fully qualified path to a share from which the database will be created. A fully qualified path follows the format of `"<organization_name>"."<account_name>"."<share_name>"`.
37
+ :param pulumi.Input[str] catalog: The database parameter that specifies the default catalog to use for Iceberg tables.
38
+ :param pulumi.Input[str] comment: Specifies a comment for the database.
39
+ :param pulumi.Input[str] default_ddl_collation: Specifies a default collation specification for all schemas and tables added to the database. It can be overridden on schema or table level. For more information, see [collation specification](https://docs.snowflake.com/en/sql-reference/collation#label-collation-specification).
40
+ :param pulumi.Input[bool] enable_console_output: If true, enables stdout/stderr fast path logging for anonymous stored procedures.
41
+ :param pulumi.Input[str] external_volume: The database parameter that specifies the default external volume to use for Iceberg tables.
42
+ :param pulumi.Input[str] log_level: Specifies the severity level of messages that should be ingested and made available in the active event table. Valid options are: [TRACE DEBUG INFO WARN ERROR FATAL OFF]. Messages at the specified level (and at more severe levels) are ingested. For more information, see [LOG_LEVEL](https://docs.snowflake.com/en/sql-reference/parameters.html#label-log-level).
43
+ :param pulumi.Input[str] name: Specifies the identifier for the database; must be unique for your account.
44
+ :param pulumi.Input[bool] quoted_identifiers_ignore_case: If true, the case of quoted identifiers is ignored.
45
+ :param pulumi.Input[bool] replace_invalid_characters: Specifies whether to replace invalid UTF-8 characters with the Unicode replacement character (�) in query results for an Iceberg table. You can only set this parameter for tables that use an external Iceberg catalog.
46
+ :param pulumi.Input[str] storage_serialization_policy: The storage serialization policy for Iceberg tables that use Snowflake as the catalog. Valid options are: [COMPATIBLE OPTIMIZED]. COMPATIBLE: Snowflake performs encoding and compression of data files that ensures interoperability with third-party compute engines. OPTIMIZED: Snowflake performs encoding and compression of data files that ensures the best table performance within Snowflake.
47
+ :param pulumi.Input[int] suspend_task_after_num_failures: How many times a task must fail in a row before it is automatically suspended. 0 disables auto-suspending.
48
+ :param pulumi.Input[int] task_auto_retry_attempts: Maximum automatic retries allowed for a user task.
49
+ :param pulumi.Input[str] trace_level: Controls how trace events are ingested into the event table. Valid options are: [ALWAYS ON*EVENT OFF]. For information about levels, see [TRACE*LEVEL](https://docs.snowflake.com/en/sql-reference/parameters.html#label-trace-level).
50
+ :param pulumi.Input[str] user_task_managed_initial_warehouse_size: The initial size of warehouse to use for managed warehouses in the absence of history.
51
+ :param pulumi.Input[int] user_task_minimum_trigger_interval_in_seconds: Minimum amount of time between Triggered Task executions in seconds.
52
+ :param pulumi.Input[int] user_task_timeout_ms: User task execution timeout in milliseconds.
53
+ """
54
+ pulumi.set(__self__, "from_share", from_share)
55
+ if catalog is not None:
56
+ pulumi.set(__self__, "catalog", catalog)
57
+ if comment is not None:
58
+ pulumi.set(__self__, "comment", comment)
59
+ if default_ddl_collation is not None:
60
+ pulumi.set(__self__, "default_ddl_collation", default_ddl_collation)
61
+ if enable_console_output is not None:
62
+ pulumi.set(__self__, "enable_console_output", enable_console_output)
63
+ if external_volume is not None:
64
+ pulumi.set(__self__, "external_volume", external_volume)
65
+ if log_level is not None:
66
+ pulumi.set(__self__, "log_level", log_level)
67
+ if name is not None:
68
+ pulumi.set(__self__, "name", name)
69
+ if quoted_identifiers_ignore_case is not None:
70
+ pulumi.set(__self__, "quoted_identifiers_ignore_case", quoted_identifiers_ignore_case)
71
+ if replace_invalid_characters is not None:
72
+ pulumi.set(__self__, "replace_invalid_characters", replace_invalid_characters)
73
+ if storage_serialization_policy is not None:
74
+ pulumi.set(__self__, "storage_serialization_policy", storage_serialization_policy)
75
+ if suspend_task_after_num_failures is not None:
76
+ pulumi.set(__self__, "suspend_task_after_num_failures", suspend_task_after_num_failures)
77
+ if task_auto_retry_attempts is not None:
78
+ pulumi.set(__self__, "task_auto_retry_attempts", task_auto_retry_attempts)
79
+ if trace_level is not None:
80
+ pulumi.set(__self__, "trace_level", trace_level)
81
+ if user_task_managed_initial_warehouse_size is not None:
82
+ pulumi.set(__self__, "user_task_managed_initial_warehouse_size", user_task_managed_initial_warehouse_size)
83
+ if user_task_minimum_trigger_interval_in_seconds is not None:
84
+ pulumi.set(__self__, "user_task_minimum_trigger_interval_in_seconds", user_task_minimum_trigger_interval_in_seconds)
85
+ if user_task_timeout_ms is not None:
86
+ pulumi.set(__self__, "user_task_timeout_ms", user_task_timeout_ms)
87
+
88
+ @property
89
+ @pulumi.getter(name="fromShare")
90
+ def from_share(self) -> pulumi.Input[str]:
91
+ """
92
+ A fully qualified path to a share from which the database will be created. A fully qualified path follows the format of `"<organization_name>"."<account_name>"."<share_name>"`.
93
+ """
94
+ return pulumi.get(self, "from_share")
95
+
96
+ @from_share.setter
97
+ def from_share(self, value: pulumi.Input[str]):
98
+ pulumi.set(self, "from_share", value)
99
+
100
+ @property
101
+ @pulumi.getter
102
+ def catalog(self) -> Optional[pulumi.Input[str]]:
103
+ """
104
+ The database parameter that specifies the default catalog to use for Iceberg tables.
105
+ """
106
+ return pulumi.get(self, "catalog")
107
+
108
+ @catalog.setter
109
+ def catalog(self, value: Optional[pulumi.Input[str]]):
110
+ pulumi.set(self, "catalog", value)
111
+
112
+ @property
113
+ @pulumi.getter
114
+ def comment(self) -> Optional[pulumi.Input[str]]:
115
+ """
116
+ Specifies a comment for the database.
117
+ """
118
+ return pulumi.get(self, "comment")
119
+
120
+ @comment.setter
121
+ def comment(self, value: Optional[pulumi.Input[str]]):
122
+ pulumi.set(self, "comment", value)
123
+
124
+ @property
125
+ @pulumi.getter(name="defaultDdlCollation")
126
+ def default_ddl_collation(self) -> Optional[pulumi.Input[str]]:
127
+ """
128
+ Specifies a default collation specification for all schemas and tables added to the database. It can be overridden on schema or table level. For more information, see [collation specification](https://docs.snowflake.com/en/sql-reference/collation#label-collation-specification).
129
+ """
130
+ return pulumi.get(self, "default_ddl_collation")
131
+
132
+ @default_ddl_collation.setter
133
+ def default_ddl_collation(self, value: Optional[pulumi.Input[str]]):
134
+ pulumi.set(self, "default_ddl_collation", value)
135
+
136
+ @property
137
+ @pulumi.getter(name="enableConsoleOutput")
138
+ def enable_console_output(self) -> Optional[pulumi.Input[bool]]:
139
+ """
140
+ If true, enables stdout/stderr fast path logging for anonymous stored procedures.
141
+ """
142
+ return pulumi.get(self, "enable_console_output")
143
+
144
+ @enable_console_output.setter
145
+ def enable_console_output(self, value: Optional[pulumi.Input[bool]]):
146
+ pulumi.set(self, "enable_console_output", value)
147
+
148
+ @property
149
+ @pulumi.getter(name="externalVolume")
150
+ def external_volume(self) -> Optional[pulumi.Input[str]]:
151
+ """
152
+ The database parameter that specifies the default external volume to use for Iceberg tables.
153
+ """
154
+ return pulumi.get(self, "external_volume")
155
+
156
+ @external_volume.setter
157
+ def external_volume(self, value: Optional[pulumi.Input[str]]):
158
+ pulumi.set(self, "external_volume", value)
159
+
160
+ @property
161
+ @pulumi.getter(name="logLevel")
162
+ def log_level(self) -> Optional[pulumi.Input[str]]:
163
+ """
164
+ Specifies the severity level of messages that should be ingested and made available in the active event table. Valid options are: [TRACE DEBUG INFO WARN ERROR FATAL OFF]. Messages at the specified level (and at more severe levels) are ingested. For more information, see [LOG_LEVEL](https://docs.snowflake.com/en/sql-reference/parameters.html#label-log-level).
165
+ """
166
+ return pulumi.get(self, "log_level")
167
+
168
+ @log_level.setter
169
+ def log_level(self, value: Optional[pulumi.Input[str]]):
170
+ pulumi.set(self, "log_level", value)
171
+
172
+ @property
173
+ @pulumi.getter
174
+ def name(self) -> Optional[pulumi.Input[str]]:
175
+ """
176
+ Specifies the identifier for the database; must be unique for your account.
177
+ """
178
+ return pulumi.get(self, "name")
179
+
180
+ @name.setter
181
+ def name(self, value: Optional[pulumi.Input[str]]):
182
+ pulumi.set(self, "name", value)
183
+
184
+ @property
185
+ @pulumi.getter(name="quotedIdentifiersIgnoreCase")
186
+ def quoted_identifiers_ignore_case(self) -> Optional[pulumi.Input[bool]]:
187
+ """
188
+ If true, the case of quoted identifiers is ignored.
189
+ """
190
+ return pulumi.get(self, "quoted_identifiers_ignore_case")
191
+
192
+ @quoted_identifiers_ignore_case.setter
193
+ def quoted_identifiers_ignore_case(self, value: Optional[pulumi.Input[bool]]):
194
+ pulumi.set(self, "quoted_identifiers_ignore_case", value)
195
+
196
+ @property
197
+ @pulumi.getter(name="replaceInvalidCharacters")
198
+ def replace_invalid_characters(self) -> Optional[pulumi.Input[bool]]:
199
+ """
200
+ Specifies whether to replace invalid UTF-8 characters with the Unicode replacement character (�) in query results for an Iceberg table. You can only set this parameter for tables that use an external Iceberg catalog.
201
+ """
202
+ return pulumi.get(self, "replace_invalid_characters")
203
+
204
+ @replace_invalid_characters.setter
205
+ def replace_invalid_characters(self, value: Optional[pulumi.Input[bool]]):
206
+ pulumi.set(self, "replace_invalid_characters", value)
207
+
208
+ @property
209
+ @pulumi.getter(name="storageSerializationPolicy")
210
+ def storage_serialization_policy(self) -> Optional[pulumi.Input[str]]:
211
+ """
212
+ The storage serialization policy for Iceberg tables that use Snowflake as the catalog. Valid options are: [COMPATIBLE OPTIMIZED]. COMPATIBLE: Snowflake performs encoding and compression of data files that ensures interoperability with third-party compute engines. OPTIMIZED: Snowflake performs encoding and compression of data files that ensures the best table performance within Snowflake.
213
+ """
214
+ return pulumi.get(self, "storage_serialization_policy")
215
+
216
+ @storage_serialization_policy.setter
217
+ def storage_serialization_policy(self, value: Optional[pulumi.Input[str]]):
218
+ pulumi.set(self, "storage_serialization_policy", value)
219
+
220
+ @property
221
+ @pulumi.getter(name="suspendTaskAfterNumFailures")
222
+ def suspend_task_after_num_failures(self) -> Optional[pulumi.Input[int]]:
223
+ """
224
+ How many times a task must fail in a row before it is automatically suspended. 0 disables auto-suspending.
225
+ """
226
+ return pulumi.get(self, "suspend_task_after_num_failures")
227
+
228
+ @suspend_task_after_num_failures.setter
229
+ def suspend_task_after_num_failures(self, value: Optional[pulumi.Input[int]]):
230
+ pulumi.set(self, "suspend_task_after_num_failures", value)
231
+
232
+ @property
233
+ @pulumi.getter(name="taskAutoRetryAttempts")
234
+ def task_auto_retry_attempts(self) -> Optional[pulumi.Input[int]]:
235
+ """
236
+ Maximum automatic retries allowed for a user task.
237
+ """
238
+ return pulumi.get(self, "task_auto_retry_attempts")
239
+
240
+ @task_auto_retry_attempts.setter
241
+ def task_auto_retry_attempts(self, value: Optional[pulumi.Input[int]]):
242
+ pulumi.set(self, "task_auto_retry_attempts", value)
243
+
244
+ @property
245
+ @pulumi.getter(name="traceLevel")
246
+ def trace_level(self) -> Optional[pulumi.Input[str]]:
247
+ """
248
+ Controls how trace events are ingested into the event table. Valid options are: [ALWAYS ON*EVENT OFF]. For information about levels, see [TRACE*LEVEL](https://docs.snowflake.com/en/sql-reference/parameters.html#label-trace-level).
249
+ """
250
+ return pulumi.get(self, "trace_level")
251
+
252
+ @trace_level.setter
253
+ def trace_level(self, value: Optional[pulumi.Input[str]]):
254
+ pulumi.set(self, "trace_level", value)
255
+
256
+ @property
257
+ @pulumi.getter(name="userTaskManagedInitialWarehouseSize")
258
+ def user_task_managed_initial_warehouse_size(self) -> Optional[pulumi.Input[str]]:
259
+ """
260
+ The initial size of warehouse to use for managed warehouses in the absence of history.
261
+ """
262
+ return pulumi.get(self, "user_task_managed_initial_warehouse_size")
263
+
264
+ @user_task_managed_initial_warehouse_size.setter
265
+ def user_task_managed_initial_warehouse_size(self, value: Optional[pulumi.Input[str]]):
266
+ pulumi.set(self, "user_task_managed_initial_warehouse_size", value)
267
+
268
+ @property
269
+ @pulumi.getter(name="userTaskMinimumTriggerIntervalInSeconds")
270
+ def user_task_minimum_trigger_interval_in_seconds(self) -> Optional[pulumi.Input[int]]:
271
+ """
272
+ Minimum amount of time between Triggered Task executions in seconds.
273
+ """
274
+ return pulumi.get(self, "user_task_minimum_trigger_interval_in_seconds")
275
+
276
+ @user_task_minimum_trigger_interval_in_seconds.setter
277
+ def user_task_minimum_trigger_interval_in_seconds(self, value: Optional[pulumi.Input[int]]):
278
+ pulumi.set(self, "user_task_minimum_trigger_interval_in_seconds", value)
279
+
280
+ @property
281
+ @pulumi.getter(name="userTaskTimeoutMs")
282
+ def user_task_timeout_ms(self) -> Optional[pulumi.Input[int]]:
283
+ """
284
+ User task execution timeout in milliseconds.
285
+ """
286
+ return pulumi.get(self, "user_task_timeout_ms")
287
+
288
+ @user_task_timeout_ms.setter
289
+ def user_task_timeout_ms(self, value: Optional[pulumi.Input[int]]):
290
+ pulumi.set(self, "user_task_timeout_ms", value)
291
+
292
+
293
+ @pulumi.input_type
294
+ class _SharedDatabaseState:
295
+ def __init__(__self__, *,
296
+ catalog: Optional[pulumi.Input[str]] = None,
297
+ comment: Optional[pulumi.Input[str]] = None,
298
+ default_ddl_collation: Optional[pulumi.Input[str]] = None,
299
+ enable_console_output: Optional[pulumi.Input[bool]] = None,
300
+ external_volume: Optional[pulumi.Input[str]] = None,
301
+ from_share: Optional[pulumi.Input[str]] = None,
302
+ log_level: Optional[pulumi.Input[str]] = None,
303
+ name: Optional[pulumi.Input[str]] = None,
304
+ quoted_identifiers_ignore_case: Optional[pulumi.Input[bool]] = None,
305
+ replace_invalid_characters: Optional[pulumi.Input[bool]] = None,
306
+ storage_serialization_policy: Optional[pulumi.Input[str]] = None,
307
+ suspend_task_after_num_failures: Optional[pulumi.Input[int]] = None,
308
+ task_auto_retry_attempts: Optional[pulumi.Input[int]] = None,
309
+ trace_level: Optional[pulumi.Input[str]] = None,
310
+ user_task_managed_initial_warehouse_size: Optional[pulumi.Input[str]] = None,
311
+ user_task_minimum_trigger_interval_in_seconds: Optional[pulumi.Input[int]] = None,
312
+ user_task_timeout_ms: Optional[pulumi.Input[int]] = None):
313
+ """
314
+ Input properties used for looking up and filtering SharedDatabase resources.
315
+ :param pulumi.Input[str] catalog: The database parameter that specifies the default catalog to use for Iceberg tables.
316
+ :param pulumi.Input[str] comment: Specifies a comment for the database.
317
+ :param pulumi.Input[str] default_ddl_collation: Specifies a default collation specification for all schemas and tables added to the database. It can be overridden on schema or table level. For more information, see [collation specification](https://docs.snowflake.com/en/sql-reference/collation#label-collation-specification).
318
+ :param pulumi.Input[bool] enable_console_output: If true, enables stdout/stderr fast path logging for anonymous stored procedures.
319
+ :param pulumi.Input[str] external_volume: The database parameter that specifies the default external volume to use for Iceberg tables.
320
+ :param pulumi.Input[str] from_share: A fully qualified path to a share from which the database will be created. A fully qualified path follows the format of `"<organization_name>"."<account_name>"."<share_name>"`.
321
+ :param pulumi.Input[str] log_level: Specifies the severity level of messages that should be ingested and made available in the active event table. Valid options are: [TRACE DEBUG INFO WARN ERROR FATAL OFF]. Messages at the specified level (and at more severe levels) are ingested. For more information, see [LOG_LEVEL](https://docs.snowflake.com/en/sql-reference/parameters.html#label-log-level).
322
+ :param pulumi.Input[str] name: Specifies the identifier for the database; must be unique for your account.
323
+ :param pulumi.Input[bool] quoted_identifiers_ignore_case: If true, the case of quoted identifiers is ignored.
324
+ :param pulumi.Input[bool] replace_invalid_characters: Specifies whether to replace invalid UTF-8 characters with the Unicode replacement character (�) in query results for an Iceberg table. You can only set this parameter for tables that use an external Iceberg catalog.
325
+ :param pulumi.Input[str] storage_serialization_policy: The storage serialization policy for Iceberg tables that use Snowflake as the catalog. Valid options are: [COMPATIBLE OPTIMIZED]. COMPATIBLE: Snowflake performs encoding and compression of data files that ensures interoperability with third-party compute engines. OPTIMIZED: Snowflake performs encoding and compression of data files that ensures the best table performance within Snowflake.
326
+ :param pulumi.Input[int] suspend_task_after_num_failures: How many times a task must fail in a row before it is automatically suspended. 0 disables auto-suspending.
327
+ :param pulumi.Input[int] task_auto_retry_attempts: Maximum automatic retries allowed for a user task.
328
+ :param pulumi.Input[str] trace_level: Controls how trace events are ingested into the event table. Valid options are: [ALWAYS ON*EVENT OFF]. For information about levels, see [TRACE*LEVEL](https://docs.snowflake.com/en/sql-reference/parameters.html#label-trace-level).
329
+ :param pulumi.Input[str] user_task_managed_initial_warehouse_size: The initial size of warehouse to use for managed warehouses in the absence of history.
330
+ :param pulumi.Input[int] user_task_minimum_trigger_interval_in_seconds: Minimum amount of time between Triggered Task executions in seconds.
331
+ :param pulumi.Input[int] user_task_timeout_ms: User task execution timeout in milliseconds.
332
+ """
333
+ if catalog is not None:
334
+ pulumi.set(__self__, "catalog", catalog)
335
+ if comment is not None:
336
+ pulumi.set(__self__, "comment", comment)
337
+ if default_ddl_collation is not None:
338
+ pulumi.set(__self__, "default_ddl_collation", default_ddl_collation)
339
+ if enable_console_output is not None:
340
+ pulumi.set(__self__, "enable_console_output", enable_console_output)
341
+ if external_volume is not None:
342
+ pulumi.set(__self__, "external_volume", external_volume)
343
+ if from_share is not None:
344
+ pulumi.set(__self__, "from_share", from_share)
345
+ if log_level is not None:
346
+ pulumi.set(__self__, "log_level", log_level)
347
+ if name is not None:
348
+ pulumi.set(__self__, "name", name)
349
+ if quoted_identifiers_ignore_case is not None:
350
+ pulumi.set(__self__, "quoted_identifiers_ignore_case", quoted_identifiers_ignore_case)
351
+ if replace_invalid_characters is not None:
352
+ pulumi.set(__self__, "replace_invalid_characters", replace_invalid_characters)
353
+ if storage_serialization_policy is not None:
354
+ pulumi.set(__self__, "storage_serialization_policy", storage_serialization_policy)
355
+ if suspend_task_after_num_failures is not None:
356
+ pulumi.set(__self__, "suspend_task_after_num_failures", suspend_task_after_num_failures)
357
+ if task_auto_retry_attempts is not None:
358
+ pulumi.set(__self__, "task_auto_retry_attempts", task_auto_retry_attempts)
359
+ if trace_level is not None:
360
+ pulumi.set(__self__, "trace_level", trace_level)
361
+ if user_task_managed_initial_warehouse_size is not None:
362
+ pulumi.set(__self__, "user_task_managed_initial_warehouse_size", user_task_managed_initial_warehouse_size)
363
+ if user_task_minimum_trigger_interval_in_seconds is not None:
364
+ pulumi.set(__self__, "user_task_minimum_trigger_interval_in_seconds", user_task_minimum_trigger_interval_in_seconds)
365
+ if user_task_timeout_ms is not None:
366
+ pulumi.set(__self__, "user_task_timeout_ms", user_task_timeout_ms)
367
+
368
+ @property
369
+ @pulumi.getter
370
+ def catalog(self) -> Optional[pulumi.Input[str]]:
371
+ """
372
+ The database parameter that specifies the default catalog to use for Iceberg tables.
373
+ """
374
+ return pulumi.get(self, "catalog")
375
+
376
+ @catalog.setter
377
+ def catalog(self, value: Optional[pulumi.Input[str]]):
378
+ pulumi.set(self, "catalog", value)
379
+
380
+ @property
381
+ @pulumi.getter
382
+ def comment(self) -> Optional[pulumi.Input[str]]:
383
+ """
384
+ Specifies a comment for the database.
385
+ """
386
+ return pulumi.get(self, "comment")
387
+
388
+ @comment.setter
389
+ def comment(self, value: Optional[pulumi.Input[str]]):
390
+ pulumi.set(self, "comment", value)
391
+
392
+ @property
393
+ @pulumi.getter(name="defaultDdlCollation")
394
+ def default_ddl_collation(self) -> Optional[pulumi.Input[str]]:
395
+ """
396
+ Specifies a default collation specification for all schemas and tables added to the database. It can be overridden on schema or table level. For more information, see [collation specification](https://docs.snowflake.com/en/sql-reference/collation#label-collation-specification).
397
+ """
398
+ return pulumi.get(self, "default_ddl_collation")
399
+
400
+ @default_ddl_collation.setter
401
+ def default_ddl_collation(self, value: Optional[pulumi.Input[str]]):
402
+ pulumi.set(self, "default_ddl_collation", value)
403
+
404
+ @property
405
+ @pulumi.getter(name="enableConsoleOutput")
406
+ def enable_console_output(self) -> Optional[pulumi.Input[bool]]:
407
+ """
408
+ If true, enables stdout/stderr fast path logging for anonymous stored procedures.
409
+ """
410
+ return pulumi.get(self, "enable_console_output")
411
+
412
+ @enable_console_output.setter
413
+ def enable_console_output(self, value: Optional[pulumi.Input[bool]]):
414
+ pulumi.set(self, "enable_console_output", value)
415
+
416
+ @property
417
+ @pulumi.getter(name="externalVolume")
418
+ def external_volume(self) -> Optional[pulumi.Input[str]]:
419
+ """
420
+ The database parameter that specifies the default external volume to use for Iceberg tables.
421
+ """
422
+ return pulumi.get(self, "external_volume")
423
+
424
+ @external_volume.setter
425
+ def external_volume(self, value: Optional[pulumi.Input[str]]):
426
+ pulumi.set(self, "external_volume", value)
427
+
428
+ @property
429
+ @pulumi.getter(name="fromShare")
430
+ def from_share(self) -> Optional[pulumi.Input[str]]:
431
+ """
432
+ A fully qualified path to a share from which the database will be created. A fully qualified path follows the format of `"<organization_name>"."<account_name>"."<share_name>"`.
433
+ """
434
+ return pulumi.get(self, "from_share")
435
+
436
+ @from_share.setter
437
+ def from_share(self, value: Optional[pulumi.Input[str]]):
438
+ pulumi.set(self, "from_share", value)
439
+
440
+ @property
441
+ @pulumi.getter(name="logLevel")
442
+ def log_level(self) -> Optional[pulumi.Input[str]]:
443
+ """
444
+ Specifies the severity level of messages that should be ingested and made available in the active event table. Valid options are: [TRACE DEBUG INFO WARN ERROR FATAL OFF]. Messages at the specified level (and at more severe levels) are ingested. For more information, see [LOG_LEVEL](https://docs.snowflake.com/en/sql-reference/parameters.html#label-log-level).
445
+ """
446
+ return pulumi.get(self, "log_level")
447
+
448
+ @log_level.setter
449
+ def log_level(self, value: Optional[pulumi.Input[str]]):
450
+ pulumi.set(self, "log_level", value)
451
+
452
+ @property
453
+ @pulumi.getter
454
+ def name(self) -> Optional[pulumi.Input[str]]:
455
+ """
456
+ Specifies the identifier for the database; must be unique for your account.
457
+ """
458
+ return pulumi.get(self, "name")
459
+
460
+ @name.setter
461
+ def name(self, value: Optional[pulumi.Input[str]]):
462
+ pulumi.set(self, "name", value)
463
+
464
+ @property
465
+ @pulumi.getter(name="quotedIdentifiersIgnoreCase")
466
+ def quoted_identifiers_ignore_case(self) -> Optional[pulumi.Input[bool]]:
467
+ """
468
+ If true, the case of quoted identifiers is ignored.
469
+ """
470
+ return pulumi.get(self, "quoted_identifiers_ignore_case")
471
+
472
+ @quoted_identifiers_ignore_case.setter
473
+ def quoted_identifiers_ignore_case(self, value: Optional[pulumi.Input[bool]]):
474
+ pulumi.set(self, "quoted_identifiers_ignore_case", value)
475
+
476
+ @property
477
+ @pulumi.getter(name="replaceInvalidCharacters")
478
+ def replace_invalid_characters(self) -> Optional[pulumi.Input[bool]]:
479
+ """
480
+ Specifies whether to replace invalid UTF-8 characters with the Unicode replacement character (�) in query results for an Iceberg table. You can only set this parameter for tables that use an external Iceberg catalog.
481
+ """
482
+ return pulumi.get(self, "replace_invalid_characters")
483
+
484
+ @replace_invalid_characters.setter
485
+ def replace_invalid_characters(self, value: Optional[pulumi.Input[bool]]):
486
+ pulumi.set(self, "replace_invalid_characters", value)
487
+
488
+ @property
489
+ @pulumi.getter(name="storageSerializationPolicy")
490
+ def storage_serialization_policy(self) -> Optional[pulumi.Input[str]]:
491
+ """
492
+ The storage serialization policy for Iceberg tables that use Snowflake as the catalog. Valid options are: [COMPATIBLE OPTIMIZED]. COMPATIBLE: Snowflake performs encoding and compression of data files that ensures interoperability with third-party compute engines. OPTIMIZED: Snowflake performs encoding and compression of data files that ensures the best table performance within Snowflake.
493
+ """
494
+ return pulumi.get(self, "storage_serialization_policy")
495
+
496
+ @storage_serialization_policy.setter
497
+ def storage_serialization_policy(self, value: Optional[pulumi.Input[str]]):
498
+ pulumi.set(self, "storage_serialization_policy", value)
499
+
500
+ @property
501
+ @pulumi.getter(name="suspendTaskAfterNumFailures")
502
+ def suspend_task_after_num_failures(self) -> Optional[pulumi.Input[int]]:
503
+ """
504
+ How many times a task must fail in a row before it is automatically suspended. 0 disables auto-suspending.
505
+ """
506
+ return pulumi.get(self, "suspend_task_after_num_failures")
507
+
508
+ @suspend_task_after_num_failures.setter
509
+ def suspend_task_after_num_failures(self, value: Optional[pulumi.Input[int]]):
510
+ pulumi.set(self, "suspend_task_after_num_failures", value)
511
+
512
+ @property
513
+ @pulumi.getter(name="taskAutoRetryAttempts")
514
+ def task_auto_retry_attempts(self) -> Optional[pulumi.Input[int]]:
515
+ """
516
+ Maximum automatic retries allowed for a user task.
517
+ """
518
+ return pulumi.get(self, "task_auto_retry_attempts")
519
+
520
+ @task_auto_retry_attempts.setter
521
+ def task_auto_retry_attempts(self, value: Optional[pulumi.Input[int]]):
522
+ pulumi.set(self, "task_auto_retry_attempts", value)
523
+
524
+ @property
525
+ @pulumi.getter(name="traceLevel")
526
+ def trace_level(self) -> Optional[pulumi.Input[str]]:
527
+ """
528
+ Controls how trace events are ingested into the event table. Valid options are: [ALWAYS ON*EVENT OFF]. For information about levels, see [TRACE*LEVEL](https://docs.snowflake.com/en/sql-reference/parameters.html#label-trace-level).
529
+ """
530
+ return pulumi.get(self, "trace_level")
531
+
532
+ @trace_level.setter
533
+ def trace_level(self, value: Optional[pulumi.Input[str]]):
534
+ pulumi.set(self, "trace_level", value)
535
+
536
+ @property
537
+ @pulumi.getter(name="userTaskManagedInitialWarehouseSize")
538
+ def user_task_managed_initial_warehouse_size(self) -> Optional[pulumi.Input[str]]:
539
+ """
540
+ The initial size of warehouse to use for managed warehouses in the absence of history.
541
+ """
542
+ return pulumi.get(self, "user_task_managed_initial_warehouse_size")
543
+
544
+ @user_task_managed_initial_warehouse_size.setter
545
+ def user_task_managed_initial_warehouse_size(self, value: Optional[pulumi.Input[str]]):
546
+ pulumi.set(self, "user_task_managed_initial_warehouse_size", value)
547
+
548
+ @property
549
+ @pulumi.getter(name="userTaskMinimumTriggerIntervalInSeconds")
550
+ def user_task_minimum_trigger_interval_in_seconds(self) -> Optional[pulumi.Input[int]]:
551
+ """
552
+ Minimum amount of time between Triggered Task executions in seconds.
553
+ """
554
+ return pulumi.get(self, "user_task_minimum_trigger_interval_in_seconds")
555
+
556
+ @user_task_minimum_trigger_interval_in_seconds.setter
557
+ def user_task_minimum_trigger_interval_in_seconds(self, value: Optional[pulumi.Input[int]]):
558
+ pulumi.set(self, "user_task_minimum_trigger_interval_in_seconds", value)
559
+
560
+ @property
561
+ @pulumi.getter(name="userTaskTimeoutMs")
562
+ def user_task_timeout_ms(self) -> Optional[pulumi.Input[int]]:
563
+ """
564
+ User task execution timeout in milliseconds.
565
+ """
566
+ return pulumi.get(self, "user_task_timeout_ms")
567
+
568
+ @user_task_timeout_ms.setter
569
+ def user_task_timeout_ms(self, value: Optional[pulumi.Input[int]]):
570
+ pulumi.set(self, "user_task_timeout_ms", value)
571
+
572
+
573
+ class SharedDatabase(pulumi.CustomResource):
574
+ @overload
575
+ def __init__(__self__,
576
+ resource_name: str,
577
+ opts: Optional[pulumi.ResourceOptions] = None,
578
+ catalog: Optional[pulumi.Input[str]] = None,
579
+ comment: Optional[pulumi.Input[str]] = None,
580
+ default_ddl_collation: Optional[pulumi.Input[str]] = None,
581
+ enable_console_output: Optional[pulumi.Input[bool]] = None,
582
+ external_volume: Optional[pulumi.Input[str]] = None,
583
+ from_share: Optional[pulumi.Input[str]] = None,
584
+ log_level: Optional[pulumi.Input[str]] = None,
585
+ name: Optional[pulumi.Input[str]] = None,
586
+ quoted_identifiers_ignore_case: Optional[pulumi.Input[bool]] = None,
587
+ replace_invalid_characters: Optional[pulumi.Input[bool]] = None,
588
+ storage_serialization_policy: Optional[pulumi.Input[str]] = None,
589
+ suspend_task_after_num_failures: Optional[pulumi.Input[int]] = None,
590
+ task_auto_retry_attempts: Optional[pulumi.Input[int]] = None,
591
+ trace_level: Optional[pulumi.Input[str]] = None,
592
+ user_task_managed_initial_warehouse_size: Optional[pulumi.Input[str]] = None,
593
+ user_task_minimum_trigger_interval_in_seconds: Optional[pulumi.Input[int]] = None,
594
+ user_task_timeout_ms: Optional[pulumi.Input[int]] = None,
595
+ __props__=None):
596
+ """
597
+ !> **V1 release candidate** This resource was reworked and is a release candidate for the V1. We do not expect significant changes in it before the V1. We will welcome any feedback and adjust the resource if needed. Any errors reported will be resolved with a higher priority. We encourage checking this resource out before the V1 release. Please follow the migration guide to use it.
598
+
599
+ A shared database creates a database from a share provided by another Snowflake account. For more information about shares, see [Introduction to Secure Data Sharing](https://docs.snowflake.com/en/user-guide/data-sharing-intro).
600
+
601
+ ## Import
602
+
603
+ ```sh
604
+ $ pulumi import snowflake:index/sharedDatabase:SharedDatabase example 'shared_database_name'
605
+ ```
606
+
607
+ :param str resource_name: The name of the resource.
608
+ :param pulumi.ResourceOptions opts: Options for the resource.
609
+ :param pulumi.Input[str] catalog: The database parameter that specifies the default catalog to use for Iceberg tables.
610
+ :param pulumi.Input[str] comment: Specifies a comment for the database.
611
+ :param pulumi.Input[str] default_ddl_collation: Specifies a default collation specification for all schemas and tables added to the database. It can be overridden on schema or table level. For more information, see [collation specification](https://docs.snowflake.com/en/sql-reference/collation#label-collation-specification).
612
+ :param pulumi.Input[bool] enable_console_output: If true, enables stdout/stderr fast path logging for anonymous stored procedures.
613
+ :param pulumi.Input[str] external_volume: The database parameter that specifies the default external volume to use for Iceberg tables.
614
+ :param pulumi.Input[str] from_share: A fully qualified path to a share from which the database will be created. A fully qualified path follows the format of `"<organization_name>"."<account_name>"."<share_name>"`.
615
+ :param pulumi.Input[str] log_level: Specifies the severity level of messages that should be ingested and made available in the active event table. Valid options are: [TRACE DEBUG INFO WARN ERROR FATAL OFF]. Messages at the specified level (and at more severe levels) are ingested. For more information, see [LOG_LEVEL](https://docs.snowflake.com/en/sql-reference/parameters.html#label-log-level).
616
+ :param pulumi.Input[str] name: Specifies the identifier for the database; must be unique for your account.
617
+ :param pulumi.Input[bool] quoted_identifiers_ignore_case: If true, the case of quoted identifiers is ignored.
618
+ :param pulumi.Input[bool] replace_invalid_characters: Specifies whether to replace invalid UTF-8 characters with the Unicode replacement character (�) in query results for an Iceberg table. You can only set this parameter for tables that use an external Iceberg catalog.
619
+ :param pulumi.Input[str] storage_serialization_policy: The storage serialization policy for Iceberg tables that use Snowflake as the catalog. Valid options are: [COMPATIBLE OPTIMIZED]. COMPATIBLE: Snowflake performs encoding and compression of data files that ensures interoperability with third-party compute engines. OPTIMIZED: Snowflake performs encoding and compression of data files that ensures the best table performance within Snowflake.
620
+ :param pulumi.Input[int] suspend_task_after_num_failures: How many times a task must fail in a row before it is automatically suspended. 0 disables auto-suspending.
621
+ :param pulumi.Input[int] task_auto_retry_attempts: Maximum automatic retries allowed for a user task.
622
+ :param pulumi.Input[str] trace_level: Controls how trace events are ingested into the event table. Valid options are: [ALWAYS ON*EVENT OFF]. For information about levels, see [TRACE*LEVEL](https://docs.snowflake.com/en/sql-reference/parameters.html#label-trace-level).
623
+ :param pulumi.Input[str] user_task_managed_initial_warehouse_size: The initial size of warehouse to use for managed warehouses in the absence of history.
624
+ :param pulumi.Input[int] user_task_minimum_trigger_interval_in_seconds: Minimum amount of time between Triggered Task executions in seconds.
625
+ :param pulumi.Input[int] user_task_timeout_ms: User task execution timeout in milliseconds.
626
+ """
627
+ ...
628
+ @overload
629
+ def __init__(__self__,
630
+ resource_name: str,
631
+ args: SharedDatabaseArgs,
632
+ opts: Optional[pulumi.ResourceOptions] = None):
633
+ """
634
+ !> **V1 release candidate** This resource was reworked and is a release candidate for the V1. We do not expect significant changes in it before the V1. We will welcome any feedback and adjust the resource if needed. Any errors reported will be resolved with a higher priority. We encourage checking this resource out before the V1 release. Please follow the migration guide to use it.
635
+
636
+ A shared database creates a database from a share provided by another Snowflake account. For more information about shares, see [Introduction to Secure Data Sharing](https://docs.snowflake.com/en/user-guide/data-sharing-intro).
637
+
638
+ ## Import
639
+
640
+ ```sh
641
+ $ pulumi import snowflake:index/sharedDatabase:SharedDatabase example 'shared_database_name'
642
+ ```
643
+
644
+ :param str resource_name: The name of the resource.
645
+ :param SharedDatabaseArgs args: The arguments to use to populate this resource's properties.
646
+ :param pulumi.ResourceOptions opts: Options for the resource.
647
+ """
648
+ ...
649
+ def __init__(__self__, resource_name: str, *args, **kwargs):
650
+ resource_args, opts = _utilities.get_resource_args_opts(SharedDatabaseArgs, pulumi.ResourceOptions, *args, **kwargs)
651
+ if resource_args is not None:
652
+ __self__._internal_init(resource_name, opts, **resource_args.__dict__)
653
+ else:
654
+ __self__._internal_init(resource_name, *args, **kwargs)
655
+
656
+ def _internal_init(__self__,
657
+ resource_name: str,
658
+ opts: Optional[pulumi.ResourceOptions] = None,
659
+ catalog: Optional[pulumi.Input[str]] = None,
660
+ comment: Optional[pulumi.Input[str]] = None,
661
+ default_ddl_collation: Optional[pulumi.Input[str]] = None,
662
+ enable_console_output: Optional[pulumi.Input[bool]] = None,
663
+ external_volume: Optional[pulumi.Input[str]] = None,
664
+ from_share: Optional[pulumi.Input[str]] = None,
665
+ log_level: Optional[pulumi.Input[str]] = None,
666
+ name: Optional[pulumi.Input[str]] = None,
667
+ quoted_identifiers_ignore_case: Optional[pulumi.Input[bool]] = None,
668
+ replace_invalid_characters: Optional[pulumi.Input[bool]] = None,
669
+ storage_serialization_policy: Optional[pulumi.Input[str]] = None,
670
+ suspend_task_after_num_failures: Optional[pulumi.Input[int]] = None,
671
+ task_auto_retry_attempts: Optional[pulumi.Input[int]] = None,
672
+ trace_level: Optional[pulumi.Input[str]] = None,
673
+ user_task_managed_initial_warehouse_size: Optional[pulumi.Input[str]] = None,
674
+ user_task_minimum_trigger_interval_in_seconds: Optional[pulumi.Input[int]] = None,
675
+ user_task_timeout_ms: Optional[pulumi.Input[int]] = None,
676
+ __props__=None):
677
+ opts = pulumi.ResourceOptions.merge(_utilities.get_resource_opts_defaults(), opts)
678
+ if not isinstance(opts, pulumi.ResourceOptions):
679
+ raise TypeError('Expected resource options to be a ResourceOptions instance')
680
+ if opts.id is None:
681
+ if __props__ is not None:
682
+ raise TypeError('__props__ is only valid when passed in combination with a valid opts.id to get an existing resource')
683
+ __props__ = SharedDatabaseArgs.__new__(SharedDatabaseArgs)
684
+
685
+ __props__.__dict__["catalog"] = catalog
686
+ __props__.__dict__["comment"] = comment
687
+ __props__.__dict__["default_ddl_collation"] = default_ddl_collation
688
+ __props__.__dict__["enable_console_output"] = enable_console_output
689
+ __props__.__dict__["external_volume"] = external_volume
690
+ if from_share is None and not opts.urn:
691
+ raise TypeError("Missing required property 'from_share'")
692
+ __props__.__dict__["from_share"] = from_share
693
+ __props__.__dict__["log_level"] = log_level
694
+ __props__.__dict__["name"] = name
695
+ __props__.__dict__["quoted_identifiers_ignore_case"] = quoted_identifiers_ignore_case
696
+ __props__.__dict__["replace_invalid_characters"] = replace_invalid_characters
697
+ __props__.__dict__["storage_serialization_policy"] = storage_serialization_policy
698
+ __props__.__dict__["suspend_task_after_num_failures"] = suspend_task_after_num_failures
699
+ __props__.__dict__["task_auto_retry_attempts"] = task_auto_retry_attempts
700
+ __props__.__dict__["trace_level"] = trace_level
701
+ __props__.__dict__["user_task_managed_initial_warehouse_size"] = user_task_managed_initial_warehouse_size
702
+ __props__.__dict__["user_task_minimum_trigger_interval_in_seconds"] = user_task_minimum_trigger_interval_in_seconds
703
+ __props__.__dict__["user_task_timeout_ms"] = user_task_timeout_ms
704
+ super(SharedDatabase, __self__).__init__(
705
+ 'snowflake:index/sharedDatabase:SharedDatabase',
706
+ resource_name,
707
+ __props__,
708
+ opts)
709
+
710
+ @staticmethod
711
+ def get(resource_name: str,
712
+ id: pulumi.Input[str],
713
+ opts: Optional[pulumi.ResourceOptions] = None,
714
+ catalog: Optional[pulumi.Input[str]] = None,
715
+ comment: Optional[pulumi.Input[str]] = None,
716
+ default_ddl_collation: Optional[pulumi.Input[str]] = None,
717
+ enable_console_output: Optional[pulumi.Input[bool]] = None,
718
+ external_volume: Optional[pulumi.Input[str]] = None,
719
+ from_share: Optional[pulumi.Input[str]] = None,
720
+ log_level: Optional[pulumi.Input[str]] = None,
721
+ name: Optional[pulumi.Input[str]] = None,
722
+ quoted_identifiers_ignore_case: Optional[pulumi.Input[bool]] = None,
723
+ replace_invalid_characters: Optional[pulumi.Input[bool]] = None,
724
+ storage_serialization_policy: Optional[pulumi.Input[str]] = None,
725
+ suspend_task_after_num_failures: Optional[pulumi.Input[int]] = None,
726
+ task_auto_retry_attempts: Optional[pulumi.Input[int]] = None,
727
+ trace_level: Optional[pulumi.Input[str]] = None,
728
+ user_task_managed_initial_warehouse_size: Optional[pulumi.Input[str]] = None,
729
+ user_task_minimum_trigger_interval_in_seconds: Optional[pulumi.Input[int]] = None,
730
+ user_task_timeout_ms: Optional[pulumi.Input[int]] = None) -> 'SharedDatabase':
731
+ """
732
+ Get an existing SharedDatabase resource's state with the given name, id, and optional extra
733
+ properties used to qualify the lookup.
734
+
735
+ :param str resource_name: The unique name of the resulting resource.
736
+ :param pulumi.Input[str] id: The unique provider ID of the resource to lookup.
737
+ :param pulumi.ResourceOptions opts: Options for the resource.
738
+ :param pulumi.Input[str] catalog: The database parameter that specifies the default catalog to use for Iceberg tables.
739
+ :param pulumi.Input[str] comment: Specifies a comment for the database.
740
+ :param pulumi.Input[str] default_ddl_collation: Specifies a default collation specification for all schemas and tables added to the database. It can be overridden on schema or table level. For more information, see [collation specification](https://docs.snowflake.com/en/sql-reference/collation#label-collation-specification).
741
+ :param pulumi.Input[bool] enable_console_output: If true, enables stdout/stderr fast path logging for anonymous stored procedures.
742
+ :param pulumi.Input[str] external_volume: The database parameter that specifies the default external volume to use for Iceberg tables.
743
+ :param pulumi.Input[str] from_share: A fully qualified path to a share from which the database will be created. A fully qualified path follows the format of `"<organization_name>"."<account_name>"."<share_name>"`.
744
+ :param pulumi.Input[str] log_level: Specifies the severity level of messages that should be ingested and made available in the active event table. Valid options are: [TRACE DEBUG INFO WARN ERROR FATAL OFF]. Messages at the specified level (and at more severe levels) are ingested. For more information, see [LOG_LEVEL](https://docs.snowflake.com/en/sql-reference/parameters.html#label-log-level).
745
+ :param pulumi.Input[str] name: Specifies the identifier for the database; must be unique for your account.
746
+ :param pulumi.Input[bool] quoted_identifiers_ignore_case: If true, the case of quoted identifiers is ignored.
747
+ :param pulumi.Input[bool] replace_invalid_characters: Specifies whether to replace invalid UTF-8 characters with the Unicode replacement character (�) in query results for an Iceberg table. You can only set this parameter for tables that use an external Iceberg catalog.
748
+ :param pulumi.Input[str] storage_serialization_policy: The storage serialization policy for Iceberg tables that use Snowflake as the catalog. Valid options are: [COMPATIBLE OPTIMIZED]. COMPATIBLE: Snowflake performs encoding and compression of data files that ensures interoperability with third-party compute engines. OPTIMIZED: Snowflake performs encoding and compression of data files that ensures the best table performance within Snowflake.
749
+ :param pulumi.Input[int] suspend_task_after_num_failures: How many times a task must fail in a row before it is automatically suspended. 0 disables auto-suspending.
750
+ :param pulumi.Input[int] task_auto_retry_attempts: Maximum automatic retries allowed for a user task.
751
+ :param pulumi.Input[str] trace_level: Controls how trace events are ingested into the event table. Valid options are: [ALWAYS ON*EVENT OFF]. For information about levels, see [TRACE*LEVEL](https://docs.snowflake.com/en/sql-reference/parameters.html#label-trace-level).
752
+ :param pulumi.Input[str] user_task_managed_initial_warehouse_size: The initial size of warehouse to use for managed warehouses in the absence of history.
753
+ :param pulumi.Input[int] user_task_minimum_trigger_interval_in_seconds: Minimum amount of time between Triggered Task executions in seconds.
754
+ :param pulumi.Input[int] user_task_timeout_ms: User task execution timeout in milliseconds.
755
+ """
756
+ opts = pulumi.ResourceOptions.merge(opts, pulumi.ResourceOptions(id=id))
757
+
758
+ __props__ = _SharedDatabaseState.__new__(_SharedDatabaseState)
759
+
760
+ __props__.__dict__["catalog"] = catalog
761
+ __props__.__dict__["comment"] = comment
762
+ __props__.__dict__["default_ddl_collation"] = default_ddl_collation
763
+ __props__.__dict__["enable_console_output"] = enable_console_output
764
+ __props__.__dict__["external_volume"] = external_volume
765
+ __props__.__dict__["from_share"] = from_share
766
+ __props__.__dict__["log_level"] = log_level
767
+ __props__.__dict__["name"] = name
768
+ __props__.__dict__["quoted_identifiers_ignore_case"] = quoted_identifiers_ignore_case
769
+ __props__.__dict__["replace_invalid_characters"] = replace_invalid_characters
770
+ __props__.__dict__["storage_serialization_policy"] = storage_serialization_policy
771
+ __props__.__dict__["suspend_task_after_num_failures"] = suspend_task_after_num_failures
772
+ __props__.__dict__["task_auto_retry_attempts"] = task_auto_retry_attempts
773
+ __props__.__dict__["trace_level"] = trace_level
774
+ __props__.__dict__["user_task_managed_initial_warehouse_size"] = user_task_managed_initial_warehouse_size
775
+ __props__.__dict__["user_task_minimum_trigger_interval_in_seconds"] = user_task_minimum_trigger_interval_in_seconds
776
+ __props__.__dict__["user_task_timeout_ms"] = user_task_timeout_ms
777
+ return SharedDatabase(resource_name, opts=opts, __props__=__props__)
778
+
779
+ @property
780
+ @pulumi.getter
781
+ def catalog(self) -> pulumi.Output[str]:
782
+ """
783
+ The database parameter that specifies the default catalog to use for Iceberg tables.
784
+ """
785
+ return pulumi.get(self, "catalog")
786
+
787
+ @property
788
+ @pulumi.getter
789
+ def comment(self) -> pulumi.Output[Optional[str]]:
790
+ """
791
+ Specifies a comment for the database.
792
+ """
793
+ return pulumi.get(self, "comment")
794
+
795
+ @property
796
+ @pulumi.getter(name="defaultDdlCollation")
797
+ def default_ddl_collation(self) -> pulumi.Output[str]:
798
+ """
799
+ Specifies a default collation specification for all schemas and tables added to the database. It can be overridden on schema or table level. For more information, see [collation specification](https://docs.snowflake.com/en/sql-reference/collation#label-collation-specification).
800
+ """
801
+ return pulumi.get(self, "default_ddl_collation")
802
+
803
+ @property
804
+ @pulumi.getter(name="enableConsoleOutput")
805
+ def enable_console_output(self) -> pulumi.Output[bool]:
806
+ """
807
+ If true, enables stdout/stderr fast path logging for anonymous stored procedures.
808
+ """
809
+ return pulumi.get(self, "enable_console_output")
810
+
811
+ @property
812
+ @pulumi.getter(name="externalVolume")
813
+ def external_volume(self) -> pulumi.Output[str]:
814
+ """
815
+ The database parameter that specifies the default external volume to use for Iceberg tables.
816
+ """
817
+ return pulumi.get(self, "external_volume")
818
+
819
+ @property
820
+ @pulumi.getter(name="fromShare")
821
+ def from_share(self) -> pulumi.Output[str]:
822
+ """
823
+ A fully qualified path to a share from which the database will be created. A fully qualified path follows the format of `"<organization_name>"."<account_name>"."<share_name>"`.
824
+ """
825
+ return pulumi.get(self, "from_share")
826
+
827
+ @property
828
+ @pulumi.getter(name="logLevel")
829
+ def log_level(self) -> pulumi.Output[str]:
830
+ """
831
+ Specifies the severity level of messages that should be ingested and made available in the active event table. Valid options are: [TRACE DEBUG INFO WARN ERROR FATAL OFF]. Messages at the specified level (and at more severe levels) are ingested. For more information, see [LOG_LEVEL](https://docs.snowflake.com/en/sql-reference/parameters.html#label-log-level).
832
+ """
833
+ return pulumi.get(self, "log_level")
834
+
835
+ @property
836
+ @pulumi.getter
837
+ def name(self) -> pulumi.Output[str]:
838
+ """
839
+ Specifies the identifier for the database; must be unique for your account.
840
+ """
841
+ return pulumi.get(self, "name")
842
+
843
+ @property
844
+ @pulumi.getter(name="quotedIdentifiersIgnoreCase")
845
+ def quoted_identifiers_ignore_case(self) -> pulumi.Output[bool]:
846
+ """
847
+ If true, the case of quoted identifiers is ignored.
848
+ """
849
+ return pulumi.get(self, "quoted_identifiers_ignore_case")
850
+
851
+ @property
852
+ @pulumi.getter(name="replaceInvalidCharacters")
853
+ def replace_invalid_characters(self) -> pulumi.Output[bool]:
854
+ """
855
+ Specifies whether to replace invalid UTF-8 characters with the Unicode replacement character (�) in query results for an Iceberg table. You can only set this parameter for tables that use an external Iceberg catalog.
856
+ """
857
+ return pulumi.get(self, "replace_invalid_characters")
858
+
859
+ @property
860
+ @pulumi.getter(name="storageSerializationPolicy")
861
+ def storage_serialization_policy(self) -> pulumi.Output[str]:
862
+ """
863
+ The storage serialization policy for Iceberg tables that use Snowflake as the catalog. Valid options are: [COMPATIBLE OPTIMIZED]. COMPATIBLE: Snowflake performs encoding and compression of data files that ensures interoperability with third-party compute engines. OPTIMIZED: Snowflake performs encoding and compression of data files that ensures the best table performance within Snowflake.
864
+ """
865
+ return pulumi.get(self, "storage_serialization_policy")
866
+
867
+ @property
868
+ @pulumi.getter(name="suspendTaskAfterNumFailures")
869
+ def suspend_task_after_num_failures(self) -> pulumi.Output[int]:
870
+ """
871
+ How many times a task must fail in a row before it is automatically suspended. 0 disables auto-suspending.
872
+ """
873
+ return pulumi.get(self, "suspend_task_after_num_failures")
874
+
875
+ @property
876
+ @pulumi.getter(name="taskAutoRetryAttempts")
877
+ def task_auto_retry_attempts(self) -> pulumi.Output[int]:
878
+ """
879
+ Maximum automatic retries allowed for a user task.
880
+ """
881
+ return pulumi.get(self, "task_auto_retry_attempts")
882
+
883
+ @property
884
+ @pulumi.getter(name="traceLevel")
885
+ def trace_level(self) -> pulumi.Output[str]:
886
+ """
887
+ Controls how trace events are ingested into the event table. Valid options are: [ALWAYS ON*EVENT OFF]. For information about levels, see [TRACE*LEVEL](https://docs.snowflake.com/en/sql-reference/parameters.html#label-trace-level).
888
+ """
889
+ return pulumi.get(self, "trace_level")
890
+
891
+ @property
892
+ @pulumi.getter(name="userTaskManagedInitialWarehouseSize")
893
+ def user_task_managed_initial_warehouse_size(self) -> pulumi.Output[str]:
894
+ """
895
+ The initial size of warehouse to use for managed warehouses in the absence of history.
896
+ """
897
+ return pulumi.get(self, "user_task_managed_initial_warehouse_size")
898
+
899
+ @property
900
+ @pulumi.getter(name="userTaskMinimumTriggerIntervalInSeconds")
901
+ def user_task_minimum_trigger_interval_in_seconds(self) -> pulumi.Output[int]:
902
+ """
903
+ Minimum amount of time between Triggered Task executions in seconds.
904
+ """
905
+ return pulumi.get(self, "user_task_minimum_trigger_interval_in_seconds")
906
+
907
+ @property
908
+ @pulumi.getter(name="userTaskTimeoutMs")
909
+ def user_task_timeout_ms(self) -> pulumi.Output[int]:
910
+ """
911
+ User task execution timeout in milliseconds.
912
+ """
913
+ return pulumi.get(self, "user_task_timeout_ms")
914
+