* test some refactoring for cachedplayer * rework logging * fix saving of log level --------- Co-authored-by: rootdarkarchon <root.darkarchon@outlook.com>
138 lines
5.7 KiB
C#
138 lines
5.7 KiB
C#
using Dalamud.Configuration;
|
|
using Dalamud.Plugin;
|
|
using MareSynchronos.MareConfiguration.Models;
|
|
using MareSynchronos.WebAPI;
|
|
using Microsoft.Extensions.Logging;
|
|
|
|
namespace MareSynchronos.MareConfiguration.Configurations.Obsolete;
|
|
|
|
[Serializable]
|
|
[Obsolete("Deprecated, use MareConfig")]
|
|
public class Configuration : IPluginConfiguration
|
|
{
|
|
public int Version { get; set; } = 6;
|
|
[NonSerialized]
|
|
private DalamudPluginInterface? _pluginInterface;
|
|
public Dictionary<string, ServerStorageV0> ServerStorage { get; set; } = new(StringComparer.OrdinalIgnoreCase)
|
|
{
|
|
{ ApiController.MainServiceUri, new ServerStorageV0() { ServerName = ApiController.MainServer, ServerUri = ApiController.MainServiceUri } },
|
|
};
|
|
public bool AcceptedAgreement { get; set; } = false;
|
|
public string CacheFolder { get; set; } = string.Empty;
|
|
public double MaxLocalCacheInGiB { get; set; } = 20;
|
|
public bool ReverseUserSort { get; set; } = false;
|
|
public int TimeSpanBetweenScansInSeconds { get; set; } = 30;
|
|
public bool FileScanPaused { get; set; } = false;
|
|
public bool InitialScanComplete { get; set; } = false;
|
|
public bool FullPause { get; set; } = false;
|
|
public bool HideInfoMessages { get; set; } = false;
|
|
public bool DisableOptionalPluginWarnings { get; set; } = false;
|
|
public bool OpenGposeImportOnGposeStart { get; set; } = false;
|
|
public bool ShowTransferWindow { get; set; } = true;
|
|
public bool OpenPopupOnAdd { get; set; } = true;
|
|
public string CurrentServer { get; set; } = string.Empty;
|
|
|
|
private string _apiUri = string.Empty;
|
|
public string ApiUri
|
|
{
|
|
get => string.IsNullOrEmpty(_apiUri) ? ApiController.MainServiceUri : _apiUri;
|
|
set => _apiUri = value;
|
|
}
|
|
public Dictionary<string, string> ClientSecret { get; set; } = new(StringComparer.Ordinal);
|
|
public Dictionary<string, string> CustomServerList { get; set; } = new(StringComparer.Ordinal);
|
|
public Dictionary<string, Dictionary<string, string>> UidServerComments { get; set; } = new(StringComparer.Ordinal);
|
|
public Dictionary<string, Dictionary<string, string>> GidServerComments { get; set; } = new(StringComparer.Ordinal);
|
|
/// <summary>
|
|
/// Each paired user can have multiple tags. Each tag will create a category, and the user will
|
|
/// be displayed into that category.
|
|
/// The dictionary first maps a server URL to a dictionary, and that
|
|
/// dictionary maps the OtherUID of the <see cref="ClientPairDto"/> to a list of tags.
|
|
/// </summary>
|
|
public Dictionary<string, Dictionary<string, List<string>>> UidServerPairedUserTags = new(StringComparer.Ordinal);
|
|
/// <summary>
|
|
/// A dictionary that maps a server URL to the tags the user has added for that server.
|
|
/// </summary>
|
|
public Dictionary<string, HashSet<string>> ServerAvailablePairTags = new(StringComparer.Ordinal);
|
|
public HashSet<string> OpenPairTags = new(StringComparer.Ordinal);
|
|
|
|
|
|
public void Save()
|
|
{
|
|
_pluginInterface!.SavePluginConfig(this);
|
|
}
|
|
|
|
public MareConfigV0 ToMareConfig(ILogger logger)
|
|
{
|
|
|
|
MareConfigV0 newConfig = new();
|
|
logger.LogInformation("Migrating Config to MareConfig");
|
|
|
|
newConfig.AcceptedAgreement = AcceptedAgreement;
|
|
newConfig.CacheFolder = CacheFolder;
|
|
newConfig.MaxLocalCacheInGiB = MaxLocalCacheInGiB;
|
|
newConfig.ReverseUserSort = ReverseUserSort;
|
|
newConfig.TimeSpanBetweenScansInSeconds = TimeSpanBetweenScansInSeconds;
|
|
newConfig.FileScanPaused = FileScanPaused;
|
|
newConfig.InitialScanComplete = InitialScanComplete;
|
|
newConfig.DisableOptionalPluginWarnings = DisableOptionalPluginWarnings;
|
|
newConfig.OpenGposeImportOnGposeStart = OpenGposeImportOnGposeStart;
|
|
newConfig.ShowTransferWindow = ShowTransferWindow;
|
|
newConfig.OpenPopupOnAdd = OpenPopupOnAdd;
|
|
newConfig.CurrentServer = ApiUri;
|
|
|
|
// create all server storage based on current clientsecret
|
|
foreach (var secret in ClientSecret)
|
|
{
|
|
logger.LogDebug("Migrating " + secret.Key);
|
|
var apiuri = secret.Key;
|
|
var secretkey = secret.Value;
|
|
ServerStorageV0 toAdd = new();
|
|
if (string.Equals(apiuri, ApiController.MainServiceUri, StringComparison.OrdinalIgnoreCase))
|
|
{
|
|
toAdd.ServerUri = ApiController.MainServiceUri;
|
|
toAdd.ServerName = ApiController.MainServer;
|
|
}
|
|
else
|
|
{
|
|
toAdd.ServerUri = apiuri;
|
|
if (!CustomServerList.TryGetValue(apiuri, out var serverName)) serverName = apiuri;
|
|
toAdd.ServerName = serverName;
|
|
}
|
|
|
|
toAdd.SecretKeys[0] = new SecretKey()
|
|
{
|
|
FriendlyName = "Auto Migrated Secret Key (" + DateTime.Now.ToString("yyyy-MM-dd") + ")",
|
|
Key = secretkey,
|
|
};
|
|
|
|
if (GidServerComments.TryGetValue(apiuri, out var gids))
|
|
{
|
|
toAdd.GidServerComments = gids;
|
|
}
|
|
if (UidServerComments.TryGetValue(apiuri, out var uids))
|
|
{
|
|
toAdd.UidServerComments = uids;
|
|
}
|
|
if (UidServerPairedUserTags.TryGetValue(apiuri, out var uidtag))
|
|
{
|
|
toAdd.UidServerPairedUserTags = uidtag;
|
|
}
|
|
if (ServerAvailablePairTags.TryGetValue(apiuri, out var servertag))
|
|
{
|
|
toAdd.ServerAvailablePairTags = servertag;
|
|
}
|
|
toAdd.OpenPairTags = OpenPairTags;
|
|
toAdd.FullPause = FullPause;
|
|
|
|
newConfig.ServerStorage[apiuri] = toAdd;
|
|
}
|
|
|
|
return newConfig;
|
|
}
|
|
|
|
public void Migrate()
|
|
{
|
|
|
|
}
|
|
}
|