You've already forked AstralRinth
forked from didirus/AstralRinth
* Migration * Fixup db models * Redis * Stuff * Switch PKs to BIGSERIALs, insert to notifications_deliveries when inserting notifications * Queue, templates * Query cache * Fixes, fixtures * Perf, cache template data & HTML bodies * Notification type configuration, ResetPassword notification type * Reset password * Query cache * Clippy + fmt * Traces, fix typo, fix user email in ResetPassword * send_email * Models, db * Remove dead code, adjust notification settings in migration * Clippy fmt * Delete dead code, fixes * Fmt * Update apps/labrinth/src/queue/email.rs Co-authored-by: Copilot <175728472+Copilot@users.noreply.github.com> Signed-off-by: François-Xavier Talbot <108630700+fetchfern@users.noreply.github.com> * Remove old fixtures * Unify email retry delay * Fix type * External notifications * Remove `notifications_types_preference_restrictions`, as user notification preferences is out of scope for this PR * Query cache, fmt, clippy * Fix join in get_many_user_exposed_on_site * Remove migration comment * Query cache * Update html body urls * Remove comment * Add paymentfailed.service variable to PaymentFailed notification variant * Fix compile error * Fix deleting notifications * Update apps/labrinth/src/database/models/user_item.rs Co-authored-by: Josiah Glosson <soujournme@gmail.com> Signed-off-by: François-Xavier Talbot <108630700+fetchfern@users.noreply.github.com> * Update apps/labrinth/src/database/models/user_item.rs Co-authored-by: Josiah Glosson <soujournme@gmail.com> Signed-off-by: François-Xavier Talbot <108630700+fetchfern@users.noreply.github.com> * Update Cargo.toml Co-authored-by: Josiah Glosson <soujournme@gmail.com> Signed-off-by: François-Xavier Talbot <108630700+fetchfern@users.noreply.github.com> * Update apps/labrinth/migrations/20250902133943_notification-extension.sql Co-authored-by: Josiah Glosson <soujournme@gmail.com> Signed-off-by: François-Xavier Talbot <108630700+fetchfern@users.noreply.github.com> * Address review comments * Fix compliation * Update apps/labrinth/src/database/models/users_notifications_preferences_item.rs Co-authored-by: Josiah Glosson <soujournme@gmail.com> Signed-off-by: François-Xavier Talbot <108630700+fetchfern@users.noreply.github.com> * Use strfmt to format emails * Configurable Reply-To * Configurable Reply-To * Refactor for email background task * Send some emails inline * Fix account creation email check * Revert "Use strfmt to format emails" This reverts commit e0d6614afe51fa6349918377e953ba294c34ae0b. * Reintroduce fill_template * Set password reset email inline * Process more emails per index * clippy fmt * Query cache --------- Signed-off-by: François-Xavier Talbot <108630700+fetchfern@users.noreply.github.com> Co-authored-by: Copilot <175728472+Copilot@users.noreply.github.com> Co-authored-by: Josiah Glosson <soujournme@gmail.com>
53 lines
1.5 KiB
Rust
53 lines
1.5 KiB
Rust
use crate::database::models::ids::DBUserId;
|
|
use crate::database::models::notification_item::NotificationBuilder;
|
|
use crate::database::models::user_item::DBUser;
|
|
use crate::database::redis::RedisPool;
|
|
use crate::models::v3::notifications::NotificationBody;
|
|
use crate::routes::ApiError;
|
|
use crate::util::guards::external_notification_key_guard;
|
|
use actix_web::web;
|
|
use actix_web::{HttpResponse, post};
|
|
use ariadne::ids::UserId;
|
|
use serde::Deserialize;
|
|
use sqlx::PgPool;
|
|
|
|
pub fn config(cfg: &mut web::ServiceConfig) {
|
|
cfg.service(create);
|
|
}
|
|
|
|
#[derive(Deserialize)]
|
|
struct CreateNotification {
|
|
pub body: NotificationBody,
|
|
pub user_ids: Vec<UserId>,
|
|
}
|
|
|
|
#[post("external_notifications", guard = "external_notification_key_guard")]
|
|
pub async fn create(
|
|
pool: web::Data<PgPool>,
|
|
redis: web::Data<RedisPool>,
|
|
create_notification: web::Json<CreateNotification>,
|
|
) -> Result<HttpResponse, ApiError> {
|
|
let CreateNotification { body, user_ids } =
|
|
create_notification.into_inner();
|
|
let user_ids = user_ids
|
|
.into_iter()
|
|
.map(|x| DBUserId(x.0 as i64))
|
|
.collect::<Vec<_>>();
|
|
|
|
let mut txn = pool.begin().await?;
|
|
|
|
if !DBUser::exists_many(&user_ids, &mut *txn).await? {
|
|
return Err(ApiError::InvalidInput(
|
|
"One of the specified users do not exist.".to_owned(),
|
|
));
|
|
}
|
|
|
|
NotificationBuilder { body }
|
|
.insert_many(user_ids, &mut txn, &redis)
|
|
.await?;
|
|
|
|
txn.commit().await?;
|
|
|
|
Ok(HttpResponse::Accepted().finish())
|
|
}
|