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
|
'''
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()
for i in Invitation.objects.filter(user=request.user,name=invitation.name).all:
i.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))
|