@contentrain/types
v0.2.0
Published
Shared TypeScript types for Contentrain ecosystem
Maintainers
Readme
@contentrain/types
Shared TypeScript types for the Contentrain ecosystem.
This package is the common schema layer used by:
@contentrain/mcpcontentrain@contentrain/query@contentrain/rules
It defines the stable type vocabulary for models, config, metadata, validation, scanning, and context files.
✨ When To Use It
Use @contentrain/types when you are:
- building tooling on top of Contentrain packages
- sharing model/config types between packages in a workspace
- authoring framework integrations or SDK extensions
- consuming Contentrain JSON structures directly in TypeScript
🚀 Install
pnpm add @contentrain/types📦 What It Exports
Core unions:
FieldTypeModelKindContentStatusContentSourceWorkflowModeStackTypePlatformContextSourceCollectionRuntimeFormatLocaleStrategy
Core interfaces:
FieldDefModelDefinitionContentrainConfigVocabularyEntryMetaAssetEntryValidationErrorValidationResultScaffoldTemplateScanCandidateDuplicateGroupGraphNodeProjectGraphScanCandidatesResultScanSummaryResultContextJson
Storage/runtime helper types:
SingletonContentFileCollectionContentFileDictionaryContentFileCollectionEntryCollectionContentOutputSingletonMetaCollectionMetaDocumentMetaDictionaryMeta
🧭 Stability
This package is intended to be the shared public contract across the Contentrain ecosystem.
In practice that means:
- types exported from the package root are the public surface
- packages should depend on these shared definitions instead of redefining domain types
- breaking changes here should be treated as ecosystem-level breaking changes
🧪 Quick Example
import type {
ContentrainConfig,
FieldDef,
ModelDefinition,
ValidationResult,
} from '@contentrain/types'
const fields: Record<string, FieldDef> = {
title: { type: 'string', required: true },
slug: { type: 'slug', required: true, unique: true },
}
const model: ModelDefinition = {
id: 'blog-post',
name: 'Blog Post',
kind: 'collection',
domain: 'blog',
i18n: true,
fields,
}
const config: ContentrainConfig = {
version: 1,
stack: 'next',
workflow: 'review',
locales: { default: 'en', supported: ['en', 'tr'] },
domains: ['blog'],
}
const result: ValidationResult = {
valid: true,
errors: [],
}📝 Import Style
Type-only usage:
import type { ModelDefinition, ContentrainConfig } from '@contentrain/types'Runtime-safe mixed usage:
import type { FieldDef } from '@contentrain/types'🧠 Design Role
@contentrain/types exists so every package in the monorepo speaks the same domain language.
Examples:
- MCP validates and writes
ModelDefinition - CLI reads
ContextJson - SDK codegen consumes
ModelDefinitionandFieldDef - AI rules align with the same model and workflow vocabulary
This package should stay:
- small
- dependency-light
- stable
- free of package-specific behavior
🛠 Development
From the monorepo root:
pnpm --filter @contentrain/types build
pnpm --filter @contentrain/types test
pnpm --filter @contentrain/types typecheck🔗 Related Packages
@contentrain/mcpcontentrain@contentrain/query@contentrain/rules
📄 License
MIT
