workflow
Version:
Workflow DevKit - Build durable, resilient, and observable workflows
137 lines (102 loc) • 3.44 kB
text/mdx
---
title: webhook-invalid-respond-with-value
description: The respondWith option must be "manual" or a Response object.
type: troubleshooting
summary: Resolve the webhook-invalid-respond-with-value error by using a valid respondWith option.
prerequisites:
- /docs/foundations/hooks
related:
- /docs/api-reference/workflow/create-webhook
---
This error occurs when you provide an invalid value for the `respondWith` option when creating a webhook. The `respondWith` option must be either `"manual"` or a `Response` object.
```
Invalid `respondWith` value: [value]
```
When creating a webhook with `createWebhook()`, you can specify how the webhook should respond to incoming HTTP requests using the `respondWith` option. This option only accepts specific values:
1. `"manual"` - Allows you to manually send a response from within the workflow
2. A `Response` object - A pre-defined response to send immediately
3. `undefined` (default) - Returns a `202 Accepted` response
```typescript lineNumbers
// Error - invalid string value
export async function webhookWorkflow() {
"use workflow";
const webhook = await createWebhook({
respondWith: "automatic", // Error! // [!code highlight]
});
}
```
**Solution:** Use `"manual"` or provide a `Response` object.
```typescript lineNumbers
// Fixed - use "manual"
export async function webhookWorkflow() {
"use workflow";
const webhook = await createWebhook({
respondWith: "manual", // [!code highlight]
});
const request = await webhook;
// Send custom response
await request.respondWith(new Response("OK", { status: 200 })); // [!code highlight]
}
```
```typescript lineNumbers
// Error - plain object instead of Response
export async function webhookWorkflow() {
"use workflow";
const webhook = await createWebhook({
respondWith: { status: 200, body: "OK" }, // Error! // [!code highlight]
});
}
```
**Solution:** Create a proper `Response` object.
```typescript lineNumbers
// Fixed - use Response constructor
export async function webhookWorkflow() {
"use workflow";
const webhook = await createWebhook({
respondWith: new Response("OK", { status: 200 }), // [!code highlight]
});
}
```
```typescript lineNumbers
// Returns 202 Accepted automatically
const webhook = await createWebhook();
const request = await webhook;
// No need to send a response
```
```typescript lineNumbers
// Manual response control
const webhook = await createWebhook({
respondWith: "manual",
});
const request = await webhook;
// Process the request...
const data = await request.json();
// Send custom response
await request.respondWith(
new Response(JSON.stringify({ success: true }), {
status: 200,
headers: { "Content-Type": "application/json" },
})
);
```
```typescript lineNumbers
// Immediate response
const webhook = await createWebhook({
respondWith: new Response("Request received", { status: 200 }),
});
const request = await webhook;
// Response already sent
```
- [createWebhook() API Reference](/docs/api-reference/workflow/create-webhook)
- [resumeWebhook() API Reference](/docs/api-reference/workflow-api/resume-webhook)
- [Webhooks Guide](/docs/foundations/hooks)