# Update an order line item Note: The Order Line Items feature is now generally available to all Zuora customers. You need to enable the Orders feature to access the Order Line Items feature. As of Zuora Billing Release 313 (November 2021), new customers who onboard on Orders will have the Order Line Items feature enabled by default. If you are a new customer who onboard on Orders Harmonization and want to enable the Order Line Items feature, submit a request at Zuora Global Support. If you are an existing Orders or Orders Harmonization customer and want to enable the Order Line Items feature, submit a request at Zuora Global Support. Updates a specified order line item. The following tutorials demonstrate how to use this operation: * Update an order line item * Cancel an order line item Endpoint: PUT /v1/order-line-items/{itemId} Version: 2026-02-20 Security: bearerAuth ## Header parameters: - `Accept-Encoding` (string) Include the Accept-Encoding: gzip header to compress responses as a gzipped file. It can significantly reduce the bandwidth required for a response. If specified, Zuora automatically compresses responses that contain over 1000 bytes of data, and the response contains a Content-Encoding header with the compression algorithm so that your client can decompress it. - `Content-Encoding` (string) Include the Content-Encoding: gzip header to compress a request. With this header specified, you should upload a gzipped file for the request payload instead of sending the JSON payload. - `Zuora-Track-Id` (string) A custom identifier for tracing the API call. If you set a value for this header, Zuora returns the same value in the response headers. This header enables you to associate your system process identifiers with Zuora API calls, to assist with troubleshooting in the event of an issue. The value of this field must use the US-ASCII character set and must not include any of the following characters: colon (:), semicolon (;), double quote ("), and quote ('). - `Zuora-Entity-Ids` (string) An entity ID. If you have Zuora Multi-entity enabled and the OAuth token is valid for more than one entity, you must use this header to specify which entity to perform the operation in. If the OAuth token is only valid for a single entity, or you do not have Zuora Multi-entity enabled, you should not set this header. - `Zuora-Org-Ids` (string) Comma separated IDs. If you have Zuora Multi-Org enabled, you can use this header to specify which orgs to perform the operation in. If you do not have Zuora Multi-Org enabled, you should not set this header. The IDs must be a sub-set of the user's accessible orgs. If you specify an org that the user does not have access to, the operation fails. This header is important in Multi-Org (MO) setups because it defines the organization context under which the API should operate—mainly used for read access or data visibility filtering. If the header is not set, the operation is performed in scope of the user's accessible orgs. - `Zuora-Version` (string) The minor API version. For a list of available minor versions, see API upgrades. ## Path parameters: - `itemId` (string, required) The id of the Order Line Item to update. ## Request fields (application/json): - `UOM` (string) Specifies the units to measure usage. You can update this field only for a sales OLI and only when the sales OLI is in the Executing state (when the itemState field is set as Executing). - `accountingCode` (string) The accountingCode for the Order Line Item (OLI). You can update this field only for a sales OLI and only when the sales OLI is in the Executing state (when the itemState field is set as Executing). - `adjustmentLiabilityAccountingCode` (string) The accounting code on the Order Line Item object. This field is available only if you have enabled Order to Revenue or Zuora Billing - Revenue Integration feature. You can update this field only for a sales OLI and only when the sales OLI is in the Executing state (when the itemState field is set as Executing). - `adjustmentRevenueAccountingCode` (string) The accounting code on the Order Line Item object. This field is available only if you have enabled Order to Revenue or Zuora Billing - Revenue Integration feature. You can update this field only for a sales OLI and only when the sales OLI is in the Executing state (when the itemState field is set as Executing). - `amountPerUnit` (number) The actual charged amount per unit for the Order Line Item (OLI). You can update this field only for a sales OLI and only when the sales OLI is in the Executing state (when the itemState field is set as Executing). - `billTargetDate` (string) The target date for the Order Line Item (OLI) to be picked up by bill run for generating billing documents. To generate billing documents for an OLI, you must set this field and set the itemState field to SentToBilling. You can update this field for a sales or return OLI only when the OLI is in the Executing or Booked state. - `billTo` (string) The ID of the bill-to contact of an order line item. Specify an existing contact under the billing account as the bill-to contact of the order line item. The billing account is the order account. You can update this field only for a sales OLI and only when the sales OLI is in the Executing state (when the itemState field is set as Executing). - `billingRule` (string) The rule for billing of the Order Line Item (OLI). You can update this field for a sales or return OLI only when it is in the Executing state (when the itemState field is set as Executing). Enum: "TriggerWithoutFulfillment", "TriggerAsFulfillmentOccurs" - `contractAssetAccountingCode` (string) The accounting code on the Order Line Item object. This field is available only if you have enabled Order to Revenue or Zuora Billing - Revenue Integration feature. You can update this field only for a sales OLI and only when the sales OLI is in the Executing state (when the itemState field is set as Executing). - `contractLiabilityAccountingCode` (string) The accounting code on the Order Line Item object. This field is available only if you have enabled Order to Revenue or Zuora Billing - Revenue Integration feature. You can update this field only for a sales OLI and only when the sales OLI is in the Executing state (when the itemState field is set as Executing). - `contractRecognizedRevenueAccountingCode` (string) The accounting code on the Order Line Item object. This field is available only if you have enabled Order to Revenue or Zuora Billing - Revenue Integration feature. You can update this field only for a sales OLI and only when the sales OLI is in the Executing state (when the itemState field is set as Executing). - `customFields` (object) Container for custom fields of an Order Line Item object. - `deferredRevenueAccountingCode` (string) The deferred revenue accounting code for the Order Line Item (OLI). You can update this field only for a sales OLI and only when the sales OLI is in the Executing state (when the itemState field is set as Executing). - `description` (string) The description of the Order Line Item (OLI). You can update this field for a sales or return OLI only when the OLI is in the Executing state (when the itemState field is set as Executing). - `excludeItemBillingFromRevenueAccounting` (boolean) Indicates whether to exclude the related invoice items, invoice item adjustments, credit memo items, and debit memo items from revenue accounting. Note: This field is only available if you have the Order to Revenue or Billing - Revenue Integration feature enabled. - `excludeItemBookingFromRevenueAccounting` (boolean) Indicates whether to exclude the related rate plan charges and order line items from revenue accounting. Note: This field is only available if you have the Order to Revenue or Billing - Revenue Integration feature enabled. - `inlineDiscountPerUnit` (number) You can update this field only for a sales OLI and only when the sales OLI is in the Executing state (when the itemState field is set as Executing). Use this field in accordance with the inlineDiscountType field, in the following manner: * If the inlineDiscountType field is set as Percentage, this field specifies the discount percentage for each unit of the order line item. For exmaple, if you specify 5 in this field, the discount percentage is 5%. * If the inlineDiscountType field is set as FixedAmount, this field specifies the discount amount on each unit of the order line item. For exmaple, if you specify 10 in this field, the discount amount on each unit of the order line item is 10. Once you set the inlineDiscountType, inlineDiscountPerUnit, and listPricePerUnit fields, the system will automatically generate the amountPerUnit field. You shall not set the amountPerUnit field by yourself. - `inlineDiscountType` (string) You can update this field only for a sales OLI and only when the sales OLI is in the Executing state (when the itemState field is set as Executing). Use this field to specify the inline discount type, which can be Percentage, FixedAmount, or None. The default value is Percentage. Use this field together with the inlineDiscountPerUnit field to specify inline discounts for order line items. The inline discount is applied to the list price of an order line item. Once you set the inlineDiscountType, inlineDiscountPerUnit, and listPricePerUnit fields, the system will automatically generate the amountPerUnit field. You shall not set the amountPerUnit field by yourself. Enum: "Percentage", "FixedAmount", "None" - `isAllocationEligible` (boolean) This field is used to identify if the charge segment is allocation eligible in revenue recognition. Note: The field is only available if you have the Order to Revenue feature enabled. To enable this field, submit a request at Zuora Global Support. - `isUnbilled` (boolean) This field is used to dictate how to perform the accounting during revenue recognition. Note: The field is only available if you have the Order to Revenue feature enabled. To enable this field, submit a request at Zuora Global Support. - `itemName` (string) The name of the Order Line Item (OLI). You can update this field for a sales or return OLI only when the OLI is in the Executing state (when the itemState field is set as Executing). - `itemState` (string) The state of the Order Line Item (OLI). See [State transitions for an order, order line item, and fulfillment](https://knowledgecenter.zuora.com/Billing/Subscriptions/Orders/Order_Line_Items/AB_Order_Line_Item_States_and_Order_States) for more information. To generate invoice for an OLI, you must set this field to SentToBilling and set the billTargetDate field . You can update this field for a sales or return OLI only when the OLI is in the Executing or 'Booked' or SentToBillingstate (when the itemState field is set as Executing or SentToBilling). Enum: "Executing", "Booked", "SentToBilling", "Complete", "Canceled" - `itemType` (string) The type of the Order Line Item (OLI). You can update this field only for a sales OLI and only when the sales OLI is in the Executing state (when the itemState field is set as Executing). Enum: "Product", "Fee", "Services" - `listPricePerUnit` (number) The list price per unit for the Order Line Item (OLI). You can update this field only for a sales OLI and only when the sales OLI is in the Executing state (when the itemState field is set as Executing). - `ownerAccountNumber` (string) Use this field to assign an existing account as the owner of an order line item. You can update this field only for a sales OLI and only when the sales OLI is in the Executing state (when the itemState field is set as Executing). - `productCode` (string) The product code for the Order Line Item (OLI). You can update this field only for a sales OLI and only when the sales OLI is in the Executing state (when the itemState field is set as Executing). - `purchaseOrderNumber` (string) Used by customers to specify the Purchase Order Number provided by the buyer. You can update this field only for a sales OLI and only when the sales OLI is in the Executing state (when the itemState field is set as Executing). - `quantity` (number) The quantity of units, such as the number of authors in a hosted wiki service. You can update this field for a sales or return OLI only when the OLI in the Executing state (when the itemState field is set as Executing). - `recognizedRevenueAccountingCode` (string) The recognized revenue accounting code for the Order Line Item (OLI). You can update this field only for a sales OLI and only when the sales OLI is in the Executing state (when the itemState field is set as Executing). - `relatedSubscriptionNumber` (string) Use this field to relate an order line item to an subscription. Specify this field to the subscription number of the subscription to relate. You can update this field only for a sales OLI and only when the sales OLI is in the Executing state (when the itemState field is set as Executing). - `revenueRecognitionRule` (string) The Revenue Recognition rule for the Order Line Item (OLI). You can update this field only for a sales OLI and only when the sales OLI is in the Executing state (when the itemState field is set as Executing). - `revenueRecognitionTiming` (string) Specifies the type of revenue recognition timing. Predefined options are listed as enum values in this API Reference. Other options might also be avaliable depending on the revenue recognition policy configuration in the Zuora Billing UI. You can update this field only for a sales OLI and only when the sales OLI is in the Executing state (when the itemState field is set as Executing). Note: This field is only available if you have the Order to Revenue feature enabled. Enum: "Upon Billing Document Posting Date", "Upon Order Activation Date" - `revenueAmortizationMethod` (string) Specifies the type of revenue amortization method. Predefined options are listed as enum values in this API Reference. Other options might also be avaliable depending on the revenue recognition policy configuration in the Zuora Billing UI. You can update this field only for a sales OLI and only when the sales OLI is in the Executing state (when the itemState field is set as Executing). Note: This field is only available if you have the Order to Revenue feature enabled. Enum: "Immediate", "Ratable Using Start And End Dates" - `invoiceGroupNumber` (string,null) The number of the invoice group associated with the order line item. After enabling the Invoice Grouping feature, you can specify invoice group numbers to bill subscriptions and order line items based on specific criteria. For the same account, Zuora generates separate invoices for subscriptions and order line items, each identified by unique invoice group numbers. For more information, see [Invoice Grouping](https://knowledgecenter.zuora.com/Billing/Subscriptions/Invoice_Grouping). Note: - If you have the Flexible Billing Attributes feature disabled, this field is unavailable in the request body and the value of this field is null in the response body. - If you have the Flexible Billing Attributes feature enabled, and you do not specify this field in the request during subscription creation, the value of this field is automatically set to null in the response body. - You can specify this field on a sales order line item when its state (that is, the itemState field) is Executing, Booked, or SentToBilling. - `sequenceSetId` (string) The ID or number of the sequence set associated with the order line item. Note: - If you have the Flexible Billing Attributes feature disabled, this field is unavailable in the request body and the value of this field is null in the response body. - If you have the Flexible Billing Attributes feature enabled, and you do not specify this field in the request during subscription creation, the value of this field is automatically set to null in the response body. - You can specify this field on a sales order line item when its state (that is, the itemState field) is Executing, Booked, or SentToBilling. - `paymentTerm` (string) The payment term name associated with the order line item. Note: - If you have the Flexible Billing Attributes feature disabled, this field is unavailable in the request body and the value of this field is null in the response body. - If you have the Flexible Billing Attributes feature enabled, and you do not specify this field in the request during subscription creation, the value of this field is automatically set to null in the response body. - You can specify this field on a sales order line item when its state (that is, the itemState field) is Executing, Booked, or SentToBilling. - `invoiceTemplateId` (string) The ID of the invoice template associated with the order line item. Note: - If you have the Flexible Billing Attributes feature disabled, this field is unavailable in the request body and the value of this field is null in the response body. - If you have the Flexible Billing Attributes feature enabled, and you do not specify this field in the request during subscription creation, the value of this field is automatically set to null in the response body. - You can specify this field on a sales order line item when its state (that is, the itemState field) is Executing, Booked, or SentToBilling. - `shipTo` (string) Use this field to assign an existing account as the ship-to contact of an order line item, by the following rules: * If the ownerAccountNumber field is set, then this field must be the ID of a contact that belongs to the owner account of the order line item. * If the ownerAccountNumber field is not set, then this field must be the ID of a contact that belongs to the billing account of the order line item. The billing account is the order account. You can update this field only for a sales OLI and only when the sales OLI is in the Executing state (when the itemState field is set as Executing). - `soldTo` (string) Use this field to assign an existing account as the sold-to contact of an order line item, by the following rules: * If the ownerAccountNumber field is set, then this field must be the ID of a contact that belongs to the owner account of the order line item. * If the ownerAccountNumber field is not set, then this field must be the ID of a contact that belongs to the billing account of the order line item. The billing account is the order account. You can update this field only for a sales OLI and only when the sales OLI is in the Executing state (when the itemState field is set as Executing). - `taxCode` (string) The tax code for the Order Line Item (OLI). You can update this field only for a sales OLI and only when the sales OLI is in the Executing state (when the itemState field is set as Executing). - `taxMode` (string) The tax mode for the Order Line Item (OLI). You can update this field only for a sales OLI and only when the sales OLI is in the Executing state (when the itemState field is set as Executing). Enum: "TaxInclusive", "TaxExclusive" - `transactionEndDate` (string) The date a transaction is completed. The default value of this field is the transaction start date. Also, the value of this field should always equal or be later than the value of the transactionStartDate field. You can update this field for a sales or return OLI only when the OLI is in the Executing state (when the itemState field is set as Executing). - `transactionStartDate` (string) The date a transaction starts. The default value of this field is the order date. You can update this field for a sales or return OLI only when the OLI is in the Executing state (when the itemState field is set as Executing). - `unbilledReceivablesAccountingCode` (string) The accounting code on the Order Line Item object. This field is available only if you have enabled Order to Revenue or Zuora Billing - Revenue Integration feature. You can update this field only for a sales OLI and only when the sales OLI is in the Executing state (when the itemState field is set as Executing). ## Response 200 fields (application/json): - `processId` (string) The ID of the process that handles the operation. - `reasons` (array) The container of the error code and message. This field is available only if the success field is false. - `reasons.code` (string) The error code of response. - `reasons.message` (string) The detail information of the error response - `requestId` (string) Unique identifier of the request. - `success` (boolean) Indicates whether the call succeeded. ## Response 500 fields (application/json): - `reasons` (array) Example: [{"code":"ObjectNotFound","message":"Notification definition with id 6e569e1e05f040eda51a927b140c0ac1 does not exist"}] - `reasons.code` (string) The error code of response. - `reasons.message` (string) The detail information of the error response ## Response 4XX fields (application/json): - `processId` (string) The ID of the process that handles the operation. - `reasons` (array) The container of the error code and message. This field is available only if the success field is false. - `reasons.code` (string) The error code of response. - `reasons.message` (string) The detail information of the error response - `requestId` (string) Unique identifier of the request. - `success` (boolean) Indicates whether the call succeeded.