Strip SysConfiguration to fit with the standard model

develop
Matija Koželj 2 years ago
parent 35b4388b3c
commit c5c6ac4a72

@ -1,49 +1,14 @@
namespace Connected.Host.Configuration
{
internal static class SysConfiguration
{
private const string DefaultStart = "Connected.Instance.Start, Connected.Instance";
private static List<MicroServiceDescriptor> _microServices;
private static List<string> _locations;
private static string _start;
public static List<MicroServiceDescriptor> MicroServices => _microServices;
public static List<string> Locations => _locations;
public static string Start => _start;
public static void Build()
{
var cb = new ConfigurationBuilder();
var appPath = AppContext.BaseDirectory;
var segments = new Uri(appPath).Segments;
segments = segments.Select(e => e.Replace("%20", " ")).ToArray();
for (var i = 1; i <= segments.Length; i++)
{
var pathBase = Path.Combine(segments[0..i]);
var filePath = Path.Combine(pathBase, "sys.json");
namespace Connected.Host.Configuration;
if (File.Exists(filePath))
internal class SysConfiguration
{
cb.AddJsonFile(filePath, true, false);
break;
}
}
cb.AddEnvironmentVariables();
var config = cb.Build();
private const string DefaultStart = "Connected.Instance.Start, Connected.Instance";
_microServices = new List<MicroServiceDescriptor>();
_locations = new List<string>();
private string _start = DefaultStart;
config.Bind("microServices", _microServices);
config.Bind("locations", _locations);
public List<MicroServiceDescriptor> MicroServices { get; set; } = new();
_start = config["start"];
public List<string> Repositories { get; set; } = new();
if (string.IsNullOrWhiteSpace(_start))
_start = DefaultStart;
}
}
public string Start { get => _start ?? DefaultStart; set => _start = value; }
}

Loading…
Cancel
Save