UPGRADE-API-2.2.md
2.1 TO 2.2| Old route | New route |
|---|---|
sylius_api_show_payment_request_get | sylius_api_shop_payment_request_get |
sylius_api_show_payment_request_post | sylius_api_shop_payment_request_post |
sylius_api_show_payment_request_put | sylius_api_shop_payment_request_put |
The HTTP status code for missing required fields in API requests has been changed from 400 Bad Request to 422 Unprocessable Content to follow REST API best practices and RFC 9110 semantics.
Additionally, the redundant code field has been removed from the error response body, as the status code is already available in the HTTP response headers.
Before:
{
"@context": "/api/v2/contexts/Error",
"@type": "hydra:Error",
"status": 400,
"detail": "Request does not have the following required fields specified: email."
}
After:
{
"@context": "/api/v2/contexts/Error",
"@type": "hydra:Error",
"status": 422,
"detail": "Request does not have the following required fields specified: email."
}
Breaking changes:
400 → 422code removed (was redundant with HTTP status header)Affected endpoints: All POST/PATCH endpoints that validate required fields (e.g., /api/v2/shop/customers, /api/v2/shop/orders/{token}/items, etc.)
Migration guide:
response.status === 400 for missing fields, change it to response.status === 422response.data.code, use response.status (HTTP header) insteadReferences: RFC 9110 (400 = syntactic errors, 422 = semantic/validation errors)
The following API Platform resource classes are now defined as container parameters, allowing you to override them:
| Parameter | Default class |
|---|---|
sylius_api.command.account.reset_password.class | Sylius\Bundle\ApiBundle\Command\Account\ResetPassword |
sylius_api.command.account.verify_shop_user.class | Sylius\Bundle\ApiBundle\Command\Account\VerifyShopUser |
sylius_api.command.admin.account.reset_password.class | Sylius\Bundle\ApiBundle\Command\Admin\Account\ResetPassword |
sylius_api.command.send_contact_request.class | Sylius\Bundle\ApiBundle\Command\SendContactRequest |
To override a class, define the parameter in your configuration:
parameters:
sylius_api.command.account.reset_password.class: App\Api\Command\CustomResetPassword