summaryrefslogtreecommitdiff
path: root/coip/apps/invitation/views.py
blob: 359d884d4951dad414213ad93f32d88e0f552f7e (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
'''
Created on Jun 23, 2010

@author: leifj
'''
from django.contrib.auth.decorators import login_required
from coip.apps.invitation.models import Invitation
from coip.apps.invitation.forms import InvitationForm
from django.http import HttpResponseRedirect
from coip.apps.auth.utils import nonce
from coip.multiresponse import respond_to, render403
from coip.apps.name.models import Name 
import datetime
from coip.apps.membership.models import Membership
from django.shortcuts import get_object_or_404
    
@login_required
def invite(request,id):
    name = get_object_or_404(Name,pk=id)
    
    if not name.has_permission(request.user,'i'):
        return render403('You are not allowed to invite users to '+name)
    
    user = request.user
    if request.method == 'POST':
        invitation=Invitation(inviter=user,nonce=nonce(),name=name)
        form = InvitationForm(request.POST,instance=invitation)
        if form.is_valid():
            invitation = form.save()
            invitation.send_email()
            return HttpResponseRedirect("/name/id/%d" % (name.id))
    else:
        exp = datetime.datetime.now()+datetime.timedelta(days=1)
        invitation=Invitation(message="Please consider joining my group!",expires=exp.strftime("%Y-%m-%d"))
        form = InvitationForm(instance=invitation);
    
    return respond_to(request,{'text/html': 'apps/invitation/edit.html'},{'form': form,'name': name,'formtitle': 'Invite to %s' % (name),'submitname': 'Invite User'})

@login_required
def accept(request,nonce):
    invitation = get_object_or_404(Invitation,nonce=nonce)
    
    (membership,created) = Membership.objects.get_or_create(user=request.user,name=invitation.name)
    if created or not membership.enabled:
        membership.enabled = True
        membership.save()
    
    invitation.delete()
    
    return HttpResponseRedirect("/membership/%d" % (membership.id))

@login_required
def cancel(request,id):
    invitation = get_object_or_404(Invitation,pk=id)
    name = invitation.name
    
    if not name.has_permission(request.user,'w'):
        return render403('You are not allowed to cancel pending invitations to %s' % (name))
    
    invitation.delete()
    return HttpResponseRedirect("/name/id/%d" % (name.id))

def resend(request,id):
    invitation = get_object_or_404(Invitation,pk=id)
    name = invitation.name
    
    invitation.send_email()
    return HttpResponseRedirect("/name/id/%d" % (name.id))