This breaks types, and makes api / internal return any?
Hello so i just come across was was breaking api / internal types for convex in my repo:
And i'm curious to learn as of why this would break it?
This works:
This breaks api / internal and make them any
6 Replies
Furthermore explicitly typing the return of the handler, fixes the issue? and lets me return the object
I'm so confused, because this is not the first time im returning a object from a handler? So i dont think i fully understand why the type cant get through when done without typing the return type
Yep explicit typing generally fixes this sort of thing. I've run into it a lot and still don't understand it, but I have seen more than once that directly returning the result of a query/mutation can cause this, in this case
videoId
being included in the returned object.
Your error probably says the type is infinitely deep, which again points to some sort of recursion of types issue with returning the result of an api/internal function.Yeah! The return type of the of the inner call comes from the api/internal - yet it is required to infer the type of the caller, which is part of the api/internal type! That's the infinite loop 😦
data:image/s3,"s3://crabby-images/4ff84/4ff844956d8da2535a73f642e1e52dfe612579d5" alt="No description"
Yeah def had me confused too Erquhart, thanks for chipping in with what you experienced. Now it makes more sense with the visual representation of the infinite loop that Michael drew out.
@Michal Srb specifying the function return type is pretty much the workaround here right? Just making sure there's not another way.
Yup, specifying the caller's return type is a the right way to break the cycle.