Documentation ¶
Index ¶
- Constants
- Variables
- type AcceptArgs
- type Account
- type AccountAndKey
- type AddressInfo
- type AddressesInfo
- type CompleteResult
- type Deposit
- type DepositKey
- type DepositRepository
- type Encrypter
- type FixedFee
- type Market
- func (m *Market) BaseAssetPrice() decimal.Decimal
- func (m *Market) ChangeBasePrice(price decimal.Decimal) error
- func (m *Market) ChangeFeeBasisPoint(fee int64) error
- func (m *Market) ChangeFixedFee(baseFee, quoteFee int64) error
- func (m *Market) ChangeQuotePrice(price decimal.Decimal) error
- func (m *Market) IsStrategyBalanced() bool
- func (m *Market) IsStrategyPluggable() bool
- func (m *Market) IsStrategyPluggableInitialized() bool
- func (m *Market) IsTradable() bool
- func (m *Market) MakeNotTradable() error
- func (m *Market) MakeStrategyBalanced() error
- func (m *Market) MakeStrategyPluggable() error
- func (m *Market) MakeTradable() error
- func (m *Market) Preview(baseBalance, quoteBalance, amount uint64, isBaseAsset, isBuy bool) (*PreviewInfo, error)
- func (m *Market) QuoteAssetPrice() decimal.Decimal
- func (m *Market) VerifyMarketFunds(fundingTxs []OutpointWithAsset) error
- type MarketRepository
- type MnemonicStore
- type OutpointWithAsset
- type Page
- type PluggableStrategy
- func (s PluggableStrategy) FormulaType() int
- func (s PluggableStrategy) InGivenOut(_opts interface{}, amountOut uint64) (uint64, error)
- func (s PluggableStrategy) OutGivenIn(_opts interface{}, amountIn uint64) (uint64, error)
- func (s PluggableStrategy) SpotPrice(_opts interface{}) (spotPrice decimal.Decimal, err error)
- type PluggableStrategyOpts
- type PreviewInfo
- type Prices
- type PsetParser
- type Status
- type StrategyType
- type Swap
- type SwapAccept
- type SwapComplete
- type SwapError
- type SwapFail
- type SwapParser
- type SwapRequest
- type Trade
- func (t *Trade) Accept(psetBase64 string, inputBlindingKeys, outputBlindingKeys map[string][]byte, ...) (bool, error)
- func (t *Trade) Complete(tx string) (*CompleteResult, error)
- func (t *Trade) ContainsSwap(swapID string) bool
- func (t *Trade) Expire() (bool, error)
- func (t *Trade) Fail(swapID string, errCode int, errMsg string)
- func (t *Trade) IsAccepted() bool
- func (t *Trade) IsCompleted() bool
- func (t *Trade) IsEmpty() bool
- func (t *Trade) IsExpired() bool
- func (t *Trade) IsProposal() bool
- func (t *Trade) IsRejected() bool
- func (t *Trade) IsSettled() bool
- func (t *Trade) Propose(swapRequest SwapRequest, marketBaseAsset, marketQuoteAsset string, ...) (bool, error)
- func (t *Trade) Settle(settlementTime uint64) (bool, error)
- func (t *Trade) SwapAcceptMessage() SwapAccept
- func (t *Trade) SwapCompleteMessage() SwapComplete
- func (t *Trade) SwapFailMessage() SwapFail
- func (t *Trade) SwapRequestMessage() SwapRequest
- type TradeRepository
- type Unspent
- func (u *Unspent) Confirm()
- func (u *Unspent) IsConfirmed() bool
- func (u *Unspent) IsKeyEqual(key UnspentKey) bool
- func (u *Unspent) IsLocked() bool
- func (u *Unspent) IsSpent() bool
- func (u *Unspent) Key() UnspentKey
- func (u *Unspent) Lock(tradeID *uuid.UUID) error
- func (u *Unspent) Spend()
- func (u *Unspent) ToOutpointWithAsset() OutpointWithAsset
- func (u *Unspent) ToUtxo() explorer.Utxo
- func (u *Unspent) Unlock()
- type UnspentKey
- type UnspentRepository
- type Vault
- func (v *Vault) AccountByAddress(addr string) (*Account, int, error)
- func (v *Vault) AccountByIndex(accountIndex int) (*Account, error)
- func (v *Vault) AllDerivedAddressesInfo() AddressesInfo
- func (v *Vault) AllDerivedAddressesInfoForAccount(accountIndex int) (AddressesInfo, error)
- func (v *Vault) AllDerivedExternalAddressesInfoForAccount(accountIndex int) (AddressesInfo, error)
- func (v *Vault) ChangePassphrase(currentPassphrase, newPassphrase string) error
- func (v *Vault) DeriveNextExternalAddressForAccount(accountIndex int) (*AddressInfo, error)
- func (v *Vault) DeriveNextInternalAddressForAccount(accountIndex int) (*AddressInfo, error)
- func (v *Vault) GetMnemonicSafe() ([]string, error)
- func (v *Vault) InitAccount(accountIndex int)
- func (v *Vault) IsInitialized() bool
- func (v *Vault) IsLocked() bool
- func (v *Vault) IsZero() bool
- func (v *Vault) Lock()
- func (v *Vault) Unlock(passphrase string) error
- type VaultRepository
- type Withdrawal
- type WithdrawalRepository
Constants ¶
const ( FeeAccount = iota WalletAccount FeeFragmenterAccount MarketFragmenterAccount UnusedAccount3 MarketAccountStart ExternalChain = 0 InternalChain = 1 MinMilliSatPerByte = 100 StrategyTypePluggable StrategyType = 0 StrategyTypeBalanced StrategyType = 1 StrategyTypeUnbalanced StrategyType = 2 )
const ( Empty = iota - 1 Undefined Proposal Accepted Completed Settled Expired )
const ( DefaultPageNumber = 1 DefaultPageSize = 10 )
Variables ¶
var ( // ErrMarketFeeTooLow ... ErrMarketFeeTooLow = errors.New("market fee too low, must be at least 1 bp (0.01%)") // ErrMarketFeeTooHigh ... ErrMarketFeeTooHigh = errors.New("market fee too high, must be at most 9999 bp (99,99%)") // ErrMarketMissingFunds ... ErrMarketMissingFunds = errors.New("missing funds of both base and quote asset") // ErrMarketMissingBaseAsset ... ErrMarketMissingBaseAsset = errors.New( "missing funds for base asset. A market with zero balance and balanced " + "strategy requires a deposit with funds of both assets. " + "You should change strategy to be able to make a single asset deposit", ) // ErrMarketMissingQuoteAsset ... ErrMarketMissingQuoteAsset = errors.New( "quote asset is missing. A market with zero balance and balanced " + "strategy requires a deposit with funds of both assets. " + "You should change strategy to be able to make a single asset deposit", ) // ErrMarketTooManyAssets ... ErrMarketTooManyAssets = errors.New( "too many assets. This means among the deposited funds there are " + "unspents with asset different from the market pair. " + "They must be withdrawn to open the market", ) //ErrMarketNotFunded is thrown when a market requires being funded for a change ErrMarketNotFunded = errors.New("market must be funded") //ErrMarketIsClosed is thrown when a market requires being tradable for a change ErrMarketIsClosed = errors.New("the market is paused, please open it first") //ErrMarketMustBeClosed is thrown when a market requires being NOT tradable for a change ErrMarketMustBeClosed = errors.New("the market is active, please pause it first") //ErrMarketNotPriced is thrown when the price is still 0 (ie. not initialized) ErrMarketNotPriced = errors.New("the selected strategy mandates price to be updated manually") //ErrMarketInvalidBasePrice is thrown when the amount for Base price is an invalid satoshis value. ErrMarketInvalidBasePrice = errors.New("the amount for base price is invalid") //ErrMarketInvalidQuotePrice is thrown when the amount for Quote price is an invalid satoshis value. ErrMarketInvalidQuotePrice = errors.New("the amount for base price is invalid") // ErrMarketInvalidBaseAsset is thrown when non valid base asset is given ErrMarketInvalidBaseAsset = errors.New("invalid base asset") // ErrMarketInvalidQuoteAsset is thrown when non valid quote asset is given ErrMarketInvalidQuoteAsset = errors.New("invalid quote asset") // ErrInvalidFixedFee ... ErrInvalidFixedFee = errors.New("fixed fee must be a positive value") // ErrMarketPreviewAmountTooLow is returned when a preview fails because // the provided amount makes the previewed amount to be too low (lower than // the optional fixed fee). ErrMarketPreviewAmountTooLow = errors.New("provided amount is too low") // ErrMarketPreviewAmountTooBig is returned when a preview fails because // the provided amount makes the previewed amount to be too big (greater than // the overall balance). ErrMarketPreviewAmountTooBig = errors.New("provided amount is too big") )
Market errors
var ( // ErrVaultMustBeLocked is thrown when trying to change the passphrase with an unlocked wallet ErrVaultMustBeLocked = errors.New("wallet must be locked to perform this operation") // ErrVaultMustBeUnlocked is thrown when trying to make an operation that requires the wallet to be unlocked ErrVaultMustBeUnlocked = errors.New("wallet must be unlocked to perform this operation") // ErrVaultInvalidPassphrase ... ErrVaultInvalidPassphrase = errors.New("passphrase is not valid") // ErrVaultAlreadyInitialized ... ErrVaultAlreadyInitialized = errors.New("vault is already initialized") // ErrVaultNullMnemonicOrPassphrase ... ErrVaultNullMnemonicOrPassphrase = errors.New("mnemonic and/or passphrase must not be null") // ErrVaultNullNetwork ... ErrVaultNullNetwork = errors.New("network must not be null") // ErrVaultAccountNotFound ... ErrVaultAccountNotFound = errors.New("account not found") )
Vault errors
var ( // ErrTradeMustBeEmpty ... ErrTradeMustBeEmpty = errors.New( "trade must be empty for parsing a proposal", ) // ErrTradeMustBeProposal ... ErrTradeMustBeProposal = errors.New( "trade must be in proposal state for being accepted", ) // ErrTradeMustBeAccepted ... ErrTradeMustBeAccepted = errors.New( "trade must be in accepted state for being completed", ) // ErrTradeMustBeCompleted ... ErrTradeMustBeCompletedOrAccepted = errors.New( "trade must be in completed or accepted to be settled", ) // ErrTradeExpirationDateNotReached ... ErrTradeExpirationDateNotReached = errors.New( "trade must have reached the expiration date to be set expired", ) // ErrTradeExpired ... ErrTradeExpired = errors.New("trade has expired") // ErrTradeNullExpirationDate ... ErrTradeNullExpirationDate = errors.New( "trade must have an expiration date set to be set expired", ) )
Trade errors
var ( // EmptyStatus represent the status of an empty trade. EmptyStatus = Status{ Code: Empty, } // ProposalStatus represent the status of a trade presented by some trader to // the daemon and not yet processed. ProposalStatus = Status{ Code: Proposal, } // ProposalRejectedStatus represents the status of a trade presented by some // trader to the daemon and rejected for some reason. ProposalRejectedStatus = Status{ Code: Proposal, Failed: true, } // AcceptedStatus represents the status of a trade proposal that has been // accepted by the daemon AcceptedStatus = Status{ Code: Accepted, } // FailedToCompleteStatus represents the status of a trade that failed to be // be completed for some reason. FailedToCompleteStatus = Status{ Code: Accepted, Failed: true, } // CompletedStatus represents the status of a trade that has been completed // and accepted in mempool, waiting for being published on the blockchain. CompletedStatus = Status{ Code: Completed, } // FailedToSettleStatus represents the status of a trade that failed to be // be settled for some reason. FailedToSettleStatus = Status{ Code: Completed, Failed: true, } // SettledStatus represents the status of a trade that has been settled, // meaning that has been included into the blockchain. SettledStatus = Status{ Code: Settled, } // ExpiredStatus represents the status of a trade that has been expired, // meaning that it was at least accepted, but not settled within the // expiration time frame. ExpiredStatus = Status{ Code: Expired, Failed: true, } )
var ( // SwapParserManager ... SwapParserManager SwapParser // PsetParserManager ... PsetParserManager PsetParser )
var ( MnemonicStoreManager MnemonicStore EncrypterManager Encrypter )
MnemonicStore can be set externally by the user of the domain, assigning it to an instance of a IMnemonicStore implementation
var ( // ErrInvalidAccount ... ErrInvalidAccount = errors.New("account index must be a positive integer number") )
Account errors
var ( // ErrUnspentAlreadyLocked ... ErrUnspentAlreadyLocked = errors.New("cannot lock an already locked unspent") )
Unspent errors
Functions ¶
This section is empty.
Types ¶
type AcceptArgs ¶ added in v0.3.0
type AcceptArgs struct { RequestMessage []byte Transaction string InputBlindingKeys map[string][]byte OutputBlindingKeys map[string][]byte }
AcceptArgs ...
type Account ¶
type Account struct { AccountIndex int LastExternalIndex int LastInternalIndex int DerivationPathByScript map[string]string }
Account defines the entity data struture for a derived account of the daemon's HD wallet
func NewAccount ¶
NewAccount returns an empty Account instance
type AccountAndKey ¶
type AddressInfo ¶
type AddressesInfo ¶ added in v0.3.0
type AddressesInfo []AddressInfo
func (AddressesInfo) Addresses ¶ added in v0.3.0
func (info AddressesInfo) Addresses() []string
func (AddressesInfo) AddressesAndKeys ¶ added in v0.3.0
func (info AddressesInfo) AddressesAndKeys() ([]string, [][]byte)
type CompleteResult ¶
CompleteResult is return type of Complete method.
type Deposit ¶ added in v0.6.0
type Deposit struct { AccountIndex int TxID string VOut int Asset string Value uint64 Timestamp uint64 }
Deposit is used to follow deposit statistics made by operator
func (Deposit) Key ¶ added in v0.6.0
func (d Deposit) Key() DepositKey
type DepositKey ¶ added in v0.6.0
DepositKey represent the ID of an Deposit, composed by its txid and vout.
type DepositRepository ¶ added in v0.6.0
type DepositRepository interface { // AddDeposits adds the provided deposits to the repository. Those already // existing won't be re-added. AddDeposits(ctx context.Context, deposits []Deposit) (int, error) // ListDepositsForAccount returns the list of deposits related to the given // wallet account id. ListDepositsForAccount( ctx context.Context, accountIndex int, ) ([]Deposit, error) // ListDepositsForAccountAndPage returns a page containing a subset of the // list of deposits related to the given wallet account id. ListDepositsForAccountAndPage( ctx context.Context, accountIndex int, page Page, ) ([]Deposit, error) // ListAllDeposits returns all deposits related to all wallet accounts stored // in the repository. ListAllDeposits(ctx context.Context) ([]Deposit, error) // ListAllDepositsForPage returns a page containing a subset of deposits // related to all wallet accounts stored in the repository. ListAllDepositsForPage(ctx context.Context, page Page) ([]Deposit, error) }
DepositRepository is the abstraction to which all concrete implementations must sitck with to persist deposits.
type Encrypter ¶ added in v0.3.0
type Encrypter interface { Encrypt(mnemonic, passphrase string) (string, error) Decrypt(encryptedMnemonic, passphrase string) (string, error) }
Encrypter defines the required methods to override the default encryption performed through pkg/wallet package.
type Market ¶
type Market struct { // AccountIndex links a market to a HD wallet account derivation. AccountIndex int BaseAsset string QuoteAsset string // Each Market has a different fee expressed in basis point of each swap. Fee int64 FixedFee FixedFee // if curretly open for trades Tradable bool // Market Making strategy Strategy mm.MakingStrategy // Pluggable Price of the asset pair. Price Prices }
Market defines the Market entity data structure for holding an asset pair state
func NewMarket ¶
func NewMarket( accountIndex int, baseAsset, quoteAsset string, feeInBasisPoint int64, ) (*Market, error)
NewMarket returns a new market with an account index, the asset pair and the percentage fee set.
func (*Market) BaseAssetPrice ¶
BaseAssetPrice returns the latest price for the base asset
func (*Market) ChangeBasePrice ¶
ChangeBasePrice ...
func (*Market) ChangeFeeBasisPoint ¶ added in v0.3.9
ChangeFeeBasisPoint ...
func (*Market) ChangeFixedFee ¶ added in v0.3.9
ChangeFixedFee ...
func (*Market) ChangeQuotePrice ¶
ChangeQuotePrice ...
func (*Market) IsStrategyBalanced ¶ added in v0.8.1
func (*Market) IsStrategyPluggable ¶
IsStrategyPluggable returns true if the the startegy isn't automated.
func (*Market) IsStrategyPluggableInitialized ¶
IsStrategyPluggableInitialized returns true if the prices have been set.
func (*Market) IsTradable ¶
IsTradable returns true if the market is available for trading
func (*Market) MakeStrategyBalanced ¶
MakeStrategyBalanced makes the current market using a balanced AMM formula 50/50
func (*Market) MakeStrategyPluggable ¶
MakeStrategyPluggable makes the current market using a given price (ie. set via UpdateMarketPrice rpc either manually or a price feed plugin)
func (*Market) Preview ¶ added in v0.4.4
func (m *Market) Preview( baseBalance, quoteBalance, amount uint64, isBaseAsset, isBuy bool, ) (*PreviewInfo, error)
func (*Market) QuoteAssetPrice ¶
QuoteAssetPrice returns the latest price for the quote asset
func (*Market) VerifyMarketFunds ¶ added in v0.6.0
func (m *Market) VerifyMarketFunds(fundingTxs []OutpointWithAsset) error
VerifyMarketFunds verifies that the provided list of outpoints (each including the unblinded asset) are valid funds of the market, by checking that their assets match those of the market.
type MarketRepository ¶
type MarketRepository interface { // Retrieves a market with the given account index. If not found, a new entry shall be created. GetOrCreateMarket(ctx context.Context, market *Market) (*Market, error) // Retrieves a market with a given account index. GetMarketByAccount(ctx context.Context, accountIndex int) (market *Market, err error) // Retrieves a market with a given a quote asset hash. GetMarketByAssets( ctx context.Context, baseAsset, quoteAsset string, ) (market *Market, accountIndex int, err error) // Retrieves the latest market sorted by account index GetLatestMarket(ctx context.Context) (market *Market, accountIndex int, err error) // Retrieves all the markets that are open for trading GetTradableMarkets(ctx context.Context) ([]Market, error) // Retrieves all the markets GetAllMarkets(ctx context.Context) ([]Market, error) // Updates the state of a market. In order to be flexible for many use case and to manage // at an higher level the possible errors, an update closure function shall be passed UpdateMarket( ctx context.Context, accountIndex int, updateFn func(m *Market) (*Market, error), ) error // Open and close trading activities for a market with the given quote asset hash OpenMarket(ctx context.Context, accountIndex int) error CloseMarket(ctx context.Context, accountIndex int) error // Update only the price without touching market details UpdatePrices(ctx context.Context, accountIndex int, prices Prices) error // DeleteMarket deletes market for accountIndex DeleteMarket(ctx context.Context, accountIndex int) error }
MarketRepository defines the abstraction for Market
type MnemonicStore ¶ added in v0.3.0
MnemonicStore defines the required methods to override the default storage of the plaintext mnemonic once Unlocking a Vault. At the moment this is achieved by storing the mnemonic in the in-memory pkg/config store. Soon this will be changed since this package shouldn't depend on config.
type OutpointWithAsset ¶
OutpointWithAsset contains the transaction outpoint (tx hash and vout) along with the asset hash
type PluggableStrategy ¶ added in v0.4.4
type PluggableStrategy struct{}
func (PluggableStrategy) FormulaType ¶ added in v0.4.4
func (s PluggableStrategy) FormulaType() int
func (PluggableStrategy) InGivenOut ¶ added in v0.4.4
func (s PluggableStrategy) InGivenOut(_opts interface{}, amountOut uint64) (uint64, error)
func (PluggableStrategy) OutGivenIn ¶ added in v0.4.4
func (s PluggableStrategy) OutGivenIn(_opts interface{}, amountIn uint64) (uint64, error)
type PluggableStrategyOpts ¶ added in v0.4.4
type PreviewInfo ¶ added in v0.4.4
PreviewInfo contains info about a price preview based on the market's current strategy.
type Prices ¶
type Prices struct { // how much 1 base asset is valued in quote asset. BasePrice decimal.Decimal // how much 1 quote asset is valued in base asset QuotePrice decimal.Decimal }
Prices ...
type PsetParser ¶ added in v0.3.0
type PsetParser interface { GetTxID(psetBase64 string) (string, error) GetTxHex(psetBase64 string) (string, error) }
PsetParser defines the required methods to override the extraction of the txid and of the final transaction in hex format from the PSET one. The default one comes from go-elements.
type SwapAccept ¶ added in v0.3.0
type SwapAccept interface { GetId() string GetRequestId() string GetTransaction() string GetInputBlindingKey() map[string][]byte GetOutputBlindingKey() map[string][]byte }
SwapAccept is the abstracted representation of a SwapAccept message.
type SwapComplete ¶ added in v0.3.0
SwapComplete is the abstracted representation of a SwapComplete message.
type SwapError ¶ added in v0.3.0
SwapError is the special error returned by the ISwapParser when serializing a swap message.
type SwapFail ¶ added in v0.3.0
type SwapFail interface { GetId() string GetMessageId() string GetFailureCode() uint32 GetFailureMessage() string }
SwapFail is the abstracted representation of a SwapFail message.
type SwapParser ¶ added in v0.3.0
type SwapParser interface { SerializeRequest(r SwapRequest) ([]byte, *SwapError) SerializeAccept(args AcceptArgs) (string, []byte, *SwapError) SerializeComplete(accMsg []byte, tx string) (string, []byte, *SwapError) SerializeFail(id string, code int, msg string) (string, []byte) DeserializeRequest(msg []byte) (SwapRequest, error) DeserializeAccept(msg []byte) (SwapAccept, error) DeserializeComplete(msg []byte) (SwapComplete, error) DeserializeFail(msg []byte) (SwapFail, error) }
SwapParser defines the required methods to override the default swap message parser, which is grpc-proto.
type SwapRequest ¶ added in v0.3.0
type SwapRequest interface { GetId() string GetAssetP() string GetAmountP() uint64 GetAssetR() string GetAmountR() uint64 GetTransaction() string GetInputBlindingKey() map[string][]byte GetOutputBlindingKey() map[string][]byte }
SwapRequest is the abstracted representation of a SwapRequest message.
type Trade ¶
type Trade struct { ID uuid.UUID MarketBaseAsset string MarketQuoteAsset string MarketPrice Prices MarketFee int64 MarketFixedBaseFee int64 MarketFixedQuoteFee int64 TraderPubkey []byte Status Status PsetBase64 string TxID string TxHex string ExpiryTime uint64 SettlementTime uint64 SwapRequest Swap SwapAccept Swap SwapComplete Swap SwapFail Swap }
Trade is the data structure representing a trade entity.
func (*Trade) Accept ¶
func (t *Trade) Accept( psetBase64 string, inputBlindingKeys, outputBlindingKeys map[string][]byte, expiryDuration uint64, ) (bool, error)
Accept brings a trade from the Proposal to the Accepted status by validating the provided arguemtn against the the SwapRequest message and sets its expiration time.
func (*Trade) Complete ¶
func (t *Trade) Complete(tx string) (*CompleteResult, error)
Complete brings a trade from the Accepted to the Completed status by checking that the given PSET completes the one of the SwapAccept message and by finalizing it and extracting the raw tx in hex format. Complete must be called before the trade expires, otherwise it won't be possible to actually complete an accepted trade.
func (*Trade) ContainsSwap ¶
ContainsSwap returns whether a swap identified by its id belongs to the current trade.
func (*Trade) Expire ¶ added in v0.3.0
Expire brings the trade to the Expired status if its expiration date was previosly set. This infers that it must be in any of the Accepted, Completed, or related failed statuses. This method makes also sure that the expiration date has passed before changing the status.
func (*Trade) Fail ¶
Fail marks the current status of the trade as Failed and adds the SwapFail message.
func (*Trade) IsAccepted ¶
IsAccepted returns whether the trade is in Accepted status.
func (*Trade) IsCompleted ¶
IsCompleted returns whether the trade is in Completed status.
func (*Trade) IsExpired ¶
IsExpired returns whether the trade is in Expired status, or if its expiration date has passed.
func (*Trade) IsProposal ¶
IsProposal returns whether the trade is in Proposal status.
func (*Trade) IsRejected ¶
IsRejected returns whether the trade has failed.
func (*Trade) Propose ¶
func (t *Trade) Propose( swapRequest SwapRequest, marketBaseAsset, marketQuoteAsset string, marketFee, fixedBaseFee, fixedQuoteFee int64, traderPubkey []byte, ) (bool, error)
Propose brings an Empty trade to the Propose status by first validating the provided arguments.
func (*Trade) Settle ¶ added in v0.1.2
Settle brings the trade from the Completed to the Settled status, unsets the expiration time and adds the timestamp of the settlement (it must be a blocktime).
func (*Trade) SwapAcceptMessage ¶
func (t *Trade) SwapAcceptMessage() SwapAccept
SwapAcceptMessage returns the deserialized swap accept message, if defined.
func (*Trade) SwapCompleteMessage ¶
func (t *Trade) SwapCompleteMessage() SwapComplete
SwapCompleteMessage returns the deserialized swap complete message, if defined.
func (*Trade) SwapFailMessage ¶
SwapFailMessage returns the deserialized swap fail message, if defined.
func (*Trade) SwapRequestMessage ¶
func (t *Trade) SwapRequestMessage() SwapRequest
SwapRequestMessage returns the deserialized swap request message.
type TradeRepository ¶
type TradeRepository interface { // GetOrCreateTrade returns the trade with the given tradeID, or create a // new empty one if not found. GetOrCreateTrade(ctx context.Context, tradeID *uuid.UUID) (*Trade, error) // GetAllTrades returns all the trades stored in the repository. GetAllTrades(ctx context.Context) ([]*Trade, error) // GetAllTrades returns a page containg a subset of all trades stored in the // repository. GetAllTradesForPage(ctx context.Context, page Page) ([]*Trade, error) // GetAllTradesByMarket returns all the trades filtered by a market // identified by its quote asset. GetAllTradesByMarket( ctx context.Context, marketQuoteAsset string, ) ([]*Trade, error) // GetAllTradesByMarketAndPage returns a page containing a subset of all // trades filtered by a market identified by its quote asset. GetAllTradesByMarketAndPage( ctx context.Context, marketQuoteAsset string, page Page, ) ([]*Trade, error) // GetCompletedTradesByMarket returns all the Completed or Settled trades // for the provided market identified by its quote asset. GetCompletedTradesByMarket( ctx context.Context, marketQuoteAsset string, ) ([]*Trade, error) // GetCompletedTradesByMarketAndPage returns a page containing a subset of // all Completed or Settled trades for the provided market identified by // its quote asset. GetCompletedTradesByMarketAndPage( ctx context.Context, marketQuoteAsset string, page Page, ) ([]*Trade, error) // GetTradeBySwapAcceptID returns the trade that contains the SwapAccept // message matching the given id. GetTradeBySwapAcceptID(ctx context.Context, swapAcceptID string) (*Trade, error) // GetTradeByTxID returns the trade which transaction matches the given // transaction id. GetTradeByTxID(ctx context.Context, txID string) (*Trade, error) // UpdateTrade allowa to commit multiple changes to the same trade in a // transactional way. UpdateTrade( ctx context.Context, tradeID *uuid.UUID, updateFn func(t *Trade) (*Trade, error), ) error }
TradeRepository is the abstraction for any kind of database intended to persist Trades.
type Unspent ¶
type Unspent struct { TxID string VOut uint32 Value uint64 AssetHash string ValueCommitment string AssetCommitment string ValueBlinder []byte AssetBlinder []byte ScriptPubKey []byte Nonce []byte RangeProof []byte SurjectionProof []byte Address string Spent bool Locked bool LockedBy *uuid.UUID Confirmed bool }
Unspent is the data structure representing an Elements based UTXO with some other information like whether it is spent/unspent, confirmed/unconfirmed or locked/unlocked.
func (*Unspent) IsConfirmed ¶
IsConfirmed returns whether the unspent is already confirmed.
func (*Unspent) IsKeyEqual ¶
func (u *Unspent) IsKeyEqual(key UnspentKey) bool
IsKeyEqual returns whether the provided UnspentKey matches that or the current unspent.
func (*Unspent) IsLocked ¶
IsLocked returns whether the unspent is already locked - used in some not yet broadcasted trade.
func (*Unspent) Key ¶
func (u *Unspent) Key() UnspentKey
Key returns the UnspentKey of the current unspent.
func (*Unspent) Lock ¶
Lock marks the current unspent as locked, referring to some trade by its UUID.
func (*Unspent) ToOutpointWithAsset ¶ added in v0.3.0
func (u *Unspent) ToOutpointWithAsset() OutpointWithAsset
type UnspentKey ¶
UnspentKey represent the ID of an Unspent, composed by its txid and vout.
type UnspentRepository ¶
type UnspentRepository interface { // AddUnspents adds the provided unspents to the repository. Those already // existing won't be re-added AddUnspents(ctx context.Context, unspents []Unspent) (int, error) // GetAllUnspents returns the entire UTXO set, included those locked or // already spent. GetAllUnspents(ctx context.Context) []Unspent // GetAvailableUnspents returns all unlocked unspent UTXOs. GetAvailableUnspents(ctx context.Context) ([]Unspent, error) // GetAllUnspentsForAddresses returns the entire UTXO set (locked and spent // included) for the provided list of addresses. GetAllUnspentsForAddresses(ctx context.Context, addresses []string) ([]Unspent, error) // GetAllUnspentsForAddressesAndPage returns a subset of the entire UTXO set // (locked and spent included) for the provided list of addresses. GetAllUnspentsForAddressesAndPage(ctx context.Context, addresses []string, page Page) ([]Unspent, error) // GetUnspentsForAddresses returns the list of all unspent UTXOs for the // provided list of address (locked unspents included). GetUnspentsForAddresses(ctx context.Context, addresses []string) ([]Unspent, error) // GetAvailableUnspentsForAddresses returns the list of spendable UTXOs for the // provided list of addresses (locked unspents excluded). GetAvailableUnspentsForAddresses(ctx context.Context, addresses []string) ([]Unspent, error) // GetBalance returns the current balance of a certain asset for the provided // list of addresses (locked unspents included) GetBalance(ctx context.Context, addresses []string, assetHash string) (uint64, error) // GetUnlockedBalance returns the current balance of a certain asset for the // provided list of addresses (locked unspents exlcuded). GetUnlockedBalance(ctx context.Context, addresses []string, assetHash string) (uint64, error) // SpendUnspents let mark the provided list of unspent UTXOs (identified by their // keys) as spent. SpendUnspents(ctx context.Context, unspentKeys []UnspentKey) (int, error) // ConfirmUnspents let mark the provided list of unconfirmed unspent UTXOs as // confirmed. ConfirmUnspents(ctx context.Context, unspentKeys []UnspentKey) (int, error) // LockUnspents let lock the provided list of unlocked, unspent UTXOs, // referring to a certain trade by its UUID. LockUnspents(ctx context.Context, unspentKeys []UnspentKey, tradeID uuid.UUID) (int, error) // UnlockUnspents let unlock the provided list of locked, unspent UTXOs. UnlockUnspents(ctx context.Context, unspentKeys []UnspentKey) (int, error) }
UnspentRepository is the abstraction for any kind of database intended to persist Unspents.
type Vault ¶
type Vault struct { EncryptedMnemonic string PassphraseHash []byte Accounts map[int]*Account AccountAndKeyByAddress map[string]AccountAndKey Network *network.Network }
func NewVault ¶
NewVault encrypts the provided mnemonic with the passhrase and returns a new Vault initialized with the encrypted mnemonic and the hash of the passphrase. The Vault is locked by default since it is initialized without the mnemonic in plain text
func (*Vault) AccountByAddress ¶
AccountByAddress returns the account to which the provided address belongs
func (*Vault) AccountByIndex ¶
AccountByIndex returns the account with the given index
func (*Vault) AllDerivedAddressesInfo ¶
func (v *Vault) AllDerivedAddressesInfo() AddressesInfo
AllDerivedAddressesInfo returns the info of all the external and internal addresses derived by the daemon. This method does not require the Vault to be unlocked since it does not make use of the mnemonic in plain text. The info returned for each address are the account index, the derivation path, and the private blinding key.
func (*Vault) AllDerivedAddressesInfoForAccount ¶ added in v0.3.0
func (v *Vault) AllDerivedAddressesInfoForAccount( accountIndex int, ) (AddressesInfo, error)
AllDerivedAddressesInfoForAccount returns info about all the external and internal addresses derived for the provided account.
func (*Vault) AllDerivedExternalAddressesInfoForAccount ¶ added in v0.3.0
func (v *Vault) AllDerivedExternalAddressesInfoForAccount( accountIndex int, ) (AddressesInfo, error)
AllDerivedExternalAddressesInfoForAccount returns info about all external addresses derived for the provided account.
func (*Vault) ChangePassphrase ¶
ChangePassphrase attempts to unlock the
func (*Vault) DeriveNextExternalAddressForAccount ¶
func (v *Vault) DeriveNextExternalAddressForAccount(accountIndex int) (*AddressInfo, error)
DeriveNextExternalAddressForAccount returns the next unused address, the corresponding output script, the blinding key.
func (*Vault) DeriveNextInternalAddressForAccount ¶
func (v *Vault) DeriveNextInternalAddressForAccount(accountIndex int) (*AddressInfo, error)
DeriveNextInternalAddressForAccount returns the next unused change address for the provided account and the corresponding output script
func (*Vault) GetMnemonicSafe ¶
GetMnemonicSafe is getter for Vault's mnemonic in plain text
func (*Vault) InitAccount ¶
InitAccount creates a new account in the current Vault if not existing
func (*Vault) IsInitialized ¶ added in v0.3.0
IsInitialized returnes whether the Vault has been inizitialized
func (*Vault) IsLocked ¶ added in v0.3.0
IsLocked returns whether the Vault is initialized and locked
type VaultRepository ¶
type VaultRepository interface { // GetOrCreateVault returns the Vault stored in the repo. If not yet created, // a new one is created the provided mnemonic, passphrase, and network. GetOrCreateVault( ctx context.Context, mnemonic []string, passphrase string, network *network.Network, ) (*Vault, error) // GetAccountByIndex returns the account with the given index, if it // exists. GetAccountByIndex(ctx context.Context, accountIndex int) (*Account, error) // GetAccountByAddress returns the account with the given index, if it // exists. GetAccountByAddress(ctx context.Context, addr string) (*Account, int, error) // GetAllDerivedAddressesInfoForAccount returns the list of info about all // external and internal (change) addresses derived for the provided account. GetAllDerivedAddressesInfoForAccount( ctx context.Context, accountIndex int, ) (AddressesInfo, error) // GetDerivationPathByScript returns the derivation paths for the given account // index and the given list of scripts. GetDerivationPathByScript( ctx context.Context, accountIndex int, scripts []string, ) (map[string]string, error) // GetAllDerivedExternalAddressesInfoForAccount returns info about all receiving // addresses derived for the provided account so far. GetAllDerivedExternalAddressesInfoForAccount( ctx context.Context, accountIndex int, ) (AddressesInfo, error) // UpdateVault is the method allowing to make multiple changes to a vault in // a transactional way. UpdateVault( ctx context.Context, updateFn func(v *Vault) (*Vault, error), ) error }
VaultRepository is the abstraction for any kind of database intended to persist a Vault.
type Withdrawal ¶ added in v0.6.0
type Withdrawal struct { TxID string AccountIndex int BaseAmount uint64 QuoteAmount uint64 MillisatPerByte int64 Address string Timestamp uint64 }
Withdrawal is used to follow funds withdrawal statistics
type WithdrawalRepository ¶ added in v0.6.0
type WithdrawalRepository interface { // AddWithdrawals adds the provided withdrawals to the repository. Those already // existing won't be re-added. AddWithdrawals(ctx context.Context, withdrawals []Withdrawal) (int, error) // ListWithdrawalsForAccount returns the list with the withdrawals related to // the given wallet account id. ListWithdrawalsForAccount( ctx context.Context, accountIndex int, ) ([]Withdrawal, error) // ListWithdrawalsForAccountAndPage returns a page containing a subset of the // list with the withdrawals related to the given wallet account id. ListWithdrawalsForAccountAndPage( ctx context.Context, accountIndex int, page Page, ) ([]Withdrawal, error) // ListAllWithdrawals returns all withdrawals related to all wallet accounts // stored in the repository. ListAllWithdrawals(ctx context.Context) ([]Withdrawal, error) // ListAllWithdrawalsForPage returns a page containing a subset of all // withdrawals related to all wallet accounts stored in the repository. ListAllWithdrawalsForPage(ctx context.Context, page Page) ([]Withdrawal, error) }
WithdrawalRepository is the abstraction to which all concrete implementations must sitck with to persist withdrawals.
Source Files ¶
- constants.go
- deposit_model.go
- deposit_repository.go
- errors.go
- market_model.go
- market_repository.go
- market_service.go
- page_model.go
- pluggable_strategy.go
- trade_model.go
- trade_repository.go
- trade_service.go
- unspent_model.go
- unspent_repository.go
- unspent_service.go
- vault_model.go
- vault_repository.go
- vault_service.go
- withdrawal_model.go
- withdrawal_repository.go