Documentation ¶
Index ¶
- Constants
- Variables
- func ConvertAndEncode(hrp string, data []byte) (string, error)
- func CosmosPrivateKeyToTMPrivateKey(privateKey cryptotypes.PrivKey) crypto.PrivKey
- func Entropy(b []byte) float64
- func GetMedianInt64(vals []int64) int64
- func GetMedianUint(vals []cosmos.Uint) cosmos.Uint
- func GetSafeShare(part, total, allocation cosmos.Uint) cosmos.Uint
- func GetUncappedShare(part, total, allocation cosmos.Uint) (share cosmos.Uint)
- func RandHexString(n int) string
- func RoundSignificantFigures(number uint64, significantDigits int64) uint64
- func SafeSub(input1, input2 cosmos.Uint) cosmos.Uint
- func Sign(buf []byte) ([]byte, []byte, error)
- func SignBase64(buf []byte) (string, string, error)
- func WeightedMean(vals, weights []cosmos.Uint) (cosmos.Uint, error)
- type Account
- type Address
- func (addr Address) AccAddress() (cosmos.AccAddress, error)
- func (addr Address) Equals(addr2 Address) bool
- func (addr Address) GetChain() Chain
- func (addr Address) GetNetwork(ver semver.Version, chain Chain) ChainNetwork
- func (addr Address) IsChain(chain Chain) bool
- func (addr Address) IsEmpty() bool
- func (addr Address) IsNoop() bool
- func (addr Address) IsValidBCHAddress() bool
- func (addr Address) String() string
- type AddressSuite
- type Asset
- func BEP2RuneAsset() Asset
- func ERC20RuneAsset() Asset
- func NewAsset(input string) (Asset, error)
- func NewAssetWithShortCodes(version semver.Version, input string) (Asset, error)
- func NewAssetWithShortCodesV115(input string) (Asset, error)
- func NewAssetWithShortCodesV124(input string) (Asset, error)
- func RuneAsset() Asset
- func (*Asset) Descriptor() ([]byte, []int)
- func (a Asset) Equals(a2 Asset) bool
- func (a Asset) GetChain() Chain
- func (a Asset) GetDerivedAsset() Asset
- func (a Asset) GetLayer1Asset() Asset
- func (a Asset) GetSyntheticAsset() Asset
- func (a Asset) GetTradeAsset() Asset
- func (a Asset) IsBNB() bool
- func (a Asset) IsDerivedAsset() bool
- func (a Asset) IsEmpty() bool
- func (a Asset) IsGasAsset() bool
- func (a Asset) IsNative() bool
- func (a Asset) IsNativeRune() bool
- func (a Asset) IsRune() bool
- func (a Asset) IsSyntheticAsset() bool
- func (a Asset) IsTradeAsset() bool
- func (a Asset) IsVaultAsset() bool
- func (m *Asset) Marshal() (dAtA []byte, err error)
- func (a Asset) MarshalJSON() ([]byte, error)
- func (a Asset) MarshalJSONPB(*jsonpb.Marshaler) ([]byte, error)
- func (m *Asset) MarshalTo(dAtA []byte) (int, error)
- func (m *Asset) MarshalToSizedBuffer(dAtA []byte) (int, error)
- func (a Asset) MimirString() string
- func (a Asset) Native() string
- func (*Asset) ProtoMessage()
- func (m *Asset) Reset()
- func (a Asset) ShortCode() string
- func (m *Asset) Size() (n int)
- func (a Asset) String() string
- func (m *Asset) Unmarshal(dAtA []byte) error
- func (a *Asset) UnmarshalJSON(data []byte) error
- func (a *Asset) UnmarshalJSONPB(unmarshal *jsonpb.Unmarshaler, content []byte) error
- func (m *Asset) XXX_DiscardUnknown()
- func (m *Asset) XXX_Marshal(b []byte, deterministic bool) ([]byte, error)
- func (m *Asset) XXX_Merge(src proto.Message)
- func (m *Asset) XXX_Size() int
- func (m *Asset) XXX_Unmarshal(b []byte) error
- type Chain
- func (c Chain) AddressPrefix(cn ChainNetwork) string
- func (c Chain) ApproximateBlockMilliseconds() int64
- func (c Chain) DefaultCoinbase() float64
- func (c Chain) DustThreshold() cosmos.Uint
- func (c Chain) Equals(c2 Chain) bool
- func (c Chain) GetGasAsset() Asset
- func (c Chain) GetGasAssetDecimal() int64
- func (c Chain) GetGasUnits() string
- func (c Chain) GetSigningAlgo() SigningAlgo
- func (c Chain) InboundNotes() string
- func (c Chain) IsBNB() bool
- func (c Chain) IsBSCChain() bool
- func (c Chain) IsEVM() bool
- func (c Chain) IsEmpty() bool
- func (c Chain) IsTHORChain() bool
- func (c Chain) IsUTXO() bool
- func (c Chain) IsValidAddress(addr Address) bool
- func (c Chain) MaxMemoLength() int
- func (c Chain) String() string
- func (c Chain) Validate() error
- type ChainNetwork
- type ChainPoolInfo
- type Chains
- type Coin
- func (*Coin) Descriptor() ([]byte, []int)
- func (c Coin) Equals(cc Coin) bool
- func (c Coin) IsEmpty() bool
- func (c Coin) IsNative() bool
- func (m *Coin) Marshal() (dAtA []byte, err error)
- func (m *Coin) MarshalTo(dAtA []byte) (int, error)
- func (m *Coin) MarshalToSizedBuffer(dAtA []byte) (int, error)
- func (c Coin) Native() (cosmos.Coin, error)
- func (*Coin) ProtoMessage()
- func (m *Coin) Reset()
- func (m *Coin) Size() (n int)
- func (c Coin) String() string
- func (m *Coin) Unmarshal(dAtA []byte) error
- func (c Coin) Valid() error
- func (c Coin) WithDecimals(decimal int64) Coin
- func (m *Coin) XXX_DiscardUnknown()
- func (m *Coin) XXX_Marshal(b []byte, deterministic bool) ([]byte, error)
- func (m *Coin) XXX_Merge(src proto.Message)
- func (m *Coin) XXX_Size() int
- func (m *Coin) XXX_Unmarshal(b []byte) error
- type Coins
- func (oldCoins Coins) Add(addCoins ...Coin) Coins
- func (cs Coins) Add_deprecated(coin Coin) Coins
- func (cs Coins) Adds_deprecated(coins Coins) Coins
- func (cs Coins) Contains(c Coin) bool
- func (cs Coins) Copy() Coins
- func (cs Coins) Distinct() Coins
- func (cs Coins) EqualsEx(cs2 Coins) bool
- func (cs Coins) Equals_deprecated(cs2 Coins) bool
- func (cs Coins) GetCoin(asset Asset) Coin
- func (cs Coins) HasNoneNativeRune() bool
- func (cs Coins) HasSynthetic() bool
- func (cs Coins) IsEmpty() bool
- func (cs Coins) Native() (cosmos.Coins, error)
- func (cs Coins) NoneEmpty() Coins
- func (oldCoins Coins) SafeSub(subCoins ...Coin) Coins
- func (cs Coins) SafeSub_deprecated(coin Coin) Coins
- func (cs Coins) String() string
- func (cs Coins) Valid() error
- type Fee
- func (*Fee) Descriptor() ([]byte, []int)
- func (m *Fee) Marshal() (dAtA []byte, err error)
- func (m *Fee) MarshalTo(dAtA []byte) (int, error)
- func (m *Fee) MarshalToSizedBuffer(dAtA []byte) (int, error)
- func (*Fee) ProtoMessage()
- func (m *Fee) Reset()
- func (m *Fee) Size() (n int)
- func (f Fee) String() string
- func (m *Fee) Unmarshal(dAtA []byte) error
- func (m *Fee) XXX_DiscardUnknown()
- func (m *Fee) XXX_Marshal(b []byte, deterministic bool) ([]byte, error)
- func (m *Fee) XXX_Merge(src proto.Message)
- func (m *Fee) XXX_Size() int
- func (m *Fee) XXX_Unmarshal(b []byte) error
- type Gas
- type Invariant
- type InvariantRoute
- type ProtoUint
- func (*ProtoUint) Descriptor() ([]byte, []int)
- func (m *ProtoUint) Marshal() (dAtA []byte, err error)
- func (m *ProtoUint) MarshalTo(dAtA []byte) (int, error)
- func (m *ProtoUint) MarshalToSizedBuffer(dAtA []byte) (int, error)
- func (*ProtoUint) ProtoMessage()
- func (m *ProtoUint) Reset()
- func (m *ProtoUint) Size() (n int)
- func (this *ProtoUint) String() string
- func (m *ProtoUint) Unmarshal(dAtA []byte) error
- func (m *ProtoUint) XXX_DiscardUnknown()
- func (m *ProtoUint) XXX_Marshal(b []byte, deterministic bool) ([]byte, error)
- func (m *ProtoUint) XXX_Merge(src proto.Message)
- func (m *ProtoUint) XXX_Size() int
- func (m *ProtoUint) XXX_Unmarshal(b []byte) error
- type PubKey
- func (pubKey PubKey) EVMPubkeyToAddress() (Address, error)
- func (pubKey PubKey) Equals(pubKey1 PubKey) bool
- func (pubKey PubKey) GetAddress(chain Chain) (Address, error)
- func (pubKey PubKey) GetThorAddress() (cosmos.AccAddress, error)
- func (pubKey PubKey) IsEmpty() bool
- func (pubKey PubKey) MarshalJSON() ([]byte, error)
- func (pubKey PubKey) String() string
- func (pubKey *PubKey) UnmarshalJSON(data []byte) error
- type PubKeySet
- func (pks PubKeySet) Contains(pk PubKey) bool
- func (*PubKeySet) Descriptor() ([]byte, []int)
- func (pks PubKeySet) Equals(pks1 PubKeySet) bool
- func (pks PubKeySet) GetAddress(chain Chain) (Address, error)
- func (pks PubKeySet) IsEmpty() bool
- func (m *PubKeySet) Marshal() (dAtA []byte, err error)
- func (m *PubKeySet) MarshalTo(dAtA []byte) (int, error)
- func (m *PubKeySet) MarshalToSizedBuffer(dAtA []byte) (int, error)
- func (*PubKeySet) ProtoMessage()
- func (m *PubKeySet) Reset()
- func (m *PubKeySet) Size() (n int)
- func (pks PubKeySet) String() string
- func (m *PubKeySet) Unmarshal(dAtA []byte) error
- func (m *PubKeySet) XXX_DiscardUnknown()
- func (m *PubKeySet) XXX_Marshal(b []byte, deterministic bool) ([]byte, error)
- func (m *PubKeySet) XXX_Merge(src proto.Message)
- func (m *PubKeySet) XXX_Size() int
- func (m *PubKeySet) XXX_Unmarshal(b []byte) error
- type PubKeys
- type SigningAlgo
- type Symbol
- type Ticker
- type Tickers
- type Tx
- func (*Tx) Descriptor() ([]byte, []int)
- func (tx Tx) Equals(tx2 Tx) bool
- func (tx Tx) EqualsEx(tx2 Tx) bool
- func (tx Tx) Hash() string
- func (tx Tx) Hash_deprecated() string
- func (tx Tx) IsEmpty() bool
- func (m *Tx) Marshal() (dAtA []byte, err error)
- func (m *Tx) MarshalTo(dAtA []byte) (int, error)
- func (m *Tx) MarshalToSizedBuffer(dAtA []byte) (int, error)
- func (*Tx) ProtoMessage()
- func (m *Tx) Reset()
- func (m *Tx) Size() (n int)
- func (tx Tx) String() string
- func (tx Tx) ToAttributes() []cosmos.Attribute
- func (m *Tx) Unmarshal(dAtA []byte) error
- func (tx Tx) Valid() error
- func (m *Tx) XXX_DiscardUnknown()
- func (m *Tx) XXX_Marshal(b []byte, deterministic bool) ([]byte, error)
- func (m *Tx) XXX_Merge(src proto.Message)
- func (m *Tx) XXX_Size() int
- func (m *Tx) XXX_Unmarshal(b []byte) error
- type TxID
- type TxIDs
- type Txs
Constants ¶
const ( NoAddress = Address("") NoopAddress = Address("noop") )
const ( EmptyChain = Chain("") BNBChain = Chain("BNB") BSCChain = Chain("BSC") ETHChain = Chain("ETH") BTCChain = Chain("BTC") LTCChain = Chain("LTC") BCHChain = Chain("BCH") DOGEChain = Chain("DOGE") THORChain = Chain("THOR") TERRAChain = Chain("TERRA") GAIAChain = Chain("GAIA") AVAXChain = Chain("AVAX") SigningAlgoSecp256k1 = SigningAlgo("secp256k1") SigningAlgoEd25519 = SigningAlgo("ed25519") )
const ( // BNBSymbol BNB BNBSymbol = Symbol("BNB") // Rune67CSymbol RUNE on binance testnet Rune67CSymbol = Symbol("RUNE-67C") // RuneB1ASymbol RUNE on binance mainnet RuneB1ASymbol = Symbol("RUNE-B1A") )
const CurrentChainNetwork = MainNet
const One = 100000000
One is useful type so THORNode doesn't need to manage 8 zeroes all the time
const THORChainDecimals = 8
THORChainDecimals indicate the number of decimal points used in THORChain
Variables ¶
var ( // EmptyAsset empty asset, not valid EmptyAsset = Asset{Chain: EmptyChain, Symbol: "", Ticker: "", Synth: false} // LUNAAsset LUNA LUNAAsset = Asset{Chain: TERRAChain, Symbol: "LUNA", Ticker: "LUNA", Synth: false} // ATOMAsset ATOM ATOMAsset = Asset{Chain: GAIAChain, Symbol: "ATOM", Ticker: "ATOM", Synth: false} // BNBAsset BNB BNBAsset = Asset{Chain: BNBChain, Symbol: "BNB", Ticker: "BNB", Synth: false} // BNBBEP20Asset BNB BNBBEP20Asset = Asset{Chain: BSCChain, Symbol: "BNB", Ticker: "BNB", Synth: false} // BTCAsset BTC BTCAsset = Asset{Chain: BTCChain, Symbol: "BTC", Ticker: "BTC", Synth: false} // LTCAsset BTC LTCAsset = Asset{Chain: LTCChain, Symbol: "LTC", Ticker: "LTC", Synth: false} // BCHAsset BCH BCHAsset = Asset{Chain: BCHChain, Symbol: "BCH", Ticker: "BCH", Synth: false} // DOGEAsset DOGE DOGEAsset = Asset{Chain: DOGEChain, Symbol: "DOGE", Ticker: "DOGE", Synth: false} // ETHAsset ETH ETHAsset = Asset{Chain: ETHChain, Symbol: "ETH", Ticker: "ETH", Synth: false} // AVAXAsset AVAX AVAXAsset = Asset{Chain: AVAXChain, Symbol: "AVAX", Ticker: "AVAX", Synth: false} // Rune67CAsset RUNE on Binance test net Rune67CAsset = Asset{Chain: BNBChain, Symbol: "RUNE-67C", Ticker: "RUNE", Synth: false} // mocknet asset on binance ganges // RuneB1AAsset RUNE on Binance main net RuneB1AAsset = Asset{Chain: BNBChain, Symbol: "RUNE-B1A", Ticker: "RUNE", Synth: false} // mainnet // RuneNative RUNE on thorchain RuneNative = Asset{Chain: THORChain, Symbol: "RUNE", Ticker: "RUNE", Synth: false} RuneERC20Asset = Asset{Chain: ETHChain, Symbol: "RUNE-0x3155ba85d5f96b2d030a4966af206230e46849cb", Ticker: "RUNE", Synth: false} RuneERC20MocknetAsset = Asset{Chain: ETHChain, Symbol: "RUNE-0xd601c6A3a36721320573885A8d8420746dA3d7A0", Ticker: "RUNE", Synth: false} TOR = Asset{Chain: THORChain, Symbol: "TOR", Ticker: "TOR", Synth: false} THORBTC = Asset{Chain: THORChain, Symbol: "BTC", Ticker: "BTC", Synth: false} )
var ( ErrInvalidLengthCommon = fmt.Errorf("proto: negative length found during unmarshaling") ErrIntOverflowCommon = fmt.Errorf("proto: integer overflow") ErrUnexpectedEndOfGroupCommon = fmt.Errorf("proto: unexpected end of group") )
var ( EmptyPubKey PubKey EmptyPubKeySet PubKeySet )
var AllChains = [...]Chain{ BNBChain, BSCChain, ETHChain, BTCChain, LTCChain, BCHChain, DOGEChain, THORChain, TERRAChain, GAIAChain, AVAXChain, }
var BNBGasFeeMulti = Gas{ {Asset: BNBAsset, Amount: bnbMultiTxFee}, }
BNBGasFeeMulti gas fee for multi send
var BNBGasFeeSingleton = Gas{ {Asset: BNBAsset, Amount: bnbSingleTxFee}, }
BNBGasFeeSingleton fee charged by Binance for transfer with a single coin
var BlankTxID = TxID("0000000000000000000000000000000000000000000000000000000000000000")
BlankTxID represent blank
var LatestVersion semver.Version = semver.MustParse("999.0.0")
var NoCoin = Coin{ Asset: EmptyAsset, Amount: cosmos.ZeroUint(), }
NoCoin is empty Coin
Functions ¶
func ConvertAndEncode ¶
ConvertAndEncode converts from a base64 encoded byte string to hex or base32 encoded byte string and then to bech32
func CosmosPrivateKeyToTMPrivateKey ¶ added in v0.41.0
func CosmosPrivateKeyToTMPrivateKey(privateKey cryptotypes.PrivKey) crypto.PrivKey
CosmosPrivateKeyToTMPrivateKey convert cosmos implementation of private key to tendermint private key
func GetMedianInt64 ¶ added in v1.121.0
func GetSafeShare ¶ added in v0.63.0
GetSafeShare does the same as GetUncappedShare , but GetSafeShare will guarantee the result will not more than total. The first two arguments should always have the same units (cancelling out to represent a unitless ratio applied to the allocation).
func GetUncappedShare ¶ added in v1.93.0
GetUncappedShare this method will panic if any of the input parameter can't be convert to cosmos.Dec which shouldn't happen. The first two arguments should always have the same units (cancelling out to represent a unitless ratio applied to the allocation).
func RandHexString ¶ added in v1.124.0
RandHexString generates random hex string used for test purpose
func RoundSignificantFigures ¶ added in v1.116.0
RoundSignificantFigures rounds an unsigned 64-bit integer to the specified number of significant digits. It takes the number and significant digits as arguments.
func SafeSub ¶
SafeSub subtract input2 from input1, given cosmos.Uint can't be negative , otherwise it will panic thus in this method,when input2 is larger than input 1, it will just return cosmos.ZeroUint
Types ¶
type Address ¶
type Address string
func ConvertToNewBCHAddressFormat ¶ added in v0.54.0
ConvertToNewBCHAddressFormat convert the given BCH to new address format
func ConvertToNewBCHAddressFormatV83 ¶ added in v1.83.0
ConvertToNewBCHAddressFormatV83 convert the given BCH to new address format
func NewAddress ¶
NewAddress create a new Address. Supports Binance, Bitcoin, and Ethereum
func (Address) AccAddress ¶ added in v0.41.0
func (addr Address) AccAddress() (cosmos.AccAddress, error)
func (Address) GetChain ¶ added in v0.41.0
Note that this will always return ETHChain for an AVAXChain address, so perhaps only use it when determining a network (e.g. mainnet/testnet).
func (Address) GetNetwork ¶ added in v0.54.0
func (addr Address) GetNetwork(ver semver.Version, chain Chain) ChainNetwork
func (Address) IsChain ¶
Note that this can have false positives, such as being unable to distinguish between ETH and AVAX.
func (Address) IsValidBCHAddress ¶ added in v0.54.0
IsValidBCHAddress determinate whether the address is a valid new BCH address format
type AddressSuite ¶ added in v1.105.0
type AddressSuite struct{}
func (*AddressSuite) TestAddress ¶ added in v1.105.0
func (s *AddressSuite) TestAddress(c *C)
func (*AddressSuite) TestConvertToNewBCHAddressFormat ¶ added in v1.105.0
func (s *AddressSuite) TestConvertToNewBCHAddressFormat(c *C)
type Asset ¶
type Asset struct { Chain Chain `protobuf:"bytes,1,opt,name=chain,proto3,casttype=Chain" json:"chain,omitempty"` Symbol Symbol `protobuf:"bytes,2,opt,name=symbol,proto3,casttype=Symbol" json:"symbol,omitempty"` Ticker Ticker `protobuf:"bytes,3,opt,name=ticker,proto3,casttype=Ticker" json:"ticker,omitempty"` Synth bool `protobuf:"varint,4,opt,name=synth,proto3" json:"synth,omitempty"` Trade bool `protobuf:"varint,5,opt,name=trade,proto3" json:"trade,omitempty"` }
func NewAssetWithShortCodes ¶ added in v1.115.0
func NewAssetWithShortCodesV115 ¶ added in v1.124.0
func NewAssetWithShortCodesV124 ¶ added in v1.124.0
func RuneAsset ¶
func RuneAsset() Asset
RuneAsset return RUNE Asset depends on different environment
func (*Asset) Descriptor ¶ added in v0.41.0
func (Asset) GetDerivedAsset ¶ added in v1.121.0
Get derived asset of asset
func (Asset) GetLayer1Asset ¶ added in v0.41.0
Get layer1 asset version
func (Asset) GetSyntheticAsset ¶ added in v0.41.0
Get synthetic asset of asset
func (Asset) GetTradeAsset ¶ added in v1.128.0
Get trade asset of asset
func (Asset) IsDerivedAsset ¶ added in v1.121.0
Check if asset is a derived asset
func (Asset) IsGasAsset ¶ added in v0.41.0
IsGasAsset check whether asset is base asset used to pay for gas
func (Asset) IsNative ¶ added in v1.121.0
IsNative is a helper function, returns true when the asset is a native asset to THORChain (ie rune, a synth, etc)
func (Asset) IsNativeRune ¶ added in v0.41.0
IsNativeRune is a helper function, return true only when the asset represent NATIVE RUNE
func (Asset) IsSyntheticAsset ¶ added in v0.41.0
Check if asset is a pegged asset
func (Asset) IsTradeAsset ¶ added in v1.128.0
func (Asset) IsVaultAsset ¶ added in v1.121.0
func (Asset) MarshalJSON ¶
MarshalJSON implement Marshaler interface
func (Asset) MarshalJSONPB ¶ added in v0.41.0
MarshalJSONPB implement jsonpb.Marshaler
func (*Asset) MarshalToSizedBuffer ¶ added in v0.41.0
func (Asset) MimirString ¶ added in v1.121.0
Replace pool name "." with a "-" for Mimir key checking.
func (*Asset) ProtoMessage ¶ added in v0.41.0
func (*Asset) ProtoMessage()
func (*Asset) UnmarshalJSON ¶
UnmarshalJSON implement Unmarshaler interface
func (*Asset) UnmarshalJSONPB ¶ added in v0.41.0
func (a *Asset) UnmarshalJSONPB(unmarshal *jsonpb.Unmarshaler, content []byte) error
UnmarshalJSONPB implement jsonpb.Unmarshaler
func (*Asset) XXX_DiscardUnknown ¶ added in v0.41.0
func (m *Asset) XXX_DiscardUnknown()
func (*Asset) XXX_Marshal ¶ added in v0.41.0
func (*Asset) XXX_Unmarshal ¶ added in v0.41.0
type Chain ¶
type Chain string
func GetEVMChains ¶ added in v1.95.0
func GetEVMChains() []Chain
GetEVMChains returns all "EVM" chains connected to THORChain "EVM" is defined, in thornode's context, as a chain that: - uses 0x as an address prefix - has a "Router" Smart Contract
func GetUTXOChains ¶ added in v1.113.1
func GetUTXOChains() []Chain
GetUTXOChains returns all "UTXO" chains connected to THORChain.
func (Chain) AddressPrefix ¶
func (c Chain) AddressPrefix(cn ChainNetwork) string
AddressPrefix return the address prefix used by the given network (mocknet/mainnet)
func (Chain) ApproximateBlockMilliseconds ¶ added in v1.99.0
func (Chain) DefaultCoinbase ¶ added in v1.99.0
DefaultCoinbase returns the default coinbase address for each chain, returns 0 if no coinbase emission is used. This is used used at the time of writing as a fallback value in Bifrost, and for inbound confirmation count estimates in the quote APIs.
func (Chain) DustThreshold ¶ added in v1.99.0
DustThreshold returns the min dust threshold for each chain The min dust threshold defines the lower end of the withdraw range of memoless savers txs The native coin value provided in a memoless tx defines a basis points amount of Withdraw or Add to a savers position as follows: Withdraw range: (dust_threshold + 1) -> (dust_threshold + 10_000) Add range: dust_threshold -> Inf NOTE: these should all be in 8 decimal places
func (Chain) GetGasAssetDecimal ¶ added in v0.80.0
GetGasAssetDecimal for the gas asset of given chain , what kind of precision it is using TERRA and GAIA are using 1E6, all other gas asset so far using 1E8 THORChain is using 1E8, if an external chain's gas asset is larger than 1E8, just return cosmos.DefaultCoinDecimals
func (Chain) GetGasUnits ¶ added in v1.97.0
GetGasUnits returns name of the gas unit for each chain
func (Chain) GetSigningAlgo ¶
func (c Chain) GetSigningAlgo() SigningAlgo
GetSigningAlgo get the signing algorithm for the given chain
func (Chain) InboundNotes ¶ added in v1.103.0
func (Chain) IsBSCChain ¶ added in v1.124.0
func (Chain) IsEVM ¶ added in v1.95.0
IsEVM returns true if given chain is an EVM chain. See working definition of an "EVM" chain in the `GetEVMChains` function description
func (Chain) IsTHORChain ¶ added in v0.41.0
func (Chain) IsValidAddress ¶ added in v0.54.0
IsValidAddress make sure the address is correct for the chain And this also make sure mocknet doesn't use mainnet address vice versa
func (Chain) MaxMemoLength ¶ added in v1.99.0
MaxMemoLength returns the max memo length for each chain.
type ChainNetwork ¶
type ChainNetwork uint8
ChainNetwork is to indicate which chain environment THORNode are working with
const ( // TestNet network for test - DO NOT USE // TODO: remove on hard fork TestNet ChainNetwork = iota // MainNet network for mainnet MainNet // MockNet network for mocknet MockNet // Stagenet network for stagenet StageNet )
func (ChainNetwork) SoftEquals ¶ added in v0.54.0
func (net ChainNetwork) SoftEquals(net2 ChainNetwork) bool
Soft Equals check is mainnet == mainet, or mocknet == mocknet
type ChainPoolInfo ¶
type ChainPoolInfo struct { Chain Chain `json:"chain"` PubKey PubKey `json:"pub_key"` PoolAddress Address `json:"pool_address"` }
ChainPoolInfo represent the pool address specific for a chain
var EmptyChainPoolInfo ChainPoolInfo
EmptyChainPoolInfo everything is empty
func NewChainPoolInfo ¶
func NewChainPoolInfo(chain Chain, pubKey PubKey) (ChainPoolInfo, error)
NewChainPoolInfo create a new instance of ChainPoolInfo
func (ChainPoolInfo) IsEmpty ¶
func (cpi ChainPoolInfo) IsEmpty() bool
IsEmpty whether the struct is empty
type Chains ¶
type Chains []Chain
Chains represent a slice of Chain
type Coin ¶
type Coin struct { Asset Asset `protobuf:"bytes,1,opt,name=asset,proto3" json:"asset"` Amount github_com_cosmos_cosmos_sdk_types.Uint `protobuf:"bytes,2,opt,name=amount,proto3,customtype=github.com/cosmos/cosmos-sdk/types.Uint" json:"amount"` Decimals int64 `protobuf:"varint,3,opt,name=decimals,proto3" json:"decimals,omitempty"` }
func (*Coin) Descriptor ¶ added in v0.41.0
func (*Coin) MarshalToSizedBuffer ¶ added in v0.41.0
func (*Coin) ProtoMessage ¶ added in v0.41.0
func (*Coin) ProtoMessage()
func (Coin) WithDecimals ¶ added in v0.41.0
WithDecimals update coin with a decimal
func (*Coin) XXX_DiscardUnknown ¶ added in v0.41.0
func (m *Coin) XXX_DiscardUnknown()
func (*Coin) XXX_Marshal ¶ added in v0.41.0
func (*Coin) XXX_Unmarshal ¶ added in v0.41.0
type Coins ¶
type Coins []Coin
Coins represent a slice of Coin
func (Coins) Add_deprecated ¶ added in v1.129.0
This overwrites cs by changing its slice-referenced values (when and only when there is a shared Asset), so it is recommended to use destination := NewCoins(source...) first. NOTE: **DEPRECATED** - do not use. TODO: remove usage of this on hard fork.
func (Coins) Adds_deprecated ¶ added in v1.121.0
This overwrites cs by changing its slice-referenced values, so it is recommended to use destination := NewCoins(source...) first. NOTE: **DEPRECATED** - do not use. TODO: remove usage of this on hard fork.
func (Coins) Distinct ¶ added in v0.41.0
Distinct return a new Coins ,which duplicated coins had been removed
func (Coins) EqualsEx ¶ added in v0.65.0
EqualsEx Check if two lists of coins are equal to each other. This method will make a copy of cs1 & cs2 , thus the original coins order will not be changed
func (Coins) Equals_deprecated ¶ added in v1.121.0
Equals checks if two lists of coins are equal to each other - order does not matter. This method has a side effect of sorting the input parameters. Since this is already used, it cannot be changed without causing consensus failure. TODO: Deprecated, remove on hard fork.
func (Coins) GetCoin ¶
GetCoin gets a specific coin by asset. Assumes there is only one of this coin in the list.
func (Coins) HasNoneNativeRune ¶ added in v0.41.0
HasNoneNativeRune check whether the coins contains NoneNativeRUNE
At the moment, there are BEP2 RUNE, ERC20 RUNE and Native RUNE
func (Coins) HasSynthetic ¶ added in v0.55.0
HasSynthetic check whether the coins contains synth coin
func (Coins) NoneEmpty ¶ added in v0.54.0
NoneEmpty return a new Coins , which ignore the coin that is empty either Coin asset is empty or amount is empty
func (Coins) SafeSub_deprecated ¶ added in v1.129.0
This overwrites cs by changing its slice-referenced values, so it is recommended to use destination := NewCoins(source...) first. NOTE: **DEPRECATED** - do not use. TODO: remove usage of this on hard fork.
type Fee ¶
type Fee struct { Coins Coins `protobuf:"bytes,1,rep,name=coins,proto3,castrepeated=Coins" json:"coins"` PoolDeduct github_com_cosmos_cosmos_sdk_types.Uint `` /* 132-byte string literal not displayed */ }
func (*Fee) Descriptor ¶ added in v0.41.0
func (*Fee) MarshalToSizedBuffer ¶ added in v0.41.0
func (*Fee) ProtoMessage ¶ added in v0.41.0
func (*Fee) ProtoMessage()
func (*Fee) XXX_DiscardUnknown ¶ added in v0.41.0
func (m *Fee) XXX_DiscardUnknown()
func (*Fee) XXX_Marshal ¶ added in v0.41.0
func (*Fee) XXX_Unmarshal ¶ added in v0.41.0
type Gas ¶
type Gas Coins
Gas coins
func CalcBinanceGasPrice ¶
CalcBinanceGasPrice calculate gas price for Binance chain
func GetEVMGasFee ¶ added in v1.111.0
func (Gas) Adds_deprecated ¶ added in v1.129.0
Add combines two gas objects into one, adding amounts where needed or appending new coins. **WARNING**: dangerous, returns self-reference and also self-modifies
func (Gas) Equals ¶
Equals Check if two lists of coins are equal to each other. Order does not matter
func (Gas) NoneEmpty ¶ added in v1.122.0
NoneEmpty returns a new Gas which ignores any coin which is empty either Coin asset is empty or amount is empty
type Invariant ¶ added in v1.117.0
An Invariant is a function which tests a particular invariant. The invariant returns a descriptive message about what happened and a boolean indicating whether the invariant has been broken.
type InvariantRoute ¶ added in v1.117.0
invariant route
func NewInvariantRoute ¶ added in v1.117.0
func NewInvariantRoute(route string, invariant Invariant) InvariantRoute
NewInvariantRoute - create an InvariantRoute object
type ProtoUint ¶ added in v1.121.0
type ProtoUint struct {
Value github_com_cosmos_cosmos_sdk_types.Uint `protobuf:"bytes,1,opt,name=value,proto3,customtype=github.com/cosmos/cosmos-sdk/types.Uint" json:"value"`
}
func (*ProtoUint) Descriptor ¶ added in v1.121.0
func (*ProtoUint) MarshalToSizedBuffer ¶ added in v1.121.0
func (*ProtoUint) ProtoMessage ¶ added in v1.121.0
func (*ProtoUint) ProtoMessage()
func (*ProtoUint) XXX_DiscardUnknown ¶ added in v1.121.0
func (m *ProtoUint) XXX_DiscardUnknown()
func (*ProtoUint) XXX_Marshal ¶ added in v1.121.0
func (*ProtoUint) XXX_Unmarshal ¶ added in v1.121.0
type PubKey ¶
type PubKey string
PubKey used in thorchain, it should be bech32 encoded string thus it will be something like tthorpub1addwnpepqt7qug8vk9r3saw8n4r803ydj2g3dqwx0mvq5akhnze86fc536xcycgtrnv tthorpub1addwnpepqdqvd4r84lq9m54m5kk9sf4k6kdgavvch723pcgadulxd6ey9u70k6zq8qe
func NewPubKeyFromCrypto ¶
NewPubKeyFromCrypto
func (PubKey) EVMPubkeyToAddress ¶ added in v1.95.0
EVMPubkeyToAddress converts a pubkey of an EVM chain to the corresponding address
func (PubKey) GetAddress ¶
GetAddress will return an address for the given chain
func (PubKey) GetThorAddress ¶
func (pubKey PubKey) GetThorAddress() (cosmos.AccAddress, error)
func (PubKey) MarshalJSON ¶
MarshalJSON to Marshals to JSON using Bech32
func (*PubKey) UnmarshalJSON ¶
UnmarshalJSON to Unmarshal from JSON assuming Bech32 encoding
type PubKeySet ¶
type PubKeySet struct { Secp256k1 PubKey `protobuf:"bytes,1,opt,name=secp256k1,proto3,casttype=PubKey" json:"secp256k1,omitempty"` Ed25519 PubKey `protobuf:"bytes,2,opt,name=ed25519,proto3,casttype=PubKey" json:"ed25519,omitempty"` }
PubKeySet contains two pub keys , secp256k1 and ed25519
func NewPubKeySet ¶
NewPubKeySet create a new instance of PubKeySet , which contains two keys
func (*PubKeySet) Descriptor ¶ added in v0.41.0
func (PubKeySet) GetAddress ¶
GetAddress
func (*PubKeySet) MarshalToSizedBuffer ¶ added in v0.41.0
func (*PubKeySet) ProtoMessage ¶ added in v0.41.0
func (*PubKeySet) ProtoMessage()
func (*PubKeySet) XXX_DiscardUnknown ¶ added in v0.41.0
func (m *PubKeySet) XXX_DiscardUnknown()
func (*PubKeySet) XXX_Marshal ¶ added in v0.41.0
func (*PubKeySet) XXX_Unmarshal ¶ added in v0.41.0
type PubKeys ¶
type PubKeys []PubKey
PubKey used in thorchain, it should be bech32 encoded string thus it will be something like tthorpub1addwnpepqt7qug8vk9r3saw8n4r803ydj2g3dqwx0mvq5akhnze86fc536xcycgtrnv tthorpub1addwnpepqdqvd4r84lq9m54m5kk9sf4k6kdgavvch723pcgadulxd6ey9u70k6zq8qe
func (PubKeys) Addresses ¶ added in v1.120.0
func (pks PubKeys) Addresses() ([]cosmos.AccAddress, error)
type SigningAlgo ¶ added in v1.83.0
type SigningAlgo string
type Symbol ¶
type Symbol string
Symbol represent an asset
func (Symbol) IsMiniToken ¶
IsMiniToken is to determine whether it is a mini token on binance chain
type Ticker ¶
type Ticker string
Ticker The trading 'symbol' or shortened name (typically in capital letters) that refer to a coin on a trading platform. For example: BNB
func NewTicker ¶
NewTicker parse the given string as ticker, return error if it is not legitimate ticker
type Tx ¶
type Tx struct { ID TxID `protobuf:"bytes,1,opt,name=id,proto3,casttype=TxID" json:"id,omitempty"` Chain Chain `protobuf:"bytes,2,opt,name=chain,proto3,casttype=Chain" json:"chain,omitempty"` FromAddress Address `protobuf:"bytes,3,opt,name=from_address,json=fromAddress,proto3,casttype=Address" json:"from_address,omitempty"` ToAddress Address `protobuf:"bytes,4,opt,name=to_address,json=toAddress,proto3,casttype=Address" json:"to_address,omitempty"` Coins Coins `protobuf:"bytes,5,rep,name=coins,proto3,castrepeated=Coins" json:"coins"` Gas Gas `protobuf:"bytes,6,rep,name=gas,proto3,castrepeated=Gas" json:"gas"` Memo string `protobuf:"bytes,7,opt,name=memo,proto3" json:"memo,omitempty"` }
func GetRagnarokTx ¶
GetRagnarokTx return a tx used for ragnarok
func (*Tx) Descriptor ¶ added in v0.41.0
func (Tx) Equals ¶
Equals compares two Txs to see whether they represent the same Tx. This method has a side effect of sorting the input parameters. Since this is already used, it cannot be changed without causing consensus failure. TODO: Deprecated, remove on hard fork.
func (Tx) EqualsEx ¶ added in v0.65.0
EqualsEx compare two Tx to see whether they represent the same Tx This method will not change the original tx & tx2
func (Tx) Hash_deprecated ¶ added in v1.131.0
TODO: Remove on hard fork. Hash_deprecated calculates a hash only based on from address and to address
func (*Tx) MarshalToSizedBuffer ¶ added in v0.41.0
func (*Tx) ProtoMessage ¶ added in v0.41.0
func (*Tx) ProtoMessage()
func (Tx) ToAttributes ¶
ToAttributes push all the tx fields into a slice of cosmos Attribute(key value pairs)
func (Tx) Valid ¶
Valid do some data sanity check , if the tx contains invalid information it will return an none nil error
func (*Tx) XXX_DiscardUnknown ¶ added in v0.41.0
func (m *Tx) XXX_DiscardUnknown()
func (*Tx) XXX_Marshal ¶ added in v0.41.0
func (*Tx) XXX_Unmarshal ¶ added in v0.41.0
type TxID ¶
type TxID string
TxID is a string that can uniquely represent a transaction on different block chain
Source Files ¶
- account.go
- address.go
- address_test_mainnet.go
- asset.go
- asset_archive.go
- chain.go
- chain_network.go
- chain_network_mainnet.go
- coin.go
- common.go
- common.pb.go
- entropy.go
- fee.go
- gas.go
- invariant.go
- math.go
- pubkey.go
- random_string.go
- sign.go
- significant_figures.go
- symbol.go
- ticker.go
- tx.go
- type_chain_pool_addr.go
- type_convert.go