App Events

Status: Development

This document defines events related to client-side applications (e.g. web apps or mobile apps).

Click Events

Event: app.screen.click

Status: Development

The event name MUST be app.screen.click.

This event represents an instantaneous click on the screen of an application.

The app.screen.click event can be used to indicate that a user has clicked or tapped on the screen portion of an application. Clicks outside of an application’s active area SHOULD NOT generate this event. This event does not differentiate between touch/mouse down and touch/mouse up. Implementations SHOULD give preference to generating this event at the time the click is complete, typically on touch release or mouse up. The location of the click event MUST be provided in absolute screen pixels.

Attributes:

KeyStabilityRequirement LevelValue TypeDescriptionExample Values
app.screen.coordinate.xDevelopmentRequiredintThe x (horizontal) coordinate of a screen coordinate, in screen pixels.0; 131
app.screen.coordinate.yDevelopmentRequiredintThe y (vertical) component of a screen coordinate, in screen pixels.12; 99
app.screen.idDevelopmentRecommendedstringAn identifier that uniquely differentiates this screen from other screens in the same application. [1]f9bc787d-ff05-48ad-90e1-fca1d46130b3; com.example.app.MainActivity; com.example.shop.ProductDetailFragment; MyApp.ProfileView; MyApp.ProfileViewController
app.screen.nameDevelopmentOpt-InstringThe name of an application screen. [2]MainActivity; ProductDetailFragment; ProfileView; ProfileViewController

[1] app.screen.id: A screen represents only the part of the device display drawn by the app. It typically contains multiple widgets or UI components and is larger in scope than individual widgets. Multiple screens can coexist on the same display simultaneously (e.g., split view on tablets).

[2] app.screen.name: A screen represents only the part of the device display drawn by the app. It typically contains multiple widgets or UI components and is larger in scope than individual widgets. Multiple screens can coexist on the same display simultaneously (e.g., split view on tablets).

Event: app.widget.click

Status: Development

The event name MUST be app.widget.click.

This event indicates that an application widget has been clicked.

Use this event to indicate that visual application component has been clicked, typically through a user’s manual interaction.

Attributes:

KeyStabilityRequirement LevelValue TypeDescriptionExample Values
app.widget.idDevelopmentRequiredstringAn identifier that uniquely differentiates this widget from other widgets in the same application. [1]f9bc787d-ff05-48ad-90e1-fca1d46130b3; submit_order_1829
app.screen.idDevelopmentRecommendedstringAn identifier that uniquely differentiates this screen from other screens in the same application. [2]f9bc787d-ff05-48ad-90e1-fca1d46130b3; com.example.app.MainActivity; com.example.shop.ProductDetailFragment; MyApp.ProfileView; MyApp.ProfileViewController
app.screen.coordinate.xDevelopmentOpt-InintThe x (horizontal) coordinate of a screen coordinate, in screen pixels.0; 131
app.screen.coordinate.yDevelopmentOpt-InintThe y (vertical) component of a screen coordinate, in screen pixels.12; 99
app.screen.nameDevelopmentOpt-InstringThe name of an application screen. [3]MainActivity; ProductDetailFragment; ProfileView; ProfileViewController
app.widget.nameDevelopmentOpt-InstringThe name of an application widget. [4]submit; attack; Clear Cart

[1] app.widget.id: A widget is an application component, typically an on-screen visual GUI element.

[2] app.screen.id: A screen represents only the part of the device display drawn by the app. It typically contains multiple widgets or UI components and is larger in scope than individual widgets. Multiple screens can coexist on the same display simultaneously (e.g., split view on tablets).

[3] app.screen.name: A screen represents only the part of the device display drawn by the app. It typically contains multiple widgets or UI components and is larger in scope than individual widgets. Multiple screens can coexist on the same display simultaneously (e.g., split view on tablets).

[4] app.widget.name: A widget is an application component, typically an on-screen visual GUI element.

Crash Event

Event: app.crash

Status: Development

The event name MUST be app.crash.

This event represents a termination of a user-facing application due to unrecoverable programming errors such as exceptions or signals that indicate an error has happened at a lower level.

