| use crate::binary::mapper; |
| use crate::binary::sender::Sender; |
| use crate::state::command::EntryCommand; |
| use crate::streaming::session::Session; |
| use crate::streaming::systems::system::SharedSystem; |
| use crate::streaming::utils::crypto; |
| use anyhow::Result; |
| use iggy::error::IggyError; |
| use iggy::users::create_user::CreateUser; |
| use tracing::debug; |
| |
| pub async fn handle( |
| command: CreateUser, |
| sender: &mut dyn Sender, |
| session: &Session, |
| system: &SharedSystem, |
| ) -> Result<(), IggyError> { |
| debug!("session: {session}, command: {command}"); |
| let response; |
| { |
| let mut system = system.write().await; |
| let user = system |
| .create_user( |
| session, |
| &command.username, |
| &command.password, |
| command.status, |
| command.permissions.clone(), |
| ) |
| .await?; |
| response = mapper::map_user(user); |
| } |
| |
| // For the security of the system, we hash the password before storing it in metadata. |
| let system = system.read().await; |
| system |
| .state |
| .apply( |
| session.get_user_id(), |
| EntryCommand::CreateUser(CreateUser { |
| username: command.username.to_owned(), |
| password: crypto::hash_password(&command.password), |
| status: command.status, |
| permissions: command.permissions.clone(), |
| }), |
| ) |
| .await?; |
| sender.send_ok_response(&response).await?; |
| Ok(()) |
| } |