2 schema::federation_allowlist,
4 federation_allowlist::{FederationAllowList, FederationAllowListForm},
8 use diesel::{dsl::*, result::Error, *};
10 impl FederationAllowList {
11 pub fn replace(conn: &mut PgConnection, list_opt: Option<Vec<String>>) -> Result<(), Error> {
12 conn.build_transaction().read_write().run(|conn| {
13 if let Some(list) = list_opt {
17 // Upsert all of these as instances
18 let instance = Instance::create(conn, &domain)?;
20 let form = FederationAllowListForm {
21 instance_id: instance.id,
24 insert_into(federation_allowlist::table)
26 .get_result::<Self>(conn)?;
35 pub fn clear(conn: &mut PgConnection) -> Result<usize, Error> {
36 diesel::delete(federation_allowlist::table).execute(conn)
42 source::{federation_allowlist::FederationAllowList, instance::Instance},
43 utils::establish_unpooled_connection,
45 use serial_test::serial;
49 fn test_allowlist_insert_and_clear() {
50 let conn = &mut establish_unpooled_connection();
51 let allowed = Some(vec![
52 "tld1.xyz".to_string(),
53 "tld2.xyz".to_string(),
54 "tld3.xyz".to_string(),
57 FederationAllowList::replace(conn, allowed).unwrap();
59 let allows = Instance::allowlist(conn).unwrap();
61 assert_eq!(3, allows.len());
64 "tld1.xyz".to_string(),
65 "tld2.xyz".to_string(),
66 "tld3.xyz".to_string()
71 // Now test clearing them via Some(empty vec)
72 let clear_allows = Some(Vec::new());
74 FederationAllowList::replace(conn, clear_allows).unwrap();
75 let allows = Instance::allowlist(conn).unwrap();
77 assert_eq!(0, allows.len());
79 Instance::delete_all(conn).unwrap();