![JAR search and dependency download from the Maven repository](/logo.png)
org.opensaml.xmlsec.impl.BasicSignatureValidationParametersResolver Maven / Gradle / Ivy
/*
* Licensed to the University Corporation for Advanced Internet Development,
* Inc. (UCAID) under one or more contributor license agreements. See the
* NOTICE file distributed with this work for additional information regarding
* copyright ownership. The UCAID licenses this file to You under the Apache
* License, Version 2.0 (the "License"); you may not use this file except in
* compliance with the License. You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
package org.opensaml.xmlsec.impl;
import java.util.Collections;
import javax.annotation.Nonnull;
import javax.annotation.Nullable;
import net.shibboleth.utilities.java.support.logic.Constraint;
import net.shibboleth.utilities.java.support.resolver.CriteriaSet;
import net.shibboleth.utilities.java.support.resolver.ResolverException;
import org.opensaml.xmlsec.SignatureValidationConfiguration;
import org.opensaml.xmlsec.SignatureValidationParameters;
import org.opensaml.xmlsec.SignatureValidationParametersResolver;
import org.opensaml.xmlsec.criterion.SignatureValidationConfigurationCriterion;
import org.opensaml.xmlsec.signature.support.SignatureTrustEngine;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
/**
* Basic implementation of {@link SignatureValidationParametersResolver}.
*
*
* The following {@link net.shibboleth.utilities.java.support.resolver.Criterion} inputs are supported:
*
* - {@link SignatureValidationConfigurationCriterion} - required
*
*
*/
public class BasicSignatureValidationParametersResolver
extends AbstractSecurityParametersResolver
implements SignatureValidationParametersResolver {
/** Logger. */
private Logger log = LoggerFactory.getLogger(BasicSignatureValidationParametersResolver.class);
/** {@inheritDoc} */
@Nonnull public Iterable resolve(@Nonnull final CriteriaSet criteria)
throws ResolverException {
SignatureValidationParameters params = resolveSingle(criteria);
if (params != null) {
return Collections.singletonList(params);
} else {
return Collections.emptyList();
}
}
/** {@inheritDoc} */
@Nullable
public SignatureValidationParameters resolveSingle(@Nonnull final CriteriaSet criteria) throws ResolverException {
Constraint.isNotNull(criteria, "CriteriaSet was null");
Constraint.isNotNull(criteria.get(SignatureValidationConfigurationCriterion.class),
"Resolver requires an instance of SignatureValidationConfigurationCriterion");
SignatureValidationParameters params = new SignatureValidationParameters();
resolveAndPopulateWhiteAndBlacklists(params, criteria,
criteria.get(SignatureValidationConfigurationCriterion.class).getConfigurations());
params.setSignatureTrustEngine(resolveSignatureTrustEngine(criteria));
logResult(params);
return params;
}
/**
* Log the resolved parameters.
*
* @param params the resolved param
*/
protected void logResult(@Nonnull final SignatureValidationParameters params) {
if (log.isDebugEnabled()) {
log.debug("Resolved SignatureValidationParameters:");
log.debug("\tAlgorithm whitelist: {}", params.getWhitelistedAlgorithms());
log.debug("\tAlgorithm blacklist: {}", params.getBlacklistedAlgorithms());
log.debug("\tSignatureTrustEngine: {}",
params.getSignatureTrustEngine() != null ? "present" : "null");
}
}
/**
* Resolve and return the effective {@link SignatureTrustEngine}.
*
* @param criteria the input criteria being evaluated
*
* @return the effective resolver, or null
*/
@Nullable protected SignatureTrustEngine resolveSignatureTrustEngine(@Nonnull final CriteriaSet criteria) {
for (SignatureValidationConfiguration config : criteria.get(SignatureValidationConfigurationCriterion.class)
.getConfigurations()) {
if (config.getSignatureTrustEngine() != null) {
return config.getSignatureTrustEngine();
}
}
return null;
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy