Initial support for a trollbox

This commit is contained in:
dsc 2022-03-14 11:41:02 +02:00
parent e79059820f
commit 0619522bb1
6 changed files with 104 additions and 12 deletions

View file

@ -7,6 +7,7 @@ import asyncio
from typing import List, Set from typing import List, Set
from datetime import datetime from datetime import datetime
from asyncio_multisubscriber_queue import MultisubscriberQueue
from quart import Quart from quart import Quart
from quart_session import Session from quart_session import Session
import aioredis import aioredis
@ -18,7 +19,7 @@ now = datetime.now()
app: Quart = None app: Quart = None
cache = None cache = None
user_agents: List[str] = None user_agents: List[str] = None
connected_websockets: Set[asyncio.Queue] = set() broadcast = MultisubscriberQueue()
_is_primary_worker_thread = False _is_primary_worker_thread = False

View file

@ -11,7 +11,7 @@ from quart import websocket, jsonify, send_from_directory
import settings import settings
from wowlet_backend.factory import app from wowlet_backend.factory import app
from wowlet_backend.wsparse import WebsocketParse from wowlet_backend.wsparse import WebsocketParse
from wowlet_backend.utils import collect_websocket, feather_data from wowlet_backend.utils import broadcast, feather_data
@app.route("/") @app.route("/")
@ -28,8 +28,7 @@ async def suchwow(name: str):
@app.websocket('/ws') @app.websocket('/ws')
@collect_websocket async def ws():
async def ws(queue):
data = await feather_data() data = await feather_data()
# blast available data on connect # blast available data on connect
@ -56,7 +55,7 @@ async def ws(queue):
async def tx(): async def tx():
while True: while True:
data = await queue.get() data = await broadcast.get()
payload = json.dumps(data).encode() payload = json.dumps(data).encode()
await websocket.send(payload) await websocket.send(payload)

View file

@ -39,7 +39,7 @@ class WowletTask:
self._running = False self._running = False
async def start(self, *args, **kwargs): async def start(self, *args, **kwargs):
from wowlet_backend.factory import app, connected_websockets from wowlet_backend.factory import app, broadcast
if not self._active: if not self._active:
# invalid task # invalid task
return return
@ -94,11 +94,10 @@ class WowletTask:
propagate = False propagate = False
if propagate: if propagate:
for queue in connected_websockets: await broadcast.put({
await queue.put({ "cmd": self._websocket_cmd,
"cmd": self._websocket_cmd, "data": result
"data": result })
})
# optional: cache the result # optional: cache the result
if self._cache_key and result: if self._cache_key and result:

View file

@ -0,0 +1,26 @@
import re, sys, os
from datetime import datetime
import time
from wowlet_backend.factory import broadcast
HISTORY = []
async def add_chat(message: str, balance: float = 0):
global HISTORY
item = {
"message": message,
"balance": balance,
"date": int(time.time())
}
HISTORY.append(item)
if len(HISTORY) >= 25:
HISTORY = HISTORY[:25]
await broadcast.put({
"cmd": "trollEntry",
"data": item
})

View file

@ -161,3 +161,54 @@ async def image_resize(buffer: bytes, max_bounding_box: int = 512, quality: int
buffer.seek(0) buffer.seek(0)
return buffer.read() return buffer.read()
async def whaleornot(amount: float):
if amount <= 0:
fish_str = "amoeba"
elif amount < 100:
fish_str = "plankton"
elif amount >= 100 and amount < 200:
fish_str = "Paedocypris"
elif amount >= 200 and amount < 500:
fish_str = "Dwarf Goby"
elif amount >= 500 and amount < 1000:
fish_str = "European Pilchard"
elif amount >= 1000 and amount < 2000:
fish_str = "Goldfish"
elif amount >= 2000 and amount < 4000:
fish_str = "Herring"
elif amount >= 4000 and amount < 7000:
fish_str = "Atlantic Macerel"
elif amount >= 7000 and amount < 9000:
fish_str = "Gilt-head Bream"
elif amount >= 9000 and amount < 12000:
fish_str = "Salmonidae"
elif amount >= 12000 and amount < 20000:
fish_str = "Gadidae"
elif amount >= 20000 and amount < 40000:
fish_str = "Norwegian Delicious Salmon"
elif amount >= 40000 and amount < 60000:
fish_str = "Electric eel"
elif amount >= 60000 and amount < 80000:
fish_str = "Tuna"
elif amount >= 80000 and amount < 100000:
fish_str = "Wels catfish"
elif amount >= 100000 and amount < 120000:
fish_str = "Black marlin"
elif amount >= 120000 and amount < 160000:
fish_str = "Shark"
elif amount >= 160000 and amount < 220000:
fish_str = "Dolphin"
elif amount >= 220000 and amount < 320000:
fish_str = "Narwhal"
elif amount >= 320000 and amount < 500000:
fish_str = "Orca"
elif amount >= 500000 and amount < 700000:
fish_str = "Blue Whale"
elif amount >= 700000 and amount < 1000000:
fish_str = "Leviathan"
else:
fish_str = "Cthulu"
return fish_str

View file

@ -10,6 +10,7 @@ from typing import Dict, Union, Optional
from copy import deepcopy from copy import deepcopy
import asyncio import asyncio
import re import re
from wowlet_backend.trollbox import add_chat
from wowlet_backend.utils import RE_ADDRESS from wowlet_backend.utils import RE_ADDRESS
@ -27,6 +28,21 @@ class WebsocketParse:
return await WebsocketParse.requestPIN(data) return await WebsocketParse.requestPIN(data)
elif cmd == "lookupPIN": elif cmd == "lookupPIN":
return await WebsocketParse.lookupPIN(data) return await WebsocketParse.lookupPIN(data)
elif cmd == "trollbox":
pass
#return await WebsocketParse.addTrollChat(data)
@staticmethod
async def addTrollChat(data):
if not data or not isinstance(data, dict):
return
for needle in ['message', 'balance']:
if needle not in data:
return
message = data['message']
balance = data['balance']
await add_chat(message, balance)
@staticmethod @staticmethod
async def txFiatHistory(data=None): async def txFiatHistory(data=None):