#[derive(Clone)]
#[cfg_attr(not(feature = "redact-generated-debug"), derive(Debug))]
#[cfg_attr(feature = "deserialize", derive(serde::Deserialize))]
pub struct Customer {
pub address: Option<stripe_shared::Address>,
pub balance: Option<i64>,
pub business_name: Option<String>,
pub cash_balance: Option<stripe_shared::CashBalance>,
pub created: stripe_types::Timestamp,
pub currency: Option<stripe_types::Currency>,
pub customer_account: Option<String>,
pub default_source: Option<stripe_types::Expandable<stripe_shared::PaymentSource>>,
pub delinquent: Option<bool>,
pub description: Option<String>,
pub discount: Option<stripe_shared::Discount>,
pub email: Option<String>,
pub id: stripe_shared::CustomerId,
pub individual_name: Option<String>,
pub invoice_credit_balance: Option<std::collections::HashMap<String, i64>>,
pub invoice_prefix: Option<String>,
pub invoice_settings: Option<stripe_shared::InvoiceSettingCustomerSetting>,
pub livemode: bool,
pub metadata: Option<std::collections::HashMap<String, String>>,
pub name: Option<String>,
pub next_invoice_sequence: Option<i64>,
pub phone: Option<String>,
pub preferred_locales: Option<Vec<String>>,
pub shipping: Option<stripe_shared::Shipping>,
pub sources: Option<stripe_types::List<stripe_shared::PaymentSource>>,
pub subscriptions: Option<stripe_types::List<stripe_shared::Subscription>>,
pub tax: Option<stripe_shared::CustomerTax>,
pub tax_exempt: Option<stripe_shared::CustomerTaxExempt>,
pub tax_ids: Option<stripe_types::List<stripe_shared::TaxId>>,
pub test_clock: Option<stripe_types::Expandable<stripe_shared::TestHelpersTestClock>>,
}
#[cfg(feature = "redact-generated-debug")]
impl std::fmt::Debug for Customer {
fn fmt(&self, f: &mut std::fmt::Formatter) -> std::fmt::Result {
f.debug_struct("Customer").finish_non_exhaustive()
}
}
#[doc(hidden)]
pub struct CustomerBuilder {
address: Option<Option<stripe_shared::Address>>,
balance: Option<Option<i64>>,
business_name: Option<Option<String>>,
cash_balance: Option<Option<stripe_shared::CashBalance>>,
created: Option<stripe_types::Timestamp>,
currency: Option<Option<stripe_types::Currency>>,
customer_account: Option<Option<String>>,
default_source: Option<Option<stripe_types::Expandable<stripe_shared::PaymentSource>>>,
delinquent: Option<Option<bool>>,
description: Option<Option<String>>,
discount: Option<Option<stripe_shared::Discount>>,
email: Option<Option<String>>,
id: Option<stripe_shared::CustomerId>,
individual_name: Option<Option<String>>,
invoice_credit_balance: Option<Option<std::collections::HashMap<String, i64>>>,
invoice_prefix: Option<Option<String>>,
invoice_settings: Option<Option<stripe_shared::InvoiceSettingCustomerSetting>>,
livemode: Option<bool>,
metadata: Option<Option<std::collections::HashMap<String, String>>>,
name: Option<Option<String>>,
next_invoice_sequence: Option<Option<i64>>,
phone: Option<Option<String>>,
preferred_locales: Option<Option<Vec<String>>>,
shipping: Option<Option<stripe_shared::Shipping>>,
sources: Option<Option<stripe_types::List<stripe_shared::PaymentSource>>>,
subscriptions: Option<Option<stripe_types::List<stripe_shared::Subscription>>>,
tax: Option<Option<stripe_shared::CustomerTax>>,
tax_exempt: Option<Option<stripe_shared::CustomerTaxExempt>>,
tax_ids: Option<Option<stripe_types::List<stripe_shared::TaxId>>>,
test_clock: Option<Option<stripe_types::Expandable<stripe_shared::TestHelpersTestClock>>>,
}
#[allow(
unused_variables,
irrefutable_let_patterns,
clippy::let_unit_value,
clippy::match_single_binding,
clippy::single_match
)]
const _: () = {
use miniserde::de::{Map, Visitor};
use miniserde::json::Value;
use miniserde::{Deserialize, Result, make_place};
use stripe_types::miniserde_helpers::FromValueOpt;
use stripe_types::{MapBuilder, ObjectDeser};
make_place!(Place);
impl Deserialize for Customer {
fn begin(out: &mut Option<Self>) -> &mut dyn Visitor {
Place::new(out)
}
}
struct Builder<'a> {
out: &'a mut Option<Customer>,
builder: CustomerBuilder,
}
impl Visitor for Place<Customer> {
fn map(&mut self) -> Result<Box<dyn Map + '_>> {
Ok(Box::new(Builder { out: &mut self.out, builder: CustomerBuilder::deser_default() }))
}
}
impl MapBuilder for CustomerBuilder {
type Out = Customer;
fn key(&mut self, k: &str) -> Result<&mut dyn Visitor> {
Ok(match k {
"address" => Deserialize::begin(&mut self.address),
"balance" => Deserialize::begin(&mut self.balance),
"business_name" => Deserialize::begin(&mut self.business_name),
"cash_balance" => Deserialize::begin(&mut self.cash_balance),
"created" => Deserialize::begin(&mut self.created),
"currency" => Deserialize::begin(&mut self.currency),
"customer_account" => Deserialize::begin(&mut self.customer_account),
"default_source" => Deserialize::begin(&mut self.default_source),
"delinquent" => Deserialize::begin(&mut self.delinquent),
"description" => Deserialize::begin(&mut self.description),
"discount" => Deserialize::begin(&mut self.discount),
"email" => Deserialize::begin(&mut self.email),
"id" => Deserialize::begin(&mut self.id),
"individual_name" => Deserialize::begin(&mut self.individual_name),
"invoice_credit_balance" => Deserialize::begin(&mut self.invoice_credit_balance),
"invoice_prefix" => Deserialize::begin(&mut self.invoice_prefix),
"invoice_settings" => Deserialize::begin(&mut self.invoice_settings),
"livemode" => Deserialize::begin(&mut self.livemode),
"metadata" => Deserialize::begin(&mut self.metadata),
"name" => Deserialize::begin(&mut self.name),
"next_invoice_sequence" => Deserialize::begin(&mut self.next_invoice_sequence),
"phone" => Deserialize::begin(&mut self.phone),
"preferred_locales" => Deserialize::begin(&mut self.preferred_locales),
"shipping" => Deserialize::begin(&mut self.shipping),
"sources" => Deserialize::begin(&mut self.sources),
"subscriptions" => Deserialize::begin(&mut self.subscriptions),
"tax" => Deserialize::begin(&mut self.tax),
"tax_exempt" => Deserialize::begin(&mut self.tax_exempt),
"tax_ids" => Deserialize::begin(&mut self.tax_ids),
"test_clock" => Deserialize::begin(&mut self.test_clock),
_ => <dyn Visitor>::ignore(),
})
}
fn deser_default() -> Self {
Self {
address: Some(None),
balance: Some(None),
business_name: Some(None),
cash_balance: Some(None),
created: None,
currency: Some(None),
customer_account: Some(None),
default_source: Some(None),
delinquent: Some(None),
description: Some(None),
discount: Some(None),
email: Some(None),
id: None,
individual_name: Some(None),
invoice_credit_balance: Some(None),
invoice_prefix: Some(None),
invoice_settings: Some(None),
livemode: None,
metadata: Some(None),
name: Some(None),
next_invoice_sequence: Some(None),
phone: Some(None),
preferred_locales: Some(None),
shipping: Some(None),
sources: Some(None),
subscriptions: Some(None),
tax: Some(None),
tax_exempt: Some(None),
tax_ids: Some(None),
test_clock: Some(None),
}
}
fn take_out(&mut self) -> Option<Self::Out> {
let (
Some(address),
Some(balance),
Some(business_name),
Some(cash_balance),
Some(created),
Some(currency),
Some(customer_account),
Some(default_source),
Some(delinquent),
Some(description),
Some(discount),
Some(email),
Some(id),
Some(individual_name),
Some(invoice_credit_balance),
Some(invoice_prefix),
Some(invoice_settings),
Some(livemode),
Some(metadata),
Some(name),
Some(next_invoice_sequence),
Some(phone),
Some(preferred_locales),
Some(shipping),
Some(sources),
Some(subscriptions),
Some(tax),
Some(tax_exempt),
Some(tax_ids),
Some(test_clock),
) = (
self.address.take(),
self.balance,
self.business_name.take(),
self.cash_balance.take(),
self.created,
self.currency.take(),
self.customer_account.take(),
self.default_source.take(),
self.delinquent,
self.description.take(),
self.discount.take(),
self.email.take(),
self.id.take(),
self.individual_name.take(),
self.invoice_credit_balance.take(),
self.invoice_prefix.take(),
self.invoice_settings.take(),
self.livemode,
self.metadata.take(),
self.name.take(),
self.next_invoice_sequence,
self.phone.take(),
self.preferred_locales.take(),
self.shipping.take(),
self.sources.take(),
self.subscriptions.take(),
self.tax.take(),
self.tax_exempt.take(),
self.tax_ids.take(),
self.test_clock.take(),
)
else {
return None;
};
Some(Self::Out {
address,
balance,
business_name,
cash_balance,
created,
currency,
customer_account,
default_source,
delinquent,
description,
discount,
email,
id,
individual_name,
invoice_credit_balance,
invoice_prefix,
invoice_settings,
livemode,
metadata,
name,
next_invoice_sequence,
phone,
preferred_locales,
shipping,
sources,
subscriptions,
tax,
tax_exempt,
tax_ids,
test_clock,
})
}
}
impl Map for Builder<'_> {
fn key(&mut self, k: &str) -> Result<&mut dyn Visitor> {
self.builder.key(k)
}
fn finish(&mut self) -> Result<()> {
*self.out = self.builder.take_out();
Ok(())
}
}
impl ObjectDeser for Customer {
type Builder = CustomerBuilder;
}
impl FromValueOpt for Customer {
fn from_value(v: Value) -> Option<Self> {
let Value::Object(obj) = v else {
return None;
};
let mut b = CustomerBuilder::deser_default();
for (k, v) in obj {
match k.as_str() {
"address" => b.address = FromValueOpt::from_value(v),
"balance" => b.balance = FromValueOpt::from_value(v),
"business_name" => b.business_name = FromValueOpt::from_value(v),
"cash_balance" => b.cash_balance = FromValueOpt::from_value(v),
"created" => b.created = FromValueOpt::from_value(v),
"currency" => b.currency = FromValueOpt::from_value(v),
"customer_account" => b.customer_account = FromValueOpt::from_value(v),
"default_source" => b.default_source = FromValueOpt::from_value(v),
"delinquent" => b.delinquent = FromValueOpt::from_value(v),
"description" => b.description = FromValueOpt::from_value(v),
"discount" => b.discount = FromValueOpt::from_value(v),
"email" => b.email = FromValueOpt::from_value(v),
"id" => b.id = FromValueOpt::from_value(v),
"individual_name" => b.individual_name = FromValueOpt::from_value(v),
"invoice_credit_balance" => {
b.invoice_credit_balance = FromValueOpt::from_value(v)
}
"invoice_prefix" => b.invoice_prefix = FromValueOpt::from_value(v),
"invoice_settings" => b.invoice_settings = FromValueOpt::from_value(v),
"livemode" => b.livemode = FromValueOpt::from_value(v),
"metadata" => b.metadata = FromValueOpt::from_value(v),
"name" => b.name = FromValueOpt::from_value(v),
"next_invoice_sequence" => {
b.next_invoice_sequence = FromValueOpt::from_value(v)
}
"phone" => b.phone = FromValueOpt::from_value(v),
"preferred_locales" => b.preferred_locales = FromValueOpt::from_value(v),
"shipping" => b.shipping = FromValueOpt::from_value(v),
"sources" => b.sources = FromValueOpt::from_value(v),
"subscriptions" => b.subscriptions = FromValueOpt::from_value(v),
"tax" => b.tax = FromValueOpt::from_value(v),
"tax_exempt" => b.tax_exempt = FromValueOpt::from_value(v),
"tax_ids" => b.tax_ids = FromValueOpt::from_value(v),
"test_clock" => b.test_clock = FromValueOpt::from_value(v),
_ => {}
}
}
b.take_out()
}
}
};
#[cfg(feature = "serialize")]
impl serde::Serialize for Customer {
fn serialize<S: serde::Serializer>(&self, s: S) -> Result<S::Ok, S::Error> {
use serde::ser::SerializeStruct;
let mut s = s.serialize_struct("Customer", 31)?;
s.serialize_field("address", &self.address)?;
s.serialize_field("balance", &self.balance)?;
s.serialize_field("business_name", &self.business_name)?;
s.serialize_field("cash_balance", &self.cash_balance)?;
s.serialize_field("created", &self.created)?;
s.serialize_field("currency", &self.currency)?;
s.serialize_field("customer_account", &self.customer_account)?;
s.serialize_field("default_source", &self.default_source)?;
s.serialize_field("delinquent", &self.delinquent)?;
s.serialize_field("description", &self.description)?;
s.serialize_field("discount", &self.discount)?;
s.serialize_field("email", &self.email)?;
s.serialize_field("id", &self.id)?;
s.serialize_field("individual_name", &self.individual_name)?;
s.serialize_field("invoice_credit_balance", &self.invoice_credit_balance)?;
s.serialize_field("invoice_prefix", &self.invoice_prefix)?;
s.serialize_field("invoice_settings", &self.invoice_settings)?;
s.serialize_field("livemode", &self.livemode)?;
s.serialize_field("metadata", &self.metadata)?;
s.serialize_field("name", &self.name)?;
s.serialize_field("next_invoice_sequence", &self.next_invoice_sequence)?;
s.serialize_field("phone", &self.phone)?;
s.serialize_field("preferred_locales", &self.preferred_locales)?;
s.serialize_field("shipping", &self.shipping)?;
s.serialize_field("sources", &self.sources)?;
s.serialize_field("subscriptions", &self.subscriptions)?;
s.serialize_field("tax", &self.tax)?;
s.serialize_field("tax_exempt", &self.tax_exempt)?;
s.serialize_field("tax_ids", &self.tax_ids)?;
s.serialize_field("test_clock", &self.test_clock)?;
s.serialize_field("object", "customer")?;
s.end()
}
}
impl stripe_types::Object for Customer {
type Id = stripe_shared::CustomerId;
fn id(&self) -> &Self::Id {
&self.id
}
fn into_id(self) -> Self::Id {
self.id
}
}
stripe_types::def_id!(CustomerId);
#[derive(Clone, Eq, PartialEq)]
#[non_exhaustive]
pub enum CustomerTaxExempt {
Exempt,
None,
Reverse,
Unknown(String),
}
impl CustomerTaxExempt {
pub fn as_str(&self) -> &str {
use CustomerTaxExempt::*;
match self {
Exempt => "exempt",
None => "none",
Reverse => "reverse",
Unknown(v) => v,
}
}
}
impl std::str::FromStr for CustomerTaxExempt {
type Err = std::convert::Infallible;
fn from_str(s: &str) -> Result<Self, Self::Err> {
use CustomerTaxExempt::*;
match s {
"exempt" => Ok(Exempt),
"none" => Ok(None),
"reverse" => Ok(Reverse),
v => {
tracing::warn!("Unknown value '{}' for enum '{}'", v, "CustomerTaxExempt");
Ok(Unknown(v.to_owned()))
}
}
}
}
impl std::fmt::Display for CustomerTaxExempt {
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 CustomerTaxExempt {
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 CustomerTaxExempt {
fn fmt(&self, f: &mut std::fmt::Formatter) -> std::fmt::Result {
f.debug_struct(stringify!(CustomerTaxExempt)).finish_non_exhaustive()
}
}
impl serde::Serialize for CustomerTaxExempt {
fn serialize<S>(&self, serializer: S) -> Result<S::Ok, S::Error>
where
S: serde::Serializer,
{
serializer.serialize_str(self.as_str())
}
}
impl miniserde::Deserialize for CustomerTaxExempt {
fn begin(out: &mut Option<Self>) -> &mut dyn miniserde::de::Visitor {
crate::Place::new(out)
}
}
impl miniserde::de::Visitor for crate::Place<CustomerTaxExempt> {
fn string(&mut self, s: &str) -> miniserde::Result<()> {
use std::str::FromStr;
self.out = Some(CustomerTaxExempt::from_str(s).expect("infallible"));
Ok(())
}
}
stripe_types::impl_from_val_with_from_str!(CustomerTaxExempt);
#[cfg(feature = "deserialize")]
impl<'de> serde::Deserialize<'de> for CustomerTaxExempt {
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"))
}
}