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.
- pulumi_webflow/__init__.py +76 -0
- pulumi_webflow/_inputs.py +254 -0
- pulumi_webflow/_utilities.py +331 -0
- pulumi_webflow/asset.py +334 -0
- pulumi_webflow/asset_folder.py +225 -0
- pulumi_webflow/collection.py +235 -0
- pulumi_webflow/collection_field.py +322 -0
- pulumi_webflow/collection_item.py +283 -0
- pulumi_webflow/config/__init__.py +9 -0
- pulumi_webflow/config/__init__.pyi +21 -0
- pulumi_webflow/config/vars.py +29 -0
- pulumi_webflow/ecommerce_settings.py +146 -0
- pulumi_webflow/get_authorized_user.py +109 -0
- pulumi_webflow/get_token_info.py +82 -0
- pulumi_webflow/outputs.py +455 -0
- pulumi_webflow/page_content.py +172 -0
- pulumi_webflow/page_custom_code.py +178 -0
- pulumi_webflow/page_data.py +256 -0
- pulumi_webflow/provider.py +106 -0
- pulumi_webflow/pulumi-plugin.json +4 -0
- pulumi_webflow/py.typed +0 -0
- pulumi_webflow/redirect.py +226 -0
- pulumi_webflow/registered_script.py +295 -0
- pulumi_webflow/robots_txt.py +166 -0
- pulumi_webflow/site.py +361 -0
- pulumi_webflow/site_custom_code.py +178 -0
- pulumi_webflow/user.py +284 -0
- pulumi_webflow/webhook.py +235 -0
- pulumi_webflow-0.0.0.dist-info/METADATA +602 -0
- pulumi_webflow-0.0.0.dist-info/RECORD +32 -0
- pulumi_webflow-0.0.0.dist-info/WHEEL +5 -0
- pulumi_webflow-0.0.0.dist-info/top_level.txt +1 -0
pulumi_webflow/asset.py
ADDED
|
@@ -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
|
+
|