Documentation ¶
Index ¶
- Variables
- func AWSErrorCode(err error) string
- func IsClusterReadable(p Path) bool
- func IsDirectory(p Path) bool
- func NewSwiftClient(ctx context.Context) (*gophercloud.ServiceClient, error)
- func RelativePath(base Path, child Path) (string, error)
- func RetryWithBackoff(backoff wait.Backoff, condition func() (bool, error)) (bool, error)
- func VFSPath(url string) (string, error)
- type ACL
- type ACLOracle
- type AzureBlobPath
- func (p *AzureBlobPath) Base() string
- func (p *AzureBlobPath) CreateFile(ctx context.Context, data io.ReadSeeker, acl ACL) error
- func (p *AzureBlobPath) Hash(a hashing.HashAlgorithm) (*hashing.Hash, error)
- func (p *AzureBlobPath) Join(relativePath ...string) Path
- func (p *AzureBlobPath) Path() string
- func (p *AzureBlobPath) PreferredHash() (*hashing.Hash, error)
- func (p *AzureBlobPath) ReadDir() ([]Path, error)
- func (p *AzureBlobPath) ReadFile(ctx context.Context) ([]byte, error)
- func (p *AzureBlobPath) ReadTree(ctx context.Context) ([]Path, error)
- func (p *AzureBlobPath) Remove(ctx context.Context) error
- func (p *AzureBlobPath) RemoveAll(ctx context.Context) error
- func (p *AzureBlobPath) RemoveAllVersions(ctx context.Context) error
- func (p *AzureBlobPath) WriteFile(ctx context.Context, data io.ReadSeeker, acl ACL) error
- func (p *AzureBlobPath) WriteTo(w io.Writer) (n int64, err error)
- type Cache
- type FSPath
- func (p *FSPath) Base() string
- func (p *FSPath) CreateFile(ctx context.Context, data io.ReadSeeker, acl ACL) error
- func (p *FSPath) Hash(a hashing.HashAlgorithm) (*hashing.Hash, error)
- func (p *FSPath) Join(relativePath ...string) Path
- func (p *FSPath) Path() string
- func (p *FSPath) PreferredHash() (*hashing.Hash, error)
- func (p *FSPath) ReadDir() ([]Path, error)
- func (p *FSPath) ReadFile(ctx context.Context) ([]byte, error)
- func (p *FSPath) ReadTree(ctx context.Context) ([]Path, error)
- func (p *FSPath) Remove(ctx context.Context) error
- func (p *FSPath) RemoveAll(ctx context.Context) error
- func (p *FSPath) RemoveAllVersions(ctx context.Context) error
- func (p *FSPath) String() string
- func (p *FSPath) WriteFile(ctx context.Context, data io.ReadSeeker, acl ACL) error
- func (p *FSPath) WriteTo(out io.Writer) (int64, error)
- type GSAcl
- type GSPath
- func (p *GSPath) Base() string
- func (p *GSPath) Bucket() string
- func (p *GSPath) Client(ctx context.Context) (*storage.Service, error)
- func (p *GSPath) CreateFile(ctx context.Context, data io.ReadSeeker, acl ACL) error
- func (p *GSPath) Hash(a hashing.HashAlgorithm) (*hashing.Hash, error)
- func (p *GSPath) Join(relativePath ...string) Path
- func (p *GSPath) Object() string
- func (p *GSPath) Path() string
- func (p *GSPath) PreferredHash() (*hashing.Hash, error)
- func (p *GSPath) ReadDir() ([]Path, error)
- func (p *GSPath) ReadFile(ctx context.Context) ([]byte, error)
- func (p *GSPath) ReadTree(ctx context.Context) ([]Path, error)
- func (p *GSPath) Remove(ctx context.Context) error
- func (p *GSPath) RemoveAll(ctx context.Context) error
- func (p *GSPath) RemoveAllVersions(ctx context.Context) error
- func (p *GSPath) RenderTerraform(w *terraformWriter.TerraformWriter, name string, data io.Reader, acl ACL) error
- func (p *GSPath) String() string
- func (s *GSPath) TerraformLink(name string) *terraformWriter.Literal
- func (p *GSPath) WriteFile(ctx context.Context, data io.ReadSeeker, acl ACL) error
- func (p *GSPath) WriteTo(out io.Writer) (int64, error)
- type HasClusterReadable
- type HasHash
- type KubernetesContext
- type KubernetesPath
- func (p *KubernetesPath) Base() string
- func (p *KubernetesPath) CreateFile(ctx context.Context, data io.ReadSeeker, acl ACL) error
- func (p *KubernetesPath) Hash(a hashing.HashAlgorithm) (*hashing.Hash, error)
- func (p *KubernetesPath) Host() string
- func (p *KubernetesPath) Join(relativePath ...string) Path
- func (p *KubernetesPath) Key() string
- func (p *KubernetesPath) Path() string
- func (p *KubernetesPath) PreferredHash() (*hashing.Hash, error)
- func (p *KubernetesPath) ReadDir() ([]Path, error)
- func (p *KubernetesPath) ReadFile(ctx context.Context) ([]byte, error)
- func (p *KubernetesPath) ReadTree(ctx context.Context) ([]Path, error)
- func (p *KubernetesPath) Remove(ctx context.Context) error
- func (p *KubernetesPath) RemoveAll(ctx context.Context) error
- func (p *KubernetesPath) RemoveAllVersions(ctx context.Context) error
- func (p *KubernetesPath) String() string
- func (p *KubernetesPath) WriteFile(ctx context.Context, data io.ReadSeeker, acl ACL) error
- func (p *KubernetesPath) WriteTo(out io.Writer) (int64, error)
- type MemFSContext
- type MemFSPath
- func (p *MemFSPath) Base() string
- func (p *MemFSPath) CreateFile(ctx context.Context, data io.ReadSeeker, acl ACL) error
- func (c *MemFSPath) HasChildren() bool
- func (c *MemFSPath) IsClusterReadable() bool
- func (p *MemFSPath) IsPublic() (bool, error)
- func (p *MemFSPath) Join(relativePath ...string) Path
- func (p *MemFSPath) Location() string
- func (p *MemFSPath) Path() string
- func (p *MemFSPath) ReadDir() ([]Path, error)
- func (p *MemFSPath) ReadFile(ctx context.Context) ([]byte, error)
- func (p *MemFSPath) ReadTree(ctx context.Context) ([]Path, error)
- func (p *MemFSPath) Remove(ctx context.Context) error
- func (p *MemFSPath) RemoveAll(ctx context.Context) error
- func (p *MemFSPath) RemoveAllVersions(ctx context.Context) error
- func (p *MemFSPath) RenderTerraform(w *terraformWriter.TerraformWriter, name string, data io.Reader, acl ACL) error
- func (p *MemFSPath) String() string
- func (p *MemFSPath) WriteFile(ctx context.Context, r io.ReadSeeker, acl ACL) error
- func (p *MemFSPath) WriteTo(out io.Writer) (int64, error)
- type OpenstackConfig
- type Path
- type S3Acl
- type S3BucketDetails
- type S3Context
- type S3Path
- func (p *S3Path) Base() string
- func (p *S3Path) Bucket() string
- func (p *S3Path) CreateFile(ctx context.Context, data io.ReadSeeker, acl ACL) error
- func (p *S3Path) GetHTTPsUrl(dualstack bool) (string, error)
- func (p *S3Path) Hash(a hashing.HashAlgorithm) (*hashing.Hash, error)
- func (p *S3Path) IsBucketPublic(ctx context.Context) (bool, error)
- func (p *S3Path) IsPublic() (bool, error)
- func (p *S3Path) Join(relativePath ...string) Path
- func (p *S3Path) Key() string
- func (p *S3Path) Path() string
- func (p *S3Path) PreferredHash() (*hashing.Hash, error)
- func (p *S3Path) ReadDir() ([]Path, error)
- func (p *S3Path) ReadFile(ctx context.Context) ([]byte, error)
- func (p *S3Path) ReadTree(ctx context.Context) ([]Path, error)
- func (p *S3Path) Remove(ctx context.Context) error
- func (p *S3Path) RemoveAll(ctx context.Context) error
- func (p *S3Path) RemoveAllVersions(ctx context.Context) error
- func (p *S3Path) RenderTerraform(w *terraformWriter.TerraformWriter, name string, data io.Reader, acl ACL) error
- func (p *S3Path) String() string
- func (p *S3Path) WriteFile(ctx context.Context, data io.ReadSeeker, aclObj ACL) error
- func (p *S3Path) WriteTo(out io.Writer) (int64, error)
- type SSHAcl
- type SSHPath
- func (p *SSHPath) Base() string
- func (p *SSHPath) CreateFile(ctx context.Context, data io.ReadSeeker, acl ACL) error
- func (p *SSHPath) Join(relativePath ...string) Path
- func (p *SSHPath) Path() string
- func (p *SSHPath) ReadDir() ([]Path, error)
- func (p *SSHPath) ReadFile(ctx context.Context) ([]byte, error)
- func (p *SSHPath) ReadTree(ctx context.Context) ([]Path, error)
- func (p *SSHPath) Remove(ctx context.Context) error
- func (p *SSHPath) RemoveAll(ctx context.Context) error
- func (p *SSHPath) RemoveAllVersions(ctx context.Context) error
- func (p *SSHPath) String() string
- func (p *SSHPath) WriteFile(ctx context.Context, data io.ReadSeeker, acl ACL) error
- func (p *SSHPath) WriteTo(out io.Writer) (int64, error)
- type SwiftPath
- func (p *SwiftPath) Base() string
- func (p *SwiftPath) Bucket() string
- func (p *SwiftPath) CreateFile(ctx context.Context, data io.ReadSeeker, acl ACL) error
- func (p *SwiftPath) Hash(a hashing.HashAlgorithm) (*hashing.Hash, error)
- func (p *SwiftPath) Join(relativePath ...string) Path
- func (p *SwiftPath) Path() string
- func (p *SwiftPath) PreferredHash() (*hashing.Hash, error)
- func (p *SwiftPath) ReadDir() ([]Path, error)
- func (p *SwiftPath) ReadFile(ctx context.Context) ([]byte, error)
- func (p *SwiftPath) ReadTree(ctx context.Context) ([]Path, error)
- func (p *SwiftPath) Remove(ctx context.Context) error
- func (p *SwiftPath) RemoveAll(ctx context.Context) error
- func (p *SwiftPath) RemoveAllVersions(ctx context.Context) error
- func (p *SwiftPath) String() string
- func (p *SwiftPath) WriteFile(ctx context.Context, data io.ReadSeeker, acl ACL) error
- func (p *SwiftPath) WriteTo(out io.Writer) (int64, error)
- type TerraformPath
- type VFS
- type VFSContext
- type VFSOption
- type WriteOption
Constants ¶
This section is empty.
Variables ¶
var Context = NewVFSContext()
Context holds the global VFS state. Deprecated: prefer FromContext.
Functions ¶
func AWSErrorCode ¶
AWSErrorCode returns the aws error code, if it is an awserr.Error, otherwise ""
func IsClusterReadable ¶
func IsDirectory ¶
func NewSwiftClient ¶ added in v1.10.0
func NewSwiftClient(ctx context.Context) (*gophercloud.ServiceClient, error)
func RetryWithBackoff ¶ added in v1.10.0
RetryWithBackoff runs until a condition function returns true, or until Steps attempts have been taken As compared to wait.ExponentialBackoff, this function returns the results from the function on the final attempt
Types ¶
type AzureBlobPath ¶ added in v1.20.0
type AzureBlobPath struct {
// contains filtered or unexported fields
}
AzureBlobPath is a path in the VFS space backed by Azure Blob.
func NewAzureBlobPath ¶ added in v1.20.0
func NewAzureBlobPath(vfsContext *VFSContext, container string, key string) *AzureBlobPath
NewAzureBlobPath returns a new AzureBlobPath.
func (*AzureBlobPath) Base ¶ added in v1.20.0
func (p *AzureBlobPath) Base() string
Base returns the base name (last element).
func (*AzureBlobPath) CreateFile ¶ added in v1.20.0
func (p *AzureBlobPath) CreateFile(ctx context.Context, data io.ReadSeeker, acl ACL) error
CreateFile writes the file contents only if the file does not already exist.
func (*AzureBlobPath) Hash ¶ added in v1.20.0
func (p *AzureBlobPath) Hash(a hashing.HashAlgorithm) (*hashing.Hash, error)
Hash gets the hash, or nil if the hash cannot be (easily) computed.
func (*AzureBlobPath) Join ¶ added in v1.20.0
func (p *AzureBlobPath) Join(relativePath ...string) Path
Join returns a new path that joins the current path and given relative paths.
func (*AzureBlobPath) Path ¶ added in v1.20.0
func (p *AzureBlobPath) Path() string
Path returns a string representing the full path.
func (*AzureBlobPath) PreferredHash ¶ added in v1.20.0
func (p *AzureBlobPath) PreferredHash() (*hashing.Hash, error)
PreferredHash returns the hash of the file contents, with the preferred hash algorithm.
func (*AzureBlobPath) ReadDir ¶ added in v1.20.0
func (p *AzureBlobPath) ReadDir() ([]Path, error)
ReadDir lists the blobs under the current Path.
func (*AzureBlobPath) ReadFile ¶ added in v1.20.0
func (p *AzureBlobPath) ReadFile(ctx context.Context) ([]byte, error)
ReadFile returns the content of the blob.
func (*AzureBlobPath) ReadTree ¶ added in v1.20.0
func (p *AzureBlobPath) ReadTree(ctx context.Context) ([]Path, error)
ReadTree lists all blobs (recursively) in the subtree rooted at the current Path.
func (*AzureBlobPath) Remove ¶ added in v1.20.0
func (p *AzureBlobPath) Remove(ctx context.Context) error
Remove deletes the blob.
func (*AzureBlobPath) RemoveAll ¶ added in v1.28.0
func (p *AzureBlobPath) RemoveAll(ctx context.Context) error
func (*AzureBlobPath) RemoveAllVersions ¶ added in v1.20.0
func (p *AzureBlobPath) RemoveAllVersions(ctx context.Context) error
func (*AzureBlobPath) WriteFile ¶ added in v1.20.0
func (p *AzureBlobPath) WriteFile(ctx context.Context, data io.ReadSeeker, acl ACL) error
WriteFile writes the blob to the reader.
TODO(kenji): Support ACL.
type Cache ¶ added in v1.16.0
type Cache struct {
// contains filtered or unexported fields
}
Cache is a simple cache for vfs files.
Currently we never expire the cache, so this is only safe for a relatively bounded set of files - but it would not be too hard to fix this.
type FSPath ¶
type FSPath struct {
// contains filtered or unexported fields
}
func (*FSPath) CreateFile ¶
func (*FSPath) RemoveAllVersions ¶ added in v1.16.3
type GSAcl ¶ added in v1.10.0
type GSAcl struct {
Acl []*storage.ObjectAccessControl
}
GSAcl is an ACL implementation for objects on Google Cloud Storage
type GSPath ¶ added in v1.10.0
type GSPath struct {
// contains filtered or unexported fields
}
GSPath is a vfs path for Google Cloud Storage
func (*GSPath) CreateFile ¶ added in v1.10.0
func (*GSPath) PreferredHash ¶ added in v1.10.0
func (*GSPath) RemoveAllVersions ¶ added in v1.16.3
func (*GSPath) RenderTerraform ¶ added in v1.23.0
func (p *GSPath) RenderTerraform(w *terraformWriter.TerraformWriter, name string, data io.Reader, acl ACL) error
func (*GSPath) TerraformLink ¶ added in v1.23.0
func (s *GSPath) TerraformLink(name string) *terraformWriter.Literal
type HasClusterReadable ¶
type HasClusterReadable interface {
IsClusterReadable() bool
}
type KubernetesContext ¶ added in v1.10.0
type KubernetesContext struct{}
KubernetesContext is the context for a Kubernetes VFS implementation
func NewKubernetesContext ¶ added in v1.10.0
func NewKubernetesContext() *KubernetesContext
NewKubernetesContext builds a KubernetesContext This will likely take a kubernetes rest client object (or similar) once the implementation is more complete
type KubernetesPath ¶ added in v1.10.0
type KubernetesPath struct {
// contains filtered or unexported fields
}
KubernetesPath is a path for a VFS backed by the kubernetes API Currently all operations are no-ops
func (*KubernetesPath) Base ¶ added in v1.10.0
func (p *KubernetesPath) Base() string
func (*KubernetesPath) CreateFile ¶ added in v1.10.0
func (p *KubernetesPath) CreateFile(ctx context.Context, data io.ReadSeeker, acl ACL) error
func (*KubernetesPath) Hash ¶ added in v1.10.0
func (p *KubernetesPath) Hash(a hashing.HashAlgorithm) (*hashing.Hash, error)
func (*KubernetesPath) Host ¶ added in v1.10.0
func (p *KubernetesPath) Host() string
func (*KubernetesPath) Join ¶ added in v1.10.0
func (p *KubernetesPath) Join(relativePath ...string) Path
func (*KubernetesPath) Key ¶ added in v1.10.0
func (p *KubernetesPath) Key() string
func (*KubernetesPath) Path ¶ added in v1.10.0
func (p *KubernetesPath) Path() string
func (*KubernetesPath) PreferredHash ¶ added in v1.10.0
func (p *KubernetesPath) PreferredHash() (*hashing.Hash, error)
func (*KubernetesPath) ReadDir ¶ added in v1.10.0
func (p *KubernetesPath) ReadDir() ([]Path, error)
func (*KubernetesPath) ReadFile ¶ added in v1.10.0
func (p *KubernetesPath) ReadFile(ctx context.Context) ([]byte, error)
ReadFile implements Path::ReadFile
func (*KubernetesPath) ReadTree ¶ added in v1.10.0
func (p *KubernetesPath) ReadTree(ctx context.Context) ([]Path, error)
func (*KubernetesPath) Remove ¶ added in v1.10.0
func (p *KubernetesPath) Remove(ctx context.Context) error
func (*KubernetesPath) RemoveAll ¶ added in v1.28.0
func (p *KubernetesPath) RemoveAll(ctx context.Context) error
func (*KubernetesPath) RemoveAllVersions ¶ added in v1.16.3
func (p *KubernetesPath) RemoveAllVersions(ctx context.Context) error
func (*KubernetesPath) String ¶ added in v1.10.0
func (p *KubernetesPath) String() string
func (*KubernetesPath) WriteFile ¶ added in v1.10.0
func (p *KubernetesPath) WriteFile(ctx context.Context, data io.ReadSeeker, acl ACL) error
type MemFSContext ¶
type MemFSContext struct {
// contains filtered or unexported fields
}
func NewMemFSContext ¶
func NewMemFSContext() *MemFSContext
func (*MemFSContext) MarkClusterReadable ¶
func (c *MemFSContext) MarkClusterReadable()
MarkClusterReadable pretends the current memfscontext is cluster readable; this is useful for tests
type MemFSPath ¶
type MemFSPath struct {
// contains filtered or unexported fields
}
func NewMemFSPath ¶
func NewMemFSPath(context *MemFSContext, location string) *MemFSPath
func (*MemFSPath) CreateFile ¶
func (*MemFSPath) HasChildren ¶ added in v1.10.0
func (*MemFSPath) IsClusterReadable ¶
func (*MemFSPath) RemoveAllVersions ¶ added in v1.16.3
func (*MemFSPath) RenderTerraform ¶ added in v1.21.3
func (p *MemFSPath) RenderTerraform(w *terraformWriter.TerraformWriter, name string, data io.Reader, acl ACL) error
type OpenstackConfig ¶ added in v1.10.0
type OpenstackConfig struct{}
func (OpenstackConfig) GetCredential ¶ added in v1.10.0
func (oc OpenstackConfig) GetCredential() (gophercloud.AuthOptions, error)
func (OpenstackConfig) GetRegion ¶ added in v1.15.1
func (oc OpenstackConfig) GetRegion() (string, error)
func (OpenstackConfig) GetServiceConfig ¶ added in v1.10.0
func (oc OpenstackConfig) GetServiceConfig(name string) (gophercloud.EndpointOpts, error)
type Path ¶
type Path interface { io.WriterTo Join(relativePath ...string) Path // ReadFile returns the contents of the file, or an error if the file could not be read. // If the file did not exist, err = os.ErrNotExist // As this reads the entire file into memory, consider using WriteTo for bigger files ReadFile(ctx context.Context) ([]byte, error) WriteFile(ctx context.Context, data io.ReadSeeker, acl ACL) error // CreateFile writes the file contents, but only if the file does not already exist CreateFile(ctx context.Context, data io.ReadSeeker, acl ACL) error // Remove deletes the file Remove(ctx context.Context) error // RemoveAll deletes all files recursively, deletes only files as returned per ReadTree RemoveAll(ctx context.Context) error // RemoveAllVersions completely deletes the file (with all its versions and markers). RemoveAllVersions(ctx context.Context) error // Base returns the base name (last element) Base() string // Path returns a string representing the full path Path() string // ReadDir lists the files in a particular Path ReadDir() ([]Path, error) // ReadTree lists all files (recursively) in the subtree rooted at the current Path /// Note: returns only files, not directories ReadTree(ctx context.Context) ([]Path, error) }
Path is a path in the VFS space, which we can read, write, list etc
type S3Acl ¶ added in v1.10.0
type S3Acl struct {
RequestACL *string
}
S3Acl is an ACL implementation for objects on S3
type S3BucketDetails ¶ added in v1.10.0
type S3BucketDetails struct {
// contains filtered or unexported fields
}
type S3Context ¶ added in v1.4.1
type S3Context struct {
// contains filtered or unexported fields
}
func NewS3Context ¶ added in v1.4.1
func NewS3Context() *S3Context
type S3Path ¶
type S3Path struct {
// contains filtered or unexported fields
}
func (*S3Path) CreateFile ¶
func (*S3Path) GetHTTPsUrl ¶ added in v1.21.0
func (*S3Path) IsBucketPublic ¶ added in v1.26.0
func (*S3Path) RemoveAllVersions ¶ added in v1.16.3
func (*S3Path) RenderTerraform ¶ added in v1.21.3
func (p *S3Path) RenderTerraform(w *terraformWriter.TerraformWriter, name string, data io.Reader, acl ACL) error
type SSHPath ¶
type SSHPath struct {
// contains filtered or unexported fields
}
func NewSSHPath ¶
func (*SSHPath) CreateFile ¶
func (*SSHPath) RemoveAllVersions ¶ added in v1.16.3
type SwiftPath ¶ added in v1.10.0
type SwiftPath struct {
// contains filtered or unexported fields
}
SwiftPath is a vfs path for Openstack Cloud Storage.
func NewSwiftPath ¶ added in v1.10.0
func NewSwiftPath(vfsContext *VFSContext, bucket string, key string) (*SwiftPath, error)
func (*SwiftPath) CreateFile ¶ added in v1.10.0
func (*SwiftPath) PreferredHash ¶ added in v1.10.0
func (*SwiftPath) RemoveAllVersions ¶ added in v1.16.3
type TerraformPath ¶ added in v1.21.3
type TerraformPath interface { Path // RenderTerraform renders the file to a TerraformWriter. RenderTerraform(writer *terraformWriter.TerraformWriter, name string, data io.Reader, acl ACL) error }
TerraformPath is a Path that can render to Terraform.
type VFSContext ¶
type VFSContext struct {
// contains filtered or unexported fields
}
VFSContext is a 'context' for VFS, that is normally a singleton but allows us to configure S3 credentials, for example
func NewTestingVFSContext ¶ added in v1.28.0
func NewTestingVFSContext() *VFSContext
func NewVFSContext ¶ added in v1.26.0
func NewVFSContext() *VFSContext
NewVFSContext builds a new VFSContext
func (*VFSContext) BuildVfsPath ¶
func (c *VFSContext) BuildVfsPath(p string) (Path, error)
func (*VFSContext) ReadFile ¶
func (c *VFSContext) ReadFile(location string, options ...VFSOption) ([]byte, error)
ReadFile reads a file from a vfs URL It supports additional schemes which don't (yet) have full VFS implementations:
metadata: reads from instance metadata on GCE/AWS http / https: reads from HTTP
func (*VFSContext) ResetMemfsContext ¶ added in v1.10.0
func (c *VFSContext) ResetMemfsContext(clusterReadable bool)
func (*VFSContext) WithGCSClient ¶ added in v1.26.0
func (v *VFSContext) WithGCSClient(gcsClient *storage.Service) *VFSContext
type VFSOption ¶ added in v1.15.1
type VFSOption func(options *vfsOptions)
func WithBackoff ¶ added in v1.15.1
WithBackoff specifies a custom VFS backoff policy
type WriteOption ¶ added in v1.4.1
type WriteOption string
const ( WriteOptionCreate WriteOption = "Create" WriteOptionOnlyIfExists WriteOption = "IfExists" )