@talismn/sapi 0.1.1 → 0.1.2

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.2",
89
89
  author: "Talisman",
90
90
  homepage: "https://talisman.xyz",
91
91
  license: "GPL-3.0-or-later",
@@ -210,6 +210,87 @@ 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 signedExtensions = metadata.extrinsic.signedExtensions;
220
+ const extensionsArray = Array.isArray(signedExtensions[0]) ? signedExtensions[0] : signedExtensions;
221
+ const extraDec = import_substrate_bindings.Struct.dec(
222
+ Object.fromEntries(
223
+ extensionsArray.map((x) => [x.identifier, builder.buildDefinition(x.type)[1]])
224
+ )
225
+ );
226
+ let callDec;
227
+ const { extrinsic } = metadata;
228
+ if ("address" in extrinsic) {
229
+ callDec = builder.buildDefinition(extrinsic.call)[1];
230
+ } else {
231
+ const params = metadata.lookup[extrinsic.type]?.params;
232
+ const callType = params?.find((v) => v.name === "Call")?.type;
233
+ if (callType == null) throw new Error("Call type not found in metadata");
234
+ callDec = builder.buildDefinition(callType)[1];
235
+ }
236
+ let addressDec;
237
+ let signatureDec;
238
+ if ("address" in extrinsic) {
239
+ addressDec = builder.buildDefinition(extrinsic.address)[1];
240
+ signatureDec = builder.buildDefinition(extrinsic.signature)[1];
241
+ } else {
242
+ const params = metadata.lookup[extrinsic.type]?.params;
243
+ const addrType = params?.find((v) => v.name === "Address")?.type;
244
+ const sigType = params?.find((v) => v.name === "Signature")?.type;
245
+ if (addrType == null || sigType == null)
246
+ throw new Error("Address or Signature type not found");
247
+ addressDec = builder.buildDefinition(addrType)[1];
248
+ signatureDec = builder.buildDefinition(sigType)[1];
249
+ }
250
+ const v4Body = import_substrate_bindings.Struct.dec({
251
+ address: addressDec,
252
+ signature: signatureDec,
253
+ extra: extraDec,
254
+ callData: allBytesDec
255
+ });
256
+ const extrinsicDecoder = (0, import_substrate_bindings.enhanceDecoder)(
257
+ (0, import_substrate_bindings.createDecoder)((data) => {
258
+ const len = import_substrate_bindings.compactNumber.dec(data);
259
+ const { type, version } = import_substrate_bindings.extrinsicFormat[1](data);
260
+ if (type === "bare") {
261
+ return { len, version, type, callData: allBytesDec(data) };
262
+ }
263
+ if (type === "signed") {
264
+ return { len, version, type, ...v4Body(data) };
265
+ }
266
+ const extensionVersion = import_substrate_bindings.u8.dec(data);
267
+ const extra = extraDec(data);
268
+ return {
269
+ len,
270
+ type,
271
+ version,
272
+ extensionVersion,
273
+ extra,
274
+ callData: allBytesDec(data)
275
+ };
276
+ }),
277
+ (v) => ({
278
+ ...v,
279
+ call: callDec(v.callData.asBytes())
280
+ })
281
+ );
282
+ const decoded = extrinsicDecoder(extrinsicHex);
283
+ return {
284
+ pallet: decoded.call.type,
285
+ method: decoded.call.value.type,
286
+ args: decoded.call.value.value
287
+ };
288
+ } catch (err) {
289
+ console.error("[SAPI] Failed to decode extrinsic:", err);
290
+ return null;
291
+ }
292
+ };
293
+
213
294
  // src/helpers/getDryRunCall.ts
214
295
  var import_polkadot_api = require("polkadot-api");
215
296
 
