Struct stripe::CreateCoupon

source ·
pub struct CreateCoupon<'a> {
Show 13 fields pub amount_off: Option<i64>, pub applies_to: Option<CreateCouponAppliesTo>, pub currency: Option<Currency>, pub currency_options: Option<HashMap<Currency, CreateCouponCurrencyOptions>>, pub duration: Option<CouponDuration>, pub duration_in_months: Option<i64>, pub expand: &'a [&'a str], pub id: Option<&'a str>, pub max_redemptions: Option<i64>, pub metadata: Option<Metadata>, pub name: Option<&'a str>, pub percent_off: Option<f64>, pub redeem_by: Option<Timestamp>,
}
Expand description

The parameters for Coupon::create.

Fields§

§amount_off: Option<i64>

A positive integer representing the amount to subtract from an invoice total (required if percent_off is not passed).

§applies_to: Option<CreateCouponAppliesTo>

A hash containing directions for what this Coupon will apply discounts to.

§currency: Option<Currency>

Three-letter ISO code for the currency of the amount_off parameter (required if amount_off is passed).

§currency_options: Option<HashMap<Currency, CreateCouponCurrencyOptions>>

Coupons defined in each available currency option (only supported if amount_off is passed).

Each key must be a three-letter ISO currency code and a supported currency.

§duration: Option<CouponDuration>

Specifies how long the discount will be in effect if used on a subscription.

Defaults to once.

§duration_in_months: Option<i64>

Required only if duration is repeating, in which case it must be a positive integer that specifies the number of months the discount will be in effect.

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

Specifies which fields in the response should be expanded.

§id: Option<&'a str>

Unique string of your choice that will be used to identify this coupon when applying it to a customer.

If you don’t want to specify a particular code, you can leave the ID blank and we’ll generate a random code for you.

§max_redemptions: Option<i64>

A positive integer specifying the number of times the coupon can be redeemed before it’s no longer valid.

For example, you might have a 50% off coupon that the first 20 readers of your blog can use.

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

§name: Option<&'a str>

Name of the coupon displayed to customers on, for instance invoices, or receipts.

By default the id is shown if name is not set.

§percent_off: Option<f64>

A positive float larger than 0, and smaller or equal to 100, that represents the discount the coupon will apply (required if amount_off is not passed).

§redeem_by: Option<Timestamp>

Unix timestamp specifying the last time at which the coupon can be redeemed.

After the redeem_by date, the coupon can no longer be applied to new customers.

Implementations§

source§

impl<'a> CreateCoupon<'a>

source

pub fn new() -> Self

Trait Implementations§

source§

impl<'a> Clone for CreateCoupon<'a>

source§

fn clone(&self) -> CreateCoupon<'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 CreateCoupon<'a>

source§

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

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

impl<'a> Default for CreateCoupon<'a>

source§

fn default() -> CreateCoupon<'a>

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

impl<'a> Serialize for CreateCoupon<'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 CreateCoupon<'a>

§

impl<'a> Send for CreateCoupon<'a>

§

impl<'a> Sync for CreateCoupon<'a>

§

impl<'a> Unpin for CreateCoupon<'a>

§

impl<'a> UnwindSafe for CreateCoupon<'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