I’ve wanted this for a long time, and thanks to Claude and a few nights back and forth iterating and refining, I’m pretty much there.
I’d really welcome improvements and feedback on this.
- Basic Structure Checks:
- Ensures each automation has a trigger and action section
- Checks that the YAML is properly formatted
- Validates that triggers/conditions/actions are either single items or lists
- Trigger Validations:
- Checks for required fields based on trigger type (e.g., platform, entity_id)
- Validates trigger platforms (state, mqtt, event, numeric_state, etc.)
- For state triggers: checks entity IDs exist
- For time triggers: validates time formats
- For MQTT triggers: ensures topic is present
- For sun triggers: validates event types (sunrise/sunset)
- For numeric triggers: checks for valid above/below values
- For template triggers: checks for Jinja2 delimiters
- Condition Validations:
- Validates condition types (state, numeric, template, etc.)
- Checks required fields for each condition type
- Checks numeric ranges in numeric conditions
- Validates time formats in time conditions
- Action Validations:
- Validates service calls have proper domain.service format
- Checks for required fields in different action types
- Validates data and data_template structures
- Checks for proper formatting of service templates
- Validates complex actions like repeat and choose
- Checks for proper MQTT topic/payload structure
- Toggle Pattern Detection:
- For certain device types (covers, media players, etc.)
- Checks if there are matching on/off state triggers
- Warns about missing toggle counterparts
- Entity Reference Tracking:
- Tracks all referenced entities
- Checks for undefined automations that are referenced
- Validates entity ID formats
- Special Case Validations:
- Checks for self-references in templates
- Validates time patterns and formats
- Checks for impossible numeric conditions
- Service Call Validations:
- Validates MQTT publish actions have topics
- Checks for transition times in light brightness changes
- Warns about generic notify services
- Warnings are generated for:
- Unknown fields in triggers/conditions/actions
- Missing optional but recommended fields
- Non-standard usage patterns
- Potential improvements (like adding transitions)
- Critical errors are flagged for:
- Missing required fields
- Invalid formats
- Impossible conditions
- Malformed structures
The script also categorizes automations based on their content, primarily looking at:
- Service domains
- Entity types
- Action types
- Common patterns in naming and usage
It’s not perfect…
To run, download it, then call python sorter.py
where automations.yaml is in the same directory as the script. Do this locally rather than on the server!!!