From 07a29dd660a617251ed2d9c2cd6c75db89b4f1fe Mon Sep 17 00:00:00 2001 From: Felix Fontein Date: Thu, 8 Feb 2024 21:19:54 +0100 Subject: [PATCH] Format errors as JSON when in JSON progress mode. Signed-off-by: Felix Fontein --- cmd/compose/compose.go | 36 ++++++++++++++++++++++++++++++++++++ 1 file changed, 36 insertions(+) diff --git a/cmd/compose/compose.go b/cmd/compose/compose.go index fe7d49174a5..8801d5415da 100644 --- a/cmd/compose/compose.go +++ b/cmd/compose/compose.go @@ -18,6 +18,7 @@ package compose import ( "context" + "encoding/json" "errors" "fmt" "os" @@ -99,6 +100,9 @@ func AdaptCmd(fn CobraCommand) func(cmd *cobra.Command, args []string) error { Status: err.Error(), } } + if ui.Mode == ui.ModeJSON { + err = makeJSONError(err) + } return err } } @@ -154,6 +158,38 @@ func (o *ProjectOptions) WithServices(dockerCli command.Cli, fn ProjectServicesF }) } +type jsonErrorData struct { + Error bool `json:"error,omitempty"` + Message string `json:"message,omitempty"` +} + +func errorAsJSON(message string) string { + errorMessage := &jsonErrorData{ + Error: true, + Message: message, + } + marshal, err := json.Marshal(errorMessage) + if err == nil { + return string(marshal) + } else { + return message + } +} + +func makeJSONError(err error) error { + if err == nil { + return nil + } + var statusErr dockercli.StatusError + if errors.As(err, &statusErr) { + return dockercli.StatusError{ + StatusCode: statusErr.StatusCode, + Status: errorAsJSON(statusErr.Status), + } + } + return fmt.Errorf("%s", errorAsJSON(err.Error())) +} + func (o *ProjectOptions) addProjectFlags(f *pflag.FlagSet) { f.StringArrayVar(&o.Profiles, "profile", []string{}, "Specify a profile to enable") f.StringVarP(&o.ProjectName, "project-name", "p", "", "Project name")