-
Notifications
You must be signed in to change notification settings - Fork 5.4k
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
Expose console primitives to Workers #11844
Comments
I am not a fan of this suggestion, as it leaks a lot of "private" non-web standard stuff, no matter which way you look at it, and it would dramatically increase the "contracted" API surface. I had a similar problem of wanting to "sandbox" a workers console output and did this: https://github.com/kitsonk/dectyl/blob/main/runtime/console.ts along with this https://github.com/kitsonk/dectyl/blob/main/runtime/inspect.ts. It is effectively a re-implentation of the Deno runtime code for console and inspect and then post a message back to the main worker for additional processing: https://github.com/kitsonk/dectyl/blob/main/runtime/main.ts#L612-L618 |
It is probably not that niche, because users asking about this on StackOverflow https://stackoverflow.com/questions/64362869/how-to-pipe-stdout-stderr-to-file-from-worker-in-deno and I have same problem and @kitsonk also faces the need to do this. If you consider workers are good idea for running code you don't really fully trust it seems logical you don't want to have standard output or error of this process in your parent process logs.
👍 Something like this could be nice const worker = new Worker("./worker.ts", {
type: "module",
deno: true,
stdout: file.rid,
stderr: file.rid
});
It is certainly not typical web standard stuff, but maybe it could be done with web platform in mind, e.g. by providing stderr or stdout via transferable streams? https://github.com/whatwg/streams/blob/main/transferable-streams-explainer.md? You could then create a worker with stdin, stdout and stderr set to some web streams |
We discussed this during our team meeting and we're feeling we should add |
This is a probably a pretty niche use case, but maybe there's some useful general feature to arise from it.
I have the following situation:
Worker
Deno
privilegesI tried to copy/paste the guts of the console implementation, but in addition to being quite complex, it's not possible to replicate fully without some internal hooks, notably to inspect
Promise
values (and maybe other stuff).Other approaches I tried or considered:
Deno.inspect
, but there's no guarantee that logged objects can be transferred over the boundary.I got stuck at this point, and ended up forking Deno to solve this. (I added a
runtime/js
script that exports theConsole
class, and doconsole = new Console(myInterceptorFunc)
in the Worker module). This was quite a simple change and ended up with exactly the behavior I want, but naturally I'd rather not have to maintain a fork.Would any of these features be considered for Deno (in order of how useful they'd be to me)?
Console
class constructor to workers somehowWorker
constructor to redirect its output/error streamsDeno.inspect
but nothing else (maybe Enable Deno namespace by default in Workers #8174 implies this, but it's not clear to me if it goes far enough)Open to any other alternatives that achieve the same result as well!
The text was updated successfully, but these errors were encountered: