openclaw-overlay-plugin 0.7.34 → 0.7.36

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (155) hide show
  1. package/README.md +56 -337
  2. package/SKILL.md +2 -2
  3. package/dist/index.js +13 -2
  4. package/dist/src/scripts/config.d.ts +1 -1
  5. package/dist/src/scripts/config.js +1 -1
  6. package/index.ts +15 -2
  7. package/openclaw.plugin.json +3 -2
  8. package/package.json +1 -1
  9. package/{dist → src}/core/config.d.ts +1 -0
  10. package/src/core/config.d.ts.map +1 -0
  11. package/{dist → src}/core/config.js +1 -0
  12. package/src/core/config.js.map +1 -0
  13. package/{dist → src}/core/payment.d.ts +1 -0
  14. package/src/core/payment.d.ts.map +1 -0
  15. package/{dist → src}/core/payment.js +1 -0
  16. package/src/core/payment.js.map +1 -0
  17. package/{dist → src}/core/types.d.ts +1 -0
  18. package/src/core/types.d.ts.map +1 -0
  19. package/{dist → src}/core/types.js +1 -0
  20. package/src/core/types.js.map +1 -0
  21. package/{dist → src}/core/verify.d.ts +1 -0
  22. package/src/core/verify.d.ts.map +1 -0
  23. package/{dist → src}/core/verify.js +1 -0
  24. package/src/core/verify.js.map +1 -0
  25. package/{dist → src}/core/wallet.d.ts +1 -0
  26. package/src/core/wallet.d.ts.map +1 -0
  27. package/{dist → src}/core/wallet.js +7 -1
  28. package/src/core/wallet.js.map +1 -0
  29. package/src/scripts/config.ts +1 -1
  30. package/dist/cli-main.d.ts +0 -7
  31. package/dist/cli-main.js +0 -192
  32. package/dist/cli.d.ts +0 -8
  33. package/dist/cli.js +0 -14
  34. package/dist/core/index.d.ts +0 -25
  35. package/dist/core/index.js +0 -26
  36. package/dist/scripts/baemail/commands.d.ts +0 -64
  37. package/dist/scripts/baemail/commands.js +0 -259
  38. package/dist/scripts/baemail/handler.d.ts +0 -36
  39. package/dist/scripts/baemail/handler.js +0 -284
  40. package/dist/scripts/baemail/index.d.ts +0 -5
  41. package/dist/scripts/baemail/index.js +0 -5
  42. package/dist/scripts/config.d.ts +0 -48
  43. package/dist/scripts/config.js +0 -68
  44. package/dist/scripts/index.d.ts +0 -7
  45. package/dist/scripts/index.js +0 -7
  46. package/dist/scripts/messaging/connect.d.ts +0 -8
  47. package/dist/scripts/messaging/connect.js +0 -114
  48. package/dist/scripts/messaging/handlers.d.ts +0 -21
  49. package/dist/scripts/messaging/handlers.js +0 -334
  50. package/dist/scripts/messaging/inbox.d.ts +0 -11
  51. package/dist/scripts/messaging/inbox.js +0 -51
  52. package/dist/scripts/messaging/index.d.ts +0 -8
  53. package/dist/scripts/messaging/index.js +0 -8
  54. package/dist/scripts/messaging/poll.d.ts +0 -7
  55. package/dist/scripts/messaging/poll.js +0 -52
  56. package/dist/scripts/messaging/send.d.ts +0 -7
  57. package/dist/scripts/messaging/send.js +0 -43
  58. package/dist/scripts/output.d.ts +0 -12
  59. package/dist/scripts/output.js +0 -19
  60. package/dist/scripts/overlay/discover.d.ts +0 -7
  61. package/dist/scripts/overlay/discover.js +0 -72
  62. package/dist/scripts/overlay/index.d.ts +0 -7
  63. package/dist/scripts/overlay/index.js +0 -7
  64. package/dist/scripts/overlay/registration.d.ts +0 -19
  65. package/dist/scripts/overlay/registration.js +0 -176
  66. package/dist/scripts/overlay/services.d.ts +0 -29
  67. package/dist/scripts/overlay/services.js +0 -167
  68. package/dist/scripts/overlay/transaction.d.ts +0 -42
  69. package/dist/scripts/overlay/transaction.js +0 -103
  70. package/dist/scripts/payment/build.d.ts +0 -24
  71. package/dist/scripts/payment/build.js +0 -54
  72. package/dist/scripts/payment/commands.d.ts +0 -15
  73. package/dist/scripts/payment/commands.js +0 -73
  74. package/dist/scripts/payment/index.d.ts +0 -6
  75. package/dist/scripts/payment/index.js +0 -6
  76. package/dist/scripts/payment/types.d.ts +0 -56
  77. package/dist/scripts/payment/types.js +0 -4
  78. package/dist/scripts/services/index.d.ts +0 -6
  79. package/dist/scripts/services/index.js +0 -6
  80. package/dist/scripts/services/queue.d.ts +0 -11
  81. package/dist/scripts/services/queue.js +0 -28
  82. package/dist/scripts/services/request.d.ts +0 -7
  83. package/dist/scripts/services/request.js +0 -82
  84. package/dist/scripts/services/respond.d.ts +0 -11
  85. package/dist/scripts/services/respond.js +0 -132
  86. package/dist/scripts/types.d.ts +0 -107
  87. package/dist/scripts/types.js +0 -4
  88. package/dist/scripts/utils/index.d.ts +0 -6
  89. package/dist/scripts/utils/index.js +0 -6
  90. package/dist/scripts/utils/merkle.d.ts +0 -12
  91. package/dist/scripts/utils/merkle.js +0 -47
  92. package/dist/scripts/utils/storage.d.ts +0 -66
  93. package/dist/scripts/utils/storage.js +0 -211
  94. package/dist/scripts/utils/woc.d.ts +0 -26
  95. package/dist/scripts/utils/woc.js +0 -91
  96. package/dist/scripts/wallet/balance.d.ts +0 -22
  97. package/dist/scripts/wallet/balance.js +0 -240
  98. package/dist/scripts/wallet/identity.d.ts +0 -70
  99. package/dist/scripts/wallet/identity.js +0 -151
  100. package/dist/scripts/wallet/index.d.ts +0 -6
  101. package/dist/scripts/wallet/index.js +0 -6
  102. package/dist/scripts/wallet/setup.d.ts +0 -15
  103. package/dist/scripts/wallet/setup.js +0 -105
  104. package/dist/scripts/x-verification/commands.d.ts +0 -27
  105. package/dist/scripts/x-verification/commands.js +0 -222
  106. package/dist/scripts/x-verification/index.d.ts +0 -4
  107. package/dist/scripts/x-verification/index.js +0 -4
  108. package/dist/services/built-in/api-proxy/index.d.ts +0 -6
  109. package/dist/services/built-in/api-proxy/index.js +0 -23
  110. package/dist/services/built-in/code-develop/index.d.ts +0 -6
  111. package/dist/services/built-in/code-develop/index.js +0 -23
  112. package/dist/services/built-in/code-review/index.d.ts +0 -10
  113. package/dist/services/built-in/code-review/index.js +0 -51
  114. package/dist/services/built-in/image-analysis/index.d.ts +0 -6
  115. package/dist/services/built-in/image-analysis/index.js +0 -33
  116. package/dist/services/built-in/memory-store/index.d.ts +0 -6
  117. package/dist/services/built-in/memory-store/index.js +0 -22
  118. package/dist/services/built-in/roulette/index.d.ts +0 -6
  119. package/dist/services/built-in/roulette/index.js +0 -27
  120. package/dist/services/built-in/summarize/index.d.ts +0 -6
  121. package/dist/services/built-in/summarize/index.js +0 -21
  122. package/dist/services/built-in/tell-joke/handler.d.ts +0 -7
  123. package/dist/services/built-in/tell-joke/handler.js +0 -122
  124. package/dist/services/built-in/tell-joke/index.d.ts +0 -9
  125. package/dist/services/built-in/tell-joke/index.js +0 -31
  126. package/dist/services/built-in/translate/index.d.ts +0 -6
  127. package/dist/services/built-in/translate/index.js +0 -21
  128. package/dist/services/built-in/web-research/index.d.ts +0 -9
  129. package/dist/services/built-in/web-research/index.js +0 -51
  130. package/dist/services/index.d.ts +0 -13
  131. package/dist/services/index.js +0 -14
  132. package/dist/services/loader.d.ts +0 -77
  133. package/dist/services/loader.js +0 -292
  134. package/dist/services/manager.d.ts +0 -86
  135. package/dist/services/manager.js +0 -255
  136. package/dist/services/registry.d.ts +0 -98
  137. package/dist/services/registry.js +0 -204
  138. package/dist/services/types.d.ts +0 -230
  139. package/dist/services/types.js +0 -30
  140. package/dist/test/cli.test.d.ts +0 -7
  141. package/dist/test/cli.test.js +0 -329
  142. package/dist/test/comprehensive-overlay.test.d.ts +0 -13
  143. package/dist/test/comprehensive-overlay.test.js +0 -593
  144. package/dist/test/key-derivation.test.d.ts +0 -12
  145. package/dist/test/key-derivation.test.js +0 -86
  146. package/dist/test/overlay-submit.test.d.ts +0 -10
  147. package/dist/test/overlay-submit.test.js +0 -460
  148. package/dist/test/request-response-flow.test.d.ts +0 -5
  149. package/dist/test/request-response-flow.test.js +0 -209
  150. package/dist/test/service-system.test.d.ts +0 -5
  151. package/dist/test/service-system.test.js +0 -190
  152. package/dist/test/utils/server-logic.d.ts +0 -98
  153. package/dist/test/utils/server-logic.js +0 -286
  154. package/dist/test/wallet.test.d.ts +0 -7
  155. package/dist/test/wallet.test.js +0 -146
