From 6c75635bfe685aa47b78e2b8d5df79a8d0d07287 Mon Sep 17 00:00:00 2001 From: Thorsten Klein Date: Mon, 23 Dec 2024 11:12:15 +0100 Subject: [PATCH] add: model-provider errors --- .../handlers/toolreference/toolreference.go | 18 +++++++++++++++++- .../model-providers/ModelProviderForm.tsx | 10 +++++++++- ui/admin/app/hooks/useAsync.tsx | 14 ++++++++++++++ 3 files changed, 40 insertions(+), 2 deletions(-) diff --git a/pkg/controller/handlers/toolreference/toolreference.go b/pkg/controller/handlers/toolreference/toolreference.go index 34ebc62cf..e9f70df06 100644 --- a/pkg/controller/handlers/toolreference/toolreference.go +++ b/pkg/controller/handlers/toolreference/toolreference.go @@ -3,10 +3,12 @@ package toolreference import ( "context" "crypto/sha256" + "encoding/json" "fmt" "net/url" "os" "path" + "regexp" "strings" "time" @@ -385,7 +387,21 @@ func (h *Handler) BackPopulateModels(req router.Request, _ router.Response) erro if err != nil { // Don't error and retry because it will likely fail again. Log the error, and the user can re-sync manually. // Also, the toolRef.Status.Error field will bubble up to the user in the UI. - toolRef.Status.Error = err.Error() + + // Check if the model provider returned a properly formatted error message and set it as status + re := regexp.MustCompile(`\{.*"error":.*}`) + match := re.FindString(err.Error()) + if match != "" { + toolRef.Status.Error = match + type errorResponse struct { + Error string `json:"error"` + } + var eR errorResponse + if err := json.Unmarshal([]byte(match), &eR); err == nil { + toolRef.Status.Error = eR.Error + } + } + log.Errorf(err.Error()) return nil } diff --git a/ui/admin/app/components/model-providers/ModelProviderForm.tsx b/ui/admin/app/components/model-providers/ModelProviderForm.tsx index b38cbc52d..1c6139e36 100644 --- a/ui/admin/app/components/model-providers/ModelProviderForm.tsx +++ b/ui/admin/app/components/model-providers/ModelProviderForm.tsx @@ -199,7 +199,15 @@ export function ModelProviderForm({ Your configuration was saved, but we were not able to connect to the model provider. Please check your - configuration and try again. + configuration and try again:{" "} + + {(typeof fetchAvailableModels.error === + "object" && + "message" in fetchAvailableModels.error && + (fetchAvailableModels.error + .message as string)) ?? + "Unknown error"} + diff --git a/ui/admin/app/hooks/useAsync.tsx b/ui/admin/app/hooks/useAsync.tsx index d02461073..c9a7999d2 100644 --- a/ui/admin/app/hooks/useAsync.tsx +++ b/ui/admin/app/hooks/useAsync.tsx @@ -43,6 +43,20 @@ export function useAsync( onSuccess?.(data, params); }) .catch((error) => { + if ( + error.response && + typeof error.response.data === "string" + ) { + const errorMessageMatch = + error.response.data.match(/{"error":"(.*?)"}/); + if (errorMessageMatch) { + const errorMessage = JSON.parse( + errorMessageMatch[0] + ).error; + console.log("Error: ", errorMessage); + error.message = errorMessage; + } + } setError(error); onError?.(error, params); })