Skip to main content

Upgrade links


Create upgrade links and offer them to your customers. 


All Avangate accounts. 


Configure upgrades for your products/subscription plans.

Create the upgrade link

To build upgrade links you need the following two elements:

  1. The main upgrade link

    The unique subscription identifier from the Avangate system: LICENSE=ABC1D2E345. The simplest upgrade link you can build is:

Query parameters

The following table summarizes the query parameters that you can insert into links to customize upgrades.

Parameters Type / Description
LICENSE Required

Specifies the subscription to be upgraded.

LANG Optional

ISO country code of the language used for the order processing interface and shopper emails.

Default value: EN.

  Preselects the billing currency to be used in the transaction.
SHOPURL Optional
  Custom URL used for "Back to shopping" link.
OPTIONS(ProductID) Optional

Preselects the pricing options for the subscription, using the pricing options codes (the IDs you set for each option individually). You need to append the unique product identifier generated by the Avangate platform after the OPTIONS parameter. 

Example: OPTIONS1234567=5usr,2year.

Required in conjunction with UPGRADEOPT.

Optional otherwise.

  Product ID of the target product used in the upgrade process.


  Product option code of the target product used in the upgrade process. Can only be used in conjunction with UPGRADEPROD.
  Use DESIGN_TYPE=1 to change the layout of the shopping cart template interface, positioning the payment methods selector in a more prominent position, above the billing details area.

Enables you to control which version of the shopping cart Avangate serves to shoppers.

Possible values:

  • CLASSIC - the desktop variant of the shopping cart (Avangate serves the desktop version of the cart even to mobile device users.)
  • MOBILE - Avangate mobile cart (Avangate serves the mobile version of the shopping cart, even to users of desktop browsers.)
REF Optional
  External order reference (string). Add a string identifier to every URL (less than 100 characters). Avangate saves the string at order-level, in addition to the system generated order reference. If there is a need for longer references, use a md5 hash. To access external reference info navigate to the order details page.
SRC Optional
  Identifies the source of a sale by assigning a unique URL identifier. For instance, if there are two buy links on your website, one in the product page and another one in the download page, you can track the source page by entering the following parameters:
  • SRC=prodpage for the product page
  • SRC=dlpage for the link on the download page
COUPON Optional

Promotion coupon code applied to the order. Use commas (,) to separate multiple values.

Example: [...]&COUPON=voucher1,voucher2[...] 
CARD Optional

Possible values:

  • 1 to display the payment form in the selected landing page. Shoppers get to place orders from the Review page.
  • 2 to display the payment form in the selected landing page, and shoppers to place orders immediately after entering their payment data, excluding the Review page.
  Allows you to set the desired ordering interface template, overriding the default template assigned to the product group. Each template defined in the Interface Templates area of the Control Panel has a unique identifier associated which is visible in the browser address bar when previewing the shopping cart.

Requires Avangate activation before using.


Use AUTO_PREFILL=1 to set the ZIP code and country fields as mandatory. Address, City and State details are calculated automatically by the Avangate system. The address can be excluded completely. Using the AUTO_PREFILL=1 parameter without the feature being enabled for your account will result in shoppers following the classic purchase flow, where all billing address data is mandatory. 


Upgrade a specific subscription

To trigger the upgrade of a specific subscription, include the LICENSE parameter in the upgrade link, where 1A22223BC4 represents the Avangate Subscription Reference.

Domain use

  1. If your account is using the Avangate's domain, then your custom on-demand renewal links would look like this:
  2. Custom domains such as If your account is using a custom domain such as, then your custom on-demand renewal links would look like this: /order/upgrade.php?

Build on-demand upgrade links

On-demand upgrade links allow you to create your own rules in terms of product upgrades, overriding existing upgrade settings through URL parameters.

You can define:

  • The upgrade product
  • Upgrade price
  • Pricing options
  • Time interval added to the subscription lifetime

Build your upgrade links using the following parameters.

Parameter Type/Description
LICENSE Required

Specifies the subscription to be upgraded.

PROD Required
  Product ID of the target product used in the upgrade process.
PRICES(ProductId)[CURRENCY] Optional

Price and currency to be used for the upgrade product.

Example: PRICES4692644[USD]=999
PERIOD Optional
  Period of time to replace the subscription lifetime. Starts when the order is finalized. Requires PRICES parameter.
OPTIONS(ProductID) Optional

Product pricing options to be applied to the upgrade product.

Example: OPTIONS4692644=option1,option2
PHASH Required if using PRICE, PERIOD and/or OPTIONS.
  All custom upgrade links require digital signing, similar to current manual renewal links.

Upgrade a subscription with a specific price and period of time

For this example, let's assume that we need a custom on-demand upgrade link for Subscription A (monthly subscription expiring on June 30th, 2013 with the reference ABC1D2E345) associated with Product A with the ID 1234567.

Product A is offered to customers in two versions:

  • 1 user (code: 1user) - $99.99; (the customer using Subscription A opted for this particular pricing option).
  • 2 users (code: 2users) - $149.99.

You're looking to prolong the subscription lifetime with 30 days, and charge the customer $50. We'll use the some of the parameters listed above:






Build the PHASH for the link above.

  1. Using the parameters above, you get the following sequence: LICENSE=ABC1D2E345&PROD=1234567&OPTIONS1234567=1user&PRICES[USD]=50&PERIOD=30.
  2. You need to add the length of the character sequence at its beginning, to calculate the hash, namely 77. The resulting BASE STRING is 77LICENSE=ABC1D2E345&PROD=1234567&OPTIONS1234567=1user&PRICES[USD]=50&PERIOD=30.
  3. For the purpose of this demo, let's assume that your secret key is SECRET_KEY.
  4. Use the secret key and the base string to calculate the HMAC-MD5 HASH. The result should be: 32057a4f03f4ca766122040c4f2663c0 (valid exclusively for this example).
  5. Build your complete link:[USD]=50&PERIOD=30&PHASH=32057a4f03f4ca766122040c4f2663c0