<html><head><meta http-equiv="Content-Type" content="text/html charset=windows-1252"></head><body style="word-wrap: break-word; -webkit-nbsp-mode: space; -webkit-line-break: after-white-space; "><br><div><div>On Mar 28, 2013, at 8:03 AM, Christos Vasilakis &lt;<a href="mailto:cvasilak@gmail.com">cvasilak@gmail.com</a>&gt; wrote:</div><br class="Apple-interchange-newline"><blockquote type="cite"><meta http-equiv="Content-Type" content="text/html charset=windows-1252"><div style="word-wrap: break-word; -webkit-nbsp-mode: space; -webkit-line-break: after-white-space; ">Hi team,<div><br></div><div>on the last couple of days I have been playing with the idea on how &nbsp;to support nested path in resources (a.k.a subresources).&nbsp;I am more keen in the idea to treat the nested resources as full-time citizens. That is, treat the nested resource as a Pipe.</div></div></blockquote><div><br></div><div><br></div><div>interesting concept&nbsp;</div><br><blockquote type="cite"><div style="word-wrap: break-word; -webkit-nbsp-mode: space; -webkit-line-break: after-white-space; "><div><br></div><div>I came up with the following proposal (showing here in iOS)</div><div><br></div><div>For demonstration I use an imaginative Soccer API</div><div><br></div><div>e.g.</div><div><a href="http://soccer.org/leagues/">soccer.org/leagues/</a>{id}/teams/{id}/players</div><div><br></div><div>when expanded with sample {ids}:</div><div><a href="http://soccer.org/leagues/seattle/teams/trebuchet/players">soccer.org/leagues/seattle/teams/trebuchet/players</a></div><div><br></div><div>During registration of the "parent pipe" (leagues) we specify the nested resources for this Pipe using &nbsp;the "setNestedPipes"&nbsp; config option. Internally the Pipeline during the setup of this pipe creates the corresponding nested pipes, initialising their URL accordingly.</div><div><br></div><div>e.g.</div><div>-----</div><div>AGPipeline* pipeline = [AGPipeline pipelineWithBaseURL:BASE_SOCCER_APP_URL];</div><div><div><br></div><div>id&lt;AGPipe&gt; leagues = [pipeline pipe:^(id&lt;AGPipeConfig&gt; config) {</div><div>&nbsp; &nbsp; [config setName:@"leagues"];</div><div><br></div><div>&nbsp; &nbsp; [config setNestedPipes:[@"teams", @"players"]; &nbsp;// an array of nested resources for this pipe</div></div></div></blockquote><div><br></div><div>so since these are essentially pipes, &nbsp;how far can they be configured. &nbsp;for example, &nbsp;could they have callbacks. &nbsp; and yes, i know that makes no sense&nbsp;</div><div><br></div><br><blockquote type="cite"><div style="word-wrap: break-word; -webkit-nbsp-mode: space; -webkit-line-break: after-white-space; "><div><div>}];</div></div><div>-----</div><div><br></div><div>A new "pipe" method is added in the pipeline with params the Parent ID's of this nested resource. Once returned you have a fill Pipe to invoke operations on.</div><div><br></div><div>-----</div><div><a href="http://soccer.org/leagues/seattle/teams/trebuchet">soccer.org/leagues/seattle/teams/trebuchet</a> - &gt;&nbsp;</div><div><span class="Apple-tab-span" style="white-space: pre; ">        </span>[[pipeline&nbsp;pipe:@"teams" pathParams:@[@"seattle"]]&nbsp;<b>read:@</b>"trebuchet"] ...</div><div><br></div><div><a href="http://soccer.org/leagues/seattle/teams/trebuchet/players/foo">soccer.org/leagues/seattle/teams/trebuchet/players/foo</a> - &gt;</div><div><span class="Apple-tab-span" style="white-space:pre">        </span>&nbsp;[[pipeline&nbsp;pipe:@"players"&nbsp;pathParams:@[@"seattle", @"trebuchet"]]&nbsp;<b>read</b>:@"foo"] ..</div><div>-----</div><div><br></div><div><br></div><div>Wdyt?</div><div><br></div><div>Thanks</div><div>Christos</div><div><br></div><div>On Mar 18, 2013, at 1:12 PM, Sebastien Blanc &lt;<a href="mailto:scm.blanc@gmail.com">scm.blanc@gmail.com</a>&gt; wrote:</div><div><div><br class="Apple-interchange-newline"><blockquote type="cite">Well, that would not be possible, for that you will have to create a "child" pipe. But I agree, that is maybe no optimal ...<div><br><br><div class="gmail_quote">On Fri, Mar 15, 2013 at 6:44 PM, Summers Pittman <span dir="ltr">&lt;<a href="mailto:supittma@redhat.com" target="_blank">supittma@redhat.com</a>&gt;</span> wrote:<br>
<blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex">
  
    
  
  <div bgcolor="#FFFFFF" text="#000000"><div class="im">
    <div>On 03/15/2013 01:34 PM, Sebastien Blanc
      wrote:<br>
    </div>
    <blockquote type="cite">I like the idea but I will more see that has a
      method/function for the pipelineManager (and will be easier to
      implement in JS, I think) :
      <div><br>
      </div>
      <div>var myParentPipe =
        Aerogear.Pipeline({name:"parentPipe"}).pipes.parentPipe</div>
      <div><br>
      </div>
      <div>var myChildPipe = Aerogear.Pipeline.fromParent(myParentPipe,
        {options} )</div>
    </blockquote></div>
    What would it look like to get a child record from a parent?<div><div class="h5"><br>
    <blockquote type="cite">
      <div>&nbsp;<br>
        <br>
        <div class="gmail_quote">On Fri, Mar 15, 2013 at 5:37 PM,
          Douglas Campos <span dir="ltr">&lt;<a href="mailto:qmx@qmx.me" target="_blank">qmx@qmx.me</a>&gt;</span>
          wrote:<br>
          <blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex">What about
            this?<br>
            <br>
            Pipeline&lt;Post&gt; postPipeline = …<br>
            Post post = // get from the pipeline<br>
            Pipeline&lt;Comment&gt;
            postPipeline.childPipelineForOrOtherWeirdName(Comment.class,
            post)<br>
            <div>
              <div><br>
                <br>
                On 15/03/2013, at 12:26, Summers Pittman &lt;<a href="mailto:supittma@redhat.com" target="_blank">supittma@redhat.com</a>&gt;
                wrote:<br>
                <br>
                &gt; On 03/14/2013 04:48 AM, Matthias Wessendorf wrote:<br>
                &gt;&gt;<br>
                &gt;&gt;<br>
                &gt;&gt; On Thu, Mar 14, 2013 at 9:32 AM, Sebastien
                Blanc &lt;<a href="mailto:scm.blanc@gmail.com" target="_blank">scm.blanc@gmail.com</a>&gt;
                wrote:<br>
                &gt;&gt; Hi,<br>
                &gt;&gt; While I was playing with scaffolding and tried
                to build a simple Blog Application with Aerogear I faced
                the current situation :<br>
                &gt;&gt; I have a Post object which contains many
                Comment objects. Now I want to call my Post pipe to
                retrieve the related &nbsp;comments, I have currently 2
                options :<br>
                &gt;&gt;<br>
                &gt;&gt; /posts/1 -&gt; assuming comments will be
                implicitly retrieved (eager loading)<br>
                &gt;&gt; /comments/?postid=1<br>
                &gt;&gt;<br>
                &gt;&gt; But regarding our model the correct form should
                be :<br>
                &gt;&gt;<br>
                &gt;&gt; /posts/1/comments<br>
                &gt;&gt;<br>
                &gt;&gt;<br>
                &gt;&gt; +1<br>
                &gt;&gt; that is the ideal way to model URIs for
                "nested" resources.<br>
                &gt;&gt;<br>
                &gt;&gt; See [1], extracted from [2]<br>
                &gt;&gt;<br>
                &gt;&gt;<br>
                &gt;&gt;<br>
                &gt;&gt; But, AFAIK, &nbsp;with the current API, it is not
                possible to define this last pattern &nbsp;(at least for JS
                and iOs, confirmed by Matzew). When doing a read we can
                pass an id option but as mentioned in the doc, this id
                will always be append to the endpoint.<br>
                &gt;&gt;<br>
                &gt;&gt;<br>
                &gt;&gt; Well, it is possible - but in a very (IMO) ugly
                way:<br>
                &gt;&gt;<br>
                &gt;&gt; <a href="https://gist.github.com/matzew/6ab432e437b9a017a21d" target="_blank">https://gist.github.com/matzew/6ab432e437b9a017a21d</a><br>
                &gt;&gt;<br>
                &gt;&gt;<br>
                &gt;&gt;<br>
                &gt;&gt;<br>
                &gt;&gt; IMO, we should be able to support this pattern
                but for now I'm not really sure how to specify this in
                our API, so if you have any ideas feedback this thread
                has been made for you !<br>
                &gt;&gt;<br>
                &gt;&gt;<br>
                &gt;&gt;<br>
                &gt;&gt; Suggestion: Enhance the read function -
                example:<br>
                &gt;&gt;<br>
                &gt;&gt; <a href="https://gist.github.com/matzew/04f069dfbed2cc77a8b4" target="_blank">https://gist.github.com/matzew/04f069dfbed2cc77a8b4</a><br>
                &gt; I'm thinking of the inverse myself. &nbsp;Add a
                "ParentPath" property which can be used to extract
                information from parent objects.<br>
                &gt;<br>
                &gt; <a href="https://gist.github.com/secondsun/17ce96082eda37dbd10e" target="_blank">https://gist.github.com/secondsun/17ce96082eda37dbd10e</a><br>
                &gt;<br>
                &gt;&gt;<br>
                &gt;&gt;<br>
                &gt;&gt; -Matthias<br>
                &gt;&gt;<br>
                &gt;&gt;<br>
                &gt;&gt; [1] <a href="http://www.infoq.com/resource/articles/rest-introduction/en/resources/figure2.jpg" target="_blank">http://www.infoq.com/resource/articles/rest-introduction/en/resources/figure2.jpg</a><br>

                &gt;&gt; [2] <a href="http://www.infoq.com/articles/rest-introduction" target="_blank">http://www.infoq.com/articles/rest-introduction</a><br>
                &gt;&gt;<br>
                &gt;&gt;<br>
                &gt;&gt;<br>
                &gt;&gt;<br>
                &gt;&gt; Seb<br>
                &gt;&gt;<br>
                &gt;&gt;<br>
                &gt;&gt; _______________________________________________<br>
                &gt;&gt; aerogear-dev mailing list<br>
                &gt;&gt; <a href="mailto:aerogear-dev@lists.jboss.org" target="_blank">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;&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; _______________________________________________<br>
                &gt;&gt; aerogear-dev mailing list<br>
                &gt;&gt;<br>
                &gt;&gt; <a href="mailto:aerogear-dev@lists.jboss.org" target="_blank">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; aerogear-dev mailing list<br>
                &gt; <a href="mailto:aerogear-dev@lists.jboss.org" target="_blank">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>
                <br>
              </div>
            </div>
            -- qmx<br>
            <div>
              <div><br>
                <br>
                _______________________________________________<br>
                aerogear-dev mailing list<br>
                <a href="mailto:aerogear-dev@lists.jboss.org" target="_blank">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>
      <br>
      <fieldset></fieldset>
      <br>
      <pre>_______________________________________________
aerogear-dev mailing list
<a href="mailto:aerogear-dev@lists.jboss.org" target="_blank">aerogear-dev@lists.jboss.org</a>
<a href="https://lists.jboss.org/mailman/listinfo/aerogear-dev" target="_blank">https://lists.jboss.org/mailman/listinfo/aerogear-dev</a></pre>
    </blockquote>
    <br>
  </div></div></div>

<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></blockquote></div><br></div>
_______________________________________________<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">https://lists.jboss.org/mailman/listinfo/aerogear-dev</a></blockquote></div><br></div></div>_______________________________________________<br>aerogear-dev mailing list<br><a href="mailto:aerogear-dev@lists.jboss.org">aerogear-dev@lists.jboss.org</a><br>https://lists.jboss.org/mailman/listinfo/aerogear-dev</blockquote></div><br></body></html>