Skip to content

Commit

Permalink
Added fetchfirefoxaddon
Browse files Browse the repository at this point in the history
  • Loading branch information
Qubasa authored and Mic92 committed Dec 2, 2020
1 parent eedee46 commit 397597f
Show file tree
Hide file tree
Showing 3 changed files with 49 additions and 32 deletions.
41 changes: 9 additions & 32 deletions pkgs/applications/networking/browsers/firefox/wrapper.nix
Expand Up @@ -35,9 +35,13 @@ let
, cfg ? config.${browserName} or {}

## Following options are needed for extra prefs & policies
# For more information about anti tracking (german website)
# vist https://wiki.kairaven.de/open/app/firefo
, extraPrefs ? ""
# For more information about policies visit
# https://github.com/mozilla/policy-templates#enterprisepoliciesenabled
, extraPolicies ? {}
, firefoxLibName ? "firefox"
, firefoxLibName ? "firefox" # Important for tor package or the like
, extraExtensions ? [ ]
}:

Expand Down Expand Up @@ -98,37 +102,10 @@ let
(builtins.toJSON enterprisePolicies);

extensions = builtins.map (a:
if ! (builtins.hasAttr "name" a) || ! (builtins.isString a.name) then
throw "Firefox addon needs a name attribute"
else if ! (builtins.hasAttr "url" a) || ! (builtins.isString a.url) then
throw "Addon ${a.pname} needs an url"
else if ! (builtins.hasAttr "sha256" a) || ! (builtins.isString a.sha256) then
throw "Addon ${a.pname} needs an sha256 checksum"
else stdenv.mkDerivation rec {
pname = a.name;
version = "1.0";
src = fetchurl {
url = a.url;
sha256 = a.sha256;
};

phases = [ "buildPhase" ];

extid = "${a.sha256}@${a.name}";

buildInputs = [ zip unzip jq ];

buildPhase = ''
UUID="${extid}"
mkdir -p "$out/$UUID"
unzip -q ${src} -d "$out/$UUID"
NEW_MANIFEST=$(jq '. + {"applications": { "gecko": { "id": "${extid}" }}, "browser_specific_settings":{"gecko":{"id": "${extid}"}}}' "$out/$UUID/manifest.json")
echo "$NEW_MANIFEST" > "$out/$UUID/manifest.json"
cd "$out/$UUID"
zip -r -q -FS "$out/$UUID.xpi" *
rm -r "$out/$UUID"
'';
}
if ! (builtins.hasAttr "extid" a) then
throw "extraExtensions has an invalid entry. Missing extid attribute. Please use fetchfirefoxaddon"
else
a
) extraExtensions;

enterprisePolicies =
Expand Down
38 changes: 38 additions & 0 deletions pkgs/build-support/fetchfirefoxaddon/default.nix
@@ -0,0 +1,38 @@
{stdenv, lib, coreutils, unzip, jq, zip, fetchurl,writeScript, ...}:
let

in
{ name,
url,
sha256,
}:

stdenv.mkDerivation rec {

inherit name;
extid = "${sha256}@${name}";
passthru = {
exitd=extid;
};

builder = writeScript "xpibuilder" ''
source $stdenv/setup
header "firefox addon $name into $out"
UUID="${extid}"
mkdir -p "$out/$UUID"
unzip -q ${src} -d "$out/$UUID"
NEW_MANIFEST=$(jq '. + {"applications": { "gecko": { "id": "${extid}" }}, "browser_specific_settings":{"gecko":{"id": "${extid}"}}}' "$out/$UUID/manifest.json")
echo "$NEW_MANIFEST" > "$out/$UUID/manifest.json"
cd "$out/$UUID"
zip -r -q -FS "$out/$UUID.xpi" *
rm -r "$out/$UUID"
'';
src = fetchurl {
url = url;
sha256 = sha256;
};
nativeBuildInputs = [ coreutils unzip zip jq ];
}

2 changes: 2 additions & 0 deletions pkgs/top-level/all-packages.nix
Expand Up @@ -365,6 +365,8 @@ in

fetchhg = callPackage ../build-support/fetchhg { };

fetchfirefoxaddon = callPackage ../build-support/fetchfirefoxaddon {};

# `fetchurl' downloads a file from the network.
fetchurl = if stdenv.buildPlatform != stdenv.hostPlatform
then buildPackages.fetchurl # No need to do special overrides twice,
Expand Down

0 comments on commit 397597f

Please sign in to comment.