pub struct CreateInvoiceItem<'a> {
Show 19 fields pub amount: Option<i64>, pub currency: Option<Currency>, pub customer: CustomerId, pub description: Option<&'a str>, pub discountable: Option<bool>, pub discounts: Option<Vec<CreateInvoiceItemDiscounts>>, pub expand: &'a [&'a str], pub invoice: Option<InvoiceId>, pub metadata: Option<Metadata>, pub period: Option<Period>, pub price: Option<PriceId>, pub price_data: Option<InvoiceItemPriceData>, pub quantity: Option<u64>, pub subscription: Option<SubscriptionId>, pub tax_behavior: Option<InvoiceItemTaxBehavior>, pub tax_code: Option<String>, pub tax_rates: Option<Vec<String>>, pub unit_amount: Option<i64>, pub unit_amount_decimal: Option<&'a str>,
}
Expand description

The parameters for InvoiceItem::create.

Fields§

§amount: Option<i64>

The integer amount in cents (or local equivalent) of the charge to be applied to the upcoming invoice.

Passing in a negative amount will reduce the amount_due on the invoice.

§currency: Option<Currency>

Three-letter ISO currency code, in lowercase.

Must be a supported currency.

§customer: CustomerId

The ID of the customer who will be billed when this invoice item is billed.

§description: Option<&'a str>

An arbitrary string which you can attach to the invoice item.

The description is displayed in the invoice for easy tracking.

§discountable: Option<bool>

Controls whether discounts apply to this invoice item.

Defaults to false for prorations or negative invoice items, and true for all other invoice items.

§discounts: Option<Vec<CreateInvoiceItemDiscounts>>

The coupons to redeem into discounts for the invoice item or invoice line item.

§expand: &'a [&'a str]

Specifies which fields in the response should be expanded.

§invoice: Option<InvoiceId>

The ID of an existing invoice to add this invoice item to.

When left blank, the invoice item will be added to the next upcoming scheduled invoice. This is useful when adding invoice items in response to an invoice.created webhook. You can only add invoice items to draft invoices and there is a maximum of 250 items per invoice.

§metadata: Option<Metadata>

Set of key-value pairs that you can attach to an object.

This can be useful for storing additional information about the object in a structured format. Individual keys can be unset by posting an empty value to them. All keys can be unset by posting an empty value to metadata.

§period: Option<Period>

The period associated with this invoice item.

When set to different values, the period will be rendered on the invoice. If you have Stripe Revenue Recognition enabled, the period will be used to recognize and defer revenue. See the Revenue Recognition documentation for details.

§price: Option<PriceId>

The ID of the price object.

§price_data: Option<InvoiceItemPriceData>

Data used to generate a new Price object inline.

§quantity: Option<u64>

Non-negative integer.

The quantity of units for the invoice item.

§subscription: Option<SubscriptionId>

The ID of a subscription to add this invoice item to.

When left blank, the invoice item will be be added to the next upcoming scheduled invoice. When set, scheduled invoices for subscriptions other than the specified subscription will ignore the invoice item. Use this when you want to express that an invoice item has been accrued within the context of a particular subscription.

§tax_behavior: Option<InvoiceItemTaxBehavior>

Only required if a default tax behavior was not provided in the Stripe Tax settings.

Specifies whether the price is considered inclusive of taxes or exclusive of taxes. One of inclusive, exclusive, or unspecified. Once specified as either inclusive or exclusive, it cannot be changed.

§tax_code: Option<String>

A tax code ID.

§tax_rates: Option<Vec<String>>

The tax rates which apply to the invoice item.

When set, the default_tax_rates on the invoice do not apply to this invoice item.

§unit_amount: Option<i64>

The integer unit amount in cents (or local equivalent) of the charge to be applied to the upcoming invoice.

This unit_amount will be multiplied by the quantity to get the full amount. Passing in a negative unit_amount will reduce the amount_due on the invoice.

§unit_amount_decimal: Option<&'a str>

