Documentation ¶
Index ¶
- func AssetFromContractData(ledgerEntry xdr.LedgerEntry, passphrase string) *xdr.Asset
- func AssetToContractData(isNative bool, code, issuer string, contractID [32]byte) (xdr.LedgerEntryData, error)
- func BalanceToContractData(assetContractId, holderID [32]byte, amt uint64) xdr.LedgerEntryData
- func ContractBalanceFromContractData(ledgerEntry xdr.LedgerEntry, passphrase string) ([32]byte, *big.Int, bool)
- func EncodeOfferId(id uint64, typ OfferIDType) int64
- func ParticipantsForTransaction(sequence uint32, transaction ingest.LedgerTransaction) ([]xdr.AccountId, error)
- func PoolIDToString(id xdr.PoolId) string
- func StreamChanges(ctx context.Context, changeProcessor ChangeProcessor, ...) error
- func StreamLedgerTransactions(ctx context.Context, txFilterer LedgerTransactionFilterer, ...) error
- type AccountDataProcessor
- type AccountsProcessor
- type AssetStatSet
- func (s AssetStatSet) AddClaimableBalance(change ingest.Change) error
- func (s AssetStatSet) AddContractData(change ingest.Change) error
- func (s AssetStatSet) AddLiquidityPool(change ingest.Change) error
- func (s AssetStatSet) AddTrustline(change ingest.Change) error
- func (s AssetStatSet) All() ([]history.ExpAssetStat, map[[32]byte]*xdr.Asset, ...)
- func (s AssetStatSet) AllFromSnapshot() ([]history.ExpAssetStat, error)
- type AssetStatsProcessor
- type ChangeProcessor
- type ClaimableBalancesChangeProcessor
- type ClaimableBalancesTransactionProcessor
- type EffectProcessor
- type LedgerTransactionFilterer
- type LedgerTransactionProcessor
- type LedgersProcessor
- type LiquidityPoolsChangeProcessor
- type LiquidityPoolsTransactionProcessor
- type MockChangeProcessor
- type OfferIDType
- type OffersProcessor
- type OperationProcessor
- type ParticipantsProcessor
- type SignersProcessor
- type StatsLedgerTransactionProcessor
- func (p *StatsLedgerTransactionProcessor) Flush(ctx context.Context, session db.SessionInterface) error
- func (p *StatsLedgerTransactionProcessor) GetResults() StatsLedgerTransactionProcessorResults
- func (p *StatsLedgerTransactionProcessor) ProcessTransaction(lcm xdr.LedgerCloseMeta, transaction ingest.LedgerTransaction) error
- func (p *StatsLedgerTransactionProcessor) ResetStats()
- type StatsLedgerTransactionProcessorResults
- type TradeProcessor
- type TradeStats
- type TransactionProcessor
- type TrustLinesProcessor
Constants ¶
This section is empty.
Variables ¶
This section is empty.
Functions ¶
func AssetFromContractData ¶
func AssetFromContractData(ledgerEntry xdr.LedgerEntry, passphrase string) *xdr.Asset
AssetFromContractData takes a ledger entry and verifies if the ledger entry corresponds to the asset info entry written to contract storage by the Stellar Asset Contract upon initialization.
Note that AssetFromContractData will ignore forged asset info entries by deriving the Stellar Asset Contract ID from the asset info entry and comparing it to the contract ID found in the ledger entry.
If the given ledger entry is a verified asset info entry, AssetFromContractData will return the corresponding Stellar asset. Otherwise, it returns nil.
References: https://github.com/stellar/rs-soroban-env/blob/v0.0.16/soroban-env-host/src/native_contract/token/public_types.rs#L21 https://github.com/stellar/rs-soroban-env/blob/v0.0.16/soroban-env-host/src/native_contract/token/asset_info.rs#L6 https://github.com/stellar/rs-soroban-env/blob/v0.0.16/soroban-env-host/src/native_contract/token/contract.rs#L115
The asset info in `ContractData` entry takes the following form:
Instance storage - it's part of contract instance data storage
Key: a vector with one element, which is the symbol "AssetInfo"
ScVal{ Vec: ScVec({ ScVal{ Sym: ScSymbol("AssetInfo") }})}
Value: a map with two key-value pairs: code and issuer
ScVal{ Map: ScMap( { ScVal{ Sym: ScSymbol("asset_code") } -> ScVal{ Str: ScString(...) } }, { ScVal{ Sym: ScSymbol("issuer") } -> ScVal{ Bytes: ScBytes(...) } } )}
func AssetToContractData ¶
func AssetToContractData(isNative bool, code, issuer string, contractID [32]byte) (xdr.LedgerEntryData, error)
AssetToContractData is the inverse of AssetFromContractData. It creates a ledger entry containing the asset info entry written to contract storage by the Stellar Asset Contract.
Warning: Only for use in tests. This does not set a realistic expirationLedgerSeq
func BalanceToContractData ¶
func BalanceToContractData(assetContractId, holderID [32]byte, amt uint64) xdr.LedgerEntryData
BalanceToContractData is the inverse of ContractBalanceFromContractData. It creates a ledger entry containing the asset balance of a contract holder written to contract storage by the Stellar Asset Contract.
Warning: Only for use in tests. This does not set a realistic expirationLedgerSeq
func ContractBalanceFromContractData ¶
func ContractBalanceFromContractData(ledgerEntry xdr.LedgerEntry, passphrase string) ([32]byte, *big.Int, bool)
ContractBalanceFromContractData takes a ledger entry and verifies that the ledger entry corresponds to the balance entry written to contract storage by the Stellar Asset Contract.
Reference:
https://github.com/stellar/rs-soroban-env/blob/da325551829d31dcbfa71427d51c18e71a121c5f/soroban-env-host/src/native_contract/token/storage_types.rs#L11-L24
func EncodeOfferId ¶
func EncodeOfferId(id uint64, typ OfferIDType) int64
EncodeOfferId creates synthetic offer ids to be used by trade resources
This is required because stellar-core does not allocate offer ids for immediately filled offers, while clients expect them for aggregated views.
The encoded value is of type int64 for sql compatibility. The 2nd bit is used to differentiate between stellar-core offer ids and operation ids, which are toids.
Due to the 2nd bit being used, the largest possible toid is: 0011111111111111111111111111111100000000000000000001000000000001 \ ledger /\ transaction /\ op /
= 1073741823 with avg. 5 sec close time will reach in ~170 years
func PoolIDToString ¶
PoolIDToString encodes a liquidity pool id xdr value to its string form
func StreamChanges ¶
func StreamChanges( ctx context.Context, changeProcessor ChangeProcessor, reader ingest.ChangeReader, ) error
func StreamLedgerTransactions ¶
func StreamLedgerTransactions( ctx context.Context, txFilterer LedgerTransactionFilterer, filteredTxProcessor LedgerTransactionProcessor, txProcessor LedgerTransactionProcessor, reader *ingest.LedgerTransactionReader, ledger xdr.LedgerCloseMeta, ) error
Types ¶
type AccountDataProcessor ¶
type AccountDataProcessor struct {
// contains filtered or unexported fields
}
func NewAccountDataProcessor ¶
func NewAccountDataProcessor(dataQ history.QData) *AccountDataProcessor
func (*AccountDataProcessor) Commit ¶
func (p *AccountDataProcessor) Commit(ctx context.Context) error
func (*AccountDataProcessor) ProcessChange ¶
type AccountsProcessor ¶
type AccountsProcessor struct {
// contains filtered or unexported fields
}
func NewAccountsProcessor ¶
func NewAccountsProcessor(accountsQ history.QAccounts) *AccountsProcessor
func (*AccountsProcessor) ProcessChange ¶
type AssetStatSet ¶
type AssetStatSet struct {
// contains filtered or unexported fields
}
AssetStatSet represents a collection of asset stats and a mapping of Soroban contract IDs to classic assets (which is unique to each network).
func NewAssetStatSet ¶
func NewAssetStatSet(networkPassphrase string) AssetStatSet
NewAssetStatSet constructs a new AssetStatSet instance
func (AssetStatSet) AddClaimableBalance ¶
func (s AssetStatSet) AddClaimableBalance(change ingest.Change) error
AddClaimableBalance updates the set to account for how a given claimable balance has changed. change must be a xdr.LedgerEntryTypeClaimableBalance type.
func (AssetStatSet) AddContractData ¶
func (s AssetStatSet) AddContractData(change ingest.Change) error
AddContractData updates the set to account for how a given contract data entry has changed. change must be a xdr.LedgerEntryTypeContractData type.
func (AssetStatSet) AddLiquidityPool ¶
func (s AssetStatSet) AddLiquidityPool(change ingest.Change) error
AddLiquidityPool updates the set to account for how a given liquidity pool has changed. change must be a xdr.LedgerEntryTypeLiqidityPool type.
func (AssetStatSet) AddTrustline ¶
func (s AssetStatSet) AddTrustline(change ingest.Change) error
AddTrustline updates the set to account for how a given trustline has changed. change must be a xdr.LedgerEntryTypeTrustLine type.
func (AssetStatSet) All ¶
func (s AssetStatSet) All() ([]history.ExpAssetStat, map[[32]byte]*xdr.Asset, map[[32]byte]contractAssetStatValue)
All returns a list of all `history.ExpAssetStat` contained within the set along with all contract id attribution changes in the set.
func (AssetStatSet) AllFromSnapshot ¶
func (s AssetStatSet) AllFromSnapshot() ([]history.ExpAssetStat, error)
AllFromSnapshot returns a list of all `history.ExpAssetStat` contained within the set. AllFromSnapshot should only be invoked when the AssetStatSet has been derived from ledger entry changes consisting of only inserts (no updates) reflecting the current state of the ledger without any missing entries (e.g. history archives).
type AssetStatsProcessor ¶
type AssetStatsProcessor struct {
// contains filtered or unexported fields
}
func NewAssetStatsProcessor ¶
func NewAssetStatsProcessor( assetStatsQ history.QAssetStats, networkPassphrase string, useLedgerEntryCache bool, ) *AssetStatsProcessor
NewAssetStatsProcessor constructs a new AssetStatsProcessor instance. If useLedgerEntryCache is false we don't use ledger cache and we just add trust lines to assetStatSet, then we insert all the stats in one insert query. This is done to make history buckets processing faster (batch inserting).
func (*AssetStatsProcessor) Commit ¶
func (p *AssetStatsProcessor) Commit(ctx context.Context) error
func (*AssetStatsProcessor) ProcessChange ¶
type ChangeProcessor ¶
type ClaimableBalancesChangeProcessor ¶
type ClaimableBalancesChangeProcessor struct {
// contains filtered or unexported fields
}
func NewClaimableBalancesChangeProcessor ¶
func NewClaimableBalancesChangeProcessor(Q history.QClaimableBalances) *ClaimableBalancesChangeProcessor
func (*ClaimableBalancesChangeProcessor) Commit ¶
func (p *ClaimableBalancesChangeProcessor) Commit(ctx context.Context) error
func (*ClaimableBalancesChangeProcessor) ProcessChange ¶
type ClaimableBalancesTransactionProcessor ¶
type ClaimableBalancesTransactionProcessor struct {
// contains filtered or unexported fields
}
func NewClaimableBalancesTransactionProcessor ¶
func NewClaimableBalancesTransactionProcessor( cbLoader *history.ClaimableBalanceLoader, txBatch history.TransactionClaimableBalanceBatchInsertBuilder, opBatch history.OperationClaimableBalanceBatchInsertBuilder, ) *ClaimableBalancesTransactionProcessor
func (*ClaimableBalancesTransactionProcessor) Flush ¶
func (p *ClaimableBalancesTransactionProcessor) Flush(ctx context.Context, session db.SessionInterface) error
func (*ClaimableBalancesTransactionProcessor) ProcessTransaction ¶
func (p *ClaimableBalancesTransactionProcessor) ProcessTransaction( lcm xdr.LedgerCloseMeta, transaction ingest.LedgerTransaction, ) error
type EffectProcessor ¶
type EffectProcessor struct {
// contains filtered or unexported fields
}
EffectProcessor process effects
func NewEffectProcessor ¶
func NewEffectProcessor( accountLoader *history.AccountLoader, batch history.EffectBatchInsertBuilder, network string, ) *EffectProcessor
func (*EffectProcessor) Flush ¶
func (p *EffectProcessor) Flush(ctx context.Context, session db.SessionInterface) (err error)
func (*EffectProcessor) ProcessTransaction ¶
func (p *EffectProcessor) ProcessTransaction( lcm xdr.LedgerCloseMeta, transaction ingest.LedgerTransaction, ) error
type LedgerTransactionProcessor ¶
type LedgerTransactionProcessor interface { ProcessTransaction(lcm xdr.LedgerCloseMeta, transaction ingest.LedgerTransaction) error Flush(ctx context.Context, session db.SessionInterface) error }
type LedgersProcessor ¶
type LedgersProcessor struct {
// contains filtered or unexported fields
}
func NewLedgerProcessor ¶
func NewLedgerProcessor(batch history.LedgerBatchInsertBuilder, ingestVersion int) *LedgersProcessor
func (*LedgersProcessor) Flush ¶
func (p *LedgersProcessor) Flush(ctx context.Context, session db.SessionInterface) error
func (*LedgersProcessor) ProcessLedger ¶
func (p *LedgersProcessor) ProcessLedger(lcm xdr.LedgerCloseMeta) *ledgerInfo
func (*LedgersProcessor) ProcessTransaction ¶
func (p *LedgersProcessor) ProcessTransaction(lcm xdr.LedgerCloseMeta, transaction ingest.LedgerTransaction) error
type LiquidityPoolsChangeProcessor ¶
type LiquidityPoolsChangeProcessor struct {
// contains filtered or unexported fields
}
func NewLiquidityPoolsChangeProcessor ¶
func NewLiquidityPoolsChangeProcessor(Q history.QLiquidityPools, sequence uint32) *LiquidityPoolsChangeProcessor
func (*LiquidityPoolsChangeProcessor) Commit ¶
func (p *LiquidityPoolsChangeProcessor) Commit(ctx context.Context) error
func (*LiquidityPoolsChangeProcessor) ProcessChange ¶
type LiquidityPoolsTransactionProcessor ¶
type LiquidityPoolsTransactionProcessor struct {
// contains filtered or unexported fields
}
func NewLiquidityPoolsTransactionProcessor ¶
func NewLiquidityPoolsTransactionProcessor( lpLoader *history.LiquidityPoolLoader, txBatch history.TransactionLiquidityPoolBatchInsertBuilder, opBatch history.OperationLiquidityPoolBatchInsertBuilder, ) *LiquidityPoolsTransactionProcessor
func (*LiquidityPoolsTransactionProcessor) Flush ¶
func (p *LiquidityPoolsTransactionProcessor) Flush(ctx context.Context, session db.SessionInterface) error
func (*LiquidityPoolsTransactionProcessor) ProcessTransaction ¶
func (p *LiquidityPoolsTransactionProcessor) ProcessTransaction(lcm xdr.LedgerCloseMeta, transaction ingest.LedgerTransaction) error
type MockChangeProcessor ¶
func (*MockChangeProcessor) ProcessChange ¶
type OfferIDType ¶
type OfferIDType uint64
const ( CoreOfferIDType OfferIDType = 0 TOIDType OfferIDType = 1 )
func DecodeOfferID ¶
func DecodeOfferID(encodedId int64) (uint64, OfferIDType)
DecodeOfferID performs the reverse operation of EncodeOfferID
type OffersProcessor ¶
type OffersProcessor struct {
// contains filtered or unexported fields
}
func NewOffersProcessor ¶
func NewOffersProcessor(offersQ history.QOffers, sequence uint32) *OffersProcessor
func (*OffersProcessor) ProcessChange ¶
type OperationProcessor ¶
type OperationProcessor struct {
// contains filtered or unexported fields
}
OperationProcessor operations processor
func NewOperationProcessor ¶
func NewOperationProcessor(batch history.OperationBatchInsertBuilder, network string) *OperationProcessor
func (*OperationProcessor) Flush ¶
func (p *OperationProcessor) Flush(ctx context.Context, session db.SessionInterface) error
func (*OperationProcessor) ProcessTransaction ¶
func (p *OperationProcessor) ProcessTransaction(lcm xdr.LedgerCloseMeta, transaction ingest.LedgerTransaction) error
ProcessTransaction process the given transaction
type ParticipantsProcessor ¶
type ParticipantsProcessor struct {
// contains filtered or unexported fields
}
ParticipantsProcessor is a processor which ingests various participants from different sources (transactions, operations, etc)
func NewParticipantsProcessor ¶
func NewParticipantsProcessor( accountLoader *history.AccountLoader, txBatch history.TransactionParticipantsBatchInsertBuilder, opBatch history.OperationParticipantBatchInsertBuilder, ) *ParticipantsProcessor
func (*ParticipantsProcessor) Flush ¶
func (p *ParticipantsProcessor) Flush(ctx context.Context, session db.SessionInterface) error
func (*ParticipantsProcessor) ProcessTransaction ¶
func (p *ParticipantsProcessor) ProcessTransaction(lcm xdr.LedgerCloseMeta, transaction ingest.LedgerTransaction) error
type SignersProcessor ¶
type SignersProcessor struct {
// contains filtered or unexported fields
}
func NewSignersProcessor ¶
func NewSignersProcessor( signersQ history.QSigners, useLedgerEntryCache bool, ) *SignersProcessor
func (*SignersProcessor) ProcessChange ¶
type StatsLedgerTransactionProcessor ¶
type StatsLedgerTransactionProcessor struct {
// contains filtered or unexported fields
}
StatsLedgerTransactionProcessor is a state processors that counts number of changes types and entry types.
func NewStatsLedgerTransactionProcessor ¶
func NewStatsLedgerTransactionProcessor() *StatsLedgerTransactionProcessor
func (*StatsLedgerTransactionProcessor) Flush ¶
func (p *StatsLedgerTransactionProcessor) Flush(ctx context.Context, session db.SessionInterface) error
func (*StatsLedgerTransactionProcessor) GetResults ¶
func (p *StatsLedgerTransactionProcessor) GetResults() StatsLedgerTransactionProcessorResults
func (*StatsLedgerTransactionProcessor) ProcessTransaction ¶
func (p *StatsLedgerTransactionProcessor) ProcessTransaction(lcm xdr.LedgerCloseMeta, transaction ingest.LedgerTransaction) error
func (*StatsLedgerTransactionProcessor) ResetStats ¶
func (p *StatsLedgerTransactionProcessor) ResetStats()
type StatsLedgerTransactionProcessorResults ¶
type StatsLedgerTransactionProcessorResults struct { Transactions int64 TransactionsSuccessful int64 TransactionsFailed int64 TransactionsFiltered int64 Operations int64 OperationsInSuccessful int64 OperationsInFailed int64 OperationsCreateAccount int64 OperationsPayment int64 OperationsPathPaymentStrictReceive int64 OperationsManageSellOffer int64 OperationsCreatePassiveSellOffer int64 OperationsSetOptions int64 OperationsChangeTrust int64 OperationsAllowTrust int64 OperationsAccountMerge int64 OperationsInflation int64 OperationsManageData int64 OperationsBumpSequence int64 OperationsManageBuyOffer int64 OperationsPathPaymentStrictSend int64 OperationsCreateClaimableBalance int64 OperationsClaimClaimableBalance int64 OperationsBeginSponsoringFutureReserves int64 OperationsEndSponsoringFutureReserves int64 OperationsRevokeSponsorship int64 OperationsClawback int64 OperationsClawbackClaimableBalance int64 OperationsSetTrustLineFlags int64 OperationsLiquidityPoolDeposit int64 OperationsLiquidityPoolWithdraw int64 OperationsInvokeHostFunction int64 OperationsBumpFootprintExpiration int64 OperationsRestoreFootprint int64 }
StatsLedgerTransactionProcessorResults contains results after running StatsLedgerTransactionProcessor.
func (*StatsLedgerTransactionProcessorResults) Map ¶
func (stats *StatsLedgerTransactionProcessorResults) Map() map[string]interface{}
type TradeProcessor ¶
type TradeProcessor struct {
// contains filtered or unexported fields
}
TradeProcessor operations processor
func NewTradeProcessor ¶
func NewTradeProcessor( accountLoader *history.AccountLoader, lpLoader *history.LiquidityPoolLoader, assetLoader *history.AssetLoader, batch history.TradeBatchInsertBuilder, ) *TradeProcessor
func (*TradeProcessor) Flush ¶
func (p *TradeProcessor) Flush(ctx context.Context, session db.SessionInterface) error
func (*TradeProcessor) GetStats ¶
func (p *TradeProcessor) GetStats() TradeStats
func (*TradeProcessor) ProcessTransaction ¶
func (p *TradeProcessor) ProcessTransaction(lcm xdr.LedgerCloseMeta, transaction ingest.LedgerTransaction) (err error)
ProcessTransaction process the given transaction
func (*TradeProcessor) ResetStats ¶
func (p *TradeProcessor) ResetStats()
type TradeStats ¶
type TradeStats struct {
// contains filtered or unexported fields
}
func (*TradeStats) Map ¶
func (stats *TradeStats) Map() map[string]interface{}
type TransactionProcessor ¶
type TransactionProcessor struct {
// contains filtered or unexported fields
}
func NewTransactionFilteredTmpProcessor ¶
func NewTransactionFilteredTmpProcessor(batch history.TransactionBatchInsertBuilder) *TransactionProcessor
func NewTransactionProcessor ¶
func NewTransactionProcessor(batch history.TransactionBatchInsertBuilder) *TransactionProcessor
func (*TransactionProcessor) Flush ¶
func (p *TransactionProcessor) Flush(ctx context.Context, session db.SessionInterface) error
func (*TransactionProcessor) ProcessTransaction ¶
func (p *TransactionProcessor) ProcessTransaction(lcm xdr.LedgerCloseMeta, transaction ingest.LedgerTransaction) error
type TrustLinesProcessor ¶
type TrustLinesProcessor struct {
// contains filtered or unexported fields
}
func NewTrustLinesProcessor ¶
func NewTrustLinesProcessor(trustLinesQ history.QTrustLines) *TrustLinesProcessor
func (*TrustLinesProcessor) Commit ¶
func (p *TrustLinesProcessor) Commit(ctx context.Context) error
func (*TrustLinesProcessor) ProcessChange ¶
Source Files ¶
- account_data_processor.go
- accounts_processor.go
- asset_stats_processor.go
- asset_stats_set.go
- change_processors.go
- claimable_balances_change_processor.go
- claimable_balances_transaction_processor.go
- contract_data.go
- effects_processor.go
- ledgers_processor.go
- liquidity_pools_change_processor.go
- liquidity_pools_transaction_processor.go
- main.go
- mock_change_processor.go
- offers_processor.go
- operations_processor.go
- participants_processor.go
- signers_processor.go
- stats_ledger_transaction_processor.go
- synt_offer_id.go
- trades_processor.go
- transactions_processor.go
- trust_lines_processor.go