forked from liza/Influx
Include levels for combat jobs
This commit is contained in:
parent
9b2169623b
commit
4b59c71815
@ -26,6 +26,7 @@ internal class InfluxStatisticsClient : IDisposable
|
|||||||
private readonly ClientState _clientState;
|
private readonly ClientState _clientState;
|
||||||
private readonly IReadOnlyDictionary<byte, byte> _classJobToArrayIndex;
|
private readonly IReadOnlyDictionary<byte, byte> _classJobToArrayIndex;
|
||||||
private readonly IReadOnlyDictionary<byte, string> _classJobNames;
|
private readonly IReadOnlyDictionary<byte, string> _classJobNames;
|
||||||
|
private readonly Dictionary<sbyte, string> _expToJobs;
|
||||||
|
|
||||||
public InfluxStatisticsClient(ChatGui chatGui, Configuration configuration, DataManager dataManager,
|
public InfluxStatisticsClient(ChatGui chatGui, Configuration configuration, DataManager dataManager,
|
||||||
ClientState clientState)
|
ClientState clientState)
|
||||||
@ -39,6 +40,10 @@ internal class InfluxStatisticsClient : IDisposable
|
|||||||
.ToDictionary(x => (byte)x.RowId, x => (byte)x.ExpArrayIndex);
|
.ToDictionary(x => (byte)x.RowId, x => (byte)x.ExpArrayIndex);
|
||||||
_classJobNames = dataManager.GetExcelSheet<ClassJob>()!.Where(x => x.RowId > 0)
|
_classJobNames = dataManager.GetExcelSheet<ClassJob>()!.Where(x => x.RowId > 0)
|
||||||
.ToDictionary(x => (byte)x.RowId, x => x.Abbreviation.ToString());
|
.ToDictionary(x => (byte)x.RowId, x => x.Abbreviation.ToString());
|
||||||
|
_expToJobs = dataManager.GetExcelSheet<ClassJob>()!.Where(x => x.RowId > 0)
|
||||||
|
.Where(x => x.JobIndex > 0)
|
||||||
|
.Where(x => x.Abbreviation.ToString() != "SMN")
|
||||||
|
.ToDictionary(x => x.ExpArrayIndex, x => x.Abbreviation.ToString());
|
||||||
}
|
}
|
||||||
|
|
||||||
public bool Enabled => _configuration.Server.Enabled;
|
public bool Enabled => _configuration.Server.Enabled;
|
||||||
@ -109,6 +114,25 @@ internal class InfluxStatisticsClient : IDisposable
|
|||||||
.Field("squadron_unlocked", localStats.SquadronUnlocked == true ? 1 : 0)
|
.Field("squadron_unlocked", localStats.SquadronUnlocked == true ? 1 : 0)
|
||||||
.Timestamp(date, WritePrecision.S));
|
.Timestamp(date, WritePrecision.S));
|
||||||
|
|
||||||
|
if (localStats.ClassJobLevels.Count > 0)
|
||||||
|
{
|
||||||
|
foreach (var (expIndex, abbreviation) in _expToJobs)
|
||||||
|
{
|
||||||
|
var level = localStats.ClassJobLevels[expIndex];
|
||||||
|
if (level > 0)
|
||||||
|
{
|
||||||
|
values.Add(PointData.Measurement("experience")
|
||||||
|
.Tag("id", character.CharacterId.ToString())
|
||||||
|
.Tag("player_name", character.Name)
|
||||||
|
.Tag("type", character.CharacterType.ToString())
|
||||||
|
.Tag("fc_id", character.FreeCompanyId > 0 ? character.FreeCompanyId.ToString() : null)
|
||||||
|
.Tag("job", abbreviation)
|
||||||
|
.Field("level", level)
|
||||||
|
.Timestamp(date, WritePrecision.S));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
if (localStats.MsqCount != -1)
|
if (localStats.MsqCount != -1)
|
||||||
{
|
{
|
||||||
values.Add(PointData.Measurement("quests")
|
values.Add(PointData.Measurement("quests")
|
||||||
|
Loading…
Reference in New Issue
Block a user