@spaire/elysia
v2.0.1
Published
Spaire integration for Elysia
Maintainers
Readme
@spaire/elysia
Payments and Checkouts made dead simple with Elysia.
pnpm install @spaire/elysia zod
Checkout
Create a Checkout handler which takes care of redirections.
import { Elysia } from "elysia";
import { Checkout } from "@spaire/elysia";
const app = new Elysia();
app.get(
"/checkout",
Checkout({
accessToken: "xxx", // Or set an environment variable to SPAIRE_ACCESS_TOKEN
successUrl: process.env.SUCCESS_URL,
returnUrl: "https://myapp.com", // Optional Return URL, which renders a Back-button in the Checkout
server: "sandbox", // Use sandbox if you're testing Spaire - omit the parameter or pass 'production' otherwise
theme: "dark" // Enforces the theme - System-preferred theme will be set if left omitted
}),
);Query Params
Pass query params to this route.
- products
?products=123 - customerId (optional)
?products=123&customerId=xxx - customerExternalId (optional)
?products=123&customerExternalId=xxx - customerEmail (optional)
?products=123&[email protected] - customerName (optional)
?products=123&customerName=Jane - seats (optional)
?products=123&seats=5- Number of seats for seat-based products - metadata (optional)
URL-Encoded JSON string
Customer Portal
Create a customer portal where your customer can view orders and subscriptions.
import { Elysia } from "elysia";
import { CustomerPortal } from "@spaire/elysia";
const app = new Elysia();
app.get(
"/portal",
CustomerPortal({
accessToken: "xxx", // Or set an environment variable to SPAIRE_ACCESS_TOKEN
getCustomerId: (event) => "", // Fuction to resolve a Spaire Customer ID
returnUrl: "https://myapp.com", // Optional Return URL, which renders a Back-button in the Customer Portal
server: "sandbox", // Use sandbox if you're testing Spaire - omit the parameter or pass 'production' otherwise
}),
);Webhooks
A simple utility which resolves incoming webhook payloads by signing the webhook secret properly.
import { Elysia } from 'elysia'
import { Webhooks } from "@spaire/elysia";
const app = new Elysia()
app.post('/spaire/webhooks', Webhooks({
webhookSecret: process.env.SPAIRE_WEBHOOK_SECRET!,
onPayload: async (payload) => /** Handle payload */,
}))Payload Handlers
The Webhook handler also supports granular handlers for easy integration.
- onCheckoutCreated: (payload) =>
- onCheckoutUpdated: (payload) =>
- onOrderCreated: (payload) =>
- onOrderUpdated: (payload) =>
- onOrderPaid: (payload) =>
- onSubscriptionCreated: (payload) =>
- onSubscriptionUpdated: (payload) =>
- onSubscriptionActive: (payload) =>
- onSubscriptionCanceled: (payload) =>
- onSubscriptionRevoked: (payload) =>
- onProductCreated: (payload) =>
- onProductUpdated: (payload) =>
- onOrganizationUpdated: (payload) =>
- onBenefitCreated: (payload) =>
- onBenefitUpdated: (payload) =>
- onBenefitGrantCreated: (payload) =>
- onBenefitGrantUpdated: (payload) =>
- onBenefitGrantRevoked: (payload) =>
- onCustomerCreated: (payload) =>
- onCustomerUpdated: (payload) =>
- onCustomerDeleted: (payload) =>
- onCustomerStateChanged: (payload) =>
