Merge branch 'main' of https://github.com/perm-hack/perm-hack
commit
985481b01a
@ -0,0 +1,18 @@
|
|||||||
|
import asyncio
|
||||||
|
from websockets.server import serve
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
async def handler(websocket):
|
||||||
|
async for message in websocket:
|
||||||
|
print('recv msg', message)
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
async def main():
|
||||||
|
async with serve(handler, '0.0.0.0', 8765):
|
||||||
|
await asyncio.Future() # run forever
|
||||||
|
|
||||||
|
asyncio.run(main())
|
@ -0,0 +1 @@
|
|||||||
|
websockets
|
@ -1,18 +1,84 @@
|
|||||||
from datetime import datetime
|
from datetime import datetime
|
||||||
|
|
||||||
from api.response.base import ResponseBase
|
from api.response.base import ResponseBase
|
||||||
|
from db.models.conveer import DBConveer
|
||||||
|
from pydantic import Field
|
||||||
|
|
||||||
|
|
||||||
class AreaCharts:
|
class AreaCharts(ResponseBase):
|
||||||
name: str
|
name: str = Field(...)
|
||||||
value: int
|
value: int = Field(...)
|
||||||
|
|
||||||
|
|
||||||
class TimelineCharts(AreaCharts):
|
class TimelineCharts(AreaCharts):
|
||||||
time: datetime
|
time: datetime = Field(...)
|
||||||
|
|
||||||
|
|
||||||
class RequestAnalytics(ResponseBase):
|
class ResponseAnalytics(ResponseBase):
|
||||||
timeline_charts: list[TimelineCharts]
|
timeline_charts: list[TimelineCharts] = Field(...)
|
||||||
area_charts: list[AreaCharts]
|
area_charts: list[AreaCharts] = Field(...)
|
||||||
bar_chars: list[AreaCharts]
|
total_numb: int = Field(...)
|
||||||
|
metal_numb: int = Field(...)
|
||||||
|
wood_numb: int = Field(...)
|
||||||
|
plastic_numb: int = Field(...)
|
||||||
|
glass_numb: int = Field(...)
|
||||||
|
|
||||||
|
|
||||||
|
class ResponseAnalyticsFactory:
|
||||||
|
|
||||||
|
@staticmethod
|
||||||
|
def get_from_model_area_charts(value, name) -> AreaCharts:
|
||||||
|
return AreaCharts(
|
||||||
|
name=name,
|
||||||
|
value=value
|
||||||
|
)
|
||||||
|
|
||||||
|
@staticmethod
|
||||||
|
def count_categories(models: list[DBConveer]) -> list[int]:
|
||||||
|
wood = 0
|
||||||
|
glass = 0
|
||||||
|
metal = 0
|
||||||
|
plastic = 0
|
||||||
|
for i in models:
|
||||||
|
wood += i.wood
|
||||||
|
glass += i.glass
|
||||||
|
metal += i.metal
|
||||||
|
plastic += i.plastic
|
||||||
|
return [wood, glass, metal, plastic]
|
||||||
|
|
||||||
|
@classmethod
|
||||||
|
def get_from_models_area_charts(cls, models: list[DBConveer]) -> list[AreaCharts]:
|
||||||
|
wood, glass, metal, plastic = cls.count_categories(models)
|
||||||
|
return [cls.get_from_model_area_charts(name='wood', value=wood),
|
||||||
|
cls.get_from_model_area_charts(name='glass', value=glass),
|
||||||
|
cls.get_from_model_area_charts(name='metal', value=metal),
|
||||||
|
cls.get_from_model_area_charts(name='plastic', value=plastic)]
|
||||||
|
|
||||||
|
@classmethod
|
||||||
|
def get_from_model_timeline_charts(cls, name, value, time):
|
||||||
|
return TimelineCharts(
|
||||||
|
**cls.get_from_model_area_charts(name=name, value=value).__dict__,
|
||||||
|
time=time)
|
||||||
|
|
||||||
|
@classmethod
|
||||||
|
def get_from_model_timeline_chart(cls, models: list[DBConveer]) -> list[TimelineCharts]:
|
||||||
|
response = []
|
||||||
|
print(len(models))
|
||||||
|
for i in models:
|
||||||
|
response.append(cls.get_from_model_timeline_charts(name='wood', value=i.wood, time=i.created_at))
|
||||||
|
response.append(cls.get_from_model_timeline_charts(name='glass', value=i.glass, time=i.created_at))
|
||||||
|
response.append(cls.get_from_model_timeline_charts(name='plastic', value=i.plastic, time=i.created_at))
|
||||||
|
response.append(cls.get_from_model_timeline_charts(name='metal', value=i.metal, time=i.created_at))
|
||||||
|
return response
|
||||||
|
|
||||||
|
@classmethod
|
||||||
|
def get_from_models(cls, models: list[DBConveer]) -> ResponseAnalytics:
|
||||||
|
return ResponseAnalytics(
|
||||||
|
area_charts=cls.get_from_models_area_charts(models),
|
||||||
|
timeline_charts=cls.get_from_model_timeline_chart(models),
|
||||||
|
total_numb=sum(cls.count_categories(models)),
|
||||||
|
metal_numb=cls.count_categories(models)[2],
|
||||||
|
wood_numb=cls.count_categories(models)[0],
|
||||||
|
plastic_numb=cls.count_categories(models)[3],
|
||||||
|
glass_numb=cls.count_categories(models)[1]
|
||||||
|
)
|
||||||
|
Loading…
Reference in new issue