Go maintainers started to unconditionally update the minimum go version for golang.org/x/ dependencies to go1.23, which means that we'll no longer be able to support any version below that when updating those dependencies; > all: upgrade go directive to at least 1.23.0 [generated] > > By now Go 1.24.0 has been released, and Go 1.22 is no longer supported > per the Go Release Policy (https://go.dev/doc/devel/release#policy). > > For golang/go#69095. This updates our minimum version to go1.23, as we won't be able to maintain compatibility with older versions because of the above. Signed-off-by: Sebastiaan van Stijn <github@gone.nl>
74 lines
2.1 KiB
Go
74 lines
2.1 KiB
Go
// FIXME(thaJeztah): remove once we are a module; the go:build directive prevents go from downgrading language version to go1.16:
|
|
//go:build go1.23
|
|
|
|
package config
|
|
|
|
import (
|
|
"context"
|
|
"errors"
|
|
"strings"
|
|
|
|
"github.com/docker/cli/cli"
|
|
"github.com/docker/cli/cli/command"
|
|
"github.com/docker/cli/cli/command/formatter"
|
|
flagsHelper "github.com/docker/cli/cli/flags"
|
|
"github.com/spf13/cobra"
|
|
)
|
|
|
|
// InspectOptions contains options for the docker config inspect command.
|
|
type InspectOptions struct {
|
|
Names []string
|
|
Format string
|
|
Pretty bool
|
|
}
|
|
|
|
func newConfigInspectCommand(dockerCli command.Cli) *cobra.Command {
|
|
opts := InspectOptions{}
|
|
cmd := &cobra.Command{
|
|
Use: "inspect [OPTIONS] CONFIG [CONFIG...]",
|
|
Short: "Display detailed information on one or more configs",
|
|
Args: cli.RequiresMinArgs(1),
|
|
RunE: func(cmd *cobra.Command, args []string) error {
|
|
opts.Names = args
|
|
return RunConfigInspect(cmd.Context(), dockerCli, opts)
|
|
},
|
|
ValidArgsFunction: func(cmd *cobra.Command, args []string, toComplete string) ([]string, cobra.ShellCompDirective) {
|
|
return completeNames(dockerCli)(cmd, args, toComplete)
|
|
},
|
|
}
|
|
|
|
cmd.Flags().StringVarP(&opts.Format, "format", "f", "", flagsHelper.InspectFormatHelp)
|
|
cmd.Flags().BoolVar(&opts.Pretty, "pretty", false, "Print the information in a human friendly format")
|
|
return cmd
|
|
}
|
|
|
|
// RunConfigInspect inspects the given Swarm config.
|
|
func RunConfigInspect(ctx context.Context, dockerCLI command.Cli, opts InspectOptions) error {
|
|
apiClient := dockerCLI.Client()
|
|
|
|
if opts.Pretty {
|
|
opts.Format = "pretty"
|
|
}
|
|
|
|
getRef := func(id string) (any, []byte, error) {
|
|
return apiClient.ConfigInspectWithRaw(ctx, id)
|
|
}
|
|
f := opts.Format
|
|
|
|
// check if the user is trying to apply a template to the pretty format, which
|
|
// is not supported
|
|
if strings.HasPrefix(f, "pretty") && f != "pretty" {
|
|
return errors.New("cannot supply extra formatting options to the pretty template")
|
|
}
|
|
|
|
configCtx := formatter.Context{
|
|
Output: dockerCLI.Out(),
|
|
Format: NewFormat(f, false),
|
|
}
|
|
|
|
if err := InspectFormatWrite(configCtx, opts.Names, getRef); err != nil {
|
|
return cli.StatusError{StatusCode: 1, Status: err.Error()}
|
|
}
|
|
return nil
|
|
}
|