-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathsetup_wsl_debian
executable file
·261 lines (234 loc) · 7.46 KB
/
setup_wsl_debian
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
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
#!/bin/bash
set -euo pipefail
create_sudoers() {
if [ ! -f "/etc/sudoers.d/$USER" ]; then
echo "Setting no-password sudo for $USER"
echo -e "$USER ALL=(ALL) NOPASSWD: ALL\n" | sudo tee /etc/sudoers.d/$USER >/dev/null
else
echo "Already no-password sudo for $USER"
fi
}
create_update() {
if [ ! -f "/etc/apt/apt.conf.d/00unattended-upgrade-all" ]; then
echo "Setting full unattended upgrades"
cat << EOF | sudo tee /etc/apt/apt.conf.d/00unattended-upgrade-all >/dev/null
APT::Periodic::AutocleanInterval "1";
APT::Periodic::Enable "1";
APT::Periodic::Unattended-Upgrade "1";
APT::Periodic::Update-Package-Lists "1";
Unattended-Upgrade::Origins-Pattern {
"origin=*";
};
EOF
else
echo "Already full unattended upgrades"
fi
}
ensure_wsl_systemd() {
sudo augtool <<EOF
set /augeas/load/IniFile/lens IniFile.lns_loose
set /augeas/load/IniFile/incl /etc/wsl.conf
load
set /files/etc/wsl.conf/section boot
set /files/etc/wsl.conf/section["boot"]/systemd true
save
EOF
}
ensure_latest_azure_cli() {
curl -sL https://aka.ms/InstallAzureCLIDeb | sudo bash
}
ensure_latest_bun() {
if ! [ -x "$(command -v bun)" ]; then
curl -fsSL https://bun.sh/install | bash
else
bun upgrade
fi
}
ensure_latest_deno() {
if ! [ -x "$(command -v deno)" ]; then
curl -fsSL https://deno.land/install.sh | sh
else
deno upgrade
fi
}
ensure_latest_docker() {
if ! [ -x "$(command -v docker)" ]; then
echo "Installing Docker"
sudo apt-get install -y ca-certificates curl
sudo install -m 0755 -d /etc/apt/keyrings
sudo curl -fsSL https://download.docker.com/linux/$ID/gpg -o /etc/apt/keyrings/docker.asc
sudo chmod a+r /etc/apt/keyrings/docker.asc
echo \
"deb [arch=$ARCH \
signed-by=/etc/apt/keyrings/docker.asc] \
https://download.docker.com/linux/$ID \
$VERSION_CODENAME stable" |
sudo tee /etc/apt/sources.list.d/docker.list >/dev/null
sudo apt-get update
sudo apt-get install -y docker-ce docker-ce-cli containerd.io docker-buildx-plugin docker-compose-plugin
sudo usermod -aG docker $USER
else
echo "Docker already installed"
fi
}
ensure_latest_dotnet() {
if ! [ -x "$(command -v dotnet)" ]; then
curl -fsSL https://packages.microsoft.com/config/debian/$VERSION_ID/packages-microsoft-prod.deb -o packages-microsoft-prod.deb
sudo dpkg -i packages-microsoft-prod.deb
rm packages-microsoft-prod.deb
sudo apt-get update
sudo apt-get install -y dotnet-sdk-9.0
fi
}
install_latest_glab() {
curl -LO https://gitlab.com/gitlab-org/cli/-/releases/v${GLAB_LATEST_VERSION}/downloads/glab_${GLAB_LATEST_VERSION}_linux_${ARCH}.deb
sudo dpkg -i glab_${GLAB_LATEST_VERSION}_linux_${ARCH}.deb
rm glab_${GLAB_LATEST_VERSION}_linux_${ARCH}.deb
}
ensure_latest_glab() {
GLAB_LATEST_VERSION=$(curl -s https://gitlab.com/api/v4/projects/gitlab-org%2Fcli/releases | jq -r '.[0].name[1:]')
if ! [ -x "$(command -v glab)" ]; then
echo "Downloading glab"
install_latest_glab
else
GLAB_INSTALLED_VERSION=$(glab version | awk 'NR==1 {print $4}')
if [ "$GLAB_LATEST_VERSION" != "$GLAB_INSTALLED_VERSION" ]; then
echo "Updating glab from $GLAB_INSTALLED_VERSION to $GLAB_LATEST_VERSION"
install_latest_glab
else
echo "Latest version of glab already installed"
fi
fi
}
ensure_latest_helm() {
curl https://baltocdn.com/helm/signing.asc | gpg --dearmor | sudo tee /usr/share/keyrings/helm.gpg > /dev/null
echo "deb [arch=$ARCH signed-by=/usr/share/keyrings/helm.gpg] https://baltocdn.com/helm/stable/debian/ all main" | sudo tee /etc/apt/sources.list.d/helm-stable-debian.list
sudo apt-get update
sudo apt-get install helm
}
install_latest_k9s() {
curl -LO https://github.com/derailed/k9s/releases/download/$K9S_LATEST_VERSION/k9s_Linux_$ARCH.tar.gz
tar -xzvf k9s_Linux_$ARCH.tar.gz --wildcards 'k9s'
rm k9s_Linux_$ARCH.tar.gz
sudo mv ./k9s /usr/local/bin/k9s
git clone -n --depth=1 --filter=tree:0 https://github.com/derailed/k9s /tmp/k9s
pushd /tmp/k9s
git sparse-checkout set --no-cone /skins
git checkout
mkdir -p ~/.config/k9s/skins
mv -f skins/* ~/.config/k9s/skins
rm -rf /tmp/k9s
popd
}
ensure_latest_k9s() {
K9S_LATEST_VERSION=$(curl -s https://api.github.com/repos/derailed/k9s/tags | jq -r '.[0].name')
if ! [ -x "$(command -v k9s)" ]; then
echo "Downloading k9s"
install_latest_k9s
else
K9S_INSTALLED_VERSION=$(k9s version | awk '/ v/ {print $2}')
if [ "$K9S_LATEST_VERSION" != "$K9S_INSTALLED_VERSION" ]; then
echo "Updating k9s from $K9S_INSTALLED_VERSION to $K9S_LATEST_VERSION"
install_latest_k9s
else
echo "Latest version of k9s already installed"
fi
fi
}
install_latest_kind() {
curl -Lo ./kind https://github.com/kubernetes-sigs/kind/releases/download/v{$KIND_LATEST_VERSION}/kind-linux-$ARCH
chmod +x ./kind
sudo mv ./kind /usr/local/bin/kind
}
ensure_latest_kind() {
KIND_LATEST_VERSION=$(curl -s https://api.github.com/repos/kubernetes-sigs/kind/tags | jq -r '[.[] | select(.name | test("-alpha$") | not)][0].name | sub("^."; "")')
if ! [ -x "$(command -v kind)" ]; then
echo "Installing kind"
install_latest_kind
else
KIND_INSTALLED_VERSION=$(kind --version | awk '{print $3}')
if [ "$KIND_LATEST_VERSION" != "$KIND_INSTALLED_VERSION" ]; then
echo "Updating kind from $KIND_INSTALLED_VERSION to $KIND_LATEST_VERSION"
install_latest_kind
else
echo "Latest version of kind already installed"
fi
fi
}
install_latest_kubectl() {
curl -LO "https://dl.k8s.io/release/$KUBECTL_LATEST_VERSION/bin/linux/$ARCH/kubectl"
chmod +x ./kubectl
sudo mv ./kubectl /usr/local/bin/kubectl
}
ensure_latest_kubectl() {
KUBECTL_LATEST_VERSION=$(curl -L -s https://dl.k8s.io/release/stable.txt)
if ! [ -x "$(command -v kubectl)" ]; then
echo "Downloading kubectl"
install_latest_kubectl
else
KUBECTL_INSTALLED_VERSION=$(kubectl version --client=true | awk 'NR==1 {print $3}')
if [ "$KUBECTL_LATEST_VERSION" != "$KUBECTL_INSTALLED_VERSION" ]; then
echo "Updating kubectl from $KUBECTL_INSTALLED_VERSION to $KUBECTL_LATEST_VERSION"
install_latest_kubectl
else
echo "Latest version of kubectl already installed"
fi
fi
}
ensure_latest_node() {
if ! [ -x "$(command -v node)" ]; then
echo "Installing node"
curl -fsSL https://deb.nodesource.com/setup_current.x | sudo -E bash -
sudo apt install -y nodejs
fi
}
ensure_latest_powershell() {
if ! [ -x "$(command -v pwsh)" ]; then
curl -fsSL https://packages.microsoft.com/config/debian/$VERSION_ID/packages-microsoft-prod.deb -o packages-microsoft-prod.deb
sudo dpkg -i packages-microsoft-prod.deb
rm packages-microsoft-prod.deb
sudo apt-get update
sudo apt-get install -y powershell
fi
}
ensure_latest_rust() {
if ! [ -x "$(command -v rustup)" ]; then
curl --proto '=https' --tlsv1.2 -sSf https://sh.rustup.rs | sh
else
rustup self update
rustup update
fi
}
. /etc/os-release
ARCH=$(dpkg --print-architecture)
create_sudoers
create_update
sudo apt-get update
sudo apt-get upgrade -y
sudo apt-get install -y \
augeas-tools \
build-essential \
curl \
gh \
git \
gpg \
jq \
python3-pip \
unattended-upgrades \
unzip \
yq \
sudo dpkg-reconfigure -u unattended-upgrades
ensure_wsl_systemd
ensure_latest_azure_cli
ensure_latest_bun
ensure_latest_deno
ensure_latest_docker
ensure_latest_dotnet
ensure_latest_glab
ensure_latest_helm
ensure_latest_k9s
ensure_latest_kind
ensure_latest_kubectl
ensure_latest_node
ensure_latest_powershell
ensure_latest_rust