Sending Lightning Payments

Once you have outbound liquidity you can start sending payments too.

Rust
let use_trampoline = true;
// The `amount_msat` param is optional and should only passed if the bolt11 doesn't specify an amount.
// The amount_msat is required in case an amount is not specified in the bolt11 invoice'.
let optional_amount_msat: Option<u64> = None;
let optional_label = Some("<label>".to_string());

let req = SendPaymentRequest {
    bolt11: "...".into(),
    use_trampoline,
    amount_msat: optional_amount_msat,
    label: optional_label,
};
let response = sdk.send_payment(req).await?;
Swift
let useTrampoline = true
// The `amountMsat` param is optional and should only passed if the bolt11 doesn't specify an amount.
// The amountMsat is required in case an amount is not specified in the bolt11 invoice'.
let optionalAmountMsat: UInt64 = 3_000_000
let optionalLabel = "<label>"
let req = SendPaymentRequest(bolt11: "...", useTrampoline: useTrampoline, amountMsat: optionalAmountMsat, label: optionalLabel)
let response = try? sdk.sendPayment(req: req)
Kotlin
val bolt11 = "..."
try {
    val useTrampoline = true
    // The `amountMsat` param is optional and should only passed if the bolt11 doesn't specify an amount.
    // The amountMsat is required in case an amount is not specified in the bolt11 invoice'.
    val optionalAmountMsat = 3_000_000.toULong()
    val optionalLabel = "<label>"
    val req = SendPaymentRequest(bolt11, useTrampoline, optionalAmountMsat, optionalLabel)
    val response = sdk.sendPayment(req)
} catch (e: Exception) {
    // handle error
}
React Native
try {
  const bolt11 = 'bolt11 invoice'
  const useTrampoline = true
  // The `amountMsat` param is optional and should only passed if the bolt11 doesn't specify an amount.
  // The amountMsat is required in case an amount is not specified in the bolt11 invoice'.
  const optionalAmountMsat = 3000000
  const optionalLabel = '<label>'
  const response = await sendPayment({
    bolt11,
    useTrampoline,
    amountMsat: optionalAmountMsat,
    label: optionalLabel
  })
} catch (err) {
  console.error(err)
}
Dart
// The `amountMsat` param is optional and should only passed if the bolt11 doesn't specify an amount.
// The amountMsat is required in case an amount is not specified in the bolt11 invoice'.
bool useTrampoline = true;
int optionalAmountMsat = 3000000;
String optionalLabel = "<label>";

SendPaymentRequest req = SendPaymentRequest(bolt11: bolt11, useTrampoline: useTrampoline, amountMsat: optionalAmountMsat, label: optionalLabel);
SendPaymentResponse resp = await breezSDK.sendPayment(req: req);
Python
bolt11 = "..."
try:
    use_trampoline = True
    # The `amount_msat` param is optional and should only passed if the bolt11 doesn't specify an amount.
    # The amount_msat is required in case an amount is not specified in the bolt11 invoice'.
    optional_amount_msat = 3000000
    optional_label = "<label>"
    req = breez_sdk.SendPaymentRequest(bolt11=bolt11, use_trampoline=use_trampoline, amount_msat=optional_amount_msat, label=optional_label)
    sdk_services.send_payment(req=req)
except Exception as error:
    print(error)
    raise        
Go
bolt11 := "bolt11 invoice"
useTrampoline := true
// The `amountMsat` param is optional and should only passed if the bolt11 doesn't specify an amount.
// The amountMsat is required in case an amount is not specified in the bolt11 invoice'.
optionalAmountMsat := uint64(3_000_000)
optionalLabel := "<label>"
sendPaymentRequest := breez_sdk.SendPaymentRequest{
    Bolt11:        bolt11,
    UseTrampoline: useTrampoline,
    AmountMsat:    &optionalAmountMsat,
    Label:         &optionalLabel,
}
response, err := sdk.SendPayment(sendPaymentRequest)
if err != nil {
    return err
}
log.Printf("%#v", response)
C#
var bolt11 = "...";
var useTrampoline = true;
ulong optionalAmountMsat = 3_000_000;
var optionalLabel = "<label>";


try
{
    // The `amountMsat` param is optional and should only passed if the
    // bolt11 doesn't specify an amount.
    // The amountMsat is required in case an amount is not specified in
    // the bolt11 invoice.
    var response = sdk.SendPayment(
        new SendPaymentRequest(bolt11, useTrampoline, optionalAmountMsat, optionalLabel));
}
catch (Exception)
{
    // Handle error
}

Trampoline payments

In the above example, the use_trampoline flag is set to true to enable trampoline payments. With trampoline, pathfinding through the lightning network is outsourced to the LSP.

This has several benefits:

  • The payment is more reliable and faster as the LSP has a better view of the network topology and can find good routes faster.
  • There is less interaction between the user's app and the user's node in the cloud, improving payment speed.
  • Fees for lightning payments are fixed. That means fees can be displayed to the user before paying.

The trade-offs are:

  • The payment is less private as the LSP will learn the payment destination.

To disable trampoline payments, set use_trampoline to false. The user's node will then attempt to find routes directly, without outsourcing pathfinding to the LSP.