From 43cea834bf36656b830e6f0c8d8da23f0da34c25 Mon Sep 17 00:00:00 2001 From: Alfred-Mutai Date: Thu, 6 Jun 2024 11:11:41 +0300 Subject: [PATCH] POC-745: --- app/facility-mappings/registers.js | 20 ++++++++++++++++++ app/routes/registers.route.js | 34 ++++++++++++++++++++++++++++++ 2 files changed, 54 insertions(+) create mode 100644 app/facility-mappings/registers.js create mode 100644 app/routes/registers.route.js diff --git a/app/facility-mappings/registers.js b/app/facility-mappings/registers.js new file mode 100644 index 000000000..f4cd52ebd --- /dev/null +++ b/app/facility-mappings/registers.js @@ -0,0 +1,20 @@ +var db = require('../../etl-db'); + +var defs = { + getPrEPRegisterData: (params) => { + return new Promise((resolve, reject) => { + let queryParts = {}; + let sql = + 'SELECT l.name as location_name, fps.encounter_id, pi.identifier AS PrEP_Number, pi2.identifier AS National_ID, pi3.identifier AS NUPI, fps.encounter_datetime AS Date_Of_Visit, EXTRACT(YEAR FROM fps.encounter_datetime) - EXTRACT(YEAR FROM fps.birthdate) - CASE WHEN (EXTRACT(MONTH FROM fps.encounter_datetime) < EXTRACT(MONTH FROM fps.birthdate)) OR (EXTRACT(MONTH FROM fps.encounter_datetime) = EXTRACT(MONTH FROM fps.birthdate) AND EXTRACT(DAY FROM fps.encounter_datetime) < EXTRACT(DAY FROM fps.birthdate)) THEN 1 ELSE 0 END Age, fps.gender AS Sex, fps.population_type, NULL AS client_prep_status, NULL AS prep_method, CASE WHEN COALESCE(fps.hiv_rapid_test_result) = 664 THEN "N" WHEN COALESCE(fps.hiv_rapid_test_result) = 703 THEN "P" END AS HIV_result, NULL AS with_STI, COALESCE(fps.initiation_reason, fps.discontinued_reason) AS remarks FROM etl.flat_prep_summary_v1_1 fps LEFT JOIN amrs.location l ON l.location_id = fps.location_id LEFT JOIN amrs.patient_identifier pi ON fps.person_id = pi.patient_id AND pi.identifier_type = 44 LEFT JOIN amrs.patient_identifier pi2 ON fps.person_id = pi2.patient_id AND pi2.identifier_type = 5 LEFT JOIN amrs.patient_identifier pi3 ON fps.person_id = pi3.patient_id AND pi3.identifier_type = 45 WHERE DATE(fps.encounter_datetime)= "2024-01-02" AND fps.location_id in (1,13,14)'; + queryParts = { + sql: sql + }; + return db.queryServer(queryParts, function (result) { + result.sql = sql; + resolve(result.result); + }); + }); + } +}; + +module.exports = defs; diff --git a/app/routes/registers.route.js b/app/routes/registers.route.js new file mode 100644 index 000000000..1b90f2b06 --- /dev/null +++ b/app/routes/registers.route.js @@ -0,0 +1,34 @@ +var authorizer = require('../../authorization/etl-authorizer'); +var privileges = authorizer.getAllPrivileges(); +var facilitymappings = require('../facility-mappings/registers'); + +const routes = [ + { + method: 'GET', + path: '/etl/prepregisterdata', + config: { + plugins: {}, + handler: function (request, reply) { + facilitymappings + .getPrEPRegisterData(request.query) + .then((result) => { + reply(result); + }) + .catch((error) => { + reply(error); + }); + }, + description: 'List of facilities with MFL code', + notes: 'Returns facilities list', + tags: ['api'], + validate: { + options: { + allowUnknown: true + }, + params: {} + } + } + } +]; + +exports.routes = (server) => server.route(routes);