Subscription: Update
- 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.
    Arguments
Idrequired, stringAdditional Parameters
The collection of add-ons associated with a subscription. Add-on details can only be managed within the Control Panel.
AddarrayAmountDecimalInheritedFromIdstringNeverExpiresboolNumberOfBillingCyclesstringQuantityintRemovearrayUpdatearrayAmountDecimalExistingIdstringNeverExpiresboolNumberOfBillingCyclesstringQuantityintDynamic descriptors are not enabled on all accounts by default. If you receive a validation error of 92203 or if your dynamic descriptors are not displaying as expected, please contact us.
Dynamic descriptors are sent on a per-transaction basis and define what will appear on your customers' credit card statements for a specific purchase. The clearer the description of your product, the less likely customers will issue chargebacks due to confusion or non-recognition.
 See the dynamic descriptor example for additional information.
NamestringThe value in the business name field of a customer's statement. The specific length/character requirements for this value depend on your processor. Contact us for assistance.
PhonestringUrlstringA collection of discounts associated with this subscription. Discount details can only be managed within the Control Panel.
AddarrayAmountDecimalInheritedFromIdstringNeverExpiresboolNumberOfBillingCyclesstringQuantityintRemovearrayUpdatearrayAmountDecimalExistingIdstringNeverExpiresboolNumberOfBillingCyclesstringQuantityintIdstringMerchantAccountIdstringThe merchant account ID used to create the subscription's transactions. Currency is also determined by merchant account ID and it must match the Plan's currency. See the Transaction MerchantAccountId parameter for more information.
NeverExpiresboolWhether a subscription's billing cycle is set to never expire instead of running for a specific number of billing cycles. If this is set to true, NumberOfBillingCycles will be set to null as a subscription can't have a limited number of billing cycles and never expire. If set to false, NumberOfBillingCycles can't be null.
The number of billing cycles of the subscription. If this is set to a non-null value, NeverExpires will be set to false as a subscription can't both have a limited number of billing cycles and never expire. This value must be greater than or equal to the value of CurrentBillingCycle.
DescriptionstringProrateChargesboolWhen set to true, the plan's add-ons and discounts are removed, setting the value to 0. This parameter can also be used in conjunction with the add parameters to replace a plan's existing add-ons and discounts with those specified.
By default, if the transaction for the prorated amount fails, the subscription is reverted. If you would like to continue with the update to the subscription and add the prorated amount to the balance even though the transaction failed, you should set this field to false.
PaymentMethodNoncestringOne-time-use reference to a payment method provided by your customer, such as a credit card or PayPal account.
A payment method must be vaulted before you can associate it with a subscription, so it's usually simplest to refer to the payment method using its PaymentMethodToken. However, there are 2 cases where you can pass a payment method nonce instead of a payment method token:
- If the nonce was generated by our Drop-in UI and you passed a CustomerId when generating the client token, or
- If the nonce was generated from a vaulted payment method belonging to the customer that owns the subscription
PaymentMethodTokenstringAn alphanumeric value that references a specific payment method stored in your Vault. If provided, this will change the payment method associated with the subscription. Under certain circumstances, you can pass a PaymentMethodNonce instead.
PlanIdstringPriceDecimalThe price specified for a subscription. Billing price must be formatted like 10 or 10.00. If you provide a price, it can't be an empty string. You must update the price in this parameter; updating the PlanId will not automatically change the price of a subscription. You can't update the price of a Past Due, Expired, or Canceled subscription. Price can't be greater than the maximum allowed by the processor. Contact us for your specific limit.
Examples
Add-ons and discounts
- 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
);Update with 3D Secure enriched payment method nonce
    If you use 3D Secure and need to apply 3DS to the next transaction of an existing subscription, you
    must update the subscription using a
    3DS-enriched nonce. See the
    3D Secure guide for details on how to
    properly obtain a 3DS-enriched nonce, and see the
    3D Secure for Recurring Transactions
    page for more information on utilizing 3DS for subscription transactions. Once you've obtained a
    3DS-enriched nonce, provide it on the subscription update call:
    - C#
var request = new SubscriptionRequest {
    PaymentMethodNonce = "nonce_from_the_client",
    Id = "subscription_id"
};
Result<subscription> result = gateway.Subscription.Update(request);Multiple updates
    You can also add, update and remove multiple add-ons/discounts at the same time.
    - C#
var request = new SubscriptionRequest {
    AddOns = new AddOnsRequest {
        Add = new AddAddOnRequest[] {
            new AddAddOnRequest { InheritedFromId = "add_on_id_1", Amount = 20.00M },
            new AddAddOnRequest { InheritedFromId = "add_on_id_2", Amount = 30.00M }
        },
        Update = new UpdateAddOnRequest[] {
            new UpdateAddOnRequest { ExistingId = "add_on_id_3", Quantity = 2 },
            new UpdateAddOnRequest { ExistingId = "add_on_id_4", Quantity = 3 }
        },
        Remove = new String[] { "add_on_id_5", "add_on_id_6" }
    }
};
Result<subscription> result = gateway.Subscription.Update(
    "the_subscription_id",
    request
);Override details
    When adding add-ons/discounts, all details will be inherited from the add-on/discount specified by
    the InheritedFromId. You can override any of the following:
 - Amount
- NumberOfBillingCycles or NeverExpires
- Quantity
- C#
var request = new SubscriptionRequest {
    AddOns = new AddOnsRequest {
        Add = new AddAddOnRequest[] {
            new AddAddOnRequest { InheritedFromId = "add_on_id_1", Amount = 20.00M, NumberOfBillingCycles = 2, Quantity = 4 }
        },
        Update = new UpdateAddOnRequest[] {
            new UpdateAddOnRequest { ExistingId = "add_on_id_2", Amount = 15.00M, NeverExpires = true, Quantity = 3 }
        }
    }
};
Result<subscription> result = gateway.Subscription.Update(
    "the_subscription_id",
    request
);Remove add-ons and discounts
    If you prefer to update a subscription and remove all existing add-ons and discounts, you can pass
    the ReplaceAllAddOnsAndDiscounts option.
    - C#
var request = new SubscriptionRequest {
    Options = new SubscriptionOptionsRequest {
        ReplaceAllAddOnsAndDiscounts = true
    }
};
Result<subscription> result = gateway.Subscription.Update(
    "the_subscription_id",
    request
);