添加日志
This commit is contained in:
@@ -1,5 +1,8 @@
|
|||||||
using CommonEntity;
|
using CommonEntity;
|
||||||
using CSRedis;
|
using CSRedis;
|
||||||
|
using Newtonsoft.Json;
|
||||||
|
using NLog;
|
||||||
|
using System.Net;
|
||||||
using System.Text.Json;
|
using System.Text.Json;
|
||||||
|
|
||||||
namespace BLWLogProduce.Models
|
namespace BLWLogProduce.Models
|
||||||
@@ -7,7 +10,9 @@ namespace BLWLogProduce.Models
|
|||||||
public class MyPublishRedis
|
public class MyPublishRedis
|
||||||
{
|
{
|
||||||
public static CSRedisClient? redis4;
|
public static CSRedisClient? redis4;
|
||||||
|
public static CSRedisClient? redis6;
|
||||||
|
|
||||||
|
public static Logger logger = LogManager.GetCurrentClassLogger();
|
||||||
private const string ip = "127.0.0.1";
|
private const string ip = "127.0.0.1";
|
||||||
private const string port = "6379";
|
private const string port = "6379";
|
||||||
static MyPublishRedis()
|
static MyPublishRedis()
|
||||||
@@ -16,28 +21,30 @@ namespace BLWLogProduce.Models
|
|||||||
if (!string.IsNullOrEmpty(redisHostStr))
|
if (!string.IsNullOrEmpty(redisHostStr))
|
||||||
{
|
{
|
||||||
redis4 = new CSRedisClient(redisHostStr + ",password=,defaultDatabase=4");
|
redis4 = new CSRedisClient(redisHostStr + ",password=,defaultDatabase=4");
|
||||||
string channel = "__keyevent@4__:expired";
|
redis6 = new CSRedisClient(redisHostStr + ",password=,defaultDatabase=6");
|
||||||
|
string channel = "__keyevent@6__:expired";
|
||||||
var QQQ = new ValueTuple<string, Action<CSRedisClient.SubscribeMessageEventArgs>>(channel, (msg) =>
|
var QQQ = new ValueTuple<string, Action<CSRedisClient.SubscribeMessageEventArgs>>(channel, (msg) =>
|
||||||
{
|
{
|
||||||
|
string data = msg.Body;
|
||||||
try
|
try
|
||||||
{
|
{
|
||||||
var o = JsonSerializer.Deserialize<OnOffLineData>(msg.Body);
|
var data_take =redis4.Get(data);
|
||||||
o.CurrentStatus = "off";
|
if (!string.IsNullOrEmpty(data_take))
|
||||||
string str = Newtonsoft.Json.JsonConvert.SerializeObject(o);
|
{
|
||||||
|
var o = JsonConvert.DeserializeObject<OnOffLineData>(data_take);
|
||||||
|
o.CurrentStatus = "off";
|
||||||
|
string str = Newtonsoft.Json.JsonConvert.SerializeObject(o);
|
||||||
|
|
||||||
redis4.Publish("redis-on_off_line", str);
|
redis6.Publish("redis-on_off_line", str);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
catch (Exception ex)
|
catch (Exception ex)
|
||||||
{
|
{
|
||||||
|
logger.Error("定阅出错:"+data);
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
redis4.Subscribe(QQQ);
|
redis6.Subscribe(QQQ);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
public class MyPublishRedis2
|
|
||||||
{
|
|
||||||
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -548,6 +548,10 @@ namespace BLWLogProduce.Services
|
|||||||
{
|
{
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
if (poo.cmd_word.Equals("0E")&&poo.fault_list.Count==0&&poo.device_list.Count==0)
|
||||||
|
{
|
||||||
|
return;
|
||||||
|
}
|
||||||
string TopicKey1 = KafkaKey.BLWLog4NodeJs_RCU_Action_Topic;
|
string TopicKey1 = KafkaKey.BLWLog4NodeJs_RCU_Action_Topic;
|
||||||
string DetailKey1 = poo.frame_id.ToString();
|
string DetailKey1 = poo.frame_id.ToString();
|
||||||
|
|
||||||
@@ -662,6 +666,7 @@ namespace BLWLogProduce.Services
|
|||||||
try
|
try
|
||||||
{
|
{
|
||||||
|
|
||||||
|
MyPublishRedis.redis6.Set("ChangLiang", "1", 3600); //设置过期时间1小时,离线事件靠过期事件触发
|
||||||
string body = args.Body;
|
string body = args.Body;
|
||||||
CommonEntity.OnOffLineData? usa = System.Text.Json.JsonSerializer.Deserialize<CommonEntity.OnOffLineData>(body);
|
CommonEntity.OnOffLineData? usa = System.Text.Json.JsonSerializer.Deserialize<CommonEntity.OnOffLineData>(body);
|
||||||
|
|
||||||
@@ -678,6 +683,7 @@ namespace BLWLogProduce.Services
|
|||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
string Key1 = KafkaKey.BLWLog4NodeJs_RCU_OnOffLine_Topic;
|
string Key1 = KafkaKey.BLWLog4NodeJs_RCU_OnOffLine_Topic;
|
||||||
string Key2 = usa.HostNumber;
|
string Key2 = usa.HostNumber;
|
||||||
byte[] nnn = Encoding.UTF8.GetBytes(body);
|
byte[] nnn = Encoding.UTF8.GetBytes(body);
|
||||||
@@ -790,9 +796,26 @@ namespace BLWLogProduce.Services
|
|||||||
{
|
{
|
||||||
string body = args.Body;
|
string body = args.Body;
|
||||||
NewVersionHexData? usa = System.Text.Json.JsonSerializer.Deserialize<NewVersionHexData>(body);
|
NewVersionHexData? usa = System.Text.Json.JsonSerializer.Deserialize<NewVersionHexData>(body);
|
||||||
byte[] bytes = MyMessagePacker.FastSerialize(usa);
|
|
||||||
string TopicKey = KafkaKey.BLWLog_RCU_Topic;
|
RestartIOTData rrr = new RestartIOTData()
|
||||||
string DetailKey = KafkaKey.RCUNewVersion_RestartReason;
|
{
|
||||||
|
HotelCode = usa.HotelCode,
|
||||||
|
HostNumber = usa.HostNumber,
|
||||||
|
MAC = usa.MAC,
|
||||||
|
RoomNumber = usa.RoomNumber,
|
||||||
|
EndPoint = usa.RemoteEndPoint,
|
||||||
|
CurrentStatus = usa.CurrentStatus,
|
||||||
|
CurrentTime = usa.CurrentTime,
|
||||||
|
UnixTime = Tools.GetUnixTime_MS(),
|
||||||
|
LauncherVersion= usa.LauncherVersion,
|
||||||
|
RebootReason= usa.RebootReason
|
||||||
|
};
|
||||||
|
|
||||||
|
byte[] bytes = Encoding.UTF8.GetBytes(JsonConvert.SerializeObject(rrr));
|
||||||
|
|
||||||
|
//byte[] bytes = MyMessagePacker.FastSerialize(rrr);
|
||||||
|
string TopicKey = KafkaKey.BLWLog4NodeJs_RCU_OnOffLine_Topic;
|
||||||
|
string DetailKey = usa.HotelCode;
|
||||||
var dr = await p.ProduceAsync(TopicKey, new Message<string, byte[]> { Key = DetailKey, Value = bytes });
|
var dr = await p.ProduceAsync(TopicKey, new Message<string, byte[]> { Key = DetailKey, Value = bytes });
|
||||||
}
|
}
|
||||||
catch (Exception ex)
|
catch (Exception ex)
|
||||||
@@ -956,6 +979,7 @@ namespace BLWLogProduce.Services
|
|||||||
//新版本日志
|
//新版本日志
|
||||||
CSRedisCacheHelper.redis3.Subscribe(TSLog_DingYue);
|
CSRedisCacheHelper.redis3.Subscribe(TSLog_DingYue);
|
||||||
CSRedisCacheHelper.redis3.Subscribe(TSLog_DingYue_0X36);
|
CSRedisCacheHelper.redis3.Subscribe(TSLog_DingYue_0X36);
|
||||||
|
CSRedisCacheHelper.redis3.Subscribe(DingYue11);
|
||||||
}
|
}
|
||||||
catch (Exception ex)
|
catch (Exception ex)
|
||||||
{
|
{
|
||||||
|
|||||||
@@ -396,19 +396,19 @@ namespace BLWLogServer.Services
|
|||||||
else if (k.Equals(KafkaKey.RCUNewVersion_RestartReason))
|
else if (k.Equals(KafkaKey.RCUNewVersion_RestartReason))
|
||||||
{
|
{
|
||||||
|
|
||||||
var collection = client.GetDatabase("udppackage").GetCollection<NewVersionHexData_db>("rcu_hexdata");
|
//var collection = client.GetDatabase("udppackage").GetCollection<NewVersionHexData_db>("rcu_hexdata");
|
||||||
NewVersionHexData UDPPPP = MyMessagePacker.FastDeserialize<NewVersionHexData>(v);
|
//NewVersionHexData UDPPPP = MyMessagePacker.FastDeserialize<NewVersionHexData>(v);
|
||||||
NewVersionHexData_db cv = new NewVersionHexData_db();
|
//NewVersionHexData_db cv = new NewVersionHexData_db();
|
||||||
cv.HotelCode = UDPPPP.HotelCode;
|
//cv.HotelCode = UDPPPP.HotelCode;
|
||||||
cv.HostNumber = UDPPPP.HostNumber;
|
//cv.HostNumber = UDPPPP.HostNumber;
|
||||||
cv.RoomNumber = UDPPPP.RoomNumber;
|
//cv.RoomNumber = UDPPPP.RoomNumber;
|
||||||
cv.CurrentTime = UDPPPP.CurrentTime;
|
//cv.CurrentTime = UDPPPP.CurrentTime;
|
||||||
cv.RemoteEndPoint = UDPPPP.RemoteEndPoint;
|
//cv.RemoteEndPoint = UDPPPP.RemoteEndPoint;
|
||||||
cv.CmdType = UDPPPP.CmdType;
|
//cv.CmdType = UDPPPP.CmdType;
|
||||||
cv.HexData = UDPPPP.HexData;
|
//cv.HexData = UDPPPP.HexData;
|
||||||
cv.CurrentTime = UDPPPP.CurrentTime;
|
//cv.CurrentTime = UDPPPP.CurrentTime;
|
||||||
|
|
||||||
await collection.InsertOneAsync(cv);
|
//await collection.InsertOneAsync(cv);
|
||||||
}
|
}
|
||||||
else if (k.Equals(KafkaKey.RCUNewVersion_0E))
|
else if (k.Equals(KafkaKey.RCUNewVersion_0E))
|
||||||
{
|
{
|
||||||
@@ -476,9 +476,10 @@ namespace BLWLogServer.Services
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
catch (OperationCanceledException)
|
catch (OperationCanceledException ex)
|
||||||
{
|
{
|
||||||
logger.Error("操作出错");
|
logger.Error("操作出错"+ex.Message);
|
||||||
|
logger.Error(ex.StackTrace);
|
||||||
Console.WriteLine("操作错误");
|
Console.WriteLine("操作错误");
|
||||||
}
|
}
|
||||||
catch (Exception ex)
|
catch (Exception ex)
|
||||||
|
|||||||
@@ -72,6 +72,12 @@ namespace CommonEntity
|
|||||||
public string? DeviceAddress { get; set; }
|
public string? DeviceAddress { get; set; }
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public class RestartIOTData:OnOffLineData
|
||||||
|
{
|
||||||
|
public byte[]? LauncherVersion { get; set; }
|
||||||
|
public byte[]? RebootReason { get; set; }
|
||||||
|
}
|
||||||
|
|
||||||
[GenerateSerializer()]
|
[GenerateSerializer()]
|
||||||
[MessagePackObject()]
|
[MessagePackObject()]
|
||||||
public class OnOffLineData
|
public class OnOffLineData
|
||||||
|
|||||||
@@ -31,6 +31,21 @@ namespace CommonEntity
|
|||||||
|
|
||||||
[Key(6)]
|
[Key(6)]
|
||||||
public DateTime CurrentTime { get; set; }
|
public DateTime CurrentTime { get; set; }
|
||||||
|
|
||||||
|
[Key(7)]
|
||||||
|
public string? MAC { get; set; }
|
||||||
|
|
||||||
|
[Key(8)]
|
||||||
|
public string? CurrentStatus { get; set; }
|
||||||
|
|
||||||
|
[Key(9)]
|
||||||
|
public long? UnixTime { get; set; }
|
||||||
|
|
||||||
|
[Key(10)]
|
||||||
|
public byte[]? LauncherVersion { get; set; }
|
||||||
|
|
||||||
|
[Key(11)]
|
||||||
|
public byte[]? RebootReason { get; set; }
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|||||||
@@ -35,7 +35,7 @@ namespace CommonEntity
|
|||||||
/// 心跳包
|
/// 心跳包
|
||||||
/// </summary>
|
/// </summary>
|
||||||
public static string BLWLog4NodeJs_RCU_Topic = "blwlog4Nodejs-rcu-heartbeat-topic";
|
public static string BLWLog4NodeJs_RCU_Topic = "blwlog4Nodejs-rcu-heartbeat-topic";
|
||||||
public static string BLWLog4NodeJs_RCU_OnOffLine_Topic = "blwlog4Nodejs-rcu-onoffline-topic";
|
public static string BLWLog4NodeJs_RCU_OnOffLine_Topic = "blwlog4Nodejs-rcu-onoffline-topic-0";
|
||||||
public static string BLWLog4NodeJs_RCU_Action_Topic = "blwlog4Nodejs-rcu-action-topic";
|
public static string BLWLog4NodeJs_RCU_Action_Topic = "blwlog4Nodejs-rcu-action-topic";
|
||||||
|
|
||||||
#endregion
|
#endregion
|
||||||
|
|||||||
@@ -39,34 +39,15 @@ namespace Common
|
|||||||
string channel = "__keyevent@4__:expired";
|
string channel = "__keyevent@4__:expired";
|
||||||
var QQQ = new ValueTuple<string, Action<CSRedisClient.SubscribeMessageEventArgs>>(channel, (msg) =>
|
var QQQ = new ValueTuple<string, Action<CSRedisClient.SubscribeMessageEventArgs>>(channel, (msg) =>
|
||||||
{
|
{
|
||||||
//string Key = CacheKey.UPGradeProgressBar + "_" + id;
|
|
||||||
try
|
try
|
||||||
{
|
{
|
||||||
if (!msg.Body.StartsWith("hb#"))
|
|
||||||
{
|
|
||||||
bool containsHyphen = msg.Body.Contains("-");
|
|
||||||
bool isNumeric = msg.Body.All(char.IsDigit);
|
|
||||||
if (containsHyphen == false && isNumeric)
|
|
||||||
{
|
|
||||||
//string hotelcode = Tools.HostNumberToHotelCode(msg.Body).ToString();
|
|
||||||
//OnOffLineData o = new OnOffLineData();
|
|
||||||
//o.HotelCode = hotelcode;
|
|
||||||
//o.HostNumber = msg.Body;
|
|
||||||
//o.CurrentStatus = "off";
|
|
||||||
//o.CurrentTime = DateTime.Now;
|
|
||||||
////新来的数据
|
|
||||||
//string str = Newtonsoft.Json.JsonConvert.SerializeObject(o);
|
|
||||||
//CSRedisCacheHelper.redis3.Publish("redis-on_off_line", str);
|
|
||||||
|
|
||||||
//redis4.Set(HeartBeatPrefix + "_" + msg.Body, 1, 5 * 60);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
catch (Exception ex)
|
catch (Exception ex)
|
||||||
{
|
{
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
redis.Subscribe(QQQ);
|
//redis.Subscribe(QQQ);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
/// <summary>
|
/// <summary>
|
||||||
|
|||||||
40
ConsoleApp2/GoodRedis.cs
Normal file
40
ConsoleApp2/GoodRedis.cs
Normal file
@@ -0,0 +1,40 @@
|
|||||||
|
using CSRedis;
|
||||||
|
using System;
|
||||||
|
using System.Collections.Generic;
|
||||||
|
using System.Linq;
|
||||||
|
using System.Text;
|
||||||
|
using System.Threading.Tasks;
|
||||||
|
|
||||||
|
namespace ConsoleApp2
|
||||||
|
{
|
||||||
|
public class GoodRedis
|
||||||
|
{
|
||||||
|
public static CSRedisClient? redis6;
|
||||||
|
|
||||||
|
private const string ip = "127.0.0.1";
|
||||||
|
private const string port = "6379";
|
||||||
|
static GoodRedis()
|
||||||
|
{
|
||||||
|
var redisHostStr = string.Format("{0}:{1}", ip, port);
|
||||||
|
if (!string.IsNullOrEmpty(redisHostStr))
|
||||||
|
{
|
||||||
|
redis6 = new CSRedisClient(redisHostStr + ",password=,defaultDatabase=6");
|
||||||
|
//string channel = "__keyevent@6__:expired";
|
||||||
|
string channel = "__keyevent@6__:expired";
|
||||||
|
var QQQ = new ValueTuple<string, Action<CSRedisClient.SubscribeMessageEventArgs>>(channel, (msg) =>
|
||||||
|
{
|
||||||
|
//body 是键
|
||||||
|
string data = msg.Body;
|
||||||
|
try
|
||||||
|
{
|
||||||
|
Console.WriteLine(data);
|
||||||
|
}
|
||||||
|
catch (Exception ex)
|
||||||
|
{
|
||||||
|
}
|
||||||
|
});
|
||||||
|
redis6.Subscribe(QQQ);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
@@ -5,6 +5,7 @@ using BLWData.Entity;
|
|||||||
using CommonEntity;
|
using CommonEntity;
|
||||||
using CommonTools;
|
using CommonTools;
|
||||||
using MessagePack;
|
using MessagePack;
|
||||||
|
using Newtonsoft.Json;
|
||||||
|
|
||||||
namespace ConsoleApp2
|
namespace ConsoleApp2
|
||||||
{
|
{
|
||||||
@@ -13,6 +14,10 @@ namespace ConsoleApp2
|
|||||||
static void Main(string[] args)
|
static void Main(string[] args)
|
||||||
{
|
{
|
||||||
|
|
||||||
|
GoodRedis.redis6.Set("aaa", "bbb", 10);
|
||||||
|
Console.ReadLine();
|
||||||
|
string YYY111111 = File.ReadAllText("2.txt");
|
||||||
|
var o = JsonConvert.DeserializeObject<CommonEntity.OnOffLineData>(YYY111111);
|
||||||
string afds = "hello";
|
string afds = "hello";
|
||||||
string dda = afds;
|
string dda = afds;
|
||||||
dda = "world";
|
dda = "world";
|
||||||
@@ -52,7 +57,7 @@ namespace ConsoleApp2
|
|||||||
string HOSTNUMBER = "099008" + MAC1 + MAC2;
|
string HOSTNUMBER = "099008" + MAC1 + MAC2;
|
||||||
|
|
||||||
string nnn = File.ReadAllText("1.txt");
|
string nnn = File.ReadAllText("1.txt");
|
||||||
UDPPackage? usa = JsonSerializer.Deserialize<UDPPackage>(nnn);
|
UDPPackage? usa = System.Text.Json.JsonSerializer.Deserialize<UDPPackage>(nnn);
|
||||||
AAA a = new AAA();
|
AAA a = new AAA();
|
||||||
MyClass mm = new MyClass();
|
MyClass mm = new MyClass();
|
||||||
mm.Age = 30;
|
mm.Age = 30;
|
||||||
|
|||||||
@@ -17,6 +17,7 @@ namespace Redis定阅
|
|||||||
NengHao? poo = System.Text.Json.JsonSerializer.Deserialize<NengHao>(body);
|
NengHao? poo = System.Text.Json.JsonSerializer.Deserialize<NengHao>(body);
|
||||||
}));
|
}));
|
||||||
CSRedisCacheHelper.redis.Subscribe(DingYue3);
|
CSRedisCacheHelper.redis.Subscribe(DingYue3);
|
||||||
|
Console.ReadLine();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
Binary file not shown.
Binary file not shown.
Binary file not shown.
Binary file not shown.
Binary file not shown.
Binary file not shown.
Binary file not shown.
@@ -14,7 +14,7 @@ using System.Reflection;
|
|||||||
[assembly: System.Reflection.AssemblyCompanyAttribute("Redis定阅")]
|
[assembly: System.Reflection.AssemblyCompanyAttribute("Redis定阅")]
|
||||||
[assembly: System.Reflection.AssemblyConfigurationAttribute("Debug")]
|
[assembly: System.Reflection.AssemblyConfigurationAttribute("Debug")]
|
||||||
[assembly: System.Reflection.AssemblyFileVersionAttribute("1.0.0.0")]
|
[assembly: System.Reflection.AssemblyFileVersionAttribute("1.0.0.0")]
|
||||||
[assembly: System.Reflection.AssemblyInformationalVersionAttribute("1.0.0+10bf712006c48a55355558d20b38cacc42f7879c")]
|
[assembly: System.Reflection.AssemblyInformationalVersionAttribute("1.0.0+3de5990573473ba6dad2b9f61b1d597740cd6ff2")]
|
||||||
[assembly: System.Reflection.AssemblyProductAttribute("Redis定阅")]
|
[assembly: System.Reflection.AssemblyProductAttribute("Redis定阅")]
|
||||||
[assembly: System.Reflection.AssemblyTitleAttribute("Redis定阅")]
|
[assembly: System.Reflection.AssemblyTitleAttribute("Redis定阅")]
|
||||||
[assembly: System.Reflection.AssemblyVersionAttribute("1.0.0.0")]
|
[assembly: System.Reflection.AssemblyVersionAttribute("1.0.0.0")]
|
||||||
|
|||||||
@@ -1 +1 @@
|
|||||||
5283559792cfb48abbd55d29822fde595259debf0e2dbd5145d5bb9737d31a98
|
cffca3bad22d59989963e58ffa867bb7a20c1d17663478a4cf724d50f06891d2
|
||||||
|
|||||||
Binary file not shown.
Binary file not shown.
Binary file not shown.
Binary file not shown.
Binary file not shown.
Binary file not shown.
@@ -14,7 +14,7 @@ using System.Reflection;
|
|||||||
[assembly: System.Reflection.AssemblyCompanyAttribute("Redis定阅")]
|
[assembly: System.Reflection.AssemblyCompanyAttribute("Redis定阅")]
|
||||||
[assembly: System.Reflection.AssemblyConfigurationAttribute("Release")]
|
[assembly: System.Reflection.AssemblyConfigurationAttribute("Release")]
|
||||||
[assembly: System.Reflection.AssemblyFileVersionAttribute("1.0.0.0")]
|
[assembly: System.Reflection.AssemblyFileVersionAttribute("1.0.0.0")]
|
||||||
[assembly: System.Reflection.AssemblyInformationalVersionAttribute("1.0.0+10bf712006c48a55355558d20b38cacc42f7879c")]
|
[assembly: System.Reflection.AssemblyInformationalVersionAttribute("1.0.0+3de5990573473ba6dad2b9f61b1d597740cd6ff2")]
|
||||||
[assembly: System.Reflection.AssemblyProductAttribute("Redis定阅")]
|
[assembly: System.Reflection.AssemblyProductAttribute("Redis定阅")]
|
||||||
[assembly: System.Reflection.AssemblyTitleAttribute("Redis定阅")]
|
[assembly: System.Reflection.AssemblyTitleAttribute("Redis定阅")]
|
||||||
[assembly: System.Reflection.AssemblyVersionAttribute("1.0.0.0")]
|
[assembly: System.Reflection.AssemblyVersionAttribute("1.0.0.0")]
|
||||||
|
|||||||
@@ -1 +1 @@
|
|||||||
99d430bebbce6c50f252c7cf5891f373a780ce938fba0ebed0f195265e8a331a
|
6b5070cb382d125c9ffb0bb5415855e4173eae9cf2c6bd156d0b4a3335889da7
|
||||||
|
|||||||
Binary file not shown.
Reference in New Issue
Block a user