diff --git a/draft-ietf-jose-json-proof-algorithms.md b/draft-ietf-jose-json-proof-algorithms.md index a59ea0b..f08d2f0 100644 --- a/draft-ietf-jose-json-proof-algorithms.md +++ b/draft-ietf-jose-json-proof-algorithms.md @@ -46,7 +46,7 @@ organization = "Ping Identity" .# Abstract -The JSON Proof Algorithms (JPA) specification registers cryptographic algorithms and identifiers to be used with the JSON Web Proof and JSON Web Key (JWK) specifications. It defines IANA registries for these identifiers. +The JSON Proof Algorithms (JPA) specification registers cryptographic algorithms and identifiers to be used with the JSON Web Proof, JSON Web Key (JWK), and COSE specifications. It defines IANA registries for these identifiers. {mainmatter} @@ -160,9 +160,9 @@ Each individual payload is signed using the selected internal algorithm using th ### Issuer Protected Header -The JWK of the issuer's Ephemeral Key MUST be included in the issuer protected header with the property name of `proof_jwk` and contain only the REQUIRED values to represent the public key. +The issuer's Ephemeral Key MUST be included in the issuer protected header via the Proof Key header parameter. -The holder's Presentation Key JWK MUST be included in issuer protected header using the `presentation_jwk` parameter. +The holder's Presentation Key MUST be included in issuer protected header via the Presentation Key header parameter. The issuer protected header is signed using the given JWA and the issuer's Stable Key. @@ -199,9 +199,9 @@ Since the individual signatures in the proof value are unique and remain unchang ### Verification -The verifier MUST verify the issuer protected header octets against the first part in the proof using the issuer's Stable Key. It MUST also verify the presentation protected header octets against the second part in the proof value using the holder's Presentation Key, as provided in the `presentation_jwk` claim in the issuer protected header. +The verifier MUST verify the issuer protected header octets against the first part in the proof using the issuer's Stable Key. It MUST also verify the presentation protected header octets against the second part in the proof value using the holder's Presentation Key, as provided in the Presentation Key header parameter. -With the headers verified, the issuer's Ephemeral Key as given in the issuer protected header `proof_jwk` parameter can then be used to verify each of the disclosed payload signatures. +With the headers verified, the Proof Key header parameter can then be used to verify each of the disclosed payload signatures. ### JPA Registration {#SU-registration} @@ -221,11 +221,9 @@ The `BBS-PROOF` `alg` parameter value in the presentation protected header corre ### Key Format -The key used for the `BBS` algorithm is an elliptic curve-based key pair, specifically against the G_2 subgroup of a pairing friendly curve. Additional details on key generation can be found in [@!I-D.irtf-cfrg-bbs-signatures, Section 3.4] +The key used for the `BBS` algorithm is an elliptic curve-based key pair, specifically against the G_2 subgroup of a pairing friendly curve. Additional details on key generation can be found in [@!I-D.irtf-cfrg-bbs-signatures, Section 3.4]. The JWK and Cose Key Object representations of the key are detailed in [@!I-D.ietf-cose-bls-key-representations]. -The JWK form of this key is an `OKP` type with a curve of `BLS12381G2`, with `x` being the base64url-encoded form of the output of `point_to_octets_E2`. The use of this curve is described in [@!I-D.ietf-cose-bls-key-representations]. - -There is no additional holder key necessary for presentation proofs. +There is no additional holder presentation key necessary for presentation proofs. ### Issuance @@ -269,11 +267,9 @@ The design is intentionally minimal and only involves using a single standardize ### Holder Setup -Prior to the issuer creating a new JWP, it must have presentation binding information provided by the holder. This enables the holder to perform replay prevention while presenting the JWP. - -The presentation key used by the holder must be transferred to the issuer and verified, likely through a challenge and self-signing mechanism. If the holder requires unlinkability, it must also generate a new key that is verified and bound to each new JWP. +Prior to the issuer creating a new JWP, the issuer MUST have a presentation public key provided by the holder. -How these holder presentation keys are transferred and verified is out of scope of this specification. Protocols such as OpenID Connect can be used to accomplish this. What is required by this definition is that the holder's presentation key MUST be included in the issuer's protected header using the `presentation_jwk` parameter with a JWK as the value. +The holder's presentation key MUST be included in the issuer's protected header using the Presentation Key header parameter. ### Issuer Setup @@ -281,10 +277,6 @@ To use the MAC algorithm, the issuer must have a stable public key pair to perfo The Shared Secret is used by both the issuer and holder as the MAC method's key to generate a new set of unique ephemeral keys. These keys are then used as the input to generate a MAC that protects each payload. -### Issuer Protected Header {#issuer-protected-header} - -The holder's presentation key JWK MUST be included in the issuer protected header using the `presentation_jwk` parameter. The issuer MUST validate that the holder has possession of this key through a trusted mechanism such as verifying the signature of a unique nonce value from the holder. - ### Combined MAC Representation The combined MAC representation is a single octet string representing the MAC values of the issuer protected header, along with each payload provided by the issuer. This representation is signed by the issuer, but not shared - parties will recreate this octet string and verify the signature to verify the integrity of supplied issuer protected header and the integrity of any disclosed payloads. @@ -317,7 +309,7 @@ See the JWS [Presentation Protected Header](#presentation-protected-header) sect > Editor's Note: The current definition here is incomplete, the holder's signature needs to also incorporate the presented proof. -The first value in the presentation proof is the presentation signature. This is a signature over the presentation protected header, using the key specified by the `presentation_jwk` parameter in the issuer protected header. +The first value in the presentation proof is the presentation signature. This is a signature over the presentation protected header, using the key specified by the Presentation Key header parameter in the issuer protected header. The second value is the issuer signature over the Combined MAC Representation provided with the issued form. @@ -534,31 +526,6 @@ defining the revised implementation requirements level. * Specification Document(s): (#MAC-registration) of this specification * Algorithm Analysis Documents(s): n/a -## JSON Web Proof Header Parameters Registration {#HdrReg} - -This section registers the following JWP Header Parameters in the -IANA "JSON Web Proof Header Parameters" registry -established by [@!I-D.ietf-jose-json-web-proof]. - -### Registry Contents {#HdrContents} - -#### Proof JWK Header Parameter - -* Header Parameter Name: `proof_jwk` -* Header Parameter Description: Issuer's Ephemeral Key -* Header Parameter Usage Location(s): Issued -* Change Controller: IETF -* Specification Document(s): (#issuer-protected-header) of this specification - -#### Presentation JWK Header Parameter - -* Header Parameter Name: `presentation_jwk` -* Header Parameter Description: Holder's Presentation Key -* Header Parameter Usage Location(s): Issued -* Change Controller: IETF -* Specification Document(s): (#issuer-protected-header) of this specification - - {backmatter} @@ -583,7 +550,6 @@ established by [@!I-D.ietf-jose-json-web-proof]. - # Example JWPs The following examples use algorithms defined in JSON Proof Algorithms and also contain the keys used, so that implementations can validate these samples. @@ -800,6 +766,17 @@ The BBS examples were generated using the library at https://github.com/mattrglo [[ To be removed from the final specification ]] + -latest + + * Defer BBS key definition to [@I-D.ietf-cose-bls-key-representations] + * Modify example generation to use `proof_key` and `presentation_key` names + * Change `proof_jwk` to `proof_key` and `presentation_jwk` to + `presentation_key` to better represent that the key may be JSON + or CBOR-formatted. + * Moved the registry for `proof_key` and `presentation_key` to JWP + where they are defined. Consolidated usage, purpose and + requirements from algorith musage under these definitions. + -06 * Update reference to new repository home diff --git a/draft-ietf-jose-json-web-proof.md b/draft-ietf-jose-json-web-proof.md index 776024d..0afa152 100644 --- a/draft-ietf-jose-json-web-proof.md +++ b/draft-ietf-jose-json-web-proof.md @@ -308,10 +308,12 @@ therefore, it MUST occur only within the JWP Protected Header. Use of this Header Parameter is OPTIONAL. This Header Parameter MUST be understood and processed by implementations. -### "proof_jwk" (Proof JWK) Header Parameter {#proof_jwkDef} +### "proof_key" (Proof Key) Header Parameter {#proof_keyDef} + +The `proof_key` (Proof Key) represents the public key used by the issuer +for proof of possession within certain algorithms. This is an ephemeral +key that MUST be unique for each issued JWP. -The `proof_jwk` (Proof JWK) represents the public key used by the issuer -for proof of possession. This header parameter is references a JSON Web Key (JWK) public key value when represented as a JSON Protected Header, and a COSE Key Object when represented as a CBOR Protected Header. @@ -319,28 +321,39 @@ Object when represented as a CBOR Protected Header. It MUST contain only public key parameters and SHOULD contain only the minimum parameters necessary to represent the key; other parameters included can be checked for consistency and honored, or they can be ignored. -This Header Parameter MUST be present in the JWP issuer header parameters -and MUST be understood and processed by implementations. -### "presentation_jwk" (Presentation JWK) Header Parameter {#presentation_jwkDef} +When present, this Header Parameter MUST be understood and processed by implementations. + +### "presentation_key" (Presentation Key) Header Parameter {#presentation_keyDef} + +The `presentation_key` (Presentation Key) represents the public key +with certain algorithms, and is used by the holder for proof of +possession and integrity protection of the presented protected header. -The `presentation_jwk` (Presentation JWK) represents the public key used by the holder -for proof of possession. +The issuer MUST validate that the holder has possession of this key +through a trusted mechanism, such as requiring the signature of a +unique nonce value from the holder before issuing the JWP. This header parameter is references a JSON Web Key (JWK) public key value when represented as a JSON Protected Header, and a COSE Key Object when represented as a CBOR Protected Header. -It MUST contain only public key parameters and -SHOULD contain only the minimum parameters necessary to represent the key; -other parameters included can be checked for consistency and honored, or they can be ignored. -This Header Parameter MUST be present in the JWP issuer header parameters -and MUST be understood and processed by implementations. +It MUST contain only public key parameters and SHOULD contain only the +minimum parameters necessary to represent the key; other parameters +included can be checked for consistency and honored, or they can be +ignored. + +If holder unlinkability is required, this value MUST not be repeated +in multiple issued JWPs; a different presentation key MUST +be included in each issuance. + +This Header Parameter MUST be understood and processed by implementations when present. ### "iss" (Issuer) Header Parameter {#issDef} The `iss` (issuer) Header Parameter identifies the principal that issued the JWP. The processing of this claim is generally application specific. + The `iss` value is a case-sensitive string containing a StringOrURI value. Its definition is intentionally parallel to the `iss` claim defined in [@!RFC7519]. @@ -805,6 +818,24 @@ This section registers the Header Parameters defined in * Change Controller: IETF * Specification Document(s): (#claimsDef) of this specification +#### Proof Key Header Parameter + +* Header Parameter Name: Proof Key +* Header Parameter JSON Label: `proof_key` +* Header Parameter CBOR Label: 9 +* Header Parameter Usage Location(s): Issued +* Change Controller: IETF +* Specification Document(s): (#proof_keyDef) of this specification + +#### Presentation Key Header Parameter + +* Header Parameter Name: Presentation Key +* Header Parameter JSON Label: `presentation_key` +* Header Parameter CBOR Label: 10 +* Header Parameter Usage Location(s): Issued +* Change Controller: IETF +* Specification Document(s): (#presentation_keyDef) of this specification + ## Media Type Registration {#MediaReg} ### Registry Contents {#MediaContents} @@ -1017,6 +1048,19 @@ for his valuable contributions to this specification. [[ To be removed from the final specification ]] + -latest + + * Modify example generation to use `proof_key` and `presentation_key` names + * Change `proof_jwk` to `proof_key` and `presentation_jwk` to + `presentation_key` to better represent that the key may be JSON + or CBOR-formatted. + * Moved the registry for `proof_key` and `presentation_key` to JWP + where they are defined. Consolidated usage, purpose and + requirements from algorith musage under these definitions. + * Clarified that `proof_key` and `presentation_key` are required + by particular algorithms and are not more generally required for + issued and presented JWPs. + -06 * Update reference to new repository home. diff --git a/fixtures/mac-h256-fixtures.mjs b/fixtures/mac-h256-fixtures.mjs index 91b791c..69a60ae 100644 --- a/fixtures/mac-h256-fixtures.mjs +++ b/fixtures/mac-h256-fixtures.mjs @@ -35,7 +35,7 @@ const holderPrivateKey = crypto.createPrivateKey({ /// Create Issued JWP // Modify the issuer protected header by adding the Holder's public key -issuerProtectedHeaderJSON.presentation_jwk = holderPublicKeyJSON; +issuerProtectedHeaderJSON.presentation_key = holderPublicKeyJSON; // encode/sign the issuer protected header w/ the stable key const finalIssuerProtectedHeader = JSON.stringify(issuerProtectedHeaderJSON); diff --git a/fixtures/su-es256-fixtures.mjs b/fixtures/su-es256-fixtures.mjs index 610e780..45556d2 100644 --- a/fixtures/su-es256-fixtures.mjs +++ b/fixtures/su-es256-fixtures.mjs @@ -34,8 +34,8 @@ const ephemeralPrivateKey = crypto.createPrivateKey({ // storage as we build up const sigs = []; -issuerProtectedHeaderJSON.proof_jwk = ephemeralPrivateKeyJSON; -issuerProtectedHeaderJSON.presentation_jwk = holderPrivateKeyJSON; +issuerProtectedHeaderJSON.proof_key = ephemeralPrivateKeyJSON; +issuerProtectedHeaderJSON.presentation_key = holderPrivateKeyJSON; await fs.writeFile("build/su-es256-issuer-protected-header.json", JSON.stringify(issuerProtectedHeaderJSON, null, 2), {encoding: "UTF-8"}); await fs.writeFile("build/su-es256-issuer-protected-header.json.wrapped", lineWrap(JSON.stringify(issuerProtectedHeaderJSON, null, 2)), {encoding: "UTF-8"});