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

New simple SDK #2

Merged
merged 123 commits into from
Dec 11, 2024
Merged
Show file tree
Hide file tree
Changes from 1 commit
Commits
Show all changes
123 commits
Select commit Hold shift + click to select a range
837ae96
feat: new sdk
alrxy Oct 1, 2024
ae49372
refactor: arch with abstract contracts
alrxy Oct 2, 2024
dbbd79d
refactor: redundant key management
alrxy Oct 2, 2024
3898883
refactor: add hints for slashing, gettters
alrxy Oct 4, 2024
2c3114a
fix: optimize our data structure with times, add vault init check, va…
alrxy Oct 8, 2024
7278b86
refactor: changed timestamps to epoch
alrxy Oct 9, 2024
9ba23ec
feat: new example
1kresh Oct 18, 2024
7d8c5d9
chore: set [email protected]
1kresh Oct 18, 2024
f4d1117
test: add simple middleware tests
alrxy Oct 23, 2024
f221bee
Merge branch 'new-simple-sdk' into new-example
alrxy Oct 24, 2024
4fc50f2
Merge pull request #3 from symbioticfi/new-example
alrxy Oct 24, 2024
e7c382b
chore: Readme and fixes
alrxy Oct 24, 2024
6856448
add LICENSE
algys Oct 24, 2024
a18076d
fix: add opeartors vault check on slash
alrxy Oct 24, 2024
d98f473
chore: add notice epoch starts from 1
alrxy Oct 24, 2024
7f3b5ac
fix: no additional epoch between pause/unpause
alrxy Oct 24, 2024
d63c92a
fix: vault slash check and blskeymanager get key check
alrxy Oct 24, 2024
326c242
fix was active at
alrxy Oct 24, 2024
7aa21a2
fix: wasActiveAt bug and validateUnregister/Unpause
alrxy Oct 24, 2024
b5488cd
fix: unpause/unregister validation
alrxy Oct 24, 2024
4af8fed
chore: start epoch from 0
alrxy Oct 24, 2024
03dbdf2
fix: sdk fixes with tests
alrxy Oct 31, 2024
b048bbe
tests: add tests
alrxy Oct 31, 2024
76ab4db
test: slash stake tests
alrxy Nov 5, 2024
e28288a
refactor: separate modules as default and base
alrxy Nov 5, 2024
2bb43f8
refactor: tests adapt
alrxy Nov 5, 2024
ef71272
refactor: add checks, make virtual some public functions and add was …
alrxy Nov 6, 2024
97e4952
fix: vault inactive slash check
alrxy Nov 6, 2024
6b85333
refactor: readme and arch img
alrxy Nov 6, 2024
57be776
refactor: move examples to examples dir
alrxy Nov 6, 2024
87878df
refactor: make initializble, add all network active vaults getter, su…
alrxy Nov 9, 2024
9e64c77
WIP: removed epochs
algys Nov 9, 2024
25b0899
WIP: fixed almost all compilation issues
algys Nov 10, 2024
2036ec1
WIP: bumped solc version up to 0.8.26 to avoid compilation error
algys Nov 10, 2024
3b86efd
WIP: reworked BaseKeyRegistry
algys Nov 10, 2024
7756d0e
fix: now compile tests
alrxy Nov 10, 2024
99ce066
fixed capture timestamp
gm256 Nov 11, 2024
10fb317
fixed capture timestamp
gm256 Nov 11, 2024
1185593
WIP: new structure with extensions
algys Nov 11, 2024
35873af
refactor: reorganized and add selfresgiterOM
alrxy Nov 11, 2024
e7d8efb
fixed set
gm256 Nov 12, 2024
171e268
Merge branch 'new-simple-sdk' of github.com:symbioticfi/middleware-sd…
gm256 Nov 12, 2024
a656bc0
merge
algys Nov 12, 2024
5ce6284
feat: add sumberworks extension
algys Nov 12, 2024
d3b7810
feat: add oz access managed
algys Nov 12, 2024
4ba578c
fix: selfregisteroperator
alrxy Nov 12, 2024
8799115
temp_commit
gm256 Nov 12, 2024
40f0535
Merge branch 'new-simple-sdk' of github.com:symbioticfi/middleware-sd…
gm256 Nov 12, 2024
358c148
chore: rename key storages
algys Nov 12, 2024
dbf47e9
feat: add ed25519 sig
alrxy Nov 12, 2024
135af7f
added tests
gm256 Nov 12, 2024
81794a3
Merge branch 'new-simple-sdk' of github.com:symbioticfi/middleware-sd…
gm256 Nov 12, 2024
cf13039
fmt
gm256 Nov 12, 2024
6f792d3
feat: key sigs
alrxy Nov 12, 2024
41bc52a
fix: can compile without via-ir
alrxy Nov 14, 2024
aeb2a9d
Merge branch 'new-simple-sdk' into ed25519/ecdsa
alrxy Nov 14, 2024
77e909b
tests: ed25519 tests and refactor
alrxy Nov 16, 2024
1b76443
refactor: add recover function and ecrecover via OZ ECDSA
Nov 18, 2024
5bac83f
refactor: recover is internal
alrxy Nov 18, 2024
c41c8b5
refactor keys and self register operators
alrxy Nov 20, 2024
c404675
refactor: add checkunregister function for bytes32/bytes sets
alrxy Nov 20, 2024
47e8e30
refactor: forge fmt
alrxy Nov 20, 2024
1d17825
refactor: fix docstrings and capture timestamps add
alrxy Nov 21, 2024
4bd51ed
refactor: add check for ed25519sig contract
alrxy Nov 21, 2024
07ba6f1
fix: disallow unpause/unregister in forceoperators
alrxy Nov 21, 2024
67b2ba5
Merge pull request #4 from symbioticfi/ed25519/ecdsa
alrxy Nov 21, 2024
75d9a73
chore: adjust workflows
1kresh Nov 21, 2024
9787a88
feat: make direct storage access
alrxy Nov 21, 2024
22add8a
feat: add enabled constant var getter for extensions
alrxy Nov 21, 2024
31167e4
fix: adjust slot hashes
1kresh Nov 21, 2024
8e322a8
forge install: crypto-lib
alrxy Nov 25, 2024
05ecd75
fix: arbitrary len ed25519 sig
alrxy Nov 25, 2024
c7efb34
fix: ed25519 licence
alrxy Nov 25, 2024
47e83cb
Merge pull request #5 from symbioticfi/fix-ed25519
alrxy Nov 26, 2024
8247e9b
refactor: rename ed25519 to eddsa, key storage to extensions, add bas…
alrxy Nov 26, 2024
dacbed3
fix: lint
alrxy Nov 26, 2024
7818c55
feat: versions instead of enabled
alrxy Nov 26, 2024
40b0450
fix: non-revert noaccessmanager and init owner in sqrttaskmiddleware
alrxy Nov 26, 2024
0b16b20
fix: init not override in sqrttaskmiddleware
alrxy Nov 26, 2024
fe7276a
chore: readme
alrxy Nov 27, 2024
2f5ed47
fix: basemiddleware docstrings
alrxy Nov 27, 2024
e875a73
feat: stake to power extensions
alrxy Nov 27, 2024
70f9ef7
refactor: remove operator stake public function
alrxy Nov 27, 2024
b24cbc0
feat: OzAccessControl
alrxy Nov 27, 2024
c81f6f8
feat: validate operator vault
alrxy Dec 2, 2024
019433a
fix: add operator vault validation
alrxy Dec 2, 2024
52ae4ff
fix: statemind-Double import of IVetoSlasher in VaultManager.sol
alrxy Dec 2, 2024
96b7949
fix: lint tests
alrxy Dec 2, 2024
702a09d
fix: statemind-Extra SLOAD and MLOAD calls
alrxy Dec 2, 2024
e772f1a
fix: statemind-Unused errors in the OperatorManager contract
alrxy Dec 2, 2024
1f5ca0f
fix: statemind-Typos
alrxy Dec 2, 2024
9992230
fix: Vault Check is outside VaultManager._validateVault()
alrxy Dec 2, 2024
3101f0f
fix: statemind-Missing slasher check
alrxy Dec 2, 2024
da22200
fix: optimize vault manager code reusing
alrxy Dec 2, 2024
95e4fd8
chore: make stake functions private
alrxy Dec 4, 2024
c7a044d
chore: rm getOperatorStake function
alrxy Dec 4, 2024
07e7171
WIP: restructure
alrxy Dec 5, 2024
639a351
feat: external read helper
alrxy Dec 5, 2024
81c65f1
chore: clean base middleware
alrxy Dec 5, 2024
990cf3e
fix: read helper
alrxy Dec 6, 2024
3957a61
refactor: restructure managers
alrxy Dec 6, 2024
a99aecb
chore: lint
alrxy Dec 6, 2024
93b9ed1
chore: interfaces and readme
alrxy Dec 6, 2024
52567e0
chore: lint
alrxy Dec 6, 2024
623be0a
chore: wip and under audits mention
alrxy Dec 6, 2024
3a30665
fix: statemind-Unable to unregister operator's key
alrxy Dec 9, 2024
d3aa340
fix: statemind-Extra memory value calls in SimplePosMiddleware._slash…
alrxy Dec 9, 2024
4cfbacd
fix: statemind-SimplePosMiddleware gas optimizations
alrxy Dec 9, 2024
838b0e6
fix: statemind-Redundant module in SqrtTaskMiddleware
alrxy Dec 9, 2024
140db6b
fix:statemind-Inconsistency between Epoch and Timestamp
alrxy Dec 9, 2024
eebbe5d
fix:statemind-Zero check for owner
alrxy Dec 9, 2024
a18cb65
fix:statemind-Incorrect storage slot location
alrxy Dec 9, 2024
e80e1e3
fix: statemind-Use custom errors instead of require
alrxy Dec 9, 2024
49e456f
fix:statemind-Multiple Time.timestamp() calls optimization
alrxy Dec 9, 2024
43d5462
fix:statemind-Typos
alrxy Dec 9, 2024
1fc8c32
fix:statemind-Missing Veto Slasher consideration
alrxy Dec 9, 2024
9deff3f
chore: add epoch duration getter
alrxy Dec 9, 2024
3832990
fix: docstrings and reader
alrxy Dec 11, 2024
1b8cec1
fix: register default subnetwork 0
alrxy Dec 11, 2024
5e24395
fix: lint
alrxy Dec 11, 2024
48828bb
chore: upd readme
alrxy Dec 11, 2024
a931af1
fix: selfed middleware
alrxy Dec 11, 2024
7470662
fix: docstring
alrxy Dec 11, 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
2 changes: 1 addition & 1 deletion lib/core
Submodule core updated 81 files
+2 −2 README.md
+1 −1 package.json
+18 −2 script/deploy/Core.s.sol
+2 −2 script/deploy/OptInService.s.sol
+63 −41 script/deploy/Vault.s.sol
+8 −20 src/contracts/VaultConfigurator.sol
+1 −1 src/contracts/common/Entity.sol
+31 −4 src/contracts/common/Factory.sol
+15 −15 src/contracts/common/MigratableEntity.sol
+32 −13 src/contracts/common/MigratablesFactory.sol
+30 −10 src/contracts/delegator/BaseDelegator.sol
+2 −2 src/contracts/delegator/FullRestakeDelegator.sol
+2 −2 src/contracts/delegator/NetworkRestakeDelegator.sol
+153 −0 src/contracts/delegator/OperatorSpecificDelegator.sol
+67 −0 src/contracts/hints/DelegatorHints.sol
+1 −1 src/contracts/hints/OptInServiceHints.sol
+38 −5 src/contracts/hints/SlasherHints.sol
+2 −2 src/contracts/libraries/Checkpoints.sol
+2 −2 src/contracts/libraries/ERC4626Math.sol
+21 −0 src/contracts/libraries/LICENSE
+2 −2 src/contracts/libraries/Subnetwork.sol
+106 −15 src/contracts/service/OptInService.sol
+58 −12 src/contracts/slasher/BaseSlasher.sol
+2 −6 src/contracts/slasher/Slasher.sol
+9 −13 src/contracts/slasher/VetoSlasher.sol
+121 −44 src/contracts/vault/Vault.sol
+13 −3 src/contracts/vault/VaultStorage.sol
+112 −0 src/contracts/vault/VaultTokenized.sol
+2 −2 src/interfaces/IDelegatorFactory.sol
+2 −2 src/interfaces/INetworkRegistry.sol
+2 −2 src/interfaces/IOperatorRegistry.sol
+2 −2 src/interfaces/ISlasherFactory.sol
+3 −5 src/interfaces/IVaultConfigurator.sol
+2 −2 src/interfaces/IVaultFactory.sol
+21 −0 src/interfaces/LICENSE
+0 −99 src/interfaces/collateral/ICollateral.sol
+4 −2 src/interfaces/common/IEntity.sol
+32 −4 src/interfaces/common/IFactory.sol
+3 −3 src/interfaces/common/IMigratableEntity.sol
+3 −5 src/interfaces/common/IMigratableEntityProxy.sol
+31 −9 src/interfaces/common/IMigratablesFactory.sol
+2 −2 src/interfaces/common/IRegistry.sol
+18 −2 src/interfaces/delegator/IBaseDelegator.sol
+2 −1 src/interfaces/delegator/IDelegatorHook.sol
+2 −1 src/interfaces/delegator/IFullRestakeDelegator.sol
+2 −1 src/interfaces/delegator/INetworkRestakeDelegator.sol
+88 −0 src/interfaces/delegator/IOperatorSpecificDelegator.sol
+2 −2 src/interfaces/service/IMetadataService.sol
+2 −2 src/interfaces/service/INetworkMiddlewareService.sol
+50 −6 src/interfaces/service/IOptInService.sol
+25 −6 src/interfaces/slasher/IBaseSlasher.sol
+2 −2 src/interfaces/slasher/ISlasher.sol
+4 −4 src/interfaces/slasher/IVetoSlasher.sol
+70 −8 src/interfaces/vault/IVault.sol
+14 −2 src/interfaces/vault/IVaultStorage.sol
+18 −0 src/interfaces/vault/IVaultTokenized.sol
+36 −25 test/DelegatorFactory.t.sol
+27 −0 test/POC.t.sol
+652 −0 test/POCBase.t.sol
+38 −27 test/SlasherFactory.t.sol
+37 −81 test/VaultConfigurator.t.sol
+36 −23 test/VaultFactory.t.sol
+3 −3 test/common/Entity.t.sol
+25 −5 test/common/Factory.t.sol
+7 −32 test/common/MigratableEntity.t.sol
+3 −3 test/common/MigratableEntityProxy.t.sol
+31 −10 test/common/MigratablesFactory.t.sol
+1 −1 test/common/Registry.t.sol
+189 −64 test/delegator/FullRestakeDelegator.t.sol
+187 −62 test/delegator/NetworkRestakeDelegator.t.sol
+1,636 −0 test/delegator/OperatorSpecificDelegator.t.sol
+0 −99 test/mocks/SimpleCollateral.sol
+7 −3 test/mocks/SimpleFullRestakeDelegatorHook.sol
+1 −1 test/mocks/SimpleMigratableEntity.sol
+7 −3 test/mocks/SimpleNetworkRestakeDelegatorHook.sol
+20 −0 test/mocks/SimpleOperatorSpecificDelegatorHook.sol
+309 −6 test/service/OptInService.t.sol
+344 −90 test/slasher/Slasher.t.sol
+284 −128 test/slasher/VetoSlasher.t.sol
+752 −389 test/vault/Vault.t.sol
+3,102 −0 test/vault/VaultTokenized.t.sol
2 changes: 1 addition & 1 deletion lib/openzeppelin-contracts
Submodule openzeppelin-contracts updated 83 files
+5 −0 .changeset/four-chairs-help.md
+8 −0 .solcover.js
+1 −1 CHANGELOG.md
+7 −0 GUIDELINES.md
+ audits/2024-10-v5.1.pdf
+1 −0 audits/README.md
+2 −0 contracts/access/Ownable2Step.sol
+2 −2 contracts/finance/VestingWallet.sol
+4 −2 contracts/finance/VestingWalletCliff.sol
+2 −2 contracts/governance/Governor.sol
+3 −0 contracts/governance/IGovernor.sol
+4 −2 contracts/governance/extensions/GovernorCountingFractional.sol
+16 −6 contracts/governance/extensions/GovernorStorage.sol
+1 −1 contracts/governance/utils/Votes.sol
+1 −1 contracts/interfaces/IERC1363Receiver.sol
+1 −1 contracts/interfaces/IERC1363Spender.sol
+2 −2 contracts/metatx/ERC2771Forwarder.sol
+1 −51 contracts/mocks/StorageSlotMock.sol
+61 −0 contracts/mocks/TransientSlotMock.sol
+141 −0 contracts/proxy/Clones.sol
+1 −6 contracts/proxy/transparent/TransparentUpgradeableProxy.sol
+4 −2 contracts/token/ERC1155/utils/ERC1155Utils.sol
+2 −0 contracts/token/ERC20/extensions/ERC1363.sol
+1 −1 contracts/token/ERC20/extensions/ERC4626.sol
+7 −8 contracts/token/ERC20/extensions/draft-ERC20TemporaryApproval.sol
+2 −0 contracts/token/ERC721/utils/ERC721Utils.sol
+4 −1 contracts/token/common/ERC2981.sol
+1 −0 contracts/utils/Base64.sol
+5 −0 contracts/utils/Comparators.sol
+2 −0 contracts/utils/Errors.sol
+2 −0 contracts/utils/Packing.sol
+2 −0 contracts/utils/Panic.sol
+8 −1 contracts/utils/README.adoc
+4 −2 contracts/utils/ReentrancyGuardTransient.sol
+4 −2 contracts/utils/SlotDerivation.sol
+1 −169 contracts/utils/StorageSlot.sol
+182 −0 contracts/utils/TransientSlot.sol
+10 −3 contracts/utils/cryptography/ECDSA.sol
+3 −1 contracts/utils/cryptography/Hashes.sol
+4 −4 contracts/utils/cryptography/MerkleProof.sol
+88 −36 contracts/utils/cryptography/P256.sol
+26 −18 contracts/utils/cryptography/RSA.sol
+1 −1 contracts/utils/introspection/ERC165Checker.sol
+30 −6 contracts/utils/structs/Checkpoints.sol
+12 −3 contracts/utils/structs/CircularBuffer.sol
+55 −55 contracts/utils/structs/EnumerableMap.sol
+83 −404 contracts/utils/structs/Heap.sol
+15 −12 contracts/utils/structs/MerkleTree.sol
+6 −3 contracts/utils/types/Time.sol
+1 −1 docs/modules/ROOT/pages/erc4626.adoc
+8 −8 docs/modules/ROOT/pages/utilities.adoc
+1 −1 fv-requirements.txt
+1 −1 lib/forge-std
+5 −0 scripts/generate/helpers/sanitize.js
+2 −2 scripts/generate/run.js
+10 −2 scripts/generate/templates/Checkpoints.js
+13 −13 scripts/generate/templates/EnumerableMap.js
+0 −327 scripts/generate/templates/Heap.js
+0 −13 scripts/generate/templates/Heap.opts.js
+0 −89 scripts/generate/templates/Heap.t.js
+1 −1 scripts/generate/templates/MerkleProof.js
+7 −4 scripts/generate/templates/Packing.js
+2 −0 scripts/generate/templates/Slot.opts.js
+4 −1 scripts/generate/templates/SlotDerivation.js
+14 −0 scripts/generate/templates/SlotDerivation.t.js
+1 −55 scripts/generate/templates/StorageSlot.js
+1 −14 scripts/generate/templates/StorageSlotMock.js
+80 −0 scripts/generate/templates/TransientSlot.js
+35 −0 scripts/generate/templates/TransientSlotMock.js
+17 −0 test/access/Ownable2Step.test.js
+11 −8 test/governance/utils/ERC6372.behavior.js
+2 −2 test/helpers/iterate.js
+34 −2 test/proxy/Clones.t.sol
+151 −71 test/proxy/Clones.test.js
+20 −0 test/utils/SlotDerivation.t.sol
+0 −33 test/utils/StorageSlot.test.js
+59 −0 test/utils/TransientSlot.test.js
+13 −104 test/utils/cryptography/P256.t.sol
+53 −48 test/utils/cryptography/RSA.test.js
+4 −0 test/utils/structs/CircularBuffer.test.js
+2 −81 test/utils/structs/Heap.t.sol
+86 −104 test/utils/structs/Heap.test.js
+11 −11 test/utils/structs/MerkleTree.test.js
20 changes: 17 additions & 3 deletions src/BLSKeyManager.sol
Original file line number Diff line number Diff line change
Expand Up @@ -4,21 +4,27 @@ pragma solidity 0.8.25;
import {Time} from "@openzeppelin/contracts/utils/types/Time.sol";

