diff options
author | Timo Kösters <timo@koesters.xyz> | 2023-08-10 17:26:55 +0200 |
---|---|---|
committer | Timo Kösters <timo@koesters.xyz> | 2023-08-10 17:26:55 +0200 |
commit | 606b25b9e73b467f44912bf10d2d4c299e9dbd2d (patch) | |
tree | a5eb41312a2c356d7d98854ac02944cb81680f86 | |
parent | fd9e52a559303989740cb64deb273eefea9d3958 (diff) | |
download | conduit-606b25b9e73b467f44912bf10d2d4c299e9dbd2d.zip |
improvement: more forgiving admin command syntax
-rw-r--r-- | src/service/admin/mod.rs | 2 | ||||
-rw-r--r-- | src/service/rooms/timeline/mod.rs | 4 |
2 files changed, 4 insertions, 2 deletions
diff --git a/src/service/admin/mod.rs b/src/service/admin/mod.rs index 6c3e3d0..0fe5edf 100644 --- a/src/service/admin/mod.rs +++ b/src/service/admin/mod.rs @@ -287,7 +287,7 @@ impl Service { // Parse and process a message from the admin room async fn process_admin_message(&self, room_message: String) -> RoomMessageEventContent { - let mut lines = room_message.lines(); + let mut lines = room_message.lines().filter(|l| !l.trim().is_empty()); let command_line = lines.next().expect("each string has at least one line"); let body: Vec<_> = lines.collect(); diff --git a/src/service/rooms/timeline/mod.rs b/src/service/rooms/timeline/mod.rs index 83c3010..25e1c54 100644 --- a/src/service/rooms/timeline/mod.rs +++ b/src/service/rooms/timeline/mod.rs @@ -456,7 +456,9 @@ impl Service { let server_user = format!("@conduit:{}", services().globals.server_name()); let to_conduit = body.starts_with(&format!("{server_user}: ")) - || body.starts_with(&format!("{server_user} ")); + || body.starts_with(&format!("{server_user} ")) + || body == format!("{server_user}:") + || body == format!("{server_user}"); // This will evaluate to false if the emergency password is set up so that // the administrator can execute commands as conduit |