All notable changes to this project will be documented in this file.
The format is based on Keep a Changelog, and this project adheres to Semantic Versioning.
1.3.10 - 2026-01-25
- Synchronized release with terraform-provider-turingpi v1.3.10
- Provider fix: BMC firmware 2.0.5+ flash status response format now supported
1.3.9 - 2026-01-19
- talos-image module: SBC overlay support for single-board computers
- New
sbc_overlayvariable for board-specific overlays (turingrk1, rpi_generic, rock5b, etc.) - Auto-detection of overlay images from overlay name
- Supports 16+ SBC boards across Rockchip, Raspberry Pi, Jetson, and Allwinner families
- New
- talos-cluster module: Added
talosconfig_pathoutput - talos-wipe.sh: Added
--yes/-yflag for non-interactive automation - scripts/find-armbian-image.sh - Find and download Armbian images for Turing RK1 from GitHub releases
- test/addon-test/ - Comprehensive addon module test configuration
- test/provider-test/ - Provider data source test configuration
- talos-cluster module: Fixed talosconfig output format - now generates proper YAML with context, endpoints, nodes (previously output unusable JSON)
- talos-wipe.sh: Removed eMMC wipe attempt - eMMC is system disk and cannot be wiped via talosctl reset
- Shellcheck SC2002 warnings in helper scripts
- Enhanced docs/WORKFLOWS.md with comprehensive K3s and Talos deployment steps
- Updated README version references to ~> 1.3.9
- All addon modules tested on Talos v1.9.2 (Turing RK1 with turingrk1 overlay)
- metallb: L2 mode with IP pool 10.10.88.80-89
- ingress-nginx: LoadBalancer service on 10.10.88.80
- cert-manager: Self-signed CA and ClusterIssuers ready
- longhorn: StorageClass created with NVMe storage class
- monitoring: Prometheus + Grafana with persistent storage
- portainer: Agent accessible on 10.10.88.81:9001
- Talos Image Factory integration with SBC overlays verified
1.3.8 - 2026-01-19
- Wipe scripts now wipe both NVMe and eMMC drives by default
- Added prominent warning box showing all data to be destroyed
- Changed confirmation from 'yes' to 'DESTROY' for safety
- Added
--no-emmcflag to skip eMMC wipe if needed
1.3.7 - 2026-01-19
- Helper scripts bash
set -ecompatibility (STEP increment, log_output function) - Scripts now auto-load credentials from
~/.secrets/turning-pi-cluster-bmcfile format - Scripts auto-detect SSH key from
~/.secrets/turningpi-cluster
1.3.6 - 2026-01-19
- talos-image module - Generate Talos images with extensions (iscsi-tools, util-linux-tools) for Longhorn support
- docs/WORKFLOWS.md - Complete cluster lifecycle documentation with Mermaid flowcharts for Talos and K3s
- scripts/cluster-preflight.sh - Pre-deployment validation script checking tools, BMC connectivity, node status
- scripts/talos-wipe.sh - Enhanced Talos cluster wipe with env vars, credential files, terraform cleanup, force power-off
- scripts/k3s-wipe.sh - Enhanced K3s cluster wipe with node draining, container cleanup, iptables cleanup
- Updated talos-full-stack example to use talos-image module for automatic image generation
- Enhanced README with documentation links and helper script examples
- Added platform-specific configurations to addon modules (Talos vs K3s/Armbian)
- Added storage capacity planning guidance for eMMC-constrained nodes
1.3.5 - 2026-01-18
- cert-manager addon module - TLS certificate management with Let's Encrypt and self-signed CA support
- docs/UPGRADE.md with comprehensive upgrade guidance
namespacevariable to all addon modules (metallb, ingress-nginx, longhorn, monitoring, portainer)controller_resourcesandspeaker_resourcesto MetalLB modulecontroller_replicas,controller_resources,enable_metricsto ingress-nginx modulemanager_resources,ui_replicasto Longhorn modulereplicasvariable to Portainer module- Grafana password validation (minimum 8 characters) in monitoring module
- All addon modules now use configurable namespaces instead of hardcoded values
- Improved resource configuration flexibility across all addon modules
- MetalLB and cert-manager modules now use
valuesblock instead ofsetblocks for Helm provider v3.x compatibility
1.3.4 - 2026-01-18
- Synchronized release with terraform-provider-turingpi v1.3.4
- Provider now supports BMC firmware 2.3.4 API response format
1.3.3 - 2026-01-18
- CODE_OF_CONDUCT.md (Contributor Covenant v2.0)
- docs/ARCHITECTURE.md with module dependency diagrams
- Security workflow with Trivy scanning and dependency review
- Enhanced SECURITY.md with supply chain security section
- Enhanced CODEOWNERS with per-path ownership
- Enhanced CONTRIBUTING.md with release process
- Enhanced pre-commit hooks with additional checks
- README badges updated
1.3.2 - 2025-12-30
- Bump actions/checkout from v4 to v6
- Bump terraform-linters/setup-tflint from v4 to v6
1.3.1 - 2025-12-30
- README badges (CI status, Terraform Registry, License) to root and all submodule READMEs
1.3.0 - 2025-12-30
- GitHub Actions workflow for Terraform validation (fmt, init, validate) on PRs
- TFLint integration with recommended ruleset (
.tflint.hcl) - Trivy security scanning for misconfigurations (
trivy.yaml) - terraform-docs integration for auto-generated documentation (
.terraform-docs.yml) - Dependabot for Terraform provider and GitHub Actions updates
- Pre-commit hooks for local validation (
.pre-commit-config.yaml) - CODEOWNERS file for automatic PR review requests
- Branch protection with required status checks and code owner reviews
- Issue templates (bug report, feature request)
- Pull request template with validation checklist
- CONTRIBUTING guide with development setup instructions
- Unused
install_timeoutvariable from k3s-cluster module - Unused
allow_scheduling_on_control_planevariable from talos-cluster module
1.2.4 - 2025-12-30
talos_versionvariable to talos-cluster module for explicit Talos version in config generationkubernetes_versionvariable to talos-cluster module for explicit Kubernetes version
1.2.3 - 2025-12-30
- Updated provider requirement to
>= 1.3.0(includes BMC API compatibility and flash implementation) - Updated all documentation examples to reference v1.3.0
1.2.2 - 2025-12-29
- Updated all module version references to
>= 1.2.0 - Updated provider requirement to
>= 1.2.0 - Added k3s-cluster, longhorn, monitoring, portainer to available_submodules list
- Synchronized documentation with terraform-provider-turingpi repo
1.2.1 - 2025-12-29
- Applied terraform fmt formatting fixes across all modules
1.2.0 - 2025-12-29
-
k3s-cluster module - Deploy K3s Kubernetes cluster on Armbian
- SSH-based deployment (key or password authentication)
- NVMe storage configuration for Longhorn
- Automatic package installation (open-iscsi, nfs-common)
- Configurable K3s options (disable traefik, servicelb, etc.)
-
k3s-full-stack example - Complete K3s deployment with all addons
- Updated talos-full-stack example with all addon modules
- Updated root README with K3s quick start and Talos vs K3s comparison
1.1.0 - 2025-12-29
-
Addon modules
longhorn- Distributed block storage with NVMe-optimized storage classmonitoring- Prometheus, Grafana, Alertmanager (kube-prometheus-stack)portainer- Cluster management agent for CE/BE
-
NVMe storage support for talos-cluster module
nvme_storage_enabled- Enable NVMe configurationnvme_device- Device path configurationnvme_mountpoint- Mount point for Longhornnvme_control_plane- Configure NVMe on control plane nodes
-
talos-full-stack example - Complete Talos deployment with all addons
- Updated talos-cluster module with NVMe configuration options
- Enhanced README with full stack examples
1.0.4 - 2025-12-29
- Version constraint updates in examples
1.0.3 - 2025-12-29
- Duplicate terraform block in flash-nodes module
1.0.2 - 2025-12-29
- Root module configuration for Terraform Registry compatibility
1.0.1 - 2025-12-29
- Module README files for all submodules
- versions.tf files for Terraform Registry compatibility
1.0.0 - 2025-12-29
- Initial release
- flash-nodes module - Flash firmware to Turing Pi nodes
- talos-cluster module - Deploy Talos Kubernetes cluster
- metallb addon - MetalLB load balancer
- ingress-nginx addon - NGINX Ingress controller