import {MiddlewareStorage} from "./MiddlewareStorage.sol";
import {ArrayWithTimes} from "./libraries/ArrayWithTimes.sol";
import {EnumerableSetWithTimeData} from "./libraries/EnumerableSetWithTimeData.sol";

abstract contract BLSKeyManager is MiddlewareStorage {
using ArrayWithTimes for ArrayWithTimes.Address;
using EnumerableSetWithTimeData for EnumerableSetWithTimeData.Inner;

error DuplicateBLSKey();
error FreshBLSKey();

mapping(address => bytes) public blsKeys;
mapping(bytes => ArrayWithTimes.Address) internal blsKeyData;
mapping(address => bytes) public prevBLSKeys;
mapping(bytes => EnumerableSetWithTimeData.Inner) internal blsKeyData;

function operatorByBLSKey(bytes memory key) public view returns (address) {
return blsKeyData[key].getAddress();
}

function operatorBLSKey(address operator) public view returns (bytes memory) {
if (blsKeyData[blsKeys[operator]].enabled == Time.timestamp()) {
return prevBLSKeys[operator];
}

return blsKeys[operator];
}

Expand All @@ -31,6 +37,14 @@ abstract contract BLSKeyManager is MiddlewareStorage {
revert DuplicateBLSKey();
}

alrxy marked this conversation as resolved.
Show resolved Hide resolved
if (keccak256(blsKeys[operator]) != keccak256("")) {
if (blsKeyData[blsKeys[operator]].enabled == Time.timestamp()) {
revert FreshBLSKey();
}

prevBLSKeys[operator] = blsKeys[operator];
}

blsKeys[operator] = key;
blsKeyData[key].set(operator);
}
Expand Down
20 changes: 17 additions & 3 deletions src/KeyManager.sol
Original file line number Diff line number Diff line change
Expand Up @@ -4,21 +4,27 @@ pragma solidity 0.8.25;
import {Time} from "@openzeppelin/contracts/utils/types/Time.sol";

