(arrumando) envio de email?
[cascardo/eventmanager.git] / views.py
index b28f98f..e75b7e1 100644 (file)
--- a/views.py
+++ b/views.py
@@ -1,4 +1,4 @@
-# -*- coding: utf8; -*-
+# -*- coding: utf-8; -*-
 """
 Copyright (C) 2007 Lincoln de Sousa <lincoln@archlinux-br.org>
 
@@ -18,17 +18,20 @@ Free Software Foundation, Inc., 59 Temple Place - Suite 330,
 Boston, MA 02111-1307, USA.
 """
 from django.shortcuts import render_to_response
-from django.template import RequestContext, Context
+from django.template import RequestContext, Context, loader
 from django.contrib.auth.decorators import login_required, user_passes_test
 from django.contrib.auth.models import Group, User
-from django.contrib.auth.forms import AuthenticationForm
-from django.contrib.auth import login
+from django.core.mail import EmailMessage
 from django.db import transaction
+from django.http import get_host
 
 from eventmanager.decorators import enable_login_form
 from eventmanager.forms import *
 from eventmanager.conteudo.models import Noticia, Menu, Secao
 from eventmanager.eventos.models import *
+import sha
+
+FROM_EMAIL = 'Emsl 2007 <noreply@minaslivre.org>'
 
 def build_response(request, template, extra={}):
     """
@@ -93,6 +96,7 @@ def cadastro_palestrante(request):
 
             user = User(username=cd['nome_usuario'], email=cd['email'])
             user.set_password(cd['senha'])
+            user.is_active = False
             user.save()
             user.groups.add(group)
 
@@ -116,30 +120,52 @@ def cadastro_palestrante(request):
             for i in cd.get('area_interesse', []):
                 p.area_interesse.add(i)
 
-            fakepost = request.POST.copy()
-            fakepost['username'] = cd['nome_usuario']
-            fakepost['password'] = cd['senha']
+            pid = p.id
+            md5_email = sha.new(cd['email']).hexdigest()
+            email = '%s <%s>' % (cd['nome_completo'], cd['email'])
+            link = '%s/verificar?c=%s&c1=%s' % (get_host(request),
+                    pid, md5_email)
+            t = loader.get_template('email-palestrante.html')
+            c = Context(dict(fulano=['nome_usuario'], link=link))
+            try:
+                m = EmailMessage('Encontro Mineiro de Software Livre',
+                    t.render(c), FROM_EMAIL, [email])
+                m.send()
+            except Exception:
+                badattr['email'] = ['Não pude enviar o email de confirmação']
+                transaction.rollback()
+            else:
+                ok = True
+                transaction.commit()
 
-            manipulator = AuthenticationForm(request)
-            errors = manipulator.get_validation_errors(fakepost)
-            got_user = manipulator.get_user()
-            login(request, got_user)
-            transaction.commit()
-            ok = True
     c = {'form': form, 'ok': ok}
     return build_response(request, 'cadastro.html', c)
 
 
 @enable_login_form
 def inscricao(request):
-    form = Inscricao(request.POST or None)
+    post = request.POST
+    post2 = 'post2' in post and post or None
+
+    # exibe o formulário de inscrição de estudantes.
+    if 'estudante' in post:
+        form = InscricaoEstudante(post2)
+
+    # inscrição normal (sem ser estudante)
+    elif not 'estudante' in post or 'empresa' in post:
+        form = InscricaoNormal(post2)
+
+    # primeiro passo...
+    else:
+        form = Inscricao(post or None)
+
     return build_response(request, 'inscricao.html', {'form': form})
 
 
 @login_required
 @user_passes_test(lambda u:u.palestrante_set.count() == 1, login_url='/')
 def submeter_trabalho(request):
-    form = SubmeterTrabalho(request.POST or None)
+    form = SubmeterTrabalho(request, request.POST or None)
     ok = False
 
     if request.POST and form.is_valid():
@@ -147,7 +173,7 @@ def submeter_trabalho(request):
         t = Trabalho()
         t.titulo = cd['titulo']
         t.tipo = TipoTrabalho.objects.get(pk=cd['tipo'])
-        t.categoria = CategoriaTrabalho.objects.get(pk=cd['categoria'])
+        t.categoria = CategoriaTrabalho.objects.get_or_create(nome='Pendente')[0]
         t.descricao_curta = cd['descricao_curta']
         t.descricao_longa = cd['descricao_longa']
         t.recursos = cd['recursos']
@@ -203,3 +229,7 @@ def meus_dados(request):
 @enable_login_form
 def chamada_trabalhos(request):
     return build_response(request, 'chamada_trabalhos.html')
+
+@enable_login_form
+def avaliacao(request):
+    return build_response(request, 'avaliacao.html')