2024-12-28 11:13:51 +02:00
|
|
|
using System;
|
|
|
|
using System.Collections.Generic;
|
|
|
|
using System.Security.Cryptography;
|
|
|
|
using System.Text;
|
2025-01-06 20:27:54 +02:00
|
|
|
using System.Text.Json.Serialization;
|
2024-12-28 11:13:51 +02:00
|
|
|
using lib;
|
|
|
|
|
|
|
|
namespace client;
|
|
|
|
|
|
|
|
public class Message
|
|
|
|
{
|
|
|
|
public uint Id { set; get; }
|
|
|
|
public string Sender { set; get; }
|
|
|
|
public bool IsAck { set; get; }
|
|
|
|
public string Content { set; get; }
|
2025-01-06 20:27:54 +02:00
|
|
|
[JsonIgnore]
|
2024-12-28 11:13:51 +02:00
|
|
|
public byte[] Signature { set; get; }
|
|
|
|
|
|
|
|
public Message(byte[] bytes)
|
|
|
|
{
|
|
|
|
if (bytes[0] != 0)
|
|
|
|
{
|
|
|
|
Console.WriteLine("Failed parsing message, unsupported version");
|
|
|
|
}
|
|
|
|
// skip the first byte for simplicity
|
|
|
|
bytes = bytes[1..];
|
|
|
|
Id = BitConverter.ToUInt32(bytes, 0);
|
|
|
|
Sender = Utils.BytesToNumber(bytes[4..12]);
|
|
|
|
IsAck = bytes[12] != 0;
|
2025-01-01 19:42:20 +02:00
|
|
|
Content = Encoding.UTF8.GetString(bytes[13..bytes.Length]);
|
|
|
|
Signature = [];
|
2024-12-28 11:13:51 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
public Message(uint Id, string Sender, bool IsAck, string Content)
|
|
|
|
{
|
|
|
|
this.Id = Id;
|
|
|
|
this.Sender = Sender;
|
|
|
|
this.IsAck = IsAck;
|
|
|
|
this.Content = Content;
|
|
|
|
Signature = [];
|
|
|
|
}
|
|
|
|
|
|
|
|
public void CalculateSignature(RSA key)
|
|
|
|
{
|
2025-01-01 19:42:20 +02:00
|
|
|
Signature = key.SignData(Bytes(), HashAlgorithmName.SHA256, RSASignaturePadding.Pkcs1);
|
2024-12-28 11:13:51 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
public bool IsSignatureValid(RSA key)
|
|
|
|
{
|
2025-01-01 19:42:20 +02:00
|
|
|
return key.VerifyData(Bytes(), Signature, HashAlgorithmName.SHA256, RSASignaturePadding.Pkcs1);
|
2024-12-28 11:13:51 +02:00
|
|
|
}
|
|
|
|
|
2025-01-01 19:42:20 +02:00
|
|
|
public byte[] Bytes()
|
2024-12-28 11:13:51 +02:00
|
|
|
{
|
2025-01-07 18:40:03 +02:00
|
|
|
// initialize a list
|
2024-12-28 11:13:51 +02:00
|
|
|
List<byte> msg = [];
|
2025-01-07 18:40:03 +02:00
|
|
|
// 0..4 - message id
|
2024-12-28 11:13:51 +02:00
|
|
|
msg.AddRange(BitConverter.GetBytes(Id));
|
2025-01-07 18:40:03 +02:00
|
|
|
// 4..12 - sender's phone number
|
2024-12-28 11:13:51 +02:00
|
|
|
msg.AddRange(Utils.NumberToBytes(Sender));
|
2025-01-07 18:40:03 +02:00
|
|
|
// 12 - is this message an acknowledgement or a normal message
|
2024-12-28 11:13:51 +02:00
|
|
|
msg.Add((byte)(IsAck ? 1 : 0));
|
2025-01-07 18:40:03 +02:00
|
|
|
// 13.. the message itself (should be empty for an acknowledgement)
|
2024-12-28 11:13:51 +02:00
|
|
|
msg.AddRange(Encoding.UTF8.GetBytes(Content));
|
2025-01-07 18:40:03 +02:00
|
|
|
// Turn into array, prepending the version byte
|
2024-12-28 11:13:51 +02:00
|
|
|
return [0, .. msg];
|
|
|
|
}
|
|
|
|
}
|