Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Feature/ongoing pp #282

Closed
wants to merge 100 commits into from
Closed
Show file tree
Hide file tree
Changes from 1 commit
Commits
Show all changes
100 commits
Select commit Hold shift + click to select a range
bbe1b35
ongoing
invocamanman Jul 3, 2024
81fe6c9
ongoing
invocamanman Jul 8, 2024
1f723c3
ongoing
invocamanman Jul 8, 2024
e6111ee
wip update polygonRollupManager
laisolizq Jul 11, 2024
45912c5
wip new polygon consensus contract
laisolizq Jul 11, 2024
3b3fcd7
review
laisolizq Jul 15, 2024
55029f8
review consensus contract
laisolizq Jul 15, 2024
5136a6c
review PR
laisolizq Jul 15, 2024
1e3c96c
small fixes to compile
invocamanman Jul 16, 2024
0520738
Implement PP at add new rollupType
ignasirv Jul 16, 2024
f0a993c
ongoign
invocamanman Jul 17, 2024
81a372a
now compiles
invocamanman Jul 17, 2024
3ee556c
hi
invocamanman Jul 17, 2024
9ad9c33
wip
krlosMata Jul 17, 2024
a267651
empty commit signed
invocamanman Jul 17, 2024
4c12976
verify PP
krlosMata Jul 18, 2024
591a6ca
rollup.verifier --> address type. Load interface depending on verify …
krlosMata Jul 18, 2024
116454f
fixes
invocamanman Jul 19, 2024
d80cd1e
mini updates
laisolizq Jul 18, 2024
87e91ac
review PR
laisolizq Jul 19, 2024
a3fc69f
fix compilation
invocamanman Jul 20, 2024
7473921
Update events for PP
ignasirv Jul 18, 2024
f9eca7b
sudo in docker script. Comments PR
krlosMata Jul 22, 2024
b19aafd
fix dockerv2 sudo
laisolizq Jul 22, 2024
77dc579
update scripts deploy-docker
laisolizq Jul 23, 2024
c70866c
update docs-compiledcontracts
krlosMata Jul 23, 2024
1ffa27a
ongoing
invocamanman Jul 3, 2024
089288a
ongoing
invocamanman Jul 8, 2024
70519e3
ongoing
invocamanman Jul 8, 2024
3fab639
wip update polygonRollupManager
laisolizq Jul 11, 2024
6be961b
wip new polygon consensus contract
laisolizq Jul 11, 2024
ff3220c
review
laisolizq Jul 15, 2024
c552eea
review consensus contract
laisolizq Jul 15, 2024
a268254
review PR
laisolizq Jul 15, 2024
1597d8f
small fixes to compile
invocamanman Jul 16, 2024
81d3c5c
Implement PP at add new rollupType
ignasirv Jul 16, 2024
b0ef71c
ongoign
invocamanman Jul 17, 2024
9c34d74
now compiles
invocamanman Jul 17, 2024
2324b1a
hi
invocamanman Jul 17, 2024
36ed20c
wip
krlosMata Jul 17, 2024
794e10d
empty commit signed
invocamanman Jul 17, 2024
60725a2
verify PP
krlosMata Jul 18, 2024
2cb2e20
rollup.verifier --> address type. Load interface depending on verify …
krlosMata Jul 18, 2024
942c65a
fixes
invocamanman Jul 19, 2024
f8c33cf
mini updates
laisolizq Jul 18, 2024
d48660c
review PR
laisolizq Jul 19, 2024
b15cacf
fix compilation
invocamanman Jul 20, 2024
77a9b46
Update events for PP
ignasirv Jul 18, 2024
e412d4b
sudo in docker script. Comments PR
krlosMata Jul 22, 2024
1f93373
fix dockerv2 sudo
laisolizq Jul 22, 2024
c4ee4ab
update scripts deploy-docker
laisolizq Jul 23, 2024
82f59ad
update docs + fox zeroAddress
krlosMata Jul 23, 2024
eb1e9af
update contracts tests
laisolizq Jul 24, 2024
1b328ce
ignore PolygonRollupManagerUpgrade test
laisolizq Jul 25, 2024
7a61a94
WIP
krlosMata Jul 25, 2024
f696419
test full pesismistic
krlosMata Jul 26, 2024
ae107da
new getters rollupData. All tests passing
krlosMata Jul 26, 2024
fdda2b3
rename _legacy... to _
krlosMata Jul 30, 2024
5225b1f
increase coverage
krlosMata Jul 30, 2024
da25752
add edge case
krlosMata Jul 30, 2024
3c7d6c8
all coverage
krlosMata Jul 31, 2024
fcf9142
fix eslint
krlosMata Jul 31, 2024
cebd5b8
add rollupID as a public input
krlosMata Aug 1, 2024
a1dd5a1
remove incorrect comment
krlosMata Aug 1, 2024
b3c3101
missing checkout on gha docker-build
krlosMata Aug 2, 2024
9735b85
returnData V2
krlosMata Aug 2, 2024
f508836
fix build docker
krlosMata Aug 2, 2024
0ae4063
mini thingds
invocamanman Aug 5, 2024
1a3fc82
move function
invocamanman Aug 5, 2024
e077054
mini fix
invocamanman Aug 18, 2024
65f9710
compiled and docs
invocamanman Aug 18, 2024
4fb1711
udpate PP
invocamanman Aug 18, 2024
00216b5
Spellcheck
ignasirv Aug 20, 2024
a2384a5
Add rollupManager initializer versioning
ignasirv Aug 22, 2024
cceaa7a
Add version in constant
ignasirv Aug 27, 2024
ad20201
github comments
ignasirv Aug 29, 2024
f8fcc1d
Move to constants
ignasirv Aug 29, 2024
c9cb821
selecterGER --> l1InfoTreeLeafCount
krlosMata Aug 29, 2024
0b9e04f
add _disableInitializers();
krlosMata Aug 30, 2024
9f7b676
hidden typo
krlosMata Aug 30, 2024
f0ba99b
Setup for sp1 e2e testing
ignasirv Sep 9, 2024
e52f54e
fix build dockerv2:contracts
laisolizq Sep 12, 2024
acf1d85
update forkID=11 docker build
laisolizq Sep 13, 2024
67ae71b
fix lint
laisolizq Sep 13, 2024
5c48e01
token wrapped bridge contract
invocamanman Sep 13, 2024
df75d51
get ABI from compiled-contracts
krlosMata Sep 15, 2024
713ef56
rename to TokenWrappedBridge
krlosMata Sep 15, 2024
5aaa318
fix test
krlosMata Sep 15, 2024
533f053
minor fixes on tools
krlosMata Sep 5, 2024
095fdf2
cherry-pick 4af640cfb84b4841450d335dc5a5c0cd4d800cea
krlosMata Sep 15, 2024
25d847d
disable initializer=false
krlosMata Sep 23, 2024
48b7bbc
Merge pull request #340 from 0xPolygonHermez/feature/fix-initilaize
invocamanman Sep 26, 2024
d05367e
audit remediations
krlosMata Oct 3, 2024
289b8ad
support deployment real sp1 verifier & update tools
krlosMata Oct 6, 2024
d5de496
Merge pull request #341 from 0xPolygonHermez/feature/audit-changes
invocamanman Oct 7, 2024
f57c655
PR review
krlosMata Oct 7, 2024
d0b44f2
Merge pull request #342 from 0xPolygonHermez/feature/real-sp1-verifier
invocamanman Oct 7, 2024
d947b94
Update e2e with l1InfoTree + upgrade verifier to v2
ignasirv Oct 7, 2024
82d3577
Merge pull request #343 from 0xPolygonHermez/feature/sp1-e2e-update
invocamanman Oct 7, 2024
2b044eb
Recover reference url comments
ignasirv Oct 7, 2024
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
Prev Previous commit
Next Next commit
new getters rollupData. All tests passing
  • Loading branch information
