From 5ea95f245fcae96bead71ab70b861a33287dcb32 Mon Sep 17 00:00:00 2001 From: Matt Johnstone Date: Mon, 14 Oct 2024 17:20:34 +0200 Subject: [PATCH] added rpc error data --- pkg/rpc/client.go | 2 +- pkg/rpc/responses.go | 7 ++++--- 2 files changed, 5 insertions(+), 4 deletions(-) diff --git a/pkg/rpc/client.go b/pkg/rpc/client.go index fb9fe64..226364b 100644 --- a/pkg/rpc/client.go +++ b/pkg/rpc/client.go @@ -131,7 +131,7 @@ func getResponse[T any]( return fmt.Errorf("failed to decode %s response body: %w", method, err) } - // last error check: + // check for an actual rpc error if rpcResponse.Error.Code != 0 { return &rpcResponse.Error } diff --git a/pkg/rpc/responses.go b/pkg/rpc/responses.go index f6cc3dd..8b88e74 100644 --- a/pkg/rpc/responses.go +++ b/pkg/rpc/responses.go @@ -7,8 +7,9 @@ import ( type ( RPCError struct { - Message string `json:"message"` - Code int64 `json:"code"` + Message string `json:"message"` + Code int64 `json:"code"` + Data map[string]any `json:"data"` } response[T any] struct { @@ -97,7 +98,7 @@ type ( ) func (e *RPCError) Error() string { - return fmt.Sprintf("RPC Error (%d): %s", e.Code, e.Message) + return fmt.Sprintf("rpc error (code: %d): %s (data: %v)", e.Code, e.Message, e.Data) } func (hp *HostProduction) UnmarshalJSON(data []byte) error {