]> git.immae.eu Git - perso/Immae/Config/Nix.git/commitdiff
Use new withPlugin system
authorIsmaël Bouya <ismael.bouya@normalesup.org>
Fri, 8 May 2020 21:59:21 +0000 (23:59 +0200)
committerIsmaël Bouya <ismael.bouya@normalesup.org>
Fri, 8 May 2020 22:30:49 +0000 (00:30 +0200)
- dokuwiki
- mantisbt
- mediagoblin
- roundcube
- ttrss
- yourls

15 files changed:
modules/private/websites/tools/git/mantisbt.nix
modules/private/websites/tools/mail/default.nix
modules/private/websites/tools/mail/roundcubemail.nix
modules/private/websites/tools/mgoblin/default.nix
modules/private/websites/tools/tools/dokuwiki.nix
modules/private/websites/tools/tools/ttrss.nix
modules/private/websites/tools/tools/yourls.nix
modules/webapps/mediagoblin.nix
pkgs/webapps/default.nix
pkgs/webapps/dokuwiki/default.nix
pkgs/webapps/mantisbt_2/default.nix
pkgs/webapps/mediagoblin/default.nix
pkgs/webapps/roundcubemail/default.nix
pkgs/webapps/ttrss/default.nix
pkgs/webapps/yourls/default.nix

index 50851aa5677dd33d2d0adeee8c5fe5509c800d40..a74d76e8b5e8e08c83e07b0b0a3fa52d740573bd 100644 (file)
@@ -46,7 +46,7 @@ rec {
       $g_ldap_organization = '${env.ldap.filter}';
     '';
   }];
