Creating a Order
This API creates an order for a specific Account and Price List.
API |
Signature |
---|---|
createOrder |
webService static Apttus_CPQApi.CPQ.CreateOrderResponseDO createOrder(Apttus_CPQApi.CPQ.CreateOrderRequestDO request) |
Parameters |
|||
---|---|---|---|
Name |
Type |
Required? |
Description |
request |
|
Yes |
The request data object. |
Request Data Object - Apttus_CPQApi.CPQ.CreateOrderRequestDO |
||
---|---|---|
Field |
Type |
Description |
CustomFields |
List<String> |
List of Custom fields which can be used in Order Creation. |
OrderInput |
Apttus_Config2__Order__c |
The Order Object |
OrderItems |
List<Apttus_CPQApi.CPQ.SelectedProductDO> |
List of Order Items |
OrderItemSource |
String |
The source from where the Order is getting created. |
Properties |
List<Apttus_Config2.Property> |
List of properties |
Response Data Object - Apttus_CPQApi.CPQ.CreateOrderResponseDO |
||
---|---|---|
Field |
Type |
Description |
JobId |
ID |
In case of a Bulk order creation the API will return the Job ID which can be tracked. |
OrderId |
ID |
Order Id |
Code Sample
The code below helps to create an order from a quote. It takes a quote number as input, creates an order, and generates order line items for the respective quote line items.
/** * The below method demonstrates how to create Order * The input of this method is Quote Number */ public static void createOrder(String quoteNumber) { // Query to retrieve proposal line items based on the provided quote number List<Apttus_Proposal__Proposal_Line_Item__c> proposalLineItems = [ SELECT Id, Apttus_Proposal__Proposal__r.Apttus_Proposal__Account__c, Apttus_Proposal__Proposal__r.Apttus_QPConfig__PriceListId__c, Apttus_Proposal__Proposal__r.Apttus_Proposal__ExpectedStartDate__c, Apttus_Proposal__Proposal__r.Apttus_Proposal__ExpectedEndDate__c FROM Apttus_Proposal__Proposal_Line_Item__c WHERE Apttus_Proposal__Proposal__r.Name = :quoteNumber AND Apttus_QPConfig__ParentBundleNumber__c = NULL AND Apttus_QPConfig__IsPrimaryLine__c = true ]; // Initialize the order creation request object Apttus_CPQApi.CPQ.CreateOrderRequestDO request = new Apttus_CPQApi.CPQ.CreateOrderRequestDO(); // Check if there are any proposal line items returned from the query if (!proposalLineItems.isEmpty()) { // Loop through each proposal line item to prepare the order items for (Apttus_Proposal__Proposal_Line_Item__c proposalLineItem : proposalLineItems) { // Create a selected product object for each proposal line item Apttus_CPQApi.CPQ.SelectedProductDO selectedProduct = new Apttus_CPQApi.CPQ.SelectedProductDO(); selectedProduct.SourceId = proposalLineItem.Id; // Set the source ID request.OrderItems.add(selectedProduct); // Add selected product to the order items } } // Create the order input object Apttus_Config2__Order__c orderInput = new Apttus_Config2__Order__c(); // Populate the order input fields with values from the first proposal line item orderInput.Apttus_Config2__SoldToAccountId__c = proposalLineItems[0].Apttus_Proposal__Proposal__r.Apttus_Proposal__Account__c; orderInput.Apttus_Config2__PriceListId__c = proposalLineItems[0].Apttus_Proposal__Proposal__r.Apttus_QPConfig__PriceListId__c; orderInput.Apttus_Config2__OrderStartDate__c = proposalLineItems[0].Apttus_Proposal__Proposal__r.Apttus_Proposal__ExpectedStartDate__c; orderInput.Apttus_Config2__OrderEndDate__c = proposalLineItems[0].Apttus_Proposal__Proposal__r.Apttus_Proposal__ExpectedEndDate__c; // Set the order item source request.orderItemSource = Apttus_CPQApi.CPQ.ITEMSOURCE_QUOTE_LINEITEM; request.OrderInput = orderInput; // Attach the order input to the request // Call the API to create the order and capture the response Apttus_CPQApi.CPQ.CreateOrderResponseDO createOrderResponseDO = Apttus_CPQApi.CPQWebService.createOrder(request); // Log the response for debugging purposes System.debug('createOrderResponseDO:-- ' + createOrderResponseDO); }