Files
linker/cmonitor/server/api/services/ReportClientService.cs
2023-09-20 17:57:32 +08:00

85 lines
3.3 KiB
C#

using cmonitor.server.service;
using cmonitor.server.service.messengers.command;
using cmonitor.server.service.messengers.sign;
using common.libs;
using common.libs.extends;
using System.Diagnostics;
namespace cmonitor.server.api.services
{
public sealed class ReportClientService : IClientService
{
private readonly MessengerSender messengerSender;
private readonly SignCaching signCaching;
private readonly IClientServer clientServer;
private readonly Config config;
public ReportClientService(MessengerSender messengerSender, SignCaching signCaching, IClientServer clientServer, Config config)
{
this.messengerSender = messengerSender;
this.signCaching = signCaching;
this.clientServer = clientServer;
this.config = config;
}
public bool Update(ClientServiceParamsInfo param)
{
string[] names = param.Content.DeJson<string[]>();
for (int i = 0; i < names.Length; i++)
{
bool res = signCaching.Get(names[i], out SignCacheInfo cache)
&& cache.Connected
&& cache.GetReport(config.ReportDelay)
&& Interlocked.CompareExchange(ref cache.ReportFlag, 0, 1) == 1;
if (res)
{
cache.UpdateReport();
_ = messengerSender.SendOnly(new MessageRequestWrap
{
Connection = cache.Connection,
MessengerId = (ushort)ReportMessengerIds.Update,
Timeout = 1000,
}).ContinueWith((result) =>
{
Interlocked.Exchange(ref cache.ReportFlag, 1);
});
}
}
return true;
}
public bool Ping(ClientServiceParamsInfo param)
{
string[] names = param.Content.DeJson<string[]>();
for (int i = 0; i < names.Length; i++)
{
if (signCaching.Get(names[i], out SignCacheInfo cache) && cache.Connected && Interlocked.CompareExchange(ref cache.PingFlag, 0, 1) == 1)
{
string name = names[i];
DateTime starTime = DateTime.Now;
_ = messengerSender.SendReply(new MessageRequestWrap
{
Connection = cache.Connection,
MessengerId = (ushort)ReportMessengerIds.Ping,
Payload = Helper.EmptyArray,
Timeout = 1000,
}).ContinueWith((result) =>
{
if (result.Result.Code == MessageResponeCodes.OK)
{
clientServer.Notify("/notify/report/pong", new { Name = name, Time = (int)((DateTime.Now - starTime).TotalMilliseconds) }, param.Connection);
}
else
{
clientServer.Notify("/notify/report/pong", new { Name = name, Time = -1 }, param.Connection);
}
Interlocked.Exchange(ref cache.PingFlag, 1);
});
}
}
return true;
}
}
}