The business layer classes contain logic and business rules for the purchase process. The methods in these classes are used to make changes to an Order. These methods contain logic that alters the Order’s data structure and maintains its accuracy; all calls to alter an Order should be made through these classes.
| Class | Description | 
|---|
| OrderTools
 | Low-level interface containing the logic for editing an Orderdata structure. It is not meant to contain business logic or to be used directly. In general, only theOrderManagerorSimpleOrderManagermakes calls to anOrderToolsobject. For more information, see the OrderTools section. | 
| OrderManager
 | Contains most of the functionality for working with an Order, including methods such ascreateOrder(), as well as properties referencing the other manager classes listed below. The methods in this class are higher level than the methods inOrderTools. | 
| CommerceItemManager
 | Contains functionality for working with a CommerceItem, including methods such asaddCommerceItemToOrder()andaddItemQuantityToShippingGroup(). | 
| ShippingGroupManager
 | Contains functionality for working with ShippingGroups, includingcreateShippingGroup()andsplitShippingGroup(). | 
| HandlingInstructionManager
 | Contains functionality for working with handling instructions, including methods such as createHandlingInstruction()andremoveHandlingInstructionsFromShippingGroup(). | 
| PaymentGroupManager
 | Contains functionality for working with PaymentGroups, includingcreatePaymentGroup()andintializeCreditCard(). | 
| OrderQueries
 | Contains lookup methods such as getOrdersForProfile()andgetOrderIdsWithinDateRange(). | 
| SimpleOrderManager
 | This class extends OrderManager. It is a very high-level interface for altering anOrder; only one method call inSimpleOrderManageris required to make a series of changes to anOrder. For more information, see the Using the SimpleOrderManager section. | 
| ReturnTools
 | This class provides utility features for returns, such as identifying if a return can be initiated for a specific order, and obtaining reason codes for the return. For information on this class, refer to the Setting Up Returns section. | 
| ReturnManager
 | Contains the main API for setting up and configuring returns using a ReturnRequest, and uses methods such asapplySelectedItemsto identify items to be returned. For more information, refer to the Setting Up Returns section. |