@silvana-one/nft 0.1.0

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 (236) hide show
  1. package/README.md +1400 -0
  2. package/dist/node/admin/advanced.d.ts +469 -0
  3. package/dist/node/admin/advanced.js +525 -0
  4. package/dist/node/admin/advanced.js.map +1 -0
  5. package/dist/node/admin/index.d.ts +1 -0
  6. package/dist/node/admin/index.js +2 -0
  7. package/dist/node/admin/index.js.map +1 -0
  8. package/dist/node/contracts/admin.d.ts +140 -0
  9. package/dist/node/contracts/admin.js +336 -0
  10. package/dist/node/contracts/admin.js.map +1 -0
  11. package/dist/node/contracts/collection.d.ts +551 -0
  12. package/dist/node/contracts/collection.js +1049 -0
  13. package/dist/node/contracts/collection.js.map +1 -0
  14. package/dist/node/contracts/index.d.ts +3 -0
  15. package/dist/node/contracts/index.js +4 -0
  16. package/dist/node/contracts/index.js.map +1 -0
  17. package/dist/node/contracts/nft.d.ts +76 -0
  18. package/dist/node/contracts/nft.js +329 -0
  19. package/dist/node/contracts/nft.js.map +1 -0
  20. package/dist/node/contracts.d.ts +709 -0
  21. package/dist/node/contracts.js +61 -0
  22. package/dist/node/contracts.js.map +1 -0
  23. package/dist/node/index.cjs +5032 -0
  24. package/dist/node/index.d.ts +8 -0
  25. package/dist/node/index.js +9 -0
  26. package/dist/node/index.js.map +1 -0
  27. package/dist/node/interfaces/admin.d.ts +102 -0
  28. package/dist/node/interfaces/admin.js +2 -0
  29. package/dist/node/interfaces/admin.js.map +1 -0
  30. package/dist/node/interfaces/approval.d.ts +57 -0
  31. package/dist/node/interfaces/approval.js +62 -0
  32. package/dist/node/interfaces/approval.js.map +1 -0
  33. package/dist/node/interfaces/collection.d.ts +57 -0
  34. package/dist/node/interfaces/collection.js +2 -0
  35. package/dist/node/interfaces/collection.js.map +1 -0
  36. package/dist/node/interfaces/encoding.d.ts +24 -0
  37. package/dist/node/interfaces/encoding.js +32 -0
  38. package/dist/node/interfaces/encoding.js.map +1 -0
  39. package/dist/node/interfaces/events.d.ts +833 -0
  40. package/dist/node/interfaces/events.js +106 -0
  41. package/dist/node/interfaces/events.js.map +1 -0
  42. package/dist/node/interfaces/index.d.ts +10 -0
  43. package/dist/node/interfaces/index.js +11 -0
  44. package/dist/node/interfaces/index.js.map +1 -0
  45. package/dist/node/interfaces/ownable.d.ts +94 -0
  46. package/dist/node/interfaces/ownable.js +12 -0
  47. package/dist/node/interfaces/ownable.js.map +1 -0
  48. package/dist/node/interfaces/owner.d.ts +61 -0
  49. package/dist/node/interfaces/owner.js +101 -0
  50. package/dist/node/interfaces/owner.js.map +1 -0
  51. package/dist/node/interfaces/pausable.d.ts +74 -0
  52. package/dist/node/interfaces/pausable.js +14 -0
  53. package/dist/node/interfaces/pausable.js.map +1 -0
  54. package/dist/node/interfaces/types.d.ts +2297 -0
  55. package/dist/node/interfaces/types.js +507 -0
  56. package/dist/node/interfaces/types.js.map +1 -0
  57. package/dist/node/interfaces/update.d.ts +53 -0
  58. package/dist/node/interfaces/update.js +58 -0
  59. package/dist/node/interfaces/update.js.map +1 -0
  60. package/dist/node/marketplace/auction.d.ts +775 -0
  61. package/dist/node/marketplace/auction.js +430 -0
  62. package/dist/node/marketplace/auction.js.map +1 -0
  63. package/dist/node/marketplace/bid.d.ts +254 -0
  64. package/dist/node/marketplace/bid.js +260 -0
  65. package/dist/node/marketplace/bid.js.map +1 -0
  66. package/dist/node/marketplace/index.d.ts +5 -0
  67. package/dist/node/marketplace/index.js +6 -0
  68. package/dist/node/marketplace/index.js.map +1 -0
  69. package/dist/node/marketplace/nft-shares.d.ts +1083 -0
  70. package/dist/node/marketplace/nft-shares.js +398 -0
  71. package/dist/node/marketplace/nft-shares.js.map +1 -0
  72. package/dist/node/marketplace/offer.d.ts +192 -0
  73. package/dist/node/marketplace/offer.js +132 -0
  74. package/dist/node/marketplace/offer.js.map +1 -0
  75. package/dist/node/marketplace/types.d.ts +374 -0
  76. package/dist/node/marketplace/types.js +33 -0
  77. package/dist/node/marketplace/types.js.map +1 -0
  78. package/dist/node/metadata/index.d.ts +3 -0
  79. package/dist/node/metadata/index.js +4 -0
  80. package/dist/node/metadata/index.js.map +1 -0
  81. package/dist/node/metadata/metadata.d.ts +337 -0
  82. package/dist/node/metadata/metadata.js +439 -0
  83. package/dist/node/metadata/metadata.js.map +1 -0
  84. package/dist/node/metadata/text.d.ts +44 -0
  85. package/dist/node/metadata/text.js +42 -0
  86. package/dist/node/metadata/text.js.map +1 -0
  87. package/dist/node/metadata/tree.d.ts +75 -0
  88. package/dist/node/metadata/tree.js +85 -0
  89. package/dist/node/metadata/tree.js.map +1 -0
  90. package/dist/node/vk.d.ts +42 -0
  91. package/dist/node/vk.js +45 -0
  92. package/dist/node/vk.js.map +1 -0
  93. package/dist/node/zkprogram-example/game.d.ts +76 -0
  94. package/dist/node/zkprogram-example/game.js +108 -0
  95. package/dist/node/zkprogram-example/game.js.map +1 -0
  96. package/dist/node/zkprogram-example/index.d.ts +2 -0
  97. package/dist/node/zkprogram-example/index.js +3 -0
  98. package/dist/node/zkprogram-example/index.js.map +1 -0
  99. package/dist/node/zkprogram-example/update.d.ts +76 -0
  100. package/dist/node/zkprogram-example/update.js +85 -0
  101. package/dist/node/zkprogram-example/update.js.map +1 -0
  102. package/dist/tsconfig.tsbuildinfo +1 -0
  103. package/dist/tsconfig.web.tsbuildinfo +1 -0
  104. package/dist/web/admin/advanced.d.ts +469 -0
  105. package/dist/web/admin/advanced.js +525 -0
  106. package/dist/web/admin/advanced.js.map +1 -0
  107. package/dist/web/admin/index.d.ts +1 -0
  108. package/dist/web/admin/index.js +2 -0
  109. package/dist/web/admin/index.js.map +1 -0
  110. package/dist/web/contracts/admin.d.ts +140 -0
  111. package/dist/web/contracts/admin.js +336 -0
  112. package/dist/web/contracts/admin.js.map +1 -0
  113. package/dist/web/contracts/collection.d.ts +551 -0
  114. package/dist/web/contracts/collection.js +1049 -0
  115. package/dist/web/contracts/collection.js.map +1 -0
  116. package/dist/web/contracts/index.d.ts +3 -0
  117. package/dist/web/contracts/index.js +4 -0
  118. package/dist/web/contracts/index.js.map +1 -0
  119. package/dist/web/contracts/nft.d.ts +76 -0
  120. package/dist/web/contracts/nft.js +329 -0
  121. package/dist/web/contracts/nft.js.map +1 -0
  122. package/dist/web/contracts.d.ts +709 -0
  123. package/dist/web/contracts.js +61 -0
  124. package/dist/web/contracts.js.map +1 -0
  125. package/dist/web/index.d.ts +8 -0
  126. package/dist/web/index.js +9 -0
  127. package/dist/web/index.js.map +1 -0
  128. package/dist/web/interfaces/admin.d.ts +102 -0
  129. package/dist/web/interfaces/admin.js +2 -0
  130. package/dist/web/interfaces/admin.js.map +1 -0
  131. package/dist/web/interfaces/approval.d.ts +57 -0
  132. package/dist/web/interfaces/approval.js +62 -0
  133. package/dist/web/interfaces/approval.js.map +1 -0
  134. package/dist/web/interfaces/collection.d.ts +57 -0
  135. package/dist/web/interfaces/collection.js +2 -0
  136. package/dist/web/interfaces/collection.js.map +1 -0
  137. package/dist/web/interfaces/encoding.d.ts +24 -0
  138. package/dist/web/interfaces/encoding.js +32 -0
  139. package/dist/web/interfaces/encoding.js.map +1 -0
  140. package/dist/web/interfaces/events.d.ts +833 -0
  141. package/dist/web/interfaces/events.js +106 -0
  142. package/dist/web/interfaces/events.js.map +1 -0
  143. package/dist/web/interfaces/index.d.ts +10 -0
  144. package/dist/web/interfaces/index.js +11 -0
  145. package/dist/web/interfaces/index.js.map +1 -0
  146. package/dist/web/interfaces/ownable.d.ts +94 -0
  147. package/dist/web/interfaces/ownable.js +12 -0
  148. package/dist/web/interfaces/ownable.js.map +1 -0
  149. package/dist/web/interfaces/owner.d.ts +61 -0
  150. package/dist/web/interfaces/owner.js +101 -0
  151. package/dist/web/interfaces/owner.js.map +1 -0
  152. package/dist/web/interfaces/pausable.d.ts +74 -0
  153. package/dist/web/interfaces/pausable.js +14 -0
  154. package/dist/web/interfaces/pausable.js.map +1 -0
  155. package/dist/web/interfaces/types.d.ts +2297 -0
  156. package/dist/web/interfaces/types.js +507 -0
  157. package/dist/web/interfaces/types.js.map +1 -0
  158. package/dist/web/interfaces/update.d.ts +53 -0
  159. package/dist/web/interfaces/update.js +58 -0
  160. package/dist/web/interfaces/update.js.map +1 -0
  161. package/dist/web/marketplace/auction.d.ts +775 -0
  162. package/dist/web/marketplace/auction.js +430 -0
  163. package/dist/web/marketplace/auction.js.map +1 -0
  164. package/dist/web/marketplace/bid.d.ts +254 -0
  165. package/dist/web/marketplace/bid.js +260 -0
  166. package/dist/web/marketplace/bid.js.map +1 -0
  167. package/dist/web/marketplace/index.d.ts +5 -0
  168. package/dist/web/marketplace/index.js +6 -0
  169. package/dist/web/marketplace/index.js.map +1 -0
  170. package/dist/web/marketplace/nft-shares.d.ts +1083 -0
  171. package/dist/web/marketplace/nft-shares.js +398 -0
  172. package/dist/web/marketplace/nft-shares.js.map +1 -0
  173. package/dist/web/marketplace/offer.d.ts +192 -0
  174. package/dist/web/marketplace/offer.js +132 -0
  175. package/dist/web/marketplace/offer.js.map +1 -0
  176. package/dist/web/marketplace/types.d.ts +374 -0
  177. package/dist/web/marketplace/types.js +33 -0
  178. package/dist/web/marketplace/types.js.map +1 -0
  179. package/dist/web/metadata/index.d.ts +3 -0
  180. package/dist/web/metadata/index.js +4 -0
  181. package/dist/web/metadata/index.js.map +1 -0
  182. package/dist/web/metadata/metadata.d.ts +337 -0
  183. package/dist/web/metadata/metadata.js +439 -0
  184. package/dist/web/metadata/metadata.js.map +1 -0
  185. package/dist/web/metadata/text.d.ts +44 -0
  186. package/dist/web/metadata/text.js +42 -0
  187. package/dist/web/metadata/text.js.map +1 -0
  188. package/dist/web/metadata/tree.d.ts +75 -0
  189. package/dist/web/metadata/tree.js +85 -0
  190. package/dist/web/metadata/tree.js.map +1 -0
  191. package/dist/web/vk.d.ts +42 -0
  192. package/dist/web/vk.js +45 -0
  193. package/dist/web/vk.js.map +1 -0
  194. package/dist/web/zkprogram-example/game.d.ts +76 -0
  195. package/dist/web/zkprogram-example/game.js +108 -0
  196. package/dist/web/zkprogram-example/game.js.map +1 -0
  197. package/dist/web/zkprogram-example/index.d.ts +2 -0
  198. package/dist/web/zkprogram-example/index.js +3 -0
  199. package/dist/web/zkprogram-example/index.js.map +1 -0
  200. package/dist/web/zkprogram-example/update.d.ts +76 -0
  201. package/dist/web/zkprogram-example/update.js +85 -0
  202. package/dist/web/zkprogram-example/update.js.map +1 -0
  203. package/package.json +65 -0
  204. package/src/admin/advanced.ts +601 -0
  205. package/src/admin/index.ts +1 -0
  206. package/src/contracts/admin.ts +301 -0
  207. package/src/contracts/collection.ts +1172 -0
  208. package/src/contracts/index.ts +3 -0
  209. package/src/contracts/nft.ts +344 -0
  210. package/src/contracts.ts +107 -0
  211. package/src/index.ts +8 -0
  212. package/src/interfaces/admin.ts +127 -0
  213. package/src/interfaces/approval.ts +99 -0
  214. package/src/interfaces/collection.ts +68 -0
  215. package/src/interfaces/encoding.ts +32 -0
  216. package/src/interfaces/events.ts +115 -0
  217. package/src/interfaces/index.ts +10 -0
  218. package/src/interfaces/ownable.ts +32 -0
  219. package/src/interfaces/owner.ts +143 -0
  220. package/src/interfaces/pausable.ts +41 -0
  221. package/src/interfaces/types.ts +623 -0
  222. package/src/interfaces/update.ts +104 -0
  223. package/src/marketplace/auction.ts +527 -0
  224. package/src/marketplace/bid.ts +294 -0
  225. package/src/marketplace/index.ts +5 -0
  226. package/src/marketplace/nft-shares.ts +388 -0
  227. package/src/marketplace/offer.ts +153 -0
  228. package/src/marketplace/types.ts +33 -0
  229. package/src/metadata/index.ts +3 -0
  230. package/src/metadata/metadata.ts +603 -0
  231. package/src/metadata/text.ts +60 -0
  232. package/src/metadata/tree.ts +128 -0
  233. package/src/vk.ts +64 -0
  234. package/src/zkprogram-example/game.ts +136 -0
  235. package/src/zkprogram-example/index.ts +2 -0
  236. package/src/zkprogram-example/update.ts +98 -0
