npm package discovery and stats viewer.

Discover Tips

  • General search

    [free text search, go nuts!]

  • Package details

    pkg:[package-name]

  • User packages

    @[username]

Sponsor

Optimize Toolset

I’ve always been into building performant and accessible sites, but lately I’ve been taking it extremely seriously. So much so that I’ve been building a tool to help me optimize and monitor the sites that I build to make sure that I’m making an attempt to offer the best experience to those who visit them. If you’re into performant, accessible and SEO friendly sites, you might like it too! You can check it out at Optimize Toolset.

About

Hi, 👋, I’m Ryan Hefner  and I built this site for me, and you! The goal of this site was to provide an easy way for me to check the stats on my npm packages, both for prioritizing issues and updates, and to give me a little kick in the pants to keep up on stuff.

As I was building it, I realized that I was actually using the tool to build the tool, and figured I might as well put this out there and hopefully others will find it to be a fast and useful way to search and browse npm packages as I have.

If you’re interested in other things I’m working on, follow me on Twitter or check out the open source projects I’ve been publishing on GitHub.

I am also working on a Twitter bot for this site to tweet the most popular, newest, random packages from npm. Please follow that account now and it will start sending out packages soon–ish.

Open Software & Tools

This site wouldn’t be possible without the immense generosity and tireless efforts from the people who make contributions to the world and share their work via open source initiatives. Thank you 🙏

© 2026 – Pkg Stats / Ryan Hefner

@contentful/optimization-core

v0.1.0-alpha14

Published

<p align="center"> <a href="https://www.contentful.com/developers/docs/personalization/"> <img alt="Contentful Logo" title="Contentful" src="https://raw.githubusercontent.com/contentful/optimization/v0.1.0-alpha14/contentful-icon.png" width="150">

Readme

Guides · Reference · Contributing

[!WARNING]

The Optimization SDK Suite is pre-release (alpha). Breaking changes can be published at any time.

The Optimization Core SDK owns the platform-agnostic optimization state machine, event builders, queues, resolvers, and interceptors used by the application-facing SDKs. Web, React Web, Node, React Native, and native bridge layers build on this package.

We recommend starting application code with a platform SDK rather than Core directly. Use this README when building or maintaining SDK layers, and use Choosing the right SDK when deciding which application-facing package belongs in an integration. Generated reference documentation remains the source of truth for exported API signatures.

Getting started

Install using an NPM-compatible package manager, pnpm for example:

pnpm install @contentful/optimization-core

Choose the stateful or stateless Core class based on the runtime layer you are building:

import { CoreStateful, CoreStateless } from '@contentful/optimization-core'

const statefulOptimization = new CoreStateful({ clientId: 'your-client-id' })
const statelessOptimization = new CoreStateless({ clientId: 'your-client-id' })

Stateful runtimes own durable in-process SDK state. Stateless runtimes bind request-scoped consent, profile state, event context, and Experience API options before calling event methods:

const requestOptimization = statelessOptimization.forRequest({
  consent: true,
  eventContext: { locale: 'en-US' },
  experienceOptions: { locale: 'de-DE', preflight: false },
  profile: { id: 'profile-id' },
})

await requestOptimization.page()

When to use this package

Use @contentful/optimization-core when you are building or maintaining an SDK layer that needs the shared optimization state machine, event builders, queueing, resolvers, or interceptors. Most application code uses a platform SDK such as Web, React Web, Node, or React Native instead of depending on Core directly.

Core variants

Stateful Core

CoreStateful is the basis for SDKs that run in stateful JavaScript runtimes such as browsers, mobile JavaScript containers, and native bridge runtimes. It maintains consent, profile, selected optimization, flag, event-stream, blocked-event, and preview-panel state as read-only observables.

[!IMPORTANT]

CoreStateful uses module-global state by design. Initialize exactly one stateful instance per JavaScript runtime and reuse it.

Stateless Core

CoreStateless is the basis for SDKs that run in stateless environments such as Node servers and server-side functions. It does not store consent or profile state between requests. Consumers call forRequest() to create a request-bound event client with the consent, profile, event context, and Experience options for that one incoming request.

Common configuration

Shared Core configuration:

| Option | Required? | Default | Description | | -------------- | --------- | --------------------- | ----------------------------------------------------------- | | clientId | Yes | N/A | Shared API key for Experience API and Insights API requests | | environment | No | 'main' | Contentful environment identifier | | api | No | See API options below | Experience API and Insights API endpoint options | | eventBuilder | No | SDK-layer defaults | Event metadata overrides for platform SDK authors | | fetchOptions | No | SDK defaults | Fetch timeout and retry behavior | | logLevel | No | 'error' | Minimum log level for the default console sink |

