182 lines
6.9 KiB
C#
182 lines
6.9 KiB
C#
using Serilog;
|
|
using TwitchChatTTS.Hermes.Socket;
|
|
using TwitchLib.Client.Models;
|
|
using static TwitchChatTTS.Chat.Commands.TTSCommands;
|
|
|
|
namespace TwitchChatTTS.Chat.Commands
|
|
{
|
|
public class TTSCommand : IChatCommand
|
|
{
|
|
private readonly User _user;
|
|
private readonly ILogger _logger;
|
|
|
|
|
|
public TTSCommand(User user, ILogger logger)
|
|
{
|
|
_user = user;
|
|
_logger = logger;
|
|
}
|
|
|
|
public string Name => "tts";
|
|
|
|
public void Build(ICommandBuilder builder)
|
|
{
|
|
builder.CreateCommandTree(Name, b =>
|
|
{
|
|
b.CreateStaticInputParameter("add", b =>
|
|
{
|
|
b.CreateVoiceNameParameter("voiceName", false)
|
|
.CreateCommand(new AddTTSVoiceCommand(_user, _logger));
|
|
})
|
|
.CreateStaticInputParameter("del", b =>
|
|
{
|
|
b.CreateVoiceNameParameter("voiceName", true)
|
|
.CreateCommand(new DeleteTTSVoiceCommand(_user, _logger));
|
|
})
|
|
.CreateStaticInputParameter("delete", b =>
|
|
{
|
|
b.CreateVoiceNameParameter("voiceName", true)
|
|
.CreateCommand(new DeleteTTSVoiceCommand(_user, _logger));
|
|
})
|
|
.CreateStaticInputParameter("remove", b =>
|
|
{
|
|
b.CreateVoiceNameParameter("voiceName", true)
|
|
.CreateCommand(new DeleteTTSVoiceCommand(_user, _logger));
|
|
})
|
|
.CreateStaticInputParameter("enable", b =>
|
|
{
|
|
b.CreateVoiceNameParameter("voiceName", false)
|
|
.CreateCommand(new SetTTSVoiceStateCommand(true, _user, _logger));
|
|
})
|
|
.CreateStaticInputParameter("on", b =>
|
|
{
|
|
b.CreateVoiceNameParameter("voiceName", false)
|
|
.CreateCommand(new SetTTSVoiceStateCommand(true, _user, _logger));
|
|
})
|
|
.CreateStaticInputParameter("disable", b =>
|
|
{
|
|
b.CreateVoiceNameParameter("voiceName", true)
|
|
.CreateCommand(new SetTTSVoiceStateCommand(false, _user, _logger));
|
|
})
|
|
.CreateStaticInputParameter("off", b =>
|
|
{
|
|
b.CreateVoiceNameParameter("voiceName", true)
|
|
.CreateCommand(new SetTTSVoiceStateCommand(false, _user, _logger));
|
|
});
|
|
});
|
|
}
|
|
|
|
private sealed class AddTTSVoiceCommand : IChatPartialCommand
|
|
{
|
|
private readonly User _user;
|
|
private readonly ILogger _logger;
|
|
|
|
public bool AcceptCustomPermission { get => false; }
|
|
|
|
|
|
public AddTTSVoiceCommand(User user, ILogger logger)
|
|
{
|
|
_user = user;
|
|
_logger = logger;
|
|
}
|
|
|
|
public bool CheckDefaultPermissions(ChatMessage message)
|
|
{
|
|
return false;
|
|
}
|
|
|
|
public async Task Execute(IDictionary<string, string> values, ChatMessage message, HermesSocketClient client)
|
|
{
|
|
if (_user == null || _user.VoicesAvailable == null)
|
|
return;
|
|
|
|
var voiceName = values["voiceName"];
|
|
var voiceNameLower = voiceName.ToLower();
|
|
var exists = _user.VoicesAvailable.Any(v => v.Value.ToLower() == voiceNameLower);
|
|
if (exists)
|
|
{
|
|
_logger.Warning($"Voice already exists [voice: {voiceName}][id: {message.UserId}]");
|
|
return;
|
|
}
|
|
|
|
await client.CreateTTSVoice(voiceName);
|
|
_logger.Information($"Added a new TTS voice by {message.Username} [voice: {voiceName}][id: {message.UserId}]");
|
|
}
|
|
}
|
|
|
|
private sealed class DeleteTTSVoiceCommand : IChatPartialCommand
|
|
{
|
|
private readonly User _user;
|
|
private ILogger _logger;
|
|
|
|
public bool AcceptCustomPermission { get => false; }
|
|
|
|
public DeleteTTSVoiceCommand(User user, ILogger logger)
|
|
{
|
|
_user = user;
|
|
_logger = logger;
|
|
}
|
|
|
|
public bool CheckDefaultPermissions(ChatMessage message)
|
|
{
|
|
return false;
|
|
}
|
|
|
|
public async Task Execute(IDictionary<string, string> values, ChatMessage message, HermesSocketClient client)
|
|
{
|
|
if (_user == null || _user.VoicesAvailable == null)
|
|
{
|
|
_logger.Debug($"Voices available are not loaded [chatter: {message.Username}][chatter id: {message.UserId}]");
|
|
return;
|
|
}
|
|
|
|
var voiceName = values["voiceName"];
|
|
var voiceNameLower = voiceName.ToLower();
|
|
var exists = _user.VoicesAvailable.Any(v => v.Value.ToLower() == voiceNameLower);
|
|
if (!exists)
|
|
{
|
|
_logger.Debug($"Voice does not exist [voice: {voiceName}][chatter: {message.Username}][chatter id: {message.UserId}]");
|
|
return;
|
|
}
|
|
|
|
var voiceId = _user.VoicesAvailable.FirstOrDefault(v => v.Value.ToLower() == voiceName).Key;
|
|
await client.DeleteTTSVoice(voiceId);
|
|
_logger.Information($"Deleted a TTS voice [voice: {voiceName}][chatter: {message.Username}][chatter id: {message.UserId}]");
|
|
}
|
|
}
|
|
|
|
private sealed class SetTTSVoiceStateCommand : IChatPartialCommand
|
|
{
|
|
private bool _state;
|
|
private readonly User _user;
|
|
private ILogger _logger;
|
|
|
|
public bool AcceptCustomPermission { get => true; }
|
|
|
|
public SetTTSVoiceStateCommand(bool state, User user, ILogger logger)
|
|
{
|
|
_state = state;
|
|
_user = user;
|
|
_logger = logger;
|
|
}
|
|
|
|
public bool CheckDefaultPermissions(ChatMessage message)
|
|
{
|
|
return message.IsModerator || message.IsBroadcaster;
|
|
}
|
|
|
|
public async Task Execute(IDictionary<string, string> values, ChatMessage message, HermesSocketClient client)
|
|
{
|
|
if (_user == null || _user.VoicesAvailable == null)
|
|
return;
|
|
|
|
var voiceName = values["voiceName"];
|
|
var voiceNameLower = voiceName.ToLower();
|
|
var voiceId = _user.VoicesAvailable.FirstOrDefault(v => v.Value.ToLower() == voiceNameLower).Key;
|
|
|
|
await client.UpdateTTSVoiceState(voiceId, _state);
|
|
_logger.Information($"Changed state for TTS voice [voice: {voiceName}][state: {_state}][invoker: {message.Username}][id: {message.UserId}]");
|
|
}
|
|
}
|
|
}
|
|
} |