@hashgraphonline/standards-agent-kit 0.2.101 → 0.2.103

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 (187) hide show
  1. package/dist/cjs/builders/hcs2/hcs2-builder.d.ts +50 -0
  2. package/dist/cjs/builders/hcs2/index.d.ts +1 -0
  3. package/dist/cjs/builders/index.d.ts +2 -0
  4. package/dist/cjs/builders/inscriber/index.d.ts +1 -0
  5. package/dist/cjs/builders/inscriber/inscriber-builder.d.ts +46 -0
  6. package/dist/cjs/index.d.ts +1 -1
  7. package/dist/cjs/standards-agent-kit.cjs +1 -1
  8. package/dist/cjs/standards-agent-kit.cjs.map +1 -1
  9. package/dist/cjs/tools/hcs10/FindRegistrationsTool.d.ts +4 -4
  10. package/dist/cjs/tools/hcs10/RegisterAgentTool.d.ts +10 -4
  11. package/dist/cjs/tools/hcs10/index.d.ts +1 -0
  12. package/dist/cjs/tools/hcs10/natural-language-mapper.d.ts +19 -0
  13. package/dist/cjs/tools/hcs2/CreateRegistryTool.d.ts +48 -0
  14. package/dist/cjs/tools/hcs2/DeleteEntryTool.d.ts +41 -0
  15. package/dist/cjs/tools/hcs2/MigrateRegistryTool.d.ts +47 -0
  16. package/dist/cjs/tools/hcs2/QueryRegistryTool.d.ts +47 -0
  17. package/dist/cjs/tools/hcs2/RegisterEntryTool.d.ts +47 -0
  18. package/dist/cjs/tools/hcs2/UpdateEntryTool.d.ts +53 -0
  19. package/dist/cjs/tools/hcs2/base-hcs2-tools.d.ts +28 -0
  20. package/dist/cjs/tools/hcs2/hcs2-tool-params.d.ts +18 -0
  21. package/dist/cjs/tools/hcs2/index.d.ts +8 -0
  22. package/dist/cjs/tools/index.d.ts +2 -0
  23. package/dist/cjs/tools/inscriber/InscribeFromBufferTool.d.ts +77 -0
  24. package/dist/cjs/tools/inscriber/InscribeFromFileTool.d.ts +65 -0
  25. package/dist/cjs/tools/inscriber/InscribeFromUrlTool.d.ts +65 -0
  26. package/dist/cjs/tools/inscriber/InscribeHashinalTool.d.ts +125 -0
  27. package/dist/cjs/tools/inscriber/RetrieveInscriptionTool.d.ts +35 -0
  28. package/dist/cjs/tools/inscriber/base-inscriber-tools.d.ts +28 -0
  29. package/dist/cjs/tools/inscriber/index.d.ts +7 -0
  30. package/dist/cjs/tools/inscriber/inscriber-tool-params.d.ts +18 -0
  31. package/dist/es/builders/hcs2/hcs2-builder.d.ts +50 -0
  32. package/dist/es/builders/hcs2/index.d.ts +1 -0
  33. package/dist/es/builders/index.d.ts +2 -0
  34. package/dist/es/builders/inscriber/index.d.ts +1 -0
  35. package/dist/es/builders/inscriber/inscriber-builder.d.ts +46 -0
  36. package/dist/es/index.d.ts +1 -1
  37. package/dist/es/standards-agent-kit.es.js +50 -16
  38. package/dist/es/standards-agent-kit.es.js.map +1 -1
  39. package/dist/es/standards-agent-kit.es10.js +17 -23
  40. package/dist/es/standards-agent-kit.es10.js.map +1 -1
  41. package/dist/es/standards-agent-kit.es11.js +36 -58
  42. package/dist/es/standards-agent-kit.es11.js.map +1 -1
  43. package/dist/es/standards-agent-kit.es12.js +43 -18
  44. package/dist/es/standards-agent-kit.es12.js.map +1 -1
  45. package/dist/es/standards-agent-kit.es13.js +53 -16
  46. package/dist/es/standards-agent-kit.es13.js.map +1 -1
  47. package/dist/es/standards-agent-kit.es14.js +18 -28
  48. package/dist/es/standards-agent-kit.es14.js.map +1 -1
  49. package/dist/es/standards-agent-kit.es15.js +26 -12
  50. package/dist/es/standards-agent-kit.es15.js.map +1 -1
  51. package/dist/es/standards-agent-kit.es16.js +37 -241
  52. package/dist/es/standards-agent-kit.es16.js.map +1 -1
  53. package/dist/es/standards-agent-kit.es17.js +16 -136
  54. package/dist/es/standards-agent-kit.es17.js.map +1 -1
  55. package/dist/es/standards-agent-kit.es18.js +154 -27
  56. package/dist/es/standards-agent-kit.es18.js.map +1 -1
  57. package/dist/es/standards-agent-kit.es19.js +26 -22
  58. package/dist/es/standards-agent-kit.es19.js.map +1 -1
  59. package/dist/es/standards-agent-kit.es20.js +42 -3
  60. package/dist/es/standards-agent-kit.es20.js.map +1 -1
  61. package/dist/es/standards-agent-kit.es21.js +48 -0
  62. package/dist/es/standards-agent-kit.es21.js.map +1 -0
  63. package/dist/es/standards-agent-kit.es22.js +51 -0
  64. package/dist/es/standards-agent-kit.es22.js.map +1 -0
  65. package/dist/es/standards-agent-kit.es23.js +45 -0
  66. package/dist/es/standards-agent-kit.es23.js.map +1 -0
  67. package/dist/es/standards-agent-kit.es24.js +48 -0
  68. package/dist/es/standards-agent-kit.es24.js.map +1 -0
  69. package/dist/es/standards-agent-kit.es25.js +45 -0
  70. package/dist/es/standards-agent-kit.es25.js.map +1 -0
  71. package/dist/es/standards-agent-kit.es26.js +32 -0
  72. package/dist/es/standards-agent-kit.es26.js.map +1 -0
  73. package/dist/es/standards-agent-kit.es27.js +71 -0
  74. package/dist/es/standards-agent-kit.es27.js.map +1 -0
  75. package/dist/es/standards-agent-kit.es28.js +71 -0
  76. package/dist/es/standards-agent-kit.es28.js.map +1 -0
  77. package/dist/es/standards-agent-kit.es29.js +79 -0
  78. package/dist/es/standards-agent-kit.es29.js.map +1 -0
  79. package/dist/es/standards-agent-kit.es3.js +59 -296
  80. package/dist/es/standards-agent-kit.es3.js.map +1 -1
  81. package/dist/es/standards-agent-kit.es30.js +90 -0
  82. package/dist/es/standards-agent-kit.es30.js.map +1 -0
  83. package/dist/es/standards-agent-kit.es31.js +45 -0
  84. package/dist/es/standards-agent-kit.es31.js.map +1 -0
  85. package/dist/es/standards-agent-kit.es32.js +249 -0
  86. package/dist/es/standards-agent-kit.es32.js.map +1 -0
  87. package/dist/es/standards-agent-kit.es33.js +141 -0
  88. package/dist/es/standards-agent-kit.es33.js.map +1 -0
  89. package/dist/es/standards-agent-kit.es34.js +33 -0
  90. package/dist/es/standards-agent-kit.es34.js.map +1 -0
  91. package/dist/es/standards-agent-kit.es35.js +28 -0
  92. package/dist/es/standards-agent-kit.es35.js.map +1 -0
  93. package/dist/es/standards-agent-kit.es36.js +7 -0
  94. package/dist/es/standards-agent-kit.es36.js.map +1 -0
  95. package/dist/es/standards-agent-kit.es4.js +44 -20
  96. package/dist/es/standards-agent-kit.es4.js.map +1 -1
  97. package/dist/es/standards-agent-kit.es5.js +302 -184
  98. package/dist/es/standards-agent-kit.es5.js.map +1 -1
  99. package/dist/es/standards-agent-kit.es6.js +24 -23
  100. package/dist/es/standards-agent-kit.es6.js.map +1 -1
  101. package/dist/es/standards-agent-kit.es7.js +220 -20
  102. package/dist/es/standards-agent-kit.es7.js.map +1 -1
  103. package/dist/es/standards-agent-kit.es8.js +20 -29
  104. package/dist/es/standards-agent-kit.es8.js.map +1 -1
  105. package/dist/es/standards-agent-kit.es9.js +26 -36
  106. package/dist/es/standards-agent-kit.es9.js.map +1 -1
  107. package/dist/es/tools/hcs10/FindRegistrationsTool.d.ts +4 -4
  108. package/dist/es/tools/hcs10/RegisterAgentTool.d.ts +10 -4
  109. package/dist/es/tools/hcs10/index.d.ts +1 -0
  110. package/dist/es/tools/hcs10/natural-language-mapper.d.ts +19 -0
  111. package/dist/es/tools/hcs2/CreateRegistryTool.d.ts +48 -0
  112. package/dist/es/tools/hcs2/DeleteEntryTool.d.ts +41 -0
  113. package/dist/es/tools/hcs2/MigrateRegistryTool.d.ts +47 -0
  114. package/dist/es/tools/hcs2/QueryRegistryTool.d.ts +47 -0
  115. package/dist/es/tools/hcs2/RegisterEntryTool.d.ts +47 -0
  116. package/dist/es/tools/hcs2/UpdateEntryTool.d.ts +53 -0
  117. package/dist/es/tools/hcs2/base-hcs2-tools.d.ts +28 -0
  118. package/dist/es/tools/hcs2/hcs2-tool-params.d.ts +18 -0
  119. package/dist/es/tools/hcs2/index.d.ts +8 -0
  120. package/dist/es/tools/index.d.ts +2 -0
  121. package/dist/es/tools/inscriber/InscribeFromBufferTool.d.ts +77 -0
  122. package/dist/es/tools/inscriber/InscribeFromFileTool.d.ts +65 -0
  123. package/dist/es/tools/inscriber/InscribeFromUrlTool.d.ts +65 -0
  124. package/dist/es/tools/inscriber/InscribeHashinalTool.d.ts +125 -0
  125. package/dist/es/tools/inscriber/RetrieveInscriptionTool.d.ts +35 -0
  126. package/dist/es/tools/inscriber/base-inscriber-tools.d.ts +28 -0
  127. package/dist/es/tools/inscriber/index.d.ts +7 -0
  128. package/dist/es/tools/inscriber/inscriber-tool-params.d.ts +18 -0
  129. package/dist/umd/builders/hcs2/hcs2-builder.d.ts +50 -0
  130. package/dist/umd/builders/hcs2/index.d.ts +1 -0
  131. package/dist/umd/builders/index.d.ts +2 -0
  132. package/dist/umd/builders/inscriber/index.d.ts +1 -0
  133. package/dist/umd/builders/inscriber/inscriber-builder.d.ts +46 -0
  134. package/dist/umd/index.d.ts +1 -1
  135. package/dist/umd/standards-agent-kit.umd.js +1 -1
  136. package/dist/umd/standards-agent-kit.umd.js.map +1 -1
  137. package/dist/umd/tools/hcs10/FindRegistrationsTool.d.ts +4 -4
  138. package/dist/umd/tools/hcs10/RegisterAgentTool.d.ts +10 -4
  139. package/dist/umd/tools/hcs10/index.d.ts +1 -0
  140. package/dist/umd/tools/hcs10/natural-language-mapper.d.ts +19 -0
  141. package/dist/umd/tools/hcs2/CreateRegistryTool.d.ts +48 -0
  142. package/dist/umd/tools/hcs2/DeleteEntryTool.d.ts +41 -0
  143. package/dist/umd/tools/hcs2/MigrateRegistryTool.d.ts +47 -0
  144. package/dist/umd/tools/hcs2/QueryRegistryTool.d.ts +47 -0
  145. package/dist/umd/tools/hcs2/RegisterEntryTool.d.ts +47 -0
  146. package/dist/umd/tools/hcs2/UpdateEntryTool.d.ts +53 -0
  147. package/dist/umd/tools/hcs2/base-hcs2-tools.d.ts +28 -0
  148. package/dist/umd/tools/hcs2/hcs2-tool-params.d.ts +18 -0
  149. package/dist/umd/tools/hcs2/index.d.ts +8 -0
  150. package/dist/umd/tools/index.d.ts +2 -0
  151. package/dist/umd/tools/inscriber/InscribeFromBufferTool.d.ts +77 -0
  152. package/dist/umd/tools/inscriber/InscribeFromFileTool.d.ts +65 -0
  153. package/dist/umd/tools/inscriber/InscribeFromUrlTool.d.ts +65 -0
  154. package/dist/umd/tools/inscriber/InscribeHashinalTool.d.ts +125 -0
  155. package/dist/umd/tools/inscriber/RetrieveInscriptionTool.d.ts +35 -0
  156. package/dist/umd/tools/inscriber/base-inscriber-tools.d.ts +28 -0
  157. package/dist/umd/tools/inscriber/index.d.ts +7 -0
  158. package/dist/umd/tools/inscriber/inscriber-tool-params.d.ts +18 -0
  159. package/package.json +33 -31
  160. package/src/builders/hcs2/hcs2-builder.ts +148 -0
  161. package/src/builders/hcs2/index.ts +1 -0
  162. package/src/builders/index.ts +3 -1
  163. package/src/builders/inscriber/index.ts +1 -0
  164. package/src/builders/inscriber/inscriber-builder.ts +112 -0
  165. package/src/index.ts +1 -1
  166. package/src/tools/hcs10/FindRegistrationsTool.ts +19 -4
  167. package/src/tools/hcs10/RegisterAgentTool.ts +37 -5
  168. package/src/tools/hcs10/index.ts +2 -1
  169. package/src/tools/hcs10/natural-language-mapper.ts +194 -0
  170. package/src/tools/hcs2/CreateRegistryTool.ts +63 -0
  171. package/src/tools/hcs2/DeleteEntryTool.ts +58 -0
  172. package/src/tools/hcs2/MigrateRegistryTool.ts +64 -0
  173. package/src/tools/hcs2/QueryRegistryTool.ts +70 -0
  174. package/src/tools/hcs2/RegisterEntryTool.ts +63 -0
  175. package/src/tools/hcs2/UpdateEntryTool.ts +68 -0
  176. package/src/tools/hcs2/base-hcs2-tools.ts +65 -0
  177. package/src/tools/hcs2/hcs2-tool-params.ts +21 -0
  178. package/src/tools/hcs2/index.ts +8 -0
  179. package/src/tools/index.ts +3 -2
  180. package/src/tools/inscriber/InscribeFromBufferTool.ts +105 -0
  181. package/src/tools/inscriber/InscribeFromFileTool.ts +93 -0
  182. package/src/tools/inscriber/InscribeFromUrlTool.ts +93 -0
  183. package/src/tools/inscriber/InscribeHashinalTool.ts +117 -0
  184. package/src/tools/inscriber/RetrieveInscriptionTool.ts +59 -0
  185. package/src/tools/inscriber/base-inscriber-tools.ts +65 -0
  186. package/src/tools/inscriber/index.ts +7 -0
  187. package/src/tools/inscriber/inscriber-tool-params.ts +21 -0
