pulumi-webflow 0.0.0__py3-none-any.whl

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -0,0 +1,334 @@
1
+ # coding=utf-8
2
+ # *** WARNING: this file was generated by pulumi-language-python. ***
3
+ # *** Do not edit by hand unless you're certain you know what you are doing! ***
4
+
5
+ import builtins as _builtins
6
+ import warnings
7
+ import sys
8
+ import pulumi
9
+ import pulumi.runtime
10
+ from typing import Any, Mapping, Optional, Sequence, Union, overload
11
+ if sys.version_info >= (3, 11):
12
+ from typing import NotRequired, TypedDict, TypeAlias
13
+ else:
14
+ from typing_extensions import NotRequired, TypedDict, TypeAlias
15
+ from . import _utilities
16
+
17
+ __all__ = ['AssetArgs', 'Asset']
18
+
19
+ @pulumi.input_type
20
+ class AssetArgs:
21
+ def __init__(__self__, *,
22
+ file_hash: pulumi.Input[_builtins.str],
23
+ file_name: pulumi.Input[_builtins.str],
24
+ site_id: pulumi.Input[_builtins.str],
25
+ file_source: Optional[pulumi.Input[_builtins.str]] = None,
26
+ parent_folder: Optional[pulumi.Input[_builtins.str]] = None):
27
+ """
28
+ The set of arguments for constructing a Asset resource.
29
+ :param pulumi.Input[_builtins.str] file_hash: MD5 hash of the file content (required). Webflow uses this hash to identify and deduplicate assets. Generate using: md5sum <filename> (Linux) or md5 <filename> (macOS). Example: 'd41d8cd98f00b204e9800998ecf8427e'.
30
+ :param pulumi.Input[_builtins.str] file_name: The name of the file to upload, including the extension. Examples: 'logo.png', 'hero-image.jpg', 'document.pdf'. The file name must not exceed 255 characters and should not contain invalid characters (<, >, :, ", |, ?, *).
31
+ :param pulumi.Input[_builtins.str] site_id: The Webflow site ID (24-character lowercase hexadecimal string, e.g., '5f0c8c9e1c9d440000e8d8c3'). You can find your site ID in the Webflow dashboard under Site Settings. This field will be validated before making any API calls.
32
+ :param pulumi.Input[_builtins.str] file_source: The source of the file to upload. For the current implementation, this is a reference field. In future versions, this may support URLs or local file paths for automatic upload. Examples: 'https://example.com/logo.png', '/path/to/local/file.png'.
33
+ :param pulumi.Input[_builtins.str] parent_folder: Optional folder ID where the asset will be organized in the Webflow Assets panel. If not specified, the asset will be placed at the root level. Example: '5f0c8c9e1c9d440000e8d8c4'.
34
+ """
35
+ pulumi.set(__self__, "file_hash", file_hash)
36
+ pulumi.set(__self__, "file_name", file_name)
37
+ pulumi.set(__self__, "site_id", site_id)
38
+ if file_source is not None:
39
+ pulumi.set(__self__, "file_source", file_source)
40
+ if parent_folder is not None:
41
+ pulumi.set(__self__, "parent_folder", parent_folder)
42
+
43
+ @_builtins.property
44
+ @pulumi.getter(name="fileHash")
45
+ def file_hash(self) -> pulumi.Input[_builtins.str]:
46
+ """
47
+ MD5 hash of the file content (required). Webflow uses this hash to identify and deduplicate assets. Generate using: md5sum <filename> (Linux) or md5 <filename> (macOS). Example: 'd41d8cd98f00b204e9800998ecf8427e'.
48
+ """
49
+ return pulumi.get(self, "file_hash")
50
+
51
+ @file_hash.setter
52
+ def file_hash(self, value: pulumi.Input[_builtins.str]):
53
+ pulumi.set(self, "file_hash", value)
54
+
55
+ @_builtins.property
56
+ @pulumi.getter(name="fileName")
57
+ def file_name(self) -> pulumi.Input[_builtins.str]:
58
+ """
59
+ The name of the file to upload, including the extension. Examples: 'logo.png', 'hero-image.jpg', 'document.pdf'. The file name must not exceed 255 characters and should not contain invalid characters (<, >, :, ", |, ?, *).
60
+ """
61
+ return pulumi.get(self, "file_name")
62
+
63
+ @file_name.setter
64
+ def file_name(self, value: pulumi.Input[_builtins.str]):
65
+ pulumi.set(self, "file_name", value)
66
+
67
+ @_builtins.property
68
+ @pulumi.getter(name="siteId")
69
+ def site_id(self) -> pulumi.Input[_builtins.str]:
70
+ """
71
+ The Webflow site ID (24-character lowercase hexadecimal string, e.g., '5f0c8c9e1c9d440000e8d8c3'). You can find your site ID in the Webflow dashboard under Site Settings. This field will be validated before making any API calls.
72
+ """
73
+ return pulumi.get(self, "site_id")
74
+
75
+ @site_id.setter
76
+ def site_id(self, value: pulumi.Input[_builtins.str]):
77
+ pulumi.set(self, "site_id", value)
78
+
79
+ @_builtins.property
80
+ @pulumi.getter(name="fileSource")
81
+ def file_source(self) -> Optional[pulumi.Input[_builtins.str]]:
82
+ """
83
+ The source of the file to upload. For the current implementation, this is a reference field. In future versions, this may support URLs or local file paths for automatic upload. Examples: 'https://example.com/logo.png', '/path/to/local/file.png'.
84
+ """
85
+ return pulumi.get(self, "file_source")
86
+
87
+ @file_source.setter
88
+ def file_source(self, value: Optional[pulumi.Input[_builtins.str]]):
89
+ pulumi.set(self, "file_source", value)
90
+
91
+ @_builtins.property
92
+ @pulumi.getter(name="parentFolder")
93
+ def parent_folder(self) -> Optional[pulumi.Input[_builtins.str]]:
94
+ """
95
+ Optional folder ID where the asset will be organized in the Webflow Assets panel. If not specified, the asset will be placed at the root level. Example: '5f0c8c9e1c9d440000e8d8c4'.
96
+ """
97
+ return pulumi.get(self, "parent_folder")
98
+
99
+ @parent_folder.setter
100
+ def parent_folder(self, value: Optional[pulumi.Input[_builtins.str]]):
101
+ pulumi.set(self, "parent_folder", value)
102
+
103
+
104
+ @pulumi.type_token("webflow:index:Asset")
105
+ class Asset(pulumi.CustomResource):
106
+ @overload
107
+ def __init__(__self__,
108
+ resource_name: str,
109
+ opts: Optional[pulumi.ResourceOptions] = None,
110
+ file_hash: Optional[pulumi.Input[_builtins.str]] = None,
111
+ file_name: Optional[pulumi.Input[_builtins.str]] = None,
112
+ file_source: Optional[pulumi.Input[_builtins.str]] = None,
113
+ parent_folder: Optional[pulumi.Input[_builtins.str]] = None,
114
+ site_id: Optional[pulumi.Input[_builtins.str]] = None,
115
+ __props__=None):
116
+ """
117
+ Manages assets (images, files, documents) for a Webflow site. This resource allows you to upload and manage files that can be used in your Webflow site. Note: Assets are immutable - changing any property will delete and recreate the asset.
118
+
119
+ :param str resource_name: The name of the resource.
120
+ :param pulumi.ResourceOptions opts: Options for the resource.
121
+ :param pulumi.Input[_builtins.str] file_hash: MD5 hash of the file content (required). Webflow uses this hash to identify and deduplicate assets. Generate using: md5sum <filename> (Linux) or md5 <filename> (macOS). Example: 'd41d8cd98f00b204e9800998ecf8427e'.
122
+ :param pulumi.Input[_builtins.str] file_name: The name of the file to upload, including the extension. Examples: 'logo.png', 'hero-image.jpg', 'document.pdf'. The file name must not exceed 255 characters and should not contain invalid characters (<, >, :, ", |, ?, *).
123
+ :param pulumi.Input[_builtins.str] file_source: The source of the file to upload. For the current implementation, this is a reference field. In future versions, this may support URLs or local file paths for automatic upload. Examples: 'https://example.com/logo.png', '/path/to/local/file.png'.
124
+ :param pulumi.Input[_builtins.str] parent_folder: Optional folder ID where the asset will be organized in the Webflow Assets panel. If not specified, the asset will be placed at the root level. Example: '5f0c8c9e1c9d440000e8d8c4'.
125
+ :param pulumi.Input[_builtins.str] site_id: The Webflow site ID (24-character lowercase hexadecimal string, e.g., '5f0c8c9e1c9d440000e8d8c3'). You can find your site ID in the Webflow dashboard under Site Settings. This field will be validated before making any API calls.
126
+ """
127
+ ...
128
+ @overload
129
+ def __init__(__self__,
130
+ resource_name: str,
131
+ args: AssetArgs,
132
+ opts: Optional[pulumi.ResourceOptions] = None):
133
+ """
134
+ Manages assets (images, files, documents) for a Webflow site. This resource allows you to upload and manage files that can be used in your Webflow site. Note: Assets are immutable - changing any property will delete and recreate the asset.
135
+
136
+ :param str resource_name: The name of the resource.
137
+ :param AssetArgs args: The arguments to use to populate this resource's properties.
138
+ :param pulumi.ResourceOptions opts: Options for the resource.
139
+ """
140
+ ...
141
+ def __init__(__self__, resource_name: str, *args, **kwargs):
142
+ resource_args, opts = _utilities.get_resource_args_opts(AssetArgs, pulumi.ResourceOptions, *args, **kwargs)
143
+ if resource_args is not None:
144
+ __self__._internal_init(resource_name, opts, **resource_args.__dict__)
145
+ else:
146
+ __self__._internal_init(resource_name, *args, **kwargs)
147
+
148
+ def _internal_init(__self__,
149
+ resource_name: str,
150
+ opts: Optional[pulumi.ResourceOptions] = None,
151
+ file_hash: Optional[pulumi.Input[_builtins.str]] = None,
152
+ file_name: Optional[pulumi.Input[_builtins.str]] = None,
153
+ file_source: Optional[pulumi.Input[_builtins.str]] = None,
154
+ parent_folder: Optional[pulumi.Input[_builtins.str]] = None,
155
+ site_id: Optional[pulumi.Input[_builtins.str]] = None,
156
+ __props__=None):
157
+ opts = pulumi.ResourceOptions.merge(_utilities.get_resource_opts_defaults(), opts)
158
+ if not isinstance(opts, pulumi.ResourceOptions):
159
+ raise TypeError('Expected resource options to be a ResourceOptions instance')
160
+ if opts.id is None:
161
+ if __props__ is not None:
162
+ raise TypeError('__props__ is only valid when passed in combination with a valid opts.id to get an existing resource')
163
+ __props__ = AssetArgs.__new__(AssetArgs)
164
+
165
+ if file_hash is None and not opts.urn:
166
+ raise TypeError("Missing required property 'file_hash'")
167
+ __props__.__dict__["file_hash"] = file_hash
168
+ if file_name is None and not opts.urn:
169
+ raise TypeError("Missing required property 'file_name'")
170
+ __props__.__dict__["file_name"] = file_name
171
+ __props__.__dict__["file_source"] = file_source
172
+ __props__.__dict__["parent_folder"] = parent_folder
173
+ if site_id is None and not opts.urn:
174
+ raise TypeError("Missing required property 'site_id'")
175
+ __props__.__dict__["site_id"] = site_id
176
+ __props__.__dict__["asset_id"] = None
177
+ __props__.__dict__["asset_url"] = None
178
+ __props__.__dict__["content_type"] = None
179
+ __props__.__dict__["created_on"] = None
180
+ __props__.__dict__["hosted_url"] = None
181
+ __props__.__dict__["last_updated"] = None
182
+ __props__.__dict__["size"] = None
183
+ __props__.__dict__["upload_details"] = None
184
+ __props__.__dict__["upload_url"] = None
185
+ super(Asset, __self__).__init__(
186
+ 'webflow:index:Asset',
187
+ resource_name,
188
+ __props__,
189
+ opts)
190
+
191
+ @staticmethod
192
+ def get(resource_name: str,
193
+ id: pulumi.Input[str],
194
+ opts: Optional[pulumi.ResourceOptions] = None) -> 'Asset':
195
+ """
196
+ Get an existing Asset resource's state with the given name, id, and optional extra
197
+ properties used to qualify the lookup.
198
+
199
+ :param str resource_name: The unique name of the resulting resource.
200
+ :param pulumi.Input[str] id: The unique provider ID of the resource to lookup.
201
+ :param pulumi.ResourceOptions opts: Options for the resource.
202
+ """
203
+ opts = pulumi.ResourceOptions.merge(opts, pulumi.ResourceOptions(id=id))
204
+
205
+ __props__ = AssetArgs.__new__(AssetArgs)
206
+
207
+ __props__.__dict__["asset_id"] = None
208
+ __props__.__dict__["asset_url"] = None
209
+ __props__.__dict__["content_type"] = None
210
+ __props__.__dict__["created_on"] = None
211
+ __props__.__dict__["file_hash"] = None
212
+ __props__.__dict__["file_name"] = None
213
+ __props__.__dict__["file_source"] = None
214
+ __props__.__dict__["hosted_url"] = None
215
+ __props__.__dict__["last_updated"] = None
216
+ __props__.__dict__["parent_folder"] = None
217
+ __props__.__dict__["site_id"] = None
218
+ __props__.__dict__["size"] = None
219
+ __props__.__dict__["upload_details"] = None
220
+ __props__.__dict__["upload_url"] = None
221
+ return Asset(resource_name, opts=opts, __props__=__props__)
222
+
223
+ @_builtins.property
224
+ @pulumi.getter(name="assetId")
225
+ def asset_id(self) -> pulumi.Output[Optional[_builtins.str]]:
226
+ """
227
+ The Webflow-assigned asset ID (read-only). This unique identifier can be used to reference the asset in API calls.
228
+ """
229
+ return pulumi.get(self, "asset_id")
230
+
231
+ @_builtins.property
232
+ @pulumi.getter(name="assetUrl")
233
+ def asset_url(self) -> pulumi.Output[Optional[_builtins.str]]:
234
+ """
235
+ The direct S3 URL for the asset (read-only). This is the raw S3 location where the file is stored.
236
+ """
237
+ return pulumi.get(self, "asset_url")
238
+
239
+ @_builtins.property
240
+ @pulumi.getter(name="contentType")
241
+ def content_type(self) -> pulumi.Output[Optional[_builtins.str]]:
242
+ """
243
+ The MIME type of the asset (read-only). Examples: 'image/png', 'image/jpeg', 'application/pdf'. Determined by the fileName extension.
244
+ """
245
+ return pulumi.get(self, "content_type")
246
+
247
+ @_builtins.property
248
+ @pulumi.getter(name="createdOn")
249
+ def created_on(self) -> pulumi.Output[Optional[_builtins.str]]:
250
+ """
251
+ The timestamp when the asset metadata was created (RFC3339 format, read-only). This is set when the asset is registered with Webflow.
252
+ """
253
+ return pulumi.get(self, "created_on")
254
+
255
+ @_builtins.property
256
+ @pulumi.getter(name="fileHash")
257
+ def file_hash(self) -> pulumi.Output[_builtins.str]:
258
+ """
259
+ MD5 hash of the file content (required). Webflow uses this hash to identify and deduplicate assets. Generate using: md5sum <filename> (Linux) or md5 <filename> (macOS). Example: 'd41d8cd98f00b204e9800998ecf8427e'.
260
+ """
261
+ return pulumi.get(self, "file_hash")
262
+
263
+ @_builtins.property
264
+ @pulumi.getter(name="fileName")
265
+ def file_name(self) -> pulumi.Output[_builtins.str]:
266
+ """
267
+ The name of the file to upload, including the extension. Examples: 'logo.png', 'hero-image.jpg', 'document.pdf'. The file name must not exceed 255 characters and should not contain invalid characters (<, >, :, ", |, ?, *).
268
+ """
269
+ return pulumi.get(self, "file_name")
270
+
271
+ @_builtins.property
272
+ @pulumi.getter(name="fileSource")
273
+ def file_source(self) -> pulumi.Output[Optional[_builtins.str]]:
274
+ """
275
+ The source of the file to upload. For the current implementation, this is a reference field. In future versions, this may support URLs or local file paths for automatic upload. Examples: 'https://example.com/logo.png', '/path/to/local/file.png'.
276
+ """
277
+ return pulumi.get(self, "file_source")
278
+
279
+ @_builtins.property
280
+ @pulumi.getter(name="hostedUrl")
281
+ def hosted_url(self) -> pulumi.Output[Optional[_builtins.str]]:
282
+ """
283
+ The Webflow CDN URL where the asset will be hosted (read-only). This URL becomes accessible after completing the S3 upload. Example: 'https://assets.website-files.com/.../logo.png'.
284
+ """
285
+ return pulumi.get(self, "hosted_url")
286
+
287
+ @_builtins.property
288
+ @pulumi.getter(name="lastUpdated")
289
+ def last_updated(self) -> pulumi.Output[Optional[_builtins.str]]:
290
+ """
291
+ The timestamp when the asset was last modified (RFC3339 format, read-only). For most assets, this will be the same as createdOn since assets are immutable.
292
+ """
293
+ return pulumi.get(self, "last_updated")
294
+
295
+ @_builtins.property
296
+ @pulumi.getter(name="parentFolder")
297
+ def parent_folder(self) -> pulumi.Output[Optional[_builtins.str]]:
298
+ """
299
+ Optional folder ID where the asset will be organized in the Webflow Assets panel. If not specified, the asset will be placed at the root level. Example: '5f0c8c9e1c9d440000e8d8c4'.
300
+ """
301
+ return pulumi.get(self, "parent_folder")
302
+
303
+ @_builtins.property
304
+ @pulumi.getter(name="siteId")
305
+ def site_id(self) -> pulumi.Output[_builtins.str]:
306
+ """
307
+ The Webflow site ID (24-character lowercase hexadecimal string, e.g., '5f0c8c9e1c9d440000e8d8c3'). You can find your site ID in the Webflow dashboard under Site Settings. This field will be validated before making any API calls.
308
+ """
309
+ return pulumi.get(self, "site_id")
310
+
311
+ @_builtins.property
312
+ @pulumi.getter
313
+ def size(self) -> pulumi.Output[Optional[_builtins.int]]:
314
+ """
315
+ The size of the asset in bytes (read-only). This is the actual size of the uploaded file.
316
+ """
317
+ return pulumi.get(self, "size")
318
+
319
+ @_builtins.property
320
+ @pulumi.getter(name="uploadDetails")
321
+ def upload_details(self) -> pulumi.Output[Optional[Mapping[str, _builtins.str]]]:
322
+ """
323
+ AWS S3 POST form fields required to complete the upload (read-only). Include these as form fields when POSTing the file to uploadUrl. Keys: acl, bucket, key, Content-Type, X-Amz-Algorithm, X-Amz-Credential, X-Amz-Date, Policy, X-Amz-Signature, success_action_status, Cache-Control.
324
+ """
325
+ return pulumi.get(self, "upload_details")
326
+
327
+ @_builtins.property
328
+ @pulumi.getter(name="uploadUrl")
329
+ def upload_url(self) -> pulumi.Output[Optional[_builtins.str]]:
330
+ """
331
+ The presigned S3 URL for uploading the file content (read-only). Use this URL along with uploadDetails to complete the asset upload. See AWS S3 POST documentation: https://docs.aws.amazon.com/AmazonS3/latest/API/RESTObjectPOST.html
332
+ """
333
+ return pulumi.get(self, "upload_url")
334
+
@@ -0,0 +1,225 @@
1
+ # coding=utf-8
2
+ # *** WARNING: this file was generated by pulumi-language-python. ***
3
+ # *** Do not edit by hand unless you're certain you know what you are doing! ***
4
+
5
+ import builtins as _builtins
6
+ import warnings
7
+ import sys
8
+ import pulumi
9
+ import pulumi.runtime
10
+ from typing import Any, Mapping, Optional, Sequence, Union, overload
11
+ if sys.version_info >= (3, 11):
12
+ from typing import NotRequired, TypedDict, TypeAlias
13
+ else:
14
+ from typing_extensions import NotRequired, TypedDict, TypeAlias
15
+ from . import _utilities
16
+
17
+ __all__ = ['AssetFolderArgs', 'AssetFolder']
18
+
19
+ @pulumi.input_type
20
+ class AssetFolderArgs:
21
+ def __init__(__self__, *,
22
+ display_name: pulumi.Input[_builtins.str],
23
+ site_id: pulumi.Input[_builtins.str],
24
+ parent_folder: Optional[pulumi.Input[_builtins.str]] = None):
25
+ """
26
+ The set of arguments for constructing a AssetFolder resource.
27
+ :param pulumi.Input[_builtins.str] display_name: The human-readable name for the asset folder. This name appears in the Webflow Assets panel and helps organize your files. Examples: 'Images', 'Documents', 'Icons', 'Hero Backgrounds'. Maximum length: 255 characters.
28
+ :param pulumi.Input[_builtins.str] site_id: The Webflow site ID (24-character lowercase hexadecimal string, e.g., '5f0c8c9e1c9d440000e8d8c3'). You can find your site ID in the Webflow dashboard under Site Settings. This field will be validated before making any API calls.
29
+ :param pulumi.Input[_builtins.str] parent_folder: Optional ID of the parent folder for creating nested folder structures. If not specified, the folder will be created at the root level of the Assets panel. Example: '5f0c8c9e1c9d440000e8d8c4'.
30
+ """
31
+ pulumi.set(__self__, "display_name", display_name)
32
+ pulumi.set(__self__, "site_id", site_id)
33
+ if parent_folder is not None:
34
+ pulumi.set(__self__, "parent_folder", parent_folder)
35
+
36
+ @_builtins.property
37
+ @pulumi.getter(name="displayName")
38
+ def display_name(self) -> pulumi.Input[_builtins.str]:
39
+ """
40
+ The human-readable name for the asset folder. This name appears in the Webflow Assets panel and helps organize your files. Examples: 'Images', 'Documents', 'Icons', 'Hero Backgrounds'. Maximum length: 255 characters.
41
+ """
42
+ return pulumi.get(self, "display_name")
43
+
44
+ @display_name.setter
45
+ def display_name(self, value: pulumi.Input[_builtins.str]):
46
+ pulumi.set(self, "display_name", value)
47
+
48
+ @_builtins.property
49
+ @pulumi.getter(name="siteId")
50
+ def site_id(self) -> pulumi.Input[_builtins.str]:
51
+ """
52
+ The Webflow site ID (24-character lowercase hexadecimal string, e.g., '5f0c8c9e1c9d440000e8d8c3'). You can find your site ID in the Webflow dashboard under Site Settings. This field will be validated before making any API calls.
53
+ """
54
+ return pulumi.get(self, "site_id")
55
+
56
+ @site_id.setter
57
+ def site_id(self, value: pulumi.Input[_builtins.str]):
58
+ pulumi.set(self, "site_id", value)
59
+
60
+ @_builtins.property
61
+ @pulumi.getter(name="parentFolder")
62
+ def parent_folder(self) -> Optional[pulumi.Input[_builtins.str]]:
63
+ """
64
+ Optional ID of the parent folder for creating nested folder structures. If not specified, the folder will be created at the root level of the Assets panel. Example: '5f0c8c9e1c9d440000e8d8c4'.
65
+ """
66
+ return pulumi.get(self, "parent_folder")
67
+
68
+ @parent_folder.setter
69
+ def parent_folder(self, value: Optional[pulumi.Input[_builtins.str]]):
70
+ pulumi.set(self, "parent_folder", value)
71
+
72
+
73
+ @pulumi.type_token("webflow:index:AssetFolder")
74
+ class AssetFolder(pulumi.CustomResource):
75
+ @overload
76
+ def __init__(__self__,
77
+ resource_name: str,
78
+ opts: Optional[pulumi.ResourceOptions] = None,
79
+ display_name: Optional[pulumi.Input[_builtins.str]] = None,
80
+ parent_folder: Optional[pulumi.Input[_builtins.str]] = None,
81
+ site_id: Optional[pulumi.Input[_builtins.str]] = None,
82
+ __props__=None):
83
+ """
84
+ Manages asset folders for organizing files in a Webflow site. This resource allows you to create folders to organize your assets (images, documents, etc.) in the Webflow Assets panel. NOTE: The Webflow API does not support deleting or updating asset folders. Deleting this resource will only remove it from Pulumi state, not from Webflow. Any changes to folder properties will require creating a new folder.
85
+
86
+ :param str resource_name: The name of the resource.
87
+ :param pulumi.ResourceOptions opts: Options for the resource.
88
+ :param pulumi.Input[_builtins.str] display_name: The human-readable name for the asset folder. This name appears in the Webflow Assets panel and helps organize your files. Examples: 'Images', 'Documents', 'Icons', 'Hero Backgrounds'. Maximum length: 255 characters.
89
+ :param pulumi.Input[_builtins.str] parent_folder: Optional ID of the parent folder for creating nested folder structures. If not specified, the folder will be created at the root level of the Assets panel. Example: '5f0c8c9e1c9d440000e8d8c4'.
90
+ :param pulumi.Input[_builtins.str] site_id: The Webflow site ID (24-character lowercase hexadecimal string, e.g., '5f0c8c9e1c9d440000e8d8c3'). You can find your site ID in the Webflow dashboard under Site Settings. This field will be validated before making any API calls.
91
+ """
92
+ ...
93
+ @overload
94
+ def __init__(__self__,
95
+ resource_name: str,
96
+ args: AssetFolderArgs,
97
+ opts: Optional[pulumi.ResourceOptions] = None):
98
+ """
99
+ Manages asset folders for organizing files in a Webflow site. This resource allows you to create folders to organize your assets (images, documents, etc.) in the Webflow Assets panel. NOTE: The Webflow API does not support deleting or updating asset folders. Deleting this resource will only remove it from Pulumi state, not from Webflow. Any changes to folder properties will require creating a new folder.
100
+
101
+ :param str resource_name: The name of the resource.
102
+ :param AssetFolderArgs args: The arguments to use to populate this resource's properties.
103
+ :param pulumi.ResourceOptions opts: Options for the resource.
104
+ """
105
+ ...
106
+ def __init__(__self__, resource_name: str, *args, **kwargs):
107
+ resource_args, opts = _utilities.get_resource_args_opts(AssetFolderArgs, pulumi.ResourceOptions, *args, **kwargs)
108
+ if resource_args is not None:
109
+ __self__._internal_init(resource_name, opts, **resource_args.__dict__)
110
+ else:
111
+ __self__._internal_init(resource_name, *args, **kwargs)
112
+
113
+ def _internal_init(__self__,
114
+ resource_name: str,
115
+ opts: Optional[pulumi.ResourceOptions] = None,
116
+ display_name: Optional[pulumi.Input[_builtins.str]] = None,
117
+ parent_folder: Optional[pulumi.Input[_builtins.str]] = None,
118
+ site_id: Optional[pulumi.Input[_builtins.str]] = None,
119
+ __props__=None):
120
+ opts = pulumi.ResourceOptions.merge(_utilities.get_resource_opts_defaults(), opts)
121
+ if not isinstance(opts, pulumi.ResourceOptions):
122
+ raise TypeError('Expected resource options to be a ResourceOptions instance')
123
+ if opts.id is None:
124
+ if __props__ is not None:
125
+ raise TypeError('__props__ is only valid when passed in combination with a valid opts.id to get an existing resource')
126
+ __props__ = AssetFolderArgs.__new__(AssetFolderArgs)
127
+
128
+ if display_name is None and not opts.urn:
129
+ raise TypeError("Missing required property 'display_name'")
130
+ __props__.__dict__["display_name"] = display_name
131
+ __props__.__dict__["parent_folder"] = parent_folder
132
+ if site_id is None and not opts.urn:
133
+ raise TypeError("Missing required property 'site_id'")
134
+ __props__.__dict__["site_id"] = site_id
135
+ __props__.__dict__["assets"] = None
136
+ __props__.__dict__["created_on"] = None
137
+ __props__.__dict__["folder_id"] = None
138
+ __props__.__dict__["last_updated"] = None
139
+ super(AssetFolder, __self__).__init__(
140
+ 'webflow:index:AssetFolder',
141
+ resource_name,
142
+ __props__,
143
+ opts)
144
+
145
+ @staticmethod
146
+ def get(resource_name: str,
147
+ id: pulumi.Input[str],
148
+ opts: Optional[pulumi.ResourceOptions] = None) -> 'AssetFolder':
149
+ """
150
+ Get an existing AssetFolder resource's state with the given name, id, and optional extra
151
+ properties used to qualify the lookup.
152
+
153
+ :param str resource_name: The unique name of the resulting resource.
154
+ :param pulumi.Input[str] id: The unique provider ID of the resource to lookup.
155
+ :param pulumi.ResourceOptions opts: Options for the resource.
156
+ """
157
+ opts = pulumi.ResourceOptions.merge(opts, pulumi.ResourceOptions(id=id))
158
+
159
+ __props__ = AssetFolderArgs.__new__(AssetFolderArgs)
160
+
161
+ __props__.__dict__["assets"] = None
162
+ __props__.__dict__["created_on"] = None
163
+ __props__.__dict__["display_name"] = None
164
+ __props__.__dict__["folder_id"] = None
165
+ __props__.__dict__["last_updated"] = None
166
+ __props__.__dict__["parent_folder"] = None
167
+ __props__.__dict__["site_id"] = None
168
+ return AssetFolder(resource_name, opts=opts, __props__=__props__)
169
+
170
+ @_builtins.property
171
+ @pulumi.getter
172
+ def assets(self) -> pulumi.Output[Optional[Sequence[_builtins.str]]]:
173
+ """
174
+ List of asset IDs currently contained in this folder (read-only). This is automatically populated by Webflow when assets are added to the folder.
175
+ """
176
+ return pulumi.get(self, "assets")
177
+
178
+ @_builtins.property
179
+ @pulumi.getter(name="createdOn")
180
+ def created_on(self) -> pulumi.Output[Optional[_builtins.str]]:
181
+ """
182
+ The timestamp when the folder was created (RFC3339 format, read-only). This is automatically set when the folder is created.
183
+ """
184
+ return pulumi.get(self, "created_on")
185
+
186
+ @_builtins.property
187
+ @pulumi.getter(name="displayName")
188
+ def display_name(self) -> pulumi.Output[_builtins.str]:
189
+ """
190
+ The human-readable name for the asset folder. This name appears in the Webflow Assets panel and helps organize your files. Examples: 'Images', 'Documents', 'Icons', 'Hero Backgrounds'. Maximum length: 255 characters.
191
+ """
192
+ return pulumi.get(self, "display_name")
193
+
194
+ @_builtins.property
195
+ @pulumi.getter(name="folderId")
196
+ def folder_id(self) -> pulumi.Output[Optional[_builtins.str]]:
197
+ """
198
+ The Webflow-assigned folder ID (read-only). This unique identifier can be used to reference the folder in other resources, such as when uploading assets to this folder.
199
+ """
200
+ return pulumi.get(self, "folder_id")
201
+
202
+ @_builtins.property
203
+ @pulumi.getter(name="lastUpdated")
204
+ def last_updated(self) -> pulumi.Output[Optional[_builtins.str]]:
205
+ """
206
+ The timestamp when the folder was last modified (RFC3339 format, read-only). This is updated when assets are added or removed from the folder.
207
+ """
208
+ return pulumi.get(self, "last_updated")
209
+
210
+ @_builtins.property
211
+ @pulumi.getter(name="parentFolder")
212
+ def parent_folder(self) -> pulumi.Output[Optional[_builtins.str]]:
213
+ """
214
+ Optional ID of the parent folder for creating nested folder structures. If not specified, the folder will be created at the root level of the Assets panel. Example: '5f0c8c9e1c9d440000e8d8c4'.
215
+ """
216
+ return pulumi.get(self, "parent_folder")
217
+
218
+ @_builtins.property
219
+ @pulumi.getter(name="siteId")
220
+ def site_id(self) -> pulumi.Output[_builtins.str]:
221
+ """
222
+ The Webflow site ID (24-character lowercase hexadecimal string, e.g., '5f0c8c9e1c9d440000e8d8c3'). You can find your site ID in the Webflow dashboard under Site Settings. This field will be validated before making any API calls.
223
+ """
224
+ return pulumi.get(self, "site_id")
225
+