ygot

package
v0.29.15 Latest Latest
Warning

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

Go to latest
Published: Nov 7, 2023 License: Apache-2.0 Imports: 23 Imported by: 795

Documentation

Overview

Package ygot contains helper methods for dealing with structs that represent a YANG schema. Particularly, it takes structs that represent a YANG schema - generated by ygen:

  • Provides helper functions which simplify their usage such as functions to return pointers to a type.
  • Renders structs to other output formats such as JSON, or gNMI notifications.

Index

Constants

View Source
const (
	// PathStructInterfaceName is the name for the interface implemented by all
	// generated path structs.
	PathStructInterfaceName = "PathStruct"
	// PathBaseTypeName is the type name of the common embedded struct
	// containing the path information for a path struct.
	PathBaseTypeName = "NodePath"
	// FakeRootBaseTypeName is the type name of the fake root struct which
	// should be embedded within the fake root path struct.
	FakeRootBaseTypeName = "DeviceRootBase"
)
View Source
const (
	// BinaryTypeName is the name of the type that is used for YANG
	// binary fields in the output structs.
	BinaryTypeName string = "Binary"
	// EmptyTypeName is the name of the type that is used for YANG
	// empty fields in the output structs.
	EmptyTypeName string = "YANGEmpty"
)
View Source
const (
	// GoCompressedLeafAnnotation is the yang.Entry annotation name to
	// indicate that a particular leaf entry has a sibling that is
	// compressed out.
	GoCompressedLeafAnnotation = "ygot-oc-compressed-leaf"
)

Variables

View Source
var (
	// SimpleUnionBuiltinGoTypes stores the valid types that the Go code
	// generation produces for simple union types given a regular leaf type
	// name in Go.
	SimpleUnionBuiltinGoTypes = map[string]string{
		"int8":         "UnionInt8",
		"int16":        "UnionInt16",
		"int32":        "UnionInt32",
		"int64":        "UnionInt64",
		"uint8":        "UnionUint8",
		"uint16":       "UnionUint16",
		"uint32":       "UnionUint32",
		"uint64":       "UnionUint64",
		"float64":      "UnionFloat64",
		"string":       "UnionString",
		"bool":         "UnionBool",
		"interface{}":  "*UnionUnsupported",
		BinaryTypeName: BinaryTypeName,
		EmptyTypeName:  EmptyTypeName,
	}
)

Functions

func BinaryToFloat32 added in v0.7.0

func BinaryToFloat32(in []byte) float32

BinaryToFloat32 converts the input bytes to a float32 assuming IEEE 754 representation. The input bytes should be of length 4.

func Bool

func Bool(b bool) *bool

Bool takes a boolean argument and returns a pointer to it.

func BuildEmptyTree

func BuildEmptyTree(s GoStruct)

BuildEmptyTree initialises the YANG tree starting at the root GoStruct provided. This allows the YANG container hierarchy (i.e., any structs within the tree) to be pre-initialised rather than requiring the user to initialise each as it is required. Given that some trees may be large, then some caution should be exercised in initialising an entire tree. If struct pointer fields are non-nil, they are considered initialised, and are skipped.

func ConstructIETFJSON

func ConstructIETFJSON(s GoStruct, args *RFC7951JSONConfig) (map[string]any, error)

ConstructIETFJSON marshals a supplied GoStruct to a map, suitable for handing to json.Marshal. It complies with the convention for marshalling to JSON described by RFC7951. The supplied args control options corresponding to the method by which JSON is marshalled.

func ConstructInternalJSON

func ConstructInternalJSON(s GoStruct) (map[string]any, error)

ConstructInternalJSON marshals a supplied GoStruct to a map, suitable for handing to json.Marshal. It uses the loosely specified JSON format document in go/yang-internal-json.

func Diff added in v0.6.0

func Diff(original, modified GoStruct, opts ...DiffOpt) (*gnmipb.Notification, error)

Diff takes an original and modified GoStruct, which must be of the same type and returns a gNMI Notification that contains the diff between them. The original struct is considered as the "from" data, with the modified struct the "to" such that:

  • The contents of the Update field of the notification indicate that the field in modified was either not present in original, or had a different field value.
  • The paths within the Delete field of the notification indicate that the field was not present in the modified struct, but was set in the original.
  • NOTE: For `ordered-by user` nodes, which are represented by ordered maps in the ygot-generated code, the output Notification cannot be directly unmarshalling into original to arrive at modified since updates are granular. For generating atomic:true Notifications, use ygot.DiffWithAtomic instead.

