@aztec/entrypoints 0.34.0 → 0.35.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.
- package/dest/account_entrypoint.d.ts +3 -3
- package/dest/account_entrypoint.d.ts.map +1 -1
- package/dest/account_entrypoint.js +13 -11
- package/dest/dapp_entrypoint.d.ts +3 -3
- package/dest/dapp_entrypoint.d.ts.map +1 -1
- package/dest/dapp_entrypoint.js +12 -10
- package/package.json +7 -8
- package/src/account_entrypoint.ts +12 -11
- package/src/dapp_entrypoint.ts +12 -10
- package/dest/entrypoint_payload.d.ts +0 -41
- package/dest/entrypoint_payload.d.ts.map +0 -1
- package/dest/entrypoint_payload.js +0 -76
- package/dest/multi_call_entrypoint.d.ts +0 -15
- package/dest/multi_call_entrypoint.d.ts.map +0 -1
- package/dest/multi_call_entrypoint.js +0 -84
- package/src/entrypoint_payload.ts +0 -121
- package/src/multi_call_entrypoint.ts +0 -91
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
import { type AuthWitnessProvider } from '@aztec/aztec.js/account';
|
|
2
|
-
import { type EntrypointInterface, type
|
|
3
|
-
import {
|
|
2
|
+
import { type EntrypointInterface, type ExecutionRequestInit } from '@aztec/aztec.js/entrypoint';
|
|
3
|
+
import { TxExecutionRequest } from '@aztec/circuit-types';
|
|
4
4
|
import { type AztecAddress } from '@aztec/circuits.js';
|
|
5
5
|
/**
|
|
6
6
|
* Implementation for an entrypoint interface that follows the default entrypoint signature
|
|
@@ -12,7 +12,7 @@ export declare class DefaultAccountEntrypoint implements EntrypointInterface {
|
|
|
12
12
|
private chainId;
|
|
13
13
|
private version;
|
|
14
14
|
constructor(address: AztecAddress, auth: AuthWitnessProvider, chainId?: number, version?: number);
|
|
15
|
-
createTxExecutionRequest(
|
|
15
|
+
createTxExecutionRequest(exec: ExecutionRequestInit): Promise<TxExecutionRequest>;
|
|
16
16
|
private getEntrypointAbi;
|
|
17
17
|
}
|
|
18
18
|
//# sourceMappingURL=account_entrypoint.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"account_entrypoint.d.ts","sourceRoot":"","sources":["../src/account_entrypoint.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,KAAK,mBAAmB,EAAE,MAAM,yBAAyB,CAAC;AACnE,OAAO,EAAE,KAAK,mBAAmB,
|
|
1
|
+
{"version":3,"file":"account_entrypoint.d.ts","sourceRoot":"","sources":["../src/account_entrypoint.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,KAAK,mBAAmB,EAAE,MAAM,yBAAyB,CAAC;AACnE,OAAO,EAAE,KAAK,mBAAmB,EAAqB,KAAK,oBAAoB,EAAE,MAAM,4BAA4B,CAAC;AACpH,OAAO,EAAgB,kBAAkB,EAAE,MAAM,sBAAsB,CAAC;AACxE,OAAO,EAAE,KAAK,YAAY,EAAwC,MAAM,oBAAoB,CAAC;AAK7F;;;GAGG;AACH,qBAAa,wBAAyB,YAAW,mBAAmB;IAEhE,OAAO,CAAC,OAAO;IACf,OAAO,CAAC,IAAI;IACZ,OAAO,CAAC,OAAO;IACf,OAAO,CAAC,OAAO;gBAHP,OAAO,EAAE,YAAY,EACrB,IAAI,EAAE,mBAAmB,EACzB,OAAO,GAAE,MAAyB,EAClC,OAAO,GAAE,MAAwB;IAGrC,wBAAwB,CAAC,IAAI,EAAE,oBAAoB,GAAG,OAAO,CAAC,kBAAkB,CAAC;IAwBvF,OAAO,CAAC,gBAAgB;CA+FzB"}
|
|
@@ -1,8 +1,8 @@
|
|
|
1
|
-
import {
|
|
2
|
-
import {
|
|
1
|
+
import { EntrypointPayload } from '@aztec/aztec.js/entrypoint';
|
|
2
|
+
import { PackedValues, TxExecutionRequest } from '@aztec/circuit-types';
|
|
3
|
+
import { FunctionData, GasSettings, TxContext } from '@aztec/circuits.js';
|
|
3
4
|
import { encodeArguments } from '@aztec/foundation/abi';
|
|
4
5
|
import { DEFAULT_CHAIN_ID, DEFAULT_VERSION } from './constants.js';
|
|
5
|
-
import { buildAppPayload, buildFeePayload, hashPayload } from './entrypoint_payload.js';
|
|
6
6
|
/**
|
|
7
7
|
* Implementation for an entrypoint interface that follows the default entrypoint signature
|
|
8
8
|
* for an account, which accepts an AppPayload and a FeePayload as defined in noir-libs/aztec-noir/src/entrypoint module
|
|
@@ -14,20 +14,22 @@ export class DefaultAccountEntrypoint {
|
|
|
14
14
|
this.chainId = chainId;
|
|
15
15
|
this.version = version;
|
|
16
16
|
}
|
|
17
|
-
async createTxExecutionRequest(
|
|
18
|
-
const {
|
|
19
|
-
const
|
|
17
|
+
async createTxExecutionRequest(exec) {
|
|
18
|
+
const { calls, fee } = exec;
|
|
19
|
+
const appPayload = EntrypointPayload.fromAppExecution(calls);
|
|
20
|
+
const feePayload = await EntrypointPayload.fromFeeOptions(fee);
|
|
20
21
|
const abi = this.getEntrypointAbi();
|
|
21
|
-
const entrypointPackedArgs =
|
|
22
|
-
const appAuthWitness = await this.auth.createAuthWit(
|
|
23
|
-
const feeAuthWitness = await this.auth.createAuthWit(
|
|
22
|
+
const entrypointPackedArgs = PackedValues.fromValues(encodeArguments(abi, [appPayload, feePayload]));
|
|
23
|
+
const appAuthWitness = await this.auth.createAuthWit(appPayload.hash());
|
|
24
|
+
const feeAuthWitness = await this.auth.createAuthWit(feePayload.hash());
|
|
24
25
|
const txRequest = TxExecutionRequest.from({
|
|
25
26
|
argsHash: entrypointPackedArgs.hash,
|
|
26
27
|
origin: this.address,
|
|
27
28
|
functionData: FunctionData.fromAbi(abi),
|
|
28
29
|
txContext: TxContext.empty(this.chainId, this.version),
|
|
29
|
-
packedArguments: [...
|
|
30
|
+
packedArguments: [...appPayload.packedArguments, ...feePayload.packedArguments, entrypointPackedArgs],
|
|
30
31
|
authWitnesses: [appAuthWitness, feeAuthWitness],
|
|
32
|
+
gasSettings: exec.fee?.gasSettings ?? GasSettings.default(),
|
|
31
33
|
});
|
|
32
34
|
return txRequest;
|
|
33
35
|
}
|
|
@@ -127,4 +129,4 @@ export class DefaultAccountEntrypoint {
|
|
|
127
129
|
};
|
|
128
130
|
}
|
|
129
131
|
}
|
|
130
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
132
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYWNjb3VudF9lbnRyeXBvaW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vc3JjL2FjY291bnRfZW50cnlwb2ludC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFDQSxPQUFPLEVBQTRCLGlCQUFpQixFQUE2QixNQUFNLDRCQUE0QixDQUFDO0FBQ3BILE9BQU8sRUFBRSxZQUFZLEVBQUUsa0JBQWtCLEVBQUUsTUFBTSxzQkFBc0IsQ0FBQztBQUN4RSxPQUFPLEVBQXFCLFlBQVksRUFBRSxXQUFXLEVBQUUsU0FBUyxFQUFFLE1BQU0sb0JBQW9CLENBQUM7QUFDN0YsT0FBTyxFQUFvQixlQUFlLEVBQUUsTUFBTSx1QkFBdUIsQ0FBQztBQUUxRSxPQUFPLEVBQUUsZ0JBQWdCLEVBQUUsZUFBZSxFQUFFLE1BQU0sZ0JBQWdCLENBQUM7QUFFbkU7OztHQUdHO0FBQ0gsTUFBTSxPQUFPLHdCQUF3QjtJQUNuQyxZQUNVLE9BQXFCLEVBQ3JCLElBQXlCLEVBQ3pCLFVBQWtCLGdCQUFnQixFQUNsQyxVQUFrQixlQUFlO1FBSGpDLFlBQU8sR0FBUCxPQUFPLENBQWM7UUFDckIsU0FBSSxHQUFKLElBQUksQ0FBcUI7UUFDekIsWUFBTyxHQUFQLE9BQU8sQ0FBMkI7UUFDbEMsWUFBTyxHQUFQLE9BQU8sQ0FBMEI7SUFDeEMsQ0FBQztJQUVKLEtBQUssQ0FBQyx3QkFBd0IsQ0FBQyxJQUEwQjtRQUN2RCxNQUFNLEVBQUUsS0FBSyxFQUFFLEdBQUcsRUFBRSxHQUFHLElBQUksQ0FBQztRQUM1QixNQUFNLFVBQVUsR0FBRyxpQkFBaUIsQ0FBQyxnQkFBZ0IsQ0FBQyxLQUFLLENBQUMsQ0FBQztRQUM3RCxNQUFNLFVBQVUsR0FBRyxNQUFNLGlCQUFpQixDQUFDLGNBQWMsQ0FBQyxHQUFHLENBQUMsQ0FBQztRQUUvRCxNQUFNLEdBQUcsR0FBRyxJQUFJLENBQUMsZ0JBQWdCLEVBQUUsQ0FBQztRQUNwQyxNQUFNLG9CQUFvQixHQUFHLFlBQVksQ0FBQyxVQUFV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
|
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
import { type AuthWitnessProvider } from '@aztec/aztec.js/account';
|
|
2
|
-
import { type EntrypointInterface } from '@aztec/aztec.js/entrypoint';
|
|
3
|
-
import {
|
|
2
|
+
import { type EntrypointInterface, type ExecutionRequestInit } from '@aztec/aztec.js/entrypoint';
|
|
3
|
+
import { TxExecutionRequest } from '@aztec/circuit-types';
|
|
4
4
|
import { type AztecAddress } from '@aztec/circuits.js';
|
|
5
5
|
/**
|
|
6
6
|
* Implementation for an entrypoint interface that follows the default entrypoint signature
|
|
@@ -13,7 +13,7 @@ export declare class DefaultDappEntrypoint implements EntrypointInterface {
|
|
|
13
13
|
private chainId;
|
|
14
14
|
private version;
|
|
15
15
|
constructor(userAddress: AztecAddress, userAuthWitnessProvider: AuthWitnessProvider, dappEntrypointAddress: AztecAddress, chainId?: number, version?: number);
|
|
16
|
-
createTxExecutionRequest(
|
|
16
|
+
createTxExecutionRequest(exec: ExecutionRequestInit): Promise<TxExecutionRequest>;
|
|
17
17
|
private getEntrypointAbi;
|
|
18
18
|
}
|
|
19
19
|
//# sourceMappingURL=dapp_entrypoint.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"dapp_entrypoint.d.ts","sourceRoot":"","sources":["../src/dapp_entrypoint.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,KAAK,mBAAmB,EAAE,MAAM,yBAAyB,CAAC;AACnE,OAAO,EAAE,KAAK,mBAAmB,EAAE,MAAM,4BAA4B,CAAC;
|
|
1
|
+
{"version":3,"file":"dapp_entrypoint.d.ts","sourceRoot":"","sources":["../src/dapp_entrypoint.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,KAAK,mBAAmB,EAAE,MAAM,yBAAyB,CAAC;AACnE,OAAO,EAAE,KAAK,mBAAmB,EAAqB,KAAK,oBAAoB,EAAE,MAAM,4BAA4B,CAAC;AACpH,OAAO,EAAgB,kBAAkB,EAAE,MAAM,sBAAsB,CAAC;AACxE,OAAO,EAAE,KAAK,YAAY,EAA4C,MAAM,oBAAoB,CAAC;AAKjG;;;GAGG;AACH,qBAAa,qBAAsB,YAAW,mBAAmB;IAE7D,OAAO,CAAC,WAAW;IACnB,OAAO,CAAC,uBAAuB;IAC/B,OAAO,CAAC,qBAAqB;IAC7B,OAAO,CAAC,OAAO;IACf,OAAO,CAAC,OAAO;gBAJP,WAAW,EAAE,YAAY,EACzB,uBAAuB,EAAE,mBAAmB,EAC5C,qBAAqB,EAAE,YAAY,EACnC,OAAO,GAAE,MAAyB,EAClC,OAAO,GAAE,MAAwB;IAGrC,wBAAwB,CAAC,IAAI,EAAE,oBAAoB,GAAG,OAAO,CAAC,kBAAkB,CAAC;IAoCvF,OAAO,CAAC,gBAAgB;CA8DzB"}
|
package/dest/dapp_entrypoint.js
CHANGED
|
@@ -1,9 +1,9 @@
|
|
|
1
1
|
import { computeInnerAuthWitHash, computeOuterAuthWitHash } from '@aztec/aztec.js';
|
|
2
|
-
import {
|
|
3
|
-
import {
|
|
2
|
+
import { EntrypointPayload } from '@aztec/aztec.js/entrypoint';
|
|
3
|
+
import { PackedValues, TxExecutionRequest } from '@aztec/circuit-types';
|
|
4
|
+
import { Fr, FunctionData, GasSettings, TxContext } from '@aztec/circuits.js';
|
|
4
5
|
import { encodeArguments } from '@aztec/foundation/abi';
|
|
5
6
|
import { DEFAULT_CHAIN_ID, DEFAULT_VERSION } from './constants.js';
|
|
6
|
-
import { buildDappPayload } from './entrypoint_payload.js';
|
|
7
7
|
/**
|
|
8
8
|
* Implementation for an entrypoint interface that follows the default entrypoint signature
|
|
9
9
|
* for an account, which accepts an AppPayload and a FeePayload as defined in noir-libs/aztec-noir/src/entrypoint module
|
|
@@ -16,13 +16,14 @@ export class DefaultDappEntrypoint {
|
|
|
16
16
|
this.chainId = chainId;
|
|
17
17
|
this.version = version;
|
|
18
18
|
}
|
|
19
|
-
async createTxExecutionRequest(
|
|
20
|
-
|
|
21
|
-
|
|
19
|
+
async createTxExecutionRequest(exec) {
|
|
20
|
+
const { calls } = exec;
|
|
21
|
+
if (calls.length !== 1) {
|
|
22
|
+
throw new Error(`Expected exactly 1 function call, got ${calls.length}`);
|
|
22
23
|
}
|
|
23
|
-
const
|
|
24
|
+
const payload = EntrypointPayload.fromFunctionCalls(calls);
|
|
24
25
|
const abi = this.getEntrypointAbi();
|
|
25
|
-
const entrypointPackedArgs =
|
|
26
|
+
const entrypointPackedArgs = PackedValues.fromValues(encodeArguments(abi, [payload, this.userAddress]));
|
|
26
27
|
const functionData = FunctionData.fromAbi(abi);
|
|
27
28
|
const innerHash = computeInnerAuthWitHash([Fr.ZERO, functionData.selector.toField(), entrypointPackedArgs.hash]);
|
|
28
29
|
const outerHash = computeOuterAuthWitHash(this.dappEntrypointAddress, new Fr(this.chainId), new Fr(this.version), innerHash);
|
|
@@ -32,8 +33,9 @@ export class DefaultDappEntrypoint {
|
|
|
32
33
|
origin: this.dappEntrypointAddress,
|
|
33
34
|
functionData,
|
|
34
35
|
txContext: TxContext.empty(this.chainId, this.version),
|
|
35
|
-
packedArguments: [...packedArguments, entrypointPackedArgs],
|
|
36
|
+
packedArguments: [...payload.packedArguments, entrypointPackedArgs],
|
|
36
37
|
authWitnesses: [authWitness],
|
|
38
|
+
gasSettings: exec.fee?.gasSettings ?? GasSettings.default(),
|
|
37
39
|
});
|
|
38
40
|
return txRequest;
|
|
39
41
|
}
|
|
@@ -100,4 +102,4 @@ export class DefaultDappEntrypoint {
|
|
|
100
102
|
};
|
|
101
103
|
}
|
|
102
104
|
}
|
|
103
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
105
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZGFwcF9lbnRyeXBvaW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vc3JjL2RhcHBfZW50cnlwb2ludC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsdUJBQXVCLEVBQUUsdUJBQXVCLEVBQUUsTUFBTSxpQkFBaUIsQ0FBQztBQUVuRixPQUFPLEVBQTRCLGlCQUFpQixFQUE2QixNQUFNLDRCQUE0QixDQUFDO0FBQ3BILE9BQU8sRUFBRSxZQUFZLEVBQUUsa0JBQWtCLEVBQUUsTUFBTSxzQkFBc0IsQ0FBQztBQUN4RSxPQUFPLEVBQXFCLEVBQUUsRUFBRSxZQUFZLEVBQUUsV0FBVyxFQUFFLFNBQVMsRUFBRSxNQUFNLG9CQUFvQixDQUFDO0FBQ2pHLE9BQU8sRUFBb0IsZUFBZSxFQUFFLE1BQU0sdUJBQXVCLENBQUM7QUFFMUUsT0FBTyxFQUFFLGdCQUFnQixFQUFFLGVBQWUsRUFBRSxNQUFNLGdCQUFnQixDQUFDO0FBRW5FOzs7R0FHRztBQUNILE1BQU0sT0FBTyxxQkFBcUI7SUFDaEMsWUFDVSxXQUF5QixFQUN6Qix1QkFBNEMsRUFDNUMscUJBQW1DLEVBQ25DLFVBQWtCLGdCQUFnQixFQUNsQyxVQUFrQixlQUFlO1FBSmpDLGdCQUFXLEdBQVgsV0FBVyxDQUFjO1FBQ3pCLDRCQUF1QixHQUF2Qix1QkFBdUIsQ0FBcUI7UUFDNUMsMEJBQXFCLEdBQXJCLHFCQUFxQixDQUFjO1FBQ25DLFlBQU8sR0FBUCxPQUFPLENBQTJCO1FBQ2xDLFlBQU8sR0FBUCxPQUFPLENBQTBCO0lBQ3hDLENBQUM7SUFFSixLQUFLLENBQUMsd0JBQXdCLENBQUMsSUFBMEI7UUFDdkQsTUFBTSxFQUFFLEtBQUssRUFBRSxHQUFHLElBQUksQ0FBQztRQUN2QixJQUFJLEtBQUssQ0FBQyxNQUFNLEtBQUssQ0FBQyxFQUFFLENBQUM7WUFDdkIsTUFBTSxJQUFJLEtBQUssQ0FBQyx5Q0FBeUMsS0FBSyxDQUFDLE1BQU0sRUFBRSxDQUFDLENB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
|
package/package.json
CHANGED
|
@@ -2,12 +2,11 @@
|
|
|
2
2
|
"name": "@aztec/entrypoints",
|
|
3
3
|
"homepage": "https://github.com/AztecProtocol/aztec-packages/tree/master/yarn-project/entrypoints",
|
|
4
4
|
"description": "Implementation of sample contract entrypoints for the Aztec Network",
|
|
5
|
-
"version": "0.
|
|
5
|
+
"version": "0.35.0",
|
|
6
6
|
"type": "module",
|
|
7
7
|
"exports": {
|
|
8
8
|
"./dapp": "./dest/dapp_entrypoint.js",
|
|
9
|
-
"./account": "./dest/account_entrypoint.js"
|
|
10
|
-
"./multi-call": "./dest/multi_call_entrypoint.js"
|
|
9
|
+
"./account": "./dest/account_entrypoint.js"
|
|
11
10
|
},
|
|
12
11
|
"typedocOptions": {
|
|
13
12
|
"entryPoints": [
|
|
@@ -44,11 +43,11 @@
|
|
|
44
43
|
]
|
|
45
44
|
},
|
|
46
45
|
"dependencies": {
|
|
47
|
-
"@aztec/aztec.js": "0.
|
|
48
|
-
"@aztec/circuit-types": "0.
|
|
49
|
-
"@aztec/circuits.js": "0.
|
|
50
|
-
"@aztec/foundation": "0.
|
|
51
|
-
"@aztec/protocol-contracts": "0.
|
|
46
|
+
"@aztec/aztec.js": "0.35.0",
|
|
47
|
+
"@aztec/circuit-types": "0.35.0",
|
|
48
|
+
"@aztec/circuits.js": "0.35.0",
|
|
49
|
+
"@aztec/foundation": "0.35.0",
|
|
50
|
+
"@aztec/protocol-contracts": "0.35.0",
|
|
52
51
|
"tslib": "^2.4.0"
|
|
53
52
|
},
|
|
54
53
|
"devDependencies": {
|
|
@@ -1,11 +1,10 @@
|
|
|
1
1
|
import { type AuthWitnessProvider } from '@aztec/aztec.js/account';
|
|
2
|
-
import { type EntrypointInterface, type
|
|
3
|
-
import {
|
|
4
|
-
import { type AztecAddress, FunctionData,
|
|
2
|
+
import { type EntrypointInterface, EntrypointPayload, type ExecutionRequestInit } from '@aztec/aztec.js/entrypoint';
|
|
3
|
+
import { PackedValues, TxExecutionRequest } from '@aztec/circuit-types';
|
|
4
|
+
import { type AztecAddress, FunctionData, GasSettings, TxContext } from '@aztec/circuits.js';
|
|
5
5
|
import { type FunctionAbi, encodeArguments } from '@aztec/foundation/abi';
|
|
6
6
|
|
|
7
7
|
import { DEFAULT_CHAIN_ID, DEFAULT_VERSION } from './constants.js';
|
|
8
|
-
import { buildAppPayload, buildFeePayload, hashPayload } from './entrypoint_payload.js';
|
|
9
8
|
|
|
10
9
|
/**
|
|
11
10
|
* Implementation for an entrypoint interface that follows the default entrypoint signature
|
|
@@ -19,23 +18,25 @@ export class DefaultAccountEntrypoint implements EntrypointInterface {
|
|
|
19
18
|
private version: number = DEFAULT_VERSION,
|
|
20
19
|
) {}
|
|
21
20
|
|
|
22
|
-
async createTxExecutionRequest(
|
|
23
|
-
const {
|
|
24
|
-
const
|
|
21
|
+
async createTxExecutionRequest(exec: ExecutionRequestInit): Promise<TxExecutionRequest> {
|
|
22
|
+
const { calls, fee } = exec;
|
|
23
|
+
const appPayload = EntrypointPayload.fromAppExecution(calls);
|
|
24
|
+
const feePayload = await EntrypointPayload.fromFeeOptions(fee);
|
|
25
25
|
|
|
26
26
|
const abi = this.getEntrypointAbi();
|
|
27
|
-
const entrypointPackedArgs =
|
|
27
|
+
const entrypointPackedArgs = PackedValues.fromValues(encodeArguments(abi, [appPayload, feePayload]));
|
|
28
28
|
|
|
29
|
-
const appAuthWitness = await this.auth.createAuthWit(
|
|
30
|
-
const feeAuthWitness = await this.auth.createAuthWit(
|
|
29
|
+
const appAuthWitness = await this.auth.createAuthWit(appPayload.hash());
|
|
30
|
+
const feeAuthWitness = await this.auth.createAuthWit(feePayload.hash());
|
|
31
31
|
|
|
32
32
|
const txRequest = TxExecutionRequest.from({
|
|
33
33
|
argsHash: entrypointPackedArgs.hash,
|
|
34
34
|
origin: this.address,
|
|
35
35
|
functionData: FunctionData.fromAbi(abi),
|
|
36
36
|
txContext: TxContext.empty(this.chainId, this.version),
|
|
37
|
-
packedArguments: [...
|
|
37
|
+
packedArguments: [...appPayload.packedArguments, ...feePayload.packedArguments, entrypointPackedArgs],
|
|
38
38
|
authWitnesses: [appAuthWitness, feeAuthWitness],
|
|
39
|
+
gasSettings: exec.fee?.gasSettings ?? GasSettings.default(),
|
|
39
40
|
});
|
|
40
41
|
|
|
41
42
|
return txRequest;
|
package/src/dapp_entrypoint.ts
CHANGED
|
@@ -1,12 +1,11 @@
|
|
|
1
1
|
import { computeInnerAuthWitHash, computeOuterAuthWitHash } from '@aztec/aztec.js';
|
|
2
2
|
import { type AuthWitnessProvider } from '@aztec/aztec.js/account';
|
|
3
|
-
import { type EntrypointInterface } from '@aztec/aztec.js/entrypoint';
|
|
4
|
-
import {
|
|
5
|
-
import { type AztecAddress, Fr, FunctionData, TxContext } from '@aztec/circuits.js';
|
|
3
|
+
import { type EntrypointInterface, EntrypointPayload, type ExecutionRequestInit } from '@aztec/aztec.js/entrypoint';
|
|
4
|
+
import { PackedValues, TxExecutionRequest } from '@aztec/circuit-types';
|
|
5
|
+
import { type AztecAddress, Fr, FunctionData, GasSettings, TxContext } from '@aztec/circuits.js';
|
|
6
6
|
import { type FunctionAbi, encodeArguments } from '@aztec/foundation/abi';
|
|
7
7
|
|
|
8
8
|
import { DEFAULT_CHAIN_ID, DEFAULT_VERSION } from './constants.js';
|
|
9
|
-
import { buildDappPayload } from './entrypoint_payload.js';
|
|
10
9
|
|
|
11
10
|
/**
|
|
12
11
|
* Implementation for an entrypoint interface that follows the default entrypoint signature
|
|
@@ -21,14 +20,16 @@ export class DefaultDappEntrypoint implements EntrypointInterface {
|
|
|
21
20
|
private version: number = DEFAULT_VERSION,
|
|
22
21
|
) {}
|
|
23
22
|
|
|
24
|
-
async createTxExecutionRequest(
|
|
25
|
-
|
|
26
|
-
|
|
23
|
+
async createTxExecutionRequest(exec: ExecutionRequestInit): Promise<TxExecutionRequest> {
|
|
24
|
+
const { calls } = exec;
|
|
25
|
+
if (calls.length !== 1) {
|
|
26
|
+
throw new Error(`Expected exactly 1 function call, got ${calls.length}`);
|
|
27
27
|
}
|
|
28
|
-
|
|
28
|
+
|
|
29
|
+
const payload = EntrypointPayload.fromFunctionCalls(calls);
|
|
29
30
|
|
|
30
31
|
const abi = this.getEntrypointAbi();
|
|
31
|
-
const entrypointPackedArgs =
|
|
32
|
+
const entrypointPackedArgs = PackedValues.fromValues(encodeArguments(abi, [payload, this.userAddress]));
|
|
32
33
|
|
|
33
34
|
const functionData = FunctionData.fromAbi(abi);
|
|
34
35
|
|
|
@@ -47,8 +48,9 @@ export class DefaultDappEntrypoint implements EntrypointInterface {
|
|
|
47
48
|
origin: this.dappEntrypointAddress,
|
|
48
49
|
functionData,
|
|
49
50
|
txContext: TxContext.empty(this.chainId, this.version),
|
|
50
|
-
packedArguments: [...packedArguments, entrypointPackedArgs],
|
|
51
|
+
packedArguments: [...payload.packedArguments, entrypointPackedArgs],
|
|
51
52
|
authWitnesses: [authWitness],
|
|
53
|
+
gasSettings: exec.fee?.gasSettings ?? GasSettings.default(),
|
|
52
54
|
});
|
|
53
55
|
|
|
54
56
|
return txRequest;
|
|
@@ -1,41 +0,0 @@
|
|
|
1
|
-
import { type FeeOptions } from '@aztec/aztec.js/entrypoint';
|
|
2
|
-
import { Fr } from '@aztec/aztec.js/fields';
|
|
3
|
-
import { type FunctionCall, PackedArguments } from '@aztec/circuit-types';
|
|
4
|
-
import { type AztecAddress } from '@aztec/circuits.js';
|
|
5
|
-
/** Encoded function call for account contract entrypoint */
|
|
6
|
-
type EntrypointFunctionCall = {
|
|
7
|
-
/** Arguments hash for the call */
|
|
8
|
-
args_hash: Fr;
|
|
9
|
-
/** Selector of the function to call */
|
|
10
|
-
function_selector: Fr;
|
|
11
|
-
/** Address of the contract to call */
|
|
12
|
-
target_address: Fr;
|
|
13
|
-
/** Whether the function is public or private */
|
|
14
|
-
is_public: boolean;
|
|
15
|
-
};
|
|
16
|
-
/** Encoded payload for the account contract entrypoint */
|
|
17
|
-
type EntrypointPayload = {
|
|
18
|
-
/** Encoded function calls to execute */
|
|
19
|
-
function_calls: EntrypointFunctionCall[];
|
|
20
|
-
/** A nonce for replay protection */
|
|
21
|
-
nonce: Fr;
|
|
22
|
-
};
|
|
23
|
-
/** Represents a generic payload to be executed in the context of an account contract */
|
|
24
|
-
export type PayloadWithArguments = {
|
|
25
|
-
/** The payload to be run */
|
|
26
|
-
payload: EntrypointPayload;
|
|
27
|
-
/** The packed arguments for the function calls */
|
|
28
|
-
packedArguments: PackedArguments[];
|
|
29
|
-
};
|
|
30
|
-
/** builds the payload for a Dapp entrypoint */
|
|
31
|
-
export declare function buildDappPayload(call: FunctionCall): PayloadWithArguments;
|
|
32
|
-
/** Assembles an entrypoint app payload from a set of private and public function calls */
|
|
33
|
-
export declare function buildAppPayload(calls: FunctionCall[]): PayloadWithArguments;
|
|
34
|
-
/** Creates the payload for paying the fee for a transaction */
|
|
35
|
-
export declare function buildFeePayload(feeOpts?: FeeOptions): Promise<PayloadWithArguments>;
|
|
36
|
-
/** Hashes a payload to a 32-byte buffer */
|
|
37
|
-
export declare function hashPayload(payload: EntrypointPayload, generatorIndex: number): Fr;
|
|
38
|
-
/** Hash the payload for a dapp */
|
|
39
|
-
export declare function hashDappPayload(payload: EntrypointPayload, userAddress: AztecAddress, generatorIndex: number): Fr;
|
|
40
|
-
export {};
|
|
41
|
-
//# sourceMappingURL=entrypoint_payload.d.ts.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"entrypoint_payload.d.ts","sourceRoot":"","sources":["../src/entrypoint_payload.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,KAAK,UAAU,EAAE,MAAM,4BAA4B,CAAC;AAC7D,OAAO,EAAE,EAAE,EAAE,MAAM,wBAAwB,CAAC;AAC5C,OAAO,EAAE,KAAK,YAAY,EAAE,eAAe,EAAqB,MAAM,sBAAsB,CAAC;AAC7F,OAAO,EAAE,KAAK,YAAY,EAAE,MAAM,oBAAoB,CAAC;AAUvD,4DAA4D;AAC5D,KAAK,sBAAsB,GAAG;IAE5B,kCAAkC;IAClC,SAAS,EAAE,EAAE,CAAC;IAEd,uCAAuC;IACvC,iBAAiB,EAAE,EAAE,CAAC;IAEtB,sCAAsC;IACtC,cAAc,EAAE,EAAE,CAAC;IAEnB,gDAAgD;IAChD,SAAS,EAAE,OAAO,CAAC;CACpB,CAAC;AAEF,0DAA0D;AAC1D,KAAK,iBAAiB,GAAG;IAEvB,wCAAwC;IACxC,cAAc,EAAE,sBAAsB,EAAE,CAAC;IACzC,oCAAoC;IACpC,KAAK,EAAE,EAAE,CAAC;CACX,CAAC;AAEF,wFAAwF;AACxF,MAAM,MAAM,oBAAoB,GAAG;IACjC,4BAA4B;IAC5B,OAAO,EAAE,iBAAiB,CAAC;IAC3B,kDAAkD;IAClD,eAAe,EAAE,eAAe,EAAE,CAAC;CACpC,CAAC;AAsCF,+CAA+C;AAC/C,wBAAgB,gBAAgB,CAAC,IAAI,EAAE,YAAY,GAAG,oBAAoB,CAEzE;AAED,0FAA0F;AAC1F,wBAAgB,eAAe,CAAC,KAAK,EAAE,YAAY,EAAE,GAAG,oBAAoB,CAE3E;AAED,+DAA+D;AAC/D,wBAAsB,eAAe,CAAC,OAAO,CAAC,EAAE,UAAU,GAAG,OAAO,CAAC,oBAAoB,CAAC,CAGzF;AAGD,2CAA2C;AAC3C,wBAAgB,WAAW,CAAC,OAAO,EAAE,iBAAiB,EAAE,cAAc,EAAE,MAAM,MAE7E;AAED,kCAAkC;AAClC,wBAAgB,eAAe,CAAC,OAAO,EAAE,iBAAiB,EAAE,WAAW,EAAE,YAAY,EAAE,cAAc,EAAE,MAAM,MAE5G"}
|
|
@@ -1,76 +0,0 @@
|
|
|
1
|
-
import { Fr } from '@aztec/aztec.js/fields';
|
|
2
|
-
import { PackedArguments, emptyFunctionCall } from '@aztec/circuit-types';
|
|
3
|
-
import { padArrayEnd } from '@aztec/foundation/collection';
|
|
4
|
-
import { pedersenHash } from '@aztec/foundation/crypto';
|
|
5
|
-
// These must match the values defined in:
|
|
6
|
-
// - noir-projects/aztec-nr/aztec/src/entrypoint/app.nr
|
|
7
|
-
const ACCOUNT_MAX_CALLS = 4;
|
|
8
|
-
// - and noir-projects/aztec-nr/aztec/src/entrypoint/fee.nr
|
|
9
|
-
const FEE_MAX_CALLS = 2;
|
|
10
|
-
/**
|
|
11
|
-
* Builds a payload to be sent to the account contract
|
|
12
|
-
* @param calls - The function calls to run
|
|
13
|
-
* @param maxCalls - The maximum number of call expected to be run. Used for padding
|
|
14
|
-
* @returns A payload object and packed arguments
|
|
15
|
-
*/
|
|
16
|
-
function buildPayload(calls, maxCalls) {
|
|
17
|
-
const nonce = Fr.random();
|
|
18
|
-
const paddedCalls = padArrayEnd(calls, emptyFunctionCall(), maxCalls);
|
|
19
|
-
const packedArguments = [];
|
|
20
|
-
for (const call of paddedCalls) {
|
|
21
|
-
packedArguments.push(PackedArguments.fromArgs(call.args));
|
|
22
|
-
}
|
|
23
|
-
const formattedCalls = paddedCalls.map((call, index) => ({
|
|
24
|
-
// eslint-disable-next-line camelcase
|
|
25
|
-
args_hash: packedArguments[index].hash,
|
|
26
|
-
// eslint-disable-next-line camelcase
|
|
27
|
-
function_selector: call.functionData.selector.toField(),
|
|
28
|
-
// eslint-disable-next-line camelcase
|
|
29
|
-
target_address: call.to.toField(),
|
|
30
|
-
// eslint-disable-next-line camelcase
|
|
31
|
-
is_public: !call.functionData.isPrivate,
|
|
32
|
-
}));
|
|
33
|
-
return {
|
|
34
|
-
payload: {
|
|
35
|
-
// eslint-disable-next-line camelcase
|
|
36
|
-
function_calls: formattedCalls,
|
|
37
|
-
nonce,
|
|
38
|
-
},
|
|
39
|
-
packedArguments,
|
|
40
|
-
};
|
|
41
|
-
}
|
|
42
|
-
/** builds the payload for a Dapp entrypoint */
|
|
43
|
-
export function buildDappPayload(call) {
|
|
44
|
-
return buildPayload([call], 1);
|
|
45
|
-
}
|
|
46
|
-
/** Assembles an entrypoint app payload from a set of private and public function calls */
|
|
47
|
-
export function buildAppPayload(calls) {
|
|
48
|
-
return buildPayload(calls, ACCOUNT_MAX_CALLS);
|
|
49
|
-
}
|
|
50
|
-
/** Creates the payload for paying the fee for a transaction */
|
|
51
|
-
export async function buildFeePayload(feeOpts) {
|
|
52
|
-
const calls = feeOpts ? await feeOpts.paymentMethod.getFunctionCalls(new Fr(feeOpts.maxFee)) : [];
|
|
53
|
-
return buildPayload(calls, FEE_MAX_CALLS);
|
|
54
|
-
}
|
|
55
|
-
// TODO (dogfooding) change all of these names app/dapp/fee/payload and generator indices for all of them
|
|
56
|
-
/** Hashes a payload to a 32-byte buffer */
|
|
57
|
-
export function hashPayload(payload, generatorIndex) {
|
|
58
|
-
return pedersenHash(flattenPayload(payload), generatorIndex);
|
|
59
|
-
}
|
|
60
|
-
/** Hash the payload for a dapp */
|
|
61
|
-
export function hashDappPayload(payload, userAddress, generatorIndex) {
|
|
62
|
-
return pedersenHash([...flattenPayload(payload), userAddress], generatorIndex);
|
|
63
|
-
}
|
|
64
|
-
/** Flattens an payload */
|
|
65
|
-
function flattenPayload(payload) {
|
|
66
|
-
return [
|
|
67
|
-
...payload.function_calls.flatMap(call => [
|
|
68
|
-
call.args_hash,
|
|
69
|
-
call.function_selector,
|
|
70
|
-
call.target_address,
|
|
71
|
-
new Fr(call.is_public),
|
|
72
|
-
]),
|
|
73
|
-
payload.nonce,
|
|
74
|
-
];
|
|
75
|
-
}
|
|
76
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZW50cnlwb2ludF9wYXlsb2FkLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vc3JjL2VudHJ5cG9pbnRfcGF5bG9hZC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFDQSxPQUFPLEVBQUUsRUFBRSxFQUFFLE1BQU0sd0JBQXdCLENBQUM7QUFDNUMsT0FBTyxFQUFxQixlQUFlLEVBQUUsaUJBQWlCLEVBQUUsTUFBTSxzQkFBc0IsQ0FBQztBQUU3RixPQUFPLEVBQUUsV0FBVyxFQUFFLE1BQU0sOEJBQThCLENBQUM7QUFDM0QsT0FBTyxFQUFFLFlBQVksRUFBRSxNQUFNLDBCQUEwQixDQUFDO0FBRXhELDBDQUEwQztBQUMxQyx1REFBdUQ7QUFDdkQsTUFBTSxpQkFBaUIsR0FBRyxDQUFDLENBQUM7QUFDNUIsMkRBQTJEO0FBQzNELE1BQU0sYUFBYSxHQUFHLENBQUMsQ0FBQztBQW1DeEI7Ozs7O0dBS0c7QUFDSCxTQUFTLFlBQVksQ0FBQyxLQUFxQixFQUFFLFFBQWdCO0lBQzNELE1BQU0sS0FBSyxHQUFHLEVBQUUsQ0FBQyxNQUFNLEVBQUUsQ0FBQztJQUUxQixNQUFNLFdBQVcsR0FBRyxXQUFXLENBQUMsS0FBSyxFQUFFLGlCQUFpQixFQUFFLEVBQUUsUUFBUSxDQUFDLENBQUM7SUFDdEUsTUFBTSxlQUFlLEdBQXNCLEVBQUUsQ0FBQztJQUM5QyxLQUFLLE1BQU0sSUFBSSxJQUFJLFdBQVcsRUFBRSxDQUFDO1FBQy9CLGVBQWUsQ0FBQyxJQUFJLENBQUMsZUFBZSxDQUFDLFFBQVEsQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUFDLENBQUMsQ0FBQztJQUM1RCxDQUFDO0lBRUQsTUFBTSxjQUFjLEdBQTZCLFdBQVcsQ0FBQyxHQUFHLENBQUMsQ0FBQyxJQUFJLEVBQUUsS0FBSyxFQUFFLEVBQUUsQ0FBQyxDQUFDO1FBQ2pGLHFDQUFxQztRQUNyQyxTQUFTLEVBQUUsZUFBZSxDQUFDLEtBQUssQ0FBQyxDQUFDLElBQUk7UUFDdEMscUNBQXFDO1FBQ3JDLGlCQUFpQixFQUFFLElBQUksQ0FBQyxZQUFZLENBQUMsUUFBUSxDQUFDLE9BQU8sRUFBRTtRQUN2RCxxQ0FBcUM7UUFDckMsY0FBYyxFQUFFLElBQUksQ0FBQyxFQUFFLENBQUMsT0FBTyxFQUFFO1FBQ2pDLHFDQUFxQztRQUNyQyxTQUFTLEVBQUUsQ0FBQyxJQUFJLENBQUMsWUFBWSxDQUFDLFNBQVM7S0FDeEMsQ0FBQyxDQUFDLENBQUM7SUFFSixPQUFPO1FBQ0wsT0FBTyxFQUFFO1lBQ1AscUNBQXFDO1lBQ3JDLGNBQWMsRUFBRSxjQUFjO1lBQzlCLEtBQUs7U0FDTjtRQUNELGVBQWU7S0FDaEIsQ0FBQztBQUNKLENBQUM7QUFFRCwrQ0FBK0M7QUFDL0MsTUFBTSxVQUFVLGdCQUFnQixDQUFDLElBQWtCO0lBQ2pELE9BQU8sWUFBWSxDQUFDLENBQUMsSUFBSSxDQUFDLEVBQUUsQ0FBQyxDQUFDLENBQUM7QUFDakMsQ0FBQztBQUVELDBGQUEwRjtBQUMxRixNQUFNLFVBQVUsZUFBZSxDQUFDLEtBQXFCO0lBQ25ELE9BQU8sWUFBWSxDQUFDLEtBQUssRUFBRSxpQkFBaUIsQ0FBQyxDQUFDO0FBQ2hELENBQUM7QUFFRCwrREFBK0Q7QUFDL0QsTUFBTSxDQUFDLEtBQUssVUFBVSxlQUFlLENBQUMsT0FBb0I7SUFDeEQsTUFBTSxLQUFLLEdBQUcsT0FBTyxDQUFDLENBQUMsQ0FBQyxNQUFNLE9BQU8sQ0FBQyxhQUFhLENBQUMsZ0JBQWdCLENBQUMsSUFBSSxFQUFFLENBQUMsT0FBTyxDQUFDLE1BQU0sQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLEVBQUUsQ0FBQztJQUNsRyxPQUFPLFlBQVksQ0FBQyxLQUFLLEVBQUUsYUFBYSxDQUFDLENBQUM7QUFDNUMsQ0FBQztBQUVELHlHQUF5RztBQUN6RywyQ0FBMkM7QUFDM0MsTUFBTSxVQUFVLFdBQVcsQ0FBQyxPQUEwQixFQUFFLGNBQXNCO0lBQzVFLE9BQU8sWUFBWSxDQUFDLGNBQWMsQ0FBQyxPQUFPLENBQUMsRUFBRSxjQUFjLENBQUMsQ0FBQztBQUMvRCxDQUFDO0FBRUQsa0NBQWtDO0FBQ2xDLE1BQU0sVUFBVSxlQUFlLENBQUMsT0FBMEIsRUFBRSxXQUF5QixFQUFFLGNBQXNCO0lBQzNHLE9BQU8sWUFBWSxDQUFDLENBQUMsR0FBRyxjQUFjLENBQUMsT0FBTyxDQUFDLEVBQUUsV0FBVyxDQUFDLEVBQUUsY0FBYyxDQUFDLENBQUM7QUFDakYsQ0FBQztBQUVELDBCQUEwQjtBQUMxQixTQUFTLGNBQWMsQ0FBQyxPQUEwQjtJQUNoRCxPQUFPO1FBQ0wsR0FBRyxPQUFPLENBQUMsY0FBYyxDQUFDLE9BQU8sQ0FBQyxJQUFJLENBQUMsRUFBRSxDQUFDO1lBQ3hDLElBQUksQ0FBQyxTQUFTO1lBQ2QsSUFBSSxDQUFDLGlCQUFpQjtZQUN0QixJQUFJLENBQUMsY0FBYztZQUNuQixJQUFJLEVBQUUsQ0FBQyxJQUFJLENBQUMsU0FBUyxDQUFDO1NBQ3ZCLENBQUM7UUFDRixPQUFPLENBQUMsS0FBSztLQUNkLENBQUM7QUFDSixDQUFDIn0=
|
|
@@ -1,15 +0,0 @@
|
|
|
1
|
-
import { type EntrypointInterface } from '@aztec/aztec.js/entrypoint';
|
|
2
|
-
import { type FunctionCall, TxExecutionRequest } from '@aztec/circuit-types';
|
|
3
|
-
import { type AztecAddress } from '@aztec/circuits.js';
|
|
4
|
-
/**
|
|
5
|
-
* Implementation for an entrypoint interface that can execute multiple function calls in a single transaction
|
|
6
|
-
*/
|
|
7
|
-
export declare class DefaultMultiCallEntrypoint implements EntrypointInterface {
|
|
8
|
-
private address;
|
|
9
|
-
private chainId;
|
|
10
|
-
private version;
|
|
11
|
-
constructor(address?: AztecAddress, chainId?: number, version?: number);
|
|
12
|
-
createTxExecutionRequest(executions: FunctionCall[]): Promise<TxExecutionRequest>;
|
|
13
|
-
private getEntrypointAbi;
|
|
14
|
-
}
|
|
15
|
-
//# sourceMappingURL=multi_call_entrypoint.d.ts.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"multi_call_entrypoint.d.ts","sourceRoot":"","sources":["../src/multi_call_entrypoint.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,KAAK,mBAAmB,EAAE,MAAM,4BAA4B,CAAC;AACtE,OAAO,EAAE,KAAK,YAAY,EAAmB,kBAAkB,EAAE,MAAM,sBAAsB,CAAC;AAC9F,OAAO,EAAE,KAAK,YAAY,EAA2B,MAAM,oBAAoB,CAAC;AAOhF;;GAEG;AACH,qBAAa,0BAA2B,YAAW,mBAAmB;IAElE,OAAO,CAAC,OAAO;IACf,OAAO,CAAC,OAAO;IACf,OAAO,CAAC,OAAO;gBAFP,OAAO,GAAE,YAAuD,EAChE,OAAO,GAAE,MAAyB,EAClC,OAAO,GAAE,MAAwB;IAG3C,wBAAwB,CAAC,UAAU,EAAE,YAAY,EAAE,GAAG,OAAO,CAAC,kBAAkB,CAAC;IAkBjF,OAAO,CAAC,gBAAgB;CAqDzB"}
|
|
@@ -1,84 +0,0 @@
|
|
|
1
|
-
import { PackedArguments, TxExecutionRequest } from '@aztec/circuit-types';
|
|
2
|
-
import { FunctionData, TxContext } from '@aztec/circuits.js';
|
|
3
|
-
import { encodeArguments } from '@aztec/foundation/abi';
|
|
4
|
-
import { getCanonicalMultiCallEntrypointAddress } from '@aztec/protocol-contracts/multi-call-entrypoint';
|
|
5
|
-
import { DEFAULT_CHAIN_ID, DEFAULT_VERSION } from './constants.js';
|
|
6
|
-
import { buildAppPayload } from './entrypoint_payload.js';
|
|
7
|
-
/**
|
|
8
|
-
* Implementation for an entrypoint interface that can execute multiple function calls in a single transaction
|
|
9
|
-
*/
|
|
10
|
-
export class DefaultMultiCallEntrypoint {
|
|
11
|
-
constructor(address = getCanonicalMultiCallEntrypointAddress(), chainId = DEFAULT_CHAIN_ID, version = DEFAULT_VERSION) {
|
|
12
|
-
this.address = address;
|
|
13
|
-
this.chainId = chainId;
|
|
14
|
-
this.version = version;
|
|
15
|
-
}
|
|
16
|
-
createTxExecutionRequest(executions) {
|
|
17
|
-
const { payload: appPayload, packedArguments: appPackedArguments } = buildAppPayload(executions);
|
|
18
|
-
const abi = this.getEntrypointAbi();
|
|
19
|
-
const entrypointPackedArgs = PackedArguments.fromArgs(encodeArguments(abi, [appPayload]));
|
|
20
|
-
const txRequest = TxExecutionRequest.from({
|
|
21
|
-
argsHash: entrypointPackedArgs.hash,
|
|
22
|
-
origin: this.address,
|
|
23
|
-
functionData: FunctionData.fromAbi(abi),
|
|
24
|
-
txContext: TxContext.empty(this.chainId, this.version),
|
|
25
|
-
packedArguments: [...appPackedArguments, entrypointPackedArgs],
|
|
26
|
-
authWitnesses: [],
|
|
27
|
-
});
|
|
28
|
-
return Promise.resolve(txRequest);
|
|
29
|
-
}
|
|
30
|
-
getEntrypointAbi() {
|
|
31
|
-
return {
|
|
32
|
-
name: 'entrypoint',
|
|
33
|
-
isInitializer: false,
|
|
34
|
-
functionType: 'secret',
|
|
35
|
-
isInternal: false,
|
|
36
|
-
parameters: [
|
|
37
|
-
{
|
|
38
|
-
name: 'app_payload',
|
|
39
|
-
type: {
|
|
40
|
-
kind: 'struct',
|
|
41
|
-
path: 'authwit::entrypoint::app::AppPayload',
|
|
42
|
-
fields: [
|
|
43
|
-
{
|
|
44
|
-
name: 'function_calls',
|
|
45
|
-
type: {
|
|
46
|
-
kind: 'array',
|
|
47
|
-
length: 4,
|
|
48
|
-
type: {
|
|
49
|
-
kind: 'struct',
|
|
50
|
-
path: 'authwit::entrypoint::function_call::FunctionCall',
|
|
51
|
-
fields: [
|
|
52
|
-
{ name: 'args_hash', type: { kind: 'field' } },
|
|
53
|
-
{
|
|
54
|
-
name: 'function_selector',
|
|
55
|
-
type: {
|
|
56
|
-
kind: 'struct',
|
|
57
|
-
path: 'authwit::aztec::protocol_types::abis::function_selector::FunctionSelector',
|
|
58
|
-
fields: [{ name: 'inner', type: { kind: 'integer', sign: 'unsigned', width: 32 } }],
|
|
59
|
-
},
|
|
60
|
-
},
|
|
61
|
-
{
|
|
62
|
-
name: 'target_address',
|
|
63
|
-
type: {
|
|
64
|
-
kind: 'struct',
|
|
65
|
-
path: 'authwit::aztec::protocol_types::address::AztecAddress',
|
|
66
|
-
fields: [{ name: 'inner', type: { kind: 'field' } }],
|
|
67
|
-
},
|
|
68
|
-
},
|
|
69
|
-
{ name: 'is_public', type: { kind: 'boolean' } },
|
|
70
|
-
],
|
|
71
|
-
},
|
|
72
|
-
},
|
|
73
|
-
},
|
|
74
|
-
{ name: 'nonce', type: { kind: 'field' } },
|
|
75
|
-
],
|
|
76
|
-
},
|
|
77
|
-
visibility: 'public',
|
|
78
|
-
},
|
|
79
|
-
],
|
|
80
|
-
returnTypes: [],
|
|
81
|
-
};
|
|
82
|
-
}
|
|
83
|
-
}
|
|
84
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibXVsdGlfY2FsbF9lbnRyeXBvaW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vc3JjL211bHRpX2NhbGxfZW50cnlwb2ludC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFDQSxPQUFPLEVBQXFCLGVBQWUsRUFBRSxrQkFBa0IsRUFBRSxNQUFNLHNCQUFzQixDQUFDO0FBQzlGLE9BQU8sRUFBcUIsWUFBWSxFQUFFLFNBQVMsRUFBRSxNQUFNLG9CQUFvQixDQUFDO0FBQ2hGLE9BQU8sRUFBb0IsZUFBZSxFQUFFLE1BQU0sdUJBQXVCLENBQUM7QUFDMUUsT0FBTyxFQUFFLHNDQUFzQyxFQUFFLE1BQU0saURBQWlELENBQUM7QUFFekcsT0FBTyxFQUFFLGdCQUFnQixFQUFFLGVBQWUsRUFBRSxNQUFNLGdCQUFnQixDQUFDO0FBQ25FLE9BQU8sRUFBRSxlQUFlLEVBQUUsTUFBTSx5QkFBeUIsQ0FBQztBQUUxRDs7R0FFRztBQUNILE1BQU0sT0FBTywwQkFBMEI7SUFDckMsWUFDVSxVQUF3QixzQ0FBc0MsRUFBRSxFQUNoRSxVQUFrQixnQkFBZ0IsRUFDbEMsVUFBa0IsZUFBZTtRQUZqQyxZQUFPLEdBQVAsT0FBTyxDQUF5RDtRQUNoRSxZQUFPLEdBQVAsT0FBTyxDQUEyQjtRQUNsQyxZQUFPLEdBQVAsT0FBTyxDQUEwQjtJQUN4QyxDQUFDO0lBRUosd0JBQXdCLENBQUMsVUFBMEI7UUFDakQsTUFBTSxFQUFFLE9BQU8sRUFBRSxVQUFVLEVBQUUsZUFBZSxFQUFFLGtCQUFrQixFQUFFLEdBQUcsZUFBZSxDQUFDLFVBQVUsQ0FBQyxDQUFDO1FBRWpHLE1BQU0sR0FBRyxHQUFHLElBQUksQ0FBQyxnQkFBZ0IsRUFBRSxDQUFDO1FBQ3BDLE1BQU0sb0JBQW9CLEdBQUcsZUFBZSxDQUFDLFFBQVEsQ0FBQyxlQUFlLENBQUMsR0FBRyxFQUFFLENBQUMsVUFBVSxDQUFDLENBQUMsQ0FBQyxDQUFDO1FBRTFGLE1BQU0sU0FBUyxHQUFHLGtCQUFrQixDQUFDLElBQUksQ0FBQztZQUN4QyxRQUFRLEVBQUUsb0JBQW9CLENBQUMsSUFBSTtZQUNuQyxNQUFNLEVBQUUsSUFBSSxDQUFDLE9BQU87WUFDcEIsWUFBWSxFQUFFLFlBQVksQ0FBQyxPQUFPLENBQUMsR0FBRyxDQUFDO1lBQ3ZDLFNBQVMsRUFBRSxTQUFTLENBQUMsS0FBSyxDQUFDLElBQUksQ0FBQyxPQUFPLEVBQUUsSUFBSSxDQUFDLE9BQU8sQ0FBQztZQUN0RCxlQUFlLEVBQUUsQ0FBQyxHQUFHLGtCQUFrQixFQUFFLG9CQUFvQixDQUFDO1lBQzlELGFBQWEsRUFBRSxFQUFFO1NBQ2xCLENBQUMsQ0FBQztRQUVILE9BQU8sT0FBTyxDQUFDLE9BQU8sQ0FBQyxTQUFTLENBQUMsQ0FBQztJQUNwQyxDQUFDO0lBRU8sZ0JBQWdCO1FBQ3RCLE9BQU87WUFDTCxJQUFJLEVBQUUsWUFBWTtZQUNsQixhQUFhLEVBQUUsS0FBSztZQUNwQixZQUFZLEVBQUUsUUFBUTtZQUN0QixVQUFVLEVBQUUsS0FBSztZQUNqQixVQUFVLEVBQUU7Z0JBQ1Y7b0JBQ0UsSUFBSSxFQUFFLGFBQWE7b0JBQ25CLElBQUksRUFBRTt3QkFDSixJQUFJLEVBQUUsUUFBUTt3QkFDZCxJQUFJLEVBQUUsc0NBQXNDO3dCQUM1QyxNQUFNLEVBQUU7NEJBQ047Z0NBQ0UsSUFBSSxFQUFFLGdCQUFnQjtnQ0FDdEIsSUFBSSxFQUFFO29DQUNKLElBQUksRUFBRSxPQUFPO29DQUNiLE1BQU0sRUFBRSxDQUFDO29DQUNULElBQUksRUFBRTt3Q0FDSixJQUFJLEVBQUUsUUFBUTt3Q0FDZCxJQUFJLEVBQUUsa0RBQWtEO3dDQUN4RCxNQUFNLEVBQUU7NENBQ04sRUFBRSxJQUFJLEVBQUUsV0FBVyxFQUFFLElBQUksRUFBRSxFQUFFLElBQUksRUFBRSxPQUFPLEVBQUUsRUFBRTs0Q0FDOUM7Z0RBQ0UsSUFBSSxFQUFFLG1CQUFtQjtnREFDekIsSUFBSSxFQUFFO29EQUNKLElBQUksRUFBRSxRQUFRO29EQUNkLElBQUksRUFBRSwyRUFBMkU7b0RBQ2pGLE1BQU0sRUFBRSxDQUFDLEVBQUUsSUFBSSxFQUFFLE9BQU8sRUFBRSxJQUFJLEVBQUUsRUFBRSxJQUFJLEVBQUUsU0FBUyxFQUFFLElBQUksRUFBRSxVQUFVLEVBQUUsS0FBSyxFQUFFLEVBQUUsRUFBRSxFQUFFLENBQUM7aURBQ3BGOzZDQUNGOzRDQUNEO2dEQUNFLElBQUksRUFBRSxnQkFBZ0I7Z0RBQ3RCLElBQUksRUFBRTtvREFDSixJQUFJLEVBQUUsUUFBUTtvREFDZCxJQUFJLEVBQUUsdURBQXVEO29EQUM3RCxNQUFNLEVBQUUsQ0FBQyxFQUFFLElBQUksRUFBRSxPQUFPLEVBQUUsSUFBSSxFQUFFLEVBQUUsSUFBSSxFQUFFLE9BQU8sRUFBRSxFQUFFLENBQUM7aURBQ3JEOzZDQUNGOzRDQUNELEVBQUUsSUFBSSxFQUFFLFdBQVcsRUFBRSxJQUFJLEVBQUUsRUFBRSxJQUFJLEVBQUUsU0FBUyxFQUFFLEVBQUU7eUNBQ2pEO3FDQUNGO2lDQUNGOzZCQUNGOzRCQUNELEVBQUUsSUFBSSxFQUFFLE9BQU8sRUFBRSxJQUFJLEVBQUUsRUFBRSxJQUFJLEVBQUUsT0FBTyxFQUFFLEVBQUU7eUJBQzNDO3FCQUNGO29CQUNELFVBQVUsRUFBRSxRQUFRO2lCQUNyQjthQUNGO1lBQ0QsV0FBVyxFQUFFLEVBQUU7U0FDRCxDQUFDO0lBQ25CLENBQUM7Q0FDRiJ9
|
|
@@ -1,121 +0,0 @@
|
|
|
1
|
-
import { type FeeOptions } from '@aztec/aztec.js/entrypoint';
|
|
2
|
-
import { Fr } from '@aztec/aztec.js/fields';
|
|
3
|
-
import { type FunctionCall, PackedArguments, emptyFunctionCall } from '@aztec/circuit-types';
|
|
4
|
-
import { type AztecAddress } from '@aztec/circuits.js';
|
|
5
|
-
import { padArrayEnd } from '@aztec/foundation/collection';
|
|
6
|
-
import { pedersenHash } from '@aztec/foundation/crypto';
|
|
7
|
-
|
|
8
|
-
// These must match the values defined in:
|
|
9
|
-
// - noir-projects/aztec-nr/aztec/src/entrypoint/app.nr
|
|
10
|
-
const ACCOUNT_MAX_CALLS = 4;
|
|
11
|
-
// - and noir-projects/aztec-nr/aztec/src/entrypoint/fee.nr
|
|
12
|
-
const FEE_MAX_CALLS = 2;
|
|
13
|
-
|
|
14
|
-
/** Encoded function call for account contract entrypoint */
|
|
15
|
-
type EntrypointFunctionCall = {
|
|
16
|
-
// eslint-disable-next-line camelcase
|
|
17
|
-
/** Arguments hash for the call */
|
|
18
|
-
args_hash: Fr;
|
|
19
|
-
// eslint-disable-next-line camelcase
|
|
20
|
-
/** Selector of the function to call */
|
|
21
|
-
function_selector: Fr;
|
|
22
|
-
// eslint-disable-next-line camelcase
|
|
23
|
-
/** Address of the contract to call */
|
|
24
|
-
target_address: Fr;
|
|
25
|
-
// eslint-disable-next-line camelcase
|
|
26
|
-
/** Whether the function is public or private */
|
|
27
|
-
is_public: boolean;
|
|
28
|
-
};
|
|
29
|
-
|
|
30
|
-
/** Encoded payload for the account contract entrypoint */
|
|
31
|
-
type EntrypointPayload = {
|
|
32
|
-
// eslint-disable-next-line camelcase
|
|
33
|
-
/** Encoded function calls to execute */
|
|
34
|
-
function_calls: EntrypointFunctionCall[];
|
|
35
|
-
/** A nonce for replay protection */
|
|
36
|
-
nonce: Fr;
|
|
37
|
-
};
|
|
38
|
-
|
|
39
|
-
/** Represents a generic payload to be executed in the context of an account contract */
|
|
40
|
-
export type PayloadWithArguments = {
|
|
41
|
-
/** The payload to be run */
|
|
42
|
-
payload: EntrypointPayload;
|
|
43
|
-
/** The packed arguments for the function calls */
|
|
44
|
-
packedArguments: PackedArguments[];
|
|
45
|
-
};
|
|
46
|
-
|
|
47
|
-
/**
|
|
48
|
-
* Builds a payload to be sent to the account contract
|
|
49
|
-
* @param calls - The function calls to run
|
|
50
|
-
* @param maxCalls - The maximum number of call expected to be run. Used for padding
|
|
51
|
-
* @returns A payload object and packed arguments
|
|
52
|
-
*/
|
|
53
|
-
function buildPayload(calls: FunctionCall[], maxCalls: number): PayloadWithArguments {
|
|
54
|
-
const nonce = Fr.random();
|
|
55
|
-
|
|
56
|
-
const paddedCalls = padArrayEnd(calls, emptyFunctionCall(), maxCalls);
|
|
57
|
-
const packedArguments: PackedArguments[] = [];
|
|
58
|
-
for (const call of paddedCalls) {
|
|
59
|
-
packedArguments.push(PackedArguments.fromArgs(call.args));
|
|
60
|
-
}
|
|
61
|
-
|
|
62
|
-
const formattedCalls: EntrypointFunctionCall[] = paddedCalls.map((call, index) => ({
|
|
63
|
-
// eslint-disable-next-line camelcase
|
|
64
|
-
args_hash: packedArguments[index].hash,
|
|
65
|
-
// eslint-disable-next-line camelcase
|
|
66
|
-
function_selector: call.functionData.selector.toField(),
|
|
67
|
-
// eslint-disable-next-line camelcase
|
|
68
|
-
target_address: call.to.toField(),
|
|
69
|
-
// eslint-disable-next-line camelcase
|
|
70
|
-
is_public: !call.functionData.isPrivate,
|
|
71
|
-
}));
|
|
72
|
-
|
|
73
|
-
return {
|
|
74
|
-
payload: {
|
|
75
|
-
// eslint-disable-next-line camelcase
|
|
76
|
-
function_calls: formattedCalls,
|
|
77
|
-
nonce,
|
|
78
|
-
},
|
|
79
|
-
packedArguments,
|
|
80
|
-
};
|
|
81
|
-
}
|
|
82
|
-
|
|
83
|
-
/** builds the payload for a Dapp entrypoint */
|
|
84
|
-
export function buildDappPayload(call: FunctionCall): PayloadWithArguments {
|
|
85
|
-
return buildPayload([call], 1);
|
|
86
|
-
}
|
|
87
|
-
|
|
88
|
-
/** Assembles an entrypoint app payload from a set of private and public function calls */
|
|
89
|
-
export function buildAppPayload(calls: FunctionCall[]): PayloadWithArguments {
|
|
90
|
-
return buildPayload(calls, ACCOUNT_MAX_CALLS);
|
|
91
|
-
}
|
|
92
|
-
|
|
93
|
-
/** Creates the payload for paying the fee for a transaction */
|
|
94
|
-
export async function buildFeePayload(feeOpts?: FeeOptions): Promise<PayloadWithArguments> {
|
|
95
|
-
const calls = feeOpts ? await feeOpts.paymentMethod.getFunctionCalls(new Fr(feeOpts.maxFee)) : [];
|
|
96
|
-
return buildPayload(calls, FEE_MAX_CALLS);
|
|
97
|
-
}
|
|
98
|
-
|
|
99
|
-
// TODO (dogfooding) change all of these names app/dapp/fee/payload and generator indices for all of them
|
|
100
|
-
/** Hashes a payload to a 32-byte buffer */
|
|
101
|
-
export function hashPayload(payload: EntrypointPayload, generatorIndex: number) {
|
|
102
|
-
return pedersenHash(flattenPayload(payload), generatorIndex);
|
|
103
|
-
}
|
|
104
|
-
|
|
105
|
-
/** Hash the payload for a dapp */
|
|
106
|
-
export function hashDappPayload(payload: EntrypointPayload, userAddress: AztecAddress, generatorIndex: number) {
|
|
107
|
-
return pedersenHash([...flattenPayload(payload), userAddress], generatorIndex);
|
|
108
|
-
}
|
|
109
|
-
|
|
110
|
-
/** Flattens an payload */
|
|
111
|
-
function flattenPayload(payload: EntrypointPayload) {
|
|
112
|
-
return [
|
|
113
|
-
...payload.function_calls.flatMap(call => [
|
|
114
|
-
call.args_hash,
|
|
115
|
-
call.function_selector,
|
|
116
|
-
call.target_address,
|
|
117
|
-
new Fr(call.is_public),
|
|
118
|
-
]),
|
|
119
|
-
payload.nonce,
|
|
120
|
-
];
|
|
121
|
-
}
|
|
@@ -1,91 +0,0 @@
|
|
|
1
|
-
import { type EntrypointInterface } from '@aztec/aztec.js/entrypoint';
|
|
2
|
-
import { type FunctionCall, PackedArguments, TxExecutionRequest } from '@aztec/circuit-types';
|
|
3
|
-
import { type AztecAddress, FunctionData, TxContext } from '@aztec/circuits.js';
|
|
4
|
-
import { type FunctionAbi, encodeArguments } from '@aztec/foundation/abi';
|
|
5
|
-
import { getCanonicalMultiCallEntrypointAddress } from '@aztec/protocol-contracts/multi-call-entrypoint';
|
|
6
|
-
|
|
7
|
-
import { DEFAULT_CHAIN_ID, DEFAULT_VERSION } from './constants.js';
|
|
8
|
-
import { buildAppPayload } from './entrypoint_payload.js';
|
|
9
|
-
|
|
10
|
-
/**
|
|
11
|
-
* Implementation for an entrypoint interface that can execute multiple function calls in a single transaction
|
|
12
|
-
*/
|
|
13
|
-
export class DefaultMultiCallEntrypoint implements EntrypointInterface {
|
|
14
|
-
constructor(
|
|
15
|
-
private address: AztecAddress = getCanonicalMultiCallEntrypointAddress(),
|
|
16
|
-
private chainId: number = DEFAULT_CHAIN_ID,
|
|
17
|
-
private version: number = DEFAULT_VERSION,
|
|
18
|
-
) {}
|
|
19
|
-
|
|
20
|
-
createTxExecutionRequest(executions: FunctionCall[]): Promise<TxExecutionRequest> {
|
|
21
|
-
const { payload: appPayload, packedArguments: appPackedArguments } = buildAppPayload(executions);
|
|
22
|
-
|
|
23
|
-
const abi = this.getEntrypointAbi();
|
|
24
|
-
const entrypointPackedArgs = PackedArguments.fromArgs(encodeArguments(abi, [appPayload]));
|
|
25
|
-
|
|
26
|
-
const txRequest = TxExecutionRequest.from({
|
|
27
|
-
argsHash: entrypointPackedArgs.hash,
|
|
28
|
-
origin: this.address,
|
|
29
|
-
functionData: FunctionData.fromAbi(abi),
|
|
30
|
-
txContext: TxContext.empty(this.chainId, this.version),
|
|
31
|
-
packedArguments: [...appPackedArguments, entrypointPackedArgs],
|
|
32
|
-
authWitnesses: [],
|
|
33
|
-
});
|
|
34
|
-
|
|
35
|
-
return Promise.resolve(txRequest);
|
|
36
|
-
}
|
|
37
|
-
|
|
38
|
-
private getEntrypointAbi() {
|
|
39
|
-
return {
|
|
40
|
-
name: 'entrypoint',
|
|
41
|
-
isInitializer: false,
|
|
42
|
-
functionType: 'secret',
|
|
43
|
-
isInternal: false,
|
|
44
|
-
parameters: [
|
|
45
|
-
{
|
|
46
|
-
name: 'app_payload',
|
|
47
|
-
type: {
|
|
48
|
-
kind: 'struct',
|
|
49
|
-
path: 'authwit::entrypoint::app::AppPayload',
|
|
50
|
-
fields: [
|
|
51
|
-
{
|
|
52
|
-
name: 'function_calls',
|
|
53
|
-
type: {
|
|
54
|
-
kind: 'array',
|
|
55
|
-
length: 4,
|
|
56
|
-
type: {
|
|
57
|
-
kind: 'struct',
|
|
58
|
-
path: 'authwit::entrypoint::function_call::FunctionCall',
|
|
59
|
-
fields: [
|
|
60
|
-
{ name: 'args_hash', type: { kind: 'field' } },
|
|
61
|
-
{
|
|
62
|
-
name: 'function_selector',
|
|
63
|
-
type: {
|
|
64
|
-
kind: 'struct',
|
|
65
|
-
path: 'authwit::aztec::protocol_types::abis::function_selector::FunctionSelector',
|
|
66
|
-
fields: [{ name: 'inner', type: { kind: 'integer', sign: 'unsigned', width: 32 } }],
|
|
67
|
-
},
|
|
68
|
-
},
|
|
69
|
-
{
|
|
70
|
-
name: 'target_address',
|
|
71
|
-
type: {
|
|
72
|
-
kind: 'struct',
|
|
73
|
-
path: 'authwit::aztec::protocol_types::address::AztecAddress',
|
|
74
|
-
fields: [{ name: 'inner', type: { kind: 'field' } }],
|
|
75
|
-
},
|
|
76
|
-
},
|
|
77
|
-
{ name: 'is_public', type: { kind: 'boolean' } },
|
|
78
|
-
],
|
|
79
|
-
},
|
|
80
|
-
},
|
|
81
|
-
},
|
|
82
|
-
{ name: 'nonce', type: { kind: 'field' } },
|
|
83
|
-
],
|
|
84
|
-
},
|
|
85
|
-
visibility: 'public',
|
|
86
|
-
},
|
|
87
|
-
],
|
|
88
|
-
returnTypes: [],
|
|
89
|
-
} as FunctionAbi;
|
|
90
|
-
}
|
|
91
|
-
}
|