/** * 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.camel.component.xmlsecurity; import java.io.ByteArrayInputStream; import java.security.KeyPair; import java.util.Map; import javax.xml.crypto.KeySelector; import org.w3c.dom.Document; import org.apache.camel.CamelContext; import org.apache.camel.Message; import org.apache.camel.builder.RouteBuilder; import org.apache.camel.component.mock.MockEndpoint; import org.apache.camel.component.xmlsecurity.api.KeyAccessor; import org.apache.camel.component.xmlsecurity.api.XmlSignatureHelper; import org.apache.camel.impl.JndiRegistry; import org.apache.camel.spring.SpringCamelContext; import org.junit.Test; public class SpringXmlSignatureTest extends XmlSignatureTest { private static KeyPair rsaPair; protected CamelContext createCamelContext() throws Exception { rsaPair = getKeyPair("RSA", 1024); return SpringCamelContext.springCamelContext("/org/apache/camel/component/xmlsecurity/SpringXmlSignatureTests.xml"); } public static KeyAccessor getDsaKeyAccessor() { return getKeyAccessor(getKeyPair("DSA", 1024).getPrivate()); } public static KeyAccessor getRsaKeyAccessor() { return getKeyAccessor(rsaPair.getPrivate()); } public static KeySelector getDsaKeySelector() { return KeySelector.singletonKeySelector(getKeyPair("DSA", 1024).getPublic()); } public static KeySelector getRsaKeySelector() { return KeySelector.singletonKeySelector(rsaPair.getPublic()); } @Override protected JndiRegistry createRegistry() throws Exception { return super.createRegistry(); } @Override protected RouteBuilder[] createRouteBuilders() throws Exception { return new RouteBuilder[] {}; } @Override XmlSignerEndpoint getDetachedSignerEndpoint() { XmlSignerEndpoint endpoint = (XmlSignerEndpoint) context() .getEndpoint( "xmlsecurity:sign:detached?keyAccessor=#accessorRsa&xpathsToIdAttributes=#xpathsToIdAttributes&"// + "schemaResourceUri=org/apache/camel/component/xmlsecurity/Test.xsd&signatureId=&clearHeaders=false"); return endpoint; } @Override XmlSignerEndpoint getSignatureEncpointForSignException() { XmlSignerEndpoint endpoint = (XmlSignerEndpoint)context().getEndpoint(// "xmlsecurity:sign:signexceptioninvalidkey?keyAccessor=#accessorRsa"); return endpoint; } @Override String getVerifierEndpointURIEnveloped() { return "xmlsecurity:verify:enveloped?keySelector=#selectorRsa"; } @Override String getSignerEndpointURIEnveloped() { return "xmlsecurity:sign:enveloped?keyAccessor=#accessorRsa&parentLocalName=root&parentNamespace=http://test/test"; } @Override String getVerifierEndpointURIEnveloping() { return "xmlsecurity:verify:enveloping?keySelector=#selectorRsa"; } @Override String getSignerEndpointURIEnveloping() { return "xmlsecurity:sign:enveloping?keyAccessor=#accessorRsa"; } @Test public void xades() throws Exception { MockEndpoint mock = getMockEndpoint("mock:result"); mock.expectedMessageCount(1); sendBody("direct:xades", payload); assertMockEndpointsSatisfied(); Message message = getMessage(mock); byte[] body = message.getBody(byte[].class); Document doc = XmlSignatureHelper.newDocumentBuilder(true).parse(new ByteArrayInputStream(body)); Map<String, String> prefix2Ns = XAdESSignaturePropertiesTest.getPrefix2NamespaceMap(); prefix2Ns.put("t", "http://test.com/"); XAdESSignaturePropertiesTest .checkXpath( doc, "/ds:Signature/ds:Object/etsi:QualifyingProperties/etsi:SignedProperties/etsi:SignedSignatureProperties/etsi:SignerRole/etsi:ClaimedRoles/etsi:ClaimedRole/t:test", prefix2Ns, "test"); } }