ts-reverse-proxy/flake.nix

44 lines
1.3 KiB
Nix

{
description = "ts-reverse-proxy: a TailScale aware reverse proxy";
inputs.nixpkgs.url = "nixpkgs/nixos-unstable";
outputs = { self, nixpkgs }:
let
supportedSystems =
[ "x86_64-linux" "x86_64-darwin" "aarch64-linux" "aarch64-darwin" ];
forAllSystems = nixpkgs.lib.genAttrs supportedSystems;
nixpkgsFor = forAllSystems (system: import nixpkgs { inherit system; });
in {
overlay = final: prev: {
inherit (self.packages.${prev.system}) ts-reverse-proxy;
};
packages = forAllSystems (system:
let pkgs = nixpkgsFor.${system};
in {
ts-reverse-proxy = pkgs.buildGo120Module {
pname = "ts-reverse-proxy";
version = "v0.2.1";
src = ./.;
vendorSha256 = "sha256-L9XWqXlVoUVEGcic7X1x8dbgvE9VopNxTrdzF+jFPB4=";
};
});
defaultPackage = forAllSystems (system: self.packages.${system}.ts-reverse-proxy);
devShells = forAllSystems (system:
let pkgs = nixpkgsFor.${system};
in {
default = pkgs.mkShell {
shellHook = ''
PS1='\u@\h:\@; '
echo "Go `${pkgs.go}/bin/go version`"
nix run github:qbit/xin#flake-warn
'';
nativeBuildInputs = with pkgs; [ git go_1_20 gopls go-tools graphviz ];
};
});
};
}