krlosMata committed Sep 15, 2024
commit ae107daa76c87680ab0867fff45d6d432598165e
4 changes: 2 additions & 2 deletions .github/workflows/compile.yml
Original file line number Diff line number Diff line change
Expand Up @@ -5,9 +5,9 @@ name: Main CI

on:
push:
branches: [feature/ongoingPP]
branches: [main, develop, feature/ongoingPP]
pull_request:
branches: [feature/ongoingPP]
branches: [main, develop, feature/ongoingPP]

jobs:
lint-and-test:
Expand Down
4 changes: 2 additions & 2 deletions .github/workflows/main.yml
Original file line number Diff line number Diff line change
Expand Up @@ -5,9 +5,9 @@ name: Main CI

on:
push:
branches: [main, develop]
branches: [main, develop, feature/ongoingPP]
pull_request:
branches: [main, develop]
branches: [main, develop, feature/ongoingPP]

jobs:
lint-and-test:
Expand Down
157 changes: 139 additions & 18 deletions contracts/v2/PolygonRollupManager.sol
Original file line number Diff line number Diff line change
Expand Up @@ -45,6 +45,7 @@ contract PolygonRollupManager is
address consensusImplementation;
address verifier;
uint64 forkID;
/// @custom:oz-retyped-from uint8
VerifierType rollupVerifierType;
bool obsolete;
bytes32 genesis;
Expand Down Expand Up @@ -79,15 +80,74 @@ contract PolygonRollupManager is
uint64 forkID;
mapping(uint64 batchNum => bytes32) batchNumToStateRoot;
mapping(uint64 batchNum => SequencedBatchData) sequencedBatches;
/// @custom:oz-renamed-from pendingStateTransitions
mapping(uint256 pendingStateNum => PendingState) _legacyPendingStateTransitions;
bytes32 lastLocalExitRoot;
uint64 lastBatchSequenced;
uint64 lastVerifiedBatch;
uint128 _legacyPendingStateGap;
// uint64 _legacyLastPendingState;
// uint64 _legacyLastPendingStateConsolidated;
/// @custom:oz-renamed-from lastPendingState
uint64 _legacyLastPendingState;
/// @custom:oz-renamed-from lastPendingStateConsolidated
uint64 _legacyLastPendingStateConsolidated;
uint64 lastVerifiedBatchBeforeUpgrade;
uint64 rollupTypeID;
/// @custom:oz-retyped-from uint8
VerifierType rollupVerifierType;
bytes32 lastPessimisticRoot;
bytes32 programVKey;
}

