2024-12-31 18:31:21 +00:00
|
|
|
using HermesSocketLibrary.Requests.Messages;
|
2024-10-19 01:50:46 +00:00
|
|
|
using HermesSocketServer.Models;
|
2024-10-17 19:07:00 +00:00
|
|
|
using HermesSocketServer.Store;
|
2024-06-24 22:21:59 +00:00
|
|
|
using ILogger = Serilog.ILogger;
|
|
|
|
|
|
|
|
namespace HermesSocketServer.Requests
|
|
|
|
{
|
|
|
|
public class UpdateTTSVoice : IRequest
|
|
|
|
{
|
|
|
|
public string Name => "update_tts_voice";
|
2024-10-20 20:39:13 +00:00
|
|
|
public string[] RequiredKeys => ["voice", "voiceId"];
|
2024-12-31 18:31:21 +00:00
|
|
|
private IStore<string, TTSVoice> _voices;
|
2024-06-24 22:21:59 +00:00
|
|
|
private ILogger _logger;
|
|
|
|
|
2024-10-17 19:07:00 +00:00
|
|
|
public UpdateTTSVoice(VoiceStore voices, ILogger logger)
|
2024-06-24 22:21:59 +00:00
|
|
|
{
|
2024-10-17 19:07:00 +00:00
|
|
|
_voices = voices;
|
2024-06-24 22:21:59 +00:00
|
|
|
_logger = logger;
|
|
|
|
}
|
|
|
|
|
2024-12-28 17:24:02 +00:00
|
|
|
public Task<RequestResult> Grant(Channel channel, IDictionary<string, object> data)
|
2024-06-24 22:21:59 +00:00
|
|
|
{
|
2024-12-27 23:31:36 +00:00
|
|
|
string voiceName = data["voice"].ToString()!;
|
|
|
|
string voiceId = data["voiceid"].ToString()!;
|
2024-06-24 22:21:59 +00:00
|
|
|
|
2024-12-31 18:31:21 +00:00
|
|
|
var result = _voices.Set(voiceId, new TTSVoice()
|
2024-10-19 01:50:46 +00:00
|
|
|
{
|
2024-12-27 23:31:36 +00:00
|
|
|
Id = voiceId,
|
|
|
|
Name = voiceName
|
2024-10-19 01:50:46 +00:00
|
|
|
});
|
2024-10-20 20:39:13 +00:00
|
|
|
if (result)
|
|
|
|
{
|
2024-12-27 23:31:36 +00:00
|
|
|
_logger.Information($"Updated voice's [voice id: {voiceId}] name [new name: {voiceName}]");
|
2024-12-28 17:24:02 +00:00
|
|
|
return Task.FromResult(RequestResult.Successful(null));
|
2024-10-20 20:39:13 +00:00
|
|
|
}
|
2024-12-28 17:24:02 +00:00
|
|
|
return Task.FromResult(RequestResult.Failed("Something went wrong when updating the cache."));
|
2024-06-24 22:21:59 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|