1 from django.contrib.auth.decorators import login_required
2 from django.shortcuts import render_to_response
3 from django.shortcuts import get_object_or_404
4 from django.template import RequestContext
5 from django.utils.translation import ugettext as _
6 from django.contrib.auth.models import User
7 from django.core.urlresolvers import reverse
8 from django.http import HttpResponseRedirect, HttpResponseForbidden
9 from django.views.generic.list_detail import object_detail, object_list
10 from xerxes.influences.models import Character
11 from xerxes.influences.models import Influence
12 from xerxes.tools.forms import ContextModelForm
16 class InfluenceForm(ContextModelForm):
19 fields = ('character', 'contact', 'summary', 'description')
21 class CharacterForm(ContextModelForm):
27 def add_influence(request, character_id=None):
29 # Get the current user's characters
30 chars = request.user.character_set.all()
32 # If a character_id was specified in the url, or there is only one
33 # character, preselect it.
35 initial['character'] = character_id
36 elif (chars.count() == 1):
37 initial['character'] = chars[0].id
40 f = InfluenceForm(request=request, initial=initial)
42 # Only allow characters of the current user. Putting this here also
43 # ensures that a form will not validate when any other choice was
44 # selected (perhaps through URL crafting).
45 f.fields['character']._set_queryset(chars)
48 # The form was submitted, let's save it.
50 # Redirect to the just saved influence
51 return HttpResponseRedirect(reverse('influences_influence_detail', args=[influence.id]))
53 return render_to_response('influences/add.html', {'form' : f}, RequestContext(request))
56 def add_character(request):
57 f = CharacterForm(request=request)
59 character = f.save(commit=False)
60 character.player = request.user
62 return HttpResponseRedirect(reverse('influences_character_detail', args=[character.id]))
64 return render_to_response('influences/add_character.html', {'form' : f}, RequestContext(request))
68 # Only show this player's characters and influences
69 characters = request.user.character_set.all()
70 influences = Influence.objects.filter(character__player=request.user)
71 return render_to_response('influences/index.html', {'characters' : characters, 'influences' : influences}, RequestContext(request))
74 # The views below are very similar to django's generic views (in fact,
75 # they used to be generic views before). However, since they all depend
76 # on the currently logged in user (for limiting the show list or
77 # performing access control), we won't actually use the generic views
81 def character_list(request):
82 # Only show this player's characters
83 os = request.user.character_set.all()
84 return render_to_response('influences/character_list.html', {'object_list' : os}, RequestContext(request))
87 def character_detail(request, object_id):
88 o = Character.objects.get(pk=object_id)
89 # Don't show other player's characters
90 if (o.player != request.user):
91 return HttpResponseForbidden("Forbidden -- Trying to view somebody else's character")
92 return render_to_response('influences/character_detail.html', {'object' : o}, RequestContext(request))
95 def influence_list(request):
96 # Only show this player's influences
97 os = Influence.objects.filter(character__player=request.user)
98 return render_to_response('influences/influence_list.html', {'object_list' : os}, RequestContext(request))
101 def influence_detail(request, object_id):
102 o = Influence.objects.get(pk=object_id)
103 # Don't show other player's influences
104 if (o.character.player != request.user):
105 return HttpResponseForbidden("Forbidden -- Trying to view influences of somebody else's character")
106 return render_to_response('influences/influence_detail.html', {'object' : o}, RequestContext(request))
108 # vim: set sts=4 sw=4 expandtab: