org.opensaml.xml.signature.validator.PGPDataSchemaValidator Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of xmltooling Show documentation
Show all versions of xmltooling Show documentation
XMLTooling-J is a low-level library that may be used to construct libraries that allow developers to work with XML in a Java beans manner.
/*
* 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.xml.signature.validator;
import java.util.HashSet;
import java.util.Set;
import javax.xml.namespace.QName;
import org.opensaml.xml.XMLObject;
import org.opensaml.xml.signature.PGPData;
import org.opensaml.xml.signature.PGPKeyID;
import org.opensaml.xml.signature.PGPKeyPacket;
import org.opensaml.xml.util.XMLConstants;
import org.opensaml.xml.validation.ValidationException;
import org.opensaml.xml.validation.Validator;
/**
* Checks {@link org.opensaml.xml.signature.PGPData} for Schema compliance.
*/
public class PGPDataSchemaValidator implements Validator {
/** QNames corresponding to the valid children. */
private static final Set VALID_DS_CHILD_NAMES;
/** {@inheritDoc} */
public void validate(PGPData xmlObject) throws ValidationException {
validateChildrenPresence(xmlObject);
validateChildrenNamespaces(xmlObject);
}
/**
* Get the QNames corresponding to the valid children
* defined in the XML Signature namespace.
*
* @return list of valid child QNames
*/
protected static Set getValidDSChildNames() {
return VALID_DS_CHILD_NAMES;
}
/**
* Validate that at least one mandatory child is present.
*
* @param xmlObject the object to validate
* @throws ValidationException thrown if the object is invalid
*/
protected void validateChildrenPresence(PGPData xmlObject) throws ValidationException {
if (xmlObject.getPGPKeyID() == null && xmlObject.getPGPKeyPacket() == null) {
throw new ValidationException("PGPData must contain at least one of PGPKeyID or PGPKeyPacket");
}
}
/**
* Validate that all children are either ones defined within the XML Signature schema,
* or are from another namespace.
*
* @param xmlObject the object to validate
* @throws ValidationException thrown if the object is invalid
*/
protected void validateChildrenNamespaces(PGPData xmlObject) throws ValidationException {
// Validate that any unknown children are from another namespace.
for (XMLObject child : xmlObject.getUnknownXMLObjects()) {
QName childName = child.getElementQName();
if (! getValidDSChildNames().contains(childName)
&& XMLConstants.XMLSIG_NS.equals(childName.getNamespaceURI())) {
throw new ValidationException("PGPData contains an illegal child extension element: " + childName);
}
}
}
static {
VALID_DS_CHILD_NAMES = new HashSet(5);
VALID_DS_CHILD_NAMES.add(PGPKeyID.DEFAULT_ELEMENT_NAME);
VALID_DS_CHILD_NAMES.add(PGPKeyPacket.DEFAULT_ELEMENT_NAME);
}
}
© 2015 - 2024 Weber Informatics LLC | Privacy Policy