ESHIPPER API DOCUMENTATION V3.0.
2
Revision Log Date
Oct 12, 2006 Oct 30, 2006 Jan 11, 2007 Jan 11, 2007 Jan 11, 2007 Jun 20, 2007 Dec 5, 2007 Jan 20, 2007 Jan 24, 2007
Version
2.0.1 2.0.2 2.0.3 2.0.3 2.0.3 2.0.4 2.0.5 2.0.6 2.0.7
Modifications
Added Purolator Ground 9AM and 1030 services. Added all DHL services. COD and Insurance Handling for DHL Services (See section 8.1). Scheduled Ship Date option (See section 8.2). Saturday Service option Services (See section 8.3). Returning tracking URL in ShippingReply FedEx USA service Ids added UPS services added Canada Post services added. Added FedEx Express Saver Service. Updated API and schema to return label image (PNG) if available (see section 5.4). Added new API call ShipmentCancelRequest (see section 6). Added new API call OrderInformationRequest (see section 7). Insurance amounts and COD amounts to be sent at package level (as opposed to order level). See section 8.1 Added UPS services in USA Added LTL services in USA and Canada Removed DHL USA Domestic Services. Changed test server URL Added Version Management (See section 3.1) Returning currency code attribute with Quote element.(See section 4.1) Returning Original Charge and Applicable Charge with OrderInformationReply (See Section 7.1) Returning Pickup confirmation number with ShippingReply and OrderInformationReply (See Section 5.6/7.2) Added additional services: Schedule Pickup (See section 8.4), Signature Required (See section 8.5), Hold for Pickup Required (See section 8.6), Delivery Appointment (See section 8.7), Special Equipment (See section 8.8), Inside delivery (See section 8.9), Freight Class and Type (See section 8.10) Insurance Type (See section 8.11) Updated status values
February 12, 2007
2.0.8
April 15, 2008
2.0.9
March 01, 2009
2.1.0
3.0.0 3.0.0
3.0.0
October 21, 2009
3.0.2
1. Introduction
This document outlines the details of the API specifications for integrating with the EShipper application. The EShipper API is a work in progress, and it is expected that some minor changes may be made to the API before a fully stable version is released. The protocol of communication between the client and the EShipper application will be based on XML technology. Currently, the EShipper will handle 4 types of requests from the client, (i) Quote Request, (ii) Ship Request, (iii) Order Information Request, and (iv) Cancel Order Request. All requests will be sent via the client in XML format, and the EShipper application will respond to these requests in XML format.
2. Set up Process
Any customer willing to use the XML API will require to be registered with the application first. Please contact EShipper administrator or your sales representative to ensure that you have been set-up on the application. A special password will then be provided to the customer, which will be sent in the request along with the customer name. The EShipper application will use the customer name and password to authenticate the request before processing it. All requests will be sent to the URL www.e-shipper.net/rpc2 . Customers can also use the test server to post test requests. The URL for the test server is
http://test.eshipper.com:2201/eshipper/rpc2 . 3. XML Schema
The XML schema for the EShipper API is shown below. This schema contains definitions for elements and attributes used in the 8 message types:- (i) QuoteRequest, (ii) QuoteReply, (iii) ShippingRequest, (iv) ShipReply, (v) ShipmentCancelRequest, (vi) ShipmentCancelReply, (vii) OrderInformationRequest, and (viii) OrderInformationReply. 3.1 Version Management (since v3.0.0) The use of version in the root element has been introduced as of v3.0.0. For all requests, version information will have to be sent in the <EShipper> element. Example of version in the EShipper element:<Eshipper xmlns="http://www.eshipper.net/XMLSchema" username="merchant" password="9999" version="3.0.0"> XSD file containing the schema is included in this package.
4. Getting a Quote
In order to receive a quote from the EShipper API, the client can send a QuoteRequest message to the API. The API will process the request and return a QuoteReply message. The elements and attributes required by the Quote request and response messages are shown in the schema above. A sample request and response is shown below:-
Available Tags with Attributes in the QuoteRequest
QuoteRequest [Required]
o o o serviceId [Optional] dangerousGoodsType [Optional] isSaturdayService [Optional]
o signatureRequired [Optional] o holdForPickupRequired [Optional] o specialEquipment [Optional] o deliveryAppointment [Optional] o insideDelivery [Optional] o scheduledShipDate [Optional] o insuranceType [Optional] From [Required]
o id [Required] o company [Required] o address1 [Required] o city [Required] o state [Required] o country [Required] o zip [Required] To [Required] o id [Required] o company [Required] o address1 [Required] o city [Required] o state [Required] o country [Required] o zip [Required] COD [Optional] o paymentType [Required] CODReturnAddress [Required if COD is selected] o codCompany [Required] o codName [Required] o codAddress1 [Required] o codCity [Required] o codStateCode [Required] o codZip [Required] o codCountry [Required] Packages [Optional][Required if type=Package or Pallet] o type [Required] Package [Optional][Required if type=Package or Pallet] o length [Required] o width [Required] o height [Required] o weight [Required] o type [Optional][Required if type Pallet] o freightClass [Optional] [Required if type=Pallet] o insuranceAmount [Optional] o codAmount [Optional] o description [Optional][Required if type=Pallet] Pickup [Optional] o contactName [Required] o phoneNumber [Required] o pickupDate [Required] o pickupTime [Required] o closingTime [Required] o location [Optional]
Sample QuoteRequest message
<?xml version="1.0" encoding="UTF-8"?> <EShipper xmlns="http://www.eshipper.net/XMLSchema" username="merchant inc." password="9999" version="3.0.0"> <QuoteRequest serviceId="0"> <From id="123" company="Test Company" address1="650 CIT Drive" city="Livingston" state="ON" country="CA" zip="L4J7Y9" /> <To company="Test Company" address1="650 CIT Drive" city="Livingston" state="MA" zip="01603" country="CA" /> <!-- COD is optional --> <COD paymentType="Check"> <CODReturnAddress codCompany="ABC Towing" codName="Alfred" codAddress1="444 Highway 401" codCity="Toronto" codStateCode="ON" codZip="A1B2C3" codCountry="CA"/> </COD> <!-- If type="Envelope" package information is not required, otherwise it must be included --> <Packages type="Package"> <!-- Description is ignore for quote requests --> <!-- If package type="Pallet", type and freightClass are required for quote requests --> <Package length="15" width="10" height="12" weight="10" type="70" freightClass="Pallet" insuranceAmount="0.0" codAmount="0.0" description="desc."/> <Package length="15" width="10" height="10" weight="5" type="70" freightClass="Pallet" insuranceAmount="0.0" codAmount="0.0" description="desc."/> </Packages> <!-- Pickup is optional --> <Pickup contactName="Test Name" phoneNumber="888-888-8888" pickupDate="2009-08-03" pickupTime="16:30" closingTime="17:45" location="Front Door"/> </QuoteRequest> </EShipper>
Sample QuoteReply response to QuoteRequest message
<EShipper xmlns="http://www.eshipper.net/XMLSchema" version="3.0.0"> <QuoteReply> <Quote carrierId="2" carrierName="Purolator" serviceId="4" serviceName="Air" modeTransport="A" transitDays="1" baseCharge="177.0" fuelSurcharge="0.0" totalCharge="177.0" currency="CAD"> </quote>
<Quote carrierId="2" carrierName="Purolator" serviceId="13" serviceName="Ground" modeTransport="G" transitDays="1" baseCharge="28.650000000000002" fuelSurcharge="0.0" totalCharge="28.65" currency="CAD"> </quote> <Quote carrierId="1" carrierName="Federal Express" serviceId="1" serviceName="Priority" modeTransport="null" transitDays="0" baseCharge="46.27000045776367" fuelSurcharge="6.25" totalCharge="52.52" currency="CAD"> </quote> <Quote carrierId="1" carrierName="Federal Express" serviceId="3" serviceName="Ground" modeTransport="null" transitDays="0" baseCharge="30.739999771118164" fuelSurcharge="0.0" totalCharge="31.82" currency="CAD"> <Surcharge id="null" name="Other" amount="1.0800000429153442"/> </quote> <Quote carrierId="3" carrierName="Canada WorldWide" serviceId="16" serviceName="Air Freight" modeTransport="null" transitDays="0" baseCharge="300.0" fuelSurcharge="36.0" totalCharge="336.0" currency="CAD"> </quote> <Quote carrierId="3" carrierName="Canada WorldWide" serviceId="15" serviceName="Next Flight Out" modeTransport="null" transitDays="0" baseCharge="165.0" fuelSurcharge="19.8" totalCharge="184.8" currency="CAD"> </quote> </QuoteReply> <Eshipper> 4.1 Currency Code (since v3.0.0) The API will return currency code attribute in the Quote response. This attribute will be return in the Quote element. Example of currency code in the Quote element:<Quote carrierId="3" carrierName="Canada WorldWide" serviceId="15" serviceName="Next Flight Out" modeTransport="null" transitDays="0" baseCharge="165.0" fuelSurcharge="19.8" totalCharge="184.8" currency="CAD"> </quote>
5. Shipping an Order
In order to ship an order using the EShipper API, the client can send a ShippingRequest message to the API. The application then attempts to ship the order using the information provided. If a serviceId is specified in the request, the application will attempt to ship the order using that service only. If no serviceId attribute is specified, the application will retrieve rates for all eligible services and will ship using the cheapest fastest service available, i.e. it will first filter the services by the fastest and then pick the cheapest amongst these.
Available Tags with Attributes in the ShippingRequest
ShippingRequest [Required]
o serviceId [Optional] o dangerousGoodsType [Optional] o isSaturdayService [Optional] o signatureRequired [Optional] o holdForPickupRequired [Optional] o specialEquipment [Optional] o deliveryAppointment [Optional] o insideDelivery [Optional] o scheduledShipDate [Optional] o insuranceType [Optional] From [Required]
o id [Required] o company [Required] o address1 [Required] o city [Required] o state [Required] o country [Required] o zip [Required] To [Required] o id [Required] o company [Required] o address1 [Required] o city [Required] o state [Required] o country [Required] o zip [Required] Payment [Required] o type [Required] Reference [Optional] o name [Required] o code [Required] COD [Optional] o paymentType [Required] CODReturnAddress [Required if COD is selected] o codCompany [Required] o codName [Required] o codAddress1 [Required] o codCity [Required] o codStateCode [Required] o codZip [Required] o codCountry [Required] Packages [Optional][Required if type=Package or Pallet] o type [Required] Package [Optional][Required if type=Package or Pallet] o length [Required] o width [Required] o height [Required] o weight [Required] o type [Optional][Required if type Pallet] o freightClass [Optional] [Required if type=Pallet]
o insuranceAmount [Optional] o codAmount [Optional] o description [Optional][Required if type=Pallet] Pickup [Optional] o contactName [Required] o phoneNumber [Required] o pickupDate [Required] o pickupTime [Required] o closingTime [Required] o location [Optional] CustomsInvoice [Optional] [Required if International shipment.] BillTo [Required] o company [Required] o name [Required] o address1 [Required] o city [Required] o state [Required] o zip [Required] o country [Required] Contact [Required] o name [Required] o phone [Required] Item [Required] o code [Required] o description [Required] o originCountry [Required] o quantity [Required] o unitPrice [Required]
Sample ShippingRequest message
<?xml version="1.0" encoding="UTF-8"?> <EShipper xmlns="http://www.eshipper.net/XMLSchema" username="merchant inc." password="abcd" version="3.0.0"> <ShippingRequest serviceId="3"> <From id="123" company="Test Company" address1="650 CIT Drive" city="Livingston" state="ON" zip="L8E5X9" country="CA" phone="9052223333" attention="Riz" email="riz@shaw.ca"/> <To company="Test Company" address1="650 CIT Drive" city="Livingston" state="BC" zip="V3N4R3" country="CA" phone="4162223333" attention="RizTo" email="riz@shaw.ca"/> <!-- COD is optional --> <COD paymentType="Check"> <CODReturnAddress codCompany="ABC Towing" codName="Alfred" codAddress1="444 Highway 401" codCity="Toronto" codStateCode="On" codZip="A1B2C3" codCountry="CA"/> </COD>
<!-- If type="Envelope" package information is not required, otherwise it must be included --> <Packages type="Package"> <!-- If package type="Pallet", type and freightClass are required for shipping requests --> <Package length="15" width="10" height="12" weight="12" type="70" freightClass="Pallet" insuranceAmount="0.0" codAmount="0.0" description="desc."/> <Package length="15" width="10" height="10" weight="14" type="70" freightClass="Pallet" insuranceAmount="0.0" codAmount="0.0" description="desc."/> </Packages> <!-- Pickup is optional --> <Pickup contactName="Test Name" phoneNumber="888-888-8888" pickupDate="2009-08-03" pickupTime="16:30" closingTime="17:45" location="Front Door"/> <Payment type="3rd Party" /> <!-- References are optional and up to 3 may be specified. First reference specified is primary reference, second reference is secondary reference and so on--> <Reference name="" code="123456" /> <Reference name="" code="" /> <Reference name="" code="" /> <!--CustomsInvoice is optional, required for international shipment--> <CustomsInvoice> <BillTo company="ABC Towing" name="Alfred" address1="444 Highway 401" city="Toronto" state="ON" zip="A1B 2C3" country="CA" /> <Contact name="Rizwan" phone="555-555-4444" /> <Item code="1234" description="Laptop computer" originCountry="US" quantity="100" unitPrice="1000.00" /> </CustomsInvoice> </ShippingRequest> </EShipper>
Sample ShippingReply response to ShippingRequest message
<EShipper xmlns="http://www.eshipper.net/xml/XMLSchema" version="3.0.0"> <ShippingReply> <Order id="181004" /> <Carrier carrierName="Federal Express" serviceName="FedEx Ground" /> <Reference code="1234567" name="RizReference" /> <Package trackingNumber="052800410000484" /> <Package trackingNumber="052800410000491" />
<Pickup confirmationNumber ="123456789" /> <TrackingURL>http://www.fedex.com/Tracking?tracknumbers=052 800410000484</TrackingURL> <Labels>[base-64 encoded String]</Labels> <CustomsInvoice>[base-64 encoded String]</CustomsInvoice> <!--There will be only one quote element in the shipping reply--> <Quote carrierId="1" carrierName="Federal Express" serviceId="3" serviceName="Ground" modeTransport="null" transitDays="0" baseCharge="30.739999771118164" fuelSurcharge="0.0" totalCharge="31.82" currency="CAD"> <Surcharge id="null" name="Other" amount="1.0800000429153442"/> </quote> </ShippingReply> </EShipper> As seen in the request above, the serviceId was set to 3 which implies that a FedEx Ground shipment was requested (see section on Services for more information on this feature). The application performed the shipment and returned the tracking numbers for the packages along with the carrier and service information. 5.1 Labels The labels are returned in Acrobat PDF format as a base-64 encoded string inside the <Labels> tag. In order to recreate the labels on the client side, the client will have to read the characters enclosed inside this Labels tag, decode it using a base-64 decoding algorithm (which is readily available on most platforms), and then create an Acrobat PDF file from the resulting bytes. Please see appendix A for some examples on this process. 5.2 Customs Invoice If customs invoice information is submitted in the shipping request, it is returned in Acrobat PDF format as a base-64 encoded string inside the <CustomsInvoice> tag. In order to recreate the customs invoice on the client side, the client will have to read the characters enclosed inside this CustomsInvoice tag, decode it using a base-64 decoding algorithm (which is readily available on most platforms), and then create an Acrobat PDF file from the resulting bytes. Please see appendix A for some examples on this process. 5.3 Tracking URL (since v2.0.4) The API will return a tracking URL in the ShippingReply response. This URL can be used to track the shipment on the carriers website. If no tracking URL is available, then the API will return an empty string. 5.4 Label Images (since v2.0.7) The API returns label images if the images are available from the carrier. Currently, the API returns PNG images only. For multi-package shipments the API will return one label image per package. The images are sent under the <LabelData/> element. Each label will have its own <Label> element, containing sub-elements <Type> and <Data>. The image data is contained in the <Data> element as a base-64 encoded string (similar to the PDF data). The contents of the <Data> element will have to be decoded using Base-64 decoding algorithm. For example, a shipment with 2 packages will return images in the following method:<LabelData> <Label>
<Type>PNG</Type> <Data>[base-64 encoded String]</Data> </Label> <Label> <Type>PNG</Type> <Data>[base-64 encoded String]</Data> </Label> </LabelData> 5.5 Quote (since v3.0.0) The API will return a Quote element in the ShippingReply response. The Quote element contains the rate information about the shipment. 5.6 Pickup confirmation number (since v3.0.0) The API will return a Pickup element in the ShippingReply response. The Pickup element contains the pickup confirmation number of the pickup request. The attribute confirmationNumber is optional. <Pickup confirmationNumber ="123456789" />
6. Shipment Cancel Request
In order to cancel an order that was previously created using the EShipper API, the client can send a ShipmentCancelRequest message to the API. The system will attempt to cancel the order based on the orderId provided in the request. A success or error message will be returned depending on the result of the request. A status of 4 indicates that the shipment was cancelled. For a list of status mappings, please see Appendix B, section 10.1. Sample ShipmentCancelRequest message <?xml version="1.0" encoding="UTF-8"?> <es:EShipper xmlns:es="http://www.eshipper.net/XMLSchema" username="test" password="test" version="3.0.0"> <ShipmentCancelRequest> <Order orderId="383363"/> </ShipmentCancelRequest> </es:EShipper> Sample ShipmentCancelReply response to ShipmentCancelRequest message <EShipper xmlns="http://www.eshipper.net/xml/XMLSchema" version="3.0.0"> <ShipmentCancelReply> <Order orderId="383363" message="Order has been cancelled!" /> <Status statusId="4" /> </ShipmentCancelReply> </EShipper>
7. Order Information Request
Information on orders that were previously created can be requested using the OrderInformationRequest. This request will return all the fields from the ShippingReply, plus a status element <Status> containing the status Id and corresponding status name for the order. For a list of status mappings, please see Appendix B, section 10.1. Sample OrderInformationRequest message
<?xml version="1.0" encoding="UTF-8"?> <es:EShipper xmlns:es="http://www.eshipper.net/XMLSchema" username="test" password="test" version="3.0.0"> <OrderInformationRequest> <Order orderId="232212"/> </OrderInformationRequest> </es:EShipper Sample OrderInformationReply response to OrderInformationRequest message
<EShipper xmlns="http://www.eshipper.net/xml/XMLSchema" version="3.0.0"> <OrderInformationReply> <Order id="383361" /> <Carrier carrierName="Purolator" serviceName="Purolator Ground" /> <Reference code="123456" name="" /> <Package trackingNumber="VVV000197197" /> <Package trackingNumber="VVV000197198" /> <Pickup confirmationNumber ="123456789" /> <TrackingURL/> <Labels>[base-64 encoded String]</Labels> <Status statusId="3" statusName="DELIVERED" /> <OriginalCharge carrierId="1" carrierName="Federal Express" serviceId="3" serviceName="Ground" modeTransport="null" transitDays="0" baseCharge="30.739999771118164" fuelSurcharge="0.0" totalCharge="31.82" currency="CAD" actualWeight="10"> <Surcharge id="null" name="Other" amount="1.0800000429153442"/> </OriginalCharge>
<ApplicableCharge carrierId="1" carrierName="Federal Express" serviceId="3" serviceName="Ground" modeTransport="null" transitDays="0" baseCharge="30.739999771118164" fuelSurcharge="0.0" totalCharge="31.82" currency="CAD" billedWeight="10"> <Surcharge id="null" name="Other" amount="1.0800000429153442"/> </ApplicableCharge> </OrderInformationReply> </EShipper> 7.1 OriginalCharge and ApplicableCharge (since v3.0.0) The OriginalCharge element contains quoted rate information when shipment is created. The ApplicableCharge element contains actual rate information after the final charges have been determined for the shipment (based on information received from carrier after shipment is delivered). The OrderInformationReply element may contain more than one ApplicableCharge element.
Once final charges have been determined, the 'OriginalCharge' element and 'ApplicableCharge' element(s) will be return inside the OrderInformationReply element. If final charges have not yet been determined, the Quote element will be return inside the OrderInformationReply element. 7.2 Pickup confirmation number (since v3.0.0) The API will return a Pickup element in the OrderInformationReply response. The Pickup element contains the pickup confirmation number of the pickup request. The attribute confirmationNumber is optional. <Pickup confirmationNumber ="123456789" />
8. Services
The QuoteRequest and ShippingRequest messages have an optional attributed called serviceId. The value of this attribute maps to one of several services offered by EShipper. A list of the services and corresponding values are shown below. If this attribute is set to a positive value other than 0 in the QuoteRequest, the EShipper application will return a quote for that service only. Similarly, if this attribute is set to a positive value other than 0 in the ShippingRequest, the application will try and ship the order using that service. If the service is not available or an invalid service id is supplied, no quote will be returned. It is highly recommended to send a serviceId value with a ShippingRequest message. If no serviceId is sent with a ShippingRequest, EShipper will ship the shipment using a service of its discretion. Service ID 1 2 3 28 29 30 4 5 6 7 8 9 10 11 12 13 19 Service Name FedEx Priority FedEx First Overnight FedEx Ground FedEx Standard Overnight FedEx 2nd Day FedEx Express Saver Purolator Air Purolator Air 9AM Purolator Air 1030 Puroletter Puroletter 9AM Puroletter 1030 PuroPak PuroPak 9AM PuroPak 1030 Purolator Ground Purolator Ground 9AM Shipment Country of Origin US, CA US, CA US, CA US US US CA CA CA CA CA CA CA CA CA CA CA
20 14 15 16 17 106 600 601 602 603 604 605 606 607 608 609 610 611 500 501 502 503 504 505 506 507 508 1100 1500 1501 1502 1503 1504
Purolator Ground 1030 Canada Worldwide Same Day Canada Worldwide Next Flight Out Canada Worldwide Air Freight Canada Worldwide LTL DHL International Express UPS Express, Next Day Air UPS Expedited, Second Day Air UPS Worldwide Express UPS Worldwide Expedited UPS Standard (Ground) UPS Express Early A.M., Next Day Air Early A.M. UPS Three-Day Select UPS Saver UPS Ground Next Day Saver Worldwide Express Plus Second Day Air A.M. Canada Post Priority Canada Post Xpress Post Canada Post Expedited Canada Post Regular Canada Post Xpress Post USA Canada Post Xpress Post Intl Canada Post Air Parcel Intl Canada Post Surface Parcel Intl Canada Post Expedited Parcel USA TST LTL eShipper LTL - Chicago Suburban Express eShipper LTL - FedEx Freight East eShipper LTL - FedEx Freight West eShipper LTL - Mid-States Express eShipper LTL - New England Motor Freight
CA
US CA, US CA, US CA CA CA CA, US CA CA US US US US CA CA CA CA CA CA CA CA CA CA US US US US US
1505 1506 1507 1508 1509 1510 1511 1512 1513 1514 1515
eShipper LTL - New Penn eShipper LTL Oak Harbor eShipper LTL Pitt Ohio eShipper LTL R&L Carriers eShipper LTL - SAIA eShipper LTL USF Reddaway eShipper LTL Vitran Express eShipper LTL Wilson Trucking eShipper LTL Yellow Transportation eShipper LTL Roadway eShipper LTL FedEx National
US US US US US US US US US US US
PLEASE NOTE: 1. Purolator and Canada Post services are available for shipments originating in Canada only. 2. DHL International service is available for shipments originating in the United States only. 3. Federal Express and UPS services are available originating in both United States and Canada. 4. TST LTL service is available originating in Canada only.
The following additional services can be requested with the Quote and Shipping request.
8.1 COD and Insurance All insurance amounts are to be requested at the package level (as opposed to order level). The use of insuranceAmount in the root element has been deprecated as of v2.0.9. For Quote and Shipping requests, insurance amounts will have to be sent in the <Package> element in the attribute insuranceAmount. This amount has to be a float number. For COD requests, the COD element will be sent which highlights the payment details such as payment type, and return address for COD (see examples in section 4 and 5). The actual amounts for COD are to be sent along with the package information in the <Package> element. Note: The <CODReturnAddress> element needs to be sent only if the COD is to be shipped to a location different than the address specified in the <From> element, i.e. to a location other than the sender. Currently, this service (return COD to address other than sender) is available through FedEx USA only. In all other cases, COD will be returned to sender address. Examples of the <Package> element for quotes and shipping requests containing insurance and COD amounts:Example 1
<Packages type="Package"> <Package length="15" width="10" height="12" weight="12" codAmount=100 insuranceAmount=300 /> <Package length="15" width="10" height="10" weight="14" codAmount=120.54/>
</Packages>
In this example, package1 has a COD amount of $100 and an insurance amount of $30. Package2 has a COD amount of $120.54 and no insurance amount. Example 2
<Packages type="Package"> <Package length="15" width="10" height="12" weight="12"/> <Package length="15" width="10" height="10" weight="14" insuranceAmount=250.0/> </Packages>
In this example, package1 has no COD and insurance amounts. Package2 has no COD amount and an insurance amount of $250. Example 3
<Packages type="Package"> <Package length="15" width="10" height="12" weight="12"/> <Package length="15" width="10" height="10" weight="14"/> </Packages>
In this example, both packages have no COD and insurance amounts. 8.2 Scheduled Ship Date Quote and Shipping requests can include a scheduledShipDate field. This date can be the current date or a future date. The scheduledShipDate attribute can be sent in the <QuoteRequest> or <ShippingRequest> element. This attribute is optional. The format for the date is yyyy-MM-dd (for example 2007-01-11 would imply January 11, 2007). Example of scheduled date in the ShippingRequest element:-
<ShipipngRequest serviceId=100 scheduledShipDate=2007-02-14>
8.3 Saturday Service Request Saturday service can be requested by setting the isSaturdayService attribute in the Quote and Shipping requests. The isSaturdayService attribute can be sent in the <QuoteRequest> or <ShippingRequest> element. Valid values are true and false. This attribute is optional. Example of Saturday service request in the ShippingRequest element:-
<ShipipngRequest serviceId=4 isSaturdayService=true>
8.4 Pickup (since v3.0.0) Note: Pickup service is available only for UPS and Purolator. Pickup service can be requested by setting the Pickup element in the Quote and Shipping requests. The Pickup element can be sent in the <QuoteRequest> or <ShippingRequest> element. This element is optional.
The format for the date is yyyy-MM-dd (for example 2007-01-11 would imply January 11, 2007). The format for the time is HH:MM (for example 16:30 would imply 4:30 PM). In case of UPS, phone number should contain at least 10 digits. In case of Purolator, pickup location is required and format of phone number should be (###-#######). Valid values for location are: 1. Receiving 2. Garage 3. Lobby 4. Reception 5. Front Desk 6. Vault 7. Switchboard 8. Back Door 9. Desk 10. Between Doors 11. Kiosk 12. Office 13. Outside Door 14. Mailbox 15. Side Door 16. Service Counter 17. Security 18. Shipping 19. Front Door 20. Basement 21. Mail Room 22. Lab 23. Warehouse 24. Pharmacy 25. Pro Shop 26. Parts Department 27. Counter 28. Loading Dock 29. Gate House Example of the <Pickup> element for quotes and shipping requests containing pickup:-
<Pickup contactName="Test Name" phoneNumber="888-8888888" pickupDate="2009-08-03" pickupTime="16:30" closingTime="17:45" location="Front Door" />
8.5 Signature Required Service (since v3.0.0) Signature required service can be requested by setting the signatureRequired attribute in the Quote and Shipping requests. The signatureRequired attribute can be sent in the <QuoteRequest> or <ShippingRequest> element. This attribute is optional. Valid values are No and Yes, if from country is CANADA. Valid values are No, Indirect, Direct and Adult, if from country is US. Example of Signature required service request in the ShippingRequest element:-
<ShipipngRequest serviceId="4" signatureRequired="Yes">
Note: Only for UPS, Signature service not allowed with COD service. 8.6 Hold for Pickup Required Service (since v3.0.0) Hold for Pickup Required service can be requested by setting the holdForPickupRequired attribute in the Quote and Shipping requests. The holdForPickupRequired attribute can be sent in the <QuoteRequest> or <ShippingRequest> element. Valid values are true and false. This attribute is optional. Example of Hold for Pickup Required service request in the ShippingRequest element:-
<ShipipngRequest serviceId="4" holdForPickupRequired="true">
8.7 Delivery Appointment Service (since v3.0.0) Delivery Appointment service can be requested by setting the deliveryAppointment attribute in the Quote and Shipping requests. The deliveryAppointment attribute can be sent in the <QuoteRequest> or <ShippingRequest> element. Valid values are true and false. This attribute is optional. Example of Delivery Appointment service request in the ShippingRequest element:-
<ShipipngRequest serviceId="4" deliveryAppointment="true">
8.8 Special Equipment Service (since v3.0.0) Special Equipment service can be requested by setting the specialEquipment attribute in the Quote and Shipping requests if the package type is set to Pallet. The specialEquipment attribute can be sent in the <QuoteRequest> or <ShippingRequest> element. This attribute is optional. Valid values are: 1) Container 2) Dry Box 48' 3) Dry Box 53' 4) Flat Bed 48' 5) Flat Bed 53' 6) Flat 4X 48' 7) Reefer 48' 8) Reefer 53' 9) Straight Truck 10) Tractor 11) Trailer 12) Tri-Axle Van 13) Volvos Example of Special Equipment service request in the ShippingRequest element:-
<ShipipngRequest serviceId="4" specialEquipment="Container">
8.9 Inside Delivery Service (since v3.0.0) Inside Delivery service can be requested by setting the insideDelivery attribute in the Quote and Shipping requests. The insideDelivery attribute can be sent in the <QuoteRequest> or <ShippingRequest> element. Valid values are true and false. This attribute is optional.
Example of Inside Delivery service request in the ShippingRequest element:-
<ShipipngRequest serviceId="4" insideDelivery="true">
8.10 Freight Class and Type (since v3.0.0) All Freight Class and Type are to be requested at the package level if package type is set to Pallet. For Quote and Shipping requests, freight class and type will be sent in the <Package> elements as the attributes freightClass and type. These attributes are required if package type is set to Pallet. Valid values for Freight Class are: 1) 50 2) 55 3) 60 4) 65 5) 70 6) 77 7) 77.5 8) 85 9) 92.5 10) 100 11) 110 12) 125 13) 150 14) 175 15) 200 16) 250 17) 300 18) 400 Valid values for Type are: 1) Pallet 2) Drum 3) Boxes 4) Rolls 5) Pipes/Tubes 6) Bales 7) Bags 8) Cylinder 9) Pails 10) Reels Examples of the <Package> element for quotes and shipping requests containing freightClass and Type:-
<Packages type="Pallet"> <Package length="15" width="10" height="12" weight="12" type=Drum freightClass=70/> <Package length="15" width="10" height="10" weight="14" type=Boxes freightClass=77.5/> </Packages>
In this example, package1 has a type of Drum and freightClass of 70. Package2 has a type of Boxes and freightClass of 77.5
8.10 Insurance Type (since v3.0.0) Insurance Type service can be requested by setting the insuranceType attribute in the Quote and Shipping requests. The insuranceType attribute can be sent in the <QuoteRequest> or <ShippingRequest> element. This attribute is optional. For envelope and pak, the only possible insurance type is 'Carrier'. In this case the insurance type will always be Carrier insurance and the maximum value will be $100. For pallet, the only possible insurance type is eShipper. In this case the insurance type will always be eShipper insurance and the maximum value will be $100,000. For package, the possible insurance types are eShipper and Carrier. In this case insuranceType attribute is missing in the request then default customer insurance preference will be applied. The maximum allowed value will be $100,000. Valid values are: 1. eShipper. 2. Carrier. Example of Insurance Type service request in the ShippingRequest element:-
<ShipipngRequest serviceId="4" insuranceType="Carrier"> NOTE: A fee usually applies to Shipping Requests that require additional services.
9. Appendix A Reading and Decoding the Labels from the ShippingReply
The labels in the ShippingReply message are located between the <Label></Labels> tag in base-64 encoded format. This string of characters needs to be decoded using a base-64 decryption algorithm, and the resulting bytes can then be written into a PDF file.
9.1 Java Example
In the Java programming language, this can be accomplished using the Base64 class found in the Apache org.apache.commons.codec.binary package. Assuming that the String inside the labels tag has been read into a variable called encodedString, the following function can be called to create the pdf file: public void generatePdf(String encodedString){ try{ FileOutputStream fos = new FileOutputStream(new File("C:\\temp\\mylabel.pdf")); byte[] bytes2 = Base64.decodeBase64(encodedString.getBytes()); fos.write(bytes2); fos.close(); } catch (Exception e) { e.printStackTrace(); } }
9.2 Other Languages
.NET
Look up the Convert class in System. It contains ToBase64String(), ToBase64CharArray(), FromBase64String(), and FromBase64CharArray() static methods. C programming Language http://www.scripting.com/midas/base64/source.html
10. Appendix B 10.1 Status Mappings
Status Id 1 2 3 4 5 7 Status READY FOR SHIPPING IN TRANSIT DELIVERED CANCELLED EXCEPTION CLOSED