mirror of https://github.com/docker/compose.git
Put each compose command in own file
This commit is contained in:
parent
962efef48c
commit
0765b08309
|
@ -2,9 +2,6 @@ package compose
|
||||||
|
|
||||||
import (
|
import (
|
||||||
"github.com/spf13/cobra"
|
"github.com/spf13/cobra"
|
||||||
|
|
||||||
"github.com/docker/api/client"
|
|
||||||
"github.com/docker/api/compose"
|
|
||||||
)
|
)
|
||||||
|
|
||||||
// Command returns the compose command with its child commands
|
// Command returns the compose command with its child commands
|
||||||
|
@ -13,48 +10,11 @@ func Command() *cobra.Command {
|
||||||
Short: "Docker Compose",
|
Short: "Docker Compose",
|
||||||
Use: "compose",
|
Use: "compose",
|
||||||
}
|
}
|
||||||
|
|
||||||
command.AddCommand(
|
command.AddCommand(
|
||||||
upCommand(),
|
upCommand(),
|
||||||
downCommand(),
|
downCommand(),
|
||||||
)
|
)
|
||||||
|
|
||||||
return command
|
return command
|
||||||
}
|
}
|
||||||
|
|
||||||
func upCommand() *cobra.Command {
|
|
||||||
opts := &compose.ProjectOptions{}
|
|
||||||
upCmd := &cobra.Command{
|
|
||||||
Use: "up",
|
|
||||||
RunE: func(cmd *cobra.Command, args []string) error {
|
|
||||||
c, err := client.New(cmd.Context())
|
|
||||||
if err != nil {
|
|
||||||
return err
|
|
||||||
}
|
|
||||||
return c.ComposeService().Up(cmd.Context(), *opts)
|
|
||||||
},
|
|
||||||
}
|
|
||||||
upCmd.Flags().StringVar(&opts.Name, "name", "", "Project name")
|
|
||||||
upCmd.Flags().StringVar(&opts.WorkDir, "workdir", ".", "Work dir")
|
|
||||||
upCmd.Flags().StringArrayVarP(&opts.ConfigPaths, "file", "f", []string{}, "Compose configuration files")
|
|
||||||
upCmd.Flags().StringArrayVarP(&opts.Environment, "environment", "e", []string{}, "Environment variables")
|
|
||||||
|
|
||||||
return upCmd
|
|
||||||
}
|
|
||||||
|
|
||||||
func downCommand() *cobra.Command {
|
|
||||||
opts := &compose.ProjectOptions{}
|
|
||||||
downCmd := &cobra.Command{
|
|
||||||
Use: "down",
|
|
||||||
RunE: func(cmd *cobra.Command, args []string) error {
|
|
||||||
c, err := client.New(cmd.Context())
|
|
||||||
if err != nil {
|
|
||||||
return err
|
|
||||||
}
|
|
||||||
return c.ComposeService().Down(cmd.Context(), *opts)
|
|
||||||
},
|
|
||||||
}
|
|
||||||
downCmd.Flags().StringVar(&opts.Name, "name", "", "Project name")
|
|
||||||
downCmd.Flags().StringVar(&opts.WorkDir, "workdir", ".", "Work dir")
|
|
||||||
downCmd.Flags().StringArrayVarP(&opts.ConfigPaths, "file", "f", []string{}, "Compose configuration files")
|
|
||||||
|
|
||||||
return downCmd
|
|
||||||
}
|
|
||||||
|
|
|
@ -0,0 +1,40 @@
|
||||||
|
package compose
|
||||||
|
|
||||||
|
import (
|
||||||
|
"context"
|
||||||
|
"errors"
|
||||||
|
|
||||||
|
"github.com/spf13/cobra"
|
||||||
|
|
||||||
|
"github.com/docker/api/client"
|
||||||
|
"github.com/docker/api/compose"
|
||||||
|
)
|
||||||
|
|
||||||
|
func downCommand() *cobra.Command {
|
||||||
|
opts := compose.ProjectOptions{}
|
||||||
|
downCmd := &cobra.Command{
|
||||||
|
Use: "down",
|
||||||
|
RunE: func(cmd *cobra.Command, args []string) error {
|
||||||
|
return runDown(cmd.Context(), opts)
|
||||||
|
},
|
||||||
|
}
|
||||||
|
downCmd.Flags().StringVar(&opts.Name, "name", "", "Project name")
|
||||||
|
downCmd.Flags().StringVar(&opts.WorkDir, "workdir", ".", "Work dir")
|
||||||
|
downCmd.Flags().StringArrayVarP(&opts.ConfigPaths, "file", "f", []string{}, "Compose configuration files")
|
||||||
|
|
||||||
|
return downCmd
|
||||||
|
}
|
||||||
|
|
||||||
|
func runDown(ctx context.Context, opts compose.ProjectOptions) error {
|
||||||
|
c, err := client.New(ctx)
|
||||||
|
if err != nil {
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
|
||||||
|
composeService := c.ComposeService()
|
||||||
|
if composeService == nil {
|
||||||
|
return errors.New("compose not implemented in current context")
|
||||||
|
}
|
||||||
|
|
||||||
|
return composeService.Down(ctx, opts)
|
||||||
|
}
|
|
@ -0,0 +1,41 @@
|
||||||
|
package compose
|
||||||
|
|
||||||
|
import (
|
||||||
|
"context"
|
||||||
|
"errors"
|
||||||
|
|
||||||
|
"github.com/spf13/cobra"
|
||||||
|
|
||||||
|
"github.com/docker/api/client"
|
||||||
|
"github.com/docker/api/compose"
|
||||||
|
)
|
||||||
|
|
||||||
|
func upCommand() *cobra.Command {
|
||||||
|
opts := compose.ProjectOptions{}
|
||||||
|
upCmd := &cobra.Command{
|
||||||
|
Use: "up",
|
||||||
|
RunE: func(cmd *cobra.Command, args []string) error {
|
||||||
|
return runUp(cmd.Context(), opts)
|
||||||
|
},
|
||||||
|
}
|
||||||
|
upCmd.Flags().StringVar(&opts.Name, "name", "", "Project name")
|
||||||
|
upCmd.Flags().StringVar(&opts.WorkDir, "workdir", ".", "Work dir")
|
||||||
|
upCmd.Flags().StringArrayVarP(&opts.ConfigPaths, "file", "f", []string{}, "Compose configuration files")
|
||||||
|
upCmd.Flags().StringArrayVarP(&opts.Environment, "environment", "e", []string{}, "Environment variables")
|
||||||
|
|
||||||
|
return upCmd
|
||||||
|
}
|
||||||
|
|
||||||
|
func runUp(ctx context.Context, opts compose.ProjectOptions) error {
|
||||||
|
c, err := client.New(ctx)
|
||||||
|
if err != nil {
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
|
||||||
|
composeService := c.ComposeService()
|
||||||
|
if composeService == nil {
|
||||||
|
return errors.New("compose not implemented in current context")
|
||||||
|
}
|
||||||
|
|
||||||
|
return composeService.Up(ctx, opts)
|
||||||
|
}
|
Loading…
Reference in New Issue