PyPI | Docker | Docs | Example | Jinja reference
Generate entire directory structures using Jinja templates with support for external data and custom plugins.
makejinja can be used to automatically generate files from Jinja templates. It is conceptually similar to Ansible templates since both are built on top of Jinja. However, makejinja is a standalone tool that can be used without Ansible and offers some advanced features like custom plugins.
A popular use case is generating config files for Home Assistant: Using the same Jinja language that Home Assistant's built-in templates use, you can greatly simplify your configuration management. makejinja's custom delimiter support prevents conflicts with Home Assistant's own template syntax, while file-specific data loading enables modular dashboard and automation generation. Our comprehensive Home Assistant example demonstrates dashboard generation with custom plugins, multiple data sources, and advanced template organization.
- Multi-Source Data Integration: Load variables from YAML, TOML, and Python files, with support for file-specific data sources and runtime variable injection.
- Custom Template Delimiters: Configure Jinja delimiters (e.g.,
<% %>
instead of{{ }}
) to avoid conflicts with target file formats like Home Assistant, Kubernetes, or Terraform. - Flexible Directory Processing: Process multiple input directories with complex nested structures, preserving hierarchy while applying powerful template transformations.
- Extensible Plugin System: Create custom plugins with filters, functions, and path filtering logic for specialized requirements.
- Production-Ready: Comprehensive CLI interface, configuration file support, and Python library API for seamless workflow integration.
- Configuration Management: Generate environment-specific configs (dev/staging/prod) from shared templates with different data sources.
- Home Assistant Dashboards: Create complex dashboards and automations using Jinja syntax without conflicts. See our complete example.
- Infrastructure as Code: Generate Kubernetes manifests, Terraform modules, or Docker Compose files with consistent patterns across environments.
- Web Development: Generate HTML pages, CSS files, or JavaScript configs from data sources for static sites or multi-tenant applications.
- Database Schemas: Create SQL migration scripts, database configurations, or ORM models based on structured schema definitions.
- Network Configuration: Generate router configs, firewall rules, or network device settings from centralized network topology data.
- Monitoring & Alerting: Create Grafana dashboards, Prometheus rules, or alerting configurations from service inventories.
- Documentation & CI/CD: Create project docs, API specifications, or pipeline definitions from structured data sources.
The tool is written in Python and can be installed via uv, nix, and docker. It can be used as a CLI tool or as a Python library.
makejinja is available on PyPI and can be installed via uv
:
uv tool install makejinja
makejinja -i ./input -o ./output
makejinja is packaged in nixpkgs.
To use the most recent version, you can run it via nix run
:
nix run github:mirkolenz/makejinja -- -i ./input -o ./output
Alternatively, you can add this repository as an input to your flake and use makejinja.packages.${system}.default
.
We automatically publish an image to the GitHub Container Registry. To use it, mount a directory to the container and pass the options as the command:
docker run --rm -v $(pwd)/data:/data ghcr.io/mirkolenz/makejinja:latest -i /data/input -o /data/output
In its default configuration, makejinja searches the input directory recursively for files ending in .jinja
.
It then renders these files and writes them to the output directory, preserving the directory structure.
Our documentation contains a detailed description of all options and can also be accessed via makejinja --help
.