@ -12,7 +12,7 @@ from django.contrib.contenttypes.models import ContentType 
			
		
	
		
		
			
				
					from  django . core . exceptions  import  ValidationError from  django . core . exceptions  import  ValidationError  
			
		
	
		
		
			
				
					from  django . db  import  models ,  transaction from  django . db  import  models ,  transaction  
			
		
	
		
		
			
				
					from  django . forms  import  ModelForm from  django . forms  import  ModelForm  
			
		
	
		
		
			
				
					
					from  django . utils . translation  import  ugettext_lazy  as  _ from  django . utils . translation  import  ugettext_lazy  as  _ ,  string_concat  
			
				
				
			
		
	
		
		
	
		
		
			
				
					import  django_filters import  django_filters  
			
		
	
		
		
			
				
					
 
			
		
	
		
		
			
				
					from  sapl . base . models  import  Autor ,  TipoAutor from  sapl . base . models  import  Autor ,  TipoAutor  
			
		
	
	
		
		
			
				
					
						
						
						
							
								 
						
					 
					@ -34,6 +34,15 @@ ACTION_CREATE_USERS_AUTOR_CHOICE = [ 
			
		
	
		
		
			
				
					] ]  
			
		
	
		
		
			
				
					
 
			
		
	
		
		
			
				
					
 
			
		
	
		
		
			
				
					STATUS_USER_CHOICE  =  [  
			
		
	
		
		
			
				
					    ( ' R ' ,  _ ( ' Apenas retirar Perfil de Autor do Usuário que está sendo '  
			
		
	
		
		
			
				
					            '  desvinculado ' ) ) ,  
			
		
	
		
		
			
				
					    ( ' D ' ,  _ ( ' Retirar Perfil de Autor e desativar Usuário que está sendo '  
			
		
	
		
		
			
				
					            '  desvinculado ' ) ) ,  
			
		
	
		
		
			
				
					    ( ' X ' ,  _ ( ' Excluir Usuário ' ) ) ,  
			
		
	
		
		
			
				
					]  
			
		
	
		
		
			
				
					
 
			
		
	
		
		
			
				
					
 
			
		
	
		
		
			
				
					class  TipoAutorForm ( ModelForm ) : class  TipoAutorForm ( ModelForm ) :  
			
		
	
		
		
			
				
					
 
			
		
	
		
		
			
				
					    content_type  =  forms . ModelChoiceField (     content_type  =  forms . ModelChoiceField (  
			
		
	
	
		
		
			
				
					
						
							
								 
						
						
							
								 
						
						
					 
					@ -97,7 +106,8 @@ class AutorForm(ModelForm): 
			
		
	
		
		
			
				
					        required = False ,         required = False ,  
			
		
	
		
		
			
				
					        label = _ ( ' Confirmar Email ' ) )         label = _ ( ' Confirmar Email ' ) )  
			
		
	
		
		
			
				
					
 
			
		
	
		
		
			
				
					
					    username  =  forms . CharField (     username  =  forms . CharField ( label = get_user_model ( ) . _meta . get_field (  
			
				
				
			
		
	
		
		
	
		
		
			
				
					        ' username ' ) . verbose_name . capitalize ( ) ,  
			
		
	
		
		
			
				
					        required = False ,         required = False ,  
			
		
	
		
		
			
				
					        max_length = 50 )         max_length = 50 )  
			
		
	
		
		
			
				
					
 
			
		
	
	
		
		
			
				
					
						
						
						
							
								 
						
					 
					@ -111,10 +121,19 @@ class AutorForm(ModelForm): 
			
		
	
		
		
			
				
					                                                 widget = forms . RadioSelect ( ) )                                                  widget = forms . RadioSelect ( ) )  
			
		
	
		
		
			
				
					
 
			
		
	
		
		
			
				
					    action_user  =  forms . ChoiceField (     action_user  =  forms . ChoiceField (  
			
		
	
		
		
			
				
					
					        label = _ ( ' Usuário de  acesso ao Sistema para este Autor ' ) ,         label = _ ( ' Usuário com  acesso ao Sistema para este Autor ' ) ,  
			
				
				
			
		
	
		
		
	
		
		
			
				
					        choices = ACTION_CREATE_USERS_AUTOR_CHOICE ,         choices = ACTION_CREATE_USERS_AUTOR_CHOICE ,  
			
		
	
		
		
			
				
					        widget = forms . RadioSelect ( ) )         widget = forms . RadioSelect ( ) )  
			
		
	
		
		
			
				
					
 
			
		
	
		
		
			
				
					    status_user  =  forms . ChoiceField (  
			
		
	
		
		
			
				
					        label = _ ( ' Bloqueio do Usuário Existente ' ) ,  
			
		
	
		
		
			
				
					        choices = STATUS_USER_CHOICE ,  
			
		
	
		
		
			
				
					        widget = forms . RadioSelect ( ) ,  
			
		
	
		
		
			
				
					        required = False ,  
			
		
	
		
		
			
				
					        help_text = _ ( ' Se vc está trocando ou removendo o usuário deste Autor,  '  
			
		
	
		
		
			
				
					                    ' como o Sistema deve proceder com o usuário que está sendo '  
			
		
	
		
		
			
				
					                    '  desvinculado? ' ) )  
			
		
	
		
		
			
				
					
 
			
		
	
		
		
			
				
					    class  Meta :     class  Meta :  
			
		
	
		
		
			
				
					        model  =  Autor         model  =  Autor  
			
		
	
		
		
			
				
					        fields  =  [ ' tipo ' ,         fields  =  [ ' tipo ' ,  
			
		
	
	
		
		
			
				
					
						
							
								 
						
						
							
								 
						
						
					 
					@ -150,16 +169,19 @@ class AutorForm(ModelForm): 
			
		
	
		
		
			
				
					                               12 ) ) )                                12 ) ) )  
			
		
	
		
		
			
				
					
 
			
		
	
		
		
			
				
					        row2  =  Row ( to_column ( ( InlineRadios ( ' action_user ' ) ,  8 ) ) ,         row2  =  Row ( to_column ( ( InlineRadios ( ' action_user ' ) ,  8 ) ) ,  
			
		
	
		
		
			
				
					
					                   to_column ( ( ' username ' ,  4 ) ) )                    to_column ( ( Div ( ' username ' ) ,  4 ) ) )  
			
				
				
			
		
	
		
		
	
		
		
			
				
					        row3  =  Row ( to_column ( ( ' senha ' ,  3 ) ) ,         row3  =  Row ( to_column ( ( ' senha ' ,  3 ) ) ,  
			
		
	
		
		
			
				
					                   to_column ( ( ' senha_confirma ' ,  3 ) ) ,                    to_column ( ( ' senha_confirma ' ,  3 ) ) ,  
			
		
	
		
		
			
				
					                   to_column ( ( ' email ' ,  3 ) ) ,                    to_column ( ( ' email ' ,  3 ) ) ,  
			
		
	
		
		
			
				
					                   to_column ( ( ' confirma_email ' ,  3 ) ) ,                    to_column ( ( ' confirma_email ' ,  3 ) ) ,  
			
		
	
		
		
			
				
					                   css_class = ' new_user_fields hidden ' )                    css_class = ' new_user_fields hidden ' )  
			
		
	
		
		
			
				
					
 
			
		
	
		
		
			
				
					        row4  =  Row ( to_column ( ( Div ( InlineRadios ( ' status_user ' ) ,  
			
		
	
		
		
			
				
					                                  css_class = ' radiogroup-status hidden ' ) ,  12 ) ) )  
			
		
	
		
		
			
				
					
 
			
		
	
		
		
			
				
					        controle_acesso  =  Fieldset (         controle_acesso  =  Fieldset (  
			
		
	
		
		
			
				
					            _ ( ' Controle de Acesso do Autor ' ) ,             _ ( ' Controle de Acesso do Autor ' ) ,  
			
		
	
		
		
			
				
					
					            row2 ,  row3             row2 ,  row3 ,  row4  
			
				
				
			
		
	
		
		
	
		
		
			
				
					        )         )  
			
		
	
		
		
			
				
					
 
			
		
	
		
		
			
				
					        self . helper  =  FormHelper ( )         self . helper  =  FormHelper ( )  
			
		
	
	
		
		
			
				
					
						
						
						
							
								 
						
					 
					@ -168,7 +190,6 @@ class AutorForm(ModelForm): 
			
		
	
		
		
			
				
					        super ( AutorForm ,  self ) . __init__ ( * args ,  * * kwargs )         super ( AutorForm ,  self ) . __init__ ( * args ,  * * kwargs )  
			
		
	
		
		
			
				
					
 
			
		
	
		
		
			
				
					        self . fields [ ' action_user ' ] . initial  =  ' N '         self . fields [ ' action_user ' ] . initial  =  ' N '  
			
		
	
		
		
			
				
					        self . fields [ ' action_user ' ] . inline_class  =  True  
			
		
	
		
		
			
				
					
 
			
		
	
		
		
			
				
					        if  self . instance . pk :         if  self . instance . pk :  
			
		
	
		
		
			
				
					            if  self . instance . autor_related :             if  self . instance . autor_related :  
			
		
	
	
		
		
			
				
					
						
						
						
							
								 
						
					 
					@ -180,6 +201,13 @@ class AutorForm(ModelForm): 
			
		
	
		
		
			
				
					            if  self . instance . user :             if  self . instance . user :  
			
		
	
		
		
			
				
					                self . fields [ ' username ' ] . initial  =  self . instance . user . username                 self . fields [ ' username ' ] . initial  =  self . instance . user . username  
			
		
	
		
		
			
				
					                self . fields [ ' action_user ' ] . initial  =  ' A '                 self . fields [ ' action_user ' ] . initial  =  ' A '  
			
		
	
		
		
			
				
					                self . fields [ ' status_user ' ] . initial  =  ' R '  
			
		
	
		
		
			
				
					                self . fields [ ' username ' ] . label  =  string_concat (  
			
		
	
		
		
			
				
					                    self . fields [ ' username ' ] . label ,  
			
		
	
		
		
			
				
					                    '  ( ' ,  self . instance . user . username ,  ' ) ' )  
			
		
	
		
		
			
				
					            self . fields [ ' username ' ] . widget . attrs . update ( {  
			
		
	
		
		
			
				
					                ' data ' :  self . instance . user . username  
			
		
	
		
		
			
				
					                if  self . instance . user  else  ' ' } )  
			
		
	
		
		
			
				
					
 
			
		
	
		
		
			
				
					    def  valida_igualdade ( self ,  texto1 ,  texto2 ,  msg ) :     def  valida_igualdade ( self ,  texto1 ,  texto2 ,  msg ) :  
			
		
	
		
		
			
				
					        if  texto1  !=  texto2 :         if  texto1  !=  texto2 :  
			
		
	
	
		
		
			
				
					
						
						
						
							
								 
						
					 
					@ -190,12 +218,20 @@ class AutorForm(ModelForm): 
			
		
	
		
		
			
				
					        User  =  get_user_model ( )         User  =  get_user_model ( )  
			
		
	
		
		
			
				
					        cd  =  self . cleaned_data         cd  =  self . cleaned_data  
			
		
	
		
		
			
				
					
 
			
		
	
		
		
			
				
					
					        if  ' username '  not  in  cd :         if  ' username '  not  in  cd  or  not  cd [ ' username ' ]  :  
			
				
				
			
		
	
		
		
	
		
		
			
				
					            raise  ValidationError ( _ ( ' O username deve ser informado. ' ) )             raise  ValidationError ( _ ( ' O username deve ser informado. ' ) )  
			
		
	
		
		
			
				
					
 
			
		
	
		
		
			
				
					
					        if  ' action_user '  not  in  cd :         if  ' action_user '  not  in  cd  or  not  cd [ ' action_user ' ]  :  
			
				
				
			
		
	
		
		
	
		
		
			
				
					            raise  ValidationError ( _ ( ' Informe se o Autor terá usuário  '             raise  ValidationError ( _ ( ' Informe se o Autor terá usuário  '  
			
		
	
		
		
			
				
					
					                                    ' para acesso ao Sistema. ' ) )                                     ' vinculado para acesso ao Sistema. ' ) )  
			
				
				
			
		
	
		
		
	
		
		
			
				
					
 
			
		
	
		
		
			
				
					        if  self . instance . pk  and  self . instance . user_id :  
			
		
	
		
		
			
				
					            if  self . instance . user . username  !=  cd [ ' username ' ] :  
			
		
	
		
		
			
				
					                if  ' status_user '  not  in  cd  or  cd [ ' status_user ' ] :  
			
		
	
		
		
			
				
					                    raise  ValidationError (  
			
		
	
		
		
			
				
					                        _ ( ' Foi trocado ou removido o usuário deste Autor,  '  
			
		
	
		
		
			
				
					                          ' mas não foi informado com se deve proceder com o  '  
			
		
	
		
		
			
				
					                          ' usuário que está sendo desvinculado? ' ) )  
			
		
	
		
		
			
				
					
 
			
		
	
		
		
			
				
					        qs_user  =  User . objects . all ( )         qs_user  =  User . objects . all ( )  
			
		
	
		
		
			
				
					        qs_autor  =  Autor . objects . all ( )         qs_autor  =  Autor . objects . all ( )  
			
		
	
	
		
		
			
				
					
						
						
						
							
								 
						
					 
					@ -209,7 +245,7 @@ class AutorForm(ModelForm): 
			
		
	
		
		
			
				
					            if  User . objects . filter ( username = cd [ ' username ' ] ) . exists ( ) :             if  User . objects . filter ( username = cd [ ' username ' ] ) . exists ( ) :  
			
		
	
		
		
			
				
					                raise  ValidationError (                 raise  ValidationError (  
			
		
	
		
		
			
				
					                    _ ( ' Já existe usuário com o username  " %s " .  '                     _ ( ' Já existe usuário com o username  " %s " .  '  
			
		
	
		
		
			
				
					
					                      ' Para usá-lo  você deve selecionar  '                       ' Para utilizar esse username  você deve selecionar  '  
			
				
				
			
		
	
		
		
	
		
		
			
				
					                      ' " Associar um usuário existente " . ' )  %  cd [ ' username ' ] )                       ' " Associar um usuário existente " . ' )  %  cd [ ' username ' ] )  
			
		
	
		
		
			
				
					
 
			
		
	
		
		
			
				
					            if  ( ' senha '  not  in  cd  or  ' senha_confirma '  not  in  cd  or             if  ( ' senha '  not  in  cd  or  ' senha_confirma '  not  in  cd  or  
			
		
	
	
		
		
			
				
					
						
							
								 
						
						
							
								 
						
						
					 
					@ -242,7 +278,7 @@ class AutorForm(ModelForm): 
			
		
	
		
		
			
				
					            if  not  User . objects . filter ( username = cd [ ' username ' ] ) . exists ( ) :             if  not  User . objects . filter ( username = cd [ ' username ' ] ) . exists ( ) :  
			
		
	
		
		
			
				
					                raise  ValidationError (                 raise  ValidationError (  
			
		
	
		
		
			
				
					                    _ ( ' Não existe usuário com username  " %s " .  '                     _ ( ' Não existe usuário com username  " %s " .  '  
			
		
	
		
		
			
				
					
					                      ' Para usá-lo  você deve selecionar  '                       ' Para utilizar esse username  você deve selecionar  '  
			
				
				
			
		
	
		
		
	
		
		
			
				
					                      ' " Criar novo Usuário " . ' )  %  cd [ ' username ' ] )                       ' " Criar novo Usuário " . ' )  %  cd [ ' username ' ] )  
			
		
	
		
		
			
				
					
 
			
		
	
		
		
			
				
					        if  cd [ ' action_user ' ]  !=  ' N ' :         if  cd [ ' action_user ' ]  !=  ' N ' :  
			
		
	
	
		
		
			
				
					
						
							
								 
						
						
							
								 
						
						
					 
					@ -292,10 +328,10 @@ class AutorForm(ModelForm): 
			
		
	
		
		
			
				
					
 
			
		
	
		
		
			
				
					        user_old  =  autor . user  if  autor . user_id  else  None         user_old  =  autor . user  if  autor . user_id  else  None  
			
		
	
		
		
			
				
					
 
			
		
	
		
		
			
				
					        u  =  None  
			
		
	
		
		
			
				
					        if  self . cleaned_data [ ' action_user ' ]  ==  ' A ' :         if  self . cleaned_data [ ' action_user ' ]  ==  ' A ' :  
			
		
	
		
		
			
				
					            u  =  get_user_model ( ) . objects . get (             u  =  get_user_model ( ) . objects . get (  
			
		
	
		
		
			
				
					                username = self . cleaned_data [ ' username ' ] )                 username = self . cleaned_data [ ' username ' ] )  
			
		
	
		
		
			
				
					            autor . user  =  u  
			
		
	
		
		
			
				
					        elif  self . cleaned_data [ ' action_user ' ]  ==  ' C ' :         elif  self . cleaned_data [ ' action_user ' ]  ==  ' C ' :  
			
		
	
		
		
			
				
					            u  =  get_user_model ( ) . objects . create (             u  =  get_user_model ( ) . objects . create (  
			
		
	
		
		
			
				
					                username = self . cleaned_data [ ' username ' ] ,                 username = self . cleaned_data [ ' username ' ] ,  
			
		
	
	
		
		
			
				
					
						
						
						
							
								 
						
					 
					@ -318,15 +354,29 @@ class AutorForm(ModelForm): 
			
		
	
		
		
			
				
					
 
			
		
	
		
		
			
				
					        autor . save ( )         autor . save ( )  
			
		
	
		
		
			
				
					
 
			
		
	
		
		
			
				
					
					        if  self . cleaned_data [ ' action_user ' ]  !=  ' N ' :         # FIXME melhorar captura de grupo de Autor, levando em conta,  
			
				
				
			
		
	
		
		
			
				
					
					            # FIXME melhorar captura de grupo de Autor, levando em conta         # no mínimo, a tradução.  
			
				
				
			
		
	
		
		
			
				
					            # tradução  
			
		
	
		
		
	
		
		
	
		
		
			
				
					        grupo  =  Group . objects . filter ( name = ' Autor ' ) [ 0 ]         grupo  =  Group . objects . filter ( name = ' Autor ' ) [ 0 ]  
			
		
	
		
		
			
				
					        if  self . cleaned_data [ ' action_user ' ]  !=  ' N ' :  
			
		
	
		
		
			
				
					            autor . user . groups . add ( grupo )             autor . user . groups . add ( grupo )  
			
		
	
		
		
			
				
					
 
			
		
	
		
		
			
				
					            if  user_old  and  user_old  !=  autor . user :             if  user_old  and  user_old  !=  autor . user :  
			
		
	
		
		
			
				
					                user_old . groups . remove ( grupo )                 user_old . groups . remove ( grupo )  
			
		
	
		
		
			
				
					
 
			
		
	
		
		
			
				
					        else :  
			
		
	
		
		
			
				
					            if  ' status_user '  in  self . cleaned_data  and  user_old :  
			
		
	
		
		
			
				
					                if  self . cleaned_data [ ' status_user ' ]  ==  ' X ' :  
			
		
	
		
		
			
				
					                    user_old . delete ( )  
			
		
	
		
		
			
				
					
 
			
		
	
		
		
			
				
					                elif  self . cleaned_data [ ' status_user ' ]  ==  ' D ' :  
			
		
	
		
		
			
				
					                    user_old . groups . remove ( grupo )  
			
		
	
		
		
			
				
					                    user_old . is_active  =  False  
			
		
	
		
		
			
				
					                    user_old . save ( )  
			
		
	
		
		
			
				
					
 
			
		
	
		
		
			
				
					                elif  self . cleaned_data [ ' status_user ' ]  ==  ' R ' :  
			
		
	
		
		
			
				
					                    user_old . groups . remove ( grupo )  
			
		
	
		
		
			
				
					            else :  
			
		
	
		
		
			
				
					                user_old . groups . remove ( grupo )  
			
		
	
		
		
			
				
					
 
			
		
	
		
		
			
				
					        return  autor         return  autor