Multipart upload metadata
If you're using the Workers Script Upload API or Version Upload API directly, multipart/form-data uploads require you to specify a metadata part. This metadata defines the Worker's configuration in JSON format, analogue to the wrangler.toml file.
{  "main_module": "main.js",  "bindings": [    {      "type": "plain_text",      "name": "MESSAGE",      "text": "Hello, world!"    }  ],  "compatibility_date": "2021-09-14"}The following attributes are configurable at the top-level.
- 
main_modulestring required- The part name that contains the module entry point of the Worker that will be executed. For example, main.js.
 
- The part name that contains the module entry point of the Worker that will be executed. For example, 
- 
assetsobject optional- Asset configuration for a Worker.
- configobject optional- html_handling determines the redirects and rewrites of requests for HTML content.
- not_found_handling determines the response when a request does not match a static asset.
 
- jwtfield provides a token authorizing assets to be attached to a Worker.
 
- 
keep_assetsboolean optional- Specifies whether assets should be retained from a previously uploaded Worker version; used in lieu of providing a completion token.
 
- 
bindingsarray[object] optional- Bindings to expose in the Worker.
 
- 
placementobject optional- Smart placement object for the Worker.
- modefield only supports- smartfor automatic placement.
 
- 
compatibility_datestring optional- Compatibility Date indicating targeted support in the Workers runtime. Backwards incompatible fixes to the runtime following this date will not affect this Worker. Highly recommended to set a compatibility_date, otherwise if on upload via the API, it defaults to the oldest compatibility date before any flags took effect (2021-11-02).
 
- Compatibility Date indicating targeted support in the Workers runtime. Backwards incompatible fixes to the runtime following this date will not affect this Worker. Highly recommended to set a 
- 
compatibility_flagsarray[string] optional- Compatibility Flags that enable or disable certain features in the Workers runtime. Used to enable upcoming features or opt in or out of specific changes not included in a compatibility_date.
 
- Compatibility Flags that enable or disable certain features in the Workers runtime. Used to enable upcoming features or opt in or out of specific changes not included in a 
Additional attributes: Workers Script Upload API
For immediately deployed uploads, the following additional attributes are configurable at the top-level.
- 
migrationsarray[object] optional- Durable Objects migrations to apply.
 
- 
logpushboolean optional- Whether Logpush is turned on for the Worker.
 
- 
tail_consumersarray[object] optional- Tail Workers that will consume logs from the attached Worker.
 
- 
tagsarray[string] optional- List of strings to use as tags for this Worker.
 
Additional attributes: Version Upload API
For version uploads, the following additional attributes are configurable at the top-level.
- 
annotationsobject optional- Annotations object specific to the Worker version.
- workers/messagespecifies a custom message for the version.
- workers/tagspecifies a custom identifier for the version.
- workers/aliasspecifies a custom alias for this version.
 
Workers can interact with resources on the Cloudflare Developer Platform using bindings. Refer to the JSON example below that shows how to add bindings in the metadata part.
{  "bindings": [    {      "type": "ai",      "name": "<VARIABLE_NAME>"    },    {      "type": "analytics_engine",      "name": "<VARIABLE_NAME>",      "dataset": "<DATASET>"    },    {      "type": "assets",      "name": "<VARIABLE_NAME>"    },    {      "type": "browser_rendering",      "name": "<VARIABLE_NAME>"    },    {      "type": "d1",      "name": "<VARIABLE_NAME>",      "id": "<D1_ID>"    },    {      "type": "durable_object_namespace",      "name": "<VARIABLE_NAME>",      "class_name": "<DO_CLASS_NAME>"    },    {      "type": "hyperdrive",      "name": "<VARIABLE_NAME>",      "id": "<HYPERDRIVE_ID>"    },    {      "type": "kv_namespace",      "name": "<VARIABLE_NAME>",      "namespace_id": "<KV_ID>"    },    {      "type": "mtls_certificate",      "name": "<VARIABLE_NAME>",      "certificate_id": "<MTLS_CERTIFICATE_ID>"    },    {      "type": "plain_text",      "name": "<VARIABLE_NAME>",      "text": "<VARIABLE_VALUE>"    },    {      "type": "queue",      "name": "<VARIABLE_NAME>",      "queue_name": "<QUEUE_NAME>"    },    {      "type": "r2_bucket",      "name": "<VARIABLE_NAME>",      "bucket_name": "<R2_BUCKET_NAME>"    },    {      "type": "secret_text",      "name": "<VARIABLE_NAME>",      "text": "<SECRET_VALUE>"    },    {      "type": "service",      "name": "<VARIABLE_NAME>",      "service": "<SERVICE_NAME>",      "environment": "production"    },    {      "type": "tail_consumer",      "service": "<WORKER_NAME>"    },    {      "type": "vectorize",      "name": "<VARIABLE_NAME>",      "index_name": "<INDEX_NAME>"    },    {      "type": "version_metadata",      "name": "<VARIABLE_NAME>"    }  ]}Was this helpful?
- Resources
- API
- New to Cloudflare?
- Products
- Sponsorships
- Open Source
- Support
- Help Center
- System Status
- Compliance
- GDPR
- Company
- cloudflare.com
- Our team
- Careers
- © 2025 Cloudflare, Inc.
- Privacy Policy
- Terms of Use
- Report Security Issues
- Trademark