| name | contentful-sdk |
| description | Comprehensive Contentful SDK guide for TypeScript/JavaScript. Covers Management SDK (CMA) for content/schema management, Delivery SDK (CDA) for fetching content, and App Framework SDK for building Contentful apps. Use for any Contentful API integration work. |
Contentful SDK Guide
Comprehensive guide for Contentful SDKs in TypeScript/JavaScript.
Which SDK Do You Need?
- Management SDK (CMA): Creating/updating content, managing content types, assets, environments → Start at references/management/overview.md
- Delivery SDK (CDA): Fetching published content for production apps → Start at references/delivery/overview.md
- App Framework: Building Contentful Apps that extend the UI → Start at references/app-framework/overview.md
Management SDK (CMA)
For creating, updating, and managing content, content types, assets, and environments.
Start here: references/management/overview.md
Topics:
- content-types.md - Define and update content models with field types and validations
- entries.md - Create, update, query, and publish entries with version locking
- assets.md - Upload, process, and publish media files
- environments.md - Create, clone, and manage environments and aliases
- error-handling.md - Handle rate limits, version conflicts, and validation errors
- bulk-operations.md - Pagination, batch processing, and concurrency control
Delivery SDK (CDA)
For fetching published content in production applications.
Start here: references/delivery/overview.md
Topics:
- querying.md - Query parameters, filters, search operators, and pagination
- includes-links.md - Link resolution, includes parameter, and handling references
- localization.md - Locale handling, fallbacks, and multi-language content
- rich-text.md - Rendering rich text fields with embedded entries and assets
App Framework SDK
For building apps that extend the Contentful UI.
Start here: references/app-framework/overview.md
Topics:
- locations.md - All app locations: field, sidebar, dialog, entry editor, page, config
- sdk-apis.md - Navigator, dialogs, notifier, access, and window APIs
- parameters.md - Installation, instance, and invocation parameters
Quick Reference
Version Locking (Management SDK)
Always pass sys when updating to prevent conflicts:
const entry = await client.entry.get({ spaceId, environmentId, entryId })
await client.entry.update({ spaceId, environmentId, entryId }, {
sys: entry.sys, // Required for version locking
fields: { ... }
})
TypeScript Entry Skeletons (Delivery SDK)
Define type-safe content structures:
type BlogPostSkeleton = {
contentTypeId: 'blogPost'
fields: {
title: EntryFieldTypes.Text
slug: EntryFieldTypes.Symbol
body: EntryFieldTypes.RichText
}
}
const entry = await client.getEntry<BlogPostSkeleton>('entry-id')
CMA Integration in Apps (App Framework)
Use SDK adapter to avoid exposing tokens:
import contentful from 'contentful-management'
const cma = contentful.createClient(
{ apiAdapter: sdk.cmaAdapter },
{
type: 'plain',
defaults: {
spaceId: sdk.ids.space,
environmentId: sdk.ids.environmentAlias ?? sdk.ids.environment
}
}
)