-
Notifications
You must be signed in to change notification settings - Fork 41
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Isolating execution via separate contexts #208
Comments
Hi @mashdragon, thanks for taking the time to check out PythonMonkey! This is definitely on our roadmap and something we will get to in the future |
I think it's a good idea, quickjs did it |
This is definitely an interesting idea. It does raise some complex questions like - what happens when a JS variable is shared from one context to another via the underlying Python code? The GC requirements in PythonMonkey can get very interesting because we have to interoperate with both interpreters at the same time. One of the questions that pops is -- do we care about complete isolation, meaning a new SpiderMonkey JSContext *cx, or is symbol-level isolation enough? Providing a new global object and standard classes (Array, Object, etc) would be pretty easy, along with an isolated module context via ctx-module. But this type of incomplete isolation might have interesting prototype-walking attacks, like I like the QuickJS interface. If we do this, we will also make it possible to emulate the NodeJS |
I think what we want is separate realms. We can call 'em contexts from the users' POV. http://www.carolinecullen.com/spidermonkeynotes/notes/runtime.html |
I just ran into PythonMonkey, and so far it's been great! I just wanted to bump this issue because I also would find the ability to create separate contexts extremely useful. |
This feature is definitely a must. I'm a little shocked that it's sitting on the backburner as far as I can tell so far the only way to achieve this would be through the use of IIFE's to run a set of eval's concurrently while keeping them each in their own context? I haven't tried it yet though, so I'm not sure how well that would work with @wiwichips is there any updated on this or a generally accepted way of achieving this yet? or how would IIFE's work with |
Fixes Distributive-Network#208 Implement isolated JavaScript execution contexts in PythonMonkey. * Define `Context` class in `include/modules/pythonmonkey/pythonmonkey.hh` to encapsulate JSContext, global object, auto realm, and job queue. * Implement `Context` class in `src/modules/pythonmonkey/pythonmonkey.cc` for initialization, destruction, and accessing the context. * Add `createContext`, `evalInContext`, and `cleanupContexts` functions in `src/modules/pythonmonkey/pythonmonkey.cc` to manage multiple contexts. * Update `eval` function in `src/modules/pythonmonkey/pythonmonkey.cc` to accept a context ID and evaluate JavaScript code within the specified context. * Update module initialization in `src/modules/pythonmonkey/pythonmonkey.cc` to include the `context` function. * Add `SuperGlobalContext` class in `include/modules/pythonmonkey/pythonmonkey.hh` to encapsulate shared JSContext, global object, auto realm, and job queue. * Implement `SuperGlobalContext` class in `src/modules/pythonmonkey/pythonmonkey.cc` for initialization and cleanup of shared resources. * Update `Context` class to reference `SuperGlobalContext` for shared resources. * Modify `evalInContext` function to use `SuperGlobalContext` for shared resources. * Make `SuperGlobalContext` accessible through a `GLOBAL_CX` variable. * Update `JobQueue` class in `include/JobQueue.hh` and `src/JobQueue.cc` to accept a JSContext in the constructor. * Update various proxy classes in `src/JSMethodProxy.cc`, `src/JSObjectItemsProxy.cc`, `src/JSObjectIterProxy.cc`, `src/JSObjectKeysProxy.cc`, `src/JSObjectProxy.cc`, and `src/JSStringProxy.cc` to use the `Context` object instead of the global `GLOBAL_CX` variable.
@dsetzer a completely isolated context is quite different from what you can do with IIFE symbol isolation. For instance, an object literal declared in one context is not an instance of Object in another context. Then we have to consider the issues like how to deal with JS objects that cross the JS cx boundary via PythonMonkey. Do we double-proxy? Re-wrap? Pass raw jsval pointers? How do Python reference counts work, etc. Does it make sense to have an event loop per context? etc. (JS generally has one loop per process, but async Python can get weird). I saw in the notes from your closed PR that you were considering the SuperGlobal case. I love super globals and went out of my way to implement them in gpsee back in the day. But JS contexts don't share a global, the fact that contexts each have their own globalThis is one of their defining characteristics. (cx here is like a v8 isolate if you're used to v8? Think one cx = one browser tab). Maybe we need to think about terminology a bit? If you wind up with a patch you'd like to upstream - we'd be interested. I, too, agree that this is a very important feature in the long term. |
Describe your feature request here.
It does not seem like there is a feature in PythonMonkey to run JavaScript scripts or evals in isolation after importing the module. This means that I have to keep track of the JavaScript state myself and perform any cleanup manually on objects that pollute the
globalThis
space.It would be nice if there were a way to isolate execution so that separate scripts run in separate environments, just like how scripts in the web are isolated to their pages.
Maybe this would appear as a
pm.context()
function to get a new JavaScript execution context.Code example
The text was updated successfully, but these errors were encountered: