mirror of
https://github.com/moby/moby.git
synced 2022-11-09 12:21:53 -05:00
240a9fcb83
Adds code to support Cluster Volumes in Swarm using CSI drivers. Signed-off-by: Drew Erny <derny@mirantis.com>
34 lines
1.5 KiB
Go
34 lines
1.5 KiB
Go
package volume // import "github.com/docker/docker/api/server/router/volume"
|
|
|
|
import (
|
|
"context"
|
|
|
|
"github.com/docker/docker/volume/service/opts"
|
|
// TODO return types need to be refactored into pkg
|
|
"github.com/docker/docker/api/types"
|
|
"github.com/docker/docker/api/types/filters"
|
|
"github.com/docker/docker/api/types/volume"
|
|
)
|
|
|
|
// Backend is the methods that need to be implemented to provide
|
|
// volume specific functionality
|
|
type Backend interface {
|
|
List(ctx context.Context, filter filters.Args) ([]*volume.Volume, []string, error)
|
|
Get(ctx context.Context, name string, opts ...opts.GetOption) (*volume.Volume, error)
|
|
Create(ctx context.Context, name, driverName string, opts ...opts.CreateOption) (*volume.Volume, error)
|
|
Remove(ctx context.Context, name string, opts ...opts.RemoveOption) error
|
|
Prune(ctx context.Context, pruneFilters filters.Args) (*types.VolumesPruneReport, error)
|
|
}
|
|
|
|
// ClusterBackend is the backend used for Swarm Cluster Volumes. Regular
|
|
// volumes go through the volume service, but to avoid across-dependency
|
|
// between the cluster package and the volume package, we simply provide two
|
|
// backends here.
|
|
type ClusterBackend interface {
|
|
GetVolume(nameOrID string) (volume.Volume, error)
|
|
GetVolumes(options volume.ListOptions) ([]*volume.Volume, error)
|
|
CreateVolume(volume volume.CreateOptions) (*volume.Volume, error)
|
|
RemoveVolume(nameOrID string, force bool) error
|
|
UpdateVolume(nameOrID string, version uint64, volume volume.UpdateOptions) error
|
|
IsManager() bool
|
|
}
|