@pezkuwi/api-contract 16.5.5 → 16.5.6

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (234) hide show
  1. package/Abi/index.js +359 -0
  2. package/Abi/toLatestCompatible.js +30 -0
  3. package/Abi/toV1.js +21 -0
  4. package/Abi/toV2.js +27 -0
  5. package/Abi/toV3.js +10 -0
  6. package/Abi/toV4.js +10 -0
  7. package/LICENSE +201 -0
  8. package/README.md +1 -1
  9. package/augment.js +1 -0
  10. package/base/Base.js +40 -0
  11. package/base/Blueprint.js +51 -0
  12. package/base/Code.js +74 -0
  13. package/base/Contract.js +127 -0
  14. package/{src/base/index.ts → base/index.js} +0 -3
  15. package/base/mock.js +38 -0
  16. package/{build/base → base}/util.d.ts +1 -1
  17. package/base/util.js +33 -0
  18. package/bundle-pezkuwi-api-contract.js +1238 -0
  19. package/{src/bundle.ts → bundle.js} +0 -6
  20. package/cjs/Abi/index.d.ts +31 -0
  21. package/cjs/Abi/index.js +363 -0
  22. package/cjs/Abi/toLatestCompatible.d.ts +15 -0
  23. package/cjs/Abi/toLatestCompatible.js +36 -0
  24. package/cjs/Abi/toV1.d.ts +3 -0
  25. package/cjs/Abi/toV1.js +24 -0
  26. package/cjs/Abi/toV2.d.ts +3 -0
  27. package/cjs/Abi/toV2.js +30 -0
  28. package/cjs/Abi/toV3.d.ts +3 -0
  29. package/cjs/Abi/toV3.js +13 -0
  30. package/cjs/Abi/toV4.d.ts +3 -0
  31. package/cjs/Abi/toV4.js +13 -0
  32. package/cjs/augment.d.ts +1 -0
  33. package/cjs/augment.js +3 -0
  34. package/cjs/base/Base.d.ts +13 -0
  35. package/cjs/base/Base.js +44 -0
  36. package/cjs/base/Blueprint.d.ts +24 -0
  37. package/cjs/base/Blueprint.js +57 -0
  38. package/cjs/base/Code.d.ts +22 -0
  39. package/cjs/base/Code.js +80 -0
  40. package/cjs/base/Contract.d.ts +25 -0
  41. package/cjs/base/Contract.js +133 -0
  42. package/cjs/base/index.d.ts +3 -0
  43. package/cjs/base/index.js +14 -0
  44. package/cjs/base/mock.d.ts +3 -0
  45. package/cjs/base/mock.js +41 -0
  46. package/{src/base/types.ts → cjs/base/types.d.ts} +6 -21
  47. package/cjs/base/types.js +2 -0
  48. package/cjs/base/util.d.ts +16 -0
  49. package/cjs/base/util.js +42 -0
  50. package/cjs/bundle.d.ts +4 -0
  51. package/cjs/bundle.js +10 -0
  52. package/cjs/index.js +5 -0
  53. package/cjs/package.json +3 -0
  54. package/cjs/packageDetect.d.ts +1 -0
  55. package/cjs/packageDetect.js +7 -0
  56. package/cjs/packageInfo.js +4 -0
  57. package/cjs/promise/index.js +23 -0
  58. package/cjs/promise/types.js +2 -0
  59. package/cjs/rx/index.js +23 -0
  60. package/cjs/rx/types.js +2 -0
  61. package/cjs/types.js +2 -0
  62. package/cjs/util.js +13 -0
  63. package/index.d.ts +2 -0
  64. package/index.js +2 -0
  65. package/package.json +384 -15
  66. package/packageDetect.d.ts +1 -0
  67. package/{src/packageDetect.ts → packageDetect.js} +0 -8
  68. package/packageInfo.d.ts +6 -0
  69. package/packageInfo.js +1 -0
  70. package/promise/index.d.ts +13 -0
  71. package/promise/index.js +17 -0
  72. package/{src/promise/types.ts → promise/types.d.ts} +0 -4
  73. package/promise/types.js +1 -0
  74. package/rx/index.d.ts +13 -0
  75. package/rx/index.js +17 -0
  76. package/{src/rx/types.ts → rx/types.d.ts} +0 -4
  77. package/rx/types.js +1 -0
  78. package/types.d.ts +79 -0
  79. package/types.js +1 -0
  80. package/util.d.ts +5 -0
  81. package/util.js +10 -0
  82. package/src/Abi/Abi.spec.ts +0 -235
  83. package/src/Abi/index.ts +0 -477
  84. package/src/Abi/toLatestCompatible.spec.ts +0 -219
  85. package/src/Abi/toLatestCompatible.ts +0 -52
  86. package/src/Abi/toV1.ts +0 -35
  87. package/src/Abi/toV2.ts +0 -58
  88. package/src/Abi/toV3.ts +0 -18
  89. package/src/Abi/toV4.ts +0 -21
  90. package/src/augment.ts +0 -4
  91. package/src/base/Base.ts +0 -52
  92. package/src/base/Blueprint.ts +0 -90
  93. package/src/base/Code.spec.ts +0 -47
  94. package/src/base/Code.ts +0 -142
  95. package/src/base/Contract.ts +0 -197
  96. package/src/base/mock.ts +0 -48
  97. package/src/base/util.ts +0 -56
  98. package/src/checkTypes.manual.ts +0 -45
  99. package/src/index.ts +0 -6
  100. package/src/mod.ts +0 -4
  101. package/src/packageInfo.ts +0 -6
  102. package/src/promise/index.ts +0 -28
  103. package/src/rx/index.ts +0 -28
  104. package/src/test/compare/ink_v0_delegator.test.json +0 -47
  105. package/src/test/compare/ink_v0_dns.test.json +0 -232
  106. package/src/test/compare/ink_v0_erc20.test.json +0 -253
  107. package/src/test/compare/ink_v0_erc721.test.json +0 -415
  108. package/src/test/compare/ink_v0_flipper.test.json +0 -9
  109. package/src/test/compare/ink_v0_flipperBundle.test.json +0 -9
  110. package/src/test/compare/ink_v0_incrementer.test.json +0 -9
  111. package/src/test/compare/ink_v0_multisigPlain.test.json +0 -562
  112. package/src/test/compare/ink_v1_flipper.test.json +0 -9
  113. package/src/test/compare/ink_v1_psp22.test.json +0 -531
  114. package/src/test/compare/ink_v2_erc20.test.json +0 -205
  115. package/src/test/compare/ink_v2_flipper.test.json +0 -9
  116. package/src/test/compare/ink_v3_flipper.test.json +0 -9
  117. package/src/test/compare/ink_v3_traitErc20.test.json +0 -205
  118. package/src/test/compare/ink_v4_erc20Contract.test.json +0 -253
  119. package/src/test/compare/ink_v4_erc20Metadata.test.json +0 -253
  120. package/src/test/compare/ink_v4_flipperContract.test.json +0 -155
  121. package/src/test/compare/ink_v4_flipperMetadata.test.json +0 -155
  122. package/src/test/compare/ink_v5_erc20.test.json +0 -370
  123. package/src/test/compare/ink_v5_erc20AnonymousTransferMetadata.test.json +0 -370
  124. package/src/test/compare/ink_v5_erc20Contract.test.json +0 -370
  125. package/src/test/compare/ink_v5_erc20Metadata.test.json +0 -370
  126. package/src/test/compare/ink_v5_flipperContract.test.json +0 -174
  127. package/src/test/compare/ink_v5_flipperMetadata.test.json +0 -174
  128. package/src/test/compare/ink_v6_erc20Contract.test.json +0 -418
  129. package/src/test/compare/ink_v6_erc20Metadata.test.json +0 -418
  130. package/src/test/compare/solang_v0_ints256.test.json +0 -9
  131. package/src/test/compare/user_v0_assetTransfer.test.json +0 -54
  132. package/src/test/compare/user_v0_enumExample.test.json +0 -303
  133. package/src/test/compare/user_v0_recursive.test.json +0 -27
  134. package/src/test/compare/user_v0_withString.test.json +0 -260
  135. package/src/test/compare/user_v3_ask.test.json +0 -71
  136. package/src/test/compare/user_v4_events.test.json +0 -1328
  137. package/src/test/contracts/index.ts +0 -20
  138. package/src/test/contracts/ink/index.ts +0 -13
  139. package/src/test/contracts/ink/v0/accumulator.wasm +0 -0
  140. package/src/test/contracts/ink/v0/adder.wasm +0 -0
  141. package/src/test/contracts/ink/v0/delegator.json +0 -252
  142. package/src/test/contracts/ink/v0/delegator.wasm +0 -0
  143. package/src/test/contracts/ink/v0/dns.json +0 -713
  144. package/src/test/contracts/ink/v0/dns.wasm +0 -0
  145. package/src/test/contracts/ink/v0/erc20.json +0 -704
  146. package/src/test/contracts/ink/v0/erc20.wasm +0 -0
  147. package/src/test/contracts/ink/v0/erc721.json +0 -1197
  148. package/src/test/contracts/ink/v0/erc721.wasm +0 -0
  149. package/src/test/contracts/ink/v0/flipper.contract.json +0 -107
  150. package/src/test/contracts/ink/v0/flipper.json +0 -106
  151. package/src/test/contracts/ink/v0/flipper.wasm +0 -0
  152. package/src/test/contracts/ink/v0/incrementer.json +0 -108
  153. package/src/test/contracts/ink/v0/incrementer.wasm +0 -0
  154. package/src/test/contracts/ink/v0/index.ts +0 -11
  155. package/src/test/contracts/ink/v0/multisig_plain.json +0 -1466
  156. package/src/test/contracts/ink/v0/multisig_plain.wasm +0 -0
  157. package/src/test/contracts/ink/v0/subber.wasm +0 -0
  158. package/src/test/contracts/ink/v0/trait-flipper.json +0 -103
  159. package/src/test/contracts/ink/v0/trait-flipper.wasm +0 -0
  160. package/src/test/contracts/ink/v1/flipper.contract.json +0 -111
  161. package/src/test/contracts/ink/v1/index.ts +0 -6
  162. package/src/test/contracts/ink/v1/psp22_minter_pauser.contract.json +0 -1722
  163. package/src/test/contracts/ink/v2/erc20.contract.json +0 -630
  164. package/src/test/contracts/ink/v2/flipper.contract.json +0 -103
  165. package/src/test/contracts/ink/v2/index.ts +0 -5
  166. package/src/test/contracts/ink/v3/flipper.contract.json +0 -105
  167. package/src/test/contracts/ink/v3/index.ts +0 -6
  168. package/src/test/contracts/ink/v3/trait_erc20.contract.json +0 -631
  169. package/src/test/contracts/ink/v4/erc20.contract.json +0 -1
  170. package/src/test/contracts/ink/v4/erc20.json +0 -821
  171. package/src/test/contracts/ink/v4/erc20.wasm +0 -0
  172. package/src/test/contracts/ink/v4/flipper.contract.json +0 -1
  173. package/src/test/contracts/ink/v4/flipper.json +0 -396
  174. package/src/test/contracts/ink/v4/flipper.wasm +0 -0
  175. package/src/test/contracts/ink/v4/index.ts +0 -7
  176. package/src/test/contracts/ink/v5/erc20.contract.json +0 -1
  177. package/src/test/contracts/ink/v5/erc20.json +0 -1025
  178. package/src/test/contracts/ink/v5/erc20.wasm +0 -0
  179. package/src/test/contracts/ink/v5/erc20_anonymous_transfer.json +0 -1025
  180. package/src/test/contracts/ink/v5/flipper.contract.json +0 -1
  181. package/src/test/contracts/ink/v5/flipper.json +0 -420
  182. package/src/test/contracts/ink/v5/flipper.wasm +0 -0
  183. package/src/test/contracts/ink/v5/index.ts +0 -8
  184. package/src/test/contracts/ink/v6/erc20.contract.json +0 -1
  185. package/src/test/contracts/ink/v6/erc20.json +0 -1081
  186. package/src/test/contracts/ink/v6/erc20.polkavm +0 -0
  187. package/src/test/contracts/ink/v6/index.ts +0 -5
  188. package/src/test/contracts/solang/index.ts +0 -7
  189. package/src/test/contracts/solang/v0/index.ts +0 -4
  190. package/src/test/contracts/solang/v0/ints256.json +0 -113
  191. package/src/test/contracts/solang/v0/ints256.sol +0 -13
  192. package/src/test/contracts/solang/v0/ints256.wasm +0 -0
  193. package/src/test/contracts/user/index.ts +0 -9
  194. package/src/test/contracts/user/v0/assetTransfer.json +0 -299
  195. package/src/test/contracts/user/v0/assetTransfer.wasm +0 -0
  196. package/src/test/contracts/user/v0/enumExample.json +0 -528
  197. package/src/test/contracts/user/v0/enumExample.wasm +0 -0
  198. package/src/test/contracts/user/v0/index.ts +0 -7
  199. package/src/test/contracts/user/v0/recursive.contract.json +0 -1
  200. package/src/test/contracts/user/v0/withString.json +0 -777
  201. package/src/test/contracts/user/v3/ask.json +0 -550
  202. package/src/test/contracts/user/v3/index.ts +0 -4
  203. package/src/test/contracts/user/v4/events.contract.json +0 -2990
  204. package/src/test/contracts/user/v4/index.ts +0 -4
  205. package/src/test/contracts/util.ts +0 -14
  206. package/src/types.ts +0 -98
  207. package/src/util.ts +0 -20
  208. package/tsconfig.build.json +0 -22
  209. package/tsconfig.build.tsbuildinfo +0 -1
  210. package/tsconfig.spec.json +0 -26
  211. /package/{build/Abi → Abi}/index.d.ts +0 -0
  212. /package/{build/Abi → Abi}/toLatestCompatible.d.ts +0 -0
  213. /package/{build/Abi → Abi}/toV1.d.ts +0 -0
  214. /package/{build/Abi → Abi}/toV2.d.ts +0 -0
  215. /package/{build/Abi → Abi}/toV3.d.ts +0 -0
  216. /package/{build/Abi → Abi}/toV4.d.ts +0 -0
  217. /package/{build/augment.d.ts → augment.d.ts} +0 -0
  218. /package/{build/base → base}/Base.d.ts +0 -0
  219. /package/{build/base → base}/Blueprint.d.ts +0 -0
  220. /package/{build/base → base}/Code.d.ts +0 -0
  221. /package/{build/base → base}/Contract.d.ts +0 -0
  222. /package/{build/base → base}/index.d.ts +0 -0
  223. /package/{build/base → base}/mock.d.ts +0 -0
  224. /package/{build/base → base}/types.d.ts +0 -0
  225. /package/{build/packageDetect.d.ts → base/types.js} +0 -0
  226. /package/{build/bundle.d.ts → bundle.d.ts} +0 -0
  227. /package/{build → cjs}/index.d.ts +0 -0
  228. /package/{build → cjs}/packageInfo.d.ts +0 -0
  229. /package/{build → cjs}/promise/index.d.ts +0 -0
  230. /package/{build → cjs}/promise/types.d.ts +0 -0
  231. /package/{build → cjs}/rx/index.d.ts +0 -0
  232. /package/{build → cjs}/rx/types.d.ts +0 -0
  233. /package/{build → cjs}/types.d.ts +0 -0
  234. /package/{build → cjs}/util.d.ts +0 -0
