-
Notifications
You must be signed in to change notification settings - Fork 386
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
feat: add error codes #1377
feat: add error codes #1377
Conversation
Very nice and granular error codes! This will bring the DX of Supabase's authentication module much closer to that of Firebase. Great work. 😎 |
Note that at this point these are just extractions, they're not definitive in shape or form. |
would be great if we can create an |
67c583b
to
3a558bc
Compare
6f0b17b
to
e9b32fc
Compare
5b94095
to
00f6ab1
Compare
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Thanks! This looks fine to me - will do another pass later in day and open PR if needed
b480655
to
a47ce87
Compare
🤖 I have created a release *beep* *boop* --- ## [2.145.0](v2.144.0...v2.145.0) (2024-03-26) ### Features * add error codes ([#1377](#1377)) ([e4beea1](e4beea1)) * add kakao OIDC ([#1381](#1381)) ([b5566e7](b5566e7)) * clean up expired factors ([#1371](#1371)) ([5c94207](5c94207)) * configurable NameID format for SAML provider ([#1481](#1481)) ([ef405d8](ef405d8)) * HTTP Hook - Add custom envconfig decoding for HTTP Hook Secrets ([#1467](#1467)) ([5b24c4e](5b24c4e)) * refactor PKCE FlowState to reduce duplicate code ([#1446](#1446)) ([b8d0337](b8d0337)) ### Bug Fixes * add http support for https hooks on localhost ([#1484](#1484)) ([5c04104](5c04104)) * cleanup panics due to bad inactivity timeout code ([#1471](#1471)) ([548edf8](548edf8)) * **docs:** remove bracket on file name for broken link ([#1493](#1493)) ([96f7a68](96f7a68)) * impose expiry on auth code instead of magic link ([#1440](#1440)) ([35aeaf1](35aeaf1)) * invalidate email, phone OTPs on password change ([#1489](#1489)) ([960a4f9](960a4f9)) * move creation of flow state into function ([#1470](#1470)) ([4392a08](4392a08)) * prevent user email side-channel leak on verify ([#1472](#1472)) ([311cde8](311cde8)) * refactor email sending functions ([#1495](#1495)) ([285c290](285c290)) * refactor factor_test to centralize setup ([#1473](#1473)) ([c86007e](c86007e)) * refactor mfa challenge and tests ([#1469](#1469)) ([6c76f21](6c76f21)) * Resend SMS when duplicate SMS sign ups are made ([#1490](#1490)) ([73240a0](73240a0)) * unlink identity bugs ([#1475](#1475)) ([73e8d87](73e8d87)) --- This PR was generated with [Release Please](https://github.com/googleapis/release-please). See [documentation](https://github.com/googleapis/release-please#release-please). Co-authored-by: github-actions[bot] <41898282+github-actions[bot]@users.noreply.github.com>
Adds support for error codes. All `AuthError` descendants will now have a `code` property which will encode (when present and supported by the server) the reason why the error occurred. To support this, the library will now advertise `X-Supabase-Api-Version: 2024-01-01` which is the first version of a new versioning strategy that supports a different encoding for error responses. See: - supabase/auth#1377
@mashwishi From your code snippet I don't really understand how that log message is getting generated, but I believe that Something like this:
|
Will test that out today. |
that's weird. it works on console.log({
'code:': response?.error?.code,
'name:': response?.error?.name,
'status:': response?.error?.status,
'message:': response?.error?.message
}); with output:
But what i am trying to get is proper error code which i get it right now and right error message like example invalid password, account doesnt exist something like that from the auth api. because if i am going to base it on error code, how would i determine if account doesn't exist or password is incorrect? because they have same output of error message "Invalid credentials" if using error response and "400 error code" |
## What kind of change does this PR introduce? * Fixes an error introduced in #1377 where generating a signup link for a new user results in a "User with this email not found" error ## What is the current behavior? Please link any relevant issues here. ## What is the new behavior? Feel free to include screenshots if it includes visual changes. ## Additional context Add any other context or screenshots.
Adds proper error codes with API versioning. From now on, all responses that end in a 4XX HTTP status code will include a textual description of the error that occurred. Error responses on API versions before `2024-01-01` have this schema: ```json { "code": "<http status code>", "msg": "<descriptive error message>", "error_code": "<textual error code>" } ``` Error responses on API version on or after `2024-01-01` have this schema: ```json { "code": "<textual error code>", "message": "<descriptive error message>" } ``` API versions are controlled by submitting an `X-Supabase-Api-Version` header to the request. A missing or invalid value assumes the "initial" API version as used before the introduction of API version `2024-01-01`. Error code contract for API version `2024-01-01`: 1. Error codes will not be renamed. You can safely rely on them. 2. HTTP status codes are _mostly_ fixed, but you should not rely on them except the class 4XX vs 5XX. 3. Error messages are a _developer aid._ They may change across deployed version. You should not rely on them, but if you want you can show them to your users. Error translations should be based on the error code! Of the 4XX HTTP status code class, only these codes are allowed to be used in API version `2024-01-01` according to these rules. The purpose of this is to keep proper HTTP semantics. The tuple `(http_status_code, error_code)` shouldn't be used by clients! <table> <thead class="simple-table-header"><tr id="865bd663-796b-4bdc-a53d-8aecbdc35ab5"><th id="=Aef" class="simple-table-header-color simple-table-header" style="width:142.9666748046875px">HTTP Status Code</th><th id="UuUa" class="simple-table-header-color simple-table-header" style="width:390px">When to use?</th><th>Primary Fault At</th></tr></thead><tbody><tr id="794cf424-14a8-449c-880f-b6073206e70b"><td id="=Aef" class="" style="width:142.9666748046875px">400 Bad Request</td><td id="UuUa" class="" style="width:390px">Inputs (body, headers) and their contents are not valid as a whole, or parts of them. Example: bad JSON, bad JSON object, using two mutually exclusive JSON fields, missing required fields, wrong encoding…<br><br>If the answer to this question is <br><em>yes</em> then you should probably use 400: Is there some <em>technical</em> thing the developer should do to get a different status code?</td><td>Developer.<br><br>MUST NEVER OCCUR WHEN USING AN OFFICIAL SUPABASE LIBRARY.<br><br>Why?<br>- Library should not send invalid requests.<br>- If occurring, means: improper types, no client-side validation.<br></td></tr><tr id="11fb5eb7-0d25-41f3-998b-86162dedcf93"><td id="=Aef" class="" style="width:142.9666748046875px">401 Unauthorized</td><td id="UuUa" class="" style="width:390px">You must use this code if security headers or inputs are missing, and are not valid to some extent. Example: missing JWT, missing CAPTCHA token, missing important query params that serve to authenticate the caller.<br><br>You may use 400 instead if the security headers or inputs are provided and relatively valid (valid JWT signature, bad claims) instead, though prefer 401 over 400 unless it aids in DX.<br><br>Do not use this code to signal that the user does not have sufficient application privileges.<br><br>If the answer to this question is <br><em>yes</em> then you should use 401: Are the credentials the user/client sending missing or invalid in form, structure, encoding? </td><td>Developer.<br><br>MUST NEVER OCCUR WHEN USING AN OFFICIAL SUPABASE LIBRARY. <br><br>Why?<br>- Library should never send improper requests (missing authorization headers for features that require authorization).<br>- If occurring means: broken logic, improper types, no client-side validation.<br></td></tr><tr id="fa0e33d5-425c-442d-bdfb-18d68e11cc9e"><td id="=Aef" class="" style="width:142.9666748046875px">403 Forbidden</td><td id="UuUa" class="" style="width:390px">Do not use this code for bad JWT format, missing headers or other validation on security sensitive payloads. Return 400 on those.<br><br>Once security payloads have been validated in structure, only return this error if the user/client can be authenticated properly but they do not possess the proper authorization to access the resource.<br><br>If the answer to this question is <br><em>yes</em> then you should use 403: Should the user/client be someone else to get a different status code?<br><br>In some cases you should prefer 200 responses with empty bodies, akin to RLS behavior.<br></td><td>User.<br><br>Developer is at fault for not hiding the feature sufficiently.<br><br>Can rarely occur when using Supabase libraries, and in such cases it means docs / explanation problems.<br></td></tr><tr id="c16ac87c-7433-4750-bdf8-a8a47148b5da"><td id="=Aef" class="" style="width:142.9666748046875px">404 Not Found</td><td id="UuUa" class="" style="width:390px">Do not use this for missing objects in the database. Prefer using 422 instead.<br><br>Use only if the URL cannot be fully validated, resulting in a resource that cannot be properly identified. If there’s no variables in the path, this code must not be used.<br><br>Good:<br>- /users/<not-uuid><br>- /users/<uuid> (but such a user does not exist)<br><br>Bad:<br>- /token?grant_type=password (no variables in URL)<br>- /sessions (no variables in URL)<br><br>For cases where a feature is disabled on a server consider using 501 or 422.<br><br>For requests that “look up” entities consider using 200 with an empty/null response body or 204 No Content instead.<br></td><td>Developer.<br><br>MUST NEVER OCCUR WHEN USING AN OFFICIAL SUPABASE LIBRARY. <br><br>Why?<br>- Library should never send improperly formatted URLs, or encode data in URLs that it knows to be invalid.<br>- Ideally library should not take in freeform input about entities, and should use some “proof” that the entity exists. Example: calling methods on objects returned by a list/find-by-id method.<br>- In some situations it’s inevitable (like in admin APIs).<br></td></tr><tr id="ab865315-a594-4490-ab71-254cd536c461"><td id="=Aef" class="" style="width:142.9666748046875px"><a href="https://www.rfc-editor.org/rfc/rfc9110#section-15.5.21">422 Unprocessable Entity</a></td><td id="UuUa" class="" style="width:390px">Do not use for bad inputs!<br><br>Once all inputs to a request have been validated to the fullest extent possible (e.g. OK to validate an email address format, but not necessary to validate that there’s a SMTP server listening), use this status code to signal errors with the processing logic. This includes all logic dependent on database state (user exists, or doesn’t). All third-party expected errors (like calling into a third service) should end with 422.<br><br>If the answer to this question is <br><em>yes</em> then you should use 422: Is there something different that the user should do to get a different status code?</td><td>User.<br><br>Developer is at fault for using the feature in an improper part of the flow.<br><br>Can rarely occur when using Supabase libraries, and in such cases it means docs / explanation problems.<br></td></tr><tr id="58d30ecb-ca21-4bcf-ab4f-79e352eea516"><td id="=Aef" class="" style="width:142.9666748046875px">429 Too Many Requests</td><td id="UuUa" class="" style="width:390px">Only use this for rate-limiting or other cases that limit the number of requests. Third-party rate-limits should be propagated with this error.</td><td>User.<br><br>Developer should have implemented a better UX to prevent reaching this error for legitimate users. (Disabling buttons, adding timeout UI elements…)<br></td></tr><tr id="305e93a6-65e9-4670-a778-523470696d4a"><td id="=Aef" class="" style="width:142.9666748046875px">500 Internal Server Error</td><td id="UuUa" class="" style="width:390px">Use this for any <em>unexpected</em> errors when processing a request. Default to this code if you can’t find a 4XX error code for it.</td><td>Supabase. Developer in some cases (such as when changing database contents).<br><br>The cause of this error should not be situations arising from official Supabase libraries (such as sending inputs that crash the server).<br><br></td></tr><tr id="3fdd4130-137b-49d4-807e-003ce7baf4af"><td id="=Aef" class="" style="width:142.9666748046875px">501 Not Implemented</td><td id="UuUa" class="" style="width:390px">A feature is disabled, not configured (properly), blocked or otherwise unavailable.</td><td>Developer, for not enabling or configuring features properly.</td></tr></tbody> </table> --------- Co-authored-by: joel <joel@joels-MacBook-Pro.local>
🤖 I have created a release *beep* *boop* --- ## [2.145.0](supabase/auth@v2.144.0...v2.145.0) (2024-03-26) ### Features * add error codes ([supabase#1377](supabase#1377)) ([e4beea1](supabase@e4beea1)) * add kakao OIDC ([supabase#1381](supabase#1381)) ([b5566e7](supabase@b5566e7)) * clean up expired factors ([supabase#1371](supabase#1371)) ([5c94207](supabase@5c94207)) * configurable NameID format for SAML provider ([supabase#1481](supabase#1481)) ([ef405d8](supabase@ef405d8)) * HTTP Hook - Add custom envconfig decoding for HTTP Hook Secrets ([supabase#1467](supabase#1467)) ([5b24c4e](supabase@5b24c4e)) * refactor PKCE FlowState to reduce duplicate code ([supabase#1446](supabase#1446)) ([b8d0337](supabase@b8d0337)) ### Bug Fixes * add http support for https hooks on localhost ([supabase#1484](supabase#1484)) ([5c04104](supabase@5c04104)) * cleanup panics due to bad inactivity timeout code ([supabase#1471](supabase#1471)) ([548edf8](supabase@548edf8)) * **docs:** remove bracket on file name for broken link ([supabase#1493](supabase#1493)) ([96f7a68](supabase@96f7a68)) * impose expiry on auth code instead of magic link ([supabase#1440](supabase#1440)) ([35aeaf1](supabase@35aeaf1)) * invalidate email, phone OTPs on password change ([supabase#1489](supabase#1489)) ([960a4f9](supabase@960a4f9)) * move creation of flow state into function ([supabase#1470](supabase#1470)) ([4392a08](supabase@4392a08)) * prevent user email side-channel leak on verify ([supabase#1472](supabase#1472)) ([311cde8](supabase@311cde8)) * refactor email sending functions ([supabase#1495](supabase#1495)) ([285c290](supabase@285c290)) * refactor factor_test to centralize setup ([supabase#1473](supabase#1473)) ([c86007e](supabase@c86007e)) * refactor mfa challenge and tests ([supabase#1469](supabase#1469)) ([6c76f21](supabase@6c76f21)) * Resend SMS when duplicate SMS sign ups are made ([supabase#1490](supabase#1490)) ([73240a0](supabase@73240a0)) * unlink identity bugs ([supabase#1475](supabase#1475)) ([73e8d87](supabase@73e8d87)) --- This PR was generated with [Release Please](https://github.com/googleapis/release-please). See [documentation](https://github.com/googleapis/release-please#release-please). Co-authored-by: github-actions[bot] <41898282+github-actions[bot]@users.noreply.github.com>
## What kind of change does this PR introduce? * Fixes an error introduced in supabase#1377 where generating a signup link for a new user results in a "User with this email not found" error ## What is the current behavior? Please link any relevant issues here. ## What is the new behavior? Feel free to include screenshots if it includes visual changes. ## Additional context Add any other context or screenshots.
Adds proper error codes with API versioning. From now on, all responses that end in a 4XX HTTP status code will include a textual description of the error that occurred. Error responses on API versions before `2024-01-01` have this schema: ```json { "code": "<http status code>", "msg": "<descriptive error message>", "error_code": "<textual error code>" } ``` Error responses on API version on or after `2024-01-01` have this schema: ```json { "code": "<textual error code>", "message": "<descriptive error message>" } ``` API versions are controlled by submitting an `X-Supabase-Api-Version` header to the request. A missing or invalid value assumes the "initial" API version as used before the introduction of API version `2024-01-01`. Error code contract for API version `2024-01-01`: 1. Error codes will not be renamed. You can safely rely on them. 2. HTTP status codes are _mostly_ fixed, but you should not rely on them except the class 4XX vs 5XX. 3. Error messages are a _developer aid._ They may change across deployed version. You should not rely on them, but if you want you can show them to your users. Error translations should be based on the error code! Of the 4XX HTTP status code class, only these codes are allowed to be used in API version `2024-01-01` according to these rules. The purpose of this is to keep proper HTTP semantics. The tuple `(http_status_code, error_code)` shouldn't be used by clients! <table> <thead class="simple-table-header"><tr id="865bd663-796b-4bdc-a53d-8aecbdc35ab5"><th id="=Aef" class="simple-table-header-color simple-table-header" style="width:142.9666748046875px">HTTP Status Code</th><th id="UuUa" class="simple-table-header-color simple-table-header" style="width:390px">When to use?</th><th>Primary Fault At</th></tr></thead><tbody><tr id="794cf424-14a8-449c-880f-b6073206e70b"><td id="=Aef" class="" style="width:142.9666748046875px">400 Bad Request</td><td id="UuUa" class="" style="width:390px">Inputs (body, headers) and their contents are not valid as a whole, or parts of them. Example: bad JSON, bad JSON object, using two mutually exclusive JSON fields, missing required fields, wrong encoding…<br><br>If the answer to this question is <br><em>yes</em> then you should probably use 400: Is there some <em>technical</em> thing the developer should do to get a different status code?</td><td>Developer.<br><br>MUST NEVER OCCUR WHEN USING AN OFFICIAL SUPABASE LIBRARY.<br><br>Why?<br>- Library should not send invalid requests.<br>- If occurring, means: improper types, no client-side validation.<br></td></tr><tr id="11fb5eb7-0d25-41f3-998b-86162dedcf93"><td id="=Aef" class="" style="width:142.9666748046875px">401 Unauthorized</td><td id="UuUa" class="" style="width:390px">You must use this code if security headers or inputs are missing, and are not valid to some extent. Example: missing JWT, missing CAPTCHA token, missing important query params that serve to authenticate the caller.<br><br>You may use 400 instead if the security headers or inputs are provided and relatively valid (valid JWT signature, bad claims) instead, though prefer 401 over 400 unless it aids in DX.<br><br>Do not use this code to signal that the user does not have sufficient application privileges.<br><br>If the answer to this question is <br><em>yes</em> then you should use 401: Are the credentials the user/client sending missing or invalid in form, structure, encoding? </td><td>Developer.<br><br>MUST NEVER OCCUR WHEN USING AN OFFICIAL SUPABASE LIBRARY. <br><br>Why?<br>- Library should never send improper requests (missing authorization headers for features that require authorization).<br>- If occurring means: broken logic, improper types, no client-side validation.<br></td></tr><tr id="fa0e33d5-425c-442d-bdfb-18d68e11cc9e"><td id="=Aef" class="" style="width:142.9666748046875px">403 Forbidden</td><td id="UuUa" class="" style="width:390px">Do not use this code for bad JWT format, missing headers or other validation on security sensitive payloads. Return 400 on those.<br><br>Once security payloads have been validated in structure, only return this error if the user/client can be authenticated properly but they do not possess the proper authorization to access the resource.<br><br>If the answer to this question is <br><em>yes</em> then you should use 403: Should the user/client be someone else to get a different status code?<br><br>In some cases you should prefer 200 responses with empty bodies, akin to RLS behavior.<br></td><td>User.<br><br>Developer is at fault for not hiding the feature sufficiently.<br><br>Can rarely occur when using Supabase libraries, and in such cases it means docs / explanation problems.<br></td></tr><tr id="c16ac87c-7433-4750-bdf8-a8a47148b5da"><td id="=Aef" class="" style="width:142.9666748046875px">404 Not Found</td><td id="UuUa" class="" style="width:390px">Do not use this for missing objects in the database. Prefer using 422 instead.<br><br>Use only if the URL cannot be fully validated, resulting in a resource that cannot be properly identified. If there’s no variables in the path, this code must not be used.<br><br>Good:<br>- /users/<not-uuid><br>- /users/<uuid> (but such a user does not exist)<br><br>Bad:<br>- /token?grant_type=password (no variables in URL)<br>- /sessions (no variables in URL)<br><br>For cases where a feature is disabled on a server consider using 501 or 422.<br><br>For requests that “look up” entities consider using 200 with an empty/null response body or 204 No Content instead.<br></td><td>Developer.<br><br>MUST NEVER OCCUR WHEN USING AN OFFICIAL SUPABASE LIBRARY. <br><br>Why?<br>- Library should never send improperly formatted URLs, or encode data in URLs that it knows to be invalid.<br>- Ideally library should not take in freeform input about entities, and should use some “proof” that the entity exists. Example: calling methods on objects returned by a list/find-by-id method.<br>- In some situations it’s inevitable (like in admin APIs).<br></td></tr><tr id="ab865315-a594-4490-ab71-254cd536c461"><td id="=Aef" class="" style="width:142.9666748046875px"><a href="https://www.rfc-editor.org/rfc/rfc9110#section-15.5.21">422 Unprocessable Entity</a></td><td id="UuUa" class="" style="width:390px">Do not use for bad inputs!<br><br>Once all inputs to a request have been validated to the fullest extent possible (e.g. OK to validate an email address format, but not necessary to validate that there’s a SMTP server listening), use this status code to signal errors with the processing logic. This includes all logic dependent on database state (user exists, or doesn’t). All third-party expected errors (like calling into a third service) should end with 422.<br><br>If the answer to this question is <br><em>yes</em> then you should use 422: Is there something different that the user should do to get a different status code?</td><td>User.<br><br>Developer is at fault for using the feature in an improper part of the flow.<br><br>Can rarely occur when using Supabase libraries, and in such cases it means docs / explanation problems.<br></td></tr><tr id="58d30ecb-ca21-4bcf-ab4f-79e352eea516"><td id="=Aef" class="" style="width:142.9666748046875px">429 Too Many Requests</td><td id="UuUa" class="" style="width:390px">Only use this for rate-limiting or other cases that limit the number of requests. Third-party rate-limits should be propagated with this error.</td><td>User.<br><br>Developer should have implemented a better UX to prevent reaching this error for legitimate users. (Disabling buttons, adding timeout UI elements…)<br></td></tr><tr id="305e93a6-65e9-4670-a778-523470696d4a"><td id="=Aef" class="" style="width:142.9666748046875px">500 Internal Server Error</td><td id="UuUa" class="" style="width:390px">Use this for any <em>unexpected</em> errors when processing a request. Default to this code if you can’t find a 4XX error code for it.</td><td>Supabase. Developer in some cases (such as when changing database contents).<br><br>The cause of this error should not be situations arising from official Supabase libraries (such as sending inputs that crash the server).<br><br></td></tr><tr id="3fdd4130-137b-49d4-807e-003ce7baf4af"><td id="=Aef" class="" style="width:142.9666748046875px">501 Not Implemented</td><td id="UuUa" class="" style="width:390px">A feature is disabled, not configured (properly), blocked or otherwise unavailable.</td><td>Developer, for not enabling or configuring features properly.</td></tr></tbody> </table> --------- Co-authored-by: joel <joel@joels-MacBook-Pro.local>
🤖 I have created a release *beep* *boop* --- ## [2.145.0](supabase/auth@v2.144.0...v2.145.0) (2024-03-26) ### Features * add error codes ([supabase#1377](supabase#1377)) ([e4beea1](supabase@e4beea1)) * add kakao OIDC ([supabase#1381](supabase#1381)) ([b5566e7](supabase@b5566e7)) * clean up expired factors ([supabase#1371](supabase#1371)) ([5c94207](supabase@5c94207)) * configurable NameID format for SAML provider ([supabase#1481](supabase#1481)) ([ef405d8](supabase@ef405d8)) * HTTP Hook - Add custom envconfig decoding for HTTP Hook Secrets ([supabase#1467](supabase#1467)) ([5b24c4e](supabase@5b24c4e)) * refactor PKCE FlowState to reduce duplicate code ([supabase#1446](supabase#1446)) ([b8d0337](supabase@b8d0337)) ### Bug Fixes * add http support for https hooks on localhost ([supabase#1484](supabase#1484)) ([5c04104](supabase@5c04104)) * cleanup panics due to bad inactivity timeout code ([supabase#1471](supabase#1471)) ([548edf8](supabase@548edf8)) * **docs:** remove bracket on file name for broken link ([supabase#1493](supabase#1493)) ([96f7a68](supabase@96f7a68)) * impose expiry on auth code instead of magic link ([supabase#1440](supabase#1440)) ([35aeaf1](supabase@35aeaf1)) * invalidate email, phone OTPs on password change ([supabase#1489](supabase#1489)) ([960a4f9](supabase@960a4f9)) * move creation of flow state into function ([supabase#1470](supabase#1470)) ([4392a08](supabase@4392a08)) * prevent user email side-channel leak on verify ([supabase#1472](supabase#1472)) ([311cde8](supabase@311cde8)) * refactor email sending functions ([supabase#1495](supabase#1495)) ([285c290](supabase@285c290)) * refactor factor_test to centralize setup ([supabase#1473](supabase#1473)) ([c86007e](supabase@c86007e)) * refactor mfa challenge and tests ([supabase#1469](supabase#1469)) ([6c76f21](supabase@6c76f21)) * Resend SMS when duplicate SMS sign ups are made ([supabase#1490](supabase#1490)) ([73240a0](supabase@73240a0)) * unlink identity bugs ([supabase#1475](supabase#1475)) ([73e8d87](supabase@73e8d87)) --- This PR was generated with [Release Please](https://github.com/googleapis/release-please). See [documentation](https://github.com/googleapis/release-please#release-please). Co-authored-by: github-actions[bot] <41898282+github-actions[bot]@users.noreply.github.com>
## What kind of change does this PR introduce? * Fixes an error introduced in supabase#1377 where generating a signup link for a new user results in a "User with this email not found" error ## What is the current behavior? Please link any relevant issues here. ## What is the new behavior? Feel free to include screenshots if it includes visual changes. ## Additional context Add any other context or screenshots.
Adds proper error codes with API versioning. From now on, all responses that end in a 4XX HTTP status code will include a textual description of the error that occurred. Error responses on API versions before `2024-01-01` have this schema: ```json { "code": "<http status code>", "msg": "<descriptive error message>", "error_code": "<textual error code>" } ``` Error responses on API version on or after `2024-01-01` have this schema: ```json { "code": "<textual error code>", "message": "<descriptive error message>" } ``` API versions are controlled by submitting an `X-Supabase-Api-Version` header to the request. A missing or invalid value assumes the "initial" API version as used before the introduction of API version `2024-01-01`. Error code contract for API version `2024-01-01`: 1. Error codes will not be renamed. You can safely rely on them. 2. HTTP status codes are _mostly_ fixed, but you should not rely on them except the class 4XX vs 5XX. 3. Error messages are a _developer aid._ They may change across deployed version. You should not rely on them, but if you want you can show them to your users. Error translations should be based on the error code! Of the 4XX HTTP status code class, only these codes are allowed to be used in API version `2024-01-01` according to these rules. The purpose of this is to keep proper HTTP semantics. The tuple `(http_status_code, error_code)` shouldn't be used by clients! <table> <thead class="simple-table-header"><tr id="865bd663-796b-4bdc-a53d-8aecbdc35ab5"><th id="=Aef" class="simple-table-header-color simple-table-header" style="width:142.9666748046875px">HTTP Status Code</th><th id="UuUa" class="simple-table-header-color simple-table-header" style="width:390px">When to use?</th><th>Primary Fault At</th></tr></thead><tbody><tr id="794cf424-14a8-449c-880f-b6073206e70b"><td id="=Aef" class="" style="width:142.9666748046875px">400 Bad Request</td><td id="UuUa" class="" style="width:390px">Inputs (body, headers) and their contents are not valid as a whole, or parts of them. Example: bad JSON, bad JSON object, using two mutually exclusive JSON fields, missing required fields, wrong encoding…<br><br>If the answer to this question is <br><em>yes</em> then you should probably use 400: Is there some <em>technical</em> thing the developer should do to get a different status code?</td><td>Developer.<br><br>MUST NEVER OCCUR WHEN USING AN OFFICIAL SUPABASE LIBRARY.<br><br>Why?<br>- Library should not send invalid requests.<br>- If occurring, means: improper types, no client-side validation.<br></td></tr><tr id="11fb5eb7-0d25-41f3-998b-86162dedcf93"><td id="=Aef" class="" style="width:142.9666748046875px">401 Unauthorized</td><td id="UuUa" class="" style="width:390px">You must use this code if security headers or inputs are missing, and are not valid to some extent. Example: missing JWT, missing CAPTCHA token, missing important query params that serve to authenticate the caller.<br><br>You may use 400 instead if the security headers or inputs are provided and relatively valid (valid JWT signature, bad claims) instead, though prefer 401 over 400 unless it aids in DX.<br><br>Do not use this code to signal that the user does not have sufficient application privileges.<br><br>If the answer to this question is <br><em>yes</em> then you should use 401: Are the credentials the user/client sending missing or invalid in form, structure, encoding? </td><td>Developer.<br><br>MUST NEVER OCCUR WHEN USING AN OFFICIAL SUPABASE LIBRARY. <br><br>Why?<br>- Library should never send improper requests (missing authorization headers for features that require authorization).<br>- If occurring means: broken logic, improper types, no client-side validation.<br></td></tr><tr id="fa0e33d5-425c-442d-bdfb-18d68e11cc9e"><td id="=Aef" class="" style="width:142.9666748046875px">403 Forbidden</td><td id="UuUa" class="" style="width:390px">Do not use this code for bad JWT format, missing headers or other validation on security sensitive payloads. Return 400 on those.<br><br>Once security payloads have been validated in structure, only return this error if the user/client can be authenticated properly but they do not possess the proper authorization to access the resource.<br><br>If the answer to this question is <br><em>yes</em> then you should use 403: Should the user/client be someone else to get a different status code?<br><br>In some cases you should prefer 200 responses with empty bodies, akin to RLS behavior.<br></td><td>User.<br><br>Developer is at fault for not hiding the feature sufficiently.<br><br>Can rarely occur when using Supabase libraries, and in such cases it means docs / explanation problems.<br></td></tr><tr id="c16ac87c-7433-4750-bdf8-a8a47148b5da"><td id="=Aef" class="" style="width:142.9666748046875px">404 Not Found</td><td id="UuUa" class="" style="width:390px">Do not use this for missing objects in the database. Prefer using 422 instead.<br><br>Use only if the URL cannot be fully validated, resulting in a resource that cannot be properly identified. If there’s no variables in the path, this code must not be used.<br><br>Good:<br>- /users/<not-uuid><br>- /users/<uuid> (but such a user does not exist)<br><br>Bad:<br>- /token?grant_type=password (no variables in URL)<br>- /sessions (no variables in URL)<br><br>For cases where a feature is disabled on a server consider using 501 or 422.<br><br>For requests that “look up” entities consider using 200 with an empty/null response body or 204 No Content instead.<br></td><td>Developer.<br><br>MUST NEVER OCCUR WHEN USING AN OFFICIAL SUPABASE LIBRARY. <br><br>Why?<br>- Library should never send improperly formatted URLs, or encode data in URLs that it knows to be invalid.<br>- Ideally library should not take in freeform input about entities, and should use some “proof” that the entity exists. Example: calling methods on objects returned by a list/find-by-id method.<br>- In some situations it’s inevitable (like in admin APIs).<br></td></tr><tr id="ab865315-a594-4490-ab71-254cd536c461"><td id="=Aef" class="" style="width:142.9666748046875px"><a href="https://www.rfc-editor.org/rfc/rfc9110#section-15.5.21">422 Unprocessable Entity</a></td><td id="UuUa" class="" style="width:390px">Do not use for bad inputs!<br><br>Once all inputs to a request have been validated to the fullest extent possible (e.g. OK to validate an email address format, but not necessary to validate that there’s a SMTP server listening), use this status code to signal errors with the processing logic. This includes all logic dependent on database state (user exists, or doesn’t). All third-party expected errors (like calling into a third service) should end with 422.<br><br>If the answer to this question is <br><em>yes</em> then you should use 422: Is there something different that the user should do to get a different status code?</td><td>User.<br><br>Developer is at fault for using the feature in an improper part of the flow.<br><br>Can rarely occur when using Supabase libraries, and in such cases it means docs / explanation problems.<br></td></tr><tr id="58d30ecb-ca21-4bcf-ab4f-79e352eea516"><td id="=Aef" class="" style="width:142.9666748046875px">429 Too Many Requests</td><td id="UuUa" class="" style="width:390px">Only use this for rate-limiting or other cases that limit the number of requests. Third-party rate-limits should be propagated with this error.</td><td>User.<br><br>Developer should have implemented a better UX to prevent reaching this error for legitimate users. (Disabling buttons, adding timeout UI elements…)<br></td></tr><tr id="305e93a6-65e9-4670-a778-523470696d4a"><td id="=Aef" class="" style="width:142.9666748046875px">500 Internal Server Error</td><td id="UuUa" class="" style="width:390px">Use this for any <em>unexpected</em> errors when processing a request. Default to this code if you can’t find a 4XX error code for it.</td><td>Supabase. Developer in some cases (such as when changing database contents).<br><br>The cause of this error should not be situations arising from official Supabase libraries (such as sending inputs that crash the server).<br><br></td></tr><tr id="3fdd4130-137b-49d4-807e-003ce7baf4af"><td id="=Aef" class="" style="width:142.9666748046875px">501 Not Implemented</td><td id="UuUa" class="" style="width:390px">A feature is disabled, not configured (properly), blocked or otherwise unavailable.</td><td>Developer, for not enabling or configuring features properly.</td></tr></tbody> </table> --------- Co-authored-by: joel <joel@joels-MacBook-Pro.local>
🤖 I have created a release *beep* *boop* --- ## [2.145.0](supabase/auth@v2.144.0...v2.145.0) (2024-03-26) ### Features * add error codes ([supabase#1377](supabase#1377)) ([e4beea1](supabase@e4beea1)) * add kakao OIDC ([supabase#1381](supabase#1381)) ([b5566e7](supabase@b5566e7)) * clean up expired factors ([supabase#1371](supabase#1371)) ([5c94207](supabase@5c94207)) * configurable NameID format for SAML provider ([supabase#1481](supabase#1481)) ([ef405d8](supabase@ef405d8)) * HTTP Hook - Add custom envconfig decoding for HTTP Hook Secrets ([supabase#1467](supabase#1467)) ([5b24c4e](supabase@5b24c4e)) * refactor PKCE FlowState to reduce duplicate code ([supabase#1446](supabase#1446)) ([b8d0337](supabase@b8d0337)) ### Bug Fixes * add http support for https hooks on localhost ([supabase#1484](supabase#1484)) ([5c04104](supabase@5c04104)) * cleanup panics due to bad inactivity timeout code ([supabase#1471](supabase#1471)) ([548edf8](supabase@548edf8)) * **docs:** remove bracket on file name for broken link ([supabase#1493](supabase#1493)) ([96f7a68](supabase@96f7a68)) * impose expiry on auth code instead of magic link ([supabase#1440](supabase#1440)) ([35aeaf1](supabase@35aeaf1)) * invalidate email, phone OTPs on password change ([supabase#1489](supabase#1489)) ([960a4f9](supabase@960a4f9)) * move creation of flow state into function ([supabase#1470](supabase#1470)) ([4392a08](supabase@4392a08)) * prevent user email side-channel leak on verify ([supabase#1472](supabase#1472)) ([311cde8](supabase@311cde8)) * refactor email sending functions ([supabase#1495](supabase#1495)) ([285c290](supabase@285c290)) * refactor factor_test to centralize setup ([supabase#1473](supabase#1473)) ([c86007e](supabase@c86007e)) * refactor mfa challenge and tests ([supabase#1469](supabase#1469)) ([6c76f21](supabase@6c76f21)) * Resend SMS when duplicate SMS sign ups are made ([supabase#1490](supabase#1490)) ([73240a0](supabase@73240a0)) * unlink identity bugs ([supabase#1475](supabase#1475)) ([73e8d87](supabase@73e8d87)) --- This PR was generated with [Release Please](https://github.com/googleapis/release-please). See [documentation](https://github.com/googleapis/release-please#release-please). Co-authored-by: github-actions[bot] <41898282+github-actions[bot]@users.noreply.github.com>
## What kind of change does this PR introduce? * Fixes an error introduced in supabase#1377 where generating a signup link for a new user results in a "User with this email not found" error ## What is the current behavior? Please link any relevant issues here. ## What is the new behavior? Feel free to include screenshots if it includes visual changes. ## Additional context Add any other context or screenshots.
Adds proper error codes with API versioning.
From now on, all responses that end in a 4XX HTTP status code will include a textual description of the error that occurred.
Error responses on API versions before
2024-01-01
have this schema:Error responses on API version on or after
2024-01-01
have this schema:API versions are controlled by submitting an
X-Supabase-Api-Version
header to the request. A missing or invalid value assumes the "initial" API version as used before the introduction of API version2024-01-01
.Error code contract for API version
2024-01-01
:Of the 4XX HTTP status code class, only these codes are allowed to be used in API version
2024-01-01
according to these rules. The purpose of this is to keep proper HTTP semantics. The tuple(http_status_code, error_code)
shouldn't be used by clients!If the answer to this question is
yes then you should probably use 400: Is there some technical thing the developer should do to get a different status code?
MUST NEVER OCCUR WHEN USING AN OFFICIAL SUPABASE LIBRARY.
Why?
- Library should not send invalid requests.
- If occurring, means: improper types, no client-side validation.
You may use 400 instead if the security headers or inputs are provided and relatively valid (valid JWT signature, bad claims) instead, though prefer 401 over 400 unless it aids in DX.
Do not use this code to signal that the user does not have sufficient application privileges.
If the answer to this question is
yes then you should use 401: Are the credentials the user/client sending missing or invalid in form, structure, encoding?
MUST NEVER OCCUR WHEN USING AN OFFICIAL SUPABASE LIBRARY.
Why?
- Library should never send improper requests (missing authorization headers for features that require authorization).
- If occurring means: broken logic, improper types, no client-side validation.
Once security payloads have been validated in structure, only return this error if the user/client can be authenticated properly but they do not possess the proper authorization to access the resource.
If the answer to this question is
yes then you should use 403: Should the user/client be someone else to get a different status code?
In some cases you should prefer 200 responses with empty bodies, akin to RLS behavior.
Developer is at fault for not hiding the feature sufficiently.
Can rarely occur when using Supabase libraries, and in such cases it means docs / explanation problems.
Use only if the URL cannot be fully validated, resulting in a resource that cannot be properly identified. If there’s no variables in the path, this code must not be used.
Good:
- /users/<not-uuid>
- /users/<uuid> (but such a user does not exist)
Bad:
- /token?grant_type=password (no variables in URL)
- /sessions (no variables in URL)
For cases where a feature is disabled on a server consider using 501 or 422.
For requests that “look up” entities consider using 200 with an empty/null response body or 204 No Content instead.
MUST NEVER OCCUR WHEN USING AN OFFICIAL SUPABASE LIBRARY.
Why?
- Library should never send improperly formatted URLs, or encode data in URLs that it knows to be invalid.
- Ideally library should not take in freeform input about entities, and should use some “proof” that the entity exists. Example: calling methods on objects returned by a list/find-by-id method.
- In some situations it’s inevitable (like in admin APIs).
Once all inputs to a request have been validated to the fullest extent possible (e.g. OK to validate an email address format, but not necessary to validate that there’s a SMTP server listening), use this status code to signal errors with the processing logic. This includes all logic dependent on database state (user exists, or doesn’t). All third-party expected errors (like calling into a third service) should end with 422.
If the answer to this question is
yes then you should use 422: Is there something different that the user should do to get a different status code?
Developer is at fault for using the feature in an improper part of the flow.
Can rarely occur when using Supabase libraries, and in such cases it means docs / explanation problems.
Developer should have implemented a better UX to prevent reaching this error for legitimate users. (Disabling buttons, adding timeout UI elements…)
The cause of this error should not be situations arising from official Supabase libraries (such as sending inputs that crash the server).