depot/third_party/nixpkgs/patches/pr138359-pomerium-bump.patch

420 lines
14 KiB
Diff

From 786b4216c5481d8826c42defabed4721a74e1cd0 Mon Sep 17 00:00:00 2001
From: Luke Granger-Brown <git@lukegb.com>
Date: Sat, 18 Sep 2021 02:55:10 +0000
Subject: [PATCH 1/4] gn1924: init at 2021-08-08, use generic derivation
generator
Split into "current" version, as used by most things (aka gn),
and "gn1924", which uses a more recent version of gn which is
incompatible with the currently packaged version of v8 in nixpkgs.
We can't win, but I need a newer version of gn for envoy.
Note that the newer gn matches the version in Chromium's DEPS for
v93.0.4577.82, the current Linux stable build as of September.
---
.../tools/build-managers/gn/default.nix | 58 +-----------------
.../tools/build-managers/gn/generic.nix | 60 +++++++++++++++++++
.../tools/build-managers/gn/rev1924.nix | 8 +++
3 files changed, 70 insertions(+), 56 deletions(-)
create mode 100644 pkgs/development/tools/build-managers/gn/generic.nix
create mode 100644 pkgs/development/tools/build-managers/gn/rev1924.nix
diff --git a/pkgs/development/tools/build-managers/gn/default.nix b/pkgs/development/tools/build-managers/gn/default.nix
index 3c0abb3edeab5..508a821d74950 100644
--- a/pkgs/development/tools/build-managers/gn/default.nix
+++ b/pkgs/development/tools/build-managers/gn/default.nix
@@ -1,64 +1,10 @@
-{ stdenv, lib, fetchgit, darwin, writeText
-, ninja, python3
-}:
+{ callPackage, ... } @ args:
-let
+callPackage ./generic.nix args {
# Note: Please use the recommended version for Chromium, e.g.:
# https://git.archlinux.org/svntogit/packages.git/tree/trunk/chromium-gn-version.sh?h=packages/gn
rev = "fd3d768bcfd44a8d9639fe278581bd9851d0ce3a";
revNum = "1718"; # git describe HEAD --match initial-commit | cut -d- -f3
version = "2020-03-09";
sha256 = "1asc14y8by7qcn10vbk467hvx93s30pif8r0brissl0sihsaqazr";
-
- revShort = builtins.substring 0 7 rev;
- lastCommitPosition = writeText "last_commit_position.h" ''
- #ifndef OUT_LAST_COMMIT_POSITION_H_
- #define OUT_LAST_COMMIT_POSITION_H_
-
- #define LAST_COMMIT_POSITION_NUM ${revNum}
- #define LAST_COMMIT_POSITION "${revNum} (${revShort})"
-
- #endif // OUT_LAST_COMMIT_POSITION_H_
- '';
-
-in stdenv.mkDerivation {
- pname = "gn-unstable";
- inherit version;
-
- src = fetchgit {
- # Note: The TAR-Archives (+archive/${rev}.tar.gz) are not deterministic!
- url = "https://gn.googlesource.com/gn";
- inherit rev sha256;
- };
-
- nativeBuildInputs = [ ninja python3 ];
- buildInputs = lib.optionals stdenv.isDarwin (with darwin; with apple_sdk.frameworks; [
- libobjc
- cctools
-
- # frameworks
- ApplicationServices
- Foundation
- AppKit
- ]);
-
- buildPhase = ''
- python build/gen.py --no-last-commit-position
- ln -s ${lastCommitPosition} out/last_commit_position.h
- ninja -j $NIX_BUILD_CORES -C out gn
- '';
-
- installPhase = ''
- install -vD out/gn "$out/bin/gn"
- '';
-
- setupHook = ./setup-hook.sh;
-
- meta = with lib; {
- description = "A meta-build system that generates build files for Ninja";
- homepage = "https://gn.googlesource.com/gn";
- license = licenses.bsd3;
- platforms = platforms.unix;
- maintainers = with maintainers; [ stesie matthewbauer primeos ];
- };
}
diff --git a/pkgs/development/tools/build-managers/gn/generic.nix b/pkgs/development/tools/build-managers/gn/generic.nix
new file mode 100644
index 0000000000000..4214bb822b994
--- /dev/null
+++ b/pkgs/development/tools/build-managers/gn/generic.nix
@@ -0,0 +1,60 @@
+{ stdenv, lib, fetchgit, darwin, writeText
+, ninja, python3
+, ...
+}:
+
+{ rev, revNum, version, sha256 }:
+
+let
+ revShort = builtins.substring 0 7 rev;
+ lastCommitPosition = writeText "last_commit_position.h" ''
+ #ifndef OUT_LAST_COMMIT_POSITION_H_
+ #define OUT_LAST_COMMIT_POSITION_H_
+
+ #define LAST_COMMIT_POSITION_NUM ${revNum}
+ #define LAST_COMMIT_POSITION "${revNum} (${revShort})"
+
+ #endif // OUT_LAST_COMMIT_POSITION_H_
+ '';
+
+in stdenv.mkDerivation {
+ pname = "gn-unstable";
+ inherit version;
+
+ src = fetchgit {
+ # Note: The TAR-Archives (+archive/${rev}.tar.gz) are not deterministic!
+ url = "https://gn.googlesource.com/gn";
+ inherit rev sha256;
+ };
+
+ nativeBuildInputs = [ ninja python3 ];
+ buildInputs = lib.optionals stdenv.isDarwin (with darwin; with apple_sdk.frameworks; [
+ libobjc
+ cctools
+
+ # frameworks
+ ApplicationServices
+ Foundation
+ AppKit
+ ]);
+
+ buildPhase = ''
+ python build/gen.py --no-last-commit-position
+ ln -s ${lastCommitPosition} out/last_commit_position.h
+ ninja -j $NIX_BUILD_CORES -C out gn
+ '';
+
+ installPhase = ''
+ install -vD out/gn "$out/bin/gn"
+ '';
+
+ setupHook = ./setup-hook.sh;
+
+ meta = with lib; {
+ description = "A meta-build system that generates build files for Ninja";
+ homepage = "https://gn.googlesource.com/gn";
+ license = licenses.bsd3;
+ platforms = platforms.unix;
+ maintainers = with maintainers; [ stesie matthewbauer primeos ];
+ };
+}
diff --git a/pkgs/development/tools/build-managers/gn/rev1924.nix b/pkgs/development/tools/build-managers/gn/rev1924.nix
new file mode 100644
index 0000000000000..1b17328f2e095
--- /dev/null
+++ b/pkgs/development/tools/build-managers/gn/rev1924.nix
@@ -0,0 +1,8 @@
+{ callPackage, ... } @ args:
+
+callPackage ./generic.nix args {
+ rev = "24e2f7df92641de0351a96096fb2c490b2436bb8";
+ revNum = "1924"; # git describe HEAD --match initial-commit | cut -d- -f3
+ version = "2021-08-08";
+ sha256 = "1lwkyhfhw0zd7daqz466n7x5cddf0danr799h4jg3s0yvd4galjl";
+}
From 637d735ad55d3d69bab6a4360327db8f988b86bb Mon Sep 17 00:00:00 2001
From: Luke Granger-Brown <git@lukegb.com>
Date: Sat, 18 Sep 2021 02:56:17 +0000
Subject: [PATCH 2/4] envoy: 1.17.3 -> 1.19.1
This now uses gn1924 to allow v8 to build properly.
---
pkgs/servers/http/envoy/default.nix | 14 ++++----------
pkgs/top-level/all-packages.nix | 2 ++
2 files changed, 6 insertions(+), 10 deletions(-)
diff --git a/pkgs/servers/http/envoy/default.nix b/pkgs/servers/http/envoy/default.nix
index d26782560a470..c81d79dbb24be 100644
--- a/pkgs/servers/http/envoy/default.nix
+++ b/pkgs/servers/http/envoy/default.nix
@@ -17,8 +17,8 @@ let
# However, the version string is more useful for end-users.
# These are contained in a attrset of their own to make it obvious that
# people should update both.
- version = "1.17.3";
- commit = "46bf743b97d0d3f01ff437b2f10cc0bd9cdfe6e4";
+ version = "1.19.1";
+ commit = "a2a1e3eed4214a38608ec223859fcfa8fb679b14";
};
in
buildBazelPackage rec {
@@ -28,7 +28,7 @@ buildBazelPackage rec {
owner = "envoyproxy";
repo = "envoy";
rev = srcVer.commit;
- hash = "sha256:09zzr4h3zjsb2rkxrvlazpx0jy33yn9j65ilxiqbvv0ckaralqfc";
+ hash = "sha256:1v1hv4blrppnhllsxd9d3k2wl6nhd59r4ydljy389na3bb41jwf9";
extraPostFetch = ''
chmod -R +w $out
@@ -58,7 +58,7 @@ buildBazelPackage rec {
];
fetchAttrs = {
- sha256 = "sha256:1cy2b73x8jzczq9z9c1kl7zrg5iasvsakb50zxn4mswpmajkbj5h";
+ sha256 = "sha256:0vnl0gq6nhvyzz39jg1bvvna0xyhxalg71bp1jbxib7ql026004r";
dontUseCmakeConfigure = true;
dontUseGnConfigure = true;
preInstall = ''
@@ -75,12 +75,6 @@ buildBazelPackage rec {
$bazelOut/external/local_config_sh/BUILD
rm -r $bazelOut/external/go_sdk
- # Replace some wheels which are only used for tests with empty files;
- # they're nondeterministically built and packed.
- >$bazelOut/external/config_validation_pip3/PyYAML-5.3.1-cp38-cp38-linux_x86_64.whl
- >$bazelOut/external/protodoc_pip3/PyYAML-5.3.1-cp38-cp38-linux_x86_64.whl
- >$bazelOut/external/thrift_pip3/thrift-0.13.0-cp38-cp38-linux_x86_64.whl
-
# Remove Unix timestamps from go cache.
rm -rf $bazelOut/external/bazel_gazelle_go_repository_cache/{gocache,pkg/mod/cache,pkg/sumdb}
'';
diff --git a/pkgs/top-level/all-packages.nix b/pkgs/top-level/all-packages.nix
index 542235a61f109..3cfdd5f4edb85 100644
--- a/pkgs/top-level/all-packages.nix
+++ b/pkgs/top-level/all-packages.nix
@@ -14956,6 +14956,7 @@ with pkgs;
nimbo = with python3Packages; callPackage ../applications/misc/nimbo { };
gn = callPackage ../development/tools/build-managers/gn { };
+ gn1924 = callPackage ../development/tools/build-managers/gn/rev1924.nix { };
nixbang = callPackage ../development/tools/misc/nixbang {
pythonPackages = python3Packages;
@@ -20738,6 +20739,7 @@ with pkgs;
envoy = callPackage ../servers/http/envoy {
go = go_1_15;
jdk = openjdk11;
+ gn = gn1924;
};
etcd = callPackage ../servers/etcd { };
From 4099f938597110708889eed18e81511fdfecc1db Mon Sep 17 00:00:00 2001
From: Luke Granger-Brown <git@lukegb.com>
Date: Sat, 18 Sep 2021 02:57:32 +0000
Subject: [PATCH 3/4] pomerium: 0.14.7 -> 0.15.7
---
pkgs/servers/http/pomerium/default.nix | 39 +++++++++++++-------------
1 file changed, 20 insertions(+), 19 deletions(-)
diff --git a/pkgs/servers/http/pomerium/default.nix b/pkgs/servers/http/pomerium/default.nix
index 7b28200b284e6..9f24d64ae6ca8 100644
--- a/pkgs/servers/http/pomerium/default.nix
+++ b/pkgs/servers/http/pomerium/default.nix
@@ -11,15 +11,15 @@ let
in
buildGoModule rec {
pname = "pomerium";
- version = "0.14.7";
+ version = "0.15.7";
src = fetchFromGitHub {
owner = "pomerium";
repo = "pomerium";
rev = "v${version}";
- hash = "sha256:1jb96jk5qmary4fi1z9zwmppdyskj0qb6qii8s8mwazjjxqj1z2s";
+ hash = "sha256:0adlk4ylny1z43x1dw3ny0s1932vhb61hpf5wdz4r65y8k9qyfgr";
};
- vendorSha256 = "sha256:1daabi9qc9nx8bafn26iw6rv4vx2xpd0nnk06265aqaksx26db0s";
+ vendorSha256 = "sha256:1fszfbra84pcs8v1h2kf7iy603vf9v2ysg6il76aqmqrxmb1p7nv";
subPackages = [
"cmd/pomerium"
"cmd/pomerium-cli"
@@ -38,24 +38,25 @@ buildGoModule rec {
"${varFlags}"
];
- nativeBuildInputs = [
- zip
- ];
+ preBuild = ''
+ rm internal/envoy/files/files_{darwin,linux}*.go
+ cat <<EOF >internal/envoy/files/files_generic.go
+ package files
+
+ import _ "embed" // embed
+
+ //go:embed envoy
+ var rawBinary []byte
- # Pomerium expects to have envoy append to it in a zip.
- # We use a store-only (-0) zip, so that the Nix scanner can find any store references we had in the envoy binary.
- postBuild = ''
- # Append Envoy
- pushd $NIX_BUILD_TOP
- mkdir -p envoy
- cd envoy
- cp ${envoy}/bin/envoy envoy
- zip -0 envoy.zip envoy
- popd
+ //go:embed envoy.sha256
+ var rawChecksum string
- mv $GOPATH/bin/pomerium $GOPATH/bin/pomerium.old
- cat $GOPATH/bin/pomerium.old $NIX_BUILD_TOP/envoy/envoy.zip >$GOPATH/bin/pomerium
- zip --adjust-sfx $GOPATH/bin/pomerium
+ //go:embed envoy.version
+ var rawVersion string
+ EOF
+ cp ${envoy}/bin/envoy internal/envoy/files/envoy
+ sha256sum ${envoy}/bin/envoy > internal/envoy/files/envoy.sha256
+ echo ${envoy.version} > internal/envoy/files/envoy.version
'';
# We also need to set dontStrip to avoid having the envoy ZIP stripped off the end.
From 74560e35e5c8ada70bb170be352d8996160f7be3 Mon Sep 17 00:00:00 2001
From: Luke Granger-Brown <git@lukegb.com>
Date: Tue, 7 Dec 2021 15:04:09 +0000
Subject: [PATCH 4/4] pomerium: use on-disk envoy
MIME-Version: 1.0
Content-Type: text/plain; charset=UTF-8
Content-Transfer-Encoding: 8bit
We can set an override path for Envoy's binary location now, so
do that instead of the previous thing of embedding the binary.
Note that we still need to include the SHA256/version of the binary
we're referring to, but Through The Power Of Nix™ we can do that
with relative ease.
---
pkgs/servers/http/pomerium/default.nix | 36 ++++++++++++++++----------
1 file changed, 23 insertions(+), 13 deletions(-)
diff --git a/pkgs/servers/http/pomerium/default.nix b/pkgs/servers/http/pomerium/default.nix
index 9f24d64ae6ca8..cbf2fe1943542 100644
--- a/pkgs/servers/http/pomerium/default.nix
+++ b/pkgs/servers/http/pomerium/default.nix
@@ -7,7 +7,7 @@
}:
let
- inherit (lib) concatStringsSep mapAttrsToList;
+ inherit (lib) concatStringsSep concatMap id mapAttrsToList;
in
buildGoModule rec {
pname = "pomerium";
@@ -28,24 +28,38 @@ buildGoModule rec {
ldflags = let
# Set a variety of useful meta variables for stamping the build with.
setVars = {
- Version = "v${version}";
- BuildMeta = "nixpkgs";
- ProjectName = "pomerium";
- ProjectURL = "github.com/pomerium/pomerium";
+ "github.com/pomerium/pomerium/internal/version" = {
+ Version = "v${version}";
+ BuildMeta = "nixpkgs";
+ ProjectName = "pomerium";
+ ProjectURL = "github.com/pomerium/pomerium";
+ };
+ "github.com/pomerium/pomerium/internal/envoy" = {
+ OverrideEnvoyPath = "${envoy}/bin/envoy";
+ };
};
- varFlags = concatStringsSep " " (mapAttrsToList (name: value: "-X github.com/pomerium/pomerium/internal/version.${name}=${value}") setVars);
+ concatStringsSpace = list: concatStringsSep " " list;
+ mapAttrsToFlatList = fn: list: concatMap id (mapAttrsToList fn list);
+ varFlags = concatStringsSpace (
+ mapAttrsToFlatList (package: packageVars:
+ mapAttrsToList (variable: value:
+ "-X ${package}.${variable}=${value}"
+ ) packageVars
+ ) setVars);
in [
"${varFlags}"
];
preBuild = ''
+ # Replace embedded envoy with nothing.
+ # We set OverrideEnvoyPath above, so rawBinary should never get looked at
+ # but we still need to set a checksum/version.
rm internal/envoy/files/files_{darwin,linux}*.go
cat <<EOF >internal/envoy/files/files_generic.go
package files
import _ "embed" // embed
- //go:embed envoy
var rawBinary []byte
//go:embed envoy.sha256
@@ -54,14 +68,10 @@ buildGoModule rec {
//go:embed envoy.version
var rawVersion string
EOF
- cp ${envoy}/bin/envoy internal/envoy/files/envoy
- sha256sum ${envoy}/bin/envoy > internal/envoy/files/envoy.sha256
- echo ${envoy.version} > internal/envoy/files/envoy.version
+ sha256sum '${envoy}/bin/envoy' > internal/envoy/files/envoy.sha256
+ echo '${envoy.version}' > internal/envoy/files/envoy.version
'';
- # We also need to set dontStrip to avoid having the envoy ZIP stripped off the end.
- dontStrip = true;
-
installPhase = ''
install -Dm0755 $GOPATH/bin/pomerium $out/bin/pomerium
install -Dm0755 $GOPATH/bin/pomerium-cli $out/bin/pomerium-cli