aboutsummaryrefslogtreecommitdiff
path: root/default.nix
blob: 171a3a96ae52b3d333effffa7746bdee014fc293 (plain) (blame)
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
let pkgs = import <nixpkgs> { };
in rec {
  utils = import ./utils.nix {
    pkgs = pkgs;
    src = pkgs.nix-gitignore.gitignoreSource [ ] ./.;
    baseName = "vps";
  };
  subtasks = rec {
    formatTerraform = utils.baseTask.overrideAttrs (baseAttrs: {
      name = "${baseAttrs.name}-format-terraform";
      buildInputs = baseAttrs.buildInputs ++ [ pkgs.terraform ];
      buildPhase = ''
        terraform fmt -check=true -diff=true || {
          echo "Terraform files are unformatted. To fix it, run:"
          echo "  terraform fmt"
          exit 1
        }
        touch $out
      '';
    });
    dockerComposeLint = utils.baseTask.overrideAttrs (baseAttrs: {
      name = "${baseAttrs.name}-docker-compose-lint";
      buildInputs = baseAttrs.buildInputs ++ [ pkgs.docker-compose ];
      buildPhase = ''
        source .envrc
        # =docker-compose config= doesn't accept files with different names
        cp docker-compose.env.yaml docker-compose.yaml
        docker-compose config &> /dev/null || {
          echo "Invalid docker-compose.yml file."
          exit 1
        }
        touch $out
      '';
    });
    shellBuildInputs = with pkgs; [
      file
      gitMinimal
      git-crypt
      gettext
      terraform-providers.vultr
      terraform
      ansible
    ];
  };
  test = utils.test [
    (utils.shellcheck null)
    (utils.fixme null)
    (utils.shellEnvironmentBuild subtasks.shellBuildInputs)
    utils.formatNix
    subtasks.formatTerraform
    subtasks.dockerComposeLint
  ];
  shell = utils.shellEnvironment subtasks.shellBuildInputs;
}