Decompiled source of ValheimRAFTBETA v4.1.0
plugins\DynamicLocations.dll
Decompiled a week agousing System; using System.Collections; using System.Collections.Generic; using System.Diagnostics; using System.Linq; using System.Reflection; using System.Runtime.CompilerServices; using System.Runtime.InteropServices; using System.Runtime.Versioning; using System.Security; using System.Security.Permissions; using System.Text; using BepInEx; using BepInEx.Configuration; using DynamicLocations.API; using DynamicLocations.Commands; using DynamicLocations.Config; using DynamicLocations.Constants; using DynamicLocations.Controllers; using DynamicLocations.Patches; using DynamicLocations.Structs; using HarmonyLib; using JetBrains.Annotations; using Jotunn; using Jotunn.Entities; using Jotunn.Managers; using Jotunn.Utils; using Microsoft.CodeAnalysis; using UnityEngine; using ZdoWatcher; using Zolantris.Shared; using Zolantris.Shared.Debug; [assembly: CompilationRelaxations(8)] [assembly: RuntimeCompatibility(WrapNonExceptionThrows = true)] [assembly: Debuggable(DebuggableAttribute.DebuggingModes.IgnoreSymbolStoreSequencePoints)] [assembly: AssemblyTitle("DynamicLocations")] [assembly: AssemblyDescription("Valheim Mod made to attach to an item/prefab such as a bed and place a player or object near the item wherever it is in the current game. Meant for ValheimVehicles but could be used for any movement mod. Requires Jotunn and ZdoWatcher")] [assembly: AssemblyConfiguration("")] [assembly: AssemblyCompany("Virtualize LLC")] [assembly: AssemblyProduct("DynamicLocations")] [assembly: AssemblyCopyright("Copyright © 2023-2024, GNU-v3 licensed")] [assembly: Guid("6015B165-2627-40A7-8CA1-3E6B6CD7CB49")] [assembly: AssemblyFileVersion("1.2.0")] [assembly: TargetFramework(".NETStandard,Version=v2.1", FrameworkDisplayName = ".NET Standard 2.1")] [assembly: SecurityPermission(SecurityAction.RequestMinimum, SkipVerification = true)] [assembly: AssemblyVersion("1.2.0.0")] [module: UnverifiableCode] [module: RefSafetyRules(11)] namespace Microsoft.CodeAnalysis { [CompilerGenerated] [Microsoft.CodeAnalysis.Embedded] internal sealed class EmbeddedAttribute : Attribute { } } namespace System.Runtime.CompilerServices { [CompilerGenerated] [Microsoft.CodeAnalysis.Embedded] [AttributeUsage(AttributeTargets.Class | AttributeTargets.Property | AttributeTargets.Field | AttributeTargets.Event | AttributeTargets.Parameter | AttributeTargets.ReturnValue | AttributeTargets.GenericParameter, AllowMultiple = false, Inherited = false)] internal sealed class NullableAttribute : Attribute { public readonly byte[] NullableFlags; public NullableAttribute(byte P_0) { NullableFlags = new byte[1] { P_0 }; } public NullableAttribute(byte[] P_0) { NullableFlags = P_0; } } [CompilerGenerated] [Microsoft.CodeAnalysis.Embedded] [AttributeUsage(AttributeTargets.Class | AttributeTargets.Struct | AttributeTargets.Method | AttributeTargets.Interface | AttributeTargets.Delegate, AllowMultiple = false, Inherited = false)] internal sealed class NullableContextAttribute : Attribute { public readonly byte Flag; public NullableContextAttribute(byte P_0) { Flag = P_0; } } [CompilerGenerated] [Microsoft.CodeAnalysis.Embedded] [AttributeUsage(AttributeTargets.Module, AllowMultiple = false, Inherited = false)] internal sealed class RefSafetyRulesAttribute : Attribute { public readonly int Version; public RefSafetyRulesAttribute(int P_0) { Version = P_0; } } } namespace DynamicLocations { internal class ZdoWatcherDelegate { public static readonly int DynamicLocationSpawn = StringExtensionMethods.GetStableHashCode("DynamicLocation_Spawn"); public static readonly int DynamicLocationLogout = StringExtensionMethods.GetStableHashCode("DynamicLocation_Logout"); public static Dictionary<int, ZDOID> DynamicSpawns; public void RegisterToZdoManager() { ZdoWatchController.OnDeserialize = (Action<ZDO>)Delegate.Combine(ZdoWatchController.OnDeserialize, new Action<ZDO>(OnZdoRegister)); ZdoWatchController.OnLoad = (Action<ZDO>)Delegate.Combine(ZdoWatchController.OnLoad, new Action<ZDO>(OnZdoRegister)); } private static void OnZdoRegister(ZDO zdo) { } public static void OnZdoUnRegister(ZDO zdo) { } } [BepInPlugin("zolantris.DynamicLocations", "DynamicLocations", "1.2.0")] [BepInDependency(/*Could not decode attribute arguments.*/)] [BepInDependency(/*Could not decode attribute arguments.*/)] [NetworkCompatibility(/*Could not decode attribute arguments.*/)] public class DynamicLocationsPlugin : BaseUnityPlugin { public const string Author = "zolantris"; public const string Version = "1.2.0"; public const string ModName = "DynamicLocations"; public const string BepInGuid = "zolantris.DynamicLocations"; private static Harmony _harmony; public const string ModDescription = "Valheim Mod made to attach to an item/prefab such as a bed and place a player or object near the item wherever it is in the current game. Meant for ValheimVehicles but could be used for any movement mod. Requires Jotunn and ZdoWatcher"; public const string CopyRight = "Copyright © 2023-2024, GNU-v3 licensed"; public static string HarmonyGuid => "zolantris.DynamicLocations"; public void Awake() { //IL_0010: Unknown result type (might be due to invalid IL or missing references) //IL_001a: Expected O, but got Unknown DynamicLocationsConfig.BindConfig(((BaseUnityPlugin)this).Config); _harmony = new Harmony(HarmonyGuid); _harmony.PatchAll(typeof(DynamicLocationsPatches)); RegisterCommands(); } public void RegisterCommands() { CommandManager.Instance.AddConsoleCommand((ConsoleCommand)(object)new DynamicLocationsCommands()); } } } namespace DynamicLocations.Structs { public struct DynamicLocation { public Tuple<int, int> zoneId; public Tuple<float, float, float> position; public LocationVariation locationType; } public struct IntegrationConfig { public string ZdoTargetTargetPrefabName { get; private set; } public string Guid { get; set; } public string Version { get; set; } public string Name { get; set; } public BaseUnityPlugin Plugin { get; set; } public bool UseDefaultCallbacks { get; set; } public int MovementTimeout { get; set; } public bool ShouldFreezePlayer { get; set; } public int LoginPrefabHashCode { get; set; } public int Priority { get; set; } public List<string> RunBeforePlugins { get; } public List<string> RunAfterPlugins { get; } [UsedImplicitly] public IntegrationConfig() { UseDefaultCallbacks = false; MovementTimeout = 0; ShouldFreezePlayer = false; LoginPrefabHashCode = 0; Priority = 999; RunBeforePlugins = new List<string>(); RunAfterPlugins = new List<string>(); throw new Exception("This constructor is not supported, please provide plugin and zdoTargetPrefabName"); } public IntegrationConfig(BaseUnityPlugin plugin, string zdoTargetPrefabName) { UseDefaultCallbacks = false; MovementTimeout = 0; ShouldFreezePlayer = false; LoginPrefabHashCode = 0; Priority = 999; RunBeforePlugins = new List<string>(); RunAfterPlugins = new List<string>(); Plugin = plugin; ZdoTargetTargetPrefabName = zdoTargetPrefabName; LoginPrefabHashCode = zdoTargetPrefabName.GetHashCode(); Name = plugin.Info.Metadata.Name; Version = plugin.Info.Metadata.Version.ToString(); Guid = plugin.Info.Metadata.GUID; Logger.LogDebug((object)$"PluginVersion: {plugin.Info.Metadata.Version} stringVersion {Version}, Name: {Name}"); } } } namespace DynamicLocations.Prefabs { public class DynamicPointPrefab { public static readonly DynamicPointPrefab Instance = new DynamicPointPrefab(); public void Register(PrefabManager prefabManager, PieceManager pieceManager) { prefabManager.CreateEmptyPrefab("DynamicLocations_Prefabs_SpawnPoint", true).layer = LayerMask.NameToLayer("piece"); } } internal static class PrefabNames { private const string ModNamePrefix = "DynamicLocations_Prefabs"; public const string SpawnPoint = "DynamicLocations_Prefabs_SpawnPoint"; } } namespace DynamicLocations.Patches { public class DynamicLocationsPatches { [HarmonyPatch(typeof(Bed), "Interact")] [HarmonyPostfix] private static void OnSpawnPointUpdated(Bed __instance) { //IL_000a: Unknown result type (might be due to invalid IL or missing references) Game.instance.GetPlayerProfile().GetCustomSpawnPoint(); if (((Character)Player.m_localPlayer).InInterior()) { if (DynamicLocationsConfig.IsDebug) { Logger.LogDebug((object)"Cannot dynamic spawn inside dungeon or building. InIniterior returned true, must skip."); } return; } PlayerSpawnController instance = PlayerSpawnController.Instance; if (Object.op_Implicit((Object)(object)instance)) { instance?.SyncBedSpawnPoint(__instance.m_nview.GetZDO(), __instance); } } [HarmonyPatch(typeof(Player), "OnDeath")] [HarmonyPostfix] private static void OnDeathDestroyLogoutPoint(Player __instance) { if (!((Character)__instance).m_nview.IsOwner()) { return; } try { LocationController.RemoveZdoTarget(LocationVariation.Logout, __instance); } catch (Exception arg) { LoggerProvider.LogError($"Error occurred while removing a zdotarget. \n{arg}", "C:\\Users\\fre\\dev\\repos\\ValheimMods\\src\\DynamicLocations\\DynamicLocations.Patches\\DynamicLocationsPatches.cs", 63); } } [HarmonyPatch(typeof(Player), "ShowTeleportAnimation")] [HarmonyPostfix] private static void ShowTeleportAnimation(bool __result) { if (!((Object)(object)PlayerSpawnController.Instance == (Object)null) && PlayerSpawnController.Instance.IsTeleportingToDynamicLocation) { __result = false; } } [HarmonyPatch(typeof(Game), "Awake")] [HarmonyPostfix] private static void AddSpawnController(Game __instance) { Logger.LogDebug((object)"Game Awake called and added PlayerSpawnController and LocationController"); ((Component)__instance).gameObject.AddComponent<LocationController>(); ((Component)__instance).gameObject.AddComponent<PlayerSpawnController>(); } [HarmonyPatch(typeof(Game), "OnDestroy")] [HarmonyPostfix] private static void ResetSpawnController(Game __instance) { try { LocationController.ResetCachedValues(); } catch (Exception arg) { LoggerProvider.LogError($"Error with ResetSpawnController \n{arg}", "C:\\Users\\fre\\dev\\repos\\ValheimMods\\src\\DynamicLocations\\DynamicLocations.Patches\\DynamicLocationsPatches.cs", 103); } } [HarmonyPatch(typeof(Game), "RequestRespawn")] [HarmonyPrefix] public static bool RequestRespawnListener(Game __instance) { return true; } public static void SetupPlayerDebugValues() { } [HarmonyPatch(typeof(Game), "SpawnPlayer")] [HarmonyPostfix] private static void OnSpawned(Game __instance, Player __result) { if (ZNetView.m_forceDisableInit || (!DynamicLocationsConfig.EnableDynamicLogoutPoint.Value && !DynamicLocationsConfig.EnableDynamicLogoutPoint.Value && ((Object)(object)__result == (Object)null || (Object)(object)Game.instance == (Object)null))) { return; } SetupPlayerDebugValues(); PlayerProfile playerProfile = Game.instance.GetPlayerProfile(); if ((Object)(object)PlayerSpawnController.Instance == (Object)null) { LoggerProvider.LogWarning("No spawn controller. This means dynamic locations is not working.", "C:\\Users\\fre\\dev\\repos\\ValheimMods\\src\\DynamicLocations\\DynamicLocations.Patches\\DynamicLocationsPatches.cs", 159); } else if (playerProfile != null && playerProfile.HaveLogoutPoint()) { if (DynamicLocationsConfig.EnableDynamicLogoutPoint.Value && !((Character)__result).InInterior() && !((Character)__result).InIntro()) { PlayerSpawnController.Instance.MovePlayerToLogoutPoint(); } } else if (__instance.m_respawnAfterDeath && DynamicLocationsConfig.EnableDynamicSpawnPoint.Value && !((Character)__result).InIntro()) { PlayerSpawnController.Instance.MovePlayerToSpawnPoint(); } } } } namespace DynamicLocations.Interfaces { internal interface IModLoginAPI { BaseUnityPlugin Plugin { get; set; } bool UseDefaultCallbacks { get; } int MovementTimeout { get; } bool ShouldFreezePlayer { get; } int LoginPrefabHashCode { get; } int Priority { get; } List<string> RunBeforePlugins { get; } List<string> RunAfterPlugins { get; } IEnumerator OnLoginMoveToZDO(ZDO zdo, Vector3? offset, PlayerSpawnController playerSpawnController); bool OnLoginMatchZdoPrefab(ZDO zdo); } public interface IVehiclePiecesController { bool IsActivationComplete { get; } } } namespace DynamicLocations.Controllers { public interface ICachedLocation { Vector3? Offset { get; set; } ZDO Zdo { get; set; } } public class CacheLocationItem : ICachedLocation { public Vector3? Offset { get; set; } public ZDO? Zdo { get; set; } } public class LocationController : MonoBehaviour { private const string DynamicPrefix = "Dynamic"; private const string SpawnZdoPrefix = "SpawnZdo"; private const string SpawnZdoOffsetPrefix = "SpawnZdoOffset"; private const string LogoutParentZdoOffsetPrefix = "LogoutParentZdoOffset"; private const string LogoutParentZdoPrefix = "LogoutParentZdo"; private static Dictionary<LocationVariation, ICachedLocation> _cachedLocations = new Dictionary<LocationVariation, ICachedLocation>(); public static LocationController Instance; internal static long WorldIdOverride = 0L; private static long CurrentWorldId => GetCurrentWorldId(); public void Awake() { Instance = this; } public void OnDestroy() { _cachedLocations.Clear(); } public static ICachedLocation? GetCachedDynamicLocation(LocationVariation locationVariationType) { _cachedLocations.TryGetValue(locationVariationType, out ICachedLocation value); return value; } public static bool SetCachedDynamicLocation(LocationVariation locationVariationType, CacheLocationItem cachedLocationItem) { if (GetCachedDynamicLocation(locationVariationType) != null) { _cachedLocations[locationVariationType] = cachedLocationItem; } else { _cachedLocations.Add(locationVariationType, cachedLocationItem); } return true; } public static string GetPluginPrefix() { return "DynamicLocations"; } public static string GetFullPrefix() { return GetPluginPrefix() + "_Dynamic"; } public static long GetCurrentWorldId() { if (WorldIdOverride != 0L) { return WorldIdOverride; } if ((Object)(object)ZNet.instance == (Object)null) { return 0L; } return ZNet.instance.GetWorldUID(); } public static string GetLogoutZdoOffsetKey() { if (Object.op_Implicit((Object)(object)ZNet.instance)) { return string.Format("{0}_{1}_{2}", GetFullPrefix(), "LogoutParentZdoOffset", CurrentWorldId); } return ""; } public static string GetLogoutZdoKey() { if (Object.op_Implicit((Object)(object)ZNet.instance)) { return string.Format("{0}_{1}_{2}", GetFullPrefix(), "LogoutParentZdo", CurrentWorldId); } return ""; } public static string GetSpawnZdoOffsetKey() { if (Object.op_Implicit((Object)(object)ZNet.instance)) { return string.Format("{0}_{1}_{2}", GetFullPrefix(), "SpawnZdoOffset", CurrentWorldId); } return ""; } public static string GetSpawnZdoKey() { if (Object.op_Implicit((Object)(object)ZNet.instance)) { return string.Format("{0}_{1}_{2}", GetFullPrefix(), "SpawnZdo", CurrentWorldId); } return ""; } private static string ZDOIDToString(ZDOID zdoid) { long userID = ((ZDOID)(ref zdoid)).UserID; uint iD = ((ZDOID)(ref zdoid)).ID; return $"{userID},{iD}"; } private static ZDOID? StringToZDOID(string zdoidString) { //IL_004c: Unknown result type (might be due to invalid IL or missing references) string[] array = zdoidString.Split(','); if (array.Length != 2) { return null; } long.TryParse(array[0], out var result); uint.TryParse(array[1], out var result2); if (result == 0L || result2 == 0) { Logger.LogDebug((object)"failed to parse to ZDOID"); return null; } return new ZDOID(result, result2); } private static string Vector3ToString(Vector3 val) { //IL_0005: Unknown result type (might be due to invalid IL or missing references) //IL_0010: Unknown result type (might be due to invalid IL or missing references) //IL_001b: Unknown result type (might be due to invalid IL or missing references) return $"{val.x},{val.y},{val.z}"; } private static Vector3? StringToVector3(string val) { //IL_003f: Unknown result type (might be due to invalid IL or missing references) string[] array = val.Split(','); if (array.Length != 3) { return null; } float.TryParse(array[0], out var result); float.TryParse(array[1], out var result2); float.TryParse(array[2], out var result3); return new Vector3(result, result2, result3); } internal static void DEBUG_RemoveAllDynamicLocationKeys() { KeyValuePair<string, string>[] array = Player.m_localPlayer.m_customData.ToArray(); for (int i = 0; i < array.Length; i++) { KeyValuePair<string, string> keyValuePair = array[i]; if (keyValuePair.Key.Contains(GetFullPrefix())) { Logger.LogDebug((object)("Removing: Key: " + keyValuePair.Key + " Value: " + keyValuePair.Value)); Player.m_localPlayer.m_customData.Remove(keyValuePair.Key); } } } internal static void DEBUGCOMMAND_RemoveLogout() { string logoutZdoKey = GetLogoutZdoKey(); Logger.LogInfo((object)(Player.m_localPlayer.m_customData.Remove(logoutZdoKey) ? ("Removing logout key: " + logoutZdoKey) : "No logout key found")); } internal static void DEBUGCOMMAND_ListAllKeys() { KeyValuePair<string, string>[] array = Player.m_localPlayer.m_customData.ToArray(); List<string> list = new List<string>(); List<string> list2 = new List<string>(); List<string> list3 = new List<string>(); List<string> list4 = new List<string>(); string[] value = Player.m_localPlayer.m_customData.ToArray().Where(delegate(KeyValuePair<string, string> keyValuePair) { KeyValuePair<string, string> keyValuePair4 = keyValuePair; return keyValuePair4.Key.Contains($"{CurrentWorldId}"); }).Select(delegate(KeyValuePair<string, string> keyValuePair) { KeyValuePair<string, string> keyValuePair3 = keyValuePair; return keyValuePair3.Value; }) .ToArray(); KeyValuePair<string, string>[] array2 = array; for (int i = 0; i < array2.Length; i++) { KeyValuePair<string, string> keyValuePair2 = array2[i]; if (keyValuePair2.Key.Contains(GetFullPrefix())) { if (keyValuePair2.Key.Contains("SpawnZdoOffset")) { list4.Add(keyValuePair2.Value); } else if (keyValuePair2.Key.Contains("SpawnZdo")) { list3.Add(keyValuePair2.Value); } else if (keyValuePair2.Key.Contains("LogoutParentZdoOffset")) { list2.Add(keyValuePair2.Value); } else if (keyValuePair2.Key.Contains("LogoutParentZdo")) { list.Add(keyValuePair2.Value); } } } Logger.LogInfo((object)("currentWorldItems: " + string.Join(", ", value))); Logger.LogInfo((object)("spawnKeys: " + string.Join(", ", list3))); Logger.LogInfo((object)("spawnOffsetKeys: " + string.Join(", ", list4))); Logger.LogInfo((object)("logoutKeys: " + string.Join(", ", list))); Logger.LogInfo((object)("logoutOffsetKeys: " + string.Join(", ", list2))); } public static bool RemoveZdoTarget(LocationVariation locationVariationType, Player? player) { RemoveTargetKey(locationVariationType, player); return true; } public static int? GetZdoFromStore(LocationVariation locationVariationType, Player? player) { string zdoStorageKey = GetZdoStorageKey(locationVariationType); if ((Object)(object)player == (Object)null) { return null; } if (!player.m_customData.TryGetValue(zdoStorageKey, out var value)) { return null; } if (!int.TryParse(value, out var result)) { Logger.LogError((object)("The targetKey <" + zdoStorageKey + "> zdoKey: <" + value + "> could not be parsed as an int")); return null; } Logger.LogDebug((object)$"Retreiving targetKey <{zdoStorageKey}> zdoKey: <{value}> for name: {player.GetPlayerName()} id: {player.GetPlayerID()}"); return result; } public static bool TryGetWorldUidFromKey(string storageKey, out long worldUid) { long.TryParse(storageKey.Split('_').Last(), out var result); worldUid = result; return result == CurrentWorldId; } public static void RemoveTargetKey(LocationVariation locationVariationType, Player? player) { if (!((Object)(object)player == (Object)null) && !((Object)(object)ZNet.instance == (Object)null)) { string zdoStorageKey = GetZdoStorageKey(locationVariationType); string offsetStorageKey = GetOffsetStorageKey(locationVariationType); if (!TryGetWorldUidFromKey(zdoStorageKey, out var worldUid)) { Logger.LogWarning((object)$"Skipping key deletion due to current world {CurrentWorldId} not matching key worldUid {worldUid}"); return; } player.m_customData.Remove(zdoStorageKey); player.m_customData.Remove(offsetStorageKey); Game.instance.m_playerProfile.SavePlayerData(player); } } public static IEnumerator GetZdoFromStoreAsync(LocationVariation locationVariationType, Player? player, Action<ZDO?> onComplete) { int? zdoFromStore = GetZdoFromStore(locationVariationType, player); if (!zdoFromStore.HasValue) { onComplete(null); yield break; } ZDO zdoOutput = null; yield return ZdoWatchController.Instance.GetZdoFromServerAsync(zdoFromStore.Value, (Action<ZDO>)delegate(ZDO? output) { zdoOutput = output; }); if (zdoOutput == null) { Logger.LogDebug((object)"Removing targetKey as it's ZDO no longer exists"); RemoveTargetKey(locationVariationType, player); } else if (zdoOutput.GetInt("DynamicLocations_Point", 0) != 0) { onComplete(zdoOutput); } } public static void ResetCachedValues() { _cachedLocations.Clear(); } public static Vector3 GetOffset(LocationVariation locationVariationType, Player? player) { //IL_0007: Unknown result type (might be due to invalid IL or missing references) return GetOffset(GetOffsetStorageKey(locationVariationType), player); } public static Vector3 GetOffset(string key, Player? player) { //IL_0009: Unknown result type (might be due to invalid IL or missing references) //IL_001f: Unknown result type (might be due to invalid IL or missing references) //IL_003d: Unknown result type (might be due to invalid IL or missing references) //IL_0035: Unknown result type (might be due to invalid IL or missing references) if ((Object)(object)player == (Object)null) { return Vector3.zero; } if (!player.m_customData.TryGetValue(key, out var value)) { return Vector3.zero; } return (Vector3)(((??)StringToVector3(value)) ?? Vector3.zero); } public static ZDO? SetZdo(LocationVariation locationVaration, Player? player, ZDO? zdo) { //IL_00af: Unknown result type (might be due to invalid IL or missing references) if ((Object)(object)player == (Object)null) { return null; } if (!Object.op_Implicit((Object)(object)ZNet.instance)) { return null; } if (zdo == null) { return null; } string zdoStorageKey = GetZdoStorageKey(locationVaration); int num = default(int); if (!ZdoWatchController.GetPersistentID(zdo, ref num)) { Logger.LogWarning((object)$"No persistent id found for dynamicObj {zdo}"); return null; } zdo.Set("DynamicLocations_Point", 1); if (player.m_customData.TryGetValue(zdoStorageKey, out var _)) { player.m_customData[zdoStorageKey] = num.ToString(); } else { player.m_customData.Add(zdoStorageKey, num.ToString()); } if (!player.m_customData.ContainsKey(zdoStorageKey)) { Logger.LogError((object)"Zdo string failed to set on player.customData"); } Logger.LogDebug((object)$"Setting key: {zdoStorageKey}, uid: {zdo.m_uid} for name: {player.GetPlayerName()} id: {player.GetPlayerID()}"); Game.instance.m_playerProfile.SavePlayerData(player); return zdo; } public static Vector3? SetOffset(LocationVariation locationVariationType, Player player, Vector3 offset) { //IL_0007: Unknown result type (might be due to invalid IL or missing references) return SetOffset(GetOffsetStorageKey(locationVariationType), player, offset); } public static Vector3? SetOffset(string key, Player player, Vector3 offset) { //IL_0012: Unknown result type (might be due to invalid IL or missing references) //IL_0017: Unknown result type (might be due to invalid IL or missing references) //IL_004d: Unknown result type (might be due to invalid IL or missing references) //IL_0058: Unknown result type (might be due to invalid IL or missing references) if (!Object.op_Implicit((Object)(object)player)) { return null; } if (Vector3.zero == offset) { if (player.m_customData.TryGetValue(key, out var _)) { player.m_customData.Remove(key); } return null; } player.m_customData[key] = Vector3ToString(offset); return offset; } public static string GetOffsetStorageKey(LocationVariation locationVariationType) { return locationVariationType switch { LocationVariation.Spawn => GetSpawnZdoOffsetKey(), LocationVariation.Logout => GetLogoutZdoOffsetKey(), _ => throw new ArgumentOutOfRangeException("locationVariationType", locationVariationType, null), }; } public static string GetZdoStorageKey(LocationVariation locationVariationType) { return locationVariationType switch { LocationVariation.Spawn => GetSpawnZdoKey(), LocationVariation.Logout => GetLogoutZdoKey(), _ => throw new ArgumentOutOfRangeException("locationVariationType", locationVariationType, null), }; } public static bool SetLocationTypeData(LocationVariation locationVariation, Player player, ZDO zdo, Vector3 offset) { //IL_0007: Unknown result type (might be due to invalid IL or missing references) Vector3? offset2 = SetOffset(GetOffsetStorageKey(locationVariation), player, offset); ZDO val = SetZdo(locationVariation, player, zdo); if (val == null) { return false; } SetCachedDynamicLocation(locationVariation, new CacheLocationItem { Zdo = val, Offset = offset2 }); return true; } public static void SaveWorldData() { World.GetWorldSavePath((FileSource)0); _ = Game.instance.m_devWorldName + "_mod_dynamic_locations.json"; } } public class LoginAPIController { internal static readonly Dictionary<string, DynamicLoginIntegration> LoginIntegrations = new Dictionary<string, DynamicLoginIntegration>(); internal static readonly Dictionary<string, DynamicLoginIntegration> DisabledLoginIntegrations = new Dictionary<string, DynamicLoginIntegration>(); internal static List<DynamicLoginIntegration> loginIntegrationsByPriority = new List<DynamicLoginIntegration>(); private PlayerSpawnController? _playerSpawnController => PlayerSpawnController.Instance; private static string? GetModIntegrationId(DynamicLoginIntegration integration) { if (integration.Guid != "") { return integration.Guid; } Logger.LogWarning((object)"Invalid guid detected, make sure the BepInPlugin guid is a valid number"); return null; } public static List<DynamicLoginIntegration> OrderItems(List<DynamicLoginIntegration> items) { Dictionary<string, DynamicLoginIntegration> itemLookup = items.ToDictionary((DynamicLoginIntegration i) => i.Guid); List<DynamicLoginIntegration> result = new List<DynamicLoginIntegration>(); HashSet<string> placed = new HashSet<string>(); foreach (DynamicLoginIntegration item in items.OrderBy((DynamicLoginIntegration i) => i.Guid)) { AddItemWithDependencies(item, itemLookup, result, placed); } return result; } private static void AddItemWithDependencies(DynamicLoginIntegration item, Dictionary<string, DynamicLoginIntegration> itemLookup, List<DynamicLoginIntegration> result, HashSet<string> placed) { if (placed.Contains(item.Guid)) { return; } foreach (string runAfterPlugin in item.RunAfterPlugins) { if (itemLookup.TryGetValue(runAfterPlugin, out DynamicLoginIntegration value)) { AddItemWithDependencies(value, itemLookup, result, placed); } } result.Add(item); placed.Add(item.Guid); foreach (string runBeforePlugin in item.RunBeforePlugins) { if (itemLookup.TryGetValue(runBeforePlugin, out DynamicLoginIntegration value2)) { AddItemWithDependencies(value2, itemLookup, result, placed); } } } internal static void UpdateIntegrations() { foreach (string disabledLoginApiIntegration in DynamicLocationsConfig.DisabledLoginApiIntegrations) { if (LoginIntegrations.ContainsKey(disabledLoginApiIntegration)) { LoginIntegrations.Remove(disabledLoginApiIntegration); } } foreach (KeyValuePair<string, DynamicLoginIntegration> disabledLoginIntegration in DisabledLoginIntegrations) { bool flag = false; foreach (string disabledLoginApiIntegration2 in DynamicLocationsConfig.DisabledLoginApiIntegrations) { if (DisabledLoginIntegrations.ContainsKey(disabledLoginApiIntegration2)) { flag = true; } } if (!flag) { LoginIntegrations.Add(disabledLoginIntegration.Key, disabledLoginIntegration.Value); } } loginIntegrationsByPriority = OrderItems(LoginIntegrations.Values.ToList()); foreach (DynamicLoginIntegration item in loginIntegrationsByPriority) { Logger.LogInfo((object)$"item ----> name:{item.Name}, guid: {item.Guid}, priority: {item.Priority}"); } } public static bool AddLoginApiIntegration(DynamicLoginIntegration loginIntegration) { string modIntegrationId = GetModIntegrationId(loginIntegration); if (modIntegrationId == null) { return false; } if (!LoginIntegrations.ContainsKey(modIntegrationId)) { LoginIntegrations.Add(modIntegrationId, loginIntegration); UpdateIntegrations(); return true; } if (loginIntegration.LoginPrefabHashCode == 0) { Logger.LogWarning((object)$"LoginIntegration provided invalid prefab identifier, the hashcode was {loginIntegration.LoginPrefabHashCode}."); } if (DynamicLocationsConfig.IsDebug) { if (!ZNetScene.instance.m_namedPrefabs.TryGetValue(loginIntegration.LoginPrefabHashCode, out var value)) { Logger.LogError((object)$"Prefab not found for stableHashCode {loginIntegration.LoginPrefabHashCode}"); } else { Logger.LogDebug((object)$"Found prefab for stableHashCode {loginIntegration.LoginPrefabHashCode} name {((Object)value).name}"); } } Logger.LogError((object)"Could not integrate component due to collision in registered plugin GUID and plugin_version, this ModAPI plugin will not be loaded. Make sure your plugin only creates 1 instance of ModLoginApi and that your plugin GUID or plugin.Name_plugin_Version are unique."); return false; } private static void LogResults(DynamicLoginIntegration? selectedIntegration) { if (DynamicLocationsConfig.IsDebug) { Logger.LogDebug((object)((selectedIntegration != null) ? ("Successfully handled ModApi " + selectedIntegration.Name + " matched") : "No matches found for registered integrations")); } } public static IEnumerator RunAllIntegrations_OnLoginMoveToZdo(ZDO zdo, Vector3? offset, PlayerSpawnController playerSpawnController) { if ((Object)(object)playerSpawnController == (Object)null) { yield break; } DynamicLoginIntegration selectedIntegration = null; foreach (DynamicLoginIntegration item in loginIntegrationsByPriority) { if (item.OnLoginMatchZdoPrefab(zdo)) { selectedIntegration = item; yield return item.API_OnLoginMoveToZDO(zdo, offset, playerSpawnController); break; } } if (selectedIntegration != null) { yield return (object)new WaitUntil((Func<bool>)(() => selectedIntegration.IsComplete)); } LogResults(selectedIntegration); } } public class PlayerSpawnController : MonoBehaviour { public delegate TResult Func<in T, out TResult>(T arg); internal bool CanUpdateLogoutPoint = true; internal bool CanRemoveLogoutAfterSync = true; internal bool IsTeleportingToDynamicLocation; private bool IsRunningFindDynamicZdo; public static Dictionary<long, PlayerSpawnController> Instances = new Dictionary<long, PlayerSpawnController>(); public static PlayerSpawnController? Instance; public static Coroutine? MoveToLogoutRoutine; public static Coroutine? MoveToSpawnRoutine; internal static List<DebugSafeTimer> Timers = new List<DebugSafeTimer>(); private bool MovePlayerToZdoComplete; private static Player? player => Player.m_localPlayer; private void Awake() { Setup(); } private void Update() { DebugSafeTimer.UpdateTimersFromList(Timers); } public void DEBUG_MoveTo(LocationVariation locationVariationType) { CanUpdateLogoutPoint = true; CanRemoveLogoutAfterSync = false; switch (locationVariationType) { case LocationVariation.Spawn: Instance?.MovePlayerToSpawnPoint(); break; case LocationVariation.Logout: Instance?.MovePlayerToLogoutPoint(); break; default: throw new ArgumentOutOfRangeException("locationVariationType", locationVariationType, null); } } internal void Reset() { IsRunningFindDynamicZdo = false; IsTeleportingToDynamicLocation = false; CanUpdateLogoutPoint = true; CanRemoveLogoutAfterSync = true; MovePlayerToZdoComplete = true; ResetRoutine(ref MoveToLogoutRoutine); ResetRoutine(ref MoveToSpawnRoutine); } internal void OnMovePlayerToZdoComplete(bool success = false, string errorMessage = "OnMovePlayerToZdo exited but failed") { Reset(); Timers.Clear(); IsTeleportingToDynamicLocation = false; MovePlayerToZdoComplete = true; if (!success) { Logger.LogError((object)errorMessage); } } internal static void ResetRoutine(ref Coroutine? routine) { if (routine != null) { PlayerSpawnController? instance = Instance; if (instance != null) { ((MonoBehaviour)instance).StopCoroutine(routine); } routine = null; } } private void OnDestroy() { Reset(); Logger.LogDebug((object)"Called onDestroy"); } private void OnDisable() { Reset(); ((MonoBehaviour)this).StopAllCoroutines(); } private void Setup() { Instance = this; _ = (Object)(object)player == (Object)null; } public bool PersistDynamicPoint(ZDO zdo, LocationVariation locationVariationType, out int id) { id = 0; if ((Object)(object)ZdoWatchController.Instance == (Object)null) { return false; } id = ZdoWatchController.Instance.GetOrCreatePersistentID(zdo); if (id == 0) { if (locationVariationType == LocationVariation.Spawn) { Logger.LogError((object)"No persistent ID returned for bed, this should not be possible. Please report this error"); RemoveDynamicPoint(zdo, locationVariationType); } return false; } AddDynamicPoint(zdo, locationVariationType); return true; } public void AddDynamicPoint(ZDO zdo, LocationVariation locationVariationType) { zdo.Set("DynamicLocations_Point", 1); } public void RemoveDynamicPoint(ZDO? zdo, LocationVariation locationVariationType) { LocationController.RemoveZdoTarget(locationVariationType, player); if (zdo != null) { zdo.RemoveInt("DynamicLocations_Point"); } } public bool SyncBedSpawnPoint(ZDO zdo, Bed bed) { //IL_0031: Unknown result type (might be due to invalid IL or missing references) //IL_0040: Unknown result type (might be due to invalid IL or missing references) //IL_0045: Unknown result type (might be due to invalid IL or missing references) if ((Object)(object)player == (Object)null) { return false; } if (!bed.IsMine()) { return false; } PersistDynamicPoint(zdo, LocationVariation.Spawn, out var _); return LocationController.SetLocationTypeData(LocationVariation.Spawn, player, zdo, ((Component)bed).transform.position - ((Component)player).transform.position); } public bool SyncLogoutPoint(ZDO? zdo, bool shouldRemove = false) { //IL_00a6: Unknown result type (might be due to invalid IL or missing references) //IL_00b5: Unknown result type (might be due to invalid IL or missing references) //IL_00d1: Unknown result type (might be due to invalid IL or missing references) if ((Object)(object)ZNet.instance == (Object)null) { return false; } if (zdo == null && !shouldRemove) { Logger.LogError((object)"ZDO not found for netview, this likely means something is wrong with the are it is being called in"); return false; } if (shouldRemove) { RemoveDynamicPoint(zdo, LocationVariation.Logout); Game.instance.m_playerProfile.SavePlayerData(player); return true; } int id; bool flag = PersistDynamicPoint(zdo, LocationVariation.Logout, out id); if (!shouldRemove && !flag) { Logger.LogDebug((object)"vehicleZdoId is invalid"); return false; } if (LocationController.GetZdoFromStore(LocationVariation.Logout, player) == id) { Logger.LogDebug((object)"Matching ZDOID found already stored, skipping sync/save"); return false; } if ((Object)(object)player == (Object)null) { return false; } if (((Component)player).transform.localPosition != ((Component)player).transform.position) { LocationController.SetOffset(LocationVariation.Logout, player, ((Component)player).transform.localPosition); } LocationController.SetZdo(LocationVariation.Logout, player, zdo); Game.instance.m_playerProfile.SavePlayerData(player); return true; } [UsedImplicitly] public bool DynamicTeleport(Vector3 position, Quaternion rotation) { //IL_002e: Unknown result type (might be due to invalid IL or missing references) //IL_002f: Unknown result type (might be due to invalid IL or missing references) if ((Object)(object)player == (Object)null) { return false; } player.m_teleportCooldown = 15f; player.m_teleporting = false; return ((Character)player).TeleportTo(position, rotation, !DynamicLocationsConfig.DebugDisableDistancePortal.Value); } public void MovePlayerToLogoutPoint() { MoveToLogoutRoutine = ((MonoBehaviour)this).StartCoroutine(UpdateLocation(LocationVariation.Logout)); } public IEnumerator FindDynamicZdo(LocationVariation locationVariationType, Action<ZDO?> onComplete, bool shouldAdjustReferencePoint = false) { IsRunningFindDynamicZdo = true; ZDO zdoOutput = null; yield return LocationController.GetZdoFromStoreAsync(locationVariationType, player, delegate(ZDO? output) { zdoOutput = output; }); onComplete(zdoOutput); if (shouldAdjustReferencePoint && (Object)(object)ZNet.instance != (Object)null && zdoOutput != null) { ZNet.instance.SetReferencePosition(zdoOutput.GetPosition()); } IsRunningFindDynamicZdo = false; } private IEnumerator UpdateLocation(LocationVariation locationVariationType) { DebugSafeTimer timer = DebugSafeTimer.StartNew(Timers); IsTeleportingToDynamicLocation = false; Vector3 offset = LocationController.GetOffset(locationVariationType, player); ZDO zdoOutput = null; yield return FindDynamicZdo(locationVariationType, delegate(ZDO? output) { zdoOutput = output; }); if (zdoOutput == null) { yield break; } switch (locationVariationType) { case LocationVariation.Spawn: yield return MovePlayerToZdo(zdoOutput, offset); break; case LocationVariation.Logout: yield return LoginAPIController.RunAllIntegrations_OnLoginMoveToZdo(zdoOutput, offset, this); break; default: throw new ArgumentOutOfRangeException("locationVariationType", locationVariationType, null); } IsTeleportingToDynamicLocation = false; LocationVariation locationVariation = locationVariationType; if (locationVariation != 0) { if (locationVariation != LocationVariation.Logout || !((Object)(object)player != (Object)null)) { throw new ArgumentOutOfRangeException("locationVariationType", locationVariationType, null); } if (CanRemoveLogoutAfterSync && DynamicLocationsConfig.DEBUG_ShouldNotRemoveTargetKey.Value) { LocationController.RemoveZdoTarget(LocationVariation.Logout, player); } } timer.Clear(); yield return true; } public Coroutine MovePlayerToSpawnPoint() { ResetRoutine(ref MoveToSpawnRoutine); ResetRoutine(ref MoveToLogoutRoutine); MoveToSpawnRoutine = ((MonoBehaviour)this).StartCoroutine(UpdateLocation(LocationVariation.Spawn)); return MoveToSpawnRoutine; } private void SyncPlayerPosition(Vector3 newPosition) { //IL_0042: Unknown result type (might be due to invalid IL or missing references) //IL_0057: Unknown result type (might be due to invalid IL or missing references) //IL_0058: Unknown result type (might be due to invalid IL or missing references) //IL_007f: Unknown result type (might be due to invalid IL or missing references) //IL_0086: Unknown result type (might be due to invalid IL or missing references) //IL_008d: Unknown result type (might be due to invalid IL or missing references) //IL_008e: Unknown result type (might be due to invalid IL or missing references) //IL_00a2: Unknown result type (might be due to invalid IL or missing references) //IL_0069: Unknown result type (might be due to invalid IL or missing references) Logger.LogDebug((object)"Running PlayerPosition Sync"); if (ZNetView.m_forceDisableInit || (Object)(object)player == (Object)null) { return; } ZDO zDO = ((Character)player).m_nview.GetZDO(); if (zDO == null) { Logger.LogDebug((object)"Player zdo invalid exiting"); return; } Logger.LogDebug((object)$"Syncing Player Position and sector, {newPosition}"); if (!ZoneSystem.instance.IsZoneLoaded(ZoneSystem.GetZone(newPosition))) { Logger.LogDebug((object)$"zone not loaded, exiting SyncPlayerPosition for position: {newPosition}"); return; } ZNet.instance.SetReferencePosition(newPosition); zDO.SetPosition(newPosition); zDO.SetSector(ZoneSystem.GetZone(newPosition)); ((Component)player).transform.position = newPosition; } public static bool HasExpiredTimer(Stopwatch timer, int timeInMs = 1000) { int num = ((timeInMs > 1000) ? timeInMs : DynamicLocationsConfig.LocationControlsTimeoutInMs.Value); return timer.ElapsedMilliseconds > num; } public static bool HasExpiredTimer(DebugSafeTimer timer, int timeInMs = 1000) { int num = ((timeInMs > 1000) ? timeInMs : DynamicLocationsConfig.LocationControlsTimeoutInMs.Value); return timer.ElapsedMilliseconds > (float)num; } [UsedImplicitly] public bool CanFreezePlayer(bool val) { return !DynamicLocationsConfig.DebugDisableFreezePlayerTeleportMechanics.Value && val; } public IEnumerator MovePlayerToZdo(ZDO? zdo, Vector3? offset, bool freezePlayerOnTeleport = false, bool shouldKeepPlayerFrozen = false) { ZDO zdo2 = zdo; if (!Object.op_Implicit((Object)(object)player) || zdo2 == null) { OnMovePlayerToZdoComplete(); yield break; } DebugSafeTimer timer = DebugSafeTimer.StartNew(); bool hasKinematicPlayerFreeze = CanFreezePlayer(freezePlayerOnTeleport); bool hasKeepPlayerFrozen = CanFreezePlayer(shouldKeepPlayerFrozen); if (DynamicLocationsConfig.IsDebug) { Logger.LogDebug((object)"Running MovePlayerToZdo"); } Vector3 val = Vector3.up * (float)DynamicLocationsConfig.RespawnHeightOffset.Value; Vector3 position = zdo2.GetPosition() + val; IsTeleportingToDynamicLocation = DynamicTeleport(position, zdo2.GetRotation()); Vector2i zone = ZoneSystem.GetZone(zdo2.GetPosition()); ZoneSystem.instance.PokeLocalZone(zone); bool zoneIsNotLoaded = false; while (!zoneIsNotLoaded) { zone = ZoneSystem.GetZone(zdo2.GetPosition()); zoneIsNotLoaded = ZoneSystem.instance.IsZoneLoaded(zone); yield return (object)new WaitForFixedUpdate(); } if (!IsTeleportingToDynamicLocation) { OnMovePlayerToZdoComplete(); Logger.LogError((object)"Teleport command failed for player, exiting dynamic spawn MovePlayerToZdo."); yield break; } if ((Object)(object)player != (Object)null && CanFreezePlayer(freezePlayerOnTeleport) && ((Character)player).IsDebugFlying()) { player.ToggleDebugFly(); } ZNetView zdoNetViewInstance = null; zone = ZoneSystem.GetZone(zdo2.GetPosition()); ZoneSystem.instance.PokeLocalZone(zone); yield return (object)new WaitUntil((Func<bool>)(() => !((Character)Player.m_localPlayer).IsTeleporting() || HasExpiredTimer(timer, DynamicLocationsConfig.LocationControlsTimeoutInMs.Value))); zdoNetViewInstance = ZNetScene.instance.FindInstance(zdo2); yield return (object)new WaitUntil((Func<bool>)delegate { zdoNetViewInstance = ZNetScene.instance.FindInstance(zdo2); return (Object)(object)zdoNetViewInstance != (Object)null || HasExpiredTimer(timer, DynamicLocationsConfig.LocationControlsTimeoutInMs.Value); }); if (HasExpiredTimer(timer, DynamicLocationsConfig.LocationControlsTimeoutInMs.Value)) { Logger.LogError((object)"Error attempting to find NetView instance of the ZDO"); yield break; } if ((Object)(object)player != (Object)null && hasKinematicPlayerFreeze && !hasKeepPlayerFrozen && ((Character)player).IsDebugFlying()) { player.ToggleDebugFly(); } if (DynamicLocationsConfig.DebugForceUpdatePositionAfterTeleport.Value && DynamicLocationsConfig.DebugForceUpdatePositionDelay.Value > 0f) { yield return (object)new WaitForSeconds(DynamicLocationsConfig.DebugForceUpdatePositionDelay.Value); } if ((Object)(object)player != (Object)null && DynamicLocationsConfig.DebugForceUpdatePositionAfterTeleport.Value) { ZNetView obj = zdoNetViewInstance; Vector3? obj2; if (obj == null) { obj2 = null; } else { Vector3 position2 = ((Component)obj).transform.position; Vector3? val2 = offset; obj2 = (val2.HasValue ? new Vector3?(position2 + val2.GetValueOrDefault()) : null); } position = (Vector3)(((??)obj2) ?? zdo2.GetPosition()) + Vector3.up * (float)DynamicLocationsConfig.RespawnHeightOffset.Value; ((Component)player).transform.position = position; } timer.Clear(); yield return null; } } } namespace DynamicLocations.Constants { public enum LocationVariation { Spawn, Logout } public static class LocationVariationUtils { public const string LogoutString = "logout"; public const string SpawnString = "spawn"; public static LocationVariation? ToLocationVaration(string? locationVarationString) { string text = locationVarationString?.ToLower(); if (!(text == "logout")) { if (text == "spawn") { return LocationVariation.Spawn; } return null; } return LocationVariation.Logout; } } public static class ZdoVarKeys { public const string DynamicLocationsPoint = "DynamicLocations_Point"; } } namespace DynamicLocations.Config { public static class DynamicLocationsConfig { public static ConfigEntry<string> DisabledLoginApiIntegrationsString; private const string MainSection = "Main"; private const string DebugSection = "Debug"; public static ConfigFile? Config { get; private set; } public static ConfigEntry<int> LocationControlsTimeoutInMs { get; private set; } public static List<string> DisabledLoginApiIntegrations => DisabledLoginApiIntegrationsString?.Value.Split(',').ToList() ?? new List<string>(); public static ConfigEntry<bool> HasCustomSpawnDelay { get; private set; } public static ConfigEntry<bool> DEBUG_ShouldNotRemoveTargetKey { get; private set; } public static ConfigEntry<float> CustomSpawnDelay { get; private set; } public static ConfigEntry<int> RespawnHeightOffset { get; set; } public static ConfigEntry<bool> EnableDynamicSpawnPoint { get; private set; } public static ConfigEntry<bool> EnableDynamicLogoutPoint { get; private set; } public static ConfigEntry<bool> DebugDisableFreezePlayerTeleportMechanics { get; private set; } private static ConfigEntry<bool> Debug { get; set; } public static bool IsDebug => Debug.Value; public static ConfigEntry<bool> DebugDisableDistancePortal { get; private set; } public static ConfigEntry<float> DebugForceUpdatePositionDelay { get; private set; } public static ConfigEntry<bool> DebugForceUpdatePositionAfterTeleport { get; private set; } public static void BindConfig(ConfigFile config) { //IL_0020: Unknown result type (might be due to invalid IL or missing references) //IL_0025: Unknown result type (might be due to invalid IL or missing references) //IL_002c: Unknown result type (might be due to invalid IL or missing references) //IL_0039: Expected O, but got Unknown //IL_0039: Unknown result type (might be due to invalid IL or missing references) //IL_004d: Expected O, but got Unknown //IL_007e: Unknown result type (might be due to invalid IL or missing references) //IL_0083: Unknown result type (might be due to invalid IL or missing references) //IL_008a: Unknown result type (might be due to invalid IL or missing references) //IL_0097: Expected O, but got Unknown //IL_0097: Unknown result type (might be due to invalid IL or missing references) //IL_00ab: Expected O, but got Unknown //IL_00ca: Unknown result type (might be due to invalid IL or missing references) //IL_00cf: Unknown result type (might be due to invalid IL or missing references) //IL_00d6: Unknown result type (might be due to invalid IL or missing references) //IL_00e3: Expected O, but got Unknown //IL_00e3: Unknown result type (might be due to invalid IL or missing references) //IL_00f7: Expected O, but got Unknown //IL_0128: Unknown result type (might be due to invalid IL or missing references) //IL_012d: Unknown result type (might be due to invalid IL or missing references) //IL_0134: Unknown result type (might be due to invalid IL or missing references) //IL_0141: Expected O, but got Unknown //IL_0141: Unknown result type (might be due to invalid IL or missing references) //IL_0155: Expected O, but got Unknown //IL_0178: Unknown result type (might be due to invalid IL or missing references) //IL_017d: Unknown result type (might be due to invalid IL or missing references) //IL_0184: Unknown result type (might be due to invalid IL or missing references) //IL_0191: Expected O, but got Unknown //IL_0191: Unknown result type (might be due to invalid IL or missing references) //IL_01a5: Expected O, but got Unknown //IL_01c4: Unknown result type (might be due to invalid IL or missing references) //IL_01c9: Unknown result type (might be due to invalid IL or missing references) //IL_01d0: Unknown result type (might be due to invalid IL or missing references) //IL_01dd: Expected O, but got Unknown //IL_01dd: Unknown result type (might be due to invalid IL or missing references) //IL_01f1: Expected O, but got Unknown //IL_0210: Unknown result type (might be due to invalid IL or missing references) //IL_0215: Unknown result type (might be due to invalid IL or missing references) //IL_021c: Unknown result type (might be due to invalid IL or missing references) //IL_0229: Expected O, but got Unknown //IL_0229: Unknown result type (might be due to invalid IL or missing references) //IL_023d: Expected O, but got Unknown //IL_026e: Unknown result type (might be due to invalid IL or missing references) //IL_0273: Unknown result type (might be due to invalid IL or missing references) //IL_027a: Unknown result type (might be due to invalid IL or missing references) //IL_0287: Expected O, but got Unknown //IL_0287: Unknown result type (might be due to invalid IL or missing references) //IL_029b: Expected O, but got Unknown //IL_02ba: Unknown result type (might be due to invalid IL or missing references) //IL_02bf: Unknown result type (might be due to invalid IL or missing references) //IL_02c6: Unknown result type (might be due to invalid IL or missing references) //IL_02d3: Expected O, but got Unknown //IL_02d3: Unknown result type (might be due to invalid IL or missing references) //IL_02e7: Expected O, but got Unknown //IL_0306: Unknown result type (might be due to invalid IL or missing references) //IL_030b: Unknown result type (might be due to invalid IL or missing references) //IL_0312: Unknown result type (might be due to invalid IL or missing references) //IL_031f: Expected O, but got Unknown //IL_031f: Unknown result type (might be due to invalid IL or missing references) //IL_0333: Expected O, but got Unknown //IL_0352: Unknown result type (might be due to invalid IL or missing references) //IL_0357: Unknown result type (might be due to invalid IL or missing references) //IL_035e: Unknown result type (might be due to invalid IL or missing references) //IL_036b: Expected O, but got Unknown //IL_036b: Unknown result type (might be due to invalid IL or missing references) //IL_037f: Expected O, but got Unknown //IL_03a6: Unknown result type (might be due to invalid IL or missing references) //IL_03ab: Unknown result type (might be due to invalid IL or missing references) //IL_03b2: Unknown result type (might be due to invalid IL or missing references) //IL_03bf: Expected O, but got Unknown //IL_03bf: Unknown result type (might be due to invalid IL or missing references) //IL_03d3: Expected O, but got Unknown //IL_03f2: Unknown result type (might be due to invalid IL or missing references) //IL_03f7: Unknown result type (might be due to invalid IL or missing references) //IL_03fe: Unknown result type (might be due to invalid IL or missing references) //IL_040b: Expected O, but got Unknown //IL_040b: Unknown result type (might be due to invalid IL or missing references) //IL_041f: Expected O, but got Unknown Config = config; DEBUG_ShouldNotRemoveTargetKey = BepInExConfigUtils.BindUnique<bool>(config, "Main", "DEBUG_ShouldNotRemoveTargetKey", true, new ConfigDescription("Debug only command: will prevent removing of data on the player. This is meant to debug issues with the player spawn points. Should not be enabled in production builds.", (AcceptableValueBase)null, new object[1] { (object)new ConfigurationManagerAttributes { IsAdminOnly = true, IsAdvanced = true } }), "C:\\Users\\fre\\dev\\repos\\ValheimMods\\src\\DynamicLocations\\DynamicLocations.Config\\DynamicLocationConfig.cs", 135); LocationControlsTimeoutInMs = BepInExConfigUtils.BindUnique<int>(config, "Main", "LocationControls Timeout In Ms", 20000, new ConfigDescription("Allows for setting the delay in which the spawn will exit logic to prevent degraded performance.", (AcceptableValueBase)(object)new AcceptableValueRange<int>(1000, 40000), new object[1] { (object)new ConfigurationManagerAttributes { IsAdminOnly = true, IsAdvanced = false } }), "C:\\Users\\fre\\dev\\repos\\ValheimMods\\src\\DynamicLocations\\DynamicLocations.Config\\DynamicLocationConfig.cs", 144); HasCustomSpawnDelay = BepInExConfigUtils.BindUnique<bool>(config, "Main", "HasCustomSpawnDelay", false, new ConfigDescription("Enables custom spawn delay. This is meant to speed-up the game.", (AcceptableValueBase)null, new object[1] { (object)new ConfigurationManagerAttributes { IsAdminOnly = true, IsAdvanced = false } }), "C:\\Users\\fre\\dev\\repos\\ValheimMods\\src\\DynamicLocations\\DynamicLocations.Config\\DynamicLocationConfig.cs", 153); CustomSpawnDelay = BepInExConfigUtils.BindUnique<float>(config, "Main", "CustomSpawnDelay", 1f, new ConfigDescription("Will significantly speed-up respawn and login process. This mod will NOT support respawn delays above default(10) seconds, this is too punishing for players. Try to make other consequences instead of preventing people from playing.", (AcceptableValueBase)(object)new AcceptableValueRange<float>(0f, 10f), new object[1] { (object)new ConfigurationManagerAttributes { IsAdminOnly = true, IsAdvanced = false } }), "C:\\Users\\fre\\dev\\repos\\ValheimMods\\src\\DynamicLocations\\DynamicLocations.Config\\DynamicLocationConfig.cs", 162); DisabledLoginApiIntegrationsString = BepInExConfigUtils.BindUnique<string>(config, "Main", "DisabledLoginApiIntegrations", "", new ConfigDescription("A list of disabled plugins by GUID or name. Each item must be separated by a comma. This list will force disable any plugins matching either the guid or name. e.g. if you don't want ValheimRAFT to be enabling dynamic locations login integrations add \"zolantris.ValheimRAFT\" or \"ValheimRAFT.2.3.0\".", (AcceptableValueBase)null, new object[1] { (object)new ConfigurationManagerAttributes { IsAdminOnly = false, IsAdvanced = false } }), "C:\\Users\\fre\\dev\\repos\\ValheimMods\\src\\DynamicLocations\\DynamicLocations.Config\\DynamicLocationConfig.cs", 171); DebugDisableFreezePlayerTeleportMechanics = BepInExConfigUtils.BindUnique<bool>(config, "Debug", "DEBUG_DisableFreezePlayerMechanics", false, new ConfigDescription("This will disable freezing of players from integrations. Do not disable this unless you know what you are doing. Freezing is used to prevent physics happening during teleport.", (AcceptableValueBase)null, new object[1] { (object)new ConfigurationManagerAttributes { IsAdminOnly = false, IsAdvanced = false } }), "C:\\Users\\fre\\dev\\repos\\ValheimMods\\src\\DynamicLocations\\DynamicLocations.Config\\DynamicLocationConfig.cs", 180); DebugDisableDistancePortal = BepInExConfigUtils.BindUnique<bool>(config, "Debug", "DebugDistancePortal", false, new ConfigDescription("distance portal enabled, disabling this could break portals", (AcceptableValueBase)null, new object[1] { (object)new ConfigurationManagerAttributes { IsAdminOnly = true, IsAdvanced = true } }), "C:\\Users\\fre\\dev\\repos\\ValheimMods\\src\\DynamicLocations\\DynamicLocations.Config\\DynamicLocationConfig.cs", 189); DebugForceUpdatePositionDelay = BepInExConfigUtils.BindUnique<float>(config, "Debug", "DebugForceUpdatePositionDelay", 0f, new ConfigDescription("distance portal enabled, disabling this could break portals", (AcceptableValueBase)(object)new AcceptableValueRange<float>(0f, 5f), new object[1] { (object)new ConfigurationManagerAttributes { IsAdminOnly = true, IsAdvanced = true } }), "C:\\Users\\fre\\dev\\repos\\ValheimMods\\src\\DynamicLocations\\DynamicLocations.Config\\DynamicLocationConfig.cs", 199); DebugForceUpdatePositionAfterTeleport = BepInExConfigUtils.BindUnique<bool>(config, "Debug", "DebugForceUpdatePositionAfterTeleport", false, new ConfigDescription("distance portal enabled, disabling this could break portals", (AcceptableValueBase)null, new object[1] { (object)new ConfigurationManagerAttributes { IsAdminOnly = true, IsAdvanced = true } }), "C:\\Users\\fre\\dev\\repos\\ValheimMods\\src\\DynamicLocations\\DynamicLocations.Config\\DynamicLocationConfig.cs", 209); EnableDynamicSpawnPoint = BepInExConfigUtils.BindUnique<bool>(config, "Main", "enableDynamicSpawnPoints", true, new ConfigDescription("Enable dynamic spawn points. This will allow the user to re-spawn in a new area of the map if a vehicle has moved.", (AcceptableValueBase)null, new object[1] { (object)new ConfigurationManagerAttributes { IsAdminOnly = true, IsAdvanced = true } }), "C:\\Users\\fre\\dev\\repos\\ValheimMods\\src\\DynamicLocations\\DynamicLocations.Config\\DynamicLocationConfig.cs", 218); EnableDynamicLogoutPoint = BepInExConfigUtils.BindUnique<bool>(config, "Main", "enableDynamicLogoutPoints", true, new ConfigDescription("Enable dynamic logout points. This will allow the user to login to a new area of the map if a vehicle has moved", (AcceptableValueBase)null, new object[1] { (object)new ConfigurationManagerAttributes { IsAdminOnly = true, IsAdvanced = true } }), "C:\\Users\\fre\\dev\\repos\\ValheimMods\\src\\DynamicLocations\\DynamicLocations.Config\\DynamicLocationConfig.cs", 227); RespawnHeightOffset = BepInExConfigUtils.BindUnique<int>(config, "Main", "respawnHeightOffset", 0, new ConfigDescription("Sets the respawn height for beds. Useful if the player is spawning within the bed instead of above it", (AcceptableValueBase)(object)new AcceptableValueRange<int>(-5, 10), new object[1] { (object)new ConfigurationManagerAttributes { IsAdminOnly = false, IsAdvanced = true } }), "C:\\Users\\fre\\dev\\repos\\ValheimMods\\src\\DynamicLocations\\DynamicLocations.Config\\DynamicLocationConfig.cs", 236); Debug = BepInExConfigUtils.BindUnique<bool>(config, "Main", "debug", false, new ConfigDescription("Enable additional logging and debug drawing around spawn and logout points. Useful for debugging this mod", (AcceptableValueBase)null, new object[1] { (object)new ConfigurationManagerAttributes { IsAdminOnly = true, IsAdvanced = true } }), "C:\\Users\\fre\\dev\\repos\\ValheimMods\\src\\DynamicLocations\\DynamicLocations.Config\\DynamicLocationConfig.cs", 245); DisabledLoginApiIntegrationsString.SettingChanged += delegate { LoginAPIController.UpdateIntegrations(); }; _ = Debug.Value; } } } namespace DynamicLocations.Commands { public class KeyValueSerializer { public static string Serialize(object obj, int indentLevel = 0) { if (obj == null) { return string.Empty; } StringBuilder stringBuilder = new StringBuilder(); string indent = new string(' ', indentLevel * 4); Type type = obj.GetType(); PropertyInfo[] properties = type.GetProperties(BindingFlags.Instance | BindingFlags.Public); FieldInfo[] fields = type.GetFields(BindingFlags.Instance | BindingFlags.Public); PropertyInfo[] array = properties; foreach (PropertyInfo propertyInfo in array) { object value = propertyInfo.GetValue(obj); SerializeValue(stringBuilder, propertyInfo.Name, value, indent, indentLevel); } FieldInfo[] array2 = fields; foreach (FieldInfo fieldInfo in array2) { object value2 = fieldInfo.GetValue(obj); SerializeValue(stringBuilder, fieldInfo.Name, value2, indent, indentLevel); } return stringBuilder.ToString(); } private static void SerializeValue(StringBuilder sb, string name, object value, string indent, int indentLevel) { if (value == null) { sb.AppendLine(indent + name + ": null"); return; } if (value is string || value.GetType().IsPrimitive) { sb.AppendLine($"{indent}{name}: {value}"); return; } if (value is IEnumerable enumerable) { sb.AppendLine(indent + name + ":"); { foreach (object item in enumerable) { SerializeValue(sb, "- Item", item, indent + " ", indentLevel + 1); } return; } } sb.AppendLine(indent + name + ":"); sb.Append(Serialize(value, indentLevel + 1)); } } public class ListAllKeysCommand : ConsoleCommand { public override string Name => "list-all-keys"; public override string Help { get; } = "list all keys"; public override void Run(string[] args) { if (args.Length != 0) { LocationController.DEBUGCOMMAND_ListAllKeys(); } } } public class ModIntegrationsCommand : ConsoleCommand { private const string Indent = "\n- "; public override string Name => "mod-integrations"; public override string Help { get; } = "Lists all mods using this plugin, e.g. ValheimRaft/Vehicles. \n- Name + version will be output only.\n- To see everything add -v will output the whole object per integration."; private static void ModIntegrationsCommands(bool isVerbose) { Logger.LogMessage((object)"Listing all integrations by order"); int num = 1; foreach (DynamicLoginIntegration item in LoginAPIController.loginIntegrationsByPriority) { if (isVerbose) { Logger.LogMessage((object)KeyValueSerializer.Serialize(item)); } else { Logger.LogMessage((object)$"[LoginIntegration]: [index: {num}] -> ModName: {item.Name} ModVersion {item.Version}, priority {item.Priority}, guid: {item.Guid}"); } num++; } } private static bool IsVerboseFlag(string arg) { switch (arg) { case "-v": case "-verbose": case "--verbose": return true; default: return false; } } public override void Run(string[] args) { if (args.Length != 0) { ModIntegrationsCommands(IsVerboseFlag(args.First())); } } public override List<string> CommandOptionList() { return new List<string>(1) { "-v" }; } } public class MoveToCommand : ConsoleCommand { public override bool IsCheat => true; public override string Name => "move-to"; public override string Help { get; } = "Moves to logout point. Requires Admin privileges"; public override void Run(string[] args) { if (args.Length == 0) { Logger.LogMessage((object)("Requires an argument of " + string.Join(",", ((ConsoleCommand)this).CommandOptionList().ToArray()))); return; } string text = args.First(); LocationVariation? locationVariation = LocationVariationUtils.ToLocationVaration(text); if (!locationVariation.HasValue) { Logger.LogMessage((object)("Invalid input " + text)); } else { PlayerSpawnController.Instance?.DEBUG_MoveTo(locationVariation.Value); } } public override List<string> CommandOptionList() { return new List<string>(2) { "logout", "spawn" }; } } public class DynamicLocationsCommands : ConsoleCommand { private enum CommandsEnum { Help, MoveToLocation, ClearAll, ClearSpawn, ClearLogout, ListAllKeys, ListIntegrations } private const string playerClearAllCommand = "playerClearAll"; private const string playerClearSpawnCommand = "playerClearSpawn"; private const string playerClearLogoutCommand = "playerClearLogout"; private const string serverClearAllCommand = "serverClearAll"; private const string helpCommand = "help"; private static readonly ListAllKeysCommand ListAllKeysCommandInstance = new ListAllKeysCommand(); private static readonly ModIntegrationsCommand ModIntegrationsCommandInstance = new ModIntegrationsCommand(); private static readonly MoveToCommand MoveToCommandInstance = new MoveToCommand(); private static string helpCommandItems = string.Join("\n", "DynamicLocationsCLI Mod CLI: ", FormatCommand("playerClearLogout") + " removes logout for the current world, will not change other worlds", FormatCommand("playerClearAll") + " clears all dynamicLogin and dynamicSpawn points for a player for the corresponding world", FormatCommand((ConsoleCommand)(object)MoveToCommandInstance), FormatCommand((ConsoleCommand)(object)ListAllKeysCommandInstance), FormatCommand((ConsoleCommand)(object)ModIntegrationsCommandInstance)); public override string Help => OnHelp(); public override string Name => "dynamic-locations"; private static string FormatCommand(string? command) { if (command != null) { return "<" + command + ">:"; } return ""; } private static string FormatCommand(string command, List<string>? args, string description) { return "<" + command + ">: " + string.Join("", args?.Select((string arg) => " " + FormatCommand(arg)) ?? Array.Empty<string>()) + " " + description; } private static string FormatCommand(ConsoleCommand consoleCommand) { return FormatCommand(consoleCommand.Name, consoleCommand.CommandOptionList(), consoleCommand.Help); } private static string OnHelp() { return helpCommandItems; } private static CommandsEnum? GetCommandArg(string commandString) { if (((ConsoleCommand)ModIntegrationsCommandInstance).Name == commandString) { return CommandsEnum.ListIntegrations; } if (((ConsoleCommand)ListAllKeysCommandInstance).Name == commandString) { return CommandsEnum.ListAllKeys; } if (((ConsoleCommand)MoveToCommandInstance).Name == commandString) { return CommandsEnum.MoveToLocation; } return commandString switch { "playerClearAll" => CommandsEnum.ClearAll, "playerClearLogout" => CommandsEnum.ClearLogout, "help" => CommandsEnum.Help, _ => null, }; } public override void Run(string[] args) { if (args.Length != 0) { ParseFirstArg(args); } } private static void ParseFirstArg(string[]? args) { string text = args?.First() ?? ""; if (text == "") { Logger.LogMessage((object)"Must provide a argument for a command. Please run help for more information."); } CommandsEnum? commandArg = GetCommandArg(text); if (!commandArg.HasValue) { Logger.LogMessage((object)("Command " + text + " not recognized. Please run help for more information.")); return; } string[] array = args?.Skip(1)?.ToArray() ?? Array.Empty<string>(); if (commandArg.HasValue) { switch (commandArg.GetValueOrDefault()) { case CommandsEnum.ClearAll: PlayerClearAll(array); break; case CommandsEnum.ClearSpawn: case CommandsEnum.ClearLogout: case CommandsEnum.ListAllKeys: ((ConsoleCommand)ListAllKeysCommandInstance).Run(array); break; case CommandsEnum.ListIntegrations: ((ConsoleCommand)ModIntegrationsCommandInstance).Run(array); break; case CommandsEnum.Help: OnHelp(); break; case CommandsEnum.MoveToLocation: ((ConsoleCommand)MoveToCommandInstance).Run(array); break; default: throw new ArgumentOutOfRangeException(); } } } private bool IsAdmin() { if (!SynchronizationManager.Instance.PlayerIsAdmin) { Logger.LogMessage((object)"Player is not admin, must be admin to run this command"); return false; } return true; } public static void PlayerClearAll(string[] args) { if (args.Length == 0) { LocationController.DEBUG_RemoveAllDynamicLocationKeys(); } } public void PlayerListAllDynamicLocationKeys() { LocationController.DEBUGCOMMAND_ListAllKeys(); } public static void PlayerClearLogout() { LocationController.DEBUGCOMMAND_RemoveLogout(); } public override List<string> CommandOptionList() { return new List<string>(5) { ((ConsoleCommand)ListAllKeysCommandInstance).Name, ((ConsoleCommand)MoveToCommandInstance).Name, ((ConsoleCommand)ModIntegrationsCommandInstance).Name, "playerClearLogout", "playerClearAll" }; } } } namespace DynamicLocations.API { public class DynamicLoginIntegration { private const int DefaultMovementTimeoutMs = 5000; private readonly DebugSafeTimer _timerInstance = new DebugSafeTimer(); private bool _isRunningOnLoginMoveToZdo; private bool _hasCompleted; private Coroutine? _onLoginMoveToZdoCoroutine; public int LoginPrefabHashCode => Config.LoginPrefabHashCode; internal string Guid => Config.Guid; internal string Name => Config.Name; internal string Version => Config.Version; public bool ShouldFreezePlayer => Config.ShouldFreezePlayer; public List<string> RunBeforePlugins => Config.RunBeforePlugins; public List<string> RunAfterPlugins => Config.RunAfterPlugins; public int Priority { get { if (Config.Priority <= 0) { return 999; } return Config.Priority; } } public int MovementTimeoutMs => GetMovementTimeout(); public bool IsComplete { get { if (_hasCompleted && !_isRunningOnLoginMoveToZdo) { return _onLoginMoveToZdoCoroutine == null; } return false; } } public IntegrationConfig Config { get; set; } protected DynamicLoginIntegration(IntegrationConfig config) { //IL_0001: Unknown result type (might be due to invalid IL or missing references) //IL_000b: Expected O, but got Unknown Config = config; } private int GetMovementTimeout() { int movementTimeout = Config.MovementTimeout; if (movementTimeout < 2000 || movementTimeout > 20000) { return 5000; } return Config.MovementTimeout; } public static IntegrationConfig CreateConfig(BaseUnityPlugin plugin, string zdoTargetPrefabName) { return new IntegrationConfig(plugin, zdoTargetPrefabName); } private void OnStart() { _timerInstance.Restart(); PlayerSpawnController.ResetRoutine(ref _onLoginMoveToZdoCoroutine); _hasCompleted = false; _isRunningOnLoginMoveToZdo = true; } private void OnComplete() { _timerInstance.Reset(); PlayerSpawnController.ResetRoutine(ref _onLoginMoveToZdoCoroutine); _isRunningOnLoginMoveToZdo = false; _hasCompleted = true; } protected internal IEnumerator API_OnLoginMoveToZDO(ZDO zdo, Vector3? offset, PlayerSpawnController playerSpawnController) { OnStart(); _onLoginMoveToZdoCoroutine = ((MonoBehaviour)playerSpawnController).StartCoroutine(OnLoginMoveToZDO(zdo, offset, playerSpawnController)); yield return _onLoginMoveToZdoCoroutine; yield return (object)new WaitUntil((Func<bool>)(() => _onLoginMoveToZdoCoroutine == null || _timerInstance.ElapsedMilliseconds >= (float)GetMovementTimeout())); OnComplete(); yield return true; } protected virtual IEnumerator OnLoginMoveToZDO(ZDO zdo, Vector3? offset, PlayerSpawnController playerSpawnController) { if (DynamicLocationsConfig.IsDebug) { Logger.LogDebug((object)"Not overridden custom handler, running MovePlayerToZdo default call."); } if (OnLoginMatchZdoPrefab(zdo)) { yield return playerSpawnController.MovePlayerToZdo(zdo, (Vector3)(((??)offset) ?? Vector3.zero)); yield return (object)new WaitUntil((Func<bool>)(() => PlayerSpawnController.MoveToLogoutRoutine == null)); } } [UsedImplicitly] public virtual bool OnLoginMatchZdoPrefab(ZDO zdo) { if (LoginPrefabHashCode == 0) { Logger.LogError((object)("Login Prefab Hash was zero, this likely means the mod " + Config.Name + " " + Config.Version + " has not properly been integrated for DynamicLoginIntegration")); return false; } return zdo.GetPrefab() == LoginPrefabHashCode; } } } namespace System.Runtime.CompilerServices { [AttributeUsage(AttributeTargets.Assembly, AllowMultiple = true)] internal sealed class IgnoresAccessChecksToAttribute : Attribute { internal IgnoresAccessChecksToAttribute(string assemblyName) { } } }
plugins\Newtonsoft.Json.dll
Decompiled a week ago
The result has been truncated due to the large size, download it to view full contents!
using System; using System.Collections; using System.Collections.Concurrent; using System.Collections.Generic; using System.Collections.ObjectModel; using System.Collections.Specialized; using System.ComponentModel; using System.Data; using System.Data.SqlTypes; using System.Diagnostics; using System.Diagnostics.CodeAnalysis; using System.Dynamic; using System.Globalization; using System.IO; using System.Linq; using System.Linq.Expressions; using System.Numerics; using System.Reflection; using System.Reflection.Emit; using System.Resources; using System.Runtime.CompilerServices; using System.Runtime.InteropServices; using System.Runtime.Serialization; using System.Runtime.Serialization.Formatters; using System.Runtime.Versioning; using System.Security; using System.Security.Permissions; using System.Text; using System.Text.RegularExpressions; using System.Threading; using System.Threading.Tasks; using System.Xml; using System.Xml.Linq; using Microsoft.CodeAnalysis; using Newtonsoft.Json.Bson; using Newtonsoft.Json.Converters; using Newtonsoft.Json.Linq; using Newtonsoft.Json.Linq.JsonPath; using Newtonsoft.Json.Schema; using Newtonsoft.Json.Serialization; using Newtonsoft.Json.Utilities; [assembly: CompilationRelaxations(8)] [assembly: RuntimeCompatibility(WrapNonExceptionThrows = true)] [assembly: Debuggable(DebuggableAttribute.DebuggingModes.IgnoreSymbolStoreSequencePoints)] [assembly: AllowPartiallyTrustedCallers] [assembly: InternalsVisibleTo("Newtonsoft.Json.Schema, PublicKey=0024000004800000940000000602000000240000525341310004000001000100f561df277c6c0b497d629032b410cdcf286e537c054724f7ffa0164345f62b3e642029d7a80cc351918955328c4adc8a048823ef90b0cf38ea7db0d729caf2b633c3babe08b0310198c1081995c19029bc675193744eab9d7345b8a67258ec17d112cebdbbb2a281487dceeafb9d83aa930f32103fbe1d2911425bc5744002c7")] [assembly: InternalsVisibleTo("Newtonsoft.Json.Tests, PublicKey=0024000004800000940000000602000000240000525341310004000001000100f561df277c6c0b497d629032b410cdcf286e537c054724f7ffa0164345f62b3e642029d7a80cc351918955328c4adc8a048823ef90b0cf38ea7db0d729caf2b633c3babe08b0310198c1081995c19029bc675193744eab9d7345b8a67258ec17d112cebdbbb2a281487dceeafb9d83aa930f32103fbe1d2911425bc5744002c7")] [assembly: InternalsVisibleTo("Newtonsoft.Json.Dynamic, PublicKey=0024000004800000940000000602000000240000525341310004000001000100cbd8d53b9d7de30f1f1278f636ec462cf9c254991291e66ebb157a885638a517887633b898ccbcf0d5c5ff7be85a6abe9e765d0ac7cd33c68dac67e7e64530e8222101109f154ab14a941c490ac155cd1d4fcba0fabb49016b4ef28593b015cab5937da31172f03f67d09edda404b88a60023f062ae71d0b2e4438b74cc11dc9")] [assembly: AssemblyTrademark("")] [assembly: ComVisible(false)] [assembly: Guid("9ca358aa-317b-4925-8ada-4a29e943a363")] [assembly: CLSCompliant(true)] [assembly: TargetFramework(".NETFramework,Version=v4.5", FrameworkDisplayName = ".NET Framework 4.5")] [assembly: AssemblyCompany("Newtonsoft")] [assembly: AssemblyConfiguration("Release")] [assembly: AssemblyCopyright("Copyright © James Newton-King 2008")] [assembly: AssemblyDescription("Json.NET is a popular high-performance JSON framework for .NET")] [assembly: AssemblyFileVersion("13.0.3.27908")] [assembly: AssemblyInformationalVersion("13.0.3+0a2e291c0d9c0c7675d445703e51750363a549ef")] [assembly: AssemblyProduct("Json.NET")] [assembly: AssemblyTitle("Json.NET .NET 4.5")] [assembly: AssemblyMetadata("RepositoryUrl", "https://github.com/JamesNK/Newtonsoft.Json")] [assembly: NeutralResourcesLanguage("en-US")] [assembly: AssemblyVersion("13.0.0.0")] namespace Microsoft.CodeAnalysis { [CompilerGenerated] [Microsoft.CodeAnalysis.Embedded] internal sealed class EmbeddedAttribute : Attribute { } } namespace System.Runtime.CompilerServices { [CompilerGenerated] [Microsoft.CodeAnalysis.Embedded] internal sealed class IsReadOnlyAttribute : Attribute { } [CompilerGenerated] [Microsoft.CodeAnalysis.Embedded] [AttributeUsage(AttributeTargets.Class | AttributeTargets.Property | AttributeTargets.Field | AttributeTargets.Event | AttributeTargets.Parameter | AttributeTargets.ReturnValue | AttributeTargets.GenericParameter, AllowMultiple = false, Inherited = false)] internal sealed class NullableAttribute : Attribute { public readonly byte[] NullableFlags; public NullableAttribute(byte P_0) { NullableFlags = new byte[1] { P_0 }; } public NullableAttribute(byte[] P_0) { NullableFlags = P_0; } } [CompilerGenerated] [Microsoft.CodeAnalysis.Embedded] [AttributeUsage(AttributeTargets.Class | AttributeTargets.Struct | AttributeTargets.Method | AttributeTargets.Interface | AttributeTargets.Delegate, AllowMultiple = false, Inherited = false)] internal sealed class NullableContextAttribute : Attribute { public readonly byte Flag; public NullableContextAttribute(byte P_0) { Flag = P_0; } } } namespace System.Diagnostics.CodeAnalysis { [AttributeUsage(AttributeTargets.Method | AttributeTargets.Property | AttributeTargets.Field | AttributeTargets.Parameter | AttributeTargets.ReturnValue, AllowMultiple = true)] internal sealed class NotNullAttribute : Attribute { } [AttributeUsage(AttributeTargets.Parameter, AllowMultiple = false)] internal sealed class NotNullWhenAttribute : Attribute { public bool ReturnValue { get; } public NotNullWhenAttribute(bool returnValue) { ReturnValue = returnValue; } } [AttributeUsage(AttributeTargets.Property | AttributeTargets.Field | AttributeTargets.Parameter | AttributeTargets.ReturnValue, Inherited = false)] internal sealed class MaybeNullAttribute : Attribute { } [AttributeUsage(AttributeTargets.Property | AttributeTargets.Field | AttributeTargets.Parameter, Inherited = false)] internal sealed class AllowNullAttribute : Attribute { } [AttributeUsage(AttributeTargets.Parameter, Inherited = false)] internal class DoesNotReturnIfAttribute : Attribute { public bool ParameterValue { get; } public DoesNotReturnIfAttribute(bool parameterValue) { ParameterValue = parameterValue; } } } namespace Newtonsoft.Json { public enum ConstructorHandling { Default, AllowNonPublicDefaultConstructor } public enum DateFormatHandling { IsoDateFormat, MicrosoftDateFormat } public enum DateParseHandling { None, DateTime, DateTimeOffset } public enum DateTimeZoneHandling { Local, Utc, Unspecified, RoundtripKind } public class DefaultJsonNameTable : JsonNameTable { private class Entry { internal readonly string Value; internal readonly int HashCode; internal Entry Next; internal Entry(string value, int hashCode, Entry next) { Value = value; HashCode = hashCode; Next = next; } } private static readonly int HashCodeRandomizer; private int _count; private Entry[] _entries; private int _mask = 31; static DefaultJsonNameTable() { HashCodeRandomizer = Environment.TickCount; } public DefaultJsonNameTable() { _entries = new Entry[_mask + 1]; } public override string? Get(char[] key, int start, int length) { if (length == 0) { return string.Empty; } int num = length + HashCodeRandomizer; num += (num << 7) ^ key[start]; int num2 = start + length; for (int i = start + 1; i < num2; i++) { num += (num << 7) ^ key[i]; } num -= num >> 17; num -= num >> 11; num -= num >> 5; int num3 = Volatile.Read(ref _mask); int num4 = num & num3; for (Entry entry = _entries[num4]; entry != null; entry = entry.Next) { if (entry.HashCode == num && TextEquals(entry.Value, key, start, length)) { return entry.Value; } } return null; } public string Add(string key) { if (key == null) { throw new ArgumentNullException("key"); } int length = key.Length; if (length == 0) { return string.Empty; } int num = length + HashCodeRandomizer; for (int i = 0; i < key.Length; i++) { num += (num << 7) ^ key[i]; } num -= num >> 17; num -= num >> 11; num -= num >> 5; for (Entry entry = _entries[num & _mask]; entry != null; entry = entry.Next) { if (entry.HashCode == num && entry.Value.Equals(key, StringComparison.Ordinal)) { return entry.Value; } } return AddEntry(key, num); } private string AddEntry(string str, int hashCode) { int num = hashCode & _mask; Entry entry = new Entry(str, hashCode, _entries[num]); _entries[num] = entry; if (_count++ == _mask) { Grow(); } return entry.Value; } private void Grow() { Entry[] entries = _entries; int num = _mask * 2 + 1; Entry[] array = new Entry[num + 1]; for (int i = 0; i < entries.Length; i++) { Entry entry = entries[i]; while (entry != null) { int num2 = entry.HashCode & num; Entry next = entry.Next; entry.Next = array[num2]; array[num2] = entry; entry = next; } } _entries = array; Volatile.Write(ref _mask, num); } private static bool TextEquals(string str1, char[] str2, int str2Start, int str2Length) { if (str1.Length != str2Length) { return false; } for (int i = 0; i < str1.Length; i++) { if (str1[i] != str2[str2Start + i]) { return false; } } return true; } } [Flags] public enum DefaultValueHandling { Include = 0, Ignore = 1, Populate = 2, IgnoreAndPopulate = 3 } public enum FloatFormatHandling { String, Symbol, DefaultValue } public enum FloatParseHandling { Double, Decimal } public enum Formatting { None, Indented } public interface IArrayPool<T> { T[] Rent(int minimumLength); void Return(T[]? array); } public interface IJsonLineInfo { int LineNumber { get; } int LinePosition { get; } bool HasLineInfo(); } [AttributeUsage(AttributeTargets.Class | AttributeTargets.Interface, AllowMultiple = false)] public sealed class JsonArrayAttribute : JsonContainerAttribute { private bool _allowNullItems; public bool AllowNullItems { get { return _allowNullItems; } set { _allowNullItems = value; } } public JsonArrayAttribute() { } public JsonArrayAttribute(bool allowNullItems) { _allowNullItems = allowNullItems; } public JsonArrayAttribute(string id) : base(id) { } } [AttributeUsage(AttributeTargets.Constructor, AllowMultiple = false)] public sealed class JsonConstructorAttribute : Attribute { } [AttributeUsage(AttributeTargets.Class | AttributeTargets.Interface, AllowMultiple = false)] public abstract class JsonContainerAttribute : Attribute { internal bool? _isReference; internal bool? _itemIsReference; internal ReferenceLoopHandling? _itemReferenceLoopHandling; internal TypeNameHandling? _itemTypeNameHandling; private Type? _namingStrategyType; private object[]? _namingStrategyParameters; public string? Id { get; set; } public string? Title { get; set; } public string? Description { get; set; } public Type? ItemConverterType { get; set; } public object[]? ItemConverterParameters { get; set; } public Type? NamingStrategyType { get { return _namingStrategyType; } set { _namingStrategyType = value; NamingStrategyInstance = null; } } public object[]? NamingStrategyParameters { get { return _namingStrategyParameters; } set { _namingStrategyParameters = value; NamingStrategyInstance = null; } } internal NamingStrategy? NamingStrategyInstance { get; set; } public bool IsReference { get { return _isReference.GetValueOrDefault(); } set { _isReference = value; } } public bool ItemIsReference { get { return _itemIsReference.GetValueOrDefault(); } set { _itemIsReference = value; } } public ReferenceLoopHandling ItemReferenceLoopHandling { get { return _itemReferenceLoopHandling.GetValueOrDefault(); } set { _itemReferenceLoopHandling = value; } } public TypeNameHandling ItemTypeNameHandling { get { return _itemTypeNameHandling.GetValueOrDefault(); } set { _itemTypeNameHandling = value; } } protected JsonContainerAttribute() { } protected JsonContainerAttribute(string id) { Id = id; } } public static class JsonConvert { public static readonly string True = "true"; public static readonly string False = "false"; public static readonly string Null = "null"; public static readonly string Undefined = "undefined"; public static readonly string PositiveInfinity = "Infinity"; public static readonly string NegativeInfinity = "-Infinity"; public static readonly string NaN = "NaN"; public static Func<JsonSerializerSettings>? DefaultSettings { get; set; } public static string ToString(DateTime value) { return ToString(value, DateFormatHandling.IsoDateFormat, DateTimeZoneHandling.RoundtripKind); } public static string ToString(DateTime value, DateFormatHandling format, DateTimeZoneHandling timeZoneHandling) { DateTime value2 = DateTimeUtils.EnsureDateTime(value, timeZoneHandling); using StringWriter stringWriter = StringUtils.CreateStringWriter(64); stringWriter.Write('"'); DateTimeUtils.WriteDateTimeString(stringWriter, value2, format, null, CultureInfo.InvariantCulture); stringWriter.Write('"'); return stringWriter.ToString(); } public static string ToString(DateTimeOffset value) { return ToString(value, DateFormatHandling.IsoDateFormat); } public static string ToString(DateTimeOffset value, DateFormatHandling format) { using StringWriter stringWriter = StringUtils.CreateStringWriter(64); stringWriter.Write('"'); DateTimeUtils.WriteDateTimeOffsetString(stringWriter, value, format, null, CultureInfo.InvariantCulture); stringWriter.Write('"'); return stringWriter.ToString(); } public static string ToString(bool value) { if (!value) { return False; } return True; } public static string ToString(char value) { return ToString(char.ToString(value)); } public static string ToString(Enum value) { return value.ToString("D"); } public static string ToString(int value) { return value.ToString(null, CultureInfo.InvariantCulture); } public static string ToString(short value) { return value.ToString(null, CultureInfo.InvariantCulture); } [CLSCompliant(false)] public static string ToString(ushort value) { return value.ToString(null, CultureInfo.InvariantCulture); } [CLSCompliant(false)] public static string ToString(uint value) { return value.ToString(null, CultureInfo.InvariantCulture); } public static string ToString(long value) { return value.ToString(null, CultureInfo.InvariantCulture); } private static string ToStringInternal(BigInteger value) { return value.ToString(null, CultureInfo.InvariantCulture); } [CLSCompliant(false)] public static string ToString(ulong value) { return value.ToString(null, CultureInfo.InvariantCulture); } public static string ToString(float value) { return EnsureDecimalPlace(value, value.ToString("R", CultureInfo.InvariantCulture)); } internal static string ToString(float value, FloatFormatHandling floatFormatHandling, char quoteChar, bool nullable) { return EnsureFloatFormat(value, EnsureDecimalPlace(value, value.ToString("R", CultureInfo.InvariantCulture)), floatFormatHandling, quoteChar, nullable); } private static string EnsureFloatFormat(double value, string text, FloatFormatHandling floatFormatHandling, char quoteChar, bool nullable) { if (floatFormatHandling == FloatFormatHandling.Symbol || (!double.IsInfinity(value) && !double.IsNaN(value))) { return text; } if (floatFormatHandling == FloatFormatHandling.DefaultValue) { if (nullable) { return Null; } return "0.0"; } return quoteChar + text + quoteChar; } public static string ToString(double value) { return EnsureDecimalPlace(value, value.ToString("R", CultureInfo.InvariantCulture)); } internal static string ToString(double value, FloatFormatHandling floatFormatHandling, char quoteChar, bool nullable) { return EnsureFloatFormat(value, EnsureDecimalPlace(value, value.ToString("R", CultureInfo.InvariantCulture)), floatFormatHandling, quoteChar, nullable); } private static string EnsureDecimalPlace(double value, string text) { if (double.IsNaN(value) || double.IsInfinity(value) || StringUtils.IndexOf(text, '.') != -1 || StringUtils.IndexOf(text, 'E') != -1 || StringUtils.IndexOf(text, 'e') != -1) { return text; } return text + ".0"; } private static string EnsureDecimalPlace(string text) { if (StringUtils.IndexOf(text, '.') != -1) { return text; } return text + ".0"; } public static string ToString(byte value) { return value.ToString(null, CultureInfo.InvariantCulture); } [CLSCompliant(false)] public static string ToString(sbyte value) { return value.ToString(null, CultureInfo.InvariantCulture); } public static string ToString(decimal value) { return EnsureDecimalPlace(value.ToString(null, CultureInfo.InvariantCulture)); } public static string ToString(Guid value) { return ToString(value, '"'); } internal static string ToString(Guid value, char quoteChar) { string text = value.ToString("D", CultureInfo.InvariantCulture); string text2 = quoteChar.ToString(CultureInfo.InvariantCulture); return text2 + text + text2; } public static string ToString(TimeSpan value) { return ToString(value, '"'); } internal static string ToString(TimeSpan value, char quoteChar) { return ToString(value.ToString(), quoteChar); } public static string ToString(Uri? value) { if (value == null) { return Null; } return ToString(value, '"'); } internal static string ToString(Uri value, char quoteChar) { return ToString(value.OriginalString, quoteChar); } public static string ToString(string? value) { return ToString(value, '"'); } public static string ToString(string? value, char delimiter) { return ToString(value, delimiter, StringEscapeHandling.Default); } public static string ToString(string? value, char delimiter, StringEscapeHandling stringEscapeHandling) { if (delimiter != '"' && delimiter != '\'') { throw new ArgumentException("Delimiter must be a single or double quote.", "delimiter"); } return JavaScriptUtils.ToEscapedJavaScriptString(value, delimiter, appendDelimiters: true, stringEscapeHandling); } public static string ToString(object? value) { if (value == null) { return Null; } return ConvertUtils.GetTypeCode(value.GetType()) switch { PrimitiveTypeCode.String => ToString((string)value), PrimitiveTypeCode.Char => ToString((char)value), PrimitiveTypeCode.Boolean => ToString((bool)value), PrimitiveTypeCode.SByte => ToString((sbyte)value), PrimitiveTypeCode.Int16 => ToString((short)value), PrimitiveTypeCode.UInt16 => ToString((ushort)value), PrimitiveTypeCode.Int32 => ToString((int)value), PrimitiveTypeCode.Byte => ToString((byte)value), PrimitiveTypeCode.UInt32 => ToString((uint)value), PrimitiveTypeCode.Int64 => ToString((long)value), PrimitiveTypeCode.UInt64 => ToString((ulong)value), PrimitiveTypeCode.Single => ToString((float)value), PrimitiveTypeCode.Double => ToString((double)value), PrimitiveTypeCode.DateTime => ToString((DateTime)value), PrimitiveTypeCode.Decimal => ToString((decimal)value), PrimitiveTypeCode.DBNull => Null, PrimitiveTypeCode.DateTimeOffset => ToString((DateTimeOffset)value), PrimitiveTypeCode.Guid => ToString((Guid)value), PrimitiveTypeCode.Uri => ToString((Uri)value), PrimitiveTypeCode.TimeSpan => ToString((TimeSpan)value), PrimitiveTypeCode.BigInteger => ToStringInternal((BigInteger)value), _ => throw new ArgumentException("Unsupported type: {0}. Use the JsonSerializer class to get the object's JSON representation.".FormatWith(CultureInfo.InvariantCulture, value.GetType())), }; } [DebuggerStepThrough] public static string SerializeObject(object? value) { return SerializeObject(value, (Type?)null, (JsonSerializerSettings?)null); } [DebuggerStepThrough] public static string SerializeObject(object? value, Formatting formatting) { return SerializeObject(value, formatting, (JsonSerializerSettings?)null); } [DebuggerStepThrough] public static string SerializeObject(object? value, params JsonConverter[] converters) { JsonSerializerSettings settings = ((converters != null && converters.Length != 0) ? new JsonSerializerSettings { Converters = converters } : null); return SerializeObject(value, null, settings); } [DebuggerStepThrough] public static string SerializeObject(object? value, Formatting formatting, params JsonConverter[] converters) { JsonSerializerSettings settings = ((converters != null && converters.Length != 0) ? new JsonSerializerSettings { Converters = converters } : null); return SerializeObject(value, null, formatting, settings); } [DebuggerStepThrough] public static string SerializeObject(object? value, JsonSerializerSettings? settings) { return SerializeObject(value, null, settings); } [DebuggerStepThrough] public static string SerializeObject(object? value, Type? type, JsonSerializerSettings? settings) { JsonSerializer jsonSerializer = JsonSerializer.CreateDefault(settings); return SerializeObjectInternal(value, type, jsonSerializer); } [DebuggerStepThrough] public static string SerializeObject(object? value, Formatting formatting, JsonSerializerSettings? settings) { return SerializeObject(value, null, formatting, settings); } [DebuggerStepThrough] public static string SerializeObject(object? value, Type? type, Formatting formatting, JsonSerializerSettings? settings) { JsonSerializer jsonSerializer = JsonSerializer.CreateDefault(settings); jsonSerializer.Formatting = formatting; return SerializeObjectInternal(value, type, jsonSerializer); } private static string SerializeObjectInternal(object? value, Type? type, JsonSerializer jsonSerializer) { StringWriter stringWriter = new StringWriter(new StringBuilder(256), CultureInfo.InvariantCulture); using (JsonTextWriter jsonTextWriter = new JsonTextWriter(stringWriter)) { jsonTextWriter.Formatting = jsonSerializer.Formatting; jsonSerializer.Serialize(jsonTextWriter, value, type); } return stringWriter.ToString(); } [DebuggerStepThrough] public static object? DeserializeObject(string value) { return DeserializeObject(value, (Type?)null, (JsonSerializerSettings?)null); } [DebuggerStepThrough] public static object? DeserializeObject(string value, JsonSerializerSettings settings) { return DeserializeObject(value, null, settings); } [DebuggerStepThrough] public static object? DeserializeObject(string value, Type type) { return DeserializeObject(value, type, (JsonSerializerSettings?)null); } [DebuggerStepThrough] public static T? DeserializeObject<T>(string value) { return JsonConvert.DeserializeObject<T>(value, (JsonSerializerSettings?)null); } [DebuggerStepThrough] public static T? DeserializeAnonymousType<T>(string value, T anonymousTypeObject) { return DeserializeObject<T>(value); } [DebuggerStepThrough] public static T? DeserializeAnonymousType<T>(string value, T anonymousTypeObject, JsonSerializerSettings settings) { return DeserializeObject<T>(value, settings); } [DebuggerStepThrough] public static T? DeserializeObject<T>(string value, params JsonConverter[] converters) { return (T)DeserializeObject(value, typeof(T), converters); } [DebuggerStepThrough] public static T? DeserializeObject<T>(string value, JsonSerializerSettings? settings) { return (T)DeserializeObject(value, typeof(T), settings); } [DebuggerStepThrough] public static object? DeserializeObject(string value, Type type, params JsonConverter[] converters) { JsonSerializerSettings settings = ((converters != null && converters.Length != 0) ? new JsonSerializerSettings { Converters = converters } : null); return DeserializeObject(value, type, settings); } public static object? DeserializeObject(string value, Type? type, JsonSerializerSettings? settings) { ValidationUtils.ArgumentNotNull(value, "value"); JsonSerializer jsonSerializer = JsonSerializer.CreateDefault(settings); if (!jsonSerializer.IsCheckAdditionalContentSet()) { jsonSerializer.CheckAdditionalContent = true; } using JsonTextReader reader = new JsonTextReader(new StringReader(value)); return jsonSerializer.Deserialize(reader, type); } [DebuggerStepThrough] public static void PopulateObject(string value, object target) { PopulateObject(value, target, null); } public static void PopulateObject(string value, object target, JsonSerializerSettings? settings) { JsonSerializer jsonSerializer = JsonSerializer.CreateDefault(settings); using JsonReader jsonReader = new JsonTextReader(new StringReader(value)); jsonSerializer.Populate(jsonReader, target); if (settings == null || !settings.CheckAdditionalContent) { return; } while (jsonReader.Read()) { if (jsonReader.TokenType != JsonToken.Comment) { throw JsonSerializationException.Create(jsonReader, "Additional text found in JSON string after finishing deserializing object."); } } } public static string SerializeXmlNode(XmlNode? node) { return SerializeXmlNode(node, Formatting.None); } public static string SerializeXmlNode(XmlNode? node, Formatting formatting) { XmlNodeConverter xmlNodeConverter = new XmlNodeConverter(); return SerializeObject(node, formatting, xmlNodeConverter); } public static string SerializeXmlNode(XmlNode? node, Formatting formatting, bool omitRootObject) { XmlNodeConverter xmlNodeConverter = new XmlNodeConverter { OmitRootObject = omitRootObject }; return SerializeObject(node, formatting, xmlNodeConverter); } public static XmlDocument? DeserializeXmlNode(string value) { return DeserializeXmlNode(value, null); } public static XmlDocument? DeserializeXmlNode(string value, string? deserializeRootElementName) { return DeserializeXmlNode(value, deserializeRootElementName, writeArrayAttribute: false); } public static XmlDocument? DeserializeXmlNode(string value, string? deserializeRootElementName, bool writeArrayAttribute) { return DeserializeXmlNode(value, deserializeRootElementName, writeArrayAttribute, encodeSpecialCharacters: false); } public static XmlDocument? DeserializeXmlNode(string value, string? deserializeRootElementName, bool writeArrayAttribute, bool encodeSpecialCharacters) { XmlNodeConverter xmlNodeConverter = new XmlNodeConverter(); xmlNodeConverter.DeserializeRootElementName = deserializeRootElementName; xmlNodeConverter.WriteArrayAttribute = writeArrayAttribute; xmlNodeConverter.EncodeSpecialCharacters = encodeSpecialCharacters; return (XmlDocument)DeserializeObject(value, typeof(XmlDocument), xmlNodeConverter); } public static string SerializeXNode(XObject? node) { return SerializeXNode(node, Formatting.None); } public static string SerializeXNode(XObject? node, Formatting formatting) { return SerializeXNode(node, formatting, omitRootObject: false); } public static string SerializeXNode(XObject? node, Formatting formatting, bool omitRootObject) { XmlNodeConverter xmlNodeConverter = new XmlNodeConverter { OmitRootObject = omitRootObject }; return SerializeObject(node, formatting, xmlNodeConverter); } public static XDocument? DeserializeXNode(string value) { return DeserializeXNode(value, null); } public static XDocument? DeserializeXNode(string value, string? deserializeRootElementName) { return DeserializeXNode(value, deserializeRootElementName, writeArrayAttribute: false); } public static XDocument? DeserializeXNode(string value, string? deserializeRootElementName, bool writeArrayAttribute) { return DeserializeXNode(value, deserializeRootElementName, writeArrayAttribute, encodeSpecialCharacters: false); } public static XDocument? DeserializeXNode(string value, string? deserializeRootElementName, bool writeArrayAttribute, bool encodeSpecialCharacters) { //IL_0035: Unknown result type (might be due to invalid IL or missing references) //IL_003b: Expected O, but got Unknown XmlNodeConverter xmlNodeConverter = new XmlNodeConverter(); xmlNodeConverter.DeserializeRootElementName = deserializeRootElementName; xmlNodeConverter.WriteArrayAttribute = writeArrayAttribute; xmlNodeConverter.EncodeSpecialCharacters = encodeSpecialCharacters; return (XDocument)DeserializeObject(value, typeof(XDocument), xmlNodeConverter); } } public abstract class JsonConverter { public virtual bool CanRead => true; public virtual bool CanWrite => true; public abstract void WriteJson(JsonWriter writer, object? value, JsonSerializer serializer); public abstract object? ReadJson(JsonReader reader, Type objectType, object? existingValue, JsonSerializer serializer); public abstract bool CanConvert(Type objectType); } public abstract class JsonConverter<T> : JsonConverter { public sealed override void WriteJson(JsonWriter writer, object? value, JsonSerializer serializer) { if (!((value != null) ? (value is T) : ReflectionUtils.IsNullable(typeof(T)))) { throw new JsonSerializationException("Converter cannot write specified value to JSON. {0} is required.".FormatWith(CultureInfo.InvariantCulture, typeof(T))); } WriteJson(writer, (T)value, serializer); } public abstract void WriteJson(JsonWriter writer, T? value, JsonSerializer serializer); public sealed override object? ReadJson(JsonReader reader, Type objectType, object? existingValue, JsonSerializer serializer) { bool flag = existingValue == null; if (!flag && !(existingValue is T)) { throw new JsonSerializationException("Converter cannot read JSON with the specified existing value. {0} is required.".FormatWith(CultureInfo.InvariantCulture, typeof(T))); } return ReadJson(reader, objectType, flag ? default(T) : ((T)existingValue), !flag, serializer); } public abstract T? ReadJson(JsonReader reader, Type objectType, T? existingValue, bool hasExistingValue, JsonSerializer serializer); public sealed override bool CanConvert(Type objectType) { return typeof(T).IsAssignableFrom(objectType); } } [AttributeUsage(AttributeTargets.Class | AttributeTargets.Struct | AttributeTargets.Enum | AttributeTargets.Property | AttributeTargets.Field | AttributeTargets.Interface | AttributeTargets.Parameter, AllowMultiple = false)] public sealed class JsonConverterAttribute : Attribute { private readonly Type _converterType; public Type ConverterType => _converterType; public object[]? ConverterParameters { get; } public JsonConverterAttribute(Type converterType) { if (converterType == null) { throw new ArgumentNullException("converterType"); } _converterType = converterType; } public JsonConverterAttribute(Type converterType, params object[] converterParameters) : this(converterType) { ConverterParameters = converterParameters; } } public class JsonConverterCollection : Collection<JsonConverter> { } [AttributeUsage(AttributeTargets.Class | AttributeTargets.Interface, AllowMultiple = false)] public sealed class JsonDictionaryAttribute : JsonContainerAttribute { public JsonDictionaryAttribute() { } public JsonDictionaryAttribute(string id) : base(id) { } } [Serializable] public class JsonException : Exception { public JsonException() { } public JsonException(string message) : base(message) { } public JsonException(string message, Exception? innerException) : base(message, innerException) { } public JsonException(SerializationInfo info, StreamingContext context) : base(info, context) { } internal static JsonException Create(IJsonLineInfo lineInfo, string path, string message) { message = JsonPosition.FormatMessage(lineInfo, path, message); return new JsonException(message); } } [AttributeUsage(AttributeTargets.Property | AttributeTargets.Field, AllowMultiple = false)] public class JsonExtensionDataAttribute : Attribute { public bool WriteData { get; set; } public bool ReadData { get; set; } public JsonExtensionDataAttribute() { WriteData = true; ReadData = true; } } [AttributeUsage(AttributeTargets.Property | AttributeTargets.Field, AllowMultiple = false)] public sealed class JsonIgnoreAttribute : Attribute { } public abstract class JsonNameTable { public abstract string? Get(char[] key, int start, int length); } [AttributeUsage(AttributeTargets.Class | AttributeTargets.Struct | AttributeTargets.Interface, AllowMultiple = false)] public sealed class JsonObjectAttribute : JsonContainerAttribute { private MemberSerialization _memberSerialization; internal MissingMemberHandling? _missingMemberHandling; internal Required? _itemRequired; internal NullValueHandling? _itemNullValueHandling; public MemberSerialization MemberSerialization { get { return _memberSerialization; } set { _memberSerialization = value; } } public MissingMemberHandling MissingMemberHandling { get { return _missingMemberHandling.GetValueOrDefault(); } set { _missingMemberHandling = value; } } public NullValueHandling ItemNullValueHandling { get { return _itemNullValueHandling.GetValueOrDefault(); } set { _itemNullValueHandling = value; } } public Required ItemRequired { get { return _itemRequired.GetValueOrDefault(); } set { _itemRequired = value; } } public JsonObjectAttribute() { } public JsonObjectAttribute(MemberSerialization memberSerialization) { MemberSerialization = memberSerialization; } public JsonObjectAttribute(string id) : base(id) { } } internal enum JsonContainerType { None, Object, Array, Constructor } internal struct JsonPosition { private static readonly char[] SpecialCharacters = new char[18] { '.', ' ', '\'', '/', '"', '[', ']', '(', ')', '\t', '\n', '\r', '\f', '\b', '\\', '\u0085', '\u2028', '\u2029' }; internal JsonContainerType Type; internal int Position; internal string? PropertyName; internal bool HasIndex; public JsonPosition(JsonContainerType type) { Type = type; HasIndex = TypeHasIndex(type); Position = -1; PropertyName = null; } internal int CalculateLength() { switch (Type) { case JsonContainerType.Object: return PropertyName.Length + 5; case JsonContainerType.Array: case JsonContainerType.Constructor: return MathUtils.IntLength((ulong)Position) + 2; default: throw new ArgumentOutOfRangeException("Type"); } } internal void WriteTo(StringBuilder sb, ref StringWriter? writer, ref char[]? buffer) { switch (Type) { case JsonContainerType.Object: { string propertyName = PropertyName; if (propertyName.IndexOfAny(SpecialCharacters) != -1) { sb.Append("['"); if (writer == null) { writer = new StringWriter(sb); } JavaScriptUtils.WriteEscapedJavaScriptString(writer, propertyName, '\'', appendDelimiters: false, JavaScriptUtils.SingleQuoteCharEscapeFlags, StringEscapeHandling.Default, null, ref buffer); sb.Append("']"); } else { if (sb.Length > 0) { sb.Append('.'); } sb.Append(propertyName); } break; } case JsonContainerType.Array: case JsonContainerType.Constructor: sb.Append('['); sb.Append(Position); sb.Append(']'); break; } } internal static bool TypeHasIndex(JsonContainerType type) { if (type != JsonContainerType.Array) { return type == JsonContainerType.Constructor; } return true; } internal static string BuildPath(List<JsonPosition> positions, JsonPosition? currentPosition) { int num = 0; if (positions != null) { for (int i = 0; i < positions.Count; i++) { num += positions[i].CalculateLength(); } } if (currentPosition.HasValue) { num += currentPosition.GetValueOrDefault().CalculateLength(); } StringBuilder stringBuilder = new StringBuilder(num); StringWriter writer = null; char[] buffer = null; if (positions != null) { foreach (JsonPosition position in positions) { position.WriteTo(stringBuilder, ref writer, ref buffer); } } currentPosition?.WriteTo(stringBuilder, ref writer, ref buffer); return stringBuilder.ToString(); } internal static string FormatMessage(IJsonLineInfo? lineInfo, string path, string message) { if (!message.EndsWith(Environment.NewLine, StringComparison.Ordinal)) { message = message.Trim(); if (!StringUtils.EndsWith(message, '.')) { message += "."; } message += " "; } message += "Path '{0}'".FormatWith(CultureInfo.InvariantCulture, path); if (lineInfo != null && lineInfo.HasLineInfo()) { message += ", line {0}, position {1}".FormatWith(CultureInfo.InvariantCulture, lineInfo.LineNumber, lineInfo.LinePosition); } message += "."; return message; } } [AttributeUsage(AttributeTargets.Property | AttributeTargets.Field | AttributeTargets.Parameter, AllowMultiple = false)] public sealed class JsonPropertyAttribute : Attribute { internal NullValueHandling? _nullValueHandling; internal DefaultValueHandling? _defaultValueHandling; internal ReferenceLoopHandling? _referenceLoopHandling; internal ObjectCreationHandling? _objectCreationHandling; internal TypeNameHandling? _typeNameHandling; internal bool? _isReference; internal int? _order; internal Required? _required; internal bool? _itemIsReference; internal ReferenceLoopHandling? _itemReferenceLoopHandling; internal TypeNameHandling? _itemTypeNameHandling; public Type? ItemConverterType { get; set; } public object[]? ItemConverterParameters { get; set; } public Type? NamingStrategyType { get; set; } public object[]? NamingStrategyParameters { get; set; } public NullValueHandling NullValueHandling { get { return _nullValueHandling.GetValueOrDefault(); } set { _nullValueHandling = value; } } public DefaultValueHandling DefaultValueHandling { get { return _defaultValueHandling.GetValueOrDefault(); } set { _defaultValueHandling = value; } } public ReferenceLoopHandling ReferenceLoopHandling { get { return _referenceLoopHandling.GetValueOrDefault(); } set { _referenceLoopHandling = value; } } public ObjectCreationHandling ObjectCreationHandling { get { return _objectCreationHandling.GetValueOrDefault(); } set { _objectCreationHandling = value; } } public TypeNameHandling TypeNameHandling { get { return _typeNameHandling.GetValueOrDefault(); } set { _typeNameHandling = value; } } public bool IsReference { get { return _isReference.GetValueOrDefault(); } set { _isReference = value; } } public int Order { get { return _order.GetValueOrDefault(); } set { _order = value; } } public Required Required { get { return _required.GetValueOrDefault(); } set { _required = value; } } public string? PropertyName { get; set; } public ReferenceLoopHandling ItemReferenceLoopHandling { get { return _itemReferenceLoopHandling.GetValueOrDefault(); } set { _itemReferenceLoopHandling = value; } } public TypeNameHandling ItemTypeNameHandling { get { return _itemTypeNameHandling.GetValueOrDefault(); } set { _itemTypeNameHandling = value; } } public bool ItemIsReference { get { return _itemIsReference.GetValueOrDefault(); } set { _itemIsReference = value; } } public JsonPropertyAttribute() { } public JsonPropertyAttribute(string propertyName) { PropertyName = propertyName; } } public abstract class JsonReader : IDisposable { protected internal enum State { Start, Complete, Property, ObjectStart, Object, ArrayStart, Array, Closed, PostValue, ConstructorStart, Constructor, Error, Finished } private JsonToken _tokenType; private object? _value; internal char _quoteChar; internal State _currentState; private JsonPosition _currentPosition; private CultureInfo? _culture; private DateTimeZoneHandling _dateTimeZoneHandling; private int? _maxDepth; private bool _hasExceededMaxDepth; internal DateParseHandling _dateParseHandling; internal FloatParseHandling _floatParseHandling; private string? _dateFormatString; private List<JsonPosition>? _stack; protected State CurrentState => _currentState; public bool CloseInput { get; set; } public bool SupportMultipleContent { get; set; } public virtual char QuoteChar { get { return _quoteChar; } protected internal set { _quoteChar = value; } } public DateTimeZoneHandling DateTimeZoneHandling { get { return _dateTimeZoneHandling; } set { if (value < DateTimeZoneHandling.Local || value > DateTimeZoneHandling.RoundtripKind) { throw new ArgumentOutOfRangeException("value"); } _dateTimeZoneHandling = value; } } public DateParseHandling DateParseHandling { get { return _dateParseHandling; } set { if (value < DateParseHandling.None || value > DateParseHandling.DateTimeOffset) { throw new ArgumentOutOfRangeException("value"); } _dateParseHandling = value; } } public FloatParseHandling FloatParseHandling { get { return _floatParseHandling; } set { if (value < FloatParseHandling.Double || value > FloatParseHandling.Decimal) { throw new ArgumentOutOfRangeException("value"); } _floatParseHandling = value; } } public string? DateFormatString { get { return _dateFormatString; } set { _dateFormatString = value; } } public int? MaxDepth { get { return _maxDepth; } set { if (value <= 0) { throw new ArgumentException("Value must be positive.", "value"); } _maxDepth = value; } } public virtual JsonToken TokenType => _tokenType; public virtual object? Value => _value; public virtual Type? ValueType => _value?.GetType(); public virtual int Depth { get { int num = _stack?.Count ?? 0; if (JsonTokenUtils.IsStartToken(TokenType) || _currentPosition.Type == JsonContainerType.None) { return num; } return num + 1; } } public virtual string Path { get { if (_currentPosition.Type == JsonContainerType.None) { return string.Empty; } JsonPosition? currentPosition = ((_currentState != State.ArrayStart && _currentState != State.ConstructorStart && _currentState != State.ObjectStart) ? new JsonPosition?(_currentPosition) : null); return JsonPosition.BuildPath(_stack, currentPosition); } } public CultureInfo Culture { get { return _culture ?? CultureInfo.InvariantCulture; } set { _culture = value; } } public virtual Task<bool> ReadAsync(CancellationToken cancellationToken = default(CancellationToken)) { return cancellationToken.CancelIfRequestedAsync<bool>() ?? Read().ToAsync(); } public async Task SkipAsync(CancellationToken cancellationToken = default(CancellationToken)) { if (TokenType == JsonToken.PropertyName) { await ReadAsync(cancellationToken).ConfigureAwait(continueOnCapturedContext: false); } if (JsonTokenUtils.IsStartToken(TokenType)) { int depth = Depth; while (await ReadAsync(cancellationToken).ConfigureAwait(continueOnCapturedContext: false) && depth < Depth) { } } } internal async Task ReaderReadAndAssertAsync(CancellationToken cancellationToken) { if (!(await ReadAsync(cancellationToken).ConfigureAwait(continueOnCapturedContext: false))) { throw CreateUnexpectedEndException(); } } public virtual Task<bool?> ReadAsBooleanAsync(CancellationToken cancellationToken = default(CancellationToken)) { return cancellationToken.CancelIfRequestedAsync<bool?>() ?? Task.FromResult(ReadAsBoolean()); } public virtual Task<byte[]?> ReadAsBytesAsync(CancellationToken cancellationToken = default(CancellationToken)) { return cancellationToken.CancelIfRequestedAsync<byte[]>() ?? Task.FromResult(ReadAsBytes()); } internal async Task<byte[]?> ReadArrayIntoByteArrayAsync(CancellationToken cancellationToken) { List<byte> buffer = new List<byte>(); do { if (!(await ReadAsync(cancellationToken).ConfigureAwait(continueOnCapturedContext: false))) { SetToken(JsonToken.None); } } while (!ReadArrayElementIntoByteArrayReportDone(buffer)); byte[] array = buffer.ToArray(); SetToken(JsonToken.Bytes, array, updateIndex: false); return array; } public virtual Task<DateTime?> ReadAsDateTimeAsync(CancellationToken cancellationToken = default(CancellationToken)) { return cancellationToken.CancelIfRequestedAsync<DateTime?>() ?? Task.FromResult(ReadAsDateTime()); } public virtual Task<DateTimeOffset?> ReadAsDateTimeOffsetAsync(CancellationToken cancellationToken = default(CancellationToken)) { return cancellationToken.CancelIfRequestedAsync<DateTimeOffset?>() ?? Task.FromResult(ReadAsDateTimeOffset()); } public virtual Task<decimal?> ReadAsDecimalAsync(CancellationToken cancellationToken = default(CancellationToken)) { return cancellationToken.CancelIfRequestedAsync<decimal?>() ?? Task.FromResult(ReadAsDecimal()); } public virtual Task<double?> ReadAsDoubleAsync(CancellationToken cancellationToken = default(CancellationToken)) { return Task.FromResult(ReadAsDouble()); } public virtual Task<int?> ReadAsInt32Async(CancellationToken cancellationToken = default(CancellationToken)) { return cancellationToken.CancelIfRequestedAsync<int?>() ?? Task.FromResult(ReadAsInt32()); } public virtual Task<string?> ReadAsStringAsync(CancellationToken cancellationToken = default(CancellationToken)) { return cancellationToken.CancelIfRequestedAsync<string>() ?? Task.FromResult(ReadAsString()); } internal async Task<bool> ReadAndMoveToContentAsync(CancellationToken cancellationToken) { bool flag = await ReadAsync(cancellationToken).ConfigureAwait(continueOnCapturedContext: false); if (flag) { flag = await MoveToContentAsync(cancellationToken).ConfigureAwait(continueOnCapturedContext: false); } return flag; } internal Task<bool> MoveToContentAsync(CancellationToken cancellationToken) { JsonToken tokenType = TokenType; if (tokenType == JsonToken.None || tokenType == JsonToken.Comment) { return MoveToContentFromNonContentAsync(cancellationToken); } return AsyncUtils.True; } private async Task<bool> MoveToContentFromNonContentAsync(CancellationToken cancellationToken) { JsonToken tokenType; do { if (!(await ReadAsync(cancellationToken).ConfigureAwait(continueOnCapturedContext: false))) { return false; } tokenType = TokenType; } while (tokenType == JsonToken.None || tokenType == JsonToken.Comment); return true; } internal JsonPosition GetPosition(int depth) { if (_stack != null && depth < _stack.Count) { return _stack[depth]; } return _currentPosition; } protected JsonReader() { _currentState = State.Start; _dateTimeZoneHandling = DateTimeZoneHandling.RoundtripKind; _dateParseHandling = DateParseHandling.DateTime; _floatParseHandling = FloatParseHandling.Double; _maxDepth = 64; CloseInput = true; } private void Push(JsonContainerType value) { UpdateScopeWithFinishedValue(); if (_currentPosition.Type == JsonContainerType.None) { _currentPosition = new JsonPosition(value); return; } if (_stack == null) { _stack = new List<JsonPosition>(); } _stack.Add(_currentPosition); _currentPosition = new JsonPosition(value); if (!_maxDepth.HasValue || !(Depth + 1 > _maxDepth) || _hasExceededMaxDepth) { return; } _hasExceededMaxDepth = true; throw JsonReaderException.Create(this, "The reader's MaxDepth of {0} has been exceeded.".FormatWith(CultureInfo.InvariantCulture, _maxDepth)); } private JsonContainerType Pop() { JsonPosition currentPosition; if (_stack != null && _stack.Count > 0) { currentPosition = _currentPosition; _currentPosition = _stack[_stack.Count - 1]; _stack.RemoveAt(_stack.Count - 1); } else { currentPosition = _currentPosition; _currentPosition = default(JsonPosition); } if (_maxDepth.HasValue && Depth <= _maxDepth) { _hasExceededMaxDepth = false; } return currentPosition.Type; } private JsonContainerType Peek() { return _currentPosition.Type; } public abstract bool Read(); public virtual int? ReadAsInt32() { JsonToken contentToken = GetContentToken(); switch (contentToken) { case JsonToken.None: case JsonToken.Null: case JsonToken.EndArray: return null; case JsonToken.Integer: case JsonToken.Float: { object value = Value; if (value is int) { return (int)value; } int num; if (value is BigInteger bigInteger) { num = (int)bigInteger; } else { try { num = Convert.ToInt32(value, CultureInfo.InvariantCulture); } catch (Exception ex) { throw JsonReaderException.Create(this, "Could not convert to integer: {0}.".FormatWith(CultureInfo.InvariantCulture, value), ex); } } SetToken(JsonToken.Integer, num, updateIndex: false); return num; } case JsonToken.String: { string s = (string)Value; return ReadInt32String(s); } default: throw JsonReaderException.Create(this, "Error reading integer. Unexpected token: {0}.".FormatWith(CultureInfo.InvariantCulture, contentToken)); } } internal int? ReadInt32String(string? s) { if (StringUtils.IsNullOrEmpty(s)) { SetToken(JsonToken.Null, null, updateIndex: false); return null; } if (int.TryParse(s, NumberStyles.Integer, Culture, out var result)) { SetToken(JsonToken.Integer, result, updateIndex: false); return result; } SetToken(JsonToken.String, s, updateIndex: false); throw JsonReaderException.Create(this, "Could not convert string to integer: {0}.".FormatWith(CultureInfo.InvariantCulture, s)); } public virtual string? ReadAsString() { JsonToken contentToken = GetContentToken(); switch (contentToken) { case JsonToken.None: case JsonToken.Null: case JsonToken.EndArray: return null; case JsonToken.String: return (string)Value; default: if (JsonTokenUtils.IsPrimitiveToken(contentToken)) { object value = Value; if (value != null) { string text = ((!(value is IFormattable formattable)) ? ((value is Uri uri) ? uri.OriginalString : value.ToString()) : formattable.ToString(null, Culture)); SetToken(JsonToken.String, text, updateIndex: false); return text; } } throw JsonReaderException.Create(this, "Error reading string. Unexpected token: {0}.".FormatWith(CultureInfo.InvariantCulture, contentToken)); } } public virtual byte[]? ReadAsBytes() { JsonToken contentToken = GetContentToken(); switch (contentToken) { case JsonToken.StartObject: { ReadIntoWrappedTypeObject(); byte[] array2 = ReadAsBytes(); ReaderReadAndAssert(); if (TokenType != JsonToken.EndObject) { throw JsonReaderException.Create(this, "Error reading bytes. Unexpected token: {0}.".FormatWith(CultureInfo.InvariantCulture, TokenType)); } SetToken(JsonToken.Bytes, array2, updateIndex: false); return array2; } case JsonToken.String: { string text = (string)Value; Guid g; byte[] array3 = ((text.Length == 0) ? CollectionUtils.ArrayEmpty<byte>() : ((!ConvertUtils.TryConvertGuid(text, out g)) ? Convert.FromBase64String(text) : g.ToByteArray())); SetToken(JsonToken.Bytes, array3, updateIndex: false); return array3; } case JsonToken.None: case JsonToken.Null: case JsonToken.EndArray: return null; case JsonToken.Bytes: if (Value is Guid guid) { byte[] array = guid.ToByteArray(); SetToken(JsonToken.Bytes, array, updateIndex: false); return array; } return (byte[])Value; case JsonToken.StartArray: return ReadArrayIntoByteArray(); default: throw JsonReaderException.Create(this, "Error reading bytes. Unexpected token: {0}.".FormatWith(CultureInfo.InvariantCulture, contentToken)); } } internal byte[] ReadArrayIntoByteArray() { List<byte> list = new List<byte>(); do { if (!Read()) { SetToken(JsonToken.None); } } while (!ReadArrayElementIntoByteArrayReportDone(list)); byte[] array = list.ToArray(); SetToken(JsonToken.Bytes, array, updateIndex: false); return array; } private bool ReadArrayElementIntoByteArrayReportDone(List<byte> buffer) { switch (TokenType) { case JsonToken.None: throw JsonReaderException.Create(this, "Unexpected end when reading bytes."); case JsonToken.Integer: buffer.Add(Convert.ToByte(Value, CultureInfo.InvariantCulture)); return false; case JsonToken.EndArray: return true; case JsonToken.Comment: return false; default: throw JsonReaderException.Create(this, "Unexpected token when reading bytes: {0}.".FormatWith(CultureInfo.InvariantCulture, TokenType)); } } public virtual double? ReadAsDouble() { JsonToken contentToken = GetContentToken(); switch (contentToken) { case JsonToken.None: case JsonToken.Null: case JsonToken.EndArray: return null; case JsonToken.Integer: case JsonToken.Float: { object value = Value; if (value is double) { return (double)value; } double num = ((!(value is BigInteger bigInteger)) ? Convert.ToDouble(value, CultureInfo.InvariantCulture) : ((double)bigInteger)); SetToken(JsonToken.Float, num, updateIndex: false); return num; } case JsonToken.String: return ReadDoubleString((string)Value); default: throw JsonReaderException.Create(this, "Error reading double. Unexpected token: {0}.".FormatWith(CultureInfo.InvariantCulture, contentToken)); } } internal double? ReadDoubleString(string? s) { if (StringUtils.IsNullOrEmpty(s)) { SetToken(JsonToken.Null, null, updateIndex: false); return null; } if (double.TryParse(s, NumberStyles.Float | NumberStyles.AllowThousands, Culture, out var result)) { SetToken(JsonToken.Float, result, updateIndex: false); return result; } SetToken(JsonToken.String, s, updateIndex: false); throw JsonReaderException.Create(this, "Could not convert string to double: {0}.".FormatWith(CultureInfo.InvariantCulture, s)); } public virtual bool? ReadAsBoolean() { JsonToken contentToken = GetContentToken(); switch (contentToken) { case JsonToken.None: case JsonToken.Null: case JsonToken.EndArray: return null; case JsonToken.Integer: case JsonToken.Float: { bool flag = ((!(Value is BigInteger bigInteger)) ? Convert.ToBoolean(Value, CultureInfo.InvariantCulture) : (bigInteger != 0L)); SetToken(JsonToken.Boolean, flag, updateIndex: false); return flag; } case JsonToken.String: return ReadBooleanString((string)Value); case JsonToken.Boolean: return (bool)Value; default: throw JsonReaderException.Create(this, "Error reading boolean. Unexpected token: {0}.".FormatWith(CultureInfo.InvariantCulture, contentToken)); } } internal bool? ReadBooleanString(string? s) { if (StringUtils.IsNullOrEmpty(s)) { SetToken(JsonToken.Null, null, updateIndex: false); return null; } if (bool.TryParse(s, out var result)) { SetToken(JsonToken.Boolean, result, updateIndex: false); return result; } SetToken(JsonToken.String, s, updateIndex: false); throw JsonReaderException.Create(this, "Could not convert string to boolean: {0}.".FormatWith(CultureInfo.InvariantCulture, s)); } public virtual decimal? ReadAsDecimal() { JsonToken contentToken = GetContentToken(); switch (contentToken) { case JsonToken.None: case JsonToken.Null: case JsonToken.EndArray: return null; case JsonToken.Integer: case JsonToken.Float: { object value = Value; if (value is decimal) { return (decimal)value; } decimal num; if (value is BigInteger bigInteger) { num = (decimal)bigInteger; } else { try { num = Convert.ToDecimal(value, CultureInfo.InvariantCulture); } catch (Exception ex) { throw JsonReaderException.Create(this, "Could not convert to decimal: {0}.".FormatWith(CultureInfo.InvariantCulture, value), ex); } } SetToken(JsonToken.Float, num, updateIndex: false); return num; } case JsonToken.String: return ReadDecimalString((string)Value); default: throw JsonReaderException.Create(this, "Error reading decimal. Unexpected token: {0}.".FormatWith(CultureInfo.InvariantCulture, contentToken)); } } internal decimal? ReadDecimalString(string? s) { if (StringUtils.IsNullOrEmpty(s)) { SetToken(JsonToken.Null, null, updateIndex: false); return null; } if (decimal.TryParse(s, NumberStyles.Number, Culture, out var result)) { SetToken(JsonToken.Float, result, updateIndex: false); return result; } if (ConvertUtils.DecimalTryParse(s.ToCharArray(), 0, s.Length, out result) == ParseResult.Success) { SetToken(JsonToken.Float, result, updateIndex: false); return result; } SetToken(JsonToken.String, s, updateIndex: false); throw JsonReaderException.Create(this, "Could not convert string to decimal: {0}.".FormatWith(CultureInfo.InvariantCulture, s)); } public virtual DateTime? ReadAsDateTime() { switch (GetContentToken()) { case JsonToken.None: case JsonToken.Null: case JsonToken.EndArray: return null; case JsonToken.Date: if (Value is DateTimeOffset dateTimeOffset) { SetToken(JsonToken.Date, dateTimeOffset.DateTime, updateIndex: false); } return (DateTime)Value; case JsonToken.String: return ReadDateTimeString((string)Value); default: throw JsonReaderException.Create(this, "Error reading date. Unexpected token: {0}.".FormatWith(CultureInfo.InvariantCulture, TokenType)); } } internal DateTime? ReadDateTimeString(string? s) { if (StringUtils.IsNullOrEmpty(s)) { SetToken(JsonToken.Null, null, updateIndex: false); return null; } if (DateTimeUtils.TryParseDateTime(s, DateTimeZoneHandling, _dateFormatString, Culture, out var dt)) { dt = DateTimeUtils.EnsureDateTime(dt, DateTimeZoneHandling); SetToken(JsonToken.Date, dt, updateIndex: false); return dt; } if (DateTime.TryParse(s, Culture, DateTimeStyles.RoundtripKind, out dt)) { dt = DateTimeUtils.EnsureDateTime(dt, DateTimeZoneHandling); SetToken(JsonToken.Date, dt, updateIndex: false); return dt; } throw JsonReaderException.Create(this, "Could not convert string to DateTime: {0}.".FormatWith(CultureInfo.InvariantCulture, s)); } public virtual DateTimeOffset? ReadAsDateTimeOffset() { JsonToken contentToken = GetContentToken(); switch (contentToken) { case JsonToken.None: case JsonToken.Null: case JsonToken.EndArray: return null; case JsonToken.Date: if (Value is DateTime dateTime) { SetToken(JsonToken.Date, new DateTimeOffset(dateTime), updateIndex: false); } return (DateTimeOffset)Value; case JsonToken.String: { string s = (string)Value; return ReadDateTimeOffsetString(s); } default: throw JsonReaderException.Create(this, "Error reading date. Unexpected token: {0}.".FormatWith(CultureInfo.InvariantCulture, contentToken)); } } internal DateTimeOffset? ReadDateTimeOffsetString(string? s) { if (StringUtils.IsNullOrEmpty(s)) { SetToken(JsonToken.Null, null, updateIndex: false); return null; } if (DateTimeUtils.TryParseDateTimeOffset(s, _dateFormatString, Culture, out var dt)) { SetToken(JsonToken.Date, dt, updateIndex: false); return dt; } if (DateTimeOffset.TryParse(s, Culture, DateTimeStyles.RoundtripKind, out dt)) { SetToken(JsonToken.Date, dt, updateIndex: false); return dt; } SetToken(JsonToken.String, s, updateIndex: false); throw JsonReaderException.Create(this, "Could not convert string to DateTimeOffset: {0}.".FormatWith(CultureInfo.InvariantCulture, s)); } internal void ReaderReadAndAssert() { if (!Read()) { throw CreateUnexpectedEndException(); } } internal JsonReaderException CreateUnexpectedEndException() { return JsonReaderException.Create(this, "Unexpected end when reading JSON."); } internal void ReadIntoWrappedTypeObject() { ReaderReadAndAssert(); if (Value != null && Value.ToString() == "$type") { ReaderReadAndAssert(); if (Value != null && Value.ToString().StartsWith("System.Byte[]", StringComparison.Ordinal)) { ReaderReadAndAssert(); if (Value.ToString() == "$value") { return; } } } throw JsonReaderException.Create(this, "Error reading bytes. Unexpected token: {0}.".FormatWith(CultureInfo.InvariantCulture, JsonToken.StartObject)); } public void Skip() { if (TokenType == JsonToken.PropertyName) { Read(); } if (JsonTokenUtils.IsStartToken(TokenType)) { int depth = Depth; while (Read() && depth < Depth) { } } } protected void SetToken(JsonToken newToken) { SetToken(newToken, null, updateIndex: true); } protected void SetToken(JsonToken newToken, object? value) { SetToken(newToken, value, updateIndex: true); } protected void SetToken(JsonToken newToken, object? value, bool updateIndex) { _tokenType = newToken; _value = value; switch (newToken) { case JsonToken.StartObject: _currentState = State.ObjectStart; Push(JsonContainerType.Object); break; case JsonToken.StartArray: _currentState = State.ArrayStart; Push(JsonContainerType.Array); break; case JsonToken.StartConstructor: _currentState = State.ConstructorStart; Push(JsonContainerType.Constructor); break; case JsonToken.EndObject: ValidateEnd(JsonToken.EndObject); break; case JsonToken.EndArray: ValidateEnd(JsonToken.EndArray); break; case JsonToken.EndConstructor: ValidateEnd(JsonToken.EndConstructor); break; case JsonToken.PropertyName: _currentState = State.Property; _currentPosition.PropertyName = (string)value; break; case JsonToken.Raw: case JsonToken.Integer: case JsonToken.Float: case JsonToken.String: case JsonToken.Boolean: case JsonToken.Null: case JsonToken.Undefined: case JsonToken.Date: case JsonToken.Bytes: SetPostValueState(updateIndex); break; case JsonToken.Comment: break; } } internal void SetPostValueState(bool updateIndex) { if (Peek() != 0 || SupportMultipleContent) { _currentState = State.PostValue; } else { SetFinished(); } if (updateIndex) { UpdateScopeWithFinishedValue(); } } private void UpdateScopeWithFinishedValue() { if (_currentPosition.HasIndex) { _currentPosition.Position++; } } private void ValidateEnd(JsonToken endToken) { JsonContainerType jsonContainerType = Pop(); if (GetTypeForCloseToken(endToken) != jsonContainerType) { throw JsonReaderException.Create(this, "JsonToken {0} is not valid for closing JsonType {1}.".FormatWith(CultureInfo.InvariantCulture, endToken, jsonContainerType)); } if (Peek() != 0 || SupportMultipleContent) { _currentState = State.PostValue; } else { SetFinished(); } } protected void SetStateBasedOnCurrent() { JsonContainerType jsonContainerType = Peek(); switch (jsonContainerType) { case JsonContainerType.Object: _currentState = State.Object; break; case JsonContainerType.Array: _currentState = State.Array; break; case JsonContainerType.Constructor: _currentState = State.Constructor; break; case JsonContainerType.None: SetFinished(); break; default: throw JsonReaderException.Create(this, "While setting the reader state back to current object an unexpected JsonType was encountered: {0}".FormatWith(CultureInfo.InvariantCulture, jsonContainerType)); } } private void SetFinished() { _currentState = ((!SupportMultipleContent) ? State.Finished : State.Start); } private JsonContainerType GetTypeForCloseToken(JsonToken token) { return token switch { JsonToken.EndObject => JsonContainerType.Object, JsonToken.EndArray => JsonContainerType.Array, JsonToken.EndConstructor => JsonContainerType.Constructor, _ => throw JsonReaderException.Create(this, "Not a valid close JsonToken: {0}".FormatWith(CultureInfo.InvariantCulture, token)), }; } void IDisposable.Dispose() { Dispose(disposing: true); GC.SuppressFinalize(this); } protected virtual void Dispose(bool disposing) { if (_currentState != State.Closed && disposing) { Close(); } } public virtual void Close() { _currentState = State.Closed; _tokenType = JsonToken.None; _value = null; } internal void ReadAndAssert() { if (!Read()) { throw JsonSerializationException.Create(this, "Unexpected end when reading JSON."); } } internal void ReadForTypeAndAssert(JsonContract? contract, bool hasConverter) { if (!ReadForType(contract, hasConverter)) { throw JsonSerializationException.Create(this, "Unexpected end when reading JSON."); } } internal bool ReadForType(JsonContract? contract, bool hasConverter) { if (hasConverter) { return Read(); } switch (contract?.InternalReadType ?? ReadType.Read) { case ReadType.Read: return ReadAndMoveToContent(); case ReadType.ReadAsInt32: ReadAsInt32(); break; case ReadType.ReadAsInt64: { bool result = ReadAndMoveToContent(); if (TokenType == JsonToken.Undefined) { throw JsonReaderException.Create(this, "An undefined token is not a valid {0}.".FormatWith(CultureInfo.InvariantCulture, contract?.UnderlyingType ?? typeof(long))); } return result; } case ReadType.ReadAsDecimal: ReadAsDecimal(); break; case ReadType.ReadAsDouble: ReadAsDouble(); break; case ReadType.ReadAsBytes: ReadAsBytes(); break; case ReadType.ReadAsBoolean: ReadAsBoolean(); break; case ReadType.ReadAsString: ReadAsString(); break; case ReadType.ReadAsDateTime: ReadAsDateTime(); break; case ReadType.ReadAsDateTimeOffset: ReadAsDateTimeOffset(); break; default: throw new ArgumentOutOfRangeException(); } return TokenType != JsonToken.None; } internal bool ReadAndMoveToContent() { if (Read()) { return MoveToContent(); } return false; } internal bool MoveToContent() { JsonToken tokenType = TokenType; while (tokenType == JsonToken.None || tokenType == JsonToken.Comment) { if (!Read()) { return false; } tokenType = TokenType; } return true; } private JsonToken GetContentToken() { JsonToken tokenType; do { if (!Read()) { SetToken(JsonToken.None); return JsonToken.None; } tokenType = TokenType; } while (tokenType == JsonToken.Comment); return tokenType; } } [Serializable] public class JsonReaderException : JsonException { public int LineNumber { get; } public int LinePosition { get; } public string? Path { get; } public JsonReaderException() { } public JsonReaderException(string message) : base(message) { } public JsonReaderException(string message, Exception innerException) : base(message, innerException) { } public JsonReaderException(SerializationInfo info, StreamingContext context) : base(info, context) { } public JsonReaderException(string message, string path, int lineNumber, int linePosition, Exception? innerException) : base(message, innerException) { Path = path; LineNumber = lineNumber; LinePosition = linePosition; } internal static JsonReaderException Create(JsonReader reader, string message) { return Create(reader, message, null); } internal static JsonReaderException Create(JsonReader reader, string message, Exception? ex) { return Create(reader as IJsonLineInfo, reader.Path, message, ex); } internal static JsonReaderException Create(IJsonLineInfo? lineInfo, string path, string message, Exception? ex) { message = JsonPosition.FormatMessage(lineInfo, path, message); int lineNumber; int linePosition; if (lineInfo != null && lineInfo.HasLineInfo()) { lineNumber = lineInfo.LineNumber; linePosition = lineInfo.LinePosition; } else { lineNumber = 0; linePosition = 0; } return new JsonReaderException(message, path, lineNumber, linePosition, ex); } } [AttributeUsage(AttributeTargets.Property | AttributeTargets.Field, AllowMultiple = false)] public sealed class JsonRequiredAttribute : Attribute { } [Serializable] public class JsonSerializationException : JsonException { public int LineNumber { get; } public int LinePosition { get; } public string? Path { get; } public JsonSerializationException() { } public JsonSerializationException(string message) : base(message) { } public JsonSerializationException(string message, Exception innerException) : base(message, innerException) { } public JsonSerializationException(SerializationInfo info, StreamingContext context) : base(info, context) { } public JsonSerializationException(string message, string path, int lineNumber, int linePosition, Exception? innerException) : base(message, innerException) { Path = path; LineNumber = lineNumber; LinePosition = linePosition; } internal static JsonSerializationException Create(JsonReader reader, string message) { return Create(reader, message, null); } internal static JsonSerializationException Create(JsonReader reader, string message, Exception? ex) { return Create(reader as IJsonLineInfo, reader.Path, message, ex); } internal static JsonSerializationException Create(IJsonLineInfo? lineInfo, string path, string message, Exception? ex) { message = JsonPosition.FormatMessage(lineInfo, path, message); int lineNumber; int linePosition; if (lineInfo != null && lineInfo.HasLineInfo()) { lineNumber = lineInfo.LineNumber; linePosition = lineInfo.LinePosition; } else { lineNumber = 0; linePosition = 0; } return new JsonSerializationException(message, path, lineNumber, linePosition, ex); } } public class JsonSerializer { internal TypeNameHandling _typeNameHandling; internal TypeNameAssemblyFormatHandling _typeNameAssemblyFormatHandling; internal PreserveReferencesHandling _preserveReferencesHandling; internal ReferenceLoopHandling _referenceLoopHandling; internal MissingMemberHandling _missingMemberHandling; internal ObjectCreationHandling _objectCreationHandling; internal NullValueHandling _nullValueHandling; internal DefaultValueHandling _defaultValueHandling; internal ConstructorHandling _constructorHandling; internal MetadataPropertyHandling _metadataPropertyHandling; internal JsonConverterCollection? _converters; internal IContractResolver _contractResolver; internal ITraceWriter? _traceWriter; internal IEqualityComparer? _equalityComparer; internal ISerializationBinder _serializationBinder; internal StreamingContext _context; private IReferenceResolver? _referenceResolver; private Formatting? _formatting; private DateFormatHandling? _dateFormatHandling; private DateTimeZoneHandling? _dateTimeZoneHandling; private DateParseHandling? _dateParseHandling; private FloatFormatHandling? _floatFormatHandling; private FloatParseHandling? _floatParseHandling; private StringEscapeHandling? _stringEscapeHandling; private CultureInfo _culture; private int? _maxDepth; private bool _maxDepthSet; private bool? _checkAdditionalContent; private string? _dateFormatString; private bool _dateFormatStringSet; public virtual IReferenceResolver? ReferenceResolver { get { return GetReferenceResolver(); } set { if (value == null) { throw new ArgumentNullException("value", "Reference resolver cannot be null."); } _referenceResolver = value; } } [Obsolete("Binder is obsolete. Use SerializationBinder instead.")] public virtual SerializationBinder Binder { get { if (_serializationBinder is SerializationBinder result) { return result; } if (_serializationBinder is SerializationBinderAdapter serializationBinderAdapter) { return serializationBinderAdapter.SerializationBinder; } throw new InvalidOperationException("Cannot get SerializationBinder because an ISerializationBinder was previously set."); } set { if (value == null) { throw new ArgumentNullException("value", "Serialization binder cannot be null."); } _serializationBinder = (value as ISerializationBinder) ?? new SerializationBinderAdapter(value); } } public virtual ISerializationBinder SerializationBinder { get { return _serializationBinder; } set { if (value == null) { throw new ArgumentNullException("value", "Serialization binder cannot be null."); } _serializationBinder = value; } } public virtual ITraceWriter? TraceWriter { get { return _traceWriter; } set { _traceWriter = value; } } public virtual IEqualityComparer? EqualityComparer { get { return _equalityComparer; } set { _equalityComparer = value; } } public virtual TypeNameHandling TypeNameHandling { get { return _typeNameHandling; } set { if (value < TypeNameHandling.None || value > TypeNameHandling.Auto) { throw new ArgumentOutOfRangeException("value"); } _typeNameHandling = value; } } [Obsolete("TypeNameAssemblyFormat is obsolete. Use TypeNameAssemblyFormatHandling instead.")] public virtual FormatterAssemblyStyle TypeNameAssemblyFormat { get { return (FormatterAssemblyStyle)_typeNameAssemblyFormatHandling; } set { if (value < FormatterAssemblyStyle.Simple || value > FormatterAssemblyStyle.Full) { throw new ArgumentOutOfRangeException("value"); } _typeNameAssemblyFormatHandling = (TypeNameAssemblyFormatHandling)value; } } public virtual TypeNameAssemblyFormatHandling TypeNameAssemblyFormatHandling { get { return _typeNameAssemblyFormatHandling; } set { if (value < TypeNameAssemblyFormatHandling.Simple || value > TypeNameAssemblyFormatHandling.Full) { throw new ArgumentOutOfRangeException("value"); } _typeNameAssemblyFormatHandling = value; } } public virtual PreserveReferencesHandling PreserveReferencesHandling { get { return _preserveReferencesHandling; } set { if (value < PreserveReferencesHandling.None || value > PreserveReferencesHandling.All) { throw new ArgumentOutOfRangeException("value"); } _preserveReferencesHandling = value; } } public virtual ReferenceLoopHandling ReferenceLoopHandling { get { return _referenceLoopHandling; } set { if (value < ReferenceLoopHandling.Error || value > ReferenceLoopHandling.Serialize) { throw new ArgumentOutOfRangeException("value"); } _referenceLoopHandling = value; } } public virtual MissingMemberHandling MissingMemberHandling { get { return _missingMemberHandling; } set { if (value < MissingMemberHandling.Ignore || value > MissingMemberHandling.Error) { throw new ArgumentOutOfRangeException("value"); } _missingMemberHandling = value; } } public virtual NullValueHandling NullValueHandling { get { return _nullValueHandling; } set { if (value < NullValueHandling.Include || value > NullValueHandling.Ignore) { throw new ArgumentOutOfRangeException("value"); } _nullValueHandling = value; } } public virtual DefaultValueHandling DefaultValueHandling { get { return _defaultValueHandling; } set { if (value < DefaultValueHandling.Include || value > DefaultValueHandling.IgnoreAndPopulate) { throw new ArgumentOutOfRangeException("value"); } _defaultValueHandling = value; } } public virtual ObjectCreationHandling ObjectCreationHandling { get { return _objectCreationHandling; } set { if (value < ObjectCreationHandling.Auto || value > ObjectCreationHandling.Replace) { throw new ArgumentOutOfRangeException("value"); } _objectCreationHandling = value; } } public virtual ConstructorHandling ConstructorHandling { get { return _constructorHandling; } set { if (value < ConstructorHandling.Default || value > ConstructorHandling.AllowNonPublicDefaultConstructor) { throw new ArgumentOutOfRangeException("value"); } _constructorHandling = value; } } public virtual MetadataPropertyHandling MetadataPropertyHandling { get { return _metadataPropertyHandling; } set { if (value < MetadataPropertyHandling.Default || value > MetadataPropertyHandling.Ignore) { throw new ArgumentOutOfRangeException("value"); } _metadataPropertyHandling = value; } } public virtual JsonConverterCollection Converters { get { if (_converters == null) { _converters = new JsonConverterCollection(); } return _converters; } } public virtual IContractResolver ContractResolver { get { return _contractResolver; } set { _contractResolver = value ?? DefaultContractResolver.Instance; } } public virtual StreamingContext Context { get { return _context; } set { _context = value; } } public virtual Formatting Formatting { get { return _formatting.GetValueOrDefault(); } set { _formatting = value; } } public virtual DateFormatHandling DateFormatHandling { get { return _dateFormatHandling.GetValueOrDefault(); } set { _dateFormatHandling = value; } } public virtual DateTimeZoneHandling DateTimeZoneHandling { get { return _dateTimeZoneHandling ?? DateTimeZoneHandling.RoundtripKind; } set { _dateTimeZoneHandling = value; } } public virtual DateParseHandling DateParseHandling { get { return _dateParseHandling ?? DateParseHandling.DateTime; } set { _dateParseHandling = value; } } public virtual FloatParseHandling FloatParseHandling { get { return _floatParseHandling.GetValueOrDefault(); } set { _floatParseHandling = value; } } public virtual FloatFormatHandling FloatFormatHandling { get { return _floatFormatHandling.GetValueOrDefault(); } set { _floatFormatHandling = value; } } public virtual StringEscapeHandling StringEscapeHandling { get { return _stringEscapeHandling.GetValueOrDefault(); } set { _stringEscapeHandling = value; } } public virtual string DateFormatString { get { return _dateFormatString ?? "yyyy'-'MM'-'dd'T'HH':'mm':'ss.FFFFFFFK"; } set { _dateFormatString = value; _dateFormatStringSet = true; } } public virtual CultureInfo Culture { get { return _culture ?? JsonSerializerSettings.DefaultCulture; } set { _culture = value; } } public virtual int? MaxDepth { get { return _maxDepth; } set { if (value <= 0) { throw new ArgumentException("Value must be positive.", "value"); } _maxDepth = value; _maxDepthSet = true; } } public virtual bool CheckAdditionalContent { get { return _checkAdditionalContent.GetValueOrDefault(); } set { _checkAdditionalContent = value; } } public virtual event EventHandler<Newtonsoft.Json.Serialization.ErrorEventArgs>? Error; internal bool IsCheckAdditionalContentSet() { return _checkAdditionalContent.HasValue; } public JsonSerializer() { _referenceLoopHandling = ReferenceLoopHandling.Error; _missingMemberHandling = MissingMemberHandling.Ignore; _nullValueHandling = NullValueHandling.Include; _defaultValueHandling = DefaultValueHandling.Include; _objectCreationHandling = ObjectCreationHandling.Auto; _preserveReferencesHandling = PreserveReferencesHandling.None; _constructorHandling = ConstructorHandling.Default; _typeNameHandling = TypeNameHandling.None; _metadataPropertyHandling = MetadataPropertyHandling.Default; _context = JsonSerializerSettings.DefaultContext; _serializationBinder = DefaultSerializationBinder.Instance; _culture = JsonSerializerSettings.DefaultCulture; _contractResolver = DefaultContractResolver.Instance; } public static JsonSerializer Create() { return new JsonSerializer(); } public static JsonSerializer Create(JsonSerializerSettings? settings) { JsonSerializer jsonSerializer = Create(); if (settings != null) { ApplySerializerSettings(jsonSerializer, settings); } return jsonSerializer; } public static JsonSerializer CreateDefault() { return Create(JsonConvert.DefaultSettings?.Invoke()); } public static JsonSerializer CreateDefault(JsonSerializerSettings? settings) { JsonSerializer jsonSerializer = CreateDefault(); if (settings != null) { ApplySerializerSettings(jsonSerializer, settings); } return jsonSerializer; } private static void ApplySerializerSettings(JsonSerializer serializer, JsonSerializerSettings settings) { if (!CollectionUtils.IsNullOrEmpty(settings.Converters)) { for (int i = 0; i < settings.Converters.Count; i++) { serializer.Converters.Insert(i, settings.Converters[i]); } } if (settings._typeNameHandling.HasValue) { serializer.TypeNameHandling = settings.TypeNameHandling; } if (settings._metadataPropertyHandling.HasValue) { serializer.MetadataPropertyHandling = settings.MetadataPropertyHandling; } if (settings._typeNameAssemblyFormatHandling.HasValue) { serializer.TypeNameAssemblyFormatHandling = settings.TypeNameAssemblyFormatHandling; } if (settings._preserveReferencesHandling.HasValue) { serializer.PreserveReferencesHandling = settings.PreserveReferencesHandling; } if (settings._referenceLoopHandling.HasValue) { serializer.ReferenceLoopHandling = settings.ReferenceLoopHandling; } if (settings._missingMemberHandling.HasValue) { serializer.MissingMemberHandling = settings.MissingMemberHandling; } if (settings._objectCreationHandling.HasValue) { serializer.ObjectCreationHandling = settings.ObjectCreationHandling; } if (settings._nullValueHandling.HasValue) { serializer.NullValueHandling = settings.NullValueHandling; } if (settings._defaultValueHandling.HasValue) { serializer.DefaultValueHandling = settings.DefaultValueHandling; } if (settings._constructorHandling.HasValue) { serializer.ConstructorHandling = settings.ConstructorHandling; } if (settings._context.HasValue) { serializer.Context = settings.Context; } if (settings._checkAdditionalContent.HasValue) { serializer._checkAdditionalContent = settings._checkAdditionalContent; } if (settings.Error != null) { serializer.Error += settings.Error; } if (settings.ContractResolver != null) { serializer.ContractResolver = settings.ContractResolver; } if (settings.ReferenceResolverProvider != null) { serializer.ReferenceResolver = settings.ReferenceResolverProvider(); } if (settings.TraceWriter != null) { serializer.TraceWriter = settings.TraceWriter; } if (settings.EqualityComparer != null) { serializer.EqualityComparer = settings.EqualityComparer; } if (settings.SerializationBinder != null) { serializer.SerializationBinder = settings.SerializationBinder; } if (settings._formatting.HasValue) { serializer._formatting = settings._formatting; } if (settings._dateFormatHandling.HasValue) { serializer._dateFormatHandling = settings._dateFormatHandling; } if (settings._dateTimeZoneHandling.HasValue) { serializer._dateTimeZoneHandling = settings._dateTimeZoneHandling; } if (settings._dateParseHandling.HasValue) { serializer._dateParseHandling = settings._dateParseHandling; } if (settings._dateFormatStringSet) { serializer._dateFormatString = settings._dateFormatString; serializer._dateFormatStringSet = settings._dateFormatStringSet; } if (settings._floatFormatHandling.HasValue) { serializer._floatFormatHandling = settings._floatFormatHandling; } if (settings._floatParseHandling.HasValue) { serializer._floatParseHandling = settings._floatParseHandling; } if (settings._stringEscapeHandling.HasValue) { serializer._stringEscapeHandling = settings._stringEscapeHandling; } if (settings._culture != null) { serializer._culture = settings._culture; } if (settings._maxDepthSet) { serializer._maxDepth = settings._maxDepth; serializer._maxDepthSet = settings._maxDepthSet; } } [DebuggerStepThrough] public void Populate(TextReader reader, object target) { Populate(new JsonTextReader(reader), target); } [DebuggerStepThrough] public void Populate(JsonReader reader, object target) { PopulateInternal(reader, target); } internal virtual void PopulateInternal(JsonReader reader, object target) { ValidationUtils.ArgumentNotNull(reader, "reader"); ValidationUtils.ArgumentNotNull(target, "target"); SetupReader(reader, out CultureInfo previousCulture, out DateTimeZoneHandling? previousDateTimeZoneHandling, out DateParseHandling? previousDateParseHandling, out FloatParseHandling? previousFloatParseHandling, out int? previousMaxDepth, out string previousDateFormatString); TraceJsonReader traceJsonReader = ((TraceWriter != null && TraceWriter.LevelFilter >= TraceLevel.Verbose) ? CreateTraceJsonReader(reader) : null); new JsonSerializerInternalReader(this).Populate(traceJsonReader ?? reader, target); if (traceJsonReader != null) { TraceWriter.Trace(TraceLevel.Verbose, traceJsonReader.GetDeserializedJsonMessage(), null); } ResetReader(reader, previousCulture, previousDateTimeZoneHandling, previousDateParseHandling, previousFloatParseHandling, previousMaxDepth, previousDateFormatString); } [DebuggerStepThrough] public object? Deserialize(JsonReader reader) { return Deserialize(reader, null); } [DebuggerStepThrough] public object? Deserialize(TextReader reader, Type objectType) { return Deserialize(new JsonTextReader(reader), objectType); } [DebuggerStepThrough] public T? Deserialize<T>(JsonReader reader) { return (T)Deserialize(reader, typeof(T)); } [DebuggerStepThrough] public object? Deserialize(JsonReader reader, Type? objectType) { return DeserializeInternal(reader, objectType); } internal virtual object? DeserializeInternal(JsonReader reader, Type? objectType) { ValidationUtils.ArgumentNotNull(reader, "reader"); SetupReader(reader, out CultureInfo previousCulture, out DateTimeZoneHandling? previousDateTimeZoneHandling, out DateParseHandling? previousDateParseHandling, out FloatParseHandling? previousFloatParseHandling, out int? previousMaxDepth, out string previousDateFormatString); TraceJsonReader traceJsonReader = ((TraceWriter != null && TraceWriter.LevelFilter >= TraceLevel.Verbose) ? CreateTraceJsonReader(reader) : null); object? result = new JsonSerializerInternalReader(this).Deserialize(traceJsonReader ?? reader, objectType, CheckAdditionalContent); if (traceJsonReader != null) { TraceWriter.Trace(TraceLevel.Verbose, traceJsonReader.GetDeserializedJsonMessage(), null); } ResetReader(reader, previousCulture, previousDateTimeZoneHandling, previousDateParseHandling, previousFloatParseHandling, previousMaxDepth, previousDateFormatString); return result; } internal void SetupReader(JsonReader reader, out CultureInfo? previousCulture, out DateTimeZoneHandling? previousDateTimeZoneHandling, out DateParseHandling? previousDateParseHandling, out FloatParseHandling? previousFloatParseHandling, out int? previousMaxDepth, out string? previousDateFormatString) { if (_culture != null && !_culture.Equals(reader.Culture)) { previousCulture = reader.Culture; reader.Culture = _culture; } else { previousCulture = null; } if (_dateTimeZoneHandling.HasValue && reader.DateTimeZoneHandling != _dateTimeZoneHandling) { previousDateTimeZoneHandling = reader.DateTimeZoneHandling; reader.DateTimeZoneHandling = _dateTimeZoneHandling.GetValueOrDefault(); } else { previousDateTimeZoneHandling = null; } if (_dateParseHandling.HasValue && reader.DateParseHandling != _dateParseHandling) { previousDateParseHandling = reader.DateParseHandling; reader.DateParseHandling = _dateParseHandling.GetValueOrDefault(); } else { previousDateParseHandling = null; } if (_floatParseHandling.HasValue && reader.FloatParseHandling != _floatParseHandling) { previousFloatParseHandling = reader.FloatParseHandling; reader.FloatParseHandling = _floatParseHandling.GetValueOrDefault(); } else { previousFloatParseHandling = null; } if (_maxDepthSet && reader.MaxDepth != _maxDepth) { previousMaxDepth = reader.MaxDepth; reader.MaxDepth = _maxDepth; } else { previousMaxDepth = null; } if (_dateFormatStringSet && reader.DateFormatString != _dateFormatString) { previousDateFormatString = reader.DateFormatString; reader.DateFormatString = _dateFormatString; } else { previousDateFormatString = null; } if (reader is JsonTextReader jsonTextReader && jsonTextReader.PropertyNameTable == null && _contractResolver is DefaultContractResolver defaultContractResolver) { jsonTextReader.PropertyNameTable = defaultContractResolver.GetNameTable(); } } private void ResetReader(JsonReader reader, CultureInfo? previousCulture, DateTimeZoneHandling? previousDateTimeZoneHandling, DateParseHandling? previousDateParseHandling, FloatParseHandling? previousFloatParseHandling, int? previousMaxDepth, string? previousDateFormatString) { if (previousCulture != null) { reader.Culture = previousCulture; } if (previousDateTimeZoneHandling.HasValue) { reader.DateTimeZoneHandling = previousDateTimeZoneHandling.GetValueOrDefault(); } if (previousDateParseHandling.HasValue) { reader.DateParseHandling = previousDateParseHandling.GetValueOrDefault(); } if (previousFloatParseHandling.HasValue) { reader.FloatParseHandling = previousFloatParseHandling.GetValueOrDefault(); } if (_maxDepthSet) { reader.MaxDepth = previousMaxDepth; } if (_dateFormatStringSet) { reader.DateFormatString = previousDateFormatString; } if (reader is JsonTextReader jsonTextReader && jsonTextReader.PropertyNameTable != null && _contractResolver is DefaultContractResolver defaultContractResolver && jsonTextReader.PropertyNameTable == defaultContractResolver.GetNameTable()) { jsonTextReader.PropertyNameTable = null; } } public void Serialize(TextWriter textWriter, object? value) { Serialize(new JsonTextWriter(textWriter), value); } public void Serialize(JsonWriter jsonWriter, object? value, Type? objectType) { SerializeInternal(jsonWriter, value, objectType); } public void Serialize(TextWriter textWriter, object? value, Type objectType) { Serialize(new JsonTextWriter(textWriter), value, objectType); } public void Serialize(JsonWriter jsonWriter, object? value) { SerializeInternal(jsonWriter, value, null); } private TraceJsonReader CreateTraceJsonReader(JsonReader reader) { TraceJsonReader traceJsonReader = new TraceJsonReader(reader); if (reader.TokenType != 0) { traceJsonReader.WriteCurrentToken(); } return traceJsonReader; } internal virtual void SerializeInternal(JsonWriter jsonWriter, object? value, Type? objectType) { ValidationUtils.ArgumentNotNull(jsonWriter, "jsonWriter"); Formatting? formatting = null; if (_formatting.HasValue && jsonWriter.Formatting != _formatting) { formatting = jsonWriter.Formatting; jsonWriter.Formatting = _formatting.GetValueOrDefault(); } DateFormatHandling? dateFormatHandling = null; if (_dateFormatHandling.HasValue && jsonWriter.DateFormatHandling != _dateFormatHandling) { dateFormatHandling = jsonWriter.DateFormatHandling; jsonWriter.DateFormatHandling = _dateFormatHandling.GetValueOrDefault(); } DateTimeZoneHandling? dateTimeZoneHandling = null; if (_dateTimeZoneHandling.HasValue && jsonWriter.DateTimeZoneHandling != _dateTimeZoneHandling) { dateTimeZoneHandling = jsonWriter.DateTimeZoneHandling; jsonWriter.DateTimeZoneHandling = _dateTimeZoneHandling.GetValueOrDefault(); } FloatFormatHandling? floatFormatHandling = null; if (_floatFormatHandling.HasValue && jsonWriter.FloatFormatHandling != _floatFormatHandling) { floatFormatHandling = jsonWriter.FloatFormatHandling; jsonWriter.FloatFormatHandling = _floatFormatHandling.GetValueOrDefault(); } StringEscapeHandling? stringEscapeHandling = null; if (_stringEscapeHandling.HasValue && jsonWriter.StringEscapeHandling != _stringEscapeHandling) { stringEscapeHandling = jsonWriter.StringEscapeHandling; jsonWriter.StringEscapeHandling = _stringEscapeHandling.GetValueOrDefault(); } CultureInfo cultureInfo = null; if (_culture != null && !_culture.Equals(jsonWriter.Culture)) { cultureInfo = jsonWriter.Culture; jsonWriter.Culture = _culture; } string dateFormatString = null; if (_dateFormatStringSet && jsonWriter.DateFormatString != _dateFormatString) { dateFormatString = jsonWriter.DateFormatString; jsonWriter.DateFormatString = _dateFormatString; } TraceJsonWriter traceJsonWriter = ((TraceWriter != null && TraceWriter.LevelFilter >= TraceLevel.Verbose) ? new TraceJsonWriter(jsonWriter) : null); new JsonSerializerInternalWriter(this).Serialize(traceJsonWriter ?? jsonWriter, value, objectType); if (traceJsonWriter != null) { TraceWriter.Trace(TraceLevel.Verbose, traceJsonWriter.GetSerializedJsonMessage(), null); } if (formatting.HasValue) { jsonWriter.Formatting = formatting.GetValueOrDefault(); } if (dateFormatHandling.HasValue) { jsonWriter.DateFormatHandling = dateFormatHandling.GetValueOrDefault(); } if (dateTimeZoneHandling.HasValue) { jsonWriter.DateTimeZoneHandling = dateTimeZoneHandling.GetValueOrDefault(); } if (floatFormatHandling.HasValue) { jsonWriter.FloatFormatHandling = floatFormatHandling.GetValueOrDefault(); } if (stringEscapeHandling.HasValue) { jsonWriter.StringEscapeHandling = stringEscapeHandling.GetValueOrDefault(); } if (_dateFormatStringSet) { jsonWriter.DateFormatString = dateFormatString; } if (cultureInfo != null) { jsonWriter.Culture = cultureInfo; } } internal IReferenceResolver GetReferenceResolver() { if (_referenceResolver == null) { _referenceResolver = new DefaultReferenceResolver(); } return _referenceResolver; } internal JsonConverter? GetMatchingConverter(Type type) { return GetMatchingConverter(_converters, type); } internal static JsonConverter? GetMatchingConverter(IList<JsonConverter>? converters, Type objectType) { if (converters != null) { for (int i = 0; i < converters.Count; i++) { JsonConverter jsonConverter = converters[i]; if (jsonConverter.CanConvert(objectType)) { return jsonConverter; } } } return null; } internal void OnError(Newtonsoft.Json.Serialization.ErrorEventArgs e) { this.Error?.Invoke(this, e); } } public class JsonSerializerSettings { internal const ReferenceLoopHandling DefaultReferenceLoopHandling = ReferenceLoopHandling.Error; internal const MissingMemberHandling DefaultMissingMemberHandling = MissingMemberHandling.Ignore; internal const NullValueHandling DefaultNullValueHandling = NullValueHandling.Include; internal const DefaultValueHandling DefaultDefaultValueHandling = DefaultValueHandling.Include; internal const ObjectCreationHandling DefaultObjectCreationHandling = ObjectCreationHandling.Auto; internal const PreserveReferencesHandling DefaultPreserveReferencesHandling = PreserveReferencesHandling.None; internal const ConstructorHandling DefaultConstructorHandling = ConstructorHandling.Default; internal const TypeNameHandling DefaultTypeNameHandling = TypeNameHandling.None; internal const MetadataPropertyHandling DefaultMetadataPropertyHandling = MetadataPropertyHandling.Default; internal static readonly StreamingContext DefaultContext; internal const Formatting DefaultFormatting = Formatting.None; internal const DateFormatHandling DefaultDateFormatHandling = DateFormatHandling.IsoDateFormat; internal const DateTimeZoneHandling DefaultDateTimeZoneHandling = DateTimeZoneHandling.RoundtripKind; internal const DateParseHandling DefaultDateParseHandling = DateParseHandling.DateTime; internal const FloatParseHandling DefaultFloatParseHandling = FloatParseHandling.Double; internal const FloatFormatHandling DefaultFloatFormatHandling = FloatFormatHandling.String; internal const StringEscapeHandling DefaultStringEscapeHandling = StringEscapeHandling.Default; internal const TypeNameAssemblyFormatHandling DefaultTypeNameAssemblyFormatHandling = TypeNameAssemblyFormatHandling.Simple; internal static readonly CultureInfo DefaultCulture; internal const bool DefaultCheckAdditionalContent = false; internal const string DefaultDateFormatString = "yyyy'-'MM'-'dd'T'HH':'mm':'ss.FFFFFFFK"; internal const int DefaultMaxDepth = 64; internal Formatting? _formatting; internal DateFormatHandling? _dateFormatHandling; internal DateTimeZoneHandling? _dateTimeZoneHandling; internal DateParseHandling? _dateParseHandling; internal FloatFormatHandling? _floatFormatHandling; internal FloatParseHandling? _floatParseHandling; internal StringEscapeHandling? _stringEscapeHandling; internal CultureInfo? _culture; internal bool? _checkAdditionalContent; internal int? _maxDepth; internal bool _maxDepthSet; internal string? _dateFormatString; internal bool _dateFormatStringSet; internal TypeNameAssemblyFormatHandling? _typeNameAssemblyFormatHandling; internal DefaultValueHandling? _defaultValueHandling; internal PreserveReferencesHandling? _preserveReferencesHandling; internal NullValueHandling? _nullValueHandling; internal ObjectCreationHandling? _objectCreationHandling; internal MissingMemberHandling? _missingMemberHandling; internal ReferenceLoopHandling? _referenceLoopHandling; internal StreamingContext? _context; internal ConstructorHandling? _constructorHandling; internal TypeNameHandling? _typeNameHandling; internal MetadataPropertyHandling? _metadataPropertyHandling; public ReferenceLoopHandling ReferenceLoopHandling { get { return _referenceLoopHandling.GetValueOrDefault(); } set { _referenceLoopHandling = value; } } public MissingMemberHandling MissingMemberHandling { get { return _missingMemberHandling.GetValueOrDefault(); } set { _missingMemberHandling = value; } } public ObjectCreationHandling ObjectCreationHandling { get { return _objectCreationHandling.GetValueOrDefault(); } set { _objectCreationHandling = value; } } public NullValueHandling NullValueHandling { get { return _nullValueHandling.GetValueOrDefault(); } set { _nullValueHandling = value; } } public DefaultValueHandling DefaultValueHandling { get { return _defaultValueHandling.GetValueOrDefault(); } set { _defaultValueHandling = value; } } public IList<JsonConverter> Converters { get; set; } public PreserveReferencesHandling PreserveReferencesHandling { get { return _preserveReferencesHandling.GetValueOrDef
plugins\ServerSync.dll
Decompiled a week agousing System; using System.Collections; using System.Collections.Generic; using System.Diagnostics; using System.Globalization; using System.IO; using System.IO.Compression; using System.Linq; using System.Reflection; using System.Runtime.CompilerServices; using System.Runtime.InteropServices; using System.Runtime.Serialization; using System.Runtime.Versioning; using BepInEx; using BepInEx.Configuration; using HarmonyLib; using JetBrains.Annotations; using Microsoft.CodeAnalysis; using TMPro; using UnityEngine; [assembly: CompilationRelaxations(8)] [assembly: RuntimeCompatibility(WrapNonExceptionThrows = true)] [assembly: Debuggable(DebuggableAttribute.DebuggingModes.Default | DebuggableAttribute.DebuggingModes.DisableOptimizations | DebuggableAttribute.DebuggingModes.IgnoreSymbolStoreSequencePoints | DebuggableAttribute.DebuggingModes.EnableEditAndContinue)] [assembly: AssemblyTitle("ServerSync")] [assembly: AssemblyDescription("")] [assembly: AssemblyConfiguration("")] [assembly: AssemblyCompany("")] [assembly: AssemblyProduct("ServerSync")] [assembly: AssemblyCopyright("Copyright © 2021")] [assembly: AssemblyTrademark("")] [assembly: ComVisible(false)] [assembly: Guid("E16C3332-50B4-4DA6-9E8A-A590C4E5CD49")] [assembly: AssemblyFileVersion("1.0.0.0")] [assembly: TargetFramework(".NETFramework,Version=v4.8", FrameworkDisplayName = ".NET Framework 4.8")] [assembly: AssemblyVersion("1.0.0.0")] [module: RefSafetyRules(11)] namespace Microsoft.CodeAnalysis { [CompilerGenerated] [Microsoft.CodeAnalysis.Embedded] internal sealed class EmbeddedAttribute : Attribute { } } namespace System.Runtime.CompilerServices { [CompilerGenerated] [Microsoft.CodeAnalysis.Embedded] [AttributeUsage(AttributeTargets.Class | AttributeTargets.Property | AttributeTargets.Field | AttributeTargets.Event | AttributeTargets.Parameter | AttributeTargets.ReturnValue | AttributeTargets.GenericParameter, AllowMultiple = false, Inherited = false)] internal sealed class NullableAttribute : Attribute { public readonly byte[] NullableFlags; public NullableAttribute(byte P_0) { NullableFlags = new byte[1] { P_0 }; } public NullableAttribute(byte[] P_0) { NullableFlags = P_0; } } [CompilerGenerated] [Microsoft.CodeAnalysis.Embedded] [AttributeUsage(AttributeTargets.Class | AttributeTargets.Struct | AttributeTargets.Method | AttributeTargets.Interface | AttributeTargets.Delegate, AllowMultiple = false, Inherited = false)] internal sealed class NullableContextAttribute : Attribute { public readonly byte Flag; public NullableContextAttribute(byte P_0) { Flag = P_0; } } [CompilerGenerated] [Microsoft.CodeAnalysis.Embedded] [AttributeUsage(AttributeTargets.Module, AllowMultiple = false, Inherited = false)] internal sealed class RefSafetyRulesAttribute : Attribute { public readonly int Version; public RefSafetyRulesAttribute(int P_0) { Version = P_0; } } } namespace ServerSync { [PublicAPI] public abstract class OwnConfigEntryBase { public object? LocalBaseValue; public bool SynchronizedConfig = true; public abstract ConfigEntryBase BaseConfig { get; } } [PublicAPI] public class SyncedConfigEntry<T> : OwnConfigEntryBase { public readonly ConfigEntry<T> SourceConfig; public override ConfigEntryBase BaseConfig => (ConfigEntryBase)(object)SourceConfig; public T Value { get { return SourceConfig.Value; } set { SourceConfig.Value = value; } } public SyncedConfigEntry(ConfigEntry<T> sourceConfig) { SourceConfig = sourceConfig; base..ctor(); } public void AssignLocalValue(T value) { if (LocalBaseValue == null) { Value = value; } else { LocalBaseValue = value; } } } public abstract class CustomSyncedValueBase { public object? LocalBaseValue; public readonly string Identifier; public readonly Type Type; private object? boxedValue; protected bool localIsOwner; public readonly int Priority; public object? BoxedValue { get { return boxedValue; } set { boxedValue = value; this.ValueChanged?.Invoke(); } } public event Action? ValueChanged; protected CustomSyncedValueBase(ConfigSync configSync, string identifier, Type type, int priority) { Priority = priority; Identifier = identifier; Type = type; configSync.AddCustomValue(this); localIsOwner = configSync.IsSourceOfTruth; configSync.SourceOfTruthChanged += delegate(bool truth) { localIsOwner = truth; }; } } [PublicAPI] public sealed class CustomSyncedValue<T> : CustomSyncedValueBase { public T Value { get { return (T)base.BoxedValue; } set { base.BoxedValue = value; } } public CustomSyncedValue(ConfigSync configSync, string identifier, T value = default(T), int priority = 0) : base(configSync, identifier, typeof(T), priority) { Value = value; } public void AssignLocalValue(T value) { if (localIsOwner) { Value = value; } else { LocalBaseValue = value; } } } internal class ConfigurationManagerAttributes { [UsedImplicitly] public bool? ReadOnly = false; } [PublicAPI] public class ConfigSync { [HarmonyPatch(typeof(ZRpc), "HandlePackage")] private static class SnatchCurrentlyHandlingRPC { public static ZRpc? currentRpc; [HarmonyPrefix] private static void Prefix(ZRpc __instance) { currentRpc = __instance; } } [HarmonyPatch(typeof(ZNet), "Awake")] internal static class RegisterRPCPatch { [HarmonyPostfix] private static void Postfix(ZNet __instance) { isServer = __instance.IsServer(); foreach (ConfigSync configSync2 in configSyncs) { ZRoutedRpc.instance.Register<ZPackage>(configSync2.Name + " ConfigSync", (Action<long, ZPackage>)configSync2.RPC_FromOtherClientConfigSync); if (isServer) { configSync2.InitialSyncDone = true; Debug.Log((object)("Registered '" + configSync2.Name + " ConfigSync' RPC - waiting for incoming connections")); } } if (isServer) { ((MonoBehaviour)__instance).StartCoroutine(WatchAdminListChanges()); } static void SendAdmin(List<ZNetPeer> peers, bool isAdmin) { ZPackage package = ConfigsToPackage(null, null, new PackageEntry[1] { new PackageEntry { section = "Internal", key = "lockexempt", type = typeof(bool), value = isAdmin } }); ConfigSync configSync = configSyncs.First(); if (configSync != null) { ((MonoBehaviour)ZNet.instance).StartCoroutine(configSync.sendZPackage(peers, package)); } } static IEnumerator WatchAdminListChanges() { MethodInfo listContainsId = AccessTools.DeclaredMethod(typeof(ZNet), "ListContainsId", (Type[])null, (Type[])null); SyncedList adminList = (SyncedList)AccessTools.DeclaredField(typeof(ZNet), "m_adminList").GetValue(ZNet.instance); List<string> CurrentList = new List<string>(adminList.GetList()); while (true) { yield return (object)new WaitForSeconds(30f); if (!adminList.GetList().SequenceEqual(CurrentList)) { CurrentList = new List<string>(adminList.GetList()); List<ZNetPeer> adminPeer = ZNet.instance.GetPeers().Where(delegate(ZNetPeer p) { string hostName = p.m_rpc.GetSocket().GetHostName(); return ((object)listContainsId == null) ? adminList.Contains(hostName) : ((bool)listContainsId.Invoke(ZNet.instance, new object[2] { adminList, hostName })); }).ToList(); List<ZNetPeer> nonAdminPeer = ZNet.instance.GetPeers().Except(adminPeer).ToList(); SendAdmin(nonAdminPeer, isAdmin: false); SendAdmin(adminPeer, isAdmin: true); } } } } } [HarmonyPatch(typeof(ZNet), "OnNewConnection")] private static class RegisterClientRPCPatch { [HarmonyPostfix] private static void Postfix(ZNet __instance, ZNetPeer peer) { if (__instance.IsServer()) { return; } foreach (ConfigSync configSync in configSyncs) { peer.m_rpc.Register<ZPackage>(configSync.Name + " ConfigSync", (Action<ZRpc, ZPackage>)configSync.RPC_FromServerConfigSync); } } } private class ParsedConfigs { public readonly Dictionary<OwnConfigEntryBase, object?> configValues = new Dictionary<OwnConfigEntryBase, object>(); public readonly Dictionary<CustomSyncedValueBase, object?> customValues = new Dictionary<CustomSyncedValueBase, object>(); } [HarmonyPatch(typeof(ZNet), "Shutdown")] private class ResetConfigsOnShutdown { [HarmonyPostfix] private static void Postfix() { ProcessingServerUpdate = true; foreach (ConfigSync configSync in configSyncs) { configSync.resetConfigsFromServer(); configSync.IsSourceOfTruth = true; configSync.InitialSyncDone = false; } ProcessingServerUpdate = false; } } [HarmonyPatch(typeof(ZNet), "RPC_PeerInfo")] private class SendConfigsAfterLogin { private class BufferingSocket : ZPlayFabSocket, ISocket { public volatile bool finished = false; public volatile int versionMatchQueued = -1; public readonly List<ZPackage> Package = new List<ZPackage>(); public readonly ISocket Original; public BufferingSocket(ISocket original) { Original = original; ((ZPlayFabSocket)this)..ctor(); } public bool IsConnected() { return Original.IsConnected(); } public ZPackage Recv() { return Original.Recv(); } public int GetSendQueueSize() { return Original.GetSendQueueSize(); } public int GetCurrentSendRate() { return Original.GetCurrentSendRate(); } public bool IsHost() { return Original.IsHost(); } public void Dispose() { Original.Dispose(); } public bool GotNewData() { return Original.GotNewData(); } public void Close() { Original.Close(); } public string GetEndPointString() { return Original.GetEndPointString(); } public void GetAndResetStats(out int totalSent, out int totalRecv) { Original.GetAndResetStats(ref totalSent, ref totalRecv); } public void GetConnectionQuality(out float localQuality, out float remoteQuality, out int ping, out float outByteSec, out float inByteSec) { Original.GetConnectionQuality(ref localQuality, ref remoteQuality, ref ping, ref outByteSec, ref inByteSec); } public ISocket Accept() { return Original.Accept(); } public int GetHostPort() { return Original.GetHostPort(); } public bool Flush() { return Original.Flush(); } public string GetHostName() { return Original.GetHostName(); } public void VersionMatch() { if (finished) { Original.VersionMatch(); } else { versionMatchQueued = Package.Count; } } public void Send(ZPackage pkg) { //IL_0057: Unknown result type (might be due to invalid IL or missing references) //IL_005d: Expected O, but got Unknown int pos = pkg.GetPos(); pkg.SetPos(0); int num = pkg.ReadInt(); if ((num == StringExtensionMethods.GetStableHashCode("PeerInfo") || num == StringExtensionMethods.GetStableHashCode("RoutedRPC") || num == StringExtensionMethods.GetStableHashCode("ZDOData")) && !finished) { ZPackage val = new ZPackage(pkg.GetArray()); val.SetPos(pos); Package.Add(val); } else { pkg.SetPos(pos); Original.Send(pkg); } } } [HarmonyPriority(800)] [HarmonyPrefix] private static void Prefix(ref Dictionary<Assembly, BufferingSocket>? __state, ZNet __instance, ZRpc rpc) { //IL_0078: Unknown result type (might be due to invalid IL or missing references) //IL_007e: Invalid comparison between Unknown and I4 if (!__instance.IsServer()) { return; } BufferingSocket bufferingSocket = new BufferingSocket(rpc.GetSocket()); AccessTools.DeclaredField(typeof(ZRpc), "m_socket").SetValue(rpc, bufferingSocket); object? obj = AccessTools.DeclaredMethod(typeof(ZNet), "GetPeer", new Type[1] { typeof(ZRpc) }, (Type[])null).Invoke(__instance, new object[1] { rpc }); ZNetPeer val = (ZNetPeer)((obj is ZNetPeer) ? obj : null); if (val != null && (int)ZNet.m_onlineBackend > 0) { FieldInfo fieldInfo = AccessTools.DeclaredField(typeof(ZNetPeer), "m_socket"); object? value = fieldInfo.GetValue(val); ZPlayFabSocket val2 = (ZPlayFabSocket)((value is ZPlayFabSocket) ? value : null); if (val2 != null) { typeof(ZPlayFabSocket).GetField("m_remotePlayerId").SetValue(bufferingSocket, val2.m_remotePlayerId); } fieldInfo.SetValue(val, bufferingSocket); } if (__state == null) { __state = new Dictionary<Assembly, BufferingSocket>(); } __state[Assembly.GetExecutingAssembly()] = bufferingSocket; } [HarmonyPostfix] private static void Postfix(Dictionary<Assembly, BufferingSocket> __state, ZNet __instance, ZRpc rpc) { ZRpc rpc2 = rpc; ZNet __instance2 = __instance; Dictionary<Assembly, BufferingSocket> __state2 = __state; ZNetPeer peer; if (__instance2.IsServer()) { object obj = AccessTools.DeclaredMethod(typeof(ZNet), "GetPeer", new Type[1] { typeof(ZRpc) }, (Type[])null).Invoke(__instance2, new object[1] { rpc2 }); peer = (ZNetPeer)((obj is ZNetPeer) ? obj : null); if (peer == null) { SendBufferedData(); } else { ((MonoBehaviour)__instance2).StartCoroutine(sendAsync()); } } void SendBufferedData() { if (rpc2.GetSocket() is BufferingSocket bufferingSocket) { AccessTools.DeclaredField(typeof(ZRpc), "m_socket").SetValue(rpc2, bufferingSocket.Original); object? obj2 = AccessTools.DeclaredMethod(typeof(ZNet), "GetPeer", new Type[1] { typeof(ZRpc) }, (Type[])null).Invoke(__instance2, new object[1] { rpc2 }); ZNetPeer val = (ZNetPeer)((obj2 is ZNetPeer) ? obj2 : null); if (val != null) { AccessTools.DeclaredField(typeof(ZNetPeer), "m_socket").SetValue(val, bufferingSocket.Original); } } BufferingSocket bufferingSocket2 = __state2[Assembly.GetExecutingAssembly()]; bufferingSocket2.finished = true; for (int i = 0; i < bufferingSocket2.Package.Count; i++) { if (i == bufferingSocket2.versionMatchQueued) { bufferingSocket2.Original.VersionMatch(); } bufferingSocket2.Original.Send(bufferingSocket2.Package[i]); } if (bufferingSocket2.Package.Count == bufferingSocket2.versionMatchQueued) { bufferingSocket2.Original.VersionMatch(); } } IEnumerator sendAsync() { foreach (ConfigSync configSync in configSyncs) { List<PackageEntry> entries = new List<PackageEntry>(); if (configSync.CurrentVersion != null) { entries.Add(new PackageEntry { section = "Internal", key = "serverversion", type = typeof(string), value = configSync.CurrentVersion }); } MethodInfo listContainsId = AccessTools.DeclaredMethod(typeof(ZNet), "ListContainsId", (Type[])null, (Type[])null); SyncedList adminList = (SyncedList)AccessTools.DeclaredField(typeof(ZNet), "m_adminList").GetValue(ZNet.instance); entries.Add(new PackageEntry { section = "Internal", key = "lockexempt", type = typeof(bool), value = (((object)listContainsId == null) ? ((object)adminList.Contains(rpc2.GetSocket().GetHostName())) : listContainsId.Invoke(ZNet.instance, new object[2] { adminList, rpc2.GetSocket().GetHostName() })) }); ZPackage package = ConfigsToPackage(configSync.allConfigs.Select((OwnConfigEntryBase c) => c.BaseConfig), configSync.allCustomValues, entries, partial: false); yield return ((MonoBehaviour)__instance2).StartCoroutine(configSync.sendZPackage(new List<ZNetPeer> { peer }, package)); } SendBufferedData(); } } } private class PackageEntry { public string section = null; public string key = null; public Type type = null; public object? value; } [HarmonyPatch(typeof(ConfigEntryBase), "GetSerializedValue")] private static class PreventSavingServerInfo { [HarmonyPrefix] private static bool Prefix(ConfigEntryBase __instance, ref string __result) { OwnConfigEntryBase ownConfigEntryBase = configData(__instance); if (ownConfigEntryBase == null || isWritableConfig(ownConfigEntryBase)) { return true; } __result = TomlTypeConverter.ConvertToString(ownConfigEntryBase.LocalBaseValue, __instance.SettingType); return false; } } [HarmonyPatch(typeof(ConfigEntryBase), "SetSerializedValue")] private static class PreventConfigRereadChangingValues { [HarmonyPrefix] private static bool Prefix(ConfigEntryBase __instance, string value) { OwnConfigEntryBase ownConfigEntryBase = configData(__instance); if (ownConfigEntryBase == null || ownConfigEntryBase.LocalBaseValue == null) { return true; } try { ownConfigEntryBase.LocalBaseValue = TomlTypeConverter.ConvertToValue(value, __instance.SettingType); } catch (Exception ex) { Debug.LogWarning((object)$"Config value of setting \"{__instance.Definition}\" could not be parsed and will be ignored. Reason: {ex.Message}; Value: {value}"); } return false; } } private class InvalidDeserializationTypeException : Exception { public string expected = null; public string received = null; public string field = ""; } public static bool ProcessingServerUpdate; public readonly string Name; public string? DisplayName; public string? CurrentVersion; public string? MinimumRequiredVersion; public bool ModRequired = false; private bool? forceConfigLocking; private bool isSourceOfTruth = true; private static readonly HashSet<ConfigSync> configSyncs; private readonly HashSet<OwnConfigEntryBase> allConfigs = new HashSet<OwnConfigEntryBase>(); private HashSet<CustomSyncedValueBase> allCustomValues = new HashSet<CustomSyncedValueBase>(); private static bool isServer; private static bool lockExempt; private OwnConfigEntryBase? lockedConfig = null; private const byte PARTIAL_CONFIGS = 1; private const byte FRAGMENTED_CONFIG = 2; private const byte COMPRESSED_CONFIG = 4; private readonly Dictionary<string, SortedDictionary<int, byte[]>> configValueCache = new Dictionary<string, SortedDictionary<int, byte[]>>(); private readonly List<KeyValuePair<long, string>> cacheExpirations = new List<KeyValuePair<long, string>>(); private static long packageCounter; public bool IsLocked { get { bool? flag = forceConfigLocking; bool num; if (!flag.HasValue) { if (lockedConfig == null) { goto IL_0052; } num = ((IConvertible)lockedConfig.BaseConfig.BoxedValue).ToInt32(CultureInfo.InvariantCulture) != 0; } else { num = flag.GetValueOrDefault(); } if (!num) { goto IL_0052; } int result = ((!lockExempt) ? 1 : 0); goto IL_0053; IL_0053: return (byte)result != 0; IL_0052: result = 0; goto IL_0053; } set { forceConfigLocking = value; } } public bool IsAdmin => lockExempt || isSourceOfTruth; public bool IsSourceOfTruth { get { return isSourceOfTruth; } private set { if (value != isSourceOfTruth) { isSourceOfTruth = value; this.SourceOfTruthChanged?.Invoke(value); } } } public bool InitialSyncDone { get; private set; } = false; public event Action<bool>? SourceOfTruthChanged; private event Action? lockedConfigChanged; static ConfigSync() { ProcessingServerUpdate = false; configSyncs = new HashSet<ConfigSync>(); lockExempt = false; packageCounter = 0L; RuntimeHelpers.RunClassConstructor(typeof(VersionCheck).TypeHandle); } public ConfigSync(string name) { Name = name; configSyncs.Add(this); new VersionCheck(this); } public SyncedConfigEntry<T> AddConfigEntry<T>(ConfigEntry<T> configEntry) { ConfigEntry<T> configEntry2 = configEntry; OwnConfigEntryBase ownConfigEntryBase = configData((ConfigEntryBase)(object)configEntry2); SyncedConfigEntry<T> syncedEntry = ownConfigEntryBase as SyncedConfigEntry<T>; if (syncedEntry == null) { syncedEntry = new SyncedConfigEntry<T>(configEntry2); AccessTools.DeclaredField(typeof(ConfigDescription), "<Tags>k__BackingField").SetValue(((ConfigEntryBase)configEntry2).Description, new object[1] { new ConfigurationManagerAttributes() }.Concat(((ConfigEntryBase)configEntry2).Description.Tags ?? Array.Empty<object>()).Concat(new SyncedConfigEntry<T>[1] { syncedEntry }).ToArray()); configEntry2.SettingChanged += delegate { if (!ProcessingServerUpdate && syncedEntry.SynchronizedConfig) { Broadcast(ZRoutedRpc.Everybody, (ConfigEntryBase)configEntry2); } }; allConfigs.Add(syncedEntry); } return syncedEntry; } public SyncedConfigEntry<T> AddLockingConfigEntry<T>(ConfigEntry<T> lockingConfig) where T : IConvertible { if (lockedConfig != null) { throw new Exception("Cannot initialize locking ConfigEntry twice"); } lockedConfig = AddConfigEntry<T>(lockingConfig); lockingConfig.SettingChanged += delegate { this.lockedConfigChanged?.Invoke(); }; return (SyncedConfigEntry<T>)lockedConfig; } internal void AddCustomValue(CustomSyncedValueBase customValue) { CustomSyncedValueBase customValue2 = customValue; if (allCustomValues.Select((CustomSyncedValueBase v) => v.Identifier).Concat(new string[1] { "serverversion" }).Contains(customValue2.Identifier)) { throw new Exception("Cannot have multiple settings with the same name or with a reserved name (serverversion)"); } allCustomValues.Add(customValue2); allCustomValues = new HashSet<CustomSyncedValueBase>(allCustomValues.OrderByDescending((CustomSyncedValueBase v) => v.Priority)); customValue2.ValueChanged += delegate { if (!ProcessingServerUpdate) { Broadcast(ZRoutedRpc.Everybody, customValue2); } }; } private void RPC_FromServerConfigSync(ZRpc rpc, ZPackage package) { lockedConfigChanged += serverLockedSettingChanged; IsSourceOfTruth = false; if (HandleConfigSyncRPC(0L, package, clientUpdate: false)) { InitialSyncDone = true; } } private void RPC_FromOtherClientConfigSync(long sender, ZPackage package) { HandleConfigSyncRPC(sender, package, clientUpdate: true); } private bool HandleConfigSyncRPC(long sender, ZPackage package, bool clientUpdate) { //IL_0076: Unknown result type (might be due to invalid IL or missing references) //IL_007d: Expected O, but got Unknown //IL_0250: Unknown result type (might be due to invalid IL or missing references) //IL_0257: Expected O, but got Unknown //IL_01ea: Unknown result type (might be due to invalid IL or missing references) //IL_01f1: Expected O, but got Unknown try { if (isServer && IsLocked) { ZRpc? currentRpc = SnatchCurrentlyHandlingRPC.currentRpc; object obj; if (currentRpc == null) { obj = null; } else { ISocket socket = currentRpc.GetSocket(); obj = ((socket != null) ? socket.GetHostName() : null); } string text = (string)obj; if (text != null) { MethodInfo methodInfo = AccessTools.DeclaredMethod(typeof(ZNet), "ListContainsId", (Type[])null, (Type[])null); SyncedList val = (SyncedList)AccessTools.DeclaredField(typeof(ZNet), "m_adminList").GetValue(ZNet.instance); if (!(((object)methodInfo == null) ? val.Contains(text) : ((bool)methodInfo.Invoke(ZNet.instance, new object[2] { val, text })))) { return false; } } } cacheExpirations.RemoveAll(delegate(KeyValuePair<long, string> kv) { if (kv.Key < DateTimeOffset.Now.Ticks) { configValueCache.Remove(kv.Value); return true; } return false; }); byte b = package.ReadByte(); if ((b & 2u) != 0) { long num = package.ReadLong(); string text2 = sender.ToString() + num; if (!configValueCache.TryGetValue(text2, out SortedDictionary<int, byte[]> value)) { value = new SortedDictionary<int, byte[]>(); configValueCache[text2] = value; cacheExpirations.Add(new KeyValuePair<long, string>(DateTimeOffset.Now.AddSeconds(60.0).Ticks, text2)); } int key = package.ReadInt(); int num2 = package.ReadInt(); value.Add(key, package.ReadByteArray()); if (value.Count < num2) { return false; } configValueCache.Remove(text2); package = new ZPackage(value.Values.SelectMany((byte[] a) => a).ToArray()); b = package.ReadByte(); } ProcessingServerUpdate = true; if ((b & 4u) != 0) { byte[] buffer = package.ReadByteArray(); MemoryStream stream = new MemoryStream(buffer); MemoryStream memoryStream = new MemoryStream(); using (DeflateStream deflateStream = new DeflateStream(stream, CompressionMode.Decompress)) { deflateStream.CopyTo(memoryStream); } package = new ZPackage(memoryStream.ToArray()); b = package.ReadByte(); } if ((b & 1) == 0) { resetConfigsFromServer(); } ParsedConfigs parsedConfigs = ReadConfigsFromPackage(package); ConfigFile val2 = null; bool saveOnConfigSet = false; foreach (KeyValuePair<OwnConfigEntryBase, object> configValue in parsedConfigs.configValues) { if (!isServer && configValue.Key.LocalBaseValue == null) { configValue.Key.LocalBaseValue = configValue.Key.BaseConfig.BoxedValue; } if (val2 == null) { val2 = configValue.Key.BaseConfig.ConfigFile; saveOnConfigSet = val2.SaveOnConfigSet; val2.SaveOnConfigSet = false; } configValue.Key.BaseConfig.BoxedValue = configValue.Value; } if (val2 != null) { val2.SaveOnConfigSet = saveOnConfigSet; val2.Save(); } foreach (KeyValuePair<CustomSyncedValueBase, object> customValue in parsedConfigs.customValues) { if (!isServer) { CustomSyncedValueBase key2 = customValue.Key; if (key2.LocalBaseValue == null) { key2.LocalBaseValue = customValue.Key.BoxedValue; } } customValue.Key.BoxedValue = customValue.Value; } Debug.Log((object)string.Format("Received {0} configs and {1} custom values from {2} for mod {3}", parsedConfigs.configValues.Count, parsedConfigs.customValues.Count, (isServer || clientUpdate) ? $"client {sender}" : "the server", DisplayName ?? Name)); if (!isServer) { serverLockedSettingChanged(); } return true; } finally { ProcessingServerUpdate = false; } } private ParsedConfigs ReadConfigsFromPackage(ZPackage package) { ParsedConfigs parsedConfigs = new ParsedConfigs(); Dictionary<string, OwnConfigEntryBase> dictionary = allConfigs.Where((OwnConfigEntryBase c) => c.SynchronizedConfig).ToDictionary((OwnConfigEntryBase c) => c.BaseConfig.Definition.Section + "_" + c.BaseConfig.Definition.Key, (OwnConfigEntryBase c) => c); Dictionary<string, CustomSyncedValueBase> dictionary2 = allCustomValues.ToDictionary((CustomSyncedValueBase c) => c.Identifier, (CustomSyncedValueBase c) => c); int num = package.ReadInt(); for (int i = 0; i < num; i++) { string text = package.ReadString(); string text2 = package.ReadString(); string text3 = package.ReadString(); Type type = Type.GetType(text3); if (text3 == "" || type != null) { object obj; try { obj = ((text3 == "") ? null : ReadValueWithTypeFromZPackage(package, type)); } catch (InvalidDeserializationTypeException ex) { Debug.LogWarning((object)("Got unexpected struct internal type " + ex.received + " for field " + ex.field + " struct " + text3 + " for " + text2 + " in section " + text + " for mod " + (DisplayName ?? Name) + ", expecting " + ex.expected)); continue; } OwnConfigEntryBase value2; if (text == "Internal") { CustomSyncedValueBase value; if (text2 == "serverversion") { if (obj?.ToString() != CurrentVersion) { Debug.LogWarning((object)("Received server version is not equal: server version = " + (obj?.ToString() ?? "null") + "; local version = " + (CurrentVersion ?? "unknown"))); } } else if (text2 == "lockexempt") { if (obj is bool flag) { lockExempt = flag; } } else if (dictionary2.TryGetValue(text2, out value)) { if ((text3 == "" && (!value.Type.IsValueType || Nullable.GetUnderlyingType(value.Type) != null)) || GetZPackageTypeString(value.Type) == text3) { parsedConfigs.customValues[value] = obj; continue; } Debug.LogWarning((object)("Got unexpected type " + text3 + " for internal value " + text2 + " for mod " + (DisplayName ?? Name) + ", expecting " + value.Type.AssemblyQualifiedName)); } } else if (dictionary.TryGetValue(text + "_" + text2, out value2)) { Type type2 = configType(value2.BaseConfig); if ((text3 == "" && (!type2.IsValueType || Nullable.GetUnderlyingType(type2) != null)) || GetZPackageTypeString(type2) == text3) { parsedConfigs.configValues[value2] = obj; continue; } Debug.LogWarning((object)("Got unexpected type " + text3 + " for " + text2 + " in section " + text + " for mod " + (DisplayName ?? Name) + ", expecting " + type2.AssemblyQualifiedName)); } else { Debug.LogWarning((object)("Received unknown config entry " + text2 + " in section " + text + " for mod " + (DisplayName ?? Name) + ". This may happen if client and server versions of the mod do not match.")); } continue; } Debug.LogWarning((object)("Got invalid type " + text3 + ", abort reading of received configs")); return new ParsedConfigs(); } return parsedConfigs; } private static bool isWritableConfig(OwnConfigEntryBase config) { OwnConfigEntryBase config2 = config; ConfigSync configSync = configSyncs.FirstOrDefault((ConfigSync cs) => cs.allConfigs.Contains(config2)); if (configSync == null) { return true; } return configSync.IsSourceOfTruth || !config2.SynchronizedConfig || config2.LocalBaseValue == null || (!configSync.IsLocked && (config2 != configSync.lockedConfig || lockExempt)); } private void serverLockedSettingChanged() { foreach (OwnConfigEntryBase allConfig in allConfigs) { configAttribute<ConfigurationManagerAttributes>(allConfig.BaseConfig).ReadOnly = !isWritableConfig(allConfig); } } private void resetConfigsFromServer() { ConfigFile val = null; bool saveOnConfigSet = false; foreach (OwnConfigEntryBase item in allConfigs.Where((OwnConfigEntryBase config) => config.LocalBaseValue != null)) { if (val == null) { val = item.BaseConfig.ConfigFile; saveOnConfigSet = val.SaveOnConfigSet; val.SaveOnConfigSet = false; } item.BaseConfig.BoxedValue = item.LocalBaseValue; item.LocalBaseValue = null; } if (val != null) { val.SaveOnConfigSet = saveOnConfigSet; } foreach (CustomSyncedValueBase item2 in allCustomValues.Where((CustomSyncedValueBase config) => config.LocalBaseValue != null)) { item2.BoxedValue = item2.LocalBaseValue; item2.LocalBaseValue = null; } lockedConfigChanged -= serverLockedSettingChanged; serverLockedSettingChanged(); } private IEnumerator<bool> distributeConfigToPeers(ZNetPeer peer, ZPackage package) { ZNetPeer peer2 = peer; ZRoutedRpc rpc = ZRoutedRpc.instance; if (rpc == null) { yield break; } byte[] data = package.GetArray(); if (data != null && data.LongLength > 250000) { int fragments = (int)(1 + (data.LongLength - 1) / 250000); long packageIdentifier = ++packageCounter; int fragment = 0; while (fragment < fragments) { foreach (bool item in waitForQueue()) { yield return item; } if (peer2.m_socket.IsConnected()) { ZPackage fragmentedPackage = new ZPackage(); fragmentedPackage.Write((byte)2); fragmentedPackage.Write(packageIdentifier); fragmentedPackage.Write(fragment); fragmentedPackage.Write(fragments); fragmentedPackage.Write(data.Skip(250000 * fragment).Take(250000).ToArray()); SendPackage(fragmentedPackage); if (fragment != fragments - 1) { yield return true; } int num = fragment + 1; fragment = num; continue; } break; } yield break; } foreach (bool item2 in waitForQueue()) { yield return item2; } SendPackage(package); void SendPackage(ZPackage pkg) { string text = Name + " ConfigSync"; if (isServer) { peer2.m_rpc.Invoke(text, new object[1] { pkg }); } else { rpc.InvokeRoutedRPC(peer2.m_server ? 0 : peer2.m_uid, text, new object[1] { pkg }); } } IEnumerable<bool> waitForQueue() { float timeout = Time.time + 30f; while (peer2.m_socket.GetSendQueueSize() > 20000) { if (Time.time > timeout) { Debug.Log((object)$"Disconnecting {peer2.m_uid} after 30 seconds config sending timeout"); peer2.m_rpc.Invoke("Error", new object[1] { (object)(ConnectionStatus)5 }); ZNet.instance.Disconnect(peer2); break; } yield return false; } } } private IEnumerator sendZPackage(long target, ZPackage package) { if (!Object.op_Implicit((Object)(object)ZNet.instance)) { return Enumerable.Empty<object>().GetEnumerator(); } List<ZNetPeer> list = (List<ZNetPeer>)AccessTools.DeclaredField(typeof(ZRoutedRpc), "m_peers").GetValue(ZRoutedRpc.instance); if (target != ZRoutedRpc.Everybody) { list = list.Where((ZNetPeer p) => p.m_uid == target).ToList(); } return sendZPackage(list, package); } private IEnumerator sendZPackage(List<ZNetPeer> peers, ZPackage package) { ZPackage package2 = package; if (!Object.op_Implicit((Object)(object)ZNet.instance)) { yield break; } byte[] rawData = package2.GetArray(); if (rawData != null && rawData.LongLength > 10000) { ZPackage compressedPackage = new ZPackage(); compressedPackage.Write((byte)4); MemoryStream output = new MemoryStream(); using (DeflateStream deflateStream = new DeflateStream(output, CompressionLevel.Optimal)) { deflateStream.Write(rawData, 0, rawData.Length); } compressedPackage.Write(output.ToArray()); package2 = compressedPackage; } List<IEnumerator<bool>> writers = (from peer in peers where peer.IsReady() select peer into p select distributeConfigToPeers(p, package2)).ToList(); writers.RemoveAll((IEnumerator<bool> writer) => !writer.MoveNext()); while (writers.Count > 0) { yield return null; writers.RemoveAll((IEnumerator<bool> writer) => !writer.MoveNext()); } } private void Broadcast(long target, params ConfigEntryBase[] configs) { if (!IsLocked || isServer) { ZPackage package = ConfigsToPackage(configs); ZNet instance = ZNet.instance; if (instance != null) { ((MonoBehaviour)instance).StartCoroutine(sendZPackage(target, package)); } } } private void Broadcast(long target, params CustomSyncedValueBase[] customValues) { if (!IsLocked || isServer) { ZPackage package = ConfigsToPackage(null, customValues); ZNet instance = ZNet.instance; if (instance != null) { ((MonoBehaviour)instance).StartCoroutine(sendZPackage(target, package)); } } } private static OwnConfigEntryBase? configData(ConfigEntryBase config) { return config.Description.Tags?.OfType<OwnConfigEntryBase>().SingleOrDefault(); } public static SyncedConfigEntry<T>? ConfigData<T>(ConfigEntry<T> config) { return ((ConfigEntryBase)config).Description.Tags?.OfType<SyncedConfigEntry<T>>().SingleOrDefault(); } private static T configAttribute<T>(ConfigEntryBase config) { return config.Description.Tags.OfType<T>().First(); } private static Type configType(ConfigEntryBase config) { return configType(config.SettingType); } private static Type configType(Type type) { return type.IsEnum ? Enum.GetUnderlyingType(type) : type; } private static ZPackage ConfigsToPackage(IEnumerable<ConfigEntryBase>? configs = null, IEnumerable<CustomSyncedValueBase>? customValues = null, IEnumerable<PackageEntry>? packageEntries = null, bool partial = true) { //IL_0051: Unknown result type (might be due to invalid IL or missing references) //IL_0057: Expected O, but got Unknown List<ConfigEntryBase> list = configs?.Where((ConfigEntryBase config) => configData(config).SynchronizedConfig).ToList() ?? new List<ConfigEntryBase>(); List<CustomSyncedValueBase> list2 = customValues?.ToList() ?? new List<CustomSyncedValueBase>(); ZPackage val = new ZPackage(); val.Write((byte)(partial ? 1 : 0)); val.Write(list.Count + list2.Count + (packageEntries?.Count() ?? 0)); foreach (PackageEntry item in packageEntries ?? Array.Empty<PackageEntry>()) { AddEntryToPackage(val, item); } foreach (CustomSyncedValueBase item2 in list2) { AddEntryToPackage(val, new PackageEntry { section = "Internal", key = item2.Identifier, type = item2.Type, value = item2.BoxedValue }); } foreach (ConfigEntryBase item3 in list) { AddEntryToPackage(val, new PackageEntry { section = item3.Definition.Section, key = item3.Definition.Key, type = configType(item3), value = item3.BoxedValue }); } return val; } private static void AddEntryToPackage(ZPackage package, PackageEntry entry) { package.Write(entry.section); package.Write(entry.key); package.Write((entry.value == null) ? "" : GetZPackageTypeString(entry.type)); AddValueToZPackage(package, entry.value); } private static string GetZPackageTypeString(Type type) { return type.AssemblyQualifiedName; } private static void AddValueToZPackage(ZPackage package, object? value) { Type type = value?.GetType(); if (value is Enum) { value = ((IConvertible)value).ToType(Enum.GetUnderlyingType(value.GetType()), CultureInfo.InvariantCulture); } else { if (value is ICollection collection) { package.Write(collection.Count); { foreach (object item in collection) { AddValueToZPackage(package, item); } return; } } if ((object)type != null && type.IsValueType && !type.IsPrimitive) { FieldInfo[] fields = type.GetFields(BindingFlags.Instance | BindingFlags.Public | BindingFlags.NonPublic); package.Write(fields.Length); FieldInfo[] array = fields; foreach (FieldInfo fieldInfo in array) { package.Write(GetZPackageTypeString(fieldInfo.FieldType)); AddValueToZPackage(package, fieldInfo.GetValue(value)); } return; } } ZRpc.Serialize(new object[1] { value }, ref package); } private static object ReadValueWithTypeFromZPackage(ZPackage package, Type type) { if ((object)type != null && type.IsValueType && !type.IsPrimitive && !type.IsEnum) { FieldInfo[] fields = type.GetFields(BindingFlags.Instance | BindingFlags.Public | BindingFlags.NonPublic); int num = package.ReadInt(); if (num != fields.Length) { throw new InvalidDeserializationTypeException { received = $"(field count: {num})", expected = $"(field count: {fields.Length})" }; } object uninitializedObject = FormatterServices.GetUninitializedObject(type); FieldInfo[] array = fields; foreach (FieldInfo fieldInfo in array) { string text = package.ReadString(); if (text != GetZPackageTypeString(fieldInfo.FieldType)) { throw new InvalidDeserializationTypeException { received = text, expected = GetZPackageTypeString(fieldInfo.FieldType), field = fieldInfo.Name }; } fieldInfo.SetValue(uninitializedObject, ReadValueWithTypeFromZPackage(package, fieldInfo.FieldType)); } return uninitializedObject; } if (type.IsGenericType && type.GetGenericTypeDefinition() == typeof(Dictionary<, >)) { int num2 = package.ReadInt(); IDictionary dictionary = (IDictionary)Activator.CreateInstance(type); Type type2 = typeof(KeyValuePair<, >).MakeGenericType(type.GenericTypeArguments); FieldInfo field = type2.GetField("key", BindingFlags.Instance | BindingFlags.NonPublic); FieldInfo field2 = type2.GetField("value", BindingFlags.Instance | BindingFlags.NonPublic); for (int j = 0; j < num2; j++) { object obj = ReadValueWithTypeFromZPackage(package, type2); dictionary.Add(field.GetValue(obj), field2.GetValue(obj)); } return dictionary; } if (type != typeof(List<string>) && type.IsGenericType) { Type type3 = typeof(ICollection<>).MakeGenericType(type.GenericTypeArguments[0]); if ((object)type3 != null && type3.IsAssignableFrom(type)) { int num3 = package.ReadInt(); object obj2 = Activator.CreateInstance(type); MethodInfo method = type3.GetMethod("Add"); for (int k = 0; k < num3; k++) { method.Invoke(obj2, new object[1] { ReadValueWithTypeFromZPackage(package, type.GenericTypeArguments[0]) }); } return obj2; } } ParameterInfo parameterInfo = (ParameterInfo)FormatterServices.GetUninitializedObject(typeof(ParameterInfo)); AccessTools.DeclaredField(typeof(ParameterInfo), "ClassImpl").SetValue(parameterInfo, type); List<object> source = new List<object>(); ZRpc.Deserialize(new ParameterInfo[2] { null, parameterInfo }, package, ref source); return source.First(); } } [PublicAPI] [HarmonyPatch] public class VersionCheck { private static readonly HashSet<VersionCheck> versionChecks; private static readonly Dictionary<string, string> notProcessedNames; public string Name; private string? displayName; private string? currentVersion; private string? minimumRequiredVersion; public bool ModRequired = true; private string? ReceivedCurrentVersion; private string? ReceivedMinimumRequiredVersion; private readonly List<ZRpc> ValidatedClients = new List<ZRpc>(); private ConfigSync? ConfigSync; public string DisplayName { get { return displayName ?? Name; } set { displayName = value; } } public string CurrentVersion { get { return currentVersion ?? "0.0.0"; } set { currentVersion = value; } } public string MinimumRequiredVersion { get { return minimumRequiredVersion ?? (ModRequired ? CurrentVersion : "0.0.0"); } set { minimumRequiredVersion = value; } } private static void PatchServerSync() { //IL_005e: Unknown result type (might be due to invalid IL or missing references) //IL_0064: Expected O, but got Unknown Patches patchInfo = PatchProcessor.GetPatchInfo((MethodBase)AccessTools.DeclaredMethod(typeof(ZNet), "Awake", (Type[])null, (Type[])null)); if (patchInfo != null && patchInfo.Postfixes.Count((Patch p) => p.PatchMethod.DeclaringType == typeof(ConfigSync.RegisterRPCPatch)) > 0) { return; } Harmony val = new Harmony("org.bepinex.helpers.ServerSync"); foreach (Type item in from t in typeof(ConfigSync).GetNestedTypes(BindingFlags.NonPublic).Concat(new Type[1] { typeof(VersionCheck) }) where t.IsClass select t) { val.PatchAll(item); } } static VersionCheck() { versionChecks = new HashSet<VersionCheck>(); notProcessedNames = new Dictionary<string, string>(); typeof(ThreadingHelper).GetMethod("StartSyncInvoke").Invoke(ThreadingHelper.Instance, new object[1] { new Action(PatchServerSync) }); } public VersionCheck(string name) { Name = name; ModRequired = true; versionChecks.Add(this); } public VersionCheck(ConfigSync configSync) { ConfigSync = configSync; Name = ConfigSync.Name; versionChecks.Add(this); } public void Initialize() { ReceivedCurrentVersion = null; ReceivedMinimumRequiredVersion = null; if (ConfigSync != null) { Name = ConfigSync.Name; DisplayName = ConfigSync.DisplayName; CurrentVersion = ConfigSync.CurrentVersion; MinimumRequiredVersion = ConfigSync.MinimumRequiredVersion; ModRequired = ConfigSync.ModRequired; } } private bool IsVersionOk() { if (ReceivedMinimumRequiredVersion == null || ReceivedCurrentVersion == null) { return !ModRequired; } bool flag = new Version(CurrentVersion) >= new Version(ReceivedMinimumRequiredVersion); bool flag2 = new Version(ReceivedCurrentVersion) >= new Version(MinimumRequiredVersion); return flag && flag2; } private string ErrorClient() { if (ReceivedMinimumRequiredVersion == null) { return DisplayName + " is not installed on the server."; } return (new Version(CurrentVersion) >= new Version(ReceivedMinimumRequiredVersion)) ? (DisplayName + " may not be higher than version " + ReceivedCurrentVersion + ". You have version " + CurrentVersion + ".") : (DisplayName + " needs to be at least version " + ReceivedMinimumRequiredVersion + ". You have version " + CurrentVersion + "."); } private string ErrorServer(ZRpc rpc) { return "Disconnect: The client (" + rpc.GetSocket().GetHostName() + ") doesn't have the correct " + DisplayName + " version " + MinimumRequiredVersion; } private string Error(ZRpc? rpc = null) { return (rpc == null) ? ErrorClient() : ErrorServer(rpc); } private static VersionCheck[] GetFailedClient() { return versionChecks.Where((VersionCheck check) => !check.IsVersionOk()).ToArray(); } private static VersionCheck[] GetFailedServer(ZRpc rpc) { ZRpc rpc2 = rpc; return versionChecks.Where((VersionCheck check) => check.ModRequired && !check.ValidatedClients.Contains(rpc2)).ToArray(); } private static void Logout() { Game.instance.Logout(true, true); AccessTools.DeclaredField(typeof(ZNet), "m_connectionStatus").SetValue(null, (object)(ConnectionStatus)3); } private static void DisconnectClient(ZRpc rpc) { rpc.Invoke("Error", new object[1] { 3 }); } private static void CheckVersion(ZRpc rpc, ZPackage pkg) { CheckVersion(rpc, pkg, null); } private static void CheckVersion(ZRpc rpc, ZPackage pkg, Action<ZRpc, ZPackage>? original) { string text = pkg.ReadString(); string text2 = pkg.ReadString(); string text3 = pkg.ReadString(); bool flag = false; foreach (VersionCheck versionCheck in versionChecks) { if (!(text != versionCheck.Name)) { Debug.Log((object)("Received " + versionCheck.DisplayName + " version " + text3 + " and minimum version " + text2 + " from the " + (ZNet.instance.IsServer() ? "client" : "server") + ".")); versionCheck.ReceivedMinimumRequiredVersion = text2; versionCheck.ReceivedCurrentVersion = text3; if (ZNet.instance.IsServer() && versionCheck.IsVersionOk()) { versionCheck.ValidatedClients.Add(rpc); } flag = true; } } if (flag) { return; } pkg.SetPos(0); if (original != null) { original(rpc, pkg); if (pkg.GetPos() == 0) { notProcessedNames.Add(text, text3); } } } [HarmonyPatch(typeof(ZNet), "RPC_PeerInfo")] [HarmonyPrefix] private static bool RPC_PeerInfo(ZRpc rpc, ZNet __instance) { VersionCheck[] array = (__instance.IsServer() ? GetFailedServer(rpc) : GetFailedClient()); if (array.Length == 0) { return true; } VersionCheck[] array2 = array; foreach (VersionCheck versionCheck in array2) { Debug.LogWarning((object)versionCheck.Error(rpc)); } if (__instance.IsServer()) { DisconnectClient(rpc); } else { Logout(); } return false; } [HarmonyPatch(typeof(ZNet), "OnNewConnection")] [HarmonyPrefix] private static void RegisterAndCheckVersion(ZNetPeer peer, ZNet __instance) { //IL_018e: Unknown result type (might be due to invalid IL or missing references) //IL_0195: Expected O, but got Unknown notProcessedNames.Clear(); IDictionary dictionary = (IDictionary)typeof(ZRpc).GetField("m_functions", BindingFlags.Instance | BindingFlags.NonPublic).GetValue(peer.m_rpc); if (dictionary.Contains(StringExtensionMethods.GetStableHashCode("ServerSync VersionCheck"))) { object obj = dictionary[StringExtensionMethods.GetStableHashCode("ServerSync VersionCheck")]; Action<ZRpc, ZPackage> action = (Action<ZRpc, ZPackage>)obj.GetType().GetField("m_action", BindingFlags.Instance | BindingFlags.NonPublic).GetValue(obj); peer.m_rpc.Register<ZPackage>("ServerSync VersionCheck", (Action<ZRpc, ZPackage>)delegate(ZRpc rpc, ZPackage pkg) { CheckVersion(rpc, pkg, action); }); } else { peer.m_rpc.Register<ZPackage>("ServerSync VersionCheck", (Action<ZRpc, ZPackage>)CheckVersion); } foreach (VersionCheck versionCheck in versionChecks) { versionCheck.Initialize(); if (versionCheck.ModRequired || __instance.IsServer()) { Debug.Log((object)("Sending " + versionCheck.DisplayName + " version " + versionCheck.CurrentVersion + " and minimum version " + versionCheck.MinimumRequiredVersion + " to the " + (__instance.IsServer() ? "client" : "server") + ".")); ZPackage val = new ZPackage(); val.Write(versionCheck.Name); val.Write(versionCheck.MinimumRequiredVersion); val.Write(versionCheck.CurrentVersion); peer.m_rpc.Invoke("ServerSync VersionCheck", new object[1] { val }); } } } [HarmonyPatch(typeof(ZNet), "Disconnect")] [HarmonyPrefix] private static void RemoveDisconnected(ZNetPeer peer, ZNet __instance) { if (!__instance.IsServer()) { return; } foreach (VersionCheck versionCheck in versionChecks) { versionCheck.ValidatedClients.Remove(peer.m_rpc); } } [HarmonyPatch(typeof(FejdStartup), "ShowConnectError")] [HarmonyPostfix] private static void ShowConnectionError(FejdStartup __instance) { //IL_000e: Unknown result type (might be due to invalid IL or missing references) //IL_0014: Invalid comparison between Unknown and I4 //IL_0186: Unknown result type (might be due to invalid IL or missing references) //IL_018b: Unknown result type (might be due to invalid IL or missing references) //IL_0199: Unknown result type (might be due to invalid IL or missing references) //IL_01de: Unknown result type (might be due to invalid IL or missing references) //IL_01ea: Unknown result type (might be due to invalid IL or missing references) //IL_01f8: Unknown result type (might be due to invalid IL or missing references) //IL_020a: Unknown result type (might be due to invalid IL or missing references) //IL_0219: Unknown result type (might be due to invalid IL or missing references) //IL_021e: Unknown result type (might be due to invalid IL or missing references) //IL_0229: Unknown result type (might be due to invalid IL or missing references) if (!__instance.m_connectionFailedPanel.activeSelf || (int)ZNet.GetConnectionStatus() != 3) { return; } bool flag = false; VersionCheck[] failedClient = GetFailedClient(); if (failedClient.Length != 0) { string text = string.Join("\n", failedClient.Select((VersionCheck check) => check.Error())); TMP_Text connectionFailedError = __instance.m_connectionFailedError; connectionFailedError.text = connectionFailedError.text + "\n" + text; flag = true; } foreach (KeyValuePair<string, string> item in notProcessedNames.OrderBy<KeyValuePair<string, string>, string>((KeyValuePair<string, string> kv) => kv.Key)) { if (!__instance.m_connectionFailedError.text.Contains(item.Key)) { TMP_Text connectionFailedError2 = __instance.m_connectionFailedError; connectionFailedError2.text = connectionFailedError2.text + "\nServer expects you to have " + item.Key + " (Version: " + item.Value + ") installed."; flag = true; } } if (flag) { RectTransform component = ((Component)__instance.m_connectionFailedPanel.transform.Find("Image")).GetComponent<RectTransform>(); Vector2 sizeDelta = component.sizeDelta; sizeDelta.x = 675f; component.sizeDelta = sizeDelta; __instance.m_connectionFailedError.ForceMeshUpdate(false, false); float num = __instance.m_connectionFailedError.renderedHeight + 105f; RectTransform component2 = ((Component)((Component)component).transform.Find("ButtonOk")).GetComponent<RectTransform>(); component2.anchoredPosition = new Vector2(component2.anchoredPosition.x, component2.anchoredPosition.y - (num - component.sizeDelta.y) / 2f); sizeDelta = component.sizeDelta; sizeDelta.y = num; component.sizeDelta = sizeDelta; } } } }
plugins\ValheimRAFT.dll
Decompiled a week agousing System; using System.Collections.Generic; using System.Diagnostics; using System.Reflection; using System.Runtime.CompilerServices; using System.Runtime.InteropServices; using System.Runtime.Versioning; using System.Security; using System.Security.Permissions; using BepInEx; using BepInEx.Configuration; using DynamicLocations.API; using DynamicLocations.Controllers; using JetBrains.Annotations; using Jotunn; using Jotunn.Entities; using Jotunn.Managers; using Jotunn.Utils; using Microsoft.CodeAnalysis; using ServerSync; using UnityEngine; using UnityEngine.Rendering; using ValheimVehicles; using ValheimVehicles.Compat; using ValheimVehicles.Components; using ValheimVehicles.ConsoleCommands; using ValheimVehicles.Controllers; using ValheimVehicles.Injections; using ValheimVehicles.Integrations; using ValheimVehicles.ModSupport; using ValheimVehicles.Prefabs; using ValheimVehicles.Providers; using ValheimVehicles.SharedScripts; using ZdoWatcher; using Zolantris.Shared; [assembly: CompilationRelaxations(8)] [assembly: RuntimeCompatibility(WrapNonExceptionThrows = true)] [assembly: Debuggable(DebuggableAttribute.DebuggingModes.IgnoreSymbolStoreSequencePoints)] [assembly: AssemblyInformationalVersion("3.7.2")] [assembly: AssemblyTitle("ValheimRAFT")] [assembly: AssemblyDescription("Valheim Mod for building on the sea, requires Jotunn to be installed.")] [assembly: AssemblyConfiguration("")] [assembly: AssemblyCompany("Virtualize LLC")] [assembly: AssemblyProduct("ValheimRAFT")] [assembly: AssemblyCopyright("Copyright © 2023-2024, GNU-v3 licensed")] [assembly: Guid("6015B165-2627-40A7-8CA1-3E6B6CD7CB49")] [assembly: AssemblyFileVersion("4.1.0.0")] [assembly: TargetFramework(".NETStandard,Version=v2.1", FrameworkDisplayName = ".NET Standard 2.1")] [assembly: SecurityPermission(SecurityAction.RequestMinimum, SkipVerification = true)] [assembly: AssemblyVersion("4.1.0.0")] [module: UnverifiableCode] [module: RefSafetyRules(11)] namespace Microsoft.CodeAnalysis { [CompilerGenerated] [Microsoft.CodeAnalysis.Embedded] internal sealed class EmbeddedAttribute : Attribute { } } namespace System.Runtime.CompilerServices { [CompilerGenerated] [Microsoft.CodeAnalysis.Embedded] [AttributeUsage(AttributeTargets.Class | AttributeTargets.Property | AttributeTargets.Field | AttributeTargets.Event | AttributeTargets.Parameter | AttributeTargets.ReturnValue | AttributeTargets.GenericParameter, AllowMultiple = false, Inherited = false)] internal sealed class NullableAttribute : Attribute { public readonly byte[] NullableFlags; public NullableAttribute(byte P_0) { NullableFlags = new byte[1] { P_0 }; } public NullableAttribute(byte[] P_0) { NullableFlags = P_0; } } [CompilerGenerated] [Microsoft.CodeAnalysis.Embedded] [AttributeUsage(AttributeTargets.Class | AttributeTargets.Struct | AttributeTargets.Method | AttributeTargets.Interface | AttributeTargets.Delegate, AllowMultiple = false, Inherited = false)] internal sealed class NullableContextAttribute : Attribute { public readonly byte Flag; public NullableContextAttribute(byte P_0) { Flag = P_0; } } [CompilerGenerated] [Microsoft.CodeAnalysis.Embedded] [AttributeUsage(AttributeTargets.Module, AllowMultiple = false, Inherited = false)] internal sealed class RefSafetyRulesAttribute : Attribute { public readonly int Version; public RefSafetyRulesAttribute(int P_0) { Version = P_0; } } } namespace ValheimRAFT { public class DockComponent : MonoBehaviour { private enum DockState { None, EnteringDock, Docked, LeavingDock } private DockState m_dockState; private float m_dockingStrength = 1f; private GameObject m_dockedObject; private Rigidbody m_dockedRigidbody; private ZNetView m_nview; public Transform m_dockLocation; public Transform m_dockExit; public void Awake() { m_nview = ((Component)this).GetComponent<ZNetView>(); } public void FixedUpdate() { if (Object.op_Implicit((Object)(object)m_dockedRigidbody)) { if (m_dockState == DockState.EnteringDock) { PushToward(m_dockLocation); } else if (m_dockState == DockState.LeavingDock) { PushToward(m_dockExit); } } } private void PushToward(Transform target) { //IL_0006: Unknown result type (might be due to invalid IL or missing references) //IL_0016: Unknown result type (might be due to invalid IL or missing references) //IL_001b: Unknown result type (might be due to invalid IL or missing references) //IL_0020: Unknown result type (might be due to invalid IL or missing references) //IL_0029: Unknown result type (might be due to invalid IL or missing references) //IL_0034: Unknown result type (might be due to invalid IL or missing references) Vector3 val = ((Component)target).transform.position - ((Component)m_dockedRigidbody).transform.position; m_dockedRigidbody.AddForce(((Vector3)(ref val)).normalized * m_dockingStrength, (ForceMode)2); } public void OnTriggerEnter(Collider other) { if (Object.op_Implicit((Object)(object)m_dockedObject) && CanDock(other)) { Dock(other); } } private void Dock(Collider other) { ZNetView componentInParent = ((Component)other).GetComponentInParent<ZNetView>(); if (Object.op_Implicit((Object)(object)componentInParent) && componentInParent.IsOwner()) { Rigidbody component = ((Component)componentInParent).GetComponent<Rigidbody>(); if (Object.op_Implicit((Object)(object)component)) { int orCreatePersistentID = ZdoWatchController.Instance.GetOrCreatePersistentID(componentInParent.m_zdo); m_dockedObject = ((Component)componentInParent).gameObject; m_dockedRigidbody = component; m_nview.m_zdo.Set("MBDock_dockedObject", orCreatePersistentID); m_dockState = DockState.EnteringDock; } } } private bool CanDock(Collider other) { if (((Object)other).name.StartsWith("Karve")) { return true; } if (((Object)other).name.StartsWith("VikingShip")) { return true; } return false; } } public class MoveableBaseRootComponent : MonoBehaviour { public void Awake() { LoggerProvider.LogError("V1 vehicles are removed. You should never see this message unless another mod is force rendering ValheimRAFT. Deprecation started at v2.0.0 of ValheimRAFT and v3 does not support v1 rafts anymore.\n This class is retained to not break older mods. It may be removed in future versions.", "C:\\Users\\fre\\dev\\repos\\ValheimMods\\src\\ValheimRAFT\\ValheimRAFT\\MoveableBaseRootComponent.cs", 17); } public void CleanUp() { } private void Sync() { } public void FixedUpdate() { } public void LateUpdate() { } public void Client_UpdateAllPieces() { } public void ServerSyncAllPieces() { } public void UpdatePieces(List<ZDO> list) { } internal float GetColliderBottom() { return 0f; } public static void AddInactivePiece(int id, ZNetView netView) { } public void UpdateMass(ZNetView netView, bool isRemoving = false) { } public void RemovePiece(ZNetView netView) { } private float ComputeContainerWeight(Container container, bool isRemoving = false) { return 0f; } private float ComputePieceWeight(Piece piece, bool isRemoving) { return 0f; } public void DestroyPiece(WearNTear wnt) { } public void DestroyBoat() { } public static void AddDynamicParent(ZNetView source, GameObject target) { } public float GetTotalSailArea() { return 0f; } [Obsolete("GetSailingForce is deprecated, please use VehicleMovementController.GetSailingForce instead.")] public float GetSailingForce() { return 0f; } public static void AddDynamicParent(ZNetView source, GameObject target, Vector3 offset) { } public static void InitZDO(ZDO zdo) { } public static void RemoveZDO(ZDO zdo) { } private static int GetParentID(ZDO zdo) { return 0; } public static void InitPiece(ZNetView netview) { } public void ActivatePiece(ZNetView netview) { } public void AddTemporaryPiece(Piece piece) { } public void AddNewPiece(Piece piece) { } public void AddNewPiece(ZNetView netView) { } public void AddPiece(ZNetView netView) { } private void UpdatePieceCount() { } public void EncapsulateBounds(ZNetView netview) { } internal int GetPieceCount() { return 0; } } public class MoveableBaseShipComponent : MonoBehaviour { [Flags] public enum MBFlags { None = 0, IsAnchored = 1, HideMesh = 2 } public VehicleDebugHelpers VehicleDebugHelpersInstance; public MoveableBaseRootComponent m_baseRoot; public bool isCreative; internal Rigidbody m_rigidbody; internal Ship m_ship; internal ShipStats m_shipStats = new ShipStats(); internal ZNetView m_nview; internal GameObject m_baseRootObject; internal ZSyncTransform m_zsync; public float m_targetHeight; public float m_balanceForce = 0.03f; public float m_liftForce = 20f; public MBFlags m_flags; public bool IsAnchored => m_flags.HasFlag(MBFlags.IsAnchored); public MoveableBaseRootComponent GetMbRoot() { return m_baseRoot; } public void Awake() { } public void UpdateVisual() { } public void OnDestroy() { } public ShipStats GetShipStats() { return m_shipStats; } private void FirstTimeCreation() { } public void Ascend() { } public void Descent() { } public void UpdateStats(bool flight) { } public void SetAnchor(bool state) { } public void RPC_SetAnchor(long sender, bool state) { } internal void SetVisual(bool state) { } public void RPC_SetVisual(long sender, bool state) { } } [BepInPlugin("zolantris.ValheimRAFT", "ValheimRAFT", "4.1.0")] [BepInDependency(/*Could not decode attribute arguments.*/)] [BepInDependency("zolantris.DynamicLocations", "1.2.0")] [BepInDependency(/*Could not decode attribute arguments.*/)] [NetworkCompatibility(/*Could not decode attribute arguments.*/)] public class ValheimRaftPlugin : BaseUnityPlugin { public const string Author = "zolantris"; public const string ModName = "ValheimRAFT"; public const string ModGuid = "zolantris.ValheimRAFT"; public const string ModDescription = "Valheim Mod for building on the sea, requires Jotunn to be installed."; public const string CopyRight = "Copyright © 2023-2024, GNU-v3 licensed"; public static ConfigSync ModConfigSync = new ConfigSync("ValheimRAFT") { DisplayName = "ValheimRAFT", CurrentVersion = GetPluginVersion(), ModRequired = true, IsLocked = true }; public static string Version => "4.1.0"; public static string HarmonyGuid => "zolantris.ValheimRAFT"; public static ValheimRaftPlugin Instance { get; private set; } private ConfigDescription CreateConfigDescription(string description, bool isAdmin = false, bool isAdvanced = false, AcceptableValueBase? acceptableValues = null) { //IL_000b: Unknown result type (might be due to invalid IL or missing references) //IL_0010: Unknown result type (might be due to invalid IL or missing references) //IL_0017: Unknown result type (might be due to invalid IL or missing references) //IL_0024: Expected O, but got Unknown //IL_0024: Unknown result type (might be due to invalid IL or missing references) //IL_002a: Expected O, but got Unknown return new ConfigDescription(description, acceptableValues, new object[1] { (object)new ConfigurationManagerAttributes { IsAdminOnly = isAdmin, IsAdvanced = isAdvanced } }); } [UsedImplicitly] public static string GetPluginVersion() { return Version; } [UsedImplicitly] public static string GetPluginName() { return "ValheimRAFT"; } public void Awake() { Instance = this; ProviderInitializers.InitProviders(((BaseUnityPlugin)this).Logger, ((Component)this).gameObject); ValheimRAFT_API.RegisterHost((object)Instance); PrefabRegistryController.InitValheimVehiclesAssetBundle(); ValheimVehiclesPlugin.CreateConfigFromValheimRAFTPluginConfig(ModConfigSync, ((BaseUnityPlugin)this).Config); PatchController.Apply(HarmonyGuid); AddPhysicsSettings(); RegisterVehicleConsoleCommands(); PrefabManager.OnVanillaPrefabsAvailable += delegate { if ((Object)(object)ZNet.instance == (Object)null || ZNetExtension.IsLocalInstance(ZNet.instance) || ZNetExtension.IsClientInstance(ZNet.instance) || !ZNet.instance.IsDedicated()) { LoadCustomTextures(); } AddCustomItemsAndPieces(); }; VehicleZDOWatcherDelegate.RegisterToZdoManager(); PowerSystemClusterManager.Init(); AddModSupport(); RenderPipelineAsset defaultRenderPipeline = GraphicsSettings.defaultRenderPipeline; if ((Object)(object)defaultRenderPipeline != (Object)null) { ((BaseUnityPlugin)this).Logger.LogDebug((object)$"Valheim GameEngine is using: <{defaultRenderPipeline}> graphics pipeline "); } ((Component)this).gameObject.AddComponent<ValheimVehiclesPlugin>(); } private void OnDestroy() { PatchController.UnpatchSelf(); } public void AddModSupport() { AddModSupportDynamicLocations(); } public void AddModSupportDynamicLocations() { //IL_0006: Unknown result type (might be due to invalid IL or missing references) //IL_000b: Unknown result type (might be due to invalid IL or missing references) //IL_0015: Expected O, but got Unknown LoginAPIController.AddLoginApiIntegration((DynamicLoginIntegration)new DynamicLocationsLoginIntegration(DynamicLoginIntegration.CreateConfig((BaseUnityPlugin)(object)this, PrefabNames.WaterVehicleShip))); } public void RegisterVehicleConsoleCommands() { //IL_0005: Unknown result type (might be due to invalid IL or missing references) //IL_000f: Expected O, but got Unknown CommandManager.Instance.AddConsoleCommand((ConsoleCommand)new VehicleCommands()); } private void Start() { GenerateAutoDocs(); } private void GenerateAutoDocs() { } private void AddPhysicsSettings() { LayerHelpers.PrintAllLayers(); int num = LayerMask.NameToLayer("vehicle"); for (int i = 0; i < 32; i++) { Physics.IgnoreLayerCollision(29, i, Physics.GetIgnoreLayerCollision(num, i)); } Physics.IgnoreLayerCollision(29, LayerMask.NameToLayer("vehicle"), true); Physics.IgnoreLayerCollision(29, LayerMask.NameToLayer("piece"), false); Physics.IgnoreLayerCollision(29, LayerMask.NameToLayer("character"), true); Physics.IgnoreLayerCollision(29, LayerMask.NameToLayer("smoke"), true); Physics.IgnoreLayerCollision(29, LayerMask.NameToLayer("character_ghost"), true); Physics.IgnoreLayerCollision(29, LayerMask.NameToLayer("weapon"), true); Physics.IgnoreLayerCollision(29, LayerMask.NameToLayer("blocker"), true); Physics.IgnoreLayerCollision(29, LayerMask.NameToLayer("pathblocker"), true); Physics.IgnoreLayerCollision(29, LayerMask.NameToLayer("viewblock"), true); Physics.IgnoreLayerCollision(29, LayerMask.NameToLayer("character_net"), true); Physics.IgnoreLayerCollision(29, LayerMask.NameToLayer("character_noenv"), true); Physics.IgnoreLayerCollision(29, LayerMask.NameToLayer("Default_small"), false); Physics.IgnoreLayerCollision(29, LayerMask.NameToLayer("Default"), false); } private void LoadCustomTextures() { try { foreach (CustomTexture texture in CustomTextureGroup.Load("Sails").Textures) { texture.Texture.wrapMode = (TextureWrapMode)1; if (Object.op_Implicit((Object)(object)texture.Normal)) { texture.Normal.wrapMode = (TextureWrapMode)1; } } foreach (CustomTexture texture2 in CustomTextureGroup.Load("Patterns").Textures) { texture2.Texture.filterMode = (FilterMode)0; texture2.Texture.wrapMode = (TextureWrapMode)0; if (Object.op_Implicit((Object)(object)texture2.Normal)) { texture2.Normal.wrapMode = (TextureWrapMode)0; } } foreach (CustomTexture texture3 in CustomTextureGroup.Load("Logos").Textures) { texture3.Texture.wrapMode = (TextureWrapMode)1; if (Object.op_Implicit((Object)(object)texture3.Normal)) { texture3.Normal.wrapMode = (TextureWrapMode)1; } } } catch (Exception arg) { LoggerProvider.LogWarning($"Problem occurred when loading custom textures from the mod's Asset folder. Please ensure this folder exists. \n{arg}", "C:\\Users\\fre\\dev\\repos\\ValheimMods\\src\\ValheimRAFT\\ValheimRAFT\\ValheimRaftPlugin.cs", 295); } } private void AddCustomItemsAndPieces() { PrefabRegistryController.Initialize(((BaseUnityPlugin)this).Config, "zolantris-ValheimRAFT", Version, "PrefabSnapshots"); PrefabRegistryController.InitAfterVanillaItemsAndPrefabsAreAvailable(); } } } namespace Properties { [AttributeUsage(AttributeTargets.Assembly, Inherited = false, AllowMultiple = false)] internal sealed class SentryDSN : Attribute { public string Dsn { get; } public SentryDSN(string sentryDsn) { Dsn = sentryDsn; } } } namespace ValheimVehicles.SharedScripts { internal static class BuildInfo { public const string Version = "4.1.0"; public const string AssemblyVersion = "4.1.0.0"; public const string FileVersion = "4.1.0.0"; public const string PackageVersion = "4.1.0"; } } namespace System.Runtime.CompilerServices { [AttributeUsage(AttributeTargets.Assembly, AllowMultiple = true)] internal sealed class IgnoresAccessChecksToAttribute : Attribute { internal IgnoresAccessChecksToAttribute(string assemblyName) { } } }
plugins\ValheimVehicles.dll
Decompiled a week ago
The result has been truncated due to the large size, download it to view full contents!
using System; using System.Collections; using System.Collections.Concurrent; using System.Collections.Generic; using System.ComponentModel; using System.Diagnostics; using System.Diagnostics.CodeAnalysis; using System.Globalization; using System.IO; using System.Linq; using System.Reflection; using System.Reflection.Emit; using System.Runtime.CompilerServices; using System.Runtime.InteropServices; using System.Runtime.Versioning; using System.Security; using System.Security.Permissions; using System.Text; using System.Text.RegularExpressions; using Advize_PlantEasily; using BepInEx; using BepInEx.Bootstrap; using BepInEx.Configuration; using BepInEx.Logging; using ComfyGizmo; using DynamicLocations.API; using DynamicLocations.Constants; using DynamicLocations.Controllers; using DynamicLocations.Structs; using HarmonyLib; using JetBrains.Annotations; using Jotunn; using Jotunn.Configs; using Jotunn.Entities; using Jotunn.Extensions; using Jotunn.GUI; using Jotunn.Managers; using Jotunn.Utils; using Microsoft.CodeAnalysis; using Newtonsoft.Json; using PlanBuild.Blueprints.Components; using PlanBuild.Plans; using Registry; using ServerSync; using Splatform; using TMPro; using Unity.Collections; using Unity.Jobs; using UnityEngine; using UnityEngine.Assertions; using UnityEngine.EventSystems; using UnityEngine.Events; using UnityEngine.Experimental.Rendering; using UnityEngine.Rendering; using UnityEngine.Serialization; using UnityEngine.TextCore; using UnityEngine.U2D; using UnityEngine.UI; using UnityEngine.UIElements; using Valheim.UI; using ValheimVehicles.Attributes; using ValheimVehicles.BepInExConfig; using ValheimVehicles.Compat; using ValheimVehicles.Components; using ValheimVehicles.ConsoleCommands; using ValheimVehicles.Controllers; using ValheimVehicles.Enums; using ValheimVehicles.Helpers; using ValheimVehicles.Injections; using ValheimVehicles.Integrations; using ValheimVehicles.Integrations.PowerSystem; using ValheimVehicles.Integrations.PowerSystem.Interfaces; using ValheimVehicles.Interfaces; using ValheimVehicles.ModSupport; using ValheimVehicles.Patches; using ValheimVehicles.Prefabs; using ValheimVehicles.Prefabs.Registry; using ValheimVehicles.Prefabs.ValheimVehicles.Prefabs.Registry; using ValheimVehicles.Propulsion.Rudder; using ValheimVehicles.Propulsion.Sail; using ValheimVehicles.RPC; using ValheimVehicles.Shared.Constants; using ValheimVehicles.SharedScripts; using ValheimVehicles.SharedScripts.Helpers; using ValheimVehicles.SharedScripts.Interfaces; using ValheimVehicles.SharedScripts.Modules; using ValheimVehicles.SharedScripts.PowerSystem; using ValheimVehicles.SharedScripts.PowerSystem.Compute; using ValheimVehicles.SharedScripts.PowerSystem.Interfaces; using ValheimVehicles.SharedScripts.Prefabs; using ValheimVehicles.SharedScripts.Structs; using ValheimVehicles.SharedScripts.UI; using ValheimVehicles.SharedScripts.ValheimVehicles.SharedScripts; using ValheimVehicles.SharedScripts.Validation; using ValheimVehicles.Storage.Serialization; using ValheimVehicles.Structs; using ValheimVehicles.UI; using ValheimVehicles.ValheimVehicles.Components; using ValheimVehicles.ValheimVehicles.Integrations; using ValheimVehicles.ValheimVehicles.Patches; using ValheimVehicles.ValheimVehicles.Plugins; using ValheimVehicles.ValheimVehicles.Prefabs.ValheimVehicles.Prefabs.Registry; using ValheimVehicles.ValheimVehicles.Structs; using ZdoWatcher; using ZdoWatcher.ZdoWatcher.Utils; using Zolantris.Shared; using Zolantris.Shared.Debug; [assembly: CompilationRelaxations(8)] [assembly: RuntimeCompatibility(WrapNonExceptionThrows = true)] [assembly: Debuggable(DebuggableAttribute.DebuggingModes.IgnoreSymbolStoreSequencePoints)] [assembly: AssemblyInformationalVersion("3.7.2")] [assembly: AssemblyTitle("ValheimVehicles")] [assembly: AssemblyProduct("ValheimVehicles")] [assembly: ComVisible(false)] [assembly: Guid("E9B48BE9-4D8E-44DB-961A-D7C279B2CA2B")] [assembly: AssemblyFileVersion("1.0.0.0")] [assembly: TargetFramework(".NETStandard,Version=v2.1", FrameworkDisplayName = ".NET Standard 2.1")] [assembly: SecurityPermission(SecurityAction.RequestMinimum, SkipVerification = true)] [assembly: AssemblyVersion("1.0.0.0")] [module: UnverifiableCode] [module: RefSafetyRules(11)] namespace Microsoft.CodeAnalysis { [CompilerGenerated] [Microsoft.CodeAnalysis.Embedded] internal sealed class EmbeddedAttribute : Attribute { } } namespace System.Runtime.CompilerServices { [CompilerGenerated] [Microsoft.CodeAnalysis.Embedded] [AttributeUsage(AttributeTargets.Class | AttributeTargets.Property | AttributeTargets.Field | AttributeTargets.Event | AttributeTargets.Parameter | AttributeTargets.ReturnValue | AttributeTargets.GenericParameter, AllowMultiple = false, Inherited = false)] internal sealed class NullableAttribute : Attribute { public readonly byte[] NullableFlags; public NullableAttribute(byte P_0) { NullableFlags = new byte[1] { P_0 }; } public NullableAttribute(byte[] P_0) { NullableFlags = P_0; } } [CompilerGenerated] [Microsoft.CodeAnalysis.Embedded] [AttributeUsage(AttributeTargets.Class | AttributeTargets.Struct | AttributeTargets.Method | AttributeTargets.Interface | AttributeTargets.Delegate, AllowMultiple = false, Inherited = false)] internal sealed class NullableContextAttribute : Attribute { public readonly byte Flag; public NullableContextAttribute(byte P_0) { Flag = P_0; } } [CompilerGenerated] [Microsoft.CodeAnalysis.Embedded] [AttributeUsage(AttributeTargets.Module, AllowMultiple = false, Inherited = false)] internal sealed class RefSafetyRulesAttribute : Attribute { public readonly int Version; public RefSafetyRulesAttribute(int P_0) { Version = P_0; } } } [BepInPlugin("dev.inventorypatchdetector", "Inventory Patch Detector", "1.0.0")] public class PatchDetector : BaseUnityPlugin { private void Start() { foreach (MethodInfo item in from m in typeof(Inventory).GetMethods(BindingFlags.Instance | BindingFlags.Public | BindingFlags.NonPublic) where m.Name == "RemoveItem" select m) { Patches patchInfo = Harmony.GetPatchInfo((MethodBase)item); if (patchInfo == null) { continue; } ((BaseUnityPlugin)this).Logger.LogInfo((object)$"RemoveItem PATCHED: {item}"); foreach (Patch prefix in patchInfo.Prefixes) { ((BaseUnityPlugin)this).Logger.LogInfo((object)$" Prefix: {prefix.owner} {prefix.PatchMethod.DeclaringType}.{prefix.PatchMethod.Name}"); } foreach (Patch postfix in patchInfo.Postfixes) { ((BaseUnityPlugin)this).Logger.LogInfo((object)$" Postfix: {postfix.owner} {postfix.PatchMethod.DeclaringType}.{postfix.PatchMethod.Name}"); } foreach (Patch transpiler in patchInfo.Transpilers) { ((BaseUnityPlugin)this).Logger.LogInfo((object)$" Transpiler: {transpiler.owner} {transpiler.PatchMethod.DeclaringType}.{transpiler.PatchMethod.Name}"); } } } } public class NearestTargetScanManager : SingletonBehaviour<NearestTargetScanManager> { [SerializeField] public float scanRadius = 10f; [SerializeField] private string characterLayerName = "character"; [SerializeField] private float scanInterval = 1f; private readonly Collider[] _scanBuffer = (Collider[])(object)new Collider[128]; private readonly List<Character> _nearbyCharacters = new List<Character>(); private float _lastScanTime; private int _layerMask; public IReadOnlyList<Character> CachedCharacters => _nearbyCharacters; public override void Awake() { SingletonBehaviour<NearestTargetScanManager>.Instance = this; _layerMask = 1 << LayerMask.NameToLayer(characterLayerName); } private void FixedUpdate() { if (!((Object)(object)ZNet.instance == (Object)null) && !((Object)(object)ZNetScene.instance == (Object)null) && !((Object)(object)Game.instance == (Object)null) && Time.time - _lastScanTime >= scanInterval) { RefreshNearestTargetsToCurrentPlayer(); } } private void RefreshNearestTargetsToCurrentPlayer() { //IL_0023: Unknown result type (might be due to invalid IL or missing references) if ((Object)(object)Player.m_localPlayer == (Object)null) { return; } _nearbyCharacters.Clear(); int num = Physics.OverlapSphereNonAlloc(((Component)Player.m_localPlayer).transform.position, scanRadius, _scanBuffer, _layerMask); Character item = default(Character); for (int i = 0; i < num; i++) { if (((Component)_scanBuffer[i]).TryGetComponent<Character>(ref item)) { _nearbyCharacters.Add(item); } } _lastScanTime = Time.time; } private void Refresh() { } } public class PowerConduitPlateBridge : PowerNetworkDataEntity<PowerConduitPlateBridge, PowerConduitPlateComponent, PowerConduitData>, IPowerConduit, IPowerNode { public static List<PowerConduitPlateBridge> Instances = new List<PowerConduitPlateBridge>(); public List<Player> m_localPlayers = new List<Player>(); public Coroutine? _triggerCoroutine; public float interval = 2f; public bool MustSync; public Rigidbody m_body; public FixedJoint m_joint; private Transform? _lastParent; public string NetworkId => base.Logic.NetworkId; public Vector3 Position => ((Component)this).transform.position; public Vector3 ConnectorPoint => Position; public bool IsActive => Data.IsActive; public bool IsDemanding => base.Logic.IsDemanding; public void OnEnable() { if (!Instances.Contains(this)) { Instances.Add(this); } } public void OnDisable() { Instances.Remove(this); Instances.RemoveAll((PowerConduitPlateBridge x) => !Object.op_Implicit((Object)(object)x)); } public float RequestPower(float deltaTime) { LoggerProvider.LogWarning("Deprecated RequestPower", "C:\\Users\\fre\\dev\\repos\\ValheimMods\\src\\ValheimVehicles\\ValheimVehicles.Integrations.PowerSystem.Components\\PowerConduitPlateBridge.cs", 51); return 0f; } public float SupplyPower(float deltaTime) { LoggerProvider.LogWarning("Deprecated SupplyPower", "C:\\Users\\fre\\dev\\repos\\ValheimMods\\src\\ValheimVehicles\\ValheimVehicles.Integrations.PowerSystem.Components\\PowerConduitPlateBridge.cs", 56); return 0f; } private void HandlePlayerEnterActiveZone(Player player) { if (Object.op_Implicit((Object)(object)player)) { Data.AddOrUpdate(player.GetPlayerID(), player.GetEitr(), ((Character)player).GetMaxEitr()); if (!m_localPlayers.Contains(player)) { m_localPlayers.Add(player); } base.Logic.SetHasPlayerInRange(Data.HasPlayersWithEitr); } } private void HandlePlayerExitActiveZone(Player player) { if (Object.op_Implicit((Object)(object)player)) { Data.RemovePlayer(((Character)player).GetOwner()); if (m_localPlayers.Contains(player)) { m_localPlayers.Remove(player); } base.Logic.SetHasPlayerInRange(Data.HasPlayersWithEitr); } } private void OnTriggerEnter(Collider other) { Player componentInParent = ((Component)other).GetComponentInParent<Player>(); if (!Object.op_Implicit((Object)(object)componentInParent)) { Physics.IgnoreCollision(other, base.Logic.m_triggerCollider, true); return; } HandlePlayerEnterActiveZone(componentInParent); if (m_localPlayers.Count > 0 && _triggerCoroutine == null) { _triggerCoroutine = ((MonoBehaviour)this).StartCoroutine(HandleTriggerRoutine()); } } private IEnumerator HandleTriggerRoutine() { if (!this.IsNetViewValid(out ZNetView netview)) { _triggerCoroutine = null; yield break; } while (((Behaviour)this).isActiveAndEnabled && m_localPlayers.Count > 0 && (Object)(object)netview != (Object)null && netview.m_zdo != null) { PowerSystemRPC.Request_OfferAllPlayerEitr(netview.m_zdo, m_localPlayers); yield return (object)new WaitForSeconds(interval); } _triggerCoroutine = null; } private void OnTriggerExit(Collider other) { //IL_0050: Unknown result type (might be due to invalid IL or missing references) Player componentInParent = ((Component)other).GetComponentInParent<Player>(); if (Object.op_Implicit((Object)(object)componentInParent)) { HandlePlayerExitActiveZone(componentInParent); if (m_localPlayers.Count <= 0 && _triggerCoroutine != null) { ((MonoBehaviour)this).StopCoroutine(_triggerCoroutine); _triggerCoroutine = null; } if (this.IsNetViewValid(out ZNetView validNetView)) { PowerSystemRPC.Request_PlayerExitedConduit(validNetView.GetZDO().m_uid, componentInParent.GetPlayerID()); } } } protected override void Start() { ((MonoBehaviour)(object)this).WaitForPowerSystemNodeData(delegate(PowerConduitData data) { Data = data; Data.Load(); base.Logic.GetPlayerEitr = () => PowerConduitData.GetAverageEitr(Data.PlayerPeerToData.Values.ToList(), Data.PlayerPeerToData); base.Logic.AddPlayerEitr = delegate(float val) { Data.AddEitrToPlayers(val); }; base.Logic.SubtractPlayerEitr = delegate(float val) { Data.TryRemoveEitrFromPlayers(val); }; _lastParent = ((Component)this).transform.parent; AddRigidbodyIfParentIsRigidbody(); }); base.Start(); } public void OnTransformParentChanged() { Transform parent = ((Component)this).transform.parent; if (!Object.op_Implicit((Object)(object)parent) || !((Object)(object)parent == (Object)(object)_lastParent)) { _lastParent = parent; AddRigidbodyIfParentIsRigidbody(); } } protected void AddRigidbodyIfParentIsRigidbody() { //IL_006d: Unknown result type (might be due to invalid IL or missing references) Rigidbody componentInParent = ((Component)this).GetComponentInParent<Rigidbody>(); if (!Object.op_Implicit((Object)(object)m_body)) { m_body = ((Component)this).gameObject.AddComponent<Rigidbody>(); } m_body.isKinematic = !Object.op_Implicit((Object)(object)componentInParent); if (!Object.op_Implicit((Object)(object)componentInParent)) { if (Object.op_Implicit((Object)(object)m_joint)) { Object.Destroy((Object)(object)m_joint); } } else { FixedJoint obj = ((Component)this).gameObject.AddComponent<FixedJoint>(); ((Joint)obj).connectedBody = componentInParent; ((Joint)obj).axis = Vector3.one; ((Joint)obj).enableCollision = false; } } protected override void OnDestroy() { base.OnDestroy(); } protected override void RegisterDefaultRPCs() { } public void SetNetworkId(string id) { if (this.IsNetViewValid(out ZNetView validNetView)) { string @string = validNetView.GetZDO().GetString("PowerSystem_NetworkId", ""); base.Logic.SetNetworkId(@string); } } GameObject IPowerNode.get_gameObject() { return ((Component)this).gameObject; } } public class CannonHandHeldController : CannonController, Hoverable { [Header("Aiming")] public static float minPitch = -70f; public static float maxPitch = 70f; public static float minYaw = -30f; public static float maxYaw = 50f; [SerializeField] public float defaultElevationDegrees = 5f; [SerializeField] public bool debugDraw; private float _lastPitch; private float _lastYaw; private bool _hasLastAngles; private Quaternion _lastRotation; public static float SquareMagnitudeThreshold = 1E-06f; public static bool ShouldUpdate = true; public AmmoController ammoController; private Player m_player; public Transform? playerParentTransform; public Player? playerParentComponent; public static RPCEntity FireHandHeldCannon_RPC = null; protected internal override void Start() { m_nview = ((Component)this).GetComponentInParent<ZNetView>(); ammoController = ((Component)this).GetComponent<AmmoController>(); TryInitController(); base.Start(); } protected internal override void OnEnable() { base.OnEnable(); base.OnFired += OnCannonFire; } protected internal override void OnDisable() { base.OnDisable(); base.OnFired -= OnCannonFire; } public void OnCannonFire() { //IL_0039: Unknown result type (might be due to invalid IL or missing references) //IL_003e: Unknown result type (might be due to invalid IL or missing references) if (!Object.op_Implicit((Object)(object)m_player)) { m_player = ((Component)this).GetComponentInParent<Player>(); } if (!((Object)(object)m_player == (Object)null)) { ((Character)m_player).ApplyPushback(-((Component)m_player).transform.forward, 0.2f); ((Humanoid)m_player).ResetLoadedWeapon(); } } private bool TryInitController() { try { if ((Object)(object)ammoController == (Object)null) { ammoController = ((Component)this).GetComponent<AmmoController>(); } return (Object)(object)ammoController != (Object)null; } catch (Exception ex) { LoggerProvider.LogError("[HandCannonCameraPitchAiming] Failed to init controller: \n" + ex.Message, "C:\\Users\\fre\\dev\\repos\\ValheimMods\\src\\ValheimVehicles\\ValheimVehicles.Integrations\\CannonHandHeldController.cs", 77); return false; } } public void UpdatePlayerParent() { if (!((Object)(object)playerParentTransform != (Object)null)) { playerParentComponent = ((Component)((Component)this).transform).GetComponentInParent<Player>(); if ((Object)(object)playerParentComponent == (Object)null) { playerParentTransform = null; playerParentComponent = null; } else { playerParentTransform = ((Component)playerParentComponent).transform; } } } protected internal override void FixedUpdate() { //IL_0086: Unknown result type (might be due to invalid IL or missing references) //IL_008b: Unknown result type (might be due to invalid IL or missing references) //IL_0090: Unknown result type (might be due to invalid IL or missing references) //IL_00a0: Unknown result type (might be due to invalid IL or missing references) //IL_00a6: Unknown result type (might be due to invalid IL or missing references) //IL_00c9: Unknown result type (might be due to invalid IL or missing references) //IL_0072: Unknown result type (might be due to invalid IL or missing references) //IL_0077: Unknown result type (might be due to invalid IL or missing references) //IL_007c: Unknown result type (might be due to invalid IL or missing references) //IL_0138: Unknown result type (might be due to invalid IL or missing references) //IL_013d: Unknown result type (might be due to invalid IL or missing references) //IL_013f: Unknown result type (might be due to invalid IL or missing references) //IL_0141: Unknown result type (might be due to invalid IL or missing references) //IL_0146: Unknown result type (might be due to invalid IL or missing references) //IL_014b: Unknown result type (might be due to invalid IL or missing references) //IL_015b: Unknown result type (might be due to invalid IL or missing references) //IL_0160: Unknown result type (might be due to invalid IL or missing references) //IL_0165: Unknown result type (might be due to invalid IL or missing references) //IL_016a: Unknown result type (might be due to invalid IL or missing references) //IL_018e: Unknown result type (might be due to invalid IL or missing references) //IL_0196: Unknown result type (might be due to invalid IL or missing references) //IL_0198: Unknown result type (might be due to invalid IL or missing references) //IL_0174: Unknown result type (might be due to invalid IL or missing references) //IL_0177: Unknown result type (might be due to invalid IL or missing references) //IL_01c1: Unknown result type (might be due to invalid IL or missing references) //IL_01cc: Unknown result type (might be due to invalid IL or missing references) //IL_01d7: Unknown result type (might be due to invalid IL or missing references) //IL_01e1: Unknown result type (might be due to invalid IL or missing references) //IL_01e6: Unknown result type (might be due to invalid IL or missing references) //IL_01eb: Unknown result type (might be due to invalid IL or missing references) if (!ShouldUpdate || !TryInitController()) { return; } UpdatePlayerParent(); bool flag = IsHeldByLocalPlayer(); if ((Object)(object)playerParentTransform == (Object)null) { return; } Transform parent = cannonRotationalTransform.parent; if (!Object.op_Implicit((Object)(object)parent)) { return; } Vector3 val; if (flag) { if ((Object)(object)GameCamera.instance == (Object)null) { return; } Camera camera = GameCamera.instance.m_camera; if ((Object)(object)camera == (Object)null) { return; } val = parent.InverseTransformDirection(((Component)camera).transform.forward); } else { val = parent.InverseTransformDirection(playerParentTransform.forward); } if (((Vector3)(ref val)).sqrMagnitude < SquareMagnitudeThreshold) { return; } float num = Mathf.Atan2(val.x, val.z) * 57.29578f; num = Mathf.Clamp(num, minYaw, maxYaw); float num2 = (0f - Mathf.Asin(Mathf.Clamp(val.y, -1f, 1f))) * 57.29578f; num2 -= defaultElevationDegrees; num2 = Mathf.Clamp(num2, minPitch, maxPitch); if (!_hasLastAngles || !Mathf.Approximately(num2, _lastPitch) || !Mathf.Approximately(num, _lastYaw)) { Quaternion val2 = Quaternion.Euler(num2, num, 0f); Vector3 val3 = val2 * Vector3.forward; if (((Vector3)(ref val3)).sqrMagnitude < 1E-05f) { val2 = Quaternion.LookRotation(Vector3.forward, Vector3.up); } if (!_hasLastAngles || Quaternion.Angle(val2, _lastRotation) > 0.01f) { cannonRotationalTransform.localRotation = val2; _lastRotation = val2; _lastPitch = num2; _lastYaw = num; _hasLastAngles = true; } if (debugDraw) { RuntimeDebugLineDrawer.DrawLine(cannonShooterTransform.position, cannonShooterTransform.position + cannonShooterTransform.forward * 5f, Color.green, 0.1f, 0.04f); } base.FixedUpdate(); } } public void Request_FireHandHeld() { //IL_008f: Unknown result type (might be due to invalid IL or missing references) if (ammoController.GetAmmoAmountFromCannonballVariant(AmmoVariant) < 1) { return; } if (!Object.op_Implicit((Object)(object)m_nview)) { m_nview = ((Component)this).GetComponentInParent<ZNetView>(); } if (!Object.op_Implicit((Object)(object)m_nview)) { LoggerProvider.LogWarning("cannonController missing znetview!", "C:\\Users\\fre\\dev\\repos\\ValheimMods\\src\\ValheimVehicles\\ValheimVehicles.Integrations\\CannonHandHeldController.cs", 186); return; } CannonFireData? cannonFireData = CannonFireData.CreateCannonFireDataFromHandHeld(this); if (!cannonFireData.HasValue) { LoggerProvider.LogWarning("cannonController missing cannonfiredata!", "C:\\Users\\fre\\dev\\repos\\ValheimMods\\src\\ValheimVehicles\\ValheimVehicles.Integrations\\CannonHandHeldController.cs", 192); return; } ZPackage pkg = CannonFireData.WriteToPackage(cannonFireData.Value); cannonRotationalTransform.localRotation = cannonFireData.Value.cannonLocalRotation; FireHandHeldCannon_RPC.Send(ZNetView.Everybody, pkg); if (m_nview.IsOwner()) { ammoController.OnAmmoChangedFromVariant(AmmoVariant, cannonFireData.Value.allocatedAmmo); } else { LoggerProvider.LogWarning("Attempted to decrement ammo but the user is not the owner.", "C:\\Users\\fre\\dev\\repos\\ValheimMods\\src\\ValheimVehicles\\ValheimVehicles.Integrations\\CannonHandHeldController.cs", 205); } } public static void RegisterCannonControllerRPCs() { FireHandHeldCannon_RPC = RPCManager.RegisterRPC("RPC_FireHandHeldCannon", RPC_FireHandHeldCannon); } public static IEnumerator RPC_FireHandHeldCannon(long senderId, ZPackage package) { package.SetPos(0); CannonFireData data = CannonFireData.ReadFromPackage(package); ZDOID cannonControllerZDOID = data.cannonControllerZDOID; GameObject val = ZNetScene.instance.FindInstance(cannonControllerZDOID); if (!Object.op_Implicit((Object)(object)val)) { LoggerProvider.LogWarning($"cannonHandheld {cannonControllerZDOID} not found. CannonController should exist otherwise we cannot instantiate cannonball without collision issues", "C:\\Users\\fre\\dev\\repos\\ValheimMods\\src\\ValheimVehicles\\ValheimVehicles.Integrations\\CannonHandHeldController.cs", 225); yield break; } CannonHandHeldController componentInChildren = val.GetComponentInChildren<CannonHandHeldController>(); if (!Object.op_Implicit((Object)(object)componentInChildren)) { LoggerProvider.LogWarning($"cannonHandheld {cannonControllerZDOID} not found. CannonController should exist otherwise we cannot instantiate cannonball without collision issues", "C:\\Users\\fre\\dev\\repos\\ValheimMods\\src\\ValheimVehicles\\ValheimVehicles.Integrations\\CannonHandHeldController.cs", 233); yield break; } bool isHost = componentInChildren.m_nview.IsOwner(); componentInChildren.FireHandHeldCannon(data, isHost); } internal bool FireHandHeldCannon(CannonFireData data, bool isHost = true) { if (Fire(data, ammoController.GetAmmoAmountFromCannonballVariant(AmmoVariant), isManualFiring: true, isHost)) { return true; } return false; } private bool IsHeldByLocalPlayer() { if ((Object)(object)Player.m_localPlayer == (Object)null) { return false; } if ((Object)(object)playerParentComponent == (Object)null) { return false; } return (Object)(object)Player.m_localPlayer == (Object)(object)playerParentComponent; } public string GetHoverText() { return Localization.instance.Localize("$valheim_vehicles_cannon_handheld_item (H)"); } public string GetHoverName() { return Localization.instance.Localize("$valheim_vehicles_cannon_handheld_item"); } } namespace Registry { public class ShipKeelPrefab : RegisterPrefab<ShipKeelPrefab> { public override void OnRegister() { //IL_0051: Unknown result type (might be due to invalid IL or missing references) //IL_0057: Expected O, but got Unknown //IL_00a4: Unknown result type (might be due to invalid IL or missing references) //IL_00a9: Unknown result type (might be due to invalid IL or missing references) //IL_00b1: Unknown result type (might be due to invalid IL or missing references) //IL_00bc: Unknown result type (might be due to invalid IL or missing references) //IL_00c4: Expected O, but got Unknown //IL_00ca: Unknown result type (might be due to invalid IL or missing references) //IL_00d5: Expected O, but got Unknown GameObject val = PrefabManager.Instance.CreateClonedPrefab(PrefabNames.ShipKeel, LoadValheimVehicleAssets.ShipKeelAsset); PrefabRegistryHelpers.HoistSnapPointsToPrefab(val, val.transform); PrefabRegistryHelpers.AddNetViewWithPersistence(val); PrefabRegistryHelpers.SetWearNTear(val); PrefabRegistryHelpers.AddPieceForPrefab(PrefabNames.ShipKeel, val); PrefabRegistryHelpers.PieceData valueSafe = GeneralExtensions.GetValueSafe<string, PrefabRegistryHelpers.PieceData>(PrefabRegistryHelpers.PieceDataDictionary, PrefabNames.ShipKeel); PieceConfig val2 = new PieceConfig(); val2.PieceTable = PrefabRegistryController.GetPieceTableName(); val2.Description = valueSafe.Description; val2.Icon = LoadValheimVehicleAssets.VehicleSprites.GetSprite("keel"); val2.Category = PrefabRegistryController.SetCategoryName("Structure"); val2.Enabled = true; val2.Requirements = (RequirementConfig[])(object)new RequirementConfig[1] { new RequirementConfig { Amount = 10, Item = "Wood", Recover = true } }; PrefabRegistryController.AddPiece(new CustomPiece(val, false, val2)); } } public class VehiclePiecesPrefab : RegisterPrefab<VehiclePiecesPrefab> { public static GameObject VehiclePiecesContainer; public override void OnRegister() { RegisterPiecesContainer(); } public void RegisterPiecesContainer() { VehiclePiecesContainer = PrefabManager.Instance.CreateClonedPrefab(PrefabNames.VehiclePiecesContainer, LoadValheimVehicleAssets.VehiclePiecesAsset); } } } namespace ValheimVehicles { public class ValheimVehiclesPlugin : MonoBehaviour { public const string Author = "zolantris"; public const string Version = "1.0.0"; internal const string ModName = "ValheimVehicles"; public const string ModGuid = "zolantris.ValheimVehicles"; public static bool HasRunSetup; private static bool HasCreatedConfig; private RetryGuard _languageRetry; private MapPinSync _mapPinSync; private SwivelUIPanelComponentIntegration _swivelUIPanel; private ScreenSizeWatcher _screenSizeWatcher; private PowerNetworkControllerIntegration _powerNetworkController; private Coroutine? translationRoutine; internal static ConfigSync ModConfigSync; public static ValheimVehiclesPlugin Instance { get; private set; } private void Awake() { Instance = this; _languageRetry = new RetryGuard((MonoBehaviour)(object)Instance); if (!Object.op_Implicit((Object)(object)LoadValheimVehicleAssets._bundle)) { PrefabRegistryController.InitValheimVehiclesAssetBundle(); } TMPProHelpers.Init(); } private IEnumerator UpdateTranslationsRoutine() { Stopwatch timer = Stopwatch.StartNew(); while (timer.ElapsedMilliseconds < 10000 && !ModTranslations.CanRunLocalization()) { yield return null; } Localization.OnLanguageChange = (Action)Delegate.Combine(Localization.OnLanguageChange, new Action(OnLanguageChanged)); OnLanguageChanged(); ModTranslations.ForceUpdateTranslations(); yield return (object)new WaitForFixedUpdate(); ModTranslations.ForceUpdateTranslations(); yield return (object)new WaitForSeconds(3f); ModTranslations.ForceUpdateTranslations(); yield return (object)new WaitForSeconds(10f); _languageRetry.Reset(); OnLanguageChanged(); yield return (object)new WaitForSeconds(20f); _languageRetry.Reset(); OnLanguageChanged(); translationRoutine = null; } private void OnEnable() { Setup(); translationRoutine = ((MonoBehaviour)this).StartCoroutine(UpdateTranslationsRoutine()); } private void OnDisable() { ((MonoBehaviour)this).CancelInvoke(); if (translationRoutine != null) { ((MonoBehaviour)this).StopCoroutine(translationRoutine); translationRoutine = null; } HasRunSetup = false; if ((Object)(object)_mapPinSync != (Object)null) { Object.Destroy((Object)(object)_mapPinSync); } if (Localization.instance != null) { Localization.OnLanguageChange = (Action)Delegate.Remove(Localization.OnLanguageChange, new Action(OnLanguageChanged)); } } public void Setup() { if (!HasRunSetup) { SetupComponents(); HasRunSetup = true; } } private void SetupComponents() { _mapPinSync = ((Component)this).gameObject.AddComponent<MapPinSync>(); _swivelUIPanel = ((Component)this).gameObject.AddComponent<SwivelUIPanelComponentIntegration>(); _screenSizeWatcher = ((Component)this).gameObject.AddComponent<ScreenSizeWatcher>(); _powerNetworkController = ((Component)this).gameObject.AddComponent<PowerNetworkControllerIntegration>(); } private void OnLanguageChanged() { ModTranslations.ForceUpdateTranslations(); if (!ModTranslations.IsHealthy()) { _languageRetry.Retry(OnLanguageChanged, 1f); } else { _languageRetry.Reset(); } } [UsedImplicitly] public static void CreateConfigFromValheimRAFTPluginConfig(ConfigSync configSync, ConfigFile config) { if (!HasCreatedConfig) { ModConfigSync = configSync; BepInExBaseConfig<PatchConfig>.BindConfig(config); BepInExBaseConfig<PrefabConfig>.BindConfig(config); BepInExBaseConfig<CannonPrefabConfig>.BindConfig(config); BepInExBaseConfig<RamConfig>.BindConfig(config); BepInExBaseConfig<PrefabRecipeConfig>.BindConfig(config); BepInExBaseConfig<VehicleGuiMenuConfig>.BindConfig(config); BepInExBaseConfig<PropulsionConfig>.BindConfig(config); BepInExBaseConfig<ModSupportConfig>.BindConfig(config); BepInExBaseConfig<CustomMeshConfig>.BindConfig(config); BepInExBaseConfig<WaterConfig>.BindConfig(config); BepInExBaseConfig<PhysicsConfig>.BindConfig(config); BepInExBaseConfig<MinimapConfig>.BindConfig(config); BepInExBaseConfig<HudConfig>.BindConfig(config); BepInExBaseConfig<CameraConfig>.BindConfig(config); BepInExBaseConfig<RenderingConfig>.BindConfig(config); BepInExBaseConfig<VehicleGlobalConfig>.BindConfig(config); BepInExBaseConfig<GuiConfig>.BindConfig(config); BepInExBaseConfig<PowerSystemConfig>.BindConfig(config); BepInExBaseConfig<Mod_PieceOverlapConfig>.BindConfig(config); LoggerProvider.LogInfo("Plugin ValheimVehicles started on server.", "C:\\Users\\fre\\dev\\repos\\ValheimMods\\src\\ValheimVehicles\\ValheimVehiclesPlugin.cs", 197); HasCreatedConfig = true; } } } } namespace ValheimVehicles.Shared.Constants { public static class VehicleZdoVars { public const string ZdoKeyBaseVehicleInitState = "ValheimVehicles_BaseVehicle_Initialized"; public const string ModVersion = "ValheimVehicles_ModVersion"; public const string VehicleFloatationHeight = "ValheimVehicles_VehicleFloatationHeight"; public const string VehicleFloatationCustomModeEnabled = "ValheimVehicles_VehicleFloatationCustomModeEnabled"; public const string ToggleSwitchAction = "ValheimVehicles_ToggleSwitchAction"; public const string RopeConnections = "MBRopeAnchor_Ropes"; public const string SwivelParentId = "SwivelParentId"; public const string Mechanism_Swivel_TargetId = "Mechanism_swivelTargetId"; public const string SwivelSyncPosition = "SwivelSync_Position"; public const string SwivelSyncRotation = "SwivelSync_Rotation"; public const string SwivelSyncVelocity = "SwivelSync_Velocity"; public const string SwivelSyncAngularVelocity = "SwivelSync_AngularVelocity"; public const string PowerSystem_IsActive = "PowerSystem_IsActive"; public const string PowerSystem_NetworkId = "PowerSystem_NetworkId"; public const string PowerSystem_Energy = "PowerSystem_StoredEnergy"; public const string PowerSystem_Fuel = "PowerSystem_StoredFuel"; public const string PowerSystem_FuelOutputRate = "PowerSystem_FuelOutputRate"; public const string PowerSystem_FuelType = "PowerSystem_FuelType"; public const string PowerSystem_EnergyCapacity = "PowerSystem_StoredEnergyCapacity"; public const string PowerSystem_StoredFuelCapacity = "PowerSystem_StoredFuelCapacity"; public const string PowerSystem_IsForceDeactivated = "PowerSystem_ForceDeactivated"; public const string PowerSystem_IsRunning = "PowerSystem_IsRunning"; public const string PowerSystem_IsDemanding = "PowerSystem_IsDemanding"; public const string PowerSystem_BasePowerConsumption = "PowerSystem_BasePowerConsumption"; public const string PowerSystem_Intensity_Level = "PowerSystem_ConsumerLevel"; public static string CustomMeshId = "ValheimVehicles_CustomMesh"; public static string CustomMeshScale = "ValheimVehicles_CustomMeshSize"; public static string CustomMeshPrimitiveType = "ValheimVehicles_CustomMeshPrimitiveType"; public static readonly int MBCultivatableParentIdHash = StringExtensionMethods.GetStableHashCode("MBCultivatableParentId"); public static readonly int TempPieceParentId = StringExtensionMethods.GetStableHashCode("VehicleTempPieceParentId"); public static readonly int DEPRECATED_VehicleFlags = StringExtensionMethods.GetStableHashCode("VehicleFlags"); public static readonly string VehicleAnchorState = "VehicleAnchorState"; public const string VehicleChunkBounds = "VehicleChunkBounds"; public static readonly int VehicleTargetHeight = StringExtensionMethods.GetStableHashCode("VehicleTargetHeight"); public static readonly int VehicleOceanSway = StringExtensionMethods.GetStableHashCode("VehicleOceanSway"); public static readonly int MBParentId = StringExtensionMethods.GetStableHashCode("MBParentId"); public static readonly int MBPositionHash = StringExtensionMethods.GetStableHashCode("MBPosition"); public static readonly int MBRotationHash = StringExtensionMethods.GetStableHashCode("MBRotation"); public static readonly int MBRotationVecHash = StringExtensionMethods.GetStableHashCode("MBRotationVec"); public static readonly int MBPieceCount = StringExtensionMethods.GetStableHashCode("MBPieceCount"); public static readonly KeyValuePair<int, int> MBCultivatableParentHash = ZDO.GetHashZDOID("MBCultivatableParent"); public static readonly KeyValuePair<int, int> MBParentHash = ZDO.GetHashZDOID("MBParent"); } } namespace ValheimVehicles.UI { public static class DropdownHelpers { public static void SetupOptionsAndSelectFirst(TMP_Dropdown dropdown, List<OptionData> options) { if ((Object)(object)dropdown == (Object)null || options == null || options.Count == 0) { LoggerProvider.LogWarning("[DropdownHelpers] Dropdown or options list is null/empty. Cannot setup options.", "C:\\Users\\fre\\dev\\repos\\ValheimMods\\src\\ValheimVehicles\\ValheimVehicles.UI\\DropdownHelpers.cs", 16); return; } dropdown.ClearOptions(); dropdown.AddOptions(options); dropdown.RefreshShownValue(); dropdown.value = 0; dropdown.captionText.text = options[0].text; } } public class DropdownRefreshOnHover : MonoBehaviour, IPointerEnterHandler, IEventSystemHandler { private TMP_Dropdown dropdown; public Action<TMP_Dropdown>? OnPointerEnterAction; private void Awake() { dropdown = ((Component)this).GetComponent<TMP_Dropdown>(); } public void OnPointerEnter(PointerEventData eventData) { OnPointerEnterAction?.Invoke(dropdown); } } public class EditRampComponent { private BoardingRampComponent m_ramp; private GameObject m_editPanel; private InputField m_segmentsInput; private int m_segmentCount; public void ShowPanel(BoardingRampComponent boardingRamp) { m_ramp = boardingRamp; if (!Object.op_Implicit((Object)(object)m_editPanel)) { InitPanel(); } m_segmentCount = boardingRamp.m_segments; m_segmentsInput.SetTextWithoutNotify(boardingRamp.m_segments.ToString()); GUIManager.BlockInput(true); m_editPanel.SetActive(true); } private void InitPanel() { //IL_0094: Unknown result type (might be due to invalid IL or missing references) //IL_009e: Expected O, but got Unknown //IL_00aa: Unknown result type (might be due to invalid IL or missing references) //IL_00b4: Expected O, but got Unknown Transform transform = GUIManager.CustomGUIFront.transform; m_editPanel = Object.Instantiate<GameObject>(PrefabRegistryController.vehicleAssetBundle.LoadAsset<GameObject>("edit_ramp_panel"), transform, false); PanelUtil.ApplyPanelStyle(m_editPanel); m_segmentsInput = ((Component)m_editPanel.transform.Find("SegmentsInput")).GetComponent<InputField>(); Button component = ((Component)m_editPanel.transform.Find("SaveButton")).GetComponent<Button>(); Button component2 = ((Component)m_editPanel.transform.Find("CancelButton")).GetComponent<Button>(); ((UnityEvent)component.onClick).AddListener(new UnityAction(SaveEditPanel)); ((UnityEvent)component2.onClick).AddListener(new UnityAction(CancelEditPanel)); ((UnityEvent<string>)(object)m_segmentsInput.onValueChanged).AddListener((UnityAction<string>)delegate(string val) { int.TryParse(val, out m_segmentCount); m_segmentCount = Mathf.Clamp(m_segmentCount, 2, 32); }); } private void ClosePanel() { GUIManager.BlockInput(false); m_editPanel.SetActive(false); } private void CancelEditPanel() { ClosePanel(); } private void SaveEditPanel() { if ((Object)(object)m_ramp != (Object)null) { m_ramp.SetSegmentCount(m_segmentCount); } ClosePanel(); } } public class EditSailComponentPanel { private GameObject m_editPanel; private GameObject m_editSailPanel; private GameObject m_editPatternPanel; private GameObject m_editLogoPanel; private SailComponent m_editSail; private Toggle[] m_editLockedSailSides; private Toggle[] m_editLockedSailCorners; private Toggle m_sailShrinkingToggle; private GameObject m_locksTri; private GameObject m_locksQuad; private Toggle m_disableClothToggle; private TMP_Dropdown m_sailVariantDropdown; private Transform sailVariantTransform; public static string[] GetVariantNames() { return new string[4] { ModTranslations.CustomSail, ModTranslations.RaftSail, ModTranslations.KarveSail, ModTranslations.DrakkalSail }; } public static string GetMaterialFromVariant(SailComponent.MaterialVariant material) { return material switch { SailComponent.MaterialVariant.Custom => ModTranslations.CustomSail, SailComponent.MaterialVariant.Raft => ModTranslations.RaftSail, SailComponent.MaterialVariant.Drakkal => ModTranslations.DrakkalSail, SailComponent.MaterialVariant.Karve => ModTranslations.KarveSail, _ => ModTranslations.CustomSail, }; } public static SailComponent.MaterialVariant GetVariant(string variantName) { if (variantName == ModTranslations.CustomSail) { return SailComponent.MaterialVariant.Custom; } if (variantName == ModTranslations.RaftSail) { return SailComponent.MaterialVariant.Raft; } if (variantName == ModTranslations.DrakkalSail) { return SailComponent.MaterialVariant.Drakkal; } if (variantName == ModTranslations.KarveSail) { return SailComponent.MaterialVariant.Karve; } return SailComponent.MaterialVariant.Custom; } public void ShowPanel(SailComponent sailComponent) { m_editSail = sailComponent; m_editSail.StartEdit(); bool flag = m_editSail.m_sailCorners.Count == 3; if (!Object.op_Implicit((Object)(object)m_editPanel)) { InitPanel(); } GameObject val = (flag ? m_locksTri : m_locksQuad); m_editLockedSailCorners = (Toggle[])(object)new Toggle[flag ? 3 : 4]; m_editLockedSailSides = (Toggle[])(object)new Toggle[flag ? 3 : 4]; m_locksTri.SetActive(flag); m_locksQuad.SetActive(!flag); m_editLockedSailCorners[0] = ((Component)val.transform.Find("CornerA")).GetComponent<Toggle>(); m_editLockedSailCorners[1] = ((Component)val.transform.Find("CornerB")).GetComponent<Toggle>(); m_editLockedSailCorners[2] = ((Component)val.transform.Find("CornerC")).GetComponent<Toggle>(); if (!flag) { m_editLockedSailCorners[3] = ((Component)val.transform.Find("CornerD")).GetComponent<Toggle>(); } m_editLockedSailSides[0] = ((Component)val.transform.Find("SideA")).GetComponent<Toggle>(); m_editLockedSailSides[1] = ((Component)val.transform.Find("SideB")).GetComponent<Toggle>(); m_editLockedSailSides[2] = ((Component)val.transform.Find("SideC")).GetComponent<Toggle>(); if (!flag) { m_editLockedSailSides[3] = ((Component)val.transform.Find("SideD")).GetComponent<Toggle>(); } UpdateSelectedSailVariant(); for (int i = 0; i < m_editLockedSailCorners.Length; i++) { m_editLockedSailCorners[i].SetIsOnWithoutNotify(m_editSail.m_lockedSailCorners.HasFlag((SailComponent.SailLockedSide)(1 << i))); m_editLockedSailSides[i].SetIsOnWithoutNotify(m_editSail.m_lockedSailSides.HasFlag((SailComponent.SailLockedSide)(1 << i))); } m_sailShrinkingToggle.SetIsOnWithoutNotify(m_editSail.m_sailFlags.HasFlag(SailComponent.SailFlags.AllowSailShrinking)); m_disableClothToggle.SetIsOnWithoutNotify(m_editSail.m_sailFlags.HasFlag(SailComponent.SailFlags.DisableCloth)); GUIManager.BlockInput(true); m_editPanel.SetActive(true); } private void UpdateSelectedSailVariant() { if (!Object.op_Implicit((Object)(object)sailVariantTransform)) { return; } TMP_Dropdown componentInChildren = ((Component)sailVariantTransform).GetComponentInChildren<TMP_Dropdown>(); string[] variantNames = GetVariantNames(); int valueWithoutNotify = 0; try { valueWithoutNotify = variantNames.ToList().FindIndex((string x) => GetVariant(x) == m_editSail.m_materialVariant); } catch (Exception) { } componentInChildren.SetValueWithoutNotify(valueWithoutNotify); } private void InitPanel() { //IL_00c9: Unknown result type (might be due to invalid IL or missing references) //IL_00d3: Expected O, but got Unknown //IL_00f9: Unknown result type (might be due to invalid IL or missing references) //IL_0103: Expected O, but got Unknown //IL_0129: Unknown result type (might be due to invalid IL or missing references) //IL_0133: Expected O, but got Unknown //IL_0178: Unknown result type (might be due to invalid IL or missing references) //IL_0182: Expected O, but got Unknown //IL_0193: Unknown result type (might be due to invalid IL or missing references) //IL_019d: Expected O, but got Unknown //IL_03cc: Unknown result type (might be due to invalid IL or missing references) //IL_03d6: Expected O, but got Unknown //IL_03e3: Unknown result type (might be due to invalid IL or missing references) //IL_03ed: Expected O, but got Unknown //IL_03fb: Unknown result type (might be due to invalid IL or missing references) //IL_0405: Expected O, but got Unknown Transform transform = GUIManager.CustomGUIFront.transform; m_editPanel = Object.Instantiate<GameObject>(LoadValheimRaftAssets.editPanel, transform, false); PanelUtil.ApplyPanelStyle(m_editPanel); GameObject editTexturePanel = LoadValheimRaftAssets.editTexturePanel; PanelUtil.ApplyPanelStyle(editTexturePanel); GUIManager.Instance.ApplyDropdownStyle(((Component)editTexturePanel.transform.Find("TextureName")).GetComponent<Dropdown>(), 15); m_editSailPanel = Object.Instantiate<GameObject>(editTexturePanel, transform, false); m_editPatternPanel = Object.Instantiate<GameObject>(editTexturePanel, transform, false); m_editLogoPanel = Object.Instantiate<GameObject>(editTexturePanel, transform, false); m_editSailPanel.SetActive(false); m_editPatternPanel.SetActive(false); m_editLogoPanel.SetActive(false); ((UnityEvent)((Component)m_editSailPanel.transform.Find("Button")).GetComponent<Button>().onClick).AddListener((UnityAction)delegate { m_editSailPanel.SetActive(false); m_editPanel.SetActive(true); }); ((UnityEvent)((Component)m_editPatternPanel.transform.Find("Button")).GetComponent<Button>().onClick).AddListener((UnityAction)delegate { m_editPatternPanel.SetActive(false); m_editPanel.SetActive(true); }); ((UnityEvent)((Component)m_editLogoPanel.transform.Find("Button")).GetComponent<Button>().onClick).AddListener((UnityAction)delegate { m_editLogoPanel.SetActive(false); m_editPanel.SetActive(true); }); GameObject gameObject = ((Component)m_editPanel.transform.Find("SaveButton")).gameObject; ((UnityEvent)((Component)m_editPanel.transform.Find("CancelButton")).gameObject.GetComponent<Button>().onClick).AddListener(new UnityAction(CancelEditPanel)); ((UnityEvent)gameObject.GetComponent<Button>().onClick).AddListener(new UnityAction(SaveEditPanel)); m_sailShrinkingToggle = ((Component)m_editPanel.transform.Find("SailShrinkingToggle")).GetComponent<Toggle>(); ((UnityEvent<bool>)(object)m_sailShrinkingToggle.onValueChanged).AddListener((UnityAction<bool>)delegate(bool b) { m_editSail.SetSailMastSetting(SailComponent.SailFlags.AllowSailShrinking, b); }); m_disableClothToggle = ((Component)m_editPanel.transform.Find("SailClothToggle")).GetComponent<Toggle>(); ((UnityEvent<bool>)(object)m_disableClothToggle.onValueChanged).AddListener((UnityAction<bool>)delegate(bool b) { m_editSail.SetSailMastSetting(SailComponent.SailFlags.DisableCloth, b); }); m_locksTri = ((Component)m_editPanel.transform.Find("LocksTri")).gameObject; m_locksQuad = ((Component)m_editPanel.transform.Find("LocksQuad")).gameObject; Toggle[] componentsInChildren = m_locksTri.GetComponentsInChildren<Toggle>(); for (int i = 0; i < componentsInChildren.Length; i++) { ((UnityEvent<bool>)(object)componentsInChildren[i].onValueChanged).AddListener((UnityAction<bool>)delegate { UpdateSails(); }); } componentsInChildren = m_locksQuad.GetComponentsInChildren<Toggle>(); for (int i = 0; i < componentsInChildren.Length; i++) { ((UnityEvent<bool>)(object)componentsInChildren[i].onValueChanged).AddListener((UnityAction<bool>)delegate { UpdateSails(); }); } Button component = ((Component)m_editPanel.transform.Find("EditSailButton")).GetComponent<Button>(); Button component2 = ((Component)m_editPanel.transform.Find("EditPatternButton")).GetComponent<Button>(); Button component3 = ((Component)m_editPanel.transform.Find("EditLogoButton")).GetComponent<Button>(); sailVariantTransform = m_editPanel.transform.Find("SailVariant"); if (Object.op_Implicit((Object)(object)sailVariantTransform)) { SwivelUISharedStyles viewStyles = new SwivelUISharedStyles(); string[] variantNames = GetVariantNames(); int num = 0; try { num = variantNames.ToList().FindIndex((string x) => GetVariant(x) == m_editSail.m_materialVariant); } catch (Exception) { } SwivelUIHelpers.AddDropdownRow(sailVariantTransform, viewStyles, ModTranslations.SailVariant, variantNames, variantNames[num], delegate(int val) { if (val <= variantNames.Length - 1) { SailComponent.MaterialVariant variant = GetVariant(variantNames[val]); m_editSail.SetMaterialVariant(variant); } }); } ((UnityEvent)component.onClick).AddListener((UnityAction)delegate { m_editSailPanel.SetActive(true); m_editPatternPanel.SetActive(false); m_editLogoPanel.SetActive(false); m_editPanel.SetActive(false); LoadTexturePanel(m_editSailPanel, m_editSail.GetSailMaterial(), "_Main", CustomTextureGroup.Get("Sails")); }); ((UnityEvent)component2.onClick).AddListener((UnityAction)delegate { m_editSailPanel.SetActive(false); m_editPatternPanel.SetActive(true); m_editLogoPanel.SetActive(false); m_editPanel.SetActive(false); LoadTexturePanel(m_editPatternPanel, m_editSail.GetSailMaterial(), "_Pattern", CustomTextureGroup.Get("Patterns")); }); ((UnityEvent)component3.onClick).AddListener((UnityAction)delegate { m_editSailPanel.SetActive(false); m_editPatternPanel.SetActive(false); m_editLogoPanel.SetActive(true); m_editPanel.SetActive(false); LoadTexturePanel(m_editLogoPanel, m_editSail.GetSailMaterial(), "_Logo", CustomTextureGroup.Get("Logos")); }); } private void LoadTexturePanel(GameObject editPanel, Material mat, string parameterName, CustomTextureGroup group) { //IL_0135: Unknown result type (might be due to invalid IL or missing references) //IL_013f: Expected O, but got Unknown //IL_0192: Unknown result type (might be due to invalid IL or missing references) //IL_019c: Expected O, but got Unknown //IL_02af: Unknown result type (might be due to invalid IL or missing references) //IL_02cf: Unknown result type (might be due to invalid IL or missing references) //IL_02d4: Unknown result type (might be due to invalid IL or missing references) //IL_0311: Unknown result type (might be due to invalid IL or missing references) //IL_0316: Unknown result type (might be due to invalid IL or missing references) Material mat2 = mat; string parameterName2 = parameterName; CustomTextureGroup group2 = group; Button component = ((Component)editPanel.transform.Find("TextureColor")).GetComponent<Button>(); Dropdown component2 = ((Component)editPanel.transform.Find("TextureName")).GetComponent<Dropdown>(); InputField component3 = ((Component)editPanel.transform.Find("OffsetX")).GetComponent<InputField>(); InputField component4 = ((Component)editPanel.transform.Find("OffsetY")).GetComponent<InputField>(); InputField component5 = ((Component)editPanel.transform.Find("TilingX")).GetComponent<InputField>(); InputField component6 = ((Component)editPanel.transform.Find("TilingY")).GetComponent<InputField>(); InputField component7 = ((Component)editPanel.transform.Find("Rotation")).GetComponent<InputField>(); ((UnityEventBase)component.onClick).RemoveAllListeners(); ((UnityEventBase)component2.onValueChanged).RemoveAllListeners(); ((UnityEventBase)component3.onValueChanged).RemoveAllListeners(); ((UnityEventBase)component4.onValueChanged).RemoveAllListeners(); ((UnityEventBase)component5.onValueChanged).RemoveAllListeners(); ((UnityEventBase)component6.onValueChanged).RemoveAllListeners(); ((UnityEventBase)component7.onValueChanged).RemoveAllListeners(); List<OptionData> list = new List<OptionData>(); for (int i = 0; i < group2.Textures.Count; i++) { list.Add(new OptionData(((Object)group2.Textures[i].Texture).name)); } component2.options = list; ((UnityEvent<int>)(object)component2.onValueChanged).AddListener((UnityAction<int>)delegate(int index) { mat2.SetTexture(parameterName2 + "Tex", group2.Textures[index].Texture); if (Object.op_Implicit((Object)(object)group2.Textures[index].Normal)) { mat2.SetTexture(parameterName2 + "Normal", group2.Textures[index].Normal); } }); GUIManager.Instance.ApplyDropdownStyle(component2, 15); ((UnityEvent)component.onClick).AddListener((UnityAction)delegate { //IL_000f: Unknown result type (might be due to invalid IL or missing references) //IL_001e: Unknown result type (might be due to invalid IL or missing references) //IL_002d: Unknown result type (might be due to invalid IL or missing references) //IL_0048: Unknown result type (might be due to invalid IL or missing references) //IL_0059: Unknown result type (might be due to invalid IL or missing references) //IL_0065: Unknown result type (might be due to invalid IL or missing references) //IL_0070: Expected O, but got Unknown //IL_0070: Expected O, but got Unknown GUIManager.Instance.CreateColorPicker(new Vector2(0.5f, 0.5f), new Vector2(0.5f, 0.5f), new Vector2(0.5f, 0.5f), mat2.GetColor(parameterName2 + "Color"), "Color", (ColorEvent)delegate(Color color) { //IL_0016: Unknown result type (might be due to invalid IL or missing references) mat2.SetColor(parameterName2 + "Color", color); }, (ColorEvent)delegate(Color color) { //IL_0016: Unknown result type (might be due to invalid IL or missing references) mat2.SetColor(parameterName2 + "Color", color); }, true); }); ((UnityEvent<string>)(object)component3.onValueChanged).AddListener((UnityAction<string>)delegate(string str) { //IL_0020: Unknown result type (might be due to invalid IL or missing references) //IL_0025: Unknown result type (might be due to invalid IL or missing references) //IL_0044: Unknown result type (might be due to invalid IL or missing references) if (float.TryParse(str, out var result5)) { Vector2 textureOffset3 = mat2.GetTextureOffset(parameterName2 + "Tex"); textureOffset3.x = result5; mat2.SetTextureOffset(parameterName2 + "Tex", textureOffset3); } }); ((UnityEvent<string>)(object)component4.onValueChanged).AddListener((UnityAction<string>)delegate(string str) { //IL_0020: Unknown result type (might be due to invalid IL or missing references) //IL_0025: Unknown result type (might be due to invalid IL or missing references) //IL_0044: Unknown result type (might be due to invalid IL or missing references) if (float.TryParse(str, out var result4)) { Vector2 textureOffset2 = mat2.GetTextureOffset(parameterName2 + "Tex"); textureOffset2.y = result4; mat2.SetTextureOffset(parameterName2 + "Tex", textureOffset2); } }); ((UnityEvent<string>)(object)component5.onValueChanged).AddListener((UnityAction<string>)delegate(string str) { //IL_0020: Unknown result type (might be due to invalid IL or missing references) //IL_0025: Unknown result type (might be due to invalid IL or missing references) //IL_0044: Unknown result type (might be due to invalid IL or missing references) if (float.TryParse(str, out var result3)) { Vector2 textureScale3 = mat2.GetTextureScale(parameterName2 + "Tex"); textureScale3.x = result3; mat2.SetTextureScale(parameterName2 + "Tex", textureScale3); } }); ((UnityEvent<string>)(object)component6.onValueChanged).AddListener((UnityAction<string>)delegate(string str) { //IL_0020: Unknown result type (might be due to invalid IL or missing references) //IL_0025: Unknown result type (might be due to invalid IL or missing references) //IL_0044: Unknown result type (might be due to invalid IL or missing references) if (float.TryParse(str, out var result2)) { Vector2 textureScale2 = mat2.GetTextureScale(parameterName2 + "Tex"); textureScale2.y = result2; mat2.SetTextureScale(parameterName2 + "Tex", textureScale2); } }); string text = parameterName2 + "Rotation"; if (mat2.HasProperty(text)) { ((Component)component7).gameObject.SetActive(true); ((UnityEvent<string>)(object)component7.onValueChanged).AddListener((UnityAction<string>)delegate(string str) { if (float.TryParse(str, out var result)) { mat2.SetFloat(parameterName2 + "Rotation", result); } }); } else { ((Component)component7).gameObject.SetActive(false); } Texture texture = mat2.GetTexture(parameterName2 + "Tex"); CustomTexture textureByHash = group2.GetTextureByHash(StringExtensionMethods.GetStableHashCode(((Object)texture).name)); if (textureByHash != null) { component2.SetValueWithoutNotify(textureByHash.Index); } UpdateColorButton(component, mat2.GetColor(parameterName2 + "Color")); Vector2 textureOffset = mat2.GetTextureOffset(parameterName2 + "Tex"); component3.SetTextWithoutNotify(textureOffset.x.ToString()); component4.SetTextWithoutNotify(textureOffset.y.ToString()); Vector2 textureScale = mat2.GetTextureScale(parameterName2 + "Tex"); component5.SetTextWithoutNotify(textureScale.x.ToString()); component6.SetTextWithoutNotify(textureScale.y.ToString()); if (((Component)component7).gameObject.activeSelf) { component7.SetTextWithoutNotify(mat2.GetFloat(parameterName2 + "Rotation").ToString()); } } private void UpdateColorButton(Button button, Color color) { //IL_000f: Unknown result type (might be due to invalid IL or missing references) //IL_0017: Unknown result type (might be due to invalid IL or missing references) //IL_001f: Unknown result type (might be due to invalid IL or missing references) //IL_0027: Unknown result type (might be due to invalid IL or missing references) //IL_003b: Unknown result type (might be due to invalid IL or missing references) //IL_0043: Unknown result type (might be due to invalid IL or missing references) //IL_0055: Unknown result type (might be due to invalid IL or missing references) color.a = 1f; ColorBlock colors = default(ColorBlock); ((ColorBlock)(ref colors)).normalColor = color; ((ColorBlock)(ref colors)).highlightedColor = color; ((ColorBlock)(ref colors)).disabledColor = color; ((ColorBlock)(ref colors)).fadeDuration = 0.1f; ((ColorBlock)(ref colors)).pressedColor = color; ((ColorBlock)(ref colors)).selectedColor = color; ((ColorBlock)(ref colors)).colorMultiplier = 1f; ((Selectable)button).colors = colors; } private void UpdateSails() { if (Object.op_Implicit((Object)(object)m_editSail)) { m_editSail.m_lockedSailCorners = SailComponent.SailLockedSide.None; for (int i = 0; i < m_editLockedSailCorners.Length; i++) { m_editSail.m_lockedSailCorners |= (SailComponent.SailLockedSide)(m_editLockedSailCorners[i].isOn ? (1 << i) : 0); } m_editSail.m_lockedSailSides = SailComponent.SailLockedSide.None; for (int j = 0; j < m_editLockedSailSides.Length; j++) { m_editSail.m_lockedSailSides |= (SailComponent.SailLockedSide)(m_editLockedSailSides[j].isOn ? (1 << j) : 0); } m_editSail.UpdateCoefficients(); } } private void CloseEditPanel() { if (Object.op_Implicit((Object)(object)m_editPanel)) { m_editPanel.SetActive(false); } if (Object.op_Implicit((Object)(object)m_editSail)) { m_editSail.EndEdit(); } m_editSail = null; GUIManager.BlockInput(false); } private void CancelEditPanel() { if (Object.op_Implicit((Object)(object)m_editSail)) { m_editSail.LoadZDO(); } CloseEditPanel(); } private void SaveEditPanel() { if (Object.op_Implicit((Object)(object)m_editSail)) { m_editSail.LoadFromMaterial(); m_editSail.SaveZdo(); m_editSail.LoadZDO(); } CloseEditPanel(); } } public class PanelUtil { public static GameObject CreateBasicPanel(string panelName, bool hasImage) { //IL_0021: Unknown result type (might be due to invalid IL or missing references) //IL_0027: Expected O, but got Unknown //IL_004e: Unknown result type (might be due to invalid IL or missing references) //IL_0063: Unknown result type (might be due to invalid IL or missing references) //IL_0078: Unknown result type (might be due to invalid IL or missing references) //IL_0083: Unknown result type (might be due to invalid IL or missing references) //IL_0097: Unknown result type (might be due to invalid IL or missing references) //IL_00d6: Unknown result type (might be due to invalid IL or missing references) //IL_00e0: Expected O, but got Unknown GameObject val = new GameObject(panelName, new Type[2] { typeof(RectTransform), typeof(Image) }); ((Object)val).name = panelName; if (!hasImage) { ((Behaviour)val.GetComponent<Image>()).enabled = false; } RectTransform component = val.GetComponent<RectTransform>(); component.anchorMin = new Vector2(0.5f, 0.5f); component.anchorMax = new Vector2(0.5f, 0.5f); component.pivot = new Vector2(0.5f, 0.5f); component.anchoredPosition = Vector2.zero; component.sizeDelta = new Vector2(600f, 0f); VerticalLayoutGroup obj = val.AddComponent<VerticalLayoutGroup>(); ((HorizontalOrVerticalLayoutGroup)obj).childControlHeight = true; ((HorizontalOrVerticalLayoutGroup)obj).childForceExpandHeight = false; ((HorizontalOrVerticalLayoutGroup)obj).childControlWidth = true; ((HorizontalOrVerticalLayoutGroup)obj).childForceExpandWidth = true; ((HorizontalOrVerticalLayoutGroup)obj).spacing = 10f; ((LayoutGroup)obj).padding = new RectOffset(20, 20, 20, 20); ContentSizeFitter obj2 = val.AddComponent<ContentSizeFitter>(); obj2.verticalFit = (FitMode)2; obj2.horizontalFit = (FitMode)2; LayoutElement obj3 = val.AddComponent<LayoutElement>(); obj3.preferredHeight = Mathf.Clamp((float)Screen.height - 100f, 500f, 800f); obj3.flexibleWidth = 1f; obj3.minWidth = 300f; obj3.preferredWidth = 500f; obj3.flexibleHeight = 0f; return val; } public static void OnPanelPositionChange(RectTransform panelTransform, ConfigEntry<Vector2> WindowPosition) { //IL_0001: Unknown result type (might be due to invalid IL or missing references) //IL_0006: Unknown result type (might be due to invalid IL or missing references) //IL_0008: Unknown result type (might be due to invalid IL or missing references) Vector2 anchoredPosition = panelTransform.anchoredPosition; WindowPosition.Value = anchoredPosition; } public static GameObject CreateDraggableHideShowPanel(string panelName, Transform panelParent, Unity2dViewStyles panelStyles, Unity2dViewStyles buttonStyles, string hideText, string showText, ConfigEntry<Vector2> WindowPosition, Action<Text>? onToggle = null, bool isActive = false) { //IL_0070: Unknown result type (might be due to invalid IL or missing references) //IL_0076: Expected O, but got Unknown //IL_007d: Unknown result type (might be due to invalid IL or missing references) //IL_0089: Unknown result type (might be due to invalid IL or missing references) //IL_0095: Unknown result type (might be due to invalid IL or missing references) //IL_012d: Unknown result type (might be due to invalid IL or missing references) //IL_0133: Unknown result type (might be due to invalid IL or missing references) //IL_0139: Unknown result type (might be due to invalid IL or missing references) //IL_01f7: Unknown result type (might be due to invalid IL or missing references) //IL_0201: Expected O, but got Unknown ConfigEntry<Vector2> WindowPosition2 = WindowPosition; Action<Text> onToggle2 = onToggle; string hideText2 = hideText; string showText2 = showText; GameObject panel = CreateBasicPanel(panelName, hasImage: false); DragWindowControllerExtension dragWindowControllerExtension = panel.AddComponent<DragWindowControllerExtension>(); panel.transform.SetParent(panelParent, false); panel.GetComponent<Image>().pixelsPerUnitMultiplier = 1f; RectTransform val = (RectTransform)panel.transform; val.anchoredPosition = WindowPosition2.Value; val.anchorMin = panelStyles.anchorMin; val.anchorMax = panelStyles.anchorMax; if (panelStyles.width.HasValue) { val.SetSizeWithCurrentAnchors((Axis)0, panelStyles.width.GetValueOrDefault()); } if (panelStyles.height.HasValue) { val.SetSizeWithCurrentAnchors((Axis)1, panelStyles.height.GetValueOrDefault()); } dragWindowControllerExtension.OnDragCalled = (Action<RectTransform>)Delegate.Combine(dragWindowControllerExtension.OnDragCalled, (Action<RectTransform>)delegate(RectTransform _panelTransform) { OnPanelPositionChange(_panelTransform, WindowPosition2); }); GameObject val2 = GUIManager.Instance.CreateButton(isActive ? hideText2 : showText2, panel.transform, buttonStyles.anchorMin, buttonStyles.anchorMax, buttonStyles.position, buttonStyles.width ?? 150f, buttonStyles.height ?? 150f); LayoutElement obj = val2.AddComponent<LayoutElement>(); obj.flexibleWidth = 150f; obj.flexibleHeight = 0f; obj.preferredHeight = buttonStyles.height ?? 40f; obj.minHeight = 32f; Text text = val2.GetComponentInChildren<Text>(); Button component = val2.GetComponent<Button>(); bool hasToggle = onToggle2 != null; ((UnityEvent)component.onClick).AddListener((UnityAction)delegate { if (!((Object)(object)text == (Object)null)) { if (hasToggle) { onToggle2?.Invoke(text); } else { bool flag = !panel.activeSelf; text.text = (flag ? hideText2 : showText2); panel.SetActive(flag); } } }); return panel; } public static void ApplyPanelStyle(GameObject editPanel) { //IL_00de: Unknown result type (might be due to invalid IL or missing references) Array.ForEach(editPanel.GetComponentsInChildren<Button>(true), delegate(Button b) { if (((Object)b).name.EndsWith("Button")) { GUIManager.Instance.ApplyButtonStyle(b, 16); } }); Array.ForEach(editPanel.GetComponentsInChildren<InputField>(true), delegate(InputField b) { GUIManager.Instance.ApplyInputFieldStyle(b, 16); }); Array.ForEach(editPanel.GetComponentsInChildren<Text>(true), delegate(Text b) { b.text = Localization.instance.Localize(b.text); if (((Object)b).name.EndsWith("Label")) { GUIManager.Instance.ApplyTextStyle(b, 16); } }); Array.ForEach(editPanel.GetComponentsInChildren<Toggle>(true), delegate(Toggle b) { if (((Object)b).name.EndsWith("Toggle")) { GUIManager.Instance.ApplyToogleStyle(b); } }); Image component = editPanel.GetComponent<Image>(); component.sprite = GUIManager.Instance.GetSprite("woodpanel_trophys"); component.type = (Type)1; ((Graphic)component).material = Cache.GetPrefab<Material>("litpanel"); ((Graphic)component).color = Color.white; } } public class ScreenSizeWatcher : SingletonBehaviour<ScreenSizeWatcher> { private Vector2Int _lastSize; private Coroutine _updateCoroutine; public static event Action<Vector2Int>? OnScreenSizeChanged; private void Start() { //IL_000b: Unknown result type (might be due to invalid IL or missing references) //IL_0010: Unknown result type (might be due to invalid IL or missing references) _lastSize = new Vector2Int(Screen.width, Screen.height); } private void OnEnable() { _updateCoroutine = ((MonoBehaviour)this).StartCoroutine(UpdateScreenSizeCoroutine()); } private void OnDisable() { ((MonoBehaviour)this).StopCoroutine(_updateCoroutine); } private void SyncScreenSize() { //IL_001a: Unknown result type (might be due to invalid IL or missing references) //IL_001c: Unknown result type (might be due to invalid IL or missing references) //IL_0029: Unknown result type (might be due to invalid IL or missing references) //IL_002a: Unknown result type (might be due to invalid IL or missing references) //IL_0039: Unknown result type (might be due to invalid IL or missing references) if (((Behaviour)this).isActiveAndEnabled) { Vector2Int val = default(Vector2Int); ((Vector2Int)(ref val))..ctor(Screen.width, Screen.height); if (val != _lastSize) { _lastSize = val; ScreenSizeWatcher.OnScreenSizeChanged?.Invoke(val); } } } private IEnumerator UpdateScreenSizeCoroutine() { while (((Behaviour)this).isActiveAndEnabled) { yield return (object)new WaitForSeconds(3f); yield return (object)new WaitForEndOfFrame(); SyncScreenSize(); } } } public class SwivelUIPanelComponentIntegration : SwivelUIPanelComponent { public Action<Text>? OnPanelToggleAction; public Unity2dViewStyles buttonStyles = new Unity2dViewStyles { anchorMin = Vector2.zero, anchorMax = Vector2.one, position = Vector2.zero, width = 150f }; public Unity2dViewStyles panelStyles = new Unity2dViewStyles { width = 500f }; private const string PanelName = "ValheimVehicles_SwivelPanel"; public override void OnAwake() { _ = ZNetView.m_forceDisableInit; } public void OnEnable() { } public void OnDisable() { } public static void Init() { if (!Object.op_Implicit((Object)(object)SingletonBehaviour<SwivelUIPanelComponent>.Instance) && Object.op_Implicit((Object)(object)Game.instance)) { ((Component)Game.instance).gameObject.AddComponent<SwivelUIPanelComponentIntegration>(); } } public void TryGetCurrentSwivelIntegration() { //IL_0023: Unknown result type (might be due to invalid IL or missing references) if (!Object.op_Implicit((Object)(object)_currentSwivel) && Object.op_Implicit((Object)(object)Player.m_localPlayer)) { SwivelHelpers.FindAllSwivelsWithinRange(((Component)Player.m_localPlayer).transform.position, out List<SwivelComponent> _, out _currentSwivel); } } public override void BindTo(SwivelComponent target, bool isToggle = false) { if (!Object.op_Implicit((Object)(object)target)) { LoggerProvider.LogDebug("No swivel to open this panel", "C:\\Users\\fre\\dev\\repos\\ValheimMods\\src\\ValheimVehicles\\ValheimVehicles.UI\\SwivelUIPanelComponentIntegration.cs", 64); Object.Destroy((Object)(object)panelRoot); return; } if (Object.op_Implicit((Object)(object)_currentSwivel)) { SwivelComponentBridge swivelComponentBridge = _currentSwivel as SwivelComponentBridge; if ((Object)(object)swivelComponentBridge != (Object)null) { swivelComponentBridge.prefabConfigSync.Load(); } } base.BindTo(target, isToggle); } public void SyncUIFromPartialConfig(SwivelCustomConfig updated) { //IL_011b: Unknown result type (might be due to invalid IL or missing references) //IL_0121: Unknown result type (might be due to invalid IL or missing references) //IL_0190: Unknown result type (might be due to invalid IL or missing references) //IL_0196: Unknown result type (might be due to invalid IL or missing references) //IL_0139: Unknown result type (might be due to invalid IL or missing references) //IL_0154: Unknown result type (might be due to invalid IL or missing references) //IL_016f: Unknown result type (might be due to invalid IL or missing references) //IL_0185: Unknown result type (might be due to invalid IL or missing references) //IL_01ae: Unknown result type (might be due to invalid IL or missing references) //IL_01c9: Unknown result type (might be due to invalid IL or missing references) //IL_01e4: Unknown result type (might be due to invalid IL or missing references) //IL_01fa: Unknown result type (might be due to invalid IL or missing references) if ((Object)(object)_currentSwivel == (Object)null || IsEditing) { return; } SwivelCustomConfig currentPanelConfig = _currentPanelConfig; if (updated.Mode != currentPanelConfig.Mode) { modeDropdown.value = (int)updated.Mode; _currentPanelConfig.Mode = updated.Mode; RefreshUI(); } if (!Mathf.Approximately(updated.InterpolationSpeed, currentPanelConfig.InterpolationSpeed)) { movementLerpRow.GetComponentInChildren<Slider>().SetValueWithoutNotify(updated.InterpolationSpeed); _currentPanelConfig.InterpolationSpeed = updated.InterpolationSpeed; } if (updated.HingeAxes != currentPanelConfig.HingeAxes) { Toggle[] componentsInChildren = hingeAxisRow.GetComponentsInChildren<Toggle>(); if (componentsInChildren.Length == 3) { componentsInChildren[0].isOn = updated.HingeAxes.HasFlag(HingeAxis.X); componentsInChildren[1].isOn = updated.HingeAxes.HasFlag(HingeAxis.Y); componentsInChildren[2].isOn = updated.HingeAxes.HasFlag(HingeAxis.Z); } _currentPanelConfig.HingeAxes = updated.HingeAxes; } if (updated.MaxEuler != currentPanelConfig.MaxEuler) { maxXRow.GetComponentInChildren<Slider>().value = updated.MaxEuler.x; maxYRow.GetComponentInChildren<Slider>().value = updated.MaxEuler.y; maxZRow.GetComponentInChildren<Slider>().value = updated.MaxEuler.z; _currentPanelConfig.MaxEuler = updated.MaxEuler; } if (updated.MovementOffset != currentPanelConfig.MovementOffset) { targetDistanceXRow.GetComponentInChildren<Slider>().value = updated.MovementOffset.x; targetDistanceYRow.GetComponentInChildren<Slider>().value = updated.MovementOffset.y; targetDistanceZRow.GetComponentInChildren<Slider>().value = updated.MovementOffset.z; _currentPanelConfig.MovementOffset = updated.MovementOffset; } motionStateDropdown.value = (int)updated.MotionState; IsEditing = false; } protected override void OnPanelSave() { TryGetCurrentSwivelIntegration(); SwivelComponentBridge swivelComponentBridge = _currentSwivel as SwivelComponentBridge; if (Object.op_Implicit((Object)(object)swivelComponentBridge) && ((INetView)swivelComponentBridge).IsNetViewValid()) { SwivelCustomConfig swivelCustomConfig = new SwivelCustomConfig(); swivelCustomConfig.ApplyFrom(_currentPanelConfig); swivelCustomConfig.MotionState = swivelComponentBridge.MotionState; if (swivelCustomConfig.Mode == SwivelMode.None && modeDropdown.value != 0) { LoggerProvider.LogWarning("Swivel is in None mode, but the UI does not match. Not saving. This is a bug.", "C:\\Users\\fre\\dev\\repos\\ValheimMods\\src\\ValheimVehicles\\ValheimVehicles.UI\\SwivelUIPanelComponentIntegration.cs", 151); } else { swivelComponentBridge.prefabConfigSync.Request_CommitConfigChange(swivelCustomConfig); } } } public override GameObject CreateUIRoot() { return PanelUtil.CreateDraggableHideShowPanel("ValheimVehicles_SwivelPanel", VehicleGui.GetVehicleGui().transform, panelStyles, buttonStyles, ModTranslations.GuiShow, ModTranslations.GuiHide, GuiConfig.SwivelPanelLocation); } } public static class TMPDropdownFactory { public static Color BackgroundElementColor = new Color(0.2f, 0.2f, 0.2f, 1f); public static TMP_Dropdown CreateTMPDropDown(Transform parent, Vector2 anchoredPosition, Vector2 size, string captionText = "", string itemPrototypeText = "Option") { //IL_003f: Unknown result type (might be due to invalid IL or missing references) //IL_0045: Expected O, but got Unknown //IL_0059: Unknown result type (might be due to invalid IL or missing references) //IL_005f: Unknown result type (might be due to invalid IL or missing references) //IL_008a: Unknown result type (might be due to invalid IL or missing references) //IL_008f: Unknown result type (might be due to invalid IL or missing references) //IL_00a1: Unknown result type (might be due to invalid IL or missing references) //IL_00a8: Unknown result type (might be due to invalid IL or missing references) //IL_00b3: Unknown result type (might be due to invalid IL or missing references) //IL_00c8: Unknown result type (might be due to invalid IL or missing references) //IL_00dc: Unknown result type (might be due to invalid IL or missing references) //IL_0123: Unknown result type (might be due to invalid IL or missing references) //IL_015f: Unknown result type (might be due to invalid IL or missing references) //IL_0164: Unknown result type (might be due to invalid IL or missing references) //IL_0186: Unknown result type (might be due to invalid IL or missing references) //IL_019b: Unknown result type (might be due to invalid IL or missing references) //IL_01b0: Unknown result type (might be due to invalid IL or missing references) //IL_01c4: Unknown result type (might be due to invalid IL or missing references) //IL_020d: Unknown result type (might be due to invalid IL or missing references) //IL_0213: Expected O, but got Unknown //IL_023e: Unknown result type (might be due to invalid IL or missing references) //IL_0253: Unknown result type (might be due to invalid IL or missing references) //IL_0268: Unknown result type (might be due to invalid IL or missing references) //IL_027d: Unknown result type (might be due to invalid IL or missing references) //IL_02e5: Unknown result type (might be due to invalid IL or missing references) //IL_02ec: Expected O, but got Unknown //IL_0314: Unknown result type (might be due to invalid IL or missing references) //IL_032a: Unknown result type (might be due to invalid IL or missing references) //IL_0340: Unknown result type (might be due to invalid IL or missing references) //IL_034c: Unknown result type (might be due to invalid IL or missing references) //IL_0358: Unknown result type (might be due to invalid IL or missing references) //IL_03aa: Unknown result type (might be due to invalid IL or missing references) //IL_03b1: Expected O, but got Unknown //IL_03da: Unknown result type (might be due to invalid IL or missing references) //IL_03f0: Unknown result type (might be due to invalid IL or missing references) //IL_0406: Unknown result type (might be due to invalid IL or missing references) //IL_0412: Unknown result type (might be due to invalid IL or missing references) //IL_041e: Unknown result type (might be due to invalid IL or missing references) //IL_045a: Unknown result type (might be due to invalid IL or missing references) //IL_0464: Expected O, but got Unknown //IL_049f: Unknown result type (might be due to invalid IL or missing references) //IL_04a6: Expected O, but got Unknown //IL_04f2: Unknown result type (might be due to invalid IL or missing references) //IL_0538: Unknown result type (might be due to invalid IL or missing references) //IL_053d: Unknown result type (might be due to invalid IL or missing references) //IL_0550: Unknown result type (might be due to invalid IL or missing references) //IL_0557: Unknown result type (might be due to invalid IL or missing references) //IL_0562: Unknown result type (might be due to invalid IL or missing references) //IL_0577: Unknown result type (might be due to invalid IL or missing references) //IL_058b: Unknown result type (might be due to invalid IL or missing references) //IL_05d9: Unknown result type (might be due to invalid IL or missing references) //IL_0622: Unknown result type (might be due to invalid IL or missing references) //IL_062e: Unknown result type (might be due to invalid IL or missing references) //IL_063a: Unknown result type (might be due to invalid IL or missing references) GameObject val = new GameObject("VehicleGUI_TMP_Dropdown", new Type[4] { typeof(RectTransform), typeof(CanvasRenderer), typeof(Image), typeof(TMP_Dropdown) }); val.transform.SetParent(parent, false); RectTransform component = val.GetComponent<RectTransform>(); component.sizeDelta = size; component.anchoredPosition = anchoredPosition; GameObject val2 = new GameObject("Label", new Type[2] { typeof(RectTransform), typeof(TextMeshProUGUI) }); val2.transform.SetParent(val.transform, false); RectTransform component2 = val2.GetComponent<RectTransform>(); component2.anchorMin = Vector2.zero; component2.anchorMax = Vector2.one; component2.offsetMin = new Vector2(10f, 6f); component2.offsetMax = new Vector2(-25f, -7f); TextMeshProUGUI component3 = val2.GetComponent<TextMeshProUGUI>(); ((TMP_Text)component3).font = TMP_Settings.defaultFontAsset; ((TMP_Text)component3).text = captionText ?? ""; ((TMP_Text)component3).alignment = (TextAlignmentOptions)4097; ((TMP_Text)component3).fontSize = 24f; ((Graphic)component3).color = GUIManager.Instance.ValheimOrange; GameObject val3 = new GameObject("Arrow", new Type[3] { typeof(RectTransform), typeof(CanvasRenderer), typeof(Image) }); val3.transform.SetParent(val.transform, false); RectTransform component4 = val3.GetComponent<RectTransform>(); component4.anchorMin = new Vector2(1f, 0.5f); component4.anchorMax = new Vector2(1f, 0.5f); component4.sizeDelta = new Vector2(20f, 20f); component4.anchoredPosition = new Vector2(-15f, 0f); GameObject val4 = new GameObject("Template", new Type[4] { typeof(RectTransform), typeof(CanvasRenderer), typeof(Image), typeof(ScrollRect) }); val4.transform.SetParent(val.transform, false); val4.SetActive(false); RectTransform component5 = val4.GetComponent<RectTransform>(); component5.pivot = new Vector2(0.5f, 1f); component5.anchorMin = new Vector2(0f, 0f); component5.anchorMax = new Vector2(1f, 0f); component5.sizeDelta = new Vector2(0f, 150f); Canvas obj = val4.AddComponent<Canvas>(); obj.overrideSorting = true; obj.sortingOrder = 300; ScrollRect component6 = val4.GetComponent<ScrollRect>(); GameObject val5 = new GameObject("Viewport", new Type[4] { typeof(RectTransform), typeof(CanvasRenderer), typeof(Image), typeof(Mask) }); val5.transform.SetParent(val4.transform, false); RectTransform component7 = val5.GetComponent<RectTransform>(); component7.pivot = new Vector2(0f, 1f); component7.anchorMin = new Vector2(0f, 0f); component7.anchorMax = new Vector2(1f, 1f); component7.offsetMin = Vector2.zero; component7.offsetMax = Vector2.zero; val5.GetComponent<Mask>().showMaskGraphic = false; component6.viewport = component7; GameObject val6 = new GameObject("Content", new Type[3] { typeof(RectTransform), typeof(VerticalLayoutGroup), typeof(ContentSizeFitter) }); val6.transform.SetParent(val5.transform, false); RectTransform component8 = val6.GetComponent<RectTransform>(); component8.pivot = new Vector2(0.5f, 1f); component8.anchorMin = new Vector2(0f, 0f); component8.anchorMax = new Vector2(1f, 1f); component8.offsetMin = Vector2.zero; component8.offsetMax = Vector2.zero; VerticalLayoutGroup component9 = val6.GetComponent<VerticalLayoutGroup>(); ((HorizontalOrVerticalLayoutGroup)component9).childForceExpandHeight = false; ((HorizontalOrVerticalLayoutGroup)component9).childControlHeight = true; ((HorizontalOrVerticalLayoutGroup)component9).childForceExpandWidth = true; ((HorizontalOrVerticalLayoutGroup)component9).childControlWidth = true; ((HorizontalOrVerticalLayoutGroup)component9).spacing = 5f; ((LayoutGroup)component9).padding = new RectOffset(5, 5, 5, 5); val6.GetComponent<ContentSizeFitter>().verticalFit = (FitMode)2; component6.content = component8; GameObject val7 = new GameObject("Item", new Type[2] { typeof(RectTransform), typeof(Toggle) }); LayoutElement obj2 = val7.AddComponent<LayoutElement>(); obj2.preferredHeight = 30f; obj2.minHeight = 30f; obj2.flexibleHeight = 0f; val7.transform.SetParent(val6.transform, false); val7.GetComponent<RectTransform>().sizeDelta = new Vector2(0f, 30f); Image val9 = (Image)(object)(((Selectable)val7.GetComponent<Toggle>()).targetGraphic = (Graphic)(object)val7.AddComponent<Image>()); GameObject val10 = new GameObject("Item Label", new Type[2] { typeof(RectTransform), typeof(TextMeshProUGUI) }); val10.transform.SetParent(val7.transform, false); RectTransform component10 = val10.GetComponent<RectTransform>(); component10.anchorMin = Vector2.zero; component10.anchorMax = Vector2.one; component10.offsetMin = new Vector2(10f, 0f); component10.offsetMax = new Vector2(-10f, 0f); TextMeshProUGUI component11 = val10.GetComponent<TextMeshProUGUI>(); ((TMP_Text)component11).font = TMP_Settings.defaultFontAsset; ((TMP_Text)component11).text = itemPrototypeText ?? "Option"; ((TMP_Text)component11).alignment = (TextAlignmentOptions)4097; ((TMP_Text)component11).fontSize = 22f; ((Graphic)component11).color = GUIManager.Instance.ValheimOrange; TMP_Dropdown component12 = val.GetComponent<TMP_Dropdown>(); component12.captionText = (TMP_Text)(object)component3; component12.template = component5; component12.itemText = (TMP_Text)(object)component11; ((Selectable)component12).targetGraphic = (Graphic)(object)val.GetComponent<Image>(); component6.content = component8; Image component13 = val.GetComponent<Image>(); Image component14 = val4.GetComponent<Image>(); ((Graphic)component13).color = BackgroundElementColor; ((Graphic)component14).color = BackgroundElementColor; ((Graphic)val9).color = BackgroundElementColor; return component12; } } public class VehicleGui : SingletonBehaviour<VehicleGui> { private GUIStyle? myButtonStyle; private string ShipMovementOffsetText; private Vector3 _shipMovementOffset; public static TMP_Dropdown VehicleSelectDropdown; public static VehicleGui Gui; public static GameObject GuiObj; public const string vehicleConfigHide = "Vehicle Config (Hide)"; public const string vehicleConfigShow = "Vehicle Config (Show)"; public static bool vehicleDebugPhysicsSync = true; private int buttonFontSize = 16; private int titleFontSize = 18; private GUIStyle buttonStyle; private GUIStyle labelStyle; public static bool hasCommandsWindowOpened = false; public static bool hasConfigPanelOpened = false; public static bool isCommandsToggleButtonVisible = false; public static bool isConfigPanelToggleButtonVisible = false; private GameObject? configWindow; private GameObject? commandsWindow; private GameObject? commandsToggleButtonWindow; private GameObject? configToggleButtonWindow; private List<GameObject> commandsPanelToggleObjects = new List<GameObject>(); private List<GameObject> configPanelToggleObjects = new List<GameObject>(); private bool hasInitialized; private const int panelHeight = 500; private const float buttonHeight = 60f; private const float buttonWidth = 350f; private static float panelWidth = 385f; private static readonly Vector2 anchorMin = new Vector2(0f, 0.5f); private static readonly Vector2 anchorMax = new Vector2(0.5f, 0.5f); private static readonly Vector2 panelPosition = Vector2.zero; private static readonly Vector3 buttonHeightVector3 = Vector3.up * 60f; private static readonly Vector3 panelHeightVector3 = Vector3.up * 500f / 2f; public bool lastPanelState; public VehicleManager? targetInstance; private GenericInputAction _getCurrentVehicleGenericInputAction = new GenericInputAction { title = "Update current vehicle", OnButtonPress = delegate { if (!((Object)(object)SingletonBehaviour<VehicleGui>.Instance == (Object)null)) { VehicleManager nearestVehicleManager = VehicleCommands.GetNearestVehicleManager(); if ((Object)(object)nearestVehicleManager == (Object)null) { SingletonBehaviour<VehicleGui>.Instance.targetInstance = null; } else { SingletonBehaviour<VehicleGui>.Instance.targetInstance = nearestVehicleManager; } } } }; private const string CommandsPanelWindowName = "ValheimVehicles_commandsWindow"; private const string ConfigPanelWindowName = "ValheimVehicles_configWindow"; public static GameObject? ConfigScrollView; public static Slider? LandVehicleTreadDistance_Slider; public static Slider? LandVehicleTreadScale_Slider; public static Slider? WaterFloatation_Slider; public static Toggle? WaterFloatation_Toggle; public static GameObject? WaterFloatationSliderRow; public static VehicleManager? CurrentSelectedVehicle; public static bool IsEditing = false; private static TextMeshProUGUI _saveStatus; private static Button _resetButton; public static VehicleCustomConfig _tempVehicleConfig = new VehicleCustomConfig(); public static string vehicleCommandsHide => ModTranslations.GuiCommandsMenuTitle + " (" + ModTranslations.GuiHide + ")"; public static string vehicleCommandsShow => ModTranslations.GuiCommandsMenuTitle + " (" + ModTranslations.GuiShow + ")"; public static GameObject GetVehicleGui() { //IL_0012: Unknown result type (might be due to invalid IL or missing references) //IL_0017: Unknown result type (might be due to invalid IL or missing references) //IL_002c: Unknown result type (might be due to invalid IL or missing references) //IL_003c: Expected O, but got Unknown if ((Object)(object)GuiObj == (Object)null) { GameObject val = new GameObject("ValheimVehicles_VehicleGui"); val.transform.parent = GUIManager.CustomGUIFront.transform; val.layer = LayerHelpers.UILayer; GuiObj = val; } return GuiObj; } public static void AddRemoveVehicleGui() { if (!((Object)(object)ZNet.instance == (Object)null)) { if (Object.op_Implicit((Object)(object)Gui)) { Gui.RemoveGui(); Gui = null; } if (Object.op_Implicit((Object)(object)GuiObj)) { Object.Destroy((Object)(object)GuiObj); GuiObj = null; } GuiObj = GetVehicleGui(); if ((Object)(object)Gui == (Object)null) { Gui = GuiObj.gameObject.GetOrAddComponent<VehicleGui>(); } if ((Object)(object)SingletonBehaviour<VehicleGui>.Instance != (Object)null) { SingletonBehaviour<VehicleGui>.Instance.InitPanel(); SetCommandsPanelState(VehicleGuiMenuConfig.VehicleDebugMenuEnabled.Value); } } } private Vector3 GetShipMovementOffset() { //IL_0048: Unknown result type (might be due to invalid IL or missing references) //IL_0024: Unknown result type (might be due to invalid IL or missing references) string[] array = ShipMovementOffsetText.Split(','); if (array.Length != 3) { return new Vector3(0f, 0f, 0f); } float num = float.Parse(array[0]); float num2 = float.Parse(array[1]); float num3 = float.Parse(array[2]); return new Vector3(num, num2, num3); } private void Start() { buttonFontSize = VehicleGuiMenuConfig.ButtonFontSize.Value; titleFontSize = VehicleGuiMenuConfig.TitleFontSize.Value; hasInitialized = false; GUIManager.OnCustomGUIAvailable += InitPanel; } private void OnEnable() { hasInitialized = false; InitPanel(); } private void OnDisable() { RemoveGui(); } public void RemoveGui() { commandsPanelToggleObjects.Clear(); configPanelToggleObjects.Clear(); if (Object.op_Implicit((Object)(object)commandsToggleButtonWindow)) { Object.Destroy((Object)(object)commandsToggleButtonWindow); } if (Object.op_Implicit((Object)(object)configToggleButtonWindow)) { Object.Destroy((Object)(object)configToggleButtonWindow); } if (Object.op_Implicit((Object)(object)commandsWindow)) { Object.Destroy((Object)(object)commandsWindow); } if (Object.op_Implicit((Object)(object)configWindow)) { Object.Destroy((Object)(object)configWindow); } commandsToggleButtonWindow = null; configToggleButtonWindow = null; commandsWindow = null; configWindow = null; if (Object.op_Implicit((Object)(object)GuiObj)) { Object.Destroy((Object)(object)GuiObj); } } public static void ToggleConfigPanelState(bool shouldHideShowButton = false) { hasConfigPanelOpened = !hasConfigPanelOpened; HideOrShowVehicleConfigPanel(hasConfigPanelOpened, shouldHideShowButton); } public static void SetConfigPanelState(bool val) { hasConfigPanelOpened = val; HideOrShowVehicleConfigPanel(val, canUpdateTogglePanel: true); } public void HideOrShowPanel(bool isVisible, bool shouldDeactivateToggleButton, ref GameObject toggleWindow, ref GameObject panelWindow, ref List<GameObject> toggleObjects) { if ((Object)(object)SingletonBehaviour<VehicleGui>.Instance == (Object)null) { return; } if ((Object)(object)toggleWindow == (Object)null || (Object)(object)panelWindow == (Object)null) { InitPanel(); } if ((Object)(object)toggleWindow != (Object)null && shouldDeactivateToggleButton) { toggleWindow.SetActive(isVisible); } if (!((Object)(object)panelWindow != (Object)null)) { return; } panelWindow.SetActive(isVisible); toggleObjects.ForEach(delegate(GameObject x) { if (!((Object)(object)x == (Object)null)) { x.SetActive(isVisible); } }); } public static void HideOrShowCommandPanel(bool isVisible, bool canUpdateTogglePanel) { if ((Object)(object)SingletonBehaviour<VehicleGui>.Instance == (Object)null) { AddRemoveVehicleGui(); } else { SingletonBehaviour<VehicleGui>.Instance.HideOrShowPanel(isVisible, canUpdateTogglePanel, ref SingletonBehaviour<VehicleGui>.Instance.commandsToggleButtonWindow, ref SingletonBehaviour<VehicleGui>.Instance.commandsWindow, ref SingletonBehaviour<VehicleGui>.Instance.commandsPanelToggleObjects); } } public static void HideOrShowVehicleConfigPanel(bool isVisible, bool canUpdateTogglePanel) { if ((Object)(object)SingletonBehaviour<VehicleGui>.Instance == (Object)null) { AddRemoveVehicleGui(); } else { SingletonBehaviour<VehicleGui>.Instance.HideOrShowPanel(isVisible, canUpdateTogglePanel, ref SingletonBehaviour<VehicleGui>.Instance.configToggleButtonWindow, ref SingletonBehaviour<VehicleGui>.Instance.configWindow, ref SingletonBehaviour<VehicleGui>.Instance.configPanelToggleObjects); } } public static void SetCommandsPanelState(bool val) { hasCommandsWindowOpened = val; HideOrShowVehicleConfigPanel(val, canUpdateTogglePanel: false); } public static void ToggleCommandsPanelState(bool canUpdateTogglePanel) { hasCommandsWindowOpened = !hasCommandsWindowOpened; HideOrShowCommandPanel(hasCommandsWindowOpened, canUpdateTogglePanel); if (!hasCommandsWindowOpened) { HideOrShowVehicleConfigPanel(hasCommandsWindowOpened, canUpdateTogglePanel: true); } } public void InitPanel() { if (GUIManager.Instance != null && !((Object)(object)GUIManager.CustomGUIFront == (Object)null)) { CreateCommandsShortcutPanel(); CreateVehicleConfigShortcutPanel(); HideOrShowCommandPanel(hasCommandsWindowOpened, canUpdateTogglePanel: true); HideOrShowVehicleConfigPanel(hasConfigPanelOpened, canUpdateTogglePanel: true); hasInitialized = true; } } public static void VehicleSelectOnDropdownChanged(int index) { List<VehicleStorageController.StoredVehicleData> allVehicles = VehicleStorageController.GetAllVehicles(); if (index == 0) { VehicleStorageController.SelectedVehicle = ""; } else if (index > 0 && index <= allVehicles.Count) { VehicleStorageController.SelectedVehicle = allVehicles[index - 1].VehicleName; LoggerProvider.LogInfo("Selected Vehicle: " + VehicleStorageController.SelectedVehicle, "C:\\Users\\fre\\dev\\repos\\ValheimMods\\src\\ValheimVehicles\\ValheimVehicles.UI\\VehicleGui.cs", 305); } else { LoggerProvider.LogWarning("No vehicles detected cannot select any vehicle.", "C:\\Users\\fre\\dev\\repos\\ValheimMods\\src\\ValheimVehicles\\ValheimVehicles.UI\\VehicleGui.cs", 309); VehicleStorageController.SelectedVehicle = ""; } } public static GameObject AddDropdownWithAction(GenericInputAction genericInputAction, int index, float StartHeight, Transform parent) { //IL_0010: Unknown result type (might be due to invalid IL or missing references) //IL_001f: Unknown result type (might be due to invalid IL or missing references) TMP_Dropdown val = TMPDropdownFactory.CreateTMPDropDown(parent, new Vector2(0f, StartHeight - (float)index * 60f), new Vector2(350f, 90f)); if (genericInputAction.OnDropdownChanged != null) { ((UnityEvent<int>)(object)val.onValueChanged).AddListener(genericInputAction.OnDropdownChanged); } else { LoggerProvider.LogError("OnDropdownChanged not provided for a AddDropdownAction. This is an error with Valheim Vehicles. Please Report", "C:\\Users\\fre\\dev\\repos\\ValheimMods\\src\\ValheimVehicles\\ValheimVehicles.UI\\VehicleGui.cs", 329); } DropdownRefreshOnHover dropdownRefreshOnHover = ((Component)val).gameObject.AddComponent<DropdownRefreshOnHover>(); if (genericInputAction.OnPointerEnterAction != null) { dropdownRefreshOnHover.OnPointerEnterAction = genericInputAction.OnPointerEnterAction; } if (genericInputAction.OnCreateDropdown != null) { genericInputAction.OnCreateDropdown(val); } return ((Component)val).gameObject; } public GameObject AddInputWithAction(GenericInputAction genericInputAction, int index, float StartHeight, Transform windowTransform) { //IL_0011: Unknown result type (might be due to invalid IL or missing references) //IL_0020: Unknown result type (might be due to invalid IL or missing references) //IL_0034: Unknown result type (might be due to invalid IL or missing references) GameObject obj = GUIManager.Instance.CreateInputField(windowTransform, new Vector2(0.5f, 0.5f), new Vector2(0.5f, 0.5f), new Vector2(0f, StartHeight - (float)index * 60f), (ContentType)2, "8", 16, 0f, 0f); obj.SetActive(true); ((UnityEvent<string>)(object)obj.GetComponent<InputField>().onSubmit).AddListener((UnityAction<string>)delegate(string x) { if (float.TryParse(x, out var result)) { Logger.LogDebug((object)$"Converted string to float {result}"); } else { Logger.LogDebug((object)("Not a string " + x)); } }); return obj; } public GameObject AddButtonWithAction(GenericInputAction genericInputAction, int index, float StartHeight, Transform windowTransform) { //IL_0029: Unknown result type (might be due to invalid IL or missing references) //IL_0038: Unknown result type (might be due to invalid IL or missing references) //IL_004c: Unknown result type (might be due to invalid IL or missing references) //IL_0097: Unknown result type (might be due to invalid IL or missing references) //IL_00a1: Expected O, but got Unknown GameObject obj = GUIManager.Instance.CreateButton(genericInputAction.title, windowTransform, new Vector2(0.5f, 0.5f), new Vector2(0.5f, 0.5f), new Vector2(0f, StartHeight - (float)index * 60f), 350f, 60f); obj.SetActive(true); Button component = obj.GetComponent<Button>(); Text component2 = obj.GetComponent<Text>(); if ((Object)(object)component2 != (Object)null) { component2.fontSize = buttonFontSize; } ((UnityEvent)component.onClick).AddListener((UnityAction)delegate { genericInputAction.OnButtonPress(); }); return obj; } private GameObject CreateConfigTogglePanel() { //IL_0006: Unknown result type (might be due to invalid IL or missing references) //IL_0011: Unknown result type (might be due to invalid IL or missing references) //IL_002c: Unknown result type (might be due to invalid IL or missing references) //IL_0041: Unknown result type (might be due to invalid IL or missing references) //IL_004c: Unknown result type (might be due to invalid IL or missing references) Unity2dViewStyles panelStyles = new Unity2dViewStyles { anchorMin = anchorMin, anchorMax = anchorMax }; Unity2dViewStyles buttonStyles = new Unity2dViewStyles { anchorMin = new Vector2(0.5f, 0f), anchorMax = new Vector2(0.5f, 1f), position = Vector2.zero, height = 60f, width = 350f }; return PanelUtil.CreateDraggableHideShowPanel("ValheimVehicles_configWindow", GuiObj.transform, panelStyles, buttonStyles, "Vehicle Config (Hide)", "Vehicle Config (Show)", GuiConfig.VehicleCommandsPanelLocation, OnConfigCommandsPanelToggle); } private void OnConfigCommandsPanelToggle(Text buttonText) { HideOrShowVehicleConfigPanel(!configWindow.activeSelf, canUpdateTogglePanel: false); } private void OnWindowCommandsPanelToggle(Text buttonText) { bool flag = !commandsWindow.activeSelf; buttonText.text = (flag ? vehicleCommandsHide : vehicleCommandsShow); HideOrShowCommandPanel(flag, canUpdateTogglePanel: false); } private GameObject CreateCommandsTogglePanel() { //IL_0006: Unknown result type (might be due to invalid IL or missing references) //IL_0011: Unknown result type (might be due to invalid IL or missing references) //IL_002c: Unknown result type (might be due to invalid IL or missing references) //IL_0041: Unknown result type (might be due to invalid IL or missing references) //IL_004c: Unknown result type (might be due to invalid IL or missing references) Unity2dViewStyles panelStyles = new Unity2dViewStyles { anchorMin = anchorMin, anchorMax = anchorMax }; Unity2dViewStyles buttonStyles = new Unity2dViewStyles { anchorMin = new Vector2(0.5f, 0f), anchorMax = new Vector2(0.5f, 1f), position = Vector2.zero, height = 60f
plugins\ZdoWatcher.dll
Decompiled a week agousing System; using System.Collections; using System.Collections.Generic; using System.Diagnostics; using System.Linq; using System.Reflection; using System.Runtime.CompilerServices; using System.Runtime.InteropServices; using System.Runtime.Versioning; using System.Security; using System.Security.Permissions; using BepInEx; using BepInEx.Configuration; using HarmonyLib; using Jotunn; using Jotunn.Entities; using Jotunn.Managers; using Jotunn.Utils; using Microsoft.CodeAnalysis; using UnityEngine; using ZdoWatcher.Patches; using ZdoWatcher.ZdoWatcher.Config; using ZdoWatcher.ZdoWatcher.Utils; using Zolantris.Shared; using Zolantris.Shared.Debug; [assembly: CompilationRelaxations(8)] [assembly: RuntimeCompatibility(WrapNonExceptionThrows = true)] [assembly: Debuggable(DebuggableAttribute.DebuggingModes.IgnoreSymbolStoreSequencePoints)] [assembly: AssemblyTitle("ZdoWatcher")] [assembly: AssemblyDescription("Valheim Mod made to share Zdo Changes and side effect through one shareable interface")] [assembly: AssemblyConfiguration("")] [assembly: AssemblyCompany("Virtualize LLC")] [assembly: AssemblyProduct("ZdoWatcher")] [assembly: AssemblyCopyright("Copyright © 2023-2025, GNU-v3 licensed")] [assembly: Guid("6015B165-2627-40A7-8CA1-3E6B6CD7CB49")] [assembly: AssemblyFileVersion("1.2.0")] [assembly: TargetFramework(".NETStandard,Version=v2.1", FrameworkDisplayName = ".NET Standard 2.1")] [assembly: SecurityPermission(SecurityAction.RequestMinimum, SkipVerification = true)] [assembly: AssemblyVersion("1.2.0.0")] [module: UnverifiableCode] [module: RefSafetyRules(11)] namespace Microsoft.CodeAnalysis { [CompilerGenerated] [Microsoft.CodeAnalysis.Embedded] internal sealed class EmbeddedAttribute : Attribute { } } namespace System.Runtime.CompilerServices { [CompilerGenerated] [Microsoft.CodeAnalysis.Embedded] [AttributeUsage(AttributeTargets.Class | AttributeTargets.Property | AttributeTargets.Field | AttributeTargets.Event | AttributeTargets.Parameter | AttributeTargets.ReturnValue | AttributeTargets.GenericParameter, AllowMultiple = false, Inherited = false)] internal sealed class NullableAttribute : Attribute { public readonly byte[] NullableFlags; public NullableAttribute(byte P_0) { NullableFlags = new byte[1] { P_0 }; } public NullableAttribute(byte[] P_0) { NullableFlags = P_0; } } [CompilerGenerated] [Microsoft.CodeAnalysis.Embedded] [AttributeUsage(AttributeTargets.Class | AttributeTargets.Struct | AttributeTargets.Method | AttributeTargets.Interface | AttributeTargets.Delegate, AllowMultiple = false, Inherited = false)] internal sealed class NullableContextAttribute : Attribute { public readonly byte Flag; public NullableContextAttribute(byte P_0) { Flag = P_0; } } [CompilerGenerated] [Microsoft.CodeAnalysis.Embedded] [AttributeUsage(AttributeTargets.Module, AllowMultiple = false, Inherited = false)] internal sealed class RefSafetyRulesAttribute : Attribute { public readonly int Version; public RefSafetyRulesAttribute(int P_0) { Version = P_0; } } } namespace ZdoWatcher { public static class ZdoVarController { private static readonly Dictionary<string, string> ZdoVariables = new Dictionary<string, string>(); public static readonly int PersistentUidHash = StringExtensionMethods.GetStableHashCode("PersistentID"); public static string NameToVar(BaseUnityPlugin unityPlugin, string key) { return ((Object)unityPlugin).name + "_" + key; } public static void RegisterPublicVar(BaseUnityPlugin unityPlugin, string key, int value) { string key2 = NameToVar(unityPlugin, key); ZdoVariables.Add(key2, value.ToString()); } public static void RegisterPublicVar(BaseUnityPlugin unityPlugin, string key, string value) { string key2 = NameToVar(unityPlugin, key); ZdoVariables.Add(key2, value); } public static void ListPublicVar(bool shouldLog = true) { if (!shouldLog) { return; } foreach (KeyValuePair<string, string> zdoVariable in ZdoVariables) { Logger.LogInfo((object)("Key: " + zdoVariable.Key + ", Value: " + zdoVariable.Value)); } } } public class ZdoWatchController : MonoBehaviour { public static Action<ZDO>? OnDeserialize = null; public static Action<ZDO>? OnLoad = null; public static Action<ZDO>? OnReset = null; public static ZdoWatchController Instance; private readonly Dictionary<int, ZDO> _zdoGuidLookup = new Dictionary<int, ZDO>(); private readonly List<DebugSafeTimer> _timers = new List<DebugSafeTimer>(); private CustomRPC RPC_RequestPersistentIdInstance; public static string RPC_RequestPersistentId_Name = "ZdoWatcherController_RPC_RequestSync"; public Dictionary<int, ZDO?> PendingPersistentIdQueries = new Dictionary<int, ZDO>(); public void Awake() { //IL_0012: Unknown result type (might be due to invalid IL or missing references) //IL_001d: Expected O, but got Unknown RPC_RequestPersistentIdInstance = NetworkManager.Instance.AddRPC(RPC_RequestPersistentId_Name, new CoroutineHandler(RequestPersistentIdRPCServerReceive), (CoroutineHandler)null); } public Dictionary<int, ZDO> GetAllZdoGuids() { return _zdoGuidLookup.ToDictionary<KeyValuePair<int, ZDO>, int, ZDO>((KeyValuePair<int, ZDO> kvp) => kvp.Key, (KeyValuePair<int, ZDO> kvp) => kvp.Value); } public void Update() { DebugSafeTimer.UpdateTimersFromList(_timers); } public void SyncToPeer(ZDOPeer? zdoPeer) { //IL_0030: Unknown result type (might be due to invalid IL or missing references) if (!ZNet.instance.IsServer() || zdoPeer == null) { return; } foreach (ZDO value in _zdoGuidLookup.Values) { if (zdoPeer != null) { zdoPeer.ForceSendZDO(value.m_uid); } } } private IEnumerator RequestPersistentIdRPCServerReceive(long sender, ZPackage package) { int num = package.ReadInt(); ZDOPeer peer = ZDOMan.instance.GetPeer(sender); Logger.LogDebug((object)$"Sending first id across to peer {num}"); ZDO zdo = GetZdo(num); if (zdo != null && peer != null) { peer.ForceSendZDO(zdo.m_uid); } else { Logger.LogDebug((object)"RequestPersistentIdRPCServerReceive called but zdoid not found, attempting to sync all ids to peer"); SyncToPeer(peer); } yield return null; } public ZPackage GetAllServerZdoIds() { //IL_0000: Unknown result type (might be due to invalid IL or missing references) //IL_0006: Expected O, but got Unknown //IL_0047: Unknown result type (might be due to invalid IL or missing references) ZPackage val = new ZPackage(); Logger.LogMessage((object)$"Writing {_zdoGuidLookup.Values.Count} zdos to a ZPackage"); foreach (ZDO value in _zdoGuidLookup.Values) { val.Write(value.m_uid); } return val; } public bool RequestZdoFromServer(int persistentId) { //IL_000e: Unknown result type (might be due to invalid IL or missing references) //IL_0014: Expected O, but got Unknown if (ZNet.instance.IsDedicated()) { return false; } ZPackage val = new ZPackage(); val.Write(persistentId); long serverPeerID = ZRoutedRpc.instance.GetServerPeerID(); RPC_RequestPersistentIdInstance.SendPackage(serverPeerID, val); return true; } public IEnumerator GetZdoFromServerAsync(int persistentId, Action<ZDO?> onComplete) { if (ZNet.instance.IsServer() && ZNet.instance.IsDedicated()) { ZDO zdo = GetZdo(persistentId); Logger.LogWarning((object)$"Called GetZdoFromServer for {persistentId} on the server. This should not happen"); onComplete(zdo); yield break; } ZDO zdo2 = GetZdo(persistentId); if (zdo2 != null) { onComplete(zdo2); } else if (PendingPersistentIdQueries.ContainsKey(persistentId)) { Logger.LogWarning((object)$"RequestPersistentID called for ongoing operation on id: {persistentId}, requests cannot be called during a specific timelimit"); onComplete(null); } else { RequestZdoFromServer(persistentId); yield return WaitForZdo(persistentId, onComplete); } } private IEnumerator WaitForZdo(int persistentId, Action<ZDO?> onComplete, int timeoutInMs = 2000) { DebugSafeTimer timer = DebugSafeTimer.StartNew(_timers); ZDO targetZdo = null; while (timer.ElapsedMilliseconds < (float)timeoutInMs && targetZdo == null) { if (_zdoGuidLookup.TryGetValue(persistentId, out ZDO value)) { targetZdo = value; break; } yield return (object)new WaitForFixedUpdate(); } if (timer.ElapsedMilliseconds >= (float)timeoutInMs) { Logger.LogWarning((object)"Timeout for WaitForZdo reached, exiting the WaitForZdo call with a failure."); } else { Logger.LogDebug((object)$"Completed timer in: {timer.ElapsedMilliseconds} milliseconds"); } if (PendingPersistentIdQueries.ContainsKey(persistentId)) { PendingPersistentIdQueries.Remove(persistentId); } onComplete(targetZdo); } public void Reset() { _zdoGuidLookup.Clear(); } public static bool GetPersistentID(ZDO zdo, out int id) { id = zdo.GetInt(ZdoVarController.PersistentUidHash, 0); return id != 0; } public int GetOrCreatePersistentID(ZDO? zdo) { //IL_0010: Unknown result type (might be due to invalid IL or missing references) //IL_0017: Expected O, but got Unknown //IL_002a: Unknown result type (might be due to invalid IL or missing references) if (zdo == null) { Logger.LogWarning((object)"GetOrCreatePersistentID called with a null ZDO, this will be disabled in the future."); } if (zdo == null) { zdo = new ZDO(); } int @int = zdo.GetInt(ZdoVarController.PersistentUidHash, 0); if (@int != 0) { return @int; } for (@int = ZdoUtils.ZdoIdToId(zdo.m_uid); _zdoGuidLookup.ContainsKey(@int); @int++) { } zdo.Set(ZdoVarController.PersistentUidHash, @int, false); _zdoGuidLookup[@int] = zdo; return @int; } public void HandleRegisterPersistentId(ZDO zdo) { if (GetPersistentID(zdo, out var id)) { _zdoGuidLookup[id] = zdo; } } private void HandleDeregisterPersistentId(ZDO zdo) { if (GetPersistentID(zdo, out var id)) { _zdoGuidLookup.Remove(id); } } public void Deserialize(ZDO zdo) { HandleRegisterPersistentId(zdo); if (OnDeserialize == null) { return; } try { OnDeserialize(zdo); } catch { Logger.LogError((object)"OnDeserialize had an error"); } } public void Load(ZDO zdo) { HandleRegisterPersistentId(zdo); if (OnLoad == null) { return; } try { OnLoad(zdo); } catch { Logger.LogError((object)"OnLoad had an error"); } } public void Reset(ZDO zdo) { HandleDeregisterPersistentId(zdo); if (OnReset == null) { return; } try { OnReset(zdo); } catch { Logger.LogError((object)"OnReset had an error"); } } public ZDO? GetZdo(int id) { if (!_zdoGuidLookup.TryGetValue(id, out ZDO value)) { return null; } return value; } public GameObject? GetGameObject(int id) { ZNetView instance = GetInstance(id); if (!Object.op_Implicit((Object)(object)instance)) { return null; } if (instance == null) { return null; } return ((Component)instance).gameObject; } public ZNetView? GetInstance(int id) { ZDO zdo = GetZdo(id); if (zdo == null) { return null; } return ZNetScene.instance.FindInstance(zdo); } } [BepInPlugin("zolantris.ZdoWatcher", "ZdoWatcher", "1.2.0")] [NetworkCompatibility(/*Could not decode attribute arguments.*/)] public class ZdoWatcherPlugin : BaseUnityPlugin { public const string Author = "zolantris"; public const string Version = "1.2.0"; public const string ModName = "ZdoWatcher"; public const string ModGuid = "zolantris.ZdoWatcher"; private static Harmony _harmony; public const string ModDescription = "Valheim Mod made to share Zdo Changes and side effect through one shareable interface"; public const string CopyRight = "Copyright © 2023-2025, GNU-v3 licensed"; public static string HarmonyGuid => "zolantris.ZdoWatcher"; private void Awake() { //IL_0010: Unknown result type (might be due to invalid IL or missing references) //IL_001a: Expected O, but got Unknown ZdoWatcherConfig.BindConfig(((BaseUnityPlugin)this).Config); _harmony = new Harmony(HarmonyGuid); _harmony.PatchAll(typeof(ZdoPatch)); _harmony.PatchAll(typeof(ZNetScene_Patch)); _harmony.PatchAll(typeof(ZDOMan_Patch)); if (ZdoWatcherConfig.GuardAgainstInvalidZNetSceneSpam != null && ZdoWatcherConfig.GuardAgainstInvalidZNetSceneSpam.Value) { _harmony.PatchAll(typeof(InvalidZNetScenePatch)); } ZdoWatchController.Instance = ((Component)this).gameObject.AddComponent<ZdoWatchController>(); } } } namespace ZdoWatcher.Patches { public class ZDOMan_Patch { [HarmonyPatch(typeof(ZDOMan), "AddPeer")] [HarmonyPostfix] private static void OnAddPeer(ZDOMan __instance) { int num = __instance.m_peers.Count - 1; if (num >= 1) { ZDOPeer zdoPeer = __instance.m_peers[num]; ZdoWatchController.Instance.SyncToPeer(zdoPeer); } } } [HarmonyPatch] public class ZdoPatch { [HarmonyPatch(typeof(ZDO), "Deserialize")] [HarmonyPostfix] private static void ZDO_Deserialize(ZDO __instance, ZPackage pkg) { ZdoWatchController.Instance.Deserialize(__instance); } [HarmonyPatch(typeof(ZDO), "Load")] [HarmonyPostfix] private static void ZDO_Load(ZDO __instance, ZPackage pkg, int version) { ZdoWatchController.Instance.Load(__instance); } [HarmonyPatch(typeof(ZDO), "Reset")] [HarmonyPrefix] private static void ZDO_Reset(ZDO __instance) { ZdoWatchController.Instance.Reset(__instance); } } public class ZNetScene_Patch { [HarmonyPatch(typeof(ZNetScene), "Shutdown")] [HarmonyPostfix] private static void ZNetScene_Shutdown() { ZdoWatchController.Instance.Reset(); } } } namespace ZdoWatcher.ZdoWatcher.Utils { public static class ZdoUtils { public static int ZdoIdToId(ZDOID zdoid) { return (int)((ZDOID)(ref zdoid)).UserID + (int)((ZDOID)(ref zdoid)).ID; } } } namespace ZdoWatcher.ZdoWatcher.Config { public class ConfigHelpers { public static ConfigDescription CreateConfigDescription(string description, bool isAdmin = false, bool isAdvanced = false) { //IL_000a: Unknown result type (might be due to invalid IL or missing references) //IL_000f: Unknown result type (might be due to invalid IL or missing references) //IL_0016: Unknown result type (might be due to invalid IL or missing references) //IL_0023: Expected O, but got Unknown //IL_0023: Unknown result type (might be due to invalid IL or missing references) //IL_0029: Expected O, but got Unknown return new ConfigDescription(description, (AcceptableValueBase)null, new object[1] { (object)new ConfigurationManagerAttributes { IsAdminOnly = isAdmin, IsAdvanced = isAdvanced } }); } } public static class ZdoWatcherConfig { public static ConfigFile? Config { get; private set; } public static ConfigEntry<bool>? GuardAgainstInvalidZNetSceneSpam { get; private set; } public static void BindConfig(ConfigFile config) { Config = config; GuardAgainstInvalidZNetSceneSpam = BepInExConfigUtils.BindUnique<bool>(config, "Patches", "GuardAgainstInvalidZNetScene", true, ConfigHelpers.CreateConfigDescription("Allows you to customize what piece the raft initializes with. Admins only as this can be overpowered.", isAdmin: true, isAdvanced: true), "C:\\Users\\fre\\dev\\repos\\ValheimMods\\src\\ZdoWatcher\\ZdoWatcher.Config\\ZdoWatcherConfig.cs", 15); } } public class InvalidZNetScenePatch { [HarmonyPatch(typeof(ZNetScene), "RemoveObjects")] [HarmonyPrefix] private static bool RemoveObjects(ZNetScene __instance, List<ZDO> currentNearObjects, List<ZDO> currentDistantObjects) { byte b = (byte)((uint)Time.frameCount & 0xFFu); foreach (ZDO currentNearObject in currentNearObjects) { currentNearObject.TempRemoveEarmark = b; } foreach (ZDO currentDistantObject in currentDistantObjects) { currentDistantObject.TempRemoveEarmark = b; } __instance.m_tempRemoved.Clear(); foreach (ZNetView value in __instance.m_instances.Values) { if (Object.op_Implicit((Object)(object)value) && value.GetZDO().TempRemoveEarmark != b) { __instance.m_tempRemoved.Add(value); } } for (int i = 0; i < __instance.m_tempRemoved.Count; i++) { ZNetView val = __instance.m_tempRemoved[i]; if (Object.op_Implicit((Object)(object)val)) { ZDO zDO = val.GetZDO(); val.ResetZDO(); Object.Destroy((Object)(object)((Component)val).gameObject); if (!zDO.Persistent && zDO.IsOwner()) { ZDOMan.instance.DestroyZDO(zDO); } __instance.m_instances.Remove(zDO); } } return false; } } } namespace System.Runtime.CompilerServices { [AttributeUsage(AttributeTargets.Assembly, AllowMultiple = true)] internal sealed class IgnoresAccessChecksToAttribute : Attribute { internal IgnoresAccessChecksToAttribute(string assemblyName) { } } }
plugins\Zolantris.Shared.dll
Decompiled a week agousing System; using System.Collections; using System.Collections.Generic; using System.Diagnostics; using System.IO; using System.Linq; using System.Reflection; using System.Runtime.CompilerServices; using System.Runtime.Versioning; using System.Security; using System.Security.Permissions; using System.Text; using System.Text.RegularExpressions; using BepInEx; using BepInEx.Configuration; using BepInEx.Logging; using HarmonyLib; using JetBrains.Annotations; using Microsoft.CodeAnalysis; using UnityEngine; using UnityEngine.Rendering; using Zolantris.Shared.Interfaces; [assembly: CompilationRelaxations(8)] [assembly: RuntimeCompatibility(WrapNonExceptionThrows = true)] [assembly: Debuggable(DebuggableAttribute.DebuggingModes.IgnoreSymbolStoreSequencePoints)] [assembly: TargetFramework(".NETStandard,Version=v2.1", FrameworkDisplayName = ".NET Standard 2.1")] [assembly: SecurityPermission(SecurityAction.RequestMinimum, SkipVerification = true)] [assembly: AssemblyVersion("0.0.0.0")] [module: UnverifiableCode] [module: RefSafetyRules(11)] namespace Microsoft.CodeAnalysis { [CompilerGenerated] [Microsoft.CodeAnalysis.Embedded] internal sealed class EmbeddedAttribute : Attribute { } } namespace System.Runtime.CompilerServices { [CompilerGenerated] [Microsoft.CodeAnalysis.Embedded] [AttributeUsage(AttributeTargets.Class | AttributeTargets.Property | AttributeTargets.Field | AttributeTargets.Event | AttributeTargets.Parameter | AttributeTargets.ReturnValue | AttributeTargets.GenericParameter, AllowMultiple = false, Inherited = false)] internal sealed class NullableAttribute : Attribute { public readonly byte[] NullableFlags; public NullableAttribute(byte P_0) { NullableFlags = new byte[1] { P_0 }; } public NullableAttribute(byte[] P_0) { NullableFlags = P_0; } } [CompilerGenerated] [Microsoft.CodeAnalysis.Embedded] [AttributeUsage(AttributeTargets.Class | AttributeTargets.Struct | AttributeTargets.Method | AttributeTargets.Interface | AttributeTargets.Delegate, AllowMultiple = false, Inherited = false)] internal sealed class NullableContextAttribute : Attribute { public readonly byte Flag; public NullableContextAttribute(byte P_0) { Flag = P_0; } } [CompilerGenerated] [Microsoft.CodeAnalysis.Embedded] [AttributeUsage(AttributeTargets.Module, AllowMultiple = false, Inherited = false)] internal sealed class RefSafetyRulesAttribute : Attribute { public readonly int Version; public RefSafetyRulesAttribute(int P_0) { Version = P_0; } } } namespace Shared.Interfaces { public interface PluginInfo { string Name { get; } string Version { get; } string Guid { get; } } } namespace Zolantris.Shared { public class AnimatorIKRelay : MonoBehaviour { [CanBeNull] public IAnimatorIKRelayReceiver relayReceiver; private void LateUpdate() { relayReceiver?.OnAnimatorOverride(); } private void OnAnimatorIK(int layerIndex) { relayReceiver?.OnAnimatorIKRelay(layerIndex); } public void SetReceiver(IAnimatorIKRelayReceiver receiver) { relayReceiver = receiver; } } public static class BepInExConfigUtils { private static readonly HashSet<string> BoundKeys = new HashSet<string>(); private static void EnsureUniqueKey(string section, string key, string file, int line) { string text = section + "." + key; if (!BoundKeys.Add(text)) { throw new InvalidOperationException($"[BepInExConfigUtils] Duplicate config key: '{text}'\n - Source: {file}:{line}"); } } public static ConfigEntry<T> BindUnique<T>(this ConfigFile config, string section, string key, T defaultValue, ConfigDescription desc, [CallerFilePath] string file = "", [CallerLineNumber] int line = 0) { EnsureUniqueKey(section, key, file, line); return config.Bind<T>(section, key, defaultValue, desc); } public static ConfigEntry<bool> BindUnique(this ConfigFile config, string section, string key, bool defaultValue, string description, [CallerFilePath] string file = "", [CallerLineNumber] int line = 0) { //IL_0017: Unknown result type (might be due to invalid IL or missing references) //IL_0021: Expected O, but got Unknown EnsureUniqueKey(section, key, file, line); return config.Bind<bool>(section, key, defaultValue, new ConfigDescription(description, (AcceptableValueBase)null, Array.Empty<object>())); } public static ConfigEntry<int> BindUnique(this ConfigFile config, string section, string key, int defaultValue, string description, [CallerFilePath] string file = "", [CallerLineNumber] int line = 0) { //IL_0017: Unknown result type (might be due to invalid IL or missing references) //IL_0021: Expected O, but got Unknown EnsureUniqueKey(section, key, file, line); return config.Bind<int>(section, key, defaultValue, new ConfigDescription(description, (AcceptableValueBase)null, Array.Empty<object>())); } public static ConfigEntry<float> BindUnique(this ConfigFile config, string section, string key, float defaultValue, string description, [CallerFilePath] string file = "", [CallerLineNumber] int line = 0) { //IL_0017: Unknown result type (might be due to invalid IL or missing references) //IL_0021: Expected O, but got Unknown EnsureUniqueKey(section, key, file, line); return config.Bind<float>(section, key, defaultValue, new ConfigDescription(description, (AcceptableValueBase)null, Array.Empty<object>())); } public static ConfigEntry<string> BindUnique(this ConfigFile config, string section, string key, string defaultValue, string description, [CallerFilePath] string file = "", [CallerLineNumber] int line = 0) { //IL_0017: Unknown result type (might be due to invalid IL or missing references) //IL_0021: Expected O, but got Unknown EnsureUniqueKey(section, key, file, line); return config.Bind<string>(section, key, defaultValue, new ConfigDescription(description, (AcceptableValueBase)null, Array.Empty<object>())); } } public class CoroutineHandle { [CanBeNull] private readonly MonoBehaviour _owner; public bool IsRunning => Instance != null; public Coroutine Instance { get; private set; } public CoroutineHandle(MonoBehaviour owner) { _owner = owner; } public MonoBehaviour GetOwner() { return _owner; } public bool IsValid(MonoBehaviour? instance) { if ((Object)(object)instance == (Object)null) { return false; } if (!Object.op_Implicit((Object)(object)_owner)) { return false; } if ((Object)(object)instance != (Object)(object)_owner) { return false; } return true; } public void Start(IEnumerator routine, bool shouldStop = true) { if (shouldStop) { Stop(); } if (!IsRunning && (Object)(object)_owner != (Object)null) { Instance = _owner.StartCoroutine(Wrap(routine)); } } public void Stop() { if (Instance != null) { if ((Object)(object)_owner != (Object)null) { _owner.StopCoroutine(Instance); } Instance = null; } } private IEnumerator Wrap(IEnumerator routine) { try { while (true) { try { if (!routine.MoveNext()) { break; } } catch (Exception arg) { LoggerProvider.LogError($"[CoroutineHandle] Exception in coroutine: {arg}", "C:\\Users\\fre\\dev\\repos\\ValheimMods\\src\\Shared\\Zolantris.Shared\\CoroutineHandler.cs", 80); break; } yield return routine.Current; } } finally { Instance = null; } } } public static class HarmonyHelper { private const bool IsDebug = false; public static void TryPatchAll(Harmony harmonyInstance, Type type) { try { harmonyInstance.PatchAll(type); } catch (Exception arg) { LoggerProvider.LogError($"[Harmony] Failed to patch: {type.Name}\n{arg}", "C:\\Users\\fre\\dev\\repos\\ValheimMods\\src\\Shared\\Zolantris.Shared\\HarmonyHelpers.cs", 32); } } public static void TryPatchAll(Harmony harmonyInstance, params Type[] patchTypes) { foreach (Type type in patchTypes) { TryPatchAll(harmonyInstance, type); } } } [Serializable] public struct JointPose { public Vector3 Position; public Quaternion Rotation; public JointPose(Vector3 pos, Quaternion rot) { //IL_0001: Unknown result type (might be due to invalid IL or missing references) //IL_0002: Unknown result type (might be due to invalid IL or missing references) //IL_0008: Unknown result type (might be due to invalid IL or missing references) //IL_0009: Unknown result type (might be due to invalid IL or missing references) Position = pos; Rotation = rot; } public override string ToString() { return $"new JointPose(new Vector3({Position.x}f, {Position.y}f, {Position.z}f), new Quaternion({Rotation.x}f, {Rotation.y}f, {Rotation.z}f, {Rotation.w}f))"; } } public static class JointPoseDumpUtility { public static Dictionary<string, JointPose> ComputeDeltaPose(Dictionary<string, JointPose> basePose, Dictionary<string, JointPose> otherPose, float positionEpsilon = 0.01f, float rotationEpsilon = 0.01f) { //IL_0031: Unknown result type (might be due to invalid IL or missing references) //IL_0038: Unknown result type (might be due to invalid IL or missing references) //IL_003d: Unknown result type (might be due to invalid IL or missing references) //IL_0042: Unknown result type (might be due to invalid IL or missing references) //IL_0057: Unknown result type (might be due to invalid IL or missing references) //IL_005e: Unknown result type (might be due to invalid IL or missing references) Dictionary<string, JointPose> dictionary = new Dictionary<string, JointPose>(); foreach (KeyValuePair<string, JointPose> item in otherPose) { bool flag = true; if (basePose.TryGetValue(item.Key, out var value)) { Vector3 val = item.Value.Position - value.Position; bool num = ((Vector3)(ref val)).sqrMagnitude > positionEpsilon * positionEpsilon; bool flag2 = Quaternion.Angle(item.Value.Rotation, value.Rotation) > rotationEpsilon; flag = num || flag2; } if (flag) { dictionary[item.Key] = item.Value; } } return dictionary; } public static void DumpDeltaPoseToFile(Dictionary<string, JointPose> basePose, Dictionary<string, JointPose> otherPose, string deltaName, string outputDir = null) { DumpPoseToFile(ComputeDeltaPose(basePose, otherPose), deltaName, outputDir); } public static void DumpPoseToFile(Dictionary<string, JointPose> poseDict, string modelName, string outputDir = null) { //IL_0103: Unknown result type (might be due to invalid IL or missing references) //IL_0108: Unknown result type (might be due to invalid IL or missing references) //IL_0111: Unknown result type (might be due to invalid IL or missing references) //IL_0116: Unknown result type (might be due to invalid IL or missing references) //IL_0131: Unknown result type (might be due to invalid IL or missing references) //IL_0140: Unknown result type (might be due to invalid IL or missing references) //IL_014f: Unknown result type (might be due to invalid IL or missing references) //IL_015e: Unknown result type (might be due to invalid IL or missing references) //IL_016d: Unknown result type (might be due to invalid IL or missing references) //IL_017c: Unknown result type (might be due to invalid IL or missing references) //IL_018b: Unknown result type (might be due to invalid IL or missing references) string text = modelName.Replace(" ", "_").Replace("-", "_"); string text2 = DateTime.Now.ToString("yyyy_MM_dd_HH_mm_ss"); string text3 = "ModelJointPoseSnapshot_" + text + "_" + text2; string path = "unity-model-poses-export"; string path2 = text + ".cs"; if (string.IsNullOrEmpty(outputDir)) { outputDir = Environment.GetFolderPath(Environment.SpecialFolder.Desktop); } outputDir = Path.Combine(outputDir, path); if (!Directory.Exists(outputDir)) { Directory.CreateDirectory(outputDir); } string path3 = Path.Combine(outputDir, path2); StringBuilder stringBuilder = new StringBuilder(); stringBuilder.AppendLine("// Auto-generated model pose snapshot"); stringBuilder.AppendLine("using UnityEngine;"); stringBuilder.AppendLine(); stringBuilder.AppendLine("public static class CustomAnimationPoses"); stringBuilder.AppendLine("{"); stringBuilder.AppendLine(" public static readonly System.Collections.Generic.Dictionary<string, JointPose> " + text3 + " = new() {"); foreach (KeyValuePair<string, JointPose> item in poseDict) { Vector3 position = item.Value.Position; Quaternion rotation = item.Value.Rotation; stringBuilder.AppendLine($" [\"{item.Key}\"] = new JointPose(new Vector3({position.x}f, {position.y}f, {position.z}f), new Quaternion({rotation.x}f, {rotation.y}f, {rotation.z}f, {rotation.w}f)),"); } stringBuilder.AppendLine(" };"); stringBuilder.AppendLine("}"); File.WriteAllText(path3, stringBuilder.ToString()); } } public static class LayerHelpers { public const int CustomRaftLayer = 29; public static int TerrainLayer = LayerMask.NameToLayer("terrain"); public static int UILayer = LayerMask.NameToLayer("UI"); public static int PieceLayer = LayerMask.NameToLayer("piece"); public static int DefaultLayer = LayerMask.NameToLayer("Default"); public static int DefaultSmallLayer = LayerMask.NameToLayer("Default_small"); public static int ItemLayer = LayerMask.NameToLayer("item"); public static int HitboxLayer = LayerMask.NameToLayer("hitbox"); public static LayerMask CustomRaftLayerMask = LayerMask.op_Implicit(LayerMask.GetMask(new string[1] { LayerMask.LayerToName(29) })); public static LayerMask PieceLayerMask = LayerMask.op_Implicit(LayerMask.GetMask(new string[1] { "piece" })); public static LayerMask PieceAndCustomVehicleMask = LayerMask.op_Implicit(LayerMask.GetMask(new string[2] { "piece", LayerMask.LayerToName(29) })); public static LayerMask PhysicalLayerMask = LayerMask.op_Implicit(LayerMask.GetMask(new string[9] { "Default", "character", "piece", "terrain", "static_solid", "Default_small", "character_net", "vehicle", LayerMask.LayerToName(29) })); public static LayerMask GroundLayers = LayerMask.op_Implicit(LayerMask.GetMask(new string[5] { "Default", "piece", "terrain", "static_solid", "Default_small" })); public static LayerMask OnboardLayers = LayerMask.op_Implicit(LayerMask.GetMask(new string[2] { "item", "character" })); public static string SmokeLayerString = LayerMask.LayerToName(31); public static LayerMask BlockingColliderExcludeLayers = LayerMask.op_Implicit(LayerMask.GetMask(new string[7] { "character", "character_net", "character_trigger", "viewbox", "character_nonenv", LayerMask.LayerToName(29), SmokeLayerString })); public static LayerMask CannonHitLayers = LayerMask.op_Implicit(LayerMask.GetMask(new string[11] { "character", "character_net", "character_ghost", "character_noenv", "Default", "Default_small", "hitbox", "piece", "static_solid", "terrain", "vehicle" })); public static LayerMask CannonBlockingSiteHitLayers = LayerMask.op_Implicit(LayerMask.GetMask(new string[7] { "Default", "Default_small", "piece", "terrain", "character", "character_net", "character_noenv" })); public static List<string> ActiveLayersForBlockingMask = new List<string>(); public static int PieceNonSolidLayer = LayerMask.NameToLayer("piece_nonsolid"); public static int IgnoreRaycastLayer = LayerMask.NameToLayer("Ignore Raycast"); public static LayerMask RamColliderExcludeLayers = LayerMask.op_Implicit(LayerMask.GetMask(new string[12] { "character_trigger", "viewbox", "character_nonenv", "UI", "effect", "ghost", "piece_nonsolid", "Water", "WaterVolume", "skybox", "hitbox", "character_ghost" })); public static int CharacterLayer = LayerMask.NameToLayer("character"); public static int CharacterTriggerLayer = LayerMask.NameToLayer("character_trigger"); public static int CharacterLayerMask = LayerMask.GetMask(new string[3] { "character", "character_net", "character_nonenv" }); public static bool IsItemLayer(int layer) { return layer == ItemLayer; } public static bool IsContainedWithinLayerMask(int layer, LayerMask mask) { return (((LayerMask)(ref mask)).value & (1 << layer)) != 0; } public static Func<Collider, bool> IsContainedWithinLayerMaskPredicate(LayerMask mask) { //IL_0006: Unknown result type (might be due to invalid IL or missing references) //IL_0007: Unknown result type (might be due to invalid IL or missing references) return (Collider c) => (Object)(object)c != (Object)null && ((1 << ((Component)c).gameObject.layer) & ((LayerMask)(ref mask)).value) != 0; } [UsedImplicitly] public static List<int> GetActiveLayers(LayerMask mask) { ActiveLayersForBlockingMask.Clear(); List<int> list = new List<int>(); for (int i = 0; i < 32; i++) { if ((((LayerMask)(ref mask)).value & (1 << i)) != 0) { string item = LayerMask.LayerToName(i); ActiveLayersForBlockingMask.Add(item); list.Add(i); } } return list; } [UsedImplicitly] public static void PrintAllLayers() { LoggerProvider.LogDebug("Listing All Runtime game layers", "C:\\Users\\fre\\dev\\repos\\ValheimMods\\src\\Shared\\Zolantris.Shared\\LayerHelpers.cs", 119); for (int i = 0; i < 32; i++) { string text = LayerMask.LayerToName(i); if (!string.IsNullOrEmpty(text)) { LoggerProvider.LogDebugDebounced($"Layer {i}: {text}", 5f, "C:\\Users\\fre\\dev\\repos\\ValheimMods\\src\\Shared\\Zolantris.Shared\\LayerHelpers.cs", 125); } } } public static LayerMask CombineLayerMask(LayerMask originalMask, int layerToAdd) { //IL_0000: Unknown result type (might be due to invalid IL or missing references) //IL_000d: Unknown result type (might be due to invalid IL or missing references) return LayerMask.op_Implicit(LayerMask.op_Implicit(originalMask) | (1 << layerToAdd)); } } public static class LoggerProvider { public static LogLevel ActiveLogLevel = (LogLevel)63; private static ManualLogSource? Logger; private static LogLevel GlobalLogLevel = (LogLevel)63; private static bool _hasInitialized; private static readonly Dictionary<string, string> _callerCache = new Dictionary<string, string>(); private static readonly Dictionary<string, float> _lastLogTimestamps = new Dictionary<string, float>(); private static float GetTime() { return Time.realtimeSinceStartup; } public static void Setup(ManualLogSource? logger) { //IL_002c: Unknown result type (might be due to invalid IL or missing references) //IL_0031: Unknown result type (might be due to invalid IL or missing references) //IL_003b: Unknown result type (might be due to invalid IL or missing references) //IL_0045: Unknown result type (might be due to invalid IL or missing references) //IL_0022: Unknown result type (might be due to invalid IL or missing references) if (_hasInitialized) { Debug.LogWarning((object)"LoggerProvider: Setup called more than once. Ignoring duplicate initialization."); return; } _hasInitialized = true; Logger = (ManualLogSource?)(((object)logger) ?? ((object)new ManualLogSource("ValheimVehiclesLoggerProviderFallback"))); GlobalLogLevel = ReadBepInExConsoleLogLevel(); LogInfo($"Logger initialized. Plugin Level: {ActiveLogLevel}, Global Level: {GlobalLogLevel}", "C:\\Users\\fre\\dev\\repos\\ValheimMods\\src\\Shared\\Zolantris.Shared\\LoggerProvider.cs", 53); } public static void LogError(string val, [CallerFilePath] string file = "", [CallerLineNumber] int line = 0) { if (IsLevelEnabled((LogLevel)2)) { SafeLog((LogLevel)2, Format("Error", val, file, line)); } } public static void LogWarning(string val, [CallerFilePath] string file = "", [CallerLineNumber] int line = 0) { if (IsLevelEnabled((LogLevel)4)) { SafeLog((LogLevel)4, Format("Warning", val, file, line)); } } [Conditional("DEBUG")] public static void LogDev(string val, [CallerFilePath] string file = "", [CallerLineNumber] int line = 0) { if (IsLevelEnabled((LogLevel)32)) { SafeLog((LogLevel)32, Format("Dev", val, file, line)); } } public static void LogDebug(string val, [CallerFilePath] string file = "", [CallerLineNumber] int line = 0) { if (IsLevelEnabled((LogLevel)32)) { SafeLog((LogLevel)32, Format("Debug", val, file, line)); } } public static void LogMessage(string val, [CallerFilePath] string file = "", [CallerLineNumber] int line = 0) { if (IsLevelEnabled((LogLevel)8)) { SafeLog((LogLevel)8, Format("Message", val, file, line)); } } public static void LogInfo(string val, [CallerFilePath] string file = "", [CallerLineNumber] int line = 0) { if (IsLevelEnabled((LogLevel)16)) { SafeLog((LogLevel)16, Format("Info", val, file, line)); } } private static bool IsLevelEnabled(LogLevel level) { //IL_0000: Unknown result type (might be due to invalid IL or missing references) //IL_0007: Unknown result type (might be due to invalid IL or missing references) //IL_0010: Unknown result type (might be due to invalid IL or missing references) //IL_0017: Invalid comparison between Unknown and I4 //IL_0024: Unknown result type (might be due to invalid IL or missing references) //IL_0025: Unknown result type (might be due to invalid IL or missing references) //IL_0019: Unknown result type (might be due to invalid IL or missing references) //IL_0020: Invalid comparison between Unknown and I4 //IL_002c: Unknown result type (might be due to invalid IL or missing references) //IL_002d: Unknown result type (might be due to invalid IL or missing references) if ((int)ActiveLogLevel == 0 || (int)GlobalLogLevel == 0) { return false; } if ((int)ActiveLogLevel == 63 && (int)GlobalLogLevel == 63) { return true; } if (level <= ActiveLogLevel) { return level <= GlobalLogLevel; } return false; } private static void SafeLog(LogLevel level, string message) { //IL_0096: Unknown result type (might be due to invalid IL or missing references) //IL_0098: Invalid comparison between Unknown and I4 //IL_000a: Unknown result type (might be due to invalid IL or missing references) //IL_000c: Invalid comparison between Unknown and I4 //IL_00a6: Unknown result type (might be due to invalid IL or missing references) //IL_00a8: Invalid comparison between Unknown and I4 //IL_009a: Unknown result type (might be due to invalid IL or missing references) //IL_009c: Unknown result type (might be due to invalid IL or missing references) //IL_009e: Invalid comparison between Unknown and I4 //IL_002c: Unknown result type (might be due to invalid IL or missing references) //IL_002f: Invalid comparison between Unknown and I4 //IL_000e: Unknown result type (might be due to invalid IL or missing references) //IL_0010: Unknown result type (might be due to invalid IL or missing references) //IL_0026: Expected I4, but got Unknown //IL_00aa: Unknown result type (might be due to invalid IL or missing references) //IL_00ad: Invalid comparison between Unknown and I4 //IL_00a0: Unknown result type (might be due to invalid IL or missing references) //IL_00a2: Invalid comparison between Unknown and I4 //IL_0031: Unknown result type (might be due to invalid IL or missing references) //IL_0034: Invalid comparison between Unknown and I4 //IL_0026: Unknown result type (might be due to invalid IL or missing references) //IL_0028: Invalid comparison between Unknown and I4 //IL_00af: Unknown result type (might be due to invalid IL or missing references) //IL_00b2: Invalid comparison between Unknown and I4 try { if (Logger != null) { if ((int)level <= 8) { switch (level - 1) { default: if ((int)level != 8) { break; } Logger.LogMessage((object)message); return; case 0: Logger.LogFatal((object)message); return; case 1: Logger.LogError((object)message); return; case 3: Logger.LogWarning((object)message); return; case 2: break; } } else { if ((int)level == 16) { Logger.LogInfo((object)message); return; } if ((int)level == 32) { Logger.LogDebug((object)message); return; } } Logger.LogMessage((object)message); return; } if ((int)level <= 4) { if (level - 1 <= 1) { Debug.LogError((object)message); return; } if ((int)level == 4) { Debug.LogWarning((object)message); return; } } else { if ((int)level == 8 || (int)level == 16) { Debug.Log((object)message); return; } if ((int)level == 32) { return; } } Debug.Log((object)message); } catch (Exception ex) { Debug.LogWarning((object)("LoggerProvider: Failed to log message. Exception: " + ex.Message + "\nOriginalMessage: " + message)); } } private static string Format(string logType, string message, string file, int line) { string key = $"{file}:{line}"; if (!_callerCache.TryGetValue(key, out string value)) { MethodBase? obj = new StackTrace(2, fNeedFileInfo: true).GetFrame(0)?.GetMethod(); Type type = obj?.DeclaringType; string text; if (type == null) { text = "UnknownType"; } else if (type.IsGenericType) { string name = type.Name; int num = name.IndexOf('`'); string obj2 = ((num >= 0) ? name.Substring(0, num) : name); string[] value2 = (from t in type.GetGenericArguments() select t.Name).ToArray(); text = obj2 + "<" + string.Join(", ", value2) + ">"; } else { text = type.Name; } string text2 = obj?.Name ?? "UnknownMethod"; string fileName = Path.GetFileName(file); value = $"[{text}.{fileName}:{line} ({text2})]"; _callerCache[key] = value; } return logType + ":" + value + " " + message; } public static void LogDevDebounced(string val, float debounceSeconds = 5f, [CallerFilePath] string file = "", [CallerLineNumber] int line = 0) { if (IsLevelEnabled((LogLevel)32) && !ShouldDebounce($"Dev:{file}:{line}:{val.GetHashCode()}", debounceSeconds)) { SafeLog((LogLevel)16, Format("Dev", val, file, line)); } } public static void LogDebugDebounced(string val, float debounceSeconds = 5f, [CallerFilePath] string file = "", [CallerLineNumber] int line = 0) { if (IsLevelEnabled((LogLevel)32) && !ShouldDebounce($"Debug:{file}:{line}:{val.GetHashCode()}", debounceSeconds)) { SafeLog((LogLevel)16, Format("Debug", val, file, line)); } } public static void LogInfoDebounced(string val, float debounceSeconds = 5f, [CallerFilePath] string file = "", [CallerLineNumber] int line = 0) { if (IsLevelEnabled((LogLevel)16) && !ShouldDebounce($"INFO:{file}:{line}:{val.GetHashCode()}", debounceSeconds)) { SafeLog((LogLevel)16, Format("Info", val, file, line)); } } public static void LogInfoDebounced(string key, string message, float debounceSeconds = 5f, [CallerFilePath] string file = "", [CallerLineNumber] int line = 0) { if (!ShouldDebounce($"INFO:{file}:{line}:{key}", debounceSeconds)) { SafeLog((LogLevel)16, Format("Info", message, file, line)); } } private static bool ShouldDebounce(string key, float debounceSeconds) { float time = GetTime(); if (_lastLogTimestamps.TryGetValue(key, out var value) && time - value < debounceSeconds) { return true; } _lastLogTimestamps[key] = time; return false; } private static LogLevel ReadBepInExConsoleLogLevel() { //IL_001f: Unknown result type (might be due to invalid IL or missing references) //IL_001a: Unknown result type (might be due to invalid IL or missing references) //IL_006a: Unknown result type (might be due to invalid IL or missing references) //IL_0047: Unknown result type (might be due to invalid IL or missing references) //IL_0048: Unknown result type (might be due to invalid IL or missing references) try { string text = Path.Combine(Paths.ConfigPath, "BepInEx.cfg"); if (!File.Exists(text)) { return (LogLevel)63; } ConfigEntry<string> val = default(ConfigEntry<string>); if (new ConfigFile(text, true).TryGetEntry<string>("Logging", "ConsoleDisplayedLevel", ref val) && Enum.TryParse<LogLevel>(val.Value, ignoreCase: true, out LogLevel result)) { return result; } } catch (Exception ex) { Debug.LogWarning((object)("LoggerProvider: Failed to read BepInEx.cfg console level. Defaulting to All. Exception: " + ex.Message)); } return (LogLevel)63; } } public class RuntimeDebugLineDrawer : SingletonBehaviour<RuntimeDebugLineDrawer> { private class LineInstance { public bool active; public float expiry; public LineRenderer renderer; } private static GameObject _singletonObject; public static Material DebugRayMaterial; public static bool IsEnabled = false; public static bool HasMaterialColorOverride = true; public static Color TRed = new Color(1f, 0f, 0f, 0.75f); public static Color TGreen = new Color(0f, 1f, 0f, 0.75f); public static Color TBlue = new Color(0f, 0.5f, 1f, 0.75f); public static Color TOrange = new Color(1f, 0.5f, 0f, 0.75f); public static Color TYellow = new Color(1f, 1f, 0f, 0.75f); private readonly Queue<LineInstance> _linePool = new Queue<LineInstance>(); private readonly List<LineInstance> _lines = new List<LineInstance>(); private Material _defaultMat; private void Update() { if (!IsEnabled) { return; } float realtimeSinceStartup = Time.realtimeSinceStartup; for (int i = 0; i < _lines.Count; i++) { LineInstance lineInstance = _lines[i]; if (lineInstance.active && realtimeSinceStartup > lineInstance.expiry) { ((Renderer)lineInstance.renderer).enabled = false; lineInstance.active = false; _linePool.Enqueue(lineInstance); } } } public override void OnAwake() { //IL_0028: Unknown result type (might be due to invalid IL or missing references) //IL_002d: Unknown result type (might be due to invalid IL or missing references) //IL_002e: Unknown result type (might be due to invalid IL or missing references) //IL_0038: Unknown result type (might be due to invalid IL or missing references) //IL_0048: Expected O, but got Unknown if ((Object)(object)_defaultMat == (Object)null) { if ((Object)(object)DebugRayMaterial == (Object)null) { Shader val = Shader.Find("Sprites/Default"); _defaultMat = new Material(val) { color = Color.white, renderQueue = 3000 }; } else { _defaultMat = DebugRayMaterial; _defaultMat.renderQueue = 3000; } } } private static void Init() { //IL_0020: Unknown result type (might be due to invalid IL or missing references) //IL_002a: Expected O, but got Unknown if (IsEnabled) { _singletonObject = new GameObject("RuntimeDebugLineDrawer_Singleton", new Type[1] { typeof(RuntimeDebugLineDrawer) }); SingletonBehaviour<RuntimeDebugLineDrawer>.Instance = _singletonObject.GetComponent<RuntimeDebugLineDrawer>(); Object.DontDestroyOnLoad((Object)(object)_singletonObject); } } public static void DrawLine(Vector3 start, Vector3 end, Color color, float duration = 0.1f, float width = 0.04f) { //IL_011f: Unknown result type (might be due to invalid IL or missing references) //IL_012c: Unknown result type (might be due to invalid IL or missing references) //IL_0074: Unknown result type (might be due to invalid IL or missing references) //IL_0079: Unknown result type (might be due to invalid IL or missing references) //IL_0150: Unknown result type (might be due to invalid IL or missing references) //IL_015c: Unknown result type (might be due to invalid IL or missing references) //IL_0144: Unknown result type (might be due to invalid IL or missing references) if (!IsEnabled) { return; } if ((Object)(object)SingletonBehaviour<RuntimeDebugLineDrawer>.Instance == (Object)null) { Init(); } if ((Object)(object)SingletonBehaviour<RuntimeDebugLineDrawer>.Instance == (Object)null || !((Behaviour)SingletonBehaviour<RuntimeDebugLineDrawer>.Instance).isActiveAndEnabled) { return; } LineInstance lineInstance = null; while (SingletonBehaviour<RuntimeDebugLineDrawer>.Instance._linePool.Count > 0 && lineInstance == null) { LineInstance lineInstance2 = SingletonBehaviour<RuntimeDebugLineDrawer>.Instance._linePool.Dequeue(); if (Object.op_Implicit((Object)(object)lineInstance2.renderer)) { lineInstance = lineInstance2; } } if (lineInstance == null) { GameObject val = new GameObject("[DebugLine]"); val.transform.SetParent(((Component)SingletonBehaviour<RuntimeDebugLineDrawer>.Instance).transform, false); LineRenderer val2 = val.AddComponent<LineRenderer>(); ((Renderer)val2).material = SingletonBehaviour<RuntimeDebugLineDrawer>.Instance._defaultMat; val2.positionCount = 2; val2.startWidth = width; val2.endWidth = width; ((Renderer)val2).shadowCastingMode = (ShadowCastingMode)0; ((Renderer)val2).receiveShadows = false; val2.useWorldSpace = true; lineInstance = new LineInstance { renderer = val2 }; SingletonBehaviour<RuntimeDebugLineDrawer>.Instance._lines.Add(lineInstance); } lineInstance.active = true; lineInstance.expiry = Time.realtimeSinceStartup + Mathf.Max(0.016f, duration); ((Renderer)lineInstance.renderer).enabled = true; lineInstance.renderer.SetPosition(0, start); lineInstance.renderer.SetPosition(1, end); if (HasMaterialColorOverride) { ((Renderer)lineInstance.renderer).material.color = color; } lineInstance.renderer.startColor = color; lineInstance.renderer.endColor = color; lineInstance.renderer.startWidth = width; lineInstance.renderer.endWidth = width; } public static void ClearAll() { if ((Object)(object)SingletonBehaviour<RuntimeDebugLineDrawer>.Instance == (Object)null || SingletonBehaviour<RuntimeDebugLineDrawer>.Instance._lines.Count == 0) { return; } foreach (LineInstance line in SingletonBehaviour<RuntimeDebugLineDrawer>.Instance._lines) { if (Object.op_Implicit((Object)(object)line.renderer)) { ((Renderer)line.renderer).enabled = false; } line.active = false; SingletonBehaviour<RuntimeDebugLineDrawer>.Instance._linePool.Enqueue(line); } } } public class SingletonBehaviour<T> : MonoBehaviour where T : SingletonBehaviour<T> { public static T? Instance { get; protected set; } public static event Action? OnPostAwake; public virtual void Awake() { if ((Object)(object)Instance != (Object)null && (Object)(object)Instance != (Object)(object)this) { Object.Destroy((Object)(object)((Component)this).gameObject); return; } Instance = (T)this; Object.DontDestroyOnLoad((Object)(object)((Component)this).gameObject); OnAwake(); SingletonBehaviour<T>.OnPostAwake?.Invoke(); } protected virtual void OnDestroy() { if ((Object)(object)Instance == (Object)(object)this) { Instance = null; } } public virtual void OnAwake() { } } [AttributeUsage(AttributeTargets.Method)] public class MeasureTimeAttribute : Attribute { } public static class TimerUtility { public static void ExecuteWithTiming(Action action, [CallerMemberName] string methodName = "") { } public static void MeasureTimeWithAttribute(object instance, string methodName) { object instance2 = instance; MethodInfo method = instance2.GetType().GetMethod(methodName); if ((object)method != null && method.GetCustomAttribute<MeasureTimeAttribute>() != null) { ExecuteWithTiming(delegate { method.Invoke(instance2, null); }, methodName); } else { method?.Invoke(instance2, null); } } } public class BatchedLogger : MonoBehaviour { private static BatchedLogger? _instance; private static readonly Queue<string> _logQueue = new Queue<string>(); private float _timer; public static bool IsLoggingEnabled { get; set; } = true; [UsedImplicitly] public static float BatchIntervalFrequencyInSeconds { get; set; } = 3f; public static BatchedLogger Instance { get { //IL_000c: Unknown result type (might be due to invalid IL or missing references) //IL_0011: Unknown result type (might be due to invalid IL or missing references) //IL_0021: Expected O, but got Unknown if (_instance == null) { GameObject val = new GameObject("Logger"); _instance = val.AddComponent<BatchedLogger>(); Object.DontDestroyOnLoad((Object)val); } return _instance; } } public void Log(string message) { _logQueue.Enqueue(message); } private void FlushLogs() { while (_logQueue.Count > 0) { LoggerProvider.LogInfoDebounced(_logQueue.Dequeue(), 5f, "C:\\Users\\fre\\dev\\repos\\ValheimMods\\src\\Shared\\Zolantris.Shared\\WithMethodDebugger.cs", 96); } } } } namespace Zolantris.Shared.Debug { public class DebugSafeTimer { private bool _isRunning; private float _elapsedTime; private List<DebugSafeTimer>? _listRef; public float ElapsedMilliseconds => _elapsedTime * 1000f; public static DebugSafeTimer StartNew() { DebugSafeTimer debugSafeTimer = new DebugSafeTimer(); debugSafeTimer.Start(); return debugSafeTimer; } public static DebugSafeTimer StartNew(List<DebugSafeTimer> list) { DebugSafeTimer debugSafeTimer = new DebugSafeTimer(); debugSafeTimer.Start(); list.Add(debugSafeTimer); debugSafeTimer._listRef = list; return debugSafeTimer; } public static void UpdateTimersFromList(List<DebugSafeTimer> list) { if (list.Count == 0) { return; } DebugSafeTimer[] array = list.ToArray(); foreach (DebugSafeTimer debugSafeTimer in array) { if (debugSafeTimer != null) { debugSafeTimer.Update(); } else if (debugSafeTimer == null) { list.Remove(debugSafeTimer); } } } [UsedImplicitly] public void Start() { if (_listRef != null && !_listRef.Contains(this)) { _listRef.Add(this); } _isRunning = true; } [UsedImplicitly] public void Stop() { _isRunning = false; } [UsedImplicitly] public void Reset() { if (_listRef != null && _listRef.Contains(this)) { _listRef.Remove(this); } _elapsedTime = 0f; Stop(); } [UsedImplicitly] public void Restart() { _elapsedTime = 0f; Start(); } [UsedImplicitly] public void Clear() { Reset(); if (_listRef == null) { LoggerProvider.LogDebug("Called delete but listRef did not exist", "C:\\Users\\fre\\dev\\repos\\ValheimMods\\src\\Shared\\Zolantris.Shared\\DebugSafeTimer.cs", 109); } else { _listRef?.Remove(this); } } private void OnUpdateAutoExpire() { if (ElapsedMilliseconds > 20000f) { Clear(); } } [UsedImplicitly] private void Update() { if (_isRunning) { _elapsedTime += Time.deltaTime; } OnUpdateAutoExpire(); } } } namespace Zolantris.Shared.ModIntegrations { public interface IModIntegrationApi { void RunIntegration(); } public static class ConditionalImporter { public static bool ImportConditionally(string modGuid, string targetClass) { Type type = Type.GetType("Namespace.ParentClassName"); if (type != null) { LoggerProvider.LogDebug("Conditional " + modGuid + " found. " + targetClass + " will now run", "C:\\Users\\fre\\dev\\repos\\ValheimMods\\src\\Shared\\Zolantris.Shared\\ConditionalImporter.cs", 20); (Activator.CreateInstance(type) as IModIntegrationApi)?.RunIntegration(); return true; } LoggerProvider.LogDebug("Conditional " + modGuid + " not found. Exiting", "C:\\Users\\fre\\dev\\repos\\ValheimMods\\src\\Shared\\Zolantris.Shared\\ConditionalImporter.cs", 30); return false; } } } namespace Zolantris.Shared.BepInExAutoDoc { public class BepInExConfigAutoDoc { private static readonly Regex ConfigMatchRegExp = new Regex("\\[(.*?)\\]"); public bool runOnDebug = true; public bool runOnRelease; private static string? GetOutputFolderPath(PluginInfo plugin, string autoDocName) { string directoryName = Path.GetDirectoryName(Assembly.GetEntryAssembly()?.Location); string directoryName2 = Path.GetDirectoryName(Assembly.GetExecutingAssembly().Location); LoggerProvider.LogDebug("BepInExConfigAutoDoc: GetOutputFolderPath() " + directoryName, "C:\\Users\\fre\\dev\\repos\\ValheimMods\\src\\Shared\\Zolantris.Shared\\BepInExAutoDoc.cs", 29); LoggerProvider.LogDebug("BepInExConfigAutoDoc: GetOutputFolderPath() executingAssemblyLocation " + directoryName2, "C:\\Users\\fre\\dev\\repos\\ValheimMods\\src\\Shared\\Zolantris.Shared\\BepInExAutoDoc.cs", 31); if (directoryName2 == null) { return null; } return Path.Combine(directoryName2, autoDocName + "_AutoDoc.md"); } private static string StripString(string x) { return ConfigMatchRegExp.Match(x).Groups[1].Value; } private static void AutoWriteBepInExConfigDoc(PluginInfo plugin, ConfigFile Config, string documentName) { StringBuilder stringBuilder = new StringBuilder(); string text = ""; foreach (ConfigDefinition key in Config.Keys) { if (key.Section != text) { text = key.Section; stringBuilder.Append(Environment.NewLine + "## " + key.Section + Environment.NewLine); } stringBuilder.Append(("\n### " + key.Key + " [" + StripString(Config[key].Description.Description) + "]").Replace("[]", "") + Environment.NewLine + "- Description: " + Config[key].Description.Description.Replace("[Synced with Server]", "").Replace("[Not Synced with Server]", "") + $"{Environment.NewLine}- Default Value: {Config[key].DefaultValue}{Environment.NewLine}"); } string outputFolderPath = GetOutputFolderPath(plugin, documentName); if (outputFolderPath != null) { File.WriteAllText(outputFolderPath, stringBuilder.ToString()); } } public void Generate(PluginInfo pluginInfo, ConfigFile configFile, string documentName) { AutoWriteBepInExConfigDoc(pluginInfo, configFile, documentName); } } } namespace Zolantris.Shared.Interfaces { public interface IAnimatorIKRelayReceiver { void OnAnimatorIKRelay(int layerIndex); void OnAnimatorOverride(); } }