/*
* Tapis Meta V3 API
*
* The Tapis Meta API provides access to a MongoDB database. A standalone service which connects to a MongoDB database and immediately exposes all of MongoDB’s capabilities through a complete REST API, which allows the user to read and write JSON messages and binary data via HTTP.
*
* The version of the OpenAPI document: 0.1
* Contact: cicsupport@tacc.utexas.edu
* Generated by: https://openapi-generator.tech
*/
use super::{configuration, ContentType, Error};
use crate::{apis::ResponseContent, models};
use reqwest;
use serde::{de::Error as _, Deserialize, Serialize};
/// struct for typed errors of method [`create_collection`]
#[derive(Debug, Clone, Serialize, Deserialize)]
#[serde(untagged)]
pub enum CreateCollectionError {
Status401(serde_json::Value),
Status500(serde_json::Value),
UnknownValue(serde_json::Value),
}
/// struct for typed errors of method [`delete_collection`]
#[derive(Debug, Clone, Serialize, Deserialize)]
#[serde(untagged)]
pub enum DeleteCollectionError {
Status401(serde_json::Value),
Status500(serde_json::Value),
UnknownValue(serde_json::Value),
}
/// struct for typed errors of method [`get_collection_metadata`]
#[derive(Debug, Clone, Serialize, Deserialize)]
#[serde(untagged)]
pub enum GetCollectionMetadataError {
Status401(serde_json::Value),
Status500(serde_json::Value),
UnknownValue(serde_json::Value),
}
/// struct for typed errors of method [`get_collection_size`]
#[derive(Debug, Clone, Serialize, Deserialize)]
#[serde(untagged)]
pub enum GetCollectionSizeError {
Status401(serde_json::Value),
Status500(serde_json::Value),
UnknownValue(serde_json::Value),
}
/// struct for typed errors of method [`list_documents`]
#[derive(Debug, Clone, Serialize, Deserialize)]
#[serde(untagged)]
pub enum ListDocumentsError {
Status401(serde_json::Value),
Status500(serde_json::Value),
UnknownValue(serde_json::Value),
}
/// struct for typed errors of method [`submit_large_query`]
#[derive(Debug, Clone, Serialize, Deserialize)]
#[serde(untagged)]
pub enum SubmitLargeQueryError {
Status401(serde_json::Value),
Status500(serde_json::Value),
UnknownValue(serde_json::Value),
}
/// Create a new collection in the database.
pub async fn create_collection(
configuration: &configuration::Configuration,
db: &str,
collection: &str,
) -> Result<(), Error<CreateCollectionError>> {
// add a prefix to parameters to efficiently prevent name collisions
let p_path_db = db;
let p_path_collection = collection;
let uri_str = format!(
"{}/meta/{db}/{collection}",
configuration.base_path,
db = crate::apis::urlencode(p_path_db),
collection = crate::apis::urlencode(p_path_collection)
);
let mut req_builder = configuration.client.request(reqwest::Method::PUT, &uri_str);
if let Some(ref user_agent) = configuration.user_agent {
req_builder = req_builder.header(reqwest::header::USER_AGENT, user_agent.clone());
}
if let Some(ref apikey) = configuration.api_key {
let key = apikey.key.clone();
let value = match apikey.prefix {
Some(ref prefix) => format!("{} {}", prefix, key),
None => key,
};
req_builder = req_builder.header("X-Tapis-Token", value);
};
let req = req_builder.build()?;
let resp = configuration.client.execute(req).await?;
let status = resp.status();
if !status.is_client_error() && !status.is_server_error() {
Ok(())
} else {
let content = resp.text().await?;
let entity: Option<CreateCollectionError> = serde_json::from_str(&content).ok();
Err(Error::ResponseError(ResponseContent {
status,
content,
entity,
}))
}
}
/// Delete a collection in the database. This operation is limit by default to tenant administrators. An (If-Match) header parameter with the value of the collections etag must be supplied in order for this operations to succeed.
pub async fn delete_collection(
configuration: &configuration::Configuration,
if_match: &str,
db: &str,
collection: &str,
) -> Result<(), Error<DeleteCollectionError>> {
// add a prefix to parameters to efficiently prevent name collisions
let p_header_if_match = if_match;
let p_path_db = db;
let p_path_collection = collection;
let uri_str = format!(
"{}/meta/{db}/{collection}",
configuration.base_path,
db = crate::apis::urlencode(p_path_db),
collection = crate::apis::urlencode(p_path_collection)
);
let mut req_builder = configuration
.client
.request(reqwest::Method::DELETE, &uri_str);
if let Some(ref user_agent) = configuration.user_agent {
req_builder = req_builder.header(reqwest::header::USER_AGENT, user_agent.clone());
}
req_builder = req_builder.header("If-Match", p_header_if_match.to_string());
if let Some(ref apikey) = configuration.api_key {
let key = apikey.key.clone();
let value = match apikey.prefix {
Some(ref prefix) => format!("{} {}", prefix, key),
None => key,
};
req_builder = req_builder.header("X-Tapis-Token", value);
};
let req = req_builder.build()?;
let resp = configuration.client.execute(req).await?;
let status = resp.status();
if !status.is_client_error() && !status.is_server_error() {
Ok(())
} else {
let content = resp.text().await?;
let entity: Option<DeleteCollectionError> = serde_json::from_str(&content).ok();
Err(Error::ResponseError(ResponseContent {
status,
content,
entity,
}))
}
}
/// Get the Metadata for the collection.
pub async fn get_collection_metadata(
configuration: &configuration::Configuration,
db: &str,
collection: &str,
) -> Result<serde_json::Value, Error<GetCollectionMetadataError>> {
// add a prefix to parameters to efficiently prevent name collisions
let p_path_db = db;
let p_path_collection = collection;
let uri_str = format!(
"{}/meta/{db}/{collection}/_meta",
configuration.base_path,
db = crate::apis::urlencode(p_path_db),
collection = crate::apis::urlencode(p_path_collection)
);
let mut req_builder = configuration.client.request(reqwest::Method::GET, &uri_str);
if let Some(ref user_agent) = configuration.user_agent {
req_builder = req_builder.header(reqwest::header::USER_AGENT, user_agent.clone());
}
if let Some(ref apikey) = configuration.api_key {
let key = apikey.key.clone();
let value = match apikey.prefix {
Some(ref prefix) => format!("{} {}", prefix, key),
None => key,
};
req_builder = req_builder.header("X-Tapis-Token", value);
};
let req = req_builder.build()?;
let resp = configuration.client.execute(req).await?;
let status = resp.status();
let content_type = resp
.headers()
.get("content-type")
.and_then(|v| v.to_str().ok())
.unwrap_or("application/octet-stream");
let content_type = super::ContentType::from(content_type);
if !status.is_client_error() && !status.is_server_error() {
let content = resp.text().await?;
match content_type {
ContentType::Json => serde_json::from_str(&content).map_err(Error::from),
ContentType::Text => Err(Error::from(serde_json::Error::custom("Received `text/plain` content type response that cannot be converted to `serde_json::Value`"))),
ContentType::Unsupported(unknown_type) => Err(Error::from(serde_json::Error::custom(format!("Received `{unknown_type}` content type response that cannot be converted to `serde_json::Value`")))),
}
} else {
let content = resp.text().await?;
let entity: Option<GetCollectionMetadataError> = serde_json::from_str(&content).ok();
Err(Error::ResponseError(ResponseContent {
status,
content,
entity,
}))
}
}
/// Get the size of the collection. The response will contain the number of documents found in the collection.
pub async fn get_collection_size(
configuration: &configuration::Configuration,
db: &str,
collection: &str,
) -> Result<String, Error<GetCollectionSizeError>> {
// add a prefix to parameters to efficiently prevent name collisions
let p_path_db = db;
let p_path_collection = collection;
let uri_str = format!(
"{}/meta/{db}/{collection}/_size",
configuration.base_path,
db = crate::apis::urlencode(p_path_db),
collection = crate::apis::urlencode(p_path_collection)
);
let mut req_builder = configuration.client.request(reqwest::Method::GET, &uri_str);
if let Some(ref user_agent) = configuration.user_agent {
req_builder = req_builder.header(reqwest::header::USER_AGENT, user_agent.clone());
}
if let Some(ref apikey) = configuration.api_key {
let key = apikey.key.clone();
let value = match apikey.prefix {
Some(ref prefix) => format!("{} {}", prefix, key),
None => key,
};
req_builder = req_builder.header("X-Tapis-Token", value);
};
let req = req_builder.build()?;
let resp = configuration.client.execute(req).await?;
let status = resp.status();
let content_type = resp
.headers()
.get("content-type")
.and_then(|v| v.to_str().ok())
.unwrap_or("application/octet-stream");
let content_type = super::ContentType::from(content_type);
if !status.is_client_error() && !status.is_server_error() {
let content = resp.text().await?;
match content_type {
ContentType::Json => serde_json::from_str(&content).map_err(Error::from),
ContentType::Text => Err(Error::from(serde_json::Error::custom("Received `text/plain` content type response that cannot be converted to `String`"))),
ContentType::Unsupported(unknown_type) => Err(Error::from(serde_json::Error::custom(format!("Received `{unknown_type}` content type response that cannot be converted to `String`")))),
}
} else {
let content = resp.text().await?;
let entity: Option<GetCollectionSizeError> = serde_json::from_str(&content).ok();
Err(Error::ResponseError(ResponseContent {
status,
content,
entity,
}))
}
}
/// List of documents in the collection. If no query parameters are submitted a default number of documents <pagesize> is returned in default sort order (sort) as the first page <page> of a document result set. The default sort order is based on the \"_id\" of the document. A (filter) query parameter value is represented by a valid MongoDb query document. This will allow retrieving documents that meet a desired criteria. When coupled with the (keys) query parameter a projection will limit the fields to return for all matching documents.
pub async fn list_documents(
configuration: &configuration::Configuration,
db: &str,
collection: &str,
page: Option<i32>,
pagesize: Option<i32>,
filter: Option<serde_json::Value>,
sort: Option<serde_json::Value>,
keys: Option<Vec<String>>,
) -> Result<Vec<serde_json::Value>, Error<ListDocumentsError>> {
// add a prefix to parameters to efficiently prevent name collisions
let p_path_db = db;
let p_path_collection = collection;
let p_query_page = page;
let p_query_pagesize = pagesize;
let p_query_filter = filter;
let p_query_sort = sort;
let p_query_keys = keys;
let uri_str = format!(
"{}/meta/{db}/{collection}",
configuration.base_path,
db = crate::apis::urlencode(p_path_db),
collection = crate::apis::urlencode(p_path_collection)
);
let mut req_builder = configuration.client.request(reqwest::Method::GET, &uri_str);
if let Some(ref param_value) = p_query_page {
req_builder = req_builder.query(&[("page", ¶m_value.to_string())]);
}
if let Some(ref param_value) = p_query_pagesize {
req_builder = req_builder.query(&[("pagesize", ¶m_value.to_string())]);
}
if let Some(ref param_value) = p_query_filter {
req_builder = req_builder.query(&[("filter", &serde_json::to_string(param_value)?)]);
}
if let Some(ref param_value) = p_query_sort {
req_builder = req_builder.query(&[("sort", &serde_json::to_string(param_value)?)]);
}
if let Some(ref param_value) = p_query_keys {
req_builder = match "multi" {
"multi" => req_builder.query(
¶m_value
.iter()
.map(|p| ("keys".to_owned(), p.to_string()))
.collect::<Vec<(std::string::String, std::string::String)>>(),
),
_ => req_builder.query(&[(
"keys",
¶m_value
.iter()
.map(|p| p.to_string())
.collect::<Vec<String>>()
.join(",")
.to_string(),
)]),
};
}
if let Some(ref user_agent) = configuration.user_agent {
req_builder = req_builder.header(reqwest::header::USER_AGENT, user_agent.clone());
}
if let Some(ref apikey) = configuration.api_key {
let key = apikey.key.clone();
let value = match apikey.prefix {
Some(ref prefix) => format!("{} {}", prefix, key),
None => key,
};
req_builder = req_builder.header("X-Tapis-Token", value);
};
let req = req_builder.build()?;
let resp = configuration.client.execute(req).await?;
let status = resp.status();
let content_type = resp
.headers()
.get("content-type")
.and_then(|v| v.to_str().ok())
.unwrap_or("application/octet-stream");
let content_type = super::ContentType::from(content_type);
if !status.is_client_error() && !status.is_server_error() {
let content = resp.text().await?;
match content_type {
ContentType::Json => serde_json::from_str(&content).map_err(Error::from),
ContentType::Text => Err(Error::from(serde_json::Error::custom("Received `text/plain` content type response that cannot be converted to `Vec<serde_json::Value>`"))),
ContentType::Unsupported(unknown_type) => Err(Error::from(serde_json::Error::custom(format!("Received `{unknown_type}` content type response that cannot be converted to `Vec<serde_json::Value>`")))),
}
} else {
let content = resp.text().await?;
let entity: Option<ListDocumentsError> = serde_json::from_str(&content).ok();
Err(Error::ResponseError(ResponseContent {
status,
content,
entity,
}))
}
}
/// This is a POST version of filter on a collection with a filter value to large to submit in a query parameter. If the filter parameter is to large, it may exceed the HTTP header character limit. The HTTP server will throw a query header to large error.
pub async fn submit_large_query(
configuration: &configuration::Configuration,
db: &str,
collection: &str,
page: Option<i32>,
pagesize: Option<i32>,
sort: Option<serde_json::Value>,
keys: Option<Vec<String>>,
body: Option<serde_json::Value>,
) -> Result<Vec<serde_json::Value>, Error<SubmitLargeQueryError>> {
// add a prefix to parameters to efficiently prevent name collisions
let p_path_db = db;
let p_path_collection = collection;
let p_query_page = page;
let p_query_pagesize = pagesize;
let p_query_sort = sort;
let p_query_keys = keys;
let p_body_body = body;
let uri_str = format!(
"{}/meta/{db}/{collection}/_filter",
configuration.base_path,
db = crate::apis::urlencode(p_path_db),
collection = crate::apis::urlencode(p_path_collection)
);
let mut req_builder = configuration
.client
.request(reqwest::Method::POST, &uri_str);
if let Some(ref param_value) = p_query_page {
req_builder = req_builder.query(&[("page", ¶m_value.to_string())]);
}
if let Some(ref param_value) = p_query_pagesize {
req_builder = req_builder.query(&[("pagesize", ¶m_value.to_string())]);
}
if let Some(ref param_value) = p_query_sort {
req_builder = req_builder.query(&[("sort", &serde_json::to_string(param_value)?)]);
}
if let Some(ref param_value) = p_query_keys {
req_builder = match "multi" {
"multi" => req_builder.query(
¶m_value
.iter()
.map(|p| ("keys".to_owned(), p.to_string()))
.collect::<Vec<(std::string::String, std::string::String)>>(),
),
_ => req_builder.query(&[(
"keys",
¶m_value
.iter()
.map(|p| p.to_string())
.collect::<Vec<String>>()
.join(",")
.to_string(),
)]),
};
}
if let Some(ref user_agent) = configuration.user_agent {
req_builder = req_builder.header(reqwest::header::USER_AGENT, user_agent.clone());
}
if let Some(ref apikey) = configuration.api_key {
let key = apikey.key.clone();
let value = match apikey.prefix {
Some(ref prefix) => format!("{} {}", prefix, key),
None => key,
};
req_builder = req_builder.header("X-Tapis-Token", value);
};
req_builder = req_builder.json(&p_body_body);
let req = req_builder.build()?;
let resp = configuration.client.execute(req).await?;
let status = resp.status();
let content_type = resp
.headers()
.get("content-type")
.and_then(|v| v.to_str().ok())
.unwrap_or("application/octet-stream");
let content_type = super::ContentType::from(content_type);
if !status.is_client_error() && !status.is_server_error() {
let content = resp.text().await?;
match content_type {
ContentType::Json => serde_json::from_str(&content).map_err(Error::from),
ContentType::Text => Err(Error::from(serde_json::Error::custom("Received `text/plain` content type response that cannot be converted to `Vec<serde_json::Value>`"))),
ContentType::Unsupported(unknown_type) => Err(Error::from(serde_json::Error::custom(format!("Received `{unknown_type}` content type response that cannot be converted to `Vec<serde_json::Value>`")))),
}
} else {
let content = resp.text().await?;
let entity: Option<SubmitLargeQueryError> = serde_json::from_str(&content).ok();
Err(Error::ResponseError(ResponseContent {
status,
content,
entity,
}))
}
}