Flutter集成Breez平台插件breez_sdk的使用

Flutter集成Breez平台插件breez_sdk的使用

pub package

目录

描述

这是一个封装了Breez SDK Dart绑定的Flutter插件。

Android iOS
支持 SDK 21+ 12.0+

概述

Breez SDK使开发者能够以非常低的学习曲线将闪电网络和比特币支付集成到他们的应用中。应用场景广泛——从希望在用户之间实现打赏功能的社会应用到希望通过添加比特币变现功能的内容创作应用。关键在于,这是一个端到端、非托管的解决方案,由内置的LSP(Lightning Service Provider)Greenlight、链上互操作性、第三方法币接入等服务支持。Breez SDK对开发者免费。

Breez SDK提供了以下服务:

  • 通过各种协议发送付款(如bolt11、keysend、lnurl-pay、闪电地址等)
  • 通过各种协议接收付款(如bolt11、lnurl-withdraw等)
  • 获取节点状态(如余额、最大允许支付金额、最大允许接收金额、链上余额等)
  • 连接到新节点或现有节点

更多详情请参阅文档

安装

要使用此插件,你需要在pubspec.yaml文件中添加breez_sdk作为依赖项。

dependencies:
  breez_sdk: ^<latest_version>

运行flutter pub get以获取最新的包。

使用

首先,在你的Dart文件中导入该包。

import 'package:breez_sdk/breez_sdk.dart';

建议在整个应用中只使用一个BreezSDK()实例。假设示例中的breezSDK变量指向这个实例:

首先检查Breez节点服务是否已初始化,可以通过调用isInitialized()方法来实现,然后调用initialize()方法来初始化Breez SDK的事件和日志流,最好在main.dart文件中进行。

if (!await breezSDK.isInitialized()) {
  await breezSDK.initialize();
}

更多关于Flutter集成Breez平台插件breez_sdk的使用的实战教程也可以访问 https://www.itying.com/category-92-b0.html

1 回复

更多关于Flutter集成Breez平台插件breez_sdk的使用的实战系列教程也可以访问 https://www.itying.com/category-92-b0.html


在Flutter应用中集成Breez平台插件breez_sdk,可以让你轻松地与Breez Lightning Network节点进行交互。以下是集成和使用的步骤:

1. 在pubspec.yaml中添加依赖

首先,你需要在pubspec.yaml文件中添加breez_sdk依赖:

dependencies:
  flutter:
    sdk: flutter
  breez_sdk: ^0.1.0  # 请根据实际版本号进行替换

然后运行flutter pub get来获取依赖。

2. 初始化Breez SDK

在你的Flutter应用中,首先需要初始化Breez SDK。通常,你可以在main.dart或某个单独的初始化类中进行初始化。

import 'package:breez_sdk/breez_sdk.dart';

void main() async {
  WidgetsFlutterBinding.ensureInitialized();
  
  // 初始化Breez SDK
  await BreezSDK().initialize(
    config: BreezConfig(
      apiKey: 'YOUR_API_KEY',  // 替换为你的API Key
      environment: Environment.production,  // 或者选择测试环境Environment.testnet
      nodeConfig: NodeConfig(
        nodeType: NodeType.INTERNAL,  // 或者选择外部节点NodeType.EXTERNAL
        nodeAddress: 'YOUR_NODE_ADDRESS',  // 如果是外部节点,需提供地址
      ),
    ),
  );

  runApp(MyApp());
}

3. 使用Breez SDK进行交互

一旦SDK初始化完成,你就可以使用BreezSDK实例来进行各种操作,例如创建发票、发送支付、获取余额等。

创建发票

import 'package:breez_sdk/breez_sdk.dart';

Future<void> createInvoice() async {
  try {
    final invoice = await BreezSDK().createInvoice(
      amountSat: 1000,  // 以satoshi为单位的金额
      description: 'Test Invoice',  // 发票描述
      expirySec: 3600,  // 发票有效期(秒)
    );
    print('Invoice created: ${invoice.paymentRequest}');
  } catch (e) {
    print('Failed to create invoice: $e');
  }
}

发送支付

import 'package:breez_sdk/breez_sdk.dart';

Future<void> sendPayment(String paymentRequest) async {
  try {
    final paymentResult = await BreezSDK().sendPayment(paymentRequest);
    print('Payment sent: ${paymentResult.paymentHash}');
  } catch (e) {
    print('Failed to send payment: $e');
  }
}

获取余额

import 'package:breez_sdk/breez_sdk.dart';

Future<void> getBalance() async {
  try {
    final balance = await BreezSDK().getBalance();
    print('Current balance: ${balance.balanceSat} satoshis');
  } catch (e) {
    print('Failed to get balance: $e');
  }
}

4. 处理回调事件

Breez SDK提供了一些事件回调,你可以监听这些事件来处理例如支付状态变化、节点连接状态等。

import 'package:breez_sdk/breez_sdk.dart';

void setupEventListeners() {
  BreezSDK().onPaymentReceived.listen((payment) {
    print('Payment received: ${payment.paymentHash}');
  });

  BreezSDK().onPaymentSucceeded.listen((payment) {
    print('Payment succeeded: ${payment.paymentHash}');
  });

  BreezSDK().onPaymentFailed.listen((payment) {
    print('Payment failed: ${payment.paymentHash}');
  });
}

5. 清理资源

在应用退出时,确保关闭Breez SDK以释放资源。

import 'package:breez_sdk/breez_sdk.dart';

void dispose() async {
  await BreezSDK().dispose();
}
回到顶部