API Reference
API Reference

To add an order to a store, first instantiate a new order object with the store's API key and an associative array of the order data. A comprehensive list of the data attributes and their definitions can be found here. Then simply call the create() method.

<?php
$order = new ShippingEasy_Order("dc52f121e5ede4c163739c8dad4f98",
    array("external_order_identifier" => "390049", 
      "subtotal_including_tax" => "12.38", 
      "ordered_at" => "2019-10-21 08:51:00 -0500",
      "notes" => "Here is the customer note",
      "internal_notes" => "Here is the internal note",
      "discount_amount" => "2.38",
      "custom_1" => "Custom Field 1",
      "custom_2" => "Custom Field 2",
      "custom_3" => "Custom Field 3",
      "total_including_tax" => "12.63",
      "total_excluding_tax" => "10.00",
      "discount_amount" => "0.00",
      "coupon_discount" => "0.00",
      "subtotal_including_tax" => "12.63",
      "subtotal_excluding_tax" => "10.00",
      "subtotal_tax" => "0.00",
      "total_tax" => "0.00",
      "base_shipping_cost" => "2.63",
      "shipping_cost_including_tax" => "2.63",
      "shipping_cost_excluding_tax" => "2.63",
      "shipping_cost_tax" => "0.00",
      "recipients" => array(
         array(
        	"first_name" => "Jack",
        	"last_name" => "Ship",
        	"company" => "ShippingEasy",
        	"email" => "[email protected]",
        	"phone_number" => "855-202-2275",
        	"residential" => "true",
        	"address" => "3700 N Capital of Texas Hwy",
        	"address2" => "Ste 550",
          "province" => "",
       	  "state" => "TX",
        	"city" => "Austin",
        	"postal_code" => "78746",
        	"postal_code_plus_4" => "0036",
        	"country" => "US",
        	"shipping_method" => "Ground",
        	"items_total" => "1",
        	"line_items" => array(
            array(
              "item_name" => "Pencil Holder",
              "sku" => "9876543",
              "bin_picking_number" => "7",
              "unit_price" => "1.30",
              "total_excluding_tax" => "1.30",
	            "price_excluding_tax" => "1.30",
              "weight_in_ounces" => "10",
              "product_options" => array(
                "pa_size" => "large",
                "Colour" => "Blue"
               ),
              "quantity" => "1"
            )
          )
        )
     )
  ));

$res = $order->create();
?>

If successful the call will return a JSON hash with the ShippingEasy order ID, as well as the external order identifier originally supplied in your call.

{ "order" => { "id" => "27654", "external_order_identifier" => "ABC123" } }

Possible Exceptions

ShippingEasy_AuthenticationError

Your credentials could not be authenticated.

ShippingEasy_InvalidRequestError

The order could not be created on the server for one or more of the following reasons:

  • The JSON payload could not be parsed.
  • One or more of the supplied data attributes failed validation and is missing or incorrect.
  • An order with the supplied external_order_identifier already exists for that store.

The exception will contain a message that indicates which of these conditions failed.

Order Attributes

The following is a list of attributes that should be provided to the ShippingEasy_Order object as a associative array.

An example associative array for the create order API call may be found here: https://gist.github.com/twmills/8711096.

external_order_identifier
: Required. The e-commerce system's order ID.

ordered_at
: Required. Timestamp when the order was created.

order_status
: Possible values are "awaiting_shipment", "awaiting_payment", "awaiting_fulfillment", "awaiting_shipment", "partially_shipped". Default is "awaiting_shipment".

alternate_order_id
: Additional identifier for the e-commerce order.

total_including_tax
: Defaults to 0.0 if not specified.

total_excluding_tax
: Defaults to 0.0 if not specified.

discount_amount
: Defaults to 0.0 if not specified.

coupon_discount
: Defaults to 0.0 if not specified.

subtotal_including_tax
: Defaults to 0.0 if not specified.

subtotal_excluding_tax
: Defaults to 0.0 if not specified.

subtotal_tax
: Defaults to 0.0 if not specified.

total_tax
: Defaults to 0.0 if not specified.

base_shipping_cost
: Defaults to 0.0 if not specified.

shipping_cost_including_tax
: Defaults to 0.0 if not specified.

shipping_cost_excluding_tax
: Defaults to 0.0 if not specified.

