-
Notifications
You must be signed in to change notification settings - Fork 0
74 lines (71 loc) · 3.04 KB
/
ci.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
name: ci
on:
push:
jobs:
build:
runs-on: ubuntu-latest
if: github.ref == 'refs/heads/master'
permissions:
contents: write
outputs:
artifact_source_url: ${{ steps.upload.outputs.sunsetglow_artifact_url }}
env:
ACTIONS_ALLOW_UNSECURE_COMMANDS: true
steps:
- uses: actions/checkout@v3
- uses: cachix/install-nix-action@v20
- uses: cachix/cachix-action@v12
with:
name: sunsetglow
authToken: '${{ secrets.CACHIX_AUTH_TOKEN }}'
- name: Build Nix
run: nix build -j8 .#devShells.x86_64-linux.build
- name: Build Website
run: nix develop .#devShells.x86_64-linux.build --command make build
- name: Create Tarball
run: nix develop .#devShells.x86_64-linux.build --command bash -c '(cd dist/ && tar -czvf ../sunsetglow.tar.gz *)'
- name: Create release and upload tarball
id: upload
run: |
commit_sha="$(git rev-parse --short HEAD)"
timestamp="$(date +%Y-%m-%d_%H-%M-%S)"
release_name="sunsetglow-${timestamp}-${commit_sha}"
token=${{ secrets.GITHUB_TOKEN }}
# https://docs.github.com/en/rest/releases/releases#create-a-release
# https://stackoverflow.com/questions/45240336/how-to-use-github-release-api-to-make-a-release-without-source-code
upload_url="$(curl -s -H "Authorization: token $token" \
-d "{\"tag_name\": \"$release_name\", \"name\":\"$release_name\",\"target_comitish\": \"$commit_sha\"}" \
"https://api.github.com/repos/azuline/sunsetglow/releases" | jq -r '.upload_url')"
upload_url="${upload_url%\{*}"
echo "Created release $release_name"
artifact_url="$(curl -s -H "Authorization: token $token" \
-H "Content-Type: application/gzip" \
--data-binary @sunsetglow.tar.gz \
"$upload_url?name=sunsetglow.tar.gz&label=sunsetglow.tar.gz" | jq -r '.browser_download_url')"
echo "Uploaded sunsetglow.tar.gz to release"
echo "sunsetglow_artifact_url=${artifact_url}"
echo "sunsetglow_artifact_url=${artifact_url}" >> $GITHUB_OUTPUT
deploy:
runs-on: ubuntu-latest
needs: build
env:
ACTIONS_ALLOW_UNSECURE_COMMANDS: true
ARTIFACT_SOURCE_URL: ${{ needs.build-sunsetglow.outputs.artifact_source_url }}
NOMAD_ADDR: http://100.84.146.55:4646
NOMAD_NAMESPACE: sunsetglow
NOMAD_TOKEN: ${{ secrets.NOMAD_TOKEN }}
steps:
- uses: actions/checkout@v3
- uses: cachix/install-nix-action@v20
- uses: cachix/cachix-action@v12
with:
name: sunsetglow
authToken: '${{ secrets.CACHIX_AUTH_TOKEN }}'
- name: Tailscale
uses: tailscale/github-action@v1
with:
authkey: ${{ secrets.TAILSCALE_AUTHKEY }}
- name: Build Nix
run: nix build -j8 .#devShells.x86_64-linux.deploy
- name: Deploy
run: nix develop .#devShells.x86_64-linux.deploy --command levant deploy -log-level=debug -var "artifact_source_url=$ARTIFACT_SOURCE_URL" deploy.nomad