<html>
  <head>
    <meta content="text/html; charset=ISO-8859-1"
      http-equiv="Content-Type">
  </head>
  <body bgcolor="#FFFFFF" text="#000000">
    <div class="moz-cite-prefix">On 08/28/2013 10:12 AM, Kris Borchers
      wrote:<br>
    </div>
    <blockquote
      cite="mid:FA022201-529E-4A40-B846-DC369DCCDD9C@redhat.com"
      type="cite">
      <meta http-equiv="Content-Type" content="text/html;
        charset=ISO-8859-1">
      As I work more and more toward aligning with the API spec laid out
      by Mozilla for SimplePush, I find myself needing to make a major
      change to the way we have implemented channel registrations.
      Basically what I have found is that our storage and reuse of
      channels between app restart/refresh, though meant to be an
      improvement to performance, is causing more issues than it's
      solving.
      <div><br>
      </div>
      <div>The Proposal</div>
      <div>I would like to only persist the user agent id (UAID) in
        storage and only keep the channel registrations in memory while
        the app is running. Each time the app starts up, the workflow
        would be:</div>
      <div><br>
      </div>
      <div>
        <ul class="MailOutline">
          <li>First Start</li>
          <ol class="">
            <li>Client Hello =&gt; Server</li>
            <li>Server Ack =&gt; Client</li>
            <li>Client 1 or more channel registrations =&gt; Server</li>
            <li>Server stores channel and sends pushEndpoint =&gt;
              Client</li>
            <li>Client registers endpont =&gt; App Server or UP Server</li>
            <li>Push messages abound</li>
          </ol>
          <li>Restart / Refresh</li>
          <ol class="">
            <li>Client Hello =&gt; Server</li>
            <li>Server recognizes UAID and since no channels were
              included in Hello, all existing channels are removed as
              per the spec and sends Ack =&gt; Client</li>
            <li>Client 1 or more channel registrations =&gt; Server</li>
            <li>Server stores channel and sends pushEndpoint =&gt;
              Client</li>
            <li>Client registers endpont =&gt; App Server or UP Server</li>
            <li>Push messages abound</li>
          </ol>
        </ul>
        <div><br>
        </div>
      </div>
      <div>The only possible downside I see here is there will be
        slightly more chatter over the network since the registrations
        will happen every time the app loads. There should be no
        performance decrease and may see a performance boost since we
        will be eliminating a number of synchronous calls into
        localStorage. The main benefit is that this will allow us to
        almost completely synchronize our API with Mozilla's which would
        then allow for immediate use of one of our apps as a web app and
        Firefox OS app with NO modifications.</div>
      <div><br>
      </div>
      <div>Any thoughts?</div>
    </blockquote>
    Sounds good.&nbsp; While not 100% related rerunning registration on app
    load is something Google suggests for GCM.<br>
    <blockquote
      cite="mid:FA022201-529E-4A40-B846-DC369DCCDD9C@redhat.com"
      type="cite">
      <br>
      <fieldset class="mimeAttachmentHeader"></fieldset>
      <br>
      <pre wrap="">_______________________________________________
aerogear-dev mailing list
<a class="moz-txt-link-abbreviated" href="mailto:aerogear-dev@lists.jboss.org">aerogear-dev@lists.jboss.org</a>
<a class="moz-txt-link-freetext" href="https://lists.jboss.org/mailman/listinfo/aerogear-dev">https://lists.jboss.org/mailman/listinfo/aerogear-dev</a></pre>
    </blockquote>
    <br>
  </body>
</html>