mirror of
https://github.com/misternebula/quantum-space-buddies.git
synced 2025-01-03 17:38:30 +00:00
170 lines
6.1 KiB
C#
170 lines
6.1 KiB
C#
#if !DISABLESTEAMWORKS
|
|
using Steamworks;
|
|
using System;
|
|
using System.Collections.Generic;
|
|
using UnityEngine;
|
|
|
|
namespace Mirror.FizzySteam
|
|
{
|
|
public class LegacyServer : LegacyCommon, IServer
|
|
{
|
|
private event Action<int> OnConnected;
|
|
private event Action<int, byte[], int> OnReceivedData;
|
|
private event Action<int> OnDisconnected;
|
|
private event Action<int, TransportError, string> OnReceivedError;
|
|
|
|
private BidirectionalDictionary<CSteamID, int> steamToMirrorIds;
|
|
private int maxConnections;
|
|
private int nextConnectionID;
|
|
|
|
public static LegacyServer CreateServer(FizzySteamworks transport, int maxConnections)
|
|
{
|
|
LegacyServer s = new LegacyServer(transport, maxConnections);
|
|
|
|
s.OnConnected += (id) => transport.OnServerConnected.Invoke(id);
|
|
s.OnDisconnected += (id) => transport.OnServerDisconnected.Invoke(id);
|
|
s.OnReceivedData += (id, data, channel) => transport.OnServerDataReceived.Invoke(id, new ArraySegment<byte>(data), channel);
|
|
s.OnReceivedError += (id, error, reason) => transport.OnServerError.Invoke(id, error, reason);
|
|
|
|
try
|
|
{
|
|
#if UNITY_SERVER
|
|
InteropHelp.TestIfAvailableGameServer();
|
|
#else
|
|
InteropHelp.TestIfAvailableClient();
|
|
#endif
|
|
}
|
|
catch
|
|
{
|
|
Debug.LogError("SteamWorks not initialized.");
|
|
}
|
|
|
|
return s;
|
|
}
|
|
|
|
private LegacyServer(FizzySteamworks transport, int maxConnections) : base(transport)
|
|
{
|
|
this.maxConnections = maxConnections;
|
|
steamToMirrorIds = new BidirectionalDictionary<CSteamID, int>();
|
|
nextConnectionID = 1;
|
|
}
|
|
|
|
protected override void OnNewConnection(P2PSessionRequest_t result)
|
|
{
|
|
#if UNITY_SERVER
|
|
SteamGameServerNetworking.AcceptP2PSessionWithUser(result.m_steamIDRemote);
|
|
#else
|
|
SteamNetworking.AcceptP2PSessionWithUser(result.m_steamIDRemote);
|
|
#endif
|
|
}
|
|
|
|
protected override void OnReceiveInternalData(InternalMessages type, CSteamID clientSteamID)
|
|
{
|
|
switch (type)
|
|
{
|
|
case InternalMessages.CONNECT:
|
|
if (steamToMirrorIds.Count >= maxConnections)
|
|
{
|
|
SendInternal(clientSteamID, InternalMessages.DISCONNECT);
|
|
return;
|
|
}
|
|
|
|
SendInternal(clientSteamID, InternalMessages.ACCEPT_CONNECT);
|
|
|
|
int connectionId = nextConnectionID++;
|
|
steamToMirrorIds.Add(clientSteamID, connectionId);
|
|
OnConnected.Invoke(connectionId);
|
|
Debug.Log($"Client with SteamID {clientSteamID} connected. Assigning connection id {connectionId}");
|
|
break;
|
|
case InternalMessages.DISCONNECT:
|
|
if (steamToMirrorIds.TryGetValue(clientSteamID, out int connId))
|
|
{
|
|
OnDisconnected.Invoke(connId);
|
|
CloseP2PSessionWithUser(clientSteamID);
|
|
steamToMirrorIds.Remove(clientSteamID);
|
|
Debug.Log($"Client with SteamID {clientSteamID} disconnected.");
|
|
}
|
|
|
|
break;
|
|
default:
|
|
Debug.Log("Received unknown message type");
|
|
break;
|
|
}
|
|
}
|
|
|
|
protected override void OnReceiveData(byte[] data, CSteamID clientSteamID, int channel)
|
|
{
|
|
if (steamToMirrorIds.TryGetValue(clientSteamID, out int connectionId))
|
|
{
|
|
OnReceivedData.Invoke(connectionId, data, channel);
|
|
}
|
|
else
|
|
{
|
|
CloseP2PSessionWithUser(clientSteamID);
|
|
Debug.LogError("Data received from steam client thats not known " + clientSteamID);
|
|
OnReceivedError.Invoke(-1, TransportError.DnsResolve, "ERROR Unknown SteamID");
|
|
}
|
|
}
|
|
|
|
public void Disconnect(int connectionId)
|
|
{
|
|
if (steamToMirrorIds.TryGetValue(connectionId, out CSteamID steamID))
|
|
{
|
|
SendInternal(steamID, InternalMessages.DISCONNECT);
|
|
steamToMirrorIds.Remove(connectionId);
|
|
}
|
|
else
|
|
{
|
|
Debug.LogWarning("Trying to disconnect unknown connection id: " + connectionId);
|
|
}
|
|
}
|
|
|
|
public void Shutdown()
|
|
{
|
|
foreach (KeyValuePair<CSteamID, int> client in steamToMirrorIds)
|
|
{
|
|
Disconnect(client.Value);
|
|
WaitForClose(client.Key);
|
|
}
|
|
|
|
Dispose();
|
|
}
|
|
|
|
public void Send(int connectionId, byte[] data, int channelId)
|
|
{
|
|
if (steamToMirrorIds.TryGetValue(connectionId, out CSteamID steamId))
|
|
{
|
|
Send(steamId, data, channelId);
|
|
}
|
|
else
|
|
{
|
|
Debug.LogError("Trying to send on unknown connection: " + connectionId);
|
|
OnReceivedError.Invoke(connectionId, TransportError.Unexpected, "ERROR Unknown Connection");
|
|
}
|
|
}
|
|
|
|
public string ServerGetClientAddress(int connectionId)
|
|
{
|
|
if (steamToMirrorIds.TryGetValue(connectionId, out CSteamID steamId))
|
|
{
|
|
return steamId.ToString();
|
|
}
|
|
else
|
|
{
|
|
Debug.LogError("Trying to get info on unknown connection: " + connectionId);
|
|
OnReceivedError.Invoke(connectionId, TransportError.Unexpected, "ERROR Unknown Connection");
|
|
return string.Empty;
|
|
}
|
|
}
|
|
|
|
protected override void OnConnectionFailed(CSteamID remoteId)
|
|
{
|
|
int connectionId = steamToMirrorIds.TryGetValue(remoteId, out int connId) ? connId : nextConnectionID++;
|
|
OnDisconnected.Invoke(connectionId);
|
|
|
|
steamToMirrorIds.Remove(remoteId);
|
|
}
|
|
public void FlushData() { }
|
|
}
|
|
}
|
|
#endif // !DISABLESTEAMWORKS |