Hi, It looks like there are some thing is wrong with request when the SqsComponent try to set the QueueAttributes on the client from the stack trance,
Caused by: Status Code: 400, AWS Service: AmazonSQS, AWS Request ID: cd5d1220-0524-5cf8-aed7-5b061e896d5c, AWS Error Code: MissingParameter, AWS Error Message: The request must contain the parameter Attribute.Name. -- Willem Jiang Red Hat, Inc. FuseSource is now part of Red Hat Web: http://www.fusesource.com | http://www.redhat.com Blog: http://willemjiang.blogspot.com (http://willemjiang.blogspot.com/) (English) http://jnn.javaeye.com (http://jnn.javaeye.com/) (Chinese) Twitter: willemjiang Weibo: willemjiang On Wednesday, November 21, 2012 at 8:14 AM, rbogdanoff wrote: > Hi, > > Am trying to use camel aws-sqs endpoint to send a message. I can do this no > problem with Java AWS API directly, but with camel I am having trouble. > Here is my code... > > package com.equilar.camelexamples; > > import org.apache.camel.CamelContext; > import org.apache.camel.builder.RouteBuilder; > import org.apache.camel.impl.DefaultCamelContext; > import org.apache.camel.impl.SimpleRegistry; > > import com.amazonaws.ClientConfiguration; > import com.amazonaws.auth.AWSCredentials; > import com.amazonaws.auth.BasicAWSCredentials; > import com.amazonaws.services.sqs.AmazonSQSClient; > > > public class SQS { > > public void exec(String command) { > try { > // create CamelContext > SimpleRegistry registry = new SimpleRegistry(); > AWSCredentials awsCredentials = new BasicAWSCredentials("mykey", > "mysecretkey"); > ClientConfiguration clientConfiguration = new > ClientConfiguration(); > AmazonSQSClient client = new AmazonSQSClient(awsCredentials, > clientConfiguration); > registry.put("amazonSQSClient" , client); > CamelContext context = new DefaultCamelContext(registry); > > // add our route to the CamelContext > context.addRoutes(new RouteBuilder() { > public void configure() { > from("file:/tmp/mydir?fileName=myfile.txt") > .to("aws-sqs://MyQueue?amazonSQSClient=#amazonSQSClient"); > } > }); > > context.start(); > > context.stop(); > } catch ( Exception e ) { > throw new RuntimeException(e); > } > > } > > } > > I get this exception... > > java.lang.RuntimeException: org.apache.camel.FailedToCreateRouteException: > Failed to create route route1 at: >>> > To[aws-sqs://MyQueue?amazonSQSClient=#amazonSQSClient] <<< in route: > Route[[From[file:/tmp/mydir?fileName=myfile.txt]] -> [To[aws... because of > Failed to resolve endpoint: > aws-sqs://MyQueue?amazonSQSClient=%23amazonSQSClient due to: The request > must contain the parameter Attribute.Name. > at com.equilar.camelexamples.SQS.exec(SQS.java:58) > at com.equilar.camelexamples.SQSTest.test2(SQSTest.java:21) > 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:45) > at > org.junit.internal.runners.model.ReflectiveCallable.run(ReflectiveCallable.java:15) > at > org.junit.runners.model.FrameworkMethod.invokeExplosively(FrameworkMethod.java:42) > at > org.junit.internal.runners.statements.InvokeMethod.evaluate(InvokeMethod.java:20) > at org.junit.runners.ParentRunner.runLeaf(ParentRunner.java:263) > at > org.junit.runners.BlockJUnit4ClassRunner.runChild(BlockJUnit4ClassRunner.java:68) > at > org.junit.runners.BlockJUnit4ClassRunner.runChild(BlockJUnit4ClassRunner.java:47) > at org.junit.runners.ParentRunner$3.run(ParentRunner.java:231) > at org.junit.runners.ParentRunner$1.schedule(ParentRunner.java:60) > at org.junit.runners.ParentRunner.runChildren(ParentRunner.java:229) > at org.junit.runners.ParentRunner.access$000(ParentRunner.java:50) > at org.junit.runners.ParentRunner$2.evaluate(ParentRunner.java:222) > at org.junit.runners.ParentRunner.run(ParentRunner.java:300) > at > org.eclipse.jdt.internal.junit4.runner.JUnit4TestReference.run(JUnit4TestReference.java:50) > 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.FailedToCreateRouteException: Failed to create > route route1 at: >>> To[aws-sqs://MyQueue?amazonSQSClient=#amazonSQSClient] > <<< in route: Route[[From[file:/tmp/mydir?fileName=myfile.txt]] -> > [To[aws... because of Failed to resolve endpoint: > aws-sqs://MyQueue?amazonSQSClient=%23amazonSQSClient due to: The request > must contain the parameter Attribute.Name. > at > org.apache.camel.model.RouteDefinition.addRoutes(RouteDefinition.java:873) > at > org.apache.camel.model.RouteDefinition.addRoutes(RouteDefinition.java:171) > at > org.apache.camel.impl.DefaultCamelContext.startRoute(DefaultCamelContext.java:722) > at > org.apache.camel.impl.DefaultCamelContext.startRouteDefinitions(DefaultCamelContext.java:1789) > at > org.apache.camel.impl.DefaultCamelContext.doStartCamel(DefaultCamelContext.java:1575) > at > org.apache.camel.impl.DefaultCamelContext.doStart(DefaultCamelContext.java:1444) > at org.apache.camel.support.ServiceSupport.start(ServiceSupport.java:60) > at > org.apache.camel.impl.DefaultCamelContext.start(DefaultCamelContext.java:1412) > at com.equilar.camelexamples.SQS.exec(SQS.java:54) > ... 24 more > Caused by: org.apache.camel.ResolveEndpointFailedException: Failed to > resolve endpoint: aws-sqs://MyQueue?amazonSQSClient=%23amazonSQSClient due > to: The request must contain the parameter Attribute.Name. > at > org.apache.camel.impl.DefaultCamelContext.getEndpoint(DefaultCamelContext.java:479) > at > org.apache.camel.util.CamelContextHelper.getMandatoryEndpoint(CamelContextHelper.java:50) > at > org.apache.camel.model.RouteDefinition.resolveEndpoint(RouteDefinition.java:186) > at > org.apache.camel.impl.DefaultRouteContext.resolveEndpoint(DefaultRouteContext.java:108) > at > org.apache.camel.impl.DefaultRouteContext.resolveEndpoint(DefaultRouteContext.java:114) > 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:441) > at > org.apache.camel.model.ProcessorDefinition.addRoutes(ProcessorDefinition.java:179) > at > org.apache.camel.model.RouteDefinition.addRoutes(RouteDefinition.java:870) > ... 32 more > Caused by: Status Code: 400, AWS Service: AmazonSQS, AWS Request ID: > cd5d1220-0524-5cf8-aed7-5b061e896d5c, AWS Error Code: MissingParameter, AWS > Error Message: The request must contain the parameter Attribute.Name. > at > com.amazonaws.http.AmazonHttpClient.handleErrorResponse(AmazonHttpClient.java:556) > at > com.amazonaws.http.AmazonHttpClient.executeHelper(AmazonHttpClient.java:289) > at com.amazonaws.http.AmazonHttpClient.execute(AmazonHttpClient.java:170) > at > com.amazonaws.services.sqs.AmazonSQSClient.invoke(AmazonSQSClient.java:812) > at > com.amazonaws.services.sqs.AmazonSQSClient.setQueueAttributes(AmazonSQSClient.java:246) > at > org.apache.camel.component.aws.sqs.SqsEndpoint.updateQueueAttributes(SqsEndpoint.java:139) > at > org.apache.camel.component.aws.sqs.SqsEndpoint.doStart(SqsEndpoint.java:93) > at org.apache.camel.support.ServiceSupport.start(ServiceSupport.java:60) > at > org.apache.camel.impl.DefaultCamelContext.startService(DefaultCamelContext.java:1763) > at > org.apache.camel.impl.DefaultCamelContext.doAddService(DefaultCamelContext.java:931) > at > org.apache.camel.impl.DefaultCamelContext.addService(DefaultCamelContext.java:892) > at > org.apache.camel.impl.DefaultCamelContext.getEndpoint(DefaultCamelContext.java:475) > ... 41 more > > What could be the problem? > > Regards > Ron Bogdanoff > > > > -- > View this message in context: > http://camel.465427.n5.nabble.com/aws-sqs-returns-exception-The-request-must-contain-the-parameter-Attribute-Name-tp5723036.html > Sent from the Camel - Users mailing list archive at Nabble.com > (http://Nabble.com).