use std::rc::Rc;
use std::borrow::Borrow;
use hyper;
use serde_json;
use futures;
use futures::{Future, Stream};
use super::{Error, configuration};
pub struct TokenBackendApiClient<C: hyper::client::Connect> {
configuration: Rc<configuration::Configuration<C>>,
}
impl<C: hyper::client::Connect> TokenBackendApiClient<C> {
pub fn new(configuration: Rc<configuration::Configuration<C>>) -> TokenBackendApiClient<C> {
TokenBackendApiClient {
configuration: configuration,
}
}
}
pub trait TokenBackendApi {
fn create_orphan_token(&self, x_vault_token: &str, body: ::models::CreateTokenParameters) -> Box<Future<Item = ::models::AuthResponse, Error = Error>>;
fn create_token(&self, x_vault_token: &str, body: ::models::CreateTokenParameters) -> Box<Future<Item = ::models::AuthResponse, Error = Error>>;
fn log_in_with_tls_certificate(&self, body: ::models::AuthCertLoginParameters) -> Box<Future<Item = ::models::AuthResponse, Error = Error>>;
fn renew_own_token(&self, x_vault_token: &str, body: ::models::RenewSelfParameters) -> Box<Future<Item = ::models::AuthResponse, Error = Error>>;
}
impl<C: hyper::client::Connect>TokenBackendApi for TokenBackendApiClient<C> {
fn create_orphan_token(&self, x_vault_token: &str, body: ::models::CreateTokenParameters) -> Box<Future<Item = ::models::AuthResponse, Error = Error>> {
let configuration: &configuration::Configuration<C> = self.configuration.borrow();
let method = hyper::Method::Post;
let uri_str = format!("{}/auth/token/create-orphan", configuration.base_path);
let uri = uri_str.parse();
let mut req = hyper::Request::new(method, uri.unwrap());
{
let mut headers = req.headers_mut();
headers.set_raw("X-Vault-Token", x_vault_token);
}
let serialized = serde_json::to_string(&body).unwrap();
req.headers_mut().set(hyper::header::ContentType::json());
req.headers_mut().set(hyper::header::ContentLength(serialized.len() as u64));
req.set_body(serialized);
Box::new(
configuration.client.request(req).and_then(|res| { res.body().concat2() })
.map_err(|e| Error::from(e))
.and_then(|body| {
let parsed: Result<::models::AuthResponse, _> = serde_json::from_slice(&body);
parsed.map_err(|e| Error::from(e))
}).map_err(|e| Error::from(e))
)
}
fn create_token(&self, x_vault_token: &str, body: ::models::CreateTokenParameters) -> Box<Future<Item = ::models::AuthResponse, Error = Error>> {
let configuration: &configuration::Configuration<C> = self.configuration.borrow();
let method = hyper::Method::Post;
let uri_str = format!("{}/auth/token/create", configuration.base_path);
let uri = uri_str.parse();
let mut req = hyper::Request::new(method, uri.unwrap());
{
let mut headers = req.headers_mut();
headers.set_raw("X-Vault-Token", x_vault_token);
}
let serialized = serde_json::to_string(&body).unwrap();
req.headers_mut().set(hyper::header::ContentType::json());
req.headers_mut().set(hyper::header::ContentLength(serialized.len() as u64));
req.set_body(serialized);
Box::new(
configuration.client.request(req).and_then(|res| { res.body().concat2() })
.map_err(|e| Error::from(e))
.and_then(|body| {
let parsed: Result<::models::AuthResponse, _> = serde_json::from_slice(&body);
parsed.map_err(|e| Error::from(e))
}).map_err(|e| Error::from(e))
)
}
fn log_in_with_tls_certificate(&self, body: ::models::AuthCertLoginParameters) -> Box<Future<Item = ::models::AuthResponse, Error = Error>> {
let configuration: &configuration::Configuration<C> = self.configuration.borrow();
let method = hyper::Method::Post;
let uri_str = format!("{}/auth/cert/login", configuration.base_path);
let uri = uri_str.parse();
let mut req = hyper::Request::new(method, uri.unwrap());
let serialized = serde_json::to_string(&body).unwrap();
req.headers_mut().set(hyper::header::ContentType::json());
req.headers_mut().set(hyper::header::ContentLength(serialized.len() as u64));
req.set_body(serialized);
Box::new(
configuration.client.request(req).and_then(|res| { res.body().concat2() })
.map_err(|e| Error::from(e))
.and_then(|body| {
let parsed: Result<::models::AuthResponse, _> = serde_json::from_slice(&body);
parsed.map_err(|e| Error::from(e))
}).map_err(|e| Error::from(e))
)
}
fn renew_own_token(&self, x_vault_token: &str, body: ::models::RenewSelfParameters) -> Box<Future<Item = ::models::AuthResponse, Error = Error>> {
let configuration: &configuration::Configuration<C> = self.configuration.borrow();
let method = hyper::Method::Post;
let uri_str = format!("{}/auth/token/renew-self", configuration.base_path);
let uri = uri_str.parse();
let mut req = hyper::Request::new(method, uri.unwrap());
{
let mut headers = req.headers_mut();
headers.set_raw("X-Vault-Token", x_vault_token);
}
let serialized = serde_json::to_string(&body).unwrap();
req.headers_mut().set(hyper::header::ContentType::json());
req.headers_mut().set(hyper::header::ContentLength(serialized.len() as u64));
req.set_body(serialized);
Box::new(
configuration.client.request(req).and_then(|res| { res.body().concat2() })
.map_err(|e| Error::from(e))
.and_then(|body| {
let parsed: Result<::models::AuthResponse, _> = serde_json::from_slice(&body);
parsed.map_err(|e| Error::from(e))
}).map_err(|e| Error::from(e))
)
}
}