From 383856c25644fb6c6e1dfc544f29b7d33d767fea Mon Sep 17 00:00:00 2001 From: Tom Date: Wed, 10 Jan 2024 20:30:26 +0800 Subject: [PATCH] feat: Adding market tags proposal spec (#2103) --------- Co-authored-by: Gordsport <83510148+gordsport@users.noreply.github.com> --- .github/workflows/quality_check.yml | 2 +- makefile | 2 +- protocol/0001-MKTF-market_framework.md | 1 + protocol/0028-GOVE-governance.md | 43 +++++++++++++++++++++++++- protocol/nebula-features.json | 30 ++++++++++++++++++ 5 files changed, 75 insertions(+), 3 deletions(-) create mode 100644 protocol/nebula-features.json diff --git a/.github/workflows/quality_check.yml b/.github/workflows/quality_check.yml index bc8042d5a..c4869cb04 100644 --- a/.github/workflows/quality_check.yml +++ b/.github/workflows/quality_check.yml @@ -77,4 +77,4 @@ jobs: - name: "Run Check Features" run: | - npx github:vegaprotocol/approbation check-features --specs="{./non-protocol-specs/**/*.md,./protocol/**/*.md,./protocol/**/*.ipynb}" --features="./protocol/features.json" + npx github:vegaprotocol/approbation check-features --specs="{./non-protocol-specs/**/*.md,./protocol/**/*.md,./protocol/**/*.ipynb}" --features="./protocol/nebula-features.json" diff --git a/makefile b/makefile index ae9bcacd0..f2bc609ae 100644 --- a/makefile +++ b/makefile @@ -64,7 +64,7 @@ spellcheck: # Checks for duplicated ACs in the features.json file .PHONY: check-features check-features: - npx github:vegaprotocol/approbation check-features --specs="{./non-protocol-specs/**/*.md,./protocol/**/*.md,./protocol/**/*.ipynb}" --features="./protocol/features.json" + npx github:vegaprotocol/approbation check-features --specs="{./non-protocol-specs/**/*.md,./protocol/**/*.md,./protocol/**/*.ipynb}" --features="./protocol/nebula-features.json" clean: rm -rf $(TEMP) diff --git a/protocol/0001-MKTF-market_framework.md b/protocol/0001-MKTF-market_framework.md index 1f4bc30d5..5f16a0699 100644 --- a/protocol/0001-MKTF-market_framework.md +++ b/protocol/0001-MKTF-market_framework.md @@ -80,6 +80,7 @@ Data: - **Name:** full and fairly descriptive name for the instrument. - **Metadata fields:** A series of arbitrary strings that can be used in clients - **Product:** a reference to or instance of a fully specified product, including all required product parameters for that product. +- **Community Tags:** A list of string community tags assigning the market to certain categories. Each of these is a free text field of a network parameter defined maximum length. These are managed through a separate proposal type and cannot be set at market creation or changed in a normal market update proposal. ## Product diff --git a/protocol/0028-GOVE-governance.md b/protocol/0028-GOVE-governance.md index d29c11836..c4aba128b 100644 --- a/protocol/0028-GOVE-governance.md +++ b/protocol/0028-GOVE-governance.md @@ -249,6 +249,32 @@ The following are immutable and cannot be changed: - position decimal places - `settlementAsset` +### 2.1 Change community tags + +Separately to a general market change proposal, proposers can create a proposal to add or remove lists of free-text string community tags to a market. Although these proposals change only a single market, it is possible that these tags will be used to control external behaviour of systems interacting with the vega chain, therefore they do not allow for voting using ELS and instead must be voted through by the general pool of token holders as with any other proposal. The maximum length of a community tags is specified by the network parameter `governance.proposal.market.maxCommunityTagLength`. The community tags on a market are controlled by a single proposal type, `UpdateCommunityTags` with a structure akin to: + +```proto +message UpdateCommunityTags { + string marketId; + repeated string addTags; + repeated string removeTags; +} +``` + +allowing proposals to add and remove tags independently from others. + +The following network parameters will decide how these proposals are treated: +`governance.proposal.updateCommunityTags.maxClose` e.g. `720h`, +`governance.proposal.updateCommunityTags.minClose` e,g. `168h`, +`governance.proposal.updateCommunityTags.maxEnact` e.g. `720h`, +`governance.proposal.updateCommunityTags.minEnact` e,g. `168h`, +`governance.proposal.updateCommunityTags.minProposerBalance` e.g. `1000000000000000000` i.e. 1 VEGA, +`governance.proposal.updateCommunityTags.minVoterBalance` e.g. `1000000000000000000` i.e. 1 VEGA, +`governance.proposal.updateCommunityTags.requiredMajority` e.g. `0.66`, +`governance.proposal.updateCommunityTags.requiredParticipation` e.g. `0.05`. + +Note: Although community tags cannot be amended in an update market proposal, they may be included in the same batch proposal as one. + ## 3. Change network parameters [Network parameters](./0054-NETP-network_parameters.md) that may be changed are described in the _Network Parameters_ spec, this document for details on these parameters, including the category of the parameters. New network parameters require a code change, so there is no support for adding new network parameters. @@ -708,9 +734,10 @@ It is NOT possible to submit a governance proposal where the source account is t 1. volume discount program, 1. referral program, 1. governance transfer, + 1. a community tags proposal can be submitted, voted through and each proposal enacted. -On top of that signed bundles for changing withdrawal delay and threshold on the bridge are emitted (0028-GOVE-160) +On top of that signed bundles for changing withdrawal delay and threshold on the bridge are emitted (0028-GOVE-177) - A batch proposal can be submitted changing the same network parameter twice to two different values with two different enactment timestamps. The voting to approve the batch happens, the batch passes, both changes are observed at the desired time. (0028-GOVE-161) @@ -726,3 +753,17 @@ The voting to approve the batch happens, the batch passes, the value of the prop ##### Network History - A datanode restored from network history will contain any recurring and one-off transfers created prior to the restore and these can be retrieved via APIs on the new datanode.(0028-GOVE-127) + +##### Community Market Tags + +- A proposal to add community tags to a market can be successfully submitted. (0028-GOVE-167) + - When that proposal is approved and enacted the community tags are immediately added to that market's community tags property. (0028-GOVE-168) +- A proposal to remove community tags from a market can be successfully submitted. (0028-GOVE-169) + - When that proposal is approved and enacted the community tags are immediately removed from that market's community tags property. (0028-GOVE-170) +- A proposal to add some and remove other community tags from a market can be successfully submitted. (0028-GOVE-171) + - When that proposal is approved and enacted the community tags are immediately removed and added to that market's community tags property. (0028-GOVE-172) +- Neither market creation nor market update proposals can change the community tags property on a market. (0028-GOVE-173) +- A voter's equity-like share does not give them any additional voting weight when voting on a market community tags update proposal. (0028-GOVE-174) +- A proposal to add community tags with any community tags longer than `governance.proposal.market.maxCommunityTagLength` is rejected as invalid (0028-GOVE-175) +- A proposal to remove community tags with any community tags longer than `governance.proposal.market.maxCommunityTagLength` is rejected as invalid (0028-GOVE-176) + diff --git a/protocol/nebula-features.json b/protocol/nebula-features.json new file mode 100644 index 000000000..9b201a88e --- /dev/null +++ b/protocol/nebula-features.json @@ -0,0 +1,30 @@ +{ + "TBC": { + "milestone": "cosmic-carryover", + "acs": [] + }, + "TBC": { + "milestone": "palazzo-carryover", + "acs": [] + }, + "Community Tags": { + "milestone": "nebula", + "acs": [ + "0028-GOVE-167", + "0028-GOVE-168", + "0028-GOVE-169", + "0028-GOVE-170", + "0028-GOVE-171", + "0028-GOVE-172", + "0028-GOVE-173", + "0028-GOVE-174", + "0028-GOVE-175", + "0028-GOVE-176", + "0028-GOVE-177" + ] + }, + "Unknown": { + "milestone": "unknown", + "acs": [] + } +}