Dynamically Loading Python Application Code From Database Under Google App Engine
Solution 1:
I was able to do what I intent after reading more about Python dynamic code loading.
Here is the sample code. I removed headers to be lighter:
Thanks anyway!
=============
classDynCode(db.Model):
name = db.StringProperty()
code = db.TextProperty(default=None)
=============
classMainHandler(webapp.RequestHandler):
defget(self):
dyn = DynCode()
dyn = "index"
dyn.code = """
from google.appengine.ext import webapp
class MainHandler(webapp.RequestHandler):
def get(self):
self.response.out.write("Hello World\\n")
self.response.out.write("Hello World 2\\n")
"""
dyn.put()
self.response.out.write("OK.")
defmain():
application = webapp.WSGIApplication([('/update', MainHandler)], debug=True)
util.run_wsgi_app(application)
if __name__ == '__main__':
main()
==================================
def main():
query = DynCode.all()
dyncodes = query.fetch(1)
module = imp.new_module('mymodule')
for dyn in dyncodes:
exec dyn.code in module.__dict__
application = webapp.WSGIApplication([('/', module.MainHandler)], debug=True)
util.run_wsgi_app(application)
if __name__ == '__main__':
main()
=======================
Solution 2:
If you want a more robust mechanism, you probably want to read PEP302, which describes input hooks. You can use these to import code rather than having to eval it.
Solution 3:
I somewhat agree with the commentators above, it sounds kind of dangerous. However:
I experimented a little with App Engine Console ( http://con.appspot.com/console/ ), and eval()
indeed tended to throw SyntaxError
's.
Instead, the exec
statement might be your friend ( http://docs.python.org/release/2.5.2/ref/exec.html ).
I managed to run this in App Engine Console:
>>>exec"def f(x):\n x = x + 1\n y = 10\n return x + y">>>f(10)
21
So try the exec
statement, but remember the many, many (many!) perils of code coming directly from end-users.
Post a Comment for "Dynamically Loading Python Application Code From Database Under Google App Engine"