@hashgraphonline/standards-agent-kit 0.0.37 → 0.2.0

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 (251) hide show
  1. package/dist/cjs/builders/hcs10/hcs10-builder.d.ts +262 -0
  2. package/dist/cjs/builders/index.d.ts +2 -0
  3. package/dist/cjs/builders/types.d.ts +10 -0
  4. package/dist/cjs/index.d.ts +3 -1
  5. package/dist/cjs/init/init.d.ts +21 -22
  6. package/dist/cjs/plugins/PluginInterface.d.ts +4 -80
  7. package/dist/cjs/plugins/PluginRegistry.d.ts +1 -47
  8. package/dist/cjs/plugins/defi/index.d.ts +7 -4
  9. package/dist/cjs/plugins/hedera/HbarPricePlugin.d.ts +7 -35
  10. package/dist/cjs/plugins/index.d.ts +0 -5
  11. package/dist/cjs/plugins/weather/index.d.ts +6 -5
  12. package/dist/cjs/standards-agent-kit.cjs +1 -1
  13. package/dist/cjs/standards-agent-kit.cjs.map +1 -1
  14. package/dist/cjs/state/state-types.d.ts +8 -8
  15. package/dist/cjs/tools/hcs10/AcceptConnectionRequestTool.d.ts +40 -0
  16. package/dist/cjs/tools/hcs10/CheckMessagesTool.d.ts +40 -0
  17. package/dist/cjs/tools/hcs10/ConnectionMonitorTool.d.ts +134 -0
  18. package/dist/cjs/tools/hcs10/FindRegistrationsTool.d.ts +34 -0
  19. package/dist/cjs/tools/hcs10/InitiateConnectionTool.d.ts +43 -0
  20. package/dist/cjs/tools/hcs10/ListConnectionsTool.d.ts +34 -0
  21. package/dist/cjs/tools/hcs10/ListUnapprovedConnectionRequestsTool.d.ts +15 -0
  22. package/dist/cjs/tools/hcs10/ManageConnectionRequestsTool.d.ts +34 -0
  23. package/dist/cjs/tools/hcs10/RegisterAgentTool.d.ts +218 -0
  24. package/dist/cjs/tools/hcs10/RetrieveProfileTool.d.ts +33 -0
  25. package/dist/cjs/tools/hcs10/SendMessageToConnectionTool.d.ts +40 -0
  26. package/dist/cjs/tools/hcs10/base-hcs10-tools.d.ts +28 -0
  27. package/dist/cjs/tools/hcs10/hcs10-tool-params.d.ts +18 -0
  28. package/dist/cjs/tools/hcs10/index.d.ts +13 -0
  29. package/dist/cjs/tools/index.d.ts +1 -13
  30. package/dist/es/builders/hcs10/hcs10-builder.d.ts +262 -0
  31. package/dist/es/builders/index.d.ts +2 -0
  32. package/dist/es/builders/types.d.ts +10 -0
  33. package/dist/es/index.d.ts +3 -1
  34. package/dist/es/init/init.d.ts +21 -22
  35. package/dist/es/plugins/PluginInterface.d.ts +4 -80
  36. package/dist/es/plugins/PluginRegistry.d.ts +1 -47
  37. package/dist/es/plugins/defi/index.d.ts +7 -4
  38. package/dist/es/plugins/hedera/HbarPricePlugin.d.ts +7 -35
  39. package/dist/es/plugins/index.d.ts +0 -5
  40. package/dist/es/plugins/weather/index.d.ts +6 -5
  41. package/dist/es/standards-agent-kit.es.js +10 -18
  42. package/dist/es/standards-agent-kit.es.js.map +1 -1
  43. package/dist/es/standards-agent-kit.es10.js +29 -76
  44. package/dist/es/standards-agent-kit.es10.js.map +1 -1
  45. package/dist/es/standards-agent-kit.es11.js +61 -384
  46. package/dist/es/standards-agent-kit.es11.js.map +1 -1
  47. package/dist/es/standards-agent-kit.es12.js +22 -190
  48. package/dist/es/standards-agent-kit.es12.js.map +1 -1
  49. package/dist/es/standards-agent-kit.es13.js +26 -138
  50. package/dist/es/standards-agent-kit.es13.js.map +1 -1
  51. package/dist/es/standards-agent-kit.es14.js +35 -59
  52. package/dist/es/standards-agent-kit.es14.js.map +1 -1
  53. package/dist/es/standards-agent-kit.es15.js +11 -117
  54. package/dist/es/standards-agent-kit.es15.js.map +1 -1
  55. package/dist/es/standards-agent-kit.es16.js +1 -1
  56. package/dist/es/standards-agent-kit.es16.js.map +1 -1
  57. package/dist/es/standards-agent-kit.es17.js +63 -46
  58. package/dist/es/standards-agent-kit.es17.js.map +1 -1
  59. package/dist/es/standards-agent-kit.es18.js +25 -74
  60. package/dist/es/standards-agent-kit.es18.js.map +1 -1
  61. package/dist/es/standards-agent-kit.es19.js +22 -13
  62. package/dist/es/standards-agent-kit.es19.js.map +1 -1
  63. package/dist/es/standards-agent-kit.es2.js +1381 -188
  64. package/dist/es/standards-agent-kit.es2.js.map +1 -1
  65. package/dist/es/standards-agent-kit.es20.js +3 -67
  66. package/dist/es/standards-agent-kit.es20.js.map +1 -1
  67. package/dist/es/standards-agent-kit.es3.js +285 -347
  68. package/dist/es/standards-agent-kit.es3.js.map +1 -1
  69. package/dist/es/standards-agent-kit.es4.js +22 -74
  70. package/dist/es/standards-agent-kit.es4.js.map +1 -1
  71. package/dist/es/standards-agent-kit.es5.js +127 -154
  72. package/dist/es/standards-agent-kit.es5.js.map +1 -1
  73. package/dist/es/standards-agent-kit.es6.js +21 -88
  74. package/dist/es/standards-agent-kit.es6.js.map +1 -1
  75. package/dist/es/standards-agent-kit.es7.js +28 -86
  76. package/dist/es/standards-agent-kit.es7.js.map +1 -1
  77. package/dist/es/standards-agent-kit.es8.js +27 -100
  78. package/dist/es/standards-agent-kit.es8.js.map +1 -1
  79. package/dist/es/standards-agent-kit.es9.js +35 -117
  80. package/dist/es/standards-agent-kit.es9.js.map +1 -1
  81. package/dist/es/state/state-types.d.ts +8 -8
  82. package/dist/es/tools/hcs10/AcceptConnectionRequestTool.d.ts +40 -0
  83. package/dist/es/tools/hcs10/CheckMessagesTool.d.ts +40 -0
  84. package/dist/es/tools/hcs10/ConnectionMonitorTool.d.ts +134 -0
  85. package/dist/es/tools/hcs10/FindRegistrationsTool.d.ts +34 -0
  86. package/dist/es/tools/hcs10/InitiateConnectionTool.d.ts +43 -0
  87. package/dist/es/tools/hcs10/ListConnectionsTool.d.ts +34 -0
  88. package/dist/es/tools/hcs10/ListUnapprovedConnectionRequestsTool.d.ts +15 -0
  89. package/dist/es/tools/hcs10/ManageConnectionRequestsTool.d.ts +34 -0
  90. package/dist/es/tools/hcs10/RegisterAgentTool.d.ts +218 -0
  91. package/dist/es/tools/hcs10/RetrieveProfileTool.d.ts +33 -0
  92. package/dist/es/tools/hcs10/SendMessageToConnectionTool.d.ts +40 -0
  93. package/dist/es/tools/hcs10/base-hcs10-tools.d.ts +28 -0
  94. package/dist/es/tools/hcs10/hcs10-tool-params.d.ts +18 -0
  95. package/dist/es/tools/hcs10/index.d.ts +13 -0
  96. package/dist/es/tools/index.d.ts +1 -13
  97. package/dist/umd/builders/hcs10/hcs10-builder.d.ts +262 -0
  98. package/dist/umd/builders/index.d.ts +2 -0
  99. package/dist/umd/builders/types.d.ts +10 -0
  100. package/dist/umd/index.d.ts +3 -1
  101. package/dist/umd/init/init.d.ts +21 -22
  102. package/dist/umd/plugins/PluginInterface.d.ts +4 -80
  103. package/dist/umd/plugins/PluginRegistry.d.ts +1 -47
  104. package/dist/umd/plugins/defi/index.d.ts +7 -4
  105. package/dist/umd/plugins/hedera/HbarPricePlugin.d.ts +7 -35
  106. package/dist/umd/plugins/index.d.ts +0 -5
  107. package/dist/umd/plugins/weather/index.d.ts +6 -5
  108. package/dist/umd/standards-agent-kit.umd.js +1 -164
  109. package/dist/umd/standards-agent-kit.umd.js.map +1 -1
  110. package/dist/umd/state/state-types.d.ts +8 -8
  111. package/dist/umd/tools/hcs10/AcceptConnectionRequestTool.d.ts +40 -0
  112. package/dist/umd/tools/hcs10/CheckMessagesTool.d.ts +40 -0
  113. package/dist/umd/tools/hcs10/ConnectionMonitorTool.d.ts +134 -0
  114. package/dist/umd/tools/hcs10/FindRegistrationsTool.d.ts +34 -0
  115. package/dist/umd/tools/hcs10/InitiateConnectionTool.d.ts +43 -0
  116. package/dist/umd/tools/hcs10/ListConnectionsTool.d.ts +34 -0
  117. package/dist/umd/tools/hcs10/ListUnapprovedConnectionRequestsTool.d.ts +15 -0
  118. package/dist/umd/tools/hcs10/ManageConnectionRequestsTool.d.ts +34 -0
  119. package/dist/umd/tools/hcs10/RegisterAgentTool.d.ts +218 -0
  120. package/dist/umd/tools/hcs10/RetrieveProfileTool.d.ts +33 -0
  121. package/dist/umd/tools/hcs10/SendMessageToConnectionTool.d.ts +40 -0
  122. package/dist/umd/tools/hcs10/base-hcs10-tools.d.ts +28 -0
  123. package/dist/umd/tools/hcs10/hcs10-tool-params.d.ts +18 -0
  124. package/dist/umd/tools/hcs10/index.d.ts +13 -0
  125. package/dist/umd/tools/index.d.ts +1 -13
  126. package/package.json +41 -41
  127. package/src/builders/hcs10/hcs10-builder.ts +2108 -0
  128. package/src/builders/index.ts +2 -0
  129. package/src/builders/types.ts +11 -0
  130. package/src/hcs10/HCS10Client.ts +3 -2
  131. package/src/index.ts +4 -2
  132. package/src/init/init.ts +85 -63
  133. package/src/plugins/PluginInterface.ts +15 -94
  134. package/src/plugins/PluginRegistry.ts +2 -98
  135. package/src/plugins/defi/index.ts +31 -118
  136. package/src/plugins/hedera/HbarPricePlugin.ts +19 -100
  137. package/src/plugins/index.ts +0 -5
  138. package/src/plugins/weather/index.ts +56 -40
  139. package/src/state/state-types.ts +9 -11
  140. package/src/tools/hcs10/AcceptConnectionRequestTool.ts +56 -0
  141. package/src/tools/hcs10/CheckMessagesTool.ts +73 -0
  142. package/src/tools/hcs10/ConnectionMonitorTool.ts +111 -0
  143. package/src/tools/hcs10/FindRegistrationsTool.ts +64 -0
  144. package/src/tools/hcs10/InitiateConnectionTool.ts +66 -0
  145. package/src/tools/hcs10/ListConnectionsTool.ts +58 -0
  146. package/src/tools/hcs10/ListUnapprovedConnectionRequestsTool.ts +26 -0
  147. package/src/tools/hcs10/ManageConnectionRequestsTool.ts +48 -0
  148. package/src/tools/hcs10/RegisterAgentTool.ts +213 -0
  149. package/src/tools/hcs10/RetrieveProfileTool.ts +61 -0
  150. package/src/tools/hcs10/SendMessageToConnectionTool.ts +45 -0
  151. package/src/tools/hcs10/base-hcs10-tools.ts +65 -0
  152. package/src/tools/hcs10/hcs10-tool-params.ts +21 -0
  153. package/src/tools/hcs10/index.ts +13 -0
  154. package/src/tools/index.ts +2 -13
  155. package/src/utils/HederaClient.ts +2 -2
  156. package/src/utils/ensure-agent-has-hbar.ts +3 -4
  157. package/dist/cjs/agents/index.d.ts +0 -0
  158. package/dist/cjs/plugins/BasePlugin.d.ts +0 -28
  159. package/dist/cjs/plugins/GenericPlugin.d.ts +0 -17
  160. package/dist/cjs/plugins/HCS10Plugin.d.ts +0 -13
  161. package/dist/cjs/plugins/PluginLoader.d.ts +0 -38
  162. package/dist/cjs/plugins/openconvai/OpenConvAIPlugin.d.ts +0 -23
  163. package/dist/cjs/plugins/openconvai/index.d.ts +0 -1
  164. package/dist/cjs/tools/AcceptConnectionRequestTool.d.ts +0 -33
  165. package/dist/cjs/tools/CheckMessagesTool.d.ts +0 -34
  166. package/dist/cjs/tools/ConnectionMonitorTool.d.ts +0 -100
  167. package/dist/cjs/tools/ConnectionTool.d.ts +0 -40
  168. package/dist/cjs/tools/FindRegistrationsTool.d.ts +0 -28
  169. package/dist/cjs/tools/InitiateConnectionTool.d.ts +0 -30
  170. package/dist/cjs/tools/ListConnectionsTool.d.ts +0 -33
  171. package/dist/cjs/tools/ListUnapprovedConnectionRequestsTool.d.ts +0 -41
  172. package/dist/cjs/tools/ManageConnectionRequestsTool.d.ts +0 -38
  173. package/dist/cjs/tools/RegisterAgentTool.d.ts +0 -188
  174. package/dist/cjs/tools/RetrieveProfileTool.d.ts +0 -34
  175. package/dist/cjs/tools/SendMessageToConnectionTool.d.ts +0 -34
  176. package/dist/cjs/tools/SendMessageTool.d.ts +0 -40
  177. package/dist/es/agents/index.d.ts +0 -0
  178. package/dist/es/plugins/BasePlugin.d.ts +0 -28
  179. package/dist/es/plugins/GenericPlugin.d.ts +0 -17
  180. package/dist/es/plugins/HCS10Plugin.d.ts +0 -13
  181. package/dist/es/plugins/PluginLoader.d.ts +0 -38
  182. package/dist/es/plugins/openconvai/OpenConvAIPlugin.d.ts +0 -23
  183. package/dist/es/plugins/openconvai/index.d.ts +0 -1
  184. package/dist/es/standards-agent-kit.es21.js +0 -92
  185. package/dist/es/standards-agent-kit.es21.js.map +0 -1
  186. package/dist/es/standards-agent-kit.es22.js +0 -7
  187. package/dist/es/standards-agent-kit.es22.js.map +0 -1
  188. package/dist/es/standards-agent-kit.es23.js +0 -106
  189. package/dist/es/standards-agent-kit.es23.js.map +0 -1
  190. package/dist/es/standards-agent-kit.es24.js +0 -7
  191. package/dist/es/standards-agent-kit.es24.js.map +0 -1
  192. package/dist/es/standards-agent-kit.es25.js +0 -7
  193. package/dist/es/standards-agent-kit.es25.js.map +0 -1
  194. package/dist/es/standards-agent-kit.es26.js +0 -85
  195. package/dist/es/standards-agent-kit.es26.js.map +0 -1
  196. package/dist/es/standards-agent-kit.es27.js +0 -28
  197. package/dist/es/standards-agent-kit.es27.js.map +0 -1
  198. package/dist/es/tools/AcceptConnectionRequestTool.d.ts +0 -33
  199. package/dist/es/tools/CheckMessagesTool.d.ts +0 -34
  200. package/dist/es/tools/ConnectionMonitorTool.d.ts +0 -100
  201. package/dist/es/tools/ConnectionTool.d.ts +0 -40
  202. package/dist/es/tools/FindRegistrationsTool.d.ts +0 -28
  203. package/dist/es/tools/InitiateConnectionTool.d.ts +0 -30
  204. package/dist/es/tools/ListConnectionsTool.d.ts +0 -33
  205. package/dist/es/tools/ListUnapprovedConnectionRequestsTool.d.ts +0 -41
  206. package/dist/es/tools/ManageConnectionRequestsTool.d.ts +0 -38
  207. package/dist/es/tools/RegisterAgentTool.d.ts +0 -188
  208. package/dist/es/tools/RetrieveProfileTool.d.ts +0 -34
  209. package/dist/es/tools/SendMessageToConnectionTool.d.ts +0 -34
  210. package/dist/es/tools/SendMessageTool.d.ts +0 -40
  211. package/dist/umd/agents/index.d.ts +0 -0
  212. package/dist/umd/plugins/BasePlugin.d.ts +0 -28
  213. package/dist/umd/plugins/GenericPlugin.d.ts +0 -17
  214. package/dist/umd/plugins/HCS10Plugin.d.ts +0 -13
  215. package/dist/umd/plugins/PluginLoader.d.ts +0 -38
  216. package/dist/umd/plugins/openconvai/OpenConvAIPlugin.d.ts +0 -23
  217. package/dist/umd/plugins/openconvai/index.d.ts +0 -1
  218. package/dist/umd/tools/AcceptConnectionRequestTool.d.ts +0 -33
  219. package/dist/umd/tools/CheckMessagesTool.d.ts +0 -34
  220. package/dist/umd/tools/ConnectionMonitorTool.d.ts +0 -100
  221. package/dist/umd/tools/ConnectionTool.d.ts +0 -40
  222. package/dist/umd/tools/FindRegistrationsTool.d.ts +0 -28
  223. package/dist/umd/tools/InitiateConnectionTool.d.ts +0 -30
  224. package/dist/umd/tools/ListConnectionsTool.d.ts +0 -33
  225. package/dist/umd/tools/ListUnapprovedConnectionRequestsTool.d.ts +0 -41
  226. package/dist/umd/tools/ManageConnectionRequestsTool.d.ts +0 -38
  227. package/dist/umd/tools/RegisterAgentTool.d.ts +0 -188
  228. package/dist/umd/tools/RetrieveProfileTool.d.ts +0 -34
  229. package/dist/umd/tools/SendMessageToConnectionTool.d.ts +0 -34
  230. package/dist/umd/tools/SendMessageTool.d.ts +0 -40
  231. package/src/agents/index.ts +0 -1
  232. package/src/plugins/BasePlugin.ts +0 -37
  233. package/src/plugins/GenericPlugin.ts +0 -19
  234. package/src/plugins/HCS10Plugin.ts +0 -14
  235. package/src/plugins/PluginLoader.ts +0 -121
  236. package/src/plugins/README.md +0 -113
  237. package/src/plugins/openconvai/OpenConvAIPlugin.ts +0 -124
  238. package/src/plugins/openconvai/index.ts +0 -1
  239. package/src/tools/AcceptConnectionRequestTool.ts +0 -196
  240. package/src/tools/CheckMessagesTool.ts +0 -194
  241. package/src/tools/ConnectionMonitorTool.ts +0 -550
  242. package/src/tools/ConnectionTool.ts +0 -231
  243. package/src/tools/FindRegistrationsTool.ts +0 -114
  244. package/src/tools/InitiateConnectionTool.ts +0 -137
  245. package/src/tools/ListConnectionsTool.ts +0 -158
  246. package/src/tools/ListUnapprovedConnectionRequestsTool.ts +0 -173
  247. package/src/tools/ManageConnectionRequestsTool.ts +0 -275
  248. package/src/tools/RegisterAgentTool.ts +0 -590
  249. package/src/tools/RetrieveProfileTool.ts +0 -94
  250. package/src/tools/SendMessageToConnectionTool.ts +0 -142
  251. 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
- }