@hashgraphonline/standards-agent-kit 0.0.38 → 0.2.1

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 (252) hide show
  1. package/README.md +137 -170
  2. package/dist/cjs/builders/hcs10/hcs10-builder.d.ts +262 -0
  3. package/dist/cjs/builders/index.d.ts +2 -0
  4. package/dist/cjs/builders/types.d.ts +10 -0
  5. package/dist/cjs/index.d.ts +3 -1
  6. package/dist/cjs/init/init.d.ts +21 -22
  7. package/dist/cjs/plugins/PluginInterface.d.ts +4 -80
  8. package/dist/cjs/plugins/PluginRegistry.d.ts +1 -47
  9. package/dist/cjs/plugins/defi/index.d.ts +7 -4
  10. package/dist/cjs/plugins/hedera/HbarPricePlugin.d.ts +7 -35
  11. package/dist/cjs/plugins/index.d.ts +0 -5
  12. package/dist/cjs/plugins/weather/index.d.ts +6 -5
  13. package/dist/cjs/standards-agent-kit.cjs +1 -1
  14. package/dist/cjs/standards-agent-kit.cjs.map +1 -1
  15. package/dist/cjs/state/state-types.d.ts +8 -8
  16. package/dist/cjs/tools/hcs10/AcceptConnectionRequestTool.d.ts +40 -0
  17. package/dist/cjs/tools/hcs10/CheckMessagesTool.d.ts +40 -0
  18. package/dist/cjs/tools/hcs10/ConnectionMonitorTool.d.ts +134 -0
  19. package/dist/cjs/tools/hcs10/FindRegistrationsTool.d.ts +34 -0
  20. package/dist/cjs/tools/hcs10/InitiateConnectionTool.d.ts +43 -0
  21. package/dist/cjs/tools/hcs10/ListConnectionsTool.d.ts +34 -0
  22. package/dist/cjs/tools/hcs10/ListUnapprovedConnectionRequestsTool.d.ts +15 -0
  23. package/dist/cjs/tools/hcs10/ManageConnectionRequestsTool.d.ts +34 -0
  24. package/dist/cjs/tools/hcs10/RegisterAgentTool.d.ts +218 -0
  25. package/dist/cjs/tools/hcs10/RetrieveProfileTool.d.ts +33 -0
  26. package/dist/cjs/tools/hcs10/SendMessageToConnectionTool.d.ts +40 -0
  27. package/dist/cjs/tools/hcs10/base-hcs10-tools.d.ts +28 -0
  28. package/dist/cjs/tools/hcs10/hcs10-tool-params.d.ts +18 -0
  29. package/dist/cjs/tools/hcs10/index.d.ts +13 -0
  30. package/dist/cjs/tools/index.d.ts +1 -13
  31. package/dist/es/builders/hcs10/hcs10-builder.d.ts +262 -0
  32. package/dist/es/builders/index.d.ts +2 -0
  33. package/dist/es/builders/types.d.ts +10 -0
  34. package/dist/es/index.d.ts +3 -1
  35. package/dist/es/init/init.d.ts +21 -22
  36. package/dist/es/plugins/PluginInterface.d.ts +4 -80
  37. package/dist/es/plugins/PluginRegistry.d.ts +1 -47
  38. package/dist/es/plugins/defi/index.d.ts +7 -4
  39. package/dist/es/plugins/hedera/HbarPricePlugin.d.ts +7 -35
  40. package/dist/es/plugins/index.d.ts +0 -5
  41. package/dist/es/plugins/weather/index.d.ts +6 -5
  42. package/dist/es/standards-agent-kit.es.js +10 -18
  43. package/dist/es/standards-agent-kit.es.js.map +1 -1
  44. package/dist/es/standards-agent-kit.es10.js +29 -76
  45. package/dist/es/standards-agent-kit.es10.js.map +1 -1
  46. package/dist/es/standards-agent-kit.es11.js +61 -384
  47. package/dist/es/standards-agent-kit.es11.js.map +1 -1
  48. package/dist/es/standards-agent-kit.es12.js +22 -190
  49. package/dist/es/standards-agent-kit.es12.js.map +1 -1
  50. package/dist/es/standards-agent-kit.es13.js +26 -138
  51. package/dist/es/standards-agent-kit.es13.js.map +1 -1
  52. package/dist/es/standards-agent-kit.es14.js +35 -59
  53. package/dist/es/standards-agent-kit.es14.js.map +1 -1
  54. package/dist/es/standards-agent-kit.es15.js +11 -117
  55. package/dist/es/standards-agent-kit.es15.js.map +1 -1
  56. package/dist/es/standards-agent-kit.es16.js +1 -1
  57. package/dist/es/standards-agent-kit.es16.js.map +1 -1
  58. package/dist/es/standards-agent-kit.es17.js +63 -46
  59. package/dist/es/standards-agent-kit.es17.js.map +1 -1
  60. package/dist/es/standards-agent-kit.es18.js +25 -74
  61. package/dist/es/standards-agent-kit.es18.js.map +1 -1
  62. package/dist/es/standards-agent-kit.es19.js +22 -13
  63. package/dist/es/standards-agent-kit.es19.js.map +1 -1
  64. package/dist/es/standards-agent-kit.es2.js +1381 -188
  65. package/dist/es/standards-agent-kit.es2.js.map +1 -1
  66. package/dist/es/standards-agent-kit.es20.js +3 -67
  67. package/dist/es/standards-agent-kit.es20.js.map +1 -1
  68. package/dist/es/standards-agent-kit.es3.js +285 -347
  69. package/dist/es/standards-agent-kit.es3.js.map +1 -1
  70. package/dist/es/standards-agent-kit.es4.js +22 -74
  71. package/dist/es/standards-agent-kit.es4.js.map +1 -1
  72. package/dist/es/standards-agent-kit.es5.js +127 -154
  73. package/dist/es/standards-agent-kit.es5.js.map +1 -1
  74. package/dist/es/standards-agent-kit.es6.js +21 -88
  75. package/dist/es/standards-agent-kit.es6.js.map +1 -1
  76. package/dist/es/standards-agent-kit.es7.js +28 -86
  77. package/dist/es/standards-agent-kit.es7.js.map +1 -1
  78. package/dist/es/standards-agent-kit.es8.js +27 -100
  79. package/dist/es/standards-agent-kit.es8.js.map +1 -1
  80. package/dist/es/standards-agent-kit.es9.js +35 -117
  81. package/dist/es/standards-agent-kit.es9.js.map +1 -1
  82. package/dist/es/state/state-types.d.ts +8 -8
  83. package/dist/es/tools/hcs10/AcceptConnectionRequestTool.d.ts +40 -0
  84. package/dist/es/tools/hcs10/CheckMessagesTool.d.ts +40 -0
  85. package/dist/es/tools/hcs10/ConnectionMonitorTool.d.ts +134 -0
  86. package/dist/es/tools/hcs10/FindRegistrationsTool.d.ts +34 -0
  87. package/dist/es/tools/hcs10/InitiateConnectionTool.d.ts +43 -0
  88. package/dist/es/tools/hcs10/ListConnectionsTool.d.ts +34 -0
  89. package/dist/es/tools/hcs10/ListUnapprovedConnectionRequestsTool.d.ts +15 -0
  90. package/dist/es/tools/hcs10/ManageConnectionRequestsTool.d.ts +34 -0
  91. package/dist/es/tools/hcs10/RegisterAgentTool.d.ts +218 -0
  92. package/dist/es/tools/hcs10/RetrieveProfileTool.d.ts +33 -0
  93. package/dist/es/tools/hcs10/SendMessageToConnectionTool.d.ts +40 -0
  94. package/dist/es/tools/hcs10/base-hcs10-tools.d.ts +28 -0
  95. package/dist/es/tools/hcs10/hcs10-tool-params.d.ts +18 -0
  96. package/dist/es/tools/hcs10/index.d.ts +13 -0
  97. package/dist/es/tools/index.d.ts +1 -13
  98. package/dist/umd/builders/hcs10/hcs10-builder.d.ts +262 -0
  99. package/dist/umd/builders/index.d.ts +2 -0
  100. package/dist/umd/builders/types.d.ts +10 -0
  101. package/dist/umd/index.d.ts +3 -1
  102. package/dist/umd/init/init.d.ts +21 -22
  103. package/dist/umd/plugins/PluginInterface.d.ts +4 -80
  104. package/dist/umd/plugins/PluginRegistry.d.ts +1 -47
  105. package/dist/umd/plugins/defi/index.d.ts +7 -4
  106. package/dist/umd/plugins/hedera/HbarPricePlugin.d.ts +7 -35
  107. package/dist/umd/plugins/index.d.ts +0 -5
  108. package/dist/umd/plugins/weather/index.d.ts +6 -5
  109. package/dist/umd/standards-agent-kit.umd.js +1 -194
  110. package/dist/umd/standards-agent-kit.umd.js.map +1 -1
  111. package/dist/umd/state/state-types.d.ts +8 -8
  112. package/dist/umd/tools/hcs10/AcceptConnectionRequestTool.d.ts +40 -0
  113. package/dist/umd/tools/hcs10/CheckMessagesTool.d.ts +40 -0
  114. package/dist/umd/tools/hcs10/ConnectionMonitorTool.d.ts +134 -0
  115. package/dist/umd/tools/hcs10/FindRegistrationsTool.d.ts +34 -0
  116. package/dist/umd/tools/hcs10/InitiateConnectionTool.d.ts +43 -0
  117. package/dist/umd/tools/hcs10/ListConnectionsTool.d.ts +34 -0
  118. package/dist/umd/tools/hcs10/ListUnapprovedConnectionRequestsTool.d.ts +15 -0
  119. package/dist/umd/tools/hcs10/ManageConnectionRequestsTool.d.ts +34 -0
  120. package/dist/umd/tools/hcs10/RegisterAgentTool.d.ts +218 -0
  121. package/dist/umd/tools/hcs10/RetrieveProfileTool.d.ts +33 -0
  122. package/dist/umd/tools/hcs10/SendMessageToConnectionTool.d.ts +40 -0
  123. package/dist/umd/tools/hcs10/base-hcs10-tools.d.ts +28 -0
  124. package/dist/umd/tools/hcs10/hcs10-tool-params.d.ts +18 -0
  125. package/dist/umd/tools/hcs10/index.d.ts +13 -0
  126. package/dist/umd/tools/index.d.ts +1 -13
  127. package/package.json +40 -37
  128. package/src/builders/hcs10/hcs10-builder.ts +2108 -0
  129. package/src/builders/index.ts +2 -0
  130. package/src/builders/types.ts +11 -0
  131. package/src/hcs10/HCS10Client.ts +3 -2
  132. package/src/index.ts +4 -2
  133. package/src/init/init.ts +85 -63
  134. package/src/plugins/PluginInterface.ts +15 -94
  135. package/src/plugins/PluginRegistry.ts +2 -98
  136. package/src/plugins/defi/index.ts +30 -117
  137. package/src/plugins/hedera/HbarPricePlugin.ts +19 -100
  138. package/src/plugins/index.ts +0 -5
  139. package/src/plugins/weather/index.ts +56 -40
  140. package/src/state/state-types.ts +9 -11
  141. package/src/tools/hcs10/AcceptConnectionRequestTool.ts +56 -0
  142. package/src/tools/hcs10/CheckMessagesTool.ts +73 -0
  143. package/src/tools/hcs10/ConnectionMonitorTool.ts +111 -0
  144. package/src/tools/hcs10/FindRegistrationsTool.ts +64 -0
  145. package/src/tools/hcs10/InitiateConnectionTool.ts +66 -0
  146. package/src/tools/hcs10/ListConnectionsTool.ts +58 -0
  147. package/src/tools/hcs10/ListUnapprovedConnectionRequestsTool.ts +26 -0
  148. package/src/tools/hcs10/ManageConnectionRequestsTool.ts +48 -0
  149. package/src/tools/hcs10/RegisterAgentTool.ts +213 -0
  150. package/src/tools/hcs10/RetrieveProfileTool.ts +61 -0
  151. package/src/tools/hcs10/SendMessageToConnectionTool.ts +45 -0
  152. package/src/tools/hcs10/base-hcs10-tools.ts +65 -0
  153. package/src/tools/hcs10/hcs10-tool-params.ts +21 -0
  154. package/src/tools/hcs10/index.ts +13 -0
  155. package/src/tools/index.ts +2 -13
  156. package/src/utils/HederaClient.ts +2 -2
  157. package/src/utils/ensure-agent-has-hbar.ts +3 -4
  158. package/dist/cjs/agents/index.d.ts +0 -0
  159. package/dist/cjs/plugins/BasePlugin.d.ts +0 -28
  160. package/dist/cjs/plugins/GenericPlugin.d.ts +0 -17
  161. package/dist/cjs/plugins/HCS10Plugin.d.ts +0 -13
  162. package/dist/cjs/plugins/PluginLoader.d.ts +0 -38
  163. package/dist/cjs/plugins/openconvai/OpenConvAIPlugin.d.ts +0 -23
  164. package/dist/cjs/plugins/openconvai/index.d.ts +0 -1
  165. package/dist/cjs/tools/AcceptConnectionRequestTool.d.ts +0 -33
  166. package/dist/cjs/tools/CheckMessagesTool.d.ts +0 -34
  167. package/dist/cjs/tools/ConnectionMonitorTool.d.ts +0 -100
  168. package/dist/cjs/tools/ConnectionTool.d.ts +0 -40
  169. package/dist/cjs/tools/FindRegistrationsTool.d.ts +0 -28
  170. package/dist/cjs/tools/InitiateConnectionTool.d.ts +0 -30
  171. package/dist/cjs/tools/ListConnectionsTool.d.ts +0 -33
  172. package/dist/cjs/tools/ListUnapprovedConnectionRequestsTool.d.ts +0 -41
  173. package/dist/cjs/tools/ManageConnectionRequestsTool.d.ts +0 -38
  174. package/dist/cjs/tools/RegisterAgentTool.d.ts +0 -188
  175. package/dist/cjs/tools/RetrieveProfileTool.d.ts +0 -34
  176. package/dist/cjs/tools/SendMessageToConnectionTool.d.ts +0 -34
  177. package/dist/cjs/tools/SendMessageTool.d.ts +0 -40
  178. package/dist/es/agents/index.d.ts +0 -0
  179. package/dist/es/plugins/BasePlugin.d.ts +0 -28
  180. package/dist/es/plugins/GenericPlugin.d.ts +0 -17
  181. package/dist/es/plugins/HCS10Plugin.d.ts +0 -13
  182. package/dist/es/plugins/PluginLoader.d.ts +0 -38
  183. package/dist/es/plugins/openconvai/OpenConvAIPlugin.d.ts +0 -23
  184. package/dist/es/plugins/openconvai/index.d.ts +0 -1
  185. package/dist/es/standards-agent-kit.es21.js +0 -92
  186. package/dist/es/standards-agent-kit.es21.js.map +0 -1
  187. package/dist/es/standards-agent-kit.es22.js +0 -7
  188. package/dist/es/standards-agent-kit.es22.js.map +0 -1
  189. package/dist/es/standards-agent-kit.es23.js +0 -106
  190. package/dist/es/standards-agent-kit.es23.js.map +0 -1
  191. package/dist/es/standards-agent-kit.es24.js +0 -7
  192. package/dist/es/standards-agent-kit.es24.js.map +0 -1
  193. package/dist/es/standards-agent-kit.es25.js +0 -7
  194. package/dist/es/standards-agent-kit.es25.js.map +0 -1
  195. package/dist/es/standards-agent-kit.es26.js +0 -85
  196. package/dist/es/standards-agent-kit.es26.js.map +0 -1
  197. package/dist/es/standards-agent-kit.es27.js +0 -28
  198. package/dist/es/standards-agent-kit.es27.js.map +0 -1
  199. package/dist/es/tools/AcceptConnectionRequestTool.d.ts +0 -33
  200. package/dist/es/tools/CheckMessagesTool.d.ts +0 -34
  201. package/dist/es/tools/ConnectionMonitorTool.d.ts +0 -100
  202. package/dist/es/tools/ConnectionTool.d.ts +0 -40
  203. package/dist/es/tools/FindRegistrationsTool.d.ts +0 -28
  204. package/dist/es/tools/InitiateConnectionTool.d.ts +0 -30
  205. package/dist/es/tools/ListConnectionsTool.d.ts +0 -33
  206. package/dist/es/tools/ListUnapprovedConnectionRequestsTool.d.ts +0 -41
  207. package/dist/es/tools/ManageConnectionRequestsTool.d.ts +0 -38
  208. package/dist/es/tools/RegisterAgentTool.d.ts +0 -188
  209. package/dist/es/tools/RetrieveProfileTool.d.ts +0 -34
  210. package/dist/es/tools/SendMessageToConnectionTool.d.ts +0 -34
  211. package/dist/es/tools/SendMessageTool.d.ts +0 -40
  212. package/dist/umd/agents/index.d.ts +0 -0
  213. package/dist/umd/plugins/BasePlugin.d.ts +0 -28
  214. package/dist/umd/plugins/GenericPlugin.d.ts +0 -17
  215. package/dist/umd/plugins/HCS10Plugin.d.ts +0 -13
  216. package/dist/umd/plugins/PluginLoader.d.ts +0 -38
  217. package/dist/umd/plugins/openconvai/OpenConvAIPlugin.d.ts +0 -23
  218. package/dist/umd/plugins/openconvai/index.d.ts +0 -1
  219. package/dist/umd/tools/AcceptConnectionRequestTool.d.ts +0 -33
  220. package/dist/umd/tools/CheckMessagesTool.d.ts +0 -34
  221. package/dist/umd/tools/ConnectionMonitorTool.d.ts +0 -100
  222. package/dist/umd/tools/ConnectionTool.d.ts +0 -40
  223. package/dist/umd/tools/FindRegistrationsTool.d.ts +0 -28
  224. package/dist/umd/tools/InitiateConnectionTool.d.ts +0 -30
  225. package/dist/umd/tools/ListConnectionsTool.d.ts +0 -33
  226. package/dist/umd/tools/ListUnapprovedConnectionRequestsTool.d.ts +0 -41
  227. package/dist/umd/tools/ManageConnectionRequestsTool.d.ts +0 -38
  228. package/dist/umd/tools/RegisterAgentTool.d.ts +0 -188
  229. package/dist/umd/tools/RetrieveProfileTool.d.ts +0 -34
  230. package/dist/umd/tools/SendMessageToConnectionTool.d.ts +0 -34
  231. package/dist/umd/tools/SendMessageTool.d.ts +0 -40
  232. package/src/agents/index.ts +0 -1
  233. package/src/plugins/BasePlugin.ts +0 -37
  234. package/src/plugins/GenericPlugin.ts +0 -19
  235. package/src/plugins/HCS10Plugin.ts +0 -14
  236. package/src/plugins/PluginLoader.ts +0 -121
  237. package/src/plugins/README.md +0 -113
  238. package/src/plugins/openconvai/OpenConvAIPlugin.ts +0 -124
  239. package/src/plugins/openconvai/index.ts +0 -1
  240. package/src/tools/AcceptConnectionRequestTool.ts +0 -196
  241. package/src/tools/CheckMessagesTool.ts +0 -194
  242. package/src/tools/ConnectionMonitorTool.ts +0 -550
  243. package/src/tools/ConnectionTool.ts +0 -231
  244. package/src/tools/FindRegistrationsTool.ts +0 -114
  245. package/src/tools/InitiateConnectionTool.ts +0 -137
  246. package/src/tools/ListConnectionsTool.ts +0 -158
  247. package/src/tools/ListUnapprovedConnectionRequestsTool.ts +0 -173
  248. package/src/tools/ManageConnectionRequestsTool.ts +0 -275
  249. package/src/tools/RegisterAgentTool.ts +0 -590
  250. package/src/tools/RetrieveProfileTool.ts +0 -94
  251. package/src/tools/SendMessageToConnectionTool.ts +0 -142
  252. package/src/tools/SendMessageTool.ts +0 -116
