mirror of
https://github.com/LemmyNet/lemmy.git
synced 2025-01-22 06:01:09 +00:00
2e8687e203
* Update comment_report_view.rs * Update comment_report_view.rs * Update post_view.rs * Update utils.rs * Update schema.rs * stuff * stuff * fix actions * PostLike * fmt * more post stuff (partial) * remove uplete * returning * rename read_comments field * PersonPostAggregates * a * fix usage of read_comments_amount * comment * community * community_block * instance_block * LocalUser::export_backup * person_block * person * stuff (partial) * update cargo.lock * fix lemmy_db_schema * post_view * comment_report_view * comment_view * post_report_view * find and replace some selected values * private_message_view * vote_view * comment_reply_view * some action views * action_query, find_action * community_view * block views * person_mention_view * remove struct update * refactor actions function * actions_alias * clean up return types and trait bounds * fix all rust code * fmt * clippy fix * Migrate tables * migrate indexes and contraints, and add statistics * fix what appears to be a messed up merge * commented thing * Create uplete.rs * Update uplete.rs * Update uplete.rs * Update up.sql * Update comment.rs * Update Cargo.toml * Update comment.rs * Update post.rs * Update comment_view.rs * Update post_view.rs * Update comment_reply_view.rs * Update person_mention_view.rs * Update Cargo.toml * Update utils.rs * Update comment.rs * Update utils.rs * Update uplete.rs * Update uplete.rs * Update uplete.rs * Update comment.rs * Update uplete.rs * Update uplete.rs * Update uplete.rs * Update uplete.rs * Update uplete.rs * Update uplete.rs * Update comment_view.rs * Update post_view.rs * Update triggers.sql * Update triggers.sql * Update triggers.sql * Update comment_reply_view.rs * Update person_mention_view.rs * Update person_mention_view.rs * Update comment_reply_view.rs * Update uplete.rs * start removing post_id column * Update down.sql * Update schema.rs * Update comment.rs * Update comment.rs * Update comment.rs * Update schema.rs * Update comment.rs * Update like.rs * Update comment.rs * Update up.sql * Update down.sql * Update down.sql * Update up.sql * Update up.sql * Update down.sql * Update comment.rs * Update vote_view.rs * Update vote_view.rs * Update comment_aggregates.rs * Update person_aggregates.rs * Update comment_view.rs * Update vote_view.rs * Update mod.rs * Update create.rs * Update comment.rs * Update community.rs * Update community.rs * Update up.sql * Update uplete.rs * Update uplete.rs * revert to UpleteCount * Update comment.rs * Update traits.rs * Update comment.rs * Update community.rs * Update community_block.rs * Update community.rs * Update instance_block.rs * Update instance.rs * Update community_block.rs * Update person.rs * Update person_block.rs * Update person.rs * Update person_block.rs * Update person.rs * Update instance.rs * Update instance_block.rs * Update instance.rs * Update person.rs * Update post.rs * Update comment.rs * Update community.rs * Update person.rs * Update post_view.rs * Update comment.rs * reduce diff * revert some changes in views * Update post_view.rs * Update comment.rs * Update post.rs * fix missing cfg_attr * rewrite uplete * Update Cargo.toml * Update Cargo.toml * Update uplete.rs * add `pub` to structs that appear in trait bounds * optional = true * Update uplete.rs * Update community.rs * Update comment.rs * Update uplete.rs * Update uplete.rs * Update uplete.rs * Update uplete.rs * something is wrong with me * use new uplete function everywhere * fmt * fmt * Keep post_id when comment_actions::liked is not null * Update up.sql * Update up.sql * clean up up.sql * clean up down.sql * fix * Update person_aggregates.rs * fmt * Update uplete.rs * fmt * Update uplete.rs * Update community.rs * Update uplete.rs * Update local_user.rs * fmt * fix * fix * fmt * improve uplete api * Update uplete.rs * fix * fix * Update uplete.rs * Update uplete.rs * Update uplete.rs * Update uplete.rs * fix * fix test * fix db_views_actor imports * fix uplete import in post_view test * rerun ci * fix AllNull syntax error * fix DynColumn * Fix rust syntax * fmt * fix iter * pain * Update community_moderators.rs * Update community_moderator_view.rs * Update uplete.rs * Fix mistake found by chatgpt * revert debugging stuff, change migration date, refactor constraint * Update down.sql * Update down.sql * fmt * make things added to db_schema::utils more understandable * update rust version for woodpecker * finish merge * Fix index that checked read_comments twice instead of also checking read_comments_amount * fix * uplete: test_count, test_generated_sql_setting_one_column_null, test_count_methods * refactor uplete sql test * test setting both columns to null in uplete * make AllNull generic * test AllNull * Merge remote-tracking branch 'upstream/main' into smoosh-tables-together --------- Co-authored-by: phiresky <phireskyde+git@gmail.com>
200 lines
5.2 KiB
Rust
200 lines
5.2 KiB
Rust
use crate::{
|
|
newtypes::{CommunityId, DbUrl, PersonId},
|
|
utils::{get_conn, uplete, DbPool},
|
|
};
|
|
use diesel::{
|
|
associations::HasTable,
|
|
dsl,
|
|
query_builder::{DeleteStatement, IntoUpdateTarget},
|
|
query_dsl::methods::{FindDsl, LimitDsl},
|
|
result::Error,
|
|
Table,
|
|
};
|
|
use diesel_async::{
|
|
methods::{ExecuteDsl, LoadQuery},
|
|
AsyncPgConnection,
|
|
RunQueryDsl,
|
|
};
|
|
|
|
/// Returned by `diesel::delete`
|
|
pub type Delete<T> = DeleteStatement<<T as HasTable>::Table, <T as IntoUpdateTarget>::WhereClause>;
|
|
|
|
/// Returned by `Self::table().find(id)`
|
|
pub type Find<T> = dsl::Find<<T as HasTable>::Table, <T as Crud>::IdType>;
|
|
|
|
pub type PrimaryKey<T> = <<T as HasTable>::Table as Table>::PrimaryKey;
|
|
|
|
// Trying to create default implementations for `create` and `update` results in a lifetime mess and
|
|
// weird compile errors. https://github.com/rust-lang/rust/issues/102211
|
|
#[async_trait]
|
|
pub trait Crud: HasTable + Sized
|
|
where
|
|
Self::Table: FindDsl<Self::IdType>,
|
|
Find<Self>: LimitDsl + IntoUpdateTarget + Send,
|
|
Delete<Find<Self>>: ExecuteDsl<AsyncPgConnection> + Send + 'static,
|
|
|
|
// Used by `RunQueryDsl::first`
|
|
dsl::Limit<Find<Self>>: LoadQuery<'static, AsyncPgConnection, Self> + Send + 'static,
|
|
{
|
|
type InsertForm;
|
|
type UpdateForm;
|
|
type IdType: Send;
|
|
|
|
async fn create(pool: &mut DbPool<'_>, form: &Self::InsertForm) -> Result<Self, Error>;
|
|
|
|
async fn read(pool: &mut DbPool<'_>, id: Self::IdType) -> Result<Self, Error> {
|
|
let query: Find<Self> = Self::table().find(id);
|
|
let conn = &mut *get_conn(pool).await?;
|
|
query.first(conn).await
|
|
}
|
|
|
|
/// when you want to null out a column, you have to send Some(None)), since sending None means you
|
|
/// just don't want to update that column.
|
|
async fn update(
|
|
pool: &mut DbPool<'_>,
|
|
id: Self::IdType,
|
|
form: &Self::UpdateForm,
|
|
) -> Result<Self, Error>;
|
|
|
|
async fn delete(pool: &mut DbPool<'_>, id: Self::IdType) -> Result<usize, Error> {
|
|
let query: Delete<Find<Self>> = diesel::delete(Self::table().find(id));
|
|
let conn = &mut *get_conn(pool).await?;
|
|
query.execute(conn).await
|
|
}
|
|
}
|
|
|
|
#[async_trait]
|
|
pub trait Followable {
|
|
type Form;
|
|
async fn follow(pool: &mut DbPool<'_>, form: &Self::Form) -> Result<Self, Error>
|
|
where
|
|
Self: Sized;
|
|
async fn follow_accepted(
|
|
pool: &mut DbPool<'_>,
|
|
community_id: CommunityId,
|
|
person_id: PersonId,
|
|
) -> Result<Self, Error>
|
|
where
|
|
Self: Sized;
|
|
async fn unfollow(pool: &mut DbPool<'_>, form: &Self::Form) -> Result<uplete::Count, Error>
|
|
where
|
|
Self: Sized;
|
|
}
|
|
|
|
#[async_trait]
|
|
pub trait Joinable {
|
|
type Form;
|
|
async fn join(pool: &mut DbPool<'_>, form: &Self::Form) -> Result<Self, Error>
|
|
where
|
|
Self: Sized;
|
|
async fn leave(pool: &mut DbPool<'_>, form: &Self::Form) -> Result<uplete::Count, Error>
|
|
where
|
|
Self: Sized;
|
|
}
|
|
|
|
#[async_trait]
|
|
pub trait Likeable {
|
|
type Form;
|
|
type IdType;
|
|
async fn like(pool: &mut DbPool<'_>, form: &Self::Form) -> Result<Self, Error>
|
|
where
|
|
Self: Sized;
|
|
async fn remove(
|
|
pool: &mut DbPool<'_>,
|
|
person_id: PersonId,
|
|
item_id: Self::IdType,
|
|
) -> Result<uplete::Count, Error>
|
|
where
|
|
Self: Sized;
|
|
}
|
|
|
|
#[async_trait]
|
|
pub trait Bannable {
|
|
type Form;
|
|
async fn ban(pool: &mut DbPool<'_>, form: &Self::Form) -> Result<Self, Error>
|
|
where
|
|
Self: Sized;
|
|
async fn unban(pool: &mut DbPool<'_>, form: &Self::Form) -> Result<uplete::Count, Error>
|
|
where
|
|
Self: Sized;
|
|
}
|
|
|
|
#[async_trait]
|
|
pub trait Saveable {
|
|
type Form;
|
|
async fn save(pool: &mut DbPool<'_>, form: &Self::Form) -> Result<Self, Error>
|
|
where
|
|
Self: Sized;
|
|
async fn unsave(pool: &mut DbPool<'_>, form: &Self::Form) -> Result<uplete::Count, Error>
|
|
where
|
|
Self: Sized;
|
|
}
|
|
|
|
#[async_trait]
|
|
pub trait Blockable {
|
|
type Form;
|
|
async fn block(pool: &mut DbPool<'_>, form: &Self::Form) -> Result<Self, Error>
|
|
where
|
|
Self: Sized;
|
|
async fn unblock(pool: &mut DbPool<'_>, form: &Self::Form) -> Result<uplete::Count, Error>
|
|
where
|
|
Self: Sized;
|
|
}
|
|
|
|
#[async_trait]
|
|
pub trait Reportable {
|
|
type Form;
|
|
type IdType;
|
|
type ObjectIdType;
|
|
async fn report(pool: &mut DbPool<'_>, form: &Self::Form) -> Result<Self, Error>
|
|
where
|
|
Self: Sized;
|
|
async fn resolve(
|
|
pool: &mut DbPool<'_>,
|
|
report_id: Self::IdType,
|
|
resolver_id: PersonId,
|
|
) -> Result<usize, Error>
|
|
where
|
|
Self: Sized;
|
|
async fn resolve_all_for_object(
|
|
pool: &mut DbPool<'_>,
|
|
comment_id_: Self::ObjectIdType,
|
|
by_resolver_id: PersonId,
|
|
) -> Result<usize, Error>
|
|
where
|
|
Self: Sized;
|
|
async fn unresolve(
|
|
pool: &mut DbPool<'_>,
|
|
report_id: Self::IdType,
|
|
resolver_id: PersonId,
|
|
) -> Result<usize, Error>
|
|
where
|
|
Self: Sized;
|
|
}
|
|
|
|
#[async_trait]
|
|
pub trait ApubActor {
|
|
async fn read_from_apub_id(
|
|
pool: &mut DbPool<'_>,
|
|
object_id: &DbUrl,
|
|
) -> Result<Option<Self>, Error>
|
|
where
|
|
Self: Sized;
|
|
/// - actor_name is the name of the community or user to read.
|
|
/// - include_deleted, if true, will return communities or users that were deleted/removed
|
|
async fn read_from_name(
|
|
pool: &mut DbPool<'_>,
|
|
actor_name: &str,
|
|
include_deleted: bool,
|
|
) -> Result<Option<Self>, Error>
|
|
where
|
|
Self: Sized;
|
|
async fn read_from_name_and_domain(
|
|
pool: &mut DbPool<'_>,
|
|
actor_name: &str,
|
|
protocol_domain: &str,
|
|
) -> Result<Option<Self>, Error>
|
|
where
|
|
Self: Sized;
|
|
}
|