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-10-19 01:50:46 +00:00
|
|
|
private IStore<string, Voice> _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-27 23:31:36 +00:00
|
|
|
public async 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-27 23:31:36 +00:00
|
|
|
var result = _voices.Set(voiceId, new Voice()
|
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-10-20 20:39:13 +00:00
|
|
|
return RequestResult.Successful(null);
|
|
|
|
}
|
|
|
|
return RequestResult.Failed("Something went wrong when updating the cache.");
|
2024-06-24 22:21:59 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|