-  webRoot = (mantisbt_2.override { mantis_config = "/var/secrets/webapps/tools-mantisbt"; }).withPlugins (builtins.attrValues mantisbt_2-plugins);
+  webRoot = (mantisbt_2.override { mantis_config = "/var/secrets/webapps/tools-mantisbt"; }).withPlugins (p: [p.slack p.source-integration]);
   apache = rec {
     user = "wwwrun";
     group = "wwwrun";
index 7d7904fdd057efa4e77b395094c143b5f683966e..7c60ae45b110c9a0a2538ee7ffdcb7ac972b5460 100644 (file)
@@ -1,7 +1,7 @@
 { lib, pkgs, config,  ... }:
 let
   roundcubemail = pkgs.callPackage ./roundcubemail.nix {
-    inherit (pkgs.webapps) roundcubemail roundcubemail-plugins roundcubemail-skins;
+    inherit (pkgs.webapps) roundcubemail;
     env = config.myEnv.tools.roundcubemail;
   };
   rainloop = pkgs.callPackage ./rainloop.nix {
index 6875bae54de653104fa901e8775147d5e3326b12..bb7dee9eba1e97072bc3100f3042220a0ae7c56f 100644 (file)
@@ -1,4 +1,4 @@
-{ env, roundcubemail, roundcubemail-plugins, roundcubemail-skins, apacheHttpd }:
+{ env, roundcubemail, apacheHttpd }:
 rec {
   varDir = "/var/lib/roundcubemail";
   activationScript = {
@@ -75,8 +75,7 @@ rec {
         $config['mime_types'] = '${apacheHttpd}/conf/mime.types';
     '';
   }];
-  webRoot = (roundcubemail.override { roundcube_config = "/var/secrets/webapps/tools-roundcube"; }).withPlugins
-    (builtins.attrValues roundcubemail-plugins) (builtins.attrValues roundcubemail-skins);
+  webRoot = (roundcubemail.override { roundcube_config = "/var/secrets/webapps/tools-roundcube"; }).withPlugins (p: [ p.automatic_addressbook p.carddav p.contextmenu p.contextmenu_folder p.html5_notifier p.ident_switch p.message_highlight p.thunderbird_labels ]);
   apache = rec {
     user = "wwwrun";
     group = "wwwrun";
index 5224a0d6b295ab05e6672ae1510f1f8b314cb5a8..719d3d3595d9b59689661a81efbe83e63db8abcb 100644 (file)
@@ -83,7 +83,7 @@ in {
 
     services.mediagoblin = {
       enable     = true;
-      plugins    = builtins.attrValues pkgs.webapps.mediagoblin-plugins;
+      package    = pkgs.webapps.mediagoblin.withPlugins (p: [p.basicsearch]);
       configFile = "/var/secrets/webapps/tools-mediagoblin";
     };
     services.filesWatcher.mediagoblin-web = {
index 26c04b753845e40740a1ee59dbb54e76809a364e..5290a96f4c8388ef8e6802f1f9ab4ee5252b15ff 100644 (file)
@@ -19,7 +19,7 @@ rec {
       install -m 0750 -o ${apache.user} -g ${apache.group} -d ${varDir}/phpSessions
     '';
   };
-  webRoot = dokuwiki.withPlugins (builtins.attrValues dokuwiki-plugins);
+  webRoot = dokuwiki.withPlugins (p: [ p.farmer p.todo ]);
   apache = rec {
     user = "wwwrun";
     group = "wwwrun";
index 48876d3ebf2a8d40cc4194929ac9a25ba0910009..ce1ab8e9dac3851410c141d1f8695982f89feea0 100644 (file)
@@ -88,7 +88,11 @@ rec {
         define('LDAP_AUTH_DEBUG', FALSE);
       '';
   }];
-  webRoot = (ttrss.override { ttrss_config = "/var/secrets/webapps/tools-ttrss"; }).withPlugins (builtins.attrValues ttrss-plugins);
+  webRoot = (ttrss.override { ttrss_config = "/var/secrets/webapps/tools-ttrss"; }).withPlugins (p: [
+    p.auth_ldap p.ff_instagram p.tumblr_gdpr_ua
+    (p.af_feedmod.override { patched = true; })
+    (p.feediron.override { patched = true; })
+  ]);
   apache = rec {
     user = "wwwrun";
     group = "wwwrun";
index cb03b6cb5d8283ab4886af14106430bf2d666f4b..77ac0a32130f5af9e98e0e57785cf27e822b5d4e 100644 (file)
@@ -40,8 +40,7 @@ rec {
       define( 'LDAPAUTH_USERCACHE_TYPE', 0);
     '';
   }];
-  webRoot = (yourls.override { yourls_config = "/var/secrets/webapps/tools-yourls"; }).withPlugins
-    (builtins.attrValues yourls-plugins);
+  webRoot = (yourls.override { yourls_config = "/var/secrets/webapps/tools-yourls"; }).withPlugins (p: [p.ldap]);
   apache = rec {
     user = "wwwrun";
     group = "wwwrun";
index dbc4c2b19043aae5647a60820e987d14e4c9e33b..19bbc2e8ce6c394ea282dfcde04d8e2598bcefbf 100644 (file)
@@ -15,8 +15,8 @@ let
 
     [app:mediagoblin]
     use = egg:mediagoblin#app
-    config = ${cfg.configFile} ${cfg.workdir}/mediagoblin.ini
-    /mgoblin_static = ${cfg.workdir}/mediagoblin/static
+    config = ${cfg.configFile} ${cfg.package}/mediagoblin.ini
+    /mgoblin_static = ${cfg.package}/mediagoblin/static
 
     [loggers]
     keys = root
@@ -87,26 +87,13 @@ in
     package = lib.mkOption {
       type = lib.types.package;
       default = pkgs.webapps.mediagoblin;
+      example = lib.literalExample ''
+        pkgs.webapps.mediagoblin.withPlugins (p: [p.basicsearch])
+      '';
       description = ''
         Mediagoblin package to use.
         '';
     };
-    plugins = lib.mkOption {
-      type = lib.types.listOf lib.types.package;
-      default = [];
-      description = ''
-        Mediagoblin plugins to use.
-        '';
-    };
-    # Output variables
-    workdir = lib.mkOption {
-      type = lib.types.package;
-      default = cfg.package.withPlugins cfg.plugins;
-      description = ''
-      Adjusted Mediagoblin package with plugins
-      '';
-      readOnly = true;
-    };
     systemdStateDirectory = lib.mkOption {
       type = lib.types.str;
       # Use ReadWritePaths= instead if varDir is outside of /var/lib
@@ -187,7 +174,7 @@ in
       preStart = ''
         if [ -d ${cfg.dataDir}/plugin_static/ ]; then
           rm ${cfg.dataDir}/plugin_static/coreplugin_basic_auth
-          ln -sf ${cfg.workdir}/mediagoblin/plugins/basic_auth/static ${cfg.dataDir}/plugin_static/coreplugin_basic_auth
+          ln -sf ${cfg.package}/mediagoblin/plugins/basic_auth/static ${cfg.dataDir}/plugin_static/coreplugin_basic_auth
         fi
         ./bin/gmg -cf ${cfg.configFile} dbupdate
         '';
@@ -198,7 +185,7 @@ in
         Restart = "always";
         TimeoutSec = 15;
         Type = "simple";
-        WorkingDirectory = cfg.workdir;
+        WorkingDirectory = cfg.package;
         RuntimeDirectory = cfg.systemdRuntimeDirectory;
         StateDirectory= cfg.systemdStateDirectory;
         PIDFile = cfg.pids.paster;
@@ -227,7 +214,7 @@ in
         Restart = "always";
         TimeoutSec = 60;
         Type = "simple";
-        WorkingDirectory = cfg.workdir;
+        WorkingDirectory = cfg.package;
         RuntimeDirectory = cfg.systemdRuntimeDirectory;
         StateDirectory= cfg.systemdStateDirectory;
         PIDFile = cfg.pids.celery;
index e3ec07f2c9d1270160a6c0cbfd308f6b4b881cdd..33fd7300997a225e97f3b578bd5a33b1bbcc75d6 100644 (file)
@@ -1,92 +1,27 @@
-{ callPackage, mylibs, composerEnv, lib }:
+{ callPackage, mylibs, composerEnv }:
 rec {
   adminer = callPackage ./adminer {};
   apache-theme = callPackage ./apache-theme {};
   awl = callPackage ./awl {};
   davical = callPackage ./davical {};
   diaspora = callPackage ./diaspora { inherit mylibs; };
-
   dokuwiki = callPackage ./dokuwiki { inherit mylibs; };
-  dokuwiki-with-plugins = dokuwiki.withPlugins (builtins.attrValues dokuwiki-plugins);
-  dokuwiki-plugins = let
-    names = [ "farmer" "todo" ];
-  in
-    lib.attrsets.genAttrs names
-      (name: callPackage (./dokuwiki/plugins + "/${name}.nix") {});
-
   etherpad-lite = callPackage ./etherpad-lite {};
-
   grocy = callPackage ./grocy { inherit mylibs composerEnv; };
-
   infcloud = callPackage ./infcloud {};
-
   mantisbt_2 = callPackage ./mantisbt_2 {};
-  mantisbt_2-with-plugins = mantisbt_2.withPlugins (builtins.attrValues mantisbt_2-plugins);
-  mantisbt_2-plugins = let
-    names = [ "slack" "source-integration" ];
-  in
-    lib.attrsets.genAttrs names
-      (name: callPackage (./mantisbt_2/plugins + "/${name}") {});
-
   mastodon = callPackage ./mastodon { inherit mylibs; };
-
   mediagoblin = callPackage ./mediagoblin { inherit mylibs; };
-  mediagoblin-with-plugins = mediagoblin.withPlugins (builtins.attrValues mediagoblin-plugins);
-  mediagoblin-plugins = let
-    names = [ "basicsearch" ];
-  in
-    lib.attrsets.genAttrs names
-      (name: callPackage (./mediagoblin/plugins + "/${name}") {});
-
   nextcloud = callPackage ./nextcloud {};
-
   peertube = callPackage ./peertube { inherit mylibs; };
   phpbb = callPackage ./phpbb {};
-
   phpldapadmin = callPackage ./phpldapadmin {};
   rompr = callPackage ./rompr { inherit mylibs; };
-
   roundcubemail = callPackage ./roundcubemail {};
-  roundcubemail-with-plugins-skins = roundcubemail.withPlugins (builtins.attrValues roundcubemail-plugins) (builtins.attrValues roundcubemail-skins);
-  roundcubemail-skins = let
-    names = [];
-  in
-    lib.attrsets.genAttrs names
-      (name: callPackage (./roundcubemail/skins + "/${name}") {});
-  roundcubemail-plugins = let
-    names = [
-      "automatic_addressbook" "carddav" "contextmenu"
-      "contextmenu_folder" "html5_notifier" "ident_switch"
-      "message_highlight" "thunderbird_labels"
-    ];
-  in
-    lib.attrsets.genAttrs names
-      (name: callPackage (./roundcubemail/plugins + "/${name}") { buildPlugin = roundcubemail.buildPlugin; });
-
   spip = callPackage ./spip {};
-
   surfer = callPackage ./surfer { inherit mylibs; };
   taskwarrior-web = callPackage ./taskwarrior-web { inherit mylibs; };
-
   ttrss = callPackage ./ttrss { inherit mylibs; };
-  ttrss-with-plugins = ttrss.withPlugins (builtins.attrValues ttrss-plugins);
-  ttrss-plugins = let
-    names = [ "auth_ldap" "af_feedmod" "feediron" "ff_instagram" "tumblr_gdpr_ua" ];
-    patched = [ "af_feedmod" "feediron" ];
-  in
-    lib.attrsets.genAttrs names
-      (name: callPackage (./ttrss/plugins + "/${name}") (
-        { inherit mylibs; } //
-        (if builtins.elem name patched then { patched = true; } else {})
-        )
-      );
-
   wallabag = callPackage ./wallabag { inherit composerEnv; };
   yourls = callPackage ./yourls { inherit mylibs; };
-  yourls-with-plugins = yourls.withPlugins (builtins.attrValues yourls-plugins);
-  yourls-plugins = let
-    names = [ "ldap" ];
-  in
-    lib.attrsets.genAttrs names
-      (name: callPackage (./yourls/plugins + "/${name}") { inherit mylibs; });
 }
index 9df88c6b24ca29fa3614b37385d87c114bae1a24..874f0d87696f69b2ba6d4a21006414dedf2eead1 100644 (file)
@@ -1,4 +1,4 @@
-{ varDir ? "/var/lib/dokuwiki", preload ? "", lib, stdenv, mylibs, writeText }:
+{ varDir ? "/var/lib/dokuwiki", preload ? "", lib, callPackage, stdenv, mylibs, writeText }:
 let
   preloadFile = plugins: let preloads = [preload]
       ++ builtins.concatMap (p: lib.optional (lib.hasAttr "preload" p) (p.preload p)) plugins;
@@ -6,21 +6,26 @@ let
       <?php
       '' + builtins.concatStringsSep "\n" preloads
     );
-  withPlugins = plugins: package.overrideAttrs(old: {
-    name = "${old.name}-with-plugins";
-    installPhase = old.installPhase + (
-      builtins.concatStringsSep "\n" (
-        map (value: "ln -sf ${value} $out/lib/plugins/${value.pluginName}") plugins
-        )
-      );
-    installPreloadPhase = ''
-      cp ${preloadFile plugins} $out/inc/preload.php
-      '';
-    passthru = old.passthru // {
-      inherit plugins;
-      withPlugins = morePlugins: old.withPlugins (morePlugins ++ plugins);
-    };
-  });
+  pluginNames = [ "farmer" "todo" ];
+  allPlugins = lib.attrsets.genAttrs pluginNames
+    (name: callPackage (./plugins + "/${name}.nix") {});
+  toPassthru = pkg: plugins: {
+    inherit plugins varDir allPlugins;
+    withPlugins = withPlugins pkg;
+  };
+  withPlugins = pkg: toPlugins:
+    let
+      plugins = toPlugins allPlugins;
+      toInstallPlugin = n:
+        "ln -sf ${n} $out/lib/plugins/${n.pluginName}";
+      newDokuwiki = pkg.overrideAttrs(old: {
+        installPhase = old.installPhase + "\n" + builtins.concatStringsSep "\n" (map toInstallPlugin plugins);
+        installPreloadPhase = ''
+          cp ${preloadFile (pkg.plugins ++ plugins)} $out/inc/preload.php
+        '';
+        passthru = toPassthru newDokuwiki (pkg.plugins ++ plugins);
+      });
+    in newDokuwiki;
   package = stdenv.mkDerivation (mylibs.fetchedGithub ./dokuwiki.json // rec {
     phases = "unpackPhase buildPhase installPhase installPreloadPhase fixupPhase";
     buildPhase = ''
@@ -35,9 +40,6 @@ let
     installPreloadPhase = ''
       cp ${preloadFile []} $out/inc/preload.php
       '';
-    passthru = {
-      plugins = [];
-      inherit withPlugins varDir;
-    };
+    passthru = toPassthru package [];
   });
 in package
index bb2aad354c19dde76517301bef72e473c4417d3a..5aa04d1b4574165bd07be60139a0d00dad2a67c3 100644 (file)
@@ -1,20 +1,25 @@
-{ mantis_config ? "/etc/mantisbt/config_inc.php", stdenv, fetchurl }:
+{ mantis_config ? "/etc/mantisbt/config_inc.php", stdenv, fetchurl, lib, callPackage}:
 let
-  withPlugins = plugins: package.overrideAttrs(old: {
-    name = "${old.name}-with-plugins";
-    installPhase = old.installPhase + (
-      builtins.concatStringsSep "\n" (
-        map (value: if builtins.hasAttr "selector" value then
-            "ln -sf ${value}/${value.selector} $out/plugins/"
-          else
-            "ln -sf ${value} $out/plugins/${value.pluginName}"
-        ) plugins
-      ));
-    passthru = old.passthru // {
-      inherit plugins;
-      withPlugins = morePlugins: old.withPlugins (morePlugins ++ plugins);
-    };
-  });
+  pluginNames = [ "slack" "source-integration" ];
+  allPlugins = lib.attrsets.genAttrs pluginNames
+    (name: callPackage (./plugins + "/${name}") {});
+  toPassthru = pkg: plugins: {
+    inherit plugins allPlugins;
+    withPlugins = withPlugins pkg;
+  };
+  withPlugins = pkg: toPlugins:
+    let
+      plugins = toPlugins allPlugins;
+      toInstallPlugin = n:
+        if builtins.hasAttr "selector" n then
+          "ln -sf ${n}/${n.selector} $out/plugins/"
+        else
+          "ln -sf ${n} $out/plugins/${n.pluginName}";
+      newMantisbt = pkg.overrideAttrs(old: {
+        installPhase = old.installPhase + "\n" + builtins.concatStringsSep "\n" (map toInstallPlugin plugins);
+        passthru = toPassthru newMantisbt (pkg.plugins ++ plugins);
+      });
+    in newMantisbt;
   package = stdenv.mkDerivation rec {
     name = "mantisbt-${version}";
     version = "2.21.0";
@@ -33,9 +38,6 @@ let
     ln -s ${mantis_config} $out/config/config_inc.php
     '';
 
-    passthru = {
-      plugins = [];
-      inherit withPlugins;
-    };
+    passthru = toPassthru package [];
   };
 in package
index c20bcb4230e2a188c33f009a050b2869f8079907..d348ce1fd3f9bf8849506052efc73e910b9a6e37 100644 (file)
@@ -1,4 +1,4 @@
-{ makeWrapper, stdenv, writeScript, fetchurl, buildBowerComponents, mylibs, which, python36, gst_all_1, automake, autoconf, nodejs, nodePackages }:
+{ makeWrapper, stdenv, writeScript, fetchurl, buildBowerComponents, mylibs, which, python36, gst_all_1, automake, autoconf, nodejs, nodePackages, lib, callPackage }:
 let
   overridePython = let
     packageOverrides = self: super: {
@@ -113,18 +113,22 @@ let
     generated = ./bower-packages.nix;
     src = (mylibs.fetchedGit ./mediagoblin.json).src;
   };
-  withPlugins = plugins: package.overrideAttrs(old: {
-    name = "${old.name}-with-plugins";
-    postBuild = old.postBuild + (
-      builtins.concatStringsSep "\n" (
-        map (value: "ln -s ${value} mediagoblin/plugins/${value.pluginName}") plugins
-        )
-      );
-    passthru = old.passthru // {
-      inherit plugins;
-      withPlugins = morePlugins: old.withPlugins (morePlugins ++ plugins);
-    };
-  });
+  pluginNames = [ "basicsearch" ];
+  allPlugins = lib.attrsets.genAttrs pluginNames
+    (name: callPackage (./plugins + "/${name}") {});
+  toPassthru = pkg: {
+    inherit allPlugins;
+    withPlugins = withPlugins pkg;
+  };
+  withPlugins = pkg: toPlugins:
+    let
+      plugins = toPlugins allPlugins;
+      toBuildPlugin = n: "ln -s ${n} mediagoblin/plugins/${n.pluginName}";
+      newMediagoblin = pkg.overrideAttrs(old: {
+        postBuild = old.postBuild + "\n" + builtins.concatStringsSep "\n" (map toBuildPlugin plugins);
+        passthru = toPassthru newMediagoblin;
+      });
+    in newMediagoblin;
   package = stdenv.mkDerivation (mylibs.fetchedGit ./mediagoblin.json // rec {
     preConfigure = ''
       # ./bootstrap.sh
@@ -173,9 +177,6 @@ let
       '';
     buildInputs = [ makeWrapper automake autoconf which nodePackages.bower nodejs python ];
     propagatedBuildInputs = with gst_all_1; [ python gst-libav gst-plugins-good gst-plugins-bad gst-plugins-ugly gstreamer ];
-    passthru = {
-      plugins = [];
-      inherit withPlugins;
-    };
+    passthru = toPassthru package;
   });
 in package
index 4f288b8882389bd4ed0344b06a226d3ef00f9b57..2b22b299e2da29bbf728657cef6990f75a1e2d92 100644 (file)
@@ -1,6 +1,6 @@
 { varDir ? "/var/lib/roundcubemail"
 , roundcube_config ? "/etc/roundcube/config.php"
-, stdenv, fetchurl, jre, unzip }:
+, stdenv, fetchurl, jre, unzip, lib, callPackage }:
 let
   defaultInstall = ''
     mkdir -p $out
@@ -19,20 +19,39 @@ let
       src = fetchurl { inherit url sha256; };
       passthru.pluginName = appName;
     };
