Private
Public Access
1
0
Files
rowsandall/rowers/views/otherviews.py
Sander Roosendaal b4ed7a0a6b laatste loodjes
2021-04-26 19:52:36 +02:00

132 lines
3.4 KiB
Python

from __future__ import absolute_import
from __future__ import division
from __future__ import print_function
from __future__ import unicode_literals
from rowers.views.statements import *
from rq import Queue
from redis import Redis
from rq.job import Job
@login_required()
def download_fit(request,filename=''):
r = getrower(request.user)
pss = PlannedSession.objects.filter(fitfile=filename)
if len(pss) != 1: # pragma: no cover
raise Http404("Could not find the required file")
ps = pss[0]
owns = False
if ps.manager == request.user or request.user.rower in ps.rower.all():
owns = True
if not owns: # pragma: no cover
raise PermissionDenied("You are not allowed to download this file")
fitfile = ps.fitfile
try:
response = HttpResponse(fitfile)
except FileNotFoundError:
raise Http404("File not found")
response['Content-Disposition'] = 'attachment; filename="%s"' % filename # pragma: no cover
response['Content-Type'] = 'application/octet-stream' # pragma: no cover
return response # pragma: no cover
@login_required()
def failed_queue_view(request):
if not request.user.is_staff: # pragma: no cover
raise PermissionDenied("Not Allowed")
q = Queue('failed', connection=Redis())
resultslist = []
for job in q.jobs: # pragma: no cover
traceback = str(job.exc_info)
info = {
'id':job.id,
'started_at': job.started_at,
'traceback1': traceback,
}
resultslist += [info]
return render(request,
"failed_jobs.html",
{
'resultslist':resultslist,
}
)
@login_required()
def failed_queue_empty(request):
if not request.user.is_staff: # pragma: no cover
raise PermissionDenied("Not Allowed")
q = Queue('failed', connection=Redis())
q.empty()
return HttpResponseRedirect(reverse('failed_queue_view'))
@login_required()
def failed_job_view(request,id=0): # pragma: no cover
if not request.user.is_staff:
raise PermissionDenied("Not Allowed")
q = Queue('failed', connection=Redis())
thejob = q.fetch_job(id)
thejob.delete()
return HttpResponseRedirect(reverse('failed_queue_view'))
@login_required()
def errormessage_view(request,errormessage='aap'): # pragma: no cover
if (errormessage=='3dsecure'):
errormessage = '3D Secure Card Verification Error. Please check your card details.'
messages.error(request,errormessage)
return JSONResponse({
"result":1,
})
# Shows analysis page
@login_required()
@permission_required('rower.is_coach',fn=get_user_by_userid,raise_exception=True)
def analysis_view(request,userid=0):
r = getrequestrower(request,userid=userid)
return render(request,
"analysis.html",
{
'active':'nav-analysis',
'rower':r,
}
)
# Shows laboratory page
@login_required()
@permission_required('rower.is_coach',fn=get_user_by_userid,raise_exception=True)
def laboratory_view(request,userid=0):
r = getrequestrower(request,userid=userid)
return render(request,
"laboratory.html",
{
'active':'nav-analysis',
'rower':r,
}
)