-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathflake.nix
63 lines (60 loc) · 1.78 KB
/
flake.nix
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
{
inputs = {
nixpkgs.url = "github:NixOS/nixpkgs/nixos-24.11";
nixos-generators = {
url = "github:nix-community/nixos-generators";
inputs.nixpkgs.follows = "nixpkgs";
};
flake-utils.url = "github:numtide/flake-utils";
};
outputs =
{
self,
nixpkgs,
nixos-generators,
flake-utils,
...
}:
flake-utils.lib.eachDefaultSystem (
system:
let
pkgs = import nixpkgs { inherit system; };
in
{
builders = {
gceImage =
{
extraModules ? [ ],
}:
nixos-generators.nixosGenerate {
system = "x86_64-linux";
modules = [
./configuration.nix
] ++ extraModules;
format = "gce";
pkgs = nixpkgs.legacyPackages.x86_64-linux;
lib = nixpkgs.legacyPackages.x86_64-linux.lib;
};
uploadGceImage =
{
bucket,
gceImage,
imagePrefixName,
}:
let
imgId = pkgs.runCommand "sanitizedImgId" { } ''
echo -n ${imagePrefixName} | ${pkgs.gnused}/bin/sed 's|.raw.tar.gz$||;s|\.|-|g;s|_|-|g' > $out
'';
in
pkgs.writeShellScriptBin "handler" ''
set -euo pipefail
${pkgs.google-cloud-sdk}/bin/gsutil cp ${gceImage}/*.raw.tar.gz "gs://${bucket}/${imagePrefixName}.raw.tar.gz"
${pkgs.google-cloud-sdk}/bin/gcloud compute images create ${builtins.readFile imgId} \
--source-uri "gs://${bucket}/${imagePrefixName}.raw.tar.gz" \
--family="nixos-image-gitlab-runner" \
--guest-os-features=GVNIC
'';
};
}
);
}