summaryrefslogtreecommitdiff
path: root/scipy/views.py
blob: c01d55d20e75da682ad334614bd4234970f2597c (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
from django.http import HttpResponse, HttpResponseRedirect
from django.core.context_processors import csrf
from django.shortcuts import render_to_response
from django.contrib.auth.models import User
from django.contrib.auth import authenticate, login, logout
from django.contrib.auth.decorators import login_required

from scipy.forms import UserLoginForm, UserRegisterForm, UserProfileForm, DocumentUploadForm

# User Login View
def user_login(request):
    if request.user.is_anonymous():
        if request.method == 'POST':
            username = request.POST['username']
            password = request.POST['password']
            user = authenticate(username=username, password=password)
            if user is not None:
                if user.is_active:
                    login(request, user)
                    reviewers = ['jaidevd', 'prabhu', 'jarrod', 'hardythe1']
                    if user.username in reviewers:
                        return HttpResponseRedirect('/2013/abstracts')
                    else: 
                        return HttpResponseRedirect(request.POST['next'])
                else:
                    return HttpResponse("Not active")
            else:
                return HttpResponseRedirect("/2013/accounts/login/?status=in")
        else:
            form = UserLoginForm()

        next = '/2013/accounts/upload-document/'
        if 'next' in request.GET:
            next = request.GET['next']
        
        status = ''        
        if 'status' in request.GET:
            status = request.GET['status']
            
        context = {}
        context.update(csrf(request))
        context['form'] = form
        context['next'] = next
        context['status'] = status
        return render_to_response('login.html', context)
    else:
        return HttpResponseRedirect('/2013/accounts/upload-document')

# User Logout View
def user_logout(request):
    logout(request)
    return HttpResponseRedirect('/')

# User Register View
def user_register(request):
    context = {}
    if request.user.is_anonymous():
        if request.method == 'POST':
            form = UserRegisterForm(request.POST)
            if form.is_valid():
                form.save()
                return HttpResponseRedirect('/2013/accounts/upload-document')
            else:
                context.update(csrf(request))
                context['form'] = form
                return render_to_response('register.html', context)
        else:
            form = UserRegisterForm()
        context.update(csrf(request))
        context['form'] = form
        return render_to_response('register.html', context)
    else:
        return HttpResponseRedirect('/2013/accounts/upload-document')

# User Profile View
def user_profile(request):
    if request.user.is_authenticated():
        context = {}
        context.update(csrf(request))
        context['form'] = UserProfileForm(instance=request.user)
        return render_to_response('profile.html', context)
    else:
        return HttpResponseRedirect('/2013/accounts/login?next=/2013/accounts/profile')

# Document Upload View
def upload_document(request):
    allowed_files = ['doc', 'docx', 'txt', 'pdf']
    invalid_file_msg = None
    large_file_msg = None
    context = {}
    context['current_user'] = request.user
    if request.user.is_authenticated():
        if request.method == 'POST':
            form = DocumentUploadForm(request.POST, request.FILES)
            if form.is_valid():
                data = form.save(commit=False)
                data.user = request.user
                data.verified = False
                data.save()
                return HttpResponseRedirect("/2013/call-for-proposals/?status=up")
        else:
            form = DocumentUploadForm()
        context.update(csrf(request))
        context['form'] = form
        return render_to_response('upload-document.html', context)
    else:
        return HttpResponseRedirect('/2013/accounts/login')