use reqwest;
use crate::apis::ResponseContent;
use super::{Error, configuration};
#[derive(Clone, Debug, Default)]
pub struct CreateLogSftpParams {
pub service_id: String,
pub version_id: i32,
pub name: Option<String>,
pub placement: Option<String>,
pub response_condition: Option<String>,
pub format: Option<String>,
pub format_version: Option<i32>,
pub message_type: Option<String>,
pub timestamp_format: Option<String>,
pub compression_codec: Option<String>,
pub period: Option<i32>,
pub gzip_level: Option<i32>,
pub address: Option<String>,
pub port: Option<i32>,
pub password: Option<String>,
pub path: Option<String>,
pub public_key: Option<String>,
pub secret_key: Option<String>,
pub ssh_known_hosts: Option<String>,
pub user: Option<String>
}
#[derive(Clone, Debug, Default)]
pub struct DeleteLogSftpParams {
pub service_id: String,
pub version_id: i32,
pub logging_sftp_name: String
}
#[derive(Clone, Debug, Default)]
pub struct GetLogSftpParams {
pub service_id: String,
pub version_id: i32,
pub logging_sftp_name: String
}
#[derive(Clone, Debug, Default)]
pub struct ListLogSftpParams {
pub service_id: String,
pub version_id: i32
}
#[derive(Clone, Debug, Default)]
pub struct UpdateLogSftpParams {
pub service_id: String,
pub version_id: i32,
pub logging_sftp_name: String,
pub name: Option<String>,
pub placement: Option<String>,
pub response_condition: Option<String>,
pub format: Option<String>,
pub format_version: Option<i32>,
pub message_type: Option<String>,
pub timestamp_format: Option<String>,
pub compression_codec: Option<String>,
pub period: Option<i32>,
pub gzip_level: Option<i32>,
pub address: Option<String>,
pub port: Option<i32>,
pub password: Option<String>,
pub path: Option<String>,
pub public_key: Option<String>,
pub secret_key: Option<String>,
pub ssh_known_hosts: Option<String>,
pub user: Option<String>
}
#[derive(Debug, Clone, Serialize, Deserialize)]
#[serde(untagged)]
pub enum CreateLogSftpError {
UnknownValue(serde_json::Value),
}
#[derive(Debug, Clone, Serialize, Deserialize)]
#[serde(untagged)]
pub enum DeleteLogSftpError {
UnknownValue(serde_json::Value),
}
#[derive(Debug, Clone, Serialize, Deserialize)]
#[serde(untagged)]
pub enum GetLogSftpError {
UnknownValue(serde_json::Value),
}
#[derive(Debug, Clone, Serialize, Deserialize)]
#[serde(untagged)]
pub enum ListLogSftpError {
UnknownValue(serde_json::Value),
}
#[derive(Debug, Clone, Serialize, Deserialize)]
#[serde(untagged)]
pub enum UpdateLogSftpError {
UnknownValue(serde_json::Value),
}
pub async fn create_log_sftp(configuration: &mut configuration::Configuration, params: CreateLogSftpParams) -> Result<crate::models::LoggingSftpResponse, Error<CreateLogSftpError>> {
let local_var_configuration = configuration;
let service_id = params.service_id;
let version_id = params.version_id;
let name = params.name;
let placement = params.placement;
let response_condition = params.response_condition;
let format = params.format;
let format_version = params.format_version;
let message_type = params.message_type;
let timestamp_format = params.timestamp_format;
let compression_codec = params.compression_codec;
let period = params.period;
let gzip_level = params.gzip_level;
let address = params.address;
let port = params.port;
let password = params.password;
let path = params.path;
let public_key = params.public_key;
let secret_key = params.secret_key;
let ssh_known_hosts = params.ssh_known_hosts;
let user = params.user;
let local_var_client = &local_var_configuration.client;
let local_var_uri_str = format!("{}/service/{service_id}/version/{version_id}/logging/sftp", local_var_configuration.base_path, service_id=crate::apis::urlencode(service_id), version_id=version_id);
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_user_agent) = local_var_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_apikey) = local_var_configuration.api_key {
let local_var_key = local_var_apikey.key.clone();
let local_var_value = match local_var_apikey.prefix {
Some(ref local_var_prefix) => format!("{} {}", local_var_prefix, local_var_key),
None => local_var_key,
};
local_var_req_builder = local_var_req_builder.header("Fastly-Key", local_var_value);
};
let mut local_var_form_params = std::collections::HashMap::new();
if let Some(local_var_param_value) = name {
local_var_form_params.insert("name", local_var_param_value.to_string());
}
if let Some(local_var_param_value) = placement {
local_var_form_params.insert("placement", local_var_param_value.to_string());
}
if let Some(local_var_param_value) = response_condition {
local_var_form_params.insert("response_condition", local_var_param_value.to_string());
}
if let Some(local_var_param_value) = format {
local_var_form_params.insert("format", local_var_param_value.to_string());
}
if let Some(local_var_param_value) = format_version {
local_var_form_params.insert("format_version", local_var_param_value.to_string());
}
if let Some(local_var_param_value) = message_type {
local_var_form_params.insert("message_type", local_var_param_value.to_string());
}
if let Some(local_var_param_value) = timestamp_format {
local_var_form_params.insert("timestamp_format", local_var_param_value.to_string());
}
if let Some(local_var_param_value) = compression_codec {
local_var_form_params.insert("compression_codec", local_var_param_value.to_string());
}
if let Some(local_var_param_value) = period {
local_var_form_params.insert("period", local_var_param_value.to_string());
}
if let Some(local_var_param_value) = gzip_level {
local_var_form_params.insert("gzip_level", local_var_param_value.to_string());
}
if let Some(local_var_param_value) = address {
local_var_form_params.insert("address", local_var_param_value.to_string());
}
if let Some(local_var_param_value) = port {
local_var_form_params.insert("port", local_var_param_value.to_string());
}
if let Some(local_var_param_value) = password {
local_var_form_params.insert("password", local_var_param_value.to_string());
}
if let Some(local_var_param_value) = path {
local_var_form_params.insert("path", local_var_param_value.to_string());
}
if let Some(local_var_param_value) = public_key {
local_var_form_params.insert("public_key", local_var_param_value.to_string());
}
if let Some(local_var_param_value) = secret_key {
local_var_form_params.insert("secret_key", local_var_param_value.to_string());
}
if let Some(local_var_param_value) = ssh_known_hosts {
local_var_form_params.insert("ssh_known_hosts", local_var_param_value.to_string());
}
if let Some(local_var_param_value) = user {
local_var_form_params.insert("user", local_var_param_value.to_string());
}
local_var_req_builder = local_var_req_builder.form(&local_var_form_params);
let local_var_req = local_var_req_builder.build()?;
let local_var_resp = local_var_client.execute(local_var_req).await?;
if "POST" != "GET" && "POST" != "HEAD" {
let headers = local_var_resp.headers();
local_var_configuration.rate_limit_remaining = match headers.get("Fastly-RateLimit-Remaining") {
Some(v) => v.to_str().unwrap().parse().unwrap(),
None => configuration::DEFAULT_RATELIMIT,
};
local_var_configuration.rate_limit_reset = match headers.get("Fastly-RateLimit-Reset") {
Some(v) => v.to_str().unwrap().parse().unwrap(),
None => 0,
};
}
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<CreateLogSftpError> = 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 delete_log_sftp(configuration: &mut configuration::Configuration, params: DeleteLogSftpParams) -> Result<crate::models::InlineResponse200, Error<DeleteLogSftpError>> {
let local_var_configuration = configuration;
let service_id = params.service_id;
let version_id = params.version_id;
let logging_sftp_name = params.logging_sftp_name;
let local_var_client = &local_var_configuration.client;
let local_var_uri_str = format!("{}/service/{service_id}/version/{version_id}/logging/sftp/{logging_sftp_name}", local_var_configuration.base_path, service_id=crate::apis::urlencode(service_id), version_id=version_id, logging_sftp_name=crate::apis::urlencode(logging_sftp_name));
let mut local_var_req_builder = local_var_client.request(reqwest::Method::DELETE, local_var_uri_str.as_str());
if let Some(ref local_var_user_agent) = local_var_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_apikey) = local_var_configuration.api_key {
let local_var_key = local_var_apikey.key.clone();
let local_var_value = match local_var_apikey.prefix {
Some(ref local_var_prefix) => format!("{} {}", local_var_prefix, local_var_key),
None => local_var_key,
};
local_var_req_builder = local_var_req_builder.header("Fastly-Key", local_var_value);
};
let local_var_req = local_var_req_builder.build()?;
let local_var_resp = local_var_client.execute(local_var_req).await?;
if "DELETE" != "GET" && "DELETE" != "HEAD" {
let headers = local_var_resp.headers();
local_var_configuration.rate_limit_remaining = match headers.get("Fastly-RateLimit-Remaining") {
Some(v) => v.to_str().unwrap().parse().unwrap(),
None => configuration::DEFAULT_RATELIMIT,
};
local_var_configuration.rate_limit_reset = match headers.get("Fastly-RateLimit-Reset") {
Some(v) => v.to_str().unwrap().parse().unwrap(),
None => 0,
};
}
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<DeleteLogSftpError> = 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 get_log_sftp(configuration: &mut configuration::Configuration, params: GetLogSftpParams) -> Result<crate::models::LoggingSftpResponse, Error<GetLogSftpError>> {
let local_var_configuration = configuration;
let service_id = params.service_id;
let version_id = params.version_id;
let logging_sftp_name = params.logging_sftp_name;
let local_var_client = &local_var_configuration.client;
let local_var_uri_str = format!("{}/service/{service_id}/version/{version_id}/logging/sftp/{logging_sftp_name}", local_var_configuration.base_path, service_id=crate::apis::urlencode(service_id), version_id=version_id, logging_sftp_name=crate::apis::urlencode(logging_sftp_name));
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_user_agent) = local_var_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_apikey) = local_var_configuration.api_key {
let local_var_key = local_var_apikey.key.clone();
let local_var_value = match local_var_apikey.prefix {
Some(ref local_var_prefix) => format!("{} {}", local_var_prefix, local_var_key),
None => local_var_key,
};
local_var_req_builder = local_var_req_builder.header("Fastly-Key", local_var_value);
};
let local_var_req = local_var_req_builder.build()?;
let local_var_resp = local_var_client.execute(local_var_req).await?;
if "GET" != "GET" && "GET" != "HEAD" {
let headers = local_var_resp.headers();
local_var_configuration.rate_limit_remaining = match headers.get("Fastly-RateLimit-Remaining") {
Some(v) => v.to_str().unwrap().parse().unwrap(),
None => configuration::DEFAULT_RATELIMIT,
};
local_var_configuration.rate_limit_reset = match headers.get("Fastly-RateLimit-Reset") {
Some(v) => v.to_str().unwrap().parse().unwrap(),
None => 0,
};
}
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<GetLogSftpError> = 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 list_log_sftp(configuration: &mut configuration::Configuration, params: ListLogSftpParams) -> Result<Vec<crate::models::LoggingSftpResponse>, Error<ListLogSftpError>> {
let local_var_configuration = configuration;
let service_id = params.service_id;
let version_id = params.version_id;
let local_var_client = &local_var_configuration.client;
let local_var_uri_str = format!("{}/service/{service_id}/version/{version_id}/logging/sftp", local_var_configuration.base_path, service_id=crate::apis::urlencode(service_id), version_id=version_id);
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_user_agent) = local_var_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_apikey) = local_var_configuration.api_key {
let local_var_key = local_var_apikey.key.clone();
let local_var_value = match local_var_apikey.prefix {
Some(ref local_var_prefix) => format!("{} {}", local_var_prefix, local_var_key),
None => local_var_key,
};
local_var_req_builder = local_var_req_builder.header("Fastly-Key", local_var_value);
};
let local_var_req = local_var_req_builder.build()?;
let local_var_resp = local_var_client.execute(local_var_req).await?;
if "GET" != "GET" && "GET" != "HEAD" {
let headers = local_var_resp.headers();
local_var_configuration.rate_limit_remaining = match headers.get("Fastly-RateLimit-Remaining") {
Some(v) => v.to_str().unwrap().parse().unwrap(),
None => configuration::DEFAULT_RATELIMIT,
};
local_var_configuration.rate_limit_reset = match headers.get("Fastly-RateLimit-Reset") {
Some(v) => v.to_str().unwrap().parse().unwrap(),
None => 0,
};
}
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<ListLogSftpError> = 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 update_log_sftp(configuration: &mut configuration::Configuration, params: UpdateLogSftpParams) -> Result<crate::models::LoggingSftpResponse, Error<UpdateLogSftpError>> {
let local_var_configuration = configuration;
let service_id = params.service_id;
let version_id = params.version_id;
let logging_sftp_name = params.logging_sftp_name;
let name = params.name;
let placement = params.placement;
let response_condition = params.response_condition;
let format = params.format;
let format_version = params.format_version;
let message_type = params.message_type;
let timestamp_format = params.timestamp_format;
let compression_codec = params.compression_codec;
let period = params.period;
let gzip_level = params.gzip_level;
let address = params.address;
let port = params.port;
let password = params.password;
let path = params.path;
let public_key = params.public_key;
let secret_key = params.secret_key;
let ssh_known_hosts = params.ssh_known_hosts;
let user = params.user;
let local_var_client = &local_var_configuration.client;
let local_var_uri_str = format!("{}/service/{service_id}/version/{version_id}/logging/sftp/{logging_sftp_name}", local_var_configuration.base_path, service_id=crate::apis::urlencode(service_id), version_id=version_id, logging_sftp_name=crate::apis::urlencode(logging_sftp_name));
let mut local_var_req_builder = local_var_client.request(reqwest::Method::PUT, local_var_uri_str.as_str());
if let Some(ref local_var_user_agent) = local_var_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_apikey) = local_var_configuration.api_key {
let local_var_key = local_var_apikey.key.clone();
let local_var_value = match local_var_apikey.prefix {
Some(ref local_var_prefix) => format!("{} {}", local_var_prefix, local_var_key),
None => local_var_key,
};
local_var_req_builder = local_var_req_builder.header("Fastly-Key", local_var_value);
};
let mut local_var_form_params = std::collections::HashMap::new();
if let Some(local_var_param_value) = name {
local_var_form_params.insert("name", local_var_param_value.to_string());
}
if let Some(local_var_param_value) = placement {
local_var_form_params.insert("placement", local_var_param_value.to_string());
}
if let Some(local_var_param_value) = response_condition {
local_var_form_params.insert("response_condition", local_var_param_value.to_string());
}
if let Some(local_var_param_value) = format {
local_var_form_params.insert("format", local_var_param_value.to_string());
}
if let Some(local_var_param_value) = format_version {
local_var_form_params.insert("format_version", local_var_param_value.to_string());
}
if let Some(local_var_param_value) = message_type {
local_var_form_params.insert("message_type", local_var_param_value.to_string());
}
if let Some(local_var_param_value) = timestamp_format {
local_var_form_params.insert("timestamp_format", local_var_param_value.to_string());
}
if let Some(local_var_param_value) = compression_codec {
local_var_form_params.insert("compression_codec", local_var_param_value.to_string());
}
if let Some(local_var_param_value) = period {
local_var_form_params.insert("period", local_var_param_value.to_string());
}
if let Some(local_var_param_value) = gzip_level {
local_var_form_params.insert("gzip_level", local_var_param_value.to_string());
}
if let Some(local_var_param_value) = address {
local_var_form_params.insert("address", local_var_param_value.to_string());
}
if let Some(local_var_param_value) = port {
local_var_form_params.insert("port", local_var_param_value.to_string());
}
if let Some(local_var_param_value) = password {
local_var_form_params.insert("password", local_var_param_value.to_string());
}
if let Some(local_var_param_value) = path {
local_var_form_params.insert("path", local_var_param_value.to_string());
}
if let Some(local_var_param_value) = public_key {
local_var_form_params.insert("public_key", local_var_param_value.to_string());
}
if let Some(local_var_param_value) = secret_key {
local_var_form_params.insert("secret_key", local_var_param_value.to_string());
}
if let Some(local_var_param_value) = ssh_known_hosts {
local_var_form_params.insert("ssh_known_hosts", local_var_param_value.to_string());
}
if let Some(local_var_param_value) = user {
local_var_form_params.insert("user", local_var_param_value.to_string());
}
local_var_req_builder = local_var_req_builder.form(&local_var_form_params);
let local_var_req = local_var_req_builder.build()?;
let local_var_resp = local_var_client.execute(local_var_req).await?;
if "PUT" != "GET" && "PUT" != "HEAD" {
let headers = local_var_resp.headers();
local_var_configuration.rate_limit_remaining = match headers.get("Fastly-RateLimit-Remaining") {
Some(v) => v.to_str().unwrap().parse().unwrap(),
None => configuration::DEFAULT_RATELIMIT,
};
local_var_configuration.rate_limit_reset = match headers.get("Fastly-RateLimit-Reset") {
Some(v) => v.to_str().unwrap().parse().unwrap(),
None => 0,
};
}
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<UpdateLogSftpError> = 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))
}
}