Integrate Fastlane by PayPal

Before beginning your integration, you need to set up your development environment. You can refer to this flow diagram, and watch a video demonstrating how to integrate PayPal Fastlane.

Start your integration by grabbing the sample code from PayPal’s GitHub repo, or visiting the PayPal GitHub Codespace. Read the Codespaces guide for more information.

1. Integrate front end CLIENT

Set up your front end to integrate Fastlane.

Front-end process

  1. Your app shows Fastlane Payment component.
  2. Your app calls server endpoints to create the order and capture payment.

Step 1: Generate client token

To instantiate the JavaScript SDK and the Fastlane components, use a server-side call to generate a client token and then pass the token into the SDK.

  1. Replace CLIENT ID with your client ID.
  2. Replace CLIENT_SECRET with your client secret. Get your client ID and secret.
  3. Replace example.com, example2.com with your own domains. Provide the root domain name only. No subdomains such as sub.example.com. No wildcard characters such as *.example.com. No protocols such as http or https.

Step 2: Initialize PayPal JS SDK and Fastlane

First, Initialize the SDK through a script tag on your HTML page.

The fields required to initialize the PayPal JS SDK are:

  • client-id: client-id of your application.
  • data-sdk-client-token: generated from the token initialization.

Fastlane is initialized with a call to paypal.Fastlane in the app.js file. You must pass a configuration object during initialization.

Specify locale

You can specify the language in which the Fastlane components are rendered. After you initialize the Fastlane component, you can set the locale.

Fastlane supports the following languages; en_us (English, default), es_us (Spanish), fr_us (French), and zh_us (Mandarin).

Step 3: Capture user email address

You’ll need to render your own email field to capture the payer’s email address.

Because the email address will be shared with PayPal, it is crucial to inform the payer. We recommend to display the Fastlane watermark below the email field.

After collecting the email address, PayPal determines whether the email is associated with a Fastlane profile or if it belongs to a PayPal member. Use the following code snippet to look up the customer's email.

Authenticate profile with one-time password

If the user is identified with a Fastlane profile, they need to authenticate before Fastlane retrieves their saved payment and address information. The user is presented with a screen to authenticate themselves by entering a one-time password sent to their registered mobile number.

The triggerAuthenticationFlow() method returns an AuthenticatedCustomerResult object. Use the authenticationState property in the AuthenticatedCustomerResult object to check if the payer has authenticated.

On authentication:

  • The Fastlane member's card details and default shipping address are returned with the profileData object contents.
  • The renderFastlaneMemberExperience is set to True.

If a user fails or declines to authenticate, render the same experience as you would for a guest payer.

Step 4: Render shipping address

This step is not required for:

  • Fastlane members without a shipping address.
  • Fastlane members with a shipping address in a region you don't support.
  • Guest payers

Continue to render your own shipping address collection form and pass it into the server-side transaction request.

For Fastlane members with a shipping address, you’ll need to render:

  • Shipping address returned from profile data on successful authentication.
  • Fastlane watermark.
  • Fastlane by PayPal logo.
  • Change address button that invokes showShippingAddressSelector().
    This provides a payer with the option to change or add a new address.

Step 5: Accept payments

Fastlane offers two different integration patterns to accept payments; quick start and flexible.

Flexible

The flexible payment integration enables you to customize the UI and render your own form fields to collect an address. You can customize the behavior and experience of your checkout and create your own payment forms.

Integration Requirements

You’ll need to vary your integration a little for each persona.

For Fastlane members with a stored card, you’ll need to render:

  1. The selected card from the profile object
  2. Fastlane watermark
  3. Change card button that invokes showCardSelector()

For Fastlane members with no card, an unsupported card, and guest payers, you’ll need to render:

  1. The FastlaneCardComponent to accept new card information.
  2. A form to capture the payer's billing address

Pass billing address and cardholder name in getPaymentToken() Method. When calling the getPaymentToken() method, ensure that the billing address is included in the request.

If the cardholderName field is disabled in your checkout process, it must still be sent in the getPaymentToken() request.

Render watermark

When displaying the card from payer’s Fastlane profile, you must inform them about it by displaying the Fastlane watermark below the card.

For a better payer experience of Fastlane, preload the watermark asset by adding the following code to the <head> section of the page.

<link rel="preload" href="https://www.paypalobjects.com/fastlane-v1/assets/fastlane-with-tooltip_en_sm_light.0808.svg" as="image" type="image/avif" />

The mouse-over tooltip functionality will be added to the image when the Watermark component completes loading. After it loads, the information is displayed when the user hovers over the i icon.

When opting to integrate using the flexible pattern, load card assets for the selected card so that the payer can see their card brand.

Step 6: Configure the styling of the Fastlane component OPTIONAL

When styling the Fastlane components to match the look and feel of your checkout page, here are some guidelines to provide an accessible and transparent experience to your payer:

  • Ensure that there is adequate contrast between the backgroundColor and textColor to ensure that all text, especially the legal text under the opt-in, is clear and legible. If the contrast ratio between the two is not 4.5:1 or greater, PayPal will automatically set the contrast to their default values.
  • Ensure there is adequate contrast between the borderColor, which drives the consent toggle coloring, and the backgroundColor.

