func (f *Finder) ComputeResourceList(ctx context.Context, path string) ([]*object.ComputeResource, error) { es, err := f.find(ctx, f.hostFolder, false, path) if err != nil { return nil, err } var crs []*object.ComputeResource for _, e := range es { var cr *object.ComputeResource switch o := e.Object.(type) { case mo.ComputeResource, mo.ClusterComputeResource: cr = object.NewComputeResource(f.client, o.Reference()) default: continue } cr.InventoryPath = e.Path crs = append(crs, cr) } if len(crs) == 0 { return nil, &NotFoundError{"compute resource", path} } return crs, nil }
func (h *Helper) LocalDatastores(ctx context.Context, cr *object.ComputeResource) ([]*object.Datastore, error) { // List datastores for compute resource dss, err := cr.Datastores(ctx) if err != nil { return nil, err } // Filter local datastores var ldss []*object.Datastore for _, ds := range dss { var mds mo.Datastore err = property.DefaultCollector(h.c).RetrieveOne(ctx, ds.Reference(), nil, &mds) if err != nil { return nil, err } switch i := mds.Info.(type) { case *types.VmfsDatastoreInfo: if i.Vmfs.Local != nil && *i.Vmfs.Local == true { break } default: continue } ds.InventoryPath = mds.Name ldss = append(ldss, ds) } return ldss, nil }