quantum-space-buddies/QSB/QSBNetworkManager.cs

252 lines
8.4 KiB
C#
Raw Normal View History

2020-08-22 18:08:25 +01:00
using OWML.Common;
2020-12-20 10:56:15 +00:00
using OWML.Utils;
2020-08-22 18:08:25 +01:00
using QSB.Animation;
2020-08-13 21:46:16 +02:00
using QSB.DeathSync;
2020-09-17 20:14:55 +01:00
using QSB.ElevatorSync;
2020-12-14 16:24:52 +00:00
using QSB.Events;
2020-08-13 19:25:12 +02:00
using QSB.GeyserSync;
2020-11-20 19:50:31 +00:00
using QSB.Instruments;
using QSB.OrbSync;
2020-11-03 21:11:10 +00:00
using QSB.Patches;
2020-11-03 21:33:48 +00:00
using QSB.Player;
2020-11-03 22:29:23 +00:00
using QSB.SectorSync;
using QSB.TimeSync;
2020-02-21 23:36:07 +01:00
using QSB.TransformSync;
using QSB.Utility;
2020-09-04 20:57:35 +01:00
using QSB.WorldSync;
2020-12-04 22:15:41 +00:00
using QuantumUNET;
2020-12-07 21:19:16 +00:00
using QuantumUNET.Components;
2020-08-21 14:04:13 +01:00
using System;
using System.Linq;
2020-02-21 23:36:07 +01:00
using UnityEngine;
2020-02-13 20:23:26 +01:00
using UnityEngine.Networking;
2020-02-15 20:48:02 +01:00
namespace QSB
{
2020-12-02 21:29:53 +00:00
public class QSBNetworkManager : QSBNetworkManagerUNET
{
2020-12-14 21:20:53 +00:00
public static QSBNetworkManager Instance { get; private set; }
2020-12-02 21:29:53 +00:00
2020-12-14 21:20:53 +00:00
public event Action OnNetworkManagerReady;
2020-12-02 21:29:53 +00:00
2020-12-14 21:20:53 +00:00
public bool IsReady { get; private set; }
public GameObject OrbPrefab { get; set; }
2020-12-03 08:28:05 +00:00
2020-12-14 21:20:53 +00:00
private const int MaxConnections = 128;
private const int MaxBufferedPackets = 64;
2020-12-02 21:29:53 +00:00
2020-12-14 21:20:53 +00:00
private QSBNetworkLobby _lobby;
2020-12-02 21:29:53 +00:00
private AssetBundle _assetBundle;
private GameObject _shipPrefab;
private GameObject _cameraPrefab;
private GameObject _probePrefab;
2020-12-14 21:41:56 +01:00
public void Awake()
2020-12-02 21:29:53 +00:00
{
base.Awake();
2020-12-02 21:29:53 +00:00
Instance = this;
_lobby = gameObject.AddComponent<QSBNetworkLobby>();
2020-12-14 16:24:52 +00:00
_assetBundle = QSBCore.NetworkAssetBundle;
2020-12-02 21:29:53 +00:00
playerPrefab = _assetBundle.LoadAsset<GameObject>("assets/networkplayer.prefab");
2020-12-14 21:20:53 +00:00
SetupNetworkId(playerPrefab);
SetupNetworkTransform(playerPrefab);
playerPrefab.AddComponent<PlayerTransformSync>();
2020-12-02 21:29:53 +00:00
playerPrefab.AddComponent<AnimationSync>();
playerPrefab.AddComponent<WakeUpSync>();
playerPrefab.AddComponent<InstrumentsManager>();
_shipPrefab = _assetBundle.LoadAsset<GameObject>("assets/networkship.prefab");
2020-12-14 21:20:53 +00:00
SetupNetworkId(_shipPrefab);
SetupNetworkTransform(_shipPrefab);
_shipPrefab.AddComponent<ShipTransformSync>();
2020-12-02 21:29:53 +00:00
spawnPrefabs.Add(_shipPrefab);
_cameraPrefab = _assetBundle.LoadAsset<GameObject>("assets/networkcameraroot.prefab");
2020-12-14 21:20:53 +00:00
SetupNetworkId(_cameraPrefab);
SetupNetworkTransform(_cameraPrefab);
_cameraPrefab.AddComponent<PlayerCameraSync>();
2020-12-02 21:29:53 +00:00
spawnPrefabs.Add(_cameraPrefab);
_probePrefab = _assetBundle.LoadAsset<GameObject>("assets/networkprobe.prefab");
2020-12-14 21:20:53 +00:00
SetupNetworkId(_probePrefab);
SetupNetworkTransform(_probePrefab);
_probePrefab.AddComponent<PlayerProbeSync>();
2020-12-02 21:29:53 +00:00
spawnPrefabs.Add(_probePrefab);
OrbPrefab = _assetBundle.LoadAsset<GameObject>("assets/networkorb.prefab");
2020-12-14 21:20:53 +00:00
SetupNetworkId(OrbPrefab);
SetupNetworkTransform(OrbPrefab);
OrbPrefab.AddComponent<NomaiOrbTransformSync>();
2020-12-02 21:29:53 +00:00
spawnPrefabs.Add(OrbPrefab);
ConfigureNetworkManager();
QSBSceneManager.OnUniverseSceneLoaded += OnSceneLoaded;
}
2020-12-14 21:20:53 +00:00
private void SetupNetworkId(GameObject go)
{
var ident = go.AddComponent<QSBNetworkIdentity>();
ident.LocalPlayerAuthority = true;
2020-12-16 17:34:54 +00:00
ident.SetValue("m_AssetId", go.GetComponent<NetworkIdentity>().assetId);
ident.SetValue("m_SceneId", go.GetComponent<NetworkIdentity>().sceneId);
2020-12-14 21:20:53 +00:00
}
private void SetupNetworkTransform(GameObject go)
{
var trans = go.AddComponent<QSBNetworkTransform>();
trans.SyncRotationAxis = QSBNetworkTransform.AxisSyncMode.AxisXYZ;
2020-12-17 16:23:04 +00:00
Destroy(go.GetComponent<NetworkTransform>());
2020-12-19 10:56:25 +00:00
Destroy(go.GetComponent<NetworkIdentity>());
2020-12-14 21:20:53 +00:00
}
public void OnDestroy() =>
QSBSceneManager.OnUniverseSceneLoaded -= OnSceneLoaded;
2020-12-02 21:29:53 +00:00
private void OnSceneLoaded(OWScene scene)
{
OrbManager.Instance.BuildOrbs();
OrbManager.Instance.QueueBuildSlots();
2020-12-11 13:14:58 +00:00
QSBWorldSync.OldDialogueTrees.Clear();
QSBWorldSync.OldDialogueTrees = Resources.FindObjectsOfTypeAll<CharacterDialogueTree>().ToList();
2020-12-02 21:29:53 +00:00
}
private void ConfigureNetworkManager()
{
2020-12-14 16:24:52 +00:00
networkAddress = QSBCore.DefaultServerIP;
networkPort = QSBCore.Port;
2020-12-02 21:29:53 +00:00
maxConnections = MaxConnections;
customConfig = true;
connectionConfig.AddChannel(QosType.Reliable);
connectionConfig.AddChannel(QosType.Unreliable);
this.SetValue("m_MaxBufferedPackets", MaxBufferedPackets);
channels.Add(QosType.Reliable);
channels.Add(QosType.Unreliable);
DebugLog.DebugWrite("Network Manager ready.", MessageType.Success);
}
public override void OnStartServer()
{
DebugLog.DebugWrite("OnStartServer", MessageType.Info);
2020-12-11 13:14:58 +00:00
if (QSBWorldSync.OrbSyncList.Count == 0 && QSBSceneManager.IsInUniverse)
2020-12-02 21:29:53 +00:00
{
OrbManager.Instance.QueueBuildOrbs();
}
2020-12-11 13:14:58 +00:00
if (QSBWorldSync.OldDialogueTrees.Count == 0 && QSBSceneManager.IsInUniverse)
2020-12-02 21:29:53 +00:00
{
2020-12-11 13:14:58 +00:00
QSBWorldSync.OldDialogueTrees = Resources.FindObjectsOfTypeAll<CharacterDialogueTree>().ToList();
2020-12-02 21:29:53 +00:00
}
}
public override void OnServerAddPlayer(QSBNetworkConnection connection, short playerControllerId) // Called on the server when a client joins
{
2020-12-12 18:14:04 +00:00
DebugLog.DebugWrite($"OnServerAddPlayer {playerControllerId}", MessageType.Info);
2020-12-02 21:29:53 +00:00
base.OnServerAddPlayer(connection, playerControllerId);
QSBNetworkServer.SpawnWithClientAuthority(Instantiate(_shipPrefab), connection);
QSBNetworkServer.SpawnWithClientAuthority(Instantiate(_cameraPrefab), connection);
QSBNetworkServer.SpawnWithClientAuthority(Instantiate(_probePrefab), connection);
}
2020-12-19 21:40:54 +01:00
public override void OnStartClient(QSBNetworkClient _)
{
DebugLog.DebugWrite($"Setting defaultServerIP to {networkAddress}");
var config = QSBCore.Helper.Config;
config.SetSettingsValue("defaultServerIP", networkAddress);
QSBCore.Helper.Storage.Save(config, Constants.ModConfigFileName);
}
2020-12-02 21:29:53 +00:00
public override void OnClientConnect(QSBNetworkConnection connection) // Called on the client when connecting to a server
{
DebugLog.DebugWrite("OnClientConnect", MessageType.Info);
base.OnClientConnect(connection);
2020-12-12 18:14:04 +00:00
QSBEventManager.Init();
2020-12-02 21:29:53 +00:00
gameObject.AddComponent<SectorSync.SectorSync>();
gameObject.AddComponent<RespawnOnDeath>();
gameObject.AddComponent<PreventShipDestruction>();
if (QSBSceneManager.IsInUniverse)
{
QSBSectorManager.Instance.RebuildSectors();
OrbManager.Instance.QueueBuildSlots();
}
2020-12-21 19:41:53 +00:00
var specificType = QSBNetworkServer.active ? QSBPatchTypes.OnServerClientConnect : QSBPatchTypes.OnNonServerClientConnect;
QSBPatchManager.DoPatchType(specificType);
2020-12-02 21:29:53 +00:00
QSBPatchManager.DoPatchType(QSBPatchTypes.OnClientConnect);
_lobby.CanEditName = false;
OnNetworkManagerReady?.Invoke();
IsReady = true;
2020-12-14 16:24:52 +00:00
QSBCore.Helper.Events.Unity.RunWhen(() => QSBEventManager.Ready && PlayerTransformSync.LocalInstance != null,
2020-12-02 21:29:53 +00:00
() => GlobalMessenger<string>.FireEvent(EventNames.QSBPlayerJoin, _lobby.PlayerName));
2020-12-14 16:24:52 +00:00
if (!QSBCore.IsServer)
2020-12-11 22:42:21 +00:00
{
2020-12-14 16:24:52 +00:00
QSBCore.Helper.Events.Unity.RunWhen(() => QSBEventManager.Ready && PlayerTransformSync.LocalInstance != null,
2020-12-02 21:29:53 +00:00
() => GlobalMessenger.FireEvent(EventNames.QSBPlayerStatesRequest));
2020-12-11 22:42:21 +00:00
}
2020-12-02 21:29:53 +00:00
}
public override void OnStopClient() // Called on the client when closing connection
{
DebugLog.DebugWrite("OnStopClient", MessageType.Info);
DebugLog.ToConsole("Disconnecting from server...", MessageType.Info);
Destroy(GetComponent<SectorSync.SectorSync>());
Destroy(GetComponent<RespawnOnDeath>());
Destroy(GetComponent<PreventShipDestruction>());
QSBEventManager.Reset();
QSBPlayerManager.PlayerList.ForEach(player => player.HudMarker?.Remove());
QSBPlayerManager.RemoveAllPlayers();
2020-12-11 13:14:58 +00:00
QSBWorldSync.RemoveWorldObjects<QSBOrbSlot>();
QSBWorldSync.RemoveWorldObjects<QSBElevator>();
QSBWorldSync.RemoveWorldObjects<QSBGeyser>();
QSBWorldSync.RemoveWorldObjects<QSBSector>();
QSBWorldSync.OrbSyncList.Clear();
QSBWorldSync.OldDialogueTrees.Clear();
2020-12-02 21:29:53 +00:00
_lobby.CanEditName = true;
}
public override void OnServerDisconnect(QSBNetworkConnection connection) // Called on the server when any client disconnects
{
2020-12-12 11:27:28 +00:00
base.OnServerDisconnect(connection);
2020-12-02 21:29:53 +00:00
DebugLog.DebugWrite("OnServerDisconnect", MessageType.Info);
2020-12-11 13:14:58 +00:00
foreach (var item in QSBWorldSync.OrbSyncList)
2020-12-02 21:29:53 +00:00
{
var identity = item.GetComponent<QSBNetworkIdentity>();
if (identity.ClientAuthorityOwner == connection)
{
identity.RemoveClientAuthority(connection);
}
}
}
public override void OnStopServer()
{
DebugLog.DebugWrite("OnStopServer", MessageType.Info);
Destroy(GetComponent<SectorSync.SectorSync>());
Destroy(GetComponent<RespawnOnDeath>());
Destroy(GetComponent<PreventShipDestruction>());
QSBEventManager.Reset();
2020-12-13 22:25:23 +00:00
DebugLog.ToConsole("Server stopped!", MessageType.Info);
2020-12-02 21:29:53 +00:00
QSBPlayerManager.PlayerList.ForEach(player => player.HudMarker?.Remove());
2020-12-11 13:14:58 +00:00
QSBWorldSync.RemoveWorldObjects<QSBOrbSlot>();
QSBWorldSync.RemoveWorldObjects<QSBElevator>();
QSBWorldSync.RemoveWorldObjects<QSBGeyser>();
QSBWorldSync.RemoveWorldObjects<QSBSector>();
2020-12-02 21:29:53 +00:00
base.OnStopServer();
}
}
2020-11-22 21:08:10 +00:00
}