|
@ -1,5 +1,4 @@ |
|
|
import datetime |
|
|
import datetime |
|
|
from typing import TypedDict |
|
|
|
|
|
import docutils.core |
|
|
import docutils.core |
|
|
import json |
|
|
import json |
|
|
import shutil |
|
|
import shutil |
|
@ -15,6 +14,7 @@ from sigi.apps.casas.models import Orgao |
|
|
from sigi.apps.contatos.models import UnidadeFederativa |
|
|
from sigi.apps.contatos.models import UnidadeFederativa |
|
|
|
|
|
|
|
|
LOG_GERAL = _("Mensagens gerais") |
|
|
LOG_GERAL = _("Mensagens gerais") |
|
|
|
|
|
IGNORES = ["_psl", "k8s", "www.", "sapl."] |
|
|
|
|
|
|
|
|
get_iname = lambda d: "-".join(d.split(".")[:-2]) |
|
|
get_iname = lambda d: "-".join(d.split(".")[:-2]) |
|
|
get_sigla_serv = lambda d: "".join(d.split(".")[-2:]).upper() |
|
|
get_sigla_serv = lambda d: "".join(d.split(".")[-2:]).upper() |
|
@ -47,6 +47,19 @@ class Job(DailyJob): |
|
|
f" Início: {datetime.datetime.now(): %d/%m/%Y %H:%M:%S}" |
|
|
f" Início: {datetime.datetime.now(): %d/%m/%Y %H:%M:%S}" |
|
|
) |
|
|
) |
|
|
) |
|
|
) |
|
|
|
|
|
# TODO: Resolver |
|
|
|
|
|
print("Este CRON está desativado até resolvermos questões internas") |
|
|
|
|
|
return |
|
|
|
|
|
|
|
|
|
|
|
self._log[LOG_GERAL] = get_log_entry() |
|
|
|
|
|
|
|
|
|
|
|
if ( |
|
|
|
|
|
not settings.REGISTRO_PATH.exists() |
|
|
|
|
|
or not settings.REGISTRO_PATH.is_dir() |
|
|
|
|
|
): |
|
|
|
|
|
self.error(_(f"Arquivos de DNS não encontrados.")) |
|
|
|
|
|
self.report() |
|
|
|
|
|
return |
|
|
|
|
|
|
|
|
self._nomes_gerados = { |
|
|
self._nomes_gerados = { |
|
|
generate_instance_name(o): o |
|
|
generate_instance_name(o): o |
|
@ -57,8 +70,6 @@ class Job(DailyJob): |
|
|
tipo_servico__modo="R", data_desativacao=None |
|
|
tipo_servico__modo="R", data_desativacao=None |
|
|
).update(flag_confirmado=False) |
|
|
).update(flag_confirmado=False) |
|
|
|
|
|
|
|
|
self._log[LOG_GERAL] = get_log_entry() |
|
|
|
|
|
|
|
|
|
|
|
for uf in UnidadeFederativa.objects.all(): |
|
|
for uf in UnidadeFederativa.objects.all(): |
|
|
self._log[uf] = get_log_entry() |
|
|
self._log[uf] = get_log_entry() |
|
|
self.processa_uf(uf) |
|
|
self.processa_uf(uf) |
|
@ -89,8 +100,8 @@ class Job(DailyJob): |
|
|
except: |
|
|
except: |
|
|
pass |
|
|
pass |
|
|
|
|
|
|
|
|
if "_psl" in dominio: |
|
|
if any([i in dominio for i in IGNORES]): |
|
|
# Ignorar registros _PSL sem fazer log # |
|
|
# Ignorar esses registros sem fazer log # |
|
|
return |
|
|
return |
|
|
|
|
|
|
|
|
try: |
|
|
try: |
|
@ -119,49 +130,63 @@ class Job(DailyJob): |
|
|
) |
|
|
) |
|
|
return |
|
|
return |
|
|
except Servico.DoesNotExist: |
|
|
except Servico.DoesNotExist: |
|
|
if iname in self._nomes_gerados: |
|
|
# Tenta encontrar um registro desativado para esta instância # |
|
|
orgao = self._nomes_gerados[iname] |
|
|
servico = Servico.objects.filter( |
|
|
log_entry = orgao.municipio.uf |
|
|
tipo_servico=tipo, instancia=iname |
|
|
servico = Servico( |
|
|
).first() |
|
|
casa_legislativa=orgao, |
|
|
if servico is not None: |
|
|
tipo_servico=tipo, |
|
|
# Reativa o servico # |
|
|
instancia=iname, |
|
|
servico.data_desativacao = None |
|
|
data_ativacao=timezone.localdate(), |
|
|
servico.instancia = iname |
|
|
flag_confirmado=True, |
|
|
self.log_reativa(servico) |
|
|
) |
|
|
|
|
|
self.log_novo(servico) |
|
|
|
|
|
else: |
|
|
else: |
|
|
if nivel < 4: |
|
|
servico = None |
|
|
# Ignora registros de 3º nível ou abaixo, sem logar # |
|
|
# Tenta encontrar um registro ativo com mesmo domínio # |
|
|
return |
|
|
servico = Servico.objects.filter( |
|
|
try: |
|
|
tipo_servico=tipo, url=dominio, data_desativacao=None |
|
|
servico = Servico.objects.get( |
|
|
).first() |
|
|
tipo_servico=tipo, |
|
|
if servico is not None: |
|
|
url__icontains=dominio, |
|
|
|
|
|
data_desativacao=None, |
|
|
|
|
|
) |
|
|
|
|
|
self.log_update(servico) |
|
|
self.log_update(servico) |
|
|
except Servico.MultipleObjectsReturned: |
|
|
else: |
|
|
self.log_ignore( |
|
|
# Tenta encontrar um registro desativado com mesmo domínio # |
|
|
dominio, |
|
|
servico = Servico.objects.filter( |
|
|
_("existe mais de um registro no SIGI deste domínio."), |
|
|
tipo_servico=tipo, url=dominio |
|
|
log_entry, |
|
|
).first() |
|
|
|
|
|
if servico is not None: |
|
|
|
|
|
servico.instancia = iname |
|
|
|
|
|
self.log_reativa(servico) |
|
|
|
|
|
|
|
|
|
|
|
if servico is None: |
|
|
|
|
|
# Tenta criar o registro # |
|
|
|
|
|
if iname in self._nomes_gerados: |
|
|
|
|
|
orgao = self._nomes_gerados[iname] |
|
|
|
|
|
log_entry = orgao.municipio.uf |
|
|
|
|
|
servico = Servico( |
|
|
|
|
|
casa_legislativa=orgao, |
|
|
|
|
|
tipo_servico=tipo, |
|
|
|
|
|
instancia=iname, |
|
|
|
|
|
data_ativacao=timezone.localdate(), |
|
|
|
|
|
flag_confirmado=True, |
|
|
) |
|
|
) |
|
|
return |
|
|
self.log_novo(servico) |
|
|
except Servico.DoesNotExist: |
|
|
|
|
|
|
|
|
if servico is None: |
|
|
|
|
|
if nivel > 3: |
|
|
|
|
|
# Loga registro não encontrado apenas para 4º+ nível # |
|
|
self.log_ignore( |
|
|
self.log_ignore( |
|
|
dominio, |
|
|
dominio, |
|
|
_("não parece pertencer a nenhum órgão"), |
|
|
_("não parece pertencer a nenhum órgão"), |
|
|
log_entry, |
|
|
log_entry, |
|
|
) |
|
|
) |
|
|
return |
|
|
else: |
|
|
# atualiza o serviço no SIGI |
|
|
# atualiza o serviço no SIGI |
|
|
servico.url = dominio |
|
|
servico.url = dominio |
|
|
servico.hospedagem_interlegis = True |
|
|
servico.instancia = iname |
|
|
servico.data_verificacao = timezone.localtime() |
|
|
servico.hospedagem_interlegis = True |
|
|
servico.resultado_verificacao = "F" # Funcionando |
|
|
servico.data_verificacao = timezone.localtime() |
|
|
servico.flag_confirmado = True |
|
|
servico.resultado_verificacao = "F" # Funcionando |
|
|
servico.save() |
|
|
servico.flag_confirmado = True |
|
|
|
|
|
servico.save() |
|
|
|
|
|
|
|
|
def processa_uf(self, uf): |
|
|
def processa_uf(self, uf): |
|
|
file_path = settings.REGISTRO_PATH / f"{uf.sigla.lower()}.leg.br." |
|
|
file_path = settings.REGISTRO_PATH / f"{uf.sigla.lower()}.leg.br." |
|
@ -286,6 +311,16 @@ class Job(DailyJob): |
|
|
uf = srv.casa_legislativa.municipio.uf |
|
|
uf = srv.casa_legislativa.municipio.uf |
|
|
self._log[uf]["sumario"]["atualizados"] += 1 |
|
|
self._log[uf]["sumario"]["atualizados"] += 1 |
|
|
|
|
|
|
|
|
|
|
|
def log_reativa(self, srv): |
|
|
|
|
|
orgao = srv.casa_legislativa |
|
|
|
|
|
uf = orgao.municipio.uf |
|
|
|
|
|
msg = _( |
|
|
|
|
|
f"Instância {srv.instancia} de {srv.tipo_servico.nome} " |
|
|
|
|
|
f"para {orgao.nome} ({uf.sigla}) reativada no SIGI" |
|
|
|
|
|
) |
|
|
|
|
|
self._log[uf]["sumario"]["atualizados"] += 1 |
|
|
|
|
|
self.info(msg, uf) |
|
|
|
|
|
|
|
|
def log_remove(self, srv): |
|
|
def log_remove(self, srv): |
|
|
orgao = srv.casa_legislativa |
|
|
orgao = srv.casa_legislativa |
|
|
uf = orgao.municipio.uf |
|
|
uf = orgao.municipio.uf |
|
|