# SPDX-FileCopyrightText: 2020 Luke Granger-Brown <depot@lukegb.com> # # SPDX-License-Identifier: Apache-2.0 { depot, system, ... }@ch: let nixpkgsConfig = { allowUnfree = true; checkMeta = false; permittedInsecurePackages = [ "nodejs-16.20.2" # for openvscode-server ]; packageOverrides = pkgs: { factorio = pkgs.factorio.override depot.ops.secrets.factorio; factorio-experimental = pkgs.factorio-experimental.override depot.ops.secrets.factorio; ntfy = (pkgs.ntfy.override { withXmpp = false; withSlack = false; python39 = pkgs.python3; }).overridePythonAttrs (oldAttrs: { doCheck = false; checkPhase = ""; }); delve = pkgs.delve.overrideAttrs (oldAttrs: { meta = oldAttrs.meta // { platforms = oldAttrs.meta.platforms ++ [ "aarch64-linux" ]; }; }); }; }; nixpkgs = import ./nixpkgs { inherit system; config = nixpkgsConfig; overlays = [(final: prev: { go_1_20_socket = prev.go_1_20.overrideAttrs (old: { patches = old.patches ++ [(final.fetchpatch { url = "https://go.googlesource.com/go/+/ad087ee2804b7ce088161df04403c93ddc623888%5E%21?format=TEXT"; sha256 = "14z1rgn2qhmzhk9b8iksdknzrf0fbbhabqngcz5jlskc8vwdd14v"; decode = "base64 -d"; })]; }); vault = prev.vault.override { buildGoModule = prev.buildGoModule.override { go = final.go_1_20_socket; }; }; go_1_19_socket = prev.go_1_19.overrideAttrs (old: { patches = old.patches ++ [(final.fetchpatch { url = "https://go.googlesource.com/go/+/ad087ee2804b7ce088161df04403c93ddc623888%5E%21?format=TEXT"; sha256 = "14z1rgn2qhmzhk9b8iksdknzrf0fbbhabqngcz5jlskc8vwdd14v"; decode = "base64 -d"; })]; }); })]; }; crate2nixSrc = nixpkgs.fetchFromGitHub { owner = "kolloch"; repo = "crate2nix"; rev = "e07af104b8e41d1cd7e41dc7ac3fdcdf4953efae"; hash = "sha256:07syygn1rc5n1big7hf42pzgm5wc1r0mzglzvlbcb7rkzgqqhbqx"; }; naerskSrc = nixpkgs.fetchFromGitHub { owner = "nmattia"; repo = "naersk"; rev = "e0fe990b478a66178a58c69cf53daec0478ca6f9"; sha256 = "sha256:0qjyfmw5v7s6ynjns4a61vlyj9cghj7vbpgrp9147ngb1f8krz2c"; }; tvlDepot = import ./tvl { nixpkgsBisectPath = ./nixpkgs; inherit nixpkgsConfig; nixpkgsSystem = system; }; in rec { inherit nixpkgsConfig nixpkgs; nixos = import ./nixpkgs/nixos; nixeval = import ./nixpkgs/nixos/lib/eval-config.nix; buildGo = let orig = import ./tvl/nix/buildGo { pkgs = nixpkgs; inherit gopkgs; }; in orig // { program = { dockerData ? [], ... }@args: let origOut = orig.program (nixpkgs.lib.filterAttrs (n: v: n != "dockerData") args); in origOut // { dockerImage = nixpkgs.dockerTools.buildImage { name = args.name; copyToRoot = nixpkgs.buildEnv { name = "${args.name}-env"; paths = dockerData; }; config = { Entrypoint = [ "${origOut}/bin/${args.name}" ]; Env = [ "SSL_CERT_FILE=${nixpkgs.cacert}/etc/ssl/certs/ca-bundle.crt" ]; }; }; }; }; readTree = import ./tvl/nix/readTree {}; gopkgs = readTree { args = ch; path = ./gopkgs; }; bat_syntaxes = tvlDepot.third_party.bat_syntaxes; cheddar = tvlDepot.tools.cheddar; naersk = nixpkgs.callPackage naerskSrc {}; crate2nix = import "${crate2nixSrc}" { pkgs = ch.depot.pkgs; }; }