@@ -0,0 +1,601 @@
1
+ /**
2
+ * The `NFTAdvancedAdminContract` is an implementation of an admin contract that uses a whitelist to control access to certain actions within the NFT ecosystem.
3
+ * This contract ensures that only whitelisted addresses can perform specific actions such as minting, updating, transferring, buying, or selling NFTs.
4
+ * It also introduces functionality for pausing and resuming the contract, upgrading the contract's verification key, and transferring ownership.
5
+ */
6
+
7
+ import {
8
+ Bool,
9
+ DeployArgs,
10
+ method,
11
+ Permissions,
12
+ PublicKey,
13
+ SmartContract,
14
+ State,
15
+ state,
16
+ VerificationKey,
17
+ UInt64,
18
+ Provable,
19
+ Field,
20
+ AccountUpdate,
21
+ Mina,
22
+ UInt32,
23
+ Struct,
24
+ } from "o1js";
25
+ import { Whitelist } from "@silvana-one/storage";
26
+ import {
27
+ MintRequest,
28
+ NFTState,
29
+ NFTAdminBase,
30
+ MintParamsOption,
31
+ PauseEvent,
32
+ PausableContract,
33
+ OwnershipChangeEvent,
34
+ OwnableContract,
35
+ TransferEvent,
36
+ } from "../interfaces/index.js";
37
+ import {
38
+ UpgradeAuthorityBase,
39
+ VerificationKeyUpgradeData,
40
+ UpgradableContract,
41
+ UpgradeAuthorityContractConstructor,
42
+ } from "@silvana-one/upgradable";
43
+
44
+ export { NFTAdvancedAdminContract, AdminData, NFTAdvancedAdminDeployProps };
45
+
46
+ /**
47
+ * Deployment properties for the `NFTAdvancedAdminContract`.
48
+ */
49
+ interface NFTAdvancedAdminDeployProps extends Exclude<DeployArgs, undefined> {
50
+ /** The public key of the admin or owner of the contract. */
51
+ admin: PublicKey;
52
+ /** The public key of the Upgrade Authority Contract. */
53
+ upgradeAuthority: PublicKey;
54
+ /** The whitelist. */
55
+ whitelist: Whitelist;
56
+
57
+ /** The URI of the zkApp. */
58
+ uri: string;
59
+ /** The admin data. */
60
+ adminData: AdminData;
61
+ }
62
+
63
+ /**
64
+ * Represents pause-related data, containing flags for pause functionality.
65
+ */
66
+ class AdminData extends Struct({
67
+ /** Indicates whether the contract can be paused. */
68
+ canPause: Bool,
69
+ /** Indicates whether the contract is currently paused. */
70
+ isPaused: Bool,
71
+ /** Indicates whether the contract can change the royalty fee. */
72
+ allowChangeRoyalty: Bool,
73
+ /** Indicates whether the contract can change the transfer fee. */
74
+ allowChangeTransferFee: Bool,
75
+ /** Indicates whether the contract can change the base URI. */
76
+ allowChangeBaseUri: Bool,
77
+ /** Indicates whether the contract can change the creator. */
78
+ allowChangeCreator: Bool,
79
+ /** Indicates whether the contract can change the admin. */
80
+ allowChangeAdmin: Bool,
81
+ /** Indicates whether the contract can change the name. */
82
+ allowChangeName: Bool,
83
+ }) {
84
+ static new(
85
+ params: {
86
+ canPause?: boolean;
87
+ isPaused?: boolean;
88
+ allowChangeRoyalty?: boolean;
89
+ allowChangeTransferFee?: boolean;
90
+ allowChangeBaseUri?: boolean;
91
+ allowChangeCreator?: boolean;
92
+ allowChangeAdmin?: boolean;
93
+ allowChangeName?: boolean;
94
+ } = {}
95
+ ) {
96
+ const {
97
+ canPause,
98
+ isPaused,
99
+ allowChangeRoyalty,
100
+ allowChangeTransferFee,
101
+ allowChangeBaseUri,
102
+ allowChangeCreator,
103
+ allowChangeAdmin,
104
+ allowChangeName,
105
+ } = params;
106
+ return new AdminData({
107
+ canPause: Bool(canPause ?? true),
108
+ isPaused: Bool(isPaused ?? false),
109
+ allowChangeRoyalty: Bool(allowChangeRoyalty ?? false),
110
+ allowChangeTransferFee: Bool(allowChangeTransferFee ?? false),
111
+ allowChangeBaseUri: Bool(allowChangeBaseUri ?? false),
112
+ allowChangeCreator: Bool(allowChangeCreator ?? false),
113
+ allowChangeAdmin: Bool(allowChangeAdmin ?? false),
114
+ allowChangeName: Bool(allowChangeName ?? false),
115
+ });
116
+ }
117
+ /**
118
+ * Packs the pause data into a `Field`.
119
+ * @returns A `Field` representing the packed pause data.
120
+ */
121
+ pack(): Field {
122
+ return Field.fromBits([
123
+ this.isPaused,
124
+ this.canPause,
125
+ this.allowChangeRoyalty,
126
+ this.allowChangeTransferFee,
127
+ this.allowChangeBaseUri,
128
+ this.allowChangeCreator,
129
+ this.allowChangeAdmin,
130
+ this.allowChangeName,
131
+ ]);
132
+ }
133
+ /**
134
+ * Unpacks a `Field` into `PauseData`.
135
+ * @param field The `Field` to unpack.
136
+ * @returns An instance of `PauseData`.
137
+ */
138
+ static unpack(field: Field): AdminData {
139
+ const [
140
+ isPaused,
141
+ canPause,
142
+ allowChangeRoyalty,
143
+ allowChangeTransferFee,
144
+ allowChangeBaseUri,
145
+ allowChangeCreator,
146
+ allowChangeAdmin,
147
+ allowChangeName,
148
+ ] = field.toBits(8);
149
+ return new AdminData({
150
+ canPause,
151
+ isPaused,
152
+ allowChangeRoyalty,
153
+ allowChangeTransferFee,
154
+ allowChangeBaseUri,
155
+ allowChangeCreator,
156
+ allowChangeAdmin,
157
+ allowChangeName,
158
+ });
159
+ }
160
+ static isPaused(field: Field): Bool {
161
+ return field.toBits(8)[0];
162
+ }
163
+ }
164
+
165
+ const NFTAdvancedAdminContractErrors = {
166
+ contractIsPaused: "Contract is paused",
167
+ notWhitelisted: "Address not whitelisted",
168
+ senderNotWhitelisted: "Sender address not whitelisted",
169
+ cannotMint: "Cannot mint",
170
+ verificationKeyHashNotFound: "Verification key hash not found",
171
+ cannotUpgradeVerificationKey: "Cannot upgrade verification key",
172
+ };
173
+
174
+ /**
175
+ * Constructs the `NFTAdvancedAdmin` class, an admin contract that uses a whitelist to control access.
176
+ * @param params Object containing the upgrade contract constructor.
177
+ * @returns The `NFTAdvancedAdmin` class.
178
+ */
179
+ function NFTAdvancedAdminContract(params: {
180
+ upgradeContract: UpgradeAuthorityContractConstructor;
181
+ }) {
182
+ const { upgradeContract } = params;
183
+
184
+ /**
185
+ * The `NFTWhitelistedAdmin` class ensures that only whitelisted addresses can perform specific actions such as minting, updating, transferring, buying, or selling NFTs.
186
+ * It also provides functionality for pausing and resuming the contract, upgrading the contract's verification key, and transferring ownership.
187
+ */
188
+ class NFTAdvancedAdmin
189
+ extends SmartContract
190
+ implements
191
+ NFTAdminBase,
192
+ UpgradableContract,
193
+ PausableContract,
194
+ OwnableContract
195
+ {
196
+ /** The public key of the admin or owner of the contract. */
197
+ @state(PublicKey) admin = State<PublicKey>();
198
+ /** The public key of the Upgrade Authority Contract. */
199
+ @state(PublicKey) upgradeAuthority = State<PublicKey>();
200
+ /** The root hash of the Merkle tree representing the whitelist. */
201
+ @state(Whitelist) whitelist = State<Whitelist>();
202
+ /** Packed field containing pause-related flags. */
203
+ @state(Field) data = State<Field>();
204
+
205
+ /**
206
+ * Deploys the `NFTWhitelistedAdmin` contract with the provided initial settings.
207
+ * @param props Deployment properties.
208
+ */
209
+ async deploy(props: NFTAdvancedAdminDeployProps) {
210
+ await super.deploy(props);
211
+ this.admin.set(props.admin);
212
+ this.upgradeAuthority.set(props.upgradeAuthority);
213
+ this.whitelist.set(props.whitelist);
214
+ this.data.set(props.adminData.pack());
215
+ this.account.zkappUri.set(props.uri);
216
+ this.account.permissions.set({
217
+ ...Permissions.default(),
218
+ // Allow the upgrade authority to set the verification key
219
+ // even when there is no protocol upgrade
220
+ setVerificationKey:
221
+ Permissions.VerificationKey.proofDuringCurrentVersion(),
222
+ setPermissions: Permissions.impossible(),
223
+ access: Permissions.proof(),
224
+ send: Permissions.proof(),
225
+ setZkappUri: Permissions.impossible(),
226
+ setTokenSymbol: Permissions.impossible(),
227
+ });
228
+ }
229
+
230
+ events = {
231
+ /** Emitted when the contract's verification key is upgraded. */
232
+ upgradeVerificationKey: Field,
233
+ /** Emitted when the contract is paused. */
234
+ pause: PauseEvent,
235
+ /** Emitted when the contract is resumed. */
236
+ resume: PauseEvent,
237
+ /** Emitted when ownership of the contract changes. */
238
+ ownershipChange: OwnershipChangeEvent,
239
+ /** Emitted when the whitelist is updated. */
240
+ updateWhitelist: Whitelist,
241
+ };
242
+
243
+ /**
244
+ * Ensures that the transaction is authorized by the contract owner.
245
+ * @returns An `AccountUpdate` representing the admin's signed transaction.
246
+ */
247
+ async ensureOwnerSignature(): Promise<AccountUpdate> {
248
+ const admin = this.admin.getAndRequireEquals();
249
+ const adminUpdate = AccountUpdate.createSigned(admin);
250
+ adminUpdate.body.useFullCommitment = Bool(true); // prevent memo and fee change
251
+ return adminUpdate;
252
+ }
253
+
254
+ /** Gets the upgrade contract constructor. */
255
+ get getUpgradeContractConstructor() {
256
+ return upgradeContract;
257
+ }
258
+
259
+ /**
260
+ * Retrieves the `UpgradeAuthorityBase` contract instance.
261
+ * @returns An instance of the upgrade authority contract.
262
+ */
263
+ async getUpgradeContract(): Promise<UpgradeAuthorityBase> {
264
+ return new this.getUpgradeContractConstructor(
265
+ this.upgradeAuthority.getAndRequireEquals()
266
+ );
267
+ }
268
+
269
+ /**
270
+ * Upgrades the contract's verification key using the Upgrade Authority Contract.
271
+ * @param vk The new verification key.
272
+ */
273
+ @method
274
+ async upgradeVerificationKey(vk: VerificationKey) {
275
+ await this.ensureOwnerSignature();
276
+ const upgradeContract = await this.getUpgradeContract();
277
+ // fetchAccount() should be called before calling this method
278
+ // this code should be changed after verification key precondition
279
+ // will be added to the Mina protocol
280
+ const previousVerificationKeyHash = Provable.witness(Field, () => {
281
+ const account = Mina.getAccount(this.address);
282
+ const vkHash = account.zkapp?.verificationKey?.hash;
283
+ if (!vkHash) {
284
+ throw Error(
285
+ NFTAdvancedAdminContractErrors.verificationKeyHashNotFound
286
+ );
287
+ }
288
+ return vkHash;
289
+ });
290
+ const data = new VerificationKeyUpgradeData({
291
+ address: this.address,
292
+ tokenId: this.tokenId,
293
+ previousVerificationKeyHash,
294
+ newVerificationKeyHash: vk.hash,
295
+ });
296
+ const upgradeAuthorityAnswer = await upgradeContract.verifyUpgradeData(
297
+ data
298
+ );
299
+ upgradeAuthorityAnswer.isVerified.assertTrue(
300
+ NFTAdvancedAdminContractErrors.cannotUpgradeVerificationKey
301
+ );
302
+ this.account.verificationKey.set(vk);
303
+ this.upgradeAuthority.set(
304
+ upgradeAuthorityAnswer.nextUpgradeAuthority.orElse(
305
+ this.upgradeAuthority.getAndRequireEquals()
306
+ )
307
+ );
308
+ this.emitEvent("upgradeVerificationKey", vk.hash);
309
+ }
310
+
311
+ /**
312
+ * Determines if the minting request can proceed by checking if the owner and sender are whitelisted.
313
+ * @param mintRequest The minting request parameters.
314
+ * @returns A `MintParamsOption` indicating if minting is allowed.
315
+ */
316
+ @method.returns(MintParamsOption)
317
+ async canMint(mintRequest: MintRequest): Promise<MintParamsOption> {
318
+ AdminData.isPaused(this.data.getAndRequireEquals()).assertFalse(
319
+ NFTAdvancedAdminContractErrors.contractIsPaused
320
+ );
321
+
322
+ const whitelist = this.whitelist.getAndRequireEquals();
323
+ const ownerAmount = await whitelist.getWhitelistedAmount(
324
+ mintRequest.owner
325
+ );
326
+ ownerAmount.isSome.assertTrue(
327
+ NFTAdvancedAdminContractErrors.notWhitelisted
328
+ );
329
+
330
+ const sender = this.sender.getUnconstrained();
331
+ const senderUpdate = AccountUpdate.createSigned(sender);
332
+ senderUpdate.body.useFullCommitment = Bool(true); // prevent memo and fee change
333
+ const senderAmount = await whitelist.getWhitelistedAmount(sender);
334
+ senderAmount.isSome.assertTrue(
335
+ NFTAdvancedAdminContractErrors.senderNotWhitelisted
336
+ );
337
+ const mintParams = await Provable.witnessAsync(
338
+ MintParamsOption,
339
+ async () => {
340
+ // only creator can mint
341
+ // can be changed in the future to support CMS
342
+ return MintParamsOption.none();
343
+ }
344
+ );
345
+ return mintParams;
346
+ }
347
+
348
+ /**
349
+ * Checks whether the NFT's state can be updated, ensuring the new owner is whitelisted.
350
+ * @param input The current state of the NFT.
351
+ * @param output The desired new state of the NFT.
352
+ * @returns A `Bool` indicating whether the update is permitted.
353
+ */
354
+ @method.returns(Bool)
355
+ async canUpdate(input: NFTState, output: NFTState) {
356
+ AdminData.isPaused(this.data.getAndRequireEquals()).assertFalse(
357
+ NFTAdvancedAdminContractErrors.contractIsPaused
358
+ );
359
+ const whitelist = this.whitelist.getAndRequireEquals();
360
+ return (await whitelist.getWhitelistedAmount(output.owner)).isSome.and(
361
+ (await whitelist.getWhitelistedAmount(input.owner)).isSome
362
+ );
363
+ }
364
+
365
+ /**
366
+ * Verifies if the transfer between `from` and `to` addresses is allowed based on whitelist status.
367
+ * @param address The address of the NFT.
368
+ * @param from The sender's public key.
369
+ * @param to The receiver's public key.
370
+ * @returns A `Bool` indicating whether the transfer is permitted.
371
+ */
372
+ @method.returns(Bool)
373
+ async canTransfer(transferEvent: TransferEvent) {
374
+ AdminData.isPaused(this.data.getAndRequireEquals()).assertFalse(
375
+ NFTAdvancedAdminContractErrors.contractIsPaused
376
+ );
377
+ const { to, from, price } = transferEvent;
378
+
379
+ const whitelist = this.whitelist.getAndRequireEquals();
380
+ const toAmount = await whitelist.getWhitelistedAmount(to);
381
+ const fromAmount = await whitelist.getWhitelistedAmount(from);
382
+
383
+ const toAmountAllowed = toAmount
384
+ .orElse(UInt64.from(0))
385
+ .greaterThanOrEqual(price.orElse(UInt64.zero));
386
+
387
+ const fromAmountAllowed = fromAmount
388
+ .orElse(UInt64.from(0))
389
+ .greaterThanOrEqual(price.orElse(UInt64.zero));
390
+
391
+ return toAmountAllowed
392
+ .and(fromAmountAllowed)
393
+ .and(toAmount.isSome)
394
+ .and(fromAmount.isSome);
395
+ }
396
+
397
+ /**
398
+ * Updates the whitelist's Merkle root and the associated off-chain storage reference.
399
+ * @param whitelistRoot The new whitelist root.
400
+ * @param storage The storage reference for the whitelist data.
401
+ */
402
+ @method
403
+ async updateWhitelist(whitelist: Whitelist) {
404
+ AdminData.isPaused(this.data.getAndRequireEquals()).assertFalse(
405
+ NFTAdvancedAdminContractErrors.contractIsPaused
406
+ );
407
+ await this.ensureOwnerSignature();
408
+ this.whitelist.set(whitelist);
409
+ this.emitEvent("updateWhitelist", whitelist);
410
+ }
411
+
412
+ /**
413
+ * Pauses the contract, preventing certain administrative actions from being performed.
414
+ */
415
+ @method
416
+ async pause(): Promise<void> {
417
+ await this.ensureOwnerSignature();
418
+ const adminData = AdminData.unpack(this.data.getAndRequireEquals());
419
+ adminData.canPause.assertTrue();
420
+ adminData.isPaused = Bool(true);
421
+ this.data.set(adminData.pack());
422
+ this.emitEvent("pause", new PauseEvent({ isPaused: Bool(true) }));
423
+ }
424
+
425
+ /**
426
+ * Resumes the contract, allowing administrative actions to be performed again.
427
+ */
428
+ @method
429
+ async resume(): Promise<void> {
430
+ await this.ensureOwnerSignature();
431
+ const adminData = AdminData.unpack(this.data.getAndRequireEquals());
432
+ adminData.canPause.assertTrue();
433
+ adminData.isPaused = Bool(false);
434
+ this.data.set(adminData.pack());
435
+ this.emitEvent("resume", new PauseEvent({ isPaused: Bool(false) }));
436
+ }
437
+
438
+ /**
439
+ * Transfers ownership of the contract to a new admin.
440
+ * @param newOwner The public key of the new admin.
441
+ * @returns The public key of the old owner.
442
+ */
443
+ @method.returns(PublicKey)
444
+ async transferOwnership(to: PublicKey): Promise<PublicKey> {
445
+ AdminData.isPaused(this.data.getAndRequireEquals()).assertFalse(
446
+ NFTAdvancedAdminContractErrors.contractIsPaused
447
+ );
448
+ await this.ensureOwnerSignature();
449
+ const from = this.admin.getAndRequireEquals();
450
+ this.admin.set(to);
451
+ this.emitEvent(
452
+ "ownershipChange",
453
+ new OwnershipChangeEvent({
454
+ from,
455
+ to,
456
+ })
457
+ );
458
+ return from;
459
+ }
460
+
461
+ @method.returns(Bool)
462
+ async canChangeVerificationKey(
463
+ vk: VerificationKey,
464
+ address: PublicKey,
465
+ tokenId: Field
466
+ ): Promise<Bool> {
467
+ AdminData.isPaused(this.data.getAndRequireEquals()).assertFalse(
468
+ NFTAdvancedAdminContractErrors.contractIsPaused
469
+ );
470
+ const upgradeContract = await this.getUpgradeContract();
471
+
472
+ // fetchAccount() should be called before calling this method
473
+ // TODO: this code should be changed after verification key precondition
474
+ // will be added to the Mina protocol
475
+ const previousVerificationKeyHash = Provable.witness(Field, () => {
476
+ const account = Mina.getAccount(address, tokenId);
477
+ const vkHash = account.zkapp?.verificationKey?.hash;
478
+ if (!vkHash) {
479
+ throw Error("Verification key hash not found");
480
+ }
481
+ return vkHash;
482
+ });
483
+ const data = new VerificationKeyUpgradeData({
484
+ address: address,
485
+ tokenId: tokenId,
486
+ previousVerificationKeyHash,
487
+ newVerificationKeyHash: vk.hash,
488
+ });
489
+ const upgradeAuthorityAnswer = await upgradeContract.verifyUpgradeData(
490
+ data
491
+ );
492
+
493
+ return upgradeAuthorityAnswer.isVerified;
494
+ }
495
+ /**
496
+ * Determines if the name can be changed for a Collection.
497
+ */
498
+ @method.returns(Bool)
499
+ async canChangeName(name: Field): Promise<Bool> {
500
+ await this.ensureOwnerSignature();
501
+ const adminData = AdminData.unpack(this.data.getAndRequireEquals());
502
+ adminData.isPaused.assertFalse(
503
+ NFTAdvancedAdminContractErrors.contractIsPaused
504
+ );
505
+ return adminData.allowChangeName;
506
+ }
507
+
508
+ /**
509
+ * Determines if the creator can be changed for a Collection.
510
+ */
511
+ @method.returns(Bool)
512
+ async canChangeCreator(creator: PublicKey): Promise<Bool> {
513
+ await this.ensureOwnerSignature();
514
+ const adminData = AdminData.unpack(this.data.getAndRequireEquals());
515
+ adminData.isPaused.assertFalse(
516
+ NFTAdvancedAdminContractErrors.contractIsPaused
517
+ );
518
+ return adminData.allowChangeCreator;
519
+ }
520
+
521
+ /**
522
+ * Determines if the base URI can be changed for a Collection.
523
+ */
524
+ @method.returns(Bool)
525
+ async canChangeBaseUri(baseUri: Field): Promise<Bool> {
526
+ await this.ensureOwnerSignature();
527
+ const adminData = AdminData.unpack(this.data.getAndRequireEquals());
528
+ adminData.isPaused.assertFalse(
529
+ NFTAdvancedAdminContractErrors.contractIsPaused
530
+ );
531
+ return adminData.allowChangeBaseUri;
532
+ }
533
+
534
+ /**
535
+ * Determines if the royalty fee can be changed for a Collection.
536
+ */
537
+ @method.returns(Bool)
538
+ async canChangeRoyalty(royaltyFee: UInt32): Promise<Bool> {
539
+ await this.ensureOwnerSignature();
540
+ const adminData = AdminData.unpack(this.data.getAndRequireEquals());
541
+ adminData.isPaused.assertFalse(
542
+ NFTAdvancedAdminContractErrors.contractIsPaused
543
+ );
544
+ return adminData.allowChangeRoyalty;
545
+ }
546
+
547
+ /**
548
+ * Determines if the transfer fee can be changed for a Collection.
549
+ */
550
+ @method.returns(Bool)
551
+ async canChangeTransferFee(transferFee: UInt64): Promise<Bool> {
552
+ await this.ensureOwnerSignature();
553
+ const adminData = AdminData.unpack(this.data.getAndRequireEquals());
554
+ adminData.isPaused.assertFalse(
555
+ NFTAdvancedAdminContractErrors.contractIsPaused
556
+ );
557
+ return adminData.allowChangeTransferFee;
558
+ }
559
+
560
+ /**
561
+ * Determines if the admin contract can be changed for a Collection.
562
+ */
563
+ @method.returns(Bool)
564
+ async canSetAdmin(admin: PublicKey): Promise<Bool> {
565
+ await this.ensureOwnerSignature();
566
+ const adminData = AdminData.unpack(this.data.getAndRequireEquals());
567
+ adminData.isPaused.assertFalse(
568
+ NFTAdvancedAdminContractErrors.contractIsPaused
569
+ );
570
+ return adminData.allowChangeAdmin;
571
+ }
572
+
573
+ /**
574
+ * Determines if the collection can be paused.
575
+ */
576
+ @method.returns(Bool)
577
+ async canPause(): Promise<Bool> {
578
+ await this.ensureOwnerSignature();
579
+ const adminData = AdminData.unpack(this.data.getAndRequireEquals());
580
+ adminData.isPaused.assertFalse(
581
+ NFTAdvancedAdminContractErrors.contractIsPaused
582
+ );
583
+ return adminData.canPause;
584
+ }
585
+
586
+ /**
587
+ * Determines if the collection can be resumed.
588
+ */
589
+ @method.returns(Bool)
590
+ async canResume(): Promise<Bool> {
591
+ await this.ensureOwnerSignature();
592
+ const adminData = AdminData.unpack(this.data.getAndRequireEquals());
593
+ adminData.isPaused.assertFalse(
594
+ NFTAdvancedAdminContractErrors.contractIsPaused
595
+ );
596
+ return adminData.canPause;
597
+ }
598
+ }
599
+
600
+ return NFTAdvancedAdmin;
601
+ }
@@ -0,0 +1 @@
1
+ export * from "./advanced.js";