Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

feat: add plugin ckb fiber #2084

Open
wants to merge 20 commits into
base: main
Choose a base branch
from
Open
12 changes: 12 additions & 0 deletions .env.example
Original file line number Diff line number Diff line change
Expand Up @@ -373,3 +373,15 @@ FUEL_WALLET_PRIVATE_KEY=
# Tokenizer Settings
TOKENIZER_MODEL= # Specify the tokenizer model to be used.
TOKENIZER_TYPE= # Options: tiktoken (for OpenAI models) or auto (AutoTokenizer from Hugging Face for non-OpenAI models). Default: tiktoken.

# CKB Fiber Configuration
FIBER_ENABLE=true

FIBER_RPC_URL= # RPC url of your Fiber node, anyone can control the Fiber node through this RPC, so make sure that the RPC url cannot be accessed externally. Default is http://127.0.0.1:8227
FIBER_RPC_HEADERS= # (Optional) The headers of the Fiber RPC (JSON string). It is used to authenticate the Fiber RPC if needed

FIBER_DEFAULT_PEER_ID=QmeiL6iR7EvxFM6vkRufj9SbKfiRPHcfofMQfoEFgUJ3Qe # The default peer id of the Fiber node, it is used to connect to the Fiber network, you can get it from https://testnet.explorer.nervos.org/fiber/graph/nodes
FIBER_DEFAULT_PEER_ADDRESS=/ip4/127.0.0.1/tcp/8230/p2p/QmeiL6iR7EvxFM6vkRufj9SbKfiRPHcfofMQfoEFgUJ3Qe # The default peer address of the Fiber node, it is used to connect to the Fiber network, you can get it from https://testnet.explorer.nervos.org/fiber/graph/nodes

FIBER_CKB_FUNDING_AMOUNT= # (Optional) The default funding amount when open the default channel
FIBER_UDT_FUNDING_AMOUNTS= # (Optional) The default funding udt amounts (JSON string) when open the default channel
1 change: 1 addition & 0 deletions .gitignore
Original file line number Diff line number Diff line change
Expand Up @@ -55,3 +55,4 @@ coverage
.eslintcache

