blob: 753bfb1ff43d1a5c57de27193585f75576843bfb [file] [log] [blame]
/*
* Copyright 2004,2005 The Apache Software Foundation.
*
* Licensed 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.ws.secpolicy.model;
import javax.xml.namespace.QName;
import javax.xml.stream.XMLStreamException;
import javax.xml.stream.XMLStreamWriter;
import org.apache.neethi.PolicyComponent;
import org.apache.ws.secpolicy.Constants;
public class X509Token extends Token {
private boolean requireKeyIdentifierReference;
private boolean requireIssuerSerialReference;
private boolean requireEmbeddedTokenReference;
private boolean requireThumbprintReference;
private String tokenVersionAndType;
/**
* @return Returns the requireEmbeddedTokenReference.
*/
public boolean isRequireEmbeddedTokenReference() {
return requireEmbeddedTokenReference;
}
/**
* @param requireEmbeddedTokenReference The requireEmbeddedTokenReference to set.
*/
public void setRequireEmbeddedTokenReference(
boolean requireEmbeddedTokenReference) {
this.requireEmbeddedTokenReference = requireEmbeddedTokenReference;
}
/**
* @return Returns the requireIssuerSerialReference.
*/
public boolean isRequireIssuerSerialReference() {
return requireIssuerSerialReference;
}
/**
* @param requireIssuerSerialReference The requireIssuerSerialReference to set.
*/
public void setRequireIssuerSerialReference(boolean requireIssuerSerialReference) {
this.requireIssuerSerialReference = requireIssuerSerialReference;
}
/**
* @return Returns the requireKeyIdentifierReference.
*/
public boolean isRequireKeyIdentifierReference() {
return requireKeyIdentifierReference;
}
/**
* @param requireKeyIdentifierReference The requireKeyIdentifierReference to set.
*/
public void setRequireKeyIdentifierReference(
boolean requireKeyIdentifierReference) {
this.requireKeyIdentifierReference = requireKeyIdentifierReference;
}
/**
* @return Returns the requireThumbprintReference.
*/
public boolean isRequireThumbprintReference() {
return requireThumbprintReference;
}
/**
* @param requireThumbprintReference The requireThumbprintReference to set.
*/
public void setRequireThumbprintReference(boolean requireThumbprintReference) {
this.requireThumbprintReference = requireThumbprintReference;
}
/**
* @return Returns the tokenVersionAndType.
*/
public String getTokenVersionAndType() {
return tokenVersionAndType;
}
/**
* @param tokenVersionAndType The tokenVersionAndType to set.
*/
public void setTokenVersionAndType(String tokenVersionAndType) {
this.tokenVersionAndType = tokenVersionAndType;
}
public QName getName() {
return Constants.X509_TOKEN;
}
public PolicyComponent normalize() {
throw new UnsupportedOperationException();
}
public void serialize(XMLStreamWriter writer) throws XMLStreamException {
String localName = Constants.X509_TOKEN.getLocalPart();
String namespaceURI = Constants.X509_TOKEN.getNamespaceURI();
String prefix = writer.getPrefix(namespaceURI);
if (prefix == null) {
prefix = Constants.X509_TOKEN.getPrefix();
writer.setPrefix(prefix, namespaceURI);
}
// <sp:X509Token>
writer.writeStartElement(prefix, localName, namespaceURI);
String inclusion = getInclusion();
if (inclusion != null) {
writer.writeAttribute(prefix, namespaceURI, Constants.INCLUDE_TOKEN
.getLocalPart(), inclusion);
}
String pPrefix = writer.getPrefix(Constants.POLICY.getNamespaceURI());
if (pPrefix == null) {
pPrefix = Constants.POLICY.getPrefix();
writer.setPrefix(pPrefix, Constants.POLICY.getNamespaceURI());
}
// <wsp:Policy>
writer.writeStartElement(pPrefix, Constants.POLICY.getLocalPart(), Constants.POLICY.getNamespaceURI());
if (isRequireKeyIdentifierReference()) {
// <sp:RequireKeyIdentifierReference />
writer.writeStartElement(prefix, Constants.REQUIRE_KEY_IDENTIFIRE_REFERENCE.getLocalPart(), namespaceURI);
writer.writeEndElement();
}
if (isRequireIssuerSerialReference()) {
// <sp:RequireIssuerSerialReference />
writer.writeStartElement(prefix, Constants.REQUIRE_ISSUER_SERIAL_REFERENCE.getLocalPart(), namespaceURI);
writer.writeEndElement();
}
if (isRequireEmbeddedTokenReference()) {
// <sp:RequireEmbeddedTokenReference />
writer.writeStartElement(prefix, Constants.REQUIRE_EMBEDDED_TOKEN_REFERENCE.getLocalPart(), namespaceURI);
writer.writeEndElement();
}
if (isRequireThumbprintReference()) {
// <sp:RequireThumbprintReference />
writer.writeStartElement(prefix, Constants.REQUIRE_THUMBPRINT_REFERENCE.getLocalPart(), namespaceURI);
writer.writeEndElement();
}
if (tokenVersionAndType != null) {
// <sp:WssX509V1Token10 /> | ..
writer.writeStartElement(prefix, tokenVersionAndType, namespaceURI);
writer.writeEndElement();
}
if(isDerivedKeys()) {
// <sp:RequireDerivedKeys/>
writer.writeStartElement(prefix, Constants.REQUIRE_DERIVED_KEYS.getLocalPart(), namespaceURI);
writer.writeEndElement();
}
// </wsp:Policy>
writer.writeEndElement();
// </sp:X509Token>
writer.writeEndElement();
}
}