Skip to main content
Version: mainnet (v0.72)

markets.proto

path vega/markets.proto

package vega


Messages

AuctionDuration

Auction duration is used to configure 3 auction periods: 1. `duration > 0`, `volume == 0`: The auction will last for at least N seconds 2. `duration == 0`, `volume > 0`: The auction will end once the given volume will match at uncrossing 3. `duration > 0`, `volume > 0`: The auction will take at least N seconds, but can end sooner if the market can trade a certain volume

NameTypeDescription
durationint64Duration of the auction in seconds.
volumeuint64Target uncrossing trading volume.

DataSourceSpecToFutureBinding

DataSourceSpecToFutureBinding describes which property of the data source data is to be used as settlement data and which to use as the trading terminated trigger

NameTypeDescription
settlement_data_propertystringName of the property in the source data that should be used as settlement data. If it is set to "prices.BTC.value", then the Future will use the value of this property as settlement data.
trading_termination_propertystringName of the property in the data source data that signals termination of trading.

FeeFactors

Fee factors definition

NameTypeDescription
maker_feestringMarket maker fee charged network wide.
infrastructure_feestringInfrastructure fee charged network wide for staking and governance.
liquidity_feestringLiquidity fee applied per market for market making.

Fees

Fees definition

NameTypeDescription
factorsFeeFactorsFee factors.

Future

Future product definition

NameTypeDescription
settlement_assetstringUnderlying asset for the future.
quote_namestringQuote name of the instrument.
data_source_spec_for_settlement_dataDataSourceSpecData source specification that describes the settlement data source filter.
data_source_spec_for_trading_terminationDataSourceSpecData source specification that describes the trading termination data source filter.
data_source_spec_bindingDataSourceSpecToFutureBindingBinding between the data spec and the data source.

Instrument

Instrument definition

NameTypeDescription
idstringUnique instrument ID.
codestringCode for the instrument.
namestringName of the instrument.
metadataInstrumentMetadataCollection of instrument meta-data.
futureFutureFuture.
spotSpotSpot.

InstrumentMetadata

Instrument metadata definition

NameTypeDescription
tagsstringList of 0 or more tags.

LiquidityMonitoringParameters

LiquidityMonitoringParameters contains settings used for liquidity monitoring

NameTypeDescription
target_stake_parametersTargetStakeParametersSpecifies parameters related to target stake calculation.
triggering_ratiostringSpecifies the triggering ratio for entering liquidity auction.
auction_extensionint64Specifies by how many seconds an auction should be extended if leaving the auction were to trigger a liquidity auction.

LogNormalModelParams

Risk model parameters for log normal

NameTypeDescription
mudoubleMu parameter, annualised growth rate of the underlying asset.
rdoubleR parameter, annualised growth rate of the risk-free asset, used for discounting of future cash flows, can be any real number.
sigmadoubleSigma parameter, annualised volatility of the underlying asset, must be a strictly non-negative real number.

LogNormalRiskModel

Risk model for log normal

NameTypeDescription
risk_aversion_parameterdoubleRisk Aversion Parameter.
taudoubleTau parameter of the risk model, projection horizon measured as a year fraction used in the expected shortfall calculation to obtain the maintenance margin, must be a strictly non-negative real number.
paramsLogNormalModelParamsRisk model parameters for log normal.

MarginCalculator

Margin Calculator definition

NameTypeDescription
scaling_factorsScalingFactorsScaling factors for margin calculation.

Market

Market definition

NameTypeDescription
idstringUnique ID for the market.
tradable_instrumentTradableInstrumentTradable instrument configuration.
decimal_placesuint64Number of decimal places that a price must be shifted by in order to get a correct price denominated in the currency of the market, for example: `realPrice = price / 10^decimalPlaces`.
feesFeesFees configuration that apply to the market.
opening_auctionAuctionDurationAuction duration specifies how long the opening auction will run (minimum duration and optionally a minimum traded volume).
price_monitoring_settingsPriceMonitoringSettingsPriceMonitoringSettings for the market.
liquidity_monitoring_parametersLiquidityMonitoringParametersLiquidityMonitoringParameters for the market.
trading_modeMarket.TradingModeCurrent mode of execution of the market.
stateMarket.StateCurrent state of the market.
market_timestampsMarketTimestampsTimestamps for when the market state changes.
position_decimal_placesint64The number of decimal places for a position.
lp_price_rangestringPercentage move up and down from the mid price which specifies the range of price levels over which automated liquidity provision orders will be deployed.
linear_slippage_factorstringLinear slippage factor is used to cap the slippage component of maintenance margin - it is applied to the slippage volume.
quadratic_slippage_factorstringQuadratic slippage factor is used to cap the slippage component of maintenance margin - it is applied to the square of the slippage volume.
parent_market_idstringID of the market this market succeeds
insurance_pool_fractionstringThe fraction of the parent market's insurance pool that this market inherits; range 0 through 1.
successor_market_idstringID of the market that succeeds this market if it exists. This will be populated by the system when the successor market is enabled.

