client: Add get_login_types

This commit is contained in:
Kévin Commaille 2021-03-23 14:27:55 +01:00
parent dc74bc6116
commit 51d915a181
3 changed files with 48 additions and 9 deletions

View file

@ -74,7 +74,7 @@ use matrix_sdk_common::{
message::send_message_event, message::send_message_event,
profile::{get_avatar_url, get_display_name, set_avatar_url, set_display_name}, profile::{get_avatar_url, get_display_name, set_avatar_url, set_display_name},
room::create_room, room::create_room,
session::login, session::{get_login_types, login},
sync::sync_events, sync::sync_events,
uiaa::AuthData, uiaa::AuthData,
}, },
@ -636,6 +636,15 @@ impl Client {
.and_then(|room| room::Left::new(self.clone(), room)) .and_then(|room| room::Left::new(self.clone(), room))
} }
/// Gets the homeservers supported login types.
///
/// This should be the first step when trying to login so you can call the
/// appropriate method for the next step.
pub async fn get_login_types(&self) -> Result<get_login_types::Response> {
let request = get_login_types::Request::new();
self.send(request, None).await
}
/// Login to the server. /// Login to the server.
/// ///
/// This can be used for the first login as well as for subsequent logins, /// This can be used for the first login as well as for subsequent logins,
@ -1816,7 +1825,7 @@ mod test {
api::r0::{ api::r0::{
account::register::Request as RegistrationRequest, account::register::Request as RegistrationRequest,
directory::get_public_rooms_filtered::Request as PublicRoomsFilterRequest, directory::get_public_rooms_filtered::Request as PublicRoomsFilterRequest,
membership::Invite3pid, uiaa::AuthData, membership::Invite3pid, session::get_login_types::LoginType, uiaa::AuthData,
}, },
assign, assign,
directory::Filter, directory::Filter,
@ -1847,13 +1856,27 @@ mod test {
async fn login() { async fn login() {
let homeserver = Url::from_str(&mockito::server_url()).unwrap(); let homeserver = Url::from_str(&mockito::server_url()).unwrap();
let _m = mock("POST", "/_matrix/client/r0/login") let client = Client::new(homeserver).unwrap();
let _m_types = mock("GET", "/_matrix/client/r0/login")
.with_status(200)
.with_body(test_json::LOGIN_TYPES.to_string())
.create();
let can_password = client
.get_login_types()
.await
.unwrap()
.flows
.iter()
.any(|flow| flow == &LoginType::Password);
assert!(can_password);
let _m_login = mock("POST", "/_matrix/client/r0/login")
.with_status(200) .with_status(200)
.with_body(test_json::LOGIN.to_string()) .with_body(test_json::LOGIN.to_string())
.create(); .create();
let client = Client::new(homeserver).unwrap();
client client
.login("example", "wordpass", None, None) .login("example", "wordpass", None, None)
.await .await

View file

@ -198,6 +198,22 @@ lazy_static! {
}); });
} }
lazy_static! {
pub static ref LOGIN_TYPES: JsonValue = json!({
"flows": [
{
"type": "m.login.password"
},
{
"type": "m.login.sso"
},
{
"type": "m.login.token"
}
]
});
}
lazy_static! { lazy_static! {
pub static ref LOGOUT: JsonValue = json!({}); pub static ref LOGOUT: JsonValue = json!({});
} }

View file

@ -12,10 +12,10 @@ pub mod members;
pub mod sync; pub mod sync;
pub use events::{ pub use events::{
ALIAS, ALIASES, EVENT_ID, KEYS_QUERY, KEYS_UPLOAD, LOGIN, LOGIN_RESPONSE_ERR, LOGOUT, MEMBER, ALIAS, ALIASES, EVENT_ID, KEYS_QUERY, KEYS_UPLOAD, LOGIN, LOGIN_RESPONSE_ERR, LOGIN_TYPES,
MEMBER_NAME_CHANGE, MESSAGE_EDIT, MESSAGE_TEXT, NAME, POWER_LEVELS, PRESENCE, PUBLIC_ROOMS, LOGOUT, MEMBER, MEMBER_NAME_CHANGE, MESSAGE_EDIT, MESSAGE_TEXT, NAME, POWER_LEVELS, PRESENCE,
REACTION, REDACTED, REDACTED_INVALID, REDACTED_STATE, REDACTION, REGISTRATION_RESPONSE_ERR, PUBLIC_ROOMS, REACTION, REDACTED, REDACTED_INVALID, REDACTED_STATE, REDACTION,
ROOM_ID, ROOM_MESSAGES, TYPING, REGISTRATION_RESPONSE_ERR, ROOM_ID, ROOM_MESSAGES, TYPING,
}; };
pub use sync::{ pub use sync::{
DEFAULT_SYNC_SUMMARY, INVITE_SYNC, LEAVE_SYNC, LEAVE_SYNC_EVENT, MORE_SYNC, SYNC, VOIP_SYNC, DEFAULT_SYNC_SUMMARY, INVITE_SYNC, LEAVE_SYNC, LEAVE_SYNC_EVENT, MORE_SYNC, SYNC, VOIP_SYNC,