/**
* @notice Struct to return all the necessary rollup info: VerifierType StateTransition
* @param rollupContract Rollup consensus contract, which manages everything
* related to sequencing transactions
* @param chainID Chain ID of the rollup
* @param verifier Verifier contract
* @param forkID ForkID of the rollup
* @param lastLocalExitRoot Last exit root verified, used for compute the rollupExitRoot
* @param lastBatchSequenced Last batch sent by the consensus contract
* @param lastVerifiedBatch Last batch verified
* @param _legacyLastPendingState Last pending state (deprecated)
* @param _legacyLastPendingStateConsolidated Last pending state consolidated (deprecated)
* @param lastVerifiedBatchBeforeUpgrade Last batch verified before the last upgrade
* @param rollupTypeID Rollup type ID, can be 0 if it was added as an existing rollup
* @param rollupVerifierType Rollup ID used for compatibility checks when upgrading
*/
struct RollupDataReturnStateTransistion {
IPolygonRollupBase rollupContract;
uint64 chainID;
address verifier;
uint64 forkID;
bytes32 lastLocalExitRoot;
uint64 lastBatchSequenced;
uint64 lastVerifiedBatch;
uint64 _legacyLastPendingState;
uint64 _legacyLastPendingStateConsolidated;
uint64 lastVerifiedBatchBeforeUpgrade;
uint64 rollupTypeID;
VerifierType rollupVerifierType;
}

