Documentation ¶
Overview ¶
Package types is for types that are shared by multiple packages
Index ¶
Constants ¶
This section is empty.
Variables ¶
var (
// CurOfferVersion is the latest supported version of a serialised Offer struct
CurOfferVersion, _ = semver.NewVersion("1.0.0")
)
var EmptyHash = Hash{}
EmptyHash is an empty Hash
var EthAssetETH = EthAsset(ethcommon.Address{})
EthAssetETH describes regular ETH (rather than an ERC-20 token)
Functions ¶
func IsHashZero ¶
IsHashZero returns true if the hash is all zeros, otherwise false
Types ¶
type EthAsset ¶
EthAsset represents an Ethereum asset (ETH or a token address)
func (EthAsset) MarshalText ¶
MarshalText returns the hex representation of the EthAsset or, in some cases, a short string.
func (EthAsset) String ¶
String implements fmt.Stringer, returning the asset's address in hex prefixed by `ERC20@` if it's an ERC20 token, or ETH for ether.
func (*EthAsset) UnmarshalText ¶
UnmarshalText assigns the EthAsset from the input text
type Offer ¶
type Offer struct { Version semver.Version `json:"version"` ID Hash `json:"offerID" validate:"required"` Provides coins.ProvidesCoin `json:"provides" validate:"required"` MinAmount *apd.Decimal `json:"minAmount" validate:"required"` // Min XMR amount MaxAmount *apd.Decimal `json:"maxAmount" validate:"required"` // Max XMR amount ExchangeRate *coins.ExchangeRate `json:"exchangeRate" validate:"required"` EthAsset EthAsset `json:"ethAsset"` Nonce uint64 `json:"nonce" validate:"required"` }
Offer represents a swap offer
func NewOffer ¶
func NewOffer( coin coins.ProvidesCoin, minAmount *apd.Decimal, maxAmount *apd.Decimal, exRate *coins.ExchangeRate, ethAsset EthAsset, ) *Offer
NewOffer creates and returns an Offer with an initialised ID and Version fields
func UnmarshalOffer ¶
UnmarshalOffer deserializes a JSON offer, checking the version for compatibility before attempting to deserialize the whole blob.
func (*Offer) MarshalJSON ¶
MarshalJSON provides JSON marshalling for the Offer type
func (*Offer) UnmarshalJSON ¶
UnmarshalJSON provides JSON unmarshalling the Offer type
type OfferExtra ¶
type OfferExtra struct { StatusCh chan Status `json:"-"` UseRelayer bool `json:"useRelayer,omitempty"` }
OfferExtra represents extra data that is passed when an offer is made.
type Status ¶
type Status byte
Status represents the stage that a swap is at.
const ( // UnknownStatus is a placeholder for unmatched status strings and // uninitialized variables UnknownStatus Status = iota // ExpectingKeys is the status of the taker between taking an offer and // receiving a response with swap keys from the maker. It is also the // maker's status after creating an offer up until receiving keys from a // taker accepting the offer. ExpectingKeys // KeysExchanged is the status of the maker after a taker accepts his offer. KeysExchanged // ETHLocked is the taker status after locking her ETH up until confirming // that the maker locked his XMR. ETHLocked // XMRLocked is the maker's state after locking the XMR up until he confirms // that the the taker has set the contract to ready. XMRLocked // ContractReady is the taker's state after verifying the locked XMR and // setting the contract to ready. ContractReady // CompletedSuccess represents a successful swap. CompletedSuccess // CompletedRefund represents a swap that was refunded. CompletedRefund // CompletedAbort represents the case where the swap aborts before any funds // are locked. CompletedAbort )
Status values
func NewStatus ¶
NewStatus returns a Status from the given string. If there is no match, it returns UnknownStatus
func (Status) Description ¶
Description returns a description of the swap stage.
func (Status) MarshalText ¶
MarshalText implements the encoding.TextMarshaler interface.
func (*Status) UnmarshalText ¶
UnmarshalText implements the encoding.TextUnmarshaler interface.