2020-05-29 12:02:07 +02:00
package dockerclassic
import (
"context"
"fmt"
"os"
"os/exec"
2020-05-29 17:07:48 +02:00
"github.com/spf13/cobra"
2020-05-29 12:02:07 +02:00
apicontext "github.com/docker/api/context"
"github.com/docker/api/context/store"
)
2020-05-29 17:07:48 +02:00
// Exec delegates to docker-classic
2020-05-29 12:02:07 +02:00
func Exec ( ctx context . Context ) {
currentContext := apicontext . CurrentContext ( ctx )
s := store . ContextStore ( ctx )
_ , err := s . Get ( currentContext )
// Only run original docker command if the current context is not
// ours.
if err != nil {
cmd := exec . CommandContext ( ctx , "docker-classic" , os . Args [ 1 : ] ... )
cmd . Stdin = os . Stdin
cmd . Stdout = os . Stdout
cmd . Stderr = os . Stderr
if err := cmd . Run ( ) ; err != nil {
if exiterr , ok := err . ( * exec . ExitError ) ; ok {
os . Exit ( exiterr . ExitCode ( ) )
}
fmt . Fprintln ( os . Stderr , err )
os . Exit ( 1 )
}
os . Exit ( 0 )
}
}
2020-05-29 17:07:48 +02:00
// ExecCmd delegates the cli command to docker-classic. The error is never returned (process will exit with docker classic exit code), the return type is to make it easier to use with cobra commands
func ExecCmd ( command * cobra . Command ) error {
Exec ( command . Context ( ) )
return nil
}