zotero: 4.0.29 -> 5.0.25

This uses buildFHSUserenv.  The source installation probably does not work until
node2nix supports nodejs-8.x.
This commit is contained in:
timor 2017-11-15 13:59:33 +01:00
parent 73af2b27c9
commit e1a797e37f
2 changed files with 36 additions and 72 deletions

View File

@ -1,82 +1,48 @@
{ stdenv, fetchurl, lib, bash, firefox, perl, unzipNLS, xorg }: { stdenv, fetchurl, buildFHSUserEnv, writeTextFile, bash, wrapGAppsHook, gsettings_desktop_schemas, gtk3, gnome3 }:
let let
version = "5.0.25";
meta = with stdenv.lib; {
homepage = https://www.zotero.org;
description = "Collect, organize, cite, and share your research sources";
license = licenses.agpl3;
platforms = platforms.linux;
};
xpi = fetchurl { zoteroSrc = stdenv.mkDerivation rec {
url = "https://download.zotero.org/extension/zotero-${version}.xpi";
sha256 = "1dyf578yfj3xr9kkhmsvbkvraw2arghmh67ksi5c8qlxczx5i1xy";
};
version = "4.0.29";
in
stdenv.mkDerivation {
name = "zotero-${version}";
inherit version; inherit version;
name = "zotero-${version}-pkg";
src = fetchurl { src = fetchurl {
url = "https://github.com/zotero/zotero-standalone-build/archive/4.0.29.2.tar.gz"; url = "https://download.zotero.org/client/release/${version}/Zotero-${version}_linux-x86_64.tar.bz2";
sha256 = "0pfip6s5dawp7wp8r5czvzlnxvvdwjja64g71h9dxyxrh49v2mxa"; sha256 = "1y3q5582xp4inpz137x0r9iscs1g0cjlqcfjpzl3klsq3yas688k";
}; };
nativeBuildInputs = [ perl unzipNLS ]; buildInputs= [ wrapGAppsHook gsettings_desktop_schemas gtk3 gnome3.adwaita-icon-theme gnome3.dconf ];
phases = [ "unpackPhase" "installPhase" "fixupPhase"];
inherit bash firefox;
phases = "unpackPhase installPhase fixupPhase";
installPhase = '' installPhase = ''
mkdir -p "$out/libexec/zotero" mkdir -p $out/data
unzip "${xpi}" -d "$out/libexec/zotero" cp -r * $out/data
mkdir $out/bin
BUILDID=`date +%Y%m%d` ln -s $out/data/zotero $out/bin/zotero
GECKO_VERSION="${lib.removeSuffix "esr" firefox.passthru.version}"
UPDATE_CHANNEL="default"
# Copy branding
cp -R assets/branding "$out/libexec/zotero/chrome/branding"
# Adjust chrome.manifest
echo "" >> "$out/libexec/zotero/chrome.manifest"
cat assets/chrome.manifest >> "$out/libexec/zotero/chrome.manifest"
# Copy updater.ini
cp assets/updater.ini "$out/libexec/zotero"
# Adjust connector pref
perl -pi -e 's/pref\("extensions\.zotero\.httpServer\.enabled", false\);/pref("extensions.zotero.httpServer.enabled", true);/g' "$out/libexec/zotero/defaults/preferences/zotero.js"
perl -pi -e 's/pref\("extensions\.zotero\.connector\.enabled", false\);/pref("extensions.zotero.connector.enabled", true);/g' "$out/libexec/zotero/defaults/preferences/zotero.js"
# Copy icons
cp -r assets/icons "$out/libexec/zotero/chrome/icons"
# Copy application.ini and modify
cp assets/application.ini "$out/libexec/zotero/application.ini"
perl -pi -e "s/\{\{VERSION}}/$version/" "$out/libexec/zotero/application.ini"
perl -pi -e "s/\{\{BUILDID}}/$BUILDID/" "$out/libexec/zotero/application.ini"
perl -pi -e "s/^MaxVersion.*\$/MaxVersion=$GECKO_VERSION/" "$out/libexec/zotero/application.ini"
# Copy prefs.js and modify
cp assets/prefs.js "$out/libexec/zotero/defaults/preferences"
perl -pi -e 's/pref\("app\.update\.channel", "[^"]*"\);/pref\("app\.update\.channel", "'"$UPDATE_CHANNEL"'");/' "$out/libexec/zotero/defaults/preferences/prefs.js"
perl -pi -e 's/%GECKO_VERSION%/'"$GECKO_VERSION"'/g' "$out/libexec/zotero/defaults/preferences/prefs.js"
# Add platform-specific standalone assets
cp -R assets/unix "$out/libexec/zotero"
mkdir -p "$out/bin"
substituteAll "${./zotero.sh}" "$out/bin/zotero"
chmod +x "$out/bin/zotero"
''; '';
};
doInstallCheck = true; fhsEnv = buildFHSUserEnv {
installCheckPhase = "$out/bin/zotero --version"; name = "zotero-fhs-env";
targetPkgs = pkgs: with pkgs; with xlibs; [
gtk3 dbus_glib
libXt nss
];
};
meta = with stdenv.lib; { in writeTextFile {
homepage = https://www.zotero.org; name = "zotero";
description = "Collect, organize, cite, and share your research sources"; destination = "/bin/zotero";
license = licenses.agpl3; executable = true;
platforms = platforms.linux; text = ''
broken = true; # probably; see #20049 #!${bash}/bin/bash
}; ${fhsEnv}/bin/zotero-fhs-env ${zoteroSrc}/bin/zotero
} '';
} // {inherit meta; }

View File

@ -17627,9 +17627,7 @@ with pkgs;
zoom-us = callPackage ../applications/networking/instant-messengers/zoom-us { }; zoom-us = callPackage ../applications/networking/instant-messengers/zoom-us { };
zotero = callPackage ../applications/office/zotero { zotero = callPackage ../applications/office/zotero { };
firefox = firefox-esr-unwrapped;
};
zscroll = callPackage ../applications/misc/zscroll {}; zscroll = callPackage ../applications/misc/zscroll {};