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

fix: include full-complement paramters in JWT_PRIVATE_SIGNING_JWK #925

Merged

Conversation

kdmccormick
Copy link
Collaborator

@kdmccormick kdmccormick commented Oct 20, 2023

Addresses the breaking upstream change in this commit: openedx/edx-platform@92731be

image

Relevant discussions:

See Changelog entry for details.


@timmc-edx , could you sanity check this?

HEADS UP REVIEWERS: I don't exactly grok how JWTs and JWKs work and whether this fix is safe. I hope one of you do. If not, we should find someone who does.

Addresses the breaking upstream change in this commit:
openedx/edx-platform@92731be

See Changelog entry for details.
@kdmccormick kdmccormick requested a review from regisb October 20, 2023 18:43
Copy link

@timmc-edx timmc-edx left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Looks good!

@@ -189,6 +189,9 @@
"n": "{{ jwt_rsa_key.n|long_to_base64 }}",
"p": "{{ jwt_rsa_key.p|long_to_base64 }}",
"q": "{{ jwt_rsa_key.q|long_to_base64 }}",
"dq": "{{ jwt_rsa_key.dq|long_to_base64 }}",
"dp": "{{ jwt_rsa_key.dp|long_to_base64 }}",
"qi": "{{ jwt_rsa_key.invq|long_to_base64 }}",

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Some notes on confirming that this is correct:

RSA private numbers are represented with slightly different names in different libraries. n, e, d, p, and q always seem to have the same names. dp and dq aren't documented in pycryptodome (which is what Tutor is using here) but apparently they're present and have a matching definition (d mod (p - 1) and likewise for q.) For qi we can compare with PyJWT's translation from the cryptography library and see that cryptography's iqmp has the same definition as PyCryptodome's invq.

(The JWK spec doesn't actually define what qi is, but instead refers the reader to several print books.)

@regisb
Copy link
Contributor

regisb commented Oct 23, 2023

Let's merge this change and test it in quince.

@regisb regisb merged commit 7f47c3c into overhangio:nightly Oct 23, 2023
1 check passed
@regisb
Copy link
Contributor

regisb commented Oct 23, 2023

Wait... My understanding was that this change was required in Quince. Did I get that correctly @kdmccormick?

@kdmccormick
Copy link
Collaborator Author

@regisb We need the change on Nightly. I don't think we need it in Quince since the breaking edx-platform changed merged after the cut, but it's totally OK to have it in Quince regardless.

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.

3 participants