2022-05-18 16:12:54 +00:00
// VulcanizeDB
// Copyright © 2022 Vulcanize
// This program is free software: you can redistribute it and/or modify
// it under the terms of the GNU Affero General Public License as published by
// the Free Software Foundation, either version 3 of the License, or
// (at your option) any later version.
// This program is distributed in the hope that it will be useful,
// but WITHOUT ANY WARRANTY; without even the implied warranty of
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
// GNU Affero General Public License for more details.
// You should have received a copy of the GNU Affero General Public License
// along with this program. If not, see <http://www.gnu.org/licenses/>.
2022-04-26 17:57:01 +00:00
package beaconclient
// This interface captured what the events can be for processed event streams.
type ProcessedEvents interface {
2022-05-06 15:03:15 +00:00
Head | ChainReorg
2022-04-26 17:57:01 +00:00
}
// This struct captures the JSON representation of the head topic
type Head struct {
Slot string ` json:"slot" `
Block string ` json:"block" `
State string ` json:"state" `
CurrentDutyDependentRoot string ` json:"current_duty_dependent_root" `
PreviousDutyDependentRoot string ` json:"previous_duty_dependent_root" `
EpochTransition bool ` json:"epoch_transition" `
ExecutionOptimistic bool ` json:"execution_optimistic" `
}
// This struct captures the JSON representation of the finalized_checkpoint topic.
type FinalizedCheckpoint struct {
Block string ` json:"block" `
State string ` json:"state" `
Epoch string ` json:"epoch" `
ExecutionOptimistic bool ` json:"execution_optimistic" `
}
// This struct captures the JSON representation of the chain_reorg topic.
type ChainReorg struct {
Slot string ` json:"slot" `
Depth string ` json:"depth" `
OldHeadBlock string ` json:"old_head_block" `
NewHeadBlock string ` json:"new_head_block" `
OldHeadState string ` json:"old_head_state" `
NewHeadState string ` json:"new_head_state" `
Epoch string ` json:"epoch" `
ExecutionOptimistic bool ` json:"execution_optimistic" `
}
2022-05-06 15:03:15 +00:00
// A struct to capture whats being written to the ethcl.slots table.
type DbSlots struct {
Epoch string // The epoch.
Slot string // The slot.
BlockRoot string // The block root
StateRoot string // The state root
2022-05-13 12:48:31 +00:00
Status string // The status, it can be proposed | forked | skipped.
2022-05-06 15:03:15 +00:00
}
// A struct to capture whats being written to ethcl.signed_beacon_block table.
type DbSignedBeaconBlock struct {
2022-05-12 19:44:05 +00:00
Slot string // The slot.
BlockRoot string // The block root
ParentBlock string // The parent block root.
Eth1BlockHash string // The eth1 block_hash
MhKey string // The ipld multihash key.
2022-05-06 15:03:15 +00:00
}
// A struct to capture whats being written to ethcl.beacon_state table.
type DbBeaconState struct {
Slot string // The slot.
StateRoot string // The state root
MhKey string // The ipld multihash key.
}
2022-05-12 19:44:05 +00:00
// A structure to capture whats being written to the ethcl.known_gaps table.
type DbKnownGaps struct {
StartSlot string // The start slot for known_gaps, inclusive.
EndSlot string // The end slot for known_gaps, inclusive.
CheckedOut bool // Indicates if any process is currently processing this entry.
ReprocessingError string // The error that occurred when attempting to reprocess these entries.
EntryError string // The error that caused this entry to be added to the table. Could be null.
EntryTime string // The time this range was added to the DB. This can help us catch ranges that have not been processed for a long time due to some error.
EntryProcess string // The entry process that added this process. Potential options are StartUp, Error, ManualEntry, HeadGap.
}