@ -381,6 +381,15 @@ class Gescon(models.Model):
" <li>Ocorrendo qualquer uma das palavras, o contrato será "
" <li>Ocorrendo qualquer uma das palavras, o contrato será "
" importado.</li></ul> " )
" importado.</li></ul> " )
)
)
orgaos_gestores = models . TextField (
_ ( " Órgãos gestores " ) ,
default = " SCCO " ,
help_text = _ ( " Siglas de órgãos gestores que devem aparecer no campo "
" ORGAOSGESTORESTITULARES "
" <ul><li>Informe um sigla por linha.</li> "
" <li>Ocorrendo qualquer uma das siglas, o contrato será "
" importado.</li></ul> " )
)
email = models . EmailField (
email = models . EmailField (
_ ( " E-mail " ) ,
_ ( " E-mail " ) ,
help_text = _ ( " Caixa de e-mail para onde o relatório diário de "
help_text = _ ( " Caixa de e-mail para onde o relatório diário de "
@ -429,16 +438,13 @@ class Gescon(models.Model):
def importa_contratos ( self ) :
def importa_contratos ( self ) :
self . ultima_importacao = " "
self . ultima_importacao = " "
self . add_message (
self . add_message (
_ ( " Importação iniciada em { : %d / % m/ % Y % H: % M: % S} \n "
_ ( f " Importação iniciada em { datetime . now ( ) : %d/%m/%Y %H:%M:%S } \n "
" ========================================== \n " ) . format (
" ========================================================== \n " )
datetime . now ( )
)
)
)
if self . palavras == " " :
if self . palavras == " " or self . orgaos_gestores == " " :
self . add_message ( _ ( " Nenhuma palavra de pesquisa definida - "
self . add_message ( _ ( " Nenhuma palavra de pesquisa ou orgãos "
" processo abortado. " ) , True )
" gestores definidos - processo abortado. " ) , True )
return
if self . subespecies == " " :
if self . subespecies == " " :
self . add_message ( _ ( " Nenhuma subespécie definida - processo "
self . add_message ( _ ( " Nenhuma subespécie definida - processo "
@ -457,11 +463,14 @@ class Gescon(models.Model):
return
return
palavras = self . palavras . split ( )
palavras = self . palavras . split ( )
orgaos = self . orgaos_gestores . split ( )
subespecies = { tuple ( s . split ( " = " ) ) for s in self . subespecies . split ( ) }
subespecies = { tuple ( s . split ( " = " ) ) for s in self . subespecies . split ( ) }
lista_cnpj = { re . sub ( " [^ \ d] " , " " , o . cnpj ) . zfill ( 14 ) : o
for o in Orgao . objects . exclude ( cnpj = " " )
if re . sub ( " [^ \ d] " , " " , o . cnpj ) != ' ' }
for sigla_gescon , sigla_sigi in subespecies :
for sigla_gescon , sigla_sigi in subespecies :
self . add_message ( _ ( " \n Importando subespécie {s} " . format (
self . add_message ( _ ( f " \n Importando subespécie { sigla_gescon } " ) )
s = sigla_gescon ) ) )
url = self . url_gescon . format ( s = sigla_gescon )
url = self . url_gescon . format ( s = sigla_gescon )
projeto = Projeto . objects . get ( sigla = sigla_sigi )
projeto = Projeto . objects . get ( sigla = sigla_sigi )
@ -469,42 +478,34 @@ class Gescon(models.Model):
try :
try :
response = requests . get ( url , verify = False )
response = requests . get ( url , verify = False )
except Exception as e :
except Exception as e :
self . add_message (
self . add_message ( _ ( f " \t Erro ao acessar { url } : { e . message } " ) )
_ ( " \t Erro ao acessar {url} : {errmsg} " ) . format (
url = url ,
errmsg = e . message . decode ( " utf8 " )
)
)
continue
continue
if not response . ok :
if not response . ok :
self . add_message (
self . add_message (
_ ( " \t Erro ao acessar {url} : {reason} " ) . format (
_ ( f " \t Erro ao acessar { url } : { response . reason } " )
url = url ,
reason = response . reason
)
)
)
continue
continue
if not ' application/json ' in response . headers . get ( ' Content-Type ' ) :
if not ' application/json ' in response . headers . get ( ' Content-Type ' ) :
self . add_message ( _ ( " \t Resultado da consulta à {url} não "
self . add_message ( _ ( f " \t Resultado da consulta à { url } não "
" retornou dados em formato json " ) . format (
" retornou dados em formato json " ) )
url = url
)
)
continue
continue
contratos = response . json ( )
contratos = response . json ( )
# Pegar só os contratos que possuem alguma das palavras-chave
# Pegar só os contratos que possuem alguma das palavras-chave
nossos = [ c for c in contratos
nossos = [
if any ( palavra in c [ ' objeto ' ] for palavra in palavras ) ]
c for c in contratos
if any ( palavra in c [ ' objeto ' ] for palavra in palavras ) or
any ( orgao in c [ ' orgaosGestoresTitulares ' ]
for orgao in orgaos
if c [ ' orgaosGestoresTitulares ' ] is not None )
]
self . add_message (
self . add_message (
_ ( " \t {count} contratos encontrados no Gescon " ) . format (
_ ( f " \t { len ( nossos ) } contratos encontrados no Gescon " )
count = len ( nossos )
)
)
)
novos = 0
novos = 0
@ -514,17 +515,14 @@ class Gescon(models.Model):
for contrato in nossos :
for contrato in nossos :
numero = contrato [ ' numero ' ] . zfill ( 8 )
numero = contrato [ ' numero ' ] . zfill ( 8 )
numero = " {} / {} " . format ( numero [ : 4 ] , numero [ 4 : ] )
numero = f " { numero [ : 4 ] } / { numero [ 4 : ] } "
sigad = contrato [ ' processo ' ] . zfill ( 17 )
sigad = contrato [ ' processo ' ] . zfill ( 17 )
sigad = " {} . {} / {} - {} " . format ( sigad [ : 5 ] , sigad [ 5 : 11 ] ,
sigad = f " { sigad [ : 5 ] } . { sigad [ 5 : 11 ] } / { sigad [ 11 : 15 ] } - { sigad [ 15 : ] } "
sigad [ 11 : 15 ] , sigad [ 15 : ] )
if contrato [ ' cnpjCpfFornecedor ' ] :
if contrato [ ' cnpjCpfFornecedor ' ] :
cnpj = contrato [ ' cnpjCpfFornecedor ' ] . zfill ( 14 )
cnpj = contrato [ ' cnpjCpfFornecedor ' ] . zfill ( 14 )
cnpj = " {} . {} . {} / {} - {} " . format ( cnpj [ : 2 ] , cnpj [ 2 : 5 ] ,
cnpj_masked = ( f " { cnpj [ : 2 ] } . { cnpj [ 2 : 5 ] } . { cnpj [ 5 : 8 ] } / "
cnpj [ 5 : 8 ] , cnpj [ 8 : 12 ] ,
f " { cnpj [ 8 : 12 ] } - { cnpj [ 12 : ] } " )
cnpj [ 12 : ] )
else :
else :
cnpj = None
cnpj = None
@ -541,8 +539,8 @@ class Gescon(models.Model):
if ( cnpj is None ) and ( nome is None ) :
if ( cnpj is None ) and ( nome is None ) :
self . add_message (
self . add_message (
_ ( " \t O contrato {numero} no Gescon não informa o CNPJ "
_ ( f " \t O contrato { numero } no Gescon não informa o CNPJ "
" nem o nome do órgão. " ) . format ( numero = numero )
" nem o nome do órgão. " )
)
)
erros + = 1
erros + = 1
continue
continue
@ -550,13 +548,16 @@ class Gescon(models.Model):
orgao = None
orgao = None
if cnpj is not None :
if cnpj is not None :
try :
if cnpj in lista_cnpj :
orgao = Orgao . objects . get ( cnpj = cnpj )
orgao = lista_cnpj [ cnpj ]
except (
else :
Orgao . DoesNotExist ,
try :
Orgao . MultipleObjectsReturned ) as e :
orgao = Orgao . objects . get ( cnpj = cnpj_masked )
orgao = None
except (
pass
Orgao . DoesNotExist ,
Orgao . MultipleObjectsReturned ) as e :
orgao = None
pass
if ( orgao is None ) and ( nome is not None ) :
if ( orgao is None ) and ( nome is not None ) :
try :
try :
@ -569,14 +570,11 @@ class Gescon(models.Model):
if orgao is None :
if orgao is None :
self . add_message (
self . add_message (
_ ( " \t Órgão não encontrado no SIGI ou mais de um órgão "
_ ( f " \t Órgão não encontrado no SIGI ou mais de um órgão "
" encontrado com o mesmo CNPJ ou nome. Favor "
f " encontrado com o mesmo CNPJ ou nome. Favor "
" regularizar o cadastro: CNPJ: {cnpj} , "
f " regularizar o cadastro: "
" Nome: {nome} " . format (
f " CNPJ: { contrato [ ' cnpjCpfFornecedor ' ] } , "
cnpj = contrato [ ' cnpjCpfFornecedor ' ] ,
f " Nome: { contrato [ ' nomeFornecedor ' ] } " )
nome = contrato [ ' nomeFornecedor ' ]
)
)
)
)
erros + = 1
erros + = 1
continue
continue
@ -628,15 +626,9 @@ class Gescon(models.Model):
convenio . observacao_gescon = ' '
convenio . observacao_gescon = ' '
if convenio . casa_legislativa != orgao :
if convenio . casa_legislativa != orgao :
self . add_message (
self . add_message (
_ ( " \t O órgao no convênio {url} diverge do que "
_ ( f " \t O órgao no convênio { convenio . id } diverge do "
" consta no Gescon ( {cnpj} , {nome} ) " ) . format (
f " que consta no Gescon ( { cnpj } , "
url = reverse ( ' admin: %s _ %s _change ' % (
f " { contrato [ ' nomeFornecedor ' ] } ) " )
convenio . _meta . app_label ,
convenio . _meta . model_name ) ,
args = [ convenio . id ] ) ,
cnpj = cnpj ,
nome = contrato [ ' nomeFornecedor ' ]
)
)
)
convenio . observacao_gescon = _ (
convenio . observacao_gescon = _ (
' ERRO: Órgão diverge do Gescon. Não atualizado! '
' ERRO: Órgão diverge do Gescon. Não atualizado! '
@ -647,19 +639,12 @@ class Gescon(models.Model):
if convenio . num_processo_sf != sigad :
if convenio . num_processo_sf != sigad :
self . add_message (
self . add_message (
_ ( " \t O contrato Gescon nº {numero} corresponde "
_ ( f " \t O contrato Gescon nº { numero } corresponde "
" ao convênio SIGI {url} , mas o NUP sigad "
f " ao convênio SIGI { convenio . id } , mas o NUP "
" diverge (Gescon: {sigad_gescon} , "
f " sigad diverge (Gescon: { sigad } , "
" SIGI: {sigad_sigi} ). CORRIGIDO! " ) . format (
f " SIGI: { convenio . num_processo_sf } ). "
numero = numero ,
" CORRIGIDO! " )
url = reverse ( ' admin: %s _ %s _change ' % (
)
convenio . _meta . app_label ,
convenio . _meta . model_name ) ,
args = [ convenio . id ] ) ,
sigad_gescon = sigad ,
sigad_sigi = convenio . num_processo_sf
)
)
convenio . num_processo_sf = sigad
convenio . num_processo_sf = sigad
convenio . observacao_gescon + = _ (
convenio . observacao_gescon + = _ (
" Número do SIGAD atualizado. \n "
" Número do SIGAD atualizado. \n "
@ -668,19 +653,11 @@ class Gescon(models.Model):
if convenio . num_convenio != numero :
if convenio . num_convenio != numero :
self . add_message (
self . add_message (
_ ( " \t O contrato Gescon ID {id} corresponde ao "
_ ( f " \t O contrato Gescon ID { contrato [ ' id ' ] } "
" convênio SIGI {url} , mas o número do convênio "
f " corresponde ao convênio SIGI { convenio . id } , "
" diverge (Gescon: {numero_gescon} , SIGI: "
" mas o número do convênio diverge ( "
" {numero_sigi} ). CORRIGIDO! " ) . format (
f " Gescon: { numero } , SIGI: { convenio . num_convenio } "
id = contrato [ ' id ' ] ,
" ). CORRIGIDO! " )
url = reverse ( ' admin: %s _ %s _change ' % (
convenio . _meta . app_label ,
convenio . _meta . model_name ) ,
args = [ convenio . id ]
) ,
numero_gescon = numero ,
numero_sigi = convenio . num_convenio
)
)
)
convenio . num_convenio = numero
convenio . num_convenio = numero
convenio . observacao_gescon + = _ (
convenio . observacao_gescon + = _ (
@ -713,44 +690,28 @@ class Gescon(models.Model):
convenio . save ( )
convenio . save ( )
except Exception as e :
except Exception as e :
self . add_message (
self . add_message (
_ ( " Ocorreu um erro ao salvar o convênio {url} no "
_ ( " Ocorreu um erro ao salvar o convênio "
" SIGI. Alguma informação do Gescon pode ter "
f " { convenio . id } no SIGI. Alguma informação do "
" quebrado o sistema. Informe ao suporte. Erro: "
" Gescon pode ter quebrado o sistema. Informe ao "
" {errmsg} " ) . format (
f " suporte. Erro: { e . message } " )
url = reverse ( ' admin: %s _ %s _change ' % (
convenio . _meta . app_label ,
convenio . _meta . model_name ) ,
args = [ convenio . id ]
) ,
errmsg = e . message . decode ( " utf8 " )
)
)
)
erros + = 1
erros + = 1
continue
continue
atualizados + = 1
atualizados + = 1
else :
else :
self . add_message ( _ ( " \t Existem {count} convênios no SIGI "
self . add_message (
" que correspondem ao mesmo contrato no "
_ ( f " \t Existem { chk } convênios no SIGI que "
" Gescon (contrato {numero} , sigad "
" correspondem ao mesmo contrato no Gescon (contrato "
" {sigad} ) " ) . format (
f " { numero } , sigad { sigad } ) " )
count = chk ,
numero = numero ,
sigad = sigad
)
)
)
erros + = 1
erros + = 1
continue
continue
self . add_message (
self . add_message (
_ ( " \t {novos} novos convenios adicionados ao SIGI, "
_ ( f " \t { novos } novos convenios adicionados ao SIGI, "
" {atualizados} atualizados, sendo {alertas} com alertas, e "
f " { atualizados } atualizados, sendo { alertas } com alertas, e "
" {erros} reportados com erro. " ) . format (
f " { erros } reportados com erro. " )
novos = novos ,
atualizados = atualizados ,
alertas = alertas ,
erros = erros
)
)
)
self . save ( )
self . save ( )