Web Site Punchout Implementation Guide
Web Site Punchout Implementation Guide
Implementation
Guide
AUGUST 2000
Copyright 2000 by Ariba, Inc. The information contained in this document is proprietary and
confidential to Ariba, Inc. All rights reserved. Patents Pending.
Ariba and the Ariba logo are registered trademarks of Ariba, Inc. Ariba B2B Commerce Platform,
Ariba Buyer, Ariba Marketplace, Ariba Dynamic Trade, Ariba Commerce Services Network,
buyer.ariba, supplier.ariba, ECTranslator, ECTransport, Walkup UI, Supplier Advisor and Making
the Net Work for B2B are trademarks or servicemarks of Ariba, Inc.
All other brand or product names may be trademarks or registered trademarks of their respective
companies or organizations.
Preface . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . iii
Audience and Prerequisites. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . iii
Related Documentation. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . iii
Typography . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . iv
Ariba Technical Support . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . iv
Chapter 1
Supplier PunchOut Implementation . . . . . . . . . . . . . . . . . . 1
Implementation Methodology. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 1
Planning . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 2
Analysis of Present and Future State . . . . . . . . . . . . . . . . . . . . . . . 2
Outsourcing Versus Internal Development . . . . . . . . . . . . . . . . . . 3
Design . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 6
Supplier Specifics . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 6
Buyer’s Business Requirements . . . . . . . . . . . . . . . . . . . . . . . . . . 7
Buyer Specifications . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 8
PunchOut Process Flow. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 9
Development . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 9
Message Flow . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 10
Specifying the PunchOut URL . . . . . . . . . . . . . . . . . . . . . . . . . . 13
Extrinsics and Supplier Cookies . . . . . . . . . . . . . . . . . . . . . . . . . 14
Multiple From Credentials in Marketplace Transactions . . . . . . 15
Support for Profile Transaction . . . . . . . . . . . . . . . . . . . . . . . . . . 16
Testing. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 16
Self-Testing on Ariba CSN . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 17
Testing with Ariba Global Solutions . . . . . . . . . . . . . . . . . . . . . . 18
Testing with the Client. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 18
Deployment. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 21
Chapter 2
Expediting Development of a PunchOut Site . . . . . . . . . 23
cXML Messaging . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 24
Chapter 3
Retrofitting an Existing Website . . . . . . . . . . . . . . . . . . . . 25
Leveraging the Existing Site. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 25
Chapter 4
Integrating Service Organizations . . . . . . . . . . . . . . . . . . 27
PunchOut for Services . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 27
Milestones . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 28
Chapter 5
Sample Code. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 31
cXML Index File . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 31
PunchOut Setup Request Document. . . . . . . . . . . . . . . . . . . . . . . . . . 32
Key Elements. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 32
Sample . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 34
PunchOut Setup Response Document . . . . . . . . . . . . . . . . . . . . . . . . 35
Key Elements. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 35
Sample . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 36
PunchOut Order Message Document . . . . . . . . . . . . . . . . . . . . . . . . . 36
Key Elements. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 36
Sample . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 37
Order Request Document . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 39
Key Elements. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 39
Sample . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 39
Order Response Document . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 43
Sample . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 43
Rapid Site Deployment. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 43
File receivePunchoutSetupRequest.asp . . . . . . . . . . . . . . . . . . . . 44
File resolveXML.asp . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 45
Index . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 49
This document describes the process for successfully integrating suppliers into a
buying organization’s Ariba Buyer procurement environment and Ariba Marketplace,
Network Edition. The focus is on the various steps: planning, design, development,
testing, and deployment of a production-ready PunchOut site.
Readers should have a working knowledge of e-commerce concepts and the HTTP
Web communication standard.
Related Documentation
cXML User’s Guide
Describes available catalog features and the syntax of CIF 3.0 and
cXML catalogs.
Typography
cXML elements and attributes are denoted with a monotype font. cXML element and
attribute names are case-sensitive. Both are a combination of lower and uppercase,
with elements beginning with an uppercase letter, and attributes beginning with a
lowercase letter. For example, MyElement is a cXML element, and myAttribute is a
cXML attribute.
The following table describes other typographic conventions used in this book:
Typeface or
Meaning Example
Symbol
<AaBbCc123> Text you need to change is http://<yourServer>:<HTTPServerPort>/
italicized, and appears between inspector
angle brackets.
AaBbCc123 The names of user interface Choose Edit from the File menu.
controls, menus, and menu
items.
AaBbCc123 Files and directory names, There is one line in ReportMeta.csv for each
parameters, fields in CSV files, report in the system.
command lines, and code
examples.
AaBbCc123 The names of books. For more information, see Ariba Buyer
Configuration Overview.
1 Supplier PunchOut
Implementation
Implementation
To the Ariba Buyer user, the key difference between PunchOut and local catalogs is
what they see in the User Interface (UI). For both, the UI displays a catalog hierarchy
enabling users to choose items, listed as line items on requisitions. Functionally, the
1 Supplier PunchOut
difference between the two is that PunchOut catalogs require hosting by you, the
Implementation
supplier, while local catalogs are completely hosted by Ariba CSN.
For local catalogs, CIF files typically populate both the catalog hierarchy and
requisition line items. With PunchOut however, populating the catalog hierarchy and
requisition line items use separate vehicles. First, you provide a PunchOut index file
that is loaded into Ariba Buyer that populates the catalog hierarchy. Second, the
posting of a cXML message to Ariba Buyer from the check-out page of your
1 Supplier PunchOut
PunchOut site populates requisitions with line-items. Ariba Buyer does not require
any customization to be able to handle these cXML messages, tagged with the cXML
Implementation
element PunchOutOrderMessage.
Implementation Methodology
The supplier PunchOut implementation process spans from initial evaluation of a
1 Supplier PunchOut
supplier’s system to certification by Ariba. You obtain certification when the
Implementation
PunchOut site is ready to exchange documents with an Ariba customer.
• Planning
• Design
• Development
1 Supplier PunchOut
Implementation
• Testing
• Deployment
Planning
The Planning phase should include the development of a high-level vision of the
integration as well as a rough cut at the project plan and resources required.
• How will the process flow from time of shopping through order placement and
fulfillment?
• Can a single product line be selected for an initial pilot of PunchOut integration?
• Will you need to interface with multiple XML-based procurement applications?
• How should your concept of a “shopping cart” be modeled in requisition line
items?
Implementation
Outsourcing Versus Internal Development
Next, you should review outsourcing versus building the integration yourself. The
Ariba Supplier Advisor, available at supplier.ariba.com, will help you in making this
decision and offer suggestions for partners to assist in the technical integration. Some
key factors to take into account:
1 Supplier PunchOut
Implementation
• Does your existing technical staff have the expertise to implement a PunchOut site?
• Do you have an existing Web infrastructure that can be leveraged relative to Ariba’s
protocols?
• Do you have an approved budget for e-commerce initiatives, in particular, Ariba
Supplier Network enablement?
• Has you evaluated the process flow with PunchOut to verify that it fits into your
business model for offering service procurement?
1 Supplier PunchOut
Implementation
Key Participants
The Ariba supplier integration process is a collaborative effort that leverages the
skills of Ariba, client, and supplier resources. The key participants typically involved
in the process are as follows:.
1 Supplier PunchOut
Implementation
You are strongly encouraged to identify a qualified team member to assume the role
of Technical Developer for the PunchOut site. This person acts as the primary owner
of the supplier PunchOut process and assumes responsibility for a number of tasks.
The following is a role description for the Supplier Technical Developer:
• Main recipient of PunchOut documentation available from Ariba online from the
following Websites:
http://supplier.ariba.com
1 Supplier PunchOut
Implementation
http://cxml.org/home/
http://xml.cxml.org/
• CIF
1 Supplier PunchOut
Implementation
• PunchOut
• Main point of contact when testing the PunchOut site with Ariba and the client
• Manages the Ariba Supplier account for all technical PunchOut related matters
The Supplier Integration Manager is the main point of contact for non-technical
issues relating to PunchOut and enabling a site. The role description for this person
includes:
• Verifying the Dun and Bradstreet (D&B) number for your company,
• To find out or obtain the D&B number, visit:
http://www.dnb.com/dunsno/whereduns.htm. Registering for a D-U-N-S® number
is free, but it can take up to three weeks to process.
• Managing the relationship between PunchOut customer and supplier; resolving
issues such as:
Ariba Consultants can provide targeted support on specific topics such as Ariba
Commerce Services Network (CSN) registration and functionality, catalog formats,
testing approaches, etc. Ariba CSN supports suppliers at any level of technical
sophistication.
Your requirements, order volume, the amount of automation desired, and your level
of expertise determine the level of support needed. Answering the following
questions can help determine the level of support needed.
Implementation
Do you have a solid understanding of XML and cXML?
XML (eXtensible Markup Language) provides the building blocks of any cXML
document. cXML documents provide a way for buyers, suppliers, and Ariba CSN to
communicate with each other. cXML documents are constructed based on a
Document Type Definition (DTD) files which are used to define a content model for a
1 Supplier PunchOut
cXML document. A DTD includes the specifications for the elements allowed, their
Implementation
order, and the data types of attributes.
1 Supplier PunchOut
copies of the schema and instancing tools XML Authority and XML instance at
Implementation
http://www.extensibility.com/products/index.htm. Several third party tools and
services exist to accelerate the implementation of an XML enabled infrastructure.
Contact Ariba CSN Support at network_support@ariba.com for details.
A catalog index file is a cXML or Catalog Information Format (CIF) document you
create that the buyer loads into Ariba Buyer to create entries in the catalog hierarchy.
1 Supplier PunchOut
The file defines how you and your products appear in the Ariba Buyer catalog UI. For
Implementation
a CIF catalog, a UNSPSC code in the index file is mapped to an internal commodity
code in Ariba Buyer. The objects residing in the buyer system must be pre-configured
for you and the commodities being imported.
A catalog entry is created when the index file has been imported and approved. When
the user selects the catalog entry, Ariba Buyer formats and sends a PunchOut Setup
Request document to Ariba CSN, which initiates the session. A Web browser then
1 Supplier PunchOut
display the PunchOut catalog on your Website. See “cXML Index File” on page 31
for an example of a cXML index file.
Implementation
1 Supplier PunchOut
Implementation
'HVLJQ
The overall design of a PunchOut site and how it will integrate with a supplier’s
system is critical to the implementation process.
Since certain catalog formats are better for certain commodities and business rules,
you must understand them and discuss them with the client to understand buyer
requirements. You must address the following areas to complete this analysis:
• Supplier specifics
• Buyer’s business requirements
• Buyer specifications
• PunchOut process flow
Supplier Specifics
There is flexibility in the appearance and functionality of your PunchOut site derived
from supplier specific aspects of your Punchout design, listed as follows:
• Branding
• Publishing the catalog
• Communicating with other Ariba Network suppliers
• Ariba Ready
Several factors, such as schedule, budget, and appearance will influence how you
approach some of the supplier specifics and you should review all of them as part of
your design process.
Branding
Implementation
Publishing the catalog
PunchOut catalogs are published on Ariba CSN like other catalog types. The supplier
can make the catalog public and available to all buyers, or private and available only
to specific buyers. Buyers select catalogs to view based on their description and on
details about the supplier. Publishing a catalog to Ariba CSN is the quickest way let
1 Supplier PunchOut
buyers know that a new supplier has come online.
Implementation
Communication with other Ariba Network Suppliers
Ariba hosts two supplier forums each year for the exchange of information about
supplier e-commerce requirements and to deliver updates on the state of the industry.
These summits provide an excellent educational and networking forum, and deliver
insight into supplier challenges and opportunities in e-commerce. These meetings are
limited to ASL (Ariba Supplier Link) members.
1 Supplier PunchOut
Implementation
Ariba also hosts two Customer Advisory Council meetings each year. These events
are open to all Ariba customers, including non-ASL members. The Customer
Advisory Council is another great medium for interacting with both buyers and
suppliers, as well as learning about the latest state of Ariba products.
Ariba Ready
1 Supplier PunchOut
Ariba Ready is a service offered at the supplier.ariba.com website. Once the
PunchOut site is enabled and tested thoroughly with the PunchOut Test Tool, you
Implementation
should apply for Ariba Ready, where the PunchOut site is placed in a queue to be
tested by the Ariba Ready team. Once testing is complete, the site is passed to an
Ariba partner for script testing. When the site passes the scripts, the supplier receives
an Ariba Ready logo. This may be placed on the site to notify potential buyers that
the supplier has met Ariba’s PunchOut requirements, expediting the addition of
buyers to the site. Once the supplier account is active, obtain information about Ariba
Ready at supplier.ariba.com. To access Ariba Ready, login to your supplier account
and click the Become Ariba Ready link under Quick Links.
1 Supplier PunchOut
Implementation
Buyer’s Business Requirements
Meet with your customers to determine their business requirements. You should:
Define with the buyer which products are to be used for PunchOut. Determining
whether or not PunchOut is the best solution for a supplier is important because
development of a PunchOut site can be time-consuming and costly. If you retail only
a small number of products for the buyer, a CIF catalog may be more appropriate than
PunchOut.
The current state of your system impacts the development time line for creating a
PunchOut site. A thorough evaluation your existing system and available resources is
imperative to determine a realistic time frame for development through production.
Buyer Specifications
To build the appropriate functionality in a PunchOut site, review the buyer’s
specifications. In addition to technical requirements, you should analyze:
The purpose of this step is to review and develop the processes for addressing the
multiple issues that arise when two entities enter as buyer and supplier into a business
arrangement. Inspection of the above review points will assist in determining the
following.
Implementation
PunchOut Process Flow
It is important to document the transaction process flow in and out of your user
interface, and to identify which messages need to be coded. Ariba has documentation
available to assist in defining the process within an organization. Suppliers registered
on Ariba CSN can download the following guides from supplier.ariba.com by
1 Supplier PunchOut
clicking the Help tab:
Implementation
Ariba CSN Supplier’s Guide
1 Supplier PunchOut
Describes available catalog features and the syntax of CIF 3.0 and
Implementation
cXML catalogs.
'HYHORSPHQW
You complete the development phase by enabling each step in the PunchOut process.
1 Supplier PunchOut
This process can be described by a message flow, shown in the diagram below,
Implementation
followed by the details and the requirements of each step in the process.
1 Supplier PunchOut
Implementation
1 Supplier PunchOut
Implementation
Message Flow
The following transaction flow diagram details the PunchOut process between the
PunchOut site and Ariba CSN.
Public Internet
Corporate Intranet/
Supplier PunchOut Site
Ariba Buyer
Ariba CSN
PunchoutSetupRequest Supplier Authenticates
Buyer
PunchoutSetupResponse PunchoutSetupResponse
Shopping cart contents transferred back to Ariba Buyer using Browser Form Post
1. User login
To place an order, the user at a buying organization logs onto Ariba Buyer,
creates a requisition, and selects a PunchOut catalog. The supplier’s catalog
is highlighted, at which point the user executes PunchOut to the supplier
PunchOut site. The user may have access store-, aisle-, and product-level
PunchOut. If the user has selected an item or aisle from the catalog, they
PunchOut to an item or aisle specific page. They also may have he option to
PunchOut directly to the supplier’s site without first selecting an item, where
they can then browse for an item.
Implementation
When a buyer registers on Ariba CSN, the administrator is issued a login ID
(usually an e-mail address), and a password. As part of the maintenance
process, the buyer may select a SharedSecret or additional password different
from the one used for login. A PunchOut Setup Request document contains
identification details (domain, NetworkID), as well as the supplier’s D-U-N-S
number. When it is sent to Ariba CSN, the network is able to identify the
1 Supplier PunchOut
buyer based on the Identity element in the From root element and populate the
Implementation
Credential domain with the buyer’s Ariba CSN ID. This is the ID the supplier
sees in the PunchOut Setup Request and one of two elements used to
authenticate the buyer. Each buyer has their own NetworkID.
1 Supplier PunchOut
to log in to supplier.com, which then becomes the password used by the
Implementation
buyer to log in to the supplier’s site. The supplier never sees the buyer’s
SharedSecret and does not have to maintain a separate password/login for
each user. Details about the Ariba Buyer user may be captured in Contact and
Extrinsic elements. See page 32 for a cXML example of a PunchOut Setup
Request document.
1 Supplier PunchOut
PunchOut session, thereby allowing a supplier to track which screen a user is
Implementation
on during the shopping process. An edit operation on an existing order
results in a new buyer cookie for that particular session. To link a specific
order to a user, use the SupplierPartAuxiliaryID (supplier cookie) element.
3. PunchOut authentication
When a supplier site receives the PunchOut Setup Request document, the
following takes place:
1 Supplier PunchOut
• Authentication of Ariba CSN is established based on Sender contents,
Implementation
• The supplier can now initiate a session using the buyer’s company and
user information because the buyer is a certified Ariba CSN user. A link to
the new PunchOut session can be established using the returned start page
URL.
• The From identification is verified and the user redirected to the supplier’s
site.
1 Supplier PunchOut
Implementation
5. Shopping experience
Once in a supplier’s Website, the user should be able to navigate easily and
without confusion. Selecting an item adds it to a shopping cart or basket in
the supplier’s site. Upon completion of shopping, the user returns to Ariba
Buyer where they can inspect and edit line items procured from the
supplier’s PunchOut site. This is accomplished by mapping the contents of
the shopping cart to cXML and then returning to the user’s Ariba Buyer
system.
In addition to the above, the checkout process for PunchOut should not
require the user to enter credit card information or ship-to address details.
This data is maintained on the buyer side. Ship-to information is visible to
the supplier in both the requisition and later in the order. Upon submitting
the quote, the user is returned to Ariba Buyer. In versions of Ariba Buyer
prior to 7.0, because the supplier’s site appears in a new browser, there is a
final screen that the user sees containing the supplier’s purchase requisition
number and a button with the text “Close Browser”. This returns the user to
Ariba Buyer. See page 36 for a cXML example of a PunchOut Order
Message document.
Implementation
Ariba Buyer submits the quote for approval and routes to workflow. At the
present time, Ariba Buyer does not update the supplier on the progress of an
order after it has been submitted for approval. If a manager on a workflow
chain denies the order, they have the option of using PunchOut to the
supplier’s site to remove line items or to delete the requisition. However, this
is not required. Ariba recommends that the supplier reach an agreement with
1 Supplier PunchOut
the buyer as to how a cancelled requisition will be handled in the production
Implementation
environment.
1 Supplier PunchOut
supplier. See page 39 for a cXML example of an Order Request document.
Implementation
9. Order Response generated
The Order Response document confirms that the order was received by the
supplier and parsed correctly. It is not a commitment to execute a purchase
order, only confirmation that it was received and is a valid cXML document.
The Response is transmitted via Ariba CSN. The key element is the Status
which will be have code equal to “200” and text set to “OK” if there are no
1 Supplier PunchOut
errors. See page 39 for a cXML example of an Order Response message.
Implementation
Specifying the PunchOut URL
There are two places where you specify your PunchOut site's URL: in your PunchOut
index catalog, and in the "Punchout Setup Request URL" field in the Configuration
area of your Ariba CSN account.
1 Supplier PunchOut
Ariba CSN uses both URLs.
Implementation
URLs from Your Index Catalog
When users punch out, their procurement application adds the URL from your index
catalog to the SupplierSetup element in the PunchOut Setup Request document.
<PunchoutDetail>
Implementation
</PunchoutDetail>
Depending on the cXML version used by your PunchOut site, the PunchOut Setup
Request might also contain a SelectedItem element specifying the item the user is
punching out for:
• cXML 1.0 and ORMS 6.1 do not use SelectedItem. So, the URL in your index
catalog is the only way to specify the item to punch out for.
• cXML 1.1 and Ariba Buyer 7.0 use SelectedItem to specify the Item ID of the item
to punch out for. Your PunchOut site can ignore the URL within the PunchOut Setup
Request, so you can use a bogus URL within your index catalog.
You determine where Ariba CSN forwards the PunchOut Setup Request document by
specifying a URL in your Ariba CSN account configuration:
• If you do not specify this URL on Ariba CSN, it routes the PunchOut Setup
Request to the URL specified within your index catalog.
• If you specify this URL on Ariba CSN, it routes the PunchOut Setup Request to
that URL, not to the URL specified within your index catalog.
It is highly recommended that you enter your PunchOut URL on Ariba CSN, because
if you change the location of your PunchOut site, you can easily change this
parameter on Ariba CSN, without having to distribute new index catalogs. This
parameter enables you to store routing information with the application that needs it
(Ariba CSN) instead of distributing it to applications that do not need it.
Implementation
coordinated with the buying organization. Heavy reliance on extrinsic data is
discouraged, since it makes the scaling of the PunchOut integration to other buying
organizations more difficult.
1 Supplier PunchOut
procurement application, Ariba Buyer, passes it back to the supplier in any
Implementation
subsequent PunchOut Setup Request “edit” or “inspect” sessions, and any resulting
cXML Order Request. The cookie is often used to associate items in a purchase
requisition with the corresponding items in a shopping cart at the supplier’s Website.
Extrinsics are not currently supported in any document sent to Ariba Buyer.
1 Supplier PunchOut
Implementation
If you work with Ariba Marketplace, Network Edition (AM-NE) marketplaces and
you have a cXML-enabled Website, you should be aware of a change to cXML
documents. All cXML 1.1 documents from marketplaces, such as PunchOut Setup
Requests and purchase orders, contain multiple From credentials. A new credential
that identifies the member organization will supplement the existing credential that
identifies the marketplace host.
1 Supplier PunchOut
accept multiple From credentials; for example:
Implementation
<From>
<!-- Acme Enterprises -->
<Credential domain = "NetworkID">
<Identity>AN66667777</Identity>
</Credential>
<!-- Triton Bank B2B Exchange -->
<Credential domain = "NetworkID" type="marketplace">
<Identity>AN223344789</Identity>
1 Supplier PunchOut
</Credential>
Implementation
</From>
<To>
<!-- Work Chairs, Inc. -->
<Credential domain = "duns">
<Identity>942888711</Identity>
<SharedSecret>abracadabra</SharedSecret>
</Credential>
</To>
1 Supplier PunchOut
Implementation
You can include "type-marketplace" in the credential you pass back to AM-NE. For
cXML 1.0 documents, AM-NE will continue to include only the marketplace host’s
credential, and it will leave off the "type=marketplace" attribute. No Credential element
for the member company is provided to cXML 1.0 suppliers.
To use the Profile transaction, send a Profile Request document with the following To
credential:
<To>
<Credential domain="AribaNetworkUserId">
<Identity>admin@ariba.com</Identity>
</Credential>
</To>
Ariba CSN responds with a list of all Requests that it supports, and the appropriate
URLs for those Requests. The information returned changes occasionally; it is
recommended that cXML-enabled Websites issue a Profile Request daily. For
complete information about the Profile transaction, see the cXML User’s Guide.
7HVWLQJ
The objective of PunchOut testing is to ensure that the PunchOut technology is
configured properly and that the supplier’s site will effectively communicate with
Ariba Buyer. There are three phases of supplier testing:
Implementation
Self-Testing on Ariba CSN
Supplier test accounts have a built-in order tester that allows you to check CIF
catalogs and order routing. The order tester can be used to send simple purchase
orders to the supplier. The tester is only available with CIF 2.1 format and PunchOut
catalogs. The tool is useful for debugging a PunchOut-enabled Website and for
1 Supplier PunchOut
demonstrating the site to a potential customer.
Implementation
▼ To self-test on Ariba CSN:
Note: The order tester exists only in test accounts, not in production
accounts.
1 Supplier PunchOut
2. Create a PunchOut catalog entry at supplier.ariba.com.
Implementation
For specific details on creating this, please see the Ariba Network Supplier’s
Guide.
Note: Only catalogs in the test account are visible. Catalogs can be tested
before or after publishing them, but they must first pass validation. If a
1 Supplier PunchOut
“Test” link does not display, the catalog failed validation, or it is not in one
Implementation
of the testable formats.
1 Supplier PunchOut
this link, a frame set opens and displays your live Web page for that item.
Implementation
6. After creating a purchase order, click Submit to send it.
Ariba CSN generates a cXML purchase order. You can view the cXML
contents and response from Ariba CSN.
In addition to completing these steps, the supplier should have their functional and
technical staff available for testing. A series of transactions get the information from
the supplier’s site, return to the requisition, submit for approval, and approve an order.
The time required to perform these transactions depends on the number of
transactions tested, the number of commodities included in the testing, and the
complexity of the supplier’s site.
A few specific scenarios to run through when testing with the customer are suggested
below. The purpose of these illustrations is to give you an idea of how the PunchOut
site and Ariba Buyer work together. In addition to the cases listed, it is recommended
that you follow the same scenarios used when testing directly with Ariba. For further
details, contact Ariba CSN and work with the buyer to help define the testing script.
Authentication
Implementation
Security
The PunchOut site URL must be HTTPS (secure). HTTP may be used for testing, but
the site must be secure before it can be deployed.
1 Supplier PunchOut
Implementation
Testing the PunchOut item
Create a requisition in Ariba Buyer. Select a PunchOut item from the
PunchOut catalog for the specific supplier.
Expected behavior: The system should connect to your site. The user should
be able to shop, place items in a cart, then return the cart to the Ariba Buyer
requisition.
1 Supplier PunchOut
Simulating a lost connection
Implementation
Create a requisition in Ariba Buyer. Select a PunchOut item from the
PunchOut catalog. The system brings up the supplier’s site. Close the
supplier’s site before “checking out.”
Expected behavior: The user should be returned to Ariba Buyer and see the
Ariba Front Page.
Contact with the site reinitiates and a PunchOut item selected from the
1 Supplier PunchOut
PunchOut catalog.
Implementation
Expected behavior: Return to the supplier’s site, where shopping cart should
be empty.
1 Supplier PunchOut
Expected behavior: Both items appear in the cart upon return to the
Implementation
supplier’s site.
The Cart returns to Ariba Buyer. Both items are selected and removed.
Expected behavior: All the items selected from the PunchOut session should
be removed.
1 Supplier PunchOut
Implementation
1. Using PunchOut, a user goes to the supplier site and provides configuration
data. The supplier returns a line item.
2. Using PunchOut with an edit, the user selects a product which causes a line
item to be brought back with pricing. Ariba CSN approval flow has been
initiated. The order request is sent. The user now tries to PunchOut with both
edit and inspect.
1. Using PunchOut, a buyer goes to your site and provides configuration data.
You provide a line item back including contract pricing.
2. The Ariba user submits the requisition and initiates the workflow and
approval process.
3. Once the requisition is approved, the user, through an edit PunchOut, selects
a product. The user can also PunchOut with inspect. The supplier sends the
order request.
1. Using PunchOut, the user goes to supplier site and selects configuration.
Supplier provides line item(s) back to Ariba CSN.
3. Ariba workflow and approvals are done through Ariba CSN. The order
request is sent.
Implementation
'HSOR\PHQW
Prior to going live, have the buyer migrate content and order routing to production.
This includes creating new Websites, generation of customer-specific content and
pricing, and infrastructure enhancements to support additional traffic. In addition,
confirmation should be made that the Customer Service organization on your side is
1 Supplier PunchOut
ready to support any new policies and procedures. Schedule several orders through
Implementation
the buyer’s and supplier’s system to validate connectivity in the production
environment. Finally, have the buyer confirm with Ariba Buyer your go-live date and
closely monitor the Ariba account to ensure connectivity with the buyer’s order entry
system.
1 Supplier PunchOut
Implementation
• How you authenticates the user
• How you handle non-Catalog orders
• How you handle copied requisitions
• How to handle control data such as shipToLocationID’s from the buyer
• How the buyer can specify content to be shown, such as contract only, or both non-
1 Supplier PunchOut
contract and contract items
Implementation
The availability of this information will make the rollout to subsequent customers a
much easier task.
1 Supplier PunchOut
Implementation
1 Supplier PunchOut
Implementation
Development of a
PunchOut Site
PunchOut Site
2 Expediting
If speed to market is a concern, use Ariba’s examples as a starting point. If ASP
(Active Server Pages), Cold Fusion, or another scripted environment is already in
place, then Website assistance is readily available. Ariba has some “non-supported”
Development of a
examples available on how to handle PunchOut Setup Request and Response
PunchOut Site
2 Expediting
documents. Once a system can support the Request and Response, an Ariba user can
PunchOut to the supplier’s Website. To obtain the example source code, request a zip
file from an Ariba Commerce Services Network contact.
Use the following steps as a guide to help you to rapidly deploy a PunchOut site:
Development of a
2. Adapt a bid/quote, then a receive order model.
PunchOut Site
2 Expediting
If the current site won’t support the order model, leverage the existing code
base and build a new site with new processes. One size fits all is not always
appropriate, and often looks and works poorly.
3. Remove or deactivate:
• Payment info
Development of a
PunchOut Site
• Shipping info
2 Expediting
• Workflow
cXML Messaging
The PunchOut Setup Request and PunchOut Setup Response are how a buyer obtains
the login to a supplier site and initiates a PunchOut session. See “Rapid Site
Deployment” on page 43 of this document for sample cXML code geared toward
rapid implementation.
A zip file of the code is available from Commerce Services for ASP (Active Server
Page) and Cold Fusion implementations. See “Ariba Technical Support” on page iv
for contact information.
Note: If using the ASP version, Microsoft IIS 3.0 or 4.0 and Internet
Explorer 5 are required on the Web server.
The following is a clarification of the Active Server Pages referenced in the example.
• receivePunchoutSetupRequest.asp
This file grabs the HTTP POST cXML message and outputs a valid cXML
Response document containing the supplier’s login URL.
• resolveXML.asp
This file loads the HTTP POST into a Microsoft DOM object and extracts
data for the PunchOut Setup Response document.
Existing Website
3 Retrofitting an
In many cases, a supplier has an existing Website they may be able to use to
accommodate PunchOut. This approach can be either very difficult or simple
depending on what is currently in place. Software works best when its design meets
its use. Requirements change, and opportunities evolve; the best of both worlds is to
leverage what has already been created.
Existing Website
3 Retrofitting an
Leveraging the Existing Site
Often suppliers have an existing e-commerce site that they consider a B2B site. Their
customers typically log in directly, configure commodities, and place orders. The end
user enters an order, usually pays by credit card, and selects shipping instructions.
Then, the order is placed and the transaction is complete. However, technically, this is
Existing Website
3 Retrofitting an
a B2C type application: consumer direct, commodity selection, and order creation.
If the site has dynamic workflow, approvals, saved shopping carts, and contracted
pricing, then it’s a B2B site. But even if the supplier has a true B2B type application,
it still most likely images B2C, and there are several processes that are no longer
needed. Existing processes such as dynamic workflow, or collection of shipping and
payment information, will probably not be needed during configuration for an Ariba
Buyer user.
Existing Website
3 Retrofitting an
The Ariba model to adopt when creating a PunchOut site is bid/quote, then purchase.
PunchOut sessions are for configuration only. The process flow is as follows:
1. An Ariba Buyer user uses PunchOut to go to the supplier site and select a
product.
3. In Ariba Buyer, the user selects logistic information including Bill-to, Ship-
Existing Website
3 Retrofitting an
to, shipping method, and Need-by date. This may also occur prior to the
initial PunchOut session.
4 Integrating Service
Organizations
Often, tangible products are not the only items an Ariba Buyer user might wish to
procure through PunchOut. Many companies supply only services. Developing a
PunchOut site for services requires detailing the process with the customer.
Procuring services through Ariba Buyer is very different from procuring commodities
4 Integrating Service
such as books and pencils, which are easily managed. For these simple commodities,
Organizations
the work flow for approval and the access control lists are within Ariba Buyer; there
is no preliminary “configuration” required, and the number of items listed in the
catalog are not in the tens of thousands, nor are they dynamically changing based on
market conditions.
Any commodity that does not follow the above principles lends itself to PunchOut,
where the commodity catalog is maintained by the supplier in the context of Ariba
Buyer. Thus, integrating services with the Ariba Buyer requires the supplier to
4 Integrating Service
PunchOut enable their services exchange.
Organizations
PunchOut for Services
You can create PunchOut sites that supply services or contract work. The vast
majority of supplier service exchanges operate on these two distinct workflow
4 Integrating Service
possibilities:
Organizations
• Opening a position
If the request to punch out is successful, the supplier’s exchange sends a URL to
Ariba Buyer which opens a new browser window with that URL. All supplier session
variables now pertain to the new browser window, where the Ariba Buyer user begins
4 Integrating Service
a new session, completely controlled by the supplier’s services exchange. After the
user has initiated and completed the session within the services exchange, they are
Organizations
sent back to Ariba Buyer. The supplier’s services exchange submits the required
fields to Ariba Buyer, populating a single line of the requisition. This first milestone
in a PunchOut is called a “create” operation.
Milestones
The two milestones involved in PunchOut are creating a session, and editing a
session. Creating a session to retain a “contract worker” follows to further describe
the process of these milestones:
• Create session
The PunchOut operation of opening a contract worker position is a create session.
This session is subject to a fiscal approval flow within Ariba Buyer if it returns with
dollar estimates for requested services.
The work flow can be stopped temporarily from proceeding by withholding a key
field such as Unit of Measure (UOM). The Ariba user receives an e-mail
notification from the supplier’s services exchange to return to the site and continue
with the process. At this point, asynchronous communications between the buyer
and the supplier, initiated by the supplier, can exist only in the form of e-mail
messages. This e-mail message from the supplier can only initiate an action by the
Ariba user and cannot automatically trigger an event within Ariba Buyer.
• Edit session
The edit session is where the above mentioned missing UOM field can be entered,
thus making the requisition complete and ready for the start of the approval process
within Ariba Buyer. The create session is the first event and opens a contract
worker position; edit is the second event and engages a candidate to fill the opened
position. Opening a position does not go through an Ariba approval, while
engaging a candidate does.
If opening a position requires a pre-approval in Ariba Buyer, then a custom double
approval chain for the service-specific commodity needs to be written. The
supplier’s service exchange needs to be notified of approval or denial of this
request. At this time, this can be done only through e-mail notifications, e-mail
notifications cannot be triggered by the approval engine.
The edit operation is the more crucial step, since it populates Ariba Buyer with the
required fields, while the create operation triggers the search for the candidate. After
the approval process within Ariba Buyer, the Purchase Order is sent to the supplier’s
service exchange.
4 Integrating Service
Organizations
The contract worker starts on the negotiated start date and enters time worked into
time sheets maintained and invoiced to Ariba Buyer, in this case the supplier of the
service. The Accounts Payable ERP system linked to Ariba Buyer processes the
invoices and pays against them accordingly. The AP process is outside of Ariba Buyer
at this time and not tracked within Ariba Buyer.
4 Integrating Service
Note that this is a simplified approach to a possible integration. This integration
assumes a sign-off from all parties concerned. Any modification to this approach will
Organizations
require customizing and the involvement of an Ariba implementation team. Time
sheets, for example, are not supported by standard PunchOut messages and require
additional development by the supplier and the buyer.
4 Integrating Service
Organizations
4 Integrating Service
Organizations
4 Integrating Service
Organizations
4 Integrating Service
Organizations
5 Sample Code
The examples provided in the following sections are meant only as a guide. The code
below is not intended to be implemented “as is” into a supplier’s cXML documents or
Website.
5 Sample Code
cXML Index File
A cXML index file is a PunchOut index file that the buyer loads into Ariba Buyer to
create entries in the catalog hierarchy. The file defines how the supplier and their
products appear in the Ariba Buyer catalog UI. The important elements of an index
file are as follows:
SupplierID
5 Sample Code
Because buyers identify their respective suppliers in a unique fashion that is usually
rooted in an ERP or legacy system (e.g., a vendor number), a supplier should choose a
standard way of identifying themselves to buyers. The preferred standard among most
buyers is the D-U-N-S® number. Information on D-U-N-S numbers can be found at
http://www.dnb.com/.
URL
5 Sample Code
The URL identifies a resource which processes a PunchOut Setup Request document.
The Ariba Network, upon authenticating the setup request, may forward the cXML
document to this resource. In all cases, this URL appears in the PunchOut Setup
Request for sessions started in this line item.
Classification
Buyers and suppliers often have unique ways of representing their items. For a
punchout index item to map correctly to an entry in the buyer’s catalog hierarchy,
5 Sample Code
items must be identifiable. The standard method among buyers for classifying
products is UNSPSC. For more information on this, see http://www.unspsc.com.
Suppliers must identify the items they want represented in a buyer’s catalog hierarchy
by its UNSPSC code in this field. The number of items needed in the catalog
hierarchy depends on the configuration of the buyer’s system and on the supplier’s
ability to serve up a dynamic page based on product-level attributes. If the catalog is
targeted for PunchOut only, only one default UNSPSC code is required. Note: in the
index file the domain name is UNSPSC.
<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE Index SYSTEM "http://xml.cxml.org/schemas/cXML/1.1.009/cXML.dtd">
<Index>
<SupplierID domain="DUNS">1234567</SupplierID>
<Comments xml:lang="en-US">Sample cXML/Index</Comments>
<IndexItem>
<IndexItemPunchout>
<ItemID>
<SupplierPartID>po123456</SupplierPartID>
</ItemID>
<PunchoutDetail>
<Description xml:lang="en-US">Supplier R Us</Description>
<URL>http://www9.supp.com/cgi-
bin/hsrun/Staging/SRUS_SD/SRUS_SD.htx;start=AribaRequest</URL>
<Classification domain="UNSPSC">88888889</Classification>
</PunchoutDetail>
</IndexItemPunchout>
</IndexItem>
</Index>
Key Elements
The important elements in a PunchOut Setup Request document are as follows:
Credential domain
The <From> element contains the buyer’s Ariba Network ID. The <To> element
contains the supplier’s D-U-N-S number.
5 Sample Code
Identity
SharedSecret
Contains the buyer’s secret on the Ariba Network which Ariba CSN replaces with the
5 Sample Code
supplier’s password for login to the PunchOut site.
BuyerCookie
Used by the supplier to track the actions of a buyer while in a particular PunchOut
session. The cookie changes with each PunchOut session.
Extrinsic
5 Sample Code
Used to further identify a user to a supplier. The standard extrinsics sent from Ariba
Buyer are User and CostCenter. Both elements are maintained by the buyer.
Contact
SupplierSetup URL
5 Sample Code
In releases of cXML prior to 1.1, the SupplierSetup element specifies the URL of your
PunchOut Website. This URL is generated from the Supplier’s storeFrontURL, or from
the PunchOutDetail URL, depending on where the user is when they PunchOut.
Beginning with cXML 1.1, the e-commerce hub already knows the URL of your
PunchOut Website.
SelectedItem
5 Sample Code
Starting with cXML 1.1, procurement applications can use the SelectedItem element to
specify store-, aisle-, or product-level PunchOut.
The SupplierSetup element has been deprecated. However, your PunchOut Website
must continue to handle this methods until all PunchOut Websites recognize the
SelectedItem element.
5 Sample Code
Sample
The following is a sample of a PunchOut Setup Request document:
<?xml version="1.0"?>
<!DOCTYPE cXML SYSTEM "http://xml.cxml.org/schemas/cXML/1.1.009/cXML.dtd">
<cXML payloadID="958075346970@www.xyz3Demo.com " timestamp="2000-06-
14T12:57:09-07:00">
<Header>
<From>
<Credential domain="NetworkID">
<Identity>AN010000002792</Identity>
</Credential>
</From>
<To>
<Credential domain="DUNS">
<Identity>12345678-T</Identity>
</Credential>
</To>
<Sender>
<Credential domain="NetworkID">
<Identity>AN010000002792-T</Identity>
<SharedSecret>I+,F$,\[</SharedSecret>
</Credential>
<UserAgent>Ariba ORMS 6.1</UserAgent>
</Sender>
</Header>
<Request>
<PunchOutSetupRequest operation="create">
<BuyerCookie>1J3YVWU9QWMTB</BuyerCookie>
<Extrinsic name="CostCenter">610</Extrinsic>
<Extrinsic name="User">jpicard</Extrinsic>
<BrowserFormPost>
<URL>http:// buyeruser:3377/punchout</URL>
</BrowserFormPost>
<SupplierSetup>
<URL>https://xyzdemo.xyzr.com/servlets/AribaBuyerServlet</URL>
</SupplierSetup>
<ShipTo>
<Address addressID="001">
<Name xml:lang="en">Acme Headquarters No2</Name>
<PostalAddress>
<DeliverTo>Jean Picard</DeliverTo>
<Street>1565 Pine, MS A.2</Street>
<City>New York</City>
<State>NY</State>
<PostalCode>01043</PostalCode>
<Country isoCountryCode="US">United States</Country>
</PostalAddress>
5 Sample Code
</Address>
</ShipTo>
<Contact>
<Name>Fred Perry</Name>
</Contact>
<SelectedItem>
<ItemID>
<SupplierPartID>54543</SupplierPartID>
5 Sample Code
</ItemID>
</SelectedItem>
</PunchOutSetupRequest>
</Request>
</cXML>
5 Sample Code
After receiving a PunchOut Setup Request document, the supplier Website sends a
PunchOut Setup Response document. The PunchOut Setup Response document
serves two functions:
5 Sample Code
Key Elements
The important elements in a PunchOut Setup Response document are as follows:
Status
5 Sample Code
code attribute and a text attribute, and an optional xml:lang attribute. The code attribute
follows the HTTP status code model. In general, a 2xx series code indicates a
successful client-server communication, a 4xx series code indicates a client error
status code, and a 5xx series code indicates a server error code. The text attribute and
optional xml:lang attribute allow for a text description of the status returned in a
response. Suppliers are strongly encouraged to place the actual XML parse or
application error in the body of the Status element. This allows for better one-sided
debugging and inter operability testing.
5 Sample Code
StartPage URL
The PunchOut Setup Response document contains a URL element that specifies the
start page URL to pass to the user’s browser for the interactive browser session.
Sample
The following is a sample of a PunchOut Setup Response document:
<!DOCTYPE cXML SYSTEM "http://xml.cxml.org/schemas/cXML/1.1.009/cXML.dtd">
<cXML payloadID="958074700772@www.xyz3Demo.com" timestamp="2000-06-
14T12:59:09-07:00">
<Response>
<Status code="200" text="success"/>
<PunchOutSetupResponse>
<StartPage>
<URL>https://xyzdemo.xyzr.com/servlets/AribaServlet?pageid=psaribastartpage&#
x26;sessionid=986958074700612</URL>
</StartPage>
</PunchOutSetupResponse>
</Response>
</cXML>
Effectively, with the PunchOut Order Message, the supplier has provided a quote for
the requested items—but has not yet received a purchase order, so the order cannot
yet be booked. This message is submitted to the procurement application, returning
the user’s browser to their requisition.
Key Elements
The important elements in a PunchOut Order Message document are as follows:
5 Sample Code
operationAllowed
Specifies the PunchOut Setup Request operation allowed: create, inspect, or edit. This
attribute controls whether the user can initiate a later PunchOut Setup Request
transaction containing data from a PunchOut Order Message. If operationAllowed=
“create”, only a later Order Request can contain these items. Otherwise, the
procurement application can inspect or edit the shopping cart later, initiating
5 Sample Code
subsequent PunchOut Setup Request transactions with the appropriate operations and
the ItemOut elements corresponding to the ItemIn list returned in a PunchOut Order
Message. Support for edit implies support for inspect.
cxml-urlencoded
Hidden HTML form field that stores the cXML PunchOut Order Message.
Optionally, this can be cxml-base64 in cXML 1.1.
5 Sample Code
BuyerCookie
Used by Ariba Buyer to validate the PunchOut Order Message and retrieve the line
item collection. Once used, it is discarded by the buyer, and is valid only for one hour
after it is issued. The PunchOut Order Message must contain the same BuyerCookie that
was used in the PunchOut Setup Request for this PunchOut session.
SupplierPartAuxiliaryID
5 Sample Code
Helps the remote Website transport complex configuration and bill-of-goods
information to re-identify the item when presented to a remote Website in the future.
If SupplierPartAuxiliaryID contains special characters, such as additional XML elements
not defined in the cXML protocol, they must be escaped properly.
Classification domain
Specifies the commodity grouping of the line item to the buyer. All products and
5 Sample Code
services must be mapped and standardized to the UNSPSC schema. Determines
handling in ERP systems and buyer systems of different commodities with varying
workflow. For a list of UNSPSC codes, see http://www.unspsc.org/
Sample
The following is a sample of a PunchOut Order Message document:
5 Sample Code
<Header>
<From>
<Credential domain="DUNS">
<Identity>12345678</Identity>
</Credential>
</From>
<To>
<Credential domain="NetworkId">
<Identity>AN01000002792-T</Identity>
</Credential>
</To>
<Sender>
<Credential domain="www.xyz3Demo.com">
<Identity>PunchoutResponse</Identity>
</Credential>
<UserAgent>xyz3.x Buyer Services</UserAgent>
</Sender>
</Header>
<Message>
<PunchOutOrderMessage>
<BuyerCookie>1J3YVWU9QWMTB</BuyerCookie>
<PunchOutOrderMessageHeader operationAllowed="edit">
<Total>
<Money currency="USD">14.27</Money>
</Total>
</PunchOutOrderMessageHeader>
<ItemIn quantity="2">
<ItemID>
<SupplierPartID>3171 04 20</SupplierPartID>
<SupplierPartAuxiliaryID>ContractId=1751
ItemId=417714</SupplierPartAuxiliaryID>
</ItemID>
<ItemDetail>
<UnitPrice>
<Money currency="USD">1.22</Money>
</UnitPrice>
<Description xml:lang="en">ADAPTER; TUBE; 5/32"; MALE; #10-32 UNF;
FITTING</Description>
<UnitOfMeasure>EA</UnitOfMeasure>
<Classification domain="UNSPSC">21101510</Classification>
<ManufacturerName>Dogwood</ManufacturerName>
</ItemDetail>
</ItemIn>
<ItemIn quantity="1">
<ItemID>
<SupplierPartID>3801 04 20</SupplierPartID>
<SupplierPartAuxiliaryID>
ContractId=1751 ItemId=417769
</SupplierPartAuxiliaryID>
</ItemID>
5 Sample Code
<ItemDetail>
<UnitPrice>
<Money currency="USD">11.83</Money>
</UnitPrice>
<Description xml:lang="en">ADAPTER; TUBE; 5/32"; 2 PER PACK; MALE #10-
32 UNF; STAINLESS STEEL; FITTING</Description>
<UnitOfMeasure>EA</UnitOfMeasure>
<Classification domain="UNSPSC">21101510</Classification>
5 Sample Code
<ManufacturerName>Legris</ManufacturerName>
</ItemDetail>
<SupplierID domain="DUNS">022878979</SupplierID>
</ItemIn>
</PunchOutOrderMessage>
</Message>
</cXML>
5 Sample Code
Order Request Document
The Order Request is analogous to a purchase order. It contains header and line item
details so that a product can be shipped and invoiced correctly to the buyer.
Key Elements
5 Sample Code
In addition to the key elements identified in the Punchout Order Message, the
following are critical in the Order Request document:
ShipTo/DeliverTo
First line
5 Sample Code
Second line
The location, building, city, office, mail stop, where goods will be delivered.
Sample
The following is a sample of a Order Request document:
<?xml version="1.0" encoding="UTF-8"?>
5 Sample Code
<Request>
<OrderRequest>
<OrderRequestHeader orderID="DO152" orderDate="2000-05-
11T13:10:11+07:00" type="new">
<Total>
<Money currency="USD">13.05</Money>
</Total>
<ShipTo>
<Address isoCountryCode="US" addressID="001">
<Name xml:lang="en">Acme Headquarters No2</Name>
<PostalAddress name="default">
<DeliverTo>Jonluc Picard</DeliverTo>
<DeliverTo>Acme Headquarters No2</DeliverTo>
<Street>1565 Pine, MS A.2</Street>
<City>New York</City>
<State>NY</State>
<PostalCode>01035</PostalCode>
<Country isoCountryCode="US">United States</Country>
</PostalAddress>
<Email name="default">rlim@acme.com</Email>
<Phone name="work">
<TelephoneNumber>
<CountryCode isoCountryCode="US">1</CountryCode>
<AreaOrCityCode>718</AreaOrCityCode>
<Number>9306200</Number>
</TelephoneNumber>
</Phone>
<Fax name="work">
5 Sample Code
<TelephoneNumber>
<CountryCode isoCountryCode="US">1</CountryCode>
<AreaOrCityCode>718</AreaOrCityCode>
<Number>9308410</Number>
</TelephoneNumber>
</Fax>
<URL name="default">www.acme.com</URL>
</Address>
5 Sample Code
</ShipTo>
<BillTo>
<Address isoCountryCode="US" addressID="15">
<Name xml:lang="en">Acme Headquarters</Name>
<PostalAddress name="default">
<Street>1565 Pine, MS A.2</Street>
<City>New York</City>
<State>NY</State>
<PostalCode>01035</PostalCode>
<Country isoCountryCode="US">United States</Country>
5 Sample Code
</PostalAddress>
<Email name="default">rlim@acme.com</Email>
<Phone name="work">
<TelephoneNumber>
<CountryCode isoCountryCode="US">1</CountryCode>
<AreaOrCityCode>718</AreaOrCityCode>
<Number>9306200</Number>
</TelephoneNumber>
</Phone>
<Fax name="work">
5 Sample Code
<TelephoneNumber>
<CountryCode isoCountryCode="US">1</CountryCode>
<AreaOrCityCode>718</AreaOrCityCode>
<Number>9308410</Number>
</TelephoneNumber>
</Fax>
<URL name="default">www.acme.com</URL>
</Address>
</BillTo>
</OrderRequestHeader>
5 Sample Code
<ItemOut quantity="1" >
<ItemID>
<SupplierPartID>3171 04 20</SupplierPartID>
<SupplierPartAuxiliaryID>ContractId=1751 ItemId=417714</SupplierP
artAuxiliaryID>
</ItemID>
<ItemDetail>
<UnitPrice>
<Money currency="USD">1.22</Money>
</UnitPrice>
5 Sample Code
<Description
xml:lang="en">ADAPTER; TUBE; 5/32"; MALE; #10-
32 UNF; FITTING</Description>
<UnitOfMeasure>EA</UnitOfMeasure>
<Classification domain="UNSPSC">88888889</Classification>
<ManufacturerName>Legris</ManufacturerName>
<URL>https://xyzdemo.xyzr.com/servlets/AribaBuyerServlet</URL>
<Extrinsic name="PR No.">PR172</Extrinsic>
<Extrinsic
name="Requester">Jonluc Lim (AN Consultant)</Extrinsic>
</ItemDetail>
<Distribution>
<Accounting name="DistributionCharge">
<Segment type="Cost Center" id="5202"
description="Department Name"/>
<Segment type="Account" id="5203" description="Account Name"/>
</Accounting>
<Charge>
<Money currency="USD">1.22</Money>
</Charge>
</Distribution>
</ItemOut>
<ItemOut quantity="1" >
<ItemID>
<SupplierPartID>3801 04 20</SupplierPartID>
<SupplierPartAuxiliaryID>ContractId=1751 ItemId=417769</SupplierPartAuxiliaryID
>
</ItemID>
<ItemDetail>
<UnitPrice>
<Money currency="USD">11.83</Money>
</UnitPrice>
<Description
xml:lang="en">ADAPTER; TUBE; 5/32"; 2 PER PA
CK; MALE #10-
32 UNF; STAINLESS STEEL; FITTING</Description>
<UnitOfMeasure>EA</UnitOfMeasure>
<Classification domain="UNSPSC">88888889</Classification>
<ManufacturerName>Legris</ManufacturerName>
<URL>https://xyzdemo.xyzr.com/servlets/AribaBuyerServlet</URL>
<Extrinsic name="PR No.">PR172</Extrinsic>
<Extrinsic
name="Requester">Jonluc Lim (AN Consultant)</Extrinsic>
</ItemDetail>
<Distribution>
<Accounting name="DistributionCharge">
<Segment type="Cost Center" id="5202"
description="Department Name"/>
<Segment type="Account" id="5203" description="Account Name"/>
</Accounting>
5 Sample Code
<Charge>
<Money currency="USD">11.83</Money>
</Charge>
</Distribution>
</ItemOut>
</OrderRequest>
</Request>
</cXML>
5 Sample Code
Order Response Document
The Order Response document acknowledges that you have received the purchase
order and that it parsed correctly. It is not a commitment to execute the purchase
order. If the message received is not a valid cXML document, a return code of 500 is
acceptable. All cXML Order Request transactions, including ad hoc, changed, and
5 Sample Code
cancelled orders, should be acknowledged with a Status code of 200.
Sample
The following is a sample of a Order Response document:
<?xml encoding="UTF-8"?>
<!DOCTYPE cXML SYSTEM "http://xml.cxml.org/schemas/cXML/1.1.009/cXML.dtd">
5 Sample Code
<cXML timestamp="2000-06-14T13:07:39-07:00" payloadID="958075659144--
4074645440380323973@206.251.25.163">
<Response>
<Status code="200" text="OK"></Status>
</Response>
</cXML>
5 Sample Code
Rapid Site Deployment
The following ASP examples can be used as a starting point to rapidly deploy a site
for PunchOut. The two files demonstrate how to handle PunchOut Setup Request and
Response documents. Once a system can support the Request and Response, an Ariba
user can punch out to the supplier’s Website. To obtain the example source code,
request a zip file from an Ariba Commerce Services contact.
5 Sample Code
Please note that this is basic example and not production quality. For example,
credential variables attached in the query string are not acceptable for production
code. Variables have not been declared and must be prior to use. Since a global
variable file has not been included with this example, change the following variables
in the appropriate locations:
receivePunchoutSetupRequest.asp
myAribaPassword = "welcome"
myURL = http://nathanalbee/punchoutasp/
resolveXML.asp
olddtdvalue = """cXML.dtd"""
newdtdvalue = """http://nathanalbee/cxml1.1/cXML.dtd"""
File receivePunchoutSetupRequest.asp
This file grabs the HTTP POST cXML message and outputs a valid cXML PunchOut
Setup Response document containing the supplier’s login URL:
<%@LANGUAGE = VBScript%>
<%
Dim myAribaPassword
Dim myURL
%>
<%
’********************************Comments****************************
’Include file that loads http post cXML and parses with MS DOM
’********************************************************************
%>
<!--#include file="resolveXML.asp" --->
<%
’********************************Comments****************************
’ Variables needed for example Very simple validation for asp
’ Set sharedsecret password expected from Ariba
’********************************************************************
myAribaPassword = "welcome"
myURL = "http://nathanalbee/punchoutaspv2/"
%>
<%
’********************************Comments****************************
’Basic Shared Secret validation.
’IMPORTANT
’Please note: You will need to fix the timestamp and payloadID the
’f() Now is currently invalid and will fail on some builds of Ariba Buyer as well as
’other product lines. Please user format specified in the cxml users guide available
5 Sample Code
’@ http://www.cxml.org
’See file TCcXMLFormatDTime.asp for a good start on formatting the time ISO 8601
date/time standard.
’********************************************************************
5 Sample Code
<cXML version="1.0" payloadID="<%= Now &"@"&
Request.ServerVariables("LOCAL_ADDR")%>" timestamp="<%= Now
%>">
<Response>
<Status code="500" Text="Invalid document" />
</Response>
</cXML>
<% else %>
<?xml version="1.0" ?>
<!DOCTYPE cXML SYSTEM "cXML.dtd">
5 Sample Code
<cXML version="1.0" payloadID="<%= Now &"@"&
Request.ServerVariables("LOCAL_ADDR")%>" timestamp="<%= Now
%>">
<Response>
<Status code="200" text="Success">
</Status>
<PunchOutSetupResponse>
<StartPage>
<URL>
<%=myURL%>
5 Sample Code
<html>
<head>
<title></title>
</head>
<body>
<p>b2bsite/shop.asp?fromIdentity=<%= fromIdentity%>&operation=<%=
operation%>&buyerCookie=<%= buyerCookie%>&BrowserFormPost=<%=
5 Sample Code
BrowserFormPost%></URL></StartPage></PunchOutSetupResponse></Response></c
XML> <%end if%> </p>
</body>
</html>
File resolveXML.asp
5 Sample Code
This file loads the HTTP POST into a Microsoft DOM object and extracts data for the
PunchOut Setup Response document:
<%
Dim xml
Dim xdoc
Dim xml2
’********************************Comments****************************
’ MSDOM can’t resolve DTD’s, so replace defination with URL
’ GET dtd’s from http://cxml.org/
’ But put them locally on your server for performance
’********************************************************************
Dim olddtdvalue
Dim newdtdvalue
olddtdvalue = """cXML.dtd"""
newdtdvalue = """http://nathanalbee/cxml1.0/cXML.dtd"""
’********************************Comments****************************
’ Create MSDOM Object and set load values
’********************************************************************
5 Sample Code
Set senderCred =
xdoc.getElementsByTagName("Header/Sender/Credential/Identity")
senderCred = (senderCred.item(0).text)
Set sharedSecret =
xdoc.getElementsByTagName("Header/Sender/Credential/SharedSecret")
sharedSecret = (sharedSecret.item(0).text)
Set fromUserAgent =
xdoc.getElementsByTagName("Header/Sender/UserAgent")
5 Sample Code
fromUserAge = (fromUserAgent.item(0).text)
Set operation =
xdoc.documentElement.childNodes(1).childNodes(0).attributes.getNamedItem("operation"
)
operation =
xdoc.documentElement.childNodes(1).childNodes(0).attributes.getNamedItem("operation"
).text
Set buyerCookie =
xdoc.getElementsByTagName("Request/PunchOutSetupRequest/BuyerCookie")
buyerCookie = (buyerCookie.item(0).text)
5 Sample Code
Set buyExtrinsics =
xdoc.getElementsByTagName("Request/PunchOutSetupRequest/Extrinsic")
For i = 0 To (buyExtrinsics.length -1)
BuyExtrinsicVars = (buyExtrinsics.item(i).text) & "," & BuyExtrinsicVars
Next
Set BrowserFormPost =
xdoc.getElementsByTagName("Request/PunchOutSetupRequest/BrowserFormPost")
BrowserFormPost = (BrowserFormPost.item(0).text)
’********************************Comments****************************
5 Sample Code
’ Some nice MSDOM error logging for a failed parse or load
’********************************************************************
Else
Response.Write " <P> xml @ supplier site failed to load using MSDOM: "
Dim strErrText
Dim xPE
5 Sample Code
& "Position In File: " & xPE.filepos & "Source Text: " & xPE.srcText & "Document URL: " &
xPE.url
Response.Write strErrText
End If
Else
’********************************Comments****************************
’ ASP page was called using a GET. Functions expect a post.
’********************************************************************
Response.Write "<P> Wrong Method Get: Post supported only"
End if
5 Sample Code
%>
<html>
<head>
<title></title>
</head>
<body>
</body>
</html>
Index
A E
Ariba Ready 7 EDI 2, 26
Ariba Supplier Link 7 Extrinsic data 14
ASL 7 Extrinsic element 33
ASP 23
H
B HTTPS 19
Index
B2B 25
B2C 25
BuyerCookie element 33, 37 I
Identity element 33
C
cancelled requisition 13 N
Catalog Information Format 5 NetworkID 18
Index
CIF catalog iii, 5, 8, 9, 17
CIF files 1
Classification element 31, 37 O
Cold Fusion 23 operationAllowed attribute 12, 37
Contact element 33 Order Request document 13
Credential element 11, 32 Order Response document 13
Customer Advisory Council 7
cXML 5, 26
cXML catalog iii, 9 P
Index
cXML index file 31 Profile Request document 16
cxml-urlencoded 37 PunchOut 1
PunchOut catalog 1, 10, 17
D PunchOut index file 1, 31
PunchOut Setup Request document 11
Document Type Definition 5 PunchOut Setup Response document 12
DOM object 24 PunchOutOrderMessage element 1
domain attribute 11, 32, 37
DTD 5
Index
R
receivePunchoutSetupRequest.asp 24, 44
resolveXML.asp 24, 44
S
SelectedItem element 14, 33
SharedSecret element 11, 33
StartPage element 36
Status element 13, 35
SupplierID element 31
SupplierPartAuxiliaryID element 15, 20, 37
SupplierSetup element 33
T
Technical Support iv
U
Unit of Measure 8, 28
UNSPSC 5, 31
UOM 8, 28
URL element 31, 33, 36
X
XML 5
XML parser 5
Index
Index
Index
Index
Index
Index