org.apache.cxf.transport.https.CertConstraintsJaxBUtils Maven / Gradle / Ivy
/**
* Licensed to the Apache Software Foundation (ASF) under one
* or more contributor license agreements. See the NOTICE file
* distributed with this work for additional information
* regarding copyright ownership. The ASF 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.apache.cxf.transport.https;
import java.util.List;
import org.apache.cxf.configuration.security.CertificateConstraintsType;
import org.apache.cxf.configuration.security.CombinatorType;
import org.apache.cxf.configuration.security.DNConstraintsType;
/**
* A set of static methods that operate on the generated CertificateConstraintsType.
*/
public final class CertConstraintsJaxBUtils {
private CertConstraintsJaxBUtils() {
// complete
}
/**
* Create a CertConstraints object from a JAXB CertificateConstraintsType
*/
public static CertConstraints createCertConstraints(
CertificateConstraintsType certConstraints
) {
List subjectRegexps = getSubjectConstraints(certConstraints);
CertConstraints.Combinator subjectCombinator =
getSubjectConstraintsCombinator(certConstraints);
List issuerRegexps = getIssuerConstraints(certConstraints);
CertConstraints.Combinator issuerCombinator =
getIssuerConstraintsCombinator(certConstraints);
return new CertConstraints(
subjectRegexps, subjectCombinator, issuerRegexps, issuerCombinator);
}
/**
* Get a List of Strings that corresponds to the subject regular expression
* constraints from a JAXB CertificateConstraintsType
*/
public static List getSubjectConstraints(
CertificateConstraintsType certConstraints
) {
if (certConstraints != null && certConstraints.isSetSubjectDNConstraints()) {
DNConstraintsType constraints = certConstraints.getSubjectDNConstraints();
return constraints.getRegularExpression();
}
return java.util.Collections.emptyList();
}
/**
* Get a List of Strings that corresponds to the issuer regular expression
* constraints from a JAXB CertificateConstraintsType
*/
public static List getIssuerConstraints(
CertificateConstraintsType certConstraints
) {
if (certConstraints != null && certConstraints.isSetIssuerDNConstraints()) {
DNConstraintsType constraints = certConstraints.getIssuerDNConstraints();
return constraints.getRegularExpression();
}
return java.util.Collections.emptyList();
}
/**
* Get a (subject) CertConstrains.Combinator from a JAXB CertificateConstraintsType
*/
public static CertConstraints.Combinator getSubjectConstraintsCombinator(
CertificateConstraintsType certConstraints
) {
if (certConstraints != null && certConstraints.isSetSubjectDNConstraints()) {
DNConstraintsType constraints = certConstraints.getSubjectDNConstraints();
if (constraints != null && constraints.isSetCombinator()) {
CombinatorType combinator = constraints.getCombinator();
if (combinator == CombinatorType.ANY) {
return CertConstraints.Combinator.ANY;
}
}
}
return CertConstraints.Combinator.ALL;
}
/**
* Get a (issuer) CertConstrains.Combinator from a JAXB CertificateConstraintsType
*/
public static CertConstraints.Combinator getIssuerConstraintsCombinator(
CertificateConstraintsType certConstraints
) {
if (certConstraints != null && certConstraints.isSetIssuerDNConstraints()) {
DNConstraintsType constraints = certConstraints.getIssuerDNConstraints();
if (constraints != null && constraints.isSetCombinator()) {
CombinatorType combinator = constraints.getCombinator();
if (combinator == CombinatorType.ANY) {
return CertConstraints.Combinator.ANY;
}
}
}
return CertConstraints.Combinator.ALL;
}
}