com.nimbusds.jose.crypto.CriticalHeaderParamsDeferral Maven / Gradle / Ivy
package com.nimbusds.jose.crypto;
import java.util.Collections;
import java.util.Set;
import com.nimbusds.jose.CriticalHeaderParamsAware;
import com.nimbusds.jose.Header;
import com.nimbusds.jose.JOSEException;
import com.nimbusds.jose.JWEHeader;
/**
* Critical ({@code crit}) header parameters deferral policy.
*
* @see CriticalHeaderParamsAware
*
* @author Vladimir Dzhuvinov
* @version 2015-05-20
*/
class CriticalHeaderParamsDeferral {
/**
* The names of the deferred critical headers.
*/
private Set deferredParams = Collections.emptySet();
/**
* Returns the names of the critical ({@code crit}) header parameters
* that are understood and processed.
*
* @return Empty immutable set.
*/
public Set getProcessedCriticalHeaderParams() {
return Collections.emptySet();
}
/**
* Returns the names of the critical ({@code crit}) header parameters
* that are deferred to the application for processing.
*
* @return The names of the critical header parameters that are
* deferred to the application for processing, as an
* unmodifiable set, empty set if none.
*/
public Set getDeferredCriticalHeaderParams() {
return Collections.unmodifiableSet(deferredParams);
}
/**
* Sets the names of the critical ({@code crit}) header parameters
* that are deferred to the application for processing.
*
* @param defCritHeaders The names of the critical header parameters
* that are deferred to the application for
* processing, empty set or {@code null} if none.
*/
public void setDeferredCriticalHeaderParams(final Set defCritHeaders) {
if (defCritHeaders == null) {
this.deferredParams = Collections.emptySet();
} else {
this.deferredParams = defCritHeaders;
}
}
/**
* Returns {@code true} if the specified header passes the critical
* parameters check.
*
* @param header The JWS or JWE header to check. Must not be
* {@code null}.
*
* @return {@code true} if the header passes, {@code false} if the
* header contains one or more critical header parameters which
* are not marked for deferral to the application.
*/
public boolean headerPasses(final Header header) {
Set crit = header.getCriticalParams();
if (crit == null || crit.isEmpty()) {
return true; // OK
}
// Ensure all marked as deferred
return deferredParams != null && deferredParams.containsAll(crit);
}
/**
* Throws a JOSE exception if the specified JWE header doesn't pass the
* critical header parameters check.
*
* @param header The JWE header to check. Must not be {@code null}.
*
* @throws JOSEException If the JWE header doesn't pass the check.
*/
public void ensureHeaderPasses(final JWEHeader header)
throws JOSEException {
if (! headerPasses(header)) {
throw new JOSEException("Unsupported critical header parameter(s)");
}
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy