mirror of
https://gitlab.com/allianceauth/allianceauth.git
synced 2026-02-06 07:06:19 +01:00
Added Signature Tracker
Added a tool to help track various sites and wormholes
This commit is contained in:
0
sigtracker/__init__.py
Normal file
0
sigtracker/__init__.py
Normal file
6
sigtracker/admin.py
Normal file
6
sigtracker/admin.py
Normal file
@@ -0,0 +1,6 @@
|
||||
from django.contrib import admin
|
||||
|
||||
from models import sigtracker
|
||||
|
||||
admin.site.register(sigtracker)
|
||||
# Register your models here.
|
||||
20
sigtracker/form.py
Normal file
20
sigtracker/form.py
Normal file
@@ -0,0 +1,20 @@
|
||||
from django import forms
|
||||
from django.core.validators import MaxValueValidator, MinValueValidator
|
||||
|
||||
|
||||
|
||||
class SignitureForm(forms.Form):
|
||||
sigtype = [('Wormhole', 'Wormhole'), ('Combat', 'Combat'), ('Data', 'Data'),
|
||||
('Relic', 'Relic')]
|
||||
status = [('Open', 'Open'), ('Started', 'Started'), ('Finished', 'Finished')]
|
||||
|
||||
system = forms.CharField(max_length=254, required=True, label='System')
|
||||
ident = forms.CharField(max_length=254, required=True, label="ID")
|
||||
sigtype = forms.ChoiceField(choices=sigtype, required=True, label="Signiture Type")
|
||||
destination = forms.CharField(max_length=254, label="destination", required=True, initial="")
|
||||
status = forms.ChoiceField(choices=status, required=True, label="Status")
|
||||
notes = forms.CharField(max_length=254, label="Notes", required=False, initial="")
|
||||
|
||||
|
||||
|
||||
|
||||
18
sigtracker/models.py
Normal file
18
sigtracker/models.py
Normal file
@@ -0,0 +1,18 @@
|
||||
from django.db import models
|
||||
from django.contrib.auth.models import User
|
||||
|
||||
from eveonline.models import EveCharacter
|
||||
from eveonline.models import EveCorporationInfo
|
||||
|
||||
|
||||
class sigtracker(models.Model):
|
||||
class Meta:
|
||||
ordering = ['sigtype']
|
||||
ident = models.CharField(max_length=254, default="")
|
||||
system = models.CharField(max_length=254, default="")
|
||||
destination = models.CharField(max_length=254, default="")
|
||||
sigtype = models.CharField(max_length=254, default="")
|
||||
status = models.CharField(max_length=254, default="")
|
||||
notes = models.CharField(max_length=254, default="")
|
||||
|
||||
|
||||
1
sigtracker/tests.py
Normal file
1
sigtracker/tests.py
Normal file
@@ -0,0 +1 @@
|
||||
# Create your tests here.
|
||||
72
sigtracker/views.py
Normal file
72
sigtracker/views.py
Normal file
@@ -0,0 +1,72 @@
|
||||
import datetime
|
||||
|
||||
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 util import check_if_user_has_permission
|
||||
from authentication.managers import AuthServicesInfoManager
|
||||
from eveonline.managers import EveManager
|
||||
from form import SignitureForm
|
||||
from models import sigtracker
|
||||
|
||||
import logging
|
||||
|
||||
logger = logging.getLogger(__name__)
|
||||
|
||||
def sigtracker_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(sigtracker_util_test)
|
||||
@permission_required('auth.signiture_view')
|
||||
def sigtracker_view(request):
|
||||
logger.debug("sigtracker_view called by user %s" % request.user)
|
||||
sigtracker_list = sigtracker.objects.all()
|
||||
render_items = {'sigtracker': sigtracker.objects.all()}
|
||||
|
||||
return render_to_response('registered/signituremanagement.html', render_items, context_instance=RequestContext(request))
|
||||
|
||||
|
||||
@login_required
|
||||
@permission_required('auth.signiture_management')
|
||||
def add_signiture_view(request):
|
||||
logger.debug("add_signiture_view called by user %s" % request.user)
|
||||
if request.method == 'POST':
|
||||
form = SignitureForm(request.POST)
|
||||
logger.debug("Request type POST contains form valid: %s" % form.is_valid())
|
||||
if form.is_valid():
|
||||
# handle valid form
|
||||
sig = sigtracker()
|
||||
sig.ident = form.cleaned_data['ident']
|
||||
sig.system = form.cleaned_data['system']
|
||||
sig.destination = form.cleaned_data['destination']
|
||||
sig.sigtype = form.cleaned_data['sigtype']
|
||||
sig.status = form.cleaned_data['status']
|
||||
sig.notes = form.cleaned_data['notes']
|
||||
sig.save()
|
||||
return HttpResponseRedirect("/sigtracker/")
|
||||
else:
|
||||
logger.debug("Returning new SignitureForm")
|
||||
form = SignitureForm()
|
||||
|
||||
render_items = {'form': form}
|
||||
|
||||
return render_to_response('registered/addsigniture.html', render_items, context_instance=RequestContext(request))
|
||||
|
||||
|
||||
@login_required
|
||||
@permission_required('auth.signiture_management')
|
||||
def remove_signiture(request, sigtracker_id):
|
||||
logger.debug("remove_signiture called by user %s for signiture id %s" % (request.user, sigtracker_id))
|
||||
if sigtracker.objects.filter(id=sigtracker_id).exists():
|
||||
sig = sigtracker.objects.get(id=sigtracker_id)
|
||||
sig.delete()
|
||||
logger.debug("Deleting sigtracker id %s by user %s" % (sigtracker_id, request.user))
|
||||
else:
|
||||
logger.error("Unable to delete signiture id %s for user %s - signiture matching id not found." % (sigtracker_id, request.user))
|
||||
return HttpResponseRedirect("/sigtracker/")
|
||||
Reference in New Issue
Block a user