-
Imagine, you have a webhook and you don't know if the request payload is {
"id": 1,
"name": "John Doe"
} or {
"error": "DuplicateEntry",
"message": "A user with name John Doe already exists"
} Currently, you'd create one request like this: class WebhookRequest extends FormRequest
{
public function rules(): array
{
return [
'id' => [ 'int', 'required_without:error,message' ],
'name' => [ 'string', 'required_without:error,message' ],
'error' => 'string',
'message' => 'string',
];
} But what if you could do just this: class WebhookController
{
public function inbound(UserCreatedRequest|UserCreationErrorRequest $request)
{
if ($request instanceof UserCreationErrorRequest) {
throw new Exception("[{$request->error}] {$request->message}");
}
[ 'id' => $id, 'name' => $name ] = $request->validated();
// …
}
} |
Beta Was this translation helpful? Give feedback.
Replies: 3 comments 9 replies
-
Or, seperating the logic, register more controllers for the same route. That way you can also have multiple providers using the same endpoint. It would help in such situation to specify the source. Or a filter telling laravel which controller logic to use. In your case it seems a whole lot of logic that does basically the same thing as invalid input response, but I may be missing something? |
Beta Was this translation helpful? Give feedback.
-
Hello. Usually all APIs have this situation and you check first if the response is valid and only then you validate it if needed. This happens for the JS clients that can't handle properly non 200 responses only. For api to api the second case with error should not happen on 200. |
Beta Was this translation helpful? Give feedback.
-
So I did a little research on what happens when a form request is passed into a controller method. And let me tell you two things: It's a whole lot and it's almost impossible to tap into that the way I suggested:
So, essentially, because of 4 and 6 resp. 8, chances of getting it implemented as proposed by me are slim at best. |
Beta Was this translation helpful? Give feedback.
It's released:
laravel-working-group/laravel-form-requests-improved
🚀 🥳