Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Network Hip initial implementation(AIIMS) #373

Open
wants to merge 13 commits into
base: master
Choose a base branch
from
4 changes: 2 additions & 2 deletions hip-service.sln
Original file line number Diff line number Diff line change
Expand Up @@ -9,9 +9,9 @@ Project("{2150E333-8FDC-42A3-9474-1A3956D46DE8}") = "test", "test", "{C6699092-7
EndProject
Project("{FAE04EC0-301F-11D3-BF4B-00C04F79EFBC}") = "In.ProjectEKA.HipServiceTest", "test\In.ProjectEKA.HipServiceTest\In.ProjectEKA.HipServiceTest.csproj", "{B5A9C0B9-25EC-472E-B2CD-3EC5A69584F7}"
EndProject
Project("{FAE04EC0-301F-11D3-BF4B-00C04F79EFBC}") = "In.ProjectEKA.DefaultHip", "src\In.ProjectEKA.DefaultHip\In.ProjectEKA.DefaultHip.csproj", "{23976B61-FBF9-41B8-AEA2-B70AD47F00A8}"
Project("{FAE04EC0-301F-11D3-BF4B-00C04F79EFBC}") = "In.ProjectEKA.FHIRHip", "src\In.ProjectEKA.FHIRHip\In.ProjectEKA.FHIRHip.csproj", "{23976B61-FBF9-41B8-AEA2-B70AD47F00A8}"
EndProject
Project("{FAE04EC0-301F-11D3-BF4B-00C04F79EFBC}") = "In.ProjectEKA.DefaultHipTest", "test\In.ProjectEKA.DefaultHipTest\In.ProjectEKA.DefaultHipTest.csproj", "{4412373D-2E69-412A-8264-FA2806902173}"
Project("{FAE04EC0-301F-11D3-BF4B-00C04F79EFBC}") = "In.ProjectEKA.FHIRHipTest", "test\In.ProjectEKA.FHIRHipTest\In.ProjectEKA.FHIRHipTest.csproj", "{4412373D-2E69-412A-8264-FA2806902173}"
EndProject
Project("{FAE04EC0-301F-11D3-BF4B-00C04F79EFBC}") = "In.ProjectEKA.HipLibrary", "src\In.ProjectEKA.HipLibrary\In.ProjectEKA.HipLibrary.csproj", "{40B6794D-AA65-4B3D-B929-0180CA40E3D6}"
EndProject
Expand Down
127 changes: 0 additions & 127 deletions src/In.ProjectEKA.DefaultHip/DataFlow/Collect.cs

This file was deleted.

