Documentation ¶
Index ¶
- Variables
- func GetApricotPhase0Time(networkID uint32) time.Time
- func GetApricotPhase1Time(networkID uint32) time.Time
- func GetApricotPhase2Time(networkID uint32) time.Time
- func GetApricotPhase3Time(networkID uint32) time.Time
- func GetApricotPhase4MinPChainHeight(networkID uint32) uint64
- func GetApricotPhase4Time(networkID uint32) time.Time
- func GetApricotPhase5Time(networkID uint32) time.Time
- type Application
- type ApplicationParser
- type Compatibility
- type Parser
- type Version
Constants ¶
This section is empty.
Variables ¶
View Source
var ( // TODO: Change to Flare versions after all nodes on Songbird have hard-coded // Flare versioning support. Current = NewDefaultVersion(1, 7, 2) CurrentApp = NewDefaultApplication(constants.PlatformName, Current.Major(), Current.Minor(), Current.Patch()) MinimumCompatibleVersion = NewDefaultApplication(constants.PlatformName, 1, 7, 0) PrevMinimumCompatibleVersion = NewDefaultApplication(constants.PlatformName, 1, 5, 0) MinimumUnmaskedVersion = NewDefaultApplication(constants.PlatformName, 1, 1, 0) PrevMinimumUnmaskedVersion = NewDefaultApplication(constants.PlatformName, 1, 0, 0) VersionParser = NewDefaultApplicationParser() CurrentDatabase = DatabaseVersion1_4_5 PrevDatabase = DatabaseVersion1_0_0 DatabaseVersion1_4_5 = NewDefaultVersion(1, 4, 5) DatabaseVersion1_0_0 = NewDefaultVersion(1, 0, 0) ApricotPhase0Times = map[uint32]time.Time{} ApricotPhase0DefaultTime = time.Date(2000, time.January, 1, 0, 0, 0, 0, time.UTC) ApricotPhase1Times = map[uint32]time.Time{} ApricotPhase1DefaultTime = time.Date(2000, time.January, 1, 0, 0, 0, 0, time.UTC) ApricotPhase2Times = map[uint32]time.Time{} ApricotPhase2DefaultTime = time.Date(2000, time.January, 1, 0, 0, 0, 0, time.UTC) ApricotPhase3Times = map[uint32]time.Time{ constants.CostonID: time.Date(2100, time.January, 1, 0, 0, 0, 0, time.UTC), constants.SongbirdID: time.Date(2100, time.January, 1, 0, 0, 0, 0, time.UTC), constants.FlareID: time.Date(2100, time.January, 1, 0, 0, 0, 0, time.UTC), } ApricotPhase3DefaultTime = time.Date(2000, time.January, 1, 0, 0, 0, 0, time.UTC) ApricotPhase4Times = map[uint32]time.Time{ constants.CostonID: time.Date(2100, time.January, 1, 0, 0, 0, 0, time.UTC), constants.SongbirdID: time.Date(2100, time.January, 1, 0, 0, 0, 0, time.UTC), constants.FlareID: time.Date(2100, time.January, 1, 0, 0, 0, 0, time.UTC), } ApricotPhase4DefaultTime = time.Date(2000, time.January, 1, 0, 0, 0, 0, time.UTC) ApricotPhase5Times = map[uint32]time.Time{ constants.CostonID: time.Date(2100, time.January, 1, 0, 0, 0, 0, time.UTC), constants.SongbirdID: time.Date(2100, time.January, 1, 0, 0, 0, 0, time.UTC), constants.FlareID: time.Date(2100, time.January, 1, 0, 0, 0, 0, time.UTC), } ApricotPhase5DefaultTime = time.Date(2000, time.December, 5, 5, 0, 0, 0, time.UTC) ApricotPhase4MinPChainHeight = map[uint32]uint64{} ApricotPhase4DefaultMinPChainHeight = uint64(0) )
These are globals that describe network upgrades and node versions
View Source
var ( // String is displayed when CLI arg --version is used String string // GitCommit is set in the build script at compile time GitCommit string )
View Source
var ( // DefaultVersion1_0_0 is a useful version to use in tests DefaultVersion1_0_0 = NewDefaultVersion(1, 0, 0) )
Functions ¶
func GetApricotPhase0Time ¶
func GetApricotPhase1Time ¶
func GetApricotPhase2Time ¶
func GetApricotPhase3Time ¶
func GetApricotPhase4MinPChainHeight ¶ added in v0.2.3
func GetApricotPhase4Time ¶ added in v0.2.3
func GetApricotPhase5Time ¶ added in v0.4.0
Types ¶
type Application ¶
type Application interface { Version App() string Compatible(Application) error Before(Application) bool }
Application defines what is needed to describe a versioned Application.
func NewApplication ¶
func NewApplication( app string, appSeparator string, versionSeparator string, major int, minor int, patch int, ) Application
NewApplication returns a new version
func NewDefaultApplication ¶
func NewDefaultApplication( app string, major int, minor int, patch int, ) Application
NewDefaultApplication returns a new version with default separators
type ApplicationParser ¶
type ApplicationParser interface {
Parse(string) (Application, error)
}
ApplicationParser defines the interface of an ApplicationVersion parser
func NewApplicationParser ¶
func NewApplicationParser(appSeparator string, versionSeparator string) ApplicationParser
NewApplicationParser returns a new parser
func NewDefaultApplicationParser ¶
func NewDefaultApplicationParser() ApplicationParser
NewDefaultApplicationParser returns a new parser with the default separators
type Compatibility ¶
type Compatibility interface { // Returns the local version Version() Application // Returns nil if the provided version is compatible with the local version. // This means that the version is connectable and that consensus messages // can be made to them. Compatible(Application) error // Returns nil if the provided version shouldn't be masked. This means that // the version is connectable but not compatible. The version is so old that // it should just be masked. Unmaskable(Application) error // Returns nil if the provided version will not be masked by this version. WontMask(Application) error // Returns when additional masking will occur. MaskTime() time.Time }
Compatibility a utility for checking the compatibility of peer versions
func GetCompatibility ¶
func GetCompatibility(networkID uint32) Compatibility
func NewCompatibility ¶
func NewCompatibility( version Application, minCompatible Application, minCompatibleTime time.Time, prevMinCompatible Application, minUnmaskable Application, minUnmaskableTime time.Time, prevMinUnmaskable Application, ) Compatibility
NewCompatibility returns a compatibility checker with the provided options
type Parser ¶
Parser defines the interface of a Version parser
func NewDefaultParser ¶
func NewDefaultParser() Parser
Click to show internal directories.
Click to hide internal directories.