version

package
v1.0.0-rc1 Latest Latest
Warning

This package is not in the latest version of its module.

Go to latest
Published: Apr 28, 2021 License: Apache-2.0 Imports: 8 Imported by: 869

Documentation

Index

Constants

This section is empty.

Variables

View Source
var All = PluginSupports("0.1.0", "0.2.0", "0.3.0", "0.3.1", "0.4.0", "1.0.0")
View Source
var Legacy = PluginSupports("0.1.0", "0.2.0")

Legacy PluginInfo describes a plugin that is backwards compatible with the CNI spec version 0.1.0. In particular, a runtime compiled against the 0.1.0 library ought to work correctly with a plugin that reports support for Legacy versions.

Any future CNI spec versions which meet this definition should be added to this list.

Functions

func Current

func Current() string

Current reports the version of the CNI spec implemented by this library

func GreaterThanOrEqualTo added in v0.7.0

func GreaterThanOrEqualTo(version, otherVersion string) (bool, error)

GreaterThanOrEqualTo takes two string versions, parses them into major/minor/micro numbers, and compares them to determine whether the first version is greater than or equal to the second

func NewResult added in v0.5.0

func NewResult(version string, resultBytes []byte) (types.Result, error)

Finds a Result object matching the requested version (if any) and asks that object to parse the plugin result, returning an error if parsing failed.

func ParsePrevResult added in v0.7.0

func ParsePrevResult(conf *types.NetConf) error

ParsePrevResult parses a prevResult in a NetConf structure and sets the NetConf's PrevResult member to the parsed Result object.

func ParseVersion added in v0.7.0

func ParseVersion(version string) (int, int, int, error)

ParseVersion parses a version string like "3.0.1" or "0.4.5" into major, minor, and micro numbers or returns an error

Types

type ConfigDecoder

type ConfigDecoder struct{}

ConfigDecoder can decode the CNI version available in network config data

func (*ConfigDecoder) Decode

func (*ConfigDecoder) Decode(jsonBytes []byte) (string, error)

type ErrorIncompatible

type ErrorIncompatible struct {
	Config    string
	Supported []string
}

func (*ErrorIncompatible) Details

func (e *ErrorIncompatible) Details() string

func (*ErrorIncompatible) Error

func (e *ErrorIncompatible) Error() string

type PluginDecoder

type PluginDecoder struct{}

PluginDecoder can decode the response returned by a plugin's VERSION command

func (*PluginDecoder) Decode

func (*PluginDecoder) Decode(jsonBytes []byte) (PluginInfo, error)

type PluginInfo

type PluginInfo interface {
	// SupportedVersions returns one or more CNI spec versions that the plugin
	// supports.  If input is provided in one of these versions, then the plugin
	// promises to use the same CNI version in its response
	SupportedVersions() []string

	// Encode writes this CNI version information as JSON to the given Writer
	Encode(io.Writer) error
}

PluginInfo reports information about CNI versioning

func PluginSupports

func PluginSupports(supportedVersions ...string) PluginInfo

PluginSupports returns a new PluginInfo that will report the given versions as supported

type Reconciler

type Reconciler struct{}

func (*Reconciler) Check

func (r *Reconciler) Check(configVersion string, pluginInfo PluginInfo) *ErrorIncompatible

func (*Reconciler) CheckRaw added in v0.5.0

func (*Reconciler) CheckRaw(configVersion string, supportedVersions []string) *ErrorIncompatible

Directories

Path Synopsis
Package legacy_examples contains sample code from prior versions of the CNI library, for use in verifying backwards compatibility.
Package legacy_examples contains sample code from prior versions of the CNI library, for use in verifying backwards compatibility.
Package testhelpers supports testing of CNI components of different versions For example, to build a plugin against an old version of the CNI library, we can pass the plugin's source and the old git commit reference to BuildAt.
Package testhelpers supports testing of CNI components of different versions For example, to build a plugin against an old version of the CNI library, we can pass the plugin's source and the old git commit reference to BuildAt.

Jump to

Keyboard shortcuts

? : This menu
/ : Search site
f or F : Jump to
y or Y : Canonical URL