# File generated from our OpenAPI spec # frozen_string_literal: true module Stripe # A subscription schedule allows you to create and manage the lifecycle of a subscription by predefining expected changes. # # Related guide: [Subscription Schedules](https://stripe.com/docs/billing/subscriptions/subscription-schedules). class SubscriptionSchedule < APIResource extend Stripe::APIOperations::Create extend Stripe::APIOperations::List include Stripe::APIOperations::Save OBJECT_NAME = "subscription_schedule" def cancel(params = {}, opts = {}) request_stripe_object( method: :post, path: format("/v1/subscription_schedules/%s/cancel", { schedule: CGI.escape(self["id"]) }), params: params, opts: opts ) end def release(params = {}, opts = {}) request_stripe_object( method: :post, path: format("/v1/subscription_schedules/%s/release", { schedule: CGI.escape(self["id"]) }), params: params, opts: opts ) end def self.cancel(schedule, params = {}, opts = {}) request_stripe_object( method: :post, path: format("/v1/subscription_schedules/%s/cancel", { schedule: CGI.escape(schedule) }), params: params, opts: opts ) end def self.release(schedule, params = {}, opts = {}) request_stripe_object( method: :post, path: format("/v1/subscription_schedules/%s/release", { schedule: CGI.escape(schedule) }), params: params, opts: opts ) end end end