Set up the TypeScript SDK

Learn how to configure your environment for the TypeScript SDK.

  • After completing this module, you should be able to:

    • Use the TypeScript SDK to work on a Composable Commerce Project.
  • The following instructions help you set up your environment to develop applications with Composable Commerce using the TypeScript SDK.

    To follow along, you'll need:

    • A text editor or preferred TypeScript IDE
    • The Node.js runtime to execute your program code

    Pay special attention to version requirements.

    Install text editor

    In this tutorial, we use Visual Studio Code(VS Code), however, you can use any text editor that you are familiar with.

    In case you don’t have VS Code installed, you can follow the instructions here or use your preferred package manager.

    Check Node.js runtime version

    Next, we need to ensure that we have the Node.js runtime installed. The SDK supports Node.js v12.22.7 (or later). Node.js versions 18 and 20 work for this tutorial.

    To check the current version of Node.js on your computer, run the following command in your terminal:

    node -v

    If the installed version of Node.js is lower than 18, you will need to switch to a newer version. The method you use to do this depends on the initial installation process of Node.js on your computer, whether through NVM, FNM, or another Node.js version manager.

    If you don't have Node.js installed, we recommend using a Node.js version manager to install it. Version managers simplify installing and switching to different versions. The most popular solutions are NVM and FNM. We recommend NVM for this tutorial, as it has higher adoption and more supporting documentation for a large variety of use cases. Chose one of the solutions and follow the instructions to install them:

    Install the SDK

    Let's now install the SDK on your machine.

    Step 1: Create local repository

    Create a new empty folder for a local code repository to install the SDK, and open it in VS Code. We named ours commercetools-environment.

    New empty folder called commercetools environment.

    Now open VS Code and open the new folder: select File > Open Folder > {select your folder} > Open.

    Next, open a terminal in VS Code: select Terminal > New Terminal. The terminal should automatically be pointing to the folder of your new repository. The terminal should display the name of the folder that you created. Make sure you are not located in a subfolder of your repository.

    Terminal showing the new empty folder called commercetools environment.

    Step 2: Initialize the project

    Run the appropriate initialization command based on your chosen package manager:

    Package managerInitialization command
    npmnpm init -y
    pnpmpnpm init -y
    yarnyarn init -y

    Step 3: Run install command

    We now want to install the SDK by running the install command in the terminal. This command differs based on the package manager that you use. By default Node.js comes with npm, alternatively, you can use Yarn or pnpm. If you want to use either of the latter two package managers, you must install them first. If you are unsure, use npm because it comes installed with Node.js.

    In this tutorial, we are working with the Composable Commerce SDK Client package. Use the command that corresponds to your package manager.

    Package managerSDK Client
    npmnpm install @commercetools/ts-client @commercetools/platform-sdk node-fetch dotenv
    pnpmpnpm install @commercetools/ts-client @commercetools/platform-sdk node-fetch dotenv
    yarnyarn add @commercetools/ts-client @commercetools/platform-sdk node-fetch dotenv

    Step 4: Finish setup

    Once we have all of the packages installed, package.json should display three dependencies. To check this, open Explorer within VS Code (Mac Shortcut ⇧⌘E and Windows Shortcut Ctrl+K R) and inspect the files within the project. You should see a new file called package.json.

    Package.json showing all three packages installed.

    Do you see all the packages installed? Great, you are ready to create a Composable Commerce application!

    Test your setup

    Let's now check if the SDK is set up correctly or not. Make sure that you have created an API Client as we mentioned previously before continuing.

    Step 4: Set up an API Client in your SDK

    For the TypeScript SDK, use the following code example to create a file apiClient.js and place it in a folder called /impl.

    import fetch from 'node-fetch';
    import { createApiBuilderFromCtpClient } from '@commercetools/platform-sdk';
    import { ClientBuilder } from '@commercetools/ts-client';
    import 'dotenv/config';
    // --- Configuration ---
    const projectKey = process.env.CTP_PROJECT_KEY;
    const clientId = process.env.CTP_CLIENT_ID;
    const clientSecret = process.env.CTP_CLIENT_SECRET;
    const authUrl = process.env.CTP_AUTH_URL;
    const apiUrl = process.env.CTP_API_URL;
    const scopes = [`manage_customers:${projectKey}`];
    // --- Middleware Functions ---
    // Function for custom header middleware
    function createCustomHeaderMiddleware() {
    return (next) => (request) => {
    return next({
    ...request,
    headers: {
    ...request.headers,
    'accept-language': 'en-AU',
    },
    });
    };
    }
    // Function for custom logger middleware
    const customLoggerMiddleware = {
    logLevel: 'debug',
    httpMethods: ['POST', 'GET'],
    maskSensitiveData: true,
    logger: (method, ...args) => {
    console.log(`[CUSTOM LOGGER] ${method}`, ...args);
    },
    };
    // --- Middleware Options ---
    // Auth Middleware Options
    const authMiddlewareOptions = {
    host: authUrl,
    projectKey: projectKey,
    credentials: { clientId, clientSecret },
    scopes: scopes,
    httpClient: fetch,
    };
    // Http Middleware Options
    const httpMiddlewareOptions = {
    host: apiUrl,
    includeResponseHeaders: true,
    maskSensitiveHeaderData: false,
    includeOriginalRequest: true,
    includeRequestInErrorResponse: true,
    enableRetry: true,
    retryConfig: {
    maxRetries: 3,
    retryDelay: 200,
    backoff: false,
    retryCodes: [500, 503],
    },
    httpClient: fetch,
    };
    // Correlation ID Middleware Options
    const correlationIdMiddlewareOptions = {
    // Replace with your own UUID, ULID, or a generator function. Do not use this example in production!
    generate: () => 'cd260fc9-c575-4ba3-8789-cc4c9980ee4e',
    };
    // Concurrent Modification Middleware Options
    const concurrentModificationMiddlewareOptions = {
    concurrentModificationHandlerFn: (version, request) => {
    console.log(`Concurrent modification error, retry with version ${version}`);
    request.body.version = version;
    return JSON.stringify(request.body);
    },
    };
    // --- Optional Telemetry Middleware (Commented Out) ---
    /*
    const telemetryOptions = {
    createTelemetryMiddleware,
    apm: () => typeof require('newrelic'),
    tracer: () => typeof require('/absolute-path-to-a-tracer-module'),
    };
    */
    // --- Client Creation ---
    const client = new ClientBuilder()
    .withProjectKey(projectKey)
    .withClientCredentialsFlow(authMiddlewareOptions)
    .withLoggerMiddleware(customLoggerMiddleware)
    .withCorrelationIdMiddleware(correlationIdMiddlewareOptions)
    .withMiddleware(createCustomHeaderMiddleware())
    .withHttpMiddleware(httpMiddlewareOptions)
    .withConcurrentModificationMiddleware(concurrentModificationMiddlewareOptions)
    // .withTelemetryMiddleware(telemetryOptions)
    .build();
    // --- API Root Creation ---
    const apiRoot = createApiBuilderFromCtpClient(client).withProjectKey({
    projectKey,
    });
    export { apiRoot };

    Create a file in the root directory called .env. Inside the file paste the environment variables from the API Client. Now our apiClient.js can read the secrets from this environment variables file.

    Merchant Center new API client screen with manage customers scope selected.

    Step 5: Fetch the Customer data

    Now let's use our API Client to make the first call to the Composable Commerce API. We can use a temporary file and discuss a proper project structure separately.

    Create a file called customerFetch.js in the root folder. Copy the following code snippet and make sure to update the Customer ID.

    import { apiRoot } from '../impl/apiClient.js'; // Update to map to your Import API root
    const customerId = 'ded97f0d-a0bc-4478-b0f5-cf04932cf65c';
    async function customerFetchById(customerId) {
    try {
    const response = await apiRoot
    .customers()
    .withId({
    ID: customerId,
    })
    .get()
    .execute();
    console.log('Success', JSON.stringify(response.body, null, 2));
    } catch (error) {
    console.log(JSON.stringify(error, null, 2));
    }
    }
    customerFetchById(customerId);

    Step 6: Execute the code

    Now it is time to execute the code by running the following command in the terminal:

    node customerFetch.js

    Ta-da! We have fetched the customer!

    Customer successfully fetched.

    This self-learning module has taken you through the basics of setting up the SDK. You can find additional information on this process in our Get started with the TypeScript SDK page in the docs.

    To get the most from the TypeScript SDK, follow the TypeScript SDK best practices guide.