2024-03-11 00:30:12 +00:00
|
|
|
|
using HarmonyLib;
|
|
|
|
|
using NewHorizons;
|
|
|
|
|
using QSB.Menus;
|
|
|
|
|
using QSB.Messaging;
|
|
|
|
|
using QSB.Player;
|
|
|
|
|
using QSB;
|
|
|
|
|
using System;
|
|
|
|
|
using System.Collections.Generic;
|
|
|
|
|
using System.Linq;
|
|
|
|
|
using System.Text;
|
|
|
|
|
using System.Threading.Tasks;
|
|
|
|
|
using Mirror;
|
2024-03-11 01:36:48 +00:00
|
|
|
|
using QSB.Patches;
|
2024-03-11 00:30:12 +00:00
|
|
|
|
using QSB.Utility;
|
|
|
|
|
|
|
|
|
|
namespace QSBNH;
|
|
|
|
|
public static class WarpManager
|
|
|
|
|
{
|
|
|
|
|
internal static bool RemoteWarp = false;
|
|
|
|
|
|
|
|
|
|
private static void Kick(string reason)
|
|
|
|
|
{
|
|
|
|
|
DebugLog.DebugWrite(reason);
|
|
|
|
|
MenuManager.Instance.OnKicked(reason);
|
|
|
|
|
NetworkClient.Disconnect();
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
public static void RemoteChangeStarSystem(string system, bool ship, bool vessel, int[] hostAddonHash)
|
|
|
|
|
{
|
|
|
|
|
// Flag to not send a message
|
|
|
|
|
RemoteWarp = true;
|
|
|
|
|
|
|
|
|
|
DebugLog.DebugWrite($"Remote request received to go to {system}");
|
|
|
|
|
|
|
|
|
|
if (!NewHorizons.Main.SystemDict.ContainsKey(system))
|
|
|
|
|
{
|
|
|
|
|
// If you can't go to that system then you have to be disconnected
|
|
|
|
|
Kick($"You don't have the mod installed for {system}");
|
|
|
|
|
}
|
|
|
|
|
else
|
|
|
|
|
{
|
|
|
|
|
var localHash = QSBNH.HashAddonsForSystem(system);
|
|
|
|
|
if (localHash != hostAddonHash)
|
|
|
|
|
{
|
|
|
|
|
var missingAddonHashes = hostAddonHash.Except(localHash);
|
|
|
|
|
var extraAddonHashes = localHash.Except(hostAddonHash);
|
|
|
|
|
|
|
|
|
|
if (missingAddonHashes.Count() > 0)
|
|
|
|
|
{
|
|
|
|
|
Kick($"You are missing {missingAddonHashes.Count()} addon(s) that effect {system}");
|
|
|
|
|
return;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
if (extraAddonHashes.Count() > 0)
|
|
|
|
|
{
|
|
|
|
|
var extraMods = extraAddonHashes.Select(x => QSBNH.HashToMod(x));
|
|
|
|
|
|
|
|
|
|
// TODO: Disable these mods for the client and do not kick them
|
|
|
|
|
|
|
|
|
|
Kick($"You have {extraAddonHashes.Count()} extra addon(s) that effect {system}. Check the logs.");
|
|
|
|
|
DebugLog.DebugWrite($"You have mods affecting {system} that the host does not: {string.Join(", ", extraMods)}");
|
|
|
|
|
return;
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
NewHorizons.Main.Instance.ChangeCurrentStarSystem(system, ship, vessel);
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
public class NHWarpMessage : QSBMessage
|
|
|
|
|
{
|
|
|
|
|
private string _starSystem;
|
|
|
|
|
private bool _shipWarp;
|
|
|
|
|
private bool _vesselWarp;
|
|
|
|
|
|
|
|
|
|
public NHWarpMessage(string starSystem, bool shipWarp, bool vesselWarp) : base()
|
|
|
|
|
{
|
|
|
|
|
_starSystem = starSystem;
|
|
|
|
|
_shipWarp = shipWarp;
|
|
|
|
|
_vesselWarp = vesselWarp;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
public override void Serialize(NetworkWriter writer)
|
|
|
|
|
{
|
|
|
|
|
base.Serialize(writer);
|
|
|
|
|
|
|
|
|
|
writer.Write(_starSystem);
|
|
|
|
|
writer.Write(_shipWarp);
|
|
|
|
|
writer.Write(_vesselWarp);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
public override void Deserialize(NetworkReader reader)
|
|
|
|
|
{
|
|
|
|
|
base.Deserialize(reader);
|
|
|
|
|
|
|
|
|
|
_starSystem = reader.Read<string>();
|
|
|
|
|
_shipWarp = reader.Read<bool>();
|
|
|
|
|
_vesselWarp = reader.Read<bool>();
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
public override void OnReceiveRemote()
|
|
|
|
|
{
|
|
|
|
|
DebugLog.DebugWrite($"Player#{From} is telling Player#{To} to warp to {_starSystem}");
|
|
|
|
|
if (QSBCore.IsHost && !NewHorizons.Main.SystemDict.ContainsKey(_starSystem))
|
|
|
|
|
{
|
|
|
|
|
// If the host doesn't have that system then we can't
|
|
|
|
|
DebugLog.DebugWrite($"The host doesn't have {_starSystem} installed: aborting");
|
|
|
|
|
}
|
|
|
|
|
else
|
|
|
|
|
{
|
|
|
|
|
if (QSBCore.IsHost)
|
|
|
|
|
{
|
|
|
|
|
new NHWarpMessage(_starSystem, _shipWarp, _vesselWarp).Send();
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
RemoteChangeStarSystem(_starSystem, _shipWarp, _vesselWarp, QSBNH.HashAddonsForSystem(_starSystem));
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
2024-03-11 01:36:48 +00:00
|
|
|
|
public class NHWarpPatch : QSBPatch
|
2024-03-11 00:30:12 +00:00
|
|
|
|
{
|
2024-03-11 01:36:48 +00:00
|
|
|
|
public override QSBPatchTypes Type => QSBPatchTypes.OnModStart;
|
|
|
|
|
|
2024-03-11 00:30:12 +00:00
|
|
|
|
[HarmonyPrefix]
|
|
|
|
|
[HarmonyPatch(typeof(NewHorizons.Main), nameof(NewHorizons.Main.ChangeCurrentStarSystem))]
|
|
|
|
|
public static bool NewHorizons_ChangeCurrentStarSystem(string newStarSystem, bool warp, bool vessel)
|
|
|
|
|
{
|
|
|
|
|
if (RemoteWarp)
|
|
|
|
|
{
|
|
|
|
|
// We're being told to warp so just do it
|
|
|
|
|
RemoteWarp = false;
|
|
|
|
|
return true;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
DebugLog.DebugWrite($"Local request received to go to {newStarSystem}");
|
|
|
|
|
if (QSBCore.IsHost)
|
|
|
|
|
{
|
|
|
|
|
// The host will tell all other users to warp
|
|
|
|
|
DebugLog.DebugWrite($"Host: Telling others to go to {newStarSystem}");
|
|
|
|
|
new NHWarpMessage(newStarSystem, warp, vessel).Send();
|
|
|
|
|
// The host can now warp
|
|
|
|
|
return true;
|
|
|
|
|
}
|
|
|
|
|
else
|
|
|
|
|
{
|
|
|
|
|
// We're a client that has to tell the host to start warping people
|
|
|
|
|
DebugLog.DebugWrite($"Client: Telling host to send us to {newStarSystem}");
|
|
|
|
|
new NHWarpMessage(newStarSystem, warp, vessel) { To = 0 }.Send();
|
|
|
|
|
|
|
|
|
|
// We have to wait for the host to get back to us
|
|
|
|
|
return false;
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
[HarmonyPostfix]
|
|
|
|
|
[HarmonyPatch(typeof(NewHorizons.Main), nameof(NewHorizons.Main.ChangeCurrentStarSystem))]
|
|
|
|
|
public static void NewHorizons_ChangeCurrentStarSystem(NewHorizons.Main __instance)
|
|
|
|
|
{
|
|
|
|
|
if (__instance.IsWarpingFromShip)
|
|
|
|
|
{
|
|
|
|
|
// If QSB doesn't say we're piloting the ship then dont keep them on as the one warping
|
|
|
|
|
__instance.GetType().GetProperty(nameof(NewHorizons.Main.IsWarpingFromShip)).SetValue(__instance, QSBPlayerManager.LocalPlayer.FlyingShip);
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|