Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Return GraphQL JSON response in case of JSON Input error instead of Internal Server Error #208

Conversation

cvergne
Copy link
Contributor

@cvergne cvergne commented Apr 17, 2024

Fixes #207


The purpose of the PR is to return a standard GraphQL JSON error response in case of JSON error in given input (request body).

{
    "errors": [
        {
            "message": "Invalid JSON.",
            "extensions": {
                "reason": "Syntax error"
            }
        }
    ]
}

It adds an Exception Listener which set a JsonResponse in case of thrown GraphQLExceptionInterface (to catch any GraphQL Exception outside of the GraphQL Server context).

Also added the two exception cases of the controller into errors functional tests.

Note

Got an error when running test about DependencyInjection/Configuration.php not compatible with implemented interface, so fixed it but tell me if I should remove it and having it fixed in another PR.

@homersimpsons homersimpsons requested a review from mistraloz May 5, 2024 00:09
@homersimpsons
Copy link
Collaborator

I will let @mistraloz review this as you discussed it.

About the implementation I'm okay with the current status. But I'm feeling that it may be too complex, this adds a lew listener, a new exception (which names conflict with a std one).

I think this is the right way to approach this as the end user will have enough control on it. But maybe a simple return new JsonResponse(..., 422) would have been sufficient.

Thank you for the tests too!

@cvergne
Copy link
Contributor Author

cvergne commented Nov 7, 2024

May we reopen this pull request as it just needs review ? :)

@homersimpsons homersimpsons reopened this Nov 9, 2024
@github-actions github-actions bot removed the stale label Nov 10, 2024
@andrew-demb
Copy link
Collaborator

@cvergne what do you think about such refactoring - to avoid introducing an exception listener for now (as suggested in #208 (comment))?

andrew-demb@cf664c3

@andrew-demb andrew-demb self-requested a review January 2, 2025 08:41
@Lappihuan
Copy link
Collaborator

@andrew-demb looks good, we ended up adding a listener in our app to make sure we always return a valid json in /graphql but it always felt hacky.

@andrew-demb
Copy link
Collaborator

@cvergne please rebase this PR over the current master with the applied suggestion from #208 (comment)

@cvergne
Copy link
Contributor Author

cvergne commented Jan 3, 2025

@andrew-demb I will do it by tuesday at the latest 😉

@cvergne cvergne force-pushed the feat/json-error-to-graphql-response branch 2 times, most recently from 57abcaa to fba23aa Compare January 5, 2025 20:34
@cvergne cvergne force-pushed the feat/json-error-to-graphql-response branch from fba23aa to 80cdfbb Compare January 5, 2025 20:37
@cvergne
Copy link
Contributor Author

cvergne commented Jan 5, 2025

@andrew-demb Please do not merge it yet, I have to check why the tests are failing. I'll do it this monday 😉

Exceptions/JsonException.php Outdated Show resolved Hide resolved
@cvergne cvergne requested a review from andrew-demb January 6, 2025 15:46
@cvergne
Copy link
Contributor Author

cvergne commented Jan 6, 2025

Alright, all green about tests.
I didn't even noticed some of my files were not in src… 🤦

@andrew-demb andrew-demb merged commit 58cc91a into thecodingmachine:master Jan 6, 2025
3 checks passed
@andrew-demb
Copy link
Collaborator

Thank you @cvergne

Released in v7.1.0 https://github.com/thecodingmachine/graphqlite-bundle/releases/tag/v7.1.0

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

JSON Error : return readable error instead of RuntimeException
4 participants