
Security News
/Research
Popular node-ipc npm Package Infected with Credential Stealer
Socket detected malicious node-ipc versions with obfuscated stealer/backdoor behavior in a developing npm supply chain attack.
@optimizely/cms-cli
Advanced tools
The official command-line tool for Optimizely CMS that enables code-first content modeling. Sync your TypeScript content type definitions to Optimizely CMS, allowing you to manage content models alongside your code with full version control.
Install as a development dependency:
npm install -D @optimizely/cms-cli
Or using other package managers:
# pnpm
pnpm add -D @optimizely/cms-cli
# yarn
yarn add -D @optimizely/cms-cli
Tip: You can also use
npx @optimizely/cms-clito run commands without installing the package.
Create a .env file in your project root with your CMS credentials:
OPTIMIZELY_CMS_URL=https://your-cms-instance.com
OPTIMIZELY_CMS_CLIENT_ID=your-client-id
OPTIMIZELY_CMS_CLIENT_SECRET=your-client-secret
Create TypeScript definitions for your content models:
import { contentType } from '@optimizely/cms-sdk';
export const ArticlePage = contentType({
key: 'Article',
displayName: 'Article page',
baseType: '_page',
properties: {
title: {
displayName: 'Title',
type: 'string',
},
subtitle: {
type: 'string',
displayName: 'Subtitle',
},
body: {
displayName: 'body ',
type: 'richText',
},
},
});
Run the CLI to push your definitions to Optimizely CMS:
# If installed as a dependency
pnpm exec optimizely-cms-cli config push ./optimizely.config.mjs
# Or using npx without installation
npx @optimizely/cms-cli config push ./optimizely.config.mjs
All commands can be run using either the installed CLI or via npx @optimizely/cms-cli.
Sync your TypeScript content type definitions with Optimizely CMS:
# Push content types to CMS (reads ./optimizely.config.mjs from project root by default)
optimizely-cms-cli config push
# or: npx @optimizely/cms-cli config push
# Push with custom config file path
optimizely-cms-cli config push ./path/to/custom-config.mjs
# Force update (may result in data loss)
optimizely-cms-cli config push --force
# Pull content types from CMS and generate TypeScript files (prompts for options)
optimizely-cms-cli config pull
# With output directory specified
optimizely-cms-cli config pull --output ./src/content-types
# Group generated files by content type base type (page/, component/, section/, etc.)
optimizely-cms-cli config pull --output ./src/types --group
# Output raw JSON manifest (useful for piping/processing)
optimizely-cms-cli config pull --json
# Save raw JSON manifest to file (automatically detects redirection)
optimizely-cms-cli config pull > manifest.json
# Or explicitly specify JSON output
optimizely-cms-cli config pull --json > manifest.json
# Pipe JSON output to other commands (automatically detects piping)
optimizely-cms-cli config pull | jq .contentTypes
optimizely-cms-cli config pull | grep -i "Article"
# Include read-only system content types
optimizely-cms-cli config pull --include-read-only
Note: The command automatically detects when output is piped or redirected and outputs JSON without prompting. You can also explicitly use
--jsonto force JSON output. The--outputflag works in all environments, including CI/non-TTY contexts.
Note: Use
--include-read-onlyto pull all content types including system-generated read-only types. By default, only user-editable content types are pulled. This flag is useful for:
PaaS environments where content types may be created from C# or .NET applications
Auditing or understanding the full CMS content type schema
Generating TypeScript types for content types in CMS managed by other systems like CMP
Note that read-only types cannot be modified via the CLI or CMS REST API.
Note: When using
--group:
- Display templates are co-located with their content types in the same file
- Orphaned display templates (without a matching content type) are placed in the
displayTemplates/directorySee File Organization below for detailed examples.
Verify your CMS credentials are correctly configured:
# Test your credentials from environment variables
optimizely-cms-cli login
# Show detailed authentication output
optimizely-cms-cli login --verbose
Manage individual content types:
# Delete a specific content type
optimizely-cms-cli content delete ArticlePage
# Delete with custom host
optimizely-cms-cli content delete ProductPage --host https://example.com
β οΈ Use with extreme caution - these commands are destructive:
# Delete ALL user-defined content types (interactive confirmation required)
optimizely-cms-cli danger delete-all-content-types
# Show all available commands
optimizely-cms-cli --help
# Show help for a specific command
optimizely-cms-cli config push --help
# Show help for a topic
optimizely-cms-cli config --help
When pulling content types from CMS, the CLI generates TypeScript files with different organization strategies:
--group flag (default)src/content-types/
βββ ArticlePage.ts
βββ ProductPage.ts
βββ HeroComponent.ts
βββ display-templates/
βββ ArticleDisplayTemplate.ts
βββ HeroDisplayTemplate.ts
--group flagOrganizes files by content type base type (_page, _component, _section, etc.) and co-locates display templates with their content types:
src/types/
βββ page/
β βββ ArticlePage.ts # Contains ArticlePageCT + ArticleDisplayTemplateDT
β βββ ProductPage.ts # Contains ProductPageCT + ProductDisplayTemplateDT
βββ component/
β βββ HeroComponent.ts # Contains HeroComponentCT + HeroDisplayTemplateDT
β βββ Teaser.ts # Contains TeaserCT + TeaserDisplayTemplateDT
βββ section/
β βββ ContentSection.ts # Contains ContentSectionCT + ContentSectionDisplayTemplateDT
βββ displayTemplates/ # Only created if orphaned templates exist
βββ LegacyTemplate.ts # Display templates with no matching content type
Example co-located file (page/ArticlePage.ts):
import { contentType, displayTemplate } from '@optimizely/cms-sdk';
/**
* Article Page
*/
export const ArticlePageCT = contentType({
key: 'ArticlePage',
baseType: '_page',
properties: {
/* ... */
},
});
/**
* Article Display Template
*/
export const ArticleDisplayTemplateDT = displayTemplate({
key: 'ArticleDisplayTemplate',
contentType: 'ArticlePage',
isDefault: true,
});
Benefits of grouping:
For comprehensive guides and best practices:
This CLI tool works best when used alongside the @optimizely/cms-sdk for a complete type-safe development experience:
# Install both packages
npm install @optimizely/cms-sdk
npm install -D @optimizely/cms-cli
The typical workflow:
For complete setup instructions, see the main repository README.
Apache License 2.0
Built by the Optimizely CMS Team | Documentation | GitHub
FAQs
CLI application for integration with Optimizely CMS
The npm package @optimizely/cms-cli receives a total of 376 weekly downloads. As such, @optimizely/cms-cli popularity was classified as not popular.
We found that @optimizely/cms-cli demonstrated a healthy version release cadence and project activity because the last version was released less than a year ago.Β It has 1 open source maintainer collaborating on the project.
Did you know?

Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.

Security News
/Research
Socket detected malicious node-ipc versions with obfuscated stealer/backdoor behavior in a developing npm supply chain attack.

Security News
TeamPCP and BreachForums are promoting a Shai-Hulud supply chain attack contest with a $1,000 prize for the biggest package compromise.

Security News
Packagist urges PHP projects to update Composer after a GitHub token format change exposed some GitHub Actions tokens in CI logs.