Class: Stripe::Plan
- Inherits:
-
APIResource
- Object
- StripeObject
- APIResource
- Stripe::Plan
- Extended by:
- APIOperations::Create, APIOperations::List
- Includes:
- APIOperations::Delete, APIOperations::Save
- Defined in:
- lib/stripe/resources/plan.rb
Overview
You can now model subscriptions more flexibly using the [Prices API](stripe.com/docs/api#prices). It replaces the Plans API and is backwards compatible to simplify your migration.
Plans define the base price, currency, and billing cycle for recurring purchases of products. [Products](stripe.com/docs/api#products) help you track inventory or provisioning, and plans help you track pricing. Different physical goods or levels of service should be represented by products, and pricing options should be represented by plans. This approach lets you change prices without having to change your provisioning scheme.
For example, you might have a single “gold” product that has plans for $10/month, $100/year, €9/month, and €90/year.
Related guides: [Set up a subscription](stripe.com/docs/billing/subscriptions/set-up-subscription) and more about [products and prices](stripe.com/docs/products-prices/overview).
Constant Summary collapse
- OBJECT_NAME =
"plan"
Constants inherited from StripeObject
StripeObject::RESERVED_FIELD_NAMES
Instance Attribute Summary
Attributes inherited from APIResource
Attributes inherited from StripeObject
Class Method Summary collapse
-
.create(params = {}, opts = {}) ⇒ Object
You can now model subscriptions more flexibly using the [Prices API](stripe.com/docs/api#prices).
-
.delete(id, params = {}, opts = {}) ⇒ Object
Deleting plans means new subscribers can’t be added.
-
.list(filters = {}, opts = {}) ⇒ Object
Returns a list of your plans.
- .object_name ⇒ Object
-
.update(id, params = {}, opts = {}) ⇒ Object
Updates the specified plan by setting the values of the parameters passed.
Instance Method Summary collapse
-
#delete(params = {}, opts = {}) ⇒ Object
Deleting plans means new subscribers can’t be added.
Methods included from APIOperations::Create
Methods included from APIOperations::List
Methods included from APIOperations::Save
Methods included from APIOperations::Delete
Methods inherited from APIResource
class_name, custom_method, #refresh, #request_stripe_object, resource_url, #resource_url, retrieve, save_nested_resource
Methods included from APIOperations::Request
Methods inherited from StripeObject
#==, #[], #[]=, additive_object_param, additive_object_param?, #as_json, construct_from, #deleted?, #dirty!, #each, #eql?, #hash, #initialize, #inspect, #keys, #marshal_dump, #marshal_load, protected_fields, #serialize_params, #to_hash, #to_json, #to_s, #update_attributes, #values
Constructor Details
This class inherits a constructor from Stripe::StripeObject
Dynamic Method Handling
This class handles dynamic methods through the method_missing method in the class Stripe::StripeObject
Class Method Details
.create(params = {}, opts = {}) ⇒ Object
You can now model subscriptions more flexibly using the [Prices API](stripe.com/docs/api#prices). It replaces the Plans API and is backwards compatible to simplify your migration.
25 26 27 |
# File 'lib/stripe/resources/plan.rb', line 25 def self.create(params = {}, opts = {}) request_stripe_object(method: :post, path: "/v1/plans", params: params, opts: opts) end |
.delete(id, params = {}, opts = {}) ⇒ Object
Deleting plans means new subscribers can’t be added. Existing subscribers aren’t affected.
30 31 32 33 34 35 36 37 |
# File 'lib/stripe/resources/plan.rb', line 30 def self.delete(id, params = {}, opts = {}) request_stripe_object( method: :delete, path: format("/v1/plans/%<id>s", { id: CGI.escape(id) }), params: params, opts: opts ) end |
.list(filters = {}, opts = {}) ⇒ Object
Returns a list of your plans.
50 51 52 |
# File 'lib/stripe/resources/plan.rb', line 50 def self.list(filters = {}, opts = {}) request_stripe_object(method: :get, path: "/v1/plans", params: filters, opts: opts) end |
.object_name ⇒ Object
20 21 22 |
# File 'lib/stripe/resources/plan.rb', line 20 def self.object_name "plan" end |
.update(id, params = {}, opts = {}) ⇒ Object
Updates the specified plan by setting the values of the parameters passed. Any parameters not provided are left unchanged. By design, you cannot change a plan’s ID, amount, currency, or billing cycle.
55 56 57 58 59 60 61 62 |
# File 'lib/stripe/resources/plan.rb', line 55 def self.update(id, params = {}, opts = {}) request_stripe_object( method: :post, path: format("/v1/plans/%<id>s", { id: CGI.escape(id) }), params: params, opts: opts ) end |
Instance Method Details
#delete(params = {}, opts = {}) ⇒ Object
Deleting plans means new subscribers can’t be added. Existing subscribers aren’t affected.
40 41 42 43 44 45 46 47 |
# File 'lib/stripe/resources/plan.rb', line 40 def delete(params = {}, opts = {}) request_stripe_object( method: :delete, path: format("/v1/plans/%<plan>s", { plan: CGI.escape(self["id"]) }), params: params, opts: opts ) end |