This commit is contained in:
2025-08-15 18:13:10 -03:00
parent fe77add302
commit da6e9e9b8f

View File

@@ -21,7 +21,7 @@ public class CurlElectoralApiService : IElectoralApiService
{
_logger = logger;
_configuration = configuration;
_baseUrl = _configuration["ElectoralApi:BaseUrl"] ?? "";
_baseUrl = _configuration["ElectoralApi__BaseUrl"] ?? "";
}
private async Task<(int, string)> ExecuteCurlCommand(string arguments)
@@ -57,16 +57,28 @@ public class CurlElectoralApiService : IElectoralApiService
public async Task<string?> GetAuthTokenAsync()
{
var username = _configuration["ElectoralApi:Username"];
var password = _configuration["ElectoralApi:Password"];
var username = _configuration["ElectoralApi__Username"];
var password = _configuration["ElectoralApi__Password"]; // OJO: Verifica el nombre exacto de la variable en tu .env
var arguments = $"-s -H \"username: {username}\" -H \"password: {password}\" \"{_baseUrl}/api/createtoken\"";
var (status, output) = await ExecuteCurlCommand(arguments);
if (status != 200) return null;
if (status != 200)
{
_logger.LogError("Curl recibió un código de estado no exitoso. Respuesta: {Output}", output);
return null;
}
try
{
var tokenResponse = JsonSerializer.Deserialize<TokenResponse>(output);
return tokenResponse?.Data?.AccessToken;
}
catch (JsonException ex)
{
_logger.LogError(ex, "Falló la deserialización del JSON. La respuesta del servidor NO era un JSON válido. Respuesta recibida: {Output}", output);
return null;
}
}
// Implementa los demás métodos de la interfaz usando el mismo patrón
// ...