@aztec/cli 0.13.1 → 0.14.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/github.d.ts +4 -0
- package/dest/github.d.ts.map +1 -0
- package/dest/github.js +4 -0
- package/dest/index.d.ts.map +1 -1
- package/dest/index.js +22 -4
- package/dest/unbox.d.ts.map +1 -1
- package/dest/unbox.js +2 -4
- package/dest/update/common.d.ts +17 -0
- package/dest/update/common.d.ts.map +1 -0
- package/dest/update/common.js +2 -0
- package/dest/update/noir.d.ts +10 -0
- package/dest/update/noir.d.ts.map +1 -0
- package/dest/update/noir.js +63 -0
- package/dest/update/npm.d.ts +32 -0
- package/dest/update/npm.d.ts.map +1 -0
- package/dest/update/npm.js +106 -0
- package/dest/update/update.d.ts +3 -0
- package/dest/update/update.d.ts.map +1 -0
- package/dest/update/update.js +93 -0
- package/dest/utils.d.ts +6 -0
- package/dest/utils.d.ts.map +1 -1
- package/dest/utils.js +27 -2
- package/package.json +9 -8
- package/src/github.ts +3 -0
- package/src/index.ts +25 -3
- package/src/unbox.ts +2 -3
- package/src/update/common.ts +16 -0
- package/src/update/noir.ts +79 -0
- package/src/update/npm.ts +129 -0
- package/src/update/update.ts +126 -0
- package/src/utils.ts +29 -1
|
@@ -0,0 +1,93 @@
|
|
|
1
|
+
import { relative, resolve } from 'path';
|
|
2
|
+
import { coerce, gt, lt, parse } from 'semver';
|
|
3
|
+
import { createCompatibleClient } from '../client.js';
|
|
4
|
+
import { GITHUB_TAG_PREFIX } from '../github.js';
|
|
5
|
+
import { updateAztecNr } from './noir.js';
|
|
6
|
+
import { getNewestVersion as getLatestVersion, readPackageJson, updateAztecDeps, updateLockfile } from './npm.js';
|
|
7
|
+
const SANDBOX_PACKAGE = '@aztec/aztec-sandbox';
|
|
8
|
+
export async function update(projectPath, contracts, pxeUrl, sandboxVersion, log, debugLog) {
|
|
9
|
+
const targetSandboxVersion = sandboxVersion === 'latest' ? await getLatestVersion(SANDBOX_PACKAGE, 'latest') : parse(sandboxVersion);
|
|
10
|
+
if (!targetSandboxVersion) {
|
|
11
|
+
throw new Error(`Invalid aztec version ${sandboxVersion}`);
|
|
12
|
+
}
|
|
13
|
+
let currentSandboxVersion = await getNpmSandboxVersion(projectPath, log);
|
|
14
|
+
if (!currentSandboxVersion) {
|
|
15
|
+
currentSandboxVersion = await getRemoteSandboxVersion(pxeUrl, log, debugLog);
|
|
16
|
+
if (currentSandboxVersion && lt(currentSandboxVersion, targetSandboxVersion)) {
|
|
17
|
+
log(`
|
|
18
|
+
Sandbox is older than version ${targetSandboxVersion}. If running via docker-compose, follow update instructions:
|
|
19
|
+
https://docs.aztec.network/dev_docs/cli/updating
|
|
20
|
+
|
|
21
|
+
Once the sandbox is updated, run the \`aztec-cli update\` command again`);
|
|
22
|
+
return;
|
|
23
|
+
}
|
|
24
|
+
}
|
|
25
|
+
if (!currentSandboxVersion) {
|
|
26
|
+
throw new Error('Sandbox version could not be detected');
|
|
27
|
+
}
|
|
28
|
+
// sanity check
|
|
29
|
+
if (gt(currentSandboxVersion, targetSandboxVersion)) {
|
|
30
|
+
throw new Error('Local sandbox version is newer than latest version.');
|
|
31
|
+
}
|
|
32
|
+
const npmChanges = await updateAztecDeps(projectPath, targetSandboxVersion, log);
|
|
33
|
+
if (npmChanges.dependencies.length > 0) {
|
|
34
|
+
updateLockfile(projectPath, log);
|
|
35
|
+
}
|
|
36
|
+
const contractChanges = [];
|
|
37
|
+
for (const contract of contracts) {
|
|
38
|
+
try {
|
|
39
|
+
contractChanges.push(await updateAztecNr(resolve(projectPath, contract), `${GITHUB_TAG_PREFIX}-v${targetSandboxVersion.version}`, log));
|
|
40
|
+
}
|
|
41
|
+
catch (err) {
|
|
42
|
+
if (err instanceof Error && 'code' in err && err.code === 'ENOENT') {
|
|
43
|
+
log(`No Nargo.toml found in ${relative(process.cwd(), contract)}. Skipping...`);
|
|
44
|
+
process.exit(1);
|
|
45
|
+
}
|
|
46
|
+
throw err;
|
|
47
|
+
}
|
|
48
|
+
}
|
|
49
|
+
printChanges(npmChanges, log);
|
|
50
|
+
contractChanges.forEach(changes => {
|
|
51
|
+
printChanges(changes, log);
|
|
52
|
+
});
|
|
53
|
+
}
|
|
54
|
+
function printChanges(changes, log) {
|
|
55
|
+
log(`\nIn ${relative(process.cwd(), changes.file)}:`);
|
|
56
|
+
if (changes.dependencies.length === 0) {
|
|
57
|
+
log(' No changes');
|
|
58
|
+
}
|
|
59
|
+
else {
|
|
60
|
+
changes.dependencies.forEach(({ name, from, to }) => {
|
|
61
|
+
log(` Updated ${name} from ${from} to ${to}`);
|
|
62
|
+
});
|
|
63
|
+
}
|
|
64
|
+
}
|
|
65
|
+
async function getNpmSandboxVersion(projectPath, log) {
|
|
66
|
+
try {
|
|
67
|
+
const pkg = await readPackageJson(projectPath);
|
|
68
|
+
// use coerce instead of parse because it eliminates semver operators like ~ and ^
|
|
69
|
+
return coerce(pkg.dependencies?.[SANDBOX_PACKAGE]);
|
|
70
|
+
}
|
|
71
|
+
catch (err) {
|
|
72
|
+
if (err instanceof Error && 'code' in err && err.code === 'ENOENT') {
|
|
73
|
+
log(`No package.json found in ${projectPath}`);
|
|
74
|
+
process.exit(1);
|
|
75
|
+
}
|
|
76
|
+
throw err;
|
|
77
|
+
}
|
|
78
|
+
}
|
|
79
|
+
async function getRemoteSandboxVersion(pxeUrl, log, debugLog) {
|
|
80
|
+
try {
|
|
81
|
+
const client = await createCompatibleClient(pxeUrl, debugLog);
|
|
82
|
+
const nodeInfo = await client.getNodeInfo();
|
|
83
|
+
return parse(nodeInfo.sandboxVersion);
|
|
84
|
+
}
|
|
85
|
+
catch (err) {
|
|
86
|
+
if (err instanceof Error && err.message === 'fetch failed') {
|
|
87
|
+
log(`Could not connect to Sandbox running on ${pxeUrl}`);
|
|
88
|
+
process.exit(1);
|
|
89
|
+
}
|
|
90
|
+
throw err;
|
|
91
|
+
}
|
|
92
|
+
}
|
|
93
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidXBkYXRlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vc3JjL3VwZGF0ZS91cGRhdGUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBR0EsT0FBTyxFQUFFLFFBQVEsRUFBRSxPQUFPLEVBQUUsTUFBTSxNQUFNLENBQUM7QUFDekMsT0FBTyxFQUFVLE1BQU0sRUFBRSxFQUFFLEVBQUUsRUFBRSxFQUFFLEtBQUssRUFBRSxNQUFNLFFBQVEsQ0FBQztBQUV2RCxPQUFPLEVBQUUsc0JBQXNCLEVBQUUsTUFBTSxjQUFjLENBQUM7QUFDdEQsT0FBTyxFQUFFLGlCQUFpQixFQUFFLE1BQU0sY0FBYyxDQUFDO0FBRWpELE9BQU8sRUFBRSxhQUFhLEVBQUUsTUFBTSxXQUFXLENBQUM7QUFDMUMsT0FBTyxFQUFFLGdCQUFnQixJQUFJLGdCQUFnQixFQUFFLGVBQWUsRUFBRSxlQUFlLEVBQUUsY0FBYyxFQUFFLE1BQU0sVUFBVSxDQUFDO0FBRWxILE1BQU0sZUFBZSxHQUFHLHNCQUFzQixDQUFDO0FBRS9DLE1BQU0sQ0FBQyxLQUFLLFVBQVUsTUFBTSxDQUMxQixXQUFtQixFQUNuQixTQUFtQixFQUNuQixNQUFjLEVBQ2QsY0FBc0IsRUFDdEIsR0FBVSxFQUNWLFFBQXFCO0lBRXJCLE1BQU0sb0JBQW9CLEdBQ3hCLGNBQWMsS0FBSyxRQUFRLENBQUMsQ0FBQyxDQUFDLE1BQU0sZ0JBQWdCLENBQUMsZUFBZSxFQUFFLFFBQVEsQ0FBQyxDQUFDLENBQUMsQ0FBQyxLQUFLLENBQUMsY0FBYyxDQUFDLENBQUM7SUFFMUcsSUFBSSxDQUFDLG9CQUFvQixFQUFFO1FBQ3pCLE1BQU0sSUFBSSxLQUFLLENBQUMseUJBQXlCLGNBQWMsRUFBRSxDQUFDLENBQUM7S0FDNUQ7SUFFRCxJQUFJLHFCQUFxQixHQUFHLE1BQU0sb0JBQW9CLENBQUMsV0FBVyxFQUFFLEdBQUcsQ0FBQyxDQUFDO0lBRXpFLElBQUksQ0FBQyxxQkFBcUIsRUFBRTtRQUMxQixxQkFBcUIs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
|
package/dest/utils.d.ts
CHANGED
|
@@ -158,5 +158,11 @@ export declare function parseField(field: string): Fr;
|
|
|
158
158
|
* @returns An array of Frs.
|
|
159
159
|
*/
|
|
160
160
|
export declare function parseFields(fields: string[]): Fr[];
|
|
161
|
+
/**
|
|
162
|
+
* Updates a file in place atomically.
|
|
163
|
+
* @param filePath - Path to file
|
|
164
|
+
* @param contents - New contents to write
|
|
165
|
+
*/
|
|
166
|
+
export declare function atomicUpdateFile(filePath: string, contents: string): Promise<void>;
|
|
161
167
|
export {};
|
|
162
168
|
//# sourceMappingURL=utils.d.ts.map
|
package/dest/utils.d.ts.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"utils.d.ts","sourceRoot":"","sources":["../src/utils.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,YAAY,EAAE,UAAU,EAAE,EAAE,EAAE,gBAAgB,EAAE,cAAc,EAAE,GAAG,EAAE,KAAK,EAAE,MAAM,EAAE,MAAM,iBAAiB,CAAC;AAErH,OAAO,EAAE,gBAAgB,EAAE,MAAM,uBAAuB,CAAC;AACzD,OAAO,EAAE,WAAW,EAAE,KAAK,EAAE,MAAM,uBAAuB,CAAC;AAa3D,OAAO,EAAE,KAAK,EAAE,MAAM,cAAc,CAAC;AAQrC;;GAEG;AACH,UAAU,aAAa;IACrB,CAAC,GAAG,EAAE,MAAM,GAAG,gBAAgB,CAAC;CACjC;AAED;;;;;GAKG;AACH,wBAAgB,mBAAmB,CAAC,QAAQ,EAAE,gBAAgB,EAAE,MAAM,EAAE,MAAM,oDAM7E;AAED;;;;;;GAMG;AACH,wBAAsB,oBAAoB,CACxC,MAAM,EAAE,MAAM,EACd,MAAM,EAAE,MAAM,EACd,UAAU,EAAE,MAAM,EAClB,QAAQ,EAAE,MAAM,EAChB,WAAW,EAAE,WAAW,wDA2BzB;AAED;;;GAGG;AACH,wBAAsB,2BAA2B,2BAGhD;AAED;;;;GAIG;AACH,wBAAsB,mBAAmB,CAAC,OAAO,EAAE,MAAM,EAAE,GAAG,EAAE,KAAK,6BAuBpE;AAED;;;;;;GAMG;AACH,wBAAsB,WAAW,CAAC,GAAG,EAAE,GAAG,EAAE,KAAK,CAAC,EAAE,MAAM,yBAgBzD;AAED;;;;;;;GAOG;AACH,wBAAsB,MAAM,CAAC,YAAY,EAAE,MAAM,EAAE,YAAY,EAAE,MAAM,EAAE,aAAa,EAAE,MAAM,EAAE,EAAE,GAAG,EAAE,KAAK;;;GAM3G;AAED;;;;GAIG;AACH,eAAO,MAAM,eAAe,QAAS,MAAM,WAK1C,CAAC;AAEF;;;;GAIG;AACH,wBAAgB,sBAAsB,CAAC,GAAG,EAAE,MAAM,GAAG,EAAE,CActD;AAED;;;;;GAKG;AACH,wBAAgB,iBAAiB,CAAC,OAAO,EAAE,MAAM,GAAG,YAAY,CAM/D;AAED;;;;;GAKG;AACH,wBAAgB,oBAAoB,CAAC,OAAO,EAAE,MAAM,GAAG,UAAU,CAMhE;AAED;;;;;GAKG;AACH,wBAAgB,yBAAyB,CAAC,OAAO,EAAE,MAAM,GAAG,YAAY,GAAG,SAAS,CAKnF;AAED;;;;;GAKG;AACH,wBAAgB,kBAAkB,CAAC,KAAK,EAAE,MAAM,GAAG,KAAK,GAAG,SAAS,CAKnE;AAED;;;;;GAKG;AACH,wBAAgB,qBAAqB,CAAC,QAAQ,EAAE,MAAM,GAAG,gBAAgB,GAAG,SAAS,CASpF;AAED;;;;;;GAMG;AACH,wBAAgB,oBAAoB,CAAC,KAAK,EAAE,MAAM,GAAG,MAAM,GAAG,SAAS,CAStE;AAED;;;;;GAKG;AACH,wBAAgB,WAAW,CAAC,MAAM,EAAE,MAAM,GAAG,MAAM,CAMlD;AAED;;;;;;GAMG;AACH,wBAAgB,mBAAmB,CAAC,MAAM,EAAE,MAAM,GAAG,MAAM,GAAG,SAAS,CAKtE;AAED;;;;;GAKG;AACH,wBAAgB,cAAc,CAAC,SAAS,EAAE,MAAM,GAAG,KAAK,CAMvD;AAED;;;;;GAKG;AACH,wBAAgB,mBAAmB,CAAC,OAAO,EAAE,MAAM,GAAG,EAAE,CAMvD;AAED;;;;;GAKG;AACH,wBAAgB,eAAe,CAAC,UAAU,EAAE,MAAM,GAAG,cAAc,CAYlE;AAED;;;;;GAKG;AACH,wBAAgB,UAAU,CAAC,KAAK,EAAE,MAAM,GAAG,EAAE,CAyB5C;AAED;;;;GAIG;AACH,wBAAgB,WAAW,CAAC,MAAM,EAAE,MAAM,EAAE,GAAG,EAAE,EAAE,CAElD"}
|
|
1
|
+
{"version":3,"file":"utils.d.ts","sourceRoot":"","sources":["../src/utils.ts"],"names":[],"mappings":"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"}
|
package/dest/utils.js
CHANGED
|
@@ -2,7 +2,7 @@ import { AztecAddress, EthAddress, Fr, FunctionSelector, GrumpkinScalar, Point,
|
|
|
2
2
|
import { createEthereumChain, deployL1Contracts } from '@aztec/ethereum';
|
|
3
3
|
import { ContractDeploymentEmitterAbi, ContractDeploymentEmitterBytecode, InboxAbi, InboxBytecode, OutboxAbi, OutboxBytecode, RegistryAbi, RegistryBytecode, RollupAbi, RollupBytecode, } from '@aztec/l1-artifacts';
|
|
4
4
|
import { LogId } from '@aztec/types';
|
|
5
|
-
import { InvalidArgumentError } from 'commander';
|
|
5
|
+
import { CommanderError, InvalidArgumentError } from 'commander';
|
|
6
6
|
import fs from 'fs';
|
|
7
7
|
import { mnemonicToAccount, privateKeyToAccount } from 'viem/accounts';
|
|
8
8
|
import { encodeArgs } from './encoding.js';
|
|
@@ -355,4 +355,29 @@ export function parseField(field) {
|
|
|
355
355
|
export function parseFields(fields) {
|
|
356
356
|
return fields.map(parseField);
|
|
357
357
|
}
|
|
358
|
-
|
|
358
|
+
/**
|
|
359
|
+
* Updates a file in place atomically.
|
|
360
|
+
* @param filePath - Path to file
|
|
361
|
+
* @param contents - New contents to write
|
|
362
|
+
*/
|
|
363
|
+
export async function atomicUpdateFile(filePath, contents) {
|
|
364
|
+
const tmpFilepath = filePath + '.tmp';
|
|
365
|
+
try {
|
|
366
|
+
await fs.promises.writeFile(tmpFilepath, contents, {
|
|
367
|
+
// let's crash if the tmp file already exists
|
|
368
|
+
flag: 'wx',
|
|
369
|
+
});
|
|
370
|
+
await fs.promises.rename(tmpFilepath, filePath);
|
|
371
|
+
}
|
|
372
|
+
catch (e) {
|
|
373
|
+
if (e instanceof Error && 'code' in e && e.code === 'EEXIST') {
|
|
374
|
+
const commanderError = new CommanderError(1, e.code, `Temporary file already exists: ${tmpFilepath}. Delete this file and try again.`);
|
|
375
|
+
commanderError.nestedError = e.message;
|
|
376
|
+
throw commanderError;
|
|
377
|
+
}
|
|
378
|
+
else {
|
|
379
|
+
throw e;
|
|
380
|
+
}
|
|
381
|
+
}
|
|
382
|
+
}
|
|
383
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidXRpbHMuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi9zcmMvdXRpbHMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFlBQVksRUFBRSxVQUFVLEVBQUUsRUFBRSxFQUFFLGdCQUFnQixFQUFFLGNBQWMsRUFBTyxLQUFLLEVBQUUsTUFBTSxFQUFFLE1BQU0saUJBQWlCLENBQUM7QUFDckgsT0FBTyxFQUFvQyxtQkFBbUIsRUFBRSxpQkFBaUIsRUFBRSxNQUFNLGlCQUFpQixDQUFDO0FBRzNHLE9BQU8sRUFDTCw0QkFBNEIsRUFDNUIsaUNBQWlDLEVBQ2pDLFFBQVEsRUFDUixhQUFhLEVBQ2IsU0FBUyxFQUNULGNBQWMsRUFDZCxXQUFXLEVBQ1gsZ0JBQWdCLEVBQ2hCLFNBQVMsRUFDVCxjQUFjLEdBQ2YsTUFBTSxxQkFBcUIsQ0FBQztBQUM3QixPQUFPLEVBQUUsS0FBSyxFQUFFLE1BQU0sY0FBYyxDQUFDO0FBRXJDLE9BQU8sRUFBRSxjQUFjLEVBQUUsb0JBQW9CLEVBQUUsTUFBTSxXQUFXLENBQUM7QUFDakUsT0FBTyxFQUFFLE1BQU0sSUFBSSxDQUFDO0FBQ3BCLE9BQU8sRUFBRSxpQkFBaUIsRUFBRSxtQkFBbUIsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUV2RSxPQUFPLEVBQUUsVUFBVSxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBUzNDOzs7OztHQUtHO0FBQ0gsTUFBTSxVQUFVLG1CQUFtQixDQUFDLFFBQTBCLEVBQUUsTUFBYztJQUM1RSxNQUFNLEVBQUUsR0FBRyxRQUFRLENBQUMsU0FBUyxDQUFDLElBQUksQ0FBQyxDQUFDLEVBQUUsSUFBSSxFQUFFLEVBQUUsRUFBRSxDQUFDLElBQUksS0FBSyxNQUFNLENBQUMsQ0FBQztJQUNsRSxJQUFJLENBQUMsRUFBRSxFQUFFO1FBQ1AsTUFBTSxLQUFLLENBQUMsWUFBWSxNQUFNLDZCQUE2QixDQUFDLENBQUM7S0FDOUQ7SUFDRCxPQUFPLEVBQUUsQ0FBQztBQUNaLENB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
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@aztec/cli",
|
|
3
|
-
"version": "0.
|
|
3
|
+
"version": "0.14.0",
|
|
4
4
|
"type": "module",
|
|
5
5
|
"main": "./dest/index.js",
|
|
6
6
|
"bin": {
|
|
@@ -34,14 +34,15 @@
|
|
|
34
34
|
"rootDir": "./src"
|
|
35
35
|
},
|
|
36
36
|
"dependencies": {
|
|
37
|
-
"@aztec/aztec.js": "0.
|
|
38
|
-
"@aztec/ethereum": "0.
|
|
39
|
-
"@aztec/foundation": "0.
|
|
40
|
-
"@aztec/l1-artifacts": "0.
|
|
41
|
-
"@aztec/noir-compiler": "0.
|
|
42
|
-
"@aztec/noir-contracts": "0.
|
|
43
|
-
"@aztec/types": "0.
|
|
37
|
+
"@aztec/aztec.js": "0.14.0",
|
|
38
|
+
"@aztec/ethereum": "0.14.0",
|
|
39
|
+
"@aztec/foundation": "0.14.0",
|
|
40
|
+
"@aztec/l1-artifacts": "0.14.0",
|
|
41
|
+
"@aztec/noir-compiler": "0.14.0",
|
|
42
|
+
"@aztec/noir-contracts": "0.14.0",
|
|
43
|
+
"@aztec/types": "0.14.0",
|
|
44
44
|
"@libp2p/peer-id-factory": "^3.0.4",
|
|
45
|
+
"@ltd/j-toml": "^1.38.0",
|
|
45
46
|
"commander": "^9.0.0",
|
|
46
47
|
"jszip": "^3.10.1",
|
|
47
48
|
"lodash.startcase": "^4.4.0",
|
package/src/github.ts
ADDED
package/src/index.ts
CHANGED
|
@@ -32,7 +32,9 @@ import { mnemonicToAccount } from 'viem/accounts';
|
|
|
32
32
|
|
|
33
33
|
import { createCompatibleClient } from './client.js';
|
|
34
34
|
import { encodeArgs, parseStructString } from './encoding.js';
|
|
35
|
+
import { GITHUB_TAG_PREFIX } from './github.js';
|
|
35
36
|
import { unboxContract } from './unbox.js';
|
|
37
|
+
import { update } from './update/update.js';
|
|
36
38
|
import {
|
|
37
39
|
deployAztecContracts,
|
|
38
40
|
getContractArtifact,
|
|
@@ -70,9 +72,9 @@ export function getProgram(log: LogFn, debugLogger: DebugLogger): Command {
|
|
|
70
72
|
const program = new Command();
|
|
71
73
|
|
|
72
74
|
const packageJsonPath = resolve(dirname(fileURLToPath(import.meta.url)), '../package.json');
|
|
73
|
-
const
|
|
75
|
+
const cliVersion: string = JSON.parse(readFileSync(packageJsonPath).toString()).version;
|
|
74
76
|
|
|
75
|
-
program.name('aztec-cli').description('CLI for interacting with Aztec.').version(
|
|
77
|
+
program.name('aztec-cli').description('CLI for interacting with Aztec.').version(cliVersion);
|
|
76
78
|
|
|
77
79
|
const pxeOption = new Option('-u, --rpc-url <string>', 'URL of the PXE')
|
|
78
80
|
.env('PXE_URL')
|
|
@@ -246,6 +248,14 @@ export function getProgram(log: LogFn, debugLogger: DebugLogger): Command {
|
|
|
246
248
|
const constructorArtifact = contractArtifact.functions.find(({ name }) => name === 'constructor');
|
|
247
249
|
|
|
248
250
|
const client = await createCompatibleClient(rpcUrl, debugLogger);
|
|
251
|
+
const nodeInfo = await client.getNodeInfo();
|
|
252
|
+
const expectedAztecNrVersion = `${GITHUB_TAG_PREFIX}-v${nodeInfo.sandboxVersion}`;
|
|
253
|
+
if (contractArtifact.aztecNrVersion && contractArtifact.aztecNrVersion !== expectedAztecNrVersion) {
|
|
254
|
+
log(
|
|
255
|
+
`\nWarning: Contract was compiled with a different version of Aztec.nr: ${contractArtifact.aztecNrVersion}. Consider updating Aztec.nr to ${expectedAztecNrVersion}\n`,
|
|
256
|
+
);
|
|
257
|
+
}
|
|
258
|
+
|
|
249
259
|
const deployer = new ContractDeployer(contractArtifact, client, publicKey);
|
|
250
260
|
|
|
251
261
|
const constructor = getFunctionArtifact(contractArtifact, 'constructor');
|
|
@@ -649,7 +659,7 @@ export function getProgram(log: LogFn, debugLogger: DebugLogger): Command {
|
|
|
649
659
|
)
|
|
650
660
|
.action(async (contractName, localDirectory) => {
|
|
651
661
|
const unboxTo: string = localDirectory ? localDirectory : contractName;
|
|
652
|
-
await unboxContract(contractName, unboxTo,
|
|
662
|
+
await unboxContract(contractName, unboxTo, cliVersion, log);
|
|
653
663
|
});
|
|
654
664
|
|
|
655
665
|
program
|
|
@@ -701,6 +711,18 @@ export function getProgram(log: LogFn, debugLogger: DebugLogger): Command {
|
|
|
701
711
|
log(`${selector}`);
|
|
702
712
|
});
|
|
703
713
|
|
|
714
|
+
program
|
|
715
|
+
.command('update')
|
|
716
|
+
.description('Updates Nodejs and Noir dependencies')
|
|
717
|
+
.argument('[projectPath]', 'Path to the project directory', process.cwd())
|
|
718
|
+
.option('--contract [paths...]', 'Paths to contracts to update dependencies', [])
|
|
719
|
+
.option('--sandbox-version <semver>', 'The sandbox version to update to. Defaults to latest', 'latest')
|
|
720
|
+
.addOption(pxeOption)
|
|
721
|
+
.action(async (projectPath: string, options) => {
|
|
722
|
+
const { contract } = options;
|
|
723
|
+
await update(projectPath, contract, options.rpcUrl, options.sandboxVersion, log, debugLogger);
|
|
724
|
+
});
|
|
725
|
+
|
|
704
726
|
compileContract(program, 'compile', log);
|
|
705
727
|
generateTypescriptInterface(program, 'generate-typescript', log);
|
|
706
728
|
generateNoirInterface(program, 'generate-noir-interface', log);
|
package/src/unbox.ts
CHANGED
|
@@ -14,9 +14,8 @@ import JSZip from 'jszip';
|
|
|
14
14
|
import fetch from 'node-fetch';
|
|
15
15
|
import * as path from 'path';
|
|
16
16
|
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
const GITHUB_TAG_PREFIX = 'aztec-packages';
|
|
17
|
+
import { GITHUB_OWNER, GITHUB_REPO, GITHUB_TAG_PREFIX } from './github.js';
|
|
18
|
+
|
|
20
19
|
const BOXES_PATH = 'yarn-project/boxes';
|
|
21
20
|
|
|
22
21
|
/**
|
|
@@ -0,0 +1,16 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Tracks changes to dependencies
|
|
3
|
+
*/
|
|
4
|
+
export type DependencyChanges = {
|
|
5
|
+
/** Which file was changed */
|
|
6
|
+
file: string;
|
|
7
|
+
/** changes done to the file */
|
|
8
|
+
dependencies: Array<{
|
|
9
|
+
/** Name of the dependency being changed */
|
|
10
|
+
name: string;
|
|
11
|
+
/** Previous version of the dependency */
|
|
12
|
+
from: string;
|
|
13
|
+
/** New version of the dependency (after the update) */
|
|
14
|
+
to: string;
|
|
15
|
+
}>;
|
|
16
|
+
};
|
|
@@ -0,0 +1,79 @@
|
|
|
1
|
+
import { LogFn } from '@aztec/foundation/log';
|
|
2
|
+
import { NoirPackageConfig, parseNoirPackageConfig } from '@aztec/foundation/noir';
|
|
3
|
+
|
|
4
|
+
import TOML from '@ltd/j-toml';
|
|
5
|
+
import { readFile } from 'fs/promises';
|
|
6
|
+
import { EOL } from 'os';
|
|
7
|
+
import { join, relative, resolve } from 'path';
|
|
8
|
+
|
|
9
|
+
import { atomicUpdateFile } from '../utils.js';
|
|
10
|
+
import { DependencyChanges } from './common.js';
|
|
11
|
+
|
|
12
|
+
/**
|
|
13
|
+
* Updates Aztec.nr dependencies
|
|
14
|
+
* @param contractPath - Path to the contract to be updated
|
|
15
|
+
* @param tag - The tag to update to
|
|
16
|
+
* @param log - Logging function
|
|
17
|
+
*/
|
|
18
|
+
export async function updateAztecNr(contractPath: string, tag: string, log: LogFn): Promise<DependencyChanges> {
|
|
19
|
+
const configFilepath = resolve(join(contractPath, 'Nargo.toml'));
|
|
20
|
+
const packageConfig = parseNoirPackageConfig(TOML.parse(await readFile(configFilepath, 'utf-8')));
|
|
21
|
+
const changes: DependencyChanges = {
|
|
22
|
+
dependencies: [],
|
|
23
|
+
file: configFilepath,
|
|
24
|
+
};
|
|
25
|
+
|
|
26
|
+
log(`Updating Aztec.nr libraries to ${tag} in ${relative(process.cwd(), changes.file)}`);
|
|
27
|
+
for (const dep of Object.values(packageConfig.dependencies)) {
|
|
28
|
+
if (!('git' in dep)) {
|
|
29
|
+
continue;
|
|
30
|
+
}
|
|
31
|
+
|
|
32
|
+
// remove trailing slash
|
|
33
|
+
const gitUrl = dep.git.toLowerCase().replace(/\/$/, '');
|
|
34
|
+
if (gitUrl !== 'https://github.com/aztecprotocol/aztec-packages') {
|
|
35
|
+
continue;
|
|
36
|
+
}
|
|
37
|
+
|
|
38
|
+
if (dep.tag !== tag) {
|
|
39
|
+
// show the Aztec.nr package name rather than the lib name
|
|
40
|
+
const dirParts = dep.directory?.split('/') ?? [];
|
|
41
|
+
changes.dependencies.push({
|
|
42
|
+
name: dirParts.slice(-2).join('/'),
|
|
43
|
+
from: dep.tag,
|
|
44
|
+
to: tag,
|
|
45
|
+
});
|
|
46
|
+
|
|
47
|
+
dep.tag = tag;
|
|
48
|
+
}
|
|
49
|
+
}
|
|
50
|
+
|
|
51
|
+
if (changes.dependencies.length > 0) {
|
|
52
|
+
const contents = prettyPrintTOML(packageConfig);
|
|
53
|
+
await atomicUpdateFile(configFilepath, contents);
|
|
54
|
+
}
|
|
55
|
+
|
|
56
|
+
return changes;
|
|
57
|
+
}
|
|
58
|
+
|
|
59
|
+
/**
|
|
60
|
+
* Pretty prints a NoirPackageConfig to a string
|
|
61
|
+
* @param packageConfig - Nargo.toml contents
|
|
62
|
+
* @returns The Nargo.toml contents as a string
|
|
63
|
+
*/
|
|
64
|
+
function prettyPrintTOML(packageConfig: NoirPackageConfig): string {
|
|
65
|
+
// hint to TOML.stringify how we want the file to look like
|
|
66
|
+
return TOML.stringify(
|
|
67
|
+
{
|
|
68
|
+
package: TOML.Section(packageConfig.package),
|
|
69
|
+
dependencies: TOML.Section(
|
|
70
|
+
Object.fromEntries(Object.entries(packageConfig.dependencies).map(([name, dep]) => [name, TOML.inline(dep)])),
|
|
71
|
+
),
|
|
72
|
+
},
|
|
73
|
+
{
|
|
74
|
+
indent: 2,
|
|
75
|
+
newline: EOL as any,
|
|
76
|
+
newlineAround: 'section',
|
|
77
|
+
},
|
|
78
|
+
);
|
|
79
|
+
}
|
|
@@ -0,0 +1,129 @@
|
|
|
1
|
+
import { LogFn } from '@aztec/foundation/log';
|
|
2
|
+
|
|
3
|
+
import { spawnSync } from 'child_process';
|
|
4
|
+
import { existsSync } from 'fs';
|
|
5
|
+
import { readFile } from 'fs/promises';
|
|
6
|
+
import { join, relative, resolve } from 'path';
|
|
7
|
+
import { SemVer, parse } from 'semver';
|
|
8
|
+
|
|
9
|
+
import { atomicUpdateFile } from '../utils.js';
|
|
10
|
+
import { DependencyChanges } from './common.js';
|
|
11
|
+
|
|
12
|
+
/**
|
|
13
|
+
* Looks up a package.json file and returns its contents
|
|
14
|
+
* @param projectPath - Path to Nodejs project
|
|
15
|
+
* @returns The parsed package.json
|
|
16
|
+
*/
|
|
17
|
+
export async function readPackageJson(projectPath: string): Promise<{
|
|
18
|
+
/** dependencies */
|
|
19
|
+
dependencies?: Record<string, string>;
|
|
20
|
+
}> {
|
|
21
|
+
const configFilepath = resolve(join(projectPath, 'package.json'));
|
|
22
|
+
const pkg = JSON.parse(await readFile(configFilepath, 'utf-8'));
|
|
23
|
+
|
|
24
|
+
return pkg;
|
|
25
|
+
}
|
|
26
|
+
|
|
27
|
+
/**
|
|
28
|
+
* Queries the npm registry for the latest version of a package
|
|
29
|
+
* @param packageName - The package to query
|
|
30
|
+
* @param distTag - The distribution tag
|
|
31
|
+
* @returns The latest version of the package on that distribution tag
|
|
32
|
+
*/
|
|
33
|
+
export async function getNewestVersion(packageName: string, distTag = 'latest'): Promise<SemVer> {
|
|
34
|
+
const url = new URL(packageName, 'https://registry.npmjs.org/');
|
|
35
|
+
const response = await fetch(url);
|
|
36
|
+
if (!response.ok) {
|
|
37
|
+
throw new Error(`Failed to fetch ${url}`);
|
|
38
|
+
}
|
|
39
|
+
|
|
40
|
+
const body = await response.json();
|
|
41
|
+
const latestVersion = parse(body['dist-tags'][distTag]);
|
|
42
|
+
if (!latestVersion) {
|
|
43
|
+
throw new Error(`Failed to get latest version from registry`);
|
|
44
|
+
}
|
|
45
|
+
|
|
46
|
+
return latestVersion;
|
|
47
|
+
}
|
|
48
|
+
|
|
49
|
+
/**
|
|
50
|
+
* Updates a project's \@aztec/* dependencies to the specific version
|
|
51
|
+
* @param projectPath - Path to Nodejs project
|
|
52
|
+
* @param aztecVersion - The version to update to
|
|
53
|
+
* @returns True if the project was updated
|
|
54
|
+
*/
|
|
55
|
+
export async function updateAztecDeps(
|
|
56
|
+
projectPath: string,
|
|
57
|
+
aztecVersion: SemVer,
|
|
58
|
+
log: LogFn,
|
|
59
|
+
): Promise<DependencyChanges> {
|
|
60
|
+
const pkg = await readPackageJson(projectPath);
|
|
61
|
+
const changes: DependencyChanges = {
|
|
62
|
+
file: resolve(join(projectPath, 'package.json')),
|
|
63
|
+
dependencies: [],
|
|
64
|
+
};
|
|
65
|
+
|
|
66
|
+
if (!pkg.dependencies) {
|
|
67
|
+
return changes;
|
|
68
|
+
}
|
|
69
|
+
|
|
70
|
+
log(`Updating @aztec packages to ${aztecVersion} in ${relative(process.cwd(), changes.file)}`);
|
|
71
|
+
const version = aztecVersion.version;
|
|
72
|
+
|
|
73
|
+
for (const name of Object.keys(pkg.dependencies)) {
|
|
74
|
+
if (!name.startsWith('@aztec/')) {
|
|
75
|
+
continue;
|
|
76
|
+
}
|
|
77
|
+
|
|
78
|
+
// different release schedule
|
|
79
|
+
if (name === '@aztec/aztec-ui') {
|
|
80
|
+
continue;
|
|
81
|
+
}
|
|
82
|
+
|
|
83
|
+
if (pkg.dependencies[name] !== version) {
|
|
84
|
+
changes.dependencies.push({
|
|
85
|
+
name,
|
|
86
|
+
from: pkg.dependencies[name],
|
|
87
|
+
to: version,
|
|
88
|
+
});
|
|
89
|
+
|
|
90
|
+
pkg.dependencies[name] = version;
|
|
91
|
+
}
|
|
92
|
+
}
|
|
93
|
+
|
|
94
|
+
if (changes.dependencies.length > 0) {
|
|
95
|
+
const contents = JSON.stringify(pkg, null, 2) + '\n';
|
|
96
|
+
await atomicUpdateFile(resolve(join(projectPath, 'package.json')), contents);
|
|
97
|
+
}
|
|
98
|
+
|
|
99
|
+
return changes;
|
|
100
|
+
}
|
|
101
|
+
|
|
102
|
+
/**
|
|
103
|
+
* Updates a project's yarn.lock or package-lock.json
|
|
104
|
+
* @param projectPath - Path to Nodejs project
|
|
105
|
+
*/
|
|
106
|
+
export function updateLockfile(projectPath: string, log: LogFn): void {
|
|
107
|
+
const isNpm = existsSync(resolve(join(projectPath, 'package-lock.json')));
|
|
108
|
+
const isYarn = existsSync(resolve(join(projectPath, 'yarn.lock')));
|
|
109
|
+
const isPnpm = existsSync(resolve(join(projectPath, 'pnpm-lock.yaml')));
|
|
110
|
+
|
|
111
|
+
if (isPnpm) {
|
|
112
|
+
spawnSync('pnpm', ['install'], {
|
|
113
|
+
cwd: projectPath,
|
|
114
|
+
stdio: 'inherit',
|
|
115
|
+
});
|
|
116
|
+
} else if (isYarn) {
|
|
117
|
+
spawnSync('yarn', ['install'], {
|
|
118
|
+
cwd: projectPath,
|
|
119
|
+
stdio: 'inherit',
|
|
120
|
+
});
|
|
121
|
+
} else if (isNpm) {
|
|
122
|
+
spawnSync('npm', ['install'], {
|
|
123
|
+
cwd: projectPath,
|
|
124
|
+
stdio: 'inherit',
|
|
125
|
+
});
|
|
126
|
+
} else {
|
|
127
|
+
log(`No lockfile found in ${projectPath}. Skipping lockfile update...`);
|
|
128
|
+
}
|
|
129
|
+
}
|