<div dir="ltr"><span style="color:rgb(119,119,119);font-family:Helvetica,arial,freesans,clean,sans-serif;font-size:13px;line-height:20px;background-color:rgb(251,251,251)">&gt;if we add a dependency on the params into our client library, we pretty much build against a &quot;demo API&quot;. </span><br style="color:rgb(119,119,119);font-family:Helvetica,arial,freesans,clean,sans-serif;font-size:13px;line-height:20px;background-color:rgb(251,251,251)">
<span style="color:rgb(119,119,119);font-family:Helvetica,arial,freesans,clean,sans-serif;font-size:13px;line-height:20px;background-color:rgb(251,251,251)">There should be no dependencies in the client APIs to these params or headers. This is up the the implementation of the target Route and the params names, the response headers could be anything they user wants. This is just an example where we try to provide a good way of doing this. At least this is my view of it.</span><br>
<div><span style="color:rgb(119,119,119);font-family:Helvetica,arial,freesans,clean,sans-serif;font-size:13px;line-height:20px;background-color:rgb(251,251,251)"><br></span></div><div style><span style="color:rgb(119,119,119);font-family:Helvetica,arial,freesans,clean,sans-serif;font-size:13px;line-height:20px;background-color:rgb(251,251,251)">/Dan</span></div>
</div><div class="gmail_extra"><br><br><div class="gmail_quote">On 14 January 2013 10:28, Matthias Wessendorf <span dir="ltr">&lt;<a href="mailto:matzew@apache.org" target="_blank">matzew@apache.org</a>&gt;</span> wrote:<br>
<blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex">Looking at the PR for the demo ([1]) ,I am a bit surprised that<br>
classes like &quot;Links.java&quot; or &quot;Metadata.java&quot; are part of the demo<br>
code.<br>
<br>
I thought that the metadata/header informations on the response, like:<br>
```<br>
AG-Paging-Offset: 1<br>
AG-Paging-Limit: 4<br>
AG-Paging-Total: 4<br>
AG-Links-First: cars?offset=0&amp;limit=4<br>
AG-Links-Previous: cars?offset=0&amp;limit=4<br>
AG-Links-Next: cars?offset=2&amp;limit=4<br>
AG-Links-Last: cars?offset=3&amp;limit=4<br>
```<br>
<br>
are applied by the framework. Of course, the &quot;cars&quot; in there is app<br>
specific, but this information could be read out of the actual route<br>
(/cars).<br>
<br>
Not sure, but... if all the time we (end user) needs to (re)impl.<br>
these things... it could be a bit annoying.<br>
<br>
<br>
IMO the problem would be:<br>
- if we add a dependency on the params into our client libraries, we<br>
pretty much build against a &quot;demo API&quot;. Which is odd...<br>
I thought these &quot;metadata details&quot; are offered by the framework.<br>
<br>
-M<br>
<br>
[1] <a href="https://github.com/aerogear/aerogear-controller-demo/pull/19" target="_blank">https://github.com/aerogear/aerogear-controller-demo/pull/19</a><br>
<br>
On Sun, Jan 13, 2013 at 12:09 PM, Daniel Bevenius<br>
&lt;<a href="mailto:daniel.bevenius@gmail.com">daniel.bevenius@gmail.com</a>&gt; wrote:<br>
&gt; I&#39;ve updated the demo and think I&#39;ve included all the requests.<br>
&gt; * Pre-populate the database upon deployment of demo.<br>
&gt; * Use &#39;offset/limit&#39; instead of &#39;page/perPage&#39;.<br>
&gt; * Use &#39;AG-&#39; prefix for headers.<br>
&gt;<br>
&gt; Let me know if you are missing anything, or would like something done in a<br>
&gt; different way.<br>
&gt;<br>
&gt; Use case<br>
&gt;<br>
&gt; The example is using /cars as the resource to interact with.<br>
&gt;<br>
&gt; The following route has been added to the demo:<br>
&gt;<br>
&gt; route()<br>
&gt;       .from(&quot;/cars&quot;)<br>
&gt;       .on(RequestMethod.GET)<br>
&gt;       .produces(MediaType.JSON)<br>
&gt;       .to(Cars.class).get(param(&quot;offset&quot;, &quot;0&quot;), param(&quot;limit&quot;, &quot;-1&quot;));<br>
&gt;<br>
&gt; From this we can see that there are two optional parameters, offset and<br>
&gt; limit. If these are not specified all cars will be returned.<br>
&gt;<br>
&gt; Getting a page of Cars<br>
&gt;<br>
&gt; curl -i --header &quot;Accept: application/json&quot;<br>
&gt; &quot;<a href="http://controllerdemo-danbev.rhcloud.com/aerogear-controller-demo/cars?offset=0&amp;limit=4" target="_blank">http://controllerdemo-danbev.rhcloud.com/aerogear-controller-demo/cars?offset=0&amp;limit=4</a>&quot;<br>

