K2 Native Delegation Module for MEV Plus
Plus module for performing K2 native delegation registrations and restaking cloud participation.
The K2 native delegation module for MEV Plus gives node runners the ability to automate their Proposer Registry and K2 validator native delegation registrations without the need for external parties or exposing validator keys outside of the node. Additionally their keys can easily be changed on their node as and when they wish and the module would facilitate this automatic registration without the need for extra steps or further action from the user.
Exiting K2 and Rewards claiming can also be programmatically configured by the user, turning contract interactions for validators to simple and better managed calls through MEV Plus.
Tutorial
To follow a tutorial for the installation of the K2 native delegation module click here.
Prerequisites
-
MEV Plus with K2 Native Delegation module plugged in.
-
Eth1 Wallet: You should have an Ethereum wallet with sufficient funds to pay for gas fees. This wallet is used to pay for gas fees when interacting with the Proposer Registry and K2 contracts.
-
MEV Plus connected to node by Builder API: The module requires the node to be connected to MEV Plus through the Builder API. This is required for the module to receive the presigned messages from the node and register validators on-chain.
Supported Networks
Please note that currently only Goerli
supports native delegation at this time. However, Mainnet
supports native delegation pre-registration
due to the proposer registry deployments already existing on mainnet.
PoN deployment information can be found here:
https://github.com/pon-network/contract-deployments
Configuration
You can configure the K2 Native Delegation module using the following flags:
Required Flags
-
k2.eth1-private-key
: The private key of the proposer(s) representative wallet. This key is essential for signing registration messages and interacting with all the smart contracts.
NOTE: This key is the only wallet key that would be granted permission to manage validators on-chain and act as their representative. Keep this wallet safe.
-
k2.beacon-node-url
: The URL of the beacon node. This URL is required for syncing with the Ethereum Consensus Layer.
-
k2.execution-node-url
: The URL of the execution node to connect to for on-chain execution.
Optional Flags
-
k2.registration-only
: This flag is used to register validators on-chain in the Proposer Registry without natively delegating them to the K2 contract pool.
-
k2.web3-signer-url
: The module supports the use of a Web3Signer to sign custom registration messages with a modified payout recipient address from the one configured on the node. This flag is optional and can be used to configure the Web3Signer URL. The validator keys to which their registration messages wish to be signed should be configured on the Web3Signer.
-
k2.payout-recipient
: The address of an alternative globally configured payout recipient. This address will be used for all validators if specified. If not specified, the payout recipient address configured on the node for each validator key will be used. To use this flag, the k2.web3-signer-url
flag must also be specified in order to sign the registration messages with the alternative payout recipient address.
-
k2.max-gas-price
: The maximum gas price to be used for on-chain transactions. This flag is optional and defaults to 10 Gwei if not specified. If in any registration, the gas price exceeds the maximum gas price, the registration/delegation will be skipped for that epoch.
-
k2.listen-address
: The address on which the module will listen for incoming requests. This flag is optional and defaults to localhost:10000
if not specified. The API specifications can be found here.
-
k2.claim-threshold
: The threshold for claiming rewards from the K2 contract. This flag is optional and defaults to 0.0 KETH if not specified (claims any available rewards). If the rewards for a validator exceed the threshold, the rewards will be claimed from the K2 contract upon any request to the API.
-
k2.exclusion-list
: This flag is used to specify a list of validator public keys to exclude from either on-chain registration or native delegation. The flag accepts a filepath to a JSON file containing the list of validator public keys to exclude. The file is continuously monitored by the software and would pick up any changes immediately, allowing you to manage your registrations without restarting MEV Plus. The JSON file should be in the following format:
[
{
"publicKey": string,
"excludedFromProposerRegistration": bool,
"excludedFromNativeDelegation": bool
}
]
eg. k2.exclusion-list ./exclusion-list.json
[
{
"publicKey": "0x93e2de67f75817c101c637b16efc4ba1de8374ed563a4cdcf2d6cc5ea6c1de4ab5abcefdb3bd2baa96a1a2ddb1847d08",
"excludedFromProposerRegistration": false,
"excludedFromNativeDelegation": true
},
{
"publicKey": "0x83eef01c1dafda9ca1d4ec1e4d92ca8dac4131b7289c4b11e7024752ea66a5180462661b8b4a862b3aca970422377eb3",
"excludedFromProposerRegistration": true,
"excludedFromNativeDelegation": true
},
]
NOTE: The excludedFromProposerRegistration
and excludedFromNativeDelegation
fields are optional and default to false
if not specified, either or both can be specified.
If excludedFromProposerRegistration
is set to true
, the validator will not be registered on-chain in the Proposer Registry. And if this validator is intended to be natively delegated, and is not already in the Proposer Registry, the registration will fail, as native delegation requires registration in the Proposer Registry.
How It Works
Validator Registration: The K2-Native-Delegation module enables node runners to register as validators on-chain by securely registering their BLS keys with the Proposer Registry contract. The module utilises the presigned messages broadcasted by the node through the Builder API of the consensus client to register validators on-chain.
Signature Swapper: The module uses the signature swapper to generate and manage ECDSA signatures as proof of ownership of the BLS keys. This ensures the security of the registration process and avoids spoofing.
Balance Verification: The module verifies the effective balance of the proposer wallet before registering validators on-chain. If the balance is insufficient (<32 ETH), the registration is skipped for that epoch. This verifiaction is also available as a remote designated verifier for each network that is used to balance report to the contracts for reward claiming or exiting the protocol.
K2 Contract Interaction: The module communicates with the K2 contract on the blockchain to register validators and participate in restaking cloud activities. A requirement of K2 native delegation is registration with Proof of Neutrality single sign on proposer registry, which is also facilitated by this module.
Payout Management: Node runners can configure the payout recipient address. If not specified, payouts go to the fee recipients configured in your consensus client for each validator key.
Benefits for Node Runners
Security: Validators can securely sign registration messages and interact with the K2 contract without revealing their private keys to external parties.
Local Machine Control: Node runners have full control over the registration, claiming and exiting processes on their local machines, reducing reliance on third-party services or DApps.
Restaking Cloud Participation: This module enables validators to participate in Restaking Cloud; k2 activities, potentially increasing their rewards in a secure and controlled manner.
Custom Payouts: Validators can configure payout recipient addresses, giving them flexibility in managing their rewards, or use their set fee recipients on the node, to receive rewards through both block proposer rewards and rewards through restaking (exposure to multiple income streams to your configured node fee recipient).
Installation
The K2 Native Delegation module is a plugin for MEV Plus. To install the module, import the module into your MEV Plus moduleList.go
file and instantiate the NewK2Service()
and NewCommand()
from service.go functions in the respective service and command lists variables within the moduleList.go file.
Build your modified MEV Plus binary and run it with the required flags.
For more information on building MEV Plus, check out
How to build MEV Plus
Usage
The module functionality can be enabled/disabled by running mev-plus with the k2 flags available.
# Enable K2 Native Delegation Module
mevPlus ............ -k2.eth1-private 1234567890abcdef1234567890abcdef12345f -k2.beacon-node-url http://localhost:5052 -k2.execution-node-url http://localhost:8545
API
The module runs a REST API on localhost
port 10000
by default. The API exposes the following important endpoints:
POST /eth/v1/exit
This endpoint is used to exit the protocol. It accepts a JSON body with the BLS Public Key of the validator to exit.
BLS Public Key {string}
POST /eth/v1/claim
This endpoint is used to claim rewards from the K2 contract. It accepts a JSON body with a list of BLS Public Keys of the validators to claim rewar
[
BLS Public Key {string},
BLS Public Key {string},
...
]
POST /eth/v1/register
This endpoint is used to register validators on-chain. It offers an alternative endpoint dedicated for signed registration messages to which can be processed immediately without having to wait for epoch changes from the node. It accepts a JSON body with a list of registration messages to register on-chain.
[
{
"message": {
"pubkey": string,
"fee_recipient": string,
"gas_limit": uint64,
"timestamp": uint64,
},
"signature": string
},
]
License
MIT