Issuing policies

Use the following endpoint to issue policies in BillingCenter:

  • POST billing/v1/accounts/{accountId}/issuances

Minimum creation criteria

The policy issuance request object consists of several required objects and one array. Some of these top-level entities have required fields. The following table details these entities and their required fields:

Object Description Required fields
charges

An array of charge objects.

For each charge object:

  • amount
  • chargePattern
paymentPlan

An object specifying the policy’s payment plan.

  • id
policy

An object containing optional information about the policy.

No required fields

policyPeriod

An object containing information on the policy period.

  • effectiveDate
  • expirationDate
  • policyNumber

Minimal policy issuance request

The following request provides an example of issuing a minimal policy on account bc:101

POST /billing/v1/accounts/bc:101/issuances
{
    "data": {
        "attributes": {
            "charges": [
                {
                    "amount": {
                        "amount": "1200",
                        "currency": "USD"
                    },
                    "chargePattern": {
                        "id": "default_data:1",
                    }
                },
                {
                    "amount": {
                        "amount": "60",
                        "currency": "USD"
                    },
                    "chargePattern": {
                        "id": "default_data:6",
                    }
                }
            ],
            "paymentPlan": {
                "id": "bc:SseFjlFaE9xxBLBG1ZRNR"
            },
            "policy": {},
            "policyPeriod": {
                "effectiveDate": "2023-12-11",
                "expirationDate": "2024-12-11",
                "policyNumber": "PA-234553"
            }
        }
    }
}
Java

This request performs the following:

  • Creates a personal auto policy with the policy number PA-234553
  • Creates a policy period on that policy
  • Sets the payment plan to an existing payment plan
  • Creates two charges on the policy period: one $1200 premium charge and one $60 tax charge. The charge pattern is identified by the id.
Note: In this example, there is no need to specify any fields for the policy itself. But the policy object is always required, even when there are no fields to specify. This is why the payload includes an empty policy object.

The issuance response object

The minimal POST request provided above returns the following response object.
POST /billing/v1/accounts/bc:101/issuances

{
    "data": {
        "attributes": {
            "charges": [
                {
                    "amount": {
                        "amount": "1200.00",
                        "currency": "usd"
                    },
                    "chargeDate": "2023-12-12T17:29:05.022Z",
                    "chargePattern": {
                        "displayName": "Premium",
                        "id": "default_data:1",
                        "type": "ChargePattern",
                        "uri": "/admin/v1/charge-patterns/default_data:1"
                    },
                    "holdStatus": {
                        "code": "none",
                        "name": "Not Held"
                    },
                    "id": "bc:SFy0AE8LdXyShiK08inYY",
                    "reversed": false,
                    "skipInvoiceItemCreation": false,
                    "totalInstallments": 9
                },
                {
                    "amount": {
                        "amount": "60.00",
                        "currency": "usd"
                    },
                    "chargeDate": "2023-12-12T17:29:05.022Z",
                    "chargePattern": {
                        "displayName": "Taxes",
                        "id": "default_data:6",
                        "type": "ChargePattern",
                        "uri": "/admin/v1/charge-patterns/default_data:6"
                    },
                    "holdStatus": {
                        "code": "none",
                        "name": "Not Held"
                    },
                    "id": "bc:SakMlRBrLNvF0Crvj2Mrl",
                    "reversed": false,
                    "skipInvoiceItemCreation": false,
                    "totalInstallments": 0
                }
            ],
            "createTime": "2023-12-12T17:29:05.022Z",
            "executed": true,
            "id": "bc:SZVcFGJg56XPQPrtq8HUG",
            "paymentPlan": {
                "displayName": "A Monthly 10% Down, 9 Max installments",
                "id": "bc:SseFjlFaE9xxBLBG1ZRNR",
                "type": "PaymentPlan",
                "uri": "/admin/v1/payment-plans/bc:SseFjlFaE9xxBLBG1ZRNR"
            },
            "policy": {
                "createTime": "2023-12-12T17:29:05.022Z",
                "currency": {
                    "code": "usd",
                    "name": "USD"
                },
                "displayName": "PA-234553",
                "doNotArchive": false,
                "id": "bc:S6UbABC8vyTq2lKgu3GVK"
            },
            "policyPeriod": {
                "assignedRisk": false,
                "billingMethod": {
                    "code": "DirectBill",
                    "name": "Direct Bill"
                },
                "boundDate": "2023-12-11",
                "cancelStatus": {
                    "code": "open",
                    "name": "Open"
                },
                "chargeHeld": false,
                "closureStatus": {
                    "code": "open",
                    "name": "Open"
                },
                "confirmationNotificationState": {
                    "code": "DoNotNotify",
                    "name": "Do Not Notify"
                },
                "currency": {
                    "code": "usd",
                    "name": "USD"
                },
                "effectiveDate": "2023-12-11",
                "eligibleForFullPayDiscount": false,
                "equityBuffer": 30,
                "equityWarningsEnabled": true,
                "expirationDate": "2024-12-11",
                "fullPayDiscountEvaluated": false,
                "heldForInvoiceSending": false,
                "holdInvoicingWhenDelinquent": false,
                "id": "bc:S-r07gO0hbKuQwcUoeAWf",
                "paymentDistributionEnabled": true,
                "paymentPlan": {
                    "displayName": "A Monthly 10% Down, 9 Max installments",
                    "id": "bc:SseFjlFaE9xxBLBG1ZRNR",
                    "type": "PaymentPlan",
                    "uri": "/admin/v1/payment-plans/bc:SseFjlFaE9xxBLBG1ZRNR"
                },
                "pendingRemainingBalanceFix": false,
                "policyNumber": "PA-234553",
                "policyNumberLong": "PA-234553-1",
                "retrieved": false,
                "returnPremiumPlan": {
                    "displayName": "Default Return Premium Plan",
                    "id": "ret_premium_plan:1",
                    "type": "ReturnPremiumPlan",
                    "uri": "/admin/v1/return-premium-plans/ret_premium_plan:1"
                },
                "termConfirmed": true,
                "termNumber": 1,
                "westernMethod": false
            }
        },
        "checksum": "0"
    }
}
Java

Specifying additional information

When specifying policy and policy period details, take note of the following guidelines.

Overriding payer accounts and invoice streams - Invoice streams must be on the same account as the payer account. If you add an overriding payer account, the invoice stream will automatically be set to this payer’s default invoice stream. This can be set on either the policy period or on specific charges.

Policy number - The policy number for a newly issued policy must be unique.

Currency - Payment plans and delinquency plans have arrays of supported currencies. The payer account’s currency must be included in those arrays.

In a mono-currency instance of BillingCenter, any monetary amount specified in a request must have the same currency as the payer account. This includes charges, deposit requirements, and other monetary information provided in the policyPeriod object. Additionally, the overriding payer account and the account that owns the policy must both have the same currency.

In a multicurrency instance of BillingCenter, the currency of a charge can be different than the account's currency. However, as of this release, Cloud API does not support billing requests where the currency of any charge is different than the account's currency. For billing requests submitted through Cloud API, all charges must have the same currency as the associated account

Charge breakdowns - As of this release, Cloud API does not support adding charge breakdown information when issuing a policy.

Billing method - As of this release, the only supported billing method is direct bill.