-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathTaskfile.yaml
78 lines (67 loc) · 2.13 KB
/
Taskfile.yaml
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
---
# yaml-language-server: $schema=https://taskfile.dev/schema.json
version: '3'
set: [pipefail]
shopt: [globstar]
vars:
# Directories
BOOTSTRAP_DIR: '{{.ROOT_DIR}}/bootstrap'
KUBERNETES_DIR: '{{.ROOT_DIR}}/kubernetes'
SCRIPTS_DIR: '{{.ROOT_DIR}}/scripts'
# Files
BOOTSTRAP_CONFIG_FILE: '{{.ROOT_DIR}}/config.yaml'
MAKEJINJA_CONFIG_FILE: '{{.ROOT_DIR}}/makejinja.toml'
SOPS_CONFIG_FILE: '{{.ROOT_DIR}}/.sops.yaml'
env:
KUBECONFIG: '{{.ROOT_DIR}}/kubeconfig'
PYTHONDONTWRITEBYTECODE: '1'
SOPS_AGE_KEY_FILE: '{{.ROOT_DIR}}/age.key'
VIRTUAL_ENV: '{{.ROOT_DIR}}/.venv'
includes:
kubernetes: .taskfiles/Kubernetes
flux: .taskfiles/Flux
repository: .taskfiles/Repository
talos: .taskfiles/Talos
sops: .taskfiles/Sops
workstation: .taskfiles/Workstation
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}}
- cmd: echo === Configuration file copied ===
- cmd: echo Proceed with updating the configuration files...
- cmd: 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', 'sops:age-keygen', 'init']
cmds:
- task: template
- task: sops:encrypt
- task: validate
template:
internal: true
cmd: '{{.VIRTUAL_ENV}}/bin/makejinja'
preconditions:
- test -d {{.VIRTUAL_ENV}}
- test -f {{.MAKEJINJA_CONFIG_FILE}}
- test -f {{.BOOTSTRAP_DIR}}/scripts/plugin.py
- test -f {{.BOOTSTRAP_CONFIG_FILE}}
validate:
internal: true
cmds:
- task: kubernetes:kubeconform
- cmd: echo === Done rendering and validating YAML ===
- cmd: |
if test -f ~/.config/sops/age/keys.txt; then
echo WARNING: SOPS Age key found in home directory, this may cause conflicts.
fi
silent: true