Skip to main content
Sitecore Documentation
  • Learn
  • Downloads
  • Changelog
  • Roadmap
PersonalizeCloud Portal
Sitecore Personalize developer documentation
  • Developing with Sitecore Personalize
        • Integrate using the Engage SDK script and Google Tag Manager
        • Integrate using the Engage SDK script
        • Integrate a React app using the Engage SDK package
        • Integrate a Next app using the Engage SDK package (client-set cookies)
        • Integrate a Next.js app using the Engage SDK package (server-set cookies)
        • Integrate using direct HTTP requests
        • Upgrade from the Boxever JavaScript Library to the Engage SDK
    • IP allowlists
  1. Walkthroughs for integrating
  1. Walkthroughs for integrating

Integrate a Next.js app using the Engage SDK package (server-set cookies)

Note

If your organization has a JSS Next.js or a JSS Angular application connected to SitecoreAI, implement Sitecore Personalize-related functionality on your SitecoreAI site using the Sitecore Cloud SDK instead. See also a comparison of the Cloud SDK and the Engage SDK.

This topic explains how to integrate your Next.js app using the Engage SDK package. In this walkthrough, you'll use server-set cookies. We assume that you are using the src folder, but you don't have to.

This walkthrough describes how to:

  1. Install and initialize @sitecore/engage on the server side.

  2. Initialize @sitecore/engage on the client side.

  3. Send your first VIEW event.

  4. Verify that Sitecore Personalize captured your VIEW event.

Before you begin
  • Collect the required details about your Sitecore Personalize instance.

  • Have a Next.js app to integrate. This walkthrough was tested on Next.js versions 12, 13, and 14.2.5, both for the Pages Router and the App Router.

Install and initialize @sitecore/engage on the server side

The first step to integrating your app is to install and initialize the @sitecore/engage package in your web server. This step involves setting cookies from the server and sending them to the client.

To install and initialize the package on the server side:

  1. In your terminal, open the root folder of your Next.js app.

  2. Install the Engage SDK by running the following command:

    npm install @sitecore/engage
  3. In your code editor, open the root folder of your Next.js app.

  4. In the src folder, create a file called middleware.js.

  5. In middleware.js paste the following code:

    import { NextResponse } from 'next/server';
    import { initServer } from '@sitecore/engage';
    
    export async function middleware(request) {
      const response = NextResponse.next();
    
      try {
        const engageSettings = {
          clientKey: "<client_key_PLACEHOLDER>",
          targetURL: "<stream_api_target_endpoint_PLACEHOLDER>",
          pointOfSale: "<point_of_sale_PLACEHOLDER>",
          cookieDomain: "<cookie_domain_PLACEHOLDER>",
          cookieExpiryDays: 365,
          forceServerCookieMode: true
        };
    
        const engageServer = initServer(engageSettings);
        await engageServer.handleCookie(request, response);
      } catch (error) {
        console.error(error);
      }
    
      return response;
    };

    Replace the placeholder values with the required details from your Sitecore Personalize instance.

    Cookie consent

    In production, only load the Engage SDK and set cookies if your site visitor grants consent. See also a code example to check if your site visitor accepts cookies.

    Content Security Policy (CSP)

    To ensure that the Engage SDK script loads, you might have to add the following to your Content Security Policy (CSP):

    • Your Stream API target endpoint.

    • https://d1mj578wat5n4o.cloudfront.net

    • If you run web personalization and your environment is AP Region, EU Region, or US Region:

      https://d35vb5cccm4xzp.cloudfront.net

    • If you run web personalization and your environment is JP Region:

      https://d2ez8k04aaol9g.cloudfront.net

    This script:

    • Initializes the Engage SDK in a middleware function on the server using the initServer() function.

    • Collects the details about your Sitecore Personalize instance and cookie settings in the engageSettings object, and passes the object to the EngageServer.handleEngageCookie() function.

    • Sets cookies from the server.

Initialize @sitecore/engage on the client side

After you have installed and initialized the @sitecore/engage package in your web server, you initialize the package on the client side. This step involves receiving cookies from the server and storing them in the web browser.

To initialize the package on the client side:

  1. Depending on your router type:

    • If using the Pages Router - in the pages folder, in the index.js file, import useEffect from React and init from @sitecore/engage:

      import { useEffect } from "react";
      import { init } from "@sitecore/engage";
    • If using the App Router - in the app folder, in the page.js file, import useEffect from React and init from @sitecore/engage. Also, add the "use client" directive at the top of of the file, above all the imports:

      "use client";
      import { useEffect } from "react";
      import { init } from "@sitecore/engage";
  2. Above the Home() function, create an object called engageSettings:

    const engageSettings = {
      clientKey: "<client_key_PLACEHOLDER>",
      targetURL: "<stream_api_target_endpoint_PLACEHOLDER>",
      pointOfSale: "<point_of_sale_PLACEHOLDER>",
      forceServerCookieMode: true,
      includeUTMParameters: true,
      webPersonalization: true /* boolean or object. See Settings object for all options. */
    };

    Replace the placeholder values with the required details from your Sitecore Personalize instance.

  3. In the Home() function, create an empty, asynchronous function loadEngage(), then call loadEngage() in an Effect Hook. You should use the Effect Hook because the window object has to be present before you load the Engage API. In the next procedure, you'll update the code inside loadEngage() to load the Engage API and start sending VIEW events.

    export default function Home() {
      const loadEngage = async () => {
        // Load Engage API
        // Send VIEW events
      };
        
      useEffect(() => {
        loadEngage();
      }, []);
    
      return (<></>)
    };

Send your first VIEW event

Next, you update the code inside the loadEngage() function to start collecting and sending data to Sitecore Personalize. You'll send a VIEW event because the VIEW event triggers every time your webpage loads.

To send a VIEW event:

  1. In the loadEngage() function, load the Engage API by passing engageSettings to the init() function. The init() function is asynchronous, so you must await the return value.

    const loadEngage = async () => {
      // Load Engage API
      const engage = await init(engageSettings);
    
      // Send VIEW events
    };

    In production, you should call the init() function once, then share it across the app using the state management solution of your choice, for example, React Context or Redux.

  2. In the loadEngage() function, after you load the Engage API, call the engage.pageView() function to send VIEW event data:

    const loadEngage = async () => {
      // Load Engage API
      const engage = await init(engageSettings);  
    
      // Send VIEW events
      engage.pageView({
        channel: "<channel_PLACEHOLDER>",
        currency: "<currency_PLACEHOLDER>"
      });
    };

    Replace the placeholder values with the event details specific to your organization.

  3. In the loadEngage() function, below the engage.pageView() function, for testing and debugging purposes only, log the browser ID to the console:

    const loadEngage = async () => {
      // Load Engage API
      // ...
    
      // Send VIEW events
      // ...
    
      // For testing and debugging purposes only
      console.log("Copy-paste the following line into Sitecore Personalize > Developer center > Event viewer > Search field:");
      console.log(engage.getBrowserId());
    };

    You'll use the browser ID in the next procedure to find the VIEW event in Sitecore Personalize.

  4. In your terminal, enter npm run dev to start your Next.js app. When the webpage loads, the VIEW event triggers and the event data is sent.

Verify that Sitecore Personalize captured your VIEW event

After you have sent a VIEW event, you log in to Sitecore Personalize and find the event.

To verify that Sitecore Personalize captured your VIEW event:

  1. In your web browser's console, find a text similar to:

    a38b230c-11eb-4cf9-8d5d-274e9f344925​

  2. Copy the text.

  3. In Sitecore Personalize, click Developer center > Event viewer, then in the search dropdown, select Browser ID and paste the copied text into the search field. A list of events associated with this guest displays. The list contains a VIEW event. This is the event that was triggered in a previous procedure.

    Note

    If you have both Sitecore CDP and Sitecore Personalize, you can find the data in Guests.

Next steps

You've now successfully integrated your app with Sitecore Personalize. You sent an event from your app and verified that Sitecore Personalize captures data about your users in real time.

Next, you can:

  • Send other behavioral data, for example, an IDENTITY event or a custom event.

  • Send transactional data as the user interacts with products and shopping carts on your site.

  • Run experiences and experiments.

If you have suggestions for improving this article, let us know!

Documentation Assistant

This assistant uses AI to generate responses based on Sitecore documentation. While it has access to official sources, answers may be incomplete or inaccurate and should not be considered official advice or support.
Powered by
k
kapa.ai
Protected by reCAPTCHA

© Copyright 2026, Sitecore A/S or a Sitecore affiliated company.
All rights reserved.

Privacy policySitecore Trust CenterTerms of use