Class: MetronomeSDK::Models::V1::ContractCreateParams::Subscription

Inherits:
Internal::Type::BaseModel show all
Defined in:
lib/metronome_sdk/models/v1/contract_create_params.rb

Defined Under Namespace

Modules: CollectionSchedule, QuantityManagementMode Classes: Proration, SeatConfig, SubscriptionRate

Instance Attribute Summary collapse

Class Method Summary collapse

Instance Method Summary collapse

Methods inherited from Internal::Type::BaseModel

==, #==, #[], coerce, #deconstruct_keys, #deep_to_h, dump, fields, hash, #hash, inherited, 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

#initialize(collection_schedule:, proration:, subscription_rate:, custom_fields: nil, description: nil, ending_before: nil, initial_quantity: nil, name: nil, quantity_management_mode: nil, seat_config: nil, starting_at: nil, temporary_id: nil) ⇒ Object

Some parameter documentations has been truncated, see MetronomeSDK::Models::V1::ContractCreateParams::Subscription for more details.

Parameters:



# File 'lib/metronome_sdk/models/v1/contract_create_params.rb', line 3184

Instance Attribute Details

#collection_scheduleSymbol, MetronomeSDK::Models::V1::ContractCreateParams::Subscription::CollectionSchedule



3107
3108
# File 'lib/metronome_sdk/models/v1/contract_create_params.rb', line 3107

required :collection_schedule,
enum: -> { MetronomeSDK::V1::ContractCreateParams::Subscription::CollectionSchedule }

#custom_fieldsHash{Symbol=>String}?

Custom fields to be added eg. { “key1”: “value1”, “key2”: “value2” }

Returns:

  • (Hash{Symbol=>String}, nil)


3124
# File 'lib/metronome_sdk/models/v1/contract_create_params.rb', line 3124

optional :custom_fields, MetronomeSDK::Internal::Type::HashOf[String]

#descriptionString?

Returns:

  • (String, nil)


3129
# File 'lib/metronome_sdk/models/v1/contract_create_params.rb', line 3129

optional :description, String

#ending_beforeTime?

Exclusive end time for the subscription. If not provided, subscription inherits contract end date.

Returns:

  • (Time, nil)


3136
# File 'lib/metronome_sdk/models/v1/contract_create_params.rb', line 3136

optional :ending_before, Time

#initial_quantityFloat?

The initial quantity for the subscription. It must be non-negative value. Required if quantity_management_mode is QUANTITY_ONLY.

Returns:

  • (Float, nil)


3143
# File 'lib/metronome_sdk/models/v1/contract_create_params.rb', line 3143

optional :initial_quantity, Float

#nameString?

Returns:

  • (String, nil)


3148
# File 'lib/metronome_sdk/models/v1/contract_create_params.rb', line 3148

optional :name, String

#prorationMetronomeSDK::Models::V1::ContractCreateParams::Subscription::Proration



3113
# File 'lib/metronome_sdk/models/v1/contract_create_params.rb', line 3113

required :proration, -> { MetronomeSDK::V1::ContractCreateParams::Subscription::Proration }

#quantity_management_modeSymbol, ...

Determines how the subscription’s quantity is controlled. Defaults to QUANTITY_ONLY. QUANTITY_ONLY: The subscription quantity is specified directly on the subscription. ‘initial_quantity` must be provided with this option. Compatible with recurring commits/credits that use POOLED allocation. SEAT_BASED: Use when you want to pass specific seat identifiers (e.g. add user_123) to increment and decrement a subscription quantity, rather than directly providing the quantity. You must use a SEAT_BASED subscription to use a linked recurring credit with an allocation per seat. `seat_config` must be provided with this option.



3162
3163
# File 'lib/metronome_sdk/models/v1/contract_create_params.rb', line 3162

optional :quantity_management_mode,
enum: -> { MetronomeSDK::V1::ContractCreateParams::Subscription::QuantityManagementMode }

#seat_configMetronomeSDK::Models::V1::ContractCreateParams::Subscription::SeatConfig?



3168
# File 'lib/metronome_sdk/models/v1/contract_create_params.rb', line 3168

optional :seat_config, -> { MetronomeSDK::V1::ContractCreateParams::Subscription::SeatConfig }

#starting_atTime?

Inclusive start time for the subscription. If not provided, defaults to contract start date

Returns:

  • (Time, nil)


3175
# File 'lib/metronome_sdk/models/v1/contract_create_params.rb', line 3175

optional :starting_at, Time

#subscription_rateMetronomeSDK::Models::V1::ContractCreateParams::Subscription::SubscriptionRate



3118
# File 'lib/metronome_sdk/models/v1/contract_create_params.rb', line 3118

required :subscription_rate, -> { MetronomeSDK::V1::ContractCreateParams::Subscription::SubscriptionRate }

#temporary_idString?

A temporary ID used to reference the subscription in recurring commit/credit subscription configs created within the same payload.

Returns:

  • (String, nil)


3182
# File 'lib/metronome_sdk/models/v1/contract_create_params.rb', line 3182

optional :temporary_id, String

Class Method Details

.valuesArray<Symbol>

Returns:

  • (Array<Symbol>)


# File 'lib/metronome_sdk/models/v1/contract_create_params.rb', line 3219