&gt;<br>
&gt; The request will return:<br>
&gt;<br>
&gt; HTTP/1.1 200 OK<br>
&gt; Content-Type: application/json;charset=UTF-8<br>
&gt; Content-Length: 160<br>
&gt; AG-Paging-Offset: 0<br>
&gt; AG-Paging-Limit: 4<br>
&gt; AG-Paging-Total: 4<br>
&gt; AG-Links-Next: cars?offset=1&amp;limit=4<br>
&gt; AG-Links-Last: cars?offset=3&amp;limit=4<br>
&gt; [<br>
&gt;   {&quot;color&quot;:&quot;Green&quot;,&quot;brand&quot;:&quot;Audi&quot;,&quot;id&quot;:1},<br>
&gt;   {&quot;color&quot;:&quot;White&quot;,&quot;brand&quot;:&quot;Audi&quot;,&quot;id&quot;:2},<br>
&gt;   {&quot;color&quot;:&quot;Black&quot;,&quot;brand&quot;:&quot;Audi&quot;,&quot;id&quot;:3},<br>
&gt;   {&quot;color&quot;:&quot;Black&quot;,&quot;brand&quot;:&quot;BMW&quot;,&quot;id&quot;:4}<br>
&gt; ]<br>
&gt;<br>
&gt; Getting the next page of Cars<br>
&gt;<br>
&gt; To get the next page you can follow the next link:<br>
&gt;<br>
&gt; curl -i --header &quot;Accept: application/json&quot;<br>
&gt; &quot;<a href="http://controllerdemo-danbev.rhcloud.com/aerogear-controller-demo/cars?offset=1&amp;limit=4" target="_blank">http://controllerdemo-danbev.rhcloud.com/aerogear-controller-demo/cars?offset=1&amp;limit=4</a>&quot;<br>

