Enabling open market dynamics for infrastructure operators in high performance, proof of stake networks.

Background

Proof-of-Stake has emerged as the architecture of choice for securing the modern blockchain network. As the industry ushers in a new wave of highly performant PoS networks, we are all once again forced to reckon with the design tradeoffs weighed by the networks of generations past. Today we have no shortage of hot, new blockchains, pushing the theoretical limits of throughput, latency, TPS, and any of number of other metrics.

The Evolution of Yield

There are currently many ways to pursue yield on PoS tokens.

Direct Staking

Staking with a validator is the most ‘direct’ in the sense that the only counterparty between your assets and the yield they earn is the operator themselves. Now of course, operators may behave poorly, charge high commissions, get slashed, or go offline entirely. Luckily, when this happens, one can simply undelegate their stake from that particular operator, and move their funds elsewhere. This democratic system reinforces an expected behavior for operators that is congruent with the network’s goals.

Liquid Staking

Liquid staking platforms take this one step further, giving users a liquid derivative of the underlying PoS token. Again, delegators are entirely free to move their stake around as they see fit, but the expectation is that the pool(s) of operators backing a particular liquid staking platform are going to operate honestly, and with high performance. This results in fairly curated and coordinated validator pool underlying the liquid staking platform. This coordination between the platform and its underlying validator pool typically means that there is some sort of selection process and agreed upon fee structure imposed by the pool, in addition to any validator-specific commissions. Validators who charge artificially high commissions are generally excluded from these types of pools. Validators in liquid staking pools can also be accompanied by MEV-enabled clients as a way to increase the yield generated by the staking pool.

DeFi

Of course there are other ways to earn yield on PoS tokens, like providing liquidity to a lending platform. Yields can be higher in these contexts, but don’t come without additional counterparty risk, as LP’s can lose money if the system takes on too much bad debt.

The Problem

While there is plenty of buzz, excitement, and investment around this new generation of blockchains, it is important to consider what may be traded off to achieve the performance.

Foundations

When launching a chain, projects very often create a foundation to manage large portions of the token treasury. The objective of the foundation and its members is to coordinate the allocation of the network’s capital. This may be an oversimplification, but for our purposes, all we need to know is that some of the largest beneficiaries of this capital are the operators who are ‘selected’ to run validators. Network security and performance are among the highest priorities for any team launching a chain, meaning that the importance of selecting reliable validators and delegating them initial capital cannot be understated.

While it may be acceptable for the network to subsidize its own security by delegating to a curated set of nodes at genesis, there are some negative externalities and incentives that emerge. Foundations typically provide their curated set of nodes with guidelines around the maximum commission that they can charge based on the amount of stake they have been delegated. Naturally, what follows is a commission structure across validators that almost perfectly reflects this. The calculus isn’t terribly complicated for an operator. Why should I charge anything less than than the guideline provided by the foundation when their delegation accounts for nearly 100% of my entire stake? For independent operators, profitably running a validator can be tricky, and reducing commissions meaningfully to attract organic stake is is often an unsustainable strategy, especially as the network is still in its nascency.

Don’t mistake this criticism as a call to remove foundation delegation from the staking landscape. Delegation by foundations has proven to be massively important for growing the network, distributing risk across a diverse set of operators, and investing in teams that allign with the project’s goals. In fact, it is probably one of the most important capital allocation responsibilities that a foundation has.

But inevitably, foundations are faced with the problem of rebalancing capital in a way that promotes network growth, while simultaneously ensuring that there are no adverse outcomes to the existing validator set in doing so. The process of divirsifying a node away from foundation stake toward organic stake is one that can take years, and depends largely on how motivated a given node operator is.

Bootstrapping

In many of today’s high performance chains, it is virtually impossible to join the validator set without considerable capital or prior relationships. Many chains proudly advertise their validator sets as permissionless, requiring only a few of commands to join. Just run a few commands, round up ~7-8 figures of cash, a couple hundred gigs of RAM and you’re off to the races! It’s no wonder that despite the absence of programmatic barriers, projects find themselves running a highly curated set of nodes. It also means that there are highly qualified, geographically diverse teams out there that simply don’t possess the resources to bootstrap their own validator.

There are many reasons to create a high barrier to entry, especially in the early innings of a network. Most of these chains have not been load or performance tested with larger validator sets, especially not ones that are an order of magnitude larger. Expanding participation in consensus must be done carefully and thoughtfully at the outset, but as the network matures, the expectation should be that the validator set grows into something much more fluid and diverse.

