From 902510b8d1187ecd14158fd27596edfc70662051 Mon Sep 17 00:00:00 2001 From: candida-d <62548908+candida-d@users.noreply.github.com> Date: Fri, 23 Feb 2024 18:39:44 +0000 Subject: [PATCH 01/14] treasury --- docs/concepts/governance.md | 360 ------------------ docs/concepts/governance/_category_.json | 5 + docs/concepts/governance/asset.md | 85 +++++ docs/concepts/governance/index.md | 33 ++ docs/concepts/governance/lifecycle.md | 136 +++++++ docs/concepts/governance/market.md | 121 ++++++ docs/concepts/governance/network-parameter.md | 33 ++ docs/concepts/governance/treasury.md | 67 ++++ .../trading-on-vega/discounts-rewards.md | 6 +- docs/concepts/vega-chain/_category_.json | 4 +- docs/concepts/vega-chain/proof-of-stake.md | 11 +- docs/topics/_topic-governance.mdx | 2 +- docs/tutorials/proposals/index.md | 6 +- 13 files changed, 498 insertions(+), 371 deletions(-) delete mode 100644 docs/concepts/governance.md create mode 100644 docs/concepts/governance/_category_.json create mode 100644 docs/concepts/governance/asset.md create mode 100644 docs/concepts/governance/index.md create mode 100644 docs/concepts/governance/lifecycle.md create mode 100644 docs/concepts/governance/market.md create mode 100644 docs/concepts/governance/network-parameter.md create mode 100644 docs/concepts/governance/treasury.md diff --git a/docs/concepts/governance.md b/docs/concepts/governance.md deleted file mode 100644 index d40225ff8..000000000 --- a/docs/concepts/governance.md +++ /dev/null @@ -1,360 +0,0 @@ ---- -sidebar_position: 5 -title: Governance -vega_network: TESTNET -hide_title: false -description: Governance allows for on-chain decision making by tokenholders. ---- -import NetworkParameter from '@site/src/components/NetworkParameter'; - -Governance allows the Vega network to arrive at on-chain decisions, where tokenholders can create proposals that other tokenholders can vote to approve or reject. - -Vega supports on-chain proposals for creating markets and assets, changing network parameters, markets and assets, and transferring assets between some network-managed accounts. Vega also supports freeform proposals for community suggestions that will not be enacted on-chain. - -Taking part in governance by voting, or by proposing additions/changes with community support, is a way for tokenholders and community members to contribute to improve the network, and to add value for other network participants. - -## Voting on proposals -Proposals only get enacted if they get enough votes from VEGA tokenholders. There's no limit to how many active proposals they can vote on. - -To vote, your tokens must be associated with a Vega public key. It's not necessary to have those tokens nominated to validators, but the tokens must be associated to the Vega key used for voting. - -You can vote on a proposal as soon as it passes validation and is active, and it can be voted on until the proposal's closing date/time. - -* How many tokens are associated with your voting key determines how much weight the vote has. For market parameter change proposals, the liquidity providers' market share is also taken into account. -* Each Vega public key with a non-zero token balance gets one vote, and the key votes with the full weight of all the tokens associated to that key. You'll need to have tokens when the vote is submitted *and* when votes are counted, otherwise your vote is disregarded. -* Tokens used for voting are not locked or transferred: they can be used to nominate validators and to vote on other active proposals. -* While the voting period is open, you can change your vote, but only the most recent vote will count at the proposal's close. - -## How a proposal's outcome is calculated -* The network compares the weight of all valid votes cast as a percentage of the total weight that could vote, to the minimum participation requirement - `participation_rate = SUM (weightings of ALL valid votes cast) / max total weighting possible` -* The network compares the weight of all 'for' votes, as a percentage of the weight of all votes cast, to the required majority - `for_rate = SUM (weightings of votes cast for) / SUM (weightings of all votes cast)` -* If the minimum for both is reached, the proposal is enacted. If at least one is not reached, the proposal fails. - -### Proposal outcome: Update market -For proposals to update a market, there are extra requirements. The market's liquidity providers can vote with their equity-like share without requiring tokenholder participation. However, if tokenholders vote and participation and majority requirements for this vote are met, then the tokenholders' votes can overrule the liquidity providers' votes. - -The network will also calculate: -* The LP participation rate, which is the sum of the equity-like share of all LPs who cast a vote - `LP participation rate = SUM (equity-like share of all LPs who cast a vote)` -* The rate of 'for' votes cast by liquidity providers, calculated as the sum of all who voted 'for', divided by the LP participation rate - `LP for rate = SUM (all who voted for) / LP participation rate` - -The proposal will pass if one of the two scenarios occur: -1. The tokenholder vote meets or exceeds the minimum set by , and the votes in favour are greater than the amount set by . In this case the market's liquidity providers were overridden by governance token holders. -2. The governance tokenholder vote does not reach participation threshold, but the liquidity providers' votes do, and there are enough votes in favour. The participation rate must be greater than/equal to , and the liquidity providers' participation rate must be greater than/equal to , and the liquidity providers' votes in favour is greater than/equal to - -### Proposal outcome: Successor market -For proposals adding a new successor market, the outcome of the proposal can change even after it's been approved. - -If a parent market is still in its proposed state, its successor market cannot be enacted, even if it passes the vote. - -Two proposals that name the same parent can be submitted and pass a governance vote. Whichever market clears its [opening auction](./trading-on-vega/trading-modes.md#auction-type-opening) first gets the share of the insurance pool, and the liquidity providers' equity-like share is moved to that market. The second market will then be [rejected](./trading-on-vega/market-lifecycle.md#market-status-rejected). - -:::tip Try it out -**[Vega governance dApp ↗](https://governance.fairground.wtf)**: Vote on active proposals. -::: - -## Lifecycle of a governance proposal -You need community support if you want to change something about the network, whether that's to add a new market, change a network parameter, or transfer pooled assets. It's worth considering what your proposed change contributes to the network, and if it would get enough votes from fellow tokenholders. - -You'll have a better chance of positively contributing to the network if you confirm there is support off-chain before submitting a proposal. - -### 1. Sense checking proposal idea (off-chain) -Before submitting a proposal, share an outline of your proposed action informally in a new topic on the [community forum ↗](https://community.vega.xyz/c/governance/25/) Governance Proposals section, with a "sense-check" tag. You can find out if there is enough interest in your proposal. - -Proposals can be submitted for creating a new market, amending an existing market, changing network parameters, adding an external asset to Vega, transferring out of asset pools. You can also suggest changes that won't impact network behaviour with a freeform proposal. - -### 2. Formalising proposal (off-chain) -Once the proposal details are refined, share the detailed proposal in the same topic you created for your sense check, and change the tag to "formalise". - -Including as much detail as possible gives other community members the opportunity to fully understand your proposal. Include the rationale for the proposal (and IPFS hash for more details), the specifics of the proposed addition/change, and the data (JSON or similar) that would be submitted on-chain. Invite debate and discussion to amend the proposal until it reaches a final state, ready to submit. - -When formalising the proposal, it is worth ensuring that any fields that are dependent on a range set by network parameters are correctly defined. See the network parameters and their values on the [Vega block explorer ↗](https://explorer.fairground.wtf/network-parameters). - -### 3. Submitting proposal and telling the community (on-chain and off-chain) -You can submit a governance proposal to the network using the command line, a script, or the [governance dApp ↗](https://governance.fairground.wtf/proposals/propose/raw). - -Your Vega key must have enough VEGA associated to submit a proposal. For a 'market parameter change' proposal, you'll also need enough equity-like share in the market from your liquidity commitment. This is defined in the network parameter . - -Proposals are first checked by the wallet, then verified by the nodes before entering into the voting period you set. A proposal must have all of the relevant information, in the correct format, and in some cases within the accepted range - otherwise it will be rejected immediately. - -A proposal cannot be changed once it's submitted to the network. - -After it's submitted and accepted, rally the community to vote on the proposal by announcing it on the [forum ↗](https://community.vega.xyz/), [Discord ↗](https://vega.xyz/discord), and through your own networks to vote on the proposal. - -:::tip Try it out -**[Proposals guides](../tutorials/proposals/index.md)**: How to build and then submit a proposal using the command line. -::: - -#### Validating a proposal -* The governance proposal is checked and then accepted by the wallet as a transaction. -* The validator nodes then check and validate the proposal. This is when the proposal data that defines the minimum duration, minimum time to enactment, minimum participation rate, and required majority are evaluated against the network's requirements, defined by [network parameters ↗](https://explorer.fairground.wtf/network-parameters), which are different depending the type of proposal. -* If not specified on the proposal, the required participation rate and majority for success are defined and copied to the proposal. You can find them under the [network parameters ↗](https://explorer.fairground.wtf/network-parameters), and they are specific to each proposal type. -* If the above conditions are not met, the proposal will be rejected and will not be available for a vote. **You'll need to fix and re-submit the proposal.** - -### 4. Voting (on-chain) -VEGA tokenholders - including those who submitted a proposal - can vote for or against any active proposals, with the full weight of the tokens associated with each public key. - -Read more about [voting](#voting-on-proposals). - -### 5. Enacting changes (on-chain) -If a proposal receives enough token weight in favour within the enactment period, the change/addition is accepted (except for a freeform proposal), and will be enacted on the enactment date defined in the proposal. - -Note the enactment date must be at least the minimum enactment period for the proposal type/subtype (specified by a network parameter for each proposal type) after voting closes. See the network parameters and their values on the [Vega block explorer ↗](https://explorer.fairground.wtf/network-parameters). - -## Thresholds set by network parameters -Certain governance parameters need to be within a defined range, but offer some flexibility. - -When a submitted governance proposal is validated, the values chosen will be checked to ensure they fit within the thresholds, which themselves are defined by network parameters. - -Each type of governance proposal can have different thresholds, though they fit into broader categories. Those categories include: - -* `minProposerBalance`: Minimum amount of VEGA that a proposer needs to have associated with their Vega key to have the proposal accepted for a tokenholder vote -* `minClose`: Minimum amount of time before a proposal can be closed for voting -* `maxClose`: Maximum amount of time a proposal can be open for voting -* `minEnactment`: Minimum time allowed between vote closing on a proposal and the proposal's change being enacted on the network -* `maxEnactment`: Maximum time allowed between vote closing on a proposal and the proposal's change being enacted on the network -* `requiredParticipation`: Minimum number of tokens that must vote for a proposal to pass -* `requiredMajority`: Minimum majority that a proposal's 'yes' votes must reach for it to be enacted - -As these thresholds are network parameters, their values can be changed through governance. - -:::tip Query for data -**[Block explorer ↗](https://explorer.fairground.wtf)**: See the current network parameter values (in some cases, different per network). - -**[REST](../api/rest/state/core-state-service-list-network-parameters.api.mdx)** The API provides the network parameters and their values. -::: - -### Example -Consider a network parameter that specifies the proportion of fees that goes to validators (). Each of the following thresholds would need to be met: - -* -* -* -* -* -* -* - -## Submitting proposals in a batch -You can submit governance proposals individually, or batch up the proposed changes into one proposal. - -The only thing that can't be proposed in a batch is adding a new asset - that needs to be a proposal on its own. - -When a batch proposal goes up for the vote, each proposed change within the batch needs to pass based on its own voting requirements. For example, if the batch includes a market change, the equity-like share voting rules apply to that specific change. - -Every proposed change in the batch needs to pass its voting requirements, or the whole batch fails. - -The batch proposal only has one rationale field, as well as one closing timestamp, for the whole set of proposals, so the description should describe why each change is being proposed. Each enactment timestamp needs to work with the single closing timestamp chosen for the batch. - -## Asset governance -Assets need to be proposed and pass a governance vote before they can be used on the Vega network. - -The protocol currently supports adding ERC-20 assets. Those ERC-20 assets that are successfully validated and pass a governance vote are can be enabled via the Vega bridge. In practice, that means that assets on Vega are deposited from and withdrawn to Ethereum. - -After a new asset vote passes, the change has to be submitted to the asset bridge on Ethereum. Until it has been submitted, no one can start depositing that asset. - -Certain asset details can also be changed through a governance proposal. While the [contract-level details](./assets/asset-framework.md#contract-level-details) are immutable, the [protocol-level details](./assets/asset-framework.md#protocol-level-details) can be changed. - -:::note Learn more -See the tutorials to: -* [Propose a new asset](../tutorials/proposals/new-asset-proposal.md) -* [Propose an update to an asset](../tutorials/proposals/update-asset-proposal.md) -::: - -### ERC-20 asset validation -When adding an ERC-20 asset to the bridge, the key details are compared to the smart contract on Ethereum. - -Specifically: -* The contract must be an ERC-20 asset -* The name and symbol must match the contract -* There cannot be multiple assets on a Vega network for the same ERC-20 asset - -### Transferring assets -For assets that are held in certain accounts - those with pooled assets, the community determines if the assets should be moved, and how they should be used. Generally speaking, those accounts have accumulated assets from settled markets, market protection movements, or are entirely funded by community members that transfer assets into them. - -These proposals give community members a chance to determine what they think the assets should be spent on, whether that's to fund [trading or validator rewards](./trading-on-vega/discounts-rewards.md#trading-rewards), to move money from [insurance pools](./assets/accounts.md#insurance-pool-accounts) into [network treasury accounts](./assets/accounts.md#network-treasury-accounts), or for other purposes. - -Transferring assets from network-managed account types can only be initiated by on-chain governance proposals. - -The transfers from those asset pools can be one-off or recurring. A recurring transfer that's initiated by governance can only be cancelled when a governance proposal to cancel it is submitted and passes the governance vote. - -To see a full table of which types of transfers can only be initiated through governance, see the [transfers page](./assets/transfers.md#governance-initiated-transfers). - -:::info Read more -* [Transfers](./assets/transfers.md) -* [Tutorial: Propose transferring assets](../tutorials/proposals/asset-transfer-proposal.md) -::: - -### Propose an asset transfer -Tokenholders can propose asset transfers from certain accounts, which then need to be voted on by other tokenholders. Not all transfers need to be proposed by governance. - -The proposer will need to have at least , associated with the public key you're using to propose the market, and staked to a validator. Note, this amount is set through the network parameter . - -If the proposal gets a majority of tokenholder support, then it will be enacted. The required majority is defined by the network parameter . It would also need to pass the required participation threshold: . - -To propose assets be transferred, you'll need to provide the details required for the transfer to be successful. While some of the fields are free-text, others are constrained by a range set through network parameters, to ensure that the values provided are fit for purpose. - -Proposal fields include: -* Source account type: The type of account that the assets are to be transferred from, such as the network treasury -* Source: The actual account ID. For network treasury, leave it blank. -* Asset: Asset to transfer -* Transfer type, which can be 'all or nothing' or 'best effort' - * All or nothing: Transfers the specified amount, or nothing - * Best effort: Transfers the specified amount or the max allowable amount if it's less than the specified amount -* Amount: Maximum amount to transfer; can be used to add an upper limit the fractional amount described below -* Fraction of balance: Maximum fraction of the source account's balance to transfer, submitted as a decimal (i.e. 0.1 = 10% of the balance) -* Destination type: Type of account to transfer to, such as reward pool, individual party, market insurance pool -* Destination: Specific account to transfer to, using an ID or public key. For network treasury, leave it blank. -* If the proposal is for a one-off transfer, it can optionally define a time, based on Vega time, for delivery. If there is no delivery time, it will execute immediately -* If the proposal is for a recurring transfer, it must include a start epoch. It can optionally include an end epoch for the last transfer - -#### Calculating amount to be transferred -The final amount transferred is determined based on the inputs into the proposal as well as the values of the relevant network parameters: -* specifies the maximum amount that can be transferred from a source account in a proposal -* specifies the maximum fraction of the balance that can be transferred from a source account. - -The final amount is calculated with the following formula: - -``` - transfer_amount = min( - proposal.fraction_of_balance * source.balance, - proposal.amount, - governance.transfer.max.amount, - governance.transfer.max.fraction * source.balance ) -``` - -## Market governance -Markets are proposed and voted into existence by Vega tokenholders. The parameters for a market all need to be defined in the proposal. - -Some market parameters can also be changed. They can only be proposed by a liquidity provider with enough equity-like share in the market, and need to be voted for by a sufficient number of tokenholders and/or liquidity providers. - -When creating a market governance proposal, whether it is for a new futures market, a new perpetual futures market, or to change parameters for an existing market, it's recommended that you sense check the proposal and share the final details with the tokenholder community before proposing, so that you can garner support and make any necessary amends. - -Read more: -* [Vega community forum ↗](https://community.vega.xyz): Share your draft proposals for community discussion. -* [New perpetual futures market proposal ↗](../tutorials/proposals/new-perpetuals-market.md): Guide to submitting a proposal for a new market -* [New futures market proposal ↗](../tutorials/proposals/new-market-proposal.md): Guide to submitting a proposal for a new market -* [New successor market proposal ↗](../tutorials/proposals/new-successor-market-proposal.md): Guide to submitting a proposal for a new successor market -* [Update market proposal ↗](../tutorials/proposals/update-market-proposal.md): Guide to submitting a proposal to change a market using the command line - -### Propose a new market -Tokenholders can propose new markets, which then need to be voted on by other tokenholders. The proposer will need to have at least , associated with the public key you're using to propose the market, and staked to a validator. Note, this amount is set through the network parameter . - -If the market proposal gets a majority of tokenholder support, then it will be enacted. The required majority is defined by the network parameter . - -To propose a market, you'll need to provide the details required for the market to begin trading right away. While some of the fields are free-text, others are constrained by a range set through network parameters, to ensure that the values provided are fit for purpose. - -Required fields include: -* Instrument details, including a human-readable name, an understandable shortcode for the market, the type of product -* Risk model parameters -* Product specifics including the settlement asset and quote name -* Decimal places for the market and positions. (Note: A market cannot specify more decimal places than its settlement asset supports) -* Oracle details, including the oracle's public key, specifications for settlement price, and data filters -* Liquidity parameters, including the target stake -* Method for setting liquidity fees, such as constant, marginal cost or stake-weighted average - -Optional fields include: -* Metadata so that people can easily interpret the market's details - while this is optional, it's highly recommended that you include metadata for the market -* Price monitoring parameters, including the triggers covering the horizon, probability and auction extension time. If left blank these parameters will default to the values set in the network parameters - -:::note Read more -* [New market proposal tutorial](../tutorials/proposals/new-market-proposal.md) -* [Data sources](./trading-on-vega/data-sources.md) -* [Price monitoring parameters](./trading-on-vega/market-protections.md#price-monitoring) -::: - -### Risk models and parameters -When proposing a market, the market proposer will need to choose the risk parameters associated with the risk model that's appropriate for the instrument. The acceptable amount of volatility on a market is driven by its risk model. The risk model is essential for calculating margins on the market. - -The [log-normal risk model](#log-normal-risk-model) is the only one currently supported. While the model is pre-defined, you'll need to choose the individual parameters. - -You should choose parameters that ensure the risk model adequately represents the dynamics of the underlying instrument, and that the resulting margins strike the right balance between prudence and capital efficiency. - -Below are the risk parameters, the accepted values for each parameter and suggested values for some. When suggested values are provided, these should be used as a reference point and to aid in deciding on what's appropriate for the market, not in place of rigorous analysis and calibration. - -Model-independent parameters used in margin calculation are: - -* `Risk aversion lambda` - probability confidence level used in [expected shortfall ↗](https://vega.xyz/papers/margins-and-credit-risk.pdf#page=7) calculation when obtaining the maintenance margin level. This enters the margin calculation as follows. First, the value at risk, defined by confidence lambda is calculated. This is the cash amount that one would need to add to the position to make the probability of the value of the position and cash going negative after time tau to be less than lambda. The margin is then the expected loss of the position given that it incurred a loss bigger than the value at risk. - * accepted values: **strictly greater than 0 and strictly smaller than 1** - * suggested value: `0.00001` -* `Tau` - projection horizon measured as a year fraction used in the expected shortfall calculation to obtain the maintenance margin: - * accepted values: **any strictly non-negative real number**, - * suggested value: `0.000114077116130504` - corresponds to one hour expressed as year fraction -* `Risk free rate` - annualised growth rate of the risk-free asset, it's used for discounting of future cash flows: - * accepted values: **any real number**, - * suggested value: `0`. - -The remaining, model specific parameters are covered below. - -:::note Go deeper -**[Margins and Credit Risk on Vega ↗](https://vega.xyz/papers/margins-and-credit-risk.pdf)**: Note, a position size of 1 is assumed throughout the research paper. -::: - -#### Log-normal risk model -The log-normal model assumes that the logarithm of the price increments are normally distributed. The main model parameter is: -* `Volatility (Sigma)` - annualised historical volatility of the underlying asset: - * accepted values: **any strictly non-negative real number**, - * suggested value: asset dependent, should be derived from the historical time-series of prices, and a typical value would be 0.8 = 80% - -Another parameter is -* `Mu` - annualised growth rate of the underlying asset: - * accepted values: **any real number**, - * suggested value: in almost all situations `0` is the value to use - -### Propose a successor market -A successor market is a market that will carry on after the original market, or parent, that it is based on has settled - though a parent and successor market can be active simultaneously. Proposing a new successor market that follows from an existing market offers liquidity providers the option to keep their [equity-like share](./liquidity/rewards-penalties.md#how-liquidity-fees-are-split) on the new market, even when the original market expires. Creating an entirely new market with no parent doesn't offer the same benefit. - -Each market can have only one active successor. A successor market can also be a parent market. - -In terms of the proposal format, there are only two differences between a succesor market proposal and that for a regular market, and one field that ties the successor to the parent market. -* Parent market ID: Required to define the proposal as for a successor market -* Insurance pool percentage: Required percentage of the parent market's insurance pool, up to 100%, can be earmarked for transfer to the successor market. It is submitted as a number between and including 0 and 1, which represents the factor for the percentage. -* Settlement asset validation: The settlement asset needs to match that of the parent market - -For a successor market to be enacted, the parent market must be in one of the following states: proposed, pending, active, suspended or trading terminated. - -The parent market can be settled or cancelled when the successor market reaches enactment time, as long as the time it's been settled/cancelled is equal to or less than the parent market's settlement time plus the `market.liquidity.successorLaunchWindowLength` - determined by a network parameter. This parameter specifies for how long after a market has settled, the liquidity provider's equity-like share data are retained and the insurance pool is left undistributed to allow a successor to be defined. If the successor is proposed after that time, then it's rejected and any assets committed to the market are returned. - -### Propose updates to a market -Most details about a market can be changed through governance. Those includes risk models, monitoring triggers, and the settlement and termination (if applicable) data sources. - -However, there are a few that cannot be edited, and will be the same for the duration of the market's life. -* Name: Market name, which should be a short, descriptive and relevant name -* Settlement asset: Asset used for margin, liquidity, and to settle positions -* Decimal places/precision for: - * Market - Sets the smallest price increment on the book. A market cannot specify more decimal places than its settlement asset supports - * Position - Precision of the position size - -### Propose a change to a market's state -Markets can be suspended, resumed from being suspended, and terminated using governance proposals. - -Suspending a market puts the market into an auction-only state. A market can be suspended for an indefinite amount of time, and it may never come out of suspension. - -A suspended market can only open to normal trading again if a proposal to resume the market is proposed and enacted. - -Markets that are terminated are closed to trading forever. When a proposal to terminate a market is enacted, it ends all trading on the market, settles all positions, and closes the market completely. The termination proposal includes a final price that's used to settle all open positions. - -:::tip Try it out -[Tutorial: Propose a change to a market's state](../tutorials/proposals/market-state-proposal.md) -::: - -## Network parameter governance -There are certain parameters within Vega that influence the behaviour of the system and can be changed by on-chain governance. Vega tokenholders can define the optimal network configuration by creating and voting on network parameter proposals to change the values of existing network parameters. - -Network parameters can only be added and removed with Vega core software releases. - -:::note Go deeper -* [Concept: Network parameters](../concepts/vega-chain/network.md#parameters) -* [Network parameters: See full list on the block explorer ↗](https://explorer.fairground.wtf/network-parameters) -* [Tutorial: Propose a network parameter change](../tutorials/proposals/network-parameter-proposal.md) -::: - -### Suggested ranges for parameters -Some network parameters have minimum/maximum boundaries to ensure they aren't supplied with nonsensical values. The table below contains those parameters, to be used as guidance when proposing changes to any of those parameters. - -| Parameter name | Minimum/Maximum | -|---------------------------------------------------|-----------------| -| `reward.staking.delegation.competitionLevel` | Minimum value 1 (inclusive), no maximum. | -| `governance.proposal.(TYPE).minEnact` | Must be greater than / equal to the corresponding `minClose`, proposal can't be enacted before voting on it has closed. | -| `governance.proposal.(TYPE).requiredMajority` | Minimum 0.0, maximum 1.0. Is multiplied by 100 to get percentage. | -| `governance.proposal.(TYPE).requiredParticipation`| Minimum 0.0, maximum 1.0. Is multiplied by 100 to get percentage. | -| `rewards.activityStreak.benefitTiers`: `reward_multiplier` | Minimum 1.0. | \ No newline at end of file diff --git a/docs/concepts/governance/_category_.json b/docs/concepts/governance/_category_.json new file mode 100644 index 000000000..46b2edfe0 --- /dev/null +++ b/docs/concepts/governance/_category_.json @@ -0,0 +1,5 @@ +{ + "label": "Governance", + "collapsed": false, + "position": 3 +} \ No newline at end of file diff --git a/docs/concepts/governance/asset.md b/docs/concepts/governance/asset.md new file mode 100644 index 000000000..5e3e34aa7 --- /dev/null +++ b/docs/concepts/governance/asset.md @@ -0,0 +1,85 @@ +--- +sidebar_position: 4 +title: Asset governance +vega_network: TESTNET +hide_title: false +description: Add assets or move network-held funds. +--- +import NetworkParameter from '@site/src/components/NetworkParameter'; + +## Asset governance +Assets need to be proposed and pass a governance vote before they can be used on the Vega network. + +The protocol currently supports adding ERC-20 assets. Those ERC-20 assets that are successfully validated and pass a governance vote are can be enabled via the Vega bridge. In practice, that means that assets on Vega are deposited from and withdrawn to Ethereum. + +After a new asset vote passes, the change has to be submitted to the asset bridge on Ethereum. Until it has been submitted, no one can start depositing that asset. + +Certain asset details can also be changed through a governance proposal. While the [contract-level details](../assets/asset-framework.md#contract-level-details) are immutable, the [protocol-level details](../assets/asset-framework.md#protocol-level-details) can be changed. + +:::note Learn more +See the tutorials to: +* [Propose a new asset](../../tutorials/proposals/new-asset-proposal.md) +* [Propose an update to an asset](../../tutorials/proposals/update-asset-proposal.md) +::: + +### ERC-20 asset validation +When adding an ERC-20 asset to the bridge, the key details are compared to the smart contract on Ethereum. + +Specifically: +* The contract must be an ERC-20 asset +* The name and symbol must match the contract +* There cannot be multiple assets on a Vega network for the same ERC-20 asset + +### Transferring assets +For assets that are held in certain accounts - those with pooled assets, the community determines if the assets should be moved, and how they should be used. Generally speaking, those accounts have accumulated assets from settled markets, market protection movements, or are entirely funded by community members that transfer assets into them. + +These proposals give community members a chance to determine what they think the assets should be spent on, whether that's to fund [trading or validator rewards](../trading-on-vega/discounts-rewards.md#trading-rewards), to move money from [insurance pools](../assets/accounts.md#insurance-pool-accounts) into [network treasury accounts](../assets/accounts.md#network-treasury-accounts), or for other purposes. + +Transferring assets from network-managed account types can only be initiated by on-chain governance proposals. + +The transfers from those asset pools can be one-off or recurring. A recurring transfer that's initiated by governance can only be cancelled when a governance proposal to cancel it is submitted and passes the governance vote. + +To see a full table of which types of transfers can only be initiated through governance, see the [transfers page](../assets/transfers.md#governance-initiated-transfers). + +:::info Read more +* [Transfers](../assets/transfers.md) +* [Tutorial: Propose transferring assets](../../tutorials/proposals/asset-transfer-proposal.md) +::: + +### Propose an asset transfer +Tokenholders can propose asset transfers from certain accounts, which then need to be voted on by other tokenholders. Not all transfers need to be proposed by governance. + +The proposer will need to have at least , associated with the public key you're using to propose the market, and staked to a validator. Note, this amount is set through the network parameter . + +If the proposal gets a majority of tokenholder support, then it will be enacted. The required majority is defined by the network parameter . It would also need to pass the required participation threshold: . + +To propose assets be transferred, you'll need to provide the details required for the transfer to be successful. While some of the fields are free-text, others are constrained by a range set through network parameters, to ensure that the values provided are fit for purpose. + +Proposal fields include: +* Source account type: The type of account that the assets are to be transferred from, such as the network treasury +* Source: The actual account ID. For network treasury, leave it blank. +* Asset: Asset to transfer +* Transfer type, which can be 'all or nothing' or 'best effort' + * All or nothing: Transfers the specified amount, or nothing + * Best effort: Transfers the specified amount or the max allowable amount if it's less than the specified amount +* Amount: Maximum amount to transfer; can be used to add an upper limit the fractional amount described below +* Fraction of balance: Maximum fraction of the source account's balance to transfer, submitted as a decimal (i.e. 0.1 = 10% of the balance) +* Destination type: Type of account to transfer to, such as reward pool, individual party, market insurance pool +* Destination: Specific account to transfer to, using an ID or public key. For network treasury, leave it blank. +* If the proposal is for a one-off transfer, it can optionally define a time, based on Vega time, for delivery. If there is no delivery time, it will execute immediately +* If the proposal is for a recurring transfer, it must include a start epoch. It can optionally include an end epoch for the last transfer + +#### Calculating amount to be transferred +The final amount transferred is determined based on the inputs into the proposal as well as the values of the relevant network parameters: +* specifies the maximum amount that can be transferred from a source account in a proposal +* specifies the maximum fraction of the balance that can be transferred from a source account. + +The final amount is calculated with the following formula: + +``` + transfer_amount = min( + proposal.fraction_of_balance * source.balance, + proposal.amount, + governance.transfer.max.amount, + governance.transfer.max.fraction * source.balance ) +``` diff --git a/docs/concepts/governance/index.md b/docs/concepts/governance/index.md new file mode 100644 index 000000000..1becbddff --- /dev/null +++ b/docs/concepts/governance/index.md @@ -0,0 +1,33 @@ +--- +sidebar_position: 1 +title: Governance +vega_network: TESTNET +hide_title: false +description: Governance allows tokenholders to make on-chain decision. +--- +import NetworkParameter from '@site/src/components/NetworkParameter'; +import DocCardList from '@theme/DocCardList'; +import {useCurrentSidebarCategory} from '@docusaurus/theme-common'; + +## Overview +Governance allows the Vega network to arrive at on-chain decisions, where tokenholders can create proposals that other tokenholders can vote to approve or reject. Contribute to the network by voting or submitting proposals. + +Proposals are enacted if they get enough votes from VEGA holders. There's no limit to how many active proposals you can vote on. + +Vega supports on-chain proposals for governing: +* **Markets**: Creating new markets and changing parameters for existing ones +* **Assets** - Adding new assets and changing parameters for existing ones +* **Transferring network assets** - Moving network-held assets to different accounts or keys +* **Network parameters** - Changing the values of existing parameters to change network and market behaviour +* **Freeform** - Exploring community sentiment for actions that may or may not be enacted on-chain + +:::tip Try it out +**[Vega governance dApp ↗](https://governance.fairground.wtf)**: Read through and vote on active proposals. +::: + +:::note Looking for proposal templates? +**[Tutorials: Governance proposals](../../tutorials/proposals/index.md)**: See the full range of proposal templates and descriptions of the fields. +::: + +## Governance topics + \ No newline at end of file diff --git a/docs/concepts/governance/lifecycle.md b/docs/concepts/governance/lifecycle.md new file mode 100644 index 000000000..6bf99d073 --- /dev/null +++ b/docs/concepts/governance/lifecycle.md @@ -0,0 +1,136 @@ +--- +sidebar_position: 2 +title: Taking part +vega_network: TESTNET +hide_title: false +description: Understanding the governance lifecycle. +--- +import NetworkParameter from '@site/src/components/NetworkParameter'; + +## Voting +Proposals are enacted if they get enough votes from VEGA holders. There's no limit to how many active proposals you can vote on. + +Your tokens must be associated with a Vega public key. The tokens need to be associated to your Vega key, but they don't need to be nominated to validators. To check if your tokens are associated, connect to your Vega wallet on the [governance dApp ↗](https://governance.fairground.wtf). + +You can vote as soon as the proposal passes validation and is active, and it can be voted on until the proposal's closing date/time. + +* How many tokens are associated with your voting key determines how much weight the vote has. For market parameter change proposals, the liquidity providers' market share is also taken into account. +* Each Vega public key with a non-zero token balance gets one vote, and the key votes with the full weight of all the tokens associated to that key. You'll need to have tokens when the vote is submitted *and* when votes are counted, otherwise your vote is disregarded. +* Tokens used for voting are not locked or transferred: they can be used to nominate validators and to vote on other active proposals. +* While the voting period is open, you can change your vote, but only the most recent vote will count at the proposal's close. + +## How a proposal's outcome is calculated +* The network compares the weight of all valid votes cast as a percentage of the total weight that could vote, to the minimum participation requirement - `participation_rate = SUM (weightings of ALL valid votes cast) / max total weighting possible` +* The network compares the weight of all 'for' votes, as a percentage of the weight of all votes cast, to the required majority - `for_rate = SUM (weightings of votes cast for) / SUM (weightings of all votes cast)` +* If the minimum for both is reached, the proposal is enacted. If at least one is not reached, the proposal fails. + +### Proposal outcome: Update market +For proposals to update a market, there are extra requirements. The market's liquidity providers can vote with their equity-like share without requiring tokenholder participation. However, if tokenholders vote and participation and majority requirements for this vote are met, then the tokenholders' votes can overrule the liquidity providers' votes. + +The network will also calculate: +* The LP participation rate, which is the sum of the equity-like share of all LPs who cast a vote - `LP participation rate = SUM (equity-like share of all LPs who cast a vote)` +* The rate of 'for' votes cast by liquidity providers, calculated as the sum of all who voted 'for', divided by the LP participation rate - `LP for rate = SUM (all who voted for) / LP participation rate` + +The proposal will pass if one of the two scenarios occur: +1. The tokenholder vote meets or exceeds the minimum set by , and the votes in favour are greater than the amount set by . In this case the market's liquidity providers were overridden by governance token holders. +2. The governance tokenholder vote does not reach participation threshold, but the liquidity providers' votes do, and there are enough votes in favour. The participation rate must be greater than/equal to , and the liquidity providers' participation rate must be greater than/equal to , and the liquidity providers' votes in favour is greater than/equal to + +### Proposal outcome: Successor market +For proposals adding a new successor market, the outcome of the proposal can change even after it's been approved. + +If a parent market is still in its proposed state, its successor market cannot be enacted, even if it passes the vote. + +Two proposals that name the same parent can be submitted and pass a governance vote. Whichever market clears its [opening auction](../trading-on-vega/trading-modes.md#auction-type-opening) first gets the share of the insurance pool, and the liquidity providers' equity-like share is moved to that market. The second market will then be [rejected](../trading-on-vega/market-lifecycle.md#market-status-rejected). + +## Lifecycle of a governance proposal +You need community support if you want to change something about the network, whether that's to add a new market, change a network parameter, or transfer pooled assets. It's worth considering what your proposed change contributes to the network, and if it would get enough votes from fellow tokenholders. + +You'll have a better chance of positively contributing to the network if you confirm there is support off-chain before submitting a proposal. + +### 1. Sense checking proposal idea (off-chain) +Before submitting a proposal, share an outline of your proposed action informally in a new topic on the [community forum ↗](https://community.vega.xyz/c/governance/25/) Governance Proposals section, with a "sense-check" tag. You can find out if there is enough interest in your proposal. + +Proposals can be submitted for creating a new market, amending an existing market, changing network parameters, adding an external asset to Vega, transferring out of asset pools. You can also suggest changes that won't impact network behaviour with a freeform proposal. + +### 2. Formalising proposal (off-chain) +Once the proposal details are refined, share the detailed proposal in the same topic you created for your sense check, and change the tag to "formalise". + +Including as much detail as possible gives other community members the opportunity to fully understand your proposal. Include the rationale for the proposal (and IPFS hash for more details), the specifics of the proposed addition/change, and the data (JSON or similar) that would be submitted on-chain. Invite debate and discussion to amend the proposal until it reaches a final state, ready to submit. + +When formalising the proposal, it is worth ensuring that any fields that are dependent on a range set by network parameters are correctly defined. See the network parameters and their values on the [Vega block explorer ↗](https://explorer.fairground.wtf/network-parameters). + +### 3. Submitting proposal and telling the community (on-chain and off-chain) +You can submit a governance proposal to the network using the command line, a script, or the [governance dApp ↗](https://governance.fairground.wtf/proposals/propose/raw). + +Your Vega key must have enough VEGA associated to submit a proposal. For a 'market parameter change' proposal, you'll also need enough equity-like share in the market from your liquidity commitment. This is defined in the network parameter . + +Proposals are first checked by the wallet, then verified by the nodes before entering into the voting period you set. A proposal must have all of the relevant information, in the correct format, and in some cases within the accepted range - otherwise it will be rejected immediately. + +A proposal cannot be changed once it's submitted to the network. + +After it's submitted and accepted, rally the community to vote on the proposal by announcing it on the [forum ↗](https://community.vega.xyz/), [Discord ↗](https://vega.xyz/discord), and through your own networks to vote on the proposal. + +:::tip Try it out +**[Proposals guides](../../tutorials/proposals/index.md)**: How to build and then submit a proposal using the command line. +::: + +#### Validating a proposal +* The governance proposal is checked and then accepted by the wallet as a transaction. +* The validator nodes then check and validate the proposal. This is when the proposal data that defines the minimum duration, minimum time to enactment, minimum participation rate, and required majority are evaluated against the network's requirements, defined by [network parameters ↗](https://explorer.fairground.wtf/network-parameters), which are different depending the type of proposal. +* If not specified on the proposal, the required participation rate and majority for success are defined and copied to the proposal. You can find them under the [network parameters ↗](https://explorer.fairground.wtf/network-parameters), and they are specific to each proposal type. +* If the above conditions are not met, the proposal will be rejected and will not be available for a vote. **You'll need to fix and re-submit the proposal.** + +### 4. Voting (on-chain) +VEGA tokenholders - including those who submitted a proposal - can vote for or against any active proposals, with the full weight of the tokens associated with each public key. + +Read more about [voting](#voting-on-proposals). + +### 5. Enacting changes (on-chain) +If a proposal receives enough token weight in favour within the enactment period, the change/addition is accepted (except for a freeform proposal), and will be enacted on the enactment date defined in the proposal. + +Note the enactment date must be at least the minimum enactment period for the proposal type/subtype (specified by a network parameter for each proposal type) after voting closes. See the network parameters and their values on the [Vega block explorer ↗](https://explorer.fairground.wtf/network-parameters). + +## Submitting proposals in a batch +You can submit governance proposals individually, or batch up the proposed changes into one proposal. + +The only thing that can't be proposed in a batch is adding a new asset - that needs to be a proposal on its own. + +When a batch proposal goes up for the vote, each proposed change within the batch needs to pass based on its own voting requirements. For example, if the batch includes a market change, the equity-like share voting rules apply to that specific change. + +Every proposed change in the batch needs to pass its voting requirements, or the whole batch fails. + +The batch proposal only has one rationale field, as well as one closing timestamp, for the whole set of proposals, so the description should describe why each change is being proposed. Each enactment timestamp needs to work with the single closing timestamp chosen for the batch. + +## Thresholds set by network parameters +Certain governance parameters need to be within a defined range, but offer some flexibility. + +When a submitted governance proposal is validated, the values chosen will be checked to ensure they fit within the thresholds, which themselves are defined by network parameters. + +Each type of governance proposal can have different thresholds, though they fit into broader categories. Those categories include: + +* `minProposerBalance`: Minimum amount of VEGA that a proposer needs to have associated with their Vega key to have the proposal accepted for a tokenholder vote +* `minClose`: Minimum amount of time before a proposal can be closed for voting +* `maxClose`: Maximum amount of time a proposal can be open for voting +* `minEnactment`: Minimum time allowed between vote closing on a proposal and the proposal's change being enacted on the network +* `maxEnactment`: Maximum time allowed between vote closing on a proposal and the proposal's change being enacted on the network +* `requiredParticipation`: Minimum number of tokens that must vote for a proposal to pass +* `requiredMajority`: Minimum majority that a proposal's 'yes' votes must reach for it to be enacted + +As these thresholds are network parameters, their values can be changed through governance. + +:::tip Query for data +**[Block explorer ↗](https://explorer.fairground.wtf)**: See the current network parameter values (in some cases, different per network). + +**[REST](../../api/rest/state/core-state-service-list-network-parameters.api.mdx)** The API provides the network parameters and their values. +::: + +### Example +Consider a network parameter that specifies the proportion of fees that goes to validators (). Each of the following thresholds would need to be met: + +* +* +* +* +* +* +* diff --git a/docs/concepts/governance/market.md b/docs/concepts/governance/market.md new file mode 100644 index 000000000..ae91ed298 --- /dev/null +++ b/docs/concepts/governance/market.md @@ -0,0 +1,121 @@ +--- +sidebar_position: 5 +title: Market governance +vega_network: TESTNET +hide_title: false +description: Add new markets or change existing ones. +--- +import NetworkParameter from '@site/src/components/NetworkParameter'; + +Markets are proposed and voted into existence by Vega tokenholders. The parameters for a market all need to be defined in the proposal. + +Some market parameters can also be changed. They can only be proposed by a liquidity provider with enough equity-like share in the market, and need to be voted for by a sufficient number of tokenholders and/or liquidity providers. + +When creating a market governance proposal, whether it is for a new dated futures market, a new perpetual futures market, or to change parameters for an existing market, it's recommended that you sense check the proposal and share the final details with the tokenholder community before proposing, so that you can garner support and make any necessary amends. + +Read more: +* [Vega community forum ↗](https://community.vega.xyz): Share your draft proposals for community discussion. +* [New perpetual futures market proposal ↗](../../tutorials/proposals/new-perpetuals-market.md): Guide to submitting a proposal for a new market +* [New futures market proposal ↗](../../tutorials/proposals/new-market-proposal.md): Guide to submitting a proposal for a new market +* [New successor market proposal ↗](../../tutorials/proposals/new-successor-market-proposal.md): Guide to submitting a proposal for a new successor market +* [Update market proposal ↗](../../tutorials/proposals/update-market-proposal.md): Guide to submitting a proposal to change a market using the command line + +### Propose a new market +Tokenholders can propose new markets, which then need to be voted on by other tokenholders. The proposer will need to have at least , associated with the public key you're using to propose the market, and staked to a validator. Note, this amount is set through the network parameter . + +If the market proposal gets a majority of tokenholder support, then it will be enacted. The required majority is defined by the network parameter . + +To propose a market, you'll need to provide the details required for the market to begin trading right away. While some of the fields are free-text, others are constrained by a range set through network parameters, to ensure that the values provided are fit for purpose. + +Required fields include: +* Instrument details, including a human-readable name, an understandable shortcode for the market, the type of product +* Risk model parameters +* Product specifics including the settlement asset and quote name +* Decimal places for the market and positions. (Note: A market cannot specify more decimal places than its settlement asset supports) +* Oracle details, including the oracle's public key, specifications for settlement price, and data filters +* Liquidity parameters, including the target stake + +Optional fields include: +* Metadata so that people can easily interpret the market's details - while this is optional, it's highly recommended that you include metadata for the market +* Price monitoring parameters, including the triggers covering the horizon, probability and auction extension time. If left blank these parameters will default to the values set in the network parameters + +:::note Read more +* [New market proposal tutorial](../../tutorials/proposals/new-market-proposal.md) +* [Data sources](../trading-on-vega/data-sources.md) +* [Price monitoring parameters](../trading-on-vega/market-protections.md#price-monitoring) +::: + +### Risk models and parameters +When proposing a market, the market proposer will need to choose the risk parameters associated with the risk model that's appropriate for the instrument. The acceptable amount of volatility on a market is driven by its risk model. The risk model is essential for calculating margins on the market. + +The [log-normal risk model](#log-normal-risk-model) is the only one currently supported. While the model is pre-defined, you'll need to choose the individual parameters. + +You should choose parameters that ensure the risk model adequately represents the dynamics of the underlying instrument, and that the resulting margins strike the right balance between prudence and capital efficiency. + +Below are the risk parameters, the accepted values for each parameter and suggested values for some. When suggested values are provided, these should be used as a reference point and to aid in deciding on what's appropriate for the market, not in place of rigorous analysis and calibration. + +Model-independent parameters used in margin calculation are: + +* `Risk aversion lambda` - probability confidence level used in [expected shortfall ↗](https://vega.xyz/papers/margins-and-credit-risk.pdf#page=7) calculation when obtaining the maintenance margin level. This enters the margin calculation as follows. First, the value at risk, defined by confidence lambda is calculated. This is the cash amount that one would need to add to the position to make the probability of the value of the position and cash going negative after time tau to be less than lambda. The margin is then the expected loss of the position given that it incurred a loss bigger than the value at risk. + * accepted values: **strictly greater than 0 and strictly smaller than 1** + * suggested value: `0.00001` +* `Tau` - projection horizon measured as a year fraction used in the expected shortfall calculation to obtain the maintenance margin: + * accepted values: **any strictly non-negative real number**, + * suggested value: `0.000114077116130504` - corresponds to one hour expressed as year fraction +* `Risk free rate` - annualised growth rate of the risk-free asset, it's used for discounting of future cash flows: + * accepted values: **any real number**, + * suggested value: `0`. + +The remaining, model specific parameters are covered below. + +:::note Go deeper +**[Margins and Credit Risk on Vega ↗](https://vega.xyz/papers/margins-and-credit-risk.pdf)**: Note, a position size of 1 is assumed throughout the research paper. +::: + +#### Log-normal risk model +The log-normal model assumes that the logarithm of the price increments are normally distributed. The main model parameter is: +* `Volatility (Sigma)` - annualised historical volatility of the underlying asset: + * accepted values: **any strictly non-negative real number**, + * suggested value: asset dependent, should be derived from the historical time-series of prices, and a typical value would be 0.8 = 80% + +Another parameter is +* `Mu` - annualised growth rate of the underlying asset: + * accepted values: **any real number**, + * suggested value: in almost all situations `0` is the value to use + +### Propose a successor market +A successor market is a market that will carry on after the original market, or parent, that it is based on has settled - though a parent and successor market can be active simultaneously. Proposing a new successor market that follows from an existing market offers liquidity providers the option to keep their [equity-like share](../liquidity/rewards-penalties.md#how-liquidity-fees-are-split) on the new market, even when the original market expires. Creating an entirely new market with no parent doesn't offer the same benefit. + +Each market can have only one active successor. A successor market can also be a parent market. + +In terms of the proposal format, there are only two differences between a succesor market proposal and that for a regular market, and one field that ties the successor to the parent market. +* Parent market ID: Required to define the proposal as for a successor market +* Insurance pool percentage: Required percentage of the parent market's insurance pool, up to 100%, can be earmarked for transfer to the successor market. It is submitted as a number between and including 0 and 1, which represents the factor for the percentage. +* Settlement asset validation: The settlement asset needs to match that of the parent market + +For a successor market to be enacted, the parent market must be in one of the following states: proposed, pending, active, suspended or trading terminated. + +The parent market can be settled or cancelled when the successor market reaches enactment time, as long as the time it's been settled/cancelled is equal to or less than the parent market's settlement time plus the `market.liquidity.successorLaunchWindowLength` - determined by a network parameter. This parameter specifies for how long after a market has settled, the liquidity provider's equity-like share data are retained and the insurance pool is left undistributed to allow a successor to be defined. If the successor is proposed after that time, then it's rejected and any assets committed to the market are returned. + +### Propose updates to a market +Most details about a market can be changed through governance. Those includes risk models, monitoring triggers, and the settlement and termination (if applicable) data sources. + +However, there are a few that cannot be edited, and will be the same for the duration of the market's life. +* Name: Market name, which should be a short, descriptive and relevant name +* Settlement asset: Asset used for margin, liquidity, and to settle positions +* Decimal places/precision for: + * Market - Sets the smallest price increment on the book. A market cannot specify more decimal places than its settlement asset supports + * Position - Precision of the position size + +### Propose a change to a market's state +Markets can be suspended, resumed from being suspended, and terminated using governance proposals. + +Suspending a market puts the market into an auction-only state. A market can be suspended for an indefinite amount of time, and it may never come out of suspension. + +A suspended market can only open to normal trading again if a proposal to resume the market is proposed and enacted. + +Markets that are terminated are closed to trading forever. When a proposal to terminate a market is enacted, it ends all trading on the market, settles all positions, and closes the market completely. The termination proposal includes a final price that's used to settle all open positions. + +:::tip Try it out +[Tutorial: Propose a change to a market's state](../../tutorials/proposals/market-state-proposal.md) +::: diff --git a/docs/concepts/governance/network-parameter.md b/docs/concepts/governance/network-parameter.md new file mode 100644 index 000000000..7b844026c --- /dev/null +++ b/docs/concepts/governance/network-parameter.md @@ -0,0 +1,33 @@ +--- +sidebar_position: 6 +title: Network parameter +vega_network: TESTNET +hide_title: false +description: Change network configuration parameters. +--- +import NetworkParameter from '@site/src/components/NetworkParameter'; + +There are certain parameters within Vega that influence the behaviour of the system and can be changed by on-chain governance. + +Vega tokenholders can define the optimal network configuration by creating and voting on network parameter proposals to change the values of existing network parameters. + +Network parameters can only be added and removed with Vega core software releases. + +:::note Go deeper +* [Concept: Network parameters](../vega-chain/network.md#parameters) +* [Network parameters: See full list on the block explorer ↗](https://explorer.fairground.wtf/network-parameters) +* [Tutorial: Propose a network parameter change](../../tutorials/proposals/network-parameter-proposal.md) +::: + +### Suggested ranges for parameters +Some network parameters have minimum/maximum boundaries to ensure they aren't supplied with nonsensical values. The table below contains those parameters, to be used as guidance when proposing changes to any of those parameters. + +| Parameter name | Minimum/Maximum | +|---------------------------------------------------|-----------------| +| `reward.staking.delegation.competitionLevel` | Minimum value 1 (inclusive), no maximum. | +| `governance.proposal.(TYPE).minEnact` | Must be greater than / equal to the corresponding `minClose`, proposal can't be enacted before voting on it has closed. | +| `governance.proposal.(TYPE).requiredMajority` | Minimum 0.0, maximum 1.0. Is multiplied by 100 to get percentage. | +| `governance.proposal.(TYPE).requiredParticipation`| Minimum 0.0, maximum 1.0. Is multiplied by 100 to get percentage. | +| `rewards.activityStreak.benefitTiers`: `reward_multiplier` | Minimum 1.0. | +import DocCardList from '@theme/DocCardList'; +import {useCurrentSidebarCategory} from '@docusaurus/theme-common'; diff --git a/docs/concepts/governance/treasury.md b/docs/concepts/governance/treasury.md new file mode 100644 index 000000000..b3359e7ac --- /dev/null +++ b/docs/concepts/governance/treasury.md @@ -0,0 +1,67 @@ +--- +sidebar_position: 3 +title: Vega treasury +vega_network: TESTNET +hide_title: false +description: How you can allocate treasury funds. +--- +import NetworkParameter from '@site/src/components/NetworkParameter'; + +The network treasury holds assets that can be used by the community to fund initiatives. You can take part in decision-making around building and growing Vega. + +Treasury assets can be used to fund trading rewards, team competitions, grants, or other opportunities. + +Anyone with VEGA tokens can vote on or raise proposals to use treasury assets. + +## Treasury basics +The network treasury is funded with VEGA tokens, to be used by community members to grow and support the Vega network. + +### Token details +Contract address: `0xcB84d72e61e383767C4DFEb2d8ff7f4FB89abc6e` + +Vega asset ID: `d1984e3d365faa05bcafbe41f50f90e3663ee7c0da22bb1e24b164e9532691b2` + +See more details on the [block explorer ↗](https://explorer.vega.xyz/assets/d1984e3d365faa05bcafbe41f50f90e3663ee7c0da22bb1e24b164e9532691b2). + +### Treasury value +You can see how much is in the network treasury at any point with the `list accounts API`. + +* Use the [REST endpoint](../../api/rest/data-v2/trading-data-service-list-accounts.api.mdx) +* Filter by: + * Asset ID for the VEGA token, and + * Account type: `ACCOUNT_TYPE_NETWORK_TREASURY` +* Don't forget to account for the token's 18 decimal places + +## What the treasury can fund + +**Rewards**: Rewards can incentivise trading, liquidity provision, and proposing successful markets. +- Recognise *active traders* by targeting those who pay maker fees, or have large or profitable positions +- Incentivise *liquidity provision* by funding rewards for participants who receive liquidity and/or maker fees +- Support market success by rewarding proposers who create markets that attract high trading volumes + +Read in detail on the [rewards page](../trading-on-vega/discounts-rewards.md#trading-rewards) about the trading rewards you can choose from. + +**Team games**: Rewards that are targeted to a team entity scope let teams compete against each other for a share of the winnings. You can propose a team game for any type of trading reward. + +Read more about how these work in the [teams and games](../trading-on-vega/discounts-rewards.md#teams-and-games) section. + +**Grants and other initiatives**: A transfer can send to any Vega key, even if it's an individual and not a reward account. You can use a freeform proposal to gauge the community's interest and hone the plan before setting up the proposal for transferring assets. + +## How to allocate the treasury +The most direct way to propose spending the assets is by submitting a **[proposal to transfer assets](../assets/transfers.md#governance-initiated-transfers)**. + +The proposal includes details about the specific account(s) or key(s) that you want to send assets to, as well as when to send, and how often. The transfer can be set to happen once or repeatedly. + +Include a description of what you're intending to do with the treasury funds in your proposal's rationale so that the community can understand why and engage with your proposal. + +See the [tutorial](../../tutorials/proposals/asset-transfer-proposal.md) for a template and description of each field. + +Another option is to submit a [freeform proposal](../../tutorials/proposals/freeform-proposal.md) to suggest a non-binding idea to the community and gauge their sentiment. This would be a good option for grants or other initiatives. Raise a freeform proposal with your plan, with clear details about what you think the money should be spent on, and if there's an organisation or provider you'd like to suggest working with, details about who they are and why they, and the initiative, are a good choice. Based on feedback and voting for your freeform proposal, you can then decide to raise a proposal to transfer assets accordingly. + + + + + + diff --git a/docs/concepts/trading-on-vega/discounts-rewards.md b/docs/concepts/trading-on-vega/discounts-rewards.md index 1952f160e..b2680a58c 100644 --- a/docs/concepts/trading-on-vega/discounts-rewards.md +++ b/docs/concepts/trading-on-vega/discounts-rewards.md @@ -102,7 +102,7 @@ Leaving your reward earnings in your vested account will increase your share of You can see the current reward hoarder bonus requirements and benefits on the [block explorer ↗](https://explorer.fairground.wtf/network-parameters#rewards.vesting.benefitTiers), or querying the [network parameters API](../../api/rest/data-v2/trading-data-service-list-network-parameters.api.mdx) for the `rewards.vesting.benefitTiers` network parameter. -These tiers are set through network parameters, and thus can be changed through [governance](../governance.md#network-parameter-governance). +These tiers are set through network parameters, and thus can be changed through [governance](../governance/network-parameters.md). :::tip Try it out [Tutorial: Propose a network parameter change](../../tutorials/proposals/network-parameter-proposal.md) @@ -121,7 +121,7 @@ If you go inactive for more than , as well as the settlement asset's quantum to assess the market's size. diff --git a/docs/concepts/vega-chain/_category_.json b/docs/concepts/vega-chain/_category_.json index 05f2cb09a..25ad5bb0d 100644 --- a/docs/concepts/vega-chain/_category_.json +++ b/docs/concepts/vega-chain/_category_.json @@ -1,5 +1,5 @@ { "label": "Vega chain", - "collapsed": false, - "position": 4 + "collapsed": true, + "position": 5 } \ No newline at end of file diff --git a/docs/concepts/vega-chain/proof-of-stake.md b/docs/concepts/vega-chain/proof-of-stake.md index 0dbacef59..b17721f06 100644 --- a/docs/concepts/vega-chain/proof-of-stake.md +++ b/docs/concepts/vega-chain/proof-of-stake.md @@ -33,6 +33,13 @@ Vega is non-slashing -- there is no mechanism through which a tokenholder can lo ## VEGA token Vega uses the VEGA ERC20 token for governance, which includes nominating validators to run nodes, and creating and voting on governance proposals. +:::info VEGA token details +Asset ID: `d1984e3d365faa05bcafbe41f50f90e3663ee7c0da22bb1e24b164e9532691b2` +Contract address: `0xcB84d72e61e383767C4DFEb2d8ff7f4FB89abc6e` + +See more details on the [block explorer ↗](https://explorer.vega.xyz/assets/d1984e3d365faa05bcafbe41f50f90e3663ee7c0da22bb1e24b164e9532691b2). +::: + If a token is delegated, its governance voting rights stay with the tokenholder and are not transferred to any validators that the tokenholder nominates. A VEGA token (or fraction) can be either dissociated or associated with a Vega key: @@ -42,7 +49,7 @@ A VEGA token (or fraction) can be either dissociated or associated with a Vega k **All tokens can be used for staking and voting** on governance proposals. This includes tokens that are locked in the vesting contract. Tokens that are staked can be used to vote, and tokens used to vote can be staked. -Read more: [Governance of Vega](../governance.md) +Read more: [Governance of Vega](../governance/index.md) :::tip Associate tokens first A user's VEGA tokens must first be associated with a Vega key before they can be used for governance and nominating validators. @@ -68,7 +75,7 @@ Whether tokens are unlocked or locked, the bridge events let the Vega network kn All events (including the above, plus stake per validator and others) are only registered after a certain number of block confirmations, as defined by the network parameter . :::note Go deeper -**[Staking Bridge contracts](https://github.com/vegaprotocol/Staking_Bridge)** - on Vega's staking bridge GitHub repository. +**[Staking Bridge contracts ↗](https://github.com/vegaprotocol/Staking_Bridge)** - on Vega's staking bridge GitHub repository. ::: ## Staking on Vega diff --git a/docs/topics/_topic-governance.mdx b/docs/topics/_topic-governance.mdx index fbf927b03..26e4f4bb4 100644 --- a/docs/topics/_topic-governance.mdx +++ b/docs/topics/_topic-governance.mdx @@ -5,7 +5,7 @@ This section is part of a series on the topic of *Governance*. Docs: -- [Introduction to governance](/concepts/governance.md) +- [Introduction to governance](/concepts/governance/index.md) - [Tutorials: Governance proposals](/tutorials/proposals/index.md) Tools: diff --git a/docs/tutorials/proposals/index.md b/docs/tutorials/proposals/index.md index 4d1ce8a63..923a676ad 100644 --- a/docs/tutorials/proposals/index.md +++ b/docs/tutorials/proposals/index.md @@ -25,12 +25,12 @@ You will typically need: - A connected [Vega wallet](../../tools/vega-wallet/index.md), with your wallet name and public key to hand - A minimum amount of Vega tokens associated with that public key -- Familiarity with [governance on Vega](../../concepts/governance.md) +- Familiarity with [governance on Vega](../../concepts/governance/index.md) ## Proposal types This section includes sample proposals that you can amend and submit via the command line. - +Read more about the lifecycle of a governance proposal in [the Concepts section](../../concepts/governance/lifecycle.md). -Read more about the lifecycle of a governance proposal in [the Concepts section](../../concepts/governance.md). + From 658164507eea7f3f0f226e7875ebed1ce4480dd7 Mon Sep 17 00:00:00 2001 From: Edd Date: Fri, 23 Feb 2024 19:22:31 +0000 Subject: [PATCH 02/14] Make noisy logging opt in --- .../webpack-docusaurus-plugin.config.js | 59 ++++++++++++++----- 1 file changed, 43 insertions(+), 16 deletions(-) diff --git a/src/plugins/webpack-docusaurus-plugin.config.js b/src/plugins/webpack-docusaurus-plugin.config.js index 4d4b2e6a6..4fc33b82f 100644 --- a/src/plugins/webpack-docusaurus-plugin.config.js +++ b/src/plugins/webpack-docusaurus-plugin.config.js @@ -8,6 +8,22 @@ async function webpackDocusaurusPlugin(context, options) { name: 'webpack-docusaurus-plugin', configureWebpack(config, isServer, utils) { const isCI = process.env.CI; + const enableVerboseBuild = process.env.VERBOSE_BUILD === "true"; + const enableEsbuild = process.env.ESBUILD === "true"; + + if (isServer) { + if (enableVerboseBuild) { + console.log(`🏗️ Enabling verbose, error obscuring output for webpack`); + } else { + console.log(`🏗️ Set VERBOSE_BUILD=true to see more output from webpack`); + } + if (enableEsbuild) { + console.log(`📦️ Enabling ESBuild minifier`); + } else { + console.log(`📦️️ Set ESBUILD=true to use alternative minification`); + } + } + let cacheOptions // Right now, isServer is only used to avoid logging the cache disablement twice. @@ -17,7 +33,7 @@ async function webpackDocusaurusPlugin(context, options) { if (isServer) { // Only logs on server, purely so it only shows up once rather than twice console.log(`🚤 Allowing brotli ${ isServer ? 'server' : 'client'} webpack cache`); - cacheOptions = isCI ? { cache: false } : { cache: { profile: true, type: 'filesystem', compression: 'brotli' }}; + cacheOptions = { cache: { type: 'filesystem', compression: 'brotli' }}; } else { console.log(`ℹ️ Disabling ${ isServer ? 'server' : 'client'} webpack cache because Vercel sigkills`); cacheOptions = { cache: false } @@ -27,32 +43,43 @@ async function webpackDocusaurusPlugin(context, options) { } else { if (isServer) { // Only logs on server, purely so it only shows up once rather than twice - console.log(`🚤 Enabling filesystem cache 🚤🚤 (${ isServer ? 'server' : 'client' })`); + console.log(`🚤 Enabling filesystem cache 🚤🚤`); } - cacheOptions = isCI ? { cache: false } : { cache: { profile: true, type: 'filesystem' }}; + cacheOptions = { cache: { type: 'filesystem' }}; } - const plugins = config.plugins.filter(p => { - return !(p instanceof webpackbar); - }); - - // A more informative progress reporter than webpackbar - plugins.push(new webpack.ProgressPlugin(),) + // Replace webpackbar with a more informative progress reporter (if DEBUG=true is passed in) + let plugins + if (enableVerboseBuild) { + plugins = config.plugins.filter(p => { + return !(p instanceof webpackbar); + }); - const minimizer = new TerserPlugin({ - minify: TerserPlugin.esbuildMinify, - }); + // A more informative progress reporter than webpackbar + plugins.push(new webpack.ProgressPlugin(),) + } else { + plugins = config.plugins + } - const minimizers = config.optimization.minimizer?.map((m) => - m instanceof TerserPlugin ? minimizer : m - ); + // Replace TerserPlugin with esbuild for faster, more efficient minification (if ESBUILD=true is passed in) + let minimizers + if (enableEsbuild) { + const minimizer = new TerserPlugin({ + minify: TerserPlugin.esbuildMinify, + }); + minimizers = config.optimization.minimizer?.map((m) => + m instanceof TerserPlugin ? minimizer : m + ); + } else { + minimizers = config.optimization.minimizer + } return { // Ensure these new options get used mergeStrategy: { 'cache': 'replace', 'cache.type': 'replace', - 'cache.profile': 'replace', + 'cache.compression': 'replace', 'infrastructureLogging.level': 'replace', 'stats.all': 'replace', 'optimization.minimizer': 'replace', From c6265bed63d8a2408bf245783aa46c55dc380e41 Mon Sep 17 00:00:00 2001 From: candida-d <62548908+candida-d@users.noreply.github.com> Date: Mon, 26 Feb 2024 13:00:43 +0000 Subject: [PATCH 03/14] governance section --- docs/api/building-blocks.md | 4 ++-- docs/concepts/trading-on-vega/discounts-rewards.md | 2 +- docs/intro/token-economics.md | 2 +- docs/tutorials/proposals/asset-transfer-proposal.md | 4 ++-- docs/tutorials/proposals/freeform-proposal.md | 4 ++-- docs/tutorials/proposals/market-state-proposal.md | 4 ++-- docs/tutorials/proposals/network-parameter-proposal.md | 4 ++-- docs/tutorials/proposals/new-asset-proposal.md | 4 ++-- docs/tutorials/proposals/new-market-proposal.md | 8 ++++---- docs/tutorials/proposals/new-perpetuals-market.md | 6 +++--- docs/tutorials/proposals/new-successor-market-proposal.md | 6 +++--- docs/tutorials/proposals/referral-program-proposal.md | 4 ++-- docs/tutorials/proposals/update-asset-bridge.md | 2 +- docs/tutorials/proposals/update-asset-proposal.md | 4 ++-- docs/tutorials/proposals/update-market-proposal.md | 4 ++-- .../proposals/volume-discount-program-proposal.md | 4 ++-- docs/tutorials/using-data-sources.md | 2 +- 17 files changed, 34 insertions(+), 34 deletions(-) diff --git a/docs/api/building-blocks.md b/docs/api/building-blocks.md index 7789bf6f9..7d7d4db8e 100644 --- a/docs/api/building-blocks.md +++ b/docs/api/building-blocks.md @@ -77,7 +77,7 @@ Governance proposals used to add new assets and markets, as well as to suggest c | Get detailed information about a specific governance proposal using its ID | [Proposal](../api/rest/data-v2/trading-data-service-get-governance-data.api.mdx) | `GET /api/v2/governance` ||| |How to submit proposals using command line | [Submitting proposals](../tutorials/proposals/index.md) | | -| Understanding the concepts: Governance | [Vega governance](../concepts/governance.md) | +| Understanding the concepts: Governance | [Vega governance](../concepts/governance/index.md) | ### Governance token VEGA token are used for taking part in network, market, asset and freeform governance, and to secure the network by nominating validators that run the network. @@ -87,4 +87,4 @@ VEGA token are used for taking part in network, market, asset and freeform gover | See a list of votes | [List votes](../api/rest/data-v2/trading-data-service-list-votes.api.mdx) | `GET /api/v2/votes` | ||| | How to nominate validators using the smart contracts | [Stake tokens](../tutorials/assets-tokens/staking-tokens.md) | -| Understand the concepts: Governance | [Vega governance](../concepts/governance.md) | +| Understand the concepts: Governance | [Vega governance](../concepts/governance/index.md) | diff --git a/docs/concepts/trading-on-vega/discounts-rewards.md b/docs/concepts/trading-on-vega/discounts-rewards.md index b2680a58c..c5d48b07c 100644 --- a/docs/concepts/trading-on-vega/discounts-rewards.md +++ b/docs/concepts/trading-on-vega/discounts-rewards.md @@ -102,7 +102,7 @@ Leaving your reward earnings in your vested account will increase your share of You can see the current reward hoarder bonus requirements and benefits on the [block explorer ↗](https://explorer.fairground.wtf/network-parameters#rewards.vesting.benefitTiers), or querying the [network parameters API](../../api/rest/data-v2/trading-data-service-list-network-parameters.api.mdx) for the `rewards.vesting.benefitTiers` network parameter. -These tiers are set through network parameters, and thus can be changed through [governance](../governance/network-parameters.md). +These tiers are set through network parameters, and thus can be changed through [governance](../governance/network-parameter.md). :::tip Try it out [Tutorial: Propose a network parameter change](../../tutorials/proposals/network-parameter-proposal.md) diff --git a/docs/intro/token-economics.md b/docs/intro/token-economics.md index 92bc67a09..91ddf738c 100644 --- a/docs/intro/token-economics.md +++ b/docs/intro/token-economics.md @@ -26,4 +26,4 @@ Check active validators and their respective stakes and performances using the [ Once staked, VEGA tokens also allow holders to vote on governance proposals, along with proposing their own changes. These proposals range from changing network parameter values to proposing entirely new markets. -Active proposals can be found on the [governance dApp proposals page ↗](https://token.vega.xyz/proposals) whilst a more in-depth guide to the various governance options can be found on the [governance](../concepts/governance.md) concepts page. \ No newline at end of file +Active proposals can be found on the [governance dApp proposals page ↗](https://token.vega.xyz/proposals) whilst a more in-depth guide to the various governance options can be found on the [governance](../concepts/governance/index.md) concepts page. \ No newline at end of file diff --git a/docs/tutorials/proposals/asset-transfer-proposal.md b/docs/tutorials/proposals/asset-transfer-proposal.md index c8b89834c..2ce6f9615 100644 --- a/docs/tutorials/proposals/asset-transfer-proposal.md +++ b/docs/tutorials/proposals/asset-transfer-proposal.md @@ -25,7 +25,7 @@ This tutorial describes what you need to propose transferring assets from those You will need: * A connected [Vega wallet](../../tools/vega-wallet/index.md), with your wallet name and public key to hand * A minimum of whichever is larger, associated with that public key: () or () -* Familiarity with how [proposing an asset transfer](../../concepts/governance.md#propose-an-asset-transfer) works +* Familiarity with how [proposing an asset transfer](../../concepts/governance/asset.md#propose-an-asset-transfer) works @@ -357,7 +357,7 @@ Building support is down to you. Share your proposal in the [_Governance_ sectio To vote, community members need, at a minimum, the larger of , or associated with their Vega key. -Your proposal will need [participation](../../concepts/governance.md#how-a-proposals-outcome-is-calculated) of and a majority of , so having community support is essential. +Your proposal will need [participation](../../concepts/governance/lifecycle.md#how-a-proposals-outcome-is-calculated) of and a majority of , so having community support is essential. Proposers who invite feedback, engage with comments, and make revisions to meet the needs of the community are more likely to be successful. diff --git a/docs/tutorials/proposals/freeform-proposal.md b/docs/tutorials/proposals/freeform-proposal.md index c62319a00..802477fee 100644 --- a/docs/tutorials/proposals/freeform-proposal.md +++ b/docs/tutorials/proposals/freeform-proposal.md @@ -32,7 +32,7 @@ At enactment time, no changes are effected on the system, but the record of how You will need: * A connected [Vega wallet](../../tools/vega-wallet/index.md), with your wallet name and public key to hand * A minimum of whichever is larger, associated with that public key: () or () -* Familiarity with [governance on Vega](../../concepts/governance.md) +* Familiarity with [governance on Vega](../../concepts/governance/index.md) @@ -75,6 +75,6 @@ Building support is down to you. Share your proposal in the [_Governance_ sectio To vote, community members need, at a minimum, the larger of or , associated to their Vega key. -Your proposal will need [participation](../../concepts/governance.md#how-the-outcome-is-calculated) of and a voting majority of , so having community support is essential. +Your proposal will need [participation](../../concepts/governance/lifecycle.md#how-a-proposals-outcome-is-calculated) of and a voting majority of , so having community support is essential. Proposers who invite feedback, engage with comments, and make revisions to meet the needs of the community are more likely to be successful. diff --git a/docs/tutorials/proposals/market-state-proposal.md b/docs/tutorials/proposals/market-state-proposal.md index 309dd12b3..16986ad11 100644 --- a/docs/tutorials/proposals/market-state-proposal.md +++ b/docs/tutorials/proposals/market-state-proposal.md @@ -28,7 +28,7 @@ Below, learn how to submit a governance proposal to: You will need: * A connected [Vega wallet](../../tools/vega-wallet/index.md), with your wallet name and public key to hand * A minimum of whichever is larger, associated with that public key: () or () -* Familiarity with [market governance](../../concepts/governance.md#market-governance) on Vega +* Familiarity with [market governance](../../concepts/governance/market.md) on Vega @@ -410,7 +410,7 @@ Building support is down to you. Share your proposal in the [_Governance_ sectio To vote, community members need, at a minimum, the larger of or associated to their Vega key. -Your proposal will need [participation](../../concepts/governance.md#how-the-outcome-is-calculated) of , a majority of , as well as a percentage of liquidity provider votes of so having community support is essential. +Your proposal will need [participation](../../concepts/governance/lifecycle.md#how-a-proposals-outcome-is-calculated) of , a majority of , as well as a percentage of liquidity provider votes of so having community support is essential. Proposers who invite feedback, engage with comments, and make revisions to meet the needs of the community are more likely to be successful. diff --git a/docs/tutorials/proposals/network-parameter-proposal.md b/docs/tutorials/proposals/network-parameter-proposal.md index 3b45c441d..43386a780 100644 --- a/docs/tutorials/proposals/network-parameter-proposal.md +++ b/docs/tutorials/proposals/network-parameter-proposal.md @@ -32,7 +32,7 @@ This page describes what you need to propose a change to a network parameter, an You will need: * A connected [Vega wallet](../../tools/vega-wallet/index.md), with your wallet name and public key to hand * A minimum of whichever is larger, associated with that public key: () or () -* Familiarity with [governance on Vega](../../concepts/governance.md) +* Familiarity with [governance on Vega](../../concepts/governance/network-parameter.md) ## Anatomy of a network parameter proposal Read on for the key inputs to a network parameter proposal. @@ -106,7 +106,7 @@ Building support is down to you. Share your proposal in the [_Governance_ sectio To vote, community members need, at a minimum, the larger of , or associated with their Vega key. -Your proposal will need [participation](../../concepts/governance.md#how-a-proposals-outcome-is-calculated) of and a majority of , so having community support is essential. +Your proposal will need [participation](../../concepts/governance/lifecycle.md#how-a-proposals-outcome-is-calculated) of and a majority of , so having community support is essential. Proposers who invite feedback, engage with comments, and make revisions to meet the needs of the community are more likely to be successful. diff --git a/docs/tutorials/proposals/new-asset-proposal.md b/docs/tutorials/proposals/new-asset-proposal.md index 6eb05549a..518fb1f6b 100644 --- a/docs/tutorials/proposals/new-asset-proposal.md +++ b/docs/tutorials/proposals/new-asset-proposal.md @@ -27,7 +27,7 @@ This page provides a tutorial for submitting a proposal for a new ERC-20 asset t You will need: * A connected [Vega wallet](../../tools/vega-wallet/index.md), with your wallet name and public key to hand * A minimum of whichever is larger, associated with that public key: () or () -* Familiarity with [governance on Vega](../../concepts/governance.md), particularly [assets at a protocol level](../../concepts/governance.md#asset-governance) +* Familiarity with [governance on Vega](../../concepts/governance/asset.md). After a new asset vote passes, the change has to be submitted to the asset bridge on Ethereum. Until it has been submitted, no one can start depositing that asset. See the [tutorial](./update-asset-bridge.md) for how to do that. @@ -104,7 +104,7 @@ Building support is down to you. Share your proposal in the [_Governance_ sectio To vote, community members need, at a minimum, the larger of or associated with their Vega key. -Your proposal will need [participation](../../concepts/governance.md#how-the-outcome-is-calculated) of and a majority of , so having community support is essential. +Your proposal will need [participation](../../concepts/governance/lifecycle.md#how-the-outcome-is-calculated) of and a majority of , so having community support is essential. Proposers who invite feedback, engage with comments, and make revisions to meet the needs of the community are more likely to be successful. diff --git a/docs/tutorials/proposals/new-market-proposal.md b/docs/tutorials/proposals/new-market-proposal.md index 15f117476..2ff60a91e 100644 --- a/docs/tutorials/proposals/new-market-proposal.md +++ b/docs/tutorials/proposals/new-market-proposal.md @@ -39,7 +39,7 @@ Looking to propose a perpetuals market? See the [perpetual futures tutorial](./n You will need: * A connected [Vega wallet](../../tools/vega-wallet/index.md), with your wallet name and public key to hand * A minimum of whichever is larger, associated with that public key: , () or () -* Familiarity with [market governance](../../concepts/governance.md#market-governance) on Vega +* Familiarity with [market governance](../../concepts/governance/market.md) on Vega @@ -184,11 +184,11 @@ Price monitoring uses the following properties: You can use a maximum of 5 sets of price monitoring parameters for a market. ### Risk model -Choose the individual parameters for the [log-normal risk model](../../concepts/governance.md#log-normal-risk-model). You should ensure the risk model parameters represent the dynamics of the underlying instrument, and that the resulting margins strike the right balance between prudence and capital efficiency. +Choose the individual parameters for the [log-normal risk model](../../concepts/governance/market.md#log-normal-risk-model). You should ensure the risk model parameters represent the dynamics of the underlying instrument, and that the resulting margins strike the right balance between prudence and capital efficiency. While you cannot define exactly how much margin (or leverage) is possible, you can influence the acceptable levels of market volatility. -Read about the [risk models and parameters](../../concepts/governance.md#risk-models-and-parameters) before choosing your values. +Read about the [risk models and parameters](../../concepts/governance/market.md#risk-models-and-parameters) before choosing your values. The risk model uses the following properties: @@ -268,7 +268,7 @@ Your proposal will need [participation](../../concepts/governance.md#how-a-propo Proposers who invite feedback, engage with comments, and make revisions to meet the needs of the community are more likely to be successful. -Learn more about voting on the [governance concepts](../../concepts/governance.md#voting-on-proposals) page. +Learn more about voting on the [governance concepts](../../concepts/governance/lifecycle.md#voting) page. ## Enactment If successful, the proposal will be enacted at the time you specify in the `enactmentTimestamp` field, or as soon as the [opening auction](../../concepts/trading-on-vega/trading-modes.md#auction-type-opening) has successfully concluded, whichever is later. \ No newline at end of file diff --git a/docs/tutorials/proposals/new-perpetuals-market.md b/docs/tutorials/proposals/new-perpetuals-market.md index 96cab1646..f54ec6f7c 100644 --- a/docs/tutorials/proposals/new-perpetuals-market.md +++ b/docs/tutorials/proposals/new-perpetuals-market.md @@ -31,7 +31,7 @@ import TabItem from '@theme/TabItem'; You will need: * A connected [Vega wallet](../../tools/vega-wallet/index.md), with your wallet name and public key to hand * A minimum of whichever is larger, associated with that public key: () or () -* Familiarity with [governance](../../concepts/governance.md) on Vega +* Familiarity with [governance](../../concepts/governance/market.md) on Vega * Familiarity with using [Ethereum to provide data](../using-data-sources.md#ethereum-oracles) @@ -194,11 +194,11 @@ Price monitoring uses the following properties: You can use a maximum of 5 sets of price monitoring parameters for a market. ### Risk model -Choose the individual parameters for the [log-normal risk model](../../concepts/governance.md#log-normal-risk-model). You should ensure the risk model parameters represent the dynamics of the underlying instrument, and that the resulting margins strike the right balance between prudence and capital efficiency. +Choose the individual parameters for the [log-normal risk model](../../concepts/governance/market.md#log-normal-risk-model). You should ensure the risk model parameters represent the dynamics of the underlying instrument, and that the resulting margins strike the right balance between prudence and capital efficiency. While you cannot define exactly how much margin (or leverage) is possible, you can influence the acceptable levels of market volatility. -Read about the [risk models and parameters](../../concepts/governance.md#risk-models-and-parameters) before choosing your values. +Read about the [risk models and parameters](../../concepts/governance/market.md#risk-models-and-parameters) before choosing your values. The risk model uses the following properties: diff --git a/docs/tutorials/proposals/new-successor-market-proposal.md b/docs/tutorials/proposals/new-successor-market-proposal.md index 396d22a37..b7cba90fa 100644 --- a/docs/tutorials/proposals/new-successor-market-proposal.md +++ b/docs/tutorials/proposals/new-successor-market-proposal.md @@ -30,7 +30,7 @@ Propose a cash-settled futures market to succeed an existing market, taking alon You will need: * A connected [Vega wallet](../../tools/vega-wallet/index.md), with your wallet name and public key to hand * A minimum of whichever is larger, associated with that public key: () or () -* Familiarity with [successor market governance](../../concepts/governance.md#propose-a-successor-market) on Vega +* Familiarity with [successor market governance](../../concepts/governance/market.md#propose-a-successor-market) on Vega ## Anatomy of a new successor market proposal The new successor market proposal requires the same fields as a new market proposal, with the addition of two fields described below. @@ -84,9 +84,9 @@ Building support is down to you. Share your proposal in the [_Governance_ sectio To vote, community members need, at a minimum, the larger of or associated to their Vega key. -Your proposal will need [participation](../../concepts/governance.md#how-a-proposals-outcome-is-calculated) of and a majority of , so having community support is essential. +Your proposal will need [participation](../../concepts/governance/lifecycle.md#how-a-proposals-outcome-is-calculated) of and a majority of , so having community support is essential. Proposers who invite feedback, engage with comments, and make revisions to meet the needs of the community are more likely to be successful. ## Enactment -If successful, the proposal will be enacted at the time you specify in the `enactmentTimestamp` field, depending on the [status of other successor market proposals](../../concepts/governance.md#proposal-outcome-successor-market). \ No newline at end of file +If successful, the proposal will be enacted at the time you specify in the `enactmentTimestamp` field, depending on the [status of other successor market proposals](../../concepts/governance/lifecycle.md#proposal-outcome-successor-market). \ No newline at end of file diff --git a/docs/tutorials/proposals/referral-program-proposal.md b/docs/tutorials/proposals/referral-program-proposal.md index d85048340..d15d224f2 100644 --- a/docs/tutorials/proposals/referral-program-proposal.md +++ b/docs/tutorials/proposals/referral-program-proposal.md @@ -27,7 +27,7 @@ This page describes what you need to propose enabling or replacing the referral You will need: * A connected [Vega wallet](../../tools/vega-wallet/index.md), with your wallet name and public key to hand * A minimum of whichever is larger, associated with that public key: () or () -* Familiarity with [governance on Vega](../../concepts/governance.md) +* Familiarity with [governance on Vega](../../concepts/governance/index.md) ## Anatomy of a referral program proposal The fields below all need to be defined to enable the referral program or replace an existing one. @@ -229,7 +229,7 @@ Building support is down to you. Share your proposal in the [_Governance_ sectio To vote, community members need, at a minimum, the larger of or associated to their Vega key. -Your proposal will need [participation](../../concepts/governance.md#how-the-outcome-is-calculated) of and a majority of , so having community support is essential. +Your proposal will need [participation](../../concepts/governance/lifecycle.md#how-the-outcome-is-calculated) of and a majority of , so having community support is essential. Proposers who invite feedback, engage with comments, and make revisions to meet the needs of the community are more likely to be successful. diff --git a/docs/tutorials/proposals/update-asset-bridge.md b/docs/tutorials/proposals/update-asset-bridge.md index 8e80ab126..24f0a6131 100644 --- a/docs/tutorials/proposals/update-asset-bridge.md +++ b/docs/tutorials/proposals/update-asset-bridge.md @@ -25,7 +25,7 @@ Vega validators automatically create a multisig bundle - a collection of signatu ## Requirements You will need: * An Ethereum wallet -* Familiarity with [asset governance](../../concepts/governance.md#asset-governance), as well as how the [asset bridge](../../concepts/assets/asset-framework.md#asset-bridges) works on Ethereum. +* Familiarity with [asset governance](../../concepts/governance/asset.md), as well as how the [asset bridge](../../concepts/assets/asset-framework.md#asset-bridges) works on Ethereum. As an alternative to making the transaction yourself, Etherscan provides a simple interface that can be used to submit updates to the bridge. You can access it by visiting the relevant contract page, under 'Contract' > 'Write contract'. diff --git a/docs/tutorials/proposals/update-asset-proposal.md b/docs/tutorials/proposals/update-asset-proposal.md index 652e3f87e..fa4116aeb 100644 --- a/docs/tutorials/proposals/update-asset-proposal.md +++ b/docs/tutorials/proposals/update-asset-proposal.md @@ -34,7 +34,7 @@ The underlying contract, asset name and symbol cannot be changed. You will need: * A connected [Vega wallet](../../tools/vega-wallet/index.md), with your wallet name and public key to hand -* A minimum of whichever is larger, associated with that public key: () or ()- Familiarity with [governance on Vega](../../concepts/governance.md), particularly [assets at a protocol level](../../concepts/governance.md#asset-governance) +* A minimum of whichever is larger, associated with that public key: () or ()- Familiarity with [governance on Vega](../../concepts/governance/asset.md), particularly [assets at a protocol level](../../concepts/governance/asset.md) After a new asset vote passes, the change has to be submitted to the asset bridge on Ethereum. See the [tutorial](./update-asset-bridge.md) for how to do that. @@ -91,7 +91,7 @@ Building support is down to you. Share your proposal in the [_Governance_ sectio To vote, community members need, at a minimum, the larger of or associated with their Vega key. -Your proposal will need [participation](../../concepts/governance.md#how-the-outcome-is-calculated) of and a majority of , so having community support is essential. +Your proposal will need [participation](../../concepts/governance/lifecycle.md.md#how-the-outcome-is-calculated) of and a majority of , so having community support is essential. Proposers who invite feedback, engage with comments, and make revisions to meet the needs of the community are more likely to be successful. diff --git a/docs/tutorials/proposals/update-market-proposal.md b/docs/tutorials/proposals/update-market-proposal.md index 485deaa34..69ce37e3a 100644 --- a/docs/tutorials/proposals/update-market-proposal.md +++ b/docs/tutorials/proposals/update-market-proposal.md @@ -30,7 +30,7 @@ You will need: * A connected [Vega wallet](../../tools/vega-wallet/index.md), with your wallet name and public key to hand * A minimum of whichever is larger, associated with that public key: () or () * A minimum equity-like share in the market of -* Familiarity with [market governance](../../concepts/governance.md#market-governance) on Vega +* Familiarity with [market governance](../../concepts/governance/market.md) on Vega ## Anatomy of an update market proposal @@ -94,7 +94,7 @@ Building support is down to you. Share your proposal in the [_Governance_ sectio To vote, community members need, at a minimum, the larger of or associated to their Vega key. -Your proposal will need [participation](../../concepts/governance.md#how-the-outcome-is-calculated) of and a majority of , so having community support is essential. +Your proposal will need [participation](../../concepts/governance/lifecycle.md#how-the-outcome-is-calculated) of and a majority of , so having community support is essential. Proposers who invite feedback, engage with comments, and make revisions to meet the needs of the community are more likely to be successful. diff --git a/docs/tutorials/proposals/volume-discount-program-proposal.md b/docs/tutorials/proposals/volume-discount-program-proposal.md index 85316b3d6..b5ede12f7 100644 --- a/docs/tutorials/proposals/volume-discount-program-proposal.md +++ b/docs/tutorials/proposals/volume-discount-program-proposal.md @@ -26,7 +26,7 @@ This page describes what you need to propose enabling or replacing the volume di You will need: * A connected [Vega wallet](../../tools/vega-wallet/index.md), with your wallet name and public key to hand * A minimum of whichever is larger, associated with that public key: () or () -* Familiarity with [governance on Vega](../../concepts/governance.md) +* Familiarity with [governance on Vega](../../concepts/governance/index.md) ## Anatomy of a volume discount program proposal The fields below all need to be defined to enable the volume discount program or replace an existing one. @@ -176,7 +176,7 @@ Building support is down to you. Share your proposal in the [_Governance_ sectio To vote, community members need, at a minimum, the larger of or associated to their Vega key. -Your proposal will need [participation](../../concepts/governance.md#how-the-outcome-is-calculated) of and a majority of , so having community support is essential. +Your proposal will need [participation](../../concepts/governance/lifecycle.md#how-the-outcome-is-calculated) of and a majority of , so having community support is essential. Proposers who invite feedback, engage with comments, and make revisions to meet the needs of the community are more likely to be successful. diff --git a/docs/tutorials/using-data-sources.md b/docs/tutorials/using-data-sources.md index 4f60c9a6e..53aef8d4d 100644 --- a/docs/tutorials/using-data-sources.md +++ b/docs/tutorials/using-data-sources.md @@ -20,7 +20,7 @@ This is done by: The **binding** tells the market which field contains the value. The **spec** defines where this data will come from, and which values to pass through to the binding. :::note Read more: -* [Concept: Market governance](../concepts/governance.md#market-governance) +* [Concept: Market governance](../concepts/governance/market.md) * [Tutorial: Proposing a market](./proposals/new-market-proposal.md) ::: From dbe4f97ac860176bfdb9aa13d31b5d30f07adc1d Mon Sep 17 00:00:00 2001 From: candida-d <62548908+candida-d@users.noreply.github.com> Date: Mon, 26 Feb 2024 13:23:24 +0000 Subject: [PATCH 04/14] governance section --- docs/concepts/assets/asset-framework.md | 2 +- docs/concepts/assets/transfers.md | 2 +- docs/concepts/trading-on-vega/discounts-rewards.md | 2 +- docs/concepts/trading-on-vega/margin.md | 2 +- docs/concepts/trading-on-vega/market-lifecycle.md | 2 +- docs/concepts/trading-on-vega/trading-modes.md | 4 ++-- docs/tutorials/proposals/new-market-proposal.md | 2 +- docs/tutorials/proposals/update-asset-proposal.md | 2 +- 8 files changed, 9 insertions(+), 9 deletions(-) diff --git a/docs/concepts/assets/asset-framework.md b/docs/concepts/assets/asset-framework.md index 9923127ed..aebd9593c 100644 --- a/docs/concepts/assets/asset-framework.md +++ b/docs/concepts/assets/asset-framework.md @@ -5,7 +5,7 @@ vega_network: TESTNET hide_title: false description: Vega supports ERC-20 assets that are added through governance. --- -Vega currently supports exclusively using ERC-20 tokens for markets on Vega. Those assets must be [proposed through governance](../governance.md#asset-governance) and pass the voting threshold, and be enabled on the Vega bridge. ERC-20 tokens originate on the Ethereum chain, not the Vega chain. Inter-chain asset interactions between Vega and Ethereum are facilitated through the Ethereum bridges. +Vega currently supports exclusively using ERC-20 tokens for markets on Vega. Those assets must be [proposed through governance](../governance/asset.md) and pass the voting threshold, and be enabled on the Vega bridge. ERC-20 tokens originate on the Ethereum chain, not the Vega chain. Inter-chain asset interactions between Vega and Ethereum are facilitated through the Ethereum bridges. The assets on Vega are used for margining and settling positions, paying fees, and supplying liquidity on markets. Assets can also be transferred between keys and accounts. diff --git a/docs/concepts/assets/transfers.md b/docs/concepts/assets/transfers.md index 2e8009fe8..ba16f3f1c 100644 --- a/docs/concepts/assets/transfers.md +++ b/docs/concepts/assets/transfers.md @@ -90,6 +90,6 @@ The table below details which types of transfers need to be done using a governa | Any other account | Any | No | :::note Read more -* [Concept: Transfers initiated by governance](../governance.md#transferring-assets) +* [Concept: Transfers initiated by governance](../governance/asset.md#propose-an-asset-transfer) * [Tutorial: Asset transfer proposal](../../tutorials/proposals/asset-transfer-proposal.md) ::: \ No newline at end of file diff --git a/docs/concepts/trading-on-vega/discounts-rewards.md b/docs/concepts/trading-on-vega/discounts-rewards.md index c5d48b07c..796e0b562 100644 --- a/docs/concepts/trading-on-vega/discounts-rewards.md +++ b/docs/concepts/trading-on-vega/discounts-rewards.md @@ -121,7 +121,7 @@ If you go inactive for more than ## Market status: Proposed -All markets must first be proposed by tokenholders by following the [governance process](../governance.md). Once a valid market proposal is accepted, the market can accept [liquidity commitments](../liquidity/provision.md). +All markets must first be proposed by tokenholders by following the [governance process](../governance/lifecycle.md). Once a valid market proposal is accepted, the market can accept [liquidity commitments](../liquidity/provision.md). Voting begins and its state is `proposed`. Not every market that is proposed (and accepts liquidity) is guaranteed to exist, as it must get enough votes in favour from tokenholders. diff --git a/docs/concepts/trading-on-vega/trading-modes.md b/docs/concepts/trading-on-vega/trading-modes.md index e135a82bc..d45efdf21 100644 --- a/docs/concepts/trading-on-vega/trading-modes.md +++ b/docs/concepts/trading-on-vega/trading-modes.md @@ -50,7 +50,7 @@ Every continuous trading market opens with an auction. Their purpose is to calib While a market is in opening auction, liquidity commitments can be submitted to it. Those who start committing earlier will receive a greater [equity-like share](../liquidity/rewards-penalties.md#how-the-fee-is-derived) in the market, which influences the amount of fee revenue they receive. -In the case of a [successor market](../governance.md#propose-a-successor-market), any liquidity provider can submit liquidity commitments to it but those that had been providing liquidity to the parent market will have their equity-like share, and thus its benefits, carried over. +In the case of a [successor market](../governance/market.md#propose-a-successor-market), any liquidity provider can submit liquidity commitments to it but those that had been providing liquidity to the parent market will have their equity-like share, and thus its benefits, carried over. #### Entry into an opening auction A new market’s opening auction begins at the proposal’s closing date. @@ -60,7 +60,7 @@ A market’s opening auction ends at the market enactment time, unless an openin When a market leaves its opening auction, it will use the mid-price within the range of auction bids that would result in the highest trade volume for its normal trading mode. For example, if the volume maximising range is 98-102, the market would price all trades in the uncrossing at 100. The order book would then be uncrossed at that price and the trades follow the normal flow. -When a [successor market](../governance.md#propose-a-successor-market) leaves its opening auction, the insurance pool fraction (multiplied by the parent market's insurance pool balance) that was defined in its market proposal is transferred to the successor market's insurance pool. +When a [successor market](../governance/market.md#propose-a-successor-market) leaves its opening auction, the insurance pool fraction (multiplied by the parent market's insurance pool balance) that was defined in its market proposal is transferred to the successor market's insurance pool. ### Auction type: Price monitoring Sometimes low liquidity and/or a large quantity of order volume can cause a market's price to diverge from the true price. The Vega protocol is designed to assume that relatively small moves are 'real' and that larger moves might not be. The market's risk model and price monitoring settings are used to determine what the boundaries are between small, acceptable moves and large, unrealistic ones. diff --git a/docs/tutorials/proposals/new-market-proposal.md b/docs/tutorials/proposals/new-market-proposal.md index 2ff60a91e..7d4110cac 100644 --- a/docs/tutorials/proposals/new-market-proposal.md +++ b/docs/tutorials/proposals/new-market-proposal.md @@ -264,7 +264,7 @@ A vote can be submitted with a [transaction](../../api/grpc/vega/commands/v1/com To vote, community members need, at a minimum, the larger of , or associated with their Vega key. -Your proposal will need [participation](../../concepts/governance.md#how-a-proposals-outcome-is-calculated) of and a majority of , so having community support is essential. +Your proposal will need [participation](../../concepts/governance/lifecycle.md#how-a-proposals-outcome-is-calculated) of and a majority of , so having community support is essential. Proposers who invite feedback, engage with comments, and make revisions to meet the needs of the community are more likely to be successful. diff --git a/docs/tutorials/proposals/update-asset-proposal.md b/docs/tutorials/proposals/update-asset-proposal.md index fa4116aeb..9fb2f8029 100644 --- a/docs/tutorials/proposals/update-asset-proposal.md +++ b/docs/tutorials/proposals/update-asset-proposal.md @@ -91,7 +91,7 @@ Building support is down to you. Share your proposal in the [_Governance_ sectio To vote, community members need, at a minimum, the larger of or associated with their Vega key. -Your proposal will need [participation](../../concepts/governance/lifecycle.md.md#how-the-outcome-is-calculated) of and a majority of , so having community support is essential. +Your proposal will need [participation](../../concepts/governance/lifecycle.md#how-the-outcome-is-calculated) of and a majority of , so having community support is essential. Proposers who invite feedback, engage with comments, and make revisions to meet the needs of the community are more likely to be successful. From dc509b1f7f1a3cb3a3bc9f80a9e4543767f0ee9b Mon Sep 17 00:00:00 2001 From: candida-d <62548908+candida-d@users.noreply.github.com> Date: Mon, 26 Feb 2024 13:32:26 +0000 Subject: [PATCH 05/14] governance --- docs/concepts/assets/asset-framework.md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/docs/concepts/assets/asset-framework.md b/docs/concepts/assets/asset-framework.md index aebd9593c..eb7615c19 100644 --- a/docs/concepts/assets/asset-framework.md +++ b/docs/concepts/assets/asset-framework.md @@ -56,7 +56,7 @@ ERC-20 is a ubiquitous smart contract interface that allows users to mint, issue Assets need to be proposed and pass a governance vote before they can be used on the Vega network. After a new asset vote passes, the change has to be submitted to the asset bridge on Ethereum. Until it has been submitted, no one can start depositing that asset. :::note Read more -* [Concept: Asset governance](../governance.md#asset-governance) +* [Concept: Asset governance](../governance/asset.md) * [Tutorial: Proposing an asset](../../tutorials/proposals/new-asset-proposal.md) * [Tutorial: Proposing a change to an asset](../../tutorials/proposals/update-asset-proposal.md) ::: From 71f19f091d583a9695d357f695f8aa3b7e07d681 Mon Sep 17 00:00:00 2001 From: candida-d <62548908+candida-d@users.noreply.github.com> Date: Mon, 4 Mar 2024 13:20:52 +0000 Subject: [PATCH 06/14] tick size addition --- docs/concepts/governance/market.md | 1 + 1 file changed, 1 insertion(+) diff --git a/docs/concepts/governance/market.md b/docs/concepts/governance/market.md index ae91ed298..5e26a1e0a 100644 --- a/docs/concepts/governance/market.md +++ b/docs/concepts/governance/market.md @@ -38,6 +38,7 @@ Required fields include: Optional fields include: * Metadata so that people can easily interpret the market's details - while this is optional, it's highly recommended that you include metadata for the market * Price monitoring parameters, including the triggers covering the horizon, probability and auction extension time. If left blank these parameters will default to the values set in the network parameters +* Tick size, to set the minimal change in a price. If not set, it will default to 1 (or 10^{-market decimal places}) :::note Read more * [New market proposal tutorial](../../tutorials/proposals/new-market-proposal.md) From ddc9dc7ded551ea2f14cb346d3ce5b290373baae Mon Sep 17 00:00:00 2001 From: candida-d <62548908+candida-d@users.noreply.github.com> Date: Mon, 11 Mar 2024 15:31:26 +0000 Subject: [PATCH 07/14] treasury Co-authored-by: Barnaby M --- docs/concepts/governance/treasury.md | 48 +++++++++++++++++++++------- 1 file changed, 36 insertions(+), 12 deletions(-) diff --git a/docs/concepts/governance/treasury.md b/docs/concepts/governance/treasury.md index b3359e7ac..4b2193c11 100644 --- a/docs/concepts/governance/treasury.md +++ b/docs/concepts/governance/treasury.md @@ -9,26 +9,26 @@ import NetworkParameter from '@site/src/components/NetworkParameter'; The network treasury holds assets that can be used by the community to fund initiatives. You can take part in decision-making around building and growing Vega. -Treasury assets can be used to fund trading rewards, team competitions, grants, or other opportunities. +Treasury assets can be used to fund trading rewards, team competitions, grants, Vega protocol software and/or product development, teams building on Vega, or other opportunities. Anyone with VEGA tokens can vote on or raise proposals to use treasury assets. ## Treasury basics -The network treasury is funded with VEGA tokens, to be used by community members to grow and support the Vega network. +The network treasury can hold VEGA tokens and other assets, which can be used by the community via on-chain governance to grow and support the development of the Vega software and network. -### Token details -Contract address: `0xcB84d72e61e383767C4DFEb2d8ff7f4FB89abc6e` +### VEGA token details +VEGA token contract address (Ethereum mainnet): `0xcB84d72e61e383767C4DFEb2d8ff7f4FB89abc6e` ([view on Etherscan ↗](https://etherscan.io/token/0xcB84d72e61e383767C4DFEb2d8ff7f4FB89abc6e)) Vega asset ID: `d1984e3d365faa05bcafbe41f50f90e3663ee7c0da22bb1e24b164e9532691b2` See more details on the [block explorer ↗](https://explorer.vega.xyz/assets/d1984e3d365faa05bcafbe41f50f90e3663ee7c0da22bb1e24b164e9532691b2). ### Treasury value -You can see how much is in the network treasury at any point with the `list accounts API`. +You can see how much is in the network treasury, along with recent transactions using the on-chain treasury page on [Block Explorer ↗](https://explorer.vega.xyz/treasury). -* Use the [REST endpoint](../../api/rest/data-v2/trading-data-service-list-accounts.api.mdx) +You can also see the balance programmatically with the `list accounts API`. For example, using the [REST endpoint](../../api/rest/data-v2/trading-data-service-list-accounts.api.mdx): * Filter by: - * Asset ID for the VEGA token, and + * Asset ID for VEGA: `d1984e3d365faa05bcafbe41f50f90e3663ee7c0da22bb1e24b164e9532691b2`, and * Account type: `ACCOUNT_TYPE_NETWORK_TREASURY` * Don't forget to account for the token's 18 decimal places @@ -48,7 +48,12 @@ Read more about how these work in the [teams and games](../trading-on-vega/disco **Grants and other initiatives**: A transfer can send to any Vega key, even if it's an individual and not a reward account. You can use a freeform proposal to gauge the community's interest and hone the plan before setting up the proposal for transferring assets. ## How to allocate the treasury -The most direct way to propose spending the assets is by submitting a **[proposal to transfer assets](../assets/transfers.md#governance-initiated-transfers)**. + +### Using governance to spend assets + +Assets can only be spend from the on-chain treasury by governance, when a **[proposal to transfer assets](../assets/transfers.md#governance-initiated-transfers)** is enacted. + +The most direct way to propose spending the assets is by submitting one of these proposals. In practice, community members almost always discuss proposals on the **[Vega community forums ↗](https://community.vega.xyz/) before submitting**, in order to incorporate community feedback into the proposal and ensure there's broad support before going through the effort of putting it on-chain. The proposal includes details about the specific account(s) or key(s) that you want to send assets to, as well as when to send, and how often. The transfer can be set to happen once or repeatedly. @@ -56,11 +61,30 @@ Include a description of what you're intending to do with the treasury funds in See the [tutorial](../../tutorials/proposals/asset-transfer-proposal.md) for a template and description of each field. -Another option is to submit a [freeform proposal](../../tutorials/proposals/freeform-proposal.md) to suggest a non-binding idea to the community and gauge their sentiment. This would be a good option for grants or other initiatives. Raise a freeform proposal with your plan, with clear details about what you think the money should be spent on, and if there's an organisation or provider you'd like to suggest working with, details about who they are and why they, and the initiative, are a good choice. Based on feedback and voting for your freeform proposal, you can then decide to raise a proposal to transfer assets accordingly. - +### Freeform proposals + +Another option is to submit a [freeform proposal](../../tutorials/proposals/freeform-proposal.md) to suggest a non-binding idea to the community and gauge their sentiment. This would be a good option for grants or other initiatives, especially where opinions may be split on what to do. + +Raise a freeform proposal with your plan. Include clear details about what you think the money should be spent on, and if there's an organisation or provider you'd like to suggest working with, details about who they are and why they -- and the initiative -- are a good choice. You could even raise a few freeform proposals to help decide which of several competing ideas to take through to a final proposal. + +Based on feedback and voting for your freeform proposal, you can then decide to raise a proposal to transfer assets accordingly. + +### Batch proposals + +For more complex sets of actions, you can use a batch proposal to submit several actions to be coordinated to happen as the result of a single vote. These can be spread across time, and can even be used to make temporary changes by including both the changes and a later reversal in the same batch. + +Examples of actions that can be coordinated together in a batch include: +- Funding multiple reward pools +- Paying for a service or action over a period of time +- Creating markets +- Changing fee rates +- Setting up or changing programmes like referral schemes, or activity streak or volume discount parameters + +:::note Read more +[Batch proposals](./lifecycle.md/#submitting-proposals-in-a-batch) +::: + From bef44cf4915700ba34ddb0fa8d2a8b89ba516d03 Mon Sep 17 00:00:00 2001 From: candida-d <62548908+candida-d@users.noreply.github.com> Date: Mon, 11 Mar 2024 15:55:00 +0000 Subject: [PATCH 08/14] add governance section --- docs/concepts/governance/market.md | 2 +- docs/concepts/governance/treasury.md | 15 +- .../version-v0.74/concepts/governance.md | 360 ------------------ .../concepts/governance/_category_.json | 5 + .../concepts/governance/asset.md | 85 +++++ .../concepts/governance/index.md | 33 ++ .../concepts/governance/lifecycle.md | 136 +++++++ .../concepts/governance/market.md | 121 ++++++ .../concepts/governance/network-parameter.md | 33 ++ .../concepts/governance/treasury.md | 93 +++++ 10 files changed, 515 insertions(+), 368 deletions(-) delete mode 100644 versioned_docs/version-v0.74/concepts/governance.md create mode 100644 versioned_docs/version-v0.74/concepts/governance/_category_.json create mode 100644 versioned_docs/version-v0.74/concepts/governance/asset.md create mode 100644 versioned_docs/version-v0.74/concepts/governance/index.md create mode 100644 versioned_docs/version-v0.74/concepts/governance/lifecycle.md create mode 100644 versioned_docs/version-v0.74/concepts/governance/market.md create mode 100644 versioned_docs/version-v0.74/concepts/governance/network-parameter.md create mode 100644 versioned_docs/version-v0.74/concepts/governance/treasury.md diff --git a/docs/concepts/governance/market.md b/docs/concepts/governance/market.md index 5e26a1e0a..2d454f337 100644 --- a/docs/concepts/governance/market.md +++ b/docs/concepts/governance/market.md @@ -38,7 +38,7 @@ Required fields include: Optional fields include: * Metadata so that people can easily interpret the market's details - while this is optional, it's highly recommended that you include metadata for the market * Price monitoring parameters, including the triggers covering the horizon, probability and auction extension time. If left blank these parameters will default to the values set in the network parameters -* Tick size, to set the minimal change in a price. If not set, it will default to 1 (or 10^{-market decimal places}) +* Tick size, to set the minimal change in a price. If not set, it will default to 1 (which is 10^{-market decimal places}) :::note Read more * [New market proposal tutorial](../../tutorials/proposals/new-market-proposal.md) diff --git a/docs/concepts/governance/treasury.md b/docs/concepts/governance/treasury.md index 4b2193c11..70d6c70b6 100644 --- a/docs/concepts/governance/treasury.md +++ b/docs/concepts/governance/treasury.md @@ -11,7 +11,10 @@ The network treasury holds assets that can be used by the community to fund init Treasury assets can be used to fund trading rewards, team competitions, grants, Vega protocol software and/or product development, teams building on Vega, or other opportunities. -Anyone with VEGA tokens can vote on or raise proposals to use treasury assets. +Anyone with enough VEGA tokens can vote and raise proposals to use treasury assets based on discussions in the community. + +* To vote a proposal, you usually need at least 1 VEGA, but the amount may vary per proposal type. Check the [block explorer](https://explorer.fairground.wtf/network-parameters) for each `minVoterBalance`. +* How many VEGA you need to submit a proposal depends on the proposal type. Check the [block explorer](https://explorer.fairground.wtf/network-parameters) for each `minProposerBalance`. ## Treasury basics The network treasury can hold VEGA tokens and other assets, which can be used by the community via on-chain governance to grow and support the development of the Vega software and network. @@ -24,7 +27,7 @@ Vega asset ID: `d1984e3d365faa05bcafbe41f50f90e3663ee7c0da22bb1e24b164e9532691b2 See more details on the [block explorer ↗](https://explorer.vega.xyz/assets/d1984e3d365faa05bcafbe41f50f90e3663ee7c0da22bb1e24b164e9532691b2). ### Treasury value -You can see how much is in the network treasury, along with recent transactions using the on-chain treasury page on [Block Explorer ↗](https://explorer.vega.xyz/treasury). +You can see how much is in the network treasury, along with recent transactions using the on-chain treasury page on the [block explorer ↗](https://explorer.vega.xyz/treasury). You can also see the balance programmatically with the `list accounts API`. For example, using the [REST endpoint](../../api/rest/data-v2/trading-data-service-list-accounts.api.mdx): * Filter by: @@ -49,7 +52,7 @@ Read more about how these work in the [teams and games](../trading-on-vega/disco ## How to allocate the treasury -### Using governance to spend assets +### Use governance to spend assets Assets can only be spend from the on-chain treasury by governance, when a **[proposal to transfer assets](../assets/transfers.md#governance-initiated-transfers)** is enacted. @@ -61,12 +64,10 @@ Include a description of what you're intending to do with the treasury funds in See the [tutorial](../../tutorials/proposals/asset-transfer-proposal.md) for a template and description of each field. - -### Freeform proposals - +### Suggest ideas with freeform proposals Another option is to submit a [freeform proposal](../../tutorials/proposals/freeform-proposal.md) to suggest a non-binding idea to the community and gauge their sentiment. This would be a good option for grants or other initiatives, especially where opinions may be split on what to do. -Raise a freeform proposal with your plan. Include clear details about what you think the money should be spent on, and if there's an organisation or provider you'd like to suggest working with, details about who they are and why they -- and the initiative -- are a good choice. You could even raise a few freeform proposals to help decide which of several competing ideas to take through to a final proposal. +Raise a freeform proposal with your plan. Include clear details about what you think the money should be spent on, and if there's an organisation or provider you'd like to suggest working with, details about who they are and why they -- and the initiative -- are a good choice. You could even raise two or three freeform proposals to help decide which of several competing ideas to take through to a final proposal. Based on feedback and voting for your freeform proposal, you can then decide to raise a proposal to transfer assets accordingly. diff --git a/versioned_docs/version-v0.74/concepts/governance.md b/versioned_docs/version-v0.74/concepts/governance.md deleted file mode 100644 index 15773256a..000000000 --- a/versioned_docs/version-v0.74/concepts/governance.md +++ /dev/null @@ -1,360 +0,0 @@ ---- -sidebar_position: 4 -title: Governance -vega_network: MAINNET -hide_title: false -description: Governance allows for on-chain decision making by tokenholders. ---- -import NetworkParameter from '@site/src/components/NetworkParameter'; - -Governance allows the Vega network to arrive at on-chain decisions, where tokenholders can create proposals that other tokenholders can vote to approve or reject. - -Vega supports on-chain proposals for creating markets and assets, changing network parameters, markets and assets, and transferring assets between some network-managed accounts. Vega also supports freeform proposals for community suggestions that will not be enacted on-chain. - -Taking part in governance by voting, or by proposing additions/changes with community support, is a way for tokenholders and community members to contribute to improve the network, and to add value for other network participants. - -## Voting on proposals -Proposals only get enacted if they get enough votes from VEGA tokenholders. There's no limit to how many active proposals they can vote on. - -To vote, your tokens must be associated with a Vega public key. It's not necessary to have those tokens nominated to validators, but the tokens must be associated to the Vega key used for voting. - -You can vote on a proposal as soon as it passes validation and is active, and it can be voted on until the proposal's closing date/time. - -* How many tokens are associated with your voting key determines how much weight the vote has. For market parameter change proposals, the liquidity providers' market share is also taken into account. -* Each Vega public key with a non-zero token balance gets one vote, and the key votes with the full weight of all the tokens associated to that key. You'll need to have tokens when the vote is submitted *and* when votes are counted, otherwise your vote is disregarded. -* Tokens used for voting are not locked or transferred: they can be used to nominate validators and to vote on other active proposals. -* While the voting period is open, you can change your vote, but only the most recent vote will count at the proposal's close. - -## How a proposal's outcome is calculated -* The network compares the weight of all valid votes cast as a percentage of the total weight that could vote, to the minimum participation requirement - `participation_rate = SUM (weightings of ALL valid votes cast) / max total weighting possible` -* The network compares the weight of all 'for' votes, as a percentage of the weight of all votes cast, to the required majority - `for_rate = SUM (weightings of votes cast for) / SUM (weightings of all votes cast)` -* If the minimum for both is reached, the proposal is enacted. If at least one is not reached, the proposal fails. - -### Proposal outcome: Update market -For proposals to update a market, there are extra requirements. The market's liquidity providers can vote with their equity-like share without requiring tokenholder participation. However, if tokenholders vote and participation and majority requirements for this vote are met, then the tokenholders' votes can overrule the liquidity providers' votes. - -The network will also calculate: -* The LP participation rate, which is the sum of the equity-like share of all LPs who cast a vote - `LP participation rate = SUM (equity-like share of all LPs who cast a vote)` -* The rate of 'for' votes cast by liquidity providers, calculated as the sum of all who voted 'for', divided by the LP participation rate - `LP for rate = SUM (all who voted for) / LP participation rate` - -The proposal will pass if one of the two scenarios occur: -1. The tokenholder vote meets or exceeds the minimum set by , and the votes in favour are greater than the amount set by . In this case the market's liquidity providers were overridden by governance token holders. -2. The governance tokenholder vote does not reach participation threshold, but the liquidity providers' votes do, and there are enough votes in favour. The participation rate must be greater than/equal to , and the liquidity providers' participation rate must be greater than/equal to , and the liquidity providers' votes in favour is greater than/equal to - -### Proposal outcome: Successor market -For proposals adding a new successor market, the outcome of the proposal can change even after it's been approved. - -If a parent market is still in its proposed state, its successor market cannot be enacted, even if it passes the vote. - -Two proposals that name the same parent can be submitted and pass a governance vote. Whichever market clears its [opening auction](./trading-on-vega/trading-modes.md#auction-type-opening) first gets the share of the insurance pool, and the liquidity providers' equity-like share is moved to that market. The second market will then be [rejected](./trading-on-vega/market-lifecycle.md#market-status-rejected). - -:::tip Try it out -**[Vega governance dApp ↗](https://governance.vega.xyz)**: Vote on active proposals. -::: - -## Lifecycle of a governance proposal -You need community support if you want to change something about the network, whether that's to add a new market, change a network parameter, or transfer pooled assets. It's worth considering what your proposed change contributes to the network, and if it would get enough votes from fellow tokenholders. - -You'll have a better chance of positively contributing to the network if you confirm there is support off-chain before submitting a proposal. - -### 1. Sense checking proposal idea (off-chain) -Before submitting a proposal, share an outline of your proposed action informally in a new topic on the [community forum ↗](https://community.vega.xyz/c/governance/25/) Governance Proposals section, with a "sense-check" tag. You can find out if there is enough interest in your proposal. - -Proposals can be submitted for creating a new market, amending an existing market, changing network parameters, adding an external asset to Vega, transferring out of asset pools. You can also suggest changes that won't impact network behaviour with a freeform proposal. - -### 2. Formalising proposal (off-chain) -Once the proposal details are refined, share the detailed proposal in the same topic you created for your sense check, and change the tag to "formalise". - -Including as much detail as possible gives other community members the opportunity to fully understand your proposal. Include the rationale for the proposal (and IPFS hash for more details), the specifics of the proposed addition/change, and the data (JSON or similar) that would be submitted on-chain. Invite debate and discussion to amend the proposal until it reaches a final state, ready to submit. - -When formalising the proposal, it is worth ensuring that any fields that are dependent on a range set by network parameters are correctly defined. See the network parameters and their values on the [Vega block explorer ↗](https://explorer.vega.xyz/network-parameters). - -### 3. Submitting proposal and telling the community (on-chain and off-chain) -You can submit a governance proposal to the network using the command line, a script, or the [governance dApp ↗](https://governance.vega.xyz/proposals/propose/raw). - -Your Vega key must have enough VEGA associated to submit a proposal. For a 'market parameter change' proposal, you'll also need enough equity-like share in the market from your liquidity commitment. This is defined in the network parameter . - -Proposals are first checked by the wallet, then verified by the nodes before entering into the voting period you set. A proposal must have all of the relevant information, in the correct format, and in some cases within the accepted range - otherwise it will be rejected immediately. - -A proposal cannot be changed once it's submitted to the network. - -After it's submitted and accepted, rally the community to vote on the proposal by announcing it on the [forum ↗](https://community.vega.xyz/), [Discord ↗](https://vega.xyz/discord), and through your own networks to vote on the proposal. - -:::tip Try it out -**[Proposals guides](../tutorials/proposals/index.md)**: How to build and then submit a proposal using the command line. -::: - -#### Validating a proposal -* The governance proposal is checked and then accepted by the wallet as a transaction. -* The validator nodes then check and validate the proposal. This is when the proposal data that defines the minimum duration, minimum time to enactment, minimum participation rate, and required majority are evaluated against the network's requirements, defined by [network parameters ↗](https://explorer.vega.xyz/network-parameters), which are different depending the type of proposal. -* If not specified on the proposal, the required participation rate and majority for success are defined and copied to the proposal. You can find them under the [network parameters ↗](https://explorer.vega.xyz/network-parameters), and they are specific to each proposal type. -* If the above conditions are not met, the proposal will be rejected and will not be available for a vote. **You'll need to fix and re-submit the proposal.** - -### 4. Voting (on-chain) -VEGA tokenholders - including those who submitted a proposal - can vote for or against any active proposals, with the full weight of the tokens associated with each public key. - -Read more about [voting](#voting-on-proposals). - -### 5. Enacting changes (on-chain) -If a proposal receives enough token weight in favour within the enactment period, the change/addition is accepted (except for a freeform proposal), and will be enacted on the enactment date defined in the proposal. - -Note the enactment date must be at least the minimum enactment period for the proposal type/subtype (specified by a network parameter for each proposal type) after voting closes. See the network parameters and their values on the [Vega block explorer ↗](https://explorer.vega.xyz/network-parameters). - -## Thresholds set by network parameters -Certain governance parameters need to be within a defined range, but offer some flexibility. - -When a submitted governance proposal is validated, the values chosen will be checked to ensure they fit within the thresholds, which themselves are defined by network parameters. - -Each type of governance proposal can have different thresholds, though they fit into broader categories. Those categories include: - -* `minProposerBalance`: Minimum amount of VEGA that a proposer needs to have associated with their Vega key to have the proposal accepted for a tokenholder vote -* `minClose`: Minimum amount of time before a proposal can be closed for voting -* `maxClose`: Maximum amount of time a proposal can be open for voting -* `minEnactment`: Minimum time allowed between vote closing on a proposal and the proposal's change being enacted on the network -* `maxEnactment`: Maximum time allowed between vote closing on a proposal and the proposal's change being enacted on the network -* `requiredParticipation`: Minimum number of tokens that must vote for a proposal to pass -* `requiredMajority`: Minimum majority that a proposal's 'yes' votes must reach for it to be enacted - -As these thresholds are network parameters, their values can be changed through governance. - -:::tip Query for data -**[Block explorer ↗](https://explorer.vega.xyz)**: See the current network parameter values (in some cases, different per network). - -**[REST](../api/rest/state/core-state-service-list-network-parameters.api.mdx)** The API provides the network parameters and their values. -::: - -### Example -Consider a network parameter that specifies the proportion of fees that goes to validators (). Each of the following thresholds would need to be met: - -* -* -* -* -* -* -* - -## Submitting proposals in a batch -You can submit governance proposals individually, or batch up the proposed changes into one proposal. - -The only thing that can't be proposed in a batch is adding a new asset - that needs to be a proposal on its own. - -When a batch proposal goes up for the vote, each proposed change within the batch needs to pass based on its own voting requirements. For example, if the batch includes a market change, the equity-like share voting rules apply to that specific change. - -Every proposed change in the batch needs to pass its voting requirements, or the whole batch fails. - -The batch proposal only has one rationale field, as well as one closing timestamp, for the whole set of proposals, so the description should describe why each change is being proposed. Each enactment timestamp needs to work with the single closing timestamp chosen for the batch. - -## Asset governance -Assets need to be proposed and pass a governance vote before they can be used on the Vega network. - -The protocol currently supports adding ERC-20 assets. Those ERC-20 assets that are successfully validated and pass a governance vote are can be enabled via the Vega bridge. In practice, that means that assets on Vega are deposited from and withdrawn to Ethereum. - -After a new asset vote passes, the change has to be submitted to the asset bridge on Ethereum. Until it has been submitted, no one can start depositing that asset. - -Certain asset details can also be changed through a governance proposal. While the [contract-level details](./assets/asset-framework.md#contract-level-details) are immutable, the [protocol-level details](./assets/asset-framework.md#protocol-level-details) can be changed. - -:::note Learn more -See the tutorials to: -* [Propose a new asset](../tutorials/proposals/new-asset-proposal.md) -* [Propose an update to an asset](../tutorials/proposals/update-asset-proposal.md) -::: - -### ERC-20 asset validation -When adding an ERC-20 asset to the bridge, the key details are compared to the smart contract on Ethereum. - -Specifically: -* The contract must be an ERC-20 asset -* The name and symbol must match the contract -* There cannot be multiple assets on a Vega network for the same ERC-20 asset - -### Transferring assets -For assets that are held in certain accounts - those with pooled assets, the community determines if the assets should be moved, and how they should be used. Generally speaking, those accounts have accumulated assets from settled markets, market protection movements, or are entirely funded by community members that transfer assets into them. - -These proposals give community members a chance to determine what they think the assets should be spent on, whether that's to fund [trading or validator rewards](./trading-on-vega/discounts-rewards.md#trading-rewards), to move money from [insurance pools](./assets/accounts.md#insurance-pool-accounts) into [network treasury accounts](./assets/accounts.md#network-treasury-accounts), or for other purposes. - -Transferring assets from network-managed account types can only be initiated by on-chain governance proposals. - -The transfers from those asset pools can be one-off or recurring. A recurring transfer that's initiated by governance can only be cancelled when a governance proposal to cancel it is submitted and passes the governance vote. - -To see a full table of which types of transfers can only be initiated through governance, see the [transfers page](./assets/transfers.md#governance-initiated-transfers). - -:::info Read more -* [Transfers](./assets/transfers.md) -* [Tutorial: Propose transferring assets](../tutorials/proposals/asset-transfer-proposal.md) -::: - -### Propose an asset transfer -Tokenholders can propose asset transfers from certain accounts, which then need to be voted on by other tokenholders. Not all transfers need to be proposed by governance. - -The proposer will need to have at least , associated with the public key you're using to propose the market, and staked to a validator. Note, this amount is set through the network parameter . - -If the proposal gets a majority of tokenholder support, then it will be enacted. The required majority is defined by the network parameter . It would also need to pass the required participation threshold: . - -To propose assets be transferred, you'll need to provide the details required for the transfer to be successful. While some of the fields are free-text, others are constrained by a range set through network parameters, to ensure that the values provided are fit for purpose. - -Proposal fields include: -* Source account type: The type of account that the assets are to be transferred from, such as the network treasury -* Source: The actual account ID. For network treasury, leave it blank. -* Asset: Asset to transfer -* Transfer type, which can be 'all or nothing' or 'best effort' - * All or nothing: Transfers the specified amount, or nothing - * Best effort: Transfers the specified amount or the max allowable amount if it's less than the specified amount -* Amount: Maximum amount to transfer; can be used to add an upper limit the fractional amount described below -* Fraction of balance: Maximum fraction of the source account's balance to transfer, submitted as a decimal (i.e. 0.1 = 10% of the balance) -* Destination type: Type of account to transfer to, such as reward pool, individual party, market insurance pool -* Destination: Specific account to transfer to, using an ID or public key. For network treasury, leave it blank. -* If the proposal is for a one-off transfer, it can optionally define a time, based on Vega time, for delivery. If there is no delivery time, it will execute immediately -* If the proposal is for a recurring transfer, it must include a start epoch. It can optionally include an end epoch for the last transfer - -#### Calculating amount to be transferred -The final amount transferred is determined based on the inputs into the proposal as well as the values of the relevant network parameters: -* specifies the maximum amount that can be transferred from a source account in a proposal -* specifies the maximum fraction of the balance that can be transferred from a source account. - -The final amount is calculated with the following formula: - -``` - transfer_amount = min( - proposal.fraction_of_balance * source.balance, - proposal.amount, - governance.transfer.max.amount, - governance.transfer.max.fraction * source.balance ) -``` - -## Market governance -Markets are proposed and voted into existence by Vega tokenholders. The parameters for a market all need to be defined in the proposal. - -Some market parameters can also be changed. They can only be proposed by a liquidity provider with enough equity-like share in the market, and need to be voted for by a sufficient number of tokenholders and/or liquidity providers. - -When creating a market governance proposal, whether it is for a new futures market, a new perpetual futures market, or to change parameters for an existing market, it's recommended that you sense check the proposal and share the final details with the tokenholder community before proposing, so that you can garner support and make any necessary amends. - -Read more: -* [Vega community forum ↗](https://community.vega.xyz): Share your draft proposals for community discussion. -* [New perpetual futures market proposal ↗](../tutorials/proposals/new-perpetuals-market.md): Guide to submitting a proposal for a new market -* [New futures market proposal ↗](../tutorials/proposals/new-market-proposal.md): Guide to submitting a proposal for a new market -* [New successor market proposal ↗](../tutorials/proposals/new-successor-market-proposal.md): Guide to submitting a proposal for a new successor market -* [Update market proposal ↗](../tutorials/proposals/update-market-proposal.md): Guide to submitting a proposal to change a market using the command line - -### Propose a new market -Tokenholders can propose new markets, which then need to be voted on by other tokenholders. The proposer will need to have at least , associated with the public key you're using to propose the market, and staked to a validator. Note, this amount is set through the network parameter . - -If the market proposal gets a majority of tokenholder support, then it will be enacted. The required majority is defined by the network parameter . - -To propose a market, you'll need to provide the details required for the market to begin trading right away. While some of the fields are free-text, others are constrained by a range set through network parameters, to ensure that the values provided are fit for purpose. - -Required fields include: -* Instrument details, including a human-readable name, an understandable shortcode for the market, the type of product -* Risk model parameters -* Product specifics including the settlement asset and quote name -* Decimal places for the market and positions. (Note: A market cannot specify more decimal places than its settlement asset supports) -* Oracle details, including the oracle's public key, specifications for settlement price, and data filters -* Liquidity parameters, including the target stake -* Method for setting liquidity fees, such as constant, marginal cost or stake-weighted average - -Optional fields include: -* Metadata so that people can easily interpret the market's details - while this is optional, it's highly recommended that you include metadata for the market -* Price monitoring parameters, including the triggers covering the horizon, probability and auction extension time. If left blank these parameters will default to the values set in the network parameters - -:::note Read more -* [New market proposal tutorial](../tutorials/proposals/new-market-proposal.md) -* [Data sources](./trading-on-vega/data-sources.md) -* [Price monitoring parameters](./trading-on-vega/market-protections.md#price-monitoring) -::: - -### Risk models and parameters -When proposing a market, the market proposer will need to choose the risk parameters associated with the risk model that's appropriate for the instrument. The acceptable amount of volatility on a market is driven by its risk model. The risk model is essential for calculating margins on the market. - -The [log-normal risk model](#log-normal-risk-model) is the only one currently supported. While the model is pre-defined, you'll need to choose the individual parameters. - -You should choose parameters that ensure the risk model adequately represents the dynamics of the underlying instrument, and that the resulting margins strike the right balance between prudence and capital efficiency. - -Below are the risk parameters, the accepted values for each parameter and suggested values for some. When suggested values are provided, these should be used as a reference point and to aid in deciding on what's appropriate for the market, not in place of rigorous analysis and calibration. - -Model-independent parameters used in margin calculation are: - -* `Risk aversion lambda` - probability confidence level used in [expected shortfall ↗](https://vega.xyz/papers/margins-and-credit-risk.pdf#page=7) calculation when obtaining the maintenance margin level. This enters the margin calculation as follows. First, the value at risk, defined by confidence lambda is calculated. This is the cash amount that one would need to add to the position to make the probability of the value of the position and cash going negative after time tau to be less than lambda. The margin is then the expected loss of the position given that it incurred a loss bigger than the value at risk. - * accepted values: **strictly greater than 0 and strictly smaller than 1** - * suggested value: `0.00001` -* `Tau` - projection horizon measured as a year fraction used in the expected shortfall calculation to obtain the maintenance margin: - * accepted values: **any strictly non-negative real number**, - * suggested value: `0.000114077116130504` - corresponds to one hour expressed as year fraction -* `Risk free rate` - annualised growth rate of the risk-free asset, it's used for discounting of future cash flows: - * accepted values: **any real number**, - * suggested value: `0`. - -The remaining, model specific parameters are covered below. - -:::note Go deeper -**[Margins and Credit Risk on Vega ↗](https://vega.xyz/papers/margins-and-credit-risk.pdf)**: Note, a position size of 1 is assumed throughout the research paper. -::: - -#### Log-normal risk model -The log-normal model assumes that the logarithm of the price increments are normally distributed. The main model parameter is: -* `Volatility (Sigma)` - annualised historical volatility of the underlying asset: - * accepted values: **any strictly non-negative real number**, - * suggested value: asset dependent, should be derived from the historical time-series of prices, and a typical value would be 0.8 = 80% - -Another parameter is -* `Mu` - annualised growth rate of the underlying asset: - * accepted values: **any real number**, - * suggested value: in almost all situations `0` is the value to use - -### Propose a successor market -A successor market is a market that will carry on after the original market, or parent, that it is based on has settled - though a parent and successor market can be active simultaneously. Proposing a new successor market that follows from an existing market offers liquidity providers the option to keep their [equity-like share](./liquidity/rewards-penalties.md#how-liquidity-fees-are-split) on the new market, even when the original market expires. Creating an entirely new market with no parent doesn't offer the same benefit. - -Each market can have only one active successor. A successor market can also be a parent market. - -In terms of the proposal format, there are only two differences between a succesor market proposal and that for a regular market, and one field that ties the successor to the parent market. -* Parent market ID: Required to define the proposal as for a successor market -* Insurance pool percentage: Required percentage of the parent market's insurance pool, up to 100%, can be earmarked for transfer to the successor market. It is submitted as a number between and including 0 and 1, which represents the factor for the percentage. -* Settlement asset validation: The settlement asset needs to match that of the parent market - -For a successor market to be enacted, the parent market must be in one of the following states: proposed, pending, active, suspended or trading terminated. - -The parent market can be settled or cancelled when the successor market reaches enactment time, as long as the time it's been settled/cancelled is equal to or less than the parent market's settlement time plus the `market.liquidity.successorLaunchWindowLength` - determined by a network parameter. This parameter specifies for how long after a market has settled, the liquidity provider's equity-like share data are retained and the insurance pool is left undistributed to allow a successor to be defined. If the successor is proposed after that time, then it's rejected and any assets committed to the market are returned. - -### Propose updates to a market -Most details about a market can be changed through governance. Those includes risk models, monitoring triggers, and the settlement and termination (if applicable) data sources. - -However, there are a few that cannot be edited, and will be the same for the duration of the market's life. -* Name: Market name, which should be a short, descriptive and relevant name -* Settlement asset: Asset used for margin, liquidity, and to settle positions -* Decimal places/precision for: - * Market - Sets the smallest price increment on the book. A market cannot specify more decimal places than its settlement asset supports - * Position - Precision of the position size - -### Propose a change to a market's state -Markets can be suspended, resumed from being suspended, and terminated using governance proposals. - -Suspending a market puts the market into an auction-only state. A market can be suspended for an indefinite amount of time, and it may never come out of suspension. - -A suspended market can only open to normal trading again if a proposal to resume the market is proposed and enacted. - -Markets that are terminated are closed to trading forever. When a proposal to terminate a market is enacted, it ends all trading on the market, settles all positions, and closes the market completely. The termination proposal includes a final price that's used to settle all open positions. - -:::tip Try it out -[Tutorial: Propose a change to a market's state](../tutorials/proposals/market-state-proposal.md) -::: - -## Network parameter governance -There are certain parameters within Vega that influence the behaviour of the system and can be changed by on-chain governance. Vega tokenholders can define the optimal network configuration by creating and voting on network parameter proposals to change the values of existing network parameters. - -Network parameters can only be added and removed with Vega core software releases. - -:::note Go deeper -* [Concept: Network parameters](../concepts/vega-chain/network.md#parameters) -* [Network parameters: See full list on the block explorer ↗](https://explorer.vega.xyz/network-parameters) -* [Tutorial: Propose a network parameter change](../tutorials/proposals/network-parameter-proposal.md) -::: - -### Suggested ranges for parameters -Some network parameters have minimum/maximum boundaries to ensure they aren't supplied with nonsensical values. The table below contains those parameters, to be used as guidance when proposing changes to any of those parameters. - -| Parameter name | Minimum/Maximum | -|---------------------------------------------------|-----------------| -| `reward.staking.delegation.competitionLevel` | Minimum value 1 (inclusive), no maximum. | -| `governance.proposal.(TYPE).minEnact` | Must be greater than / equal to the corresponding `minClose`, proposal can't be enacted before voting on it has closed. | -| `governance.proposal.(TYPE).requiredMajority` | Minimum 0.0, maximum 1.0. Is multiplied by 100 to get percentage. | -| `governance.proposal.(TYPE).requiredParticipation`| Minimum 0.0, maximum 1.0. Is multiplied by 100 to get percentage. | -| `rewards.activityStreak.benefitTiers`: `reward_multiplier` | Minimum 1.0. | \ No newline at end of file diff --git a/versioned_docs/version-v0.74/concepts/governance/_category_.json b/versioned_docs/version-v0.74/concepts/governance/_category_.json new file mode 100644 index 000000000..46b2edfe0 --- /dev/null +++ b/versioned_docs/version-v0.74/concepts/governance/_category_.json @@ -0,0 +1,5 @@ +{ + "label": "Governance", + "collapsed": false, + "position": 3 +} \ No newline at end of file diff --git a/versioned_docs/version-v0.74/concepts/governance/asset.md b/versioned_docs/version-v0.74/concepts/governance/asset.md new file mode 100644 index 000000000..3a0877be1 --- /dev/null +++ b/versioned_docs/version-v0.74/concepts/governance/asset.md @@ -0,0 +1,85 @@ +--- +sidebar_position: 4 +title: Asset governance +vega_network: MAINNET +hide_title: false +description: Add assets or move network-held funds. +--- +import NetworkParameter from '@site/src/components/NetworkParameter'; + +## Asset governance +Assets need to be proposed and pass a governance vote before they can be used on the Vega network. + +The protocol currently supports adding ERC-20 assets. Those ERC-20 assets that are successfully validated and pass a governance vote are can be enabled via the Vega bridge. In practice, that means that assets on Vega are deposited from and withdrawn to Ethereum. + +After a new asset vote passes, the change has to be submitted to the asset bridge on Ethereum. Until it has been submitted, no one can start depositing that asset. + +Certain asset details can also be changed through a governance proposal. While the [contract-level details](../assets/asset-framework.md#contract-level-details) are immutable, the [protocol-level details](../assets/asset-framework.md#protocol-level-details) can be changed. + +:::note Learn more +See the tutorials to: +* [Propose a new asset](../../tutorials/proposals/new-asset-proposal.md) +* [Propose an update to an asset](../../tutorials/proposals/update-asset-proposal.md) +::: + +### ERC-20 asset validation +When adding an ERC-20 asset to the bridge, the key details are compared to the smart contract on Ethereum. + +Specifically: +* The contract must be an ERC-20 asset +* The name and symbol must match the contract +* There cannot be multiple assets on a Vega network for the same ERC-20 asset + +### Transferring assets +For assets that are held in certain accounts - those with pooled assets, the community determines if the assets should be moved, and how they should be used. Generally speaking, those accounts have accumulated assets from settled markets, market protection movements, or are entirely funded by community members that transfer assets into them. + +These proposals give community members a chance to determine what they think the assets should be spent on, whether that's to fund [trading or validator rewards](../trading-on-vega/discounts-rewards.md#trading-rewards), to move money from [insurance pools](../assets/accounts.md#insurance-pool-accounts) into [network treasury accounts](../assets/accounts.md#network-treasury-accounts), or for other purposes. + +Transferring assets from network-managed account types can only be initiated by on-chain governance proposals. + +The transfers from those asset pools can be one-off or recurring. A recurring transfer that's initiated by governance can only be cancelled when a governance proposal to cancel it is submitted and passes the governance vote. + +To see a full table of which types of transfers can only be initiated through governance, see the [transfers page](../assets/transfers.md#governance-initiated-transfers). + +:::info Read more +* [Transfers](../assets/transfers.md) +* [Tutorial: Propose transferring assets](../../tutorials/proposals/asset-transfer-proposal.md) +::: + +### Propose an asset transfer +Tokenholders can propose asset transfers from certain accounts, which then need to be voted on by other tokenholders. Not all transfers need to be proposed by governance. + +The proposer will need to have at least , associated with the public key you're using to propose the market, and staked to a validator. Note, this amount is set through the network parameter . + +If the proposal gets a majority of tokenholder support, then it will be enacted. The required majority is defined by the network parameter . It would also need to pass the required participation threshold: . + +To propose assets be transferred, you'll need to provide the details required for the transfer to be successful. While some of the fields are free-text, others are constrained by a range set through network parameters, to ensure that the values provided are fit for purpose. + +Proposal fields include: +* Source account type: The type of account that the assets are to be transferred from, such as the network treasury +* Source: The actual account ID. For network treasury, leave it blank. +* Asset: Asset to transfer +* Transfer type, which can be 'all or nothing' or 'best effort' + * All or nothing: Transfers the specified amount, or nothing + * Best effort: Transfers the specified amount or the max allowable amount if it's less than the specified amount +* Amount: Maximum amount to transfer; can be used to add an upper limit the fractional amount described below +* Fraction of balance: Maximum fraction of the source account's balance to transfer, submitted as a decimal (i.e. 0.1 = 10% of the balance) +* Destination type: Type of account to transfer to, such as reward pool, individual party, market insurance pool +* Destination: Specific account to transfer to, using an ID or public key. For network treasury, leave it blank. +* If the proposal is for a one-off transfer, it can optionally define a time, based on Vega time, for delivery. If there is no delivery time, it will execute immediately +* If the proposal is for a recurring transfer, it must include a start epoch. It can optionally include an end epoch for the last transfer + +#### Calculating amount to be transferred +The final amount transferred is determined based on the inputs into the proposal as well as the values of the relevant network parameters: +* specifies the maximum amount that can be transferred from a source account in a proposal +* specifies the maximum fraction of the balance that can be transferred from a source account. + +The final amount is calculated with the following formula: + +``` + transfer_amount = min( + proposal.fraction_of_balance * source.balance, + proposal.amount, + governance.transfer.max.amount, + governance.transfer.max.fraction * source.balance ) +``` diff --git a/versioned_docs/version-v0.74/concepts/governance/index.md b/versioned_docs/version-v0.74/concepts/governance/index.md new file mode 100644 index 000000000..f597d88e4 --- /dev/null +++ b/versioned_docs/version-v0.74/concepts/governance/index.md @@ -0,0 +1,33 @@ +--- +sidebar_position: 1 +title: Governance +vega_network: MAINNET +hide_title: false +description: Governance allows tokenholders to make on-chain decision. +--- +import NetworkParameter from '@site/src/components/NetworkParameter'; +import DocCardList from '@theme/DocCardList'; +import {useCurrentSidebarCategory} from '@docusaurus/theme-common'; + +## Overview +Governance allows the Vega network to arrive at on-chain decisions, where tokenholders can create proposals that other tokenholders can vote to approve or reject. Contribute to the network by voting or submitting proposals. + +Proposals are enacted if they get enough votes from VEGA holders. There's no limit to how many active proposals you can vote on. + +Vega supports on-chain proposals for governing: +* **Markets**: Creating new markets and changing parameters for existing ones +* **Assets** - Adding new assets and changing parameters for existing ones +* **Transferring network assets** - Moving network-held assets to different accounts or keys +* **Network parameters** - Changing the values of existing parameters to change network and market behaviour +* **Freeform** - Exploring community sentiment for actions that may or may not be enacted on-chain + +:::tip Try it out +**[Vega governance dApp ↗](https://governance.vega.xyz)**: Read through and vote on active proposals. +::: + +:::note Looking for proposal templates? +**[Tutorials: Governance proposals](../../tutorials/proposals/index.md)**: See the full range of proposal templates and descriptions of the fields. +::: + +## Governance topics + \ No newline at end of file diff --git a/versioned_docs/version-v0.74/concepts/governance/lifecycle.md b/versioned_docs/version-v0.74/concepts/governance/lifecycle.md new file mode 100644 index 000000000..94f8eba8e --- /dev/null +++ b/versioned_docs/version-v0.74/concepts/governance/lifecycle.md @@ -0,0 +1,136 @@ +--- +sidebar_position: 2 +title: Taking part +vega_network: MAINNET +hide_title: false +description: Understanding the governance lifecycle. +--- +import NetworkParameter from '@site/src/components/NetworkParameter'; + +## Voting +Proposals are enacted if they get enough votes from VEGA holders. There's no limit to how many active proposals you can vote on. + +Your tokens must be associated with a Vega public key. The tokens need to be associated to your Vega key, but they don't need to be nominated to validators. To check if your tokens are associated, connect to your Vega wallet on the [governance dApp ↗](https://governance.vega.xyz). + +You can vote as soon as the proposal passes validation and is active, and it can be voted on until the proposal's closing date/time. + +* How many tokens are associated with your voting key determines how much weight the vote has. For market parameter change proposals, the liquidity providers' market share is also taken into account. +* Each Vega public key with a non-zero token balance gets one vote, and the key votes with the full weight of all the tokens associated to that key. You'll need to have tokens when the vote is submitted *and* when votes are counted, otherwise your vote is disregarded. +* Tokens used for voting are not locked or transferred: they can be used to nominate validators and to vote on other active proposals. +* While the voting period is open, you can change your vote, but only the most recent vote will count at the proposal's close. + +## How a proposal's outcome is calculated +* The network compares the weight of all valid votes cast as a percentage of the total weight that could vote, to the minimum participation requirement - `participation_rate = SUM (weightings of ALL valid votes cast) / max total weighting possible` +* The network compares the weight of all 'for' votes, as a percentage of the weight of all votes cast, to the required majority - `for_rate = SUM (weightings of votes cast for) / SUM (weightings of all votes cast)` +* If the minimum for both is reached, the proposal is enacted. If at least one is not reached, the proposal fails. + +### Proposal outcome: Update market +For proposals to update a market, there are extra requirements. The market's liquidity providers can vote with their equity-like share without requiring tokenholder participation. However, if tokenholders vote and participation and majority requirements for this vote are met, then the tokenholders' votes can overrule the liquidity providers' votes. + +The network will also calculate: +* The LP participation rate, which is the sum of the equity-like share of all LPs who cast a vote - `LP participation rate = SUM (equity-like share of all LPs who cast a vote)` +* The rate of 'for' votes cast by liquidity providers, calculated as the sum of all who voted 'for', divided by the LP participation rate - `LP for rate = SUM (all who voted for) / LP participation rate` + +The proposal will pass if one of the two scenarios occur: +1. The tokenholder vote meets or exceeds the minimum set by , and the votes in favour are greater than the amount set by . In this case the market's liquidity providers were overridden by governance token holders. +2. The governance tokenholder vote does not reach participation threshold, but the liquidity providers' votes do, and there are enough votes in favour. The participation rate must be greater than/equal to , and the liquidity providers' participation rate must be greater than/equal to , and the liquidity providers' votes in favour is greater than/equal to + +### Proposal outcome: Successor market +For proposals adding a new successor market, the outcome of the proposal can change even after it's been approved. + +If a parent market is still in its proposed state, its successor market cannot be enacted, even if it passes the vote. + +Two proposals that name the same parent can be submitted and pass a governance vote. Whichever market clears its [opening auction](../trading-on-vega/trading-modes.md#auction-type-opening) first gets the share of the insurance pool, and the liquidity providers' equity-like share is moved to that market. The second market will then be [rejected](../trading-on-vega/market-lifecycle.md#market-status-rejected). + +## Lifecycle of a governance proposal +You need community support if you want to change something about the network, whether that's to add a new market, change a network parameter, or transfer pooled assets. It's worth considering what your proposed change contributes to the network, and if it would get enough votes from fellow tokenholders. + +You'll have a better chance of positively contributing to the network if you confirm there is support off-chain before submitting a proposal. + +### 1. Sense checking proposal idea (off-chain) +Before submitting a proposal, share an outline of your proposed action informally in a new topic on the [community forum ↗](https://community.vega.xyz/c/governance/25/) Governance Proposals section, with a "sense-check" tag. You can find out if there is enough interest in your proposal. + +Proposals can be submitted for creating a new market, amending an existing market, changing network parameters, adding an external asset to Vega, transferring out of asset pools. You can also suggest changes that won't impact network behaviour with a freeform proposal. + +### 2. Formalising proposal (off-chain) +Once the proposal details are refined, share the detailed proposal in the same topic you created for your sense check, and change the tag to "formalise". + +Including as much detail as possible gives other community members the opportunity to fully understand your proposal. Include the rationale for the proposal (and IPFS hash for more details), the specifics of the proposed addition/change, and the data (JSON or similar) that would be submitted on-chain. Invite debate and discussion to amend the proposal until it reaches a final state, ready to submit. + +When formalising the proposal, it is worth ensuring that any fields that are dependent on a range set by network parameters are correctly defined. See the network parameters and their values on the [Vega block explorer ↗](https://explorer.vega.xyz/network-parameters). + +### 3. Submitting proposal and telling the community (on-chain and off-chain) +You can submit a governance proposal to the network using the command line, a script, or the [governance dApp ↗](https://governance.vega.xyz/proposals/propose/raw). + +Your Vega key must have enough VEGA associated to submit a proposal. For a 'market parameter change' proposal, you'll also need enough equity-like share in the market from your liquidity commitment. This is defined in the network parameter . + +Proposals are first checked by the wallet, then verified by the nodes before entering into the voting period you set. A proposal must have all of the relevant information, in the correct format, and in some cases within the accepted range - otherwise it will be rejected immediately. + +A proposal cannot be changed once it's submitted to the network. + +After it's submitted and accepted, rally the community to vote on the proposal by announcing it on the [forum ↗](https://community.vega.xyz/), [Discord ↗](https://vega.xyz/discord), and through your own networks to vote on the proposal. + +:::tip Try it out +**[Proposals guides](../../tutorials/proposals/index.md)**: How to build and then submit a proposal using the command line. +::: + +#### Validating a proposal +* The governance proposal is checked and then accepted by the wallet as a transaction. +* The validator nodes then check and validate the proposal. This is when the proposal data that defines the minimum duration, minimum time to enactment, minimum participation rate, and required majority are evaluated against the network's requirements, defined by [network parameters ↗](https://explorer.vega.xyz/network-parameters), which are different depending the type of proposal. +* If not specified on the proposal, the required participation rate and majority for success are defined and copied to the proposal. You can find them under the [network parameters ↗](https://explorer.vega.xyz/network-parameters), and they are specific to each proposal type. +* If the above conditions are not met, the proposal will be rejected and will not be available for a vote. **You'll need to fix and re-submit the proposal.** + +### 4. Voting (on-chain) +VEGA tokenholders - including those who submitted a proposal - can vote for or against any active proposals, with the full weight of the tokens associated with each public key. + +Read more about [voting](#voting-on-proposals). + +### 5. Enacting changes (on-chain) +If a proposal receives enough token weight in favour within the enactment period, the change/addition is accepted (except for a freeform proposal), and will be enacted on the enactment date defined in the proposal. + +Note the enactment date must be at least the minimum enactment period for the proposal type/subtype (specified by a network parameter for each proposal type) after voting closes. See the network parameters and their values on the [block explorer ↗](https://explorer.vega.xyz/network-parameters). + +## Submitting proposals in a batch +You can submit governance proposals individually, or batch up the proposed changes into one proposal. + +The only thing that can't be proposed in a batch is adding a new asset - that needs to be a proposal on its own. + +When a batch proposal goes up for the vote, each proposed change within the batch needs to pass based on its own voting requirements. For example, if the batch includes a market change, the equity-like share voting rules apply to that specific change. + +Every proposed change in the batch needs to pass its voting requirements, or the whole batch fails. + +The batch proposal only has one rationale field, as well as one closing timestamp, for the whole set of proposals, so the description should describe why each change is being proposed. Each enactment timestamp needs to work with the single closing timestamp chosen for the batch. + +## Thresholds set by network parameters +Certain governance parameters need to be within a defined range, but offer some flexibility. + +When a submitted governance proposal is validated, the values chosen will be checked to ensure they fit within the thresholds, which themselves are defined by network parameters. + +Each type of governance proposal can have different thresholds, though they fit into broader categories. Those categories include: + +* `minProposerBalance`: Minimum amount of VEGA that a proposer needs to have associated with their Vega key to have the proposal accepted for a tokenholder vote +* `minClose`: Minimum amount of time before a proposal can be closed for voting +* `maxClose`: Maximum amount of time a proposal can be open for voting +* `minEnactment`: Minimum time allowed between vote closing on a proposal and the proposal's change being enacted on the network +* `maxEnactment`: Maximum time allowed between vote closing on a proposal and the proposal's change being enacted on the network +* `requiredParticipation`: Minimum number of tokens that must vote for a proposal to pass +* `requiredMajority`: Minimum majority that a proposal's 'yes' votes must reach for it to be enacted + +As these thresholds are network parameters, their values can be changed through governance. + +:::tip Query for data +**[Block explorer ↗](https://explorer.vega.xyz)**: See the current network parameter values (in some cases, different per network). + +**[REST](../../api/rest/state/core-state-service-list-network-parameters.api.mdx)** The API provides the network parameters and their values. +::: + +### Example +Consider a network parameter that specifies the proportion of fees that goes to validators (). Each of the following thresholds would need to be met: + +* +* +* +* +* +* +* diff --git a/versioned_docs/version-v0.74/concepts/governance/market.md b/versioned_docs/version-v0.74/concepts/governance/market.md new file mode 100644 index 000000000..01b8b84a0 --- /dev/null +++ b/versioned_docs/version-v0.74/concepts/governance/market.md @@ -0,0 +1,121 @@ +--- +sidebar_position: 5 +title: Market governance +vega_network: MAINNET +hide_title: false +description: Add new markets or change existing ones. +--- +import NetworkParameter from '@site/src/components/NetworkParameter'; + +Markets are proposed and voted into existence by Vega tokenholders. The parameters for a market all need to be defined in the proposal. + +Some market parameters can also be changed. They can only be proposed by a liquidity provider with enough equity-like share in the market, and need to be voted for by a sufficient number of tokenholders and/or liquidity providers. + +When creating a market governance proposal, whether it is for a new dated futures market, a new perpetual futures market, or to change parameters for an existing market, it's recommended that you sense check the proposal and share the final details with the tokenholder community before proposing, so that you can garner support and make any necessary amends. + +Read more: +* [Vega community forum ↗](https://community.vega.xyz): Share your draft proposals for community discussion. +* [New perpetual futures market proposal ↗](../../tutorials/proposals/new-perpetuals-market.md): Guide to submitting a proposal for a new market +* [New futures market proposal ↗](../../tutorials/proposals/new-market-proposal.md): Guide to submitting a proposal for a new market +* [New successor market proposal ↗](../../tutorials/proposals/new-successor-market-proposal.md): Guide to submitting a proposal for a new successor market +* [Update market proposal ↗](../../tutorials/proposals/update-market-proposal.md): Guide to submitting a proposal to change a market using the command line + +### Propose a new market +Tokenholders can propose new markets, which then need to be voted on by other tokenholders. The proposer will need to have at least , associated with the public key you're using to propose the market, and staked to a validator. Note, this amount is set through the network parameter . + +If the market proposal gets a majority of tokenholder support, then it will be enacted. The required majority is defined by the network parameter . + +To propose a market, you'll need to provide the details required for the market to begin trading right away. While some of the fields are free-text, others are constrained by a range set through network parameters, to ensure that the values provided are fit for purpose. + +Required fields include: +* Instrument details, including a human-readable name, an understandable shortcode for the market, the type of product +* Risk model parameters +* Product specifics including the settlement asset and quote name +* Decimal places for the market and positions. (Note: A market cannot specify more decimal places than its settlement asset supports) +* Oracle details, including the oracle's public key, specifications for settlement price, and data filters +* Liquidity parameters, including the target stake + +Optional fields include: +* Metadata so that people can easily interpret the market's details - while this is optional, it's highly recommended that you include metadata for the market +* Price monitoring parameters, including the triggers covering the horizon, probability and auction extension time. If left blank these parameters will default to the values set in the network parameters + +:::note Read more +* [New market proposal tutorial](../../tutorials/proposals/new-market-proposal.md) +* [Data sources](../trading-on-vega/data-sources.md) +* [Price monitoring parameters](../trading-on-vega/market-protections.md#price-monitoring) +::: + +### Risk models and parameters +When proposing a market, the market proposer will need to choose the risk parameters associated with the risk model that's appropriate for the instrument. The acceptable amount of volatility on a market is driven by its risk model. The risk model is essential for calculating margins on the market. + +The [log-normal risk model](#log-normal-risk-model) is the only one currently supported. While the model is pre-defined, you'll need to choose the individual parameters. + +You should choose parameters that ensure the risk model adequately represents the dynamics of the underlying instrument, and that the resulting margins strike the right balance between prudence and capital efficiency. + +Below are the risk parameters, the accepted values for each parameter and suggested values for some. When suggested values are provided, these should be used as a reference point and to aid in deciding on what's appropriate for the market, not in place of rigorous analysis and calibration. + +Model-independent parameters used in margin calculation are: + +* `Risk aversion lambda` - probability confidence level used in [expected shortfall ↗](https://vega.xyz/papers/margins-and-credit-risk.pdf#page=7) calculation when obtaining the maintenance margin level. This enters the margin calculation as follows. First, the value at risk, defined by confidence lambda is calculated. This is the cash amount that one would need to add to the position to make the probability of the value of the position and cash going negative after time tau to be less than lambda. The margin is then the expected loss of the position given that it incurred a loss bigger than the value at risk. + * accepted values: **strictly greater than 0 and strictly smaller than 1** + * suggested value: `0.00001` +* `Tau` - projection horizon measured as a year fraction used in the expected shortfall calculation to obtain the maintenance margin: + * accepted values: **any strictly non-negative real number**, + * suggested value: `0.000114077116130504` - corresponds to one hour expressed as year fraction +* `Risk free rate` - annualised growth rate of the risk-free asset, it's used for discounting of future cash flows: + * accepted values: **any real number**, + * suggested value: `0`. + +The remaining, model specific parameters are covered below. + +:::note Go deeper +**[Margins and Credit Risk on Vega ↗](https://vega.xyz/papers/margins-and-credit-risk.pdf)**: Note, a position size of 1 is assumed throughout the research paper. +::: + +#### Log-normal risk model +The log-normal model assumes that the logarithm of the price increments are normally distributed. The main model parameter is: +* `Volatility (Sigma)` - annualised historical volatility of the underlying asset: + * accepted values: **any strictly non-negative real number**, + * suggested value: asset dependent, should be derived from the historical time-series of prices, and a typical value would be 0.8 = 80% + +Another parameter is +* `Mu` - annualised growth rate of the underlying asset: + * accepted values: **any real number**, + * suggested value: in almost all situations `0` is the value to use + +### Propose a successor market +A successor market is a market that will carry on after the original market, or parent, that it is based on has settled - though a parent and successor market can be active simultaneously. Proposing a new successor market that follows from an existing market offers liquidity providers the option to keep their [equity-like share](../liquidity/rewards-penalties.md#how-liquidity-fees-are-split) on the new market, even when the original market expires. Creating an entirely new market with no parent doesn't offer the same benefit. + +Each market can have only one active successor. A successor market can also be a parent market. + +In terms of the proposal format, there are only two differences between a succesor market proposal and that for a regular market, and one field that ties the successor to the parent market. +* Parent market ID: Required to define the proposal as for a successor market +* Insurance pool percentage: Required percentage of the parent market's insurance pool, up to 100%, can be earmarked for transfer to the successor market. It is submitted as a number between and including 0 and 1, which represents the factor for the percentage. +* Settlement asset validation: The settlement asset needs to match that of the parent market + +For a successor market to be enacted, the parent market must be in one of the following states: proposed, pending, active, suspended or trading terminated. + +The parent market can be settled or cancelled when the successor market reaches enactment time, as long as the time it's been settled/cancelled is equal to or less than the parent market's settlement time plus the `market.liquidity.successorLaunchWindowLength` - determined by a network parameter. This parameter specifies for how long after a market has settled, the liquidity provider's equity-like share data are retained and the insurance pool is left undistributed to allow a successor to be defined. If the successor is proposed after that time, then it's rejected and any assets committed to the market are returned. + +### Propose updates to a market +Most details about a market can be changed through governance. Those includes risk models, monitoring triggers, and the settlement and termination (if applicable) data sources. + +However, there are a few that cannot be edited, and will be the same for the duration of the market's life. +* Name: Market name, which should be a short, descriptive and relevant name +* Settlement asset: Asset used for margin, liquidity, and to settle positions +* Decimal places/precision for: + * Market - Sets the smallest price increment on the book. A market cannot specify more decimal places than its settlement asset supports + * Position - Precision of the position size + +### Propose a change to a market's state +Markets can be suspended, resumed from being suspended, and terminated using governance proposals. + +Suspending a market puts the market into an auction-only state. A market can be suspended for an indefinite amount of time, and it may never come out of suspension. + +A suspended market can only open to normal trading again if a proposal to resume the market is proposed and enacted. + +Markets that are terminated are closed to trading forever. When a proposal to terminate a market is enacted, it ends all trading on the market, settles all positions, and closes the market completely. The termination proposal includes a final price that's used to settle all open positions. + +:::tip Try it out +[Tutorial: Propose a change to a market's state](../../tutorials/proposals/market-state-proposal.md) +::: diff --git a/versioned_docs/version-v0.74/concepts/governance/network-parameter.md b/versioned_docs/version-v0.74/concepts/governance/network-parameter.md new file mode 100644 index 000000000..023c9ffc5 --- /dev/null +++ b/versioned_docs/version-v0.74/concepts/governance/network-parameter.md @@ -0,0 +1,33 @@ +--- +sidebar_position: 6 +title: Network parameter +vega_network: MAINNET +hide_title: false +description: Change network configuration parameters. +--- +import NetworkParameter from '@site/src/components/NetworkParameter'; + +There are certain parameters within Vega that influence the behaviour of the system and can be changed by on-chain governance. + +Vega tokenholders can define the optimal network configuration by creating and voting on network parameter proposals to change the values of existing network parameters. + +Network parameters can only be added and removed with Vega core software releases. + +:::note Go deeper +* [Concept: Network parameters](../vega-chain/network.md#parameters) +* [Network parameters: See full list on the block explorer ↗](https://explorer.vega.xyz/network-parameters) +* [Tutorial: Propose a network parameter change](../../tutorials/proposals/network-parameter-proposal.md) +::: + +### Suggested ranges for parameters +Some network parameters have minimum/maximum boundaries to ensure they aren't supplied with nonsensical values. The table below contains those parameters, to be used as guidance when proposing changes to any of those parameters. + +| Parameter name | Minimum/Maximum | +|---------------------------------------------------|-----------------| +| `reward.staking.delegation.competitionLevel` | Minimum value 1 (inclusive), no maximum. | +| `governance.proposal.(TYPE).minEnact` | Must be greater than / equal to the corresponding `minClose`, proposal can't be enacted before voting on it has closed. | +| `governance.proposal.(TYPE).requiredMajority` | Minimum 0.0, maximum 1.0. Is multiplied by 100 to get percentage. | +| `governance.proposal.(TYPE).requiredParticipation`| Minimum 0.0, maximum 1.0. Is multiplied by 100 to get percentage. | +| `rewards.activityStreak.benefitTiers`: `reward_multiplier` | Minimum 1.0. | +import DocCardList from '@theme/DocCardList'; +import {useCurrentSidebarCategory} from '@docusaurus/theme-common'; diff --git a/versioned_docs/version-v0.74/concepts/governance/treasury.md b/versioned_docs/version-v0.74/concepts/governance/treasury.md new file mode 100644 index 000000000..6a65186fe --- /dev/null +++ b/versioned_docs/version-v0.74/concepts/governance/treasury.md @@ -0,0 +1,93 @@ +--- +sidebar_position: 3 +title: Vega treasury +vega_network: TESTNET +hide_title: false +description: How you can allocate treasury funds. +--- +import NetworkParameter from '@site/src/components/NetworkParameter'; + +The network treasury holds assets that can be used by the community to fund initiatives. You can take part in decision-making around building and growing Vega. + +Treasury assets can be used to fund trading rewards, team competitions, grants, Vega protocol software and/or product development, teams building on Vega, or other opportunities. + +Anyone with enough VEGA tokens can vote and raise proposals to use treasury assets based on discussions in the community. + +* To vote a proposal, you usually need at least 1 VEGA, but the amount may vary per proposal type. Check the [block explorer](https://explorer.fairground.wtf/network-parameters) for each `minVoterBalance`. +* How many VEGA you need to submit a proposal depends on the proposal type. Check the [block explorer](https://explorer.fairground.wtf/network-parameters) for each `minProposerBalance`. + +## Treasury basics +The network treasury can hold VEGA tokens and other assets, which can be used by the community via on-chain governance to grow and support the development of the Vega software and network. + +### VEGA token details +VEGA token contract address (Ethereum mainnet): `0xcB84d72e61e383767C4DFEb2d8ff7f4FB89abc6e` ([view on Etherscan ↗](https://etherscan.io/token/0xcB84d72e61e383767C4DFEb2d8ff7f4FB89abc6e)) + +Vega asset ID: `d1984e3d365faa05bcafbe41f50f90e3663ee7c0da22bb1e24b164e9532691b2` + +See more details on the [block explorer ↗](https://explorer.vega.xyz/assets/d1984e3d365faa05bcafbe41f50f90e3663ee7c0da22bb1e24b164e9532691b2). + +### Treasury value +You can see how much is in the network treasury, along with recent transactions using the on-chain treasury page on the [block explorer ↗](https://explorer.vega.xyz/treasury). + +You can also see the balance programmatically with the `list accounts API`. For example, using the [REST endpoint](../../api/rest/data-v2/trading-data-service-list-accounts.api.mdx): +* Filter by: + * Asset ID for VEGA: `d1984e3d365faa05bcafbe41f50f90e3663ee7c0da22bb1e24b164e9532691b2`, and + * Account type: `ACCOUNT_TYPE_NETWORK_TREASURY` +* Don't forget to account for the token's 18 decimal places + +## What the treasury can fund + +**Rewards**: Rewards can incentivise trading, liquidity provision, and proposing successful markets. +- Recognise *active traders* by targeting those who pay maker fees, or have large or profitable positions +- Incentivise *liquidity provision* by funding rewards for participants who receive liquidity and/or maker fees +- Support market success by rewarding proposers who create markets that attract high trading volumes + +Read in detail on the [rewards page](../trading-on-vega/discounts-rewards.md#trading-rewards) about the trading rewards you can choose from. + +**Team games**: Rewards that are targeted to a team entity scope let teams compete against each other for a share of the winnings. You can propose a team game for any type of trading reward. + +Read more about how these work in the [teams and games](../trading-on-vega/discounts-rewards.md#teams-and-games) section. + +**Grants and other initiatives**: A transfer can send to any Vega key, even if it's an individual and not a reward account. You can use a freeform proposal to gauge the community's interest and hone the plan before setting up the proposal for transferring assets. + +## How to allocate the treasury + +### Use governance to spend assets + +Assets can only be spend from the on-chain treasury by governance, when a **[proposal to transfer assets](../assets/transfers.md#governance-initiated-transfers)** is enacted. + +The most direct way to propose spending the assets is by submitting one of these proposals. In practice, community members almost always discuss proposals on the **[Vega community forums ↗](https://community.vega.xyz/) before submitting**, in order to incorporate community feedback into the proposal and ensure there's broad support before going through the effort of putting it on-chain. + +The proposal includes details about the specific account(s) or key(s) that you want to send assets to, as well as when to send, and how often. The transfer can be set to happen once or repeatedly. + +Include a description of what you're intending to do with the treasury funds in your proposal's rationale so that the community can understand why and engage with your proposal. + +See the [tutorial](../../tutorials/proposals/asset-transfer-proposal.md) for a template and description of each field. + +### Suggest ideas with freeform proposals + +Another option is to submit a [freeform proposal](../../tutorials/proposals/freeform-proposal.md) to suggest a non-binding idea to the community and gauge their sentiment. This would be a good option for grants or other initiatives, especially where opinions may be split on what to do. + +Raise a freeform proposal with your plan. Include clear details about what you think the money should be spent on, and if there's an organisation or provider you'd like to suggest working with, details about who they are and why they -- and the initiative -- are a good choice. You could even raise two or three freeform proposals to help decide which of several competing ideas to take through to a final proposal. + +Based on feedback and voting for your freeform proposal, you can then decide to raise a proposal to transfer assets accordingly. + +### Batch proposals + +For more complex sets of actions, you can use a batch proposal to submit several actions to be coordinated to happen as the result of a single vote. These can be spread across time, and can even be used to make temporary changes by including both the changes and a later reversal in the same batch. + +Examples of actions that can be coordinated together in a batch include: +- Funding multiple reward pools +- Paying for a service or action over a period of time +- Creating markets +- Changing fee rates +- Setting up or changing programmes like referral schemes, or activity streak or volume discount parameters + +:::note Read more +[Batch proposals](./lifecycle.md/#submitting-proposals-in-a-batch) +::: + + + + + From 73279674ac8ff703f3295ab6b57610b96e642e09 Mon Sep 17 00:00:00 2001 From: candida-d <62548908+candida-d@users.noreply.github.com> Date: Mon, 11 Mar 2024 17:11:24 +0000 Subject: [PATCH 09/14] governance section --- versioned_docs/version-v0.74/api/building-blocks.md | 4 ++-- .../version-v0.74/concepts/assets/asset-framework.md | 4 ++-- .../concepts/trading-on-vega/discounts-rewards.md | 6 +++--- .../version-v0.74/concepts/trading-on-vega/margin.md | 3 +-- .../concepts/trading-on-vega/trading-modes.md | 4 ++-- .../version-v0.74/concepts/vega-chain/_category_.json | 4 ++-- .../concepts/vega-chain/proof-of-stake.md | 11 +++++++++-- versioned_docs/version-v0.74/intro/token-economics.md | 2 +- .../version-v0.74/topics/_topic-governance.mdx | 2 +- .../tutorials/proposals/asset-transfer-proposal.md | 4 ++-- .../tutorials/proposals/freeform-proposal.md | 4 ++-- .../version-v0.74/tutorials/proposals/index.md | 4 ++-- .../tutorials/proposals/market-state-proposal.md | 4 ++-- .../tutorials/proposals/network-parameter-proposal.md | 4 ++-- .../tutorials/proposals/new-asset-proposal.md | 4 ++-- .../tutorials/proposals/new-market-proposal.md | 10 +++++----- .../tutorials/proposals/new-perpetuals-market.md | 6 +++--- .../proposals/new-successor-market-proposal.md | 6 +++--- .../tutorials/proposals/referral-program-proposal.md | 4 ++-- .../tutorials/proposals/update-asset-bridge.md | 2 +- .../tutorials/proposals/update-asset-proposal.md | 4 ++-- .../tutorials/proposals/update-market-proposal.md | 4 ++-- .../proposals/volume-discount-program-proposal.md | 4 ++-- .../version-v0.74/tutorials/using-data-sources.md | 2 +- 24 files changed, 56 insertions(+), 50 deletions(-) diff --git a/versioned_docs/version-v0.74/api/building-blocks.md b/versioned_docs/version-v0.74/api/building-blocks.md index 665a6697c..d926fe53a 100644 --- a/versioned_docs/version-v0.74/api/building-blocks.md +++ b/versioned_docs/version-v0.74/api/building-blocks.md @@ -77,7 +77,7 @@ Governance proposals used to add new assets and markets, as well as to suggest c | Get detailed information about a specific governance proposal using its ID | [Proposal](../api/rest/data-v2/trading-data-service-get-governance-data.api.mdx) | `GET /api/v2/governance` ||| |How to submit proposals using command line | [Submitting proposals](../tutorials/proposals/index.md) | | -| Understanding the concepts: Governance | [Vega governance](../concepts/governance.md) | +| Understanding the concepts: Governance | [Vega governance](../concepts/governance/index.md) | ### Governance token VEGA token are used for taking part in network, market, asset and freeform governance, and to secure the network by nominating validators that run the network. @@ -87,4 +87,4 @@ VEGA token are used for taking part in network, market, asset and freeform gover | See a list of votes | [List votes](../api/rest/data-v2/trading-data-service-list-votes.api.mdx) | `GET /api/v2/votes` | ||| | How to nominate validators using the smart contracts | [Stake tokens](../tutorials/assets-tokens/staking-tokens.md) | -| Understand the concepts: Governance | [Vega governance](../concepts/governance.md) | +| Understanding the concepts: Governance | [Vega governance](../concepts/governance/index.md) | \ No newline at end of file diff --git a/versioned_docs/version-v0.74/concepts/assets/asset-framework.md b/versioned_docs/version-v0.74/concepts/assets/asset-framework.md index f23f610b8..80189a49e 100644 --- a/versioned_docs/version-v0.74/concepts/assets/asset-framework.md +++ b/versioned_docs/version-v0.74/concepts/assets/asset-framework.md @@ -6,7 +6,7 @@ hide_title: false description: Vega supports ERC-20 assets that are added through governance. --- -Vega currently supports exclusively using ERC-20 tokens for markets on Vega. Those assets must be [proposed through governance](../governance.md#asset-governance) and pass the voting threshold, and be enabled on the Vega bridge. ERC-20 tokens originate on the Ethereum chain, not the Vega chain. Inter-chain asset interactions between Vega and Ethereum are facilitated through the Ethereum bridges. +Vega currently supports exclusively using ERC-20 tokens for markets on Vega. Those assets must be [proposed through governance](../governance/asset.md) and pass the voting threshold, and be enabled on the Vega bridge. ERC-20 tokens originate on the Ethereum chain, not the Vega chain. Inter-chain asset interactions between Vega and Ethereum are facilitated through the Ethereum bridges. The assets on Vega are used for margining and settling positions, paying fees, and supplying liquidity on markets. Assets can also be transferred between keys and accounts. @@ -57,7 +57,7 @@ ERC-20 is a ubiquitous smart contract interface that allows users to mint, issue Assets need to be proposed and pass a governance vote before they can be used on the Vega network. After a new asset vote passes, the change has to be submitted to the asset bridge on Ethereum. Until it has been submitted, no one can start depositing that asset. :::note Read more -* [Concept: Asset governance](../governance.md#asset-governance) +* [Concept: Asset governance](../governance/asset.md) * [Tutorial: Proposing an asset](../../tutorials/proposals/new-asset-proposal.md) * [Tutorial: Proposing a change to an asset](../../tutorials/proposals/update-asset-proposal.md) ::: diff --git a/versioned_docs/version-v0.74/concepts/trading-on-vega/discounts-rewards.md b/versioned_docs/version-v0.74/concepts/trading-on-vega/discounts-rewards.md index a03846553..98045a3e8 100644 --- a/versioned_docs/version-v0.74/concepts/trading-on-vega/discounts-rewards.md +++ b/versioned_docs/version-v0.74/concepts/trading-on-vega/discounts-rewards.md @@ -105,7 +105,7 @@ Leaving your reward earnings in your vested account will increase your share of You can see the current reward hoarder bonus requirements and benefits on the [block explorer ↗](https://explorer.vega.xyz/network-parameters#rewards.vesting.benefitTiers), or querying the [network parameters API](../../api/rest/data-v2/trading-data-service-list-network-parameters.api.mdx) for the `rewards.vesting.benefitTiers` network parameter. -These tiers are set through network parameters, and thus can be changed through [governance](../governance.md#network-parameter-governance). +These tiers are set through network parameters, and thus can be changed through [governance](../governance/network-parameter.md). :::tip Try it out [Tutorial: Propose a network parameter change](../../tutorials/proposals/network-parameter-proposal.md) @@ -124,7 +124,7 @@ If you go inactive for more than , as well as the settlement asset's quantum to assess the market's size. diff --git a/versioned_docs/version-v0.74/concepts/trading-on-vega/margin.md b/versioned_docs/version-v0.74/concepts/trading-on-vega/margin.md index b1f139fd4..60a49ffef 100644 --- a/versioned_docs/version-v0.74/concepts/trading-on-vega/margin.md +++ b/versioned_docs/version-v0.74/concepts/trading-on-vega/margin.md @@ -127,8 +127,7 @@ If there is enough volume on the book, the slippage comes directly from the book :::note Read more [Concept: Closeouts](./market-protections.md#closeouts) -[Concept: Risk model parameters](../governance.md#risk-models-and-parameters) -::: +[Concept: Risk model parameters](../governance/market.md#risk-models-and-parameters)::: ### Margin level: Initial The *initial margin level* has two different functions, depending on which margin mode you're using. diff --git a/versioned_docs/version-v0.74/concepts/trading-on-vega/trading-modes.md b/versioned_docs/version-v0.74/concepts/trading-on-vega/trading-modes.md index e135a82bc..d45efdf21 100644 --- a/versioned_docs/version-v0.74/concepts/trading-on-vega/trading-modes.md +++ b/versioned_docs/version-v0.74/concepts/trading-on-vega/trading-modes.md @@ -50,7 +50,7 @@ Every continuous trading market opens with an auction. Their purpose is to calib While a market is in opening auction, liquidity commitments can be submitted to it. Those who start committing earlier will receive a greater [equity-like share](../liquidity/rewards-penalties.md#how-the-fee-is-derived) in the market, which influences the amount of fee revenue they receive. -In the case of a [successor market](../governance.md#propose-a-successor-market), any liquidity provider can submit liquidity commitments to it but those that had been providing liquidity to the parent market will have their equity-like share, and thus its benefits, carried over. +In the case of a [successor market](../governance/market.md#propose-a-successor-market), any liquidity provider can submit liquidity commitments to it but those that had been providing liquidity to the parent market will have their equity-like share, and thus its benefits, carried over. #### Entry into an opening auction A new market’s opening auction begins at the proposal’s closing date. @@ -60,7 +60,7 @@ A market’s opening auction ends at the market enactment time, unless an openin When a market leaves its opening auction, it will use the mid-price within the range of auction bids that would result in the highest trade volume for its normal trading mode. For example, if the volume maximising range is 98-102, the market would price all trades in the uncrossing at 100. The order book would then be uncrossed at that price and the trades follow the normal flow. -When a [successor market](../governance.md#propose-a-successor-market) leaves its opening auction, the insurance pool fraction (multiplied by the parent market's insurance pool balance) that was defined in its market proposal is transferred to the successor market's insurance pool. +When a [successor market](../governance/market.md#propose-a-successor-market) leaves its opening auction, the insurance pool fraction (multiplied by the parent market's insurance pool balance) that was defined in its market proposal is transferred to the successor market's insurance pool. ### Auction type: Price monitoring Sometimes low liquidity and/or a large quantity of order volume can cause a market's price to diverge from the true price. The Vega protocol is designed to assume that relatively small moves are 'real' and that larger moves might not be. The market's risk model and price monitoring settings are used to determine what the boundaries are between small, acceptable moves and large, unrealistic ones. diff --git a/versioned_docs/version-v0.74/concepts/vega-chain/_category_.json b/versioned_docs/version-v0.74/concepts/vega-chain/_category_.json index 83bb449a0..386160270 100644 --- a/versioned_docs/version-v0.74/concepts/vega-chain/_category_.json +++ b/versioned_docs/version-v0.74/concepts/vega-chain/_category_.json @@ -1,5 +1,5 @@ { "label": "Vega chain", - "collapsed": true, - "position": 3 + "collapsed": false, + "position": 5 } \ No newline at end of file diff --git a/versioned_docs/version-v0.74/concepts/vega-chain/proof-of-stake.md b/versioned_docs/version-v0.74/concepts/vega-chain/proof-of-stake.md index bda32298b..6f02d9f73 100644 --- a/versioned_docs/version-v0.74/concepts/vega-chain/proof-of-stake.md +++ b/versioned_docs/version-v0.74/concepts/vega-chain/proof-of-stake.md @@ -33,6 +33,13 @@ Vega is non-slashing -- there is no mechanism through which a tokenholder can lo ## VEGA token Vega uses the VEGA ERC20 token for governance, which includes nominating validators to run nodes, and creating and voting on governance proposals. +:::info VEGA token details +Asset ID: `d1984e3d365faa05bcafbe41f50f90e3663ee7c0da22bb1e24b164e9532691b2` +Contract address: `0xcB84d72e61e383767C4DFEb2d8ff7f4FB89abc6e` + +See more details on the [block explorer ↗](https://explorer.vega.xyz/assets/d1984e3d365faa05bcafbe41f50f90e3663ee7c0da22bb1e24b164e9532691b2). +::: + If a token is delegated, its governance voting rights stay with the tokenholder and are not transferred to any validators that the tokenholder nominates. A VEGA token (or fraction) can be either dissociated or associated with a Vega key: @@ -42,7 +49,7 @@ A VEGA token (or fraction) can be either dissociated or associated with a Vega k **All tokens can be used for staking and voting** on governance proposals. This includes tokens that are locked in the vesting contract. Tokens that are staked can be used to vote, and tokens used to vote can be staked. -Read more: [Governance of Vega](../governance.md) +Read more: [Governance of Vega](../governance/index.md) :::tip Associate tokens first A user's VEGA tokens must first be associated with a Vega key before they can be used for governance and nominating validators. @@ -68,7 +75,7 @@ Whether tokens are unlocked or locked, the bridge events let the Vega network kn All events (including the above, plus stake per validator and others) are only registered after a certain number of block confirmations, as defined by the network parameter . :::note Go deeper -**[Staking Bridge contracts](https://github.com/vegaprotocol/Staking_Bridge)** - on Vega's staking bridge GitHub repository. +**[Staking Bridge contracts ↗](https://github.com/vegaprotocol/Staking_Bridge)** - on Vega's staking bridge GitHub repository. ::: ## Staking on Vega diff --git a/versioned_docs/version-v0.74/intro/token-economics.md b/versioned_docs/version-v0.74/intro/token-economics.md index 92bc67a09..91ddf738c 100644 --- a/versioned_docs/version-v0.74/intro/token-economics.md +++ b/versioned_docs/version-v0.74/intro/token-economics.md @@ -26,4 +26,4 @@ Check active validators and their respective stakes and performances using the [ Once staked, VEGA tokens also allow holders to vote on governance proposals, along with proposing their own changes. These proposals range from changing network parameter values to proposing entirely new markets. -Active proposals can be found on the [governance dApp proposals page ↗](https://token.vega.xyz/proposals) whilst a more in-depth guide to the various governance options can be found on the [governance](../concepts/governance.md) concepts page. \ No newline at end of file +Active proposals can be found on the [governance dApp proposals page ↗](https://token.vega.xyz/proposals) whilst a more in-depth guide to the various governance options can be found on the [governance](../concepts/governance/index.md) concepts page. \ No newline at end of file diff --git a/versioned_docs/version-v0.74/topics/_topic-governance.mdx b/versioned_docs/version-v0.74/topics/_topic-governance.mdx index cb59c7a65..11d07fc87 100644 --- a/versioned_docs/version-v0.74/topics/_topic-governance.mdx +++ b/versioned_docs/version-v0.74/topics/_topic-governance.mdx @@ -5,7 +5,7 @@ This section is part of a series on the topic of *Governance*. Docs: -- [Introduction to governance](/concepts/governance.md) +- [Introduction to governance](/concepts/governance/index.md) - [Tutorials: Governance proposals](/tutorials/proposals/index.md) Tools: diff --git a/versioned_docs/version-v0.74/tutorials/proposals/asset-transfer-proposal.md b/versioned_docs/version-v0.74/tutorials/proposals/asset-transfer-proposal.md index cca8498d8..57a9a1f4b 100644 --- a/versioned_docs/version-v0.74/tutorials/proposals/asset-transfer-proposal.md +++ b/versioned_docs/version-v0.74/tutorials/proposals/asset-transfer-proposal.md @@ -25,7 +25,7 @@ This tutorial describes what you need to propose transferring assets from those You will need: * A connected [Vega wallet](../../tools/vega-wallet/index.md), with your wallet name and public key to hand * A minimum of whichever is larger, associated with that public key: () or () -* Familiarity with how [proposing an asset transfer](../../concepts/governance.md#propose-an-asset-transfer) works +* Familiarity with how [proposing an asset transfer](../../concepts/governance/asset.md#propose-an-asset-transfer) works You should also share your proposal idea in the [_Governance_ forum section ↗](https://community.vega.xyz/c/governance) before submitting it to the network. @@ -355,7 +355,7 @@ Building support is down to you. Share your proposal in the [_Governance_ sectio To vote, community members need, at a minimum, the larger of , or associated with their Vega key. -Your proposal will need [participation](../../concepts/governance.md#how-a-proposals-outcome-is-calculated) of and a majority of , so having community support is essential. +Your proposal will need [participation](../../concepts/governance/lifecycle.md#how-a-proposals-outcome-is-calculated) of and a majority of , so having community support is essential. Proposers who invite feedback, engage with comments, and make revisions to meet the needs of the community are more likely to be successful. diff --git a/versioned_docs/version-v0.74/tutorials/proposals/freeform-proposal.md b/versioned_docs/version-v0.74/tutorials/proposals/freeform-proposal.md index f7dcf2a37..85e34a4e3 100644 --- a/versioned_docs/version-v0.74/tutorials/proposals/freeform-proposal.md +++ b/versioned_docs/version-v0.74/tutorials/proposals/freeform-proposal.md @@ -32,7 +32,7 @@ At enactment time, no changes are effected on the system, but the record of how You will need: * A connected [Vega wallet](../../tools/vega-wallet/index.md), with your wallet name and public key to hand * A minimum of whichever is larger, associated with that public key: () or () -* Familiarity with [governance on Vega](../../concepts/governance.md) +* Familiarity with [governance on Vega](../../concepts/governance/index.md) You should also share your proposal idea in the [_Freeform Proposals_ forum section ↗](https://community.vega.xyz/c/governance/free-form-proposals/31) before submitting it to the network. @@ -73,6 +73,6 @@ Building support is down to you. Share your proposal in the [_Governance_ sectio To vote, community members need, at a minimum, the larger of or , associated to their Vega key. -Your proposal will need [participation](../../concepts/governance.md#how-the-outcome-is-calculated) of and a voting majority of , so having community support is essential. +Your proposal will need [participation](../../concepts/governance/lifecycle.md#how-the-outcome-is-calculated) of and a voting majority of , so having community support is essential. Proposers who invite feedback, engage with comments, and make revisions to meet the needs of the community are more likely to be successful. diff --git a/versioned_docs/version-v0.74/tutorials/proposals/index.md b/versioned_docs/version-v0.74/tutorials/proposals/index.md index f50e729a2..90377891d 100644 --- a/versioned_docs/version-v0.74/tutorials/proposals/index.md +++ b/versioned_docs/version-v0.74/tutorials/proposals/index.md @@ -25,7 +25,7 @@ You will typically need: - A connected [Vega wallet](../../tools/vega-wallet/index.md), with your wallet name and public key to hand - A minimum amount of Vega tokens associated with that public key -- Familiarity with [governance on Vega](../../concepts/governance.md) +* Familiarity with [governance on Vega](../../concepts/governance/index.md) ## Proposal types @@ -33,4 +33,4 @@ This section includes sample proposals that you can amend and submit via the com -Read more about the lifecycle of a governance proposal in [the Concepts section](../../concepts/governance.md). +Read more about the lifecycle of a governance proposal in [the Concepts section](../../concepts/governance/lifecycle.md). diff --git a/versioned_docs/version-v0.74/tutorials/proposals/market-state-proposal.md b/versioned_docs/version-v0.74/tutorials/proposals/market-state-proposal.md index e6645c1d9..04fec9335 100644 --- a/versioned_docs/version-v0.74/tutorials/proposals/market-state-proposal.md +++ b/versioned_docs/version-v0.74/tutorials/proposals/market-state-proposal.md @@ -28,7 +28,7 @@ Below, learn how to submit a governance proposal to: You will need: * A connected [Vega wallet](../../tools/vega-wallet/index.md), with your wallet name and public key to hand * A minimum of whichever is larger, associated with that public key: () or () -* Familiarity with [market governance](../../concepts/governance.md#market-governance) on Vega +* Familiarity with [market governance](../../concepts/governance/market.md) on Vega You should also share your proposal idea in the [_Governance_ forum section ↗](https://community.vega.xyz/c/governance) before submitting it to the network. @@ -408,7 +408,7 @@ Building support is down to you. Share your proposal in the [_Governance_ sectio To vote, community members need, at a minimum, the larger of or associated to their Vega key. -Your proposal will need [participation](../../concepts/governance.md#how-the-outcome-is-calculated) of , a majority of , as well as a percentage of liquidity provider votes of so having community support is essential. +Your proposal will need [participation](../../concepts/governance/lifecycle.md#how-the-outcome-is-calculated) of , a majority of , as well as a percentage of liquidity provider votes of so having community support is essential. Proposers who invite feedback, engage with comments, and make revisions to meet the needs of the community are more likely to be successful. diff --git a/versioned_docs/version-v0.74/tutorials/proposals/network-parameter-proposal.md b/versioned_docs/version-v0.74/tutorials/proposals/network-parameter-proposal.md index c93863b8b..76433c1d2 100644 --- a/versioned_docs/version-v0.74/tutorials/proposals/network-parameter-proposal.md +++ b/versioned_docs/version-v0.74/tutorials/proposals/network-parameter-proposal.md @@ -32,7 +32,7 @@ You should also share your proposal idea in the [_Governance_ forum section ↗] You will need: * A connected [Vega wallet](../../tools/vega-wallet/index.md), with your wallet name and public key to hand * A minimum of whichever is larger, associated with that public key: () or () -* Familiarity with [governance on Vega](../../concepts/governance.md) +* Familiarity with [governance on Vega](../../concepts/governance/network-parameter.md) ## Anatomy of a network parameter proposal Read on for the key inputs to a network parameter proposal. @@ -104,7 +104,7 @@ Building support is down to you. Share your proposal in the [_Governance_ sectio To vote, community members need, at a minimum, the larger of , or associated with their Vega key. -Your proposal will need [participation](../../concepts/governance.md#how-a-proposals-outcome-is-calculated) of and a majority of , so having community support is essential. +Your proposal will need [participation](../../concepts/governance/lifecycle.md#how-a-proposals-outcome-is-calculated) of and a majority of , so having community support is essential. Proposers who invite feedback, engage with comments, and make revisions to meet the needs of the community are more likely to be successful. diff --git a/versioned_docs/version-v0.74/tutorials/proposals/new-asset-proposal.md b/versioned_docs/version-v0.74/tutorials/proposals/new-asset-proposal.md index ed073f1e5..bad28df37 100644 --- a/versioned_docs/version-v0.74/tutorials/proposals/new-asset-proposal.md +++ b/versioned_docs/version-v0.74/tutorials/proposals/new-asset-proposal.md @@ -27,7 +27,7 @@ This page provides a tutorial for submitting a proposal for a new ERC-20 asset t You will need: * A connected [Vega wallet](../../tools/vega-wallet/index.md), with your wallet name and public key to hand * A minimum of whichever is larger, associated with that public key: () or () -* Familiarity with [governance on Vega](../../concepts/governance.md), particularly [assets at a protocol level](../../concepts/governance.md#asset-governance) +* Familiarity with [governance on Vega](../../concepts/governance/asset.md) After a new asset vote passes, the change has to be submitted to the asset bridge on Ethereum. Until it has been submitted, no one can start depositing that asset. See the [tutorial](./update-asset-bridge.md) for how to do that. @@ -102,7 +102,7 @@ Building support is down to you. Share your proposal in the [_Governance_ sectio To vote, community members need, at a minimum, the larger of or associated with their Vega key. -Your proposal will need [participation](../../concepts/governance.md#how-the-outcome-is-calculated) of and a majority of , so having community support is essential. +Your proposal will need [participation](../../concepts/governance/lifecycle.md#how-the-outcome-is-calculated) of and a majority of , so having community support is essential. Proposers who invite feedback, engage with comments, and make revisions to meet the needs of the community are more likely to be successful. diff --git a/versioned_docs/version-v0.74/tutorials/proposals/new-market-proposal.md b/versioned_docs/version-v0.74/tutorials/proposals/new-market-proposal.md index 9f3bcedfa..c37782d30 100644 --- a/versioned_docs/version-v0.74/tutorials/proposals/new-market-proposal.md +++ b/versioned_docs/version-v0.74/tutorials/proposals/new-market-proposal.md @@ -39,7 +39,7 @@ Looking to propose a perpetuals market? See the [perpetual futures tutorial](./n You will need: * A connected [Vega wallet](../../tools/vega-wallet/index.md), with your wallet name and public key to hand * A minimum of whichever is larger, associated with that public key: , () or () -* Familiarity with [market governance](../../concepts/governance.md#market-governance) on Vega +* Familiarity with [market governance](../../concepts/governance/market.md) on Vega You should also share your proposal idea in the [_Governance_ forum section ↗](https://community.vega.xyz/c/governance) before submitting it to the network. @@ -195,11 +195,11 @@ Price monitoring uses the following properties: You can use a maximum of 5 sets of price monitoring parameters for a market. ### Risk model -Choose the individual parameters for the [log-normal risk model](../../concepts/governance.md#log-normal-risk-model). You should ensure the risk model parameters represent the dynamics of the underlying instrument, and that the resulting margins strike the right balance between prudence and capital efficiency. +Choose the individual parameters for the [log-normal risk model](../../concepts/governance/market.md#log-normal-risk-model). You should ensure the risk model parameters represent the dynamics of the underlying instrument, and that the resulting margins strike the right balance between prudence and capital efficiency. While you cannot define exactly how much margin (or leverage) is possible, you can influence the acceptable levels of market volatility. -Read about the [risk models and parameters](../../concepts/governance.md#risk-models-and-parameters) before choosing your values. +Read about the [risk models and parameters](../../concepts/governance/market.md#risk-models-and-parameters) before choosing your values. The risk model uses the following properties: @@ -273,11 +273,11 @@ A vote can be submitted with a [transaction](../../api/grpc/vega/commands/v1/com To vote, community members need, at a minimum, the larger of , or associated with their Vega key. -Your proposal will need [participation](../../concepts/governance.md#how-a-proposals-outcome-is-calculated) of and a majority of , so having community support is essential. +Your proposal will need [participation](../../concepts/governance/lifecycle.md#how-a-proposals-outcome-is-calculated) of and a majority of , so having community support is essential. Proposers who invite feedback, engage with comments, and make revisions to meet the needs of the community are more likely to be successful. -Learn more about voting on the [governance concepts](../../concepts/governance.md#voting-on-proposals) page. +Learn more about voting on the [governance concepts](../../concepts/governance/lifecycle.md#voting-on-proposals) page. ## Enactment If successful, the proposal will be enacted at the time you specify in the `enactmentTimestamp` field, or as soon as the [opening auction](../../concepts/trading-on-vega/trading-modes.md#auction-type-opening) has successfully concluded, whichever is later. \ No newline at end of file diff --git a/versioned_docs/version-v0.74/tutorials/proposals/new-perpetuals-market.md b/versioned_docs/version-v0.74/tutorials/proposals/new-perpetuals-market.md index 32f47e6bf..297c97172 100644 --- a/versioned_docs/version-v0.74/tutorials/proposals/new-perpetuals-market.md +++ b/versioned_docs/version-v0.74/tutorials/proposals/new-perpetuals-market.md @@ -31,7 +31,7 @@ import TabItem from '@theme/TabItem'; You will need: * A connected [Vega wallet](../../tools/vega-wallet/index.md), with your wallet name and public key to hand * A minimum of whichever is larger, associated with that public key: () or () -* Familiarity with [governance](../../concepts/governance.md) on Vega +* Familiarity with [governance](../../concepts/governance/market.md) on Vega * Familiarity with using [Ethereum to provide data](../using-data-sources.md#ethereum-oracles) You should also share your proposal idea in the [_Governance_ forum section ↗](https://community.vega.xyz/c/governance) before submitting it to the network. @@ -193,11 +193,11 @@ Price monitoring uses the following properties: You can use a maximum of 5 sets of price monitoring parameters for a market. ### Risk model -Choose the individual parameters for the [log-normal risk model](../../concepts/governance.md#log-normal-risk-model). You should ensure the risk model parameters represent the dynamics of the underlying instrument, and that the resulting margins strike the right balance between prudence and capital efficiency. +Choose the individual parameters for the [log-normal risk model](../../concepts/governance/market.md#log-normal-risk-model). You should ensure the risk model parameters represent the dynamics of the underlying instrument, and that the resulting margins strike the right balance between prudence and capital efficiency. While you cannot define exactly how much margin (or leverage) is possible, you can influence the acceptable levels of market volatility. -Read about the [risk models and parameters](../../concepts/governance.md#risk-models-and-parameters) before choosing your values. +Read about the [risk models and parameters](../../concepts/governance/market.md#risk-models-and-parameters) before choosing your values. The risk model uses the following properties: diff --git a/versioned_docs/version-v0.74/tutorials/proposals/new-successor-market-proposal.md b/versioned_docs/version-v0.74/tutorials/proposals/new-successor-market-proposal.md index 91d5e7077..5b7c2f897 100644 --- a/versioned_docs/version-v0.74/tutorials/proposals/new-successor-market-proposal.md +++ b/versioned_docs/version-v0.74/tutorials/proposals/new-successor-market-proposal.md @@ -30,7 +30,7 @@ Propose a cash-settled futures market to succeed an existing market, taking alon You will need: * A connected [Vega wallet](../../tools/vega-wallet/index.md), with your wallet name and public key to hand * A minimum of whichever is larger, associated with that public key: () or () -* Familiarity with [successor market governance](../../concepts/governance.md#propose-a-successor-market) on Vega +* Familiarity with [successor market governance](../../concepts/governance/market.md#propose-a-successor-market) on Vega ## Anatomy of a new successor market proposal The new successor market proposal requires the same fields as a new market proposal, with the addition of two fields described below. @@ -82,9 +82,9 @@ Building support is down to you. Share your proposal in the [_Governance_ sectio To vote, community members need, at a minimum, the larger of or associated to their Vega key. -Your proposal will need [participation](../../concepts/governance.md#how-a-proposals-outcome-is-calculated) of and a majority of , so having community support is essential. +Your proposal will need [participation](../../concepts/governance/lifecycle.md#how-a-proposals-outcome-is-calculated) of and a majority of , so having community support is essential. Proposers who invite feedback, engage with comments, and make revisions to meet the needs of the community are more likely to be successful. ## Enactment -If successful, the proposal will be enacted at the time you specify in the `enactmentTimestamp` field, depending on the [status of other successor market proposals](../../concepts/governance.md#proposal-outcome-successor-market). \ No newline at end of file +If successful, the proposal will be enacted at the time you specify in the `enactmentTimestamp` field, depending on the [status of other successor market proposals](../../concepts/governance/lifecycle.md#proposal-outcome-successor-market). \ No newline at end of file diff --git a/versioned_docs/version-v0.74/tutorials/proposals/referral-program-proposal.md b/versioned_docs/version-v0.74/tutorials/proposals/referral-program-proposal.md index ac4efe60a..9f7239e4f 100644 --- a/versioned_docs/version-v0.74/tutorials/proposals/referral-program-proposal.md +++ b/versioned_docs/version-v0.74/tutorials/proposals/referral-program-proposal.md @@ -27,7 +27,7 @@ This page describes what you need to propose enabling or replacing the referral You will need: * A connected [Vega wallet](../../tools/vega-wallet/index.md), with your wallet name and public key to hand * A minimum of whichever is larger, associated with that public key: () or () -* Familiarity with [governance on Vega](../../concepts/governance.md) +* Familiarity with [governance on Vega](../../concepts/governance/index.md) ## Anatomy of a referral program proposal The fields below all need to be defined to enable the referral program or replace an existing one. @@ -227,7 +227,7 @@ Building support is down to you. Share your proposal in the [_Governance_ sectio To vote, community members need, at a minimum, the larger of or associated to their Vega key. -Your proposal will need [participation](../../concepts/governance.md#how-the-outcome-is-calculated) of and a majority of , so having community support is essential. +Your proposal will need [participation](../../concepts/governance/lifecycle.md#how-the-outcome-is-calculated) of and a majority of , so having community support is essential. Proposers who invite feedback, engage with comments, and make revisions to meet the needs of the community are more likely to be successful. diff --git a/versioned_docs/version-v0.74/tutorials/proposals/update-asset-bridge.md b/versioned_docs/version-v0.74/tutorials/proposals/update-asset-bridge.md index 4e2650714..fed880434 100644 --- a/versioned_docs/version-v0.74/tutorials/proposals/update-asset-bridge.md +++ b/versioned_docs/version-v0.74/tutorials/proposals/update-asset-bridge.md @@ -25,7 +25,7 @@ Vega validators automatically create a multisig bundle - a collection of signatu ## Requirements You will need: * An Ethereum wallet -* Familiarity with [asset governance](../../concepts/governance.md#asset-governance), as well as how the [asset bridge](../../concepts/assets/asset-framework.md#asset-bridges) works on Ethereum. +* Familiarity with [asset governance](../../concepts/governance/asset.md), as well as how the [asset bridge](../../concepts/assets/asset-framework.md#asset-bridges) works on Ethereum. As an alternative to making the transaction yourself, Etherscan provides a simple interface that can be used to submit updates to the bridge. You can access it by visiting the relevant contract page, under 'Contract' > 'Write contract'. diff --git a/versioned_docs/version-v0.74/tutorials/proposals/update-asset-proposal.md b/versioned_docs/version-v0.74/tutorials/proposals/update-asset-proposal.md index 8d9862a6c..941659820 100644 --- a/versioned_docs/version-v0.74/tutorials/proposals/update-asset-proposal.md +++ b/versioned_docs/version-v0.74/tutorials/proposals/update-asset-proposal.md @@ -34,7 +34,7 @@ The underlying contract, asset name and symbol cannot be changed. You will need: * A connected [Vega wallet](../../tools/vega-wallet/index.md), with your wallet name and public key to hand -* A minimum of whichever is larger, associated with that public key: () or ()- Familiarity with [governance on Vega](../../concepts/governance.md), particularly [assets at a protocol level](../../concepts/governance.md#asset-governance) +* A minimum of whichever is larger, associated with that public key: () or ()- Familiarity with [governance on Vega](../../concepts/governance/asset.md) After a new asset vote passes, the change has to be submitted to the asset bridge on Ethereum. See the [tutorial](./update-asset-bridge.md) for how to do that. @@ -89,7 +89,7 @@ Building support is down to you. Share your proposal in the [_Governance_ sectio To vote, community members need, at a minimum, the larger of or associated with their Vega key. -Your proposal will need [participation](../../concepts/governance.md#how-the-outcome-is-calculated) of and a majority of , so having community support is essential. +Your proposal will need [participation](../../concepts/governance/lifecycle.md#how-the-outcome-is-calculated) of and a majority of , so having community support is essential. Proposers who invite feedback, engage with comments, and make revisions to meet the needs of the community are more likely to be successful. diff --git a/versioned_docs/version-v0.74/tutorials/proposals/update-market-proposal.md b/versioned_docs/version-v0.74/tutorials/proposals/update-market-proposal.md index 1a0ecf384..e9618a438 100644 --- a/versioned_docs/version-v0.74/tutorials/proposals/update-market-proposal.md +++ b/versioned_docs/version-v0.74/tutorials/proposals/update-market-proposal.md @@ -30,7 +30,7 @@ You will need: * A connected [Vega wallet](../../tools/vega-wallet/index.md), with your wallet name and public key to hand * A minimum of whichever is larger, associated with that public key: () or () * A minimum equity-like share in the market of -* Familiarity with [market governance](../../concepts/governance.md#market-governance) on Vega +* Familiarity with [market governance](../../concepts/governance/market.md) on Vega ## Anatomy of an update market proposal @@ -101,7 +101,7 @@ Building support is down to you. Share your proposal in the [_Governance_ sectio To vote, community members need, at a minimum, the larger of or associated to their Vega key. -Your proposal will need [participation](../../concepts/governance.md#how-the-outcome-is-calculated) of and a majority of , so having community support is essential. +Your proposal will need [participation](../../concepts/governance/lifecycle.md#how-the-outcome-is-calculated) of and a majority of , so having community support is essential. Proposers who invite feedback, engage with comments, and make revisions to meet the needs of the community are more likely to be successful. diff --git a/versioned_docs/version-v0.74/tutorials/proposals/volume-discount-program-proposal.md b/versioned_docs/version-v0.74/tutorials/proposals/volume-discount-program-proposal.md index 8e95f7214..ff539f681 100644 --- a/versioned_docs/version-v0.74/tutorials/proposals/volume-discount-program-proposal.md +++ b/versioned_docs/version-v0.74/tutorials/proposals/volume-discount-program-proposal.md @@ -26,7 +26,7 @@ This page describes what you need to propose enabling or replacing the volume di You will need: * A connected [Vega wallet](../../tools/vega-wallet/index.md), with your wallet name and public key to hand * A minimum of whichever is larger, associated with that public key: () or () -* Familiarity with [governance on Vega](../../concepts/governance.md) +* Familiarity with [governance on Vega](../../concepts/governance/index.md) ## Anatomy of a volume discount program proposal The fields below all need to be defined to enable the volume discount program or replace an existing one. @@ -174,7 +174,7 @@ Building support is down to you. Share your proposal in the [_Governance_ sectio To vote, community members need, at a minimum, the larger of or associated to their Vega key. -Your proposal will need [participation](../../concepts/governance.md#how-the-outcome-is-calculated) of and a majority of , so having community support is essential. +Your proposal will need [participation](../../concepts/governance/lifecycle.md#how-the-outcome-is-calculated) of and a majority of , so having community support is essential. Proposers who invite feedback, engage with comments, and make revisions to meet the needs of the community are more likely to be successful. diff --git a/versioned_docs/version-v0.74/tutorials/using-data-sources.md b/versioned_docs/version-v0.74/tutorials/using-data-sources.md index 42c12d3bb..44561476e 100644 --- a/versioned_docs/version-v0.74/tutorials/using-data-sources.md +++ b/versioned_docs/version-v0.74/tutorials/using-data-sources.md @@ -20,7 +20,7 @@ This is done by: The **binding** tells the market which field contains the value. The **spec** defines where this data will come from, and which values to pass through to the binding. :::note Read more: -* [Concept: Market governance](../concepts/governance.md#market-governance) +* [Concept: Market governance](../concepts/governance/market.md) * [Tutorial: Proposing a market](./proposals/new-market-proposal.md) ::: From 9fd4f35059e9688e614b7da707c634f316e61154 Mon Sep 17 00:00:00 2001 From: candida-d <62548908+candida-d@users.noreply.github.com> Date: Mon, 11 Mar 2024 18:44:19 +0000 Subject: [PATCH 10/14] governance --- versioned_docs/version-v0.74/concepts/assets/transfers.md | 2 +- .../version-v0.74/concepts/trading-on-vega/margin.md | 6 ++++-- .../concepts/trading-on-vega/market-lifecycle.md | 2 +- 3 files changed, 6 insertions(+), 4 deletions(-) diff --git a/versioned_docs/version-v0.74/concepts/assets/transfers.md b/versioned_docs/version-v0.74/concepts/assets/transfers.md index ff6e333ab..391ae3ae3 100644 --- a/versioned_docs/version-v0.74/concepts/assets/transfers.md +++ b/versioned_docs/version-v0.74/concepts/assets/transfers.md @@ -89,6 +89,6 @@ The table below details which types of transfers need to be done using a governa | Any other account | Any | No | :::note Read more -* [Concept: Transfers initiated by governance](../governance.md#transferring-assets) +* [Concept: Transfers initiated by governance](../governance/asset.md#transferring-assets) * [Tutorial: Asset transfer proposal](../../tutorials/proposals/asset-transfer-proposal.md) ::: \ No newline at end of file diff --git a/versioned_docs/version-v0.74/concepts/trading-on-vega/margin.md b/versioned_docs/version-v0.74/concepts/trading-on-vega/margin.md index 60a49ffef..a835f7e9c 100644 --- a/versioned_docs/version-v0.74/concepts/trading-on-vega/margin.md +++ b/versioned_docs/version-v0.74/concepts/trading-on-vega/margin.md @@ -143,12 +143,14 @@ The initial margin is scaled from the *maintenance margin* amount. It's calculat The initial margin level being higher than the *margin search level* (which itself is higher than the *maintenance margin level*) ensures that a small negative price move won't lead to a situation where the network has to attempt to allocate more collateral immediately after a trade has been entered into. - ### Margin level: Searching for collateral - cross only For a trader using cross margining, if the balance available in your margin account is less than the position's *margin search level*, but is still above the maintenance level -- the network will try to allocate more money, up to the current initial margin level, from your general account to be used for margin. @@ -166,7 +168,7 @@ If there is not enough collateral to provide the required margin, then the posit :::note Read more [Concept: Closeouts](./market-protections.md#closeouts) -:::--> +::: ### Margin level: Releasing collateral - cross only When using cross margin mode, if your margin balance exceeds the *collateral release level*, the position is considered overcollateralised. The excess money is released to your general account, to get your margin back to the *initial margin level*. diff --git a/versioned_docs/version-v0.74/concepts/trading-on-vega/market-lifecycle.md b/versioned_docs/version-v0.74/concepts/trading-on-vega/market-lifecycle.md index 15288a85a..89f659f57 100644 --- a/versioned_docs/version-v0.74/concepts/trading-on-vega/market-lifecycle.md +++ b/versioned_docs/version-v0.74/concepts/trading-on-vega/market-lifecycle.md @@ -25,7 +25,7 @@ trigger, or product lifecycle trigger | Exit conditions met per [ ## Market status: Proposed -All markets must first be proposed by tokenholders by following the [governance process](../governance.md). Once a valid market proposal is accepted, the market can accept [liquidity commitments](../liquidity/provision.md). +All markets must first be proposed by tokenholders by following the [governance process](../governance/lifecycle.md). Once a valid market proposal is accepted, the market can accept [liquidity commitments](../liquidity/provision.md). Voting begins and its state is `proposed`. Not every market that is proposed (and accepts liquidity) is guaranteed to exist, as it must get enough votes in favour from tokenholders. From 81742cc60a90ef5d73fae2f5cd56b8f1b4fd8f2e Mon Sep 17 00:00:00 2001 From: candida-d <62548908+candida-d@users.noreply.github.com> Date: Tue, 12 Mar 2024 12:14:23 +0000 Subject: [PATCH 11/14] treasury page --- .../concepts/governance/treasury.md | 24 ++++++++----------- 1 file changed, 10 insertions(+), 14 deletions(-) diff --git a/versioned_docs/version-v0.74/concepts/governance/treasury.md b/versioned_docs/version-v0.74/concepts/governance/treasury.md index 6a65186fe..911412f07 100644 --- a/versioned_docs/version-v0.74/concepts/governance/treasury.md +++ b/versioned_docs/version-v0.74/concepts/governance/treasury.md @@ -11,10 +11,10 @@ The network treasury holds assets that can be used by the community to fund init Treasury assets can be used to fund trading rewards, team competitions, grants, Vega protocol software and/or product development, teams building on Vega, or other opportunities. -Anyone with enough VEGA tokens can vote and raise proposals to use treasury assets based on discussions in the community. +Anyone with enough VEGA tokens can vote on and submit proposals to [allocate treasury assets](#how-to-allocate-the-treasury) based on discussions in the community. -* To vote a proposal, you usually need at least 1 VEGA, but the amount may vary per proposal type. Check the [block explorer](https://explorer.fairground.wtf/network-parameters) for each `minVoterBalance`. -* How many VEGA you need to submit a proposal depends on the proposal type. Check the [block explorer](https://explorer.fairground.wtf/network-parameters) for each `minProposerBalance`. +* To vote a proposal, you need at least 1 VEGA, but the minimum amount can vary per proposal type. Check the [block explorer ↗](https://explorer.fairground.wtf/network-parameters) for each `minVoterBalance`. +* How many VEGA you need to submit a proposal depends on the type. Check the [block explorer ↗](https://explorer.fairground.wtf/network-parameters) for each `minProposerBalance`. ## Treasury basics The network treasury can hold VEGA tokens and other assets, which can be used by the community via on-chain governance to grow and support the development of the Vega software and network. @@ -51,12 +51,15 @@ Read more about how these work in the [teams and games](../trading-on-vega/disco **Grants and other initiatives**: A transfer can send to any Vega key, even if it's an individual and not a reward account. You can use a freeform proposal to gauge the community's interest and hone the plan before setting up the proposal for transferring assets. ## How to allocate the treasury +Allocating assets in the treasury requires using governance. There are a few options for moving those assets. + +Before submitting a proposal, make sure you understand the full [governance lifecycle](./lifecycle.md). ### Use governance to spend assets -Assets can only be spend from the on-chain treasury by governance, when a **[proposal to transfer assets](../assets/transfers.md#governance-initiated-transfers)** is enacted. +Assets can only be spend from the on-chain treasury by governance, when a [proposal to transfer assets](../assets/transfers.md#governance-initiated-transfers) is enacted. -The most direct way to propose spending the assets is by submitting one of these proposals. In practice, community members almost always discuss proposals on the **[Vega community forums ↗](https://community.vega.xyz/) before submitting**, in order to incorporate community feedback into the proposal and ensure there's broad support before going through the effort of putting it on-chain. +The most direct way to propose spending the assets is by submitting one of these proposals. In practice, community members almost always **discuss proposals on the[Vega community forums ↗](https://community.vega.xyz/) before submitting**, in order to incorporate community feedback into the proposal and ensure there's broad support before going through the effort of putting it on-chain. The proposal includes details about the specific account(s) or key(s) that you want to send assets to, as well as when to send, and how often. The transfer can be set to happen once or repeatedly. @@ -72,9 +75,9 @@ Raise a freeform proposal with your plan. Include clear details about what you t Based on feedback and voting for your freeform proposal, you can then decide to raise a proposal to transfer assets accordingly. -### Batch proposals +### Batch up your proposals -For more complex sets of actions, you can use a batch proposal to submit several actions to be coordinated to happen as the result of a single vote. These can be spread across time, and can even be used to make temporary changes by including both the changes and a later reversal in the same batch. +For more complex sets of actions, you can use a [batch proposal](./lifecycle.md/#submitting-proposals-in-a-batch) to submit several actions to be coordinated to happen as the result of a single vote. These can be spread across time, and can even be used to make temporary changes by including both the changes and a later reversal in the same batch. Examples of actions that can be coordinated together in a batch include: - Funding multiple reward pools @@ -83,11 +86,4 @@ Examples of actions that can be coordinated together in a batch include: - Changing fee rates - Setting up or changing programmes like referral schemes, or activity streak or volume discount parameters -:::note Read more -[Batch proposals](./lifecycle.md/#submitting-proposals-in-a-batch) -::: - - - - From 7d42d43e0b34ea14b8eb75007577c6c36faa241e Mon Sep 17 00:00:00 2001 From: candida-d <62548908+candida-d@users.noreply.github.com> Date: Tue, 12 Mar 2024 12:54:18 +0000 Subject: [PATCH 12/14] change titles --- docs/concepts/governance/asset.md | 2 +- docs/concepts/governance/market.md | 2 +- docs/concepts/governance/network-parameter.md | 2 +- versioned_docs/version-v0.74/concepts/governance/asset.md | 2 +- versioned_docs/version-v0.74/concepts/governance/market.md | 2 +- .../version-v0.74/concepts/governance/network-parameter.md | 2 +- 6 files changed, 6 insertions(+), 6 deletions(-) diff --git a/docs/concepts/governance/asset.md b/docs/concepts/governance/asset.md index 5e3e34aa7..62711a827 100644 --- a/docs/concepts/governance/asset.md +++ b/docs/concepts/governance/asset.md @@ -1,6 +1,6 @@ --- sidebar_position: 4 -title: Asset governance +title: Assets vega_network: TESTNET hide_title: false description: Add assets or move network-held funds. diff --git a/docs/concepts/governance/market.md b/docs/concepts/governance/market.md index 2d454f337..fe5a737ac 100644 --- a/docs/concepts/governance/market.md +++ b/docs/concepts/governance/market.md @@ -1,6 +1,6 @@ --- sidebar_position: 5 -title: Market governance +title: Markets vega_network: TESTNET hide_title: false description: Add new markets or change existing ones. diff --git a/docs/concepts/governance/network-parameter.md b/docs/concepts/governance/network-parameter.md index 7b844026c..05d6342fc 100644 --- a/docs/concepts/governance/network-parameter.md +++ b/docs/concepts/governance/network-parameter.md @@ -1,6 +1,6 @@ --- sidebar_position: 6 -title: Network parameter +title: Network parameters vega_network: TESTNET hide_title: false description: Change network configuration parameters. diff --git a/versioned_docs/version-v0.74/concepts/governance/asset.md b/versioned_docs/version-v0.74/concepts/governance/asset.md index 3a0877be1..c312be5d9 100644 --- a/versioned_docs/version-v0.74/concepts/governance/asset.md +++ b/versioned_docs/version-v0.74/concepts/governance/asset.md @@ -1,6 +1,6 @@ --- sidebar_position: 4 -title: Asset governance +title: Assets vega_network: MAINNET hide_title: false description: Add assets or move network-held funds. diff --git a/versioned_docs/version-v0.74/concepts/governance/market.md b/versioned_docs/version-v0.74/concepts/governance/market.md index 01b8b84a0..16bb7c5ea 100644 --- a/versioned_docs/version-v0.74/concepts/governance/market.md +++ b/versioned_docs/version-v0.74/concepts/governance/market.md @@ -1,6 +1,6 @@ --- sidebar_position: 5 -title: Market governance +title: Markets vega_network: MAINNET hide_title: false description: Add new markets or change existing ones. diff --git a/versioned_docs/version-v0.74/concepts/governance/network-parameter.md b/versioned_docs/version-v0.74/concepts/governance/network-parameter.md index 023c9ffc5..73bd9d36d 100644 --- a/versioned_docs/version-v0.74/concepts/governance/network-parameter.md +++ b/versioned_docs/version-v0.74/concepts/governance/network-parameter.md @@ -1,6 +1,6 @@ --- sidebar_position: 6 -title: Network parameter +title: Network parameters vega_network: MAINNET hide_title: false description: Change network configuration parameters. From 9b379e0852968831603c4debe49b283705c34b9f Mon Sep 17 00:00:00 2001 From: candida-d <62548908+candida-d@users.noreply.github.com> Date: Tue, 12 Mar 2024 13:24:26 +0000 Subject: [PATCH 13/14] remove subheading --- docs/concepts/governance/asset.md | 1 - versioned_docs/version-v0.74/concepts/governance/asset.md | 1 - 2 files changed, 2 deletions(-) diff --git a/docs/concepts/governance/asset.md b/docs/concepts/governance/asset.md index 62711a827..94943e145 100644 --- a/docs/concepts/governance/asset.md +++ b/docs/concepts/governance/asset.md @@ -7,7 +7,6 @@ description: Add assets or move network-held funds. --- import NetworkParameter from '@site/src/components/NetworkParameter'; -## Asset governance Assets need to be proposed and pass a governance vote before they can be used on the Vega network. The protocol currently supports adding ERC-20 assets. Those ERC-20 assets that are successfully validated and pass a governance vote are can be enabled via the Vega bridge. In practice, that means that assets on Vega are deposited from and withdrawn to Ethereum. diff --git a/versioned_docs/version-v0.74/concepts/governance/asset.md b/versioned_docs/version-v0.74/concepts/governance/asset.md index c312be5d9..9c4329902 100644 --- a/versioned_docs/version-v0.74/concepts/governance/asset.md +++ b/versioned_docs/version-v0.74/concepts/governance/asset.md @@ -7,7 +7,6 @@ description: Add assets or move network-held funds. --- import NetworkParameter from '@site/src/components/NetworkParameter'; -## Asset governance Assets need to be proposed and pass a governance vote before they can be used on the Vega network. The protocol currently supports adding ERC-20 assets. Those ERC-20 assets that are successfully validated and pass a governance vote are can be enabled via the Vega bridge. In practice, that means that assets on Vega are deposited from and withdrawn to Ethereum. From 06ea5bfaf9080b124e97cf1bd72b8352b60fe097 Mon Sep 17 00:00:00 2001 From: candida-d <62548908+candida-d@users.noreply.github.com> Date: Wed, 13 Mar 2024 15:53:33 +0000 Subject: [PATCH 14/14] treasury Co-authored-by: Edd --- docs/concepts/governance/treasury.md | 4 ++-- .../version-v0.74/concepts/governance/treasury.md | 6 +++--- 2 files changed, 5 insertions(+), 5 deletions(-) diff --git a/docs/concepts/governance/treasury.md b/docs/concepts/governance/treasury.md index 70d6c70b6..b115194d1 100644 --- a/docs/concepts/governance/treasury.md +++ b/docs/concepts/governance/treasury.md @@ -13,7 +13,7 @@ Treasury assets can be used to fund trading rewards, team competitions, grants, Anyone with enough VEGA tokens can vote and raise proposals to use treasury assets based on discussions in the community. -* To vote a proposal, you usually need at least 1 VEGA, but the amount may vary per proposal type. Check the [block explorer](https://explorer.fairground.wtf/network-parameters) for each `minVoterBalance`. +* To vote on a proposal, you usually need at least 1 VEGA, but the amount may vary per proposal type. Check the [block explorer](https://explorer.fairground.wtf/network-parameters) for each `minVoterBalance`. * How many VEGA you need to submit a proposal depends on the proposal type. Check the [block explorer](https://explorer.fairground.wtf/network-parameters) for each `minProposerBalance`. ## Treasury basics @@ -54,7 +54,7 @@ Read more about how these work in the [teams and games](../trading-on-vega/disco ### Use governance to spend assets -Assets can only be spend from the on-chain treasury by governance, when a **[proposal to transfer assets](../assets/transfers.md#governance-initiated-transfers)** is enacted. +Assets can only be spent from the on-chain treasury by governance, when a **[proposal to transfer assets](../assets/transfers.md#governance-initiated-transfers)** is enacted. The most direct way to propose spending the assets is by submitting one of these proposals. In practice, community members almost always discuss proposals on the **[Vega community forums ↗](https://community.vega.xyz/) before submitting**, in order to incorporate community feedback into the proposal and ensure there's broad support before going through the effort of putting it on-chain. diff --git a/versioned_docs/version-v0.74/concepts/governance/treasury.md b/versioned_docs/version-v0.74/concepts/governance/treasury.md index 911412f07..75d6df4b7 100644 --- a/versioned_docs/version-v0.74/concepts/governance/treasury.md +++ b/versioned_docs/version-v0.74/concepts/governance/treasury.md @@ -13,7 +13,7 @@ Treasury assets can be used to fund trading rewards, team competitions, grants, Anyone with enough VEGA tokens can vote on and submit proposals to [allocate treasury assets](#how-to-allocate-the-treasury) based on discussions in the community. -* To vote a proposal, you need at least 1 VEGA, but the minimum amount can vary per proposal type. Check the [block explorer ↗](https://explorer.fairground.wtf/network-parameters) for each `minVoterBalance`. +* To vote on a proposal, you need at least 1 VEGA, but the minimum amount can vary per proposal type. Check the [block explorer ↗](https://explorer.fairground.wtf/network-parameters) for each `minVoterBalance`. * How many VEGA you need to submit a proposal depends on the type. Check the [block explorer ↗](https://explorer.fairground.wtf/network-parameters) for each `minProposerBalance`. ## Treasury basics @@ -57,9 +57,9 @@ Before submitting a proposal, make sure you understand the full [governance life ### Use governance to spend assets -Assets can only be spend from the on-chain treasury by governance, when a [proposal to transfer assets](../assets/transfers.md#governance-initiated-transfers) is enacted. +Assets can only be spent from the on-chain treasury by governance, when a [proposal to transfer assets](../assets/transfers.md#governance-initiated-transfers) is enacted. -The most direct way to propose spending the assets is by submitting one of these proposals. In practice, community members almost always **discuss proposals on the[Vega community forums ↗](https://community.vega.xyz/) before submitting**, in order to incorporate community feedback into the proposal and ensure there's broad support before going through the effort of putting it on-chain. +The most direct way to propose spending the assets is by submitting one of these proposals. In practice, community members almost always **discuss proposals on the [Vega community forums ↗](https://community.vega.xyz/) before submitting**, in order to incorporate community feedback into the proposal and ensure there's broad support before going through the effort of putting it on-chain. The proposal includes details about the specific account(s) or key(s) that you want to send assets to, as well as when to send, and how often. The transfer can be set to happen once or repeatedly.