def redirect_to_next(request, default_resolve, *args, **kwargs): next = kwargs.pop('next', None) if not next: default = restrict_reverse(default_resolve, *args, restrict_domain=settings.COOKIE_DOMAIN, **kwargs) next = request.GET.get('next', default) next = restrict_next(next, domain=settings.COOKIE_DOMAIN) return redirect(next)
def project_add_or_modify(request, project_uuid=None): user = request.user # only check quota for non project admin users if not user.is_project_admin(): ok, limit = check_pending_app_quota(user) if not ok: m = _(astakos_messages.PENDING_APPLICATION_LIMIT_ADD) % limit messages.error(request, m) return redirect(restrict_reverse('astakos.im.views.project_list')) project = None if project_uuid: project = get_object_or_404(Project, uuid=project_uuid) if not user.owns_project(project) and not user.is_project_admin(): m = _(astakos_messages.NOT_ALLOWED) raise PermissionDenied(m) details_fields = [ "name", "homepage", "description", "start_date", "end_date", "comments" ] membership_fields = [ "member_join_policy", "member_leave_policy", "limit_on_members_number" ] resource_catalog, resource_groups = _resources_catalog() resource_catalog_dict, resource_groups_dict = \ _resources_catalog(as_dict=True) extra_context = { 'resource_catalog': resource_catalog, 'resource_groups': resource_groups, 'resource_catalog_dict': resource_catalog_dict, 'resource_groups_dict': resource_groups_dict, 'show_form': True, 'details_fields': details_fields, 'membership_fields': membership_fields, 'object': project } with transaction.atomic(): template_name = 'im/projects/projectapplication_form.html' summary_template_name = \ 'im/projects/projectapplication_form_summary.html' success_msg = _("The project application has been received and " "is under consideration.") form_class = ProjectApplicationForm if project: template_name = 'im/projects/projectmodification_form.html' summary_template_name = \ 'im/projects/projectmodification_form_summary.html' success_msg = _("The project modification has been received and " "is under consideration.") form_class = ProjectModificationForm details_fields.remove('start_date') extra_context['edit'] = 0 if request.method == 'POST': form = form_class(request.POST, request.FILES, instance=project) if form.is_valid(): verify = request.GET.get('verify') edit = request.GET.get('edit') if verify == '1': extra_context['show_form'] = False extra_context['form_data'] = form.cleaned_data template_name = summary_template_name elif edit == '1': extra_context['show_form'] = True else: new_object = form.save() messages.success(request, success_msg, fail_silently=True) return redirect(restrict_reverse('project_list')) else: # handle terminated projects for which the name attribute # has been set to null if project and not project.name: project.name = project.realname form = form_class(instance=project) extra_context['form'] = form return render_to_response(template_name, extra_context, context_instance=RequestContext(request))
def project_add_or_modify(request, project_uuid=None): user = request.user # only check quota for non project admin users if not user.is_project_admin(): ok, limit = check_pending_app_quota(user) if not ok: m = _(astakos_messages.PENDING_APPLICATION_LIMIT_ADD) % limit messages.error(request, m) return redirect(restrict_reverse( 'astakos.im.views.project_list')) project = None if project_uuid: project = get_object_or_404(Project, uuid=project_uuid) if not user.owns_project(project) and not user.is_project_admin(): m = _(astakos_messages.NOT_ALLOWED) raise PermissionDenied(m) details_fields = ["name", "homepage", "description", "start_date", "end_date", "comments"] membership_fields = ["member_join_policy", "member_leave_policy", "limit_on_members_number"] resource_catalog, resource_groups = _resources_catalog() resource_catalog_dict, resource_groups_dict = \ _resources_catalog(as_dict=True) extra_context = { 'resource_catalog': resource_catalog, 'resource_groups': resource_groups, 'resource_catalog_dict': resource_catalog_dict, 'resource_groups_dict': resource_groups_dict, 'show_form': True, 'details_fields': details_fields, 'membership_fields': membership_fields, 'object': project } with transaction.commit_on_success(): template_name = 'im/projects/projectapplication_form.html' summary_template_name = \ 'im/projects/projectapplication_form_summary.html' success_msg = _("The project application has been received and " "is under consideration.") form_class = ProjectApplicationForm if project: template_name = 'im/projects/projectmodification_form.html' summary_template_name = \ 'im/projects/projectmodification_form_summary.html' success_msg = _("The project modification has been received and " "is under consideration.") form_class = ProjectModificationForm details_fields.remove('start_date') extra_context['edit'] = 0 if request.method == 'POST': form = form_class(request.POST, request.FILES, instance=project) if form.is_valid(): verify = request.GET.get('verify') edit = request.GET.get('edit') if verify == '1': extra_context['show_form'] = False extra_context['form_data'] = form.cleaned_data template_name = summary_template_name elif edit == '1': extra_context['show_form'] = True else: new_object = form.save() messages.success(request, success_msg, fail_silently=True) return redirect(restrict_reverse('project_list')) else: form = form_class(instance=project) extra_context['form'] = form return render_to_response(template_name, extra_context, context_instance=RequestContext(request))