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
review
  • Loading branch information
laisolizq authored and krlosMata committed Sep 15, 2024
commit ff3220c5d0a243691be8d9da749642f8e26386fb
180 changes: 155 additions & 25 deletions contracts/v2/PolygonRollupManager.sol
Original file line number Diff line number Diff line change
Expand Up @@ -65,12 +65,12 @@ contract PolygonRollupManager is
* @param forkID ForkID of the rollup
* @param batchNumToStateRoot State root mapping
* @param sequencedBatches Queue of batches that defines the virtual state
* @param pendingStateTransitionsDeprecated Pending state mapping (deprecated)
* @param _legacyPendingStateTransitions Pending state mapping (deprecated)
* @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 lastPendingStateDeprecated Last pending state (deprecated)
* @param lastPendingStateConsolidatedDeprecated Last pending state consolidated (deprecated)
* @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
Expand All @@ -83,12 +83,12 @@ contract PolygonRollupManager is
uint64 forkID;
mapping(uint64 batchNum => bytes32) batchNumToStateRoot;
mapping(uint64 batchNum => SequencedBatchData) sequencedBatches;
mapping(uint256 pendingStateNumDeprecated => PendingStateDeprecated) pendingStateTransitionsDeprecated;
mapping(uint256 _legacyPendingStateNum => PendingState) _legacyPendingStateTransitions;
bytes32 lastLocalExitRoot;
uint64 lastBatchSequenced;
uint64 lastVerifiedBatch;
uint64 lastPendingStateDeprecated;
uint64 lastPendingStateConsolidatedDeprecated;
uint64 _legacyLastPendingState;
uint64 _legacyLastPendingStateConsolidated;
uint64 lastVerifiedBatchBeforeUpgrade;
uint64 rollupTypeID;
VerifierType rollupVerifierType;
Expand Down Expand Up @@ -207,18 +207,18 @@ contract PolygonRollupManager is
uint64 internal __legacyTrustedAggregatorTimeout;

// Once a pending state exceeds this timeout it can be consolidated (deprecated)
uint64 public pendingStateTimeoutDeprecated;
uint64 internal __legacyPendingStateTimeout;

// Time target of the verification of a batch
// Adaptively the batchFee will be updated to achieve this target
uint64 internal __legacyVerifyBatchTimeTarget;

// Batch fee multiplier with 3 decimals that goes from 1000 - 1023
uint16 public multiplierBatchFeeDeprecated;
uint16 public multiplierBatchFee;

// Current POL fee per batch sequenced
// note This variable is internal, since the view function getBatchFee is likely to be upgraded
uint256 internal _batchFeeDeprecated;
uint256 internal _batchFee;

// Timestamp when the last emergency state was deactivated
uint64 public lastDeactivatedEmergencyStateTimestamp;
Expand Down Expand Up @@ -291,18 +291,34 @@ contract PolygonRollupManager is
address indexed aggregator
);

/**
* @dev Emitted when rollback batches
*/
event RollbackBatches(
uint32 indexed rollupID,
uint64 indexed targetBatch,
bytes32 accInputHashToRollback
);

/**
/**
* @dev Emitted when is updated the trusted aggregator timeout
*/
event SetTrustedAggregatorTimeout(uint64 newTrustedAggregatorTimeout);

/**
* @dev Emitted when is updated the multiplier batch fee
*/
event SetMultiplierBatchFee(uint16 newMultiplierBatchFee);

/**
* @dev Emitted when is updated the trusted aggregator address
*/
event SetTrustedAggregator(address newTrustedAggregator);

/**
* @dev Emitted when is updated the batch fee
*/
event SetBatchFee(uint256 newBatchFee);