Same as unit_amount, but accepts a decimal value in cents (or local equivalent) with at most 12 decimal places.

Only one of unit_amount and unit_amount_decimal can be set.

Implementations§

source§

impl<'a> CreateInvoiceItem<'a>

source

pub fn new(customer: CustomerId) -> Self

Trait Implementations§

source§

impl<'a> Clone for CreateInvoiceItem<'a>

source§

fn clone(&self) -> CreateInvoiceItem<'a>

Returns a copy of the value. Read more
1.0.0 · source§

fn clone_from(&mut self, source: &Self)

Performs copy-assignment from source. Read more
source§

impl<'a> Debug for CreateInvoiceItem<'a>

source§

fn fmt(&self, f: &mut Formatter<'_>) -> Result

Formats the value using the given formatter. Read more
source§

impl<'a> Serialize for CreateInvoiceItem<'a>

source§

fn serialize<__S>(&self, __serializer: __S) -> Result<__S::Ok, __S::Error>
where __S: Serializer,

Serialize this value into the given Serde serializer. Read more

Auto Trait Implementations§

§

impl<'a> RefUnwindSafe for CreateInvoiceItem<'a>

§

impl<'a> Send for CreateInvoiceItem<'a>

§

impl<'a> Sync for CreateInvoiceItem<'a>

§

impl<'a> Unpin for CreateInvoiceItem<'a>

§

impl<'a> UnwindSafe for CreateInvoiceItem<'a>

Blanket Implementations§

source§

impl<T> Any for T
where T: 'static + ?Sized,

source§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
source§

impl<T> Borrow<T> for T
where T: ?Sized,

source§

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
source§

impl<T> BorrowMut<T> for T
where T: ?Sized,

source§

fn borrow_mut(&mut self) -> &mut T

Mutably borrows from an owned value. Read more
source§

impl<T> From<T> for T

source§

fn from(t: T) -> T

Returns the argument unchanged.

source§

impl<T> Instrument for T

source§

fn instrument(self, span: Span) -> Instrumented<Self>

Instruments this type with the provided Span, returning an Instrumented wrapper. Read more
source§

fn in_current_span(self) -> Instrumented<Self>

Instruments this type with the current Span, returning an Instrumented wrapper. Read more
source§

impl<T, U> Into<U> for T
where U: From<T>,

source§

fn into(self) -> U

Calls U::from(self).

That is, this conversion is whatever the implementation of From<T> for U chooses to do.

source§

impl<T> Same for T

§

type Output = T

Should always be Self
source§

impl<T> ToOwned for T
where T: Clone,

§

type Owned = T

The resulting type after obtaining ownership.
source§

fn to_owned(&self) -> T

Creates owned data from borrowed data, usually by cloning. Read more
source§

fn clone_into(&self, target: &mut T)

Uses borrowed data to replace owned data, usually by cloning. Read more
source§

impl<T, U> TryFrom<U> for T
where U: Into<T>,

§

type Error = Infallible

The type returned in the event of a conversion error.
source§

fn try_from(value: U) -> Result<T, <T as TryFrom<U>>::Error>

Performs the conversion.
source§

impl<T, U> TryInto<U> for T
where U: TryFrom<T>,

§

type Error = <U as TryFrom<T>>::Error

The type returned in the event of a conversion error.
source§

fn try_into(self) -> Result<U, <U as TryFrom<T>>::Error>

Performs the conversion.
§

impl<V, T> VZip<V> for T
where V: MultiLane<T>,

§

fn vzip(self) -> V

source§

impl<T> WithSubscriber for T

source§

fn with_subscriber<S>(self, subscriber: S) -> WithDispatch<Self>
where S: Into<Dispatch>,

Attaches the provided Subscriber to this type, returning a WithDispatch wrapper. Read more
source§

fn with_current_subscriber(self) -> WithDispatch<Self>

Attaches the current default Subscriber to this type, returning a WithDispatch wrapper. Read more