X-Git-Url: https://git.immae.eu/?p=perso%2FImmae%2FConfig%2FNix.git;a=blobdiff_plain;f=pkgs%2Fwebapps%2Fnextcloud%2Fdefault.nix;h=12134943cf746683946c3b956f2fd056ca11b586;hp=0287f75321bcafe99d3394b7b3af41ff9fec1917;hb=50def5927f7640dbcb4f97be916a1930765edf09;hpb=3a1461cf44102e6cd8cdee5e0f1ff1d7992894ad diff --git a/pkgs/webapps/nextcloud/default.nix b/pkgs/webapps/nextcloud/default.nix index 0287f75..1213494 100644 --- a/pkgs/webapps/nextcloud/default.nix +++ b/pkgs/webapps/nextcloud/default.nix @@ -1,42 +1,51 @@ -{ varDir ? "/var/lib/nextcloud", otherConfig ? {}, lib, stdenv, fetchurl }: +{ varDir ? "/var/lib/nextcloud", nextcloudVersion ? 18, otherConfig ? {}, lib, stdenv, callPackage, fetchzip, fetchurl }: let - buildApp = { appName, version, url, sha256, otherConfig ? {}, installPhase ? "mkdir -p $out && cp -R . $out/" }: + appNames = [ + "apporder" "audioplayer" "bookmarks" "calendar" "carnet" "contacts" + "cookbook" "deck" "extract" "files_markdown" "files_readmemd" + "flowupload" "gpxedit" "gpxpod" "keeweb" "maps" "metadata" "music" + "notes" "ocsms" "passman" "polls" "spreed" "tasks" + ]; + allApps = lib.attrsets.genAttrs appNames + (name: callPackage (./apps + "/${name}.nix") { inherit buildApp nextcloudVersion; }); + buildApp = { appName, version, url, sha256, zip ? false, otherConfig ? {}, installPhase ? "mkdir -p $out && cp -R . $out/" }: stdenv.mkDerivation rec { name = "nextcloud-app-${appName}-${version}"; inherit version; phases = "unpackPhase installPhase"; inherit installPhase; - src = fetchurl { inherit url sha256; }; + src = (if zip then fetchzip else fetchurl) { inherit url sha256; }; passthru = { inherit appName otherConfig; }; }; - withApps = apps: package.overrideAttrs(old: { - name = "${old.name}-with-apps"; - - installPhase = old.installPhase + ( - builtins.concatStringsSep "\n" ( - map (value: "ln -sf ${value} $out/apps/${value.appName}") apps - )); - - passthru.otherConfig = with lib.attrsets; with lib.lists; let - zipped = zipAttrs ([old.otherConfig or {}] ++ map (v: v.otherConfig) apps); - in - { - mimetypealiases = foldr (h: prev: prev // h) {} zipped.mimetypealiases; - mimetypemapping = mapAttrs (_: v: unique (flatten v)) (zipAttrs zipped.mimetypemapping); + toPassthru = pkg: apps: otherConfig: { + inherit apps otherConfig allApps buildApp varDir; + withApps = withApps pkg; + }; + withApps = pkg: toApps: + let + apps = toApps allApps; + toInstallApp = n: '' + ln -sf ${n} $out/apps/${n.appName} + ''; + zipped = lib.attrsets.zipAttrs ([pkg.otherConfig or {}] ++ map (v: v.otherConfig) apps); + appConfigs = with lib.attrsets; with lib.lists; { + mimetypealiases = foldr (h: prev: prev // h) {} (zipped.mimetypealiases or []); + mimetypemapping = mapAttrs (_: v: unique (flatten v)) (zipAttrs (zipped.mimetypemapping or [])); }; - passthru.apps = apps; - passthru.withApps = moreApps: old.withApps (moreApps ++ apps); - }); - + newNextcloud = pkg.overrideAttrs(old: { + installPhase = old.installPhase + "\n" + builtins.concatStringsSep "\n" (map toInstallApp apps); + passthru = toPassthru newNextcloud (pkg.apps ++ apps) appConfigs; + }); + in newNextcloud; package = stdenv.mkDerivation rec { name = "nextcloud-${version}"; - version = "16.0.0"; + version = "${builtins.toString nextcloudVersion}.0.4"; src = fetchurl { url = "https://download.nextcloud.com/server/releases/${name}.tar.bz2"; - sha256 = "0bj014vczlrql1w32pqmr7cyqn9awnyzpi2syxhg16qxic1gfcj5"; + sha256 = "0aa3f4xbkzacfw0h9aic0ywk5mqlwka83qaszizj8lmk68kf3n7s"; }; installPhase = '' @@ -46,10 +55,7 @@ let ln -sf ${varDir}/config $out/config ''; - passthru = { - apps = []; - inherit otherConfig buildApp withApps varDir; - }; + passthru = toPassthru package [] otherConfig; meta = { description = "Sharing solution for files, calendars, contacts and more"; homepage = https://nextcloud.com;