@talismn/sapi 0.1.5 → 0.1.6
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/index.js +11 -12
- package/dist/index.js.map +1 -1
- package/dist/index.mjs +8 -9
- package/dist/index.mjs.map +1 -1
- package/package.json +1 -2
package/dist/index.js
CHANGED
|
@@ -85,7 +85,7 @@ var import_anylogger = __toESM(require("anylogger"));
|
|
|
85
85
|
// package.json
|
|
86
86
|
var package_default = {
|
|
87
87
|
name: "@talismn/sapi",
|
|
88
|
-
version: "0.1.
|
|
88
|
+
version: "0.1.6",
|
|
89
89
|
author: "Talisman",
|
|
90
90
|
homepage: "https://talisman.xyz",
|
|
91
91
|
license: "GPL-3.0-or-later",
|
|
@@ -118,7 +118,6 @@ var package_default = {
|
|
|
118
118
|
"@polkadot-api/utils": "0.2.0",
|
|
119
119
|
"@polkadot/types": "16.1.2",
|
|
120
120
|
"@polkadot/types-codec": "16.1.2",
|
|
121
|
-
"@polkadot/util": "13.5.3",
|
|
122
121
|
"@talismn/scale": "workspace:*",
|
|
123
122
|
anylogger: "^1.0.11",
|
|
124
123
|
"polkadot-api": "1.23.3",
|
|
@@ -443,9 +442,10 @@ var getDryRunCall = async (chain, from, decodedCall) => {
|
|
|
443
442
|
var import_polkadot_api2 = require("polkadot-api");
|
|
444
443
|
|
|
445
444
|
// src/helpers/getExtrinsicDispatchInfo.ts
|
|
446
|
-
var
|
|
445
|
+
var import_utils3 = require("@polkadot-api/utils");
|
|
447
446
|
var getExtrinsicDispatchInfo = async (chain, signedExtrinsic) => {
|
|
448
|
-
|
|
447
|
+
if (!signedExtrinsic.isSigned)
|
|
448
|
+
throw new Error("Extrinsic must be signed (or fakeSigned) in order to query fee");
|
|
449
449
|
const len = signedExtrinsic.registry.createType("u32", signedExtrinsic.encodedLength);
|
|
450
450
|
const dispatchInfo = await stateCall(
|
|
451
451
|
chain.connector.send,
|
|
@@ -461,7 +461,7 @@ var getExtrinsicDispatchInfo = async (chain, signedExtrinsic) => {
|
|
|
461
461
|
};
|
|
462
462
|
var stateCall = async (request, method, resultType, args, blockHash, isCacheable) => {
|
|
463
463
|
const registry = args[0].registry;
|
|
464
|
-
const bytes = registry.createType("Raw", (0,
|
|
464
|
+
const bytes = registry.createType("Raw", (0, import_utils3.mergeUint8)(...args.map((arg) => arg.toU8a())));
|
|
465
465
|
const result = await request("state_call", [method, bytes.toHex(), blockHash], isCacheable);
|
|
466
466
|
return registry.createType(resultType, result);
|
|
467
467
|
};
|
|
@@ -532,13 +532,12 @@ var getSapiConnector = ({
|
|
|
532
532
|
});
|
|
533
533
|
|
|
534
534
|
// src/helpers/getSignerPayloadJSON.ts
|
|
535
|
-
var
|
|
536
|
-
var import_utils4 = require("@polkadot-api/utils");
|
|
535
|
+
var import_utils5 = require("@polkadot-api/utils");
|
|
537
536
|
var import_polkadot_api3 = require("polkadot-api");
|
|
538
537
|
|
|
539
538
|
// src/helpers/getPayloadWithMetadataHash.ts
|
|
540
539
|
var import_merkleize_metadata = require("@polkadot-api/merkleize-metadata");
|
|
541
|
-
var
|
|
540
|
+
var import_utils4 = require("@polkadot-api/utils");
|
|
542
541
|
var getPayloadWithMetadataHash = (chain, chainInfo, payload) => {
|
|
543
542
|
if (!chain.hasCheckMetadataHash || !payload.signedExtensions.includes("CheckMetadataHash"))
|
|
544
543
|
return {
|
|
@@ -550,7 +549,7 @@ var getPayloadWithMetadataHash = (chain, chainInfo, payload) => {
|
|
|
550
549
|
const { base58Prefix, specName, specVersion } = chainInfo;
|
|
551
550
|
const metadataHashInputs = { tokenSymbol, decimals, base58Prefix, specName, specVersion };
|
|
552
551
|
const merkleizedMetadata = (0, import_merkleize_metadata.merkleizeMetadata)(chain.hexMetadata, metadataHashInputs);
|
|
553
|
-
const metadataHash = (0,
|
|
552
|
+
const metadataHash = (0, import_utils4.toHex)(merkleizedMetadata.digest());
|
|
554
553
|
log_default.log("metadataHash", metadataHash, metadataHashInputs);
|
|
555
554
|
const payloadWithMetadataHash = {
|
|
556
555
|
...payload,
|
|
@@ -614,7 +613,7 @@ function trailingZeroes(n) {
|
|
|
614
613
|
var ERA_PERIOD = 64;
|
|
615
614
|
var getSignerPayloadJSON = async (chain, palletName, methodName, args, signerConfig, chainInfo) => {
|
|
616
615
|
const { codec, location } = chain.builder.buildCall(palletName, methodName);
|
|
617
|
-
const method = import_polkadot_api3.Binary.fromBytes((0,
|
|
616
|
+
const method = import_polkadot_api3.Binary.fromBytes((0, import_utils5.mergeUint8)([new Uint8Array(location), codec.enc(args)]));
|
|
618
617
|
let blockHash = await getSendRequestResult(
|
|
619
618
|
chain,
|
|
620
619
|
"chain_getFinalizedHead",
|
|
@@ -649,14 +648,14 @@ var getSignerPayloadJSON = async (chain, palletName, methodName, args, signerCon
|
|
|
649
648
|
specVersion: toPjsHex(chainInfo.specVersion, 4),
|
|
650
649
|
transactionVersion: toPjsHex(chainInfo.transactionVersion, 4),
|
|
651
650
|
blockNumber: toPjsHex(blockNumber, 4),
|
|
652
|
-
era: (0,
|
|
651
|
+
era: (0, import_utils5.toHex)(era),
|
|
653
652
|
tip: toPjsHex(0, 16),
|
|
654
653
|
// TODO gas station (required for Astar)
|
|
655
654
|
assetId: void 0,
|
|
656
655
|
version: 4
|
|
657
656
|
};
|
|
658
657
|
const { payload, txMetadata } = getPayloadWithMetadataHash(chain, chainInfo, basePayload);
|
|
659
|
-
const shortMetadata = txMetadata ? (0,
|
|
658
|
+
const shortMetadata = txMetadata ? (0, import_utils5.toHex)(txMetadata) : void 0;
|
|
660
659
|
if (payload.signedExtensions.includes("CheckAppId"))
|
|
661
660
|
payload.appId = 0;
|
|
662
661
|
log_default.log("[sapi] payload", { newPayload: payload, txMetadata });
|
package/dist/index.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["../src/index.ts","../src/fetchBestMetadata.ts","../src/sapi.ts","../src/log.ts","../package.json","../src/helpers/getCallDocs.ts","../src/helpers/getConstantValue.ts","../src/helpers/getChainInfo.ts","../src/helpers/getDecodedCall.ts","../src/helpers/getDecodedCallFromExtrinsic.ts","../src/helpers/getDryRunCall.ts","../src/helpers/errors.ts","../src/helpers/getRuntimeCallResult.ts","../src/helpers/getSendRequestResult.ts","../src/helpers/isApiAvailable.ts","../src/helpers/getFeeEstimate.ts","../src/helpers/getExtrinsicDispatchInfo.ts","../src/helpers/getTypeRegistry.ts","../src/helpers/getSapiConnector.ts","../src/helpers/getSignerPayloadJSON.ts","../src/helpers/getPayloadWithMetadataHash.ts","../src/helpers/getStorageValue.ts","../src/helpers/papi.ts","../src/helpers/hasEvent.ts","../src/helpers/submit.ts"],"sourcesContent":["export * from \"./fetchBestMetadata\"\nexport * from \"./sapi\"\nexport * from \"./types\"\n","import { toHex } from \"@polkadot-api/utils\"\nimport { u32, Vector } from \"scale-ts\"\n\nconst MAGIC_NUMBER = 1635018093\n\n// it's important to set a max because some chains also return high invalid version numbers in the metadata_versions list (ex on Polkadot, related to JAM?)\nexport const MAX_SUPPORTED_METADATA_VERSION = 15 // v16 sometimes outputs different metadata hashes, ignore v16 until that is fixed in PAPI\n\ntype RpcSendFunc = <T>(method: string, params: unknown[], isCacheable?: boolean) => Promise<T>\n\n/**\n * Fetches the highest supported version of metadata from the chain.\n *\n * @param rpcSend\n * @returns hex-encoded metadata starting with the magic number\n */\nexport const fetchBestMetadata = async (\n rpcSend: RpcSendFunc,\n allowLegacyFallback?: boolean\n): Promise<`0x${string}`> => {\n try {\n // fetch available versions of metadata\n const metadataVersions = await rpcSend<string>(\n \"state_call\",\n [\"Metadata_metadata_versions\", \"0x\"],\n true\n )\n const availableVersions = Vector(u32).dec(metadataVersions)\n const bestVersion = Math.max(\n ...availableVersions.filter((v) => v <= MAX_SUPPORTED_METADATA_VERSION)\n )\n\n const metadata = await rpcSend<`0x${string}`>(\n \"state_call\",\n [\"Metadata_metadata_at_version\", toHex(u32.enc(bestVersion))],\n true\n )\n\n return normalizeMetadata(metadata)\n } catch (cause) {\n // if the chain doesnt support the Metadata pallet, fallback to legacy rpc provided metadata (V14)\n const message = (cause as { message?: string })?.message\n if (\n allowLegacyFallback ||\n message?.includes(\"is not found\") || // ex: crust standalone\n message?.includes(\"Module doesn't have export Metadata_metadata_versions\") || // ex: 3DPass\n message?.includes(\"Exported method Metadata_metadata_versions is not found\") || // ex: sora-polkadot & sora-standalone\n message?.includes(\"Execution, MethodNotFound, Metadata_metadata_versions\") // ex: stafi\n ) {\n return (await rpcSend(\"state_getMetadata\", [], true)) as `0x${string}`\n }\n\n // otherwise throw so it can be handled by the caller\n throw new Error(\"Failed to fetch metadata\", { cause })\n }\n}\n\n/**\n * Removes everything before the magic number in the metadata.\n * This ensures Opaque metadata is usable by pjs\n */\nconst normalizeMetadata = (metadata: `0x${string}`): `0x${string}` => {\n const hexMagicNumber = toHex(u32.enc(MAGIC_NUMBER)).slice(2)\n\n const magicNumberIndex = metadata.indexOf(hexMagicNumber)\n if (magicNumberIndex === -1) throw new Error(\"Invalid metadata format: magic number not found\")\n\n return `0x${metadata.slice(magicNumberIndex)}` as `0x${string}`\n}\n","import type { ExtDef } from \"@polkadot/types/extrinsic/signedExtensions/types\"\nimport type { SignerPayloadJSON } from \"@polkadot/types/types\"\nimport { parseMetadataRpc } from \"@talismn/scale\"\n\nimport { getCallDocs } from \"./helpers/getCallDocs\"\nimport { getChainInfo } from \"./helpers/getChainInfo\"\nimport { getConstantValue } from \"./helpers/getConstantValue\"\nimport { getDecodedCall, getDecodedCallFromPayload } from \"./helpers/getDecodedCall\"\nimport { getDecodedCallFromExtrinsic } from \"./helpers/getDecodedCallFromExtrinsic\"\nimport { getDryRunCall } from \"./helpers/getDryRunCall\"\nimport { getFeeEstimate } from \"./helpers/getFeeEstimate\"\nimport { getRuntimeCallResult } from \"./helpers/getRuntimeCallResult\"\nimport { getSapiConnector } from \"./helpers/getSapiConnector\"\nimport { getSignerPayloadJSON } from \"./helpers/getSignerPayloadJSON\"\nimport { getStorageValue } from \"./helpers/getStorageValue\"\nimport { getTypeRegistry } from \"./helpers/getTypeRegistry\"\nimport { hasEvent } from \"./helpers/hasEvent\"\nimport { isApiAvailable } from \"./helpers/isApiAvailable\"\nimport { submit } from \"./helpers/submit\"\nimport type { Chain } from \"./helpers/types\"\nimport type {\n DecodedCall,\n PayloadSignerConfig,\n SapiConnectorProps,\n ScaleApiSubmitMode,\n} from \"./types\"\n\nexport type ScaleApi = NonNullable<ReturnType<typeof getScaleApi>>\n\nexport const getScaleApi = (\n connector: SapiConnectorProps,\n hexMetadata: `0x${string}`,\n token: { symbol: string; decimals: number },\n hasCheckMetadataHash?: boolean,\n signedExtensions?: ExtDef,\n registryTypes?: unknown\n) => {\n const { unifiedMetadata: metadata, lookupFn: lookup, builder } = parseMetadataRpc(hexMetadata)\n\n const chain: Chain = {\n connector: getSapiConnector(connector),\n hexMetadata,\n\n token,\n hasCheckMetadataHash,\n signedExtensions,\n registryTypes,\n\n metadata,\n lookup,\n builder,\n metadataRpc: hexMetadata,\n }\n\n const chainInfo = getChainInfo(chain)\n\n const { specName, specVersion, base58Prefix } = chainInfo\n\n return {\n id: `${connector.chainId}::${specName}::${specVersion}`,\n chainId: connector.chainId,\n specName,\n specVersion,\n hasCheckMetadataHash,\n base58Prefix,\n token: chain.token,\n chain,\n\n getConstant: <T>(pallet: string, constant: string) =>\n getConstantValue<T>(chain, pallet, constant),\n\n getStorage: <T>(pallet: string, entry: string, keys: unknown[], at?: string) =>\n getStorageValue<T>(chain, pallet, entry, keys, at),\n\n getDecodedCall: (pallet: string, method: string, args: unknown) =>\n getDecodedCall(pallet, method, args),\n\n getDecodedCallFromPayload: <Res extends DecodedCall>(payload: {\n method: SignerPayloadJSON[\"method\"]\n }) => getDecodedCallFromPayload<Res>(chain, payload),\n\n getDecodedCallFromExtrinsic: <Res extends DecodedCall>(extrinsicHex: `0x${string}`) =>\n getDecodedCallFromExtrinsic<Res>(chain, extrinsicHex),\n\n getExtrinsicPayload: (\n pallet: string,\n method: string,\n args: unknown,\n config: PayloadSignerConfig\n ) => getSignerPayloadJSON(chain, pallet, method, args, config, chainInfo),\n\n getFeeEstimate: (payload: SignerPayloadJSON) => getFeeEstimate(chain, payload, chainInfo),\n\n getRuntimeCallValue: <T>(apiName: string, method: string, args: unknown[]) =>\n getRuntimeCallResult<T>(chain, apiName, method, args),\n\n getTypeRegistry: (payload: SignerPayloadJSON) => getTypeRegistry(chain, payload),\n\n submit: (\n payload: SignerPayloadJSON,\n signature?: `0x${string}`,\n txInfo?: unknown,\n mode?: ScaleApiSubmitMode\n ) => submit(chain, payload, signature, txInfo, mode),\n\n getCallDocs: (pallet: string, method: string) => getCallDocs(chain, pallet, method),\n\n getDryRunCall: <T>(from: string, decodedCall: DecodedCall<unknown>) =>\n getDryRunCall<T>(chain, from, decodedCall),\n\n isApiAvailable: (name: string, method: string) => isApiAvailable(chain, name, method),\n\n hasEvent: (pallet: string, event: string) => hasEvent(chain, pallet, event),\n }\n}\n","import anylogger from \"anylogger\"\n\nimport packageJson from \"../package.json\"\n\nexport default anylogger(packageJson.name)\n","{\n \"name\": \"@talismn/sapi\",\n \"version\": \"0.1.5\",\n \"author\": \"Talisman\",\n \"homepage\": \"https://talisman.xyz\",\n \"license\": \"GPL-3.0-or-later\",\n \"publishConfig\": {\n \"access\": \"public\"\n },\n \"repository\": {\n \"directory\": \"packages/sapi\",\n \"type\": \"git\",\n \"url\": \"https://github.com/TalismanSociety/talisman.git\"\n },\n \"main\": \"./dist/index.js\",\n \"module\": \"./dist/index.mjs\",\n \"files\": [\n \"dist\"\n ],\n \"engines\": {\n \"node\": \">=20\"\n },\n \"scripts\": {\n \"test\": \"vitest run\",\n \"clean\": \"rm -rf dist .turbo node_modules\",\n \"build\": \"tsup --silent\",\n \"typecheck\": \"tsc --noEmit\"\n },\n \"dependencies\": {\n \"@polkadot-api/merkleize-metadata\": \"1.1.29\",\n \"@polkadot-api/metadata-builders\": \"0.13.9\",\n \"@polkadot-api/substrate-bindings\": \"0.17.0\",\n \"@polkadot-api/utils\": \"0.2.0\",\n \"@polkadot/types\": \"16.1.2\",\n \"@polkadot/types-codec\": \"16.1.2\",\n \"@polkadot/util\": \"13.5.3\",\n \"@talismn/scale\": \"workspace:*\",\n \"anylogger\": \"^1.0.11\",\n \"polkadot-api\": \"1.23.3\",\n \"scale-ts\": \"^1.6.1\"\n },\n \"devDependencies\": {\n \"@talismn/tsconfig\": \"workspace:*\",\n \"typescript\": \"^5.6.3\"\n },\n \"types\": \"./dist/index.d.ts\",\n \"exports\": {\n \".\": {\n \"@talismn/source\": \"./src/index.ts\",\n \"import\": {\n \"types\": \"./dist/index.d.mts\",\n \"default\": \"./dist/index.mjs\"\n },\n \"require\": {\n \"types\": \"./dist/index.d.ts\",\n \"default\": \"./dist/index.js\"\n }\n }\n }\n}\n","import log from \"../log\"\nimport type { Chain } from \"./types\"\n\nexport const getCallDocs = (chain: Chain, pallet: string, method: string): string | null => {\n try {\n const typeIdCalls = chain.metadata.pallets.find(({ name }) => name === pallet)?.calls?.type\n if (!typeIdCalls) return null\n\n // biome-ignore lint/suspicious/noExplicitAny: legacy\n let palletCalls: any = chain.metadata.lookup[typeIdCalls]\n if (!palletCalls || palletCalls.id !== typeIdCalls)\n palletCalls = chain.metadata.lookup.find((v) => v.id === typeIdCalls)\n\n if (!palletCalls) return null\n\n const call = palletCalls.def.value.find(\n (c: { name: string; docs?: string[] | null }) => c.name === method\n )\n\n return call?.docs?.join(\"\\n\") ?? null\n } catch {\n log.error(\"Failed to find call docs\", { pallet, method, chain })\n return null\n }\n}\n","import { getConstantValueFromMetadata } from \"@talismn/scale\"\n\nimport type { Chain } from \"./types\"\n\nexport const getConstantValue = <T>(chain: Chain, pallet: string, constant: string) => {\n return getConstantValueFromMetadata<T>(\n {\n builder: chain.builder,\n unifiedMetadata: chain.metadata,\n },\n pallet,\n constant\n )\n}\n","import { getConstantValue } from \"./getConstantValue\"\nimport type { Chain } from \"./types\"\n\ntype SystemVersion = {\n spec_name: string\n spec_version: number\n transaction_version: number\n}\n\nexport const getChainInfo = (chain: Chain) => {\n const {\n spec_name: specName,\n spec_version: specVersion,\n transaction_version: transactionVersion,\n } = getConstantValue<SystemVersion>(chain, \"System\", \"Version\")\n\n const base58Prefix = getConstantValue<number>(chain, \"System\", \"SS58Prefix\")\n\n return {\n specName,\n specVersion,\n transactionVersion,\n base58Prefix,\n }\n}\n","import type { SignerPayloadJSON } from \"@polkadot/types/types\"\n\nimport type { DecodedCall } from \"../types\"\nimport type { Chain } from \"./types\"\n\nexport const getDecodedCall = (palletName: string, methodName: string, args: unknown) => ({\n type: palletName,\n value: { type: methodName, value: args },\n})\n\nexport const getDecodedCallFromPayload = <Res extends DecodedCall>(\n chain: Chain,\n payload: { method: SignerPayloadJSON[\"method\"] }\n): Res => {\n const def = chain.builder.buildDefinition(chain.lookup.call!)\n const decoded = def.dec(payload.method)\n\n return {\n pallet: decoded.type,\n method: decoded.value.type,\n args: decoded.value.value,\n } as Res\n}\n","import {\n Bin,\n compactNumber,\n createDecoder,\n type Decoder,\n enhanceDecoder,\n extrinsicFormat,\n type StringRecord,\n Struct,\n u8,\n} from \"@polkadot-api/substrate-bindings\"\n\nimport type { DecodedCall } from \"../types\"\nimport type { Chain } from \"./types\"\n\nconst allBytesDec = Bin(Infinity).dec\n\n/**\n * Decodes a signed extrinsic and extracts the call data.\n * Handles different metadata versions (v14, v15, v16) and extrinsic formats.\n *\n * @param chain - The chain context with metadata and builder\n * @param extrinsicHex - The hex-encoded extrinsic (with 0x prefix)\n * @returns The decoded call with pallet, method, and args, or null if decoding fails\n */\nexport const getDecodedCallFromExtrinsic = <Res extends DecodedCall>(\n chain: Chain,\n extrinsicHex: `0x${string}`\n): Res | null => {\n try {\n const { metadata, builder } = chain\n\n // Build decoder for signed extensions (extra field)\n // signedExtensions is keyed by extension version, 0 is the default\n const extensionsArray = metadata.extrinsic.signedExtensions[0] ?? []\n const extraDec = Struct.dec(\n Object.fromEntries(\n extensionsArray.map((x) => [x.identifier, builder.buildDefinition(x.type)[1]])\n ) as StringRecord<Decoder<unknown>>\n )\n\n // Build call decoder\n let callDec: Decoder<{ type: string; value: { type: string; value: unknown } }>\n const { extrinsic } = metadata\n if (\"address\" in extrinsic) {\n // v15/v16 metadata\n callDec = builder.buildDefinition(extrinsic.call)[1]\n } else {\n // v14 metadata\n const params = metadata.lookup[extrinsic.type]?.params\n const callType = params?.find((v) => v.name === \"Call\")?.type\n if (callType == null) throw new Error(\"Call type not found in metadata\")\n callDec = builder.buildDefinition(callType)[1]\n }\n\n // Build address and signature decoders\n let addressDec: Decoder<unknown>\n let signatureDec: Decoder<unknown>\n if (\"address\" in extrinsic) {\n // v15/v16\n addressDec = builder.buildDefinition(extrinsic.address)[1]\n signatureDec = builder.buildDefinition(extrinsic.signature)[1]\n } else {\n // v14\n const params = metadata.lookup[extrinsic.type]?.params\n const addrType = params?.find((v) => v.name === \"Address\")?.type\n const sigType = params?.find((v) => v.name === \"Signature\")?.type\n if (addrType == null || sigType == null)\n throw new Error(\"Address or Signature type not found\")\n addressDec = builder.buildDefinition(addrType)[1]\n signatureDec = builder.buildDefinition(sigType)[1]\n }\n\n // Build full signed extrinsic body decoder\n const v4Body = Struct.dec({\n address: addressDec,\n signature: signatureDec,\n extra: extraDec,\n callData: allBytesDec,\n })\n\n // Create the full extrinsic decoder\n const extrinsicDecoder = enhanceDecoder(\n createDecoder((data) => {\n const len = compactNumber.dec(data)\n const { type, version } = extrinsicFormat[1](data)\n\n if (type === \"bare\") {\n return { len, version, type, callData: allBytesDec(data) }\n }\n if (type === \"signed\") {\n return { len, version, type, ...v4Body(data) }\n }\n\n // v5 general format\n const extensionVersion = u8.dec(data)\n const extra = extraDec(data)\n return {\n len,\n type,\n version,\n extensionVersion,\n extra,\n callData: allBytesDec(data),\n }\n }),\n (v) => ({\n ...v,\n call: callDec(v.callData.asBytes()),\n })\n )\n\n // Decode the extrinsic\n const decoded = extrinsicDecoder(extrinsicHex)\n\n return {\n pallet: decoded.call.type,\n method: decoded.call.value.type,\n args: decoded.call.value.value,\n } as Res\n } catch (err) {\n // biome-ignore lint/suspicious/noConsole: troubleshoting\n console.error(\"[SAPI] Failed to decode extrinsic:\", err)\n return null\n }\n}\n","import type { polkadot, polkadotAssetHub } from \"@polkadot-api/descriptors\"\nimport { Enum } from \"polkadot-api\"\n\nimport log from \"../log\"\nimport type { DecodedCall } from \"../types\"\nimport { getDispatchErrorMessage } from \"./errors\"\nimport { getRuntimeCallResult } from \"./getRuntimeCallResult\"\nimport { isApiAvailable } from \"./isApiAvailable\"\nimport type { Chain } from \"./types\"\n\ntype DryRunResult = (\n | typeof polkadot\n | typeof polkadotAssetHub\n)[\"descriptors\"][\"apis\"][\"DryRunApi\"][\"dry_run_call\"][1]\n\nexport const getDryRunCall = async <T>(\n chain: Chain,\n from: string,\n decodedCall: DecodedCall<unknown>\n): Promise<\n | {\n available: boolean\n data: null\n ok?: undefined\n errorMessage?: undefined\n }\n | {\n available: boolean\n data: T\n ok: boolean\n errorMessage: string | null\n }\n> => {\n try {\n if (!isApiAvailable(chain, \"DryRunApi\", \"dry_run_call\"))\n return {\n available: false,\n data: null,\n }\n\n const origin = Enum(\"system\", Enum(\"Signed\", from))\n\n const { pallet, method, args } = decodedCall\n const call = { type: pallet, value: { type: method, value: args } }\n\n // This will throw an error if the api is not available on that chain\n const data = await getRuntimeCallResult<DryRunResult>(chain, \"DryRunApi\", \"dry_run_call\", [\n origin,\n call,\n ])\n\n const ok = data.success && data.value.execution_result.success\n const errorMessage =\n data.success && !data.value.execution_result.success\n ? getDispatchErrorMessage(chain, data.value.execution_result.value.error)\n : null\n\n return {\n available: true,\n // NOTE: we can't re-export `@polkadot-api/descriptors` from this package.\n // So, the caller of this function must pass in their own instance of `type DryRunResult` as the generic argument `T`.\n data: data as T,\n ok,\n errorMessage,\n }\n } catch (err) {\n // Note : err is null if chain doesnt have the api\n log.error(\"Failed to dry run\", { chainId: chain.connector.chainId, err })\n return {\n available: false,\n data: null,\n }\n }\n}\n","import { getLookupFn } from \"@polkadot-api/metadata-builders\"\n\nimport log from \"../log\"\nimport type { Chain } from \"./types\"\n\nexport const getDispatchErrorMessage = (chain: Chain, err: unknown): string | null => {\n try {\n if (!err) return null\n\n const error = err as UnsafeDispatchError\n if (!error.type) throw new Error(\"Unknown dispatch error\")\n\n const lv1 = DISPATCH_ERROR[error.type as keyof typeof DISPATCH_ERROR]\n if (!lv1) throw new Error(\"Unknown dispatch error\")\n if (lv1 === ERROR_METADATA_LOOKUP)\n return getModuleErrorMessage(chain, error.value as UnsafeModuleError)\n if (typeof lv1 === \"string\") return lv1\n\n const lv2 = lv1[error.value?.type as keyof typeof lv1]\n if (!lv2) throw new Error(\"Unknown dispatch error\")\n if (typeof lv2 === \"string\") return lv2\n\n throw new Error(\"Unknown dispatch error\")\n } catch (cause) {\n log.error(\"Failed to parse runtime error\", { chainId: chain.connector.chainId, cause, err })\n return tryFormatError(err)\n }\n}\n\nconst ERROR_METADATA_LOOKUP = \"METADATA_LOOKUP\"\n\n// only `Module` errors are part of the metadata\n// errors below are defined as part of the runtime but their docs aren't included in the metadata\n// so those are copy/pasted from the polkadot-sdk repo\n\n// https://github.com/paritytech/polkadot-sdk/blob/56d97c3ad8c86e602bc7ac368751210517c4309f/substrate/primitives/runtime/src/lib.rs#L543\nconst ERRORS_TRANSACTIONAL = {\n LimitReached: \"Too many transactional layers have been spawned\",\n NoLayer: \"A transactional layer was expected, but does not exist\",\n}\n\n// https://github.com/paritytech/polkadot-sdk/blob/56d97c3ad8c86e602bc7ac368751210517c4309f/substrate/primitives/runtime/src/lib.rs#L672\nconst ERRORS_TOKEN = {\n FundsUnavailable: \"Funds are unavailable\",\n OnlyProvider: \"Account that must exist would die\",\n BelowMinimum: \"Account cannot exist with the funds that would be given\",\n CannotCreate: \"Account cannot be created\",\n UnknownAsset: \"The asset in question is unknown\",\n Frozen: \"Funds exist but are frozen\",\n Unsupported: \"Operation is not supported by the asset\",\n CannotCreateHold: \"Account cannot be created for recording amount on hold\",\n NotExpendable: \"Account that is desired to remain would die\",\n Blocked: \"Account cannot receive the assets\",\n}\n\n// https://github.com/paritytech/polkadot-sdk/blob/56d97c3ad8c86e602bc7ac368751210517c4309f/substrate/primitives/arithmetic/src/lib.rs#L76\nconst ERRORS_ARITHMETIC = {\n Overflow: \"An underflow would occur\",\n Underflow: \"An overflow would occur\",\n DivisionByZero: \"Division by zero\",\n}\n\n// https://github.com/paritytech/polkadot-sdk/blob/56d97c3ad8c86e602bc7ac368751210517c4309f/substrate/primitives/runtime/src/lib.rs#L714\nconst DISPATCH_ERROR = {\n CannotLookup: \"Cannot lookup\",\n BadOrigin: \"Bad origin\",\n Module: ERROR_METADATA_LOOKUP,\n ConsumerRemaining: \"Consumer remaining\",\n NoProviders: \"No providers\",\n TooManyConsumers: \"Too many consumers\",\n Token: ERRORS_TOKEN,\n Arithmetic: ERRORS_ARITHMETIC,\n Transactional: ERRORS_TRANSACTIONAL,\n Exhausted: \"Resources exhausted\",\n Corruption: \"State corrupt\",\n Unavailable: \"Resource unavailable\",\n RootNotAllowed: \"Root not allowed\",\n Trie: \"Unknown error\", // unsupported,\n Other: \"Unknown error\", // unsupported,\n}\n\ntype UnsafeDispatchError = {\n type: string\n value:\n | {\n type: string\n value:\n | {\n type: string\n value: undefined\n }\n | undefined\n }\n | undefined\n}\n\ntype UnsafeModuleError = {\n type: string\n value: {\n type: string\n value: undefined\n }\n}\n\nconst getModuleErrorMessage = (chain: Chain, error: UnsafeModuleError): string => {\n try {\n if (!chain.metadata) throw new Error(\"Could not fetch metadata\")\n\n const pallet = chain.metadata.pallets.find((p) => p.name === error.type)\n if (typeof pallet?.errors !== \"number\") throw new Error(\"Unknown pallet\")\n\n const lookup = getLookupFn(chain.metadata)\n\n const palletErrors = lookup(pallet.errors)\n if (palletErrors.type !== \"enum\" || !palletErrors.innerDocs[error.value.type]?.length)\n throw new Error(\"Unknown error type\")\n\n return palletErrors.innerDocs[error.value.type].join(\" \")\n } catch (err) {\n log.error(\"Failed to parse module error\", { chainId: chain.connector.chainId, error, err })\n return [error.type, error.value.type].join(\": \")\n }\n}\n\nconst tryFormatError = (err: unknown): string => {\n try {\n // biome-ignore lint/suspicious/noExplicitAny: legacy\n const unsafeErr = err as any\n if (unsafeErr.type && unsafeErr.value?.type)\n return [unsafeErr.type, unsafeErr.value.type].join(\": \")\n } catch {\n // ignore\n }\n\n return \"Unknown error\"\n}\n","import { toHex } from \"@polkadot-api/utils\"\n\nimport { getSendRequestResult } from \"./getSendRequestResult\"\nimport type { Chain } from \"./types\"\n\nexport const getRuntimeCallResult = async <T>(\n chain: Chain,\n apiName: string,\n method: string,\n args: unknown[]\n) => {\n const call = chain.builder.buildRuntimeCall(apiName, method)\n\n const hex = await getSendRequestResult<string>(chain, \"state_call\", [\n `${apiName}_${method}`,\n toHex(call.args.enc(args)),\n ])\n\n return call.value.dec(hex) as T\n}\n","import type { Chain } from \"./types\"\n\nexport const getSendRequestResult = <Res>(\n chain: Chain,\n method: string,\n params: unknown[],\n isCacheable?: boolean\n): Promise<Res> => {\n return chain.connector.send(method, params, isCacheable) as Promise<Res>\n}\n","import type { Chain } from \"./types\"\n\nexport const isApiAvailable = (chain: Chain, name: string, method: string) => {\n return chain.metadata.apis.some(\n (a) => a.name === name && a.methods.some((m) => m.name === method)\n )\n}\n","import type {\n IRuntimeVersionBase,\n SignatureOptions,\n SignerPayloadJSON,\n} from \"@polkadot/types/types\"\nimport { Binary } from \"polkadot-api\"\n\nimport log from \"../log\"\nimport { getExtrinsicDispatchInfo } from \"./getExtrinsicDispatchInfo\"\nimport { getRuntimeCallResult } from \"./getRuntimeCallResult\"\nimport { getTypeRegistry } from \"./getTypeRegistry\"\nimport type { Chain, ChainInfo } from \"./types\"\n\nexport const getFeeEstimate = async (\n chain: Chain,\n payload: SignerPayloadJSON,\n chainInfo: ChainInfo\n) => {\n // TODO do this without PJS / registry => waiting for @polkadot-api/tx-utils\n const registry = getTypeRegistry(chain, payload)\n const extrinsic = registry.createType(\"Extrinsic\", payload)\n\n extrinsic.signFake(payload.address, {\n appId: 0,\n nonce: payload.nonce,\n blockHash: payload.blockHash,\n genesisHash: payload.genesisHash,\n runtimeVersion: {\n specVersion: chainInfo.specVersion,\n transactionVersion: chainInfo.transactionVersion,\n // other fields aren't necessary for signing\n } as IRuntimeVersionBase,\n } as SignatureOptions)\n\n const bytes = extrinsic.toU8a(true)\n const binary = Binary.fromBytes(bytes)\n\n try {\n const result = await getRuntimeCallResult<{ partial_fee: bigint }>(\n chain,\n \"TransactionPaymentApi\",\n \"query_info\",\n [binary, bytes.length]\n )\n // Do not throw if partialFee is 0n. This is a valid response, eg: Bittensor remove_stake fee estimation is 0n.\n if (!result?.partial_fee && result.partial_fee !== 0n) {\n throw new Error(\"partialFee is not found\")\n }\n return result.partial_fee\n } catch (err) {\n log.error(\"Failed to get fee estimate using getRuntimeCallValue\", { err })\n }\n\n // fallback to pjs encoded state call, in case the above fails (extracting runtime calls codecs might require metadata V15)\n // Note: PAPI will consider TransactionPaymentApi as first class api so it should work even without V15, but this is not the case yet.\n const { partialFee } = await getExtrinsicDispatchInfo(chain, extrinsic)\n\n return BigInt(partialFee)\n}\n","import type { GenericExtrinsic } from \"@polkadot/types\"\nimport type { RuntimeDispatchInfo } from \"@polkadot/types/interfaces\"\nimport type { Codec } from \"@polkadot/types-codec/types\"\nimport { assert, u8aConcatStrict } from \"@polkadot/util\"\nimport type { HexString } from \"@polkadot/util/types\"\n\nimport type { JsonRpcRequestSend } from \"../types\"\nimport type { Chain } from \"./types\"\n\ntype ExtrinsicDispatchInfo = {\n partialFee: string\n}\n\n// used for chains that dont have metadata v15 yet\nexport const getExtrinsicDispatchInfo = async (\n chain: Chain,\n signedExtrinsic: GenericExtrinsic\n): Promise<ExtrinsicDispatchInfo> => {\n assert(signedExtrinsic.isSigned, \"Extrinsic must be signed (or fakeSigned) in order to query fee\")\n\n const len = signedExtrinsic.registry.createType(\"u32\", signedExtrinsic.encodedLength)\n\n const dispatchInfo = (await stateCall(\n chain.connector.send,\n \"TransactionPaymentApi_query_info\",\n \"RuntimeDispatchInfo\",\n [signedExtrinsic, len],\n undefined,\n true\n )) as RuntimeDispatchInfo\n\n return {\n partialFee: dispatchInfo.partialFee.toString(),\n }\n}\n\nconst stateCall = async <K extends string = string>(\n request: JsonRpcRequestSend,\n method: string,\n resultType: K,\n args: Codec[],\n blockHash?: HexString,\n isCacheable?: boolean\n) => {\n // on a state call there are always arguments\n const registry = args[0].registry\n\n const bytes = registry.createType(\"Raw\", u8aConcatStrict(args.map((arg) => arg.toU8a())))\n\n const result = await request(\"state_call\", [method, bytes.toHex(), blockHash], isCacheable)\n\n return registry.createType(resultType, result)\n}\n","import { Metadata, TypeRegistry } from \"@polkadot/types\"\nimport type { RegistryTypes, SignerPayloadJSON } from \"@polkadot/types/types\"\n\nimport log from \"../log\"\nimport type { Chain } from \"./types\"\n\nexport const getTypeRegistry = (chain: Chain, payload: SignerPayloadJSON) => {\n log.debug(`[sapi] getTypeRegistry for payload (${chain.token.symbol})`)\n const registry = new TypeRegistry()\n\n if (chain.registryTypes) registry.register(chain.registryTypes as RegistryTypes)\n\n const meta = new Metadata(registry, chain.hexMetadata)\n registry.setMetadata(meta, payload.signedExtensions, chain.signedExtensions) // ~30ms\n\n return registry\n}\n","import type { SapiConnectorProps } from \"../types\"\n\nexport type SapiConnector = Required<SapiConnectorProps>\n\nexport const getSapiConnector = ({\n chainId,\n send,\n submit,\n submitWithBittensorMevShield,\n}: SapiConnectorProps): SapiConnector => ({\n chainId,\n send,\n submit: (...args) => {\n if (submit) return submit(...args)\n throw new Error(\"submit handler not provided\")\n },\n submitWithBittensorMevShield: (...args) => {\n if (submitWithBittensorMevShield) return submitWithBittensorMevShield(...args)\n throw new Error(\"submitWithBittensorMevShield handler not provided\")\n },\n})\n","import type { SignerPayloadJSON } from \"@polkadot/types/types\"\nimport { u8aToHex } from \"@polkadot/util\"\nimport { mergeUint8, toHex } from \"@polkadot-api/utils\"\nimport { Binary } from \"polkadot-api\"\n\nimport log from \"../log\"\nimport type { PayloadSignerConfig } from \"../types\"\nimport { getPayloadWithMetadataHash } from \"./getPayloadWithMetadataHash\"\nimport { getSendRequestResult } from \"./getSendRequestResult\"\nimport { getStorageValue } from \"./getStorageValue\"\nimport { mortal, toPjsHex } from \"./papi\"\nimport type { Chain, ChainInfo } from \"./types\"\n\nconst ERA_PERIOD = 64 // validity period in blocks, used for mortal era\n\nexport const getSignerPayloadJSON = async (\n chain: Chain,\n palletName: string,\n methodName: string,\n args: unknown,\n signerConfig: PayloadSignerConfig,\n chainInfo: ChainInfo\n): Promise<{\n payload: SignerPayloadJSON\n txMetadata: Uint8Array | undefined\n shortMetadata: `0x${string}` | undefined\n}> => {\n const { codec, location } = chain.builder.buildCall(palletName, methodName)\n const method = Binary.fromBytes(mergeUint8([new Uint8Array(location), codec.enc(args)]))\n\n // on unstable networks with lots of forks (ex: westend asset hub as of june 2025),\n // using a finalized block as reference for mortality is necessary for txs to get through\n let blockHash = await getSendRequestResult<`0x${string}`>(\n chain,\n \"chain_getFinalizedHead\",\n [],\n false\n )\n\n const [nonce, genesisHash, blockNumberFinalized, blockNumberCurrent] = await Promise.all([\n getSendRequestResult<number>(chain, \"system_accountNextIndex\", [signerConfig.address], false),\n getStorageValue<Binary>(chain, \"System\", \"BlockHash\", [0]),\n getStorageValue<number>(chain, \"System\", \"Number\", [], blockHash),\n getStorageValue<number>(chain, \"System\", \"Number\", []),\n ])\n if (!genesisHash) throw new Error(\"Genesis hash not found\")\n if (!blockHash) throw new Error(\"Block hash not found\")\n\n let blockNumber = blockNumberFinalized\n\n // on Autonomys the finalized block hash is wrong (7000 blocks behind),\n // if we use it to craft a tx it will be invalid\n // => if finalized block number is more than 32 blocks behind, use current - 16\n if (blockNumberCurrent - blockNumberFinalized > 32) {\n blockNumber = blockNumberCurrent - 16\n\n const binBlockHash = await getStorageValue<Binary>(chain, \"System\", \"BlockHash\", [blockNumber])\n blockHash = binBlockHash.asHex() as `0x${string}`\n }\n\n const era = mortal({ period: ERA_PERIOD, phase: blockNumber % ERA_PERIOD })\n // signedExtensions is keyed by extension version, 0 is the default\n const signedExtensions = (chain.metadata.extrinsic.signedExtensions[0] ?? []).map(\n (ext) => ext.identifier\n )\n\n const basePayload: SignerPayloadJSON = {\n address: signerConfig.address,\n genesisHash: genesisHash.asHex() as `0x${string}`,\n blockHash,\n method: method.asHex(),\n signedExtensions,\n nonce: toPjsHex(nonce, 4),\n specVersion: toPjsHex(chainInfo.specVersion, 4),\n transactionVersion: toPjsHex(chainInfo.transactionVersion, 4),\n blockNumber: toPjsHex(blockNumber, 4),\n era: toHex(era) as `0x${string}`,\n tip: toPjsHex(0, 16), // TODO gas station (required for Astar)\n assetId: undefined,\n version: 4,\n }\n\n const { payload, txMetadata } = getPayloadWithMetadataHash(chain, chainInfo, basePayload)\n const shortMetadata = txMetadata ? u8aToHex(txMetadata) : undefined\n\n // Avail support\n if (payload.signedExtensions.includes(\"CheckAppId\"))\n (payload as SignerPayloadJSON & { appId: number }).appId = 0\n\n log.log(\"[sapi] payload\", { newPayload: payload, txMetadata })\n\n return {\n payload,\n txMetadata, // TODO remove\n shortMetadata,\n }\n}\n","import type { SignerPayloadJSON } from \"@polkadot/types/types\"\nimport { merkleizeMetadata } from \"@polkadot-api/merkleize-metadata\"\nimport { toHex } from \"@polkadot-api/utils\"\n\nimport log from \"../log\"\nimport { getTypeRegistry } from \"./getTypeRegistry\"\nimport type { Chain, ChainInfo } from \"./types\"\n\nexport const getPayloadWithMetadataHash = (\n chain: Chain,\n chainInfo: ChainInfo,\n payload: SignerPayloadJSON\n): { payload: SignerPayloadJSON; txMetadata?: Uint8Array } => {\n if (!chain.hasCheckMetadataHash || !payload.signedExtensions.includes(\"CheckMetadataHash\"))\n return {\n payload,\n txMetadata: undefined,\n }\n\n try {\n const { decimals, symbol: tokenSymbol } = chain.token\n const { base58Prefix, specName, specVersion } = chainInfo\n const metadataHashInputs = { tokenSymbol, decimals, base58Prefix, specName, specVersion }\n\n // since ultimately this needs a V15 object, would be nice if this accepted one directly as input\n const merkleizedMetadata = merkleizeMetadata(chain.hexMetadata, metadataHashInputs)\n const metadataHash = toHex(merkleizedMetadata.digest()) as `0x${string}`\n log.log(\"metadataHash\", metadataHash, metadataHashInputs)\n\n const payloadWithMetadataHash = {\n ...payload,\n mode: 1,\n metadataHash,\n withSignedTransaction: true,\n }\n\n // TODO do this without PJS / registry => waiting for @polkadot-api/tx-utils\n // const { extra, additionalSigned } = getSignedExtensionValues(payload, metadata)\n // const badExtPayload = mergeUint8([fromHex(payload.method), ...extra, ...additionalSigned])\n\n const registry = getTypeRegistry(chain, payload)\n const extPayload = registry.createType(\"ExtrinsicPayload\", payloadWithMetadataHash)\n const barePayload = extPayload.toU8a(true)\n\n const txMetadata = merkleizedMetadata.getProofForExtrinsicPayload(barePayload)\n\n return {\n payload: payloadWithMetadataHash,\n txMetadata,\n }\n } catch (err) {\n log.error(\"Failed to get shortened metadata\", { error: err })\n return {\n payload,\n txMetadata: undefined,\n }\n }\n}\n","import { getSendRequestResult } from \"./getSendRequestResult\"\nimport type { Chain } from \"./types\"\n\nexport const getStorageValue = async <T>(\n chain: Chain,\n pallet: string,\n entry: string,\n keys: unknown[],\n at?: string\n) => {\n const storageCodec = chain.builder.buildStorage(pallet, entry)\n const stateKey = storageCodec.keys.enc(...keys)\n\n const hexValue = await getSendRequestResult<string | null>(chain, \"state_getStorage\", [\n stateKey,\n at,\n ])\n if (!hexValue) return null as T // caller will need to expect null when applicable\n\n return storageCodec.value.dec(hexValue) as T\n}\n","import { Bytes, enhanceEncoder, u16 } from \"@polkadot-api/substrate-bindings\"\n\n//////////////////////////////////////////////////////////////////////////////////////////////////////////////\n//////////////////////////// Utilities from PAPI /////////////////////////////\n//////////////////////////////////////////////////////////////////////////////////////////////////////////////\n\nexport const toPjsHex = (value: number | bigint, minByteLen?: number) => {\n let inner = value.toString(16)\n inner = (inner.length % 2 ? \"0\" : \"\") + inner\n const nPaddedBytes = Math.max(0, (minByteLen || 0) - inner.length / 2)\n return `0x${\"00\".repeat(nPaddedBytes)}${inner}` as `0x${string}`\n}\n\nexport const mortal = enhanceEncoder(Bytes(2).enc, (value: { period: number; phase: number }) => {\n const factor = Math.max(value.period >> 12, 1)\n const left = Math.min(Math.max(trailingZeroes(value.period) - 1, 1), 15)\n const right = (value.phase / factor) << 4\n return u16.enc(left | right)\n})\n\nfunction trailingZeroes(n: number) {\n let i = 0\n while (!(n & 1)) {\n i++\n n >>= 1\n }\n return i\n}\n","import { getLookupFn } from \"@polkadot-api/metadata-builders\"\n\nimport log from \"../log\"\nimport type { Chain } from \"./types\"\n\nexport const hasEvent = (chain: Chain, pallet: string, event: string): boolean => {\n try {\n const palletDef = chain.metadata.pallets.find((p) => p.name === pallet)\n if (typeof palletDef?.events !== \"number\") return false\n\n const lookup = getLookupFn(chain.metadata)\n const palletEvents = lookup(palletDef.events)\n\n return palletEvents.type === \"enum\" && event in palletEvents.innerDocs\n } catch (err) {\n log.error(\"Failed to check event existence\", { pallet, event, err })\n return false\n }\n}\n","import type { SignerPayloadJSON } from \"@polkadot/types/types\"\nimport type { ScaleApiSubmitMode } from \"../types\"\nimport type { Chain } from \"./types\"\n\nexport const submit = async (\n chain: Chain,\n payload: SignerPayloadJSON,\n signature?: `0x${string}`,\n txInfo?: unknown,\n mode?: ScaleApiSubmitMode\n): Promise<{ hash: `0x${string}`; innerHash?: `0x${string}` }> => {\n switch (mode) {\n case \"bittensor-mev-shield\":\n if (signature)\n throw new Error(\"Signature should not be provided when using bittensor-mev-shield mode\")\n return chain.connector.submitWithBittensorMevShield(payload, txInfo)\n\n default:\n return chain.connector.submit(payload, signature, txInfo)\n }\n}\n"],"mappings":"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","names":["import_scale","anylogger","import_utils","import_polkadot_api","submit","import_util","import_utils","import_polkadot_api","import_utils","import_substrate_bindings","import_metadata_builders"]}
|
|
1
|
+
{"version":3,"sources":["../src/index.ts","../src/fetchBestMetadata.ts","../src/sapi.ts","../src/log.ts","../package.json","../src/helpers/getCallDocs.ts","../src/helpers/getConstantValue.ts","../src/helpers/getChainInfo.ts","../src/helpers/getDecodedCall.ts","../src/helpers/getDecodedCallFromExtrinsic.ts","../src/helpers/getDryRunCall.ts","../src/helpers/errors.ts","../src/helpers/getRuntimeCallResult.ts","../src/helpers/getSendRequestResult.ts","../src/helpers/isApiAvailable.ts","../src/helpers/getFeeEstimate.ts","../src/helpers/getExtrinsicDispatchInfo.ts","../src/helpers/getTypeRegistry.ts","../src/helpers/getSapiConnector.ts","../src/helpers/getSignerPayloadJSON.ts","../src/helpers/getPayloadWithMetadataHash.ts","../src/helpers/getStorageValue.ts","../src/helpers/papi.ts","../src/helpers/hasEvent.ts","../src/helpers/submit.ts"],"sourcesContent":["export * from \"./fetchBestMetadata\"\nexport * from \"./sapi\"\nexport * from \"./types\"\n","import { toHex } from \"@polkadot-api/utils\"\nimport { u32, Vector } from \"scale-ts\"\n\nconst MAGIC_NUMBER = 1635018093\n\n// it's important to set a max because some chains also return high invalid version numbers in the metadata_versions list (ex on Polkadot, related to JAM?)\nexport const MAX_SUPPORTED_METADATA_VERSION = 15 // v16 sometimes outputs different metadata hashes, ignore v16 until that is fixed in PAPI\n\ntype RpcSendFunc = <T>(method: string, params: unknown[], isCacheable?: boolean) => Promise<T>\n\n/**\n * Fetches the highest supported version of metadata from the chain.\n *\n * @param rpcSend\n * @returns hex-encoded metadata starting with the magic number\n */\nexport const fetchBestMetadata = async (\n rpcSend: RpcSendFunc,\n allowLegacyFallback?: boolean\n): Promise<`0x${string}`> => {\n try {\n // fetch available versions of metadata\n const metadataVersions = await rpcSend<string>(\n \"state_call\",\n [\"Metadata_metadata_versions\", \"0x\"],\n true\n )\n const availableVersions = Vector(u32).dec(metadataVersions)\n const bestVersion = Math.max(\n ...availableVersions.filter((v) => v <= MAX_SUPPORTED_METADATA_VERSION)\n )\n\n const metadata = await rpcSend<`0x${string}`>(\n \"state_call\",\n [\"Metadata_metadata_at_version\", toHex(u32.enc(bestVersion))],\n true\n )\n\n return normalizeMetadata(metadata)\n } catch (cause) {\n // if the chain doesnt support the Metadata pallet, fallback to legacy rpc provided metadata (V14)\n const message = (cause as { message?: string })?.message\n if (\n allowLegacyFallback ||\n message?.includes(\"is not found\") || // ex: crust standalone\n message?.includes(\"Module doesn't have export Metadata_metadata_versions\") || // ex: 3DPass\n message?.includes(\"Exported method Metadata_metadata_versions is not found\") || // ex: sora-polkadot & sora-standalone\n message?.includes(\"Execution, MethodNotFound, Metadata_metadata_versions\") // ex: stafi\n ) {\n return (await rpcSend(\"state_getMetadata\", [], true)) as `0x${string}`\n }\n\n // otherwise throw so it can be handled by the caller\n throw new Error(\"Failed to fetch metadata\", { cause })\n }\n}\n\n/**\n * Removes everything before the magic number in the metadata.\n * This ensures Opaque metadata is usable by pjs\n */\nconst normalizeMetadata = (metadata: `0x${string}`): `0x${string}` => {\n const hexMagicNumber = toHex(u32.enc(MAGIC_NUMBER)).slice(2)\n\n const magicNumberIndex = metadata.indexOf(hexMagicNumber)\n if (magicNumberIndex === -1) throw new Error(\"Invalid metadata format: magic number not found\")\n\n return `0x${metadata.slice(magicNumberIndex)}` as `0x${string}`\n}\n","import type { ExtDef } from \"@polkadot/types/extrinsic/signedExtensions/types\"\nimport type { SignerPayloadJSON } from \"@polkadot/types/types\"\nimport { parseMetadataRpc } from \"@talismn/scale\"\n\nimport { getCallDocs } from \"./helpers/getCallDocs\"\nimport { getChainInfo } from \"./helpers/getChainInfo\"\nimport { getConstantValue } from \"./helpers/getConstantValue\"\nimport { getDecodedCall, getDecodedCallFromPayload } from \"./helpers/getDecodedCall\"\nimport { getDecodedCallFromExtrinsic } from \"./helpers/getDecodedCallFromExtrinsic\"\nimport { getDryRunCall } from \"./helpers/getDryRunCall\"\nimport { getFeeEstimate } from \"./helpers/getFeeEstimate\"\nimport { getRuntimeCallResult } from \"./helpers/getRuntimeCallResult\"\nimport { getSapiConnector } from \"./helpers/getSapiConnector\"\nimport { getSignerPayloadJSON } from \"./helpers/getSignerPayloadJSON\"\nimport { getStorageValue } from \"./helpers/getStorageValue\"\nimport { getTypeRegistry } from \"./helpers/getTypeRegistry\"\nimport { hasEvent } from \"./helpers/hasEvent\"\nimport { isApiAvailable } from \"./helpers/isApiAvailable\"\nimport { submit } from \"./helpers/submit\"\nimport type { Chain } from \"./helpers/types\"\nimport type {\n DecodedCall,\n PayloadSignerConfig,\n SapiConnectorProps,\n ScaleApiSubmitMode,\n} from \"./types\"\n\nexport type ScaleApi = NonNullable<ReturnType<typeof getScaleApi>>\n\nexport const getScaleApi = (\n connector: SapiConnectorProps,\n hexMetadata: `0x${string}`,\n token: { symbol: string; decimals: number },\n hasCheckMetadataHash?: boolean,\n signedExtensions?: ExtDef,\n registryTypes?: unknown\n) => {\n const { unifiedMetadata: metadata, lookupFn: lookup, builder } = parseMetadataRpc(hexMetadata)\n\n const chain: Chain = {\n connector: getSapiConnector(connector),\n hexMetadata,\n\n token,\n hasCheckMetadataHash,\n signedExtensions,\n registryTypes,\n\n metadata,\n lookup,\n builder,\n metadataRpc: hexMetadata,\n }\n\n const chainInfo = getChainInfo(chain)\n\n const { specName, specVersion, base58Prefix } = chainInfo\n\n return {\n id: `${connector.chainId}::${specName}::${specVersion}`,\n chainId: connector.chainId,\n specName,\n specVersion,\n hasCheckMetadataHash,\n base58Prefix,\n token: chain.token,\n chain,\n\n getConstant: <T>(pallet: string, constant: string) =>\n getConstantValue<T>(chain, pallet, constant),\n\n getStorage: <T>(pallet: string, entry: string, keys: unknown[], at?: string) =>\n getStorageValue<T>(chain, pallet, entry, keys, at),\n\n getDecodedCall: (pallet: string, method: string, args: unknown) =>\n getDecodedCall(pallet, method, args),\n\n getDecodedCallFromPayload: <Res extends DecodedCall>(payload: {\n method: SignerPayloadJSON[\"method\"]\n }) => getDecodedCallFromPayload<Res>(chain, payload),\n\n getDecodedCallFromExtrinsic: <Res extends DecodedCall>(extrinsicHex: `0x${string}`) =>\n getDecodedCallFromExtrinsic<Res>(chain, extrinsicHex),\n\n getExtrinsicPayload: (\n pallet: string,\n method: string,\n args: unknown,\n config: PayloadSignerConfig\n ) => getSignerPayloadJSON(chain, pallet, method, args, config, chainInfo),\n\n getFeeEstimate: (payload: SignerPayloadJSON) => getFeeEstimate(chain, payload, chainInfo),\n\n getRuntimeCallValue: <T>(apiName: string, method: string, args: unknown[]) =>\n getRuntimeCallResult<T>(chain, apiName, method, args),\n\n getTypeRegistry: (payload: SignerPayloadJSON) => getTypeRegistry(chain, payload),\n\n submit: (\n payload: SignerPayloadJSON,\n signature?: `0x${string}`,\n txInfo?: unknown,\n mode?: ScaleApiSubmitMode\n ) => submit(chain, payload, signature, txInfo, mode),\n\n getCallDocs: (pallet: string, method: string) => getCallDocs(chain, pallet, method),\n\n getDryRunCall: <T>(from: string, decodedCall: DecodedCall<unknown>) =>\n getDryRunCall<T>(chain, from, decodedCall),\n\n isApiAvailable: (name: string, method: string) => isApiAvailable(chain, name, method),\n\n hasEvent: (pallet: string, event: string) => hasEvent(chain, pallet, event),\n }\n}\n","import anylogger from \"anylogger\"\n\nimport packageJson from \"../package.json\"\n\nexport default anylogger(packageJson.name)\n","{\n \"name\": \"@talismn/sapi\",\n \"version\": \"0.1.6\",\n \"author\": \"Talisman\",\n \"homepage\": \"https://talisman.xyz\",\n \"license\": \"GPL-3.0-or-later\",\n \"publishConfig\": {\n \"access\": \"public\"\n },\n \"repository\": {\n \"directory\": \"packages/sapi\",\n \"type\": \"git\",\n \"url\": \"https://github.com/TalismanSociety/talisman.git\"\n },\n \"main\": \"./dist/index.js\",\n \"module\": \"./dist/index.mjs\",\n \"files\": [\n \"dist\"\n ],\n \"engines\": {\n \"node\": \">=20\"\n },\n \"scripts\": {\n \"test\": \"vitest run\",\n \"clean\": \"rm -rf dist .turbo node_modules\",\n \"build\": \"tsup --silent\",\n \"typecheck\": \"tsc --noEmit\"\n },\n \"dependencies\": {\n \"@polkadot-api/merkleize-metadata\": \"1.1.29\",\n \"@polkadot-api/metadata-builders\": \"0.13.9\",\n \"@polkadot-api/substrate-bindings\": \"0.17.0\",\n \"@polkadot-api/utils\": \"0.2.0\",\n \"@polkadot/types\": \"16.1.2\",\n \"@polkadot/types-codec\": \"16.1.2\",\n \"@talismn/scale\": \"workspace:*\",\n \"anylogger\": \"^1.0.11\",\n \"polkadot-api\": \"1.23.3\",\n \"scale-ts\": \"^1.6.1\"\n },\n \"devDependencies\": {\n \"@talismn/tsconfig\": \"workspace:*\",\n \"typescript\": \"^5.6.3\"\n },\n \"types\": \"./dist/index.d.ts\",\n \"exports\": {\n \".\": {\n \"@talismn/source\": \"./src/index.ts\",\n \"import\": {\n \"types\": \"./dist/index.d.mts\",\n \"default\": \"./dist/index.mjs\"\n },\n \"require\": {\n \"types\": \"./dist/index.d.ts\",\n \"default\": \"./dist/index.js\"\n }\n }\n }\n}\n","import log from \"../log\"\nimport type { Chain } from \"./types\"\n\nexport const getCallDocs = (chain: Chain, pallet: string, method: string): string | null => {\n try {\n const typeIdCalls = chain.metadata.pallets.find(({ name }) => name === pallet)?.calls?.type\n if (!typeIdCalls) return null\n\n // biome-ignore lint/suspicious/noExplicitAny: legacy\n let palletCalls: any = chain.metadata.lookup[typeIdCalls]\n if (!palletCalls || palletCalls.id !== typeIdCalls)\n palletCalls = chain.metadata.lookup.find((v) => v.id === typeIdCalls)\n\n if (!palletCalls) return null\n\n const call = palletCalls.def.value.find(\n (c: { name: string; docs?: string[] | null }) => c.name === method\n )\n\n return call?.docs?.join(\"\\n\") ?? null\n } catch {\n log.error(\"Failed to find call docs\", { pallet, method, chain })\n return null\n }\n}\n","import { getConstantValueFromMetadata } from \"@talismn/scale\"\n\nimport type { Chain } from \"./types\"\n\nexport const getConstantValue = <T>(chain: Chain, pallet: string, constant: string) => {\n return getConstantValueFromMetadata<T>(\n {\n builder: chain.builder,\n unifiedMetadata: chain.metadata,\n },\n pallet,\n constant\n )\n}\n","import { getConstantValue } from \"./getConstantValue\"\nimport type { Chain } from \"./types\"\n\ntype SystemVersion = {\n spec_name: string\n spec_version: number\n transaction_version: number\n}\n\nexport const getChainInfo = (chain: Chain) => {\n const {\n spec_name: specName,\n spec_version: specVersion,\n transaction_version: transactionVersion,\n } = getConstantValue<SystemVersion>(chain, \"System\", \"Version\")\n\n const base58Prefix = getConstantValue<number>(chain, \"System\", \"SS58Prefix\")\n\n return {\n specName,\n specVersion,\n transactionVersion,\n base58Prefix,\n }\n}\n","import type { SignerPayloadJSON } from \"@polkadot/types/types\"\n\nimport type { DecodedCall } from \"../types\"\nimport type { Chain } from \"./types\"\n\nexport const getDecodedCall = (palletName: string, methodName: string, args: unknown) => ({\n type: palletName,\n value: { type: methodName, value: args },\n})\n\nexport const getDecodedCallFromPayload = <Res extends DecodedCall>(\n chain: Chain,\n payload: { method: SignerPayloadJSON[\"method\"] }\n): Res => {\n const def = chain.builder.buildDefinition(chain.lookup.call!)\n const decoded = def.dec(payload.method)\n\n return {\n pallet: decoded.type,\n method: decoded.value.type,\n args: decoded.value.value,\n } as Res\n}\n","import {\n Bin,\n compactNumber,\n createDecoder,\n type Decoder,\n enhanceDecoder,\n extrinsicFormat,\n type StringRecord,\n Struct,\n u8,\n} from \"@polkadot-api/substrate-bindings\"\n\nimport type { DecodedCall } from \"../types\"\nimport type { Chain } from \"./types\"\n\nconst allBytesDec = Bin(Infinity).dec\n\n/**\n * Decodes a signed extrinsic and extracts the call data.\n * Handles different metadata versions (v14, v15, v16) and extrinsic formats.\n *\n * @param chain - The chain context with metadata and builder\n * @param extrinsicHex - The hex-encoded extrinsic (with 0x prefix)\n * @returns The decoded call with pallet, method, and args, or null if decoding fails\n */\nexport const getDecodedCallFromExtrinsic = <Res extends DecodedCall>(\n chain: Chain,\n extrinsicHex: `0x${string}`\n): Res | null => {\n try {\n const { metadata, builder } = chain\n\n // Build decoder for signed extensions (extra field)\n // signedExtensions is keyed by extension version, 0 is the default\n const extensionsArray = metadata.extrinsic.signedExtensions[0] ?? []\n const extraDec = Struct.dec(\n Object.fromEntries(\n extensionsArray.map((x) => [x.identifier, builder.buildDefinition(x.type)[1]])\n ) as StringRecord<Decoder<unknown>>\n )\n\n // Build call decoder\n let callDec: Decoder<{ type: string; value: { type: string; value: unknown } }>\n const { extrinsic } = metadata\n if (\"address\" in extrinsic) {\n // v15/v16 metadata\n callDec = builder.buildDefinition(extrinsic.call)[1]\n } else {\n // v14 metadata\n const params = metadata.lookup[extrinsic.type]?.params\n const callType = params?.find((v) => v.name === \"Call\")?.type\n if (callType == null) throw new Error(\"Call type not found in metadata\")\n callDec = builder.buildDefinition(callType)[1]\n }\n\n // Build address and signature decoders\n let addressDec: Decoder<unknown>\n let signatureDec: Decoder<unknown>\n if (\"address\" in extrinsic) {\n // v15/v16\n addressDec = builder.buildDefinition(extrinsic.address)[1]\n signatureDec = builder.buildDefinition(extrinsic.signature)[1]\n } else {\n // v14\n const params = metadata.lookup[extrinsic.type]?.params\n const addrType = params?.find((v) => v.name === \"Address\")?.type\n const sigType = params?.find((v) => v.name === \"Signature\")?.type\n if (addrType == null || sigType == null)\n throw new Error(\"Address or Signature type not found\")\n addressDec = builder.buildDefinition(addrType)[1]\n signatureDec = builder.buildDefinition(sigType)[1]\n }\n\n // Build full signed extrinsic body decoder\n const v4Body = Struct.dec({\n address: addressDec,\n signature: signatureDec,\n extra: extraDec,\n callData: allBytesDec,\n })\n\n // Create the full extrinsic decoder\n const extrinsicDecoder = enhanceDecoder(\n createDecoder((data) => {\n const len = compactNumber.dec(data)\n const { type, version } = extrinsicFormat[1](data)\n\n if (type === \"bare\") {\n return { len, version, type, callData: allBytesDec(data) }\n }\n if (type === \"signed\") {\n return { len, version, type, ...v4Body(data) }\n }\n\n // v5 general format\n const extensionVersion = u8.dec(data)\n const extra = extraDec(data)\n return {\n len,\n type,\n version,\n extensionVersion,\n extra,\n callData: allBytesDec(data),\n }\n }),\n (v) => ({\n ...v,\n call: callDec(v.callData.asBytes()),\n })\n )\n\n // Decode the extrinsic\n const decoded = extrinsicDecoder(extrinsicHex)\n\n return {\n pallet: decoded.call.type,\n method: decoded.call.value.type,\n args: decoded.call.value.value,\n } as Res\n } catch (err) {\n // biome-ignore lint/suspicious/noConsole: troubleshoting\n console.error(\"[SAPI] Failed to decode extrinsic:\", err)\n return null\n }\n}\n","import type { polkadot, polkadotAssetHub } from \"@polkadot-api/descriptors\"\nimport { Enum } from \"polkadot-api\"\n\nimport log from \"../log\"\nimport type { DecodedCall } from \"../types\"\nimport { getDispatchErrorMessage } from \"./errors\"\nimport { getRuntimeCallResult } from \"./getRuntimeCallResult\"\nimport { isApiAvailable } from \"./isApiAvailable\"\nimport type { Chain } from \"./types\"\n\ntype DryRunResult = (\n | typeof polkadot\n | typeof polkadotAssetHub\n)[\"descriptors\"][\"apis\"][\"DryRunApi\"][\"dry_run_call\"][1]\n\nexport const getDryRunCall = async <T>(\n chain: Chain,\n from: string,\n decodedCall: DecodedCall<unknown>\n): Promise<\n | {\n available: boolean\n data: null\n ok?: undefined\n errorMessage?: undefined\n }\n | {\n available: boolean\n data: T\n ok: boolean\n errorMessage: string | null\n }\n> => {\n try {\n if (!isApiAvailable(chain, \"DryRunApi\", \"dry_run_call\"))\n return {\n available: false,\n data: null,\n }\n\n const origin = Enum(\"system\", Enum(\"Signed\", from))\n\n const { pallet, method, args } = decodedCall\n const call = { type: pallet, value: { type: method, value: args } }\n\n // This will throw an error if the api is not available on that chain\n const data = await getRuntimeCallResult<DryRunResult>(chain, \"DryRunApi\", \"dry_run_call\", [\n origin,\n call,\n ])\n\n const ok = data.success && data.value.execution_result.success\n const errorMessage =\n data.success && !data.value.execution_result.success\n ? getDispatchErrorMessage(chain, data.value.execution_result.value.error)\n : null\n\n return {\n available: true,\n // NOTE: we can't re-export `@polkadot-api/descriptors` from this package.\n // So, the caller of this function must pass in their own instance of `type DryRunResult` as the generic argument `T`.\n data: data as T,\n ok,\n errorMessage,\n }\n } catch (err) {\n // Note : err is null if chain doesnt have the api\n log.error(\"Failed to dry run\", { chainId: chain.connector.chainId, err })\n return {\n available: false,\n data: null,\n }\n }\n}\n","import { getLookupFn } from \"@polkadot-api/metadata-builders\"\n\nimport log from \"../log\"\nimport type { Chain } from \"./types\"\n\nexport const getDispatchErrorMessage = (chain: Chain, err: unknown): string | null => {\n try {\n if (!err) return null\n\n const error = err as UnsafeDispatchError\n if (!error.type) throw new Error(\"Unknown dispatch error\")\n\n const lv1 = DISPATCH_ERROR[error.type as keyof typeof DISPATCH_ERROR]\n if (!lv1) throw new Error(\"Unknown dispatch error\")\n if (lv1 === ERROR_METADATA_LOOKUP)\n return getModuleErrorMessage(chain, error.value as UnsafeModuleError)\n if (typeof lv1 === \"string\") return lv1\n\n const lv2 = lv1[error.value?.type as keyof typeof lv1]\n if (!lv2) throw new Error(\"Unknown dispatch error\")\n if (typeof lv2 === \"string\") return lv2\n\n throw new Error(\"Unknown dispatch error\")\n } catch (cause) {\n log.error(\"Failed to parse runtime error\", { chainId: chain.connector.chainId, cause, err })\n return tryFormatError(err)\n }\n}\n\nconst ERROR_METADATA_LOOKUP = \"METADATA_LOOKUP\"\n\n// only `Module` errors are part of the metadata\n// errors below are defined as part of the runtime but their docs aren't included in the metadata\n// so those are copy/pasted from the polkadot-sdk repo\n\n// https://github.com/paritytech/polkadot-sdk/blob/56d97c3ad8c86e602bc7ac368751210517c4309f/substrate/primitives/runtime/src/lib.rs#L543\nconst ERRORS_TRANSACTIONAL = {\n LimitReached: \"Too many transactional layers have been spawned\",\n NoLayer: \"A transactional layer was expected, but does not exist\",\n}\n\n// https://github.com/paritytech/polkadot-sdk/blob/56d97c3ad8c86e602bc7ac368751210517c4309f/substrate/primitives/runtime/src/lib.rs#L672\nconst ERRORS_TOKEN = {\n FundsUnavailable: \"Funds are unavailable\",\n OnlyProvider: \"Account that must exist would die\",\n BelowMinimum: \"Account cannot exist with the funds that would be given\",\n CannotCreate: \"Account cannot be created\",\n UnknownAsset: \"The asset in question is unknown\",\n Frozen: \"Funds exist but are frozen\",\n Unsupported: \"Operation is not supported by the asset\",\n CannotCreateHold: \"Account cannot be created for recording amount on hold\",\n NotExpendable: \"Account that is desired to remain would die\",\n Blocked: \"Account cannot receive the assets\",\n}\n\n// https://github.com/paritytech/polkadot-sdk/blob/56d97c3ad8c86e602bc7ac368751210517c4309f/substrate/primitives/arithmetic/src/lib.rs#L76\nconst ERRORS_ARITHMETIC = {\n Overflow: \"An underflow would occur\",\n Underflow: \"An overflow would occur\",\n DivisionByZero: \"Division by zero\",\n}\n\n// https://github.com/paritytech/polkadot-sdk/blob/56d97c3ad8c86e602bc7ac368751210517c4309f/substrate/primitives/runtime/src/lib.rs#L714\nconst DISPATCH_ERROR = {\n CannotLookup: \"Cannot lookup\",\n BadOrigin: \"Bad origin\",\n Module: ERROR_METADATA_LOOKUP,\n ConsumerRemaining: \"Consumer remaining\",\n NoProviders: \"No providers\",\n TooManyConsumers: \"Too many consumers\",\n Token: ERRORS_TOKEN,\n Arithmetic: ERRORS_ARITHMETIC,\n Transactional: ERRORS_TRANSACTIONAL,\n Exhausted: \"Resources exhausted\",\n Corruption: \"State corrupt\",\n Unavailable: \"Resource unavailable\",\n RootNotAllowed: \"Root not allowed\",\n Trie: \"Unknown error\", // unsupported,\n Other: \"Unknown error\", // unsupported,\n}\n\ntype UnsafeDispatchError = {\n type: string\n value:\n | {\n type: string\n value:\n | {\n type: string\n value: undefined\n }\n | undefined\n }\n | undefined\n}\n\ntype UnsafeModuleError = {\n type: string\n value: {\n type: string\n value: undefined\n }\n}\n\nconst getModuleErrorMessage = (chain: Chain, error: UnsafeModuleError): string => {\n try {\n if (!chain.metadata) throw new Error(\"Could not fetch metadata\")\n\n const pallet = chain.metadata.pallets.find((p) => p.name === error.type)\n if (typeof pallet?.errors !== \"number\") throw new Error(\"Unknown pallet\")\n\n const lookup = getLookupFn(chain.metadata)\n\n const palletErrors = lookup(pallet.errors)\n if (palletErrors.type !== \"enum\" || !palletErrors.innerDocs[error.value.type]?.length)\n throw new Error(\"Unknown error type\")\n\n return palletErrors.innerDocs[error.value.type].join(\" \")\n } catch (err) {\n log.error(\"Failed to parse module error\", { chainId: chain.connector.chainId, error, err })\n return [error.type, error.value.type].join(\": \")\n }\n}\n\nconst tryFormatError = (err: unknown): string => {\n try {\n // biome-ignore lint/suspicious/noExplicitAny: legacy\n const unsafeErr = err as any\n if (unsafeErr.type && unsafeErr.value?.type)\n return [unsafeErr.type, unsafeErr.value.type].join(\": \")\n } catch {\n // ignore\n }\n\n return \"Unknown error\"\n}\n","import { toHex } from \"@polkadot-api/utils\"\n\nimport { getSendRequestResult } from \"./getSendRequestResult\"\nimport type { Chain } from \"./types\"\n\nexport const getRuntimeCallResult = async <T>(\n chain: Chain,\n apiName: string,\n method: string,\n args: unknown[]\n) => {\n const call = chain.builder.buildRuntimeCall(apiName, method)\n\n const hex = await getSendRequestResult<string>(chain, \"state_call\", [\n `${apiName}_${method}`,\n toHex(call.args.enc(args)),\n ])\n\n return call.value.dec(hex) as T\n}\n","import type { Chain } from \"./types\"\n\nexport const getSendRequestResult = <Res>(\n chain: Chain,\n method: string,\n params: unknown[],\n isCacheable?: boolean\n): Promise<Res> => {\n return chain.connector.send(method, params, isCacheable) as Promise<Res>\n}\n","import type { Chain } from \"./types\"\n\nexport const isApiAvailable = (chain: Chain, name: string, method: string) => {\n return chain.metadata.apis.some(\n (a) => a.name === name && a.methods.some((m) => m.name === method)\n )\n}\n","import type {\n IRuntimeVersionBase,\n SignatureOptions,\n SignerPayloadJSON,\n} from \"@polkadot/types/types\"\nimport { Binary } from \"polkadot-api\"\n\nimport log from \"../log\"\nimport { getExtrinsicDispatchInfo } from \"./getExtrinsicDispatchInfo\"\nimport { getRuntimeCallResult } from \"./getRuntimeCallResult\"\nimport { getTypeRegistry } from \"./getTypeRegistry\"\nimport type { Chain, ChainInfo } from \"./types\"\n\nexport const getFeeEstimate = async (\n chain: Chain,\n payload: SignerPayloadJSON,\n chainInfo: ChainInfo\n) => {\n // TODO do this without PJS / registry => waiting for @polkadot-api/tx-utils\n const registry = getTypeRegistry(chain, payload)\n const extrinsic = registry.createType(\"Extrinsic\", payload)\n\n extrinsic.signFake(payload.address, {\n appId: 0,\n nonce: payload.nonce,\n blockHash: payload.blockHash,\n genesisHash: payload.genesisHash,\n runtimeVersion: {\n specVersion: chainInfo.specVersion,\n transactionVersion: chainInfo.transactionVersion,\n // other fields aren't necessary for signing\n } as IRuntimeVersionBase,\n } as SignatureOptions)\n\n const bytes = extrinsic.toU8a(true)\n const binary = Binary.fromBytes(bytes)\n\n try {\n const result = await getRuntimeCallResult<{ partial_fee: bigint }>(\n chain,\n \"TransactionPaymentApi\",\n \"query_info\",\n [binary, bytes.length]\n )\n // Do not throw if partialFee is 0n. This is a valid response, eg: Bittensor remove_stake fee estimation is 0n.\n if (!result?.partial_fee && result.partial_fee !== 0n) {\n throw new Error(\"partialFee is not found\")\n }\n return result.partial_fee\n } catch (err) {\n log.error(\"Failed to get fee estimate using getRuntimeCallValue\", { err })\n }\n\n // fallback to pjs encoded state call, in case the above fails (extracting runtime calls codecs might require metadata V15)\n // Note: PAPI will consider TransactionPaymentApi as first class api so it should work even without V15, but this is not the case yet.\n const { partialFee } = await getExtrinsicDispatchInfo(chain, extrinsic)\n\n return BigInt(partialFee)\n}\n","import type { GenericExtrinsic } from \"@polkadot/types\"\nimport type { RuntimeDispatchInfo } from \"@polkadot/types/interfaces\"\nimport type { Codec } from \"@polkadot/types-codec/types\"\nimport { mergeUint8 } from \"@polkadot-api/utils\"\nimport type { JsonRpcRequestSend } from \"../types\"\nimport type { Chain } from \"./types\"\n\ntype ExtrinsicDispatchInfo = {\n partialFee: string\n}\n\n// used for chains that dont have metadata v15 yet\nexport const getExtrinsicDispatchInfo = async (\n chain: Chain,\n signedExtrinsic: GenericExtrinsic\n): Promise<ExtrinsicDispatchInfo> => {\n if (!signedExtrinsic.isSigned)\n throw new Error(\"Extrinsic must be signed (or fakeSigned) in order to query fee\")\n\n const len = signedExtrinsic.registry.createType(\"u32\", signedExtrinsic.encodedLength)\n\n const dispatchInfo = (await stateCall(\n chain.connector.send,\n \"TransactionPaymentApi_query_info\",\n \"RuntimeDispatchInfo\",\n [signedExtrinsic, len],\n undefined,\n true\n )) as RuntimeDispatchInfo\n\n return {\n partialFee: dispatchInfo.partialFee.toString(),\n }\n}\n\nconst stateCall = async <K extends string = string>(\n request: JsonRpcRequestSend,\n method: string,\n resultType: K,\n args: Codec[],\n blockHash?: `0x${string}`,\n isCacheable?: boolean\n) => {\n // on a state call there are always arguments\n const registry = args[0].registry\n\n const bytes = registry.createType(\"Raw\", mergeUint8(...args.map((arg) => arg.toU8a())))\n\n const result = await request(\"state_call\", [method, bytes.toHex(), blockHash], isCacheable)\n\n return registry.createType(resultType, result)\n}\n","import { Metadata, TypeRegistry } from \"@polkadot/types\"\nimport type { RegistryTypes, SignerPayloadJSON } from \"@polkadot/types/types\"\n\nimport log from \"../log\"\nimport type { Chain } from \"./types\"\n\nexport const getTypeRegistry = (chain: Chain, payload: SignerPayloadJSON) => {\n log.debug(`[sapi] getTypeRegistry for payload (${chain.token.symbol})`)\n const registry = new TypeRegistry()\n\n if (chain.registryTypes) registry.register(chain.registryTypes as RegistryTypes)\n\n const meta = new Metadata(registry, chain.hexMetadata)\n registry.setMetadata(meta, payload.signedExtensions, chain.signedExtensions) // ~30ms\n\n return registry\n}\n","import type { SapiConnectorProps } from \"../types\"\n\nexport type SapiConnector = Required<SapiConnectorProps>\n\nexport const getSapiConnector = ({\n chainId,\n send,\n submit,\n submitWithBittensorMevShield,\n}: SapiConnectorProps): SapiConnector => ({\n chainId,\n send,\n submit: (...args) => {\n if (submit) return submit(...args)\n throw new Error(\"submit handler not provided\")\n },\n submitWithBittensorMevShield: (...args) => {\n if (submitWithBittensorMevShield) return submitWithBittensorMevShield(...args)\n throw new Error(\"submitWithBittensorMevShield handler not provided\")\n },\n})\n","import type { SignerPayloadJSON } from \"@polkadot/types/types\"\nimport { mergeUint8, toHex } from \"@polkadot-api/utils\"\nimport { Binary } from \"polkadot-api\"\n\nimport log from \"../log\"\nimport type { PayloadSignerConfig } from \"../types\"\nimport { getPayloadWithMetadataHash } from \"./getPayloadWithMetadataHash\"\nimport { getSendRequestResult } from \"./getSendRequestResult\"\nimport { getStorageValue } from \"./getStorageValue\"\nimport { mortal, toPjsHex } from \"./papi\"\nimport type { Chain, ChainInfo } from \"./types\"\n\nconst ERA_PERIOD = 64 // validity period in blocks, used for mortal era\n\nexport const getSignerPayloadJSON = async (\n chain: Chain,\n palletName: string,\n methodName: string,\n args: unknown,\n signerConfig: PayloadSignerConfig,\n chainInfo: ChainInfo\n): Promise<{\n payload: SignerPayloadJSON\n txMetadata: Uint8Array | undefined\n shortMetadata: `0x${string}` | undefined\n}> => {\n const { codec, location } = chain.builder.buildCall(palletName, methodName)\n const method = Binary.fromBytes(mergeUint8([new Uint8Array(location), codec.enc(args)]))\n\n // on unstable networks with lots of forks (ex: westend asset hub as of june 2025),\n // using a finalized block as reference for mortality is necessary for txs to get through\n let blockHash = await getSendRequestResult<`0x${string}`>(\n chain,\n \"chain_getFinalizedHead\",\n [],\n false\n )\n\n const [nonce, genesisHash, blockNumberFinalized, blockNumberCurrent] = await Promise.all([\n getSendRequestResult<number>(chain, \"system_accountNextIndex\", [signerConfig.address], false),\n getStorageValue<Binary>(chain, \"System\", \"BlockHash\", [0]),\n getStorageValue<number>(chain, \"System\", \"Number\", [], blockHash),\n getStorageValue<number>(chain, \"System\", \"Number\", []),\n ])\n if (!genesisHash) throw new Error(\"Genesis hash not found\")\n if (!blockHash) throw new Error(\"Block hash not found\")\n\n let blockNumber = blockNumberFinalized\n\n // on Autonomys the finalized block hash is wrong (7000 blocks behind),\n // if we use it to craft a tx it will be invalid\n // => if finalized block number is more than 32 blocks behind, use current - 16\n if (blockNumberCurrent - blockNumberFinalized > 32) {\n blockNumber = blockNumberCurrent - 16\n\n const binBlockHash = await getStorageValue<Binary>(chain, \"System\", \"BlockHash\", [blockNumber])\n blockHash = binBlockHash.asHex() as `0x${string}`\n }\n\n const era = mortal({ period: ERA_PERIOD, phase: blockNumber % ERA_PERIOD })\n // signedExtensions is keyed by extension version, 0 is the default\n const signedExtensions = (chain.metadata.extrinsic.signedExtensions[0] ?? []).map(\n (ext) => ext.identifier\n )\n\n const basePayload: SignerPayloadJSON = {\n address: signerConfig.address,\n genesisHash: genesisHash.asHex() as `0x${string}`,\n blockHash,\n method: method.asHex(),\n signedExtensions,\n nonce: toPjsHex(nonce, 4),\n specVersion: toPjsHex(chainInfo.specVersion, 4),\n transactionVersion: toPjsHex(chainInfo.transactionVersion, 4),\n blockNumber: toPjsHex(blockNumber, 4),\n era: toHex(era) as `0x${string}`,\n tip: toPjsHex(0, 16), // TODO gas station (required for Astar)\n assetId: undefined,\n version: 4,\n }\n\n const { payload, txMetadata } = getPayloadWithMetadataHash(chain, chainInfo, basePayload)\n const shortMetadata = txMetadata ? (toHex(txMetadata) as `0x${string}`) : undefined\n\n // Avail support\n if (payload.signedExtensions.includes(\"CheckAppId\"))\n (payload as SignerPayloadJSON & { appId: number }).appId = 0\n\n log.log(\"[sapi] payload\", { newPayload: payload, txMetadata })\n\n return {\n payload,\n txMetadata, // TODO remove\n shortMetadata,\n }\n}\n","import type { SignerPayloadJSON } from \"@polkadot/types/types\"\nimport { merkleizeMetadata } from \"@polkadot-api/merkleize-metadata\"\nimport { toHex } from \"@polkadot-api/utils\"\n\nimport log from \"../log\"\nimport { getTypeRegistry } from \"./getTypeRegistry\"\nimport type { Chain, ChainInfo } from \"./types\"\n\nexport const getPayloadWithMetadataHash = (\n chain: Chain,\n chainInfo: ChainInfo,\n payload: SignerPayloadJSON\n): { payload: SignerPayloadJSON; txMetadata?: Uint8Array } => {\n if (!chain.hasCheckMetadataHash || !payload.signedExtensions.includes(\"CheckMetadataHash\"))\n return {\n payload,\n txMetadata: undefined,\n }\n\n try {\n const { decimals, symbol: tokenSymbol } = chain.token\n const { base58Prefix, specName, specVersion } = chainInfo\n const metadataHashInputs = { tokenSymbol, decimals, base58Prefix, specName, specVersion }\n\n // since ultimately this needs a V15 object, would be nice if this accepted one directly as input\n const merkleizedMetadata = merkleizeMetadata(chain.hexMetadata, metadataHashInputs)\n const metadataHash = toHex(merkleizedMetadata.digest()) as `0x${string}`\n log.log(\"metadataHash\", metadataHash, metadataHashInputs)\n\n const payloadWithMetadataHash = {\n ...payload,\n mode: 1,\n metadataHash,\n withSignedTransaction: true,\n }\n\n // TODO do this without PJS / registry => waiting for @polkadot-api/tx-utils\n // const { extra, additionalSigned } = getSignedExtensionValues(payload, metadata)\n // const badExtPayload = mergeUint8([fromHex(payload.method), ...extra, ...additionalSigned])\n\n const registry = getTypeRegistry(chain, payload)\n const extPayload = registry.createType(\"ExtrinsicPayload\", payloadWithMetadataHash)\n const barePayload = extPayload.toU8a(true)\n\n const txMetadata = merkleizedMetadata.getProofForExtrinsicPayload(barePayload)\n\n return {\n payload: payloadWithMetadataHash,\n txMetadata,\n }\n } catch (err) {\n log.error(\"Failed to get shortened metadata\", { error: err })\n return {\n payload,\n txMetadata: undefined,\n }\n }\n}\n","import { getSendRequestResult } from \"./getSendRequestResult\"\nimport type { Chain } from \"./types\"\n\nexport const getStorageValue = async <T>(\n chain: Chain,\n pallet: string,\n entry: string,\n keys: unknown[],\n at?: string\n) => {\n const storageCodec = chain.builder.buildStorage(pallet, entry)\n const stateKey = storageCodec.keys.enc(...keys)\n\n const hexValue = await getSendRequestResult<string | null>(chain, \"state_getStorage\", [\n stateKey,\n at,\n ])\n if (!hexValue) return null as T // caller will need to expect null when applicable\n\n return storageCodec.value.dec(hexValue) as T\n}\n","import { Bytes, enhanceEncoder, u16 } from \"@polkadot-api/substrate-bindings\"\n\n//////////////////////////////////////////////////////////////////////////////////////////////////////////////\n//////////////////////////// Utilities from PAPI /////////////////////////////\n//////////////////////////////////////////////////////////////////////////////////////////////////////////////\n\nexport const toPjsHex = (value: number | bigint, minByteLen?: number) => {\n let inner = value.toString(16)\n inner = (inner.length % 2 ? \"0\" : \"\") + inner\n const nPaddedBytes = Math.max(0, (minByteLen || 0) - inner.length / 2)\n return `0x${\"00\".repeat(nPaddedBytes)}${inner}` as `0x${string}`\n}\n\nexport const mortal = enhanceEncoder(Bytes(2).enc, (value: { period: number; phase: number }) => {\n const factor = Math.max(value.period >> 12, 1)\n const left = Math.min(Math.max(trailingZeroes(value.period) - 1, 1), 15)\n const right = (value.phase / factor) << 4\n return u16.enc(left | right)\n})\n\nfunction trailingZeroes(n: number) {\n let i = 0\n while (!(n & 1)) {\n i++\n n >>= 1\n }\n return i\n}\n","import { getLookupFn } from \"@polkadot-api/metadata-builders\"\n\nimport log from \"../log\"\nimport type { Chain } from \"./types\"\n\nexport const hasEvent = (chain: Chain, pallet: string, event: string): boolean => {\n try {\n const palletDef = chain.metadata.pallets.find((p) => p.name === pallet)\n if (typeof palletDef?.events !== \"number\") return false\n\n const lookup = getLookupFn(chain.metadata)\n const palletEvents = lookup(palletDef.events)\n\n return palletEvents.type === \"enum\" && event in palletEvents.innerDocs\n } catch (err) {\n log.error(\"Failed to check event existence\", { pallet, event, err })\n return false\n }\n}\n","import type { SignerPayloadJSON } from \"@polkadot/types/types\"\nimport type { ScaleApiSubmitMode } from \"../types\"\nimport type { Chain } from \"./types\"\n\nexport const submit = async (\n chain: Chain,\n payload: SignerPayloadJSON,\n signature?: `0x${string}`,\n txInfo?: unknown,\n mode?: ScaleApiSubmitMode\n): Promise<{ hash: `0x${string}`; innerHash?: `0x${string}` }> => {\n switch (mode) {\n case \"bittensor-mev-shield\":\n if (signature)\n throw new Error(\"Signature should not be provided when using bittensor-mev-shield mode\")\n return chain.connector.submitWithBittensorMevShield(payload, txInfo)\n\n default:\n return chain.connector.submit(payload, signature, txInfo)\n }\n}\n"],"mappings":"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","names":["import_scale","anylogger","import_utils","import_polkadot_api","import_utils","submit","import_utils","import_polkadot_api","import_utils","import_substrate_bindings","import_metadata_builders"]}
|
package/dist/index.mjs
CHANGED
|
@@ -47,7 +47,7 @@ import anylogger from "anylogger";
|
|
|
47
47
|
// package.json
|
|
48
48
|
var package_default = {
|
|
49
49
|
name: "@talismn/sapi",
|
|
50
|
-
version: "0.1.
|
|
50
|
+
version: "0.1.6",
|
|
51
51
|
author: "Talisman",
|
|
52
52
|
homepage: "https://talisman.xyz",
|
|
53
53
|
license: "GPL-3.0-or-later",
|
|
@@ -80,7 +80,6 @@ var package_default = {
|
|
|
80
80
|
"@polkadot-api/utils": "0.2.0",
|
|
81
81
|
"@polkadot/types": "16.1.2",
|
|
82
82
|
"@polkadot/types-codec": "16.1.2",
|
|
83
|
-
"@polkadot/util": "13.5.3",
|
|
84
83
|
"@talismn/scale": "workspace:*",
|
|
85
84
|
anylogger: "^1.0.11",
|
|
86
85
|
"polkadot-api": "1.23.3",
|
|
@@ -413,9 +412,10 @@ var getDryRunCall = async (chain, from, decodedCall) => {
|
|
|
413
412
|
import { Binary } from "polkadot-api";
|
|
414
413
|
|
|
415
414
|
// src/helpers/getExtrinsicDispatchInfo.ts
|
|
416
|
-
import {
|
|
415
|
+
import { mergeUint8 } from "@polkadot-api/utils";
|
|
417
416
|
var getExtrinsicDispatchInfo = async (chain, signedExtrinsic) => {
|
|
418
|
-
|
|
417
|
+
if (!signedExtrinsic.isSigned)
|
|
418
|
+
throw new Error("Extrinsic must be signed (or fakeSigned) in order to query fee");
|
|
419
419
|
const len = signedExtrinsic.registry.createType("u32", signedExtrinsic.encodedLength);
|
|
420
420
|
const dispatchInfo = await stateCall(
|
|
421
421
|
chain.connector.send,
|
|
@@ -431,7 +431,7 @@ var getExtrinsicDispatchInfo = async (chain, signedExtrinsic) => {
|
|
|
431
431
|
};
|
|
432
432
|
var stateCall = async (request, method, resultType, args, blockHash, isCacheable) => {
|
|
433
433
|
const registry = args[0].registry;
|
|
434
|
-
const bytes = registry.createType("Raw",
|
|
434
|
+
const bytes = registry.createType("Raw", mergeUint8(...args.map((arg) => arg.toU8a())));
|
|
435
435
|
const result = await request("state_call", [method, bytes.toHex(), blockHash], isCacheable);
|
|
436
436
|
return registry.createType(resultType, result);
|
|
437
437
|
};
|
|
@@ -502,8 +502,7 @@ var getSapiConnector = ({
|
|
|
502
502
|
});
|
|
503
503
|
|
|
504
504
|
// src/helpers/getSignerPayloadJSON.ts
|
|
505
|
-
import {
|
|
506
|
-
import { mergeUint8, toHex as toHex4 } from "@polkadot-api/utils";
|
|
505
|
+
import { mergeUint8 as mergeUint82, toHex as toHex4 } from "@polkadot-api/utils";
|
|
507
506
|
import { Binary as Binary2 } from "polkadot-api";
|
|
508
507
|
|
|
509
508
|
// src/helpers/getPayloadWithMetadataHash.ts
|
|
@@ -584,7 +583,7 @@ function trailingZeroes(n) {
|
|
|
584
583
|
var ERA_PERIOD = 64;
|
|
585
584
|
var getSignerPayloadJSON = async (chain, palletName, methodName, args, signerConfig, chainInfo) => {
|
|
586
585
|
const { codec, location } = chain.builder.buildCall(palletName, methodName);
|
|
587
|
-
const method = Binary2.fromBytes(
|
|
586
|
+
const method = Binary2.fromBytes(mergeUint82([new Uint8Array(location), codec.enc(args)]));
|
|
588
587
|
let blockHash = await getSendRequestResult(
|
|
589
588
|
chain,
|
|
590
589
|
"chain_getFinalizedHead",
|
|
@@ -626,7 +625,7 @@ var getSignerPayloadJSON = async (chain, palletName, methodName, args, signerCon
|
|
|
626
625
|
version: 4
|
|
627
626
|
};
|
|
628
627
|
const { payload, txMetadata } = getPayloadWithMetadataHash(chain, chainInfo, basePayload);
|
|
629
|
-
const shortMetadata = txMetadata ?
|
|
628
|
+
const shortMetadata = txMetadata ? toHex4(txMetadata) : void 0;
|
|
630
629
|
if (payload.signedExtensions.includes("CheckAppId"))
|
|
631
630
|
payload.appId = 0;
|
|
632
631
|
log_default.log("[sapi] payload", { newPayload: payload, txMetadata });
|
package/dist/index.mjs.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["../src/fetchBestMetadata.ts","../src/sapi.ts","../src/log.ts","../package.json","../src/helpers/getCallDocs.ts","../src/helpers/getConstantValue.ts","../src/helpers/getChainInfo.ts","../src/helpers/getDecodedCall.ts","../src/helpers/getDecodedCallFromExtrinsic.ts","../src/helpers/getDryRunCall.ts","../src/helpers/errors.ts","../src/helpers/getRuntimeCallResult.ts","../src/helpers/getSendRequestResult.ts","../src/helpers/isApiAvailable.ts","../src/helpers/getFeeEstimate.ts","../src/helpers/getExtrinsicDispatchInfo.ts","../src/helpers/getTypeRegistry.ts","../src/helpers/getSapiConnector.ts","../src/helpers/getSignerPayloadJSON.ts","../src/helpers/getPayloadWithMetadataHash.ts","../src/helpers/getStorageValue.ts","../src/helpers/papi.ts","../src/helpers/hasEvent.ts","../src/helpers/submit.ts"],"sourcesContent":["import { toHex } from \"@polkadot-api/utils\"\nimport { u32, Vector } from \"scale-ts\"\n\nconst MAGIC_NUMBER = 1635018093\n\n// it's important to set a max because some chains also return high invalid version numbers in the metadata_versions list (ex on Polkadot, related to JAM?)\nexport const MAX_SUPPORTED_METADATA_VERSION = 15 // v16 sometimes outputs different metadata hashes, ignore v16 until that is fixed in PAPI\n\ntype RpcSendFunc = <T>(method: string, params: unknown[], isCacheable?: boolean) => Promise<T>\n\n/**\n * Fetches the highest supported version of metadata from the chain.\n *\n * @param rpcSend\n * @returns hex-encoded metadata starting with the magic number\n */\nexport const fetchBestMetadata = async (\n rpcSend: RpcSendFunc,\n allowLegacyFallback?: boolean\n): Promise<`0x${string}`> => {\n try {\n // fetch available versions of metadata\n const metadataVersions = await rpcSend<string>(\n \"state_call\",\n [\"Metadata_metadata_versions\", \"0x\"],\n true\n )\n const availableVersions = Vector(u32).dec(metadataVersions)\n const bestVersion = Math.max(\n ...availableVersions.filter((v) => v <= MAX_SUPPORTED_METADATA_VERSION)\n )\n\n const metadata = await rpcSend<`0x${string}`>(\n \"state_call\",\n [\"Metadata_metadata_at_version\", toHex(u32.enc(bestVersion))],\n true\n )\n\n return normalizeMetadata(metadata)\n } catch (cause) {\n // if the chain doesnt support the Metadata pallet, fallback to legacy rpc provided metadata (V14)\n const message = (cause as { message?: string })?.message\n if (\n allowLegacyFallback ||\n message?.includes(\"is not found\") || // ex: crust standalone\n message?.includes(\"Module doesn't have export Metadata_metadata_versions\") || // ex: 3DPass\n message?.includes(\"Exported method Metadata_metadata_versions is not found\") || // ex: sora-polkadot & sora-standalone\n message?.includes(\"Execution, MethodNotFound, Metadata_metadata_versions\") // ex: stafi\n ) {\n return (await rpcSend(\"state_getMetadata\", [], true)) as `0x${string}`\n }\n\n // otherwise throw so it can be handled by the caller\n throw new Error(\"Failed to fetch metadata\", { cause })\n }\n}\n\n/**\n * Removes everything before the magic number in the metadata.\n * This ensures Opaque metadata is usable by pjs\n */\nconst normalizeMetadata = (metadata: `0x${string}`): `0x${string}` => {\n const hexMagicNumber = toHex(u32.enc(MAGIC_NUMBER)).slice(2)\n\n const magicNumberIndex = metadata.indexOf(hexMagicNumber)\n if (magicNumberIndex === -1) throw new Error(\"Invalid metadata format: magic number not found\")\n\n return `0x${metadata.slice(magicNumberIndex)}` as `0x${string}`\n}\n","import type { ExtDef } from \"@polkadot/types/extrinsic/signedExtensions/types\"\nimport type { SignerPayloadJSON } from \"@polkadot/types/types\"\nimport { parseMetadataRpc } from \"@talismn/scale\"\n\nimport { getCallDocs } from \"./helpers/getCallDocs\"\nimport { getChainInfo } from \"./helpers/getChainInfo\"\nimport { getConstantValue } from \"./helpers/getConstantValue\"\nimport { getDecodedCall, getDecodedCallFromPayload } from \"./helpers/getDecodedCall\"\nimport { getDecodedCallFromExtrinsic } from \"./helpers/getDecodedCallFromExtrinsic\"\nimport { getDryRunCall } from \"./helpers/getDryRunCall\"\nimport { getFeeEstimate } from \"./helpers/getFeeEstimate\"\nimport { getRuntimeCallResult } from \"./helpers/getRuntimeCallResult\"\nimport { getSapiConnector } from \"./helpers/getSapiConnector\"\nimport { getSignerPayloadJSON } from \"./helpers/getSignerPayloadJSON\"\nimport { getStorageValue } from \"./helpers/getStorageValue\"\nimport { getTypeRegistry } from \"./helpers/getTypeRegistry\"\nimport { hasEvent } from \"./helpers/hasEvent\"\nimport { isApiAvailable } from \"./helpers/isApiAvailable\"\nimport { submit } from \"./helpers/submit\"\nimport type { Chain } from \"./helpers/types\"\nimport type {\n DecodedCall,\n PayloadSignerConfig,\n SapiConnectorProps,\n ScaleApiSubmitMode,\n} from \"./types\"\n\nexport type ScaleApi = NonNullable<ReturnType<typeof getScaleApi>>\n\nexport const getScaleApi = (\n connector: SapiConnectorProps,\n hexMetadata: `0x${string}`,\n token: { symbol: string; decimals: number },\n hasCheckMetadataHash?: boolean,\n signedExtensions?: ExtDef,\n registryTypes?: unknown\n) => {\n const { unifiedMetadata: metadata, lookupFn: lookup, builder } = parseMetadataRpc(hexMetadata)\n\n const chain: Chain = {\n connector: getSapiConnector(connector),\n hexMetadata,\n\n token,\n hasCheckMetadataHash,\n signedExtensions,\n registryTypes,\n\n metadata,\n lookup,\n builder,\n metadataRpc: hexMetadata,\n }\n\n const chainInfo = getChainInfo(chain)\n\n const { specName, specVersion, base58Prefix } = chainInfo\n\n return {\n id: `${connector.chainId}::${specName}::${specVersion}`,\n chainId: connector.chainId,\n specName,\n specVersion,\n hasCheckMetadataHash,\n base58Prefix,\n token: chain.token,\n chain,\n\n getConstant: <T>(pallet: string, constant: string) =>\n getConstantValue<T>(chain, pallet, constant),\n\n getStorage: <T>(pallet: string, entry: string, keys: unknown[], at?: string) =>\n getStorageValue<T>(chain, pallet, entry, keys, at),\n\n getDecodedCall: (pallet: string, method: string, args: unknown) =>\n getDecodedCall(pallet, method, args),\n\n getDecodedCallFromPayload: <Res extends DecodedCall>(payload: {\n method: SignerPayloadJSON[\"method\"]\n }) => getDecodedCallFromPayload<Res>(chain, payload),\n\n getDecodedCallFromExtrinsic: <Res extends DecodedCall>(extrinsicHex: `0x${string}`) =>\n getDecodedCallFromExtrinsic<Res>(chain, extrinsicHex),\n\n getExtrinsicPayload: (\n pallet: string,\n method: string,\n args: unknown,\n config: PayloadSignerConfig\n ) => getSignerPayloadJSON(chain, pallet, method, args, config, chainInfo),\n\n getFeeEstimate: (payload: SignerPayloadJSON) => getFeeEstimate(chain, payload, chainInfo),\n\n getRuntimeCallValue: <T>(apiName: string, method: string, args: unknown[]) =>\n getRuntimeCallResult<T>(chain, apiName, method, args),\n\n getTypeRegistry: (payload: SignerPayloadJSON) => getTypeRegistry(chain, payload),\n\n submit: (\n payload: SignerPayloadJSON,\n signature?: `0x${string}`,\n txInfo?: unknown,\n mode?: ScaleApiSubmitMode\n ) => submit(chain, payload, signature, txInfo, mode),\n\n getCallDocs: (pallet: string, method: string) => getCallDocs(chain, pallet, method),\n\n getDryRunCall: <T>(from: string, decodedCall: DecodedCall<unknown>) =>\n getDryRunCall<T>(chain, from, decodedCall),\n\n isApiAvailable: (name: string, method: string) => isApiAvailable(chain, name, method),\n\n hasEvent: (pallet: string, event: string) => hasEvent(chain, pallet, event),\n }\n}\n","import anylogger from \"anylogger\"\n\nimport packageJson from \"../package.json\"\n\nexport default anylogger(packageJson.name)\n","{\n \"name\": \"@talismn/sapi\",\n \"version\": \"0.1.5\",\n \"author\": \"Talisman\",\n \"homepage\": \"https://talisman.xyz\",\n \"license\": \"GPL-3.0-or-later\",\n \"publishConfig\": {\n \"access\": \"public\"\n },\n \"repository\": {\n \"directory\": \"packages/sapi\",\n \"type\": \"git\",\n \"url\": \"https://github.com/TalismanSociety/talisman.git\"\n },\n \"main\": \"./dist/index.js\",\n \"module\": \"./dist/index.mjs\",\n \"files\": [\n \"dist\"\n ],\n \"engines\": {\n \"node\": \">=20\"\n },\n \"scripts\": {\n \"test\": \"vitest run\",\n \"clean\": \"rm -rf dist .turbo node_modules\",\n \"build\": \"tsup --silent\",\n \"typecheck\": \"tsc --noEmit\"\n },\n \"dependencies\": {\n \"@polkadot-api/merkleize-metadata\": \"1.1.29\",\n \"@polkadot-api/metadata-builders\": \"0.13.9\",\n \"@polkadot-api/substrate-bindings\": \"0.17.0\",\n \"@polkadot-api/utils\": \"0.2.0\",\n \"@polkadot/types\": \"16.1.2\",\n \"@polkadot/types-codec\": \"16.1.2\",\n \"@polkadot/util\": \"13.5.3\",\n \"@talismn/scale\": \"workspace:*\",\n \"anylogger\": \"^1.0.11\",\n \"polkadot-api\": \"1.23.3\",\n \"scale-ts\": \"^1.6.1\"\n },\n \"devDependencies\": {\n \"@talismn/tsconfig\": \"workspace:*\",\n \"typescript\": \"^5.6.3\"\n },\n \"types\": \"./dist/index.d.ts\",\n \"exports\": {\n \".\": {\n \"@talismn/source\": \"./src/index.ts\",\n \"import\": {\n \"types\": \"./dist/index.d.mts\",\n \"default\": \"./dist/index.mjs\"\n },\n \"require\": {\n \"types\": \"./dist/index.d.ts\",\n \"default\": \"./dist/index.js\"\n }\n }\n }\n}\n","import log from \"../log\"\nimport type { Chain } from \"./types\"\n\nexport const getCallDocs = (chain: Chain, pallet: string, method: string): string | null => {\n try {\n const typeIdCalls = chain.metadata.pallets.find(({ name }) => name === pallet)?.calls?.type\n if (!typeIdCalls) return null\n\n // biome-ignore lint/suspicious/noExplicitAny: legacy\n let palletCalls: any = chain.metadata.lookup[typeIdCalls]\n if (!palletCalls || palletCalls.id !== typeIdCalls)\n palletCalls = chain.metadata.lookup.find((v) => v.id === typeIdCalls)\n\n if (!palletCalls) return null\n\n const call = palletCalls.def.value.find(\n (c: { name: string; docs?: string[] | null }) => c.name === method\n )\n\n return call?.docs?.join(\"\\n\") ?? null\n } catch {\n log.error(\"Failed to find call docs\", { pallet, method, chain })\n return null\n }\n}\n","import { getConstantValueFromMetadata } from \"@talismn/scale\"\n\nimport type { Chain } from \"./types\"\n\nexport const getConstantValue = <T>(chain: Chain, pallet: string, constant: string) => {\n return getConstantValueFromMetadata<T>(\n {\n builder: chain.builder,\n unifiedMetadata: chain.metadata,\n },\n pallet,\n constant\n )\n}\n","import { getConstantValue } from \"./getConstantValue\"\nimport type { Chain } from \"./types\"\n\ntype SystemVersion = {\n spec_name: string\n spec_version: number\n transaction_version: number\n}\n\nexport const getChainInfo = (chain: Chain) => {\n const {\n spec_name: specName,\n spec_version: specVersion,\n transaction_version: transactionVersion,\n } = getConstantValue<SystemVersion>(chain, \"System\", \"Version\")\n\n const base58Prefix = getConstantValue<number>(chain, \"System\", \"SS58Prefix\")\n\n return {\n specName,\n specVersion,\n transactionVersion,\n base58Prefix,\n }\n}\n","import type { SignerPayloadJSON } from \"@polkadot/types/types\"\n\nimport type { DecodedCall } from \"../types\"\nimport type { Chain } from \"./types\"\n\nexport const getDecodedCall = (palletName: string, methodName: string, args: unknown) => ({\n type: palletName,\n value: { type: methodName, value: args },\n})\n\nexport const getDecodedCallFromPayload = <Res extends DecodedCall>(\n chain: Chain,\n payload: { method: SignerPayloadJSON[\"method\"] }\n): Res => {\n const def = chain.builder.buildDefinition(chain.lookup.call!)\n const decoded = def.dec(payload.method)\n\n return {\n pallet: decoded.type,\n method: decoded.value.type,\n args: decoded.value.value,\n } as Res\n}\n","import {\n Bin,\n compactNumber,\n createDecoder,\n type Decoder,\n enhanceDecoder,\n extrinsicFormat,\n type StringRecord,\n Struct,\n u8,\n} from \"@polkadot-api/substrate-bindings\"\n\nimport type { DecodedCall } from \"../types\"\nimport type { Chain } from \"./types\"\n\nconst allBytesDec = Bin(Infinity).dec\n\n/**\n * Decodes a signed extrinsic and extracts the call data.\n * Handles different metadata versions (v14, v15, v16) and extrinsic formats.\n *\n * @param chain - The chain context with metadata and builder\n * @param extrinsicHex - The hex-encoded extrinsic (with 0x prefix)\n * @returns The decoded call with pallet, method, and args, or null if decoding fails\n */\nexport const getDecodedCallFromExtrinsic = <Res extends DecodedCall>(\n chain: Chain,\n extrinsicHex: `0x${string}`\n): Res | null => {\n try {\n const { metadata, builder } = chain\n\n // Build decoder for signed extensions (extra field)\n // signedExtensions is keyed by extension version, 0 is the default\n const extensionsArray = metadata.extrinsic.signedExtensions[0] ?? []\n const extraDec = Struct.dec(\n Object.fromEntries(\n extensionsArray.map((x) => [x.identifier, builder.buildDefinition(x.type)[1]])\n ) as StringRecord<Decoder<unknown>>\n )\n\n // Build call decoder\n let callDec: Decoder<{ type: string; value: { type: string; value: unknown } }>\n const { extrinsic } = metadata\n if (\"address\" in extrinsic) {\n // v15/v16 metadata\n callDec = builder.buildDefinition(extrinsic.call)[1]\n } else {\n // v14 metadata\n const params = metadata.lookup[extrinsic.type]?.params\n const callType = params?.find((v) => v.name === \"Call\")?.type\n if (callType == null) throw new Error(\"Call type not found in metadata\")\n callDec = builder.buildDefinition(callType)[1]\n }\n\n // Build address and signature decoders\n let addressDec: Decoder<unknown>\n let signatureDec: Decoder<unknown>\n if (\"address\" in extrinsic) {\n // v15/v16\n addressDec = builder.buildDefinition(extrinsic.address)[1]\n signatureDec = builder.buildDefinition(extrinsic.signature)[1]\n } else {\n // v14\n const params = metadata.lookup[extrinsic.type]?.params\n const addrType = params?.find((v) => v.name === \"Address\")?.type\n const sigType = params?.find((v) => v.name === \"Signature\")?.type\n if (addrType == null || sigType == null)\n throw new Error(\"Address or Signature type not found\")\n addressDec = builder.buildDefinition(addrType)[1]\n signatureDec = builder.buildDefinition(sigType)[1]\n }\n\n // Build full signed extrinsic body decoder\n const v4Body = Struct.dec({\n address: addressDec,\n signature: signatureDec,\n extra: extraDec,\n callData: allBytesDec,\n })\n\n // Create the full extrinsic decoder\n const extrinsicDecoder = enhanceDecoder(\n createDecoder((data) => {\n const len = compactNumber.dec(data)\n const { type, version } = extrinsicFormat[1](data)\n\n if (type === \"bare\") {\n return { len, version, type, callData: allBytesDec(data) }\n }\n if (type === \"signed\") {\n return { len, version, type, ...v4Body(data) }\n }\n\n // v5 general format\n const extensionVersion = u8.dec(data)\n const extra = extraDec(data)\n return {\n len,\n type,\n version,\n extensionVersion,\n extra,\n callData: allBytesDec(data),\n }\n }),\n (v) => ({\n ...v,\n call: callDec(v.callData.asBytes()),\n })\n )\n\n // Decode the extrinsic\n const decoded = extrinsicDecoder(extrinsicHex)\n\n return {\n pallet: decoded.call.type,\n method: decoded.call.value.type,\n args: decoded.call.value.value,\n } as Res\n } catch (err) {\n // biome-ignore lint/suspicious/noConsole: troubleshoting\n console.error(\"[SAPI] Failed to decode extrinsic:\", err)\n return null\n }\n}\n","import type { polkadot, polkadotAssetHub } from \"@polkadot-api/descriptors\"\nimport { Enum } from \"polkadot-api\"\n\nimport log from \"../log\"\nimport type { DecodedCall } from \"../types\"\nimport { getDispatchErrorMessage } from \"./errors\"\nimport { getRuntimeCallResult } from \"./getRuntimeCallResult\"\nimport { isApiAvailable } from \"./isApiAvailable\"\nimport type { Chain } from \"./types\"\n\ntype DryRunResult = (\n | typeof polkadot\n | typeof polkadotAssetHub\n)[\"descriptors\"][\"apis\"][\"DryRunApi\"][\"dry_run_call\"][1]\n\nexport const getDryRunCall = async <T>(\n chain: Chain,\n from: string,\n decodedCall: DecodedCall<unknown>\n): Promise<\n | {\n available: boolean\n data: null\n ok?: undefined\n errorMessage?: undefined\n }\n | {\n available: boolean\n data: T\n ok: boolean\n errorMessage: string | null\n }\n> => {\n try {\n if (!isApiAvailable(chain, \"DryRunApi\", \"dry_run_call\"))\n return {\n available: false,\n data: null,\n }\n\n const origin = Enum(\"system\", Enum(\"Signed\", from))\n\n const { pallet, method, args } = decodedCall\n const call = { type: pallet, value: { type: method, value: args } }\n\n // This will throw an error if the api is not available on that chain\n const data = await getRuntimeCallResult<DryRunResult>(chain, \"DryRunApi\", \"dry_run_call\", [\n origin,\n call,\n ])\n\n const ok = data.success && data.value.execution_result.success\n const errorMessage =\n data.success && !data.value.execution_result.success\n ? getDispatchErrorMessage(chain, data.value.execution_result.value.error)\n : null\n\n return {\n available: true,\n // NOTE: we can't re-export `@polkadot-api/descriptors` from this package.\n // So, the caller of this function must pass in their own instance of `type DryRunResult` as the generic argument `T`.\n data: data as T,\n ok,\n errorMessage,\n }\n } catch (err) {\n // Note : err is null if chain doesnt have the api\n log.error(\"Failed to dry run\", { chainId: chain.connector.chainId, err })\n return {\n available: false,\n data: null,\n }\n }\n}\n","import { getLookupFn } from \"@polkadot-api/metadata-builders\"\n\nimport log from \"../log\"\nimport type { Chain } from \"./types\"\n\nexport const getDispatchErrorMessage = (chain: Chain, err: unknown): string | null => {\n try {\n if (!err) return null\n\n const error = err as UnsafeDispatchError\n if (!error.type) throw new Error(\"Unknown dispatch error\")\n\n const lv1 = DISPATCH_ERROR[error.type as keyof typeof DISPATCH_ERROR]\n if (!lv1) throw new Error(\"Unknown dispatch error\")\n if (lv1 === ERROR_METADATA_LOOKUP)\n return getModuleErrorMessage(chain, error.value as UnsafeModuleError)\n if (typeof lv1 === \"string\") return lv1\n\n const lv2 = lv1[error.value?.type as keyof typeof lv1]\n if (!lv2) throw new Error(\"Unknown dispatch error\")\n if (typeof lv2 === \"string\") return lv2\n\n throw new Error(\"Unknown dispatch error\")\n } catch (cause) {\n log.error(\"Failed to parse runtime error\", { chainId: chain.connector.chainId, cause, err })\n return tryFormatError(err)\n }\n}\n\nconst ERROR_METADATA_LOOKUP = \"METADATA_LOOKUP\"\n\n// only `Module` errors are part of the metadata\n// errors below are defined as part of the runtime but their docs aren't included in the metadata\n// so those are copy/pasted from the polkadot-sdk repo\n\n// https://github.com/paritytech/polkadot-sdk/blob/56d97c3ad8c86e602bc7ac368751210517c4309f/substrate/primitives/runtime/src/lib.rs#L543\nconst ERRORS_TRANSACTIONAL = {\n LimitReached: \"Too many transactional layers have been spawned\",\n NoLayer: \"A transactional layer was expected, but does not exist\",\n}\n\n// https://github.com/paritytech/polkadot-sdk/blob/56d97c3ad8c86e602bc7ac368751210517c4309f/substrate/primitives/runtime/src/lib.rs#L672\nconst ERRORS_TOKEN = {\n FundsUnavailable: \"Funds are unavailable\",\n OnlyProvider: \"Account that must exist would die\",\n BelowMinimum: \"Account cannot exist with the funds that would be given\",\n CannotCreate: \"Account cannot be created\",\n UnknownAsset: \"The asset in question is unknown\",\n Frozen: \"Funds exist but are frozen\",\n Unsupported: \"Operation is not supported by the asset\",\n CannotCreateHold: \"Account cannot be created for recording amount on hold\",\n NotExpendable: \"Account that is desired to remain would die\",\n Blocked: \"Account cannot receive the assets\",\n}\n\n// https://github.com/paritytech/polkadot-sdk/blob/56d97c3ad8c86e602bc7ac368751210517c4309f/substrate/primitives/arithmetic/src/lib.rs#L76\nconst ERRORS_ARITHMETIC = {\n Overflow: \"An underflow would occur\",\n Underflow: \"An overflow would occur\",\n DivisionByZero: \"Division by zero\",\n}\n\n// https://github.com/paritytech/polkadot-sdk/blob/56d97c3ad8c86e602bc7ac368751210517c4309f/substrate/primitives/runtime/src/lib.rs#L714\nconst DISPATCH_ERROR = {\n CannotLookup: \"Cannot lookup\",\n BadOrigin: \"Bad origin\",\n Module: ERROR_METADATA_LOOKUP,\n ConsumerRemaining: \"Consumer remaining\",\n NoProviders: \"No providers\",\n TooManyConsumers: \"Too many consumers\",\n Token: ERRORS_TOKEN,\n Arithmetic: ERRORS_ARITHMETIC,\n Transactional: ERRORS_TRANSACTIONAL,\n Exhausted: \"Resources exhausted\",\n Corruption: \"State corrupt\",\n Unavailable: \"Resource unavailable\",\n RootNotAllowed: \"Root not allowed\",\n Trie: \"Unknown error\", // unsupported,\n Other: \"Unknown error\", // unsupported,\n}\n\ntype UnsafeDispatchError = {\n type: string\n value:\n | {\n type: string\n value:\n | {\n type: string\n value: undefined\n }\n | undefined\n }\n | undefined\n}\n\ntype UnsafeModuleError = {\n type: string\n value: {\n type: string\n value: undefined\n }\n}\n\nconst getModuleErrorMessage = (chain: Chain, error: UnsafeModuleError): string => {\n try {\n if (!chain.metadata) throw new Error(\"Could not fetch metadata\")\n\n const pallet = chain.metadata.pallets.find((p) => p.name === error.type)\n if (typeof pallet?.errors !== \"number\") throw new Error(\"Unknown pallet\")\n\n const lookup = getLookupFn(chain.metadata)\n\n const palletErrors = lookup(pallet.errors)\n if (palletErrors.type !== \"enum\" || !palletErrors.innerDocs[error.value.type]?.length)\n throw new Error(\"Unknown error type\")\n\n return palletErrors.innerDocs[error.value.type].join(\" \")\n } catch (err) {\n log.error(\"Failed to parse module error\", { chainId: chain.connector.chainId, error, err })\n return [error.type, error.value.type].join(\": \")\n }\n}\n\nconst tryFormatError = (err: unknown): string => {\n try {\n // biome-ignore lint/suspicious/noExplicitAny: legacy\n const unsafeErr = err as any\n if (unsafeErr.type && unsafeErr.value?.type)\n return [unsafeErr.type, unsafeErr.value.type].join(\": \")\n } catch {\n // ignore\n }\n\n return \"Unknown error\"\n}\n","import { toHex } from \"@polkadot-api/utils\"\n\nimport { getSendRequestResult } from \"./getSendRequestResult\"\nimport type { Chain } from \"./types\"\n\nexport const getRuntimeCallResult = async <T>(\n chain: Chain,\n apiName: string,\n method: string,\n args: unknown[]\n) => {\n const call = chain.builder.buildRuntimeCall(apiName, method)\n\n const hex = await getSendRequestResult<string>(chain, \"state_call\", [\n `${apiName}_${method}`,\n toHex(call.args.enc(args)),\n ])\n\n return call.value.dec(hex) as T\n}\n","import type { Chain } from \"./types\"\n\nexport const getSendRequestResult = <Res>(\n chain: Chain,\n method: string,\n params: unknown[],\n isCacheable?: boolean\n): Promise<Res> => {\n return chain.connector.send(method, params, isCacheable) as Promise<Res>\n}\n","import type { Chain } from \"./types\"\n\nexport const isApiAvailable = (chain: Chain, name: string, method: string) => {\n return chain.metadata.apis.some(\n (a) => a.name === name && a.methods.some((m) => m.name === method)\n )\n}\n","import type {\n IRuntimeVersionBase,\n SignatureOptions,\n SignerPayloadJSON,\n} from \"@polkadot/types/types\"\nimport { Binary } from \"polkadot-api\"\n\nimport log from \"../log\"\nimport { getExtrinsicDispatchInfo } from \"./getExtrinsicDispatchInfo\"\nimport { getRuntimeCallResult } from \"./getRuntimeCallResult\"\nimport { getTypeRegistry } from \"./getTypeRegistry\"\nimport type { Chain, ChainInfo } from \"./types\"\n\nexport const getFeeEstimate = async (\n chain: Chain,\n payload: SignerPayloadJSON,\n chainInfo: ChainInfo\n) => {\n // TODO do this without PJS / registry => waiting for @polkadot-api/tx-utils\n const registry = getTypeRegistry(chain, payload)\n const extrinsic = registry.createType(\"Extrinsic\", payload)\n\n extrinsic.signFake(payload.address, {\n appId: 0,\n nonce: payload.nonce,\n blockHash: payload.blockHash,\n genesisHash: payload.genesisHash,\n runtimeVersion: {\n specVersion: chainInfo.specVersion,\n transactionVersion: chainInfo.transactionVersion,\n // other fields aren't necessary for signing\n } as IRuntimeVersionBase,\n } as SignatureOptions)\n\n const bytes = extrinsic.toU8a(true)\n const binary = Binary.fromBytes(bytes)\n\n try {\n const result = await getRuntimeCallResult<{ partial_fee: bigint }>(\n chain,\n \"TransactionPaymentApi\",\n \"query_info\",\n [binary, bytes.length]\n )\n // Do not throw if partialFee is 0n. This is a valid response, eg: Bittensor remove_stake fee estimation is 0n.\n if (!result?.partial_fee && result.partial_fee !== 0n) {\n throw new Error(\"partialFee is not found\")\n }\n return result.partial_fee\n } catch (err) {\n log.error(\"Failed to get fee estimate using getRuntimeCallValue\", { err })\n }\n\n // fallback to pjs encoded state call, in case the above fails (extracting runtime calls codecs might require metadata V15)\n // Note: PAPI will consider TransactionPaymentApi as first class api so it should work even without V15, but this is not the case yet.\n const { partialFee } = await getExtrinsicDispatchInfo(chain, extrinsic)\n\n return BigInt(partialFee)\n}\n","import type { GenericExtrinsic } from \"@polkadot/types\"\nimport type { RuntimeDispatchInfo } from \"@polkadot/types/interfaces\"\nimport type { Codec } from \"@polkadot/types-codec/types\"\nimport { assert, u8aConcatStrict } from \"@polkadot/util\"\nimport type { HexString } from \"@polkadot/util/types\"\n\nimport type { JsonRpcRequestSend } from \"../types\"\nimport type { Chain } from \"./types\"\n\ntype ExtrinsicDispatchInfo = {\n partialFee: string\n}\n\n// used for chains that dont have metadata v15 yet\nexport const getExtrinsicDispatchInfo = async (\n chain: Chain,\n signedExtrinsic: GenericExtrinsic\n): Promise<ExtrinsicDispatchInfo> => {\n assert(signedExtrinsic.isSigned, \"Extrinsic must be signed (or fakeSigned) in order to query fee\")\n\n const len = signedExtrinsic.registry.createType(\"u32\", signedExtrinsic.encodedLength)\n\n const dispatchInfo = (await stateCall(\n chain.connector.send,\n \"TransactionPaymentApi_query_info\",\n \"RuntimeDispatchInfo\",\n [signedExtrinsic, len],\n undefined,\n true\n )) as RuntimeDispatchInfo\n\n return {\n partialFee: dispatchInfo.partialFee.toString(),\n }\n}\n\nconst stateCall = async <K extends string = string>(\n request: JsonRpcRequestSend,\n method: string,\n resultType: K,\n args: Codec[],\n blockHash?: HexString,\n isCacheable?: boolean\n) => {\n // on a state call there are always arguments\n const registry = args[0].registry\n\n const bytes = registry.createType(\"Raw\", u8aConcatStrict(args.map((arg) => arg.toU8a())))\n\n const result = await request(\"state_call\", [method, bytes.toHex(), blockHash], isCacheable)\n\n return registry.createType(resultType, result)\n}\n","import { Metadata, TypeRegistry } from \"@polkadot/types\"\nimport type { RegistryTypes, SignerPayloadJSON } from \"@polkadot/types/types\"\n\nimport log from \"../log\"\nimport type { Chain } from \"./types\"\n\nexport const getTypeRegistry = (chain: Chain, payload: SignerPayloadJSON) => {\n log.debug(`[sapi] getTypeRegistry for payload (${chain.token.symbol})`)\n const registry = new TypeRegistry()\n\n if (chain.registryTypes) registry.register(chain.registryTypes as RegistryTypes)\n\n const meta = new Metadata(registry, chain.hexMetadata)\n registry.setMetadata(meta, payload.signedExtensions, chain.signedExtensions) // ~30ms\n\n return registry\n}\n","import type { SapiConnectorProps } from \"../types\"\n\nexport type SapiConnector = Required<SapiConnectorProps>\n\nexport const getSapiConnector = ({\n chainId,\n send,\n submit,\n submitWithBittensorMevShield,\n}: SapiConnectorProps): SapiConnector => ({\n chainId,\n send,\n submit: (...args) => {\n if (submit) return submit(...args)\n throw new Error(\"submit handler not provided\")\n },\n submitWithBittensorMevShield: (...args) => {\n if (submitWithBittensorMevShield) return submitWithBittensorMevShield(...args)\n throw new Error(\"submitWithBittensorMevShield handler not provided\")\n },\n})\n","import type { SignerPayloadJSON } from \"@polkadot/types/types\"\nimport { u8aToHex } from \"@polkadot/util\"\nimport { mergeUint8, toHex } from \"@polkadot-api/utils\"\nimport { Binary } from \"polkadot-api\"\n\nimport log from \"../log\"\nimport type { PayloadSignerConfig } from \"../types\"\nimport { getPayloadWithMetadataHash } from \"./getPayloadWithMetadataHash\"\nimport { getSendRequestResult } from \"./getSendRequestResult\"\nimport { getStorageValue } from \"./getStorageValue\"\nimport { mortal, toPjsHex } from \"./papi\"\nimport type { Chain, ChainInfo } from \"./types\"\n\nconst ERA_PERIOD = 64 // validity period in blocks, used for mortal era\n\nexport const getSignerPayloadJSON = async (\n chain: Chain,\n palletName: string,\n methodName: string,\n args: unknown,\n signerConfig: PayloadSignerConfig,\n chainInfo: ChainInfo\n): Promise<{\n payload: SignerPayloadJSON\n txMetadata: Uint8Array | undefined\n shortMetadata: `0x${string}` | undefined\n}> => {\n const { codec, location } = chain.builder.buildCall(palletName, methodName)\n const method = Binary.fromBytes(mergeUint8([new Uint8Array(location), codec.enc(args)]))\n\n // on unstable networks with lots of forks (ex: westend asset hub as of june 2025),\n // using a finalized block as reference for mortality is necessary for txs to get through\n let blockHash = await getSendRequestResult<`0x${string}`>(\n chain,\n \"chain_getFinalizedHead\",\n [],\n false\n )\n\n const [nonce, genesisHash, blockNumberFinalized, blockNumberCurrent] = await Promise.all([\n getSendRequestResult<number>(chain, \"system_accountNextIndex\", [signerConfig.address], false),\n getStorageValue<Binary>(chain, \"System\", \"BlockHash\", [0]),\n getStorageValue<number>(chain, \"System\", \"Number\", [], blockHash),\n getStorageValue<number>(chain, \"System\", \"Number\", []),\n ])\n if (!genesisHash) throw new Error(\"Genesis hash not found\")\n if (!blockHash) throw new Error(\"Block hash not found\")\n\n let blockNumber = blockNumberFinalized\n\n // on Autonomys the finalized block hash is wrong (7000 blocks behind),\n // if we use it to craft a tx it will be invalid\n // => if finalized block number is more than 32 blocks behind, use current - 16\n if (blockNumberCurrent - blockNumberFinalized > 32) {\n blockNumber = blockNumberCurrent - 16\n\n const binBlockHash = await getStorageValue<Binary>(chain, \"System\", \"BlockHash\", [blockNumber])\n blockHash = binBlockHash.asHex() as `0x${string}`\n }\n\n const era = mortal({ period: ERA_PERIOD, phase: blockNumber % ERA_PERIOD })\n // signedExtensions is keyed by extension version, 0 is the default\n const signedExtensions = (chain.metadata.extrinsic.signedExtensions[0] ?? []).map(\n (ext) => ext.identifier\n )\n\n const basePayload: SignerPayloadJSON = {\n address: signerConfig.address,\n genesisHash: genesisHash.asHex() as `0x${string}`,\n blockHash,\n method: method.asHex(),\n signedExtensions,\n nonce: toPjsHex(nonce, 4),\n specVersion: toPjsHex(chainInfo.specVersion, 4),\n transactionVersion: toPjsHex(chainInfo.transactionVersion, 4),\n blockNumber: toPjsHex(blockNumber, 4),\n era: toHex(era) as `0x${string}`,\n tip: toPjsHex(0, 16), // TODO gas station (required for Astar)\n assetId: undefined,\n version: 4,\n }\n\n const { payload, txMetadata } = getPayloadWithMetadataHash(chain, chainInfo, basePayload)\n const shortMetadata = txMetadata ? u8aToHex(txMetadata) : undefined\n\n // Avail support\n if (payload.signedExtensions.includes(\"CheckAppId\"))\n (payload as SignerPayloadJSON & { appId: number }).appId = 0\n\n log.log(\"[sapi] payload\", { newPayload: payload, txMetadata })\n\n return {\n payload,\n txMetadata, // TODO remove\n shortMetadata,\n }\n}\n","import type { SignerPayloadJSON } from \"@polkadot/types/types\"\nimport { merkleizeMetadata } from \"@polkadot-api/merkleize-metadata\"\nimport { toHex } from \"@polkadot-api/utils\"\n\nimport log from \"../log\"\nimport { getTypeRegistry } from \"./getTypeRegistry\"\nimport type { Chain, ChainInfo } from \"./types\"\n\nexport const getPayloadWithMetadataHash = (\n chain: Chain,\n chainInfo: ChainInfo,\n payload: SignerPayloadJSON\n): { payload: SignerPayloadJSON; txMetadata?: Uint8Array } => {\n if (!chain.hasCheckMetadataHash || !payload.signedExtensions.includes(\"CheckMetadataHash\"))\n return {\n payload,\n txMetadata: undefined,\n }\n\n try {\n const { decimals, symbol: tokenSymbol } = chain.token\n const { base58Prefix, specName, specVersion } = chainInfo\n const metadataHashInputs = { tokenSymbol, decimals, base58Prefix, specName, specVersion }\n\n // since ultimately this needs a V15 object, would be nice if this accepted one directly as input\n const merkleizedMetadata = merkleizeMetadata(chain.hexMetadata, metadataHashInputs)\n const metadataHash = toHex(merkleizedMetadata.digest()) as `0x${string}`\n log.log(\"metadataHash\", metadataHash, metadataHashInputs)\n\n const payloadWithMetadataHash = {\n ...payload,\n mode: 1,\n metadataHash,\n withSignedTransaction: true,\n }\n\n // TODO do this without PJS / registry => waiting for @polkadot-api/tx-utils\n // const { extra, additionalSigned } = getSignedExtensionValues(payload, metadata)\n // const badExtPayload = mergeUint8([fromHex(payload.method), ...extra, ...additionalSigned])\n\n const registry = getTypeRegistry(chain, payload)\n const extPayload = registry.createType(\"ExtrinsicPayload\", payloadWithMetadataHash)\n const barePayload = extPayload.toU8a(true)\n\n const txMetadata = merkleizedMetadata.getProofForExtrinsicPayload(barePayload)\n\n return {\n payload: payloadWithMetadataHash,\n txMetadata,\n }\n } catch (err) {\n log.error(\"Failed to get shortened metadata\", { error: err })\n return {\n payload,\n txMetadata: undefined,\n }\n }\n}\n","import { getSendRequestResult } from \"./getSendRequestResult\"\nimport type { Chain } from \"./types\"\n\nexport const getStorageValue = async <T>(\n chain: Chain,\n pallet: string,\n entry: string,\n keys: unknown[],\n at?: string\n) => {\n const storageCodec = chain.builder.buildStorage(pallet, entry)\n const stateKey = storageCodec.keys.enc(...keys)\n\n const hexValue = await getSendRequestResult<string | null>(chain, \"state_getStorage\", [\n stateKey,\n at,\n ])\n if (!hexValue) return null as T // caller will need to expect null when applicable\n\n return storageCodec.value.dec(hexValue) as T\n}\n","import { Bytes, enhanceEncoder, u16 } from \"@polkadot-api/substrate-bindings\"\n\n//////////////////////////////////////////////////////////////////////////////////////////////////////////////\n//////////////////////////// Utilities from PAPI /////////////////////////////\n//////////////////////////////////////////////////////////////////////////////////////////////////////////////\n\nexport const toPjsHex = (value: number | bigint, minByteLen?: number) => {\n let inner = value.toString(16)\n inner = (inner.length % 2 ? \"0\" : \"\") + inner\n const nPaddedBytes = Math.max(0, (minByteLen || 0) - inner.length / 2)\n return `0x${\"00\".repeat(nPaddedBytes)}${inner}` as `0x${string}`\n}\n\nexport const mortal = enhanceEncoder(Bytes(2).enc, (value: { period: number; phase: number }) => {\n const factor = Math.max(value.period >> 12, 1)\n const left = Math.min(Math.max(trailingZeroes(value.period) - 1, 1), 15)\n const right = (value.phase / factor) << 4\n return u16.enc(left | right)\n})\n\nfunction trailingZeroes(n: number) {\n let i = 0\n while (!(n & 1)) {\n i++\n n >>= 1\n }\n return i\n}\n","import { getLookupFn } from \"@polkadot-api/metadata-builders\"\n\nimport log from \"../log\"\nimport type { Chain } from \"./types\"\n\nexport const hasEvent = (chain: Chain, pallet: string, event: string): boolean => {\n try {\n const palletDef = chain.metadata.pallets.find((p) => p.name === pallet)\n if (typeof palletDef?.events !== \"number\") return false\n\n const lookup = getLookupFn(chain.metadata)\n const palletEvents = lookup(palletDef.events)\n\n return palletEvents.type === \"enum\" && event in palletEvents.innerDocs\n } catch (err) {\n log.error(\"Failed to check event existence\", { pallet, event, err })\n return false\n }\n}\n","import type { SignerPayloadJSON } from \"@polkadot/types/types\"\nimport type { ScaleApiSubmitMode } from \"../types\"\nimport type { Chain } from \"./types\"\n\nexport const submit = async (\n chain: Chain,\n payload: SignerPayloadJSON,\n signature?: `0x${string}`,\n txInfo?: unknown,\n mode?: ScaleApiSubmitMode\n): Promise<{ hash: `0x${string}`; innerHash?: `0x${string}` }> => {\n switch (mode) {\n case \"bittensor-mev-shield\":\n if (signature)\n throw new Error(\"Signature should not be provided when using bittensor-mev-shield mode\")\n return chain.connector.submitWithBittensorMevShield(payload, txInfo)\n\n default:\n return chain.connector.submit(payload, signature, txInfo)\n }\n}\n"],"mappings":"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","names":["toHex","toHex","submit","toHex","Binary","toHex","toHex","Binary","toHex","getLookupFn","getLookupFn"]}
|
|
1
|
+
{"version":3,"sources":["../src/fetchBestMetadata.ts","../src/sapi.ts","../src/log.ts","../package.json","../src/helpers/getCallDocs.ts","../src/helpers/getConstantValue.ts","../src/helpers/getChainInfo.ts","../src/helpers/getDecodedCall.ts","../src/helpers/getDecodedCallFromExtrinsic.ts","../src/helpers/getDryRunCall.ts","../src/helpers/errors.ts","../src/helpers/getRuntimeCallResult.ts","../src/helpers/getSendRequestResult.ts","../src/helpers/isApiAvailable.ts","../src/helpers/getFeeEstimate.ts","../src/helpers/getExtrinsicDispatchInfo.ts","../src/helpers/getTypeRegistry.ts","../src/helpers/getSapiConnector.ts","../src/helpers/getSignerPayloadJSON.ts","../src/helpers/getPayloadWithMetadataHash.ts","../src/helpers/getStorageValue.ts","../src/helpers/papi.ts","../src/helpers/hasEvent.ts","../src/helpers/submit.ts"],"sourcesContent":["import { toHex } from \"@polkadot-api/utils\"\nimport { u32, Vector } from \"scale-ts\"\n\nconst MAGIC_NUMBER = 1635018093\n\n// it's important to set a max because some chains also return high invalid version numbers in the metadata_versions list (ex on Polkadot, related to JAM?)\nexport const MAX_SUPPORTED_METADATA_VERSION = 15 // v16 sometimes outputs different metadata hashes, ignore v16 until that is fixed in PAPI\n\ntype RpcSendFunc = <T>(method: string, params: unknown[], isCacheable?: boolean) => Promise<T>\n\n/**\n * Fetches the highest supported version of metadata from the chain.\n *\n * @param rpcSend\n * @returns hex-encoded metadata starting with the magic number\n */\nexport const fetchBestMetadata = async (\n rpcSend: RpcSendFunc,\n allowLegacyFallback?: boolean\n): Promise<`0x${string}`> => {\n try {\n // fetch available versions of metadata\n const metadataVersions = await rpcSend<string>(\n \"state_call\",\n [\"Metadata_metadata_versions\", \"0x\"],\n true\n )\n const availableVersions = Vector(u32).dec(metadataVersions)\n const bestVersion = Math.max(\n ...availableVersions.filter((v) => v <= MAX_SUPPORTED_METADATA_VERSION)\n )\n\n const metadata = await rpcSend<`0x${string}`>(\n \"state_call\",\n [\"Metadata_metadata_at_version\", toHex(u32.enc(bestVersion))],\n true\n )\n\n return normalizeMetadata(metadata)\n } catch (cause) {\n // if the chain doesnt support the Metadata pallet, fallback to legacy rpc provided metadata (V14)\n const message = (cause as { message?: string })?.message\n if (\n allowLegacyFallback ||\n message?.includes(\"is not found\") || // ex: crust standalone\n message?.includes(\"Module doesn't have export Metadata_metadata_versions\") || // ex: 3DPass\n message?.includes(\"Exported method Metadata_metadata_versions is not found\") || // ex: sora-polkadot & sora-standalone\n message?.includes(\"Execution, MethodNotFound, Metadata_metadata_versions\") // ex: stafi\n ) {\n return (await rpcSend(\"state_getMetadata\", [], true)) as `0x${string}`\n }\n\n // otherwise throw so it can be handled by the caller\n throw new Error(\"Failed to fetch metadata\", { cause })\n }\n}\n\n/**\n * Removes everything before the magic number in the metadata.\n * This ensures Opaque metadata is usable by pjs\n */\nconst normalizeMetadata = (metadata: `0x${string}`): `0x${string}` => {\n const hexMagicNumber = toHex(u32.enc(MAGIC_NUMBER)).slice(2)\n\n const magicNumberIndex = metadata.indexOf(hexMagicNumber)\n if (magicNumberIndex === -1) throw new Error(\"Invalid metadata format: magic number not found\")\n\n return `0x${metadata.slice(magicNumberIndex)}` as `0x${string}`\n}\n","import type { ExtDef } from \"@polkadot/types/extrinsic/signedExtensions/types\"\nimport type { SignerPayloadJSON } from \"@polkadot/types/types\"\nimport { parseMetadataRpc } from \"@talismn/scale\"\n\nimport { getCallDocs } from \"./helpers/getCallDocs\"\nimport { getChainInfo } from \"./helpers/getChainInfo\"\nimport { getConstantValue } from \"./helpers/getConstantValue\"\nimport { getDecodedCall, getDecodedCallFromPayload } from \"./helpers/getDecodedCall\"\nimport { getDecodedCallFromExtrinsic } from \"./helpers/getDecodedCallFromExtrinsic\"\nimport { getDryRunCall } from \"./helpers/getDryRunCall\"\nimport { getFeeEstimate } from \"./helpers/getFeeEstimate\"\nimport { getRuntimeCallResult } from \"./helpers/getRuntimeCallResult\"\nimport { getSapiConnector } from \"./helpers/getSapiConnector\"\nimport { getSignerPayloadJSON } from \"./helpers/getSignerPayloadJSON\"\nimport { getStorageValue } from \"./helpers/getStorageValue\"\nimport { getTypeRegistry } from \"./helpers/getTypeRegistry\"\nimport { hasEvent } from \"./helpers/hasEvent\"\nimport { isApiAvailable } from \"./helpers/isApiAvailable\"\nimport { submit } from \"./helpers/submit\"\nimport type { Chain } from \"./helpers/types\"\nimport type {\n DecodedCall,\n PayloadSignerConfig,\n SapiConnectorProps,\n ScaleApiSubmitMode,\n} from \"./types\"\n\nexport type ScaleApi = NonNullable<ReturnType<typeof getScaleApi>>\n\nexport const getScaleApi = (\n connector: SapiConnectorProps,\n hexMetadata: `0x${string}`,\n token: { symbol: string; decimals: number },\n hasCheckMetadataHash?: boolean,\n signedExtensions?: ExtDef,\n registryTypes?: unknown\n) => {\n const { unifiedMetadata: metadata, lookupFn: lookup, builder } = parseMetadataRpc(hexMetadata)\n\n const chain: Chain = {\n connector: getSapiConnector(connector),\n hexMetadata,\n\n token,\n hasCheckMetadataHash,\n signedExtensions,\n registryTypes,\n\n metadata,\n lookup,\n builder,\n metadataRpc: hexMetadata,\n }\n\n const chainInfo = getChainInfo(chain)\n\n const { specName, specVersion, base58Prefix } = chainInfo\n\n return {\n id: `${connector.chainId}::${specName}::${specVersion}`,\n chainId: connector.chainId,\n specName,\n specVersion,\n hasCheckMetadataHash,\n base58Prefix,\n token: chain.token,\n chain,\n\n getConstant: <T>(pallet: string, constant: string) =>\n getConstantValue<T>(chain, pallet, constant),\n\n getStorage: <T>(pallet: string, entry: string, keys: unknown[], at?: string) =>\n getStorageValue<T>(chain, pallet, entry, keys, at),\n\n getDecodedCall: (pallet: string, method: string, args: unknown) =>\n getDecodedCall(pallet, method, args),\n\n getDecodedCallFromPayload: <Res extends DecodedCall>(payload: {\n method: SignerPayloadJSON[\"method\"]\n }) => getDecodedCallFromPayload<Res>(chain, payload),\n\n getDecodedCallFromExtrinsic: <Res extends DecodedCall>(extrinsicHex: `0x${string}`) =>\n getDecodedCallFromExtrinsic<Res>(chain, extrinsicHex),\n\n getExtrinsicPayload: (\n pallet: string,\n method: string,\n args: unknown,\n config: PayloadSignerConfig\n ) => getSignerPayloadJSON(chain, pallet, method, args, config, chainInfo),\n\n getFeeEstimate: (payload: SignerPayloadJSON) => getFeeEstimate(chain, payload, chainInfo),\n\n getRuntimeCallValue: <T>(apiName: string, method: string, args: unknown[]) =>\n getRuntimeCallResult<T>(chain, apiName, method, args),\n\n getTypeRegistry: (payload: SignerPayloadJSON) => getTypeRegistry(chain, payload),\n\n submit: (\n payload: SignerPayloadJSON,\n signature?: `0x${string}`,\n txInfo?: unknown,\n mode?: ScaleApiSubmitMode\n ) => submit(chain, payload, signature, txInfo, mode),\n\n getCallDocs: (pallet: string, method: string) => getCallDocs(chain, pallet, method),\n\n getDryRunCall: <T>(from: string, decodedCall: DecodedCall<unknown>) =>\n getDryRunCall<T>(chain, from, decodedCall),\n\n isApiAvailable: (name: string, method: string) => isApiAvailable(chain, name, method),\n\n hasEvent: (pallet: string, event: string) => hasEvent(chain, pallet, event),\n }\n}\n","import anylogger from \"anylogger\"\n\nimport packageJson from \"../package.json\"\n\nexport default anylogger(packageJson.name)\n","{\n \"name\": \"@talismn/sapi\",\n \"version\": \"0.1.6\",\n \"author\": \"Talisman\",\n \"homepage\": \"https://talisman.xyz\",\n \"license\": \"GPL-3.0-or-later\",\n \"publishConfig\": {\n \"access\": \"public\"\n },\n \"repository\": {\n \"directory\": \"packages/sapi\",\n \"type\": \"git\",\n \"url\": \"https://github.com/TalismanSociety/talisman.git\"\n },\n \"main\": \"./dist/index.js\",\n \"module\": \"./dist/index.mjs\",\n \"files\": [\n \"dist\"\n ],\n \"engines\": {\n \"node\": \">=20\"\n },\n \"scripts\": {\n \"test\": \"vitest run\",\n \"clean\": \"rm -rf dist .turbo node_modules\",\n \"build\": \"tsup --silent\",\n \"typecheck\": \"tsc --noEmit\"\n },\n \"dependencies\": {\n \"@polkadot-api/merkleize-metadata\": \"1.1.29\",\n \"@polkadot-api/metadata-builders\": \"0.13.9\",\n \"@polkadot-api/substrate-bindings\": \"0.17.0\",\n \"@polkadot-api/utils\": \"0.2.0\",\n \"@polkadot/types\": \"16.1.2\",\n \"@polkadot/types-codec\": \"16.1.2\",\n \"@talismn/scale\": \"workspace:*\",\n \"anylogger\": \"^1.0.11\",\n \"polkadot-api\": \"1.23.3\",\n \"scale-ts\": \"^1.6.1\"\n },\n \"devDependencies\": {\n \"@talismn/tsconfig\": \"workspace:*\",\n \"typescript\": \"^5.6.3\"\n },\n \"types\": \"./dist/index.d.ts\",\n \"exports\": {\n \".\": {\n \"@talismn/source\": \"./src/index.ts\",\n \"import\": {\n \"types\": \"./dist/index.d.mts\",\n \"default\": \"./dist/index.mjs\"\n },\n \"require\": {\n \"types\": \"./dist/index.d.ts\",\n \"default\": \"./dist/index.js\"\n }\n }\n }\n}\n","import log from \"../log\"\nimport type { Chain } from \"./types\"\n\nexport const getCallDocs = (chain: Chain, pallet: string, method: string): string | null => {\n try {\n const typeIdCalls = chain.metadata.pallets.find(({ name }) => name === pallet)?.calls?.type\n if (!typeIdCalls) return null\n\n // biome-ignore lint/suspicious/noExplicitAny: legacy\n let palletCalls: any = chain.metadata.lookup[typeIdCalls]\n if (!palletCalls || palletCalls.id !== typeIdCalls)\n palletCalls = chain.metadata.lookup.find((v) => v.id === typeIdCalls)\n\n if (!palletCalls) return null\n\n const call = palletCalls.def.value.find(\n (c: { name: string; docs?: string[] | null }) => c.name === method\n )\n\n return call?.docs?.join(\"\\n\") ?? null\n } catch {\n log.error(\"Failed to find call docs\", { pallet, method, chain })\n return null\n }\n}\n","import { getConstantValueFromMetadata } from \"@talismn/scale\"\n\nimport type { Chain } from \"./types\"\n\nexport const getConstantValue = <T>(chain: Chain, pallet: string, constant: string) => {\n return getConstantValueFromMetadata<T>(\n {\n builder: chain.builder,\n unifiedMetadata: chain.metadata,\n },\n pallet,\n constant\n )\n}\n","import { getConstantValue } from \"./getConstantValue\"\nimport type { Chain } from \"./types\"\n\ntype SystemVersion = {\n spec_name: string\n spec_version: number\n transaction_version: number\n}\n\nexport const getChainInfo = (chain: Chain) => {\n const {\n spec_name: specName,\n spec_version: specVersion,\n transaction_version: transactionVersion,\n } = getConstantValue<SystemVersion>(chain, \"System\", \"Version\")\n\n const base58Prefix = getConstantValue<number>(chain, \"System\", \"SS58Prefix\")\n\n return {\n specName,\n specVersion,\n transactionVersion,\n base58Prefix,\n }\n}\n","import type { SignerPayloadJSON } from \"@polkadot/types/types\"\n\nimport type { DecodedCall } from \"../types\"\nimport type { Chain } from \"./types\"\n\nexport const getDecodedCall = (palletName: string, methodName: string, args: unknown) => ({\n type: palletName,\n value: { type: methodName, value: args },\n})\n\nexport const getDecodedCallFromPayload = <Res extends DecodedCall>(\n chain: Chain,\n payload: { method: SignerPayloadJSON[\"method\"] }\n): Res => {\n const def = chain.builder.buildDefinition(chain.lookup.call!)\n const decoded = def.dec(payload.method)\n\n return {\n pallet: decoded.type,\n method: decoded.value.type,\n args: decoded.value.value,\n } as Res\n}\n","import {\n Bin,\n compactNumber,\n createDecoder,\n type Decoder,\n enhanceDecoder,\n extrinsicFormat,\n type StringRecord,\n Struct,\n u8,\n} from \"@polkadot-api/substrate-bindings\"\n\nimport type { DecodedCall } from \"../types\"\nimport type { Chain } from \"./types\"\n\nconst allBytesDec = Bin(Infinity).dec\n\n/**\n * Decodes a signed extrinsic and extracts the call data.\n * Handles different metadata versions (v14, v15, v16) and extrinsic formats.\n *\n * @param chain - The chain context with metadata and builder\n * @param extrinsicHex - The hex-encoded extrinsic (with 0x prefix)\n * @returns The decoded call with pallet, method, and args, or null if decoding fails\n */\nexport const getDecodedCallFromExtrinsic = <Res extends DecodedCall>(\n chain: Chain,\n extrinsicHex: `0x${string}`\n): Res | null => {\n try {\n const { metadata, builder } = chain\n\n // Build decoder for signed extensions (extra field)\n // signedExtensions is keyed by extension version, 0 is the default\n const extensionsArray = metadata.extrinsic.signedExtensions[0] ?? []\n const extraDec = Struct.dec(\n Object.fromEntries(\n extensionsArray.map((x) => [x.identifier, builder.buildDefinition(x.type)[1]])\n ) as StringRecord<Decoder<unknown>>\n )\n\n // Build call decoder\n let callDec: Decoder<{ type: string; value: { type: string; value: unknown } }>\n const { extrinsic } = metadata\n if (\"address\" in extrinsic) {\n // v15/v16 metadata\n callDec = builder.buildDefinition(extrinsic.call)[1]\n } else {\n // v14 metadata\n const params = metadata.lookup[extrinsic.type]?.params\n const callType = params?.find((v) => v.name === \"Call\")?.type\n if (callType == null) throw new Error(\"Call type not found in metadata\")\n callDec = builder.buildDefinition(callType)[1]\n }\n\n // Build address and signature decoders\n let addressDec: Decoder<unknown>\n let signatureDec: Decoder<unknown>\n if (\"address\" in extrinsic) {\n // v15/v16\n addressDec = builder.buildDefinition(extrinsic.address)[1]\n signatureDec = builder.buildDefinition(extrinsic.signature)[1]\n } else {\n // v14\n const params = metadata.lookup[extrinsic.type]?.params\n const addrType = params?.find((v) => v.name === \"Address\")?.type\n const sigType = params?.find((v) => v.name === \"Signature\")?.type\n if (addrType == null || sigType == null)\n throw new Error(\"Address or Signature type not found\")\n addressDec = builder.buildDefinition(addrType)[1]\n signatureDec = builder.buildDefinition(sigType)[1]\n }\n\n // Build full signed extrinsic body decoder\n const v4Body = Struct.dec({\n address: addressDec,\n signature: signatureDec,\n extra: extraDec,\n callData: allBytesDec,\n })\n\n // Create the full extrinsic decoder\n const extrinsicDecoder = enhanceDecoder(\n createDecoder((data) => {\n const len = compactNumber.dec(data)\n const { type, version } = extrinsicFormat[1](data)\n\n if (type === \"bare\") {\n return { len, version, type, callData: allBytesDec(data) }\n }\n if (type === \"signed\") {\n return { len, version, type, ...v4Body(data) }\n }\n\n // v5 general format\n const extensionVersion = u8.dec(data)\n const extra = extraDec(data)\n return {\n len,\n type,\n version,\n extensionVersion,\n extra,\n callData: allBytesDec(data),\n }\n }),\n (v) => ({\n ...v,\n call: callDec(v.callData.asBytes()),\n })\n )\n\n // Decode the extrinsic\n const decoded = extrinsicDecoder(extrinsicHex)\n\n return {\n pallet: decoded.call.type,\n method: decoded.call.value.type,\n args: decoded.call.value.value,\n } as Res\n } catch (err) {\n // biome-ignore lint/suspicious/noConsole: troubleshoting\n console.error(\"[SAPI] Failed to decode extrinsic:\", err)\n return null\n }\n}\n","import type { polkadot, polkadotAssetHub } from \"@polkadot-api/descriptors\"\nimport { Enum } from \"polkadot-api\"\n\nimport log from \"../log\"\nimport type { DecodedCall } from \"../types\"\nimport { getDispatchErrorMessage } from \"./errors\"\nimport { getRuntimeCallResult } from \"./getRuntimeCallResult\"\nimport { isApiAvailable } from \"./isApiAvailable\"\nimport type { Chain } from \"./types\"\n\ntype DryRunResult = (\n | typeof polkadot\n | typeof polkadotAssetHub\n)[\"descriptors\"][\"apis\"][\"DryRunApi\"][\"dry_run_call\"][1]\n\nexport const getDryRunCall = async <T>(\n chain: Chain,\n from: string,\n decodedCall: DecodedCall<unknown>\n): Promise<\n | {\n available: boolean\n data: null\n ok?: undefined\n errorMessage?: undefined\n }\n | {\n available: boolean\n data: T\n ok: boolean\n errorMessage: string | null\n }\n> => {\n try {\n if (!isApiAvailable(chain, \"DryRunApi\", \"dry_run_call\"))\n return {\n available: false,\n data: null,\n }\n\n const origin = Enum(\"system\", Enum(\"Signed\", from))\n\n const { pallet, method, args } = decodedCall\n const call = { type: pallet, value: { type: method, value: args } }\n\n // This will throw an error if the api is not available on that chain\n const data = await getRuntimeCallResult<DryRunResult>(chain, \"DryRunApi\", \"dry_run_call\", [\n origin,\n call,\n ])\n\n const ok = data.success && data.value.execution_result.success\n const errorMessage =\n data.success && !data.value.execution_result.success\n ? getDispatchErrorMessage(chain, data.value.execution_result.value.error)\n : null\n\n return {\n available: true,\n // NOTE: we can't re-export `@polkadot-api/descriptors` from this package.\n // So, the caller of this function must pass in their own instance of `type DryRunResult` as the generic argument `T`.\n data: data as T,\n ok,\n errorMessage,\n }\n } catch (err) {\n // Note : err is null if chain doesnt have the api\n log.error(\"Failed to dry run\", { chainId: chain.connector.chainId, err })\n return {\n available: false,\n data: null,\n }\n }\n}\n","import { getLookupFn } from \"@polkadot-api/metadata-builders\"\n\nimport log from \"../log\"\nimport type { Chain } from \"./types\"\n\nexport const getDispatchErrorMessage = (chain: Chain, err: unknown): string | null => {\n try {\n if (!err) return null\n\n const error = err as UnsafeDispatchError\n if (!error.type) throw new Error(\"Unknown dispatch error\")\n\n const lv1 = DISPATCH_ERROR[error.type as keyof typeof DISPATCH_ERROR]\n if (!lv1) throw new Error(\"Unknown dispatch error\")\n if (lv1 === ERROR_METADATA_LOOKUP)\n return getModuleErrorMessage(chain, error.value as UnsafeModuleError)\n if (typeof lv1 === \"string\") return lv1\n\n const lv2 = lv1[error.value?.type as keyof typeof lv1]\n if (!lv2) throw new Error(\"Unknown dispatch error\")\n if (typeof lv2 === \"string\") return lv2\n\n throw new Error(\"Unknown dispatch error\")\n } catch (cause) {\n log.error(\"Failed to parse runtime error\", { chainId: chain.connector.chainId, cause, err })\n return tryFormatError(err)\n }\n}\n\nconst ERROR_METADATA_LOOKUP = \"METADATA_LOOKUP\"\n\n// only `Module` errors are part of the metadata\n// errors below are defined as part of the runtime but their docs aren't included in the metadata\n// so those are copy/pasted from the polkadot-sdk repo\n\n// https://github.com/paritytech/polkadot-sdk/blob/56d97c3ad8c86e602bc7ac368751210517c4309f/substrate/primitives/runtime/src/lib.rs#L543\nconst ERRORS_TRANSACTIONAL = {\n LimitReached: \"Too many transactional layers have been spawned\",\n NoLayer: \"A transactional layer was expected, but does not exist\",\n}\n\n// https://github.com/paritytech/polkadot-sdk/blob/56d97c3ad8c86e602bc7ac368751210517c4309f/substrate/primitives/runtime/src/lib.rs#L672\nconst ERRORS_TOKEN = {\n FundsUnavailable: \"Funds are unavailable\",\n OnlyProvider: \"Account that must exist would die\",\n BelowMinimum: \"Account cannot exist with the funds that would be given\",\n CannotCreate: \"Account cannot be created\",\n UnknownAsset: \"The asset in question is unknown\",\n Frozen: \"Funds exist but are frozen\",\n Unsupported: \"Operation is not supported by the asset\",\n CannotCreateHold: \"Account cannot be created for recording amount on hold\",\n NotExpendable: \"Account that is desired to remain would die\",\n Blocked: \"Account cannot receive the assets\",\n}\n\n// https://github.com/paritytech/polkadot-sdk/blob/56d97c3ad8c86e602bc7ac368751210517c4309f/substrate/primitives/arithmetic/src/lib.rs#L76\nconst ERRORS_ARITHMETIC = {\n Overflow: \"An underflow would occur\",\n Underflow: \"An overflow would occur\",\n DivisionByZero: \"Division by zero\",\n}\n\n// https://github.com/paritytech/polkadot-sdk/blob/56d97c3ad8c86e602bc7ac368751210517c4309f/substrate/primitives/runtime/src/lib.rs#L714\nconst DISPATCH_ERROR = {\n CannotLookup: \"Cannot lookup\",\n BadOrigin: \"Bad origin\",\n Module: ERROR_METADATA_LOOKUP,\n ConsumerRemaining: \"Consumer remaining\",\n NoProviders: \"No providers\",\n TooManyConsumers: \"Too many consumers\",\n Token: ERRORS_TOKEN,\n Arithmetic: ERRORS_ARITHMETIC,\n Transactional: ERRORS_TRANSACTIONAL,\n Exhausted: \"Resources exhausted\",\n Corruption: \"State corrupt\",\n Unavailable: \"Resource unavailable\",\n RootNotAllowed: \"Root not allowed\",\n Trie: \"Unknown error\", // unsupported,\n Other: \"Unknown error\", // unsupported,\n}\n\ntype UnsafeDispatchError = {\n type: string\n value:\n | {\n type: string\n value:\n | {\n type: string\n value: undefined\n }\n | undefined\n }\n | undefined\n}\n\ntype UnsafeModuleError = {\n type: string\n value: {\n type: string\n value: undefined\n }\n}\n\nconst getModuleErrorMessage = (chain: Chain, error: UnsafeModuleError): string => {\n try {\n if (!chain.metadata) throw new Error(\"Could not fetch metadata\")\n\n const pallet = chain.metadata.pallets.find((p) => p.name === error.type)\n if (typeof pallet?.errors !== \"number\") throw new Error(\"Unknown pallet\")\n\n const lookup = getLookupFn(chain.metadata)\n\n const palletErrors = lookup(pallet.errors)\n if (palletErrors.type !== \"enum\" || !palletErrors.innerDocs[error.value.type]?.length)\n throw new Error(\"Unknown error type\")\n\n return palletErrors.innerDocs[error.value.type].join(\" \")\n } catch (err) {\n log.error(\"Failed to parse module error\", { chainId: chain.connector.chainId, error, err })\n return [error.type, error.value.type].join(\": \")\n }\n}\n\nconst tryFormatError = (err: unknown): string => {\n try {\n // biome-ignore lint/suspicious/noExplicitAny: legacy\n const unsafeErr = err as any\n if (unsafeErr.type && unsafeErr.value?.type)\n return [unsafeErr.type, unsafeErr.value.type].join(\": \")\n } catch {\n // ignore\n }\n\n return \"Unknown error\"\n}\n","import { toHex } from \"@polkadot-api/utils\"\n\nimport { getSendRequestResult } from \"./getSendRequestResult\"\nimport type { Chain } from \"./types\"\n\nexport const getRuntimeCallResult = async <T>(\n chain: Chain,\n apiName: string,\n method: string,\n args: unknown[]\n) => {\n const call = chain.builder.buildRuntimeCall(apiName, method)\n\n const hex = await getSendRequestResult<string>(chain, \"state_call\", [\n `${apiName}_${method}`,\n toHex(call.args.enc(args)),\n ])\n\n return call.value.dec(hex) as T\n}\n","import type { Chain } from \"./types\"\n\nexport const getSendRequestResult = <Res>(\n chain: Chain,\n method: string,\n params: unknown[],\n isCacheable?: boolean\n): Promise<Res> => {\n return chain.connector.send(method, params, isCacheable) as Promise<Res>\n}\n","import type { Chain } from \"./types\"\n\nexport const isApiAvailable = (chain: Chain, name: string, method: string) => {\n return chain.metadata.apis.some(\n (a) => a.name === name && a.methods.some((m) => m.name === method)\n )\n}\n","import type {\n IRuntimeVersionBase,\n SignatureOptions,\n SignerPayloadJSON,\n} from \"@polkadot/types/types\"\nimport { Binary } from \"polkadot-api\"\n\nimport log from \"../log\"\nimport { getExtrinsicDispatchInfo } from \"./getExtrinsicDispatchInfo\"\nimport { getRuntimeCallResult } from \"./getRuntimeCallResult\"\nimport { getTypeRegistry } from \"./getTypeRegistry\"\nimport type { Chain, ChainInfo } from \"./types\"\n\nexport const getFeeEstimate = async (\n chain: Chain,\n payload: SignerPayloadJSON,\n chainInfo: ChainInfo\n) => {\n // TODO do this without PJS / registry => waiting for @polkadot-api/tx-utils\n const registry = getTypeRegistry(chain, payload)\n const extrinsic = registry.createType(\"Extrinsic\", payload)\n\n extrinsic.signFake(payload.address, {\n appId: 0,\n nonce: payload.nonce,\n blockHash: payload.blockHash,\n genesisHash: payload.genesisHash,\n runtimeVersion: {\n specVersion: chainInfo.specVersion,\n transactionVersion: chainInfo.transactionVersion,\n // other fields aren't necessary for signing\n } as IRuntimeVersionBase,\n } as SignatureOptions)\n\n const bytes = extrinsic.toU8a(true)\n const binary = Binary.fromBytes(bytes)\n\n try {\n const result = await getRuntimeCallResult<{ partial_fee: bigint }>(\n chain,\n \"TransactionPaymentApi\",\n \"query_info\",\n [binary, bytes.length]\n )\n // Do not throw if partialFee is 0n. This is a valid response, eg: Bittensor remove_stake fee estimation is 0n.\n if (!result?.partial_fee && result.partial_fee !== 0n) {\n throw new Error(\"partialFee is not found\")\n }\n return result.partial_fee\n } catch (err) {\n log.error(\"Failed to get fee estimate using getRuntimeCallValue\", { err })\n }\n\n // fallback to pjs encoded state call, in case the above fails (extracting runtime calls codecs might require metadata V15)\n // Note: PAPI will consider TransactionPaymentApi as first class api so it should work even without V15, but this is not the case yet.\n const { partialFee } = await getExtrinsicDispatchInfo(chain, extrinsic)\n\n return BigInt(partialFee)\n}\n","import type { GenericExtrinsic } from \"@polkadot/types\"\nimport type { RuntimeDispatchInfo } from \"@polkadot/types/interfaces\"\nimport type { Codec } from \"@polkadot/types-codec/types\"\nimport { mergeUint8 } from \"@polkadot-api/utils\"\nimport type { JsonRpcRequestSend } from \"../types\"\nimport type { Chain } from \"./types\"\n\ntype ExtrinsicDispatchInfo = {\n partialFee: string\n}\n\n// used for chains that dont have metadata v15 yet\nexport const getExtrinsicDispatchInfo = async (\n chain: Chain,\n signedExtrinsic: GenericExtrinsic\n): Promise<ExtrinsicDispatchInfo> => {\n if (!signedExtrinsic.isSigned)\n throw new Error(\"Extrinsic must be signed (or fakeSigned) in order to query fee\")\n\n const len = signedExtrinsic.registry.createType(\"u32\", signedExtrinsic.encodedLength)\n\n const dispatchInfo = (await stateCall(\n chain.connector.send,\n \"TransactionPaymentApi_query_info\",\n \"RuntimeDispatchInfo\",\n [signedExtrinsic, len],\n undefined,\n true\n )) as RuntimeDispatchInfo\n\n return {\n partialFee: dispatchInfo.partialFee.toString(),\n }\n}\n\nconst stateCall = async <K extends string = string>(\n request: JsonRpcRequestSend,\n method: string,\n resultType: K,\n args: Codec[],\n blockHash?: `0x${string}`,\n isCacheable?: boolean\n) => {\n // on a state call there are always arguments\n const registry = args[0].registry\n\n const bytes = registry.createType(\"Raw\", mergeUint8(...args.map((arg) => arg.toU8a())))\n\n const result = await request(\"state_call\", [method, bytes.toHex(), blockHash], isCacheable)\n\n return registry.createType(resultType, result)\n}\n","import { Metadata, TypeRegistry } from \"@polkadot/types\"\nimport type { RegistryTypes, SignerPayloadJSON } from \"@polkadot/types/types\"\n\nimport log from \"../log\"\nimport type { Chain } from \"./types\"\n\nexport const getTypeRegistry = (chain: Chain, payload: SignerPayloadJSON) => {\n log.debug(`[sapi] getTypeRegistry for payload (${chain.token.symbol})`)\n const registry = new TypeRegistry()\n\n if (chain.registryTypes) registry.register(chain.registryTypes as RegistryTypes)\n\n const meta = new Metadata(registry, chain.hexMetadata)\n registry.setMetadata(meta, payload.signedExtensions, chain.signedExtensions) // ~30ms\n\n return registry\n}\n","import type { SapiConnectorProps } from \"../types\"\n\nexport type SapiConnector = Required<SapiConnectorProps>\n\nexport const getSapiConnector = ({\n chainId,\n send,\n submit,\n submitWithBittensorMevShield,\n}: SapiConnectorProps): SapiConnector => ({\n chainId,\n send,\n submit: (...args) => {\n if (submit) return submit(...args)\n throw new Error(\"submit handler not provided\")\n },\n submitWithBittensorMevShield: (...args) => {\n if (submitWithBittensorMevShield) return submitWithBittensorMevShield(...args)\n throw new Error(\"submitWithBittensorMevShield handler not provided\")\n },\n})\n","import type { SignerPayloadJSON } from \"@polkadot/types/types\"\nimport { mergeUint8, toHex } from \"@polkadot-api/utils\"\nimport { Binary } from \"polkadot-api\"\n\nimport log from \"../log\"\nimport type { PayloadSignerConfig } from \"../types\"\nimport { getPayloadWithMetadataHash } from \"./getPayloadWithMetadataHash\"\nimport { getSendRequestResult } from \"./getSendRequestResult\"\nimport { getStorageValue } from \"./getStorageValue\"\nimport { mortal, toPjsHex } from \"./papi\"\nimport type { Chain, ChainInfo } from \"./types\"\n\nconst ERA_PERIOD = 64 // validity period in blocks, used for mortal era\n\nexport const getSignerPayloadJSON = async (\n chain: Chain,\n palletName: string,\n methodName: string,\n args: unknown,\n signerConfig: PayloadSignerConfig,\n chainInfo: ChainInfo\n): Promise<{\n payload: SignerPayloadJSON\n txMetadata: Uint8Array | undefined\n shortMetadata: `0x${string}` | undefined\n}> => {\n const { codec, location } = chain.builder.buildCall(palletName, methodName)\n const method = Binary.fromBytes(mergeUint8([new Uint8Array(location), codec.enc(args)]))\n\n // on unstable networks with lots of forks (ex: westend asset hub as of june 2025),\n // using a finalized block as reference for mortality is necessary for txs to get through\n let blockHash = await getSendRequestResult<`0x${string}`>(\n chain,\n \"chain_getFinalizedHead\",\n [],\n false\n )\n\n const [nonce, genesisHash, blockNumberFinalized, blockNumberCurrent] = await Promise.all([\n getSendRequestResult<number>(chain, \"system_accountNextIndex\", [signerConfig.address], false),\n getStorageValue<Binary>(chain, \"System\", \"BlockHash\", [0]),\n getStorageValue<number>(chain, \"System\", \"Number\", [], blockHash),\n getStorageValue<number>(chain, \"System\", \"Number\", []),\n ])\n if (!genesisHash) throw new Error(\"Genesis hash not found\")\n if (!blockHash) throw new Error(\"Block hash not found\")\n\n let blockNumber = blockNumberFinalized\n\n // on Autonomys the finalized block hash is wrong (7000 blocks behind),\n // if we use it to craft a tx it will be invalid\n // => if finalized block number is more than 32 blocks behind, use current - 16\n if (blockNumberCurrent - blockNumberFinalized > 32) {\n blockNumber = blockNumberCurrent - 16\n\n const binBlockHash = await getStorageValue<Binary>(chain, \"System\", \"BlockHash\", [blockNumber])\n blockHash = binBlockHash.asHex() as `0x${string}`\n }\n\n const era = mortal({ period: ERA_PERIOD, phase: blockNumber % ERA_PERIOD })\n // signedExtensions is keyed by extension version, 0 is the default\n const signedExtensions = (chain.metadata.extrinsic.signedExtensions[0] ?? []).map(\n (ext) => ext.identifier\n )\n\n const basePayload: SignerPayloadJSON = {\n address: signerConfig.address,\n genesisHash: genesisHash.asHex() as `0x${string}`,\n blockHash,\n method: method.asHex(),\n signedExtensions,\n nonce: toPjsHex(nonce, 4),\n specVersion: toPjsHex(chainInfo.specVersion, 4),\n transactionVersion: toPjsHex(chainInfo.transactionVersion, 4),\n blockNumber: toPjsHex(blockNumber, 4),\n era: toHex(era) as `0x${string}`,\n tip: toPjsHex(0, 16), // TODO gas station (required for Astar)\n assetId: undefined,\n version: 4,\n }\n\n const { payload, txMetadata } = getPayloadWithMetadataHash(chain, chainInfo, basePayload)\n const shortMetadata = txMetadata ? (toHex(txMetadata) as `0x${string}`) : undefined\n\n // Avail support\n if (payload.signedExtensions.includes(\"CheckAppId\"))\n (payload as SignerPayloadJSON & { appId: number }).appId = 0\n\n log.log(\"[sapi] payload\", { newPayload: payload, txMetadata })\n\n return {\n payload,\n txMetadata, // TODO remove\n shortMetadata,\n }\n}\n","import type { SignerPayloadJSON } from \"@polkadot/types/types\"\nimport { merkleizeMetadata } from \"@polkadot-api/merkleize-metadata\"\nimport { toHex } from \"@polkadot-api/utils\"\n\nimport log from \"../log\"\nimport { getTypeRegistry } from \"./getTypeRegistry\"\nimport type { Chain, ChainInfo } from \"./types\"\n\nexport const getPayloadWithMetadataHash = (\n chain: Chain,\n chainInfo: ChainInfo,\n payload: SignerPayloadJSON\n): { payload: SignerPayloadJSON; txMetadata?: Uint8Array } => {\n if (!chain.hasCheckMetadataHash || !payload.signedExtensions.includes(\"CheckMetadataHash\"))\n return {\n payload,\n txMetadata: undefined,\n }\n\n try {\n const { decimals, symbol: tokenSymbol } = chain.token\n const { base58Prefix, specName, specVersion } = chainInfo\n const metadataHashInputs = { tokenSymbol, decimals, base58Prefix, specName, specVersion }\n\n // since ultimately this needs a V15 object, would be nice if this accepted one directly as input\n const merkleizedMetadata = merkleizeMetadata(chain.hexMetadata, metadataHashInputs)\n const metadataHash = toHex(merkleizedMetadata.digest()) as `0x${string}`\n log.log(\"metadataHash\", metadataHash, metadataHashInputs)\n\n const payloadWithMetadataHash = {\n ...payload,\n mode: 1,\n metadataHash,\n withSignedTransaction: true,\n }\n\n // TODO do this without PJS / registry => waiting for @polkadot-api/tx-utils\n // const { extra, additionalSigned } = getSignedExtensionValues(payload, metadata)\n // const badExtPayload = mergeUint8([fromHex(payload.method), ...extra, ...additionalSigned])\n\n const registry = getTypeRegistry(chain, payload)\n const extPayload = registry.createType(\"ExtrinsicPayload\", payloadWithMetadataHash)\n const barePayload = extPayload.toU8a(true)\n\n const txMetadata = merkleizedMetadata.getProofForExtrinsicPayload(barePayload)\n\n return {\n payload: payloadWithMetadataHash,\n txMetadata,\n }\n } catch (err) {\n log.error(\"Failed to get shortened metadata\", { error: err })\n return {\n payload,\n txMetadata: undefined,\n }\n }\n}\n","import { getSendRequestResult } from \"./getSendRequestResult\"\nimport type { Chain } from \"./types\"\n\nexport const getStorageValue = async <T>(\n chain: Chain,\n pallet: string,\n entry: string,\n keys: unknown[],\n at?: string\n) => {\n const storageCodec = chain.builder.buildStorage(pallet, entry)\n const stateKey = storageCodec.keys.enc(...keys)\n\n const hexValue = await getSendRequestResult<string | null>(chain, \"state_getStorage\", [\n stateKey,\n at,\n ])\n if (!hexValue) return null as T // caller will need to expect null when applicable\n\n return storageCodec.value.dec(hexValue) as T\n}\n","import { Bytes, enhanceEncoder, u16 } from \"@polkadot-api/substrate-bindings\"\n\n//////////////////////////////////////////////////////////////////////////////////////////////////////////////\n//////////////////////////// Utilities from PAPI /////////////////////////////\n//////////////////////////////////////////////////////////////////////////////////////////////////////////////\n\nexport const toPjsHex = (value: number | bigint, minByteLen?: number) => {\n let inner = value.toString(16)\n inner = (inner.length % 2 ? \"0\" : \"\") + inner\n const nPaddedBytes = Math.max(0, (minByteLen || 0) - inner.length / 2)\n return `0x${\"00\".repeat(nPaddedBytes)}${inner}` as `0x${string}`\n}\n\nexport const mortal = enhanceEncoder(Bytes(2).enc, (value: { period: number; phase: number }) => {\n const factor = Math.max(value.period >> 12, 1)\n const left = Math.min(Math.max(trailingZeroes(value.period) - 1, 1), 15)\n const right = (value.phase / factor) << 4\n return u16.enc(left | right)\n})\n\nfunction trailingZeroes(n: number) {\n let i = 0\n while (!(n & 1)) {\n i++\n n >>= 1\n }\n return i\n}\n","import { getLookupFn } from \"@polkadot-api/metadata-builders\"\n\nimport log from \"../log\"\nimport type { Chain } from \"./types\"\n\nexport const hasEvent = (chain: Chain, pallet: string, event: string): boolean => {\n try {\n const palletDef = chain.metadata.pallets.find((p) => p.name === pallet)\n if (typeof palletDef?.events !== \"number\") return false\n\n const lookup = getLookupFn(chain.metadata)\n const palletEvents = lookup(palletDef.events)\n\n return palletEvents.type === \"enum\" && event in palletEvents.innerDocs\n } catch (err) {\n log.error(\"Failed to check event existence\", { pallet, event, err })\n return false\n }\n}\n","import type { SignerPayloadJSON } from \"@polkadot/types/types\"\nimport type { ScaleApiSubmitMode } from \"../types\"\nimport type { Chain } from \"./types\"\n\nexport const submit = async (\n chain: Chain,\n payload: SignerPayloadJSON,\n signature?: `0x${string}`,\n txInfo?: unknown,\n mode?: ScaleApiSubmitMode\n): Promise<{ hash: `0x${string}`; innerHash?: `0x${string}` }> => {\n switch (mode) {\n case \"bittensor-mev-shield\":\n if (signature)\n throw new Error(\"Signature should not be provided when using bittensor-mev-shield mode\")\n return chain.connector.submitWithBittensorMevShield(payload, txInfo)\n\n default:\n return chain.connector.submit(payload, signature, txInfo)\n }\n}\n"],"mappings":"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","names":["toHex","toHex","submit","mergeUint8","toHex","Binary","toHex","toHex","Binary","mergeUint8","toHex","getLookupFn","getLookupFn"]}
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@talismn/sapi",
|
|
3
|
-
"version": "0.1.
|
|
3
|
+
"version": "0.1.6",
|
|
4
4
|
"author": "Talisman",
|
|
5
5
|
"homepage": "https://talisman.xyz",
|
|
6
6
|
"license": "GPL-3.0-or-later",
|
|
@@ -27,7 +27,6 @@
|
|
|
27
27
|
"@polkadot-api/utils": "0.2.0",
|
|
28
28
|
"@polkadot/types": "16.1.2",
|
|
29
29
|
"@polkadot/types-codec": "16.1.2",
|
|
30
|
-
"@polkadot/util": "13.5.3",
|
|
31
30
|
"anylogger": "^1.0.11",
|
|
32
31
|
"polkadot-api": "1.23.3",
|
|
33
32
|
"scale-ts": "^1.6.1",
|