Compare commits
1 Commits
99e5a44e40
...
main
| Author | SHA1 | Date | |
|---|---|---|---|
|
|
d8c1748244 |
4
.envrc
4
.envrc
@@ -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
|
||||||
|
|||||||
32
src/main.rs
32
src/main.rs
@@ -1,4 +1,4 @@
|
|||||||
use std::{io, path::Path};
|
use std::{io, path::Path, time::Duration};
|
||||||
|
|
||||||
use ::serenity::all::{ChannelId, EditMessage, 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};
|
||||||
@@ -392,12 +392,17 @@ async fn register_commands(
|
|||||||
}
|
}
|
||||||
|
|
||||||
#[tracing::instrument(skip(ctx))]
|
#[tracing::instrument(skip(ctx))]
|
||||||
async fn handle_message(ctx: impl AsRef<serenity::Http>, message: &serenity::Message) -> Result<()> {
|
async fn handle_message(
|
||||||
for embed in &message.embeds {
|
ctx: impl AsRef<serenity::Http>,
|
||||||
if embed.url.as_ref().is_some_and(|url| url.contains("https://clocktower.live")) {
|
message: &serenity::Message,
|
||||||
|
) -> Result<()> {
|
||||||
|
tracing::info!("Got message: {}", message.content);
|
||||||
|
if message.content.contains("https://clocktower.live") {
|
||||||
let mut message = message.clone();
|
let mut message = message.clone();
|
||||||
message.edit(&ctx.as_ref(), EditMessage::new().suppress_embeds(true)).await?;
|
tokio::time::sleep(Duration::from_secs(2)).await;
|
||||||
}
|
message
|
||||||
|
.edit(&ctx.as_ref(), EditMessage::new().suppress_embeds(true))
|
||||||
|
.await?;
|
||||||
}
|
}
|
||||||
Ok(())
|
Ok(())
|
||||||
}
|
}
|
||||||
@@ -409,8 +414,13 @@ async fn on_event(
|
|||||||
_: &Data,
|
_: &Data,
|
||||||
) -> Result<()> {
|
) -> Result<()> {
|
||||||
match event {
|
match event {
|
||||||
serenity::FullEvent::GuildCreate { guild, is_new: _ } => register_commands(ctx, framework.options, guild.id).await?,
|
serenity::FullEvent::GuildCreate { guild, is_new: _ } => {
|
||||||
serenity::FullEvent::Message { new_message: msg } | serenity::FullEvent::MessageUpdate { new: Some(msg), .. } => handle_message(ctx, msg).await?,
|
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(())
|
||||||
@@ -436,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_MESSAGES;
|
| 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 {
|
||||||
|
|||||||
Reference in New Issue
Block a user