<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">
<html>
  <head>
    <meta content="text/html; charset=windows-1252"
      http-equiv="Content-Type">
  </head>
  <body bgcolor="#ffffff" text="#000066">
    WebSocket is a good start.  The security issues should be addressed,
    and there are some things that haven't been handled.  Two of these
    are application level, end-to-end flow control and channelization.
    (I'll suggest that to the HyBi list.)  Other needed features include
    features that presence/IM systems like XMPP include: federated
    authentication, logical routing, and message multiplexing.  There
    should be a defined layering of XMPP or XMPP equivalent protocol
    over WebSocket.  Conversely, it should be possible to use XMPP (and
    maybe even BEEP) as the equivalent of HTTP/WebSocket.  In other
    words, at the browser / Javascript level, <a class="moz-txt-link-freetext" href="https://">https://</a>, wss://, and
    <a class="moz-txt-link-freetext" href="xmpp://">xmpp://</a> (xmpps:// ?) should be a URL detail over which the same
    application protocols can be implemented.<br>
    <br>
    IETF BEEP had a lot of things right, and with some nice
    conciseness.  For IM, there was not strong enough reason to change
    XMPP.<br>
    <br>
    Stephen<br>
    <br>
    On 2/21/11 11:11 AM, Matthew A. Miller wrote:
    <blockquote
      cite="mid:4430F232-E5FE-465F-B4C8-5E3E5D608172@outer-planes.net"
      type="cite">
      <pre wrap="">(Apologies for the delay in publicizing; sickness overtook me)

One of the guerilla conversations at the XSF Summit was about XMPP usage in the browser.  Below is the first documented follow-on.  Most of the rest of the responses were about general acceptance of the concept, hence they're omission.

I'll try to forward the more substantive comments soon (and/or urge the original participants to respond again here).


- m&amp;m

(PS: Originally sent from the "wrong" account; hopefully this doesn't show up twice!)

Begin forwarded message:

</pre>
      <blockquote type="cite">
        <pre wrap="">From: Adam Brault <a class="moz-txt-link-rfc2396E" href="mailto:adam@andyet.net">&lt;adam@andyet.net&gt;</a>
Date: February 8, 2011 21:25:58 MST
To: <a class="moz-txt-link-abbreviated" href="mailto:mwild1@gmail.com">mwild1@gmail.com</a>, <a class="moz-txt-link-abbreviated" href="mailto:nathan@andyet.net">nathan@andyet.net</a>, <a class="moz-txt-link-abbreviated" href="mailto:kevin@kismith.co.uk">kevin@kismith.co.uk</a>, <a class="moz-txt-link-abbreviated" href="mailto:stpeter@stpeter.im">stpeter@stpeter.im</a>, <a class="moz-txt-link-abbreviated" href="mailto:ralphm@ik.nu">ralphm@ik.nu</a>, <a class="moz-txt-link-abbreviated" href="mailto:mamille2@cisco.com">mamille2@cisco.com</a>, <a class="moz-txt-link-abbreviated" href="mailto:florian@florianjensen.com">florian@florianjensen.com</a>, <a class="moz-txt-link-abbreviated" href="mailto:jack@metajack.im">jack@metajack.im</a>, <a class="moz-txt-link-abbreviated" href="mailto:will.sheward@isode.com">will.sheward@isode.com</a>, <a class="moz-txt-link-abbreviated" href="mailto:bear@code-bear.com">bear@code-bear.com</a>, <a class="moz-txt-link-abbreviated" href="mailto:nveri
te@process-one.net">nverite@process-one.net</a>, <a class="moz-txt-link-abbreviated" href="mailto:alexey.melnikov@isode.com">alexey.melnikov@isode.com</a>, <a class="moz-txt-link-abbreviated" href="mailto:simon@buddycloud.com">simon@buddycloud.com</a>, <a class="moz-txt-link-abbreviated" href="mailto:joe.hildebrand@webex.com">joe.hildebrand@webex.com</a>, <a class="moz-txt-link-abbreviated" href="mailto:julien.genestoux@gmail.com">julien.genestoux@gmail.com</a>, <a class="moz-txt-link-abbreviated" href="mailto:laurent@eschenauer.be">laurent@eschenauer.be</a>
Cc: <a class="moz-txt-link-abbreviated" href="mailto:henrik@andyet.net">henrik@andyet.net</a>
Subject: XMPP in the browser -- your thoughts?

Hi, Folks...

So... what do you *really* think about the idea of XMPP in the browser? ;)

After discussions at the XSF Summit this weekend, I feel pretty passionate about this idea and want to do what I can to help push the issue at least to a point of reasonable consideration. (For those of you who weren't a part of the conversations that took place, it sounds as if there is a window of possibility for XMPP in the browser.)

As most of you know, I am not a software engineer and I'm not even close to an XMPP developer. Also note that I myself don't take ownership for these ideas—they belong to people smarter than me. I'm just set on advocating them as much as I can.

Will you take a look at what I've written below and provide your feedback? (My current thought is to post a variation of it based on feedback to the hybi mailing list and to our blog at some point. At Joe's suggestion, I submitted a talk to OSCON with the same general topic.)

The kinds of things to consider as you read: What do I have wrong? Where are the blind spots? Where does it sound naive? What examples should I be pointing to? Is this even a good point—do you yourself think it's a good idea? What other arguments do you perceive there to be for and against it—particularly in terms of benefits, barriers and objections...? Would it be better for someone other than myself to propose the notion? I certainly wouldn't take offense at the suggestion.

I very much appreciate your honest feedback and consideration. Don't be afraid you'll hurt my feelings—just be as blunt as you possibly can. :)

