Skip to content
This repository has been archived by the owner on Mar 25, 2024. It is now read-only.

feat: calculate-hashes command to detect contract changes #37

Merged
merged 26 commits into from
Oct 18, 2023
Merged
Show file tree
Hide file tree
Changes from 24 commits
Commits
Show all changes
26 commits
Select commit Hold shift + click to select a range
3621c4c
feat: calculate-hashes
benceharomi Oct 6, 2023
dacbeb3
fix: build-yul command updated
benceharomi Oct 6, 2023
d732a3e
chore: CI workflow renamed
benceharomi Oct 6, 2023
6355c20
feat(calculate-hashes): "--check-only" flag added
benceharomi Oct 8, 2023
62f8b9a
ci: calculate-hashes added to pipeline
benceharomi Oct 8, 2023
639650b
modifying hash to test calculate-hashes in CI
benceharomi Oct 8, 2023
30d5dd8
Revert "modifying hash to test calculate-hashes in CI"
benceharomi Oct 8, 2023
b4c7cd9
chore: bytecodeHash renamed
benceharomi Oct 9, 2023
adfd15e
chore: importing and typo
benceharomi Oct 9, 2023
f655642
feat: revert command renames
benceharomi Oct 11, 2023
4566798
chore: major calculate-hashes refactor
benceharomi Oct 11, 2023
1305230
Merge branch 'dev' into bh-evm-290-detect-when-bootloader-hash-has-ch…
benceharomi Oct 11, 2023
f9388f3
ci: check hashes into separate job
benceharomi Oct 11, 2023
6fb1383
ci: yarn cacheing
benceharomi Oct 11, 2023
dd1d9e7
fix: absolutePath
benceharomi Oct 11, 2023
cd5018b
fix: hash updated
benceharomi Oct 11, 2023
d5788c0
fix: SHA256 hash updated
benceharomi Oct 11, 2023
7d9770d
docs: readme updated
benceharomi Oct 12, 2023
4047088
chore: changed hashes to array
benceharomi Oct 12, 2023
59c390d
chore: SystemContractsHashes updated
benceharomi Oct 12, 2023
b8868f5
Merge branch 'dev' into bh-evm-290-detect-when-bootloader-hash-has-ch…
benceharomi Oct 16, 2023
e75c105
lint(calculate-hashes): format+lint
benceharomi Oct 16, 2023
494df9c
docs: command name typo
benceharomi Oct 16, 2023
247c90f
fix: calculate hashes updated
benceharomi Oct 16, 2023
0a9a14f
chore: automatic contracts details generation
benceharomi Oct 18, 2023
bfd2f28
chore: changed the order of json properties
benceharomi Oct 18, 2023
File filter

Filter by extension

Filter by extension


Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
34 changes: 34 additions & 0 deletions .github/workflows/ci.yaml
Original file line number Diff line number Diff line change
Expand Up @@ -14,6 +14,7 @@ jobs:
uses: actions/setup-node@v3
with:
node-version: 18.18.0
cache: yarn

- name: Install dependencies
run: yarn
Expand Down Expand Up @@ -52,6 +53,39 @@ jobs:
- name: Run lint
run: yarn lint

check_hashes:
needs: [build]
runs-on: ubuntu-latest

steps:
- name: Checkout the repository
uses: actions/checkout@v3

- name: Use Node.js
uses: actions/setup-node@v3
with:
node-version: 18.18.0
cache: yarn

- name: Install dependencies
run: yarn

- name: Restore artifacts cache
uses: actions/cache/restore@v3
with:
fail-on-cache-miss: true
key: artifacts-${{ github.sha }}
path: |
artifacts-zk
cache-zk
typechain-types
contracts/artifacts
contracts/precompiles/artifacts
bootloader/build

- name: Check hashes
run: yarn calculate-hashes --check-only

