use reqwest;
use crate::apis::ResponseContent;
use super::{Error, configuration};
#[derive(Clone, Debug, Default)]
pub struct CreateBackendParams {
    pub service_id: String,
    pub version_id: i32,
    pub address: Option<String>,
    pub auto_loadbalance: Option<bool>,
    pub between_bytes_timeout: Option<i32>,
    pub client_cert: Option<String>,
    pub comment: Option<String>,
    pub connect_timeout: Option<i32>,
    pub first_byte_timeout: Option<i32>,
    pub healthcheck: Option<String>,
    pub hostname: Option<String>,
    pub ipv4: Option<String>,
    pub ipv6: Option<String>,
    pub keepalive_time: Option<i32>,
    pub max_conn: Option<i32>,
    pub max_tls_version: Option<String>,
    pub min_tls_version: Option<String>,
    pub name: Option<String>,
    pub override_host: Option<String>,
    pub port: Option<i32>,
    pub request_condition: Option<String>,
    pub share_key: Option<String>,
    pub shield: Option<String>,
    pub ssl_ca_cert: Option<String>,
    pub ssl_cert_hostname: Option<String>,
    pub ssl_check_cert: Option<bool>,
    pub ssl_ciphers: Option<String>,
    pub ssl_client_cert: Option<String>,
    pub ssl_client_key: Option<String>,
    pub ssl_hostname: Option<String>,
    pub ssl_sni_hostname: Option<String>,
    pub tcp_keepalive_enable: Option<bool>,
    pub tcp_keepalive_interval: Option<i32>,
    pub tcp_keepalive_probes: Option<i32>,
    pub tcp_keepalive_time: Option<i32>,
    pub use_ssl: Option<bool>,
    pub weight: Option<i32>
}
#[derive(Clone, Debug, Default)]
pub struct DeleteBackendParams {
    pub service_id: String,
    pub version_id: i32,
    pub backend_name: String
}
#[derive(Clone, Debug, Default)]
pub struct GetBackendParams {
    pub service_id: String,
    pub version_id: i32,
    pub backend_name: String
}
#[derive(Clone, Debug, Default)]
pub struct ListBackendsParams {
    pub service_id: String,
    pub version_id: i32
}
#[derive(Clone, Debug, Default)]
pub struct UpdateBackendParams {
    pub service_id: String,
    pub version_id: i32,
    pub backend_name: String,
    pub address: Option<String>,
    pub auto_loadbalance: Option<bool>,
    pub between_bytes_timeout: Option<i32>,
    pub client_cert: Option<String>,
    pub comment: Option<String>,
    pub connect_timeout: Option<i32>,
    pub first_byte_timeout: Option<i32>,
    pub healthcheck: Option<String>,
    pub hostname: Option<String>,
    pub ipv4: Option<String>,
    pub ipv6: Option<String>,
    pub keepalive_time: Option<i32>,
    pub max_conn: Option<i32>,
    pub max_tls_version: Option<String>,
    pub min_tls_version: Option<String>,
    pub name: Option<String>,
    pub override_host: Option<String>,
    pub port: Option<i32>,
    pub request_condition: Option<String>,
    pub share_key: Option<String>,
    pub shield: Option<String>,
    pub ssl_ca_cert: Option<String>,
    pub ssl_cert_hostname: Option<String>,
    pub ssl_check_cert: Option<bool>,
    pub ssl_ciphers: Option<String>,
    pub ssl_client_cert: Option<String>,
    pub ssl_client_key: Option<String>,
    pub ssl_hostname: Option<String>,
    pub ssl_sni_hostname: Option<String>,
    pub tcp_keepalive_enable: Option<bool>,
    pub tcp_keepalive_interval: Option<i32>,
    pub tcp_keepalive_probes: Option<i32>,
    pub tcp_keepalive_time: Option<i32>,
    pub use_ssl: Option<bool>,
    pub weight: Option<i32>
}
#[derive(Debug, Clone, Serialize, Deserialize)]
#[serde(untagged)]
pub enum CreateBackendError {
    UnknownValue(serde_json::Value),
}
#[derive(Debug, Clone, Serialize, Deserialize)]
#[serde(untagged)]
pub enum DeleteBackendError {
    UnknownValue(serde_json::Value),
}
#[derive(Debug, Clone, Serialize, Deserialize)]
#[serde(untagged)]
pub enum GetBackendError {
    UnknownValue(serde_json::Value),
}
#[derive(Debug, Clone, Serialize, Deserialize)]
#[serde(untagged)]
pub enum ListBackendsError {
    UnknownValue(serde_json::Value),
}
#[derive(Debug, Clone, Serialize, Deserialize)]
#[serde(untagged)]
pub enum UpdateBackendError {
    UnknownValue(serde_json::Value),
}
pub async fn create_backend(configuration: &mut configuration::Configuration, params: CreateBackendParams) -> Result<crate::models::BackendResponse, Error<CreateBackendError>> {
    let local_var_configuration = configuration;
    let service_id = params.service_id;
    let version_id = params.version_id;
    let address = params.address;
    let auto_loadbalance = params.auto_loadbalance;
    let between_bytes_timeout = params.between_bytes_timeout;
    let client_cert = params.client_cert;
    let comment = params.comment;
    let connect_timeout = params.connect_timeout;
    let first_byte_timeout = params.first_byte_timeout;
    let healthcheck = params.healthcheck;
    let hostname = params.hostname;
    let ipv4 = params.ipv4;
    let ipv6 = params.ipv6;
    let keepalive_time = params.keepalive_time;
    let max_conn = params.max_conn;
    let max_tls_version = params.max_tls_version;
    let min_tls_version = params.min_tls_version;
    let name = params.name;
    let override_host = params.override_host;
    let port = params.port;
    let request_condition = params.request_condition;
    let share_key = params.share_key;
    let shield = params.shield;
    let ssl_ca_cert = params.ssl_ca_cert;
    let ssl_cert_hostname = params.ssl_cert_hostname;
    let ssl_check_cert = params.ssl_check_cert;
    let ssl_ciphers = params.ssl_ciphers;
    let ssl_client_cert = params.ssl_client_cert;
    let ssl_client_key = params.ssl_client_key;
    let ssl_hostname = params.ssl_hostname;
    let ssl_sni_hostname = params.ssl_sni_hostname;
    let tcp_keepalive_enable = params.tcp_keepalive_enable;
    let tcp_keepalive_interval = params.tcp_keepalive_interval;
    let tcp_keepalive_probes = params.tcp_keepalive_probes;
    let tcp_keepalive_time = params.tcp_keepalive_time;
    let use_ssl = params.use_ssl;
    let weight = params.weight;
    let local_var_client = &local_var_configuration.client;
    let local_var_uri_str = format!("{}/service/{service_id}/version/{version_id}/backend", 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) = address {
        local_var_form_params.insert("address", local_var_param_value.to_string());
    }
    if let Some(local_var_param_value) = auto_loadbalance {
        local_var_form_params.insert("auto_loadbalance", local_var_param_value.to_string());
    }
    if let Some(local_var_param_value) = between_bytes_timeout {
        local_var_form_params.insert("between_bytes_timeout", local_var_param_value.to_string());
    }
    if let Some(local_var_param_value) = client_cert {
        local_var_form_params.insert("client_cert", local_var_param_value.to_string());
    }
    if let Some(local_var_param_value) = comment {
        local_var_form_params.insert("comment", local_var_param_value.to_string());
    }
    if let Some(local_var_param_value) = connect_timeout {
        local_var_form_params.insert("connect_timeout", local_var_param_value.to_string());
    }
    if let Some(local_var_param_value) = first_byte_timeout {
        local_var_form_params.insert("first_byte_timeout", local_var_param_value.to_string());
    }
    if let Some(local_var_param_value) = healthcheck {
        local_var_form_params.insert("healthcheck", local_var_param_value.to_string());
    }
    if let Some(local_var_param_value) = hostname {
        local_var_form_params.insert("hostname", local_var_param_value.to_string());
    }
    if let Some(local_var_param_value) = ipv4 {
        local_var_form_params.insert("ipv4", local_var_param_value.to_string());
    }
    if let Some(local_var_param_value) = ipv6 {
        local_var_form_params.insert("ipv6", local_var_param_value.to_string());
    }
    if let Some(local_var_param_value) = keepalive_time {
        local_var_form_params.insert("keepalive_time", local_var_param_value.to_string());
    }
    if let Some(local_var_param_value) = max_conn {
        local_var_form_params.insert("max_conn", local_var_param_value.to_string());
    }
    if let Some(local_var_param_value) = max_tls_version {
        local_var_form_params.insert("max_tls_version", local_var_param_value.to_string());
    }
    if let Some(local_var_param_value) = min_tls_version {
        local_var_form_params.insert("min_tls_version", local_var_param_value.to_string());
    }
    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) = override_host {
        local_var_form_params.insert("override_host", 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) = request_condition {
        local_var_form_params.insert("request_condition", local_var_param_value.to_string());
    }
    if let Some(local_var_param_value) = share_key {
        local_var_form_params.insert("share_key", local_var_param_value.to_string());
    }
    if let Some(local_var_param_value) = shield {
        local_var_form_params.insert("shield", local_var_param_value.to_string());
    }
    if let Some(local_var_param_value) = ssl_ca_cert {
        local_var_form_params.insert("ssl_ca_cert", local_var_param_value.to_string());
    }
    if let Some(local_var_param_value) = ssl_cert_hostname {
        local_var_form_params.insert("ssl_cert_hostname", local_var_param_value.to_string());
    }
    if let Some(local_var_param_value) = ssl_check_cert {
        local_var_form_params.insert("ssl_check_cert", local_var_param_value.to_string());
    }
    if let Some(local_var_param_value) = ssl_ciphers {
        local_var_form_params.insert("ssl_ciphers", local_var_param_value.to_string());
    }
    if let Some(local_var_param_value) = ssl_client_cert {
        local_var_form_params.insert("ssl_client_cert", local_var_param_value.to_string());
    }
    if let Some(local_var_param_value) = ssl_client_key {
        local_var_form_params.insert("ssl_client_key", local_var_param_value.to_string());
    }
    if let Some(local_var_param_value) = ssl_hostname {
        local_var_form_params.insert("ssl_hostname", local_var_param_value.to_string());
    }
    if let Some(local_var_param_value) = ssl_sni_hostname {
        local_var_form_params.insert("ssl_sni_hostname", local_var_param_value.to_string());
    }
    if let Some(local_var_param_value) = tcp_keepalive_enable {
        local_var_form_params.insert("tcp_keepalive_enable", local_var_param_value.to_string());
    }
    if let Some(local_var_param_value) = tcp_keepalive_interval {
        local_var_form_params.insert("tcp_keepalive_interval", local_var_param_value.to_string());
    }
    if let Some(local_var_param_value) = tcp_keepalive_probes {
        local_var_form_params.insert("tcp_keepalive_probes", local_var_param_value.to_string());
    }
    if let Some(local_var_param_value) = tcp_keepalive_time {
        local_var_form_params.insert("tcp_keepalive_time", local_var_param_value.to_string());
    }
    if let Some(local_var_param_value) = use_ssl {
        local_var_form_params.insert("use_ssl", local_var_param_value.to_string());
    }
    if let Some(local_var_param_value) = weight {
        local_var_form_params.insert("weight", 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<CreateBackendError> = 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_backend(configuration: &mut configuration::Configuration, params: DeleteBackendParams) -> Result<crate::models::InlineResponse200, Error<DeleteBackendError>> {
    let local_var_configuration = configuration;
    let service_id = params.service_id;
    let version_id = params.version_id;
    let backend_name = params.backend_name;
    let local_var_client = &local_var_configuration.client;
    let local_var_uri_str = format!("{}/service/{service_id}/version/{version_id}/backend/{backend_name}", local_var_configuration.base_path, service_id=crate::apis::urlencode(service_id), version_id=version_id, backend_name=crate::apis::urlencode(backend_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<DeleteBackendError> = 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_backend(configuration: &mut configuration::Configuration, params: GetBackendParams) -> Result<crate::models::BackendResponse, Error<GetBackendError>> {
    let local_var_configuration = configuration;
    let service_id = params.service_id;
    let version_id = params.version_id;
    let backend_name = params.backend_name;
    let local_var_client = &local_var_configuration.client;
    let local_var_uri_str = format!("{}/service/{service_id}/version/{version_id}/backend/{backend_name}", local_var_configuration.base_path, service_id=crate::apis::urlencode(service_id), version_id=version_id, backend_name=crate::apis::urlencode(backend_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<GetBackendError> = 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_backends(configuration: &mut configuration::Configuration, params: ListBackendsParams) -> Result<Vec<crate::models::BackendResponse>, Error<ListBackendsError>> {
    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}/backend", 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<ListBackendsError> = 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_backend(configuration: &mut configuration::Configuration, params: UpdateBackendParams) -> Result<crate::models::BackendResponse, Error<UpdateBackendError>> {
    let local_var_configuration = configuration;
    let service_id = params.service_id;
    let version_id = params.version_id;
    let backend_name = params.backend_name;
    let address = params.address;
    let auto_loadbalance = params.auto_loadbalance;
    let between_bytes_timeout = params.between_bytes_timeout;
    let client_cert = params.client_cert;
    let comment = params.comment;
    let connect_timeout = params.connect_timeout;
    let first_byte_timeout = params.first_byte_timeout;
    let healthcheck = params.healthcheck;
    let hostname = params.hostname;
    let ipv4 = params.ipv4;
    let ipv6 = params.ipv6;
    let keepalive_time = params.keepalive_time;
    let max_conn = params.max_conn;
    let max_tls_version = params.max_tls_version;
    let min_tls_version = params.min_tls_version;
    let name = params.name;
    let override_host = params.override_host;
    let port = params.port;
    let request_condition = params.request_condition;
    let share_key = params.share_key;
    let shield = params.shield;
    let ssl_ca_cert = params.ssl_ca_cert;
    let ssl_cert_hostname = params.ssl_cert_hostname;
    let ssl_check_cert = params.ssl_check_cert;
    let ssl_ciphers = params.ssl_ciphers;
    let ssl_client_cert = params.ssl_client_cert;
    let ssl_client_key = params.ssl_client_key;
    let ssl_hostname = params.ssl_hostname;
    let ssl_sni_hostname = params.ssl_sni_hostname;
    let tcp_keepalive_enable = params.tcp_keepalive_enable;
    let tcp_keepalive_interval = params.tcp_keepalive_interval;
    let tcp_keepalive_probes = params.tcp_keepalive_probes;
    let tcp_keepalive_time = params.tcp_keepalive_time;
    let use_ssl = params.use_ssl;
    let weight = params.weight;
    let local_var_client = &local_var_configuration.client;
    let local_var_uri_str = format!("{}/service/{service_id}/version/{version_id}/backend/{backend_name}", local_var_configuration.base_path, service_id=crate::apis::urlencode(service_id), version_id=version_id, backend_name=crate::apis::urlencode(backend_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) = address {
        local_var_form_params.insert("address", local_var_param_value.to_string());
    }
    if let Some(local_var_param_value) = auto_loadbalance {
        local_var_form_params.insert("auto_loadbalance", local_var_param_value.to_string());
    }
    if let Some(local_var_param_value) = between_bytes_timeout {
        local_var_form_params.insert("between_bytes_timeout", local_var_param_value.to_string());
    }
    if let Some(local_var_param_value) = client_cert {
        local_var_form_params.insert("client_cert", local_var_param_value.to_string());
    }
    if let Some(local_var_param_value) = comment {
        local_var_form_params.insert("comment", local_var_param_value.to_string());
    }
    if let Some(local_var_param_value) = connect_timeout {
        local_var_form_params.insert("connect_timeout", local_var_param_value.to_string());
    }
    if let Some(local_var_param_value) = first_byte_timeout {
        local_var_form_params.insert("first_byte_timeout", local_var_param_value.to_string());
    }
    if let Some(local_var_param_value) = healthcheck {
        local_var_form_params.insert("healthcheck", local_var_param_value.to_string());
    }
    if let Some(local_var_param_value) = hostname {
        local_var_form_params.insert("hostname", local_var_param_value.to_string());
    }
    if let Some(local_var_param_value) = ipv4 {
        local_var_form_params.insert("ipv4", local_var_param_value.to_string());
    }
    if let Some(local_var_param_value) = ipv6 {
        local_var_form_params.insert("ipv6", local_var_param_value.to_string());
    }
    if let Some(local_var_param_value) = keepalive_time {
        local_var_form_params.insert("keepalive_time", local_var_param_value.to_string());
    }
    if let Some(local_var_param_value) = max_conn {
        local_var_form_params.insert("max_conn", local_var_param_value.to_string());
    }
    if let Some(local_var_param_value) = max_tls_version {
        local_var_form_params.insert("max_tls_version", local_var_param_value.to_string());
    }
    if let Some(local_var_param_value) = min_tls_version {
        local_var_form_params.insert("min_tls_version", local_var_param_value.to_string());
    }
    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) = override_host {
        local_var_form_params.insert("override_host", 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) = request_condition {
        local_var_form_params.insert("request_condition", local_var_param_value.to_string());
    }
    if let Some(local_var_param_value) = share_key {
        local_var_form_params.insert("share_key", local_var_param_value.to_string());
    }
    if let Some(local_var_param_value) = shield {
        local_var_form_params.insert("shield", local_var_param_value.to_string());
    }
    if let Some(local_var_param_value) = ssl_ca_cert {
        local_var_form_params.insert("ssl_ca_cert", local_var_param_value.to_string());
    }
    if let Some(local_var_param_value) = ssl_cert_hostname {
        local_var_form_params.insert("ssl_cert_hostname", local_var_param_value.to_string());
    }
    if let Some(local_var_param_value) = ssl_check_cert {
        local_var_form_params.insert("ssl_check_cert", local_var_param_value.to_string());
    }
    if let Some(local_var_param_value) = ssl_ciphers {
        local_var_form_params.insert("ssl_ciphers", local_var_param_value.to_string());
    }
    if let Some(local_var_param_value) = ssl_client_cert {
        local_var_form_params.insert("ssl_client_cert", local_var_param_value.to_string());
    }
    if let Some(local_var_param_value) = ssl_client_key {
        local_var_form_params.insert("ssl_client_key", local_var_param_value.to_string());
    }
    if let Some(local_var_param_value) = ssl_hostname {
        local_var_form_params.insert("ssl_hostname", local_var_param_value.to_string());
    }
    if let Some(local_var_param_value) = ssl_sni_hostname {
        local_var_form_params.insert("ssl_sni_hostname", local_var_param_value.to_string());
    }
    if let Some(local_var_param_value) = tcp_keepalive_enable {
        local_var_form_params.insert("tcp_keepalive_enable", local_var_param_value.to_string());
    }
    if let Some(local_var_param_value) = tcp_keepalive_interval {
        local_var_form_params.insert("tcp_keepalive_interval", local_var_param_value.to_string());
    }
    if let Some(local_var_param_value) = tcp_keepalive_probes {
        local_var_form_params.insert("tcp_keepalive_probes", local_var_param_value.to_string());
    }
    if let Some(local_var_param_value) = tcp_keepalive_time {
        local_var_form_params.insert("tcp_keepalive_time", local_var_param_value.to_string());
    }
    if let Some(local_var_param_value) = use_ssl {
        local_var_form_params.insert("use_ssl", local_var_param_value.to_string());
    }
    if let Some(local_var_param_value) = weight {
        local_var_form_params.insert("weight", 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<UpdateBackendError> = 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))
    }
}