&gt;<br>
&gt; HTTP/1.1 200 OK<br>
&gt; Content-Type: application/json;charset=UTF-8<br>
&gt; Content-Length: 166<br>
&gt; AG-Paging-Offset: 1<br>
&gt; AG-Paging-Limit: 4<br>
&gt; AG-Paging-Total: 4<br>
&gt; AG-Links-First: cars?offset=0&amp;limit=4<br>
&gt; AG-Links-Previous: cars?offset=0&amp;limit=4<br>
&gt; AG-Links-Next: cars?offset=2&amp;limit=4<br>
&gt; AG-Links-Last: cars?offset=3&amp;limit=4<br>
&gt; [<br>
&gt;    {&quot;color&quot;:&quot;Green&quot;,&quot;brand&quot;:&quot;BMW&quot;,&quot;id&quot;:5},<br>
&gt;    {&quot;color&quot;:&quot;Red&quot;,&quot;brand&quot;:&quot;Ferrari&quot;,&quot;id&quot;:6},<br>
&gt;    {&quot;color&quot;:&quot;White&quot;,&quot;brand&quot;:&quot;Ferrari&quot;,&quot;id&quot;:7},<br>
&gt;    {&quot;color&quot;:&quot;Pink&quot;,&quot;brand&quot;:&quot;Ferrari&quot;,&quot;id&quot;:8}<br>
&gt; ]<br>
&gt;<br>
&gt; Get all Cars<br>
&gt;<br>
&gt; curl -i --header &quot;Accept: application/json&quot;<br>
&gt; &quot;<a href="http://controllerdemo-danbev.rhcloud.com/aerogear-controller-demo/cars" target="_blank">http://controllerdemo-danbev.rhcloud.com/aerogear-controller-demo/cars</a>&quot;<br>
&gt;<br>
&gt; This request will return:<br>
&gt;<br>
&gt; [<br>
&gt;    {&quot;color&quot;:&quot;Green&quot;,&quot;brand&quot;:&quot;Audi&quot;,&quot;id&quot;:1},<br>
&gt;    {&quot;color&quot;:&quot;White&quot;,&quot;brand&quot;:&quot;Audi&quot;,&quot;id&quot;:2},<br>
&gt;    {&quot;color&quot;:&quot;Black&quot;,&quot;brand&quot;:&quot;Audi&quot;,&quot;id&quot;:3},<br>
&gt;    {&quot;color&quot;:&quot;Black&quot;,&quot;brand&quot;:&quot;BMW&quot;,&quot;id&quot;:4},<br>
&gt;    {&quot;color&quot;:&quot;Green&quot;,&quot;brand&quot;:&quot;BMW&quot;,&quot;id&quot;:5},<br>
&gt;    {&quot;color&quot;:&quot;Red&quot;,&quot;brand&quot;:&quot;Ferrari&quot;,&quot;id&quot;:6},<br>
&gt;    {&quot;color&quot;:&quot;White&quot;,&quot;brand&quot;:&quot;Ferrari&quot;,&quot;id&quot;:7},<br>
&gt;    {&quot;color&quot;:&quot;Pink&quot;,&quot;brand&quot;:&quot;Ferrari&quot;,&quot;id&quot;:8},<br>
&gt;    {&quot;color&quot;:&quot;White&quot;,&quot;brand&quot;:&quot;Golf&quot;,&quot;id&quot;:15},<br>
&gt;    {&quot;color&quot;:&quot;Brown&quot;,&quot;brand&quot;:&quot;Lada&quot;,&quot;id&quot;:16},<br>
&gt;    {&quot;color&quot;:&quot;Orange&quot;,&quot;brand&quot;:&quot;Mazda&quot;,&quot;id&quot;:14},<br>
&gt;    {&quot;color&quot;:&quot;Pink&quot;,&quot;brand&quot;:&quot;Mini&quot;,&quot;id&quot;:13},<br>
&gt;    {&quot;color&quot;:&quot;Gray&quot;,&quot;brand&quot;:&quot;Nissan&quot;,&quot;id&quot;:11},<br>
&gt;    {&quot;color&quot;:&quot;Yello&quot;,&quot;brand&quot;:&quot;Opel&quot;,&quot;id&quot;:10},<br>
&gt;    {&quot;color&quot;:&quot;Blue&quot;,&quot;brand&quot;:&quot;Scoda&quot;,&quot;id&quot;:9},<br>
&gt;    {&quot;color&quot;:&quot;Red&quot;,&quot;brand&quot;:&quot;Volvo&quot;,&quot;id&quot;:12}<br>
&gt; ]<br>
&gt;<br>
&gt; Get a single Car<br>
&gt;<br>
&gt; curl -i --header &quot;Accept: application/json&quot;<br>
&gt; &quot;<a href="http://controllerdemo-danbev.rhcloud.com/aerogear-controller-demo/cars/1" target="_blank">http://controllerdemo-danbev.rhcloud.com/aerogear-controller-demo/cars/1</a>&quot;<br>
&gt;<br>
&gt; The request will return:<br>
&gt;<br>
&gt; {&quot;color&quot;:&quot;Green&quot;,&quot;brand&quot;:&quot;Audi&quot;,&quot;id&quot;:1}<br>
&gt;<br>
&gt;<br>
&gt;<br>
&gt; On 12 January 2013 11:08, Daniel Bevenius &lt;<a href="mailto:daniel.bevenius@gmail.com">daniel.bevenius@gmail.com</a>&gt; wrote:<br>
&gt;&gt;<br>
&gt;&gt; Great, lets go with &#39;AG-&#39; prefix then.<br>
&gt;&gt;<br>
&gt;&gt;<br>
&gt;&gt;<br>
&gt;&gt;<br>
&gt;&gt; On 11 January 2013 18:24, Douglas Campos &lt;<a href="mailto:qmx@qmx.me">qmx@qmx.me</a>&gt; wrote:<br>
&gt;&gt;&gt;<br>
&gt;&gt;&gt;<br>
&gt;&gt;&gt; On 11/01/2013, at 15:10, Kris Borchers &lt;<a href="mailto:kris@redhat.com">kris@redhat.com</a>&gt; wrote:<br>
&gt;&gt;&gt; &gt; I guess what I meant is I&#39;m not specifically +1 for X- prefix but just<br>
&gt;&gt;&gt; &gt; some sort of prefix in general. It just makes it easier for devs when<br>
&gt;&gt;&gt; &gt; looking through headers to see what is being sent. Even something like AG-<br>
&gt;&gt;&gt; &gt; or AeroGear- would be better IMO than no prefix.<br>
&gt;&gt;&gt;<br>
&gt;&gt;&gt; d&#39;oh, +1 - thought I&#39;ve typed it…<br>
&gt;&gt;&gt;<br>
&gt;&gt;&gt; AG- looks nicer - less bandwidth ;)<br>
&gt;&gt;&gt;<br>
&gt;&gt;&gt; -- qmx<br>
&gt;&gt;&gt; _______________________________________________<br>
&gt;&gt;&gt; aerogear-dev mailing list<br>
&gt;&gt;&gt; <a href="mailto:aerogear-dev@lists.jboss.org">aerogear-dev@lists.jboss.org</a><br>
&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;<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><br>
&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>
<span class="HOEnZb"><font color="#888888"><br>
<br>
<br>
--<br>
Matthias Wessendorf<br>
<br>
blog: <a href="http://matthiaswessendorf.wordpress.com/" target="_blank">http://matthiaswessendorf.wordpress.com/</a><br>
sessions: <a href="http://www.slideshare.net/mwessendorf" target="_blank">http://www.slideshare.net/mwessendorf</a><br>
twitter: <a href="http://twitter.com/mwessendorf" target="_blank">http://twitter.com/mwessendorf</a><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>
</font></span></blockquote></div><br></div>