telemere/main/resources/docs/signal-content.txt

42 lines
2.3 KiB
Text
Raw Permalink Normal View History

2025-03-10 21:31:54 +00:00
Telemere signals are maps with {:keys [inst id ns level data msg_ ...]},
though they can be modified by call and/or handler transform (xfns).
2024-04-12 12:57:24 +00:00
Default signal keys:
`:schema` ------ Int version of signal schema (current: 1)
2025-03-03 10:31:52 +00:00
`:inst` -------- Platform instant [1] when signal was created, monotonicity depends on system clock
2025-03-10 21:31:54 +00:00
`:ns` ---------- ?str namespace of signal callsite
`:coords` ------ ?[line column] of signal callsite
2024-08-05 10:59:18 +00:00
`:kind` -------- Signal ?kind ∈ #{nil :event :error :log :trace :spy :slf4j :tools-logging <app-val> ...}
2025-03-10 21:31:54 +00:00
`:level` ------- Signal level ∈ #{<int> :trace :debug :info :warn :error :fatal :report ...}
`:id` ---------- Signal callsite ?id (usu. keyword) (common to all signals created at callsite, contrast with `:uid`)
`:uid` --------- Signal instance ?id (usu. string) (unique to each signal created at callsite when tracing, contrast with `:id`)
2024-04-12 12:57:24 +00:00
2024-10-23 14:26:23 +00:00
`:msg_` -------- Arb app-level message ?str given to signal creator - may be a delay, always use `force` to unwrap!
2024-08-05 10:59:18 +00:00
`:data` -------- Arb app-level data ?val (usu. a map) given to signal creator
`:error` ------- Arb app-level platform ?error [2] given to signal creator
2024-04-12 12:57:24 +00:00
`:run-form` ---- Unevaluated ?form given to signal creator as `:run`
`:run-val` ----- Successful return ?val of `:run` ?form
`:run-nsecs` --- ?int nanosecs runtime of `:run` ?form
`:end-inst` ---- Platform ?instant [1] when `:run` ?form completed
`:parent` ------ ?{:keys [id uid]} of parent signal, present in nested signals when tracing
`:root` -------- ?{:keys [id uid]} of root signal, present in nested signals when tracing
`:ctx` --------- ?val of `*ctx*` (arb app-level state) when signal was created
2024-08-13 10:22:06 +00:00
`:host` -------- (Clj only) {:keys [name ip]} info for network host
`:thread` ------ (Clj only) {:keys [name id group]} info for thread that created signal
`:sample` ------ Sample ?rate ∈ℝ[0,1] for combined call AND handler sampling (0.75 => allow 75% of signals, nil => allow all)
2024-04-12 12:57:24 +00:00
2024-08-05 10:59:18 +00:00
<kvs> ---------- Other arb app-level ?kvs given to signal creator. Typically NOT included
2024-04-25 07:37:55 +00:00
in handler output, so a great way to provide custom data/opts for use
(only) by custom transforms/handlers.
2024-03-14 10:18:29 +00:00
If anything is unclear, please ping me (@ptaoussanis) so that I can improve these docs!
[1] `java.time.Instant` or `js/Date`
[2] `java.lang.Throwable` or `js/Error`