mirror of
https://github.com/osmarks/autobotrobot
synced 2025-01-09 23:20:26 +00:00
remove caching layer from apiotelephone
This commit is contained in:
parent
c150526df8
commit
b8af7a9ccc
@ -17,8 +17,6 @@ def generate_address(ctx):
|
|||||||
out += words[int.from_bytes(h[i * 2:i * 2 + 3], "little") % 8192].strip().title()
|
out += words[int.from_bytes(h[i * 2:i * 2 + 3], "little") % 8192].strip().title()
|
||||||
return out
|
return out
|
||||||
|
|
||||||
channel_calls_cache = {}
|
|
||||||
|
|
||||||
def setup(bot):
|
def setup(bot):
|
||||||
@bot.group(name="apiotelephone", aliases=["tel", "tele", "telephone", "apiotel"], brief="ApioTelephone lets you 'call' other servers.", help=f"""
|
@bot.group(name="apiotelephone", aliases=["tel", "tele", "telephone", "apiotel"], brief="ApioTelephone lets you 'call' other servers.", help=f"""
|
||||||
Call other (participating) servers with ApioTelephone! To configure a channel for telephony, do `{bot.command_prefix}tel setup` (requires Manage Channels).
|
Call other (participating) servers with ApioTelephone! To configure a channel for telephony, do `{bot.command_prefix}tel setup` (requires Manage Channels).
|
||||||
@ -34,44 +32,37 @@ def setup(bot):
|
|||||||
async def get_addr_config(addr):
|
async def get_addr_config(addr):
|
||||||
return await bot.database.execute_fetchone("SELECT * FROM telephone_config WHERE id = ?", (addr,))
|
return await bot.database.execute_fetchone("SELECT * FROM telephone_config WHERE id = ?", (addr,))
|
||||||
|
|
||||||
def cache_call(chan, other, other_wh):
|
|
||||||
x = channel_calls_cache.get(chan)
|
|
||||||
if not x:
|
|
||||||
x = []
|
|
||||||
channel_calls_cache[chan] = x
|
|
||||||
# append other end and associated webhook
|
|
||||||
x.append((other, other_wh))
|
|
||||||
|
|
||||||
def uncache_call(chan, other):
|
|
||||||
# remove other end
|
|
||||||
l = channel_calls_cache[chan]
|
|
||||||
for i, (c, _) in enumerate(l):
|
|
||||||
if c == other: l.pop(i)
|
|
||||||
|
|
||||||
async def populate_cache(db):
|
|
||||||
for row in await db.execute_fetchall("""SELECT tcf.channel_id AS from_channel, tct.channel_id AS to_channel, tcf.webhook AS from_webhook, tct.webhook AS to_webhook FROM calls
|
|
||||||
JOIN telephone_config AS tcf ON tcf.id = calls.from_id JOIN telephone_config AS tct ON tct.id = calls.to_id"""):
|
|
||||||
cache_call(row["from_channel"], row["to_channel"], row["to_webhook"])
|
|
||||||
cache_call(row["to_channel"], row["from_channel"], row["from_webhook"])
|
|
||||||
|
|
||||||
bot.loop.create_task(populate_cache(bot.database))
|
|
||||||
|
|
||||||
@bot.listen("on_message")
|
@bot.listen("on_message")
|
||||||
async def forward_call_messages(message):
|
async def forward_call_messages(message):
|
||||||
calls = channel_calls_cache.get(message.channel.id, None)
|
channel = message.channel.id
|
||||||
if not calls: return
|
|
||||||
if (message.author.discriminator == "0000" and message.author.bot) or message.author == bot.user or message.content == "": # check if webhook, from itself, or only has embeds
|
if (message.author.discriminator == "0000" and message.author.bot) or message.author == bot.user or message.content == "": # check if webhook, from itself, or only has embeds
|
||||||
return
|
return
|
||||||
|
calls = await bot.database.execute_fetchall("""SELECT tcf.channel_id AS from_channel, tct.channel_id AS to_channel,
|
||||||
|
tcf.webhook AS from_webhook, tct.webhook AS to_webhook FROM calls
|
||||||
|
JOIN telephone_config AS tcf ON tcf.id = calls.from_id JOIN telephone_config AS tct ON tct.id = calls.to_id
|
||||||
|
WHERE from_channel = ? OR to_channel = ?""", (channel, channel))
|
||||||
|
if calls == []: return
|
||||||
async def send_to(call):
|
async def send_to(call):
|
||||||
other_channel, other_webhook = call
|
if call["from_channel"] == channel:
|
||||||
if other_webhook:
|
other_channel, other_webhook = call["to_channel"], call["to_webhook"]
|
||||||
await discord.Webhook.from_url(other_webhook, adapter=discord.AsyncWebhookAdapter(bot.http._HTTPClient__session)).send(
|
|
||||||
content=message.content, username=message.author.name, avatar_url=message.author.avatar_url,
|
|
||||||
allowed_mentions=discord.AllowedMentions(everyone=False, roles=False, users=False))
|
|
||||||
else:
|
else:
|
||||||
|
other_channel, other_webhook = call["from_channel"], call["from_webhook"]
|
||||||
|
|
||||||
|
async def send_normal_message():
|
||||||
m = f"**{message.author.name}**: "
|
m = f"**{message.author.name}**: "
|
||||||
m += message.content[:2000 - len(m)]
|
m += message.content[:2000 - len(m)]
|
||||||
await bot.get_channel(other_channel).send(m)
|
await bot.get_channel(other_channel).send(m)
|
||||||
|
|
||||||
|
if other_webhook:
|
||||||
|
try:
|
||||||
|
await discord.Webhook.from_url(other_webhook, adapter=discord.AsyncWebhookAdapter(bot.http._HTTPClient__session)).send(
|
||||||
|
content=message.content, username=message.author.name, avatar_url=message.author.avatar_url,
|
||||||
|
allowed_mentions=discord.AllowedMentions(everyone=False, roles=False, users=False))
|
||||||
|
except discord.errors.NotFound:
|
||||||
|
logging.warn("channel %d webhook missing", other_channel)
|
||||||
|
await send_normal_message()
|
||||||
|
else: await send_normal_message()
|
||||||
|
|
||||||
await asyncio.gather(*map(send_to, calls))
|
await asyncio.gather(*map(send_to, calls))
|
||||||
|
|
||||||
@telephone.command()
|
@telephone.command()
|
||||||
@ -140,8 +131,6 @@ def setup(bot):
|
|||||||
ctx.send(embed=util.info_embed("Outgoing call", "Call accepted and connected.")),
|
ctx.send(embed=util.info_embed("Outgoing call", "Call accepted and connected.")),
|
||||||
recv_channel.send(embed=util.info_embed("Incoming call", "Call accepted and connected."))
|
recv_channel.send(embed=util.info_embed("Incoming call", "Call accepted and connected."))
|
||||||
)
|
)
|
||||||
cache_call(ctx.channel.id, recv_channel.id, recv_info["webhook"])
|
|
||||||
cache_call(recv_channel.id, ctx.channel.id, channel_info["webhook"])
|
|
||||||
elif em == "❎": # drop call
|
elif em == "❎": # drop call
|
||||||
await ctx.send(embed=util.error_embed("Your call was declined.", "Call declined"))
|
await ctx.send(embed=util.error_embed("Your call was declined.", "Call declined"))
|
||||||
|
|
||||||
@ -167,9 +156,6 @@ def setup(bot):
|
|||||||
await bot.database.commit()
|
await bot.database.commit()
|
||||||
other_channel = (await get_addr_config(other))["channel_id"]
|
other_channel = (await get_addr_config(other))["channel_id"]
|
||||||
|
|
||||||
uncache_call(ctx.channel.id, other_channel)
|
|
||||||
uncache_call(other_channel, ctx.channel.id)
|
|
||||||
|
|
||||||
await asyncio.gather(
|
await asyncio.gather(
|
||||||
ctx.send(embed=util.info_embed("Hung up", f"Call to {other} disconnected.")),
|
ctx.send(embed=util.info_embed("Hung up", f"Call to {other} disconnected.")),
|
||||||
bot.get_channel(other_channel).send(embed=util.info_embed("Hung up", f"Call to {addr} disconnected."))
|
bot.get_channel(other_channel).send(embed=util.info_embed("Hung up", f"Call to {addr} disconnected."))
|
||||||
|
Loading…
Reference in New Issue
Block a user