Hi,

I want to add a route for the camel-azure component 2.23.0 in pure JavaDSL with 
no Spring. Documentation 
https://github.com/apache/camel/blob/master/components/camel-azure/src/main/docs/azure-blob-component.adoc
only recommends to set the credentials and client options with a bean, but I 
can't  get that to work. How to set the options directly in the URI is not 
described.
Without bean I get an exception like this:

[ERROR] Failed to execute goal org.codehaus.mojo:exec-maven-plugin:1.6.0:java 
(default-cli) on project testjava: An exception occured while executing the 
Java class. Failed to create route route1: 
Route(route1)[[From[azure-blob:/shared1/mxtest/blabla?azureB... because of 
Failed to resolve endpoint: 
azure-blob:///shared1/mxtest/blabla?azureBlobClient=client due to: Could not 
find a suitable setter for property: azureBlobClient as there isn't a setter 
method with same type: java.lang.String nor type conversion possible: No type 
converter available to convert from type: java.lang.String to the required 
type: com.microsoft.azure.storage.blob.CloudBlob with value client

With bean it is the same error "no type converter...with value #clientreg"  - I 
assume the bean lookup does not work -  would be my 2. question how to fix 
that..

The azureBlobClient option must be of type CloudBlockBlob, credentials of type 
StorageCredentials.

How can I set the required credentials or client options in the URI ?


Peter


package testjava;

import org.apache.camel.*;
import org.apache.camel.impl.SimpleRegistry;
import org.apache.camel.language.Bean;
import org.apache.camel.main.Main;
import org.apache.camel.CamelContext;
import org.apache.camel.impl.DefaultCamelContext;
import org.apache.camel.builder.RouteBuilder;
import com.microsoft.azure.storage.*;
import com.microsoft.azure.storage.blob.*;

public class MainApp
{
            public static class ClientBean
            {
                        public CloudBlockBlob client()
                        {
                                   try
                                   {
                                               StorageCredentials creds = new 
StorageCredentialsAccountAndKey("shared1", "here gooes my key jG/zyK....");
                                               StorageUri storageURI = new 
StorageUri(new java.net.URI("https://shared1.blob.core.windows.net/mxtest";));
                                               CloudBlockBlob client = new 
CloudBlockBlob(storageURI, creds);
                                               return client;
                                   }
                                   catch(Exception e)
                                   {
                                               return null;
                                   }
                        }
            }

            public static void main(String... args) throws Exception
            {
                        SimpleRegistry myregistry = new SimpleRegistry();
                        CamelContext mycontext = new 
DefaultCamelContext(myregistry);
                        myregistry.put("clientreg", new ClientBean());

                        // as bean does not work, I try to set the stuff 
directly:
                        StorageCredentials creds = new 
StorageCredentialsAccountAndKey("shared1", "here goes my key");
                        StorageUri storageURI = new StorageUri(new 
java.net.URI("https://shared1.blob.core.windows.net/mxtest";));
                        CloudBlockBlob client = new CloudBlockBlob(storageURI, 
creds);

                        mycontext.addRoutes
                                   (new RouteBuilder()
                                               {
                                                           @Override
                                                           public void 
configure()
                                                           {
                                                                           
//bean does not work:    
from("azure-blob:/shared1/mxtest/blabla?azureBlobClient=#clientreg")
                                                                       
from("azure-blob:/shared1/mxtest/blabla?azureBlobClient=client")
                                                                       
.to("file:c:\\mx\\source");
                                                           }
                                               }
                                   );
                        mycontext.start();
            }
}



Knorr-Bremse Systeme für Schienenfahrzeuge GmbH
Sitz: München
Geschäftsführer: Dr. Jürgen Wilder (Vorsitzender), Mark Cleobury, Dr. Nicolas 
Lange, Dr. Peter Radina, Harald Schneider
Vorsitzender des Aufsichtsrats: Klaus Deller
Registergericht München, HR B 91 181

This transmission is intended solely for the addressee and contains 
confidential information.
If you are not the intended recipient, please immediately inform the sender and 
delete the message and any attachments from your system.
Furthermore, please do not copy the message or disclose the contents to anyone 
unless agreed otherwise. To the extent permitted by law we shall in no way be 
liable for any damages, whatever their nature, arising out of transmission 
failures, viruses, external influence, delays and the like.

Reply via email to