@layerzerolabs/chain-utils 0.2.66 → 0.2.67

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.
@@ -11,32 +11,32 @@
11
11
  CLI Cleaning output folder
12
12
  CJS Build start
13
13
  ESM Build start
14
- Entry module "dist/ZZHCL54L.cjs" is using named and default exports together. Consumers of your bundle will have to use `chunk.default` to access the default export, which may not be what you want. Use `output.exports: "named"` to disable this warning.
15
14
  "default" is imported from external module "path" but never used in "dist/CWKWODSW.js".
16
15
  "fileURLToPath" is imported from external module "url" but never used in "dist/CWKWODSW.js".
17
- CJS dist/index.cjs 1.32 KB
18
- CJS dist/KHVGLVR5.cjs 2.10 KB
19
- CJS dist/addressParser.cjs 1.27 KB
20
- CJS dist/C2R7HHH3.cjs 23.34 KB
21
- CJS dist/ZZHCL54L.cjs 42.51 KB
22
- CJS dist/addressParser.test.cjs 676.37 KB
23
- CJS dist/index.cjs.map 181.00 B
24
- CJS dist/C2R7HHH3.cjs.map 48.67 KB
25
- CJS dist/ZZHCL54L.cjs.map 100.23 KB
26
- CJS dist/KHVGLVR5.cjs.map 926.00 B
27
- CJS dist/addressParser.cjs.map 78.00 B
28
- CJS dist/addressParser.test.cjs.map 1.63 MB
29
- CJS ⚡️ Build success in 3647ms
30
16
  ESM dist/addressParser.js 294.00 B
31
17
  ESM dist/index.js 337.00 B
32
- ESM dist/YMF6LH6C.js 20.72 KB
18
+ ESM dist/HNVHH5C2.js 20.76 KB
33
19
  ESM dist/CWKWODSW.js 1.87 KB
34
20
  ESM dist/PYS2ZW6G.js 42.16 KB
35
21
  ESM dist/addressParser.test.js 661.84 KB
36
22
  ESM dist/addressParser.js.map 77.00 B
37
- ESM dist/YMF6LH6C.js.map 48.57 KB
38
- ESM dist/CWKWODSW.js.map 669.00 B
39
23
  ESM dist/index.js.map 160.00 B
24
+ ESM dist/HNVHH5C2.js.map 48.62 KB
25
+ ESM dist/CWKWODSW.js.map 669.00 B
40
26
  ESM dist/PYS2ZW6G.js.map 100.20 KB
41
27
  ESM dist/addressParser.test.js.map 1.63 MB
42
- ESM ⚡️ Build success in 3648ms
28
+ ESM ⚡️ Build success in 1873ms
29
+ Entry module "dist/ZZHCL54L.cjs" is using named and default exports together. Consumers of your bundle will have to use `chunk.default` to access the default export, which may not be what you want. Use `output.exports: "named"` to disable this warning.
30
+ CJS dist/index.cjs 1.33 KB
31
+ CJS dist/addressParser.cjs 1.28 KB
32
+ CJS dist/7TRUXRQA.cjs 23.38 KB
33
+ CJS dist/KHVGLVR5.cjs 2.10 KB
34
+ CJS dist/ZZHCL54L.cjs 42.51 KB
35
+ CJS dist/addressParser.test.cjs 676.39 KB
36
+ CJS dist/index.cjs.map 181.00 B
37
+ CJS dist/addressParser.cjs.map 78.00 B
38
+ CJS dist/7TRUXRQA.cjs.map 48.72 KB
39
+ CJS dist/KHVGLVR5.cjs.map 926.00 B
40
+ CJS dist/ZZHCL54L.cjs.map 100.23 KB
41
+ CJS dist/addressParser.test.cjs.map 1.63 MB
42
+ CJS ⚡️ Build success in 2864ms
@@ -2,7 +2,7 @@
2
2
  > @layerzerolabs/chain-utils@0.0.0 lint /home/runner/work/monorepo-internal/monorepo-internal/packages/chain-abstractions/chain-utils
3
3
  > eslint . --max-warnings 0 || (eslint . --fix --max-warnings 0 && false)
4
4
 
5
- (node:66146) [MODULE_TYPELESS_PACKAGE_JSON] Warning: Module type of file:///home/runner/work/monorepo-internal/monorepo-internal/eslint.config.js?mtime=1775696305303 is not specified and it doesn't parse as CommonJS.
5
+ (node:75418) [MODULE_TYPELESS_PACKAGE_JSON] Warning: Module type of file:///home/runner/work/monorepo-internal/monorepo-internal/eslint.config.js?mtime=1775770562286 is not specified and it doesn't parse as CommonJS.
6
6
  Reparsing as ES module because module syntax was detected. This incurs a performance overhead.
7
7
  To eliminate this warning, add "type": "module" to /home/runner/work/monorepo-internal/monorepo-internal/package.json.
8
8
  (Use `node --trace-warnings ...` to show where the warning was created)
@@ -13,11 +13,11 @@ Breaking changes might not follow SemVer, please pin Vitest's version when using
13
13
  error: 'The address invalid-ton-address cannot be decoded as TON, hex, or base58'
14
14
  }
15
15
 
16
- ✓ src/addressParser.test.ts (78 tests) 243ms
16
+ ✓ src/addressParser.test.ts (78 tests) 248ms
17
17
 
18
18
   Test Files  1 passed (1)
19
19
   Tests  78 passed (78)
20
20
  Type Errors  no errors
21
-  Start at  01:00:58
22
-  Duration  2.22s (transform 368ms, setup 0ms, collect 1.58s, tests 243ms, environment 0ms, prepare 145ms)
21
+  Start at  21:39:28
22
+  Duration  2.50s (transform 444ms, setup 0ms, collect 1.76s, tests 248ms, environment 0ms, prepare 207ms)
23
23
 