Annotation fields that are contained within the supplied original or modified GoStruct are skipped.

A set of options for diff's behaviour, as specified by the supplied DiffOpts can be used to modify the behaviour of the Diff function per the individual option's specification.

The returned gNMI Notification cannot be put on the wire unmodified, since it does not specify a timestamp - and may not contain the absolute paths to the fields specified if a GoStruct that does not represent the root of a YANG schema tree is not supplied as original and modified.

func DiffWithAtomic added in v0.29.0

func DiffWithAtomic(original, modified GoStruct, opts ...DiffOpt) ([]*gnmipb.Notification, error)

DiffWithAtomic takes an original and modified GoStruct, which must be of the same type and returns a slice of gNMI Notifications that represents the diff between them in a way that can be used to update a local gNMI.Subscribe server with the Notifications to be served. When ytypes.UnmarshalNotifications is called, it can also provide the same GoStruct back.

The last message in the slice (if it exists) contains a non-atomic Notification representing updates/deletes to non-atomic nodes and deletes to atomic nodes. All messages prior to the last one are atomic Notifications representing updates to atomic nodes.

NOTE: Currently only YANG `ordered-by user lists` are supported as atomic nodes. Further, they're always treated as so since there is no way of representing order using TypedValue scalar types.

The original struct is considered as the "from" data, with the modified struct the "to" such that:

  • The contents of the Update field of the notification indicate that the field in modified was either not present in original, or had a different field value.
  • The paths within the Delete field of the notification indicate that the field was not present in the modified struct, but was set in the original.

Annotation fields that are contained within the supplied original or modified GoStruct are skipped.

A set of options for diff's behaviour, as specified by the supplied DiffOpts can be used to modify the behaviour of the Diff function per the individual option's specification.

The returned gNMI Notification cannot be put on the wire unmodified, since it does not specify a timestamp - and may not contain the absolute paths to the fields specified if a GoStruct that does not represent the root of a YANG schema tree is not supplied as original and modified.

func EmitJSON

func EmitJSON(gs GoStruct, opts *EmitJSONConfig) (string, error)

EmitJSON takes an input GoStruct (produced by ygen with validation enabled) and serialises it to a JSON string. By default, produces the Internal format JSON.

func EncodeTypedValue added in v0.6.0

func EncodeTypedValue(val any, enc gnmipb.Encoding, opts ...EncodeTypedValueOpt) (*gnmipb.TypedValue, error)

EncodeTypedValue encodes val into a gNMI TypedValue message, using the specified encoding type if the value is a struct.

func EnumLogString added in v0.7.2

func EnumLogString(e GoEnum, val int64, enumTypeName string) string

EnumLogString uses the EnumDefinition map of the given enum, an input int64 val, and the input type name of the enum to output a log-friendly string. If val is a valid enum value, then the defined YANG string corresponding to the enum value is returned; otherwise, an out-of-range error string is returned.

func EnumName added in v0.6.0

func EnumName(e GoEnum) (string, error)

EnumName returns the string name of an input GoEnum e. If the enumeration is unset, the name returned is an empty string, otherwise it is the name defined within the YANG schema. Non-zero out-of-range values and unrecognized enums will produce an error.

func Float32

func Float32(f float32) *float32

Float32 takes a float32 argument and returns a pointer to it.

func Float64

func Float64(f float64) *float64

Float64 takes a float64 argument and returns a pointer to it.

func FormatDiff added in v0.29.14

func FormatDiff(n *gnmipb.Notification) string

FormatDiff formats the output of ygot.Diff as a multiline string. This function is only intended for human consumption and ignores errors. Do not depend on the output being stable. It may change over time across different versions of the program.

func GzipToSchema

func GzipToSchema(gzj []byte) (map[string]*yang.Entry, error)

GzipToSchema takes an input byte slice, and returns it as a map of yang.Entry nodes, keyed by the name of the struct that the yang.Entry describes the schema for.

func InitContainer

func InitContainer(s GoStruct, cname string) error

InitContainer initialises the container cname of the GoStruct s, it can be used to initialise an arbitrary named child container within a YANG structure in a generic manner. This allows the caller to generically initialise a sub-element of the YANG tree without needing to have specific handling code.

func Int16

func Int16(i int16) *int16

Int16 takes an int16 argument and returns a pointer to it.

func Int32

func Int32(i int32) *int32

Int32 takes an int32 argument and returns a pointer to it.

func Int64

func Int64(i int64) *int64

