2023-07-22 16:06:38 +00:00
|
|
|
# No copyright
|
|
|
|
|
|
|
|
import asyncio
|
2023-07-22 12:44:46 +00:00
|
|
|
import json
|
2023-07-22 16:06:38 +00:00
|
|
|
import logging
|
|
|
|
import pybotters
|
|
|
|
import signal
|
|
|
|
|
|
|
|
from util.pair import Pair
|
|
|
|
from util.player import Player
|
|
|
|
from algo.mm import MM
|
2023-07-22 12:44:46 +00:00
|
|
|
|
|
|
|
with open("config.json", "r") as file:
|
|
|
|
config = json.load(file)
|
2023-07-22 16:06:38 +00:00
|
|
|
|
|
|
|
async def main():
|
2023-07-22 23:55:06 +00:00
|
|
|
logging.info("#### TMM ####")
|
|
|
|
|
2023-07-22 16:06:38 +00:00
|
|
|
alive = True
|
|
|
|
logging.basicConfig(level=logging.DEBUG)
|
|
|
|
|
|
|
|
def teardown():
|
|
|
|
nonlocal alive
|
|
|
|
alive = False
|
|
|
|
for t in asyncio.all_tasks():
|
|
|
|
t.cancel()
|
|
|
|
|
|
|
|
loop = asyncio.get_event_loop()
|
|
|
|
loop.add_signal_handler(signal.SIGTERM, teardown)
|
|
|
|
loop.add_signal_handler(signal.SIGINT, teardown)
|
|
|
|
|
|
|
|
async with pybotters.Client(apis={"bitbank":config["auth"]}) as pb:
|
|
|
|
player = Player(pb)
|
|
|
|
pair = Pair(pb, config["pair"])
|
|
|
|
algo = MM(player, pair, config["algorithm"]["mm"])
|
|
|
|
while alive:
|
|
|
|
try:
|
|
|
|
await asyncio.gather(
|
|
|
|
player.update(),
|
|
|
|
pair.update())
|
|
|
|
await algo.update()
|
|
|
|
except Exception as e:
|
|
|
|
print(e)
|
|
|
|
logging.error(e)
|
|
|
|
await asyncio.sleep(int(config["interval"]))
|
2023-07-22 12:44:46 +00:00
|
|
|
|
2023-07-22 16:06:38 +00:00
|
|
|
if __name__ == "__main__":
|
|
|
|
try:
|
|
|
|
loop = asyncio.new_event_loop()
|
|
|
|
loop.run_until_complete(main())
|
|
|
|
finally:
|
|
|
|
loop.close()
|