-
Notifications
You must be signed in to change notification settings - Fork 0
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
draft: support alg ECDH-1PU+A256KW for jwe tokens #1
base: master
Are you sure you want to change the base?
Conversation
josecipher "github.com/go-jose/go-jose/v4/cipher" | ||
) | ||
|
||
type PrivateKeyResolver func(kid string) (*ecdh.PrivateKey, error) |
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.
if we can provide comments to exported types / functions - that would be great!
} | ||
} | ||
|
||
func (e *Encrypter) Encrypt(recipientKid, senderKid string, plaintext []byte) (string, error) { |
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.
can we provide options pattern here even if we don't need them now, so in future we can extend with a support of other algs / feauters. Is it reasonable?
} | ||
|
||
o := &decrypterOptions{ | ||
kid: headers["kid"], |
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.
should we have this headers as constants?
apvHash := sha256.Sum256(recipient.Bytes()) | ||
|
||
headers := map[string]string{} | ||
headers["alg"] = "ECDH-1PU+A256KW" |
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.
should we have these algorithms as constants?
Currently, we are unable to use popular JOSE libraries to build JWE tokens with the ECDH-1PU key agreement protocol. This is because the ECDH-1PU algorithm is still considered a proposal for future releases as a part of JWT. Unfortunately, there is no way to add custom key agreement protocols to the popular libraries, as explained below:
go-jose This library does not provide any interface to implement custom key agreement protocols. Additionally, it does not support go ECDH keys used for Diffie-Hellman operations.
jwx This library is slightly more flexible as it supports ECDH keys, but only on the X25519 curve, with no support for NIST curves. While it is possible to derive a CEK (Content Encryption Key) externally and pass it to the StaticEncrypt method for encrypting the KEK (Key Encryption Key), this process introduces another issue. The library adds an incorrect alg value to the header block because it does not recognize or support the ECDH-1PU protocol.