EventCatalog Linter
A comprehensive linter for EventCatalog that validates frontmatter schemas and resource references to ensure your architecture documentation is correct and consistent.
The EventCatalog Linter helps you catch issues early in your development process, ensuring your documentation maintains high quality and accuracy across all your EventCatalog resources.
Use cases
- Quality Assurance: Ensure your documentation is correct and consistent
- CI/CD: Integrate the linter into your CI/CD pipeline to catch issues early
- Documentation: Run the linter regularly as part of your development workflow
- Version Consistency: Use consistent version patterns across your EventCatalog resources
Features
- 📋 Schema Validation: Validates all resource frontmatter against defined schemas using Zod
- 🔗 Reference Validation: Ensures all referenced resources (services, events, domains, etc.) actually exist
- 📦 Semver Version Support: Supports semantic versions, ranges (
^1.0.0
,~1.2.0
), x-patterns (0.0.x
), andlatest
- ⚙️ Configurable Rules: Optional
.eventcatalogrc.js
config file for customizing rule severity and behavior - 🚫 Ignore Patterns: Skip validation for specific file patterns (archived, drafts, etc.)
- 🎯 Rule Overrides: Apply different rules to different file patterns for flexible team workflows
- 🎯 Comprehensive Coverage: Supports all EventCatalog resource types
- ⚡ Fast Performance: Efficiently scans large catalogs
- 🎨 ESLint-Inspired Output: Clean, file-grouped error reporting with severity levels
- ⚠️ Warnings Support: Distinguish between errors and warnings with
--fail-on-warning
option
Supported Resource Types
The linter validates all EventCatalog resource types:
- 🏢 Domains (including subdomains)
- ⚙️ Services
- 📨 Events
- 📤 Commands
- ❓ Queries
- 📡 Channels
- 🔄 Flows
- 📊 Entities
- 👤 Users
- 👥 Teams
Quick Start
Get started with the EventCatalog Linter in three simple steps:
1. Run the Linter
Start linting your EventCatalog immediately with npx:
npx @eventcatalog/linter
2. Configure Rules (Optional)
Create a .eventcatalogrc.js
file in your EventCatalog root to customize validation:
module.exports = {
rules: {
'best-practices/summary-required': 'warn',
'refs/owner-exists': 'error'
},
ignorePatterns: ['**/drafts/**']
};
3. Integrate with CI/CD
Add to your CI/CD pipeline for automated validation:
# GitHub Actions
- run: npx @eventcatalog/linter --fail-on-warning
Installation
Use with npx (Recommended)
- npm
- pnpm
npx @eventcatalog/linter
pnpm dlx @eventcatalog/linter
Global Installation
- npm
- pnpm
npm install -g @eventcatalog/linter
pnpm install -g @eventcatalog/linter
Add to your project
- npm
- pnpm
npm install --save-dev @eventcatalog/linter
pnpm install --save-dev @eventcatalog/linter
Usage
Basic Usage
Run the linter in your EventCatalog directory:
// Lint current directory
eventcatalog-linter
// Lint specific directory
eventcatalog-linter ./my-eventcatalog
// Verbose output with detailed information
eventcatalog-linter --verbose
// Show help
eventcatalog-linter --help
CLI Options
Usage: eventcatalog-linter [options] [directory]
Arguments:
directory EventCatalog directory to lint (default: ".")
Options:
-V, --version output the version number
-v, --verbose Show verbose output (default: false)
--fail-on-warning Exit with non-zero code on warnings (default: false)
-h, --help display help for command
Configuration
The EventCatalog Linter supports optional configuration through a .eventcatalogrc.js
file in your catalog root directory. This allows you to:
- Turn rules on/off
- Configure rule severity levels (error, warn, off)
- Ignore specific file patterns
- Override rules for specific file patterns
Quick Start with Configuration
Create a .eventcatalogrc.js
file in your EventCatalog root directory:
// .eventcatalogrc.js
module.exports = {
rules: {
// Schema validation rules
'schema/required-fields': 'error',
'schema/valid-semver': 'error',
'schema/valid-email': 'warn',
// Reference validation rules
'refs/owner-exists': 'error',
'refs/valid-version-range': 'error',
// Best practice rules
'best-practices/summary-required': 'warn',
'best-practices/owner-required': 'error',
},
// Ignore certain paths
ignorePatterns: ['**/archived/**', '**/drafts/**'],
// Override rules for specific file patterns
overrides: [
{
files: ['**/experimental/**'],
rules: {
'best-practices/owner-required': 'off'
}
}
]
};
Rule Severity Levels
'error'
- Causes the linter to exit with error code 1'warn'
- Shows warnings but allows the linter to pass (unless--fail-on-warning
is used)'off'
- Disables the rule completely
Available Rules
Rule Name | Description | Accepted Values | Default |
---|---|---|---|
Schema Validation Rules | |||
schema/required-fields | Validates that required fields are present in frontmatter | error , warn , off | error |
schema/valid-type | Validates that field types are correct (strings, arrays, objects) | error , warn , off | error |
schema/valid-semver | Validates semantic version format (1.0.0, 2.1.3-beta) | error , warn , off | error |
schema/valid-email | Validates email address format in user frontmatter | error , warn , off | error |
schema/validation-error | General schema validation errors | error , warn , off | error |
Reference Validation Rules | |||
refs/owner-exists | Ensures referenced owners (users/teams) exist | error , warn , off | error |
refs/valid-version-range | Validates version references and patterns | error , warn , off | error |
refs/resource-exists | Ensures referenced resources exist (always enabled for critical resources) | Always enabled | Always enabled |
Best Practice Rules | |||
best-practices/summary-required | Requires summary field for better documentation | error , warn , off | error |
best-practices/owner-required | Requires at least one owner for accountability | error , warn , off | error |
Core resource reference validation (services, domains, entities) is always enabled and cannot be disabled, ensuring referential integrity of your EventCatalog.
Configuration Examples
Relaxed Configuration for Development
module.exports = {
rules: {
'best-practices/summary-required': 'warn',
'best-practices/owner-required': 'warn',
'refs/owner-exists': 'warn',
},
ignorePatterns: ['**/drafts/**', '**/experimental/**']
};
Strict Configuration for Production
module.exports = {
rules: {
'schema/required-fields': 'error',
'refs/owner-exists': 'error',
'best-practices/summary-required': 'error',
'best-practices/owner-required': 'error',
}
};
Team-Specific Overrides
module.exports = {
rules: {
'best-practices/owner-required': 'error',
'best-practices/summary-required': 'error',
},
overrides: [
{
files: ['**/legacy/**'],
rules: {
'best-practices/owner-required': 'warn',
'best-practices/summary-required': 'off'
}
},
{
files: ['**/critical/**'],
rules: {
'best-practices/summary-required': 'error',
'refs/owner-exists': 'error'
}
}
]
};
Using with CI/CD
The configuration file allows you to have different validation rules for different environments:
# Development - warnings allowed
npx @eventcatalog/linter
# Production - fail on warnings
npx @eventcatalog/linter --fail-on-warning
Default Behavior
If no .eventcatalogrc.js
file is found, the linter uses default rules where all validations are set to 'error'
. This ensures strict validation out of the box, making it easy to get started with quality documentation practices.
Package.json Integration
Add to your package.json
scripts:
{
"scripts": {
"lint:eventcatalog": "eventcatalog-linter",
"lint:eventcatalog:verbose": "eventcatalog-linter --verbose"
}
}
What It Validates
Frontmatter Schema Validation
- ✅ Required fields are present (
id
,name
,version
) - ✅ Field types are correct (strings, arrays, objects)
- ✅ Semantic versions follow proper format (
1.0.0
,2.1.3-beta
) - ✅ Version patterns supported (
latest
,^1.0.0
,~1.2.0
,0.0.x
) - ✅ URLs are valid format
- ✅ Email addresses are valid format
- ✅ Enum values are from allowed lists
- ✅ Nested object structures are correct
Reference Validation
- ✅ Services referenced in domains exist
- ✅ Events/Commands/Queries referenced in services exist
- ✅ Entities referenced in domains/services exist
- ✅ Users/Teams referenced as owners exist
- ✅ Flow steps reference existing services/messages
- ✅ Entity properties reference existing entities
- ✅ Version-specific references are valid
Example Output
✅ Success Output
$ eventcatalog-linter
✔ No problems found!
42 files checked
❌ Error Output
$ eventcatalog-linter
services/user-service/index.mdx
✖ error version: Invalid semantic version format [version] (schema/valid-semver)
⚠ warning Summary is required for better documentation [summary] (best-practices/summary-required)
✖ 2 problems
domains/sales/index.mdx
✖ error Referenced service "order-service" does not exist [services] (refs/resource-exists)
✖ 1 problem
flows/user-registration/index.mdx
✖ error Referenced service "notification-service" (version: 2.0.0) does not exist [steps[1].service] (refs/valid-version-range)
✖ 1 problem
✖ 4 problems (3 errors, 1 warning)
3 files checked
Version Pattern Support
The linter supports flexible version patterns for resource references:
Exact Versions
sends:
- id: user-created
version: 1.0.0 # Exact semantic version
Latest Version
sends:
- id: user-created
version: latest # Always use the latest available version
Semver Ranges
sends:
- id: user-created
version: ^1.0.0 # Compatible with 1.x.x (1.0.0, 1.2.3, but not 2.0.0)
- id: user-updated
version: ~1.2.0 # Compatible with 1.2.x (1.2.0, 1.2.5, but not 1.3.0)
X-Pattern Matching
sends:
- id: user-created
version: 0.0.x # Matches 0.0.1, 0.0.5, 0.0.12, etc.
- id: order-placed
version: 1.x # Matches 1.0.0, 1.5.3, 1.99.0, etc.
CI/CD Integration
GitHub Actions
name: EventCatalog Lint
on: [push, pull_request]
jobs:
lint:
runs-on: ubuntu-latest
steps:
- uses: actions/checkout@v3
- uses: actions/setup-node@v3
with:
node-version: '18'
- run: npx @eventcatalog/linter
GitLab CI
eventcatalog-lint:
stage: test
image: node:18
script:
- npx @eventcatalog/linter
Rule Names and Error Codes
The linter provides descriptive rule names in parentheses to help identify and fix issues quickly. Each error shows the specific rule that was violated:
Schema Validation Rules
(schema/required-fields)
- Required field is missing(schema/valid-type)
- Field has wrong data type(schema/valid-semver)
- Invalid semantic version format(schema/valid-email)
- Invalid email address format(schema/validation-error)
- General schema validation error
Reference Validation Rules
(refs/owner-exists)
- Referenced owner (user/team) doesn't exist(refs/valid-version-range)
- Referenced version doesn't exist or invalid pattern(refs/resource-exists)
- Referenced resource doesn't exist
Best Practice Rules
(best-practices/summary-required)
- Summary field is missing(best-practices/owner-required)
- At least one owner is required
Parse Errors
(@eventcatalog/parse-error)
- YAML/frontmatter parsing error
Warnings Support
The linter distinguishes between errors (critical issues) and warnings (suggestions for improvement):
- Errors: Critical issues that must be fixed
- Warnings: Suggestions for better documentation
Use --fail-on-warning
to treat warnings as errors in CI/CD pipelines:
# Exit with error code if warnings are found
eventcatalog-linter --fail-on-warning
Common Validation Examples
Valid Frontmatter Examples
Service
---
id: user-service
name: User Service
version: 2.1.0
summary: Manages user accounts and authentication
owners:
- platform-team
- john-doe
sends:
- id: user-created
version: 1.0.0
- id: user-updated
receives:
- id: create-user
- id: update-user
entities:
- id: user
repository:
language: TypeScript
url: https://github.com/company/user-service
---
Event
---
id: user-created
name: User Created
version: 1.0.0
summary: Triggered when a new user account is created
owners:
- platform-team
sidebar:
badge: POST
label: User Events
draft: false
deprecated: false
---
Common Validation Errors
❌ Missing Required Fields
---
# Missing 'id' field
name: User Service
version: 1.0.0
---
❌ Invalid Semantic Version
---
id: user-service
name: User Service
version: v1.0 # Should be 1.0.0
---
❌ Invalid Reference
---
id: sales-domain
name: Sales Domain
version: 1.0.0
services:
- id: non-existent-service # Service doesn't exist
---
Best Practices
- Start with Configuration: Create a
.eventcatalogrc.js
file to customize rules for your team's workflow - Run in CI/CD: Integrate the linter into your CI/CD pipeline to catch issues early
- Use
--fail-on-warning
: Consider treating warnings as errors in production environments - Regular Validation: Run the linter regularly as part of your development workflow
- Fix Issues Promptly: Address validation errors immediately to maintain documentation quality
- Version Consistency: Use consistent version patterns across your EventCatalog resources
- Team Overrides: Use file pattern overrides for different validation requirements across teams
- Ignore Patterns: Use ignore patterns for draft or experimental content that shouldn't be validated yet
Issues?
If you have any issues or feedback, please let us know by opening an issue on GitHub or joining our Discord server.