-
Notifications
You must be signed in to change notification settings - Fork 3
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
Issue with normalizeAlgorithm()
universally uppercasing algorithm names
#84
Comments
Hi @Billyzou0741326 , thank you for reporting this 🙇 Checking this it seems you are correct and that the correct way to test for this is actually to have a list of supported algorithms and their canonical names that we match against case insensitively. Your proposed solution also will work for this case, but I wonder if this doesn't happen in other places as well. Maybe just updating it in normalizeAlgorithm is enough 🤷 . Given the fact this algorithm isn't currently supported I don't know whether we should fix it now as part of its implementation. But I guess we can at least apply this smaller patch cc @olegbespalov @oleiade Are there any plans on working in RSA soon ™ ? |
I could be wrong, but I think as far as algorithm name matching, it's mostly done up front in Having done some preliminary testing on rsa implementation (mostly for my immediate needs), the small snippet of patch that I mentioned above should solve the issue for Let me know if the patch is worth applying. If so, I can send a PR |
I have a local branch where I faced the same issue, and the current way of fixing it (I haven't included Webapi tests yet) is also just making an exception. I don't have a strong opinion, but wouldn't it make sense to fix this without implementing the support of RSA (which is currently missing)? |
I'm okay with introducing a custom behavior for it indeed 👍🏻 Not a strong opinion: we should probably wait and do that in the RSA implementation though? For reference, the implementation of the algorithm normalization was particularly painful at the time, and the uppercase constraint was probably a small shortcut I took at the time, that makes no sense in hindsight 🙇🏻 |
Indeed. I was bringing this up mainly because I ran into it during the implementation of that particular algorithm. Agreed that it makes sense to make the change only when it's needed (e.g. when RSA is eventually implemented). |
Another remark about a different alternative to making an exception for Something like:
The only difference is that, instead of mapping from http header name to http header values, the map would map from algorithm name (case insensitive) to its canonical form. Just pointing out another option - kind of echoing back with @mstoykov mentioned:
|
The comment here isn't true for
RSASSA-PKCS1-v1_5
(note the lower casev
in the canonical algorithm name):xk6-webcrypto/webcrypto/algorithm.go
Lines 148 to 151 in f68083c
RSASSA-PKCS1-v1_5
isn't currently supported, so there's not necessarily a problem with the current implementation.But nonetheless, seeing how there are usages of
normalizeAlgorithm()
in validating against user input (inSubtleCrypto.Encrypt
andSubtleCrypto.Decrypt
) as well as selecting the rightSignerVerifier
,KeyGenerator
,KeyImporter
, etc (as I'm typing this out, I realized it's used pretty much everywhere), it's definitely an error to uppercase the algorithm name in the case ofRSASSA-PKCS1-v1_5
in those use cases.To keep the current behavior backward compatible while paving the way for future
RSA
implementation, perhaps it's good to make a special case forRSASSA-PKCS1-v1_5
innormalizeAlgorithm()
?Edit: I'm bringing this issue up because I have a use case of signing & verifying with RSA, and am looking to close the gap in the RSA implementation.
Edit 2: The change that would fix this is as simple as:
This keeps the backward compatibility of testing upper case for all algorithm names, while still using the correct canonical algorithm name for
RSASSA-PKCS1-v1_5
. Thoughts on this approach?The text was updated successfully, but these errors were encountered: