/saleor-checkout

The first fully open source and production-ready checkout experience.

Primary LanguageTypeScript

saleor-checkout

Extensible, checkout and payment integrations powered by Saleor API.

Setup

This monorepo uses PNPM as a package manager and Turborepo for building packages.

Monorepo structure

Here's the list of each app and shared package in the monorepo (click to see a README of that project)

Apps

  • apps/checkout: an SPA React 18 checkout app, ready to be extended/modified
  • apps/checkout-app: an Next.js Saleor app with dashboard for managing settings and theme, backend for checkout SPA, ready to be extended/modified

Packages

  • packages/ui-kit: UI kit for checkout and React Storefront
  • packages/config: eslint configurations (includes eslint-config-next and eslint-config-prettier)
  • packages/tsconfig: tsconfig.jsons used throughout the monorepo

Install dependencies

pnpm i

Build

To build all apps and packages, run the following command:

pnpm run build

You can also build a specific app or package by running this command:

pnpm run build:checkout

In this example, we'll only build apps/checkout

Develop

Create a tunnel for checkout-app:

cd apps/checkout-app && npx saleor app tunnel 3000

Note: the process needs to be running in the background

Before you start the server, you need to change default environment variables. Create .env.local file in each app:

To run the development server for all the apps, use the following command:

pnpm run dev

You can also run only a specific app by running this command:

cd apps/checkout && pnpm dev

Deployment

GraphQL Schema

To generate GraphQL code based on latest schema from Saleor instance defined in SALEOR_API_URL env variable run this command:

pnpm run generate

You need to run this command after each change in *.graphql files

Env variables

Change environment variables inside .env file:

  • SALEOR_API_URL — GraphQL endpoint of your Saleor

    Example:

    https://my-env.eu.saleor.cloud/graphql/
    

    To run sandbox Saleor environment in Saleor Cloud use this command:

    npx saleor project create && npx saleor environment create

    You can also run Saleor locally. See Saleor docs for more instructions

  • CHECKOUT_APP_URL — URL of deployed Checkout App

    Example:

    https://saleor-checkout-app.vercel.app
    

    See guide below on how to deploy the Checkout App

There are more environment variables available in each app. Go to their README's to learn more

Vercel

The repo needs to be hosted on GitHub or some other git repository. Before you start, fork the repo to your account or organization.

  • Authenticate the Turborepo CLI with your Vercel account
pnpm dlx turbo login
  • Link the repo to a Vercel scope to enable the Remote Caching feature
pnpm dlx turbo link

Remote Caching drastically reduces build times if you work in a team. Learn more about it at Turborepo documentation and Vercel documentation

Checkout App

  1. Start creating new project on Vercel and select your forked GitHub repo

Note: Vercel now doesn't support importing the entire monorepo, you will need to set up a project yourself for each app inside /apps folder

Create project on Vercel by selecting your cloned GitHub repository in the menu

  1. From the configuration page:
  • Provide your project name (for example saleor-checkout-app)
  • Select framework to Next.js
  • Choose the root directory to be apps/checkout-app
  • Override the build command to:
cd ../.. && pnpm run build:checkout-app
  • Add environment variables:
    • SETTINGS_ENCRYPTION_SECRET — Random string used for encrypting apps configuration (you can generate it using openssl rand -hex 256)
    • Optional: NEXT_PUBLIC_SALEOR_API_URL — if you want to override the value of SALEOR_API_URL stored inside .env file in the root of the repository

Here's the final result on configuration page:

Vercel "Configure project" page with all settings filled out

Click deploy and wait until the app is deployed

  1. Update environment variables in repository

Update CHECKOUT_APP_URL in .env file located at the root of monorepo to be your deployment URL

Example:

https://saleor-checkout-app.vercel.app
  1. Install the app in Saleor

Grab the deployed app URL from Vercel and add /api/manifest. This URL points to the manifest file that is required for installing the app in Saleor

Example manifest URL:

https://saleor-checkout-xyz-myusername.vercel.app/api/manifest

You can install the app by using:

http://<YOUR_SALEOR_URL>/dashboard/apps/install?manifestUrl=<YOUR_MANIFEST_URL>
saleor app install

PROTIP 💡: If you want your app to automatically update whenever you push changes to the main branch, make sure to use production domain from Vercel (not deployment domain) for your manifest URL.

❌ Deployment domain (won't update app after push):

https://saleor-checkout-app-jluy793b2-myusername.vercel.app/api/manifest

✅ Production domain:

https://saleor-checkout-app.vercel.app/api/manifest

To see which domain is used for production go to Vercel Dashboard > Settings > Domains: Vercel dashboard settings page that shows which domain is connected to production deployment

  1. Generate app token

After the app was installed, generate it's authToken

saleor app token
mutation {
  appTokenCreate(input: { name: "Vercel", app: "<MY_APP_ID>" }) {
    authToken
  }
}

Where <MY_APP_ID> is the app id. You can retrieve the id by using this GraphQL query:

query {
  apps(first: 10) {
    edges {
      node {
        id
        name
      }
    }
  }
}

outputs this:

{
  "data": {
    "apps": {
      "edges": [
        {
          "node": {
            "id": "QXBwOjQ=", // <- this is the app id
            "name": "Checkout"
          }
        }
      ]
    }
  }
}
  1. Update environment variables in Vercel

You have to add additional environment variables for Checkout App in Vercel:

  • SALEOR_APP_TOKEN — Token you've just generated

🚨 These values are secrets — don't store them inside your git repository

Make sure that you also have "Automatically expose System Environment Variables" selected

Here's how the configuration should look like in the end: Vercel env variable final configuration

After you're done, re-deploy the app

⚠️ Make sure that you didn't select the "Redeploy with existing Build Cache." option

  1. 🥳 Congrats! Payment app is now ready to be used!

Checkout SPA

  1. Start by creating another project on Vercel, just like we did in Checkout App setup, select the same repository

  2. On the configuration page:

  • Provide your project name (for example saleor-checkout)
  • Select framework to Create React App
  • Choose the root directory to be apps/checkout
  • Override the build command to:
cd ../.. && pnpm run build:checkout
  • Optional: customise environment variables:
    • REACT_APP_CHECKOUT_APP_URL — URL of the deployed Checkout App.
    • REACT_APP_SALEOR_API_URL — URL of Saleor GraphQL API endpoint

By default, those environment variables are taken from .env file in root of the monorepo. You don't need to provide env variables in Vercel if you want to use the values from .env file.

Here's the final result on configuration page:

Vercel "Configure project" page with all settings filled out for Checkout frontend deployment

Click deploy and wait until the app is deployed

Payment gateways configuration

Checkout app supports two payment gateways that you can configure:

Mollie

Adyen

Payment gateways can be configured in the Checkout app inside Saleor dashboard. Go to Apps > Third party apps > Checkout.

You can toggle, which payment gateway handles each different payment options per channel:

Configuration options: Credit Card, Apple Pay, PayPal that are available in checkout app dashboard

To use payment gateway, you need to provide its credentials. You can do that by clicking settings icon in channel configuration page

Payment gateway configuration in Saleor dashboard

Mollie

  1. Sign up for Mollie account

  2. In your Mollie dashboard, select: Developers > API keys and copy API key and Profile ID

  • Live API key - for production environment
  • Test API key - for development environment
  1. In Checkout app configuration, enter the data you've just copied

Mollie config inside Saleor dashboard after env variable and profile id were pasted

  1. Enable Payment methods in your Mollie dashboard, select: Settings -> Website Profiles -> Payment methods

Adyen

Saleor Checkout uses Adyen's Pay by Link flow

  1. Sign up for Adyen test account

  2. In test Customer Area create new merchant account

  3. Create new API credentials. Go to Developers > API credentials > Create new credential

Select "Web service user" and enter some description (for example "Saleor Checkout")

Setup Adyen API credentials modal in Customer Area

  1. Copy API key from newly generated API credentials and paste it in Checkout app configuration > Adyen > Private API key

Copy API key from Adyen Customer Area

Paste API key in Checkout app configuration

  1. Click "Generate client key" and copy it to clipboard, paste it in Checkout app configuration > Adyen > Public client key

Copy client key from Adyen's Customer Area

Paste client key in Checkout app configuration

  1. Add allowed origin to your Client key, paste URL of your deployed Checkout SPA and click "Add"

Pasted deployed URL of Checkout SPA in client key's allowed origin

  1. Save changes you've made to API credential

  2. Create standard notification webhook. Go to Developers > Webhooks > "+ Webhook" > "Standard notification"

Creating new Standard notification webhook in Adyen portal

Fill out the webhook details:

  • Description - enter some description for your webhook (ex. Saleor Checkout notifications)
  • Server configuration
    • URL - URL of your deployed Checkout App + /api/webhooks/adyen
<YOUR_CHECKOUT_APP_URL>/api/webhooks/adyen
  • Other settings should be set to default:
    • Method: JSON
    • SSL version: TLSv1.2
    • Service version - 1

Webhook Server configuration config

  • Merchant accounts - choose "Include only specific merchant accounts" and select the merchant account you'll use for checkout, the name must be provided in Checkout App configuration

Webhook Merchant accounts configuration

Merchant account configuration in Checkout app settings

  • Events - leave events selected by default
  • Security
    • Basic authentication - arbitrary username and password, you can use openssl rand -hex 64 to generate random password
    • HMAC Key - click "Generate" and copy the key
    • Those 3 values: username, password and HMAC Key must be provided in Checkout App configuration

This is how your webhook configuration should look like in Adyen:

Final adyen webhook configuration

This is how your Checkout App configuration should look like in Saleor dashboard:

Final checkout app configuration in Saleor dashboard

  1. Save settings in Adyen and in Checkout App configuration

  2. Test webhook configuration in Adyen

Click "Test configuration" button after you've saved the configuration.

Select "AUTHORISATION" from the list and click "Test"

Selecting what webhook event should be sent to Checkout App

Adyen will make a call to your webhook. If everything is configured properly you'll see that the test was successful:

Successful webhook test in Adyen

Note: It can take a while for your webhook configuration to propagate in Adyen after you save it. If the test failed, give it a few minutes before you try again

If the response failed because of invalid configuration in Adyen, Checkout App will return the reason in response:

Failed test because of invalid HMAC Key

  1. After you've tested your webhook, enable it, by clicking the toggle button

Enabling the webhook in Adyen

  1. 🥳 Congrats! You've finished configuration of Adyen payment gateway