I’m building an app which must execute user-submitted bits of Ruby code.
Obviously, eval() does this. Illustration:
user_code = “‘hello’.upcase”
result = eval(user_code)
puts "the code evaluated to: " + result
But if the user’s code throws an uncaught exception, the whole app
crashes. This can be rectified by wrapping the eval() in
begin/rescue/end:
user_code = “0/0”
begin
result = eval(user_code)
puts "the code evaluated to: " + result
rescue
puts “the code had errors.”
end
Unfortunately, it is still possible to make the program crash if the
user code contains syntax errors which interfere with begin/rescue/end.
user_code = “end ‘hello there’”
begin
result = eval(user_code)
puts "the code evaluated to: " + result
rescue
puts “the code had errors.”
end
The above code will crash the entire application with “syntax error,
unexpected kEND”.
So I ask you: is it possible to execute arbitrary user-submitted code in
such a way that the user’s code won’t crash the server if it contains
innocent mistakes? I am not interested in protecting from malicious
code, just user mistakes.
Alternatively, is it possible to determine whether a given string is
syntactically-correct ruby code? If so, I could simply not eval() such
code.
I welcome any suggestions. Thanks!