blob: e16d78a7237ca780b090e8cdc1e8d94982bbcd9c [file] [log] [blame]
use crate::binary::binary_client::BinaryClient;
use crate::binary::{fail_if_not_authenticated, mapper, ClientState};
use crate::client::UserClient;
use crate::diagnostic::DiagnosticEvent;
use crate::error::IggyError;
use crate::identifier::Identifier;
use crate::models::identity_info::IdentityInfo;
use crate::models::permissions::Permissions;
use crate::models::user_info::{UserInfo, UserInfoDetails};
use crate::models::user_status::UserStatus;
use crate::users::change_password::ChangePassword;
use crate::users::create_user::CreateUser;
use crate::users::delete_user::DeleteUser;
use crate::users::get_user::GetUser;
use crate::users::get_users::GetUsers;
use crate::users::login_user::LoginUser;
use crate::users::logout_user::LogoutUser;
use crate::users::update_permissions::UpdatePermissions;
use crate::users::update_user::UpdateUser;
#[async_trait::async_trait]
impl<B: BinaryClient> UserClient for B {
async fn get_user(&self, user_id: &Identifier) -> Result<Option<UserInfoDetails>, IggyError> {
fail_if_not_authenticated(self).await?;
let response = self
.send_with_response(&GetUser {
user_id: user_id.clone(),
})
.await?;
if response.is_empty() {
return Ok(None);
}
mapper::map_user(response).map(Some)
}
async fn get_users(&self) -> Result<Vec<UserInfo>, IggyError> {
fail_if_not_authenticated(self).await?;
let response = self.send_with_response(&GetUsers {}).await?;
mapper::map_users(response)
}
async fn create_user(
&self,
username: &str,
password: &str,
status: UserStatus,
permissions: Option<Permissions>,
) -> Result<UserInfoDetails, IggyError> {
fail_if_not_authenticated(self).await?;
let response = self
.send_with_response(&CreateUser {
username: username.to_string(),
password: password.to_string(),
status,
permissions,
})
.await?;
mapper::map_user(response)
}
async fn delete_user(&self, user_id: &Identifier) -> Result<(), IggyError> {
fail_if_not_authenticated(self).await?;
self.send_with_response(&DeleteUser {
user_id: user_id.clone(),
})
.await?;
Ok(())
}
async fn update_user(
&self,
user_id: &Identifier,
username: Option<&str>,
status: Option<UserStatus>,
) -> Result<(), IggyError> {
fail_if_not_authenticated(self).await?;
self.send_with_response(&UpdateUser {
user_id: user_id.clone(),
username: username.map(|s| s.to_string()),
status,
})
.await?;
Ok(())
}
async fn update_permissions(
&self,
user_id: &Identifier,
permissions: Option<Permissions>,
) -> Result<(), IggyError> {
fail_if_not_authenticated(self).await?;
self.send_with_response(&UpdatePermissions {
user_id: user_id.clone(),
permissions,
})
.await?;
Ok(())
}
async fn change_password(
&self,
user_id: &Identifier,
current_password: &str,
new_password: &str,
) -> Result<(), IggyError> {
fail_if_not_authenticated(self).await?;
self.send_with_response(&ChangePassword {
user_id: user_id.clone(),
current_password: current_password.to_string(),
new_password: new_password.to_string(),
})
.await?;
Ok(())
}
async fn login_user(&self, username: &str, password: &str) -> Result<IdentityInfo, IggyError> {
let response = self
.send_with_response(&LoginUser {
username: username.to_string(),
password: password.to_string(),
version: Some(env!("CARGO_PKG_VERSION").to_string()),
context: Some("".to_string()),
})
.await?;
self.set_state(ClientState::Authenticated).await;
self.publish_event(DiagnosticEvent::SignedIn).await;
mapper::map_identity_info(response)
}
async fn logout_user(&self) -> Result<(), IggyError> {
fail_if_not_authenticated(self).await?;
self.send_with_response(&LogoutUser {}).await?;
self.set_state(ClientState::Connected).await;
self.publish_event(DiagnosticEvent::SignedOut).await;
Ok(())
}
}