syntax = "proto3";
package cdk_payment_processor;
service CdkPaymentProcessor {
rpc GetSettings(EmptyRequest) returns (SettingsResponse) {}
rpc CreatePayment(CreatePaymentRequest) returns (CreatePaymentResponse) {}
rpc GetPaymentQuote(PaymentQuoteRequest) returns (PaymentQuoteResponse) {}
rpc MakePayment(MakePaymentRequest) returns (MakePaymentResponse) {}
rpc CheckIncomingPayment(CheckIncomingPaymentRequest) returns (CheckIncomingPaymentResponse) {}
rpc CheckOutgoingPayment(CheckOutgoingPaymentRequest) returns (MakePaymentResponse) {}
rpc WaitIncomingPayment(EmptyRequest) returns (stream WaitIncomingPaymentResponse) {}
}
message EmptyRequest {}
message AmountMessage {
uint64 value = 1;
string unit = 2;
}
message SettingsResponse {
string unit = 1;
Bolt11Settings bolt11 = 2;
Bolt12Settings bolt12 = 3;
map<string, string> custom = 4;
}
message Bolt12Settings {
bool amountless = 2;
}
message Bolt11Settings {
bool mpp = 1;
bool amountless = 2;
bool invoice_description = 5;
}
message Bolt11IncomingPaymentOptions {
optional string description = 1;
AmountMessage amount = 2;
optional uint64 unix_expiry = 3;
}
message CustomIncomingPaymentOptions {
optional string description = 1;
optional AmountMessage amount = 2;
optional uint64 unix_expiry = 3;
// Extra payment-method-specific fields as JSON string
// These fields are flattened into the JSON representation on the client side
optional string extra_json = 4;
}
message Bolt12IncomingPaymentOptions {
optional string description = 1;
optional AmountMessage amount = 2;
optional uint64 unix_expiry = 3;
}
enum PaymentMethodType {
PAYMENT_METHOD_TYPE_UNSPECIFIED = 0;
PAYMENT_METHOD_TYPE_BOLT11 = 1;
PAYMENT_METHOD_TYPE_BOLT12 = 2;
PAYMENT_METHOD_TYPE_CUSTOM = 3;
}
enum OutgoingPaymentRequestType {
OUTGOING_PAYMENT_REQUEST_TYPE_UNSPECIFIED = 0;
OUTGOING_PAYMENT_REQUEST_TYPE_BOLT11_INVOICE = 1;
OUTGOING_PAYMENT_REQUEST_TYPE_BOLT12_OFFER = 2;
OUTGOING_PAYMENT_REQUEST_TYPE_CUSTOM = 3;
}
enum PaymentIdentifierType {
PAYMENT_IDENTIFIER_TYPE_UNSPECIFIED = 0;
PAYMENT_IDENTIFIER_TYPE_PAYMENT_HASH = 1;
PAYMENT_IDENTIFIER_TYPE_OFFER_ID = 2;
PAYMENT_IDENTIFIER_TYPE_LABEL = 3;
PAYMENT_IDENTIFIER_TYPE_BOLT12_PAYMENT_HASH = 4;
PAYMENT_IDENTIFIER_TYPE_CUSTOM_ID = 5;
PAYMENT_IDENTIFIER_TYPE_PAYMENT_ID = 6;
}
message PaymentIdentifier {
PaymentIdentifierType type = 1;
oneof value {
string hash = 2; // Used for PAYMENT_HASH and BOLT12_PAYMENT_HASH
string id = 3; // Used for OFFER_ID, LABEL, and CUSTOM_ID
}
}
message IncomingPaymentOptions {
oneof options {
Bolt11IncomingPaymentOptions bolt11 = 1;
Bolt12IncomingPaymentOptions bolt12 = 2;
CustomIncomingPaymentOptions custom = 3;
}
}
message CreatePaymentRequest {
IncomingPaymentOptions options = 2;
}
message CreatePaymentResponse {
PaymentIdentifier request_identifier = 1;
string request = 2;
optional uint64 expiry = 3;
// Extra payment-method-specific fields as JSON string
// For custom payment methods, these fields are flattened into the response
optional string extra_json = 4;
}
message Mpp {
uint64 amount = 1;
}
message Amountless {
uint64 amount_msat = 1;
}
message MeltOptions {
oneof options {
Mpp mpp = 1;
Amountless amountless = 2;
}
}
message PaymentQuoteRequest {
string request = 1;
string unit = 2;
optional MeltOptions options = 3;
OutgoingPaymentRequestType request_type = 4;
// Extra payment-method-specific fields as JSON string
// For custom payment methods, these fields are passed through for validation
optional string extra_json = 5;
}
enum QuoteState {
QUOTE_STATE_UNSPECIFIED = 0;
QUOTE_STATE_UNPAID = 1;
QUOTE_STATE_PAID = 2;
QUOTE_STATE_PENDING = 3;
QUOTE_STATE_UNKNOWN = 4;
QUOTE_STATE_FAILED = 5;
QUOTE_STATE_ISSUED = 6;
}
message PaymentQuoteResponse {
PaymentIdentifier request_identifier = 1;
AmountMessage amount = 2;
AmountMessage fee = 3;
QuoteState state = 4;
// Extra payment-method-specific fields as JSON string
// For custom payment methods, these fields are flattened into the response
optional string extra_json = 5;
}
message Bolt11OutgoingPaymentOptions {
string bolt11 = 1;
optional AmountMessage max_fee_amount = 2;
optional uint64 timeout_secs = 3;
optional MeltOptions melt_options = 4;
}
message Bolt12OutgoingPaymentOptions {
string offer = 1;
optional AmountMessage max_fee_amount = 2;
optional uint64 timeout_secs = 3;
optional MeltOptions melt_options = 5;
}
message CustomOutgoingPaymentOptions {
string offer = 1;
optional AmountMessage max_fee_amount = 2;
optional uint64 timeout_secs = 3;
optional MeltOptions melt_options = 5;
// Extra payment-method-specific fields as JSON string
// These fields are flattened into the JSON representation on the client side
optional string extra_json = 6;
}
enum OutgoingPaymentOptionsType {
OUTGOING_PAYMENT_OPTIONS_TYPE_UNSPECIFIED = 0;
OUTGOING_PAYMENT_OPTIONS_TYPE_BOLT11 = 1;
OUTGOING_PAYMENT_OPTIONS_TYPE_BOLT12 = 2;
OUTGOING_PAYMENT_OPTIONS_TYPE_CUSTOM = 3;
}
message OutgoingPaymentVariant {
oneof options {
Bolt11OutgoingPaymentOptions bolt11 = 1;
Bolt12OutgoingPaymentOptions bolt12 = 2;
CustomOutgoingPaymentOptions custom = 3;
}
}
message MakePaymentRequest {
OutgoingPaymentVariant payment_options = 1;
optional AmountMessage partial_amount = 2;
optional AmountMessage max_fee_amount = 3;
string unit = 4;
}
message MakePaymentResponse {
PaymentIdentifier payment_identifier = 1;
optional string payment_proof = 2;
QuoteState status = 3;
AmountMessage total_spent = 4;
// Extra payment-method-specific fields as JSON string
// For custom payment methods, these fields are flattened into the response
optional string extra_json = 5;
}
message CheckIncomingPaymentRequest {
PaymentIdentifier request_identifier = 1;
}
message CheckIncomingPaymentResponse {
repeated WaitIncomingPaymentResponse payments = 1;
}
message CheckOutgoingPaymentRequest {
PaymentIdentifier request_identifier = 1;
}
message WaitIncomingPaymentResponse {
PaymentIdentifier payment_identifier = 1;
AmountMessage payment_amount = 2;
string payment_id = 3;
}