path: root/doc/src/manual/cowboy_tracer_h.asciidoc
blob: e3592e464f63054646f2829c89d5ddb717120f6a (plain) (tree)

= cowboy_tracer_h(3)

== Name

cowboy_tracer_h - Tracer stream handler

== Description

The module `cowboy_tracer_h` can be used to conditionally
trace streams based on information found in the request.
Trace messages are given to the configured callback.

== Options

opts() :: #{
    tracer_callback    => Callback,
    tracer_flags       => [atom()],
    tracer_match_specs => [MatchSpec]

Callback :: fun((init | terminate | tuple(), State) -> State)

MatchSpec :: MatchPredicate
           | {method, binary()}
           | {host, binary()}
           | {path, binary()}
           | {path_start, binary()}
           | {header, binary()}
           | {header, binary(), binary()}
           | {peer_ip, inet:ip_address()}

MatchPredicate :: fun((cowboy_stream:streamid(),
                       cowboy:opts()) -> boolean())

Configuration for the tracer stream handler.

This module will not set trace patterns. Those must be
set by the user directly, either from the callback's
`init` or, preferably, in advance.


The function that will be called for each trace
events. It will also be called before any trace
event with an argument `init`, and when the
stream is terminated with an argument `terminate`.
This option is required for tracing to be enabled.
The tracer stream handler does nothing otherwise.


Trace flags to enable. See the documentation
of `erlang:trace/3` for details. Note that all
trace flags are allowed except for the `tracer`


A list of match conditions that must all be
fulfilled for the stream to be traced. Cowboy
will compare these with the information found
in the request and only enable tracing if all
matches succeed.
This option is required for tracing to be enabled.
The tracer stream handler does nothing otherwise.

== Events

The tracer stream handler does not produce any event.

== Changelog

* *2.7*: Module introduced.

== See also