-
Notifications
You must be signed in to change notification settings - Fork 1
/
Taskfile.yml
91 lines (83 loc) · 2.84 KB
/
Taskfile.yml
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
---
# yaml-language-server: $schema=https://taskfile.dev/schema.json
version: "3"
vars:
# Directory paths
KUBERNETES_DIR: "{{.ROOT_DIR}}/kubernetes"
TERRAFORM_DIR: "{{.ROOT_DIR}}/infrastructure/terraform"
TALOS_DIR: "{{.ROOT_DIR}}/infrastructure/talos/betty"
BOOTSTRAP_DIR: "{{.ROOT_DIR}}/bootstrap"
PRIVATE_DIR: "{{.ROOT_DIR}}/.private"
SCRIPTS_DIR: "{{.ROOT_DIR}}/scripts"
# GitHub settings
CLUSTER: betty
GITHUB_USER: snoopy82481
GITHUB_REPO: home_cluster
GITHUB_BRANCH: main
# File paths
AGE_FILE: "{{.ROOT_DIR}}/age.key"
BOOTSTRAP_CONFIG_FILE: "{{.ROOT_DIR}}/config.yaml"
KUBECONFIG_FILE: "{{.ROOT_DIR}}/kubeconfig"
MAKEJINJA_CONFIG_FILE: "{{.ROOT_DIR}}/makejinja.toml"
PIP_REQUIREMENTS_FILE: "{{.ROOT_DIR}}/requirements.txt"
SOPS_CONFIG_FILE: "{{.ROOT_DIR}}/.sops.yaml"
# Binary paths
PYTHON_BIN: "python3"
env:
KUBECONFIG: "{{.KUBECONFIG_FILE}}"
PYTHONDONOTWRITEBYTECODE: "1"
SOPS_AGE_KEY_FILE: "{{.ROOT_DIR}}/age.key"
VIRTUAL_ENV: "{{.ROOT_DIR}}/.venv"
includes:
bootstrap: .taskfiles/bootstrap
kubernetes: .taskfiles/kubernetes
talos: .taskfiles/talos
flux: .taskfiles/flux
workstation: .taskfiles/workstation/
terraform: .taskfiles/terraform
user:
taskfile: .taskfiles/user
optional: true
tasks:
default: task --list
init:
desc: Initialize configuration files
cmds:
- cp -n {{.BOOTSTRAP_CONFIG_FILE | replace ".yaml" ".sample.yaml"}} {{.BOOTSTRAP_CONFIG_FILE}}
- echo "=== Configuration file copied ==="
- echo "Proceed with updating the configuration files..."
- echo "{{.BOOTSTRAP_CONFIG_FILE}}"
status:
- test -f {{.BOOTSTRAP_CONFIG_FILE}}
silent: true
configure:
desc: Configure repository from bootstrap vars
prompt: Any conflicting config in the kubernetes directory will be overwritten... continue?
deps:
["workstation:direnv", "workstation:venv", "bootstrap:age-keygen", "init"]
cmds:
- task: template
- task: bootstrap:encrypt
- task: validate
template:
internal: true
cmd: "{{.VIRTUAL_ENV}}/bin/makejinja"
preconditions:
- msg: Missing virtual environment
sh: test -d {{.VIRTUAL_ENV}}
- msg: Missing Makejinja config file
sh: test -f {{.MAKEJINJA_CONFIG_FILE}}
- msg: Missing Makejinja plugin file
sh: test -f {{.BOOTSTRAP_DIR}}/scripts/plugin.py
- msg: Missing bootstrap config file
sh: test -f {{.BOOTSTRAP_CONFIG_FILE}}
validate:
internal: true
cmds:
- task: kubernetes:kubeconform
- echo "=== Done rendering and validating YAML ==="
- '{{if eq .HOME_SOPS_AGE_KEY_FILE_EXISTS "true"}}echo "WARNING: SOPS Age key found in home directory, this may cause conflicts."{{end}}'
vars:
HOME_SOPS_AGE_KEY_FILE_EXISTS:
sh: test -f ~/.config/sops/age/keys.txt && echo true || echo false
silent: true