From da4ccb3eb2fe2829c1393b8fadec45b06cf48048 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Romain=20Tarti=C3=A8re?= Date: Fri, 17 Jan 2020 13:04:42 -1000 Subject: [PATCH] Manage a wrapper for running ruby on Windows Inspired by https://github.com/choria-io/puppet-choria/issues/145#issuecomment-575381929 When the agent_shim filenamed ends with '.bat', install a wrapper batch file that run the actual '.rb' file. --- data/os/windows.yaml | 2 +- manifests/config.pp | 18 +++++++++++++++++- .../choria_mcollective_agent_compat.bat.epp | 3 +++ 3 files changed, 21 insertions(+), 2 deletions(-) create mode 100644 templates/choria_mcollective_agent_compat.bat.epp diff --git a/data/os/windows.yaml b/data/os/windows.yaml index 7bfdf22..c937f7b 100644 --- a/data/os/windows.yaml +++ b/data/os/windows.yaml @@ -4,7 +4,7 @@ choria::server_config: classesfile: "C:/ProgramData/PuppetLabs/puppet/cache/state/classes.txt" plugin.rpcaudit.logfile: "C:/ProgramData/choria/var/log/choria-audit.log" plugin.yaml: "C:/ProgramData/choria/etc/generated-facts.yaml" - plugin.choria.agent_provider.mcorpc.agent_shim: "C:/Program Files/choria/bin/choria_mcollective_agent_compat.rb" + plugin.choria.agent_provider.mcorpc.agent_shim: "C:/Program Files/choria/bin/choria_mcollective_agent_compat.bat" plugin.choria.agent_provider.mcorpc.config: "C:/ProgramData/choria/etc/choria-shim.cfg" plugin.choria.agent_provider.mcorpc.libdir: "C:/ProgramData/choria/lib/plugins" choria::rubypath: "C:/Program Files/Puppet Labs/Puppet/puppet/bin/ruby.exe" diff --git a/manifests/config.pp b/manifests/config.pp index 4b72c69..b670ead 100644 --- a/manifests/config.pp +++ b/manifests/config.pp @@ -41,12 +41,28 @@ } if "plugin.choria.agent_provider.mcorpc.agent_shim" in $choria::server_config and "plugin.choria.agent_provider.mcorpc.config" in $choria::server_config { - file{$choria::server_config["plugin.choria.agent_provider.mcorpc.agent_shim"]: + if $choria::server_config["plugin.choria.agent_provider.mcorpc.agent_shim"] =~ /\.bat$/ { + $agent_shim = $choria::server_config["plugin.choria.agent_provider.mcorpc.agent_shim"].regsubst(/\.bat$/, '.rb') + $agent_shim_wrapper = $choria::server_config["plugin.choria.agent_provider.mcorpc.agent_shim"] + } else { + $agent_shim = $choria::server_config["plugin.choria.agent_provider.mcorpc.agent_shim"] + $agent_shim_wrapper = undef + } + + file{$agent_shim: owner => $choria::config_user, group => $choria::config_group, mode => "0755", content => epp("choria/choria_mcollective_agent_compat.rb.epp") } + if $agent_shim_wrapper { + file{$agent_shim_wrapper: + owner => $choria::config_user, + group => $choria::config_group, + mode => "0755", + content => epp("choria/choria_mcollective_agent_compat.bat.epp") + } + } } if $choria::manage_server_config { diff --git a/templates/choria_mcollective_agent_compat.bat.epp b/templates/choria_mcollective_agent_compat.bat.epp new file mode 100644 index 0000000..430a7cb --- /dev/null +++ b/templates/choria_mcollective_agent_compat.bat.epp @@ -0,0 +1,3 @@ +@echo off +setlocal +"<%= $choria::rubypath %>" -S -- "<%= $choria::server_config["plugin.choria.agent_provider.mcorpc.agent_shim"].regsubst(/\.bat$/, '.rb') %>" --config "<%= $choria::server_config_file %>" %*