mirror of
https://gitlab.com/famedly/conduit.git
synced 2025-01-14 21:46:29 +03:00
Merge branch 'mr-conduit-appservice-login' into 'next'
feat: support end to bridge encryption See merge request famedly/conduit!454
This commit is contained in:
commit
422ee40107
1 changed files with 20 additions and 0 deletions
|
@ -26,6 +26,7 @@ pub async fn get_login_types_route(
|
||||||
) -> Result<get_login_types::v3::Response> {
|
) -> Result<get_login_types::v3::Response> {
|
||||||
Ok(get_login_types::v3::Response::new(vec![
|
Ok(get_login_types::v3::Response::new(vec![
|
||||||
get_login_types::v3::LoginType::Password(Default::default()),
|
get_login_types::v3::LoginType::Password(Default::default()),
|
||||||
|
get_login_types::v3::LoginType::ApplicationService(Default::default()),
|
||||||
]))
|
]))
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -103,6 +104,25 @@ pub async fn login_route(body: Ruma<login::v3::Request>) -> Result<login::v3::Re
|
||||||
));
|
));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
login::v3::LoginInfo::ApplicationService(login::v3::ApplicationService { identifier }) => {
|
||||||
|
if !body.from_appservice {
|
||||||
|
return Err(Error::BadRequest(
|
||||||
|
ErrorKind::Forbidden,
|
||||||
|
"Forbidden login type."
|
||||||
|
));
|
||||||
|
};
|
||||||
|
let username = if let UserIdentifier::UserIdOrLocalpart(user_id) = identifier {
|
||||||
|
user_id.to_lowercase()
|
||||||
|
} else {
|
||||||
|
return Err(Error::BadRequest(ErrorKind::Forbidden, "Bad login type."));
|
||||||
|
};
|
||||||
|
let user_id =
|
||||||
|
UserId::parse_with_server_name(username, services().globals.server_name())
|
||||||
|
.map_err(|_| {
|
||||||
|
Error::BadRequest(ErrorKind::InvalidUsername, "Username is invalid.")
|
||||||
|
})?;
|
||||||
|
user_id
|
||||||
|
}
|
||||||
_ => {
|
_ => {
|
||||||
return Err(Error::BadRequest(
|
return Err(Error::BadRequest(
|
||||||
ErrorKind::Unknown,
|
ErrorKind::Unknown,
|
||||||
|
|
Loading…
Reference in a new issue