using CommonSocketLibrary.Abstract; using CommonSocketLibrary.Common; using HermesSocketLibrary.Socket.Data; using Microsoft.Extensions.DependencyInjection; using Serilog; using TwitchChatTTS.Chat.Commands.Parameters; using TwitchLib.Client.Models; namespace TwitchChatTTS.Chat.Commands { public class RemoveTTSVoiceCommand : ChatCommand { private IServiceProvider _serviceProvider; private ILogger _logger; public RemoveTTSVoiceCommand( [FromKeyedServices("parameter-unvalidated")] ChatCommandParameter ttsVoiceParameter, IServiceProvider serviceProvider, ILogger logger ) : base("removettsvoice", "Select a TTS voice as the default for that user.") { _serviceProvider = serviceProvider; _logger = logger; AddParameter(ttsVoiceParameter); } public override async Task CheckPermissions(ChatMessage message, long broadcasterId) { return message.IsModerator || message.IsBroadcaster; } public override async Task Execute(IList args, ChatMessage message, long broadcasterId) { var client = _serviceProvider.GetRequiredKeyedService>("hermes"); if (client == null) return; var context = _serviceProvider.GetRequiredService(); if (context == null || context.VoicesAvailable == null) return; var voiceName = args.First().ToLower(); var exists = context.VoicesAvailable.Any(v => v.Value.ToLower() == voiceName); if (!exists) return; var voiceId = context.VoicesAvailable.FirstOrDefault(v => v.Value.ToLower() == voiceName).Key; await client.Send(3, new RequestMessage() { Type = "delete_tts_voice", Data = new Dictionary() { { "voice", voiceId } } }); _logger.Information($"Deleted a TTS voice by {message.Username} (id: {message.UserId}): {voiceName}."); } } }