Class: Orb::Models::MutatedSubscription

Inherits:
Internal::Type::BaseModel show all
Defined in:
lib/orb/models/mutated_subscription.rb

Defined Under Namespace

Modules: DiscountInterval, Status

Instance Attribute Summary collapse

Class Method Summary collapse

Methods inherited from Internal::Type::BaseModel

#==, ==, #[], coerce, #deconstruct_keys, #deep_to_h, dump, fields, hash, #hash, inherited, #initialize, inspect, #inspect, known_fields, optional, recursively_to_h, required, #to_h, #to_json, #to_s, to_sorbet_type, #to_yaml

Methods included from Internal::Type::Converter

#coerce, coerce, #dump, dump, inspect, #inspect, meta_info, new_coerce_state, type_info

Methods included from Internal::Util::SorbetRuntimeSupport

#const_missing, #define_sorbet_constant!, #sorbet_constant_defined?, #to_sorbet_type, to_sorbet_type

Constructor Details

This class inherits a constructor from Orb::Internal::Type::BaseModel

Instance Attribute Details

#active_plan_phase_orderInteger?

The current plan phase that is active, only if the subscription’s plan has phases.

Returns:

  • (Integer, nil)


16
# File 'lib/orb/models/mutated_subscription.rb', line 16

required :active_plan_phase_order, Integer, nil?: true

#adjustment_intervalsArray<Orb::Models::AdjustmentInterval>

The adjustment intervals for this subscription sorted by the start_date of the adjustment interval.



23
# File 'lib/orb/models/mutated_subscription.rb', line 23

required :adjustment_intervals, -> { Orb::Internal::Type::ArrayOf[Orb::AdjustmentInterval] }

#auto_collectionBoolean?

Determines whether issued invoices for this subscription will automatically be charged with the saved payment method on the due date. This property defaults to the plan’s behavior. If null, defaults to the customer’s setting.

Returns:

  • (Boolean, nil)


31
# File 'lib/orb/models/mutated_subscription.rb', line 31

required :auto_collection, Orb::Internal::Type::Boolean, nil?: true

#billing_cycle_anchor_configurationOrb::Models::BillingCycleAnchorConfiguration



36
# File 'lib/orb/models/mutated_subscription.rb', line 36

required :billing_cycle_anchor_configuration, -> { Orb::BillingCycleAnchorConfiguration }

#billing_cycle_dayInteger