import {MiddlewareStorage} from "./MiddlewareStorage.sol";
import {ArrayWithTimes} from "./libraries/ArrayWithTimes.sol";
import {EnumerableSetWithTimeData} from "./libraries/EnumerableSetWithTimeData.sol";

abstract contract KeyManager is MiddlewareStorage {
using ArrayWithTimes for ArrayWithTimes.Address;
using EnumerableSetWithTimeData for EnumerableSetWithTimeData.Inner;

error DuplicateKey();
error FreshKey();

mapping(address => bytes32) public keys;
mapping(bytes32 => ArrayWithTimes.Address) internal keyData;
mapping(address => bytes32) public prevKeys;
mapping(bytes32 => EnumerableSetWithTimeData.Inner) internal keyData;

function operatorByKey(bytes32 key) public view returns (address) {
return keyData[key].getAddress();
}

function operatorKey(address operator) public view returns (bytes32) {
if (keyData[keys[operator]].enabled == Time.timestamp()) {
return prevKeys[operator];
}

return keys[operator];
}

Expand All @@ -31,6 +37,14 @@ abstract contract KeyManager is MiddlewareStorage {
revert DuplicateKey();
}

alrxy marked this conversation as resolved.
Show resolved Hide resolved
if (keys[operator] != bytes32(0)) {
if (keyData[keys[operator]].enabled == Time.timestamp()) {
revert FreshKey();
}

prevKeys[operator] = keys[operator];
}

keys[operator] = key;
keyData[key].set(operator);
}
Expand Down
5 changes: 1 addition & 4 deletions src/MiddlewareStorage.sol
Original file line number Diff line number Diff line change
Expand Up @@ -4,8 +4,6 @@ pragma solidity 0.8.25;
import {Ownable} from "@openzeppelin/contracts/access/Ownable.sol";

