com.nimbusds.jose.proc.JWEKeySelector Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of nimbus-jose-jwt Show documentation
Show all versions of nimbus-jose-jwt Show documentation
Java library for Javascript Object Signing and Encryption (JOSE) and
JSON Web Tokens (JWT)
package com.nimbusds.jose.proc;
import java.io.IOException;
import java.security.Key;
import java.util.List;
import com.nimbusds.jose.JWEHeader;
import com.nimbusds.jose.KeySourceException;
/**
* Interface for selecting key candidates for decrypting a JSON Web Encryption
* (JWE) object. Applications should utilise this interface or a similar
* framework to determine whether a received JWE object (or encrypted JWT) is
* eligible for {@link com.nimbusds.jose.JWEDecrypter decryption} and further
* processing.
*
* The key selection should be based on application specific criteria, such
* as recognised header parameters referencing the key (e.g. {@code kid},
* {@code x5t}) and / or the JWE object {@link SecurityContext}.
*
*
See JSON Web Signature (JWE), Appendix D. Notes on Key Selection for
* suggestions.
*
*
Possible key types:
*
*
* - {@link javax.crypto.SecretKey} for AES keys.
*
- {@link java.security.interfaces.RSAPrivateKey} private RSA keys.
*
- {@link java.security.interfaces.ECPrivateKey} private EC keys.
*
*
* @author Vladimir Dzhuvinov
* @version 2016-06-21
*/
public interface JWEKeySelector {
/**
* Selects key candidates for decrypting a JWE object.
*
* @param header The header of the JWE object. Must not be
* {@code null}.
* @param context Optional context of the JWE object, {@code null} if
* not required.
*
* @return The key candidates in trial order, empty list if none.
*
* @throws IOException If a key source exception is encountered, e.g.
* on remote JWK retrieval.
*/
List extends Key> selectJWEKeys(final JWEHeader header, final C context)
throws KeySourceException;
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy