diff options
author | Dessalines <tyhou13@gmx.com> | 2020-07-11 19:12:56 -0400 |
---|---|---|
committer | Dessalines <tyhou13@gmx.com> | 2020-07-11 19:12:56 -0400 |
commit | 60288b2d060ba930fe6cae22c4824d88fe7a00c9 (patch) | |
tree | 8fed01325853240c69f3688ee621be29bedfd382 /server/src/code_migrations.rs | |
parent | 1710844a1bc6a4f46eceaa12f2fb428cb794c694 (diff) | |
parent | 1b9f2fa5f7f7831f59b24cb36a5607a769a0d92e (diff) |
Merge branch 'master' into jmarthernandez-remove-karma-from-search
Diffstat (limited to 'server/src/code_migrations.rs')
-rw-r--r-- | server/src/code_migrations.rs | 190 |
1 files changed, 190 insertions, 0 deletions
diff --git a/server/src/code_migrations.rs b/server/src/code_migrations.rs new file mode 100644 index 00000000..b28e120a --- /dev/null +++ b/server/src/code_migrations.rs @@ -0,0 +1,190 @@ +// This is for db migrations that require code +use crate::LemmyError; +use diesel::*; +use lemmy_db::{ + comment::Comment, + community::{Community, CommunityForm}, + naive_now, + post::Post, + private_message::PrivateMessage, + user::{UserForm, User_}, + Crud, +}; +use lemmy_utils::{generate_actor_keypair, make_apub_endpoint, EndpointType}; +use log::info; + +pub fn run_advanced_migrations(conn: &PgConnection) -> Result<(), LemmyError> { + user_updates_2020_04_02(&conn)?; + community_updates_2020_04_02(&conn)?; + post_updates_2020_04_03(&conn)?; + comment_updates_2020_04_03(&conn)?; + private_message_updates_2020_05_05(&conn)?; + + Ok(()) +} + +fn user_updates_2020_04_02(conn: &PgConnection) -> Result<(), LemmyError> { + use lemmy_db::schema::user_::dsl::*; + + info!("Running user_updates_2020_04_02"); + + // Update the actor_id, private_key, and public_key, last_refreshed_at + let incorrect_users = user_ + .filter(actor_id.eq("http://fake.com")) + .filter(local.eq(true)) + .load::<User_>(conn)?; + + sql_query("alter table user_ disable trigger refresh_user").execute(conn)?; + + for cuser in &incorrect_users { + let keypair = generate_actor_keypair()?; + + let form = UserForm { + name: cuser.name.to_owned(), + email: cuser.email.to_owned(), + matrix_user_id: cuser.matrix_user_id.to_owned(), + avatar: cuser.avatar.to_owned(), + password_encrypted: cuser.password_encrypted.to_owned(), + preferred_username: cuser.preferred_username.to_owned(), + updated: None, + admin: cuser.admin, + banned: cuser.banned, + show_nsfw: cuser.show_nsfw, + theme: cuser.theme.to_owned(), + default_sort_type: cuser.default_sort_type, + default_listing_type: cuser.default_listing_type, + lang: cuser.lang.to_owned(), + show_avatars: cuser.show_avatars, + send_notifications_to_email: cuser.send_notifications_to_email, + actor_id: make_apub_endpoint(EndpointType::User, &cuser.name).to_string(), + bio: cuser.bio.to_owned(), + local: cuser.local, + private_key: Some(keypair.private_key), + public_key: Some(keypair.public_key), + last_refreshed_at: Some(naive_now()), + }; + + User_::update(&conn, cuser.id, &form)?; + } + + sql_query("alter table user_ enable trigger refresh_user").execute(conn)?; + + info!("{} user rows updated.", incorrect_users.len()); + + Ok(()) +} + +fn community_updates_2020_04_02(conn: &PgConnection) -> Result<(), LemmyError> { + use lemmy_db::schema::community::dsl::*; + + info!("Running community_updates_2020_04_02"); + + // Update the actor_id, private_key, and public_key, last_refreshed_at + let incorrect_communities = community + .filter(actor_id.eq("http://fake.com")) + .filter(local.eq(true)) + .load::<Community>(conn)?; + + sql_query("alter table community disable trigger refresh_community").execute(conn)?; + + for ccommunity in &incorrect_communities { + let keypair = generate_actor_keypair()?; + + let form = CommunityForm { + name: ccommunity.name.to_owned(), + title: ccommunity.title.to_owned(), + description: ccommunity.description.to_owned(), + category_id: ccommunity.category_id, + creator_id: ccommunity.creator_id, + removed: None, + deleted: None, + nsfw: ccommunity.nsfw, + updated: None, + actor_id: make_apub_endpoint(EndpointType::Community, &ccommunity.name).to_string(), + local: ccommunity.local, + private_key: Some(keypair.private_key), + public_key: Some(keypair.public_key), + last_refreshed_at: Some(naive_now()), + published: None, + }; + + Community::update(&conn, ccommunity.id, &form)?; + } + + sql_query("alter table community enable trigger refresh_community").execute(conn)?; + + info!("{} community rows updated.", incorrect_communities.len()); + + Ok(()) +} + +fn post_updates_2020_04_03(conn: &PgConnection) -> Result<(), LemmyError> { + use lemmy_db::schema::post::dsl::*; + + info!("Running post_updates_2020_04_03"); + + // Update the ap_id + let incorrect_posts = post + .filter(ap_id.eq("http://fake.com")) + .filter(local.eq(true)) + .load::<Post>(conn)?; + + sql_query("alter table post disable trigger refresh_post").execute(conn)?; + + for cpost in &incorrect_posts { + let apub_id = make_apub_endpoint(EndpointType::Post, &cpost.id.to_string()).to_string(); + Post::update_ap_id(&conn, cpost.id, apub_id)?; + } + + info!("{} post rows updated.", incorrect_posts.len()); + + sql_query("alter table post enable trigger refresh_post").execute(conn)?; + + Ok(()) +} + +fn comment_updates_2020_04_03(conn: &PgConnection) -> Result<(), LemmyError> { + use lemmy_db::schema::comment::dsl::*; + + info!("Running comment_updates_2020_04_03"); + + // Update the ap_id + let incorrect_comments = comment + .filter(ap_id.eq("http://fake.com")) + .filter(local.eq(true)) + .load::<Comment>(conn)?; + + sql_query("alter table comment disable trigger refresh_comment").execute(conn)?; + + for ccomment in &incorrect_comments { + let apub_id = make_apub_endpoint(EndpointType::Comment, &ccomment.id.to_string()).to_string(); + Comment::update_ap_id(&conn, ccomment.id, apub_id)?; + } + + sql_query("alter table comment enable trigger refresh_comment").execute(conn)?; + + info!("{} comment rows updated.", incorrect_comments.len()); + + Ok(()) +} + +fn private_message_updates_2020_05_05(conn: &PgConnection) -> Result<(), LemmyError> { + use lemmy_db::schema::private_message::dsl::*; + + info!("Running private_message_updates_2020_05_05"); + + // Update the ap_id + let incorrect_pms = private_message + .filter(ap_id.eq("http://fake.com")) + .filter(local.eq(true)) + .load::<PrivateMessage>(conn)?; + + for cpm in &incorrect_pms { + let apub_id = make_apub_endpoint(EndpointType::PrivateMessage, &cpm.id.to_string()).to_string(); + PrivateMessage::update_ap_id(&conn, cpm.id, apub_id)?; + } + + info!("{} private message rows updated.", incorrect_pms.len()); + + Ok(()) +} |