use stripe_client_core::{
RequestBuilder, StripeBlockingClient, StripeClient, StripeMethod, StripeRequest,
};
#[derive(Clone, Eq, PartialEq)]
#[cfg_attr(not(feature = "redact-generated-debug"), derive(Debug))]
#[derive(serde::Serialize)]
struct ListChargeBuilder {
#[serde(skip_serializing_if = "Option::is_none")]
created: Option<stripe_types::RangeQueryTs>,
#[serde(skip_serializing_if = "Option::is_none")]
customer: Option<String>,
#[serde(skip_serializing_if = "Option::is_none")]
ending_before: Option<String>,
#[serde(skip_serializing_if = "Option::is_none")]
expand: Option<Vec<String>>,
#[serde(skip_serializing_if = "Option::is_none")]
limit: Option<i64>,
#[serde(skip_serializing_if = "Option::is_none")]
payment_intent: Option<String>,
#[serde(skip_serializing_if = "Option::is_none")]
starting_after: Option<String>,
#[serde(skip_serializing_if = "Option::is_none")]
transfer_group: Option<String>,
}
#[cfg(feature = "redact-generated-debug")]
impl std::fmt::Debug for ListChargeBuilder {
fn fmt(&self, f: &mut std::fmt::Formatter) -> std::fmt::Result {
f.debug_struct("ListChargeBuilder").finish_non_exhaustive()
}
}
impl ListChargeBuilder {
fn new() -> Self {
Self {
created: None,
customer: None,
ending_before: None,
expand: None,
limit: None,
payment_intent: None,
starting_after: None,
transfer_group: None,
}
}
}
#[derive(Clone)]
#[cfg_attr(not(feature = "redact-generated-debug"), derive(Debug))]
#[derive(serde::Serialize)]
pub struct ListCharge {
inner: ListChargeBuilder,
}
#[cfg(feature = "redact-generated-debug")]
impl std::fmt::Debug for ListCharge {
fn fmt(&self, f: &mut std::fmt::Formatter) -> std::fmt::Result {
f.debug_struct("ListCharge").finish_non_exhaustive()
}
}
impl ListCharge {
pub fn new() -> Self {
Self { inner: ListChargeBuilder::new() }
}
pub fn created(mut self, created: impl Into<stripe_types::RangeQueryTs>) -> Self {
self.inner.created = Some(created.into());
self
}
pub fn customer(mut self, customer: impl Into<String>) -> Self {
self.inner.customer = Some(customer.into());
self
}
pub fn ending_before(mut self, ending_before: impl Into<String>) -> Self {
self.inner.ending_before = Some(ending_before.into());
self
}
pub fn expand(mut self, expand: impl Into<Vec<String>>) -> Self {
self.inner.expand = Some(expand.into());
self
}
pub fn limit(mut self, limit: impl Into<i64>) -> Self {
self.inner.limit = Some(limit.into());
self
}
pub fn payment_intent(mut self, payment_intent: impl Into<String>) -> Self {
self.inner.payment_intent = Some(payment_intent.into());
self
}
pub fn starting_after(mut self, starting_after: impl Into<String>) -> Self {
self.inner.starting_after = Some(starting_after.into());
self
}
pub fn transfer_group(mut self, transfer_group: impl Into<String>) -> Self {
self.inner.transfer_group = Some(transfer_group.into());
self
}
}
impl Default for ListCharge {
fn default() -> Self {
Self::new()
}
}
impl ListCharge {
pub async fn send<C: StripeClient>(
&self,
client: &C,
) -> Result<<Self as StripeRequest>::Output, C::Err> {
self.customize().send(client).await
}
pub fn send_blocking<C: StripeBlockingClient>(
&self,
client: &C,
) -> Result<<Self as StripeRequest>::Output, C::Err> {
self.customize().send_blocking(client)
}
pub fn paginate(
&self,
) -> stripe_client_core::ListPaginator<stripe_types::List<stripe_shared::Charge>> {
stripe_client_core::ListPaginator::new_list("/charges", &self.inner)
}
}
impl StripeRequest for ListCharge {
type Output = stripe_types::List<stripe_shared::Charge>;
fn build(&self) -> RequestBuilder {
RequestBuilder::new(StripeMethod::Get, "/charges").query(&self.inner)
}
}
#[derive(Clone, Eq, PartialEq)]
#[cfg_attr(not(feature = "redact-generated-debug"), derive(Debug))]
#[derive(serde::Serialize)]
struct RetrieveChargeBuilder {
#[serde(skip_serializing_if = "Option::is_none")]
expand: Option<Vec<String>>,
}
#[cfg(feature = "redact-generated-debug")]
impl std::fmt::Debug for RetrieveChargeBuilder {
fn fmt(&self, f: &mut std::fmt::Formatter) -> std::fmt::Result {
f.debug_struct("RetrieveChargeBuilder").finish_non_exhaustive()
}
}
impl RetrieveChargeBuilder {
fn new() -> Self {
Self { expand: None }
}
}
#[derive(Clone)]
#[cfg_attr(not(feature = "redact-generated-debug"), derive(Debug))]
#[derive(serde::Serialize)]
pub struct RetrieveCharge {
inner: RetrieveChargeBuilder,
charge: stripe_shared::ChargeId,
}
#[cfg(feature = "redact-generated-debug")]
impl std::fmt::Debug for RetrieveCharge {
fn fmt(&self, f: &mut std::fmt::Formatter) -> std::fmt::Result {
f.debug_struct("RetrieveCharge").finish_non_exhaustive()
}
}
impl RetrieveCharge {
pub fn new(charge: impl Into<stripe_shared::ChargeId>) -> Self {
Self { charge: charge.into(), inner: RetrieveChargeBuilder::new() }
}
pub fn expand(mut self, expand: impl Into<Vec<String>>) -> Self {
self.inner.expand = Some(expand.into());
self
}
}
impl RetrieveCharge {
pub async fn send<C: StripeClient>(
&self,
client: &C,
) -> Result<<Self as StripeRequest>::Output, C::Err> {
self.customize().send(client).await
}
pub fn send_blocking<C: StripeBlockingClient>(
&self,
client: &C,
) -> Result<<Self as StripeRequest>::Output, C::Err> {
self.customize().send_blocking(client)
}
}
impl StripeRequest for RetrieveCharge {
type Output = stripe_shared::Charge;
fn build(&self) -> RequestBuilder {
let charge = &self.charge;
RequestBuilder::new(StripeMethod::Get, format!("/charges/{charge}")).query(&self.inner)
}
}
#[derive(Clone, Eq, PartialEq)]
#[cfg_attr(not(feature = "redact-generated-debug"), derive(Debug))]
#[derive(serde::Serialize)]
struct SearchChargeBuilder {
#[serde(skip_serializing_if = "Option::is_none")]
expand: Option<Vec<String>>,
#[serde(skip_serializing_if = "Option::is_none")]
limit: Option<i64>,
#[serde(skip_serializing_if = "Option::is_none")]
page: Option<String>,
query: String,
}
#[cfg(feature = "redact-generated-debug")]
impl std::fmt::Debug for SearchChargeBuilder {
fn fmt(&self, f: &mut std::fmt::Formatter) -> std::fmt::Result {
f.debug_struct("SearchChargeBuilder").finish_non_exhaustive()
}
}
impl SearchChargeBuilder {
fn new(query: impl Into<String>) -> Self {
Self { expand: None, limit: None, page: None, query: query.into() }
}
}
#[derive(Clone)]
#[cfg_attr(not(feature = "redact-generated-debug"), derive(Debug))]
#[derive(serde::Serialize)]
pub struct SearchCharge {
inner: SearchChargeBuilder,
}
#[cfg(feature = "redact-generated-debug")]
impl std::fmt::Debug for SearchCharge {
fn fmt(&self, f: &mut std::fmt::Formatter) -> std::fmt::Result {
f.debug_struct("SearchCharge").finish_non_exhaustive()
}
}
impl SearchCharge {
pub fn new(query: impl Into<String>) -> Self {
Self { inner: SearchChargeBuilder::new(query.into()) }
}
pub fn expand(mut self, expand: impl Into<Vec<String>>) -> Self {
self.inner.expand = Some(expand.into());
self
}
pub fn limit(mut self, limit: impl Into<i64>) -> Self {
self.inner.limit = Some(limit.into());
self
}
pub fn page(mut self, page: impl Into<String>) -> Self {
self.inner.page = Some(page.into());
self
}
}
impl SearchCharge {
pub async fn send<C: StripeClient>(
&self,
client: &C,
) -> Result<<Self as StripeRequest>::Output, C::Err> {
self.customize().send(client).await
}
pub fn send_blocking<C: StripeBlockingClient>(
&self,
client: &C,
) -> Result<<Self as StripeRequest>::Output, C::Err> {
self.customize().send_blocking(client)
}
pub fn paginate(
&self,
) -> stripe_client_core::ListPaginator<stripe_types::SearchList<stripe_shared::Charge>> {
stripe_client_core::ListPaginator::new_search_list("/charges/search", &self.inner)
}
}
impl StripeRequest for SearchCharge {
type Output = stripe_types::SearchList<stripe_shared::Charge>;
fn build(&self) -> RequestBuilder {
RequestBuilder::new(StripeMethod::Get, "/charges/search").query(&self.inner)
}
}
#[derive(Clone)]
#[cfg_attr(not(feature = "redact-generated-debug"), derive(Debug))]
#[derive(serde::Serialize)]
struct CreateChargeBuilder {
#[serde(skip_serializing_if = "Option::is_none")]
amount: Option<i64>,
#[serde(skip_serializing_if = "Option::is_none")]
application_fee: Option<i64>,
#[serde(skip_serializing_if = "Option::is_none")]
application_fee_amount: Option<i64>,
#[serde(skip_serializing_if = "Option::is_none")]
capture: Option<bool>,
#[serde(skip_serializing_if = "Option::is_none")]
currency: Option<stripe_types::Currency>,
#[serde(skip_serializing_if = "Option::is_none")]
customer: Option<String>,
#[serde(skip_serializing_if = "Option::is_none")]
description: Option<String>,
#[serde(skip_serializing_if = "Option::is_none")]
destination: Option<CreateChargeDestination>,
#[serde(skip_serializing_if = "Option::is_none")]
expand: Option<Vec<String>>,
#[serde(skip_serializing_if = "Option::is_none")]
metadata: Option<std::collections::HashMap<String, String>>,
#[serde(skip_serializing_if = "Option::is_none")]
on_behalf_of: Option<String>,
#[serde(skip_serializing_if = "Option::is_none")]
radar_options: Option<CreateChargeRadarOptions>,
#[serde(skip_serializing_if = "Option::is_none")]
receipt_email: Option<String>,
#[serde(skip_serializing_if = "Option::is_none")]
shipping: Option<OptionalFieldsShipping>,
#[serde(skip_serializing_if = "Option::is_none")]
source: Option<String>,
#[serde(skip_serializing_if = "Option::is_none")]
statement_descriptor: Option<String>,
#[serde(skip_serializing_if = "Option::is_none")]
statement_descriptor_suffix: Option<String>,
#[serde(skip_serializing_if = "Option::is_none")]
transfer_data: Option<CreateChargeTransferData>,
#[serde(skip_serializing_if = "Option::is_none")]
transfer_group: Option<String>,
}
#[cfg(feature = "redact-generated-debug")]
impl std::fmt::Debug for CreateChargeBuilder {
fn fmt(&self, f: &mut std::fmt::Formatter) -> std::fmt::Result {
f.debug_struct("CreateChargeBuilder").finish_non_exhaustive()
}
}
impl CreateChargeBuilder {
fn new() -> Self {
Self {
amount: None,
application_fee: None,
application_fee_amount: None,
capture: None,
currency: None,
customer: None,
description: None,
destination: None,
expand: None,
metadata: None,
on_behalf_of: None,
radar_options: None,
receipt_email: None,
shipping: None,
source: None,
statement_descriptor: None,
statement_descriptor_suffix: None,
transfer_data: None,
transfer_group: None,
}
}
}
#[derive(Clone, Eq, PartialEq)]
#[cfg_attr(not(feature = "redact-generated-debug"), derive(Debug))]
#[derive(serde::Serialize)]
pub struct CreateChargeDestination {
pub account: String,
#[serde(skip_serializing_if = "Option::is_none")]
pub amount: Option<i64>,
}
#[cfg(feature = "redact-generated-debug")]
impl std::fmt::Debug for CreateChargeDestination {
fn fmt(&self, f: &mut std::fmt::Formatter) -> std::fmt::Result {
f.debug_struct("CreateChargeDestination").finish_non_exhaustive()
}
}
impl CreateChargeDestination {
pub fn new(account: impl Into<String>) -> Self {
Self { account: account.into(), amount: None }
}
}
#[derive(Clone, Eq, PartialEq)]
#[cfg_attr(not(feature = "redact-generated-debug"), derive(Debug))]
#[derive(serde::Serialize)]
pub struct CreateChargeRadarOptions {
#[serde(skip_serializing_if = "Option::is_none")]
pub session: Option<String>,
}
#[cfg(feature = "redact-generated-debug")]
impl std::fmt::Debug for CreateChargeRadarOptions {
fn fmt(&self, f: &mut std::fmt::Formatter) -> std::fmt::Result {
f.debug_struct("CreateChargeRadarOptions").finish_non_exhaustive()
}
}
impl CreateChargeRadarOptions {
pub fn new() -> Self {
Self { session: None }
}
}
impl Default for CreateChargeRadarOptions {
fn default() -> Self {
Self::new()
}
}
#[derive(Clone, Eq, PartialEq)]
#[cfg_attr(not(feature = "redact-generated-debug"), derive(Debug))]
#[derive(serde::Serialize)]
pub struct CreateChargeTransferData {
#[serde(skip_serializing_if = "Option::is_none")]
pub amount: Option<i64>,
pub destination: String,
}
#[cfg(feature = "redact-generated-debug")]
impl std::fmt::Debug for CreateChargeTransferData {
fn fmt(&self, f: &mut std::fmt::Formatter) -> std::fmt::Result {
f.debug_struct("CreateChargeTransferData").finish_non_exhaustive()
}
}
impl CreateChargeTransferData {
pub fn new(destination: impl Into<String>) -> Self {
Self { amount: None, destination: destination.into() }
}
}
#[derive(Clone)]
#[cfg_attr(not(feature = "redact-generated-debug"), derive(Debug))]
#[derive(serde::Serialize)]
pub struct CreateCharge {
inner: CreateChargeBuilder,
}
#[cfg(feature = "redact-generated-debug")]
impl std::fmt::Debug for CreateCharge {
fn fmt(&self, f: &mut std::fmt::Formatter) -> std::fmt::Result {
f.debug_struct("CreateCharge").finish_non_exhaustive()
}
}
impl CreateCharge {
pub fn new() -> Self {
Self { inner: CreateChargeBuilder::new() }
}
pub fn amount(mut self, amount: impl Into<i64>) -> Self {
self.inner.amount = Some(amount.into());
self
}
pub fn application_fee(mut self, application_fee: impl Into<i64>) -> Self {
self.inner.application_fee = Some(application_fee.into());
self
}
pub fn application_fee_amount(mut self, application_fee_amount: impl Into<i64>) -> Self {
self.inner.application_fee_amount = Some(application_fee_amount.into());
self
}
pub fn capture(mut self, capture: impl Into<bool>) -> Self {
self.inner.capture = Some(capture.into());
self
}
pub fn currency(mut self, currency: impl Into<stripe_types::Currency>) -> Self {
self.inner.currency = Some(currency.into());
self
}
pub fn customer(mut self, customer: impl Into<String>) -> Self {
self.inner.customer = Some(customer.into());
self
}
pub fn description(mut self, description: impl Into<String>) -> Self {
self.inner.description = Some(description.into());
self
}
pub fn destination(mut self, destination: impl Into<CreateChargeDestination>) -> Self {
self.inner.destination = Some(destination.into());
self
}
pub fn expand(mut self, expand: impl Into<Vec<String>>) -> Self {
self.inner.expand = Some(expand.into());
self
}
pub fn metadata(
mut self,
metadata: impl Into<std::collections::HashMap<String, String>>,
) -> Self {
self.inner.metadata = Some(metadata.into());
self
}
pub fn on_behalf_of(mut self, on_behalf_of: impl Into<String>) -> Self {
self.inner.on_behalf_of = Some(on_behalf_of.into());
self
}
pub fn radar_options(mut self, radar_options: impl Into<CreateChargeRadarOptions>) -> Self {
self.inner.radar_options = Some(radar_options.into());
self
}
pub fn receipt_email(mut self, receipt_email: impl Into<String>) -> Self {
self.inner.receipt_email = Some(receipt_email.into());
self
}
pub fn shipping(mut self, shipping: impl Into<OptionalFieldsShipping>) -> Self {
self.inner.shipping = Some(shipping.into());
self
}
pub fn source(mut self, source: impl Into<String>) -> Self {
self.inner.source = Some(source.into());
self
}
pub fn statement_descriptor(mut self, statement_descriptor: impl Into<String>) -> Self {
self.inner.statement_descriptor = Some(statement_descriptor.into());
self
}
pub fn statement_descriptor_suffix(
mut self,
statement_descriptor_suffix: impl Into<String>,
) -> Self {
self.inner.statement_descriptor_suffix = Some(statement_descriptor_suffix.into());
self
}
pub fn transfer_data(mut self, transfer_data: impl Into<CreateChargeTransferData>) -> Self {
self.inner.transfer_data = Some(transfer_data.into());
self
}
pub fn transfer_group(mut self, transfer_group: impl Into<String>) -> Self {
self.inner.transfer_group = Some(transfer_group.into());
self
}
}
impl Default for CreateCharge {
fn default() -> Self {
Self::new()
}
}
impl CreateCharge {
pub async fn send<C: StripeClient>(
&self,
client: &C,
) -> Result<<Self as StripeRequest>::Output, C::Err> {
self.customize().send(client).await
}
pub fn send_blocking<C: StripeBlockingClient>(
&self,
client: &C,
) -> Result<<Self as StripeRequest>::Output, C::Err> {
self.customize().send_blocking(client)
}
}
impl StripeRequest for CreateCharge {
type Output = stripe_shared::Charge;
fn build(&self) -> RequestBuilder {
RequestBuilder::new(StripeMethod::Post, "/charges").form(&self.inner)
}
}
#[derive(Clone)]
#[cfg_attr(not(feature = "redact-generated-debug"), derive(Debug))]
#[derive(serde::Serialize)]
struct UpdateChargeBuilder {
#[serde(skip_serializing_if = "Option::is_none")]
customer: Option<String>,
#[serde(skip_serializing_if = "Option::is_none")]
description: Option<String>,
#[serde(skip_serializing_if = "Option::is_none")]
expand: Option<Vec<String>>,
#[serde(skip_serializing_if = "Option::is_none")]
fraud_details: Option<UpdateChargeFraudDetails>,
#[serde(skip_serializing_if = "Option::is_none")]
metadata: Option<std::collections::HashMap<String, String>>,
#[serde(skip_serializing_if = "Option::is_none")]
receipt_email: Option<String>,
#[serde(skip_serializing_if = "Option::is_none")]
shipping: Option<OptionalFieldsShipping>,
#[serde(skip_serializing_if = "Option::is_none")]
transfer_group: Option<String>,
}
#[cfg(feature = "redact-generated-debug")]
impl std::fmt::Debug for UpdateChargeBuilder {
fn fmt(&self, f: &mut std::fmt::Formatter) -> std::fmt::Result {
f.debug_struct("UpdateChargeBuilder").finish_non_exhaustive()
}
}
impl UpdateChargeBuilder {
fn new() -> Self {
Self {
customer: None,
description: None,
expand: None,
fraud_details: None,
metadata: None,
receipt_email: None,
shipping: None,
transfer_group: None,
}
}
}
#[derive(Clone, Eq, PartialEq)]
#[cfg_attr(not(feature = "redact-generated-debug"), derive(Debug))]
#[derive(serde::Serialize)]
pub struct UpdateChargeFraudDetails {
pub user_report: UpdateChargeFraudDetailsUserReport,
}
#[cfg(feature = "redact-generated-debug")]
impl std::fmt::Debug for UpdateChargeFraudDetails {
fn fmt(&self, f: &mut std::fmt::Formatter) -> std::fmt::Result {
f.debug_struct("UpdateChargeFraudDetails").finish_non_exhaustive()
}
}
impl UpdateChargeFraudDetails {
pub fn new(user_report: impl Into<UpdateChargeFraudDetailsUserReport>) -> Self {
Self { user_report: user_report.into() }
}
}
#[derive(Clone, Eq, PartialEq)]
#[non_exhaustive]
pub enum UpdateChargeFraudDetailsUserReport {
Fraudulent,
Safe,
Unknown(String),
}
impl UpdateChargeFraudDetailsUserReport {
pub fn as_str(&self) -> &str {
use UpdateChargeFraudDetailsUserReport::*;
match self {
Fraudulent => "fraudulent",
Safe => "safe",
Unknown(v) => v,
}
}
}
impl std::str::FromStr for UpdateChargeFraudDetailsUserReport {
type Err = std::convert::Infallible;
fn from_str(s: &str) -> Result<Self, Self::Err> {
use UpdateChargeFraudDetailsUserReport::*;
match s {
"fraudulent" => Ok(Fraudulent),
"safe" => Ok(Safe),
v => {
tracing::warn!(
"Unknown value '{}' for enum '{}'",
v,
"UpdateChargeFraudDetailsUserReport"
);
Ok(Unknown(v.to_owned()))
}
}
}
}
impl std::fmt::Display for UpdateChargeFraudDetailsUserReport {
fn fmt(&self, f: &mut std::fmt::Formatter) -> std::fmt::Result {
f.write_str(self.as_str())
}
}
#[cfg(not(feature = "redact-generated-debug"))]
impl std::fmt::Debug for UpdateChargeFraudDetailsUserReport {
fn fmt(&self, f: &mut std::fmt::Formatter) -> std::fmt::Result {
f.write_str(self.as_str())
}
}
#[cfg(feature = "redact-generated-debug")]
impl std::fmt::Debug for UpdateChargeFraudDetailsUserReport {
fn fmt(&self, f: &mut std::fmt::Formatter) -> std::fmt::Result {
f.debug_struct(stringify!(UpdateChargeFraudDetailsUserReport)).finish_non_exhaustive()
}
}
impl serde::Serialize for UpdateChargeFraudDetailsUserReport {
fn serialize<S>(&self, serializer: S) -> Result<S::Ok, S::Error>
where
S: serde::Serializer,
{
serializer.serialize_str(self.as_str())
}
}
#[cfg(feature = "deserialize")]
impl<'de> serde::Deserialize<'de> for UpdateChargeFraudDetailsUserReport {
fn deserialize<D: serde::Deserializer<'de>>(deserializer: D) -> Result<Self, D::Error> {
use std::str::FromStr;
let s: std::borrow::Cow<'de, str> = serde::Deserialize::deserialize(deserializer)?;
Ok(Self::from_str(&s).expect("infallible"))
}
}
#[derive(Clone)]
#[cfg_attr(not(feature = "redact-generated-debug"), derive(Debug))]
#[derive(serde::Serialize)]
pub struct UpdateCharge {
inner: UpdateChargeBuilder,
charge: stripe_shared::ChargeId,
}
#[cfg(feature = "redact-generated-debug")]
impl std::fmt::Debug for UpdateCharge {
fn fmt(&self, f: &mut std::fmt::Formatter) -> std::fmt::Result {
f.debug_struct("UpdateCharge").finish_non_exhaustive()
}
}
impl UpdateCharge {
pub fn new(charge: impl Into<stripe_shared::ChargeId>) -> Self {
Self { charge: charge.into(), inner: UpdateChargeBuilder::new() }
}
pub fn customer(mut self, customer: impl Into<String>) -> Self {
self.inner.customer = Some(customer.into());
self
}
pub fn description(mut self, description: impl Into<String>) -> Self {
self.inner.description = Some(description.into());
self
}
pub fn expand(mut self, expand: impl Into<Vec<String>>) -> Self {
self.inner.expand = Some(expand.into());
self
}
pub fn fraud_details(mut self, fraud_details: impl Into<UpdateChargeFraudDetails>) -> Self {
self.inner.fraud_details = Some(fraud_details.into());
self
}
pub fn metadata(
mut self,
metadata: impl Into<std::collections::HashMap<String, String>>,
) -> Self {
self.inner.metadata = Some(metadata.into());
self
}
pub fn receipt_email(mut self, receipt_email: impl Into<String>) -> Self {
self.inner.receipt_email = Some(receipt_email.into());
self
}
pub fn shipping(mut self, shipping: impl Into<OptionalFieldsShipping>) -> Self {
self.inner.shipping = Some(shipping.into());
self
}
pub fn transfer_group(mut self, transfer_group: impl Into<String>) -> Self {
self.inner.transfer_group = Some(transfer_group.into());
self
}
}
impl UpdateCharge {
pub async fn send<C: StripeClient>(
&self,
client: &C,
) -> Result<<Self as StripeRequest>::Output, C::Err> {
self.customize().send(client).await
}
pub fn send_blocking<C: StripeBlockingClient>(
&self,
client: &C,
) -> Result<<Self as StripeRequest>::Output, C::Err> {
self.customize().send_blocking(client)
}
}
impl StripeRequest for UpdateCharge {
type Output = stripe_shared::Charge;
fn build(&self) -> RequestBuilder {
let charge = &self.charge;
RequestBuilder::new(StripeMethod::Post, format!("/charges/{charge}")).form(&self.inner)
}
}
#[derive(Clone, Eq, PartialEq)]
#[cfg_attr(not(feature = "redact-generated-debug"), derive(Debug))]
#[derive(serde::Serialize)]
struct CaptureChargeBuilder {
#[serde(skip_serializing_if = "Option::is_none")]
amount: Option<i64>,
#[serde(skip_serializing_if = "Option::is_none")]
application_fee: Option<i64>,
#[serde(skip_serializing_if = "Option::is_none")]
application_fee_amount: Option<i64>,
#[serde(skip_serializing_if = "Option::is_none")]
expand: Option<Vec<String>>,
#[serde(skip_serializing_if = "Option::is_none")]
receipt_email: Option<String>,
#[serde(skip_serializing_if = "Option::is_none")]
statement_descriptor: Option<String>,
#[serde(skip_serializing_if = "Option::is_none")]
statement_descriptor_suffix: Option<String>,
#[serde(skip_serializing_if = "Option::is_none")]
transfer_data: Option<CaptureChargeTransferData>,
#[serde(skip_serializing_if = "Option::is_none")]
transfer_group: Option<String>,
}
#[cfg(feature = "redact-generated-debug")]
impl std::fmt::Debug for CaptureChargeBuilder {
fn fmt(&self, f: &mut std::fmt::Formatter) -> std::fmt::Result {
f.debug_struct("CaptureChargeBuilder").finish_non_exhaustive()
}
}
impl CaptureChargeBuilder {
fn new() -> Self {
Self {
amount: None,
application_fee: None,
application_fee_amount: None,
expand: None,
receipt_email: None,
statement_descriptor: None,
statement_descriptor_suffix: None,
transfer_data: None,
transfer_group: None,
}
}
}
#[derive(Copy, Clone, Eq, PartialEq)]
#[cfg_attr(not(feature = "redact-generated-debug"), derive(Debug))]
#[derive(serde::Serialize)]
pub struct CaptureChargeTransferData {
#[serde(skip_serializing_if = "Option::is_none")]
pub amount: Option<i64>,
}
#[cfg(feature = "redact-generated-debug")]
impl std::fmt::Debug for CaptureChargeTransferData {
fn fmt(&self, f: &mut std::fmt::Formatter) -> std::fmt::Result {
f.debug_struct("CaptureChargeTransferData").finish_non_exhaustive()
}
}
impl CaptureChargeTransferData {
pub fn new() -> Self {
Self { amount: None }
}
}
impl Default for CaptureChargeTransferData {
fn default() -> Self {
Self::new()
}
}
#[derive(Clone)]
#[cfg_attr(not(feature = "redact-generated-debug"), derive(Debug))]
#[derive(serde::Serialize)]
pub struct CaptureCharge {
inner: CaptureChargeBuilder,
charge: stripe_shared::ChargeId,
}
#[cfg(feature = "redact-generated-debug")]
impl std::fmt::Debug for CaptureCharge {
fn fmt(&self, f: &mut std::fmt::Formatter) -> std::fmt::Result {
f.debug_struct("CaptureCharge").finish_non_exhaustive()
}
}
impl CaptureCharge {
pub fn new(charge: impl Into<stripe_shared::ChargeId>) -> Self {
Self { charge: charge.into(), inner: CaptureChargeBuilder::new() }
}
pub fn amount(mut self, amount: impl Into<i64>) -> Self {
self.inner.amount = Some(amount.into());
self
}
pub fn application_fee(mut self, application_fee: impl Into<i64>) -> Self {
self.inner.application_fee = Some(application_fee.into());
self
}
pub fn application_fee_amount(mut self, application_fee_amount: impl Into<i64>) -> Self {
self.inner.application_fee_amount = Some(application_fee_amount.into());
self
}
pub fn expand(mut self, expand: impl Into<Vec<String>>) -> Self {
self.inner.expand = Some(expand.into());
self
}
pub fn receipt_email(mut self, receipt_email: impl Into<String>) -> Self {
self.inner.receipt_email = Some(receipt_email.into());
self
}
pub fn statement_descriptor(mut self, statement_descriptor: impl Into<String>) -> Self {
self.inner.statement_descriptor = Some(statement_descriptor.into());
self
}
pub fn statement_descriptor_suffix(
mut self,
statement_descriptor_suffix: impl Into<String>,
) -> Self {
self.inner.statement_descriptor_suffix = Some(statement_descriptor_suffix.into());
self
}
pub fn transfer_data(mut self, transfer_data: impl Into<CaptureChargeTransferData>) -> Self {
self.inner.transfer_data = Some(transfer_data.into());
self
}
pub fn transfer_group(mut self, transfer_group: impl Into<String>) -> Self {
self.inner.transfer_group = Some(transfer_group.into());
self
}
}
impl CaptureCharge {
pub async fn send<C: StripeClient>(
&self,
client: &C,
) -> Result<<Self as StripeRequest>::Output, C::Err> {
self.customize().send(client).await
}
pub fn send_blocking<C: StripeBlockingClient>(
&self,
client: &C,
) -> Result<<Self as StripeRequest>::Output, C::Err> {
self.customize().send_blocking(client)
}
}
impl StripeRequest for CaptureCharge {
type Output = stripe_shared::Charge;
fn build(&self) -> RequestBuilder {
let charge = &self.charge;
RequestBuilder::new(StripeMethod::Post, format!("/charges/{charge}/capture"))
.form(&self.inner)
}
}
#[derive(Clone, Eq, PartialEq)]
#[cfg_attr(not(feature = "redact-generated-debug"), derive(Debug))]
#[derive(serde::Serialize)]
pub struct OptionalFieldsAddress {
#[serde(skip_serializing_if = "Option::is_none")]
pub city: Option<String>,
#[serde(skip_serializing_if = "Option::is_none")]
pub country: Option<String>,
#[serde(skip_serializing_if = "Option::is_none")]
pub line1: Option<String>,
#[serde(skip_serializing_if = "Option::is_none")]
pub line2: Option<String>,
#[serde(skip_serializing_if = "Option::is_none")]
pub postal_code: Option<String>,
#[serde(skip_serializing_if = "Option::is_none")]
pub state: Option<String>,
}
#[cfg(feature = "redact-generated-debug")]
impl std::fmt::Debug for OptionalFieldsAddress {
fn fmt(&self, f: &mut std::fmt::Formatter) -> std::fmt::Result {
f.debug_struct("OptionalFieldsAddress").finish_non_exhaustive()
}
}
impl OptionalFieldsAddress {
pub fn new() -> Self {
Self { city: None, country: None, line1: None, line2: None, postal_code: None, state: None }
}
}
impl Default for OptionalFieldsAddress {
fn default() -> Self {
Self::new()
}
}
#[derive(Clone, Eq, PartialEq)]
#[cfg_attr(not(feature = "redact-generated-debug"), derive(Debug))]
#[derive(serde::Serialize)]
pub struct OptionalFieldsShipping {
pub address: OptionalFieldsAddress,
#[serde(skip_serializing_if = "Option::is_none")]
pub carrier: Option<String>,
pub name: String,
#[serde(skip_serializing_if = "Option::is_none")]
pub phone: Option<String>,
#[serde(skip_serializing_if = "Option::is_none")]
pub tracking_number: Option<String>,
}
#[cfg(feature = "redact-generated-debug")]
impl std::fmt::Debug for OptionalFieldsShipping {
fn fmt(&self, f: &mut std::fmt::Formatter) -> std::fmt::Result {
f.debug_struct("OptionalFieldsShipping").finish_non_exhaustive()
}
}
impl OptionalFieldsShipping {
pub fn new(address: impl Into<OptionalFieldsAddress>, name: impl Into<String>) -> Self {
Self {
address: address.into(),
carrier: None,
name: name.into(),
phone: None,
tracking_number: None,
}
}
}