/**
* @notice Struct to return all the necessary rollup info: VerifierType Pessimistic
* @param rollupContract Rollup consensus contract, which manages everything
* related to sequencing transactions
* @param chainID Chain ID of the rollup
* @param verifier Verifier contract
* @param forkID ForkID of the rollup
* @param lastLocalExitRoot Last exit root verified, used for compute the rollupExitRoot
* @param rollupTypeID Rollup type ID, can be 0 if it was added as an existing rollup
* @param rollupVerifierType Rollup ID used for compatibility checks when upgrading
* @param lastPessimisticRoot Pessimistic info, currently contains the local balance tree and the local nullifier tree hashed
* @param programVKey Hashed program that will be executed in case of using a "general porpuse ZK verifier" e.g SP1
*/
struct RollupDataReturnPessimistic {
IPolygonRollupBase rollupContract;
uint64 chainID;
address verifier;
uint64 forkID;
bytes32 lastLocalExitRoot;
uint64 rollupTypeID;
VerifierType rollupVerifierType;
bytes32 lastPessimisticRoot;
bytes32 programVKey;
Expand Down Expand Up @@ -175,13 +235,15 @@ contract PolygonRollupManager is
uint32 public rollupTypeCount;

// Rollup type mapping
// @custom:oz-retyped-from PolygonRollupManagerPrevious.RollupType
mapping(uint32 rollupTypeID => RollupType) public rollupTypeMap;

// Number of rollups added, every new rollup will be assigned sequencially a new ID
uint32 public rollupCount;

// Rollups ID mapping
mapping(uint32 rollupID => RollupData) public rollupIDToRollupData;
/// @custom:oz-renamed-from rollupIDToRollupData
mapping(uint32 rollupID => RollupData) internal legacyRollupIDToRollupData;

// Rollups address mapping
mapping(address rollupAddress => uint32 rollupID) public rollupAddressToID;
Expand All @@ -201,16 +263,20 @@ contract PolygonRollupManager is

// Trusted aggregator timeout, if a sequence is not verified in this time frame,
// everyone can verify that sequence
/// @custom:oz-renamed-from trustedAggregatorTimeout
uint64 internal __legacyTrustedAggregatorTimeout;

// Once a pending state exceeds this timeout it can be consolidated (deprecated)
/// @custom:oz-renamed-from pendingStateTimeout
uint64 internal __legacyPendingStateTimeout;

// Time target of the verification of a batch
// Adaptively the batchFee will be updated to achieve this target
/// @custom:oz-renamed-from verifyBatchTimeTarget
uint64 internal __legacyVerifyBatchTimeTarget;

// Batch fee multiplier with 3 decimals that goes from 1000 - 1023
/// @custom:oz-renamed-from multiplierBatchFee
uint16 internal __legacyMultiplierBatchFee;

// Current POL fee per batch sequenced
Expand Down Expand Up @@ -461,7 +527,7 @@ contract PolygonRollupManager is
// Store rollup data
rollupAddressToID[rollupAddress] = rollupID;

RollupData storage rollup = rollupIDToRollupData[rollupID];
RollupData storage rollup = legacyRollupIDToRollupData[rollupID];

rollup.rollupContract = IPolygonRollupBase(rollupAddress);
rollup.forkID = rollupType.forkID;
Expand Down Expand Up @@ -536,7 +602,7 @@ contract PolygonRollupManager is
// Store rollup data
rollupAddressToID[address(rollupAddress)] = rollupID;

RollupData storage rollup = rollupIDToRollupData[rollupID];
RollupData storage rollup = legacyRollupIDToRollupData[rollupID];
rollup.rollupContract = rollupAddress;
rollup.forkID = forkID;
rollup.verifier = verifier;
Expand Down Expand Up @@ -579,7 +645,7 @@ contract PolygonRollupManager is
}

