Compare commits

...

1 Commits

Author SHA1 Message Date
bluepython508
d8c1748244 Add tool to remove embeds for clocktower.live links 2025-12-29 00:53:24 +00:00
2 changed files with 34 additions and 9 deletions

4
.envrc
View File

@@ -1,4 +1,4 @@
use flake use flake
export DISCORD_TOKEN_FILE=./token-prod export DISCORD_TOKEN_FILE=./token
export DB_FILE=db-prod.sqlite export DB_FILE=db.sqlite

View File

@@ -1,6 +1,6 @@
use std::{io, path::Path}; use std::{io, path::Path, time::Duration};
use ::serenity::all::{ChannelId, GuildId, Mentionable, UserId}; use ::serenity::all::{ChannelId, EditMessage, GuildId, Mentionable, UserId};
use eyre::{Context as _, Error, OptionExt, Result}; use eyre::{Context as _, Error, OptionExt, Result};
use futures::{FutureExt, StreamExt, TryStreamExt}; use futures::{FutureExt, StreamExt, TryStreamExt};
use poise::serenity_prelude as serenity; use poise::serenity_prelude as serenity;
@@ -391,15 +391,38 @@ async fn register_commands(
Ok(()) Ok(())
} }
#[tracing::instrument(skip(ctx))]
async fn handle_message(
ctx: impl AsRef<serenity::Http>,
message: &serenity::Message,
) -> Result<()> {
tracing::info!("Got message: {}", message.content);
if message.content.contains("https://clocktower.live") {
let mut message = message.clone();
tokio::time::sleep(Duration::from_secs(2)).await;
message
.edit(&ctx.as_ref(), EditMessage::new().suppress_embeds(true))
.await?;
}
Ok(())
}
async fn on_event( async fn on_event(
ctx: &serenity::Context, ctx: &serenity::Context,
event: &serenity::FullEvent, event: &serenity::FullEvent,
framework: poise::FrameworkContext<'_, Data, Error>, framework: poise::FrameworkContext<'_, Data, Error>,
_: &Data, _: &Data,
) -> Result<()> { ) -> Result<()> {
if let serenity::FullEvent::GuildCreate { guild, is_new: _ } = event { match event {
register_commands(ctx, framework.options, guild.id).await?; serenity::FullEvent::GuildCreate { guild, is_new: _ } => {
}; register_commands(ctx, framework.options, guild.id).await?
}
serenity::FullEvent::Message { new_message: msg }
| serenity::FullEvent::MessageUpdate { new: Some(msg), .. } => {
handle_message(ctx, msg).await?
}
_ => {}
}
Ok(()) Ok(())
} }
@@ -423,8 +446,10 @@ async fn main() -> Result<()> {
) )
.wrap_err("A Discord token is required")?; .wrap_err("A Discord token is required")?;
let dbfile = std::env::var_os("DB_FILE").ok_or_eyre("A database file is required")?; let dbfile = std::env::var_os("DB_FILE").ok_or_eyre("A database file is required")?;
let intents = let intents = serenity::GatewayIntents::non_privileged()
serenity::GatewayIntents::non_privileged() | serenity::GatewayIntents::GUILD_MEMBERS; | serenity::GatewayIntents::GUILD_MEMBERS
| serenity::GatewayIntents::GUILD_MESSAGES
| serenity::GatewayIntents::MESSAGE_CONTENT;
let framework = poise::Framework::builder() let framework = poise::Framework::builder()
.options(poise::FrameworkOptions { .options(poise::FrameworkOptions {