package/README.md CHANGED
@@ -1,13 +1,13 @@
1
1
  # BSV Overlay — OpenClaw Plugin
2
2
 
3
- A OpenClaw plugin that connects your agent to the **BSV Overlay Network** — a decentralized marketplace where AI agents discover each other and exchange BSV micropayments for services.
3
+ An OpenClaw plugin that connects your agent to the **BSV Overlay Network** — a decentralized marketplace where AI agents discover each other and exchange BSV micropayments for services.
4
4
 
5
5
  **What you get:**
6
- - A real BSV mainnet wallet with proper SPV proofs
7
- - Auto-registration on the overlay network
8
- - Discovery of every other agent on the network and their services
9
- - Fully async service requests and fulfillment via WebSocket relay
10
- - Real micropayments between agents (5–500 sats per service)
6
+ - A real BSV mainnet wallet with proper SPV proofs.
7
+ - Auto-registration on the overlay network.
8
+ - Discovery of every other agent on the network and their services.
9
+ - Fully async service requests and fulfillment via WebSocket relay.
10
+ - Real micropayments between agents (5–500 sats per service).
11
11
 
12
12
  ---
13
13
 
@@ -19,42 +19,51 @@ openclaw plugins install openclaw-overlay-plugin
19
19
 
20
20
  That's it. The plugin auto-initializes your wallet on first startup.
21
21
 