// Check all sequences are verified before upgrading
RollupData storage rollup = rollupIDToRollupData[
RollupData storage rollup = legacyRollupIDToRollupData[
rollupAddressToID[address(rollupContract)]
];

Expand Down Expand Up @@ -632,7 +698,7 @@ contract PolygonRollupManager is
revert RollupMustExist();
}

RollupData storage rollup = rollupIDToRollupData[rollupID];
RollupData storage rollup = legacyRollupIDToRollupData[rollupID];

// The update must be to a new rollup type
if (rollup.rollupTypeID == newRollupTypeID) {
Expand Down Expand Up @@ -694,7 +760,7 @@ contract PolygonRollupManager is
}

// Load rollup
RollupData storage rollup = rollupIDToRollupData[rollupID];
RollupData storage rollup = legacyRollupIDToRollupData[rollupID];

if (rollup.rollupVerifierType != VerifierType.StateTransition) {
revert OnlyStateTransitionChains();
Expand Down Expand Up @@ -774,7 +840,7 @@ contract PolygonRollupManager is
revert MustSequenceSomeBatch();
}

RollupData storage rollup = rollupIDToRollupData[rollupID];
RollupData storage rollup = legacyRollupIDToRollupData[rollupID];

// Update total sequence parameters
totalSequencedBatches += newSequencedBatches;
Expand Down Expand Up @@ -823,7 +889,7 @@ contract PolygonRollupManager is
revert PendingStateNumExist();
}

RollupData storage rollup = rollupIDToRollupData[rollupID];
RollupData storage rollup = legacyRollupIDToRollupData[rollupID];

