pub struct CreateCheckoutSessionSubscriptionData {
    pub application_fee_percent: Option<f64>,
    pub billing_cycle_anchor: Option<Timestamp>,
    pub default_tax_rates: Option<Vec<String>>,
    pub description: Option<String>,
    pub invoice_settings: Option<CreateCheckoutSessionSubscriptionDataInvoiceSettings>,
    pub metadata: Option<Metadata>,
    pub on_behalf_of: Option<String>,
    pub proration_behavior: Option<CreateCheckoutSessionSubscriptionDataProrationBehavior>,
    pub transfer_data: Option<CreateCheckoutSessionSubscriptionDataTransferData>,
    pub trial_end: Option<Timestamp>,
    pub trial_period_days: Option<u32>,
    pub trial_settings: Option<CreateCheckoutSessionSubscriptionDataTrialSettings>,
}

Fields§

§application_fee_percent: Option<f64>

A non-negative decimal between 0 and 100, with at most two decimal places.

This represents the percentage of the subscription invoice total that will be transferred to the application owner’s Stripe account. To use an application fee percent, the request must be made on behalf of another account, using the Stripe-Account header or an OAuth key. For more information, see the application fees documentation.

§billing_cycle_anchor: Option<Timestamp>

A future timestamp to anchor the subscription’s billing cycle for new subscriptions.

§default_tax_rates: Option<Vec<String>>

The tax rates that will apply to any subscription item that does not have tax_rates set.

Invoices created will have their default_tax_rates populated from the subscription.

§description: Option<String>

The subscription’s description, meant to be displayable to the customer. Use this field to optionally store an explanation of the subscription for rendering in the customer portal.

§invoice_settings: Option<CreateCheckoutSessionSubscriptionDataInvoiceSettings>

All invoices will be billed using the specified settings.

§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.

§on_behalf_of: Option<String>

The account on behalf of which to charge, for each of the subscription’s invoices.

§proration_behavior: Option<CreateCheckoutSessionSubscriptionDataProrationBehavior>

Determines how to handle prorations resulting from the billing_cycle_anchor.

If no value is passed, the default is create_prorations.

§transfer_data: Option<CreateCheckoutSessionSubscriptionDataTransferData>

If specified, the funds from the subscription’s invoices will be transferred to the destination and the ID of the resulting transfers will be found on the resulting charges.

§trial_end: Option<Timestamp>

Unix timestamp representing the end of the trial period the customer will get before being charged for the first time.

Has to be at least 48 hours in the future.

§trial_period_days: Option<u32>

Integer representing the number of trial period days before the customer is charged for the first time.

Has to be at least 1.

§trial_settings: Option<CreateCheckoutSessionSubscriptionDataTrialSettings>

Settings related to subscription trials.

Trait Implementations§

source§

impl Clone for CreateCheckoutSessionSubscriptionData

source§

fn clone(&self) -> CreateCheckoutSessionSubscriptionData

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 Debug for CreateCheckoutSessionSubscriptionData

source§

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

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

impl Default for CreateCheckoutSessionSubscriptionData

source§

fn default() -> CreateCheckoutSessionSubscriptionData

Returns the “default value” for a type. Read more
source§

impl<'de> Deserialize<'de> for CreateCheckoutSessionSubscriptionData

source§

fn deserialize<__D>(__deserializer: __D) -> Result<Self, __D::Error>
where __D: Deserializer<'de>,

Deserialize this value from the given Serde deserializer. Read more
source§

impl Serialize for CreateCheckoutSessionSubscriptionData

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§

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.
source§

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

source§

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
source§

impl<T> DeserializeOwned for T
where T: for<'de> Deserialize<'de>,