2024-06-17 00:19:31 +00:00
|
|
|
using Serilog;
|
2024-07-16 04:48:55 +00:00
|
|
|
using TwitchChatTTS.Hermes.Socket;
|
2024-08-04 23:46:10 +00:00
|
|
|
using TwitchChatTTS.Twitch.Socket.Messages;
|
2024-07-19 16:56:41 +00:00
|
|
|
using static TwitchChatTTS.Chat.Commands.TTSCommands;
|
2024-03-15 12:27:35 +00:00
|
|
|
|
|
|
|
namespace TwitchChatTTS.Chat.Commands
|
|
|
|
{
|
2024-07-19 16:56:41 +00:00
|
|
|
public class VoiceCommand : IChatCommand
|
2024-03-15 12:27:35 +00:00
|
|
|
{
|
2024-06-24 22:11:36 +00:00
|
|
|
private readonly User _user;
|
|
|
|
private readonly ILogger _logger;
|
2024-03-15 12:27:35 +00:00
|
|
|
|
2024-07-19 16:56:41 +00:00
|
|
|
public VoiceCommand(User user, ILogger logger)
|
2024-06-17 00:19:31 +00:00
|
|
|
{
|
2024-06-24 22:11:36 +00:00
|
|
|
_user = user;
|
2024-03-15 12:27:35 +00:00
|
|
|
_logger = logger;
|
|
|
|
}
|
|
|
|
|
2024-07-19 16:56:41 +00:00
|
|
|
public string Name => "voice";
|
|
|
|
|
|
|
|
public void Build(ICommandBuilder builder)
|
2024-03-15 12:27:35 +00:00
|
|
|
{
|
2024-07-19 16:56:41 +00:00
|
|
|
builder.CreateCommandTree(Name, b =>
|
|
|
|
{
|
|
|
|
b.CreateVoiceNameParameter("voiceName", true)
|
2024-08-04 23:46:10 +00:00
|
|
|
.CreateCommand(new TTSVoiceSelector(_user, _logger))
|
2024-08-06 19:29:29 +00:00
|
|
|
.CreateMentionParameter("chatter", enabled: true, optional: true)
|
2024-08-06 20:32:02 +00:00
|
|
|
.AddPermission("tts.commands.voice.admin")
|
2024-08-04 23:46:10 +00:00
|
|
|
.CreateCommand(new TTSVoiceSelectorAdmin(_user, _logger));
|
2024-07-19 16:56:41 +00:00
|
|
|
});
|
2024-03-15 12:27:35 +00:00
|
|
|
}
|
|
|
|
|
2024-07-19 16:56:41 +00:00
|
|
|
private sealed class TTSVoiceSelector : IChatPartialCommand
|
2024-03-15 12:27:35 +00:00
|
|
|
{
|
2024-07-19 16:56:41 +00:00
|
|
|
private readonly User _user;
|
|
|
|
private readonly ILogger _logger;
|
2024-03-15 12:27:35 +00:00
|
|
|
|
2024-07-19 16:56:41 +00:00
|
|
|
public bool AcceptCustomPermission { get => true; }
|
2024-03-15 12:27:35 +00:00
|
|
|
|
2024-07-19 16:56:41 +00:00
|
|
|
public TTSVoiceSelector(User user, ILogger logger)
|
2024-06-17 00:19:31 +00:00
|
|
|
{
|
2024-07-19 16:56:41 +00:00
|
|
|
_user = user;
|
|
|
|
_logger = logger;
|
2024-07-16 04:48:55 +00:00
|
|
|
}
|
|
|
|
|
2024-08-06 19:29:29 +00:00
|
|
|
public async Task Execute(IDictionary<string, string> values, ChannelChatMessage message, HermesSocketClient hermes)
|
2024-08-04 23:46:10 +00:00
|
|
|
{
|
|
|
|
if (_user == null || _user.VoicesSelected == null)
|
|
|
|
return;
|
|
|
|
|
|
|
|
long chatterId = long.Parse(message.ChatterUserId);
|
|
|
|
var voiceName = values["voiceName"];
|
|
|
|
var voiceNameLower = voiceName.ToLower();
|
|
|
|
var voice = _user.VoicesAvailable.First(v => v.Value.ToLower() == voiceNameLower);
|
|
|
|
|
|
|
|
if (_user.VoicesSelected.ContainsKey(chatterId))
|
|
|
|
{
|
2024-08-06 19:29:29 +00:00
|
|
|
await hermes.UpdateTTSUser(chatterId, voice.Key);
|
2024-08-06 20:32:02 +00:00
|
|
|
_logger.Debug($"Sent request to update chat TTS voice [voice: {voice.Value}][username: {message.ChatterUserLogin}][reason: command]");
|
2024-08-04 23:46:10 +00:00
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
2024-08-06 19:29:29 +00:00
|
|
|
await hermes.CreateTTSUser(chatterId, voice.Key);
|
2024-08-06 20:32:02 +00:00
|
|
|
_logger.Debug($"Sent request to create chat TTS voice [voice: {voice.Value}][username: {message.ChatterUserLogin}][reason: command]");
|
2024-08-04 23:46:10 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
private sealed class TTSVoiceSelectorAdmin : IChatPartialCommand
|
|
|
|
{
|
|
|
|
private readonly User _user;
|
|
|
|
private readonly ILogger _logger;
|
2024-07-19 16:56:41 +00:00
|
|
|
|
2024-08-04 23:46:10 +00:00
|
|
|
public bool AcceptCustomPermission { get => true; }
|
|
|
|
|
|
|
|
public TTSVoiceSelectorAdmin(User user, ILogger logger)
|
2024-07-16 04:48:55 +00:00
|
|
|
{
|
2024-08-04 23:46:10 +00:00
|
|
|
_user = user;
|
|
|
|
_logger = logger;
|
2024-07-16 04:48:55 +00:00
|
|
|
}
|
2024-07-19 16:56:41 +00:00
|
|
|
|
2024-08-06 19:29:29 +00:00
|
|
|
public async Task Execute(IDictionary<string, string> values, ChannelChatMessage message, HermesSocketClient hermes)
|
2024-07-16 04:48:55 +00:00
|
|
|
{
|
2024-07-19 16:56:41 +00:00
|
|
|
if (_user == null || _user.VoicesSelected == null)
|
|
|
|
return;
|
|
|
|
|
2024-08-06 19:29:29 +00:00
|
|
|
var mention = message.Message.Fragments.FirstOrDefault(f => f.Mention != null && f.Text == values["chatter"])?.Mention;
|
2024-08-04 23:46:10 +00:00
|
|
|
if (mention == null)
|
|
|
|
{
|
|
|
|
_logger.Warning("Failed to find the chatter to apply voice command to.");
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
long chatterId = long.Parse(mention.UserId);
|
2024-07-19 16:56:41 +00:00
|
|
|
var voiceName = values["voiceName"];
|
|
|
|
var voiceNameLower = voiceName.ToLower();
|
|
|
|
var voice = _user.VoicesAvailable.First(v => v.Value.ToLower() == voiceNameLower);
|
|
|
|
|
|
|
|
if (_user.VoicesSelected.ContainsKey(chatterId))
|
|
|
|
{
|
2024-08-06 19:29:29 +00:00
|
|
|
await hermes.UpdateTTSUser(chatterId, voice.Key);
|
2024-08-06 20:32:02 +00:00
|
|
|
_logger.Debug($"Sent request to update chat TTS voice [voice: {voice.Value}][username: {mention.UserLogin}][reason: command]");
|
2024-07-19 16:56:41 +00:00
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
2024-08-06 19:29:29 +00:00
|
|
|
await hermes.CreateTTSUser(chatterId, voice.Key);
|
2024-08-06 20:32:02 +00:00
|
|
|
_logger.Debug($"Sent request to create chat TTS voice [voice: {voice.Value}][username: {mention.UserLogin}][reason: command]");
|
2024-07-19 16:56:41 +00:00
|
|
|
}
|
2024-07-07 03:42:33 +00:00
|
|
|
}
|
2024-03-15 12:27:35 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|