@alejoamiras/aztec-fee-payment 0.0.0-canary.gb8d1485

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 (39) hide show
  1. package/LICENSE +21 -0
  2. package/README.md +152 -0
  3. package/dist/src/artifacts/Counter.d.ts +60 -0
  4. package/dist/src/artifacts/Counter.d.ts.map +1 -0
  5. package/dist/src/artifacts/Counter.js +66 -0
  6. package/dist/src/artifacts/PrivateFPC.d.ts +64 -0
  7. package/dist/src/artifacts/PrivateFPC.d.ts.map +1 -0
  8. package/dist/src/artifacts/PrivateFPC.js +66 -0
  9. package/dist/src/ts/artifactRegistry.d.ts +46 -0
  10. package/dist/src/ts/artifactRegistry.d.ts.map +1 -0
  11. package/dist/src/ts/artifactRegistry.js +122 -0
  12. package/dist/src/ts/fee-payment-methods/index.d.ts +3 -0
  13. package/dist/src/ts/fee-payment-methods/index.d.ts.map +1 -0
  14. package/dist/src/ts/fee-payment-methods/index.js +3 -0
  15. package/dist/src/ts/fee-payment-methods/private.d.ts +34 -0
  16. package/dist/src/ts/fee-payment-methods/private.d.ts.map +1 -0
  17. package/dist/src/ts/fee-payment-methods/private.js +64 -0
  18. package/dist/src/ts/fee-payment-methods/shared.d.ts +18 -0
  19. package/dist/src/ts/fee-payment-methods/shared.d.ts.map +1 -0
  20. package/dist/src/ts/fee-payment-methods/shared.js +36 -0
  21. package/dist/src/ts/index.d.ts +28 -0
  22. package/dist/src/ts/index.d.ts.map +1 -0
  23. package/dist/src/ts/index.js +34 -0
  24. package/dist/src/ts/utils/deploy.d.ts +22 -0
  25. package/dist/src/ts/utils/deploy.d.ts.map +1 -0
  26. package/dist/src/ts/utils/deploy.js +25 -0
  27. package/dist/src/ts/utils/gas.d.ts +105 -0
  28. package/dist/src/ts/utils/gas.d.ts.map +1 -0
  29. package/dist/src/ts/utils/gas.js +130 -0
  30. package/dist/src/ts/utils/index.d.ts +4 -0
  31. package/dist/src/ts/utils/index.d.ts.map +1 -0
  32. package/dist/src/ts/utils/index.js +5 -0
  33. package/dist/target/counter_contract-Counter.json +7180 -0
  34. package/dist/target/private_contract-PrivateFPC.json +14590 -0
  35. package/package.json +86 -0
  36. package/target/counter_contract-Counter.json +7180 -0
  37. package/target/counter_contract-Counter.json.bak +1 -0
  38. package/target/private_contract-PrivateFPC.json +14590 -0
  39. package/target/private_contract-PrivateFPC.json.bak +1 -0
