From 136529b848092da05a75c27d2c498b02acada3fd Mon Sep 17 00:00:00 2001 From: "aleksej.paschenko" Date: Mon, 2 Dec 2024 14:38:00 +0300 Subject: [PATCH] API handlers to return error containing error key --- api/openapi.json | 3 +++ api/openapi.yml | 2 ++ pkg/api/converters.go | 48 ++++++++++++++++++++++++++++++++------ pkg/oas/oas_json_gen.go | 19 ++++++++++++++- pkg/oas/oas_schemas_gen.go | 13 ++++++++++- 5 files changed, 76 insertions(+), 9 deletions(-) diff --git a/api/openapi.json b/api/openapi.json index 9c8e2f11..0ab4e853 100644 --- a/api/openapi.json +++ b/api/openapi.json @@ -690,6 +690,9 @@ "properties": { "error": { "type": "string" + }, + "error_key": { + "type": "string" } }, "required": [ diff --git a/api/openapi.yml b/api/openapi.yml index 6a938ed5..8ee1c1d5 100644 --- a/api/openapi.yml +++ b/api/openapi.yml @@ -7391,3 +7391,5 @@ components: properties: error: type: string + error_key: + type: string diff --git a/pkg/api/converters.go b/pkg/api/converters.go index d26f4f4a..10f3c9c5 100644 --- a/pkg/api/converters.go +++ b/pkg/api/converters.go @@ -3,14 +3,16 @@ package api import ( "context" "encoding/json" + "errors" "fmt" - imgGenerator "github.com/tonkeeper/opentonapi/pkg/image" "math/big" "reflect" "strconv" "strings" "unicode" + imgGenerator "github.com/tonkeeper/opentonapi/pkg/image" + "github.com/go-faster/jx" "github.com/tonkeeper/tongo" "github.com/tonkeeper/tongo/boc" @@ -22,15 +24,47 @@ import ( walletPkg "github.com/tonkeeper/opentonapi/pkg/wallet" ) -func toError(code int, err error) *oas.ErrorStatusCode { - if strings.HasPrefix(err.Error(), "failed to connect to") || strings.Contains(err.Error(), "host=") { - return &oas.ErrorStatusCode{StatusCode: code, Response: oas.Error{Error: "unknown error"}} +// Error helps to pass additional information about an error from private tonapi2 handlers. +type Error struct { + Code int + Message string + Key string +} + +func (e Error) Error() string { + return e.Message +} + +// censor removes sensitive information from the error message. +func censor(msg string) string { + if strings.HasPrefix(msg, "failed to connect to") || strings.Contains(msg, "host=") { + return "unknown error" + } + return msg +} + +func optKey(s string) oas.OptString { + if s == "" { + return oas.OptString{} + } + return oas.NewOptString(s) +} + +func toError(defaultCode int, err error) *oas.ErrorStatusCode { + var e Error + if errors.As(err, &e) { + return &oas.ErrorStatusCode{ + StatusCode: e.Code, + Response: oas.Error{ + Error: censor(e.Message), + ErrorKey: optKey(e.Key), + }, + } } if s, ok := status.FromError(err); ok { - return &oas.ErrorStatusCode{StatusCode: code, Response: oas.Error{Error: s.Message()}} + return &oas.ErrorStatusCode{StatusCode: defaultCode, Response: oas.Error{Error: censor(s.Message())}} } - msg := err.Error() - return &oas.ErrorStatusCode{StatusCode: code, Response: oas.Error{Error: msg}} + return &oas.ErrorStatusCode{StatusCode: defaultCode, Response: oas.Error{Error: censor(err.Error())}} } func anyToJSONRawMap(a any) map[string]jx.Raw { //todo: переписать этот ужас diff --git a/pkg/oas/oas_json_gen.go b/pkg/oas/oas_json_gen.go index 4303363a..7200248d 100644 --- a/pkg/oas/oas_json_gen.go +++ b/pkg/oas/oas_json_gen.go @@ -15271,10 +15271,17 @@ func (s *Error) encodeFields(e *jx.Encoder) { e.FieldStart("error") e.Str(s.Error) } + { + if s.ErrorKey.Set { + e.FieldStart("error_key") + s.ErrorKey.Encode(e) + } + } } -var jsonFieldsNameOfError = [1]string{ +var jsonFieldsNameOfError = [2]string{ 0: "error", + 1: "error_key", } // Decode decodes Error from json. @@ -15298,6 +15305,16 @@ func (s *Error) Decode(d *jx.Decoder) error { }(); err != nil { return errors.Wrap(err, "decode field \"error\"") } + case "error_key": + if err := func() error { + s.ErrorKey.Reset() + if err := s.ErrorKey.Decode(d); err != nil { + return err + } + return nil + }(); err != nil { + return errors.Wrap(err, "decode field \"error_key\"") + } default: return d.Skip() } diff --git a/pkg/oas/oas_schemas_gen.go b/pkg/oas/oas_schemas_gen.go index 8d3b6e56..c7417254 100644 --- a/pkg/oas/oas_schemas_gen.go +++ b/pkg/oas/oas_schemas_gen.go @@ -5265,7 +5265,8 @@ func (s *EncryptedComment) SetCipherText(val string) { } type Error struct { - Error string `json:"error"` + Error string `json:"error"` + ErrorKey OptString `json:"error_key"` } // GetError returns the value of Error. @@ -5273,11 +5274,21 @@ func (s *Error) GetError() string { return s.Error } +// GetErrorKey returns the value of ErrorKey. +func (s *Error) GetErrorKey() OptString { + return s.ErrorKey +} + // SetError sets the value of Error. func (s *Error) SetError(val string) { s.Error = val } +// SetErrorKey sets the value of ErrorKey. +func (s *Error) SetErrorKey(val OptString) { + s.ErrorKey = val +} + // ErrorStatusCode wraps Error with StatusCode. type ErrorStatusCode struct { StatusCode int