Original file line number Diff line number Diff line change
@@ -1,4 +1,4 @@
namespace In.ProjectEKA.DefaultHip.DataFlow
namespace In.ProjectEKA.FHIRHip.DataFlow
{
using System.Collections.Generic;

Expand Down
125 changes: 125 additions & 0 deletions src/In.ProjectEKA.FHIRHip/DataFlow/Collect.cs
Original file line number Diff line number Diff line change
@@ -0,0 +1,125 @@
namespace In.ProjectEKA.FHIRHip.DataFlow
{
using System;
using System.Collections.Generic;
using System.IO;
using System.Linq;
using System.Net.Http;
using System.Net.Mime;
using System.Text;
using System.Threading.Tasks;
using HipLibrary.Patient;
using HipLibrary.Patient.Model;
using Hl7.Fhir.Model;
using Hl7.Fhir.Serialization;
using Hl7.Fhir.Utility;
using Model;
using Newtonsoft.Json;
using Newtonsoft.Json.Serialization;
using Optional;
using Serilog;

public class Collect : ICollect
{
private readonly string HipSystemDataUrl;
private readonly HttpClient HttpClient;

public Collect(string hipSystemDataUrl, HttpClient httpClient)
{
HipSystemDataUrl = hipSystemDataUrl;
HttpClient = httpClient;
}

public async Task<Option<Entries>> CollectData(DataRequest dataRequest)
{
var bundles = new List<CareBundle>();
var patientData = await FindPatientsData(dataRequest).ConfigureAwait(false);
var careContextReferences = patientData.Keys.ToList();
foreach (var careContextReference in careContextReferences)
{
foreach (var result in patientData.GetOrDefault(careContextReference))
{
Log.Information($"Returning file: {result}");
var fjp = new FhirJsonParser();
bundles.Add(new CareBundle(careContextReference, fjp.Parse<Bundle>(result)));
}
}
var entries = new Entries(bundles);
return Option.Some(entries);
}

private async Task<Dictionary<string, List<string>>> FindPatientsData(DataRequest request)
{
LogDataRequest(request);

var patientReferenceNumber = request.CareContexts.First().PatientReference;
var careContexts = request.CareContexts.Select(careContext => careContext.CareContextReference).ToList();
var dataResponse = await GetPatientsData(new NetworkDataRequest(patientReferenceNumber,
careContexts,
request.DateRange,
request.HiType)).ConfigureAwait(false);
var structuredData = new Dictionary<string, List<string>>();
return dataResponse.Map(content =>
{
foreach (var result in content.Results)
{
if (structuredData.ContainsKey(result.CareContext))
{
structuredData[result.CareContext].Add(result.FHIRData);
}
else
{
structuredData.Add(result.CareContext, new List<string> {result.FHIRData});
}
}
return structuredData;
}).ValueOr(structuredData);
}

private async Task<Option<NetworkDataResponse>> GetPatientsData(NetworkDataRequest networkDataRequest)
{
try
{
var json = JsonConvert.SerializeObject(networkDataRequest, new JsonSerializerSettings
{
NullValueHandling = NullValueHandling.Ignore,
ContractResolver = new DefaultContractResolver
{
NamingStrategy = new CamelCaseNamingStrategy()
}
});
var httpRequestMessage = new HttpRequestMessage(HttpMethod.Post, new Uri($"{HipSystemDataUrl}"))
{
Content = new StringContent(json, Encoding.UTF8, MediaTypeNames.Application.Json)
};
var response = await HttpClient.SendAsync(httpRequestMessage).ConfigureAwait(false);
if (!response.IsSuccessStatusCode)
{
return Option.None<NetworkDataResponse>();
}
var responseContent = response.Content;
using var reader = new StreamReader(await responseContent.ReadAsStreamAsync());
var result = await reader.ReadToEndAsync().ConfigureAwait(false);
return Option.Some(JsonConvert.DeserializeObject<NetworkDataResponse>(result));
}
catch (Exception exception)
{
Log.Error(exception, exception.StackTrace);
return Option.None<NetworkDataResponse>();
}
}

private static void LogDataRequest(DataRequest request)
{
var ccList = JsonConvert.SerializeObject(request.CareContexts);
var requestedHiTypes = string.Join(", ", request.HiType.Select(hiType => hiType.ToString()));
Log.Information("Data request received." +
$" transactionId:{request.TransactionId} , " +
$"CareContexts:{ccList}, " +
$"HiTypes:{requestedHiTypes}," +
$" From date:{request.DateRange.From}," +
$" To date:{request.DateRange.To}, " +
$"CallbackUrl:{request.DataPushUrl}");
}
}
}
18 changes: 18 additions & 0 deletions src/In.ProjectEKA.FHIRHip/DataFlow/Model/NetworkData.cs
Original file line number Diff line number Diff line change
@@ -0,0 +1,18 @@
namespace In.ProjectEKA.FHIRHip.DataFlow.Model
{
using HipLibrary.Patient.Model;

public class NetworkData
{
public string CareContext { get; set; }
public HiType HiType { get; set; }
public string FHIRData { get; set; }

public NetworkData(string careContext, HiType hiType, string fhirData)
{
CareContext = careContext;
HiType = hiType;
FHIRData = fhirData;
}
}
}
21 changes: 21 additions & 0 deletions src/In.ProjectEKA.FHIRHip/DataFlow/Model/NetworkDataRequest.cs
Original file line number Diff line number Diff line change
@@ -0,0 +1,21 @@
namespace In.ProjectEKA.FHIRHip.DataFlow.Model
{
using System.Collections.Generic;
using HipLibrary.Patient.Model;

public class NetworkDataRequest
{
public string PatientReference { get; set; }
public IEnumerable<string> CareContexts { get; set; }
public DateRange DataRange { get; set; }
Veena-tw marked this conversation as resolved.
Show resolved Hide resolved
public IEnumerable<HiType> HiTypes { get; set; }

public NetworkDataRequest(string patientReference, IEnumerable<string> careContexts, DateRange dataRange, IEnumerable<HiType> hiTypes)
{
PatientReference = patientReference;
CareContexts = careContexts;
DataRange = dataRange;
HiTypes = hiTypes;
}
}
}
14 changes: 14 additions & 0 deletions src/In.ProjectEKA.FHIRHip/DataFlow/Model/NetworkDataResponse.cs
Original file line number Diff line number Diff line change
@@ -0,0 +1,14 @@
namespace In.ProjectEKA.FHIRHip.DataFlow.Model
{
using System.Collections.Generic;

public class NetworkDataResponse
{
public IEnumerable<NetworkData> Results { get; set; }

public NetworkDataResponse(IEnumerable<NetworkData> results)
{
Results = results;
}
}
}
Original file line number Diff line number Diff line change
@@ -1,4 +1,4 @@
namespace In.ProjectEKA.DefaultHip.Discovery
namespace In.ProjectEKA.FHIRHip.Discovery
{
using System.Linq;
using System.Threading.Tasks;
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -2,6 +2,7 @@

<PropertyGroup>
<TargetFramework>netcoreapp3.1</TargetFramework>
<RootNamespace>In.ProjectEKA.FHIRHip</RootNamespace>
</PropertyGroup>

<ItemGroup>
Expand Down
Original file line number Diff line number Diff line change
@@ -1,4 +1,4 @@
namespace In.ProjectEKA.DefaultHip.Link
namespace In.ProjectEKA.FHIRHip.Link
{
using System;
using System.Collections.Generic;
Expand Down
Original file line number Diff line number Diff line change
@@ -1,4 +1,4 @@
namespace In.ProjectEKA.DefaultHip.Patient
namespace In.ProjectEKA.FHIRHip.Patient
{
using System.Collections.Generic;
using System.IO;
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -4,5 +4,6 @@ public class DataFlowConfiguration
{
public int DataSizeLimitInMbs { get; set; }
public int DataLinkTtlInMinutes { get; set; }
public string Url { get; set; }
}
}
Original file line number Diff line number Diff line change
Expand Up @@ -40,7 +40,7 @@
<PackageReference Include="Hangfire.MemoryStorage" Version="1.7.0" />
</ItemGroup>
<ItemGroup>
<ProjectReference Include="..\In.ProjectEKA.DefaultHip\In.ProjectEKA.DefaultHip.csproj" />
<ProjectReference Include="..\In.ProjectEKA.FHIRHip\In.ProjectEKA.FHIRHip.csproj" />
<ProjectReference Include="..\In.ProjectEKA.HipLibrary\In.ProjectEKA.HipLibrary.csproj" />
</ItemGroup>

Expand Down
8 changes: 4 additions & 4 deletions src/In.ProjectEKA.HipService/Startup.cs
Original file line number Diff line number Diff line change
Expand Up @@ -13,11 +13,11 @@ namespace In.ProjectEKA.HipService
using DataFlow;
using DataFlow.Database;
using DataFlow.Encryptor;
using DefaultHip.DataFlow;
using DefaultHip.Discovery;
using DefaultHip.Link;
using Discovery;
using Discovery.Database;
using FHIRHip.DataFlow;
using FHIRHip.Discovery;
using FHIRHip.Link;
using Gateway;
using Hangfire;
using Hangfire.MemoryStorage;
Expand Down Expand Up @@ -81,7 +81,7 @@ public void ConfigureServices(IServiceCollection services)
.AddHangfire(config => { config.UseMemoryStorage(); })
.AddSingleton<IEncryptor, Encryptor>()
.AddSingleton<IPatientRepository>(new PatientRepository("demoPatients.json"))
.AddSingleton<ICollect>(new Collect("demoPatientCareContextDataMap.json"))
.AddSingleton<ICollect>(new Collect(Configuration.GetSection("dataFlow:url").Get<string>(), HttpClient))
.AddSingleton<IPatientRepository>(new PatientRepository("demoPatients.json"))
.AddRabbit(Configuration)
.Configure<OtpServiceConfiguration>(Configuration.GetSection("OtpService"))
Expand Down
Loading