Chapters
00:00 - Adding & Defining Our Register Validator
02:04 - Inspecting How Validation Errors Are Provided
03:30 - Access & Displaying Validation Errors
Join Adocasts Plus for $8.00/mo, or sign into your account to get access to all of our lessons.
In this lesson, we'll add validation to our POST handler for our register route. We'll then update our form fields to check for and display any validation errors that may have occurred.
Developer, dog lover, and burrito eater. Currently teaching AdonisJS, a fully featured NodeJS framework, and running Adocasts where I post new lessons weekly. Professionally, I work with JavaScript, .Net C#, and SQL Server.
Adocasts
Burlington, KY
00:00 - Adding & Defining Our Register Validator
02:04 - Inspecting How Validation Errors Are Provided
03:30 - Access & Displaying Validation Errors
Join Adocasts Plus for $8.00/mo, or sign into your account to get access to all of our lessons.
Join The Discussion! (11 Comments)
Please sign in or sign up for free to join in on the dicussion.
hsn
Hey, my app doesn't provide validation errors right away. On the response tab it says "No content avaliable because this request was redirected."
And there is no attr section on vue dev tools. I checked and it looks like we have exactly same code. Is it something about different versioning or something?
Great course btw! Thanks.
Please sign in or sign up for free to reply
tomgobich
Hey hsn! When you're redirecting, is the response type a 303? Inertia expects redirect statuses to be 303 to work properly, and the AdonisJS adapter should automatically take care of this for you. So, if that isn't happening then something is likely misconfigured in your project.
As for the
attr
section, if all items being passed into a page component are registered asprops
within the page, then there won't beattrs
to display as everything will be underprops
.attrs
in Vue captures non-registered prop data. For example:In the above
theme
is a registered prop, so it'll be underprops
, but notattrs
. Meanwhile,user
is not a registered prop, but is being passed into the header. Therefore, it won't be withinprops
, but ratherattrs
.That is the only thing coming to mind as to why the
attrs
may differ.Hope this helps!!
Please sign in or sign up for free to reply
hsn
Hey Tom, thanks for fast reply. Actually i think i checked if we have anything different so far and it looks like we have same conf. But my response type is 302 found.
And thanks for the attrs explanation, i meant i tried a few things like removing defineProps to see if errors are making it to frontend as attrs but they were not. Then i removed all my attempts again, and got the errors on the frontend(idk why they were not tere and now idk how i fixed it (: ) even tho now i am getting validation errors, status code is still 302.
I will check on the repo to see what is the reason it's coming as 302.
Thanks.
Please sign in or sign up for free to reply
tomgobich
AdonisJS' automatic 302 to 303 conversion happens via the Inertia Middleware that comes with the package. You'll want to make sure it is configured as server middleware inside the
start/kernel.ts
file.I reckon the 302 issue might be related to your errors not originally populating. If you're able to and need further help digging into it, feel free to share the repo and I can take a look.
Please sign in or sign up for free to reply
nonwiz
Hi, I'm not sure if there is something that I missed, somehow my adonisjs application doesn't trigger the global exception handling, when vine throw a validation error, the server just stop. I've checked the middleware, global exceptions/handlers, it is also there :(
The server just died once there's a validation issue, it seems like it is not being wrapped by try catch, which I suppose the global exception handler should've take care of that.
I'm using request.validateUsing(…)
Please sign in or sign up for free to reply
nonwiz
Found the issue, it happened because I forgot to add "await" in front of request.usingValidatior…
Please sign in or sign up for free to reply
tomgobich
Hi nonwiz! Happy to hear you were able to get it figured out! 😊
Please sign in or sign up for free to reply
ruslan-mr
Hey! How can I send custom errors? I'm validating
certFile
and trying to return a response withresponse.unprocessableEntity
, but I’m getting an error: "All Inertia requests must receive a valid Inertia response, but a plain JSON response was received." Any ideas?Please sign in or sign up for free to reply
tomgobich
Hey Ruslan!
Yeah, as we'll discuss in lesson 3.6, covering Inertia's limitations, when Inertia sends a request it requires a specific format for the response. Otherwise, you'll get the error you mentioned above.
Because of this, Inertia doesn't want you to return 422 responses. Rather, they want you to flash the errors to the session and redirect the user back to the page.
So, if
certFile
is a form field, you could manually send back an error like this:Otherwise, if you just need a general exception-like error, separate from validation, you could do:
Hope this helps!
Please sign in or sign up for free to reply
kite
It would be great if the right hand sidebar showed completed courses. Maybe you can turn the circle that contains the module number green or something similar
Please sign in or sign up for free to reply
tomgobich
Yes, it absolutely would, thank you very much kite!! I have no clue how I overlooked that. I'll try and get this added tomorrow after work!
Please sign in or sign up for free to reply