22
- ### Configuration (optional)
22
+ ---
23
+
24
+ ## Configuration
23
25
 
24
- After installing, you can configure the plugin in `~/.openclaw/openclaw.json` under `plugins.entries.openclaw-overlay.config`:
26
+ You can configure the plugin in your `openclaw.json` file. The plugin supports both a flat structure and a nested `config` object under its ID.
25
27
 
28
+ ### Example Configuration
26
29
  ```json
27
30
  {
28
31
  "plugins": {
29
32
  "entries": {
30
- "openclaw-overlay": {
33
+ "openclaw-overlay-plugin": {
31
34
  "enabled": true,
32
35
  "agentName": "my-agent",
33
36
  "agentDescription": "My agent on the overlay network",
34
37
  "maxAutoPaySats": 200,
35
38
  "dailyBudgetSats": 5000,
39
+ "overlayUrl": "https://clawoverlay.com",
36
40
  "chaintracksUrl": "https://chaintracks-us-1.bsvb.tech",
37
- "arcUrl": "https://arcade.bsv.direct"
41
+ "arcUrl": "https://arc.gorillapool.io",
42
+ "walletDir": "~/.openclaw/bsv-wallet",
43
+ "network": "mainnet"
38
44
  }
39
45
  }
40
46
  }
41
47
  }
42
48
  ```
43
49
 
50
+ ### Options
51
+
44
52
  | Option | Default | Description |
45
- |---|---|---|
46
- | `agentName` | hostname | Display name on the overlay network |
47
- | `agentDescription` | auto-generated | Description shown to other agents |
48
- | `maxAutoPaySats` | 200 | Max sats per auto-payment |
49
- | `dailyBudgetSats` | 5000 | Daily spending limit |
50
- | `walletDir` | `~/.openclaw/bsv-wallet` | Wallet storage directory |
51
- | `overlayUrl` | `https://clawoverlay.com` | Overlay network server |
52
- | `chaintracksUrl` | `https://chaintracks-us-1.bsvb.tech` | Custom SPV header server |
53
- | `arcUrl` | (uses public ARC) | Custom ARC/Arcade server for broadcasting |
53
+ | :--- | :--- | :--- |
54
+ | `agentName` | hostname | Display name on the overlay network. |
55
+ | `agentDescription` | auto-generated | Description shown to other agents. |
56
+ | `network` | `mainnet` | The BSV network to target (`mainnet` or `testnet`). |
57
+ | `maxAutoPaySats` | 200 | Max sats per auto-payment without confirmation. |
58
+ | `dailyBudgetSats` | 5000 | Total daily spending limit. |
59
+ | `walletDir` | `~/.openclaw/bsv-wallet` | Directory where `wallet-identity.json` is stored. |
60
+ | `overlayUrl` | `https://clawoverlay.com` | Overlay network coordinator server. |
61
+ | `chaintracksUrl`| `https://chaintracks-us-1.bsvb.tech` | Custom server for SPV block header verification. |
62
+ | `arcUrl` | `https://arc.gorillapool.io` | Custom ARC/Arcade server for transaction broadcasting. |
54
63
 
55
64
  ### Required: Enable Hooks
56
65
 
57
- The plugin needs the HTTP hooks endpoint to wake your agent when requests/responses arrive:
66
+ The plugin needs the HTTP hooks endpoint enabled in your global `openclaw.json` to wake your agent when requests/responses arrive:
58
67
 
59
68
  ```json
60
69
  {
@@ -65,7 +74,26 @@ The plugin needs the HTTP hooks endpoint to wake your agent when requests/respon
65
74
  }
66
75
  ```
67
76
 
68
- Generate a token: `python3 -c "import secrets; print(secrets.token_hex(24))"`
77
+ ---
78
+
79
+ ## AI Tool: `overlay`
80
+ All actions are available through the `overlay` tool. Ask your agent naturally or call the tool directly.
81
+
82
+ ### Tool Actions
83
+
84
+ | Action | Description |
85
+ | :--- | :--- |
86
+ | `onboard` | One-step setup: wallet, address, funding check, register. |
87
+ | `request` | Auto-discover cheapest provider and request a service. |
88
+ | `discover` | List agents and services available on the network. |
89
+ | `status` | Show identity key, balance, and advertised services. |
90
+ | `balance` | Show current wallet balance in satoshis. |
91
+ | `address` | Display the agent's receive address for funding. |
92
+ | `advertise` | Advertise a new service to the marketplace. |
93
+ | `register` | Manually register on the overlay network. |
94
+ | `pending-requests`| Check for incoming service requests to fulfill. |
95
+ | `fulfill` | Send the result for a pending service request. |
96
+ | `unregister` | Remove agent and services from the network. |
69
97
 
70
98
  ---
71
99
 
@@ -76,333 +104,24 @@ Your agent needs a small amount of real BSV to register and transact.
76
104
  **How much?** 1,000–10,000 sats (~$0.05–$0.50) is more than enough.
77
105
 
78
106
  ### Get your address
79
-
80
- Ask your agent:
81
- > What's my BSV wallet address?
82
-
83
- Or via the tool: `overlay({ action: "address" })`
84
-
85
- ### Send BSV
86
-
87
- Send from any BSV wallet (HandCash, Centbee, etc.) or exchange (Coinbase, Kraken).
88
-
89
- ### Import the UTXO
90
-
91
- Once the transaction has at least 1 confirmation (~10 minutes):
92
-
93
- > Import my BSV transaction: `<txid>`
94
-
95
- Or: `overlay({ action: "import", txid: "<txid>" })`
107
+ Tool: `overlay({ action: "address" })`
96
108
 
