#[derive(Clone)]
#[cfg_attr(not(feature = "redact-generated-debug"), derive(Debug))]
#[cfg_attr(feature = "deserialize", derive(serde::Deserialize))]
pub struct Source {
pub ach_credit_transfer: Option<stripe_shared::SourceTypeAchCreditTransfer>,
pub ach_debit: Option<stripe_shared::SourceTypeAchDebit>,
pub acss_debit: Option<stripe_shared::SourceTypeAcssDebit>,
pub alipay: Option<stripe_shared::SourceTypeAlipay>,
pub allow_redisplay: Option<SourceAllowRedisplay>,
pub amount: Option<i64>,
pub au_becs_debit: Option<stripe_shared::SourceTypeAuBecsDebit>,
pub bancontact: Option<stripe_shared::SourceTypeBancontact>,
pub card: Option<stripe_shared::SourceTypeCard>,
pub card_present: Option<stripe_shared::SourceTypeCardPresent>,
pub client_secret: String,
pub code_verification: Option<stripe_shared::SourceCodeVerificationFlow>,
pub created: stripe_types::Timestamp,
pub currency: Option<stripe_types::Currency>,
pub customer: Option<String>,
pub eps: Option<stripe_shared::SourceTypeEps>,
pub flow: String,
pub giropay: Option<stripe_shared::SourceTypeGiropay>,
pub id: stripe_shared::SourceId,
pub ideal: Option<stripe_shared::SourceTypeIdeal>,
pub klarna: Option<stripe_shared::SourceTypeKlarna>,
pub livemode: bool,
pub metadata: Option<std::collections::HashMap<String, String>>,
pub multibanco: Option<stripe_shared::SourceTypeMultibanco>,
pub owner: Option<stripe_shared::SourceOwner>,
pub p24: Option<stripe_shared::SourceTypeP24>,
pub receiver: Option<stripe_shared::SourceReceiverFlow>,
pub redirect: Option<stripe_shared::SourceRedirectFlow>,
pub sepa_credit_transfer: Option<stripe_shared::SourceTypeSepaCreditTransfer>,
pub sepa_debit: Option<stripe_shared::SourceTypeSepaDebit>,
pub sofort: Option<stripe_shared::SourceTypeSofort>,
pub source_order: Option<stripe_shared::SourceOrder>,
pub statement_descriptor: Option<String>,
pub status: String,
pub three_d_secure: Option<stripe_shared::SourceTypeThreeDSecure>,
#[cfg_attr(feature = "deserialize", serde(rename = "type"))]
pub type_: SourceType,
pub usage: Option<String>,
pub wechat: Option<stripe_shared::SourceTypeWechat>,
}
#[cfg(feature = "redact-generated-debug")]
impl std::fmt::Debug for Source {
fn fmt(&self, f: &mut std::fmt::Formatter) -> std::fmt::Result {
f.debug_struct("Source").finish_non_exhaustive()
}
}
#[doc(hidden)]
pub struct SourceBuilder {
ach_credit_transfer: Option<Option<stripe_shared::SourceTypeAchCreditTransfer>>,
ach_debit: Option<Option<stripe_shared::SourceTypeAchDebit>>,
acss_debit: Option<Option<stripe_shared::SourceTypeAcssDebit>>,
alipay: Option<Option<stripe_shared::SourceTypeAlipay>>,
allow_redisplay: Option<Option<SourceAllowRedisplay>>,
amount: Option<Option<i64>>,
au_becs_debit: Option<Option<stripe_shared::SourceTypeAuBecsDebit>>,
bancontact: Option<Option<stripe_shared::SourceTypeBancontact>>,
card: Option<Option<stripe_shared::SourceTypeCard>>,
card_present: Option<Option<stripe_shared::SourceTypeCardPresent>>,
client_secret: Option<String>,
code_verification: Option<Option<stripe_shared::SourceCodeVerificationFlow>>,
created: Option<stripe_types::Timestamp>,
currency: Option<Option<stripe_types::Currency>>,
customer: Option<Option<String>>,
eps: Option<Option<stripe_shared::SourceTypeEps>>,
flow: Option<String>,
giropay: Option<Option<stripe_shared::SourceTypeGiropay>>,
id: Option<stripe_shared::SourceId>,
ideal: Option<Option<stripe_shared::SourceTypeIdeal>>,
klarna: Option<Option<stripe_shared::SourceTypeKlarna>>,
livemode: Option<bool>,
metadata: Option<Option<std::collections::HashMap<String, String>>>,
multibanco: Option<Option<stripe_shared::SourceTypeMultibanco>>,
owner: Option<Option<stripe_shared::SourceOwner>>,
p24: Option<Option<stripe_shared::SourceTypeP24>>,
receiver: Option<Option<stripe_shared::SourceReceiverFlow>>,
redirect: Option<Option<stripe_shared::SourceRedirectFlow>>,
sepa_credit_transfer: Option<Option<stripe_shared::SourceTypeSepaCreditTransfer>>,
sepa_debit: Option<Option<stripe_shared::SourceTypeSepaDebit>>,
sofort: Option<Option<stripe_shared::SourceTypeSofort>>,
source_order: Option<Option<stripe_shared::SourceOrder>>,
statement_descriptor: Option<Option<String>>,
status: Option<String>,
three_d_secure: Option<Option<stripe_shared::SourceTypeThreeDSecure>>,
type_: Option<SourceType>,
usage: Option<Option<String>>,
wechat: Option<Option<stripe_shared::SourceTypeWechat>>,
}
#[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 Source {
fn begin(out: &mut Option<Self>) -> &mut dyn Visitor {
Place::new(out)
}
}
struct Builder<'a> {
out: &'a mut Option<Source>,
builder: SourceBuilder,
}
impl Visitor for Place<Source> {
fn map(&mut self) -> Result<Box<dyn Map + '_>> {
Ok(Box::new(Builder { out: &mut self.out, builder: SourceBuilder::deser_default() }))
}
}
impl MapBuilder for SourceBuilder {
type Out = Source;
fn key(&mut self, k: &str) -> Result<&mut dyn Visitor> {
Ok(match k {
"ach_credit_transfer" => Deserialize::begin(&mut self.ach_credit_transfer),
"ach_debit" => Deserialize::begin(&mut self.ach_debit),
"acss_debit" => Deserialize::begin(&mut self.acss_debit),
"alipay" => Deserialize::begin(&mut self.alipay),
"allow_redisplay" => Deserialize::begin(&mut self.allow_redisplay),
"amount" => Deserialize::begin(&mut self.amount),
"au_becs_debit" => Deserialize::begin(&mut self.au_becs_debit),
"bancontact" => Deserialize::begin(&mut self.bancontact),
"card" => Deserialize::begin(&mut self.card),
"card_present" => Deserialize::begin(&mut self.card_present),
"client_secret" => Deserialize::begin(&mut self.client_secret),
"code_verification" => Deserialize::begin(&mut self.code_verification),
"created" => Deserialize::begin(&mut self.created),
"currency" => Deserialize::begin(&mut self.currency),
"customer" => Deserialize::begin(&mut self.customer),
"eps" => Deserialize::begin(&mut self.eps),
"flow" => Deserialize::begin(&mut self.flow),
"giropay" => Deserialize::begin(&mut self.giropay),
"id" => Deserialize::begin(&mut self.id),
"ideal" => Deserialize::begin(&mut self.ideal),
"klarna" => Deserialize::begin(&mut self.klarna),
"livemode" => Deserialize::begin(&mut self.livemode),
"metadata" => Deserialize::begin(&mut self.metadata),
"multibanco" => Deserialize::begin(&mut self.multibanco),
"owner" => Deserialize::begin(&mut self.owner),
"p24" => Deserialize::begin(&mut self.p24),
"receiver" => Deserialize::begin(&mut self.receiver),
"redirect" => Deserialize::begin(&mut self.redirect),
"sepa_credit_transfer" => Deserialize::begin(&mut self.sepa_credit_transfer),
"sepa_debit" => Deserialize::begin(&mut self.sepa_debit),
"sofort" => Deserialize::begin(&mut self.sofort),
"source_order" => Deserialize::begin(&mut self.source_order),
"statement_descriptor" => Deserialize::begin(&mut self.statement_descriptor),
"status" => Deserialize::begin(&mut self.status),
"three_d_secure" => Deserialize::begin(&mut self.three_d_secure),
"type" => Deserialize::begin(&mut self.type_),
"usage" => Deserialize::begin(&mut self.usage),
"wechat" => Deserialize::begin(&mut self.wechat),
_ => <dyn Visitor>::ignore(),
})
}
fn deser_default() -> Self {
Self {
ach_credit_transfer: Some(None),
ach_debit: Some(None),
acss_debit: Some(None),
alipay: Some(None),
allow_redisplay: Some(None),
amount: Some(None),
au_becs_debit: Some(None),
bancontact: Some(None),
card: Some(None),
card_present: Some(None),
client_secret: None,
code_verification: Some(None),
created: None,
currency: Some(None),
customer: Some(None),
eps: Some(None),
flow: None,
giropay: Some(None),
id: None,
ideal: Some(None),
klarna: Some(None),
livemode: None,
metadata: Some(None),
multibanco: Some(None),
owner: Some(None),
p24: Some(None),
receiver: Some(None),
redirect: Some(None),
sepa_credit_transfer: Some(None),
sepa_debit: Some(None),
sofort: Some(None),
source_order: Some(None),
statement_descriptor: Some(None),
status: None,
three_d_secure: Some(None),
type_: None,
usage: Some(None),
wechat: Some(None),
}
}
fn take_out(&mut self) -> Option<Self::Out> {
let (
Some(ach_credit_transfer),
Some(ach_debit),
Some(acss_debit),
Some(alipay),
Some(allow_redisplay),
Some(amount),
Some(au_becs_debit),
Some(bancontact),
Some(card),
Some(card_present),
Some(client_secret),
Some(code_verification),
Some(created),
Some(currency),
Some(customer),
Some(eps),
Some(flow),
Some(giropay),
Some(id),
Some(ideal),
Some(klarna),
Some(livemode),
Some(metadata),
Some(multibanco),
Some(owner),
Some(p24),
Some(receiver),
Some(redirect),
Some(sepa_credit_transfer),
Some(sepa_debit),
Some(sofort),
Some(source_order),
Some(statement_descriptor),
Some(status),
Some(three_d_secure),
Some(type_),
Some(usage),
Some(wechat),
) = (
self.ach_credit_transfer.take(),
self.ach_debit.take(),
self.acss_debit.take(),
self.alipay.take(),
self.allow_redisplay.take(),
self.amount,
self.au_becs_debit.take(),
self.bancontact.take(),
self.card.take(),
self.card_present.take(),
self.client_secret.take(),
self.code_verification.take(),
self.created,
self.currency.take(),
self.customer.take(),
self.eps.take(),
self.flow.take(),
self.giropay.take(),
self.id.take(),
self.ideal.take(),
self.klarna.take(),
self.livemode,
self.metadata.take(),
self.multibanco.take(),
self.owner.take(),
self.p24.take(),
self.receiver.take(),
self.redirect.take(),
self.sepa_credit_transfer.take(),
self.sepa_debit.take(),
self.sofort.take(),
self.source_order.take(),
self.statement_descriptor.take(),
self.status.take(),
self.three_d_secure.take(),
self.type_.take(),
self.usage.take(),
self.wechat.take(),
)
else {
return None;
};
Some(Self::Out {
ach_credit_transfer,
ach_debit,
acss_debit,
alipay,
allow_redisplay,
amount,
au_becs_debit,
bancontact,
card,
card_present,
client_secret,
code_verification,
created,
currency,
customer,
eps,
flow,
giropay,
id,
ideal,
klarna,
livemode,
metadata,
multibanco,
owner,
p24,
receiver,
redirect,
sepa_credit_transfer,
sepa_debit,
sofort,
source_order,
statement_descriptor,
status,
three_d_secure,
type_,
usage,
wechat,
})
}
}
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 Source {
type Builder = SourceBuilder;
}
impl FromValueOpt for Source {
fn from_value(v: Value) -> Option<Self> {
let Value::Object(obj) = v else {
return None;
};
let mut b = SourceBuilder::deser_default();
for (k, v) in obj {
match k.as_str() {
"ach_credit_transfer" => b.ach_credit_transfer = FromValueOpt::from_value(v),
"ach_debit" => b.ach_debit = FromValueOpt::from_value(v),
"acss_debit" => b.acss_debit = FromValueOpt::from_value(v),
"alipay" => b.alipay = FromValueOpt::from_value(v),
"allow_redisplay" => b.allow_redisplay = FromValueOpt::from_value(v),
"amount" => b.amount = FromValueOpt::from_value(v),
"au_becs_debit" => b.au_becs_debit = FromValueOpt::from_value(v),
"bancontact" => b.bancontact = FromValueOpt::from_value(v),
"card" => b.card = FromValueOpt::from_value(v),
"card_present" => b.card_present = FromValueOpt::from_value(v),
"client_secret" => b.client_secret = FromValueOpt::from_value(v),
"code_verification" => b.code_verification = FromValueOpt::from_value(v),
"created" => b.created = FromValueOpt::from_value(v),
"currency" => b.currency = FromValueOpt::from_value(v),
"customer" => b.customer = FromValueOpt::from_value(v),
"eps" => b.eps = FromValueOpt::from_value(v),
"flow" => b.flow = FromValueOpt::from_value(v),
"giropay" => b.giropay = FromValueOpt::from_value(v),
"id" => b.id = FromValueOpt::from_value(v),
"ideal" => b.ideal = FromValueOpt::from_value(v),
"klarna" => b.klarna = FromValueOpt::from_value(v),
"livemode" => b.livemode = FromValueOpt::from_value(v),
"metadata" => b.metadata = FromValueOpt::from_value(v),
"multibanco" => b.multibanco = FromValueOpt::from_value(v),
"owner" => b.owner = FromValueOpt::from_value(v),
"p24" => b.p24 = FromValueOpt::from_value(v),
"receiver" => b.receiver = FromValueOpt::from_value(v),
"redirect" => b.redirect = FromValueOpt::from_value(v),
"sepa_credit_transfer" => b.sepa_credit_transfer = FromValueOpt::from_value(v),
"sepa_debit" => b.sepa_debit = FromValueOpt::from_value(v),
"sofort" => b.sofort = FromValueOpt::from_value(v),
"source_order" => b.source_order = FromValueOpt::from_value(v),
"statement_descriptor" => b.statement_descriptor = FromValueOpt::from_value(v),
"status" => b.status = FromValueOpt::from_value(v),
"three_d_secure" => b.three_d_secure = FromValueOpt::from_value(v),
"type" => b.type_ = FromValueOpt::from_value(v),
"usage" => b.usage = FromValueOpt::from_value(v),
"wechat" => b.wechat = FromValueOpt::from_value(v),
_ => {}
}
}
b.take_out()
}
}
};
#[cfg(feature = "serialize")]
impl serde::Serialize for Source {
fn serialize<S: serde::Serializer>(&self, s: S) -> Result<S::Ok, S::Error> {
use serde::ser::SerializeStruct;
let mut s = s.serialize_struct("Source", 39)?;
s.serialize_field("ach_credit_transfer", &self.ach_credit_transfer)?;
s.serialize_field("ach_debit", &self.ach_debit)?;
s.serialize_field("acss_debit", &self.acss_debit)?;
s.serialize_field("alipay", &self.alipay)?;
s.serialize_field("allow_redisplay", &self.allow_redisplay)?;
s.serialize_field("amount", &self.amount)?;
s.serialize_field("au_becs_debit", &self.au_becs_debit)?;
s.serialize_field("bancontact", &self.bancontact)?;
s.serialize_field("card", &self.card)?;
s.serialize_field("card_present", &self.card_present)?;
s.serialize_field("client_secret", &self.client_secret)?;
s.serialize_field("code_verification", &self.code_verification)?;
s.serialize_field("created", &self.created)?;
s.serialize_field("currency", &self.currency)?;
s.serialize_field("customer", &self.customer)?;
s.serialize_field("eps", &self.eps)?;
s.serialize_field("flow", &self.flow)?;
s.serialize_field("giropay", &self.giropay)?;
s.serialize_field("id", &self.id)?;
s.serialize_field("ideal", &self.ideal)?;
s.serialize_field("klarna", &self.klarna)?;
s.serialize_field("livemode", &self.livemode)?;
s.serialize_field("metadata", &self.metadata)?;
s.serialize_field("multibanco", &self.multibanco)?;
s.serialize_field("owner", &self.owner)?;
s.serialize_field("p24", &self.p24)?;
s.serialize_field("receiver", &self.receiver)?;
s.serialize_field("redirect", &self.redirect)?;
s.serialize_field("sepa_credit_transfer", &self.sepa_credit_transfer)?;
s.serialize_field("sepa_debit", &self.sepa_debit)?;
s.serialize_field("sofort", &self.sofort)?;
s.serialize_field("source_order", &self.source_order)?;
s.serialize_field("statement_descriptor", &self.statement_descriptor)?;
s.serialize_field("status", &self.status)?;
s.serialize_field("three_d_secure", &self.three_d_secure)?;
s.serialize_field("type", &self.type_)?;
s.serialize_field("usage", &self.usage)?;
s.serialize_field("wechat", &self.wechat)?;
s.serialize_field("object", "source")?;
s.end()
}
}
#[derive(Clone, Eq, PartialEq)]
#[non_exhaustive]
pub enum SourceAllowRedisplay {
Always,
Limited,
Unspecified,
Unknown(String),
}
impl SourceAllowRedisplay {
pub fn as_str(&self) -> &str {
use SourceAllowRedisplay::*;
match self {
Always => "always",
Limited => "limited",
Unspecified => "unspecified",
Unknown(v) => v,
}
}
}
impl std::str::FromStr for SourceAllowRedisplay {
type Err = std::convert::Infallible;
fn from_str(s: &str) -> Result<Self, Self::Err> {
use SourceAllowRedisplay::*;
match s {
"always" => Ok(Always),
"limited" => Ok(Limited),
"unspecified" => Ok(Unspecified),
v => {
tracing::warn!("Unknown value '{}' for enum '{}'", v, "SourceAllowRedisplay");
Ok(Unknown(v.to_owned()))
}
}
}
}
impl std::fmt::Display for SourceAllowRedisplay {
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 SourceAllowRedisplay {
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 SourceAllowRedisplay {
fn fmt(&self, f: &mut std::fmt::Formatter) -> std::fmt::Result {
f.debug_struct(stringify!(SourceAllowRedisplay)).finish_non_exhaustive()
}
}
#[cfg(feature = "serialize")]
impl serde::Serialize for SourceAllowRedisplay {
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 SourceAllowRedisplay {
fn begin(out: &mut Option<Self>) -> &mut dyn miniserde::de::Visitor {
crate::Place::new(out)
}
}
impl miniserde::de::Visitor for crate::Place<SourceAllowRedisplay> {
fn string(&mut self, s: &str) -> miniserde::Result<()> {
use std::str::FromStr;
self.out = Some(SourceAllowRedisplay::from_str(s).expect("infallible"));
Ok(())
}
}
stripe_types::impl_from_val_with_from_str!(SourceAllowRedisplay);
#[cfg(feature = "deserialize")]
impl<'de> serde::Deserialize<'de> for SourceAllowRedisplay {
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, Eq, PartialEq)]
#[non_exhaustive]
pub enum SourceType {
AchCreditTransfer,
AchDebit,
AcssDebit,
Alipay,
AuBecsDebit,
Bancontact,
Card,
CardPresent,
Eps,
Giropay,
Ideal,
Klarna,
Multibanco,
P24,
SepaCreditTransfer,
SepaDebit,
Sofort,
ThreeDSecure,
Wechat,
Unknown(String),
}
impl SourceType {
pub fn as_str(&self) -> &str {
use SourceType::*;
match self {
AchCreditTransfer => "ach_credit_transfer",
AchDebit => "ach_debit",
AcssDebit => "acss_debit",
Alipay => "alipay",
AuBecsDebit => "au_becs_debit",
Bancontact => "bancontact",
Card => "card",
CardPresent => "card_present",
Eps => "eps",
Giropay => "giropay",
Ideal => "ideal",
Klarna => "klarna",
Multibanco => "multibanco",
P24 => "p24",
SepaCreditTransfer => "sepa_credit_transfer",
SepaDebit => "sepa_debit",
Sofort => "sofort",
ThreeDSecure => "three_d_secure",
Wechat => "wechat",
Unknown(v) => v,
}
}
}
impl std::str::FromStr for SourceType {
type Err = std::convert::Infallible;
fn from_str(s: &str) -> Result<Self, Self::Err> {
use SourceType::*;
match s {
"ach_credit_transfer" => Ok(AchCreditTransfer),
"ach_debit" => Ok(AchDebit),
"acss_debit" => Ok(AcssDebit),
"alipay" => Ok(Alipay),
"au_becs_debit" => Ok(AuBecsDebit),
"bancontact" => Ok(Bancontact),
"card" => Ok(Card),
"card_present" => Ok(CardPresent),
"eps" => Ok(Eps),
"giropay" => Ok(Giropay),
"ideal" => Ok(Ideal),
"klarna" => Ok(Klarna),
"multibanco" => Ok(Multibanco),
"p24" => Ok(P24),
"sepa_credit_transfer" => Ok(SepaCreditTransfer),
"sepa_debit" => Ok(SepaDebit),
"sofort" => Ok(Sofort),
"three_d_secure" => Ok(ThreeDSecure),
"wechat" => Ok(Wechat),
v => {
tracing::warn!("Unknown value '{}' for enum '{}'", v, "SourceType");
Ok(Unknown(v.to_owned()))
}
}
}
}
impl std::fmt::Display for SourceType {
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 SourceType {
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 SourceType {
fn fmt(&self, f: &mut std::fmt::Formatter) -> std::fmt::Result {
f.debug_struct(stringify!(SourceType)).finish_non_exhaustive()
}
}
#[cfg(feature = "serialize")]
impl serde::Serialize for SourceType {
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 SourceType {
fn begin(out: &mut Option<Self>) -> &mut dyn miniserde::de::Visitor {
crate::Place::new(out)
}
}
impl miniserde::de::Visitor for crate::Place<SourceType> {
fn string(&mut self, s: &str) -> miniserde::Result<()> {
use std::str::FromStr;
self.out = Some(SourceType::from_str(s).expect("infallible"));
Ok(())
}
}
stripe_types::impl_from_val_with_from_str!(SourceType);
#[cfg(feature = "deserialize")]
impl<'de> serde::Deserialize<'de> for SourceType {
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"))
}
}
impl stripe_types::Object for Source {
type Id = stripe_shared::SourceId;
fn id(&self) -> &Self::Id {
&self.id
}
fn into_id(self) -> Self::Id {
self.id
}
}
stripe_types::def_id!(SourceId);