$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";
{ 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 {
-{ env, roundcubemail, roundcubemail-plugins, roundcubemail-skins, apacheHttpd }:
+{ env, roundcubemail, apacheHttpd }:
rec {
varDir = "/var/lib/roundcubemail";
activationScript = {
$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";
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 = {
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";
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";
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";
[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
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
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
'';
Restart = "always";
TimeoutSec = 15;
Type = "simple";
- WorkingDirectory = cfg.workdir;
+ WorkingDirectory = cfg.package;
RuntimeDirectory = cfg.systemdRuntimeDirectory;
StateDirectory= cfg.systemdStateDirectory;
PIDFile = cfg.pids.paster;
Restart = "always";
TimeoutSec = 60;
Type = "simple";
- WorkingDirectory = cfg.workdir;
+ WorkingDirectory = cfg.package;
RuntimeDirectory = cfg.systemdRuntimeDirectory;
StateDirectory= cfg.systemdStateDirectory;
PIDFile = cfg.pids.celery;
-{ 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; });
}
-{ 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;
<?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 = ''
installPreloadPhase = ''
cp ${preloadFile []} $out/inc/preload.php
'';
- passthru = {
- plugins = [];
- inherit withPlugins varDir;
- };
+ passthru = toPassthru package [];
});
in package
-{ 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";
ln -s ${mantis_config} $out/config/config_inc.php
'';
- passthru = {
- plugins = [];
- inherit withPlugins;
- };
+ passthru = toPassthru package [];
};
in package
-{ 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: {
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
'';
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
{ 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
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";
cp -a . $out
ln -s ${roundcube_config} $out/config/config.inc.php
'';
- passthru = {
- plugins = [];
- skins = [];
- inherit withPlugins buildPlugin;
- };
+ passthru = toPassthru package [] [];
};
in package
{ 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
-{ 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
cp sample-robots.txt $out/robots.txt
ln -sf ${yourls_config} $out/includes/config.php
'';
- passthru = {
- plugins = [];
- inherit withPlugins;
- };
+ passthru = toPassthru package [];
});
in package