Data inicial cálculada conforme calendário CCEE. Caso ainda esteja dentro do período de coleta ainda é feito as busca dos dados do mês anterior (M-1).
This commit is contained in:
parent
41358ad446
commit
ae5be9853b
@ -2,6 +2,6 @@ namespace Application
|
|||||||
{
|
{
|
||||||
public interface ICalendarioService
|
public interface ICalendarioService
|
||||||
{
|
{
|
||||||
Task<string?> ObterEventoLimiteColetaAsync(DateTime dataReferencia, CancellationToken ct = default);
|
Task<double?> ObterEventoLimiteColetaAsync(DateTime dataReferencia, CancellationToken ct = default);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -8,7 +8,7 @@ namespace Infrastructure
|
|||||||
{
|
{
|
||||||
private const string Url = "https://www.ccee.org.br/en/web/guest/calendario?p_p_id=com_liferay_calendar_web_portlet_CalendarPortlet_INSTANCE_urjn&p_p_lifecycle=2&p_p_cacheability=cacheLevelPage&doAsUserId=&p_p_resource_id=calendarBookings";
|
private const string Url = "https://www.ccee.org.br/en/web/guest/calendario?p_p_id=com_liferay_calendar_web_portlet_CalendarPortlet_INSTANCE_urjn&p_p_lifecycle=2&p_p_cacheability=cacheLevelPage&doAsUserId=&p_p_resource_id=calendarBookings";
|
||||||
|
|
||||||
public async Task<string?> ObterEventoLimiteColetaAsync(DateTime dataReferencia, CancellationToken ct = default)
|
public async Task<double?> ObterEventoLimiteColetaAsync(DateTime dataReferencia, CancellationToken ct = default)
|
||||||
{
|
{
|
||||||
var year = dataReferencia.Year;
|
var year = dataReferencia.Year;
|
||||||
var month = dataReferencia.Month - 1;
|
var month = dataReferencia.Month - 1;
|
||||||
@ -42,37 +42,49 @@ namespace Infrastructure
|
|||||||
try
|
try
|
||||||
{
|
{
|
||||||
using var doc = JsonDocument.Parse(resposta);
|
using var doc = JsonDocument.Parse(resposta);
|
||||||
string? found = null;
|
|
||||||
|
double? encontrado = null;
|
||||||
|
double? startTimeDay = null;
|
||||||
|
|
||||||
void SearchJson(JsonElement el)
|
void SearchJson(JsonElement el)
|
||||||
{
|
{
|
||||||
if (found != null) return;
|
if (encontrado != null) return;
|
||||||
switch (el.ValueKind)
|
|
||||||
|
if (el.ValueKind == JsonValueKind.Object)
|
||||||
{
|
{
|
||||||
case JsonValueKind.String:
|
// Verifica se alguma propriedade contém o texto alvo
|
||||||
var s = el.GetString() ?? "";
|
foreach (var prop in el.EnumerateObject())
|
||||||
if (s.Contains(alvo, StringComparison.OrdinalIgnoreCase)) found = s;
|
{
|
||||||
break;
|
if (prop.Value.ValueKind == JsonValueKind.String)
|
||||||
case JsonValueKind.Object:
|
{
|
||||||
foreach (var prop in el.EnumerateObject()) SearchJson(prop.Value);
|
var s = prop.Value.GetString() ?? "";
|
||||||
break;
|
if (s.Contains(alvo, StringComparison.OrdinalIgnoreCase))
|
||||||
case JsonValueKind.Array:
|
{
|
||||||
foreach (var item in el.EnumerateArray()) SearchJson(item);
|
// Encontrou o evento, extrair dados do mesmo objeto
|
||||||
break;
|
if (el.TryGetProperty("startTimeDay", out var day))
|
||||||
|
startTimeDay = day.GetInt32();
|
||||||
|
if (startTimeDay != null)
|
||||||
|
encontrado = startTimeDay;
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
foreach (var prop in el.EnumerateObject())
|
||||||
|
SearchJson(prop.Value);
|
||||||
|
}
|
||||||
|
else if (el.ValueKind == JsonValueKind.Array)
|
||||||
|
{
|
||||||
|
foreach (var item in el.EnumerateArray())
|
||||||
|
SearchJson(item);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
SearchJson(doc.RootElement);
|
SearchJson(doc.RootElement);
|
||||||
if (found != null) return found;
|
if (encontrado != null) return encontrado;
|
||||||
}
|
}
|
||||||
catch { }
|
catch { }
|
||||||
|
|
||||||
var idx = resposta.IndexOf(alvo, StringComparison.OrdinalIgnoreCase);
|
|
||||||
if (idx >= 0)
|
|
||||||
{
|
|
||||||
var start = Math.Max(0, idx - 60);
|
|
||||||
var len = Math.Min(400, resposta.Length - start);
|
|
||||||
return resposta.Substring(start, len).Replace("\r", " ").Replace("\n", " ");
|
|
||||||
}
|
|
||||||
|
|
||||||
return null;
|
return null;
|
||||||
}
|
}
|
||||||
catch
|
catch
|
||||||
|
|||||||
@ -11,14 +11,17 @@ class Program
|
|||||||
string ACCESS_CONN_STRING = @"Provider=Microsoft.ACE.OLEDB.12.0;Data Source=\\srv-dados\documentos\Middle\Informativo Setorial\Modelo Word\BD1_dados cadastrais e faturas.accdb;Jet OLEDB:Database Password=gds21";
|
string ACCESS_CONN_STRING = @"Provider=Microsoft.ACE.OLEDB.12.0;Data Source=\\srv-dados\documentos\Middle\Informativo Setorial\Modelo Word\BD1_dados cadastrais e faturas.accdb;Jet OLEDB:Database Password=gds21";
|
||||||
string caminhoLog = $@"\\srv-dados\documentos\Back\Carteira x.x\Codigo\Erros\log_erros_{inicio:MM_dd_HH_mm}.csv";
|
string caminhoLog = $@"\\srv-dados\documentos\Back\Carteira x.x\Codigo\Erros\log_erros_{inicio:MM_dd_HH_mm}.csv";
|
||||||
|
|
||||||
//agosto finalizado
|
|
||||||
DateTime dataIni = new DateTime(inicio.Year, 11, 01);
|
|
||||||
// var a = dataFim == DateTime.Today;
|
|
||||||
DateTime dataFim = inicio.Date;
|
|
||||||
|
|
||||||
var calendarioService = new CalendarioService();
|
var calendarioService = new CalendarioService();
|
||||||
var evento = await calendarioService.ObterEventoLimiteColetaAsync(inicio, CancellationToken.None);
|
var evento = await calendarioService.ObterEventoLimiteColetaAsync(inicio, CancellationToken.None);
|
||||||
Console.WriteLine(evento != null ? $"Evento encontrado: {evento}" : "Evento não encontrado no calendário.");
|
|
||||||
|
//agosto finalizado
|
||||||
|
DateTime dataIni = new DateTime(inicio.Year, inicio.Month, 01);
|
||||||
|
DateTime dataFim = inicio.Date;
|
||||||
|
|
||||||
|
if (dataFim.Day <= evento + 1)
|
||||||
|
{
|
||||||
|
dataIni = dataIni.AddMonths(-1);
|
||||||
|
}
|
||||||
|
|
||||||
// Configuração de dependências (pode usar um container DI depois)
|
// Configuração de dependências (pode usar um container DI depois)
|
||||||
var postgresRepo = new PostgresRepository(PG_CONN_STRING_PROD);
|
var postgresRepo = new PostgresRepository(PG_CONN_STRING_PROD);
|
||||||
|
|||||||
Loading…
x
Reference in New Issue
Block a user