@vorionsys/basis 1.0.1

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 (174) hide show
  1. package/.env.example +22 -0
  2. package/AMOY-MIGRATION.md +188 -0
  3. package/DEPLOY-AMOY.md +368 -0
  4. package/DEPLOY-NOW.md +216 -0
  5. package/DEPLOYMENT.md +239 -0
  6. package/GET-WALLET.md +286 -0
  7. package/QUICK-WALLET-SETUP.md +268 -0
  8. package/README.md +195 -0
  9. package/artifacts/@openzeppelin/contracts/access/AccessControl.sol/AccessControl.dbg.json +4 -0
  10. package/artifacts/@openzeppelin/contracts/access/AccessControl.sol/AccessControl.json +236 -0
  11. package/artifacts/@openzeppelin/contracts/access/IAccessControl.sol/IAccessControl.dbg.json +4 -0
  12. package/artifacts/@openzeppelin/contracts/access/IAccessControl.sol/IAccessControl.json +204 -0
  13. package/artifacts/@openzeppelin/contracts/interfaces/IERC4906.sol/IERC4906.dbg.json +4 -0
  14. package/artifacts/@openzeppelin/contracts/interfaces/IERC4906.sol/IERC4906.json +328 -0
  15. package/artifacts/@openzeppelin/contracts/interfaces/draft-IERC6093.sol/IERC1155Errors.dbg.json +4 -0
  16. package/artifacts/@openzeppelin/contracts/interfaces/draft-IERC6093.sol/IERC1155Errors.json +113 -0
  17. package/artifacts/@openzeppelin/contracts/interfaces/draft-IERC6093.sol/IERC20Errors.dbg.json +4 -0
  18. package/artifacts/@openzeppelin/contracts/interfaces/draft-IERC6093.sol/IERC20Errors.json +97 -0
  19. package/artifacts/@openzeppelin/contracts/interfaces/draft-IERC6093.sol/IERC721Errors.dbg.json +4 -0
  20. package/artifacts/@openzeppelin/contracts/interfaces/draft-IERC6093.sol/IERC721Errors.json +114 -0
  21. package/artifacts/@openzeppelin/contracts/token/ERC721/ERC721.sol/ERC721.dbg.json +4 -0
  22. package/artifacts/@openzeppelin/contracts/token/ERC721/ERC721.sol/ERC721.json +444 -0
  23. package/artifacts/@openzeppelin/contracts/token/ERC721/IERC721.sol/IERC721.dbg.json +4 -0
  24. package/artifacts/@openzeppelin/contracts/token/ERC721/IERC721.sol/IERC721.json +296 -0
  25. package/artifacts/@openzeppelin/contracts/token/ERC721/IERC721Receiver.sol/IERC721Receiver.dbg.json +4 -0
  26. package/artifacts/@openzeppelin/contracts/token/ERC721/IERC721Receiver.sol/IERC721Receiver.json +45 -0
  27. package/artifacts/@openzeppelin/contracts/token/ERC721/extensions/ERC721Enumerable.sol/ERC721Enumerable.dbg.json +4 -0
  28. package/artifacts/@openzeppelin/contracts/token/ERC721/extensions/ERC721Enumerable.sol/ERC721Enumerable.json +521 -0
  29. package/artifacts/@openzeppelin/contracts/token/ERC721/extensions/ERC721URIStorage.sol/ERC721URIStorage.dbg.json +4 -0
  30. package/artifacts/@openzeppelin/contracts/token/ERC721/extensions/ERC721URIStorage.sol/ERC721URIStorage.json +476 -0
  31. package/artifacts/@openzeppelin/contracts/token/ERC721/extensions/IERC721Enumerable.sol/IERC721Enumerable.dbg.json +4 -0
  32. package/artifacts/@openzeppelin/contracts/token/ERC721/extensions/IERC721Enumerable.sol/IERC721Enumerable.json +352 -0
  33. package/artifacts/@openzeppelin/contracts/token/ERC721/extensions/IERC721Metadata.sol/IERC721Metadata.dbg.json +4 -0
  34. package/artifacts/@openzeppelin/contracts/token/ERC721/extensions/IERC721Metadata.sol/IERC721Metadata.json +341 -0
  35. package/artifacts/@openzeppelin/contracts/token/ERC721/utils/ERC721Utils.sol/ERC721Utils.dbg.json +4 -0
  36. package/artifacts/@openzeppelin/contracts/token/ERC721/utils/ERC721Utils.sol/ERC721Utils.json +10 -0
  37. package/artifacts/@openzeppelin/contracts/utils/Context.sol/Context.dbg.json +4 -0
  38. package/artifacts/@openzeppelin/contracts/utils/Context.sol/Context.json +10 -0
  39. package/artifacts/@openzeppelin/contracts/utils/Panic.sol/Panic.dbg.json +4 -0
  40. package/artifacts/@openzeppelin/contracts/utils/Panic.sol/Panic.json +10 -0
  41. package/artifacts/@openzeppelin/contracts/utils/Strings.sol/Strings.dbg.json +4 -0
  42. package/artifacts/@openzeppelin/contracts/utils/Strings.sol/Strings.json +37 -0
  43. package/artifacts/@openzeppelin/contracts/utils/introspection/ERC165.sol/ERC165.dbg.json +4 -0
  44. package/artifacts/@openzeppelin/contracts/utils/introspection/ERC165.sol/ERC165.json +30 -0
  45. package/artifacts/@openzeppelin/contracts/utils/introspection/IERC165.sol/IERC165.dbg.json +4 -0
  46. package/artifacts/@openzeppelin/contracts/utils/introspection/IERC165.sol/IERC165.json +30 -0
  47. package/artifacts/@openzeppelin/contracts/utils/math/Math.sol/Math.dbg.json +4 -0
  48. package/artifacts/@openzeppelin/contracts/utils/math/Math.sol/Math.json +10 -0
  49. package/artifacts/@openzeppelin/contracts/utils/math/SafeCast.sol/SafeCast.dbg.json +4 -0
  50. package/artifacts/@openzeppelin/contracts/utils/math/SafeCast.sol/SafeCast.json +65 -0
  51. package/artifacts/@openzeppelin/contracts/utils/math/SignedMath.sol/SignedMath.dbg.json +4 -0
  52. package/artifacts/@openzeppelin/contracts/utils/math/SignedMath.sol/SignedMath.json +10 -0
  53. package/artifacts/build-info/357d1bba4062d461f497f221490811a3.json +1 -0
  54. package/artifacts/contracts/AgentCard.sol/AgentCard.dbg.json +4 -0
  55. package/artifacts/contracts/AgentCard.sol/AgentCard.json +1430 -0
  56. package/build_errors.txt +0 -0
  57. package/build_output.txt +0 -0
  58. package/cache/solidity-files-cache.json +885 -0
  59. package/contracts/AgentCard.sol +478 -0
  60. package/contracts/deploy/01-deploy-agentcard.ts +66 -0
  61. package/dist/index.d.ts.map +1 -0
  62. package/dist/index.js +12 -0
  63. package/dist/kya/accountability.d.ts.map +1 -0
  64. package/dist/kya/accountability.js +100 -0
  65. package/dist/kya/authorization.d.ts.map +1 -0
  66. package/dist/kya/authorization.js +258 -0
  67. package/dist/kya/behavior.d.ts.map +1 -0
  68. package/dist/kya/behavior.js +142 -0
  69. package/dist/kya/identity.d.ts.map +1 -0
  70. package/dist/kya/identity.js +187 -0
  71. package/dist/kya/index.d.ts.map +1 -0
  72. package/dist/kya/index.js +99 -0
  73. package/dist/kya/types.d.ts.map +1 -0
  74. package/dist/kya/types.js +5 -0
  75. package/dist/trust-1000-agents.test.d.ts.map +1 -0
  76. package/dist/trust-1000-agents.test.js +608 -0
  77. package/dist/trust-capabilities.d.ts.map +1 -0
  78. package/dist/trust-capabilities.js +478 -0
  79. package/dist/trust-factors.d.ts.map +1 -0
  80. package/dist/trust-factors.js +588 -0
  81. package/dist/trust-factors.test.d.ts.map +1 -0
  82. package/dist/trust-factors.test.js +179 -0
  83. package/dist/validation-gate.d.ts.map +1 -0
  84. package/dist/validation-gate.js +468 -0
  85. package/dist/validation-gate.test.d.ts.map +1 -0
  86. package/dist/validation-gate.test.js +419 -0
  87. package/hardhat.config.ts +55 -0
  88. package/package.json +57 -0
  89. package/scripts/certify-agent.ts +91 -0
  90. package/scripts/deploy-agentcard.ts +63 -0
  91. package/scripts/mint-agentcard.ts +87 -0
  92. package/specs/adversarial-sandbox-test-suite.md +1055 -0
  93. package/specs/kya-framework.md +910 -0
  94. package/specs/trust-factors-v2.md +437 -0
  95. package/src/index.ts +14 -0
  96. package/src/kya/accountability.ts +132 -0
  97. package/src/kya/authorization.ts +325 -0
  98. package/src/kya/behavior.ts +169 -0
  99. package/src/kya/identity.ts +224 -0
  100. package/src/kya/index.ts +125 -0
  101. package/src/kya/types.ts +242 -0
  102. package/src/trust-1000-agents.test.ts +745 -0
  103. package/src/trust-capabilities.ts +517 -0
  104. package/src/trust-factors.test.ts +241 -0
  105. package/src/trust-factors.ts +666 -0
  106. package/src/validation-gate.test.ts +531 -0
  107. package/src/validation-gate.ts +665 -0
  108. package/test-kya-simple.ts +258 -0
  109. package/test-kya.ts +245 -0
  110. package/tsconfig.json +14 -0
  111. package/typechain-types/@openzeppelin/contracts/access/AccessControl.ts +324 -0
  112. package/typechain-types/@openzeppelin/contracts/access/IAccessControl.ts +292 -0
  113. package/typechain-types/@openzeppelin/contracts/access/index.ts +5 -0
  114. package/typechain-types/@openzeppelin/contracts/index.ts +11 -0
  115. package/typechain-types/@openzeppelin/contracts/interfaces/IERC4906.ts +462 -0
  116. package/typechain-types/@openzeppelin/contracts/interfaces/draft-IERC6093.sol/IERC1155Errors.ts +69 -0
  117. package/typechain-types/@openzeppelin/contracts/interfaces/draft-IERC6093.sol/IERC20Errors.ts +69 -0
  118. package/typechain-types/@openzeppelin/contracts/interfaces/draft-IERC6093.sol/IERC721Errors.ts +69 -0
  119. package/typechain-types/@openzeppelin/contracts/interfaces/draft-IERC6093.sol/index.ts +6 -0
  120. package/typechain-types/@openzeppelin/contracts/interfaces/index.ts +6 -0
  121. package/typechain-types/@openzeppelin/contracts/token/ERC721/ERC721.ts +420 -0
  122. package/typechain-types/@openzeppelin/contracts/token/ERC721/IERC721.ts +393 -0
  123. package/typechain-types/@openzeppelin/contracts/token/ERC721/IERC721Receiver.ts +110 -0
  124. package/typechain-types/@openzeppelin/contracts/token/ERC721/extensions/ERC721Enumerable.ts +470 -0
  125. package/typechain-types/@openzeppelin/contracts/token/ERC721/extensions/ERC721URIStorage.ts +489 -0
  126. package/typechain-types/@openzeppelin/contracts/token/ERC721/extensions/IERC721Enumerable.ts +443 -0
  127. package/typechain-types/@openzeppelin/contracts/token/ERC721/extensions/IERC721Metadata.ts +420 -0
  128. package/typechain-types/@openzeppelin/contracts/token/ERC721/extensions/index.ts +7 -0
  129. package/typechain-types/@openzeppelin/contracts/token/ERC721/index.ts +8 -0
  130. package/typechain-types/@openzeppelin/contracts/token/index.ts +5 -0
  131. package/typechain-types/@openzeppelin/contracts/utils/Strings.ts +69 -0
  132. package/typechain-types/@openzeppelin/contracts/utils/index.ts +8 -0
  133. package/typechain-types/@openzeppelin/contracts/utils/introspection/ERC165.ts +94 -0
  134. package/typechain-types/@openzeppelin/contracts/utils/introspection/IERC165.ts +94 -0
  135. package/typechain-types/@openzeppelin/contracts/utils/introspection/index.ts +5 -0
  136. package/typechain-types/@openzeppelin/contracts/utils/math/SafeCast.ts +69 -0
  137. package/typechain-types/@openzeppelin/contracts/utils/math/index.ts +4 -0
  138. package/typechain-types/@openzeppelin/index.ts +5 -0
  139. package/typechain-types/common.ts +131 -0
  140. package/typechain-types/contracts/AgentCard.ts +1415 -0
  141. package/typechain-types/contracts/index.ts +4 -0
  142. package/typechain-types/factories/@openzeppelin/contracts/access/AccessControl__factory.ts +250 -0
  143. package/typechain-types/factories/@openzeppelin/contracts/access/IAccessControl__factory.ts +218 -0
  144. package/typechain-types/factories/@openzeppelin/contracts/access/index.ts +5 -0
  145. package/typechain-types/factories/@openzeppelin/contracts/index.ts +7 -0
  146. package/typechain-types/factories/@openzeppelin/contracts/interfaces/IERC4906__factory.ts +339 -0
  147. package/typechain-types/factories/@openzeppelin/contracts/interfaces/draft-IERC6093.sol/IERC1155Errors__factory.ts +127 -0
  148. package/typechain-types/factories/@openzeppelin/contracts/interfaces/draft-IERC6093.sol/IERC20Errors__factory.ts +111 -0
  149. package/typechain-types/factories/@openzeppelin/contracts/interfaces/draft-IERC6093.sol/IERC721Errors__factory.ts +128 -0
  150. package/typechain-types/factories/@openzeppelin/contracts/interfaces/draft-IERC6093.sol/index.ts +6 -0
  151. package/typechain-types/factories/@openzeppelin/contracts/interfaces/index.ts +5 -0
  152. package/typechain-types/factories/@openzeppelin/contracts/token/ERC721/ERC721__factory.ts +455 -0
  153. package/typechain-types/factories/@openzeppelin/contracts/token/ERC721/IERC721Receiver__factory.ts +59 -0
  154. package/typechain-types/factories/@openzeppelin/contracts/token/ERC721/IERC721__factory.ts +307 -0
  155. package/typechain-types/factories/@openzeppelin/contracts/token/ERC721/extensions/ERC721Enumerable__factory.ts +535 -0
  156. package/typechain-types/factories/@openzeppelin/contracts/token/ERC721/extensions/ERC721URIStorage__factory.ts +490 -0
  157. package/typechain-types/factories/@openzeppelin/contracts/token/ERC721/extensions/IERC721Enumerable__factory.ts +366 -0
  158. package/typechain-types/factories/@openzeppelin/contracts/token/ERC721/extensions/IERC721Metadata__factory.ts +355 -0
  159. package/typechain-types/factories/@openzeppelin/contracts/token/ERC721/extensions/index.ts +7 -0
  160. package/typechain-types/factories/@openzeppelin/contracts/token/ERC721/index.ts +7 -0
  161. package/typechain-types/factories/@openzeppelin/contracts/token/index.ts +4 -0
  162. package/typechain-types/factories/@openzeppelin/contracts/utils/Strings__factory.ts +90 -0
  163. package/typechain-types/factories/@openzeppelin/contracts/utils/index.ts +6 -0
  164. package/typechain-types/factories/@openzeppelin/contracts/utils/introspection/ERC165__factory.ts +41 -0
  165. package/typechain-types/factories/@openzeppelin/contracts/utils/introspection/IERC165__factory.ts +41 -0
  166. package/typechain-types/factories/@openzeppelin/contracts/utils/introspection/index.ts +5 -0
  167. package/typechain-types/factories/@openzeppelin/contracts/utils/math/SafeCast__factory.ts +118 -0
  168. package/typechain-types/factories/@openzeppelin/contracts/utils/math/index.ts +4 -0
  169. package/typechain-types/factories/@openzeppelin/index.ts +4 -0
  170. package/typechain-types/factories/contracts/AgentCard__factory.ts +1480 -0
  171. package/typechain-types/factories/contracts/index.ts +4 -0
  172. package/typechain-types/factories/index.ts +5 -0
  173. package/typechain-types/index.ts +44 -0
  174. package/vitest.config.ts +8 -0
