sockscape/server/Socks/PlayerConnection.cs

62 lines
1.9 KiB
C#
Raw Normal View History

using System;
using System.Collections.Generic;
using System.Linq;
using System.Net.Sockets;
using System.Text;
using System.Threading.Tasks;
2017-06-16 21:00:01 +00:00
using Kneesocks;
2017-07-22 19:27:41 +00:00
using Glove;
using SockScape.Encryption;
2017-07-22 19:27:41 +00:00
namespace SockScape {
2017-06-06 21:13:25 +00:00
class PlayerConnection : Connection {
2017-05-12 21:05:18 +00:00
private DateTime ConnectionOpened;
2017-05-26 20:28:02 +00:00
private Key Key;
public Cipher Encryptor { get; private set; } = null;
2017-05-12 21:05:18 +00:00
protected override void OnOpen() {
ConnectionOpened = DateTime.UtcNow;
2017-05-26 20:28:02 +00:00
Key = new Key();
2017-05-25 21:08:21 +00:00
Send(Key.GenerateRequestPacket().GetBytes());
2017-05-12 21:05:18 +00:00
}
protected override void OnParse() {
if((DateTime.UtcNow - ConnectionOpened).Seconds > 60) {
Disconnect(Frame.kClosingReason.ProtocolError, "Logon request timed out.");
}
}
protected override void OnReceive(byte[] data) {
Packet packet =
Encryptor == null ? Packet.FromBytes(data)
: Packet.FromBytes(Encryptor.Parse(data));
2017-08-16 21:01:08 +00:00
if(packet == null) {
2017-05-25 21:08:21 +00:00
Disconnect(Frame.kClosingReason.ProtocolError, "Packet received was not legal.");
return;
}
switch(packet.Id) {
case Packet.kId.KeyExchange:
Key.ParseResponsePacket(packet);
if(!Key.Succeeded) {
Disconnect(Frame.kClosingReason.ProtocolError, "Could not exchange keys.");
return;
}
Encryptor = new Cipher(Key.PrivateKey);
break;
2017-05-30 21:05:02 +00:00
case Packet.kId.LoginAttempt:
break;
default:
Disconnect(Frame.kClosingReason.ProtocolError, "Packet ID could not be understood at this time.");
break;
2017-05-25 21:08:21 +00:00
}
2017-05-12 21:05:18 +00:00
Console.WriteLine(Id + " says " + data.GetString());
}
}
}