1
0
Fork 0
satnogs-db/db/base/admin.py

159 lines
5.7 KiB
Python

import logging
from socket import error as socket_error
from django.conf.urls import url
from django.contrib import admin, messages
from django.core.urlresolvers import reverse
from django.template.loader import render_to_string
from django.conf import settings
from django.contrib.sites.shortcuts import get_current_site
from django.http import HttpResponseRedirect
from django.shortcuts import redirect
from db.base.models import Mode, Satellite, Transmitter, Suggestion, DemodData, Telemetry
from db.base.tasks import check_celery, reset_decoded_data, decode_all_data
logger = logging.getLogger('db')
@admin.register(Mode)
class ModeAdmin(admin.ModelAdmin):
list_display = ('name',)
@admin.register(Satellite)
class SatelliteAdmin(admin.ModelAdmin):
list_display = ('name', 'norad_cat_id')
def get_urls(self):
urls = super(SatelliteAdmin, self).get_urls()
my_urls = [
url(r'^check_celery/$', self.check_celery, name='check_celery'),
url(r'^reset_data/(?P<norad>[0-9]+)/$', self.reset_data,
name='reset_data'),
url(r'^decode_all_data/(?P<norad>[0-9]+)/$', self.decode_all_data,
name='decode_all_data'),
]
return my_urls + urls
def check_celery(self, request):
try:
investigator = check_celery.delay()
except socket_error as e:
messages.error(request, 'Cannot connect to broker: %s' % e)
return HttpResponseRedirect(reverse('admin:index'))
try:
investigator.get(timeout=5)
except investigator.TimeoutError as e:
messages.error(request, 'Worker timeout: %s' % e)
else:
messages.success(request, 'Celery is OK')
finally:
return HttpResponseRedirect(reverse('admin:index'))
# resets all decoded data and changes the is_decoded flag back to False
# THIS IS VERY DISTRUCTIVE, but the expectation is that a decode_all_data
# would follow.
def reset_data(self, request, norad):
reset_decoded_data.delay(norad)
messages.success(request, 'Data reset task was triggered successfully!')
return redirect(reverse('admin:index'))
# force a decode of all data for a norad ID. This could be very resource
# intensive but necessary when catching a satellite up with a new decoder
def decode_all_data(self, request, norad):
decode_all_data.delay(norad)
messages.success(request, 'Decode task was triggered successfully!')
return redirect(reverse('admin:index'))
@admin.register(Transmitter)
class TransmitterAdmin(admin.ModelAdmin):
list_display = ('uuid', 'description', 'satellite', 'mode', 'uplink_low',
'uplink_high', 'downlink_low', 'downlink_high', 'baud',)
search_fields = ('satellite__id', 'uuid',)
list_filter = ('mode', 'baud')
readonly_fields = ('uuid', 'satellite', 'approved',)
@admin.register(Suggestion)
class SuggestionAdmin(admin.ModelAdmin):
list_display = ('uuid', 'description', 'transmitter_uuid', 'user', 'satellite', 'uplink_low',
'uplink_high', 'downlink_low', 'downlink_high',)
search_fields = ('satellite', 'uuid',)
list_filter = ('mode', 'invert')
readonly_fields = ('uuid', 'satellite', 'transmitter', 'approved', 'user',
'citation', 'transmitter_data')
actions = ['approve_suggestion']
def approve_suggestion(self, request, queryset):
for obj in queryset:
try:
transmitter = Transmitter.objects.get(id=obj.transmitter.id)
transmitter.update_from_suggestion(obj)
obj.delete()
except (Transmitter.DoesNotExist, AttributeError):
obj.approved = True
obj.citation = ''
obj.user = None
obj.save()
# Notify user
current_site = get_current_site(request)
subject = '[{0}] Your suggestion was approved'.format(current_site.name)
template = 'emails/suggestion_approved.txt'
data = {
'satname': obj.satellite.name
}
message = render_to_string(template, {'data': data})
try:
obj.user.email_user(subject, message, from_email=settings.DEFAULT_FROM_EMAIL)
except Exception:
logger.error(
'Could not send email to user',
exc_info=True
)
rows_updated = queryset.count()
# Print a message
if rows_updated == 1:
message_bit = '1 suggestion was'
else:
message_bit = '{0} suggestions were'.format(rows_updated)
self.message_user(request, '{0} successfully approved.'.format(message_bit))
approve_suggestion.short_description = 'Approve selected suggestions'
def transmitter_uuid(self, obj):
try:
return obj.transmitter.uuid
except Exception:
return '-'
def transmitter_data(self, obj):
if obj.transmitter:
redirect_url = reverse('admin:base_transmitter_changelist')
extra = '{0}'.format(obj.transmitter.pk)
return '<a href="{0}">Transmitter Initial Data</a>'.format(
redirect_url + extra)
else:
return '-'
transmitter_data.allow_tags = True
@admin.register(Telemetry)
class TelemetryAdmin(admin.ModelAdmin):
list_display = ('name', 'decoder')
@admin.register(DemodData)
class DemodDataAdmin(admin.ModelAdmin):
list_display = ('id', 'satellite', 'source', 'observer')
search_fields = ('transmitter__uuid', 'satellite__norad_cat_id', 'observer')
def satellite(self, obj):
return obj.satellite