@@ -0,0 +1,443 @@
1
+ /* Autogenerated file. Do not edit manually. */
2
+ /* tslint:disable */
3
+ /* eslint-disable */
4
+ import type {
5
+ BaseContract,
6
+ BigNumberish,
7
+ BytesLike,
8
+ FunctionFragment,
9
+ Result,
10
+ Interface,
11
+ EventFragment,
12
+ AddressLike,
13
+ ContractRunner,
14
+ ContractMethod,
15
+ Listener,
16
+ } from "ethers";
17
+ import type {
18
+ TypedContractEvent,
19
+ TypedDeferredTopicFilter,
20
+ TypedEventLog,
21
+ TypedLogDescription,
22
+ TypedListener,
23
+ TypedContractMethod,
24
+ } from "../../../../../common";
25
+
26
+ export interface IERC721EnumerableInterface extends Interface {
27
+ getFunction(
28
+ nameOrSignature:
29
+ | "approve"
30
+ | "balanceOf"
31
+ | "getApproved"
32
+ | "isApprovedForAll"
33
+ | "ownerOf"
34
+ | "safeTransferFrom(address,address,uint256)"
35
+ | "safeTransferFrom(address,address,uint256,bytes)"
36
+ | "setApprovalForAll"
37
+ | "supportsInterface"
38
+ | "tokenByIndex"
39
+ | "tokenOfOwnerByIndex"
40
+ | "totalSupply"
41
+ | "transferFrom"
42
+ ): FunctionFragment;
43
+
44
+ getEvent(
45
+ nameOrSignatureOrTopic: "Approval" | "ApprovalForAll" | "Transfer"
46
+ ): EventFragment;
47
+
48
+ encodeFunctionData(
49
+ functionFragment: "approve",
50
+ values: [AddressLike, BigNumberish]
51
+ ): string;
52
+ encodeFunctionData(
53
+ functionFragment: "balanceOf",
54
+ values: [AddressLike]
55
+ ): string;
56
+ encodeFunctionData(
57
+ functionFragment: "getApproved",
58
+ values: [BigNumberish]
59
+ ): string;
60
+ encodeFunctionData(
61
+ functionFragment: "isApprovedForAll",
62
+ values: [AddressLike, AddressLike]
63
+ ): string;
64
+ encodeFunctionData(
65
+ functionFragment: "ownerOf",
66
+ values: [BigNumberish]
67
+ ): string;
68
+ encodeFunctionData(
69
+ functionFragment: "safeTransferFrom(address,address,uint256)",
70
+ values: [AddressLike, AddressLike, BigNumberish]
71
+ ): string;
72
+ encodeFunctionData(
73
+ functionFragment: "safeTransferFrom(address,address,uint256,bytes)",
74
+ values: [AddressLike, AddressLike, BigNumberish, BytesLike]
75
+ ): string;
76
+ encodeFunctionData(
77
+ functionFragment: "setApprovalForAll",
78
+ values: [AddressLike, boolean]
79
+ ): string;
80
+ encodeFunctionData(
81
+ functionFragment: "supportsInterface",
82
+ values: [BytesLike]
83
+ ): string;
84
+ encodeFunctionData(
85
+ functionFragment: "tokenByIndex",
86
+ values: [BigNumberish]
87
+ ): string;
88
+ encodeFunctionData(
89
+ functionFragment: "tokenOfOwnerByIndex",
90
+ values: [AddressLike, BigNumberish]
91
+ ): string;
92
+ encodeFunctionData(
93
+ functionFragment: "totalSupply",
94
+ values?: undefined
95
+ ): string;
96
+ encodeFunctionData(
97
+ functionFragment: "transferFrom",
98
+ values: [AddressLike, AddressLike, BigNumberish]
99
+ ): string;
100
+
101
+ decodeFunctionResult(functionFragment: "approve", data: BytesLike): Result;
102
+ decodeFunctionResult(functionFragment: "balanceOf", data: BytesLike): Result;
103
+ decodeFunctionResult(
104
+ functionFragment: "getApproved",
105
+ data: BytesLike
106
+ ): Result;
107
+ decodeFunctionResult(
108
+ functionFragment: "isApprovedForAll",
109
+ data: BytesLike
110
+ ): Result;
111
+ decodeFunctionResult(functionFragment: "ownerOf", data: BytesLike): Result;
112
+ decodeFunctionResult(
113
+ functionFragment: "safeTransferFrom(address,address,uint256)",
114
+ data: BytesLike
115
+ ): Result;
116
+ decodeFunctionResult(
117
+ functionFragment: "safeTransferFrom(address,address,uint256,bytes)",
118
+ data: BytesLike
119
+ ): Result;
120
+ decodeFunctionResult(
121
+ functionFragment: "setApprovalForAll",
122
+ data: BytesLike
123
+ ): Result;
124
+ decodeFunctionResult(
125
+ functionFragment: "supportsInterface",
126
+ data: BytesLike
127
+ ): Result;
128
+ decodeFunctionResult(
129
+ functionFragment: "tokenByIndex",
130
+ data: BytesLike
131
+ ): Result;
132
+ decodeFunctionResult(
133
+ functionFragment: "tokenOfOwnerByIndex",
134
+ data: BytesLike
135
+ ): Result;
136
+ decodeFunctionResult(
137
+ functionFragment: "totalSupply",
138
+ data: BytesLike
139
+ ): Result;
140
+ decodeFunctionResult(
141
+ functionFragment: "transferFrom",
142
+ data: BytesLike
143
+ ): Result;
144
+ }
145
+
146
+ export namespace ApprovalEvent {
147
+ export type InputTuple = [
148
+ owner: AddressLike,
149
+ approved: AddressLike,
150
+ tokenId: BigNumberish
151
+ ];
152
+ export type OutputTuple = [owner: string, approved: string, tokenId: bigint];
153
+ export interface OutputObject {
154
+ owner: string;
155
+ approved: string;
156
+ tokenId: bigint;
157
+ }
158
+ export type Event = TypedContractEvent<InputTuple, OutputTuple, OutputObject>;
159
+ export type Filter = TypedDeferredTopicFilter<Event>;
160
+ export type Log = TypedEventLog<Event>;
161
+ export type LogDescription = TypedLogDescription<Event>;
162
+ }
163
+
164
+ export namespace ApprovalForAllEvent {
165
+ export type InputTuple = [
166
+ owner: AddressLike,
167
+ operator: AddressLike,
168
+ approved: boolean
169
+ ];
170
+ export type OutputTuple = [
171
+ owner: string,
172
+ operator: string,
173
+ approved: boolean
174
+ ];
175
+ export interface OutputObject {
176
+ owner: string;
177
+ operator: string;
178
+ approved: boolean;
179
+ }
180
+ export type Event = TypedContractEvent<InputTuple, OutputTuple, OutputObject>;
181
+ export type Filter = TypedDeferredTopicFilter<Event>;
182
+ export type Log = TypedEventLog<Event>;
183
+ export type LogDescription = TypedLogDescription<Event>;
184
+ }
185
+
186
+ export namespace TransferEvent {
187
+ export type InputTuple = [
188
+ from: AddressLike,
189
+ to: AddressLike,
190
+ tokenId: BigNumberish
191
+ ];
192
+ export type OutputTuple = [from: string, to: string, tokenId: bigint];
193
+ export interface OutputObject {
194
+ from: string;
195
+ to: string;
196
+ tokenId: bigint;
197
+ }
198
+ export type Event = TypedContractEvent<InputTuple, OutputTuple, OutputObject>;
199
+ export type Filter = TypedDeferredTopicFilter<Event>;
200
+ export type Log = TypedEventLog<Event>;
201
+ export type LogDescription = TypedLogDescription<Event>;
202
+ }
203
+
204
+ export interface IERC721Enumerable extends BaseContract {
205
+ connect(runner?: ContractRunner | null): IERC721Enumerable;
206
+ waitForDeployment(): Promise<this>;
207
+
208
+ interface: IERC721EnumerableInterface;
209
+
210
+ queryFilter<TCEvent extends TypedContractEvent>(
211
+ event: TCEvent,
212
+ fromBlockOrBlockhash?: string | number | undefined,
213
+ toBlock?: string | number | undefined
214
+ ): Promise<Array<TypedEventLog<TCEvent>>>;
215
+ queryFilter<TCEvent extends TypedContractEvent>(
216
+ filter: TypedDeferredTopicFilter<TCEvent>,
217
+ fromBlockOrBlockhash?: string | number | undefined,
218
+ toBlock?: string | number | undefined
219
+ ): Promise<Array<TypedEventLog<TCEvent>>>;
220
+
221
+ on<TCEvent extends TypedContractEvent>(
222
+ event: TCEvent,
223
+ listener: TypedListener<TCEvent>
224
+ ): Promise<this>;
225
+ on<TCEvent extends TypedContractEvent>(
226
+ filter: TypedDeferredTopicFilter<TCEvent>,
227
+ listener: TypedListener<TCEvent>
228
+ ): Promise<this>;
229
+
230
+ once<TCEvent extends TypedContractEvent>(
231
+ event: TCEvent,
232
+ listener: TypedListener<TCEvent>
233
+ ): Promise<this>;
234
+ once<TCEvent extends TypedContractEvent>(
235
+ filter: TypedDeferredTopicFilter<TCEvent>,
236
+ listener: TypedListener<TCEvent>
237
+ ): Promise<this>;
238
+
239
+ listeners<TCEvent extends TypedContractEvent>(
240
+ event: TCEvent
241
+ ): Promise<Array<TypedListener<TCEvent>>>;
242
+ listeners(eventName?: string): Promise<Array<Listener>>;
243
+ removeAllListeners<TCEvent extends TypedContractEvent>(
244
+ event?: TCEvent
245
+ ): Promise<this>;
246
+
247
+ approve: TypedContractMethod<
248
+ [to: AddressLike, tokenId: BigNumberish],
249
+ [void],
250
+ "nonpayable"
251
+ >;
252
+
253
+ balanceOf: TypedContractMethod<[owner: AddressLike], [bigint], "view">;
254
+
255
+ getApproved: TypedContractMethod<[tokenId: BigNumberish], [string], "view">;
256
+
257
+ isApprovedForAll: TypedContractMethod<
258
+ [owner: AddressLike, operator: AddressLike],
259
+ [boolean],
260
+ "view"
261
+ >;
262
+
263
+ ownerOf: TypedContractMethod<[tokenId: BigNumberish], [string], "view">;
264
+
265
+ "safeTransferFrom(address,address,uint256)": TypedContractMethod<
266
+ [from: AddressLike, to: AddressLike, tokenId: BigNumberish],
267
+ [void],
268
+ "nonpayable"
269
+ >;
270
+
271
+ "safeTransferFrom(address,address,uint256,bytes)": TypedContractMethod<
272
+ [
273
+ from: AddressLike,
274
+ to: AddressLike,
275
+ tokenId: BigNumberish,
276
+ data: BytesLike
277
+ ],
278
+ [void],
279
+ "nonpayable"
280
+ >;
281
+
282
+ setApprovalForAll: TypedContractMethod<
283
+ [operator: AddressLike, approved: boolean],
284
+ [void],
285
+ "nonpayable"
286
+ >;
287
+
288
+ supportsInterface: TypedContractMethod<
289
+ [interfaceId: BytesLike],
290
+ [boolean],
291
+ "view"
292
+ >;
293
+
294
+ tokenByIndex: TypedContractMethod<[index: BigNumberish], [bigint], "view">;
295
+
296
+ tokenOfOwnerByIndex: TypedContractMethod<
297
+ [owner: AddressLike, index: BigNumberish],
298
+ [bigint],
299
+ "view"
300
+ >;
301
+
302
+ totalSupply: TypedContractMethod<[], [bigint], "view">;
303
+
304
+ transferFrom: TypedContractMethod<
305
+ [from: AddressLike, to: AddressLike, tokenId: BigNumberish],
306
+ [void],
307
+ "nonpayable"
308
+ >;
309
+
310
+ getFunction<T extends ContractMethod = ContractMethod>(
311
+ key: string | FunctionFragment
312
+ ): T;
313
+
314
+ getFunction(
315
+ nameOrSignature: "approve"
316
+ ): TypedContractMethod<
317
+ [to: AddressLike, tokenId: BigNumberish],
318
+ [void],
319
+ "nonpayable"
320
+ >;
321
+ getFunction(
322
+ nameOrSignature: "balanceOf"
323
+ ): TypedContractMethod<[owner: AddressLike], [bigint], "view">;
324
+ getFunction(
325
+ nameOrSignature: "getApproved"
326
+ ): TypedContractMethod<[tokenId: BigNumberish], [string], "view">;
327
+ getFunction(
328
+ nameOrSignature: "isApprovedForAll"
329
+ ): TypedContractMethod<
330
+ [owner: AddressLike, operator: AddressLike],
331
+ [boolean],
332
+ "view"
333
+ >;
334
+ getFunction(
335
+ nameOrSignature: "ownerOf"
336
+ ): TypedContractMethod<[tokenId: BigNumberish], [string], "view">;
337
+ getFunction(
338
+ nameOrSignature: "safeTransferFrom(address,address,uint256)"
339
+ ): TypedContractMethod<
340
+ [from: AddressLike, to: AddressLike, tokenId: BigNumberish],
341
+ [void],
342
+ "nonpayable"
343
+ >;
344
+ getFunction(
345
+ nameOrSignature: "safeTransferFrom(address,address,uint256,bytes)"
346
+ ): TypedContractMethod<
347
+ [
348
+ from: AddressLike,
349
+ to: AddressLike,
350
+ tokenId: BigNumberish,
351
+ data: BytesLike
352
+ ],
353
+ [void],
354
+ "nonpayable"
355
+ >;
356
+ getFunction(
357
+ nameOrSignature: "setApprovalForAll"
358
+ ): TypedContractMethod<
359
+ [operator: AddressLike, approved: boolean],
360
+ [void],
361
+ "nonpayable"
362
+ >;
363
+ getFunction(
364
+ nameOrSignature: "supportsInterface"
365
+ ): TypedContractMethod<[interfaceId: BytesLike], [boolean], "view">;
366
+ getFunction(
367
+ nameOrSignature: "tokenByIndex"
368
+ ): TypedContractMethod<[index: BigNumberish], [bigint], "view">;
369
+ getFunction(
370
+ nameOrSignature: "tokenOfOwnerByIndex"
371
+ ): TypedContractMethod<
372
+ [owner: AddressLike, index: BigNumberish],
373
+ [bigint],
374
+ "view"
375
+ >;
376
+ getFunction(
377
+ nameOrSignature: "totalSupply"
378
+ ): TypedContractMethod<[], [bigint], "view">;
379
+ getFunction(
380
+ nameOrSignature: "transferFrom"
381
+ ): TypedContractMethod<
382
+ [from: AddressLike, to: AddressLike, tokenId: BigNumberish],
383
+ [void],
384
+ "nonpayable"
385
+ >;
386
+
387
+ getEvent(
388
+ key: "Approval"
389
+ ): TypedContractEvent<
390
+ ApprovalEvent.InputTuple,
391
+ ApprovalEvent.OutputTuple,
392
+ ApprovalEvent.OutputObject
393
+ >;
394
+ getEvent(
395
+ key: "ApprovalForAll"
396
+ ): TypedContractEvent<
397
+ ApprovalForAllEvent.InputTuple,
398
+ ApprovalForAllEvent.OutputTuple,
399
+ ApprovalForAllEvent.OutputObject
400
+ >;
401
+ getEvent(
402
+ key: "Transfer"
403
+ ): TypedContractEvent<
404
+ TransferEvent.InputTuple,
405
+ TransferEvent.OutputTuple,
406
+ TransferEvent.OutputObject
407
+ >;
408
+
409
+ filters: {
410
+ "Approval(address,address,uint256)": TypedContractEvent<
411
+ ApprovalEvent.InputTuple,
412
+ ApprovalEvent.OutputTuple,
413
+ ApprovalEvent.OutputObject
414
+ >;
415
+ Approval: TypedContractEvent<
416
+ ApprovalEvent.InputTuple,
417
+ ApprovalEvent.OutputTuple,
418
+ ApprovalEvent.OutputObject
419
+ >;
420
+
421
+ "ApprovalForAll(address,address,bool)": TypedContractEvent<
422
+ ApprovalForAllEvent.InputTuple,
423
+ ApprovalForAllEvent.OutputTuple,
424
+ ApprovalForAllEvent.OutputObject
425
+ >;
426
+ ApprovalForAll: TypedContractEvent<
427
+ ApprovalForAllEvent.InputTuple,
428
+ ApprovalForAllEvent.OutputTuple,
429
+ ApprovalForAllEvent.OutputObject
430
+ >;
431
+
432
+ "Transfer(address,address,uint256)": TypedContractEvent<
433
+ TransferEvent.InputTuple,
434
+ TransferEvent.OutputTuple,
435
+ TransferEvent.OutputObject
436
+ >;
437
+ Transfer: TypedContractEvent<
438
+ TransferEvent.InputTuple,
439
+ TransferEvent.OutputTuple,
440
+ TransferEvent.OutputObject
441
+ >;
442
+ };
443
+ }