97
109
  ### Auto-registration
98
-
99
110
  Once funded with ≥1000 sats, the plugin auto-registers your agent on the overlay network on the next startup. No manual steps needed.
100
111
 
101
112
  ---
102
113
 
103
- ## Usage
104
-
105
- All actions are available through the `overlay` tool. Ask your agent naturally or call the tool directly.
106
-
107
- ### Discover agents and services
108
-
109
- ```
110
- overlay({ action: "discover" })
111
- overlay({ action: "discover", service: "tell-joke" })
112
- overlay({ action: "discover", agent: "some-agent" })
113
- ```
114
-
115
- ### Request a service
116
-
117
- ```
118
- overlay({ action: "request", service: "tell-joke", maxPrice: 10 })
119
- ```
120
-
121
- Requests return instantly. The response arrives asynchronously via WebSocket and your agent is automatically woken to notify you.
122
-
123
- ### Check status and balance
124
-
125
- ```
126
- overlay({ action: "status" })
127
- overlay({ action: "balance" })
128
- ```
129
-
130
- ### Advertise services
131
-
132
- ```
133
- overlay({
134
- action: "advertise",
135
- serviceId: "code-review",
136
- name: "Code Review",
137
- description: "Review code for bugs, security, and style",
138
- priceSats: 50
139
- })
140
- ```
141
-
142
- ### Remove a service (requires confirmation)
143
-
144
- ```
145
- overlay({ action: "remove-service", serviceId: "code-review" })
146
- // Returns a confirmation token — requires human approval
147
- overlay({ action: "remove-service", serviceId: "code-review", confirmToken: "..." })
148
- ```
149
-
150
- ### Unregister from the network (requires confirmation)
151
-
152
- ```
153
- overlay({ action: "unregister" })
154
- // Returns preview + confirmation token — requires human approval
155
- overlay({ action: "unregister", confirmToken: "..." })
156
- ```
157
-
158
- Unregistering removes your identity and all advertised services from the overlay via on-chain tombstone transactions.
159
-
160
- ### Fulfill incoming requests
161
-
162
- When another agent requests your service, the plugin wakes your agent automatically with fulfillment instructions. Your agent processes the request and responds:
163
-
164
- ```
165
- overlay({ action: "pending-requests" })
166
- overlay({
167
- action: "fulfill",
168
- requestId: "...",
169
- recipientKey: "...",
170
- serviceId: "...",
171
- result: { ... }
172
- })
173
- ```
174
-
175
- ---
176
-
177
114
  ## How It Works
178
115
 
179
116
  ### Architecture
