def resource_remove(request, object_id): object = get_one_or_404(Resource, id=ObjectId(object_id), user=request.user, perm='can_delete') object.delete() user = get_account(request.user.id) increment_resource_crud('resouce_remove', account=user) return HttpResponseRedirect(reverse('resource_list'))
def edit(request, object_id, template_name='accounts/accounts_edit.html', next='accounts_detail'): # object = get_one_or_404(Account, id=object_id) object = get_one_or_404(Account, id=ObjectId(object_id), user=request.user, perm='can_edit') user = request.user if not (user.is_staff or object.local_id == str(user.id)): raise PermissionDenied() if request.method == 'POST': form = AccountForm(request.POST, instance=object) locationform = LocationUpdateForm(request.POST, instance=object) if form.is_valid(request.user) and locationform.is_valid(): acct = get_account(request.user.id) object.locations = locationform.locations object.save() increment_resource_crud('account_edit', account=acct) object = form.save(False) object.save(reindex=True) return HttpResponseRedirect(reverse(next, args=[object.id])) else: form = AccountForm(instance=object) locationform = LocationUpdateForm(instance=object) template_context = { 'form': form, 'object': object, 'locationform': locationform, 'new': False } return render_to_response( template_name, template_context, RequestContext(request) )
def issue_list(request, template_name='youraliss/issues.html'): account = get_account(request.user.id) issues = Issue.objects.for_account(account) template_context = {'objects': issues} return render_to_response(template_name, RequestContext(request, template_context))
def invite(request): account = get_account(request.user.id) if request.method == "POST": form = InvitationForm(request.POST) if form.is_valid(): invite = Invitation( email=form.cleaned_data['email'], message=form.cleaned_data['message'], invite_from=account) invite.save() invite.send_email() messages.success(request, 'Invitation has been emailed to %s' % invite.email) return HttpResponseRedirect(reverse('invitations')) else: form = InvitationForm(initial={ 'message': 'You have been invited to create an account on ALISS.org by %s.'% account.name}) return render_to_response('invites/invite.html', { 'account': account, 'form': form, 'submit': 'Send invitation' }, RequestContext(request))
def invite(request): account = get_account(request.user.id) if request.method == "POST": form = InvitationForm(request.POST) if form.is_valid(): invite = Invitation(email=form.cleaned_data['email'], message=form.cleaned_data['message'], invite_from=account) invite.save() invite.send_email() messages.success( request, 'Invitation has been emailed to %s' % invite.email) return HttpResponseRedirect(reverse('invitations')) else: form = InvitationForm( initial={ 'message': 'You have been invited to create an account on ALISS.org by %s.' % account.name }) return render_to_response('invites/invite.html', { 'account': account, 'form': form, 'submit': 'Send invitation' }, RequestContext(request))
def location_remove(request, object_id, index): """docstring for location_remove""" resource = get_one_or_404(Resource, id=ObjectId(object_id), user=request.user, perm='can_edit') del resource.locations[int(index)] resource.save(author=get_account(request.user.id), reindex=True) return HttpResponseRedirect(reverse('resource_edit', args=[resource.id]))
def resource_add(request, template_name='depot/resource_edit.html'): """adds a new resource""" import urllib # seems url becomes http:/ on server- no idea why # defensive coding ftw. req_path = urllib.unquote(request.path).replace( 'http://', 'http~~').replace('http:/', 'http~~').replace('||', '\n') req_data = get_req_data(req_path) debug_info = (req_path, req_data) template_info = _template_info(req_data.get('popup', '')) if request.method == 'POST': if request.POST.get('result', '') == 'Cancel': return resource_edit_complete(request, None, template_info) form = ShortResourceForm(request.POST) if form.is_valid(request.user): resource = Resource(**form.cleaned_data) # resource.metadata.author = str(request.user.id) try: # resource.collection_status = COLL_STATUS_LOC_CONF user = get_account(request.user.id) resource.owner = user # save will create default moderation and curation using owner acct resource.save(author=user, reindex=True) increment_resource_crud('resouce_add', account=user) # resource.index() # if popup: # return HttpResponseRedirect(reverse('resource-popup-close')) return HttpResponseRedirect( '%s?popup=%s' % (reverse('resource_edit', args=[resource.id]), template_info['popup'])) except OperationError: pass else: description = req_data.get('t', '') initial = { 'uri': req_data.get('page', '').replace('http~~', 'http://'), 'title': req_data.get('title', ''), 'description': description[:1250] } form = ShortResourceForm(initial=initial) return render_to_response( template_name, RequestContext( request, { 'resourceform': form, 'template_info': template_info, 'debug_info': debug_info }))
def resource_find(request, template_name='depot/resource_find.html'): """docstring for resource_find""" results = [] pt_results = {} centres = None new_search = False result = request.REQUEST.get('result', '') if request.method == 'POST' or result: if result == 'Cancel': return HttpResponseRedirect(reverse('resource_list')) form = FindResourceForm(request.REQUEST) if form.is_valid(): user = get_account(request.user.id) # print request.META.get("ENGINE_LOG") increment_queries(form.cleaned_data['kwords'], account=user) # print form.centre['loc'] if form.centre else None increment_locations( unicode(form.centre['loc']) if form.centre else None, account=user) for result in form.results: resource = get_one_or_404(Resource, id=ObjectId(result['res_id'])) result['resource'] = resource if 'pt_location' in result: pt_results.setdefault( tuple(result['pt_location'][0].split(', ')), []).append((result['res_id'], result['title'])) centres = [form.centre] if form.centre else [] else: form = FindResourceForm( initial={'boost_location': settings.SOLR_LOC_BOOST_DEFAULT}) new_search = True # hack cos map not showing if no centre point # map should show if pt_results anyway, but not happening # see also accounts.view.accounts_find # just north of Perth # default_centres = [{'location': ('56.5', '-3.5')}] context = { 'next': urlquote_plus(request.get_full_path()), 'form': form, 'results': form.results, 'pt_results': pt_results, 'centres': centres, # or default_centres if pt_results else None, 'google_key': settings.GOOGLE_KEY, 'show_map': bool(centres or pt_results), 'new_search': new_search } return render_to_response(template_name, RequestContext(request, context))
def issue_detail(request, object_id, template_name='youraliss/issue_detail.html', next='issue_detail'): account = get_account(request.user.id) issue = get_one_or_404(Issue, id=ObjectId(object_id)) if request.method == 'POST' and 'message' in request.POST: commentform = CommentForm(request.POST) if commentform.is_valid(): comment = IssueComment( owner=account, message=commentform.cleaned_data['message'], ) issue.comments.append(comment) issue.save() issue.notify_comment(comment) return HttpResponseRedirect(reverse(next, args=[issue.id])) else: commentform = CommentForm() if request.method == 'POST' and 'resolved' in request.POST: if not can_resolve(account, issue): raise PermissionDenied() form = IssueResolveForm(request.POST) if form.is_valid(): issue.resolved = int(form.cleaned_data['resolved']) issue.resolved_message = form.cleaned_data['resolved_message'] issue.save() if issue.resolved == RESOLUTION_FOR_REMOVAL: issue.related_document.moderate_as_bad(account) elif issue.severity == SEVERITY_CRITICAL: issue.related_document.remove_bad_mod() issue.notify_resolved() return HttpResponseRedirect(reverse(next, args=[issue.id])) else: form = IssueResolveForm(initial={ 'resolved': issue.resolved, 'resolved_message': issue.resolved_message }) template_context = { 'object': issue, 'commentform': commentform, 'form': form } return render_to_response(template_name, RequestContext(request, template_context))
def resource_edit(request, object_id, template_name='depot/resource_edit.html'): """ edits an existing resource. Uses a wizard-like approach, so checks resource.collection_status and hands off to resource_* function handler """ UPDATE_LOCS = 'Update locations' UPDATE_TAGS = 'Update tags' object = get_one_or_404(Resource, id=ObjectId(object_id), user=request.user, perm='can_edit') # doc = '' # places = None template_info = _template_info(request.REQUEST.get('popup', '')) if request.method == 'POST': result = request.POST.get('result', '') # or request.POST.get('result', '') if result == 'Cancel': return resource_edit_complete(request, object, template_info) resourceform = ShortResourceForm(request.POST, instance=object) eventform = EventForm(request.POST, instance=object.calendar_event) locationform = LocationUpdateForm(request.POST, instance=object) # shelflifeform = ShelflifeForm(request.POST, instance=object) if resourceform.is_valid(request.user) and locationform.is_valid() and eventform.is_valid(): acct = get_account(request.user.id) object.locations = locationform.locations increment_resource_crud('resouce_edit', account=acct) # Event dates event_start = eventform.cleaned_data['start'] if event_start: object.calendar_event = CalendarEvent(start=event_start, end=eventform.cleaned_data['end']) else: object.calendar_event = None object = resourceform.save(do_save=False) try: object.save(author=acct, reindex=True) return resource_edit_complete(request, object, template_info) except OperationError: pass else: resourceform = ShortResourceForm(instance=object) locationform = LocationUpdateForm(instance=object) eventform = EventForm(instance=object.calendar_event) # shelflifeform = ShelflifeForm(instance=object) return render_to_response(template_name, RequestContext( request, { 'template_info': template_info, 'object': object, 'resourceform': resourceform, 'locationform': locationform, 'eventform': eventform, #'places': places, # 'tagsform': tagsform, #'shelflifeform': shelflifeform, 'UPDATE_LOCS': UPDATE_LOCS, 'UPDATE_TAGS': UPDATE_TAGS }))
def curation_add(request, object_id, template_name='depot/curation_edit.html'): """docstring for curation_add""" resource = get_one_or_404(Resource, id=ObjectId(object_id)) user = get_account(request.user.id) curation = get_curation_for_acct_resource(user, resource) if curation: index, cur = curation messages.warning( request, 'You already have a curation for this resource- you can edit it if you need to make changes.' ) return HttpResponseRedirect( reverse('curation', args=[resource.id, index])) if request.method == 'POST': result = request.POST.get('result', '') next = request.GET.get('next', '') if next: url = '%s#res_%s' % (next, resource.id) else: url = '' if result == 'Cancel': return HttpResponseRedirect( url or reverse('resource', args=[resource.id])) form = CurationForm(request.POST) if form.is_valid(request.user): curation = Curation(**form.cleaned_data) curation.owner = user curation.item_metadata.update(author=user) add_curation(resource, curation) # TODO: move this into resource.add_curation increment_resource_crud('curation_add', account=user) index = len(resource.curations) - 1 return HttpResponseRedirect( url or reverse('curation', args=[resource.id, index])) else: initial = {'outcome': STATUS_OK} form = CurationForm(initial=initial) template_context = { 'next': urlquote_plus(request.GET.get('next', '')), 'form': form, 'resource': resource, 'new': True } return render_to_response(template_name, template_context, RequestContext(request))
def message_stats(request): account = get_account(request.user.id) if account: account_messages = AccountMessage.objects.filter(to_account=account) account_message_count = len(account_messages) else: account_messages = None account_message_count = 0 return { 'account_message_count': account_message_count, 'account_messages': account_messages }
def curation_remove(request, object_id, index): """docstring for curation_remove""" user = get_account(request.user.id) resource = get_one_or_404(Resource, id=ObjectId(object_id), user=request.user, perm='can_delete') if resource.owner == resource.curations[int(index)].owner: messages.warning(request, 'You cannot delete the curation by the resource owner.') return HttpResponseRedirect(reverse('curation', args=[resource.id, index])) resource.curations[int(index)].delete() del resource.curations[int(index)] resource.save(reindex=True) increment_resource_crud('curation_remove', account=user) return HttpResponseRedirect(reverse('resource', args=[resource.id]))
def resource_report(request, object_id, template_name='depot/resource_report.html'): """ View for reporting a report when a user finds a problem with it. """ resource = get_one_or_404(Resource, id=ObjectId(object_id)) reporter = get_account(request.user.id) # if 'next' in request.GET: # url = request.GET['next'] # else: # url = None # url = url or reverse('resource', args=[resource.id]) if Issue.objects(reporter=reporter, related_document=resource).count(): messages.warning(request, 'You have already reported this resource.') return HttpResponseRedirect(reverse('resource', args=[resource.id])) if request.method == 'POST': form = ResourceReportForm(request.POST) if form.is_valid(): severity = int(form.cleaned_data['severity']) message = form.cleaned_data['message'] issue = Issue(message=message, severity=severity, reporter=reporter) issue.related_document = resource issue.save() issue.notify_created() # only moderate as STATUS_BAD if SEVERITY_CRITICAL if severity == SEVERITY_CRITICAL: resource.moderate_as_bad(reporter) return HttpResponseRedirect( reverse('issue_detail', args=[issue.id])) else: form = ResourceReportForm() return render_to_response( template_name, { 'next': urlquote_plus(request.GET.get('next', '')), 'form': form, 'object': resource, }, RequestContext(request))
def accounts_find(request, template_name='accounts/accounts_find.html'): """docstring for accounts_find""" results = [] pt_results = {} centres = None new_search = False result = request.REQUEST.get('result', '') if request.method == 'POST' or result: pass if result == 'Cancel': return HttpResponseRedirect(reverse('resource_list')) form = FindAccountForm(request.REQUEST) if form.is_valid(): user = get_account(request.user.id) increment_queries(form.cleaned_data['kwords'], account=user) increment_locations(form.cleaned_data['post_code'], account=user) for result in form.results: acct = get_one_or_404(Account, id=ObjectId(result['res_id'])) result['resource'] = acct results.append({'resource_result': result}) if 'pt_location' in result: pt_results.setdefault(tuple(result['pt_location'][0].split(', ')), []).append((result['res_id'], result['title'])) centres = [form.centre] if form.centre else [] else: form = FindAccountForm(initial={'boost_location': settings.SOLR_LOC_BOOST_DEFAULT}) new_search = True # hack cos map not showing if no centre point # map should show if pt_results anyway, but not happening # see also resources.view.resource_find # just north of Perth # default_centres = [{'location': ('56.5', '-3.5')}] context = { 'next': urlquote_plus(request.get_full_path()), 'form': form, 'results': results, 'pt_results': pt_results, 'centres': centres, # or default_centres if pt_results else None, 'google_key': settings.GOOGLE_KEY, 'show_map': bool(centres or pt_results), 'new_search': new_search } return render_to_response(template_name, RequestContext(request, context))
def curation_add(request, object_id, template_name='depot/curation_edit.html'): """docstring for curation_add""" resource = get_one_or_404(Resource, id=ObjectId(object_id)) user = get_account(request.user.id) curation = get_curation_for_acct_resource(user, resource) if curation: index, cur = curation messages.warning(request, 'You already have a curation for this resource- you can edit it if you need to make changes.') return HttpResponseRedirect(reverse('curation', args=[resource.id, index])) if request.method == 'POST': result = request.POST.get('result', '') next = request.GET.get('next', '') if next: url = '%s#res_%s' % (next, resource.id) else: url = '' if result == 'Cancel': return HttpResponseRedirect(url or reverse('resource', args=[resource.id])) form = CurationForm(request.POST) if form.is_valid(request.user): curation = Curation(**form.cleaned_data) curation.owner = user curation.item_metadata.update(author=user) add_curation(resource, curation) # TODO: move this into resource.add_curation increment_resource_crud('curation_add', account=user) index = len(resource.curations) - 1 return HttpResponseRedirect(url or reverse('curation', args=[resource.id, index])) else: initial = { 'outcome': STATUS_OK} form = CurationForm(initial=initial) template_context = { 'next': urlquote_plus(request.GET.get('next', '')), 'form': form, 'resource': resource, 'new': True } return render_to_response( template_name, template_context, RequestContext(request) )
def resource_report(request, object_id, template_name='depot/resource_report.html'): """ View for reporting a report when a user finds a problem with it. """ resource = get_one_or_404(Resource, id=ObjectId(object_id)) reporter=get_account(request.user.id) # if 'next' in request.GET: # url = request.GET['next'] # else: # url = None # url = url or reverse('resource', args=[resource.id]) if Issue.objects(reporter=reporter, related_document=resource).count(): messages.warning(request, 'You have already reported this resource.') return HttpResponseRedirect(reverse('resource', args=[resource.id])) if request.method == 'POST': form = ResourceReportForm(request.POST) if form.is_valid(): severity=int(form.cleaned_data['severity']) message=form.cleaned_data['message'] issue = Issue( message=message, severity=severity, reporter=reporter) issue.related_document = resource issue.save() issue.notify_created() # only moderate as STATUS_BAD if SEVERITY_CRITICAL if severity == SEVERITY_CRITICAL: resource.moderate_as_bad(reporter) return HttpResponseRedirect(reverse('issue_detail', args=[issue.id])) else: form = ResourceReportForm() return render_to_response(template_name, { 'next': urlquote_plus(request.GET.get('next', '')), 'form': form, 'object': resource, }, RequestContext(request))
def resource_add(request, template_name='depot/resource_edit.html'): """adds a new resource""" import urllib # seems url becomes http:/ on server- no idea why # defensive coding ftw. req_path = urllib.unquote(request.path).replace('http://', 'http~~').replace('http:/', 'http~~').replace('||', '\n') req_data = get_req_data(req_path) debug_info = (req_path, req_data) template_info = _template_info(req_data.get('popup', '')) if request.method == 'POST': if request.POST.get('result', '') == 'Cancel': return resource_edit_complete(request, None, template_info) form = ShortResourceForm(request.POST) if form.is_valid(request.user): resource = Resource(**form.cleaned_data) # resource.metadata.author = str(request.user.id) try: # resource.collection_status = COLL_STATUS_LOC_CONF user = get_account(request.user.id) resource.owner = user # save will create default moderation and curation using owner acct resource.save(author=user, reindex=True) increment_resource_crud('resouce_add', account=user) # resource.index() # if popup: # return HttpResponseRedirect(reverse('resource-popup-close')) return HttpResponseRedirect('%s?popup=%s' % (reverse('resource_edit', args=[resource.id]), template_info['popup'])) except OperationError: pass else: description= req_data.get('t', '') initial = { 'uri': req_data.get('page', '').replace('http~~', 'http://'), 'title': req_data.get('title', ''), 'description': description[:1250] } form = ShortResourceForm(initial=initial) return render_to_response(template_name, RequestContext( request, {'resourceform': form, 'template_info': template_info, 'debug_info': debug_info }))
def accept(request, code): try: invitation = Invitation.objects.get(code=code) if invitation.accepted: return render(request, 'invites/invitation_used.html') except Invitation.DoesNotExist: raise Http404("Invitation for code not found") account = get_account(request.user.id) if request.method == "POST": form = InvitationAcceptForm(request.POST) if form.is_valid(): user, account = form.save() # user.is_staff = True user.save() user = authenticate(username=form.cleaned_data['username'], password=form.cleaned_data['password1']) login(request, user) invitation.accepted = True invitation.save() messages.success( request, 'Welcome to ALISS! Please check your account details below, make any changes, then "Save changes".' ) return HttpResponseRedirect(reverse('youraliss')) else: form = InvitationAcceptForm() return render_to_response( 'invites/invite.html', { 'account': account, 'form': form, 'submit': 'Create your account', 'accept': True }, RequestContext(request))
def issue_detail(request, object_id, template_name='youraliss/issue_detail.html', next='issue_detail'): account = get_account(request.user.id) issue = get_one_or_404(Issue, id=ObjectId(object_id)) if request.method == 'POST' and 'message' in request.POST: commentform = CommentForm(request.POST) if commentform.is_valid(): comment = IssueComment( owner = account, message = commentform.cleaned_data['message'], ) issue.comments.append(comment) issue.save() issue.notify_comment(comment) return HttpResponseRedirect(reverse(next, args=[issue.id])) else: commentform = CommentForm() if request.method == 'POST' and 'resolved' in request.POST: if not can_resolve(account, issue): raise PermissionDenied() form = IssueResolveForm(request.POST) if form.is_valid(): issue.resolved=int(form.cleaned_data['resolved']) issue.resolved_message=form.cleaned_data['resolved_message'] issue.save() if issue.resolved == RESOLUTION_FOR_REMOVAL: issue.related_document.moderate_as_bad(account) elif issue.severity == SEVERITY_CRITICAL: issue.related_document.remove_bad_mod() issue.notify_resolved() return HttpResponseRedirect(reverse(next, args=[issue.id])) else: form = IssueResolveForm(initial={'resolved': issue.resolved, 'resolved_message': issue.resolved_message}) template_context = {'object': issue, 'commentform': commentform, 'form': form} return render_to_response(template_name, RequestContext(request, template_context))
def curation_remove(request, object_id, index): """docstring for curation_remove""" user = get_account(request.user.id) resource = get_one_or_404(Resource, id=ObjectId(object_id), user=request.user, perm='can_delete') if resource.owner == resource.curations[int(index)].owner: messages.warning( request, 'You cannot delete the curation by the resource owner.') return HttpResponseRedirect( reverse('curation', args=[resource.id, index])) resource.curations[int(index)].delete() del resource.curations[int(index)] resource.save(reindex=True) increment_resource_crud('curation_remove', account=user) return HttpResponseRedirect(reverse('resource', args=[resource.id]))
def curation_edit(request, object_id, index, template_name='depot/curation_edit.html'): """Curation is an EmbeddedDocument, so can't be saved, needs to be edited, then Resource saved.""" resource = get_one_or_404(Resource, id=ObjectId(object_id)) object = resource.curations[int(index)] if not request.user.has_perm('can_edit', object): raise PermissionDenied() if request.method == 'POST': result = request.POST.get('result', '') if result == 'Cancel': return HttpResponseRedirect( reverse('curation', args=[resource.id, index])) form = CurationForm(request.POST, instance=object) if form.is_valid(request.user): user = get_account(request.user.id) curation = form.save(do_save=False) curation.item_metadata.update(author=user) curation.save() increment_resource_crud('curation_edit', account=user) # reload the resource, don't know why, but needed for mongoengine 0.6 resource = Resource.objects.get(id=resource.id) if curation.owner == resource.owner: resource.tags = list(set(curation.tags)) resource.save(reindex=True) return HttpResponseRedirect( reverse('curation', args=[resource.id, index])) else: form = CurationForm(instance=object) template_context = { 'form': form, 'object': object, 'resource': resource, 'new': False } return render_to_response(template_name, template_context, RequestContext(request))
def accept(request, code): try: invitation = Invitation.objects.get(code=code) if invitation.accepted: return render(request, 'invites/invitation_used.html') except Invitation.DoesNotExist: raise Http404("Invitation for code not found") account = get_account(request.user.id) if request.method == "POST": form = InvitationAcceptForm(request.POST) if form.is_valid(): user, account = form.save() # user.is_staff = True user.save() user = authenticate( username=form.cleaned_data['username'], password=form.cleaned_data['password1']) login(request, user) invitation.accepted = True invitation.save() messages.success(request, 'Welcome to ALISS! Please check your account details below, make any changes, then "Save changes".') return HttpResponseRedirect(reverse('youraliss')) else: form = InvitationAcceptForm() return render_to_response('invites/invite.html', { 'account': account, 'form': form, 'submit': 'Create your account', 'accept': True }, RequestContext(request))
def curation_edit(request, object_id, index, template_name='depot/curation_edit.html'): """Curation is an EmbeddedDocument, so can't be saved, needs to be edited, then Resource saved.""" resource = get_one_or_404(Resource, id=ObjectId(object_id)) object = resource.curations[int(index)] if not request.user.has_perm('can_edit', object): raise PermissionDenied() if request.method == 'POST': result = request.POST.get('result', '') if result == 'Cancel': return HttpResponseRedirect(reverse('curation', args=[resource.id, index])) form = CurationForm(request.POST, instance=object) if form.is_valid(request.user): user = get_account(request.user.id) curation = form.save(do_save=False) curation.item_metadata.update(author=user) curation.save() increment_resource_crud('curation_edit', account=user) # reload the resource, don't know why, but needed for mongoengine 0.6 resource = Resource.objects.get(id=resource.id) if curation.owner == resource.owner: resource.tags = list(set(curation.tags)) resource.save(reindex=True) return HttpResponseRedirect(reverse('curation', args=[resource.id, index])) else: form = CurationForm(instance=object) template_context = { 'form': form, 'object': object, 'resource': resource, 'new': False } return render_to_response( template_name, template_context, RequestContext(request) )
def account_id(user): acct = get_account(user.id) return acct.id if acct else ''
def resource_find(request, template_name='depot/resource_find.html'): """docstring for resource_find""" results = [] pt_results = {} centre = None new_search = False result = request.REQUEST.get('result', '') if request.method == 'POST' or result: if result == 'Cancel': return HttpResponseRedirect(reverse('resource_list')) form = FindResourceForm(request.REQUEST) if form.is_valid(): user = get_account(request.user.id) increment_queries(form.cleaned_data['kwords'], account=user) # print form.centre['loc'] if form.centre else None increment_locations(unicode(form.centre['loc']) if form.centre else None, account=user) for result in form.results: resource = get_one_or_404(Resource, id=ObjectId(result['res_id'])) result['resource'] = resource # try: # curation_index, curation = get_curation_for_user_resource(user, resource) # print curation # except TypeError: # curation_index = curation = None # curation_form = CurationForm( # initial={'outcome': STATUS_OK}, # instance=curation) # resource_report_form = ResourceReportForm() # results.append({ # 'resource_result': result, # 'curation': curation, # 'curation_form': curation_form, # 'resource_report_form': resource_report_form, # 'curation_index': curation_index # }) if 'pt_location' in result: pt_results.setdefault(tuple(result['pt_location'][0].split(', ')), []).append((result['res_id'], result['title'])) centre = form.centre else: form = FindResourceForm(initial={'boost_location': settings.SOLR_LOC_BOOST_DEFAULT}) new_search = True # hack cos map not showing if no centre point # map should show if pt_results anyway, but not happening # see also accounts.view.accounts_find # just north of Perth default_centre = {'location': ('56.5', '-3.5')} context = { 'next': urlquote_plus(request.get_full_path()), 'form': form, 'results': form.results, 'pt_results': pt_results, 'centre': centre or default_centre if pt_results else None, 'google_key': settings.GOOGLE_KEY, 'show_map': pt_results, 'new_search': new_search } return render_to_response(template_name, RequestContext(request, context))
def account(user): return get_account(user.id)
def account_id(user): acct = get_account(user.id) return acct.id if acct else ""
def is_owner(user, resource): return get_account(user.id) == resource.owner
def perm_can_edit(self, user): """docstring for perm_can_edit""" acct = get_account(user.id) return self.owner == acct
def perm_can_delete(self, user): """docstring for perm_can_edit""" acct = get_account(user.id) return self.owner == acct and self.resource.owner != acct
def curation_for_user(resource, user): acct = get_account(user.id) return get_curation_for_acct_resource(acct, resource)
def resource_edit(request, object_id, template_name='depot/resource_edit.html'): """ edits an existing resource. Uses a wizard-like approach, so checks resource.collection_status and hands off to resource_* function handler """ UPDATE_LOCS = 'Update locations' UPDATE_TAGS = 'Update tags' object = get_one_or_404(Resource, id=ObjectId(object_id), user=request.user, perm='can_edit') # doc = '' # places = None template_info = _template_info(request.REQUEST.get('popup', '')) if request.method == 'POST': result = request.POST.get('result', '') # or request.POST.get('result', '') if result == 'Cancel': return resource_edit_complete(request, object, template_info) resourceform = ShortResourceForm(request.POST, instance=object) eventform = EventForm(request.POST, instance=object.calendar_event) locationform = LocationUpdateForm(request.POST, instance=object) # shelflifeform = ShelflifeForm(request.POST, instance=object) if resourceform.is_valid(request.user) and locationform.is_valid( ) and eventform.is_valid(): acct = get_account(request.user.id) object.locations = locationform.locations increment_resource_crud('resouce_edit', account=acct) # Event dates event_start = eventform.cleaned_data['start'] if event_start: object.calendar_event = CalendarEvent( start=event_start, end=eventform.cleaned_data['end']) else: object.calendar_event = None object = resourceform.save(do_save=False) try: object.save(author=acct, reindex=True) return resource_edit_complete(request, object, template_info) except OperationError: pass else: resourceform = ShortResourceForm(instance=object) locationform = LocationUpdateForm(instance=object) eventform = EventForm(instance=object.calendar_event) # shelflifeform = ShelflifeForm(instance=object) return render_to_response( template_name, RequestContext( request, { 'template_info': template_info, 'object': object, 'resourceform': resourceform, 'locationform': locationform, 'eventform': eventform, #'places': places, # 'tagsform': tagsform, #'shelflifeform': shelflifeform, 'UPDATE_LOCS': UPDATE_LOCS, 'UPDATE_TAGS': UPDATE_TAGS }))