From f0c14fb4ecca121db4ce151caf9d7c4005bfd769 Mon Sep 17 00:00:00 2001 From: martin-nhs Date: Fri, 10 May 2024 10:05:19 +0100 Subject: [PATCH 1/3] [PRMT-4832] Added additional logging to sds-fhir-client.js --- src/services/fhir/sds-fhir-client.js | 31 ++++++++++++++++++---------- 1 file changed, 20 insertions(+), 11 deletions(-) diff --git a/src/services/fhir/sds-fhir-client.js b/src/services/fhir/sds-fhir-client.js index dd5e5291..42ef4f4a 100644 --- a/src/services/fhir/sds-fhir-client.js +++ b/src/services/fhir/sds-fhir-client.js @@ -6,17 +6,26 @@ export const getPracticeAsid = async (odsCode, serviceId) => { const { sdsFhirUrl, sdsFhirApiKey } = initializeConfig(); logInfo(`Getting ASID via FHIR for ODS code ${odsCode}`); try { - const response = await axios.get(`${sdsFhirUrl}/Device`, { - params: { - organization: `https://fhir.nhs.uk/Id/ods-organization-code|${odsCode}`, - identifier: `https://fhir.nhs.uk/Id/nhsServiceInteractionId|${serviceId}` - }, - headers: { - apiKey: sdsFhirApiKey - } - }); - - const entries = response.data.entry; + const entries = axios + .get(`${sdsFhirUrl}/Device`, { + params: { + organization: `https://fhir.nhs.uk/Id/ods-organization-code|${odsCode}`, + identifier: `https://fhir.nhs.uk/Id/nhsServiceInteractionId|${serviceId}` + }, + headers: { + apiKey: sdsFhirApiKey + } + }) + .then(response => response.data.entry) + .catch(error => { + logError( + `Error: Request failed with non-2xx status code\n + Response body: ${error.response.data}\n + HTTP Status code: ${error.response.status}` + ); + + throw error; + }); if (entries.length === 0) { throw new Error(`No ASID entries found for ODS code ${odsCode}`); From 560a3bff06181c8741226bf8da221a76d4d7510a Mon Sep 17 00:00:00 2001 From: martin-nhs Date: Fri, 10 May 2024 10:29:23 +0100 Subject: [PATCH 2/3] [PRMT-4832] New implementation approach. --- src/services/fhir/sds-fhir-client.js | 39 ++++++++++++++-------------- 1 file changed, 19 insertions(+), 20 deletions(-) diff --git a/src/services/fhir/sds-fhir-client.js b/src/services/fhir/sds-fhir-client.js index 42ef4f4a..73d08fe0 100644 --- a/src/services/fhir/sds-fhir-client.js +++ b/src/services/fhir/sds-fhir-client.js @@ -6,26 +6,17 @@ export const getPracticeAsid = async (odsCode, serviceId) => { const { sdsFhirUrl, sdsFhirApiKey } = initializeConfig(); logInfo(`Getting ASID via FHIR for ODS code ${odsCode}`); try { - const entries = axios - .get(`${sdsFhirUrl}/Device`, { - params: { - organization: `https://fhir.nhs.uk/Id/ods-organization-code|${odsCode}`, - identifier: `https://fhir.nhs.uk/Id/nhsServiceInteractionId|${serviceId}` - }, - headers: { - apiKey: sdsFhirApiKey - } - }) - .then(response => response.data.entry) - .catch(error => { - logError( - `Error: Request failed with non-2xx status code\n - Response body: ${error.response.data}\n - HTTP Status code: ${error.response.status}` - ); - - throw error; - }); + const response = await axios.get(`${sdsFhirUrl}/Device`, { + params: { + organization: `https://fhir.nhs.uk/Id/ods-organization-code|${odsCode}`, + identifier: `https://fhir.nhs.uk/Id/nhsServiceInteractionId|${serviceId}` + }, + headers: { + apiKey: sdsFhirApiKey + } + }); + + const entries = response.data.entry; if (entries.length === 0) { throw new Error(`No ASID entries found for ODS code ${odsCode}`); @@ -52,6 +43,14 @@ export const getPracticeAsid = async (odsCode, serviceId) => { logInfo(`Successfully retrieved ASID: ${asidCode} via FHIR for ODS code ${odsCode}`); return asidCode; } catch (err) { + if (err.response) { + console.log( + `Error: Request failed with non-2xx status code\n + Response body: ${err.response.data}\n + HTTP Status code: ${err.response.status}` + ); + } + logError(`Failed to retrieve ASID from FHIR for ODS Code: ${odsCode}`, err); throw err; } From d8ac4faf55fcf54148854272b5b930edc7a8f255 Mon Sep 17 00:00:00 2001 From: martin-nhs Date: Fri, 10 May 2024 10:29:59 +0100 Subject: [PATCH 3/3] [PRMT-4832] New implementation approach. --- src/services/fhir/sds-fhir-client.js | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/src/services/fhir/sds-fhir-client.js b/src/services/fhir/sds-fhir-client.js index 73d08fe0..049e50f9 100644 --- a/src/services/fhir/sds-fhir-client.js +++ b/src/services/fhir/sds-fhir-client.js @@ -43,15 +43,15 @@ export const getPracticeAsid = async (odsCode, serviceId) => { logInfo(`Successfully retrieved ASID: ${asidCode} via FHIR for ODS code ${odsCode}`); return asidCode; } catch (err) { + logError(`Failed to retrieve ASID from FHIR for ODS Code: ${odsCode}`, err); if (err.response) { - console.log( + logError( `Error: Request failed with non-2xx status code\n Response body: ${err.response.data}\n HTTP Status code: ${err.response.status}` ); } - logError(`Failed to retrieve ASID from FHIR for ODS Code: ${odsCode}`, err); throw err; } };