Implementation and setup

Deliver value to travelers beyond points or miles

With White Label Template, your travelers can earn loyalty currency—however your program defines it—then redeem their rewards on travel purchases. This document provides an overview of the available Loyalty operations and explains the process for you to implement the services in the test and production environments. The APIs available to you will be determined by your contract, so it's important to know what you need.

Your implementation will require that you provide standard RESTFul services with JSON payloads. We recommend using access tokens and JSON web tokens for every API request. There are additional security steps involved when calling the APIs, and any sensitive data elements in the request and response payloads will be encrypted.

When you set up your template site, you can choose to allow your customers to redeem any loyalty currency they’ve earned on whichever lines of business you’ve selected.

Alternatively, they can reach out to an Expedia brand site agent to use those points. Our internal agents will use the Account Information API to to verify the traveler’s information. Once verified, they will leverage the Points Bank API to get the traveler’s account balance and assist with booking.

Your Expedia launch manager will work with you to get all the necessary details, including SSO setup, such as: Your brand or program name, any member tiers or segments within your program, the name of your loyalty currency, and the redemption ratio (for example, $1 spent = 100 points).

We’ll also need you to provide:

  • Access Token API
  • ClientId and secret
  • Loyalty redemption endpoints
  • The service level agreement (SLA) you’ve communicated to your customers

For setup on your end, we’ll provide:

  • An OpenAPI specification
  • A JSON web key (JWK) endpoint if you’re using the Authorization2 parameter

Making API calls

Expedia uses the access token to invoke the API. The access token will be provided in the authorization HTTP header as a bearer token. The system will generate a required request signature token and provide that in the Authorization2 HTTP header.

Authorization endpoint

To get an access token for API calls, you’ll first need to set up an authorization server with a client ID and secret. Then you’ll use a POST : https://<your-oauth-endpoint> call to make the request.

Request

FieldDescriptionSample valueField typeMandatory?
content-typeIndicates the request formatapplication/x-www-form-urlencodedStringYes
grant_typeMethod of authorization for the request, such as client credentialsclient-credentials&client_id=<client_id>&client_secret=<client_secret>StringYes
client_idYour application identifier as registereda17c21ed& Yes
client_secretSecret corresponding to the client_id  Yes

Response

FieldDescriptionSample valueField typeMandatory?
content-typeIndicates the response body formatapplication/jsonStringYes
token_typeThe audience of the token; indicates the kind of access to providebearer Yes
access_tokenAn access token referencing the client_id  Yes
expires_inThe expiration time of the access token in seconds86400 Yes

Errors

FieldDescriptionSample valueField typeMandatory?
errorAn error has occurred, such as an invalid parameterinvalid_request
invalid_client
invalid_grant
StringYes
errorMessageCustom error message used to assist in logging and issue investigation StringYes

JWK endpoint response

We’ll share a URL where you can fetch JWKs to use for verification. For example: GET : https:// <WLT_Domain>/keys/public-keys --header Authorization : Bearer - Partner_client_api_key

FieldDescription
algSignature algorithm
ktyCrypto key type
kidKey identifier
useHow the key is meant to be used: for signature (sig) or encryption (enc)
x5tX.509 certificate thumbprint
x5cX.509 certificate chain
expires_onCertificate expiration date

Request signing

We recommend that every API request be signed using a JSON web token (JWT). The steps for signing requests are:

  1. We’ll set up 2048 bit CA signed RSA private key.
  2. We’ll publish the public certificate via a JWK URL (as mentioned above).
  3. We’ll then create a JWT token with issuer, subject, audience, and expiration claims and sign the token using the private key.
  4. The Expedia JWT token will have the key identifiers kid and x5t, which contain the public key certificate’s thumbprint.
  5. When performing an API call, you’ll extract the JWT from the authorization headers and validate the JWT signature using Expedia’s public key. You’ll identify the key (in case multiple keys are present in Expedia’s JWK URL) using the kid header.
  6. Next, you’ll schedule an API call to Expedia’s JWK endpoint to fetch the public key certificate.
  7. You should also use retry logic to fetch new certificate if the signature validation fails.
Did you find this page helpful?
How can we improve this content?
Thank you for helping us improve!