Update 5 files
- /home/.chezmoiscripts/universal/run_onchange_after_51-samba.sh.tmpl - /home/.chezmoiscripts/universal/run_onchange_after_53-tabby.sh.tmpl - /home/.chezmoiscripts/universal/run_onchange_after_59-connect-tailscale.sh.tmpl - /home/.chezmoiscripts/universal/run_onchange_after_81-k8s-digitalocean.sh.tmpl - /home/.chezmoi.yaml.tmpl
This commit is contained in:
parent
51ade9064a
commit
187a33a410
5 changed files with 27 additions and 13 deletions
|
@ -171,6 +171,7 @@ data:
|
||||||
r2: "{{ $cloudflareR2AccountId }}"
|
r2: "{{ $cloudflareR2AccountId }}"
|
||||||
username: "{{ $cloudflareUsername }}"
|
username: "{{ $cloudflareUsername }}"
|
||||||
defaultBrowser: firefox
|
defaultBrowser: firefox
|
||||||
|
digitalOceanClusterId: b7fc4e37-ffe7-4ea1-887a-0e19ee077f32
|
||||||
# `domain` is kept here for backwards compatibility, but the .host.domain is the preferred selector
|
# `domain` is kept here for backwards compatibility, but the .host.domain is the preferred selector
|
||||||
domain: "{{ $domain }}"
|
domain: "{{ $domain }}"
|
||||||
email: "{{ $email }}"
|
email: "{{ $email }}"
|
||||||
|
|
|
@ -58,19 +58,19 @@ if command -v smbd > /dev/null; then
|
||||||
if [ -d /mnt/s3-private ] && [ ! -d /mnt/samba-private ]; then
|
if [ -d /mnt/s3-private ] && [ ! -d /mnt/samba-private ]; then
|
||||||
sudo ln -s /mnt/s3-private /mnt/samba-private
|
sudo ln -s /mnt/s3-private /mnt/samba-private
|
||||||
else
|
else
|
||||||
sudo mkdir /mnt/samba-private
|
sudo mkdir -p /mnt/samba-private
|
||||||
fi
|
fi
|
||||||
|
|
||||||
### Ensure public Samba directory / symlink exists
|
### Ensure public Samba directory / symlink exists
|
||||||
if [ -d /mnt/s3-public ] && [ ! -d /mnt/samba-public ]; then
|
if [ -d /mnt/s3-public ] && [ ! -d /mnt/samba-public ]; then
|
||||||
sudo ln -s /mnt/s3-public /mnt/samba-public
|
sudo ln -s /mnt/s3-public /mnt/samba-public
|
||||||
else
|
else
|
||||||
sudo mkdir /mnt/samba-public
|
sudo mkdir -p /mnt/samba-public
|
||||||
fi
|
fi
|
||||||
|
|
||||||
### Copy the Samba server configuration file
|
### Copy the Samba server configuration file
|
||||||
logg info "Copying Samba server configuration to /etc/samba/smb.conf"
|
logg info "Copying Samba server configuration to /etc/samba/smb.conf"
|
||||||
sudo cp -f "${XDG_DATA_HOME:-$HOME/.config}/samba/config" "/etc/samba/smb.conf"
|
sudo cp -f "${XDG_CONFIG_HOME:-$HOME/.config}/samba/config" "/etc/samba/smb.conf"
|
||||||
|
|
||||||
### Reload configuration file changes
|
### Reload configuration file changes
|
||||||
smbcontrol smbd reload-config
|
smbcontrol smbd reload-config
|
||||||
|
|
|
@ -47,7 +47,7 @@
|
||||||
{{ includeTemplate "universal/profile" }}
|
{{ includeTemplate "universal/profile" }}
|
||||||
{{ includeTemplate "universal/logg" }}
|
{{ includeTemplate "universal/logg" }}
|
||||||
|
|
||||||
if [ -f "${XDG_CONFIG_HOME:-$HOME/.config}/tabby/plugins/package-lock.json" ]; then
|
if [ -f "${XDG_CONFIG_HOME:-$HOME/.config}/tabby/plugins/package.json" ]; then
|
||||||
if [ -d "${XDG_CONFIG_HOME:-$HOME/.config}/tabby/plugins/node_modules" ]; then
|
if [ -d "${XDG_CONFIG_HOME:-$HOME/.config}/tabby/plugins/node_modules" ]; then
|
||||||
logg info 'Skipping Tabby plugin installation because it looks like the plugins were already installed since `node_modules` is present in ~/.config/tabby/plugins'
|
logg info 'Skipping Tabby plugin installation because it looks like the plugins were already installed since `node_modules` is present in ~/.config/tabby/plugins'
|
||||||
else
|
else
|
||||||
|
|
|
@ -6,6 +6,9 @@
|
||||||
# This script ensures the `tailscaled` system daemon is installed on macOS. Then, on both macOS and Linux, it connects to the Tailscale
|
# This script ensures the `tailscaled` system daemon is installed on macOS. Then, on both macOS and Linux, it connects to the Tailscale
|
||||||
# network if the `TAILSCALE_AUTH_KEY` variable is provided.
|
# network if the `TAILSCALE_AUTH_KEY` variable is provided.
|
||||||
|
|
||||||
|
{{ includeTemplate "universal/profile" }}
|
||||||
|
{{ includeTemplate "universal/logg" }}
|
||||||
|
|
||||||
### Install the Tailscale system daemon
|
### Install the Tailscale system daemon
|
||||||
if [ -d /Applications ] && [ -d System ]; then
|
if [ -d /Applications ] && [ -d System ]; then
|
||||||
# macOS
|
# macOS
|
||||||
|
|
|
@ -6,16 +6,26 @@
|
||||||
# This script runs when `DIGITALOCEAN_ACCESS_TOKEN` is defined as an environment variable or as an encrypted key (see
|
# This script runs when `DIGITALOCEAN_ACCESS_TOKEN` is defined as an environment variable or as an encrypted key (see
|
||||||
# [Secrets documentation](https://install.doctor/docs/customization/secrets#encrypted-secrets)). If the check passes,
|
# [Secrets documentation](https://install.doctor/docs/customization/secrets#encrypted-secrets)). If the check passes,
|
||||||
# then the script ensures the DigitalOcean CLI is installed (i.e. `doctl`). Then, it uses `doctl` to connect to the Kubernetes
|
# then the script ensures the DigitalOcean CLI is installed (i.e. `doctl`). Then, it uses `doctl` to connect to the Kubernetes
|
||||||
# cluster defined by the `DIGITALOCEAN_K8S_ID` secret.
|
# cluster defined by the the configuration stored under `.user.digitalOceanClusterId` in `home/.chezmoi.yaml.tmpl`.
|
||||||
# This script detects the presence of various executables with Bash completions available and then
|
|
||||||
# conditionally adds the completions to the Bash completions folder.
|
|
||||||
|
|
||||||
### Ensure DigitalOcean CLI is instaled
|
{{ includeTemplate "universal/profile" }}
|
||||||
if ! command -v doctl > /dev/null; then
|
{{ includeTemplate "universal/logg" }}
|
||||||
logg info '`doctl` is missing - installing via Homebrew'
|
|
||||||
brew install doctl
|
### Ensure `DIGITALOCEAN_ACCESS_TOKEN` is defined (used for headlessly connecting to the k8s cluster)
|
||||||
|
export DIGITALOCEAN_ACCESS_TOKEN="{{ if (stat (joinPath .chezmoi.sourceDir ".chezmoitemplates" "secrets" "DIGITALOCEAN_ACCESS_TOKEN")) }}{{ includeTemplate "secrets/DIGITALOCEAN_ACCESS_TOKEN" | decrypt }}{{ else }}{{ env "DIGITALOCEAN_ACCESS_TOKEN" }}{{ end }}"
|
||||||
|
|
||||||
|
if [ -n "$DIGITALOCEAN_ACCESS_TOKEN" ] && [ -n '{{ .user.digitalOceanClusterId }}' ]; then
|
||||||
|
### Ensure DigitalOcean CLI is instaled
|
||||||
|
if ! command -v doctl > /dev/null; then
|
||||||
|
logg info '`doctl` is missing - installing via Homebrew'
|
||||||
|
brew install doctl
|
||||||
|
fi
|
||||||
|
|
||||||
|
### Connect to the k8s cluster with `doctl`
|
||||||
|
logg info 'Connecting to the DigitalOcean k8s cluster with `doctl`'
|
||||||
|
doctl kubernetes cluster kubeconfig save {{ .user.digitalOceanClusterId }}
|
||||||
|
else
|
||||||
|
logg info 'Skipping connecting to the DigitalOcean k8s cluster because either the `DIGITALOCEAN_ACCESS_TOKEN` or the `.user.digitalOceanClusterId` is not defined'
|
||||||
fi
|
fi
|
||||||
|
|
||||||
doctl kubernetes cluster kubeconfig save b7fc4e37-ffe7-4ea1-887a-0e19ee077f32
|
|
||||||
|
|
||||||
{{ end -}}
|
{{ end -}}
|
||||||
|
|
Loading…
Reference in a new issue