diff options
author | Jaka Hudoklin <jakahudoklin@gmail.com> | 2014-07-26 02:23:46 +0200 |
---|---|---|
committer | Jaka Hudoklin <jakahudoklin@gmail.com> | 2014-07-26 02:23:46 +0200 |
commit | b035be7b44b83644a6e34ecf1f8cbcd9eb989468 (patch) | |
tree | e45c9a9f04f49ccbd2022e452ed26d50390c101b /nixos | |
parent | 7f467aeeb2f5d4c5e1972a3b2ab01d5f8b303121 (diff) | |
parent | 7eb4d306fbb1e3d4fd3af47530c8f7d2b74ef523 (diff) | |
download | nixlib-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.nix | 18 |
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 ''; }; |