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

drf-problems fields overwrite Validation field info #5

Open
jayvdb opened this issue Jul 26, 2020 · 3 comments
Open

drf-problems fields overwrite Validation field info #5

jayvdb opened this issue Jul 26, 2020 · 3 comments

Comments

@jayvdb
Copy link

jayvdb commented Jul 26, 2020

If there is a serializer data validation error on a field title, status or type, the validation message will be overwritten by drf-problems which forces exception meta info into those fields.

@jayvdb
Copy link
Author

jayvdb commented Jul 27, 2020

It should be noted that I have no control over these fields - they are in a third-party Django app, and that app is critical, and my project is in production, so hacking about in critical third-party apps renaming their fields is not happening. I can change the front-end to suit drf-problems - but drf-problems needs to not conflict with other Django apps.

One approach used by other drf exception handlers is to move field validation errors down to a new subkey under the root.

I really appreciate that this app keeps the validation errors unmodified at the top node - that is great for compatibility, and easy adoption. But IMO copying the field validation errors to a subkey will allow clients to fix their code to use the subkey only in the areas where it is necessary because drf-problems is overwriting title/status/type at the top level.

I think there should be a config setting like DRF_PROBLEMS_CLOBBER = True enabled by default, which preserves the current behaviour, but also copies the field validations under the new subkey.

Then existing sites with clients already expecting field validation errors in the root can disable DRF_PROBLEMS_CLOBBER, and then only rely on the title/status/type on views which dont use those field name or after type checking those key values in the frontend response handler. Not pretty, but pragmatic. Some sites may have clients already using their API, and the third-party code is not under their control, or the users cant/wont be upgrading their clients quickly. In this case, drf-problems can be added in a "mostly working" state, but backwards compatibility and drf field validation takes priority.

Adding a new subkey introduces another key which could conflict with the original response, so it is worth thinking about it carefully, and possibly also worth adding a setting so sites can change it if it is causing them problems.

IMO, detail seems like a sane choice, but it isnt backwards compatible, as it conflicts with existing use of detail in responses, which includes apps like allauth, rest-auth, etc, etc.

So, IMO, an improbable default key like $errors or _errors is more appropriate.

@jayvdb
Copy link
Author

jayvdb commented Jul 27, 2020

Hmm, I see that errors is already being used in the fallback:

    else:
        data = dict(errors=response.data, title=problem_title,
                    status=problem_status, type=problem_type)

@shivanshs9
Copy link
Owner

shivanshs9 commented Aug 5, 2020

I think there should be a config setting like DRF_PROBLEMS_CLOBBER = True enabled by default, which preserves the current behaviour, but also copies the field validations under the new subkey.

That sounds like a good idea. Since this library ensures view responses are valid RFC 7807 response, title, type, status are members of it (detail would probably be provided by the view itself in most cases). Having a global flag to control whether to follow valid format as per RFC or backwards-compatible response should definitely be up to the user.

Adding a new subkey introduces another key which could conflict with the original response, so it is worth thinking about it carefully, and possibly also worth adding a setting so sites can change it if it is causing them problems.

I think asking user for the key in config setting would suffice. Something like DRF_PROBLEMS_PROBLEM_KEY = None (default for overwriting the root node). Setting it to any non-null string would use that key for providing problem details.

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

No branches or pull requests

2 participants