Writing to streams
Send events to streams using Worker bindings or HTTP endpoints for client-side applications and external systems.
Worker bindings provide a secure way to send data to streams from Workers without managing API tokens or credentials.
Add a pipeline binding to your Wrangler file that points to your stream:
{  "pipelines": [    {      "pipeline": "<STREAM_ID>",      "binding": "STREAM"    }  ]}[[pipelines]]pipeline = "<STREAM_ID>"binding = "STREAM"The pipeline binding exposes a method for sending data to your stream:
Sends an array of JSON-serializable records to the stream. Returns a Promise that resolves when records are confirmed as ingested.
export default {  async fetch(request, env, ctx) {    const event = {      user_id: "12345",      event_type: "purchase",      product_id: "widget-001",      amount: 29.99,    };
    await env.STREAM.send([event]);
    return new Response("Event sent");  },};export default {  async fetch(request, env, ctx): Promise<Response> {    const event = {      user_id: "12345",      event_type: "purchase",      product_id: "widget-001",      amount: 29.99    };
      await env.STREAM.send([event]);
      return new Response('Event sent');    },
} satisfies ExportedHandler<Env>;Each stream provides an optional HTTP endpoint for ingesting data from external applications, browsers, or any system that can make HTTP requests.
HTTP endpoints follow this format:
https://{stream-id}.ingest.cloudflare.comFind your stream's endpoint URL in the Cloudflare dashboard under Pipelines > Streams or using the Wrangler CLI:
npx wrangler pipelines streams get <STREAM_ID>Send events as JSON arrays via POST requests:
curl -X POST https://{stream-id}.ingest.cloudflare.com \  -H "Content-Type: application/json" \  -d '[    {      "user_id": "12345",      "event_type": "purchase",      "product_id": "widget-001",      "amount": 29.99    }  ]'When authentication is enabled for your stream, include the API token in the Authorization header:
curl -X POST https://{stream-id}.ingest.cloudflare.com \  -H "Content-Type: application/json" \  -H "Authorization: Bearer YOUR_API_TOKEN" \  -d '[{"event": "test"}]'The API token must have Workers Pipeline Send permission. To learn more, refer to the Create API token documentation.
Streams handle validation differently based on their configuration:
- Structured streams: Events must match the defined schema fields and types.
- Unstructured streams: Accept any valid JSON structure. Data is stored in a single valuecolumn.
For structured streams, ensure your events match the schema definition. Invalid events will be accepted but dropped, so validate your data before sending to avoid dropped events.
Was this helpful?
- Resources
- API
- New to Cloudflare?
- Directory
- 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
-