Define event definitions in the manifest file of an app¶
This topic describes how to define event definitions in the manifest file of an app. Event definitions define which log messages and trace events are shared with a provider.
About event definitions¶
Event definitions specify how an app shares log messages and trace events with the provider. Event definitions act as filters on the log message and trace event levels set by the provider. A provider specifies the event definitions for an app when a new app version or patch is published.
Event definitions are filters that act on the log messages and trace events. They determine what information is inserted in the provider event table when event sharing is enabled.
Event definitions are optional. If a provider does not specify event definitions for an app, consumers can only enable or disable event sharing for all events when the provider enables event tracing.
Caution
Event definitions differ from the log and tracing levels set by the provider. Log and tracing levels determine the information that is inserted into the consumer event table. If neither the log nor tracing levels are set, then the app does not emit any events.
The log and trace levels for an app can change based on the event definitions enabled by the consumer. Snowflake uses the most verbose log and trace levels allowed by the event definitions the consumer has enabled.
Mandatory and optional event definitions¶
Providers can set an event definition to be required or optional:
Required event definitions are enabled automatically when the app is installed.
After installing an app with required event definitions, consumers cannot disable event sharing or the required event definitions. When an app is being upgraded, providers can use system functions or the Python Permission SDK to check if the consumer has enabled all required event definitions.
Optional event definitions can be enabled or disabled by the consumer as necessary.
Supported event definitions¶
The following table lists currently supported event definitions.
Type |
Name |
Description |
Filter |
---|---|---|---|
All |
SNOWFLAKE$ALL |
Shares all log messages and trace events that the app emits. |
|
Errors and warnings |
SNOWFLAKE$ERRORS_AND_WARNINGS |
Shares logs related to errors, warnings, and fatal events. |
|
Traces |
SNOWFLAKE$TRACES |
Shares detailed traces of user activities and journeys in the application. |
|
Usage logs |
SNOWFLAKE$USAGE_LOGS |
Shares high-level logs related to user actions and app events. |
|
Debug logs |
SNOWFLAKE$DEBUG_LOGS |
Shares technical logs used to troubleshoot the app. |
|
Metrics |
SNOWFLAKE$METRICS |
Enable consumers to share metrics with providers. |
|
Note
Snowsight only displays the all event All type to the consumer if the provider has not configured the app to use event definitions.
Limitations of event definitions in apps with containers¶
Snowflake Native Apps with Snowpark Container Services currently only supports the ALL
event definition. Support for additional
event definitions will be added in a future release.
Set the log and trace levels for an app¶
To allow an app to use event tracing, a provider must configure the log and trace levels in the manifest file.
To set the log and trace levels for an app, add a configuration
block in the
manifest.yml
file as shown in the following example:
configuration:
...
log_level: INFO
trace_level: ALWAYS
metric_level: ALL
...
This example sets the log and trace levels for the app as follows:
The
log_level
property is set toINFO
.The
trace_level
property is set toALWAYS
.The
metric_level
property is set toALL
.
See LOG_LEVEL, TRACE_LEVEL, and ref:label-metric_level
for information on
the valid values for these parameters.
Caution
After you publish an app, the log and trace levels cannot be changed. If the log and trace levels are not set in the manifest file, the app does not emit any information.
When the log and trace levels are set for an app, consumers must set up an event table in their account to see the log messages and trace events that the app emits.
To allow the provider to see the log messages and trace events that an app generates, consumers must enable event sharing. See Enable event sharing for an app for more information.
Add an event definition to the manifest file¶
To specify an event definition, a provider adds an entry to the
configuration.telemetry_event_definitions
block of the manifest file as shown in the
following example:
configuration:
telemetry_event_definitions:
- type: ERRORS_AND_WARNINGS
sharing: MANDATORY
- type: DEBUG_LOGS
sharing: OPTIONAL
This example specifies the following event definitions:
A required event definition with type
ERRORS_AND_WARNINGS
.An optional event definition with type
DEBUG_LOGS
.
See Supported event definitions for more information.
After a consumer installs an app, the event definitions appears in the Events and logs tab on the Security page of the app. See Enable logging and event sharing for an app for more information.