Skip to main content

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), and latest
  • ⚙️ 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

npx @eventcatalog/linter

Global Installation

npm install -g @eventcatalog/linter

Add to your project

npm 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 NameDescriptionAccepted ValuesDefault
Schema Validation Rules
schema/required-fieldsValidates that required fields are present in frontmattererror, warn, offerror
schema/valid-typeValidates that field types are correct (strings, arrays, objects)error, warn, offerror
schema/valid-semverValidates semantic version format (1.0.0, 2.1.3-beta)error, warn, offerror
schema/valid-emailValidates email address format in user frontmattererror, warn, offerror
schema/validation-errorGeneral schema validation errorserror, warn, offerror
Reference Validation Rules
refs/owner-existsEnsures referenced owners (users/teams) existerror, warn, offerror
refs/valid-version-rangeValidates version references and patternserror, warn, offerror
refs/resource-existsEnsures referenced resources exist (always enabled for critical resources)Always enabledAlways enabled
Best Practice Rules
best-practices/summary-requiredRequires summary field for better documentationerror, warn, offerror
best-practices/owner-requiredRequires at least one owner for accountabilityerror, warn, offerror
Core Resource Validation

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

  1. Start with Configuration: Create a .eventcatalogrc.js file to customize rules for your team's workflow
  2. Run in CI/CD: Integrate the linter into your CI/CD pipeline to catch issues early
  3. Use --fail-on-warning: Consider treating warnings as errors in production environments
  4. Regular Validation: Run the linter regularly as part of your development workflow
  5. Fix Issues Promptly: Address validation errors immediately to maintain documentation quality
  6. Version Consistency: Use consistent version patterns across your EventCatalog resources
  7. Team Overrides: Use file pattern overrides for different validation requirements across teams
  8. 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.