Sistema de Apoio ao Processo Legislativo
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

194 lines
6.7 KiB

from django.contrib.contenttypes.models import ContentType
from django.core.exceptions import ObjectDoesNotExist
from django.db import IntegrityError, transaction
from django.db.models import Count
from sapl.base.models import TipoAutor, Autor
from sapl.comissoes.models import Composicao, Comissao, Reuniao
from sapl.materia.models import DespachoInicial, Autoria, Proposicao, Relatoria, UnidadeTramitacao, Tramitacao, \
MateriaLegislativa
from sapl.norma.models import AutoriaNorma
from sapl.protocoloadm.models import Protocolo, DocumentoAdministrativo, TramitacaoAdministrativo
models_comissoes = [Composicao, DespachoInicial, Relatoria, Reuniao]
models_autor = [Autoria, AutoriaNorma, Proposicao, Protocolo, DocumentoAdministrativo]
def move_comissao(from_id, to_id):
# TODO: verificar se content type é o mesmo para todos os BD
content_type = ContentType.objects.get(id=37)
tipo = TipoAutor.objects.get(id=2)
_from_comissao = Comissao.objects.get(id=from_id)
_to_comissao = Comissao.objects.get(id=to_id)
## TRATA TRAMITACAO
try:
_to_unidade_tramitacao = UnidadeTramitacao.objects.get_or_create(comissao=_to_comissao)
except ObjectDoesNotExist:
_to_unidade_tramitacao = UnidadeTramitacao.objects.create(comissao=_to_comissao)
models_tramitacao = [Tramitacao, TramitacaoAdministrativo]
for m in models_tramitacao:
for t1 in m.objects.filter(unidade_tramitacao_local__comissao=_from_comissao):
t1.unidade_tramitacao_local = _to_unidade_tramitacao
t1.save()
for t1 in m.objects.filter(unidade_tramitacao_destino__comissao=_from_comissao):
t1.unidade_tramitacao_destino = _to_unidade_tramitacao
t1.save()
UnidadeTramitacao.objects.filter(comissao=_from_comissao).delete()
for m in models_comissoes:
print('atualizando model {}'.format(m))
objects = m.objects.filter(comissao=_from_comissao)
for o in objects:
try:
o.comissao = _to_comissao
o.save()
except IntegrityError as e:
print(str(e))
o.delete()
autor_from = Autor.objects.filter(content_type=content_type,
tipo=tipo,
object_id=_from_comissao.id).values_list('id')
if not autor_from:
return
try:
autor_to = Autor.objects.get(content_type=content_type,
tipo=tipo,
object_id=_to_comissao.id)
except ObjectDoesNotExist:
print('criando autor para {}-{}'.format(_to_comissao.id, _to_comissao.nome))
autor_to = Autor.objects.create(nome=_to_comissao.nome,
tipo=tipo,
content_type=content_type,
object_id=_to_comissao.id)
to_delete = []
for m in models_autor:
print('atualizando autoria para {}'.format(m))
objects = m.objects.filter(autor_id__in=autor_from)
for o in objects:
try:
original_autor = o.autor
o.autor = autor_to
o.save()
except IntegrityError as e:
o.autor = original_autor
o.save()
to_delete.append(o)
for d in to_delete:
d.delete()
# REMOVE AUTORES DUPLICADOS
Autor.objects.filter(id__in=autor_from).delete()
def estatisticas():
# TODO: verificar se content type é o mesmo para todos os BD
content_type = ContentType.objects.get(id=37)
tipo = TipoAutor.objects.get(id=2)
for c in Comissao.objects.all().order_by('nome'):
print('-------------------------------------------------------------------')
print(c)
for m in models_comissoes + [UnidadeTramitacao]:
model_name = m.__name__
total = m.objects.filter(comissao=c).count()
print(model_name, total)
try:
autor = Autor.objects.get(content_type=content_type, tipo=tipo, object_id=c.id)
for a in models_autor:
model_name = a.__name__
total = a.objects.filter(autor=autor).count()
print(model_name, total)
except Exception as e:
print(str(e))
pass
print('-------------------------------------------------------------------')
def delete_comissao(id):
# TODO: verificar se content type é o mesmo para todos os BD
content_type = ContentType.objects.get(id=37)
tipo = TipoAutor.objects.get(id=2)
comissao = Comissao.objects.get(id=id)
for m in models_comissoes:
m.objects.filter(comissao=comissao).delete()
try:
autor = Autor.objects.get(content_type=content_type, tipo=tipo, object_id=comissao.id)
for a in models_autor:
a.objects.filter(autor=autor).delete()
autor.delete()
except Exception as e:
print(str(e))
try:
unidate_tramitacao = UnidadeTramitacao.objects.get(comissao=comissao)
models_tramitacao = [Tramitacao, TramitacaoAdministrativo]
for m in models_tramitacao:
m.objects.filter(unidade_tramitacao_local=unidate_tramitacao).delete()
m.objects.filter(unidade_tramitacao_destino=unidate_tramitacao).delete()
unidate_tramitacao.delete()
except Exception as e:
print(e)
comissao.delete()
def deduplicate_comissao():
# TODO: verificar se content type é o mesmo para todos os BD
content_type = ContentType.objects.get(id=37)
tipo = TipoAutor.objects.get(id=2)
comissoes_repetidas = [(c['nome'], c['total']) for c in
Comissao.objects.values('nome').annotate(total=Count('nome')).filter(total__gt=1)]
print(comissoes_repetidas)
for cr in comissoes_repetidas:
comissoes = list(Comissao.objects.filter(nome=cr[0]).order_by('id').values_list('id', flat=True))
print(cr)
print(comissoes)
## TODO: PODEM EXISTIR CASOS DA COMISSAO DE DESTINO NAO TER AUTOR, TERIA QUE CRIAR
## TODO: POR ENQUANTO OPTEI POR PEGAR A ULTIMA COMISSAO COM AUTOR CRIADO
while True:
c = comissoes.pop(0)
try:
Autor.objects.get(content_type=content_type, tipo=tipo, object_id=c)
comissoes = [c] + comissoes
break
except ObjectDoesNotExist:
comissoes.append(c)
print(comissoes)
principal = comissoes[0]
repetidas = comissoes[1:]
for r in repetidas:
move_comissao(r, principal)
print('apagando comissao {}'.format(r))
Comissao.objects.get(id=r).delete()
estatisticas()
deduplicate_comissao()
estatisticas()