ssh-wrapper.py 1.0 KB

1234567891011121314151617181920212223242526272829303132333435363738
  1. #!/usr/bin/env python
  2. import os
  3. import re
  4. import shlex
  5. import subprocess
  6. import sys
  7. allowed = [
  8. r'^/usr/bin/lsb_release\s+-d$',
  9. r'^/usr/lib/nagios/plugins/check_disk -w \d+% -c \d+% -p /[/a-z]*$',
  10. r'^/usr/lib/nagios/plugins/check_load -w \d+(,\d+,\d+)? -c \d+(,\d+,\d+)?$',
  11. r'^/usr/lib/nagios/plugins/check_mysql -u [a-z]+ -p [0-9a-zA-Z]+',
  12. r'^/usr/lib/nagios/plugins/check_mysql_health --user(name)?=[a-z]+ --pass(word)?=[0-9a-zA-Z]+ --mode=[a-z-]+$',
  13. # r'^/usr/lib/nagios/plugins/check_',
  14. ]
  15. cmdline = os.getenv('SSH_ORIGINAL_COMMAND')
  16. if not cmdline:
  17. print 'This is just a wrapper, no command specified!'
  18. sys.exit(3)
  19. for maybe in allowed:
  20. if re.match(maybe, cmdline):
  21. cmdline = shlex.split(cmdline)
  22. try:
  23. cmd = subprocess.Popen(cmdline, stdout=subprocess.PIPE)
  24. except Exception, exc:
  25. print 'Could not execute plugin ("%s"): %s' % (' '.join(cmdline), exc)
  26. sys.exit(3)
  27. else:
  28. print cmd.communicate()[0].rstrip()
  29. sys.exit(cmd.returncode)
  30. print '%s: No allowed command found!' % sys.argv[0]
  31. sys.exit(3)