To override the default style settings for your page, use a StyleOptions object inside the Fastlane component. You can customize the styling with different colors and shapes.

To override the default style settings for your page, use a StyleOptions object inside the Fastlane component.

You can customize the styling with different colors and shapes.

Visit the Reference page for more details about additional customization and style options.

2. Integrate back end SERVER

This section explains how to set up your back end to integrate standard checkout payments.

Back-end process

Your app creates and confirms an order on the back end by calling to the Create Orders V2 API endpoint.

Create order

On your server, you need to create an order by invoking the PPCP Orders API and passing the single use token, along with the item details and the shipping address.

Intent

Amount

Providing detailed item descriptions and product images for each item creates a better user experience. It helps email communications and streamlines any potential dispute resolution.

Special use-cases

Store pick-up: If the buyer is picking up item from a storefront, modify the shipping type parameter in the call and ensure the shipping method is set to PICKUP_IN_STORE. This ensures that buyer profiles aren’t created with the address of your store as their shipping address.

Vaulting: Make sure you have configured your REST app to enable vault. You can vault a payment method with or without a transaction.

  • Vault with transaction: If you want to save the paymentToken returned by the Fastlane SDK at the time of transaction, you can do so only when using the store_in_vault attribute in the request to /v2/orders on your server. This returns a vault ID, which can be saved and used for future captures. See the Orders v2 documentation for more details.

  • Vault without transaction: If you want to save the paymentToken returned by the Fastlane SDK without completing the transaction, then the payment token is generated but the Fastlane profile is not created for the customer. The Fastlane profile is created only for vaulting customers if they also complete a transaction during checkout.

3. Test integration

You’ll need to test your integration for guest payers, Fastlane members, and PayPal members. If you’re using the flexible integration, make sure your address and payment form fields render as expected.

Card numbers for testing

Use any of the following card numbers as test cards.

Brand Test Number
Visa 4005 5192 0000 0004
Visa 4012 0000 3333 0026
Visa 4012 0000 7777 7777
Mastercard 5555 5555 5555 4444
American Express 3782 822463 10005

Test guest payers

Before you test guest payers, make sure you:

  • Create a new email address: Provide a new email address which is not associated with a sandbox Fastlane account.
  • Ensure opt-in toggle is ON: Go through the checkout process using one of the card numbers available for testing. Be sure that the opt-in toggle is in the “on” state.
  • Enter any valid phone number for sandbox: Make sure to pass a valid area code and prefix. A Fastlane profile is not created if you pass an invalid number such as 111-111-1111. No SMS is sent in sandbox mode. Upon completing the transaction, a Fastlane profile is created. Use that profile to test subsequent transactions as a Fastlane member.

Test guest payer flows with the consent toggle both on and off. If the consent toggle is off, the payment completes successfully and no Fastlane profile is created.

Test Fastlane members

Before you test Fastlane payers, make sure you:

  • Create a Fastlane Member profile: Go through the previous step and register a new Fastlane account. Be sure to remember the email address used when you created the account so that you can use it for additional testing.
  • Use OTP for testing: When the authentication modal appears and you are prompted for a one-time password (OTP) use 111111 to trigger a successful authentication and any other 6-digit number to simulate a failed authentication.
  • Test updating payment method and shipping addresses to existing Fastlane Profiles: Make sure that you test the payer’s ability to update shipping addresses and cards associated with their profile.

Test the Fastlane member scenario as the member toggles all the options such as adding or changing an address or card, or failing the OTP.

Test PayPal members

PayPal members that choose not to save their profile will be treated as guest users.

PayPal members that choose to save their profile will be treated as returning Fastlane member for future transactions.

PayPal members do not require any additional handling within your integration because our client SDK handles this use case for you in the following ways:

  • After performing the lookupCustomerByEmail method, we will return a customerContextId as if this were a Fastlane member.

  • When you call the triggerAuthenticationFlow method, our SDK will display a call to action to the customer explaining that they can create a Fastlane profile populated with information from their PayPal account with one click.

  • If the consumer clicks yes, we will return profileData exactly as we would for a Fastlane member.

  • If the consumer closes the dialog, we will return an empty profileData object and you would handle this as you would any Fastlane guest member.

Visit the Reference page for more details about troubleshooting, best practicescustomization and style options.

4. Go live

If you have fulfilled the requirements for accepting card payments via Fastlane for your business account, review Move your app to production to test and go live.

If this is your first time testing in a live environment, follow these steps:

  1. Log into the PayPal Developer Dashboard with your PayPal business account.
  2. Complete production onboarding so you can process card payments with your live PayPal business account.
  3. Request Advanced Credit and Debit Card Payments for your business account if you are not using cards currently with PayPal. Fastlane will be enabled along with the Advanced Credit and Debit Card payments processing.

Customer


Shipping


Billing


Payment