summaryrefslogtreecommitdiff
path: root/sbhs_server/experiment
diff options
context:
space:
mode:
Diffstat (limited to 'sbhs_server/experiment')
-rw-r--r--sbhs_server/experiment/__init__.py0
-rw-r--r--sbhs_server/experiment/__init__.pycbin0 -> 149 bytes
-rw-r--r--sbhs_server/experiment/admin.py3
-rw-r--r--sbhs_server/experiment/models.py3
-rw-r--r--sbhs_server/experiment/models.pycbin0 -> 203 bytes
-rw-r--r--sbhs_server/experiment/tests.py3
-rw-r--r--sbhs_server/experiment/views.py221
-rw-r--r--sbhs_server/experiment/views.py.new222
8 files changed, 452 insertions, 0 deletions
diff --git a/sbhs_server/experiment/__init__.py b/sbhs_server/experiment/__init__.py
new file mode 100644
index 0000000..e69de29
--- /dev/null
+++ b/sbhs_server/experiment/__init__.py
diff --git a/sbhs_server/experiment/__init__.pyc b/sbhs_server/experiment/__init__.pyc
new file mode 100644
index 0000000..32fcf1c
--- /dev/null
+++ b/sbhs_server/experiment/__init__.pyc
Binary files differ
diff --git a/sbhs_server/experiment/admin.py b/sbhs_server/experiment/admin.py
new file mode 100644
index 0000000..8c38f3f
--- /dev/null
+++ b/sbhs_server/experiment/admin.py
@@ -0,0 +1,3 @@
+from django.contrib import admin
+
+# Register your models here.
diff --git a/sbhs_server/experiment/models.py b/sbhs_server/experiment/models.py
new file mode 100644
index 0000000..71a8362
--- /dev/null
+++ b/sbhs_server/experiment/models.py
@@ -0,0 +1,3 @@
+from django.db import models
+
+# Create your models here.
diff --git a/sbhs_server/experiment/models.pyc b/sbhs_server/experiment/models.pyc
new file mode 100644
index 0000000..9af4264
--- /dev/null
+++ b/sbhs_server/experiment/models.pyc
Binary files differ
diff --git a/sbhs_server/experiment/tests.py b/sbhs_server/experiment/tests.py
new file mode 100644
index 0000000..7ce503c
--- /dev/null
+++ b/sbhs_server/experiment/tests.py
@@ -0,0 +1,3 @@
+from django.test import TestCase
+
+# Create your tests here.
diff --git a/sbhs_server/experiment/views.py b/sbhs_server/experiment/views.py
new file mode 100644
index 0000000..515d2b2
--- /dev/null
+++ b/sbhs_server/experiment/views.py
@@ -0,0 +1,221 @@
+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")
diff --git a/sbhs_server/experiment/views.py.new b/sbhs_server/experiment/views.py.new
new file mode 100644
index 0000000..004f852
--- /dev/null
+++ b/sbhs_server/experiment/views.py.new
@@ -0,0 +1,222 @@
+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(str(e.id), str(settings.board[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")