@@ -1,550 +0,0 @@
1
- import { StructuredTool, ToolParams } from '@langchain/core/tools';
2
- import { z } from 'zod';
3
- import { HCS10Client } from '../hcs10/HCS10Client';
4
- import {
5
- IStateManager,
6
- ActiveConnection,
7
- AgentProfileInfo,
8
- } from '../state/state-types';
9
- import {
10
- Logger,
11
- FeeConfigBuilder,
12
- HCSMessage,
13
- FeeConfigBuilderInterface,
14
- AIAgentProfile,
15
- } from '@hashgraphonline/standards-sdk';
16
- import { ListConnectionsTool } from './ListConnectionsTool';
17
-
18
- export interface FeeDefinition {
19
- amount: number;
20
- collectorAccount?: string;
21
- }
22
-
23
- export interface TokenFeeDefinition extends FeeDefinition {
24
- tokenId: string;
25
- }
26
-
27
- export interface ConnectionMonitorToolParams extends ToolParams {
28
- hcsClient: HCS10Client;
29
- stateManager: IStateManager;
30
- }
31
-
32
- /**
33
- * A tool for monitoring incoming connection requests and accepting them with optional fee settings.
34
- */
35
- export class ConnectionMonitorTool extends StructuredTool {
36
- name = 'monitor_connections';
37
- description =
38
- 'Monitors for incoming connection requests and accepts them with optional fee settings. Use this to watch for connection requests and accept them, optionally setting HBAR or token fees on the connection.';
39
- schema = z.object({
40
- acceptAll: z
41
- .boolean()
42
- .optional()
43
- .describe(
44
- 'Whether to automatically accept all incoming connection requests. Default is false.'
45
- ),
46
- targetAccountId: z
47
- .string()
48
- .optional()
49
- .describe(
50
- 'If provided, only accept connection requests from this specific account ID.'
51
- ),
52
- hbarFees: z
53
- .array(
54
- z.object({
55
- amount: z.number(),
56
- collectorAccount: z.string().optional(),
57
- })
58
- )
59
- .optional()
60
- .describe(
61
- 'Array of HBAR fee amounts to charge per message (with optional collector accounts).'
62
- ),
63
- tokenFees: z
64
- .array(
65
- z.object({
66
- amount: z.number(),
67
- tokenId: z.string(),
68
- collectorAccount: z.string().optional(),
69
- })
70
- )
71
- .optional()
72
- .describe(
73
- 'Array of token fee amounts and IDs to charge per message (with optional collector accounts).'
74
- ),
75
- exemptAccountIds: z
76
- .array(z.string())
77
- .optional()
78
- .describe(
79
- 'Array of account IDs to exempt from ALL fees set in this request.'
80
- ),
81
- monitorDurationSeconds: z
82
- .number()
83
- .optional()
84
- .describe(
85
- 'How long to monitor for incoming requests in seconds. Default is 60.'
86
- ),
87
- defaultCollectorAccount: z
88
- .string()
89
- .optional()
90
- .describe(
91
- 'Default account to collect fees if not specified at the fee level. Defaults to the agent account.'
92
- ),
93
- });
94
-
95
- private hcsClient: HCS10Client;
96
- private stateManager: IStateManager;
97
- private logger: Logger;
98
- private isMonitoring: boolean = false;
99
- private listConnectionsTool: ListConnectionsTool;
100
-
101
- constructor({
102
- hcsClient,
103
- stateManager,
104
- ...rest
105
- }: ConnectionMonitorToolParams) {
106
- super(rest);
107
- this.hcsClient = hcsClient;
108
- this.stateManager = stateManager;
109
- this.logger = Logger.getInstance({
110
- module: 'ConnectionMonitorTool',
111
- level: 'error',
112
- });
113
- this.listConnectionsTool = new ListConnectionsTool({
114
- stateManager,
115
- hcsClient,
116
- ...rest,
117
- });
118
- }
119
-
120
- updateClient(newClient: HCS10Client): void {
121
- this.hcsClient = newClient;
122
- this.logger.info('Updated HCS10Client instance for ConnectionMonitorTool');
123
- this.listConnectionsTool = new ListConnectionsTool({
124
- stateManager: this.stateManager,
125
- hcsClient: newClient,
126
- });
127
- }
128
-
129
- protected async _call({
130
- acceptAll = false,
131
- targetAccountId,
132
- hbarFees = [],
133
- tokenFees = [],
134
- exemptAccountIds,
135
- monitorDurationSeconds = 60,
136
- defaultCollectorAccount,
137
- }: z.infer<this['schema']>): Promise<string> {
138
- const currentAgent = this.stateManager.getCurrentAgent();
139
- if (!currentAgent) {
140
- return 'Error: Cannot monitor for connections. No agent is currently active. Please register or select an agent first.';
141
- }
142
-
143
- if (this.isMonitoring) {
144
- return 'Already monitoring for connection requests. Please wait for the current monitoring session to complete.';
145
- }
146
-
147
- try {
148
- this.isMonitoring = true;
149
- const inboundTopicId = await this.hcsClient.getInboundTopicId();
150
-
151
- if (!inboundTopicId) {
152
- this.isMonitoring = false;
153
- return 'Error: Could not find inbound topic ID for the current agent.';
154
- }
155
-
156
- this.logger.info(
157
- `Starting to monitor inbound topic ${inboundTopicId} for connection requests...`
158
- );
159
-
160
- const feeConfig = this.createFeeConfig(
161
- hbarFees,
162
- tokenFees,
163
- exemptAccountIds,
164
- targetAccountId,
165
- defaultCollectorAccount
166
- );
167
-
168
- const endTime = Date.now() + monitorDurationSeconds * 1000;
169
- const pollIntervalMs = 3000;
170
- let lastSequenceNumber = 0;
171
- let connectionRequestsFound = 0;
172
- let acceptedConnections = 0;
173
- let skippedRequests = 0;
174
-
175
- while (Date.now() < endTime) {
176
- try {
177
- await this.listConnectionsTool.invoke({
178
- includeDetails: false,
179
- showPending: false,
180
- });
181
- const currentConnections = this.stateManager.listConnections();
182
-
183
- // Create a map of connections by accountId and requestId to better track multiple connections
184
- const connectionsByAccountAndRequest = new Map<string, Set<string>>();
185
-
186
- currentConnections
187
- .filter((conn) => conn.status === 'established' && !conn.isPending)
188
- .forEach((conn) => {
189
- if (!connectionsByAccountAndRequest.has(conn.targetAccountId)) {
190
- connectionsByAccountAndRequest.set(
191
- conn.targetAccountId,
192
- new Set()
193
- );
194
- }
195
-
196
- if (conn.connectionRequestId) {
197
- connectionsByAccountAndRequest
198
- .get(conn.targetAccountId)
199
- ?.add(String(conn.connectionRequestId));
200
- }
201
- });
202
-
203
- const messagesResult = await this.hcsClient.getMessages(
204
- inboundTopicId
205
- );
206
- const newMessages = messagesResult.messages.filter((msg) => {
207
- if (
208
- !msg.sequence_number ||
209
- msg.sequence_number <= lastSequenceNumber
210
- ) {
211
- return false;
212
- }
213
- lastSequenceNumber = Math.max(
214
- lastSequenceNumber,
215
- msg.sequence_number
216
- );
217
- return msg.op === 'connection_request';
218
- });
219
-
220
- for (const request of newMessages) {
221
- const requestId = request.sequence_number;
222
- if (!requestId) {
223
- continue;
224
- }
225
-
226
- connectionRequestsFound++;
227
-
228
- // Get the inbound topic ID where this request was received
229
- const inboundTopicId =
230
- (await this.hcsClient.getInboundTopicId()) || '';
231
-
232
- // Get ConnectionsManager from state manager
233
- const connectionsManager =
234
- this.stateManager.getConnectionsManager();
235
- if (!connectionsManager) {
236
- this.logger.error(
237
- 'ConnectionsManager not initialized in state manager'
238
- );
239
- continue;
240
- }
241
-
242
- // Check if we've already processed this specific request
243
- if (
244
- connectionsManager.isConnectionRequestProcessed(
245
- inboundTopicId,
246
- requestId
247
- )
248
- ) {
249
- this.logger.info(
250
- `Request #${requestId} already processed, skipping`
251
- );
252
- skippedRequests++;
253
- continue;
254
- }
255
-
256
- const requestorAccountId = this.extractAccountId(request);
257
- if (!requestorAccountId) {
258
- // Mark as processed even if we couldn't extract the account ID
259
- connectionsManager.markConnectionRequestProcessed(
260
- inboundTopicId,
261
- requestId
262
- );
263
- continue;
264
- }
265
-
266
- if (targetAccountId && requestorAccountId !== targetAccountId) {
267
- this.logger.info(
268
- `Request #${requestId} doesn't match target ${targetAccountId}`
269
- );
270
- continue;
271
- }
272
-
273
- // Check if this specific request has already been processed
274
- const existingAccountConnections =
275
- connectionsByAccountAndRequest.get(requestorAccountId);
276
- if (existingAccountConnections?.has(String(requestId))) {
277
- this.logger.info(
278
- `Already processed connection request #${requestId} from ${requestorAccountId}, skipping`
279
- );
280
- connectionsManager.markConnectionRequestProcessed(
281
- inboundTopicId,
282
- requestId
283
- );
284
- skippedRequests++;
285
- continue;
286
- }
287
-
288
- if (acceptAll) {
289
- const result = await this.acceptConnectionRequest(
290
- requestId,
291
- requestorAccountId,
292
- feeConfig
293
- );
294
- connectionsManager.markConnectionRequestProcessed(
295
- inboundTopicId,
296
- requestId
297
- );
298
-
299
- if (result.success) {
300
- acceptedConnections++;
301
- this.logger.info(
302
- `Successfully accepted connection with ${requestorAccountId} for request #${requestId}`
303
- );
304
- }
305
- } else {
306
- this.logger.info(
307
- `Found request #${requestId} from ${requestorAccountId} (not auto-accepting)`
308
- );
309
- }
310
- }
311
-
312
- await new Promise((resolve) => setTimeout(resolve, pollIntervalMs));
313
- } catch (error) {
314
- this.logger.error(`Error polling for messages: ${error}`);
315
- await new Promise((resolve) => setTimeout(resolve, pollIntervalMs));
316
- }
317
- }
318
-
319
- this.isMonitoring = false;
320
-
321
- if (connectionRequestsFound === 0) {
322
- return `No connection requests received during the ${monitorDurationSeconds} second monitoring period.`;
323
- } else if (acceptAll) {
324
- return `Monitored for ${monitorDurationSeconds} seconds. Found ${connectionRequestsFound} connection requests, accepted ${acceptedConnections} connections, skipped ${skippedRequests} existing connections${this.formatFeeString(
325
- hbarFees,
326
- tokenFees
327
- )}.`;
328
- } else {
329
- return `Monitored for ${monitorDurationSeconds} seconds. Found ${connectionRequestsFound} connection requests. To accept them, call this tool again with acceptAll=true.`;
330
- }
331
- } catch (error) {
332
- this.isMonitoring = false;
333
- this.logger.error(`Connection monitoring failed: ${error}`);
334
- return `Error monitoring for connections: ${
335
- error instanceof Error ? error.message : String(error)
336
- }`;
337
- }
338
- }
339
-
340
- private createFeeConfig(
341
- hbarFees: FeeDefinition[] = [],
342
- tokenFees: TokenFeeDefinition[] = [],
343
- exemptAccountIds?: string[],
344
- targetAccountId?: string,
345
- defaultCollectorAccount?: string
346
- ): FeeConfigBuilderInterface | undefined {
347
- if (hbarFees.length === 0 && tokenFees.length === 0) {
348
- return undefined;
349
- }
350
-
351
- try {
352
- const agentAccountId = this.hcsClient.getAccountAndSigner().accountId;
353
- const defaultCollector = defaultCollectorAccount || agentAccountId;
354
-
355
- const builder = new FeeConfigBuilder({
356
- network: this.hcsClient.getNetwork(),
357
- logger: this.logger,
358
- defaultCollectorAccountId: defaultCollector,
359
- });
360
-
361
- const exemptIds = [...(exemptAccountIds || [])];
362
- if (targetAccountId && !exemptIds.includes(targetAccountId)) {
363
- exemptIds.push(targetAccountId);
364
- }
365
-
366
- for (const hbarFee of hbarFees) {
367
- if (hbarFee.amount > 0) {
368
- const collector = hbarFee.collectorAccount || defaultCollector;
369
- builder.addHbarFee(hbarFee.amount, collector, exemptIds);
370
- this.logger.info(
371
- `Added HBAR fee: ${hbarFee.amount} HBAR to be collected by ${collector}`
372
- );
373
- }
374
- }
375
-
376
- for (const tokenFee of tokenFees) {
377
- if (tokenFee.amount > 0 && tokenFee.tokenId) {
378
- const collector = tokenFee.collectorAccount || defaultCollector;
379
- builder.addTokenFee(
380
- tokenFee.amount,
381
- tokenFee.tokenId,
382
- collector,
383
- undefined,
384
- exemptIds
385
- );
386
- this.logger.info(
387
- `Added token fee: ${tokenFee.amount} of token ${tokenFee.tokenId} to be collected by ${collector}`
388
- );
389
- }
390
- }
391
-
392
- return builder;
393
- } catch (error) {
394
- this.logger.error(`Error creating fee configuration: ${error}`);
395
- return undefined;
396
- }
397
- }
398
-
399
- private extractAccountId(request: HCSMessage): string | undefined {
400
- if (request.operator_id) {
401
- return this.hcsClient.standardClient.extractAccountFromOperatorId(
402
- request.operator_id
403
- );
404
- }
405
- return undefined;
406
- }
407
-
408
- private async acceptConnectionRequest(
409
- connectionRequestId: number,
410
- requestingAccountId: string,
411
- feeConfig?: FeeConfigBuilderInterface
412
- ): Promise<{ success: boolean; connectionTopicId?: string; error?: string }> {
413
- try {
414
- const inboundTopicId = await this.hcsClient.getInboundTopicId();
415
- this.logger.info(
416
- `Accepting connection request #${connectionRequestId} from ${requestingAccountId}`
417
- );
418
-
419
- const result = await this.hcsClient.handleConnectionRequest(
420
- inboundTopicId,
421
- requestingAccountId,
422
- connectionRequestId,
423
- feeConfig
424
- );
425
-
426
- if (!result?.connectionTopicId) {
427
- return {
428
- success: false,
429
- error: 'Connection acceptance returned no connection topic ID',
430
- };
431
- }
432
-
433
- const connectionTopicId = result.connectionTopicId;
434
- this.logger.info(
435
- `Connection established! Topic ID: ${connectionTopicId}`
436
- );
437
-
438
- let profileInfo: AIAgentProfile | undefined;
439
- try {
440
- const profile = await this.hcsClient.getAgentProfile(
441
- requestingAccountId
442
- );
443
- if (profile.success && profile.profile) {
444
- profileInfo = profile.profile;
445
- }
446
- } catch (profileError) {
447
- this.logger.warn(
448
- `Could not fetch profile for ${requestingAccountId}: ${profileError}`
449
- );
450
- }
451
-
452
- const targetInboundTopicId =
453
- (await this.hcsClient.getAgentProfile(requestingAccountId))?.topicInfo
454
- ?.inboundTopic || '';
455
-
456
- const connection: ActiveConnection = {
457
- targetAccountId: requestingAccountId,
458
- targetAgentName:
459
- profileInfo?.display_name || `Agent ${requestingAccountId}`,
460
- targetInboundTopicId,
461
- connectionTopicId,
462
- profileInfo,
463
- created: new Date(),
464
- status: 'established',
465
- metadata: {
466
- requestId: connectionRequestId,
467
- },
468
- };
469
-
470
- this.stateManager.addActiveConnection(connection);
471
-
472
- return {
473
- success: true,
474
- connectionTopicId,
475
- };
476
- } catch (error) {
477
- this.logger.error(`Error accepting connection request: ${error}`);
478
- return {
479
- success: false,
480
- error: error instanceof Error ? error.message : String(error),
481
- };
482
- }
483
- }
484
-
485
- private formatFeeString(
486
- hbarFees: FeeDefinition[] = [],
487
- tokenFees: TokenFeeDefinition[] = []
488
- ): string {
489
- if (hbarFees.length === 0 && tokenFees.length === 0) {
490
- return '';
491
- }
492
-
493
- let feeString = ' with fees: ';
494
-
495
- if (hbarFees.length > 0) {
496
- const hbarFeeDetails = hbarFees
497
- .filter((fee) => fee.amount > 0)
498
- .map((fee) => {
499
- const collector = fee.collectorAccount
500
- ? ` to ${fee.collectorAccount}`
501
- : '';
502
- return `${fee.amount} HBAR${collector}`;
503
- })
504
- .join(', ');
505
-
506
- if (hbarFeeDetails) {
507
- feeString += hbarFeeDetails;
508
- }
509
- }
510
-
511
- if (tokenFees.length > 0) {
512
- if (hbarFees.length > 0) {
513
- feeString += ' and ';
514
- }
515
-
516
- const tokenFeeDetails = tokenFees
517
- .filter((fee) => fee.amount > 0 && fee.tokenId)
518
- .map((fee) => {
519
- const collector = fee.collectorAccount
520
- ? ` to ${fee.collectorAccount}`
521
- : '';
522
- return `${fee.amount} of token ${fee.tokenId}${collector}`;
523
- })
524
- .join(', ');
525
-
526
- if (tokenFeeDetails) {
527
- feeString += tokenFeeDetails;
528
- }
529
- }
530
-
531
- return feeString === ' with fees: ' ? '' : feeString;
532
- }
533
-
534
- /**
535
- * Updates the ConnectionsManager with latest connection data
536
- * This method is meant to be called when changes to connections happen
537
- * outside this tool's monitoring process
538
- */
539
- public update(): void {
540
- // Trigger the listConnectionsTool to refresh state data
541
- this.listConnectionsTool
542
- .invoke({
543
- includeDetails: true,
544
- showPending: true,
545
- })
546
- .catch((error) => {
547
- this.logger.error(`Error updating connections: ${error}`);
548
- });
549
- }
550
- }