settlement

package
v0.54.1-nocontractcheck Latest Latest
Warning

This package is not in the latest version of its module.

Go to latest
Published: Aug 18, 2022 License: MIT Imports: 12 Imported by: 0

Documentation

Index

Constants

This section is empty.

Variables

View Source
var ErrPartyDoesNotMatch = errors.New("event party and position party do not match")

Functions

This section is empty.

Types

type Broker

type Broker interface {
	SendBatch(events []events.Event)
}

Broker - the event bus broker, send events here.

type Config

type Config struct {
	Level encoding.LogLevel `long:"log-level"`
}

Config represent the configuration of the settlement engine.

func NewDefaultConfig

func NewDefaultConfig() Config

NewDefaultConfig creates an instance of the package specific configuration, given a pointer to a logger instance to be used for logging within the package.

type Engine

type Engine struct {
	Config
	// contains filtered or unexported fields
}

Engine - the main type (of course).

func New

func New(log *logging.Logger, conf Config, product Product, market string, timeService TimeService, broker Broker, positionFactor num.Decimal) *Engine

New instantiates a new instance of the settlement engine.

func (*Engine) AddPosition

func (e *Engine) AddPosition(party string, evt events.MarketPosition)

func (*Engine) AddTrade

func (e *Engine) AddTrade(trade *types.Trade)

AddTrade - this call is required to get the correct MTM settlement values each change in position has to be calculated using the exact price of the trade.

func (*Engine) ReloadConf

func (e *Engine) ReloadConf(cfg Config)

ReloadConf update the internal configuration of the settlement engined.

func (*Engine) RemoveDistressed

func (e *Engine) RemoveDistressed(ctx context.Context, evts []events.Margin)

RemoveDistressed - remove whatever settlement data we have for distressed parties they are being closed out, and shouldn't be part of any MTM settlement or closing settlement.

func (*Engine) Settle

func (e *Engine) Settle(t time.Time, assetDecimals uint32) ([]*types.Transfer, error)

Settle run settlement over all the positions.

func (*Engine) SettleMTM

func (e *Engine) SettleMTM(ctx context.Context, markPrice *num.Uint, positions []events.MarketPosition) []events.Transfer

func (*Engine) Update

func (e *Engine) Update(positions []events.MarketPosition)

Update merely adds positions to the settlement engine, and won't be useful for a MTM settlement this function is mainly used for testing, and should be used with extreme caution as a result perhaps the tests should be refactored to use the Settle call to create positions first.

func (*Engine) UpdateProduct

func (e *Engine) UpdateProduct(product products.Product)

type MarketPosition

type MarketPosition interface {
	Party() string
	Size() int64
	Buy() int64
	Sell() int64
	Price() *num.Uint
	VWBuy() *num.Uint
	VWSell() *num.Uint
	ClearPotentials()
}

MarketPosition ...

type Product

type Product interface {
	Settle(*num.Uint, uint32, num.Decimal) (*types.FinancialAmount, bool, error)
	GetAsset() string
}

Product ...

type TimeService

type TimeService interface {
	GetTimeNow() time.Time
}

TimeService.

Directories

Path Synopsis
Package mocks is a generated GoMock package.
Package mocks is a generated GoMock package.

Jump to

Keyboard shortcuts

? : This menu
/ : Search site
f or F : Jump to
y or Y : Canonical URL