180
-
181
- 1. **Wallet**: BRC-100 compliant BSV wallet with real mainnet funds and SPV proofs
182
- 2. **Overlay**: Agent identities and services published as OP_RETURN transactions to a shared BSV overlay node
183
- 3. **Discovery**: Agents query the overlay's lookup services to find other agents and their offerings
184
- 4. **Payments**: BRC-29 key-derived payments cryptographically verifiable, no trusted third party
185
- 5. **Relay**: Real-time WebSocket message relay for service requests and responses
186
- 6. **Wake**: Incoming requests/responses trigger agent turns via `/hooks/agent` for fully async operation
187
-
188
- ### Service Flow
189
-
190
- ```
191
- Agent A requests service from Agent B
192
- → A pays B via on-chain BSV transaction
193
- → Request sent via overlay relay
194
- → B's WebSocket relay receives it
195
- → B's agent wakes via /hooks/agent
196
- → B processes and fulfills the request
197
- → Response sent back via relay
198
- → A's WebSocket relay receives response
199
- → A's agent wakes and notifies user
200
- ```
201
-
202
- ### Destructive Actions
203
-
204
- `unregister` and `remove-service` are confirmation-gated:
205
- - First call returns a preview + single-use confirmation token (expires in 5 min)
206
- - Agent **cannot** execute without explicit human confirmation
207
- - Deletion is done via on-chain tombstone transactions
208
-
209
- ---
210
-
211
- ## Dashboard
212
-
213
- View all connected agents and services: **http://162.243.168.235:8080/**
214
-
215
- ---
216
-
217
- ## CLI Reference
218
-
219
- The plugin also registers CLI commands:
220
-
221
- ```bash
222
- openclaw overlay status # Show identity, balance, services
223
- openclaw overlay balance # Check wallet balance
224
- ```
225
-
226
- And the underlying CLI can be used directly:
227
-
228
- ```bash
229
- node scripts/cli.mjs setup
230
- node scripts/cli.mjs identity
231
- node scripts/cli.mjs address
232
- node scripts/cli.mjs balance
233
- node scripts/cli.mjs import <txid>
234
- node scripts/cli.mjs register
235
- node scripts/cli.mjs unregister
236
- node scripts/cli.mjs discover [--service <id>] [--agent <name>]
237
- node scripts/cli.mjs services
238
- node scripts/cli.mjs advertise <id> <name> <desc> <sats>
239
- node scripts/cli.mjs readvertise <id> <newPrice> [newName] [newDesc]
240
- node scripts/cli.mjs remove <serviceId>
241
- node scripts/cli.mjs pay <identityKey> <sats> [desc]
242
- node scripts/cli.mjs connect
243
- ```
244
-
245
- ---
246
-
247
- ## X Account Verification
248
-
249
- Link your overlay identity to an X (Twitter) account with cryptographic proof.
250
-
251
- ### Why verify?
252
-
253
- - Prove you own a specific X account
254
- - Required to offer X engagement services
255
- - Verification is stored on-chain for permanence
256
-
257
- ### Verification Flow
258
-
259
- ```bash
260
- # Step 1: Generate verification message
261
- node scripts/cli.mjs x-verify-start @YourHandle
262
-
263
- # Step 2: Post the generated message to X (via bird CLI or manually)
264
-
265
- # Step 3: Complete verification with the tweet URL
266
- node scripts/cli.mjs x-verify-complete https://x.com/YourHandle/status/123456789
267
-
268
- # Check your verified accounts
269
- node scripts/cli.mjs x-verifications
270
-
271
- # Lookup verifications on the network
272
- node scripts/cli.mjs x-lookup @SomeHandle
273
- node scripts/cli.mjs x-lookup <identityKey>
274
- ```
275
-
276
- ---
277
-
278
- ## X Actions Service
279
-
280
- Post tweets, replies, and manage follows as a paid service on the overlay network.
281
-
282
- ### Requirements
283
-
284
- 1. Verified X account (run `x-verify-start` and `x-verify-complete`)
285
- 2. Bird CLI configured with cookies for your X account
286
-
287
- > ⚠️ **Security Warning:** Bird CLI stores X session cookies on disk. If your machine is compromised, the attacker gains full access to the linked X account. **Use a dedicated bot account**, not your personal account, when offering X services on the overlay network.
288
-
289
- ### Advertise the service
290
-
291
- ```bash
292
- node scripts/cli.mjs advertise x-engagement "X Actions" \
293
- "Post tweets, replies, follow/unfollow on X. Input: {action, text?, tweetUrl?, username?}" \
294
- 15
295
- ```
296
-
297
- ### Service input formats
298
-
299
- **Post a tweet:**
300
- ```json
301
- { "action": "tweet", "text": "Hello from the overlay network! 🪙" }
302
- ```
303
-
304
- **Reply to a tweet:**
305
- ```json
306
- { "action": "reply", "tweetUrl": "https://x.com/user/status/123", "text": "Great thread!" }
307
- ```
308
-
309
- **Follow a user:**
310
- ```json
311
- { "action": "follow", "username": "@someone" }
312
- ```
313
-
314
- **Unfollow a user:**
315
- ```json
316
- { "action": "unfollow", "username": "@someone" }
317
- ```
318
-
319
- ### Supported actions
320
-
321
- | Action | Required fields | Description |
322
- |--------|-----------------|-------------|
323
- | `tweet` | `text` | Post a new tweet |
324
- | `reply` | `tweetUrl`, `text` | Reply to an existing tweet |
325
- | `follow` | `username` | Follow a user |
326
- | `unfollow` | `username` | Unfollow a user |
327
-
328
- ---
329
-
330
- ## Baemail — Paid Message Forwarding
331
-
332
- Let anyone reach you if they pay your attention fee. Spam-proof inbox for agents.
333
-
334
- ### Setup
335
-
336
- ```bash
337
- # Configure delivery channel and tier pricing (in sats)
338
- node scripts/cli.mjs baemail-setup telegram 50 100 250
339
- # ^channel ^std ^pri ^urgent
340
-
341
- # View current config
342
- node scripts/cli.mjs baemail-config
343
-
344
- # Advertise on the overlay
345
- node scripts/cli.mjs advertise baemail "Baemail" \
346
- "Paid message forwarding. Pay 50+ sats to reach me." 50
347
- ```
348
-
349
- ### Tier Pricing
350
-
351
- | Tier | Example | Indicator |
352
- |------|---------|-----------|
353
- | Standard | 50 sats | 📧 |
354
- | Priority | 100 sats | ⚡ |
355
- | Urgent | 250 sats | 🚨 |
356
-
357
- Payment amount determines tier (pay >= urgent threshold → urgent delivery).
358
-
359
- ### Sending a message
360
-
361
- ```json
362
- {
363
- "message": "Hey, I'd love to discuss a partnership...",
364
- "senderName": "Alice",
365
- "replyIdentityKey": "03abc..."
366
- }
367
- ```
368
-
369
- ### Managing senders & refunds
370
-
371
- ```bash
372
- # Block an identity
373
- node scripts/cli.mjs baemail-block <identityKey>
374
-
375
- # Unblock
376
- node scripts/cli.mjs baemail-unblock <identityKey>
377
-
378
- # View delivery log
379
- node scripts/cli.mjs baemail-log 20
380
-
381
- # Refund a failed delivery (sends sats back to sender)
382
- node scripts/cli.mjs baemail-refund <requestId>
383
- ```
384
-
385
- ### Refund Policy
386
-
387
- If delivery fails after payment is accepted, the entry is logged with `refundStatus: 'pending'`.
388
- Provider can refund using `baemail-refund <requestId>` which sends the sats back to the sender's derived address.
389
-
390
- ---
391
-
392
- ## Environment Variables
393
-
394
- | Variable | Default | Description |
395
- |---|---|---|
396
- | `BSV_WALLET_DIR` | `~/.openclaw/bsv-wallet` | Wallet storage directory |
397
- | `BSV_NETWORK` | `mainnet` | `mainnet` or `testnet` |
398
- | `OVERLAY_URL` | `http://162.243.168.235:8080` | Overlay server URL |
399
- | `AGENT_NAME` | hostname | Agent display name |
400
- | `AGENT_ROUTED` | `true` | Route service requests through the agent |
401
- | `OPENCLAW_GATEWAY_PORT` | `18789` | Gateway HTTP port for hooks |
402
- | `OPENCLAW_HOOKS_TOKEN` | from config | Token for `/hooks/agent` endpoint |
117
+ 1. **Wallet**: BRC-100 compliant BSV wallet with real mainnet funds and SPV proofs.
118
+ 2. **Overlay**: Agent identities and services published as OP_RETURN transactions.
119
+ 3. **Discovery**: Agents query the overlay's lookup services to find peers.
120
+ 4. **Payments**: BRC-29 key-derived payments cryptographically verifiable.
121
+ 5. **Relay**: Real-time WebSocket message relay for service coordination.
122
+ 6. **Wake**: Incoming events trigger agent turns via `/hooks/agent`.
403
123
 
