@hashgraphonline/standards-sdk 0.0.121 → 0.0.123
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-10/sdk.d.ts +47 -3
- package/dist/cjs/hcs-10/sdk.d.ts.map +1 -1
- package/dist/cjs/hcs-10/types.d.ts +17 -0
- package/dist/cjs/hcs-10/types.d.ts.map +1 -1
- package/dist/cjs/hcs-11/client.d.ts +18 -1
- package/dist/cjs/hcs-11/client.d.ts.map +1 -1
- package/dist/cjs/hcs-11/index.d.ts +1 -0
- package/dist/cjs/hcs-11/index.d.ts.map +1 -1
- package/dist/cjs/hcs-11/mcp-server-builder.d.ts +122 -0
- package/dist/cjs/hcs-11/mcp-server-builder.d.ts.map +1 -0
- package/dist/cjs/hcs-11/types.d.ts +81 -18
- package/dist/cjs/hcs-11/types.d.ts.map +1 -1
- package/dist/cjs/{index-CHar8dVv-B2IK-7-2.cjs → index-CHar8dVv-ZN8JTP7M.cjs} +2 -2
- package/dist/cjs/{index-CHar8dVv-B2IK-7-2.cjs.map → index-CHar8dVv-ZN8JTP7M.cjs.map} +1 -1
- package/dist/cjs/index-Clbwco-g.cjs +11 -0
- package/dist/cjs/index-Clbwco-g.cjs.map +1 -0
- package/dist/cjs/services/mirror-node.d.ts.map +1 -1
- package/dist/cjs/standards-sdk.cjs +1 -1
- package/dist/es/hcs-10/sdk.d.ts +47 -3
- package/dist/es/hcs-10/sdk.d.ts.map +1 -1
- package/dist/es/hcs-10/types.d.ts +17 -0
- package/dist/es/hcs-10/types.d.ts.map +1 -1
- package/dist/es/hcs-11/client.d.ts +18 -1
- package/dist/es/hcs-11/client.d.ts.map +1 -1
- package/dist/es/hcs-11/index.d.ts +1 -0
- package/dist/es/hcs-11/index.d.ts.map +1 -1
- package/dist/es/hcs-11/mcp-server-builder.d.ts +122 -0
- package/dist/es/hcs-11/mcp-server-builder.d.ts.map +1 -0
- package/dist/es/hcs-11/types.d.ts +81 -18
- package/dist/es/hcs-11/types.d.ts.map +1 -1
- package/dist/es/services/mirror-node.d.ts.map +1 -1
- package/dist/es/standards-sdk.es.js +17 -12
- package/dist/es/standards-sdk.es.js.map +1 -1
- package/dist/es/standards-sdk.es10.js +1 -1
- package/dist/es/standards-sdk.es11.js +2 -2
- package/dist/es/standards-sdk.es12.js +1 -1
- package/dist/es/standards-sdk.es13.js +236 -639
- package/dist/es/standards-sdk.es13.js.map +1 -1
- package/dist/es/standards-sdk.es14.js +770 -85
- package/dist/es/standards-sdk.es14.js.map +1 -1
- package/dist/es/standards-sdk.es15.js +132 -68
- package/dist/es/standards-sdk.es15.js.map +1 -1
- package/dist/es/standards-sdk.es16.js +66 -19
- package/dist/es/standards-sdk.es16.js.map +1 -1
- package/dist/es/standards-sdk.es17.js +18 -156
- package/dist/es/standards-sdk.es17.js.map +1 -1
- package/dist/es/standards-sdk.es18.js +150 -146
- package/dist/es/standards-sdk.es18.js.map +1 -1
- package/dist/es/standards-sdk.es19.js +134 -561
- package/dist/es/standards-sdk.es19.js.map +1 -1
- package/dist/es/standards-sdk.es2.js +1 -1
- package/dist/es/standards-sdk.es20.js +577 -24
- package/dist/es/standards-sdk.es20.js.map +1 -1
- package/dist/es/standards-sdk.es21.js +23 -400
- package/dist/es/standards-sdk.es21.js.map +1 -1
- package/dist/es/standards-sdk.es22.js +381 -1507
- package/dist/es/standards-sdk.es22.js.map +1 -1
- package/dist/es/standards-sdk.es23.js +1511 -133
- package/dist/es/standards-sdk.es23.js.map +1 -1
- package/dist/es/standards-sdk.es24.js +155 -7
- package/dist/es/standards-sdk.es24.js.map +1 -1
- package/dist/es/standards-sdk.es25.js +7 -7190
- package/dist/es/standards-sdk.es25.js.map +1 -1
- package/dist/es/standards-sdk.es26.js +7190 -2
- package/dist/es/standards-sdk.es26.js.map +1 -1
- package/dist/es/standards-sdk.es27.js +2 -501
- package/dist/es/standards-sdk.es27.js.map +1 -1
- package/dist/es/standards-sdk.es28.js +457 -65
- package/dist/es/standards-sdk.es28.js.map +1 -1
- package/dist/es/standards-sdk.es29.js +80 -37
- package/dist/es/standards-sdk.es29.js.map +1 -1
- package/dist/es/standards-sdk.es3.js +1 -1
- package/dist/es/standards-sdk.es30.js +33 -223
- package/dist/es/standards-sdk.es30.js.map +1 -1
- package/dist/es/standards-sdk.es31.js +184 -101
- package/dist/es/standards-sdk.es31.js.map +1 -1
- package/dist/es/standards-sdk.es32.js +167 -5
- package/dist/es/standards-sdk.es32.js.map +1 -1
- package/dist/es/standards-sdk.es33.js +8 -7132
- package/dist/es/standards-sdk.es33.js.map +1 -1
- package/dist/es/standards-sdk.es34.js +7134 -41
- package/dist/es/standards-sdk.es34.js.map +1 -1
- package/dist/es/standards-sdk.es35.js +45 -0
- package/dist/es/standards-sdk.es35.js.map +1 -0
- package/dist/es/standards-sdk.es4.js +1 -1
- package/dist/es/standards-sdk.es5.js +4 -4
- package/dist/es/standards-sdk.es7.js +573 -62
- package/dist/es/standards-sdk.es7.js.map +1 -1
- package/dist/es/standards-sdk.es8.js +5 -5
- package/dist/es/standards-sdk.es9.js +2 -2
- package/dist/umd/hcs-10/sdk.d.ts +47 -3
- package/dist/umd/hcs-10/sdk.d.ts.map +1 -1
- package/dist/umd/hcs-10/types.d.ts +17 -0
- package/dist/umd/hcs-10/types.d.ts.map +1 -1
- package/dist/umd/hcs-11/client.d.ts +18 -1
- package/dist/umd/hcs-11/client.d.ts.map +1 -1
- package/dist/umd/hcs-11/index.d.ts +1 -0
- package/dist/umd/hcs-11/index.d.ts.map +1 -1
- package/dist/umd/hcs-11/mcp-server-builder.d.ts +122 -0
- package/dist/umd/hcs-11/mcp-server-builder.d.ts.map +1 -0
- package/dist/umd/hcs-11/types.d.ts +81 -18
- package/dist/umd/hcs-11/types.d.ts.map +1 -1
- package/dist/umd/services/mirror-node.d.ts.map +1 -1
- package/dist/umd/standards-sdk.umd.js +19 -19
- package/dist/umd/standards-sdk.umd.js.map +1 -1
- package/package.json +1 -1
- package/dist/cjs/index-CHS2J8pS.cjs +0 -11
- package/dist/cjs/index-CHS2J8pS.cjs.map +0 -1
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"standards-sdk.es20.js","sources":["../../src/utils/key-type-detector.ts"],"sourcesContent":["import { PrivateKey } from '@hashgraph/sdk';\n\nexport type KeyType = 'ed25519' | 'ecdsa';\n\nexport interface KeyDetectionResult {\n detectedType: KeyType;\n privateKey: PrivateKey;\n}\n\n/**\n * Detects the key type from a private key string and returns the parsed PrivateKey\n * @param privateKeyString The private key string to detect type from\n * @returns The detected key type and parsed PrivateKey\n * @throws Error if the private key cannot be parsed\n */\nexport function detectKeyTypeFromString(\n privateKeyString: string,\n): KeyDetectionResult {\n let detectedType: KeyType = 'ed25519';\n\n if (privateKeyString.startsWith('0x')) {\n detectedType = 'ecdsa';\n } else if (privateKeyString.startsWith('302e020100300506032b6570')) {\n detectedType = 'ed25519';\n } else if (privateKeyString.startsWith('3030020100300706052b8104000a')) {\n detectedType = 'ecdsa';\n } else if (privateKeyString.length === 96) {\n detectedType = 'ed25519';\n } else if (privateKeyString.length === 88) {\n detectedType = 'ecdsa';\n }\n\n try {\n const privateKey =\n detectedType === 'ecdsa'\n ? PrivateKey.fromStringECDSA(privateKeyString)\n : PrivateKey.fromStringED25519(privateKeyString);\n return { detectedType, privateKey };\n } catch (parseError) {\n const alternateType = detectedType === 'ecdsa' ? 'ed25519' : 'ecdsa';\n try {\n const privateKey =\n alternateType === 'ecdsa'\n ? PrivateKey.fromStringECDSA(privateKeyString)\n : PrivateKey.fromStringED25519(privateKeyString);\n return { detectedType: alternateType, privateKey };\n } catch (secondError) {\n throw new Error(\n `Failed to parse private key as either ED25519 or ECDSA: ${parseError}`,\n );\n }\n }\n}\n"],"names":[],"mappings":";AAeO,SAAS,wBACd,kBACoB;AACpB,MAAI,eAAwB;AAExB,MAAA,iBAAiB,WAAW,IAAI,GAAG;AACtB,mBAAA;AAAA,EACN,WAAA,iBAAiB,WAAW,0BAA0B,GAAG;AACnD,mBAAA;AAAA,EACN,WAAA,iBAAiB,WAAW,8BAA8B,GAAG;AACvD,mBAAA;AAAA,EAAA,WACN,iBAAiB,WAAW,IAAI;AAC1B,mBAAA;AAAA,EAAA,WACN,iBAAiB,WAAW,IAAI;AAC1B,mBAAA;AAAA,EAAA;AAGb,MAAA;AACI,UAAA,aACJ,iBAAiB,UACb,WAAW,gBAAgB,gBAAgB,IAC3C,WAAW,kBAAkB,gBAAgB;AAC5C,WAAA,EAAE,cAAc,WAAW;AAAA,WAC3B,YAAY;AACb,UAAA,gBAAgB,iBAAiB,UAAU,YAAY;AACzD,QAAA;AACI,YAAA,aACJ,kBAAkB,UACd,WAAW,gBAAgB,gBAAgB,IAC3C,WAAW,kBAAkB,gBAAgB;AAC5C,aAAA,EAAE,cAAc,eAAe,WAAW;AAAA,aAC1C,aAAa;AACpB,YAAM,IAAI;AAAA,QACR,2DAA2D,UAAU;AAAA,MACvE;AAAA,IAAA;AAAA,EACF;AAEJ;"}
|
|
1
|
+
{"version":3,"file":"standards-sdk.es20.js","sources":["../../src/utils/transaction-parser.ts"],"sourcesContent":["import { proto } from '@hashgraph/proto';\nimport { Buffer } from 'buffer';\nimport { Hbar, HbarUnit, Long } from '@hashgraph/sdk';\nimport { ethers } from 'ethers';\nimport { TokenAmount, ParsedTransaction } from './transaction-parser-types'; // Import all types\nimport { HTSParser } from './parsers/hts-parser'; // Import HTSParser\nimport { HCSParser } from './parsers/hcs-parser'; // Import HCSParser\nimport { FileParser } from './parsers/file-parser'; // Import FileParser\nimport { CryptoParser } from './parsers/crypto-parser'; // Import CryptoParser\nimport { SCSParser } from './parsers/scs-parser'; // Import SCSParser\nimport { UtilParser } from './parsers/util-parser'; // Import UtilParser\n\n/**\n * Types for transaction parsing results\n */\n\nexport class TransactionParser {\n /**\n * Parse a base64 encoded transaction body and return structured data\n * @param transactionBodyBase64 - The base64 encoded transaction body\n * @returns The parsed transaction\n */\n static parseTransactionBody(\n transactionBodyBase64: string,\n ): ParsedTransaction {\n try {\n const buffer = ethers.decodeBase64(transactionBodyBase64);\n const txBody = proto.SchedulableTransactionBody.decode(buffer);\n\n const transactionType = this.getTransactionType(txBody);\n\n const result: ParsedTransaction = {\n type: transactionType,\n humanReadableType: this.getHumanReadableType(transactionType),\n transfers: [],\n tokenTransfers: [],\n raw: txBody,\n };\n\n if (txBody.memo) {\n result.memo = txBody.memo;\n }\n\n if (txBody.transactionFee) {\n const hbarAmount = Hbar.fromTinybars(\n Long.fromValue(txBody.transactionFee),\n );\n result.transactionFee = hbarAmount.toString(HbarUnit.Hbar);\n }\n\n if (txBody.cryptoTransfer) {\n CryptoParser.parseCryptoTransfers(txBody.cryptoTransfer, result);\n }\n\n if (txBody.cryptoDelete) {\n result.cryptoDelete = CryptoParser.parseCryptoDelete(\n txBody.cryptoDelete,\n );\n }\n\n if (txBody.cryptoCreateAccount) {\n result.cryptoCreateAccount = CryptoParser.parseCryptoCreateAccount(\n txBody.cryptoCreateAccount,\n );\n }\n\n if (txBody.cryptoUpdateAccount) {\n result.cryptoUpdateAccount = CryptoParser.parseCryptoUpdateAccount(\n txBody.cryptoUpdateAccount,\n );\n }\n\n if (txBody.cryptoApproveAllowance) {\n result.cryptoApproveAllowance =\n CryptoParser.parseCryptoApproveAllowance(\n txBody.cryptoApproveAllowance,\n );\n }\n\n if (txBody.cryptoDeleteAllowance) {\n result.cryptoDeleteAllowance = CryptoParser.parseCryptoDeleteAllowance(\n txBody.cryptoDeleteAllowance,\n );\n }\n\n if (txBody.contractCall) {\n result.contractCall = SCSParser.parseContractCall(txBody.contractCall);\n }\n\n if (txBody.contractCreateInstance) {\n result.contractCreate = SCSParser.parseContractCreate(\n txBody.contractCreateInstance,\n );\n }\n\n if (txBody.contractUpdateInstance) {\n result.contractUpdate = SCSParser.parseContractUpdate(\n txBody.contractUpdateInstance,\n );\n }\n\n if (txBody.contractDeleteInstance) {\n result.contractDelete = SCSParser.parseContractDelete(\n txBody.contractDeleteInstance,\n );\n }\n\n if (txBody.tokenCreation) {\n result.tokenCreation = HTSParser.parseTokenCreate(txBody.tokenCreation);\n }\n\n if (txBody.tokenMint) {\n result.tokenMint = HTSParser.parseTokenMint(txBody.tokenMint);\n }\n\n if (txBody.tokenBurn) {\n result.tokenBurn = HTSParser.parseTokenBurn(txBody.tokenBurn);\n }\n\n if (txBody.tokenUpdate) {\n result.tokenUpdate = HTSParser.parseTokenUpdate(txBody.tokenUpdate);\n }\n\n if (txBody.tokenFeeScheduleUpdate) {\n result.tokenFeeScheduleUpdate = HTSParser.parseTokenFeeScheduleUpdate(\n txBody.tokenFeeScheduleUpdate,\n );\n }\n\n if (txBody.tokenFreeze) {\n result.tokenFreeze = HTSParser.parseTokenFreeze(txBody.tokenFreeze);\n }\n\n if (txBody.tokenUnfreeze) {\n result.tokenUnfreeze = HTSParser.parseTokenUnfreeze(\n txBody.tokenUnfreeze,\n );\n }\n\n if (txBody.tokenGrantKyc) {\n result.tokenGrantKyc = HTSParser.parseTokenGrantKyc(\n txBody.tokenGrantKyc,\n );\n }\n\n if (txBody.tokenRevokeKyc) {\n result.tokenRevokeKyc = HTSParser.parseTokenRevokeKyc(\n txBody.tokenRevokeKyc,\n );\n }\n\n if (txBody.tokenPause) {\n result.tokenPause = HTSParser.parseTokenPause(txBody.tokenPause);\n }\n\n if (txBody.tokenUnpause) {\n result.tokenUnpause = HTSParser.parseTokenUnpause(txBody.tokenUnpause);\n }\n\n if (txBody.tokenWipe) {\n result.tokenWipeAccount = HTSParser.parseTokenWipeAccount(\n txBody.tokenWipe,\n );\n }\n\n if (txBody.tokenDeletion) {\n result.tokenDelete = HTSParser.parseTokenDelete(txBody.tokenDeletion);\n }\n\n if (txBody.tokenAssociate) {\n result.tokenAssociate = HTSParser.parseTokenAssociate(\n txBody.tokenAssociate,\n );\n }\n\n if (txBody.tokenDissociate) {\n result.tokenDissociate = HTSParser.parseTokenDissociate(\n txBody.tokenDissociate,\n );\n }\n\n if (txBody.consensusCreateTopic) {\n result.consensusCreateTopic = HCSParser.parseConsensusCreateTopic(\n txBody.consensusCreateTopic,\n );\n }\n\n if (txBody.consensusSubmitMessage) {\n result.consensusSubmitMessage = HCSParser.parseConsensusSubmitMessage(\n txBody.consensusSubmitMessage,\n );\n }\n\n if (txBody.consensusUpdateTopic) {\n result.consensusUpdateTopic = HCSParser.parseConsensusUpdateTopic(\n txBody.consensusUpdateTopic,\n );\n }\n\n if (txBody.consensusDeleteTopic) {\n result.consensusDeleteTopic = HCSParser.parseConsensusDeleteTopic(\n txBody.consensusDeleteTopic,\n );\n }\n\n if (txBody.fileCreate) {\n result.fileCreate = FileParser.parseFileCreate(txBody.fileCreate);\n }\n\n if (txBody.fileAppend) {\n result.fileAppend = FileParser.parseFileAppend(txBody.fileAppend);\n }\n\n if (txBody.fileUpdate) {\n result.fileUpdate = FileParser.parseFileUpdate(txBody.fileUpdate);\n }\n\n if (txBody.fileDelete) {\n result.fileDelete = FileParser.parseFileDelete(txBody.fileDelete);\n }\n\n if (txBody.utilPrng) {\n result.utilPrng = UtilParser.parseUtilPrng(txBody.utilPrng);\n }\n\n return result;\n } catch (error) {\n throw new Error(\n `Failed to parse transaction body: ${\n error instanceof Error ? error.message : String(error)\n }`,\n );\n }\n }\n\n /**\n * Parse details from a complete schedule response\n * @param scheduleResponse - The schedule response to parse\n * @returns The parsed transaction\n */\n static parseScheduleResponse(scheduleResponse: {\n transaction_body: string;\n memo?: string;\n }): ParsedTransaction {\n if (!scheduleResponse.transaction_body) {\n throw new Error('Schedule response missing transaction_body');\n }\n\n const parsed = this.parseTransactionBody(scheduleResponse.transaction_body);\n\n if (scheduleResponse.memo) {\n parsed.memo = scheduleResponse.memo;\n }\n\n return parsed;\n }\n\n /**\n * Determine the transaction type\n * @param txBody - The transaction body to determine the type of\n * @returns The type of the transaction\n */\n private static getTransactionType(\n txBody: proto.SchedulableTransactionBody,\n ): string {\n let transactionType = 'unknown';\n\n if (txBody.cryptoTransfer) {\n transactionType = 'cryptoTransfer';\n } else if (txBody.cryptoCreateAccount) {\n transactionType = 'cryptoCreateAccount';\n } else if (txBody.cryptoUpdateAccount) {\n transactionType = 'cryptoUpdateAccount';\n } else if (txBody.cryptoApproveAllowance) {\n transactionType = 'cryptoApproveAllowance';\n } else if (txBody.cryptoDeleteAllowance) {\n transactionType = 'cryptoDeleteAllowance';\n } else if (txBody.cryptoDelete) {\n transactionType = 'cryptoDelete';\n } else if (txBody.consensusCreateTopic) {\n transactionType = 'consensusCreateTopic';\n } else if (txBody.consensusUpdateTopic) {\n transactionType = 'consensusUpdateTopic';\n } else if (txBody.consensusSubmitMessage) {\n transactionType = 'consensusSubmitMessage';\n } else if (txBody.consensusDeleteTopic) {\n transactionType = 'consensusDeleteTopic';\n } else if (txBody.fileCreate) {\n transactionType = 'fileCreate';\n } else if (txBody.fileAppend) {\n transactionType = 'fileAppend';\n } else if (txBody.fileUpdate) {\n transactionType = 'fileUpdate';\n } else if (txBody.fileDelete) {\n transactionType = 'fileDelete';\n } else if (txBody.contractCall) {\n transactionType = 'contractCall';\n } else if (txBody.contractCreateInstance) {\n transactionType = 'contractCreate';\n } else if (txBody.contractUpdateInstance) {\n transactionType = 'contractUpdate';\n } else if (txBody.contractDeleteInstance) {\n transactionType = 'contractDelete';\n } else if (txBody.tokenCreation) {\n transactionType = 'tokenCreate';\n } else if (txBody.tokenUpdate) {\n transactionType = 'tokenUpdate';\n } else if (txBody.tokenDeletion) {\n transactionType = 'tokenDelete';\n } else if (txBody.tokenAssociate) {\n transactionType = 'tokenAssociate';\n } else if (txBody.tokenDissociate) {\n transactionType = 'tokenDissociate';\n } else if (txBody.tokenMint) {\n transactionType = 'tokenMint';\n } else if (txBody.tokenBurn) {\n transactionType = 'tokenBurn';\n } else if (txBody.tokenFeeScheduleUpdate) {\n transactionType = 'tokenFeeScheduleUpdate';\n } else if (txBody.tokenFreeze) {\n transactionType = 'tokenFreeze';\n } else if (txBody.tokenUnfreeze) {\n transactionType = 'tokenUnfreeze';\n } else if (txBody.tokenGrantKyc) {\n transactionType = 'tokenGrantKyc';\n } else if (txBody.tokenRevokeKyc) {\n transactionType = 'tokenRevokeKyc';\n } else if (txBody.tokenPause) {\n transactionType = 'tokenPause';\n } else if (txBody.tokenUnpause) {\n transactionType = 'tokenUnpause';\n } else if (txBody.tokenWipe) {\n transactionType = 'tokenWipe';\n } else if (txBody.utilPrng) {\n transactionType = 'utilPrng';\n }\n\n return transactionType;\n }\n\n /**\n * Convert technical transaction type to human-readable format\n * @param type - The technical transaction type\n * @returns The human-readable transaction type\n */\n private static getHumanReadableType(type: string): string {\n const typeMap: Record<string, string> = {\n cryptoTransfer: 'HBAR Transfer',\n cryptoCreateAccount: 'Create Account',\n cryptoUpdateAccount: 'Update Account',\n cryptoDeleteAccount: 'Delete Account',\n cryptoApproveAllowance: 'Approve Allowance',\n cryptoDeleteAllowance: 'Delete Allowance',\n cryptoDelete: 'Delete Account',\n\n consensusCreateTopic: 'Create Topic',\n consensusUpdateTopic: 'Update Topic',\n consensusSubmitMessage: 'Submit Message',\n consensusDeleteTopic: 'Delete Topic',\n\n fileCreate: 'Create File',\n fileAppend: 'Append File',\n fileUpdate: 'Update File',\n fileDelete: 'Delete File',\n\n contractCall: 'Contract Call',\n contractCreate: 'Create Contract',\n contractUpdate: 'Update Contract',\n contractDelete: 'Delete Contract',\n ethereumTransaction: 'Ethereum Transaction',\n\n tokenCreate: 'Create Token',\n tokenUpdate: 'Update Token',\n tokenDelete: 'Delete Token',\n tokenAssociate: 'Associate Token',\n tokenDissociate: 'Dissociate Token',\n tokenMint: 'Mint Token',\n tokenBurn: 'Burn Token',\n tokenFeeScheduleUpdate: 'Update Token Fee Schedule',\n tokenFreeze: 'Freeze Token',\n tokenUnfreeze: 'Unfreeze Token',\n tokenGrantKyc: 'Grant KYC',\n tokenRevokeKyc: 'Revoke KYC',\n tokenPause: 'Pause Token',\n tokenUnpause: 'Unpause Token',\n tokenWipe: 'Wipe Token',\n\n scheduleCreate: 'Create Schedule',\n scheduleSign: 'Sign Schedule',\n\n utilPrng: 'Generate Random Number',\n\n unknown: 'Unknown Transaction',\n };\n\n let result: string;\n if (typeMap[type]) {\n result = typeMap[type];\n } else {\n result = 'Unknown Transaction';\n }\n\n return result;\n }\n\n /**\n * Get a human-readable summary of the transaction\n * @param parsedTx - The parsed transaction\n * @returns The human-readable summary of the transaction\n */\n static getTransactionSummary(parsedTx: ParsedTransaction): string {\n if (parsedTx.type === 'cryptoTransfer') {\n const senders = [];\n const receivers = [];\n\n for (const transfer of parsedTx.transfers) {\n const originalAmountFloat = parseFloat(transfer.amount);\n\n let displayStr = transfer.amount;\n if (displayStr.startsWith('-')) {\n displayStr = displayStr.substring(1);\n }\n displayStr = displayStr.replace(/\\s*ℏ$/, '');\n\n if (originalAmountFloat < 0) {\n senders.push(`${transfer.accountId} (${displayStr} ℏ)`);\n } else if (originalAmountFloat > 0) {\n receivers.push(`${transfer.accountId} (${displayStr} ℏ)`);\n }\n }\n\n if (senders.length > 0 && receivers.length > 0) {\n return `Transfer of HBAR from ${senders.join(', ')} to ${receivers.join(\n ', ',\n )}`;\n } else {\n return parsedTx.humanReadableType;\n }\n } else if (parsedTx.contractCall) {\n let contractCallSummary = `Contract call to ${parsedTx.contractCall.contractId} with ${parsedTx.contractCall.gas} gas`;\n\n if (parsedTx.contractCall.amount > 0) {\n contractCallSummary += ` and ${parsedTx.contractCall.amount} HBAR`;\n }\n\n if (parsedTx.contractCall.functionName) {\n contractCallSummary += ` calling function ${parsedTx.contractCall.functionName}`;\n }\n\n return contractCallSummary;\n } else if (parsedTx.tokenMint) {\n return `Mint ${parsedTx.tokenMint.amount} tokens for token ${parsedTx.tokenMint.tokenId}`;\n } else if (parsedTx.tokenBurn) {\n return `Burn ${parsedTx.tokenBurn.amount} tokens for token ${parsedTx.tokenBurn.tokenId}`;\n } else if (parsedTx.tokenCreation) {\n let summary = `Create token ${\n parsedTx.tokenCreation.tokenName || '(No Name)'\n } (${parsedTx.tokenCreation.tokenSymbol || '(No Symbol)'})`;\n if (parsedTx.tokenCreation.initialSupply) {\n summary += ` with initial supply ${parsedTx.tokenCreation.initialSupply}`;\n }\n if (parsedTx.tokenCreation.customFees?.length) {\n summary += ` including ${parsedTx.tokenCreation.customFees.length} custom fee(s)`;\n }\n return summary;\n } else if (parsedTx.tokenTransfers.length > 0) {\n const tokenGroups: Record<string, TokenAmount[]> = {};\n\n for (const transfer of parsedTx.tokenTransfers) {\n if (!tokenGroups[transfer.tokenId]) {\n tokenGroups[transfer.tokenId] = [];\n }\n tokenGroups[transfer.tokenId].push(transfer);\n }\n\n const tokenSummaries = [];\n\n for (const [tokenId, transfers] of Object.entries(tokenGroups)) {\n const tokenSenders = [];\n const tokenReceivers = [];\n\n for (const transfer of transfers) {\n const transferAmountValue = parseFloat(transfer.amount.toString());\n if (transferAmountValue < 0) {\n tokenSenders.push(\n `${transfer.accountId} (${Math.abs(transferAmountValue)})`,\n );\n } else if (transferAmountValue > 0) {\n tokenReceivers.push(\n `${transfer.accountId} (${transferAmountValue})`,\n );\n }\n }\n\n if (tokenSenders.length > 0 && tokenReceivers.length > 0) {\n tokenSummaries.push(\n `Transfer of token ${tokenId} from ${tokenSenders.join(\n ', ',\n )} to ${tokenReceivers.join(', ')}`,\n );\n }\n }\n\n if (tokenSummaries.length > 0) {\n return tokenSummaries.join('; ');\n } else {\n return parsedTx.humanReadableType;\n }\n } else if (parsedTx.consensusCreateTopic) {\n let summary = `Create new topic`;\n if (parsedTx.consensusCreateTopic.memo) {\n summary += ` with memo \"${parsedTx.consensusCreateTopic.memo}\"`;\n }\n if (parsedTx.consensusCreateTopic.autoRenewAccountId) {\n summary += `, auto-renew by ${parsedTx.consensusCreateTopic.autoRenewAccountId}`;\n }\n return summary;\n } else if (parsedTx.consensusSubmitMessage) {\n let summary = `Submit message`;\n if (parsedTx.consensusSubmitMessage.topicId) {\n summary += ` to topic ${parsedTx.consensusSubmitMessage.topicId}`;\n }\n if (parsedTx.consensusSubmitMessage.message) {\n if (parsedTx.consensusSubmitMessage.messageEncoding === 'utf8') {\n const messagePreview =\n parsedTx.consensusSubmitMessage.message.substring(0, 70);\n summary += `: \"${messagePreview}${\n parsedTx.consensusSubmitMessage.message.length > 70 ? '...' : ''\n }\"`;\n } else {\n summary += ` (binary message data, length: ${\n Buffer.from(parsedTx.consensusSubmitMessage.message, 'base64')\n .length\n } bytes)`;\n }\n }\n if (\n parsedTx.consensusSubmitMessage.chunkInfoNumber &&\n parsedTx.consensusSubmitMessage.chunkInfoTotal\n ) {\n summary += ` (chunk ${parsedTx.consensusSubmitMessage.chunkInfoNumber}/${parsedTx.consensusSubmitMessage.chunkInfoTotal})`;\n }\n return summary;\n } else if (parsedTx.fileCreate) {\n let summary = 'Create File';\n if (parsedTx.fileCreate.memo) {\n summary += ` with memo \"${parsedTx.fileCreate.memo}\"`;\n }\n if (parsedTx.fileCreate.contents) {\n summary += ` (includes content)`;\n }\n return summary;\n } else if (parsedTx.fileAppend) {\n return `Append to File ${parsedTx.fileAppend.fileId || '(Unknown ID)'}`;\n } else if (parsedTx.fileUpdate) {\n return `Update File ${parsedTx.fileUpdate.fileId || '(Unknown ID)'}`;\n } else if (parsedTx.fileDelete) {\n return `Delete File ${parsedTx.fileDelete.fileId || '(Unknown ID)'}`;\n } else if (parsedTx.consensusUpdateTopic) {\n return `Update Topic ${\n parsedTx.consensusUpdateTopic.topicId || '(Unknown ID)'\n }`;\n } else if (parsedTx.consensusDeleteTopic) {\n return `Delete Topic ${\n parsedTx.consensusDeleteTopic.topicId || '(Unknown ID)'\n }`;\n } else if (parsedTx.tokenUpdate) {\n return `Update Token ${parsedTx.tokenUpdate.tokenId || '(Unknown ID)'}`;\n } else if (parsedTx.tokenFeeScheduleUpdate) {\n return `Update Fee Schedule for Token ${\n parsedTx.tokenFeeScheduleUpdate.tokenId || '(Unknown ID)'\n }`;\n } else if (parsedTx.utilPrng) {\n let summary = 'Generate Random Number';\n if (parsedTx.utilPrng.range && parsedTx.utilPrng.range > 0) {\n summary += ` (range up to ${parsedTx.utilPrng.range - 1})`;\n }\n return summary;\n } else if (parsedTx.tokenFreeze) {\n return `Freeze Token ${parsedTx.tokenFreeze.tokenId} for Account ${parsedTx.tokenFreeze.accountId}`;\n } else if (parsedTx.tokenUnfreeze) {\n return `Unfreeze Token ${parsedTx.tokenUnfreeze.tokenId} for Account ${parsedTx.tokenUnfreeze.accountId}`;\n } else if (parsedTx.tokenGrantKyc) {\n return `Grant KYC for Token ${parsedTx.tokenGrantKyc.tokenId} to Account ${parsedTx.tokenGrantKyc.accountId}`;\n } else if (parsedTx.tokenRevokeKyc) {\n return `Revoke KYC for Token ${parsedTx.tokenRevokeKyc.tokenId} from Account ${parsedTx.tokenRevokeKyc.accountId}`;\n } else if (parsedTx.tokenPause) {\n return `Pause Token ${parsedTx.tokenPause.tokenId}`;\n } else if (parsedTx.tokenUnpause) {\n return `Unpause Token ${parsedTx.tokenUnpause.tokenId}`;\n } else if (parsedTx.tokenWipeAccount) {\n let summary = `Wipe Token ${parsedTx.tokenWipeAccount.tokenId} from Account ${parsedTx.tokenWipeAccount.accountId}`;\n if (parsedTx.tokenWipeAccount.serialNumbers?.length) {\n summary += ` (Serials: ${parsedTx.tokenWipeAccount.serialNumbers.join(\n ', ',\n )})`;\n }\n if (parsedTx.tokenWipeAccount.amount) {\n summary += ` (Amount: ${parsedTx.tokenWipeAccount.amount})`;\n }\n return summary;\n } else if (parsedTx.tokenDelete) {\n return `Delete Token ${parsedTx.tokenDelete.tokenId}`;\n } else if (parsedTx.tokenAssociate) {\n return `Associate Account ${\n parsedTx.tokenAssociate.accountId\n } with Tokens: ${parsedTx.tokenAssociate.tokenIds?.join(', ')}`;\n } else if (parsedTx.tokenDissociate) {\n return `Dissociate Account ${\n parsedTx.tokenDissociate.accountId\n } from Tokens: ${parsedTx.tokenDissociate.tokenIds?.join(', ')}`;\n } else if (parsedTx.cryptoDelete) {\n return `Delete Account ${parsedTx.cryptoDelete.deleteAccountId}`;\n }\n if (parsedTx.cryptoCreateAccount) {\n let summary = 'Create Account';\n if (\n parsedTx.cryptoCreateAccount.initialBalance &&\n parsedTx.cryptoCreateAccount.initialBalance !== '0'\n ) {\n summary += ` with balance ${parsedTx.cryptoCreateAccount.initialBalance}`;\n }\n if (parsedTx.cryptoCreateAccount.alias) {\n summary += ` (Alias: ${parsedTx.cryptoCreateAccount.alias})`;\n }\n return summary;\n }\n if (parsedTx.cryptoUpdateAccount) {\n return `Update Account ${\n parsedTx.cryptoUpdateAccount.accountIdToUpdate || '(Unknown ID)'\n }`;\n }\n if (parsedTx.cryptoApproveAllowance) {\n let count =\n (parsedTx.cryptoApproveAllowance.hbarAllowances?.length || 0) +\n (parsedTx.cryptoApproveAllowance.tokenAllowances?.length || 0) +\n (parsedTx.cryptoApproveAllowance.nftAllowances?.length || 0);\n return `Approve ${count} Crypto Allowance(s)`;\n }\n if (parsedTx.cryptoDeleteAllowance) {\n return `Delete ${\n parsedTx.cryptoDeleteAllowance.nftAllowancesToRemove?.length || 0\n } NFT Crypto Allowance(s)`;\n }\n if (parsedTx.contractCreate) {\n let summary = 'Create Contract';\n if (parsedTx.contractCreate.memo) {\n summary += ` (Memo: ${parsedTx.contractCreate.memo})`;\n }\n return summary;\n }\n if (parsedTx.contractUpdate) {\n return `Update Contract ${\n parsedTx.contractUpdate.contractIdToUpdate || '(Unknown ID)'\n }`;\n }\n if (parsedTx.contractDelete) {\n let summary = `Delete Contract ${\n parsedTx.contractDelete.contractIdToDelete || '(Unknown ID)'\n }`;\n if (parsedTx.contractDelete.transferAccountId) {\n summary += ` (Transfer to Account: ${parsedTx.contractDelete.transferAccountId})`;\n } else if (parsedTx.contractDelete.transferContractId) {\n summary += ` (Transfer to Contract: ${parsedTx.contractDelete.transferContractId})`;\n }\n return summary;\n }\n if (\n parsedTx.humanReadableType &&\n parsedTx.humanReadableType !== 'Unknown Transaction'\n ) {\n return parsedTx.humanReadableType;\n }\n if (parsedTx.tokenTransfers.length > 0) {\n const tokenGroups: Record<string, TokenAmount[]> = {};\n for (const transfer of parsedTx.tokenTransfers) {\n if (!tokenGroups[transfer.tokenId]) {\n tokenGroups[transfer.tokenId] = [];\n }\n tokenGroups[transfer.tokenId].push(transfer);\n }\n const tokenSummaries = [];\n for (const [tokenId, transfers] of Object.entries(tokenGroups)) {\n const tokenSenders = transfers\n .filter(t => t.amount < 0)\n .map(t => `${t.accountId} (${Math.abs(t.amount)})`);\n const tokenReceivers = transfers\n .filter(t => t.amount > 0)\n .map(t => `${t.accountId} (${t.amount})`);\n if (tokenSenders.length > 0 && tokenReceivers.length > 0) {\n tokenSummaries.push(\n `Transfer of token ${tokenId} from ${tokenSenders.join(\n ', ',\n )} to ${tokenReceivers.join(', ')}`,\n );\n } else if (tokenReceivers.length > 0) {\n tokenSummaries.push(\n `Token ${tokenId} received by ${tokenReceivers.join(', ')}`,\n );\n } else if (tokenSenders.length > 0) {\n tokenSummaries.push(\n `Token ${tokenId} sent from ${tokenSenders.join(', ')}`,\n );\n }\n }\n if (tokenSummaries.length > 0) return tokenSummaries.join('; ');\n }\n\n return 'Unknown Transaction';\n }\n}\n"],"names":[],"mappings":"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"}
|
|
@@ -1,410 +1,33 @@
|
|
|
1
|
-
import {
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
})
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
...input.type === "buffer" ? { fileName: input.fileName, bufferSize: input.buffer.byteLength } : {}
|
|
15
|
-
});
|
|
16
|
-
try {
|
|
17
|
-
if (options.mode === "hashinal" && options.metadata) {
|
|
18
|
-
validateHashinalMetadata(options.metadata, logger);
|
|
19
|
-
}
|
|
20
|
-
let sdk;
|
|
21
|
-
if (existingSDK) {
|
|
22
|
-
logger.debug("Using existing InscriptionSDK instance");
|
|
23
|
-
sdk = existingSDK;
|
|
24
|
-
} else if (options.apiKey) {
|
|
25
|
-
logger.debug("Initializing InscriptionSDK with API key");
|
|
26
|
-
sdk = new InscriptionSDK({
|
|
27
|
-
apiKey: options.apiKey,
|
|
28
|
-
network: clientConfig.network || "mainnet"
|
|
29
|
-
});
|
|
30
|
-
} else {
|
|
31
|
-
logger.debug("Initializing InscriptionSDK with server auth");
|
|
32
|
-
sdk = await InscriptionSDK.createWithAuth({
|
|
33
|
-
type: "server",
|
|
34
|
-
accountId: clientConfig.accountId,
|
|
35
|
-
privateKey: clientConfig.privateKey,
|
|
36
|
-
network: clientConfig.network || "mainnet"
|
|
37
|
-
});
|
|
38
|
-
}
|
|
39
|
-
const baseRequest = {
|
|
40
|
-
holderId: clientConfig.accountId,
|
|
41
|
-
metadata: options.metadata || {},
|
|
42
|
-
tags: options.tags || [],
|
|
43
|
-
mode: options.mode || "file",
|
|
44
|
-
chunkSize: options.chunkSize
|
|
45
|
-
};
|
|
46
|
-
let request;
|
|
47
|
-
switch (input.type) {
|
|
48
|
-
case "url":
|
|
49
|
-
request = {
|
|
50
|
-
...baseRequest,
|
|
51
|
-
file: {
|
|
52
|
-
type: "url",
|
|
53
|
-
url: input.url
|
|
54
|
-
}
|
|
55
|
-
};
|
|
56
|
-
break;
|
|
57
|
-
case "file":
|
|
58
|
-
request = {
|
|
59
|
-
...baseRequest,
|
|
60
|
-
file: {
|
|
61
|
-
type: "path",
|
|
62
|
-
path: input.path
|
|
63
|
-
}
|
|
64
|
-
};
|
|
65
|
-
break;
|
|
66
|
-
case "buffer":
|
|
67
|
-
request = {
|
|
68
|
-
...baseRequest,
|
|
69
|
-
file: {
|
|
70
|
-
type: "base64",
|
|
71
|
-
base64: Buffer.from(input.buffer).toString("base64"),
|
|
72
|
-
fileName: input.fileName,
|
|
73
|
-
mimeType: input.mimeType
|
|
74
|
-
}
|
|
75
|
-
};
|
|
76
|
-
break;
|
|
77
|
-
}
|
|
78
|
-
if (options.mode === "hashinal") {
|
|
79
|
-
request.metadataObject = options.metadata;
|
|
80
|
-
request.creator = options.metadata?.creator || clientConfig.accountId;
|
|
81
|
-
request.description = options.metadata?.description;
|
|
82
|
-
if (options.jsonFileURL) {
|
|
83
|
-
request.jsonFileURL = options.jsonFileURL;
|
|
84
|
-
}
|
|
85
|
-
}
|
|
86
|
-
logger.debug("Preparing to inscribe content", {
|
|
87
|
-
type: input.type,
|
|
88
|
-
mode: options.mode || "file",
|
|
89
|
-
holderId: clientConfig.accountId
|
|
90
|
-
});
|
|
91
|
-
const result = await sdk.inscribeAndExecute(request, clientConfig);
|
|
92
|
-
logger.info("Starting to inscribe.", {
|
|
93
|
-
type: input.type,
|
|
94
|
-
mode: options.mode || "file",
|
|
95
|
-
transactionId: result.jobId
|
|
96
|
-
});
|
|
97
|
-
if (options.waitForConfirmation) {
|
|
98
|
-
logger.debug("Waiting for inscription confirmation", {
|
|
99
|
-
transactionId: result.jobId,
|
|
100
|
-
maxAttempts: options.waitMaxAttempts,
|
|
101
|
-
intervalMs: options.waitIntervalMs
|
|
102
|
-
});
|
|
103
|
-
const inscription = await waitForInscriptionConfirmation(
|
|
104
|
-
sdk,
|
|
105
|
-
result.jobId,
|
|
106
|
-
options.waitMaxAttempts,
|
|
107
|
-
options.waitIntervalMs,
|
|
108
|
-
options.progressCallback
|
|
109
|
-
);
|
|
110
|
-
logger.info("Inscription confirmation received", {
|
|
111
|
-
transactionId: result.jobId
|
|
112
|
-
});
|
|
113
|
-
return {
|
|
114
|
-
confirmed: true,
|
|
115
|
-
result,
|
|
116
|
-
inscription,
|
|
117
|
-
sdk
|
|
118
|
-
};
|
|
119
|
-
}
|
|
120
|
-
return {
|
|
121
|
-
confirmed: false,
|
|
122
|
-
result,
|
|
123
|
-
sdk
|
|
124
|
-
};
|
|
125
|
-
} catch (error) {
|
|
126
|
-
logger.error("Error during inscription process", error);
|
|
127
|
-
throw error;
|
|
1
|
+
import { PrivateKey } from "@hashgraph/sdk";
|
|
2
|
+
function detectKeyTypeFromString(privateKeyString) {
|
|
3
|
+
let detectedType = "ed25519";
|
|
4
|
+
if (privateKeyString.startsWith("0x")) {
|
|
5
|
+
detectedType = "ecdsa";
|
|
6
|
+
} else if (privateKeyString.startsWith("302e020100300506032b6570")) {
|
|
7
|
+
detectedType = "ed25519";
|
|
8
|
+
} else if (privateKeyString.startsWith("3030020100300706052b8104000a")) {
|
|
9
|
+
detectedType = "ecdsa";
|
|
10
|
+
} else if (privateKeyString.length === 96) {
|
|
11
|
+
detectedType = "ed25519";
|
|
12
|
+
} else if (privateKeyString.length === 88) {
|
|
13
|
+
detectedType = "ecdsa";
|
|
128
14
|
}
|
|
129
|
-
}
|
|
130
|
-
async function inscribeWithSigner(input, signer, options, existingSDK) {
|
|
131
|
-
const logger = Logger.getInstance({
|
|
132
|
-
module: "Inscriber",
|
|
133
|
-
...options.logging
|
|
134
|
-
});
|
|
135
|
-
logger.info("Starting inscription process with signer", {
|
|
136
|
-
type: input.type,
|
|
137
|
-
mode: options.mode || "file",
|
|
138
|
-
...input.type === "url" ? { url: input.url } : {},
|
|
139
|
-
...input.type === "file" ? { path: input.path } : {},
|
|
140
|
-
...input.type === "buffer" ? { fileName: input.fileName, bufferSize: input.buffer.byteLength } : {}
|
|
141
|
-
});
|
|
142
15
|
try {
|
|
143
|
-
|
|
144
|
-
|
|
145
|
-
|
|
146
|
-
const
|
|
147
|
-
logger.debug("Using account ID from signer", { accountId });
|
|
148
|
-
let sdk;
|
|
149
|
-
if (existingSDK) {
|
|
150
|
-
logger.debug("Using existing InscriptionSDK instance");
|
|
151
|
-
sdk = existingSDK;
|
|
152
|
-
} else if (options.apiKey) {
|
|
153
|
-
logger.debug("Initializing InscriptionSDK with API key");
|
|
154
|
-
sdk = new InscriptionSDK({
|
|
155
|
-
apiKey: options.apiKey,
|
|
156
|
-
network: options.network || "mainnet"
|
|
157
|
-
});
|
|
158
|
-
} else {
|
|
159
|
-
logger.debug("Initializing InscriptionSDK with client auth");
|
|
160
|
-
sdk = await InscriptionSDK.createWithAuth({
|
|
161
|
-
type: "client",
|
|
162
|
-
accountId,
|
|
163
|
-
signer,
|
|
164
|
-
network: options.network || "mainnet"
|
|
165
|
-
});
|
|
166
|
-
}
|
|
167
|
-
const baseRequest = {
|
|
168
|
-
holderId: accountId,
|
|
169
|
-
metadata: options.metadata || {},
|
|
170
|
-
tags: options.tags || [],
|
|
171
|
-
mode: options.mode || "file",
|
|
172
|
-
chunkSize: options.chunkSize
|
|
173
|
-
};
|
|
174
|
-
let request;
|
|
175
|
-
switch (input.type) {
|
|
176
|
-
case "url":
|
|
177
|
-
request = {
|
|
178
|
-
...baseRequest,
|
|
179
|
-
file: {
|
|
180
|
-
type: "url",
|
|
181
|
-
url: input.url
|
|
182
|
-
}
|
|
183
|
-
};
|
|
184
|
-
break;
|
|
185
|
-
case "file":
|
|
186
|
-
request = {
|
|
187
|
-
...baseRequest,
|
|
188
|
-
file: {
|
|
189
|
-
type: "path",
|
|
190
|
-
path: input.path
|
|
191
|
-
}
|
|
192
|
-
};
|
|
193
|
-
break;
|
|
194
|
-
case "buffer":
|
|
195
|
-
request = {
|
|
196
|
-
...baseRequest,
|
|
197
|
-
file: {
|
|
198
|
-
type: "base64",
|
|
199
|
-
base64: Buffer.from(input.buffer).toString("base64"),
|
|
200
|
-
fileName: input.fileName,
|
|
201
|
-
mimeType: input.mimeType
|
|
202
|
-
}
|
|
203
|
-
};
|
|
204
|
-
break;
|
|
205
|
-
}
|
|
206
|
-
if (options.mode === "hashinal") {
|
|
207
|
-
request.metadataObject = options.metadata;
|
|
208
|
-
request.creator = options.metadata?.creator || accountId;
|
|
209
|
-
request.description = options.metadata?.description;
|
|
210
|
-
if (options.jsonFileURL) {
|
|
211
|
-
request.jsonFileURL = options.jsonFileURL;
|
|
212
|
-
}
|
|
213
|
-
}
|
|
214
|
-
logger.debug("Preparing to inscribe content with signer", {
|
|
215
|
-
type: input.type,
|
|
216
|
-
mode: options.mode || "file",
|
|
217
|
-
holderId: accountId
|
|
218
|
-
});
|
|
219
|
-
const result = await sdk.inscribe(
|
|
220
|
-
{
|
|
221
|
-
...request,
|
|
222
|
-
holderId: accountId
|
|
223
|
-
},
|
|
224
|
-
signer
|
|
225
|
-
);
|
|
226
|
-
logger.info("Inscription started", {
|
|
227
|
-
type: input.type,
|
|
228
|
-
mode: options.mode || "file",
|
|
229
|
-
transactionId: result.jobId
|
|
230
|
-
});
|
|
231
|
-
if (options.waitForConfirmation) {
|
|
232
|
-
logger.debug("Waiting for inscription confirmation", {
|
|
233
|
-
transactionId: result.jobId,
|
|
234
|
-
maxAttempts: options.waitMaxAttempts,
|
|
235
|
-
intervalMs: options.waitIntervalMs
|
|
236
|
-
});
|
|
237
|
-
const inscription = await waitForInscriptionConfirmation(
|
|
238
|
-
sdk,
|
|
239
|
-
result.jobId,
|
|
240
|
-
options.waitMaxAttempts,
|
|
241
|
-
options.waitIntervalMs,
|
|
242
|
-
options.progressCallback
|
|
243
|
-
);
|
|
244
|
-
logger.info("Inscription confirmation received", {
|
|
245
|
-
transactionId: result.jobId
|
|
246
|
-
});
|
|
247
|
-
return {
|
|
248
|
-
confirmed: true,
|
|
249
|
-
result,
|
|
250
|
-
inscription,
|
|
251
|
-
sdk
|
|
252
|
-
};
|
|
253
|
-
}
|
|
254
|
-
return {
|
|
255
|
-
confirmed: false,
|
|
256
|
-
result,
|
|
257
|
-
sdk
|
|
258
|
-
};
|
|
259
|
-
} catch (error) {
|
|
260
|
-
logger.error("Error during inscription process", error);
|
|
261
|
-
throw error;
|
|
262
|
-
}
|
|
263
|
-
}
|
|
264
|
-
async function retrieveInscription(transactionId, options) {
|
|
265
|
-
const logger = Logger.getInstance({
|
|
266
|
-
module: "Inscriber",
|
|
267
|
-
...options?.logging || {}
|
|
268
|
-
});
|
|
269
|
-
const formattedTransactionId = transactionId.includes("@") ? `${transactionId.split("@")[0]}-${transactionId.split("@")[1].replace(/\./g, "-")}` : transactionId;
|
|
270
|
-
logger.info("Retrieving inscription", {
|
|
271
|
-
originalTransactionId: transactionId,
|
|
272
|
-
formattedTransactionId
|
|
273
|
-
});
|
|
274
|
-
try {
|
|
275
|
-
let sdk;
|
|
276
|
-
if (options?.apiKey) {
|
|
277
|
-
logger.debug("Initializing InscriptionSDK with API key");
|
|
278
|
-
sdk = new InscriptionSDK({
|
|
279
|
-
apiKey: options.apiKey,
|
|
280
|
-
network: options.network || "mainnet"
|
|
281
|
-
});
|
|
282
|
-
} else if (options?.accountId && options?.privateKey) {
|
|
283
|
-
logger.debug("Initializing InscriptionSDK with server auth");
|
|
284
|
-
sdk = await InscriptionSDK.createWithAuth({
|
|
285
|
-
type: "server",
|
|
286
|
-
accountId: options.accountId,
|
|
287
|
-
privateKey: options.privateKey,
|
|
288
|
-
network: options.network || "mainnet"
|
|
289
|
-
});
|
|
290
|
-
} else {
|
|
291
|
-
const error = new Error(
|
|
292
|
-
"Either API key or account ID and private key are required for retrieving inscriptions"
|
|
293
|
-
);
|
|
294
|
-
logger.error("Missing authentication credentials", {
|
|
295
|
-
hasApiKey: Boolean(options?.apiKey),
|
|
296
|
-
hasAccountId: Boolean(options?.accountId),
|
|
297
|
-
hasPrivateKey: Boolean(options?.privateKey)
|
|
298
|
-
});
|
|
299
|
-
throw error;
|
|
300
|
-
}
|
|
301
|
-
logger.debug("Initialized SDK for inscription retrieval", {
|
|
302
|
-
formattedTransactionId,
|
|
303
|
-
network: options.network || "mainnet"
|
|
304
|
-
});
|
|
305
|
-
const result = await sdk.retrieveInscription(formattedTransactionId);
|
|
306
|
-
logger.info("Successfully retrieved inscription", {
|
|
307
|
-
formattedTransactionId
|
|
308
|
-
});
|
|
309
|
-
return result;
|
|
310
|
-
} catch (error) {
|
|
311
|
-
logger.error("Error retrieving inscription", {
|
|
312
|
-
formattedTransactionId,
|
|
313
|
-
error
|
|
314
|
-
});
|
|
315
|
-
throw error;
|
|
316
|
-
}
|
|
317
|
-
}
|
|
318
|
-
function validateHashinalMetadata(metadata, logger) {
|
|
319
|
-
const requiredFields = ["name", "creator", "description", "type"];
|
|
320
|
-
const missingFields = requiredFields.filter((field) => !metadata[field]);
|
|
321
|
-
if (missingFields.length > 0) {
|
|
322
|
-
const error = new Error(
|
|
323
|
-
`Missing required Hashinal metadata fields: ${missingFields.join(", ")}`
|
|
324
|
-
);
|
|
325
|
-
logger.error("Hashinal metadata validation failed", { missingFields });
|
|
326
|
-
throw error;
|
|
327
|
-
}
|
|
328
|
-
logger.debug("Hashinal metadata validation passed", {
|
|
329
|
-
name: metadata.name,
|
|
330
|
-
creator: metadata.creator,
|
|
331
|
-
description: metadata.description,
|
|
332
|
-
type: metadata.type,
|
|
333
|
-
hasAttributes: !!metadata.attributes,
|
|
334
|
-
hasProperties: !!metadata.properties
|
|
335
|
-
});
|
|
336
|
-
}
|
|
337
|
-
async function waitForInscriptionConfirmation(sdk, transactionId, maxAttempts = 30, intervalMs = 4e3, progressCallback) {
|
|
338
|
-
const logger = Logger.getInstance({ module: "Inscriber" });
|
|
339
|
-
const progressReporter = new ProgressReporter({
|
|
340
|
-
module: "Inscriber",
|
|
341
|
-
logger,
|
|
342
|
-
callback: progressCallback
|
|
343
|
-
});
|
|
344
|
-
try {
|
|
345
|
-
logger.debug("Waiting for inscription confirmation", {
|
|
346
|
-
transactionId,
|
|
347
|
-
maxAttempts,
|
|
348
|
-
intervalMs
|
|
349
|
-
});
|
|
350
|
-
progressReporter.preparing("Preparing for inscription confirmation", 5, {
|
|
351
|
-
transactionId,
|
|
352
|
-
maxAttempts,
|
|
353
|
-
intervalMs
|
|
354
|
-
});
|
|
16
|
+
const privateKey = detectedType === "ecdsa" ? PrivateKey.fromStringECDSA(privateKeyString) : PrivateKey.fromStringED25519(privateKeyString);
|
|
17
|
+
return { detectedType, privateKey };
|
|
18
|
+
} catch (parseError) {
|
|
19
|
+
const alternateType = detectedType === "ecdsa" ? "ed25519" : "ecdsa";
|
|
355
20
|
try {
|
|
356
|
-
const
|
|
357
|
-
|
|
358
|
-
|
|
359
|
-
|
|
360
|
-
|
|
361
|
-
progressReporter.report({
|
|
362
|
-
stage,
|
|
363
|
-
message,
|
|
364
|
-
progressPercent: percent,
|
|
365
|
-
details: {}
|
|
366
|
-
});
|
|
367
|
-
};
|
|
368
|
-
return await waitMethod(
|
|
369
|
-
transactionId,
|
|
370
|
-
maxAttempts,
|
|
371
|
-
intervalMs,
|
|
372
|
-
true,
|
|
373
|
-
wrappedCallback
|
|
374
|
-
);
|
|
375
|
-
} catch (e) {
|
|
376
|
-
console.log(e);
|
|
377
|
-
logger.debug("Falling back to standard waitForInscription method", {
|
|
378
|
-
error: e
|
|
379
|
-
});
|
|
380
|
-
progressReporter.verifying("Verifying inscription status", 50, {
|
|
381
|
-
error: e
|
|
382
|
-
});
|
|
383
|
-
return await sdk.waitForInscription(
|
|
384
|
-
transactionId,
|
|
385
|
-
maxAttempts,
|
|
386
|
-
intervalMs,
|
|
387
|
-
true
|
|
21
|
+
const privateKey = alternateType === "ecdsa" ? PrivateKey.fromStringECDSA(privateKeyString) : PrivateKey.fromStringED25519(privateKeyString);
|
|
22
|
+
return { detectedType: alternateType, privateKey };
|
|
23
|
+
} catch (secondError) {
|
|
24
|
+
throw new Error(
|
|
25
|
+
`Failed to parse private key as either ED25519 or ECDSA: ${parseError}`
|
|
388
26
|
);
|
|
389
27
|
}
|
|
390
|
-
} catch (error) {
|
|
391
|
-
logger.error("Error waiting for inscription confirmation", {
|
|
392
|
-
transactionId,
|
|
393
|
-
maxAttempts,
|
|
394
|
-
intervalMs,
|
|
395
|
-
error
|
|
396
|
-
});
|
|
397
|
-
progressReporter.failed("Inscription confirmation failed", {
|
|
398
|
-
transactionId,
|
|
399
|
-
error
|
|
400
|
-
});
|
|
401
|
-
throw error;
|
|
402
28
|
}
|
|
403
29
|
}
|
|
404
30
|
export {
|
|
405
|
-
|
|
406
|
-
inscribeWithSigner,
|
|
407
|
-
retrieveInscription,
|
|
408
|
-
waitForInscriptionConfirmation
|
|
31
|
+
detectKeyTypeFromString
|
|
409
32
|
};
|
|
410
33
|
//# sourceMappingURL=standards-sdk.es21.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"standards-sdk.es21.js","sources":["../../src/inscribe/inscriber.ts"],"sourcesContent":["import { InscriptionSDK } from '@kiloscribe/inscription-sdk';\nimport {\n InscriptionOptions,\n InscriptionResult,\n RetrievedInscriptionResult,\n HederaClientConfig,\n} from './types';\nimport type { DAppSigner } from '@hashgraph/hedera-wallet-connect';\nimport { Logger } from '../utils/logger';\nimport { ProgressCallback, ProgressReporter } from '../utils/progress-reporter';\n\nexport type InscriptionInput =\n | { type: 'url'; url: string }\n | { type: 'file'; path: string }\n | {\n type: 'buffer';\n buffer: ArrayBuffer | Buffer;\n fileName: string;\n mimeType?: string;\n };\n\nexport type InscriptionResponse =\n | { confirmed: false; result: InscriptionResult; sdk: InscriptionSDK }\n | {\n confirmed: true;\n result: InscriptionResult;\n inscription: RetrievedInscriptionResult;\n sdk: InscriptionSDK;\n };\n\nexport async function inscribe(\n input: InscriptionInput,\n clientConfig: HederaClientConfig,\n options: InscriptionOptions,\n existingSDK?: InscriptionSDK,\n): Promise<InscriptionResponse> {\n const logger = Logger.getInstance({\n module: 'Inscriber',\n ...options.logging,\n });\n\n logger.info('Starting inscription process', {\n type: input.type,\n mode: options.mode || 'file',\n ...(input.type === 'url' ? { url: input.url } : {}),\n ...(input.type === 'file' ? { path: input.path } : {}),\n ...(input.type === 'buffer'\n ? { fileName: input.fileName, bufferSize: input.buffer.byteLength }\n : {}),\n });\n\n try {\n if (options.mode === 'hashinal' && options.metadata) {\n validateHashinalMetadata(options.metadata, logger);\n }\n\n let sdk: InscriptionSDK;\n\n if (existingSDK) {\n logger.debug('Using existing InscriptionSDK instance');\n sdk = existingSDK;\n } else if (options.apiKey) {\n logger.debug('Initializing InscriptionSDK with API key');\n sdk = new InscriptionSDK({\n apiKey: options.apiKey,\n network: clientConfig.network || 'mainnet',\n });\n } else {\n logger.debug('Initializing InscriptionSDK with server auth');\n sdk = await InscriptionSDK.createWithAuth({\n type: 'server',\n accountId: clientConfig.accountId,\n privateKey: clientConfig.privateKey,\n network: clientConfig.network || 'mainnet',\n });\n }\n\n const baseRequest = {\n holderId: clientConfig.accountId,\n metadata: options.metadata || {},\n tags: options.tags || [],\n mode: options.mode || 'file',\n chunkSize: options.chunkSize,\n };\n\n let request: any;\n switch (input.type) {\n case 'url':\n request = {\n ...baseRequest,\n file: {\n type: 'url',\n url: input.url,\n },\n };\n break;\n\n case 'file':\n request = {\n ...baseRequest,\n file: {\n type: 'path',\n path: input.path,\n },\n };\n break;\n\n case 'buffer':\n request = {\n ...baseRequest,\n file: {\n type: 'base64',\n base64: Buffer.from(input.buffer).toString('base64'),\n fileName: input.fileName,\n mimeType: input.mimeType,\n },\n };\n break;\n }\n\n if (options.mode === 'hashinal') {\n request.metadataObject = options.metadata;\n request.creator = options.metadata?.creator || clientConfig.accountId;\n request.description = options.metadata?.description;\n\n if (options.jsonFileURL) {\n request.jsonFileURL = options.jsonFileURL;\n }\n }\n\n logger.debug('Preparing to inscribe content', {\n type: input.type,\n mode: options.mode || 'file',\n holderId: clientConfig.accountId,\n });\n\n const result = await sdk.inscribeAndExecute(request, clientConfig);\n logger.info('Starting to inscribe.', {\n type: input.type,\n mode: options.mode || 'file',\n transactionId: result.jobId,\n });\n\n if (options.waitForConfirmation) {\n logger.debug('Waiting for inscription confirmation', {\n transactionId: result.jobId,\n maxAttempts: options.waitMaxAttempts,\n intervalMs: options.waitIntervalMs,\n });\n\n const inscription = await waitForInscriptionConfirmation(\n sdk,\n result.jobId,\n options.waitMaxAttempts,\n options.waitIntervalMs,\n options.progressCallback,\n );\n\n logger.info('Inscription confirmation received', {\n transactionId: result.jobId,\n });\n\n return {\n confirmed: true,\n result,\n inscription,\n sdk,\n };\n }\n\n return {\n confirmed: false,\n result,\n sdk,\n };\n } catch (error) {\n logger.error('Error during inscription process', error);\n throw error;\n }\n}\n\nexport async function inscribeWithSigner(\n input: InscriptionInput,\n signer: DAppSigner,\n options: InscriptionOptions,\n existingSDK?: InscriptionSDK,\n): Promise<InscriptionResponse> {\n const logger = Logger.getInstance({\n module: 'Inscriber',\n ...options.logging,\n });\n\n logger.info('Starting inscription process with signer', {\n type: input.type,\n mode: options.mode || 'file',\n ...(input.type === 'url' ? { url: input.url } : {}),\n ...(input.type === 'file' ? { path: input.path } : {}),\n ...(input.type === 'buffer'\n ? { fileName: input.fileName, bufferSize: input.buffer.byteLength }\n : {}),\n });\n\n try {\n if (options.mode === 'hashinal' && options.metadata) {\n validateHashinalMetadata(options.metadata, logger);\n }\n\n const accountId = signer.getAccountId().toString();\n logger.debug('Using account ID from signer', { accountId });\n\n let sdk: InscriptionSDK;\n\n if (existingSDK) {\n logger.debug('Using existing InscriptionSDK instance');\n sdk = existingSDK;\n } else if (options.apiKey) {\n logger.debug('Initializing InscriptionSDK with API key');\n sdk = new InscriptionSDK({\n apiKey: options.apiKey,\n network: options.network || 'mainnet',\n });\n } else {\n logger.debug('Initializing InscriptionSDK with client auth');\n sdk = await InscriptionSDK.createWithAuth({\n type: 'client',\n accountId,\n signer: signer,\n network: options.network || 'mainnet',\n });\n }\n\n const baseRequest = {\n holderId: accountId,\n metadata: options.metadata || {},\n tags: options.tags || [],\n mode: options.mode || 'file',\n chunkSize: options.chunkSize,\n };\n\n let request: any;\n switch (input.type) {\n case 'url':\n request = {\n ...baseRequest,\n file: {\n type: 'url',\n url: input.url,\n },\n };\n break;\n\n case 'file':\n request = {\n ...baseRequest,\n file: {\n type: 'path',\n path: input.path,\n },\n };\n break;\n\n case 'buffer':\n request = {\n ...baseRequest,\n file: {\n type: 'base64',\n base64: Buffer.from(input.buffer).toString('base64'),\n fileName: input.fileName,\n mimeType: input.mimeType,\n },\n };\n break;\n }\n\n if (options.mode === 'hashinal') {\n request.metadataObject = options.metadata;\n request.creator = options.metadata?.creator || accountId;\n request.description = options.metadata?.description;\n\n if (options.jsonFileURL) {\n request.jsonFileURL = options.jsonFileURL;\n }\n }\n\n logger.debug('Preparing to inscribe content with signer', {\n type: input.type,\n mode: options.mode || 'file',\n holderId: accountId,\n });\n\n const result = await sdk.inscribe(\n {\n ...request,\n holderId: accountId,\n },\n signer,\n );\n logger.info('Inscription started', {\n type: input.type,\n mode: options.mode || 'file',\n transactionId: result.jobId,\n });\n\n if (options.waitForConfirmation) {\n logger.debug('Waiting for inscription confirmation', {\n transactionId: result.jobId,\n maxAttempts: options.waitMaxAttempts,\n intervalMs: options.waitIntervalMs,\n });\n\n const inscription = await waitForInscriptionConfirmation(\n sdk,\n result.jobId,\n options.waitMaxAttempts,\n options.waitIntervalMs,\n options.progressCallback,\n );\n\n logger.info('Inscription confirmation received', {\n transactionId: result.jobId,\n });\n\n return {\n confirmed: true,\n result,\n inscription,\n sdk,\n };\n }\n\n return {\n confirmed: false,\n result,\n sdk,\n };\n } catch (error) {\n logger.error('Error during inscription process', error);\n throw error;\n }\n}\n\nexport async function retrieveInscription(\n transactionId: string,\n options: InscriptionOptions & { accountId?: string; privateKey?: string },\n): Promise<RetrievedInscriptionResult> {\n const logger = Logger.getInstance({\n module: 'Inscriber',\n ...(options?.logging || {}),\n });\n\n const formattedTransactionId = transactionId.includes('@')\n ? `${transactionId.split('@')[0]}-${transactionId\n .split('@')[1]\n .replace(/\\./g, '-')}`\n : transactionId;\n\n logger.info('Retrieving inscription', {\n originalTransactionId: transactionId,\n formattedTransactionId,\n });\n\n try {\n let sdk: InscriptionSDK;\n\n if (options?.apiKey) {\n logger.debug('Initializing InscriptionSDK with API key');\n sdk = new InscriptionSDK({\n apiKey: options.apiKey,\n network: options.network || 'mainnet',\n });\n } else if (options?.accountId && options?.privateKey) {\n logger.debug('Initializing InscriptionSDK with server auth');\n sdk = await InscriptionSDK.createWithAuth({\n type: 'server',\n accountId: options.accountId,\n privateKey: options.privateKey,\n network: options.network || 'mainnet',\n });\n } else {\n const error = new Error(\n 'Either API key or account ID and private key are required for retrieving inscriptions',\n );\n logger.error('Missing authentication credentials', {\n hasApiKey: Boolean(options?.apiKey),\n hasAccountId: Boolean(options?.accountId),\n hasPrivateKey: Boolean(options?.privateKey),\n });\n throw error;\n }\n\n logger.debug('Initialized SDK for inscription retrieval', {\n formattedTransactionId,\n network: options.network || 'mainnet',\n });\n\n const result = await sdk.retrieveInscription(formattedTransactionId);\n logger.info('Successfully retrieved inscription', {\n formattedTransactionId,\n });\n\n return result;\n } catch (error) {\n logger.error('Error retrieving inscription', {\n formattedTransactionId,\n error,\n });\n throw error;\n }\n}\n\nfunction validateHashinalMetadata(metadata: any, logger: any): void {\n const requiredFields = ['name', 'creator', 'description', 'type'];\n const missingFields = requiredFields.filter(field => !metadata[field]);\n\n if (missingFields.length > 0) {\n const error = new Error(\n `Missing required Hashinal metadata fields: ${missingFields.join(', ')}`,\n );\n logger.error('Hashinal metadata validation failed', { missingFields });\n throw error;\n }\n\n logger.debug('Hashinal metadata validation passed', {\n name: metadata.name,\n creator: metadata.creator,\n description: metadata.description,\n type: metadata.type,\n hasAttributes: !!metadata.attributes,\n hasProperties: !!metadata.properties,\n });\n}\n\nexport async function waitForInscriptionConfirmation(\n sdk: InscriptionSDK,\n transactionId: string,\n maxAttempts: number = 30,\n intervalMs: number = 4000,\n progressCallback?: ProgressCallback,\n): Promise<RetrievedInscriptionResult> {\n const logger = Logger.getInstance({ module: 'Inscriber' });\n const progressReporter = new ProgressReporter({\n module: 'Inscriber',\n logger,\n callback: progressCallback,\n });\n\n try {\n logger.debug('Waiting for inscription confirmation', {\n transactionId,\n maxAttempts,\n intervalMs,\n });\n\n progressReporter.preparing('Preparing for inscription confirmation', 5, {\n transactionId,\n maxAttempts,\n intervalMs,\n });\n\n try {\n const waitMethod = sdk.waitForInscription.bind(sdk) as (\n txId: string,\n maxAttempts: number,\n intervalMs: number,\n checkCompletion: boolean,\n progressCallback?: Function,\n ) => Promise<RetrievedInscriptionResult>;\n\n const wrappedCallback = (data: any) => {\n const stage = data.stage || 'confirming';\n const message = data.message || 'Processing inscription';\n const percent = data.progressPercent || 50;\n\n progressReporter.report({\n stage: stage,\n message: message,\n progressPercent: percent,\n details: {},\n });\n };\n\n return await waitMethod(\n transactionId,\n maxAttempts,\n intervalMs,\n true,\n wrappedCallback,\n );\n } catch (e) {\n console.log(e);\n // Fall back to standard method if progress callback fails\n logger.debug('Falling back to standard waitForInscription method', {\n error: e,\n });\n progressReporter.verifying('Verifying inscription status', 50, {\n error: e,\n });\n\n return await sdk.waitForInscription(\n transactionId,\n maxAttempts,\n intervalMs,\n true,\n );\n }\n } catch (error) {\n logger.error('Error waiting for inscription confirmation', {\n transactionId,\n maxAttempts,\n intervalMs,\n error,\n });\n\n progressReporter.failed('Inscription confirmation failed', {\n transactionId,\n error,\n });\n\n throw error;\n }\n}\n"],"names":[],"mappings":"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"}
|
|
1
|
+
{"version":3,"file":"standards-sdk.es21.js","sources":["../../src/utils/key-type-detector.ts"],"sourcesContent":["import { PrivateKey } from '@hashgraph/sdk';\n\nexport type KeyType = 'ed25519' | 'ecdsa';\n\nexport interface KeyDetectionResult {\n detectedType: KeyType;\n privateKey: PrivateKey;\n}\n\n/**\n * Detects the key type from a private key string and returns the parsed PrivateKey\n * @param privateKeyString The private key string to detect type from\n * @returns The detected key type and parsed PrivateKey\n * @throws Error if the private key cannot be parsed\n */\nexport function detectKeyTypeFromString(\n privateKeyString: string,\n): KeyDetectionResult {\n let detectedType: KeyType = 'ed25519';\n\n if (privateKeyString.startsWith('0x')) {\n detectedType = 'ecdsa';\n } else if (privateKeyString.startsWith('302e020100300506032b6570')) {\n detectedType = 'ed25519';\n } else if (privateKeyString.startsWith('3030020100300706052b8104000a')) {\n detectedType = 'ecdsa';\n } else if (privateKeyString.length === 96) {\n detectedType = 'ed25519';\n } else if (privateKeyString.length === 88) {\n detectedType = 'ecdsa';\n }\n\n try {\n const privateKey =\n detectedType === 'ecdsa'\n ? PrivateKey.fromStringECDSA(privateKeyString)\n : PrivateKey.fromStringED25519(privateKeyString);\n return { detectedType, privateKey };\n } catch (parseError) {\n const alternateType = detectedType === 'ecdsa' ? 'ed25519' : 'ecdsa';\n try {\n const privateKey =\n alternateType === 'ecdsa'\n ? PrivateKey.fromStringECDSA(privateKeyString)\n : PrivateKey.fromStringED25519(privateKeyString);\n return { detectedType: alternateType, privateKey };\n } catch (secondError) {\n throw new Error(\n `Failed to parse private key as either ED25519 or ECDSA: ${parseError}`,\n );\n }\n }\n}\n"],"names":[],"mappings":";AAeO,SAAS,wBACd,kBACoB;AACpB,MAAI,eAAwB;AAExB,MAAA,iBAAiB,WAAW,IAAI,GAAG;AACtB,mBAAA;AAAA,EACN,WAAA,iBAAiB,WAAW,0BAA0B,GAAG;AACnD,mBAAA;AAAA,EACN,WAAA,iBAAiB,WAAW,8BAA8B,GAAG;AACvD,mBAAA;AAAA,EAAA,WACN,iBAAiB,WAAW,IAAI;AAC1B,mBAAA;AAAA,EAAA,WACN,iBAAiB,WAAW,IAAI;AAC1B,mBAAA;AAAA,EAAA;AAGb,MAAA;AACI,UAAA,aACJ,iBAAiB,UACb,WAAW,gBAAgB,gBAAgB,IAC3C,WAAW,kBAAkB,gBAAgB;AAC5C,WAAA,EAAE,cAAc,WAAW;AAAA,WAC3B,YAAY;AACb,UAAA,gBAAgB,iBAAiB,UAAU,YAAY;AACzD,QAAA;AACI,YAAA,aACJ,kBAAkB,UACd,WAAW,gBAAgB,gBAAgB,IAC3C,WAAW,kBAAkB,gBAAgB;AAC5C,aAAA,EAAE,cAAc,eAAe,WAAW;AAAA,aAC1C,aAAa;AACpB,YAAM,IAAI;AAAA,QACR,2DAA2D,UAAU;AAAA,MACvE;AAAA,IAAA;AAAA,EACF;AAEJ;"}
|