From 4d4bb8b6a71bb2dd7b8c541a8d9a873d1af1ec32 Mon Sep 17 00:00:00 2001 From: safehome-jdev Date: Sun, 26 May 2024 05:21:10 -0700 Subject: [PATCH] fix(server): Properly build ML predict URL (#9751) New URL via URL constructor and not string concatenation --- server/src/repositories/machine-learning.repository.ts | 8 +++++--- 1 file changed, 5 insertions(+), 3 deletions(-) diff --git a/server/src/repositories/machine-learning.repository.ts b/server/src/repositories/machine-learning.repository.ts index 3d8f0cac1e..bff22b9507 100644 --- a/server/src/repositories/machine-learning.repository.ts +++ b/server/src/repositories/machine-learning.repository.ts @@ -19,9 +19,11 @@ export class MachineLearningRepository implements IMachineLearningRepository { private async predict(url: string, input: TextModelInput | VisionModelInput, config: ModelConfig): Promise { const formData = await this.getFormData(input, config); - const res = await fetch(`${url}/predict`, { method: 'POST', body: formData }).catch((error: Error | any) => { - throw new Error(`${errorPrefix} to "${url}" failed with ${error?.cause || error}`); - }); + const res = await fetch(new URL('/predict', url), { method: 'POST', body: formData }).catch( + (error: Error | any) => { + throw new Error(`${errorPrefix} to "${url}" failed with ${error?.cause || error}`); + }, + ); if (res.status >= 400) { const modelType = config.modelType ? ` for ${config.modelType.replace('-', ' ')}` : '';