@talismn/sapi 0.1.1 → 0.1.3

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.d.mts CHANGED
@@ -31,8 +31,10 @@ type SapiConnectorProps = {
31
31
  }>;
32
32
  submitWithBittensorMevShield?: (payload: SignerPayloadJSON, txInfo?: any) => Promise<{
33
33
  hash: `0x${string}`;
34
+ innerHash?: `0x${string}`;
34
35
  }>;
35
36
  };
37
+ type ScaleApiSubmitMode = "default" | "bittensor-mev-shield";
36
38
 
37
39
  type SapiConnector = Required<SapiConnectorProps>;
38
40
 
@@ -52,8 +54,6 @@ type Chain = {
52
54
  metadataRpc: `0x${string}`;
53
55
  };
54
56
 
55
- type ScaleApiSubmitMode = "default" | "bittensor-mev-shield";
56
-
57
57
  type ScaleApi = NonNullable<ReturnType<typeof getScaleApi>>;
58
58
  declare const getScaleApi: (connector: SapiConnectorProps, hexMetadata: `0x${string}`, token: {
59
59
  symbol: string;
@@ -82,6 +82,7 @@ declare const getScaleApi: (connector: SapiConnectorProps, hexMetadata: `0x${str
82
82
  getDecodedCallFromPayload: <Res extends DecodedCall>(payload: {
83
83
  method: SignerPayloadJSON["method"];
84
84
  }) => Res;
85
+ getDecodedCallFromExtrinsic: <Res extends DecodedCall>(extrinsicHex: `0x${string}`) => Res | null;
85
86
  getExtrinsicPayload: (pallet: string, method: string, args: unknown, config: PayloadSignerConfig) => Promise<{
86
87
  payload: SignerPayloadJSON;
87
88
  txMetadata: Uint8Array | undefined;
@@ -92,6 +93,7 @@ declare const getScaleApi: (connector: SapiConnectorProps, hexMetadata: `0x${str
92
93
  getTypeRegistry: (payload: SignerPayloadJSON) => _polkadot_types.TypeRegistry;
93
94
  submit: (payload: SignerPayloadJSON, signature?: `0x${string}`, txInfo?: unknown, mode?: ScaleApiSubmitMode) => Promise<{
94
95
  hash: `0x${string}`;
96
+ innerHash?: `0x${string}`;
95
97
  }>;
96
98
  getCallDocs: (pallet: string, method: string) => string | null;
97
99
  getDryRunCall: <T>(from: string, decodedCall: DecodedCall<unknown>) => Promise<{
@@ -108,4 +110,4 @@ declare const getScaleApi: (connector: SapiConnectorProps, hexMetadata: `0x${str
108
110
  isApiAvailable: (name: string, method: string) => boolean;
109
111
  };
110
112
 
111
- export { type DecodedCall, type JsonRpcRequestSend, MAX_SUPPORTED_METADATA_VERSION, type PayloadSignerConfig, type SapiConnectorProps, type ScaleApi, fetchBestMetadata, getScaleApi };
113
+ export { type DecodedCall, type JsonRpcRequestSend, MAX_SUPPORTED_METADATA_VERSION, type PayloadSignerConfig, type SapiConnectorProps, type ScaleApi, type ScaleApiSubmitMode, fetchBestMetadata, getScaleApi };
package/dist/index.d.ts CHANGED
@@ -31,8 +31,10 @@ type SapiConnectorProps = {
31
31
  }>;
32
32
  submitWithBittensorMevShield?: (payload: SignerPayloadJSON, txInfo?: any) => Promise<{
33
33
  hash: `0x${string}`;
34
+ innerHash?: `0x${string}`;
34
35
  }>;
35
36
  };
37
+ type ScaleApiSubmitMode = "default" | "bittensor-mev-shield";
36
38
 
37
39
  type SapiConnector = Required<SapiConnectorProps>;
38
40
 
@@ -52,8 +54,6 @@ type Chain = {
52
54
  metadataRpc: `0x${string}`;
53
55
  };
54
56
 
55
- type ScaleApiSubmitMode = "default" | "bittensor-mev-shield";
56
-
57
57
  type ScaleApi = NonNullable<ReturnType<typeof getScaleApi>>;
58
58
  declare const getScaleApi: (connector: SapiConnectorProps, hexMetadata: `0x${string}`, token: {
59
59
  symbol: string;
@@ -82,6 +82,7 @@ declare const getScaleApi: (connector: SapiConnectorProps, hexMetadata: `0x${str
82
82
  getDecodedCallFromPayload: <Res extends DecodedCall>(payload: {
83
83
  method: SignerPayloadJSON["method"];
84
84
  }) => Res;
85
+ getDecodedCallFromExtrinsic: <Res extends DecodedCall>(extrinsicHex: `0x${string}`) => Res | null;
85
86
  getExtrinsicPayload: (pallet: string, method: string, args: unknown, config: PayloadSignerConfig) => Promise<{
86
87
  payload: SignerPayloadJSON;
87
88
  txMetadata: Uint8Array | undefined;
@@ -92,6 +93,7 @@ declare const getScaleApi: (connector: SapiConnectorProps, hexMetadata: `0x${str
92
93
  getTypeRegistry: (payload: SignerPayloadJSON) => _polkadot_types.TypeRegistry;
93
94
  submit: (payload: SignerPayloadJSON, signature?: `0x${string}`, txInfo?: unknown, mode?: ScaleApiSubmitMode) => Promise<{
94
95
  hash: `0x${string}`;
96
+ innerHash?: `0x${string}`;
95
97
  }>;
96
98
  getCallDocs: (pallet: string, method: string) => string | null;
97
99
  getDryRunCall: <T>(from: string, decodedCall: DecodedCall<unknown>) => Promise<{
@@ -108,4 +110,4 @@ declare const getScaleApi: (connector: SapiConnectorProps, hexMetadata: `0x${str
108
110
  isApiAvailable: (name: string, method: string) => boolean;
109
111
  };
110
112
 
111
- export { type DecodedCall, type JsonRpcRequestSend, MAX_SUPPORTED_METADATA_VERSION, type PayloadSignerConfig, type SapiConnectorProps, type ScaleApi, fetchBestMetadata, getScaleApi };
113
+ export { type DecodedCall, type JsonRpcRequestSend, MAX_SUPPORTED_METADATA_VERSION, type PayloadSignerConfig, type SapiConnectorProps, type ScaleApi, type ScaleApiSubmitMode, fetchBestMetadata, getScaleApi };
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.1",
88
+ version: "0.1.3",
89
89
  author: "Talisman",
90
90
  homepage: "https://talisman.xyz",
91
91
  license: "GPL-3.0-or-later",
@@ -112,16 +112,16 @@ var package_default = {
112
112
  typecheck: "tsc --noEmit"
113
113
  },
114
114
  dependencies: {
115
- "@polkadot-api/merkleize-metadata": "1.1.18",
116
- "@polkadot-api/metadata-builders": "0.12.2",
117
- "@polkadot-api/substrate-bindings": "0.14.0",
115
+ "@polkadot-api/merkleize-metadata": "1.1.29",
116
+ "@polkadot-api/metadata-builders": "0.13.9",
117
+ "@polkadot-api/substrate-bindings": "0.17.0",
118
118
  "@polkadot-api/utils": "0.2.0",
119
119
  "@polkadot/types": "16.1.2",
120
120
  "@polkadot/types-codec": "16.1.2",
121
121
  "@polkadot/util": "13.5.3",
122
122
  "@talismn/scale": "workspace:*",
123
123
  anylogger: "^1.0.11",
124
- "polkadot-api": "1.13.1",
124
+ "polkadot-api": "1.23.3",
125
125
  "scale-ts": "^1.6.1"
126
126
  },
127
127
  devDependencies: {
@@ -210,6 +210,86 @@ var getDecodedCallFromPayload = (chain, payload) => {
210
210
  };
211
211
  };
212
212
 
213
+ // src/helpers/getDecodedCallFromExtrinsic.ts
214
+ var import_substrate_bindings = require("@polkadot-api/substrate-bindings");
215
+ var allBytesDec = (0, import_substrate_bindings.Bin)(Infinity).dec;
216
+ var getDecodedCallFromExtrinsic = (chain, extrinsicHex) => {
217
+ try {
218
+ const { metadata, builder } = chain;
219
+ const extensionsArray = metadata.extrinsic.signedExtensions[0] ?? [];
220
+ const extraDec = import_substrate_bindings.Struct.dec(
221
+ Object.fromEntries(
222
+ extensionsArray.map((x) => [x.identifier, builder.buildDefinition(x.type)[1]])
223
+ )
224
+ );
225
+ let callDec;
226
+ const { extrinsic } = metadata;
227
+ if ("address" in extrinsic) {
228
+ callDec = builder.buildDefinition(extrinsic.call)[1];
229
+ } else {
230
+ const params = metadata.lookup[extrinsic.type]?.params;
231
+ const callType = params?.find((v) => v.name === "Call")?.type;
232
+ if (callType == null) throw new Error("Call type not found in metadata");
233
+ callDec = builder.buildDefinition(callType)[1];
234
+ }
235
+ let addressDec;
236
+ let signatureDec;
237
+ if ("address" in extrinsic) {
238
+ addressDec = builder.buildDefinition(extrinsic.address)[1];
239
+ signatureDec = builder.buildDefinition(extrinsic.signature)[1];
240
+ } else {
241
+ const params = metadata.lookup[extrinsic.type]?.params;
242
+ const addrType = params?.find((v) => v.name === "Address")?.type;
243
+ const sigType = params?.find((v) => v.name === "Signature")?.type;
244
+ if (addrType == null || sigType == null)
245
+ throw new Error("Address or Signature type not found");
246
+ addressDec = builder.buildDefinition(addrType)[1];
247
+ signatureDec = builder.buildDefinition(sigType)[1];
248
+ }
249
+ const v4Body = import_substrate_bindings.Struct.dec({
250
+ address: addressDec,
251
+ signature: signatureDec,
252
+ extra: extraDec,
253
+ callData: allBytesDec
254
+ });
255
+ const extrinsicDecoder = (0, import_substrate_bindings.enhanceDecoder)(
256
+ (0, import_substrate_bindings.createDecoder)((data) => {
257
+ const len = import_substrate_bindings.compactNumber.dec(data);
258
+ const { type, version } = import_substrate_bindings.extrinsicFormat[1](data);
259
+ if (type === "bare") {
260
+ return { len, version, type, callData: allBytesDec(data) };
261
+ }
262
+ if (type === "signed") {
263
+ return { len, version, type, ...v4Body(data) };
264
+ }
265
+ const extensionVersion = import_substrate_bindings.u8.dec(data);
266
+ const extra = extraDec(data);
267
+ return {
268
+ len,
269
+ type,
270
+ version,
271
+ extensionVersion,
272
+ extra,
273
+ callData: allBytesDec(data)
274
+ };
275
+ }),
276
+ (v) => ({
277
+ ...v,
278
+ call: callDec(v.callData.asBytes())
279
+ })
280
+ );
281
+ const decoded = extrinsicDecoder(extrinsicHex);
282
+ return {
283
+ pallet: decoded.call.type,
284
+ method: decoded.call.value.type,
285
+ args: decoded.call.value.value
286
+ };
287
+ } catch (err) {
288
+ console.error("[SAPI] Failed to decode extrinsic:", err);
289
+ return null;
290
+ }
291
+ };
292
+
213
293
  // src/helpers/getDryRunCall.ts
214
294
  var import_polkadot_api = require("polkadot-api");
215
295
 
@@ -389,12 +469,11 @@ var stateCall = async (request, method, resultType, args, blockHash, isCacheable
389
469
  // src/helpers/getTypeRegistry.ts
390
470
  var import_types = require("@polkadot/types");
391
471
  var getTypeRegistry = (chain, payload) => {
392
- log_default.log(`[sapi] getTypeRegistry begin: ${Date.now()}`);
472
+ log_default.debug(`[sapi] getTypeRegistry for payload (${chain.token.symbol})`);
393
473
  const registry = new import_types.TypeRegistry();
394
474
  if (chain.registryTypes) registry.register(chain.registryTypes);
395
475
  const meta = new import_types.Metadata(registry, chain.hexMetadata);
396
476
  registry.setMetadata(meta, payload.signedExtensions, chain.signedExtensions);
397
- log_default.log(`[sapi] getTypeRegistry end: ${Date.now()}`);
398
477
  return registry;
399
478
  };
400
479
 
@@ -509,18 +588,18 @@ var getStorageValue = async (chain, pallet, entry, keys, at) => {
509
588
  };
510
589
 
511
590
  // src/helpers/papi.ts
512
- var import_substrate_bindings = require("@polkadot-api/substrate-bindings");
591
+ var import_substrate_bindings2 = require("@polkadot-api/substrate-bindings");
513
592
  var toPjsHex = (value, minByteLen) => {
514
593
  let inner = value.toString(16);
515
594
  inner = (inner.length % 2 ? "0" : "") + inner;
516
595
  const nPaddedBytes = Math.max(0, (minByteLen || 0) - inner.length / 2);
517
596
  return `0x${"00".repeat(nPaddedBytes)}${inner}`;
518
597
  };
519
- var mortal = (0, import_substrate_bindings.enhanceEncoder)((0, import_substrate_bindings.Bytes)(2).enc, (value) => {
598
+ var mortal = (0, import_substrate_bindings2.enhanceEncoder)((0, import_substrate_bindings2.Bytes)(2).enc, (value) => {
520
599
  const factor = Math.max(value.period >> 12, 1);
521
600
  const left = Math.min(Math.max(trailingZeroes(value.period) - 1, 1), 15);
522
601
  const right = value.phase / factor << 4;
523
- return import_substrate_bindings.u16.enc(left | right);
602
+ return import_substrate_bindings2.u16.enc(left | right);
524
603
  });
525
604
  function trailingZeroes(n) {
526
605
  let i = 0;
@@ -557,7 +636,9 @@ var getSignerPayloadJSON = async (chain, palletName, methodName, args, signerCon
557
636
  blockHash = binBlockHash.asHex();
558
637
  }
559
638
  const era = mortal({ period: ERA_PERIOD, phase: blockNumber % ERA_PERIOD });
560
- const signedExtensions = chain.metadata.extrinsic.signedExtensions.map((ext) => ext.identifier);
639
+ const signedExtensions = (chain.metadata.extrinsic.signedExtensions[0] ?? []).map(
640
+ (ext) => ext.identifier
641
+ );
561
642
  const basePayload = {
562
643
  address: signerConfig.address,
563
644
  genesisHash: genesisHash.asHex(),
@@ -629,6 +710,7 @@ var getScaleApi = (connector, hexMetadata, token, hasCheckMetadataHash, signedEx
629
710
  getStorage: (pallet, entry, keys, at) => getStorageValue(chain, pallet, entry, keys, at),
630
711
  getDecodedCall: (pallet, method, args) => getDecodedCall(pallet, method, args),
631
712
  getDecodedCallFromPayload: (payload) => getDecodedCallFromPayload(chain, payload),
713
+ getDecodedCallFromExtrinsic: (extrinsicHex) => getDecodedCallFromExtrinsic(chain, extrinsicHex),
632
714
  getExtrinsicPayload: (pallet, method, args, config) => getSignerPayloadJSON(chain, pallet, method, args, config, chainInfo),
633
715
  getFeeEstimate: (payload) => getFeeEstimate(chain, payload, chainInfo),
634
716
  getRuntimeCallValue: (apiName, method, args) => getRuntimeCallResult(chain, apiName, method, args),
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/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/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 { 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 { isApiAvailable } from \"./helpers/isApiAvailable\"\nimport { type ScaleApiSubmitMode, submit } from \"./helpers/submit\"\nimport type { Chain } from \"./helpers/types\"\nimport type { DecodedCall, PayloadSignerConfig, SapiConnectorProps } 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 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}\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.1\",\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.18\",\n \"@polkadot-api/metadata-builders\": \"0.12.2\",\n \"@polkadot-api/substrate-bindings\": \"0.14.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.13.1\",\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 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.log(`[sapi] getTypeRegistry begin: ${Date.now()}`)\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 log.log(`[sapi] getTypeRegistry end: ${Date.now()}`)\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 const signedExtensions = chain.metadata.extrinsic.signedExtensions.map((ext) => ext.identifier)\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 type { SignerPayloadJSON } from \"@polkadot/types/types\"\n\nimport type { Chain } from \"./types\"\n\nexport type ScaleApiSubmitMode = \"default\" | \"bittensor-mev-shield\"\n\nexport const submit = async (\n chain: Chain,\n payload: SignerPayloadJSON,\n signature?: `0x${string}`,\n txInfo?: unknown,\n mode?: ScaleApiSubmitMode\n) => {\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"]}
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/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 { 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}\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.3\",\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 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"]}
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.1",
50
+ version: "0.1.3",
51
51
  author: "Talisman",
52
52
  homepage: "https://talisman.xyz",
53
53
  license: "GPL-3.0-or-later",
@@ -74,16 +74,16 @@ var package_default = {
74
74
  typecheck: "tsc --noEmit"
75
75
  },
76
76
  dependencies: {
77
- "@polkadot-api/merkleize-metadata": "1.1.18",
78
- "@polkadot-api/metadata-builders": "0.12.2",
79
- "@polkadot-api/substrate-bindings": "0.14.0",
77
+ "@polkadot-api/merkleize-metadata": "1.1.29",
78
+ "@polkadot-api/metadata-builders": "0.13.9",
79
+ "@polkadot-api/substrate-bindings": "0.17.0",
80
80
  "@polkadot-api/utils": "0.2.0",
81
81
  "@polkadot/types": "16.1.2",
82
82
  "@polkadot/types-codec": "16.1.2",
83
83
  "@polkadot/util": "13.5.3",
84
84
  "@talismn/scale": "workspace:*",
85
85
  anylogger: "^1.0.11",
86
- "polkadot-api": "1.13.1",
86
+ "polkadot-api": "1.23.3",
87
87
  "scale-ts": "^1.6.1"
88
88
  },
89
89
  devDependencies: {
@@ -172,6 +172,94 @@ var getDecodedCallFromPayload = (chain, payload) => {
172
172
  };
173
173
  };
174
174
 
175
+ // src/helpers/getDecodedCallFromExtrinsic.ts
176
+ import {
177
+ Bin,
178
+ compactNumber,
179
+ createDecoder,
180
+ enhanceDecoder,
181
+ extrinsicFormat,
182
+ Struct,
183
+ u8
184
+ } from "@polkadot-api/substrate-bindings";
185
+ var allBytesDec = Bin(Infinity).dec;
186
+ var getDecodedCallFromExtrinsic = (chain, extrinsicHex) => {
187
+ try {
188
+ const { metadata, builder } = chain;
189
+ const extensionsArray = metadata.extrinsic.signedExtensions[0] ?? [];
190
+ const extraDec = Struct.dec(
191
+ Object.fromEntries(
192
+ extensionsArray.map((x) => [x.identifier, builder.buildDefinition(x.type)[1]])
193
+ )
194
+ );
195
+ let callDec;
196
+ const { extrinsic } = metadata;
197
+ if ("address" in extrinsic) {
198
+ callDec = builder.buildDefinition(extrinsic.call)[1];
199
+ } else {
200
+ const params = metadata.lookup[extrinsic.type]?.params;
201
+ const callType = params?.find((v) => v.name === "Call")?.type;
202
+ if (callType == null) throw new Error("Call type not found in metadata");
203
+ callDec = builder.buildDefinition(callType)[1];
204
+ }
205
+ let addressDec;
206
+ let signatureDec;
207
+ if ("address" in extrinsic) {
208
+ addressDec = builder.buildDefinition(extrinsic.address)[1];
209
+ signatureDec = builder.buildDefinition(extrinsic.signature)[1];
210
+ } else {
211
+ const params = metadata.lookup[extrinsic.type]?.params;
212
+ const addrType = params?.find((v) => v.name === "Address")?.type;
213
+ const sigType = params?.find((v) => v.name === "Signature")?.type;
214
+ if (addrType == null || sigType == null)
215
+ throw new Error("Address or Signature type not found");
216
+ addressDec = builder.buildDefinition(addrType)[1];
217
+ signatureDec = builder.buildDefinition(sigType)[1];
218
+ }
219
+ const v4Body = Struct.dec({
220
+ address: addressDec,
221
+ signature: signatureDec,
222
+ extra: extraDec,
223
+ callData: allBytesDec
224
+ });
225
+ const extrinsicDecoder = enhanceDecoder(
226
+ createDecoder((data) => {
227
+ const len = compactNumber.dec(data);
228
+ const { type, version } = extrinsicFormat[1](data);
229
+ if (type === "bare") {
230
+ return { len, version, type, callData: allBytesDec(data) };
231
+ }
232
+ if (type === "signed") {
233
+ return { len, version, type, ...v4Body(data) };
234
+ }
235
+ const extensionVersion = u8.dec(data);
236
+ const extra = extraDec(data);
237
+ return {
238
+ len,
239
+ type,
240
+ version,
241
+ extensionVersion,
242
+ extra,
243
+ callData: allBytesDec(data)
244
+ };
245
+ }),
246
+ (v) => ({
247
+ ...v,
248
+ call: callDec(v.callData.asBytes())
249
+ })
250
+ );
251
+ const decoded = extrinsicDecoder(extrinsicHex);
252
+ return {
253
+ pallet: decoded.call.type,
254
+ method: decoded.call.value.type,
255
+ args: decoded.call.value.value
256
+ };
257
+ } catch (err) {
258
+ console.error("[SAPI] Failed to decode extrinsic:", err);
259
+ return null;
260
+ }
261
+ };
262
+
175
263
  // src/helpers/getDryRunCall.ts
176
264
  import { Enum } from "polkadot-api";
177
265
 
@@ -351,12 +439,11 @@ var stateCall = async (request, method, resultType, args, blockHash, isCacheable
351
439
  // src/helpers/getTypeRegistry.ts
352
440
  import { Metadata, TypeRegistry } from "@polkadot/types";
353
441
  var getTypeRegistry = (chain, payload) => {
354
- log_default.log(`[sapi] getTypeRegistry begin: ${Date.now()}`);
442
+ log_default.debug(`[sapi] getTypeRegistry for payload (${chain.token.symbol})`);
355
443
  const registry = new TypeRegistry();
356
444
  if (chain.registryTypes) registry.register(chain.registryTypes);
357
445
  const meta = new Metadata(registry, chain.hexMetadata);
358
446
  registry.setMetadata(meta, payload.signedExtensions, chain.signedExtensions);
359
- log_default.log(`[sapi] getTypeRegistry end: ${Date.now()}`);
360
447
  return registry;
361
448
  };
362
449
 
@@ -519,7 +606,9 @@ var getSignerPayloadJSON = async (chain, palletName, methodName, args, signerCon
519
606
  blockHash = binBlockHash.asHex();
520
607
  }
521
608
  const era = mortal({ period: ERA_PERIOD, phase: blockNumber % ERA_PERIOD });
522
- const signedExtensions = chain.metadata.extrinsic.signedExtensions.map((ext) => ext.identifier);
609
+ const signedExtensions = (chain.metadata.extrinsic.signedExtensions[0] ?? []).map(
610
+ (ext) => ext.identifier
611
+ );
523
612
  const basePayload = {
524
613
  address: signerConfig.address,
525
614
  genesisHash: genesisHash.asHex(),
@@ -591,6 +680,7 @@ var getScaleApi = (connector, hexMetadata, token, hasCheckMetadataHash, signedEx
591
680
  getStorage: (pallet, entry, keys, at) => getStorageValue(chain, pallet, entry, keys, at),
592
681
  getDecodedCall: (pallet, method, args) => getDecodedCall(pallet, method, args),
593
682
  getDecodedCallFromPayload: (payload) => getDecodedCallFromPayload(chain, payload),
683
+ getDecodedCallFromExtrinsic: (extrinsicHex) => getDecodedCallFromExtrinsic(chain, extrinsicHex),
594
684
  getExtrinsicPayload: (pallet, method, args, config) => getSignerPayloadJSON(chain, pallet, method, args, config, chainInfo),
595
685
  getFeeEstimate: (payload) => getFeeEstimate(chain, payload, chainInfo),
596
686
  getRuntimeCallValue: (apiName, method, args) => getRuntimeCallResult(chain, apiName, method, args),
@@ -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/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/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 { 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 { isApiAvailable } from \"./helpers/isApiAvailable\"\nimport { type ScaleApiSubmitMode, submit } from \"./helpers/submit\"\nimport type { Chain } from \"./helpers/types\"\nimport type { DecodedCall, PayloadSignerConfig, SapiConnectorProps } 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 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}\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.1\",\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.18\",\n \"@polkadot-api/metadata-builders\": \"0.12.2\",\n \"@polkadot-api/substrate-bindings\": \"0.14.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.13.1\",\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 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.log(`[sapi] getTypeRegistry begin: ${Date.now()}`)\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 log.log(`[sapi] getTypeRegistry end: ${Date.now()}`)\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 const signedExtensions = chain.metadata.extrinsic.signedExtensions.map((ext) => ext.identifier)\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 type { SignerPayloadJSON } from \"@polkadot/types/types\"\n\nimport type { Chain } from \"./types\"\n\nexport type ScaleApiSubmitMode = \"default\" | \"bittensor-mev-shield\"\n\nexport const submit = async (\n chain: Chain,\n payload: SignerPayloadJSON,\n signature?: `0x${string}`,\n txInfo?: unknown,\n mode?: ScaleApiSubmitMode\n) => {\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"]}
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/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 { 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}\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.3\",\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 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"]}
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@talismn/sapi",
3
- "version": "0.1.1",
3
+ "version": "0.1.3",
4
4
  "author": "Talisman",
5
5
  "homepage": "https://talisman.xyz",
6
6
  "license": "GPL-3.0-or-later",
@@ -21,17 +21,17 @@
21
21
  "node": ">=20"
22
22
  },
23
23
  "dependencies": {
24
- "@polkadot-api/merkleize-metadata": "1.1.18",
25
- "@polkadot-api/metadata-builders": "0.12.2",
26
- "@polkadot-api/substrate-bindings": "0.14.0",
24
+ "@polkadot-api/merkleize-metadata": "1.1.29",
25
+ "@polkadot-api/metadata-builders": "0.13.9",
26
+ "@polkadot-api/substrate-bindings": "0.17.0",
27
27
  "@polkadot-api/utils": "0.2.0",
28
28
  "@polkadot/types": "16.1.2",
29
29
  "@polkadot/types-codec": "16.1.2",
30
30
  "@polkadot/util": "13.5.3",
31
31
  "anylogger": "^1.0.11",
32
- "polkadot-api": "1.13.1",
32
+ "polkadot-api": "1.23.3",
33
33
  "scale-ts": "^1.6.1",
34
- "@talismn/scale": "0.3.1"
34
+ "@talismn/scale": "0.3.3"
35
35
  },
36
36
  "devDependencies": {
37
37
  "typescript": "^5.6.3",