CDK Payment Processor
The cdk-payment-processor is a Rust crate that provides both a binary and a library for handling payments to and from a cdk mint.
Overview
Library Components
- Payment Processor Server: Handles interaction with payment processor backend implementations
- Client: Used by mintd to query the server for payment information
- Backend Implementations: Supports CLN, LND, and a fake wallet (for testing)
Features
- Modular backend system supporting multiple Lightning implementations
- Extensible design allowing for custom backend implementations
Building from Source
Prerequisites
- Install Nix package manager
- Enter development environment:
Configuration
The server requires different environment variables depending on your chosen Lightning Network backend.
Core Settings
# Choose backend: CLN, LND, or FAKEWALLET
# Server configuration
Backend-Specific Configuration
Core Lightning (CLN)
# Path to CLN RPC socket
Lightning Network Daemon (LND)
# LND connection details
Building and Running
Build and run the binary with your chosen backend:
# For CLN backend
# For LND backend
# For fake wallet (testing only)
Development
To implement a new backend:
- Create a new module implementing the payment processor traits
- Add appropriate feature flags
- Update the binary to support the new backend
For library usage examples and API documentation, refer to the crate documentation.