package/LICENSE ADDED
@@ -0,0 +1,23 @@
1
+ Copyright (c) 2026 - LayerZero Labs Ltd.
2
+
3
+ Permission is hereby granted, free of charge, to any
4
+ person obtaining a copy of this software and associated
5
+ documentation files (the "Software"), to deal in the
6
+ Software without restriction, including without
7
+ limitation the rights to use, copy, modify, merge,
8
+ publish, distribute, sublicense, and/or sell copies of
9
+ the Software, and to permit persons to whom the Software
10
+ is furnished to do so, subject to the following
11
+ conditions:
12
+ The above copyright notice and this permission notice
13
+ shall be included in all copies or substantial portions
14
+ of the Software.
15
+ THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF
16
+ ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED
17
+ TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A
18
+ PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT
19
+ SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY
20
+ CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION
21
+ OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR
22
+ IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER
23
+ DEALINGS IN THE SOFTWARE.
@@ -70,7 +70,7 @@ var tonAddressParser = /* @__PURE__ */ KHVGLVR5_cjs.__name((chainName) => {
70
70
  if (address === void 0) return void 0;
71
71
  const numericalValue = addressParser.normalizedToBigInt(address);
72
72
  return {
73
- // FIXME this is wrong
73
+ // TODO: use Base64 native format instead of hex for TON addresses
74
74
  nativeAddress: addressUtilsTon.bigintToAddress(numericalValue).toString(),
75
75
  chainName
76
76
  };
@@ -460,5 +460,5 @@ exports.initiaAddressParser = initiaAddressParser;
460
460
  exports.starknetAddressParser = starknetAddressParser;
461
461
  exports.stellarAddressParser = stellarAddressParser;
462
462
  exports.tonAddressParser = tonAddressParser;
463
- //# sourceMappingURL=C2R7HHH3.cjs.map
464
- //# sourceMappingURL=C2R7HHH3.cjs.map
463
+ //# sourceMappingURL=7TRUXRQA.cjs.map
464
+ //# sourceMappingURL=7TRUXRQA.cjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../src/addressParser.ts"],"names":["init_cjs_shims","AddressEncoding","addressParser","chainName","ChainName","TON","tonAddressParser","SOLANA","base58AddressParser","INITIA","initiaAddressParser","STELLAR","stellarAddressParser","STARKNET","starknetAddressParser","hexAddressParser","normalizedToUnpaddedString","address","toString","normalizedToBigInt","BigInt","parseNative","nativeAddress","assertNative","expectedChainName","validateNative","Error","getAddress","undefined","parseTonAddress","normalizedToNative","numericalValue","bigintToAddress","normalizedToNativeString","nativeToNormalized","normalizeHex","addressToHex","nativeToBytes32Hex","hexZeroPad","nativeToBytes","hexToBytes","nativeToBytes32","normalizedToBytes32Hex","normalizedToBytes32","bytes32ToNormalized","bytes32Hex","parseNativeToUnpaddedHex","tonToNormalized","tonAddress","encoding","isHexString","test","AccAddress","fromHex","toHex","isBase58","bs58","encode","hex","bytesToHexPrefixed","decode","nativeByteLength","StaticChainConfigs","getAddressSizeInBytes","TRON","startsWith","slice","BYTES32_HEX_LENGTH","hexToStellarNative","hexPayload","length","raw","Buffer","from","StrKey","encodeContract","isValidStellarAddress","isValidEd25519PublicKey","isValidContract","isValidMed25519PublicKey","isValidLiquidityPool","isValidClaimableBalance","isValidSignedPayload","stellarTextEncoder","TextEncoder","stellarAsciiToNormalized","bytes","stellarTextDecoder","TextDecoder","normalizedToStellarAscii","normalizedHex","stellarAddress","rawBytes","decodeEd25519PublicKey","decodeContract","decodeLiquidityPool","fullBytes","decodeClaimableBalance","subarray","normalized"],"mappings":"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","file":"7TRUXRQA.cjs","sourcesContent":["import { AccAddress } from '@initia/initia.js';\nimport { StrKey } from '@stellar/stellar-sdk';\nimport type { Address } from '@ton/ton';\nimport bs58 from 'bs58';\n\nimport { addressToHex, bigintToAddress, parseTonAddress } from '@layerzerolabs/address-utils-ton';\nimport type { HexString, NormalizedHexString } from '@layerzerolabs/common-chain-model';\nimport { normalizeHex } from '@layerzerolabs/common-chain-model';\nimport {\n bytesToHexPrefixed,\n hexToBytes,\n hexZeroPad,\n isBase58,\n isHexString,\n} from '@layerzerolabs/common-encoding-utils';\nimport type {\n Base58String,\n ChainsByEncoding,\n ChainType,\n InferChainNamesForChainType,\n InferChainTypeForChainName,\n InitiaString,\n NativeAddress,\n ResolvedEncodingForChainName,\n StellarString,\n} from '@layerzerolabs/layerzero-definitions';\nimport type { ChainNativeAddress } from '@layerzerolabs/layerzero-definitions';\nimport { ChainName } from '@layerzerolabs/layerzero-definitions';\nimport { StaticChainConfigs } from '@layerzerolabs/static-chain-info';\nimport type { MaybeUndefinedMapped } from '@layerzerolabs/typescript-utils';\n\ntype NativeOrString<T extends ChainName> = ChainNativeAddress<T> | ResolvedEncodingForChainName<T>;\n\nexport enum AddressEncoding {\n HEX = 'hex',\n BASE58 = 'base58',\n TON = 'ton',\n INITIA = 'initia',\n STELLAR = 'stellar',\n}\n\nexport type ExtensionByChainType = {\n ton: {\n tonToNormalized: (tonAddress: Address) => NormalizedHexString;\n };\n};\n\nexport type InferExtensionByChainName<T extends ChainName> =\n InferChainTypeForChainName<T> extends keyof ExtensionByChainType\n ? ExtensionByChainType[InferChainTypeForChainName<T>]\n : {};\n\nexport type AddressParser<T extends ChainName> = {\n normalizedToNative: <Address extends NormalizedHexString | undefined>(\n address: Address,\n ) => MaybeUndefinedMapped<Address, ChainNativeAddress<T>>;\n normalizedToNativeString: <Address extends NormalizedHexString | undefined>(\n address: Address,\n ) => MaybeUndefinedMapped<Address, ResolvedEncodingForChainName<T>>;\n nativeToNormalized: <Address extends NativeOrString<T> | undefined>(\n nativeAddress: Address,\n ) => MaybeUndefinedMapped<Address, NormalizedHexString>;\n nativeToBytes: <Address extends NativeOrString<T> | undefined>(\n nativeAddress: Address,\n ) => MaybeUndefinedMapped<Address, Uint8Array>;\n nativeToBytes32Hex: <Address extends NativeOrString<T> | undefined>(\n nativeAddress: Address,\n ) => MaybeUndefinedMapped<Address, HexString>;\n nativeToBytes32: <Address extends NativeOrString<T> | undefined>(\n nativeAddress: Address,\n ) => MaybeUndefinedMapped<Address, Uint8Array>;\n normalizedToBytes32Hex: <Address extends NormalizedHexString | undefined>(\n address: Address,\n ) => MaybeUndefinedMapped<Address, HexString>;\n normalizedToBytes32: <Address extends NormalizedHexString | undefined>(\n address: Address,\n ) => MaybeUndefinedMapped<Address, Uint8Array>;\n bytes32ToNormalized: <B extends HexString | undefined>(\n bytes32Hex: B,\n ) => MaybeUndefinedMapped<B, NormalizedHexString>;\n validateNative: (\n nativeAddress: string | undefined,\n ) => nativeAddress is ResolvedEncodingForChainName<T>;\n /**\n * Parse a native address to a string if it is valid.\n * Throws an error if the native address is invalid.\n * @param nativeAddress - The native address to parse.\n * @returns The parsed native address.\n */\n parseNative: (nativeAddress: string | undefined) => NormalizedHexString;\n parseNativeToUnpaddedHex: (nativeAddress: string | undefined) => HexString;\n encoding: AddressEncoding;\n} & InferExtensionByChainName<T>;\n\nexport function addressParser<T extends ChainName>(chainName: T): AddressParser<T> {\n // TODO: find a way to narrow generics to avoid type cast\n if (chainName === ChainName.TON)\n return tonAddressParser(chainName) as unknown as AddressParser<T>;\n if (chainName === ChainName.SOLANA)\n return base58AddressParser(chainName) as unknown as AddressParser<T>;\n if (chainName === ChainName.INITIA)\n return initiaAddressParser(chainName) as unknown as AddressParser<T>;\n if (chainName === ChainName.STELLAR)\n return stellarAddressParser(chainName) as unknown as AddressParser<T>;\n if (chainName === ChainName.STARKNET)\n return starknetAddressParser(chainName) as unknown as AddressParser<T>;\n return hexAddressParser(chainName) as unknown as AddressParser<T>;\n}\n\nexport namespace addressParser {\n export const normalizedToUnpaddedString = (address: NormalizedHexString) => {\n return address.toString() as HexString;\n };\n\n export const normalizedToBigInt = (address: NormalizedHexString) => {\n return BigInt(address as unknown as HexString);\n };\n\n export const parseNative = (nativeAddress: NativeAddress) => {\n return addressParser(nativeAddress.chainName).parseNative(nativeAddress.nativeAddress);\n };\n}\n\nfunction assertNative<T extends ChainName>(\n nativeAddress: string | undefined,\n expectedChainName: T,\n): asserts nativeAddress is ResolvedEncodingForChainName<T> {\n if (!addressParser(expectedChainName).validateNative(nativeAddress)) {\n throw new Error(\n 'Cannot convert: \"' +\n nativeAddress +\n '\" - The native address does not match the expected format for the chain: ' +\n expectedChainName,\n );\n }\n}\n\nconst getAddress = <T extends ChainName>(nativeAddress: NativeOrString<T>) => {\n return typeof nativeAddress === 'object' ? nativeAddress.nativeAddress : nativeAddress;\n};\n\nexport const tonAddressParser: (\n chainName: InferChainNamesForChainType<ChainType.TON>,\n) => AddressParser<InferChainNamesForChainType<ChainType.TON>> = (chainName) => {\n return {\n validateNative: (nativeAddress): nativeAddress is HexString => {\n if (nativeAddress === undefined) {\n return false;\n }\n try {\n parseTonAddress(nativeAddress);\n return true;\n } catch {\n return false;\n }\n },\n normalizedToNative: (address) => {\n if (address === undefined) return undefined as any;\n const numericalValue = addressParser.normalizedToBigInt(address);\n return {\n // TODO: use Base64 native format instead of hex for TON addresses\n nativeAddress: bigintToAddress(numericalValue).toString() as HexString,\n chainName,\n };\n },\n normalizedToNativeString: (address) => {\n if (address === undefined) return undefined as any;\n return addressParser(chainName).normalizedToNative(address).nativeAddress;\n },\n nativeToNormalized: (nativeAddress) => {\n if (nativeAddress === undefined) return undefined as any;\n const address = getAddress(nativeAddress);\n assertNative(address, chainName);\n return normalizeHex(addressToHex(address));\n },\n nativeToBytes32Hex: (nativeAddress) => {\n // naturally ton is 32 bytes, pad it anyway\n if (nativeAddress === undefined) return undefined as any;\n return hexZeroPad(\n addressParser(chainName).nativeToNormalized(nativeAddress) as unknown as HexString,\n 32,\n );\n },\n nativeToBytes: (nativeAddress) => {\n if (nativeAddress === undefined) return undefined as any;\n return hexToBytes(addressParser(chainName).nativeToBytes32Hex(nativeAddress));\n },\n nativeToBytes32: (nativeAddress) => {\n if (nativeAddress === undefined) return undefined as any;\n return hexToBytes(addressParser(chainName).nativeToBytes32Hex(nativeAddress));\n },\n normalizedToBytes32Hex: (address) => {\n if (address === undefined) return undefined as any;\n return hexZeroPad(address as unknown as HexString, 32);\n },\n normalizedToBytes32: (address) => {\n if (address === undefined) return undefined as any;\n return hexToBytes(addressParser(chainName).normalizedToBytes32Hex(address));\n },\n bytes32ToNormalized: (bytes32Hex) => {\n if (bytes32Hex === undefined) return undefined as any;\n return normalizeHex(bytes32Hex);\n },\n parseNative: (nativeAddress) => {\n assertNative(nativeAddress, chainName);\n return addressParser(chainName).nativeToNormalized(nativeAddress);\n },\n parseNativeToUnpaddedHex: (nativeAddress) => {\n return addressParser(chainName).parseNative(nativeAddress) as unknown as HexString;\n },\n tonToNormalized: (tonAddress) => {\n return addressParser(chainName).parseNative(addressToHex(tonAddress));\n },\n encoding: AddressEncoding.TON,\n };\n};\n\nexport const initiaAddressParser: (\n chainName: ChainsByEncoding[InitiaString],\n) => AddressParser<ChainsByEncoding[InitiaString]> = (chainName) => {\n return {\n validateNative: (nativeAddress): nativeAddress is InitiaString => {\n if (nativeAddress === undefined) {\n return false;\n }\n try {\n // Both formats are native for the chain and are used kind of randomly.\n return (\n isHexString(nativeAddress) ||\n /^(init)1(['qpzry9x8gf2tvdw0s3jn54khce6mua7l]{38,66})$/.test(nativeAddress)\n );\n } catch {\n return false;\n }\n },\n normalizedToNative: (address) => {\n if (address === undefined) {\n return undefined as any;\n }\n return {\n nativeAddress: AccAddress.fromHex(address as unknown as HexString) as InitiaString,\n chainName,\n };\n },\n normalizedToNativeString: (address) => {\n if (address === undefined) return undefined as any;\n return addressParser(chainName).normalizedToNative(address).nativeAddress;\n },\n nativeToNormalized: (nativeAddress) => {\n if (nativeAddress === undefined) return undefined as any;\n const address = getAddress(nativeAddress);\n assertNative(address, chainName);\n if (isHexString(address)) {\n return normalizeHex(address);\n }\n return normalizeHex(AccAddress.toHex(nativeAddress.toString()) as HexString);\n },\n nativeToBytes32Hex: (nativeAddress) => {\n if (nativeAddress === undefined) return undefined as any;\n // naturally ton is 32 bytes, pad it anyway\n return hexZeroPad(\n addressParser(chainName).nativeToNormalized(nativeAddress) as unknown as HexString,\n 32,\n );\n },\n nativeToBytes: (nativeAddress) => {\n if (nativeAddress === undefined) return undefined as any;\n return hexToBytes(addressParser(chainName).nativeToBytes32Hex(nativeAddress));\n },\n nativeToBytes32: (nativeAddress) => {\n if (nativeAddress === undefined) return undefined as any;\n return hexToBytes(addressParser(chainName).nativeToBytes32Hex(nativeAddress));\n },\n normalizedToBytes32Hex: (address) => {\n if (address === undefined) return undefined as any;\n return hexZeroPad(address as unknown as HexString, 32);\n },\n normalizedToBytes32: (address) => {\n if (address === undefined) return undefined as any;\n return hexToBytes(addressParser(chainName).normalizedToBytes32Hex(address));\n },\n bytes32ToNormalized: (bytes32Hex) => {\n if (bytes32Hex === undefined) return undefined as any;\n return normalizeHex(bytes32Hex);\n },\n parseNative: (nativeAddress) => {\n assertNative(nativeAddress, chainName);\n return addressParser(chainName).nativeToNormalized(nativeAddress);\n },\n parseNativeToUnpaddedHex: (nativeAddress) => {\n return addressParser(chainName).parseNative(nativeAddress) as unknown as HexString;\n },\n encoding: AddressEncoding.INITIA,\n };\n};\n\nexport const base58AddressParser = (\n chainName: ChainsByEncoding[Base58String],\n): AddressParser<ChainsByEncoding[Base58String]> => {\n return {\n validateNative: (nativeAddress): nativeAddress is Base58String => {\n if (nativeAddress === undefined) return false;\n return isBase58(nativeAddress);\n },\n normalizedToNative: (address) => {\n if (address === undefined) return undefined as any;\n return {\n nativeAddress: bs58.encode(\n hexToBytes(address as unknown as HexString),\n ) as Base58String,\n chainName,\n };\n },\n normalizedToNativeString: (address) => {\n if (address === undefined) return undefined as any;\n return addressParser(chainName).normalizedToNative(address).nativeAddress;\n },\n nativeToNormalized: (nativeAddress) => {\n if (nativeAddress === undefined) return undefined as any;\n const address = getAddress(nativeAddress);\n assertNative(address, chainName);\n const hex = bytesToHexPrefixed(bs58.decode(address));\n return normalizeHex(hex);\n },\n nativeToBytes32Hex: (nativeAddress) => {\n // naturally solana is 32 bytes, pad it anyway\n if (nativeAddress === undefined) return undefined as any;\n return hexZeroPad(\n addressParser(chainName).nativeToNormalized(nativeAddress) as unknown as HexString,\n 32,\n );\n },\n nativeToBytes: (nativeAddress) => {\n if (nativeAddress === undefined) return undefined as any;\n const address = getAddress(nativeAddress);\n assertNative(address, chainName);\n return bs58.decode(address);\n },\n nativeToBytes32: (nativeAddress) => {\n if (nativeAddress === undefined) return undefined as any;\n return hexToBytes(addressParser(chainName).nativeToBytes32Hex(nativeAddress));\n },\n normalizedToBytes32Hex: (address) => {\n if (address === undefined) return undefined as any;\n return hexZeroPad(address as unknown as HexString, 32);\n },\n normalizedToBytes32: (address) => {\n if (address === undefined) return undefined as any;\n return hexToBytes(addressParser(chainName).normalizedToBytes32Hex(address));\n },\n bytes32ToNormalized: (bytes32Hex) => {\n if (bytes32Hex === undefined) return undefined as any;\n return normalizeHex(bytes32Hex);\n },\n parseNative: (nativeAddress) => {\n assertNative(nativeAddress, chainName);\n return addressParser(chainName).nativeToNormalized(nativeAddress);\n },\n parseNativeToUnpaddedHex: (nativeAddress) => {\n return addressParser(chainName).parseNative(nativeAddress) as unknown as HexString;\n },\n encoding: AddressEncoding.BASE58,\n };\n};\n\nexport const hexAddressParser = (\n chainName: ChainsByEncoding[HexString],\n): AddressParser<ChainsByEncoding[HexString]> => {\n return {\n validateNative: (nativeAddress): nativeAddress is HexString => {\n if (nativeAddress === undefined) return false;\n return isHexString(nativeAddress);\n },\n normalizedToNative: (address) => {\n if (address === undefined) return undefined as any;\n // we fetch here instead of storing by chain because some chains may not have this defined,\n // so we should only throw on those chains if they try to use these methods that need the native byte length\n const nativeByteLength = StaticChainConfigs.getAddressSizeInBytes(chainName);\n return {\n // we could have EIP-55 here, but omitted for now\n nativeAddress: hexZeroPad(address as unknown as HexString, nativeByteLength),\n chainName,\n };\n },\n normalizedToNativeString: (address) => {\n if (address === undefined) return undefined as any;\n const nativeByteLength = StaticChainConfigs.getAddressSizeInBytes(chainName);\n return hexZeroPad(address as unknown as HexString, nativeByteLength);\n },\n nativeToNormalized: (nativeAddress) => {\n if (nativeAddress === undefined) return undefined as any;\n const address = getAddress(nativeAddress);\n assertNative(address, chainName);\n return normalizeHex(address);\n },\n nativeToBytes: (nativeAddress) => {\n if (nativeAddress === undefined) return undefined as any;\n const address = getAddress(nativeAddress);\n assertNative(address, chainName);\n return hexToBytes(address);\n },\n nativeToBytes32Hex: (nativeAddress) => {\n if (nativeAddress === undefined) return undefined as any;\n const address = getAddress(nativeAddress);\n assertNative(address, chainName);\n return hexZeroPad(address, 32);\n },\n nativeToBytes32: (nativeAddress) => {\n if (nativeAddress === undefined) return undefined as any;\n return hexToBytes(addressParser(chainName).nativeToBytes32Hex(nativeAddress));\n },\n normalizedToBytes32Hex: (address) => {\n if (address === undefined) return undefined as any;\n return hexZeroPad(address as unknown as HexString, 32);\n },\n normalizedToBytes32: (address) => {\n if (address === undefined) return undefined as any;\n return hexToBytes(addressParser(chainName).normalizedToBytes32Hex(address));\n },\n bytes32ToNormalized: (bytes32Hex) => {\n if (bytes32Hex === undefined) return undefined as any;\n return normalizeHex(bytes32Hex);\n },\n parseNative: (nativeAddress) => {\n // Specific case to make tron a little less flaky, handle the 41 prefix\n if (chainName === ChainName.TRON && nativeAddress) {\n nativeAddress = nativeAddress.startsWith('41')\n ? `0x${nativeAddress.slice(2)}`\n : nativeAddress;\n }\n\n assertNative(nativeAddress, chainName);\n return addressParser(chainName).nativeToNormalized(nativeAddress);\n },\n parseNativeToUnpaddedHex: (nativeAddress) => {\n return addressParser(chainName).parseNative(nativeAddress) as unknown as HexString;\n },\n encoding: AddressEncoding.HEX,\n };\n};\n\nconst BYTES32_HEX_LENGTH = 64;\n\n/**\n * If the input is a 0x-prefixed bytes32 hex string (raw contract ID),\n * convert it to native Stellar base32 format. Only accepts exactly\n * 32 bytes (64 hex chars) to avoid silent corruption from other hex\n * representations (e.g. the UTF-8 \"normalized\" encoding which is 56 bytes,\n * or a 20-byte EVM address).\n */\nconst hexToStellarNative = (address: string | undefined): string | undefined => {\n if (!address || !address.startsWith('0x') || !isHexString(address)) return address;\n const hexPayload = address.slice(2);\n if (hexPayload.length !== BYTES32_HEX_LENGTH) {\n throw new Error(\n `Stellar hex address must be exactly 32 bytes (${BYTES32_HEX_LENGTH} hex chars), got ${hexPayload.length}: ${address}`,\n );\n }\n const raw = Buffer.from(hexPayload, 'hex');\n return StrKey.encodeContract(raw);\n};\n\nexport const stellarAddressParser: (\n chainName: InferChainNamesForChainType<ChainType.STELLAR>,\n) => AddressParser<InferChainNamesForChainType<ChainType.STELLAR>> = (chainName) => {\n /**\n * Validate if a string is a valid Stellar address.\n *\n * According to SEP-0023 (https://github.com/stellar/stellar-protocol/blob/master/ecosystem/sep-0023.md),\n * Stellar supports multiple address types encoded as base32 ASCII strings:\n * - Account addresses starting with 'G' (56 chars, Ed25519 public key)\n * - Contract addresses starting with 'C' (56 chars, contract ID)\n * - Muxed addresses starting with 'M' (69 chars, muxed account with ID)\n * - Liquidity pool addresses starting with 'L' (56 chars, pool ID)\n * - Claimable balance addresses starting with 'B' (56 chars, balance ID)\n * - Signed payload starting with 'P' (variable length)\n *\n * All addresses are stored in their native ASCII format to preserve type information.\n */\n const isValidStellarAddress = (address: string): boolean => {\n if (!address) return false;\n // Use the StrKey validation methods for all supported address types\n return (\n StrKey.isValidEd25519PublicKey(address) ||\n StrKey.isValidContract(address) ||\n StrKey.isValidMed25519PublicKey(address) ||\n StrKey.isValidLiquidityPool(address) ||\n StrKey.isValidClaimableBalance(address) ||\n StrKey.isValidSignedPayload(address)\n );\n };\n\n /**\n * Convert Stellar ASCII address to normalized hex by encoding the ASCII string as UTF-8 bytes.\n * This preserves the full address including type prefix and allows round-trip conversion.\n */\n const stellarTextEncoder = new TextEncoder();\n const stellarAsciiToNormalized = (address: string): NormalizedHexString => {\n // Convert ASCII address string to UTF-8 bytes, then to hex\n const bytes = stellarTextEncoder.encode(address);\n return normalizeHex(bytesToHexPrefixed(bytes));\n };\n\n /**\n * Convert normalized hex back to Stellar ASCII address by decoding UTF-8 bytes.\n */\n const stellarTextDecoder = new TextDecoder();\n const normalizedToStellarAscii = (normalizedHex: NormalizedHexString): string => {\n // Convert hex to bytes, then decode as UTF-8 string\n const bytes = hexToBytes(normalizedHex as unknown as HexString);\n return stellarTextDecoder.decode(bytes);\n };\n\n return {\n validateNative: (nativeAddress): nativeAddress is StellarString => {\n if (nativeAddress === undefined) return false;\n return isValidStellarAddress(nativeAddress);\n },\n normalizedToNative: (address) => {\n if (address === undefined) return undefined as any;\n // Decode normalized hex back to ASCII Stellar address\n const stellarAddress = normalizedToStellarAscii(address);\n return {\n nativeAddress: stellarAddress as StellarString,\n chainName,\n };\n },\n normalizedToNativeString: (address) => {\n if (address === undefined) return undefined as any;\n return normalizedToStellarAscii(address) as StellarString;\n },\n nativeToNormalized: (nativeAddress) => {\n if (nativeAddress === undefined) return undefined as any;\n const address = getAddress(nativeAddress);\n assertNative(address, chainName);\n // Convert ASCII address to normalized hex\n return stellarAsciiToNormalized(address);\n },\n nativeToBytes32Hex: (nativeAddress) => {\n if (nativeAddress === undefined) return undefined as any;\n const address = getAddress(nativeAddress);\n assertNative(address, chainName);\n // Decode the Stellar address to its raw 32-byte payload based on type\n let rawBytes: Buffer;\n if (StrKey.isValidEd25519PublicKey(address)) {\n // Account addresses (G...) - Ed25519 public key (32 bytes)\n rawBytes = StrKey.decodeEd25519PublicKey(address);\n } else if (StrKey.isValidContract(address)) {\n // Contract addresses (C...) - contract ID (32 bytes)\n rawBytes = StrKey.decodeContract(address);\n } else if (StrKey.isValidLiquidityPool(address)) {\n // Liquidity pool addresses (L...) - pool ID (32 bytes)\n rawBytes = StrKey.decodeLiquidityPool(address);\n } else if (StrKey.isValidClaimableBalance(address)) {\n // Claimable balance addresses (B...) - balance ID (33 bytes: 1-byte version + 32-byte hash)\n // Per SEP-0023: first byte is the claimable balance type (0x00 = V0), followed by 32-byte SHA256 hash\n const fullBytes = StrKey.decodeClaimableBalance(address);\n rawBytes = fullBytes.subarray(1); // Skip the first byte (version), return the 32-byte hash\n } else if (StrKey.isValidMed25519PublicKey(address)) {\n // Muxed addresses (M...) contain additional data beyond 32 bytes\n throw new Error(\n 'nativeToBytes32 is not supported for Stellar muxed addresses (M...)',\n );\n } else if (StrKey.isValidSignedPayload(address)) {\n // Signed payload (P...) has variable length\n throw new Error(\n 'nativeToBytes32 is not supported for Stellar signed payload addresses (P...)',\n );\n } else {\n throw new Error(`Unknown Stellar address type: ${address}`);\n }\n return bytesToHexPrefixed(rawBytes);\n },\n nativeToBytes: (nativeAddress) => {\n if (nativeAddress === undefined) return undefined as any;\n const address = getAddress(nativeAddress);\n assertNative(address, chainName);\n // Convert ASCII address to UTF-8 bytes\n return stellarTextEncoder.encode(address);\n },\n nativeToBytes32: (nativeAddress) => {\n if (nativeAddress === undefined) return undefined as any;\n // Use nativeToBytes32Hex and convert to Uint8Array\n const hex = addressParser(chainName).nativeToBytes32Hex(nativeAddress);\n return hexToBytes(hex);\n },\n normalizedToBytes32Hex: (address) => {\n if (address === undefined) return undefined as any;\n // Stellar normalized hex is UTF-8 of ASCII address (56 bytes), not raw bytes.\n // Route through native string to extract the raw 32-byte StrKey payload.\n return addressParser(chainName).nativeToBytes32Hex(\n addressParser(chainName).normalizedToNativeString(address),\n );\n },\n normalizedToBytes32: (address) => {\n if (address === undefined) return undefined as any;\n return hexToBytes(addressParser(chainName).normalizedToBytes32Hex(address));\n },\n bytes32ToNormalized: (bytes32Hex) => {\n if (bytes32Hex === undefined) return undefined as any;\n // Always assumes contract address type — G-address→bytes32 is a lossy upcast\n return stellarAsciiToNormalized(\n StrKey.encodeContract(Buffer.from(hexToBytes(bytes32Hex))),\n );\n },\n parseNative: (nativeAddress) => {\n nativeAddress = hexToStellarNative(nativeAddress);\n assertNative(nativeAddress, chainName);\n return addressParser(chainName).nativeToNormalized(nativeAddress);\n },\n parseNativeToUnpaddedHex: (nativeAddress) => {\n nativeAddress = hexToStellarNative(nativeAddress);\n assertNative(nativeAddress, chainName);\n const normalized = addressParser(chainName).nativeToNormalized(nativeAddress);\n return normalized as unknown as HexString;\n },\n encoding: AddressEncoding.STELLAR,\n };\n};\n\n// Starknet addresses do not handle hex-zero padding, so we just return the address as is\nexport const starknetAddressParser = (\n chainName: ChainsByEncoding[HexString],\n): AddressParser<ChainsByEncoding[HexString]> => {\n return {\n ...hexAddressParser(chainName),\n validateNative: (nativeAddress): nativeAddress is HexString => {\n if (nativeAddress === undefined) return false;\n return isHexString(nativeAddress);\n },\n parseNative: (nativeAddress) => {\n if (nativeAddress === undefined) return undefined as any;\n // We can't trust starknet.js strings, they may actually be bigints!\n // so just convert everything to hex first, then convert to normalized\n nativeAddress = `0x${BigInt(nativeAddress).toString(16)}`;\n assertNative(nativeAddress, chainName);\n return addressParser(chainName).nativeToNormalized(nativeAddress);\n },\n normalizedToNative: (address) => {\n if (address === undefined) return undefined as any;\n return {\n nativeAddress: address,\n chainName,\n };\n },\n normalizedToNativeString: (address) => {\n if (address === undefined) return undefined as any;\n return address;\n },\n };\n};\n"]}
@@ -64,7 +64,7 @@ var tonAddressParser = /* @__PURE__ */ __name((chainName) => {
64
64
  if (address === void 0) return void 0;
65
65
  const numericalValue = addressParser.normalizedToBigInt(address);
66
66
  return {
67
- // FIXME this is wrong
67
+ // TODO: use Base64 native format instead of hex for TON addresses
68
68
  nativeAddress: bigintToAddress(numericalValue).toString(),
69
69
  chainName
70
70
  };
@@ -447,5 +447,5 @@ var starknetAddressParser = /* @__PURE__ */ __name((chainName) => {
447
447
  }, "starknetAddressParser");
448
448
 
449
449
  export { AddressEncoding, addressParser, base58AddressParser, hexAddressParser, initiaAddressParser, starknetAddressParser, stellarAddressParser, tonAddressParser };
450
- //# sourceMappingURL=YMF6LH6C.js.map
451
- //# sourceMappingURL=YMF6LH6C.js.map
450
+ //# sourceMappingURL=HNVHH5C2.js.map
451
+ //# sourceMappingURL=HNVHH5C2.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../src/addressParser.ts"],"names":["AddressEncoding","addressParser","chainName","ChainName","TON","tonAddressParser","SOLANA","base58AddressParser","INITIA","initiaAddressParser","STELLAR","stellarAddressParser","STARKNET","starknetAddressParser","hexAddressParser","normalizedToUnpaddedString","address","toString","normalizedToBigInt","BigInt","parseNative","nativeAddress","assertNative","expectedChainName","validateNative","Error","getAddress","undefined","parseTonAddress","normalizedToNative","numericalValue","bigintToAddress","normalizedToNativeString","nativeToNormalized","normalizeHex","addressToHex","nativeToBytes32Hex","hexZeroPad","nativeToBytes","hexToBytes","nativeToBytes32","normalizedToBytes32Hex","normalizedToBytes32","bytes32ToNormalized","bytes32Hex","parseNativeToUnpaddedHex","tonToNormalized","tonAddress","encoding","isHexString","test","AccAddress","fromHex","toHex","isBase58","bs58","encode","hex","bytesToHexPrefixed","decode","nativeByteLength","StaticChainConfigs","getAddressSizeInBytes","TRON","startsWith","slice","BYTES32_HEX_LENGTH","hexToStellarNative","hexPayload","length","raw","Buffer","from","StrKey","encodeContract","isValidStellarAddress","isValidEd25519PublicKey","isValidContract","isValidMed25519PublicKey","isValidLiquidityPool","isValidClaimableBalance","isValidSignedPayload","stellarTextEncoder","TextEncoder","stellarAsciiToNormalized","bytes","stellarTextDecoder","TextDecoder","normalizedToStellarAscii","normalizedHex","stellarAddress","rawBytes","decodeEd25519PublicKey","decodeContract","decodeLiquidityPool","fullBytes","decodeClaimableBalance","subarray","normalized"],"mappings":"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","file":"HNVHH5C2.js","sourcesContent":["import { AccAddress } from '@initia/initia.js';\nimport { StrKey } from '@stellar/stellar-sdk';\nimport type { Address } from '@ton/ton';\nimport bs58 from 'bs58';\n\nimport { addressToHex, bigintToAddress, parseTonAddress } from '@layerzerolabs/address-utils-ton';\nimport type { HexString, NormalizedHexString } from '@layerzerolabs/common-chain-model';\nimport { normalizeHex } from '@layerzerolabs/common-chain-model';\nimport {\n bytesToHexPrefixed,\n hexToBytes,\n hexZeroPad,\n isBase58,\n isHexString,\n} from '@layerzerolabs/common-encoding-utils';\nimport type {\n Base58String,\n ChainsByEncoding,\n ChainType,\n InferChainNamesForChainType,\n InferChainTypeForChainName,\n InitiaString,\n NativeAddress,\n ResolvedEncodingForChainName,\n StellarString,\n} from '@layerzerolabs/layerzero-definitions';\nimport type { ChainNativeAddress } from '@layerzerolabs/layerzero-definitions';\nimport { ChainName } from '@layerzerolabs/layerzero-definitions';\nimport { StaticChainConfigs } from '@layerzerolabs/static-chain-info';\nimport type { MaybeUndefinedMapped } from '@layerzerolabs/typescript-utils';\n\ntype NativeOrString<T extends ChainName> = ChainNativeAddress<T> | ResolvedEncodingForChainName<T>;\n\nexport enum AddressEncoding {\n HEX = 'hex',\n BASE58 = 'base58',\n TON = 'ton',\n INITIA = 'initia',\n STELLAR = 'stellar',\n}\n\nexport type ExtensionByChainType = {\n ton: {\n tonToNormalized: (tonAddress: Address) => NormalizedHexString;\n };\n};\n\nexport type InferExtensionByChainName<T extends ChainName> =\n InferChainTypeForChainName<T> extends keyof ExtensionByChainType\n ? ExtensionByChainType[InferChainTypeForChainName<T>]\n : {};\n\nexport type AddressParser<T extends ChainName> = {\n normalizedToNative: <Address extends NormalizedHexString | undefined>(\n address: Address,\n ) => MaybeUndefinedMapped<Address, ChainNativeAddress<T>>;\n normalizedToNativeString: <Address extends NormalizedHexString | undefined>(\n address: Address,\n ) => MaybeUndefinedMapped<Address, ResolvedEncodingForChainName<T>>;\n nativeToNormalized: <Address extends NativeOrString<T> | undefined>(\n nativeAddress: Address,\n ) => MaybeUndefinedMapped<Address, NormalizedHexString>;\n nativeToBytes: <Address extends NativeOrString<T> | undefined>(\n nativeAddress: Address,\n ) => MaybeUndefinedMapped<Address, Uint8Array>;\n nativeToBytes32Hex: <Address extends NativeOrString<T> | undefined>(\n nativeAddress: Address,\n ) => MaybeUndefinedMapped<Address, HexString>;\n nativeToBytes32: <Address extends NativeOrString<T> | undefined>(\n nativeAddress: Address,\n ) => MaybeUndefinedMapped<Address, Uint8Array>;\n normalizedToBytes32Hex: <Address extends NormalizedHexString | undefined>(\n address: Address,\n ) => MaybeUndefinedMapped<Address, HexString>;\n normalizedToBytes32: <Address extends NormalizedHexString | undefined>(\n address: Address,\n ) => MaybeUndefinedMapped<Address, Uint8Array>;\n bytes32ToNormalized: <B extends HexString | undefined>(\n bytes32Hex: B,\n ) => MaybeUndefinedMapped<B, NormalizedHexString>;\n validateNative: (\n nativeAddress: string | undefined,\n ) => nativeAddress is ResolvedEncodingForChainName<T>;\n /**\n * Parse a native address to a string if it is valid.\n * Throws an error if the native address is invalid.\n * @param nativeAddress - The native address to parse.\n * @returns The parsed native address.\n */\n parseNative: (nativeAddress: string | undefined) => NormalizedHexString;\n parseNativeToUnpaddedHex: (nativeAddress: string | undefined) => HexString;\n encoding: AddressEncoding;\n} & InferExtensionByChainName<T>;\n\nexport function addressParser<T extends ChainName>(chainName: T): AddressParser<T> {\n // TODO: find a way to narrow generics to avoid type cast\n if (chainName === ChainName.TON)\n return tonAddressParser(chainName) as unknown as AddressParser<T>;\n if (chainName === ChainName.SOLANA)\n return base58AddressParser(chainName) as unknown as AddressParser<T>;\n if (chainName === ChainName.INITIA)\n return initiaAddressParser(chainName) as unknown as AddressParser<T>;\n if (chainName === ChainName.STELLAR)\n return stellarAddressParser(chainName) as unknown as AddressParser<T>;\n if (chainName === ChainName.STARKNET)\n return starknetAddressParser(chainName) as unknown as AddressParser<T>;\n return hexAddressParser(chainName) as unknown as AddressParser<T>;\n}\n\nexport namespace addressParser {\n export const normalizedToUnpaddedString = (address: NormalizedHexString) => {\n return address.toString() as HexString;\n };\n\n export const normalizedToBigInt = (address: NormalizedHexString) => {\n return BigInt(address as unknown as HexString);\n };\n\n export const parseNative = (nativeAddress: NativeAddress) => {\n return addressParser(nativeAddress.chainName).parseNative(nativeAddress.nativeAddress);\n };\n}\n\nfunction assertNative<T extends ChainName>(\n nativeAddress: string | undefined,\n expectedChainName: T,\n): asserts nativeAddress is ResolvedEncodingForChainName<T> {\n if (!addressParser(expectedChainName).validateNative(nativeAddress)) {\n throw new Error(\n 'Cannot convert: \"' +\n nativeAddress +\n '\" - The native address does not match the expected format for the chain: ' +\n expectedChainName,\n );\n }\n}\n\nconst getAddress = <T extends ChainName>(nativeAddress: NativeOrString<T>) => {\n return typeof nativeAddress === 'object' ? nativeAddress.nativeAddress : nativeAddress;\n};\n\nexport const tonAddressParser: (\n chainName: InferChainNamesForChainType<ChainType.TON>,\n) => AddressParser<InferChainNamesForChainType<ChainType.TON>> = (chainName) => {\n return {\n validateNative: (nativeAddress): nativeAddress is HexString => {\n if (nativeAddress === undefined) {\n return false;\n }\n try {\n parseTonAddress(nativeAddress);\n return true;\n } catch {\n return false;\n }\n },\n normalizedToNative: (address) => {\n if (address === undefined) return undefined as any;\n const numericalValue = addressParser.normalizedToBigInt(address);\n return {\n // TODO: use Base64 native format instead of hex for TON addresses\n nativeAddress: bigintToAddress(numericalValue).toString() as HexString,\n chainName,\n };\n },\n normalizedToNativeString: (address) => {\n if (address === undefined) return undefined as any;\n return addressParser(chainName).normalizedToNative(address).nativeAddress;\n },\n nativeToNormalized: (nativeAddress) => {\n if (nativeAddress === undefined) return undefined as any;\n const address = getAddress(nativeAddress);\n assertNative(address, chainName);\n return normalizeHex(addressToHex(address));\n },\n nativeToBytes32Hex: (nativeAddress) => {\n // naturally ton is 32 bytes, pad it anyway\n if (nativeAddress === undefined) return undefined as any;\n return hexZeroPad(\n addressParser(chainName).nativeToNormalized(nativeAddress) as unknown as HexString,\n 32,\n );\n },\n nativeToBytes: (nativeAddress) => {\n if (nativeAddress === undefined) return undefined as any;\n return hexToBytes(addressParser(chainName).nativeToBytes32Hex(nativeAddress));\n },\n nativeToBytes32: (nativeAddress) => {\n if (nativeAddress === undefined) return undefined as any;\n return hexToBytes(addressParser(chainName).nativeToBytes32Hex(nativeAddress));\n },\n normalizedToBytes32Hex: (address) => {\n if (address === undefined) return undefined as any;\n return hexZeroPad(address as unknown as HexString, 32);\n },\n normalizedToBytes32: (address) => {\n if (address === undefined) return undefined as any;\n return hexToBytes(addressParser(chainName).normalizedToBytes32Hex(address));\n },\n bytes32ToNormalized: (bytes32Hex) => {\n if (bytes32Hex === undefined) return undefined as any;\n return normalizeHex(bytes32Hex);\n },\n parseNative: (nativeAddress) => {\n assertNative(nativeAddress, chainName);\n return addressParser(chainName).nativeToNormalized(nativeAddress);\n },\n parseNativeToUnpaddedHex: (nativeAddress) => {\n return addressParser(chainName).parseNative(nativeAddress) as unknown as HexString;\n },\n tonToNormalized: (tonAddress) => {\n return addressParser(chainName).parseNative(addressToHex(tonAddress));\n },\n encoding: AddressEncoding.TON,\n };\n};\n\nexport const initiaAddressParser: (\n chainName: ChainsByEncoding[InitiaString],\n) => AddressParser<ChainsByEncoding[InitiaString]> = (chainName) => {\n return {\n validateNative: (nativeAddress): nativeAddress is InitiaString => {\n if (nativeAddress === undefined) {\n return false;\n }\n try {\n // Both formats are native for the chain and are used kind of randomly.\n return (\n isHexString(nativeAddress) ||\n /^(init)1(['qpzry9x8gf2tvdw0s3jn54khce6mua7l]{38,66})$/.test(nativeAddress)\n );\n } catch {\n return false;\n }\n },\n normalizedToNative: (address) => {\n if (address === undefined) {\n return undefined as any;\n }\n return {\n nativeAddress: AccAddress.fromHex(address as unknown as HexString) as InitiaString,\n chainName,\n };\n },\n normalizedToNativeString: (address) => {\n if (address === undefined) return undefined as any;\n return addressParser(chainName).normalizedToNative(address).nativeAddress;\n },\n nativeToNormalized: (nativeAddress) => {\n if (nativeAddress === undefined) return undefined as any;\n const address = getAddress(nativeAddress);\n assertNative(address, chainName);\n if (isHexString(address)) {\n return normalizeHex(address);\n }\n return normalizeHex(AccAddress.toHex(nativeAddress.toString()) as HexString);\n },\n nativeToBytes32Hex: (nativeAddress) => {\n if (nativeAddress === undefined) return undefined as any;\n // naturally ton is 32 bytes, pad it anyway\n return hexZeroPad(\n addressParser(chainName).nativeToNormalized(nativeAddress) as unknown as HexString,\n 32,\n );\n },\n nativeToBytes: (nativeAddress) => {\n if (nativeAddress === undefined) return undefined as any;\n return hexToBytes(addressParser(chainName).nativeToBytes32Hex(nativeAddress));\n },\n nativeToBytes32: (nativeAddress) => {\n if (nativeAddress === undefined) return undefined as any;\n return hexToBytes(addressParser(chainName).nativeToBytes32Hex(nativeAddress));\n },\n normalizedToBytes32Hex: (address) => {\n if (address === undefined) return undefined as any;\n return hexZeroPad(address as unknown as HexString, 32);\n },\n normalizedToBytes32: (address) => {\n if (address === undefined) return undefined as any;\n return hexToBytes(addressParser(chainName).normalizedToBytes32Hex(address));\n },\n bytes32ToNormalized: (bytes32Hex) => {\n if (bytes32Hex === undefined) return undefined as any;\n return normalizeHex(bytes32Hex);\n },\n parseNative: (nativeAddress) => {\n assertNative(nativeAddress, chainName);\n return addressParser(chainName).nativeToNormalized(nativeAddress);\n },\n parseNativeToUnpaddedHex: (nativeAddress) => {\n return addressParser(chainName).parseNative(nativeAddress) as unknown as HexString;\n },\n encoding: AddressEncoding.INITIA,\n };\n};\n\nexport const base58AddressParser = (\n chainName: ChainsByEncoding[Base58String],\n): AddressParser<ChainsByEncoding[Base58String]> => {\n return {\n validateNative: (nativeAddress): nativeAddress is Base58String => {\n if (nativeAddress === undefined) return false;\n return isBase58(nativeAddress);\n },\n normalizedToNative: (address) => {\n if (address === undefined) return undefined as any;\n return {\n nativeAddress: bs58.encode(\n hexToBytes(address as unknown as HexString),\n ) as Base58String,\n chainName,\n };\n },\n normalizedToNativeString: (address) => {\n if (address === undefined) return undefined as any;\n return addressParser(chainName).normalizedToNative(address).nativeAddress;\n },\n nativeToNormalized: (nativeAddress) => {\n if (nativeAddress === undefined) return undefined as any;\n const address = getAddress(nativeAddress);\n assertNative(address, chainName);\n const hex = bytesToHexPrefixed(bs58.decode(address));\n return normalizeHex(hex);\n },\n nativeToBytes32Hex: (nativeAddress) => {\n // naturally solana is 32 bytes, pad it anyway\n if (nativeAddress === undefined) return undefined as any;\n return hexZeroPad(\n addressParser(chainName).nativeToNormalized(nativeAddress) as unknown as HexString,\n 32,\n );\n },\n nativeToBytes: (nativeAddress) => {\n if (nativeAddress === undefined) return undefined as any;\n const address = getAddress(nativeAddress);\n assertNative(address, chainName);\n return bs58.decode(address);\n },\n nativeToBytes32: (nativeAddress) => {\n if (nativeAddress === undefined) return undefined as any;\n return hexToBytes(addressParser(chainName).nativeToBytes32Hex(nativeAddress));\n },\n normalizedToBytes32Hex: (address) => {\n if (address === undefined) return undefined as any;\n return hexZeroPad(address as unknown as HexString, 32);\n },\n normalizedToBytes32: (address) => {\n if (address === undefined) return undefined as any;\n return hexToBytes(addressParser(chainName).normalizedToBytes32Hex(address));\n },\n bytes32ToNormalized: (bytes32Hex) => {\n if (bytes32Hex === undefined) return undefined as any;\n return normalizeHex(bytes32Hex);\n },\n parseNative: (nativeAddress) => {\n assertNative(nativeAddress, chainName);\n return addressParser(chainName).nativeToNormalized(nativeAddress);\n },\n parseNativeToUnpaddedHex: (nativeAddress) => {\n return addressParser(chainName).parseNative(nativeAddress) as unknown as HexString;\n },\n encoding: AddressEncoding.BASE58,\n };\n};\n\nexport const hexAddressParser = (\n chainName: ChainsByEncoding[HexString],\n): AddressParser<ChainsByEncoding[HexString]> => {\n return {\n validateNative: (nativeAddress): nativeAddress is HexString => {\n if (nativeAddress === undefined) return false;\n return isHexString(nativeAddress);\n },\n normalizedToNative: (address) => {\n if (address === undefined) return undefined as any;\n // we fetch here instead of storing by chain because some chains may not have this defined,\n // so we should only throw on those chains if they try to use these methods that need the native byte length\n const nativeByteLength = StaticChainConfigs.getAddressSizeInBytes(chainName);\n return {\n // we could have EIP-55 here, but omitted for now\n nativeAddress: hexZeroPad(address as unknown as HexString, nativeByteLength),\n chainName,\n };\n },\n normalizedToNativeString: (address) => {\n if (address === undefined) return undefined as any;\n const nativeByteLength = StaticChainConfigs.getAddressSizeInBytes(chainName);\n return hexZeroPad(address as unknown as HexString, nativeByteLength);\n },\n nativeToNormalized: (nativeAddress) => {\n if (nativeAddress === undefined) return undefined as any;\n const address = getAddress(nativeAddress);\n assertNative(address, chainName);\n return normalizeHex(address);\n },\n nativeToBytes: (nativeAddress) => {\n if (nativeAddress === undefined) return undefined as any;\n const address = getAddress(nativeAddress);\n assertNative(address, chainName);\n return hexToBytes(address);\n },\n nativeToBytes32Hex: (nativeAddress) => {\n if (nativeAddress === undefined) return undefined as any;\n const address = getAddress(nativeAddress);\n assertNative(address, chainName);\n return hexZeroPad(address, 32);\n },\n nativeToBytes32: (nativeAddress) => {\n if (nativeAddress === undefined) return undefined as any;\n return hexToBytes(addressParser(chainName).nativeToBytes32Hex(nativeAddress));\n },\n normalizedToBytes32Hex: (address) => {\n if (address === undefined) return undefined as any;\n return hexZeroPad(address as unknown as HexString, 32);\n },\n normalizedToBytes32: (address) => {\n if (address === undefined) return undefined as any;\n return hexToBytes(addressParser(chainName).normalizedToBytes32Hex(address));\n },\n bytes32ToNormalized: (bytes32Hex) => {\n if (bytes32Hex === undefined) return undefined as any;\n return normalizeHex(bytes32Hex);\n },\n parseNative: (nativeAddress) => {\n // Specific case to make tron a little less flaky, handle the 41 prefix\n if (chainName === ChainName.TRON && nativeAddress) {\n nativeAddress = nativeAddress.startsWith('41')\n ? `0x${nativeAddress.slice(2)}`\n : nativeAddress;\n }\n\n assertNative(nativeAddress, chainName);\n return addressParser(chainName).nativeToNormalized(nativeAddress);\n },\n parseNativeToUnpaddedHex: (nativeAddress) => {\n return addressParser(chainName).parseNative(nativeAddress) as unknown as HexString;\n },\n encoding: AddressEncoding.HEX,\n };\n};\n\nconst BYTES32_HEX_LENGTH = 64;\n\n/**\n * If the input is a 0x-prefixed bytes32 hex string (raw contract ID),\n * convert it to native Stellar base32 format. Only accepts exactly\n * 32 bytes (64 hex chars) to avoid silent corruption from other hex\n * representations (e.g. the UTF-8 \"normalized\" encoding which is 56 bytes,\n * or a 20-byte EVM address).\n */\nconst hexToStellarNative = (address: string | undefined): string | undefined => {\n if (!address || !address.startsWith('0x') || !isHexString(address)) return address;\n const hexPayload = address.slice(2);\n if (hexPayload.length !== BYTES32_HEX_LENGTH) {\n throw new Error(\n `Stellar hex address must be exactly 32 bytes (${BYTES32_HEX_LENGTH} hex chars), got ${hexPayload.length}: ${address}`,\n );\n }\n const raw = Buffer.from(hexPayload, 'hex');\n return StrKey.encodeContract(raw);\n};\n\nexport const stellarAddressParser: (\n chainName: InferChainNamesForChainType<ChainType.STELLAR>,\n) => AddressParser<InferChainNamesForChainType<ChainType.STELLAR>> = (chainName) => {\n /**\n * Validate if a string is a valid Stellar address.\n *\n * According to SEP-0023 (https://github.com/stellar/stellar-protocol/blob/master/ecosystem/sep-0023.md),\n * Stellar supports multiple address types encoded as base32 ASCII strings:\n * - Account addresses starting with 'G' (56 chars, Ed25519 public key)\n * - Contract addresses starting with 'C' (56 chars, contract ID)\n * - Muxed addresses starting with 'M' (69 chars, muxed account with ID)\n * - Liquidity pool addresses starting with 'L' (56 chars, pool ID)\n * - Claimable balance addresses starting with 'B' (56 chars, balance ID)\n * - Signed payload starting with 'P' (variable length)\n *\n * All addresses are stored in their native ASCII format to preserve type information.\n */\n const isValidStellarAddress = (address: string): boolean => {\n if (!address) return false;\n // Use the StrKey validation methods for all supported address types\n return (\n StrKey.isValidEd25519PublicKey(address) ||\n StrKey.isValidContract(address) ||\n StrKey.isValidMed25519PublicKey(address) ||\n StrKey.isValidLiquidityPool(address) ||\n StrKey.isValidClaimableBalance(address) ||\n StrKey.isValidSignedPayload(address)\n );\n };\n\n /**\n * Convert Stellar ASCII address to normalized hex by encoding the ASCII string as UTF-8 bytes.\n * This preserves the full address including type prefix and allows round-trip conversion.\n */\n const stellarTextEncoder = new TextEncoder();\n const stellarAsciiToNormalized = (address: string): NormalizedHexString => {\n // Convert ASCII address string to UTF-8 bytes, then to hex\n const bytes = stellarTextEncoder.encode(address);\n return normalizeHex(bytesToHexPrefixed(bytes));\n };\n\n /**\n * Convert normalized hex back to Stellar ASCII address by decoding UTF-8 bytes.\n */\n const stellarTextDecoder = new TextDecoder();\n const normalizedToStellarAscii = (normalizedHex: NormalizedHexString): string => {\n // Convert hex to bytes, then decode as UTF-8 string\n const bytes = hexToBytes(normalizedHex as unknown as HexString);\n return stellarTextDecoder.decode(bytes);\n };\n\n return {\n validateNative: (nativeAddress): nativeAddress is StellarString => {\n if (nativeAddress === undefined) return false;\n return isValidStellarAddress(nativeAddress);\n },\n normalizedToNative: (address) => {\n if (address === undefined) return undefined as any;\n // Decode normalized hex back to ASCII Stellar address\n const stellarAddress = normalizedToStellarAscii(address);\n return {\n nativeAddress: stellarAddress as StellarString,\n chainName,\n };\n },\n normalizedToNativeString: (address) => {\n if (address === undefined) return undefined as any;\n return normalizedToStellarAscii(address) as StellarString;\n },\n nativeToNormalized: (nativeAddress) => {\n if (nativeAddress === undefined) return undefined as any;\n const address = getAddress(nativeAddress);\n assertNative(address, chainName);\n // Convert ASCII address to normalized hex\n return stellarAsciiToNormalized(address);\n },\n nativeToBytes32Hex: (nativeAddress) => {\n if (nativeAddress === undefined) return undefined as any;\n const address = getAddress(nativeAddress);\n assertNative(address, chainName);\n // Decode the Stellar address to its raw 32-byte payload based on type\n let rawBytes: Buffer;\n if (StrKey.isValidEd25519PublicKey(address)) {\n // Account addresses (G...) - Ed25519 public key (32 bytes)\n rawBytes = StrKey.decodeEd25519PublicKey(address);\n } else if (StrKey.isValidContract(address)) {\n // Contract addresses (C...) - contract ID (32 bytes)\n rawBytes = StrKey.decodeContract(address);\n } else if (StrKey.isValidLiquidityPool(address)) {\n // Liquidity pool addresses (L...) - pool ID (32 bytes)\n rawBytes = StrKey.decodeLiquidityPool(address);\n } else if (StrKey.isValidClaimableBalance(address)) {\n // Claimable balance addresses (B...) - balance ID (33 bytes: 1-byte version + 32-byte hash)\n // Per SEP-0023: first byte is the claimable balance type (0x00 = V0), followed by 32-byte SHA256 hash\n const fullBytes = StrKey.decodeClaimableBalance(address);\n rawBytes = fullBytes.subarray(1); // Skip the first byte (version), return the 32-byte hash\n } else if (StrKey.isValidMed25519PublicKey(address)) {\n // Muxed addresses (M...) contain additional data beyond 32 bytes\n throw new Error(\n 'nativeToBytes32 is not supported for Stellar muxed addresses (M...)',\n );\n } else if (StrKey.isValidSignedPayload(address)) {\n // Signed payload (P...) has variable length\n throw new Error(\n 'nativeToBytes32 is not supported for Stellar signed payload addresses (P...)',\n );\n } else {\n throw new Error(`Unknown Stellar address type: ${address}`);\n }\n return bytesToHexPrefixed(rawBytes);\n },\n nativeToBytes: (nativeAddress) => {\n if (nativeAddress === undefined) return undefined as any;\n const address = getAddress(nativeAddress);\n assertNative(address, chainName);\n // Convert ASCII address to UTF-8 bytes\n return stellarTextEncoder.encode(address);\n },\n nativeToBytes32: (nativeAddress) => {\n if (nativeAddress === undefined) return undefined as any;\n // Use nativeToBytes32Hex and convert to Uint8Array\n const hex = addressParser(chainName).nativeToBytes32Hex(nativeAddress);\n return hexToBytes(hex);\n },\n normalizedToBytes32Hex: (address) => {\n if (address === undefined) return undefined as any;\n // Stellar normalized hex is UTF-8 of ASCII address (56 bytes), not raw bytes.\n // Route through native string to extract the raw 32-byte StrKey payload.\n return addressParser(chainName).nativeToBytes32Hex(\n addressParser(chainName).normalizedToNativeString(address),\n );\n },\n normalizedToBytes32: (address) => {\n if (address === undefined) return undefined as any;\n return hexToBytes(addressParser(chainName).normalizedToBytes32Hex(address));\n },\n bytes32ToNormalized: (bytes32Hex) => {\n if (bytes32Hex === undefined) return undefined as any;\n // Always assumes contract address type — G-address→bytes32 is a lossy upcast\n return stellarAsciiToNormalized(\n StrKey.encodeContract(Buffer.from(hexToBytes(bytes32Hex))),\n );\n },\n parseNative: (nativeAddress) => {\n nativeAddress = hexToStellarNative(nativeAddress);\n assertNative(nativeAddress, chainName);\n return addressParser(chainName).nativeToNormalized(nativeAddress);\n },\n parseNativeToUnpaddedHex: (nativeAddress) => {\n nativeAddress = hexToStellarNative(nativeAddress);\n assertNative(nativeAddress, chainName);\n const normalized = addressParser(chainName).nativeToNormalized(nativeAddress);\n return normalized as unknown as HexString;\n },\n encoding: AddressEncoding.STELLAR,\n };\n};\n\n// Starknet addresses do not handle hex-zero padding, so we just return the address as is\nexport const starknetAddressParser = (\n chainName: ChainsByEncoding[HexString],\n): AddressParser<ChainsByEncoding[HexString]> => {\n return {\n ...hexAddressParser(chainName),\n validateNative: (nativeAddress): nativeAddress is HexString => {\n if (nativeAddress === undefined) return false;\n return isHexString(nativeAddress);\n },\n parseNative: (nativeAddress) => {\n if (nativeAddress === undefined) return undefined as any;\n // We can't trust starknet.js strings, they may actually be bigints!\n // so just convert everything to hex first, then convert to normalized\n nativeAddress = `0x${BigInt(nativeAddress).toString(16)}`;\n assertNative(nativeAddress, chainName);\n return addressParser(chainName).nativeToNormalized(nativeAddress);\n },\n normalizedToNative: (address) => {\n if (address === undefined) return undefined as any;\n return {\n nativeAddress: address,\n chainName,\n };\n },\n normalizedToNativeString: (address) => {\n if (address === undefined) return undefined as any;\n return address;\n },\n };\n};\n"]}
@@ -1,41 +1,41 @@
1
1
  'use strict';
2
2
 
3
- var C2R7HHH3_cjs = require('./C2R7HHH3.cjs');
3
+ var _7TRUXRQA_cjs = require('./7TRUXRQA.cjs');
4
4
  require('./KHVGLVR5.cjs');
5
5
 
6
6
 
7
7
 
8
8
  Object.defineProperty(exports, "AddressEncoding", {
9
9
  enumerable: true,
10
- get: function () { return C2R7HHH3_cjs.AddressEncoding; }
10
+ get: function () { return _7TRUXRQA_cjs.AddressEncoding; }
11
11
  });
12
12
  Object.defineProperty(exports, "addressParser", {
13
13
  enumerable: true,
14
- get: function () { return C2R7HHH3_cjs.addressParser; }
14
+ get: function () { return _7TRUXRQA_cjs.addressParser; }
15
15
  });
16
16
  Object.defineProperty(exports, "base58AddressParser", {
17
17
  enumerable: true,
18
- get: function () { return C2R7HHH3_cjs.base58AddressParser; }
18
+ get: function () { return _7TRUXRQA_cjs.base58AddressParser; }
19
19
  });
20
20
  Object.defineProperty(exports, "hexAddressParser", {
21
21
  enumerable: true,
22
- get: function () { return C2R7HHH3_cjs.hexAddressParser; }
22
+ get: function () { return _7TRUXRQA_cjs.hexAddressParser; }
23
23
  });
24
24
  Object.defineProperty(exports, "initiaAddressParser", {
25
25
  enumerable: true,
26
- get: function () { return C2R7HHH3_cjs.initiaAddressParser; }
26
+ get: function () { return _7TRUXRQA_cjs.initiaAddressParser; }
27
27
  });
28
28
  Object.defineProperty(exports, "starknetAddressParser", {
29
29
  enumerable: true,
30
- get: function () { return C2R7HHH3_cjs.starknetAddressParser; }
30
+ get: function () { return _7TRUXRQA_cjs.starknetAddressParser; }
31
31
  });
32
32
  Object.defineProperty(exports, "stellarAddressParser", {
33
33
  enumerable: true,
34
- get: function () { return C2R7HHH3_cjs.stellarAddressParser; }
34
+ get: function () { return _7TRUXRQA_cjs.stellarAddressParser; }
35
35
  });
36
36
  Object.defineProperty(exports, "tonAddressParser", {
37
37
  enumerable: true,
38
- get: function () { return C2R7HHH3_cjs.tonAddressParser; }
38
+ get: function () { return _7TRUXRQA_cjs.tonAddressParser; }
39
39
  });
40
40
  //# sourceMappingURL=addressParser.cjs.map
41
41
  //# sourceMappingURL=addressParser.cjs.map
@@ -1,4 +1,4 @@
1
- export { AddressEncoding, addressParser, base58AddressParser, hexAddressParser, initiaAddressParser, starknetAddressParser, stellarAddressParser, tonAddressParser } from './YMF6LH6C.js';
1
+ export { AddressEncoding, addressParser, base58AddressParser, hexAddressParser, initiaAddressParser, starknetAddressParser, stellarAddressParser, tonAddressParser } from './HNVHH5C2.js';
2
2
  import './CWKWODSW.js';
3
3
  //# sourceMappingURL=addressParser.js.map
4
4
  //# sourceMappingURL=addressParser.js.map
@@ -1,6 +1,6 @@
1
1
  'use strict';
2
2
 
3
- var C2R7HHH3_cjs = require('./C2R7HHH3.cjs');
3
+ var _7TRUXRQA_cjs = require('./7TRUXRQA.cjs');
4
4
  var KHVGLVR5_cjs = require('./KHVGLVR5.cjs');
5
5
  var bs58 = require('bs58');
6
6
  var tty = require('tty');
@@ -18120,7 +18120,7 @@ describe("addressParser - hex/EVM chains", () => {
18120
18120
  ];
18121
18121
  evmChains.forEach((chain) => {
18122
18122
  describe(chain, () => {
18123
- const parser = C2R7HHH3_cjs.addressParser(chain);
18123
+ const parser = _7TRUXRQA_cjs.addressParser(chain);
18124
18124
  it("maintains roundtrip invariant: hex -> native -> hex", () => {
18125
18125
  runPropertyTest(() => {
18126
18126
  const input = randomHex(20);
@@ -18153,13 +18153,13 @@ describe("addressParser - hex/EVM chains", () => {
18153
18153
  runPropertyTest(() => {
18154
18154
  const byteLength = Math.floor(Math.random() * 32) + 1;
18155
18155
  const input = randomHex(byteLength);
18156
- const padded = C2R7HHH3_cjs.addressParser(layerzeroDefinitions.ChainName.ETHEREUM).normalizedToBytes32Hex(input);
18156
+ const padded = _7TRUXRQA_cjs.addressParser(layerzeroDefinitions.ChainName.ETHEREUM).normalizedToBytes32Hex(input);
18157
18157
  globalExpect(padded.length).toBe(66);
18158
18158
  globalExpect(padded).toBe(commonEncodingUtils.hexZeroPad(input, 32));
18159
18159
  });
18160
18160
  });
18161
18161
  it("handles edge cases", () => {
18162
- const parser = C2R7HHH3_cjs.addressParser(layerzeroDefinitions.ChainName.ETHEREUM);
18162
+ const parser = _7TRUXRQA_cjs.addressParser(layerzeroDefinitions.ChainName.ETHEREUM);
18163
18163
  const empty = commonChainModel.normalizeHex("0x");
18164
18164
  globalExpect(parser.normalizedToNative(empty).nativeAddress.length).toBe(42);
18165
18165
  const max = commonChainModel.normalizeHex("0x" + "ff".repeat(20));
@@ -18169,7 +18169,7 @@ describe("addressParser - hex/EVM chains", () => {
18169
18169
  });
18170
18170
  });
18171
18171
  describe("addressParser - base58 chains (Solana)", () => {
18172
- const parser = C2R7HHH3_cjs.addressParser(layerzeroDefinitions.ChainName.SOLANA);
18172
+ const parser = _7TRUXRQA_cjs.addressParser(layerzeroDefinitions.ChainName.SOLANA);
18173
18173
  it("maintains roundtrip invariant: hex -> base58 -> hex", () => {
18174
18174
  runPropertyTest(() => {
18175
18175
  const byteLength = Math.floor(Math.random() * 32) + 1;
@@ -18212,15 +18212,15 @@ describe("addressParser - base58 chains (Solana)", () => {
18212
18212
  });
18213
18213
  describe("addressParser - chain validation", () => {
18214
18214
  it("validates chain names for nativeToBytes32Hex", () => {
18215
- const evmParser = C2R7HHH3_cjs.addressParser(layerzeroDefinitions.ChainName.ETHEREUM);
18216
- const solanaParser = C2R7HHH3_cjs.addressParser(layerzeroDefinitions.ChainName.SOLANA);
18215
+ const evmParser = _7TRUXRQA_cjs.addressParser(layerzeroDefinitions.ChainName.ETHEREUM);
18216
+ const solanaParser = _7TRUXRQA_cjs.addressParser(layerzeroDefinitions.ChainName.SOLANA);
18217
18217
  const evmAddress = evmParser.normalizedToNative(randomHex(20));
18218
18218
  const solanaAddress = solanaParser.normalizedToNative(randomHex(32));
18219
18219
  globalExpect(() => solanaParser.nativeToBytes32Hex(evmAddress)).toThrow(/Cannot convert/);
18220
18220
  globalExpect(() => evmParser.nativeToBytes32Hex(solanaAddress)).toThrow(/Cannot convert/);
18221
18221
  });
18222
18222
  it("accepts string addresses without validation", () => {
18223
- const parser = C2R7HHH3_cjs.addressParser(layerzeroDefinitions.ChainName.ETHEREUM);
18223
+ const parser = _7TRUXRQA_cjs.addressParser(layerzeroDefinitions.ChainName.ETHEREUM);
18224
18224
  const randomAddress = "0x" + "ab".repeat(20);
18225
18225
  const result = parser.nativeToNormalized(randomAddress);
18226
18226
  globalExpect(result).toBe(commonChainModel.normalizeHex(randomAddress));
@@ -18231,7 +18231,7 @@ describe("addressParser - chain validation", () => {
18231
18231
  });
18232
18232
  });
18233
18233
  describe("addressParser - TON", () => {
18234
- const parser = C2R7HHH3_cjs.addressParser(layerzeroDefinitions.ChainName.TON);
18234
+ const parser = _7TRUXRQA_cjs.addressParser(layerzeroDefinitions.ChainName.TON);
18235
18235
  it("maintains roundtrip invariant: hex -> ton address -> hex", () => {
18236
18236
  runPropertyTest(() => {
18237
18237
  const byteLength = Math.floor(Math.random() * 32) + 1;
@@ -18292,7 +18292,7 @@ describe("addressParser - TON", () => {
18292
18292
  });
18293
18293
  });
18294
18294
  describe("addressParser - Stellar", () => {
18295
- const parser = C2R7HHH3_cjs.addressParser(layerzeroDefinitions.ChainName.STELLAR);
18295
+ const parser = _7TRUXRQA_cjs.addressParser(layerzeroDefinitions.ChainName.STELLAR);
18296
18296
  const validTestAddresses = {
18297
18297
  // Account address (G...)
18298
18298
  account: "GA7QYNF7SOWQ3GLR2BGMZEHXAVIRZA4KVWLTJJFC7MGXUA74P7UJVSGZ",
@@ -18615,7 +18615,7 @@ describe("addressParser - normalizedToBytes32Hex (cross-chain)", () => {
18615
18615
  ];
18616
18616
  testCases.forEach(({ name, chainName, nativeAddr }) => {
18617
18617
  it(`${name}: normalizedToBytes32Hex(normalized) === nativeToBytes32Hex(native)`, () => {
18618
- const p3 = C2R7HHH3_cjs.addressParser(chainName);
18618
+ const p3 = _7TRUXRQA_cjs.addressParser(chainName);
18619
18619
  const normalized = p3.nativeToNormalized(nativeAddr);
18620
18620
  const fromNormalized = p3.normalizedToBytes32Hex(normalized);
18621
18621
  const fromNative = p3.nativeToBytes32Hex(nativeAddr);
@@ -18625,13 +18625,13 @@ describe("addressParser - normalizedToBytes32Hex (cross-chain)", () => {
18625
18625
  });
18626
18626
  });
18627
18627
  it("normalizedToBytes32Hex is consistent across chain parsers for \u226432 byte hex", () => {
18628
- const evmParser = C2R7HHH3_cjs.addressParser(layerzeroDefinitions.ChainName.ETHEREUM);
18629
- const solanaParser = C2R7HHH3_cjs.addressParser(layerzeroDefinitions.ChainName.SOLANA);
18628
+ const evmParser = _7TRUXRQA_cjs.addressParser(layerzeroDefinitions.ChainName.ETHEREUM);
18629
+ const solanaParser = _7TRUXRQA_cjs.addressParser(layerzeroDefinitions.ChainName.SOLANA);
18630
18630
  const normalized = commonChainModel.normalizeHex("0x1234567890abcdef1234567890abcdef12345678");
18631
18631
  globalExpect(evmParser.normalizedToBytes32Hex(normalized)).toBe(solanaParser.normalizedToBytes32Hex(normalized));
18632
18632
  });
18633
18633
  it("normalizedToBytes32 returns correct Uint8Array", () => {
18634
- const p3 = C2R7HHH3_cjs.addressParser(layerzeroDefinitions.ChainName.ETHEREUM);
18634
+ const p3 = _7TRUXRQA_cjs.addressParser(layerzeroDefinitions.ChainName.ETHEREUM);
18635
18635
  const normalized = commonChainModel.normalizeHex("0x1234567890abcdef1234567890abcdef12345678");
18636
18636
  const bytes32Hex = p3.normalizedToBytes32Hex(normalized);
18637
18637
  const bytes32 = p3.normalizedToBytes32(normalized);
@@ -18639,7 +18639,7 @@ describe("addressParser - normalizedToBytes32Hex (cross-chain)", () => {
18639
18639
  globalExpect(commonEncodingUtils.bytesToHexPrefixed(bytes32)).toBe(bytes32Hex);
18640
18640
  });
18641
18641
  it("returns undefined for undefined input", () => {
18642
- const p3 = C2R7HHH3_cjs.addressParser(layerzeroDefinitions.ChainName.ETHEREUM);
18642
+ const p3 = _7TRUXRQA_cjs.addressParser(layerzeroDefinitions.ChainName.ETHEREUM);
18643
18643
  globalExpect(p3.normalizedToBytes32Hex(void 0)).toBeUndefined();
18644
18644
  globalExpect(p3.normalizedToBytes32(void 0)).toBeUndefined();
18645
18645
  });
@@ -18681,14 +18681,14 @@ describe("addressParser - bytes32ToNormalized", () => {
18681
18681
  ];
18682
18682
  cases.forEach(({ name, chainName, native }) => {
18683
18683
  it(`${name}: round-trip`, () => {
18684
- const p3 = C2R7HHH3_cjs.addressParser(chainName);
18684
+ const p3 = _7TRUXRQA_cjs.addressParser(chainName);
18685
18685
  const normalized = p3.nativeToNormalized(native);
18686
18686
  const bytes32Hex = p3.nativeToBytes32Hex(native);
18687
18687
  globalExpect(p3.bytes32ToNormalized(bytes32Hex)).toBe(normalized);
18688
18688
  });
18689
18689
  });
18690
18690
  it("Stellar contract: round-trip", () => {
18691
- const p3 = C2R7HHH3_cjs.addressParser(layerzeroDefinitions.ChainName.STELLAR);
18691
+ const p3 = _7TRUXRQA_cjs.addressParser(layerzeroDefinitions.ChainName.STELLAR);
18692
18692
  const contractAddr = "CA7QYNF7SOWQ3GLR2BGMZEHXAVIRZA4KVWLTJJFC7MGXUA74P7UJUWDA";
18693
18693
  const normalized = p3.nativeToNormalized(contractAddr);
18694
18694
  const bytes32Hex = p3.nativeToBytes32Hex(contractAddr);
@@ -18696,7 +18696,7 @@ describe("addressParser - bytes32ToNormalized", () => {
18696
18696
  });
18697
18697
  });
18698
18698
  it("undefined input returns undefined", () => {
18699
- const p3 = C2R7HHH3_cjs.addressParser(layerzeroDefinitions.ChainName.ETHEREUM);
18699
+ const p3 = _7TRUXRQA_cjs.addressParser(layerzeroDefinitions.ChainName.ETHEREUM);
18700
18700
  globalExpect(p3.bytes32ToNormalized(void 0)).toBeUndefined();
18701
18701
  });
18702
18702
  it("non-Stellar: bytes32ToNative === normalizeHex for same input", () => {
@@ -18708,15 +18708,15 @@ describe("addressParser - bytes32ToNormalized", () => {
18708
18708
  ];
18709
18709
  const bytes32 = "0x0000000000000000000000001234567890abcdef1234567890abcdef12345678";
18710
18710
  chains.forEach((chainName) => {
18711
- globalExpect(C2R7HHH3_cjs.addressParser(chainName).bytes32ToNormalized(bytes32)).toBe(commonChainModel.normalizeHex(bytes32));
18711
+ globalExpect(_7TRUXRQA_cjs.addressParser(chainName).bytes32ToNormalized(bytes32)).toBe(commonChainModel.normalizeHex(bytes32));
18712
18712
  });
18713
18713
  });
18714
18714
  it("zero bytes32: EVM returns NORMALIZED_HEX_ZERO", () => {
18715
- const p3 = C2R7HHH3_cjs.addressParser(layerzeroDefinitions.ChainName.ETHEREUM);
18715
+ const p3 = _7TRUXRQA_cjs.addressParser(layerzeroDefinitions.ChainName.ETHEREUM);
18716
18716
  globalExpect(p3.bytes32ToNormalized(ZERO_BYTES32)).toBe(commonChainModel.NORMALIZED_HEX_ZERO);
18717
18717
  });
18718
18718
  it("zero bytes32: Stellar returns C-address for zero contract ID (not undefined)", () => {
18719
- const p3 = C2R7HHH3_cjs.addressParser(layerzeroDefinitions.ChainName.STELLAR);
18719
+ const p3 = _7TRUXRQA_cjs.addressParser(layerzeroDefinitions.ChainName.STELLAR);
18720
18720
  const result = p3.bytes32ToNormalized(ZERO_BYTES32);
18721
18721
  globalExpect(result).toBeDefined();
18722
18722
  globalExpect(result).not.toBe(commonChainModel.NORMALIZED_HEX_ZERO);