mirror of
https://github.com/containers/podman.git
synced 2025-06-23 02:18:13 +08:00
Merge pull request #2313 from baude/remotevolumecreate
podman-remote volume create
This commit is contained in:
@ -33,7 +33,9 @@ func getPodSubCommands() []*cobra.Command {
|
||||
|
||||
// commands that only the remoteclient implements
|
||||
func getVolumeSubCommands() []*cobra.Command {
|
||||
return []*cobra.Command{}
|
||||
return []*cobra.Command{
|
||||
_volumeCreateCommand,
|
||||
}
|
||||
}
|
||||
|
||||
// commands that only the remoteclient implements
|
||||
|
@ -27,6 +27,15 @@ type ContainerChanges (
|
||||
deleted: []string
|
||||
)
|
||||
|
||||
type VolumeCreateOpts (
|
||||
volumeName: string,
|
||||
driver: string,
|
||||
labels: [string]string,
|
||||
options: [string]string
|
||||
)
|
||||
|
||||
|
||||
|
||||
# ImageInList describes the structure that is returned in
|
||||
# ListImages.
|
||||
type ImageInList (
|
||||
@ -1053,6 +1062,9 @@ method ContainerStateData(name: string) -> (config: string)
|
||||
method SendFile(type: string, length: int) -> (file_handle: string)
|
||||
method ReceiveFile(path: string, delete: bool) -> (len: int)
|
||||
|
||||
method VolumeCreate(options: VolumeCreateOpts) -> (volumeName: string)
|
||||
|
||||
|
||||
# ImageNotFound means the image could not be found by the provided name or ID in local storage.
|
||||
error ImageNotFound (name: string)
|
||||
|
||||
|
@ -4,8 +4,7 @@ import (
|
||||
"fmt"
|
||||
|
||||
"github.com/containers/libpod/cmd/podman/cliconfig"
|
||||
"github.com/containers/libpod/cmd/podman/libpodruntime"
|
||||
"github.com/containers/libpod/libpod"
|
||||
"github.com/containers/libpod/libpod/adapter"
|
||||
"github.com/pkg/errors"
|
||||
"github.com/spf13/cobra"
|
||||
)
|
||||
@ -41,13 +40,7 @@ func init() {
|
||||
}
|
||||
|
||||
func volumeCreateCmd(c *cliconfig.VolumeCreateValues) error {
|
||||
var (
|
||||
options []libpod.VolumeCreateOption
|
||||
err error
|
||||
volName string
|
||||
)
|
||||
|
||||
runtime, err := libpodruntime.GetRuntime(&c.PodmanCommand)
|
||||
runtime, err := adapter.GetRuntime(&c.PodmanCommand)
|
||||
if err != nil {
|
||||
return errors.Wrapf(err, "error creating libpod runtime")
|
||||
}
|
||||
@ -57,36 +50,19 @@ func volumeCreateCmd(c *cliconfig.VolumeCreateValues) error {
|
||||
return errors.Errorf("too many arguments, create takes at most 1 argument")
|
||||
}
|
||||
|
||||
if len(c.InputArgs) > 0 {
|
||||
volName = c.InputArgs[0]
|
||||
options = append(options, libpod.WithVolumeName(volName))
|
||||
}
|
||||
|
||||
if c.Flag("driver").Changed {
|
||||
options = append(options, libpod.WithVolumeDriver(c.String("driver")))
|
||||
}
|
||||
|
||||
labels, err := getAllLabels([]string{}, c.Label)
|
||||
if err != nil {
|
||||
return errors.Wrapf(err, "unable to process labels")
|
||||
}
|
||||
if len(labels) != 0 {
|
||||
options = append(options, libpod.WithVolumeLabels(labels))
|
||||
}
|
||||
|
||||
opts, err := getAllLabels([]string{}, c.Opt)
|
||||
if err != nil {
|
||||
return errors.Wrapf(err, "unable to process options")
|
||||
}
|
||||
if len(options) != 0 {
|
||||
options = append(options, libpod.WithVolumeOptions(opts))
|
||||
}
|
||||
|
||||
vol, err := runtime.NewVolume(getContext(), options...)
|
||||
if err != nil {
|
||||
return err
|
||||
volumeName, err := runtime.CreateVolume(getContext(), c, labels, opts)
|
||||
if err == nil {
|
||||
fmt.Println(volumeName)
|
||||
}
|
||||
fmt.Printf("%s\n", vol.Name())
|
||||
|
||||
return nil
|
||||
return err
|
||||
}
|
||||
|
@ -155,3 +155,33 @@ func (r *LocalRuntime) Export(name string, path string) error {
|
||||
func (r *LocalRuntime) Import(ctx context.Context, source, reference string, changes []string, history string, quiet bool) (string, error) {
|
||||
return r.Runtime.Import(ctx, source, reference, changes, history, quiet)
|
||||
}
|
||||
|
||||
// CreateVolume is a wrapper to create volumes
|
||||
func (r *LocalRuntime) CreateVolume(ctx context.Context, c *cliconfig.VolumeCreateValues, labels, opts map[string]string) (string, error) {
|
||||
var (
|
||||
options []libpod.VolumeCreateOption
|
||||
volName string
|
||||
)
|
||||
|
||||
if len(c.InputArgs) > 0 {
|
||||
volName = c.InputArgs[0]
|
||||
options = append(options, libpod.WithVolumeName(volName))
|
||||
}
|
||||
|
||||
if c.Flag("driver").Changed {
|
||||
options = append(options, libpod.WithVolumeDriver(c.Driver))
|
||||
}
|
||||
|
||||
if len(labels) != 0 {
|
||||
options = append(options, libpod.WithVolumeLabels(labels))
|
||||
}
|
||||
|
||||
if len(options) != 0 {
|
||||
options = append(options, libpod.WithVolumeOptions(opts))
|
||||
}
|
||||
newVolume, err := r.NewVolume(ctx, options...)
|
||||
if err != nil {
|
||||
return "", err
|
||||
}
|
||||
return newVolume.Name(), nil
|
||||
}
|
||||
|
@ -432,3 +432,20 @@ func (r *LocalRuntime) GetContainers(filters ...libpod.ContainerFilter) ([]*libp
|
||||
func (r *LocalRuntime) RemoveContainer(ctx context.Context, c *libpod.Container, force bool) error {
|
||||
return libpod.ErrNotImplemented
|
||||
}
|
||||
|
||||
// CreateVolume creates a volume over a varlink connection for the remote client
|
||||
func (r *LocalRuntime) CreateVolume(ctx context.Context, c *cliconfig.VolumeCreateValues, labels, opts map[string]string) (string, error) {
|
||||
cvOpts := iopodman.VolumeCreateOpts{
|
||||
Options: opts,
|
||||
Labels: labels,
|
||||
}
|
||||
if len(c.InputArgs) > 0 {
|
||||
cvOpts.VolumeName = c.InputArgs[0]
|
||||
}
|
||||
|
||||
if c.Flag("driver").Changed {
|
||||
cvOpts.Driver = c.Driver
|
||||
}
|
||||
|
||||
return iopodman.VolumeCreate().Call(r.Conn, cvOpts)
|
||||
}
|
||||
|
29
pkg/varlinkapi/volumes.go
Normal file
29
pkg/varlinkapi/volumes.go
Normal file
@ -0,0 +1,29 @@
|
||||
package varlinkapi
|
||||
|
||||
import (
|
||||
"github.com/containers/libpod/cmd/podman/varlink"
|
||||
"github.com/containers/libpod/libpod"
|
||||
)
|
||||
|
||||
// VolumeCreate creates a libpod volume based on input from a varlink connection
|
||||
func (i *LibpodAPI) VolumeCreate(call iopodman.VarlinkCall, options iopodman.VolumeCreateOpts) error {
|
||||
var volumeOptions []libpod.VolumeCreateOption
|
||||
|
||||
if len(options.VolumeName) > 0 {
|
||||
volumeOptions = append(volumeOptions, libpod.WithVolumeName(options.VolumeName))
|
||||
}
|
||||
if len(options.Driver) > 0 {
|
||||
volumeOptions = append(volumeOptions, libpod.WithVolumeDriver(options.Driver))
|
||||
}
|
||||
if len(options.Labels) > 0 {
|
||||
volumeOptions = append(volumeOptions, libpod.WithVolumeLabels(options.Labels))
|
||||
}
|
||||
if len(options.Options) > 0 {
|
||||
volumeOptions = append(volumeOptions, libpod.WithVolumeOptions(options.Options))
|
||||
}
|
||||
newVolume, err := i.Runtime.NewVolume(getContext(), volumeOptions...)
|
||||
if err != nil {
|
||||
return call.ReplyErrorOccurred(err.Error())
|
||||
}
|
||||
return call.ReplyVolumeCreate(newVolume.Name())
|
||||
}
|
Reference in New Issue
Block a user