Create a new subscription
POST /accounts/{account_id}/core/v1/subscriptions
Indicates desired values for the Subscription API resource to be created.
Parameters
Name | Type | In | Required | Description |
---|---|---|---|---|
account_id |
string |
path |
True |
ID of the containing account resource
|
Request Body
Indicates desired values for the Subscription API resource to be created.
Name | Type | Required | Description |
---|---|---|---|
type |
string |
True |
Media type of the resource. Defined values are:
|
version |
string |
True |
Version of the resource. Defined values are:
|
customerProfileID |
string |
False |
JSON string containing the customer profile ID from Authorize.net, which was invoked by the UI, is not set for the trial term. Returns an empty string during read operation, if not set. Defined values are:
|
paymentFirstName |
string |
False |
JSON string containing a user-specified long-form first name used for payment billing. Specified only when the subscription is being rebilled. Defined values are:
|
paymentLastName |
string |
False |
JSON string containing a user-specified long-form last name used for payment billing. Specified only when the subscription is being rebilled. Defined values are:
|
paymentAddress |
False |
JSON object containing a collection of JSON strings specifying a billing address. Specified only when the subscription is being rebilled. If this key exists, all six of the contained JSON strings will be present. If nothing was provided by the user, the string will be empty. |
|
paymentProfileID |
string |
False |
JSON string containing the payment profile ID from Authorize.net that was invoked by the UI, not set for trial term. Returns an empty string during read operation if not set. Defined values are:
|
paymentExpiry |
string |
False |
JSON string containing a timestamp indicating when the payment method expires. This is obtained from authorize.net](http://authorize.net) and is set by the UI. Defined values are:
|
marketplace |
string |
False |
JSON string indicating the marketplace for an account where payments will be recorded. Defined values:
|
terms |
string |
True |
JSON string indicating the current tier of the account. Defined values are:
|
metadata |
False |
Client and service-specified metadata associated with the resource. Defined values are:
|
Example request
Response
Status: 201, Returns the newly created subscription resource in the JSON response body.
Name | Type | Required | Description |
---|---|---|---|
type |
string |
True |
Media type of the resource. Defined values are:
|
version |
string |
True |
Version of the resource. Defined values are:
|
id |
string |
True |
Globally unique identifier of the resource. Defined values are:
|
customerProfileID |
string |
True |
JSON string containing the customer profile ID from Authorize.net, which was invoked by the UI, is not set for the trial term. Returns an empty string during read operation, if not set. Defined values are:
|
paymentProfileID |
string |
False |
JSON string containing the payment profile ID from Authorize.net that was invoked by the UI, not set for trial term. Returns an empty string during read operation if not set. Defined values are:
|
paymentExpiry |
string |
False |
JSON string containing a timestamp indicating when the payment method expires. This is obtained from authorize.net](http://authorize.net) and is set by the UI. Defined values are:
|
purchaseOrderNumber |
string |
False |
JSON string containing the purchase order number for the payment method. Defined values are:
|
marketplace |
string |
False |
JSON string indicating the marketplace for an account where payments will be recorded. Defined values:
|
licenseSN |
string |
False |
JSON string containing the license serial number for the payment method. Defined values are:
|
terms |
string |
True |
JSON string indicating the current tier of the account. Defined values are:
|
status |
string |
True |
JSON string indicating the current status of the subscription. Defined values are:
|
appLimit |
number |
True |
JSON number indicating the application limit for this subscription. Value of -1 indicates no limit. |
namespaceLimit |
number |
True |
JSON number indicating the namespace limit for this subscription. Value of -1 indicates no limit. |
subscriptionPeriod |
number |
True |
JSON number indicating the subscription period. Value of -1 indicates no limit. Unit: days |
gracePeriod |
number |
True |
JSON number indicating the grace period after the trial subscription has expired or a paid subscription is canceled. Unit: days |
reminderBeforePeriod |
number |
True |
JSON number indicating the number of days before the end of the trial subscription we should start notifying the customer. Value of -1 indicates N/A. Unit: days |
onboardStatus |
string |
True |
JSON string indicating the current status of customer onboarding. Valid values are "not started", "in progress", "success", "failed". Defined values are:
|
costPerAppUnit |
number |
True |
JSON number indicating the cost per app unit. For a trial version, the value would be 0. Unit: US dollars |
costPerNamespaceUnit |
number |
True |
JSON number indicating the cost per namespace unit. For a trial version, the value would be 0. Unit: US dollars |
metadata |
True |
Client and service-specified metadata associated with the resource. Defined values are:
|
Example response
Response
Status: 401, Unauthorized
Name | Type | Required | Description |
---|---|---|---|
type |
string |
True |
|
title |
string |
True |
|
detail |
string |
False |
|
status |
string |
True |
|
correlationID |
string |
False |
Example response
Response
Status: 400, Bad request
Name | Type | Required | Description |
---|---|---|---|
type |
string |
True |
|
title |
string |
True |
|
detail |
string |
False |
|
status |
string |
True |
|
correlationID |
string |
False |
|
invalidFields |
array[invalidFields] |
False |
List of invalid request body fields |
Example response
Response
Status: 409, Conflict
Name | Type | Required | Description |
---|---|---|---|
type |
string |
True |
|
title |
string |
True |
|
detail |
string |
False |
|
status |
string |
True |
|
correlationID |
string |
False |
|
invalidFields |
array[invalidFields] |
False |
List of invalid request body fields |
Example response
Response
Status: 403, Forbidden
Name | Type | Required | Description |
---|---|---|---|
type |
string |
True |
|
title |
string |
True |
|
detail |
string |
False |
|
status |
string |
True |
|
correlationID |
string |
False |
Example response
Error
Status: 404, Not found
Name | Type | Required | Description |
---|---|---|---|
type |
string |
True |
|
title |
string |
True |
|
detail |
string |
False |
|
status |
string |
True |
|
correlationID |
string |
False |
Example error response
Definitions
See Definitions
paymentAddress
JSON object containing a collection of JSON strings specifying a billing address. Specified only when the subscription is being rebilled. If this key exists, all six of the contained JSON strings will be present. If nothing was provided by the user, the string will be empty.
Name | Type | Required | Description |
---|---|---|---|
addressCountry |
string |
True |
JSON string containing the country name or country code associated with the postal address, as specified in ISO 3166 Alpha-2. Defined values are:
|
addressLocality |
string |
True |
JSON string containing the locality (for example, city) associated with the postal address. Defined values are:
|
addressRegion |
string |
True |
JSON string containing the region (for example, state) associated with the postal address. Defined values are:
|
postalCode |
string |
True |
JSON string containing the postal code associated with the postal address. Defined values are:
|
streetAddress1 |
string |
True |
JSON string containing the street address associated with the postal address. Defined values are:
|
streetAddress2 |
string |
False |
JSON string containing optional ancillary street address information, post office box, and more. Defined values are:
|
type_astra_label
Name | Type | Required | Description |
---|---|---|---|
name |
string |
True |
|
value |
string |
True |
type_astra_metadata_update
Client and service-specified metadata associated with the resource. Defined values are:
-
Conforms to the Astra Metadata Schema If not specified on create, a metadata object will be created with no labels. If not specified on update, the metadata object's labels, creationTimestamp and createdBy, will be preserved without modification.
Name | Type | Required | Description |
---|---|---|---|
labels |
array[type_astra_label] |
False |
|
creationTimestamp |
string |
False |
|
modificationTimestamp |
string |
False |
|
createdBy |
string |
False |
|
modifiedBy |
string |
False |
invalidParams
Name | Type | Required | Description |
---|---|---|---|
name |
string |
True |
Name of the invalid query parameter |
reason |
string |
True |
Reason why the query parameter is invalid |
invalidFields
Name | Type | Required | Description |
---|---|---|---|
name |
string |
True |
Name of the invalid request body field |
reason |
string |
True |
Reason why the request body field is invalid |