Skip to main content

Linting rules for dashboard YAML configurations

Project description

kb-dashboard-lint

Linting rules for Kibana dashboard YAML configurations.

Overview

This package provides a configurable linting system that flags potentially problematic dashboard configurations based on best practices and style guidelines. It works with validated Pydantic models from kb-dashboard-core.

Installation

pip install kb-dashboard-lint

Or with uv:

uv add kb-dashboard-lint

Usage

CLI

# Check dashboards in a directory
kb-dashboard-lint check --input-dir ./inputs

# Check a single file
kb-dashboard-lint check --input-file dashboard.yaml

# Use custom configuration
kb-dashboard-lint check --config .dashboard-lint.yaml

# Only fail on errors (not warnings)
kb-dashboard-lint check --severity-threshold error

Programmatic API

from kb_dashboard_lint import check_dashboards
from kb_dashboard_core import load

# Load dashboards
dashboards = load('inputs/')

# Run linting
violations = check_dashboards(dashboards)

for violation in violations:
    print(f"{violation.severity}: {violation.rule_id} - {violation.message}")

Built-in Rules

Dashboard Rules

Rule ID Description Default
collapsible-minimum-kibana-version Dashboards using section panels should declare minimum_kibana_version: "9.1.0" or newer warning
dashboard-dataset-filter Dashboard should have a data_stream.dataset filter warning
dashboard-missing-description Dashboards should have a description for discoverability info
datatable-at-bottom Data table panels should be positioned at the bottom of the dashboard info
esql-minimum-kibana-version Dashboards using ES|QL panels should declare a compatible minimum_kibana_version warning
markdown-at-top Markdown panels with navigation content should be at the top of the dashboard info
metric-excessive-count Dashboards should not have excessive metric panels (style guide recommends 0-4) info

Panel Rules

Rule ID Description Default
markdown-header-height Markdown panels with headers must have height >= 3 warning
panel-min-width Panels should have minimum width for readability warning
panel-description-recommended Panels should have descriptions for accessibility info
panel-title-redundant-prefix Panel titles should not start with redundant prefixes like "Chart of" info

Chart Rules

Rule ID Description Default
gauge-goal-without-max Gauge charts with goals should define maximum values warning
metric-multiple-metrics-width Metric panels with multiple metrics should have adequate width warning
metric-redundant-label Metric primary label matching title should use hide_title: true warning
narrow-xy-chart-side-legend Narrow XY charts should use bottom legends instead of side legends warning
panel-height-for-content Panels should have minimum height for their chart type warning
esql-field-escaping ES|QL field names with numeric suffixes need backtick escaping warning
esql-group-by-syntax ES|QL uses BY within STATS, not GROUP BY warning
esql-missing-sort-after-bucket ES|QL time series queries with BUCKET should end with SORT for proper ordering warning
esql-sql-syntax ES|QL queries should not use SQL syntax warning
esql-ts-metrics-min-version FROM metrics-* should use TS metrics-* on Kibana/Elasticsearch 9.2+ warning
datatable-row-density Large datatables should consider compact density info
dimension-missing-label Dimensions should have explicit labels info
esql-dimension-missing-label ES|QL datatable dimensions should have explicit labels info
esql-dynamic-time-bucket ES|QL queries should use dynamic time bucketing info
esql-metric-missing-label ES|QL datatable metrics should have explicit labels info
esql-missing-limit ES|QL queries with SORT DESC should have explicit LIMIT for top-N results info
esql-where-clause ES|QL queries should include a WHERE clause info
pie-chart-dimension-count Pie charts with multiple dimensions may be hard to read info
pie-missing-limit Pie charts should limit slices shown (recommend 5-10 categories) info

Configuration

Create a .dashboard-lint.yaml file:

extends: default

rules:
  markdown-header-height:
    severity: error
  esql-where-clause:
    enabled: false

Development

# Install dependencies
just install

# Run CI checks
just ci

# Run tests
just test

License

MIT

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

kb_dashboard_lint-0.3.1.tar.gz (36.5 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

kb_dashboard_lint-0.3.1-py3-none-any.whl (67.9 kB view details)

Uploaded Python 3

File details

Details for the file kb_dashboard_lint-0.3.1.tar.gz.

File metadata

  • Download URL: kb_dashboard_lint-0.3.1.tar.gz
  • Upload date:
  • Size: 36.5 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: uv/0.10.11 {"installer":{"name":"uv","version":"0.10.11","subcommand":["publish"]},"python":null,"implementation":{"name":null,"version":null},"distro":{"name":"Ubuntu","version":"24.04","id":"noble","libc":null},"system":{"name":null,"release":null},"cpu":null,"openssl_version":null,"setuptools_version":null,"rustc_version":null,"ci":true}

File hashes

Hashes for kb_dashboard_lint-0.3.1.tar.gz
Algorithm Hash digest
SHA256 5cca96ef8dd89ac44cae6ea5e7fee6f962461a1bda83b09a8488f2e66ccb0963
MD5 4eadafc733d4b57e8c2d171e4d4c315b
BLAKE2b-256 e252e8fc9d07e098b28f5c4574d3436b16d29c06b3f0d7061ff30b873f785760

See more details on using hashes here.

File details

Details for the file kb_dashboard_lint-0.3.1-py3-none-any.whl.

File metadata

  • Download URL: kb_dashboard_lint-0.3.1-py3-none-any.whl
  • Upload date:
  • Size: 67.9 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: uv/0.10.11 {"installer":{"name":"uv","version":"0.10.11","subcommand":["publish"]},"python":null,"implementation":{"name":null,"version":null},"distro":{"name":"Ubuntu","version":"24.04","id":"noble","libc":null},"system":{"name":null,"release":null},"cpu":null,"openssl_version":null,"setuptools_version":null,"rustc_version":null,"ci":true}

File hashes

Hashes for kb_dashboard_lint-0.3.1-py3-none-any.whl
Algorithm Hash digest
SHA256 8b3abaad41aec5987cae9f387832aa14288b3b32d939aac37aeffc7ff6c60aa0
MD5 16cb352816b48f9b4389d88d56903407
BLAKE2b-256 b116a4e69f700706a81fd772c9fcba77c4ab015cf3dab3709f89ce478f8b98ea

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page