You signed in with another tab or window. Reload to refresh your session.You signed out in another tab or window. Reload to refresh your session.You switched accounts on another tab or window. Reload to refresh your session.Dismiss alert
The proposed web integration runs event listener in the "dispatch context", and use the "empty context" as a fallback when there is no dispatch context available.
This clashes with one of the goals: having "isolated" parts of the applications, and being able to trace from which part of the application a given error came from. The trivial approach is to store the "island ID" in an AsyncContext variable, and reading it when errors happen.
The solution that we have been discussing is to provide an EventTarget.captureFallbackContext API that lets people say "take a snapshot now, and use that as the fallback context for all the event listeners registered inside it". For example:
constcurrentTeam=newAsyncContext.Variable();addEventListener("unhandledrejection",()=>{console.log("Rejection from team "+currentTeam.get());});currentTeam.run("one",()=>EventTarget.captureFallbackContext(teamOne));currentTeam.run("two",()=>EventTarget.captureFallbackContext(teamTwo));functionteamOne(){button.addEventListener("click",()=>{// this listener will never run in the root context:// if possible it will propagate the contex that// dispatched it (e.g. by a .click() call), but if// not it will fallback to the context that was active// when EventTarget.captureFallbackContext was calledPromise.reject();});}functionteamTwo(){// ...}
This imposes less memory constraints than the approach of having event listeners always capture the registration-time context, because the expectation is that you'd define "fallbacks" much less frequently than how often you .runAsyncContext.Variables, and thus event listeners will end up capturing all the same (or a few) snapshot.
This "fallback context" is not a safe way to completely hide the root empty context: for example, a simple dynamic import is enough to get access to it. It's meant to reduce the cases where you don't want to see the root context, which most commonly happens in EventTarget and its subclasses.
There are a couple of open questions:
Explicitly pass the snapshot?
Instead of EventTarget.captureFallbackContext(fn), we might want to have EventTarget.withFallbackContext(snapshot, fn). This would make it more obvious that there is a snapshot being taken.
Support a way to get the fallback context?
#100 (comment) by @Jamesernator made me think: what if I want to just add one variable to the "fallback", rather than capturing whatever I have?
If there was a way to query the current fallback context (e.g. EventTarget.runFallbackContext()), then you'd be able to get the current context, update a variable, and set the new snapshot as the new fallback context:
Or maybe we could have more an API like EventTarget.updateFallbackContext(myVar, value, calback), although I'd prefer to only have the "primitive" that this can be built on top. Ideally, this should only happen if/after we get a way to update a Snapshot without running it.
The text was updated successfully, but these errors were encountered:
andreubotella
added a commit
to andreubotella/proposal-async-context
that referenced
this issue
Jan 7, 2025
Extracted from AsyncContext & events: alternative proposal
Ref #100
The proposed web integration runs event listener in the "dispatch context", and use the "empty context" as a fallback when there is no dispatch context available.
This clashes with one of the goals: having "isolated" parts of the applications, and being able to trace from which part of the application a given error came from. The trivial approach is to store the "island ID" in an AsyncContext variable, and reading it when errors happen.
The solution that we have been discussing is to provide an
EventTarget.captureFallbackContext
API that lets people say "take a snapshot now, and use that as the fallback context for all the event listeners registered inside it". For example:This imposes less memory constraints than the approach of having event listeners always capture the registration-time context, because the expectation is that you'd define "fallbacks" much less frequently than how often you
.run
AsyncContext.Variable
s, and thus event listeners will end up capturing all the same (or a few) snapshot.This "fallback context" is not a safe way to completely hide the root empty context: for example, a simple dynamic import is enough to get access to it. It's meant to reduce the cases where you don't want to see the root context, which most commonly happens in EventTarget and its subclasses.
There are a couple of open questions:
Explicitly pass the snapshot?
Instead of
EventTarget.captureFallbackContext(fn)
, we might want to haveEventTarget.withFallbackContext(snapshot, fn)
. This would make it more obvious that there is a snapshot being taken.Support a way to get the fallback context?
#100 (comment) by @Jamesernator made me think: what if I want to just add one variable to the "fallback", rather than capturing whatever I have?
If there was a way to query the current fallback context (e.g.
EventTarget.runFallbackContext()
), then you'd be able to get the current context, update a variable, and set the new snapshot as the new fallback context:Or maybe we could have more an API like
EventTarget.updateFallbackContext(myVar, value, calback)
, although I'd prefer to only have the "primitive" that this can be built on top. Ideally, this should only happen if/after we get a way to update a Snapshot without running it.The text was updated successfully, but these errors were encountered: