diff --git a/pkg/controller/handlers/toolreference/toolreference.go b/pkg/controller/handlers/toolreference/toolreference.go index 34ebc62cf..d8659ba7c 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,8 +387,22 @@ 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() - log.Errorf(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("%v", err) 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); })