package/LICENSE ADDED
@@ -0,0 +1,21 @@
1
+ MIT License
2
+
3
+ Copyright (c) 2025 Wonderland
4
+
5
+ Permission is hereby granted, free of charge, to any person obtaining a copy
6
+ of this software and associated documentation files (the "Software"), to deal
7
+ in the Software without restriction, including without limitation the rights
8
+ to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
9
+ copies of the Software, and to permit persons to whom the Software is
10
+ furnished to do so, subject to the following conditions:
11
+
12
+ The above copyright notice and this permission notice shall be included in all
13
+ copies or substantial portions of the Software.
14
+
15
+ THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
16
+ IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
17
+ FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
18
+ AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
19
+ LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
20
+ OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
21
+ SOFTWARE.
package/README.md ADDED
@@ -0,0 +1,152 @@
1
+ # Aztec Fee Payment Contracts
2
+
3
+ A Fee Payment Contract (FPC) for Aztec that enables private transaction fee sponsorship via FeeJuice.
4
+
5
+ ## Overview
6
+
7
+ | Contract | Description | Auth model |
8
+ |----------|-------------|-----------|
9
+ | **PrivateFPC** | Fully private. Users bridge FeeJuice from L1; the bridge claim converts to internal FJ balance for fee sponsorship. | Cryptographic bridge proof (no owner, no agent) |
10
+
11
+ ## Project Structure
12
+
13
+ ```
14
+ ├── src/
15
+ │ ├── artifacts/ # Generated contract bindings
16
+ │ ├── nr/ # Noir smart contracts
17
+ │ │ ├── counter_contract/ # Test utility contract
18
+ │ │ └── private_contract/ # PrivateFPC
19
+ │ └── ts/ # TypeScript package
20
+ │ ├── fee-payment-methods/ # Fee payment method classes
21
+ │ ├── utils/ # Utilities (gas, deploy)
22
+ │ └── test/ # Integration tests
23
+ ├── target/ # Compiled contract artifacts
24
+ ├── benchmarks/ # Performance benchmarks
25
+ └── docs/ # Product requirements
26
+ ```
27
+
28
+ ## Setup
29
+
30
+ ### Prerequisites
31
+
32
+ - [Aztec CLI](https://docs.aztec.network/getting_started) — version pinned by the repo root `package.json` `config.aztecVersion`
33
+ - Node.js 22+
34
+ - Yarn 1.22+
35
+
36
+ ### Installation
37
+
38
+ ```bash
39
+ yarn install
40
+ ```
41
+
42
+ ### Compile Contracts
43
+
44
+ ```bash
45
+ # Full rebuild: compile Noir + generate TS bindings
46
+ yarn ccc
47
+
48
+ # Or step by step
49
+ aztec compile
50
+ aztec codegen target --outdir src/artifacts
51
+ ```
52
+
53
+ ## Testing
54
+
55
+ Start the Aztec sandbox:
56
+
57
+ ```bash
58
+ aztec start --local-network
59
+ ```
60
+
61
+ Run all tests:
62
+
63
+ ```bash
64
+ yarn test # Noir unit tests + JS integration tests
65
+ yarn test:nr # Noir unit tests only
66
+ yarn test:js # JS integration tests only
67
+ ```
68
+
69
+ ## Deployment
70
+
71
+ PrivateFPC is a **fully private** contract — it has no public functions and no constructor. This means **no on-chain deployment transaction is required**. The contract address is computed deterministically from its class hash and a salt, and users interact with it privately by address.
72
+
73
+ ### Compute the address
74
+
75
+ 1. Copy `.env.example` to `.env` and set `PRIVATE_FPC_SALT`:
76
+ ```bash
77
+ cp .env.example .env
78
+ ```
79
+
80
+ 2. Compile the contracts (required on first run):
81
+ ```bash
82
+ yarn ccc
83
+ ```
84
+
85
+ 3. Run the compute script:
86
+ ```bash
87
+ yarn compute
88
+ ```
89
+
90
+ > **DANGER:** The address is derived from compiled bytecode. A different Aztec version produces different bytecode and a **different address**. Sending funds to the wrong address means **unrecoverable loss**. Before using this address, verify the target network runs the same Aztec version as the one shown in the script output:
91
+ > ```bash
92
+ > curl -s -X POST <NODE_URL> -H 'Content-Type: application/json' \
93
+ > -d '{"jsonrpc":"2.0","method":"node_getNodeInfo","id":1,"params":[]}' \
94
+ > | jq .result.nodeVersion
95
+ > ```
96
+
97
+ ## Usage
98
+
99
+ ```bash
100
+ bun add @alejoamiras/aztec-fee-payment
101
+ ```
102
+
103
+ See [src/ts/README.md](src/ts/README.md) for detailed SDK documentation.
104
+
105
+ ```typescript
106
+ import {
107
+ PrivateFPCContract,
108
+ FPCFeePaymentMethod,
109
+ PrivateMintAndPayFeePaymentMethod,
110
+ registerPrivateContract,
111
+ } from '@alejoamiras/aztec-fee-payment';
112
+
113
+ // Register the PrivateFPC — no deployment transaction needed (fully private contract)
114
+ const fpc = await registerPrivateContract(wallet, salt);
115
+
116
+ // --- L1: deposit to FeeJuicePortal with a claimer-bound secretHash ---
117
+ // secretHash = computeSecretHash(poseidon2([salt, claimerAddress], DOM_SEP))
118
+ // FeeJuicePortal.depositToAztecPublic(_to=fpc.address, _amount, secretHash)
119
+
120
+ // --- L2: two-step flow ---
121
+ // Step 1: claim FeeJuice on L2 (emits FeeJuice nullifier)
122
+ await feeJuice.methods.claim(fpc.address, amount, secret, leafIndex).send();
123
+
124
+ // Step 2: mint internal FJ balance by proving the bridge claim
125
+ await fpc.methods.mint(amount, salt, leafIndex).send();
126
+
127
+ // User sponsors a transaction from their internal balance
128
+ await myContract.methods.doSomething()
129
+ .send({ fee: { paymentMethod: new FPCFeePaymentMethod(fpc.address) } });
130
+
131
+ // --- Cold-start: claim + mint + pay fee in one transaction ---
132
+ await myContract.methods.doSomething()
133
+ .send({
134
+ fee: {
135
+ paymentMethod: new PrivateMintAndPayFeePaymentMethod(
136
+ fpc.address, amount, secret, salt, leafIndex,
137
+ ),
138
+ },
139
+ });
140
+ ```
141
+
142
+ ## Benchmarks
143
+
144
+ ```bash
145
+ yarn benchmark
146
+ ```
147
+
148
+ Benchmarks are defined in `Nargo.toml` under `[benchmark]` and run against a live local network. Each contract has its own benchmark file in `benchmarks/`.
149
+
150
+ ## License
151
+
152
+ MIT
@@ -0,0 +1,60 @@
1
+ import { AztecAddress } from '@aztec/aztec.js/addresses';
2
+ import { type AztecAddressLike, type ContractArtifact, type FieldLike, type OptionLike } from '@aztec/aztec.js/abi';
3
+ import { ContractBase, ContractFunctionInteraction, type ContractMethod, type ContractStorageLayout, type DeployInstantiationOptions, DeployMethod } from '@aztec/aztec.js/contracts';
4
+ import type { Wallet } from '@aztec/aztec.js/wallet';
5
+ export declare const CounterContractArtifact: ContractArtifact;
6
+ /**
7
+ * Type-safe interface for contract Counter;
8
+ */
9
+ export declare class CounterContract extends ContractBase {
10
+ private constructor();
11
+ /**
12
+ * Creates a contract instance.
13
+ * @param address - The deployed contract's address.
14
+ * @param wallet - The wallet to use when interacting with the contract.
15
+ * @returns A new Contract instance.
16
+ */
17
+ static at(address: AztecAddress, wallet: Wallet): CounterContract;
18
+ /**
19
+ * Creates a tx to deploy a new instance of this contract.
20
+ * @param instantiation - Optional address-affecting parameters (salt, deployer / universalDeploy, publicKeys).
21
+ * Salt defaults to a random value; the deployer is locked lazily from the first send-time `from`.
22
+ */
23
+ static deploy(wallet: Wallet, instantiation?: DeployInstantiationOptions): DeployMethod<CounterContract>;
24
+ /**
25
+ * Creates a tx to deploy a new instance of this contract using the specified constructor method.
26
+ */
27
+ static deployWithOpts<M extends keyof CounterContract['methods']>(opts: {
28
+ method?: M;
29
+ wallet: Wallet;
30
+ instantiation?: DeployInstantiationOptions;
31
+ }, ...args: Parameters<CounterContract['methods'][M]>): DeployMethod<CounterContract>;
32
+ /**
33
+ * Returns this contract's artifact.
34
+ */
35
+ static get artifact(): ContractArtifact;
36
+ /**
37
+ * Returns this contract's artifact with public bytecode.
38
+ */
39
+ static get artifactForPublic(): ContractArtifact;
40
+ static get storage(): ContractStorageLayout<'counter'>;
41
+ /** Type-safe wrappers for the public methods exposed by the contract. */
42
+ methods: {
43
+ /** get_counter() */
44
+ get_counter: (() => ContractFunctionInteraction) & Pick<ContractMethod, 'selector'>;
45
+ /** increment() */
46
+ increment: (() => ContractFunctionInteraction) & Pick<ContractMethod, 'selector'>;
47
+ /** offchain_receive(messages: struct) */
48
+ offchain_receive: ((messages: {
49
+ ciphertext: FieldLike[];
50
+ recipient: AztecAddressLike;
51
+ tx_hash: OptionLike<FieldLike>;
52
+ anchor_block_timestamp: (bigint | number);
53
+ }[]) => ContractFunctionInteraction) & Pick<ContractMethod, 'selector'>;
54
+ /** public_dispatch(selector: field) */
55
+ public_dispatch: ((selector: FieldLike) => ContractFunctionInteraction) & Pick<ContractMethod, 'selector'>;
56
+ /** sync_state(scope: struct) */
57
+ sync_state: ((scope: AztecAddressLike) => ContractFunctionInteraction) & Pick<ContractMethod, 'selector'>;
58
+ };
59
+ }
60
+ //# sourceMappingURL=Counter.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"Counter.d.ts","sourceRoot":"","sources":["../../../src/artifacts/Counter.ts"],"names":[],"mappings":"AAIA,OAAO,EAAE,YAAY,EAAmB,MAAM,2BAA2B,CAAC;AAC1E,OAAO,EAAgB,KAAK,gBAAgB,EAAE,KAAK,gBAAgB,EAAqD,KAAK,SAAS,EAA6G,KAAK,UAAU,EAAwC,MAAM,qBAAqB,CAAC;AACtU,OAAO,EAAY,YAAY,EAAE,2BAA2B,EAAE,KAAK,cAAc,EAAE,KAAK,qBAAqB,EAAE,KAAK,0BAA0B,EAAE,YAAY,EAAE,MAAM,2BAA2B,CAAC;AAIhM,OAAO,KAAK,EAAE,MAAM,EAAE,MAAM,wBAAwB,CAAC;AAErD,eAAO,MAAM,uBAAuB,kBAA4E,CAAC;AAIjH;;GAEG;AACH,qBAAa,eAAgB,SAAQ,YAAY;IAE/C,OAAO;IASP;;;;;OAKG;WACW,EAAE,CACd,OAAO,EAAE,YAAY,EACrB,MAAM,EAAE,MAAM,GACb,eAAe;IAKlB;;;;OAIG;WACW,MAAM,CAAC,MAAM,EAAE,MAAM,EAAE,aAAa,CAAC,EAAE,0BAA0B;IAY/E;;OAEG;WACW,cAAc,CAAC,CAAC,SAAS,MAAM,eAAe,CAAC,SAAS,CAAC,EACrE,IAAI,EAAE;QAAE,MAAM,CAAC,EAAE,CAAC,CAAC;QAAC,MAAM,EAAE,MAAM,CAAC;QAAC,aAAa,CAAC,EAAE,0BAA0B,CAAA;KAAE,EAChF,GAAG,IAAI,EAAE,UAAU,CAAC,eAAe,CAAC,SAAS,CAAC,CAAC,CAAC,CAAC,CAAC;IAgBpD;;OAEG;IACH,WAAkB,QAAQ,IAAI,gBAAgB,CAE7C;IAED;;OAEG;IACH,WAAkB,iBAAiB,IAAI,gBAAgB,CAEtD;IAGD,WAAkB,OAAO,IAAI,qBAAqB,CAAC,SAAS,CAAC,CAM1D;IAGH,yEAAyE;IAC1D,OAAO,EAAE;QAEtB,oBAAoB;QACpB,WAAW,EAAE,CAAC,MAAM,2BAA2B,CAAC,GAAG,IAAI,CAAC,cAAc,EAAE,UAAU,CAAC,CAAC;QAEpF,kBAAkB;QAClB,SAAS,EAAE,CAAC,MAAM,2BAA2B,CAAC,GAAG,IAAI,CAAC,cAAc,EAAE,UAAU,CAAC,CAAC;QAElF,yCAAyC;QACzC,gBAAgB,EAAE,CAAC,CAAC,QAAQ,EAAE;YAAE,UAAU,EAAE,SAAS,EAAE,CAAC;YAAC,SAAS,EAAE,gBAAgB,CAAC;YAAC,OAAO,EAAE,UAAU,CAAC,SAAS,CAAC,CAAC;YAAC,sBAAsB,EAAE,CAAC,MAAM,GAAG,MAAM,CAAC,CAAA;SAAE,EAAE,KAAK,2BAA2B,CAAC,GAAG,IAAI,CAAC,cAAc,EAAE,UAAU,CAAC,CAAC;QAExO,uCAAuC;QACvC,eAAe,EAAE,CAAC,CAAC,QAAQ,EAAE,SAAS,KAAK,2BAA2B,CAAC,GAAG,IAAI,CAAC,cAAc,EAAE,UAAU,CAAC,CAAC;QAE3G,gCAAgC;QAChC,UAAU,EAAE,CAAC,CAAC,KAAK,EAAE,gBAAgB,KAAK,2BAA2B,CAAC,GAAG,IAAI,CAAC,cAAc,EAAE,UAAU,CAAC,CAAC;KAC3G,CAAC;CAGH"}
@@ -0,0 +1,66 @@
1
+ /* Autogenerated file, do not edit! */
2
+ import { loadContractArtifact, loadContractArtifactForPublic } from '@aztec/aztec.js/abi';
3
+ import { Contract, ContractBase, DeployMethod } from '@aztec/aztec.js/contracts';
4
+ import { Fr } from '@aztec/aztec.js/fields';
5
+ import CounterContractArtifactJson from '../../target/counter_contract-Counter.json' with { type: 'json' };
6
+ export const CounterContractArtifact = loadContractArtifact(CounterContractArtifactJson);
7
+ /**
8
+ * Type-safe interface for contract Counter;
9
+ */
10
+ export class CounterContract extends ContractBase {
11
+ constructor(address, wallet) {
12
+ super(address, CounterContractArtifact, wallet);
13
+ }
14
+ /**
15
+ * Creates a contract instance.
16
+ * @param address - The deployed contract's address.
17
+ * @param wallet - The wallet to use when interacting with the contract.
18
+ * @returns A new Contract instance.
19
+ */
20
+ static at(address, wallet) {
21
+ return Contract.at(address, CounterContract.artifact, wallet);
22
+ }
23
+ /**
24
+ * Creates a tx to deploy a new instance of this contract.
25
+ * @param instantiation - Optional address-affecting parameters (salt, deployer / universalDeploy, publicKeys).
26
+ * Salt defaults to a random value; the deployer is locked lazily from the first send-time `from`.
27
+ */
28
+ static deploy(wallet, instantiation) {
29
+ return DeployMethod.create(wallet, {
30
+ artifact: CounterContractArtifact,
31
+ postDeployCtor: (instance, wallet) => CounterContract.at(instance.address, wallet),
32
+ args: [],
33
+ }, instantiation);
34
+ }
35
+ /**
36
+ * Creates a tx to deploy a new instance of this contract using the specified constructor method.
37
+ */
38
+ static deployWithOpts(opts, ...args) {
39
+ return DeployMethod.create(opts.wallet, {
40
+ artifact: CounterContractArtifact,
41
+ postDeployCtor: (instance, wallet) => CounterContract.at(instance.address, wallet),
42
+ args,
43
+ constructorNameOrArtifact: opts.method ?? 'constructor',
44
+ }, opts.instantiation);
45
+ }
46
+ /**
47
+ * Returns this contract's artifact.
48
+ */
49
+ static get artifact() {
50
+ return CounterContractArtifact;
51
+ }
52
+ /**
53
+ * Returns this contract's artifact with public bytecode.
54
+ */
55
+ static get artifactForPublic() {
56
+ return loadContractArtifactForPublic(CounterContractArtifactJson);
57
+ }
58
+ static get storage() {
59
+ return {
60
+ counter: {
61
+ slot: new Fr(1n),
62
+ }
63
+ };
64
+ }
65
+ }
66
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiQ291bnRlci5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9hcnRpZmFjdHMvQ291bnRlci50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFDQSxzQ0FBc0M7QUFJdEMsT0FBTyxFQUE0SixvQkFBb0IsRUFBRSw2QkFBNkIsRUFBb0YsTUFBTSxxQkFBcUIsQ0FBQztBQUN0VSxPQUFPLEVBQUUsUUFBUSxFQUFFLFlBQVksRUFBaUgsWUFBWSxFQUFFLE1BQU0sMkJBQTJCLENBQUM7QUFFaE0sT0FBTyxFQUFFLEVBQUUsRUFBUyxNQUFNLHdCQUF3QixDQUFDO0FBR25ELE9BQU8sMkJBQTJCLE1BQU0sNENBQTRDLENBQUMsT0FBTyxJQUFJLEVBQUUsTUFBTSxFQUFFLENBQUM7QUFDM0csTUFBTSxDQUFDLE1BQU0sdUJBQXVCLEdBQUcsb0JBQW9CLENBQUMsMkJBQW1ELENBQUMsQ0FBQztBQUlqSDs7R0FFRztBQUNILE1BQU0sT0FBTyxlQUFnQixTQUFRLFlBQVk7SUFFL0MsWUFDRSxPQUFxQixFQUNyQixNQUFjO1FBRWQsS0FBSyxDQUFDLE9BQU8sRUFBRSx1QkFBdUIsRUFBRSxNQUFNLENBQUMsQ0FBQztJQUNsRCxDQUFDO0lBSUQ7Ozs7O09BS0c7SUFDSSxNQUFNLENBQUMsRUFBRSxDQUNkLE9BQXFCLEVBQ3JCLE1BQWM7UUFFZCxPQUFPLFFBQVEsQ0FBQyxFQUFFLENBQUMsT0FBTyxFQUFFLGVBQWUsQ0FBQyxRQUFRLEVBQUUsTUFBTSxDQUFvQixDQUFDO0lBQ25GLENBQUM7SUFHRDs7OztPQUlHO0lBQ0ksTUFBTSxDQUFDLE1BQU0sQ0FBQyxNQUFjLEVBQUUsYUFBMEM7UUFDN0UsT0FBTyxZQUFZLENBQUMsTUFBTSxDQUN4QixNQUFNLEVBQ047WUFDRSxRQUFRLEVBQUUsdUJBQXVCO1lBQ2pDLGNBQWMsRUFBRSxDQUFDLFFBQVEsRUFBRSxNQUFNLEVBQUUsRUFBRSxDQUFDLGVBQWUsQ0FBQyxFQUFFLENBQUMsUUFBUSxDQUFDLE9BQU8sRUFBRSxNQUFNLENBQUM7WUFDbEYsSUFBSSxFQUFFLEVBQUU7U0FDVCxFQUNELGFBQWEsQ0FDZCxDQUFDO0lBQ0osQ0FBQztJQUVEOztPQUVHO0lBQ0ksTUFBTSxDQUFDLGNBQWMsQ0FDMUIsSUFBZ0YsRUFDaEYsR0FBRyxJQUErQztRQUVsRCxPQUFPLFlBQVksQ0FBQyxNQUFNLENBQ3hCLElBQUksQ0FBQyxNQUFNLEVBQ1g7WUFDRSxRQUFRLEVBQUUsdUJBQXVCO1lBQ2pDLGNBQWMsRUFBRSxDQUFDLFFBQVEsRUFBRSxNQUFNLEVBQUUsRUFBRSxDQUFDLGVBQWUsQ0FBQyxFQUFFLENBQUMsUUFBUSxDQUFDLE9BQU8sRUFBRSxNQUFNLENBQUM7WUFDbEYsSUFBSTtZQUNKLHlCQUF5QixFQUFFLElBQUksQ0FBQyxNQUFNLElBQUksYUFBYTtTQUN4RCxFQUNELElBQUksQ0FBQyxhQUFhLENBQ25CLENBQUM7SUFDSixDQUFDO0lBSUQ7O09BRUc7SUFDSSxNQUFNLEtBQUssUUFBUTtRQUN4QixPQUFPLHVCQUF1QixDQUFDO0lBQ2pDLENBQUM7SUFFRDs7T0FFRztJQUNJLE1BQU0sS0FBSyxpQkFBaUI7UUFDakMsT0FBTyw2QkFBNkIsQ0FBQywyQkFBbUQsQ0FBQyxDQUFDO0lBQzVGLENBQUM7SUFHTSxNQUFNLEtBQUssT0FBTztRQUNyQixPQUFPO1lBQ0wsT0FBTyxFQUFFO2dCQUNYLElBQUksRUFBRSxJQUFJLEVBQUUsQ0FBQyxFQUFFLENBQUM7YUFDakI7U0FDc0MsQ0FBQztJQUN4QyxDQUFDO0NBdUJKIn0=
@@ -0,0 +1,64 @@
1
+ import { AztecAddress } from '@aztec/aztec.js/addresses';
2
+ import { type AztecAddressLike, type ContractArtifact, type FieldLike, type OptionLike } from '@aztec/aztec.js/abi';
3
+ import { ContractBase, ContractFunctionInteraction, type ContractMethod, type ContractStorageLayout, type DeployInstantiationOptions, DeployMethod } from '@aztec/aztec.js/contracts';
4
+ import type { Wallet } from '@aztec/aztec.js/wallet';
5
+ export declare const PrivateFPCContractArtifact: ContractArtifact;
6
+ /**
7
+ * Type-safe interface for contract PrivateFPC;
8
+ */
9
+ export declare class PrivateFPCContract extends ContractBase {
10
+ private constructor();
11
+ /**
12
+ * Creates a contract instance.
13
+ * @param address - The deployed contract's address.
14
+ * @param wallet - The wallet to use when interacting with the contract.
15
+ * @returns A new Contract instance.
16
+ */
17
+ static at(address: AztecAddress, wallet: Wallet): PrivateFPCContract;
18
+ /**
19
+ * Creates a tx to deploy a new instance of this contract.
20
+ * @param instantiation - Optional address-affecting parameters (salt, deployer / universalDeploy, publicKeys).
21
+ * Salt defaults to a random value; the deployer is locked lazily from the first send-time `from`.
22
+ */
23
+ static deploy(wallet: Wallet, instantiation?: DeployInstantiationOptions): DeployMethod<PrivateFPCContract>;
24
+ /**
25
+ * Creates a tx to deploy a new instance of this contract using the specified constructor method.
26
+ */
27
+ static deployWithOpts<M extends keyof PrivateFPCContract['methods']>(opts: {
28
+ method?: M;
29
+ wallet: Wallet;
30
+ instantiation?: DeployInstantiationOptions;
31
+ }, ...args: Parameters<PrivateFPCContract['methods'][M]>): DeployMethod<PrivateFPCContract>;
32
+ /**
33
+ * Returns this contract's artifact.
34
+ */
35
+ static get artifact(): ContractArtifact;
36
+ /**
37
+ * Returns this contract's artifact with public bytecode.
38
+ */
39
+ static get artifactForPublic(): ContractArtifact;
40
+ static get storage(): ContractStorageLayout<'balances'>;
41
+ /** Type-safe wrappers for the public methods exposed by the contract. */
42
+ methods: {
43
+ /** balance_of(account: struct) */
44
+ balance_of: ((account: AztecAddressLike) => ContractFunctionInteraction) & Pick<ContractMethod, 'selector'>;
45
+ /** mint(amount: integer, salt: field, leaf_index: field) */
46
+ mint: ((amount: (bigint | number), salt: FieldLike, leaf_index: FieldLike) => ContractFunctionInteraction) & Pick<ContractMethod, 'selector'>;
47
+ /** mint_and_pay_fee(amount: integer, salt: field, leaf_index: field) */
48
+ mint_and_pay_fee: ((amount: (bigint | number), salt: FieldLike, leaf_index: FieldLike) => ContractFunctionInteraction) & Pick<ContractMethod, 'selector'>;
49
+ /** offchain_receive(messages: struct) */
50
+ offchain_receive: ((messages: {
51
+ ciphertext: FieldLike[];
52
+ recipient: AztecAddressLike;
53
+ tx_hash: OptionLike<FieldLike>;
54
+ anchor_block_timestamp: (bigint | number);
55
+ }[]) => ContractFunctionInteraction) & Pick<ContractMethod, 'selector'>;
56
+ /** pay_fee() */
57
+ pay_fee: (() => ContractFunctionInteraction) & Pick<ContractMethod, 'selector'>;
58
+ /** public_dispatch(selector: field) */
59
+ public_dispatch: ((selector: FieldLike) => ContractFunctionInteraction) & Pick<ContractMethod, 'selector'>;
60
+ /** sync_state(scope: struct) */
61
+ sync_state: ((scope: AztecAddressLike) => ContractFunctionInteraction) & Pick<ContractMethod, 'selector'>;
62
+ };
63
+ }
64
+ //# sourceMappingURL=PrivateFPC.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"PrivateFPC.d.ts","sourceRoot":"","sources":["../../../src/artifacts/PrivateFPC.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,66 @@
1
+ /* Autogenerated file, do not edit! */
2
+ import { loadContractArtifact, loadContractArtifactForPublic } from '@aztec/aztec.js/abi';
3
+ import { Contract, ContractBase, DeployMethod } from '@aztec/aztec.js/contracts';
4
+ import { Fr } from '@aztec/aztec.js/fields';
5
+ import PrivateFPCContractArtifactJson from '../../target/private_contract-PrivateFPC.json' with { type: 'json' };
6
+ export const PrivateFPCContractArtifact = loadContractArtifact(PrivateFPCContractArtifactJson);
7
+ /**
8
+ * Type-safe interface for contract PrivateFPC;
9
+ */
10
+ export class PrivateFPCContract extends ContractBase {
11
+ constructor(address, wallet) {
12
+ super(address, PrivateFPCContractArtifact, wallet);
13
+ }
14
+ /**
15
+ * Creates a contract instance.
16
+ * @param address - The deployed contract's address.
17
+ * @param wallet - The wallet to use when interacting with the contract.
18
+ * @returns A new Contract instance.
19
+ */
20
+ static at(address, wallet) {
21
+ return Contract.at(address, PrivateFPCContract.artifact, wallet);
22
+ }
23
+ /**
24
+ * Creates a tx to deploy a new instance of this contract.
25
+ * @param instantiation - Optional address-affecting parameters (salt, deployer / universalDeploy, publicKeys).
26
+ * Salt defaults to a random value; the deployer is locked lazily from the first send-time `from`.
27
+ */
28
+ static deploy(wallet, instantiation) {
29
+ return DeployMethod.create(wallet, {
30
+ artifact: PrivateFPCContractArtifact,
31
+ postDeployCtor: (instance, wallet) => PrivateFPCContract.at(instance.address, wallet),
32
+ args: [],
33
+ }, instantiation);
34
+ }
35
+ /**
36
+ * Creates a tx to deploy a new instance of this contract using the specified constructor method.
37
+ */
38
+ static deployWithOpts(opts, ...args) {
39
+ return DeployMethod.create(opts.wallet, {
40
+ artifact: PrivateFPCContractArtifact,
41
+ postDeployCtor: (instance, wallet) => PrivateFPCContract.at(instance.address, wallet),
42
+ args,
43
+ constructorNameOrArtifact: opts.method ?? 'constructor',
44
+ }, opts.instantiation);
45
+ }
46
+ /**
47
+ * Returns this contract's artifact.
48
+ */
49
+ static get artifact() {
50
+ return PrivateFPCContractArtifact;
51
+ }
52
+ /**
53
+ * Returns this contract's artifact with public bytecode.
54
+ */
55
+ static get artifactForPublic() {
56
+ return loadContractArtifactForPublic(PrivateFPCContractArtifactJson);
57
+ }
58
+ static get storage() {
59
+ return {
60
+ balances: {
61
+ slot: new Fr(1n),
62
+ }
63
+ };
64
+ }
65
+ }
66
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiUHJpdmF0ZUZQQy5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9hcnRpZmFjdHMvUHJpdmF0ZUZQQy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFDQSxzQ0FBc0M7QUFJdEMsT0FBTyxFQUE0SixvQkFBb0IsRUFBRSw2QkFBNkIsRUFBb0YsTUFBTSxxQkFBcUIsQ0FBQztBQUN0VSxPQUFPLEVBQUUsUUFBUSxFQUFFLFlBQVksRUFBaUgsWUFBWSxFQUFFLE1BQU0sMkJBQTJCLENBQUM7QUFFaE0sT0FBTyxFQUFFLEVBQUUsRUFBUyxNQUFNLHdCQUF3QixDQUFDO0FBR25ELE9BQU8sOEJBQThCLE1BQU0sK0NBQStDLENBQUMsT0FBTyxJQUFJLEVBQUUsTUFBTSxFQUFFLENBQUM7QUFDakgsTUFBTSxDQUFDLE1BQU0sMEJBQTBCLEdBQUcsb0JBQW9CLENBQUMsOEJBQXNELENBQUMsQ0FBQztBQUl2SDs7R0FFRztBQUNILE1BQU0sT0FBTyxrQkFBbUIsU0FBUSxZQUFZO0lBRWxELFlBQ0UsT0FBcUIsRUFDckIsTUFBYztRQUVkLEtBQUssQ0FBQyxPQUFPLEVBQUUsMEJBQTBCLEVBQUUsTUFBTSxDQUFDLENBQUM7SUFDckQsQ0FBQztJQUlEOzs7OztPQUtHO0lBQ0ksTUFBTSxDQUFDLEVBQUUsQ0FDZCxPQUFxQixFQUNyQixNQUFjO1FBRWQsT0FBTyxRQUFRLENBQUMsRUFBRSxDQUFDLE9BQU8sRUFBRSxrQkFBa0IsQ0FBQyxRQUFRLEVBQUUsTUFBTSxDQUF1QixDQUFDO0lBQ3pGLENBQUM7SUFHRDs7OztPQUlHO0lBQ0ksTUFBTSxDQUFDLE1BQU0sQ0FBQyxNQUFjLEVBQUUsYUFBMEM7UUFDN0UsT0FBTyxZQUFZLENBQUMsTUFBTSxDQUN4QixNQUFNLEVBQ047WUFDRSxRQUFRLEVBQUUsMEJBQTBCO1lBQ3BDLGNBQWMsRUFBRSxDQUFDLFFBQVEsRUFBRSxNQUFNLEVBQUUsRUFBRSxDQUFDLGtCQUFrQixDQUFDLEVBQUUsQ0FBQyxRQUFRLENBQUMsT0FBTyxFQUFFLE1BQU0sQ0FBQztZQUNyRixJQUFJLEVBQUUsRUFBRTtTQUNULEVBQ0QsYUFBYSxDQUNkLENBQUM7SUFDSixDQUFDO0lBRUQ7O09BRUc7SUFDSSxNQUFNLENBQUMsY0FBYyxDQUMxQixJQUFnRixFQUNoRixHQUFHLElBQWtEO1FBRXJELE9BQU8sWUFBWSxDQUFDLE1BQU0sQ0FDeEIsSUFBSSxDQUFDLE1BQU0sRUFDWDtZQUNFLFFBQVEsRUFBRSwwQkFBMEI7WUFDcEMsY0FBYyxFQUFFLENBQUMsUUFBUSxFQUFFLE1BQU0sRUFBRSxFQUFFLENBQUMsa0JBQWtCLENBQUMsRUFBRSxDQUFDLFFBQVEsQ0FBQyxPQUFPLEVBQUUsTUFBTSxDQUFDO1lBQ3JGLElBQUk7WUFDSix5QkFBeUIsRUFBRSxJQUFJLENBQUMsTUFBTSxJQUFJLGFBQWE7U0FDeEQsRUFDRCxJQUFJLENBQUMsYUFBYSxDQUNuQixDQUFDO0lBQ0osQ0FBQztJQUlEOztPQUVHO0lBQ0ksTUFBTSxLQUFLLFFBQVE7UUFDeEIsT0FBTywwQkFBMEIsQ0FBQztJQUNwQyxDQUFDO0lBRUQ7O09BRUc7SUFDSSxNQUFNLEtBQUssaUJBQWlCO1FBQ2pDLE9BQU8sNkJBQTZCLENBQUMsOEJBQXNELENBQUMsQ0FBQztJQUMvRixDQUFDO0lBR00sTUFBTSxLQUFLLE9BQU87UUFDckIsT0FBTztZQUNMLFFBQVEsRUFBRTtnQkFDWixJQUFJLEVBQUUsSUFBSSxFQUFFLENBQUMsRUFBRSxDQUFDO2FBQ2pCO1NBQ3VDLENBQUM7SUFDekMsQ0FBQztDQTZCSiJ9
@@ -0,0 +1,46 @@
1
+ import type { NoirCompiledContract } from '@aztec/aztec.js/abi';
2
+ export type ArtifactRegistryUploadResponse = {
3
+ success: true;
4
+ filename?: string;
5
+ classId?: string;
6
+ contractName?: string;
7
+ functionCount?: number;
8
+ [key: string]: unknown;
9
+ } | {
10
+ success: false;
11
+ error?: string;
12
+ message?: string;
13
+ [key: string]: unknown;
14
+ };
15
+ export declare function getArtifactRegistryBaseUrl(): string;
16
+ export declare function shouldUploadArtifacts(): boolean;
17
+ export declare function isStrictUpload(): boolean;
18
+ export declare function uploadArtifactToRegistry(params: {
19
+ artifact: unknown;
20
+ filename: string;
21
+ registryBaseUrl?: string;
22
+ }): Promise<ArtifactRegistryUploadResponse>;
23
+ export declare function uploadArtifactFileToRegistry(params: {
24
+ artifactPath: string;
25
+ filename?: string;
26
+ registryBaseUrl?: string;
27
+ }): Promise<ArtifactRegistryUploadResponse>;
28
+ export declare function maybeUploadArtifactToRegistry(params: {
29
+ artifact: unknown;
30
+ filename: string;
31
+ registryBaseUrl?: string;
32
+ }): Promise<ArtifactRegistryUploadResponse | null>;
33
+ export declare function fetchArtifactFromRegistry(params: {
34
+ classId: string;
35
+ registryBaseUrl?: string;
36
+ }): Promise<unknown>;
37
+ /**
38
+ * Loads an artifact from the registry with fallback to local file.
39
+ * Tries registry first if classId is provided, then falls back to local file.
40
+ */
41
+ export declare function loadArtifactWithRegistryFallback(params: {
42
+ classId?: string;
43
+ localPath: string;
44
+ registryBaseUrl?: string;
45
+ }): Promise<NoirCompiledContract>;
46
+ //# sourceMappingURL=artifactRegistry.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"artifactRegistry.d.ts","sourceRoot":"","sources":["../../../src/ts/artifactRegistry.ts"],"names":[],"mappings":"AAIA,OAAO,KAAK,EAAE,oBAAoB,EAAE,MAAM,qBAAqB,CAAC;AAEhE,MAAM,MAAM,8BAA8B,GACtC;IACE,OAAO,EAAE,IAAI,CAAC;IACd,QAAQ,CAAC,EAAE,MAAM,CAAC;IAClB,OAAO,CAAC,EAAE,MAAM,CAAC;IACjB,YAAY,CAAC,EAAE,MAAM,CAAC;IACtB,aAAa,CAAC,EAAE,MAAM,CAAC;IACvB,CAAC,GAAG,EAAE,MAAM,GAAG,OAAO,CAAC;CACxB,GACD;IACE,OAAO,EAAE,KAAK,CAAC;IACf,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,OAAO,CAAC,EAAE,MAAM,CAAC;IACjB,CAAC,GAAG,EAAE,MAAM,GAAG,OAAO,CAAC;CACxB,CAAC;AAMN,wBAAgB,0BAA0B,IAAI,MAAM,CAEnD;AAED,wBAAgB,qBAAqB,IAAI,OAAO,CAG/C;AAED,wBAAgB,cAAc,IAAI,OAAO,CAGxC;AAED,wBAAsB,wBAAwB,CAAC,MAAM,EAAE;IACrD,QAAQ,EAAE,OAAO,CAAC;IAClB,QAAQ,EAAE,MAAM,CAAC;IACjB,eAAe,CAAC,EAAE,MAAM,CAAC;CAC1B,GAAG,OAAO,CAAC,8BAA8B,CAAC,CA4B1C;AAED,wBAAsB,4BAA4B,CAAC,MAAM,EAAE;IACzD,YAAY,EAAE,MAAM,CAAC;IACrB,QAAQ,CAAC,EAAE,MAAM,CAAC;IAClB,eAAe,CAAC,EAAE,MAAM,CAAC;CAC1B,GAAG,OAAO,CAAC,8BAA8B,CAAC,CAS1C;AAED,wBAAsB,6BAA6B,CAAC,MAAM,EAAE;IAC1D,QAAQ,EAAE,OAAO,CAAC;IAClB,QAAQ,EAAE,MAAM,CAAC;IACjB,eAAe,CAAC,EAAE,MAAM,CAAC;CAC1B,GAAG,OAAO,CAAC,8BAA8B,GAAG,IAAI,CAAC,CAWjD;AAED,wBAAsB,yBAAyB,CAAC,MAAM,EAAE;IACtD,OAAO,EAAE,MAAM,CAAC;IAChB,eAAe,CAAC,EAAE,MAAM,CAAC;CAC1B,GAAG,OAAO,CAAC,OAAO,CAAC,CAenB;AAED;;;GAGG;AACH,wBAAsB,gCAAgC,CAAC,MAAM,EAAE;IAC7D,OAAO,CAAC,EAAE,MAAM,CAAC;IACjB,SAAS,EAAE,MAAM,CAAC;IAClB,eAAe,CAAC,EAAE,MAAM,CAAC;CAC1B,GAAG,OAAO,CAAC,oBAAoB,CAAC,CAmChC"}
@@ -0,0 +1,122 @@
1
+ import { existsSync } from 'node:fs';
2
+ import { readFile } from 'node:fs/promises';
3
+ import { dirname, join } from 'node:path';
4
+ import { fileURLToPath } from 'node:url';
5
+ function normalizeBaseUrl(baseUrl) {
6
+ return baseUrl.endsWith('/') ? baseUrl : `${baseUrl}/`;
7
+ }
8
+ export function getArtifactRegistryBaseUrl() {
9
+ return process.env.AZTEC_ARTIFACT_REGISTRY_URL ?? 'https://devnet.aztec-registry.xyz/';
10
+ }
11
+ export function shouldUploadArtifacts() {
12
+ const v = process.env.AZTEC_ARTIFACT_REGISTRY_UPLOAD ?? '';
13
+ return v === '1' || v.toLowerCase() === 'true';
14
+ }
15
+ export function isStrictUpload() {
16
+ const v = process.env.AZTEC_ARTIFACT_REGISTRY_STRICT ?? '';
17
+ return v === '1' || v.toLowerCase() === 'true';
18
+ }
19
+ export async function uploadArtifactToRegistry(params) {
20
+ const base = normalizeBaseUrl(params.registryBaseUrl ?? getArtifactRegistryBaseUrl());
21
+ const uploadUrl = new URL('api/upload', base).toString();
22
+ const body = new FormData();
23
+ const payload = JSON.stringify(params.artifact);
24
+ body.set('file', new Blob([payload], { type: 'application/json' }), params.filename);
25
+ const res = await fetch(uploadUrl, { method: 'POST', body });
26
+ // The registry commonly returns JSON even on 409; treat duplicates as non-fatal by default.
27
+ const text = await res.text();
28
+ const parsed = text ? safeJsonParse(text) : { success: res.ok };
29
+ if (res.ok) {
30
+ return isRegistryResponseObject(parsed) ? parsed : { success: true };
31
+ }
32
+ // Duplicate artifact (already uploaded) should not break deploys unless strict mode is enabled.
33
+ if (res.status === 409) {
34
+ return isRegistryResponseObject(parsed)
35
+ ? { ...parsed, success: true }
36
+ : { success: true, message: 'Artifact already exists in registry' };
37
+ }
38
+ const msg = typeof parsed === 'object' && parsed ? JSON.stringify(parsed) : text || `HTTP ${res.status} ${res.statusText}`;
39
+ throw new Error(`Artifact registry upload failed (${res.status}): ${msg}`);
40
+ }
41
+ export async function uploadArtifactFileToRegistry(params) {
42
+ const buf = await readFile(params.artifactPath, 'utf8');
43
+ const artifact = JSON.parse(buf);
44
+ const filename = params.filename ?? params.artifactPath.split('/').pop() ?? 'artifact.json';
45
+ return await uploadArtifactToRegistry({
46
+ artifact,
47
+ filename,
48
+ registryBaseUrl: params.registryBaseUrl,
49
+ });
50
+ }
51
+ export async function maybeUploadArtifactToRegistry(params) {
52
+ if (!shouldUploadArtifacts())
53
+ return null;
54
+ try {
55
+ const resp = await uploadArtifactToRegistry(params);
56
+ return resp;
57
+ }
58
+ catch (err) {
59
+ if (isStrictUpload())
60
+ throw err;
61
+ // Best-effort upload; do not fail deployments by default.
62
+ console.warn(`[artifact-registry] Upload failed (continuing): ${err instanceof Error ? err.message : String(err)}`);
63
+ return null;
64
+ }
65
+ }
66
+ export async function fetchArtifactFromRegistry(params) {
67
+ const base = normalizeBaseUrl(params.registryBaseUrl ?? getArtifactRegistryBaseUrl());
68
+ const fetchUrl = new URL(`api/artifacts/${params.classId}`, base).toString();
69
+ const res = await fetch(fetchUrl, { method: 'GET' });
70
+ if (!res.ok) {
71
+ if (res.status === 404) {
72
+ throw new Error(`Artifact not found in registry: ${params.classId}`);
73
+ }
74
+ throw new Error(`Failed to fetch artifact from registry (${res.status}): ${res.statusText}`);
75
+ }
76
+ const text = await res.text();
77
+ return safeJsonParse(text);
78
+ }
79
+ /**
80
+ * Loads an artifact from the registry with fallback to local file.
81
+ * Tries registry first if classId is provided, then falls back to local file.
82
+ */
83
+ export async function loadArtifactWithRegistryFallback(params) {
84
+ // Try registry first if classId is provided
85
+ if (params.classId) {
86
+ try {
87
+ const artifact = await fetchArtifactFromRegistry({
88
+ classId: params.classId,
89
+ registryBaseUrl: params.registryBaseUrl,
90
+ });
91
+ return artifact;
92
+ }
93
+ catch (error) {
94
+ // Fall through to local file if registry fetch fails
95
+ console.warn(`Failed to fetch artifact from registry, using local file: ${error instanceof Error ? error.message : String(error)}`);
96
+ }
97
+ }
98
+ // Fallback to local file
99
+ const __filename = fileURLToPath(import.meta.url);
100
+ const __dirname = dirname(__filename);
101
+ const localArtifactPath = join(__dirname, '../../..', params.localPath);
102
+ if (!existsSync(localArtifactPath)) {
103
+ throw new Error(`Artifact not found at local path: ${localArtifactPath}. ` +
104
+ (params.classId
105
+ ? `Registry fetch also failed for classId: ${params.classId}`
106
+ : 'No classId provided for registry fetch.'));
107
+ }
108
+ const buf = await readFile(localArtifactPath, 'utf8');
109
+ return JSON.parse(buf);
110
+ }
111
+ function safeJsonParse(text) {
112
+ try {
113
+ return JSON.parse(text);
114
+ }
115
+ catch {
116
+ return text;
117
+ }
118
+ }
119
+ function isRegistryResponseObject(value) {
120
+ return typeof value === 'object' && value !== null && 'success' in value;
121
+ }
122
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYXJ0aWZhY3RSZWdpc3RyeS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy90cy9hcnRpZmFjdFJlZ2lzdHJ5LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxVQUFVLEVBQUUsTUFBTSxTQUFTLENBQUM7QUFDckMsT0FBTyxFQUFFLFFBQVEsRUFBRSxNQUFNLGtCQUFrQixDQUFDO0FBQzVDLE9BQU8sRUFBRSxPQUFPLEVBQUUsSUFBSSxFQUFFLE1BQU0sV0FBVyxDQUFDO0FBQzFDLE9BQU8sRUFBRSxhQUFhLEVBQUUsTUFBTSxVQUFVLENBQUM7QUFtQnpDLFNBQVMsZ0JBQWdCLENBQUMsT0FBZTtJQUN2QyxPQUFPLE9BQU8sQ0FBQyxRQUFRLENBQUMsR0FBRyxDQUFDLENBQUMsQ0FBQyxDQUFDLE9BQU8sQ0FBQyxDQUFDLENBQUMsR0FBRyxPQUFPLEdBQUcsQ0FBQztBQUN6RCxDQUFDO0FBRUQsTUFBTSxVQUFVLDBCQUEwQjtJQUN4QyxPQUFPLE9BQU8sQ0FBQyxHQUFHLENBQUMsMkJBQTJCLElBQUksb0NBQW9DLENBQUM7QUFDekYsQ0FBQztBQUVELE1BQU0sVUFBVSxxQkFBcUI7SUFDbkMsTUFBTSxDQUFDLEdBQUcsT0FBTyxDQUFDLEdBQUcsQ0FBQyw4QkFBOEIsSUFBSSxFQUFFLENBQUM7SUFDM0QsT0FBTyxDQUFDLEtBQUssR0FBRyxJQUFJLENBQUMsQ0FBQyxXQUFXLEVBQUUsS0FBSyxNQUFNLENBQUM7QUFDakQsQ0FBQztBQUVELE1BQU0sVUFBVSxjQUFjO0lBQzVCLE1BQU0sQ0FBQyxHQUFHLE9BQU8sQ0FBQyxHQUFHLENBQUMsOEJBQThCLElBQUksRUFBRSxDQUFDO0lBQzNELE9BQU8sQ0FBQyxLQUFLLEdBQUcsSUFBSSxDQUFDLENBQUMsV0FBVyxFQUFFLEtBQUssTUFBTSxDQUFDO0FBQ2pELENBQUM7QUFFRCxNQUFNLENBQUMsS0FBSyxVQUFVLHdCQUF3QixDQUFDLE1BSTlDO0lBQ0Ms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
@@ -0,0 +1,3 @@
1
+ export { PrivateMintAndPayFeePaymentMethod } from './private.js';
2
+ export { FPCFeePaymentMethod } from './shared.js';
3
+ //# sourceMappingURL=index.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../../src/ts/fee-payment-methods/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,iCAAiC,EAAE,MAAM,cAAc,CAAC;AACjE,OAAO,EAAE,mBAAmB,EAAE,MAAM,aAAa,CAAC"}
@@ -0,0 +1,3 @@
1
+ export { PrivateMintAndPayFeePaymentMethod } from './private.js';
2
+ export { FPCFeePaymentMethod } from './shared.js';
3
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9zcmMvdHMvZmVlLXBheW1lbnQtbWV0aG9kcy9pbmRleC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsaUNBQWlDLEVBQUUsTUFBTSxjQUFjLENBQUM7QUFDakUsT0FBTyxFQUFFLG1CQUFtQixFQUFFLE1BQU0sYUFBYSxDQUFDIn0=