Hi,

here is an update for UnifiedPush (not yet working), that indicates a strategy:

https://github.com/matzew/aerogear-unified-push-server/commit/dcf1c96d63702e4f34ad97794df6f31125755d6f


Looks like we need/should get rid of the "pushnetwork URL" on the SP Variant class and store a (SP installation) specific (simple)PushEndpoint. I know that the SP spec names it pushEndpoint, but I feel it's better to name it "simplePushEndpoint", to explicitly make sure that this is only for Installations of a SimplePushVariant.


With that change we now store a lot of redundant metadata (for all the SP installations), which is most of the URL. Looking at the endpoint JSON object:
{
  "messageType": "register",
  "channelID": "d9b74644-4f97-46aa-b8fa-9393985cd6cd",
  "status": 200,
  "pushEndpoint": "http://pushserver.example.org/d9b74644"
}

I wonder if, instead of the ENTIRE URL, we only could just store the "hash" (here "d9b74644") and continue to use the pushNetworkURL on the SP Variant (here: "http://pushserver.example.org").

HOWEVER, I think this does not work when the URL of the "request pushendpoint" server (e.g.  "pushserver-foo.something.org") is different from the endpoint that receives the HTTP PUTs, from the AppServer/UnifiedPushServer.

SP connect:
SPClient = AeroGear.SimplePushClient({
    simplePushServerURL: "http://foobar.server.com:7777/simplepush",
    onConnect: spConnect,
    onClose: spClose
});

received endpoint payload:
{
...
"pushEndpoint" : "http://something.different.server.com/blahBlahBlub"
}



-Matthias




On Thu, Aug 8, 2013 at 9:53 AM, Daniel Bevenius <daniel.bevenius@gmail.com> wrote:
Hi all!

Yesterday Kris pointed out that we are not following the SimplePush Spec[1] when it comes to the 'pushEndpoint' that is returned when registering a channel. The spec shows that an absolute URL is returned but we are returning a relative URL. 

For the AeroGear SimplePush Server this is being address by AGPUSH-261[2], and an instance that returns absolute URL is available at http://endpointurldns-dbevenius.rhcloud.com:8000/simplepush.

This change will affect the JavaScript client, the UnifiedPush Server, the Admin UI and possibly QE integration tests. 

I won't go into all the changes for the components listed above as others can provide more accurate information about them if needed. Just wanted to give a heads up to all about this.

/Dan

[1] https://wiki.mozilla.org/WebAPI/SimplePush/Protocol#PushServer_-.3E_UserAgent_2
[2] https://issues.jboss.org/browse/AGPUSH-261

_______________________________________________
aerogear-dev mailing list
aerogear-dev@lists.jboss.org
https://lists.jboss.org/mailman/listinfo/aerogear-dev



--
Matthias Wessendorf

blog: http://matthiaswessendorf.wordpress.com/
sessions: http://www.slideshare.net/mwessendorf
twitter: http://twitter.com/mwessendorf