CORS, Theme, Better flow and dotnet tools
This commit is contained in:
@ -1,46 +1,19 @@
|
||||
using System.Text.Json;
|
||||
using System.Text.Json.Serialization;
|
||||
|
||||
namespace Expose.MyIT.Server.Models;
|
||||
|
||||
public class AppSettings
|
||||
public record AppSettings(string BuildNumber,
|
||||
string Company,
|
||||
string ConnectionString,
|
||||
string GitCommitSeven,
|
||||
bool IsDevelopment,
|
||||
bool IsStaging,
|
||||
string MonAResource,
|
||||
string MonASite,
|
||||
string Urls,
|
||||
string WorkingDirectoryName)
|
||||
{
|
||||
|
||||
public string BuildNumber { init; get; }
|
||||
public string Company { init; get; }
|
||||
public string ConnectionString { init; get; }
|
||||
public string GitCommitSeven { init; get; }
|
||||
public bool IsDevelopment { init; get; }
|
||||
public bool IsStaging { init; get; }
|
||||
public string MonAResource { init; get; }
|
||||
public string MonASite { init; get; }
|
||||
public string URLs { init; get; }
|
||||
public string WorkingDirectoryName { init; get; }
|
||||
|
||||
[JsonConstructor]
|
||||
public AppSettings(string buildNumber,
|
||||
string company,
|
||||
string connectionString,
|
||||
string gitCommitSeven,
|
||||
bool isDevelopment,
|
||||
bool isStaging,
|
||||
string monAResource,
|
||||
string monASite,
|
||||
string urls,
|
||||
string workingDirectoryName)
|
||||
{
|
||||
BuildNumber = buildNumber;
|
||||
Company = company;
|
||||
ConnectionString = connectionString;
|
||||
GitCommitSeven = gitCommitSeven;
|
||||
IsDevelopment = isDevelopment;
|
||||
IsStaging = isStaging;
|
||||
MonAResource = monAResource;
|
||||
MonASite = monASite;
|
||||
URLs = urls;
|
||||
WorkingDirectoryName = workingDirectoryName;
|
||||
}
|
||||
|
||||
public override string ToString()
|
||||
{
|
||||
string result = JsonSerializer.Serialize(this, new JsonSerializerOptions() { WriteIndented = true });
|
||||
|
28
Server/Models/AppSettingsRepository.cs
Normal file
28
Server/Models/AppSettingsRepository.cs
Normal file
@ -0,0 +1,28 @@
|
||||
using Expose.MyIT.Shared.Models.Stateless;
|
||||
using System.Text.Json;
|
||||
|
||||
namespace Expose.MyIT.Server.Models;
|
||||
|
||||
public class AppSettingsRepository : IAppSettingsRepository
|
||||
{
|
||||
|
||||
private readonly AppSettings _AppSettings;
|
||||
|
||||
public AppSettingsRepository(AppSettings appSettings) => _AppSettings = appSettings;
|
||||
|
||||
public List<string> GetAppSettings()
|
||||
{
|
||||
List<string> results = new();
|
||||
string json = JsonSerializer.Serialize(_AppSettings);
|
||||
JsonElement jsonElement = JsonSerializer.Deserialize<JsonElement>(json);
|
||||
JsonProperty[] jsonProperties = jsonElement.EnumerateObject().ToArray();
|
||||
foreach (JsonProperty jsonProperty in jsonProperties)
|
||||
results.Add(jsonProperty.Value.ToString());
|
||||
if (!_AppSettings.IsDevelopment)
|
||||
throw new Exception("Shouldn't expose!");
|
||||
return results;
|
||||
}
|
||||
|
||||
List<string> IAppSettingsRepository.GetAppSettings() => GetAppSettings();
|
||||
|
||||
}
|
35
Server/Models/ClientSettingsRepository.cs
Normal file
35
Server/Models/ClientSettingsRepository.cs
Normal file
@ -0,0 +1,35 @@
|
||||
using Expose.MyIT.Shared.Models.Stateless;
|
||||
using System.Net;
|
||||
|
||||
namespace Expose.MyIT.Server.Models;
|
||||
|
||||
public class ClientSettingsRepository : IClientSettingsRepository
|
||||
{
|
||||
|
||||
private readonly AppSettings _AppSettings;
|
||||
|
||||
public ClientSettingsRepository(AppSettings appSettings) => _AppSettings = appSettings;
|
||||
|
||||
public List<string> GetClientSettings(IPAddress? remoteIpAddress)
|
||||
{
|
||||
List<string> results = new();
|
||||
if (remoteIpAddress is null)
|
||||
results.Add(nameof(remoteIpAddress));
|
||||
else
|
||||
results.Add(remoteIpAddress.ToString());
|
||||
if (!_AppSettings.IsDevelopment)
|
||||
throw new Exception("Shouldn't expose!");
|
||||
return results;
|
||||
}
|
||||
|
||||
List<string> IClientSettingsRepository.GetClientSettings(IPAddress? remoteIpAddress) => GetClientSettings(remoteIpAddress);
|
||||
|
||||
public string GetIpAddress(IPAddress? remoteIpAddress)
|
||||
{
|
||||
string result = remoteIpAddress is null ? string.Empty : remoteIpAddress.ToString();
|
||||
return result;
|
||||
}
|
||||
|
||||
string IClientSettingsRepository.GetIpAddress(IPAddress? remoteIpAddress) => GetIpAddress(remoteIpAddress);
|
||||
|
||||
}
|
@ -1,4 +1,4 @@
|
||||
using Expose.MyIT.Shared.Models.Methods;
|
||||
using Expose.MyIT.Shared.Models.Stateless;
|
||||
using Expose.MyIT.Shared.ViewModels;
|
||||
using Serilog.Context;
|
||||
using System.Text.Json;
|
||||
@ -12,16 +12,21 @@ public class ServiceShopOrderRepository : IServiceShopOrderRepository
|
||||
|
||||
public ServiceShopOrderRepository() => _Log = Serilog.Log.ForContext<ServiceShopOrderRepository>();
|
||||
|
||||
private static ServiceShopOrder[] GetServiceShopOrders(Shared.Models.ServiceShop? ServiceShop)
|
||||
private static ServiceShopOrder[] GetServiceShopOrders(Shared.Models.ServiceShop? serviceShop)
|
||||
{
|
||||
ServiceShopOrder[] result = Shared.Models.Stateless.Methods.IServiceShopOrder.GetServiceShopOrders(ServiceShop);
|
||||
ServiceShopOrder[] result = IServiceShopOrder.GetServiceShopOrders(serviceShop);
|
||||
return result;
|
||||
}
|
||||
|
||||
private static Shared.Models.ServiceShop? GetServiceShopOrders()
|
||||
{
|
||||
Shared.Models.ServiceShop? result;
|
||||
string jsonFile = Path.Combine(AppContext.BaseDirectory, "service-shop.json");
|
||||
string jsonFile;
|
||||
string checkDirectory = Path.Combine(AppContext.BaseDirectory, "Data/Mike");
|
||||
if (Directory.Exists(checkDirectory))
|
||||
jsonFile = Path.Combine(checkDirectory, "service-shop.json");
|
||||
else
|
||||
jsonFile = Path.Combine(AppContext.BaseDirectory, "service-shop.json");
|
||||
string json = File.ReadAllText(jsonFile);
|
||||
result = JsonSerializer.Deserialize<Shared.Models.ServiceShop>(json);
|
||||
return result;
|
||||
@ -30,12 +35,12 @@ public class ServiceShopOrderRepository : IServiceShopOrderRepository
|
||||
async Task<ServiceShopOrder[]> IServiceShopOrderRepository.GetAllServiceShopOrders()
|
||||
{
|
||||
ServiceShopOrder[] results;
|
||||
string? methodName = Shared.Models.Stateless.Methods.IMethodName.GetActualAsyncMethodName();
|
||||
string? methodName = IMethodName.GetActualAsyncMethodName();
|
||||
using (LogContext.PushProperty("MethodName", methodName))
|
||||
{
|
||||
_Log.Debug("() => ...");
|
||||
Shared.Models.ServiceShop? ServiceShop = await Task.Run(GetServiceShopOrders);
|
||||
results = GetServiceShopOrders(ServiceShop);
|
||||
Shared.Models.ServiceShop? serviceShop = await Task.Run(GetServiceShopOrders);
|
||||
results = GetServiceShopOrders(serviceShop);
|
||||
}
|
||||
return results.ToArray();
|
||||
}
|
||||
@ -43,8 +48,8 @@ public class ServiceShopOrderRepository : IServiceShopOrderRepository
|
||||
async Task<ServiceShopOrder[]> IServiceShopOrderRepository.GetServiceShopOrders(string id)
|
||||
{
|
||||
ServiceShopOrder[] results;
|
||||
Shared.Models.ServiceShop? ServiceShop = await Task.Run(GetServiceShopOrders);
|
||||
results = GetServiceShopOrders(ServiceShop).Where(l => l.Id == id).ToArray();
|
||||
Shared.Models.ServiceShop? serviceShop = await Task.Run(GetServiceShopOrders);
|
||||
results = GetServiceShopOrders(serviceShop).Where(l => l.Id == id).ToArray();
|
||||
return results;
|
||||
}
|
||||
|
||||
|
@ -1,4 +1,4 @@
|
||||
using Expose.MyIT.Shared.Models.Methods;
|
||||
using Expose.MyIT.Shared.Models.Stateless;
|
||||
using Expose.MyIT.Shared.ViewModels;
|
||||
using Serilog.Context;
|
||||
using System.Text.Json;
|
||||
@ -12,29 +12,34 @@ public class SsaOrderRepository : ISsaOrderRepository
|
||||
|
||||
public SsaOrderRepository() => _Log = Serilog.Log.ForContext<SsaOrderRepository>();
|
||||
|
||||
private static SsaOrder[] GetSsaOrders(Shared.Models.SSA? ssa)
|
||||
private static SsaOrder[] GetSsaOrders(Shared.Models.Ssa? ssa)
|
||||
{
|
||||
SsaOrder[] result = Shared.Models.Stateless.Methods.ISsaOrder.GetSsaOrders(ssa);
|
||||
SsaOrder[] result = ISsaOrder.GetSsaOrders(ssa);
|
||||
return result;
|
||||
}
|
||||
|
||||
private static Shared.Models.SSA? GetSsaOrders()
|
||||
private static Shared.Models.Ssa? GetSsaOrders()
|
||||
{
|
||||
Shared.Models.SSA? result;
|
||||
string jsonFile = Path.Combine(AppContext.BaseDirectory, "ssa.json");
|
||||
Shared.Models.Ssa? result;
|
||||
string jsonFile;
|
||||
string checkDirectory = Path.Combine(AppContext.BaseDirectory, "Data/Mike");
|
||||
if (Directory.Exists(checkDirectory))
|
||||
jsonFile = Path.Combine(checkDirectory, "ssa.json");
|
||||
else
|
||||
jsonFile = Path.Combine(AppContext.BaseDirectory, "ssa.json");
|
||||
string json = File.ReadAllText(jsonFile);
|
||||
result = JsonSerializer.Deserialize<Shared.Models.SSA>(json);
|
||||
result = JsonSerializer.Deserialize<Shared.Models.Ssa>(json);
|
||||
return result;
|
||||
}
|
||||
|
||||
async Task<SsaOrder[]> ISsaOrderRepository.GetAllSsaOrders()
|
||||
{
|
||||
SsaOrder[] results;
|
||||
string? methodName = Shared.Models.Stateless.Methods.IMethodName.GetActualAsyncMethodName();
|
||||
string? methodName = IMethodName.GetActualAsyncMethodName();
|
||||
using (LogContext.PushProperty("MethodName", methodName))
|
||||
{
|
||||
_Log.Debug("() => ...");
|
||||
Shared.Models.SSA? ssa = await Task.Run(GetSsaOrders);
|
||||
Shared.Models.Ssa? ssa = await Task.Run(GetSsaOrders);
|
||||
results = GetSsaOrders(ssa);
|
||||
}
|
||||
return results.ToArray();
|
||||
@ -43,7 +48,7 @@ public class SsaOrderRepository : ISsaOrderRepository
|
||||
async Task<SsaOrder[]> ISsaOrderRepository.GetSsaOrders(string id)
|
||||
{
|
||||
SsaOrder[] results;
|
||||
Shared.Models.SSA? ssa = await Task.Run(GetSsaOrders);
|
||||
Shared.Models.Ssa? ssa = await Task.Run(GetSsaOrders);
|
||||
results = GetSsaOrders(ssa).Where(l => l.Id == id).ToArray();
|
||||
return results;
|
||||
}
|
||||
|
Reference in New Issue
Block a user