abstract contract MiddlewareStorage is Ownable {
uint256 public subnetworks;

address public immutable NETWORK;
uint48 public immutable SLASHING_WINDOW;
address public immutable VAULT_REGISTRY;
Expand All @@ -14,6 +12,7 @@ abstract contract MiddlewareStorage is Ownable {

uint64 public constant INSTANT_SLASHER_TYPE = 0;
uint64 public constant VETO_SLASHER_TYPE = 1;
uint160 public constant DEFAULT_SUBNETWORK = 0;
alrxy marked this conversation as resolved.
Show resolved Hide resolved

constructor(
address owner,
Expand All @@ -23,8 +22,6 @@ abstract contract MiddlewareStorage is Ownable {
address operatorRegistry,
address operatorNetOptIn
) Ownable(owner) {
subnetworks = 1;

NETWORK = network;
SLASHING_WINDOW = slashingWindow;
VAULT_REGISTRY = vaultRegistry;
Expand Down
6 changes: 3 additions & 3 deletions src/OperatorManager.sol
Original file line number Diff line number Diff line change
Expand Up @@ -9,17 +9,17 @@ import {Ownable} from "@openzeppelin/contracts/access/Ownable.sol";
import {Math} from "@openzeppelin/contracts/utils/math/Math.sol";

import {MiddlewareStorage} from "./MiddlewareStorage.sol";
import {ArrayWithTimes} from "./libraries/ArrayWithTimes.sol";
import {EnumerableSetWithTimeData} from "./libraries/EnumerableSetWithTimeData.sol";

abstract contract OperatorManager is MiddlewareStorage {
using ArrayWithTimes for ArrayWithTimes.AddressArray;
using EnumerableSetWithTimeData for EnumerableSetWithTimeData.AddressSet;

error NotOperator();
error OperatorNotOptedIn();
error OperatorNotRegistered();
error OperatorAlreadyRegistred();

ArrayWithTimes.AddressArray internal operators;
EnumerableSetWithTimeData.AddressSet internal operators;

function operatorsLength() external view returns (uint256) {
return operators.length();
Expand Down
47 changes: 39 additions & 8 deletions src/VaultManager.sol
Original file line number Diff line number Diff line change
Expand Up @@ -14,13 +14,16 @@ import {Time} from "@openzeppelin/contracts/utils/types/Time.sol";
import {Math} from "@openzeppelin/contracts/utils/math/Math.sol";

import {MiddlewareStorage} from "./MiddlewareStorage.sol";
import {ArrayWithTimes} from "./libraries/ArrayWithTimes.sol";
import {EnumerableSetWithTimeData} from "./libraries/EnumerableSetWithTimeData.sol";

abstract contract VaultManager is MiddlewareStorage {
using ArrayWithTimes for ArrayWithTimes.AddressArray;
using EnumerableSetWithTimeData for EnumerableSetWithTimeData.AddressSet;
using EnumerableSetWithTimeData for EnumerableSetWithTimeData.Uint160Set;

using Subnetwork for address;

error NotVault();
error VaultNotInitialized();
error VaultNotRegistered();
error VaultAlreadyRegistred();
error VaultEpochTooShort();
Expand All @@ -33,8 +36,10 @@ abstract contract VaultManager is MiddlewareStorage {
error UnknownSlasherType();
error NonVetoSlasher();

ArrayWithTimes.AddressArray internal sharedVaults;
mapping(address => ArrayWithTimes.AddressArray) internal operatorVaults;
EnumerableSetWithTimeData.Uint160Set subnetworks;

EnumerableSetWithTimeData.AddressSet internal sharedVaults;
mapping(address => EnumerableSetWithTimeData.AddressSet) internal operatorVaults;

struct SlashResponse {
address vault;
Expand All @@ -43,6 +48,18 @@ abstract contract VaultManager is MiddlewareStorage {
uint256 response; // if instant slashed amount else slash index
}

constructor() {
subnetworks.register(DEFAULT_SUBNETWORK);
}

function subnetworksLength() external view returns (uint256) {
alrxy marked this conversation as resolved.
Show resolved Hide resolved
return subnetworks.length();
}

function subnetworkWithTimesAt(uint256 pos) external view returns (uint160, uint48, uint48) {
return subnetworks.at(pos);
}

function sharedVaultsLength() external view returns (uint256) {
return sharedVaults.length();
}
Expand All @@ -64,6 +81,10 @@ abstract contract VaultManager is MiddlewareStorage {
return stake;
}

function activeSubnetworks(uint48 timestamp) public view returns (uint160[] memory) {
return subnetworks.getActive(timestamp);
}

function activeVaults(address operator, uint48 timestamp) public view returns (address[] memory) {
address[] memory activeSharedVaults = sharedVaults.getActive(timestamp);
address[] memory activeOperatorVaults = operatorVaults[operator].getActive(timestamp);
Expand Down Expand Up @@ -116,11 +137,12 @@ abstract contract VaultManager is MiddlewareStorage {

function getOperatorStake(address operator, uint48 timestamp) public view returns (uint256 stake) {
address[] memory vaults = activeVaults(operator, timestamp);
uint160[] memory _subnetworks = activeSubnetworks(timestamp);

for (uint256 i; i < vaults.length; ++i) {
address vault = vaults[i];
for (uint96 subnet = 0; subnet < subnetworks; ++subnet) {
bytes32 subnetwork = NETWORK.subnetwork(subnet);
for (uint256 j; j < _subnetworks.length; ++j) {
bytes32 subnetwork = NETWORK.subnetwork(uint96(_subnetworks[j]));
stake += IBaseDelegator(IVault(vault).delegator()).stakeAt(subnetwork, operator, timestamp, "");
}
}
Expand All @@ -130,11 +152,12 @@ abstract contract VaultManager is MiddlewareStorage {

function getOperatorPower(address operator, uint48 timestamp) public view returns (uint256 power) {
address[] memory vaults = activeVaults(operator, timestamp);
uint160[] memory _subnetworks = activeSubnetworks(timestamp);

for (uint256 i; i < vaults.length; ++i) {
address vault = vaults[i];
for (uint96 subnet = 0; subnet < subnetworks; ++subnet) {
bytes32 subnetwork = NETWORK.subnetwork(subnet);
for (uint256 j; j < _subnetworks.length; ++j) {
bytes32 subnetwork = NETWORK.subnetwork(uint96(_subnetworks[j]));
uint256 stake = IBaseDelegator(IVault(vault).delegator()).stakeAt(subnetwork, operator, timestamp, "");
power += stakeToPower(vault, stake);
}
Expand Down Expand Up @@ -168,6 +191,10 @@ abstract contract VaultManager is MiddlewareStorage {
uint256 amount,
bytes calldata hints
) internal returns (SlashResponse memory resp) {
if (!sharedVaults.contains(vault)) {
alrxy marked this conversation as resolved.
Show resolved Hide resolved
revert NotVault();
}

address slasher = IVault(vault).slasher();
alrxy marked this conversation as resolved.
Show resolved Hide resolved
uint64 slasherType = IEntity(slasher).TYPE();
resp.vault = vault;
Expand Down Expand Up @@ -205,6 +232,10 @@ abstract contract VaultManager is MiddlewareStorage {
revert NotVault();
}

if (!IVault(vault).isInitialized()) {
revert VaultNotInitialized();
}

uint48 vaultEpoch = IVault(vault).epochDuration();

address slasher = IVault(vault).slasher();
Expand Down
Loading