@@ -1,10 +1,4 @@
1
- // Copyright 2017-2025 @polkadot/api-contract authors & contributors
2
- // SPDX-License-Identifier: Apache-2.0
3
-
4
- // all named
5
1
  export { Abi } from './Abi/index.js';
6
2
  export { packageInfo } from './packageInfo.js';
7
-
8
- // all starred
9
3
  export * from './promise/index.js';
10
4
  export * from './rx/index.js';
@@ -0,0 +1,31 @@
1
+ import type { ChainProperties, ContractMetadataV4, ContractMetadataV5, ContractMetadataV6, ContractProjectInfo, EventRecord } from '@pezkuwi/types/interfaces';
2
+ import type { Codec, Registry, TypeDef } from '@pezkuwi/types/types';
3
+ import type { AbiConstructor, AbiEvent, AbiMessage, DecodedEvent, DecodedMessage } from '../types.js';
4
+ export type ContractMetadataSupported = ContractMetadataV4 | ContractMetadataV5 | ContractMetadataV6;
5
+ export declare class Abi {
6
+ #private;
7
+ readonly events: AbiEvent[];
8
+ readonly constructors: AbiConstructor[];
9
+ readonly info: ContractProjectInfo;
10
+ readonly json: Record<string, unknown>;
11
+ readonly messages: AbiMessage[];
12
+ readonly metadata: ContractMetadataSupported;
13
+ readonly registry: Registry;
14
+ readonly environment: Map<string, TypeDef | Codec>;
15
+ readonly isRevive: boolean;
16
+ constructor(abiJson: Record<string, unknown> | string, chainProperties?: ChainProperties);
17
+ /**
18
+ * Warning: Unstable API, bound to change
19
+ */
20
+ decodeEvent(record: EventRecord): DecodedEvent;
21
+ /**
22
+ * Warning: Unstable API, bound to change
23
+ */
24
+ decodeConstructor(data: Uint8Array): DecodedMessage;
25
+ /**
26
+ * Warning: Unstable API, bound to change
27
+ */
28
+ decodeMessage(data: Uint8Array): DecodedMessage;
29
+ findConstructor(constructorOrId: AbiConstructor | string | number): AbiConstructor;
30
+ findMessage(messageOrId: AbiMessage | string | number): AbiMessage;
31
+ }
@@ -0,0 +1,363 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.Abi = void 0;
4
+ const types_1 = require("@pezkuwi/types");
5
+ const types_create_1 = require("@pezkuwi/types-create");
6
+ const util_1 = require("@pezkuwi/util");
7
+ const toLatestCompatible_js_1 = require("./toLatestCompatible.js");
8
+ const l = (0, util_1.logger)('Abi');
9
+ const PRIMITIVE_ALWAYS = ['AccountId', 'AccountId20', 'AccountIndex', 'Address', 'Balance'];
10
+ function findMessage(list, messageOrId) {
11
+ const message = (0, util_1.isNumber)(messageOrId)
12
+ ? list[messageOrId]
13
+ : (0, util_1.isString)(messageOrId)
14
+ ? list.find(({ identifier }) => [identifier, (0, util_1.stringCamelCase)(identifier)].includes(messageOrId.toString()))
15
+ : messageOrId;
16
+ return (0, util_1.assertReturn)(message, () => `Attempted to call an invalid contract interface, ${(0, util_1.stringify)(messageOrId)}`);
17
+ }
18
+ function getMetadata(registry, json) {
19
+ // this is for V1, V2, V3
20
+ const vx = toLatestCompatible_js_1.enumVersions.find((v) => (0, util_1.isObject)(json[v]));
21
+ // this was added in V4
22
+ const jsonVersion = json.version;
23
+ if (!vx && jsonVersion && !toLatestCompatible_js_1.enumVersions.find((v) => v === `V${jsonVersion}`)) {
24
+ throw new Error(`Unable to handle version ${jsonVersion}`);
25
+ }
26
+ const metadata = registry.createType('ContractMetadata', vx
27
+ ? { [vx]: json[vx] }
28
+ : jsonVersion
29
+ ? { [`V${jsonVersion}`]: json }
30
+ : { V0: json });
31
+ const converter = toLatestCompatible_js_1.convertVersions.find(([v]) => metadata[`is${v}`]);
32
+ if (!converter) {
33
+ throw new Error(`Unable to convert ABI with version ${metadata.type} to a supported version`);
34
+ }
35
+ const upgradedMetadata = converter[1](registry, metadata[`as${converter[0]}`]);
36
+ return upgradedMetadata;
37
+ }
38
+ function isRevive(json) {
39
+ const source = json['source'];
40
+ const version = json['version'];
41
+ const hasContractBinary = typeof source === 'object' &&
42
+ source !== null &&
43
+ 'contract_binary' in source;
44
+ const hasVersion = typeof version === 'number' && version >= 6;
45
+ return hasContractBinary || hasVersion;
46
+ }
47
+ function parseJson(json, chainProperties) {
48
+ const registry = new types_1.TypeRegistry();
49
+ const revive = isRevive(json);
50
+ const typeName = revive ? 'ContractReviveProjectInfo' : 'ContractProjectInfo';
51
+ const info = registry.createType(typeName, json);
52
+ const metadata = getMetadata(registry, json);
53
+ const lookup = registry.createType('PortableRegistry', { types: metadata.types }, true);
54
+ // attach the lookup to the registry - now the types are known
55
+ registry.setLookup(lookup);
56
+ if (chainProperties) {
57
+ registry.setChainProperties(chainProperties);
58
+ }
59
+ // warm-up the actual type, pre-use
60
+ lookup.types.forEach(({ id }) => lookup.getTypeDef(id));
61
+ return [json, registry, metadata, info, revive];
62
+ }
63
+ /**
64
+ * @internal
65
+ * Determines if the given input value is a ContractTypeSpec
66
+ */
67
+ function isTypeSpec(value) {
68
+ return !!value && value instanceof Map && !(0, util_1.isUndefined)(value.type) && !(0, util_1.isUndefined)(value.displayName);
69
+ }
70
+ /**
71
+ * @internal
72
+ * Determines if the given input value is an Option
73
+ */
74
+ function isOption(value) {
75
+ return !!value && value instanceof types_1.Option;
76
+ }
77
+ class Abi {
78
+ events;
79
+ constructors;
80
+ info;
81
+ json;
82
+ messages;
83
+ metadata;
84
+ registry;
85
+ environment = new Map();
86
+ isRevive;
87
+ constructor(abiJson, chainProperties) {
88
+ [this.json, this.registry, this.metadata, this.info, this.isRevive] = parseJson((0, util_1.isString)(abiJson)
89
+ ? JSON.parse(abiJson)
90
+ : abiJson, chainProperties);
91
+ this.constructors = this.metadata.spec.constructors.map((spec, index) => this.#createMessage(spec, index, {
92
+ isConstructor: true,
93
+ isDefault: spec.default.isTrue,
94
+ isPayable: spec.payable.isTrue,
95
+ returnType: spec.returnType.isSome
96
+ ? this.registry.lookup.getTypeDef(spec.returnType.unwrap().type)
97
+ : null
98
+ }));
99
+ this.events = this.metadata.spec.events.map((_, index) => this.#createEvent(index));
100
+ this.messages = this.metadata.spec.messages.map((spec, index) => this.#createMessage(spec, index, {
101
+ isDefault: spec.default.isTrue,
102
+ isMutating: spec.mutates.isTrue,
103
+ isPayable: spec.payable.isTrue,
104
+ returnType: spec.returnType.isSome
105
+ ? this.registry.lookup.getTypeDef(spec.returnType.unwrap().type)
106
+ : null
107
+ }));
108
+ // NOTE See the rationale for having Option<...> values in the actual
109
+ // ContractEnvironmentV4 structure definition in interfaces/contractsAbi
110
+ // (Due to conversions, the fields may not exist)
111
+ for (const [key, opt] of this.metadata.spec.environment.entries()) {
112
+ if (isOption(opt)) {
113
+ if (opt.isSome) {
114
+ const value = opt.unwrap();
115
+ if ((0, util_1.isBn)(value)) {
116
+ this.environment.set(key, value);
117
+ }
118
+ else if (isTypeSpec(value)) {
119
+ this.environment.set(key, this.registry.lookup.getTypeDef(value.type));
120
+ }
121
+ else {
122
+ throw new Error(`Invalid environment definition for ${key}:: Expected either Number or ContractTypeSpec`);
123
+ }
124
+ }
125
+ }
126
+ else {
127
+ throw new Error(`Expected Option<*> definition for ${key} in ContractEnvironment`);
128
+ }
129
+ }
130
+ }
131
+ /**
132
+ * Warning: Unstable API, bound to change
133
+ */
134
+ decodeEvent(record) {
135
+ switch (this.metadata.version.toString()) {
136
+ // earlier version are hoisted to v4
137
+ case '4':
138
+ return this.#decodeEventV4(record);
139
+ case '5':
140
+ return this.#decodeEventV5(record);
141
+ // Latest
142
+ default:
143
+ return this.#decodeEventV6(record);
144
+ }
145
+ }
146
+ #decodeEventV6 = (record) => {
147
+ const topics = record.event.data[2];
148
+ // Try to match by signature topic (first topic)
149
+ const signatureTopic = topics[0];
150
+ const data = record.event.data[1];
151
+ if (signatureTopic) {
152
+ const event = this.events.find((e) => e.signatureTopic !== undefined && e.signatureTopic !== null && e.signatureTopic === signatureTopic.toHex());
153
+ // Early return if event found by signature topic
154
+ if (event) {
155
+ return event.fromU8a(data);
156
+ }
157
+ }
158
+ // If no event returned yet, it might be anonymous
159
+ const amountOfTopics = topics.length;
160
+ const potentialEvents = this.events.filter((e) => {
161
+ // event can't have a signature topic
162
+ if (e.signatureTopic !== null && e.signatureTopic !== undefined) {
163
+ return false;
164
+ }
165
+ // event should have same amount of indexed fields as emitted topics
166
+ const amountIndexed = e.args.filter((a) => a.indexed).length;
167
+ if (amountIndexed !== amountOfTopics) {
168
+ return false;
169
+ }
170
+ // If all conditions met, it's a potential event
171
+ return true;
172
+ });
173
+ if (potentialEvents.length === 1) {
174
+ return potentialEvents[0].fromU8a(data);
175
+ }
176
+ throw new Error('Unable to determine event');
177
+ };
178
+ #decodeEventV5 = (record) => {
179
+ // Find event by first topic, which potentially is the signature_topic
180
+ const signatureTopic = record.topics[0];
181
+ const data = record.event.data[1];
182
+ if (signatureTopic) {
183
+ const event = this.events.find((e) => e.signatureTopic !== undefined && e.signatureTopic !== null && e.signatureTopic === signatureTopic.toHex());
184
+ // Early return if event found by signature topic
185
+ if (event) {
186
+ return event.fromU8a(data);
187
+ }
188
+ }
189
+ // If no event returned yet, it might be anonymous
190
+ const amountOfTopics = record.topics.length;
191
+ const potentialEvents = this.events.filter((e) => {
192
+ // event can't have a signature topic
193
+ if (e.signatureTopic !== null && e.signatureTopic !== undefined) {
194
+ return false;
195
+ }
196
+ // event should have same amount of indexed fields as emitted topics
197
+ const amountIndexed = e.args.filter((a) => a.indexed).length;
198
+ if (amountIndexed !== amountOfTopics) {
199
+ return false;
200
+ }
201
+ // If all conditions met, it's a potential event
202
+ return true;
203
+ });
204
+ if (potentialEvents.length === 1) {
205
+ return potentialEvents[0].fromU8a(data);
206
+ }
207
+ throw new Error('Unable to determine event');
208
+ };
209
+ #decodeEventV4 = (record) => {
210
+ const data = record.event.data[1];
211
+ const index = data[0];
212
+ const event = this.events[index];
213
+ if (!event) {
214
+ throw new Error(`Unable to find event with index ${index}`);
215
+ }
216
+ return event.fromU8a(data.subarray(1));
217
+ };
218
+ /**
219
+ * Warning: Unstable API, bound to change
220
+ */
221
+ decodeConstructor(data) {
222
+ return this.#decodeMessage('message', this.constructors, data);
223
+ }
224
+ /**
225
+ * Warning: Unstable API, bound to change
226
+ */
227
+ decodeMessage(data) {
228
+ return this.#decodeMessage('message', this.messages, data);
229
+ }
230
+ findConstructor(constructorOrId) {
231
+ return findMessage(this.constructors, constructorOrId);
232
+ }
233
+ findMessage(messageOrId) {
234
+ return findMessage(this.messages, messageOrId);
235
+ }
236
+ #createArgs = (args, spec) => {
237
+ return args.map(({ label, type }, index) => {
238
+ try {
239
+ if (!(0, util_1.isObject)(type)) {
240
+ throw new Error('Invalid type definition found');
241
+ }
242
+ const displayName = type.displayName.length
243
+ ? type.displayName[type.displayName.length - 1].toString()
244
+ : undefined;
245
+ const camelName = (0, util_1.stringCamelCase)(label);
246
+ if (displayName && PRIMITIVE_ALWAYS.includes(displayName)) {
247
+ return {
248
+ name: camelName,
249
+ type: {
250
+ info: types_create_1.TypeDefInfo.Plain,
251
+ type: displayName
252
+ }
253
+ };
254
+ }
255
+ const typeDef = this.registry.lookup.getTypeDef(type.type);
256
+ return {
257
+ name: camelName,
258
+ type: displayName && !typeDef.type.startsWith(displayName)
259
+ ? { displayName, ...typeDef }
260
+ : typeDef
261
+ };
262
+ }
263
+ catch (error) {
264
+ l.error(`Error expanding argument ${index} in ${(0, util_1.stringify)(spec)}`);
265
+ throw error;
266
+ }
267
+ });
268
+ };
269
+ #createMessageParams = (args, spec) => {
270
+ return this.#createArgs(args, spec);
271
+ };
272
+ #createEventParams = (args, spec) => {
273
+ const params = this.#createArgs(args, spec);
274
+ return params.map((p, index) => ({ ...p, indexed: args[index].indexed.toPrimitive() }));
275
+ };
276
+ #createEvent = (index) => {
277
+ // TODO TypeScript would narrow this type to the correct version,
278
+ // but version is `Text` so I need to call `toString()` here,
279
+ // which breaks the type inference.
280
+ switch (this.metadata.version.toString()) {
281
+ case '4':
282
+ return this.#createEventV4(this.metadata.spec.events[index], index);
283
+ default:
284
+ return this.#createEventV5(this.metadata.spec.events[index], index);
285
+ }
286
+ };
287
+ #createEventV5 = (spec, index) => {
288
+ const args = this.#createEventParams(spec.args, spec);
289
+ const event = {
290
+ args,
291
+ docs: spec.docs.map((d) => d.toString()),
292
+ fromU8a: (data) => ({
293
+ args: this.#decodeArgs(args, data),
294
+ event
295
+ }),
296
+ identifier: [spec.module_path, spec.label].join('::'),
297
+ index,
298
+ signatureTopic: spec.signature_topic.isSome ? spec.signature_topic.unwrap().toHex() : null
299
+ };
300
+ return event;
301
+ };
302
+ #createEventV4 = (spec, index) => {
303
+ const args = this.#createEventParams(spec.args, spec);
304
+ const event = {
305
+ args,
306
+ docs: spec.docs.map((d) => d.toString()),
307
+ fromU8a: (data) => ({
308
+ args: this.#decodeArgs(args, data),
309
+ event
310
+ }),
311
+ identifier: spec.label.toString(),
312
+ index
313
+ };
314
+ return event;
315
+ };
316
+ #createMessage = (spec, index, add = {}) => {
317
+ const args = this.#createMessageParams(spec.args, spec);
318
+ const identifier = spec.label.toString();
319
+ const message = {
320
+ ...add,
321
+ args,
322
+ docs: spec.docs.map((d) => d.toString()),
323
+ fromU8a: (data) => ({
324
+ args: this.#decodeArgs(args, data),
325
+ message
326
+ }),
327
+ identifier,
328
+ index,
329
+ isDefault: spec.default.isTrue,
330
+ method: (0, util_1.stringCamelCase)(identifier),
331
+ path: identifier.split('::').map((s) => (0, util_1.stringCamelCase)(s)),
332
+ selector: spec.selector,
333
+ toU8a: (params) => this.#encodeMessageArgs(spec, args, params)
334
+ };
335
+ return message;
336
+ };
337
+ #decodeArgs = (args, data) => {
338
+ // for decoding we expect the input to be just the arg data, no selectors
339
+ // no length added (this allows use with events as well)
340
+ let offset = 0;
341
+ return args.map(({ type: { lookupName, type } }) => {
342
+ const value = this.registry.createType(lookupName || type, data.subarray(offset));
343
+ offset += value.encodedLength;
344
+ return value;
345
+ });
346
+ };
347
+ #decodeMessage = (type, list, data) => {
348
+ const [, trimmed] = (0, util_1.compactStripLength)(data);
349
+ const selector = trimmed.subarray(0, 4);
350
+ const message = list.find((m) => m.selector.eq(selector));
351
+ if (!message) {
352
+ throw new Error(`Unable to find ${type} with selector ${(0, util_1.u8aToHex)(selector)}`);
353
+ }
354
+ return message.fromU8a(trimmed.subarray(4));
355
+ };
356
+ #encodeMessageArgs = ({ label, selector }, args, data) => {
357
+ if (data.length !== args.length) {
358
+ throw new Error(`Expected ${args.length} arguments to contract message '${label.toString()}', found ${data.length}`);
359
+ }
360
+ return (0, util_1.compactAddLength)((0, util_1.u8aConcat)(this.registry.createType('ContractSelector', selector).toU8a(), ...args.map(({ type: { lookupName, type } }, index) => this.registry.createType(lookupName || type, data[index]).toU8a())));
361
+ };
362
+ }
363
+ exports.Abi = Abi;
@@ -0,0 +1,15 @@
1
+ import type { ContractMetadataV4, ContractMetadataV5, ContractMetadataV6 } from '@pezkuwi/types/interfaces';
2
+ import type { Registry } from '@pezkuwi/types/types';
3
+ import type { ContractMetadataSupported } from './index.js';
4
+ export declare const enumVersions: readonly ["V6", "V5", "V4", "V3", "V2", "V1"];
5
+ type Versions = typeof enumVersions[number] | 'V0';
6
+ type Converter = (registry: Registry, vx: any) => ContractMetadataSupported;
7
+ export declare function v6ToLatestCompatible(_registry: Registry, v6: ContractMetadataV6): ContractMetadataV6;
8
+ export declare function v5ToLatestCompatible(_registry: Registry, v5: ContractMetadataV5): ContractMetadataV5;
9
+ export declare function v4ToLatestCompatible(_registry: Registry, v4: ContractMetadataV4): ContractMetadataV4;
10
+ export declare const v3ToLatestCompatible: (registry: Registry, input: import("@pezkuwi/types/interfaces").ContractMetadataV3) => ContractMetadataSupported;
11
+ export declare const v2ToLatestCompatible: (registry: Registry, input: import("@pezkuwi/types/interfaces").ContractMetadataV2) => ContractMetadataSupported;
12
+ export declare const v1ToLatestCompatible: (registry: Registry, input: import("@pezkuwi/types/interfaces").ContractMetadataV1) => ContractMetadataSupported;
13
+ export declare const v0ToLatestCompatible: (registry: Registry, input: import("@pezkuwi/types/interfaces").ContractMetadataV0) => ContractMetadataSupported;
14
+ export declare const convertVersions: [Versions, Converter][];
15
+ export {};
@@ -0,0 +1,36 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.convertVersions = exports.v0ToLatestCompatible = exports.v1ToLatestCompatible = exports.v2ToLatestCompatible = exports.v3ToLatestCompatible = exports.enumVersions = void 0;
4
+ exports.v6ToLatestCompatible = v6ToLatestCompatible;
5
+ exports.v5ToLatestCompatible = v5ToLatestCompatible;
6
+ exports.v4ToLatestCompatible = v4ToLatestCompatible;
7
+ const toV1_js_1 = require("./toV1.js");
8
+ const toV2_js_1 = require("./toV2.js");
9
+ const toV3_js_1 = require("./toV3.js");
10
+ const toV4_js_1 = require("./toV4.js");
11
+ exports.enumVersions = ['V6', 'V5', 'V4', 'V3', 'V2', 'V1'];
12
+ function createConverter(next, step) {
13
+ return (registry, input) => next(registry, step(registry, input));
14
+ }
15
+ function v6ToLatestCompatible(_registry, v6) {
16
+ return v6;
17
+ }
18
+ function v5ToLatestCompatible(_registry, v5) {
19
+ return v5;
20
+ }
21
+ function v4ToLatestCompatible(_registry, v4) {
22
+ return v4;
23
+ }
24
+ exports.v3ToLatestCompatible = createConverter(v4ToLatestCompatible, toV4_js_1.v3ToV4);
25
+ exports.v2ToLatestCompatible = createConverter(exports.v3ToLatestCompatible, toV3_js_1.v2ToV3);
26
+ exports.v1ToLatestCompatible = createConverter(exports.v2ToLatestCompatible, toV2_js_1.v1ToV2);
27
+ exports.v0ToLatestCompatible = createConverter(exports.v1ToLatestCompatible, toV1_js_1.v0ToV1);
28
+ exports.convertVersions = [
29
+ ['V6', v6ToLatestCompatible],
30
+ ['V5', v5ToLatestCompatible],
31
+ ['V4', v4ToLatestCompatible],
32
+ ['V3', exports.v3ToLatestCompatible],
33
+ ['V2', exports.v2ToLatestCompatible],
34
+ ['V1', exports.v1ToLatestCompatible],
35
+ ['V0', exports.v0ToLatestCompatible]
36
+ ];
@@ -0,0 +1,3 @@
1
+ import type { ContractMetadataV0, ContractMetadataV1 } from '@pezkuwi/types/interfaces';
2
+ import type { Registry } from '@pezkuwi/types/types';
3
+ export declare function v0ToV1(registry: Registry, v0: ContractMetadataV0): ContractMetadataV1;
@@ -0,0 +1,24 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.v0ToV1 = v0ToV1;
4
+ const types_1 = require("@pezkuwi/types");
5
+ const util_1 = require("@pezkuwi/util");
6
+ function v0ToV1Names(all) {
7
+ return all.map((e) => (0, util_1.objectSpread)({}, e, {
8
+ name: Array.isArray(e.name)
9
+ ? e.name
10
+ : [e.name]
11
+ }));
12
+ }
13
+ function v0ToV1(registry, v0) {
14
+ if (!v0.metadataVersion.length) {
15
+ throw new Error('Invalid format for V0 (detected) contract metadata');
16
+ }
17
+ return registry.createType('ContractMetadataV1', (0, util_1.objectSpread)({}, v0, {
18
+ spec: (0, util_1.objectSpread)({}, v0.spec, {
19
+ constructors: v0ToV1Names(v0.spec.constructors),
20
+ messages: v0ToV1Names(v0.spec.messages)
21
+ }),
22
+ types: (0, types_1.convertSiV0toV1)(registry, v0.types)
23
+ }));
24
+ }
@@ -0,0 +1,3 @@
1
+ import type { ContractMetadataV1, ContractMetadataV2 } from '@pezkuwi/types/interfaces';
2
+ import type { Registry } from '@pezkuwi/types/types';
3
+ export declare function v1ToV2(registry: Registry, v1: ContractMetadataV1): ContractMetadataV2;
@@ -0,0 +1,30 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.v1ToV2 = v1ToV2;
4
+ const util_1 = require("@pezkuwi/util");
5
+ const ARG_TYPES = {
6
+ ContractConstructorSpec: 'ContractMessageParamSpecV2',
7
+ ContractEventSpec: 'ContractEventParamSpecV2',
8
+ ContractMessageSpec: 'ContractMessageParamSpecV2'
9
+ };
10
+ function v1ToV2Label(entry) {
11
+ return (0, util_1.objectSpread)({}, entry, {
12
+ label: Array.isArray(entry.name)
13
+ ? entry.name.join('::')
14
+ : entry.name
15
+ });
16
+ }
17
+ function v1ToV2Labels(registry, outType, all) {
18
+ return all.map((e) => registry.createType(`${outType}V2`, (0, util_1.objectSpread)(v1ToV2Label(e), {
19
+ args: e.args.map((a) => registry.createType(ARG_TYPES[outType], v1ToV2Label(a)))
20
+ })));
21
+ }
22
+ function v1ToV2(registry, v1) {
23
+ return registry.createType('ContractMetadataV2', (0, util_1.objectSpread)({}, v1, {
24
+ spec: (0, util_1.objectSpread)({}, v1.spec, {
25
+ constructors: v1ToV2Labels(registry, 'ContractConstructorSpec', v1.spec.constructors),
26
+ events: v1ToV2Labels(registry, 'ContractEventSpec', v1.spec.events),
27
+ messages: v1ToV2Labels(registry, 'ContractMessageSpec', v1.spec.messages)
28
+ })
29
+ }));
30
+ }
@@ -0,0 +1,3 @@
1
+ import type { ContractMetadataV2, ContractMetadataV3 } from '@pezkuwi/types/interfaces';
2
+ import type { Registry } from '@pezkuwi/types/types';
3
+ export declare function v2ToV3(registry: Registry, v2: ContractMetadataV2): ContractMetadataV3;
@@ -0,0 +1,13 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.v2ToV3 = v2ToV3;
4
+ const util_1 = require("@pezkuwi/util");
5
+ function v2ToV3(registry, v2) {
6
+ return registry.createType('ContractMetadataV3', (0, util_1.objectSpread)({}, v2, {
7
+ spec: (0, util_1.objectSpread)({}, v2.spec, {
8
+ constructors: v2.spec.constructors.map((c) =>
9
+ // V3 introduces the payable flag on constructors, for <V3, it is always true
10
+ registry.createType('ContractConstructorSpecV3', (0, util_1.objectSpread)({}, c, { payable: true })))
11
+ })
12
+ }));
13
+ }
@@ -0,0 +1,3 @@
1
+ import type { ContractMetadataV3, ContractMetadataV4 } from '@pezkuwi/types/interfaces';
2
+ import type { Registry } from '@pezkuwi/types/types';
3
+ export declare function v3ToV4(registry: Registry, v3: ContractMetadataV3): ContractMetadataV4;
@@ -0,0 +1,13 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.v3ToV4 = v3ToV4;
4
+ const util_1 = require("@pezkuwi/util");
5
+ function v3ToV4(registry, v3) {
6
+ return registry.createType('ContractMetadataV4', (0, util_1.objectSpread)({}, v3, {
7
+ spec: (0, util_1.objectSpread)({}, v3.spec, {
8
+ constructors: v3.spec.constructors.map((c) => registry.createType('ContractConstructorSpecV4', (0, util_1.objectSpread)({}, c))),
9
+ messages: v3.spec.messages.map((m) => registry.createType('ContractMessageSpecV3', (0, util_1.objectSpread)({}, m)))
10
+ }),
11
+ version: registry.createType('Text', '4')
12
+ }));
13
+ }
@@ -0,0 +1 @@
1
+ import '@pezkuwi/api-augment';
package/cjs/augment.js ADDED
@@ -0,0 +1,3 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ require("@pezkuwi/api-augment");
@@ -0,0 +1,13 @@
1
+ import type { ApiBase } from '@pezkuwi/api/base';
2
+ import type { ApiTypes, DecorateMethod } from '@pezkuwi/api/types';
3
+ import type { Registry } from '@pezkuwi/types/types';
4
+ import { Abi } from '../Abi/index.js';
5
+ export declare abstract class Base<ApiType extends ApiTypes> {
6
+ readonly abi: Abi;
7
+ readonly api: ApiBase<ApiType>;
8
+ protected readonly _decorateMethod: DecorateMethod<ApiType>;
9
+ protected readonly _isWeightV1: boolean;
10
+ protected readonly _isRevive: boolean;
11
+ constructor(api: ApiBase<ApiType>, abi: string | Record<string, unknown> | Abi, decorateMethod: DecorateMethod<ApiType>);
12
+ get registry(): Registry;
13
+ }
@@ -0,0 +1,44 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.Base = void 0;
4
+ const util_1 = require("@pezkuwi/util");
5
+ const index_js_1 = require("../Abi/index.js");
6
+ class Base {
7
+ abi;
8
+ api;
9
+ _decorateMethod;
10
+ _isWeightV1;
11
+ _isRevive;
12
+ constructor(api, abi, decorateMethod) {
13
+ if (!api || !api.isConnected || !api.tx) {
14
+ throw new Error('Your API has not been initialized correctly and is not connected to a chain');
15
+ }
16
+ this.abi = abi instanceof index_js_1.Abi
17
+ ? abi
18
+ : new index_js_1.Abi(abi, api.registry.getChainProperties());
19
+ this.api = api;
20
+ this._decorateMethod = decorateMethod;
21
+ this._isWeightV1 = !api.registry.createType('Weight').proofSize;
22
+ this._isRevive = this.abi.isRevive;
23
+ if (this._isRevive) {
24
+ if (!api.tx.revive || !(0, util_1.isFunction)(api.tx.revive.instantiateWithCode) || api.tx.revive.instantiateWithCode.meta.args.length !== 6) {
25
+ throw new Error('The runtime does not expose api.tx.revive.instantiateWithCode with storageDepositLimit');
26
+ }
27
+ else if (!api.call.reviveApi || !(0, util_1.isFunction)(api.call.reviveApi.call)) {
28
+ throw new Error('Your runtime does not expose the api.call.reviveApi.call runtime interfaces');
29
+ }
30
+ }
31
+ else {
32
+ if (!api.tx.contracts || !(0, util_1.isFunction)(api.tx.contracts.instantiateWithCode) || api.tx.contracts.instantiateWithCode.meta.args.length !== 6) {
33
+ throw new Error('The runtime does not expose api.tx.contracts.instantiateWithCode with storageDepositLimit');
34
+ }
35
+ else if (!api.call.contractsApi || !(0, util_1.isFunction)(api.call.contractsApi.call)) {
36
+ throw new Error('Your runtime does not expose the api.call.contractsApi.call runtime interfaces');
37
+ }
38
+ }
39
+ }
40
+ get registry() {
41
+ return this.api.registry;
42
+ }
43
+ }
44
+ exports.Base = Base;
@@ -0,0 +1,24 @@
1
+ import type { ApiBase } from '@pezkuwi/api/base';
2
+ import type { ApiTypes, DecorateMethod } from '@pezkuwi/api/types';
3
+ import type { Hash } from '@pezkuwi/types/interfaces';
4
+ import type { ISubmittableResult } from '@pezkuwi/types/types';
5
+ import type { Abi } from '../Abi/index.js';
6
+ import type { MapConstructorExec } from './types.js';
7
+ import { SubmittableResult } from '@pezkuwi/api';
8
+ import { Base } from './Base.js';
9
+ import { Contract } from './Contract.js';
10
+ export type BlueprintConstructor<ApiType extends ApiTypes> = new (api: ApiBase<ApiType>, abi: string | Record<string, unknown> | Abi, codeHash: string | Hash | Uint8Array) => Blueprint<ApiType>;
11
+ export declare class BlueprintSubmittableResult<ApiType extends ApiTypes> extends SubmittableResult {
12
+ readonly contract?: Contract<ApiType> | undefined;
13
+ constructor(result: ISubmittableResult, contract?: Contract<ApiType>);
14
+ }
15
+ export declare class Blueprint<ApiType extends ApiTypes> extends Base<ApiType> {
16
+ #private;
17
+ /**
18
+ * @description The on-chain code hash for this blueprint
19
+ */
20
+ readonly codeHash: Hash;
21
+ constructor(api: ApiBase<ApiType>, abi: string | Record<string, unknown> | Abi, codeHash: string | Hash | Uint8Array, decorateMethod: DecorateMethod<ApiType>);
22
+ get tx(): MapConstructorExec<ApiType>;
23
+ }
24
+ export declare function extendBlueprint<ApiType extends ApiTypes>(type: ApiType, decorateMethod: DecorateMethod<ApiType>): BlueprintConstructor<ApiType>;