@hashgraphonline/standards-sdk 0.0.197 → 0.0.199
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.
- package/dist/cjs/hcs-11/client.d.ts +40 -40
- package/dist/cjs/hcs-11/client.d.ts.map +1 -1
- package/dist/cjs/hcs-12/validation/schemas.d.ts +8 -8
- package/dist/cjs/hcs-14/did.d.ts.map +1 -1
- package/dist/cjs/standards-sdk.cjs +16 -16
- package/dist/cjs/standards-sdk.cjs.map +1 -1
- package/dist/es/hcs-11/client.d.ts +40 -40
- package/dist/es/hcs-11/client.d.ts.map +1 -1
- package/dist/es/hcs-12/validation/schemas.d.ts +8 -8
- package/dist/es/hcs-14/did.d.ts.map +1 -1
- package/dist/es/standards-sdk.es21.js +10 -5
- package/dist/es/standards-sdk.es21.js.map +1 -1
- package/dist/es/standards-sdk.es50.js +3 -1
- package/dist/es/standards-sdk.es50.js.map +1 -1
- package/dist/es/standards-sdk.es53.js +1 -1
- package/dist/es/standards-sdk.es53.js.map +1 -1
- package/dist/es/standards-sdk.es56.js +1 -1
- package/dist/es/standards-sdk.es56.js.map +1 -1
- package/package.json +1 -1
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"standards-sdk.es21.js","sources":["../../src/hcs-11/client.ts"],"sourcesContent":["import {\n AccountId,\n AccountUpdateTransaction,\n Client,\n PrivateKey,\n Status,\n Transaction,\n} from '@hashgraph/sdk';\nimport {\n inscribe,\n inscribeWithSigner,\n InscriptionInput,\n InscriptionOptions,\n InscriptionResult,\n} from '../inscribe';\nimport { Logger, ILogger, detectKeyTypeFromString, getTopicId } from '../utils';\nimport * as mime from 'mime-types';\nimport { z, ZodIssue } from 'zod';\nimport type { DAppSigner } from '@hashgraph/hedera-wallet-connect';\nimport { ProgressReporter } from '../utils/progress-reporter';\nimport { HederaMirrorNode } from '../services';\nimport { isHederaNetwork, toHederaCaip10 } from '../hcs-14/caip';\nimport { createUaid } from '../hcs-14/did';\nimport { createDID } from '@hiero-did-sdk/registrar';\nimport { TopicInfo } from '../services/types';\nimport {\n ProfileType,\n AIAgentType,\n AIAgentCapability,\n SocialLink,\n PersonalProfile,\n AIAgentProfile,\n HCS11Profile,\n HCS11Auth,\n HCS11ClientConfig,\n TransactionResult,\n InscribeProfileResponse,\n InscribeImageResponse,\n AgentMetadata,\n InscribeImageOptions,\n InscribeProfileOptions,\n capabilityNameToCapabilityMap,\n MCPServerDetails,\n MCPServerProfile,\n MCPServerCapability,\n VerificationType,\n} from './types';\n\nexport const SocialLinkSchema = z.object({\n platform: z.string().min(1),\n handle: z.string().min(1),\n});\n\nexport const AIAgentDetailsSchema = z.object({\n type: z.nativeEnum(AIAgentType),\n capabilities: z.array(z.nativeEnum(AIAgentCapability)).min(1),\n model: z.string().min(1),\n creator: z.string().optional(),\n});\n\nexport const MCPServerConnectionInfoSchema = z.object({\n url: z.string().min(1),\n transport: z.enum(['stdio', 'sse']),\n});\n\nexport const MCPServerVerificationSchema = z.object({\n type: z.nativeEnum(VerificationType),\n value: z.string(),\n dns_field: z.string().optional(),\n challenge_path: z.string().optional(),\n});\n\nexport const MCPServerHostSchema = z.object({\n minVersion: z.string().optional(),\n});\n\nexport const MCPServerResourceSchema = z.object({\n name: z.string().min(1),\n description: z.string().min(1),\n});\n\nexport const MCPServerToolSchema = z.object({\n name: z.string().min(1),\n description: z.string().min(1),\n});\n\nexport const MCPServerDetailsSchema = z.object({\n version: z.string().min(1),\n connectionInfo: MCPServerConnectionInfoSchema,\n services: z.array(z.nativeEnum(MCPServerCapability)).min(1),\n description: z.string().min(1),\n verification: MCPServerVerificationSchema.optional(),\n host: MCPServerHostSchema.optional(),\n capabilities: z.array(z.string()).optional(),\n resources: z.array(MCPServerResourceSchema).optional(),\n tools: z.array(MCPServerToolSchema).optional(),\n maintainer: z.string().optional(),\n repository: z.string().optional(),\n docs: z.string().optional(),\n});\n\nexport const BaseProfileSchema = z.object({\n version: z.string().min(1),\n type: z.nativeEnum(ProfileType),\n display_name: z.string().min(1),\n alias: z.string().optional(),\n bio: z.string().optional(),\n socials: z.array(SocialLinkSchema).optional(),\n profileImage: z.string().optional(),\n uaid: z.string().optional(),\n properties: z.record(z.any()).optional(),\n inboundTopicId: z.string().optional(),\n outboundTopicId: z.string().optional(),\n});\n\nexport const PersonalProfileSchema = BaseProfileSchema.extend({\n type: z.literal(ProfileType.PERSONAL),\n language: z.string().optional(),\n timezone: z.string().optional(),\n});\n\nexport const AIAgentProfileSchema = BaseProfileSchema.extend({\n type: z.literal(ProfileType.AI_AGENT),\n aiAgent: AIAgentDetailsSchema,\n});\n\nexport const MCPServerProfileSchema = BaseProfileSchema.extend({\n type: z.literal(ProfileType.MCP_SERVER),\n mcpServer: MCPServerDetailsSchema,\n});\n\nexport const HCS11ProfileSchema = z.union([\n PersonalProfileSchema,\n AIAgentProfileSchema,\n MCPServerProfileSchema,\n]);\n\nexport class HCS11Client {\n private client: Client;\n private auth: HCS11Auth;\n private network: string;\n private logger: ILogger;\n private mirrorNode: HederaMirrorNode;\n private keyType: 'ed25519' | 'ecdsa';\n private operatorId: string;\n\n constructor(config: HCS11ClientConfig) {\n this.client =\n config.network === 'mainnet' ? Client.forMainnet() : Client.forTestnet();\n this.auth = config.auth;\n this.network = config.network;\n this.operatorId = config.auth.operatorId;\n\n this.logger = Logger.getInstance({\n level: config.logLevel || 'info',\n module: 'HCS-11',\n silent: config.silent,\n });\n\n this.mirrorNode = new HederaMirrorNode(\n this.network as 'mainnet' | 'testnet',\n this.logger,\n );\n\n if (this.auth.privateKey) {\n if (config.keyType) {\n this.keyType = config.keyType;\n this.initializeOperatorWithKeyType();\n } else {\n try {\n const keyDetection = detectKeyTypeFromString(this.auth.privateKey);\n this.keyType = keyDetection.detectedType;\n\n if (keyDetection.warning) {\n this.logger.warn(keyDetection.warning);\n }\n\n this.client.setOperator(this.operatorId, keyDetection.privateKey);\n } catch (error) {\n this.logger.warn(\n 'Failed to detect key type from private key format, will query mirror node',\n );\n this.keyType = 'ecdsa'; // Default to ECDSA\n }\n\n this.initializeOperator();\n }\n }\n }\n\n public getClient(): Client {\n return this.client;\n }\n\n public getOperatorId(): string {\n return this.auth.operatorId;\n }\n\n public async initializeOperator() {\n const account = await this.mirrorNode.requestAccount(this.operatorId);\n const keyType = account?.key?._type;\n\n if (keyType && keyType.includes('ECDSA')) {\n this.keyType = 'ecdsa';\n } else if (keyType && keyType.includes('ED25519')) {\n this.keyType = 'ed25519';\n } else {\n this.keyType = 'ecdsa'; // Default to ECDSA\n }\n\n this.initializeOperatorWithKeyType();\n }\n\n private initializeOperatorWithKeyType() {\n if (!this.auth.privateKey) {\n return;\n }\n\n const PK =\n this.keyType === 'ecdsa'\n ? PrivateKey.fromStringECDSA(this.auth.privateKey)\n : PrivateKey.fromStringED25519(this.auth.privateKey);\n\n this.client.setOperator(this.operatorId, PK);\n }\n\n public createPersonalProfile(\n displayName: string,\n options?: {\n alias?: string;\n bio?: string;\n socials?: SocialLink[];\n profileImage?: string;\n language?: string;\n timezone?: string;\n properties?: Record<string, any>;\n inboundTopicId?: string;\n outboundTopicId?: string;\n },\n ): PersonalProfile {\n return {\n version: '1.0',\n type: ProfileType.PERSONAL,\n display_name: displayName,\n alias: options?.alias,\n bio: options?.bio,\n socials: options?.socials,\n profileImage: options?.profileImage,\n properties: options?.properties,\n inboundTopicId: options?.inboundTopicId,\n outboundTopicId: options?.outboundTopicId,\n };\n }\n\n public createAIAgentProfile(\n displayName: string,\n agentType: AIAgentType,\n capabilities: AIAgentCapability[],\n model: string,\n options?: {\n alias?: string;\n bio?: string;\n socials?: SocialLink[];\n profileImage?: string;\n properties?: Record<string, any>;\n inboundTopicId?: string;\n outboundTopicId?: string;\n creator?: string;\n },\n ): AIAgentProfile {\n const validation = this.validateProfile({\n version: '1.0',\n type: ProfileType.AI_AGENT,\n display_name: displayName,\n alias: options?.alias,\n bio: options?.bio,\n socials: options?.socials,\n profileImage: options?.profileImage,\n properties: options?.properties,\n inboundTopicId: options?.inboundTopicId,\n outboundTopicId: options?.outboundTopicId,\n aiAgent: {\n type: agentType,\n capabilities,\n model,\n creator: options?.creator,\n },\n });\n\n if (!validation.valid) {\n throw new Error(\n `Invalid AI Agent Profile: ${validation.errors.join(', ')}`,\n );\n }\n\n return {\n version: '1.0',\n type: ProfileType.AI_AGENT,\n display_name: displayName,\n alias: options?.alias,\n bio: options?.bio,\n socials: options?.socials,\n profileImage: options?.profileImage,\n properties: options?.properties,\n inboundTopicId: options?.inboundTopicId,\n outboundTopicId: options?.outboundTopicId,\n aiAgent: {\n type: agentType,\n capabilities,\n model,\n creator: options?.creator,\n },\n };\n }\n\n /**\n * Creates an MCP server profile.\n *\n * @param displayName - The display name for the MCP server\n * @param serverDetails - The MCP server details\n * @param options - Additional profile options\n * @returns An MCPServerProfile object\n */\n public createMCPServerProfile(\n displayName: string,\n serverDetails: MCPServerDetails,\n options?: {\n alias?: string;\n bio?: string;\n socials?: SocialLink[];\n profileImage?: string;\n properties?: Record<string, any>;\n inboundTopicId?: string;\n outboundTopicId?: string;\n },\n ): MCPServerProfile {\n const validation = this.validateProfile({\n version: '1.0',\n type: ProfileType.MCP_SERVER,\n display_name: displayName,\n alias: options?.alias,\n bio: options?.bio,\n socials: options?.socials,\n profileImage: options?.profileImage,\n properties: options?.properties,\n inboundTopicId: options?.inboundTopicId,\n outboundTopicId: options?.outboundTopicId,\n mcpServer: serverDetails,\n });\n\n if (!validation.valid) {\n throw new Error(\n `Invalid MCP Server Profile: ${validation.errors.join(', ')}`,\n );\n }\n\n return {\n version: '1.0',\n type: ProfileType.MCP_SERVER,\n display_name: displayName,\n alias: options?.alias,\n bio: options?.bio,\n socials: options?.socials,\n profileImage: options?.profileImage,\n properties: options?.properties,\n inboundTopicId: options?.inboundTopicId,\n outboundTopicId: options?.outboundTopicId,\n mcpServer: serverDetails,\n };\n }\n\n public validateProfile(profile: unknown): {\n valid: boolean;\n errors: string[];\n } {\n const result = HCS11ProfileSchema.safeParse(profile);\n\n if (result.success) {\n return { valid: true, errors: [] };\n }\n\n const formattedErrors = result.error.errors.map((err: ZodIssue) => {\n const path = err.path.join('.');\n let message = err.message;\n\n if (err.code === 'invalid_type') {\n message = `Expected ${err.expected}, got ${err.received}`;\n } else if (err.code === 'invalid_enum_value') {\n const validOptions = err.options?.join(', ');\n message = `Invalid value. Valid options are: ${validOptions}`;\n } else if (err.code === 'too_small' && err.type === 'string') {\n message = 'Cannot be empty';\n }\n\n return `${path}: ${message}`;\n });\n\n return { valid: false, errors: formattedErrors };\n }\n\n public profileToJSONString(profile: HCS11Profile): string {\n return JSON.stringify(profile);\n }\n\n public parseProfileFromString(profileStr: string): HCS11Profile | null {\n try {\n const parsedProfile = JSON.parse(profileStr);\n const validation = this.validateProfile(parsedProfile);\n if (!validation.valid) {\n this.logger.error('Invalid profile format:', validation.errors);\n return null;\n }\n return parsedProfile as HCS11Profile;\n } catch (error) {\n this.logger.error('Error parsing profile:');\n return null;\n }\n }\n\n public setProfileForAccountMemo(\n topicId: string,\n topicStandard: 1 | 2 | 7 = 1,\n ): string {\n return `hcs-11:hcs://${topicStandard}/${topicId}`;\n }\n\n private async executeTransaction<T>(\n transaction: Transaction,\n ): Promise<TransactionResult<T>> {\n try {\n if (this.auth.privateKey) {\n const signedTx = await transaction.signWithOperator(this.client);\n const response = await signedTx.execute(this.client);\n const receipt = await response.getReceipt(this.client);\n\n if (receipt.status.toString() !== Status.Success.toString()) {\n return {\n success: false,\n error: `Transaction failed: ${receipt.status.toString()}`,\n };\n }\n\n return {\n success: true,\n result: receipt as T,\n };\n }\n\n if (!this.auth.signer) {\n throw new Error('No valid authentication method provided');\n }\n\n const signer = this.auth.signer;\n const frozenTransaction = await transaction.freezeWithSigner(signer);\n const response = await frozenTransaction.executeWithSigner(signer);\n const receipt = await response.getReceiptWithSigner(signer);\n\n if (receipt.status.toString() !== Status.Success.toString()) {\n return {\n success: false,\n error: `Transaction failed: ${receipt.status.toString()}: ${Status.Success.toString()}`,\n };\n }\n\n return {\n success: true,\n result: receipt as T,\n };\n } catch (error) {\n return {\n success: false,\n error:\n error instanceof Error\n ? error.message\n : 'Unknown error during transaction execution',\n };\n }\n }\n\n public async inscribeImage(\n buffer: Buffer,\n fileName: string,\n options?: InscribeImageOptions,\n ): Promise<InscribeImageResponse> {\n try {\n const progressCallback = options?.progressCallback;\n const progressReporter = new ProgressReporter({\n module: 'HCS11-Image',\n logger: this.logger,\n callback: progressCallback as any,\n });\n\n progressReporter.preparing('Preparing to inscribe image', 0);\n\n const mimeType = mime.lookup(fileName) || 'application/octet-stream';\n\n const waitForConfirmation = options?.waitForConfirmation ?? true;\n\n let inscriptionResponse;\n if (this.auth.signer) {\n if ('accountId' in this.auth.signer) {\n progressReporter.preparing('Using signer for inscription', 10);\n\n inscriptionResponse = await inscribeWithSigner(\n {\n type: 'buffer',\n buffer,\n fileName,\n mimeType,\n },\n this.auth.signer as DAppSigner,\n {\n network: this.network as 'mainnet' | 'testnet',\n waitForConfirmation,\n waitMaxAttempts: 150,\n waitIntervalMs: 4000,\n logging: {\n level: 'debug',\n },\n progressCallback: data => {\n const adjustedPercent = 10 + (data.progressPercent || 0) * 0.8;\n progressReporter.report({\n stage: data.stage,\n message: data.message,\n progressPercent: adjustedPercent,\n details: data.details,\n });\n },\n },\n );\n } else {\n progressReporter.failed(\n 'Signer must be a DAppSigner for inscription',\n );\n throw new Error('Signer must be a DAppSigner for inscription');\n }\n } else {\n if (!this.auth.privateKey) {\n progressReporter.failed('Private key is required for inscription');\n this.logger.error('Private key is required for inscription');\n throw new Error('Private key is required for inscription');\n }\n\n progressReporter.preparing('Using private key for inscription', 10);\n\n const PK =\n this.keyType === 'ecdsa'\n ? PrivateKey.fromStringECDSA(this.auth.privateKey)\n : PrivateKey.fromStringED25519(this.auth.privateKey);\n\n inscriptionResponse = await inscribe(\n {\n type: 'buffer',\n buffer,\n fileName,\n mimeType,\n },\n {\n accountId: this.auth.operatorId,\n privateKey: PK,\n network: this.network as 'mainnet' | 'testnet',\n },\n {\n waitForConfirmation,\n waitMaxAttempts: 150,\n waitIntervalMs: 2000,\n logging: {\n level: 'debug',\n },\n progressCallback: data => {\n const adjustedPercent = 10 + (data.progressPercent || 0) * 0.8;\n progressReporter.report({\n stage: data.stage,\n message: data.message,\n progressPercent: adjustedPercent,\n details: data.details,\n });\n },\n },\n );\n }\n\n if (inscriptionResponse.confirmed) {\n progressReporter.completed('Image inscription completed', {\n topicId: getTopicId(inscriptionResponse.inscription),\n });\n return {\n imageTopicId: getTopicId(inscriptionResponse.inscription) || '',\n transactionId: (inscriptionResponse.result as InscriptionResult)\n .jobId,\n success: true,\n };\n } else {\n const jobId = inscriptionResponse.quote\n ? 'quote-only'\n : (inscriptionResponse.result as InscriptionResult).jobId;\n progressReporter.verifying('Waiting for inscription confirmation', 50, {\n jobId,\n });\n return {\n imageTopicId: '',\n transactionId: jobId,\n success: false,\n error: 'Inscription not confirmed',\n };\n }\n } catch (error) {\n this.logger.error('Error inscribing image:', error);\n return {\n imageTopicId: '',\n transactionId: '',\n success: false,\n error:\n error instanceof Error ? error.message : 'Error inscribing image',\n };\n }\n }\n\n public async inscribeProfile(\n profile: HCS11Profile,\n options?: InscribeProfileOptions,\n ): Promise<InscribeProfileResponse> {\n this.logger.info('Inscribing HCS-11 profile');\n\n const progressCallback = options?.progressCallback;\n const progressReporter = new ProgressReporter({\n module: 'HCS11-Profile',\n logger: this.logger,\n callback: progressCallback,\n });\n\n await this.attachUaidIfMissing(profile);\n\n progressReporter.preparing('Validating profile data', 5);\n\n const validation = this.validateProfile(profile);\n if (!validation.valid) {\n progressReporter.failed(\n `Invalid profile: ${validation.errors.join(', ')}`,\n );\n return {\n profileTopicId: '',\n transactionId: '',\n success: false,\n error: `Invalid profile: ${validation.errors.join(', ')}`,\n };\n }\n\n progressReporter.preparing('Formatting profile for inscription', 15);\n\n const profileJson = this.profileToJSONString(profile);\n const fileName = `profile-${profile.display_name\n .toLowerCase()\n .replace(/\\s+/g, '-')}.json`;\n\n try {\n const contentBuffer = Buffer.from(profileJson, 'utf-8');\n const contentType = 'application/json';\n\n progressReporter.preparing('Preparing profile for inscription', 20);\n\n const input: InscriptionInput = {\n type: 'buffer',\n buffer: contentBuffer,\n fileName,\n mimeType: contentType,\n };\n\n const inscriptionOptions: InscriptionOptions = {\n waitForConfirmation: true,\n mode: 'file',\n network: this.network as 'mainnet' | 'testnet',\n waitMaxAttempts: 100,\n waitIntervalMs: 2000,\n progressCallback: data => {\n const adjustedPercent =\n 20 + Number(data?.progressPercent || 0) * 0.75;\n progressReporter?.report({\n stage: data.stage,\n message: data.message,\n progressPercent: adjustedPercent,\n details: data.details,\n });\n },\n };\n\n progressReporter.submitting('Submitting profile to Hedera network', 30);\n\n let inscriptionResponse;\n\n if (this.auth.privateKey) {\n const PK =\n this.keyType === 'ecdsa'\n ? PrivateKey.fromStringECDSA(this.auth.privateKey)\n : PrivateKey.fromStringED25519(this.auth.privateKey);\n\n inscriptionResponse = await inscribe(\n input,\n {\n accountId: this.auth.operatorId,\n privateKey: PK,\n network: this.network as 'mainnet' | 'testnet',\n },\n inscriptionOptions,\n );\n } else if (this.auth.signer) {\n inscriptionResponse = await inscribeWithSigner(\n input,\n this.auth.signer as DAppSigner,\n inscriptionOptions,\n );\n } else {\n throw new Error(\n 'No authentication method available - neither private key nor signer',\n );\n }\n\n if (\n !inscriptionResponse.confirmed ||\n !getTopicId(inscriptionResponse.inscription)\n ) {\n progressReporter.failed('Failed to inscribe profile content');\n return {\n profileTopicId: '',\n transactionId: '',\n success: false,\n error: 'Failed to inscribe profile content',\n };\n }\n const topicId = getTopicId(inscriptionResponse.inscription);\n\n progressReporter.completed('Profile inscription completed', {\n topicId,\n transactionId: (inscriptionResponse.result as InscriptionResult)\n .transactionId,\n });\n\n return {\n profileTopicId: topicId,\n transactionId: (inscriptionResponse.result as InscriptionResult)\n .transactionId,\n success: true,\n };\n } catch (error) {\n progressReporter.failed(\n `Error inscribing profile: ${error.message || 'Unknown error'}`,\n );\n return {\n profileTopicId: '',\n transactionId: '',\n success: false,\n error: error.message || 'Unknown error during inscription',\n };\n }\n }\n\n private async attachUaidIfMissing(profile: HCS11Profile): Promise<void> {\n if ((profile as { uaid?: string }).uaid) {\n return;\n }\n if (!isHederaNetwork(this.network)) return;\n try {\n const created = await createDID({ client: this.client });\n const did = created.did;\n const nativeId = toHederaCaip10(this.network, this.auth.operatorId);\n let uid = this.auth.operatorId;\n const inboundFromProfile = profile.inboundTopicId;\n if (inboundFromProfile && inboundFromProfile.trim().length > 0) {\n uid = `${inboundFromProfile}@${this.auth.operatorId}`;\n } else {\n try {\n const fetched = await this.fetchProfileByAccountId(\n this.auth.operatorId,\n this.network as 'mainnet' | 'testnet',\n );\n const inbound = fetched?.topicInfo?.inboundTopic;\n if (inbound && inbound.trim().length > 0) {\n uid = `${inbound}@${this.auth.operatorId}`;\n }\n } catch {}\n }\n\n const uaid = createUaid(did, { proto: 'hcs-10', nativeId, uid });\n (profile as { uaid?: string }).uaid = uaid;\n } catch {\n this.logger.warn(\n 'Hiero registrar not available; skipping UAID generation for profile',\n );\n }\n }\n\n public async updateAccountMemoWithProfile(\n accountId: string | AccountId,\n profileTopicId: string,\n ): Promise<TransactionResult> {\n try {\n this.logger.info(\n `Updating account memo for ${accountId} with profile ${profileTopicId}`,\n );\n const memo = this.setProfileForAccountMemo(profileTopicId);\n\n const transaction = new AccountUpdateTransaction()\n .setAccountMemo(memo)\n .setAccountId(accountId);\n\n return this.executeTransaction(transaction);\n } catch (error) {\n this.logger.error(\n `Error updating account memo: ${\n error instanceof Error ? error.message : 'Unknown error'\n }`,\n );\n return {\n success: false,\n error:\n error instanceof Error\n ? error.message\n : 'Unknown error updating account memo',\n };\n }\n }\n\n /**\n * Creates and inscribes a profile.\n *\n * @param profile - The profile to create and inscribe.\n * @param updateAccountMemo - Whether to update the account memo with the profile.\n * @param options - Optional configuration options.\n * @returns A promise that resolves to the inscription result.\n */\n public async createAndInscribeProfile(\n profile: HCS11Profile,\n updateAccountMemo = true,\n options?: InscribeProfileOptions,\n ): Promise<InscribeProfileResponse> {\n const progressCallback = options?.progressCallback;\n const progressReporter = new ProgressReporter({\n module: 'HCS11-ProfileCreation',\n logger: this.logger,\n callback: progressCallback,\n });\n\n progressReporter.preparing('Starting profile creation process', 0);\n\n const inscriptionProgress = progressReporter.createSubProgress({\n minPercent: 0,\n maxPercent: 80,\n logPrefix: 'Inscription',\n });\n\n const inscriptionResult = await this.inscribeProfile(profile, {\n ...options,\n progressCallback: data => {\n inscriptionProgress.report({\n stage: data.stage,\n message: data.message,\n progressPercent: data.progressPercent,\n details: data.details,\n });\n },\n });\n\n if (!inscriptionResult?.success) {\n progressReporter.failed('Profile inscription failed', {\n error: inscriptionResult?.error,\n });\n return inscriptionResult;\n }\n\n progressReporter.confirming('Profile inscribed, updating account memo', 85);\n\n if (updateAccountMemo) {\n const memoResult = await this.updateAccountMemoWithProfile(\n this.auth.operatorId,\n inscriptionResult.profileTopicId,\n );\n\n if (!memoResult.success) {\n progressReporter.failed('Failed to update account memo', {\n error: memoResult?.error,\n });\n return {\n ...inscriptionResult,\n success: false,\n error: memoResult?.error,\n };\n }\n }\n\n progressReporter.completed('Profile creation completed successfully', {\n profileTopicId: inscriptionResult.profileTopicId,\n transactionId: inscriptionResult.transactionId,\n });\n\n return inscriptionResult;\n }\n\n /**\n * Gets the capabilities from the capability names.\n *\n * @param capabilityNames - The capability names to get the capabilities for.\n * @returns The capabilities.\n */\n public async getCapabilitiesFromTags(\n capabilityNames: string[],\n ): Promise<number[]> {\n const capabilities: number[] = [];\n\n if (capabilityNames.length === 0) {\n return [AIAgentCapability.TEXT_GENERATION];\n }\n\n for (const capabilityName of capabilityNames) {\n const capability =\n capabilityNameToCapabilityMap[capabilityName.toLowerCase()];\n if (capability !== undefined && !capabilities.includes(capability)) {\n capabilities.push(capability);\n }\n }\n\n if (capabilities.length === 0) {\n capabilities.push(AIAgentCapability.TEXT_GENERATION);\n }\n\n return capabilities;\n }\n\n /**\n * Gets the agent type from the metadata.\n *\n * @param metadata - The metadata of the agent.\n * @returns The agent type.\n */\n public getAgentTypeFromMetadata(metadata: AgentMetadata): AIAgentType {\n if (metadata.type === 'autonomous') {\n return AIAgentType.AUTONOMOUS;\n } else {\n return AIAgentType.MANUAL;\n }\n }\n\n /**\n * Fetches a profile from the account memo.\n *\n * @param accountId - The account ID of the agent to fetch the profile for.\n * @param network - The network to use for the fetch.\n * @returns A promise that resolves to the profile.\n */\n public async fetchProfileByAccountId(\n accountId: string | AccountId,\n network?: string,\n ): Promise<{\n success: boolean;\n profile?: HCS11Profile;\n error?: string;\n topicInfo?: TopicInfo;\n }> {\n try {\n this.logger.debug(\n `Fetching profile for account ${accountId.toString()} on ${this.network}`,\n );\n\n const memo = await this.mirrorNode.getAccountMemo(accountId.toString());\n\n this.logger.debug(`Got account memo: ${memo}`);\n\n if (!memo?.startsWith('hcs-11:')) {\n return {\n success: false,\n error: `Account ${accountId.toString()} does not have a valid HCS-11 memo. Current memo: ${memo || 'empty'}`,\n };\n }\n\n this.logger.debug(`Found HCS-11 memo: ${memo}`);\n\n const protocolReference = memo.substring(7);\n\n if (protocolReference?.startsWith('hcs://')) {\n const hcsFormat = protocolReference.match(/hcs:\\/\\/(\\d+)\\/(.+)/);\n\n if (!hcsFormat) {\n return {\n success: false,\n error: `Invalid HCS protocol reference format: ${protocolReference}`,\n };\n }\n\n const [_, protocolId, profileTopicId] = hcsFormat;\n const networkParam = network || this.network || 'mainnet';\n\n this.logger.debug(\n `Retrieving profile from Kiloscribe CDN: ${profileTopicId}`,\n );\n const cdnUrl = `https://kiloscribe.com/api/inscription-cdn/${profileTopicId}?network=${networkParam}`;\n\n try {\n const response = await fetch(cdnUrl);\n\n if (!response.ok) {\n return {\n success: false,\n error: `Failed to fetch profile from Kiloscribe CDN: ${response.statusText}`,\n };\n }\n\n const profileData = await response.json();\n\n if (!profileData) {\n return {\n success: false,\n error: `No profile data found for topic ${profileTopicId}`,\n };\n }\n\n const parsed = HCS11ProfileSchema.safeParse(profileData);\n if (!parsed.success) {\n return {\n success: false,\n error: `Invalid HCS-11 profile data for topic ${profileTopicId}`,\n };\n }\n\n return {\n success: true,\n profile: parsed.data as HCS11Profile,\n topicInfo: {\n inboundTopic: parsed.data.inboundTopicId || '',\n outboundTopic: parsed.data.outboundTopicId || '',\n profileTopicId,\n },\n };\n } catch (cdnError) {\n this.logger.error(\n `Error retrieving from Kiloscribe CDN: ${cdnError.message}`,\n );\n return {\n success: false,\n error: `Error retrieving from Kiloscribe CDN: ${cdnError.message}`,\n };\n }\n } else if (protocolReference.startsWith('ipfs://')) {\n this.logger.warn('IPFS protocol references are not fully supported');\n const response = await fetch(\n `https://ipfs.io/ipfs/${protocolReference.replace('ipfs://', '')}`,\n );\n const profileData = await response.json();\n const parsed = HCS11ProfileSchema.safeParse(profileData);\n if (!parsed.success) {\n return {\n success: false,\n error: `Invalid HCS-11 profile data from IPFS reference ${protocolReference}`,\n };\n }\n return {\n success: true,\n profile: parsed.data as HCS11Profile,\n topicInfo: {\n inboundTopic: parsed.data.inboundTopicId || '',\n outboundTopic: parsed.data.outboundTopicId || '',\n profileTopicId: '',\n },\n };\n } else if (protocolReference.startsWith('ar://')) {\n const arTxId = protocolReference.replace('ar://', '');\n const response = await fetch(`https://arweave.net/${arTxId}`);\n\n if (!response.ok) {\n return {\n success: false,\n error: `Failed to fetch profile from Arweave ${arTxId}: ${response.statusText}`,\n };\n }\n\n const profileData = await response.json();\n const parsed = HCS11ProfileSchema.safeParse(profileData);\n if (!parsed.success) {\n return {\n success: false,\n error: `Invalid HCS-11 profile data from Arweave reference ${arTxId}`,\n };\n }\n return {\n success: true,\n profile: parsed.data as HCS11Profile,\n topicInfo: {\n inboundTopic: parsed.data.inboundTopicId || '',\n outboundTopic: parsed.data.outboundTopicId || '',\n profileTopicId: '',\n },\n };\n } else {\n return {\n success: false,\n error: `Invalid protocol reference format: ${protocolReference}`,\n };\n }\n } catch (error) {\n this.logger.error(`Error fetching profile: ${error.message}`);\n return {\n success: false,\n error: `Error fetching profile: ${error.message}`,\n };\n }\n }\n}\n"],"names":["response","receipt"],"mappings":"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"}
|
|
1
|
+
{"version":3,"file":"standards-sdk.es21.js","sources":["../../src/hcs-11/client.ts"],"sourcesContent":["import {\n AccountId,\n AccountUpdateTransaction,\n Client,\n PrivateKey,\n Status,\n Transaction,\n} from '@hashgraph/sdk';\nimport {\n inscribe,\n inscribeWithSigner,\n InscriptionInput,\n InscriptionOptions,\n InscriptionResult,\n} from '../inscribe';\nimport { Logger, ILogger, detectKeyTypeFromString, getTopicId } from '../utils';\nimport * as mime from 'mime-types';\nimport { z, ZodIssue } from 'zod';\nimport type { DAppSigner } from '@hashgraph/hedera-wallet-connect';\nimport { ProgressReporter } from '../utils/progress-reporter';\nimport { HederaMirrorNode } from '../services';\nimport { isHederaNetwork, toHederaCaip10 } from '../hcs-14/caip';\nimport { HCS14Client } from '../hcs-14';\nimport { TopicInfo } from '../services/types';\nimport {\n ProfileType,\n AIAgentType,\n AIAgentCapability,\n SocialLink,\n PersonalProfile,\n AIAgentProfile,\n HCS11Profile,\n HCS11Auth,\n HCS11ClientConfig,\n TransactionResult,\n InscribeProfileResponse,\n InscribeImageResponse,\n AgentMetadata,\n InscribeImageOptions,\n InscribeProfileOptions,\n capabilityNameToCapabilityMap,\n MCPServerDetails,\n MCPServerProfile,\n MCPServerCapability,\n VerificationType,\n} from './types';\n\nexport const SocialLinkSchema = z.object({\n platform: z.string().min(1),\n handle: z.string().min(1),\n});\n\nexport const AIAgentDetailsSchema = z.object({\n type: z.nativeEnum(AIAgentType),\n capabilities: z.array(z.nativeEnum(AIAgentCapability)).min(1),\n model: z.string().min(1),\n creator: z.string().optional(),\n});\n\nexport const MCPServerConnectionInfoSchema = z.object({\n url: z.string().min(1),\n transport: z.enum(['stdio', 'sse']),\n});\n\nexport const MCPServerVerificationSchema = z.object({\n type: z.nativeEnum(VerificationType),\n value: z.string(),\n dns_field: z.string().optional(),\n challenge_path: z.string().optional(),\n});\n\nexport const MCPServerHostSchema = z.object({\n minVersion: z.string().optional(),\n});\n\nexport const MCPServerResourceSchema = z.object({\n name: z.string().min(1),\n description: z.string().min(1),\n});\n\nexport const MCPServerToolSchema = z.object({\n name: z.string().min(1),\n description: z.string().min(1),\n});\n\nexport const MCPServerDetailsSchema = z.object({\n version: z.string().min(1),\n connectionInfo: MCPServerConnectionInfoSchema,\n services: z.array(z.nativeEnum(MCPServerCapability)).min(1),\n description: z.string().min(1),\n verification: MCPServerVerificationSchema.optional(),\n host: MCPServerHostSchema.optional(),\n capabilities: z.array(z.string()).optional(),\n resources: z.array(MCPServerResourceSchema).optional(),\n tools: z.array(MCPServerToolSchema).optional(),\n maintainer: z.string().optional(),\n repository: z.string().optional(),\n docs: z.string().optional(),\n});\n\nexport const BaseProfileSchema = z.object({\n version: z.string().min(1),\n type: z.nativeEnum(ProfileType),\n display_name: z.string().min(1),\n alias: z.string().optional(),\n bio: z.string().optional(),\n socials: z.array(SocialLinkSchema).optional(),\n profileImage: z.string().optional(),\n uaid: z.string().optional(),\n properties: z.record(z.any()).optional(),\n inboundTopicId: z.string().optional(),\n outboundTopicId: z.string().optional(),\n});\n\nexport const PersonalProfileSchema = BaseProfileSchema.extend({\n type: z.literal(ProfileType.PERSONAL),\n language: z.string().optional(),\n timezone: z.string().optional(),\n});\n\nexport const AIAgentProfileSchema = BaseProfileSchema.extend({\n type: z.literal(ProfileType.AI_AGENT),\n aiAgent: AIAgentDetailsSchema,\n});\n\nexport const MCPServerProfileSchema = BaseProfileSchema.extend({\n type: z.literal(ProfileType.MCP_SERVER),\n mcpServer: MCPServerDetailsSchema,\n});\n\nexport const HCS11ProfileSchema = z.union([\n PersonalProfileSchema,\n AIAgentProfileSchema,\n MCPServerProfileSchema,\n]);\n\nexport class HCS11Client {\n private client: Client;\n private auth: HCS11Auth;\n private network: string;\n private logger: ILogger;\n private mirrorNode: HederaMirrorNode;\n private keyType: 'ed25519' | 'ecdsa';\n private operatorId: string;\n\n constructor(config: HCS11ClientConfig) {\n this.client =\n config.network === 'mainnet' ? Client.forMainnet() : Client.forTestnet();\n this.auth = config.auth;\n this.network = config.network;\n this.operatorId = config.auth.operatorId;\n\n this.logger = Logger.getInstance({\n level: config.logLevel || 'info',\n module: 'HCS-11',\n silent: config.silent,\n });\n\n this.mirrorNode = new HederaMirrorNode(\n this.network as 'mainnet' | 'testnet',\n this.logger,\n );\n\n if (this.auth.privateKey) {\n if (config.keyType) {\n this.keyType = config.keyType;\n this.initializeOperatorWithKeyType();\n } else {\n try {\n const keyDetection = detectKeyTypeFromString(this.auth.privateKey);\n this.keyType = keyDetection.detectedType;\n\n if (keyDetection.warning) {\n this.logger.warn(keyDetection.warning);\n }\n\n this.client.setOperator(this.operatorId, keyDetection.privateKey);\n } catch (error) {\n this.logger.warn(\n 'Failed to detect key type from private key format, will query mirror node',\n );\n this.keyType = 'ecdsa'; // Default to ECDSA\n }\n\n this.initializeOperator();\n }\n }\n }\n\n public getClient(): Client {\n return this.client;\n }\n\n public getOperatorId(): string {\n return this.auth.operatorId;\n }\n\n public async initializeOperator() {\n const account = await this.mirrorNode.requestAccount(this.operatorId);\n const keyType = account?.key?._type;\n\n if (keyType && keyType.includes('ECDSA')) {\n this.keyType = 'ecdsa';\n } else if (keyType && keyType.includes('ED25519')) {\n this.keyType = 'ed25519';\n } else {\n this.keyType = 'ecdsa'; // Default to ECDSA\n }\n\n this.initializeOperatorWithKeyType();\n }\n\n private initializeOperatorWithKeyType() {\n if (!this.auth.privateKey) {\n return;\n }\n\n const PK =\n this.keyType === 'ecdsa'\n ? PrivateKey.fromStringECDSA(this.auth.privateKey)\n : PrivateKey.fromStringED25519(this.auth.privateKey);\n\n this.client.setOperator(this.operatorId, PK);\n }\n\n public createPersonalProfile(\n displayName: string,\n options?: {\n alias?: string;\n bio?: string;\n socials?: SocialLink[];\n profileImage?: string;\n language?: string;\n timezone?: string;\n properties?: Record<string, any>;\n inboundTopicId?: string;\n outboundTopicId?: string;\n },\n ): PersonalProfile {\n return {\n version: '1.0',\n type: ProfileType.PERSONAL,\n display_name: displayName,\n alias: options?.alias,\n bio: options?.bio,\n socials: options?.socials,\n profileImage: options?.profileImage,\n properties: options?.properties,\n inboundTopicId: options?.inboundTopicId,\n outboundTopicId: options?.outboundTopicId,\n };\n }\n\n public createAIAgentProfile(\n displayName: string,\n agentType: AIAgentType,\n capabilities: AIAgentCapability[],\n model: string,\n options?: {\n alias?: string;\n bio?: string;\n socials?: SocialLink[];\n profileImage?: string;\n properties?: Record<string, any>;\n inboundTopicId?: string;\n outboundTopicId?: string;\n creator?: string;\n },\n ): AIAgentProfile {\n const validation = this.validateProfile({\n version: '1.0',\n type: ProfileType.AI_AGENT,\n display_name: displayName,\n alias: options?.alias,\n bio: options?.bio,\n socials: options?.socials,\n profileImage: options?.profileImage,\n properties: options?.properties,\n inboundTopicId: options?.inboundTopicId,\n outboundTopicId: options?.outboundTopicId,\n aiAgent: {\n type: agentType,\n capabilities,\n model,\n creator: options?.creator,\n },\n });\n\n if (!validation.valid) {\n throw new Error(\n `Invalid AI Agent Profile: ${validation.errors.join(', ')}`,\n );\n }\n\n return {\n version: '1.0',\n type: ProfileType.AI_AGENT,\n display_name: displayName,\n alias: options?.alias,\n bio: options?.bio,\n socials: options?.socials,\n profileImage: options?.profileImage,\n properties: options?.properties,\n inboundTopicId: options?.inboundTopicId,\n outboundTopicId: options?.outboundTopicId,\n aiAgent: {\n type: agentType,\n capabilities,\n model,\n creator: options?.creator,\n },\n };\n }\n\n /**\n * Creates an MCP server profile.\n *\n * @param displayName - The display name for the MCP server\n * @param serverDetails - The MCP server details\n * @param options - Additional profile options\n * @returns An MCPServerProfile object\n */\n public createMCPServerProfile(\n displayName: string,\n serverDetails: MCPServerDetails,\n options?: {\n alias?: string;\n bio?: string;\n socials?: SocialLink[];\n profileImage?: string;\n properties?: Record<string, any>;\n inboundTopicId?: string;\n outboundTopicId?: string;\n },\n ): MCPServerProfile {\n const validation = this.validateProfile({\n version: '1.0',\n type: ProfileType.MCP_SERVER,\n display_name: displayName,\n alias: options?.alias,\n bio: options?.bio,\n socials: options?.socials,\n profileImage: options?.profileImage,\n properties: options?.properties,\n inboundTopicId: options?.inboundTopicId,\n outboundTopicId: options?.outboundTopicId,\n mcpServer: serverDetails,\n });\n\n if (!validation.valid) {\n throw new Error(\n `Invalid MCP Server Profile: ${validation.errors.join(', ')}`,\n );\n }\n\n return {\n version: '1.0',\n type: ProfileType.MCP_SERVER,\n display_name: displayName,\n alias: options?.alias,\n bio: options?.bio,\n socials: options?.socials,\n profileImage: options?.profileImage,\n properties: options?.properties,\n inboundTopicId: options?.inboundTopicId,\n outboundTopicId: options?.outboundTopicId,\n mcpServer: serverDetails,\n };\n }\n\n public validateProfile(profile: unknown): {\n valid: boolean;\n errors: string[];\n } {\n const result = HCS11ProfileSchema.safeParse(profile);\n\n if (result.success) {\n return { valid: true, errors: [] };\n }\n\n const formattedErrors = result.error.errors.map((err: ZodIssue) => {\n const path = err.path.join('.');\n let message = err.message;\n\n if (err.code === 'invalid_type') {\n message = `Expected ${err.expected}, got ${err.received}`;\n } else if (err.code === 'invalid_enum_value') {\n const validOptions = err.options?.join(', ');\n message = `Invalid value. Valid options are: ${validOptions}`;\n } else if (err.code === 'too_small' && err.type === 'string') {\n message = 'Cannot be empty';\n }\n\n return `${path}: ${message}`;\n });\n\n return { valid: false, errors: formattedErrors };\n }\n\n public profileToJSONString(profile: HCS11Profile): string {\n return JSON.stringify(profile);\n }\n\n public parseProfileFromString(profileStr: string): HCS11Profile | null {\n try {\n const parsedProfile = JSON.parse(profileStr);\n const validation = this.validateProfile(parsedProfile);\n if (!validation.valid) {\n this.logger.error('Invalid profile format:', validation.errors);\n return null;\n }\n return parsedProfile as HCS11Profile;\n } catch (error) {\n this.logger.error('Error parsing profile:');\n return null;\n }\n }\n\n public setProfileForAccountMemo(\n topicId: string,\n topicStandard: 1 | 2 | 7 = 1,\n ): string {\n return `hcs-11:hcs://${topicStandard}/${topicId}`;\n }\n\n private async executeTransaction<T>(\n transaction: Transaction,\n ): Promise<TransactionResult<T>> {\n try {\n if (this.auth.privateKey) {\n const signedTx = await transaction.signWithOperator(this.client);\n const response = await signedTx.execute(this.client);\n const receipt = await response.getReceipt(this.client);\n\n if (receipt.status.toString() !== Status.Success.toString()) {\n return {\n success: false,\n error: `Transaction failed: ${receipt.status.toString()}`,\n };\n }\n\n return {\n success: true,\n result: receipt as T,\n };\n }\n\n if (!this.auth.signer) {\n throw new Error('No valid authentication method provided');\n }\n\n const signer = this.auth.signer;\n const frozenTransaction = await transaction.freezeWithSigner(signer);\n const response = await frozenTransaction.executeWithSigner(signer);\n const receipt = await response.getReceiptWithSigner(signer);\n\n if (receipt.status.toString() !== Status.Success.toString()) {\n return {\n success: false,\n error: `Transaction failed: ${receipt.status.toString()}: ${Status.Success.toString()}`,\n };\n }\n\n return {\n success: true,\n result: receipt as T,\n };\n } catch (error) {\n return {\n success: false,\n error:\n error instanceof Error\n ? error.message\n : 'Unknown error during transaction execution',\n };\n }\n }\n\n public async inscribeImage(\n buffer: Buffer,\n fileName: string,\n options?: InscribeImageOptions,\n ): Promise<InscribeImageResponse> {\n try {\n const progressCallback = options?.progressCallback;\n const progressReporter = new ProgressReporter({\n module: 'HCS11-Image',\n logger: this.logger,\n callback: progressCallback as any,\n });\n\n progressReporter.preparing('Preparing to inscribe image', 0);\n\n const mimeType = mime.lookup(fileName) || 'application/octet-stream';\n\n const waitForConfirmation = options?.waitForConfirmation ?? true;\n\n let inscriptionResponse;\n if (this.auth.signer) {\n if ('accountId' in this.auth.signer) {\n progressReporter.preparing('Using signer for inscription', 10);\n\n inscriptionResponse = await inscribeWithSigner(\n {\n type: 'buffer',\n buffer,\n fileName,\n mimeType,\n },\n this.auth.signer as DAppSigner,\n {\n network: this.network as 'mainnet' | 'testnet',\n waitForConfirmation,\n waitMaxAttempts: 150,\n waitIntervalMs: 4000,\n logging: {\n level: 'debug',\n },\n progressCallback: data => {\n const adjustedPercent = 10 + (data.progressPercent || 0) * 0.8;\n progressReporter.report({\n stage: data.stage,\n message: data.message,\n progressPercent: adjustedPercent,\n details: data.details,\n });\n },\n },\n );\n } else {\n progressReporter.failed(\n 'Signer must be a DAppSigner for inscription',\n );\n throw new Error('Signer must be a DAppSigner for inscription');\n }\n } else {\n if (!this.auth.privateKey) {\n progressReporter.failed('Private key is required for inscription');\n this.logger.error('Private key is required for inscription');\n throw new Error('Private key is required for inscription');\n }\n\n progressReporter.preparing('Using private key for inscription', 10);\n\n const PK =\n this.keyType === 'ecdsa'\n ? PrivateKey.fromStringECDSA(this.auth.privateKey)\n : PrivateKey.fromStringED25519(this.auth.privateKey);\n\n inscriptionResponse = await inscribe(\n {\n type: 'buffer',\n buffer,\n fileName,\n mimeType,\n },\n {\n accountId: this.auth.operatorId,\n privateKey: PK,\n network: this.network as 'mainnet' | 'testnet',\n },\n {\n waitForConfirmation,\n waitMaxAttempts: 150,\n waitIntervalMs: 2000,\n logging: {\n level: 'debug',\n },\n progressCallback: data => {\n const adjustedPercent = 10 + (data.progressPercent || 0) * 0.8;\n progressReporter.report({\n stage: data.stage,\n message: data.message,\n progressPercent: adjustedPercent,\n details: data.details,\n });\n },\n },\n );\n }\n\n if (inscriptionResponse.confirmed) {\n progressReporter.completed('Image inscription completed', {\n topicId: getTopicId(inscriptionResponse.inscription),\n });\n return {\n imageTopicId: getTopicId(inscriptionResponse.inscription) || '',\n transactionId: (inscriptionResponse.result as InscriptionResult)\n .jobId,\n success: true,\n };\n } else {\n const jobId = inscriptionResponse.quote\n ? 'quote-only'\n : (inscriptionResponse.result as InscriptionResult).jobId;\n progressReporter.verifying('Waiting for inscription confirmation', 50, {\n jobId,\n });\n return {\n imageTopicId: '',\n transactionId: jobId,\n success: false,\n error: 'Inscription not confirmed',\n };\n }\n } catch (error) {\n this.logger.error('Error inscribing image:', error);\n return {\n imageTopicId: '',\n transactionId: '',\n success: false,\n error:\n error instanceof Error ? error.message : 'Error inscribing image',\n };\n }\n }\n\n public async inscribeProfile(\n profile: HCS11Profile,\n options?: InscribeProfileOptions,\n ): Promise<InscribeProfileResponse> {\n this.logger.info('Inscribing HCS-11 profile');\n\n const progressCallback = options?.progressCallback;\n const progressReporter = new ProgressReporter({\n module: 'HCS11-Profile',\n logger: this.logger,\n callback: progressCallback,\n });\n\n await this.attachUaidIfMissing(profile);\n\n progressReporter.preparing('Validating profile data', 5);\n\n const validation = this.validateProfile(profile);\n if (!validation.valid) {\n progressReporter.failed(\n `Invalid profile: ${validation.errors.join(', ')}`,\n );\n return {\n profileTopicId: '',\n transactionId: '',\n success: false,\n error: `Invalid profile: ${validation.errors.join(', ')}`,\n };\n }\n\n progressReporter.preparing('Formatting profile for inscription', 15);\n\n const profileJson = this.profileToJSONString(profile);\n const fileName = `profile-${profile.display_name\n .toLowerCase()\n .replace(/\\s+/g, '-')}.json`;\n\n try {\n const contentBuffer = Buffer.from(profileJson, 'utf-8');\n const contentType = 'application/json';\n\n progressReporter.preparing('Preparing profile for inscription', 20);\n\n const input: InscriptionInput = {\n type: 'buffer',\n buffer: contentBuffer,\n fileName,\n mimeType: contentType,\n };\n\n const inscriptionOptions: InscriptionOptions = {\n waitForConfirmation: true,\n mode: 'file',\n network: this.network as 'mainnet' | 'testnet',\n waitMaxAttempts: 100,\n waitIntervalMs: 2000,\n progressCallback: data => {\n const adjustedPercent =\n 20 + Number(data?.progressPercent || 0) * 0.75;\n progressReporter?.report({\n stage: data.stage,\n message: data.message,\n progressPercent: adjustedPercent,\n details: data.details,\n });\n },\n };\n\n progressReporter.submitting('Submitting profile to Hedera network', 30);\n\n let inscriptionResponse;\n\n if (this.auth.privateKey) {\n const PK =\n this.keyType === 'ecdsa'\n ? PrivateKey.fromStringECDSA(this.auth.privateKey)\n : PrivateKey.fromStringED25519(this.auth.privateKey);\n\n inscriptionResponse = await inscribe(\n input,\n {\n accountId: this.auth.operatorId,\n privateKey: PK,\n network: this.network as 'mainnet' | 'testnet',\n },\n inscriptionOptions,\n );\n } else if (this.auth.signer) {\n inscriptionResponse = await inscribeWithSigner(\n input,\n this.auth.signer as DAppSigner,\n inscriptionOptions,\n );\n } else {\n throw new Error(\n 'No authentication method available - neither private key nor signer',\n );\n }\n\n if (\n !inscriptionResponse.confirmed ||\n !getTopicId(inscriptionResponse.inscription)\n ) {\n progressReporter.failed('Failed to inscribe profile content');\n return {\n profileTopicId: '',\n transactionId: '',\n success: false,\n error: 'Failed to inscribe profile content',\n };\n }\n const topicId = getTopicId(inscriptionResponse.inscription);\n\n progressReporter.completed('Profile inscription completed', {\n topicId,\n transactionId: (inscriptionResponse.result as InscriptionResult)\n .transactionId,\n });\n\n return {\n profileTopicId: topicId,\n transactionId: (inscriptionResponse.result as InscriptionResult)\n .transactionId,\n success: true,\n };\n } catch (error) {\n progressReporter.failed(\n `Error inscribing profile: ${error.message || 'Unknown error'}`,\n );\n return {\n profileTopicId: '',\n transactionId: '',\n success: false,\n error: error.message || 'Unknown error during inscription',\n };\n }\n }\n\n private async attachUaidIfMissing(profile: HCS11Profile): Promise<void> {\n if ((profile as { uaid?: string }).uaid) {\n return;\n }\n if (!isHederaNetwork(this.network)) return;\n try {\n const hcs14 = new HCS14Client({ client: this.client });\n const did = await hcs14.createDid({\n method: 'hedera',\n client: this.client,\n });\n const nativeId = toHederaCaip10(this.network, this.auth.operatorId);\n let uid = this.auth.operatorId;\n const inboundFromProfile = profile.inboundTopicId;\n if (inboundFromProfile && inboundFromProfile.trim().length > 0) {\n uid = `${inboundFromProfile}@${this.auth.operatorId}`;\n } else {\n try {\n const fetched = await this.fetchProfileByAccountId(\n this.auth.operatorId,\n this.network as 'mainnet' | 'testnet',\n );\n const inbound = fetched?.topicInfo?.inboundTopic;\n if (inbound && inbound.trim().length > 0) {\n uid = `${inbound}@${this.auth.operatorId}`;\n }\n } catch {}\n }\n\n const uaid = hcs14.createUaid(did, { proto: 'hcs-10', nativeId, uid });\n profile.uaid = uaid;\n } catch {\n this.logger.warn(\n 'Hiero registrar not available; skipping UAID generation for profile',\n );\n }\n }\n\n public async updateAccountMemoWithProfile(\n accountId: string | AccountId,\n profileTopicId: string,\n ): Promise<TransactionResult> {\n try {\n this.logger.info(\n `Updating account memo for ${accountId} with profile ${profileTopicId}`,\n );\n const memo = this.setProfileForAccountMemo(profileTopicId);\n\n const transaction = new AccountUpdateTransaction()\n .setAccountMemo(memo)\n .setAccountId(accountId);\n\n return this.executeTransaction(transaction);\n } catch (error) {\n this.logger.error(\n `Error updating account memo: ${\n error instanceof Error ? error.message : 'Unknown error'\n }`,\n );\n return {\n success: false,\n error:\n error instanceof Error\n ? error.message\n : 'Unknown error updating account memo',\n };\n }\n }\n\n /**\n * Creates and inscribes a profile.\n *\n * @param profile - The profile to create and inscribe.\n * @param updateAccountMemo - Whether to update the account memo with the profile.\n * @param options - Optional configuration options.\n * @returns A promise that resolves to the inscription result.\n */\n public async createAndInscribeProfile(\n profile: HCS11Profile,\n updateAccountMemo = true,\n options?: InscribeProfileOptions,\n ): Promise<InscribeProfileResponse> {\n const progressCallback = options?.progressCallback;\n const progressReporter = new ProgressReporter({\n module: 'HCS11-ProfileCreation',\n logger: this.logger,\n callback: progressCallback,\n });\n\n progressReporter.preparing('Starting profile creation process', 0);\n\n const inscriptionProgress = progressReporter.createSubProgress({\n minPercent: 0,\n maxPercent: 80,\n logPrefix: 'Inscription',\n });\n\n const inscriptionResult = await this.inscribeProfile(profile, {\n ...options,\n progressCallback: data => {\n inscriptionProgress.report({\n stage: data.stage,\n message: data.message,\n progressPercent: data.progressPercent,\n details: data.details,\n });\n },\n });\n\n if (!inscriptionResult?.success) {\n progressReporter.failed('Profile inscription failed', {\n error: inscriptionResult?.error,\n });\n return inscriptionResult;\n }\n\n progressReporter.confirming('Profile inscribed, updating account memo', 85);\n\n if (updateAccountMemo) {\n const memoResult = await this.updateAccountMemoWithProfile(\n this.auth.operatorId,\n inscriptionResult.profileTopicId,\n );\n\n if (!memoResult.success) {\n progressReporter.failed('Failed to update account memo', {\n error: memoResult?.error,\n });\n return {\n ...inscriptionResult,\n success: false,\n error: memoResult?.error,\n };\n }\n }\n\n progressReporter.completed('Profile creation completed successfully', {\n profileTopicId: inscriptionResult.profileTopicId,\n transactionId: inscriptionResult.transactionId,\n });\n\n return inscriptionResult;\n }\n\n /**\n * Gets the capabilities from the capability names.\n *\n * @param capabilityNames - The capability names to get the capabilities for.\n * @returns The capabilities.\n */\n public async getCapabilitiesFromTags(\n capabilityNames: string[],\n ): Promise<number[]> {\n const capabilities: number[] = [];\n\n if (capabilityNames.length === 0) {\n return [AIAgentCapability.TEXT_GENERATION];\n }\n\n for (const capabilityName of capabilityNames) {\n const capability =\n capabilityNameToCapabilityMap[capabilityName.toLowerCase()];\n if (capability !== undefined && !capabilities.includes(capability)) {\n capabilities.push(capability);\n }\n }\n\n if (capabilities.length === 0) {\n capabilities.push(AIAgentCapability.TEXT_GENERATION);\n }\n\n return capabilities;\n }\n\n /**\n * Gets the agent type from the metadata.\n *\n * @param metadata - The metadata of the agent.\n * @returns The agent type.\n */\n public getAgentTypeFromMetadata(metadata: AgentMetadata): AIAgentType {\n if (metadata.type === 'autonomous') {\n return AIAgentType.AUTONOMOUS;\n } else {\n return AIAgentType.MANUAL;\n }\n }\n\n /**\n * Fetches a profile from the account memo.\n *\n * @param accountId - The account ID of the agent to fetch the profile for.\n * @param network - The network to use for the fetch.\n * @returns A promise that resolves to the profile.\n */\n public async fetchProfileByAccountId(\n accountId: string | AccountId,\n network?: string,\n ): Promise<{\n success: boolean;\n profile?: HCS11Profile;\n error?: string;\n topicInfo?: TopicInfo;\n }> {\n try {\n this.logger.debug(\n `Fetching profile for account ${accountId.toString()} on ${this.network}`,\n );\n\n const memo = await this.mirrorNode.getAccountMemo(accountId.toString());\n\n this.logger.debug(`Got account memo: ${memo}`);\n\n if (!memo?.startsWith('hcs-11:')) {\n return {\n success: false,\n error: `Account ${accountId.toString()} does not have a valid HCS-11 memo. Current memo: ${memo || 'empty'}`,\n };\n }\n\n this.logger.debug(`Found HCS-11 memo: ${memo}`);\n\n const protocolReference = memo.substring(7);\n\n if (protocolReference?.startsWith('hcs://')) {\n const hcsFormat = protocolReference.match(/hcs:\\/\\/(\\d+)\\/(.+)/);\n\n if (!hcsFormat) {\n return {\n success: false,\n error: `Invalid HCS protocol reference format: ${protocolReference}`,\n };\n }\n\n const [_, protocolId, profileTopicId] = hcsFormat;\n const networkParam = network || this.network || 'mainnet';\n\n this.logger.debug(\n `Retrieving profile from Kiloscribe CDN: ${profileTopicId}`,\n );\n const cdnUrl = `https://kiloscribe.com/api/inscription-cdn/${profileTopicId}?network=${networkParam}`;\n\n try {\n const response = await fetch(cdnUrl);\n\n if (!response.ok) {\n return {\n success: false,\n error: `Failed to fetch profile from Kiloscribe CDN: ${response.statusText}`,\n };\n }\n\n const profileData = await response.json();\n\n if (!profileData) {\n return {\n success: false,\n error: `No profile data found for topic ${profileTopicId}`,\n };\n }\n\n const parsed = HCS11ProfileSchema.safeParse(profileData);\n if (!parsed.success) {\n return {\n success: false,\n error: `Invalid HCS-11 profile data for topic ${profileTopicId}`,\n };\n }\n\n return {\n success: true,\n profile: parsed.data as HCS11Profile,\n topicInfo: {\n inboundTopic: parsed.data.inboundTopicId || '',\n outboundTopic: parsed.data.outboundTopicId || '',\n profileTopicId,\n },\n };\n } catch (cdnError) {\n this.logger.error(\n `Error retrieving from Kiloscribe CDN: ${cdnError.message}`,\n );\n return {\n success: false,\n error: `Error retrieving from Kiloscribe CDN: ${cdnError.message}`,\n };\n }\n } else if (protocolReference.startsWith('ipfs://')) {\n this.logger.warn('IPFS protocol references are not fully supported');\n const response = await fetch(\n `https://ipfs.io/ipfs/${protocolReference.replace('ipfs://', '')}`,\n );\n const profileData = await response.json();\n const parsed = HCS11ProfileSchema.safeParse(profileData);\n if (!parsed.success) {\n return {\n success: false,\n error: `Invalid HCS-11 profile data from IPFS reference ${protocolReference}`,\n };\n }\n return {\n success: true,\n profile: parsed.data as HCS11Profile,\n topicInfo: {\n inboundTopic: parsed.data.inboundTopicId || '',\n outboundTopic: parsed.data.outboundTopicId || '',\n profileTopicId: '',\n },\n };\n } else if (protocolReference.startsWith('ar://')) {\n const arTxId = protocolReference.replace('ar://', '');\n const response = await fetch(`https://arweave.net/${arTxId}`);\n\n if (!response.ok) {\n return {\n success: false,\n error: `Failed to fetch profile from Arweave ${arTxId}: ${response.statusText}`,\n };\n }\n\n const profileData = await response.json();\n const parsed = HCS11ProfileSchema.safeParse(profileData);\n if (!parsed.success) {\n return {\n success: false,\n error: `Invalid HCS-11 profile data from Arweave reference ${arTxId}`,\n };\n }\n return {\n success: true,\n profile: parsed.data as HCS11Profile,\n topicInfo: {\n inboundTopic: parsed.data.inboundTopicId || '',\n outboundTopic: parsed.data.outboundTopicId || '',\n profileTopicId: '',\n },\n };\n } else {\n return {\n success: false,\n error: `Invalid protocol reference format: ${protocolReference}`,\n };\n }\n } catch (error) {\n this.logger.error(`Error fetching profile: ${error.message}`);\n return {\n success: false,\n error: `Error fetching profile: ${error.message}`,\n };\n }\n }\n}\n"],"names":["response","receipt"],"mappings":"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"}
|
|
@@ -61,7 +61,9 @@ function createUaidFromDidImpl(existingDid, params) {
|
|
|
61
61
|
const { sanitized, hadSuffix } = sanitizeDidSpecificId(idPart);
|
|
62
62
|
let finalId = sanitized;
|
|
63
63
|
if (method === "hedera") {
|
|
64
|
-
const networkPrefixMatch = sanitized.match(
|
|
64
|
+
const networkPrefixMatch = sanitized.match(
|
|
65
|
+
/^(mainnet|testnet|previewnet|devnet):(.+)$/
|
|
66
|
+
);
|
|
65
67
|
if (networkPrefixMatch) {
|
|
66
68
|
finalId = networkPrefixMatch[2];
|
|
67
69
|
}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"standards-sdk.es50.js","sources":["../../src/hcs-14/did.ts"],"sourcesContent":["/**\n * DID generation and parsing for HCS-14 AID/UAID methods.\n */\n\nimport { getCryptoAdapter } from '../utils/crypto-abstraction';\nimport { base58Encode } from './base58';\nimport { canonicalizeAgentData } from './canonical';\nimport {
|
|
1
|
+
{"version":3,"file":"standards-sdk.es50.js","sources":["../../src/hcs-14/did.ts"],"sourcesContent":["/**\n * DID generation and parsing for HCS-14 AID/UAID methods.\n */\n\nimport { getCryptoAdapter } from '../utils/crypto-abstraction';\nimport { base58Encode } from './base58';\nimport { canonicalizeAgentData } from './canonical';\nimport { CanonicalAgentData, DidRoutingParams, ParsedHcs14Did } from './types';\n\nfunction encodeMultibaseB58btc(input: string): string {\n const bytes = Buffer.from(input, 'utf8');\n return 'z' + base58Encode(bytes);\n}\n\nfunction sanitizeDidSpecificId(idPart: string): {\n sanitized: string;\n hadSuffix: boolean;\n} {\n const cut = idPart.search(/[;?#]/);\n if (cut === -1) return { sanitized: idPart, hadSuffix: false };\n return { sanitized: idPart.slice(0, cut), hadSuffix: true };\n}\n\nfunction buildParamString(params: DidRoutingParams): string {\n const entries: Array<[string, string]> = [];\n if (params.uid) entries.push(['uid', params.uid]);\n if (params.registry) entries.push(['registry', params.registry]);\n if (params.proto) entries.push(['proto', params.proto]);\n if (params.nativeId) entries.push(['nativeId', params.nativeId]);\n if (params.domain) entries.push(['domain', params.domain]);\n if (params.src) entries.push(['src', params.src]);\n if (entries.length === 0) return '';\n return entries.map(([k, v]) => `${k}=${v}`).join(';');\n}\n\nfunction defaultAidParams(\n data: CanonicalAgentData,\n params?: DidRoutingParams,\n): DidRoutingParams {\n const merged: DidRoutingParams = { ...params };\n if (!merged.registry) merged.registry = data.registry;\n if (!merged.nativeId) merged.nativeId = data.nativeId;\n if (!merged.uid) merged.uid = '0';\n return merged;\n}\n\nasync function createUaidAidImpl(\n input: CanonicalAgentData,\n params?: DidRoutingParams,\n options?: { includeParams?: boolean },\n): Promise<string> {\n const { normalized, canonicalJson } = canonicalizeAgentData(input);\n const adapter = getCryptoAdapter();\n const hasher = adapter.createHash('sha384');\n const digestResult = hasher\n .update(Buffer.from(canonicalJson, 'utf8'))\n .digest();\n const digestBuffer = (await Promise.resolve(\n digestResult as string | Buffer,\n )) as string | Buffer;\n const bytes = Buffer.isBuffer(digestBuffer)\n ? (digestBuffer as Buffer)\n : Buffer.from(digestBuffer as string);\n const id = base58Encode(bytes);\n const includeParams = options?.includeParams !== false;\n const finalParams = includeParams\n ? defaultAidParams(normalized, params || {})\n : {};\n const paramString = includeParams ? buildParamString(finalParams) : '';\n return paramString ? `uaid:aid:${id};${paramString}` : `uaid:aid:${id}`;\n}\n\nfunction createUaidFromDidImpl(\n existingDid: string,\n params?: DidRoutingParams,\n): string {\n let method: string;\n let idPart: string;\n if (existingDid.startsWith('uaid:aid:')) {\n method = 'aid';\n idPart = existingDid.slice('uaid:aid:'.length);\n } else if (existingDid.startsWith('did:')) {\n const idx = existingDid.indexOf(':');\n const second = existingDid.indexOf(':', idx + 1);\n if (second < 0) throw new Error('Invalid DID format');\n method = existingDid.slice(idx + 1, second);\n idPart = existingDid.slice(second + 1);\n } else {\n throw new Error('Invalid DID format');\n }\n const { sanitized, hadSuffix } = sanitizeDidSpecificId(idPart);\n\n let finalId = sanitized;\n if (method === 'hedera') {\n const networkPrefixMatch = sanitized.match(\n /^(mainnet|testnet|previewnet|devnet):(.+)$/,\n );\n if (networkPrefixMatch) {\n finalId = networkPrefixMatch[2];\n }\n }\n\n const finalParams: DidRoutingParams = { ...(params || {}) };\n if (hadSuffix && !finalParams.src) {\n finalParams.src = encodeMultibaseB58btc(existingDid);\n }\n const paramString = buildParamString(finalParams);\n return paramString\n ? `uaid:did:${finalId};${paramString}`\n : `uaid:did:${finalId}`;\n}\n\nexport function createUaid(\n existingDid: string,\n params?: DidRoutingParams,\n): string;\nexport function createUaid(\n input: CanonicalAgentData,\n params?: DidRoutingParams,\n options?: { includeParams?: boolean },\n): Promise<string>;\nexport function createUaid(\n input: string | CanonicalAgentData,\n params?: DidRoutingParams,\n options?: { includeParams?: boolean },\n): Promise<string> | string {\n if (typeof input === 'string') {\n return createUaidFromDidImpl(input, params);\n }\n return createUaidAidImpl(input, params, options);\n}\n\nexport function parseHcs14Did(did: string): ParsedHcs14Did {\n const parseParams = (paramStr: string): Record<string, string> => {\n const params: Record<string, string> = {};\n if (!paramStr) return params;\n const pairs = paramStr.split(';');\n for (const p of pairs) {\n const eq = p.indexOf('=');\n if (eq > 0) {\n const k = p.slice(0, eq);\n const v = p.slice(eq + 1);\n params[k] = v;\n }\n }\n return params;\n };\n\n if (did.startsWith('uaid:')) {\n const afterUaid = did.slice('uaid:'.length);\n let inner: 'did' | 'aid';\n let afterInner: string;\n if (afterUaid.startsWith('did:')) {\n inner = 'did';\n afterInner = afterUaid.slice('did:'.length);\n } else if (afterUaid.startsWith('aid:')) {\n inner = 'aid';\n afterInner = afterUaid.slice('aid:'.length);\n } else {\n throw new Error('Invalid UAID');\n }\n const semi = afterInner.indexOf(';');\n const id = semi >= 0 ? afterInner.slice(0, semi) : afterInner;\n const paramStr = semi >= 0 ? afterInner.slice(semi + 1) : '';\n const params = parseParams(paramStr);\n return { method: inner === 'did' ? 'uaid' : 'aid', id, params };\n }\n\n throw new Error('Invalid DID');\n}\n"],"names":[],"mappings":"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"}
|
|
@@ -8,7 +8,7 @@ class HieroDidResolver {
|
|
|
8
8
|
caip10Namespaces: ["hedera"],
|
|
9
9
|
displayName: "Hedera (Hiero Resolver)",
|
|
10
10
|
description: "Resolves did:hedera identifiers via Hiero DID resolver.",
|
|
11
|
-
homepage: "https://github.com/
|
|
11
|
+
homepage: "https://github.com/hiero-ledger/hiero-did-sdk-js"
|
|
12
12
|
};
|
|
13
13
|
}
|
|
14
14
|
supports(did) {
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"standards-sdk.es53.js","sources":["../../src/hcs-14/resolvers/hiero.ts"],"sourcesContent":["import { DidDocumentMinimal, DidResolver } from './types';\nimport { resolveDID } from '@hiero-did-sdk/resolver';\nimport type { AdapterMeta } from '../adapters/types';\n\nexport class HieroDidResolver implements DidResolver {\n readonly meta: AdapterMeta = {\n id: 'hedera/hiero-resolver',\n didMethods: ['hedera'],\n caip2Networks: ['hedera:mainnet', 'hedera:testnet', 'hedera:previewnet', 'hedera:devnet'],\n caip10Namespaces: ['hedera'],\n displayName: 'Hedera (Hiero Resolver)',\n description: 'Resolves did:hedera identifiers via Hiero DID resolver.',\n homepage: 'https://github.com/
|
|
1
|
+
{"version":3,"file":"standards-sdk.es53.js","sources":["../../src/hcs-14/resolvers/hiero.ts"],"sourcesContent":["import { DidDocumentMinimal, DidResolver } from './types';\nimport { resolveDID } from '@hiero-did-sdk/resolver';\nimport type { AdapterMeta } from '../adapters/types';\n\nexport class HieroDidResolver implements DidResolver {\n readonly meta: AdapterMeta = {\n id: 'hedera/hiero-resolver',\n didMethods: ['hedera'],\n caip2Networks: ['hedera:mainnet', 'hedera:testnet', 'hedera:previewnet', 'hedera:devnet'],\n caip10Namespaces: ['hedera'],\n displayName: 'Hedera (Hiero Resolver)',\n description: 'Resolves did:hedera identifiers via Hiero DID resolver.',\n homepage: 'https://github.com/hiero-ledger/hiero-did-sdk-js',\n };\n supports(did: string): boolean {\n return did.startsWith('did:hedera:');\n }\n\n async resolve(did: string): Promise<DidDocumentMinimal | null> {\n type MinimalResolution = {\n id?: string;\n didDocument?: { id?: string };\n };\n const res = (await resolveDID(did)) as MinimalResolution;\n const id = res.id ?? res.didDocument?.id;\n return id ? { id } : null;\n }\n}\n"],"names":[],"mappings":";AAIO,MAAM,iBAAwC;AAAA,EAA9C,cAAA;AACL,SAAS,OAAoB;AAAA,MAC3B,IAAI;AAAA,MACJ,YAAY,CAAC,QAAQ;AAAA,MACrB,eAAe,CAAC,kBAAkB,kBAAkB,qBAAqB,eAAe;AAAA,MACxF,kBAAkB,CAAC,QAAQ;AAAA,MAC3B,aAAa;AAAA,MACb,aAAa;AAAA,MACb,UAAU;AAAA,IAAA;AAAA,EACZ;AAAA,EACA,SAAS,KAAsB;AAC7B,WAAO,IAAI,WAAW,aAAa;AAAA,EACrC;AAAA,EAEA,MAAM,QAAQ,KAAiD;AAK7D,UAAM,MAAO,MAAM,WAAW,GAAG;AACjC,UAAM,KAAK,IAAI,MAAM,IAAI,aAAa;AACtC,WAAO,KAAK,EAAE,GAAA,IAAO;AAAA,EACvB;AACF;"}
|
|
@@ -13,7 +13,7 @@ class HederaHieroIssuer {
|
|
|
13
13
|
caip10Namespaces: ["hedera"],
|
|
14
14
|
displayName: "Hedera (Hiero Registrar)",
|
|
15
15
|
description: "Issues did:hedera identifiers using the Hiero DID registrar.",
|
|
16
|
-
homepage: "https://github.com/
|
|
16
|
+
homepage: "https://github.com/hiero-ledger/hiero-did-sdk-js"
|
|
17
17
|
};
|
|
18
18
|
}
|
|
19
19
|
supports(method) {
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"standards-sdk.es56.js","sources":["../../src/hcs-14/issuers/hiero.ts"],"sourcesContent":["import { DidIssueRequest, DidIssueRequestHedera, DidIssuer } from './types';\nimport type { AdapterMeta } from '../adapters/types';\nimport { createDID } from '@hiero-did-sdk/registrar';\n\nexport class HederaHieroIssuer implements DidIssuer {\n readonly meta: AdapterMeta = {\n id: 'hedera/hiero',\n didMethods: ['hedera'],\n caip2Networks: [\n 'hedera:mainnet',\n 'hedera:testnet',\n 'hedera:previewnet',\n 'hedera:devnet',\n ],\n caip10Namespaces: ['hedera'],\n displayName: 'Hedera (Hiero Registrar)',\n description: 'Issues did:hedera identifiers using the Hiero DID registrar.',\n homepage: 'https://github.com/
|
|
1
|
+
{"version":3,"file":"standards-sdk.es56.js","sources":["../../src/hcs-14/issuers/hiero.ts"],"sourcesContent":["import { DidIssueRequest, DidIssueRequestHedera, DidIssuer } from './types';\nimport type { AdapterMeta } from '../adapters/types';\nimport { createDID } from '@hiero-did-sdk/registrar';\n\nexport class HederaHieroIssuer implements DidIssuer {\n readonly meta: AdapterMeta = {\n id: 'hedera/hiero',\n didMethods: ['hedera'],\n caip2Networks: [\n 'hedera:mainnet',\n 'hedera:testnet',\n 'hedera:previewnet',\n 'hedera:devnet',\n ],\n caip10Namespaces: ['hedera'],\n displayName: 'Hedera (Hiero Registrar)',\n description: 'Issues did:hedera identifiers using the Hiero DID registrar.',\n homepage: 'https://github.com/hiero-ledger/hiero-did-sdk-js',\n };\n\n supports(method: string): boolean {\n return method === 'hedera';\n }\n\n async issue(request: DidIssueRequest): Promise<string> {\n if (request.method !== 'hedera') {\n throw new Error('HederaHieroIssuer only handles method \"hedera\"');\n }\n if (!('client' in request)) {\n throw new Error('Hedera client is required to issue did:hedera');\n }\n const did = await createDID(\n {},\n { client: (request as DidIssueRequestHedera).client },\n );\n return did.did;\n }\n}\n"],"names":[],"mappings":";AAIO,MAAM,kBAAuC;AAAA,EAA7C,cAAA;AACL,SAAS,OAAoB;AAAA,MAC3B,IAAI;AAAA,MACJ,YAAY,CAAC,QAAQ;AAAA,MACrB,eAAe;AAAA,QACb;AAAA,QACA;AAAA,QACA;AAAA,QACA;AAAA,MAAA;AAAA,MAEF,kBAAkB,CAAC,QAAQ;AAAA,MAC3B,aAAa;AAAA,MACb,aAAa;AAAA,MACb,UAAU;AAAA,IAAA;AAAA,EACZ;AAAA,EAEA,SAAS,QAAyB;AAChC,WAAO,WAAW;AAAA,EACpB;AAAA,EAEA,MAAM,MAAM,SAA2C;AACrD,QAAI,QAAQ,WAAW,UAAU;AAC/B,YAAM,IAAI,MAAM,gDAAgD;AAAA,IAClE;AACA,QAAI,EAAE,YAAY,UAAU;AAC1B,YAAM,IAAI,MAAM,+CAA+C;AAAA,IACjE;AACA,UAAM,MAAM,MAAM;AAAA,MAChB,CAAA;AAAA,MACA,EAAE,QAAS,QAAkC,OAAA;AAAA,IAAO;AAEtD,WAAO,IAAI;AAAA,EACb;AACF;"}
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@hashgraphonline/standards-sdk",
|
|
3
|
-
"version": "0.0.
|
|
3
|
+
"version": "0.0.199",
|
|
4
4
|
"description": "The Hashgraph Online Standards SDK provides a complete implementation of the Hashgraph Consensus Standards (HCS), giving developers all the tools needed to build applications on Hedera.",
|
|
5
5
|
"type": "module",
|
|
6
6
|
"files": [
|