Args in Log Streams
Hello, I am currently using Axiom to monitor my convex backend as per showcased in the documentation.
When checking and debugging the errors reported by convex to Axiom, I usually want to know what happened in my function: what args and userIdentity where passed to the failing function in order to understand and debug it. But I can not find them reported in Axiom.
Would it be possible that convex send those args to the Log Stream pipeline automatically? Not sure what entry should be used, but in any cases, that would be very useful. Otherwise, I'll probably need to write a console.log every time I create a function or modify args which is kinda error-prone.
I am kinda new to monitoring/observability, so this may be a dumb question, or there may be already a solution. Just asking in case of.
Have a nice day and thanks for your work the convex team!
10 Replies
Yeah they're not currently sent via log streams, but seems totally reasonable to want them there.
To attempt to unblock you right now, have you seen customFunctions (https://github.com/get-convex/convex-helpers/blob/main/packages/convex-helpers/README.md#custom-functions) ?
One strategy could be to add a custom wrapper that just does a
console.log
with the args + userIdentity (potentially only doing this for the subset of fields that are valuable to you + you feel fine showing up in logs). It hopefully helps a bit with needing to constantly add the console.log
sGitHub
convex-helpers/packages/convex-helpers/README.md at main · get-conv...
A collection of useful code to complement the official packages. - get-convex/convex-helpers
Oh pretty interesting workaround @sshader . I didn't event know there were out of the box customFunctions utils in convex-helpers. I will have a look. Thanks!
After digging into customFunctions, it looks like I can indeed consume the context and so, the userIdentity. On the other hand, I can not consume args passed to the final query/mutation. The args exposed by customFunctions are just "middleware" args, not the ones of the inner function.
But anyway, given this is just an helper, I can write my own version of customFunctions that passes the inner arguments I guess. May be not that easy to type this, but let's see.
@Riki maybe something like this could work, but I haven't tested it:
Definitely something the library should support.
Unfortunately, these customMutation/customQuery in
convex-helpers
don't have access to the final args passed to the query/mutationdata:image/s3,"s3://crabby-images/d2dd5/d2dd53bc941559370c691f145d46738f7e60c8d3" alt="No description"
What about
(Looking at the helpers source, not providing the
args
key to customMutation
should not split the args)Thanks for the help Michal
Unfortunately, same result
data:image/s3,"s3://crabby-images/b5a70/b5a704814c7f7f624146f026d9b2ffa71d6433ce" alt="No description"
You are right, I read the code wrong. You'll have to create a custom constructor without helpers.
Something I also haven't tested but might work:
(the types you want are
QueryBuilder
, and personally I'd use some any
s in the implementation to avoid dealing with some of the more complicated types) works for me but my mutationCtx is custom.