Crash events can be produced asynchronously by an OTel SDK instance that is not running in the application instance in which the crash happened. For example, the instrumentation may report crashes from previous app instances based on information found in tombstones on disk. If the reporter of the crash is not the crashing application instance itself, relevant resource attributes that identify the application instance that crashed MUST be provided as event attributes so that the corresponding attributes from the reporter’s resource aren’t used instead. How the instrumentation will determine whether an instance of a crash has already been reported and how the necessary data will be retrieved is left up to the instrumentation. Providing enough data to dedupe is NOT REQUIRED.

Attributes:

KeyStabilityRequirement LevelValue TypeDescriptionExample Values
app.build_idDevelopmentConditionally Required [1]stringUnique identifier for a particular build or compilation of the application.6cff0a7e-cefc-4668-96f5-1273d8b334d0; 9f2b833506aa6973a92fde9733e6271f; my-app-1.0.0-code-123
os.nameDevelopmentConditionally Required [2]stringHuman readable operating system name.iOS; Android; Ubuntu
os.versionDevelopmentConditionally Required [3]stringThe version string of the operating system as defined in Version Attributes.14.2.1; 18.04.1
service.versionStableConditionally Required [4]stringThe version string of the service component. The format is not defined by these conventions.2.0.0; a01dbef8a
app.crash.idDevelopmentRecommendedstringA unique identifier representing an instance of an end-user facing app crash. [5]083d3d2d-9a0e-47f8-be3d-bc3c5538ba38
exception.messageStableRecommendedstringThe exception message. [6]Division by zero; Can't convert 'int' object to str implicitly
exception.stacktraceStableRecommendedstringA stacktrace as a string in the natural representation for the language runtime. The representation is to be determined and documented by each language SIG. [7]Exception in thread "main" java.lang.RuntimeException: Test exception\n at com.example.GenerateTrace.methodB(GenerateTrace.java:13)\n at com.example.GenerateTrace.methodA(GenerateTrace.java:9)\n at com.example.GenerateTrace.main(GenerateTrace.java:5)
exception.typeStableRecommendedstringThe type of the exception (its fully-qualified class name, if applicable). The dynamic type of the exception should be preferred over the static type in languages that support it. [8]java.net.ConnectException; OSError
session.idDevelopmentRecommendedstringA unique id to identify a session.00112233-4455-6677-8899-aabbccddeeff

[1] app.build_id: If reporter is not the crashing application instance itself and it’s available.

[2] os.name: If reporter is not the crashing application instance itself and the OS name is available.

[3] os.version: If reporter is not the crashing application instance itself.

[4] service.version: If reporter is not the crashing application instance itself.

[5] app.crash.id: Its value MAY be meaningful and be used as a reference for telemetry and metadata recorded by the same instrumentation (e.g. it is an ID generated by an external source that captured the crash). It MAY come from a source external to the instrumentation such that it can be used to look up additional data from other sources as well as facilitate deduplication.

[6] exception.message: If this contains obfuscated symbols, app.build_id SHOULD be provided so they can be deobfuscated.

[7] exception.stacktrace: If this contains obfuscated symbols, app.build_id SHOULD be provided so they can be deobfuscated.

[8] exception.type: If this contains obfuscated symbols, app.build_id SHOULD be provided so they can be deobfuscated.

Jank Event

Event: app.jank

Jank is a disruption in UI rendering, resulting in a display that can feel sluggish or even unresponsive/frozen. Applications that are able to detect jank can report it with the following events:

Status: Development

The event name MUST be app.jank.

This event indicates that the application has detected substandard UI rendering performance.

Jank happens when the UI is rendered slowly enough for the user to experience some disruption or sluggishness.

Attributes:

KeyStabilityRequirement LevelValue TypeDescriptionExample Values
app.jank.frame_countDevelopmentRecommendedintA number of frame renders that experienced jank. [1]9; 42
app.jank.periodDevelopmentRecommendeddoubleThe time period, in seconds, for which this jank is being reported.1.0; 5.0; 10.24
app.jank.thresholdDevelopmentRecommendeddoubleThe minimum rendering threshold for this jank, in seconds.0.016; 0.7; 1.024

[1] app.jank.frame_count: Depending on platform limitations, the value provided MAY be approximation.

Attributes

See the app attributes registry for all application-related attributes that may appear on telemetry items.