-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathUtils.cs
105 lines (89 loc) · 4.03 KB
/
Utils.cs
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
/* unified/ban - Management and protection systems
© fabricators SRL, https://fabricators.ltd , https://unifiedban.solutions
This program is free software: you can redistribute it and/or modify
it under the terms of the GNU Affero General Public License with our addition
to Section 7 as published in unified/ban's the GitHub repository.
This program is distributed in the hope that it will be useful,
but WITHOUT ANY WARRANTY; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
GNU Affero General Public License for more details.
You should have received a copy of the GNU Affero General Public License and the
additional terms along with this program.
If not, see <https://docs.fabricators.ltd/docs/licenses/unifiedban>.
For more information, see Licensing FAQ:
https://docs.fabricators.ltd/docs/licenses/faq */
using System;
using System.Linq;
using System.Reflection;
using Unifiedban.Next.Common;
using Unifiedban.Next.Models.Log;
namespace Unifiedban.Next.Terminal.Telegram;
internal class Utils
{
private static readonly BusinessLogic.Log.InstanceLogic _instanceLogic = new();
private static readonly BusinessLogic.ModuleLogic _moduleLogic = new();
internal static void RegisterInstance()
{
var newInstance = new Instance()
{
ModuleId = AppDomain.CurrentDomain.FriendlyName,
Version = Assembly.GetExecutingAssembly().GetName().Version?.ToString() ?? "NoVersion",
Start = DateTime.UtcNow,
Status = Enums.States.Startup
};
var registered = _instanceLogic.Add(newInstance);
if (registered.StatusCode != 200)
{
Common.Utils.WriteLine("***************************************", 4);
Common.Utils.WriteLine("Error registering instance.", 4);
Common.Utils.WriteLine(registered.StatusDescription, 4);
Environment.Exit(0);
}
CacheData.Instance = registered.Payload;
Common.Utils.WriteLine($"== InstanceId {CacheData.Instance?.InstanceId} ==");
}
internal static void DeregisterInstance()
{
if (CacheData.Instance is null)
{
Common.Utils.WriteLine("Trying to deregister instance but is null", 3);
return;
}
CacheData.Instance.Stop = DateTime.UtcNow;
CacheData.Instance.Status = Enums.States.Stopped;
var updated = _instanceLogic.Update(CacheData.Instance!);
if (updated.StatusCode == 200) return;
Common.Utils.WriteLine("***************************************", 3);
Common.Utils.WriteLine("Error deregistering instance.", 3);
Common.Utils.WriteLine(updated.StatusDescription, 3);
}
internal static void SetInstanceStatus(Enums.States state)
{
if (CacheData.Instance is null)
{
Common.Utils.WriteLine("Trying to set instance but is null", 3);
return;
}
CacheData.Instance.Status = state;
var updated = _instanceLogic.Update(CacheData.Instance!);
if (updated.StatusCode == 0) return;
}
internal static void GetModulesQueues()
{
Common.Utils.WriteLine("Getting modules queues");
var modules = _moduleLogic.GetModules().Payload;
// modules are already ordered by priority
var joinModule = modules.FirstOrDefault(x => x.MessageCategory == Enums.QueueMessageCategories.MemberJoin);
if (joinModule is not null)
{
CacheData.MemberJoinQueue = (joinModule.Exchange, joinModule.RoutingKey);
Common.Utils.WriteLine($"MemberJoinQueue ({joinModule.Exchange}, {joinModule.RoutingKey})");
}
var messageModule = modules.FirstOrDefault(x => x.MessageCategory == Enums.QueueMessageCategories.Base);
if (messageModule is not null)
{
CacheData.MessageBaseQueue = (messageModule.Exchange, messageModule.RoutingKey);
Common.Utils.WriteLine($"MessageBaseQueue ({messageModule.Exchange}, {messageModule.RoutingKey})");
}
}
}