* Fix tags (again?) * Make tag names more consistent * Remove prefix commands (not implemented well and not worth fixing) * Allow '-'s in tags * Fix /joke * Fix /members * Fix intel_hd issue match * Fix log analysis reply * Clearer log analysis messages It's weird to say the process failed when no issues were found. * Clippy * Final doc cleanup * Fix link expanding * Fix duplicate event filtering The other code simply does not work. ChannelId does have a method to grab members but I'm not sure whether it would work either. * Remove message resolution It's surprisingly hard to create an bug-free implementation. * Fix pluralkit detection * simplify tag codegen * commands: improve error handling in members unwrap() bad!!!11!! * events: use debug logs for pk checks * Revert "Remove message resolution" This reverts commit 0d9f224a81917212adafdeb2213f3cc11b44cf88. * Bring back prefix commands with "." (it's easier to type) * Add help * Fix messsage resolution * utils: factor out message resolution * Improve tag message * Disable VC support for message resolution for now * Improve prefix command usage Update on edit, display additional tip with wrong usage. * Check invoke_on_edit to display tip * Add defer in commands which make http requests * Apply tag sorting to slash commands too * handlers::error: `+=` -> `writeln!` * handlers::event: ignore own new messages * help: remove unneeded format! * optimize for size in release builds * nix: cleanup deployment expressions * nix: use treefmt * nix: update flake.lock Flake lock file updates: • Updated input 'fenix': 'github:nix-community/fenix/eb683549b7d76b12d1a009f888b91b70ed34485f' (2024-01-27) → 'github:nix-community/fenix/c53bb4a32f2fce7acf4e8e160a54779c4460ffdb' (2024-03-17) • Updated input 'fenix/rust-analyzer-src': 'github:rust-lang/rust-analyzer/596e5c77cf5b2b660b3ac2ce732fa0596c246d9b' (2024-01-26) → 'github:rust-lang/rust-analyzer/5ecace48f693afaa6adf8cb23086b651db3aec96' (2024-03-16) • Updated input 'nixpkgs': 'github:nixos/nixpkgs/4fddc9be4eaf195d631333908f2a454b03628ee5' (2024-01-25) → 'github:nixos/nixpkgs/34ad8c9f29a18b4dd97a9ad40ceb16954f24afe7' (2024-03-17) • Updated input 'pre-commit-hooks': 'github:cachix/pre-commit-hooks.nix/f56597d53fd174f796b5a7d3ee0b494f9e2285cc' (2024-01-20) → 'github:cachix/pre-commit-hooks.nix/5df5a70ad7575f6601d91f0efec95dd9bc619431' (2024-02-15) • Updated input 'procfile-nix': 'github:getchoo/procfile-nix/31a33e4264e5c6214844993c5b508fb3500ef5cd' (2024-01-27) → 'github:getchoo/procfile-nix/7a0ab379a4ab71c9deccaca9fb463e9aaea363d8' (2024-03-14) --------- Co-authored-by: seth <getchoo@tuta.io>
52 lines
1.3 KiB
Rust
52 lines
1.3 KiB
Rust
use eyre::{eyre, OptionExt, Result};
|
|
use log::{debug, trace};
|
|
use poise::serenity_prelude::{
|
|
ChannelType, Context, CreateAllowedMentions, CreateMessage, GuildChannel,
|
|
};
|
|
|
|
pub async fn handle(ctx: &Context, thread: &GuildChannel) -> Result<()> {
|
|
if thread.kind != ChannelType::PublicThread {
|
|
trace!("Not doing support onboard in non-public thread channel");
|
|
return Ok(());
|
|
}
|
|
|
|
if thread.last_message_id.is_some() {
|
|
debug!("Ignoring duplicate thread creation event");
|
|
return Ok(());
|
|
}
|
|
|
|
if thread
|
|
.parent_id
|
|
.ok_or_else(|| eyre!("Couldn't get parent ID from thread {}!", thread.name))?
|
|
.name(ctx)
|
|
.await
|
|
.unwrap_or_default()
|
|
!= "support"
|
|
{
|
|
debug!("Not posting onboarding message to threads outside of support");
|
|
return Ok(());
|
|
}
|
|
|
|
let owner = thread
|
|
.owner_id
|
|
.ok_or_eyre("Couldn't get owner of thread!")?;
|
|
|
|
let msg = format!(
|
|
"<@{}> We've received your support ticket! {} {}",
|
|
owner,
|
|
"Please upload your logs and post the link here if possible (run `tag log` to find out how).",
|
|
"Please don't ping people for support questions, unless you have their permission."
|
|
);
|
|
|
|
let allowed_mentions = CreateAllowedMentions::new()
|
|
.replied_user(true)
|
|
.users(Vec::from([owner]));
|
|
|
|
let message = CreateMessage::new()
|
|
.content(msg)
|
|
.allowed_mentions(allowed_mentions);
|
|
|
|
thread.send_message(ctx, message).await?;
|
|
|
|
Ok(())
|
|
}
|