The Checkout Experience Backend project is a reference implementation that allows merchants to connect to Bold Checkout APIs with their custom checkout user interfaces.
It provides the following capabilities:
- Initialize and resume Bold Checkout orders.
- Serve the base HTML pages that will host your checkout user interface. These are ready-populated with all the necessary data, script, and stylesheet tags that a checkout user interface will need.
- Serve multiple stores from a single instance.
In order to run this project, you will need:
- php@8.1 with Laravel 9.
- Composer
- A MySQL database server.
- A store on a supported commerce platform, with Bold Checkout installed.
- A Bold Account Center account, associated with your store.
- A Bold Developer Portal account. This will be used to generate the OAuth Credentials required for checkout-experience-back-end to communicate with Bold Checkout.
- A publicly-accessible URL where your server will be hosted, referred to as
<YOUR_PUBLIC_SERVER_URL>
in the rest of this documentation.
-
Clone and install the dependencies:
git clone git@git-lab.boldapps.net:bold-checkout/checkout-experience-back-end.git cd checkout-experience-back-end composer install
-
Create a
.env
file from the sample file:cp .env.example .env
-
Generate key by running following command:
./artisan key:generate
-
Update the
.env
file and add following values:CHECKOUT_API_PATH=checkout CHECKOUT_API_ENVIRONMENT=https://api.boldcommerce.com APP_URL=<YOUR_PUBLIC_SERVER_URL>
The checkout-experience-back-end requires a MySQL server for persistence.
- Connect to the MySQL server.
- Create a new database.
- In the
.env
file, enter the following information:DB_DATABASE
- The database name.DB_USERNAME
- The database username.DB_PASSWORD
- The database password.DB_HOST
- The database host name.DB_PORT
- The database port.
- Run
./artisan migrate
from the project's root directory to configured the newly created database.
- Navigate to Developer Dashboard and log in. Create an account if necessary.
- Once logged in, create your API credentials.
- Name the set of credentials. Enter
<YOUR_PUBLIC_SERVER_URL>/api/authorize
in theRedirect_uris
field. - Once the credentials are created, copy the following values into your
.env
file:client_id
into theDEVELOPER_CLIENT_ID
variable.client_secret
into theDEVELOPER_CLIENT_SECRET
variable.redirect_uris
into theDEVELOPER_REDIRECT_URL
variable without quotes or brackets.
- Run
./artisan serve
from the root directory of the project. - If the project is running locally, it will also need to expose the server to the public internet using a tunnel tool of your choice (ngrok, cloudflare tunnels, etc.).
- In a browser, navigate to
<YOUR_PUBLIC_SERVER_URL>/install
. - Click install. This redirects to Bold Account Center.
- Login to your Bold Account Center account.
- If the account has multiple stores, select the store you wish to install the server on and click continue. Otherwise, continue to the next step.
- In the prompt to install Bold Checkout on the store, review the permissions and click approve. If successfully installed, you should see a JSON response beginning with
{"message":"Shop install successful"...}
.
Storefront override is platform specific, which means that every ecommerce platform has a unique implementation.
We have provided a sample BigCommerce example, as well as general best practices to redirect the store's default checkout to the overriding Bold Checkout.
Please follow the steps below to redirect the BigCommerce checkout to the new checkout override:
- Login to the store's BigCommerce admin portal.
- Go to Storefront -> Script Manager and create a new script with following values:
- Name of script - The unique script name.
- Description - A brief description.
- Location - Select
Head
option. - Select pages where script will be added - Select
Store pages
option. - Script category - Select
Essential
option. - Script Type - Select
Script
option. - Script Content - Script Content - An example script can be found at
resources/assets/bigcommerce/installation.js
. UpdateCUSTOM_CHECKOUT_INIT_URL
to match with your<YOUR_PUBLIC_SERVER_URL>
.
Once done, you can test by clicking on the BigCommerce checkout button. It should be redirecting to the new Checkout backend override.
This general approach will help you create a script depending on the platform.
- First, construct a URL that points to
<YOUR_PUBLIC_SERVER_URL>/experience/init/<SHOP_DOMAIN>
.- Replace
<SHOP_DOMAIN>
with the domain used when installing Bold Checkout on your store. - Include the appropriate query parameters (see below).
- Replace
- Update your storefront’s checkout buttons to use this new URL. The exact method to do this will depend on your platform and storefront implementation.
There are two main variations of query parameters that are supported:
-
The initialization variant creates a new order for the specified cart. This is typically desired for your storefront’s cart page or mini-cart:
Parameter Type Description cart_id
string The ID of the cart on your commerce platform. The exact structure of this string will vary by platform. return_url
string Configures where any “return-to-cart/store” links on the checkout will point to. Note: If this is excluded, these links will be broken. checkout_local_time
number (optional) A tool for tracking performance metrics. If included, it should be the current unix timestamp. customer_id
string (optional) The ID of the customer on your commerce platform. Including this will cause checkout to be initialized as the user, allowing access to their saved customer information (addresses, payment methods, etc.). Note: This project does not verify any customer information. All the authentication should be done on the platform. user_access_token
string (optional) The access token for authenticated user. Optional on most platforms right now but required if user is authenticated. -
The resume variant resumes an order that is already in progress. This variant is useful for custom communication (e.g. a custom abandoned cart email with a link to resume an order.)
Parameter Type Description public_order_id
string The public order ID of the Bold Checkout order you wish to resume. return_url
string Configures where any “return-to-cart/store” links on the checkout will point to. Note: If this is excluded, these links will be broken. checkout_local_time
number (optional) A tool for tracking performance metrics. If included, it should be the current unix timestamp. customer_id
string (optional) The ID of the customer on your commerce platform. Including this will cause checkout to be initialized as the user, allowing access to their saved customer information (addresses, payment methods, etc.). Note: This project does not verify any customer information. All the authentication should be done on the platform. user_access_token
string (optional) The access token for authenticated user. Optional on most platforms right now but required if user is authenticated.