/**
* @param _globalExitRootManager Global exit root manager address
Expand Down Expand Up @@ -727,6 +743,81 @@ contract PolygonRollupManager is
emit UpdateRollup(rollupID, newRollupTypeID, lastVerifiedBatch);
}

/**
* @notice Rollback batches of the target rollup
* Only applies to state transition rollups
* @param rollupContract Rollup consensus proxy address
* @param targetBatch Batch to rollback up to but not including this batch
*/
function rollbackBatches(
IPolygonRollupBase rollupContract,
uint64 targetBatch
) external {
// Check msg.sender has _UPDATE_ROLLUP_ROLE rol or is the admin of the network
if (
!hasRole(_UPDATE_ROLLUP_ROLE, msg.sender) &&
IPolygonRollupBase(address(rollupContract)).admin() != msg.sender
) {
revert NotAllowedAddress();
}

// Check the rollup exists
uint32 rollupID = rollupAddressToID[address(rollupContract)];
if (rollupID == 0) {
revert RollupMustExist();
}

// Load rollup
RollupData storage rollup = rollupIDToRollupData[rollupID];
uint64 lastBatchSequenced = rollup.lastBatchSequenced;

// Batch to rollback should be already sequenced
if (
targetBatch >= lastBatchSequenced ||
targetBatch < rollup.lastVerifiedBatch
) {
revert RollbackBatchIsNotValid();
}

uint64 currentBatch = lastBatchSequenced;

// delete sequence batches structs until the targetBatch
while (currentBatch != targetBatch) {
// Load previous end of sequence batch
uint64 previousBatch = rollup
.sequencedBatches[currentBatch]
.previousLastBatchSequenced;

// Batch to rollback must be end of a sequence
if (previousBatch < targetBatch) {
revert RollbackBatchIsNotEndOfSequence();
}

// delete sequence information
delete rollup.sequencedBatches[currentBatch];

// Update current batch for next iteration
currentBatch = previousBatch;
}

// Update last batch sequenced on rollup data
rollup.lastBatchSequenced = targetBatch;

// Update totalSequencedBatches
totalSequencedBatches -= lastBatchSequenced - targetBatch;

// Clean pending state if any
rollupContract.rollbackBatches(
targetBatch,
rollup.sequencedBatches[targetBatch].accInputHash
);

emit RollbackBatches(
rollupID,
targetBatch,
rollup.sequencedBatches[targetBatch].accInputHash
);
}