The Solution

One obvious characteristic of staking and liquid staking today is that staking rewards are applied proportionately, meaning that fees/commissions are applied equally across all stake for a given validator or liquid staking pool. This means that all stake is essentially ‘created equal’. There is no way to assign a specific commission or fee to a specific validator delegation or deposit in a liquid staking pool.

Why might it be useful to enable dynamic commission rates for validators?

  • Imagine you are an operator who has received delegation from some foundation, enough to meet the minimum staking requirement, earning a commission that is high enough to meet the costs of operating the node (expressed as the combined hardware and labor costs). Now your goal is to go and attract organic stake from the outside world. It would be nice if operators could use commission rates as a lever to attract new capital, without disrupting the commission they are earning from their existing stake. By offering a more competitive commission rate on new capital, operators could help diversify their stake with organic delegators who are simply searching for the best yield on staking. The result of this dynamic commission / tranched staking yield can lead to improved competition and price discovery among validators. It can also empower foundations to be more thoughtful about rebalancing delegated capital as the network matures.

  • Now imagine that you are an operator with no access to foundation delegation, who does not have the capital required to start a validator. This same mechanism could be leveraged to approach the ‘bootstrapping’ problem, where a prospective operator can offer ‘promotional’ yield on some number of staked tokens to help them cross the minimum stake requirement, at which point they will join the validator set.

What does this mean?

What we have created is a claim on the staking yield of some PoS token, with some commission rate, for some amount of time or term.

A staker commits capital, and that capital is entitled to the real staking yield of the PoS token, net some commission, for some term.

Ownership of a claim represents entitlement to the underlying quantity of tokens and the yield accrued from when the claim was created to when it was exercised.

Claims can be exercised at any time after being created, including after the term has expired.

In the case where an operator goes offline or performs poorly, stake will be rebalanced in a way that preserves the original claim.

Lockups?

Without lockups, it is more challenging for operators to forecast their costs. Servers are often billed in weekly, monthly, or even yearly installments. If the staked capital moves away from an exceptional operator, they are left to bear the costs of their hardware. This could happen simply by the changing staking dynamics during sharp moves in the underlying PoS token price, or market sentiment more broadly. These are problems that already exist today and would not necessarily be net new.

But in order to combat this sort of behavior, the terms of the offer could optionally specify a ’locked’ requirement for the duration, presumably in return for a more favorable commission rate.

Implementation

The program created to manage staking positions with different commission rates can fairly closely resemble liquid staking code. The program will serve primarily as a wrapper around the functions to add and remove stake from the underlying staking program. When staking through our new program, users receive their claim object. When redeeming the claim, our program is responsible for interpreting the information on the claim and unstaking the appropriate number of tokens.

In order to ensure that all staking activity takes place through our wrapper contract, validator commissions will be set to 100% to discourage direct staking. As a result of this, our contract must also be the only one that knows how to sign using the account key for the validator. If the operator knew this information, they could simply withdraw all the staking rewards (at 100% commission), and run off with the funds. Luckily, the account key is not needed to operate the validator.

Example on Sui

Prospective operator connects a wallet, and creates a new validator candidate through the UI. They are given back an object that represents that keypair’s ‘ownership’ of the underlying validator object.

The validator is created on chain by the wrapper_contract, and the wrapper contract is responsible for managing account keypair. This ensures that when the underlying validator commission is set to 100% (to enforce staking only through wrapper), the operator cannot run off with the rewards. the remaining keys (network, protocol, worker) are all provided to the operator. These keys are needed in order to operate the validator.

The validator can configure commission tranches in the UI, which are held in the object representing the validator.

Some examples:

first 1000 stakers staking >= 10,000 tokens ---> 0% commission
any staker staking >= 100,000 tokens ---> 0%
first 100 stakers staking >= 10,000 tokens in the next week ---> 0% commission
otherwise ---> 5% commission

These can be configured dynamically, allowing validators to present their offer/yield and run ‘promotions’ at will.

When a prospective staker visits the ui, they can browse these offers, and can provide stake from the UI. The UI interfaces with the wrapper contract which is responsible for calling the underlying staking contract. The wrapper returns a claim object to the staker.

Stake is also withdrawn using the same UI, providing the claim to the wrapper contract. the wrapper is responsible for interpreting the claim and withdrawing the appropriate amount of PoS token + rewards from the underlying staking program.