Hello,

I am playing around with the Camel AWS component. The problems exist for SQS
and S3, same problem! Everything works fine if I use the AmazonSQSClient as
it is used in the source code of the aws component tests:

   @Test
    public void testFileToAmazonSQSToFileRoute() throws Exception {
        System.out.println("testing is starting...");
        
        template.sendBodyAndHeader("file://files/inbox", "Content for Amazon
SQS Cloud Service", Exchange.FILE_NAME, "SQS-file.txt");

        Thread.sleep(1000);

        InputStream is =
FileToAmazonSQSToFileTest.class.getResourceAsStream("AwsCredentials.properties");
        AmazonSQS sqs = new AmazonSQSClient(new PropertiesCredentials(is));

        ListQueuesResult listQueues = sqs.listQueues();
    
        for (String s : listQueues.getQueueUrls()) {
          System.out.println(s);
        }
        
        // TODO assertions !!!
        
        System.out.println("testing finished...");
        
    }
    
    @Override
    protected JndiRegistry createRegistry() throws Exception {
        JndiRegistry registry = super.createRegistry();
        
        AWSCredentials awsCredentials = new
BasicAWSCredentials("AKIAJJ7GO5PHMTBKSN4A",
"VM7NQ2MImmMBBaH+atIAJEpAwjSTF5sQYP/jUMU4");
        ClientConfiguration clientConfiguration = new ClientConfiguration();
        AmazonSQSClient client = new AmazonSQSClient(awsCredentials,
clientConfiguration);
        
        registry.bind("amazonSQSClient", client);
        
        return registry;
    }

    @Override
    protected RouteBuilder createRouteBuilder() throws Exception {
        return new SQSRoute();
    }

There are no assertions yet, but there is no excpetion, and the println
shows all existing queues which it got from AWS.

But I do not need a (complex) Amazon configuration, I just want to use the
two parameters "accessKey" and "secretKey" (which should also be possible as
described at http://camel.apache.org/aws-sqs.html). 
Here you can see my route, trying both alternatives:

public class SQSRoute extends RouteBuilder {

        @Override
        public void configure() throws Exception {
                // FROM INBOX TO AWS-SQS TO OUTBOX
        from("file:inbox")
                .tracing().routeId("inbox-to-sqs")
        
        // Not working:
       
//.to("aws-sqs://camel-integration-queue-mwea-kw?accessKey=AKIAJJ7GO5PHMTBKSN4A&secretKey=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")
        
        // Working:
       
.to("aws-sqs://camel-integration-queue-mwea-kw?amazonSQSClient=#amazonSQSClient");
   ;
        
        
        // FROM AWS-SQS TO OUTBOX
       
from("aws-sqs://camel-integration-queue-mwea-kw?amazonSQSClient=#amazonSQSClient")
                .tracing().routeId("sqs-to-outbox")
        .to("file:outbox");
                
        }

}


AwsCredentials.properties file:

accessKey=AKIAJJ7GO5PHMTBKSN4A
secretKey=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


Using the AmazonClient is working. If I use the two parameters (which
contain exactly the same values as the AwsCredentials.properties, the
following exception occurs:

"The request signature we calculated does not match the signature you
provided. Check your AWS Secret Access Key and signing method. Consult the
service documentation for details."

Full strack trace:

org.apache.camel.FailedToCreateRouteException: Failed to create route
inbox-to-sqs at: >>>
To[aws-sqs://camel-integration-queue-mwea-kw?accessKey=AKIAJJ7GO5PHMTBKSN4A&secretKey=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]
<<< in route: Route[[From[file:inbox]] ->
[To[aws-sqs://camel-integration-... because of Failed to resolve endpoint:
aws-sqs://camel-integration-queue-mwea-kw?accessKey=AKIAJJ7GO5PHMTBKSN4A&secretKey=VM7NQ2MImmMBBaH+atIAJEpAwjSTF5sQYP%2FjUMU4
due to: The request signature we calculated does not match the signature you
provided. Check your AWS Secret Access Key and signing method. Consult the
service documentation for details.
        at
org.apache.camel.model.RouteDefinition.addRoutes(RouteDefinition.java:794)
        at
org.apache.camel.model.RouteDefinition.addRoutes(RouteDefinition.java:165)
        at
org.apache.camel.impl.DefaultCamelContext.startRoute(DefaultCamelContext.java:705)
        at
org.apache.camel.impl.DefaultCamelContext.startRouteDefinitions(DefaultCamelContext.java:1659)
        at
org.apache.camel.impl.DefaultCamelContext.doStartCamel(DefaultCamelContext.java:1448)
        at
org.apache.camel.impl.DefaultCamelContext.doStart(DefaultCamelContext.java:1346)
        at org.apache.camel.impl.ServiceSupport.start(ServiceSupport.java:67)
        at org.apache.camel.impl.ServiceSupport.start(ServiceSupport.java:54)
        at
org.apache.camel.impl.DefaultCamelContext.start(DefaultCamelContext.java:1324)
        at
org.apache.camel.test.junit4.CamelTestSupport.startCamelContext(CamelTestSupport.java:344)
        at
org.apache.camel.test.junit4.CamelTestSupport.doSetUp(CamelTestSupport.java:228)
        at
org.apache.camel.test.junit4.CamelTestSupport.setUp(CamelTestSupport.java:167)
        at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
        at
sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:39)
        at
sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:25)
        at java.lang.reflect.Method.invoke(Method.java:597)
        at
org.junit.runners.model.FrameworkMethod$1.runReflectiveCall(FrameworkMethod.java:44)
        at
org.junit.internal.runners.model.ReflectiveCallable.run(ReflectiveCallable.java:15)
        at
org.junit.runners.model.FrameworkMethod.invokeExplosively(FrameworkMethod.java:41)
        at
org.junit.internal.runners.statements.RunBefores.evaluate(RunBefores.java:27)
        at
org.junit.internal.runners.statements.RunAfters.evaluate(RunAfters.java:31)
        at org.junit.rules.TestWatchman$1.evaluate(TestWatchman.java:48)
        at
org.junit.runners.BlockJUnit4ClassRunner.runChild(BlockJUnit4ClassRunner.java:76)
        at
org.junit.runners.BlockJUnit4ClassRunner.runChild(BlockJUnit4ClassRunner.java:50)
        at org.junit.runners.ParentRunner$3.run(ParentRunner.java:193)
        at org.junit.runners.ParentRunner$1.schedule(ParentRunner.java:52)
        at org.junit.runners.ParentRunner.runChildren(ParentRunner.java:191)
        at org.junit.runners.ParentRunner.access$000(ParentRunner.java:42)
        at org.junit.runners.ParentRunner$2.evaluate(ParentRunner.java:184)
        at
org.junit.internal.runners.statements.RunAfters.evaluate(RunAfters.java:31)
        at org.junit.runners.ParentRunner.run(ParentRunner.java:236)
        at
org.eclipse.jdt.internal.junit4.runner.JUnit4TestReference.run(JUnit4TestReference.java:49)
        at
org.eclipse.jdt.internal.junit.runner.TestExecution.run(TestExecution.java:38)
        at
org.eclipse.jdt.internal.junit.runner.RemoteTestRunner.runTests(RemoteTestRunner.java:467)
        at
org.eclipse.jdt.internal.junit.runner.RemoteTestRunner.runTests(RemoteTestRunner.java:683)
        at
org.eclipse.jdt.internal.junit.runner.RemoteTestRunner.run(RemoteTestRunner.java:390)
        at
org.eclipse.jdt.internal.junit.runner.RemoteTestRunner.main(RemoteTestRunner.java:197)
Caused by: org.apache.camel.ResolveEndpointFailedException: Failed to
resolve endpoint:
aws-sqs://camel-integration-queue-mwea-kw?accessKey=AKIAJJ7GO5PHMTBKSN4A&secretKey=VM7NQ2MImmMBBaH+atIAJEpAwjSTF5sQYP%2FjUMU4
due to: The request signature we calculated does not match the signature you
provided. Check your AWS Secret Access Key and signing method. Consult the
service documentation for details.
        at
org.apache.camel.impl.DefaultCamelContext.getEndpoint(DefaultCamelContext.java:450)
        at
org.apache.camel.util.CamelContextHelper.getMandatoryEndpoint(CamelContextHelper.java:48)
        at
org.apache.camel.model.RouteDefinition.resolveEndpoint(RouteDefinition.java:180)
        at
org.apache.camel.impl.DefaultRouteContext.resolveEndpoint(DefaultRouteContext.java:110)
        at
org.apache.camel.impl.DefaultRouteContext.resolveEndpoint(DefaultRouteContext.java:116)
        at
org.apache.camel.model.SendDefinition.resolveEndpoint(SendDefinition.java:61)
        at
org.apache.camel.model.SendDefinition.createProcessor(SendDefinition.java:55)
        at
org.apache.camel.model.ProcessorDefinition.makeProcessor(ProcessorDefinition.java:437)
        at
org.apache.camel.model.ProcessorDefinition.addRoutes(ProcessorDefinition.java:183)
        at
org.apache.camel.model.RouteDefinition.addRoutes(RouteDefinition.java:791)
        ... 36 more
Caused by: Status Code: 403, AWS Request ID:
a7c01a60-3533-404e-bb91-c1886d2ec3cd, AWS Error Code: SignatureDoesNotMatch,
AWS Error Message: The request signature we calculated does not match the
signature you provided. Check your AWS Secret Access Key and signing method.
Consult the service documentation for details.
        at 
com.amazonaws.http.HttpClient.handleErrorResponse(HttpClient.java:519)
        at com.amazonaws.http.HttpClient.execute(HttpClient.java:215)
        at
com.amazonaws.services.sqs.AmazonSQSClient.invoke(AmazonSQSClient.java:554)
        at
com.amazonaws.services.sqs.AmazonSQSClient.createQueue(AmazonSQSClient.java:287)
        at
org.apache.camel.component.aws.sqs.SqsEndpoint.doStart(SqsEndpoint.java:86)
        at org.apache.camel.impl.ServiceSupport.start(ServiceSupport.java:67)
        at org.apache.camel.impl.ServiceSupport.start(ServiceSupport.java:54)
        at 
org.apache.camel.util.ServiceHelper.startService(ServiceHelper.java:56)
        at
org.apache.camel.impl.DefaultCamelContext.startServices(DefaultCamelContext.java:1629)
        at
org.apache.camel.impl.DefaultCamelContext.addService(DefaultCamelContext.java:911)
        at
org.apache.camel.impl.DefaultCamelContext.getEndpoint(DefaultCamelContext.java:446)
        ... 45 more





I looked at the source code of this component and saw that the tests are
using a mock. Thus, the real connection to AWS is not tested. It is a AWS
exception, but I wonder if there is a bug in the implementation of the camel
component? Or otherwise: What am I doing wrong here?

Best regards,
Kai Wähner

--
View this message in context: 
http://camel.465427.n5.nabble.com/Problem-with-AWS-Component-accessKey-secretKey-Parameters-not-working-tp4745604p4745604.html
Sent from the Camel - Users mailing list archive at Nabble.com.

Reply via email to