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

Change Issued JWK / Presented JWK Protected Headers #142

Merged
merged 6 commits into from
Oct 20, 2024
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
65 changes: 21 additions & 44 deletions draft-ietf-jose-json-proof-algorithms.md
Original file line number Diff line number Diff line change
Expand Up @@ -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}

Expand Down Expand Up @@ -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.

Expand Down Expand Up @@ -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}

Expand All @@ -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

Expand Down Expand Up @@ -269,22 +267,16 @@ 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

To use the MAC algorithm, the issuer must have a stable public key pair to perform signing. To start the issuance process, a single 32-byte random Shared Secret must first be generated. This value will be shared privately to the holder as part of the issuer's JWP proof value.

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.
Expand Down Expand Up @@ -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.

Expand Down Expand Up @@ -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}

<reference anchor="VC-DATA-MODEL-2.0" target="https://www.w3.org/TR/vc-data-model-2.0">
Expand All @@ -583,7 +550,6 @@ established by [@!I-D.ietf-jose-json-web-proof].
</front>
</reference>


# 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.
Expand Down Expand Up @@ -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
Expand Down
70 changes: 57 additions & 13 deletions draft-ietf-jose-json-web-proof.md
Original file line number Diff line number Diff line change
Expand Up @@ -308,39 +308,52 @@ 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.

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].

Expand Down Expand Up @@ -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}
Expand Down Expand Up @@ -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.
Expand Down
2 changes: 1 addition & 1 deletion fixtures/mac-h256-fixtures.mjs
Original file line number Diff line number Diff line change
Expand Up @@ -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);
Expand Down
4 changes: 2 additions & 2 deletions fixtures/su-es256-fixtures.mjs
Original file line number Diff line number Diff line change
Expand Up @@ -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"});

Expand Down
Loading