-  withPlugins = plugins: skins: package.overrideAttrs(old: {
-    name = "${old.name}${if builtins.length skins > 0 then "-with-skins" else ""}${if builtins.length plugins > 0 then "-with-plugins" else ""}";
-    installPhase = old.installPhase +
-      builtins.concatStringsSep "\n" (
-        map (value: "ln -s ${value} $out/plugins/${value.pluginName}") plugins
-      ) +
-      builtins.concatStringsSep "\n" (
-        map (value: "ln -s ${value} $out/skins/${value.skinName}") skins
-      );
-    passthru = old.passthru // {
-      inherit plugins skins;
-      withPlugins = morePlugins: moreSkins: old.withPlugins (morePlugins ++ plugins) (morePlugins ++ skins);
-    };
-  });
+  skinNames = [];
+  allSkins = lib.attrsets.genAttrs skinNames
+    (name: callPackage (./skins + "/${name}") {});
+  pluginNames = [
+    "automatic_addressbook" "carddav" "contextmenu"
+    "contextmenu_folder" "html5_notifier" "ident_switch"
+    "message_highlight" "thunderbird_labels"
+  ];
+  allPlugins = lib.attrsets.genAttrs pluginNames
+    (name: callPackage (./plugins + "/${name}") { inherit buildPlugin; });
+  toPassthru = pkg: plugins: skins: {
+    inherit plugins skins allSkins allPlugins;
+    withSkins = withSkins pkg;
+    withPlugins = withPlugins pkg;
+  };
+  withPlugins = pkg: toPlugins:
+    let
+      plugins = toPlugins allPlugins;
+      toInstallPlugin = n: "ln -s ${n} $out/plugins/${n.pluginName}";
+      newRoundcube = pkg.overrideAttrs(old: {
+        installPhase = old.installPhase + "\n" + builtins.concatStringsSep "\n" (map toInstallPlugin plugins);
+        passthru = toPassthru newRoundcube (pkg.plugins ++ plugins) pkg.skins;
+      });
+    in newRoundcube;
+  withSkins = pkg: toSkins:
+    let
+      skins = toSkins allSkins;
+      toInstallSkin = n: "ln -s ${n} $out/skins/${n.skinName}";
+      newRoundcube = pkg.overrideAttrs(old: {
+        installPhase = old.installPhase + "\n" + builtins.concatStringsSep "\n" (map toInstallSkin skins);
+        passthru = toPassthru newRoundcube pkg.plugins (pkg.skins ++ skins);
+      });
+    in newRoundcube;
   shrinker = fetchurl {
     url = "http://dl.google.com/closure-compiler/compiler-latest.zip";
     sha256 = "0naf3kflhlkm17ls1x7mgddd3b01f8yzbbbdjqwy5m12jmkzl2d5";
@@ -61,10 +80,6 @@ let
       cp -a . $out
       ln -s ${roundcube_config} $out/config/config.inc.php
     '';
-    passthru = {
-      plugins = [];
-      skins = [];
-      inherit withPlugins buildPlugin;
-    };
+    passthru = toPassthru package [] [];
   };
 in package