agent/content
/key/
1 change: 1 addition & 0 deletions agent/package.json
Original file line number Diff line number Diff line change
Expand Up @@ -61,6 +61,7 @@
"@elizaos/plugin-fuel": "workspace:*",
"@elizaos/plugin-avalanche": "workspace:*",
"@elizaos/plugin-web-search": "workspace:*",
"@elizaos/plugin-ckb-fiber": "workspace:*",
"readline": "1.3.0",
"ws": "8.18.0",
"yargs": "17.7.2"
Expand Down
4 changes: 4 additions & 0 deletions agent/src/index.ts
Original file line number Diff line number Diff line change
Expand Up @@ -64,6 +64,7 @@ import { abstractPlugin } from "@elizaos/plugin-abstract";
import { avalanchePlugin } from "@elizaos/plugin-avalanche";
import { webSearchPlugin } from "@elizaos/plugin-web-search";
import { echoChamberPlugin } from "@elizaos/plugin-echochambers";
import { ckbFiberPlugin } from "@elizaos/plugin-ckb-fiber";
import Database from "better-sqlite3";
import fs from "fs";
import path from "path";
Expand Down Expand Up @@ -609,6 +610,9 @@ export async function createAgent(
getSecret(character, "ECHOCHAMBERS_API_KEY")
? echoChamberPlugin
: null,
getSecret(character, "FIBER_ENABLE")
? ckbFiberPlugin
: null,
].filter(Boolean),
providers: [],
actions: [],
Expand Down
2 changes: 1 addition & 1 deletion characters/trump.character.json
Original file line number Diff line number Diff line change
@@ -1,6 +1,6 @@
{
"name": "trump",
"clients": [],
"clients": ["discord"],
FiberInEliza marked this conversation as resolved.
Show resolved Hide resolved
"modelProvider": "openai",
"settings": {
"secrets": {},
Expand Down
11 changes: 11 additions & 0 deletions packages/plugin-ckb-fiber/.env.example
Original file line number Diff line number Diff line change
@@ -0,0 +1,11 @@
# CKB Fiber Configuration
FIBER_ENABLE=true

FIBER_RPC_URL= # RPC url of your Fiber node, anyone can control the Fiber node through this RPC, so make sure that the RPC url cannot be accessed externally. Default is http://127.0.0.1:8227
FIBER_RPC_HEADERS= # (Optional) The headers of the Fiber RPC (JSON string). It is used to authenticate the Fiber RPC if needed

FIBER_DEFAULT_PEER_ID=QmeiL6iR7EvxFM6vkRufj9SbKfiRPHcfofMQfoEFgUJ3Qe # The default peer id of the Fiber node, it is used to connect to the Fiber network, you can get it from https://testnet.explorer.nervos.org/fiber/graph/nodes
FIBER_DEFAULT_PEER_ADDRESS=/ip4/127.0.0.1/tcp/8230/p2p/QmeiL6iR7EvxFM6vkRufj9SbKfiRPHcfofMQfoEFgUJ3Qe # The default peer address of the Fiber node, it is used to connect to the Fiber network, you can get it from https://testnet.explorer.nervos.org/fiber/graph/nodes

FIBER_CKB_FUNDING_AMOUNT= # (Optional) The default funding amount when open the default channel
FIBER_UDT_FUNDING_AMOUNTS= # (Optional) The default funding udt amounts (JSON string) when open the default channel
1 change: 1 addition & 0 deletions packages/plugin-ckb-fiber/.gitignore
Original file line number Diff line number Diff line change
@@ -0,0 +1 @@
.idea
6 changes: 6 additions & 0 deletions packages/plugin-ckb-fiber/.npmignore
Original file line number Diff line number Diff line change
@@ -0,0 +1,6 @@
*

!dist/**
!package.json
!readme.md
!tsup.config.ts
133 changes: 133 additions & 0 deletions packages/plugin-ckb-fiber/README.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,133 @@
# CKB Fiber Plugin
[Fiber](https://github.com/nervosnetwork/fiber) is a type of Lightning Network that enables AI Agents to make stablecoin payments using the Lightning Network. This PR introduces a new plugin: the CKB Fiber Plugin, enabling the Eliza agent to interact with the Fiber Network by managing a Fiber node. We implemented a standalone Fiber Network RPC client and developed a series of actions within the Eliza framework. These actions leverage the RPC client to send RPC requests and facilitate communication with the Fiber node.

# Configuration
The plugin requires the following environment variables:
``` env
# CKB Fiber Configuration
FIBER_ENABLE=true

FIBER_RPC_URL= # RPC url of your Fiber node, anyone can control the Fiber node through this RPC, so make sure that the RPC url cannot be accessed externally. Default is http://127.0.0.1:8227
FIBER_RPC_HEADERS= # (Optional) The headers of the Fiber RPC (JSON string). It is used to authenticate the Fiber RPC if needed

FIBER_DEFAULT_PEER_ID=QmSqSsbjkQG6aMBNEkG6hMLKQpMjLW3eaBmUdCghpRWqwJ # The default peer id of the Fiber node, it is used to connect to the Fiber network, you can get it from https://testnet.explorer.nervos.org/fiber/graph/nodes
FIBER_DEFAULT_PEER_ADDRESS=/ip4/43.198.162.23/tcp/8228/p2p/QmSqSsbjkQG6aMBNEkG6hMLKQpMjLW3eaBmUdCghpRWqwJ # The default peer address of the Fiber node, it is used to connect to the Fiber network, you can get it from https://testnet.explorer.nervos.org/fiber/graph/nodes

FIBER_CKB_FUNDING_AMOUNT= # (Optional) The default funding amount when open the default channel
FIBER_UDT_FUNDING_AMOUNTS= # (Optional) The default funding udt amounts (JSON string) when open the default channel
```
You can check the default values in `src/constants.ts`

# Available Actions

1. **GET_INFO**: Retrieves the current node information from the agent-controlled Fiber node.

2. **LIST_CHANNELS**: Lists all the opened channels of the agent-controlled Fiber node.

3. **SEND_PAYMENT**: Given an invoice, payment amount, and asset type (CKB, USDI, or RUSD) in the context, the agent-controlled Fiber node will verify and send the payment.

4. **GET_PAYMENT**: Given a specific payment hash, retrieves the payment details.

5. **NEW_INVOICE**: Given an amount and asset type (CKB, USDI, or RUSD), the agent generates a new invoice, enabling others to send funds to the agent-controlled Fiber node.

# Cautions & Notes
- **Start Your Fiber Node:** Before using the CKB Fiber Plugin, ensure that your Fiber node is up and running. The Fiber node should be connected to the Fiber network and have sufficient channels opened to facilitate payment transactions. Check [nervosnetwork/fiber](https://github.com/nervosnetwork/fiber) for more information.

- **Network Access Control:** If the Fiber node’s RPC URL is exposed to the external network without proper access control, there could be potential unauthorized access. Ensure the RPC URL is secured or only accessible within the local network to avoid unintended exposure.

- **Sensitive Actions:** Some actions, such as transfers, involve handling sensitive operations. These actions should be properly secured to prevent users from directly triggering them in inappropriate scenarios (e.g., unauthorized transfers). Ensuring proper access control and validation for these actions is critical.

- **Channel and Network Connectivity:** If the Fiber node is not connected to the network or doesn't have enough channels opened, SEND_PAYMENT action will fail. This could affect the overall functionality and cause disruptions in the intended operations of the Fiber node and Eliza Agent interactions.

# Benefits

### Seamless CKB Integration

- **Native CKB Support**: Effortlessly integrate CKB blockchain functionalities into your applications.
- **Efficient Transaction Handling**: Streamlined processes for sending and receiving CKB transactions.

### Robust Financial Operations

- **Automated Payment Processing**: Facilitate automated payments for services such as API calls, content generation, and more.
- **Multi-Layer Transaction Support**: Handle both on-chain and Layer 2 transactions for enhanced flexibility and scalability.
- **Real-Time Balance Monitoring**: Keep track of wallet balances with up-to-date information and notifications.

### Flexible Payment Options

- **Multi-Currency Support**: Accept payments in various cryptocurrencies and fiat currencies with automatic conversion.
- **Customizable Fee Structures**: Adjust transaction fees based on real-time market data and user preferences.
- **Recurring Payments**: Set up recurring billing for subscription-based services, ensuring consistent revenue streams.

### Enhanced Security

- **Secure Key Management**: Protect private keys using environment variables and secure storage solutions.
- **Advanced Encryption**: Ensure all sensitive data is encrypted both in transit and at rest to maintain user privacy.

# Implementation Status

### Core CKB Functionality

- Full support for CKB blockchain operations, including transaction creation and validation.
- Integration with CKB's native wallets and APIs for seamless user interactions.

### Fiber Framework Integration

- Seamless incorporation with the Fiber web framework, ensuring high performance and scalability.
- Middleware support for efficient request handling and processing within Fiber applications.

### Payment Processing Features

- Automated payment workflows implemented, enabling smooth financial transactions between agents.
- Support for both on-chain and Layer 2 transactions to cater to different scalability and cost requirements.

### USD Denomination Support

- Enable USD-denominated transactions with automatic cryptocurrency conversion based on real-time exchange rates.
- Integration of real-time price feeds to ensure accurate fee estimation and financial reporting.

### Upcoming Features

- **Enhanced Analytics**: Development of advanced dashboards for monitoring transaction metrics and user activity (planned).
- **Extended Protocol Support**: Ongoing work to integrate additional blockchain protocols, expanding the plugin's versatility and applicability.

<!--
- [x] **Payment Actions:** Implement actions to send and receive payments using the Fiber Network.
- [ ] **Channel Management:** Implement actions to manage channels, including opening, closing, and updating channels.
- [ ] **CKB functionality:** Implement actions to interact with CKB, such as querying balances, sending CKB transactions, and managing UDTs.
- [ ] **Payment History:** Implement actions to retrieve payment history and details for the agent-controlled Fiber node.
- [ ] **Authorization and Access Control:** Because some actions involve sensitive operations, implementing proper authorization and access control mechanisms is essential.
-->

# Testing
``` bash
cd packages/plugin-ckb-fiber
pnpm test
```

# Usage

## Integration

``` typescript

// Assume this is the user's message received by the client
const message: Memory = {
id: stringToUuid(
Date.now() + "-" + runtime.agentId
),
userId: runtime.agentId,
agentId: runtime.agentId,
content: {
text: "Send me 60 USDI, my invoice is: fibt600000001pp8msdlfq6gqzg7dwfhddw3x46u2xydkgzm2e37kp6dr75yakkemrxjm67xjucccgj7hz46reg9m90gvax25pgfcrerysr67fesg34zzsu895nns8g78ua6x23f3w9xjyfzwht9grq5aa2vwaz0gaaxme6dqxfypk3g02753fc0a6e4e4jx7r982qv282mutcw8zzrx3y992av365sfv2pgpschnwn5wv3lglel8x96adqemcsp9j0l2rfue2rvp9yj60320wdewqj8aln2c3dh04s30nxg0hn0vufhdj8gkcvt5h4h8gfr02k8x6rnyulnlqgt5gqzmhkchn6tcqtgk0zkglgrl0wg8ede99gv204rgsqqjge9mq07u23f7vxfcdzpm57rt72359vp0yad9pkl5ttae44vxd5rzq09m2w8rc0ydryljywvgqj2gq0d",
action: "SEND_PAYMENT",
},
roomId: runtime.agentId,
embedding: getEmbeddingZeroVector(),
createdAt: Date.now(),
};

// Process the message, it will trigger the SEND_PAYMENT action
// callback is a function to handle the response (e.g., send the response back to the user)
runtime.processActions(message, [], state, callback)

```
3 changes: 3 additions & 0 deletions packages/plugin-ckb-fiber/eslint.config.mjs
Original file line number Diff line number Diff line change
@@ -0,0 +1,3 @@
import eslintGlobalConfig from "../../eslint.config.mjs";

export default [...eslintGlobalConfig];
26 changes: 26 additions & 0 deletions packages/plugin-ckb-fiber/package.json
Original file line number Diff line number Diff line change
@@ -0,0 +1,26 @@
{
"name": "@elizaos/plugin-ckb-fiber",
"version": "0.1.0",
"main": "dist/index.js",
"type": "module",
"types": "dist/index.d.ts",
"dependencies": {
"@elizaos/core": "workspace:*",
"@ckb-ccc/core": "^0.1.0-alpha.4"
},
"devDependencies": {
"tsup": "8.3.5",
"axios": "1.7.8",
"zod": "3.23.8",
"@types/node": "^20.0.0",
"@vitest/coverage-v8": "^0.34.6",
"vitest": "^0.34.6"
},
"scripts": {
"build": "tsup --format esm --dts",
"dev": "tsup --format esm --dts --watch",
"lint": "eslint --fix --cache plugin",

"test": "vitest"
}
}
61 changes: 61 additions & 0 deletions packages/plugin-ckb-fiber/src/actions/getInfo.ts
Original file line number Diff line number Diff line change
@@ -0,0 +1,61 @@
import {
Action,
IAgentRuntime,
Memory,
HandlerCallback,
State,
elizaLogger,
} from "@elizaos/core";

import {CKBFiberService, ServiceTypeCKBFiber} from "../ckb/fiber/service.ts";
import {formatNodeInfo} from "../ckb/fiber/formatter.ts";

export const getInfo: Action = {
name: "GET_NODE_INFO",
similes: ["GET_NODE", "GET_INFO", "SHOW_INFO", "SHOW_NODE"],
description: "Get fiber node information",
validate: async (runtime: IAgentRuntime, _message: Memory) => {
if (!await runtime.getService<CKBFiberService>(ServiceTypeCKBFiber)?.checkNode())
return false
return true;
},
handler: async (
runtime: IAgentRuntime,
_message: Memory,
state: State,
_options: any,
callback: HandlerCallback
) => {
try {
const service = runtime.getService<CKBFiberService>(ServiceTypeCKBFiber);
const nodeInfo = await service.rpcClient.getNodeInfo();
const formattedInfo = formatNodeInfo(nodeInfo);

callback({ text: formattedInfo, action: "LIST_CHANNELS" }, []);
} catch (error) {
elizaLogger.error("Error getting node info:", error);
callback(
{ text: "Fail to get node information. Please try again later." },
[]
);
}
},
examples: [
[
{
user: "{{user1}}",
content: {
text: "Get your node information",
},
},
],
[
{
user: "{{user1}}",
content: {
text: "Show your node info",
},
}
],
],
};
Loading
Loading