Dalamud/Dalamud/Troubleshooting.cs

105 lines
3.5 KiB
C#

using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using Dalamud.Configuration;
using Dalamud.Plugin.Internal.Types;
using Dalamud.Utility;
using Newtonsoft.Json;
using Serilog;
namespace Dalamud
{
/// <summary>
/// Class responsible for printing troubleshooting information to the log.
/// </summary>
public static class Troubleshooting
{
/// <summary>
/// Log the last exception in a parseable format to serilog.
/// </summary>
/// <param name="exception">The exception to log.</param>
/// <param name="context">Additional context.</param>
public static void LogException(Exception exception, string context)
{
try
{
var payload = new ExceptionPayload
{
Context = context,
When = DateTime.Now,
Info = exception.ToString(),
};
var encodedPayload = Convert.ToBase64String(Encoding.UTF8.GetBytes(JsonConvert.SerializeObject(payload)));
Log.Information($"LASTEXCEPTION:{encodedPayload}");
}
catch (Exception ex)
{
Log.Error(ex, "Could not print exception.");
}
}
/// <summary>
/// Log troubleshooting information in a parseable format to Serilog.
/// </summary>
/// <param name="dalamud">The <see cref="Dalamud"/> instance to read information from.</param>
/// <param name="isInterfaceLoaded">Whether or not the interface was loaded.</param>
internal static void LogTroubleshooting(Dalamud dalamud, bool isInterfaceLoaded)
{
try
{
var payload = new TroubleshootingPayload
{
LoadedPlugins = dalamud.PluginManager.InstalledPlugins.Select(x => x.Manifest).ToArray(),
DalamudVersion = Util.AssemblyVersion,
DalamudGitHash = Util.GetGitHash(),
GameVersion = dalamud.StartInfo.GameVersion.ToString(),
Language = dalamud.StartInfo.Language.ToString(),
DoDalamudTest = dalamud.Configuration.DoDalamudTest,
DoPluginTest = dalamud.Configuration.DoPluginTest,
InterfaceLoaded = isInterfaceLoaded,
ThirdRepo = dalamud.Configuration.ThirdRepoList,
};
var encodedPayload = Convert.ToBase64String(Encoding.UTF8.GetBytes(JsonConvert.SerializeObject(payload)));
Log.Information($"TROUBLESHOOTING:{encodedPayload}");
}
catch (Exception ex)
{
Log.Error(ex, "Could not print troubleshooting.");
}
}
private class ExceptionPayload
{
public DateTime When { get; set; }
public string Info { get; set; }
public string Context { get; set; }
}
private class TroubleshootingPayload
{
public PluginManifest[] LoadedPlugins { get; set; }
public string DalamudVersion { get; set; }
public string DalamudGitHash { get; set; }
public string GameVersion { get; set; }
public string Language { get; set; }
public bool DoDalamudTest { get; set; }
public bool DoPluginTest { get; set; }
public bool InterfaceLoaded { get; set; }
public List<ThirdPartyRepoSettings> ThirdRepo { get; set; }
}
}
}