patbef-ServiceOutside/ServiceOutside/Service/ServiceInside.cs

167 lines
6.4 KiB
C#

using ServiceShared;
using ServiceShared.Crypto;
using ServiceShared.Models.Request;
using ServiceShared.Models.Response;
namespace ServiceOutside.Service
{
public static class ServiceInside
{
/// <summary>
/// URL of ServiceInside
/// </summary>
private static string ServiceInsideURL;
/// <summary>
/// Sets the URL of ServiceInside
/// </summary>
/// <param name="serviceInsideURL">Url of ServiceInside</param>
public static void SetServiceInsideURL(string serviceInsideURL)
{
ServiceInsideURL = serviceInsideURL;
}
/// <summary>
/// Sends subscribe request to the inside service
/// </summary>
/// <param name="subscribe">Subscribe object for inside service</param>
public static void Subscribe(Subscribe subscribe)
{
try
{
KeyPair keyPair = Curve25519.GenerateKeyPair();
EncryptedRequest encryptedRequest = new EncryptedRequest("Subscribe", subscribe, ServiceInsideDeriveKey(keyPair));
ServiceShared.Https.Request.PostWithoutResponse(ServiceInsideURL, "serviceoutside", "subscribe", encryptedRequest, keyPair);
}
catch (Exception ex)
{
Log.Critical(ex, "ServiceInside.Service.ServiceInside", "Subscribe");
}
}
/// <summary>
/// Sends unsubscribe request to the inside service
/// </summary>
/// <param name="subscribe">Subscribe object for inside service</param>
public static void Unsubscribe(Subscribe subscribe)
{
try
{
KeyPair keyPair = Curve25519.GenerateKeyPair();
EncryptedRequest encryptedRequest = new EncryptedRequest("Subscribe", subscribe, ServiceInsideDeriveKey(keyPair));
ServiceShared.Https.Request.PostWithoutResponse(ServiceInsideURL, "serviceoutside", "unsubscribe", encryptedRequest, keyPair);
}
catch (Exception ex)
{
Log.Critical(ex, "ServiceInside.Service.ServiceInside", "Subscribe");
}
}
/// <summary>
/// Send DeleteDevice request to the inside service
/// </summary>
/// <param name="deleteDevice">CheckResults object, that contains pgs</param>
public static EncryptedResponse DeleteDevice(DeleteDevice deleteDevice)
{
EncryptedResponse result = null;
try
{
KeyPair keyPair = Curve25519.GenerateKeyPair();
EncryptedRequest encryptedRequest = new EncryptedRequest("DeleteDevice", deleteDevice, ServiceInsideDeriveKey(keyPair));
result = ServiceShared.Https.Request.Post<EncryptedResponse>(ServiceInsideURL, "serviceoutside", "delete_device", encryptedRequest, keyPair);
if(result != null)
{
result.Decrypt(ServiceInsideDeriveKey(keyPair));
}
}
catch (Exception ex)
{
Log.Critical(ex, "ServiceInside.Service.ServiceInside", "DeleteDevice");
}
return result;
}
/// <summary>
/// Notifies the inside service, that the results was successfully picked up by patient and can be removed from the private storage in the inside service
/// </summary>
/// <param name="checkResults">CheckResults object, that contains pgs and file checksum</param>
public static void PickedUp(CheckFileChecksum checkFileChecksum)
{
try
{
KeyPair keyPair = Curve25519.GenerateKeyPair();
EncryptedRequest encryptedRequest = new EncryptedRequest("CheckFileChecksum", checkFileChecksum, ServiceInsideDeriveKey(keyPair));
ServiceShared.Https.Request.PostWithoutResponse(ServiceInsideURL, "serviceoutside", "pickedup", encryptedRequest, keyPair);
}
catch (Exception ex)
{
Log.Critical(ex, "ServiceInside.Service.ServiceInside", "PickedUp");
}
}
/// <summary>
/// Checks if results is already available for the pgs and get as encrypted download object from the inside service
/// </summary>
/// <param name="checkResults">CheckResults object, that contains pgs</param>
/// <returns>Returns Download, that contains encrypted results</returns>
public static Download GetDownload(CheckResults checkResults)
{
Download result = null;
try
{
KeyPair keyPair = Curve25519.GenerateKeyPair();
EncryptedRequest encryptedRequest = new EncryptedRequest("CheckResults", checkResults, ServiceInsideDeriveKey(keyPair));
EncryptedResponse response = ServiceShared.Https.Request.Post<EncryptedResponse>(ServiceInsideURL, "serviceoutside", "get_download", encryptedRequest, keyPair);
if(response != null)
{
result = response.Decrypt<Download>(ServiceInsideDeriveKey(keyPair));
}
}
catch (Exception ex)
{
Log.Critical(ex, "ServiceInside.Service.ServiceInside", "GetDownload");
}
return result;
}
/// <summary>
/// Shared Derive key from inside service over (exchange controller)
/// </summary>
/// <returns></returns>
private static byte[] ServiceInsideDeriveKey(KeyPair keyPair)
{
byte[] result = null;
try
{
PublicKey publicKey = ServiceShared.Https.Request.GetPublicKey(ServiceInsideURL);
if (publicKey != null && !string.IsNullOrEmpty(publicKey.key))
{
byte[] base64Encoded = Convert.FromBase64String(publicKey.key);
result = keyPair.GetSharedKey(publicKey.key);
}
else
{
Log.Critical(new Exception("Could not get public key from the inside service"), "ServiceOutside.Service.ServiceInside", "ServiceInsideDeriveKey");
}
}
catch (Exception ex)
{
Log.Critical(ex, "ServiceInside.Service.ServiceInside", "ServiceOutsideDeriveKey");
}
return result;
}
}
}