-
Notifications
You must be signed in to change notification settings - Fork 31
78 lines (76 loc) · 2.43 KB
/
nix-build-using-docker.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
name: nix-build-on-demand-docker
on:
workflow_dispatch:
inputs:
environmentName:
description: Environment name that stores configuration.nix
required: true
default: default
jobs:
build-default-image:
name: Build default image
if: ${{ github.event.inputs.environmentName == 'default' }}
runs-on: ubuntu-22.04
steps:
- uses: actions/checkout@v3.5.3
- uses: cachix/install-nix-action@v20
with:
nix_path: nixos=channel:nixos-23.05
extra_nix_config: |
extra-platforms = aarch64-linux
- name: Check nix.conf
run: cat /etc/nix/nix.conf
- name: Register binfmt
run: |
docker run --rm --privileged multiarch/qemu-user-static --reset -p yes
- name: Test binfmt availability
run: |
cat /proc/sys/fs/binfmt_misc/qemu-aarch64
- name: Build SD Image
run: |
nix-build '<nixos/nixos>' \
-A config.system.build.sdImage \
-I nixos-config=./configuration.default.sdImage.nix \
--argstr system aarch64-linux \
--option sandbox false
- uses: actions/upload-artifact@v3
with:
name: sd-image.img
path: ./result/sd-image/*.img*
build-custom-image:
name: Build custom image
if: ${{ github.event.inputs.environmentName != 'default' }}
runs-on: ubuntu-22.04
environment:
name: ${{ github.event.inputs.environmentName }}
steps:
- uses: actions/checkout@v3.5.3
- uses: cachix/install-nix-action@v20
with:
nix_path: nixos=channel:nixos-23.05
extra_nix_config: |
extra-platforms = aarch64-linux
- name: Check nix.conf
run: cat /etc/nix/nix.conf
- name: Register binfmt
run: |
docker run --rm --privileged multiarch/qemu-user-static --reset -p yes
- name: Test binfmt availability
run: |
cat /proc/sys/fs/binfmt_misc/qemu-aarch64
- name: Extract configuration from secrets
run: |
cat << EOF >> configuration.custom.sdImage.nix
${{ secrets.CONFIGURATION_NIX }}
EOF
- name: Build SD Image
run: |
nix-build '<nixos/nixos>' \
-A config.system.build.sdImage \
-I nixos-config=./configuration.custom.sdImage.nix \
--argstr system aarch64-linux \
--option sandbox false
- uses: actions/upload-artifact@v3
with:
name: sd-image.img
path: ./result/sd-image/*.img*