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

Inconsistent minimum Byte Length validation between web app and createKey API endpoint #2564

Open
3 tasks done
unrenamed opened this issue Oct 25, 2024 · 9 comments · May be fixed by #2584
Open
3 tasks done

Inconsistent minimum Byte Length validation between web app and createKey API endpoint #2564

unrenamed opened this issue Oct 25, 2024 · 9 comments · May be fixed by #2584
Assignees
Labels
Bug Something isn't working

Comments

@unrenamed
Copy link
Contributor

unrenamed commented Oct 25, 2024

Preliminary Checks

Reproduction / Replay Link (Optional)

No response

Issue Summary

When setting a default minimum byte length for keys (minimum 8 bytes) in the web app, this setting applies when creating keys via the key creation form. However, when attempting to create a key with the same byte length through the https://api.unkey.dev/v1/keys.createKey API endpoint, an error occurs. This inconsistency causes confusion, as it seems the default byte length setting should allow the request to be accepted. Clarifying or aligning these behaviors would improve user experience.

image

curl --request POST \
  --url https://api.unkey.dev/v1/keys.createKey \
  --header 'Authorization: Bearer <token>' \
  --header 'Content-Type: application/json' \
  --data '{
  "apiId": "api_<id>",
  "name": "my key",
  "byteLength": 8 }'

The response body:

{"error":{"code":"BAD_REQUEST","docs":"https://unkey.dev/docs/api-reference/errors/code/BAD_REQUEST","message":"byteLength: Number must be greater than or equal to 16","requestId":"req_"}}

Steps to Reproduce

  1. In the web app, set the default byte length for keys to 8.
  2. Attempt to create a key through the web form using an 8-byte key (this should succeed).
  3. Call the https://api.unkey.dev/v1/keys.createKey endpoint with an 8-byte key in the request body (this should fail with the error body above).

Expected behavior

  1. The web app should accept a minimum 16-byte key in the Create a new key form.
  2. The web app should accept a minimum 16-byte key in the API settings Default Bytes section.
  3. The keys.createKey should use the configured default byte length for the API if the byteLength field is not provided (body.byteLength ?? api.defaultByteLength ?? 16)

Other information

No response

Screenshots

No response

Version info

- OS:
- Node:
- npm:
@unrenamed unrenamed added Bug Something isn't working Needs Approval Needs approval from Unkey labels Oct 25, 2024
@chronark
Copy link
Collaborator

/award 150

Copy link

oss-gg bot commented Oct 25, 2024

Awarding unrenamed: 150 points 🕹️ Well done! Check out your new contribution on oss.gg/unrenamed

@chronark chronark added 🕹️ oss.gg 🕹️ 150 points and removed Needs Approval Needs approval from Unkey labels Oct 25, 2024
Copy link

oss-gg bot commented Oct 25, 2024

You already have an open issue assigned to you here. Once that's closed or unassigned, only then we recommend you to take up more.

@bitbrief
Copy link

/assign

Copy link

oss-gg bot commented Oct 25, 2024

Assigned to @bitbrief! Please open a draft PR linking this issue within 48h ⚠️ If we can't detect a PR from you linking this issue in 48h, you'll be unassigned automatically 🕹️ Excited to have you ship this 🚀

Copy link

oss-gg bot commented Oct 27, 2024

@bitbrief, please open a draft PR linking this issue within 12 hours. If we can't detect a PR in 12 hours, you will be unassigned automatically.

@bitbrief
Copy link

Screenshot 2024-10-27 at 10 40 45 AM

Hi @chronark! I am receiving a 404 error during running the api locally.

@bitbrief bitbrief linked a pull request Oct 27, 2024 that will close this issue
7 tasks
@chronark
Copy link
Collaborator

I need more context to help, what are you doing and what have you tried to fix it?

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
Bug Something isn't working
Projects
None yet
Development

Successfully merging a pull request may close this issue.

4 participants