source: firmaeventos/eventos/views.py @ 11044a5

Last change on this file since 11044a5 was 11044a5, checked in by rudmanmrrod <rudman22@…>, 7 years ago

Añadida url de murachi

  • Property mode set to 100644
File size: 7.0 KB
Line 
1# -*- encoding: utf-8 -*-
2
3import os
4import requests
5from django.conf import settings
6from django.contrib import messages
7from django.contrib.auth.mixins import LoginRequiredMixin
8from django.core.files.base import ContentFile
9from django.core.files.storage import default_storage
10from django.core.urlresolvers import reverse_lazy
11from django.shortcuts import (
12    redirect
13)
14from django.views.generic import (
15    ListView, FormView
16)
17from django.views.generic.detail import DetailView
18
19from multi_form_view import MultiModelFormView
20
21from .forms import *
22from participantes.forms import (
23    FormsetParticipanteEvento
24)
25from .models import Evento
26from participantes.models import (
27    Participante, ParticipanteEvento
28)
29
30
31def handle_uploaded_file(file, name):
32    with open('%s/%s' % (settings.TMP, name), 'wb+') as destination:
33        for chunk in file.chunks():
34            destination.write(chunk)
35
36class RegisterEvent(LoginRequiredMixin, FormView):
37    """!
38    Muestra el formulario de registro de usuarios
39
40    @author Ing. Leonel P. Hernandez M. (lhernandez at cenditel.gob.ve)
41    @copyright <a href='https://www.gnu.org/licenses/gpl-3.0.en.html'>GNU Public License versión 3 (GPLv3)</a>
42    @date 20-11-2017
43    @version 1.0.0
44    """
45
46    template_name = "register.event.html"
47    form_class = EventoForm
48    form_participante = FormsetParticipanteEvento
49    success_url = reverse_lazy('base:inicio')
50
51    def get_context_data(self, **kwargs):
52        context = super(RegisterEvent, self).get_context_data(**kwargs)
53        if 'form' not in context:
54            context['form'] = self.form_class()
55        if 'form2' not in context:
56            context['form2'] = self.form_participante(queryset=Participante.objects.none())
57        return context
58
59    def post(self, request, *args, **kwargs):
60        file =  request.FILES['file']
61        handle_uploaded_file(request.FILES['file'], file)
62        ruta = '%s/%s' % (settings.TMP, file)
63        file = open(ruta, 'rb')
64        files = {'file': file}
65        try:
66            r = requests.post('https://murachi.cenditel.gob.ve/Murachi/0.1/archivos/cargar', verify=False, headers={'Authorization': 'Basic YWRtaW46YWRtaW4='}, files=files)
67            nuevo_participante = self.form_participante(request.POST)
68            consulta_api = r.json()['fileId']
69            # elimina el archivo si fue creado en la carpeta tmp
70            file.close()
71            os.unlink(ruta)
72        except Exception as e:
73            print (e)
74            file.close()
75            os.unlink(ruta)
76            messages.error(self.request, "Error al concetar al servidor y subir\
77                                          el archivo a la api Murachi")
78            return redirect(self.success_url)
79        try:
80            if self.form_class(request.POST).is_valid() and nuevo_participante.is_valid():
81                nuevo_evento = self.form_class(request.POST, request.FILES).save(commit=False)
82                nuevo_evento.serial = consulta_api
83                nuevo_evento.save()
84                # Control para guardar y asignar participantes al evento
85                for form in nuevo_participante:
86                    if form.cleaned_data.get('DELETE') and form.instance.pk:
87                        form.instance.delete()
88                    else:
89                        instance = form.save(commit=False)
90                        parametros = {
91                                        'nombres': instance.nombres,
92                                        'apellidos': instance.apellidos,
93                                        'correo': instance.correo
94                                        }
95                        nuevo_participante, create = Participante.objects.update_or_create(pasaporte=instance.pasaporte, defaults=parametros)
96                        asigna_evento = ParticipanteEvento(
97                                        fk_participante=nuevo_participante,
98                                        fk_evento=nuevo_evento)
99                        asigna_evento.save()
100                messages.success(self.request, "El usaurio %s, ha creado con exito,\
101                                            un nuevo envento %s" %
102                                 (str(self.request.user),
103                                  str(nuevo_evento)))
104            else:
105                messages.error(self.request, "Existe un error en el\
106                                              Formualario %s %s" %
107                               (self.form_class(request.POST).errors,
108                                self.form_participante(request.POST).errors))
109        except Exception as e:
110            print (e)
111            messages.error(self.request, "Esta intentado realizar una\
112                                          accion incorrecta")
113
114        return redirect(self.success_url)
115
116
117class ListEvent(ListView):
118    """!
119    Muestra el listado de eventos
120
121    @author Rodrigo Boet (rboet at cenditel.gob.ve)
122    @copyright <a href='https://www.gnu.org/licenses/gpl-3.0.en.html'>GNU Public License versión 3 (GPLv3)</a>
123    @date 20-11-2017
124    @version 1.0.0
125    """
126    model = Evento
127    template_name = "evento.list.html"
128    paginate_by = 5
129   
130class SignEvent(FormView):
131    """!
132    Muestra el formulario para buscar y luego firmar documento
133
134    @author Rodrigo Boet (rboet at cenditel.gob.ve)
135    @copyright <a href='https://www.gnu.org/licenses/gpl-3.0.en.html'>GNU Public License versión 3 (GPLv3)</a>
136    @date 20-11-2017
137    @version 1.0.0
138    """
139    form_class = FirmaEventoForm
140    template_name = "evento.firma.html"
141   
142    def get_context_data(self, **kwargs):
143        """!
144        Metodo que permite cargar de nuevo valores en los datos de contexto de la vista
145   
146        @author Rodrigo Boet (rboet at cenditel.gob.ve)
147        @copyright GNU/GPLv3
148        @date 20-11-2017
149        @param self <b>{object}</b> Objeto que instancia la clase
150        @param kwargs <b>{object}</b> Objeto que contiene los datos de contexto
151        @return Retorna los datos de contexto
152        """
153        kwargs['nombre_evento'] = Evento.objects.get(pk=int(self.kwargs['pk']))
154        return super(SignEvent, self).get_context_data(**kwargs)
155
156
157class DetailEvent(DetailView):
158    """!
159    Muestra el detalle del evento
160
161    @author Rodrigo Boet (rboet at cenditel.gob.ve)
162    @copyright <a href='https://www.gnu.org/licenses/gpl-3.0.en.html'>GNU Public License versión 3 (GPLv3)</a>
163    @date 20-11-2017
164    @version 1.0.0
165    """
166    model = Evento
167    template_name = "evento.detail.html"
168
169    def get_context_data(self, **kwargs):
170        evento = int(self.kwargs['pk'])
171        context = super(DetailEvent, self).get_context_data(**kwargs)
172        try:
173            participante_evento = ParticipanteEvento.objects.select_related().filter(fk_evento=evento)
174            falta_porfirma = participante_evento.filter(firma=False).count()
175        except Exception as e:
176            print(e)
177            participante_evento = None
178            falta_porfirma = None
179        context['participantes'] = participante_evento
180        context['num_firma'] = falta_porfirma
181        return context
Note: See TracBrowser for help on using the repository browser.