Compare commits
No commits in common. "83e838c9b740932965a4fcda42b4a8593f840849" and "0d7b2a4935adcf770616687f036f6c3e077b4ad3" have entirely different histories.
83e838c9b7
...
0d7b2a4935
|
@ -1,4 +1,6 @@
|
||||||
from django.apps import AppConfig
|
from django.apps import AppConfig
|
||||||
|
|
||||||
|
|
||||||
class ApiConfig(AppConfig):
|
class ApiConfig(AppConfig):
|
||||||
name = 'apiserver.api'
|
default_auto_field = 'django.db.models.BigAutoField'
|
||||||
|
name = 'api'
|
||||||
|
|
|
@ -1,40 +0,0 @@
|
||||||
# Generated by Django 4.0.4 on 2022-04-27 23:47
|
|
||||||
|
|
||||||
from django.db import migrations, models
|
|
||||||
|
|
||||||
|
|
||||||
class Migration(migrations.Migration):
|
|
||||||
|
|
||||||
initial = True
|
|
||||||
|
|
||||||
dependencies = [
|
|
||||||
]
|
|
||||||
|
|
||||||
operations = [
|
|
||||||
migrations.CreateModel(
|
|
||||||
name='CoolerData',
|
|
||||||
fields=[
|
|
||||||
('id', models.BigAutoField(auto_created=True, primary_key=True, serialize=False, verbose_name='ID')),
|
|
||||||
('time', models.DateTimeField()),
|
|
||||||
('cooler_id', models.CharField(blank=True, max_length=36)),
|
|
||||||
],
|
|
||||||
),
|
|
||||||
migrations.CreateModel(
|
|
||||||
name='MinerData',
|
|
||||||
fields=[
|
|
||||||
('id', models.BigAutoField(auto_created=True, primary_key=True, serialize=False, verbose_name='ID')),
|
|
||||||
('time', models.DateTimeField()),
|
|
||||||
('miner_id', models.CharField(blank=True, max_length=36)),
|
|
||||||
('summary', models.JSONField()),
|
|
||||||
('fans', models.JSONField()),
|
|
||||||
('devdetails', models.JSONField()),
|
|
||||||
('version', models.JSONField()),
|
|
||||||
('devs', models.JSONField()),
|
|
||||||
('config', models.JSONField()),
|
|
||||||
('coin', models.JSONField()),
|
|
||||||
('pools', models.JSONField()),
|
|
||||||
('tunerstatus', models.JSONField()),
|
|
||||||
('temps', models.JSONField()),
|
|
||||||
],
|
|
||||||
),
|
|
||||||
]
|
|
|
@ -1,43 +0,0 @@
|
||||||
# Generated by Django 4.0.4 on 2022-06-23 21:30
|
|
||||||
|
|
||||||
from django.db import migrations, models
|
|
||||||
|
|
||||||
|
|
||||||
class Migration(migrations.Migration):
|
|
||||||
|
|
||||||
dependencies = [
|
|
||||||
('api', '0001_initial'),
|
|
||||||
]
|
|
||||||
|
|
||||||
operations = [
|
|
||||||
migrations.AddField(
|
|
||||||
model_name='coolerdata',
|
|
||||||
name='fan',
|
|
||||||
field=models.IntegerField(default=0),
|
|
||||||
preserve_default=False,
|
|
||||||
),
|
|
||||||
migrations.AddField(
|
|
||||||
model_name='coolerdata',
|
|
||||||
name='max_temp',
|
|
||||||
field=models.DecimalField(decimal_places=4, default=0, max_digits=7),
|
|
||||||
preserve_default=False,
|
|
||||||
),
|
|
||||||
migrations.AddField(
|
|
||||||
model_name='coolerdata',
|
|
||||||
name='pump',
|
|
||||||
field=models.IntegerField(default=0),
|
|
||||||
preserve_default=False,
|
|
||||||
),
|
|
||||||
migrations.AddField(
|
|
||||||
model_name='coolerdata',
|
|
||||||
name='rad_temp',
|
|
||||||
field=models.DecimalField(decimal_places=4, default=0, max_digits=7),
|
|
||||||
preserve_default=False,
|
|
||||||
),
|
|
||||||
migrations.AddField(
|
|
||||||
model_name='coolerdata',
|
|
||||||
name='tub_temp',
|
|
||||||
field=models.DecimalField(decimal_places=4, default=0, max_digits=7),
|
|
||||||
preserve_default=False,
|
|
||||||
),
|
|
||||||
]
|
|
|
@ -1,19 +0,0 @@
|
||||||
# Generated by Django 4.0.4 on 2022-06-24 00:01
|
|
||||||
|
|
||||||
from django.db import migrations, models
|
|
||||||
|
|
||||||
|
|
||||||
class Migration(migrations.Migration):
|
|
||||||
|
|
||||||
dependencies = [
|
|
||||||
('api', '0002_coolerdata_fan_coolerdata_max_temp_coolerdata_pump_and_more'),
|
|
||||||
]
|
|
||||||
|
|
||||||
operations = [
|
|
||||||
migrations.AddField(
|
|
||||||
model_name='minerdata',
|
|
||||||
name='json_version',
|
|
||||||
field=models.IntegerField(default=1),
|
|
||||||
preserve_default=False,
|
|
||||||
),
|
|
||||||
]
|
|
|
@ -1,28 +1,3 @@
|
||||||
from django.db import models
|
from django.db import models
|
||||||
|
|
||||||
class MinerData(models.Model):
|
# Create your models here.
|
||||||
time = models.DateTimeField()
|
|
||||||
miner_id = models.CharField(max_length=36, blank=True)
|
|
||||||
json_version = models.IntegerField()
|
|
||||||
|
|
||||||
summary = models.JSONField()
|
|
||||||
fans = models.JSONField()
|
|
||||||
devdetails = models.JSONField()
|
|
||||||
version = models.JSONField()
|
|
||||||
devs = models.JSONField()
|
|
||||||
config = models.JSONField()
|
|
||||||
coin = models.JSONField()
|
|
||||||
pools = models.JSONField()
|
|
||||||
tunerstatus = models.JSONField()
|
|
||||||
temps = models.JSONField()
|
|
||||||
|
|
||||||
class CoolerData(models.Model):
|
|
||||||
time = models.DateTimeField()
|
|
||||||
cooler_id = models.CharField(max_length=36, blank=True)
|
|
||||||
|
|
||||||
tub_temp = models.DecimalField(max_digits=7, decimal_places=4)
|
|
||||||
rad_temp = models.DecimalField(max_digits=7, decimal_places=4)
|
|
||||||
max_temp = models.DecimalField(max_digits=7, decimal_places=4)
|
|
||||||
|
|
||||||
fan = models.IntegerField()
|
|
||||||
pump = models.IntegerField()
|
|
||||||
|
|
|
@ -1,21 +1,7 @@
|
||||||
import logging
|
|
||||||
logger = logging.getLogger(__name__)
|
|
||||||
|
|
||||||
from django.contrib.auth.models import User
|
from django.contrib.auth.models import User
|
||||||
from rest_framework import viewsets, views, mixins
|
from rest_framework import viewsets
|
||||||
from rest_framework import permissions
|
from rest_framework import permissions
|
||||||
from rest_framework.decorators import action
|
from apiserver.api import serializers
|
||||||
from rest_framework.response import Response
|
|
||||||
from apiserver.api import serializers, models
|
|
||||||
|
|
||||||
from datetime import datetime, timezone
|
|
||||||
|
|
||||||
Base = viewsets.GenericViewSet
|
|
||||||
List = mixins.ListModelMixin
|
|
||||||
Retrieve = mixins.RetrieveModelMixin
|
|
||||||
Create = mixins.CreateModelMixin
|
|
||||||
Update = mixins.UpdateModelMixin
|
|
||||||
Destroy = mixins.DestroyModelMixin
|
|
||||||
|
|
||||||
|
|
||||||
class UserViewSet(viewsets.ModelViewSet):
|
class UserViewSet(viewsets.ModelViewSet):
|
||||||
|
@ -23,52 +9,3 @@ class UserViewSet(viewsets.ModelViewSet):
|
||||||
serializer_class = serializers.UserSerializer
|
serializer_class = serializers.UserSerializer
|
||||||
permission_classes = [permissions.IsAuthenticated]
|
permission_classes = [permissions.IsAuthenticated]
|
||||||
|
|
||||||
class DataViewSet(Base, List, Retrieve):
|
|
||||||
@action(detail=False, methods=['post'])
|
|
||||||
def push(self, request):
|
|
||||||
miner_data = request.data['miner_data']
|
|
||||||
cooler_data = request.data['cooler_data']
|
|
||||||
|
|
||||||
for miner_id, miner in miner_data.items():
|
|
||||||
time = miner['summary'][0]['STATUS'][0]['When']
|
|
||||||
|
|
||||||
models.MinerData.objects.update_or_create(
|
|
||||||
time=datetime.fromtimestamp(time, tz=timezone.utc),
|
|
||||||
miner_id=miner_id,
|
|
||||||
defaults=dict(
|
|
||||||
json_version=2,
|
|
||||||
summary=miner['summary'][0]['SUMMARY'][0],
|
|
||||||
fans=miner['fans'][0]['FANS'],
|
|
||||||
devdetails=miner['devdetails'][0]['DEVDETAILS'],
|
|
||||||
version=miner['version'][0]['VERSION'][0],
|
|
||||||
devs=miner['devs'][0]['DEVS'],
|
|
||||||
config=miner['config'][0]['CONFIG'][0],
|
|
||||||
coin=miner['coin'][0]['COIN'][0],
|
|
||||||
pools=miner['pools'][0]['POOLS'],
|
|
||||||
tunerstatus=miner['tunerstatus'][0]['TUNERSTATUS'][0],
|
|
||||||
temps=miner['temps'][0]['TEMPS'],
|
|
||||||
),
|
|
||||||
)
|
|
||||||
|
|
||||||
time = cooler_data['time']
|
|
||||||
cooler_id = cooler_data['cooler_id']
|
|
||||||
|
|
||||||
models.CoolerData.objects.update_or_create(
|
|
||||||
time=datetime.fromtimestamp(time, tz=timezone.utc),
|
|
||||||
cooler_id=cooler_id,
|
|
||||||
defaults=dict(
|
|
||||||
tub_temp=cooler_data['tub_temp'],
|
|
||||||
rad_temp=cooler_data['rad_temp'],
|
|
||||||
max_temp=cooler_data['max_temp'],
|
|
||||||
fan=cooler_data['fan'],
|
|
||||||
pump=cooler_data['pump'],
|
|
||||||
),
|
|
||||||
)
|
|
||||||
|
|
||||||
logging.info('Added {} miner data points from cooler {}.'.format(
|
|
||||||
len(miner_data),
|
|
||||||
cooler_id,
|
|
||||||
))
|
|
||||||
|
|
||||||
return Response(200)
|
|
||||||
|
|
||||||
|
|
|
@ -10,10 +10,6 @@ For the full list of settings and their values, see
|
||||||
https://docs.djangoproject.com/en/4.0/ref/settings/
|
https://docs.djangoproject.com/en/4.0/ref/settings/
|
||||||
"""
|
"""
|
||||||
|
|
||||||
import os
|
|
||||||
import logging.config
|
|
||||||
logger = logging.getLogger(__name__)
|
|
||||||
|
|
||||||
from pathlib import Path
|
from pathlib import Path
|
||||||
|
|
||||||
# Build paths inside the project like this: BASE_DIR / 'subdir'.
|
# Build paths inside the project like this: BASE_DIR / 'subdir'.
|
||||||
|
@ -26,8 +22,8 @@ BASE_DIR = Path(__file__).resolve().parent.parent
|
||||||
# SECURITY WARNING: keep the secret key used in production secret!
|
# SECURITY WARNING: keep the secret key used in production secret!
|
||||||
SECRET_KEY = 'django-insecure-au(y+z)$-iy#(obif&ilg*_pn0j_+0u=q*p7h(3c-ii-euncwx'
|
SECRET_KEY = 'django-insecure-au(y+z)$-iy#(obif&ilg*_pn0j_+0u=q*p7h(3c-ii-euncwx'
|
||||||
|
|
||||||
DEBUG_ENV = os.environ.get('DEBUG', False)
|
# SECURITY WARNING: don't run with debug turned on in production!
|
||||||
DEBUG = DEBUG_ENV or False
|
DEBUG = True
|
||||||
|
|
||||||
ALLOWED_HOSTS = [
|
ALLOWED_HOSTS = [
|
||||||
'api.soak.stctech.ca',
|
'api.soak.stctech.ca',
|
||||||
|
@ -44,8 +40,6 @@ INSTALLED_APPS = [
|
||||||
'django.contrib.messages',
|
'django.contrib.messages',
|
||||||
'django.contrib.staticfiles',
|
'django.contrib.staticfiles',
|
||||||
'rest_framework',
|
'rest_framework',
|
||||||
#'rest_framework.authtoken',
|
|
||||||
'apiserver.api',
|
|
||||||
]
|
]
|
||||||
|
|
||||||
MIDDLEWARE = [
|
MIDDLEWARE = [
|
||||||
|
@ -133,43 +127,3 @@ STATIC_URL = 'static/'
|
||||||
# https://docs.djangoproject.com/en/4.0/ref/settings/#default-auto-field
|
# https://docs.djangoproject.com/en/4.0/ref/settings/#default-auto-field
|
||||||
|
|
||||||
DEFAULT_AUTO_FIELD = 'django.db.models.BigAutoField'
|
DEFAULT_AUTO_FIELD = 'django.db.models.BigAutoField'
|
||||||
|
|
||||||
LOGGING = {
|
|
||||||
'version': 1,
|
|
||||||
'disable_existing_loggers': False,
|
|
||||||
'formatters': {
|
|
||||||
'medium': {
|
|
||||||
'format': '[%(asctime)s] [%(process)d] [%(levelname)7s] %(message)s'
|
|
||||||
},
|
|
||||||
},
|
|
||||||
'filters': {
|
|
||||||
},
|
|
||||||
'handlers': {
|
|
||||||
'console': {
|
|
||||||
'level': 'DEBUG',
|
|
||||||
'filters': [],
|
|
||||||
'class': 'logging.StreamHandler',
|
|
||||||
'formatter': 'medium'
|
|
||||||
},
|
|
||||||
},
|
|
||||||
'loggers': {
|
|
||||||
'gunicorn': {
|
|
||||||
'handlers': ['console'],
|
|
||||||
'level': 'DEBUG' if DEBUG else 'INFO',
|
|
||||||
'propagate': False,
|
|
||||||
},
|
|
||||||
'': {
|
|
||||||
'handlers': ['console'],
|
|
||||||
'level': 'DEBUG',
|
|
||||||
'propagate': True,
|
|
||||||
},
|
|
||||||
},
|
|
||||||
'root': {
|
|
||||||
'level': 'DEBUG' if DEBUG else 'INFO',
|
|
||||||
'handlers': ['console'],
|
|
||||||
},
|
|
||||||
}
|
|
||||||
logging.config.dictConfig(LOGGING)
|
|
||||||
|
|
||||||
if DEBUG: logger.info('Debug mode ON')
|
|
||||||
logger.info('Test logging for each thread')
|
|
||||||
|
|
|
@ -4,7 +4,6 @@ from apiserver.api import views
|
||||||
|
|
||||||
router = routers.DefaultRouter()
|
router = routers.DefaultRouter()
|
||||||
router.register(r'users', views.UserViewSet)
|
router.register(r'users', views.UserViewSet)
|
||||||
router.register(r'data', views.DataViewSet, basename='data')
|
|
||||||
|
|
||||||
# Wire up our API using automatic URL routing.
|
# Wire up our API using automatic URL routing.
|
||||||
# Additionally, we include login URLs for the browsable API.
|
# Additionally, we include login URLs for the browsable API.
|
||||||
|
|
Loading…
Reference in New Issue
Block a user