forked from bbedward/graham_discord_bot
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathbot.py
128 lines (117 loc) · 4.31 KB
/
bot.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
# Install uvloop
try:
import uvloop
uvloop.install()
except ImportError:
print("Couldn't install uvloop, falling back to the slower asyncio event loop")
from cogs import account, help, tips, tip_legacy, stats, rain, admin, useroptions, favorites, spy, giveaway
from config import Config
from discord.ext.commands import Bot
from db.models.transaction import Transaction
from db.tortoise_config import DBConfig
from db.redis import RedisDB
from server import GrahamServer
from tortoise import Tortoise
from util.discord.channel import ChannelUtil
from util.env import Env
from util.logger import setup_logger
from version import __version__
import asyncio
import discord
intents = discord.Intents.default()
intents.members = True
intents.presences = True
import logging
from rpc.client import RPCClient
from tasks.transaction_queue import TransactionQueue
# Configuration
config = Config.instance()
# Setup logger
setup_logger(config.log_file, log_level=logging.DEBUG if config.debug else logging.INFO)
logger = logging.getLogger()
# TODO - re-enable for discord.py 1.5.0
client = Bot(command_prefix=config.command_prefix, intents=intents)
client.remove_command('help')
# Periodic re-queue tranasctions
async def reQueueTransactions(client):
while True:
logger.info(f"Re-queue task started")
await asyncio.sleep(600)
logger.info(f"Re-queue task running")
TransactionQueue.instance(bot=client).clear()
unprocessed_txs = await Transaction.filter(block_hash=None, destination__not_isnull=True).all().prefetch_related('sending_user', 'receiving_user')
for tx in unprocessed_txs:
await TransactionQueue.instance(bot=client).put(tx)
logger.info(f"Re-queued {len(unprocessed_txs)} transactions")
### Bot events
@client.event
async def on_ready():
logger.info(f"Starting Graham v{__version__}")
logger.info(f"Discord.py version {discord.__version__}")
logger.info(f"Bot name: {client.user.name}")
logger.info(f"Bot Discord ID: {client.user.id}")
await client.change_presence(activity=discord.Game(config.playing_status))
# Process any transactions in our DB that are outstanding
logger.info(f"Re-queueing any unprocessed transactions")
unprocessed_txs = await Transaction.filter(block_hash=None, destination__not_isnull=True).all().prefetch_related('sending_user', 'receiving_user')
for tx in unprocessed_txs:
await TransactionQueue.instance(bot=client).put(tx)
logger.info(f"Re-queued {len(unprocessed_txs)} transactions")
@client.event
async def on_message(message: discord.Message):
# disregard messages sent by the bot
if message.author.id == client.user.id:
return
# Process commands
await client.process_commands(message)
if __name__ == "__main__":
# Add cogs
client.add_cog(account.AccountCog(client))
client.add_cog(tips.TipsCog(client))
client.add_cog(help.HelpCog(client))
client.add_cog(stats.StatsCog(client))
client.add_cog(rain.RainCog(client))
client.add_cog(admin.AdminCog(client))
client.add_cog(useroptions.UserOptionsCog(client))
client.add_cog(favorites.FavoriteCog(client))
client.add_cog(spy.SpyCog(client))
client.add_cog(giveaway.GiveawayCog(client))
if not Env.banano():
# Add a command to warn users that tip unit has changed
client.add_cog(tip_legacy.TipLegacyCog(client))
# Start bot
loop = asyncio.get_event_loop()
try:
# Initialize database first
logger.info("Initializing database")
loop.run_until_complete(DBConfig().init_db())
tasks = [
client.start(config.bot_token),
# Create two queue consumers for transactions
TransactionQueue.instance(bot=client).queue_consumer(),
TransactionQueue.instance(bot=client).queue_consumer(),
reQueueTransactions(client)
]
# Setup optional server if configured
server_host, server_port = Config.instance().get_server_info()
if server_host is None or server_port is None:
logger.info("Graham server is disabled")
else:
server = GrahamServer(client, server_host, server_port)
logger.info(f"Graham server running at {server_host}:{server_port}")
tasks.append(server.start())
loop.run_until_complete(asyncio.wait(tasks))
except Exception:
logger.exception("Graham exited with exception")
except BaseException:
pass
finally:
logger.info("Graham is exiting")
tasks = [
client.logout(),
RPCClient.close(),
RedisDB.close(),
Tortoise.close_connections()
]
loop.run_until_complete(asyncio.wait(tasks))
loop.close()