if (rollup.rollupVerifierType != VerifierType.StateTransition) {
revert OnlyStateTransitionChains();
Expand Down Expand Up @@ -871,7 +937,7 @@ contract PolygonRollupManager is
bytes32 newPessimisticRoot,
bytes calldata proof
) external onlyRole(_TRUSTED_AGGREGATOR_ROLE) {
RollupData storage rollup = rollupIDToRollupData[rollupID];
RollupData storage rollup = legacyRollupIDToRollupData[rollupID];

// Only for pessimistic verifiers
if (rollup.rollupVerifierType != VerifierType.Pessimistic) {
Expand Down Expand Up @@ -1168,7 +1234,8 @@ contract PolygonRollupManager is
// In the first iteration the nodes will be the leafs which are the local exit roots of each network
for (uint256 i = 0; i < currentNodes; i++) {
// The first rollup ID starts on 1
tmpTree[i] = rollupIDToRollupData[uint32(i + 1)].lastLocalExitRoot;
tmpTree[i] = legacyRollupIDToRollupData[uint32(i + 1)]
.lastLocalExitRoot;
}

// This variable will keep track of the zero hashes
Expand Down Expand Up @@ -1223,7 +1290,7 @@ contract PolygonRollupManager is
function getLastVerifiedBatch(
uint32 rollupID
) public view returns (uint64) {
return _getLastVerifiedBatch(rollupIDToRollupData[rollupID]);
return _getLastVerifiedBatch(legacyRollupIDToRollupData[rollupID]);
}

/**
Expand Down Expand Up @@ -1280,7 +1347,7 @@ contract PolygonRollupManager is
) public view returns (bytes memory) {
return
_getInputPessimisticBytes(
rollupIDToRollupData[rollupID],
legacyRollupIDToRollupData[rollupID],
selectedGlobalExitRoot,
newLocalExitRoot,
newPessimisticRoot
Expand Down Expand Up @@ -1335,7 +1402,7 @@ contract PolygonRollupManager is
) public view returns (bytes memory) {
return
_getInputSnarkBytes(
rollupIDToRollupData[rollupID],
legacyRollupIDToRollupData[rollupID],
initNumBatch,
finalNewBatch,
newLocalExitRoot,
Expand Down Expand Up @@ -1428,7 +1495,8 @@ contract PolygonRollupManager is
uint32 rollupID,
uint64 batchNum
) public view returns (bytes32) {
return rollupIDToRollupData[rollupID].batchNumToStateRoot[batchNum];
return
legacyRollupIDToRollupData[rollupID].batchNumToStateRoot[batchNum];
}

/**
Expand All @@ -1440,6 +1508,59 @@ contract PolygonRollupManager is
uint32 rollupID,
uint64 batchNum
) public view returns (SequencedBatchData memory) {
return rollupIDToRollupData[rollupID].sequencedBatches[batchNum];
return legacyRollupIDToRollupData[rollupID].sequencedBatches[batchNum];
}

/**
* @notice Get rollup data: VerifierType StateTransition
* @param rollupID Rollup identifier
*/
function rollupIDToRollupData(
uint32 rollupID
) public view returns (RollupDataReturnStateTransistion memory rollupData) {
RollupData storage rollup = legacyRollupIDToRollupData[rollupID];

if (rollup.rollupVerifierType != VerifierType.StateTransition) {
revert InvalidVerifierType();
}

rollupData.rollupContract = rollup.rollupContract;
rollupData.chainID = rollup.chainID;
rollupData.verifier = rollup.verifier;
rollupData.forkID = rollup.forkID;
rollupData.lastLocalExitRoot = rollup.lastLocalExitRoot;
rollupData.lastBatchSequenced = rollup.lastBatchSequenced;
rollupData.lastVerifiedBatch = rollup.lastVerifiedBatch;
rollupData._legacyLastPendingState = rollup._legacyLastPendingState;
rollupData._legacyLastPendingStateConsolidated = rollup
._legacyLastPendingStateConsolidated;
rollupData.lastVerifiedBatchBeforeUpgrade = rollup
.lastVerifiedBatchBeforeUpgrade;
rollupData.rollupTypeID = rollup.rollupTypeID;
rollupData.rollupVerifierType = rollup.rollupVerifierType;
}

/**
* @notice Get rollup data: VerifierType Pessimistic
* @param rollupID Rollup identifier
*/
function rollupIDToRollupDataPessimistic(
uint32 rollupID
) public view returns (RollupDataReturnPessimistic memory rollupData) {
RollupData storage rollup = legacyRollupIDToRollupData[rollupID];

if (rollup.rollupVerifierType != VerifierType.Pessimistic) {
revert InvalidVerifierType();
}

rollupData.rollupContract = rollup.rollupContract;
rollupData.chainID = rollup.chainID;
rollupData.verifier = rollup.verifier;
rollupData.forkID = rollup.forkID;
rollupData.lastLocalExitRoot = rollup.lastLocalExitRoot;
rollupData.rollupTypeID = rollup.rollupTypeID;
rollupData.rollupVerifierType = rollup.rollupVerifierType;
rollupData.lastPessimisticRoot = rollup.lastPessimisticRoot;
rollupData.programVKey = rollup.programVKey;
}
}
5 changes: 5 additions & 0 deletions contracts/v2/interfaces/IPolygonRollupManager.sol
Original file line number Diff line number Diff line change
Expand Up @@ -302,6 +302,11 @@ interface IPolygonRollupManager {
*/
error InvalidPessimisticProof();

/**
* @dev Invalid Verifier Type when getting rollup data
*/
error InvalidVerifierType();

enum VerifierType {
StateTransition,
Pessimistic
Expand Down
2 changes: 1 addition & 1 deletion contracts/v2/mocks/PolygonRollupManagerMock.sol
Original file line number Diff line number Diff line change
Expand Up @@ -74,7 +74,7 @@ contract PolygonRollupManagerMock is PolygonRollupManager {

// Add local Exit roots;
for (uint256 i = 0; i < localExitRoots.length; i++) {
rollupIDToRollupData[uint32(i + 1)]
legacyRollupIDToRollupData[uint32(i + 1)]
.lastLocalExitRoot = localExitRoots[i];
}
}
Expand Down
Loading