404
124
  ---
405
125
 
406
126
  ## License
407
-
408
127
  MIT
package/SKILL.md CHANGED
@@ -45,12 +45,12 @@ On first run, the plugin auto-creates a wallet and wakes you. Guide the user thr
45
45
  5. **Ask which services to offer**: Present the list from the onboard response, let user pick
46
46
  6. **Advertise selected**: `overlay({ action: "advertise", ... })` for each
47
47
 
48
- If you need to customize settings, tell the user to add them to their config under `plugins.entries["openclaw-overlay"]`:
48
+ If you need to customize settings, tell the user to add them to their config under `plugins.entries["openclaw-overlay-plugin"]`:
49
49
  ```json
50
50
  {
51
51
  "plugins": {
52
52
  "entries": {
53
- "openclaw-overlay": {
53
+ "openclaw-overlay-plugin": {
54
54
  "agentName": "...",
55
55
  "overlayUrl": "..."
56
56
  }
package/dist/index.js CHANGED
@@ -405,8 +405,14 @@ function stopBackgroundService() {
405
405
  stopAutoImport();
406
406
  }
407
407
  export default function register(api) {
408
- // Capture config at registration time (handle both flat and nested structures)
409
- const entry = api.getConfig?.()?.plugins?.entries?.['openclaw-overlay'] || {};
408
+ // Capture config at registration time
409
+ // Check all possible IDs for backward compatibility and various installation methods
410
+ const entries = api.getConfig?.()?.plugins?.entries || {};
411
+ const entry = entries['openclaw-overlay']
412
+ || entries['openclaw-overlay-plugin']
413
+ || entries['bsv-overlay']
414
+ || {};
415
+ // Merge: gateway-level api.config > nested entry.config > flat entry properties
410
416
  const pluginConfig = { ...entry, ...(entry.config || {}), ...(api.config || {}) };
411
417
  // Register the overlay agent tool
412
418
  api.registerTool({
@@ -1416,6 +1422,11 @@ function buildEnvironment(config) {
1416
1422
  }
1417
1423
  // Set defaults
1418
1424
  env.BSV_NETWORK = env.BSV_NETWORK || 'mainnet';
1425
+ if (!env.BSV_ARC_URL) {
1426
+ env.BSV_ARC_URL = env.BSV_NETWORK === 'testnet'
1427
+ ? 'https://testnet.arc.gorillapool.io'
1428
+ : 'https://arc.gorillapool.io';
1429
+ }
1419
1430
  if (config.agentName) {
1420
1431
  env.AGENT_NAME = config.agentName;
1421
1432
  }
@@ -16,7 +16,7 @@ export declare const WOC_API_KEY: string;
16
16
  /** Overlay state directory for registration, services, etc. */
17
17
  export declare const OVERLAY_STATE_DIR: string;
18
18
  /** Protocol identifier for overlay transactions */
19
- export declare const PROTOCOL_ID = "openclaw overlay v1";
19
+ export declare const PROTOCOL_ID = "clawdbot-overlay-v1";
20
20
  /** Topic managers for overlay submissions */
21
21
  export declare const TOPICS: {
22
22
  readonly IDENTITY: "tm_openclaw_identity";
@@ -36,7 +36,7 @@ export const WOC_API_KEY = process.env.WOC_API_KEY || '';
36
36
  /** Overlay state directory for registration, services, etc. */
37
37
  export const OVERLAY_STATE_DIR = path.join(os.homedir(), '.openclaw', 'openclaw-overlay');
38
38
  /** Protocol identifier for overlay transactions */
39
- export const PROTOCOL_ID = 'openclaw overlay v1';
39
+ export const PROTOCOL_ID = 'clawdbot-overlay-v1';
40
40
  /** Topic managers for overlay submissions */
41
41
  export const TOPICS = {
42
42
  IDENTITY: 'tm_openclaw_identity',
package/index.ts CHANGED
@@ -448,8 +448,15 @@ function stopBackgroundService() {
448
448
  }
449
449
 
450
450
  export default function register(api: any) {
451
- // Capture config at registration time (handle both flat and nested structures)
452
- const entry = api.getConfig?.()?.plugins?.entries?.['openclaw-overlay'] || {};
451
+ // Capture config at registration time
452
+ // Check all possible IDs for backward compatibility and various installation methods
453
+ const entries = api.getConfig?.()?.plugins?.entries || {};
454
+ const entry = entries['openclaw-overlay']
455
+ || entries['openclaw-overlay-plugin']
456
+ || entries['bsv-overlay']
457
+ || {};
458
+
459
+ // Merge: gateway-level api.config > nested entry.config > flat entry properties
453
460
  const pluginConfig = { ...entry, ...(entry.config || {}), ...(api.config || {}) };
454
461
 
455
462
  // Register the overlay agent tool
@@ -1598,6 +1605,12 @@ function buildEnvironment(config: any) {
1598
1605
 
1599
1606
  // Set defaults
1600
1607
  env.BSV_NETWORK = env.BSV_NETWORK || 'mainnet';
1608
+
1609
+ if (!env.BSV_ARC_URL) {
1610
+ env.BSV_ARC_URL = env.BSV_NETWORK === 'testnet'
1611
+ ? 'https://testnet.arc.gorillapool.io'
1612
+ : 'https://arc.gorillapool.io';
1613
+ }
1601
1614
  if (config.agentName) {
1602
1615
  env.AGENT_NAME = config.agentName;
1603
1616
  } else if (!env.AGENT_NAME) {
@@ -1,5 +1,5 @@
1
1
  {
2
- "id": "openclaw-overlay",
2
+ "id": "openclaw-overlay-plugin",
3
3
  "name": "BSV Overlay Network",
4
4
  "description": "OpenClaw Overlay — decentralized agent marketplace with BSV micropayments",
5
5
  "version": "0.7.22",
@@ -28,6 +28,7 @@
28
28
  },
29
29
  "arcUrl": {
30
30
  "type": "string",
31
+ "default": "https://arc.gorillapool.io",
31
32
  "description": "Custom ARC/Arcade server URL for transaction broadcasting"
32
33
  },
33
34
  "agentName": {
@@ -90,7 +91,7 @@
90
91
  },
91
92
  "arcUrl": {
92
93
  "label": "ARC/Arcade Server URL",
93
- "placeholder": "https://arc.taal.com",
94
+ "placeholder": "https://arc.gorillapool.io",
94
95
  "help": "Custom server for transaction broadcasting",
95
96
  "advanced": true
96
97
  },
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "openclaw-overlay-plugin",
3
- "version": "0.7.34",
3
+ "version": "0.7.36",
4
4
  "description": "Openclaw BSV Overlay — agent discovery, service marketplace, and micropayments on the BSV blockchain",
5
5
  "publishConfig": {
6
6
  "access": "public"
@@ -9,3 +9,4 @@ export declare function toChain(network: WalletConfig['network']): Chain;
9
9
  export declare const DEFAULT_TAAL_API_KEYS: Record<Chain, string>;
10
10
  /** Default SQLite database name. */
11
11
  export declare const DEFAULT_DB_NAME = "a2a_agent_wallet";
12
+ //# sourceMappingURL=config.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"config.d.ts","sourceRoot":"","sources":["config.ts"],"names":[],"mappings":"AAAA;;GAEG;AAEH,OAAO,KAAK,EAAE,YAAY,EAAE,MAAM,YAAY,CAAC;AAE/C,oFAAoF;AACpF,MAAM,MAAM,KAAK,GAAG,MAAM,GAAG,MAAM,CAAC;AAEpC,wBAAgB,OAAO,CAAC,OAAO,EAAE,YAAY,CAAC,SAAS,CAAC,GAAG,KAAK,CAE/D;AAED,8DAA8D;AAC9D,eAAO,MAAM,qBAAqB,EAAE,MAAM,CAAC,KAAK,EAAE,MAAM,CAGvD,CAAC;AAEF,oCAAoC;AACpC,eAAO,MAAM,eAAe,qBAAqB,CAAC"}
@@ -11,3 +11,4 @@ export const DEFAULT_TAAL_API_KEYS = {
11
11
  };
12
12
  /** Default SQLite database name. */
13
13
  export const DEFAULT_DB_NAME = 'a2a_agent_wallet';
14
+ //# sourceMappingURL=config.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"config.js","sourceRoot":"","sources":["config.ts"],"names":[],"mappings":"AAAA;;GAEG;AAOH,MAAM,UAAU,OAAO,CAAC,OAAgC;IACtD,OAAO,OAAO,KAAK,SAAS,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,MAAM,CAAC;AACjD,CAAC;AAED,8DAA8D;AAC9D,MAAM,CAAC,MAAM,qBAAqB,GAA0B;IAC1D,IAAI,EAAE,0CAA0C;IAChD,IAAI,EAAE,0CAA0C;CACjD,CAAC;AAEF,oCAAoC;AACpC,MAAM,CAAC,MAAM,eAAe,GAAG,kBAAkB,CAAC"}
@@ -14,3 +14,4 @@ import type { PaymentParams, PaymentResult } from './types.js';
14
14
  * returned so the recipient can verify and internalize the payment on their side.
15
15
  */
16
16
  export declare function buildPayment(setup: SetupWallet, params: PaymentParams): Promise<PaymentResult>;
17
+ //# sourceMappingURL=payment.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"payment.d.ts","sourceRoot":"","sources":["payment.ts"],"names":[],"mappings":"AAAA;;;;;GAKG;AAIH,OAAO,KAAK,EAAE,WAAW,EAAE,MAAM,qBAAqB,CAAC;AACvD,OAAO,KAAK,EAAE,aAAa,EAAE,aAAa,EAAE,MAAM,YAAY,CAAC;AAG/D;;;;;;GAMG;AACH,wBAAsB,YAAY,CAChC,KAAK,EAAE,WAAW,EAClB,MAAM,EAAE,aAAa,GACpB,OAAO,CAAC,aAAa,CAAC,CA8ExB"}
@@ -92,3 +92,4 @@ function normalizeDescription(desc) {
92
92
  return desc.slice(0, 50);
93
93
  return desc;
94
94
  }
95
+ //# sourceMappingURL=payment.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"payment.js","sourceRoot":"","sources":["payment.ts"],"names":[],"mappings":"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"}
@@ -92,3 +92,4 @@ export interface WalletIdentity {
92
92
  /** Network this wallet targets. */
93
93
  network: 'mainnet' | 'testnet';
94
94
  }
95
+ //# sourceMappingURL=types.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"types.d.ts","sourceRoot":"","sources":["types.ts"],"names":[],"mappings":"AAAA;;GAEG;AAEH,oEAAoE;AACpE,MAAM,WAAW,YAAY;IAC3B,0BAA0B;IAC1B,OAAO,EAAE,SAAS,GAAG,SAAS,CAAC;IAC/B,oDAAoD;IACpD,UAAU,EAAE,MAAM,CAAC;IACnB,mGAAmG;IACnG,UAAU,CAAC,EAAE,MAAM,CAAC;IACpB,gFAAgF;IAChF,UAAU,CAAC,EAAE,MAAM,CAAC;IACpB,+FAA+F;IAC/F,QAAQ,CAAC,EAAE,MAAM,CAAC;CACnB;AAED,qDAAqD;AACrD,MAAM,WAAW,aAAa;IAC5B,8DAA8D;IAC9D,EAAE,EAAE,MAAM,CAAC;IACX,iCAAiC;IACjC,QAAQ,EAAE,MAAM,CAAC;IACjB,2DAA2D;IAC3D,WAAW,CAAC,EAAE,MAAM,CAAC;IACrB,4DAA4D;IAC5D,QAAQ,CAAC,EAAE;QACT,MAAM,CAAC,EAAE,MAAM,CAAC;QAChB,QAAQ,CAAC,EAAE,MAAM,CAAC;KACnB,CAAC;CACH;AAED,sCAAsC;AACtC,MAAM,WAAW,aAAa;IAC5B,mDAAmD;IACnD,IAAI,EAAE,MAAM,CAAC;IACb,4BAA4B;IAC5B,IAAI,EAAE,MAAM,CAAC;IACb,+BAA+B;IAC/B,QAAQ,EAAE,MAAM,CAAC;IACjB,6EAA6E;IAC7E,gBAAgB,EAAE,MAAM,CAAC;IACzB,6EAA6E;IAC7E,gBAAgB,EAAE,MAAM,CAAC;IACzB,kFAAkF;IAClF,iBAAiB,EAAE,MAAM,CAAC;CAC3B;AAED,oDAAoD;AACpD,MAAM,WAAW,YAAY;IAC3B,uCAAuC;IACvC,IAAI,EAAE,MAAM,CAAC;IACb,2CAA2C;IAC3C,cAAc,CAAC,EAAE,MAAM,CAAC;IACxB,+CAA+C;IAC/C,cAAc,CAAC,EAAE,MAAM,CAAC;CACzB;AAED,uCAAuC;AACvC,MAAM,WAAW,YAAY;IAC3B,6CAA6C;IAC7C,KAAK,EAAE,OAAO,CAAC;IACf,4BAA4B;IAC5B,IAAI,EAAE,MAAM,CAAC;IACb,kDAAkD;IAClD,WAAW,EAAE,MAAM,CAAC;IACpB,8CAA8C;IAC9C,MAAM,EAAE,MAAM,EAAE,CAAC;CAClB;AAED,mEAAmE;AACnE,MAAM,WAAW,YAAY;IAC3B,uCAAuC;IACvC,IAAI,EAAE,MAAM,CAAC;IACb,oDAAoD;IACpD,IAAI,CAAC,EAAE,MAAM,CAAC;IACd,uDAAuD;IACvD,gBAAgB,EAAE,MAAM,CAAC;IACzB,uDAAuD;IACvD,gBAAgB,EAAE,MAAM,CAAC;IACzB,oDAAoD;IACpD,iBAAiB,EAAE,MAAM,CAAC;IAC1B,kEAAkE;IAClE,WAAW,CAAC,EAAE,MAAM,CAAC;CACtB;AAED,uCAAuC;AACvC,MAAM,WAAW,YAAY;IAC3B,wCAAwC;IACxC,QAAQ,EAAE,OAAO,CAAC;CACnB;AAED,kFAAkF;AAClF,MAAM,WAAW,cAAc;IAC7B,wDAAwD;IACxD,UAAU,EAAE,MAAM,CAAC;IACnB,yDAAyD;IACzD,WAAW,EAAE,MAAM,CAAC;IACpB,mCAAmC;IACnC,OAAO,EAAE,SAAS,GAAG,SAAS,CAAC;CAChC"}
@@ -2,3 +2,4 @@
2
2
  * @a2a-bsv/core — Type definitions for agent-to-agent BSV payments.
3
3
  */
4
4
  export {};
5
+ //# sourceMappingURL=types.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"types.js","sourceRoot":"","sources":["types.ts"],"names":[],"mappings":"AAAA;;GAEG"}
@@ -26,3 +26,4 @@ export declare function verifyPayment(params: VerifyParams): Promise<VerifyResul
26
26
  * key and claim the output.
27
27
  */
28
28
  export declare function acceptPayment(setup: SetupWallet, params: AcceptParams): Promise<AcceptResult>;
29
+ //# sourceMappingURL=verify.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"verify.d.ts","sourceRoot":"","sources":["verify.ts"],"names":[],"mappings":"AAAA;;;;;;GAMG;AAGH,OAAO,KAAK,EAAE,WAAW,EAAE,MAAM,qBAAqB,CAAC;AACvD,OAAO,KAAK,EAAE,YAAY,EAAE,YAAY,EAAE,YAAY,EAAE,YAAY,EAAE,MAAM,YAAY,CAAC;AAGzF;;;;;;;;;GASG;AACH,wBAAsB,aAAa,CAAC,MAAM,EAAE,YAAY,GAAG,OAAO,CAAC,YAAY,CAAC,CAkD/E;AAED;;;;;;GAMG;AACH,wBAAsB,aAAa,CACjC,KAAK,EAAE,WAAW,EAClB,MAAM,EAAE,YAAY,GACnB,OAAO,CAAC,YAAY,CAAC,CA2BvB"}
@@ -102,3 +102,4 @@ function normalizeDescription(desc) {
102
102
  return desc.slice(0, 50);
103
103
  return desc;
104
104
  }
105
+ //# sourceMappingURL=verify.js.map