@@ -1,33 +1,160 @@
1
- import { BasePlugin, HederaGetHbarPriceTool } from "hedera-agent-kit";
2
- import { HederaGetHbarPriceTool as HederaGetHbarPriceTool2 } from "hedera-agent-kit";
3
- class HbarPricePlugin extends BasePlugin {
4
- constructor() {
5
- super(...arguments);
6
- this.id = "hedera-hbar-price";
7
- this.name = "Hedera HBAR Price Plugin";
8
- this.description = "Provides tools to interact with Hedera network data, specifically HBAR price.";
9
- this.version = "1.0.0";
10
- this.author = "Hashgraph Online";
11
- this.tools = [];
1
+ import { AIAgentCapability } from "@hashgraphonline/standards-sdk";
2
+ const _NaturalLanguageMapper = class _NaturalLanguageMapper {
3
+ /**
4
+ * Parse natural language text and extract capability values
5
+ */
6
+ static parseCapabilities(text) {
7
+ if (!text) return [AIAgentCapability.TEXT_GENERATION];
8
+ const normalizedText = text.toLowerCase();
9
+ const capabilities = /* @__PURE__ */ new Set();
10
+ for (const [term, caps] of Object.entries(this.CAPABILITY_MAPPINGS)) {
11
+ if (normalizedText.includes(term)) {
12
+ caps.forEach((cap) => capabilities.add(cap));
13
+ }
14
+ }
15
+ if (capabilities.size === 0) {
16
+ capabilities.add(AIAgentCapability.TEXT_GENERATION);
17
+ }
18
+ return Array.from(capabilities);
12
19
  }
13
- async initialize(context) {
14
- await super.initialize(context);
15
- this.initializeTools();
20
+ /**
21
+ * Parse tags/capabilities from various input formats
22
+ */
23
+ static parseTagsOrCapabilities(input) {
24
+ if (Array.isArray(input) && input.every((item) => typeof item === "number")) {
25
+ return input;
26
+ }
27
+ if (Array.isArray(input) && input.every((item) => typeof item === "string")) {
28
+ const capabilities = /* @__PURE__ */ new Set();
29
+ input.forEach((term) => {
30
+ this.parseCapabilities(term).forEach((cap) => capabilities.add(cap));
31
+ });
32
+ return Array.from(capabilities);
33
+ }
34
+ if (typeof input === "string") {
35
+ return this.parseCapabilities(input);
36
+ }
37
+ return [AIAgentCapability.TEXT_GENERATION];
16
38
  }
17
- initializeTools() {
18
- this.tools = [
19
- new HederaGetHbarPriceTool({
20
- hederaKit: this.context.config.hederaKit,
21
- logger: this.context.logger
22
- })
23
- ];
39
+ /**
40
+ * Convert capability enum to human-readable name
41
+ */
42
+ static getCapabilityName(capability) {
43
+ const names = {
44
+ [AIAgentCapability.TEXT_GENERATION]: "Text Generation",
45
+ [AIAgentCapability.IMAGE_GENERATION]: "Image Generation",
46
+ [AIAgentCapability.AUDIO_GENERATION]: "Audio Generation",
47
+ [AIAgentCapability.VIDEO_GENERATION]: "Video Generation",
48
+ [AIAgentCapability.CODE_GENERATION]: "Code Generation",
49
+ [AIAgentCapability.LANGUAGE_TRANSLATION]: "Language Translation",
50
+ [AIAgentCapability.SUMMARIZATION_EXTRACTION]: "Summarization & Extraction",
51
+ [AIAgentCapability.KNOWLEDGE_RETRIEVAL]: "Knowledge Retrieval",
52
+ [AIAgentCapability.DATA_INTEGRATION]: "Data Integration",
53
+ [AIAgentCapability.MARKET_INTELLIGENCE]: "Market Intelligence",
54
+ [AIAgentCapability.TRANSACTION_ANALYTICS]: "Transaction Analytics",
55
+ [AIAgentCapability.SMART_CONTRACT_AUDIT]: "Smart Contract Audit",
56
+ [AIAgentCapability.GOVERNANCE_FACILITATION]: "Governance Facilitation",
57
+ [AIAgentCapability.SECURITY_MONITORING]: "Security Monitoring",
58
+ [AIAgentCapability.COMPLIANCE_ANALYSIS]: "Compliance Analysis",
59
+ [AIAgentCapability.FRAUD_DETECTION]: "Fraud Detection",
60
+ [AIAgentCapability.MULTI_AGENT_COORDINATION]: "Multi-Agent Coordination",
61
+ [AIAgentCapability.API_INTEGRATION]: "API Integration",
62
+ [AIAgentCapability.WORKFLOW_AUTOMATION]: "Workflow Automation"
63
+ };
64
+ return names[capability] || "Unknown Capability";
24
65
  }
25
- getTools() {
26
- return this.tools;
27
- }
28
- }
66
+ };
67
+ _NaturalLanguageMapper.CAPABILITY_MAPPINGS = {
68
+ // Common terms
69
+ "ai": [AIAgentCapability.TEXT_GENERATION],
70
+ "artificial intelligence": [AIAgentCapability.TEXT_GENERATION],
71
+ "chat": [AIAgentCapability.TEXT_GENERATION],
72
+ "conversation": [AIAgentCapability.TEXT_GENERATION],
73
+ "text": [AIAgentCapability.TEXT_GENERATION],
74
+ "text generation": [AIAgentCapability.TEXT_GENERATION],
75
+ // Image
76
+ "image": [AIAgentCapability.IMAGE_GENERATION],
77
+ "picture": [AIAgentCapability.IMAGE_GENERATION],
78
+ "visual": [AIAgentCapability.IMAGE_GENERATION],
79
+ "photo": [AIAgentCapability.IMAGE_GENERATION],
80
+ // Audio
81
+ "audio": [AIAgentCapability.AUDIO_GENERATION],
82
+ "sound": [AIAgentCapability.AUDIO_GENERATION],
83
+ "voice": [AIAgentCapability.AUDIO_GENERATION],
84
+ "speech": [AIAgentCapability.AUDIO_GENERATION],
85
+ // Video
86
+ "video": [AIAgentCapability.VIDEO_GENERATION],
87
+ "movie": [AIAgentCapability.VIDEO_GENERATION],
88
+ "animation": [AIAgentCapability.VIDEO_GENERATION],
89
+ // Code
90
+ "code": [AIAgentCapability.CODE_GENERATION],
91
+ "programming": [AIAgentCapability.CODE_GENERATION],
92
+ "development": [AIAgentCapability.CODE_GENERATION],
93
+ "coding": [AIAgentCapability.CODE_GENERATION],
94
+ // Translation
95
+ "translate": [AIAgentCapability.LANGUAGE_TRANSLATION],
96
+ "translation": [AIAgentCapability.LANGUAGE_TRANSLATION],
97
+ "language": [AIAgentCapability.LANGUAGE_TRANSLATION],
98
+ // Summarization
99
+ "summarize": [AIAgentCapability.SUMMARIZATION_EXTRACTION],
100
+ "summary": [AIAgentCapability.SUMMARIZATION_EXTRACTION],
101
+ "extract": [AIAgentCapability.SUMMARIZATION_EXTRACTION],
102
+ "extraction": [AIAgentCapability.SUMMARIZATION_EXTRACTION],
103
+ // Knowledge
104
+ "knowledge": [AIAgentCapability.KNOWLEDGE_RETRIEVAL],
105
+ "search": [AIAgentCapability.KNOWLEDGE_RETRIEVAL],
106
+ "retrieve": [AIAgentCapability.KNOWLEDGE_RETRIEVAL],
107
+ "lookup": [AIAgentCapability.KNOWLEDGE_RETRIEVAL],
108
+ // Data
109
+ "data": [AIAgentCapability.DATA_INTEGRATION],
110
+ "data processing": [AIAgentCapability.DATA_INTEGRATION],
111
+ "data integration": [AIAgentCapability.DATA_INTEGRATION],
112
+ "etl": [AIAgentCapability.DATA_INTEGRATION],
113
+ // Market
114
+ "market": [AIAgentCapability.MARKET_INTELLIGENCE],
115
+ "trading": [AIAgentCapability.MARKET_INTELLIGENCE],
116
+ "finance": [AIAgentCapability.MARKET_INTELLIGENCE],
117
+ "financial": [AIAgentCapability.MARKET_INTELLIGENCE],
118
+ // Analytics
119
+ "analytics": [AIAgentCapability.TRANSACTION_ANALYTICS],
120
+ "analysis": [AIAgentCapability.TRANSACTION_ANALYTICS],
121
+ "analyze": [AIAgentCapability.TRANSACTION_ANALYTICS],
122
+ "transactions": [AIAgentCapability.TRANSACTION_ANALYTICS],
123
+ // Smart Contract
124
+ "audit": [AIAgentCapability.SMART_CONTRACT_AUDIT],
125
+ "contract": [AIAgentCapability.SMART_CONTRACT_AUDIT],
126
+ "smart contract": [AIAgentCapability.SMART_CONTRACT_AUDIT],
127
+ // Governance
128
+ "governance": [AIAgentCapability.GOVERNANCE_FACILITATION],
129
+ "voting": [AIAgentCapability.GOVERNANCE_FACILITATION],
130
+ "dao": [AIAgentCapability.GOVERNANCE_FACILITATION],
131
+ // Security
132
+ "security": [AIAgentCapability.SECURITY_MONITORING],
133
+ "monitoring": [AIAgentCapability.SECURITY_MONITORING],
134
+ "threat": [AIAgentCapability.SECURITY_MONITORING],
135
+ // Compliance
136
+ "compliance": [AIAgentCapability.COMPLIANCE_ANALYSIS],
137
+ "regulatory": [AIAgentCapability.COMPLIANCE_ANALYSIS],
138
+ "regulation": [AIAgentCapability.COMPLIANCE_ANALYSIS],
139
+ // Fraud
140
+ "fraud": [AIAgentCapability.FRAUD_DETECTION],
141
+ "detection": [AIAgentCapability.FRAUD_DETECTION],
142
+ "anomaly": [AIAgentCapability.FRAUD_DETECTION],
143
+ // Multi-agent
144
+ "coordination": [AIAgentCapability.MULTI_AGENT_COORDINATION],
145
+ "multi-agent": [AIAgentCapability.MULTI_AGENT_COORDINATION],
146
+ "orchestration": [AIAgentCapability.MULTI_AGENT_COORDINATION],
147
+ // API
148
+ "api": [AIAgentCapability.API_INTEGRATION],
149
+ "integration": [AIAgentCapability.API_INTEGRATION],
150
+ "webhook": [AIAgentCapability.API_INTEGRATION],
151
+ // Workflow
152
+ "workflow": [AIAgentCapability.WORKFLOW_AUTOMATION],
153
+ "automation": [AIAgentCapability.WORKFLOW_AUTOMATION],
154
+ "process": [AIAgentCapability.WORKFLOW_AUTOMATION]
155
+ };
156
+ let NaturalLanguageMapper = _NaturalLanguageMapper;
29
157
  export {
30
- HederaGetHbarPriceTool2 as GetHbarPriceTool,
31
- HbarPricePlugin
158
+ NaturalLanguageMapper
32
159
  };
33
160
  //# sourceMappingURL=standards-agent-kit.es18.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"standards-agent-kit.es18.js","sources":["../../src/plugins/hedera/HbarPricePlugin.ts"],"sourcesContent":["// Re-export the HBAR price tool from hedera-agent-kit\nexport { HederaGetHbarPriceTool as GetHbarPriceTool } from 'hedera-agent-kit';\n\nimport { BasePlugin, GenericPluginContext, HederaTool, HederaAgentKit } from 'hedera-agent-kit';\nimport { HederaGetHbarPriceTool } from 'hedera-agent-kit';\n\n/**\n * Plugin to provide tools related to Hedera network information, like HBAR price.\n * Uses the built-in HederaGetHbarPriceTool from hedera-agent-kit.\n */\nexport class HbarPricePlugin extends BasePlugin<GenericPluginContext> {\n id = 'hedera-hbar-price';\n name = 'Hedera HBAR Price Plugin';\n description = 'Provides tools to interact with Hedera network data, specifically HBAR price.';\n version = '1.0.0';\n author = 'Hashgraph Online';\n\n private tools: HederaTool[] = [];\n\n override async initialize(context: GenericPluginContext): Promise<void> {\n await super.initialize(context);\n this.initializeTools();\n }\n\n private initializeTools(): void {\n this.tools = [\n new HederaGetHbarPriceTool({\n hederaKit: this.context.config.hederaKit as HederaAgentKit,\n logger: this.context.logger\n })\n ];\n }\n\n getTools(): HederaTool[] {\n return this.tools;\n }\n}"],"names":["HederaGetHbarPriceTool"],"mappings":";;AAUO,MAAM,wBAAwB,WAAiC;AAAA,EAA/D,cAAA;AAAA,UAAA,GAAA,SAAA;AACL,SAAA,KAAK;AACL,SAAA,OAAO;AACP,SAAA,cAAc;AACd,SAAA,UAAU;AACV,SAAA,SAAS;AAET,SAAQ,QAAsB,CAAA;AAAA,EAAC;AAAA,EAE/B,MAAe,WAAW,SAA8C;AACtE,UAAM,MAAM,WAAW,OAAO;AAC9B,SAAK,gBAAA;AAAA,EACP;AAAA,EAEQ,kBAAwB;AAC9B,SAAK,QAAQ;AAAA,MACX,IAAIA,uBAAuB;AAAA,QACzB,WAAW,KAAK,QAAQ,OAAO;AAAA,QAC/B,QAAQ,KAAK,QAAQ;AAAA,MAAA,CACtB;AAAA,IAAA;AAAA,EAEL;AAAA,EAEA,WAAyB;AACvB,WAAO,KAAK;AAAA,EACd;AACF;"}
1
+ {"version":3,"file":"standards-agent-kit.es18.js","sources":["../../src/tools/hcs10/natural-language-mapper.ts"],"sourcesContent":["import { AIAgentCapability } from '@hashgraphonline/standards-sdk';\n\n/**\n * Maps natural language terms to AIAgentCapability enum values\n */\nexport class NaturalLanguageMapper {\n private static readonly CAPABILITY_MAPPINGS: Record<string, AIAgentCapability[]> = {\n // Common terms\n 'ai': [AIAgentCapability.TEXT_GENERATION],\n 'artificial intelligence': [AIAgentCapability.TEXT_GENERATION],\n 'chat': [AIAgentCapability.TEXT_GENERATION],\n 'conversation': [AIAgentCapability.TEXT_GENERATION],\n 'text': [AIAgentCapability.TEXT_GENERATION],\n 'text generation': [AIAgentCapability.TEXT_GENERATION],\n \n // Image\n 'image': [AIAgentCapability.IMAGE_GENERATION],\n 'picture': [AIAgentCapability.IMAGE_GENERATION],\n 'visual': [AIAgentCapability.IMAGE_GENERATION],\n 'photo': [AIAgentCapability.IMAGE_GENERATION],\n \n // Audio\n 'audio': [AIAgentCapability.AUDIO_GENERATION],\n 'sound': [AIAgentCapability.AUDIO_GENERATION],\n 'voice': [AIAgentCapability.AUDIO_GENERATION],\n 'speech': [AIAgentCapability.AUDIO_GENERATION],\n \n // Video\n 'video': [AIAgentCapability.VIDEO_GENERATION],\n 'movie': [AIAgentCapability.VIDEO_GENERATION],\n 'animation': [AIAgentCapability.VIDEO_GENERATION],\n \n // Code\n 'code': [AIAgentCapability.CODE_GENERATION],\n 'programming': [AIAgentCapability.CODE_GENERATION],\n 'development': [AIAgentCapability.CODE_GENERATION],\n 'coding': [AIAgentCapability.CODE_GENERATION],\n \n // Translation\n 'translate': [AIAgentCapability.LANGUAGE_TRANSLATION],\n 'translation': [AIAgentCapability.LANGUAGE_TRANSLATION],\n 'language': [AIAgentCapability.LANGUAGE_TRANSLATION],\n \n // Summarization\n 'summarize': [AIAgentCapability.SUMMARIZATION_EXTRACTION],\n 'summary': [AIAgentCapability.SUMMARIZATION_EXTRACTION],\n 'extract': [AIAgentCapability.SUMMARIZATION_EXTRACTION],\n 'extraction': [AIAgentCapability.SUMMARIZATION_EXTRACTION],\n \n // Knowledge\n 'knowledge': [AIAgentCapability.KNOWLEDGE_RETRIEVAL],\n 'search': [AIAgentCapability.KNOWLEDGE_RETRIEVAL],\n 'retrieve': [AIAgentCapability.KNOWLEDGE_RETRIEVAL],\n 'lookup': [AIAgentCapability.KNOWLEDGE_RETRIEVAL],\n \n // Data\n 'data': [AIAgentCapability.DATA_INTEGRATION],\n 'data processing': [AIAgentCapability.DATA_INTEGRATION],\n 'data integration': [AIAgentCapability.DATA_INTEGRATION],\n 'etl': [AIAgentCapability.DATA_INTEGRATION],\n \n // Market\n 'market': [AIAgentCapability.MARKET_INTELLIGENCE],\n 'trading': [AIAgentCapability.MARKET_INTELLIGENCE],\n 'finance': [AIAgentCapability.MARKET_INTELLIGENCE],\n 'financial': [AIAgentCapability.MARKET_INTELLIGENCE],\n \n // Analytics\n 'analytics': [AIAgentCapability.TRANSACTION_ANALYTICS],\n 'analysis': [AIAgentCapability.TRANSACTION_ANALYTICS],\n 'analyze': [AIAgentCapability.TRANSACTION_ANALYTICS],\n 'transactions': [AIAgentCapability.TRANSACTION_ANALYTICS],\n \n // Smart Contract\n 'audit': [AIAgentCapability.SMART_CONTRACT_AUDIT],\n 'contract': [AIAgentCapability.SMART_CONTRACT_AUDIT],\n 'smart contract': [AIAgentCapability.SMART_CONTRACT_AUDIT],\n \n // Governance\n 'governance': [AIAgentCapability.GOVERNANCE_FACILITATION],\n 'voting': [AIAgentCapability.GOVERNANCE_FACILITATION],\n 'dao': [AIAgentCapability.GOVERNANCE_FACILITATION],\n \n // Security\n 'security': [AIAgentCapability.SECURITY_MONITORING],\n 'monitoring': [AIAgentCapability.SECURITY_MONITORING],\n 'threat': [AIAgentCapability.SECURITY_MONITORING],\n \n // Compliance\n 'compliance': [AIAgentCapability.COMPLIANCE_ANALYSIS],\n 'regulatory': [AIAgentCapability.COMPLIANCE_ANALYSIS],\n 'regulation': [AIAgentCapability.COMPLIANCE_ANALYSIS],\n \n // Fraud\n 'fraud': [AIAgentCapability.FRAUD_DETECTION],\n 'detection': [AIAgentCapability.FRAUD_DETECTION],\n 'anomaly': [AIAgentCapability.FRAUD_DETECTION],\n \n // Multi-agent\n 'coordination': [AIAgentCapability.MULTI_AGENT_COORDINATION],\n 'multi-agent': [AIAgentCapability.MULTI_AGENT_COORDINATION],\n 'orchestration': [AIAgentCapability.MULTI_AGENT_COORDINATION],\n \n // API\n 'api': [AIAgentCapability.API_INTEGRATION],\n 'integration': [AIAgentCapability.API_INTEGRATION],\n 'webhook': [AIAgentCapability.API_INTEGRATION],\n \n // Workflow\n 'workflow': [AIAgentCapability.WORKFLOW_AUTOMATION],\n 'automation': [AIAgentCapability.WORKFLOW_AUTOMATION],\n 'process': [AIAgentCapability.WORKFLOW_AUTOMATION],\n };\n\n /**\n * Parse natural language text and extract capability values\n */\n static parseCapabilities(text: string): AIAgentCapability[] {\n if (!text) return [AIAgentCapability.TEXT_GENERATION];\n \n const normalizedText = text.toLowerCase();\n const capabilities = new Set<AIAgentCapability>();\n \n // Check for exact matches first\n for (const [term, caps] of Object.entries(this.CAPABILITY_MAPPINGS)) {\n if (normalizedText.includes(term)) {\n caps.forEach(cap => capabilities.add(cap));\n }\n }\n \n // Default to TEXT_GENERATION if no capabilities found\n if (capabilities.size === 0) {\n capabilities.add(AIAgentCapability.TEXT_GENERATION);\n }\n \n return Array.from(capabilities);\n }\n\n /**\n * Parse tags/capabilities from various input formats\n */\n static parseTagsOrCapabilities(input: any): AIAgentCapability[] {\n // If already an array of numbers, return as is\n if (Array.isArray(input) && input.every(item => typeof item === 'number')) {\n return input;\n }\n \n // If array of strings, parse each\n if (Array.isArray(input) && input.every(item => typeof item === 'string')) {\n const capabilities = new Set<AIAgentCapability>();\n input.forEach(term => {\n this.parseCapabilities(term).forEach(cap => capabilities.add(cap));\n });\n return Array.from(capabilities);\n }\n \n // If single string, parse it\n if (typeof input === 'string') {\n return this.parseCapabilities(input);\n }\n \n // Default\n return [AIAgentCapability.TEXT_GENERATION];\n }\n\n /**\n * Convert capability enum to human-readable name\n */\n static getCapabilityName(capability: AIAgentCapability): string {\n const names: Record<AIAgentCapability, string> = {\n [AIAgentCapability.TEXT_GENERATION]: 'Text Generation',\n [AIAgentCapability.IMAGE_GENERATION]: 'Image Generation',\n [AIAgentCapability.AUDIO_GENERATION]: 'Audio Generation',\n [AIAgentCapability.VIDEO_GENERATION]: 'Video Generation',\n [AIAgentCapability.CODE_GENERATION]: 'Code Generation',\n [AIAgentCapability.LANGUAGE_TRANSLATION]: 'Language Translation',\n [AIAgentCapability.SUMMARIZATION_EXTRACTION]: 'Summarization & Extraction',\n [AIAgentCapability.KNOWLEDGE_RETRIEVAL]: 'Knowledge Retrieval',\n [AIAgentCapability.DATA_INTEGRATION]: 'Data Integration',\n [AIAgentCapability.MARKET_INTELLIGENCE]: 'Market Intelligence',\n [AIAgentCapability.TRANSACTION_ANALYTICS]: 'Transaction Analytics',\n [AIAgentCapability.SMART_CONTRACT_AUDIT]: 'Smart Contract Audit',\n [AIAgentCapability.GOVERNANCE_FACILITATION]: 'Governance Facilitation',\n [AIAgentCapability.SECURITY_MONITORING]: 'Security Monitoring',\n [AIAgentCapability.COMPLIANCE_ANALYSIS]: 'Compliance Analysis',\n [AIAgentCapability.FRAUD_DETECTION]: 'Fraud Detection',\n [AIAgentCapability.MULTI_AGENT_COORDINATION]: 'Multi-Agent Coordination',\n [AIAgentCapability.API_INTEGRATION]: 'API Integration',\n [AIAgentCapability.WORKFLOW_AUTOMATION]: 'Workflow Automation',\n };\n \n return names[capability] || 'Unknown Capability';\n }\n}"],"names":[],"mappings":"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"}
@@ -1,28 +1,32 @@
1
- import "@hashgraphonline/standards-sdk";
2
- import fs from "fs";
3
- import path from "path";
4
- const ENV_FILE_PATH = path.join(process.cwd(), ".env");
5
- async function updateEnvFile(envFilePath, variables) {
6
- let envContent = "";
7
- if (fs.existsSync(envFilePath)) {
8
- envContent = fs.readFileSync(envFilePath, "utf8");
1
+ import { BaseHederaTransactionTool, BaseHederaQueryTool } from "hedera-agent-kit";
2
+ class BaseHCS2TransactionTool extends BaseHederaTransactionTool {
3
+ constructor(params) {
4
+ super(params);
5
+ this.namespace = "hcs2";
6
+ this.hcs2Builder = params.hcs2Builder;
9
7
  }
10
- const envLines = envContent.split("\n");
11
- const updatedLines = [...envLines];
12
- for (const [key, value] of Object.entries(variables)) {
13
- const lineIndex = updatedLines.findIndex(
14
- (line) => line.startsWith(`${key}=`)
15
- );
16
- if (lineIndex !== -1) {
17
- updatedLines[lineIndex] = `${key}=${value}`;
18
- } else {
19
- updatedLines.push(`${key}=${value}`);
20
- }
8
+ /**
9
+ * Override to return the HCS2Builder
10
+ */
11
+ getServiceBuilder() {
12
+ return this.hcs2Builder;
13
+ }
14
+ }
15
+ class BaseHCS2QueryTool extends BaseHederaQueryTool {
16
+ constructor(params) {
17
+ super(params);
18
+ this.namespace = "hcs2";
19
+ this.hcs2Builder = params.hcs2Builder;
20
+ }
21
+ /**
22
+ * Override to return the HCS2Builder
23
+ */
24
+ getServiceBuilder() {
25
+ return this.hcs2Builder;
21
26
  }
22
- fs.writeFileSync(envFilePath, updatedLines.join("\n"));
23
27
  }
24
28
  export {
25
- ENV_FILE_PATH,
26
- updateEnvFile
29
+ BaseHCS2QueryTool,
30
+ BaseHCS2TransactionTool
27
31
  };
28
32
  //# sourceMappingURL=standards-agent-kit.es19.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"standards-agent-kit.es19.js","sources":["../../src/utils/state-tools.ts"],"sourcesContent":["import {\n HCS10Client,\n AgentBuilder,\n Logger,\n} from '@hashgraphonline/standards-sdk';\nimport fs from 'fs';\nimport path from 'path';\nimport { ensureAgentHasEnoughHbar } from './ensure-agent-has-hbar';\n\nexport const ENV_FILE_PATH = path.join(process.cwd(), '.env');\n\nexport interface AgentData {\n accountId: string;\n operatorId: string;\n inboundTopicId: string;\n outboundTopicId: string;\n client: HCS10Client;\n}\n\nexport interface RegistrationProgressData {\n registered: boolean;\n accountId?: string;\n privateKey?: string;\n publicKey?: string;\n inboundTopicId?: string;\n outboundTopicId?: string;\n}\n\nexport async function getAgentFromEnv(\n logger: Logger,\n baseClient: HCS10Client,\n agentName: string,\n envPrefix: string\n): Promise<AgentData | null> {\n const accountIdEnvVar = `${envPrefix}_ACCOUNT_ID`;\n const privateKeyEnvVar = `${envPrefix}_PRIVATE_KEY`;\n const inboundTopicIdEnvVar = `${envPrefix}_INBOUND_TOPIC_ID`;\n const outboundTopicIdEnvVar = `${envPrefix}_OUTBOUND_TOPIC_ID`;\n\n const accountId = process.env[accountIdEnvVar];\n const privateKey = process.env[privateKeyEnvVar];\n const inboundTopicId = process.env[inboundTopicIdEnvVar];\n const outboundTopicId = process.env[outboundTopicIdEnvVar];\n\n if (!accountId || !privateKey || !inboundTopicId || !outboundTopicId) {\n logger.info(`${agentName} agent not found in environment variables`);\n return null;\n }\n\n logger.info(`${agentName} agent found in environment variables`);\n logger.info(`${agentName} account ID: ${accountId}`);\n logger.info(`${agentName} inbound topic ID: ${inboundTopicId}`);\n logger.info(`${agentName} outbound topic ID: ${outboundTopicId}`);\n\n const client = new HCS10Client({\n network: 'testnet',\n operatorId: accountId,\n operatorPrivateKey: privateKey,\n guardedRegistryBaseUrl: process.env.REGISTRY_URL,\n prettyPrint: true,\n logLevel: 'debug',\n });\n\n await ensureAgentHasEnoughHbar(logger, baseClient, accountId, agentName);\n\n return {\n accountId,\n operatorId: `${inboundTopicId}@${accountId}`,\n inboundTopicId,\n outboundTopicId,\n client,\n };\n}\n\nexport async function createAgent(\n logger: Logger,\n baseClient: HCS10Client,\n agentName: string,\n agentBuilder: AgentBuilder,\n envPrefix: string\n): Promise<AgentData | null> {\n try {\n logger.info(`Creating ${agentName} agent...`);\n\n const result = await baseClient.createAndRegisterAgent(agentBuilder);\n\n if (!result.metadata) {\n logger.error(`${agentName} agent creation failed`);\n return null;\n }\n\n logger.info(`${agentName} agent created successfully`);\n logger.info(`${agentName} account ID: ${result.metadata.accountId}`);\n logger.info(`${agentName} private key: ${result.metadata.privateKey}`);\n logger.info(\n `${agentName} inbound topic ID: ${result.metadata.inboundTopicId}`\n );\n logger.info(\n `${agentName} outbound topic ID: ${result.metadata.outboundTopicId}`\n );\n\n const envVars = {\n [`${envPrefix}_ACCOUNT_ID`]: result.metadata.accountId,\n [`${envPrefix}_PRIVATE_KEY`]: result.metadata.privateKey,\n [`${envPrefix}_INBOUND_TOPIC_ID`]: result.metadata.inboundTopicId,\n [`${envPrefix}_OUTBOUND_TOPIC_ID`]: result.metadata.outboundTopicId,\n };\n\n await updateEnvFile(ENV_FILE_PATH, envVars);\n\n const client = new HCS10Client({\n network: 'testnet',\n operatorId: result.metadata.accountId,\n operatorPrivateKey: result.metadata.privateKey,\n guardedRegistryBaseUrl: process.env.REGISTRY_URL,\n prettyPrint: true,\n logLevel: 'debug',\n });\n\n return {\n accountId: result.metadata.accountId,\n operatorId: `${result.metadata.inboundTopicId}@${result.metadata.accountId}`,\n inboundTopicId: result.metadata.inboundTopicId,\n outboundTopicId: result.metadata.outboundTopicId,\n client,\n };\n } catch (error) {\n console.log('error', error, baseClient);\n logger.error(`Error creating ${agentName} agent:`, error);\n return null;\n }\n}\n\nexport async function updateEnvFile(\n envFilePath: string,\n variables: Record<string, string>\n): Promise<void> {\n let envContent = '';\n\n if (fs.existsSync(envFilePath)) {\n envContent = fs.readFileSync(envFilePath, 'utf8');\n }\n\n const envLines = envContent.split('\\n');\n const updatedLines = [...envLines];\n\n for (const [key, value] of Object.entries(variables)) {\n const lineIndex = updatedLines.findIndex((line) =>\n line.startsWith(`${key}=`)\n );\n\n if (lineIndex !== -1) {\n updatedLines[lineIndex] = `${key}=${value}`;\n } else {\n updatedLines.push(`${key}=${value}`);\n }\n }\n\n fs.writeFileSync(envFilePath, updatedLines.join('\\n'));\n}\n"],"names":[],"mappings":";;;AASO,MAAM,gBAAgB,KAAK,KAAK,QAAQ,IAAA,GAAO,MAAM;AA4H5D,eAAsB,cACpB,aACA,WACe;AACf,MAAI,aAAa;AAEjB,MAAI,GAAG,WAAW,WAAW,GAAG;AAC9B,iBAAa,GAAG,aAAa,aAAa,MAAM;AAAA,EAClD;AAEA,QAAM,WAAW,WAAW,MAAM,IAAI;AACtC,QAAM,eAAe,CAAC,GAAG,QAAQ;AAEjC,aAAW,CAAC,KAAK,KAAK,KAAK,OAAO,QAAQ,SAAS,GAAG;AACpD,UAAM,YAAY,aAAa;AAAA,MAAU,CAAC,SACxC,KAAK,WAAW,GAAG,GAAG,GAAG;AAAA,IAAA;AAG3B,QAAI,cAAc,IAAI;AACpB,mBAAa,SAAS,IAAI,GAAG,GAAG,IAAI,KAAK;AAAA,IAC3C,OAAO;AACL,mBAAa,KAAK,GAAG,GAAG,IAAI,KAAK,EAAE;AAAA,IACrC;AAAA,EACF;AAEA,KAAG,cAAc,aAAa,aAAa,KAAK,IAAI,CAAC;AACvD;"}
1
+ {"version":3,"file":"standards-agent-kit.es19.js","sources":["../../src/tools/hcs2/base-hcs2-tools.ts"],"sourcesContent":["import {\n BaseHederaTransactionTool,\n BaseHederaQueryTool,\n BaseServiceBuilder,\n} from 'hedera-agent-kit';\nimport { HCS2Builder } from '../../builders/hcs2/hcs2-builder';\nimport {\n HCS2TransactionToolParams,\n HCS2QueryToolParams,\n} from './hcs2-tool-params';\nimport { z } from 'zod';\n\n/**\n * Base class for HCS2 transaction tools\n */\nexport abstract class BaseHCS2TransactionTool<\n T extends z.ZodObject<\n z.ZodRawShape,\n z.UnknownKeysParam,\n z.ZodTypeAny\n > = z.ZodObject<z.ZodRawShape>\n> extends BaseHederaTransactionTool<T> {\n protected hcs2Builder: HCS2Builder;\n namespace = 'hcs2' as const;\n\n constructor(params: HCS2TransactionToolParams) {\n super(params);\n this.hcs2Builder = params.hcs2Builder;\n }\n\n /**\n * Override to return the HCS2Builder\n */\n protected getServiceBuilder(): BaseServiceBuilder {\n return this.hcs2Builder;\n }\n}\n\n/**\n * Base class for HCS2 query tools\n */\nexport abstract class BaseHCS2QueryTool<\n T extends z.ZodObject<\n z.ZodRawShape,\n z.UnknownKeysParam,\n z.ZodTypeAny,\n Record<string, unknown>,\n Record<string, unknown>\n > = z.ZodObject<z.ZodRawShape>\n> extends BaseHederaQueryTool<T> {\n protected hcs2Builder: HCS2Builder;\n namespace = 'hcs2' as const;\n\n constructor(params: HCS2QueryToolParams) {\n super(params);\n this.hcs2Builder = params.hcs2Builder;\n }\n\n /**\n * Override to return the HCS2Builder\n */\n protected getServiceBuilder(): BaseServiceBuilder {\n return this.hcs2Builder;\n }\n}"],"names":[],"mappings":";AAeO,MAAe,gCAMZ,0BAA6B;AAAA,EAIrC,YAAY,QAAmC;AAC7C,UAAM,MAAM;AAHd,SAAA,YAAY;AAIV,SAAK,cAAc,OAAO;AAAA,EAC5B;AAAA;AAAA;AAAA;AAAA,EAKU,oBAAwC;AAChD,WAAO,KAAK;AAAA,EACd;AACF;AAKO,MAAe,0BAQZ,oBAAuB;AAAA,EAI/B,YAAY,QAA6B;AACvC,UAAM,MAAM;AAHd,SAAA,YAAY;AAIV,SAAK,cAAc,OAAO;AAAA,EAC5B;AAAA;AAAA;AAAA;AAAA,EAKU,oBAAwC;AAChD,WAAO,KAAK;AAAA,EACd;AACF;"}
@@ -1,7 +1,46 @@
1
- function encryptMessage(message) {
2
- return message;
1
+ import { z } from "zod";
2
+ import { BaseHCS2QueryTool } from "./standards-agent-kit.es19.js";
3
+ import { HCS2RegistryType } from "@hashgraphonline/standards-sdk";
4
+ const createRegistrySchema = z.object({
5
+ registryType: z.nativeEnum(HCS2RegistryType).optional().describe("Registry type: 0 for indexed, 1 for non-indexed (default: 0)"),
6
+ ttl: z.number().int().positive().optional().describe("Time to live in seconds (default: 86400)"),
7
+ adminKey: z.union([z.string(), z.boolean()]).optional().describe("Admin key: public key string or true to use operator key"),
8
+ submitKey: z.union([z.string(), z.boolean()]).optional().describe("Submit key: public key string or true to use operator key")
9
+ });
10
+ class CreateRegistryTool extends BaseHCS2QueryTool {
11
+ constructor() {
12
+ super(...arguments);
13
+ this.name = "createHCS2Registry";
14
+ this.description = "Create a new HCS-2 registry topic for storing decentralized data";
15
+ }
16
+ get specificInputSchema() {
17
+ return createRegistrySchema;
18
+ }
19
+ async executeQuery(params, _runManager) {
20
+ try {
21
+ const result = await this.hcs2Builder.createRegistry({
22
+ registryType: params.registryType,
23
+ ttl: params.ttl,
24
+ adminKey: params.adminKey,
25
+ submitKey: params.submitKey
26
+ });
27
+ if (!result.success) {
28
+ throw new Error(result.error || "Failed to create registry");
29
+ }
30
+ return `Successfully created HCS-2 registry!
31
+
32
+ Topic ID: ${result.topicId}
33
+ Registry Type: ${params.registryType === 1 ? "Non-Indexed" : "Indexed"}
34
+ TTL: ${params.ttl || 86400} seconds
35
+
36
+ You can now register entries to this registry using the topic ID.`;
37
+ } catch (error) {
38
+ const errorMessage = error instanceof Error ? error.message : "Failed to create HCS-2 registry";
39
+ throw new Error(`Registry creation failed: ${errorMessage}`);
40
+ }
41
+ }
3
42
  }
4
43
  export {
5
- encryptMessage
44
+ CreateRegistryTool
6
45
  };
7
46
  //# sourceMappingURL=standards-agent-kit.es20.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"standards-agent-kit.es20.js","sources":["../../src/utils/Encryption.ts"],"sourcesContent":["// src/utils/Encryption.ts\n/**\n * Placeholder for encryption functionality.\n * Currently, encryption is disabled. The useEncryption flag is false by default.\n * TODO: Implement actual encryption/decryption logic.\n */\n\nexport function encryptMessage(message: string): string {\n // TODO: Add encryption logic here if useEncryption flag is true.\n return message; // currently returns plaintext.\n}\n\nexport function decryptMessage(encryptedMessage: string): string {\n // TODO: Add decryption logic here.\n return encryptedMessage;\n}\n"],"names":[],"mappings":"AAOO,SAAS,eAAe,SAAyB;AAEpD,SAAO;AACX;"}
1
+ {"version":3,"file":"standards-agent-kit.es20.js","sources":["../../src/tools/hcs2/CreateRegistryTool.ts"],"sourcesContent":["import { z } from 'zod';\nimport { BaseHCS2QueryTool } from './base-hcs2-tools';\nimport { HCS2RegistryType } from '@hashgraphonline/standards-sdk';\nimport { CallbackManagerForToolRun } from '@langchain/core/callbacks/manager';\n\n/**\n * Schema for creating an HCS-2 registry\n */\nconst createRegistrySchema = z.object({\n registryType: z\n .nativeEnum(HCS2RegistryType)\n .optional()\n .describe('Registry type: 0 for indexed, 1 for non-indexed (default: 0)'),\n ttl: z\n .number()\n .int()\n .positive()\n .optional()\n .describe('Time to live in seconds (default: 86400)'),\n adminKey: z\n .union([z.string(), z.boolean()])\n .optional()\n .describe('Admin key: public key string or true to use operator key'),\n submitKey: z\n .union([z.string(), z.boolean()])\n .optional()\n .describe('Submit key: public key string or true to use operator key'),\n});\n\n/**\n * Tool for creating HCS-2 registries\n */\nexport class CreateRegistryTool extends BaseHCS2QueryTool<typeof createRegistrySchema> {\n name = 'createHCS2Registry';\n description = 'Create a new HCS-2 registry topic for storing decentralized data';\n\n get specificInputSchema() {\n return createRegistrySchema;\n }\n\n protected async executeQuery(\n params: z.infer<typeof createRegistrySchema>,\n _runManager?: CallbackManagerForToolRun\n ): Promise<unknown> {\n try {\n const result = await this.hcs2Builder.createRegistry({\n registryType: params.registryType,\n ttl: params.ttl,\n adminKey: params.adminKey,\n submitKey: params.submitKey,\n });\n\n if (!result.success) {\n throw new Error(result.error || 'Failed to create registry');\n }\n\n return `Successfully created HCS-2 registry!\\n\\nTopic ID: ${result.topicId}\\nRegistry Type: ${params.registryType === 1 ? 'Non-Indexed' : 'Indexed'}\\nTTL: ${params.ttl || 86400} seconds\\n\\nYou can now register entries to this registry using the topic ID.`;\n } catch (error) {\n const errorMessage = error instanceof Error ? error.message : 'Failed to create HCS-2 registry';\n throw new Error(`Registry creation failed: ${errorMessage}`);\n }\n }\n}"],"names":[],"mappings":";;;AAQA,MAAM,uBAAuB,EAAE,OAAO;AAAA,EACpC,cAAc,EACX,WAAW,gBAAgB,EAC3B,SAAA,EACA,SAAS,8DAA8D;AAAA,EAC1E,KAAK,EACF,OAAA,EACA,IAAA,EACA,SAAA,EACA,SAAA,EACA,SAAS,0CAA0C;AAAA,EACtD,UAAU,EACP,MAAM,CAAC,EAAE,OAAA,GAAU,EAAE,QAAA,CAAS,CAAC,EAC/B,SAAA,EACA,SAAS,0DAA0D;AAAA,EACtE,WAAW,EACR,MAAM,CAAC,EAAE,OAAA,GAAU,EAAE,QAAA,CAAS,CAAC,EAC/B,SAAA,EACA,SAAS,2DAA2D;AACzE,CAAC;AAKM,MAAM,2BAA2B,kBAA+C;AAAA,EAAhF,cAAA;AAAA,UAAA,GAAA,SAAA;AACL,SAAA,OAAO;AACP,SAAA,cAAc;AAAA,EAAA;AAAA,EAEd,IAAI,sBAAsB;AACxB,WAAO;AAAA,EACT;AAAA,EAEA,MAAgB,aACd,QACA,aACkB;AAClB,QAAI;AACF,YAAM,SAAS,MAAM,KAAK,YAAY,eAAe;AAAA,QACnD,cAAc,OAAO;AAAA,QACrB,KAAK,OAAO;AAAA,QACZ,UAAU,OAAO;AAAA,QACjB,WAAW,OAAO;AAAA,MAAA,CACnB;AAED,UAAI,CAAC,OAAO,SAAS;AACnB,cAAM,IAAI,MAAM,OAAO,SAAS,2BAA2B;AAAA,MAC7D;AAEA,aAAO;AAAA;AAAA,YAAqD,OAAO,OAAO;AAAA,iBAAoB,OAAO,iBAAiB,IAAI,gBAAgB,SAAS;AAAA,OAAU,OAAO,OAAO,KAAK;AAAA;AAAA;AAAA,IAClL,SAAS,OAAO;AACd,YAAM,eAAe,iBAAiB,QAAQ,MAAM,UAAU;AAC9D,YAAM,IAAI,MAAM,6BAA6B,YAAY,EAAE;AAAA,IAC7D;AAAA,EACF;AACF;"}
@@ -0,0 +1,48 @@
1
+ import { z } from "zod";
2
+ import { BaseHCS2QueryTool } from "./standards-agent-kit.es19.js";
3
+ const registerEntrySchema = z.object({
4
+ registryTopicId: z.string().regex(/^\d+\.\d+\.\d+$/).describe("The HCS-2 registry topic ID (e.g., 0.0.123456)"),
5
+ targetTopicId: z.string().regex(/^\d+\.\d+\.\d+$/).describe("The target topic ID to register (e.g., 0.0.123456)"),
6
+ metadata: z.string().optional().describe("Optional metadata URI (HIP-412 format)"),
7
+ memo: z.string().max(500).optional().describe("Optional memo (max 500 characters)")
8
+ });
9
+ class RegisterEntryTool extends BaseHCS2QueryTool {
10
+ constructor() {
11
+ super(...arguments);
12
+ this.name = "registerHCS2Entry";
13
+ this.description = "Register a new entry in an HCS-2 registry";
14
+ }
15
+ get specificInputSchema() {
16
+ return registerEntrySchema;
17
+ }
18
+ async executeQuery(params, _runManager) {
19
+ try {
20
+ const result = await this.hcs2Builder.registerEntry(
21
+ params.registryTopicId,
22
+ {
23
+ targetTopicId: params.targetTopicId,
24
+ metadata: params.metadata,
25
+ memo: params.memo
26
+ }
27
+ );
28
+ if (!result.success) {
29
+ throw new Error(result.error || "Failed to register entry");
30
+ }
31
+ return `Successfully registered entry in HCS-2 registry!
32
+
33
+ Registry Topic: ${params.registryTopicId}
34
+ Target Topic ID: ${params.targetTopicId}${params.metadata ? `
35
+ Metadata: ${params.metadata}` : ""}${params.memo ? `
36
+ Memo: ${params.memo}` : ""}
37
+
38
+ The entry has been added to the registry.`;
39
+ } catch (error) {
40
+ const errorMessage = error instanceof Error ? error.message : "Failed to register entry";
41
+ throw new Error(`Entry registration failed: ${errorMessage}`);
42
+ }
43
+ }
44
+ }
45
+ export {
46
+ RegisterEntryTool
47
+ };
48
+ //# sourceMappingURL=standards-agent-kit.es21.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"standards-agent-kit.es21.js","sources":["../../src/tools/hcs2/RegisterEntryTool.ts"],"sourcesContent":["import { z } from 'zod';\nimport { BaseHCS2QueryTool } from './base-hcs2-tools';\nimport { CallbackManagerForToolRun } from '@langchain/core/callbacks/manager';\n\n/**\n * Schema for registering an entry in HCS-2\n */\nconst registerEntrySchema = z.object({\n registryTopicId: z\n .string()\n .regex(/^\\d+\\.\\d+\\.\\d+$/)\n .describe('The HCS-2 registry topic ID (e.g., 0.0.123456)'),\n targetTopicId: z\n .string()\n .regex(/^\\d+\\.\\d+\\.\\d+$/)\n .describe('The target topic ID to register (e.g., 0.0.123456)'),\n metadata: z\n .string()\n .optional()\n .describe('Optional metadata URI (HIP-412 format)'),\n memo: z\n .string()\n .max(500)\n .optional()\n .describe('Optional memo (max 500 characters)'),\n});\n\n/**\n * Tool for registering entries in HCS-2 registries\n */\nexport class RegisterEntryTool extends BaseHCS2QueryTool<typeof registerEntrySchema> {\n name = 'registerHCS2Entry';\n description = 'Register a new entry in an HCS-2 registry';\n\n get specificInputSchema() {\n return registerEntrySchema;\n }\n\n protected async executeQuery(\n params: z.infer<typeof registerEntrySchema>,\n _runManager?: CallbackManagerForToolRun\n ): Promise<unknown> {\n try {\n const result = await this.hcs2Builder.registerEntry(\n params.registryTopicId,\n {\n targetTopicId: params.targetTopicId,\n metadata: params.metadata,\n memo: params.memo,\n }\n );\n\n if (!result.success) {\n throw new Error(result.error || 'Failed to register entry');\n }\n\n return `Successfully registered entry in HCS-2 registry!\\n\\nRegistry Topic: ${params.registryTopicId}\\nTarget Topic ID: ${params.targetTopicId}${params.metadata ? `\\nMetadata: ${params.metadata}` : ''}${params.memo ? `\\nMemo: ${params.memo}` : ''}\\n\\nThe entry has been added to the registry.`;\n } catch (error) {\n const errorMessage = error instanceof Error ? error.message : 'Failed to register entry';\n throw new Error(`Entry registration failed: ${errorMessage}`);\n }\n }\n}"],"names":[],"mappings":";;AAOA,MAAM,sBAAsB,EAAE,OAAO;AAAA,EACnC,iBAAiB,EACd,OAAA,EACA,MAAM,iBAAiB,EACvB,SAAS,gDAAgD;AAAA,EAC5D,eAAe,EACZ,OAAA,EACA,MAAM,iBAAiB,EACvB,SAAS,oDAAoD;AAAA,EAChE,UAAU,EACP,OAAA,EACA,SAAA,EACA,SAAS,wCAAwC;AAAA,EACpD,MAAM,EACH,SACA,IAAI,GAAG,EACP,WACA,SAAS,oCAAoC;AAClD,CAAC;AAKM,MAAM,0BAA0B,kBAA8C;AAAA,EAA9E,cAAA;AAAA,UAAA,GAAA,SAAA;AACL,SAAA,OAAO;AACP,SAAA,cAAc;AAAA,EAAA;AAAA,EAEd,IAAI,sBAAsB;AACxB,WAAO;AAAA,EACT;AAAA,EAEA,MAAgB,aACd,QACA,aACkB;AAClB,QAAI;AACF,YAAM,SAAS,MAAM,KAAK,YAAY;AAAA,QACpC,OAAO;AAAA,QACP;AAAA,UACE,eAAe,OAAO;AAAA,UACtB,UAAU,OAAO;AAAA,UACjB,MAAM,OAAO;AAAA,QAAA;AAAA,MACf;AAGF,UAAI,CAAC,OAAO,SAAS;AACnB,cAAM,IAAI,MAAM,OAAO,SAAS,0BAA0B;AAAA,MAC5D;AAEA,aAAO;AAAA;AAAA,kBAAuE,OAAO,eAAe;AAAA,mBAAsB,OAAO,aAAa,GAAG,OAAO,WAAW;AAAA,YAAe,OAAO,QAAQ,KAAK,EAAE,GAAG,OAAO,OAAO;AAAA,QAAW,OAAO,IAAI,KAAK,EAAE;AAAA;AAAA;AAAA,IACxP,SAAS,OAAO;AACd,YAAM,eAAe,iBAAiB,QAAQ,MAAM,UAAU;AAC9D,YAAM,IAAI,MAAM,8BAA8B,YAAY,EAAE;AAAA,IAC9D;AAAA,EACF;AACF;"}
@@ -0,0 +1,51 @@
1
+ import { z } from "zod";
2
+ import { BaseHCS2QueryTool } from "./standards-agent-kit.es19.js";
3
+ const updateEntrySchema = z.object({
4
+ registryTopicId: z.string().regex(/^\d+\.\d+\.\d+$/).describe("The HCS-2 registry topic ID (must be indexed)"),
5
+ targetTopicId: z.string().regex(/^\d+\.\d+\.\d+$/).describe("The new topic ID to point to"),
6
+ uid: z.string().describe("The unique ID of the entry to update"),
7
+ metadata: z.string().optional().describe("Optional metadata URI (HIP-412 format)"),
8
+ memo: z.string().max(500).optional().describe("Optional memo (max 500 characters)")
9
+ });
10
+ class UpdateEntryTool extends BaseHCS2QueryTool {
11
+ constructor() {
12
+ super(...arguments);
13
+ this.name = "updateHCS2Entry";
14
+ this.description = "Update an existing entry in an indexed HCS-2 registry";
15
+ }
16
+ get specificInputSchema() {
17
+ return updateEntrySchema;
18
+ }
19
+ async executeQuery(params, _runManager) {
20
+ try {
21
+ const result = await this.hcs2Builder.updateEntry(
22
+ params.registryTopicId,
23
+ {
24
+ targetTopicId: params.targetTopicId,
25
+ uid: params.uid,
26
+ metadata: params.metadata,
27
+ memo: params.memo
28
+ }
29
+ );
30
+ if (!result.success) {
31
+ throw new Error(result.error || "Failed to update entry");
32
+ }
33
+ return `Successfully updated entry in HCS-2 registry!
34
+
35
+ Registry Topic: ${params.registryTopicId}
36
+ UID: ${params.uid}
37
+ New Target Topic ID: ${params.targetTopicId}${params.metadata ? `
38
+ Metadata: ${params.metadata}` : ""}${params.memo ? `
39
+ Memo: ${params.memo}` : ""}
40
+
41
+ The entry has been updated in the registry.`;
42
+ } catch (error) {
43
+ const errorMessage = error instanceof Error ? error.message : "Failed to update entry";
44
+ throw new Error(`Entry update failed: ${errorMessage}`);
45
+ }
46
+ }
47
+ }
48
+ export {
49
+ UpdateEntryTool
50
+ };
51
+ //# sourceMappingURL=standards-agent-kit.es22.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"standards-agent-kit.es22.js","sources":["../../src/tools/hcs2/UpdateEntryTool.ts"],"sourcesContent":["import { z } from 'zod';\nimport { BaseHCS2QueryTool } from './base-hcs2-tools';\nimport { CallbackManagerForToolRun } from '@langchain/core/callbacks/manager';\n\n/**\n * Schema for updating an entry in HCS-2\n */\nconst updateEntrySchema = z.object({\n registryTopicId: z\n .string()\n .regex(/^\\d+\\.\\d+\\.\\d+$/)\n .describe('The HCS-2 registry topic ID (must be indexed)'),\n targetTopicId: z\n .string()\n .regex(/^\\d+\\.\\d+\\.\\d+$/)\n .describe('The new topic ID to point to'),\n uid: z\n .string()\n .describe('The unique ID of the entry to update'),\n metadata: z\n .string()\n .optional()\n .describe('Optional metadata URI (HIP-412 format)'),\n memo: z\n .string()\n .max(500)\n .optional()\n .describe('Optional memo (max 500 characters)'),\n});\n\n\n/**\n * Tool for updating entries in HCS-2 registries\n */\nexport class UpdateEntryTool extends BaseHCS2QueryTool<typeof updateEntrySchema> {\n name = 'updateHCS2Entry';\n description = 'Update an existing entry in an indexed HCS-2 registry';\n\n get specificInputSchema() {\n return updateEntrySchema;\n }\n\n protected async executeQuery(\n params: z.infer<typeof updateEntrySchema>,\n _runManager?: CallbackManagerForToolRun\n ): Promise<unknown> {\n try {\n const result = await this.hcs2Builder.updateEntry(\n params.registryTopicId,\n {\n targetTopicId: params.targetTopicId,\n uid: params.uid,\n metadata: params.metadata,\n memo: params.memo,\n }\n );\n\n if (!result.success) {\n throw new Error(result.error || 'Failed to update entry');\n }\n\n return `Successfully updated entry in HCS-2 registry!\\n\\nRegistry Topic: ${params.registryTopicId}\\nUID: ${params.uid}\\nNew Target Topic ID: ${params.targetTopicId}${params.metadata ? `\\nMetadata: ${params.metadata}` : ''}${params.memo ? `\\nMemo: ${params.memo}` : ''}\\n\\nThe entry has been updated in the registry.`;\n } catch (error) {\n const errorMessage = error instanceof Error ? error.message : 'Failed to update entry';\n throw new Error(`Entry update failed: ${errorMessage}`);\n }\n }\n}"],"names":[],"mappings":";;AAOA,MAAM,oBAAoB,EAAE,OAAO;AAAA,EACjC,iBAAiB,EACd,OAAA,EACA,MAAM,iBAAiB,EACvB,SAAS,+CAA+C;AAAA,EAC3D,eAAe,EACZ,OAAA,EACA,MAAM,iBAAiB,EACvB,SAAS,8BAA8B;AAAA,EAC1C,KAAK,EACF,SACA,SAAS,sCAAsC;AAAA,EAClD,UAAU,EACP,OAAA,EACA,SAAA,EACA,SAAS,wCAAwC;AAAA,EACpD,MAAM,EACH,SACA,IAAI,GAAG,EACP,WACA,SAAS,oCAAoC;AAClD,CAAC;AAMM,MAAM,wBAAwB,kBAA4C;AAAA,EAA1E,cAAA;AAAA,UAAA,GAAA,SAAA;AACL,SAAA,OAAO;AACP,SAAA,cAAc;AAAA,EAAA;AAAA,EAEd,IAAI,sBAAsB;AACxB,WAAO;AAAA,EACT;AAAA,EAEA,MAAgB,aACd,QACA,aACkB;AAClB,QAAI;AACF,YAAM,SAAS,MAAM,KAAK,YAAY;AAAA,QACpC,OAAO;AAAA,QACP;AAAA,UACE,eAAe,OAAO;AAAA,UACtB,KAAK,OAAO;AAAA,UACZ,UAAU,OAAO;AAAA,UACjB,MAAM,OAAO;AAAA,QAAA;AAAA,MACf;AAGF,UAAI,CAAC,OAAO,SAAS;AACnB,cAAM,IAAI,MAAM,OAAO,SAAS,wBAAwB;AAAA,MAC1D;AAEA,aAAO;AAAA;AAAA,kBAAoE,OAAO,eAAe;AAAA,OAAU,OAAO,GAAG;AAAA,uBAA0B,OAAO,aAAa,GAAG,OAAO,WAAW;AAAA,YAAe,OAAO,QAAQ,KAAK,EAAE,GAAG,OAAO,OAAO;AAAA,QAAW,OAAO,IAAI,KAAK,EAAE;AAAA;AAAA;AAAA,IAC7Q,SAAS,OAAO;AACd,YAAM,eAAe,iBAAiB,QAAQ,MAAM,UAAU;AAC9D,YAAM,IAAI,MAAM,wBAAwB,YAAY,EAAE;AAAA,IACxD;AAAA,EACF;AACF;"}
@@ -0,0 +1,45 @@
1
+ import { z } from "zod";
2
+ import { BaseHCS2QueryTool } from "./standards-agent-kit.es19.js";
3
+ const deleteEntrySchema = z.object({
4
+ registryTopicId: z.string().regex(/^\d+\.\d+\.\d+$/).describe("The HCS-2 registry topic ID (must be indexed)"),
5
+ uid: z.string().describe("The unique ID of the entry to delete"),
6
+ memo: z.string().max(500).optional().describe("Optional memo (max 500 characters)")
7
+ });
8
+ class DeleteEntryTool extends BaseHCS2QueryTool {
9
+ constructor() {
10
+ super(...arguments);
11
+ this.name = "deleteHCS2Entry";
12
+ this.description = "Delete an entry from an indexed HCS-2 registry";
13
+ }
14
+ get specificInputSchema() {
15
+ return deleteEntrySchema;
16
+ }
17
+ async executeQuery(params, _runManager) {
18
+ try {
19
+ const result = await this.hcs2Builder.deleteEntry(
20
+ params.registryTopicId,
21
+ {
22
+ uid: params.uid,
23
+ memo: params.memo
24
+ }
25
+ );
26
+ if (!result.success) {
27
+ throw new Error(result.error || "Failed to delete entry");
28
+ }
29
+ return `Successfully deleted entry from HCS-2 registry!
30
+
31
+ Registry Topic: ${params.registryTopicId}
32
+ UID: ${params.uid}${params.memo ? `
33
+ Memo: ${params.memo}` : ""}
34
+
35
+ The entry has been removed from the registry.`;
36
+ } catch (error) {
37
+ const errorMessage = error instanceof Error ? error.message : "Failed to delete entry";
38
+ throw new Error(`Entry deletion failed: ${errorMessage}`);
39
+ }
40
+ }
41
+ }
42
+ export {
43
+ DeleteEntryTool
44
+ };
45
+ //# sourceMappingURL=standards-agent-kit.es23.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"standards-agent-kit.es23.js","sources":["../../src/tools/hcs2/DeleteEntryTool.ts"],"sourcesContent":["import { z } from 'zod';\nimport { BaseHCS2QueryTool } from './base-hcs2-tools';\nimport { CallbackManagerForToolRun } from '@langchain/core/callbacks/manager';\n\n/**\n * Schema for deleting an entry from HCS-2\n */\nconst deleteEntrySchema = z.object({\n registryTopicId: z\n .string()\n .regex(/^\\d+\\.\\d+\\.\\d+$/)\n .describe('The HCS-2 registry topic ID (must be indexed)'),\n uid: z\n .string()\n .describe('The unique ID of the entry to delete'),\n memo: z\n .string()\n .max(500)\n .optional()\n .describe('Optional memo (max 500 characters)'),\n});\n\n\n/**\n * Tool for deleting entries from HCS-2 registries\n */\nexport class DeleteEntryTool extends BaseHCS2QueryTool<typeof deleteEntrySchema> {\n name = 'deleteHCS2Entry';\n description = 'Delete an entry from an indexed HCS-2 registry';\n\n get specificInputSchema() {\n return deleteEntrySchema;\n }\n\n protected async executeQuery(\n params: z.infer<typeof deleteEntrySchema>,\n _runManager?: CallbackManagerForToolRun\n ): Promise<unknown> {\n try {\n const result = await this.hcs2Builder.deleteEntry(\n params.registryTopicId,\n {\n uid: params.uid,\n memo: params.memo,\n }\n );\n\n if (!result.success) {\n throw new Error(result.error || 'Failed to delete entry');\n }\n\n return `Successfully deleted entry from HCS-2 registry!\\n\\nRegistry Topic: ${params.registryTopicId}\\nUID: ${params.uid}${params.memo ? `\\nMemo: ${params.memo}` : ''}\\n\\nThe entry has been removed from the registry.`;\n } catch (error) {\n const errorMessage = error instanceof Error ? error.message : 'Failed to delete entry';\n throw new Error(`Entry deletion failed: ${errorMessage}`);\n }\n }\n}"],"names":[],"mappings":";;AAOA,MAAM,oBAAoB,EAAE,OAAO;AAAA,EACjC,iBAAiB,EACd,OAAA,EACA,MAAM,iBAAiB,EACvB,SAAS,+CAA+C;AAAA,EAC3D,KAAK,EACF,SACA,SAAS,sCAAsC;AAAA,EAClD,MAAM,EACH,SACA,IAAI,GAAG,EACP,WACA,SAAS,oCAAoC;AAClD,CAAC;AAMM,MAAM,wBAAwB,kBAA4C;AAAA,EAA1E,cAAA;AAAA,UAAA,GAAA,SAAA;AACL,SAAA,OAAO;AACP,SAAA,cAAc;AAAA,EAAA;AAAA,EAEd,IAAI,sBAAsB;AACxB,WAAO;AAAA,EACT;AAAA,EAEA,MAAgB,aACd,QACA,aACkB;AAClB,QAAI;AACF,YAAM,SAAS,MAAM,KAAK,YAAY;AAAA,QACpC,OAAO;AAAA,QACP;AAAA,UACE,KAAK,OAAO;AAAA,UACZ,MAAM,OAAO;AAAA,QAAA;AAAA,MACf;AAGF,UAAI,CAAC,OAAO,SAAS;AACnB,cAAM,IAAI,MAAM,OAAO,SAAS,wBAAwB;AAAA,MAC1D;AAEA,aAAO;AAAA;AAAA,kBAAsE,OAAO,eAAe;AAAA,OAAU,OAAO,GAAG,GAAG,OAAO,OAAO;AAAA,QAAW,OAAO,IAAI,KAAK,EAAE;AAAA;AAAA;AAAA,IACvK,SAAS,OAAO;AACd,YAAM,eAAe,iBAAiB,QAAQ,MAAM,UAAU;AAC9D,YAAM,IAAI,MAAM,0BAA0B,YAAY,EAAE;AAAA,IAC1D;AAAA,EACF;AACF;"}
@@ -0,0 +1,48 @@
1
+ import { z } from "zod";
2
+ import { BaseHCS2QueryTool } from "./standards-agent-kit.es19.js";
3
+ const migrateRegistrySchema = z.object({
4
+ registryTopicId: z.string().regex(/^\d+\.\d+\.\d+$/).describe("The current HCS-2 registry topic ID"),
5
+ targetTopicId: z.string().regex(/^\d+\.\d+\.\d+$/).describe("The new topic ID to migrate to"),
6
+ metadata: z.string().optional().describe("Optional metadata URI for migration details"),
7
+ memo: z.string().max(500).optional().describe("Optional memo (max 500 characters)")
8
+ });
9
+ class MigrateRegistryTool extends BaseHCS2QueryTool {
10
+ constructor() {
11
+ super(...arguments);
12
+ this.name = "migrateHCS2Registry";
13
+ this.description = "Migrate an HCS-2 registry to a new topic";
14
+ }
15
+ get specificInputSchema() {
16
+ return migrateRegistrySchema;
17
+ }
18
+ async executeQuery(params, _runManager) {
19
+ try {
20
+ const result = await this.hcs2Builder.migrateRegistry(
21
+ params.registryTopicId,
22
+ {
23
+ targetTopicId: params.targetTopicId,
24
+ metadata: params.metadata,
25
+ memo: params.memo
26
+ }
27
+ );
28
+ if (!result.success) {
29
+ throw new Error(result.error || "Failed to migrate registry");
30
+ }
31
+ return `Successfully migrated HCS-2 registry!
32
+
33
+ From Registry Topic: ${params.registryTopicId}
34
+ To Target Topic: ${params.targetTopicId}${params.metadata ? `
35
+ Metadata: ${params.metadata}` : ""}${params.memo ? `
36
+ Memo: ${params.memo}` : ""}
37
+
38
+ The registry has been migrated to the new topic.`;
39
+ } catch (error) {
40
+ const errorMessage = error instanceof Error ? error.message : "Failed to migrate registry";
41
+ throw new Error(`Registry migration failed: ${errorMessage}`);
42
+ }
43
+ }
44
+ }
45
+ export {
46
+ MigrateRegistryTool
47
+ };
48
+ //# sourceMappingURL=standards-agent-kit.es24.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"standards-agent-kit.es24.js","sources":["../../src/tools/hcs2/MigrateRegistryTool.ts"],"sourcesContent":["import { z } from 'zod';\nimport { BaseHCS2QueryTool } from './base-hcs2-tools';\nimport { CallbackManagerForToolRun } from '@langchain/core/callbacks/manager';\n\n/**\n * Schema for migrating an HCS-2 registry\n */\nconst migrateRegistrySchema = z.object({\n registryTopicId: z\n .string()\n .regex(/^\\d+\\.\\d+\\.\\d+$/)\n .describe('The current HCS-2 registry topic ID'),\n targetTopicId: z\n .string()\n .regex(/^\\d+\\.\\d+\\.\\d+$/)\n .describe('The new topic ID to migrate to'),\n metadata: z\n .string()\n .optional()\n .describe('Optional metadata URI for migration details'),\n memo: z\n .string()\n .max(500)\n .optional()\n .describe('Optional memo (max 500 characters)'),\n});\n\n\n/**\n * Tool for migrating HCS-2 registries\n */\nexport class MigrateRegistryTool extends BaseHCS2QueryTool<typeof migrateRegistrySchema> {\n name = 'migrateHCS2Registry';\n description = 'Migrate an HCS-2 registry to a new topic';\n\n get specificInputSchema() {\n return migrateRegistrySchema;\n }\n\n protected async executeQuery(\n params: z.infer<typeof migrateRegistrySchema>,\n _runManager?: CallbackManagerForToolRun\n ): Promise<unknown> {\n try {\n const result = await this.hcs2Builder.migrateRegistry(\n params.registryTopicId,\n {\n targetTopicId: params.targetTopicId,\n metadata: params.metadata,\n memo: params.memo,\n }\n );\n\n if (!result.success) {\n throw new Error(result.error || 'Failed to migrate registry');\n }\n\n return `Successfully migrated HCS-2 registry!\\n\\nFrom Registry Topic: ${params.registryTopicId}\\nTo Target Topic: ${params.targetTopicId}${params.metadata ? `\\nMetadata: ${params.metadata}` : ''}${params.memo ? `\\nMemo: ${params.memo}` : ''}\\n\\nThe registry has been migrated to the new topic.`;\n } catch (error) {\n const errorMessage = error instanceof Error ? error.message : 'Failed to migrate registry';\n throw new Error(`Registry migration failed: ${errorMessage}`);\n }\n }\n}"],"names":[],"mappings":";;AAOA,MAAM,wBAAwB,EAAE,OAAO;AAAA,EACrC,iBAAiB,EACd,OAAA,EACA,MAAM,iBAAiB,EACvB,SAAS,qCAAqC;AAAA,EACjD,eAAe,EACZ,OAAA,EACA,MAAM,iBAAiB,EACvB,SAAS,gCAAgC;AAAA,EAC5C,UAAU,EACP,OAAA,EACA,SAAA,EACA,SAAS,6CAA6C;AAAA,EACzD,MAAM,EACH,SACA,IAAI,GAAG,EACP,WACA,SAAS,oCAAoC;AAClD,CAAC;AAMM,MAAM,4BAA4B,kBAAgD;AAAA,EAAlF,cAAA;AAAA,UAAA,GAAA,SAAA;AACL,SAAA,OAAO;AACP,SAAA,cAAc;AAAA,EAAA;AAAA,EAEd,IAAI,sBAAsB;AACxB,WAAO;AAAA,EACT;AAAA,EAEA,MAAgB,aACd,QACA,aACkB;AAClB,QAAI;AACF,YAAM,SAAS,MAAM,KAAK,YAAY;AAAA,QACpC,OAAO;AAAA,QACP;AAAA,UACE,eAAe,OAAO;AAAA,UACtB,UAAU,OAAO;AAAA,UACjB,MAAM,OAAO;AAAA,QAAA;AAAA,MACf;AAGF,UAAI,CAAC,OAAO,SAAS;AACnB,cAAM,IAAI,MAAM,OAAO,SAAS,4BAA4B;AAAA,MAC9D;AAEA,aAAO;AAAA;AAAA,uBAAiE,OAAO,eAAe;AAAA,mBAAsB,OAAO,aAAa,GAAG,OAAO,WAAW;AAAA,YAAe,OAAO,QAAQ,KAAK,EAAE,GAAG,OAAO,OAAO;AAAA,QAAW,OAAO,IAAI,KAAK,EAAE;AAAA;AAAA;AAAA,IAClP,SAAS,OAAO;AACd,YAAM,eAAe,iBAAiB,QAAQ,MAAM,UAAU;AAC9D,YAAM,IAAI,MAAM,8BAA8B,YAAY,EAAE;AAAA,IAC9D;AAAA,EACF;AACF;"}