@@ -389,12 +470,11 @@ var stateCall = async (request, method, resultType, args, blockHash, isCacheable
389
470
  // src/helpers/getTypeRegistry.ts
390
471
  var import_types = require("@polkadot/types");
391
472
  var getTypeRegistry = (chain, payload) => {
392
- log_default.log(`[sapi] getTypeRegistry begin: ${Date.now()}`);
473
+ log_default.debug(`[sapi] getTypeRegistry for payload (${chain.token.symbol})`);
393
474
  const registry = new import_types.TypeRegistry();
394
475
  if (chain.registryTypes) registry.register(chain.registryTypes);
395
476
  const meta = new import_types.Metadata(registry, chain.hexMetadata);
396
477
  registry.setMetadata(meta, payload.signedExtensions, chain.signedExtensions);
397
- log_default.log(`[sapi] getTypeRegistry end: ${Date.now()}`);
398
478
  return registry;
399
479
  };
400
480
 
@@ -509,18 +589,18 @@ var getStorageValue = async (chain, pallet, entry, keys, at) => {
509
589
  };
510
590
 
511
591
  // src/helpers/papi.ts
512
- var import_substrate_bindings = require("@polkadot-api/substrate-bindings");
592
+ var import_substrate_bindings2 = require("@polkadot-api/substrate-bindings");
513
593
  var toPjsHex = (value, minByteLen) => {
514
594
  let inner = value.toString(16);
515
595
  inner = (inner.length % 2 ? "0" : "") + inner;
516
596
  const nPaddedBytes = Math.max(0, (minByteLen || 0) - inner.length / 2);
517
597
  return `0x${"00".repeat(nPaddedBytes)}${inner}`;
518
598
  };
519
- var mortal = (0, import_substrate_bindings.enhanceEncoder)((0, import_substrate_bindings.Bytes)(2).enc, (value) => {
599
+ var mortal = (0, import_substrate_bindings2.enhanceEncoder)((0, import_substrate_bindings2.Bytes)(2).enc, (value) => {
520
600
  const factor = Math.max(value.period >> 12, 1);
521
601
  const left = Math.min(Math.max(trailingZeroes(value.period) - 1, 1), 15);
522
602
  const right = value.phase / factor << 4;
523
- return import_substrate_bindings.u16.enc(left | right);
603
+ return import_substrate_bindings2.u16.enc(left | right);
524
604
  });
525
605
  function trailingZeroes(n) {
526
606
  let i = 0;
@@ -629,6 +709,7 @@ var getScaleApi = (connector, hexMetadata, token, hasCheckMetadataHash, signedEx
629
709
  getStorage: (pallet, entry, keys, at) => getStorageValue(chain, pallet, entry, keys, at),
630
710
  getDecodedCall: (pallet, method, args) => getDecodedCall(pallet, method, args),
631
711
  getDecodedCallFromPayload: (payload) => getDecodedCallFromPayload(chain, payload),
712
+ getDecodedCallFromExtrinsic: (extrinsicHex) => getDecodedCallFromExtrinsic(chain, extrinsicHex),
632
713
  getExtrinsicPayload: (pallet, method, args, config) => getSignerPayloadJSON(chain, pallet, method, args, config, chainInfo),
633
714
  getFeeEstimate: (payload) => getFeeEstimate(chain, payload, chainInfo),
634
715
  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.2\",\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 {\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 const signedExtensions = metadata.extrinsic.signedExtensions\n const extensionsArray = Array.isArray(signedExtensions[0])\n ? signedExtensions[0]\n : signedExtensions\n\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 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\"\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.2",
51
51
  author: "Talisman",
52
52
  homepage: "https://talisman.xyz",
53
53
  license: "GPL-3.0-or-later",
@@ -172,6 +172,95 @@ 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 signedExtensions = metadata.extrinsic.signedExtensions;
190
+ const extensionsArray = Array.isArray(signedExtensions[0]) ? signedExtensions[0] : signedExtensions;
191
+ const extraDec = Struct.dec(
192
+ Object.fromEntries(
193
+ extensionsArray.map((x) => [x.identifier, builder.buildDefinition(x.type)[1]])
194
+ )
195
+ );
196
+ let callDec;
197
+ const { extrinsic } = metadata;
198
+ if ("address" in extrinsic) {
199
+ callDec = builder.buildDefinition(extrinsic.call)[1];
200
+ } else {
201
+ const params = metadata.lookup[extrinsic.type]?.params;
202
+ const callType = params?.find((v) => v.name === "Call")?.type;
203
+ if (callType == null) throw new Error("Call type not found in metadata");
204
+ callDec = builder.buildDefinition(callType)[1];
205
+ }
206
+ let addressDec;
207
+ let signatureDec;
208
+ if ("address" in extrinsic) {
209
+ addressDec = builder.buildDefinition(extrinsic.address)[1];
210
+ signatureDec = builder.buildDefinition(extrinsic.signature)[1];
211
+ } else {
212
+ const params = metadata.lookup[extrinsic.type]?.params;
213
+ const addrType = params?.find((v) => v.name === "Address")?.type;
214
+ const sigType = params?.find((v) => v.name === "Signature")?.type;
215
+ if (addrType == null || sigType == null)
216
+ throw new Error("Address or Signature type not found");
217
+ addressDec = builder.buildDefinition(addrType)[1];
218
+ signatureDec = builder.buildDefinition(sigType)[1];
219
+ }
220
+ const v4Body = Struct.dec({
221
+ address: addressDec,
222
+ signature: signatureDec,
223
+ extra: extraDec,
224
+ callData: allBytesDec
225
+ });
226
+ const extrinsicDecoder = enhanceDecoder(
227
+ createDecoder((data) => {
228
+ const len = compactNumber.dec(data);
229
+ const { type, version } = extrinsicFormat[1](data);
230
+ if (type === "bare") {
231
+ return { len, version, type, callData: allBytesDec(data) };
232
+ }
233
+ if (type === "signed") {
234
+ return { len, version, type, ...v4Body(data) };
235
+ }
236
+ const extensionVersion = u8.dec(data);
237
+ const extra = extraDec(data);
238
+ return {
239
+ len,
240
+ type,
241
+ version,
242
+ extensionVersion,
243
+ extra,
244
+ callData: allBytesDec(data)
245
+ };
246
+ }),
247
+ (v) => ({
248
+ ...v,
249
+ call: callDec(v.callData.asBytes())
250
+ })
251
+ );
252
+ const decoded = extrinsicDecoder(extrinsicHex);
253
+ return {
254
+ pallet: decoded.call.type,
255
+ method: decoded.call.value.type,
256
+ args: decoded.call.value.value
257
+ };
258
+ } catch (err) {
259
+ console.error("[SAPI] Failed to decode extrinsic:", err);
260
+ return null;
261
+ }
262
+ };
263
+
175
264
  // src/helpers/getDryRunCall.ts
176
265
  import { Enum } from "polkadot-api";
177
266
 
@@ -351,12 +440,11 @@ var stateCall = async (request, method, resultType, args, blockHash, isCacheable
351
440
  // src/helpers/getTypeRegistry.ts
352
441
  import { Metadata, TypeRegistry } from "@polkadot/types";
353
442
  var getTypeRegistry = (chain, payload) => {
354
- log_default.log(`[sapi] getTypeRegistry begin: ${Date.now()}`);
443
+ log_default.debug(`[sapi] getTypeRegistry for payload (${chain.token.symbol})`);
355
444
  const registry = new TypeRegistry();
356
445
  if (chain.registryTypes) registry.register(chain.registryTypes);
357
446
  const meta = new Metadata(registry, chain.hexMetadata);
358
447
  registry.setMetadata(meta, payload.signedExtensions, chain.signedExtensions);
359
- log_default.log(`[sapi] getTypeRegistry end: ${Date.now()}`);
360
448
  return registry;
361
449
  };
362
450
 
@@ -591,6 +679,7 @@ var getScaleApi = (connector, hexMetadata, token, hasCheckMetadataHash, signedEx
591
679
  getStorage: (pallet, entry, keys, at) => getStorageValue(chain, pallet, entry, keys, at),
592
680
  getDecodedCall: (pallet, method, args) => getDecodedCall(pallet, method, args),
593
681
  getDecodedCallFromPayload: (payload) => getDecodedCallFromPayload(chain, payload),
682
+ getDecodedCallFromExtrinsic: (extrinsicHex) => getDecodedCallFromExtrinsic(chain, extrinsicHex),
594
683
  getExtrinsicPayload: (pallet, method, args, config) => getSignerPayloadJSON(chain, pallet, method, args, config, chainInfo),
595
684
  getFeeEstimate: (payload) => getFeeEstimate(chain, payload, chainInfo),
596
685
  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.2\",\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 {\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 const signedExtensions = metadata.extrinsic.signedExtensions\n const extensionsArray = Array.isArray(signedExtensions[0])\n ? signedExtensions[0]\n : signedExtensions\n\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 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\"\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.2",
4
4
  "author": "Talisman",
5
5
  "homepage": "https://talisman.xyz",
6
6
  "license": "GPL-3.0-or-later",
@@ -31,7 +31,7 @@
31
31
  "anylogger": "^1.0.11",
32
32
  "polkadot-api": "1.13.1",
33
33
  "scale-ts": "^1.6.1",
34
- "@talismn/scale": "0.3.1"
34
+ "@talismn/scale": "0.3.2"
35
35
  },
36
36
  "devDependencies": {
37
37
  "typescript": "^5.6.3",