diff --git a/IM/REST.py b/IM/REST.py index 9bbaeeb42..40cbae419 100644 --- a/IM/REST.py +++ b/IM/REST.py @@ -626,6 +626,7 @@ def RESTGetVMProperty(infid=None, vmid=None, prop=None): command = ('curl --insecure -s -H "Authorization: type = InfrastructureManager; %s" ' '-H "Accept: text/plain" %s' % (imauth, url)) + ps_command = "ps aux | grep -v grep | grep 'ssh -N -R'" info = """ res="wait" while [ "$res" == "wait" ] @@ -633,11 +634,14 @@ def RESTGetVMProperty(infid=None, vmid=None, prop=None): res=`%s` if [ "$res" != "wait" ] then - eval "$res" + echo "$res" > /var/tmp/reverse_ssh.sh + chmod a+x /var/tmp/reverse_ssh.sh + echo "*/1 * * * * root %s || /var/tmp/reverse_ssh.sh" > /etc/cron.d/reverse_ssh + /var/tmp/reverse_ssh.sh else sleep 20 fi - done""" % command + done""" % (command, ps_command) logger.debug("Step 1 command: %s" % info) elif step == 2: sel_vm = None diff --git a/test/unit/REST.py b/test/unit/REST.py index 02af74e40..786f6a64c 100755 --- a/test/unit/REST.py +++ b/test/unit/REST.py @@ -893,6 +893,7 @@ def test_commands(self, bottle_request, check_auth_data, get_infrastructure, SSH res = RESTGetVMProperty("1", "1", "command") auth_str = "Authorization: type = InfrastructureManager; username = user; password = pass" url = "http://imserver.com/infrastructures/1/vms/1/command?step=2" + ps_command = "ps aux | grep -v grep | grep 'ssh -N -R'" expected_res = """ res="wait" while [ "$res" == "wait" ] @@ -900,11 +901,14 @@ def test_commands(self, bottle_request, check_auth_data, get_infrastructure, SSH res=`curl --insecure -s -H "%s" -H "Accept: text/plain" %s` if [ "$res" != "wait" ] then - eval "$res" + echo "$res" > /var/tmp/reverse_ssh.sh + chmod a+x /var/tmp/reverse_ssh.sh + echo "*/1 * * * * root %s || /var/tmp/reverse_ssh.sh" > /etc/cron.d/reverse_ssh + /var/tmp/reverse_ssh.sh else sleep 20 fi - done""" % (auth_str, url) + done""" % (auth_str, url, ps_command) self.assertEqual(res, expected_res) inf.auth = Authentication([{'type': 'InfrastructureManager', 'token': 'token'}]) @@ -918,11 +922,14 @@ def test_commands(self, bottle_request, check_auth_data, get_infrastructure, SSH res=`curl --insecure -s -H "%s" -H "Accept: text/plain" %s` if [ "$res" != "wait" ] then - eval "$res" + echo "$res" > /var/tmp/reverse_ssh.sh + chmod a+x /var/tmp/reverse_ssh.sh + echo "*/1 * * * * root %s || /var/tmp/reverse_ssh.sh" > /etc/cron.d/reverse_ssh + /var/tmp/reverse_ssh.sh else sleep 20 fi - done""" % (auth_str, url) + done""" % (auth_str, url, ps_command) self.assertEqual(res, expected_res) radl_master = parse_radl("""