Cheers,

Adam Brault
&amp;yet


========================

Websockets are a terrific idea that suddenly got put on hold this year. But perhaps Websockets' stumble sets us up to take a closer look at something else.

Giving web developers access to a real transport opens all kinds of opportunities in development and leapfrogs a lot of the hacky methods currently used to push data to end users. Unfortunately, it's highly possible Websockets might be an opt-in feature for the forseeable future in some major browsers due to security concerns (among other things).

It makes sense to seriously evaluate the idea of browser-based XMPP. The idea isn't a new one, but it's beginning to gain some traction for good reason.

It is historical fact and present reality that the Internet as a whole is weakened by monopolies and dramatically strengthened by diversity. Competition and decentralization makes everything about the Internet better. But more than just playing to the web's ideals of decentralization, XMPP's federated, flexible, mature and secure nature as a protocol opens up enormous possibilities for developers, browser creators, business, and consumers.

A few things that browser-based XMPP would help make possible:

1. Accelerate the growth of realtime/push web applications by providing XMPP's deep feature set via JavaScript API that makes XML easier to deal with for frontend developers and faster to build off of XMPP's strengths instead of continuously reinventing the wheel.

2. Overcome the last mile of realtime tech which is often ignored—pushing to the end user. Things like PubSubHubBub push between servers and services, but the getting that same data to the end user at this point is not as elegant or straightforward as it could be with XMPP embedded in the browser.

3. Take federated social networking to the end-user, conceivably allowing them to choose network(s) to interact with, rapidly making federation the norm in this arena and decreasing the likelihood of one or two proprietary social networks to dominate the web.

4. Enable browser-based authentication, ID and payment to become a reality. In addition to speeding up development by commonly centralizing the most repetitive problems, the whole Internet basically becomes an App Store with a "Buy Now" button baked into the browser—birthing a new industry of webapps aimed at consumer-level impulse purchasing a la the various mobile app stores.

5. Revolutionary stuff that hasn't even been dreamed of yet.

Ultimately, I think this type of new browser feature set is so beneficial to all parties involved that I think we're looking at a huge increase in the Internet economy once browsers begin to implement such a spec.

These (among other things) provide some very good reasons for strongly considering browser-based XMPP.

Still, I anticipate harsh disagreement and welcome it. At the moment, I actually want to hear why this is a bad idea much more than I want to hear why it's a great one. I believe it's worth giving serious evaluation to the variety of concerns involved.

In inviting criticism, however, I'd like to make the ad hominem aspect of counterarguments moot: I work at a company that has experience with XMPP, node.js, and Websockets, and have had numerous discussions around this topic, but I myself am absolutely not a software engineer. I'm fully aware of my ignorance but generally unafraid of it. :) That said, the notion and its possibilities are not my ideas—I'm just collecting thoughts, ideas and discussion from smarter folks than myself.

I believe the critical opposing arguments that will be voiced fall into one of several categories:

1. "XMPP sucks for JavaScript developers."
As I alluded to above, there needs to be a solid JavaScript API for XMPP in the browser that means developers don't have to do the pain of working with XML in JavaScript. This is an absolute necessity for XMPP in the browser to be at all feasible.

2. "XMPP doesn't scale and doesn't belong in serious high-volume web services."
It is my understanding there's compelling real-life data showing the high level to which XMPP can be scaled. I'm not the right person to provide and discuss this evidence, however.

3. "Websockets would be better."
I think Websockets would be different—better in some ways, for certain—though without XMPP's instant depth of features and flexibility. And I would hope to see an adoption of Websockets. This isn't either/or.

Thanks for reading and I'm looking forward to discussion.

========================
</pre>
      </blockquote>
      <pre wrap="">
</pre>
      <pre wrap="">
<fieldset class="mimeAttachmentHeader"></fieldset>
_______________________________________________
JDev mailing list
Info: <a class="moz-txt-link-freetext" href="http://mail.jabber.org/mailman/listinfo/jdev">http://mail.jabber.org/mailman/listinfo/jdev</a>
Unsubscribe: <a class="moz-txt-link-abbreviated" href="mailto:JDev-unsubscribe@jabber.org">JDev-unsubscribe@jabber.org</a>
_______________________________________________
</pre>
    </blockquote>
    <br>
    <br>
    <div class="moz-signature">-- <br>
      Stephen D. Williams <a class="moz-txt-link-abbreviated" href="mailto:sdw@lig.net">sdw@lig.net</a> <a class="moz-txt-link-abbreviated" href="mailto:stephendwilliams@gmail.com">stephendwilliams@gmail.com</a>
      LinkedIn: <a class="moz-txt-link-freetext" href="http://sdw.st/in">http://sdw.st/in</a>
      V:650-450-UNIX (8649) V:866.SDW.UNIX V:703.371.9362 F:703.995.0407
      <a class="moz-txt-link-freetext" href="AIM:sdw">AIM:sdw</a> <a class="moz-txt-link-freetext" href="Skype:StephenDWilliams">Skype:StephenDWilliams</a> <a class="moz-txt-link-freetext" href="Yahoo:sdwlignet">Yahoo:sdwlignet</a> Resume:
      <a class="moz-txt-link-freetext" href="http://sdw.st/gres">http://sdw.st/gres</a>
      Personal: <a class="moz-txt-link-freetext" href="http://sdw.st">http://sdw.st</a> facebook.com/sdwlig twitter.com/scienteer
    </div>
  </body>
</html>