pub mod http_client {
pub mod v3 {
use serde_json::Value;
pub async fn get(
shasta_token: &str,
shasta_base_url: &str,
shasta_root_cert: &[u8],
username_opt: Option<&str>,
) -> Result<Vec<Value>, reqwest::Error> {
let client;
let client_builder = reqwest::Client::builder()
.add_root_certificate(reqwest::Certificate::from_pem(shasta_root_cert)?);
if std::env::var("SOCKS5").is_ok() {
log::debug!("SOCKS5 enabled");
let socks5proxy = reqwest::Proxy::all(std::env::var("SOCKS5").unwrap())?;
client = client_builder.proxy(socks5proxy).build()?;
} else {
client = client_builder.build()?;
}
let api_url = shasta_base_url.to_owned() + "/ims/v3/public-keys";
let json_response: Value = client
.get(api_url)
.bearer_auth(shasta_token)
.send()
.await?
.json()
.await?;
let mut public_key_value_list: Vec<Value> = json_response.as_array().unwrap().to_vec();
public_key_value_list = if let Some(username) = username_opt {
public_key_value_list
.retain(|ssh_key_value| ssh_key_value["name"].as_str().unwrap().eq(username));
public_key_value_list
} else {
json_response.as_array().unwrap().to_vec()
};
Ok(public_key_value_list.to_vec())
}
}
}