Recreated project with project template
This commit is contained in:
@@ -1,6 +0,0 @@
|
||||
namespace MoonlightServers.Daemon.App.Configuration;
|
||||
|
||||
public class AppConfiguration
|
||||
{
|
||||
|
||||
}
|
||||
@@ -1,109 +0,0 @@
|
||||
using System.Globalization;
|
||||
using Mono.Unix.Native;
|
||||
using MoonCore.Attributes;
|
||||
|
||||
namespace MoonlightServers.Daemon.App.Helpers;
|
||||
|
||||
[Singleton]
|
||||
public class HostHelper
|
||||
{
|
||||
public async Task<string> GetCpuModel()
|
||||
{
|
||||
var lines = await File.ReadAllLinesAsync("/proc/cpuinfo");
|
||||
|
||||
foreach (var line in lines)
|
||||
{
|
||||
if (line.StartsWith("model name"))
|
||||
return line.Split(":")[1].Trim();
|
||||
}
|
||||
|
||||
return "Unknown processor";
|
||||
}
|
||||
|
||||
public async Task<double[]> GetCpuUsage()
|
||||
{
|
||||
var linesBefore = await File.ReadAllLinesAsync("/proc/stat");
|
||||
await Task.Delay(1000); // Wait for 1 second
|
||||
var linesAfter = await File.ReadAllLinesAsync("/proc/stat");
|
||||
|
||||
var cpuDataBefore = linesBefore
|
||||
.Where(line => line.StartsWith("cpu"))
|
||||
.Select(line => line.Split([" "], StringSplitOptions.RemoveEmptyEntries).Skip(1).Select(long.Parse)
|
||||
.ToArray())
|
||||
.ToList();
|
||||
|
||||
var cpuDataAfter = linesAfter
|
||||
.Where(line => line.StartsWith("cpu"))
|
||||
.Select(line => line.Split([" "], StringSplitOptions.RemoveEmptyEntries).Skip(1).Select(long.Parse)
|
||||
.ToArray())
|
||||
.ToList();
|
||||
|
||||
var numCores = Environment.ProcessorCount;
|
||||
var cpuUsagePerCore = new double[numCores];
|
||||
|
||||
for (var i = 0; i < numCores; i++)
|
||||
{
|
||||
var beforeIdle = cpuDataBefore[i][3];
|
||||
var beforeTotal = cpuDataBefore[i].Sum();
|
||||
var afterIdle = cpuDataAfter[i][3];
|
||||
var afterTotal = cpuDataAfter[i].Sum();
|
||||
|
||||
double idleDelta = afterIdle - beforeIdle;
|
||||
double totalDelta = afterTotal - beforeTotal;
|
||||
|
||||
var usage = 100.0 * (1.0 - idleDelta / totalDelta);
|
||||
cpuUsagePerCore[i] = usage;
|
||||
}
|
||||
|
||||
return cpuUsagePerCore;
|
||||
}
|
||||
|
||||
public async Task<TimeSpan> GetUptime()
|
||||
{
|
||||
var uptimeText = await File.ReadAllTextAsync("/proc/uptime");
|
||||
var values = uptimeText.Split(" ");
|
||||
var seconds = double.Parse(values[0], CultureInfo.InvariantCulture);
|
||||
|
||||
return TimeSpan.FromSeconds(seconds);
|
||||
}
|
||||
|
||||
public async Task<ulong[]> GetMemoryDetails() // 0, total - 1, free - 2, available - 3, cached - 4, swap total - 5, swap free
|
||||
{
|
||||
var result = new ulong[6];
|
||||
|
||||
var memInfoText = await File.ReadAllLinesAsync("/proc/meminfo");
|
||||
|
||||
foreach (var line in memInfoText)
|
||||
{
|
||||
if (line.StartsWith("MemTotal:"))
|
||||
result[0] = 1024 * ulong.Parse(line.Replace("MemTotal:", "").Replace("kB", "").Trim());
|
||||
|
||||
if (line.StartsWith("MemFree:"))
|
||||
result[1] = 1024 * ulong.Parse(line.Replace("MemFree:", "").Replace("kB", "").Trim());
|
||||
|
||||
if (line.StartsWith("MemAvailable:"))
|
||||
result[2] = 1024 * ulong.Parse(line.Replace("MemAvailable:", "").Replace("kB", "").Trim());
|
||||
|
||||
if (line.StartsWith("Cached:"))
|
||||
result[3] = 1024 * ulong.Parse(line.Replace("Cached:", "").Replace("kB", "").Trim());
|
||||
|
||||
if (line.StartsWith("SwapTotal:"))
|
||||
result[4] = 1024 * ulong.Parse(line.Replace("SwapTotal:", "").Replace("kB", "").Trim());
|
||||
|
||||
if (line.StartsWith("SwapFree:"))
|
||||
result[5] = 1024 * ulong.Parse(line.Replace("SwapFree:", "").Replace("kB", "").Trim());
|
||||
}
|
||||
|
||||
return result;
|
||||
}
|
||||
|
||||
public async Task<ulong[]> GetDiskUsage() // 0, Total size - 1, Free size, - 2, Total inodes - 3, free inodes
|
||||
{
|
||||
var sysCallRes = Syscall.statvfs("/", out var buf);
|
||||
|
||||
if (sysCallRes == -1)
|
||||
return [0, 0, 0, 0];
|
||||
|
||||
return [buf.f_blocks * buf.f_frsize, buf.f_bfree * buf.f_frsize, buf.f_files, buf.f_ffree];
|
||||
}
|
||||
}
|
||||
@@ -1,47 +0,0 @@
|
||||
using Microsoft.AspNetCore.Mvc;
|
||||
using MoonlightServers.Daemon.App.Helpers;
|
||||
using MoonlightServers.DaemonShared.Http.Resources.Sys;
|
||||
|
||||
namespace MoonlightServers.Daemon.App.Http.Controllers.Sys;
|
||||
|
||||
[ApiController]
|
||||
[Route("system/info")]
|
||||
public class InfoController : Controller
|
||||
{
|
||||
private readonly HostHelper HostHelper;
|
||||
|
||||
public InfoController(HostHelper hostHelper)
|
||||
{
|
||||
HostHelper = hostHelper;
|
||||
}
|
||||
|
||||
[HttpGet]
|
||||
public async Task<ActionResult<SystemInfoResponse>> Get()
|
||||
{
|
||||
var memoryDetails = await HostHelper.GetMemoryDetails();
|
||||
var diskDetails = await HostHelper.GetDiskUsage();
|
||||
|
||||
var response = new SystemInfoResponse()
|
||||
{
|
||||
CpuModel = await HostHelper.GetCpuModel(),
|
||||
CpuUsage = await HostHelper.GetCpuUsage(),
|
||||
|
||||
Uptime = await HostHelper.GetUptime(),
|
||||
|
||||
MemoryTotal = memoryDetails[0],
|
||||
MemoryFree = memoryDetails[1],
|
||||
MemoryAvailable = memoryDetails[2],
|
||||
MemoryCached = memoryDetails[3],
|
||||
|
||||
SwapTotal = memoryDetails[4],
|
||||
SwapFree = memoryDetails[5],
|
||||
|
||||
DiskTotal = diskDetails[0],
|
||||
DiskFree = diskDetails[1],
|
||||
DiskTotalInodes = diskDetails[2],
|
||||
DiskFreeInodes = diskDetails[3]
|
||||
};
|
||||
|
||||
return Ok(response);
|
||||
}
|
||||
}
|
||||
@@ -1,29 +0,0 @@
|
||||
<Project Sdk="Microsoft.NET.Sdk.Web">
|
||||
|
||||
<PropertyGroup>
|
||||
<TargetFramework>net8.0</TargetFramework>
|
||||
<Nullable>enable</Nullable>
|
||||
<ImplicitUsings>enable</ImplicitUsings>
|
||||
</PropertyGroup>
|
||||
|
||||
<ItemGroup>
|
||||
<PackageReference Include="Microsoft.AspNetCore.OpenApi" Version="8.0.6"/>
|
||||
<PackageReference Include="MoonCore" Version="1.5.4" />
|
||||
<PackageReference Include="MoonCore.Unix" Version="1.0.0" />
|
||||
<PackageReference Include="Swashbuckle.AspNetCore" Version="6.4.0"/>
|
||||
</ItemGroup>
|
||||
|
||||
<ItemGroup>
|
||||
<ProjectReference Include="..\MoonlightServers.DaemonShared\MoonlightServers.DaemonShared.csproj" />
|
||||
</ItemGroup>
|
||||
|
||||
<ItemGroup>
|
||||
<Folder Include="App\Extensions\" />
|
||||
<Folder Include="App\Http\Middleware\" />
|
||||
<Folder Include="App\Implementations\" />
|
||||
<Folder Include="App\Interfaces\" />
|
||||
<Folder Include="App\Models\" />
|
||||
<Folder Include="App\Services\" />
|
||||
</ItemGroup>
|
||||
|
||||
</Project>
|
||||
@@ -1,34 +0,0 @@
|
||||
using MoonCore.Extensions;
|
||||
using MoonCore.Helpers;
|
||||
|
||||
var loggerFactory = new LoggerFactory();
|
||||
|
||||
var loggerProviders = LoggerBuildHelper.BuildFromConfiguration(configuration =>
|
||||
{
|
||||
configuration.Console.Enable = true;
|
||||
configuration.Console.EnableAnsiMode = true;
|
||||
|
||||
configuration.FileLogging.Enable = false;
|
||||
});
|
||||
|
||||
loggerFactory.AddProviders(loggerProviders);
|
||||
|
||||
var logger = loggerFactory.CreateLogger("Startup");
|
||||
|
||||
logger.LogInformation("Starting MoonlightServers Daemon v2.1 Galaxy"); //TODO: Versions
|
||||
|
||||
var builder = WebApplication.CreateBuilder(args);
|
||||
|
||||
builder.Logging.ClearProviders();
|
||||
builder.Logging.AddProviders(loggerProviders);
|
||||
|
||||
builder.Services.AutoAddServices<Program>();
|
||||
|
||||
builder.Services.AddHttpContextAccessor();
|
||||
builder.Services.AddControllers();
|
||||
|
||||
var app = builder.Build();
|
||||
|
||||
app.MapControllers();
|
||||
|
||||
app.Run();
|
||||
@@ -1,14 +0,0 @@
|
||||
{
|
||||
"profiles": {
|
||||
"http": {
|
||||
"commandName": "Project",
|
||||
"dotnetRunMessages": true,
|
||||
"launchBrowser": false,
|
||||
"launchUrl": "swagger",
|
||||
"applicationUrl": "http://localhost:5167",
|
||||
"environmentVariables": {
|
||||
"ASPNETCORE_ENVIRONMENT": "Development"
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
@@ -1,9 +0,0 @@
|
||||
{
|
||||
"Logging": {
|
||||
"LogLevel": {
|
||||
"Default": "Information",
|
||||
"Microsoft.AspNetCore": "Warning"
|
||||
}
|
||||
},
|
||||
"AllowedHosts": "*"
|
||||
}
|
||||
Reference in New Issue
Block a user