diff --git a/plume-models/src/instance.rs b/plume-models/src/instance.rs index 0697fae..331ecca 100644 --- a/plume-models/src/instance.rs +++ b/plume-models/src/instance.rs @@ -68,8 +68,11 @@ impl Instance { get!(instances); find_by!(instances, find_by_domain, public_domain as String); - pub fn block(&self) { - unimplemented!() + pub fn toggle_block(&self, conn: &PgConnection) { + diesel::update(self) + .set(instances::blocked.eq(!self.blocked)) + .get_result::(conn) + .expect("Couldn't block/unblock instance"); } pub fn has_admin(&self, conn: &PgConnection) -> bool { diff --git a/src/main.rs b/src/main.rs index 8491ebb..05b5f73 100644 --- a/src/main.rs +++ b/src/main.rs @@ -65,6 +65,7 @@ fn main() { routes::instance::admin, routes::instance::admin_instances, routes::instance::admin_instances_paginated, + routes::instance::toggle_block, routes::instance::update_settings, routes::instance::shared_inbox, routes::instance::nodeinfo, diff --git a/src/routes/instance.rs b/src/routes/instance.rs index 1fa6f40..ff58088 100644 --- a/src/routes/instance.rs +++ b/src/routes/instance.rs @@ -154,6 +154,15 @@ fn admin_instances_paginated(admin: Admin, conn: DbConn, page: Page) -> Template })) } +#[get("/admin/instances//block")] +fn toggle_block(admin: Admin, conn: DbConn, id: i32) -> Redirect { + if let Some(inst) = Instance::get(&*conn, id) { + inst.toggle_block(&*conn); + } + + Redirect::to(uri!(admin_instances)) +} + #[post("/inbox", data = "")] fn shared_inbox(conn: DbConn, data: String) -> String { let act: serde_json::Value = serde_json::from_str(&data[..]).unwrap(); diff --git a/templates/instance/list.html.tera b/templates/instance/list.html.tera index c534a7d..cabddcd 100644 --- a/templates/instance/list.html.tera +++ b/templates/instance/list.html.tera @@ -17,13 +17,15 @@ Administration of {{ instance.name }} {{ instance.name }} {{ instance.public_domain }}

- - {% if instance.blocked %} - Unblock - {% else %} - Block - {% endif %} - + {% if not instance.local %} + + {% if instance.blocked %} + Unblock + {% else %} + Block + {% endif %} + + {% endif %} {% endfor %}