2024-03-12 18:05:27 +00:00
|
|
|
using CommonSocketLibrary.Abstract;
|
|
|
|
using CommonSocketLibrary.Common;
|
2024-06-17 00:19:31 +00:00
|
|
|
using Serilog;
|
2024-03-12 18:05:27 +00:00
|
|
|
using TwitchChatTTS.OBS.Socket.Data;
|
|
|
|
|
|
|
|
namespace TwitchChatTTS.OBS.Socket.Handlers
|
|
|
|
{
|
|
|
|
public class EventMessageHandler : IWebSocketHandler
|
|
|
|
{
|
2024-06-24 22:11:36 +00:00
|
|
|
private readonly ILogger _logger;
|
|
|
|
public int OperationCode { get; } = 5;
|
2024-03-12 18:05:27 +00:00
|
|
|
|
2024-07-19 16:56:41 +00:00
|
|
|
public EventMessageHandler(
|
|
|
|
ILogger logger
|
|
|
|
)
|
2024-06-17 00:19:31 +00:00
|
|
|
{
|
|
|
|
_logger = logger;
|
2024-03-12 18:05:27 +00:00
|
|
|
}
|
|
|
|
|
2024-12-28 21:19:28 +00:00
|
|
|
public Task Execute<Data>(SocketClient<WebSocketMessage> sender, Data data)
|
2024-03-12 18:05:27 +00:00
|
|
|
{
|
2024-06-24 22:11:36 +00:00
|
|
|
if (data is not EventMessage message || message == null)
|
2024-12-28 21:19:28 +00:00
|
|
|
return Task.CompletedTask;
|
2024-07-19 16:56:41 +00:00
|
|
|
if (sender is not OBSSocketClient obs)
|
2024-12-28 21:19:28 +00:00
|
|
|
return Task.CompletedTask;
|
2024-06-24 22:11:36 +00:00
|
|
|
switch (message.EventType)
|
2024-06-17 00:19:31 +00:00
|
|
|
{
|
2024-03-12 18:05:27 +00:00
|
|
|
case "StreamStateChanged":
|
|
|
|
if (sender is not OBSSocketClient client)
|
2024-12-28 21:19:28 +00:00
|
|
|
return Task.CompletedTask;
|
2024-06-24 22:11:36 +00:00
|
|
|
string? raw_state = message.EventData["outputState"].ToString();
|
2024-03-12 18:05:27 +00:00
|
|
|
string? state = raw_state?.Substring(21).ToLower();
|
2024-07-19 16:56:41 +00:00
|
|
|
obs.Streaming = message.EventData["outputActive"].ToString()!.ToLower() == "true";
|
2024-06-17 00:19:31 +00:00
|
|
|
_logger.Warning("Stream " + (state != null && state.EndsWith("ing") ? "is " : "has ") + state + ".");
|
2024-03-12 18:05:27 +00:00
|
|
|
|
2024-07-19 16:56:41 +00:00
|
|
|
if (obs.Streaming == false && state != null && !state.EndsWith("ing"))
|
2024-06-17 00:19:31 +00:00
|
|
|
{
|
2024-07-16 04:48:55 +00:00
|
|
|
// Stream ended
|
2024-03-12 18:05:27 +00:00
|
|
|
}
|
|
|
|
break;
|
|
|
|
default:
|
2024-07-16 04:48:55 +00:00
|
|
|
_logger.Debug(message.EventType + " EVENT: " + string.Join(" | ", message.EventData?.Select(x => x.Key + "=" + x.Value?.ToString()) ?? Array.Empty<string>()));
|
2024-03-12 18:05:27 +00:00
|
|
|
break;
|
|
|
|
}
|
2024-12-28 21:19:28 +00:00
|
|
|
|
|
|
|
return Task.CompletedTask;
|
2024-03-12 18:05:27 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|