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.

RECORD_TYPE = ‘LOG’ AND RECORD:severity_text in (‘FATAL’, ‘ERROR’, ‘WARN’)

Traces

SNOWFLAKE$TRACES

Shares detailed traces of user activities and journeys in the application.

RECORD_TYPE in (‘SPAN’, ‘SPAN_EVENT’)

Usage logs

SNOWFLAKE$USAGE_LOGS

Shares high-level logs related to user actions and app events.

RECORD_TYPE = LOG AND RECORD:severity_text = ‘INFO’

Debug logs

SNOWFLAKE$DEBUG_LOGS

Shares technical logs used to troubleshoot the app.

RECORD_TYPE = ‘LOG’ AND RECORD:severity_text in (‘DEBUG’, ‘TRACE’)

Metrics

SNOWFLAKE$METRICS

Enable consumers to share metrics with providers.

RECORD_TYPE  in (‘METRIC’)

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
  ...
Copy

This example sets the log and trace levels for the app as follows:

  • The log_level property is set to INFO.

  • The trace_level property is set to ALWAYS.

  • The metric_level property is set to ALL.

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
Copy

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.