mirror of
https://gitlab.com/allianceauth/allianceauth.git
synced 2025-07-09 20:40:17 +02:00
84 lines
3.3 KiB
Python
84 lines
3.3 KiB
Python
|
|
|
|
from django.http import HttpResponseRedirect
|
|
from django.template import RequestContext
|
|
from django.shortcuts import render_to_response
|
|
from django.contrib.auth.decorators import login_required
|
|
from django.contrib.auth.decorators import permission_required
|
|
from django.contrib.auth.decorators import user_passes_test
|
|
from django.utils import timezone
|
|
|
|
from util import check_if_user_has_permission
|
|
from authentication.managers import AuthServicesInfoManager
|
|
from eveonline.managers import EveManager
|
|
from form import opForm
|
|
from models import optimer
|
|
|
|
import logging
|
|
|
|
logger = logging.getLogger(__name__)
|
|
|
|
def optimer_util_test(user):
|
|
return check_if_user_has_permission(user, 'member') or check_if_user_has_permission(user, 'blue_member')
|
|
|
|
|
|
@login_required
|
|
@user_passes_test(optimer_util_test)
|
|
@permission_required('auth.optimer_view')
|
|
def optimer_view(request):
|
|
logger.debug("optimer_view called by user %s" % request.user)
|
|
optimer_list = optimer.objects.all()
|
|
render_items = {'optimer': optimer.objects.all(),}
|
|
|
|
return render_to_response('registered/operationmanagement.html', render_items, context_instance=RequestContext(request))
|
|
|
|
|
|
@login_required
|
|
@permission_required('auth.optimer_management')
|
|
def add_optimer_view(request):
|
|
logger.debug("add_optimer_view called by user %s" % request.user)
|
|
if request.method == 'POST':
|
|
form = opForm(request.POST)
|
|
logger.debug("Request type POST contains form valid: %s" % form.is_valid())
|
|
if form.is_valid():
|
|
#Get Current Time
|
|
post_time = timezone.now()
|
|
# Get character
|
|
auth_info = AuthServicesInfoManager.get_auth_service_info(request.user)
|
|
character = EveManager.get_character_by_id(auth_info.main_char_id)
|
|
# handle valid form
|
|
op = optimer()
|
|
op.doctrine = form.cleaned_data['doctrine']
|
|
op.system = form.cleaned_data['system']
|
|
op.location = form.cleaned_data['location']
|
|
op.start = form.cleaned_data['start']
|
|
op.duration = form.cleaned_data['duration']
|
|
op.operation_name = form.cleaned_data['operation_name']
|
|
op.fc = form.cleaned_data['fc']
|
|
op.details = form.cleaned_data['details']
|
|
op.create_time = post_time
|
|
op.eve_character = character
|
|
op.save()
|
|
logger.info("User %s created op timer with name %s" % (request.user, op.operation_name))
|
|
return HttpResponseRedirect("/optimer/")
|
|
else:
|
|
logger.debug("Returning new opForm")
|
|
form = opForm()
|
|
|
|
render_items = {'form': form}
|
|
|
|
return render_to_response('registered/addoperation.html', render_items, context_instance=RequestContext(request))
|
|
|
|
|
|
@login_required
|
|
@permission_required('auth.optimer_management')
|
|
def remove_optimer(request, optimer_id):
|
|
logger.debug("remove_optimer called by user %s for operation id %s" % (request.user, optimer_id))
|
|
if optimer.objects.filter(id=optimer_id).exists():
|
|
op = optimer.objects.get(id=optimer_id)
|
|
op.delete()
|
|
logger.info("Deleting optimer id %s by user %s" % (optimer_id, request.user))
|
|
else:
|
|
logger.error("Unable to delete optimer id %s for user %s - operation matching id not found." % (optimer_id, request.user))
|
|
return HttpResponseRedirect("/optimer/")
|