Merge pull request 'fix: only allow valid usernames in /register' (#14) from fix-register into master

This commit is contained in:
timo 2020-05-13 18:00:18 +02:00
commit 86e20e6401
3 changed files with 21 additions and 16 deletions

2
.gitignore vendored
View File

@ -1,2 +1,4 @@
/target /target
**/*.rs.bk **/*.rs.bk
Rocket.toml

View File

@ -1,8 +1,8 @@
[global] [global]
hostname = "matrixtesting.koesters.xyz:59003" server_name = "your.server.name"
port = 59003 port = 8448
address = "0.0.0.0" address = "0.0.0.0"
[global.tls] #[global.tls]
certs = "/etc/letsencrypt/live/matrixtesting.koesters.xyz/fullchain.pem" #certs = "/etc/letsencrypt/live/your.server.name/fullchain.pem"
key = "/etc/letsencrypt/live/matrixtesting.koesters.xyz/privkey.pem" #key = "/etc/letsencrypt/live/your.server.name/privkey.pem"

View File

@ -65,9 +65,12 @@ pub fn get_register_available_route(
body: Ruma<get_username_availability::Request>, body: Ruma<get_username_availability::Request>,
) -> MatrixResult<get_username_availability::Response> { ) -> MatrixResult<get_username_availability::Response> {
// Validate user id // Validate user id
let user_id: UserId = let user_id =
match (*format!("@{}:{}", body.username.clone(), db.globals.server_name())).try_into() { match UserId::parse_with_server_name(body.username.clone(), db.globals.server_name())
Err(_) => { .ok()
.filter(|user_id| !user_id.is_historical())
{
None => {
debug!("Username invalid"); debug!("Username invalid");
return MatrixResult(Err(Error { return MatrixResult(Err(Error {
kind: ErrorKind::InvalidUsername, kind: ErrorKind::InvalidUsername,
@ -75,7 +78,7 @@ pub fn get_register_available_route(
status_code: http::StatusCode::BAD_REQUEST, status_code: http::StatusCode::BAD_REQUEST,
})); }));
} }
Ok(user_id) => user_id, Some(user_id) => user_id,
}; };
// Check if username is creative enough // Check if username is creative enough
@ -112,16 +115,16 @@ pub fn register_route(
} }
// Validate user id // Validate user id
let user_id: UserId = match (*format!( let user_id = match UserId::parse_with_server_name(
"@{}:{}",
body.username body.username
.clone() .clone()
.unwrap_or_else(|| utils::random_string(GUEST_NAME_LENGTH)), .unwrap_or_else(|| utils::random_string(GUEST_NAME_LENGTH)),
db.globals.server_name() db.globals.server_name(),
)) )
.try_into() .ok()
.filter(|user_id| !user_id.is_historical())
{ {
Err(_) => { None => {
debug!("Username invalid"); debug!("Username invalid");
return MatrixResult(Err(UiaaResponse::MatrixError(Error { return MatrixResult(Err(UiaaResponse::MatrixError(Error {
kind: ErrorKind::InvalidUsername, kind: ErrorKind::InvalidUsername,
@ -129,7 +132,7 @@ pub fn register_route(
status_code: http::StatusCode::BAD_REQUEST, status_code: http::StatusCode::BAD_REQUEST,
}))); })));
} }
Ok(user_id) => user_id, Some(user_id) => user_id,
}; };
// Check if username is creative enough // Check if username is creative enough