-
-
Notifications
You must be signed in to change notification settings - Fork 93
60 lines (57 loc) · 1.64 KB
/
darwin.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
name: "darwin"
on:
push:
branches: [master]
workflow_dispatch:
concurrency:
group: "darwin"
cancel-in-progress: false
jobs:
deploy:
environment:
name: darwin
strategy:
fail-fast: false
matrix:
host: [darwin01, darwin02]
runs-on: ubuntu-latest
timeout-minutes: 15
steps:
- uses: actions/checkout@v4
- name: Install Nix
uses: cachix/install-nix-action@v30
with:
extra_nix_config: |
accept-flake-config = true
experimental-features = nix-command flakes
- name: Setup SSH
env:
SSH_KEY: "${{ secrets.SSH_KEY }}"
run: |
mkdir -p "$HOME/.ssh"
cat >>"$HOME/.ssh/id_ed25519" <<EOF
$SSH_KEY
EOF
chmod 600 "$HOME/.ssh/id_ed25519"
known_hosts="$(nix eval .#nixosConfigurations.build01.config.environment.etc.'ssh/ssh_known_hosts'.text)"
echo -e "$known_hosts" >>"$HOME/.ssh/known_hosts"
cat >>"$HOME/.ssh/config" <<EOF
Host *
IdentityFile ~/.ssh/id_ed25519
IdentitiesOnly yes
EOF
- name: Deploy
run: |
./inv deploy --hosts ${{ matrix.host }}
- name: Alert on failure
if: ${{ failure() }}
run: |
curl -XPOST -d '{"msgtype":"m.text", "body":"${{ matrix.host }}: deployment failed"}' \
"https://matrix.org/_matrix/client/r0/rooms/!cBybDCkeRlSWfuaFvn:numtide.com/send/m.room.message?access_token=${{ secrets.TOKEN_MATRIX_BOT }}"
collect:
environment:
name: darwin
needs: deploy
runs-on: ubuntu-latest
steps:
- run: echo