online_security_project/server/Data.cs

64 lines
1.8 KiB
C#
Raw Normal View History

2024-12-27 14:47:39 +02:00
using System;
using System.Collections.Generic;
using System.Security.Cryptography;
namespace server;
public class Data
{
public Dictionary<string, RSA> Keys { set; get; } = [];
public Dictionary<string, Queue<byte[]>> Messages { set; get; } = [];
2024-12-27 14:47:39 +02:00
public RSA? GetKey(string Phone)
{
return Keys.TryGetValue(Phone, out RSA? value) ? value : null;
}
2024-12-27 14:47:39 +02:00
public List<byte[]>? GetMessages(string Phone, int limit = -1)
{
// Check we have a RSA key for the phone and get the messages
2024-12-27 14:47:39 +02:00
if (!Keys.ContainsKey(Phone)) { return null; }
if (Messages.TryGetValue(Phone, out Queue<byte[]>? value))
{
List<byte[]> msgs = new(limit == -1 ? value.Count : Math.Min(value.Count, limit));
int count = 0;
while (count != limit && value.TryDequeue(out byte[]? m))
{
count += 1;
msgs.Add(m);
}
return msgs;
}
2024-12-27 14:47:39 +02:00
else
{
2025-01-07 18:40:03 +02:00
// generate a new queue because one doesnt already exists
Messages[Phone] = new Queue<byte[]>();
2024-12-27 14:47:39 +02:00
return []; // no messages were in the list so no reason to attempt to send any message
}
}
2024-12-27 14:47:39 +02:00
public bool AddMessage(string Phone, byte[] Message)
{
if (Keys.ContainsKey(Phone))
{
if (Messages.TryGetValue(Phone, out var value))
{
value.Enqueue(Message);
}
else
{
Messages[Phone] = new Queue<byte[]>([Message]);
}
return true;
}
else
{
return false;
}
}
2024-12-27 14:47:39 +02:00
public bool PeekMessages(string Phone)
{
return Messages.TryGetValue(Phone, out Queue<byte[]>? value) && value.TryPeek(out var _);
}
}