forked from liza/Influx
Fix IPC, refactor IPC class
This commit is contained in:
parent
24879ccdb9
commit
0457a86239
106
Influx/AllaganTools/AllaganToolsIpc.cs
Normal file
106
Influx/AllaganTools/AllaganToolsIpc.cs
Normal file
@ -0,0 +1,106 @@
|
||||
using System;
|
||||
using System.Collections.Generic;
|
||||
using System.Linq;
|
||||
using Dalamud.Game.Gui;
|
||||
using Dalamud.Logging;
|
||||
using Dalamud.Plugin;
|
||||
using Dalamud.Plugin.Ipc;
|
||||
using Dalamud.Plugin.Ipc.Exceptions;
|
||||
using ECommons.Reflection;
|
||||
|
||||
namespace Influx.AllaganTools;
|
||||
|
||||
internal sealed class AllaganToolsIpc : IDisposable
|
||||
{
|
||||
private readonly DalamudPluginInterface _pluginInterface;
|
||||
private readonly ChatGui _chatGui;
|
||||
private readonly Configuration _configuration;
|
||||
private readonly ICallGateSubscriber<bool, bool>? _initalized;
|
||||
private readonly ICallGateSubscriber<bool>? _isInitialized;
|
||||
|
||||
public ICharacterMonitor Characters { get; private set; } = new UnavailableCharacterMonitor();
|
||||
public IInventoryMonitor Inventories { get; private set; } = new UnavailableInventoryMonitor();
|
||||
|
||||
public AllaganToolsIpc(DalamudPluginInterface pluginInterface, ChatGui chatGui, Configuration configuration)
|
||||
{
|
||||
_pluginInterface = pluginInterface;
|
||||
_chatGui = chatGui;
|
||||
_configuration = configuration;
|
||||
|
||||
_initalized = _pluginInterface.GetIpcSubscriber<bool, bool>("AllaganTools.Initialized");
|
||||
_isInitialized = _pluginInterface.GetIpcSubscriber<bool>("AllaganTools.IsInitialized");
|
||||
_initalized.Subscribe(ConfigureIpc);
|
||||
|
||||
try
|
||||
{
|
||||
bool isInitialized = _isInitialized.InvokeFunc();
|
||||
if (isInitialized)
|
||||
ConfigureIpc(true);
|
||||
}
|
||||
catch (IpcNotReadyError e)
|
||||
{
|
||||
PluginLog.Debug(e, "Not initializing ATools yet");
|
||||
}
|
||||
}
|
||||
|
||||
private void ConfigureIpc(bool initialized)
|
||||
{
|
||||
try
|
||||
{
|
||||
if (DalamudReflector.TryGetDalamudPlugin("Allagan Tools", out var it, false, true) &&
|
||||
_isInitialized != null && _isInitialized.InvokeFunc())
|
||||
{
|
||||
var pluginService = it.GetType().Assembly.GetType("InventoryTools.PluginService")!;
|
||||
|
||||
Characters = new CharacterMonitor(pluginService.GetProperty("CharacterMonitor")!.GetValue(null)!);
|
||||
Inventories = new InventoryMonitor(
|
||||
pluginService.GetProperty("InventoryMonitor")!.GetValue(null)!);
|
||||
}
|
||||
}
|
||||
catch (Exception e)
|
||||
{
|
||||
PluginLog.Error(e, "Could not initialize IPC");
|
||||
_chatGui.PrintError(e.ToString());
|
||||
}
|
||||
}
|
||||
|
||||
public Dictionary<Character, Currencies> CountCurrencies()
|
||||
{
|
||||
var characters = Characters.All.ToDictionary(x => x.CharacterId, x => x);
|
||||
return Inventories.All
|
||||
.Where(x => !_configuration.ExcludedCharacters.Contains(x.Key))
|
||||
.ToDictionary(
|
||||
x => characters[x.Value.CharacterId],
|
||||
y =>
|
||||
{
|
||||
var inv = new InventoryWrapper(y.Value.GetAllItems());
|
||||
return new Currencies
|
||||
{
|
||||
Gil = inv.Sum(1),
|
||||
FcCredits = inv.Sum(80),
|
||||
Ventures = inv.Sum(21072),
|
||||
CeruleumTanks = inv.Sum(10155),
|
||||
RepairKits = inv.Sum(10373),
|
||||
};
|
||||
});
|
||||
}
|
||||
|
||||
public void Dispose()
|
||||
{
|
||||
_initalized?.Unsubscribe(ConfigureIpc);
|
||||
Characters = new UnavailableCharacterMonitor();
|
||||
Inventories = new UnavailableInventoryMonitor();
|
||||
}
|
||||
|
||||
private sealed class InventoryWrapper
|
||||
{
|
||||
private readonly IEnumerable<InventoryItem> _items;
|
||||
|
||||
public InventoryWrapper(IEnumerable<InventoryItem> items)
|
||||
{
|
||||
_items = items;
|
||||
}
|
||||
|
||||
public long Sum(int itemId) => _items.Where(x => x.ItemId == itemId).Sum(x => x.Quantity);
|
||||
}
|
||||
}
|
26
Influx/AllaganTools/Character.cs
Normal file
26
Influx/AllaganTools/Character.cs
Normal file
@ -0,0 +1,26 @@
|
||||
using System.Reflection;
|
||||
|
||||
namespace Influx.AllaganTools;
|
||||
|
||||
internal sealed class Character
|
||||
{
|
||||
private readonly object _delegate;
|
||||
private readonly FieldInfo _name;
|
||||
|
||||
public Character(object @delegate)
|
||||
{
|
||||
_delegate = @delegate;
|
||||
_name = _delegate.GetType().GetField("Name")!;
|
||||
|
||||
CharacterId = (ulong)_delegate.GetType().GetField("CharacterId")!.GetValue(_delegate)!;
|
||||
CharacterType = (CharacterType)_delegate.GetType().GetProperty("CharacterType")!.GetValue(_delegate)!;
|
||||
OwnerId = (ulong)_delegate.GetType().GetField("OwnerId")!.GetValue(_delegate)!;
|
||||
FreeCompanyId = (ulong)_delegate.GetType().GetField("FreeCompanyId")!.GetValue(_delegate)!;
|
||||
}
|
||||
|
||||
public ulong CharacterId { get; }
|
||||
public CharacterType CharacterType { get; }
|
||||
public ulong OwnerId { get; }
|
||||
public ulong FreeCompanyId { get; }
|
||||
public string Name => (string)_name.GetValue(_delegate)!;
|
||||
}
|
33
Influx/AllaganTools/CharacterMonitor.cs
Normal file
33
Influx/AllaganTools/CharacterMonitor.cs
Normal file
@ -0,0 +1,33 @@
|
||||
using System;
|
||||
using System.Collections;
|
||||
using System.Collections.Generic;
|
||||
using System.Linq;
|
||||
using System.Reflection;
|
||||
|
||||
namespace Influx.AllaganTools;
|
||||
|
||||
internal sealed class CharacterMonitor : ICharacterMonitor
|
||||
{
|
||||
private readonly object _delegate;
|
||||
private readonly MethodInfo _getPlayerCharacters;
|
||||
private readonly MethodInfo _allCharacters;
|
||||
|
||||
public CharacterMonitor(object @delegate)
|
||||
{
|
||||
_delegate = @delegate;
|
||||
_getPlayerCharacters = _delegate.GetType().GetMethod("GetPlayerCharacters")!;
|
||||
_allCharacters = _delegate.GetType().GetMethod("AllCharacters")!;
|
||||
}
|
||||
|
||||
public IEnumerable<Character> PlayerCharacters => GetCharactersInternal(_getPlayerCharacters);
|
||||
public IEnumerable<Character> All => GetCharactersInternal(_allCharacters);
|
||||
|
||||
private IEnumerable<Character> GetCharactersInternal(MethodInfo methodInfo)
|
||||
{
|
||||
return ((IEnumerable)methodInfo.Invoke(_delegate, Array.Empty<object>())!)
|
||||
.Cast<object>()
|
||||
.Select(x => x.GetType().GetProperty("Value")!.GetValue(x)!)
|
||||
.Select(x => new Character(x))
|
||||
.ToList();
|
||||
}
|
||||
}
|
10
Influx/AllaganTools/CharacterType.cs
Normal file
10
Influx/AllaganTools/CharacterType.cs
Normal file
@ -0,0 +1,10 @@
|
||||
namespace Influx.AllaganTools;
|
||||
|
||||
internal enum CharacterType
|
||||
{
|
||||
Character,
|
||||
Retainer,
|
||||
FreeCompanyChest,
|
||||
Housing,
|
||||
Unknown,
|
||||
}
|
11
Influx/AllaganTools/Currencies.cs
Normal file
11
Influx/AllaganTools/Currencies.cs
Normal file
@ -0,0 +1,11 @@
|
||||
namespace Influx.AllaganTools;
|
||||
|
||||
internal struct Currencies
|
||||
{
|
||||
public long Gil { get; init; }
|
||||
public long GcSeals { get; init; }
|
||||
public long FcCredits { get; init; }
|
||||
public long Ventures { get; init; }
|
||||
public long CeruleumTanks { get; init; }
|
||||
public long RepairKits { get; init; }
|
||||
}
|
9
Influx/AllaganTools/ICharacterMonitor.cs
Normal file
9
Influx/AllaganTools/ICharacterMonitor.cs
Normal file
@ -0,0 +1,9 @@
|
||||
using System.Collections.Generic;
|
||||
|
||||
namespace Influx.AllaganTools;
|
||||
|
||||
internal interface ICharacterMonitor
|
||||
{
|
||||
IEnumerable<Character> PlayerCharacters { get; }
|
||||
IEnumerable<Character> All { get; }
|
||||
}
|
8
Influx/AllaganTools/IInventoryMonitor.cs
Normal file
8
Influx/AllaganTools/IInventoryMonitor.cs
Normal file
@ -0,0 +1,8 @@
|
||||
using System.Collections.Generic;
|
||||
|
||||
namespace Influx.AllaganTools;
|
||||
|
||||
internal interface IInventoryMonitor
|
||||
{
|
||||
public IReadOnlyDictionary<ulong, Inventory> All { get; }
|
||||
}
|
29
Influx/AllaganTools/Inventory.cs
Normal file
29
Influx/AllaganTools/Inventory.cs
Normal file
@ -0,0 +1,29 @@
|
||||
using System;
|
||||
using System.Collections;
|
||||
using System.Collections.Generic;
|
||||
using System.Linq;
|
||||
using System.Reflection;
|
||||
|
||||
namespace Influx.AllaganTools;
|
||||
|
||||
internal sealed class Inventory
|
||||
{
|
||||
private readonly object _delegate;
|
||||
private readonly MethodInfo _getAllInventories;
|
||||
|
||||
public Inventory(object @delegate)
|
||||
{
|
||||
_delegate = @delegate;
|
||||
_getAllInventories = _delegate.GetType().GetMethod("GetAllInventories")!;
|
||||
CharacterId = (ulong)_delegate.GetType().GetProperty("CharacterId")!.GetValue(_delegate)!;
|
||||
}
|
||||
|
||||
public ulong CharacterId { get; }
|
||||
|
||||
public IEnumerable<InventoryItem> GetAllItems() =>
|
||||
((IEnumerable)_getAllInventories.Invoke(_delegate, Array.Empty<object>())!)
|
||||
.Cast<IEnumerable>()
|
||||
.SelectMany(x => x.Cast<object>())
|
||||
.Select(x => new InventoryItem(x))
|
||||
.ToList();
|
||||
}
|
16
Influx/AllaganTools/InventoryItem.cs
Normal file
16
Influx/AllaganTools/InventoryItem.cs
Normal file
@ -0,0 +1,16 @@
|
||||
namespace Influx.AllaganTools;
|
||||
|
||||
internal sealed class InventoryItem
|
||||
{
|
||||
private readonly object _delegate;
|
||||
|
||||
public InventoryItem(object @delegate)
|
||||
{
|
||||
_delegate = @delegate;
|
||||
ItemId = (uint)_delegate.GetType().GetField("ItemId")!.GetValue(_delegate)!;
|
||||
Quantity = (uint)_delegate.GetType().GetField("Quantity")!.GetValue(_delegate)!;
|
||||
}
|
||||
|
||||
public uint ItemId { get; }
|
||||
public uint Quantity { get; }
|
||||
}
|
25
Influx/AllaganTools/InventoryMonitor.cs
Normal file
25
Influx/AllaganTools/InventoryMonitor.cs
Normal file
@ -0,0 +1,25 @@
|
||||
using System.Collections;
|
||||
using System.Collections.Generic;
|
||||
using System.Linq;
|
||||
using System.Reflection;
|
||||
|
||||
namespace Influx.AllaganTools;
|
||||
|
||||
internal sealed class InventoryMonitor : IInventoryMonitor
|
||||
{
|
||||
private readonly object _delegate;
|
||||
private readonly PropertyInfo _inventories;
|
||||
|
||||
public InventoryMonitor(object @delegate)
|
||||
{
|
||||
_delegate = @delegate;
|
||||
_inventories = _delegate.GetType().GetProperty("Inventories")!;
|
||||
}
|
||||
|
||||
public IReadOnlyDictionary<ulong, Inventory> All =>
|
||||
((IEnumerable)_inventories.GetValue(_delegate)!)
|
||||
.Cast<object>()
|
||||
.Select(x => x.GetType().GetProperty("Value")!.GetValue(x)!)
|
||||
.Select(x => new Inventory(x))
|
||||
.ToDictionary(x => x.CharacterId, x => x);
|
||||
}
|
10
Influx/AllaganTools/UnavailableCharacterMonitor.cs
Normal file
10
Influx/AllaganTools/UnavailableCharacterMonitor.cs
Normal file
@ -0,0 +1,10 @@
|
||||
using System;
|
||||
using System.Collections.Generic;
|
||||
|
||||
namespace Influx.AllaganTools;
|
||||
|
||||
internal sealed class UnavailableCharacterMonitor : ICharacterMonitor
|
||||
{
|
||||
public IEnumerable<Character> PlayerCharacters => Array.Empty<Character>();
|
||||
public IEnumerable<Character> All => Array.Empty<Character>();
|
||||
}
|
8
Influx/AllaganTools/UnavailableInventoryMonitor.cs
Normal file
8
Influx/AllaganTools/UnavailableInventoryMonitor.cs
Normal file
@ -0,0 +1,8 @@
|
||||
using System.Collections.Generic;
|
||||
|
||||
namespace Influx.AllaganTools;
|
||||
|
||||
internal sealed class UnavailableInventoryMonitor : IInventoryMonitor
|
||||
{
|
||||
public IReadOnlyDictionary<ulong, Inventory> All => new Dictionary<ulong, Inventory>();
|
||||
}
|
@ -1,219 +0,0 @@
|
||||
using System;
|
||||
using System.Collections;
|
||||
using System.Collections.Generic;
|
||||
using System.Linq;
|
||||
using System.Reflection;
|
||||
using Dalamud.Game.ClientState;
|
||||
using Dalamud.Game.Gui;
|
||||
using Dalamud.Plugin;
|
||||
using Dalamud.Plugin.Ipc;
|
||||
using ECommons.Reflection;
|
||||
|
||||
namespace Influx;
|
||||
|
||||
internal sealed class AllaganToolsIPC : IDisposable
|
||||
{
|
||||
private readonly DalamudPluginInterface _pluginInterface;
|
||||
private readonly ChatGui _chatGui;
|
||||
private readonly Configuration _configuration;
|
||||
private readonly ICallGateSubscriber<bool, bool>? _initalized;
|
||||
private readonly ICallGateSubscriber<bool>? _isInitialized;
|
||||
|
||||
public CharacterMonitor Characters { get; private set; }
|
||||
public InventoryMonitor Inventories { get; private set; }
|
||||
|
||||
public AllaganToolsIPC(DalamudPluginInterface pluginInterface, ChatGui chatGui, Configuration configuration)
|
||||
{
|
||||
_pluginInterface = pluginInterface;
|
||||
_chatGui = chatGui;
|
||||
_configuration = configuration;
|
||||
|
||||
_initalized = _pluginInterface.GetIpcSubscriber<bool, bool>("AllaganTools.Initialized");
|
||||
_isInitialized = _pluginInterface.GetIpcSubscriber<bool>("AllaganTools.IsInitialized");
|
||||
_initalized.Subscribe(ConfigureIpc);
|
||||
|
||||
ConfigureIpc(true);
|
||||
}
|
||||
|
||||
private void ConfigureIpc(bool initialized)
|
||||
{
|
||||
try
|
||||
{
|
||||
if (DalamudReflector.TryGetDalamudPlugin("Allagan Tools", out var it, false, true) &&
|
||||
_isInitialized != null && _isInitialized.InvokeFunc())
|
||||
{
|
||||
var pluginService = it.GetType().Assembly.GetType("InventoryTools.PluginService")!;
|
||||
|
||||
Characters = new CharacterMonitor(pluginService.GetProperty("CharacterMonitor")!.GetValue(null)!);
|
||||
Inventories = new InventoryMonitor(
|
||||
pluginService.GetProperty("InventoryMonitor")!.GetValue(null)!);
|
||||
}
|
||||
}
|
||||
catch (Exception e)
|
||||
{
|
||||
_chatGui.PrintError(e.ToString());
|
||||
}
|
||||
}
|
||||
|
||||
public Dictionary<Character, Currencies> CountCurrencies()
|
||||
{
|
||||
var characters = Characters.All.ToDictionary(x => x.CharacterId, x => x);
|
||||
return Inventories.All
|
||||
.Where(x => !_configuration.ExcludedCharacters.Contains(x.Key))
|
||||
.ToDictionary(
|
||||
x => characters[x.Value.CharacterId],
|
||||
y =>
|
||||
{
|
||||
var inv = new InventoryWrapper(y.Value.GetAllItems());
|
||||
return new Currencies
|
||||
{
|
||||
Gil = inv.Sum(1),
|
||||
FcCredits = inv.Sum(80),
|
||||
Ventures = inv.Sum(21072),
|
||||
CeruleumTanks = inv.Sum(10155),
|
||||
RepairKits = inv.Sum(10373),
|
||||
};
|
||||
});
|
||||
}
|
||||
|
||||
public void Dispose()
|
||||
{
|
||||
_initalized?.Unsubscribe(ConfigureIpc);
|
||||
}
|
||||
|
||||
public class CharacterMonitor
|
||||
{
|
||||
private readonly object _delegate;
|
||||
private readonly MethodInfo _getPlayerCharacters;
|
||||
private readonly MethodInfo _allCharacters;
|
||||
|
||||
public CharacterMonitor(object @delegate)
|
||||
{
|
||||
_delegate = @delegate;
|
||||
_getPlayerCharacters = _delegate.GetType().GetMethod("GetPlayerCharacters")!;
|
||||
_allCharacters = _delegate.GetType().GetMethod("AllCharacters")!;
|
||||
}
|
||||
|
||||
public IEnumerable<Character> PlayerCharacters => GetCharactersInternal(_getPlayerCharacters);
|
||||
public IEnumerable<Character> All => GetCharactersInternal(_allCharacters);
|
||||
|
||||
private IEnumerable<Character> GetCharactersInternal(MethodInfo methodInfo)
|
||||
{
|
||||
return ((IEnumerable)methodInfo.Invoke(_delegate, Array.Empty<object>())!)
|
||||
.Cast<object>()
|
||||
.Select(x => x.GetType().GetProperty("Value")!.GetValue(x)!)
|
||||
.Select(x => new Character(x))
|
||||
.ToList();
|
||||
}
|
||||
}
|
||||
|
||||
public class Character
|
||||
{
|
||||
private readonly object _delegate;
|
||||
private readonly FieldInfo _name;
|
||||
|
||||
public Character(object @delegate)
|
||||
{
|
||||
_delegate = @delegate;
|
||||
_name = _delegate.GetType().GetField("Name")!;
|
||||
|
||||
CharacterId = (ulong)_delegate.GetType().GetField("CharacterId")!.GetValue(_delegate)!;
|
||||
CharacterType = (CharacterType)_delegate.GetType().GetProperty("CharacterType")!.GetValue(_delegate)!;
|
||||
OwnerId = (ulong)_delegate.GetType().GetField("OwnerId")!.GetValue(_delegate)!;
|
||||
FreeCompanyId = (ulong)_delegate.GetType().GetField("FreeCompanyId")!.GetValue(_delegate)!;
|
||||
}
|
||||
|
||||
public ulong CharacterId { get; }
|
||||
public CharacterType CharacterType { get; }
|
||||
public ulong OwnerId { get; }
|
||||
public ulong FreeCompanyId { get; }
|
||||
public string Name => (string)_name.GetValue(_delegate)!;
|
||||
}
|
||||
|
||||
public enum CharacterType
|
||||
{
|
||||
Character,
|
||||
Retainer,
|
||||
FreeCompanyChest,
|
||||
Housing,
|
||||
Unknown,
|
||||
}
|
||||
|
||||
public struct Currencies
|
||||
{
|
||||
public long Gil { get; init; }
|
||||
public long GcSeals { get; init; }
|
||||
public long FcCredits { get; init; }
|
||||
public long Ventures { get; init; }
|
||||
public long CeruleumTanks { get; init; }
|
||||
public long RepairKits { get; init; }
|
||||
}
|
||||
|
||||
public sealed class InventoryMonitor
|
||||
{
|
||||
private readonly object _delegate;
|
||||
private readonly PropertyInfo _inventories;
|
||||
|
||||
public InventoryMonitor(object @delegate)
|
||||
{
|
||||
_delegate = @delegate;
|
||||
_inventories = _delegate.GetType().GetProperty("Inventories")!;
|
||||
}
|
||||
|
||||
public IReadOnlyDictionary<ulong, Inventory> All =>
|
||||
((IEnumerable)_inventories.GetValue(_delegate)!)
|
||||
.Cast<object>()
|
||||
.Select(x => x.GetType().GetProperty("Value")!.GetValue(x)!)
|
||||
.Select(x => new Inventory(x))
|
||||
.ToDictionary(x => x.CharacterId, x => x);
|
||||
}
|
||||
|
||||
public sealed class Inventory
|
||||
{
|
||||
private readonly object _delegate;
|
||||
private readonly MethodInfo _getAllInventories;
|
||||
|
||||
public Inventory(object @delegate)
|
||||
{
|
||||
_delegate = @delegate;
|
||||
_getAllInventories = _delegate.GetType().GetMethod("GetAllInventories")!;
|
||||
CharacterId = (ulong)_delegate.GetType().GetProperty("CharacterId")!.GetValue(_delegate)!;
|
||||
}
|
||||
|
||||
public ulong CharacterId { get; }
|
||||
|
||||
public IEnumerable<InventoryItem> GetAllItems() =>
|
||||
((IEnumerable)_getAllInventories.Invoke(_delegate, Array.Empty<object>())!)
|
||||
.Cast<IEnumerable>()
|
||||
.SelectMany(x => x.Cast<object>())
|
||||
.Select(x => new InventoryItem(x))
|
||||
.ToList();
|
||||
}
|
||||
|
||||
public sealed class InventoryItem
|
||||
{
|
||||
private readonly object _delegate;
|
||||
|
||||
public InventoryItem(object @delegate)
|
||||
{
|
||||
_delegate = @delegate;
|
||||
ItemId = (uint)_delegate.GetType().GetField("ItemId")!.GetValue(_delegate)!;
|
||||
Quantity = (uint)_delegate.GetType().GetField("Quantity")!.GetValue(_delegate)!;
|
||||
}
|
||||
|
||||
public uint ItemId { get; }
|
||||
public uint Quantity { get; }
|
||||
}
|
||||
|
||||
public sealed class InventoryWrapper
|
||||
{
|
||||
private readonly IEnumerable<InventoryItem> _items;
|
||||
|
||||
public InventoryWrapper(IEnumerable<InventoryItem> items)
|
||||
{
|
||||
_items = items;
|
||||
}
|
||||
|
||||
public long Sum(int itemId) => _items.Where(x => x.ItemId == itemId).Sum(x => x.Quantity);
|
||||
}
|
||||
}
|
@ -4,6 +4,7 @@ using System.Linq;
|
||||
using System.Threading;
|
||||
using System.Threading.Tasks;
|
||||
using Dalamud.Game.Gui;
|
||||
using Influx.AllaganTools;
|
||||
using InfluxDB.Client;
|
||||
using InfluxDB.Client.Api.Domain;
|
||||
using InfluxDB.Client.Writes;
|
||||
@ -36,10 +37,10 @@ internal class InfluxStatisticsClient : IDisposable
|
||||
return;
|
||||
|
||||
DateTime date = DateTime.UtcNow;
|
||||
IReadOnlyDictionary<AllaganToolsIPC.Character, AllaganToolsIPC.Currencies> stats = update.Currencies;
|
||||
IReadOnlyDictionary<Character, Currencies> stats = update.Currencies;
|
||||
|
||||
var validFcIds = stats.Keys
|
||||
.Where(x => x.CharacterType == AllaganToolsIPC.CharacterType.Character)
|
||||
.Where(x => x.CharacterType == CharacterType.Character)
|
||||
.Select(x => x.FreeCompanyId)
|
||||
.ToList();
|
||||
Task.Run(async () =>
|
||||
@ -49,7 +50,7 @@ internal class InfluxStatisticsClient : IDisposable
|
||||
List<PointData> values = new();
|
||||
foreach (var (character, currencies) in stats)
|
||||
{
|
||||
if (character.CharacterType == AllaganToolsIPC.CharacterType.Character)
|
||||
if (character.CharacterType == CharacterType.Character)
|
||||
{
|
||||
values.Add(PointData.Measurement("currency")
|
||||
.Tag("id", character.CharacterId.ToString())
|
||||
@ -61,7 +62,7 @@ internal class InfluxStatisticsClient : IDisposable
|
||||
.Field("repair_kits", currencies.RepairKits)
|
||||
.Timestamp(date, WritePrecision.S));
|
||||
}
|
||||
else if (character.CharacterType == AllaganToolsIPC.CharacterType.Retainer)
|
||||
else if (character.CharacterType == CharacterType.Retainer)
|
||||
{
|
||||
var owner = stats.Keys.First(x => x.CharacterId == character.OwnerId);
|
||||
values.Add(PointData.Measurement("currency")
|
||||
@ -74,7 +75,7 @@ internal class InfluxStatisticsClient : IDisposable
|
||||
.Field("repair_kits", currencies.RepairKits)
|
||||
.Timestamp(date, WritePrecision.S));
|
||||
}
|
||||
else if (character.CharacterType == AllaganToolsIPC.CharacterType.FreeCompanyChest &&
|
||||
else if (character.CharacterType == CharacterType.FreeCompanyChest &&
|
||||
validFcIds.Contains(character.CharacterId))
|
||||
{
|
||||
values.Add(PointData.Measurement("currency")
|
||||
|
@ -1,9 +1,6 @@
|
||||
using System;
|
||||
using System.Collections.Generic;
|
||||
using System.Diagnostics.CodeAnalysis;
|
||||
using System.Linq;
|
||||
using System.Threading;
|
||||
using System.Threading.Tasks;
|
||||
using Dalamud.Game.ClientState;
|
||||
using Dalamud.Game.Command;
|
||||
using Dalamud.Game.Gui;
|
||||
@ -11,11 +8,9 @@ using Dalamud.Interface.Windowing;
|
||||
using Dalamud.Logging;
|
||||
using Dalamud.Plugin;
|
||||
using ECommons;
|
||||
using Influx.AllaganTools;
|
||||
using Influx.Influx;
|
||||
using Influx.Windows;
|
||||
using InfluxDB.Client;
|
||||
using InfluxDB.Client.Api.Domain;
|
||||
using InfluxDB.Client.Writes;
|
||||
|
||||
namespace Influx;
|
||||
|
||||
@ -28,7 +23,7 @@ public class InfluxPlugin : IDalamudPlugin
|
||||
private readonly Configuration _configuration;
|
||||
private readonly ClientState _clientState;
|
||||
private readonly CommandManager _commandManager;
|
||||
private readonly AllaganToolsIPC _allaganToolsIpc;
|
||||
private readonly AllaganToolsIpc _allaganToolsIpc;
|
||||
private readonly InfluxStatisticsClient _influxStatisticsClient;
|
||||
private readonly WindowSystem _windowSystem;
|
||||
private readonly StatisticsWindow _statisticsWindow;
|
||||
@ -44,7 +39,7 @@ public class InfluxPlugin : IDalamudPlugin
|
||||
_configuration = LoadConfig();
|
||||
_clientState = clientState;
|
||||
_commandManager = commandManager;
|
||||
_allaganToolsIpc = new AllaganToolsIPC(pluginInterface, chatGui, _configuration);
|
||||
_allaganToolsIpc = new AllaganToolsIpc(pluginInterface, chatGui, _configuration);
|
||||
_influxStatisticsClient = new InfluxStatisticsClient(chatGui, _configuration);
|
||||
|
||||
_windowSystem = new WindowSystem(typeof(InfluxPlugin).FullName);
|
||||
|
@ -1,8 +1,9 @@
|
||||
using System.Collections.Generic;
|
||||
using Influx.AllaganTools;
|
||||
|
||||
namespace Influx;
|
||||
|
||||
internal sealed class StatisticsUpdate
|
||||
{
|
||||
public IReadOnlyDictionary<AllaganToolsIPC.Character, AllaganToolsIPC.Currencies> Currencies { get; init; }
|
||||
public required IReadOnlyDictionary<Character, Currencies> Currencies { get; init; }
|
||||
}
|
||||
|
@ -1,9 +1,9 @@
|
||||
using System;
|
||||
using System.Collections.Generic;
|
||||
using System.Collections.Generic;
|
||||
using System.Linq;
|
||||
using System.Numerics;
|
||||
using Dalamud.Interface.Windowing;
|
||||
using ImGuiNET;
|
||||
using Influx.AllaganTools;
|
||||
|
||||
namespace Influx.Windows;
|
||||
|
||||
@ -46,14 +46,14 @@ internal sealed class StatisticsWindow : Window
|
||||
public void OnStatisticsUpdate(StatisticsUpdate update)
|
||||
{
|
||||
var retainers = update.Currencies
|
||||
.Where(x => x.Key.CharacterType == AllaganToolsIPC.CharacterType.Retainer)
|
||||
.Where(x => x.Key.CharacterType == CharacterType.Retainer)
|
||||
.GroupBy(x => update.Currencies.FirstOrDefault(y => y.Key.CharacterId == x.Key.OwnerId).Key)
|
||||
.ToDictionary(x => x.Key, x => x.Select(y => y.Value).ToList());
|
||||
|
||||
_rows = update.Currencies.Where(x => x.Key.CharacterType == AllaganToolsIPC.CharacterType.Character)
|
||||
_rows = update.Currencies.Where(x => x.Key.CharacterType == CharacterType.Character)
|
||||
.Select(x =>
|
||||
{
|
||||
var currencies = new List<AllaganToolsIPC.Currencies> { x.Value };
|
||||
var currencies = new List<Currencies> { x.Value };
|
||||
if (retainers.TryGetValue(x.Key, out var retainerCurrencies))
|
||||
currencies.AddRange(retainerCurrencies);
|
||||
return new StatisticsRow
|
||||
@ -71,8 +71,8 @@ internal sealed class StatisticsWindow : Window
|
||||
|
||||
public sealed class StatisticsRow
|
||||
{
|
||||
public string Name { get; init; }
|
||||
public string Type { get; init; }
|
||||
public required string Name { get; init; }
|
||||
public required string Type { get; init; }
|
||||
public long Gil { get; init; }
|
||||
public long FcCredits { get; init; }
|
||||
}
|
||||
|
Loading…
Reference in New Issue
Block a user