PayflowPro Guide
PayflowPro Guide
Developer’s Guide
© 2008 PayPal, Inc. All rights reserved. PayPal is a registered trademark of PayPal, Inc. The PayPal logo is a trademark of PayPal, Inc. Other
trademarks and brands are the property of their respective owners.
The information in this document belongs to PayPal, Inc. It may not be used, reproduced or disclosed without the written approval of PayPal, Inc.
Copyright © PayPal. All rights reserved. PayPal S.à r.l. et Cie, S.C.A., Société en Commandite par Actions. Registered office: 22-24 Boulevard Royal, L-
2449, Luxembourg, R.C.S. Luxembourg B 118 349
Consumer advisory: The PayPal™ payment service is regarded as a stored value facility under Singapore law. As such, it does not require the approval
of the Monetary Authority of Singapore. You are advised to read the terms and conditions carefully.
Notice of non-liability:
PayPal, Inc. is providing the information in this document to you “AS-IS” with all faults. PayPal, Inc. makes no warranties of any kind (whether express,
implied or statutory) with respect to the information contained herein. PayPal, Inc. assumes no liability for damages (whether direct or indirect), caused
by errors or omissions, or resulting from the use of this document or the information contained in this document or resulting from the application or use
of the product or service described herein. PayPal, Inc. reserves the right to make changes to any information herein without further notice.
Contents
Preface . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 11
Intended Audience . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 11
Organization of This Document . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 11
Where to Go for More Information . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 12
How to Contact Customer Support. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 12
Revision History . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 12
Chapter 1 Introduction . . . . . . . . . . . . . . . . . . . . . . . . . 15
About Payflow Pro . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 15
Payflow SDK Version . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 15
Host Addresses . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 15
How Payflow Pro Works . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 15
Payflow Pro Advantages. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 16
Pre-integrated Solutions . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 16
Supported Processing Platforms . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 17
Supported Credit Cards . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 17
Supported Payment Types . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 17
Payflow Pro Recurring Billing Service . . . . . . . . . . . . . . . . . . . . . . . . . . . . 18
About Security . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 18
First Data Merchant Services (FDMS) North Purchasing Card Transaction Processing . .134
FDMS North Purchasing Card Line Item Parameters . . . . . . . . . . . . . . . . . .135
First Data Merchant Services South (FDMS) Purchasing Card Transaction Processing . .136
FDMS South Line Item Parameters . . . . . . . . . . . . . . . . . . . . . . . . . . .137
Example FDMS South Purchasing Card Level 2 and 3 Parameter String . . . . . . . .138
Example FDMS South Line Item Parameter String . . . . . . . . . . . . . . . . . . .138
Global Payments - Central Purchasing Card Transaction Processing . . . . . . . . . . . .139
Global Payments - Central Level 2 Parameters . . . . . . . . . . . . . . . . . . . . .139
Example Global Payments - Central Level 2 Visa or MasterCard Transaction Parameter
String. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .139
Global Payments - East Purchasing Card Transaction Processing . . . . . . . . . . . . .139
Global Payments - East Level 2 Parameters . . . . . . . . . . . . . . . . . . . . . .140
Example Global Payments - East Level 2 Visa or MasterCard Transaction Parameter String
140
Merchant e-Solutions Purchasing Card Transaction Processing . . . . . . . . . . . . . .140
Merchant e-Solutions Level 2 Parameters. . . . . . . . . . . . . . . . . . . . . . . .140
Merchant e-Solutions Level 3 MasterCard Parameters . . . . . . . . . . . . . . . . .141
Merchant e-Solutions Level 3 Visa Parameters . . . . . . . . . . . . . . . . . . . . .143
Nova Purchasing Card Transaction Processing . . . . . . . . . . . . . . . . . . . . . . .147
Nova Level 2 Parameters . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .147
Nova Additional Parameters . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .147
Example Nova Level 2 Transaction Parameter String . . . . . . . . . . . . . . . . . .148
Paymentech New Hampshire Purchasing Card Transaction Processing . . . . . . . . . .148
Paymentech New Hampshire Level 2 Parameters . . . . . . . . . . . . . . . . . . .148
Paymentech New Hampshire Level 3 Purchasing Card Parameters . . . . . . . . . .149
Paymentech Tampa Level 2 Purchasing Card Transaction Processing . . . . . . . . . . .152
Paymentech Tampa Level 2 Parameters . . . . . . . . . . . . . . . . . . . . . . . .152
Example Paymentech Tampa Level 2 Visa and MasterCard Transaction Parameter String
152
TSYS Acquiring Solutions Purchasing Card Transaction Processing . . . . . . . . . . . .153
TSYS Acquiring Solutions Level 2 Parameters . . . . . . . . . . . . . . . . . . . . .153
TSYS Acquiring Solutions Level 3 MasterCard Parameters. . . . . . . . . . . . . . .153
TSYS Acquiring Solutions Level 3 Visa Parameters. . . . . . . . . . . . . . . . . . .155
Index . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 191
Payflow Pro is a high performance TCP/IP-based Internet payment solution. Payflow Pro is
pre-integrated with leading e-commerce solutions and is also available as a downloadable
software development kit (SDK).
Intended Audience
This guide assumes that its readers:
z Are experienced web or application developers
z Have a background in payments services
z Appendix C, “Submitting Purchasing Card Level 2 and Level 3 Transactions.” Payflow Pro
supports passing Purchasing Card Level 2 information (such as purchase order number, tax
amount, and charge description) in the settlement file.
z Appendix D, “Verbosity: Viewing Processor-Specific Transaction Results,” describes how
you can use the Payflow Verbosity parameter to control the kind and level of information
you want returned in a transaction response.
z Appendix E, “Additional Reporting Parameters,” details the parameters that can be passed
to the server for reporting purposes.
z Appendix F, “ISO Country Codes,” lists Country Codes, Units of Measure, and Currency
Codes.
z Appendix G, “XMLPay,” briefly describes XMLPay and tells where you may obtain a
copy of Payflow Pro XMLPay Developer’s Guide.
z Appendix H, “Codes Used by FDMS South Only,” lists codes used only by First Data
Merchant Services (FDMS) South.
Revision History
Revision history for Payflow Pro Developer’s Guide.
Date Description
March 2008 Added PayPal processor responses.
Updated RESULT value 0 to include information about PayPal processor success with
warning message.
Date Description
February 2008 Removed note that PayPal processor does not support non-referenced credits. It supports
them now.
Updated test and live host URLs.
Added BILLTOCOUNTRY to Paymentech additional parameters.
Combined Telecheck transactions content into one appendix.
November 2007 Explains how merchant can determine what SDK version they are using.
Provides guidelines to merchant to determine if merchant is following American Express
CAPN requirements.
Explains more about VERBOSITY parameter.
Combines appendixes on performing Telecheck transactions with Telecheck responses.
Adds BIN ranges.
Explains how to eliminate TRANSSTATE 106 results.
Updates Index to include an alphabetical listing of all Payflow parameters cited in the
guide.
Adds new transaction type N.
Includes other minor edits for technical accuracy.
September 2007 Updated host addresses. Added new section on host addresses to introduction.
Updated SDK status.
Added AMEXPOSDATA AMEX CAPN response variable. Updated AMEXID
description.
Updated descriptions of Result values 1 and 26.
Added new section on testing Express Checkout through the PayPal Sandbox.
Added new section to button placement on how to eliminate the Express Checkout order
review page.
Date Description
February 2007 Added return codes: 51, 110, 119, 120, 121, 132, 133, 200, 201, 402, 403, 404,
600, and 601.
Updated description of PAYERID in Chapter 7, “PayPal Express Checkout
Transaction Processing.”
Chapter 5, “Testing Payflow Pro Credit Card Transactions,” is updated to
include the PayPal Processor testing values.
December 2006 Revised PayPal button graphics guidelines.
Added error code 51
Corrected test and live URLs
Added SHIPTOSTREET and SHIPTOSTREET2 to Get Express Checkout Details
response paramteters
Host Addresses
Use the following host addresses for the V4 SDK:
z For live transactions, use payflowpro.paypal.com
z For testing purposes, use pilot-payflowpro.paypal.com
For theV3 SDK, use the host addresses below:
z For live transactions, use payflow.verisign.com
z For testing purposes, use test-payflow.verisign.com
2. The Payflow server, a multi-threaded processing environment, receives the request and
transmits it (over a secure private network) to the appropriate financial processing network
for real-time payment authorization.
3. The response (approved/declined, and so on) is received from the financial network and is
returned in the same session to the Payflow client.
4. The Payflow client completes each transaction session by transparently sending a
transaction receipt to the server before disconnecting the session.
The entire process is a real-time synchronous transaction. Once connected, the transaction is
immediately processed and the answer returned in about three seconds. Processing
transactions through the Payflow service does not affect or define the time periods of
authorizations, nor does it influence the approval or denial of a transaction by the issuer.
When integrating with Payflow Pro, you need only be concerned with passing all the required
data for transaction authorization. For transactions that you want to be settled (close batch),
the operation is handled by PayPal.
Pre-integrated Solutions
Payflow Pro is integrated with the majority of third-party shopping carts and e-commerce
applications.
z Credit cards
z PayPal
z Pinless debit cards
z Electronic check
z Check cards
z Purchasing cards (also referred to as commercial cards, corporate cards, procurement
cards, or business cards) Level II and Level III
z Automated Clearing House (ACH). For information on performing ACH transactions,
contact your PayPal Sales Representative at paymentsales@PayPal.com
About Security
It is your responsibility to protect your passwords and other confidential data and to
implement security safeguards on your website and in your organization, or to ensure that your
hosting company or internal web operations team is implementing them on your behalf.
IMPO RTANT: To enable testing of Payflow Pro, PayPal provides sample transaction scripts
that you customize with your Payflow Pro account information and password.
Because the password is initially stored in the text of the program, it is
vulnerable.
Do not use the test scripts in your production environment. To minimize fraud,
machine passwords should always be encrypted. You must write a program
that encrypts and decrypts your Payflow Pro account password.
The Payflow Software Development Kit (SDK) is a set of APIs to allow you to integrate
Payflow Pro with with your application or website.
This chapter provides instructions for downloading the SDK appropriate to your platform.
S u p p o r t e d P l a tf o r m s
Payflow Pro is available on all major web server platforms in a variety of formats to support
your integration requirements. Payflow Pro is available as a .NET or Java library, or you can
build your own API by posting directly to the Payflow servers via HTTPS.
You receive the response a few seconds after you submit the transaction to the server. If the
Authorization is approved, the bank temporarily reserves credit for the amount of the
transaction to prepare to capture (fulfill) the transaction. The hold on funds typically lasts for
about a week.
N O T E : Youcannot remove a hold on funds through the processing networks—you must
contact the card issuing bank to lift a hold early.
Capturing a transaction (also known as settling a transaction) actually transfers the funds to
your bank. At least once a day, PayPal gathers all transactions that are flagged to be settled and
sends them in a batch file to the processor. The processor then charges the issuing bank and
transfers the funds to your bank. It typically takes a few days before the money is actually
available in your account, depending on your bank.
the order immediately, can use the one-step process. Check with your Internet Merchant
Account provider for suggestions on the best method for you.
z Whether or how to use risk management tools such as address verification service and card
security code. For address verification service, if the data is submitted with the initial
transaction, the issuer checks the street address and/or the ZIP (postal) code against the
billing address on file for the consumer. Address verification service is described on
page 45.
Card security code refers to a 3- or 4-digit number that appears on the back of most credit
cards. On American Express, the number appears above and to the right of the embossed
card number. Card security code is known by other names, such as CVV2, depending on
the type of card. If card security code data is submitted, the issuer can notify you whether
the number matches the number assigned to the card. Card security code is described on
page 47.
It may also be possible to implement additional safeguards yourself or to use a fraud
service. You might want to discuss risk management with your Internet Merchant Account
provider.
z Store information in your local database or use PayPal Manager reports to manage the data.
You may want to store shipping information in your system, or you may prefer to send the
information to PayPal with the transaction and report on it later.
N O T E : PayPal
recommends that you do not store credit card numbers. If you must store
numbers, encrypt and store them behind properly configured firewalls. You should
also consider whether and how to use the merchant-defined fields COMMENT1
and COMMENT2 to help tie reports to your orders/customers or to report on other
information about the transaction.
z If or how you want to integrate with other systems, such as order fulfillment, customer
service, and so on. You may wish to connect these systems directly to Payflow Pro for
capturing funds, issuing refunds/credits, and so on. Alternatively, you may prefer to
perform these steps manually using PayPal Manager. Either way, PayPal recommends that
you monitor transaction activity using PayPal Manager.
z You may want to discuss, with your Internet Merchant Acquirer, practices that help you to
obtain the most advantageous rates.
N O T E : Quotation marks (“”) are not allowed even if you use a length tag.
Max.
Parameter Description Required Type Length
ACCT Credit card or purchase card number. Yes1 Numeric 19
This value may not contain spaces, non-numeric
characters, or dashes. For example,
ACCT=5555555555554444
For the pinless debit TENDER type, ACCT can be
the bank account number.
AMT Amount (US Dollars) U.S. based currency. Yes1 Numeric 10
Specify the exact amount to the cent using a decimal USD only
point—use 34.00, not 34. Do not include comma
separators—use 1199.95 not 1,199.95.
Your processor and/or Internet Merchant Account
provider may stipulate a maximum amount.
AUTHCODE AUTHCODE is returned only for approved Voice req’d for Alpha- 6
Authorization transactions. AUTHCODE is the Voice numeric
approval code obtained over the telephone from the Authorizat
processing network. ion only.
COMMENT1 Merchant-defined value for reporting and auditing No Alpha- 128
purposes. numeric
COMMENT2 Merchant-defined value for reporting and auditing No Alpha- 128
purposes. numeric
Max.
Parameter Description Required Type Length
CURRENCY One of the following three-character currency No Alpha 3
codes:
Max.
Parameter Description Required Type Length
NAME or Account holder's name. This single field holds all of No, but Alpha- 30
FIRSTNAME the person’s name information. recom- numeric
mended uppercase
ORIGID The ID of the original transaction that is being Yes1 Alpha- 12
referenced. This ID is returned by the PNREF numeric
parameter and appears as the Transaction ID in
PayPal Manager reports.
This value is case-sensitive.
PARTNER The ID provided to you by the authorized PayPal Yes Alpha- 12
Reseller who registered you for the Payflow Pro numeric
service. If you purchased your account directly from
PayPal, use PayPal.
This value is case-sensitive.
PWD The 6- to 32-character password that you defined Yes Alpha- 32
while registering for the account. numeric
This value is case-sensitive.
STARTTIME Optional for Inquiry transactions when using No Numeric 14
CUSTREF to specify the transaction.
STARTTIME specifies the beginning of the time
period during which the transaction specified by the
CUSTREF occurred. See ENDTIME.
If you set STARTTIME, and not ENDTIME, then
ENDTIME is defaulted to 30 days after
STARTTIME.
If neither STARTTIME nor ENDTIME is specified,
then the system searches the last 30 days.
Format: yyyymmddhhmmss
STREET The cardholder’s street address (number and street No Alpha- 30
name). numeric
The STREET address is verified by the address
verification service (described in page 45.)
Max.
Parameter Description Required Type Length
SWIPE Used to pass the Track 1 or Track 2 data (the card’s Required Alpha-
magnetic stripe information) for card-present only for numeric
transactions. Include either Track 1 or Track 2 card-
data—not both. If Track 1 is physically damaged, present
the POS application can send Track 2 data instead. transac-
The track data includes the disallowed = (equal sign) tions
character. To enable you to use the data, the SWIPE
parameter must include a length tag specifying the
number of characters in the track data. For this
reason, in addition to passing the track data, the POS
application must count the characters in the track
data and pass that number. Length tags are described
in “Using Special Characters in Values” on page 25.
N O T E : SWIPE (card-present transactions) are not
supported by the PayPal processor.
TENDER The tender type (method of payment). Values are: Yes Alpha 1
A = Automated clearinghouse
C = Credit card
D = Pinless debit
K = Telecheck
P = PayPal
See the Payflow ACH Payment Service Guide for
details on the Automated clearinghouse tender type.
See “Submitting Sale Transactions” on page 31 for
information about Pinless debit transactions.
TRXTYPE A single character indicating the type of transaction Yes Alpha 1
to perform. Values are:
S = Sale transaction
C = Credit
A = Authorization
D = Delayed Capture
V = Void
F = Voice Authorization
I = Inquiry
N = Duplicate transaction
N O T E : A type N transaction represents a duplicate
transaction (version 4 SDK or HTTPS
interface only) with a PNREF the same as the
original. It appears only in the PayPal
Manager user interface will never settle.
Max.
Parameter Description Required Type Length
USER If you set up one or more additional users on the Yes Alpha- 64
account, this value is the ID of the user authorized to numeric
process transactions. If, however, you have not set
up additional users on the account, USER has the
same value as VENDOR.
The examples in this document use
USER=SuperMerchant.
This value is case-sensitive.
VENDOR Your merchant login ID that you created when you Yes Alpha- 64
registered for the Payflow Pro account. numeric
The examples in this document use VENDOR =
SuperMerchant.
This value is case sensitive.
VERBOSITY Enables you to obtain additional processor No Alpha
information for a transaction. Values are LOW or
MEDIUM.
z LOW is the default setting—normalized values.
z MEDIUM returns the processor’s raw response
values.
For more informatiom, see Appendix D, “Verbosity:
Viewing Processor-Specific Transaction Results.”
VERBOSITY is also part of an Inquiry transaction.
For more information, see “Submitting Inquiry
Transactions” on page 40.
ZIP Account holder’s 5- to 9-digit ZIP (postal) code. Do No Alpha 9
not use spaces, dashes, or non-numeric characters.
The postal code is verified by the address
verification service and international address
verification service (described on page 45).
The ZIP code is verified by the address verification
service (described in page 45.)
1. Some transaction types do not require this parameter. See “Values Required by All Transaction Types” on page 30
USER
PWD
Each transaction type has additional parameter requirements, as listed in the following
sections. Transaction responses are described in Chapter 4, “Responses to Transaction
Requests.”
Note that, besides the required parameters that you pass in a Sale transaction, this string
includes other typical parameters. The COMMENT1 (and COMMENT2) fields help to track
transaction information. The customer’s street address (STREET) and ZIP should be passed to
use address verification service. CVV2 is needed for card security code validation. For details
on address verification service and card security code, see the following sections:
z “Submitting Card-Present (SWIPE) Transactions” on page 43
z “Card Security Code Validation” on page 47
IMPO RTANT: Only one Delayed Capture transaction is allowed per Authorization
transaction.
Credit transaction when non-referenced credits are not allowed, you must pass values for the
following parameters:
ACCT
EXPDATE
AMT
IMPO RTANT: The default security setting for Payflow Pro accounts is Allow
non-referenced credits = No, so sending the ORIGID is the preferred method
for performing Credit transactions. Using the ACCT, EXPDATE, or AMT
parameters for such accounts leads to RESULT value 117 (failed the security
check). For information on setting the security settings, see PayPal Manager
online help.
Fields Copied From the Original Transaction into the Credit Transaction
The following fields are copied from the original transaction into the Credit transaction (if
they exist in the original transaction). If you provide a new value for any of these parameters
when submitting the Credit transaction, then the new value is used. (Exceptions are ACCT,
EXPDATE, and SWIPE. These parameters retain their original values).
N O T E : These
fields are not copied for referenced credits: TAXAMT, TAXEXEMPT,
DUTYAMT, FREIGHTAMT, and (for American Express only) DESC4.
N O T E : For processorsthat use the RECURRING parameter: If the RECURRING parameter
was set to Y for the original transaction, then the setting is ignored when forming the
Credit transaction.
"TRXTYPE=C&TENDER=C&PARTNER=PayPal&VENDOR=SuperMerchant
&USER=SuperMerchant&PWD=x1y2z3&ACCT=5555555555554444&EXPDATE=0308
&AMT=123.00"
N O T E : For processors
that use the RECURRING parameter: If the RECURRING parameter
was set to Y for the original transaction, then the setting is ignored when forming the
Void transaction.
CA UTION! If there are multiple transactions with a particular CUSTREF value, then the
Inquiry transaction returns only the last transaction with the specified
CUSTREF. So, to ensure that you can always access the correct transaction, you
must use a unique CUSTREF when submitting any transaction, including
retries.
IMPO RTANT: When PayPal looks up the reference transaction, neither the transaction
being referenced nor any other transaction in the database is changed in any
way. That is, a reference transaction is a read-only operation—only the new
transaction is populated with data and acted upon. No linkage is maintained
between the reference transaction and the new transaction.
You can also initiate reference transactions from PayPal Manager. See PayPal Manager online
help for details.
ACCTTYPE STREET
ACCT CITY
EXPDATE STATE
FIRSTNAME ZIP
MIDDLENAME BILLTOCOUNTRY
LASTNAME SWIPE
"TRXTYPE=A&TENDER=C&PWD=x1y2z3&PARTNER=PayPal&VENDOR=SuperMerchant&USER=Sup
erMerchant&ACCT=5555555555554444&EXPDATE=0308&AMT=100.00&INVNUM=123456789&S
TREET=5199 MAPLE&ZIP=94588"
Note the value of the PNREF in the response:
RESULT=0&PNREF=VXYZ01234567&RESPMSG=APPROVED&AUTHCODE=123456&AVSADDR=Y&AVSZ
IP=N
RESULT=0&PNREF=VXYZ01234568&AUTHCODE=25TEST&AVSADDR=Y&AVSZIP=N
Step 3 Submit a new Sale transaction of $34 for the rest of the shipment
Once you have shipped the remainder of the product, you can collect the remaining $34 in a
Sale transaction that uses the initial Authorization as a reference transaction. (This is a Sale
transaction because only one Delayed Capture transaction is allowed per Authorization.) For
example:
"TRXTYPE=S&TENDER=C&PWD=x1y2z3&PARTNER=PayPal&VENDOR=SuperMerchant&USER=Sup
erMerchant&ORIGID=VXYZ01234567&AMT=34.00"
RESULT=0&PNREF=VXYZ01234569&AUTHCODE=25TEST&AVSADDR=Y&AVSZIP=N
N O T E : In the case that your business model uses the Authorization/Delayed Capture cycle for
all transactions, you could have chosen to use an Authorization/Delayed Capture to
collect the $34 in this example. You would generate the Authorization for the $34
using the initial Authorization as a reference transaction.
transactions, and use it solely for that purpose. Use the other for card-not-present
transactions. Using the wrong account may result in downgrades.
z A Sale is the preferred method to use for card-present transactions. Consult
with your acquiring bank for recommendations on other methods.
American
Processing Platform Express Discover MasterCard Visa
FDMS Nashville X X X X
FDMS North X X X X
FDMS South X X X X
Merchant e-Solutions X X X X
Norwest — — — —
Nova X X X X
Paymentech Tampa X X X X
Vital X X X X
RESULT=0&PNREF=VXW412345678&RESPMSG=APPROVED&AUTHCODE=123456&AVSADDR=Y&AVSZ
IP=N&IAVS=X
IMPO RTANT: To comply with credit card association regulations, do not store the CVV2
value.
On most cards, the card security code is printed on the back of the card (usually in the
signature field). All or part of the card number appears before the card security code (567 in
the example). For American Express, the 4-digit number (1122 in the example) is printed on
the front of the card, above and to the right of the embossed account number. Be sure to
explain this to your customers.
American
Processing Platform Express Discover MasterCard Visa
FDMS Nashville — X X X
FDMS North X X X X
FDMS South X X X X
American
Processing Platform Express Discover MasterCard Visa
Merchant e-Solutions X X X X
Norwest — — — —
Nova — X X X
Paymentech Tampa X X X X
Vital X X X X
Even though your processor may be certified for card security code, they may not be certified
for all card types (for example, Visa CVV2 or MasterCard CVC2). The list will change as
PayPal continues to enhance its service offering.
Y The submitted value matches the data on file for the card.
N The submitted value does not match the data on file for the card.
American Express Phoenix Card security code mismatches may cause a non-approved result
Global Payments – East (RESULT = 112 or 114) in some cases. In other cases, the
Global Payments – Central transaction may be approved despite the card security code
Merchant e-Solutions mismatch.
Nova The match or mismatch information is indicated in the
Vital CVV2MATCH value.
FDMS Nashville Transactions that have card security code mismatches can come
FDMS South back as an approved transaction (RESULT = 0).
The match or mismatch information is indicated in the
Paymentech New Hampshire CVV2MATCH value.
Paymentech Tampa As with AVS, if the Authorization was successful, you must make
a decision based on the CVV2MATCH value whether or not to
proceed with the order.
When a transaction finishes, the Payflow server returns a response string made up of name-
value pairs. For example, this is a response to a credit card Sale transaction request:
RESULT=0&PNREF=VXYZ01234567&RESPMSG=APPROVED&AUTHCODE=123456
&AVSADDR=Y&AVSZIP=N&IAVS=Y&CVV2MATCH=Y
AVSZIP AVS zip code response returned if you are using Alpha 1
AVS. AVSZIP responses are for advice only. Y, N, X, or
This process does not affect the outcome of the no response
authorization. See “Using Address Verification
Service” on page 45.
PROCAVS AVS response from the processor when you use Char 1
AVS and send a VERBOSITY request parameter
value of MEDIUM. See Appendix A,
“Verbosity: Viewing Processor-Specific
Transaction Results,” for details.
obtain the PayPal processor value, set the VERBOSITY parameter to MEDIUM. With this
setting, the processor value is returned in the PROCAVS response parameter. For details on
VERBOSITY, see Appendix A, “Verbosity: Viewing Processor-Specific Transaction Results.”
PayPal
Processor
AVS Code PayPal Processor AVSCode Meaning AVSADDR AVSZIP
A Address Y N
B International “A” Y N
C International “N” N N
D International “X” Y Y
F UK-specific “X” Y Y
G Global Unavailable X X
I International Unavailable X X
N No N N
R Retry X X
U Unavailable X X
W Whole Zip N Y
X Exact Match Y Y
Y Yes Y Y
Z Zip N Y
All other X X
Normalized Results
If you submit the transaction request parameter for card security code (that is, the CVV2
parameter), the cardholder’s bank returns a normalized Yes/No response in the CVV2MATCH
response parameter, as described in Table 4.3.
Y The submitted value matches the data on file for the card.
N The submitted value does not match the data on file for the card.
M Match Y
N No Match N
P Not Processed X
U Unavailable X
X No Response X
All other X
merchandise exceeding the card balance, American Express declines the transaction and
returns the card balance in BALAMT.
For details on American Express CAPN request transaction parameters, see Appendix A,
“Processors Requiring Additional Transaction Parameters.”
PNREF Value
The PNREF is a unique transaction identification number issued by PayPal that identifies the
transaction for billing, reporting, and transaction data purposes. The PNREF value appears in
the Transaction ID column in PayPal Manager reports.
z The PNREF value is used as the ORIGID value (original transaction ID) in Delayed
Capture transactions (TRXTYPE=D), Credits (TRXTYPE=C), Inquiries (TRXTYPE=I),
and Voids (TRXTYPE=V).
z The PNREF value is used as the ORIGID value (original transaction ID) value in reference
transactions for Authorization (TRXTYPE=A) and Sale (TRXTYPE=S).
N O T E : The PNREF is also referred to as the Transaction ID in PayPal Manager.
PNREF Format
The PNREF is a 12-character string of printable characters, for example:
z VADE0B248932
z ACRAF23DB3C4
N O T E : Printable
characters also include symbols other than letters and numbers such as the
question mark (?). A PNREF typically contains letters and numbers only.
The PNREF in a transaction response tells you that your transaction is connecting to PayPal.
Historically, the contents of a PNREF indicated a test or a live transaction:
z For test servers, the first and fourth characters were alpha characters (letters), and the
second and third characters were numeric, for example: V53A17230645.
z For live servers, the first four characters were alpha characters (letters), for example:
VPNE12564395.
However, this is not always the case, and as a rule, you should not place any meaning on the
contents of a PNREF.
0 Approved.
N O T E : PayPal processor: Warning information may be returned that may be useful to
the request applicaton. See the PayPal API documentation on the PayPal
website for information on corrective actions.
2 Invalid tender type. Your merchant bank account does not support the following
credit card type that was submitted.
TABLE 4.5 Payflow transaction RESULT values and RESPMSG text (Continued)
3 Invalid transaction type. Transaction type is not appropriate for this transaction. For
example, you cannot credit an authorization-only transaction.
4 Invalid amount format. Use the format: “#####.##” Do not include currency
symbols or commas.
5 Invalid merchant information. Processor does not recognize your merchant account
information. Contact your bank account acquirer to resolve this problem.
12 Declined. Check the credit card number, expiration date, and transaction information to
make sure they were entered correctly. If this does not resolve the problem, have the
customer call their card issuing bank to resolve.
14 Invalid Client Certification ID. Check the HTTP header. If the tag, X-VPS-VIT-
CLIENT-CERTIFICATION-ID, is missing, RESULT code 14 is returned.
19 Original transaction ID not found. The transaction ID you entered for this
transaction is not valid. See RESPMSG.
25 Invalid Host Mapping. You are trying to process a tender type such as Discover Card,
but you are not set up with your merchant bank to accept this card type.
26 Invalid vendor account. Login information is incorrect. Verify that USER, VENDOR,
PARTNER, and PASSWORD have been entered correctly. VENDOR is your merchant
ID and USER is the same as VENDOR unless you created a Payflow Pro user. All
fields are case sensitive.
TABLE 4.5 Payflow transaction RESULT values and RESPMSG text (Continued)
29 Invalid XML document. This could be caused by an unrecognized XML tag or a bad
XML format that cannot be parsed by the system.
30 Duplicate transaction
104 Timeout waiting for processor response. Try your transaction again.
105 Credit error. Make sure you have not already credited this transaction, or that this
transaction ID is for a creditable transaction. (For example, you cannot credit an
authorization.)
108 Void error. See RESPMSG. Make sure the transaction ID entered has not already been
voided. If not, then look at the Transaction Detail screen for this transaction to see if it
has settled. (The Batch field is set to a number greater than zero if the transaction has
been settled). If the transaction has already settled, your only recourse is a reversal
(credit a payment or submit a payment for a credit).
TABLE 4.5 Payflow transaction RESULT values and RESPMSG text (Continued)
111 Capture error. Either an attempt to capture a transaction that is not an authorization
transaction type, or an attempt to capture an authorization transaction that has already
been captured.
112 Failed AVS check. Address and ZIP code do not match. An authorization may still
exist on the cardholder’s account.
113 Merchant sale total will exceed the sales cap with current transaction. ACH
transactions only.
114 Card Security Code (CSC) Mismatch. An authorization may still exist on the
cardholder’s account.
117 Failed merchant rule check. One or more of the following three failures occurred:
An attempt was made to submit a transaction that failed to meet the security settings
specified on the PayPal Manager Security Settings page. If the transaction exceeded the
Maximum Amount security setting, then no values are returned for AVS or CSC.
AVS validation failed. The AVS return value should appear in the RESPMSG.
CSC validation failed. The CSC return value should appear in the RESPMSG.
122 Merchant sale total will exceed the credit cap with current transaction. ACH
transactions only.
TABLE 4.5 Payflow transaction RESULT values and RESPMSG text (Continued)
128 Fraud Protection Services Filter — Declined by merchant after being flagged for
review by filters
131 Version 1 Payflow Pro SDK client no longer supported. Upgrade to the most recent
version of the Payflow Pro client.
1000 Generic host error. This is a generic message returned by your credit card processor.
The RESPMSG will contain more information describing the error.
1016 Buyer Authentication Service — 3-D Secure error response received. Instead of
receiving a PARes response to a Validate Authentication transaction, an error response
was received.
1017 Buyer Authentication Service — 3-D Secure error response is invalid. An error
response is received and the response is not well formed for a Validate Authentication
transaction.
TABLE 4.5 Payflow transaction RESULT values and RESPMSG text (Continued)
1052 Buyer Authentication Service — Validate Authentication failed: This PARES was
already validated for a previous Validate Authentication transaction
A value of -1 or -2 can also be possible if the PayPal servers are unavailable, or an incorrect
server/socket pair has been specified. A value of -1 can also result when there are internet
connectivity errors. Contact customer support regarding any other errors.
For information on firewall configuration, see Chapter 2, “Installing and Configuring the
Payflow APIs.”
N O T E : To
eliminate RESULT -31 and -108 errors described below, upgrade to a version 4
SDK or post directly to the Payflow servers via HTTPS. For details on determining the
version of your SDK, see “Payflow SDK Version” on page 15.
Details of the response message may vary slightly from that shown in the table, depending on
your SDK integration.
RESULT Description
RESULT Description
-31 The certificate chain did not validate, no local certificate found
-32 The certificate chain did not validate, common name did not match URL
-111 The following error occurred while initializing from message file: <Details of
the error message>
To test your application, direct all transactions to the host address for testing. For details, see
“Host Addresses” on page 15. Transactions directed to this URL are processed through
PayPal’s simulated payment network, enabling you to test the configuration and operation of
your application or storefront — no money changes hands. (You must activate your account
and configure your application for live transactions before accepting real orders.)
Testing Guidelines
z While testing, use only the credit card numbers listed in this chapter. Other numbers
produce an error.
z Expiration Date must be a valid date in the future (use the mmyy format).
z To view the credit card processor that you have selected for testing, see Account Info >
Processor Info in PayPal Manager.
Discover 6011111111111117
Discover 6011000990139424
JCB 3530111333300000
JCB 3566002020360505
MasterCard 5555555555554444
MasterCard 5105105105105100
Visa 4111111111111111
Visa 4012888888881881
Visa 4222222222222
N O T E : Even though this number has a different character count
than the other test numbers, it is the correct and functional
number.
Amount Result
$1001 – $2000 Certain amounts in this range will return specific PayPal results, and can be
generated by adding $1000 to that RESULT value. For example, for RESULT
value 13 (Referral), submit the amount 1013.
If the amount is in this range but does not correspond to a PayPal result
supported by this testing mechanism, RESULT value 12 (Declined) is returned.
Global Payments Central 0, 4, 5, 8, 12, 13, 23, 24, 104, 111, 114, 1000
Global Payments East 0, 4, 5, 12, 13, 23, 24, 30, 100, 104, 114, 1000
Table 5.4 shows another method for obtaining RESULT values. Non-zero RESULT values
from processors are not returned by the servers, and therefore cannot be simulated using the
amount. In some cases, you may get certain results using the RESULT value plus 1000 even
though this table suggests another means of obtaining the RESULT value.
Testing AVS
The PayPal testing server simulates AVS by returning a value for AVSADDR based on the
first three characters of the submitted value for STREET.
The testing server returns a value for AVSZIP based on the submitted ZIP value as shown in
the table.
If STREET starts with 667 or higher or begins with a non-numeric character, then the simulator
returns AVSADDR=X, AVSZIP=X.
000 Null
001-300 Y
301-600 N
601 or higher X
When you are ready to activate your Payflow Pro account to begin submitting live
transactions, follow these steps:
1. Log in to PayPal Manager at https://manager.paypal.com.
2. Click the Click Here to Activate button and follow the on-screen instructions.
3. Change the URL within your web or desktop application to point to the live PayPal
payment servers. For details on payment server URLs, see “Host Addresses” on page 15.
Even though the account is now active (live), you can test and process live transactions at
the same time, depending on the URL used. For example, a development server can point
to the testing URL while a production server points to the live URL.
This chapter provides guidelines on how to implement PayPal Express Checkout through the
Payflow SDK. The chapter introduces you to this feature and provides the information you
need to get started integrating it into your website application.
In this Chapter
z “What Is Express Checkout?” on page 73
z “How Express Checkout Works” on page 73
z “Handling Express Checkout Transactions Through the Payflow SDK” on page 75
z “Express Checkout Sale Transaction Example” on page 76
z “Express Checkout Transaction Parameter Descriptions” on page 80
z “Express Checkout Transaction Parameter Descriptions” on page 80
z “Testing Express Checkout” on page 91
Figure 7.1 shows a typical set of web pages representing your merchant website. The PayPal
logo is used by the customer to choose PayPal as their method of payment. Express Checkout
gives you the flexibility to put this PayPal button graphic first in your checkout process—or on
your billing page with other payment options.
The web page layout may differ somewhat from your own web design, but the points at which
the Express Checkout calls are made and when the customer is redirected to PayPal and back
to your website are important to understand. The events that take place at each numbered step
in the figure are described below:
1. On your website when your customer chooses to pay with PayPal, you submit a Set
Express Checkout request.
2. The server sends back a token, a string value to track your customer throughout the
checkout process.
3. You direct your customer to the PayPal site, where they log in, select a funding source, and
confirm contact and shipping information. Express Checkout includes parameters that you
can use to customize the PayPal pages so they match characteristics of your own website.
For example, you can provide your own logo and colors. These parameters are described in
“Set Express Checkout Request Parameters” on page 80.
4. When your customer clicks the “Continue” button, PayPal sends them back to your site at
the return URL you specified in the Set Express Checkout request. The token is appended
to the URL to identify the customer.
5. Optionally you can send the Get Express Checkout Details request to obtain details about
your customer such as the customer’s telephone number and shipping address. You send
the token to identify the customer. The server returns the requested information.
6. When your customer clicks the “Pay” button, you submit the Do Express Checkout
Payment request to perform the actual payment transaction. The server returns the
transaction result.
N O T E : Express
Checkout does not support reference transactions for Sales and
Authorizations.
Set Express Checkout Identifies the transaction. Is S (for Set Express Checkout)
S = Sale
A = Authorization
Get Express Checkout Details Identifies the transaction. Is G (for Get Express Checkout
S = Sale Details)
A = Authorization
Credit Card Transactions”), Set Express Checkout requires that you pass data for the following
parameters.
ACTION
AMT
RETURNURL
CANCELURL
N O T E : Youprovide appropriate values for partner, vendor, user, and pwd, as you would for
any transaction.
This is an example Set Express Checkout request parameter string for a Sale transaction:
the button displayed on the PayPal website from “Continue” to “Pay.” For more
information, see “Design Variation: Eliminating Your Order Review Page” on page 94.
PayPal recommends that you use the HTTPS response 302 “Object Moved” with your URL as
the value of the Location header in the HTTPS response. Alternately, you can generate a web
page for your buyer that includes a META REFRESH tag in the header. An example is shown
below. Remember to replace <TOKEN> with the token value that you received in the Set
Express Checkout response.
<body>
<!-- Most buyers will see the text below for less than a second. -->
<!-- Some browser types (example, cell phone)do not support META refresh tags. -->
<a href="https://www.paypal.com/cgi-bin/webscr?cmd=_express-
checkout&token=<TOKEN>"Click here if you are not redirected to PayPal within 5
seconds.</a>
</body>
</html>
Max.
Parameter Name Description Required Type Length
TOKEN Include this parameter to modify an No String 20
existing Sale or Authorization
request. The value is returned in a
previous Set Express Checkout
response.
AMT Amount (US Dollars) U.S. based Yes Numeric 10 (with
currency. No currency symbol. USD only decimal)
Specify the exact amount to the cent
using a decimal point—use 34.00, not
34. Do not include comma
separators—use 1199.95 not
1,199.95.
MAXAMT The expected maximum total amount No Numeric 9
of the complete order, including
shipping and tax charges.
ORDERDESC Description of items the customer is No Alphanumeric 127
purchasing.
CUSTOM Free-form field for your own use such No Alphanumeric 256
as a tracking number or other value
you want PayPal to return in the Get
Express Checkout Details response.
INVNUM Merchant invoice number. The No Alphanumeric 9
merchant invoice number is used for
authorizations and settlements and,
depending on your merchant bank,
will appear on your customer's credit
card statement and your bank
reconciliation report. If you do not
provide an invoice number, the
transaction ID (PNREF) will be
submitted.
Max.
Parameter Name Description Required Type Length
RETURNURL URL to which the customer’s Yes String No max
browser is returned after choosing to length
pay with PayPal.
Note: PayPal recommends that the
value of ReturnURL be the final
review page on which the customer
confirms the order and payment.
CANCELURL URL to which the customer is Yes String No max
returned if the customer does not length
approve the use of PayPal to pay you.
Note: PayPal recommends that the
value of CancelURL be the original
page on which the customer chose to
pay with PayPal.
SHIPTOSTREET Shipping Address. Yes String 30
Note: If you include a shipping
address and provide a value for the
AddressOverride
(ADDROVERRIDE) parameter,
PayPal returns this same address in
the Get Express Checkout Details
response.
SHIPTOSTREET2 Extended shipping address. Example: No String 30
Bldg. 6, Mail Stop 3.
SHIPTOCITY Ship-to city Yes String 40
SHIPTOSTATE Ship-to state No String 10
SHIPTOZIP Ship-to postal code (called ZIP code Yes String 16
in the USA)
SHIPTOCOUNTRY Ship-to country Yes String
REQCONFIRMSHIPPING Is 1 or 0. The value 1 indicates that No String 1
you require that the customer’s
shipping address on file with PayPal
be a confirmed address.
Setting this element overrides the
setting you have specified in your
Merchant Account Profile.
NOSHIPPING Is 1 or 0. The value 1 indicates that on No String 4
the PayPal pages, no shipping address
fields should be displayed
whatsoever.
Max.
Parameter Name Description Required Type Length
ADDROVERRIDE Is 1 or 0. The value 1 indicates that No String 4
the PayPal pages should display the
shipping address set by you in the
shipping address (SHIPTO*
parameters) passed to this Set
Express Checkout request, not the
shipping address on file with PayPal
for this customer.
Displaying the PayPal street address
on file does not allow the customer to
edit that address.
LOCALECODE Locale of pages displayed by PayPal No Alpha upper- or 5
during Express Checkout. lowercase
AU or en_AU
DE or de_DE
FR or fr_FR
GB or en_GB
IT or it_IT
JP or ja_JP
US or en_US
PAGESTYLE Sets the Custom Payment Page Style No Alpha 30
for payment pages associated with
this button/link. PageStyle
corresponds to the HTML variable
page_style for customizing payment
pages.
The value is the same as the Page
Style Name you chose when adding
or editing the page style from the
Profile subtab of the My Account tab
of your PayPal account.
HDRIMG A URL for the image you want to No String 127
appear at the top left of the payment
page. The image has a maximum size
of 750 pixels wide by 90 pixels high.
PayPal recommends that you provide
an image that is stored on a secure
(https) server.
Max.
Parameter Name Description Required Type Length
HDRBORDERCOLOR Sets the border color around the No String 6
header of the payment page. The HTML
border is a 2-pixel perimeter around hexadecimal
the header space, which is 750 pixels color code in
wide by 90 pixels high. ASCII
HDRBACKCOLOR Sets the background color for the No String 6
header of the payment page. HTML
hexadecimal
color code in
ASCII
COLOR Sets the background color for the No String 6
payment page. HTML
hexadecimal
color code in
ASCII
ACTION Is S to indicate this is a Set Express Yes Alpha 1
Checkout request.
EMAIL Email address of the customer as No Alphanumeric 127
entered during checkout. PayPal uses
this to pre-fill the PayPal membership
sign-up portion of the PayPal login
page.
Max.
Parameter Name Description Type Length
TOKEN A time-stamped token by which you identify to String 20
PayPal that you are processing this payment
with Express Checkout.
The token expires after three hours.
If you set TOKEN in the Set Express Checkout
request, the value of TOKEN in the response is
identical to the value in the request.
Max.
Parameter Name Description Required Type Length
ACTION Is G to indicate this is a Get Express Yes Alpha 1
Checkout Details request
TOKEN String value returned by the Set Yes String 20
Express Checkout response.
Max.
Parameter Name Description Type Length
TOKEN String value returned by Set Express String 20
Checkout response.
SHIPTOSTREET Shipping Address. String 30
Note: If you include a shipping address
and provide a value for the
AddressOverride (ADDROVERRIDE)
parameter, PayPal returns this same
address in the Get Express Checkout
Details response.
SHIPTOSTREET2 Extended shipping address. Example: String 30
Bldg. 6, Mail Stop 3.
SHIPTOCITY Ship-to city. String 40
SHIPTOSTATE Ship-to state. String 10
SHIPTOZIP Ship-to postal code (called ZIP code in the String 16
USA).
SHIPTOCOUNTRY Ship-to country. String 2
(See Appendix F, “ISO Country Codes”)
EMAIL Email address of the customer as entered Alphanumeric 127
during checkout.
SHIPTOBUSINESS Customer ’s business name. String 127
Max.
Parameter Name Description Type Length
SHIPTOCOUNTRY Customer’s country of residence in the String 2
form of ISO standard 3166 two-character
country codes.
PAYERID Unique PayPal customer account String 13
identification number.
PAYERSTATUS Status of customer. Values are: Alpha 10
verified
unverified
CUSTOM Free-form field for your own use as set by Alphanumeric 256
you in the Set Express Checkout request.
INVNUM Merchant invoice number. The merchant Alphanumeric 9
invoice number is used for authorizations
and settlements and, depending on your
merchant bank, will appear on your
customer's credit card statement and your
bank reconciliation report. If you do not
provide an invoice number, the transaction
ID (PNREF) will be submitted.
INVNUM must be unique for each
transaction to prevent processing the same
order twice.
PHONENUM Account holder’s telephone number. See String 20
“Obtaining the Customer’s Telephone
Number During PayPal Checkout” on
page 85.The field mask is
xxx-xxx-xxxx (US numbers)
+xxxxxxxxxxx (international numbers)
Max.
Parameter Name Description Required Type Length
TOKEN String value returned by Set Express Yes String 20
Checkout response.
ACTION Is D to indicate this is a Do Express Yes Alpha 1
Checkout Payment request.
PAYERID Unique PayPal customer account Yes String 13
identification number, as returned by
Get Express Checkout Details
response. This value is returned in the
URL when the customer is redirected
to your website.
AMT Total transaction amount (US Dollars) Yes Numeric 10 (with
U.S. based currency. Specify the exact decimal)
amount such as 34.00, not 34. Do not
include comma separators-use 1199.95
not 1,199.95.
ITEMAMT Sum of cost of all items in this order. No Numeric 9
Limitations: Must not exceed $10,000
USD in any currency. No currency
symbol.
Specify the exact amount to the cent
using a decimal point—use 34.00, not
34. Do not include comma
separators—use 1199.95 not 1,199.95.
FREIGHTAMT You must set the currencyID attribute No Numeric 9
to USD.
Character length and limitations: Must
not exceed $10,000 USD. No currency
symbol.
Specify the exact amount to the cent
using a decimal point—use 34.00, not
34. Do not include comma
separators—use 1199.95 not 1,199.95.
HANDLINGAMT Total handling amount. No Currency 9
Max.
Parameter Name Description Required Type Length
TAXAMT Total tax amount. No Currency 6
Specify the exact amount to the cent
using a decimal point—use 34.00, not
34. Do not include comma
separators—use 1199.95 not 1,199.95.
Value of 0 (zero) is sent if no value is
provided.
ORDERDESC Description of items the customer is Yes Alpha- 127
purchasing. numeric
CUSTOM Free-form field for your own use. Yes 256
INVNUM Merchant invoice number. The No Alpha- 9
merchant invoice number is used for numeric
authorizations and settlements and,
depending on your merchant bank,
will appear on your customer's credit
card statement and your bank
reconciliation report. If you do not
provide an invoice number, the
transaction ID (PNREF) will be
submitted.
BUTTONSOURCE Identification code for use by third- No Alpha- 32
party applications to identify numeric
transactions.
NOTIFYURL Your URL for receiving Instant No Alpha- 2,048
Payment Notification (IPN) about this numeric
transaction.
N O T E : If you do not specify
NotifyURL in the request, the
notification URL from your
Merchant Profile is used, if one
exists.
SHIPTOSTREET Shipping Address. Yes String 30
N O T E : If you include a shipping
address and provide a value for
the AddressOverride
(ADDROVERRIDE)
parameter, PayPal returns this
same address in the Get
Express Checkout Details
response.
Max.
Parameter Name Description Required Type Length
SHIPTOSTREET2 Extended shipping address. Example: No String 30
Bldg. 6, Mail Stop 3.
SHIPTOCITY Ship-to city. Yes String 40
SHIPTOSTATE Ship-to state. No String 10
SHIPTOZIP Ship-to postal code (called ZIP code in No String 16
the USA).
SHIPTOCOUNTRY Refer to Country Code tables. (See Yes String
Appendix F, “ISO Country Codes”)
N O T E : Currently US is the only
country code supported.
L_DESCn Line item description. Yes String 35
L_AMTn Total line item amount. No Currency 10
+ for debit, - for credit
L_QTYn Line item quantity. No Int 10
L_TAXAMTn Line item tax amount. No Currency 6
Max.
Parameter Name Description Type Length
TOKEN The time-stamped token value that was returned String 20
in the Set Express Checkout response.
PPREF Unique transaction ID of the payment. String 17
If the request ACTION was A (Authorization),
you should store the value of PPREF if you need
to research a specific transaction with PayPal.
FEEAMT PayPal fee amount charged for the transaction. Numeric 9
Does not exceed $10,000 USD. No currency
symbol.
Specify the exact amount to the cent using a
decimal point—use 34.00, not 34. Do not include
comma separators—use 1199.95 not 1,199.95.
Max.
Parameter Name Description Type Length
TAXAMT Total tax amount. Currency 6
Specify the exact amount to the cent using a
decimal point—use 34.00, not 34. Do not include
comma separators—use 1199.95 not 1,199.95.
Value of 0 (zero) is sent if no value is provided.
PENDINGREASON The reason the payment is pending. Values are: String
none = No pending reason
address = The payment is pending because your
customer did not include a confirmed shipping
address and your Payment Receiving Preferences
is set such that you want to manually accept or
deny each of these payments. To change your
preference, go to the Preferences section of your
Profile.
echeck = The payment is pending because it was
made by an eCheck that has not yet cleared.
intl = The payment is pending because you hold a
non-U.S. account and do not have a withdrawal
mechanism. You must manually accept or deny
this payment from your Account Overview.
multi-currency = You do not have a balance in
the currency sent, and you do not have your
Payment Receiving Preferences set to
automatically convert and accept this payment.
You must manually accept or deny this payment.
verify = The payment is pending because you are
not yet verified. You must verify your account
before you can accept this payment.
completed = The payment has been completed,
and the funds have been added successfully to
your account balance.
other = The payment is pending for a reason
other than those listed above. For more
information, contact PayPal customer service.
Max.
Parameter Name Description Required Type Length
NOTE An informal note about this settlement that No String 255
is displayed to the customer in email and in
the customer’s transaction history.
Max.
Parameter Name Description Required Type Length
NOTE An informal note about this settlement that No String 255
is displayed to the customer in email and in
the customer’s transaction history.
Max.
Parameter Name Description Required Type Length
PAYMENTTYPE Returns instant if the payment is instant or No String 7
echeck if the payment is delayed.
Max.
Parameter Name Description Required Type Length
MEMO Custom memo about the credit. No Alpha- 255
numeric
IMPO RTANT: When you offer PayPal Express Checkout to your customers, you are
required to display it in two forms, for your customers’ best buying
experience:
1. PayPal as a Checkout Choice on your shopping cart page
2. PayPal as a Payment Method
IMPO RTANT: Rather than storing the button graphics on your own server, use the PayPal-
provided image paths for the graphics to reassure your customers that the
checkout is secure and that you are displaying the most up-to-date logos from
PayPal.
You can choose from several design variations for PayPal as a Payment Method. See
“Payment Method Page Layout Recommendations.”
In this situation, you would want the button text on PayPal to appear as “Pay” rather than
“Continue.”
You control the button text through the value of the useraction variable. You set this
variable on the PayPal URL to which you redirect the buyer after calling Set Express
Checkout.
Values and resulting button text are described below:
z If you do not set useraction or you set useraction continue, PayPal displays the
button text “Continue Checkout.”
z If you set useraction to commit, PayPal displays the button text “Pay.”
To display the “Pay” button text, for example, append &useraction=commit to the redirect
URL string as shown below:
"https://www.paypal.com/cgi-bin/webscr?cmd=_express-
checkout&token=tokenvalue&useraction=commit"
where tokenvalue is the token value returned in the Set Express Checkout response.
IMPO RTANT: Do not preselect any payment method. Allow the customer to make a choice
without any default.
As a radio button:
This appendix lists both required and optional parameters supplementary to the common
parameter set.
In this Appendix
z “American Express” on page 97
z “First Data Merchant Services (FDMS) Nashville” on page 106
z “First Data Merchant Services (FDMS) South” on page 107
z “First Data Merchant Services (FDMS) North” on page 107
z “Nova” on page 109
z “Paymentech” on page 109
z “TSYS Acquiring Solutions” on page 111
American Express
In addition to the “Parameters Used in Credit Card Transactions” on page 26, American
Express accepts the parameters described in this section. Parameters to meet American
Express Card Acceptance and Processing Network (CAPN) requirements are described in
Table A.1. American Express (legacy) platform parameters are described in Table A.2.
N O T E : Most
merchants in the United States follow CAPN requirements; international
merchants do not.There are a few exceptions. If you are not sure, contact Customer
Service. See “How to Contact Customer Support” on page 12 for contact information.
contact Customer Service. See “How to Contact Customer Support” on page 12 for
contact information.
FDMS North supports partial Authorization reversals for Visa only when the capture amount
is less than the authorization amount; full Authorization reversals are not supported. FDMS
North does not support unreferenced credits.
Merchant e-Solutions
Nova
Paymentech
This chapter describes Telecheck (electronic check) transaction processing and testing.
N O T E : TeleCheck transactions are not supported on the PayPal processor.
Paypal offers electronic check acceptance through TeleCheck. Before processing electronic
check transactions, merchants must obtain an account through TeleCheck
(www.telecheck.com).
For information on:
z Performing credit card transactions, skip this chapter and see Chapter 3, “Performing
Credit Card Transactions.”
z Performing ACH transactions, contact your PayPal Sales Representative at
paymentsales@PayPal.com
TeleCheck Parameters
Parameters used for processing electronic checks through TeleCheck are described in
Table B.1. Required and optional parameters are noted.
N O T E : Appendix E, “Additional Reporting Parameters,” provides a list of parameters that you
can pass for reporting purposes.
Required Parameters
As a summary of Table B.1, the following parameters are required for every electronic check
transaction:
TRXTYPE
TENDER
CHKTYPE
PARTNER
VENDOR
USER
PWD
AMT
CITY
DL or SS
CHKNUM
EMAIL
MICR
NAME
STATE
STREET
ZIP
HOSTCODE Values
The HOSTCODE reflects the TeleCheck server result. The following tables describe the
HOSTCODE values. TeleCheck requires that you display certain verbiage to the purchaser
based on the returned HOSTCODE value—check with TeleCheck for details.
N O T E : Many of these codes will not be encountered under normal operating conditions—they
are included as a troubleshooting aid. In the tables, the Frequency column indicates the
likelihood that you will encounter the code.
PayPal Payment Services supports passing Purchasing Card Level 2 information (such as
purchase order number, tax amount, and charge description) in the settlement file.
If additional required invoice information and line item details are included in the transaction,
PayPal formats Purchasing Card Level 3 information in an appropriate format, for example,
EDI (Electronic Data Interchange) 810 format as required by American Express during
settlement processing.
Level Description
Level 1 Function as normal credit cards and are authorized and associated with normal
transaction data in authorization and settlement. Any merchant who accepts
credit cards supports this level.
Level Description
Level 2 Additional data regarding sales tax, customer code, purchase order number,
invoice number are captured at the point of sale. In most cases, this
information is combined with the merchant’s tax ID number, state, and postal
code data and is then passed through during settlement. For some processors
and banks, however, a Level 2 authorization may include some of this data.
Level 3 Significant additional information such as line items, product codes, item
descriptions, unit price, unit quantities, and ship-to postal data are added to the
Level 2 data to provide optimal reporting to buyers and sellers. Settlement
transactions typically carry Level 3 data.
Level 2 and Level 3 data is generally considered non-financial data. Lack of adequate data
may cause a transaction to be downgraded.
PayPal generally requires up to Level 2 information in an Authorization transaction followed
by additional Level 3 data in the associated Delayed Capture transaction. A Sale transaction
should include all Level 3 data since it is authorized and later settled.
Avoiding Downgrade
If a transaction uses the purchasing card BIN range (see “Accepted BIN Ranges” on page 122)
and contains a line item but does not include all mandatory Level 3 parameters, then the
transaction succeeds but is processed as Level 2 or Level 1 during settlement (depending on
which data was passed).
For downgraded transactions, with the VERBOSITY parameter set to MEDIUM or HIGH, a
message like the following is returned in the ADDLMSGS field:
Features not processed: PCARD L3 (missing or invalid: InvoiceNumber
RequestorName)
— or —
Features not processed: PCARD L3 (line item 3 missing: Description)
For details on VERBOSITY, see Appendix D, “Verbosity: Viewing Processor-Specific
Transaction Results.”
Edit Check
PayPal performs an edit check on the transaction’s amount fields to ensure that all line item
and tax amounts balance.
If the edit check fails, the transaction fails with Result 4: Invalid Amount.
To pass the edit check, the following relationship must be true:
Transaction Amount = Total Tax Amount + Total Freight Amount + Total Handling
Amount + Total Line Item Amount.
Total Line Item Amount Summation of L_QTYn * L_COSTn for all line items (n as the
line item number). For example, if there are 2 line items, then the
Total Line Item Amount would be (LQTY1*LCOST1) +
(LQTY2*LCOST2)
Mandatory
AMEX Name XMLPayRequest parameter
/ Optional
(per American (See Payflow Pro XMLPay Format
Express Developer’s Guide for (min/max,
Specification) Pay Flow SDK parameter detailed instructions.) type)
Authorization M AUTHCODE ForceCapture.Authcode
Code (Passed transparently for delayed
capture. Use only with voice
authorized force capture
transactions)
Requester Name M REQNAME ExtData ”REQNAME” 1/40, AN
Cardmember M PONUM BillTo.PONum 1/17, AN
Reference No
Ship to ZIP M SHIPTOZIP ShipTo.Address.ZIP 5/6, AN
Invoice Date O INVOICEDATE Invoice.Date YYYYMM
Defaults to Transaction Date if not DD, string
present.
Total Transaction M AMT Invoice.TotalAmt 1/8 NUM
Amount The value must include a decimal
and the exact amount to the cent
(42.00, not 42). Do not include
comma separators (1234.56 not
1,234.56).
N O T E : American Express Phoenix
Level 3 processing requires
that this parameter have a
maximum field length of 8
for Level 3 processing.
Total Tax M TAXAMT Invoice.TaxAmt 1/6 NUM
Amount The value must include a decimal
and the exact amount to the cent
(42.00, not 42). Do not include
comma separators (1234.56 not
1,234.56).
Charge O DESC Invoice.Description 1/40, AN
Description Defaults to “NO”
Total Freight Amt O FREIGHTAMT Invoice.FreightAmt 1/15, AN
Total Handling O HANDLINGAMT Invoice.HandlingAmt 1/15, AN
Amt
Quantity Invoiced M L_QTYn Item.Quantity 1/10, NUM
Unit of Measure M L_UOMn Item.UnitOfMeasurement 2/2, AN
Mandatory
AMEX Name XMLPayRequest parameter
/ Optional
(per American (See Payflow Pro XMLPay Format
Express Developer’s Guide for (min/max,
Specification) Pay Flow SDK parameter detailed instructions.) type)
Unit Price M L_COSTn Item.UnitPrice 1/15, NUM
Item Description M L_DESCn Item.Description 1/80, AN
Supplier Catalog M L_CATALOGNUMn Item.CatalogNumber 1/20, AN
No
Cost Center No M L_COSTCENTERNUMn Item.CostCenterNumber 1/30, AN
Supplier Stock O L_PRODCODEn Item.SKU 1/30, AN
Keeping Unit
Number
Universal Product O L_UPCn Item.UPC 1/30, AN
Code
Item Tax Amount O L_TAXAMTn Item.TaxAmt 1/6, NUM
Freight Amount O L_FREIGHTAMTn Item.FreightAmt 1/15, NUM
Handling Amount O L_HANDLINGAMTn Item.HandlingAmt 1/15, NUM
Tracking Number O L_TRACKINGNUMn Item.TrackingNumber 1/30, AN
Drop-off O L_PICKUPSTREETn Item.PickUp.Address.Street 1/40, AN
Address1
Drop-off City O L_PICKUPCITYn Item.PickUp.Address.City 2/30, AN
Drop-off State O L_PICKUPSTATEn Item.PickUp.Address.State 2/2, AN
Drop-off ZIP O L_PICKUPZIPn Item.PickUp.Address.ZIP 3/15, AN
Drop-off Country O L_PICKUPCOUNTRYn Item.PickUp.Address.Country 2/3, AN
UNSPSC Code O L_UNSPSCCODEn Item.UNSPSCCode 1/30, AN
<Description>Ducati parts</Description>
<Quantity>2</Quantity>
<UnitPrice>.10</UnitPrice>
<UnitOfMeasurement>10</UnitOfMeasurement>
<CostCenterNumber>5000</CostCenterNumber>
<TrackingNumber>TR42322</TrackingNumber>
<UNSPSCCode>UNSPSC001</UNSPSCCode>
<CatalogNumber>1551</CatalogNumber>
<PickUp>
<Address>
<Street>112 Pickup Ave</Street>
<City>Pickup City</City>
<State>CA</State>
<Zip>94043</Zip>
<Country>840</Country>
</Address>
</PickUp>
<FreightAmt>0.50</FreightAmt>
<HandlingAmt>0.50</HandlingAmt>
</Item>
<Item Number="2">
<SKU>42335</SKU>
<UPC>45578</UPC>
<Description>Honda Parts</Description>
<Quantity>1</Quantity>
<UnitPrice>.10</UnitPrice>
<UnitOfMeasurement>50</UnitOfMeasurement>
<CostCenterNumber>5003</CostCenterNumber>
<TrackingNumber>TR34225</TrackingNumber>
<UNSPSCCode>UNSPSC002</UNSPSCCode>
<CatalogNumber>1555</CatalogNumber>
<PickUp>
<Address>
<Street>113 Pickup Ave</Street>
<City>Pickup City</City>
<State>CA</State>
<Zip>94043</Zip>
<Country>840</Country>
</Address>
</PickUp>
<FreightAmt>0.50</FreightAmt>
<HandlingAmt>0.50</HandlingAmt>
</Item>
<Item Number="3">
<SKU>12347</SKU>
<UPC>54329</UPC>
<Description>Harley Parts</Description>
<Quantity>2</Quantity>
<UnitPrice>.10</UnitPrice>
<UnitOfMeasurement>15</UnitOfMeasurement>
<CostCenterNumber>5009</CostCenterNumber>
<TrackingNumber>TR32223</TrackingNumber>
<UNSPSCCode>UNSPSC003</UNSPSCCode>
<CatalogNumber>1560</CatalogNumber>
<PickUp>
<Address>
<Street>114 Pickup Ave</Street>
<City>Pickup City</City>
<State>CA</State>
<Zip>94043</Zip>
<Country>840</Country>
</Address>
</PickUp>
<FreightAmt>0.50</FreightAmt>
<HandlingAmt>0.50</HandlingAmt>
</Item>
</Items>
<Description>CAR PARTS</Description>
<TaxAmt>1.60</TaxAmt>
<TotalAmt>5.10</TotalAmt>
</Invoice>
<Tender>
<Card>
<CardType>AMEX</CardType>
<CardNum>378734493671000</CardNum>
<ExpDate>201312</ExpDate>
</Card>
</Tender>
</PayData>
</Sale>
</Transaction>
</Transactions>
</RequestData>
<RequestAuth>
<UserPass>
<User>USER</User>
<Password>PASSWORD</Password>
</UserPass>
</RequestAuth>
</XMLPayRequest>
TABLE C.8 FDMS South Level 2 and Level 3 purchasing card parameters
TABLE C.8 FDMS South Level 2 and Level 3 purchasing card parameters (Continued)
name-value starts with L_ and ends with n where n is the line item number. For example
L_QTY0=1 is the quantity for line item 0 and is equal to 1, with n starting at 0.
Mandatory / Format
Data Items Optional Payflow Parameter (min/max, type)
Customer Code M CUSTCODE 1/16, Char
Sales Tax M TAXAMT NUM
The value must include a decimal and the exact
amount to the cent (42.00, not 42). Do not include
comma separators (1234.56 not 1,234.56). To qualify
for Level 2 discounts, this value must not be all zeros
or blank spaces.
Length
Data Items Payflow Parameter Required Type (min/ max)
Customer Code CUSTCODE Yes char 1/16
Sales Tax TAXAMT Yes numeric
The value must include a decimal and the
exact amount to the cent (42.00, not 42). Do
not include comma separators (1234.56 not
1,234.56). To qualify for Level 2 discounts,
this value must not be all zeros or blank
spaces.
Merchant e- Format
Solutions Mandatory / (min/max,
Name Optional Payflow Parameter type)
Cust Ref ID M PONUM 1/17, AN
Tax Amount M TAXAMT NUM
The value must include a decimal and the exact amount to the
cent (42.00, not 42). Do not include comma separators
(1234.56 not 1,234.56).
Tax Amount O TAXEXEMPT, Y or N 1, A
Identifier
IMPO RTANT: The values required for Level 3 status vary by bank, so contact your bank for
details.
TABLE C.13 Merchant e-Solutions Level 2 MasterCard parameters for Level 3 line
item transactions
Merchant
e-Solutions Mandatory Length,
Name / Optional Payflow Parameter Data Type
Purchase Identifier M PONUM 25, AN
Value of TransID is sent if no value is provided.
Tax Amt M TAXAMT NUM
The value must include a decimal and the exact amount to
the cent (42.00, not 42). Do not include comma separators
(1234.56 not 1,234.56).
Lcl Tax O LOCALTAXAMT 12, NUM
Lcl Tax Incl Flag O TAXEXEMPT, Y or N 1, AN
National Tax Amt O NATIONALTAXAMT 12, NUM
You may omit this parameter if there is no such tax.
Purch Ord #/Cust M INVNUM 9, AN
Ref ID Value of PNREF is sent if no value is provided.
TABLE C.15 Merchant e-Solutions Level 3 MasterCard line item detail record
Mandatory / Length,
Merchant e-Solutions Name Optional Payflow Parameter Data Type
N O T E : For these values, n is a sequence counter that should begin with 1 and increase in sequence. Each line item
should also contain quantity (L_QUANTITY<n>) and unit price (L_COST<n>) fields.
Item Descriptor M L_DESCn 35, AN
Product Code O L_UPCn 12, AN
Quantity M L_QTYn 12, NUM
Unit of Measure/Code M L_UOMn 12, AN
Tax Rate Applied O L_TAXRATEn 4, NUM
Tax Type Applied O L_TAXTYPEn 4, AN
Tax Amount O L_TAXAMTn 12, NUM
Discount Amount O L_DISCOUNTn 12, NUM
IMPO RTANT: The values required for Level 3 status vary by bank, so contact your bank for
details.
TABLE C.16 Merchant e-Solutions Level 2 Visa parameters for Level 3 line item
transactions
Merchant e-
Solutions Mandatory Length,
Name / Optional Payflow Parameter Data Type
Purchase M PONUM 25, AN
Identifier Value of TransID is sent if no value is provided.
Tax Amount M TAXAMT NUM
The value must include a decimal and the exact amount to the
cent (42.00, not 42). Do not include comma separators
(1234.56 not 1,234.56).
Lcl Tax O LOCALTAXAMT 12, NUM
Lcl Tax Incl Flag TAXEXEMPT, Y or N. 1, AN
National Tax Amt O NATIONALTAXAMT 12, NUM
Purch Ord #/Cust M INVNUM 9, AN
Ref ID Value of TransID is sent if no value is provided.
TABLE C.18 Merchant e-Solutions Level 3 Visa line item detail record
Format
Mandatory / (min/max,
Data Items Optional Payflow Parameter type)
Customer M CUSTCODE 1/16, char
Code Value of {ServerID}{TransID} is sent if no value is provided.
Sales Tax M TAXAMT NUM
Value of 0 (zero) is sent if no value is provided.
The value must include a decimal and the exact amount to the cent
(42.00, not 42). Do not include comma separators (1234.56 not
1,234.56).
Format
Paymentech Mandatory / (min/max,
Data Items Optional Payflow Parameter type)
Customer Ref No M PONUM 1/17, char
Sales Tax M TAXAMT NUM
The value must include a decimal and the exact amount
to the cent (42.00, not 42). Do not include comma
separators (1234.56 not 1,234.56). To qualify for Level
2 discounts, this value must not be all zeros or blank
spaces.
"TRXTYPE=S&TENDER=C&PARTNER=Partner&PWD=Password&USER=User&ACCT=42753300123
45626&EXPDATE=1203&AMT=1.00&COMMENT1=0508&STREET=1600&ZIP=94065&CVV2=426&PO
NUM=ABCDEFGHIJ&TAXAMT=1.00"
Format
Paymentech Data Mandatory / (min/max,
Items Optional Payflow Parameter type)
Customer Ref No M PONUM 1/17, char
Sales Tax M TAXAMT NUM
The value must include a decimal and the exact amount
to the cent (42.00, not 42). Do not include comma
separators (1234.56 not 1,234.56). To qualify for Level
2 discounts, this value must not be all zeros or blank
spaces.
TABLE C.23 Paymentech New Hampshire Level 3 MasterCard order and line item
parameters
TABLE C.24 Paymentech New Hampshire Level 3 Visa order and line item parameters
Format
Paymentech Mandatory / (min/max,
Data Items Optional Payflow Parameter type)
Customer Ref M PONUM 1/17, char
No
Sales Tax M TAXAMT NUM
The value must include a decimal and the exact amount to
the cent (42.00, not 42). Do not include comma separators
(1234.56 not 1,234.56). To qualify for Level 2 discounts, this
value must not be all zeros or blank spaces.
Tax Exempt O TAXEXEMPT, Y or N. 1
Contact your acquiring bank to determine if your
transactions are tax exempt.
Ship to ZIP O SHIPTOZIP 1/16
Code (called ZIP code in the USA).
Format
Mandatory / (min/max,
Name Optional Payflow Parameter type)
Cust Ref ID M PONUM 1/17, AN
Tax Amount M TAXAMT NUM
The value must include a decimal and the exact amount to the
cent (42.00, not 42). Do not include comma separators
(1234.56 not 1,234.56).
Tax Amount O TAXEXEMPT, Y or N 1, A
Identifier
IMPO RTANT: The values required for Level 3 status vary by bank, so contact your bank for
details.
TSYS Acquiring Solutions Level 2 MasterCard Parameters Required for Level 3
Line Item Transactions
TABLE C.27 TSYS Acquiring Solutions Level 2 MasterCard transaction data for line
item transactions
Mandatory Length,
Name / Optional Payflow Parameter Data Type
Purchase Identifier M PONUM 25, AN
Value of TransID is sent if no value is provided.
Tax Amt M TAXAMT NUM
The value must include a decimal and the exact amount to
the cent (42.00, not 42). Do not include comma separators
(1234.56 not 1,234.56).
Lcl Tax O LOCALTAXAMT 12, NUM
Lcl Tax Incl Flag O TAXEXEMPT, Y or N 1, AN
National Tax Amt O NATIONALTAXAMT 12, NUM
You may omit this parameter if there is no such tax.
Purch Ord #/Cust M INVNUM 9, AN
Ref ID Value of PNREF is sent if no value is provided.
Mandatory / Length,
Name Optional Payflow Parameter Data Type
Freight Amt O FREIGHTAMT 12, NUM
Duty Amt O DUTYAMT 12, NUM
Dest Postal / ZIP Code M SHIPTOZIP 10, AN
The ZIP code of the address to which the goods are
shipped.
Ship from Postal / ZIP M SHIPFROMZIP 10, AN
Code The postal code (called ZIP code in the USA) from
which shipping occurs.
Dest Country Code O SHIPTOCOUNTRY 4, AN
Mandatory / Length,
Name Optional Payflow Parameter Data Type
Alt Tax Amt O ALTTAXAMT 9, NUM
TABLE C.29 TSYS Acquiring Solutions Level 3 MasterCard line item detail record
Mandatory / Length,
Name Optional Payflow Parameter Data Type
N O T E : For these values, n is a sequence counter that should begin with 1 and increase in sequence. Each line item
should also contain quantity (L_QUANTITY<n>) and unit price (L_COST<n>) fields.
Item Descriptor M L_DESCn 35, AN
Product Code O L_UPCn 12, AN
Quantity M L_QTYn 12, NUM
Unit of Measure/Code M L_UOMn 12, AN
Tax Rate Applied O L_TAXRATEn 4, NUM
Tax Type Applied O L_TAXTYPEn 4, AN
Tax Amount O L_TAXAMTn 12, NUM
Discount Amount O L_DISCOUNTn 12, NUM
IMPO RTANT: The values required for Level 3 status vary by bank, so contact your bank for
details.
TSYS Acquiring Solutions Level 2 Visa Parameters for Level 3 Line Item
Transactions
TABLE C.30 TSYS Acquiring Solutions Level 2 Visa transaction data for line item
transactions
Mandatory Length,
Name / Optional Payflow Parameter Data Type
Purchase M PONUM 25, AN
Identifier Value of TransID is sent if no value is provided.
Tax Amount M TAXAMT NUM
The value must include a decimal and the exact amount to the
cent (42.00, not 42). Do not include comma separators
(1234.56 not 1,234.56).
Lcl Tax O LOCALTAXAMT 12, NUM
Lcl Tax Incl Flag TAXEXEMPT, Y or N. 1, AN
National Tax Amt O NATIONALTAXAMT 12, NUM
Purch Ord #/Cust M INVNUM 9, AN
Ref ID Value of TransID is sent if no value is provided.
Mandatory / Length,
Name Optional Payflow Parameter Data Type
Summary Commodity M COMMCODE 4, AN
Code Commodity code identifier for the business.
Discount Amt O DISCOUNT 12, NUM
Freight Amt M FREIGHTAMT 12, NUM
Duty Amt O DUTYAMT 12, NUM
Order Date O ORDERDATE 6, NUM
Format is mmddyy with no slashes or dashes. For
example,
July 28, 2003 is 072803
TABLE C.31 TSYS Acquiring Solutions Level 3 Visa extended data (Continued)
Mandatory / Length,
Name Optional Payflow Parameter Data Type
Dest Postal / ZIP Code M SHIPTOZIP 10, AN
The ZIP code of the address to which the goods are
shipped.
Ship from Postal / ZIP M SHIPFROMZIP 10, AN
Code The postal code (called ZIP code in the USA) from
which shipping occurs.
Dest Country Code O SHIPTOCOUNTRY 4, AN
VAT Registration M VATREGNUM 20, AN
Number Can be part of the registration data or passed with each
transaction.
Unique VAT Inv Ref # M INVNUM 9, AN
Can be part of the registration data or passed with each
transaction.
Cust VAT Registr # M CUSTVATREGNUM 13, AN
VAT/Tax Amt O VATTAXAMT 12, NUM
(Freight/Ship)
VAT/Tax Rate O VATTAXPERCENT 4, NUM
(Freight/Ship)
TABLE C.32 TSYS Acquiring Solutions Level 3 Visa line item detail record
Transaction results (especially values for declines and error conditions) returned by each
PayPal-supported processor vary in detail level and in format. The Payflow Verbosity
parameter enables you to control the kind and level of information you want returned.
By default, Verbosity is set to LOW. A LOW setting causes PayPal to normalize the
transaction result values. Normalizing the values limits them to a standardized set of values
and simplifies the process of integrating the Payflow SDK.
By setting Verbosity to MEDIUM, you can view the processor’s raw response values. This
setting is more “verbose” than the LOW setting in that it returns more detailed, processor-
specific information.
Table D.2 shows the increments that are possible on basic TRANSSTATE values.
Increment Meaning
+100 No client acknowledgment (ACK) is received. For example, 106 is TRANSSTATE 6.
Transactions in this range do not settle.
For transactions in TRANSSTATE 106, use Auto Resettle in PayPal Manager’s Virtual Terminal
to submit them for settlement or void them using a manual Void.
N O T E : You can eliminate TRANSSTATE 106 by using the latest version 4 SDK with your
application. To determine the version of your SDK, see “Payflow SDK Version” on
page 15.
+200 The host process never receives ACK from the transaction broker (or backend payment server).
A transaction with a TRANSSTATE of +200 is basically in limbo and will not be settled.
+1000 Voided transactions. Any TRANSSTATE of +1000 (for example, 1006) means the transaction
was settle pending. However, it was voided either through the API, PayPal Manager, or PayPal
Customer Service.
This appendix lists parameters whose values can appear in PayPal Manager reports. For
example, the Shipping and Billing report displays these values. Some of the following
parameters may also have other purposes. The STREET and ZIP parameters, for instance, are
also used for AVS.
N O T E : Forregular credit card transactions, reporting parameters are normally not passed to
the processor. See Appendix A, “Processors Requiring Additional Transaction
Parameters,” to learn which fields are sent to your processor.
Max
Parameter Description Required Type Length
Max
Parameter Description Required Type Length
The following International Standards Organization (ISO) country codes are used when filling the order fields
BILLTOCOUNTRY, SHIPTOCOUNTRY, and CORPCOUNTRY:
TABLE F.1
TABLE F.1
TABLE F.1
TABLE F.1
TABLE F.1
About XMLPay
XMLPay specifies an XML syntax for payment requests and associated responses in a
payment-processing network. Instead of using name/value pairs, the Payflow SDK allows the
use of XML documents based on XMLPay 2.0 schema.
The typical user of XMLPay is an internet merchant or merchant aggregator who wants to
dispatch credit card, corporate purchase card, Automated Clearinghouse (ACH), or other
payment requests to a financial processing network.
Using the data type definitions specified by XMLPay, such a user creates a client payment
request and dispatches it in the same fashion as using name/value pairs to an associated
XMLPay-compliant server component. Responses are also formatted in XML and convey the
results of the payment requests to the client.
Codes used by FDMS South only are Country Codes, Units of Measure, and Currency Codes.
ALBANIA ALB
ALGERIA DZA
AMERICAN SAMOA ASM
ANDORRA AND
ANGOLA AGO
ANGUILLA AIA
ANTARCTICA ATA
ANTIGUA ATG
AO PEOPLES DEMOCRATIC LAO
APHGANISTAN AFG
ARGENTINA ARG
ARMENIA ARN
ARUBA ABW
AUSTRALIA AUS
AUSTRIA AUT
AZERBAIJAN AZE
BAHAMAS BHS
BAHRAIN BHR
BANGLADESH BGD
BARBADOS BRB
BELARUS BLR
BELGIUM BEL
TABLE H.1 MasterCard country codes TABLE H.1 MasterCard country codes
TABLE H.1 MasterCard country codes TABLE H.1 MasterCard country codes
TABLE H.1 MasterCard country codes TABLE H.1 MasterCard country codes
UZBEKISTAN UZB
VANUATU VUT
VATICAN CITY STATE VAT
VENEZUELA VEN
VIETNAM VNM
VIRGIN ISLANDS BRITISH VGB
VIRGIN ISLANDS US VIR
WALLIS AND FUTUNA IS WLF
WESTERN SAHARA ESH
YEMEN YEM
YUGOSLAVIA YUG
ZAIRE ZAR
ZAMBIA ZMB
ZIMBABWE RHO
ALBANIA AL AUSTRALIA AU
ALGERIA DZ AUSTRIA AT
ANDORRA AD BAHAMAS BS
ANGOLA AO BAHRAIN BH
ANGUILLA AI BANGLADESH BD
ANTARCTICA AQ BARBADOS BB
ANTIGUA AG BELARUS BY
APHGANISTAN AF BELGIUM BE
ARGENTINA AR BELIZE BZ
ARMENIA AM BENIN BJ
BERMUDA BM
TABLE H.2 Visa country codes TABLE H.2 Visa country codes
TABLE H.2 Visa country codes TABLE H.2 Visa country codes
GUADALUPE GP LESOTHO LS
GUAM GU LIBERIA LR
GUATEMALA GT LIBYAN ARAB JAMAHIRIYA LY
GUINEA GN LIECHTNSTIEN LI
GUINEA-BISSAU GW LITHUANIA LT
GUYANA GY LUXEMBOURG LU
HAITI HT MACAU MO
HEARD & MCDONALDS ISLAND HM MACEDONIA MK
HONDURAS HN MADAGASCAR MG
HONG KONG HK MALAWI MW
HUNGARY HU MALAYSIA MY
ICELAND IS MALDIVES MV
INDIA IN MALI ML
INDONESIA ID MALTA MT
IRAN IR MANACO MC
IRAQ IQ MARSHALL ISLANDS MH
IRELAND IE MATINIQUE MQ
ISRAEL IL MAURITANIA MR
ITALY IT MAURITIUS MU
JAMAICA JM MAYOTTE YT
JAPAN JP MEXICO MX
JORDAN JO MICRONESIA FM
KAZAKHSTAN KZ MOLDOVA MD
KENYA KE MONGOLIA MN
KIRIBATI KI MONTSERRAT MS
KOREA, REPUBLIC OF KR MOROCCO MA
KUWAIT KW MOZAMBIQUE MZ
KYRGYZSTAN KG MYANMAR MM
LAO PEOPLES DEMOCRATIC LA NAMIBIA NA
LATVIA LV NAURU NR
LEBANON LB NEPAL NP
TABLE H.2 Visa country codes TABLE H.2 Visa country codes
Units of Measure
TABLE H.3 Units of measure
B D
BALAMT 55
DESC parameter 104, 107, 128
BALAMT parameter 53, 56
DESC1 parameter 104, 127
Bank Identification Numbers. See 122
DESC2 parameter 104, 127
BIN 123
DESC3 parameter 104, 127
BUTTONSOURCE parameter 87
DESC4 parameter 104, 127
DISCOUNT parameter 134, 136, 144, 150, 151, 156
C DL parameter 114
Do Express Checkout Payment request 76
CANCELURL parameter 81 DOB parameter 114
CAPN 53, 56, 97, 124 documentation
card acceptance and processing network (CAPN) 124 API 19
card security code acceptance 49 downgraded transactions 123
CHKNUM parameter 114 downloading APIs 19
Index
I
E
IAVS 52
electronic check transaction inquiry transaction type 40
required parameters 113 INVNUM parameter 80, 85, 87, 103, 104, 106, 108,
EMAIL parameter 83, 84 110, 111, 127, 136, 142, 145, 154, 157
ENDTIME parameter 27 INVOICEDATE parameter 128
EXPDATE parameter 27 ITEMAMT parameter 86
Express Checkout
ACTION values 75
Do Express Checkout Payment request K
parameters 86 knowledgebase URL 12
Do Express Checkout Payment response
parameters 88
Get Express Checkout Details request parameters 84 L
Get Express Checkout Details response
parameters 84 L_AMTn parameter 88, 135, 138, 146, 150, 151, 158
L_CATALOGNUMn parameter 129
overview of process 73
Set Express Checkout example 76 L_COMMCODEn parameter 135, 138, 146, 158
Set Express Checkout request parameters 80 L_COSTCENTERNUMn parameter 129
L_COSTn parameter 129, 135, 138, 146, 151
testing 91
L_COSTn parameterPayflow parameters
L_COSTn 158
F L_DESCn parameter 88, 129, 135, 138, 143, 146, 150,
151, 155, 158
FDMS CardNet 107 L_DISCOUNTn 158
FDMS North 107, 134 L_DISCOUNTn parameter 135, 138, 143, 146, 150,
FDMS South 107, 136 151, 155, 158
FEEAMT parameter 88 L_FREIGHTAMTn 123
FIRSTNAME parameter 28, 102, 104, 136 L_FREIGHTAMTn parameter 129
FREIGHTAMT 123 L_HANDLINGAMTn parameter 129
FREIGHTAMT parameter 86, 128, 133, 134, 136, 142, L_PICKUPCITYn parameter 129
144, 150, 151, 154, 156 L_PICKUPCOUNTRYn parameter 129
L_PICKUPSTATEn parameter 129
G L_PICKUPSTREETn parameter 129
L_PICKUPZIPn parameter 129
Get Express Checkout Details request 76 L_PRODCODEn parameter 129, 138, 150, 151
L_QTYn 158
H L_QTYn parameter 88, 128, 135, 138, 143, 146, 150,
151, 155, 158
HANDLINGAMT parameter 86, 128 L_TAXAMTn parameter 88, 129, 135, 138, 143, 146,
HDRBACKCOLOR parameter 83 151, 155, 158
HDRBORDERCOLOR parameter 83 L_TAXRATEn parameter 143, 146, 151, 155, 158
HDRIMG parameter 82 L_TAXTYPEn parameter 143, 150, 155
host addresses 15 L_TRACKINGNUMn parameter 129
AUTHCODE 26, 35, 36, 52, 128 HANDLINGAMT 86, 124, 128
AVSADDR 52, 69 HDRBACKCOLOR 83
AVSZIP 52, 69 HDRBORDERCOLOR 83
BALAMT 53, 55 HDRIMG 82
BATCHID 162 HOSTADDRESS 24
BILLTOCOUNTRY 33, 37, 39, 42, 109, 167 HOSTCODE 117, 161
BUTTONSOURCE 87 HOSTPORT 24
CANCELURL 77, 81 IAVS 52
CHKNUM 113, 114 INVNUM 33, 37, 39, 80, 85, 87, 103, 104, 106, 108,
CHKTYPE 113, 114 110, 111, 114, 127, 136, 142, 144, 145, 154, 157
CITY 33, 37, 39, 42, 109, 113, 114, 136, 167 INVOICEDATE 128
COLOR 83 ITEMAMT 86
COMMCARD 133 L_AMT1 125
COMMCODE 144, 156 L_AMT2 125
COMMENT1 26, 33, 37, 39, 114, 167 L_AMT3 125
COMMENT2 26, 33, 37, 39, 114, 167 L_AMT4 125
COMPANYNAME 33, 37, 39 L_AMTn 88, 98, 135, 138, 146, 150, 151, 158
CORRELATIONID 53 L_CATALOGNUMn 129
CURRENCY 27 L_COMMCODEn 135, 138, 146, 158
CUSTBROWSER 98 L_COSTCENTERNUMn 129
CUSTCODE 33, 37, 39, 136, 139, 140, 167 L_COSTn 124, 129, 135, 138, 146, 151
CUSTHOSTNAME 98 L_DESC1 125
CUSTIP 33, 37, 39, 98 L_DESC2 125
CUSTOM 80, 85, 87 L_DESC3 125
CUSTREF 27, 40 L_DESC4 125
CUSTVATREGNUM 145, 157 L_DESCn 88, 97, 129, 135, 138, 143, 146, 150, 151,
CVC2 48 155, 158
CVV2 48, 69 L_DISCOUNTn 135, 138, 143, 146, 150, 151, 155
CVV2MATCH 48, 51, 54, 69 L_FREIGHTAMTn 123, 129
DATE_TO_SETTLE 162 L_HANDLINGAMTn 124, 129
DESC 104, 107, 128 L_PICKUPCITYn 129
DESC1 104, 127 L_PICKUPCOUNTRYn 129
DESC2 104, 127 L_PICKUPSTATEn 129
DESC3 104, 127 L_PICKUPSTREETn 129
DESC4 37, 104, 127 L_PICKUPZIPn 129
DISCOUNT 134, 136, 144, 150, 151, 156 L_PRODCODEn 129, 138, 150, 151
DL 33, 37, 39, 113, 114 L_QTY1 125
DOB 33, 37, 39, 114 L_QTY2 125
DUTYAMT 33, 37, 39, 133, 134, 136, 142, 144, 151, L_QTY3 125
154, 156, 167 L_QTY4 126
EMAIL 33, 37, 39, 83, 84, 98, 113, 114, 167 L_QTYn 88, 98, 124, 128, 135, 138, 143, 146, 150,
ENDTIME 27, 40 151, 155
EXPDATE 27, 31, 33, 36, 37, 39, 42, 44 L_TAXAMTn 88, 129, 135, 138, 143, 146, 151, 155,
158
FEEAMT 88
L_TAXRATEn 143, 146, 151, 155, 158
FIRSTNAME 28, 33, 37, 39, 42, 102, 104, 136, 167
L_TAXTYPEn 143, 150, 155
FREIGHTAMT 33, 37, 39, 86, 123, 128, 133, 134,
136, 142, 144, 150, 151, 154, 156, 167 L_TRACKINGNUMn 129
U
USER parameter 30
V
VATREGNUM parameter 145, 157
VATTAXAMT parameter 145, 157
VATTAXPERCENT parameter 145, 157
VENDOR parameter 30
VERBOSITY 123
VERBOSITY parameter 30