mirror of
https://github.com/vrcx-team/VRCX.git
synced 2026-04-06 00:32:02 +02:00
* fix: open folder and select item on linux * feat: linux wrist overlay * feat: linux hmd overlay * feat: replace unix sockets with shm on linux * fix: reduce linux wrist overlay fps * fix: hide electron offscreen windows * fix: destroy electron offscreen windows when not in use * fix: open folder and select item on linux * feat: cpu, uptime and device monitoring on linux * feat: native wayland gl context with x11 fallback on linux * fix: use platform agnostic wording for common folders * fix: crash dumps folder button on linux * fix: enable missing VR notification options on linux * fix: update cef, eslint config to include updated AppApiVr names * merge: rebase linux VR changes to upstream * Clean up * Load custom file contents rather than path Fixes loading custom file in debug mode * fix: call SetVR on linux as well * fix: AppApiVrElectron init, properly create and dispose of shm * Handle avatar history error * Lint * Change overlay dispose logic * macOS DOTNET_ROOT * Remove moving dotnet bin * Fix * fix: init overlay on SteamVR restart * Fix fetching empty instance, fix user dialog not fetching * Trim direct access inputs * Make icon higher res, because mac build would fail 😂 * macOS fixes * will it build? that's the question * fix: ensure offscreen windows are ready before vrinit * will it build? that's the question * will it build? that's the question * meow * one, more, time * Fix crash and overlay ellipsis * a --------- Co-authored-by: Natsumi <cmcooper123@hotmail.com>
168 lines
4.6 KiB
C#
168 lines
4.6 KiB
C#
using System;
|
|
using System.Collections.Generic;
|
|
using System.Diagnostics;
|
|
using System.Globalization;
|
|
using System.IO;
|
|
using System.Security.Cryptography;
|
|
using System.Text;
|
|
using librsync.net;
|
|
using Newtonsoft.Json;
|
|
using NLog;
|
|
|
|
namespace VRCX
|
|
{
|
|
public partial class AppApi
|
|
{
|
|
private static readonly Logger logger = LogManager.GetCurrentClassLogger();
|
|
private static readonly MD5 _hasher = MD5.Create();
|
|
|
|
public void Init()
|
|
{
|
|
}
|
|
|
|
public JsonSerializerSettings JsonSerializerSettings = new JsonSerializerSettings
|
|
{
|
|
Error = delegate(object _, Newtonsoft.Json.Serialization.ErrorEventArgs args)
|
|
{
|
|
args.ErrorContext.Handled = true;
|
|
}
|
|
};
|
|
|
|
public string MD5File(string blob)
|
|
{
|
|
var fileData = Convert.FromBase64CharArray(blob.ToCharArray(), 0, blob.Length);
|
|
using var md5 = MD5.Create();
|
|
var md5Hash = md5.ComputeHash(fileData);
|
|
return Convert.ToBase64String(md5Hash);
|
|
}
|
|
|
|
public int GetColourFromUserID(string userId)
|
|
{
|
|
var hash = _hasher.ComputeHash(Encoding.UTF8.GetBytes(userId));
|
|
return (hash[3] << 8) | hash[4];
|
|
}
|
|
|
|
public string SignFile(string blob)
|
|
{
|
|
var fileData = Convert.FromBase64String(blob);
|
|
using var sig = Librsync.ComputeSignature(new MemoryStream(fileData));
|
|
using var memoryStream = new MemoryStream();
|
|
sig.CopyTo(memoryStream);
|
|
var sigBytes = memoryStream.ToArray();
|
|
return Convert.ToBase64String(sigBytes);
|
|
}
|
|
|
|
public string FileLength(string blob)
|
|
{
|
|
var fileData = Convert.FromBase64String(blob);
|
|
return fileData.Length.ToString();
|
|
}
|
|
|
|
public void OpenLink(string url)
|
|
{
|
|
if (url.StartsWith("http://") ||
|
|
url.StartsWith("https://"))
|
|
{
|
|
Process.Start(new ProcessStartInfo(url)
|
|
{
|
|
UseShellExecute = true
|
|
});
|
|
}
|
|
}
|
|
|
|
public string GetLaunchCommand()
|
|
{
|
|
var command = StartupArgs.LaunchArguments.LaunchCommand;
|
|
StartupArgs.LaunchArguments.LaunchCommand = string.Empty;
|
|
return command;
|
|
}
|
|
|
|
public void IPCAnnounceStart()
|
|
{
|
|
IPCServer.Send(new IPCPacket
|
|
{
|
|
Type = "VRCXLaunch",
|
|
MsgType = "VRCXLaunch"
|
|
});
|
|
}
|
|
|
|
public void SendIpc(string type, string data)
|
|
{
|
|
IPCServer.Send(new IPCPacket
|
|
{
|
|
Type = "VrcxMessage",
|
|
MsgType = type,
|
|
Data = data
|
|
});
|
|
}
|
|
|
|
public string CustomCss()
|
|
{
|
|
var filePath = Path.Join(Program.AppDataDirectory, "custom.css");
|
|
if (File.Exists(filePath))
|
|
return File.ReadAllText(filePath);
|
|
|
|
return string.Empty;
|
|
}
|
|
|
|
public string CustomScript()
|
|
{
|
|
var filePath = Path.Join(Program.AppDataDirectory, "custom.js");
|
|
if (File.Exists(filePath))
|
|
return File.ReadAllText(filePath);
|
|
|
|
return string.Empty;
|
|
}
|
|
|
|
public string CurrentCulture()
|
|
{
|
|
var culture = CultureInfo.CurrentCulture.ToString();
|
|
if (string.IsNullOrEmpty(culture))
|
|
culture = "en-US";
|
|
|
|
return culture;
|
|
}
|
|
|
|
public string CurrentLanguage()
|
|
{
|
|
return CultureInfo.InstalledUICulture.Name;
|
|
}
|
|
|
|
public string GetVersion()
|
|
{
|
|
return Program.Version;
|
|
}
|
|
|
|
public bool VrcClosedGracefully()
|
|
{
|
|
return LogWatcher.Instance.VrcClosedGracefully;
|
|
}
|
|
|
|
public Dictionary<string, int> GetColourBulk(List<object> userIds)
|
|
{
|
|
var output = new Dictionary<string, int>();
|
|
foreach (string userId in userIds)
|
|
{
|
|
output.Add(userId, GetColourFromUserID(userId));
|
|
}
|
|
|
|
return output;
|
|
}
|
|
|
|
public void SetAppLauncherSettings(bool enabled, bool killOnExit)
|
|
{
|
|
AutoAppLaunchManager.Instance.Enabled = enabled;
|
|
AutoAppLaunchManager.Instance.KillChildrenOnExit = killOnExit;
|
|
}
|
|
|
|
public string GetFileBase64(string path)
|
|
{
|
|
if (File.Exists(path))
|
|
{
|
|
return Convert.ToBase64String(File.ReadAllBytes(path));
|
|
}
|
|
|
|
return null;
|
|
}
|
|
}
|
|
} |