@talismn/scale 0.0.0-pr2295-20260110044132 → 0.0.0-pr2295-20260110050558
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/index.js +1 -1
- package/dist/index.js.map +1 -1
- package/dist/index.mjs +1 -1
- package/dist/index.mjs.map +1 -1
- package/package.json +2 -2
package/dist/index.js
CHANGED
|
@@ -74,7 +74,7 @@ var import_anylogger = __toESM(require("anylogger"));
|
|
|
74
74
|
// package.json
|
|
75
75
|
var package_default = {
|
|
76
76
|
name: "@talismn/scale",
|
|
77
|
-
version: "0.0.0-pr2295-
|
|
77
|
+
version: "0.0.0-pr2295-20260110050558",
|
|
78
78
|
author: "Talisman",
|
|
79
79
|
homepage: "https://talisman.xyz",
|
|
80
80
|
license: "GPL-3.0-or-later",
|
package/dist/index.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["../src/index.ts","../src/papito.ts","../src/log.ts","../package.json","../src/util/compactMetadata.ts","../src/util/decodeScale.ts","../src/util/encodeMetadata.ts","../src/util/encodeStateKey.ts","../src/util/getMetadataVersion.ts","../src/util/serdePapi.ts","../src/util/parseMetadataRpc.ts","../src/util/getStorageKeyPrefix.ts","../src/util/hash.ts","../src/util/getConstantValueFromMetadata.ts"],"sourcesContent":["// TODO: Get the DX of this lib as close as possible to the DX of `const jsonResult = '{\"someKey\":\"someValue\"}'; JSON.decode(jsonResult)`\n\nexport * from \"./papito\"\nexport * from \"./util\"\n","import { getDynamicBuilder } from \"@polkadot-api/metadata-builders\"\n\nexport {\n getDynamicBuilder,\n getLookupFn,\n type MetadataLookup,\n} from \"@polkadot-api/metadata-builders\"\nexport type { Codec, UnifiedMetadata } from \"@polkadot-api/substrate-bindings\"\nexport {\n decAnyMetadata,\n unifyMetadata,\n metadata,\n Binary,\n FixedSizeBinary,\n} from \"@polkadot-api/substrate-bindings\"\nexport { toHex, fromHex, mergeUint8 } from \"@polkadot-api/utils\"\n\n/** Constant: https://docs.substrate.io/build/application-development/#metadata-format */\nexport const magicNumber = 1635018093\n\nexport type MetadataBuilder = ReturnType<typeof getDynamicBuilder>\n","import anylogger from \"anylogger\"\n\nimport packageJson from \"../package.json\"\n\nexport default anylogger(packageJson.name)\n","{\n \"name\": \"@talismn/scale\",\n \"version\": \"0.0.0-pr2295-20260110044132\",\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/scale\",\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 \"lint\": \"eslint src --max-warnings 0\",\n \"clean\": \"rm -rf dist .turbo node_modules\",\n \"build\": \"tsup\"\n },\n \"dependencies\": {\n \"@polkadot-api/metadata-builders\": \"0.12.2\",\n \"@polkadot-api/substrate-bindings\": \"0.14.0\",\n \"@polkadot-api/utils\": \"0.2.0\",\n \"anylogger\": \"^1.0.11\",\n \"scale-ts\": \"^1.6.1\"\n },\n \"devDependencies\": {\n \"@talismn/eslint-config\": \"workspace:*\",\n \"@talismn/tsconfig\": \"workspace:*\",\n \"eslint\": \"^8.57.1\",\n \"typescript\": \"^5.6.3\"\n },\n \"eslintConfig\": {\n \"root\": true,\n \"extends\": [\n \"@talismn/eslint-config/base\"\n ]\n },\n \"types\": \"./dist/index.d.ts\",\n \"exports\": {\n \".\": {\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 { Metadata } from \"@polkadot-api/substrate-bindings\"\n\nimport log from \"../log\"\nimport { Prettify } from \"./Prettify\"\n\nexport type MetadataType = SupportedMetadata[\"lookup\"][number]\nexport type MetadataPallet = SupportedMetadata[\"pallets\"][number]\nexport type MetadataStorageItem = NonNullable<MetadataPallet[\"storage\"]>[\"items\"][number]\n\ntype SupportedMetadata = Extract<Metadata[\"metadata\"], { tag: SupportedMetadataVersion }>[\"value\"]\ntype SupportedMetadataVersion = \"v14\" | \"v15\" | \"v16\"\n\n/**\n * Converts a `Metadata` into a `MiniMetadata`.\n *\n * A `MiniMetadata` only contains the types inside of its `lookup` which are relevant for\n * the storage queries specified in `palletsAndItems`.\n *\n * E.g. if `palletsAndItems` is `{ pallet: \"System\", items: [\"Account\"] }`, then only the\n * types used in the `System.Account` storage query will remain inside of metadata.lookups.\n */\nexport const compactMetadata = (\n anyMetadata: Metadata,\n palletsAndItems: Array<{ pallet: string; constants?: string[]; items: string[] }> = [],\n runtimeApisAndMethods: Array<{ runtimeApi: string; methods: string[] }> = [],\n extraKeepTypes: number[] = [],\n) => {\n if (!isCompactableMetadata(anyMetadata))\n throw new Error(`Metadata version ${anyMetadata.metadata.tag} not supported in compactMetadata`)\n\n const metadata: SupportedMetadata = anyMetadata.metadata.value\n\n // remove pallets we don't care about\n metadata.pallets = metadata.pallets.filter((pallet) =>\n // keep this pallet if it's listed in `palletsAndItems`\n palletsAndItems.some(({ pallet: palletName }) => pallet.name === palletName),\n ) as typeof metadata.pallets\n\n // remove fields we don't care about from each pallet, and extract types for each storage item we care about\n const palletsKeepTypes = palletsAndItems.flatMap(\n ({ pallet: palletName, constants: constantNames, items: itemNames }) => {\n const pallet = metadata.pallets.find((pallet) => pallet.name === palletName)\n if (!pallet) return []\n\n // remove pallet fields we don't care about\n pallet.calls = undefined\n pallet.constants = constantNames\n ? pallet.constants.filter((constant) => constantNames.includes(constant.name))\n : []\n // v15 (NOT v14) has docs\n if (\"docs\" in pallet) pallet.docs = []\n pallet.errors = undefined\n pallet.events = undefined\n\n if (!pallet.storage) return []\n\n // filter and extract storage items we care about\n pallet.storage.items = pallet.storage.items.filter((item) =>\n itemNames.some((itemName) => item.name === itemName),\n )\n\n return [\n ...pallet.storage.items\n .flatMap((item) => [\n // each type can be either \"Plain\" or \"Map\"\n // if it's \"Plain\" we only need to get the value type\n // if it's a \"Map\" we want to keep both the key AND the value types\n item.type.tag === \"plain\" && item.type.value,\n item.type.tag === \"map\" && item.type.value.key,\n item.type.tag === \"map\" && item.type.value.value,\n ])\n .filter((type): type is number => typeof type === \"number\"),\n ...pallet.constants.flatMap((constant) => constant.type),\n ]\n },\n )\n\n // remove runtime apis we don't care about\n let runtimeApisKeepTypes: number[] = []\n if (\"apis\" in metadata) {\n // metadata is v15 (NOT v14)\n\n // keep this api if it's listed in `runtimeApisAndMethods`\n metadata.apis = metadata.apis.filter((runtimeApi) =>\n runtimeApisAndMethods.some(\n ({ runtimeApi: runtimeApiName }) => runtimeApi.name === runtimeApiName,\n ),\n )\n\n // remove methods we don't care about from each runtime api, and extract types for each call's params and result\n runtimeApisKeepTypes = runtimeApisAndMethods.flatMap(\n ({ runtimeApi: runtimeApiName, methods: methodNames }) => {\n const runtimeApi = metadata.apis.find((runtimeApi) => runtimeApi.name === runtimeApiName)\n if (!runtimeApi) return []\n\n // remove runtime fields we don't care about\n runtimeApi.docs = []\n\n if (!runtimeApi.methods) return []\n\n // filter and extract methods we care about\n runtimeApi.methods = runtimeApi.methods.filter((method) =>\n methodNames.some((methodName) => method.name === methodName),\n )\n\n return runtimeApi.methods.flatMap((method) => [\n // each method has an array of input types (for the params)\n ...method.inputs.map((input) => input.type),\n // and one output type (for the result)\n method.output,\n ])\n },\n )\n }\n\n // this is a set of type ids which we plan to keep in our compacted metadata\n // anything not in this set will be deleted\n // we start off with just the types of the state calls we plan to make,\n // then we run those types through a function (addDependentTypes) which will also include\n // all of the types which those types depend on - recursively\n const keepTypes = new Set([...palletsKeepTypes, ...runtimeApisKeepTypes])\n extraKeepTypes?.forEach((type) => keepTypes.add(type))\n\n // recursively find all the types which our keepTypes depend on and add them to the keepTypes set\n const metadataTysMap = new Map(metadata.lookup.map((ty) => [ty.id, ty]))\n addDependentTypes(metadataTysMap, keepTypes, [...keepTypes])\n\n // ditch the types we aren't keeping\n metadata.lookup = metadata.lookup.filter((type) => keepTypes.has(type.id))\n\n // update all type ids to be sequential (fill the gaps left by the deleted types)\n const newTypeIds = new Map<number, number>()\n metadata.lookup.forEach((type, index) => newTypeIds.set(type.id, index))\n const getNewTypeId = (oldTypeId: number): number => {\n const newTypeId = newTypeIds.get(oldTypeId)\n if (typeof newTypeId !== \"number\") log.error(`Failed to find newTypeId for type ${oldTypeId}`)\n return newTypeId ?? 0\n }\n remapTypeIds(metadata, getNewTypeId)\n\n if (\"address\" in metadata.extrinsic) metadata.extrinsic.address = 0\n if (\"call\" in metadata.extrinsic) metadata.extrinsic.call = 0\n if (\"signature\" in metadata.extrinsic) metadata.extrinsic.signature = 0\n if (\"extra\" in metadata.extrinsic) metadata.extrinsic.extra = 0\n if (\"signedExtensions\" in metadata.extrinsic) metadata.extrinsic.signedExtensions = []\n if (\"outerEnums\" in metadata) {\n // metadata is v15 (NOT v14)\n metadata.outerEnums.call = 0\n metadata.outerEnums.error = 0\n metadata.outerEnums.event = 0\n }\n}\n\ntype CompactableMetadata = Prettify<\n Omit<Metadata, \"metadata\"> & {\n metadata: Extract<Metadata[\"metadata\"], { tag: SupportedMetadataVersion }>\n }\n>\nconst isCompactableMetadata = (metadata: Metadata): metadata is CompactableMetadata => {\n switch (metadata.metadata.tag) {\n case \"v14\":\n case \"v15\":\n case \"v16\":\n return true\n default:\n return false\n }\n}\n\nconst addDependentTypes = (\n metadataTysMap: Map<MetadataType[\"id\"], MetadataType>,\n keepTypes: Set<number>,\n types: number[],\n // Prevent stack overflow when a type references itself\n addedTypes: Set<number> = new Set(),\n) => {\n const addDependentSubTypes = (subTypes: number[]) =>\n addDependentTypes(metadataTysMap, keepTypes, subTypes, addedTypes)\n\n for (const typeId of types) {\n const type = metadataTysMap.get(typeId)\n if (!type) {\n log.warn(`Unable to find type with id ${typeId}`)\n continue\n }\n\n if (addedTypes.has(type.id)) continue\n keepTypes.add(type.id)\n addedTypes.add(type.id)\n\n const paramTypes = type.params\n .map((param) => param.type)\n .filter((type): type is number => typeof type === \"number\")\n addDependentSubTypes(paramTypes)\n\n switch (type.def.tag) {\n case \"array\":\n addDependentSubTypes([type.def.value.type])\n break\n\n case \"bitSequence\":\n addDependentSubTypes([type.def.value.bitOrderType, type.def.value.bitStoreType])\n break\n\n case \"compact\":\n addDependentSubTypes([type.def.value])\n break\n\n case \"composite\":\n addDependentSubTypes(\n type.def.value\n .map((field) => field.type)\n .filter((type): type is number => typeof type === \"number\"),\n )\n break\n\n case \"primitive\":\n break\n\n case \"sequence\":\n addDependentSubTypes([type.def.value])\n break\n\n case \"tuple\":\n addDependentSubTypes(\n type.def.value.filter((type): type is number => typeof type === \"number\"),\n )\n break\n\n case \"variant\":\n addDependentSubTypes(\n type.def.value\n .flatMap((member) => member.fields.map((field) => field.type))\n .filter((type): type is number => typeof type === \"number\"),\n )\n break\n\n default: {\n // force compilation error if any types don't have a case\n const exhaustiveCheck: never = type.def\n log.error(`Unhandled V15Type type ${exhaustiveCheck}`)\n }\n }\n }\n}\n\nconst remapTypeIds = (metadata: SupportedMetadata, getNewTypeId: (oldTypeId: number) => number) => {\n remapLookupTypeIds(metadata, getNewTypeId)\n remapStorageTypeIds(metadata, getNewTypeId)\n remapRuntimeApisTypeIds(metadata, getNewTypeId)\n}\n\nconst remapLookupTypeIds = (\n metadata: SupportedMetadata,\n getNewTypeId: (oldTypeId: number) => number,\n) => {\n for (const type of metadata.lookup) {\n type.id = getNewTypeId(type.id)\n\n for (const param of type.params) {\n if (typeof param.type !== \"number\") continue\n param.type = getNewTypeId(param.type)\n }\n\n switch (type.def.tag) {\n case \"array\":\n type.def.value.type = getNewTypeId(type.def.value.type)\n break\n\n case \"bitSequence\":\n type.def.value.bitOrderType = getNewTypeId(type.def.value.bitOrderType)\n type.def.value.bitStoreType = getNewTypeId(type.def.value.bitStoreType)\n break\n\n case \"compact\":\n type.def.value = getNewTypeId(type.def.value)\n break\n\n case \"composite\":\n for (const field of type.def.value) {\n if (typeof field.type !== \"number\") continue\n field.type = getNewTypeId(field.type)\n }\n break\n\n case \"primitive\":\n break\n\n case \"sequence\":\n type.def.value = getNewTypeId(type.def.value)\n break\n\n case \"tuple\":\n type.def.value = type.def.value.map((type) => {\n if (typeof type !== \"number\") return type\n return getNewTypeId(type)\n })\n break\n\n case \"variant\":\n for (const member of type.def.value) {\n for (const field of member.fields) {\n if (typeof field.type !== \"number\") continue\n field.type = getNewTypeId(field.type)\n }\n }\n break\n\n default: {\n // force compilation error if any types don't have a case\n const exhaustiveCheck: never = type.def\n log.error(`Unhandled V15Type type ${exhaustiveCheck}`)\n }\n }\n }\n}\n\nconst remapStorageTypeIds = (\n metadata: SupportedMetadata,\n getNewTypeId: (oldTypeId: number) => number,\n) => {\n for (const pallet of metadata.pallets) {\n for (const item of pallet.storage?.items ?? []) {\n if (item.type.tag === \"plain\") item.type.value = getNewTypeId(item.type.value)\n if (item.type.tag === \"map\") {\n item.type.value.key = getNewTypeId(item.type.value.key)\n item.type.value.value = getNewTypeId(item.type.value.value)\n }\n }\n for (const constant of pallet.constants ?? []) {\n constant.type = getNewTypeId(constant.type)\n }\n }\n}\n\nconst remapRuntimeApisTypeIds = (\n metadata: SupportedMetadata,\n getNewTypeId: (oldTypeId: number) => number,\n) => {\n for (const runtimeApi of metadata.apis) {\n for (const method of runtimeApi.methods ?? []) {\n for (const input of method.inputs) {\n input.type = getNewTypeId(input.type)\n }\n method.output = getNewTypeId(method.output)\n }\n }\n}\n","import log from \"../log\"\nimport { MetadataBuilder } from \"../papito\"\n\ntype ScaleStorageCoder = ReturnType<MetadataBuilder[\"buildStorage\"]>\n\nexport const decodeScale = <T>(\n scaleCoder: ScaleStorageCoder | undefined,\n change: string | null,\n error?: string,\n): T | null => {\n if (change === null) return null\n\n try {\n return (scaleCoder?.value?.dec(change) as T | undefined) ?? null\n } catch (cause) {\n log.warn(error ?? `Failed to decode ${change}`, cause)\n return null\n }\n}\n","import { Metadata } from \"@polkadot-api/substrate-bindings\"\n\nimport { metadata as scaleMetadata, toHex } from \"../papito\"\n\nexport const encodeMetadata = (metadata: Metadata) =>\n toHex(scaleMetadata.enc(metadata)) as `0x${string}`\n","import log from \"../log\"\nimport { MetadataBuilder } from \"../papito\"\n\nexport type ScaleStorageCoder = ReturnType<MetadataBuilder[\"buildStorage\"]>\n\nexport const encodeStateKey = (\n scaleCoder: ScaleStorageCoder | undefined,\n error?: string,\n ...args: any[] // eslint-disable-line @typescript-eslint/no-explicit-any\n): `0x${string}` | undefined => {\n try {\n return scaleCoder?.keys?.enc(...args) as `0x${string}`\n } catch (cause) {\n log.warn(error ?? `Failed to encode stateKey ${JSON.stringify(args)}`, cause)\n return\n }\n}\n","import { Struct, u8, u32 } from \"scale-ts\"\n\n/**\n * Extracts the `version` u8 from a SCALE-encoded metadata blob and returns it as a `number`.\n *\n * Only reads the first 40 bytes of the blob.\n */\nexport const getMetadataVersion = (metadataRpc: string | Uint8Array | ArrayBuffer) => {\n try {\n return Struct({\n magicNumber: u32,\n version: u8,\n }).dec(metadataRpc).version\n } catch {\n return 0\n }\n}\n","import { Binary } from \"@polkadot-api/substrate-bindings\"\n\n/**\n * For the substrate-tokens (and other) modules, we configure the `onChainId` field in chaindata to tell the module how to query each token.\n * These queries are made to the tokens pallet.\n * E.g. api.query.Tokens.Account(accountAddress, papiParse(onChainId))\n *\n * The `onChainId` field on chaindata must be a JSON-parseable string, but for some SCALE types (especially the Binary type) we must\n * use specific `polkadot-api` classes to handle SCALE-encoding the statekey.\n *\n * Some examples:\n * Input: `5`\n * Output: `5`\n *\n * Input: `{ type: \"DexShare\", value: [ { type: \"Token\", value: { type: \"ACA\" } }, { type: \"Token\", value: { type: \"AUSD\" } } ] }`\n * Output: `Enum(\"DexShare\", [Enum(\"Token\", Enum(\"ACA\")), Enum(\"Token\", Enum(\"AUSD\"))])`\n *\n * Input: `{ type: \"LiquidCrowdloan\", value: 13 }`\n * Output: `Enum(\"LiquidCrowdloan\", 13)`\n *\n * Input: `{ type: \"NativeToken\", value: \"bigint:2\" }`\n * Output: `Enum(\"NativeToken\", 2n)`\n *\n * Input: `{ type: \"Erc20\", value: \"hex:0x07df96d1341a7d16ba1ad431e2c847d978bc2bce\" }`\n * Output: `Enum(\"Erc20\", Binary.fromHex(\"0x07df96d1341a7d16ba1ad431e2c847d978bc2bce\"))`\n *\n * Input: `{ type: \"Stellar\", value: { code: \"bin:TZS\", issuer: \"hex:0x34c94b2a4ba9e8b57b22547dcbb30f443c4cb02da3829a89aa1bd4780e4466ba\" } }`\n * Output: `Enum(\"Stellar\", { code: Binary.fromText(\"TZS\"), issuer: Binary.fromHex(\"0x34c94b2a4ba9e8b57b22547dcbb30f443c4cb02da3829a89aa1bd4780e4466ba\") })`\n */\nexport const papiParse = <T = unknown>(text: string | T): T => {\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n const reviver = (_key: string, value: any) => {\n if (typeof value !== \"string\") return value\n if (value.startsWith(\"bigint:\")) return BigInt(value.slice(\"bigint:\".length))\n if (value.startsWith(\"hex:\")) return Binary.fromHex(value.slice(\"hex:\".length))\n if (value.startsWith(\"bin:\")) return Binary.fromText(value.slice(\"bin:\".length))\n return value\n }\n\n if (typeof text !== \"string\") return text\n return JSON.parse(text, reviver)\n}\n\nexport const papiStringify = (\n value: any, // eslint-disable-line @typescript-eslint/no-explicit-any\n space?: string | number,\n): string => {\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n const replacer = (_key: string, value: any) => {\n if (typeof value === \"bigint\") return `bigint:${String(value)}`\n if (value instanceof Binary) return `hex:${value.asHex()}`\n return value\n }\n\n return JSON.stringify(value, replacer, space)\n}\n","import { getDynamicBuilder, getLookupFn } from \"@polkadot-api/metadata-builders\"\nimport { decAnyMetadata, unifyMetadata } from \"@polkadot-api/substrate-bindings\"\n\nexport const parseMetadataRpc = (metadataRpc: `0x${string}`) => {\n const metadata = decAnyMetadata(metadataRpc)\n const unifiedMetadata = unifyMetadata(metadata)\n const lookupFn = getLookupFn(unifiedMetadata)\n const builder = getDynamicBuilder(lookupFn)\n\n return { metadata, unifiedMetadata, lookupFn, builder }\n}\n","import { Twox128 } from \"@polkadot-api/substrate-bindings\"\nimport { toHex } from \"@polkadot-api/utils\"\n\nexport const getStorageKeyPrefix = (palletName: string, storageName: string) => {\n const palletHash = Twox128(new TextEncoder().encode(palletName))\n const storageHash = Twox128(new TextEncoder().encode(storageName))\n\n // Concatenate and convert to hex\n const combined = new Uint8Array(palletHash.length + storageHash.length)\n combined.set(palletHash, 0)\n combined.set(storageHash, palletHash.length)\n\n return toHex(combined)\n}\n","export {\n Twox128,\n Blake2128,\n Blake2128Concat,\n Blake2256,\n Blake3256,\n Blake3256Concat,\n Twox256,\n Twox64Concat,\n} from \"@polkadot-api/substrate-bindings\"\n","import log from \"../log\"\nimport { MetadataBuilder, UnifiedMetadata } from \"../papito\"\nimport { parseMetadataRpc } from \"./parseMetadataRpc\"\n\nexport const getConstantValueFromMetadata = <T>(\n metadata: `0x${string}` | { builder: MetadataBuilder; unifiedMetadata: UnifiedMetadata },\n pallet: string,\n constant: string,\n) => {\n const { builder, unifiedMetadata } =\n typeof metadata === \"string\" ? parseMetadataRpc(metadata) : metadata\n\n return getConstantValueInner<T>(builder, unifiedMetadata, pallet, constant)\n}\n\nconst getConstantValueInner = <T>(\n builder: MetadataBuilder,\n unifiedMetadata: UnifiedMetadata,\n pallet: string,\n constant: string,\n) => {\n try {\n const storageCodec = builder.buildConstant(pallet, constant)\n\n const encodedValue = unifiedMetadata.pallets\n .find(({ name }) => name === pallet)\n ?.constants.find(({ name }) => name === constant)?.value\n\n if (!encodedValue) throw new Error(`Constant ${pallet}.${constant} not found`)\n\n return storageCodec.dec(encodedValue) as T\n } catch (err) {\n log.error(\"Failed to get constant value from metadata\", {\n err,\n pallet,\n constant,\n })\n throw err\n }\n}\n"],"mappings":"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","names":["anylogger","metadata","pallet","runtimeApi","type","metadata","import_substrate_bindings","value","import_metadata_builders","import_substrate_bindings","metadata","import_substrate_bindings","import_utils","import_substrate_bindings","metadata"]}
|
|
1
|
+
{"version":3,"sources":["../src/index.ts","../src/papito.ts","../src/log.ts","../package.json","../src/util/compactMetadata.ts","../src/util/decodeScale.ts","../src/util/encodeMetadata.ts","../src/util/encodeStateKey.ts","../src/util/getMetadataVersion.ts","../src/util/serdePapi.ts","../src/util/parseMetadataRpc.ts","../src/util/getStorageKeyPrefix.ts","../src/util/hash.ts","../src/util/getConstantValueFromMetadata.ts"],"sourcesContent":["// TODO: Get the DX of this lib as close as possible to the DX of `const jsonResult = '{\"someKey\":\"someValue\"}'; JSON.decode(jsonResult)`\n\nexport * from \"./papito\"\nexport * from \"./util\"\n","import { getDynamicBuilder } from \"@polkadot-api/metadata-builders\"\n\nexport {\n getDynamicBuilder,\n getLookupFn,\n type MetadataLookup,\n} from \"@polkadot-api/metadata-builders\"\nexport type { Codec, UnifiedMetadata } from \"@polkadot-api/substrate-bindings\"\nexport {\n decAnyMetadata,\n unifyMetadata,\n metadata,\n Binary,\n FixedSizeBinary,\n} from \"@polkadot-api/substrate-bindings\"\nexport { toHex, fromHex, mergeUint8 } from \"@polkadot-api/utils\"\n\n/** Constant: https://docs.substrate.io/build/application-development/#metadata-format */\nexport const magicNumber = 1635018093\n\nexport type MetadataBuilder = ReturnType<typeof getDynamicBuilder>\n","import anylogger from \"anylogger\"\n\nimport packageJson from \"../package.json\"\n\nexport default anylogger(packageJson.name)\n","{\n \"name\": \"@talismn/scale\",\n \"version\": \"0.0.0-pr2295-20260110050558\",\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/scale\",\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 \"lint\": \"eslint src --max-warnings 0\",\n \"clean\": \"rm -rf dist .turbo node_modules\",\n \"build\": \"tsup\"\n },\n \"dependencies\": {\n \"@polkadot-api/metadata-builders\": \"0.12.2\",\n \"@polkadot-api/substrate-bindings\": \"0.14.0\",\n \"@polkadot-api/utils\": \"0.2.0\",\n \"anylogger\": \"^1.0.11\",\n \"scale-ts\": \"^1.6.1\"\n },\n \"devDependencies\": {\n \"@talismn/eslint-config\": \"workspace:*\",\n \"@talismn/tsconfig\": \"workspace:*\",\n \"eslint\": \"^8.57.1\",\n \"typescript\": \"^5.6.3\"\n },\n \"eslintConfig\": {\n \"root\": true,\n \"extends\": [\n \"@talismn/eslint-config/base\"\n ]\n },\n \"types\": \"./dist/index.d.ts\",\n \"exports\": {\n \".\": {\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 { Metadata } from \"@polkadot-api/substrate-bindings\"\n\nimport log from \"../log\"\nimport { Prettify } from \"./Prettify\"\n\nexport type MetadataType = SupportedMetadata[\"lookup\"][number]\nexport type MetadataPallet = SupportedMetadata[\"pallets\"][number]\nexport type MetadataStorageItem = NonNullable<MetadataPallet[\"storage\"]>[\"items\"][number]\n\ntype SupportedMetadata = Extract<Metadata[\"metadata\"], { tag: SupportedMetadataVersion }>[\"value\"]\ntype SupportedMetadataVersion = \"v14\" | \"v15\" | \"v16\"\n\n/**\n * Converts a `Metadata` into a `MiniMetadata`.\n *\n * A `MiniMetadata` only contains the types inside of its `lookup` which are relevant for\n * the storage queries specified in `palletsAndItems`.\n *\n * E.g. if `palletsAndItems` is `{ pallet: \"System\", items: [\"Account\"] }`, then only the\n * types used in the `System.Account` storage query will remain inside of metadata.lookups.\n */\nexport const compactMetadata = (\n anyMetadata: Metadata,\n palletsAndItems: Array<{ pallet: string; constants?: string[]; items: string[] }> = [],\n runtimeApisAndMethods: Array<{ runtimeApi: string; methods: string[] }> = [],\n extraKeepTypes: number[] = [],\n) => {\n if (!isCompactableMetadata(anyMetadata))\n throw new Error(`Metadata version ${anyMetadata.metadata.tag} not supported in compactMetadata`)\n\n const metadata: SupportedMetadata = anyMetadata.metadata.value\n\n // remove pallets we don't care about\n metadata.pallets = metadata.pallets.filter((pallet) =>\n // keep this pallet if it's listed in `palletsAndItems`\n palletsAndItems.some(({ pallet: palletName }) => pallet.name === palletName),\n ) as typeof metadata.pallets\n\n // remove fields we don't care about from each pallet, and extract types for each storage item we care about\n const palletsKeepTypes = palletsAndItems.flatMap(\n ({ pallet: palletName, constants: constantNames, items: itemNames }) => {\n const pallet = metadata.pallets.find((pallet) => pallet.name === palletName)\n if (!pallet) return []\n\n // remove pallet fields we don't care about\n pallet.calls = undefined\n pallet.constants = constantNames\n ? pallet.constants.filter((constant) => constantNames.includes(constant.name))\n : []\n // v15 (NOT v14) has docs\n if (\"docs\" in pallet) pallet.docs = []\n pallet.errors = undefined\n pallet.events = undefined\n\n if (!pallet.storage) return []\n\n // filter and extract storage items we care about\n pallet.storage.items = pallet.storage.items.filter((item) =>\n itemNames.some((itemName) => item.name === itemName),\n )\n\n return [\n ...pallet.storage.items\n .flatMap((item) => [\n // each type can be either \"Plain\" or \"Map\"\n // if it's \"Plain\" we only need to get the value type\n // if it's a \"Map\" we want to keep both the key AND the value types\n item.type.tag === \"plain\" && item.type.value,\n item.type.tag === \"map\" && item.type.value.key,\n item.type.tag === \"map\" && item.type.value.value,\n ])\n .filter((type): type is number => typeof type === \"number\"),\n ...pallet.constants.flatMap((constant) => constant.type),\n ]\n },\n )\n\n // remove runtime apis we don't care about\n let runtimeApisKeepTypes: number[] = []\n if (\"apis\" in metadata) {\n // metadata is v15 (NOT v14)\n\n // keep this api if it's listed in `runtimeApisAndMethods`\n metadata.apis = metadata.apis.filter((runtimeApi) =>\n runtimeApisAndMethods.some(\n ({ runtimeApi: runtimeApiName }) => runtimeApi.name === runtimeApiName,\n ),\n )\n\n // remove methods we don't care about from each runtime api, and extract types for each call's params and result\n runtimeApisKeepTypes = runtimeApisAndMethods.flatMap(\n ({ runtimeApi: runtimeApiName, methods: methodNames }) => {\n const runtimeApi = metadata.apis.find((runtimeApi) => runtimeApi.name === runtimeApiName)\n if (!runtimeApi) return []\n\n // remove runtime fields we don't care about\n runtimeApi.docs = []\n\n if (!runtimeApi.methods) return []\n\n // filter and extract methods we care about\n runtimeApi.methods = runtimeApi.methods.filter((method) =>\n methodNames.some((methodName) => method.name === methodName),\n )\n\n return runtimeApi.methods.flatMap((method) => [\n // each method has an array of input types (for the params)\n ...method.inputs.map((input) => input.type),\n // and one output type (for the result)\n method.output,\n ])\n },\n )\n }\n\n // this is a set of type ids which we plan to keep in our compacted metadata\n // anything not in this set will be deleted\n // we start off with just the types of the state calls we plan to make,\n // then we run those types through a function (addDependentTypes) which will also include\n // all of the types which those types depend on - recursively\n const keepTypes = new Set([...palletsKeepTypes, ...runtimeApisKeepTypes])\n extraKeepTypes?.forEach((type) => keepTypes.add(type))\n\n // recursively find all the types which our keepTypes depend on and add them to the keepTypes set\n const metadataTysMap = new Map(metadata.lookup.map((ty) => [ty.id, ty]))\n addDependentTypes(metadataTysMap, keepTypes, [...keepTypes])\n\n // ditch the types we aren't keeping\n metadata.lookup = metadata.lookup.filter((type) => keepTypes.has(type.id))\n\n // update all type ids to be sequential (fill the gaps left by the deleted types)\n const newTypeIds = new Map<number, number>()\n metadata.lookup.forEach((type, index) => newTypeIds.set(type.id, index))\n const getNewTypeId = (oldTypeId: number): number => {\n const newTypeId = newTypeIds.get(oldTypeId)\n if (typeof newTypeId !== \"number\") log.error(`Failed to find newTypeId for type ${oldTypeId}`)\n return newTypeId ?? 0\n }\n remapTypeIds(metadata, getNewTypeId)\n\n if (\"address\" in metadata.extrinsic) metadata.extrinsic.address = 0\n if (\"call\" in metadata.extrinsic) metadata.extrinsic.call = 0\n if (\"signature\" in metadata.extrinsic) metadata.extrinsic.signature = 0\n if (\"extra\" in metadata.extrinsic) metadata.extrinsic.extra = 0\n if (\"signedExtensions\" in metadata.extrinsic) metadata.extrinsic.signedExtensions = []\n if (\"outerEnums\" in metadata) {\n // metadata is v15 (NOT v14)\n metadata.outerEnums.call = 0\n metadata.outerEnums.error = 0\n metadata.outerEnums.event = 0\n }\n}\n\ntype CompactableMetadata = Prettify<\n Omit<Metadata, \"metadata\"> & {\n metadata: Extract<Metadata[\"metadata\"], { tag: SupportedMetadataVersion }>\n }\n>\nconst isCompactableMetadata = (metadata: Metadata): metadata is CompactableMetadata => {\n switch (metadata.metadata.tag) {\n case \"v14\":\n case \"v15\":\n case \"v16\":\n return true\n default:\n return false\n }\n}\n\nconst addDependentTypes = (\n metadataTysMap: Map<MetadataType[\"id\"], MetadataType>,\n keepTypes: Set<number>,\n types: number[],\n // Prevent stack overflow when a type references itself\n addedTypes: Set<number> = new Set(),\n) => {\n const addDependentSubTypes = (subTypes: number[]) =>\n addDependentTypes(metadataTysMap, keepTypes, subTypes, addedTypes)\n\n for (const typeId of types) {\n const type = metadataTysMap.get(typeId)\n if (!type) {\n log.warn(`Unable to find type with id ${typeId}`)\n continue\n }\n\n if (addedTypes.has(type.id)) continue\n keepTypes.add(type.id)\n addedTypes.add(type.id)\n\n const paramTypes = type.params\n .map((param) => param.type)\n .filter((type): type is number => typeof type === \"number\")\n addDependentSubTypes(paramTypes)\n\n switch (type.def.tag) {\n case \"array\":\n addDependentSubTypes([type.def.value.type])\n break\n\n case \"bitSequence\":\n addDependentSubTypes([type.def.value.bitOrderType, type.def.value.bitStoreType])\n break\n\n case \"compact\":\n addDependentSubTypes([type.def.value])\n break\n\n case \"composite\":\n addDependentSubTypes(\n type.def.value\n .map((field) => field.type)\n .filter((type): type is number => typeof type === \"number\"),\n )\n break\n\n case \"primitive\":\n break\n\n case \"sequence\":\n addDependentSubTypes([type.def.value])\n break\n\n case \"tuple\":\n addDependentSubTypes(\n type.def.value.filter((type): type is number => typeof type === \"number\"),\n )\n break\n\n case \"variant\":\n addDependentSubTypes(\n type.def.value\n .flatMap((member) => member.fields.map((field) => field.type))\n .filter((type): type is number => typeof type === \"number\"),\n )\n break\n\n default: {\n // force compilation error if any types don't have a case\n const exhaustiveCheck: never = type.def\n log.error(`Unhandled V15Type type ${exhaustiveCheck}`)\n }\n }\n }\n}\n\nconst remapTypeIds = (metadata: SupportedMetadata, getNewTypeId: (oldTypeId: number) => number) => {\n remapLookupTypeIds(metadata, getNewTypeId)\n remapStorageTypeIds(metadata, getNewTypeId)\n remapRuntimeApisTypeIds(metadata, getNewTypeId)\n}\n\nconst remapLookupTypeIds = (\n metadata: SupportedMetadata,\n getNewTypeId: (oldTypeId: number) => number,\n) => {\n for (const type of metadata.lookup) {\n type.id = getNewTypeId(type.id)\n\n for (const param of type.params) {\n if (typeof param.type !== \"number\") continue\n param.type = getNewTypeId(param.type)\n }\n\n switch (type.def.tag) {\n case \"array\":\n type.def.value.type = getNewTypeId(type.def.value.type)\n break\n\n case \"bitSequence\":\n type.def.value.bitOrderType = getNewTypeId(type.def.value.bitOrderType)\n type.def.value.bitStoreType = getNewTypeId(type.def.value.bitStoreType)\n break\n\n case \"compact\":\n type.def.value = getNewTypeId(type.def.value)\n break\n\n case \"composite\":\n for (const field of type.def.value) {\n if (typeof field.type !== \"number\") continue\n field.type = getNewTypeId(field.type)\n }\n break\n\n case \"primitive\":\n break\n\n case \"sequence\":\n type.def.value = getNewTypeId(type.def.value)\n break\n\n case \"tuple\":\n type.def.value = type.def.value.map((type) => {\n if (typeof type !== \"number\") return type\n return getNewTypeId(type)\n })\n break\n\n case \"variant\":\n for (const member of type.def.value) {\n for (const field of member.fields) {\n if (typeof field.type !== \"number\") continue\n field.type = getNewTypeId(field.type)\n }\n }\n break\n\n default: {\n // force compilation error if any types don't have a case\n const exhaustiveCheck: never = type.def\n log.error(`Unhandled V15Type type ${exhaustiveCheck}`)\n }\n }\n }\n}\n\nconst remapStorageTypeIds = (\n metadata: SupportedMetadata,\n getNewTypeId: (oldTypeId: number) => number,\n) => {\n for (const pallet of metadata.pallets) {\n for (const item of pallet.storage?.items ?? []) {\n if (item.type.tag === \"plain\") item.type.value = getNewTypeId(item.type.value)\n if (item.type.tag === \"map\") {\n item.type.value.key = getNewTypeId(item.type.value.key)\n item.type.value.value = getNewTypeId(item.type.value.value)\n }\n }\n for (const constant of pallet.constants ?? []) {\n constant.type = getNewTypeId(constant.type)\n }\n }\n}\n\nconst remapRuntimeApisTypeIds = (\n metadata: SupportedMetadata,\n getNewTypeId: (oldTypeId: number) => number,\n) => {\n for (const runtimeApi of metadata.apis) {\n for (const method of runtimeApi.methods ?? []) {\n for (const input of method.inputs) {\n input.type = getNewTypeId(input.type)\n }\n method.output = getNewTypeId(method.output)\n }\n }\n}\n","import log from \"../log\"\nimport { MetadataBuilder } from \"../papito\"\n\ntype ScaleStorageCoder = ReturnType<MetadataBuilder[\"buildStorage\"]>\n\nexport const decodeScale = <T>(\n scaleCoder: ScaleStorageCoder | undefined,\n change: string | null,\n error?: string,\n): T | null => {\n if (change === null) return null\n\n try {\n return (scaleCoder?.value?.dec(change) as T | undefined) ?? null\n } catch (cause) {\n log.warn(error ?? `Failed to decode ${change}`, cause)\n return null\n }\n}\n","import { Metadata } from \"@polkadot-api/substrate-bindings\"\n\nimport { metadata as scaleMetadata, toHex } from \"../papito\"\n\nexport const encodeMetadata = (metadata: Metadata) =>\n toHex(scaleMetadata.enc(metadata)) as `0x${string}`\n","import log from \"../log\"\nimport { MetadataBuilder } from \"../papito\"\n\nexport type ScaleStorageCoder = ReturnType<MetadataBuilder[\"buildStorage\"]>\n\nexport const encodeStateKey = (\n scaleCoder: ScaleStorageCoder | undefined,\n error?: string,\n ...args: any[] // eslint-disable-line @typescript-eslint/no-explicit-any\n): `0x${string}` | undefined => {\n try {\n return scaleCoder?.keys?.enc(...args) as `0x${string}`\n } catch (cause) {\n log.warn(error ?? `Failed to encode stateKey ${JSON.stringify(args)}`, cause)\n return\n }\n}\n","import { Struct, u8, u32 } from \"scale-ts\"\n\n/**\n * Extracts the `version` u8 from a SCALE-encoded metadata blob and returns it as a `number`.\n *\n * Only reads the first 40 bytes of the blob.\n */\nexport const getMetadataVersion = (metadataRpc: string | Uint8Array | ArrayBuffer) => {\n try {\n return Struct({\n magicNumber: u32,\n version: u8,\n }).dec(metadataRpc).version\n } catch {\n return 0\n }\n}\n","import { Binary } from \"@polkadot-api/substrate-bindings\"\n\n/**\n * For the substrate-tokens (and other) modules, we configure the `onChainId` field in chaindata to tell the module how to query each token.\n * These queries are made to the tokens pallet.\n * E.g. api.query.Tokens.Account(accountAddress, papiParse(onChainId))\n *\n * The `onChainId` field on chaindata must be a JSON-parseable string, but for some SCALE types (especially the Binary type) we must\n * use specific `polkadot-api` classes to handle SCALE-encoding the statekey.\n *\n * Some examples:\n * Input: `5`\n * Output: `5`\n *\n * Input: `{ type: \"DexShare\", value: [ { type: \"Token\", value: { type: \"ACA\" } }, { type: \"Token\", value: { type: \"AUSD\" } } ] }`\n * Output: `Enum(\"DexShare\", [Enum(\"Token\", Enum(\"ACA\")), Enum(\"Token\", Enum(\"AUSD\"))])`\n *\n * Input: `{ type: \"LiquidCrowdloan\", value: 13 }`\n * Output: `Enum(\"LiquidCrowdloan\", 13)`\n *\n * Input: `{ type: \"NativeToken\", value: \"bigint:2\" }`\n * Output: `Enum(\"NativeToken\", 2n)`\n *\n * Input: `{ type: \"Erc20\", value: \"hex:0x07df96d1341a7d16ba1ad431e2c847d978bc2bce\" }`\n * Output: `Enum(\"Erc20\", Binary.fromHex(\"0x07df96d1341a7d16ba1ad431e2c847d978bc2bce\"))`\n *\n * Input: `{ type: \"Stellar\", value: { code: \"bin:TZS\", issuer: \"hex:0x34c94b2a4ba9e8b57b22547dcbb30f443c4cb02da3829a89aa1bd4780e4466ba\" } }`\n * Output: `Enum(\"Stellar\", { code: Binary.fromText(\"TZS\"), issuer: Binary.fromHex(\"0x34c94b2a4ba9e8b57b22547dcbb30f443c4cb02da3829a89aa1bd4780e4466ba\") })`\n */\nexport const papiParse = <T = unknown>(text: string | T): T => {\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n const reviver = (_key: string, value: any) => {\n if (typeof value !== \"string\") return value\n if (value.startsWith(\"bigint:\")) return BigInt(value.slice(\"bigint:\".length))\n if (value.startsWith(\"hex:\")) return Binary.fromHex(value.slice(\"hex:\".length))\n if (value.startsWith(\"bin:\")) return Binary.fromText(value.slice(\"bin:\".length))\n return value\n }\n\n if (typeof text !== \"string\") return text\n return JSON.parse(text, reviver)\n}\n\nexport const papiStringify = (\n value: any, // eslint-disable-line @typescript-eslint/no-explicit-any\n space?: string | number,\n): string => {\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n const replacer = (_key: string, value: any) => {\n if (typeof value === \"bigint\") return `bigint:${String(value)}`\n if (value instanceof Binary) return `hex:${value.asHex()}`\n return value\n }\n\n return JSON.stringify(value, replacer, space)\n}\n","import { getDynamicBuilder, getLookupFn } from \"@polkadot-api/metadata-builders\"\nimport { decAnyMetadata, unifyMetadata } from \"@polkadot-api/substrate-bindings\"\n\nexport const parseMetadataRpc = (metadataRpc: `0x${string}`) => {\n const metadata = decAnyMetadata(metadataRpc)\n const unifiedMetadata = unifyMetadata(metadata)\n const lookupFn = getLookupFn(unifiedMetadata)\n const builder = getDynamicBuilder(lookupFn)\n\n return { metadata, unifiedMetadata, lookupFn, builder }\n}\n","import { Twox128 } from \"@polkadot-api/substrate-bindings\"\nimport { toHex } from \"@polkadot-api/utils\"\n\nexport const getStorageKeyPrefix = (palletName: string, storageName: string) => {\n const palletHash = Twox128(new TextEncoder().encode(palletName))\n const storageHash = Twox128(new TextEncoder().encode(storageName))\n\n // Concatenate and convert to hex\n const combined = new Uint8Array(palletHash.length + storageHash.length)\n combined.set(palletHash, 0)\n combined.set(storageHash, palletHash.length)\n\n return toHex(combined)\n}\n","export {\n Twox128,\n Blake2128,\n Blake2128Concat,\n Blake2256,\n Blake3256,\n Blake3256Concat,\n Twox256,\n Twox64Concat,\n} from \"@polkadot-api/substrate-bindings\"\n","import log from \"../log\"\nimport { MetadataBuilder, UnifiedMetadata } from \"../papito\"\nimport { parseMetadataRpc } from \"./parseMetadataRpc\"\n\nexport const getConstantValueFromMetadata = <T>(\n metadata: `0x${string}` | { builder: MetadataBuilder; unifiedMetadata: UnifiedMetadata },\n pallet: string,\n constant: string,\n) => {\n const { builder, unifiedMetadata } =\n typeof metadata === \"string\" ? parseMetadataRpc(metadata) : metadata\n\n return getConstantValueInner<T>(builder, unifiedMetadata, pallet, constant)\n}\n\nconst getConstantValueInner = <T>(\n builder: MetadataBuilder,\n unifiedMetadata: UnifiedMetadata,\n pallet: string,\n constant: string,\n) => {\n try {\n const storageCodec = builder.buildConstant(pallet, constant)\n\n const encodedValue = unifiedMetadata.pallets\n .find(({ name }) => name === pallet)\n ?.constants.find(({ name }) => name === constant)?.value\n\n if (!encodedValue) throw new Error(`Constant ${pallet}.${constant} not found`)\n\n return storageCodec.dec(encodedValue) as T\n } catch (err) {\n log.error(\"Failed to get constant value from metadata\", {\n err,\n pallet,\n constant,\n })\n throw err\n }\n}\n"],"mappings":"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","names":["anylogger","metadata","pallet","runtimeApi","type","metadata","import_substrate_bindings","value","import_metadata_builders","import_substrate_bindings","metadata","import_substrate_bindings","import_utils","import_substrate_bindings","metadata"]}
|
package/dist/index.mjs
CHANGED
|
@@ -19,7 +19,7 @@ import anylogger from "anylogger";
|
|
|
19
19
|
// package.json
|
|
20
20
|
var package_default = {
|
|
21
21
|
name: "@talismn/scale",
|
|
22
|
-
version: "0.0.0-pr2295-
|
|
22
|
+
version: "0.0.0-pr2295-20260110050558",
|
|
23
23
|
author: "Talisman",
|
|
24
24
|
homepage: "https://talisman.xyz",
|
|
25
25
|
license: "GPL-3.0-or-later",
|
package/dist/index.mjs.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["../src/papito.ts","../src/log.ts","../package.json","../src/util/compactMetadata.ts","../src/util/decodeScale.ts","../src/util/encodeMetadata.ts","../src/util/encodeStateKey.ts","../src/util/getMetadataVersion.ts","../src/util/serdePapi.ts","../src/util/parseMetadataRpc.ts","../src/util/getStorageKeyPrefix.ts","../src/util/hash.ts","../src/util/getConstantValueFromMetadata.ts"],"sourcesContent":["import { getDynamicBuilder } from \"@polkadot-api/metadata-builders\"\n\nexport {\n getDynamicBuilder,\n getLookupFn,\n type MetadataLookup,\n} from \"@polkadot-api/metadata-builders\"\nexport type { Codec, UnifiedMetadata } from \"@polkadot-api/substrate-bindings\"\nexport {\n decAnyMetadata,\n unifyMetadata,\n metadata,\n Binary,\n FixedSizeBinary,\n} from \"@polkadot-api/substrate-bindings\"\nexport { toHex, fromHex, mergeUint8 } from \"@polkadot-api/utils\"\n\n/** Constant: https://docs.substrate.io/build/application-development/#metadata-format */\nexport const magicNumber = 1635018093\n\nexport type MetadataBuilder = ReturnType<typeof getDynamicBuilder>\n","import anylogger from \"anylogger\"\n\nimport packageJson from \"../package.json\"\n\nexport default anylogger(packageJson.name)\n","{\n \"name\": \"@talismn/scale\",\n \"version\": \"0.0.0-pr2295-20260110044132\",\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/scale\",\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 \"lint\": \"eslint src --max-warnings 0\",\n \"clean\": \"rm -rf dist .turbo node_modules\",\n \"build\": \"tsup\"\n },\n \"dependencies\": {\n \"@polkadot-api/metadata-builders\": \"0.12.2\",\n \"@polkadot-api/substrate-bindings\": \"0.14.0\",\n \"@polkadot-api/utils\": \"0.2.0\",\n \"anylogger\": \"^1.0.11\",\n \"scale-ts\": \"^1.6.1\"\n },\n \"devDependencies\": {\n \"@talismn/eslint-config\": \"workspace:*\",\n \"@talismn/tsconfig\": \"workspace:*\",\n \"eslint\": \"^8.57.1\",\n \"typescript\": \"^5.6.3\"\n },\n \"eslintConfig\": {\n \"root\": true,\n \"extends\": [\n \"@talismn/eslint-config/base\"\n ]\n },\n \"types\": \"./dist/index.d.ts\",\n \"exports\": {\n \".\": {\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 { Metadata } from \"@polkadot-api/substrate-bindings\"\n\nimport log from \"../log\"\nimport { Prettify } from \"./Prettify\"\n\nexport type MetadataType = SupportedMetadata[\"lookup\"][number]\nexport type MetadataPallet = SupportedMetadata[\"pallets\"][number]\nexport type MetadataStorageItem = NonNullable<MetadataPallet[\"storage\"]>[\"items\"][number]\n\ntype SupportedMetadata = Extract<Metadata[\"metadata\"], { tag: SupportedMetadataVersion }>[\"value\"]\ntype SupportedMetadataVersion = \"v14\" | \"v15\" | \"v16\"\n\n/**\n * Converts a `Metadata` into a `MiniMetadata`.\n *\n * A `MiniMetadata` only contains the types inside of its `lookup` which are relevant for\n * the storage queries specified in `palletsAndItems`.\n *\n * E.g. if `palletsAndItems` is `{ pallet: \"System\", items: [\"Account\"] }`, then only the\n * types used in the `System.Account` storage query will remain inside of metadata.lookups.\n */\nexport const compactMetadata = (\n anyMetadata: Metadata,\n palletsAndItems: Array<{ pallet: string; constants?: string[]; items: string[] }> = [],\n runtimeApisAndMethods: Array<{ runtimeApi: string; methods: string[] }> = [],\n extraKeepTypes: number[] = [],\n) => {\n if (!isCompactableMetadata(anyMetadata))\n throw new Error(`Metadata version ${anyMetadata.metadata.tag} not supported in compactMetadata`)\n\n const metadata: SupportedMetadata = anyMetadata.metadata.value\n\n // remove pallets we don't care about\n metadata.pallets = metadata.pallets.filter((pallet) =>\n // keep this pallet if it's listed in `palletsAndItems`\n palletsAndItems.some(({ pallet: palletName }) => pallet.name === palletName),\n ) as typeof metadata.pallets\n\n // remove fields we don't care about from each pallet, and extract types for each storage item we care about\n const palletsKeepTypes = palletsAndItems.flatMap(\n ({ pallet: palletName, constants: constantNames, items: itemNames }) => {\n const pallet = metadata.pallets.find((pallet) => pallet.name === palletName)\n if (!pallet) return []\n\n // remove pallet fields we don't care about\n pallet.calls = undefined\n pallet.constants = constantNames\n ? pallet.constants.filter((constant) => constantNames.includes(constant.name))\n : []\n // v15 (NOT v14) has docs\n if (\"docs\" in pallet) pallet.docs = []\n pallet.errors = undefined\n pallet.events = undefined\n\n if (!pallet.storage) return []\n\n // filter and extract storage items we care about\n pallet.storage.items = pallet.storage.items.filter((item) =>\n itemNames.some((itemName) => item.name === itemName),\n )\n\n return [\n ...pallet.storage.items\n .flatMap((item) => [\n // each type can be either \"Plain\" or \"Map\"\n // if it's \"Plain\" we only need to get the value type\n // if it's a \"Map\" we want to keep both the key AND the value types\n item.type.tag === \"plain\" && item.type.value,\n item.type.tag === \"map\" && item.type.value.key,\n item.type.tag === \"map\" && item.type.value.value,\n ])\n .filter((type): type is number => typeof type === \"number\"),\n ...pallet.constants.flatMap((constant) => constant.type),\n ]\n },\n )\n\n // remove runtime apis we don't care about\n let runtimeApisKeepTypes: number[] = []\n if (\"apis\" in metadata) {\n // metadata is v15 (NOT v14)\n\n // keep this api if it's listed in `runtimeApisAndMethods`\n metadata.apis = metadata.apis.filter((runtimeApi) =>\n runtimeApisAndMethods.some(\n ({ runtimeApi: runtimeApiName }) => runtimeApi.name === runtimeApiName,\n ),\n )\n\n // remove methods we don't care about from each runtime api, and extract types for each call's params and result\n runtimeApisKeepTypes = runtimeApisAndMethods.flatMap(\n ({ runtimeApi: runtimeApiName, methods: methodNames }) => {\n const runtimeApi = metadata.apis.find((runtimeApi) => runtimeApi.name === runtimeApiName)\n if (!runtimeApi) return []\n\n // remove runtime fields we don't care about\n runtimeApi.docs = []\n\n if (!runtimeApi.methods) return []\n\n // filter and extract methods we care about\n runtimeApi.methods = runtimeApi.methods.filter((method) =>\n methodNames.some((methodName) => method.name === methodName),\n )\n\n return runtimeApi.methods.flatMap((method) => [\n // each method has an array of input types (for the params)\n ...method.inputs.map((input) => input.type),\n // and one output type (for the result)\n method.output,\n ])\n },\n )\n }\n\n // this is a set of type ids which we plan to keep in our compacted metadata\n // anything not in this set will be deleted\n // we start off with just the types of the state calls we plan to make,\n // then we run those types through a function (addDependentTypes) which will also include\n // all of the types which those types depend on - recursively\n const keepTypes = new Set([...palletsKeepTypes, ...runtimeApisKeepTypes])\n extraKeepTypes?.forEach((type) => keepTypes.add(type))\n\n // recursively find all the types which our keepTypes depend on and add them to the keepTypes set\n const metadataTysMap = new Map(metadata.lookup.map((ty) => [ty.id, ty]))\n addDependentTypes(metadataTysMap, keepTypes, [...keepTypes])\n\n // ditch the types we aren't keeping\n metadata.lookup = metadata.lookup.filter((type) => keepTypes.has(type.id))\n\n // update all type ids to be sequential (fill the gaps left by the deleted types)\n const newTypeIds = new Map<number, number>()\n metadata.lookup.forEach((type, index) => newTypeIds.set(type.id, index))\n const getNewTypeId = (oldTypeId: number): number => {\n const newTypeId = newTypeIds.get(oldTypeId)\n if (typeof newTypeId !== \"number\") log.error(`Failed to find newTypeId for type ${oldTypeId}`)\n return newTypeId ?? 0\n }\n remapTypeIds(metadata, getNewTypeId)\n\n if (\"address\" in metadata.extrinsic) metadata.extrinsic.address = 0\n if (\"call\" in metadata.extrinsic) metadata.extrinsic.call = 0\n if (\"signature\" in metadata.extrinsic) metadata.extrinsic.signature = 0\n if (\"extra\" in metadata.extrinsic) metadata.extrinsic.extra = 0\n if (\"signedExtensions\" in metadata.extrinsic) metadata.extrinsic.signedExtensions = []\n if (\"outerEnums\" in metadata) {\n // metadata is v15 (NOT v14)\n metadata.outerEnums.call = 0\n metadata.outerEnums.error = 0\n metadata.outerEnums.event = 0\n }\n}\n\ntype CompactableMetadata = Prettify<\n Omit<Metadata, \"metadata\"> & {\n metadata: Extract<Metadata[\"metadata\"], { tag: SupportedMetadataVersion }>\n }\n>\nconst isCompactableMetadata = (metadata: Metadata): metadata is CompactableMetadata => {\n switch (metadata.metadata.tag) {\n case \"v14\":\n case \"v15\":\n case \"v16\":\n return true\n default:\n return false\n }\n}\n\nconst addDependentTypes = (\n metadataTysMap: Map<MetadataType[\"id\"], MetadataType>,\n keepTypes: Set<number>,\n types: number[],\n // Prevent stack overflow when a type references itself\n addedTypes: Set<number> = new Set(),\n) => {\n const addDependentSubTypes = (subTypes: number[]) =>\n addDependentTypes(metadataTysMap, keepTypes, subTypes, addedTypes)\n\n for (const typeId of types) {\n const type = metadataTysMap.get(typeId)\n if (!type) {\n log.warn(`Unable to find type with id ${typeId}`)\n continue\n }\n\n if (addedTypes.has(type.id)) continue\n keepTypes.add(type.id)\n addedTypes.add(type.id)\n\n const paramTypes = type.params\n .map((param) => param.type)\n .filter((type): type is number => typeof type === \"number\")\n addDependentSubTypes(paramTypes)\n\n switch (type.def.tag) {\n case \"array\":\n addDependentSubTypes([type.def.value.type])\n break\n\n case \"bitSequence\":\n addDependentSubTypes([type.def.value.bitOrderType, type.def.value.bitStoreType])\n break\n\n case \"compact\":\n addDependentSubTypes([type.def.value])\n break\n\n case \"composite\":\n addDependentSubTypes(\n type.def.value\n .map((field) => field.type)\n .filter((type): type is number => typeof type === \"number\"),\n )\n break\n\n case \"primitive\":\n break\n\n case \"sequence\":\n addDependentSubTypes([type.def.value])\n break\n\n case \"tuple\":\n addDependentSubTypes(\n type.def.value.filter((type): type is number => typeof type === \"number\"),\n )\n break\n\n case \"variant\":\n addDependentSubTypes(\n type.def.value\n .flatMap((member) => member.fields.map((field) => field.type))\n .filter((type): type is number => typeof type === \"number\"),\n )\n break\n\n default: {\n // force compilation error if any types don't have a case\n const exhaustiveCheck: never = type.def\n log.error(`Unhandled V15Type type ${exhaustiveCheck}`)\n }\n }\n }\n}\n\nconst remapTypeIds = (metadata: SupportedMetadata, getNewTypeId: (oldTypeId: number) => number) => {\n remapLookupTypeIds(metadata, getNewTypeId)\n remapStorageTypeIds(metadata, getNewTypeId)\n remapRuntimeApisTypeIds(metadata, getNewTypeId)\n}\n\nconst remapLookupTypeIds = (\n metadata: SupportedMetadata,\n getNewTypeId: (oldTypeId: number) => number,\n) => {\n for (const type of metadata.lookup) {\n type.id = getNewTypeId(type.id)\n\n for (const param of type.params) {\n if (typeof param.type !== \"number\") continue\n param.type = getNewTypeId(param.type)\n }\n\n switch (type.def.tag) {\n case \"array\":\n type.def.value.type = getNewTypeId(type.def.value.type)\n break\n\n case \"bitSequence\":\n type.def.value.bitOrderType = getNewTypeId(type.def.value.bitOrderType)\n type.def.value.bitStoreType = getNewTypeId(type.def.value.bitStoreType)\n break\n\n case \"compact\":\n type.def.value = getNewTypeId(type.def.value)\n break\n\n case \"composite\":\n for (const field of type.def.value) {\n if (typeof field.type !== \"number\") continue\n field.type = getNewTypeId(field.type)\n }\n break\n\n case \"primitive\":\n break\n\n case \"sequence\":\n type.def.value = getNewTypeId(type.def.value)\n break\n\n case \"tuple\":\n type.def.value = type.def.value.map((type) => {\n if (typeof type !== \"number\") return type\n return getNewTypeId(type)\n })\n break\n\n case \"variant\":\n for (const member of type.def.value) {\n for (const field of member.fields) {\n if (typeof field.type !== \"number\") continue\n field.type = getNewTypeId(field.type)\n }\n }\n break\n\n default: {\n // force compilation error if any types don't have a case\n const exhaustiveCheck: never = type.def\n log.error(`Unhandled V15Type type ${exhaustiveCheck}`)\n }\n }\n }\n}\n\nconst remapStorageTypeIds = (\n metadata: SupportedMetadata,\n getNewTypeId: (oldTypeId: number) => number,\n) => {\n for (const pallet of metadata.pallets) {\n for (const item of pallet.storage?.items ?? []) {\n if (item.type.tag === \"plain\") item.type.value = getNewTypeId(item.type.value)\n if (item.type.tag === \"map\") {\n item.type.value.key = getNewTypeId(item.type.value.key)\n item.type.value.value = getNewTypeId(item.type.value.value)\n }\n }\n for (const constant of pallet.constants ?? []) {\n constant.type = getNewTypeId(constant.type)\n }\n }\n}\n\nconst remapRuntimeApisTypeIds = (\n metadata: SupportedMetadata,\n getNewTypeId: (oldTypeId: number) => number,\n) => {\n for (const runtimeApi of metadata.apis) {\n for (const method of runtimeApi.methods ?? []) {\n for (const input of method.inputs) {\n input.type = getNewTypeId(input.type)\n }\n method.output = getNewTypeId(method.output)\n }\n }\n}\n","import log from \"../log\"\nimport { MetadataBuilder } from \"../papito\"\n\ntype ScaleStorageCoder = ReturnType<MetadataBuilder[\"buildStorage\"]>\n\nexport const decodeScale = <T>(\n scaleCoder: ScaleStorageCoder | undefined,\n change: string | null,\n error?: string,\n): T | null => {\n if (change === null) return null\n\n try {\n return (scaleCoder?.value?.dec(change) as T | undefined) ?? null\n } catch (cause) {\n log.warn(error ?? `Failed to decode ${change}`, cause)\n return null\n }\n}\n","import { Metadata } from \"@polkadot-api/substrate-bindings\"\n\nimport { metadata as scaleMetadata, toHex } from \"../papito\"\n\nexport const encodeMetadata = (metadata: Metadata) =>\n toHex(scaleMetadata.enc(metadata)) as `0x${string}`\n","import log from \"../log\"\nimport { MetadataBuilder } from \"../papito\"\n\nexport type ScaleStorageCoder = ReturnType<MetadataBuilder[\"buildStorage\"]>\n\nexport const encodeStateKey = (\n scaleCoder: ScaleStorageCoder | undefined,\n error?: string,\n ...args: any[] // eslint-disable-line @typescript-eslint/no-explicit-any\n): `0x${string}` | undefined => {\n try {\n return scaleCoder?.keys?.enc(...args) as `0x${string}`\n } catch (cause) {\n log.warn(error ?? `Failed to encode stateKey ${JSON.stringify(args)}`, cause)\n return\n }\n}\n","import { Struct, u8, u32 } from \"scale-ts\"\n\n/**\n * Extracts the `version` u8 from a SCALE-encoded metadata blob and returns it as a `number`.\n *\n * Only reads the first 40 bytes of the blob.\n */\nexport const getMetadataVersion = (metadataRpc: string | Uint8Array | ArrayBuffer) => {\n try {\n return Struct({\n magicNumber: u32,\n version: u8,\n }).dec(metadataRpc).version\n } catch {\n return 0\n }\n}\n","import { Binary } from \"@polkadot-api/substrate-bindings\"\n\n/**\n * For the substrate-tokens (and other) modules, we configure the `onChainId` field in chaindata to tell the module how to query each token.\n * These queries are made to the tokens pallet.\n * E.g. api.query.Tokens.Account(accountAddress, papiParse(onChainId))\n *\n * The `onChainId` field on chaindata must be a JSON-parseable string, but for some SCALE types (especially the Binary type) we must\n * use specific `polkadot-api` classes to handle SCALE-encoding the statekey.\n *\n * Some examples:\n * Input: `5`\n * Output: `5`\n *\n * Input: `{ type: \"DexShare\", value: [ { type: \"Token\", value: { type: \"ACA\" } }, { type: \"Token\", value: { type: \"AUSD\" } } ] }`\n * Output: `Enum(\"DexShare\", [Enum(\"Token\", Enum(\"ACA\")), Enum(\"Token\", Enum(\"AUSD\"))])`\n *\n * Input: `{ type: \"LiquidCrowdloan\", value: 13 }`\n * Output: `Enum(\"LiquidCrowdloan\", 13)`\n *\n * Input: `{ type: \"NativeToken\", value: \"bigint:2\" }`\n * Output: `Enum(\"NativeToken\", 2n)`\n *\n * Input: `{ type: \"Erc20\", value: \"hex:0x07df96d1341a7d16ba1ad431e2c847d978bc2bce\" }`\n * Output: `Enum(\"Erc20\", Binary.fromHex(\"0x07df96d1341a7d16ba1ad431e2c847d978bc2bce\"))`\n *\n * Input: `{ type: \"Stellar\", value: { code: \"bin:TZS\", issuer: \"hex:0x34c94b2a4ba9e8b57b22547dcbb30f443c4cb02da3829a89aa1bd4780e4466ba\" } }`\n * Output: `Enum(\"Stellar\", { code: Binary.fromText(\"TZS\"), issuer: Binary.fromHex(\"0x34c94b2a4ba9e8b57b22547dcbb30f443c4cb02da3829a89aa1bd4780e4466ba\") })`\n */\nexport const papiParse = <T = unknown>(text: string | T): T => {\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n const reviver = (_key: string, value: any) => {\n if (typeof value !== \"string\") return value\n if (value.startsWith(\"bigint:\")) return BigInt(value.slice(\"bigint:\".length))\n if (value.startsWith(\"hex:\")) return Binary.fromHex(value.slice(\"hex:\".length))\n if (value.startsWith(\"bin:\")) return Binary.fromText(value.slice(\"bin:\".length))\n return value\n }\n\n if (typeof text !== \"string\") return text\n return JSON.parse(text, reviver)\n}\n\nexport const papiStringify = (\n value: any, // eslint-disable-line @typescript-eslint/no-explicit-any\n space?: string | number,\n): string => {\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n const replacer = (_key: string, value: any) => {\n if (typeof value === \"bigint\") return `bigint:${String(value)}`\n if (value instanceof Binary) return `hex:${value.asHex()}`\n return value\n }\n\n return JSON.stringify(value, replacer, space)\n}\n","import { getDynamicBuilder, getLookupFn } from \"@polkadot-api/metadata-builders\"\nimport { decAnyMetadata, unifyMetadata } from \"@polkadot-api/substrate-bindings\"\n\nexport const parseMetadataRpc = (metadataRpc: `0x${string}`) => {\n const metadata = decAnyMetadata(metadataRpc)\n const unifiedMetadata = unifyMetadata(metadata)\n const lookupFn = getLookupFn(unifiedMetadata)\n const builder = getDynamicBuilder(lookupFn)\n\n return { metadata, unifiedMetadata, lookupFn, builder }\n}\n","import { Twox128 } from \"@polkadot-api/substrate-bindings\"\nimport { toHex } from \"@polkadot-api/utils\"\n\nexport const getStorageKeyPrefix = (palletName: string, storageName: string) => {\n const palletHash = Twox128(new TextEncoder().encode(palletName))\n const storageHash = Twox128(new TextEncoder().encode(storageName))\n\n // Concatenate and convert to hex\n const combined = new Uint8Array(palletHash.length + storageHash.length)\n combined.set(palletHash, 0)\n combined.set(storageHash, palletHash.length)\n\n return toHex(combined)\n}\n","export {\n Twox128,\n Blake2128,\n Blake2128Concat,\n Blake2256,\n Blake3256,\n Blake3256Concat,\n Twox256,\n Twox64Concat,\n} from \"@polkadot-api/substrate-bindings\"\n","import log from \"../log\"\nimport { MetadataBuilder, UnifiedMetadata } from \"../papito\"\nimport { parseMetadataRpc } from \"./parseMetadataRpc\"\n\nexport const getConstantValueFromMetadata = <T>(\n metadata: `0x${string}` | { builder: MetadataBuilder; unifiedMetadata: UnifiedMetadata },\n pallet: string,\n constant: string,\n) => {\n const { builder, unifiedMetadata } =\n typeof metadata === \"string\" ? parseMetadataRpc(metadata) : metadata\n\n return getConstantValueInner<T>(builder, unifiedMetadata, pallet, constant)\n}\n\nconst getConstantValueInner = <T>(\n builder: MetadataBuilder,\n unifiedMetadata: UnifiedMetadata,\n pallet: string,\n constant: string,\n) => {\n try {\n const storageCodec = builder.buildConstant(pallet, constant)\n\n const encodedValue = unifiedMetadata.pallets\n .find(({ name }) => name === pallet)\n ?.constants.find(({ name }) => name === constant)?.value\n\n if (!encodedValue) throw new Error(`Constant ${pallet}.${constant} not found`)\n\n return storageCodec.dec(encodedValue) as T\n } catch (err) {\n log.error(\"Failed to get constant value from metadata\", {\n err,\n pallet,\n constant,\n })\n throw err\n }\n}\n"],"mappings":"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","names":["metadata","pallet","runtimeApi","type","metadata","Binary","value","getDynamicBuilder","getLookupFn","decAnyMetadata","unifyMetadata","metadata","toHex","Twox128","metadata"]}
|
|
1
|
+
{"version":3,"sources":["../src/papito.ts","../src/log.ts","../package.json","../src/util/compactMetadata.ts","../src/util/decodeScale.ts","../src/util/encodeMetadata.ts","../src/util/encodeStateKey.ts","../src/util/getMetadataVersion.ts","../src/util/serdePapi.ts","../src/util/parseMetadataRpc.ts","../src/util/getStorageKeyPrefix.ts","../src/util/hash.ts","../src/util/getConstantValueFromMetadata.ts"],"sourcesContent":["import { getDynamicBuilder } from \"@polkadot-api/metadata-builders\"\n\nexport {\n getDynamicBuilder,\n getLookupFn,\n type MetadataLookup,\n} from \"@polkadot-api/metadata-builders\"\nexport type { Codec, UnifiedMetadata } from \"@polkadot-api/substrate-bindings\"\nexport {\n decAnyMetadata,\n unifyMetadata,\n metadata,\n Binary,\n FixedSizeBinary,\n} from \"@polkadot-api/substrate-bindings\"\nexport { toHex, fromHex, mergeUint8 } from \"@polkadot-api/utils\"\n\n/** Constant: https://docs.substrate.io/build/application-development/#metadata-format */\nexport const magicNumber = 1635018093\n\nexport type MetadataBuilder = ReturnType<typeof getDynamicBuilder>\n","import anylogger from \"anylogger\"\n\nimport packageJson from \"../package.json\"\n\nexport default anylogger(packageJson.name)\n","{\n \"name\": \"@talismn/scale\",\n \"version\": \"0.0.0-pr2295-20260110050558\",\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/scale\",\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 \"lint\": \"eslint src --max-warnings 0\",\n \"clean\": \"rm -rf dist .turbo node_modules\",\n \"build\": \"tsup\"\n },\n \"dependencies\": {\n \"@polkadot-api/metadata-builders\": \"0.12.2\",\n \"@polkadot-api/substrate-bindings\": \"0.14.0\",\n \"@polkadot-api/utils\": \"0.2.0\",\n \"anylogger\": \"^1.0.11\",\n \"scale-ts\": \"^1.6.1\"\n },\n \"devDependencies\": {\n \"@talismn/eslint-config\": \"workspace:*\",\n \"@talismn/tsconfig\": \"workspace:*\",\n \"eslint\": \"^8.57.1\",\n \"typescript\": \"^5.6.3\"\n },\n \"eslintConfig\": {\n \"root\": true,\n \"extends\": [\n \"@talismn/eslint-config/base\"\n ]\n },\n \"types\": \"./dist/index.d.ts\",\n \"exports\": {\n \".\": {\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 { Metadata } from \"@polkadot-api/substrate-bindings\"\n\nimport log from \"../log\"\nimport { Prettify } from \"./Prettify\"\n\nexport type MetadataType = SupportedMetadata[\"lookup\"][number]\nexport type MetadataPallet = SupportedMetadata[\"pallets\"][number]\nexport type MetadataStorageItem = NonNullable<MetadataPallet[\"storage\"]>[\"items\"][number]\n\ntype SupportedMetadata = Extract<Metadata[\"metadata\"], { tag: SupportedMetadataVersion }>[\"value\"]\ntype SupportedMetadataVersion = \"v14\" | \"v15\" | \"v16\"\n\n/**\n * Converts a `Metadata` into a `MiniMetadata`.\n *\n * A `MiniMetadata` only contains the types inside of its `lookup` which are relevant for\n * the storage queries specified in `palletsAndItems`.\n *\n * E.g. if `palletsAndItems` is `{ pallet: \"System\", items: [\"Account\"] }`, then only the\n * types used in the `System.Account` storage query will remain inside of metadata.lookups.\n */\nexport const compactMetadata = (\n anyMetadata: Metadata,\n palletsAndItems: Array<{ pallet: string; constants?: string[]; items: string[] }> = [],\n runtimeApisAndMethods: Array<{ runtimeApi: string; methods: string[] }> = [],\n extraKeepTypes: number[] = [],\n) => {\n if (!isCompactableMetadata(anyMetadata))\n throw new Error(`Metadata version ${anyMetadata.metadata.tag} not supported in compactMetadata`)\n\n const metadata: SupportedMetadata = anyMetadata.metadata.value\n\n // remove pallets we don't care about\n metadata.pallets = metadata.pallets.filter((pallet) =>\n // keep this pallet if it's listed in `palletsAndItems`\n palletsAndItems.some(({ pallet: palletName }) => pallet.name === palletName),\n ) as typeof metadata.pallets\n\n // remove fields we don't care about from each pallet, and extract types for each storage item we care about\n const palletsKeepTypes = palletsAndItems.flatMap(\n ({ pallet: palletName, constants: constantNames, items: itemNames }) => {\n const pallet = metadata.pallets.find((pallet) => pallet.name === palletName)\n if (!pallet) return []\n\n // remove pallet fields we don't care about\n pallet.calls = undefined\n pallet.constants = constantNames\n ? pallet.constants.filter((constant) => constantNames.includes(constant.name))\n : []\n // v15 (NOT v14) has docs\n if (\"docs\" in pallet) pallet.docs = []\n pallet.errors = undefined\n pallet.events = undefined\n\n if (!pallet.storage) return []\n\n // filter and extract storage items we care about\n pallet.storage.items = pallet.storage.items.filter((item) =>\n itemNames.some((itemName) => item.name === itemName),\n )\n\n return [\n ...pallet.storage.items\n .flatMap((item) => [\n // each type can be either \"Plain\" or \"Map\"\n // if it's \"Plain\" we only need to get the value type\n // if it's a \"Map\" we want to keep both the key AND the value types\n item.type.tag === \"plain\" && item.type.value,\n item.type.tag === \"map\" && item.type.value.key,\n item.type.tag === \"map\" && item.type.value.value,\n ])\n .filter((type): type is number => typeof type === \"number\"),\n ...pallet.constants.flatMap((constant) => constant.type),\n ]\n },\n )\n\n // remove runtime apis we don't care about\n let runtimeApisKeepTypes: number[] = []\n if (\"apis\" in metadata) {\n // metadata is v15 (NOT v14)\n\n // keep this api if it's listed in `runtimeApisAndMethods`\n metadata.apis = metadata.apis.filter((runtimeApi) =>\n runtimeApisAndMethods.some(\n ({ runtimeApi: runtimeApiName }) => runtimeApi.name === runtimeApiName,\n ),\n )\n\n // remove methods we don't care about from each runtime api, and extract types for each call's params and result\n runtimeApisKeepTypes = runtimeApisAndMethods.flatMap(\n ({ runtimeApi: runtimeApiName, methods: methodNames }) => {\n const runtimeApi = metadata.apis.find((runtimeApi) => runtimeApi.name === runtimeApiName)\n if (!runtimeApi) return []\n\n // remove runtime fields we don't care about\n runtimeApi.docs = []\n\n if (!runtimeApi.methods) return []\n\n // filter and extract methods we care about\n runtimeApi.methods = runtimeApi.methods.filter((method) =>\n methodNames.some((methodName) => method.name === methodName),\n )\n\n return runtimeApi.methods.flatMap((method) => [\n // each method has an array of input types (for the params)\n ...method.inputs.map((input) => input.type),\n // and one output type (for the result)\n method.output,\n ])\n },\n )\n }\n\n // this is a set of type ids which we plan to keep in our compacted metadata\n // anything not in this set will be deleted\n // we start off with just the types of the state calls we plan to make,\n // then we run those types through a function (addDependentTypes) which will also include\n // all of the types which those types depend on - recursively\n const keepTypes = new Set([...palletsKeepTypes, ...runtimeApisKeepTypes])\n extraKeepTypes?.forEach((type) => keepTypes.add(type))\n\n // recursively find all the types which our keepTypes depend on and add them to the keepTypes set\n const metadataTysMap = new Map(metadata.lookup.map((ty) => [ty.id, ty]))\n addDependentTypes(metadataTysMap, keepTypes, [...keepTypes])\n\n // ditch the types we aren't keeping\n metadata.lookup = metadata.lookup.filter((type) => keepTypes.has(type.id))\n\n // update all type ids to be sequential (fill the gaps left by the deleted types)\n const newTypeIds = new Map<number, number>()\n metadata.lookup.forEach((type, index) => newTypeIds.set(type.id, index))\n const getNewTypeId = (oldTypeId: number): number => {\n const newTypeId = newTypeIds.get(oldTypeId)\n if (typeof newTypeId !== \"number\") log.error(`Failed to find newTypeId for type ${oldTypeId}`)\n return newTypeId ?? 0\n }\n remapTypeIds(metadata, getNewTypeId)\n\n if (\"address\" in metadata.extrinsic) metadata.extrinsic.address = 0\n if (\"call\" in metadata.extrinsic) metadata.extrinsic.call = 0\n if (\"signature\" in metadata.extrinsic) metadata.extrinsic.signature = 0\n if (\"extra\" in metadata.extrinsic) metadata.extrinsic.extra = 0\n if (\"signedExtensions\" in metadata.extrinsic) metadata.extrinsic.signedExtensions = []\n if (\"outerEnums\" in metadata) {\n // metadata is v15 (NOT v14)\n metadata.outerEnums.call = 0\n metadata.outerEnums.error = 0\n metadata.outerEnums.event = 0\n }\n}\n\ntype CompactableMetadata = Prettify<\n Omit<Metadata, \"metadata\"> & {\n metadata: Extract<Metadata[\"metadata\"], { tag: SupportedMetadataVersion }>\n }\n>\nconst isCompactableMetadata = (metadata: Metadata): metadata is CompactableMetadata => {\n switch (metadata.metadata.tag) {\n case \"v14\":\n case \"v15\":\n case \"v16\":\n return true\n default:\n return false\n }\n}\n\nconst addDependentTypes = (\n metadataTysMap: Map<MetadataType[\"id\"], MetadataType>,\n keepTypes: Set<number>,\n types: number[],\n // Prevent stack overflow when a type references itself\n addedTypes: Set<number> = new Set(),\n) => {\n const addDependentSubTypes = (subTypes: number[]) =>\n addDependentTypes(metadataTysMap, keepTypes, subTypes, addedTypes)\n\n for (const typeId of types) {\n const type = metadataTysMap.get(typeId)\n if (!type) {\n log.warn(`Unable to find type with id ${typeId}`)\n continue\n }\n\n if (addedTypes.has(type.id)) continue\n keepTypes.add(type.id)\n addedTypes.add(type.id)\n\n const paramTypes = type.params\n .map((param) => param.type)\n .filter((type): type is number => typeof type === \"number\")\n addDependentSubTypes(paramTypes)\n\n switch (type.def.tag) {\n case \"array\":\n addDependentSubTypes([type.def.value.type])\n break\n\n case \"bitSequence\":\n addDependentSubTypes([type.def.value.bitOrderType, type.def.value.bitStoreType])\n break\n\n case \"compact\":\n addDependentSubTypes([type.def.value])\n break\n\n case \"composite\":\n addDependentSubTypes(\n type.def.value\n .map((field) => field.type)\n .filter((type): type is number => typeof type === \"number\"),\n )\n break\n\n case \"primitive\":\n break\n\n case \"sequence\":\n addDependentSubTypes([type.def.value])\n break\n\n case \"tuple\":\n addDependentSubTypes(\n type.def.value.filter((type): type is number => typeof type === \"number\"),\n )\n break\n\n case \"variant\":\n addDependentSubTypes(\n type.def.value\n .flatMap((member) => member.fields.map((field) => field.type))\n .filter((type): type is number => typeof type === \"number\"),\n )\n break\n\n default: {\n // force compilation error if any types don't have a case\n const exhaustiveCheck: never = type.def\n log.error(`Unhandled V15Type type ${exhaustiveCheck}`)\n }\n }\n }\n}\n\nconst remapTypeIds = (metadata: SupportedMetadata, getNewTypeId: (oldTypeId: number) => number) => {\n remapLookupTypeIds(metadata, getNewTypeId)\n remapStorageTypeIds(metadata, getNewTypeId)\n remapRuntimeApisTypeIds(metadata, getNewTypeId)\n}\n\nconst remapLookupTypeIds = (\n metadata: SupportedMetadata,\n getNewTypeId: (oldTypeId: number) => number,\n) => {\n for (const type of metadata.lookup) {\n type.id = getNewTypeId(type.id)\n\n for (const param of type.params) {\n if (typeof param.type !== \"number\") continue\n param.type = getNewTypeId(param.type)\n }\n\n switch (type.def.tag) {\n case \"array\":\n type.def.value.type = getNewTypeId(type.def.value.type)\n break\n\n case \"bitSequence\":\n type.def.value.bitOrderType = getNewTypeId(type.def.value.bitOrderType)\n type.def.value.bitStoreType = getNewTypeId(type.def.value.bitStoreType)\n break\n\n case \"compact\":\n type.def.value = getNewTypeId(type.def.value)\n break\n\n case \"composite\":\n for (const field of type.def.value) {\n if (typeof field.type !== \"number\") continue\n field.type = getNewTypeId(field.type)\n }\n break\n\n case \"primitive\":\n break\n\n case \"sequence\":\n type.def.value = getNewTypeId(type.def.value)\n break\n\n case \"tuple\":\n type.def.value = type.def.value.map((type) => {\n if (typeof type !== \"number\") return type\n return getNewTypeId(type)\n })\n break\n\n case \"variant\":\n for (const member of type.def.value) {\n for (const field of member.fields) {\n if (typeof field.type !== \"number\") continue\n field.type = getNewTypeId(field.type)\n }\n }\n break\n\n default: {\n // force compilation error if any types don't have a case\n const exhaustiveCheck: never = type.def\n log.error(`Unhandled V15Type type ${exhaustiveCheck}`)\n }\n }\n }\n}\n\nconst remapStorageTypeIds = (\n metadata: SupportedMetadata,\n getNewTypeId: (oldTypeId: number) => number,\n) => {\n for (const pallet of metadata.pallets) {\n for (const item of pallet.storage?.items ?? []) {\n if (item.type.tag === \"plain\") item.type.value = getNewTypeId(item.type.value)\n if (item.type.tag === \"map\") {\n item.type.value.key = getNewTypeId(item.type.value.key)\n item.type.value.value = getNewTypeId(item.type.value.value)\n }\n }\n for (const constant of pallet.constants ?? []) {\n constant.type = getNewTypeId(constant.type)\n }\n }\n}\n\nconst remapRuntimeApisTypeIds = (\n metadata: SupportedMetadata,\n getNewTypeId: (oldTypeId: number) => number,\n) => {\n for (const runtimeApi of metadata.apis) {\n for (const method of runtimeApi.methods ?? []) {\n for (const input of method.inputs) {\n input.type = getNewTypeId(input.type)\n }\n method.output = getNewTypeId(method.output)\n }\n }\n}\n","import log from \"../log\"\nimport { MetadataBuilder } from \"../papito\"\n\ntype ScaleStorageCoder = ReturnType<MetadataBuilder[\"buildStorage\"]>\n\nexport const decodeScale = <T>(\n scaleCoder: ScaleStorageCoder | undefined,\n change: string | null,\n error?: string,\n): T | null => {\n if (change === null) return null\n\n try {\n return (scaleCoder?.value?.dec(change) as T | undefined) ?? null\n } catch (cause) {\n log.warn(error ?? `Failed to decode ${change}`, cause)\n return null\n }\n}\n","import { Metadata } from \"@polkadot-api/substrate-bindings\"\n\nimport { metadata as scaleMetadata, toHex } from \"../papito\"\n\nexport const encodeMetadata = (metadata: Metadata) =>\n toHex(scaleMetadata.enc(metadata)) as `0x${string}`\n","import log from \"../log\"\nimport { MetadataBuilder } from \"../papito\"\n\nexport type ScaleStorageCoder = ReturnType<MetadataBuilder[\"buildStorage\"]>\n\nexport const encodeStateKey = (\n scaleCoder: ScaleStorageCoder | undefined,\n error?: string,\n ...args: any[] // eslint-disable-line @typescript-eslint/no-explicit-any\n): `0x${string}` | undefined => {\n try {\n return scaleCoder?.keys?.enc(...args) as `0x${string}`\n } catch (cause) {\n log.warn(error ?? `Failed to encode stateKey ${JSON.stringify(args)}`, cause)\n return\n }\n}\n","import { Struct, u8, u32 } from \"scale-ts\"\n\n/**\n * Extracts the `version` u8 from a SCALE-encoded metadata blob and returns it as a `number`.\n *\n * Only reads the first 40 bytes of the blob.\n */\nexport const getMetadataVersion = (metadataRpc: string | Uint8Array | ArrayBuffer) => {\n try {\n return Struct({\n magicNumber: u32,\n version: u8,\n }).dec(metadataRpc).version\n } catch {\n return 0\n }\n}\n","import { Binary } from \"@polkadot-api/substrate-bindings\"\n\n/**\n * For the substrate-tokens (and other) modules, we configure the `onChainId` field in chaindata to tell the module how to query each token.\n * These queries are made to the tokens pallet.\n * E.g. api.query.Tokens.Account(accountAddress, papiParse(onChainId))\n *\n * The `onChainId` field on chaindata must be a JSON-parseable string, but for some SCALE types (especially the Binary type) we must\n * use specific `polkadot-api` classes to handle SCALE-encoding the statekey.\n *\n * Some examples:\n * Input: `5`\n * Output: `5`\n *\n * Input: `{ type: \"DexShare\", value: [ { type: \"Token\", value: { type: \"ACA\" } }, { type: \"Token\", value: { type: \"AUSD\" } } ] }`\n * Output: `Enum(\"DexShare\", [Enum(\"Token\", Enum(\"ACA\")), Enum(\"Token\", Enum(\"AUSD\"))])`\n *\n * Input: `{ type: \"LiquidCrowdloan\", value: 13 }`\n * Output: `Enum(\"LiquidCrowdloan\", 13)`\n *\n * Input: `{ type: \"NativeToken\", value: \"bigint:2\" }`\n * Output: `Enum(\"NativeToken\", 2n)`\n *\n * Input: `{ type: \"Erc20\", value: \"hex:0x07df96d1341a7d16ba1ad431e2c847d978bc2bce\" }`\n * Output: `Enum(\"Erc20\", Binary.fromHex(\"0x07df96d1341a7d16ba1ad431e2c847d978bc2bce\"))`\n *\n * Input: `{ type: \"Stellar\", value: { code: \"bin:TZS\", issuer: \"hex:0x34c94b2a4ba9e8b57b22547dcbb30f443c4cb02da3829a89aa1bd4780e4466ba\" } }`\n * Output: `Enum(\"Stellar\", { code: Binary.fromText(\"TZS\"), issuer: Binary.fromHex(\"0x34c94b2a4ba9e8b57b22547dcbb30f443c4cb02da3829a89aa1bd4780e4466ba\") })`\n */\nexport const papiParse = <T = unknown>(text: string | T): T => {\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n const reviver = (_key: string, value: any) => {\n if (typeof value !== \"string\") return value\n if (value.startsWith(\"bigint:\")) return BigInt(value.slice(\"bigint:\".length))\n if (value.startsWith(\"hex:\")) return Binary.fromHex(value.slice(\"hex:\".length))\n if (value.startsWith(\"bin:\")) return Binary.fromText(value.slice(\"bin:\".length))\n return value\n }\n\n if (typeof text !== \"string\") return text\n return JSON.parse(text, reviver)\n}\n\nexport const papiStringify = (\n value: any, // eslint-disable-line @typescript-eslint/no-explicit-any\n space?: string | number,\n): string => {\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n const replacer = (_key: string, value: any) => {\n if (typeof value === \"bigint\") return `bigint:${String(value)}`\n if (value instanceof Binary) return `hex:${value.asHex()}`\n return value\n }\n\n return JSON.stringify(value, replacer, space)\n}\n","import { getDynamicBuilder, getLookupFn } from \"@polkadot-api/metadata-builders\"\nimport { decAnyMetadata, unifyMetadata } from \"@polkadot-api/substrate-bindings\"\n\nexport const parseMetadataRpc = (metadataRpc: `0x${string}`) => {\n const metadata = decAnyMetadata(metadataRpc)\n const unifiedMetadata = unifyMetadata(metadata)\n const lookupFn = getLookupFn(unifiedMetadata)\n const builder = getDynamicBuilder(lookupFn)\n\n return { metadata, unifiedMetadata, lookupFn, builder }\n}\n","import { Twox128 } from \"@polkadot-api/substrate-bindings\"\nimport { toHex } from \"@polkadot-api/utils\"\n\nexport const getStorageKeyPrefix = (palletName: string, storageName: string) => {\n const palletHash = Twox128(new TextEncoder().encode(palletName))\n const storageHash = Twox128(new TextEncoder().encode(storageName))\n\n // Concatenate and convert to hex\n const combined = new Uint8Array(palletHash.length + storageHash.length)\n combined.set(palletHash, 0)\n combined.set(storageHash, palletHash.length)\n\n return toHex(combined)\n}\n","export {\n Twox128,\n Blake2128,\n Blake2128Concat,\n Blake2256,\n Blake3256,\n Blake3256Concat,\n Twox256,\n Twox64Concat,\n} from \"@polkadot-api/substrate-bindings\"\n","import log from \"../log\"\nimport { MetadataBuilder, UnifiedMetadata } from \"../papito\"\nimport { parseMetadataRpc } from \"./parseMetadataRpc\"\n\nexport const getConstantValueFromMetadata = <T>(\n metadata: `0x${string}` | { builder: MetadataBuilder; unifiedMetadata: UnifiedMetadata },\n pallet: string,\n constant: string,\n) => {\n const { builder, unifiedMetadata } =\n typeof metadata === \"string\" ? parseMetadataRpc(metadata) : metadata\n\n return getConstantValueInner<T>(builder, unifiedMetadata, pallet, constant)\n}\n\nconst getConstantValueInner = <T>(\n builder: MetadataBuilder,\n unifiedMetadata: UnifiedMetadata,\n pallet: string,\n constant: string,\n) => {\n try {\n const storageCodec = builder.buildConstant(pallet, constant)\n\n const encodedValue = unifiedMetadata.pallets\n .find(({ name }) => name === pallet)\n ?.constants.find(({ name }) => name === constant)?.value\n\n if (!encodedValue) throw new Error(`Constant ${pallet}.${constant} not found`)\n\n return storageCodec.dec(encodedValue) as T\n } catch (err) {\n log.error(\"Failed to get constant value from metadata\", {\n err,\n pallet,\n constant,\n })\n throw err\n }\n}\n"],"mappings":"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","names":["metadata","pallet","runtimeApi","type","metadata","Binary","value","getDynamicBuilder","getLookupFn","decAnyMetadata","unifyMetadata","metadata","toHex","Twox128","metadata"]}
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@talismn/scale",
|
|
3
|
-
"version": "0.0.0-pr2295-
|
|
3
|
+
"version": "0.0.0-pr2295-20260110050558",
|
|
4
4
|
"author": "Talisman",
|
|
5
5
|
"homepage": "https://talisman.xyz",
|
|
6
6
|
"license": "GPL-3.0-or-later",
|
|
@@ -30,7 +30,7 @@
|
|
|
30
30
|
"devDependencies": {
|
|
31
31
|
"eslint": "^8.57.1",
|
|
32
32
|
"typescript": "^5.6.3",
|
|
33
|
-
"@talismn/eslint-config": "0.0.0-pr2295-
|
|
33
|
+
"@talismn/eslint-config": "0.0.0-pr2295-20260110050558",
|
|
34
34
|
"@talismn/tsconfig": "0.0.3"
|
|
35
35
|
},
|
|
36
36
|
"eslintConfig": {
|