The day of the month on which the billing cycle is anchored. If the maximum number of days in a month is greater than this value, the last day of the month is the billing cycle day (e.g. billing_cycle_day=31 for April means the billing period begins on the 30th.

Returns:

  • (Integer)


45
# File 'lib/orb/models/mutated_subscription.rb', line 45

required :billing_cycle_day, Integer

#changed_resourcesOrb::Models::ChangedSubscriptionResources?

The resources that were changed as part of this operation. Only present when fetched through the subscription changes API or if the ‘include_changed_resources` parameter was passed in the request.



215
# File 'lib/orb/models/mutated_subscription.rb', line 215

optional :changed_resources, -> { Orb::ChangedSubscriptionResources }, nil?: true

#created_atTime

Returns:

  • (Time)


50
# File 'lib/orb/models/mutated_subscription.rb', line 50

required :created_at, Time

#current_billing_period_end_dateTime?

The end of the current billing period. This is an exclusive timestamp, such that the instant returned is not part of the billing period. Set to null for subscriptions that are not currently active.

Returns:

  • (Time, nil)


58
# File 'lib/orb/models/mutated_subscription.rb', line 58

required :current_billing_period_end_date, Time, nil?: true

#current_billing_period_start_dateTime?

The start date of the current billing period. This is an inclusive timestamp; the instant returned is exactly the beginning of the billing period. Set to null if the subscription is not currently active.

Returns:

  • (Time, nil)


66
# File 'lib/orb/models/mutated_subscription.rb', line 66

required :current_billing_period_start_date, Time, nil?: true

#customerOrb::Models::Customer

A customer is a buyer of your products, and the other party to the billing relationship.

In Orb, customers are assigned system generated identifiers automatically, but it’s often desirable to have these match existing identifiers in your system. To avoid having to denormalize Orb ID information, you can pass in an ‘external_customer_id` with your own identifier. See [Customer ID Aliases](/events-and-metrics/customer-aliases) for further information about how these aliases work in Orb.

In addition to having an identifier in your system, a customer may exist in a payment provider solution like Stripe. Use the ‘payment_provider_id` and the `payment_provider` enum field to express this mapping.

A customer also has a timezone (from the standard [IANA timezone database](www.iana.org/time-zones)), which defaults to your account’s timezone. See [Timezone localization](/essentials/timezones) for information on what this timezone parameter influences within Orb.



89
# File 'lib/orb/models/mutated_subscription.rb', line 89

required :customer, -> { Orb::Customer }

#default_invoice_memoString?

Determines the default memo on this subscriptions’ invoices. Note that if this is not provided, it is determined by the plan configuration.

Returns:

  • (String, nil)


96
# File 'lib/orb/models/mutated_subscription.rb', line 96

required :default_invoice_memo, String, nil?: true

#discount_intervalsArray<Orb::Models::AmountDiscountInterval, Orb::Models::PercentageDiscountInterval, Orb::Models::UsageDiscountInterval>

Deprecated.

The discount intervals for this subscription sorted by the start_date. This field is deprecated in favor of ‘adjustment_intervals`.



105
106
# File 'lib/orb/models/mutated_subscription.rb', line 105

required :discount_intervals,
-> { Orb::Internal::Type::ArrayOf[union: Orb::MutatedSubscription::DiscountInterval] }

#end_dateTime?

The date Orb stops billing for this subscription.

Returns:

  • (Time, nil)


112
# File 'lib/orb/models/mutated_subscription.rb', line 112

required :end_date, Time, nil?: true

#fixed_fee_quantity_scheduleArray<Orb::Models::FixedFeeQuantityScheduleEntry>



117
118
# File 'lib/orb/models/mutated_subscription.rb', line 117

required :fixed_fee_quantity_schedule,
-> { Orb::Internal::Type::ArrayOf[Orb::FixedFeeQuantityScheduleEntry] }

#idString

Returns:

  • (String)


9
# File 'lib/orb/models/mutated_subscription.rb', line 9

required :id, String

#invoicing_thresholdString?

Returns:

  • (String, nil)


123
# File 'lib/orb/models/mutated_subscription.rb', line 123

required :invoicing_threshold, String, nil?: true

#maximum_intervalsArray<Orb::Models::MaximumInterval>

Deprecated.

The maximum intervals for this subscription sorted by the start_date. This field is deprecated in favor of ‘adjustment_intervals`.

Returns:



132
# File 'lib/orb/models/mutated_subscription.rb', line 132

required :maximum_intervals, -> { Orb::Internal::Type::ArrayOf[Orb::MaximumInterval] }

#metadataHash{Symbol=>String}

User specified key-value pairs for the resource. If not present, this defaults to an empty dictionary. Individual keys can be removed by setting the value to ‘null`, and the entire metadata mapping can be cleared by setting `metadata` to `null`.

Returns:

  • (Hash{Symbol=>String})


141
# File 'lib/orb/models/mutated_subscription.rb', line 141

required :metadata, Orb::Internal::Type::HashOf[String]

#minimum_intervalsArray<Orb::Models::MinimumInterval>

Deprecated.

The minimum intervals for this subscription sorted by the start_date. This field is deprecated in favor of ‘adjustment_intervals`.

Returns:



150
# File 'lib/orb/models/mutated_subscription.rb', line 150

required :minimum_intervals, -> { Orb::Internal::Type::ArrayOf[Orb::MinimumInterval] }

#nameString

The name of the subscription.

Returns:

  • (String)


156
# File 'lib/orb/models/mutated_subscription.rb', line 156

required :name, String

#net_termsInteger

Determines the difference between the invoice issue date for subscription invoices as the date that they are due. A value of ‘0` here represents that the invoice is due on issue, whereas a value of `30` represents that the customer has a month to pay the invoice.

Returns:

  • (Integer)


165
# File 'lib/orb/models/mutated_subscription.rb', line 165

required :net_terms, Integer

#pending_subscription_changeOrb::Models::SubscriptionChangeMinified?

A pending subscription change if one exists on this subscription.



171
# File 'lib/orb/models/mutated_subscription.rb', line 171

required :pending_subscription_change, -> { Orb::SubscriptionChangeMinified }, nil?: true

#planOrb::Models::Plan?

The [Plan](/core-concepts#plan-and-price) resource represents a plan that can be subscribed to by a customer. Plans define the billing behavior of the subscription. You can see more about how to configure prices in the [Price resource](/reference/price).

Returns:



180
# File 'lib/orb/models/mutated_subscription.rb', line 180

required :plan, -> { Orb::Plan }, nil?: true

#price_intervalsArray<Orb::Models::PriceInterval>

The price intervals for this subscription.

Returns:



186
# File 'lib/orb/models/mutated_subscription.rb', line 186

required :price_intervals, -> { Orb::Internal::Type::ArrayOf[Orb::PriceInterval] }

#redeemed_couponOrb::Models::CouponRedemption?



191
# File 'lib/orb/models/mutated_subscription.rb', line 191

required :redeemed_coupon, -> { Orb::CouponRedemption }, nil?: true

#start_dateTime

The date Orb starts billing for this subscription.

Returns:

  • (Time)


197
# File 'lib/orb/models/mutated_subscription.rb', line 197

required :start_date, Time

#statusSymbol, Orb::Models::MutatedSubscription::Status



202
# File 'lib/orb/models/mutated_subscription.rb', line 202

required :status, enum: -> { Orb::MutatedSubscription::Status }

#trial_infoOrb::Models::SubscriptionTrialInfo



207
# File 'lib/orb/models/mutated_subscription.rb', line 207

required :trial_info, -> { Orb::SubscriptionTrialInfo }

Class Method Details

.variantsArray(Orb::Models::AmountDiscountInterval, Orb::Models::PercentageDiscountInterval, Orb::Models::UsageDiscountInterval)



# File 'lib/orb/models/mutated_subscription.rb', line 288