<div dir="ltr">Hey Bruno, <div><br></div><div style>I totally agree. I should have been more clear regarding these controller classes, they would not be part of AeroGear-controller but as separate projects. </div><div style>
<br></div><div style><span style="font-family:arial,sans-serif;font-size:13px">&gt;Would be nice to have Camel support as an additional plugin on AG Controller to our enterprise scenarios, but now would be important to finish our pagination support on Controller, at least for CR1.</span><br>
</div><div style><font face="arial, sans-serif">The paging support is completed and just needs to be reviewed and merged. I&#39;m not sure that this integration is a requirement for CR1, only that we look into it like we have done. The actual work might be for a later release perhaps.</font></div>
<div style><font face="arial, sans-serif"><br></font></div><div style><font face="arial, sans-serif">&gt;</font><span style="font-family:arial,sans-serif;font-size:13px">On security, Camel will only support Spring and Apache Shiro, we need to measure how hard would it be to add PicketLink support.</span></div>
<div style><span style="font-family:arial,sans-serif;font-size:13px">I was thinking that AeroGear Security could be used as sort of a front-end security layer when used with AeroGear Controller. If the target Camel &quot;service&quot; uses Spring Security or Apache Shiro that would have to be configured in the Controller class. So the two would be decoupled from each other.</span></div>
<div style><span style="font-family:arial,sans-serif;font-size:13px">I might be missing something here and need to look into it more carefully...more thinking out loud at the moment :)</span></div><div style><font face="arial, sans-serif"><br>
</font></div><div style><font face="arial, sans-serif">cheers, </font></div><div style><font face="arial, sans-serif"><br></font></div><div style><font face="arial, sans-serif">/Dan</font></div><div style><font face="arial, sans-serif"><br>
</font></div></div><div class="gmail_extra"><br><br><div class="gmail_quote">On 2 January 2013 15:02, Bruno Oliveira <span dir="ltr">&lt;<a href="mailto:bruno@abstractj.org" target="_blank">bruno@abstractj.org</a>&gt;</span> wrote:<br>
<blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex">Hi Dan, Camel support on controller is a good idea, on the other hand we must keep AG controller simple as is to cover of our developers&#39; case with simple needs, I guess. Would be nice to have Camel support as an additional plugin on AG Controller to our enterprise scenarios, but now would be important to finish our pagination support on Controller, at least for CR1.<br>

<br>
Maybe file a JIRA or add it to our AG Controller roadmap? On security, Camel will only support Spring and Apache Shiro, we need to measure how hard would it be to add PicketLink support.<br>
<br>
<br>
--<br>
&quot;The measure of a man is what he does with power&quot; - Plato<br>
-<br>
@abstractj<br>
-<br>
Volenti Nihil Difficile<br>
<div class="im"><br>
<br>
<br>
On Wednesday, January 2, 2013 at 11:41 AM, Daniel Bevenius wrote:<br>
<br>
&gt; Hey Matthias,<br>
&gt;<br>
&gt; there has been a discussion about having something like what you describe for this.<br>
&gt; At the moment there is not much to it, and if I was going to do this sort of integration I think I&#39;d use the Camel/SwitchYard APIs directly, but having this as a reference or as a starting point would certainly help. With the examples in the post hopefully we can decide if we should provide an implementation, or if we should just have this more as a guide.<br>

&gt;<br>
&gt; cheers,<br>
&gt;<br>
&gt; /Dan<br>
&gt;<br>
&gt;<br>
&gt;<br>
</div><div class="im">&gt; On 2 January 2013 14:27, Matthias Wessendorf &lt;<a href="mailto:matzew@apache.org">matzew@apache.org</a> (mailto:<a href="mailto:matzew@apache.org">matzew@apache.org</a>)&gt; wrote:<br>
&gt; &gt; Hi Dan,<br>
&gt; &gt;<br>
&gt; &gt; looks nice and simple. One quick question, is there more as a guide, or is there a plan to have some &quot;plugins&quot; (e.g. an additional JAR containing something like you described for the CamelController.java)?<br>

&gt; &gt;<br>
&gt; &gt; Greetings,<br>
&gt; &gt; Matthias<br>
&gt; &gt;<br>
</div><div class="im">&gt; &gt; On Wed, Jan 2, 2013 at 2:16 PM, Daniel Bevenius &lt;<a href="mailto:daniel.bevenius@gmail.com">daniel.bevenius@gmail.com</a> (mailto:<a href="mailto:daniel.bevenius@gmail.com">daniel.bevenius@gmail.com</a>)&gt; wrote:<br>

&gt; &gt; &gt;<br>
&gt; &gt; &gt; AeroGear Camel/SwitchYard Integration<br>
&gt; &gt; &gt;<br>
&gt; &gt; &gt; There have been inquiries about how existing services could be exposed using AeroGear Controller, and this document will try to sort out why someone would want to do this, and also try to come up with some possible solutions.<br>

