From 7c1493a4bd10586785d1c8f6f3562288b4b5652e Mon Sep 17 00:00:00 2001
From: gompocp <73906388+gompocp@users.noreply.github.com>
Date: Sat, 21 Aug 2021 14:29:24 +0100
Subject: [PATCH] Remove dependency to make it "Standalone"
---
Directory.Build.props | 5 ---
StandaloneThirdPerson/Main.cs | 17 +++++++--
StandaloneThirdPerson/Utils.cs | 63 +++++++++++++++++++++++++++++++++-
VRChatMods.sln | 7 +---
4 files changed, 77 insertions(+), 15 deletions(-)
diff --git a/Directory.Build.props b/Directory.Build.props
index c4dffba..4cf5038 100644
--- a/Directory.Build.props
+++ b/Directory.Build.props
@@ -126,11 +126,6 @@
false
$(VRChatFolder)\Mods\ActionMenuApi.dll
-
- false
- false
- $(VRChatFolder)\Mods\VRChatUtilityKit.dll
-
false
false
diff --git a/StandaloneThirdPerson/Main.cs b/StandaloneThirdPerson/Main.cs
index 85b8a43..c1d7ae7 100644
--- a/StandaloneThirdPerson/Main.cs
+++ b/StandaloneThirdPerson/Main.cs
@@ -1,6 +1,7 @@
using System;
using System.Collections;
using System.Linq;
+using HarmonyLib;
using MelonLoader;
using UnityEngine;
using Main = StandaloneThirdPerson.Main;
@@ -19,8 +20,8 @@ internal partial class Main : MelonMod
private static Camera vrcCamera;
private static bool initialised;
- private static bool Allowed => VRChatUtilityKit.Utilities.VRCUtils.AreRiskyFunctionsAllowed;
-
+ internal static bool Allowed;
+
public override void OnApplicationStart()
{
//Credits to https://github.com/Psychloor/PlayerRotater/blob/master/PlayerRotater/ModMain.cs#L40 for this vr check
@@ -28,7 +29,6 @@ public override void OnApplicationStart()
ModSettings.RegisterSettings();
ModSettings.LoadSettings();
MelonCoroutines.Start(WaitForUIInit());
- VRChatUtilityKit.Utilities.NetworkEvents.OnRoomJoined += new Action(delegate { currentMode = CameraMode.Normal; });
}
private static IEnumerator WaitForUIInit()
@@ -187,5 +187,16 @@ public override void OnPreferencesSaved()
{
ModSettings.LoadSettings();
}
+
+ [HarmonyPatch(typeof(NetworkManager), "OnJoinedRoom")]
+ internal class OnJoinedRoomPatch
+ {
+ private static void Prefix()
+ {
+ currentMode = CameraMode.Normal;
+ Allowed = false;
+ MelonCoroutines.Start(Utils.CheckWorld());
+ }
+ }
}
}
\ No newline at end of file
diff --git a/StandaloneThirdPerson/Utils.cs b/StandaloneThirdPerson/Utils.cs
index bff6afa..143e625 100644
--- a/StandaloneThirdPerson/Utils.cs
+++ b/StandaloneThirdPerson/Utils.cs
@@ -1,4 +1,11 @@
-namespace StandaloneThirdPerson
+using System;
+using System.Collections;
+using MelonLoader;
+using UnityEngine;
+using UnityEngine.Networking;
+using VRC.Core;
+
+namespace StandaloneThirdPerson
{
public static class Utils
{
@@ -6,5 +13,59 @@ public static bool IsBigMenuOpen()
{
return VRCUiManager.field_Private_Static_VRCUiManager_0.field_Internal_Dictionary_2_String_VRCUiPage_0.Count > 0;
}
+
+
+ // Credits to Psychloor for this: https://github.com/Psychloor/PlayerRotater/blob/master/PlayerRotater/Utilities.cs#L76
+ internal static IEnumerator CheckWorld()
+ {
+ var worldId = RoomManager.field_Internal_Static_ApiWorld_0.id;
+
+ // Check if black/whitelisted from EmmVRC - thanks Emilia and the rest of EmmVRC Staff
+ var uwr = UnityWebRequest.Get($"https://dl.emmvrc.com/riskyfuncs.php?worldid= {worldId}");
+ uwr.SendWebRequest();
+ while (!uwr.isDone)
+ yield return new WaitForEndOfFrame();
+ var result = uwr.m_DownloadHandler.text?.Trim().ToLower();
+ uwr.Dispose();
+ if (!string.IsNullOrWhiteSpace(result))
+ switch (result)
+ {
+ case "allowed":
+ Main.Allowed = true;
+ yield break;
+
+ case "denied":
+ Main.Allowed = false;
+ yield break;
+ }
+
+
+ // no result from server or they're currently down
+ // Check tags then. should also be in cache as it just got downloaded
+ API.Fetch(
+ worldId,
+ new Action(
+ container =>
+ {
+ ApiWorld apiWorld;
+ if ((apiWorld = container.Model.TryCast()) != null)
+ {
+ foreach (var worldTag in apiWorld.tags)
+ if (worldTag.IndexOf("game", StringComparison.OrdinalIgnoreCase) != -1
+ || worldTag.IndexOf("club", StringComparison.OrdinalIgnoreCase) != -1)
+ {
+ Main.Allowed = false;
+ return;
+ }
+
+ Main.Allowed = true;
+ }
+ else
+ {
+ MelonLogger.Error("Failed to cast ApiModel to ApiWorld");
+ }
+ }),
+ disableCache: false);
+ }
}
}
\ No newline at end of file
diff --git a/VRChatMods.sln b/VRChatMods.sln
index f71d5cd..50852a7 100644
--- a/VRChatMods.sln
+++ b/VRChatMods.sln
@@ -14,8 +14,7 @@ Project("{FAE04EC0-301F-11D3-BF4B-00C04F79EFBC}") = "WorldPredownload", "WorldPr
EndProject
Project("{FAE04EC0-301F-11D3-BF4B-00C04F79EFBC}") = "ActionMenuUtils", "ActionMenuUtils\ActionMenuUtils.csproj", "{7477F0C4-44AC-4049-A81E-E6A66F28B73C}"
EndProject
-Project("{FAE04EC0-301F-11D3-BF4B-00C04F79EFBC}") = "DownloadFix", "DownloadFix\DownloadFix.csproj", "{F61964B1-1EE3-4AB1-9FC7-3456CCE5DEA8}"
-EndProject
+
Project("{FAE04EC0-301F-11D3-BF4B-00C04F79EFBC}") = "IntegrityCheckWeaver", "IntegrityCheckWeaver\IntegrityCheckWeaver.csproj", "{1FEBBC75-FCE2-45A6-B26A-135324F33FF1}"
EndProject
Project("{FAE04EC0-301F-11D3-BF4B-00C04F79EFBC}") = "IntegrityCheckGenerator", "IntegrityCheckGenerator\IntegrityCheckGenerator.csproj", "{E2E254FC-EBB1-4F5D-B2F3-26FAED02B77F}"
@@ -37,10 +36,6 @@ Global
{7477F0C4-44AC-4049-A81E-E6A66F28B73C}.Debug|Any CPU.Build.0 = Debug|Any CPU
{7477F0C4-44AC-4049-A81E-E6A66F28B73C}.Release|Any CPU.ActiveCfg = Release|Any CPU
{7477F0C4-44AC-4049-A81E-E6A66F28B73C}.Release|Any CPU.Build.0 = Release|Any CPU
- {F61964B1-1EE3-4AB1-9FC7-3456CCE5DEA8}.Debug|Any CPU.ActiveCfg = Debug|Any CPU
- {F61964B1-1EE3-4AB1-9FC7-3456CCE5DEA8}.Debug|Any CPU.Build.0 = Debug|Any CPU
- {F61964B1-1EE3-4AB1-9FC7-3456CCE5DEA8}.Release|Any CPU.ActiveCfg = Release|Any CPU
- {F61964B1-1EE3-4AB1-9FC7-3456CCE5DEA8}.Release|Any CPU.Build.0 = Release|Any CPU
{1FEBBC75-FCE2-45A6-B26A-135324F33FF1}.Debug|Any CPU.ActiveCfg = Debug|Any CPU
{1FEBBC75-FCE2-45A6-B26A-135324F33FF1}.Debug|Any CPU.Build.0 = Debug|Any CPU
{1FEBBC75-FCE2-45A6-B26A-135324F33FF1}.Release|Any CPU.ActiveCfg = Release|Any CPU