The invoice creation process can be broken up into the following steps:
Create an invoice: create a draft invoice and set the currency.
Configure the invoice: add associations to CRM records, such as a contact and line items to the invoice, properties, and configure payment settings.
Move the invoice status to open: move the invoice status from draft to open.
Share the invoice: share the invoice with the buyer.
To create an invoice, you’ll first configure its basic details by making a POST request to /crm/v3/objects/invoices.In the post body, include a properties object to store basic invoice information. The only property required for creating a draft invoice is hs_currency. You can modify a drafted invoice’s properties any time by updating the invoice. Additionally, the invoice will inherit other property values when you later associate a contact with it, such as contact and company details, which will be required before you can set the invoice to the Open state. Learn more about required properties and associations.
The response will include an id, which you’ll use to continue configuring the invoice. You can update invoice properties at any time by making a PATCH request to /crm/v3/objects/invoices/{invoiceId}.
To move the invoice to the open status so that it can be shared and paid, you’ll need to set a few required properties and associate it with other CRM records, such as line items and a contact. If you’ve set up HubSpot payments or Stripe payment processing, you can also configure the invoice’s payment settings.Below, learn more about:
To update an invoice’s properties, make a PATCH request to /crm/v3/objects/invoices/{invoiceId}. In the request body, include a properties object with fields for the properties you want to update.
The table below lists which properties are required for an invoice, and others that are set automatically. For an expanded list of available properties, see the common properties reference section.
Property
Description
hs_currency
Currency of the invoice.
hs_invoice_date
Date of the invoice. This is autoset if a date isn’t provided.
hs_due_date
Due date of the invoice. This is autoset if a date isn’t provided.
hs_tax_id
The account tax ID listed on this invoice. The tax ID includes a tax ID type and a tax ID number. This property must match a tax ID in the account settings. Or, it will autoset. Learn more about tax IDs.
To associate other CRM records with the invoice, make a PUT request to /crm/v4/objects/invoices/{fromObjectId}/associations/default/{toObjectType}/{toObjectId}.The table below show which CRM record associations are required to move the invoice to the Open state, and which are optional. View a full list of the objects can be associated with invoices.
Please note:A Draft invoice can be created without any associations.
The goods and/or services being sold through the invoice. You can create line items from products in your product library or create custom standalone line items.
Any discounts, fees, and taxes to be applied at checkout. When determining the total invoice amount, HubSpot first applies discounts, followed by fees, then taxes. You can use the hs_sort_order field to reorder objects of the same type. Can be set to fixed values or percentages by setting hs_type to either FIXED or PERCENT.
To make each association, you’ll first need to retrieve the ID of each object you want to associate. To retrieve each ID, you’ll make a GET request to the relevant object endpoint, which follows the same pattern across each CRM object.
Report incorrect code
Copy
Ask AI
#GET request for line itemscurl --request GET \ --url 'https://api.hubapi.com/crm/v3/properties/line_items?archived=false' \ --header 'authorization: Bearer YOUR_ACCESS_TOKEN'#GET request for contactscurl --request GET \ --url 'https://api.hubapi.com/crm/v3/properties/contacts?archived=false' \ --header 'authorization: Bearer YOUR_ACCESS_TOKEN'#GET request for companiescurl --request GET \ --url 'https://api.hubapi.com/crm/v3/properties/companies?archived=false' \ --header 'authorization: Bearer YOUR_ACCESS_TOKEN'#GET request for discountscurl --request GET \ --url 'https://api.hubapi.com/crm/v3/properties/discounts?archived=false' \ --header 'authorization: Bearer YOUR_ACCESS_TOKEN'#GET request for feescurl --request GET \ --url 'https://api.hubapi.com/crm/v3/properties/fees?archived=false' \ --header 'authorization: Bearer YOUR_ACCESS_TOKEN'#GET request for taxescurl --request GET \ --url 'https://api.hubapi.com/crm/v3/properties/taxes?archived=false' \ --header 'authorization: Bearer YOUR_ACCESS_TOKEN'
Each successful call will return a 200 response with details for each fetched object type. You’ll use the value in the id field to set associations in the next step.
A non-billable invoice won’t render, meaning an invoice document won’t be created, and other invoice functionalities, such as validation, email, and notifications, will not be included. This could be useful if you want to track invoice data in HubSpot, but manage or bill the invoices outside of HubSpot.To make an invoice non-billable, create an invoice, making a POST request to /crm/v3/objects/invoices and include the hs_invoice_billable property.
If your account is set up to collect digital payments using HubSpot payments or Stripe payment processing, and the currency of the invoice is set to a currency that is valid for transacting, the invoice will automatically be configured to collect payments. In addition, other properties will automatically be set based on the account payment settings.The properties below can be amended if required. This is not an exhaustive list. To get a list of all available properties, make a GET request to /crm/v3/objects/invoices.
Parameter
Type
Description
hs_allowed_payment_methods
Enumeration
The payment methods to be used. For example, credit_or_debit_card, ach.
Set to manual if you want the invoice to have digital payment capability. Set to none if you don’t want digital payment capability. If no value, autoset based on the account payment settings.
hs_collect_address_types
Boolean
The types of addresses that are collected while paying the invoice. Value can be billing_address and/or shipping_address.
You can add taxes to an invoice in two different ways depending on your use case:
Add taxes to individual line items by setting the hs_tax_rate_group_id property when you create an invoice. You’ll first need to set up tax rates in your account before associating them with line items. You’ll need to authorize the tax_rates.read scope for your app to fetch tax rates and the crm.objects.line_items.write scope to update or create a line item.
Use the tax object to add taxes to the entire invoice, applying taxes to the total amount of the invoice.
To associate a tax rate with a line item of an invoice, first make a GET request to /tax-rates/v1/tax-rates to fetch all tax rates. The resulting response will resemble the following:
You can then use the id of one of your tax rates as the hs_tax_rate_group_id when creating or updating a line item. Learn more about setting up tax rates in the line items API guide.
Rather than apply an existing tax rate to individual line items, you can instead apply a tax to the entire invoice order. An invoice-level tax has a 1:1 relationship with the invoice, meaning the tax must be unique to the invoice. However, an invoice can include multiple taxes.To add taxes to an entire invoice order:
An invoice can be set to one of four statuses, as set by the hs_invoice_status property:
Status
Description
draft
The invoice is being edited and is not yet ready to be sent.
open
The invoice has all of the details needed to be sent to the buyer, and is payable.
paid
The buyer has paid the invoice.
voided
The invoice has been voided.
When creating an invoice, you may want to set its status to draft until it’s ready to be sent to the buyer. Once all of the required properties and associations are added to the invoice, you can update its status to open, meaning the invoice can be shared and is payable.To move the invoice to the open status, make a PATCH request to /crm/v3/objects/invoices and set the hs_invoice_status property to open.
Please note:To move an invoice to the Open status (open invoice that is payable), one contact and at least one line item must be associated.
Depending on the information you need, there are a few ways to retrieve invoices:
To retrieve all invoices, make a GET request to crm/v3/objects/invoices.
To retrieve a specific invoice, make a GET request to the above URL and specify an invoice ID. For example: crm/v3/objects/invoices/44446244097.
To retrieve invoices that meet a specific set of criteria, you can make a POST request to the search endpoint and include filters in the request body. See an example of using the search endpoint below.
The response will include a few default properties, including the create date, last modified date.
For reference, review the list of common properties below. To view all available invoice properties, make a GET request to crm/v3/properties/invoices. Learn more about using the properties API.
You can use the search endpoint to retrieve invoices that meet a specific set of filter criteria. This will be a POST request that includes your filter criteria in the request body.For example, to search for all open invoices, you would make a POST request to crm/v3/objects/invoices/search with the following request body:
To retrieve association information for an invoice,make a GET request to the following URL:crm/v3/objects/invoice/{`hs_object_id}`/associations/{associatedObjectName}Associated objects can include contacts, companies, deals, line items, discounts, fees, and taxes.For example, to retrieve an invoice and the line items associated with it, make a GET request to:crm/v3/objects/invoice/{invoiceId}/associations/line_itemsThis will return the IDs of the currently associated line items, along with meta information about the association type.
You can then use the returned IDs to request more information about the line items through the line items API. For example, you could batch retrieve line items by ID by making a POST request to the following URL with the request body below:crm/v3/objects/line_items/batch/read
Please note:Line items belong to one single parent object. For example, if retrieving line items from an invoice, the line item IDs will be different to those on a deal, or a quote.
Below is a list of properties commonly used. This is not an exhaustive list. To get a list of all available properties, make a GET request to /crm/v3/objects/invoices.
Parameter
Type
Description
hs_currency
String
Currency of the invoice.
hs_invoice_date
Date/time
Date of the invoice. Autoset if one is not provided.
hs_due_date
Date/time
Due date of the invoice. Autoset if one is not provided.
hs_purchase_order_number
String
Add an associated PO number.
hs_comments
String
Add comments to the invoice for the buyer to see.
hs_tax_id
Enumeration
The account tax ID listed on this invoice. The tax ID includes a tax ID type and a tax ID number. This property must match a tax ID in the account settings. Or, it will autoset. Learn more about tax ID’s.
hs_allowed_payment_methods
Enumeration
The payment methods to be used. For example, credit_or_debit_card, ach.
Set to manual if you want the invoice to have digital payment capability. Set to none if you don’t want digital payment capability. If no value, autoset based on the account payment settings.
hs_allow_partial_payments
Boolean
Allow your customer to pay less than the balance due.
hs_collect_address_types
Boolean
The types of addresses that are collected while paying the invoice. Value can be billing_address and/or shipping_address.
hs_recipient_shipping_address
String
The shipping address of the recipient. This address is used as the billing address.
hs_recipient_shipping_address2
String
The second line of the shipping address of the recipient. This address is used as the billing address.
hs_recipient_shipping_city
String
The shipping city of the recipient.
hs_recipient_shipping_state
String
The shipping state or region of the recipient.
hs_recipient_shipping_zip
String
The shipping postal or zip code of the recipient. This postal or zip code is used as the billing postal or zip code.
hs_recipient_shipping_country
String
The shipping country of the recipient.
hs_recipient_company_address
String
The address of the recipient’s company.
hs_recipient_company_address2
String
The second line of the address of the recipient’s company.
hs_recipient_company_city
String
The city of the recipient’s company.
hs_recipient_company_state
String
The state or region of the recipient’s company.
hs_recipient_company_zip
String
The postal or zip code of the recipient’s company.