test:
needs: [build, lint]
runs-on: ubuntu-latest
Expand Down
4 changes: 4 additions & 0 deletions README.md
Original file line number Diff line number Diff line change
Expand Up @@ -35,6 +35,10 @@ This repository is used as a submodule of the [zksync-2-dev](https://github.com/

Compile the solidity and yul contracts: `yarn build`

Check the system contracts hashes: `yarn calculate-hashes --check-only`

Update the system contracts hashes: `yarn calculate-hashes`

## Update Process

System contracts handle core functionalities and play a critical role in maintaining the integrity of our protocol. To
Expand Down
149 changes: 149 additions & 0 deletions SystemContractsHashes.json
Original file line number Diff line number Diff line change
@@ -0,0 +1,149 @@
[
{
"contractName": "AccountCodeStorage",
"sourceCodePath": "contracts/AccountCodeStorage.sol",
"bytecodePath": "artifacts-zk/cache-zk/solpp-generated-contracts/AccountCodeStorage.sol/AccountCodeStorage.json",
"bytecodeHash": "0x0100009b3cd9a137912ffbd406a1d73eaffbcf40a760f3956fea7e051f0c6101",
"sourceCodeHash": "0x721f289059b0bf670fecc03ad7a1f58ca7da2fe1fd9802457708944a82418590"
},
{
"contractName": "BootloaderUtilities",
"sourceCodePath": "contracts/BootloaderUtilities.sol",
"bytecodePath": "artifacts-zk/cache-zk/solpp-generated-contracts/BootloaderUtilities.sol/BootloaderUtilities.json",
"bytecodeHash": "0x01000975e811c2ba4a3b28f70426598129f0029feb086714980f9513f59531c7",
"sourceCodeHash": "0xb03c4703cb68b22cd7f74e04fa8b5d43025b98737a53c830a50138e385e2628b"
},
{
"contractName": "ComplexUpgrader",
"sourceCodePath": "contracts/ComplexUpgrader.sol",
"bytecodePath": "artifacts-zk/cache-zk/solpp-generated-contracts/ComplexUpgrader.sol/ComplexUpgrader.json",
"bytecodeHash": "0x0100005b2eef785c804dc40ec24b3c2339b11a314fec6eb91db551a2523d6a2b",
"sourceCodeHash": "0x774da238fac06b112f94e0b10064ce5dbb45dab9378ae7bc88fe096127c36b78"
},
{
"contractName": "Compressor",
"sourceCodePath": "contracts/Compressor.sol",
"bytecodePath": "artifacts-zk/cache-zk/solpp-generated-contracts/Compressor.sol/Compressor.json",
"bytecodeHash": "0x010001b7a7bb988e52b8fca05d82bccf63ea34c6617ebea1765c91e911386756",
"sourceCodeHash": "0xfed07845a7f4b19cf41351b56687311d3f55cfca90a8d3b2a3d3df1737873bbd"
},
{
"contractName": "ContractDeployer",
"sourceCodePath": "contracts/ContractDeployer.sol",
"bytecodePath": "artifacts-zk/cache-zk/solpp-generated-contracts/ContractDeployer.sol/ContractDeployer.json",
"bytecodeHash": "0x010005bb3e1bb343565920b37c6c0d716dcfca45bbdada20a305e80ab60a6916",
"sourceCodeHash": "0x837fdb9e6f2616fe6e189417ff48f8960d1c79245d75b275684fa10c9ac7d6c3"
},
{
"contractName": "DefaultAccount",
"sourceCodePath": "contracts/DefaultAccount.sol",
"bytecodePath": "artifacts-zk/cache-zk/solpp-generated-contracts/DefaultAccount.sol/DefaultAccount.json",
"bytecodeHash": "0x0100065d0ea6130f484f6cd4936f2d5114abc9961328d6acd8b311dd00b94546",
"sourceCodeHash": "0x0af09156a1485eb2f398a082027504281a8224f8d611662570d8a43efd967372"
},
{
"contractName": "EmptyContract",
"sourceCodePath": "contracts/EmptyContract.sol",
"bytecodePath": "artifacts-zk/cache-zk/solpp-generated-contracts/EmptyContract.sol/EmptyContract.json",
"bytecodeHash": "0x01000007c08e60bc60d70f759bc49f2488b70054b0cec1a64f0cf27953448f4c",
"sourceCodeHash": "0xa1ba9e2afa6b403f23d21b8f173d273f93b522daaaba03f4cc75692ebc71a853"
},
{
"contractName": "ImmutableSimulator",
"sourceCodePath": "contracts/ImmutableSimulator.sol",
"bytecodePath": "artifacts-zk/cache-zk/solpp-generated-contracts/ImmutableSimulator.sol/ImmutableSimulator.json",
"bytecodeHash": "0x01000047b7e40b0e0f7bd7051e20853a49b972c6c0ac16872425067cb3288f08",
"sourceCodeHash": "0xcaaaa98efde534901cd80aee33fb65a8d69fe702ef0fffd1e840f607d8b67b7c"
},
{
"contractName": "KnownCodesStorage",
"sourceCodePath": "contracts/KnownCodesStorage.sol",
"bytecodePath": "artifacts-zk/cache-zk/solpp-generated-contracts/KnownCodesStorage.sol/KnownCodesStorage.json",
"bytecodeHash": "0x0100008b806f904a40cadb94318db1d8a8ae9a579f46ee0b50432e4c221572ee",
"sourceCodeHash": "0x0900ec65dd10108eeb76e4123e5ee95db16e4caf76502698511c0ac0ac2e1c55"
},
{
"contractName": "L1Messenger",
"sourceCodePath": "contracts/L1Messenger.sol",
"bytecodePath": "artifacts-zk/cache-zk/solpp-generated-contracts/L1Messenger.sol/L1Messenger.json",
"bytecodeHash": "0x010002fb863dc09dbfdae276418c307eb39af03f335a0b23a2edc8bcd1835fce",
"sourceCodeHash": "0x85d7b2639d7844735a6d2f166c77c45bd81f0197b3131d9d6a3594c313dc965a"
},
{
"contractName": "L2EthToken",
"sourceCodePath": "contracts/L2EthToken.sol",
"bytecodePath": "artifacts-zk/cache-zk/solpp-generated-contracts/L2EthToken.sol/L2EthToken.json",
"bytecodeHash": "0x01000139b0930df0818b0f10f7c78feed9ca93020efcb72e749a7ea842d08576",
"sourceCodeHash": "0xc563fe25f07906ef60b17ccb48884784543f02493648f4f5bf19c9a9c74464d5"
},
{
"contractName": "MsgValueSimulator",
"sourceCodePath": "contracts/MsgValueSimulator.sol",
"bytecodePath": "artifacts-zk/cache-zk/solpp-generated-contracts/MsgValueSimulator.sol/MsgValueSimulator.json",
"bytecodeHash": "0x0100006f5dab2685a586d5ebbd360a2c1c2d593df1ab8267d8e172d92a202bfa",
"sourceCodeHash": "0x2f4be7f4afe5ac19b02d62ae9a107c2fd6268d9cd7d96e997f049cb7eecb2c97"
},
{
"contractName": "NonceHolder",
"sourceCodePath": "contracts/NonceHolder.sol",
"bytecodePath": "artifacts-zk/cache-zk/solpp-generated-contracts/NonceHolder.sol/NonceHolder.json",
"bytecodeHash": "0x0100012f7252eee16af884775bd3279b577bbed64f124349ac6179aeb6ae3cb8",
"sourceCodeHash": "0xfdc19bf88e636b5128e9591c9b4a072e6bb0dbe24d767685d00101e83393fa06"
},
{
"contractName": "SystemContext",
"sourceCodePath": "contracts/SystemContext.sol",
"bytecodePath": "artifacts-zk/cache-zk/solpp-generated-contracts/SystemContext.sol/SystemContext.json",
"bytecodeHash": "0x0100023f1761d12df53e8581fabcb359cb069bbd2a7a7a3ef0b49f2f5d46169a",
"sourceCodeHash": "0xd41f5281ff1d10055be4a06af5d35d86406a397e7bf9bb766e9f015fa4b57dce"
},
{
"contractName": "EventWriter",
"sourceCodePath": "contracts/EventWriter.yul",
"bytecodePath": "contracts/artifacts/EventWriter.yul/EventWriter.yul.zbin",
"bytecodeHash": "0x01000019642d87621fdd82cf65aa9146486c9256d5f8849af9a37c78ef519339",
"sourceCodeHash": "0x55cfee65f174350edfd690c949bc0a29458f25da11f1d5f90b57621567df1fc3"
},
{
"contractName": "EcAdd",
"sourceCodePath": "contracts/precompiles/EcAdd.yul",
"bytecodePath": "contracts/precompiles/artifacts/EcAdd.yul/EcAdd.yul.zbin",
"bytecodeHash": "0x010000c56c054a0de4a36b133d3c114ec514c3ce0334ad7759c202392386a913",
"sourceCodeHash": "0xe73c8960a8b4060113adca9f03207d379580d172df9f0b499dd5353934a557a6"
},
{
"contractName": "EcMul",
"sourceCodePath": "contracts/precompiles/EcMul.yul",
"bytecodePath": "contracts/precompiles/artifacts/EcMul.yul/EcMul.yul.zbin",
"bytecodeHash": "0x010001378d31273c8e58caa12bcf1a5694e66a0aefdba2504adb8e3eb02b21c7",
"sourceCodeHash": "0x6c4b11542bcf85e6e02ca193fc0548353b1f21c27e972b9e73781e8f7eaf50b0"
},
{
"contractName": "Ecrecover",
"sourceCodePath": "contracts/precompiles/Ecrecover.yul",
"bytecodePath": "contracts/precompiles/artifacts/Ecrecover.yul/Ecrecover.yul.zbin",
"bytecodeHash": "0x010000114daca2ff44f27d543b8ef67d885bfed09a74ba9cb25f5912dd3d739c",
"sourceCodeHash": "0x18eac0a993afec4112da99fc8e2978891598ab12566528628896f430c855fb81"
},
{
"contractName": "Keccak256",
"sourceCodePath": "contracts/precompiles/Keccak256.yul",
"bytecodePath": "contracts/precompiles/artifacts/Keccak256.yul/Keccak256.yul.zbin",
"bytecodeHash": "0x0100001fb52ca33668d01c230a1c3b13ede90fe2e37d77222410e9f183cb7a89",
"sourceCodeHash": "0x6415e127a4e07907fb87d0cbdf480fff8c70326c4f2f670af0cf3248862e4df4"
},
{
"contractName": "SHA256",
"sourceCodePath": "contracts/precompiles/SHA256.yul",
"bytecodePath": "contracts/precompiles/artifacts/SHA256.yul/SHA256.yul.zbin",
"bytecodeHash": "0x010000178d93b2d7d6448866009892223caf018a8e8dbcf090c2b9053a285f8d",
"sourceCodeHash": "0x8f5a719394836111c850774e89ffb22ef825ff4d24d116ca750888be906f0109"
},
{
"contractName": "proved_batch",
"sourceCodePath": "bootloader/build/proved_batch.yul",
"bytecodePath": "bootloader/build/artifacts/proved_batch.yul/proved_batch.yul.zbin",
"bytecodeHash": "0x010009411d9c2342671c57d5ce038ce3e142c750df85ac5d23f67b4e4215fede",
"sourceCodeHash": "0xd48e5abbfbb493eacfcbe6dc788eada867d58ab8596d55736b496b1c2e22c636"
}
]
5 changes: 4 additions & 1 deletion package.json
Original file line number Diff line number Diff line change
Expand Up @@ -20,11 +20,13 @@
"@typechain/ethers-v5": "^10.0.0",
"@typechain/hardhat": "^7.0.0",
"@types/chai": "^4.3.1",
"@types/lodash": "^4.14.199",
"@types/mocha": "^9.1.1",
"@types/node": "^17.0.34",
"@typescript-eslint/eslint-plugin": "^6.7.4",
"@typescript-eslint/parser": "^6.7.4",
"chai": "^4.3.6",
"lodash": "^4.17.21",
"eslint": "^8.51.0",
"markdownlint-cli": "^0.33.0",
"mocha": "^10.0.0",
Expand All @@ -50,6 +52,7 @@
"build": "yarn build:sol && yarn build:yul",
"build:sol": "hardhat compile",
"build:yul": "yarn preprocess:yul && yarn compile-yul",
"calculate-hashes": "ts-node scripts/calculate-hashes.ts",
"clean": "yarn clean:sol && yarn clean:yul",
"clean:sol": "hardhat clean",
"clean:yul": "rm -rf ./bootloader/build ./bootloader/tests/artifacts ./contracts/artifacts ./contracts/precompiles/artifacts",
Expand All @@ -60,9 +63,9 @@
"lint:md": "markdownlint **/*.md",
"lint:sol": "solhint \"contracts/**/*.sol\"",
"lint:ts": "eslint .",
"preprocess:yul": "rm -rf ./bootloader/build && yarn ts-node scripts/process.ts",
"prettier:check": "prettier --check \"**/*.{js,json,md,sol,ts,yaml}\"",
"prettier:write": "prettier --write \"**/*.{js,json,md,sol,ts,yaml}\"",
"preprocess:yul": "rm -rf ./bootloader/build && yarn ts-node scripts/process.ts",
"test": "hardhat test --network zkSyncTestNode",
"test:bootloader": "cd bootloader/test_infra && cargo run"
}
Expand Down
Loading
Loading