lemmy/crates/db_schema/src/impls/local_site_rate_limit.rs
Dessalines d075acce43
Make all single-fetch database calls return an Option. (#4617)
- Diesel ordinarily throws an error when no results are returned for a
  single fetch, which is a bit confusing. This PR ensures that the
  missing value cases are all caught, and wrapped with new LemmyErrors,
  rather than diesel errors.
- Fixes #4601
2024-04-16 14:48:15 +02:00

63 lines
1.7 KiB
Rust

use crate::{
diesel::OptionalExtension,
schema::local_site_rate_limit,
source::local_site_rate_limit::{
LocalSiteRateLimit,
LocalSiteRateLimitInsertForm,
LocalSiteRateLimitUpdateForm,
},
utils::{get_conn, DbPool},
};
use diesel::{dsl::insert_into, result::Error};
use diesel_async::RunQueryDsl;
impl LocalSiteRateLimit {
pub async fn read(pool: &mut DbPool<'_>) -> Result<Option<Self>, Error> {
let conn = &mut get_conn(pool).await?;
local_site_rate_limit::table.first(conn).await.optional()
}
pub async fn create(
pool: &mut DbPool<'_>,
form: &LocalSiteRateLimitInsertForm,
) -> Result<Self, Error> {
let conn = &mut get_conn(pool).await?;
insert_into(local_site_rate_limit::table)
.values(form)
.get_result::<Self>(conn)
.await
}
pub async fn update(
pool: &mut DbPool<'_>,
form: &LocalSiteRateLimitUpdateForm,
) -> Result<(), Error> {
// avoid error "There are no changes to save. This query cannot be built"
if form.is_empty() {
return Ok(());
}
let conn = &mut get_conn(pool).await?;
diesel::update(local_site_rate_limit::table)
.set(form)
.get_result::<Self>(conn)
.await?;
Ok(())
}
}
impl LocalSiteRateLimitUpdateForm {
fn is_empty(&self) -> bool {
self.message.is_none()
&& self.message_per_second.is_none()
&& self.post.is_none()
&& self.post_per_second.is_none()
&& self.register.is_none()
&& self.register_per_second.is_none()
&& self.image.is_none()
&& self.image_per_second.is_none()
&& self.comment.is_none()
&& self.comment_per_second.is_none()
&& self.search.is_none()
&& self.search_per_second.is_none()
&& self.updated.is_none()
}
}