org.apache.cxf.ws.security.policy.model.AsymmetricBinding Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of cxf-bundle-minimal Show documentation
Show all versions of cxf-bundle-minimal Show documentation
Apache CXF Minimal Bundle Jar
/**
* 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.ws.security.policy.model;
import javax.xml.namespace.QName;
import javax.xml.stream.XMLStreamException;
import javax.xml.stream.XMLStreamWriter;
import org.apache.cxf.ws.policy.PolicyBuilder;
import org.apache.cxf.ws.policy.builder.primitive.PrimitiveAssertion;
import org.apache.cxf.ws.security.policy.SP12Constants;
import org.apache.cxf.ws.security.policy.SPConstants;
import org.apache.neethi.All;
import org.apache.neethi.ExactlyOne;
import org.apache.neethi.Policy;
import org.apache.neethi.PolicyComponent;
public class AsymmetricBinding extends SymmetricAsymmetricBindingBase {
private InitiatorToken initiatorToken;
private RecipientToken recipientToken;
public AsymmetricBinding(SPConstants version, PolicyBuilder b) {
super(version, b);
}
/**
* @return Returns the initiatorToken.
*/
public InitiatorToken getInitiatorToken() {
return initiatorToken;
}
/**
* @param initiatorToken The initiatorToken to set.
*/
public void setInitiatorToken(InitiatorToken initiatorToken) {
this.initiatorToken = initiatorToken;
}
/**
* @return Returns the recipientToken.
*/
public RecipientToken getRecipientToken() {
return recipientToken;
}
/**
* @param recipientToken The recipientToken to set.
*/
public void setRecipientToken(RecipientToken recipientToken) {
this.recipientToken = recipientToken;
}
public QName getRealName() {
return constants.getAsymmetricBinding();
}
public QName getName() {
return SP12Constants.INSTANCE.getAsymmetricBinding();
}
public PolicyComponent normalize() {
return this;
}
public Policy getPolicy() {
Policy p = new Policy();
ExactlyOne ea = new ExactlyOne();
p.addPolicyComponent(ea);
All all = new All();
/*
asymmetricBinding.setAlgorithmSuite(algorithmSuite);
asymmetricBinding.setProtectionOrder(getProtectionOrder());
asymmetricBinding.setSignatureProtection(isSignatureProtection());
asymmetricBinding.setSignedEndorsingSupportingTokens(getSignedEndorsingSupportingTokens());
asymmetricBinding.setTokenProtection(isTokenProtection());
*/
if (getInitiatorToken() != null) {
all.addPolicyComponent(getInitiatorToken());
}
if (getRecipientToken() != null) {
all.addPolicyComponent(getRecipientToken());
}
/*
if (isEntireHeadersAndBodySignatures()) {
all.addPolicyComponent(new PrimitiveAssertion(SP12Constants.ONLY_SIGN_ENTIRE_HEADERS_AND_BODY));
}
*/
if (isIncludeTimestamp()) {
all.addPolicyComponent(new PrimitiveAssertion(SP12Constants.INCLUDE_TIMESTAMP));
}
if (getLayout() != null) {
all.addPolicyComponent(getLayout());
}
ea.addPolicyComponent(all);
PolicyComponent pc = p.normalize(builder.getPolicyRegistry(), true);
if (pc instanceof Policy) {
return (Policy)pc;
} else {
p = new Policy();
p.addPolicyComponent(pc);
return p;
}
}
public void serialize(XMLStreamWriter writer) throws XMLStreamException {
String localname = getRealName().getLocalPart();
String namespaceURI = getRealName().getNamespaceURI();
String prefix = writer.getPrefix(namespaceURI);
if (prefix == null) {
prefix = getRealName().getPrefix();
writer.setPrefix(prefix, namespaceURI);
}
//
writer.writeStartElement(prefix, localname, namespaceURI);
writer.writeNamespace(prefix, namespaceURI);
String pPrefix = writer.getPrefix(SPConstants.POLICY.getNamespaceURI());
if (pPrefix == null) {
pPrefix = SPConstants.POLICY.getPrefix();
writer.setPrefix(pPrefix, SPConstants.POLICY.getNamespaceURI());
}
//
writer.writeStartElement(pPrefix, SPConstants.POLICY.getLocalPart(), SPConstants.POLICY
.getNamespaceURI());
if (initiatorToken == null) {
throw new RuntimeException("InitiatorToken is not set");
}
//
initiatorToken.serialize(writer);
//
if (recipientToken == null) {
throw new RuntimeException("RecipientToken is not set");
}
//
recipientToken.serialize(writer);
//
AlgorithmSuite algorithmSuite = getAlgorithmSuite();
if (algorithmSuite == null) {
throw new RuntimeException("AlgorithmSuite is not set");
}
//
algorithmSuite.serialize(writer);
//
Layout layout = getLayout();
if (layout != null) {
//
layout.serialize(writer);
//
}
if (isIncludeTimestamp()) {
//
writer.writeStartElement(prefix, SPConstants.INCLUDE_TIMESTAMP, namespaceURI);
writer.writeEndElement();
//
}
if (SPConstants.ProtectionOrder.EncryptBeforeSigning.equals(getProtectionOrder())) {
//
writer.writeStartElement(prefix, SPConstants.ProtectionOrder.EncryptBeforeSigning.toString(),
namespaceURI);
writer.writeEndElement();
}
if (isSignatureProtection()) {
//
// FIXME move the String constants to a QName
writer.writeStartElement(prefix, SPConstants.ENCRYPT_SIGNATURE, namespaceURI);
writer.writeEndElement();
}
if (isTokenProtection()) {
//
writer.writeStartElement(prefix, SPConstants.PROTECT_TOKENS, namespaceURI);
writer.writeEndElement();
}
if (isEntireHeadersAndBodySignatures()) {
//
writer.writeStartElement(prefix, SPConstants.ONLY_SIGN_ENTIRE_HEADERS_AND_BODY, namespaceURI);
writer.writeEndElement();
}
//
writer.writeEndElement();
//
writer.writeEndElement();
}
}