continuity/Server/ChannelSession.cs

70 lines
2.1 KiB
C#
Raw Normal View History

2023-10-12 07:15:34 +00:00
namespace Server;
using System.Security.Cryptography;
2023-08-10 06:45:51 +00:00
using System.Text;
using MassTransit.Mediator;
using Microsoft.Extensions.Logging;
using NetCoreServer;
public class ChannelSession : TcpSession
{
private static readonly byte[] Key = new byte[] { 1, 2, 3, 4, 5, 6, 7, 8, 9, 1, 2, 3, 4, 5, 6, 7 }
.Reverse().ToArray();
private static readonly byte[] Iv = new byte[]
2023-08-11 09:31:30 +00:00
{
0xfe, 220, 0xba, 0x98, 0x76, 0x54, 50, 0x10, 15, 30, 0x2d, 60, 0x4b, 90, 0x69, 120
}.Reverse().ToArray();
2023-08-10 06:45:51 +00:00
private readonly ICryptoTransform decryptor;
private readonly ICryptoTransform encryptor;
private readonly ILogger<ChannelSession> logger;
private readonly IMediator mediator;
2023-08-10 06:45:51 +00:00
public ChannelSession(TcpServer server, IMediator mediator, ILogger<ChannelSession> logger) : base(server)
{
this.mediator = mediator;
this.logger = logger;
2023-08-10 06:45:51 +00:00
var aes = Aes.Create();
aes.Key = Key;
aes.IV = Iv;
2023-08-10 06:45:51 +00:00
aes.Padding = PaddingMode.None;
2023-10-12 07:15:34 +00:00
#pragma warning disable SEC0026
2023-08-10 06:45:51 +00:00
aes.Mode = CipherMode.ECB;
2023-10-12 07:15:34 +00:00
#pragma warning restore SEC0026
2023-08-10 06:45:51 +00:00
this.decryptor = aes.CreateDecryptor(aes.Key, aes.IV);
this.encryptor = aes.CreateEncryptor(aes.Key, aes.IV);
2023-08-10 06:45:51 +00:00
}
protected override void OnReceived(byte[] buffer, long offset, long size)
{
try
{
using (var ms = new MemoryStream(Decrypt(buffer)))
using (var cs = new CryptoStream(ms, this.decryptor, CryptoStreamMode.Read))
2023-08-10 06:45:51 +00:00
{
cs.Read(buffer);
}
base.OnReceived(buffer, offset, size);
}
catch (CryptographicException ex)
{
this.logger.LogError("An error has occured while decrypting: {ErrorMessage}", ex.Message);
this.logger.LogError("Default buffer message: {Message}", Encoding.ASCII.GetString(buffer));
2023-08-10 06:45:51 +00:00
}
}
private static byte[] Decrypt(byte[] buffer)
2023-08-10 06:45:51 +00:00
{
2023-08-11 09:31:30 +00:00
for (var i = 0; i < buffer.Length; ++i)
2023-08-10 06:45:51 +00:00
{
buffer[i] = (byte)(buffer[i] ^ i ^ (3 * (0xFE - i)));
}
return buffer;
}
2023-08-11 09:31:30 +00:00
}