Consent and event configuration:

| Option | Required? | Default | Description | | ------------------- | --------- | ----------- | ------------------------------------------------------------ | | allowedEventTypes | No | [] | Event types allowed before consent is explicitly set | | onEventBlocked | No | undefined | Callback invoked when consent or guard logic blocks an event |

Core itself fails closed before consent. Platform SDKs set runtime-specific defaults for the event types that make sense in that runtime, such as browser identify/page, server identify/page, and mobile identify/screen.

Stateful-only configuration:

| Option | Required? | Default | Description | | ---------------- | --------- | ------------ | --------------------------------------------------------------------------------- | | defaults | No | undefined | Initial state, commonly including consent, persistence consent, or profile values | | getAnonymousId | No | undefined | Function used to provide an anonymous ID from application-owned identity state | | queuePolicy | No | SDK defaults | Flush retry behavior and offline queue bounds |

Persistence consent controls durable profile-continuity storage for SDKs with runtime storage: profile, anonymous ID, changes, and selected optimization caches. Event consent, stored consent decisions, and debug state are tracked separately.

Common api options:

| Option | Applies to | Default | Description | | ------------------- | ---------- | ------------------------------------------ | ----------------------------------------------- | | experienceBaseUrl | All | 'https://experience.ninetailed.co/' | Base URL for the Experience API | | insightsBaseUrl | All | 'https://ingest.insights.ninetailed.co/' | Base URL for the Insights API | | enabledFeatures | All | ['ip-enrichment', 'location'] | Experience API features for each request | | beaconHandler | Stateful | undefined | Custom handler for enqueueing Insights batches | | ip | Stateful | undefined | IP address override for Experience API analysis | | locale | Stateful | API default | Locale query parameter for localized responses | | plainText | Stateful | false | Sends performance-critical endpoints as text | | preflight | Stateful | false | Aggregates a profile state without storing it |

In stateless environments, pass ip, locale, plainText, and preflight as experienceOptions when creating the request-bound client instead of constructor config.

Core-backed stateful SDKs can accept contentfulLocales, an initial app/content locale, and runtime setLocale(locale) calls. They expose the resolved Contentful locale through the live locale getter and states.locale observable. The stateful api.locale config remains an explicit Experience API override; otherwise stateful SDK layers use the current resolved Contentful locale for Experience API localization. Stateless server SDKs should pass the request-scoped Contentful locale as the per-call { locale } option.

contentfulLocales.default and optional contentfulLocales.supported values should use the locale codes configured in Contentful locale settings or returned by the CMA locale list. The resolved value remains the configured Contentful locale code because that code is the API identifier used for CDA requests. For configuration cases, matching rules, and runtime-specific locale sources, see Locale handling in the Optimization SDK Suite.

Common fetchOptions are fetchMethod, requestTimeout, retries, intervalTimeout, onFailedAttempt, and onRequestTimeout. Default retries intentionally apply only to HTTP 503 responses.

For every option, callback payload, and exported type, use the generated Core SDK reference.

Package surface

Core exposes reusable primitives for SDK layers:

| Surface | Purpose | | ------------------------------- | ---------------------------------------------------------------------- | | CoreStateful | Stateful optimization runtime for browser, mobile, and bridge SDKs | | CoreStateless | Stateless optimization runtime for server SDKs | | Event methods | identify, page, screen, track, trackView, trackClick, etc. | | Resolution helpers | resolveOptimizedEntry, getMergeTagValue, and getFlag | | states | Stateful observable state streams | | Interceptors | First-party hooks for event and state lifecycle customization | | Queue policy and fetch helpers | Shared retry, flush, timeout, and offline buffering behavior | | Signal and observable utilities | Lightweight reactive primitives used internally by stateful SDK layers |

Resolution helpers expect Contentful entries fetched by the app layer with one CDA locale. Use the resolved SDK locale, withOptimizationLocale(contentfulClient), or the Node SDK's resolveRequestLocale() result before resolving entries. Do not pass all-locale CDA responses from withAllLocales or locale=*; optimization fields such as fields.nt_experiences and fields.nt_variants must be direct single-locale field values. See Entry personalization and variant resolution for the entry contract and Locale handling in the Optimization SDK Suite for the broader locale model.

The generated reference owns method arguments, return types, callback payload shapes, and inherited members. Keep this README focused on package role and maintainer orientation.

Preview support

Preview-panel helpers live under the internal preview-support entry. They are used by first-party preview surfaces to register preview state bridges, apply optimization overrides, and map Contentful entries for local authoring workflows.

Application code must not use preview support directly unless it is building a first-party preview surface.

Related