|  | @ -4,8 +4,9 @@ from functools import lru_cache, partial | 
			
		
	
		
		
			
				
					|  |  | from subprocess import PIPE, call |  |  | from subprocess import PIPE, call | 
			
		
	
		
		
			
				
					|  |  | 
 |  |  | 
 | 
			
		
	
		
		
			
				
					|  |  | import pkg_resources |  |  | import pkg_resources | 
			
		
	
		
		
			
				
					|  |  | import reversion |  |  |  | 
			
		
	
		
		
			
				
					|  |  | import yaml |  |  | import yaml | 
			
		
	
		
		
			
				
					|  |  |  |  |  | 
 | 
			
		
	
		
		
			
				
					|  |  |  |  |  | import reversion | 
			
		
	
		
		
			
				
					|  |  | from django.apps import apps |  |  | from django.apps import apps | 
			
		
	
		
		
			
				
					|  |  | from django.apps.config import AppConfig |  |  | from django.apps.config import AppConfig | 
			
		
	
		
		
			
				
					|  |  | from django.contrib.auth import get_user_model |  |  | from django.contrib.auth import get_user_model | 
			
		
	
	
		
		
			
				
					|  | @ -15,7 +16,6 @@ from django.core.exceptions import ObjectDoesNotExist | 
			
		
	
		
		
			
				
					|  |  | from django.db import connections, transaction |  |  | from django.db import connections, transaction | 
			
		
	
		
		
			
				
					|  |  | from django.db.models import Count, Max |  |  | from django.db.models import Count, Max | 
			
		
	
		
		
			
				
					|  |  | from django.db.models.base import ModelBase |  |  | from django.db.models.base import ModelBase | 
			
		
	
		
		
			
				
					|  |  | 
 |  |  |  | 
			
		
	
		
		
			
				
					|  |  | from sapl.base.models import AppConfig as AppConf |  |  | from sapl.base.models import AppConfig as AppConf | 
			
		
	
		
		
			
				
					|  |  | from sapl.base.models import (Autor, CasaLegislativa, ProblemaMigracao, |  |  | from sapl.base.models import (Autor, CasaLegislativa, ProblemaMigracao, | 
			
		
	
		
		
			
				
					|  |  |                               TipoAutor) |  |  |                               TipoAutor) | 
			
		
	
	
		
		
			
				
					|  | @ -146,6 +146,7 @@ def exec_sql(sql, db='default'): | 
			
		
	
		
		
			
				
					|  |  | 
 |  |  | 
 | 
			
		
	
		
		
			
				
					|  |  | # UNIFORMIZAÇÃO DO BANCO ANTES DA MIGRAÇÃO ############################### |  |  | # UNIFORMIZAÇÃO DO BANCO ANTES DA MIGRAÇÃO ############################### | 
			
		
	
		
		
			
				
					|  |  | 
 |  |  | 
 | 
			
		
	
		
		
			
				
					|  |  |  |  |  | 
 | 
			
		
	
		
		
			
				
					|  |  | SQL_NAO_TEM_TABELA = ''' |  |  | SQL_NAO_TEM_TABELA = ''' | 
			
		
	
		
		
			
				
					|  |  |    SELECT count(*) |  |  |    SELECT count(*) | 
			
		
	
		
		
			
				
					|  |  |    FROM information_schema.columns |  |  |    FROM information_schema.columns | 
			
		
	
	
		
		
			
				
					|  | @ -182,9 +183,6 @@ def garante_tabela_no_legado(create_table): | 
			
		
	
		
		
			
				
					|  |  | 
 |  |  | 
 | 
			
		
	
		
		
			
				
					|  |  | 
 |  |  | 
 | 
			
		
	
		
		
			
				
					|  |  | def migra_autor(): |  |  | def migra_autor(): | 
			
		
	
		
		
			
				
					|  |  |     SQL_ALTERA_IND_EXCLUIDO = ''' |  |  |  | 
			
		
	
		
		
			
				
					|  |  |         update {} set ind_excluido = null; |  |  |  | 
			
		
	
		
		
			
				
					|  |  |     ''' |  |  |  | 
			
		
	
		
		
			
				
					|  |  | 
 |  |  | 
 | 
			
		
	
		
		
			
				
					|  |  |     SQL_ENUMERA_REPETIDOS = ''' |  |  |     SQL_ENUMERA_REPETIDOS = ''' | 
			
		
	
		
		
			
				
					|  |  |           select cod_parlamentar, COUNT(*) |  |  |           select cod_parlamentar, COUNT(*) | 
			
		
	
	
		
		
			
				
					|  | @ -195,7 +193,7 @@ def migra_autor(): | 
			
		
	
		
		
			
				
					|  |  |     ''' |  |  |     ''' | 
			
		
	
		
		
			
				
					|  |  | 
 |  |  | 
 | 
			
		
	
		
		
			
				
					|  |  |     SQL_INFOS_AUTOR = ''' |  |  |     SQL_INFOS_AUTOR = ''' | 
			
		
	
		
		
			
				
					
					|  |  |           select * from autor  |  |  |           select cod_autor from autor | 
			
				
				
			
		
	
		
		
	
		
		
			
				
					|  |  |           where cod_parlamentar = {} |  |  |           where cod_parlamentar = {} | 
			
		
	
		
		
			
				
					|  |  |           group by cod_autor; |  |  |           group by cod_autor; | 
			
		
	
		
		
			
				
					|  |  |     ''' |  |  |     ''' | 
			
		
	
	
		
		
			
				
					|  | @ -218,44 +216,35 @@ def migra_autor(): | 
			
		
	
		
		
			
				
					|  |  |         delete from autoria where cod_materia in ({}) and cod_autor in ({}); |  |  |         delete from autoria where cod_materia in ({}) and cod_autor in ({}); | 
			
		
	
		
		
			
				
					|  |  |     ''' |  |  |     ''' | 
			
		
	
		
		
			
				
					|  |  | 
 |  |  | 
 | 
			
		
	
		
		
			
				
					
					|  |  |     cursor = exec_legado(SQL_ALTERA_IND_EXCLUIDO.format('autor')) |  |  |     cursor = exec_legado('update autor set ind_excluido = null;') | 
			
				
				
			
		
	
		
		
	
		
		
			
				
					|  |  |     cursor = exec_legado(SQL_ENUMERA_REPETIDOS) |  |  |     cursor = exec_legado(SQL_ENUMERA_REPETIDOS) | 
			
		
	
		
		
			
				
					|  |  | 
 |  |  | 
 | 
			
		
	
		
		
			
				
					
					|  |  |     all_authors = [] |  |  |     autores_parlamentares = [r[0] for r in cursor if r[0]] | 
			
				
				
			
		
	
		
		
	
		
		
			
				
					|  |  | 
 |  |  | 
 | 
			
		
	
		
		
			
				
					
					|  |  |     for response in cursor: |  |  |     for cod_autor in autores_parlamentares: | 
			
				
				
			
		
	
		
		
			
				
					|  |  |         if response[0] is not None: |  |  |  | 
			
		
	
		
		
			
				
					|  |  |             all_authors.append(response) |  |  |  | 
			
		
	
		
		
	
		
		
			
				
					|  |  | 
 |  |  | 
 | 
			
		
	
		
		
			
				
					
					|  |  |     for author in all_authors: |  |  |         sql = SQL_INFOS_AUTOR.format(cod_autor) | 
			
				
				
			
		
	
		
		
			
				
					|  |  |         sql = SQL_INFOS_AUTOR.format(str(author[0])) |  |  |  | 
			
		
	
		
		
			
				
					|  |  |         cursor = exec_legado(sql) |  |  |  | 
			
		
	
		
		
			
				
					|  |  | 
 |  |  |  | 
			
		
	
		
		
			
				
					|  |  |         user = [] |  |  |  | 
			
		
	
		
		
			
				
					|  |  | 
 |  |  |  | 
			
		
	
		
		
			
				
					|  |  |         for response in cursor: |  |  |  | 
			
		
	
		
		
			
				
					|  |  |             user.append(response) |  |  |  | 
			
		
	
		
		
	
		
		
			
				
					|  |  | 
 |  |  | 
 | 
			
		
	
		
		
			
				
					
					|  |  |         last = user.pop(len(user) - 1) |  |  |         cursor = exec_legado(sql) | 
			
				
				
			
		
	
		
		
			
				
					
					|  |  |         ativId = last[0] |  |  |         autores = cursor.fetch_all() | 
			
				
				
			
		
	
		
		
			
				
					
					|  |  |         inativIds =[u[0] for u in user] |  |  |         ids = [a[0] for a in autores] | 
			
				
				
			
		
	
		
		
	
		
		
	
		
		
	
		
		
			
				
					|  |  |  |  |  |         id_ativo, ids_inativos = ids[-1], ids[:-1] | 
			
		
	
		
		
			
				
					|  |  | 
 |  |  | 
 | 
			
		
	
		
		
			
				
					
					|  |  |         tables = ['autoria', 'documento_administrativo', 'proposicao', 'protocolo'] |  |  |         tabelas = ['autoria', 'documento_administrativo', | 
			
				
				
			
		
	
		
		
			
				
					
					|  |  |         for table in tables: |  |  |                    'proposicao', 'protocolo'] | 
			
				
				
			
		
	
		
		
	
		
		
	
		
		
			
				
					|  |  |  |  |  |         for tabela in tabelas: | 
			
		
	
		
		
			
				
					|  |  |             # Para update e delete no MySQL -> SET SQL_SAFE_UPDATES = 0; |  |  |             # Para update e delete no MySQL -> SET SQL_SAFE_UPDATES = 0; | 
			
		
	
		
		
			
				
					
					|  |  |             inativIds = (str(inativIds)).replace(']', '').replace('[', '') |  |  |             ids_inativos = str(ids_inativos).strip('[]') | 
			
				
				
			
		
	
		
		
	
		
		
			
				
					|  |  | 
 |  |  | 
 | 
			
		
	
		
		
			
				
					
					|  |  |             sql = SQL_ENUMERA_AUTORIA_REPETIDOS.format(ativId + ', ' + inativIds) |  |  |             sql = SQL_ENUMERA_AUTORIA_REPETIDOS.format(str(ids).strip('[]')) | 
			
				
				
			
		
	
		
		
	
		
		
			
				
					|  |  |             cursor = exec_legado(sql) |  |  |             cursor = exec_legado(sql) | 
			
		
	
		
		
			
				
					|  |  | 
 |  |  | 
 | 
			
		
	
		
		
			
				
					|  |  |             for response in cursor: |  |  |             for response in cursor: | 
			
		
	
		
		
			
				
					
					|  |  |                 if table == 'autoria': |  |  |                 if tabela == 'autoria': | 
			
				
				
			
		
	
		
		
			
				
					
					|  |  |                     sql = SQL_INFO_AUTORIA.format(response[0], ativId + ', ' + inativIds) |  |  |                     sql = SQL_DELETE_AUTORIA.format(response[0], ids_inativos) | 
			
				
				
			
		
	
		
		
			
				
					|  |  |                     materias = exec_legado(sql) |  |  |  | 
			
		
	
		
		
			
				
					|  |  |                     sql = SQL_DELETE_AUTORIA.format(response[0], inativIds) |  |  |  | 
			
		
	
		
		
			
				
					|  |  | 
 |  |  |  | 
			
		
	
		
		
	
		
		
	
		
		
			
				
					|  |  | 
 |  |  | 
 | 
			
		
	
		
		
			
				
					
					|  |  |             sql = SQL_UPDATE_TABLES_AUTOR.format(table, ativId, inativIds) |  |  |             sql = SQL_UPDATE_TABLES_AUTOR.format( | 
			
				
				
			
		
	
		
		
	
		
		
			
				
					|  |  |  |  |  |                 tabela, id_ativo, ids_inativos) | 
			
		
	
		
		
			
				
					|  |  |             exec_legado(sql) |  |  |             exec_legado(sql) | 
			
		
	
		
		
			
				
					|  |  | 
 |  |  | 
 | 
			
		
	
		
		
			
				
					|  |  | 
 |  |  | 
 | 
			
		
	
	
		
		
			
				
					|  | 
 |