Documentation ¶
Index ¶
- Constants
- func AnalyzeAllTables(db *sql.DB, statisticsTarget int) error
- func AnalyzeTable(db *sql.DB, table string, statisticsTarget int) error
- func CheckBadBlockApproval(ctx context.Context, db *sql.DB) (hashes []string, approvals, disapprovals, totals []int16, ...)
- func CheckBadExpiredVotedTickets(ctx context.Context, db *sql.DB) (ids []uint64, txHashes []string, spendTypes []int16, err error)
- func CheckBadMissedVotedTickets(ctx context.Context, db *sql.DB) (ids []uint64, txHashes []string, spendTypes []int16, err error)
- func CheckBadSpentLiveTickets(ctx context.Context, db *sql.DB) (ids []uint64, txHashes []string, spendTypes []int16, err error)
- func CheckBadVotedTickets(ctx context.Context, db *sql.DB) (ids []uint64, txHashes []string, spendTypes []int16, err error)
- func CheckColumnDataType(db *sql.DB, table, column string) (dataType string, err error)
- func CheckCurrentTimeZone(db *sql.DB) (currentTZ string, err error)
- func CheckDefaultTimeZone(db *sql.DB) (defaultTZ, currentTZ string, err error)
- func CheckExtraMainchainBlocks(ctx context.Context, db *sql.DB) (ids, heights []uint64, hashes []string, err error)
- func CheckMislabeledInvalidBlocks(ctx context.Context, db *sql.DB) (ids []uint64, hashes []string, err error)
- func CheckMislabeledTicketTransactions(ctx context.Context, db *sql.DB) (ids []uint64, txTypes []int16, txHashes []string, err error)
- func CheckMissingTicketTransactions(ctx context.Context, db *sql.DB) (ids []uint64, txHashes []string, err error)
- func CheckMissingTickets(ctx context.Context, db *sql.DB) (ids []uint64, txTypes []int16, txHashes []string, err error)
- func CheckSpentTicketsWithoutSpendInfo(ctx context.Context, db *sql.DB) (ids, spendHeights, spendTxDbIDs []uint64, err error)
- func CheckUnmatchedSpending(ctx context.Context, db *sql.DB) (ids []uint64, addresses []string, err error)
- func CheckUnspentTicketsWithSpendInfo(ctx context.Context, db *sql.DB) (ids, spendHeights, spendTxDbIDs []uint64, err error)
- func ClearTestingTable(db *sql.DB) error
- func Connect(host, port, user, pass, dbname string) (*sql.DB, error)
- func CountMergedFundingTxns(ctx context.Context, db *sql.DB, address string) (count int64, err error)
- func CountMergedSpendingTxns(ctx context.Context, db *sql.DB, address string) (count int64, err error)
- func CountMergedTxns(ctx context.Context, db *sql.DB, address string) (count int64, err error)
- func CreateTable(db *sql.DB, tableName string) error
- func CreateTableLegacy(db *sql.DB, tableName string) error
- func CreateTables(db *sql.DB) error
- func CreateTablesLegacy(db *sql.DB) error
- func DBBestBlock(ctx context.Context, db *sql.DB) (hash string, height int64, err error)
- func DeindexAddressTableOnAddress(db *sql.DB) (err error)
- func DeindexAddressTableOnMatchingTxHash(db *sql.DB) (err error)
- func DeindexAddressTableOnTxHash(db *sql.DB) (err error)
- func DeindexAddressTableOnVoutID(db *sql.DB) (err error)
- func DeindexAgendaVotesTableOnAgendaID(db *sql.DB) (err error)
- func DeindexAgendasTableOnAgendaID(db *sql.DB) (err error)
- func DeindexBlockTableOnHash(db *sql.DB) (err error)
- func DeindexBlockTableOnHeight(db *sql.DB) (err error)
- func DeindexBlockTableOnTime(db *sql.DB) (err error)
- func DeindexBlockTimeOnTableAddress(db *sql.DB) (err error)
- func DeindexMissesTableOnHash(db *sql.DB) (err error)
- func DeindexProposalVotesTableOnProposalsID(db *sql.DB) (err error)
- func DeindexProposalsTableOnToken(db *sql.DB) (err error)
- func DeindexStatsTableOnHeight(db *sql.DB) (err error)
- func DeindexTicketsTableOnHashes(db *sql.DB) (err error)
- func DeindexTicketsTableOnPoolStatus(db *sql.DB) (err error)
- func DeindexTicketsTableOnTxDbID(db *sql.DB) (err error)
- func DeindexTransactionTableOnBlockHeight(db *sql.DB) (err error)
- func DeindexTransactionTableOnBlockIn(db *sql.DB) (err error)
- func DeindexTransactionTableOnHashes(db *sql.DB) (err error)
- func DeindexVinTableOnPrevOuts(db *sql.DB) (err error)
- func DeindexVinTableOnVins(db *sql.DB) (err error)
- func DeindexVotesTableOnBlockHash(db *sql.DB) (err error)
- func DeindexVotesTableOnBlockTime(db *sql.DB) (err error)
- func DeindexVotesTableOnCandidate(db *sql.DB) (err error)
- func DeindexVotesTableOnHash(db *sql.DB) (err error)
- func DeindexVotesTableOnHeight(db *sql.DB) (err error)
- func DeindexVotesTableOnVoteVersion(db *sql.DB) (err error)
- func DeindexVoutTableOnSpendTxID(db *sql.DB) (err error)
- func DeindexVoutTableOnTxHashIdx(db *sql.DB) (err error)
- func DeleteBestBlock(ctx context.Context, db *sql.DB) (res dbtypes.DeletionSummary, height int64, hash string, err error)
- func DeleteBlockData(ctx context.Context, db *sql.DB, hash string) (res dbtypes.DeletionSummary, err error)
- func DeleteBlocks(ctx context.Context, N int64, db *sql.DB) (res []dbtypes.DeletionSummary, height int64, hash string, err error)
- func DeleteDuplicateAgendaVotes(db *sql.DB) (int64, error)
- func DeleteDuplicateAgendas(db *sql.DB) (int64, error)
- func DeleteDuplicateMisses(db *sql.DB) (int64, error)
- func DeleteDuplicateTickets(db *sql.DB) (int64, error)
- func DeleteDuplicateTxns(db *sql.DB) (int64, error)
- func DeleteDuplicateVins(db *sql.DB) (int64, error)
- func DeleteDuplicateVinsCockroach(db *sql.DB) (int64, error)
- func DeleteDuplicateVotes(db *sql.DB) (int64, error)
- func DeleteDuplicateVouts(db *sql.DB) (int64, error)
- func DeleteDuplicateVoutsCockroach(db *sql.DB) (int64, error)
- func DisableLog()
- func DropTables(db *sql.DB)
- func DropTestingTable(db SqlExecutor) error
- func ExistsIndex(db *sql.DB, indexName string) (exists bool, err error)
- func IBDComplete(db *sql.DB) (ibdComplete bool, err error)
- func IndexAddressTableOnAddress(db *sql.DB) (err error)
- func IndexAddressTableOnMatchingTxHash(db *sql.DB) (err error)
- func IndexAddressTableOnTxHash(db *sql.DB) (err error)
- func IndexAddressTableOnVoutID(db *sql.DB) (err error)
- func IndexAgendaVotesTableOnAgendaID(db *sql.DB) (err error)
- func IndexAgendasTableOnAgendaID(db *sql.DB) (err error)
- func IndexBlockTableOnHash(db *sql.DB) (err error)
- func IndexBlockTableOnHeight(db *sql.DB) (err error)
- func IndexBlockTableOnTime(db *sql.DB) (err error)
- func IndexBlockTimeOnTableAddress(db *sql.DB) (err error)
- func IndexMissesTableOnHashes(db *sql.DB) (err error)
- func IndexProposalVotesTableOnProposalsID(db *sql.DB) (err error)
- func IndexProposalsTableOnToken(db *sql.DB) (err error)
- func IndexStatsTableOnHeight(db *sql.DB) (err error)
- func IndexTicketsTableOnHashes(db *sql.DB) (err error)
- func IndexTicketsTableOnPoolStatus(db *sql.DB) (err error)
- func IndexTicketsTableOnTxDbID(db *sql.DB) (err error)
- func IndexTransactionTableOnBlockHeight(db *sql.DB) (err error)
- func IndexTransactionTableOnBlockIn(db *sql.DB) (err error)
- func IndexTransactionTableOnHashes(db *sql.DB) (err error)
- func IndexVinTableOnPrevOuts(db *sql.DB) (err error)
- func IndexVinTableOnVins(db *sql.DB) (err error)
- func IndexVotesTableOnBlockHash(db *sql.DB) (err error)
- func IndexVotesTableOnBlockTime(db *sql.DB) (err error)
- func IndexVotesTableOnCandidate(db *sql.DB) (err error)
- func IndexVotesTableOnHashes(db *sql.DB) (err error)
- func IndexVotesTableOnHeight(db *sql.DB) (err error)
- func IndexVotesTableOnVoteVersion(db *sql.DB) (err error)
- func IndexVoutTableOnSpendTxID(db *sql.DB) (err error)
- func IndexVoutTableOnTxHashIdx(db *sql.DB) (err error)
- func InsertAddressRow(db *sql.DB, dbA *dbtypes.AddressRow, dupCheck, updateExistingRecords bool) (uint64, error)
- func InsertAddressRows(db *sql.DB, dbAs []*dbtypes.AddressRow, dupCheck, updateExistingRecords bool) ([]uint64, error)
- func InsertAddressRowsDbTx(dbTx *sql.Tx, dbAs []*dbtypes.AddressRow, dupCheck, updateExistingRecords bool) ([]uint64, error)
- func InsertBlock(db *sql.DB, dbBlock *dbtypes.Block, isValid, isMainchain, checked bool) (uint64, error)
- func InsertBlockPrevNext(db *sql.DB, blockDbID uint64, hash, prev, next string) error
- func InsertBlockStats(db *sql.DB, blockDbID uint64, tpi *apitypes.TicketPoolInfo) error
- func InsertProposal(db *sql.DB, tokenHash, author, commit string, timestamp time.Time, ...) (uint64, error)
- func InsertProposalVote(db *sql.DB, proposalRowID uint64, ticket, choice string, checked bool) (uint64, error)
- func InsertSpendingAddressRow(db *sql.DB, fundingTxHash string, fundingTxVoutIndex uint32, ...) (int64, uint64, bool, error)
- func InsertTickets(db *sql.DB, dbTxns []*dbtypes.Tx, txDbIDs []uint64, ...) ([]uint64, []*dbtypes.Tx, error)
- func InsertTx(db *sql.DB, dbTx *dbtypes.Tx, checked, updateExistingRecords bool) (uint64, error)
- func InsertTxns(db *sql.DB, dbTxns []*dbtypes.Tx, checked, updateExistingRecords bool) ([]uint64, error)
- func InsertTxnsDbTxn(dbTx *sql.Tx, dbTxns []*dbtypes.Tx, checked, updateExistingRecords bool) ([]uint64, error)
- func InsertTxnsStmt(stmt *sql.Stmt, dbTxns []*dbtypes.Tx, checked, updateExistingRecords bool) ([]uint64, error)
- func InsertVin(db *sql.DB, dbVin dbtypes.VinTxProperty, checked bool, ...) (id uint64, err error)
- func InsertVins(db *sql.DB, dbVins dbtypes.VinTxPropertyARRAY, checked bool, ...) ([]uint64, error)
- func InsertVinsDbTxn(dbTx *sql.Tx, dbVins dbtypes.VinTxPropertyARRAY, checked bool, doUpsert bool) ([]uint64, error)
- func InsertVinsStmt(stmt *sql.Stmt, dbVins dbtypes.VinTxPropertyARRAY, checked bool, doUpsert bool) ([]uint64, error)
- func InsertVotes(db *sql.DB, dbTxns []*dbtypes.Tx, _ []uint64, fTx *TicketTxnIDGetter, ...) ([]uint64, []*dbtypes.Tx, []string, []uint64, map[string]uint64, error)
- func InsertVout(db *sql.DB, dbVout *dbtypes.Vout, checked bool, updateOnConflict ...bool) (uint64, error)
- func InsertVouts(db *sql.DB, dbVouts []*dbtypes.Vout, checked bool, updateOnConflict ...bool) ([]uint64, []dbtypes.AddressRow, error)
- func InsertVoutsDbTxn(dbTx *sql.Tx, dbVouts []*dbtypes.Vout, checked bool, doUpsert bool) ([]uint64, []dbtypes.AddressRow, error)
- func InsertVoutsStmt(stmt *sql.Stmt, dbVouts []*dbtypes.Vout, checked bool, doUpsert bool) ([]uint64, []dbtypes.AddressRow, error)
- func IsRetryError(err error) bool
- func IsUniqueIndex(db *sql.DB, indexName string) (isUnique bool, err error)
- func MakeCsvAddressRows(rows []*dbtypes.AddressRow) [][]string
- func MakeCsvAddressRowsCompact(rows []*dbtypes.AddressRowCompact) [][]string
- func RetrieveAddressBalance(ctx context.Context, db *sql.DB, address string) (balance *dbtypes.AddressBalance, err error)
- func RetrieveAddressCreditTxns(ctx context.Context, db *sql.DB, address string, N, offset int64) ([]*dbtypes.AddressRow, error)
- func RetrieveAddressDbUTXOs(ctx context.Context, db *sql.DB, address string) ([]*dbtypes.AddressTxnOutput, error)
- func RetrieveAddressDebitTxns(ctx context.Context, db *sql.DB, address string, N, offset int64) ([]*dbtypes.AddressRow, error)
- func RetrieveAddressIDsByOutpoint(ctx context.Context, db *sql.DB, txHash string, voutIndex uint32) ([]uint64, []string, int64, error)
- func RetrieveAddressMergedCreditTxns(ctx context.Context, db *sql.DB, address string, N, offset int64) ([]*dbtypes.AddressRow, error)
- func RetrieveAddressMergedDebitTxns(ctx context.Context, db *sql.DB, address string, N, offset int64) ([]*dbtypes.AddressRow, error)
- func RetrieveAddressMergedTxns(ctx context.Context, db *sql.DB, address string, N, offset int64) ([]*dbtypes.AddressRow, error)
- func RetrieveAddressSpent(ctx context.Context, db *sql.DB, address string) (count, totalAmount int64, err error)
- func RetrieveAddressTxns(ctx context.Context, db *sql.DB, address string, N, offset int64) ([]*dbtypes.AddressRow, error)
- func RetrieveAddressTxnsOrdered(ctx context.Context, db *sql.DB, addresses []string, recentBlockTime int64) (txs, recenttxs []chainhash.Hash, err error)
- func RetrieveAddressUTXOs(ctx context.Context, db *sql.DB, address string, currentBlockHeight int64) ([]*apitypes.AddressTxnOutput, error)
- func RetrieveAddressUnspent(ctx context.Context, db *sql.DB, address string) (count, totalAmount int64, err error)
- func RetrieveAllAddressMergedTxns(ctx context.Context, db *sql.DB, address string, onlyValidMainchain bool) ([]uint64, []*dbtypes.AddressRow, error)
- func RetrieveAllAddressTxns(ctx context.Context, db *sql.DB, address string) ([]*dbtypes.AddressRow, error)
- func RetrieveAllMainchainAddressTxns(ctx context.Context, db *sql.DB, address string) ([]*dbtypes.AddressRow, error)
- func RetrieveAllRevokes(ctx context.Context, db *sql.DB) (ids []uint64, hashes []string, heights []int64, vinDbIDs []uint64, err error)
- func RetrieveAllVinDbIDs(db *sql.DB) (vinDbIDs []uint64, err error)
- func RetrieveAllVotesDbIDsHeightsTicketDbIDs(ctx context.Context, db *sql.DB) (ids []uint64, heights []int64, ticketDbIDs []uint64, err error)
- func RetrieveBestBlock(ctx context.Context, db *sql.DB) (height int64, hash string, err error)
- func RetrieveBestBlockHeight(ctx context.Context, db *sql.DB) (height uint64, hash string, id uint64, err error)
- func RetrieveBestBlockHeightAny(ctx context.Context, db *sql.DB) (height uint64, hash string, id uint64, err error)
- func RetrieveBlockChainDbID(ctx context.Context, db *sql.DB, hash string) (dbID uint64, err error)
- func RetrieveBlockFlags(ctx context.Context, db *sql.DB, hash string) (isValid bool, isMainchain bool, err error)
- func RetrieveBlockHash(ctx context.Context, db *sql.DB, idx int64) (hash string, err error)
- func RetrieveBlockHeight(ctx context.Context, db *sql.DB, hash string) (height int64, err error)
- func RetrieveBlockSize(ctx context.Context, db *sql.DB, ind int64) (int32, error)
- func RetrieveBlockSizeRange(ctx context.Context, db *sql.DB, ind0, ind1 int64) ([]int32, error)
- func RetrieveBlockStatus(ctx context.Context, db *sql.DB, hash string) (bs dbtypes.BlockStatus, err error)
- func RetrieveBlockSummary(ctx context.Context, db *sql.DB, ind int64) (*apitypes.BlockDataBasic, error)
- func RetrieveBlockSummaryByHash(ctx context.Context, db *sql.DB, hash string) (*apitypes.BlockDataBasic, error)
- func RetrieveBlockSummaryByTimeRange(ctx context.Context, db *sql.DB, minTime, maxTime int64, limit int) ([]dbtypes.BlockDataBasic, error)
- func RetrieveBlockSummaryRange(ctx context.Context, db *sql.DB, ind0, ind1 int64) ([]*apitypes.BlockDataBasic, error)
- func RetrieveBlockSummaryRangeStepped(ctx context.Context, db *sql.DB, ind0, ind1, step int64) ([]*apitypes.BlockDataBasic, error)
- func RetrieveBlockTimeByHeight(ctx context.Context, db *sql.DB, idx int64) (time dbtypes.TimeDef, err error)
- func RetrieveBlockVoteCount(ctx context.Context, db *sql.DB, hash string) (numVotes int16, err error)
- func RetrieveBlocksHashesAll(ctx context.Context, db *sql.DB) ([]string, error)
- func RetrieveDbTxByHash(ctx context.Context, db *sql.DB, txHash string) (id uint64, dbTx *dbtypes.Tx, err error)
- func RetrieveDbTxsByHash(ctx context.Context, db *sql.DB, txHash string) (ids []uint64, dbTxs []*dbtypes.Tx, err error)
- func RetrieveDiff(ctx context.Context, db *sql.DB, timestamp int64) (float64, error)
- func RetrieveDisapprovedBlocks(ctx context.Context, db *sql.DB) (blocks []*dbtypes.BlockStatus, err error)
- func RetrieveFullTxByHash(ctx context.Context, db *sql.DB, txHash string) (id uint64, blockHash string, blockHeight int64, ...)
- func RetrieveFundingOutpointByTxIn(ctx context.Context, db *sql.DB, txHash string, vinIndex uint32) (id uint64, tx string, index uint32, tree int8, err error)
- func RetrieveFundingOutpointByVinID(ctx context.Context, db *sql.DB, vinDbID uint64) (tx string, index uint32, tree int8, err error)
- func RetrieveFundingOutpointIndxByVinID(ctx context.Context, db *sql.DB, vinDbID uint64) (idx uint32, err error)
- func RetrieveFundingTxByTxIn(ctx context.Context, db *sql.DB, txHash string, vinIndex uint32) (id uint64, tx string, err error)
- func RetrieveFundingTxByVinDbID(ctx context.Context, db *sql.DB, vinDbID uint64) (tx string, err error)
- func RetrieveLatestBlockSummary(ctx context.Context, db *sql.DB) (*apitypes.BlockDataBasic, error)
- func RetrieveMissForTicket(ctx context.Context, db *sql.DB, ticketHash string) (blockHash string, blockHeight int64, err error)
- func RetrieveMissedVotesInBlock(ctx context.Context, db *sql.DB, blockHash string) (ticketHashes []string, err error)
- func RetrieveMissesForTicket(ctx context.Context, db *sql.DB, ticketHash string) (blockHashes []string, blockHeights []int64, err error)
- func RetrievePGVersion(db *sql.DB) (ver string, err error)
- func RetrievePkScriptByOutpoint(ctx context.Context, db *sql.DB, txHash string, voutIndex uint32) (pkScript []byte, ver uint16, err error)
- func RetrievePkScriptByVinID(ctx context.Context, db *sql.DB, vinID uint64) (pkScript []byte, ver uint16, err error)
- func RetrievePkScriptByVoutID(ctx context.Context, db *sql.DB, voutID uint64) (pkScript []byte, ver uint16, err error)
- func RetrievePoolInfo(ctx context.Context, db *sql.DB, ind int64) (*apitypes.TicketPoolInfo, error)
- func RetrievePoolInfoByHash(ctx context.Context, db *sql.DB, hash string) (*apitypes.TicketPoolInfo, error)
- func RetrievePoolInfoRange(ctx context.Context, db *sql.DB, ind0, ind1 int64) ([]apitypes.TicketPoolInfo, []string, error)
- func RetrievePoolValAndSizeRange(ctx context.Context, db *sql.DB, ind0, ind1 int64) ([]float64, []uint32, error)
- func RetrievePreviousHashByBlockHash(ctx context.Context, db *sql.DB, hash string) (previousHash string, err error)
- func RetrieveSBitsByHash(ctx context.Context, db *sql.DB, hash string) (int64, error)
- func RetrieveSDiff(ctx context.Context, db *sql.DB, ind int64) (float64, error)
- func RetrieveSDiffRange(ctx context.Context, db *sql.DB, ind0, ind1 int64) ([]float64, error)
- func RetrieveSideChainBlocks(ctx context.Context, db *sql.DB) (blocks []*dbtypes.BlockStatus, err error)
- func RetrieveSideChainTips(ctx context.Context, db *sql.DB) (blocks []*dbtypes.BlockStatus, err error)
- func RetrieveSpendingTxByTxOut(ctx context.Context, db *sql.DB, txHash string, voutIndex uint32) (id uint64, tx string, vin uint32, tree int8, err error)
- func RetrieveSpendingTxByVinID(ctx context.Context, db *sql.DB, vinDbID uint64) (tx string, vinIndex uint32, tree int8, err error)
- func RetrieveSpendingTxsByFundingTx(ctx context.Context, db *sql.DB, fundingTxID string) (dbIDs []uint64, txns []string, vinInds []uint32, voutInds []uint32, err error)
- func RetrieveSpendingTxsByFundingTxWithBlockHeight(ctx context.Context, db *sql.DB, fundingTxID string) (aSpendByFunHash []*apitypes.SpendByFundingHash, err error)
- func RetrieveSysSettingSyncCommit(db *sql.DB) (syncCommit string, err error)
- func RetrieveTicketIDByHashNoCancel(db *sql.DB, ticketHash string) (id uint64, err error)
- func RetrieveTicketIDsByHashes(ctx context.Context, db *sql.DB, ticketHashes []string) (ids []uint64, err error)
- func RetrieveTicketInfoByHash(ctx context.Context, db *sql.DB, ticketHash string) (spendStatus dbtypes.TicketSpendType, poolStatus dbtypes.TicketPoolStatus, ...)
- func RetrieveTicketStatusByHash(ctx context.Context, db *sql.DB, ticketHash string) (id uint64, spendStatus dbtypes.TicketSpendType, ...)
- func RetrieveTxBlockTimeByHash(ctx context.Context, db *sql.DB, txHash string) (blockTime dbtypes.TimeDef, err error)
- func RetrieveTxByHash(ctx context.Context, db *sql.DB, txHash string) (id uint64, blockHash string, blockInd uint32, tree int8, err error)
- func RetrieveTxnsBlocks(ctx context.Context, db *sql.DB, txHash string) (blockHashes []string, blockHeights, blockIndexes []uint32, ...)
- func RetrieveTxnsVinsByBlock(ctx context.Context, db *sql.DB, blockHash string) (vinDbIDs []dbtypes.UInt64Array, areValid []bool, areMainchain []bool, ...)
- func RetrieveTxnsVinsVoutsByBlock(ctx context.Context, db *sql.DB, blockHash string, onlyRegular bool) (vinDbIDs, voutDbIDs []dbtypes.UInt64Array, areMainchain []bool, err error)
- func RetrieveTxsBestBlockMainchain(ctx context.Context, db *sql.DB) (height int64, hash string, err error)
- func RetrieveTxsBlocksAboveHeight(ctx context.Context, db *sql.DB, height int64) (heights []int64, hashes []string, err error)
- func RetrieveTxsByBlockHash(ctx context.Context, db *sql.DB, blockHash string) (ids []uint64, txs []string, blockInds []uint32, trees []int8, ...)
- func RetrieveUTXOs(ctx context.Context, db *sql.DB) ([]dbtypes.UTXO, error)
- func RetrieveUTXOsByVinsJoin(ctx context.Context, db *sql.DB) ([]dbtypes.UTXO, error)
- func RetrieveUnspentTickets(ctx context.Context, db *sql.DB) (ids []uint64, hashes []string, err error)
- func RetrieveVinByID(ctx context.Context, db *sql.DB, vinDbID uint64) (prevOutHash string, prevOutVoutInd uint32, prevOutTree int8, txHash string, ...)
- func RetrieveVinsByIDs(ctx context.Context, db *sql.DB, vinDbIDs []uint64) ([]dbtypes.VinTxProperty, error)
- func RetrieveVoutIDByOutpoint(ctx context.Context, db *sql.DB, txHash string, voutIndex uint32) (id uint64, err error)
- func RetrieveVoutValue(ctx context.Context, db *sql.DB, txHash string, voutIndex uint32) (value uint64, err error)
- func RetrieveVoutValues(ctx context.Context, db *sql.DB, txHash string) (values []uint64, txInds []uint32, txTrees []int8, err error)
- func RetrieveVoutsByIDs(ctx context.Context, db *sql.DB, voutDbIDs []uint64) ([]dbtypes.Vout, error)
- func SetDBBestBlock(db *sql.DB, hash string, height int64) error
- func SetIBDComplete(db SqlExecutor, ibdComplete bool) error
- func SetMainchainByBlockHash(db *sql.DB, hash string, isMainchain bool) (previousHash string, err error)
- func SetPoolStatusForTickets(db *sql.DB, ticketDbIDs []uint64, poolStatuses []dbtypes.TicketPoolStatus) (int64, error)
- func SetPoolStatusForTicketsByHash(db *sql.DB, tickets []string, poolStatuses []dbtypes.TicketPoolStatus) (int64, error)
- func SetSpendingForFundingOP(db SqlExecutor, fundingTxHash string, fundingTxVoutIndex uint32, ...) (int64, error)
- func SetSpendingForTickets(db *sql.DB, ticketDbIDs, spendDbIDs []uint64, blockHeights []int64, ...) (int64, error)
- func SetSpendingForVinDbID(db *sql.DB, vinDbID uint64) (int64, error)
- func SetSpendingForVinDbIDs(db *sql.DB, vinDbIDs []uint64) ([]int64, int64, error)
- func SetSynchronousCommit(db SqlExecutor, syncCommit string) error
- func TableExists(db *sql.DB, tableName string) (bool, error)
- func TableVersions(db *sql.DB) map[string]TableVersion
- func TicketPoolData(interval dbtypes.TimeBasedGrouping, height int64) (timeGraph *dbtypes.PoolTicketsData, priceGraph *dbtypes.PoolTicketsData, ...)
- func UpdateAddressesMainchainByIDs(db SqlExecutor, vinsBlk, voutsBlk []dbtypes.UInt64Array, isValidMainchain bool) (numSpendingRows, numFundingRows int64, err error)
- func UpdateBlockNext(db SqlExecutor, blockDbID uint64, next string) error
- func UpdateBlockNextByHash(db SqlExecutor, this, next string) error
- func UpdateBlockNextByNextHash(db SqlExecutor, currentNext, newNext string) error
- func UpdateLastAddressesValid(db *sql.DB, blockHash string, isValid bool) error
- func UpdateLastBlockValid(db SqlExecutor, blockDbID uint64, isValid bool) error
- func UpdateLastVins(db *sql.DB, blockHash string, isValid, isMainchain bool) error
- func UpdateTicketPoolData(interval dbtypes.TimeBasedGrouping, timeGraph *dbtypes.PoolTicketsData, ...)
- func UpdateTicketsMainchain(db SqlExecutor, blockHash string, isMainchain bool) (int64, error)
- func UpdateTransactionsMainchain(db *sql.DB, blockHash string, isMainchain bool) (int64, []uint64, error)
- func UpdateTransactionsValid(db *sql.DB, blockHash string, isValid bool) (int64, []uint64, error)
- func UpdateVotesMainchain(db SqlExecutor, blockHash string, isMainchain bool) (int64, error)
- func UseLogger(logger slog.Logger)
- type BestBlock
- type BlockGetter
- type ChainDB
- func (pgb *ChainDB) AddressBalance(address string) (bal *dbtypes.AddressBalance, cacheUpdated bool, err error)
- func (pgb *ChainDB) AddressData(address string, limitN, offsetAddrOuts int64, txnType dbtypes.AddrTxnViewType) (addrData *dbtypes.AddressInfo, err error)
- func (pgb *ChainDB) AddressHistory(address string, N, offset int64, txnView dbtypes.AddrTxnViewType) ([]*dbtypes.AddressRow, *dbtypes.AddressBalance, error)
- func (pgb *ChainDB) AddressHistoryAll(address string, N, offset int64) ([]*dbtypes.AddressRow, *dbtypes.AddressBalance, error)
- func (pgb *ChainDB) AddressIDsByOutpoint(txHash string, voutIndex uint32) ([]uint64, []string, int64, error)
- func (pgb *ChainDB) AddressMetrics(addr string) (*dbtypes.AddressMetrics, error)
- func (pgb *ChainDB) AddressRowsCompact(address string) ([]*dbtypes.AddressRowCompact, error)
- func (pgb *ChainDB) AddressRowsMerged(address string) ([]*dbtypes.AddressRowMerged, error)
- func (pgb *ChainDB) AddressTotals(address string) (*apitypes.AddressTotals, error)
- func (pgb *ChainDB) AddressTransactionDetails(addr string, count, skip int64, txnType dbtypes.AddrTxnViewType) (*apitypes.Address, error)
- func (pgb *ChainDB) AddressTransactions(address string, N, offset int64, txnType dbtypes.AddrTxnViewType) (addressRows []*dbtypes.AddressRow, err error)
- func (pgb *ChainDB) AddressTransactionsAll(address string) (addressRows []*dbtypes.AddressRow, err error)
- func (pgb *ChainDB) AddressTransactionsAllMerged(address string) (addressRows []*dbtypes.AddressRow, err error)
- func (pgb *ChainDB) AddressTxIoCsv(address string) ([][]string, error)
- func (pgb *ChainDB) AddressUTXO(address string) ([]*dbtypes.AddressTxnOutput, bool, error)
- func (pgb *ChainDB) AgendaVoteCounts(agendaID string) (yes, abstain, no uint32, err error)
- func (pgb *ChainDB) AgendaVotes(agendaID string, chartType int) (*dbtypes.AgendaVoteChoices, error)
- func (pgb *ChainDB) AgendasVotesSummary(agendaID string) (summary *dbtypes.AgendaSummary, err error)
- func (pgb *ChainDB) AllAgendas() (map[string]dbtypes.MileStone, error)
- func (pgb *ChainDB) BestBlock() (*chainhash.Hash, int64)
- func (pgb *ChainDB) BestBlockHash() *chainhash.Hash
- func (pgb *ChainDB) BestBlockHashStr() string
- func (pgb *ChainDB) BestBlockStr() (string, int64)
- func (pgb *ChainDB) BlockChainDbID(hash string) (dbID uint64, err error)
- func (pgb *ChainDB) BlockChainDbIDNoCancel(hash string) (dbID uint64, err error)
- func (pgb *ChainDB) BlockFlags(hash string) (bool, bool, error)
- func (pgb *ChainDB) BlockFlagsNoCancel(hash string) (bool, bool, error)
- func (pgb *ChainDB) BlockHash(height int64) (string, error)
- func (pgb *ChainDB) BlockHeight(hash string) (int64, error)
- func (pgb *ChainDB) BlockMissedVotes(blockHash string) ([]string, error)
- func (pgb *ChainDB) BlockSize(ind int64) (int32, error)
- func (pgb *ChainDB) BlockSizeRange(ind0, ind1 int64) ([]int32, error)
- func (pgb *ChainDB) BlockStatus(hash string) (dbtypes.BlockStatus, error)
- func (pgb *ChainDB) BlockSubsidy(height int64, voters uint16) *chainjson.GetBlockSubsidyResult
- func (pgb *ChainDB) BlockSummary(ind int64) (*apitypes.BlockDataBasic, error)
- func (pgb *ChainDB) BlockSummaryByHash(hash string) (*apitypes.BlockDataBasic, error)
- func (pgb *ChainDB) BlockSummaryRange(idx0, idx1 int64) ([]*apitypes.BlockDataBasic, error)
- func (pgb *ChainDB) BlockSummaryRangeStepped(idx0, idx1, step int64) ([]*apitypes.BlockDataBasic, error)
- func (pgb *ChainDB) BlockSummaryTimeRange(min, max int64, limit int) ([]dbtypes.BlockDataBasic, error)
- func (pgb *ChainDB) BlockTimeByHeight(height int64) (int64, error)
- func (pgb *ChainDB) BlockTransactions(blockHash string) ([]string, []uint32, []int8, error)
- func (pgb *ChainDB) BlockchainInfo() (*chainjson.GetBlockChainInfoResult, error)
- func (pgb *ChainDB) ChainInfo() *dbtypes.BlockChainData
- func (pgb *ChainDB) ChargePoolInfoCache(startHeight int64) error
- func (pgb *ChainDB) Close() error
- func (pgb *ChainDB) CollectTicketSpendDBInfo(dbTxns []*dbtypes.Tx, txDbIDs []uint64, msgBlock *wire.MsgBlock, ...) (spendingTxDbIDs []uint64, spendTypes []dbtypes.TicketSpendType, ...)
- func (pgb *ChainDB) CountTransactions(addr string, txnView dbtypes.AddrTxnViewType) (int, error)
- func (pgb *ChainDB) CurrentCoinSupply() (supply *apitypes.CoinSupply)
- func (pgb *ChainDB) CurrentDifficulty() (float64, error)
- func (pgb *ChainDB) DbTxByHash(txid string) (*dbtypes.Tx, error)
- func (pgb *ChainDB) DecodeRawTransaction(txhex string) (*chainjson.TxRawResult, error)
- func (pgb *ChainDB) DeindexAddressTable() error
- func (pgb *ChainDB) DeindexAll() error
- func (pgb *ChainDB) DeindexTicketsTable() error
- func (pgb *ChainDB) DeleteDuplicateAgendaVotes() (int64, error)
- func (pgb *ChainDB) DeleteDuplicateAgendas() (int64, error)
- func (pgb *ChainDB) DeleteDuplicateMisses() (int64, error)
- func (pgb *ChainDB) DeleteDuplicateTickets() (int64, error)
- func (pgb *ChainDB) DeleteDuplicateTxns() (int64, error)
- func (pgb *ChainDB) DeleteDuplicateVins() (int64, error)
- func (pgb *ChainDB) DeleteDuplicateVinsCockroach() (int64, error)
- func (pgb *ChainDB) DeleteDuplicateVotes() (int64, error)
- func (pgb *ChainDB) DeleteDuplicateVouts() (int64, error)
- func (pgb *ChainDB) DeleteDuplicateVoutsCockroach() (int64, error)
- func (pgb *ChainDB) DeleteDuplicates(barLoad chan *dbtypes.ProgressBarLoad) error
- func (pgb *ChainDB) DeleteDuplicatesRecovery(barLoad chan *dbtypes.ProgressBarLoad) error
- func (pgb *ChainDB) DevBalance() (*dbtypes.AddressBalance, error)
- func (pgb *ChainDB) Difficulty(timestamp int64) float64
- func (pgb *ChainDB) DisapprovedBlocks() ([]*dbtypes.BlockStatus, error)
- func (pgb *ChainDB) DropTables()
- func (pgb *ChainDB) EnableDuplicateCheckOnInsert(dupCheck bool)
- func (pgb *ChainDB) FillAddressTransactions(addrInfo *dbtypes.AddressInfo) error
- func (pgb *ChainDB) FreshenAddressCaches(lazyProjectFund bool, expireAddresses []string) error
- func (pgb *ChainDB) FundingOutpointIndxByVinID(id uint64) (uint32, error)
- func (pgb *ChainDB) GenesisStamp() int64
- func (pgb *ChainDB) GetAddressTransactionsRawWithSkip(addr string, count int, skip int) []*apitypes.AddressTxRaw
- func (pgb *ChainDB) GetAllTxIn(txid *chainhash.Hash) []*apitypes.TxIn
- func (pgb *ChainDB) GetAllTxOut(txid *chainhash.Hash) []*apitypes.TxOut
- func (pgb *ChainDB) GetBestBlockHash() (string, error)
- func (pgb *ChainDB) GetBestBlockSummary() *apitypes.BlockDataBasic
- func (pgb *ChainDB) GetBlockByHash(hash string) (*wire.MsgBlock, error)
- func (pgb *ChainDB) GetBlockHash(idx int64) (string, error)
- func (pgb *ChainDB) GetBlockHeaderByHash(hash string) (*wire.BlockHeader, error)
- func (pgb *ChainDB) GetBlockHeight(hash string) (int64, error)
- func (pgb *ChainDB) GetBlockSize(idx int) (int32, error)
- func (pgb *ChainDB) GetBlockSizeRange(idx0, idx1 int) ([]int32, error)
- func (pgb *ChainDB) GetBlockVerbose(idx int, verboseTx bool) *chainjson.GetBlockVerboseResult
- func (pgb *ChainDB) GetBlockVerboseByHash(hash string, verboseTx bool) *chainjson.GetBlockVerboseResult
- func (pgb *ChainDB) GetChainParams() *chaincfg.Params
- func (pgb *ChainDB) GetChainWork(hash *chainhash.Hash) (string, error)
- func (pgb *ChainDB) GetExplorerAddress(address string, count, offset int64) (*dbtypes.AddressInfo, txhelpers.AddressType, txhelpers.AddressError)
- func (pgb *ChainDB) GetExplorerBlock(hash string) *exptypes.BlockInfo
- func (pgb *ChainDB) GetExplorerBlocks(start int, end int) []*exptypes.BlockBasic
- func (pgb *ChainDB) GetExplorerFullBlocks(start int, end int) []*exptypes.BlockInfo
- func (pgb *ChainDB) GetExplorerTx(txid string) *exptypes.TxInfo
- func (pgb *ChainDB) GetHeader(idx int) *chainjson.GetBlockHeaderVerboseResult
- func (pgb *ChainDB) GetHeight() (int64, error)
- func (pgb *ChainDB) GetMempool() []exptypes.MempoolTx
- func (pgb *ChainDB) GetMempoolPriceCountTime() *apitypes.PriceCountTime
- func (pgb *ChainDB) GetMempoolSSTxDetails(N int) *apitypes.MempoolTicketDetails
- func (pgb *ChainDB) GetMempoolSSTxFeeRates(N int) *apitypes.MempoolTicketFees
- func (pgb *ChainDB) GetMempoolSSTxSummary() *apitypes.MempoolTicketFeeInfo
- func (pgb *ChainDB) GetPool(idx int64) ([]string, error)
- func (pgb *ChainDB) GetPoolInfo(idx int) *apitypes.TicketPoolInfo
- func (pgb *ChainDB) GetPoolInfoByHash(hash string) *apitypes.TicketPoolInfo
- func (pgb *ChainDB) GetPoolInfoRange(idx0, idx1 int) []apitypes.TicketPoolInfo
- func (pgb *ChainDB) GetPoolValAndSizeRange(idx0, idx1 int) ([]float64, []uint32)
- func (pgb *ChainDB) GetRawAPITransaction(txid *chainhash.Hash) *apitypes.Tx
- func (pgb *ChainDB) GetRawTransaction(txid *chainhash.Hash) (*chainjson.TxRawResult, error)
- func (pgb *ChainDB) GetSBitsByHash(hash string) int64
- func (pgb *ChainDB) GetSDiff(idx int) float64
- func (pgb *ChainDB) GetSDiffRange(idx0, idx1 int) []float64
- func (pgb *ChainDB) GetStakeDiffEstimates() *apitypes.StakeDiff
- func (pgb *ChainDB) GetStakeInfoExtendedByHash(hashStr string) *apitypes.StakeInfoExtended
- func (pgb *ChainDB) GetStakeInfoExtendedByHeight(height int) *apitypes.StakeInfoExtended
- func (pgb *ChainDB) GetStakeVersions(blockHash string, count int32) (*chainjson.GetStakeVersionsResult, error)
- func (pgb *ChainDB) GetStakeVersionsLatest() (*chainjson.StakeVersions, error)
- func (pgb *ChainDB) GetSummary(idx int) *apitypes.BlockDataBasic
- func (pgb *ChainDB) GetSummaryByHash(hash string, withTxTotals bool) *apitypes.BlockDataBasic
- func (pgb *ChainDB) GetSummaryRange(idx0, idx1 int) []*apitypes.BlockDataBasic
- func (pgb *ChainDB) GetSummaryRangeStepped(idx0, idx1, step int) []*apitypes.BlockDataBasic
- func (pgb *ChainDB) GetTicketInfo(txid string) (*apitypes.TicketInfo, error)
- func (pgb *ChainDB) GetTip() (*exptypes.WebBasicBlock, error)
- func (pgb *ChainDB) GetTransactionHex(txid *chainhash.Hash) string
- func (pgb *ChainDB) GetTransactionsForBlockByHash(hash string) *apitypes.BlockTransactions
- func (pgb *ChainDB) GetTrimmedTransaction(txid *chainhash.Hash) *apitypes.TrimmedTx
- func (pgb *ChainDB) GetVoteInfo(txhash *chainhash.Hash) (*apitypes.VoteInfo, error)
- func (pgb *ChainDB) GetVoteVersionInfo(ver uint32) (*chainjson.GetVoteInfoResult, error)
- func (pgb *ChainDB) HashDB() (string, error)
- func (pgb *ChainDB) HashDBLegacy() (string, error)
- func (pgb *ChainDB) Height() int64
- func (pgb *ChainDB) HeightDB() (int64, error)
- func (pgb *ChainDB) HeightDBLegacy() (int64, error)
- func (pgb *ChainDB) HeightHashDB() (int64, string, error)
- func (pgb *ChainDB) HeightHashDBLegacy() (uint64, string, error)
- func (pgb *ChainDB) IndexAddressTable(barLoad chan *dbtypes.ProgressBarLoad) error
- func (pgb *ChainDB) IndexAll(barLoad chan *dbtypes.ProgressBarLoad) error
- func (pgb *ChainDB) IndexTicketsTable(barLoad chan *dbtypes.ProgressBarLoad) error
- func (pgb *ChainDB) InitUtxoCache(utxos []dbtypes.UTXO)
- func (pgb *ChainDB) InsightAddressTransactions(addr []string, recentBlockHeight int64) (txs, recentTxs []chainhash.Hash, err error)
- func (pgb *ChainDB) InsightSearchRPCAddressTransactions(addr string, count, skip int) []*chainjson.SearchRawTransactionsResult
- func (pgb *ChainDB) LastPiParserSync() time.Time
- func (pgb *ChainDB) MissingAddressIndexes() (missing []string, descs []string, err error)
- func (pgb *ChainDB) MissingIndexes() (missing, descs []string, err error)
- func (pgb *ChainDB) MissingSideChainBlocks() ([]dbtypes.SideChain, int, error)
- func (pgb *ChainDB) MixedUtxosByHeight() (heights, utxoCountReg, utxoValueReg, utxoCountStk, utxoValueStk []int64, ...)
- func (pgb *ChainDB) NewChainMonitor(ctx context.Context) *ChainMonitor
- func (pgb *ChainDB) NumAddressIntervals(addr string, grouping dbtypes.TimeBasedGrouping) (int64, error)
- func (pgb *ChainDB) PiProposalsHistory() (int64, error)
- func (pgb *ChainDB) PkScriptByVinID(id uint64) (pkScript []byte, ver uint16, err error)
- func (pgb *ChainDB) PkScriptByVoutID(id uint64) (pkScript []byte, ver uint16, err error)
- func (pgb *ChainDB) PoolStatusForTicket(txid string) (dbtypes.TicketSpendType, dbtypes.TicketPoolStatus, error)
- func (pgb *ChainDB) PosIntervals(limit, offset uint64) ([]*dbtypes.BlocksGroupedInfo, error)
- func (pgb *ChainDB) PowerlessTickets() (*apitypes.PowerlessTickets, error)
- func (pgb *ChainDB) ProposalVotes(proposalToken string) (*dbtypes.ProposalChartsData, error)
- func (pgb *ChainDB) PurgeBestBlocks(N int64) (*dbtypes.DeletionSummary, int64, error)
- func (pgb *ChainDB) RegisterCharts(charts *cache.ChartData)
- func (pgb *ChainDB) ReindexAddressesBlockTime() error
- func (pgb *ChainDB) RewindStakeDB(ctx context.Context, toHeight int64, quiet ...bool) (stakeDBHeight int64, err error)
- func (pgb *ChainDB) SDiffRange(ind0, ind1 int64) ([]float64, error)
- func (pgb *ChainDB) SendRawTransaction(txhex string) (string, error)
- func (pgb *ChainDB) SetDBBestBlock() error
- func (pgb *ChainDB) SetVinsMainchainByBlock(blockHash string) (int64, []dbtypes.UInt64Array, []dbtypes.UInt64Array, error)
- func (pgb *ChainDB) SideChainBlocks() ([]*dbtypes.BlockStatus, error)
- func (pgb *ChainDB) SideChainTips() ([]*dbtypes.BlockStatus, error)
- func (pgb *ChainDB) SignalHeight(height uint32)
- func (pgb *ChainDB) SpendDetailsForFundingTx(fundHash string) ([]*apitypes.SpendByFundingHash, error)
- func (pgb *ChainDB) SpendingTransaction(fundingTxID string, fundingTxVout uint32) (string, uint32, int8, error)
- func (pgb *ChainDB) SpendingTransactions(fundingTxID string) ([]string, []uint32, []uint32, error)
- func (pgb *ChainDB) SqlDB() *sql.DB
- func (pgb *ChainDB) StartPiparserHandler()
- func (pgb *ChainDB) Store(blockData *blockdata.BlockData, msgBlock *wire.MsgBlock) error
- func (pgb *ChainDB) StoreBlock(msgBlock *wire.MsgBlock, ...) (numVins int64, numVouts int64, numAddresses int64, err error)
- func (pgb *ChainDB) SyncChainDB(ctx context.Context, client rpcutils.MasterBlockGetter, ...) (int64, error)
- func (pgb *ChainDB) SyncChainDBAsync(ctx context.Context, res chan dbtypes.SyncResult, ...)
- func (pgb *ChainDB) TicketMiss(ticketHash string) (string, int64, error)
- func (pgb *ChainDB) TicketMisses(ticketHash string) ([]string, []int64, error)
- func (pgb *ChainDB) TicketPoolBlockMaturity() int64
- func (pgb *ChainDB) TicketPoolByDateAndInterval(maturityBlock int64, interval dbtypes.TimeBasedGrouping) (*dbtypes.PoolTicketsData, error)
- func (pgb *ChainDB) TicketPoolVisualization(interval dbtypes.TimeBasedGrouping) (*dbtypes.PoolTicketsData, *dbtypes.PoolTicketsData, *dbtypes.PoolTicketsData, ...)
- func (pgb *ChainDB) TicketsByInputCount() (*dbtypes.PoolTicketsData, error)
- func (pgb *ChainDB) TicketsByPrice(maturityBlock int64) (*dbtypes.PoolTicketsData, error)
- func (pgb *ChainDB) TimeBasedIntervals(timeGrouping dbtypes.TimeBasedGrouping, limit, offset uint64) ([]*dbtypes.BlocksGroupedInfo, error)
- func (pgb *ChainDB) TipToSideChain(mainRoot string) (string, int64, error)
- func (pgb *ChainDB) Transaction(txHash string) ([]*dbtypes.Tx, error)
- func (pgb *ChainDB) TransactionBlock(txID string) (string, uint32, int8, error)
- func (pgb *ChainDB) TransactionBlocks(txHash string) ([]*dbtypes.BlockStatus, []uint32, error)
- func (pgb *ChainDB) TxHeight(txid *chainhash.Hash) (height int64)
- func (pgb *ChainDB) TxHistoryData(address string, addrChart dbtypes.HistoryChart, ...) (cd *dbtypes.ChartsData, err error)
- func (pgb *ChainDB) UpdateChainState(blockChainInfo *chainjson.GetBlockChainInfoResult)
- func (pgb *ChainDB) UpdateChan() chan uint32
- func (pgb *ChainDB) UpdateLastBlock(msgBlock *wire.MsgBlock, isMainchain bool) error
- func (pgb *ChainDB) UpdateSpendingInfoInAllAddresses(barLoad chan *dbtypes.ProgressBarLoad) (int64, error)
- func (pgb *ChainDB) UpdateSpendingInfoInAllTickets() (int64, error)
- func (pgb *ChainDB) UpgradeTables(dcrdClient BlockGetter, version, needVersion TableVersion) (bool, error)
- func (pgb *ChainDB) UseMempoolChecker(mp rpcutils.MempoolAddressChecker)
- func (pgb *ChainDB) UseStakeDB(stakeDB *stakedb.StakeDatabase)
- func (pgb *ChainDB) VersionCheck(client BlockGetter) error
- func (pgb *ChainDB) VinsForTx(dbTx *dbtypes.Tx) ([]dbtypes.VinTxProperty, []string, []uint16, error)
- func (pgb *ChainDB) VotesInBlock(hash string) (int16, error)
- func (pgb *ChainDB) VoutValue(txID string, vout uint32) (uint64, error)
- func (pgb *ChainDB) VoutValues(txID string) ([]uint64, []uint32, []int8, error)
- func (pgb *ChainDB) VoutsForTx(dbTx *dbtypes.Tx) ([]dbtypes.Vout, error)
- type ChainDBCfg
- type ChainDeployments
- type ChainMonitor
- type CompatAction
- type CompatibilityAction
- type DBInfo
- type DatabaseUpgrade
- type DatabaseVersion
- type MsgBlockPG
- type PGSetting
- type PGSettings
- type ProposalsFetcher
- type SqlExecutor
- type TableUpgrade
- type TableUpgradeType
- type TableVersion
- type TicketTxnIDGetter
- type Upgrader
- type VinVoutTypeUpdateData
Constants ¶
const MaxAddressRows int64 = 1000
MaxAddressRows is an upper limit on the number of rows that may be requested with the searchrawtransactions RPC.
Variables ¶
This section is empty.
Functions ¶
func AnalyzeAllTables ¶
AnalyzeAllTables performs an ANALYZE on all tables after setting default_statistics_target for the transaction.
func AnalyzeTable ¶
AnalyzeTable performs an ANALYZE on the specified table after setting default_statistics_target for the transaction.
func CheckBadBlockApproval ¶
func CheckBadBlockApproval(ctx context.Context, db *sql.DB) (hashes []string, approvals, disapprovals, totals []int16, approvedActual, approvedSet []bool, err error)
CheckBadBlockApproval checks the blocks table for blocks with an incorrect approval flag as determined by computing (approvals/total_votes > 0.5).
func CheckBadExpiredVotedTickets ¶
func CheckBadExpiredVotedTickets(ctx context.Context, db *sql.DB) (ids []uint64, txHashes []string, spendTypes []int16, err error)
CheckBadExpiredVotedTickets checks the tickets table for tickets with expired pool status but with voted status. This indicates likely database corruption.
func CheckBadMissedVotedTickets ¶
func CheckBadMissedVotedTickets(ctx context.Context, db *sql.DB) (ids []uint64, txHashes []string, spendTypes []int16, err error)
CheckBadMissedVotedTickets checks the tickets table for tickets with missed pool status but with voted status. This indicates likely database corruption.
func CheckBadSpentLiveTickets ¶
func CheckBadSpentLiveTickets(ctx context.Context, db *sql.DB) (ids []uint64, txHashes []string, spendTypes []int16, err error)
CheckBadSpentLiveTickets checks the tickets table for tickets with live pool status but not unspent status. This indicates likely database corruption.
func CheckBadVotedTickets ¶
func CheckBadVotedTickets(ctx context.Context, db *sql.DB) (ids []uint64, txHashes []string, spendTypes []int16, err error)
CheckBadVotedTickets checks the tickets table for tickets with voted pool status but not voted status. This indicates likely database corruption.
func CheckColumnDataType ¶
CheckColumnDataType gets the data type of specified table column .
func CheckCurrentTimeZone ¶
CheckCurrentTimeZone queries for the currently set postgres time zone.
func CheckDefaultTimeZone ¶
CheckDefaultTimeZone queries for the default postgres time zone. This is the value that would be observed if postgres were restarted using its current configuration. The currently set time zone is also returned.
func CheckExtraMainchainBlocks ¶
func CheckExtraMainchainBlocks(ctx context.Context, db *sql.DB) (ids, heights []uint64, hashes []string, err error)
CheckExtraMainchainBlocks checks the blocks table for multiple main chain blocks at a given height, which is not possible. The row IDs, block heights, and block hashes are returned. Non-zero length sizes is an indication of database corruption.
func CheckMislabeledInvalidBlocks ¶
func CheckMislabeledInvalidBlocks(ctx context.Context, db *sql.DB) (ids []uint64, hashes []string, err error)
CheckMislabeledInvalidBlocks checks the blocks table for blocks labeled as approved, but for which the following block has specified vote bits that invalidate it. This indicates likely database corruption.
func CheckMislabeledTicketTransactions ¶
func CheckMislabeledTicketTransactions(ctx context.Context, db *sql.DB) (ids []uint64, txTypes []int16, txHashes []string, err error)
CheckMislabeledTicketTransactions checks the transactions table for ticket transactions that also appear in the tickets table, but which do not have the proper tx_type (1) set. This indicates likely database corruption.
func CheckMissingTicketTransactions ¶
func CheckMissingTicketTransactions(ctx context.Context, db *sql.DB) (ids []uint64, txHashes []string, err error)
CheckMissingTicketTransactions checks the tickets table for tickets that do NOT appear in the transactions table at all. This indicates likely database corruption.
func CheckMissingTickets ¶
func CheckMissingTickets(ctx context.Context, db *sql.DB) (ids []uint64, txTypes []int16, txHashes []string, err error)
CheckMissingTickets checks the transactions table for ticket transactions (with tx_type=1) that do NOT appear in the tickets table. This indicates likely database corruption.
func CheckSpentTicketsWithoutSpendInfo ¶
func CheckSpentTicketsWithoutSpendInfo(ctx context.Context, db *sql.DB) (ids, spendHeights, spendTxDbIDs []uint64, err error)
CheckSpentTicketsWithoutSpendInfo checks the tickets table for tickets that are flagged as spent, but which do not have set either a spend height or spending transaction row id. This indicates likely database corruption.
func CheckUnmatchedSpending ¶
func CheckUnmatchedSpending(ctx context.Context, db *sql.DB) (ids []uint64, addresses []string, err error)
CheckUnmatchedSpending checks the addresses table for spending rows where the matching (funding) txhash has not been set. The row IDs and addresses are returned. Non-zero length sizes is an indication of database corruption.
func CheckUnspentTicketsWithSpendInfo ¶
func CheckUnspentTicketsWithSpendInfo(ctx context.Context, db *sql.DB) (ids, spendHeights, spendTxDbIDs []uint64, err error)
CheckUnspentTicketsWithSpendInfo checks the tickets table for tickets that are flagged as unspent, but which have set either a spend height or spending transaction row id. This indicates likely database corruption.
func ClearTestingTable ¶
func Connect ¶
Connect opens a connection to a PostgreSQL database. The caller is responsible for calling Close() on the returned db when finished using it. The input host may be an IP address for TCP connection, or an absolute path to a UNIX domain socket. An empty string should be provided for UNIX sockets.
func CountMergedFundingTxns ¶
func CountMergedSpendingTxns ¶
func CountMergedTxns ¶
func CreateTable ¶
CreateTable creates one of the known tables by name.
func CreateTableLegacy ¶
CreateTableLegacy creates one of the known tables by name.
func CreateTables ¶
CreateTables creates all tables required by dcrdata if they do not already exist.
func CreateTablesLegacy ¶
CreateTablesLegacy creates all tables required by dcrdata if they do not already exist.
func DBBestBlock ¶
DBBestBlock retrieves the best block hash and height from the meta table. The error value will never be sql.ErrNoRows; instead with height == -1 indicating no data in the meta table.
func DeindexBlockTableOnHash ¶
func DeindexBlockTableOnTime ¶
func DeindexStatsTableOnHeight ¶
DeindexStatsTableOnHeight drops the index for the stats table over height.
func DeindexVinTableOnVins ¶
func DeindexVotesTableOnHash ¶
func DeleteBestBlock ¶
func DeleteBestBlock(ctx context.Context, db *sql.DB) (res dbtypes.DeletionSummary, height int64, hash string, err error)
DeleteBestBlock removes all data for the best block in the DB from every table via DeleteBlockData. The returned height and hash are for the best block after successful data removal, or the initial best block if removal fails as indicated by a non-nil error value.
func DeleteBlockData ¶
func DeleteBlockData(ctx context.Context, db *sql.DB, hash string) (res dbtypes.DeletionSummary, err error)
DeleteBlockData removes all data for the specified block from every table. Data are removed from tables in the following order: vins, vouts, addresses, transactions, tickets, votes, misses, blocks, block_chain. WARNING: When no indexes are present, these queries are VERY SLOW.
func DeleteBlocks ¶
func DeleteBlocks(ctx context.Context, N int64, db *sql.DB) (res []dbtypes.DeletionSummary, height int64, hash string, err error)
DeleteBlocks removes all data for the N best blocks in the DB from every table via repeated calls to DeleteBestBlock.
func DeleteDuplicateAgendaVotes ¶
DeleteDuplicateAgendaVotes deletes rows in agenda_votes with duplicate votes-row-id and agendas-row-id leaving the one row with the lowest id.
func DeleteDuplicateAgendas ¶
DeleteDuplicateAgendas deletes rows in agendas with duplicate names leaving the one row with the lowest id.
func DeleteDuplicateMisses ¶
DeleteDuplicateMisses deletes rows in misses with duplicate tx-block hashes, leaving the one row with the lowest id.
func DeleteDuplicateTickets ¶
DeleteDuplicateTickets deletes rows in tickets with duplicate tx-block hashes, leaving the one row with the lowest id.
func DeleteDuplicateTxns ¶
DeleteDuplicateTxns deletes rows in transactions with duplicate tx-block hashes, leaving the one row with the lowest id.
func DeleteDuplicateVins ¶
DeleteDuplicateVins deletes rows in vin with duplicate tx information, leaving the one row with the lowest id.
func DeleteDuplicateVinsCockroach ¶
DeleteDuplicateVinsCockroach deletes rows in vin with duplicate tx information, leaving the one row with the lowest id.
func DeleteDuplicateVotes ¶
DeleteDuplicateVotes deletes rows in votes with duplicate tx-block hashes, leaving the one row with the lowest id.
func DeleteDuplicateVouts ¶
DeleteDuplicateVouts deletes rows in vouts with duplicate tx information, leaving the one row with the lowest id.
func DeleteDuplicateVoutsCockroach ¶
DeleteDuplicateVoutsCockroach deletes rows in vouts with duplicate tx information, leaving the one row with the highest id.
func DisableLog ¶
func DisableLog()
DisableLog disables all library log output. Logging output is disabled by default until UseLogger is called.
func DropTables ¶
DropTables drops all of the tables internally recognized tables.
func DropTestingTable ¶
func DropTestingTable(db SqlExecutor) error
DropTestingTable drops only the "testing" table.
func ExistsIndex ¶
ExistsIndex checks if the specified index name exists.
func IBDComplete ¶
IBDComplete indicates whether initial block download was completed according to the meta.ibd_complete flag.
func IndexAddressTableOnAddress ¶
IndexAddressTableOnAddress creates the index for the addresses table over address.
func IndexAddressTableOnMatchingTxHash ¶
IndexAddressTableOnMatchingTxHash creates the index for the addresses table over matching transaction hash.
func IndexAddressTableOnTxHash ¶
IndexAddressTableOnTxHash creates the index for the addresses table over transaction hash.
func IndexAddressTableOnVoutID ¶
IndexAddressTableOnVoutID creates the index for the addresses table over vout row ID.
func IndexBlockTableOnHash ¶
func IndexBlockTableOnHeight ¶
func IndexBlockTableOnTime ¶
func IndexBlockTimeOnTableAddress ¶
IndexBlockTimeOnTableAddress creates the index for the addresses table over block time.
func IndexStatsTableOnHeight ¶
IndexStatsTableOnHeight creates the index for the stats table over height.
func IndexVinTableOnPrevOuts ¶
func IndexVinTableOnVins ¶
func IndexVotesTableOnBlockTime ¶
IndexVotesTableOnBlockTime improves the speed of "Vote Choices By Block" agendas chart query.
func IndexVotesTableOnHashes ¶
func IndexVotesTableOnHeight ¶
IndexVotesTableOnHeight improves the speed of "Cumulative Vote Choices" agendas chart query.
func IndexVoutTableOnTxHashIdx ¶
IndexVoutTableOnTxHashIdx creates the index for the addresses table over transaction hash and index.
func InsertAddressRow ¶
func InsertAddressRow(db *sql.DB, dbA *dbtypes.AddressRow, dupCheck, updateExistingRecords bool) (uint64, error)
InsertAddressRow inserts an AddressRow (input or output), returning the row ID in the addresses table of the inserted data.
func InsertAddressRows ¶
func InsertAddressRows(db *sql.DB, dbAs []*dbtypes.AddressRow, dupCheck, updateExistingRecords bool) ([]uint64, error)
InsertAddressRows inserts multiple transaction inputs or outputs for certain addresses ([]AddressRow). The row IDs of the inserted data are returned.
func InsertAddressRowsDbTx ¶
func InsertAddressRowsDbTx(dbTx *sql.Tx, dbAs []*dbtypes.AddressRow, dupCheck, updateExistingRecords bool) ([]uint64, error)
InsertAddressRowsDbTx is like InsertAddressRows, except that it takes a sql.Tx. The caller is required to Commit or Rollback the transaction depending on the returned error value.
func InsertBlock ¶
func InsertBlock(db *sql.DB, dbBlock *dbtypes.Block, isValid, isMainchain, checked bool) (uint64, error)
InsertBlock inserts the specified dbtypes.Block as with the given valid/mainchain status. If checked is true, an upsert statement is used so that a unique constraint violation will result in an update instead of attempting to insert a duplicate row. If checked is false and there is a duplicate row, an error will be returned.
func InsertBlockPrevNext ¶
InsertBlockPrevNext inserts a new row of the block_chain table.
func InsertBlockStats ¶
InsertBlockStats inserts the block stats into the stats table.
func InsertProposal ¶
func InsertProposal(db *sql.DB, tokenHash, author, commit string, timestamp time.Time, checked bool) (uint64, error)
InsertProposal adds the proposal details per commit to the proposal table.
func InsertProposalVote ¶
func InsertProposalVote(db *sql.DB, proposalRowID uint64, ticket, choice string, checked bool) (uint64, error)
InsertProposalVote add the proposal votes entries to the proposal_votes table.
func InsertSpendingAddressRow ¶
func InsertSpendingAddressRow(db *sql.DB, fundingTxHash string, fundingTxVoutIndex uint32, fundingTxTree int8, spendingTxHash string, spendingTxVinIndex uint32, vinDbID uint64, utxoData *dbtypes.UTXOData, checked, updateExisting, mainchain, valid bool, txType int16, updateFundingRow bool, spendingTXBlockTime dbtypes.TimeDef) (int64, uint64, bool, error)
InsertSpendingAddressRow inserts a new spending tx row, and updates any corresponding funding tx row.
func InsertTickets ¶
func InsertTickets(db *sql.DB, dbTxns []*dbtypes.Tx, txDbIDs []uint64, checked, updateExistingRecords bool) ([]uint64, []*dbtypes.Tx, error)
InsertTickets takes a slice of *dbtypes.Tx and corresponding DB row IDs for transactions, extracts the tickets, and inserts the tickets into the database. Outputs are a slice of DB row IDs of the inserted tickets, and an error.
func InsertTxns ¶
func InsertTxnsDbTxn ¶
func InsertTxnsStmt ¶
func InsertVin ¶
func InsertVin(db *sql.DB, dbVin dbtypes.VinTxProperty, checked bool, updateOnConflict ...bool) (id uint64, err error)
InsertVin either inserts, attempts to insert, or upserts the given vin data into the vins table. If checked=false, an unconditional insert as attempted, which may result in a violation of a unique index constraint (error). If checked=true, a constraint violation may be handled in one of two ways: update the conflicting row (upsert), or do nothing. In all cases, the id of the new/updated/conflicting row is returned. The updateOnConflict argument may be omitted, in which case an upsert will be favored over no nothing, but only if checked=true.
func InsertVins ¶
func InsertVins(db *sql.DB, dbVins dbtypes.VinTxPropertyARRAY, checked bool, updateOnConflict ...bool) ([]uint64, error)
InsertVins is like InsertVin, except that it operates on a slice of vin data.
func InsertVinsDbTxn ¶
func InsertVinsDbTxn(dbTx *sql.Tx, dbVins dbtypes.VinTxPropertyARRAY, checked bool, doUpsert bool) ([]uint64, error)
InsertVinsDbTxn is like InsertVins, except that it takes a sql.Tx. The caller is required to Commit or Rollback the transaction depending on the returned error value.
func InsertVinsStmt ¶
func InsertVinsStmt(stmt *sql.Stmt, dbVins dbtypes.VinTxPropertyARRAY, checked bool, doUpsert bool) ([]uint64, error)
InsertVinsStmt is like InsertVins, except that it takes a sql.Stmt. The caller is required to Close the transaction.
func InsertVotes ¶
func InsertVotes(db *sql.DB, dbTxns []*dbtypes.Tx, _ []uint64, fTx *TicketTxnIDGetter, msgBlock *MsgBlockPG, checked, updateExistingRecords bool, params *chaincfg.Params, votesMilestones *dbtypes.BlockChainData) ([]uint64, []*dbtypes.Tx, []string, []uint64, map[string]uint64, error)
InsertVotes takes a slice of *dbtypes.Tx, which must contain all the stake transactions in a block, extracts the votes, and inserts the votes into the database. The input MsgBlockPG contains each stake transaction's MsgTx in STransactions, and they must be in the same order as the dbtypes.Tx slice.
This function also identifies and stores missed votes using msgBlock.Validators, which lists the ticket hashes called to vote on the previous block (msgBlock.WinningTickets are the lottery winners to be mined in the next block).
The TicketTxnIDGetter is used to get the spent tickets' row IDs. The get function, TxnDbID, is called with the expire argument set to false, so that subsequent cache lookups by other consumers will succeed.
votesMilestones holds up-to-date blockchain info deployment data.
It also updates the agendas and the agenda_votes tables. Agendas table holds the high level information about all agendas that is contained in the votingMilestones.MileStone (i.e. Agenda Name, Status and LockedIn, Activated & HardForked heights). Agenda_votes table hold the agendas vote choices information and references to the agendas and votes tables.
Outputs are slices of DB row IDs for the votes and misses, and an error.
func InsertVout ¶
func InsertVout(db *sql.DB, dbVout *dbtypes.Vout, checked bool, updateOnConflict ...bool) (uint64, error)
InsertVout either inserts, attempts to insert, or upserts the given vout data into the vouts table. If checked=false, an unconditional insert as attempted, which may result in a violation of a unique index constraint (error). If checked=true, a constraint violation may be handled in one of two ways: update the conflicting row (upsert), or do nothing. In all cases, the id of the new/updated/conflicting row is returned. The updateOnConflict argument may be omitted, in which case an upsert will be favored over no nothing, but only if checked=true.
func InsertVouts ¶
func InsertVouts(db *sql.DB, dbVouts []*dbtypes.Vout, checked bool, updateOnConflict ...bool) ([]uint64, []dbtypes.AddressRow, error)
InsertVouts is like InsertVout, except that it operates on a slice of vout data.
func InsertVoutsDbTxn ¶
func InsertVoutsDbTxn(dbTx *sql.Tx, dbVouts []*dbtypes.Vout, checked bool, doUpsert bool) ([]uint64, []dbtypes.AddressRow, error)
InsertVoutsDbTxn is like InsertVouts, except that it takes a sql.Tx. The caller is required to Commit or Rollback the transaction depending on the returned error value.
func InsertVoutsStmt ¶
func InsertVoutsStmt(stmt *sql.Stmt, dbVouts []*dbtypes.Vout, checked bool, doUpsert bool) ([]uint64, []dbtypes.AddressRow, error)
InsertVoutsStmt is like InsertVouts, except that it takes a sql.Stmt. The caller is required to Close the statement.
func IsRetryError ¶
IsRetryError checks if an error is a retryError type.
func IsUniqueIndex ¶
IsUniqueIndex checks if the given index name is defined as UNIQUE.
func MakeCsvAddressRows ¶
func MakeCsvAddressRows(rows []*dbtypes.AddressRow) [][]string
MakeCsvAddressRows converts an AddressRow slice into a [][]string, including column headers, suitable for saving to CSV.
func MakeCsvAddressRowsCompact ¶
func MakeCsvAddressRowsCompact(rows []*dbtypes.AddressRowCompact) [][]string
func RetrieveAddressBalance ¶
func RetrieveAddressBalance(ctx context.Context, db *sql.DB, address string) (balance *dbtypes.AddressBalance, err error)
RetrieveAddressBalance gets the numbers of spent and unspent outpoints for the given address, the total amounts spent and unspent, the number of distinct spending transactions, and the fraction spent to and received from stake-related transactions.
func RetrieveAddressDbUTXOs ¶
func RetrieveAddressDbUTXOs(ctx context.Context, db *sql.DB, address string) ([]*dbtypes.AddressTxnOutput, error)
RetrieveAddressDbUTXOs gets the unspent transaction outputs (UTXOs) paying to the specified address as a []*dbtypes.AddressTxnOutput. The input current block height is used to compute confirmations of the located transactions.
func RetrieveAddressIDsByOutpoint ¶
func RetrieveAddressIDsByOutpoint(ctx context.Context, db *sql.DB, txHash string, voutIndex uint32) ([]uint64, []string, int64, error)
RetrieveAddressIDsByOutpoint gets all address row IDs, addresses, and values for a given outpoint.
func RetrieveAddressSpent ¶
func RetrieveAddressTxns ¶
func RetrieveAddressTxnsOrdered ¶
func RetrieveAddressTxnsOrdered(ctx context.Context, db *sql.DB, addresses []string, recentBlockTime int64) (txs, recenttxs []chainhash.Hash, err error)
RetrieveAddressTxnsOrdered will get all transactions for addresses provided and return them sorted by time in descending order. It will also return a short list of recently (defined as greater than recentBlockHeight) confirmed transactions that can be used to validate mempool status.
func RetrieveAddressUTXOs ¶
func RetrieveAddressUTXOs(ctx context.Context, db *sql.DB, address string, currentBlockHeight int64) ([]*apitypes.AddressTxnOutput, error)
RetrieveAddressUTXOs gets the unspent transaction outputs (UTXOs) paying to the specified address as a []*apitypes.AddressTxnOutput. The input current block height is used to compute confirmations of the located transactions.
func RetrieveAddressUnspent ¶
func RetrieveAllAddressMergedTxns ¶
func RetrieveAllAddressMergedTxns(ctx context.Context, db *sql.DB, address string, onlyValidMainchain bool) ([]uint64, []*dbtypes.AddressRow, error)
RetrieveAllAddressMergedTxns retrieves all merged rows of the address table pertaining to the given address. Specify only valid_mainchain=true rows via the onlyValidMainchain argument.
func RetrieveAllAddressTxns ¶
func RetrieveAllAddressTxns(ctx context.Context, db *sql.DB, address string) ([]*dbtypes.AddressRow, error)
RetrieveAllAddressTxns retrieves all rows of the address table pertaining to the given address.
func RetrieveAllMainchainAddressTxns ¶
func RetrieveAllMainchainAddressTxns(ctx context.Context, db *sql.DB, address string) ([]*dbtypes.AddressRow, error)
RetrieveAllMainchainAddressTxns retrieves all non-merged and valid_mainchain rows of the address table pertaining to the given address.
func RetrieveAllRevokes ¶
func RetrieveAllRevokes(ctx context.Context, db *sql.DB) (ids []uint64, hashes []string, heights []int64, vinDbIDs []uint64, err error)
RetrieveAllRevokes gets for all ticket revocations the row IDs (primary keys), transaction hashes, block heights. It also gets the row ID in the vins table for the first input of the revocation transaction, which should correspond to the stakesubmission previous outpoint of the ticket purchase. This function is used in UpdateSpendingInfoInAllTickets, so it should not be subject to timeouts.
func RetrieveAllVinDbIDs ¶
RetrieveAllVinDbIDs gets every row ID (the primary keys) for the vins table. This function is used in UpdateSpendingInfoInAllAddresses, so it should not be subject to timeouts.
func RetrieveAllVotesDbIDsHeightsTicketDbIDs ¶
func RetrieveAllVotesDbIDsHeightsTicketDbIDs(ctx context.Context, db *sql.DB) (ids []uint64, heights []int64, ticketDbIDs []uint64, err error)
RetrieveAllVotesDbIDsHeightsTicketDbIDs gets for all votes the row IDs (primary keys) in the votes table, the block heights, and the row IDs in the tickets table of the spent tickets. This function is used in UpdateSpendingInfoInAllTickets, so it should not be subject to timeouts.
func RetrieveBestBlock ¶
RetrieveBestBlock gets the best block height and hash (main chain only). If there are no results from the query, the height is -1 and err is nil.
func RetrieveBestBlockHeight ¶
func RetrieveBestBlockHeight(ctx context.Context, db *sql.DB) (height uint64, hash string, id uint64, err error)
RetrieveBestBlockHeight gets the best block height and hash (main chain only). Be sure to check for sql.ErrNoRows.
func RetrieveBestBlockHeightAny ¶
func RetrieveBestBlockHeightAny(ctx context.Context, db *sql.DB) (height uint64, hash string, id uint64, err error)
RetrieveBestBlockHeightAny gets the best block height, including side chains.
func RetrieveBlockChainDbID ¶
RetrieveBlockChainDbID retrieves the row id in the block_chain table of the block with the given hash, if it exists (be sure to check error against sql.ErrNoRows!).
func RetrieveBlockFlags ¶
func RetrieveBlockFlags(ctx context.Context, db *sql.DB, hash string) (isValid bool, isMainchain bool, err error)
RetrieveBlockFlags retrieves the block's is_valid and is_mainchain flags.
func RetrieveBlockHash ¶
RetrieveBlockHash retrieves the hash of the block at the given height, if it exists (be sure to check error against sql.ErrNoRows!). WARNING: this returns the most recently added block at this height, but there may be others.
func RetrieveBlockHeight ¶
RetrieveBlockHeight retrieves the height of the block with the given hash, if it exists (be sure to check error against sql.ErrNoRows!).
func RetrieveBlockSize ¶
RetrieveBlockSize return the size of block at height ind.
func RetrieveBlockSizeRange ¶
RetrieveBlockSizeRange returns an array of block sizes for block range ind0 to ind1
func RetrieveBlockStatus ¶
func RetrieveBlockStatus(ctx context.Context, db *sql.DB, hash string) (bs dbtypes.BlockStatus, err error)
RetrieveBlockStatus retrieves the block chain status for the block with the specified hash.
func RetrieveBlockSummary ¶
func RetrieveBlockSummary(ctx context.Context, db *sql.DB, ind int64) (*apitypes.BlockDataBasic, error)
RetrieveBlockSummary fetches basic block data for block ind.
func RetrieveBlockSummaryByHash ¶
func RetrieveBlockSummaryByHash(ctx context.Context, db *sql.DB, hash string) (*apitypes.BlockDataBasic, error)
RetrieveBlockSummaryByHash fetches basic block data for block hash.
func RetrieveBlockSummaryByTimeRange ¶
func RetrieveBlockSummaryByTimeRange(ctx context.Context, db *sql.DB, minTime, maxTime int64, limit int) ([]dbtypes.BlockDataBasic, error)
RetrieveBlockSummaryByTimeRange retrieves the slice of block summaries for the given time range. The limit specifies the number of most recent block summaries to return. A limit of 0 indicates all blocks in the time range should be included.
func RetrieveBlockSummaryRange ¶
func RetrieveBlockSummaryRange(ctx context.Context, db *sql.DB, ind0, ind1 int64) ([]*apitypes.BlockDataBasic, error)
RetrieveBlockSummaryRange fetches basic block data for the blocks in range (ind0, ind1).
func RetrieveBlockSummaryRangeStepped ¶
func RetrieveBlockSummaryRangeStepped(ctx context.Context, db *sql.DB, ind0, ind1, step int64) ([]*apitypes.BlockDataBasic, error)
RetrieveBlockSummaryRangeStepped fetches basic block data for every step'th block in range (ind0, ind1).
func RetrieveBlockTimeByHeight ¶
func RetrieveBlockTimeByHeight(ctx context.Context, db *sql.DB, idx int64) (time dbtypes.TimeDef, err error)
RetrieveBlockTimeByHeight retrieves time hash of the main chain block at the given height, if it exists (be sure to check error against sql.ErrNoRows!).
func RetrieveBlockVoteCount ¶
func RetrieveBlockVoteCount(ctx context.Context, db *sql.DB, hash string) (numVotes int16, err error)
RetrieveBlockVoteCount gets the number of votes mined in a block.
func RetrieveBlocksHashesAll ¶
RetrieveBlocksHashesAll retrieve the hash of every block in the blocks table, ordered by their row ID.
func RetrieveDbTxByHash ¶
func RetrieveDbTxByHash(ctx context.Context, db *sql.DB, txHash string) (id uint64, dbTx *dbtypes.Tx, err error)
RetrieveDbTxByHash retrieves a row of the transactions table corresponding to the given transaction hash. Stake-validated transactions in mainchain blocks are chosen first. This function is used by FillAddressTransactions, an important component of the addresses page.
func RetrieveDbTxsByHash ¶
func RetrieveDbTxsByHash(ctx context.Context, db *sql.DB, txHash string) (ids []uint64, dbTxs []*dbtypes.Tx, err error)
RetrieveDbTxsByHash retrieves all the rows of the transactions table, including the primary keys/ids, for the given transaction hash. This function is used by the transaction page via ChainDB.Transaction.
func RetrieveDiff ¶
RetrieveDiff returns the difficulty for the first block mined after the provided UNIX timestamp.
func RetrieveDisapprovedBlocks ¶
func RetrieveDisapprovedBlocks(ctx context.Context, db *sql.DB) (blocks []*dbtypes.BlockStatus, err error)
RetrieveDisapprovedBlocks retrieves the block chain status for all blocks that had their regular transactions invalidated by stakeholder disapproval.
func RetrieveFullTxByHash ¶
func RetrieveFullTxByHash(ctx context.Context, db *sql.DB, txHash string) (id uint64, blockHash string, blockHeight int64, blockTime, timeVal dbtypes.TimeDef, txType int16, version int32, tree int8, blockInd uint32, lockTime, expiry int32, size uint32, spent, sent, fees int64, mixCount int32, mixDenom int64, numVin int32, vinDbIDs []int64, numVout int32, voutDbIDs []int64, isValidBlock, isMainchainBlock bool, err error)
RetrieveFullTxByHash gets all data from the transactions table for the transaction specified by its hash. Transactions in valid and mainchain blocks are chosen first. See also RetrieveDbTxByHash.
func RetrieveFundingOutpointByTxIn ¶
func RetrieveFundingOutpointByTxIn(ctx context.Context, db *sql.DB, txHash string, vinIndex uint32) (id uint64, tx string, index uint32, tree int8, err error)
RetrieveFundingOutpointByTxIn gets the previous outpoint for a transaction input specified by transaction hash and input index.
func RetrieveFundingOutpointByVinID ¶
func RetrieveFundingOutpointByVinID(ctx context.Context, db *sql.DB, vinDbID uint64) (tx string, index uint32, tree int8, err error)
RetrieveFundingOutpointByVinID gets the previous outpoint for a transaction input specified by row ID in the vins table.
func RetrieveFundingOutpointIndxByVinID ¶
func RetrieveFundingOutpointIndxByVinID(ctx context.Context, db *sql.DB, vinDbID uint64) (idx uint32, err error)
RetrieveFundingOutpointIndxByVinID gets the transaction output index of the previous outpoint for a transaction input specified by row ID in the vins table.
func RetrieveFundingTxByTxIn ¶
func RetrieveFundingTxByTxIn(ctx context.Context, db *sql.DB, txHash string, vinIndex uint32) (id uint64, tx string, err error)
RetrieveFundingTxByTxIn gets the transaction hash of the previous outpoint for a transaction input specified by hash and input index.
func RetrieveFundingTxByVinDbID ¶
func RetrieveFundingTxByVinDbID(ctx context.Context, db *sql.DB, vinDbID uint64) (tx string, err error)
RetrieveFundingTxByVinDbID gets the transaction hash of the previous outpoint for a transaction input specified by row ID in the vins table. This function is used only in UpdateSpendingInfoInAllTickets, so it should not be subject to timeouts.
func RetrieveLatestBlockSummary ¶
RetrieveLatestBlockSummary returns the block summary for the best block.
func RetrieveMissForTicket ¶
func RetrieveMissForTicket(ctx context.Context, db *sql.DB, ticketHash string) (blockHash string, blockHeight int64, err error)
RetrieveMissForTicket gets the mainchain block in which the ticket was called to place a vote on the previous block. The previous block that would have been validated by the vote is not the block data that is returned.
func RetrieveMissedVotesInBlock ¶
func RetrieveMissedVotesInBlock(ctx context.Context, db *sql.DB, blockHash string) (ticketHashes []string, err error)
RetrieveMissedVotesInBlock gets a list of ticket hashes that were called to vote in the given block, but missed their vote.
func RetrieveMissesForTicket ¶
func RetrieveMissesForTicket(ctx context.Context, db *sql.DB, ticketHash string) (blockHashes []string, blockHeights []int64, err error)
RetrieveMissesForTicket gets all of the blocks in which the ticket was called to place a vote on the previous block. The previous block that would have been validated by the vote is not the block data that is returned.
func RetrievePGVersion ¶
RetrievePGVersion retrieves the version of the connected PostgreSQL server.
func RetrievePkScriptByVinID ¶
func RetrievePoolInfo ¶
RetrievePoolInfo returns ticket pool info for block height ind
func RetrievePoolInfoByHash ¶
func RetrievePoolInfoByHash(ctx context.Context, db *sql.DB, hash string) (*apitypes.TicketPoolInfo, error)
RetrievePoolInfoByHash returns ticket pool info for blockhash hash.
func RetrievePoolInfoRange ¶
func RetrievePoolInfoRange(ctx context.Context, db *sql.DB, ind0, ind1 int64) ([]apitypes.TicketPoolInfo, []string, error)
RetrievePoolInfoRange returns an array of apitypes.TicketPoolInfo for block range ind0 to ind1 and a non-nil error on success
func RetrievePoolValAndSizeRange ¶
func RetrievePoolValAndSizeRange(ctx context.Context, db *sql.DB, ind0, ind1 int64) ([]float64, []uint32, error)
RetrievePoolValAndSizeRange returns an array each of the pool values and sizes for block range ind0 to ind1.
func RetrievePreviousHashByBlockHash ¶
func RetrievePreviousHashByBlockHash(ctx context.Context, db *sql.DB, hash string) (previousHash string, err error)
RetrievePreviousHashByBlockHash retrieves the previous block hash for the given block from the blocks table.
func RetrieveSBitsByHash ¶
RetrieveSBitsByHash returns the stake difficulty in atoms for the specified block.
func RetrieveSDiff ¶
RetrieveSDiff returns the stake difficulty for block at the specified chain height.
func RetrieveSDiffRange ¶
RetrieveSDiffRange returns an array of stake difficulties for block range ind0 to ind1.
func RetrieveSideChainBlocks ¶
func RetrieveSideChainBlocks(ctx context.Context, db *sql.DB) (blocks []*dbtypes.BlockStatus, err error)
RetrieveSideChainBlocks retrieves the block chain status for all known side chain blocks.
func RetrieveSideChainTips ¶
func RetrieveSideChainTips(ctx context.Context, db *sql.DB) (blocks []*dbtypes.BlockStatus, err error)
RetrieveSideChainTips retrieves the block chain status for all known side chain tip blocks.
func RetrieveSpendingTxByTxOut ¶
func RetrieveSpendingTxByTxOut(ctx context.Context, db *sql.DB, txHash string, voutIndex uint32) (id uint64, tx string, vin uint32, tree int8, err error)
RetrieveSpendingTxByTxOut gets any spending transaction input info for a previous outpoint specified by funding transaction hash and vout number. This function is called by SpendingTransaction, an important part of the address page loading.
func RetrieveSpendingTxByVinID ¶
func RetrieveSpendingTxByVinID(ctx context.Context, db *sql.DB, vinDbID uint64) (tx string, vinIndex uint32, tree int8, err error)
RetrieveSpendingTxByVinID gets the spending transaction input (hash, vin number, and tx tree) for the transaction input specified by row ID in the vins table.
func RetrieveSpendingTxsByFundingTx ¶
func RetrieveSpendingTxsByFundingTx(ctx context.Context, db *sql.DB, fundingTxID string) (dbIDs []uint64, txns []string, vinInds []uint32, voutInds []uint32, err error)
RetrieveSpendingTxsByFundingTx gets info on all spending transaction inputs for the given funding transaction specified by DB row ID. This function is called by SpendingTransactions, an important part of the transaction page loading, among other functions..
func RetrieveSpendingTxsByFundingTxWithBlockHeight ¶
func RetrieveSpendingTxsByFundingTxWithBlockHeight(ctx context.Context, db *sql.DB, fundingTxID string) (aSpendByFunHash []*apitypes.SpendByFundingHash, err error)
RetrieveSpendingTxsByFundingTxWithBlockHeight will retrieve all transactions, indexes and block heights funded by a specific transaction. This function is used by the DCR to Insight transaction converter.
func RetrieveSysSettingSyncCommit ¶
RetrieveSysSettingSyncCommit retrieves the synchronous_commit setting.
func RetrieveTicketIDByHashNoCancel ¶
RetrieveTicketIDByHashNoCancel gets the db row ID (primary key) in the tickets table for the given ticket hash. As the name implies, this query should not accept a cancelable context.
func RetrieveTicketIDsByHashes ¶
func RetrieveTicketIDsByHashes(ctx context.Context, db *sql.DB, ticketHashes []string) (ids []uint64, err error)
RetrieveTicketIDsByHashes gets the db row IDs (primary keys) in the tickets table for the given ticket purchase transaction hashes.
func RetrieveTicketInfoByHash ¶
func RetrieveTicketInfoByHash(ctx context.Context, db *sql.DB, ticketHash string) (spendStatus dbtypes.TicketSpendType, poolStatus dbtypes.TicketPoolStatus, purchaseBlock, lotteryBlock *apitypes.TinyBlock, spendTxid string, err error)
RetrieveTicketInfoByHash retrieves the ticket spend and pool statuses as well as the purchase and spending block info and spending txid.
func RetrieveTicketStatusByHash ¶
func RetrieveTicketStatusByHash(ctx context.Context, db *sql.DB, ticketHash string) (id uint64, spendStatus dbtypes.TicketSpendType, poolStatus dbtypes.TicketPoolStatus, err error)
RetrieveTicketStatusByHash gets the spend status and ticket pool status for the given ticket hash.
func RetrieveTxByHash ¶
func RetrieveTxnsBlocks ¶
func RetrieveTxnsBlocks(ctx context.Context, db *sql.DB, txHash string) (blockHashes []string, blockHeights, blockIndexes []uint32, areValid, areMainchain []bool, err error)
RetrieveTxnsBlocks retrieves for the specified transaction hash the following data for each block containing the transactions: block_hash, block_index, is_valid, is_mainchain.
func RetrieveTxnsVinsByBlock ¶
func RetrieveTxnsVinsByBlock(ctx context.Context, db *sql.DB, blockHash string) (vinDbIDs []dbtypes.UInt64Array, areValid []bool, areMainchain []bool, err error)
RetrieveTxnsVinsByBlock retrieves for all the transactions in the specified block the vin_db_ids arrays, is_valid, and is_mainchain. This function is used by handleVinsTableMainchainupgrade, so it should not be subject to timeouts.
func RetrieveTxnsVinsVoutsByBlock ¶
func RetrieveTxnsVinsVoutsByBlock(ctx context.Context, db *sql.DB, blockHash string, onlyRegular bool) (vinDbIDs, voutDbIDs []dbtypes.UInt64Array, areMainchain []bool, err error)
RetrieveTxnsVinsVoutsByBlock retrieves for all the transactions in the specified block the vin_db_ids and vout_db_ids arrays. This function is used only by UpdateLastAddressesValid and other setting functions, where it should not be subject to a timeout.
func RetrieveTxsBestBlockMainchain ¶
func RetrieveTxsBestBlockMainchain(ctx context.Context, db *sql.DB) (height int64, hash string, err error)
RetrieveTxsBestBlockMainchain returns the best mainchain block's height from the transactions table. If the table is empty, a height of -1, an empty hash string, and a nil error are returned
func RetrieveTxsBlocksAboveHeight ¶
func RetrieveTxsBlocksAboveHeight(ctx context.Context, db *sql.DB, height int64) (heights []int64, hashes []string, err error)
RetrieveTxsBlocksAboveHeight returns all distinct mainchain block heights and hashes referenced in the transactions table above the given height.
func RetrieveTxsByBlockHash ¶
func RetrieveTxsByBlockHash(ctx context.Context, db *sql.DB, blockHash string) (ids []uint64, txs []string, blockInds []uint32, trees []int8, blockTimes []dbtypes.TimeDef, err error)
RetrieveTxsByBlockHash retrieves all transactions in a given block. This is used by update functions, so care should be taken to not timeout in these cases.
func RetrieveUTXOs ¶
RetrieveUTXOs gets the entire UTXO set from the vouts and vins tables.
func RetrieveUTXOsByVinsJoin ¶
func RetrieveUnspentTickets ¶
func RetrieveUnspentTickets(ctx context.Context, db *sql.DB) (ids []uint64, hashes []string, err error)
RetrieveUnspentTickets gets all unspent tickets.
func RetrieveVinByID ¶
func RetrieveVinByID(ctx context.Context, db *sql.DB, vinDbID uint64) (prevOutHash string, prevOutVoutInd uint32, prevOutTree int8, txHash string, txVinInd uint32, txTree int8, valueIn int64, err error)
RetrieveVinByID gets from the vins table for the provided row ID.
func RetrieveVinsByIDs ¶
func RetrieveVinsByIDs(ctx context.Context, db *sql.DB, vinDbIDs []uint64) ([]dbtypes.VinTxProperty, error)
RetrieveVinsByIDs retrieves vin details for the rows of the vins table specified by the provided row IDs. This function is an important part of the transaction page.
func RetrieveVoutValue ¶
func RetrieveVoutValues ¶
func RetrieveVoutsByIDs ¶
func RetrieveVoutsByIDs(ctx context.Context, db *sql.DB, voutDbIDs []uint64) ([]dbtypes.Vout, error)
RetrieveVoutsByIDs retrieves vout details for the rows of the vouts table specified by the provided row IDs. This function is an important part of the transaction page.
func SetDBBestBlock ¶
SetDBBestBlock sets the best block hash and height in the meta table.
func SetIBDComplete ¶
func SetIBDComplete(db SqlExecutor, ibdComplete bool) error
SetIBDComplete set the ibd_complete (Initial Block Download complete) flag in the meta table.
func SetMainchainByBlockHash ¶
func SetMainchainByBlockHash(db *sql.DB, hash string, isMainchain bool) (previousHash string, err error)
SetMainchainByBlockHash is used to set the is_mainchain flag for the given block. This is required to handle a reorganization.
func SetPoolStatusForTickets ¶
func SetPoolStatusForTickets(db *sql.DB, ticketDbIDs []uint64, poolStatuses []dbtypes.TicketPoolStatus) (int64, error)
SetPoolStatusForTickets sets the ticket pool status for the tickets specified by db row ID.
func SetPoolStatusForTicketsByHash ¶
func SetPoolStatusForTicketsByHash(db *sql.DB, tickets []string, poolStatuses []dbtypes.TicketPoolStatus) (int64, error)
SetPoolStatusForTicketsByHash sets the ticket pool status for the tickets specified by ticket purchase transaction hash.
func SetSpendingForFundingOP ¶
func SetSpendingForFundingOP(db SqlExecutor, fundingTxHash string, fundingTxVoutIndex uint32, spendingTxHash string, _ uint32, forMainchain bool) (int64, error)
SetSpendingForFundingOP updates funding rows of the addresses table with the provided spending transaction output info. Only update rows of mainchain or side chain transactions according to forMainchain. Technically forMainchain=false also permits updating rows that are stake invalidated, but consensus-validated transactions cannot spend outputs from stake-invalidated transactions so the funding tx must not be invalid.
func SetSpendingForTickets ¶
func SetSpendingForTickets(db *sql.DB, ticketDbIDs, spendDbIDs []uint64, blockHeights []int64, spendTypes []dbtypes.TicketSpendType, poolStatuses []dbtypes.TicketPoolStatus) (int64, error)
SetSpendingForTickets sets the spend type, spend height, spending transaction row IDs (in the table relevant to the spend type), and ticket pool status for the given tickets specified by their db row IDs.
func SetSpendingForVinDbID ¶
SetSpendingForVinDbID updates rows of the addresses table with spending information from the row of the vins table specified by vinDbID. This does not insert the spending transaction into the addresses table.
func SetSpendingForVinDbIDs ¶
SetSpendingForVinDbIDs updates rows of the addresses table with spending information from the rows of the vins table specified by vinDbIDs. This does not insert the spending transaction into the addresses table.
func SetSynchronousCommit ¶
func SetSynchronousCommit(db SqlExecutor, syncCommit string) error
SetSynchronousCommit sets the synchronous_commit setting.
func TableExists ¶
TableExists checks if the specified table exists.
func TableVersions ¶
func TableVersions(db *sql.DB) map[string]TableVersion
TableVersions retrieve and maps the tables names in the auxiliary db to their current table versions.
func TicketPoolData ¶
func TicketPoolData(interval dbtypes.TimeBasedGrouping, height int64) (timeGraph *dbtypes.PoolTicketsData, priceGraph *dbtypes.PoolTicketsData, donutChart *dbtypes.PoolTicketsData, actualHeight int64, intervalFound, isStale bool)
TicketPoolData is a thread-safe way to access the ticketpool graphs data stored in the cache.
func UpdateAddressesMainchainByIDs ¶
func UpdateAddressesMainchainByIDs(db SqlExecutor, vinsBlk, voutsBlk []dbtypes.UInt64Array, isValidMainchain bool) (numSpendingRows, numFundingRows int64, err error)
UpdateAddressesMainchainByIDs sets the valid_mainchain column for the addresses specified by their vin (spending) or vout (funding) row IDs.
func UpdateBlockNext ¶
func UpdateBlockNext(db SqlExecutor, blockDbID uint64, next string) error
UpdateBlockNext sets the next block's hash for the specified row of the block_chain table specified by DB row ID.
func UpdateBlockNextByHash ¶
func UpdateBlockNextByHash(db SqlExecutor, this, next string) error
UpdateBlockNextByHash sets the next block's hash for the block in the block_chain table specified by hash.
func UpdateBlockNextByNextHash ¶
func UpdateBlockNextByNextHash(db SqlExecutor, currentNext, newNext string) error
UpdateBlockNextByNextHash sets the next block's hash for the block in the block_chain table with a current next_hash specified by hash.
func UpdateLastAddressesValid ¶
UpdateLastAddressesValid sets valid_mainchain as specified by isValid for addresses table rows pertaining to regular (non-stake) transactions found in the given block.
func UpdateLastBlockValid ¶
func UpdateLastBlockValid(db SqlExecutor, blockDbID uint64, isValid bool) error
UpdateLastBlockValid updates the is_valid column of the block specified by the row id for the blocks table.
func UpdateLastVins ¶
UpdateLastVins updates the is_valid and is_mainchain columns in the vins table for all of the transactions in the block specified by the given block hash.
func UpdateTicketPoolData ¶
func UpdateTicketPoolData(interval dbtypes.TimeBasedGrouping, timeGraph *dbtypes.PoolTicketsData, priceGraph *dbtypes.PoolTicketsData, donutcharts *dbtypes.PoolTicketsData, height int64)
UpdateTicketPoolData updates the ticket pool cache with the latest data fetched. This is a thread-safe way to update ticket pool cache data. TryLock helps avoid stacking calls to update the cache.
func UpdateTicketsMainchain ¶
func UpdateTicketsMainchain(db SqlExecutor, blockHash string, isMainchain bool) (int64, error)
UpdateTicketsMainchain sets the is_mainchain column for the tickets in the specified block.
func UpdateTransactionsMainchain ¶
func UpdateTransactionsMainchain(db *sql.DB, blockHash string, isMainchain bool) (int64, []uint64, error)
UpdateTransactionsMainchain sets the is_mainchain column for the transactions in the specified block.
func UpdateTransactionsValid ¶
UpdateTransactionsValid sets the is_valid column of the transactions table for the regular (non-stake) transactions in the specified block.
func UpdateVotesMainchain ¶
func UpdateVotesMainchain(db SqlExecutor, blockHash string, isMainchain bool) (int64, error)
UpdateVotesMainchain sets the is_mainchain column for the votes in the specified block.
Types ¶
type BestBlock ¶
type BestBlock struct {
// contains filtered or unexported fields
}
BestBlock is mutex-protected block hash and height.
func (*BestBlock) Hash ¶
func (block *BestBlock) Hash() *chainhash.Hash
Hash uses the last stored block hash.
type BlockGetter ¶
type BlockGetter interface { // rpcutils.BlockFetcher implements GetBestBlock, GetBlock, GetBlockHash, // and GetBlockHeaderVerbose. rpcutils.BlockFetcher // GetBlockChainInfo is required for a legacy upgrade involving agendas. GetBlockChainInfo() (*chainjson.GetBlockChainInfoResult, error) }
BlockGetter implements a few basic blockchain data retrieval functions. It is like rpcutils.BlockFetcher except that it must also implement GetBlockChainInfo.
type ChainDB ¶
type ChainDB struct { AddressCache *cache.AddressCache CacheLocks cacheLocks InBatchSync bool InReorg bool MPC *mempool.MempoolDataCache // BlockCache stores apitypes.BlockDataBasic and apitypes.StakeInfoExtended // in StoreBlock for quick retrieval without a DB query. BlockCache *apitypes.APICache Client *rpcclient.Client // contains filtered or unexported fields }
ChainDB provides an interface for storing and manipulating extracted blockchain data in a PostgreSQL database.
func NewChainDB ¶
func NewChainDB(cfg *ChainDBCfg, stakeDB *stakedb.StakeDatabase, mp rpcutils.MempoolAddressChecker, parser ProposalsFetcher, client *rpcclient.Client, shutdown func()) (*ChainDB, error)
NewChainDB constructs a ChainDB for the given connection and Decred network parameters. By default, duplicate row checks on insertion are enabled. See NewChainDBWithCancel to enable context cancellation of running queries. proposalsUpdateChan is used to manage politeia update notifications trigger between the notifier and the handler method. A non-nil BlockGetter is only needed if database upgrades are required.
func NewChainDBWithCancel ¶
func NewChainDBWithCancel(ctx context.Context, cfg *ChainDBCfg, stakeDB *stakedb.StakeDatabase, mp rpcutils.MempoolAddressChecker, parser ProposalsFetcher, client *rpcclient.Client, shutdown func()) (*ChainDB, error)
NewChainDBWithCancel constructs a cancellation-capable ChainDB for the given connection and Decred network parameters. By default, duplicate row checks on insertion are enabled. See EnableDuplicateCheckOnInsert to change this behavior. NewChainDB creates context that cannot be cancelled (context.Background()) except by the pg timeouts. If it is necessary to cancel queries with CTRL+C, for example, use NewChainDBWithCancel. A non-nil BlockGetter is only needed if database upgrades are required.
func (*ChainDB) AddressBalance ¶
func (pgb *ChainDB) AddressBalance(address string) (bal *dbtypes.AddressBalance, cacheUpdated bool, err error)
AddressBalance attempts to retrieve balance information for a specific address from cache, and if cache is stale or missing data for the address, a DB query is used. A successful DB query will freshen the cache.
func (*ChainDB) AddressData ¶
func (pgb *ChainDB) AddressData(address string, limitN, offsetAddrOuts int64, txnType dbtypes.AddrTxnViewType) (addrData *dbtypes.AddressInfo, err error)
AddressData returns comprehensive, paginated information for an address.
func (*ChainDB) AddressHistory ¶
func (pgb *ChainDB) AddressHistory(address string, N, offset int64, txnView dbtypes.AddrTxnViewType) ([]*dbtypes.AddressRow, *dbtypes.AddressBalance, error)
AddressHistory queries the database for rows of the addresses table containing values for a certain type of transaction (all, credits, or debits) for the given address.
func (*ChainDB) AddressHistoryAll ¶
func (pgb *ChainDB) AddressHistoryAll(address string, N, offset int64) ([]*dbtypes.AddressRow, *dbtypes.AddressBalance, error)
AddressHistoryAll retrieves N address rows of type AddrTxnAll, skipping over offset rows first, in order of block time.
func (*ChainDB) AddressIDsByOutpoint ¶
func (pgb *ChainDB) AddressIDsByOutpoint(txHash string, voutIndex uint32) ([]uint64, []string, int64, error)
AddressIDsByOutpoint fetches all address row IDs for a given outpoint (txHash:voutIndex).
func (*ChainDB) AddressMetrics ¶
func (pgb *ChainDB) AddressMetrics(addr string) (*dbtypes.AddressMetrics, error)
AddressMetrics returns the block time of the oldest transaction and the total count for all the transactions linked to the provided address grouped by years, months, weeks and days time grouping in seconds. This helps plot more meaningful address history graphs to the user.
func (*ChainDB) AddressRowsCompact ¶
func (pgb *ChainDB) AddressRowsCompact(address string) ([]*dbtypes.AddressRowCompact, error)
AddressRowsCompact gets non-merged address rows either from cache or via DB query.
func (*ChainDB) AddressRowsMerged ¶
func (pgb *ChainDB) AddressRowsMerged(address string) ([]*dbtypes.AddressRowMerged, error)
AddressRowsMerged gets the merged address rows either from cache or via DB query.
func (*ChainDB) AddressTotals ¶
func (pgb *ChainDB) AddressTotals(address string) (*apitypes.AddressTotals, error)
AddressTotals queries for the following totals: amount spent, amount unspent, number of unspent transaction outputs and number spent.
func (*ChainDB) AddressTransactionDetails ¶
func (pgb *ChainDB) AddressTransactionDetails(addr string, count, skip int64, txnType dbtypes.AddrTxnViewType) (*apitypes.Address, error)
AddressTransactionDetails returns an apitypes.Address with at most the last count transactions of type txnType in which the address was involved, starting after skip transactions. This does NOT include unconfirmed transactions.
func (*ChainDB) AddressTransactions ¶
func (pgb *ChainDB) AddressTransactions(address string, N, offset int64, txnType dbtypes.AddrTxnViewType) (addressRows []*dbtypes.AddressRow, err error)
AddressTransactions retrieves a slice of *dbtypes.AddressRow for a given address and transaction type (i.e. all, credit, or debit) from the DB. Only the first N transactions starting from the offset element in the set of all txnType transactions.
func (*ChainDB) AddressTransactionsAll ¶
func (pgb *ChainDB) AddressTransactionsAll(address string) (addressRows []*dbtypes.AddressRow, err error)
AddressTransactionsAll retrieves all non-merged main chain addresses table rows for the given address.
func (*ChainDB) AddressTransactionsAllMerged ¶
func (pgb *ChainDB) AddressTransactionsAllMerged(address string) (addressRows []*dbtypes.AddressRow, err error)
AddressTransactionsAllMerged retrieves all merged (stakeholder-approved and mainchain only) addresses table rows for the given address.
func (*ChainDB) AddressTxIoCsv ¶
AddressTxIoCsv grabs rows of an address' transaction input/output data as a 2-D array of strings to be CSV-formatted.
func (*ChainDB) AddressUTXO ¶
AddressUTXO returns the unspent transaction outputs (UTXOs) paying to the specified address in a []*dbtypes.AddressTxnOutput.
func (*ChainDB) AgendaVoteCounts ¶
AgendaVoteCounts returns the vote counts for the agenda as builtin types.
func (*ChainDB) AgendaVotes ¶
AgendaVotes fetches the data used to plot a graph of votes cast per day per choice for the provided agenda.
func (*ChainDB) AgendasVotesSummary ¶
func (pgb *ChainDB) AgendasVotesSummary(agendaID string) (summary *dbtypes.AgendaSummary, err error)
AgendasVotesSummary fetches the total vote choices count for the provided agenda.
func (*ChainDB) AllAgendas ¶
AllAgendas returns all the agendas stored currently.
func (*ChainDB) BestBlockHash ¶
func (pgb *ChainDB) BestBlockHash() *chainhash.Hash
BestBlockHash is a getter for ChainDB.bestBlock.hash.
func (*ChainDB) BestBlockHashStr ¶
BestBlockHashStr is a getter for ChainDB.bestBlock.hash.
func (*ChainDB) BestBlockStr ¶
func (*ChainDB) BlockChainDbID ¶
BlockChainDbID gets the row ID of the given block hash in the block_chain table. The cancellation context is used without timeout.
func (*ChainDB) BlockChainDbIDNoCancel ¶
BlockChainDbIDNoCancel gets the row ID of the given block hash in the block_chain table. The cancellation context is used without timeout.
func (*ChainDB) BlockFlags ¶
BlockFlags retrieves the block's isValid and isMainchain flags.
func (*ChainDB) BlockFlagsNoCancel ¶
BlockFlagsNoCancel retrieves the block's isValid and isMainchain flags.
func (*ChainDB) BlockHash ¶
BlockHash queries the DB for the hash of the mainchain block at the given height.
func (*ChainDB) BlockHeight ¶
BlockHeight queries the DB for the height of the specified hash.
func (*ChainDB) BlockMissedVotes ¶
BlockMissedVotes retrieves the ticket IDs for all missed votes in the specified block, and an error value.
func (*ChainDB) BlockSizeRange ¶
BlockSizeRange returns an array of block sizes for block range ind0 to ind1
func (*ChainDB) BlockStatus ¶
func (pgb *ChainDB) BlockStatus(hash string) (dbtypes.BlockStatus, error)
BlockStatus retrieves the block chain status of the specified block.
func (*ChainDB) BlockSubsidy ¶
func (pgb *ChainDB) BlockSubsidy(height int64, voters uint16) *chainjson.GetBlockSubsidyResult
BlockSubsidy gets the *chainjson.GetBlockSubsidyResult for the given height and number of voters, which can be fewer than the network parameter allows.
func (*ChainDB) BlockSummary ¶
func (pgb *ChainDB) BlockSummary(ind int64) (*apitypes.BlockDataBasic, error)
BlockSummary returns basic block data for block ind.
func (*ChainDB) BlockSummaryByHash ¶
func (pgb *ChainDB) BlockSummaryByHash(hash string) (*apitypes.BlockDataBasic, error)
BlockSummaryByHash makes a *apitypes.BlockDataBasic, checking the BlockCache first before querying the database.
func (*ChainDB) BlockSummaryRange ¶
func (pgb *ChainDB) BlockSummaryRange(idx0, idx1 int64) ([]*apitypes.BlockDataBasic, error)
BlockSummaryRange returns the *apitypes.BlockDataBasic for a range of block height.
func (*ChainDB) BlockSummaryRangeStepped ¶
func (pgb *ChainDB) BlockSummaryRangeStepped(idx0, idx1, step int64) ([]*apitypes.BlockDataBasic, error)
BlockSummaryRangeStepped returns the []*apitypes.BlockDataBasic for every step'th block in a specified range.
func (*ChainDB) BlockSummaryTimeRange ¶
func (pgb *ChainDB) BlockSummaryTimeRange(min, max int64, limit int) ([]dbtypes.BlockDataBasic, error)
BlockSummaryTimeRange returns the blocks created within a specified time range (min, max time), up to limit transactions.
func (*ChainDB) BlockTimeByHeight ¶
BlockTimeByHeight queries the DB for the time of the mainchain block at the given height.
func (*ChainDB) BlockTransactions ¶
BlockTransactions retrieves all transactions in the specified block, their indexes in the block, their tree, and an error value.
func (*ChainDB) BlockchainInfo ¶
func (pgb *ChainDB) BlockchainInfo() (*chainjson.GetBlockChainInfoResult, error)
BlockchainInfo retrieves the result of the getblockchaininfo node RPC.
func (*ChainDB) ChainInfo ¶
func (pgb *ChainDB) ChainInfo() *dbtypes.BlockChainData
ChainInfo guarantees thread-safe access of the deployment data.
func (*ChainDB) ChargePoolInfoCache ¶
ChargePoolInfoCache prepares the stakeDB by querying the database for block info.
func (*ChainDB) CollectTicketSpendDBInfo ¶
func (pgb *ChainDB) CollectTicketSpendDBInfo(dbTxns []*dbtypes.Tx, txDbIDs []uint64, msgBlock *wire.MsgBlock, isMainchain bool) (spendingTxDbIDs []uint64, spendTypes []dbtypes.TicketSpendType, ticketHashes []string, ticketDbIDs []uint64, err error)
CollectTicketSpendDBInfo processes the stake transactions in msgBlock, which correspond to the transaction data in dbTxns, and extracts data for votes and revokes, including the spent ticket hash and DB row ID.
func (*ChainDB) CountTransactions ¶
CountTransactions gets the total row count for the given address and address transaction view.
func (*ChainDB) CurrentCoinSupply ¶
func (pgb *ChainDB) CurrentCoinSupply() (supply *apitypes.CoinSupply)
CurrentCoinSupply gets the current coin supply as an *apitypes.CoinSupply, which additionally contains block info and max supply.
func (*ChainDB) CurrentDifficulty ¶
CurrentDifficulty returns the current difficulty from dcrd.
func (*ChainDB) DbTxByHash ¶
DbTxByHash retrieves a row of the transactions table corresponding to the given transaction hash. Transactions in valid and mainchain blocks are chosen first.
func (*ChainDB) DecodeRawTransaction ¶
func (pgb *ChainDB) DecodeRawTransaction(txhex string) (*chainjson.TxRawResult, error)
DecodeRawTransaction creates a *chainjson.TxRawResult from a hex-encoded transaction.
func (*ChainDB) DeindexAddressTable ¶
DeindexAddressTable drops the vin ID, block_time, matching_tx_hash and address column indexes for the address table.
func (*ChainDB) DeindexAll ¶
DeindexAll drops indexes in most tables.
func (*ChainDB) DeindexTicketsTable ¶
DeindexTicketsTable drops indexes in the tickets table on ticket hash, ticket pool status and tx DB ID columns.
func (*ChainDB) DeleteDuplicateAgendaVotes ¶
func (*ChainDB) DeleteDuplicateAgendas ¶
func (*ChainDB) DeleteDuplicateMisses ¶
func (*ChainDB) DeleteDuplicateTickets ¶
func (*ChainDB) DeleteDuplicateTxns ¶
func (*ChainDB) DeleteDuplicateVins ¶
func (*ChainDB) DeleteDuplicateVinsCockroach ¶
func (*ChainDB) DeleteDuplicateVotes ¶
func (*ChainDB) DeleteDuplicateVouts ¶
func (*ChainDB) DeleteDuplicateVoutsCockroach ¶
func (*ChainDB) DeleteDuplicates ¶
func (pgb *ChainDB) DeleteDuplicates(barLoad chan *dbtypes.ProgressBarLoad) error
DeleteDuplicates attempts to delete "duplicate" rows in tables where unique indexes are to be created.
func (*ChainDB) DeleteDuplicatesRecovery ¶
func (pgb *ChainDB) DeleteDuplicatesRecovery(barLoad chan *dbtypes.ProgressBarLoad) error
DeleteDuplicatesRecovery attempts to delete "duplicate" rows in all tables where unique indexes are to be created. This is like DeleteDuplicates, but it also includes transactions, tickets, votes, and misses.
func (*ChainDB) DevBalance ¶
func (pgb *ChainDB) DevBalance() (*dbtypes.AddressBalance, error)
DevBalance returns the current development/project fund balance, updating the cached balance if it is stale. DevBalance differs slightly from addressBalance(devAddress) in that it will not initiate a DB query if a chain reorganization is in progress.
func (*ChainDB) Difficulty ¶
Difficulty returns the difficulty for the first block mined after the provided UNIX timestamp.
func (*ChainDB) DisapprovedBlocks ¶
func (pgb *ChainDB) DisapprovedBlocks() ([]*dbtypes.BlockStatus, error)
DisapprovedBlocks retrieves all blocks disapproved by stakeholder votes.
func (*ChainDB) DropTables ¶
func (pgb *ChainDB) DropTables()
DropTables drops (deletes) all of the known dcrdata tables.
func (*ChainDB) EnableDuplicateCheckOnInsert ¶
EnableDuplicateCheckOnInsert specifies whether SQL insertions should check for row conflicts (duplicates), and avoid adding or updating.
func (*ChainDB) FillAddressTransactions ¶
func (pgb *ChainDB) FillAddressTransactions(addrInfo *dbtypes.AddressInfo) error
FillAddressTransactions is used to fill out the transaction details in an explorer.AddressInfo generated by dbtypes.ReduceAddressHistory, usually from the output of AddressHistory. This function also sets the number of unconfirmed transactions for the current best block in the database.
func (*ChainDB) FreshenAddressCaches ¶
FreshenAddressCaches resets the address balance cache by purging data for the addresses listed in expireAddresses, and prefetches the project fund balance if devPrefetch is enabled and not mid-reorg. The project fund update is run asynchronously if lazyProjectFund is true.
func (*ChainDB) FundingOutpointIndxByVinID ¶
FundingOutpointIndxByVinID retrieves the the transaction output index of the previous outpoint for a transaction input specified by row ID in the vins table, which stores previous outpoints for each vin.
func (*ChainDB) GenesisStamp ¶
GenesisStamp returns the stamp of the lowest mainchain block in the database.
func (*ChainDB) GetAddressTransactionsRawWithSkip ¶
func (pgb *ChainDB) GetAddressTransactionsRawWithSkip(addr string, count int, skip int) []*apitypes.AddressTxRaw
GetAddressTransactionsRawWithSkip returns an array of apitypes.AddressTxRaw objects representing the raw result of SearchRawTransactionsverbose
func (*ChainDB) GetAllTxIn ¶
GetAllTxIn gets all transaction inputs, as a slice of *apitypes.TxIn, for a given transaction ID.
func (*ChainDB) GetAllTxOut ¶
GetAllTxOut gets all transaction outputs, as a slice of *apitypes.TxOut, for a given transaction ID.
func (*ChainDB) GetBestBlockHash ¶
GetBestBlockHash is for middleware DataSource compatibility. No DB query is performed; the last stored height is used.
func (*ChainDB) GetBestBlockSummary ¶
func (pgb *ChainDB) GetBestBlockSummary() *apitypes.BlockDataBasic
GetBestBlockSummary retrieves data for the best block in the DB. If there are no blocks in the table (yet), a nil pointer is returned.
func (*ChainDB) GetBlockByHash ¶
GetBlockByHash gets a *wire.MsgBlock for the supplied hex-encoded hash string.
func (*ChainDB) GetBlockHash ¶
GetBlockHash returns the hash of the block at the specified height. TODO: create GetBlockHashes to return all blocks at a given height.
func (*ChainDB) GetBlockHeaderByHash ¶
GetBlockHeaderByHash fetches the *chainjson.GetBlockHeaderVerboseResult for a given block hash.
func (*ChainDB) GetBlockHeight ¶
GetBlockHeight returns the height of the block with the specified hash.
func (*ChainDB) GetBlockSize ¶
GetBlockSize returns the block size in bytes for the block at a given block height.
func (*ChainDB) GetBlockSizeRange ¶
GetBlockSizeRange gets the block sizes in bytes for an inclusive range of block heights.
func (*ChainDB) GetBlockVerbose ¶
func (pgb *ChainDB) GetBlockVerbose(idx int, verboseTx bool) *chainjson.GetBlockVerboseResult
GetBlockVerbose fetches the *chainjson.GetBlockVerboseResult for a given block height. Optionally include verbose transactions.
func (*ChainDB) GetBlockVerboseByHash ¶
func (pgb *ChainDB) GetBlockVerboseByHash(hash string, verboseTx bool) *chainjson.GetBlockVerboseResult
GetBlockVerboseByHash returns a *chainjson.GetBlockVerboseResult for the specified block hash, optionally with transaction details.
func (*ChainDB) GetChainParams ¶
func (pgb *ChainDB) GetChainParams() *chaincfg.Params
GetChainParams is a getter for the current network parameters.
func (*ChainDB) GetChainWork ¶
GetChainWork fetches the chainjson.BlockHeaderVerbose and returns only the ChainWork attribute as a hex-encoded string, without 0x prefix.
func (*ChainDB) GetExplorerAddress ¶
func (pgb *ChainDB) GetExplorerAddress(address string, count, offset int64) (*dbtypes.AddressInfo, txhelpers.AddressType, txhelpers.AddressError)
GetExplorerAddress fetches a *dbtypes.AddressInfo for the given address. Also returns the txhelpers.AddressType.
func (*ChainDB) GetExplorerBlock ¶
GetExplorerBlock gets a *exptypes.Blockinfo for the specified block.
func (*ChainDB) GetExplorerBlocks ¶
func (pgb *ChainDB) GetExplorerBlocks(start int, end int) []*exptypes.BlockBasic
GetExplorerBlocks creates an slice of exptypes.BlockBasic beginning at start and decreasing in block height to end, not including end.
func (*ChainDB) GetExplorerFullBlocks ¶
GetExplorerFullBlocks gets the *exptypes.BlockInfo's for a range of block heights.
func (*ChainDB) GetExplorerTx ¶
GetExplorerTx creates a *exptypes.TxInfo for the transaction with the given ID.
func (*ChainDB) GetHeader ¶
func (pgb *ChainDB) GetHeader(idx int) *chainjson.GetBlockHeaderVerboseResult
GetHeader fetches the *chainjson.GetBlockHeaderVerboseResult for a given block height.
func (*ChainDB) GetHeight ¶
GetHeight is for middleware DataSource compatibility. No DB query is performed; the last stored height is used.
func (*ChainDB) GetMempool ¶
GetMempool gets all transactions from the mempool for explorer and adds the total out for all the txs and vote info for the votes. The returned slice will be nil if the GetRawMempoolVerbose RPC fails. A zero-length non-nil slice is returned if there are no transactions in mempool.
func (*ChainDB) GetMempoolPriceCountTime ¶
func (pgb *ChainDB) GetMempoolPriceCountTime() *apitypes.PriceCountTime
GetMempoolPriceCountTime retrieves from mempool: the ticket price, the number of tickets in mempool, the time of the first ticket.
func (*ChainDB) GetMempoolSSTxDetails ¶
func (pgb *ChainDB) GetMempoolSSTxDetails(N int) *apitypes.MempoolTicketDetails
GetMempoolSSTxDetails returns the current mempool ticket info for tickets above height N in the mempool cache.
func (*ChainDB) GetMempoolSSTxFeeRates ¶
func (pgb *ChainDB) GetMempoolSSTxFeeRates(N int) *apitypes.MempoolTicketFees
GetMempoolSSTxFeeRates returns the current mempool stake fee info for tickets above height N in the mempool cache.
func (*ChainDB) GetMempoolSSTxSummary ¶
func (pgb *ChainDB) GetMempoolSSTxSummary() *apitypes.MempoolTicketFeeInfo
GetMempoolSSTxSummary returns the current *apitypes.MempoolTicketFeeInfo.
func (*ChainDB) GetPoolInfo ¶
func (pgb *ChainDB) GetPoolInfo(idx int) *apitypes.TicketPoolInfo
GetPoolInfo retrieves the ticket pool statistics at the specified height.
func (*ChainDB) GetPoolInfoByHash ¶
func (pgb *ChainDB) GetPoolInfoByHash(hash string) *apitypes.TicketPoolInfo
GetPoolInfoByHash retrieves the ticket pool statistics at the specified block hash.
func (*ChainDB) GetPoolInfoRange ¶
func (pgb *ChainDB) GetPoolInfoRange(idx0, idx1 int) []apitypes.TicketPoolInfo
GetPoolInfoRange retrieves the ticket pool statistics for a range of block heights, as a slice.
func (*ChainDB) GetPoolValAndSizeRange ¶
GetPoolValAndSizeRange returns the ticket pool size at each block height within a given range.
func (*ChainDB) GetRawAPITransaction ¶
GetRawAPITransaction gets an *apitypes.Tx for a given transaction ID.
func (*ChainDB) GetRawTransaction ¶
func (pgb *ChainDB) GetRawTransaction(txid *chainhash.Hash) (*chainjson.TxRawResult, error)
GetRawTransaction gets a chainjson.TxRawResult for the specified transaction hash.
func (*ChainDB) GetSBitsByHash ¶
GetSBitsByHash gets the stake difficulty in DCR for a given block height.
func (*ChainDB) GetSDiffRange ¶
GetSDiffRange gets the stake difficulties in DCR for a range of block heights.
func (*ChainDB) GetStakeDiffEstimates ¶
GetStakeDiffEstimates gets an *apitypes.StakeDiff, which is a combo of chainjson.EstimateStakeDiffResult and chainjson.GetStakeDifficultyResult
func (*ChainDB) GetStakeInfoExtendedByHash ¶
func (pgb *ChainDB) GetStakeInfoExtendedByHash(hashStr string) *apitypes.StakeInfoExtended
GetStakeInfoExtendedByHash fetches a apitypes.StakeInfoExtended, containing comprehensive data for the state of staking at a given block.
func (*ChainDB) GetStakeInfoExtendedByHeight ¶
func (pgb *ChainDB) GetStakeInfoExtendedByHeight(height int) *apitypes.StakeInfoExtended
GetStakeInfoExtendedByHeight gets extended stake information for the mainchain block at the specified height.
func (*ChainDB) GetStakeVersions ¶
func (pgb *ChainDB) GetStakeVersions(blockHash string, count int32) (*chainjson.GetStakeVersionsResult, error)
GetStakeVersions requests the output of the getstakeversions RPC, which gets stake version information and individual vote version information starting at the given block and for count-1 blocks prior.
func (*ChainDB) GetStakeVersionsLatest ¶
func (pgb *ChainDB) GetStakeVersionsLatest() (*chainjson.StakeVersions, error)
GetStakeVersionsLatest requests the output of the getstakeversions RPC for just the current best block.
func (*ChainDB) GetSummary ¶
func (pgb *ChainDB) GetSummary(idx int) *apitypes.BlockDataBasic
GetSummary returns the *apitypes.BlockDataBasic for a given block height.
func (*ChainDB) GetSummaryByHash ¶
func (pgb *ChainDB) GetSummaryByHash(hash string, withTxTotals bool) *apitypes.BlockDataBasic
GetSummaryByHash returns a *apitypes.BlockDataBasic for a given hex-encoded block hash. If withTxTotals is true, the TotalSent and MiningFee fields will be set, but it's costly because it requires a GetBlockVerboseByHash RPC call.
func (*ChainDB) GetSummaryRange ¶
func (pgb *ChainDB) GetSummaryRange(idx0, idx1 int) []*apitypes.BlockDataBasic
GetSummary returns the *apitypes.BlockDataBasic for a range of block heights.
func (*ChainDB) GetSummaryRangeStepped ¶
func (pgb *ChainDB) GetSummaryRangeStepped(idx0, idx1, step int) []*apitypes.BlockDataBasic
GetSummaryStepped returns the []*apitypes.BlockDataBasic for a given block height.
func (*ChainDB) GetTicketInfo ¶
func (pgb *ChainDB) GetTicketInfo(txid string) (*apitypes.TicketInfo, error)
GetTicketInfo retrieves information about the pool and spend statuses, the purchase block, the lottery block, and the spending transaction.
func (*ChainDB) GetTip ¶
func (pgb *ChainDB) GetTip() (*exptypes.WebBasicBlock, error)
GetTip grabs the highest block stored in the database.
func (*ChainDB) GetTransactionHex ¶
GetTransactionHex returns the full serialized transaction for the specified transaction hash as a hex encode string.
func (*ChainDB) GetTransactionsForBlockByHash ¶
func (pgb *ChainDB) GetTransactionsForBlockByHash(hash string) *apitypes.BlockTransactions
GetTransactionsForBlockByHash returns a *apitypes.BlockTransactions for the block with the specified hash.
func (*ChainDB) GetTrimmedTransaction ¶
GetTrimmedTransaction gets a *apitypes.TrimmedTx for a given transaction ID.
func (*ChainDB) GetVoteInfo ¶
GetVoteInfo attempts to decode the vote bits of a SSGen transaction. If the transaction is not a valid SSGen, the VoteInfo output will be nil. Depending on the stake version with which dcrdata is compiled with (chaincfg.Params), the Choices field of VoteInfo may be a nil slice even if the votebits were set for a previously-valid agenda.
func (*ChainDB) GetVoteVersionInfo ¶
func (pgb *ChainDB) GetVoteVersionInfo(ver uint32) (*chainjson.GetVoteInfoResult, error)
GetVoteVersionInfo requests stake version info from the dcrd RPC server
func (*ChainDB) HashDBLegacy ¶
HashDBLegacy queries the blocks table for the best block's hash.
func (*ChainDB) HeightDBLegacy ¶
HeightDBLegacy queries the blocks table for the best block height. When the tables are empty, the returned height will be -1.
func (*ChainDB) HeightHashDB ¶
HeightHashDB retrieves the best block height and hash according to the meta table.
func (*ChainDB) HeightHashDBLegacy ¶
HeightHashDBLegacy queries the blocks table for the best block's height and hash.
func (*ChainDB) IndexAddressTable ¶
func (pgb *ChainDB) IndexAddressTable(barLoad chan *dbtypes.ProgressBarLoad) error
IndexAddressTable creates the indexes on the address table on the vout ID, block_time, matching_tx_hash and address columns.
func (*ChainDB) IndexAll ¶
func (pgb *ChainDB) IndexAll(barLoad chan *dbtypes.ProgressBarLoad) error
IndexAll creates most indexes in the tables. Exceptions: (1) addresses on matching_tx_hash (use IndexAddressTable or do it individually), (2) all tickets table indexes (use IndexTicketsTable), and (3) vouts on tx hash and index.
func (*ChainDB) IndexTicketsTable ¶
func (pgb *ChainDB) IndexTicketsTable(barLoad chan *dbtypes.ProgressBarLoad) error
IndexTicketsTable creates indexes in the tickets table on ticket hash, ticket pool status and tx DB ID columns.
func (*ChainDB) InitUtxoCache ¶
InitUtxoCache resets the UTXO cache with the given slice of UTXO data.
func (*ChainDB) InsightAddressTransactions ¶
func (pgb *ChainDB) InsightAddressTransactions(addr []string, recentBlockHeight int64) (txs, recentTxs []chainhash.Hash, err error)
InsightAddressTransactions performs DB queries to get all transaction hashes for the specified addresses in descending order by time, then ascending order by hash. It also returns a list of recently (defined as greater than recentBlockHeight) confirmed transactions that can be used to validate mempool status.
func (*ChainDB) InsightSearchRPCAddressTransactions ¶
func (pgb *ChainDB) InsightSearchRPCAddressTransactions(addr string, count, skip int) []*chainjson.SearchRawTransactionsResult
InsightSearchRPCAddressTransactions performs a searchrawtransactions for the specified address, max number of transactions, and offset into the transaction list. The search results are in reverse temporal order. TODO: Does this really need all the prev vout extra data?
func (*ChainDB) LastPiParserSync ¶
LastPiParserSync returns last time value when the piparser run sync on proposals and proposal_votes table.
func (*ChainDB) MissingAddressIndexes ¶
MissingAddressIndexes list missing addresses table indexes and their descriptions.
func (*ChainDB) MissingIndexes ¶
MissingIndexes lists missing table indexes and their descriptions.
func (*ChainDB) MissingSideChainBlocks ¶
MissingSideChainBlocks identifies side chain blocks that are missing from the DB. Side chains known to dcrd are listed via the getchaintips RPC. Each block presence in the postgres DB is checked, and any missing block is returned in a SideChain along with a count of the total number of missing blocks.
func (*ChainDB) MixedUtxosByHeight ¶
func (*ChainDB) NewChainMonitor ¶
func (pgb *ChainDB) NewChainMonitor(ctx context.Context) *ChainMonitor
NewChainMonitor creates a new ChainMonitor.
func (*ChainDB) NumAddressIntervals ¶
func (pgb *ChainDB) NumAddressIntervals(addr string, grouping dbtypes.TimeBasedGrouping) (int64, error)
NumAddressIntervals gets the number of unique time intervals for the specified grouping where there are entries in the addresses table for the given address.
func (*ChainDB) PiProposalsHistory ¶
PiProposalsHistory queries the politeia's proposal updates via the parser tool and pushes them to the proposals and proposal_votes tables.
func (*ChainDB) PkScriptByVinID ¶
PkScriptByVinID retrieves the pkScript and script version for the row of the vouts table corresponding to the previous output of the vin specified by row ID of the vins table.
func (*ChainDB) PkScriptByVoutID ¶
PkScriptByVoutID retrieves the pkScript and script version for the row of the vouts table specified by the row ID id.
func (*ChainDB) PoolStatusForTicket ¶
func (pgb *ChainDB) PoolStatusForTicket(txid string) (dbtypes.TicketSpendType, dbtypes.TicketPoolStatus, error)
PoolStatusForTicket retrieves the specified ticket's spend status and ticket pool status, and an error value.
func (*ChainDB) PosIntervals ¶
func (pgb *ChainDB) PosIntervals(limit, offset uint64) ([]*dbtypes.BlocksGroupedInfo, error)
PosIntervals retrieves the blocks at the respective stakebase windows interval. The term "window" is used here to describe the group of blocks whose count is defined by chainParams.StakeDiffWindowSize. During this chainParams.StakeDiffWindowSize block interval the ticket price and the difficulty value is constant.
func (*ChainDB) PowerlessTickets ¶
func (pgb *ChainDB) PowerlessTickets() (*apitypes.PowerlessTickets, error)
PowerlessTickets fetches all missed and expired tickets, sorted by revocation status.
func (*ChainDB) ProposalVotes ¶
func (pgb *ChainDB) ProposalVotes(proposalToken string) (*dbtypes.ProposalChartsData, error)
ProposalVotes retrieves all the votes data associated with the provided token.
func (*ChainDB) PurgeBestBlocks ¶
PurgeBestBlocks deletes all data for the N best blocks in the DB.
func (*ChainDB) RegisterCharts ¶
RegisterCharts registers chart data fetchers and appenders with the provided ChartData.
func (*ChainDB) ReindexAddressesBlockTime ¶
ReindexAddressesBlockTime rebuilds the addresses(block_time) index.
func (*ChainDB) RewindStakeDB ¶
func (pgb *ChainDB) RewindStakeDB(ctx context.Context, toHeight int64, quiet ...bool) (stakeDBHeight int64, err error)
RewindStakeDB attempts to disconnect blocks from the stake database to reach the specified height. A Context may be provided to allow cancellation of the rewind process. If the specified height is greater than the current stake DB height, RewindStakeDB will exit without error, returning the current stake DB height and a nil error.
func (*ChainDB) SDiffRange ¶
SDiffRange returns an array of stake difficulties for block range ind0 to ind1.
func (*ChainDB) SendRawTransaction ¶
SendRawTransaction attempts to decode the input serialized transaction, passed as hex encoded string, and broadcast it, returning the tx hash.
func (*ChainDB) SetDBBestBlock ¶
SetDBBestBlock stores ChainDB's BestBlock data in the meta table.
func (*ChainDB) SetVinsMainchainByBlock ¶
func (pgb *ChainDB) SetVinsMainchainByBlock(blockHash string) (int64, []dbtypes.UInt64Array, []dbtypes.UInt64Array, error)
SetVinsMainchainByBlock first retrieves for all transactions in the specified block the vin_db_ids and vout_db_ids arrays, along with mainchain status, from the transactions table, and then sets the is_mainchain flag in the vins table for each row of vins in the vin_db_ids array. The returns are the number of vins updated, the vin row IDs array, the vouts row IDs array, and an error value.
func (*ChainDB) SideChainBlocks ¶
func (pgb *ChainDB) SideChainBlocks() ([]*dbtypes.BlockStatus, error)
SideChainBlocks retrieves all known side chain blocks.
func (*ChainDB) SideChainTips ¶
func (pgb *ChainDB) SideChainTips() ([]*dbtypes.BlockStatus, error)
SideChainTips retrieves the tip/head block for all known side chains.
func (*ChainDB) SignalHeight ¶
SignalHeight signals the database height to any registered receivers. This function is exported so that it can be called once externally after all update channel clients have subscribed.
func (*ChainDB) SpendDetailsForFundingTx ¶
func (pgb *ChainDB) SpendDetailsForFundingTx(fundHash string) ([]*apitypes.SpendByFundingHash, error)
SpendDetailsForFundingTx will return the details of any spending transactions (tx, index, block height) for a given funding transaction.
func (*ChainDB) SpendingTransaction ¶
func (pgb *ChainDB) SpendingTransaction(fundingTxID string, fundingTxVout uint32) (string, uint32, int8, error)
SpendingTransaction returns the transaction that spends the specified transaction outpoint, if it is spent. The spending transaction hash, input index, tx tree, and an error value are returned.
func (*ChainDB) SpendingTransactions ¶
SpendingTransactions retrieves all transactions spending outpoints from the specified funding transaction. The spending transaction hashes, the spending tx input indexes, and the corresponding funding tx output indexes, and an error value are returned.
func (*ChainDB) SqlDB ¶
SqlDB returns the underlying sql.DB, which should not be used directly unless you know what you are doing (if you have to ask...).
func (*ChainDB) StartPiparserHandler ¶
func (pgb *ChainDB) StartPiparserHandler()
StartPiparserHandler controls how piparser update handler will be initiated. This handler should to be run once only when the first sync after startup completes.
func (*ChainDB) Store ¶
Store satisfies BlockDataSaver. Blocks stored this way are considered valid and part of mainchain. Store should not be used for batch block processing; instead, use StoreBlock and specify appropriate flags.
func (*ChainDB) StoreBlock ¶
func (pgb *ChainDB) StoreBlock(msgBlock *wire.MsgBlock, isValid, isMainchain, updateExistingRecords, updateAddressesSpendingInfo, updateTicketsSpendingInfo bool, chainWork string) (numVins int64, numVouts int64, numAddresses int64, err error)
StoreBlock processes the input wire.MsgBlock, and saves to the data tables. The number of vins and vouts stored are returned.
func (*ChainDB) SyncChainDB ¶
func (pgb *ChainDB) SyncChainDB(ctx context.Context, client rpcutils.MasterBlockGetter, updateAllAddresses, newIndexes bool, updateExplorer chan *chainhash.Hash, barLoad chan *dbtypes.ProgressBarLoad) (int64, error)
SyncChainDB stores in the DB all blocks on the main chain available from the RPC client. The table indexes may be force-dropped and recreated by setting newIndexes to true. The quit channel is used to break the sync loop. For example, closing the channel on SIGINT.
func (*ChainDB) SyncChainDBAsync ¶
func (pgb *ChainDB) SyncChainDBAsync(ctx context.Context, res chan dbtypes.SyncResult, client rpcutils.MasterBlockGetter, updateAllAddresses, newIndexes bool, updateExplorer chan *chainhash.Hash, barLoad chan *dbtypes.ProgressBarLoad)
SyncChainDBAsync is like SyncChainDB except it also takes a result channel on which the caller should wait to receive the result. As such, this method should be called as a goroutine or it will hang on send if the channel is unbuffered.
func (*ChainDB) TicketMiss ¶
TicketMiss retrieves the mainchain block in which the specified ticket was called to vote but failed to do so (miss). If the ticket never missed a vote, the returned error will be sql.ErrNoRows.
func (*ChainDB) TicketMisses ¶
TicketMisses retrieves all blocks in which the specified ticket was called to vote but failed to do so (miss). There may be multiple since this consideres side chain blocks. See TicketMiss for a mainchain-only version. If the ticket never missed a vote, the returned error will be sql.ErrNoRows.
func (*ChainDB) TicketPoolBlockMaturity ¶
TicketPoolBlockMaturity returns the block at which all tickets with height greater than it are immature.
func (*ChainDB) TicketPoolByDateAndInterval ¶
func (pgb *ChainDB) TicketPoolByDateAndInterval(maturityBlock int64, interval dbtypes.TimeBasedGrouping) (*dbtypes.PoolTicketsData, error)
TicketPoolByDateAndInterval fetches the tickets ordered by the purchase date interval provided and an error value.
func (*ChainDB) TicketPoolVisualization ¶
func (pgb *ChainDB) TicketPoolVisualization(interval dbtypes.TimeBasedGrouping) (*dbtypes.PoolTicketsData, *dbtypes.PoolTicketsData, *dbtypes.PoolTicketsData, int64, error)
TicketPoolVisualization helps block consecutive and duplicate DB queries for the requested ticket pool chart data. If the data for the given interval is cached and fresh, it is returned. If the cached data is stale and there are no queries running to update the cache for the given interval, this launches a query and updates the cache. If there is no cached data for the interval, this will launch a new query for the data if one is not already running, and if one is running, it will wait for the query to complete.
func (*ChainDB) TicketsByInputCount ¶
func (pgb *ChainDB) TicketsByInputCount() (*dbtypes.PoolTicketsData, error)
TicketsByInputCount returns chart data for tickets grouped by number of inputs.
func (*ChainDB) TicketsByPrice ¶
func (pgb *ChainDB) TicketsByPrice(maturityBlock int64) (*dbtypes.PoolTicketsData, error)
TicketsByPrice returns chart data for tickets grouped by price. maturityBlock is used to define when tickets are considered live.
func (*ChainDB) TimeBasedIntervals ¶
func (pgb *ChainDB) TimeBasedIntervals(timeGrouping dbtypes.TimeBasedGrouping, limit, offset uint64) ([]*dbtypes.BlocksGroupedInfo, error)
TimeBasedIntervals retrieves blocks groups by the selected time-based interval. For the consecutive groups the number of blocks grouped together is not uniform.
func (*ChainDB) TipToSideChain ¶
func (*ChainDB) Transaction ¶
Transaction retrieves all rows from the transactions table for the given transaction hash.
func (*ChainDB) TransactionBlock ¶
TransactionBlock retrieves the hash of the block containing the specified transaction. The index of the transaction within the block, the transaction index, and an error value are also returned.
func (*ChainDB) TransactionBlocks ¶
TransactionBlocks retrieves the blocks in which the specified transaction appears, along with the index of the transaction in each of the blocks. The next and previous block hashes are NOT SET in each BlockStatus.
func (*ChainDB) TxHistoryData ¶
func (pgb *ChainDB) TxHistoryData(address string, addrChart dbtypes.HistoryChart, chartGroupings dbtypes.TimeBasedGrouping) (cd *dbtypes.ChartsData, err error)
TxHistoryData fetches the address history chart data for specified chart type and time grouping.
func (*ChainDB) UpdateChainState ¶
func (pgb *ChainDB) UpdateChainState(blockChainInfo *chainjson.GetBlockChainInfoResult)
UpdateChainState updates the blockchain's state, which includes each of the agenda's VotingDone and Activated heights. If the agenda passed (i.e. status is "lockedIn" or "activated"), Activated is set to the height at which the rule change will take(or took) place.
func (*ChainDB) UpdateChan ¶
UpdateChan creates a channel that will receive height updates. All calls to UpdateChan should be completed before blocks start being connected.
func (*ChainDB) UpdateLastBlock ¶
UpdateLastBlock set the previous block's next block hash in the block_chain table with this block's hash as it is next. If the current block's votes invalidated/disapproved the previous block, it also updates the is_valid columns for the previous block's entries in the following tables: blocks, vins, addresses, and transactions. If the previous block is not on the same chain as this block (as indicated by isMainchain), no updates are performed.
func (*ChainDB) UpdateSpendingInfoInAllAddresses ¶
func (pgb *ChainDB) UpdateSpendingInfoInAllAddresses(barLoad chan *dbtypes.ProgressBarLoad) (int64, error)
UpdateSpendingInfoInAllAddresses completely rebuilds the matching transaction columns for funding rows of the addresses table. This is intended to be use after syncing all other tables and creating their indexes, particularly the indexes on the vins table, and the addresses table index on the funding tx columns. This can be used instead of using updateAddressesSpendingInfo=true with storeBlockTxnTree, which will update these addresses table columns too, but much more slowly for a number of reasons (that are well worth investigating BTW!).
func (*ChainDB) UpdateSpendingInfoInAllTickets ¶
UpdateSpendingInfoInAllTickets reviews all votes and revokes and sets this spending info in the tickets table.
func (*ChainDB) UpgradeTables ¶
func (pgb *ChainDB) UpgradeTables(dcrdClient BlockGetter, version, needVersion TableVersion) (bool, error)
UpgradeTables upgrades all the tables with the pending updates from the current table versions to the most recent table version supported. A boolean is returned to indicate if the db upgrade was successfully completed.
func (*ChainDB) UseMempoolChecker ¶
func (pgb *ChainDB) UseMempoolChecker(mp rpcutils.MempoolAddressChecker)
UseMempoolChecker assigns a MempoolAddressChecker for searching mempool for transactions involving a certain address.
func (*ChainDB) UseStakeDB ¶
func (pgb *ChainDB) UseStakeDB(stakeDB *stakedb.StakeDatabase)
UseStakeDB is used to assign a stakedb.StakeDatabase for ticket tracking. This may be useful when it is necessary to construct a ChainDB prior to creating or loading a StakeDatabase, such as when dropping tables.
func (*ChainDB) VersionCheck ¶
func (pgb *ChainDB) VersionCheck(client BlockGetter) error
VersionCheck checks the current version of all known tables and notifies when an upgrade is required. If there is no automatic upgrade supported, an error is returned when any table is not of the correct version. An RPC client is passed to implement the supported upgrades if need be.
func (*ChainDB) VinsForTx ¶
func (pgb *ChainDB) VinsForTx(dbTx *dbtypes.Tx) ([]dbtypes.VinTxProperty, []string, []uint16, error)
VinsForTx returns a slice of dbtypes.VinTxProperty values for each vin referenced by the transaction dbTx, along with the pkScript and script version for the corresponding previous outpoints.
func (*ChainDB) VotesInBlock ¶
VotesInBlock returns the number of votes mined in the block with the specified hash.
func (*ChainDB) VoutValue ¶
VoutValue retrieves the value of the specified transaction outpoint in atoms.
func (*ChainDB) VoutValues ¶
VoutValues retrieves the values of each outpoint of the specified transaction. The corresponding indexes in the block and tx trees of the outpoints, and an error value are also returned.
type ChainDBCfg ¶
type ChainDeployments ¶
type ChainDeployments struct {
// contains filtered or unexported fields
}
ChainDeployments is mutex-protected blockchain deployment data.
type ChainMonitor ¶
type ChainMonitor struct { ConnectingLock chan struct{} DoneConnecting chan struct{} // contains filtered or unexported fields }
ChainMonitor responds to block connection and chain reorganization.
func (*ChainMonitor) ReorgHandler ¶
func (p *ChainMonitor) ReorgHandler(reorg *txhelpers.ReorgData) (err error)
ReorgHandler processes a blockchain reorganization and initiates a corresponding reorganization of the ChainDB. ReorgHandler satisfies notification.ReorgHandler, and is registered as a handler in main.go.
type CompatAction ¶
type CompatAction int8
CompatAction defines the action to be taken once the current and the required pg table versions are compared.
const ( Rebuild CompatAction = iota Upgrade Maintenance OK TimeTravel Unknown )
These are the recognized CompatActions for upgrading a database from one version to another.
func (CompatAction) String ¶
func (v CompatAction) String() string
String implements Stringer for CompatAction.
type CompatibilityAction ¶
type CompatibilityAction int8
CompatibilityAction defines the action to be taken once the current and the required pg table versions are compared.
func TableVersionCompatible ¶
func TableVersionCompatible(required, actual TableVersion) CompatibilityAction
TableVersionCompatible indicates if the table versions are compatible (equal), and if not, what is the required action (rebuild, upgrade, or reindex).
func (CompatibilityAction) String ¶
func (v CompatibilityAction) String() string
String implements Stringer for CompatibilityAction.
type DatabaseUpgrade ¶
type DatabaseUpgrade struct { TableName string UpgradeType CompatAction CurrentVer, RequiredVer DatabaseVersion }
DatabaseUpgrade is used to define a required DB upgrade.
func (DatabaseUpgrade) String ¶
func (s DatabaseUpgrade) String() string
String implements Stringer for DatabaseUpgrade.
type DatabaseVersion ¶
type DatabaseVersion struct {
// contains filtered or unexported fields
}
DatabaseVersion models a database version.
func DBVersion ¶
func DBVersion(db *sql.DB) (ver DatabaseVersion, err error)
DBVersion retrieves the database version from the meta table. See (*DatabaseVersion).NeededToReach for version comparison.
func NewDatabaseVersion ¶
func NewDatabaseVersion(major, minor, patch uint32) DatabaseVersion
NewDatabaseVersion returns a new DatabaseVersion with the version major.minor.patch
func (*DatabaseVersion) NeededToReach ¶
func (v *DatabaseVersion) NeededToReach(other *DatabaseVersion) CompatAction
NeededToReach describes what action is required for the DatabaseVersion to reach another version provided in the input argument.
func (DatabaseVersion) String ¶
func (v DatabaseVersion) String() string
String implements Stringer for DatabaseVersion.
type MsgBlockPG ¶
MsgBlockPG extends wire.MsgBlock with the winning tickets from the block, WinningTickets, and the tickets from the previous block that may vote on this block's validity, Validators.
type PGSetting ¶
type PGSetting struct {
Name, Setting, Unit, ShortDesc, Source, SourceFile, SourceLine string
}
PGSetting describes a PostgreSQL setting scanned from pg_settings.
type PGSettings ¶
PGSettings facilitates looking up a PGSetting based on a setting's Name.
func RetrieveSysSettingsConfFile ¶
func RetrieveSysSettingsConfFile(db *sql.DB) (PGSettings, error)
RetrieveSysSettingsConfFile retrieves settings that are set by a configuration file (rather than default, environment variable, etc.).
func RetrieveSysSettingsPerformance ¶
func RetrieveSysSettingsPerformance(db *sql.DB) (PGSettings, error)
RetrieveSysSettingsPerformance retrieves performance-related settings.
func RetrieveSysSettingsServer ¶
func RetrieveSysSettingsServer(db *sql.DB) (PGSettings, error)
RetrieveSysSettingsServer a key server configuration settings (config_file, data_directory, max_connections, dynamic_shared_memory_type, max_files_per_process, port, unix_socket_directories), which may be helpful in debugging connectivity issues or other DB errors.
func (PGSettings) String ¶
func (pgs PGSettings) String() string
String implements the Stringer interface, generating a table of the settings where the Setting and Unit fields are merged into a single column. The rows of the table are sorted by the PGSettings string key (the setting's Name). This function is not thread-safe, so do not modify PGSettings concurrently.
type ProposalsFetcher ¶
type ProposalsFetcher interface { UpdateSignal() <-chan struct{} ProposalsHistory() ([]*pitypes.History, error) ProposalsHistorySince(since time.Time) ([]*pitypes.History, error) }
ProposalsFetcher defines the interface of the proposals plug-n-play data source.
type SqlExecutor ¶
SqlExecutor is implemented by both sql.DB and sql.Tx.
type TableUpgrade ¶
type TableUpgrade struct { TableName string UpgradeType CompatibilityAction CurrentVer, RequiredVer TableVersion }
TableUpgrade is used to define a required upgrade for a table
func TableUpgradesRequired ¶
func TableUpgradesRequired(versions map[string]TableVersion) []TableUpgrade
TableUpgradesRequired builds a list of table upgrade information for each of the supported auxiliary db tables. The upgrade information includes the table name, its current & required table versions and the action to be taken after comparing the current & required versions.
func (TableUpgrade) String ¶
func (s TableUpgrade) String() string
type TableUpgradeType ¶
type TableUpgradeType struct { TableName string // contains filtered or unexported fields }
type TableVersion ¶
type TableVersion struct {
// contains filtered or unexported fields
}
TableVersion models a table version by major.minor.patch
func NewTableVersion ¶
func NewTableVersion(major, minor, patch uint32) TableVersion
NewTableVersion returns a new TableVersion with the version major.minor.patch
func (TableVersion) String ¶
func (s TableVersion) String() string
type TicketTxnIDGetter ¶
type TicketTxnIDGetter struct {
// contains filtered or unexported fields
}
TicketTxnIDGetter provides a cache for DB row IDs of tickets.
func NewTicketTxnIDGetter ¶
func NewTicketTxnIDGetter(db *sql.DB) *TicketTxnIDGetter
NewTicketTxnIDGetter constructs a new TicketTxnIDGetter with an empty cache.
func (*TicketTxnIDGetter) Set ¶
func (t *TicketTxnIDGetter) Set(txid string, txDbID uint64)
Set stores the (transaction hash, DB row ID) pair a map for future access.
func (*TicketTxnIDGetter) SetN ¶
func (t *TicketTxnIDGetter) SetN(txid []string, txDbID []uint64)
SetN stores several (transaction hash, DB row ID) pairs in the map.
func (*TicketTxnIDGetter) TxnDbID ¶
func (t *TicketTxnIDGetter) TxnDbID(txid string, expire bool) (uint64, error)
TxnDbID fetches DB row ID for the ticket specified by the input transaction hash. A cache is checked first. In the event of a cache hit, the DB ID is returned and deleted from the internal cache. In the event of a cache miss, the database is queried. If the database query fails, the error is non-nil.
type Upgrader ¶
type Upgrader struct {
// contains filtered or unexported fields
}
Upgrader contains a number of elements necessary to perform a database upgrade.
func NewUpgrader ¶
func NewUpgrader(ctx context.Context, db *sql.DB, bg BlockGetter, stakeDB *stakedb.StakeDatabase) *Upgrader
NewUpgrader is a contructor for an Upgrader.
func (*Upgrader) UpgradeDatabase ¶
UpgradeDatabase attempts to upgrade the given sql.DB with help from the BlockGetter. The DB version will be compared against the target version to decide what upgrade type to initiate.
type VinVoutTypeUpdateData ¶
type VinVoutTypeUpdateData struct { VinsDbIDs dbtypes.UInt64Array VoutsDbIDs dbtypes.UInt64Array TxType stake.TxType }
VinVoutTypeUpdateData defines the fetched details from the transactions table that are needed to undertake the histogram upgrade.