annotate gpp/bio/views.py @ 40:53b7c681d80b

Don't send plaintext password in confirmation email for site registration.
author Brian Neal <bgneal@gmail.com>
date Fri, 12 Jun 2009 01:15:49 +0000
parents 74f04122295e
children 08cd19c1ee50
rev   line source
gremmie@1 1 """
gremmie@1 2 Views for the bio application.
gremmie@1 3 """
gremmie@1 4
gremmie@1 5 from django.shortcuts import render_to_response
gremmie@1 6 from django.shortcuts import get_object_or_404
gremmie@1 7 from django.template import RequestContext
gremmie@1 8 from django.contrib import auth
gremmie@1 9 from django.http import HttpResponseRedirect
gremmie@1 10 from django.core.urlresolvers import reverse
gremmie@1 11 from django.contrib.auth.decorators import login_required
gremmie@1 12
bgneal@29 13 from elsewhere.models import SocialNetworkForm
bgneal@29 14 from elsewhere.models import InstantMessengerForm
bgneal@29 15 from elsewhere.models import WebsiteForm
bgneal@29 16
gremmie@1 17 from bio.models import UserProfile
gremmie@1 18 from bio.forms import UploadAvatarForm
gremmie@1 19 from bio.forms import EditUserForm
gremmie@1 20 from bio.forms import EditUserProfileForm
gremmie@1 21 from core.paginator import DiggPaginator
gremmie@1 22
gremmie@1 23 #######################################################################
gremmie@1 24
gremmie@1 25 def get_profile(user):
gremmie@1 26 try:
gremmie@1 27 profile = user.get_profile()
gremmie@1 28 except:
gremmie@1 29 profile = UserProfile()
gremmie@1 30 profile.user = user
gremmie@1 31 return profile
gremmie@1 32
gremmie@1 33 #######################################################################
gremmie@1 34
gremmie@1 35 def member_list(request, type='user', page=1):
gremmie@1 36 if type == 'user':
gremmie@1 37 users = auth.models.User.objects.all().order_by('username')
gremmie@1 38 else:
gremmie@1 39 users = auth.models.User.objects.all().order_by('date_joined')
gremmie@1 40
gremmie@1 41 paginator = DiggPaginator(users, 10, body=5, tail=3, margin=3, padding=2)
gremmie@1 42 try:
gremmie@1 43 the_page = paginator.page(int(page))
gremmie@1 44 except InvalidPage:
gremmie@1 45 raise Http404
gremmie@1 46
gremmie@1 47 return render_to_response('bio/members.html', {
gremmie@1 48 'page': the_page,
gremmie@1 49 'type': type,
gremmie@1 50 },
gremmie@1 51 context_instance = RequestContext(request))
gremmie@1 52
gremmie@1 53 #######################################################################
gremmie@1 54
gremmie@1 55 @login_required
gremmie@1 56 def my_profile(request):
gremmie@1 57 profile = get_profile(request.user)
gremmie@1 58
gremmie@1 59 return render_to_response('bio/view_profile.html', {
gremmie@1 60 'subject': request.user,
gremmie@1 61 'profile': profile,
gremmie@1 62 'hide_email': False,
gremmie@1 63 'this_is_me': True,
gremmie@1 64 },
gremmie@1 65 context_instance = RequestContext(request))
gremmie@1 66
gremmie@1 67 #######################################################################
gremmie@1 68
gremmie@1 69 @login_required
gremmie@1 70 def view_profile(request, username):
gremmie@1 71
gremmie@1 72 user = get_object_or_404(auth.models.User, username = username)
gremmie@1 73 if user == request.user:
gremmie@1 74 return HttpResponseRedirect(reverse('bio.views.my_profile'))
gremmie@1 75
gremmie@1 76 profile = get_profile(user)
gremmie@1 77
gremmie@1 78 # work around MySQL's handling of Boolean
gremmie@1 79 hide_email = bool(profile.hide_email)
gremmie@1 80
gremmie@1 81 return render_to_response('bio/view_profile.html', {
gremmie@1 82 'subject': user,
gremmie@1 83 'profile': profile,
gremmie@1 84 'hide_email': hide_email,
gremmie@1 85 'this_is_me': False,
gremmie@1 86 },
gremmie@1 87 context_instance = RequestContext(request))
gremmie@1 88
gremmie@1 89 #######################################################################
gremmie@1 90
gremmie@1 91 @login_required
gremmie@1 92 def edit_profile(request):
gremmie@1 93 if request.method == 'POST':
gremmie@1 94 if request.POST.get('submit_button', 'Cancel') == 'Cancel':
gremmie@1 95 return HttpResponseRedirect(reverse('bio.views.my_profile'))
gremmie@1 96 profile = get_profile(request.user)
gremmie@1 97 user_form = EditUserForm(request.POST, instance=request.user)
gremmie@1 98 profile_form = EditUserProfileForm(request.POST, instance=profile)
gremmie@1 99 if user_form.is_valid() and profile_form.is_valid():
gremmie@1 100 user_form.save()
gremmie@1 101 profile = profile_form.save(commit=False)
gremmie@1 102 profile.user = request.user
gremmie@1 103 profile.save()
gremmie@1 104 return HttpResponseRedirect(reverse('bio.views.my_profile'))
gremmie@1 105 else:
gremmie@1 106 profile = get_profile(request.user)
gremmie@1 107 user_form = EditUserForm(instance=request.user)
gremmie@1 108 profile_form = EditUserProfileForm(instance=profile)
gremmie@1 109
gremmie@1 110 return render_to_response('bio/edit_profile.html', {
gremmie@1 111 'user_form': user_form,
gremmie@1 112 'profile_form': profile_form,
gremmie@1 113 },
gremmie@1 114 context_instance = RequestContext(request))
gremmie@1 115
gremmie@1 116 #######################################################################
gremmie@1 117
gremmie@1 118 @login_required
gremmie@1 119 def change_avatar(request):
gremmie@1 120 if request.method == 'POST':
gremmie@1 121 form = UploadAvatarForm(request.POST, request.FILES)
gremmie@1 122 if form.is_valid():
gremmie@1 123 profile = get_profile(request.user)
gremmie@1 124 file = form.get_file()
gremmie@1 125 if profile.avatar.name != '':
gremmie@1 126 profile.avatar.delete(save=False)
gremmie@1 127 if file is not None:
gremmie@1 128 profile.avatar.save(form.get_filename(), file, save=False)
gremmie@1 129 profile.save()
gremmie@1 130
gremmie@1 131 request.user.message_set.create(message='Avatar updated.')
gremmie@1 132 return HttpResponseRedirect(reverse('bio-me'))
gremmie@1 133 else:
gremmie@1 134 form = UploadAvatarForm()
gremmie@1 135
gremmie@1 136 return render_to_response('bio/avatar.html', {
gremmie@1 137 'form': form,
gremmie@1 138 },
gremmie@1 139 context_instance = RequestContext(request))
gremmie@1 140
bgneal@29 141 #######################################################################
gremmie@1 142
bgneal@29 143 @login_required
bgneal@29 144 def edit_elsewhere(request):
bgneal@29 145 im_id = 'id_im_%s' # to prevent duplicate ID in HTML output
bgneal@29 146 if request.method == 'POST':
bgneal@29 147 new_data = request.POST.copy()
bgneal@29 148
bgneal@29 149 # Add forms
bgneal@29 150 if new_data.get('sn-form') or new_data.get('im-form') or new_data.get('w-form'):
bgneal@29 151
bgneal@29 152 if new_data.get('sn-form'):
bgneal@29 153 sn_form = SocialNetworkForm(new_data)
bgneal@29 154 im_form = InstantMessengerForm(auto_id=im_id)
bgneal@29 155 w_form = WebsiteForm()
bgneal@29 156 form = sn_form
bgneal@29 157 elif new_data.get('im-form'):
bgneal@29 158 sn_form = SocialNetworkForm()
bgneal@29 159 im_form = InstantMessengerForm(new_data, auto_id=im_id)
bgneal@29 160 w_form = WebsiteForm()
bgneal@29 161 form = im_form
bgneal@29 162 elif new_data.get('w-form'):
bgneal@29 163 sn_form = SocialNetworkForm()
bgneal@29 164 im_form = InstantMessengerForm(auto_id=im_id)
bgneal@29 165 w_form = WebsiteForm(new_data)
bgneal@29 166 form = w_form
bgneal@29 167
bgneal@29 168 if form.is_valid():
bgneal@29 169 profile = form.save(commit=False)
bgneal@29 170 profile.user = request.user
bgneal@29 171 profile.save()
bgneal@29 172 return HttpResponseRedirect(request.path)
bgneal@29 173
bgneal@29 174 # Delete forms
bgneal@29 175 elif new_data.get('delete-sn-form') or new_data.get('delete-im-form') or new_data.get('delete-w-form'):
bgneal@29 176 delete_id = request.POST['delete_id']
bgneal@29 177
bgneal@29 178 if new_data.get('delete-sn-form'):
bgneal@29 179 request.user.social_network_profiles.get(id=delete_id).delete()
bgneal@29 180 elif new_data.get('delete-im-form'):
bgneal@29 181 request.user.instant_messenger_profiles.get(id=delete_id).delete()
bgneal@29 182 elif new_data.get('delete-w-form'):
bgneal@29 183 request.user.website_profiles.get(id=delete_id).delete()
bgneal@29 184
bgneal@29 185 return HttpResponseRedirect(request.path)
bgneal@29 186
bgneal@29 187 # WTF?
bgneal@29 188 else:
bgneal@29 189 return HttpResponseServerError
bgneal@29 190
bgneal@29 191 else:
bgneal@29 192 # Create blank forms
bgneal@29 193 sn_form = SocialNetworkForm()
bgneal@29 194 im_form = InstantMessengerForm(auto_id=im_id)
bgneal@29 195 w_form = WebsiteForm()
bgneal@29 196
bgneal@29 197 return render_to_response('bio/edit_elsewhere.html', {
bgneal@29 198 'sn_form': sn_form,
bgneal@29 199 'im_form': im_form,
bgneal@29 200 'w_form': w_form,
bgneal@29 201 },
bgneal@29 202 context_instance=RequestContext(request))
bgneal@29 203