use of org.apache.cxf.ws.security.wss4j.CryptoCoverageUtil.CoverageType in project cxf by apache.
the class AbstractPolicySecurityTest method runInInterceptorAndValidateWss.
protected void runInInterceptorAndValidateWss(Document document, AssertionInfoMap aim, List<CoverageType> types) throws Exception {
PolicyBasedWSS4JInInterceptor inHandler = this.getInInterceptor(types);
SoapMessage inmsg = this.getSoapMessageForDom(document, aim);
Element securityHeaderElem = WSSecurityUtil.getSecurityHeader(document, "");
if (securityHeaderElem != null) {
SoapHeader securityHeader = new SoapHeader(new QName(securityHeaderElem.getNamespaceURI(), securityHeaderElem.getLocalName()), securityHeaderElem);
inmsg.getHeaders().add(securityHeader);
}
final Endpoint endpoint = inmsg.getExchange().getEndpoint();
if (endpoint != null && endpoint.getEndpointInfo().getProperty(TokenStore.class.getName()) == null) {
inmsg.put(SecurityConstants.TOKEN_STORE_CACHE_INSTANCE, new MemoryTokenStore());
}
inHandler.handleMessage(inmsg);
for (CoverageType type : types) {
switch(type) {
case SIGNED:
this.verifyWss4jSigResults(inmsg);
break;
case ENCRYPTED:
this.verifyWss4jEncResults(inmsg);
break;
default:
fail("Unsupported coverage type.");
}
}
}
use of org.apache.cxf.ws.security.wss4j.CryptoCoverageUtil.CoverageType in project cxf by apache.
the class PolicyBasedSamlTest method runInInterceptorAndValidateWss.
@Override
protected void runInInterceptorAndValidateWss(Document document, AssertionInfoMap aim, List<CoverageType> types) throws Exception {
PolicyBasedWSS4JInInterceptor inHandler = this.getInInterceptor(types);
SoapMessage inmsg = this.getSoapMessageForDom(document, aim);
Element securityHeaderElem = WSSecurityUtil.getSecurityHeader(document, "");
if (securityHeaderElem != null) {
SoapHeader securityHeader = new SoapHeader(new QName(securityHeaderElem.getNamespaceURI(), securityHeaderElem.getLocalName()), securityHeaderElem);
inmsg.getHeaders().add(securityHeader);
}
// Necessary because the Bearer Assertion does not have an internal signature
SamlAssertionValidator assertionValidator = new SamlAssertionValidator();
assertionValidator.setRequireBearerSignature(false);
inmsg.put(SecurityConstants.SAML2_TOKEN_VALIDATOR, assertionValidator);
inmsg.put(SecurityConstants.SAML1_TOKEN_VALIDATOR, assertionValidator);
inHandler.handleMessage(inmsg);
for (CoverageType type : types) {
switch(type) {
case SIGNED:
this.verifyWss4jSigResults(inmsg);
break;
case ENCRYPTED:
this.verifyWss4jEncResults(inmsg);
break;
default:
fail("Unsupported coverage type.");
}
}
}
use of org.apache.cxf.ws.security.wss4j.CryptoCoverageUtil.CoverageType in project cxf by apache.
the class PluggablePolicyValidatorTest method runInInterceptorAndValidateWss.
private void runInInterceptorAndValidateWss(Document document, AssertionInfoMap aim, List<CoverageType> types, Map<QName, SecurityPolicyValidator> validators) throws Exception {
PolicyBasedWSS4JInInterceptor inHandler = this.getInInterceptor(types);
SoapMessage inmsg = this.getSoapMessageForDom(document, aim);
Element securityHeaderElem = WSSecurityUtil.getSecurityHeader(document, "");
if (securityHeaderElem != null) {
SoapHeader securityHeader = new SoapHeader(new QName(securityHeaderElem.getNamespaceURI(), securityHeaderElem.getLocalName()), securityHeaderElem);
inmsg.getHeaders().add(securityHeader);
}
if (validators != null) {
inmsg.put(SecurityConstants.POLICY_VALIDATOR_MAP, validators);
}
inHandler.handleMessage(inmsg);
for (CoverageType type : types) {
switch(type) {
case SIGNED:
this.verifyWss4jSigResults(inmsg);
break;
case ENCRYPTED:
this.verifyWss4jEncResults(inmsg);
break;
default:
fail("Unsupported coverage type.");
}
}
}
use of org.apache.cxf.ws.security.wss4j.CryptoCoverageUtil.CoverageType in project cxf by apache.
the class AbstractPolicySecurityTest method getInInterceptor.
protected PolicyBasedWSS4JInInterceptor getInInterceptor(List<CoverageType> types) {
PolicyBasedWSS4JInInterceptor inHandler = new PolicyBasedWSS4JInInterceptor();
String action = "";
for (CoverageType type : types) {
switch(type) {
case SIGNED:
action += " " + ConfigurationConstants.SIGNATURE;
break;
case ENCRYPTED:
action += " " + ConfigurationConstants.ENCRYPTION;
break;
default:
fail("Unsupported coverage type.");
}
}
inHandler.setProperty(ConfigurationConstants.ACTION, action);
inHandler.setProperty(ConfigurationConstants.SIG_VER_PROP_FILE, "insecurity.properties");
inHandler.setProperty(ConfigurationConstants.DEC_PROP_FILE, "insecurity.properties");
inHandler.setProperty(ConfigurationConstants.PW_CALLBACK_CLASS, TestPwdCallback.class.getName());
inHandler.setProperty(ConfigurationConstants.IS_BSP_COMPLIANT, "false");
return inHandler;
}
Aggregations