sentry-python
sentry-python copied to clipboard
Capture Loguru template
Problem Statement
We currently don't have access to the raw message before formatting in Loguru logs so we can't add it as sentry.message.template.
Solution Brainstorm
- The most feasible way forward is getting the template from Loguru directly. Submitted a PR for that https://github.com/Delgan/loguru/pull/1413. This issue is mostly for internal tracking purposes and extra context.
- The other solution would be monkeypatching the
_logmethod that takes care of creating the record. This would enable us to get the raw message since the method gets it as an argument. However, we don't have a way to get the formatted message afterwards: all processing happens directly in the_logfunction and nothing is returned; instead, the records are sent to the sinks directly. We could find a way to associate a raw message we've seen in the monkeypatched_logmethod with the message we receive in our sink, but that'd mean introducing some kind of book-keeping structure which I'd like to avoid. (And since Loguru's maintainer said they'd be fine with 1, we're not doing this unless anything changes.)