Skip to content

Commit

Permalink
Maintain reverse SSH connection
Browse files Browse the repository at this point in the history
  • Loading branch information
micafer committed Feb 7, 2020
1 parent a40b94a commit b03b0fa
Show file tree
Hide file tree
Showing 2 changed files with 17 additions and 6 deletions.
8 changes: 6 additions & 2 deletions IM/REST.py
Original file line number Diff line number Diff line change
Expand Up @@ -626,18 +626,22 @@ 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" ]
do
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
Expand Down
15 changes: 11 additions & 4 deletions test/unit/REST.py
Original file line number Diff line number Diff line change
Expand Up @@ -893,18 +893,22 @@ 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" ]
do
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'}])
Expand All @@ -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("""
Expand Down

0 comments on commit b03b0fa

Please sign in to comment.