potentially fixes an issue with cache creation, do not remove mediator on failure
This commit is contained in:
@@ -1,11 +1,9 @@
|
||||
using FFXIVClientStructs.FFXIV.Client.Game.Character;
|
||||
using MareSynchronos.API.Data.Enum;
|
||||
using MareSynchronos.API.Data.Enum;
|
||||
using MareSynchronos.Factories;
|
||||
using MareSynchronos.Mediator;
|
||||
using MareSynchronos.Models;
|
||||
using MareSynchronos.Utils;
|
||||
using Microsoft.Extensions.Logging;
|
||||
using System.Collections;
|
||||
|
||||
namespace MareSynchronos.Managers;
|
||||
|
||||
@@ -14,7 +12,7 @@ public class CacheCreationService : MediatorSubscriberBase, IDisposable
|
||||
private readonly CharacterDataFactory _characterDataFactory;
|
||||
private Task? _cacheCreationTask;
|
||||
private readonly Dictionary<ObjectKind, GameObjectHandler> _cachesToCreate = new();
|
||||
private readonly CharacterData _lastCreatedData = new();
|
||||
private readonly CharacterData _playerData = new();
|
||||
private readonly CancellationTokenSource _cts = new();
|
||||
private readonly List<GameObjectHandler> _playerRelatedObjects = new();
|
||||
private CancellationTokenSource _palettePlusCts = new();
|
||||
@@ -43,9 +41,9 @@ public class CacheCreationService : MediatorSubscriberBase, IDisposable
|
||||
Task.Run(() =>
|
||||
{
|
||||
var actualMsg = (ClearCacheForObjectMessage)msg;
|
||||
_lastCreatedData.FileReplacements.Remove(actualMsg.ObjectToCreateFor.ObjectKind);
|
||||
_lastCreatedData.GlamourerString.Remove(actualMsg.ObjectToCreateFor.ObjectKind);
|
||||
Mediator.Publish(new CharacterDataCreatedMessage(_lastCreatedData));
|
||||
_playerData.FileReplacements.Remove(actualMsg.ObjectToCreateFor.ObjectKind);
|
||||
_playerData.GlamourerString.Remove(actualMsg.ObjectToCreateFor.ObjectKind);
|
||||
Mediator.Publish(new CharacterDataCreatedMessage(_playerData.ToAPI()));
|
||||
});
|
||||
});
|
||||
Mediator.Subscribe<DelayedFrameworkUpdateMessage>(this, (msg) => ProcessCacheCreation());
|
||||
@@ -57,9 +55,9 @@ public class CacheCreationService : MediatorSubscriberBase, IDisposable
|
||||
|
||||
private void PalettePlusChanged(PalettePlusMessage msg)
|
||||
{
|
||||
if (!string.Equals(msg.Data, _lastCreatedData.PalettePlusPalette, StringComparison.Ordinal))
|
||||
if (!string.Equals(msg.Data, _playerData.PalettePlusPalette, StringComparison.Ordinal))
|
||||
{
|
||||
_lastCreatedData.PalettePlusPalette = msg.Data ?? string.Empty;
|
||||
_playerData.PalettePlusPalette = msg.Data ?? string.Empty;
|
||||
|
||||
_palettePlusCts?.Cancel();
|
||||
_palettePlusCts?.Dispose();
|
||||
@@ -69,26 +67,26 @@ public class CacheCreationService : MediatorSubscriberBase, IDisposable
|
||||
Task.Run(async () =>
|
||||
{
|
||||
await Task.Delay(TimeSpan.FromSeconds(1), token).ConfigureAwait(false);
|
||||
Mediator.Publish(new CharacterDataCreatedMessage(_lastCreatedData));
|
||||
Mediator.Publish(new CharacterDataCreatedMessage(_playerData.ToAPI()));
|
||||
}, token);
|
||||
}
|
||||
}
|
||||
|
||||
private void HeelsOffsetChanged(HeelsOffsetMessage msg)
|
||||
{
|
||||
if (msg.Offset != _lastCreatedData.HeelsOffset)
|
||||
if (msg.Offset != _playerData.HeelsOffset)
|
||||
{
|
||||
_lastCreatedData.HeelsOffset = msg.Offset;
|
||||
Mediator.Publish(new CharacterDataCreatedMessage(_lastCreatedData));
|
||||
_playerData.HeelsOffset = msg.Offset;
|
||||
Mediator.Publish(new CharacterDataCreatedMessage(_playerData.ToAPI()));
|
||||
}
|
||||
}
|
||||
|
||||
private void CustomizePlusChanged(CustomizePlusMessage msg)
|
||||
{
|
||||
if (!string.Equals(msg.Data, _lastCreatedData.CustomizePlusScale, StringComparison.Ordinal))
|
||||
if (!string.Equals(msg.Data, _playerData.CustomizePlusScale, StringComparison.Ordinal))
|
||||
{
|
||||
_lastCreatedData.CustomizePlusScale = msg.Data ?? string.Empty;
|
||||
Mediator.Publish(new CharacterDataCreatedMessage(_lastCreatedData));
|
||||
_playerData.CustomizePlusScale = msg.Data ?? string.Empty;
|
||||
Mediator.Publish(new CharacterDataCreatedMessage(_playerData.ToAPI()));
|
||||
}
|
||||
}
|
||||
|
||||
@@ -104,9 +102,18 @@ public class CacheCreationService : MediatorSubscriberBase, IDisposable
|
||||
{
|
||||
foreach (var obj in toCreate)
|
||||
{
|
||||
var data = await _characterDataFactory.BuildCharacterData(_lastCreatedData, obj.Value, _cts.Token).ConfigureAwait(false);
|
||||
await _characterDataFactory.BuildCharacterData(_playerData, obj.Value, _cts.Token).ConfigureAwait(false);
|
||||
}
|
||||
Mediator.Publish(new CharacterDataCreatedMessage(_lastCreatedData));
|
||||
|
||||
int maxWaitingTime = 10000;
|
||||
while (!_playerData.IsReady && maxWaitingTime > 0)
|
||||
{
|
||||
await Task.Delay(100).ConfigureAwait(false);
|
||||
maxWaitingTime -= 100;
|
||||
_logger.LogTrace("Waiting for Cache to be ready");
|
||||
}
|
||||
|
||||
Mediator.Publish(new CharacterDataCreatedMessage(_playerData.ToAPI()));
|
||||
}
|
||||
catch (Exception ex)
|
||||
{
|
||||
@@ -115,7 +122,6 @@ public class CacheCreationService : MediatorSubscriberBase, IDisposable
|
||||
finally
|
||||
{
|
||||
_logger.LogDebug("Cache Creation complete");
|
||||
|
||||
}
|
||||
}, _cts.Token);
|
||||
}
|
||||
|
||||
@@ -378,6 +378,7 @@ public class CachedPlayer : MediatorSubscriberBase, IDisposable
|
||||
if (downloadToken.IsCancellationRequested)
|
||||
{
|
||||
_logger.LogTrace("Detected cancellation");
|
||||
_apiController.CancelDownload(downloadId);
|
||||
return;
|
||||
}
|
||||
|
||||
@@ -415,12 +416,6 @@ public class CachedPlayer : MediatorSubscriberBase, IDisposable
|
||||
|
||||
_logger.LogDebug("[{applicationId}] Application finished", _applicationId);
|
||||
});
|
||||
|
||||
_downloadCancellationTokenSource = null;
|
||||
|
||||
_logger.LogDebug("Download was cancelled");
|
||||
_apiController.CancelDownload(downloadId);
|
||||
|
||||
}, downloadToken);
|
||||
}
|
||||
|
||||
|
||||
@@ -28,7 +28,7 @@ public class OnlinePlayerManager : MediatorSubscriberBase, IDisposable
|
||||
Mediator.Subscribe<DelayedFrameworkUpdateMessage>(this, (_) => FrameworkOnUpdate());
|
||||
Mediator.Subscribe<CharacterDataCreatedMessage>(this, (msg) =>
|
||||
{
|
||||
var newData = ((CharacterDataCreatedMessage)msg).CharacterData.ToAPI();
|
||||
var newData = ((CharacterDataCreatedMessage)msg).CharacterData;
|
||||
if (_lastSentData == null || _lastSentData != null && !string.Equals(newData.DataHash.Value, _lastSentData.DataHash.Value, StringComparison.Ordinal))
|
||||
{
|
||||
_logger.LogDebug("Pushing data for visible players");
|
||||
|
||||
Reference in New Issue
Block a user