chore: TODO mobile device list api
This commit is contained in:
parent
67750f79e4
commit
1991f48757
|
@ -0,0 +1,36 @@
|
||||||
|
from typing import Optional
|
||||||
|
from rest_framework import serializers
|
||||||
|
from counter.models import DeviceCount, DeviceInfo
|
||||||
|
from mosquito.models import DeviceInfo as MosquitoDeviceInfo
|
||||||
|
|
||||||
|
|
||||||
|
class DeviceInfoMobileSerializer(serializers.ModelSerializer):
|
||||||
|
device_name = serializers.SerializerMethodField()
|
||||||
|
status = serializers.SerializerMethodField()
|
||||||
|
coordinate = serializers.SerializerMethodField()
|
||||||
|
|
||||||
|
class Meta:
|
||||||
|
model = DeviceInfo
|
||||||
|
fields = [
|
||||||
|
'device_id',
|
||||||
|
'device_name',
|
||||||
|
'status',
|
||||||
|
'coordinate',
|
||||||
|
]
|
||||||
|
|
||||||
|
def __init__(self, *args, **kwargs):
|
||||||
|
super().__init__(*args, **kwargs)
|
||||||
|
self.latest = None
|
||||||
|
self.cur_device = None
|
||||||
|
|
||||||
|
def get_device_name(self, obj) -> Optional[str]:
|
||||||
|
qs = MosquitoDeviceInfo.objects.filter(device_id=obj.device_id)
|
||||||
|
if qs.count() > 0:
|
||||||
|
device = qs.first()
|
||||||
|
self.cur_device = device
|
||||||
|
return device.device_name
|
||||||
|
return None
|
||||||
|
|
||||||
|
def get_status(self, obj) -> int:
|
||||||
|
return obj.online
|
||||||
|
|
|
@ -30,18 +30,29 @@ def get_vol(device_id, cur_vol):
|
||||||
return '{}{}'.format(round(vol, 1), '%')
|
return '{}{}'.format(round(vol, 1), '%')
|
||||||
|
|
||||||
|
|
||||||
def get_latest(device_id):
|
def get_device_latest_by_cache(device_id, key="device_latest_{}"):
|
||||||
latest_key = 'device_latest_{}'.format(device_id)
|
"""
|
||||||
|
Get latest device from cache
|
||||||
|
"""
|
||||||
|
latest_key = key.format(device_id)
|
||||||
latest = cache.get(latest_key)
|
latest = cache.get(latest_key)
|
||||||
if latest:
|
if latest:
|
||||||
return latest
|
return latest
|
||||||
latest = DeviceCount.objects.filter(device_id=device_id).order_by('-data_time')[0]
|
latest = DeviceCount.objects.filter(device_id=device_id).order_by('-data_time').first()
|
||||||
|
if latest is None:
|
||||||
|
return None
|
||||||
s = DeviceCountBaseSerializer(latest)
|
s = DeviceCountBaseSerializer(latest)
|
||||||
data = s.data
|
data = s.data
|
||||||
cache.set(latest_key, data, 60 * 10)
|
|
||||||
|
# set cache before return
|
||||||
|
set_device_latest_cache(latest_key, data)
|
||||||
return data
|
return data
|
||||||
|
|
||||||
|
|
||||||
|
def set_device_latest_cache(key: str, value: serializers.ModelSerializer, timeout=60 * 10):
|
||||||
|
cache.set(key, value, timeout)
|
||||||
|
|
||||||
|
|
||||||
class DeviceCountBaseSerializer(serializers.ModelSerializer):
|
class DeviceCountBaseSerializer(serializers.ModelSerializer):
|
||||||
class Meta:
|
class Meta:
|
||||||
model = DeviceCount
|
model = DeviceCount
|
||||||
|
@ -262,20 +273,17 @@ class DeviceInfoSerializer(serializers.ModelSerializer):
|
||||||
def get_device_name(self, obj):
|
def get_device_name(self, obj):
|
||||||
qs = MosquitoDeviceInfo.objects.filter(device_id=obj.device_id)
|
qs = MosquitoDeviceInfo.objects.filter(device_id=obj.device_id)
|
||||||
if qs.count() > 0:
|
if qs.count() > 0:
|
||||||
device = qs[0]
|
device = qs.first()
|
||||||
self.cur_device = device
|
self.cur_device = device
|
||||||
return device.device_name
|
return device.device_name
|
||||||
return None
|
return None
|
||||||
|
|
||||||
def get_status(self, obj):
|
@staticmethod
|
||||||
|
def get_status(obj):
|
||||||
return obj.online
|
return obj.online
|
||||||
|
|
||||||
def get_count(self, obj) -> str:
|
def get_count(self, obj) -> str:
|
||||||
try:
|
self.latest = get_device_latest_by_cache(obj.device_id)
|
||||||
# self.latest = DeviceCount.objects.filter(device_id=obj.device_id).order_by('-data_time')[0]
|
|
||||||
self.latest = get_latest(obj.device_id)
|
|
||||||
except IndexError:
|
|
||||||
self.latest = None
|
|
||||||
if self.latest:
|
if self.latest:
|
||||||
return self.latest['count']
|
return self.latest['count']
|
||||||
return '0'
|
return '0'
|
||||||
|
|
Loading…
Reference in New Issue