UNPKG

@hashgraphonline/standards-agent-kit

Version:

A modular SDK for building on-chain autonomous agents using Hashgraph Online Standards, including HCS-10 for agent discovery and communication.

63 lines (57 loc) 2.03 kB
import { z } from 'zod'; import { BaseHCS2QueryTool } from './base-hcs2-tools'; import { CallbackManagerForToolRun } from '@langchain/core/callbacks/manager'; /** * Schema for registering an entry in HCS-2 */ const registerEntrySchema = z.object({ registryTopicId: z .string() .regex(/^\d+\.\d+\.\d+$/) .describe('The HCS-2 registry topic ID (e.g., 0.0.123456)'), targetTopicId: z .string() .regex(/^\d+\.\d+\.\d+$/) .describe('The target topic ID to register (e.g., 0.0.123456)'), metadata: z .string() .optional() .describe('Optional metadata URI (HIP-412 format)'), memo: z .string() .max(500) .optional() .describe('Optional memo (max 500 characters)'), }); /** * Tool for registering entries in HCS-2 registries */ export class RegisterEntryTool extends BaseHCS2QueryTool<typeof registerEntrySchema> { name = 'registerHCS2Entry'; description = 'Register a new entry in an HCS-2 registry'; get specificInputSchema() { return registerEntrySchema; } protected async executeQuery( params: z.infer<typeof registerEntrySchema>, _runManager?: CallbackManagerForToolRun ): Promise<unknown> { try { const result = await this.hcs2Builder.registerEntry( params.registryTopicId, { targetTopicId: params.targetTopicId, metadata: params.metadata, memo: params.memo, } ); if (!result.success) { throw new Error(result.error || 'Failed to register entry'); } 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.`; } catch (error) { const errorMessage = error instanceof Error ? error.message : 'Failed to register entry'; throw new Error(`Entry registration failed: ${errorMessage}`); } } }