Documentation ¶
Overview ¶
Package find implements inventory listing and searching.
The Finder is an alternative to the object.SearchIndex FindByInventoryPath() and FindChild() methods. SearchIndex.FindByInventoryPath requires an absolute path, whereas the Finder also supports relative paths and patterns via path.Match. SearchIndex.FindChild requires a parent to find the child, whereas the Finder also supports an ancestor via recursive object traversal.
The various Finder methods accept a "path" argument, which can absolute or relative to the Folder for the object type. The Finder supports two modes, "list" and "find". The "list" mode behaves like the "ls" command, only searching within the immediate path. The "find" mode behaves like the "find" command, with the search starting at the immediate path but also recursing into sub Folders relative to the Datacenter. The default mode is "list" if the given path contains a "/", otherwise "find" mode is used.
The exception is to use a "..." wildcard with a path to find all objects recursively underneath any root object. For example: VirtualMachineList("/DC1/...")
See also: https://github.com/Alvis-pixel/govmomi/blob/main/govc/README.md#usage
Index ¶
- func InventoryPath(ctx context.Context, client *vim25.Client, obj types.ManagedObjectReference) (string, error)
- type DefaultMultipleFoundError
- type DefaultNotFoundError
- type Finder
- func (f *Finder) ClusterComputeResource(ctx context.Context, path string) (*object.ClusterComputeResource, error)
- func (f *Finder) ClusterComputeResourceList(ctx context.Context, path string) ([]*object.ClusterComputeResource, error)
- func (f *Finder) ClusterComputeResourceOrDefault(ctx context.Context, path string) (*object.ClusterComputeResource, error)
- func (f *Finder) ComputeResource(ctx context.Context, path string) (*object.ComputeResource, error)
- func (f *Finder) ComputeResourceList(ctx context.Context, path string) ([]*object.ComputeResource, error)
- func (f *Finder) ComputeResourceOrDefault(ctx context.Context, path string) (*object.ComputeResource, error)
- func (f *Finder) Datacenter(ctx context.Context, path string) (*object.Datacenter, error)
- func (f *Finder) DatacenterList(ctx context.Context, path string) ([]*object.Datacenter, error)
- func (f *Finder) DatacenterOrDefault(ctx context.Context, path string) (*object.Datacenter, error)
- func (f *Finder) Datastore(ctx context.Context, path string) (*object.Datastore, error)
- func (f *Finder) DatastoreCluster(ctx context.Context, path string) (*object.StoragePod, error)
- func (f *Finder) DatastoreClusterList(ctx context.Context, path string) ([]*object.StoragePod, error)
- func (f *Finder) DatastoreClusterOrDefault(ctx context.Context, path string) (*object.StoragePod, error)
- func (f *Finder) DatastoreList(ctx context.Context, path string) ([]*object.Datastore, error)
- func (f *Finder) DatastoreOrDefault(ctx context.Context, path string) (*object.Datastore, error)
- func (f *Finder) DefaultClusterComputeResource(ctx context.Context) (*object.ClusterComputeResource, error)
- func (f *Finder) DefaultComputeResource(ctx context.Context) (*object.ComputeResource, error)
- func (f *Finder) DefaultDatacenter(ctx context.Context) (*object.Datacenter, error)
- func (f *Finder) DefaultDatastore(ctx context.Context) (*object.Datastore, error)
- func (f *Finder) DefaultDatastoreCluster(ctx context.Context) (*object.StoragePod, error)
- func (f *Finder) DefaultFolder(ctx context.Context) (*object.Folder, error)
- func (f *Finder) DefaultHostSystem(ctx context.Context) (*object.HostSystem, error)
- func (f *Finder) DefaultNetwork(ctx context.Context) (object.NetworkReference, error)
- func (f *Finder) DefaultResourcePool(ctx context.Context) (*object.ResourcePool, error)
- func (f *Finder) Element(ctx context.Context, ref types.ManagedObjectReference) (*list.Element, error)
- func (f *Finder) Folder(ctx context.Context, path string) (*object.Folder, error)
- func (f *Finder) FolderList(ctx context.Context, path string) ([]*object.Folder, error)
- func (f *Finder) FolderOrDefault(ctx context.Context, path string) (*object.Folder, error)
- func (f *Finder) HostSystem(ctx context.Context, path string) (*object.HostSystem, error)
- func (f *Finder) HostSystemList(ctx context.Context, path string) ([]*object.HostSystem, error)
- func (f *Finder) HostSystemOrDefault(ctx context.Context, path string) (*object.HostSystem, error)
- func (f *Finder) ManagedObjectList(ctx context.Context, path string, include ...string) ([]list.Element, error)
- func (f *Finder) ManagedObjectListChildren(ctx context.Context, path string, include ...string) ([]list.Element, error)
- func (f *Finder) Network(ctx context.Context, path string) (object.NetworkReference, error)
- func (f *Finder) NetworkList(ctx context.Context, path string) ([]object.NetworkReference, error)
- func (f *Finder) NetworkOrDefault(ctx context.Context, path string) (object.NetworkReference, error)
- func (f *Finder) ObjectReference(ctx context.Context, ref types.ManagedObjectReference) (object.Reference, error)
- func (f *Finder) ResourcePool(ctx context.Context, path string) (*object.ResourcePool, error)
- func (f *Finder) ResourcePoolList(ctx context.Context, path string) ([]*object.ResourcePool, error)
- func (f *Finder) ResourcePoolListAll(ctx context.Context, path string) ([]*object.ResourcePool, error)
- func (f *Finder) ResourcePoolOrDefault(ctx context.Context, path string) (*object.ResourcePool, error)
- func (f *Finder) SetDatacenter(dc *object.Datacenter) *Finder
- func (f *Finder) VirtualApp(ctx context.Context, path string) (*object.VirtualApp, error)
- func (f *Finder) VirtualAppList(ctx context.Context, path string) ([]*object.VirtualApp, error)
- func (f *Finder) VirtualMachine(ctx context.Context, path string) (*object.VirtualMachine, error)
- func (f *Finder) VirtualMachineList(ctx context.Context, path string) ([]*object.VirtualMachine, error)
- type MultipleFoundError
- type NotFoundError
Examples ¶
Constants ¶
This section is empty.
Variables ¶
This section is empty.
Functions ¶
func InventoryPath ¶
func InventoryPath(ctx context.Context, client *vim25.Client, obj types.ManagedObjectReference) (string, error)
InventoryPath composes the given object's inventory path. There is no vSphere property or method that provides an inventory path directly. This method uses the ManagedEntity.Parent field to determine the ancestry tree of the object and the ManagedEntity.Name field for each ancestor to compose the path.
Types ¶
type DefaultMultipleFoundError ¶
type DefaultMultipleFoundError struct {
// contains filtered or unexported fields
}
func (DefaultMultipleFoundError) Error ¶
func (e DefaultMultipleFoundError) Error() string
type DefaultNotFoundError ¶
type DefaultNotFoundError struct {
// contains filtered or unexported fields
}
func (*DefaultNotFoundError) Error ¶
func (e *DefaultNotFoundError) Error() string
type Finder ¶
type Finder struct {
// contains filtered or unexported fields
}
func (*Finder) ClusterComputeResource ¶
func (*Finder) ClusterComputeResourceList ¶
func (*Finder) ClusterComputeResourceOrDefault ¶
func (*Finder) ComputeResource ¶
func (*Finder) ComputeResourceList ¶
func (*Finder) ComputeResourceOrDefault ¶
func (*Finder) Datacenter ¶
func (*Finder) DatacenterList ¶
func (*Finder) DatacenterOrDefault ¶
func (*Finder) DatastoreCluster ¶
func (*Finder) DatastoreClusterList ¶
func (*Finder) DatastoreClusterOrDefault ¶
func (*Finder) DatastoreList ¶
func (*Finder) DatastoreOrDefault ¶
func (*Finder) DefaultClusterComputeResource ¶
func (*Finder) DefaultComputeResource ¶
func (*Finder) DefaultDatacenter ¶
func (*Finder) DefaultDatastore ¶
func (*Finder) DefaultDatastoreCluster ¶
func (*Finder) DefaultFolder ¶
func (*Finder) DefaultHostSystem ¶
func (*Finder) DefaultNetwork ¶
func (*Finder) DefaultResourcePool ¶
func (*Finder) Element ¶
func (f *Finder) Element(ctx context.Context, ref types.ManagedObjectReference) (*list.Element, error)
Element is deprecated, use InventoryPath() instead.
func (*Finder) FolderList ¶
func (*Finder) FolderOrDefault ¶
func (*Finder) HostSystem ¶
func (*Finder) HostSystemList ¶
func (*Finder) HostSystemOrDefault ¶
func (*Finder) ManagedObjectList ¶
func (*Finder) ManagedObjectListChildren ¶
func (*Finder) Network ¶
Network finds a NetworkReference using a Name, Inventory Path, ManagedObject ID, Logical Switch UUID or Segment ID. With standard vSphere networking, Portgroups cannot have the same name within the same network folder. With NSX, Portgroups can have the same name, even within the same Switch. In this case, using an inventory path results in a MultipleFoundError. A MOID, switch UUID or segment ID can be used instead, as both are unique. See also: https://kb.vmware.com/s/article/79872#Duplicate_names Examples: - Name: "dvpg-1" - Inventory Path: "vds-1/dvpg-1" - Cluster Path: "/dc-1/host/cluster-1/dvpg-1" - ManagedObject ID: "DistributedVirtualPortgroup:dvportgroup-53" - Logical Switch UUID: "da2a59b8-2450-4cb2-b5cc-79c4c1d2144c" - Segment ID: "/infra/segments/vnet_ce50e69b-1784-4a14-9206-ffd7f1f146f7"
func (*Finder) NetworkList ¶
func (*Finder) NetworkOrDefault ¶
func (*Finder) ObjectReference ¶
func (f *Finder) ObjectReference(ctx context.Context, ref types.ManagedObjectReference) (object.Reference, error)
ObjectReference converts the given ManagedObjectReference to a type from the object package via object.NewReference with the object.Common.InventoryPath field set.
func (*Finder) ResourcePool ¶
func (*Finder) ResourcePoolList ¶
func (*Finder) ResourcePoolListAll ¶
func (f *Finder) ResourcePoolListAll(ctx context.Context, path string) ([]*object.ResourcePool, error)
ResourcePoolListAll combines ResourcePoolList and VirtualAppList VirtualAppList is only called if ResourcePoolList does not find any pools with the given path.
func (*Finder) ResourcePoolOrDefault ¶
func (*Finder) SetDatacenter ¶
func (f *Finder) SetDatacenter(dc *object.Datacenter) *Finder
func (*Finder) VirtualApp ¶
func (*Finder) VirtualAppList ¶
func (*Finder) VirtualMachine ¶
func (*Finder) VirtualMachineList ¶
type MultipleFoundError ¶
type MultipleFoundError struct {
// contains filtered or unexported fields
}
Example ¶
package main import ( "context" "errors" "fmt" "github.com/Alvis-pixel/govmomi/find" "github.com/Alvis-pixel/govmomi/simulator" "github.com/Alvis-pixel/govmomi/vim25" ) func main() { model := simulator.VPX() model.Portgroup = 2 simulator.Run(func(ctx context.Context, c *vim25.Client) error { finder := find.NewFinder(c) _, err := finder.Network(ctx, "DC0_DVPG*") _, ok := err.(*find.MultipleFoundError) // returns DC0_DVPG{0,1} if !ok { return errors.New("expected error") } net0, err := finder.Network(ctx, "DC0_DVPG0") if err != nil { return err } fmt.Println(net0.GetInventoryPath()) net1, err := finder.Network(ctx, "DC0_DVPG1") if err != nil { return err } fmt.Println(net1.GetInventoryPath()) return nil }, model) }
Output: /DC0/network/DC0_DVPG0 /DC0/network/DC0_DVPG1
func (*MultipleFoundError) Error ¶
func (e *MultipleFoundError) Error() string
type NotFoundError ¶
type NotFoundError struct {
// contains filtered or unexported fields
}
func (*NotFoundError) Error ¶
func (e *NotFoundError) Error() string