Documentation ¶
Index ¶
- Constants
- func BucketPath(bucket Hash) string
- func Categories() []string
- func CategoryCheckpointPath(cat string, chk uint32) string
- func DumpXdrAsJson(args []string) error
- func Mirror(src *Archive, dst *Archive, opts *CommandOptions) error
- func RangePaths(r Range) []string
- func Repair(src *Archive, dst *Archive, opts *CommandOptions) error
- func SortTxsForHash(txset *xdr.TransactionSet) error
- type Archive
- func (a *Archive) BucketExists(bucket Hash) (bool, error)
- func (a *Archive) CategoryCheckpointExists(cat string, chk uint32) (bool, error)
- func (arch *Archive) CheckBucketsMissing() map[Hash]bool
- func (arch *Archive) CheckCheckpointFilesMissing(opts *CommandOptions) map[string][]uint32
- func (arch *Archive) ClearCachedInfo()
- func (a *Archive) GetBucketPathForHash(hash Hash) string
- func (a *Archive) GetCheckpointHAS(chk uint32) (HistoryArchiveState, error)
- func (arch *Archive) GetCheckpointManager() CheckpointManager
- func (a *Archive) GetLedgerHeader(ledger uint32) (xdr.LedgerHeaderHistoryEntry, error)
- func (a *Archive) GetPathHAS(path string) (HistoryArchiveState, error)
- func (a *Archive) GetRootHAS() (HistoryArchiveState, error)
- func (a *Archive) GetXdrStream(pth string) (*XdrStream, error)
- func (a *Archive) GetXdrStreamForHash(hash Hash) (*XdrStream, error)
- func (a *Archive) ListAllBucketHashes() (chan Hash, chan error)
- func (a *Archive) ListAllBuckets() (chan string, chan error)
- func (a *Archive) ListBucket(dp DirPrefix) (chan string, chan error)
- func (a *Archive) ListCategoryCheckpoints(cat string, pth string) (chan uint32, chan error)
- func (arch *Archive) Log(opts *CommandOptions) error
- func (arch *Archive) MustGetBucketSize(hash Hash) int64
- func (arch *Archive) MustGetLedgerHeaderHistoryEntries(chk uint32) []xdr.LedgerHeaderHistoryEntry
- func (arch *Archive) MustGetTransactionHistoryEntries(chk uint32) []xdr.TransactionHistoryEntry
- func (arch *Archive) NoteCheckpointFile(cat string, chk uint32, present bool)
- func (arch *Archive) NoteExistingBucket(bucket Hash)
- func (arch *Archive) NoteReferencedBucket(bucket Hash) bool
- func (a *Archive) PutCheckpointHAS(chk uint32, has HistoryArchiveState, opts *CommandOptions) error
- func (a *Archive) PutPathHAS(path string, has HistoryArchiveState, opts *CommandOptions) error
- func (a *Archive) PutRootHAS(has HistoryArchiveState, opts *CommandOptions) error
- func (arch *Archive) ReportBucketStats()
- func (arch *Archive) ReportCheckpointStats()
- func (arch *Archive) ReportInvalid(opts *CommandOptions) error
- func (arch *Archive) ReportMissing(opts *CommandOptions) error
- func (arch *Archive) Scan(opts *CommandOptions) error
- func (arch *Archive) ScanAllBuckets() error
- func (arch *Archive) ScanBuckets(opts *CommandOptions) error
- func (arch *Archive) ScanCheckpoints(opts *CommandOptions) error
- func (arch *Archive) ScanCheckpointsFast(opts *CommandOptions) error
- func (arch *Archive) ScanCheckpointsSlow(opts *CommandOptions) error
- func (arch *Archive) VerifyBucketEntries(h Hash) error
- func (arch *Archive) VerifyBucketHash(h Hash) error
- func (arch *Archive) VerifyCategoryCheckpoint(cat string, chk uint32) error
- func (arch *Archive) VerifyLedgerHeaderHistoryEntry(entry *xdr.LedgerHeaderHistoryEntry) error
- func (arch *Archive) VerifyTransactionHistoryEntry(entry *xdr.TransactionHistoryEntry) error
- func (arch *Archive) VerifyTransactionHistoryResultEntry(entry *xdr.TransactionHistoryResultEntry) error
- type ArchiveBackend
- type ArchiveInterface
- type CheckpointManager
- func (c CheckpointManager) GetCheckpoint(i uint32) uint32
- func (c CheckpointManager) GetCheckpointRange(i uint32) Range
- func (c CheckpointManager) IsCheckpoint(i uint32) bool
- func (c CheckpointManager) MakeRange(low uint32, high uint32) Range
- func (c CheckpointManager) NextCheckpoint(i uint32) uint32
- func (c CheckpointManager) PrevCheckpoint(i uint32) uint32
- type CommandOptions
- type ConnectOptions
- type DirPrefix
- type FsArchiveBackend
- func (b *FsArchiveBackend) CanListFiles() bool
- func (b *FsArchiveBackend) Exists(pth string) (bool, error)
- func (b *FsArchiveBackend) GetFile(pth string) (io.ReadCloser, error)
- func (b *FsArchiveBackend) ListFiles(pth string) (chan string, chan error)
- func (b *FsArchiveBackend) PutFile(pth string, in io.ReadCloser) error
- func (b *FsArchiveBackend) Size(pth string) (int64, error)
- type Hash
- type HistoryArchiveState
- func (h *HistoryArchiveState) BucketListHash() (xdr.Hash, error)
- func (h *HistoryArchiveState) Buckets() ([]Hash, error)
- func (has *HistoryArchiveState) GetChangedBuckets(arch *Archive, prevHas *HistoryArchiveState) (string, int, int64)
- func (h *HistoryArchiveState) LevelSummary() (string, int, error)
- func (h *HistoryArchiveState) Range() Range
- type HttpArchiveBackend
- func (b *HttpArchiveBackend) CanListFiles() bool
- func (b *HttpArchiveBackend) Exists(pth string) (bool, error)
- func (b *HttpArchiveBackend) GetFile(pth string) (io.ReadCloser, error)
- func (b *HttpArchiveBackend) Head(pth string) (*http.Response, error)
- func (b *HttpArchiveBackend) ListFiles(pth string) (chan string, chan error)
- func (b *HttpArchiveBackend) PutFile(pth string, in io.ReadCloser) error
- func (b *HttpArchiveBackend) Size(pth string) (int64, error)
- type MockArchive
- func (m *MockArchive) BucketExists(bucket Hash) (bool, error)
- func (m *MockArchive) CategoryCheckpointExists(cat string, chk uint32) (bool, error)
- func (m *MockArchive) GetCheckpointHAS(chk uint32) (HistoryArchiveState, error)
- func (m *MockArchive) GetCheckpointManager() CheckpointManager
- func (m *MockArchive) GetLedgerHeader(chk uint32) (xdr.LedgerHeaderHistoryEntry, error)
- func (m *MockArchive) GetPathHAS(path string) (HistoryArchiveState, error)
- func (m *MockArchive) GetRootHAS() (HistoryArchiveState, error)
- func (m *MockArchive) GetXdrStream(pth string) (*XdrStream, error)
- func (m *MockArchive) GetXdrStreamForHash(hash Hash) (*XdrStream, error)
- func (m *MockArchive) ListAllBucketHashes() (chan Hash, chan error)
- func (m *MockArchive) ListAllBuckets() (chan string, chan error)
- func (m *MockArchive) ListBucket(dp DirPrefix) (chan string, chan error)
- func (m *MockArchive) ListCategoryCheckpoints(cat string, pth string) (chan uint32, chan error)
- func (m *MockArchive) PutCheckpointHAS(chk uint32, has HistoryArchiveState, opts *CommandOptions) error
- func (m *MockArchive) PutPathHAS(path string, has HistoryArchiveState, opts *CommandOptions) error
- func (m *MockArchive) PutRootHAS(has HistoryArchiveState, opts *CommandOptions) error
- type MockArchiveBackend
- func (b *MockArchiveBackend) CanListFiles() bool
- func (b *MockArchiveBackend) Exists(pth string) (bool, error)
- func (b *MockArchiveBackend) GetFile(pth string) (io.ReadCloser, error)
- func (b *MockArchiveBackend) ListFiles(pth string) (chan string, chan error)
- func (b *MockArchiveBackend) PutFile(pth string, in io.ReadCloser) error
- func (b *MockArchiveBackend) Size(pth string) (int64, error)
- type Range
- type S3ArchiveBackend
- func (b *S3ArchiveBackend) CanListFiles() bool
- func (b *S3ArchiveBackend) Exists(pth string) (bool, error)
- func (b *S3ArchiveBackend) GetFile(pth string) (io.ReadCloser, error)
- func (b *S3ArchiveBackend) Head(pth string) (*http.Response, error)
- func (b *S3ArchiveBackend) ListFiles(pth string) (chan string, chan error)
- func (b *S3ArchiveBackend) PutFile(pth string, in io.ReadCloser) error
- func (b *S3ArchiveBackend) Size(pth string) (int64, error)
- type XdrStream
Constants ¶
const DefaultCheckpointFrequency = uint32(64)
const NumLevels = 11
Variables ¶
This section is empty.
Functions ¶
func BucketPath ¶
func Categories ¶
func Categories() []string
func CategoryCheckpointPath ¶
func DumpXdrAsJson ¶
func Mirror ¶
func Mirror(src *Archive, dst *Archive, opts *CommandOptions) error
Mirror mirrors an archive, it assumes that the source and destination have the same checkpoint ledger frequency
func RangePaths ¶
Returns an array of path prefixes to walk to enumerate all the objects in the provided range.
func Repair ¶
func Repair(src *Archive, dst *Archive, opts *CommandOptions) error
Repair repairs a destination archive based on a source archive, it assumes that the source and destination have the same checkpoint ledger frequency
func SortTxsForHash ¶
func SortTxsForHash(txset *xdr.TransactionSet) error
Types ¶
type Archive ¶
type Archive struct {
// contains filtered or unexported fields
}
func MustConnect ¶
func MustConnect(u string, opts ConnectOptions) *Archive
func (*Archive) CategoryCheckpointExists ¶
func (*Archive) CheckBucketsMissing ¶
func (*Archive) CheckCheckpointFilesMissing ¶
func (arch *Archive) CheckCheckpointFilesMissing(opts *CommandOptions) map[string][]uint32
func (*Archive) ClearCachedInfo ¶
func (arch *Archive) ClearCachedInfo()
func (*Archive) GetBucketPathForHash ¶
func (*Archive) GetCheckpointHAS ¶
func (a *Archive) GetCheckpointHAS(chk uint32) (HistoryArchiveState, error)
func (*Archive) GetCheckpointManager ¶
func (arch *Archive) GetCheckpointManager() CheckpointManager
func (*Archive) GetLedgerHeader ¶
func (a *Archive) GetLedgerHeader(ledger uint32) (xdr.LedgerHeaderHistoryEntry, error)
func (*Archive) GetPathHAS ¶
func (a *Archive) GetPathHAS(path string) (HistoryArchiveState, error)
func (*Archive) GetRootHAS ¶
func (a *Archive) GetRootHAS() (HistoryArchiveState, error)
func (*Archive) GetXdrStreamForHash ¶
func (*Archive) ListAllBucketHashes ¶
func (*Archive) ListAllBuckets ¶
func (*Archive) ListCategoryCheckpoints ¶
func (*Archive) Log ¶
func (arch *Archive) Log(opts *CommandOptions) error
func (*Archive) MustGetBucketSize ¶
func (*Archive) MustGetLedgerHeaderHistoryEntries ¶
func (arch *Archive) MustGetLedgerHeaderHistoryEntries(chk uint32) []xdr.LedgerHeaderHistoryEntry
func (*Archive) MustGetTransactionHistoryEntries ¶
func (arch *Archive) MustGetTransactionHistoryEntries(chk uint32) []xdr.TransactionHistoryEntry
func (*Archive) NoteCheckpointFile ¶
func (*Archive) NoteExistingBucket ¶
func (*Archive) NoteReferencedBucket ¶
func (*Archive) PutCheckpointHAS ¶
func (a *Archive) PutCheckpointHAS(chk uint32, has HistoryArchiveState, opts *CommandOptions) error
func (*Archive) PutPathHAS ¶
func (a *Archive) PutPathHAS(path string, has HistoryArchiveState, opts *CommandOptions) error
func (*Archive) PutRootHAS ¶
func (a *Archive) PutRootHAS(has HistoryArchiveState, opts *CommandOptions) error
func (*Archive) ReportBucketStats ¶
func (arch *Archive) ReportBucketStats()
func (*Archive) ReportCheckpointStats ¶
func (arch *Archive) ReportCheckpointStats()
func (*Archive) ReportInvalid ¶
func (arch *Archive) ReportInvalid(opts *CommandOptions) error
func (*Archive) ReportMissing ¶
func (arch *Archive) ReportMissing(opts *CommandOptions) error
func (*Archive) Scan ¶
func (arch *Archive) Scan(opts *CommandOptions) error
func (*Archive) ScanAllBuckets ¶
func (*Archive) ScanBuckets ¶
func (arch *Archive) ScanBuckets(opts *CommandOptions) error
func (*Archive) ScanCheckpoints ¶
func (arch *Archive) ScanCheckpoints(opts *CommandOptions) error
func (*Archive) ScanCheckpointsFast ¶
func (arch *Archive) ScanCheckpointsFast(opts *CommandOptions) error
func (*Archive) ScanCheckpointsSlow ¶
func (arch *Archive) ScanCheckpointsSlow(opts *CommandOptions) error
func (*Archive) VerifyBucketEntries ¶
func (*Archive) VerifyBucketHash ¶
func (*Archive) VerifyCategoryCheckpoint ¶
func (*Archive) VerifyLedgerHeaderHistoryEntry ¶
func (arch *Archive) VerifyLedgerHeaderHistoryEntry(entry *xdr.LedgerHeaderHistoryEntry) error
func (*Archive) VerifyTransactionHistoryEntry ¶
func (arch *Archive) VerifyTransactionHistoryEntry(entry *xdr.TransactionHistoryEntry) error
func (*Archive) VerifyTransactionHistoryResultEntry ¶
func (arch *Archive) VerifyTransactionHistoryResultEntry(entry *xdr.TransactionHistoryResultEntry) error
type ArchiveBackend ¶
type ArchiveInterface ¶
type ArchiveInterface interface { GetPathHAS(path string) (HistoryArchiveState, error) PutPathHAS(path string, has HistoryArchiveState, opts *CommandOptions) error BucketExists(bucket Hash) (bool, error) CategoryCheckpointExists(cat string, chk uint32) (bool, error) GetLedgerHeader(chk uint32) (xdr.LedgerHeaderHistoryEntry, error) GetRootHAS() (HistoryArchiveState, error) GetCheckpointHAS(chk uint32) (HistoryArchiveState, error) PutCheckpointHAS(chk uint32, has HistoryArchiveState, opts *CommandOptions) error PutRootHAS(has HistoryArchiveState, opts *CommandOptions) error ListBucket(dp DirPrefix) (chan string, chan error) ListAllBuckets() (chan string, chan error) ListAllBucketHashes() (chan Hash, chan error) ListCategoryCheckpoints(cat string, pth string) (chan uint32, chan error) GetXdrStreamForHash(hash Hash) (*XdrStream, error) GetXdrStream(pth string) (*XdrStream, error) GetCheckpointManager() CheckpointManager }
type CheckpointManager ¶
type CheckpointManager struct {
// contains filtered or unexported fields
}
func NewCheckpointManager ¶
func NewCheckpointManager(checkpointFrequency uint32) CheckpointManager
NewCheckpointManager creates a CheckpointManager based on a checkpoint frequency (the number of ledgers between ledger checkpoints). If checkpointFrequency is 0 DefaultCheckpointFrequency will be used.
func (CheckpointManager) GetCheckpoint ¶
func (c CheckpointManager) GetCheckpoint(i uint32) uint32
GetCheckPoint gets the checkpoint containing information about the given ledger sequence
func (CheckpointManager) GetCheckpointRange ¶
func (c CheckpointManager) GetCheckpointRange(i uint32) Range
GetCheckpointRange gets the range of the checkpoint containing information for the given ledger sequence
func (CheckpointManager) IsCheckpoint ¶
func (c CheckpointManager) IsCheckpoint(i uint32) bool
func (CheckpointManager) MakeRange ¶
func (c CheckpointManager) MakeRange(low uint32, high uint32) Range
func (CheckpointManager) NextCheckpoint ¶
func (c CheckpointManager) NextCheckpoint(i uint32) uint32
func (CheckpointManager) PrevCheckpoint ¶
func (c CheckpointManager) PrevCheckpoint(i uint32) uint32
type CommandOptions ¶
type ConnectOptions ¶
type ConnectOptions struct { Context context.Context // NetworkPassphrase defines the expected network of history archive. It is // checked when getting HAS. If network passphrase does not match, error is // returned. NetworkPassphrase string S3Region string S3Endpoint string UnsignedRequests bool // CheckpointFrequency is the number of ledgers between checkpoints // if unset, DefaultCheckpointFrequency will be used CheckpointFrequency uint32 }
type FsArchiveBackend ¶
type FsArchiveBackend struct {
// contains filtered or unexported fields
}
func (*FsArchiveBackend) CanListFiles ¶
func (b *FsArchiveBackend) CanListFiles() bool
func (*FsArchiveBackend) GetFile ¶
func (b *FsArchiveBackend) GetFile(pth string) (io.ReadCloser, error)
func (*FsArchiveBackend) ListFiles ¶
func (b *FsArchiveBackend) ListFiles(pth string) (chan string, chan error)
func (*FsArchiveBackend) PutFile ¶
func (b *FsArchiveBackend) PutFile(pth string, in io.ReadCloser) error
type Hash ¶
func DecodeHash ¶
func EmptyXdrArrayHash ¶
func EmptyXdrArrayHash() Hash
func HashEmptyTxSet ¶
func MustDecodeHash ¶
type HistoryArchiveState ¶
type HistoryArchiveState struct { Version int `json:"version"` Server string `json:"server"` CurrentLedger uint32 `json:"currentLedger"` // NetworkPassphrase was added in Stellar-Core v14.1.0. Can be missing // in HAS created by previous versions. NetworkPassphrase string `json:"networkPassphrase"` CurrentBuckets [NumLevels]struct { Curr string `json:"curr"` Snap string `json:"snap"` Next struct { State uint32 `json:"state"` Output string `json:"output,omitempty"` } `json:"next"` } `json:"currentBuckets"` }
func (*HistoryArchiveState) BucketListHash ¶
func (h *HistoryArchiveState) BucketListHash() (xdr.Hash, error)
BucketListHash calculates the hash of bucket list in the HistoryArchiveState. This can be later compared with LedgerHeader.BucketListHash of the checkpoint ledger to ensure data in history archive has not been changed by a malicious actor. Warning: Ledger header should be fetched from a trusted (!) stellar-core instead of ex. history archives!
func (*HistoryArchiveState) Buckets ¶
func (h *HistoryArchiveState) Buckets() ([]Hash, error)
func (*HistoryArchiveState) GetChangedBuckets ¶
func (has *HistoryArchiveState) GetChangedBuckets(arch *Archive, prevHas *HistoryArchiveState) (string, int, int64)
func (*HistoryArchiveState) LevelSummary ¶
func (h *HistoryArchiveState) LevelSummary() (string, int, error)
func (*HistoryArchiveState) Range ¶
func (h *HistoryArchiveState) Range() Range
type HttpArchiveBackend ¶
type HttpArchiveBackend struct {
// contains filtered or unexported fields
}
func (*HttpArchiveBackend) CanListFiles ¶
func (b *HttpArchiveBackend) CanListFiles() bool
func (*HttpArchiveBackend) GetFile ¶
func (b *HttpArchiveBackend) GetFile(pth string) (io.ReadCloser, error)
func (*HttpArchiveBackend) Head ¶
func (b *HttpArchiveBackend) Head(pth string) (*http.Response, error)
func (*HttpArchiveBackend) ListFiles ¶
func (b *HttpArchiveBackend) ListFiles(pth string) (chan string, chan error)
func (*HttpArchiveBackend) PutFile ¶
func (b *HttpArchiveBackend) PutFile(pth string, in io.ReadCloser) error
type MockArchive ¶
MockArchive is a mockable archive.
func (*MockArchive) BucketExists ¶
func (m *MockArchive) BucketExists(bucket Hash) (bool, error)
func (*MockArchive) CategoryCheckpointExists ¶
func (m *MockArchive) CategoryCheckpointExists(cat string, chk uint32) (bool, error)
func (*MockArchive) GetCheckpointHAS ¶
func (m *MockArchive) GetCheckpointHAS(chk uint32) (HistoryArchiveState, error)
func (*MockArchive) GetCheckpointManager ¶
func (m *MockArchive) GetCheckpointManager() CheckpointManager
func (*MockArchive) GetLedgerHeader ¶
func (m *MockArchive) GetLedgerHeader(chk uint32) (xdr.LedgerHeaderHistoryEntry, error)
func (*MockArchive) GetPathHAS ¶
func (m *MockArchive) GetPathHAS(path string) (HistoryArchiveState, error)
func (*MockArchive) GetRootHAS ¶
func (m *MockArchive) GetRootHAS() (HistoryArchiveState, error)
func (*MockArchive) GetXdrStream ¶
func (m *MockArchive) GetXdrStream(pth string) (*XdrStream, error)
func (*MockArchive) GetXdrStreamForHash ¶
func (m *MockArchive) GetXdrStreamForHash(hash Hash) (*XdrStream, error)
func (*MockArchive) ListAllBucketHashes ¶
func (m *MockArchive) ListAllBucketHashes() (chan Hash, chan error)
func (*MockArchive) ListAllBuckets ¶
func (m *MockArchive) ListAllBuckets() (chan string, chan error)
func (*MockArchive) ListBucket ¶
func (m *MockArchive) ListBucket(dp DirPrefix) (chan string, chan error)
func (*MockArchive) ListCategoryCheckpoints ¶
func (m *MockArchive) ListCategoryCheckpoints(cat string, pth string) (chan uint32, chan error)
func (*MockArchive) PutCheckpointHAS ¶
func (m *MockArchive) PutCheckpointHAS(chk uint32, has HistoryArchiveState, opts *CommandOptions) error
func (*MockArchive) PutPathHAS ¶
func (m *MockArchive) PutPathHAS(path string, has HistoryArchiveState, opts *CommandOptions) error
func (*MockArchive) PutRootHAS ¶
func (m *MockArchive) PutRootHAS(has HistoryArchiveState, opts *CommandOptions) error
type MockArchiveBackend ¶
type MockArchiveBackend struct {
// contains filtered or unexported fields
}
func (*MockArchiveBackend) CanListFiles ¶
func (b *MockArchiveBackend) CanListFiles() bool
func (*MockArchiveBackend) GetFile ¶
func (b *MockArchiveBackend) GetFile(pth string) (io.ReadCloser, error)
func (*MockArchiveBackend) ListFiles ¶
func (b *MockArchiveBackend) ListFiles(pth string) (chan string, chan error)
func (*MockArchiveBackend) PutFile ¶
func (b *MockArchiveBackend) PutFile(pth string, in io.ReadCloser) error
type Range ¶
func (Range) GenerateCheckpoints ¶
func (r Range) GenerateCheckpoints(cManager CheckpointManager) chan uint32
func (Range) SizeInCheckPoints ¶
func (r Range) SizeInCheckPoints(cManager CheckpointManager) int
type S3ArchiveBackend ¶
type S3ArchiveBackend struct {
// contains filtered or unexported fields
}
func (*S3ArchiveBackend) CanListFiles ¶
func (b *S3ArchiveBackend) CanListFiles() bool
func (*S3ArchiveBackend) GetFile ¶
func (b *S3ArchiveBackend) GetFile(pth string) (io.ReadCloser, error)
func (*S3ArchiveBackend) ListFiles ¶
func (b *S3ArchiveBackend) ListFiles(pth string) (chan string, chan error)
func (*S3ArchiveBackend) PutFile ¶
func (b *S3ArchiveBackend) PutFile(pth string, in io.ReadCloser) error
type XdrStream ¶
type XdrStream struct {
// contains filtered or unexported fields
}
func NewXdrGzStream ¶
func NewXdrGzStream(in io.ReadCloser) (*XdrStream, error)
func NewXdrStream ¶
func NewXdrStream(in io.ReadCloser) *XdrStream
func (*XdrStream) Close ¶
Close closes all internal readers and checks if the expected hash (if set by SetExpectedHash) matches the actual hash of the stream.
func (*XdrStream) ExpectedHash ¶
ExpectedHash returns the expected hash and a boolean indicating if the expected hash was set