Skip to content

Commit d037904

Browse files
committed
brave: refactor package.nix to allow more architectures
1 parent 7cf19f3 commit d037904

File tree

2 files changed

+59
-45
lines changed

2 files changed

+59
-45
lines changed

pkgs/by-name/br/brave/package.nix

Lines changed: 28 additions & 20 deletions
Original file line numberDiff line numberDiff line change
@@ -1,24 +1,32 @@
11
# Expression generated by update.sh; do not edit it by hand!
22
{ stdenv, callPackage, ... }@args:
33

4-
callPackage ./make-brave.nix (removeAttrs args [ "callPackage" ])
5-
(
6-
if stdenv.hostPlatform.isAarch64 then
7-
rec {
8-
pname = "brave";
9-
version = "1.71.121";
10-
url = "https://github.com/brave/brave-browser/releases/download/v${version}/brave-browser_${version}_arm64.deb";
11-
hash = "sha256-+MBZXtgaEiTqEd63HpPbi4KjHOHPRRcf8q3QDe+YsKk=";
12-
platform = "aarch64-linux";
13-
}
14-
else if stdenv.hostPlatform.isx86_64 then
15-
rec {
16-
pname = "brave";
17-
version = "1.71.121";
18-
url = "https://github.com/brave/brave-browser/releases/download/v${version}/brave-browser_${version}_amd64.deb";
19-
hash = "sha256-sc2FFSttm9+yh8atJQ6KS5ZL87Ov9vUXJeVKYTPNpy0=";
20-
platform = "x86_64-linux";
21-
}
4+
let
5+
pname = "brave";
6+
version = "1.71.121";
7+
8+
allArchives = {
9+
aarch64-linux = {
10+
url = "https://github.com/brave/brave-browser/releases/download/v${version}/brave-browser_${version}_arm64.deb";
11+
hash = "sha256-+MBZXtgaEiTqEd63HpPbi4KjHOHPRRcf8q3QDe+YsKk=";
12+
};
13+
x86_64-linux = {
14+
url = "https://github.com/brave/brave-browser/releases/download/v${version}/brave-browser_${version}_amd64.deb";
15+
hash = "sha256-sc2FFSttm9+yh8atJQ6KS5ZL87Ov9vUXJeVKYTPNpy0=";
16+
};
17+
};
18+
19+
archive =
20+
if builtins.hasAttr stdenv.system allArchives then
21+
allArchives.${stdenv.system}
2222
else
23-
throw "Unsupported platform."
24-
)
23+
throw "Unsupported platform.";
24+
25+
in
26+
callPackage ./make-brave.nix (removeAttrs args [ "callPackage" ]) (
27+
archive
28+
// {
29+
inherit pname version;
30+
platform = stdenv.system;
31+
}
32+
)

pkgs/by-name/br/brave/update.sh

Lines changed: 31 additions & 25 deletions
Original file line numberDiff line numberDiff line change
@@ -1,17 +1,15 @@
11
#!/usr/bin/env nix-shell
2-
#!nix-shell -i bash -p curl gnused nix
2+
#!nix-shell -i bash -p curl gnused nix jq
33

44
SCRIPT_DIR="$(cd "$(dirname "${BASH_SOURCE[0]}")" &>/dev/null && pwd)"
55

6-
latestVersionAarch64="$(curl -sL https://brave-browser-apt-release.s3.brave.com/dists/stable/main/binary-arm64/Packages \
7-
| sed -r -n 's/^Version: (.*)/\1/p' | head -n1)"
6+
latestVersion="$(curl --fail -s ${GITHUB_TOKEN:+-u ":$GITHUB_TOKEN"} "https://api.github.com/repos/brave/brave-browser/releases/latest" | jq -r '.tag_name' | sed 's/^v//')"
7+
88
hashAarch64="$(nix hash to-sri --type sha256 \
99
$(curl -sL https://brave-browser-apt-release.s3.brave.com/dists/stable/main/binary-arm64/Packages \
1010
| sed -r -n 's/^SHA256: (.*)/\1/p' | head -n1)
1111
)"
1212

13-
latestVersionAmd64="$(curl -sL https://brave-browser-apt-release.s3.brave.com/dists/stable/main/binary-amd64/Packages \
14-
| sed -r -n 's/^Version: (.*)/\1/p' | head -n1)"
1513
hashAmd64="$(nix hash to-sri --type sha256 \
1614
$(curl -sL https://brave-browser-apt-release.s3.brave.com/dists/stable/main/binary-amd64/Packages \
1715
| sed -r -n 's/^SHA256: (.*)/\1/p' | head -n1)
@@ -21,25 +19,33 @@ cat > $SCRIPT_DIR/package.nix << EOF
2119
# Expression generated by update.sh; do not edit it by hand!
2220
{ stdenv, callPackage, ... }@args:
2321
24-
callPackage ./make-brave.nix (removeAttrs args [ "callPackage" ])
25-
(
26-
if stdenv.hostPlatform.isAarch64 then
27-
rec {
28-
pname = "brave";
29-
version = "${latestVersionAarch64}";
30-
url = "https://github.com/brave/brave-browser/releases/download/v\${version}/brave-browser_\${version}_arm64.deb";
31-
hash = "${hashAarch64}";
32-
platform = "aarch64-linux";
33-
}
34-
else if stdenv.hostPlatform.isx86_64 then
35-
rec {
36-
pname = "brave";
37-
version = "${latestVersionAmd64}";
38-
url = "https://github.com/brave/brave-browser/releases/download/v\${version}/brave-browser_\${version}_amd64.deb";
39-
hash = "${hashAmd64}";
40-
platform = "x86_64-linux";
41-
}
22+
let
23+
pname = "brave";
24+
version = "${latestVersion}";
25+
26+
allArchives = {
27+
aarch64-linux = {
28+
url = "https://github.com/brave/brave-browser/releases/download/v\${version}/brave-browser_\${version}_arm64.deb";
29+
hash = "${hashAarch64}";
30+
};
31+
x86_64-linux = {
32+
url = "https://github.com/brave/brave-browser/releases/download/v\${version}/brave-browser_\${version}_amd64.deb";
33+
hash = "${hashAmd64}";
34+
};
35+
};
36+
37+
archive =
38+
if builtins.hasAttr stdenv.system allArchives then
39+
allArchives.\${stdenv.system}
4240
else
43-
throw "Unsupported platform."
44-
)
41+
throw "Unsupported platform.";
42+
43+
in
44+
callPackage ./make-brave.nix (removeAttrs args [ "callPackage" ]) (
45+
archive
46+
// {
47+
inherit pname version;
48+
platform = stdenv.system;
49+
}
50+
)
4551
EOF

0 commit comments

Comments
 (0)