Documentation ¶
Index ¶
- Constants
- Variables
- func GetApricotPhase1Time(networkID uint32) time.Time
- func GetApricotPhase2Time(networkID uint32) time.Time
- func GetApricotPhase3Time(networkID uint32) time.Time
- func GetApricotPhase4Time(networkID uint32) time.Time
- func GetApricotPhase5Time(networkID uint32) time.Time
- func GetApricotPhase6Time(networkID uint32) time.Time
- func GetApricotPhasePost6Time(networkID uint32) time.Time
- func GetApricotPhasePre6Time(networkID uint32) time.Time
- func GetBanffTime(networkID uint32) time.Time
- func GetCortinaTime(networkID uint32) time.Time
- func GetDurangoTime(networkID uint32) time.Time
- func GetEUpgradeTime(networkID uint32) time.Time
- type Application
- type Compatibility
- type Semantic
- type Versions
Constants ¶
const ( Client = "avalanchego" // RPCChainVMProtocol should be bumped anytime changes are made which // require the plugin vm to upgrade to latest avalanchego release to be // compatible. RPCChainVMProtocol uint = 35 )
Variables ¶
var ( Current = &Semantic{ Major: 1, Minor: 11, Patch: 9, } CurrentApp = &Application{ Name: Client, Major: Current.Major, Minor: Current.Minor, Patch: Current.Patch, } MinimumCompatibleVersion = &Application{ Name: Client, Major: 1, Minor: 11, Patch: 0, } PrevMinimumCompatibleVersion = &Application{ Name: Client, Major: 1, Minor: 10, Patch: 0, } CurrentDatabase = DatabaseVersion1_4_5 PrevDatabase = DatabaseVersion1_0_0 DatabaseVersion1_4_5 = &Semantic{ Major: 1, Minor: 4, Patch: 5, } DatabaseVersion1_0_0 = &Semantic{ Major: 1, Minor: 0, Patch: 0, } // RPCChainVMProtocolCompatibility maps RPCChainVMProtocol versions to the // set of avalanchego versions that supported that version. This is not used // by avalanchego, but is useful for downstream libraries. RPCChainVMProtocolCompatibility map[uint][]*Semantic DefaultUpgradeTime = time.Date(2020, time.December, 5, 5, 0, 0, 0, time.UTC) ApricotPhase1Times = map[uint32]time.Time{ constants.MainnetID: time.Date(2021, time.March, 31, 14, 0, 0, 0, time.UTC), constants.FujiID: time.Date(2021, time.March, 26, 14, 0, 0, 0, time.UTC), } ApricotPhase2Times = map[uint32]time.Time{ constants.MainnetID: time.Date(2021, time.May, 10, 11, 0, 0, 0, time.UTC), constants.FujiID: time.Date(2021, time.May, 5, 14, 0, 0, 0, time.UTC), } ApricotPhase3Times = map[uint32]time.Time{ constants.MainnetID: time.Date(2021, time.August, 24, 14, 0, 0, 0, time.UTC), constants.FujiID: time.Date(2021, time.August, 16, 19, 0, 0, 0, time.UTC), } ApricotPhase4Times = map[uint32]time.Time{ constants.MainnetID: time.Date(2021, time.September, 22, 21, 0, 0, 0, time.UTC), constants.FujiID: time.Date(2021, time.September, 16, 21, 0, 0, 0, time.UTC), } ApricotPhase4MinPChainHeight = map[uint32]uint64{ constants.MainnetID: 793005, constants.FujiID: 47437, } ApricotPhase5Times = map[uint32]time.Time{ constants.MainnetID: time.Date(2021, time.December, 2, 18, 0, 0, 0, time.UTC), constants.FujiID: time.Date(2021, time.November, 24, 15, 0, 0, 0, time.UTC), } ApricotPhasePre6Times = map[uint32]time.Time{ constants.MainnetID: time.Date(2022, time.September, 5, 1, 30, 0, 0, time.UTC), constants.FujiID: time.Date(2022, time.September, 6, 20, 0, 0, 0, time.UTC), } ApricotPhase6Times = map[uint32]time.Time{ constants.MainnetID: time.Date(2022, time.September, 6, 20, 0, 0, 0, time.UTC), constants.FujiID: time.Date(2022, time.September, 6, 20, 0, 0, 0, time.UTC), } ApricotPhasePost6Times = map[uint32]time.Time{ constants.MainnetID: time.Date(2022, time.September, 7, 3, 0, 0, 0, time.UTC), constants.FujiID: time.Date(2022, time.September, 7, 6, 0, 0, 0, time.UTC), } BanffTimes = map[uint32]time.Time{ constants.MainnetID: time.Date(2022, time.October, 18, 16, 0, 0, 0, time.UTC), constants.FujiID: time.Date(2022, time.October, 3, 14, 0, 0, 0, time.UTC), } CortinaTimes = map[uint32]time.Time{ constants.MainnetID: time.Date(2023, time.April, 25, 15, 0, 0, 0, time.UTC), constants.FujiID: time.Date(2023, time.April, 6, 15, 0, 0, 0, time.UTC), } CortinaXChainStopVertexID = map[uint32]ids.ID{ constants.MainnetID: ids.FromStringOrPanic("jrGWDh5Po9FMj54depyunNixpia5PN4aAYxfmNzU8n752Rjga"), constants.FujiID: ids.FromStringOrPanic("2D1cmbiG36BqQMRyHt4kFhWarmatA1ighSpND3FeFgz3vFVtCZ"), } DurangoTimes = map[uint32]time.Time{ constants.MainnetID: time.Date(2024, time.March, 6, 16, 0, 0, 0, time.UTC), constants.FujiID: time.Date(2024, time.February, 13, 16, 0, 0, 0, time.UTC), } EUpgradeTimes = map[uint32]time.Time{ constants.MainnetID: time.Date(10000, time.December, 1, 0, 0, 0, 0, time.UTC), constants.FujiID: time.Date(10000, time.December, 1, 0, 0, 0, 0, time.UTC), } )
These are globals that describe network upgrades and node versions
var GitCommit string
GitCommit is set in the build script at compile time
var ( // V1_0_0 is a useful version to use in tests Semantic1_0_0 = &Semantic{ Major: 1, Minor: 0, Patch: 0, } )
Functions ¶
func GetApricotPhase1Time ¶ added in v1.4.5
func GetApricotPhase2Time ¶ added in v1.4.5
func GetApricotPhase3Time ¶ added in v1.5.0
func GetApricotPhase4Time ¶ added in v1.6.0
func GetApricotPhase5Time ¶ added in v1.7.0
func GetApricotPhase6Time ¶ added in v1.8.0
func GetApricotPhasePost6Time ¶ added in v1.10.19
func GetApricotPhasePre6Time ¶ added in v1.10.19
func GetBanffTime ¶ added in v1.9.0
func GetCortinaTime ¶ added in v1.9.12
func GetDurangoTime ¶ added in v1.10.17
func GetEUpgradeTime ¶ added in v1.11.3
Types ¶
type Application ¶ added in v1.4.5
type Application struct { Name string `json:"name" yaml:"name"` Major int `json:"major" yaml:"major"` Minor int `json:"minor" yaml:"minor"` Patch int `json:"patch" yaml:"patch"` // contains filtered or unexported fields }
func (*Application) Before ¶ added in v1.4.5
func (a *Application) Before(o *Application) bool
func (*Application) Compare ¶ added in v1.7.14
func (a *Application) Compare(o *Application) int
Compare returns a positive number if s > o, 0 if s == o, or a negative number if s < o.
func (*Application) Compatible ¶ added in v1.4.5
func (a *Application) Compatible(o *Application) error
func (*Application) String ¶ added in v1.7.14
func (a *Application) String() string
The only difference here between Application and Semantic is that Application prepends the client name rather than "v".
type Compatibility ¶ added in v1.3.2
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 }
Compatibility a utility for checking the compatibility of peer versions
func GetCompatibility ¶ added in v1.4.5
func GetCompatibility(networkID uint32) Compatibility
func NewCompatibility ¶ added in v1.3.2
func NewCompatibility( version *Application, minCompatible *Application, minCompatibleTime time.Time, prevMinCompatible *Application, ) Compatibility
NewCompatibility returns a compatibility checker with the provided options
type Semantic ¶ added in v1.7.14
type Semantic struct { Major int `json:"major" yaml:"major"` Minor int `json:"minor" yaml:"minor"` Patch int `json:"patch" yaml:"patch"` // contains filtered or unexported fields }
type Versions ¶ added in v1.11.9
type Versions struct { Application string `json:"application"` Database string `json:"database"` RPCChainVM uint64 `json:"rpcchainvm"` // Commit may be empty if GitCommit was not set at compile time Commit string `json:"commit"` Go string `json:"go"` }
Versions contains the versions relevant to a build of avalanchego. In addition to supporting construction of the string displayed by --version, it is used to produce the output of --version-json and can be used to unmarshal that output.
func GetVersions ¶ added in v1.11.9
func GetVersions() *Versions