index 0ce2f94fd5c78ce400b502402e38feb6592065b3..38200a1b3365f0e49843b0c13c8137397f4f24ee 100644 (file)
@@ -1,30 +1,33 @@
 { ttrss_config ? "/etc/ttrss/config.php"
 , varDir ? "/var/lib/ttrss"
-, stdenv, mylibs }:
+, stdenv, mylibs, lib, callPackage }:
 let
-  withPlugins = plugins: package.overrideAttrs(old: rec {
-    name = "${old.name}-with-plugins";
-    installPhase = old.installPhase +
-      builtins.concatStringsSep "\n" (
-        map (value: "ln -s ${value} $out/plugins/${value.pluginName}") plugins
-      );
-    passthru = old.passthru // {
-      inherit plugins;
-      withPlugins = morePlugins: old.withPlugins (morePlugins ++ plugins);
-    };
-  });
+  pluginNames = [ "auth_ldap" "af_feedmod" "feediron" "ff_instagram" "tumblr_gdpr_ua" ];
+  allPlugins = lib.attrsets.genAttrs pluginNames
+    (name: callPackage (./plugins + "/${name}") {});
+  toPassthru = pkg: plugins: {
+    inherit plugins allPlugins;
+    withPlugins = withPlugins pkg;
+  };
+  withPlugins = pkg: toPlugins:
+    let
+      plugins = toPlugins allPlugins;
+      toInstallPlugin = n:
+        "ln -sf ${n} $out/plugins/${n.pluginName}";
+      newTtrss = pkg.overrideAttrs(old: {
+        installPhase = old.installPhase + "\n" + builtins.concatStringsSep "\n" (map toInstallPlugin plugins);
+        passthru = toPassthru newTtrss (pkg.plugins ++ plugins);
+      });
+    in newTtrss;
   package = stdenv.mkDerivation (mylibs.fetchedGit ./tt-rss.json // rec {
     buildPhase = ''
       rm -rf lock feed-icons cache
       ln -sf ${varDir}/{lock,feed-icons,cache} .
-      '';
-      installPhase = ''
-        cp -a . $out
-        ln -s ${ttrss_config} $out/config.php
-      '';
-    passthru = {
-      plugins = [];
-      inherit withPlugins;
-    };
+    '';
+    installPhase = ''
+      cp -a . $out
+      ln -s ${ttrss_config} $out/config.php
+    '';
+    passthru = toPassthru package [];
   });
 in package
