summary refs log tree commit diff
path: root/nixos
diff options
context:
space:
mode:
authorJaka Hudoklin <jakahudoklin@gmail.com>2014-07-26 02:23:46 +0200
committerJaka Hudoklin <jakahudoklin@gmail.com>2014-07-26 02:23:46 +0200
commitb035be7b44b83644a6e34ecf1f8cbcd9eb989468 (patch)
treee45c9a9f04f49ccbd2022e452ed26d50390c101b /nixos
parent7f467aeeb2f5d4c5e1972a3b2ab01d5f8b303121 (diff)
parent7eb4d306fbb1e3d4fd3af47530c8f7d2b74ef523 (diff)
downloadnixlib-b035be7b44b83644a6e34ecf1f8cbcd9eb989468.tar
nixlib-b035be7b44b83644a6e34ecf1f8cbcd9eb989468.tar.gz
nixlib-b035be7b44b83644a6e34ecf1f8cbcd9eb989468.tar.bz2
nixlib-b035be7b44b83644a6e34ecf1f8cbcd9eb989468.tar.lz
nixlib-b035be7b44b83644a6e34ecf1f8cbcd9eb989468.tar.xz
nixlib-b035be7b44b83644a6e34ecf1f8cbcd9eb989468.tar.zst
nixlib-b035be7b44b83644a6e34ecf1f8cbcd9eb989468.zip
Merge pull request #3292 from offlinehacker/elasticsearch_plugins
elasticsearch: add support for plugins
Diffstat (limited to 'nixos')
-rw-r--r--nixos/modules/services/search/elasticsearch.nix18
1 files changed, 17 insertions, 1 deletions
diff --git a/nixos/modules/services/search/elasticsearch.nix b/nixos/modules/services/search/elasticsearch.nix
index eeae11dc4ff3..c99d1e229677 100644
--- a/nixos/modules/services/search/elasticsearch.nix
+++ b/nixos/modules/services/search/elasticsearch.nix
@@ -21,6 +21,11 @@ let
     ];
   };
 
+  esPlugins = pkgs.buildEnv {
+    name = "elasticsearch-plugins";
+    paths = cfg.plugins;
+  };
+
 in {
 
   ###### interface
@@ -101,6 +106,12 @@ in {
       example = [ "-Djava.net.preferIPv4Stack=true" ];
     };
 
+    plugins = mkOption {
+      description = "Extra elasticsearch plugins";
+      default = [];
+      type = types.listOf types.package;
+    };
+
   };
 
   ###### implementation
@@ -111,14 +122,19 @@ in {
       wantedBy = [ "multi-user.target" ];
       after = [ "network-interfaces.target" ];
       environment = { ES_HOME = cfg.dataDir; };
+      path = [ pkgs.elasticsearch ];
       serviceConfig = {
-        ExecStart = "${pkgs.elasticsearch}/bin/elasticsearch -Des.path.conf=${configDir} ${toString cfg.extraCmdLineOptions}";
+        ExecStart = "elasticsearch -Des.path.conf=${configDir} ${toString cfg.extraCmdLineOptions}";
         User = "elasticsearch";
         PermissionsStartOnly = true;
       };
       preStart = ''
         mkdir -m 0700 -p ${cfg.dataDir}
         if [ "$(id -u)" = 0 ]; then chown -R elasticsearch ${cfg.dataDir}; fi
+
+        # Install plugins
+        rm ${cfg.dataDir}/plugins || true
+        ln -s ${esPlugins}/plugins ${cfg.dataDir}/plugins
       '';
     };