Int64 takes an int64 argument and returns a pointer to it.

func Int8

func Int8(i int8) *int8

Int8 takes an int8 argument and returns a pointer to it.

func KeyValueAsString added in v0.6.0

func KeyValueAsString(v any) (string, error)

KeyValueAsString returns a string representation of the any supplied. If the type provided cannot be represented as a string for use in a gNMI path, an error is returned.

func Marshal7951 added in v0.8.0

func Marshal7951(d any, args ...Marshal7951Arg) ([]byte, error)

Marshal7951 renders the supplied interface to RFC7951-compatible JSON. The argument supplied must be a valid type within a generated ygot GoStruct - but can be a member field of a generated struct rather than the entire struct - allowing specific fields to be rendered. The supplied arguments control the JSON marshalling behaviour - both base JSON Marshal (e.g., indentation), as well as RFC7951 specific options such as YANG module names being prepended. The rendered JSON is returned as a byte slice - in common with json.Marshal.

func MergeJSON

func MergeJSON(a, b map[string]interface{}) (map[string]interface{}, error)

MergeJSON takes two input maps, and merges them into a single map.

func MergeStructInto added in v0.7.1

func MergeStructInto(dst, src GoStruct, opts ...MergeOpt) error

MergeStructInto takes the provided input GoStruct and merges the contents from src into dst. Unlike MergeStructs, the supplied dst is mutated.

The merge semantics are the same as those for MergeStructs.

func MergeStructJSON

func MergeStructJSON(ns GoStruct, ej map[string]interface{}, opts *EmitJSONConfig) (map[string]interface{}, error)

MergeStructJSON marshals the GoStruct ns to JSON according to the configuration, and merges it with the existing JSON provided as a map[string]interface{}. The merged JSON output is returned.

To create valid JSON-serialised YANG, it is expected that the existing JSON is in the same format as is specified in the options. Where there are overlapping tree elements in the serialised struct they are merged where possible.

func ModifyKey added in v0.7.0

func ModifyKey(n *NodePath, name string, value interface{})

ModifyKey updates a NodePath's key value.

func MustStringToPath added in v0.26.0

func MustStringToPath(path string) *gnmipb.Path

MustStringToPath calls StringToStructuredPath and panics on error. It is intended for use in tests with hard-coded strings.

func PathKeyFromStruct added in v0.6.0

func PathKeyFromStruct(v reflect.Value) (map[string]string, error)

PathKeyFromStruct returns a map[string]string which represents the keys for a YANG list element. The provided reflect.Value must implement the KeyHelperGoStruct interface, and hence be a struct which represents a list member within the schema.

func PathToSchemaPath added in v0.6.0

func PathToSchemaPath(path *gnmipb.Path) (string, error)

PathToSchemaPath returns the supplied Path as its corresponding schema path. The YANG schema path removes any keys (i.e., predicates) from the path, using only the name.

func PathToString

func PathToString(path *gnmipb.Path) (string, error)

PathToString is like PathToStrings, but returns a single formatted string representing the path. Path is always treated as absolute.

func PathToStrings

func PathToStrings(path *gnmipb.Path) ([]string, error)

PathToStrings takes a gNMI Path and provides its string representation. For example, the path Path{Element: []string{"one", "two", "three"} is converted to the slice ["one", "two", "three"] and returned. Both the pre-0.4.0 "element"-based paths, and the >0.4.0 paths based on "elem" are supported. In the case that post-0.4.0 paths are specified, keys that are specified in the path are concatenated onto the name of the path element using the format [name=value]. If the path specifies both pre- and post-0.4.0 paths, the pre-0.4.0 version is returned.

func PruneConfigFalse added in v0.12.5

func PruneConfigFalse(schema *yang.Entry, s GoStruct) error

PruneConfigFalse in-place removes branches or leaf nodes that represent derived state for compressed GoStructs, and branches or leaf nodes that contain "config false" data for uncompressed GoStructs.

Derived state is the subset of all operational state, or equivalently, "config false" nodes in the YANG definition, where the data is generated as part of the system's own interactions, rather than to reflect under what configuration the system is operating, the latter also known as applied configuration. These nodes are identifiable in YANG as the subset of "config false" nodes that do not have a sibling "config true" node in OpenConfig YANG models.

The distinction between compressed and uncompressed GoStructs is due to the intrinsic non-existence of either intended configuration or applied configuration in the GoStruct, making pruning derived state the more useful operation for compressed GoStructs.

The behaviour of this function is the same between compressed GoStructs generated using PreferIntendedConfig or PreferOperationalState, since compression behaviour doesn't affect derived state data.

If the input GoStruct is itself to be entirely pruned, then instead, all of its fields will be removed.

This function assumes that there should not be "config true" leaves underneath a "config false" branch, per RFC7950 (https://datatracker.ietf.org/doc/html/rfc7950#section-7.21.1).

func PruneEmptyBranches added in v0.6.0

func PruneEmptyBranches(s GoStruct)

PruneEmptyBranches removes branches that have no populated children from the GoStruct s in-place. This allows a YANG container hierarchy that has been initialised with BuildEmptyTree to have those branches that were not populated removed from the tree. All subtrees rooted at the supplied GoStruct are traversed and any encountered GoStruct pointer fields are removed if they equate to the zero value (i.e. are unpopulated).

func ResolvePath added in v0.7.0

func ResolvePath(n PathStruct) (*gpb.Path, map[string]interface{}, []error)

ResolvePath is a helper which returns the resolved *gpb.Path of a PathStruct node as well as the root node's customData.

func ResolveRelPath added in v0.7.0

func ResolveRelPath(n PathStruct) ([]*gpb.PathElem, []error)

ResolveRelPath returns the partial []*gpb.PathElem representing the PathStruct's relative path.

func String

func String(s string) *string

String takes a string argument and returns a pointer to it.

func StringToPath

func StringToPath(path string, pathTypes ...PathType) (*gnmipb.Path, error)

StringToPath takes an input string representing a path in gNMI, and converts it to a gNMI Path message, populated with the specified path encodings.

func StringToStringSlicePath

func StringToStringSlicePath(path string) (*gnmipb.Path, error)

StringToStringSlicePath takes a string representing a path, and converts it into a gnmi.Path. For example, if the Path "/a/b[c=d]/e" is input, it is converted to a gnmi.Path{Element: []string{"a", "b[c=d]", "e"}} which is returned. Where there are complex predicates that are used within an element, they are not parsed and the contents is left unchanged. This implements the legacy string slice path that are used in gNMI pre-0.4.0. The specification for these paths is at https://goo.gl/uD6g6z.

func StringToStructuredPath

func StringToStructuredPath(path string) (*gnmipb.Path, error)

StringToStructuredPath takes a string representing a path, and converts it to a gnmi.Path, using the PathElem element message that is defined in gNMI 0.4.0.

func ToPtr

func ToPtr(v interface{}) interface{}

ToPtr returns a pointer to v.

func TogNMINotifications

func TogNMINotifications(s GoStruct, ts int64, cfg GNMINotificationsConfig) ([]*gnmipb.Notification, error)

TogNMINotifications takes an input GoStruct and renders it to slice of Notification messages, marked with the specified timestamp. The configuration provided determines the path format utilised, and the prefix to be included in the message if relevant. If there are any `ordered-by user` lists within the input struct, then they will be treated as "telemetry-atomic", and put into separate atomic notifications after the initial notification containing the non-atomic updates.

Note: Within the generated notifications there could be data sharing for space and compute optimization. Make a deep copy if one plans to modify the generated message.

TODO(robjs): When we have deprecated the string slice paths, then this function can be simplified to remove support for them - including removing the gnmiPath abstraction. It can also be refactored to simply use the findSetleaves function which has a cleaner implementation using the reworked iterfunction util.

func Uint16

func Uint16(u uint16) *uint16

Uint16 takes an uint16 argument and returns a pointer to it.

func Uint32

func Uint32(u uint32) *uint32

Uint32 takes an uint32 argument and returns a pointer to it.

func Uint64

func Uint64(u uint64) *uint64

Uint64 takes an uint64 argument and returns a pointer to it.

func Uint8

func Uint8(u uint8) *uint8

Uint8 takes an uint8 argument and returns a pointer to it.

func ValidateGoStruct added in v0.25.2

func ValidateGoStruct(goStruct GoStruct, vopts ...ValidationOption) error

ValidateGoStruct validates a GoStruct.

Types

type Annotation added in v0.6.0

type Annotation interface {
	// MarshalJSON is used to marshal the annotation to JSON. It ensures that
	// the json.Marshaler interface is implemented.
	MarshalJSON() ([]byte, error)
	// UnmarshalJSON is used to unmarshal JSON into the Annotation. It ensures that
	// the json.Unmarshaler interface is implemented.
	UnmarshalJSON([]byte) error
}

Annotation defines an interface that is implemented by optional metadata fields within a GoStruct. Annotations are stored within each struct, and for a struct field, for example:

type GoStructExample struct {
   ΛMetadata []*ygot.Annotation `path:"@"`
   StringField *string `path:"string-field"`
   ΛStringField []*ygot.Annotation `path:"@string-field"`
}

The ΛMetadata and ΛStringField fields can be populated with a slice of arbitrary types implementing the Annotation interface.

Each Annotation must implement the MarshalJSON and UnmarshalJSON methods, such that its content can be serialised and deserialised from JSON. Using the approach described in RFC7952 can be used to store metadata within RFC7951-serialised JSON.

type DeviceRootBase added in v0.8.1

type DeviceRootBase struct {
	*NodePath
	// contains filtered or unexported fields
}

DeviceRootBase represents the fakeroot for all YANG schema elements.

func NewDeviceRootBase added in v0.8.1

func NewDeviceRootBase(id string) *DeviceRootBase

func (*DeviceRootBase) CustomData added in v0.8.1

func (d *DeviceRootBase) CustomData() map[string]interface{}

CustomData returns the customData field of the DeviceRootBase struct.

func (*DeviceRootBase) Id added in v0.8.1

func (d *DeviceRootBase) Id() string

Id returns the device ID of the DeviceRootBase struct.

func (*DeviceRootBase) PutCustomData added in v0.8.1

func (d *DeviceRootBase) PutCustomData(key string, val interface{})

PutCustomData modifies an entry in the customData field of the DeviceRootBase struct.

type DiffOpt added in v0.6.0

type DiffOpt interface {
	// IsDiffOpt is a marker method for each DiffOpt.
	IsDiffOpt()
}

DiffOpt is an interface that is implemented by the options to the Diff function. It allows user specified options to be propagated to the diff method.

type DiffPathOpt added in v0.6.0

type DiffPathOpt struct {
	// MapToSinglePath specifies whether a single ygot.GoStruct field should
	// be mapped to more than one value. If set to true, when a struct tag
	// annotation specifies more than one path (e.g., `path:"foo|config/foo"`)
	// only the shortest path is mapped to.
	//
	// This option is primarily used where path compression has been used in the
	// generated structs, which can result in duplication of list key leaves in
	// the diff output.
	MapToSinglePath bool
	// PreferShadowPath specifies whether the "shadow-path" struct tag
	// annotation should be used instead of the "path" struct tag when it
	// exists.
	//
	// This option is used when GoStructs are generated with the
	// -ignore_shadow_schema_paths flag, and therefore have the
	// "shadow-path" tag.
	PreferShadowPath bool
}

DiffPathOpt is a DiffOpt that allows control of the path behaviour of the Diff function.

func (*DiffPathOpt) IsDiffOpt added in v0.6.0

func (*DiffPathOpt) IsDiffOpt()

IsDiffOpt marks DiffPathOpt as a diff option.

type EmitJSONConfig

type EmitJSONConfig struct {
	// Format specifies the JSON format that should be output by the EmitJSON
	// function - using the enumerated JSONType function. By default, internal
	// format JSON will be produced.
	Format JSONFormat
	// RFC7951Config specifies the configuration options for RFC7951 JSON. Only
	// valid if Format is RFC7951.
	RFC7951Config *RFC7951JSONConfig
	// Indent is the string used for indentation within the JSON output. The
	// default value is three spaces.
	Indent string
	// EscapeHTML determines whether certain characters will be escaped
	// in the marshalled JSON for safety in HTML embedding. See
	// https://pkg.go.dev/encoding/json#Encoder.SetEscapeHTML.
	EscapeHTML bool
	// SkipValidation specifies whether the GoStruct supplied to EmitJSON should
	// be validated before emitting its content. Validation is skipped when it
	// is set to true.
	SkipValidation bool
	// ValidationOpts is the set of options that should be used to determine how
	// the schema should be validated. This allows fine-grained control of particular
	// validation rules in the case that a partially populated data instance is
	// to be emitted.
	ValidationOpts []ValidationOption
}

EmitJSONConfig specifies the how JSON should be created by the EmitJSON function.

type EncodeTypedValueOpt added in v0.25.3

type EncodeTypedValueOpt interface {
	// IsMarshal7951Arg is a market method.
	IsEncodeTypedValueOpt()
}

EncodeTypedValueOpt is an interface implemented by arguments to the EncodeTypedValueOpt function.

type EnumDefinition

type EnumDefinition struct {
	// Name is the string name of the enumerated value.
	Name string
	// DefiningModule specifies the module within which the enumeration was
	// defined. Only populated for identity values.
	DefiningModule string
	// Value is an optionally-populated field that specifies the value of
	// an enumerated type.
	//
	// TODO: Consider removing this field and using a custom type in the
	// ygen package since only the IR generation populates this field.
	//
	// When populated, the following values are recommended:
	// For enumerations, this value is determined by goyang.
	// For identityrefs, this value is determined by the lexicographical
	// ordering of the identityref name, starting with 0 to be consistent
	// with goyang's enumeration numbering.
	Value int
}

EnumDefinition is used to store the details of an enumerated value. All YANG enumerated values (enumeration, identityref) has a Name which represents the string name used for the enumerated value in the YANG module (which may not be Go safe). Enumerated types that are derived from identity values also have an associated DefiningModule, such that they can be serialised to the correct RFC7951 JSON format (see Section 6.8 of RFC7951), https://tools.ietf.org/html/rfc7951#section-6.8

type GNMINotificationsConfig

type GNMINotificationsConfig struct {
	// UsePathElem specifies whether the elem field of the gNMI Path
	// message should be used for the paths in the output notification. If
	// set to false, the element field is used.
	UsePathElem bool
	// ElementPrefix stores the prefix that should be used within the
	// Prefix field of the gNMI Notification message expressed as a slice
	// of strings as per the path definition in gNMI 0.3.1 and below.
	// Used if UsePathElem is unset.
	//
	// If there is an ordered map, which will always be marshalled within
	// its own Notification message, then the ordered map will be given a
	// prefix that concatenates the given prefix with the relative path of
	// the ordered map from the given node.
	StringSlicePrefix []string
	// PathElemPrefix stores the prefix that should be used within the
	// Prefix field of the gNMI Notification message, expressed as a slice
	// of PathElem messages. This path format is used by gNMI 0.4.0 and
	// above. Used if PathElem is set.
	//
	// If there is an ordered map, which will always be marshalled within
	// its own Notification message, then the ordered map will be given a
	// prefix that concatenates the given prefix with the relative path of
	// the ordered map from the given node.
	PathElemPrefix []*gnmipb.PathElem
}

GNMINotificationsConfig specifies arguments determining how the gNMI output should be created by ygot.

type GoEnum

type GoEnum interface {
	// IsYANGGoEnum is a marker method that indicates that the
	// struct implements the GoEnum interface.
	IsYANGGoEnum()
	// ΛMap is a method associated with each enumeration that retrieves a
	// map of the enumeration types to values that are associated with a
	// generated code file. The ygen library generates a static map of
	// enumeration values that this method returns.
	ΛMap() map[string]map[int64]EnumDefinition
	// String provides the string representation of the enum, which will be
	// the YANG name if it's in its defined range.
	String() string
}

GoEnum is an interface which can be implemented by derived types which represent an enumerated value within a YANG schema. This allows handling code that finds struct fields that implement this interface to do specific mapping to other types when translating to a particular schematree.

type GoKeyStruct added in v0.25.4

type GoKeyStruct interface {
	// IsYANGGoKeyStruct ensures that the interface for a standard
	// GoKeyStruct is embedded.
	IsYANGGoKeyStruct()
	// ΛListKeyMap defines a helper method that returns a map of the
	// keys of a list element.
	ΛListKeyMap() (map[string]interface{}, error)
}

GoKeyStruct is an interface which can be implemented by Go key structs that are generated to represent a YANG multi-keyed list's key that has the corresponding function to retrieve the list keys as a map.

type GoOrderedMap added in v0.29.0

type GoOrderedMap interface {
	// IsYANGOrderedList is a marker method that indicates that the struct
	// implements the GoOrderedMap interface.
	IsYANGOrderedList()
	// Len returns the size of the ordered list.
	Len() int
}

GoOrderedMap is an interface which can be implemented by Go structs that are generated to represent a YANG "ordered-by user" list. It simply allows handling code to ensure that it is interacting with a struct that will meet the expectations of the interface - such as the existence of a Values() method that allows the retrieval of the list elements within the ordered list.

type GoStruct

type GoStruct interface {
	// IsYANGGoStruct is a marker method that indicates that the struct
	// implements the GoStruct interface.
	IsYANGGoStruct()
}

GoStruct is an interface which can be implemented by Go structs that are generated to represent a YANG container or list member. It simply allows handling code to ensure that it is interacting with a struct that will meet the expectations of the interface - such as the fields being tagged with appropriate metadata (tags) that allow mapping of the struct into a YANG schematree.

func DeepCopy

func DeepCopy(s GoStruct) (GoStruct, error)

DeepCopy returns a deep copy of the supplied GoStruct. A new copy of the GoStruct is created, along with any underlying values.

func MergeStructs

func MergeStructs(a, b GoStruct, opts ...MergeOpt) (GoStruct, error)

MergeStructs takes two input GoStruct and merges their contents, returning a new GoStruct. If the input structs a and b are of different types, an error is returned.

Where two structs contain maps or slices that are populated in both a and b, merge is skipped if their contents are equal, and their contents are merged if unequal; however, an error is returned for slices if their elements are overlapping but not equal. If a leaf is populated in both a and b, an error is returned if the value of the leaf is not equal.

type IgnoreAdditions added in v0.11.3

type IgnoreAdditions struct{}

IgnoreAdditions is a DiffOpt that indicates newly-added fields should be ignored. The returned Notification will only contain the updates and deletions from original to modified.

func (*IgnoreAdditions) IsDiffOpt added in v0.11.3

func (*IgnoreAdditions) IsDiffOpt()

type JSONFormat

type JSONFormat int

JSONFormat is an enumerated integer value indicating the JSON format.

const (
	// Internal is the custom JSON format that is output by the validation library, and
	// by pyangbind. It is loosely specified - but is the default used by generator developers.
	Internal JSONFormat = iota
	// RFC7951 is JSON that conforms to RFC7951.
	RFC7951
)

type JSONIndent added in v0.8.0

type JSONIndent string

JSONIndent is a string that specifies the indentation that should be used for JSON input.

func (JSONIndent) IsMarshal7951Arg added in v0.8.0

func (JSONIndent) IsMarshal7951Arg()

IsMarshal7951Arg marks JSONIndent as a valid Marshal7951 argument.

type KeyHelperGoStruct

type KeyHelperGoStruct interface {
	// GoStruct ensures that the interface for a standard GoStruct
	// is embedded.
	GoStruct
	// ΛListKeyMap defines a helper method that returns a map of the
	// keys of a list element.
	ΛListKeyMap() (map[string]interface{}, error)
}

KeyHelperGoStruct is an interface which can be implemented by Go structs that are generated to represent a YANG container or list member that has the corresponding function to retrieve the list keys as a map.

type Marshal7951Arg added in v0.8.0

type Marshal7951Arg interface {
	// IsMarshal7951Arg is a market method.
	IsMarshal7951Arg()
}

Marshal7951Arg is an interface implemented by arguments to the Marshal7951 function.

type MergeEmptyMaps added in v0.21.0

type MergeEmptyMaps struct{}

MergeEmptyMaps is a MergeOpt that allows control of the merge behaviour of MergeStructs and MergeStructInto functions.

When used, if both the destination struct and the source struct has an empty map field, but it is non-nil in either one, then that map field in the destination will always be populated with an empty, non-nil map value.

NOTE: Since YANG doesn't distinguish between a nil map and an empty map, please consider another approach before using this option.

func (*MergeEmptyMaps) IsMergeOpt added in v0.21.0

func (*MergeEmptyMaps) IsMergeOpt()

IsMergeOpt marks MergeEmptyMaps as a MergeOpt.

type MergeOpt added in v0.8.4

type MergeOpt interface {
	// IsMergeOpt is a marker method for each MergeOpt.
	IsMergeOpt()
}

MergeOpt is an interface that is implemented by the options to the MergeStructs and MergeStructInto functions.

type MergeOverwriteExistingFields added in v0.8.4

type MergeOverwriteExistingFields struct{}

MergeOverwriteExistingFields is a MergeOpt that allows control of the merge behaviour of MergeStructs and MergeStructInto functions.

When used, fields that are populated in the destination struct will be overwritten by values that are populated in the source struct. If the field is unpopulated in the source struct, the value in the destination struct will not be modified.

func (*MergeOverwriteExistingFields) IsMergeOpt added in v0.8.4

func (*MergeOverwriteExistingFields) IsMergeOpt()

IsMergeOpt marks MergeStructOpt as a MergeOpt.

type NodePath added in v0.7.0

type NodePath struct {
	// contains filtered or unexported fields
}

NodePath is a common embedded type within all path structs. It keeps track of the necessary information to create the relative schema path as a []*gpb.PathElem during later processing using the Resolve() method, thereby delaying any errors being reported until that time.

func NewNodePath added in v0.7.0

func NewNodePath(relSchemaPath []string, keys map[string]interface{}, p PathStruct) *NodePath

NewNodePath is the constructor for NodePath.

type PathStruct added in v0.7.0

type PathStruct interface {
	// contains filtered or unexported methods
}

PathStruct is an interface that is implemented by any generated path struct type; it allows for generic handling of a path struct at any node.

type PathType

type PathType int64

PathType is used to indicate a gNMI path type.

const (
	// StructuredPath represents a Path using the structured 'PathElem' message in
	// the 'elem' field of the gNMI Path message.
	StructuredPath PathType = iota
	// StringSlicePath represents a Path using the 'Element' repeated string field
	// of the gNMI path message.
	StringSlicePath
)

type RFC7951JSONConfig

type RFC7951JSONConfig struct {
	// AppendModuleName determines whether the module name is prepended to
	// elements that are defined within a different YANG module than their
	// parent.
	AppendModuleName bool
	// PrependModuleNameIdentityref determines whether the module name is
	// prepended to identityref values. AppendModuleName (should be named
	// PrependModuleName) subsumes and overrides this flag.
	// Note: using this flag instead of AppendModuleName is not
	// RFC7951-compliant and should be avoided for any standard
	// implementation.
	PrependModuleNameIdentityref bool
	// PreferShadowPath uses the name of the "shadow-path" tag of a
	// GoStruct to determine the marshalled path elements instead of the
	// "path" tag, whenever the former is present.
	PreferShadowPath bool
	// RewriteModuleNames specifies that, when marshalling to JSON, any
	// entry that is found within module A should be assumed to be in
	// module B. This allows a user to augment modules with nodes that
	// are then rewritten to be part of the augmented (note augmentED)
	// module's namespace. The primary reason that a user may this
	// functionality is to ensure that when a node is removed from an
	// model, but it is to be re-added for backwards compatibility by
	// augmentation, then the original output is not modified.
	//
	// The RewriteModuleNames map is keyed on the name of the module that
	// is to be rewritten FROM, and the value of the map is the name of the module
	// it is to be rewritten TO.
	RewriteModuleNames map[string]string
}

RFC7951JSONConfig is used to control the behaviour of how RFC7951 JSON is output by the ygot library.

func (*RFC7951JSONConfig) IsEncodeTypedValueOpt added in v0.25.3

func (*RFC7951JSONConfig) IsEncodeTypedValueOpt()

IsEncodeTypedValueOpt marks the RFC7951JSONConfig struct as a valid option to EncodeTypedValue.

func (*RFC7951JSONConfig) IsMarshal7951Arg added in v0.8.0

func (*RFC7951JSONConfig) IsMarshal7951Arg()

IsMarshal7951Arg marks the RFC7951JSONConfig struct as a valid argument to Marshal7951.

type ValidatedGoStruct

type ValidatedGoStruct interface {
	// GoStruct ensures that the interface for a standard GoStruct
	// is embedded.
	GoStruct
	// Validate compares the contents of the implementing struct against
	// the YANG schema, and returns an error if the struct's contents
	// are not valid, or nil if the struct complies with the schema.
	Validate(...ValidationOption) error
	// ΛEnumTypeMap returns the set of enumerated types that are contained
	// in the generated code.
	ΛEnumTypeMap() map[string][]reflect.Type
	// ΛBelongingModule returns the module in which the GoStruct was
	// defined per https://datatracker.ietf.org/doc/html/rfc7951#section-4.
	// If the GoStruct is the fakeroot, then the empty string will be
	// returned.
	//
	// Strictly, this value is the name of the module having the same XML
	// namespace as this node.
	// For more information on YANG's XML namespaces see
	// https://datatracker.ietf.org/doc/html/rfc7950#section-5.3
	ΛBelongingModule() string
}

ValidatedGoStruct is an interface implemented by all Go structs (YANG container or lists), *except* when the default validate_fn_name generation flag is overridden.

type ValidationOption

type ValidationOption interface {
	IsValidationOption()
}

ValidationOption is an interface that is implemented for each struct which presents configuration parameters for validation options through the Validate public API.

Directories

Path Synopsis
Package pathtranslate exports api to transform given string slice into different forms in a schema aware manner.
Package pathtranslate exports api to transform given string slice into different forms in a schema aware manner.
Package schematest is used for testing with the default OpenConfig generated structs.
Package schematest is used for testing with the default OpenConfig generated structs.

Jump to

Keyboard shortcuts

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