summaryrefslogtreecommitdiff
path: root/parts/deployment.nix
blob: 178ae1b4302ff8f6cbaaed37d436bc7ff242dbdb (plain)
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
{
  inputs,
  self,
  ...
}: {
  flake.nixosModules.default = import ./module.nix self;

  perSystem = {
    lib,
    pkgs,
    system,
    config,
    inputs',
    ...
  }: let
    name = "getchoo/teawiebot";

    crossPkgsFor = lib.fix (finalAttrs: {
      "x86_64-linux" = {
        "amd64" = pkgs.pkgsStatic;
        "arm64v8" = pkgs.pkgsCross.aarch64-multiplatform.pkgsStatic;
      };

      "aarch64-linux" = {
        "amd64" = pkgs.pkgsCross.musl64;
        "arm64v8" = pkgs.pkgsStatic;
      };

      "x86_64-darwin" = {
        "amd64" = pkgs.pkgsCross.musl64;
        "arm64v8" = pkgs.pkgsCross.aarch64-multiplatform.pkgsStatic;
      };

      "aarch64-darwin" = finalAttrs."x86_64-darwin";
    });

    nativeArchFor = {
      "amd64" = "x86_64";
      "arm64v8" = "aarch64";
    };

    wieFor = arch: let
      target = "${nativeArchFor.${arch}}-unknown-linux-musl";
      target' = builtins.replaceStrings ["-"] ["_"] target;
      targetUpper = lib.toUpper target';

      toolchain = with inputs'.fenix.packages;
        combine [
          minimal.cargo
          minimal.rustc
          targets.${target}.latest.rust-std
        ];

      naersk' = inputs.naersk.lib.${system}.override {
        cargo = toolchain;
        rustc = toolchain;
      };

      teawiebot = config.packages.teawiebot.override {
        naersk = naersk';
        optimizeSize = true;
      };

      inherit (crossPkgsFor.${system}.${arch}.stdenv) cc;
    in
      lib.getExe (
        teawiebot.overrideAttrs (_:
          lib.fix (finalAttrs: {
            CARGO_BUILD_TARGET = target;
            "CC_${target'}" = "${cc}/bin/${cc.targetPrefix}cc";
            "CARGO_TARGET_${targetUpper}_RUSTFLAGS" = "-C target-feature=+crt-static";
            "CARGO_TARGET_${targetUpper}_LINKER" = finalAttrs."CC_${target'}";
          }))
      );

    toContainer = arch:
      assert lib.assertMsg (
        arch == "arch64" -> pkgs.stdenv.isLinux
      ) "aarch64 images are only supported on linux!";
        pkgs.dockerTools.buildLayeredImage {
          inherit name;
          tag = "latest-${arch}";
          contents = [pkgs.dockerTools.caCertificates];
          config.Cmd = [(wieFor arch)];

          architecture = crossPkgsFor.${system}.${arch}.go.GOARCH;
        };
  in {
    packages = {
      container-amd64 = toContainer "amd64";
      container-arm64v8 = toContainer "arm64v8";
    };
  };
}