* Moved encryption algorithms into a folder * Sorted networking into separate files Additions: * Created Elliptic Curve encryption implementation * Generalized the key exchange implementation - Implemented Diffie-Hellman key exchange - Implemented Elliptic Curve Diffie-Hellman key exchange * Started implementing binary data compressor Changes: * Changed NetClient and NetServer to use IKeyExchange for initial AES key exchange instead of RSA (for optimization) * Adapted TextView implementation to properly support optional borders * Fed InputView issue caused due to border rendering change * Fixed and simplified Rectangle computations * Fixed errant naming in Session layout file * Fixed errant i18n naming in Session layout file * Fixed resize background rendering issue in ConsoleController * Fully implemented ListView (needs testing) * Updated BankInteractor and server to use ECDH-E with Curve25519 Removals: * Removed identity verification from NetClient (identities checks should be performed as a layer on top of NetClient/NetServer, not as part of it)
30 lines
974 B
C#
30 lines
974 B
C#
using System;
|
|
using System.Collections.Generic;
|
|
using System.Linq;
|
|
using System.Text;
|
|
using System.Threading.Tasks;
|
|
using Tofvesson.Crypto;
|
|
|
|
namespace Common
|
|
{
|
|
// Helper methods. WithHeader() should really just be in Support.cs
|
|
public static class NetSupport
|
|
{
|
|
public static byte[] WithHeader(string message) => WithHeader(Encoding.UTF8.GetBytes(message));
|
|
public static byte[] WithHeader(byte[] message)
|
|
{
|
|
byte[] nmsg = new byte[message.Length + 4];
|
|
Support.WriteToArray(nmsg, message.Length, 0);
|
|
Array.Copy(message, 0, nmsg, 4, message.Length);
|
|
return nmsg;
|
|
}
|
|
|
|
public static byte[] FromHeaded(byte[] msg, int offset) => msg.SubArray(offset + 4, offset + 4 + Support.ReadInt(msg, offset));
|
|
|
|
internal static void DoStateCheck(bool state, bool target)
|
|
{
|
|
if (state != target) throw new InvalidOperationException("Bad state!");
|
|
}
|
|
}
|
|
}
|