MarketTimestamps

Time stamps for important times about creating, enacting etc the market

NameTypeDescription
proposedint64Time when the market is first proposed.
pendingint64Time when the market has been voted in and began its opening auction.
openint64Time when the market has left the opening auction and is ready to accept trades.
closeint64Time when the market closed.

PriceMonitoringParameters

PriceMonitoringParameters contains a collection of triggers to be used for a given market

NameTypeDescription
triggersPriceMonitoringTrigger

PriceMonitoringSettings

PriceMonitoringSettings contains the settings for price monitoring

NameTypeDescription
parametersPriceMonitoringParametersSpecifies price monitoring parameters to be used for price monitoring purposes.

PriceMonitoringTrigger

PriceMonitoringTrigger holds together price projection horizon τ, probability level p, and auction extension duration

NameTypeDescription
horizonint64Price monitoring projection horizon τ in seconds.
probabilitystringPrice monitoring probability level p.
auction_extensionint64Price monitoring auction extension duration in seconds should the price breach its theoretical level over the specified horizon at the specified probability level.

ScalingFactors

Scaling Factors (for use in margin calculation)

NameTypeDescription
search_leveldoubleCollateral search level. If collateral dips below this value, the system will search for collateral to release.
initial_margindoubleInitial margin level. This is the minimum amount of collateral required to open a position in a market that requires margin.
collateral_releasedoubleCollateral release level. If a trader has collateral above this level, the system will release collateral to a trader's general collateral account for the asset.

SimpleModelParams

Risk model parameters for simple modelling

NameTypeDescription
factor_longdoublePre-defined risk factor value for long.
factor_shortdoublePre-defined risk factor value for short.
max_move_updoublePre-defined maximum price move up that the model considers as valid.
min_move_downdoublePre-defined minimum price move down that the model considers as valid.
probability_of_tradingdoublePre-defined constant probability of trading.

SimpleRiskModel

Risk model for simple modelling

NameTypeDescription
paramsSimpleModelParamsRisk model params for simple modelling.

Spot

Spot product definition

NameTypeDescription
base_assetstringAsset ID of the underlying base asset for the spot product.
quote_assetstringAsset ID of the underlying quote asset for the spot product.
namestringName of the instrument.

TargetStakeParameters

TargetStakeParameters contains parameters used in target stake calculation

NameTypeDescription
time_windowint64Specifies length of time window expressed in seconds for target stake calculation.
scaling_factordoubleSpecifies scaling factors used in target stake calculation.

TradableInstrument

Tradable Instrument definition

NameTypeDescription
instrumentInstrumentDetails for the underlying instrument.
margin_calculatorMarginCalculatorMargin calculator for the instrument.
log_normal_risk_modelLogNormalRiskModelLog normal.
simple_risk_modelSimpleRiskModelSimple.

Enums

Market.State

Current state of the market

NameNumberDescription
STATE_UNSPECIFIED0Default value, invalid
STATE_PROPOSED1Governance proposal valid and accepted
STATE_REJECTED2Outcome of governance votes is to reject the market
STATE_PENDING3Governance vote passes/wins
STATE_CANCELLED4Market triggers cancellation condition or governance votes to close before market becomes Active
STATE_ACTIVE5Enactment date reached and usual auction exit checks pass
STATE_SUSPENDED6Price monitoring or liquidity monitoring trigger
STATE_CLOSED7Governance vote to close (Not currently implemented)
STATE_TRADING_TERMINATED8Defined by the product (i.e. from a product parameter, specified in market definition, giving close date/time)
STATE_SETTLED9Settlement triggered and completed as defined by product

Market.TradingMode

Trading mode the market is currently running, also referred to as 'market state'

NameNumberDescription
TRADING_MODE_UNSPECIFIED0Default value, this is invalid
TRADING_MODE_CONTINUOUS1Normal trading
TRADING_MODE_BATCH_AUCTION2Auction trading (FBA)
TRADING_MODE_OPENING_AUCTION3Opening auction
TRADING_MODE_MONITORING_AUCTION4Auction triggered by monitoring
TRADING_MODE_NO_TRADING5No trading is allowed