use std::fmt::Display;
use num_traits;
use reqwest;
use crate::apis::ResponseContent;
use super::{Error, configuration};
trait NumVecJoin {
fn join(&self, sep: &str) -> String;
}
impl <T: Display + num_traits::Num> NumVecJoin for Vec<T> {
fn join(&self, sep: &str) -> String {
self.iter()
.map(ToString::to_string)
.collect::<Vec<String>>()
.join(sep)
}
}
#[derive(Debug, Clone, Serialize, Deserialize)]
#[serde(untagged)]
pub enum CheckPermissionError {
Status400(crate::models::ErrorGeneric),
DefaultResponse(crate::models::ErrorGeneric),
UnknownValue(serde_json::Value),
}
#[derive(Debug, Clone, Serialize, Deserialize)]
#[serde(untagged)]
pub enum CheckPermissionOrErrorError {
Status400(crate::models::ErrorGeneric),
Status403(crate::models::CheckPermissionResult),
DefaultResponse(crate::models::ErrorGeneric),
UnknownValue(serde_json::Value),
}
#[derive(Debug, Clone, Serialize, Deserialize)]
#[serde(untagged)]
pub enum ExpandPermissionsError {
Status400(crate::models::ErrorGeneric),
Status404(crate::models::ErrorGeneric),
DefaultResponse(crate::models::ErrorGeneric),
UnknownValue(serde_json::Value),
}
#[derive(Debug, Clone, Serialize, Deserialize)]
#[serde(untagged)]
pub enum PostCheckPermissionError {
Status400(crate::models::ErrorGeneric),
DefaultResponse(crate::models::ErrorGeneric),
UnknownValue(serde_json::Value),
}
#[derive(Debug, Clone, Serialize, Deserialize)]
#[serde(untagged)]
pub enum PostCheckPermissionOrErrorError {
Status400(crate::models::ErrorGeneric),
Status403(crate::models::CheckPermissionResult),
DefaultResponse(crate::models::ErrorGeneric),
UnknownValue(serde_json::Value),
}
pub async fn check_permission(configuration: &configuration::Configuration, namespace: Option<&str>, object: Option<&str>, relation: Option<&str>, subject_id: Option<&str>, subject_set_namespace: Option<&str>, subject_set_object: Option<&str>, subject_set_relation: Option<&str>, max_depth: Option<i64>) -> Result<crate::models::CheckPermissionResult, Error<CheckPermissionError>> {
let local_var_client = &configuration.client;
let local_var_uri_str = format!("{}/relation-tuples/check/openapi", configuration.base_path);
let mut local_var_req_builder = local_var_client.request(reqwest::Method::GET, local_var_uri_str.as_str());
if let Some(ref local_var_str) = namespace {
local_var_req_builder = local_var_req_builder.query(&[("namespace", local_var_str.to_string())]);
}
if let Some(ref local_var_str) = object {
local_var_req_builder = local_var_req_builder.query(&[("object", local_var_str.to_string())]);
}
if let Some(ref local_var_str) = relation {
local_var_req_builder = local_var_req_builder.query(&[("relation", local_var_str.to_string())]);
}
if let Some(ref local_var_str) = subject_id {
local_var_req_builder = local_var_req_builder.query(&[("subject_id", local_var_str.to_string())]);
}
if let Some(ref local_var_str) = subject_set_namespace {
local_var_req_builder = local_var_req_builder.query(&[("subject_set.namespace", local_var_str.to_string())]);
}
if let Some(ref local_var_str) = subject_set_object {
local_var_req_builder = local_var_req_builder.query(&[("subject_set.object", local_var_str.to_string())]);
}
if let Some(ref local_var_str) = subject_set_relation {
local_var_req_builder = local_var_req_builder.query(&[("subject_set.relation", local_var_str.to_string())]);
}
if let Some(ref local_var_str) = max_depth {
local_var_req_builder = local_var_req_builder.query(&[("max-depth", local_var_str.to_string())]);
}
if let Some(ref local_var_user_agent) = configuration.user_agent {
local_var_req_builder = local_var_req_builder.header(reqwest::header::USER_AGENT, local_var_user_agent.clone());
}
if let Some(ref local_var_token) = configuration.bearer_access_token {
local_var_req_builder = local_var_req_builder.bearer_auth(local_var_token.to_owned());
};
let local_var_req = local_var_req_builder.build()?;
let local_var_resp = local_var_client.execute(local_var_req).await?;
let local_var_status = local_var_resp.status();
let local_var_content = local_var_resp.text().await?;
if !local_var_status.is_client_error() && !local_var_status.is_server_error() {
serde_json::from_str(&local_var_content).map_err(Error::from)
} else {
let local_var_entity: Option<CheckPermissionError> = serde_json::from_str(&local_var_content).ok();
let local_var_error = ResponseContent { status: local_var_status, content: local_var_content, entity: local_var_entity };
Err(Error::ResponseError(local_var_error))
}
}
pub async fn check_permission_or_error(configuration: &configuration::Configuration, namespace: Option<&str>, object: Option<&str>, relation: Option<&str>, subject_id: Option<&str>, subject_set_namespace: Option<&str>, subject_set_object: Option<&str>, subject_set_relation: Option<&str>, max_depth: Option<i64>) -> Result<crate::models::CheckPermissionResult, Error<CheckPermissionOrErrorError>> {
let local_var_client = &configuration.client;
let local_var_uri_str = format!("{}/relation-tuples/check", configuration.base_path);
let mut local_var_req_builder = local_var_client.request(reqwest::Method::GET, local_var_uri_str.as_str());
if let Some(ref local_var_str) = namespace {
local_var_req_builder = local_var_req_builder.query(&[("namespace", local_var_str.to_string())]);
}
if let Some(ref local_var_str) = object {
local_var_req_builder = local_var_req_builder.query(&[("object", local_var_str.to_string())]);
}
if let Some(ref local_var_str) = relation {
local_var_req_builder = local_var_req_builder.query(&[("relation", local_var_str.to_string())]);
}
if let Some(ref local_var_str) = subject_id {
local_var_req_builder = local_var_req_builder.query(&[("subject_id", local_var_str.to_string())]);
}
if let Some(ref local_var_str) = subject_set_namespace {
local_var_req_builder = local_var_req_builder.query(&[("subject_set.namespace", local_var_str.to_string())]);
}
if let Some(ref local_var_str) = subject_set_object {
local_var_req_builder = local_var_req_builder.query(&[("subject_set.object", local_var_str.to_string())]);
}
if let Some(ref local_var_str) = subject_set_relation {
local_var_req_builder = local_var_req_builder.query(&[("subject_set.relation", local_var_str.to_string())]);
}
if let Some(ref local_var_str) = max_depth {
local_var_req_builder = local_var_req_builder.query(&[("max-depth", local_var_str.to_string())]);
}
if let Some(ref local_var_user_agent) = configuration.user_agent {
local_var_req_builder = local_var_req_builder.header(reqwest::header::USER_AGENT, local_var_user_agent.clone());
}
if let Some(ref local_var_token) = configuration.bearer_access_token {
local_var_req_builder = local_var_req_builder.bearer_auth(local_var_token.to_owned());
};
let local_var_req = local_var_req_builder.build()?;
let local_var_resp = local_var_client.execute(local_var_req).await?;
let local_var_status = local_var_resp.status();
let local_var_content = local_var_resp.text().await?;
if !local_var_status.is_client_error() && !local_var_status.is_server_error() {
serde_json::from_str(&local_var_content).map_err(Error::from)
} else {
let local_var_entity: Option<CheckPermissionOrErrorError> = serde_json::from_str(&local_var_content).ok();
let local_var_error = ResponseContent { status: local_var_status, content: local_var_content, entity: local_var_entity };
Err(Error::ResponseError(local_var_error))
}
}
pub async fn expand_permissions(configuration: &configuration::Configuration, namespace: &str, object: &str, relation: &str, max_depth: Option<i64>) -> Result<crate::models::ExpandedPermissionTree, Error<ExpandPermissionsError>> {
let local_var_client = &configuration.client;
let local_var_uri_str = format!("{}/relation-tuples/expand", configuration.base_path);
let mut local_var_req_builder = local_var_client.request(reqwest::Method::GET, local_var_uri_str.as_str());
local_var_req_builder = local_var_req_builder.query(&[("namespace", namespace.to_string())]);
local_var_req_builder = local_var_req_builder.query(&[("object", object.to_string())]);
local_var_req_builder = local_var_req_builder.query(&[("relation", relation.to_string())]);
if let Some(ref local_var_str) = max_depth {
local_var_req_builder = local_var_req_builder.query(&[("max-depth", local_var_str.to_string())]);
}
if let Some(ref local_var_user_agent) = configuration.user_agent {
local_var_req_builder = local_var_req_builder.header(reqwest::header::USER_AGENT, local_var_user_agent.clone());
}
if let Some(ref local_var_token) = configuration.bearer_access_token {
local_var_req_builder = local_var_req_builder.bearer_auth(local_var_token.to_owned());
};
let local_var_req = local_var_req_builder.build()?;
let local_var_resp = local_var_client.execute(local_var_req).await?;
let local_var_status = local_var_resp.status();
let local_var_content = local_var_resp.text().await?;
if !local_var_status.is_client_error() && !local_var_status.is_server_error() {
serde_json::from_str(&local_var_content).map_err(Error::from)
} else {
let local_var_entity: Option<ExpandPermissionsError> = serde_json::from_str(&local_var_content).ok();
let local_var_error = ResponseContent { status: local_var_status, content: local_var_content, entity: local_var_entity };
Err(Error::ResponseError(local_var_error))
}
}
pub async fn post_check_permission(configuration: &configuration::Configuration, max_depth: Option<i64>, post_check_permission_body: Option<&crate::models::PostCheckPermissionBody>) -> Result<crate::models::CheckPermissionResult, Error<PostCheckPermissionError>> {
let local_var_client = &configuration.client;
let local_var_uri_str = format!("{}/relation-tuples/check/openapi", configuration.base_path);
let mut local_var_req_builder = local_var_client.request(reqwest::Method::POST, local_var_uri_str.as_str());
if let Some(ref local_var_str) = max_depth {
local_var_req_builder = local_var_req_builder.query(&[("max-depth", local_var_str.to_string())]);
}
if let Some(ref local_var_user_agent) = configuration.user_agent {
local_var_req_builder = local_var_req_builder.header(reqwest::header::USER_AGENT, local_var_user_agent.clone());
}
if let Some(ref local_var_token) = configuration.bearer_access_token {
local_var_req_builder = local_var_req_builder.bearer_auth(local_var_token.to_owned());
};
local_var_req_builder = local_var_req_builder.json(&post_check_permission_body);
let local_var_req = local_var_req_builder.build()?;
let local_var_resp = local_var_client.execute(local_var_req).await?;
let local_var_status = local_var_resp.status();
let local_var_content = local_var_resp.text().await?;
if !local_var_status.is_client_error() && !local_var_status.is_server_error() {
serde_json::from_str(&local_var_content).map_err(Error::from)
} else {
let local_var_entity: Option<PostCheckPermissionError> = serde_json::from_str(&local_var_content).ok();
let local_var_error = ResponseContent { status: local_var_status, content: local_var_content, entity: local_var_entity };
Err(Error::ResponseError(local_var_error))
}
}
pub async fn post_check_permission_or_error(configuration: &configuration::Configuration, max_depth: Option<i64>, post_check_permission_or_error_body: Option<&crate::models::PostCheckPermissionOrErrorBody>) -> Result<crate::models::CheckPermissionResult, Error<PostCheckPermissionOrErrorError>> {
let local_var_client = &configuration.client;
let local_var_uri_str = format!("{}/relation-tuples/check", configuration.base_path);
let mut local_var_req_builder = local_var_client.request(reqwest::Method::POST, local_var_uri_str.as_str());
if let Some(ref local_var_str) = max_depth {
local_var_req_builder = local_var_req_builder.query(&[("max-depth", local_var_str.to_string())]);
}
if let Some(ref local_var_user_agent) = configuration.user_agent {
local_var_req_builder = local_var_req_builder.header(reqwest::header::USER_AGENT, local_var_user_agent.clone());
}
if let Some(ref local_var_token) = configuration.bearer_access_token {
local_var_req_builder = local_var_req_builder.bearer_auth(local_var_token.to_owned());
};
local_var_req_builder = local_var_req_builder.json(&post_check_permission_or_error_body);
let local_var_req = local_var_req_builder.build()?;
let local_var_resp = local_var_client.execute(local_var_req).await?;
let local_var_status = local_var_resp.status();
let local_var_content = local_var_resp.text().await?;
if !local_var_status.is_client_error() && !local_var_status.is_server_error() {
serde_json::from_str(&local_var_content).map_err(Error::from)
} else {
let local_var_entity: Option<PostCheckPermissionOrErrorError> = serde_json::from_str(&local_var_content).ok();
let local_var_error = ResponseContent { status: local_var_status, content: local_var_content, entity: local_var_entity };
Err(Error::ResponseError(local_var_error))
}
}