# Create a new subscription Creates a new subscription for a customer with specified billing plan and schedule. The subscription will be created in 'created' status and will be activated when the customer completes the first payment. Endpoint: POST /subscriptions Version: 1.0.0 Security: JWT ## Request fields (application/json): - `customer_id` (string, required) Unique identifier of the customer associated with this subscription. Example: "cust_5JU9yv0lGSUP" - `product_name` (string, required) Name of the product being subscribed to. Example: "ShieldGuard Insurance" - `product_description` (string, required) Description of the product. Example: "Flexible, monthly insurance for belongings, travel, and digital assets; easy to manage" - `plan_name` (string) Name of the subscription plan. Example: "ShieldGuard Lite" - `plan_description` (string) Description of the subscription plan. Example: "Simple, monthly insurance plan that covers your basic belongings and key digital assets" - `amount` (number, required) The amount in the smallest currency unit. For example, if the amount is $299.00, then 29900 is passed in this field. In the case of three decimal currencies, such as KWD, BHD and OMR, to represent an amount of 295.991, pass the value as 295990. And in the case of zero decimal currencies such as JPY, for amount ¥295, pass the value as 295. - `currency` (string, required) The currency code in [ISO 4217](https://en.wikipedia.org/wiki/ISO_4217) format. - `interval_type` (string, required) Used in combination with interval_count to define the billing cycle frequency. Enum: "month", "year" - `interval_count` (integer, required) Number of intervals between a billing cycle, used in combination with interval_type. Valid combinations: - Monthly: interval_type='month', interval_count=1 - Quarterly: interval_type='month', interval_count=3 - Half-yearly: interval_type='month', interval_count=6 - Yearly: interval_type='year', interval_count=1 Enum: 1, 3, 6 - `billing_cycles` (integer, required) Total number of billing cycles for the subscription. A subscription can have a lifetime of 10 years. Maximum billing cycles therefore depend on interval: - Monthly (interval_type='month', interval_count=1): max 120 cycles - Quarterly (interval_type='month', interval_count=3): max 40 cycles - Half-yearly (interval_type='month', interval_count=6): max 20 cycles - Yearly (interval_type='year', interval_count=1): max 10 cycles Example: 12 - `start_date` (string, required) Start date of the subscription in UTC timezone and ISO 8601 format (YYYY-MM-DD). Must be today or in the future. Example: "2025-01-01" - `expires_at` (string, required) Expiration date for the subscription payment link in UTC timezone and ISO 8601 format (YYYY-MM-DD). Must be >= start_date and cannot be more than 6 months from start_date. Example: "2025-01-07" - `notify_customer` (boolean, required) Whether to send notification e-mails to customers for subscription lifecycle changes. Example: true - `starts_with_first_payment` (boolean, required) Whether the subscription payment schedule should get synchronized with the first payment. Example: true ## Response 201 fields (application/json): - `id` (string, required) Unique identifier for the subscription. Example: "sub_5JU9yv0lGSUP" - `customer_id` (string, required) Unique identifier of the customer associated with this subscription. Example: "cust_5JU9yv0lGSUP" - `product_name` (string, required) Name of the product being subscribed to. Example: "ShieldGuard Insurance" - `product_description` (string, required) Description of the product. Example: "Flexible, monthly insurance for belongings, travel, and digital assets, easy to manage" - `plan_name` (string) Name of the subscription plan. Example: "ShieldGuard Lite" - `plan_description` (string) Description of the subscription plan. Example: "Simple, monthly insurance plan that covers your basic belongings and key digital assets" - `reference_number` (string) optional identifier to be sent for reconciliations Example: "R0001" - `status` (string, required) Current status of the subscription. Enum: "created", "active", "paused", "expired", "failed", "halted", "cancelled", "completed", "authorized" - `amount` (number, required) The amount in the smallest currency unit. For example, if the amount is $299.00, then 29900 is passed in this field. In the case of three decimal currencies, such as KWD, BHD and OMR, to represent an amount of 295.991, pass the value as 295990. And in the case of zero decimal currencies such as JPY, for amount ¥295, pass the value as 295. - `currency` (string, required) The currency code in [ISO 4217](https://en.wikipedia.org/wiki/ISO_4217) format. - `interval_type` (string, required) Used in combination with interval_count to define the billing cycle frequency. Enum: "month", "year" - `interval_count` (integer, required) Number of intervals between a billing cycle, used in combination with interval_type. Valid combinations: - Monthly: interval_type='month', interval_count=1 - Quarterly: interval_type='month', interval_count=3 - Half-yearly: interval_type='month', interval_count=6 - Yearly: interval_type='year', interval_count=1 Enum: 1, 3, 6 - `billing_cycles` (integer, required) Total number of billing cycles for the subscription. Example: 12 - `start_date` (string, required) Start date of the subscription in UTC timezone and ISO 8601 format (YYYY-MM-DD). Example: "2025-01-01" - `end_date` (string, required) The date on which the subscription ends in UTC timezone and ISO 8601 format (YYYY-MM-DD). Example: "2025-12-01" - `expires_at` (string, required) Expiration date for the subscription payment link in UTC timezone and ISO 8601 format (YYYY-MM-DD). Example: "2025-01-07" - `next_payment_date` (string,null) Date of the next scheduled payment in UTC timezone and ISO 8601 format (YYYY-MM-DD). Example: "2025-02-01" - `subscription_link_url` (string, required) URL for the subscription payment page. Your customer can use this URL to make the first payment and activate the subscription. Example: "https://checkout.glomopay.com/subscription/sub_5JU9yv0lGSUP" - `cancelled_at` (string,null) Date when the subscription was cancelled in UTC timezone and ISO 8601 format (YYYY-MM-DD). This field is null unless the subscription status is 'cancelled'. Example: "2025-01-15" - `notes` (object) Any additional notes for the order Example: {"key1":"value1","key2":"value2"} ## Response 400 fields (application/json): - `error` (string) Enum: "Bad Request" - `message` (string) Error message describing the validation failure Example: "Customer not found"