/////////////////////////////////////
// Sequence/Verify batches functions
Expand Down Expand Up @@ -778,7 +869,7 @@ contract PolygonRollupManager is
/**
* @notice Allows a trusted aggregator to verify multiple batches
* @param rollupID Rollup identifier
* @param pendingStateNumDeprecated Init pending state, 0 if consolidated state is used (deprecated)
* @param pendingStateNum Init pending state, 0 if consolidated state is used (deprecated)
* @param initNumBatch Batch which the aggregator starts the verification
* @param finalNewBatch Last batch aggregator intends to verify
* @param newLocalExitRoot New local exit root once the batch is processed
Expand All @@ -788,7 +879,7 @@ contract PolygonRollupManager is
*/
function verifyBatchesTrustedAggregator(
uint32 rollupID,
uint64 pendingStateNumDeprecated,
uint64 pendingStateNum,
uint64 initNumBatch,
uint64 finalNewBatch,
bytes32 newLocalExitRoot,
Expand All @@ -797,7 +888,9 @@ contract PolygonRollupManager is
bytes32[24] calldata proof
) external onlyRole(_TRUSTED_AGGREGATOR_ROLE) {

require(pendingStateNumDeprecated == 0, "pendingStateNumDeprecated must be 0 ");
if(pendingStateNum != 0) {
revert PendingStateNumExist();
}

RollupData storage rollup = rollupIDToRollupData[rollupID];

Expand All @@ -807,7 +900,7 @@ contract PolygonRollupManager is

_verifyAndRewardBatches(
rollup,
pendingStateNumDeprecated,
pendingStateNum,
initNumBatch,
finalNewBatch,
newLocalExitRoot,
Expand Down Expand Up @@ -976,7 +1069,7 @@ contract PolygonRollupManager is
/**
* @notice Verify and reward batches internal function
* @param rollup Rollup Data storage pointer that will be used to the verification
* @param pendingStateNumDeprecated Init pending state, 0 if consolidated state is used (deprecated)
* @param pendingStateNum Init pending state, 0 if consolidated state is used (deprecated)
* @param initNumBatch Batch which the aggregator starts the verification
* @param finalNewBatch Last batch aggregator intends to verify
* @param newLocalExitRoot New local exit root once the batch is processed
Expand All @@ -986,7 +1079,7 @@ contract PolygonRollupManager is
*/
function _verifyAndRewardBatches(
RollupData storage rollup,
uint64 pendingStateNumDeprecated,
uint64 pendingStateNum,
uint64 initNumBatch,
uint64 finalNewBatch,
bytes32 newLocalExitRoot,
Expand All @@ -996,7 +1089,9 @@ contract PolygonRollupManager is
) internal virtual {
bytes32 oldStateRoot;

require(pendingStateNumDeprecated == 0, "pendingStateTimeoutDeprecated must be 0 ");
if(pendingStateNum != 0) {
revert PendingStateNumExist();
}

uint64 currentLastVerifiedBatch = _getLastVerifiedBatch(rollup);

Expand Down Expand Up @@ -1135,6 +1230,33 @@ contract PolygonRollupManager is
emit SetTrustedAggregatorTimeout(newTrustedAggregatorTimeout);
}

/**
* @notice Set a new multiplier batch fee
* @param newMultiplierBatchFee multiplier batch fee
*/
function setMultiplierBatchFee(
uint16 newMultiplierBatchFee
) external onlyRole(_TWEAK_PARAMETERS_ROLE) {
if (newMultiplierBatchFee < 1000 || newMultiplierBatchFee > 1023) {
revert InvalidRangeMultiplierBatchFee();
}

multiplierBatchFee = newMultiplierBatchFee;
emit SetMultiplierBatchFee(newMultiplierBatchFee);
}

/**
* @notice Set the current batch fee
* @param newBatchFee new batch fee
*/
function setBatchFee(uint256 newBatchFee) external onlyRole(_SET_FEE_ROLE) {
// check fees min and max
if (newBatchFee > _MAX_BATCH_FEE || newBatchFee < _MIN_BATCH_FEE) {
revert BatchFeeOutOfRange();
}
_batchFee = newBatchFee;
emit SetBatchFee(newBatchFee);
}

////////////////////////
// view/pure functions
Expand Down Expand Up @@ -1225,14 +1347,7 @@ contract PolygonRollupManager is
function _getLastVerifiedBatch(
RollupData storage rollup
) internal view returns (uint64) {
if (rollup.lastPendingState > 0) {
return
rollup
.pendingStateTransitions[rollup.lastPendingState]
.lastVerifiedBatch;
} else {
return rollup.lastVerifiedBatch;
}
return rollup.lastVerifiedBatch;
}

/**
Expand All @@ -1249,6 +1364,21 @@ contract PolygonRollupManager is
return currentBalance / totalBatchesToVerify;
}

/**
* @notice Get batch fee
* This function is used instad of the automatic public view one,
* because in a future might change the behaviour and we will be able to mantain the interface
*/
function getBatchFee() public view returns (uint256) {
return _batchFee;
}

/**
* @notice Get forced batch fee
*/
function getForcedBatchFee() public view returns (uint256) {
return _batchFee * 100;
}

/**
* @notice Function to calculate the pessimistic input bytes
Expand Down
12 changes: 9 additions & 3 deletions contracts/v2/interfaces/IPolygonRollupManager.sol
Original file line number Diff line number Diff line change
Expand Up @@ -278,17 +278,23 @@ interface IPolygonRollupManager {
error InvalidRollup();

/**
* @dev Global exit root deos not exists
* @dev Global exit root does not exists
*/
error GlobalExitRootNotExist();

/**
* @dev Global exit root deos not exists
* @dev Only Pessimistic Chains
*/
error OnlyPessimisticChains();

/**
* @dev Global exit root deos not exists
* @dev Only State Transition Chains
*/
error OnlyStateTransitionChains();

/**
* @dev Pending state num exist
*/
error PendingStateNumExist();

}
Loading