/*
* Twilio - Api
*
* This is the public Twilio REST API.
*
* The version of the OpenAPI document: 1.0.0
* Contact: support@twilio.com
* Generated by: https://openapi-generator.tech
*/
use reqwest;
use serde::{Deserialize, Serialize};
use crate::{apis::ResponseContent, models};
use super::{Error, configuration};
/// struct for passing parameters to the method [`create_message`]
#[derive(Clone, Debug)]
pub struct CreateMessageParams {
/// The SID of the [Account](https://www.twilio.com/docs/iam/api/account) creating the Message resource.
pub account_sid: String,
/// The recipient's phone number in [E.164](https://www.twilio.com/docs/glossary/what-e164) format (for SMS/MMS) or [channel address](https://www.twilio.com/docs/messaging/channels), e.g. `whatsapp:+15552229999`.
pub to: String,
/// The URL of the endpoint to which Twilio sends [Message status callback requests](https://www.twilio.com/docs/sms/api/message-resource#twilios-request-to-the-statuscallback-url). URL must contain a valid hostname and underscores are not allowed. If you include this parameter with the `messaging_service_sid`, Twilio uses this URL instead of the Status Callback URL of the [Messaging Service](https://www.twilio.com/docs/messaging/api/service-resource).
pub status_callback: Option<String>,
/// The SID of the associated [TwiML Application](https://www.twilio.com/docs/usage/api/applications). [Message status callback requests](https://www.twilio.com/docs/sms/api/message-resource#twilios-request-to-the-statuscallback-url) are sent to the TwiML App's `message_status_callback` URL. Note that the `status_callback` parameter of a request takes priority over the `application_sid` parameter; if both are included `application_sid` is ignored.
pub application_sid: Option<String>,
/// [OBSOLETE] This parameter will no longer have any effect as of 2024-06-03.
pub max_price: Option<f64>,
/// Boolean indicating whether or not you intend to provide delivery confirmation feedback to Twilio (used in conjunction with the [Message Feedback subresource](https://www.twilio.com/docs/sms/api/message-feedback-resource)). Default value is `false`.
pub provide_feedback: Option<bool>,
/// Total number of attempts made (including this request) to send the message regardless of the provider used
pub attempt: Option<i32>,
/// The maximum length in seconds that the Message can remain in Twilio's outgoing message queue. If a queued Message exceeds the `validity_period`, the Message is not sent. Accepted values are integers from `1` to `36000`. Default value is `36000`. A `validity_period` greater than `5` is recommended. [Learn more about the validity period](https://www.twilio.com/blog/take-more-control-of-outbound-messages-using-validity-period-html)
pub validity_period: Option<i32>,
/// Reserved
pub force_delivery: Option<bool>,
pub content_retention: Option<String>,
pub address_retention: Option<String>,
/// Whether to detect Unicode characters that have a similar GSM-7 character and replace them. Can be: `true` or `false`.
pub smart_encoded: Option<bool>,
/// Rich actions for non-SMS/MMS channels. Used for [sending location in WhatsApp messages](https://www.twilio.com/docs/whatsapp/message-features#location-messages-with-whatsapp).
pub persistent_action: Option<Vec<String>>,
/// For Messaging Services with [Link Shortening configured](https://www.twilio.com/docs/messaging/features/link-shortening) only: A Boolean indicating whether or not Twilio should shorten links in the `body` of the Message. Default value is `false`. If `true`, the `messaging_service_sid` parameter must also be provided.
pub shorten_urls: Option<bool>,
pub schedule_type: Option<String>,
/// The time that Twilio will send the message. Must be in ISO 8601 format.
pub send_at: Option<String>,
/// If set to `true`, Twilio delivers the message as a single MMS message, regardless of the presence of media.
pub send_as_mms: Option<bool>,
/// For [Content Editor/API](https://www.twilio.com/docs/content) only: Key-value pairs of [Template variables](https://www.twilio.com/docs/content/using-variables-with-content-api) and their substitution values. `content_sid` parameter must also be provided. If values are not defined in the `content_variables` parameter, the [Template's default placeholder values](https://www.twilio.com/docs/content/content-api-resources#create-templates) are used.
pub content_variables: Option<String>,
pub risk_check: Option<String>,
/// The sender's Twilio phone number (in [E.164](https://en.wikipedia.org/wiki/E.164) format), [alphanumeric sender ID](https://www.twilio.com/docs/sms/quickstart), [Wireless SIM](https://www.twilio.com/docs/iot/wireless/programmable-wireless-send-machine-machine-sms-commands), [short code](https://www.twilio.com/en-us/messaging/channels/sms/short-codes), or [channel address](https://www.twilio.com/docs/messaging/channels) (e.g., `whatsapp:+15554449999`). The value of the `from` parameter must be a sender that is hosted within Twilio and belongs to the Account creating the Message. If you are using `messaging_service_sid`, this parameter can be empty (Twilio assigns a `from` value from the Messaging Service's Sender Pool) or you can provide a specific sender from your Sender Pool.
pub from: Option<String>,
/// The SID of the [Messaging Service](https://www.twilio.com/docs/messaging/services) you want to associate with the Message. When this parameter is provided and the `from` parameter is omitted, Twilio selects the optimal sender from the Messaging Service's Sender Pool. You may also provide a `from` parameter if you want to use a specific Sender from the Sender Pool.
pub messaging_service_sid: Option<String>,
/// The text content of the outgoing message. Can be up to 1,600 characters in length. SMS only: If the `body` contains more than 160 [GSM-7](https://www.twilio.com/docs/glossary/what-is-gsm-7-character-encoding) characters (or 70 [UCS-2](https://www.twilio.com/docs/glossary/what-is-ucs-2-character-encoding) characters), the message is segmented and charged accordingly. For long `body` text, consider using the [send_as_mms parameter](https://www.twilio.com/blog/mms-for-long-text-messages).
pub body: Option<String>,
/// The URL of media to include in the Message content. `jpeg`, `jpg`, `gif`, and `png` file types are fully supported by Twilio and content is formatted for delivery on destination devices. The media size limit is 5 MB for supported file types (`jpeg`, `jpg`, `png`, `gif`) and 500 KB for [other types](https://www.twilio.com/docs/messaging/guides/accepted-mime-types) of accepted media. To send more than one image in the message, provide multiple `media_url` parameters in the POST request. You can include up to ten `media_url` parameters per message. [International](https://support.twilio.com/hc/en-us/articles/223179808-Sending-and-receiving-MMS-messages) and [carrier](https://support.twilio.com/hc/en-us/articles/223133707-Is-MMS-supported-for-all-carriers-in-US-and-Canada-) limits apply.
pub media_url: Option<Vec<String>>,
/// For [Content Editor/API](https://www.twilio.com/docs/content) only: The SID of the Content Template to be used with the Message, e.g., `HXXXXXXXXXXXXXXXXXXXXXXXXXXXXX`. If this parameter is not provided, a Content Template is not used. Find the SID in the Console on the Content Editor page. For Content API users, the SID is found in Twilio's response when [creating the Template](https://www.twilio.com/docs/content/content-api-resources#create-templates) or by [fetching your Templates](https://www.twilio.com/docs/content/content-api-resources#fetch-all-content-resources).
pub content_sid: Option<String>
}
/// struct for passing parameters to the method [`delete_message`]
#[derive(Clone, Debug)]
pub struct DeleteMessageParams {
/// The SID of the [Account](https://www.twilio.com/docs/iam/api/account) associated with the Message resource
pub account_sid: String,
/// The SID of the Message resource you wish to delete
pub sid: String
}
/// struct for passing parameters to the method [`fetch_message`]
#[derive(Clone, Debug)]
pub struct FetchMessageParams {
/// The SID of the [Account](https://www.twilio.com/docs/iam/api/account) associated with the Message resource
pub account_sid: String,
/// The SID of the Message resource to be fetched
pub sid: String
}
/// struct for passing parameters to the method [`list_message`]
#[derive(Clone, Debug)]
pub struct ListMessageParams {
/// The SID of the [Account](https://www.twilio.com/docs/iam/api/account) associated with the Message resources.
pub account_sid: String,
/// Filter by recipient. For example: Set this `to` parameter to `+15558881111` to retrieve a list of Message resources with `to` properties of `+15558881111`
pub to: Option<String>,
/// Filter by sender. For example: Set this `from` parameter to `+15552229999` to retrieve a list of Message resources with `from` properties of `+15552229999`
pub from: Option<String>,
/// Filter by Message `sent_date`. Accepts GMT dates in the following formats: `YYYY-MM-DD` (to find Messages with a specific `sent_date`), `<=YYYY-MM-DD` (to find Messages with `sent_date`s on and before a specific date), and `>=YYYY-MM-DD` (to find Messages with `sent_dates` on and after a specific date).
pub date_sent: Option<String>,
/// Filter by Message `sent_date`. Accepts GMT dates in the following formats: `YYYY-MM-DD` (to find Messages with a specific `sent_date`), `<=YYYY-MM-DD` (to find Messages with `sent_date`s on and before a specific date), and `>=YYYY-MM-DD` (to find Messages with `sent_dates` on and after a specific date).
pub date_sent_less_than: Option<String>,
/// Filter by Message `sent_date`. Accepts GMT dates in the following formats: `YYYY-MM-DD` (to find Messages with a specific `sent_date`), `<=YYYY-MM-DD` (to find Messages with `sent_date`s on and before a specific date), and `>=YYYY-MM-DD` (to find Messages with `sent_dates` on and after a specific date).
pub date_sent_greater_than: Option<String>,
/// How many resources to return in each list page. The default is 50, and the maximum is 1000.
pub page_size: Option<i32>,
/// The page index. This value is simply for client state.
pub page: Option<i32>,
/// The page token. This is provided by the API.
pub page_token: Option<String>
}
/// struct for passing parameters to the method [`update_message`]
#[derive(Clone, Debug)]
pub struct UpdateMessageParams {
/// The SID of the [Account](https://www.twilio.com/docs/iam/api/account) that created the Message resources to update.
pub account_sid: String,
/// The SID of the Message resource to be updated
pub sid: String,
/// The new `body` of the Message resource. To redact the text content of a Message, this parameter's value must be an empty string
pub body: Option<String>,
pub status: Option<String>
}
/// struct for typed errors of method [`create_message`]
#[derive(Debug, Clone, Serialize, Deserialize)]
#[serde(untagged)]
pub enum CreateMessageError {
UnknownValue(serde_json::Value),
}
/// struct for typed errors of method [`delete_message`]
#[derive(Debug, Clone, Serialize, Deserialize)]
#[serde(untagged)]
pub enum DeleteMessageError {
UnknownValue(serde_json::Value),
}
/// struct for typed errors of method [`fetch_message`]
#[derive(Debug, Clone, Serialize, Deserialize)]
#[serde(untagged)]
pub enum FetchMessageError {
UnknownValue(serde_json::Value),
}
/// struct for typed errors of method [`list_message`]
#[derive(Debug, Clone, Serialize, Deserialize)]
#[serde(untagged)]
pub enum ListMessageError {
UnknownValue(serde_json::Value),
}
/// struct for typed errors of method [`update_message`]
#[derive(Debug, Clone, Serialize, Deserialize)]
#[serde(untagged)]
pub enum UpdateMessageError {
UnknownValue(serde_json::Value),
}
/// Send a message
pub async fn create_message(configuration: &configuration::Configuration, params: CreateMessageParams) -> Result<models::ApiPeriodV2010PeriodAccountPeriodMessage, Error<CreateMessageError>> {
let local_var_configuration = configuration;
// unbox the parameters
let account_sid = params.account_sid;
let to = params.to;
let status_callback = params.status_callback;
let application_sid = params.application_sid;
let max_price = params.max_price;
let provide_feedback = params.provide_feedback;
let attempt = params.attempt;
let validity_period = params.validity_period;
let force_delivery = params.force_delivery;
let content_retention = params.content_retention;
let address_retention = params.address_retention;
let smart_encoded = params.smart_encoded;
let persistent_action = params.persistent_action;
let shorten_urls = params.shorten_urls;
let schedule_type = params.schedule_type;
let send_at = params.send_at;
let send_as_mms = params.send_as_mms;
let content_variables = params.content_variables;
let risk_check = params.risk_check;
let from = params.from;
let messaging_service_sid = params.messaging_service_sid;
let body = params.body;
let media_url = params.media_url;
let content_sid = params.content_sid;
let local_var_client = &local_var_configuration.client;
let local_var_uri_str = format!("{}/2010-04-01/Accounts/{AccountSid}/Messages.json", local_var_configuration.base_path, AccountSid=crate::apis::urlencode(account_sid));
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_auth_conf) = local_var_configuration.basic_auth {
local_var_req_builder = local_var_req_builder.basic_auth(local_var_auth_conf.0.to_owned(), local_var_auth_conf.1.to_owned());
};
let mut local_var_form_params = std::collections::HashMap::new();
local_var_form_params.insert("To", to.to_string());
if let Some(local_var_param_value) = status_callback {
local_var_form_params.insert("StatusCallback", local_var_param_value.to_string());
}
if let Some(local_var_param_value) = application_sid {
local_var_form_params.insert("ApplicationSid", local_var_param_value.to_string());
}
if let Some(local_var_param_value) = max_price {
local_var_form_params.insert("MaxPrice", local_var_param_value.to_string());
}
if let Some(local_var_param_value) = provide_feedback {
local_var_form_params.insert("ProvideFeedback", local_var_param_value.to_string());
}
if let Some(local_var_param_value) = attempt {
local_var_form_params.insert("Attempt", local_var_param_value.to_string());
}
if let Some(local_var_param_value) = validity_period {
local_var_form_params.insert("ValidityPeriod", local_var_param_value.to_string());
}
if let Some(local_var_param_value) = force_delivery {
local_var_form_params.insert("ForceDelivery", local_var_param_value.to_string());
}
if let Some(local_var_param_value) = content_retention {
local_var_form_params.insert("ContentRetention", local_var_param_value.to_string());
}
if let Some(local_var_param_value) = address_retention {
local_var_form_params.insert("AddressRetention", local_var_param_value.to_string());
}
if let Some(local_var_param_value) = smart_encoded {
local_var_form_params.insert("SmartEncoded", local_var_param_value.to_string());
}
if let Some(local_var_param_value) = persistent_action {
local_var_form_params.insert("PersistentAction", local_var_param_value.into_iter().map(|p| p.to_string()).collect::<Vec<String>>().join(",").to_string());
}
if let Some(local_var_param_value) = shorten_urls {
local_var_form_params.insert("ShortenUrls", local_var_param_value.to_string());
}
if let Some(local_var_param_value) = schedule_type {
local_var_form_params.insert("ScheduleType", local_var_param_value.to_string());
}
if let Some(local_var_param_value) = send_at {
local_var_form_params.insert("SendAt", local_var_param_value.to_string());
}
if let Some(local_var_param_value) = send_as_mms {
local_var_form_params.insert("SendAsMms", local_var_param_value.to_string());
}
if let Some(local_var_param_value) = content_variables {
local_var_form_params.insert("ContentVariables", local_var_param_value.to_string());
}
if let Some(local_var_param_value) = risk_check {
local_var_form_params.insert("RiskCheck", local_var_param_value.to_string());
}
if let Some(local_var_param_value) = from {
local_var_form_params.insert("From", local_var_param_value.to_string());
}
if let Some(local_var_param_value) = messaging_service_sid {
local_var_form_params.insert("MessagingServiceSid", local_var_param_value.to_string());
}
if let Some(local_var_param_value) = body {
local_var_form_params.insert("Body", local_var_param_value.to_string());
}
if let Some(local_var_param_value) = media_url {
local_var_form_params.insert("MediaUrl", local_var_param_value.into_iter().map(|p| p.to_string()).collect::<Vec<String>>().join(",").to_string());
}
if let Some(local_var_param_value) = content_sid {
local_var_form_params.insert("ContentSid", 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?;
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<CreateMessageError> = 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))
}
}
/// Deletes a Message resource from your account
pub async fn delete_message(configuration: &configuration::Configuration, params: DeleteMessageParams) -> Result<(), Error<DeleteMessageError>> {
let local_var_configuration = configuration;
// unbox the parameters
let account_sid = params.account_sid;
let sid = params.sid;
let local_var_client = &local_var_configuration.client;
let local_var_uri_str = format!("{}/2010-04-01/Accounts/{AccountSid}/Messages/{Sid}.json", local_var_configuration.base_path, AccountSid=crate::apis::urlencode(account_sid), Sid=crate::apis::urlencode(sid));
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_auth_conf) = local_var_configuration.basic_auth {
local_var_req_builder = local_var_req_builder.basic_auth(local_var_auth_conf.0.to_owned(), local_var_auth_conf.1.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() {
Ok(())
} else {
let local_var_entity: Option<DeleteMessageError> = 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))
}
}
/// Fetch a specific Message
pub async fn fetch_message(configuration: &configuration::Configuration, params: FetchMessageParams) -> Result<models::ApiPeriodV2010PeriodAccountPeriodMessage, Error<FetchMessageError>> {
let local_var_configuration = configuration;
// unbox the parameters
let account_sid = params.account_sid;
let sid = params.sid;
let local_var_client = &local_var_configuration.client;
let local_var_uri_str = format!("{}/2010-04-01/Accounts/{AccountSid}/Messages/{Sid}.json", local_var_configuration.base_path, AccountSid=crate::apis::urlencode(account_sid), Sid=crate::apis::urlencode(sid));
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_auth_conf) = local_var_configuration.basic_auth {
local_var_req_builder = local_var_req_builder.basic_auth(local_var_auth_conf.0.to_owned(), local_var_auth_conf.1.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<FetchMessageError> = 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))
}
}
/// Retrieve a list of Message resources associated with a Twilio Account
pub async fn list_message(configuration: &configuration::Configuration, params: ListMessageParams) -> Result<models::ListMessageResponse, Error<ListMessageError>> {
let local_var_configuration = configuration;
// unbox the parameters
let account_sid = params.account_sid;
let to = params.to;
let from = params.from;
let date_sent = params.date_sent;
let date_sent_less_than = params.date_sent_less_than;
let date_sent_greater_than = params.date_sent_greater_than;
let page_size = params.page_size;
let page = params.page;
let page_token = params.page_token;
let local_var_client = &local_var_configuration.client;
let local_var_uri_str = format!("{}/2010-04-01/Accounts/{AccountSid}/Messages.json", local_var_configuration.base_path, AccountSid=crate::apis::urlencode(account_sid));
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) = to {
local_var_req_builder = local_var_req_builder.query(&[("To", &local_var_str.to_string())]);
}
if let Some(ref local_var_str) = from {
local_var_req_builder = local_var_req_builder.query(&[("From", &local_var_str.to_string())]);
}
if let Some(ref local_var_str) = date_sent {
local_var_req_builder = local_var_req_builder.query(&[("DateSent", &local_var_str.to_string())]);
}
if let Some(ref local_var_str) = date_sent_less_than {
local_var_req_builder = local_var_req_builder.query(&[("DateSent<", &local_var_str.to_string())]);
}
if let Some(ref local_var_str) = date_sent_greater_than {
local_var_req_builder = local_var_req_builder.query(&[("DateSent>", &local_var_str.to_string())]);
}
if let Some(ref local_var_str) = page_size {
local_var_req_builder = local_var_req_builder.query(&[("PageSize", &local_var_str.to_string())]);
}
if let Some(ref local_var_str) = page {
local_var_req_builder = local_var_req_builder.query(&[("Page", &local_var_str.to_string())]);
}
if let Some(ref local_var_str) = page_token {
local_var_req_builder = local_var_req_builder.query(&[("PageToken", &local_var_str.to_string())]);
}
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_auth_conf) = local_var_configuration.basic_auth {
local_var_req_builder = local_var_req_builder.basic_auth(local_var_auth_conf.0.to_owned(), local_var_auth_conf.1.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<ListMessageError> = 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))
}
}
/// Update a Message resource (used to redact Message `body` text and to cancel not-yet-sent messages)
pub async fn update_message(configuration: &configuration::Configuration, params: UpdateMessageParams) -> Result<models::ApiPeriodV2010PeriodAccountPeriodMessage, Error<UpdateMessageError>> {
let local_var_configuration = configuration;
// unbox the parameters
let account_sid = params.account_sid;
let sid = params.sid;
let body = params.body;
let status = params.status;
let local_var_client = &local_var_configuration.client;
let local_var_uri_str = format!("{}/2010-04-01/Accounts/{AccountSid}/Messages/{Sid}.json", local_var_configuration.base_path, AccountSid=crate::apis::urlencode(account_sid), Sid=crate::apis::urlencode(sid));
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_auth_conf) = local_var_configuration.basic_auth {
local_var_req_builder = local_var_req_builder.basic_auth(local_var_auth_conf.0.to_owned(), local_var_auth_conf.1.to_owned());
};
let mut local_var_form_params = std::collections::HashMap::new();
if let Some(local_var_param_value) = body {
local_var_form_params.insert("Body", local_var_param_value.to_string());
}
if let Some(local_var_param_value) = status {
local_var_form_params.insert("Status", 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?;
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<UpdateMessageError> = 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))
}
}