stripe_shared/
credit_note_line_item.rs

1/// The credit note line item object
2///
3/// For more details see <<https://stripe.com/docs/api/credit_notes/line_item>>.
4#[derive(Clone, Debug)]
5#[cfg_attr(feature = "deserialize", derive(serde::Deserialize))]
6pub struct CreditNoteLineItem {
7    /// The integer amount in cents (or local equivalent) representing the gross amount being credited for this line item, excluding (exclusive) tax and discounts.
8    pub amount: i64,
9    /// Description of the item being credited.
10    pub description: Option<String>,
11    /// The integer amount in cents (or local equivalent) representing the discount being credited for this line item.
12    pub discount_amount: i64,
13    /// The amount of discount calculated per discount for this line item
14    pub discount_amounts: Vec<stripe_shared::DiscountsResourceDiscountAmount>,
15    /// Unique identifier for the object.
16    pub id: stripe_shared::CreditNoteLineItemId,
17    /// ID of the invoice line item being credited
18    pub invoice_line_item: Option<String>,
19    /// Has the value `true` if the object exists in live mode or the value `false` if the object exists in test mode.
20    pub livemode: bool,
21    /// The pretax credit amounts (ex: discount, credit grants, etc) for this line item.
22    pub pretax_credit_amounts: Vec<stripe_shared::CreditNotesPretaxCreditAmount>,
23    /// The number of units of product being credited.
24    pub quantity: Option<u64>,
25    /// The tax rates which apply to the line item.
26    pub tax_rates: Vec<stripe_shared::TaxRate>,
27    /// The tax information of the line item.
28    pub taxes: Option<Vec<stripe_shared::BillingBillResourceInvoicingTaxesTax>>,
29    /// The type of the credit note line item, one of `invoice_line_item` or `custom_line_item`.
30    /// When the type is `invoice_line_item` there is an additional `invoice_line_item` property on the resource the value of which is the id of the credited line item on the invoice.
31    #[cfg_attr(feature = "deserialize", serde(rename = "type"))]
32    pub type_: CreditNoteLineItemType,
33    /// The cost of each unit of product being credited.
34    pub unit_amount: Option<i64>,
35    /// Same as `unit_amount`, but contains a decimal value with at most 12 decimal places.
36    pub unit_amount_decimal: Option<String>,
37}
38#[doc(hidden)]
39pub struct CreditNoteLineItemBuilder {
40    amount: Option<i64>,
41    description: Option<Option<String>>,
42    discount_amount: Option<i64>,
43    discount_amounts: Option<Vec<stripe_shared::DiscountsResourceDiscountAmount>>,
44    id: Option<stripe_shared::CreditNoteLineItemId>,
45    invoice_line_item: Option<Option<String>>,
46    livemode: Option<bool>,
47    pretax_credit_amounts: Option<Vec<stripe_shared::CreditNotesPretaxCreditAmount>>,
48    quantity: Option<Option<u64>>,
49    tax_rates: Option<Vec<stripe_shared::TaxRate>>,
50    taxes: Option<Option<Vec<stripe_shared::BillingBillResourceInvoicingTaxesTax>>>,
51    type_: Option<CreditNoteLineItemType>,
52    unit_amount: Option<Option<i64>>,
53    unit_amount_decimal: Option<Option<String>>,
54}
55
56#[allow(
57    unused_variables,
58    irrefutable_let_patterns,
59    clippy::let_unit_value,
60    clippy::match_single_binding,
61    clippy::single_match
62)]
63const _: () = {
64    use miniserde::de::{Map, Visitor};
65    use miniserde::json::Value;
66    use miniserde::{Deserialize, Result, make_place};
67    use stripe_types::miniserde_helpers::FromValueOpt;
68    use stripe_types::{MapBuilder, ObjectDeser};
69
70    make_place!(Place);
71
72    impl Deserialize for CreditNoteLineItem {
73        fn begin(out: &mut Option<Self>) -> &mut dyn Visitor {
74            Place::new(out)
75        }
76    }
77
78    struct Builder<'a> {
79        out: &'a mut Option<CreditNoteLineItem>,
80        builder: CreditNoteLineItemBuilder,
81    }
82
83    impl Visitor for Place<CreditNoteLineItem> {
84        fn map(&mut self) -> Result<Box<dyn Map + '_>> {
85            Ok(Box::new(Builder {
86                out: &mut self.out,
87                builder: CreditNoteLineItemBuilder::deser_default(),
88            }))
89        }
90    }
91
92    impl MapBuilder for CreditNoteLineItemBuilder {
93        type Out = CreditNoteLineItem;
94        fn key(&mut self, k: &str) -> Result<&mut dyn Visitor> {
95            Ok(match k {
96                "amount" => Deserialize::begin(&mut self.amount),
97                "description" => Deserialize::begin(&mut self.description),
98                "discount_amount" => Deserialize::begin(&mut self.discount_amount),
99                "discount_amounts" => Deserialize::begin(&mut self.discount_amounts),
100                "id" => Deserialize::begin(&mut self.id),
101                "invoice_line_item" => Deserialize::begin(&mut self.invoice_line_item),
102                "livemode" => Deserialize::begin(&mut self.livemode),
103                "pretax_credit_amounts" => Deserialize::begin(&mut self.pretax_credit_amounts),
104                "quantity" => Deserialize::begin(&mut self.quantity),
105                "tax_rates" => Deserialize::begin(&mut self.tax_rates),
106                "taxes" => Deserialize::begin(&mut self.taxes),
107                "type" => Deserialize::begin(&mut self.type_),
108                "unit_amount" => Deserialize::begin(&mut self.unit_amount),
109                "unit_amount_decimal" => Deserialize::begin(&mut self.unit_amount_decimal),
110
111                _ => <dyn Visitor>::ignore(),
112            })
113        }
114
115        fn deser_default() -> Self {
116            Self {
117                amount: Deserialize::default(),
118                description: Deserialize::default(),
119                discount_amount: Deserialize::default(),
120                discount_amounts: Deserialize::default(),
121                id: Deserialize::default(),
122                invoice_line_item: Deserialize::default(),
123                livemode: Deserialize::default(),
124                pretax_credit_amounts: Deserialize::default(),
125                quantity: Deserialize::default(),
126                tax_rates: Deserialize::default(),
127                taxes: Deserialize::default(),
128                type_: Deserialize::default(),
129                unit_amount: Deserialize::default(),
130                unit_amount_decimal: Deserialize::default(),
131            }
132        }
133
134        fn take_out(&mut self) -> Option<Self::Out> {
135            let (
136                Some(amount),
137                Some(description),
138                Some(discount_amount),
139                Some(discount_amounts),
140                Some(id),
141                Some(invoice_line_item),
142                Some(livemode),
143                Some(pretax_credit_amounts),
144                Some(quantity),
145                Some(tax_rates),
146                Some(taxes),
147                Some(type_),
148                Some(unit_amount),
149                Some(unit_amount_decimal),
150            ) = (
151                self.amount,
152                self.description.take(),
153                self.discount_amount,
154                self.discount_amounts.take(),
155                self.id.take(),
156                self.invoice_line_item.take(),
157                self.livemode,
158                self.pretax_credit_amounts.take(),
159                self.quantity,
160                self.tax_rates.take(),
161                self.taxes.take(),
162                self.type_,
163                self.unit_amount,
164                self.unit_amount_decimal.take(),
165            )
166            else {
167                return None;
168            };
169            Some(Self::Out {
170                amount,
171                description,
172                discount_amount,
173                discount_amounts,
174                id,
175                invoice_line_item,
176                livemode,
177                pretax_credit_amounts,
178                quantity,
179                tax_rates,
180                taxes,
181                type_,
182                unit_amount,
183                unit_amount_decimal,
184            })
185        }
186    }
187
188    impl Map for Builder<'_> {
189        fn key(&mut self, k: &str) -> Result<&mut dyn Visitor> {
190            self.builder.key(k)
191        }
192
193        fn finish(&mut self) -> Result<()> {
194            *self.out = self.builder.take_out();
195            Ok(())
196        }
197    }
198
199    impl ObjectDeser for CreditNoteLineItem {
200        type Builder = CreditNoteLineItemBuilder;
201    }
202
203    impl FromValueOpt for CreditNoteLineItem {
204        fn from_value(v: Value) -> Option<Self> {
205            let Value::Object(obj) = v else {
206                return None;
207            };
208            let mut b = CreditNoteLineItemBuilder::deser_default();
209            for (k, v) in obj {
210                match k.as_str() {
211                    "amount" => b.amount = FromValueOpt::from_value(v),
212                    "description" => b.description = FromValueOpt::from_value(v),
213                    "discount_amount" => b.discount_amount = FromValueOpt::from_value(v),
214                    "discount_amounts" => b.discount_amounts = FromValueOpt::from_value(v),
215                    "id" => b.id = FromValueOpt::from_value(v),
216                    "invoice_line_item" => b.invoice_line_item = FromValueOpt::from_value(v),
217                    "livemode" => b.livemode = FromValueOpt::from_value(v),
218                    "pretax_credit_amounts" => {
219                        b.pretax_credit_amounts = FromValueOpt::from_value(v)
220                    }
221                    "quantity" => b.quantity = FromValueOpt::from_value(v),
222                    "tax_rates" => b.tax_rates = FromValueOpt::from_value(v),
223                    "taxes" => b.taxes = FromValueOpt::from_value(v),
224                    "type" => b.type_ = FromValueOpt::from_value(v),
225                    "unit_amount" => b.unit_amount = FromValueOpt::from_value(v),
226                    "unit_amount_decimal" => b.unit_amount_decimal = FromValueOpt::from_value(v),
227
228                    _ => {}
229                }
230            }
231            b.take_out()
232        }
233    }
234};
235#[cfg(feature = "serialize")]
236impl serde::Serialize for CreditNoteLineItem {
237    fn serialize<S: serde::Serializer>(&self, s: S) -> Result<S::Ok, S::Error> {
238        use serde::ser::SerializeStruct;
239        let mut s = s.serialize_struct("CreditNoteLineItem", 15)?;
240        s.serialize_field("amount", &self.amount)?;
241        s.serialize_field("description", &self.description)?;
242        s.serialize_field("discount_amount", &self.discount_amount)?;
243        s.serialize_field("discount_amounts", &self.discount_amounts)?;
244        s.serialize_field("id", &self.id)?;
245        s.serialize_field("invoice_line_item", &self.invoice_line_item)?;
246        s.serialize_field("livemode", &self.livemode)?;
247        s.serialize_field("pretax_credit_amounts", &self.pretax_credit_amounts)?;
248        s.serialize_field("quantity", &self.quantity)?;
249        s.serialize_field("tax_rates", &self.tax_rates)?;
250        s.serialize_field("taxes", &self.taxes)?;
251        s.serialize_field("type", &self.type_)?;
252        s.serialize_field("unit_amount", &self.unit_amount)?;
253        s.serialize_field("unit_amount_decimal", &self.unit_amount_decimal)?;
254
255        s.serialize_field("object", "credit_note_line_item")?;
256        s.end()
257    }
258}
259/// The type of the credit note line item, one of `invoice_line_item` or `custom_line_item`.
260/// When the type is `invoice_line_item` there is an additional `invoice_line_item` property on the resource the value of which is the id of the credited line item on the invoice.
261#[derive(Copy, Clone, Eq, PartialEq)]
262pub enum CreditNoteLineItemType {
263    CustomLineItem,
264    InvoiceLineItem,
265}
266impl CreditNoteLineItemType {
267    pub fn as_str(self) -> &'static str {
268        use CreditNoteLineItemType::*;
269        match self {
270            CustomLineItem => "custom_line_item",
271            InvoiceLineItem => "invoice_line_item",
272        }
273    }
274}
275
276impl std::str::FromStr for CreditNoteLineItemType {
277    type Err = stripe_types::StripeParseError;
278    fn from_str(s: &str) -> Result<Self, Self::Err> {
279        use CreditNoteLineItemType::*;
280        match s {
281            "custom_line_item" => Ok(CustomLineItem),
282            "invoice_line_item" => Ok(InvoiceLineItem),
283            _ => Err(stripe_types::StripeParseError),
284        }
285    }
286}
287impl std::fmt::Display for CreditNoteLineItemType {
288    fn fmt(&self, f: &mut std::fmt::Formatter) -> std::fmt::Result {
289        f.write_str(self.as_str())
290    }
291}
292
293impl std::fmt::Debug for CreditNoteLineItemType {
294    fn fmt(&self, f: &mut std::fmt::Formatter) -> std::fmt::Result {
295        f.write_str(self.as_str())
296    }
297}
298#[cfg(feature = "serialize")]
299impl serde::Serialize for CreditNoteLineItemType {
300    fn serialize<S>(&self, serializer: S) -> Result<S::Ok, S::Error>
301    where
302        S: serde::Serializer,
303    {
304        serializer.serialize_str(self.as_str())
305    }
306}
307impl miniserde::Deserialize for CreditNoteLineItemType {
308    fn begin(out: &mut Option<Self>) -> &mut dyn miniserde::de::Visitor {
309        crate::Place::new(out)
310    }
311}
312
313impl miniserde::de::Visitor for crate::Place<CreditNoteLineItemType> {
314    fn string(&mut self, s: &str) -> miniserde::Result<()> {
315        use std::str::FromStr;
316        self.out = Some(CreditNoteLineItemType::from_str(s).map_err(|_| miniserde::Error)?);
317        Ok(())
318    }
319}
320
321stripe_types::impl_from_val_with_from_str!(CreditNoteLineItemType);
322#[cfg(feature = "deserialize")]
323impl<'de> serde::Deserialize<'de> for CreditNoteLineItemType {
324    fn deserialize<D: serde::Deserializer<'de>>(deserializer: D) -> Result<Self, D::Error> {
325        use std::str::FromStr;
326        let s: std::borrow::Cow<'de, str> = serde::Deserialize::deserialize(deserializer)?;
327        Self::from_str(&s)
328            .map_err(|_| serde::de::Error::custom("Unknown value for CreditNoteLineItemType"))
329    }
330}
331impl stripe_types::Object for CreditNoteLineItem {
332    type Id = stripe_shared::CreditNoteLineItemId;
333    fn id(&self) -> &Self::Id {
334        &self.id
335    }
336
337    fn into_id(self) -> Self::Id {
338        self.id
339    }
340}
341stripe_types::def_id!(CreditNoteLineItemId);