Syncshells (#11)
* some groups stuff * further groups rework * fixes for pause changes * adjsut timeout interval * fixes and namespace change to file scoped * more fixes * further implement groups * fix change group ownership * add some more stuff for groups * more fixes and additions * some fixes based on analyzers, add shard info to ui * add discord command, cleanup * fix regex * add group migration and deletion on user deletion * add api method for client to check health of connection * adjust regex for vanity * fixes for server and bot * fixes some string comparison in linq queries * fixes group leave and sets alias to null * fix syntax in changeownership * add better logging, fixes for group leaving * fixes for group leave Co-authored-by: Stanley Dimant <root.darkarchon@outlook.com>
This commit is contained in:
		| @@ -1,4 +1,5 @@ | ||||
| using System; | ||||
| using System.Linq; | ||||
| using System.Threading; | ||||
| using System.Threading.Tasks; | ||||
| using MareSynchronos.API; | ||||
| @@ -7,6 +8,7 @@ using MareSynchronosShared.Data; | ||||
| using MareSynchronosShared.Metrics; | ||||
| using MareSynchronosShared.Services; | ||||
| using Microsoft.AspNetCore.SignalR; | ||||
| using Microsoft.Extensions.Configuration; | ||||
| using Microsoft.Extensions.DependencyInjection; | ||||
| using Microsoft.Extensions.Hosting; | ||||
| using Microsoft.Extensions.Logging; | ||||
| @@ -16,16 +18,19 @@ namespace MareSynchronosServer.Services; | ||||
| public class SystemInfoService : IHostedService, IDisposable | ||||
| { | ||||
|     private readonly MareMetrics _mareMetrics; | ||||
|     private readonly IClientIdentificationService clientIdentService; | ||||
|     private readonly IServiceProvider _services; | ||||
|     private readonly IClientIdentificationService _clientIdentService; | ||||
|     private readonly ILogger<SystemInfoService> _logger; | ||||
|     private readonly IHubContext<MareHub> _hubContext; | ||||
|     private Timer _timer; | ||||
|     private string _shardName; | ||||
|     public SystemInfoDto SystemInfoDto { get; private set; } = new(); | ||||
|  | ||||
|     public SystemInfoService(MareMetrics mareMetrics, IClientIdentificationService clientIdentService, ILogger<SystemInfoService> logger, IHubContext<MareHub> hubContext) | ||||
|     public SystemInfoService(MareMetrics mareMetrics, IConfiguration configuration, IServiceProvider services, IClientIdentificationService clientIdentService, ILogger<SystemInfoService> logger, IHubContext<MareHub> hubContext) | ||||
|     { | ||||
|         _mareMetrics = mareMetrics; | ||||
|         this.clientIdentService = clientIdentService; | ||||
|         _services = services; | ||||
|         _clientIdentService = clientIdentService; | ||||
|         _logger = logger; | ||||
|         _hubContext = hubContext; | ||||
|     } | ||||
| @@ -42,27 +47,28 @@ public class SystemInfoService : IHostedService, IDisposable | ||||
|     private void PushSystemInfo(object state) | ||||
|     { | ||||
|         ThreadPool.GetAvailableThreads(out int workerThreads, out int ioThreads); | ||||
|         _logger.LogInformation("ThreadPool: {workerThreads} workers available, {ioThreads} IO workers available", workerThreads, ioThreads); | ||||
|  | ||||
|         _mareMetrics.SetGaugeTo(MetricsAPI.GaugeAvailableWorkerThreads, workerThreads); | ||||
|         _mareMetrics.SetGaugeTo(MetricsAPI.GaugeAvailableIOWorkerThreads, ioThreads); | ||||
|  | ||||
|  | ||||
|         var secondaryServer = Environment.GetEnvironmentVariable("SECONDARY_SERVER"); | ||||
|         if (string.IsNullOrEmpty(secondaryServer) || secondaryServer == "0") | ||||
|         if (string.IsNullOrEmpty(secondaryServer) || string.Equals(secondaryServer, "0", StringComparison.Ordinal)) | ||||
|         { | ||||
|             SystemInfoDto = new SystemInfoDto() | ||||
|             { | ||||
|                 CacheUsage = 0, | ||||
|                 CpuUsage = 0, | ||||
|                 RAMUsage = 0, | ||||
|                 NetworkIn = 0, | ||||
|                 NetworkOut = 0, | ||||
|                 OnlineUsers = clientIdentService.GetOnlineUsers(), | ||||
|                 UploadedFiles = 0 | ||||
|                 OnlineUsers = _clientIdentService.GetOnlineUsers().Result, | ||||
|             }; | ||||
|  | ||||
|             _hubContext.Clients.All.SendAsync(Api.OnUpdateSystemInfo, SystemInfoDto); | ||||
|  | ||||
|             using var scope = _services.CreateScope(); | ||||
|             using var db = scope.ServiceProvider.GetService<MareDbContext>()!; | ||||
|  | ||||
|             _mareMetrics.SetGaugeTo(MetricsAPI.GaugePairs, db.ClientPairs.Count()); | ||||
|             _mareMetrics.SetGaugeTo(MetricsAPI.GaugePairsPaused, db.ClientPairs.Count(p => p.IsPaused)); | ||||
|             _mareMetrics.SetGaugeTo(MetricsAPI.GaugeGroups, db.Groups.Count()); | ||||
|             _mareMetrics.SetGaugeTo(MetricsAPI.GaugeGroupPairs, db.GroupPairs.Count()); | ||||
|             _mareMetrics.SetGaugeTo(MetricsAPI.GaugeGroupPairsPaused, db.GroupPairs.Count(p => p.IsPaused)); | ||||
|         } | ||||
|     } | ||||
|  | ||||
|   | ||||
		Reference in New Issue
	
	Block a user
	 rootdarkarchon
					rootdarkarchon