#[derive(Clone)]
#[cfg_attr(not(feature = "redact-generated-debug"), derive(Debug))]
#[cfg_attr(feature = "deserialize", derive(serde::Deserialize))]
pub struct CustomerBalanceTransaction {
pub amount: i64,
pub checkout_session: Option<stripe_types::Expandable<stripe_shared::CheckoutSession>>,
pub created: stripe_types::Timestamp,
pub credit_note: Option<stripe_types::Expandable<stripe_shared::CreditNote>>,
pub currency: stripe_types::Currency,
pub customer: stripe_types::Expandable<stripe_shared::Customer>,
pub customer_account: Option<String>,
pub description: Option<String>,
pub ending_balance: i64,
pub id: stripe_shared::CustomerBalanceTransactionId,
pub invoice: Option<stripe_types::Expandable<stripe_shared::Invoice>>,
pub livemode: bool,
pub metadata: Option<std::collections::HashMap<String, String>>,
#[cfg_attr(feature = "deserialize", serde(rename = "type"))]
pub type_: CustomerBalanceTransactionType,
}
#[cfg(feature = "redact-generated-debug")]
impl std::fmt::Debug for CustomerBalanceTransaction {
fn fmt(&self, f: &mut std::fmt::Formatter) -> std::fmt::Result {
f.debug_struct("CustomerBalanceTransaction").finish_non_exhaustive()
}
}
#[doc(hidden)]
pub struct CustomerBalanceTransactionBuilder {
amount: Option<i64>,
checkout_session: Option<Option<stripe_types::Expandable<stripe_shared::CheckoutSession>>>,
created: Option<stripe_types::Timestamp>,
credit_note: Option<Option<stripe_types::Expandable<stripe_shared::CreditNote>>>,
currency: Option<stripe_types::Currency>,
customer: Option<stripe_types::Expandable<stripe_shared::Customer>>,
customer_account: Option<Option<String>>,
description: Option<Option<String>>,
ending_balance: Option<i64>,
id: Option<stripe_shared::CustomerBalanceTransactionId>,
invoice: Option<Option<stripe_types::Expandable<stripe_shared::Invoice>>>,
livemode: Option<bool>,
metadata: Option<Option<std::collections::HashMap<String, String>>>,
type_: Option<CustomerBalanceTransactionType>,
}
#[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 CustomerBalanceTransaction {
fn begin(out: &mut Option<Self>) -> &mut dyn Visitor {
Place::new(out)
}
}
struct Builder<'a> {
out: &'a mut Option<CustomerBalanceTransaction>,
builder: CustomerBalanceTransactionBuilder,
}
impl Visitor for Place<CustomerBalanceTransaction> {
fn map(&mut self) -> Result<Box<dyn Map + '_>> {
Ok(Box::new(Builder {
out: &mut self.out,
builder: CustomerBalanceTransactionBuilder::deser_default(),
}))
}
}
impl MapBuilder for CustomerBalanceTransactionBuilder {
type Out = CustomerBalanceTransaction;
fn key(&mut self, k: &str) -> Result<&mut dyn Visitor> {
Ok(match k {
"amount" => Deserialize::begin(&mut self.amount),
"checkout_session" => Deserialize::begin(&mut self.checkout_session),
"created" => Deserialize::begin(&mut self.created),
"credit_note" => Deserialize::begin(&mut self.credit_note),
"currency" => Deserialize::begin(&mut self.currency),
"customer" => Deserialize::begin(&mut self.customer),
"customer_account" => Deserialize::begin(&mut self.customer_account),
"description" => Deserialize::begin(&mut self.description),
"ending_balance" => Deserialize::begin(&mut self.ending_balance),
"id" => Deserialize::begin(&mut self.id),
"invoice" => Deserialize::begin(&mut self.invoice),
"livemode" => Deserialize::begin(&mut self.livemode),
"metadata" => Deserialize::begin(&mut self.metadata),
"type" => Deserialize::begin(&mut self.type_),
_ => <dyn Visitor>::ignore(),
})
}
fn deser_default() -> Self {
Self {
amount: None,
checkout_session: Some(None),
created: None,
credit_note: Some(None),
currency: None,
customer: None,
customer_account: Some(None),
description: Some(None),
ending_balance: None,
id: None,
invoice: Some(None),
livemode: None,
metadata: Some(None),
type_: None,
}
}
fn take_out(&mut self) -> Option<Self::Out> {
let (
Some(amount),
Some(checkout_session),
Some(created),
Some(credit_note),
Some(currency),
Some(customer),
Some(customer_account),
Some(description),
Some(ending_balance),
Some(id),
Some(invoice),
Some(livemode),
Some(metadata),
Some(type_),
) = (
self.amount,
self.checkout_session.take(),
self.created,
self.credit_note.take(),
self.currency.take(),
self.customer.take(),
self.customer_account.take(),
self.description.take(),
self.ending_balance,
self.id.take(),
self.invoice.take(),
self.livemode,
self.metadata.take(),
self.type_.take(),
)
else {
return None;
};
Some(Self::Out {
amount,
checkout_session,
created,
credit_note,
currency,
customer,
customer_account,
description,
ending_balance,
id,
invoice,
livemode,
metadata,
type_,
})
}
}
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 CustomerBalanceTransaction {
type Builder = CustomerBalanceTransactionBuilder;
}
impl FromValueOpt for CustomerBalanceTransaction {
fn from_value(v: Value) -> Option<Self> {
let Value::Object(obj) = v else {
return None;
};
let mut b = CustomerBalanceTransactionBuilder::deser_default();
for (k, v) in obj {
match k.as_str() {
"amount" => b.amount = FromValueOpt::from_value(v),
"checkout_session" => b.checkout_session = FromValueOpt::from_value(v),
"created" => b.created = FromValueOpt::from_value(v),
"credit_note" => b.credit_note = FromValueOpt::from_value(v),
"currency" => b.currency = FromValueOpt::from_value(v),
"customer" => b.customer = FromValueOpt::from_value(v),
"customer_account" => b.customer_account = FromValueOpt::from_value(v),
"description" => b.description = FromValueOpt::from_value(v),
"ending_balance" => b.ending_balance = FromValueOpt::from_value(v),
"id" => b.id = FromValueOpt::from_value(v),
"invoice" => b.invoice = FromValueOpt::from_value(v),
"livemode" => b.livemode = FromValueOpt::from_value(v),
"metadata" => b.metadata = FromValueOpt::from_value(v),
"type" => b.type_ = FromValueOpt::from_value(v),
_ => {}
}
}
b.take_out()
}
}
};
#[cfg(feature = "serialize")]
impl serde::Serialize for CustomerBalanceTransaction {
fn serialize<S: serde::Serializer>(&self, s: S) -> Result<S::Ok, S::Error> {
use serde::ser::SerializeStruct;
let mut s = s.serialize_struct("CustomerBalanceTransaction", 15)?;
s.serialize_field("amount", &self.amount)?;
s.serialize_field("checkout_session", &self.checkout_session)?;
s.serialize_field("created", &self.created)?;
s.serialize_field("credit_note", &self.credit_note)?;
s.serialize_field("currency", &self.currency)?;
s.serialize_field("customer", &self.customer)?;
s.serialize_field("customer_account", &self.customer_account)?;
s.serialize_field("description", &self.description)?;
s.serialize_field("ending_balance", &self.ending_balance)?;
s.serialize_field("id", &self.id)?;
s.serialize_field("invoice", &self.invoice)?;
s.serialize_field("livemode", &self.livemode)?;
s.serialize_field("metadata", &self.metadata)?;
s.serialize_field("type", &self.type_)?;
s.serialize_field("object", "customer_balance_transaction")?;
s.end()
}
}
#[derive(Clone, Eq, PartialEq)]
#[non_exhaustive]
pub enum CustomerBalanceTransactionType {
Adjustment,
AppliedToInvoice,
CheckoutSessionSubscriptionPayment,
CheckoutSessionSubscriptionPaymentCanceled,
CreditNote,
Initial,
InvoiceOverpaid,
InvoiceTooLarge,
InvoiceTooSmall,
Migration,
UnappliedFromInvoice,
UnspentReceiverCredit,
Unknown(String),
}
impl CustomerBalanceTransactionType {
pub fn as_str(&self) -> &str {
use CustomerBalanceTransactionType::*;
match self {
Adjustment => "adjustment",
AppliedToInvoice => "applied_to_invoice",
CheckoutSessionSubscriptionPayment => "checkout_session_subscription_payment",
CheckoutSessionSubscriptionPaymentCanceled => {
"checkout_session_subscription_payment_canceled"
}
CreditNote => "credit_note",
Initial => "initial",
InvoiceOverpaid => "invoice_overpaid",
InvoiceTooLarge => "invoice_too_large",
InvoiceTooSmall => "invoice_too_small",
Migration => "migration",
UnappliedFromInvoice => "unapplied_from_invoice",
UnspentReceiverCredit => "unspent_receiver_credit",
Unknown(v) => v,
}
}
}
impl std::str::FromStr for CustomerBalanceTransactionType {
type Err = std::convert::Infallible;
fn from_str(s: &str) -> Result<Self, Self::Err> {
use CustomerBalanceTransactionType::*;
match s {
"adjustment" => Ok(Adjustment),
"applied_to_invoice" => Ok(AppliedToInvoice),
"checkout_session_subscription_payment" => Ok(CheckoutSessionSubscriptionPayment),
"checkout_session_subscription_payment_canceled" => {
Ok(CheckoutSessionSubscriptionPaymentCanceled)
}
"credit_note" => Ok(CreditNote),
"initial" => Ok(Initial),
"invoice_overpaid" => Ok(InvoiceOverpaid),
"invoice_too_large" => Ok(InvoiceTooLarge),
"invoice_too_small" => Ok(InvoiceTooSmall),
"migration" => Ok(Migration),
"unapplied_from_invoice" => Ok(UnappliedFromInvoice),
"unspent_receiver_credit" => Ok(UnspentReceiverCredit),
v => {
tracing::warn!(
"Unknown value '{}' for enum '{}'",
v,
"CustomerBalanceTransactionType"
);
Ok(Unknown(v.to_owned()))
}
}
}
}
impl std::fmt::Display for CustomerBalanceTransactionType {
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 CustomerBalanceTransactionType {
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 CustomerBalanceTransactionType {
fn fmt(&self, f: &mut std::fmt::Formatter) -> std::fmt::Result {
f.debug_struct(stringify!(CustomerBalanceTransactionType)).finish_non_exhaustive()
}
}
#[cfg(feature = "serialize")]
impl serde::Serialize for CustomerBalanceTransactionType {
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 CustomerBalanceTransactionType {
fn begin(out: &mut Option<Self>) -> &mut dyn miniserde::de::Visitor {
crate::Place::new(out)
}
}
impl miniserde::de::Visitor for crate::Place<CustomerBalanceTransactionType> {
fn string(&mut self, s: &str) -> miniserde::Result<()> {
use std::str::FromStr;
self.out = Some(CustomerBalanceTransactionType::from_str(s).expect("infallible"));
Ok(())
}
}
stripe_types::impl_from_val_with_from_str!(CustomerBalanceTransactionType);
#[cfg(feature = "deserialize")]
impl<'de> serde::Deserialize<'de> for CustomerBalanceTransactionType {
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 CustomerBalanceTransaction {
type Id = stripe_shared::CustomerBalanceTransactionId;
fn id(&self) -> &Self::Id {
&self.id
}
fn into_id(self) -> Self::Id {
self.id
}
}
stripe_types::def_id!(CustomerBalanceTransactionId);