체크아웃 API 경로
Dodo Payments 체크아웃을 Nuxt 앱에 서버 경로를 사용하여 통합합니다.
고객 포털 API 경로
고객이 Nuxt 서버 경로를 통해 구독 및 세부 정보를 관리할 수 있도록 합니다.
웹훅 API 경로
Nuxt에서 Dodo Payments 웹훅 이벤트를 안전하게 수신하고 처리합니다.
개요
이 가이드는 공식 Nuxt 모듈을 사용하여 Dodo Payments를 Nuxt 애플리케이션에 통합하는 방법을 설명합니다. 체크아웃, 고객 포털 및 웹훅 API 경로를 설정하고 환경 변수를 안전하게 관리하는 방법을 배웁니다.
설치
1
Nuxt 모듈 설치
프로젝트 루트에서 다음 명령을 실행합니다:
복사
npm install @dodopayments/nuxt
2
nuxt.config.ts에 모듈 등록
@dodopayments/nuxt를 modules 배열에 추가하고 구성합니다:nuxt.config.ts
복사
export default defineNuxtConfig({
modules: ["@dodopayments/nuxt"],
devtools: { enabled: true },
compatibilityDate: "2025-02-25",
runtimeConfig: {
private: {
bearerToken: process.env.NUXT_PRIVATE_BEARER_TOKEN,
webhookKey: process.env.NUXT_PRIVATE_WEBHOOK_KEY,
environment: process.env.NUXT_PRIVATE_ENVIRONMENT,
returnUrl: process.env.NUXT_PRIVATE_RETURNURL
},
}
});
.env 파일이나 비밀 정보를 버전 관리에 커밋하지 마십시오.API 경로 핸들러 예제
Nuxt에서 모든 Dodo Payments 통합은
server/routes/api/ 디렉토리의 서버 경로를 통해 처리됩니다.- 체크아웃 API 경로
- 고객 포털 API 경로
- 웹훅 API 경로
이 핸들러를 사용하여 Dodo Payments 체크아웃을 Nuxt 앱에 통합합니다. 정적 (GET), 동적 (POST) 및 세션 (POST) 결제 흐름을 지원합니다.
복사
export default defineEventHandler((event) => {
const {
private: { bearerToken, environment, returnUrl },
} = useRuntimeConfig();
const handler = checkoutHandler({
bearerToken: bearerToken,
environment: environment,
returnUrl: returnUrl,
});
return handler(event);
});
복사
export default defineEventHandler((event) => {
const {
private: { bearerToken, environment, returnUrl },
} = useRuntimeConfig();
const handler = checkoutHandler({
bearerToken: bearerToken,
environment: environment,
returnUrl: returnUrl,
type: "dynamic"
});
return handler(event);
});
복사
export default defineEventHandler((event) => {
const {
private: { bearerToken, environment, returnUrl },
} = useRuntimeConfig();
const handler = checkoutHandler({
bearerToken: bearerToken,
environment: environment,
returnUrl: returnUrl,
type: "session"
});
return handler(event);
});
productId가 없거나 유효하지 않으면 핸들러가 400 응답을 반환합니다.복사
curl --request GET \
--url 'https://example.com/api/checkout?productId=pdt_fqJhl7pxKWiLhwQR042rh' \
--header 'User-Agent: insomnia/11.2.0' \
--cookie mode=test
복사
curl --request POST \
--url https://example.com/api/checkout \
--header 'Content-Type: application/json' \
--header 'User-Agent: insomnia/11.2.0' \
--cookie mode=test \
--data '{
"billing": {
"city": "Texas",
"country": "US",
"state": "Texas",
"street": "56, hhh",
"zipcode": "560000"
},
"customer": {
"email": "[email protected]",
"name": "test"
},
"metadata": {},
"payment_link": true,
"product_id": "pdt_QMDuvLkbVzCRWRQjLNcs",
"quantity": 1,
"billing_currency": "USD",
"discount_code": "IKHZ23M9GQ",
"return_url": "https://example.com",
"trial_period_days": 10
}'
복사
curl --request POST \
--url https://example.com/api/checkout \
--header 'Content-Type: application/json' \
--header 'User-Agent: insomnia/11.2.0' \
--cookie mode=test \
--data '{
"product_cart": [
{
"product_id": "pdt_QMDuvLkbVzCRWRQjLNcs",
"quantity": 1
}
],
"customer": {
"email": "[email protected]",
"name": "test"
},
"return_url": "https://example.com/success"
}'
고객이 포털에 접근할 수 있도록 GET 경로를 생성합니다.
customer_id를 쿼리 매개변수로 받습니다.복사
export default defineEventHandler((event) => {
const {
private: { bearerToken, environment },
} = useRuntimeConfig();
const handler = customerPortalHandler({
bearerToken,
environment: environment,
});
return handler(event);
});
customer_id(필수): 포털 세션의 고객 ID (예:?customer_id=cus_123)send_email(선택적, boolean):true로 설정하면 고객에게 포털 링크가 포함된 이메일을 보냅니다.
customer_id가 없으면 400을 반환합니다.복사
curl --request GET \
--url 'https://example.com/api/customer-portal?customer_id=cus_9VuW4K7O3GHwasENg31m&send_email=true' \
--header 'User-Agent: insomnia/11.2.0' \
--cookie mode=test
Dodo Payments의 웹훅 이벤트를 안전하게 수신하고 처리하기 위해 POST 경로를 생성합니다.
복사
export default defineEventHandler((event) => {
const {
private: { webhookKey },
} = useRuntimeConfig();
const handler = Webhooks({
webhookKey: webhookKey,
onPayload: async (payload: any) => {
// Handle webhook payload here
},
// ...add other event handlers as needed
});
return handler(event);
});
체크아웃 경로 핸들러
Dodo Payments는 웹사이트에 결제를 통합하기 위한 세 가지 유형의 결제 흐름을 지원하며, 이 어댑터는 모든 유형의 결제 흐름을 지원합니다.
- 정적 결제 링크: 빠르고 코드 없이 결제를 수집할 수 있는 즉시 공유 가능한 URL입니다.
- 동적 결제 링크: API 또는 SDK를 사용하여 사용자 정의 세부정보로 결제 링크를 프로그래밍 방식으로 생성합니다.
- 체크아웃 세션: 미리 구성된 제품 장바구니 및 고객 세부정보로 안전하고 사용자 정의 가능한 체크아웃 경험을 제공합니다.
정적 체크아웃 (GET)
정적 체크아웃 (GET)
지원되는 쿼리 매개변수
제품 식별자 (예:
?productId=pdt_nZuwz45WAs64n3l07zpQR).제품의 수량.
고객의 전체 이름.
고객의 이름.
고객의 성.
고객의 이메일 주소.
고객의 국가.
고객의 주소.
고객의 도시.
고객의 주/도.
고객의 우편번호.
전체 이름 필드를 비활성화합니다.
이름 필드를 비활성화합니다.
성 필드를 비활성화합니다.
이메일 필드를 비활성화합니다.
국가 필드를 비활성화합니다.
주소 필드를 비활성화합니다.
도시 필드를 비활성화합니다.
주 필드를 비활성화합니다.
우편번호 필드를 비활성화합니다.
결제 통화를 지정합니다 (예:
USD).통화 선택기를 표시합니다.
결제 금액을 지정합니다 (예:
1000은 $10.00).할인 필드를 표시합니다.
metadata_로 시작하는 모든 쿼리 매개변수는 메타데이터로 전달됩니다.productId가 없으면 핸들러가 400 응답을 반환합니다. 유효하지 않은 쿼리 매개변수도 400 응답을 초래합니다.응답 형식
정적 체크아웃은 체크아웃 URL이 포함된 JSON 응답을 반환합니다:복사
{
"checkout_url": "https://checkout.dodopayments.com/..."
}
동적 체크아웃 (POST)
동적 체크아웃 (POST)
- POST 요청의 JSON 본문으로 매개변수를 전송합니다.
- 일회성 및 정기 결제를 모두 지원합니다.
- 지원되는 POST 본문 필드의 전체 목록은 다음을 참조하십시오:
응답 형식
동적 체크아웃은 체크아웃 URL이 포함된 JSON 응답을 반환합니다:복사
{
"checkout_url": "https://checkout.dodopayments.com/..."
}
체크아웃 세션 (POST)
체크아웃 세션 (POST)
체크아웃 세션은 일회성 구매 및 구독을 위한 전체 결제 흐름을 처리하는 보다 안전하고 호스팅된 체크아웃 경험을 제공합니다. 사용자 정의 제어가 가능합니다.자세한 내용과 지원되는 필드의 전체 목록은 체크아웃 세션 통합 가이드를 참조하십시오.
응답 형식
체크아웃 세션은 체크아웃 URL이 포함된 JSON 응답을 반환합니다:복사
{
"checkout_url": "https://checkout.dodopayments.com/session/..."
}
고객 포털 경로 핸들러
고객 포털 경로 핸들러를 사용하면 Dodo Payments 고객 포털을 Nuxt 애플리케이션에 원활하게 통합할 수 있습니다.쿼리 매개변수
포털 세션의 고객 ID (예:
?customer_id=cus_123).true로 설정하면 고객에게 포털 링크가 포함된 이메일을 보냅니다.customer_id가 없으면 400을 반환합니다.웹훅 경로 핸들러
- 메서드: POST 요청만 지원됩니다. 다른 메서드는 405를 반환합니다.
- 서명 검증:
webhookKey를 사용하여 웹훅 서명을 검증합니다. 검증 실패 시 401을 반환합니다. - 페이로드 검증: Zod로 검증됩니다. 유효하지 않은 페이로드에 대해 400을 반환합니다.
- 오류 처리:
- 401: 유효하지 않은 서명
- 400: 유효하지 않은 페이로드
- 500: 검증 중 내부 오류
- 이벤트 라우팅: 페이로드 유형에 따라 적절한 이벤트 핸들러를 호출합니다.
지원되는 웹훅 이벤트 핸들러
복사
onPayload?: (payload: WebhookPayload) => Promise<void>;
onPaymentSucceeded?: (payload: WebhookPayload) => Promise<void>;
onPaymentFailed?: (payload: WebhookPayload) => Promise<void>;
onPaymentProcessing?: (payload: WebhookPayload) => Promise<void>;
onPaymentCancelled?: (payload: WebhookPayload) => Promise<void>;
onRefundSucceeded?: (payload: WebhookPayload) => Promise<void>;
onRefundFailed?: (payload: WebhookPayload) => Promise<void>;
onDisputeOpened?: (payload: WebhookPayload) => Promise<void>;
onDisputeExpired?: (payload: WebhookPayload) => Promise<void>;
onDisputeAccepted?: (payload: WebhookPayload) => Promise<void>;
onDisputeCancelled?: (payload: WebhookPayload) => Promise<void>;
onDisputeChallenged?: (payload: WebhookPayload) => Promise<void>;
onDisputeWon?: (payload: WebhookPayload) => Promise<void>;
onDisputeLost?: (payload: WebhookPayload) => Promise<void>;
onSubscriptionActive?: (payload: WebhookPayload) => Promise<void>;
onSubscriptionOnHold?: (payload: WebhookPayload) => Promise<void>;
onSubscriptionRenewed?: (payload: WebhookPayload) => Promise<void>;
onSubscriptionPlanChanged?: (payload: WebhookPayload) => Promise<void>;
onSubscriptionCancelled?: (payload: WebhookPayload) => Promise<void>;
onSubscriptionFailed?: (payload: WebhookPayload) => Promise<void>;
onSubscriptionExpired?: (payload: WebhookPayload) => Promise<void>;
onLicenseKeyCreated?: (payload: WebhookPayload) => Promise<void>;
LLM 프롬프트
복사
You are an expert Nuxt developer assistant. Your task is to guide a user through integrating the @dodopayments/nuxt module into their existing Nuxt project.
The @dodopayments/nuxt module provides API route handlers for Dodo Payments' Checkout, Customer Portal, and Webhook functionalities, designed for Nuxt 3 server routes.
First, install the necessary package:
npm install @dodopayments/nuxt
Second, add the configuration to nuxt.config.ts
export default defineNuxtConfig({
modules: ["@dodopayments/nuxt"],
devtools: { enabled: true },
compatibilityDate: "2025-02-25",
runtimeConfig: {
private: {
bearerToken: process.env.NUXT_PRIVATE_BEARER_TOKEN,
webhookKey: process.env.NUXT_PRIVATE_BEARER_TOKEN,
environment: process.env.NUXT_PRIVATE_ENVIRONMENT,
returnUrl: process.env.NUXT_PRIVATE_RETURNURL
},
}
});
Here's how you should structure your response:
Ask the user which functionalities they want to integrate.
"Which parts of the @dodopayments/nuxt module would you like to integrate into your project? You can choose one or more of the following:
Checkout API Route (for handling product checkouts)
Customer Portal API Route (for managing customer subscriptions/details)
Webhook API Route (for receiving Dodo Payments webhook events)
All (integrate all three)"
Based on the user's selection, provide detailed integration steps for each chosen functionality.
If Checkout API Route is selected:
Purpose: This route redirects users to the Dodo Payments checkout page.
File Creation: Create a new file at server/routes/api/checkout.get.ts in your Nuxt project.
Code Snippet:
// server/routes/api/checkout.get.ts
export default defineEventHandler((event) => {
const {
private: { bearerToken, environment, returnUrl },
} = useRuntimeConfig();
const handler = checkoutHandler({
bearerToken: bearerToken,
environment: environment,
returnUrl: returnUrl,
});
return handler(event);
});
Configuration & Usage:
- bearerToken: Your Dodo Payments API key. Set via the NUXT_PRIVATE_BEARER_TOKEN environment variable.
- returnUrl: (Optional) The URL to redirect the user to after a successful checkout.
- environment: (Optional) Set to your environment (e.g., "test_mode" or "live_mode").
Static Checkout (GET) Query Parameters:
- productId (required): Product identifier (e.g., ?productId=pdt_nZuwz45WAs64n3l07zpQR)
- quantity (optional): Quantity of the product
- Customer Fields (optional): fullName, firstName, lastName, email, country, addressLine, city, state, zipCode
- Disable Flags (optional, set to true to disable): disableFullName, disableFirstName, disableLastName, disableEmail, disableCountry, disableAddressLine, disableCity, disableState, disableZipCode
- Advanced Controls (optional): paymentCurrency, showCurrencySelector, paymentAmount, showDiscounts
- Metadata (optional): Any query parameter starting with metadata_ (e.g., ?metadata_userId=abc123)
Dynamic Checkout (POST): Parameters are sent as a JSON body. Supports both one-time and recurring payments. For a complete list of supported POST body fields, refer to:
- Docs - One Time Payment Product: https://docs.dodopayments.com/api-reference/payments/post-payments
- Docs - Subscription Product: https://docs.dodopayments.com/api-reference/subscriptions/post-subscriptions
Checkout Sessions (POST) - (Recommended) A more customizable checkout experience. Returns JSON with checkout_url: Parameters are sent as a JSON body. Supports both one-time and recurring payments. Returns: {"checkout_url": "https://checkout.dodopayments.com/session/..."}. For a complete list of supported fields, refer to:
Checkout Sessions Integration Guide: https://docs.dodopayments.com/developer-resources/checkout-session
Error Handling: If productId is missing or other query parameters are invalid, the handler will return a 400 response.
If Customer Portal API Route is selected:
Purpose: This route allows customers to access their Dodo Payments customer portal.
File Creation: Create a new file at server/routes/api/customer-portal.get.ts in your Nuxt project.
Code Snippet:
// server/routes/api/customer-portal.get.ts
export default defineEventHandler((event) => {
const {
private: { bearerToken, environment },
} = useRuntimeConfig();
const handler = customerPortalHandler({
bearerToken,
environment: environment,
});
return handler(event);
});
Query Parameters:
- customer_id (required): The customer ID for the portal session (e.g., ?customer_id=cus_123)
- send_email (optional, boolean): If set to true, sends an email to the customer with the portal link.
- Returns 400 if customer_id is missing.
If Webhook API Route is selected:
Purpose: This route processes incoming webhook events from Dodo Payments, allowing your application to react to events like successful payments, refunds, or subscription changes.
File Creation: Create a new file at server/routes/api/webhook.post.ts in your Nuxt project.
Code Snippet:
// server/routes/api/webhook.post.ts
export default defineEventHandler((event) => {
const {
private: { webhookKey },
} = useRuntimeConfig();
const handler = Webhooks({
webhookKey: webhookKey,
onPayload: async (payload) => {
// handle the payload
},
// ... other event handlers for granular control
});
return handler(event);
});
Handler Details:
- Method: Only POST requests are supported. Other methods return 405.
- Signature Verification: The handler verifies the webhook signature using webhookKey and returns 401 if verification fails.
- Payload Validation: The payload is validated with Zod. Returns 400 for invalid payloads.
Error Handling:
- 401: Invalid signature
- 400: Invalid payload
- 500: Internal error during verification
Event Routing: Calls the appropriate event handler based on the payload type. Supported event handlers include:
- onPayload?: (payload: WebhookPayload) => Promise<void>
- onPaymentSucceeded?: (payload: WebhookPayload) => Promise<void>
- onPaymentFailed?: (payload: WebhookPayload) => Promise<void>
- onPaymentProcessing?: (payload: WebhookPayload) => Promise<void>
- onPaymentCancelled?: (payload: WebhookPayload) => Promise<void>
- onRefundSucceeded?: (payload: WebhookPayload) => Promise<void>
- onRefundFailed?: (payload: WebhookPayload) => Promise<void>
- onDisputeOpened?: (payload: WebhookPayload) => Promise<void>
- onDisputeExpired?: (payload: WebhookPayload) => Promise<void>
- onDisputeAccepted?: (payload: WebhookPayload) => Promise<void>
- onDisputeCancelled?: (payload: WebhookPayload) => Promise<void>
- onDisputeChallenged?: (payload: WebhookPayload) => Promise<void>
- onDisputeWon?: (payload: WebhookPayload) => Promise<void>
- onDisputeLost?: (payload: WebhookPayload) => Promise<void>
- onSubscriptionActive?: (payload: WebhookPayload) => Promise<void>
- onSubscriptionOnHold?: (payload: WebhookPayload) => Promise<void>
- onSubscriptionRenewed?: (payload: WebhookPayload) => Promise<void>
- onSubscriptionPlanChanged?: (payload: WebhookPayload) => Promise<void>
- onSubscriptionCancelled?: (payload: WebhookPayload) => Promise<void>
- onSubscriptionFailed?: (payload: WebhookPayload) => Promise<void>
- onSubscriptionExpired?: (payload: WebhookPayload) => Promise<void>
- onLicenseKeyCreated?: (payload: WebhookPayload) => Promise<void>
Environment Variable Setup:
To ensure the module functions correctly, set up the following environment variables in your Nuxt project's deployment environment (e.g., Vercel, Netlify, AWS, etc.):
- NUXT_PRIVATE_BEARER_TOKEN: Your Dodo Payments API Key (required for Checkout and Customer Portal).
- NUXT_PRIVATE_WEBHOOK_KEY: Your Dodo Payments Webhook Secret (required for Webhook handler).
- NUXT_PRIVATE_ENVIRONMENT: (Optional) Set to your environment (e.g., "test_mode" or "live_mode").
- NUXT_PRIVATE_RETURNURL: (Optional) The URL to redirect to after a successful checkout (for Checkout handler).
Usage in your code:
bearerToken: useRuntimeConfig().private.bearerToken
webhookKey: useRuntimeConfig().private.webhookKey
Important: Never commit sensitive environment variables directly into your version control. Use environment variables for all sensitive information.
If the user needs assistance setting up environment variables for their specific deployment environment, ask them what platform they are using (e.g., Vercel, Netlify, AWS, etc.), and provide guidance.
복사
You are an expert Nuxt developer assistant. Your task is to guide a user through integrating the @dodopayments/nuxt module into their existing Nuxt project.
The @dodopayments/nuxt module provides API route handlers for Dodo Payments' Checkout, Customer Portal, and Webhook functionalities, designed for Nuxt 3 server routes.
First, install the necessary package:
npm install @dodopayments/nuxt
Second, add the configuration to nuxt.config.ts
export default defineNuxtConfig({
modules: ["@dodopayments/nuxt"],
devtools: { enabled: true },
compatibilityDate: "2025-02-25",
runtimeConfig: {
private: {
bearerToken: process.env.NUXT_PRIVATE_BEARER_TOKEN,
webhookKey: process.env.NUXT_PRIVATE_BEARER_TOKEN,
environment: process.env.NUXT_PRIVATE_ENVIRONMENT,
returnUrl: process.env.NUXT_PRIVATE_RETURNURL
},
}
});
Here's how you should structure your response:
Ask the user which functionalities they want to integrate.
"Which parts of the @dodopayments/nuxt module would you like to integrate into your project? You can choose one or more of the following:
Checkout API Route (for handling product checkouts)
Customer Portal API Route (for managing customer subscriptions/details)
Webhook API Route (for receiving Dodo Payments webhook events)
All (integrate all three)"
Based on the user's selection, provide detailed integration steps for each chosen functionality.
If Checkout API Route is selected:
Purpose: This route redirects users to the Dodo Payments checkout page.
File Creation: Create a new file at server/routes/api/checkout.get.ts in your Nuxt project.
Code Snippet:
// server/routes/api/checkout.get.ts
export default defineEventHandler((event) => {
const {
private: { bearerToken, environment, returnUrl },
} = useRuntimeConfig();
const handler = checkoutHandler({
bearerToken: bearerToken,
environment: environment,
returnUrl: returnUrl,
});
return handler(event);
});
Configuration & Usage:
- bearerToken: Your Dodo Payments API key. Set via the NUXT_PRIVATE_BEARER_TOKEN environment variable.
- returnUrl: (Optional) The URL to redirect the user to after a successful checkout.
- environment: (Optional) Set to your environment (e.g., "test_mode" or "live_mode").
Static Checkout (GET) Query Parameters:
- productId (required): Product identifier (e.g., ?productId=pdt_nZuwz45WAs64n3l07zpQR)
- quantity (optional): Quantity of the product
- Customer Fields (optional): fullName, firstName, lastName, email, country, addressLine, city, state, zipCode
- Disable Flags (optional, set to true to disable): disableFullName, disableFirstName, disableLastName, disableEmail, disableCountry, disableAddressLine, disableCity, disableState, disableZipCode
- Advanced Controls (optional): paymentCurrency, showCurrencySelector, paymentAmount, showDiscounts
- Metadata (optional): Any query parameter starting with metadata_ (e.g., ?metadata_userId=abc123)
Dynamic Checkout (POST): Parameters are sent as a JSON body. Supports both one-time and recurring payments. For a complete list of supported POST body fields, refer to:
- Docs - One Time Payment Product: https://docs.dodopayments.com/api-reference/payments/post-payments
- Docs - Subscription Product: https://docs.dodopayments.com/api-reference/subscriptions/post-subscriptions
Checkout Sessions (POST) - (Recommended) A more customizable checkout experience. Returns JSON with checkout_url: Parameters are sent as a JSON body. Supports both one-time and recurring payments. Returns: {"checkout_url": "https://checkout.dodopayments.com/session/..."}. For a complete list of supported fields, refer to:
Checkout Sessions Integration Guide: https://docs.dodopayments.com/developer-resources/checkout-session
Error Handling: If productId is missing or other query parameters are invalid, the handler will return a 400 response.
If Customer Portal API Route is selected:
Purpose: This route allows customers to access their Dodo Payments customer portal.
File Creation: Create a new file at server/routes/api/customer-portal.get.ts in your Nuxt project.
Code Snippet:
// server/routes/api/customer-portal.get.ts
export default defineEventHandler((event) => {
const {
private: { bearerToken, environment },
} = useRuntimeConfig();
const handler = customerPortalHandler({
bearerToken,
environment: environment,
});
return handler(event);
});
Query Parameters:
- customer_id (required): The customer ID for the portal session (e.g., ?customer_id=cus_123)
- send_email (optional, boolean): If set to true, sends an email to the customer with the portal link.
- Returns 400 if customer_id is missing.
If Webhook API Route is selected:
Purpose: This route processes incoming webhook events from Dodo Payments, allowing your application to react to events like successful payments, refunds, or subscription changes.
File Creation: Create a new file at server/routes/api/webhook.post.ts in your Nuxt project.
Code Snippet:
// server/routes/api/webhook.post.ts
export default defineEventHandler((event) => {
const {
private: { webhookKey },
} = useRuntimeConfig();
const handler = Webhooks({
webhookKey: webhookKey,
onPayload: async (payload) => {
// handle the payload
},
// ... other event handlers for granular control
});
return handler(event);
});
Handler Details:
- Method: Only POST requests are supported. Other methods return 405.
- Signature Verification: The handler verifies the webhook signature using webhookKey and returns 401 if verification fails.
- Payload Validation: The payload is validated with Zod. Returns 400 for invalid payloads.
Error Handling:
- 401: Invalid signature
- 400: Invalid payload
- 500: Internal error during verification
Event Routing: Calls the appropriate event handler based on the payload type. Supported event handlers include:
- onPayload?: (payload: WebhookPayload) => Promise<void>
- onPaymentSucceeded?: (payload: WebhookPayload) => Promise<void>
- onPaymentFailed?: (payload: WebhookPayload) => Promise<void>
- onPaymentProcessing?: (payload: WebhookPayload) => Promise<void>
- onPaymentCancelled?: (payload: WebhookPayload) => Promise<void>
- onRefundSucceeded?: (payload: WebhookPayload) => Promise<void>
- onRefundFailed?: (payload: WebhookPayload) => Promise<void>
- onDisputeOpened?: (payload: WebhookPayload) => Promise<void>
- onDisputeExpired?: (payload: WebhookPayload) => Promise<void>
- onDisputeAccepted?: (payload: WebhookPayload) => Promise<void>
- onDisputeCancelled?: (payload: WebhookPayload) => Promise<void>
- onDisputeChallenged?: (payload: WebhookPayload) => Promise<void>
- onDisputeWon?: (payload: WebhookPayload) => Promise<void>
- onDisputeLost?: (payload: WebhookPayload) => Promise<void>
- onSubscriptionActive?: (payload: WebhookPayload) => Promise<void>
- onSubscriptionOnHold?: (payload: WebhookPayload) => Promise<void>
- onSubscriptionRenewed?: (payload: WebhookPayload) => Promise<void>
- onSubscriptionPlanChanged?: (payload: WebhookPayload) => Promise<void>
- onSubscriptionCancelled?: (payload: WebhookPayload) => Promise<void>
- onSubscriptionFailed?: (payload: WebhookPayload) => Promise<void>
- onSubscriptionExpired?: (payload: WebhookPayload) => Promise<void>
- onLicenseKeyCreated?: (payload: WebhookPayload) => Promise<void>
Environment Variable Setup:
To ensure the module functions correctly, set up the following environment variables in your Nuxt project's deployment environment (e.g., Vercel, Netlify, AWS, etc.):
- NUXT_PRIVATE_BEARER_TOKEN: Your Dodo Payments API Key (required for Checkout and Customer Portal).
- NUXT_PRIVATE_WEBHOOK_KEY: Your Dodo Payments Webhook Secret (required for Webhook handler).
- NUXT_PRIVATE_ENVIRONMENT: (Optional) Set to your environment (e.g., "test_mode" or "live_mode").
- NUXT_PRIVATE_RETURNURL: (Optional) The URL to redirect to after a successful checkout (for Checkout handler).
Usage in your code:
bearerToken: useRuntimeConfig().private.bearerToken
webhookKey: useRuntimeConfig().private.webhookKey
Important: Never commit sensitive environment variables directly into your version control. Use environment variables for all sensitive information.
If the user needs assistance setting up environment variables for their specific deployment environment, ask them what platform they are using (e.g., Vercel, Netlify, AWS, etc.), and provide guidance.