index 4bcfa4cc8d5b91bec6b4ed9d6de4b30060143da6..d940c54d1b505ebeeadb0b876c71b726775dda9d 100644 (file)
@@ -1,16 +1,21 @@
-{ yourls_config ? "/etc/yourls/config.php", mylibs, stdenv }:
+{ yourls_config ? "/etc/yourls/config.php", mylibs, callPackage, lib, stdenv }:
 let
-  withPlugins = plugins: package.overrideAttrs(old: {
-    name = "${old.name}-with-plugins";
-    installPhase = old.installPhase +
-      builtins.concatStringsSep "\n" (
-        map (value: "ln -s ${value} $out/user/plugins/${value.pluginName}") plugins
-      );
-    passthru = old.passthru // {
-      inherit plugins;
-      withPlugins = morePlugins: old.withPlugins (morePlugins ++ plugins);
-    };
-  });
+  pluginNames = [ "ldap" ];
+  allPlugins = lib.attrsets.genAttrs pluginNames
+    (name: callPackage (./plugins + "/${name}") { inherit mylibs; });
+  toPassthru = pkg: plugins: {
+    inherit plugins allPlugins;
+    withPlugins = withPlugins pkg;
+  };
+  withPlugins = pkg: toPlugins:
+    let
+      plugins = toPlugins allPlugins;
+      toInstallPlugin = n: "ln -s ${n} $out/user/plugins/${n.pluginName}";
+      newYourls = pkg.overrideAttrs(old: {
+        installPhase = old.installPhase + "\n" + builtins.concatStringsSep "\n" (map toInstallPlugin plugins);
+        passthru = toPassthru newYourls (pkg.plugins ++ plugins);
+      });
+    in newYourls;
   package = stdenv.mkDerivation (mylibs.fetchedGithub ./yourls.json // rec {
     installPhase = ''
       mkdir -p $out
@@ -18,9 +23,6 @@ let
       cp sample-robots.txt $out/robots.txt
       ln -sf ${yourls_config} $out/includes/config.php
     '';
-    passthru = {
-      plugins = [];
-      inherit withPlugins;
-    };
+    passthru = toPassthru package [];
   });
 in package