@faremeter/middleware
v0.20.1
Published
Server middleware for adding payment walls to API endpoints using x402 protocol
Downloads
1,910
Readme
@faremeter/middleware
Server middleware for adding payment walls to API endpoints using the x402 protocol.
Installation
pnpm install @faremeter/middlewareFeatures
- Paywall any endpoint - Add
middlewareto any route - Framework agnostic - Express, Hono, or custom
- Multi-chain support - Solana, EVM, extensible
- Fast validation - Payment requirements caching
- Facilitator integration - Handles settlement verification
API Reference
Functions
- createHTTPFacilitatorHandler
- findMatchingPaymentRequirements
- findMatchingPaymentRequirementsV2
- relaxedRequirementsToV2
- resolveSupportedVersions
- validateMiddlewareArgs
- deriveCapabilities
- deriveResourceInfo
- acceptsToPricing
- createRemoteX402Handlers
- resolveConfig
- handleMiddlewareRequest
- createMiddleware
- createMiddleware
createHTTPFacilitatorHandler
Creates a {@link FacilitatorHandler } that delegates to a remote facilitator via HTTP.
The glue layer constructs valid x402PaymentRequirements from
ResourcePricing using capabilities.schemes, then passes them to
getRequirements. This handler POSTs those to the facilitator's
/accepts endpoint for enrichment.
Cache key stability: caching assumes that identical accepts arrays
produce identical facilitator responses. If the facilitator returns
time-dependent values (e.g. recentBlockhash), use a short maxAge
or disable caching.
| Function | Type |
| ------------------------------ | ---------------------------------------------------------------------------------------- |
| createHTTPFacilitatorHandler | (facilitatorURL: string, opts: CreateHTTPFacilitatorHandlerOpts) => FacilitatorHandler |
findMatchingPaymentRequirements
Finds the payment requirement that matches the client's v1 payment payload.
| Function | Type |
| --------------------------------- | ------------------------------------------------------------------------------ |
| findMatchingPaymentRequirements | (accepts: x402PaymentRequirementsV1[], payload: x402PaymentPayloadV1) => any |
Parameters:
accepts: - Array of accepted payment requirements from the facilitatorpayload: - The client's payment payload
Returns:
The matching requirement, or undefined if no match found
findMatchingPaymentRequirementsV2
Finds the payment requirement that matches the client's v2 payment payload.
| Function | Type |
| ----------------------------------- | -------------------------------------------------------------------------- |
| findMatchingPaymentRequirementsV2 | (accepts: x402PaymentRequirements[], payload: x402PaymentPayload) => any |
Parameters:
accepts: - Array of accepted payment requirements from the facilitatorpayload: - The client's v2 payment payload
Returns:
The matching requirement, or undefined if no match found
relaxedRequirementsToV2
Converts v1 relaxed requirements to v2 format, preserving all fields
including extra.
| Function | Type |
| ------------------------- | ------------------------------------------------------------- |
| relaxedRequirementsToV2 | (req: x402PaymentRequirementsV1) => x402PaymentRequirements |
resolveSupportedVersions
Resolve and validate supported versions config. Returns resolved config with defaults applied. Throws if configuration is invalid.
| Function | Type |
| -------------------------- | -------------------------------------------------------------------------------------- |
| resolveSupportedVersions | (config?: SupportedVersionsConfig or undefined) => Required<SupportedVersionsConfig> |
validateMiddlewareArgs
Validates that CommonMiddlewareArgs has exactly one configuration mode.
| Function | Type |
| ------------------------ | -------------------------------------- |
| validateMiddlewareArgs | (args: CommonMiddlewareArgs) => void |
deriveCapabilities
Derives HandlerCapabilities from relaxed v1 requirements.
Used by framework adapters to construct capabilities for the HTTP wrapper
from the legacy accepts configuration.
| Function | Type |
| -------------------- | --------------------------------------------------------------- |
| deriveCapabilities | (accepts: x402PaymentRequirementsV1[]) => HandlerCapabilities |
deriveResourceInfo
Extracts resource info from v1 accepts entries. Used by framework adapters to build the resource info for the 402 response.
| Function | Type |
| -------------------- | --------------------------------------------------------------------------------- |
| deriveResourceInfo | (accepts: x402PaymentRequirementsV1[], resourceURL: string) => x402ResourceInfo |
acceptsToPricing
| Function | Type |
| ------------------ | ------------------------------------------------------------- |
| acceptsToPricing | (accepts: x402PaymentRequirementsV1[]) => ResourcePricing[] |
createRemoteX402Handlers
Creates x402 facilitator handlers backed by a remote HTTP facilitator.
This is the composable equivalent of the facilitatorURL + accepts
shorthand on {@link CommonMiddlewareArgs}. Use it when you need to
combine a remote x402 facilitator with in-process MPP handlers in the
same middleware.
| Function | Type |
| -------------------------- | -------------------------------------------------------------- |
| createRemoteX402Handlers | (args: CreateRemoteX402HandlersArgs) => FacilitatorHandler[] |
Returns:
An array of {@link FacilitatorHandler } suitable for
createMiddleware({ x402Handlers: ... }).
resolveConfig
Resolves {@link CommonMiddlewareArgs} into the handlers + pricing tuple
that {@link handleMiddlewareRequest} needs. For the facilitatorURL path,
creates an HTTP handler wrapper and converts accepts to pricing.
| Function | Type |
| --------------- | ------------------------------------------------ |
| resolveConfig | (args: CommonMiddlewareArgs) => ResolvedConfig |
handleMiddlewareRequest
Core middleware request handler that processes x402 and MPP payment flows.
Delegates to protocol-specific glue layers for challenge generation, settlement, and verification. The middleware formats HTTP responses but never constructs protocol types directly.
| Function | Type |
| ------------------------- | ------------------------------------------------------------------------------------------------------------------------- |
| handleMiddlewareRequest | <MiddlewareResponse>(args: HandleMiddlewareRequestArgs<MiddlewareResponse>) => Promise<MiddlewareResponse or undefined> |
createMiddleware
Creates Express middleware that gates routes behind x402 and MPP payment.
| Function | Type |
| ------------------ | ---------------------------------------------------------------------------------------------------------------------------------------------------------------------------- |
| createMiddleware | (args: CommonMiddlewareArgs) => Promise<(req: Request<ParamsDictionary, any, any, ParsedQs, Record<string, any>>, res: Response<...>, next: NextFunction) => Promise<...>> |
Parameters:
args: - Configuration including handlers + pricing or facilitator URL
Returns:
An Express middleware function
createMiddleware
Creates Hono middleware that gates routes behind x402 and MPP payment.
The middleware intercepts requests, checks for payment headers, validates and settles payments via x402 or MPP protocol, and only allows the request to proceed if payment is successful.
| Function | Type |
| ------------------ | ------------------------------------------------------------ |
| createMiddleware | (args: CreateMiddlewareArgs) => Promise<MiddlewareHandler> |
Parameters:
args: - Configuration including handlers + pricing or facilitator URL
Returns:
A Hono middleware handler
AgedLRUCache
An LRU cache with time-based expiration.
Entries are evicted when they exceed maxAge or when the cache reaches capacity (least recently used entries are removed first).
Methods
get
| Method | Type |
| ------ | ---------------------------- |
| get | (key: K) => V or undefined |
put
| Method | Type |
| ------ | ---------------------------- |
| put | (key: K, value: V) => void |
Types
- AgedLRUCacheOpts
- RelaxedRequirements
- RelaxedRequirementsV2
- SupportedVersionsConfig
- CommonMiddlewareArgs
- CreateRemoteX402HandlersArgs
- ResolvedConfig
- SettleResultV1
- SettleResultV2
- SettleResult
- VerifyResultV1
- VerifyResultV2
- VerifyResult
- MiddlewareBodyContextV1
- MiddlewareBodyContextV2
- SettleResultMPP
- MiddlewareBodyContextMPP
- MiddlewareBodyContext
- HandleMiddlewareRequestArgs
AgedLRUCacheOpts
Configuration options for the AgedLRUCache.
| Type | Type |
| ------------------ | ------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------ |
| AgedLRUCacheOpts | { /** Maximum number of entries. Defaults to 256. */ capacity?: number; /** Maximum age in milliseconds before entries expire. Defaults to 30000. */ maxAge?: number; /** Custom time function for testing. Defaults to Date.now. */ now?: () => number; } |
RelaxedRequirements
| Type | Type |
| --------------------- | ------------------------------------ |
| RelaxedRequirements | Partial<x402PaymentRequirementsV1> |
RelaxedRequirementsV2
| Type | Type |
| ----------------------- | ---------------------------------- |
| RelaxedRequirementsV2 | Partial<x402PaymentRequirements> |
SupportedVersionsConfig
Configuration for which x402 protocol versions the middleware supports. At least one version must be enabled.
| Type | Type |
| ------------------------- | ------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------ |
| SupportedVersionsConfig | { /** Support x402 v1 protocol (JSON body responses, X-PAYMENT header). Default: true */ x402v1?: boolean; /** Support x402 v2 protocol (PAYMENT-REQUIRED header, PAYMENT-SIGNATURE header). Default: false */ x402v2?: boolean; } |
CommonMiddlewareArgs
Common configuration arguments shared by all middleware implementations. Supports two mutually exclusive modes: in-process handlers or remote facilitator.
| Type | Type |
| ---------------------- | --------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------- |
| CommonMiddlewareArgs | { /** x402 handlers for in-process settlement. */ x402Handlers?: FacilitatorHandler[]; /** MPP method handlers for in-process settlement. */ mppMethodHandlers?: MPPMethodHandler[]; /** Protocol-agnostic pricing for in-process handlers. */ pricing?: ResourcePricing[]; /** URL of a remote facilitator service (backward compat). */ facilitatorURL?: string; /** Payment requirements for the remote facilitator path. */ accepts?: (RelaxedRequirements or RelaxedRequirements[])[]; /** Cache configuration for remote facilitator responses. */ cacheConfig?: AgedLRUCacheOpts and { disable?: boolean }; /** Which x402 protocol versions to support. */ supportedVersions?: SupportedVersionsConfig; } |
CreateRemoteX402HandlersArgs
| Type | Type |
| ------------------------------ | -------------------------------------------------------------------------------------------------------------------------------------------------- |
| CreateRemoteX402HandlersArgs | { facilitatorURL: string; accepts: (RelaxedRequirements or RelaxedRequirements[])[]; cacheConfig?: AgedLRUCacheOpts and { disable?: boolean }; } |
ResolvedConfig
| Type | Type |
| ---------------- | ----------------------------------------------------------------------------------------------------------------------------------- |
| ResolvedConfig | { handlers: FacilitatorHandler[]; pricing: ResourcePricing[]; mppHandlers: MPPMethodHandler[]; resourceInfo?: x402ResourceInfo; } |
SettleResultV1
| Type | Type |
| ---------------- | ---- | ---------------------------------------------------------------------------------------------------------------------- |
| SettleResultV1 | | { success: true; facilitatorResponse: x402SettleResponseV1 } or { success: false; errorResponse: MiddlewareResponse } |
SettleResultV2
| Type | Type |
| ---------------- | ---- | -------------------------------------------------------------------------------------------------------------------- |
| SettleResultV2 | | { success: true; facilitatorResponse: x402SettleResponse } or { success: false; errorResponse: MiddlewareResponse } |
SettleResult
| Type | Type |
| -------------- | ---- | ------------------------------------------------------------------------- |
| SettleResult | | SettleResultV1<MiddlewareResponse> or SettleResultV2<MiddlewareResponse> |
VerifyResultV1
| Type | Type |
| ---------------- | ---- | ---------------------------------------------------------------------------------------------------------------------- |
| VerifyResultV1 | | { success: true; facilitatorResponse: x402VerifyResponseV1 } or { success: false; errorResponse: MiddlewareResponse } |
VerifyResultV2
| Type | Type |
| ---------------- | ---- | -------------------------------------------------------------------------------------------------------------------- |
| VerifyResultV2 | | { success: true; facilitatorResponse: x402VerifyResponse } or { success: false; errorResponse: MiddlewareResponse } |
VerifyResult
| Type | Type |
| -------------- | ---- | ------------------------------------------------------------------------- |
| VerifyResult | | VerifyResultV1<MiddlewareResponse> or VerifyResultV2<MiddlewareResponse> |
MiddlewareBodyContextV1
Context provided to the middleware body handler for v1 protocol requests. Contains payment information and functions to verify or settle the payment.
| Type | Type |
| ------------------------- | ------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------- |
| MiddlewareBodyContextV1 | { protocolVersion: 1; paymentRequirements: x402PaymentRequirementsV1; paymentPayload: x402PaymentPayloadV1; settle: () => Promise<SettleResultV1<MiddlewareResponse>>; verify: () => Promise<VerifyResultV1<MiddlewareResponse>>; } |
MiddlewareBodyContextV2
Context provided to the middleware body handler for v2 protocol requests. Contains payment information and functions to verify or settle the payment.
| Type | Type |
| ------------------------- | --------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------- |
| MiddlewareBodyContextV2 | { protocolVersion: 2; paymentRequirements: x402PaymentRequirements; paymentPayload: x402PaymentPayload; settle: () => Promise<SettleResultV2<MiddlewareResponse>>; verify: () => Promise<VerifyResultV2<MiddlewareResponse>>; } |
SettleResultMPP
| Type | Type |
| ----------------- | ---- | ------------------------------------------------------------------------------------------------ |
| SettleResultMPP | | { success: true; receipt: mppReceipt } or { success: false; errorResponse: MiddlewareResponse } |
MiddlewareBodyContextMPP
Context provided to the middleware body handler for MPP protocol requests.
| Type | Type |
| -------------------------- | -------------------------------------------------------------------------------------------------------------------- |
| MiddlewareBodyContextMPP | { protocolVersion: "mpp"; credential: mppCredential; settle: () => Promise<SettleResultMPP<MiddlewareResponse>>; } |
MiddlewareBodyContext
Context provided to the middleware body handler. Use protocolVersion to discriminate between v1, v2, and mpp request types.
| Type | Type |
| ----------------------- | ---- | ------------------------------------------------------------------------------------------------------------------------------------------- |
| MiddlewareBodyContext | | MiddlewareBodyContextV1<MiddlewareResponse> or MiddlewareBodyContextV2<MiddlewareResponse> or MiddlewareBodyContextMPP<MiddlewareResponse> |
HandleMiddlewareRequestArgs
Arguments for the core middleware request handler. Framework-specific middleware implementations adapt their request/response objects to this interface.
| Type | Type |
| ----------------------------- | -------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------- |
| HandleMiddlewareRequestArgs | { /** x402 handlers for in-process settlement. */ x402Handlers?: FacilitatorHandler[]; /** MPP method handlers for in-process settlement. */ mppMethodHandlers?: MPPMethodHandler[]; /** Protocol-agnostic pricing entries for the current request. */ pricing: ResourcePricing[]; /** The resource URL being accessed. */ resource: string; /** Resolved supported versions configuration. */ supportedVersions: Required<SupportedVersionsConfig>; /** Function to retrieve a request header value. */ getHeader: (key: string) => string or undefined; /** Function to send a JSON response with optional headers. */ sendJSONResponse: ( status: PossibleStatusCodes, body?: PossibleJSONResponse, headers?: Record<string, string>, ) => MiddlewareResponse; /** Handler function called when a valid payment is received. */ body: ( context: MiddlewareBodyContext<MiddlewareResponse>, ) => Promise<MiddlewareResponse or undefined>; /** Optional function to set a response header. */ setResponseHeader?: (key: string, value: string) => void; /** Optional pre-built resource info for the 402 response. */ resourceInfo?: x402ResourceInfo; /** Optional accessor for the request body (for RFC 9530 digest). */ getBody?: () => Promise<ArrayBuffer or null>; } |
Examples
See working examples in the faremeter repository:
Related Packages
- @faremeter/fetch - Client-side fetch wrapper
- @faremeter/info - Network/asset configuration helpers
- @faremeter/facilitator - Payment facilitator service
License
LGPL-3.0-only
