Browse Source

Formata com black

migracao
Marcio Mazza 5 years ago
parent
commit
b5307d3200
  1. 182
      sapl/legacy/migracao_dados.py

182
sapl/legacy/migracao_dados.py

@ -34,22 +34,49 @@ from sapl.base.models import Autor, TipoAutor, cria_models_tipo_autor
from sapl.comissoes.models import Comissao, Composicao, Participacao, Reuniao from sapl.comissoes.models import Comissao, Composicao, Participacao, Reuniao
from sapl.legacy.models import NormaJuridica as OldNormaJuridica from sapl.legacy.models import NormaJuridica as OldNormaJuridica
from sapl.legacy.models import Numeracao, TipoNumeracaoProtocolo from sapl.legacy.models import Numeracao, TipoNumeracaoProtocolo
from sapl.legacy_migration_settings import (DIR_DADOS_MIGRACAO, DIR_REPO, from sapl.legacy_migration_settings import (
NOME_BANCO_LEGADO, PYTZ_TIMEZONE, DIR_DADOS_MIGRACAO,
SIGLA_CASA) DIR_REPO,
from sapl.materia.models import (AcompanhamentoMateria, DocumentoAcessorio, NOME_BANCO_LEGADO,
MateriaLegislativa, Proposicao, PYTZ_TIMEZONE,
StatusTramitacao, TipoDocumento, SIGLA_CASA,
TipoMateriaLegislativa, TipoProposicao, )
Tramitacao) from sapl.materia.models import (
from sapl.norma.models import (AssuntoNorma, NormaJuridica, NormaRelacionada, AcompanhamentoMateria,
TipoVinculoNormaJuridica) DocumentoAcessorio,
from sapl.parlamentares.models import (Legislatura, Mandato, Parlamentar, MateriaLegislativa,
Partido, TipoAfastamento) Proposicao,
from sapl.protocoloadm.models import (DocumentoAdministrativo, Protocolo, StatusTramitacao,
StatusTramitacaoAdministrativo) TipoDocumento,
from sapl.sessao.models import (ExpedienteMateria, ExpedienteSessao, OrdemDia, TipoMateriaLegislativa,
RegistroVotacao, TipoResultadoVotacao) TipoProposicao,
Tramitacao,
)
from sapl.norma.models import (
AssuntoNorma,
NormaJuridica,
NormaRelacionada,
TipoVinculoNormaJuridica,
)
from sapl.parlamentares.models import (
Legislatura,
Mandato,
Parlamentar,
Partido,
TipoAfastamento,
)
from sapl.protocoloadm.models import (
DocumentoAdministrativo,
Protocolo,
StatusTramitacaoAdministrativo,
)
from sapl.sessao.models import (
ExpedienteMateria,
ExpedienteSessao,
OrdemDia,
RegistroVotacao,
TipoResultadoVotacao,
)
from sapl.utils import normalize from sapl.utils import normalize
from .scripts.normaliza_dump_mysql import normaliza_dump_mysql from .scripts.normaliza_dump_mysql import normaliza_dump_mysql
@ -77,9 +104,7 @@ one_to_one_constraints = []
primeira_vez = [] primeira_vez = []
# apps quase não têm interseção # apps quase não têm interseção
name_sets = [ name_sets = [(ac.label, set(m.__name__ for m in ac.get_models())) for ac in appconfs]
(ac.label, set(m.__name__ for m in ac.get_models())) for ac in appconfs
]
for a1, s1 in name_sets: for a1, s1 in name_sets:
for a2, s2 in name_sets: for a2, s2 in name_sets:
if a1 is not a2: if a1 is not a2:
@ -144,9 +169,7 @@ for nome_novo, nome_antigo in (
("comissao", "cod_comissao"), ("comissao", "cod_comissao"),
("periodo", "cod_periodo_comp"), ("periodo", "cod_periodo_comp"),
): ):
campos_novos_para_antigos[ campos_novos_para_antigos[Composicao._meta.get_field(nome_novo)] = nome_antigo
Composicao._meta.get_field(nome_novo)
] = nome_antigo
# campos virtuais de Proposicao para funcionar com get_fk_related # campos virtuais de Proposicao para funcionar com get_fk_related
@ -214,9 +237,7 @@ def get_pk_legado(tabela):
# cod_parlamentar, cod_periodo_comp, cod_cargo # cod_parlamentar, cod_periodo_comp, cod_cargo
# mas essa parece sempre ser uma chave candidata # mas essa parece sempre ser uma chave candidata
return "cod_parlamentar", "cod_sessao_leg", "cod_cargo" return "cod_parlamentar", "cod_sessao_leg", "cod_cargo"
res = exec_legado( res = exec_legado('show index from {} WHERE Key_name = "PRIMARY"'.format(tabela))
'show index from {} WHERE Key_name = "PRIMARY"'.format(tabela)
)
return [r[4] for r in res] return [r[4] for r in res]
@ -243,9 +264,7 @@ class ForeignKeyFaltando(ObjectDoesNotExist):
self.valor = valor self.valor = valor
self.old = old self.old = old
msg = ( msg = "FK não encontrada para [{campo} = {valor}] (em {tabela} / pk = {pk})" # noqa
"FK não encontrada para [{campo} = {valor}] (em {tabela} / pk = {pk})"
) # noqa
@property @property
def dados(self): def dados(self):
@ -255,10 +274,7 @@ class ForeignKeyFaltando(ObjectDoesNotExist):
sql = "select * from {} where {};".format( sql = "select * from {} where {};".format(
tabela, tabela,
" and ".join( " and ".join(
[ ["{} = {}".format(k, com_aspas_se_necessario(v)) for k, v in pk.items()]
"{} = {}".format(k, com_aspas_se_necessario(v))
for k, v in pk.items()
]
), ),
) )
return OrderedDict( return OrderedDict(
@ -460,9 +476,7 @@ def unifica_autores_repetidos_no_legado(campo_agregador):
# usamos uma tupla neutra se o conjunto é vazio # usamos uma tupla neutra se o conjunto é vazio
# p q a query seja sintaticamente correta # p q a query seja sintaticamente correta
ids_ja_migrados = formatar_lista_para_sql( ids_ja_migrados = formatar_lista_para_sql(get_all_ids_from_model(Autor) or [-1000])
get_all_ids_from_model(Autor) or [-1000]
)
# enumeramos a repeticoes segundo o campo relevante # enumeramos a repeticoes segundo o campo relevante
# (p. ex. cod_parlamentar ou cod_comissao) # (p. ex. cod_parlamentar ou cod_comissao)
@ -533,9 +547,7 @@ def unifica_autores_repetidos_no_legado(campo_agregador):
# Finalmente excluimos os autores redundantes, # Finalmente excluimos os autores redundantes,
# cujas referências foram todas substituídas a essa altura # cujas referências foram todas substituídas a essa altura
exec_legado_em_subconjunto( exec_legado_em_subconjunto("delete from autor where cod_autor in {}", apagar)
"delete from autor where cod_autor in {}", apagar
)
def anula_tipos_origem_externa_invalidos(): def anula_tipos_origem_externa_invalidos():
@ -599,9 +611,7 @@ def checa_registros_votacao_ambiguos_e_remove_nao_usados():
# exclui registros não usados (zumbis) # exclui registros não usados (zumbis)
todos = set( todos = set(
primeira_coluna( primeira_coluna(exec_legado("select cod_votacao from registro_votacao"))
exec_legado("select cod_votacao from registro_votacao")
)
) )
nao_usados = todos - ordem.union(expediente) nao_usados = todos - ordem.union(expediente)
exec_legado_em_subconjunto( exec_legado_em_subconjunto(
@ -802,8 +812,7 @@ def uniformiza_banco(primeira_migracao):
garante_coluna_no_legado("proposicao", "num_proposicao int(11) NULL") garante_coluna_no_legado("proposicao", "num_proposicao int(11) NULL")
garante_coluna_no_legado( garante_coluna_no_legado(
"tipo_materia_legislativa", "tipo_materia_legislativa", "ind_num_automatica BOOLEAN NULL DEFAULT FALSE",
"ind_num_automatica BOOLEAN NULL DEFAULT FALSE",
) )
garante_coluna_no_legado( garante_coluna_no_legado(
@ -814,9 +823,7 @@ def uniformiza_banco(primeira_migracao):
# Cria campos cod_presenca_sessao (sendo a nova PK da tabela) # Cria campos cod_presenca_sessao (sendo a nova PK da tabela)
# e dat_sessao em sessao_plenaria_presenca # e dat_sessao em sessao_plenaria_presenca
if not existe_coluna_no_legado( if not existe_coluna_no_legado("sessao_plenaria_presenca", "cod_presenca_sessao"):
"sessao_plenaria_presenca", "cod_presenca_sessao"
):
exec_legado( exec_legado(
""" """
ALTER TABLE sessao_plenaria_presenca ALTER TABLE sessao_plenaria_presenca
@ -828,9 +835,7 @@ def uniformiza_banco(primeira_migracao):
"sessao_plenaria_presenca", "cod_presenca_sessao" "sessao_plenaria_presenca", "cod_presenca_sessao"
) )
garante_coluna_no_legado( garante_coluna_no_legado("sessao_plenaria_presenca", "dat_sessao DATE NULL")
"sessao_plenaria_presenca", "dat_sessao DATE NULL"
)
garante_tabela_no_legado( garante_tabela_no_legado(
""" """
@ -936,11 +941,7 @@ def iter_sql_records(tabela):
def fill_vinculo_norma_juridica(): def fill_vinculo_norma_juridica():
lista = [ lista = [
("A", "Altera o(a)", "Alterado(a) pelo(a)"), ("A", "Altera o(a)", "Alterado(a) pelo(a)"),
( ("R", "Revoga integralmente o(a)", "Revogado(a) integralmente pelo(a)",),
"R",
"Revoga integralmente o(a)",
"Revogado(a) integralmente pelo(a)",
),
("P", "Revoga parcialmente o(a)", "Revogado(a) parcialmente pelo(a)"), ("P", "Revoga parcialmente o(a)", "Revogado(a) parcialmente pelo(a)"),
( (
"T", "T",
@ -952,16 +953,8 @@ def fill_vinculo_norma_juridica():
("E", "Reedita o(a)", "Reeditada pelo(a)"), ("E", "Reedita o(a)", "Reeditada pelo(a)"),
("I", "Reedita com alteração o(a)", "Reeditada com alteração pelo(a)"), ("I", "Reedita com alteração o(a)", "Reeditada com alteração pelo(a)"),
("G", "Regulamenta o(a)", "Regulamentada pelo(a)"), ("G", "Regulamenta o(a)", "Regulamentada pelo(a)"),
( ("K", "Suspende parcialmente o(a)", "Suspenso(a) parcialmente pelo(a)",),
"K", ("L", "Suspende integralmente o(a)", "Suspenso(a) integralmente pelo(a)",),
"Suspende parcialmente o(a)",
"Suspenso(a) parcialmente pelo(a)",
),
(
"L",
"Suspende integralmente o(a)",
"Suspenso(a) integralmente pelo(a)",
),
( (
"N", "N",
"Julga integralmente inconstitucional", "Julga integralmente inconstitucional",
@ -1077,9 +1070,7 @@ def roda_comando_shell(cmd):
def get_arquivos_ajustes_pre_migracao(): def get_arquivos_ajustes_pre_migracao():
return [ return [
DIR_DADOS_MIGRACAO.child( DIR_DADOS_MIGRACAO.child("ajustes_pre_migracao", f"{SIGLA_CASA}.{sufixo}")
"ajustes_pre_migracao", f"{SIGLA_CASA}.{sufixo}"
)
for sufixo in ("sql", "reverter.yaml") for sufixo in ("sql", "reverter.yaml")
] ]
@ -1110,9 +1101,7 @@ def migrar_dados(primeira_migracao=False, apagar_do_legado=False):
# restaura dump # restaura dump
arq_dump = Path( arq_dump = Path(
DIR_DADOS_MIGRACAO.child( DIR_DADOS_MIGRACAO.child("dumps_mysql", "{}.sql".format(NOME_BANCO_LEGADO))
"dumps_mysql", "{}.sql".format(NOME_BANCO_LEGADO)
)
) )
assert arq_dump.exists(), "Dump do mysql faltando: {}".format(arq_dump) assert arq_dump.exists(), "Dump do mysql faltando: {}".format(arq_dump)
info("Restaurando dump mysql de [{}]".format(arq_dump)) info("Restaurando dump mysql de [{}]".format(arq_dump))
@ -1124,9 +1113,7 @@ def migrar_dados(primeira_migracao=False, apagar_do_legado=False):
exec_legado('SET SESSION sql_mode = "NO_AUTO_VALUE_ON_ZERO";') exec_legado('SET SESSION sql_mode = "NO_AUTO_VALUE_ON_ZERO";')
# executa ajustes pré-migração, se existirem # executa ajustes pré-migração, se existirem
arq_ajustes_sql, arq_ajustes_reverter = ( arq_ajustes_sql, arq_ajustes_reverter = get_arquivos_ajustes_pre_migracao()
get_arquivos_ajustes_pre_migracao()
)
if arq_ajustes_sql.exists(): if arq_ajustes_sql.exists():
exec_legado(arq_ajustes_sql.read_file()) exec_legado(arq_ajustes_sql.read_file())
if arq_ajustes_reverter.exists(): if arq_ajustes_reverter.exists():
@ -1186,13 +1173,9 @@ def get_models_a_migrar():
# a migração de TipoProposicao precisa ser feita # a migração de TipoProposicao precisa ser feita
# após TipoMateriaLegislativa e TipoDocumento # após TipoMateriaLegislativa e TipoDocumento
# (porém antes de Proposicao) # (porém antes de Proposicao)
move_para_depois_de( move_para_depois_de(models, TipoProposicao, [TipoMateriaLegislativa, TipoDocumento])
models, TipoProposicao, [TipoMateriaLegislativa, TipoDocumento]
)
assert models.index(TipoProposicao) < models.index(Proposicao) assert models.index(TipoProposicao) < models.index(Proposicao)
move_para_depois_de( move_para_depois_de(models, Proposicao, [MateriaLegislativa, DocumentoAcessorio])
models, Proposicao, [MateriaLegislativa, DocumentoAcessorio]
)
return models return models
@ -1270,12 +1253,9 @@ def migrar_model(model, apagar_do_legado):
] ]
def ja_esta_migrado(old): def ja_esta_migrado(old):
chave = { chave = {campos_velhos_p_novos[c]: getattr(old, c) for c in campos_chave}
campos_velhos_p_novos[c]: getattr(old, c) for c in campos_chave
}
return ( return (
chave in apagados_pelo_usuario chave in apagados_pelo_usuario or model.objects.filter(**chave).exists()
or model.objects.filter(**chave).exists()
) )
ultima_pk_legado = model_legado.objects.count() ultima_pk_legado = model_legado.objects.count()
@ -1423,11 +1403,7 @@ Colocamos então o número de protocolo no campo "número externo".
warn( warn(
"protocolo_faltando", "protocolo_faltando",
msg, msg,
{ {"numero": numero, "cod_documento": old.cod_documento, "nota": nota,},
"numero": numero,
"cod_documento": old.cod_documento,
"nota": nota,
},
) )
new.observacao += ("\n\n" if new.observacao else "") + nota new.observacao += ("\n\n" if new.observacao else "") + nota
@ -1503,9 +1479,7 @@ def adjust_participacao(new, old):
def adjust_normarelacionada(new, old): def adjust_normarelacionada(new, old):
new.tipo_vinculo = TipoVinculoNormaJuridica.objects.get( new.tipo_vinculo = TipoVinculoNormaJuridica.objects.get(sigla=old.tip_vinculo)
sigla=old.tip_vinculo
)
def adjust_protocolo_antes_salvar(new, old): def adjust_protocolo_antes_salvar(new, old):
@ -1535,9 +1509,7 @@ def get_como_resolver_registro_votacao_ambiguo():
def adjust_registrovotacao_antes_salvar(new, old): def adjust_registrovotacao_antes_salvar(new, old):
ordem_dia = OrdemDia.objects.filter( ordem_dia = OrdemDia.objects.filter(pk=old.cod_ordem, materia=old.cod_materia)
pk=old.cod_ordem, materia=old.cod_materia
)
expediente_materia = ExpedienteMateria.objects.filter( expediente_materia = ExpedienteMateria.objects.filter(
pk=old.cod_ordem, materia=old.cod_materia pk=old.cod_ordem, materia=old.cod_materia
) )
@ -1696,9 +1668,7 @@ def adjust_autor(new, old):
with reversion.create_revision(): with reversion.create_revision():
user.save() user.save()
reversion.set_comment( reversion.set_comment(
"Usuário criado pela migração para o autor {}".format( "Usuário criado pela migração para o autor {}".format(old.cod_autor)
old.cod_autor
)
) )
grupo_autor = Group.objects.get(name="Autor") grupo_autor = Group.objects.get(name="Autor")
user.groups.add(grupo_autor) user.groups.add(grupo_autor)
@ -1890,8 +1860,7 @@ def get_apagados_que_geram_ocorrencias_fk(fks_faltando):
return tabela_legado return tabela_legado
tabela_legado_p_model = { tabela_legado_p_model = {
get_tabela_legado_do_model(model): model get_tabela_legado_do_model(model): model for model in get_models_a_migrar()
for model in get_models_a_migrar()
} }
apagados = set() apagados = set()
@ -1909,15 +1878,13 @@ def get_apagados_que_geram_ocorrencias_fk(fks_faltando):
ind_mat_ou_doc ind_mat_ou_doc
].related_model ].related_model
else: else:
nome_campo_fk = { nome_campo_fk = {v: k for k, v in field_renames[model_dependente].items()}[
v: k for k, v in field_renames[model_dependente].items() fk["campo"]
}[fk["campo"]] ]
campo_fk = model_dependente._meta.get_field(nome_campo_fk) campo_fk = model_dependente._meta.get_field(nome_campo_fk)
model_relacionado = campo_fk.related_model model_relacionado = campo_fk.related_model
_, tabela_relacionada, [campo_pk] = get_estrutura_legado( _, tabela_relacionada, [campo_pk] = get_estrutura_legado(model_relacionado)
model_relacionado
)
deleted = Version.objects.get_deleted(model_relacionado) deleted = Version.objects.get_deleted(model_relacionado)
versions = deleted.filter(object_id=fk["valor"]) versions = deleted.filter(object_id=fk["valor"])
if versions: if versions:
@ -1981,8 +1948,7 @@ def get_conflitos_materias_legado_e_producao():
) )
materias_legado = {(t, n, a): id for id, t, n, a in res} materias_legado = {(t, n, a): id for id, t, n, a in res}
materias_producao = { materias_producao = {
(m.tipo_id, m.numero, m.ano): m.id (m.tipo_id, m.numero, m.ano): m.id for m in MateriaLegislativa.objects.all()
for m in MateriaLegislativa.objects.all()
} }
comuns = set(materias_legado) & set(materias_producao) comuns = set(materias_legado) & set(materias_producao)
comuns = {k: (materias_legado[k], materias_producao[k]) for k in comuns} comuns = {k: (materias_legado[k], materias_producao[k]) for k in comuns}

Loading…
Cancel
Save