mirror of
https://forgejo.ellis.link/continuwuation/continuwuity/
synced 2026-04-16 19:35:50 +00:00
Compare commits
3 Commits
renovate/p
...
renovate/h
| Author | SHA1 | Date | |
|---|---|---|---|
|
|
9a4818d5d8 | ||
|
|
bf6783cb83 | ||
|
|
2ca7149a7f |
@@ -71,7 +71,7 @@ runs:
|
||||
|
||||
- name: Install timelord-cli and git-warp-time
|
||||
if: steps.check-binaries.outputs.need-install == 'true'
|
||||
uses: https://github.com/taiki-e/install-action@eea29cff9a2b68892c0845ae3e4f45fc47ee9354 # v2
|
||||
uses: https://github.com/taiki-e/install-action@5939f3337e40968c39aa70f5ecb1417a92fb25a0 # v2
|
||||
with:
|
||||
tool: git-warp-time,timelord-cli@3.0.1
|
||||
|
||||
|
||||
@@ -205,4 +205,15 @@ jobs:
|
||||
needs:
|
||||
- merge-maxperf
|
||||
- merge-release
|
||||
env:
|
||||
BUILTIN_REGISTRY_USER: ${{ vars.BUILTIN_REGISTRY_USER }}
|
||||
BUILTIN_REGISTRY_PASSWORD: ${{ secrets.BUILTIN_REGISTRY_PASSWORD }}
|
||||
GITLAB_USERNAME: ${{ vars.GITLAB_USERNAME }}
|
||||
GITLAB_TOKEN: ${{ secrets.GITLAB_TOKEN }}
|
||||
N7574_GIT_USERNAME: ${{ vars.N7574_GIT_USERNAME }}
|
||||
N7574_GIT_TOKEN: ${{ secrets.N7574_GIT_TOKEN }}
|
||||
GH_PACKAGES_USER: ${{ vars.GH_PACKAGES_USER }}
|
||||
GH_PACKAGES_TOKEN: ${{ secrets.GH_PACKAGES_TOKEN }}
|
||||
DOCKER_MIRROR_USER: ${{ vars.DOCKER_MIRROR_USER }}
|
||||
DOCKER_MIRROR_TOKEN: ${{ secrets.DOCKER_MIRROR_TOKEN }}
|
||||
uses: ./.forgejo/workflows/mirror-images.yml
|
||||
|
||||
1
changelog.d/1624.feature
Normal file
1
changelog.d/1624.feature
Normal file
@@ -0,0 +1 @@
|
||||
Implemented option to deprioritize servers for room join requests. Contributed by @ezera.
|
||||
@@ -1409,6 +1409,20 @@
|
||||
#
|
||||
#ignore_messages_from_server_names = []
|
||||
|
||||
# List of server names that continuwuity will deprioritize (try last) when
|
||||
# a client requests to join a room.
|
||||
#
|
||||
# This can be used to potentially speed up room join requests, by
|
||||
# deprioritizing sending join requests through servers that are known to
|
||||
# be large or slow.
|
||||
#
|
||||
# continuwuity will still send join requests to servers in this list if
|
||||
# the room couldn't be joined via other servers it federates with.
|
||||
#
|
||||
# example: ["example.com"]
|
||||
#
|
||||
#deprioritize_joins_through_servers = []
|
||||
|
||||
# Send messages from users that the user has ignored to the client.
|
||||
#
|
||||
# There is no way for clients to receive messages sent while a user was
|
||||
|
||||
@@ -113,6 +113,7 @@ pub(crate) async fn join_room_by_id_route(
|
||||
servers.sort_unstable();
|
||||
servers.dedup();
|
||||
shuffle(&mut servers);
|
||||
let servers = deprioritize(servers, &services.config.deprioritize_joins_through_servers);
|
||||
|
||||
join_room_by_id_helper(
|
||||
&services,
|
||||
@@ -241,6 +242,7 @@ pub(crate) async fn join_room_by_id_or_alias_route(
|
||||
},
|
||||
};
|
||||
|
||||
let servers = deprioritize(servers, &services.config.deprioritize_joins_through_servers);
|
||||
let join_room_response = join_room_by_id_helper(
|
||||
&services,
|
||||
sender_user,
|
||||
@@ -890,3 +892,59 @@ async fn make_join_request(
|
||||
info!("All {} servers were unable to assist in joining {room_id} :(", servers.len());
|
||||
Err!(BadServerResponse("No server available to assist in joining."))
|
||||
}
|
||||
|
||||
/// Moves deprioritized servers (if any) to the back of the list.
|
||||
///
|
||||
/// No-op if we aren't given any servers to deprioritize.
|
||||
fn deprioritize(
|
||||
servers: Vec<OwnedServerName>,
|
||||
deprioritized: &[OwnedServerName],
|
||||
) -> Vec<OwnedServerName> {
|
||||
if deprioritized.is_empty() {
|
||||
return servers;
|
||||
}
|
||||
|
||||
let (mut depr, mut servers): (Vec<_>, Vec<_>) =
|
||||
servers.into_iter().partition(|s| deprioritized.contains(s));
|
||||
servers.append(&mut depr);
|
||||
servers
|
||||
}
|
||||
|
||||
#[cfg(test)]
|
||||
mod tests {
|
||||
use ruma::OwnedServerName;
|
||||
|
||||
use super::*;
|
||||
|
||||
#[test]
|
||||
fn deprioritizing_servers_works() -> Result<(), Box<dyn std::error::Error>> {
|
||||
let servers = vec![
|
||||
"example.com".try_into()?,
|
||||
"slow.invalid".try_into()?,
|
||||
"example.org".try_into()?,
|
||||
];
|
||||
let depr = vec!["slow.invalid".try_into()?];
|
||||
let expected: Vec<OwnedServerName> = vec![
|
||||
"example.com".try_into()?,
|
||||
"example.org".try_into()?,
|
||||
"slow.invalid".try_into()?,
|
||||
];
|
||||
|
||||
let servers = deprioritize(servers, &depr);
|
||||
assert_eq!(servers, expected);
|
||||
Ok(())
|
||||
}
|
||||
|
||||
#[test]
|
||||
fn empty_deprioritized_is_noop() -> Result<(), Box<dyn std::error::Error>> {
|
||||
let servers = vec![
|
||||
"example.com".try_into()?,
|
||||
"slow.invalid".try_into()?,
|
||||
"example.org".try_into()?,
|
||||
];
|
||||
|
||||
let depr_servers = deprioritize(servers.clone(), &[]);
|
||||
assert_eq!(depr_servers, servers);
|
||||
Ok(())
|
||||
}
|
||||
}
|
||||
|
||||
@@ -1630,6 +1630,22 @@ pub struct Config {
|
||||
#[serde(default, with = "serde_regex")]
|
||||
pub ignore_messages_from_server_names: RegexSet,
|
||||
|
||||
/// List of server names that continuwuity will deprioritize (try last) when
|
||||
/// a client requests to join a room.
|
||||
///
|
||||
/// This can be used to potentially speed up room join requests, by
|
||||
/// deprioritizing sending join requests through servers that are known to
|
||||
/// be large or slow.
|
||||
///
|
||||
/// continuwuity will still send join requests to servers in this list if
|
||||
/// the room couldn't be joined via other servers it federates with.
|
||||
///
|
||||
/// example: ["example.com"]
|
||||
///
|
||||
/// default: []
|
||||
#[serde(default = "Vec::new")]
|
||||
pub deprioritize_joins_through_servers: Vec<OwnedServerName>,
|
||||
|
||||
/// Send messages from users that the user has ignored to the client.
|
||||
///
|
||||
/// There is no way for clients to receive messages sent while a user was
|
||||
|
||||
Reference in New Issue
Block a user