Convex Auth: How to add custom data to signIn() (or up)
Hello all,
I'm trying to add additional fields to my sign up form which will be added to the users table. But I can't figure out how to pass them onward. Adding them to the FormData object passed to
signIn()
doesn't seem to work. How can one add these arbitrary fields (such as username
)? I could also make it optional, but it shouldn't be, every account should have a username. So I'd prefer to set it via the sign up process.
Any help much appreciated here. Also, would be happy to make a PR improving the documentation once I figure out how it's done. The documentation states:
You can only change fields to be required or add new required fields to the users table if all your authentication methods will provide those fields during sign-up (see how to do this for OAuth and Passwords).But the linked page there doesn't actually explain how to pass that data to
signIn()
when the user submits the form. And evidently the FormData is not the correct method.
Thanks for all help in advance!20 Replies
Thanks for posting in <#1088161997662724167>.
Reminder: If you have a Convex Pro account, use the Convex Dashboard to file support tickets.
- Provide context: What are you trying to achieve, what is the end-user interaction, what are you seeing? (full error message, command output, etc.)
- Use search.convex.dev to search Docs, Stack, and Discord all at once.
- Additionally, you can post your questions in the Convex Community's <#1228095053885476985> channel to receive a response from AI.
- Avoid tagging staff unless specifically instructed.
Thank you!
Update the user table (https://labs.convex.dev/auth/setup/schema)
Add a profile callback on the provider and return the extra fields from the params (FormData)(https://labs.convex.dev/auth/config/passwords#customize-user-information)
Customizing Schema - Convex Auth
Authentication library for your Convex backend
Passwords - Convex Auth
Authentication library for your Convex backend
Yes, I'm aware of those two pages but they seem incomplete... Step 2 doesn't explain how to actually pass the values.
I have added such a file, and added the username field and include it to the FormData, no dice.
This is my form onSubmit, adapted slightly from the Convex Auth boilerplate:
I've also added this per the documentation:
However when signing up, I still get an error:
How does the schema look like?
(Thanks, by the way, for the help so far)
That does look correct, I have something similar (only difference is I return the default values in the profile callback).
What can help is add an env variable in dashboard for auth debug messages
AUTH_LOG_LEVEL=DEBUG
it'll show a bunch of debug messages in the dashboard logs
or disable schema validation and see what actually makes it into the tableAlso, just to check, because it's not stated in the documentation, but I assume the
CustomProfile.ts
in the documentation should be added to auth.ts
in place of the default Password
?
As in, temporarily wrap it in v.optional()
?Yes, or disable it for the entire schema like so:
Let me give that a try...
You can also just do this in auth.ts
Right. that's a bit cleaner.
So! I made everything optional, it absolutely comes into the users table.
So I guess FormData is the correct approach...
the fields have values?
yup!
the custom ones
data:image/s3,"s3://crabby-images/4c6f1/4c6f13ad8df1f29f49b1c241fa1aabf9041b32e6" alt="No description"
However this seems to be a bug in that case...
And that table is called "users" right?
yup!
It all seems to work if those fields are optional. If they are required, something goes wrong...
something like this
I took most of those fields out as they're neither needed or actively confusing (name instead of givenName and username), etc.
This is what it looks like. Which works fine, so long as all fields but email are optional.
Which I guess could be a workaround right now, but the documentation seems to suggest this is not needed and in later when using the inferred types it would be nice to not have
| undefined
for username and the visibilities :/