Using Serilog. Added partial OBS batch request support. Added update checking. Added more commands. Added enabled/disabled TTS voices. And more.
This commit is contained in:
@@ -1,7 +1,7 @@
|
||||
using CommonSocketLibrary.Abstract;
|
||||
using CommonSocketLibrary.Common;
|
||||
using Microsoft.Extensions.DependencyInjection;
|
||||
using Microsoft.Extensions.Logging;
|
||||
using Serilog;
|
||||
using TwitchChatTTS.Seven.Socket.Context;
|
||||
using TwitchChatTTS.Seven.Socket.Data;
|
||||
|
||||
@@ -10,17 +10,18 @@ namespace TwitchChatTTS.Seven.Socket.Handlers
|
||||
public class EndOfStreamHandler : IWebSocketHandler
|
||||
{
|
||||
private ILogger Logger { get; }
|
||||
private Configuration Configuration { get; }
|
||||
private User User { get; }
|
||||
private IServiceProvider ServiceProvider { get; }
|
||||
private string[] ErrorCodes { get; }
|
||||
private int[] ReconnectDelay { get; }
|
||||
|
||||
public int OperationCode { get; set; } = 7;
|
||||
|
||||
|
||||
public EndOfStreamHandler(ILogger<EndOfStreamHandler> logger, Configuration configuration, IServiceProvider serviceProvider) {
|
||||
|
||||
public EndOfStreamHandler(ILogger logger, User user, IServiceProvider serviceProvider)
|
||||
{
|
||||
Logger = logger;
|
||||
Configuration = configuration;
|
||||
User = user;
|
||||
ServiceProvider = serviceProvider;
|
||||
|
||||
ErrorCodes = [
|
||||
@@ -59,37 +60,40 @@ namespace TwitchChatTTS.Seven.Socket.Handlers
|
||||
{
|
||||
if (message is not EndOfStreamMessage obj || obj == null)
|
||||
return;
|
||||
|
||||
|
||||
var code = obj.Code - 4000;
|
||||
if (code >= 0 && code < ErrorCodes.Length)
|
||||
Logger.LogWarning($"Received end of stream message (reason: {ErrorCodes[code]}, code: {obj.Code}, message: {obj.Message}).");
|
||||
Logger.Warning($"Received end of stream message (reason: {ErrorCodes[code]}, code: {obj.Code}, message: {obj.Message}).");
|
||||
else
|
||||
Logger.LogWarning($"Received end of stream message (code: {obj.Code}, message: {obj.Message}).");
|
||||
|
||||
Logger.Warning($"Received end of stream message (code: {obj.Code}, message: {obj.Message}).");
|
||||
|
||||
await sender.DisconnectAsync();
|
||||
|
||||
if (code >= 0 && code < ReconnectDelay.Length && ReconnectDelay[code] < 0) {
|
||||
Logger.LogError($"7tv client will remain disconnected due to a bad client implementation.");
|
||||
if (code >= 0 && code < ReconnectDelay.Length && ReconnectDelay[code] < 0)
|
||||
{
|
||||
Logger.Error($"7tv client will remain disconnected due to a bad client implementation.");
|
||||
return;
|
||||
}
|
||||
|
||||
if (string.IsNullOrWhiteSpace(Configuration.Seven?.UserId))
|
||||
if (string.IsNullOrWhiteSpace(User.SevenEmoteSetId))
|
||||
return;
|
||||
|
||||
var context = ServiceProvider.GetRequiredService<ReconnectContext>();
|
||||
await Task.Delay(ReconnectDelay[code]);
|
||||
|
||||
//var base_url = "@" + string.Join(",", Configuration.Seven.SevenId.Select(sub => sub.Type + "<" + string.Join(",", sub.Condition?.Select(e => e.Key + "=" + e.Value) ?? new string[0]) + ">"));
|
||||
var base_url = $"@emote_set.*<object_id={Configuration.Seven.UserId.Trim()}>";
|
||||
var base_url = $"@emote_set.*<object_id={User.SevenEmoteSetId}>";
|
||||
string url = $"{SevenApiClient.WEBSOCKET_URL}{base_url}";
|
||||
Logger.LogDebug($"7tv websocket reconnecting to {url}.");
|
||||
Logger.Debug($"7tv websocket reconnecting to {url}.");
|
||||
|
||||
await sender.ConnectAsync(url);
|
||||
if (context.SessionId != null) {
|
||||
if (context.SessionId != null)
|
||||
{
|
||||
await sender.Send(34, new ResumeMessage() { SessionId = context.SessionId });
|
||||
Logger.LogInformation("Resumed connection to 7tv websocket.");
|
||||
} else {
|
||||
Logger.LogDebug("7tv websocket session id not available.");
|
||||
Logger.Information("Resumed connection to 7tv websocket.");
|
||||
}
|
||||
else
|
||||
{
|
||||
Logger.Information("Resumed connection to 7tv websocket on a different session.");
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user