Initial commit
This commit is contained in:
48
src/lldap.rs
Normal file
48
src/lldap.rs
Normal file
@@ -0,0 +1,48 @@
|
||||
use anyhow::{anyhow, Context};
|
||||
use lldap_auth::{opaque, registration};
|
||||
use surf::Client;
|
||||
|
||||
pub async fn change_password(client: &Client, user_id: &str, password: &str) -> anyhow::Result<()> {
|
||||
let mut rng = rand::rngs::OsRng;
|
||||
let registration_start_request =
|
||||
opaque::client::registration::start_registration(password, &mut rng)
|
||||
.context("Could not initiate password change")?;
|
||||
|
||||
let start_request = registration::ClientRegistrationStartRequest {
|
||||
username: user_id.into(),
|
||||
registration_start_request: registration_start_request.message,
|
||||
};
|
||||
|
||||
let mut response = client
|
||||
.post("/auth/opaque/register/start")
|
||||
.body_json(&start_request)
|
||||
.map_err(|e| anyhow!(e))?
|
||||
.await
|
||||
.map_err(|e| anyhow!(e))?;
|
||||
|
||||
let response: registration::ServerRegistrationStartResponse =
|
||||
response.body_json().await.map_err(|e| anyhow!(e))?;
|
||||
|
||||
let registration_finish = opaque::client::registration::finish_registration(
|
||||
registration_start_request.state,
|
||||
response.registration_response,
|
||||
&mut rng,
|
||||
)
|
||||
.context("Error during password change")?;
|
||||
|
||||
let request = registration::ClientRegistrationFinishRequest {
|
||||
server_data: response.server_data,
|
||||
registration_upload: registration_finish.message,
|
||||
};
|
||||
|
||||
let _response = client
|
||||
.post("/auth/opaque/register/finish")
|
||||
.body_json(&request)
|
||||
.map_err(|e| anyhow!(e))?
|
||||
.await
|
||||
.map_err(|e| anyhow!(e))?;
|
||||
|
||||
println!("Changed '{user_id}' password successfully");
|
||||
|
||||
Ok(())
|
||||
}
|
||||
Reference in New Issue
Block a user