From 1c5a71d4e38ae3051e2908874cc4c47b472120fd Mon Sep 17 00:00:00 2001 From: Stefan Moser <6841360+sm3142@users.noreply.github.com> Date: Wed, 13 Nov 2024 13:56:28 +0100 Subject: [PATCH 1/4] fix: write error messages to stderr rather than stdout --- error.go | 3 ++- transforms.go | 3 ++- 2 files changed, 4 insertions(+), 2 deletions(-) diff --git a/error.go b/error.go index 7ac25d28..bbf1b6bf 100644 --- a/error.go +++ b/error.go @@ -4,6 +4,7 @@ import ( "errors" "fmt" "net/http" + "os" ) // ErrorDetailer returns error details for responses & debugging. This enables @@ -264,7 +265,7 @@ func WriteErr(api API, ctx Context, status int, msg string, errs ...error) error writeErr := writeResponse(api, ctx, status, "", err) if writeErr != nil { // If we can't write the error, log it so we know what happened. - fmt.Printf("could not write error: %s\n", writeErr) + fmt.Fprintf(os.Stderr, "could not write error: %s\n", writeErr) } return writeErr } diff --git a/transforms.go b/transforms.go index 9c5a0db2..2dd0e037 100644 --- a/transforms.go +++ b/transforms.go @@ -3,6 +3,7 @@ package huma import ( "bytes" "fmt" + "os" "path" "reflect" ) @@ -132,7 +133,7 @@ func (t *SchemaLinkTransformer) OnAddOperation(oapi *OpenAPI, op *Operation) { // Catch some scenarios that just aren't supported in Go at the // moment. Logs an error so people know what's going on. // https://github.com/danielgtaylor/huma/issues/371 - fmt.Println("Warning: unable to create schema link for type", typ, ":", r) + fmt.Fprintln(os.Stderr, "Warning: unable to create schema link for type", typ, ":", r) } }() newType := reflect.StructOf(fields) From a130837e518b608fea3ca2a3b1e6e81146855591 Mon Sep 17 00:00:00 2001 From: Stefan Moser <6841360+sm3142@users.noreply.github.com> Date: Wed, 13 Nov 2024 20:34:43 +0100 Subject: [PATCH 2/4] oops, codeRabbit called me out on sloppiness --- humacli/humacli.go | 2 +- sse/sse.go | 7 ++++--- 2 files changed, 5 insertions(+), 4 deletions(-) diff --git a/humacli/humacli.go b/humacli/humacli.go index 9db7f8a4..26fb2021 100644 --- a/humacli/humacli.go +++ b/humacli/humacli.go @@ -165,7 +165,7 @@ func (c *cli[O]) setupOptions(t reflect.Type, path []int) { if !field.IsExported() { // This isn't a public field, so we cannot use reflect.Value.Set with // it. This is usually a struct field with a lowercase name. - fmt.Println("warning: ignoring unexported options field", field.Name) + fmt.Fprintln(os.Stderr, "warning: ignoring unexported options field", field.Name) continue } diff --git a/sse/sse.go b/sse/sse.go index edda12c5..f7a505ca 100644 --- a/sse/sse.go +++ b/sse/sse.go @@ -6,6 +6,7 @@ import ( "encoding/json" "fmt" "net/http" + "os" "reflect" "runtime/debug" "time" @@ -160,10 +161,10 @@ func Register[I any](api huma.API, op huma.Operation, eventTypeMap map[string]an send := func(msg Message) error { if deadliner != nil { if err := deadliner.SetWriteDeadline(time.Now().Add(WriteTimeout)); err != nil { - fmt.Println("warning: unable to set write deadline: " + err.Error()) + fmt.Fprintln(os.Stderr, "warning: unable to set write deadline: "+err.Error()) } } else { - fmt.Println("warning: unable to set write deadline") + fmt.Fprintln(os.Stderr, "warning: unable to set write deadline") } // Write optional fields @@ -198,7 +199,7 @@ func Register[I any](api huma.API, op huma.Operation, eventTypeMap map[string]an if flusher != nil { flusher.Flush() } else { - fmt.Println("error: unable to flush") + fmt.Fprintln(os.Stderr, "error: unable to flush") return fmt.Errorf("unable to flush: %w", http.ErrNotSupported) } return nil From eee2d29ccc2625c087e0e5410a569b7fcf694e06 Mon Sep 17 00:00:00 2001 From: Stefan Moser <6841360+sm3142@users.noreply.github.com> Date: Thu, 14 Nov 2024 09:21:00 +0100 Subject: [PATCH 3/4] fix: redirect more direct output to stderr (third time's a charm?) --- humacli/humacli.go | 2 +- sse/sse.go | 2 +- 2 files changed, 2 insertions(+), 2 deletions(-) diff --git a/humacli/humacli.go b/humacli/humacli.go index 26fb2021..5942a729 100644 --- a/humacli/humacli.go +++ b/humacli/humacli.go @@ -298,7 +298,7 @@ func New[O any](onParsed func(Hooks, *O)) CLI { // Server is done, just exit. case <-quit: if c.stop != nil { - fmt.Println("Gracefully shutting down the server...") + fmt.Fprintln(os.Stderr, "Gracefully shutting down the server...") c.stop() } } diff --git a/sse/sse.go b/sse/sse.go index f7a505ca..d9c2c67f 100644 --- a/sse/sse.go +++ b/sse/sse.go @@ -177,7 +177,7 @@ func Register[I any](api huma.API, op huma.Operation, eventTypeMap map[string]an event, ok := typeToEvent[deref(reflect.TypeOf(msg.Data))] if !ok { - fmt.Println("error: unknown event type", reflect.TypeOf(msg.Data)) + fmt.Fprintln(os.Stderr, "error: unknown event type", reflect.TypeOf(msg.Data)) debug.PrintStack() } if event != "" && event != "message" { From 7e4e027057697e877d1fa0d23d67740ddb9cb32d Mon Sep 17 00:00:00 2001 From: Stefan Moser <6841360+sm3142@users.noreply.github.com> Date: Thu, 14 Nov 2024 09:37:05 +0100 Subject: [PATCH 4/4] fix: address CodeRabbit nitpicks, consistent output formatting --- error.go | 2 +- sse/sse.go | 6 +++--- 2 files changed, 4 insertions(+), 4 deletions(-) diff --git a/error.go b/error.go index bbf1b6bf..4302606e 100644 --- a/error.go +++ b/error.go @@ -265,7 +265,7 @@ func WriteErr(api API, ctx Context, status int, msg string, errs ...error) error writeErr := writeResponse(api, ctx, status, "", err) if writeErr != nil { // If we can't write the error, log it so we know what happened. - fmt.Fprintf(os.Stderr, "could not write error: %s\n", writeErr) + fmt.Fprintf(os.Stderr, "could not write error: %v\n", writeErr) } return writeErr } diff --git a/sse/sse.go b/sse/sse.go index d9c2c67f..0d648c23 100644 --- a/sse/sse.go +++ b/sse/sse.go @@ -161,10 +161,10 @@ func Register[I any](api huma.API, op huma.Operation, eventTypeMap map[string]an send := func(msg Message) error { if deadliner != nil { if err := deadliner.SetWriteDeadline(time.Now().Add(WriteTimeout)); err != nil { - fmt.Fprintln(os.Stderr, "warning: unable to set write deadline: "+err.Error()) + fmt.Fprintf(os.Stderr, "warning: unable to set write deadline: %v\n", err) } } else { - fmt.Fprintln(os.Stderr, "warning: unable to set write deadline") + fmt.Fprintln(os.Stderr, "write deadline not supported by underlying writer") } // Write optional fields @@ -177,7 +177,7 @@ func Register[I any](api huma.API, op huma.Operation, eventTypeMap map[string]an event, ok := typeToEvent[deref(reflect.TypeOf(msg.Data))] if !ok { - fmt.Fprintln(os.Stderr, "error: unknown event type", reflect.TypeOf(msg.Data)) + fmt.Fprintf(os.Stderr, "error: unknown event type %v\n", reflect.TypeOf(msg.Data)) debug.PrintStack() } if event != "" && event != "message" {