|
@ -1,5 +1,6 @@ |
|
|
|
|
|
|
|
|
from django.conf import settings |
|
|
from django.conf import settings |
|
|
|
|
|
from django.contrib.auth import get_user_model |
|
|
from django.contrib.auth.mixins import PermissionRequiredMixin |
|
|
from django.contrib.auth.mixins import PermissionRequiredMixin |
|
|
from django.contrib.auth.models import Group |
|
|
from django.contrib.auth.models import Group |
|
|
from django.contrib.auth.tokens import default_token_generator |
|
|
from django.contrib.auth.tokens import default_token_generator |
|
@ -8,7 +9,7 @@ from django.core.urlresolvers import reverse |
|
|
from django.db.models import Count, Q |
|
|
from django.db.models import Count, Q |
|
|
from django.http import HttpResponseRedirect |
|
|
from django.http import HttpResponseRedirect |
|
|
from django.utils.encoding import force_bytes |
|
|
from django.utils.encoding import force_bytes |
|
|
from django.utils.http import urlsafe_base64_encode |
|
|
from django.utils.http import urlsafe_base64_encode, urlsafe_base64_decode |
|
|
from django.utils.translation import ugettext_lazy as _ |
|
|
from django.utils.translation import ugettext_lazy as _ |
|
|
from django.views.generic.base import TemplateView |
|
|
from django.views.generic.base import TemplateView |
|
|
from django_filters.views import FilterView |
|
|
from django_filters.views import FilterView |
|
@ -21,6 +22,7 @@ from sapl.crud.base import CrudAux |
|
|
from sapl.materia.models import MateriaLegislativa, TipoMateriaLegislativa |
|
|
from sapl.materia.models import MateriaLegislativa, TipoMateriaLegislativa |
|
|
from sapl.parlamentares.models import Parlamentar |
|
|
from sapl.parlamentares.models import Parlamentar |
|
|
from sapl.sessao.models import OrdemDia, SessaoPlenaria |
|
|
from sapl.sessao.models import OrdemDia, SessaoPlenaria |
|
|
|
|
|
from sapl.utils import sapl_logger |
|
|
|
|
|
|
|
|
from .forms import (CasaLegislativaForm, ConfiguracoesAppForm, |
|
|
from .forms import (CasaLegislativaForm, ConfiguracoesAppForm, |
|
|
RelatorioAtasFilterSet, |
|
|
RelatorioAtasFilterSet, |
|
@ -36,6 +38,18 @@ def get_casalegislativa(): |
|
|
return CasaLegislativa.objects.first() |
|
|
return CasaLegislativa.objects.first() |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
class ConfirmarEmailView(TemplateView): |
|
|
|
|
|
template_name = "email/confirma.html" |
|
|
|
|
|
|
|
|
|
|
|
def get(self, request, *args, **kwargs): |
|
|
|
|
|
uid = urlsafe_base64_decode(self.kwargs['uidb64']) |
|
|
|
|
|
user = get_user_model().objects.get(id=uid) |
|
|
|
|
|
user.is_active = True |
|
|
|
|
|
user.save() |
|
|
|
|
|
context = self.get_context_data(**kwargs) |
|
|
|
|
|
return self.render_to_response(context) |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
class TipoAutorCrud(CrudAux): |
|
|
class TipoAutorCrud(CrudAux): |
|
|
model = TipoAutor |
|
|
model = TipoAutor |
|
|
help_path = 'tipo-autor' |
|
|
help_path = 'tipo-autor' |
|
@ -57,9 +71,11 @@ class AutorCrud(CrudAux): |
|
|
def delete(self, *args, **kwargs): |
|
|
def delete(self, *args, **kwargs): |
|
|
self.object = self.get_object() |
|
|
self.object = self.get_object() |
|
|
|
|
|
|
|
|
# FIXME melhorar captura de grupo de Autor, levando em conta trad |
|
|
if self.object.user: |
|
|
grupo = Group.objects.filter(name='Autor')[0] |
|
|
# FIXME melhorar captura de grupo de Autor, levando em conta |
|
|
self.object.user.groups.remove(grupo) |
|
|
# trad |
|
|
|
|
|
grupo = Group.objects.filter(name='Autor')[0] |
|
|
|
|
|
self.object.user.groups.remove(grupo) |
|
|
|
|
|
|
|
|
return CrudAux.DeleteView.delete(self, *args, **kwargs) |
|
|
return CrudAux.DeleteView.delete(self, *args, **kwargs) |
|
|
|
|
|
|
|
@ -67,50 +83,65 @@ class AutorCrud(CrudAux): |
|
|
layout_key = None |
|
|
layout_key = None |
|
|
form_class = AutorForm |
|
|
form_class = AutorForm |
|
|
|
|
|
|
|
|
|
|
|
def form_valid(self, form): |
|
|
|
|
|
# devido a implement do form o form_valid do Crud deve ser pulado |
|
|
|
|
|
return super(CrudAux.UpdateView, self).form_valid(form) |
|
|
|
|
|
|
|
|
|
|
|
def post(self, request, *args, **kwargs): |
|
|
|
|
|
if request.user.is_superuser: |
|
|
|
|
|
self.form_class = AutorFormForAdmin |
|
|
|
|
|
return CrudAux.UpdateView.post(self, request, *args, **kwargs) |
|
|
|
|
|
|
|
|
def get(self, request, *args, **kwargs): |
|
|
def get(self, request, *args, **kwargs): |
|
|
if request.user.is_superuser: |
|
|
if request.user.is_superuser: |
|
|
self.form_class = AutorFormForAdmin |
|
|
self.form_class = AutorFormForAdmin |
|
|
return CrudAux.UpdateView.get(self, request, *args, **kwargs) |
|
|
return CrudAux.UpdateView.get(self, request, *args, **kwargs) |
|
|
|
|
|
|
|
|
def get_success_url(self): |
|
|
def get_success_url(self): |
|
|
|
|
|
|
|
|
# FIXME try except - testar envio de emails |
|
|
|
|
|
|
|
|
|
|
|
pk_autor = self.object.id |
|
|
pk_autor = self.object.id |
|
|
kwargs = {} |
|
|
url_reverse = reverse('sapl.base:autor_detail', |
|
|
user = self.object.user |
|
|
kwargs={'pk': pk_autor}) |
|
|
|
|
|
try: |
|
|
"""if user.is_active: |
|
|
kwargs = {} |
|
|
return reverse('sapl.base:autor_detail', |
|
|
user = self.object.user |
|
|
kwargs={'pk': pk_autor})""" |
|
|
|
|
|
|
|
|
if not user: |
|
|
kwargs['token'] = default_token_generator.make_token(user) |
|
|
return url_reverse |
|
|
kwargs['uidb64'] = urlsafe_base64_encode(force_bytes(user.pk)) |
|
|
|
|
|
assunto = "SAPL - Confirmação de Conta" |
|
|
kwargs['token'] = default_token_generator.make_token(user) |
|
|
full_url = self.request.get_raw_uri() |
|
|
kwargs['uidb64'] = urlsafe_base64_encode(force_bytes(user.pk)) |
|
|
url_base = full_url[:full_url.find('sistema') - 1] |
|
|
assunto = "SAPL - Confirmação de Conta" |
|
|
|
|
|
full_url = self.request.get_raw_uri() |
|
|
mensagem = ( |
|
|
url_base = full_url[:full_url.find('sistema') - 1] |
|
|
"Este e-mail foi utilizado para fazer cadastro no " + |
|
|
|
|
|
"SAPL com o perfil de Autor. Agora você pode " + |
|
|
mensagem = ( |
|
|
"criar/editar/enviar Proposições.\n" + |
|
|
"Este e-mail foi utilizado para fazer cadastro no " + |
|
|
"Seu nome de usuário é: " + |
|
|
"SAPL com o perfil de Autor. Agora você pode " + |
|
|
self.request.POST['username'] + "\n" |
|
|
"criar/editar/enviar Proposições.\n" + |
|
|
"Caso você não tenha feito este cadastro, por favor " + |
|
|
"Seu nome de usuário é: " + |
|
|
"ignore esta mensagem. Caso tenha, clique " + |
|
|
self.request.POST['username'] + "\n" |
|
|
"no link abaixo\n" + url_base + |
|
|
"Caso você não tenha feito este cadastro, por favor " + |
|
|
reverse('sapl.materia:confirmar_email', kwargs=kwargs)) |
|
|
"ignore esta mensagem. Caso tenha, clique " + |
|
|
remetente = [settings.EMAIL_SEND_USER] |
|
|
"no link abaixo\n" + url_base + |
|
|
destinatario = [user.email] |
|
|
reverse('sapl.base:confirmar_email', kwargs=kwargs)) |
|
|
send_mail(assunto, mensagem, remetente, destinatario, |
|
|
remetente = [settings.EMAIL_SEND_USER] |
|
|
fail_silently=False) |
|
|
destinatario = [user.email] |
|
|
return reverse('sapl.base:autor_detail', |
|
|
send_mail(assunto, mensagem, remetente, destinatario, |
|
|
kwargs={'pk': pk_autor}) |
|
|
fail_silently=False) |
|
|
|
|
|
except: |
|
|
|
|
|
sapl_logger.error( |
|
|
|
|
|
_('Erro no envio de email na edição de Autores.')) |
|
|
|
|
|
return url_reverse |
|
|
|
|
|
|
|
|
class CreateView(CrudAux.CreateView): |
|
|
class CreateView(CrudAux.CreateView): |
|
|
form_class = AutorForm |
|
|
form_class = AutorForm |
|
|
layout_key = None |
|
|
layout_key = None |
|
|
|
|
|
|
|
|
|
|
|
def post(self, request, *args, **kwargs): |
|
|
|
|
|
if request.user.is_superuser: |
|
|
|
|
|
self.form_class = AutorFormForAdmin |
|
|
|
|
|
return CrudAux.CreateView.post(self, request, *args, **kwargs) |
|
|
|
|
|
|
|
|
def get(self, request, *args, **kwargs): |
|
|
def get(self, request, *args, **kwargs): |
|
|
if request.user.is_superuser: |
|
|
if request.user.is_superuser: |
|
|
self.form_class = AutorFormForAdmin |
|
|
self.form_class = AutorFormForAdmin |
|
@ -118,32 +149,39 @@ class AutorCrud(CrudAux): |
|
|
|
|
|
|
|
|
def get_success_url(self): |
|
|
def get_success_url(self): |
|
|
pk_autor = self.object.id |
|
|
pk_autor = self.object.id |
|
|
# FIXME try except - testar envio de emails |
|
|
url_reverse = reverse('sapl.base:autor_detail', |
|
|
kwargs = {} |
|
|
kwargs={'pk': pk_autor}) |
|
|
user = self.object.user |
|
|
try: |
|
|
kwargs['token'] = default_token_generator.make_token(user) |
|
|
kwargs = {} |
|
|
kwargs['uidb64'] = urlsafe_base64_encode(force_bytes(user.pk)) |
|
|
user = self.object.user |
|
|
assunto = "SAPL - Confirmação de Conta" |
|
|
|
|
|
full_url = self.request.get_raw_uri() |
|
|
if not user: |
|
|
url_base = full_url[:full_url.find('sistema') - 1] |
|
|
return url_reverse |
|
|
|
|
|
|
|
|
mensagem = ( |
|
|
kwargs['token'] = default_token_generator.make_token(user) |
|
|
"Este e-mail foi utilizado para fazer cadastro no " + |
|
|
kwargs['uidb64'] = urlsafe_base64_encode(force_bytes(user.pk)) |
|
|
"SAPL com o perfil de Autor. Agora você pode " + |
|
|
assunto = "SAPL - Confirmação de Conta" |
|
|
"criar/editar/enviar Proposições.\n" + |
|
|
full_url = self.request.get_raw_uri() |
|
|
"Seu nome de usuário é: " + |
|
|
url_base = full_url[:full_url.find('sistema') - 1] |
|
|
self.request.POST['username'] + "\n" |
|
|
|
|
|
"Caso você não tenha feito este cadastro, por favor " + |
|
|
mensagem = ( |
|
|
"ignore esta mensagem. Caso tenha, clique " + |
|
|
"Este e-mail foi utilizado para fazer cadastro no " + |
|
|
"no link abaixo\n" + url_base + |
|
|
"SAPL com o perfil de Autor. Agora você pode " + |
|
|
reverse('sapl.materia:confirmar_email', kwargs=kwargs)) |
|
|
"criar/editar/enviar Proposições.\n" + |
|
|
remetente = settings.EMAIL_SEND_USER |
|
|
"Seu nome de usuário é: " + |
|
|
destinatario = [user.email] |
|
|
self.request.POST['username'] + "\n" |
|
|
send_mail(assunto, mensagem, remetente, destinatario, |
|
|
"Caso você não tenha feito este cadastro, por favor " + |
|
|
fail_silently=False) |
|
|
"ignore esta mensagem. Caso tenha, clique " + |
|
|
|
|
|
"no link abaixo\n" + url_base + |
|
|
return reverse('sapl.base:autor_detail', |
|
|
reverse('sapl.base:confirmar_email', kwargs=kwargs)) |
|
|
kwargs={'pk': pk_autor}) |
|
|
remetente = [settings.EMAIL_SEND_USER] |
|
|
|
|
|
destinatario = [user.email] |
|
|
|
|
|
send_mail(assunto, mensagem, remetente, destinatario, |
|
|
|
|
|
fail_silently=False) |
|
|
|
|
|
except: |
|
|
|
|
|
sapl_logger.error( |
|
|
|
|
|
_('Erro no envio de email na criação de Autores.')) |
|
|
|
|
|
return url_reverse |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
class RelatorioAtasView(FilterView): |
|
|
class RelatorioAtasView(FilterView): |
|
|