@opentelemetry/scope-base

OpenTelemetry Base Scope Manager

Downloads in past

Stats

StarsIssuesVersionUpdatedCreatedSize
@opentelemetry/scope-base
1,4792150.4.03 years ago3 years agoMinified + gzip package size for @opentelemetry/scope-base in KB

Readme

OpenTelemetry Base Scope Manager
!Gitter chatgitter-imagegitter-url !NPM Published Versionnpm-imgnpm-url !dependenciesdependencies-imagedependencies-url !devDependenciesdevDependencies-imagedevDependencies-url !Apache Licenselicense-imagelicense-image
This package provides the ScopeManager interface (which is used by concrete implementations) and a no-op implementation (which is used internally when no scope propagation is defined). It's intended for use both on the server and in the browser.

What is a Scope Manager ?

To understand why they exists, we'll need to understand how Javascript works: when you make native function call (networks, setInterval etc) you generally call C++ code that will later callback your own code.
A common issue when tracing a request in javascript is to link the function that have made the native call to the callback that the native code called when the response is there. Imagine you want to track for which user you made the request, you need some sort of "context/scope aware storage".
ScopeManager's aim to offer exactly that, it's API offer to store an object in the current scope (with()) and if needed, bind() to a specific function call to find it back when the callback fire, which can later get retrieved using active().
This package only include the interface and a Noop implementation, for more information please see the async-hooks based ScopeManagerah-scope-manager for NodeJS.
Note: You will sometimes read about context management, which is sometimes also used for talking about scope management. However in OpenTelemetry, context was already heavily used as a concept in the Trace API so we named this package with scope to avoid confusion.

Useful links

  • For more information on OpenTelemetry, visit:
  • For more about OpenTelemetry JavaScript:
  • For help or feedback on this project, join us on gittergitter-url

License

Apache 2.0 - See LICENSElicense-url for more information.