Documentation ¶
Overview ¶
Package idxvpp implements name-to-index mapping used by VPP plugins to keep a map between VPP interface handles and northbound string-based identifiers.
Index ¶
Constants ¶
This section is empty.
Variables ¶
This section is empty.
Functions ¶
This section is empty.
Types ¶
type NameToIdx ¶
type NameToIdx interface { // GetRegistryTitle returns the title assigned to the registry. GetRegistryTitle() string // LookupIdx retrieves a previously stored index for a particular // name. Metadata can be nil. If the 'exists' flag is set to false // upon return, the init value is undefined and it should be ignored. LookupIdx(name string) (idx uint32, metadata interface{}, exists bool) // LookupName retrieves a previously stored name by particular index. // Metadata can be nil. Name contains nonempty value only if exists==true. // // Principle: // A. Registry stores mappings between names and indexes. API can optionally // attach metadata to a particular name. TBD index can be 0... // B. Metadata is needed for example in the ifplugin. This metadata is used in the following scenarios: // - for caching of data (even data that belong to a different agent), // - for remembering the last processed object, // - for indexing the BD to which a particular interface belongs to (see bd_configurator or fib_configurator). LookupName(idx uint32) (name string, metadata interface{}, exists bool) // LookupNameByMetadata returns all indexes that contain particular meta field with the provided value. LookupNameByMetadata(key string, value string) []string // ListNames returns all names in the mapping. ListNames() (names []string) // Watch subscribes to watching changes to NameToIndex mappings. // NOTE: Watching NameToIndex mapping can have negative impact on performance in case // the events are handled slowly. // // Example: // // func (plugin *Plugin) watchEvents(ctx context.Context) { // Watch(PluginID, plugin.isubscriberChan) // ... // select { // case ifIdxEv := <-plugin.isubscriberChan: // // if ifIdxEv.IsDelete() { // plugin.ResolveDeletedInterface(ifIdxEv.Name) // } else { // plugin.ResolveDeletedInterface(ifIdxEv.Name) // } // ifIdxEv.Done() // ... // } Watch(subscriber core.PluginName, callback func(NameToIdxDto)) }
NameToIdx is the "user API" to the NameToIdx registry. It provides read-only access to name-to-index mappings stored in the registry. It is intended for plugins that need to lookup the mappings.
For example, a static L2 FIB table entry refers to an underlying network interface, which is specified as a logical interface name at the L2 plugin's NB API. During configuration, the LookupIdx() function must be called to determine which VPP if index corresponds to the specified logical name.
type NameToIdxDto ¶
type NameToIdxDto struct { NameToIdxDtoWithoutMeta // Auxiliary data related to mapping Metadata interface{} }
NameToIdxDto defines the Data Transfer Object (DTO) that carries a mapping between a logical object name defined at Agent's Northbound API and an sw_if_index defined at the VPP binary API.
type NameToIdxDtoWithoutMeta ¶
type NameToIdxDtoWithoutMeta struct { idxmap.NamedMappingEvent Idx uint32 }
NameToIdxDtoWithoutMeta is the part of NameToIdxDto that can be reused by indices with typed metadata.
func (*NameToIdxDtoWithoutMeta) Done ¶
func (dto *NameToIdxDtoWithoutMeta) Done() error
Done is used to signal to the event producer that the event consumer has processed the event.
func (*NameToIdxDtoWithoutMeta) IsDelete ¶
func (dto *NameToIdxDtoWithoutMeta) IsDelete() bool
IsDelete returns true if the mapping was deleted.
func (*NameToIdxDtoWithoutMeta) IsUpdate ¶ added in v1.4.0
func (dto *NameToIdxDtoWithoutMeta) IsUpdate() bool
IsUpdate returns true if mapping metadata was updated
type NameToIdxRW ¶
type NameToIdxRW interface { NameToIdx // RegisterName registers a new name-to-index mapping. After // registration, other plugins can use the "user's API" to lookup the // index (by providing the name) or the name (by providing the index), // and/or can be notified when the mapping is changed. Plugins will // typically use the change notifications to modify the part of VPP // configuration relevant to them and use the VPP binary API to push it // to VPP. RegisterName(name string, idx uint32, metadata interface{}) // UnregisterName removes a mapping from the registry. Other plugins // can be notified and remove the relevant parts of their own respective // VPP configurations and use the VPP binary API to clean it up from // VPP. UnregisterName(name string) (idx uint32, metadata interface{}, exists bool) // UpdateMetadata replaces metadata value in existing name-to-index // mapping entry. If mapping associated with the name does not // exist, it is not created. UpdateMetadata(name string, metadata interface{}) (success bool) // Clear removes all entries present in the name-to-index mapping. // This action does not trigger any notification. Clear() }
NameToIdxRW is the "owner API" to the NameToIdx registry. Using this API the owner adds (registers) new mappings to the registry or deletes (unregisters) existing mappings from the registry.
Directories ¶
Path | Synopsis |
---|---|
Package cacheutil is a base implementation of name-to-index cache on the top of which all typesafe caches are built.
|
Package cacheutil is a base implementation of name-to-index cache on the top of which all typesafe caches are built. |
Package nametoidx is an in-memory implementation of the name-to-index mapping registry.
|
Package nametoidx is an in-memory implementation of the name-to-index mapping registry. |
Package persist asynchronously writes changes in the map (name->idx) to file.
|
Package persist asynchronously writes changes in the map (name->idx) to file. |