&gt; &gt; &gt;<br>
&gt; &gt; &gt; Why would you want to do this?<br>
&gt; &gt; &gt;<br>
</div>&gt; &gt; &gt; Currently one can already expose a service as a RESTful endpoint in Camel using Camel&#39;s CXFRS Component (<a href="http://camel.apache.org/cxfrs.html" target="_blank">http://camel.apache.org/cxfrs.html</a>). The same goes for a service in SwitchYard that can be exposed using the RestEasy Component (<a href="https://docs.jboss.org/author/display/SWITCHYARD/RESTEasy+Bindings" target="_blank">https://docs.jboss.org/author/display/SWITCHYARD/RESTEasy+Bindings</a>).<br>

<div class="im">&gt; &gt; &gt;<br>
&gt; &gt; &gt;<br>
&gt; &gt; &gt; So, a few reasons why users might opt to expose their services through AeroGear controller:<br>
&gt; &gt; &gt;<br>
&gt; &gt; &gt; Consistent way of exposing enterprise services externally for mobil developers<br>
&gt; &gt; &gt; Security<br>
&gt; &gt; &gt; Camel Integration<br>
&gt; &gt; &gt;<br>
</div>&gt; &gt; &gt; Using Camel to integrate with existing services is a great option as Camel has a huge number of components (<a href="http://camel.apache.org/components.html" target="_blank">http://camel.apache.org/components.html</a>). There is a SwitchYard Camel component too, so integrating with SwitchYard would also be possible using Camel. SwitchYard also has a new RemoteInvoker (<a href="https://docs.jboss.org/author/display/SWITCHYARD/Remote+Invoker" target="_blank">https://docs.jboss.org/author/display/SWITCHYARD/Remote+Invoker</a>) which could be used for SwitchYard specific services and would be a separate controller class.<br>

<div class="im">&gt; &gt; &gt;<br>
&gt; &gt; &gt;<br>
&gt; &gt; &gt; The goal here is to make things as flexibile as possible as it is difficult to try to account for different types of services. As a suggestion, an AeroGear Controller route that invokes a service using Camel might look like this:<br>

&gt; &gt; &gt;<br>
&gt; &gt; &gt; public class Routes extends AbstractRoutingModule { @Override public void configuration() throws Exception { route() .from(&quot;/cars/{id}&quot;) .on(RequestMethod.GET) .to(CarServiceController.class).getCar(&quot;direct://input&quot;, param(&quot;id&quot;)); } }<br>

&gt; &gt; &gt;<br>
&gt; &gt; &gt;<br>
&gt; &gt; &gt; CarServiceController.class might look something like this:<br>
&gt; &gt; &gt;<br>
&gt; &gt; &gt; public class CarServiceController extends CamelController { public String getCar(final String endpointUri, final String id) { return (String) producerTemplate().requestBody(endpointUri, Long.valueOf(id)); } }<br>

&gt; &gt; &gt;<br>
&gt; &gt; &gt;<br>
&gt; &gt; &gt; CamelController is very simple and gets injected with a CdiCamelContext and creates the ProducerTemplate.<br>
&gt; &gt; &gt;<br>
&gt; &gt; &gt; public abstract class CamelController { @Inject private CdiCamelContext camelContext; private final ProducerTemplate producer; public CamelController() { producer = this.camelContext.createProducerTemplate(); } protected ProducerTemplate producerTemplate() { return producer; } }<br>

&gt; &gt; &gt;<br>
&gt; &gt; &gt;<br>
</div>&gt; &gt; &gt; We are simply making an instance of ProducerTemplate (<a href="http://camel.apache.org/maven/current/camel-core/apidocs/org/apache/camel/ProducerTemplate.html" target="_blank">http://camel.apache.org/maven/current/camel-core/apidocs/org/apache/camel/ProducerTemplate.html</a>) available to users, and they have access to all the methods of that interface. This will enable users to send one way messages, request/response messages, and also prepare the arguments to the service and process the result if needed.<br>

<div class="im">&gt; &gt; &gt;<br>
&gt; &gt; &gt;<br>
&gt; &gt; &gt; A ProducerTemplate is created from a CamelContext. One can have multiple CamelContext&#39;s per application/deployment but the most common is that each deployment has one CamelContext. In this case we are injecting CdiCamelContext.<br>

&gt; &gt; &gt;<br>
&gt; &gt; &gt;<br>
&gt; &gt; &gt; We could also add additional methods from ProducerTemplate to CamelController which just delegate, for example:<br>
&gt; &gt; &gt;<br>
&gt; &gt; &gt; public abstract class CamelController { @Inject private CdiCamelContext camelContext; private final ProducerTemplate producer; public CamelController() { producer = this.camelContext.createProducerTemplate(); } protected ProducerTemplate producerTemplate() { return producer; } protected Object requestBody(final String endpointUri, final Object body) { return producer.requestBody(endpointUri, body); } //...more methods like requestBody }<br>

&gt; &gt; &gt;<br>
&gt; &gt; &gt;<br>
&gt; &gt; &gt; This would save subclasses from having to call producerTemplate().<br>
&gt; &gt; &gt;<br>
&gt; &gt; &gt; SwitchYard Integration<br>
&gt; &gt; &gt;<br>
&gt; &gt; &gt; As mentioned above, SwitchYard has a RemoveInvoker that could be used for invoking services from a remote client. This could be used in an AeroGear route:<br>
&gt; &gt; &gt;<br>
&gt; &gt; &gt; public class Routes extends AbstractRoutingModule { @Override public void configuration() throws Exception { route() .from(&quot;/server1/{id}&quot;) .on(RequestMethod.GET) .to(SwitchYard.class).invoke( &quot;<a href="http://localhost:8080/switchyard-remote" target="_blank">http://localhost:8080/switchyard-remote</a>&quot;, &quot;CarService&quot;, pathParam(&quot;id&quot;)); } }<br>

&gt; &gt; &gt;<br>
&gt; &gt; &gt;<br>
&gt; &gt; &gt; SwitchYard is again very simple:<br>
&gt; &gt; &gt;<br>
&gt; &gt; &gt; public class SwitchYard { public static final String REMOTE_SERVICE = &quot;urn:com.example.switchyard:remote&quot;; public Object invoke(final String url, final String serviceName, final Object payload) throws IOException { return new HttpInvoker(url).invoke(new RemoteMessage() .setContext(new DefaultContext()) .setService(new QName(REMOTE_SERVICE, serviceName)) .setContent(payload)) .getContent(); } }<br>

&gt; &gt; &gt; The original gist can be found here: <a href="https://gist.github.com/4152998" target="_blank">https://gist.github.com/4152998</a><br>
&gt; &gt; &gt;<br>
&gt; &gt; &gt;<br>
&gt; &gt; &gt; _______________________________________________<br>
&gt; &gt; &gt; aerogear-dev mailing list<br>
</div>&gt; &gt; &gt; <a href="mailto:aerogear-dev@lists.jboss.org">aerogear-dev@lists.jboss.org</a> (mailto:<a href="mailto:aerogear-dev@lists.jboss.org">aerogear-dev@lists.jboss.org</a>)<br>
<div class="im">&gt; &gt; &gt; <a href="https://lists.jboss.org/mailman/listinfo/aerogear-dev" target="_blank">https://lists.jboss.org/mailman/listinfo/aerogear-dev</a><br>
&gt; &gt;<br>
&gt; &gt;<br>
&gt; &gt;<br>
&gt; &gt;<br>
&gt; &gt; --<br>
&gt; &gt; Matthias Wessendorf<br>
&gt; &gt;<br>
&gt; &gt; blog: <a href="http://matthiaswessendorf.wordpress.com/" target="_blank">http://matthiaswessendorf.wordpress.com/</a><br>
&gt; &gt; sessions: <a href="http://www.slideshare.net/mwessendorf" target="_blank">http://www.slideshare.net/mwessendorf</a><br>
&gt; &gt; twitter: <a href="http://twitter.com/mwessendorf" target="_blank">http://twitter.com/mwessendorf</a><br>
&gt; &gt; _______________________________________________<br>
&gt; &gt; aerogear-dev mailing list<br>
</div>&gt; &gt; <a href="mailto:aerogear-dev@lists.jboss.org">aerogear-dev@lists.jboss.org</a> (mailto:<a href="mailto:aerogear-dev@lists.jboss.org">aerogear-dev@lists.jboss.org</a>)<br>
&gt; &gt; <a href="https://lists.jboss.org/mailman/listinfo/aerogear-dev" target="_blank">https://lists.jboss.org/mailman/listinfo/aerogear-dev</a><br>
&gt;<br>
&gt;<br>
&gt; _______________________________________________<br>
&gt; aerogear-dev mailing list<br>
&gt; <a href="mailto:aerogear-dev@lists.jboss.org">aerogear-dev@lists.jboss.org</a> (mailto:<a href="mailto:aerogear-dev@lists.jboss.org">aerogear-dev@lists.jboss.org</a>)<br>
&gt; <a href="https://lists.jboss.org/mailman/listinfo/aerogear-dev" target="_blank">https://lists.jboss.org/mailman/listinfo/aerogear-dev</a><br>
<div class="HOEnZb"><div class="h5"><br>
<br>
<br>
_______________________________________________<br>
aerogear-dev mailing list<br>
<a href="mailto:aerogear-dev@lists.jboss.org">aerogear-dev@lists.jboss.org</a><br>
<a href="https://lists.jboss.org/mailman/listinfo/aerogear-dev" target="_blank">https://lists.jboss.org/mailman/listinfo/aerogear-dev</a><br>
</div></div></blockquote></div><br></div>