summaryrefslogtreecommitdiff
path: root/sbhs_server/experiment/views.py
diff options
context:
space:
mode:
Diffstat (limited to 'sbhs_server/experiment/views.py')
-rw-r--r--sbhs_server/experiment/views.py221
1 files changed, 0 insertions, 221 deletions
diff --git a/sbhs_server/experiment/views.py b/sbhs_server/experiment/views.py
deleted file mode 100644
index 515d2b2..0000000
--- a/sbhs_server/experiment/views.py
+++ /dev/null
@@ -1,221 +0,0 @@
-from django.shortcuts import render
-from django.http import HttpResponse
-from django.contrib.auth.decorators import login_required
-from django.contrib.auth import authenticate
-from django.contrib.auth import login as LOGIN
-from sbhs_server.tables.models import Slot, Account, Experiment, Booking
-import json, datetime, os, time
-from django.views.decorators.csrf import csrf_exempt
-from sbhs_server import settings
-# Create your views here.
-#
-def check_connection(req):
- return HttpResponse("TESTOK")
-
-@csrf_exempt
-def initiation(req):
- username = req.POST.get("username")
- password = req.POST.get("password")
- user = authenticate(username=username, password=password)
- if user is not None:
- if user.is_active:
- user1 = Account.objects.select_related().filter(id=user.id)
- user1 = user1[0]
- user_board = user1.board
- if user_board.online:
- slots = Slot.slots_now()
- slot_ids = [s.id for s in slots]
- now = datetime.datetime.now()
- bookings = user.booking_set.filter(booking_date__year=now.year,
- booking_date__month=now.month,
- booking_date__day=now.day,
- slot_id__in=slot_ids).select_related("slot")
- try:
- cur_booking = bookings[0]
- active_slot = cur_booking.slot
- except:
- cur_booking = None
- active_slot = None
-
- if active_slot is not None:
- endtime = cur_booking.end_time()
- if now < endtime:
- filename = datetime.datetime.strftime(now, "%Y%b%d_%H_%M_%S.txt")
- logdir = os.path.join(settings.EXPERIMENT_LOGS_DIR, user.username)
- if not os.path.exists(logdir):
- os.makedirs(logdir)
-
- f = open(os.path.join(logdir, filename), "a")
- f.close()
-
- LOGIN(req, user)
-
- e = Experiment()
- e.booking=cur_booking
- e.log=os.path.join(logdir, filename)
- e.save()
-
- key = str(user_board.mid)
-
- settings.boards[key]["experiment_id"] = e.id
- reset(req)
-
-
- STATUS = 1
- MESSAGE = filename
- else:
- reset(req)
- STATUS = 0
- MESSAGE = "Slot has ended. Please book the next slot to continue the experiment."
- else:
- STATUS = 0
- MESSAGE = "You haven't booked this slot."
- else:
- STATUS = 0
- MESSAGE = "Your SBHS is offline. Please contact the Vlabs team."
- else:
- STATUS = 0
- MESSAGE = "Your account is not activated yet. Please check your email for activation link."
- else:
- STATUS = 0
- MESSAGE = "Invalid username or password"
-
- return HttpResponse(json.dumps({"STATUS": STATUS, "MESSAGE": MESSAGE}))
-# return HttpResponse(key)
-# @login_required(redirect_field_name=None)
-@csrf_exempt
-def experiment(req):
- try:
- server_start_ts = int(time.time() * 1000)
- from sbhs_server.settings import boards
- user = req.user
- key = str(user.board.mid)
- experiment = Experiment.objects.select_related().filter(id=boards[key]["experiment_id"])
-
- if len(experiment) == 1 and user.id == experiment[0].booking.account.id and experiment[0].booking.trashed_at == None:
- experiment = experiment[0]
- now = datetime.datetime.now()
- endtime = experiment.booking.end_time()
- if endtime > now:
- timeleft = int((endtime-now).seconds)
- heat = max(min(int(req.POST.get("heat")), 100), 0)
- fan = max(min(int(req.POST.get("fan")), 100), 0)
-
- boards[key]["board"].setHeat(heat)
- boards[key]["board"].setFan(fan)
- temperature = boards[key]["board"].getTemp()
- log_data(boards[key]["board"], key, heat=heat, fan=fan, temp=temperature)
-
- server_end_ts = int(time.time() * 1000)
-
- STATUS = 1
- MESSAGE = "%s %d %d %2.2f" % (req.POST.get("iteration"),
- heat,
- fan,
- temperature)
- MESSAGE = "%s %s %d %d,%s,%d" % (MESSAGE,
- req.POST.get("timestamp"),
- server_start_ts,
- server_end_ts,
- req.POST.get("variables"), timeleft)
-
- f = open(experiment.log, "a")
- f.write(" ".join(MESSAGE.split(",")[:2]) + "\n")
- f.close()
- else:
- boards[key]["board"].setHeat(0)
- boards[key]["board"].setFan(100)
- log_data(boards[key]["board"], key)
-
- STATUS = 0
- MESSAGE = "Slot has ended. Please book the next slot to continue the experiment."
-
- reset(req)
- boards[key]["experiment_id"] = None
- else:
- STATUS = 0
- MESSAGE = "You haven't booked this slot."
-
- return HttpResponse(json.dumps({"STATUS": STATUS, "MESSAGE": MESSAGE}))
- except Exception:
- return HttpResponse(json.dumps({"STATUS": 0, "MESSAGE": "Invalid input. Perhaps the slot has ended. Please book the next slot to continue the experiment."}))
-
-@csrf_exempt
-def reset(req):
- try:
- from sbhs_server.settings import boards
- user = req.user
- if user.is_authenticated():
- key = str(user.board.mid)
- experiment = Experiment.objects.select_related().filter(id=boards[key]["experiment_id"])
-
- if len(experiment) == 1 and user == experiment[0].booking.account:
- experiment = experiment[0]
- now = datetime.datetime.now()
- endtime = experiment.booking.end_time()
- boards[key]["board"].setHeat(0)
- boards[key]["board"].setFan(100)
- log_data(boards[key]["board"], key)
- if endtime < now:
- boards[key]["experiment_id"] = None
- except:
- pass
-
- return HttpResponse("")
-
-def client_version(req):
- return HttpResponse("3")
-
-@login_required(redirect_field_name=None)
-def logs(req):
- bookings = Booking.objects.only("id").filter(account__id=req.user.id)
- deleted_bookings = Booking.trash.only("id").filter(account__id=req.user.id)
- bookings = list(bookings) + list(deleted_bookings)
- booking_ids = [b.id for b in bookings]
- experiments = Experiment.objects.select_related("booking", "booking__slot").filter(booking_id__in=booking_ids)
- for e in experiments:
- e.logname = e.log.split("/")[-1]
- return render(req, "experiment/logs.html", {"experiments": reversed(experiments)})
-
-@login_required(redirect_field_name=None)
-def download_log(req, experiment_id, fn):
- try:
- experiment = Experiment.objects.select_related("booking", "booking__account").get(id=experiment_id)
- assert req.user.id == experiment.booking.account.id
- f = open(experiment.log, "r")
- data = f.read()
- f.close()
- return HttpResponse(data, content_type='text/text')
- except:
- return HttpResponse("Requested log file doesn't exist.")
-
-def log_data(sbhs, mid, heat=None, fan=None, temp=None):
- f = open(settings.SBHS_GLOBAL_LOG_DIR + "/" + str(mid) + ".log", "a")
- if heat is None:
- heat = sbhs.getHeat()
- if fan is None:
- fan = sbhs.getFan()
- if temp is None:
- temp = sbhs.getTemp()
-
- data = "%d %s %s %s\n" % (int(time.time()), str(heat), str(fan), str(temp))
- f.write(data)
- f.close()
-
-def validate_log_file(req):
- import hashlib
- data = req.POST.get("data")
- data = data.strip().split("\n")
- clean_data = ""
- for line in data:
- columns = line.split(" ")
- if len(columns) >= 6:
- clean_data += (" ".join(columns[0:6]) + "\n")
-
- checksum = hashlib.sha1(clean_data).hexdigest()
-
- try:
- e = Experiment.objects.get(checksum=checksum)
- return HttpResponse("TRUE")
- except:
- return HttpResponse("FALSE")