shipping_cost_tax
: Defaults to 0.0 if not specified.

base_handling_cost
: Defaults to 0.0 if not specified.

handling_cost_excluding_tax
: Defaults to 0.0 if not specified.

handling_cost_including_tax
: Defaults to 0.0 if not specified.

handling_cost_tax
: Defaults to 0.0 if not specified.

base_wrapping_cost
: Defaults to 0.0 if not specified.

wrapping_cost_excluding_tax
: Defaults to 0.0 if not specified.

wrapping_cost_including_tax
: Defaults to 0.0 if not specified.

wrapping_cost_tax
: Defaults to 0.0 if not specified.

notes
: Customer notes on the order.

internal_notes
: Internal notes on the order.

billing_company
: Company name for billing address

billing_first_name
: Customer first name for billing address

billing_last_name
: Customer last name for billing address

billing_address
: First address line for billing address

billing_address2
: Additional address line for billing address

billing_city
: City name for billing address

billing_state
: State name for billing address

billing_country
: Country name for billing address

billing_postal_code
: Postal code for billing address

billing_phone_number
: Phone number.

billing_email
: Email address

sales_channel
:Sales channel that provided the order, if any

custom_1
:Customer-defined value

custom_2
:Customer-defined value

custom_3
:Customer-defined value

tags
:An array of up to 10 tags for the order

gift
:Specify "1" to indicate a gift order

recipients
: A nested associative array of recipient attributes. At least one recipient is required.

recipients > company
: Company name for shipping address

recipients > first_name
: Customer first name for shipping address

recipients > last_name
: Customer last name for shipping address

recipients > address
: Required. First address line for shipping address

recipients > address2
: Additional address line for shipping address

recipients > city
: City name for shipping address

recipients > state
: State name for shipping address

recipients > country
: Country name for shipping address

recipients > residential
: Whether or not address is residential or not. Value can be "true" or "false".

recipients > postal_code
: Required. Postal code for shipping address

recipients > postal_code_plus_4
: Postal code plus 4 for shipping address

recipients > phone_number
: Customer phone number

recipients > email
: Customer email address

recipients > base_cost
: Cost before tax for all line items sent to this recipient

recipients > cost_excluding_tax
: Cost before tax for all line items sent to this recipient

recipients > cost_including_tax
: Cost including tax for all line items sent to this recipient

recipients > cost_tax
: Cost of the tax for all line items sent to this recipient

recipients > base_handling_cost
: Handling cost before tax for all line items sent to this recipient

recipients > handling_cost_excluding_tax
: Handling cost before tax for all line items sent to this recipient

recipients > handling_cost_including_tax
: Handling cost including tax for all line items sent to this recipient

recipients > handling_cost_tax
: Handling cost of the tax for all line items sent to this recipient

recipients > shipping_zone_id
: ID of the shipping zone.

recipients > shipping_zone_name
: Name of the shipping zone.

recipients > shipping_method
: Method of shipment.

recipients > items_total
: Total number of items.

recipients > items_shipped
: Total number of items shipped.

recipients > line_items
: A nested associative array of line item attributes. At least one line item is required.

recipients > line_items > item_name
: Name of the item/product.

recipients > line_items > sku
: SKU of the item/product.

recipients > line_items > bin_picking_number
: Bin number where the item may be stored in a warehouse.

recipients > line_items > weight_in_ounces
: Weight of the item in ounces. This is the single unit weight - ShippingEasy multiplies weight_in_ounces by quantity to calculate shipping weight.

recipients > line_items > quantity
: Quantity of the items for the line item.

recipients > line_items > total_excluding_tax
: Total amount excluding tax for the item. This is the single unit amount - ShippingEasy multiplies total_excluding_tax by quantity to display a line item total on packing slips.

recipients > line_items > unit_price
: Unit price of the item. Should be set to the same value as total_excluding_tax.

recipients > line_items > price_excluding_tax
: Unit price of the item. Should be set to the same value as total_excluding_tax. Used for displaying order search results.

recipients > line_items > product_options
: Hash of product variations applicable to this line item. E.g. {"color":"red", "size":"XXL"}

recipients > line_items > ext_line_item_id
: Unique identifier used in the store for this line item in the order

recipients > line_items >gift_message
:Gift message, if any, for this line item