Manage Subscriptions
Manage subscription scenarios
Updating subscriptions
    The following details can be updated for eligible
    Pending and
    Active
    subscriptions:- Subscription ID
- Price
- Plan
- Payment method
- Add-on and discount details
- Number of billing cycles
- Merchant account
- Descriptor
Important
        Merchants operating in the European Union must give customers 4 weeks' notice before changing the
        price of their recurring billing plan; 4 weeks' notice is also required before billing customers
        if it has been 6+ months since their last payment. If you don't operate in the EU, these notices
        aren't required (but they're still good practice).
    
- C#
var result = gateway.Subscription.Update(subscription.Id, new SubscriptionRequest {
    Id = "new_id",
    PaymentMethodToken = "new_payment_method_token",
    Price = 14.00M,
    PlanId = "new_plan",
    MerchantAccountId = "new_merchant_account"
});NotFoundException.
    Plans
    If you update a subscription's plan, the subscription will not inherit the new plan's price.
    Additionally, you can only update to a plan with the same billing cycle (e.g. you can't update from
    a yearly plan to a monthly plan and vice versa).
    Payment methods
    You can update the payment method associated with a Pending, Active, or
    Past Due subscription using either of the following:*If you
    delete a payment method
    using its payment method token, all associated subscriptions will be canceled immediately and the
    customer will forfeit any remaining days they've already paid for.
    When you update a Past Due subscription's payment method and you have
    proration enabled, the subscription will be automatically retried.
    Add-ons and discounts
    When updating a subscription, you can modify the add-ons and discounts in 3 ways:- New add-ons/discounts can be added
- Existing add-ons/discounts associated with the subscription can be updated
- Existing add-ons/discounts associated with the subscription can be removed
- C#
var request = new SubscriptionRequest {
    AddOns = new AddOnsRequest {
        Add = new AddAddOnRequest[] {
            new AddAddOnRequest {
                InheritedFromId = "add_on_id_1",
                Amount = 25.00M
            }
        },
        Update = new UpdateAddOnRequest[] {
            new UpdateAddOnRequest {
                ExistingId = "add_on_id_2",
                Amount = 50.00M
            }
        },
        Remove = new String[] {
            "add_on_id_3"
        }
    },
    Discounts = new DiscountsRequest {
        Add = new AddDiscountRequest[] {
            new AddDiscountRequest {
                InheritedFromId = "discount_id_1",
                Amount = 7.00M
            }
        },
        Update = new UpdateDiscountRequest[] {
            new UpdateDiscountRequest {
                ExistingId = "discount_id_2",
                Amount = 15.00M
            }
        },
        Remove = new String[] {
            "discount_id_3"
        }
    }
};
Result<subscription> result = gateway.Subscription.Update("the_subscription_id", request);Note
        You can only add an add-on or discount to a subscription once. If you'd like to apply an add-on or
        discount to a subscription several times, you can pass Quantity when
        creating or updating the add-on/discount.
    
Proration
    You can use proration to charge or credit a customer if a change is made to the subscription price
    in the middle of a billing cycle. Enabling proration adjusts the price based on how many days are
    left in the billing cycle, and charges the customer the newly-calculated rate immediately. Without
    proration enabled, any changes made to a customer's subscription mid-cycle will go into effect at
    the beginning of the next cycle.Note
        The number of days that have passed in a billing cycle is updated each day at 12am in the time
        zone specified in your Control Panel. The time zone for your account was established during the
        application process; to see your current time zone settings, navigate to
        Account > Merchant Account Info > Time Zone.
    
Proration with add-ons and discounts
    Add-ons and discounts will only be prorated when you pass the option
    ProrateCharges
    as true. If existing add-ons or discounts were not originally passed with this option
    set to true, they will not be prorated. For example, if a request is sent to update an
    add-on's quantity from 4 to 6 with
    ProrateCharges set to true, and the original add-ons did not
    also pass this option as true, the subscriber will only be charged a prorated amount
    for the additional 2 add-ons.
    Merchant accounts
    Since
    MerchantAccountId
    determines currency, updating the merchant account used to process transactions for a subscription
    may change which currency the subscription is processed in.
    Past Due subscriptions
    A subscription's balance represents the amount of outstanding charges associated with that
    subscription. If a customer's payment method fails or is declined, their subscription status will
    change to Past Due, and the subscription's balance is incremented by the amount of the transaction that failed. This
    amount includes the subscription base price as well as any associated add-ons and/or discounts. If
    the subscription has add-ons and discounts with a specified number of billing cycles, the number of
    billing cycles are also reflected in the subscription's balance. For example, let's say that a
    subscription was created with these settings:
        
        Subscription price: $12 for 12 billing cycles 
             Add-on price: $10 for 2 billing cycles
    
    
        2 failed billing cycles, $12 each = $24 
             1 failed billing cycle for the add-on charge for $10 
             Total balance = $34
    
Updating Past Due subscriptions
    When updating a subscription that is
    Past Due, you can only update fields that do not change the price:
    - Subscription ID
- Payment method
- Merchant account
- Descriptor
Retry logic
    We will automatically attempt to charge past due subscriptions at the beginning of each new billing
    cycle. You can also customize our retry logic
    in the Control Panel
    if you would like to charge past due subscriptions in-between billing cycles. Depending on the
    processor response code,
    some declines are not retried
    because they suggest that it's unlikely the transaction will ever be successful. A subscription's
    balance will only be adjusted by our retry logic at the beginning of a new billing cycle. In other
    words, if the automatic retry attempts during one billing cycle are not successful, the
    subscription's balance will increase in the next billing cycle to incorporate the missed payment.
    You can also retry transactions manually, either on a
    one-off basis or as a part of your own recurring logic.
    Negative balance
    A negative balance indicates that credit is owed to the customer on that subscription. A
    subscription's balance can go into the negative if you have configured your processing options to
    allow
    proration on downgrades. If a subscription has a negative balance that is enough to cover the charge, the subscription
    will bill successfully without actually charging the payment method.
    Retrying transactions manually
Important
        When handling declined transactions, keep in mind that there are
        rules around retrying recurring transactions.
    
Submitting for settlement
    When retrying a declined transaction via the API, pass [true] in the argument to
    automatically submit the transaction for settlement if the retry request is successful:
    - C#
Result<transaction> retryResult = gateway.Subscription.RetryCharge(subscription.Id, 24.00M, true);
if (retryResult.IsSuccess()) {
    // true
}Availability
        Submitting transactions for settlement in the
        
Subscription: Retry Charge
        call is supported in the latest versions of our server SDKs. In older versions, you must
        submit for settlement separately
        .
    Refunding a subscription
    Refunds for subscriptions work the same as
    refunds for individual transactions. You can only issue a refund against an existing sale transaction, and that transaction must have
    a status of settled or
    settling. You can specify the
    refund amount if you don't want to refund the full amount of an existing sale transaction. If a
    customer has an annual subscription and you want to refund them for six months, issue a refund by
    reversing the original transaction for half the amount paid in a single transaction. use
    Transaction: Refund
    to issue a refund via the API. You can also
    issue a refund within the Control Panel. If you do not want to continue charging the customer for their subscription in the future, be
    sure to
    cancel the subscription as well.
    Next Page: →