What is XMPP?
XMPP is an XML instant messaging protocol that was developed by the Jabber foundation, as a reaction to the closed protocols of ICQ, Microsoft Messenger etc etc. It is based on the concepts of
- server side contact lists (Roster in XMPP terminology)
- open XML streams between the XMPP server and any connected client once the connection is established
- every connected XMPP client gets a unique ID (e.g. "firstname.lastname@example.org/phone1/xyz") under the common XMPP "bare" ID (email@example.com) and is uniquely addressable by XMPP packets. This can be used in situations where there is no direct IP number available or it is changing (e.g. mobile devices), making any Internet-connected device addressable as a potential server, with a constant address over time and space - an URI.
- extensible payloads of XML packets as defined by the XMPP Specification, the most important reflecting the 3 paradigms of asynchronous communication, and supported by all major XMPP servers
- broadcast ("<presence>")
- one-to-one or one-to-many ("<message>")
- request/response with acknowledgement ("<iq>"), similar to the HTTP protocol
- handling of status, presence of resources and routing of messages to the right receivers by the XMPP servers
- from the beginning built to scale for the Internet with distributed infrastructure, as explained in this blog post
- large existing XMPP networks to tap into (GoogleTalk, iChat, Facebook Connect, holding part of your existing social graph in the contact lists) and open XMPP servers to set up your own XMPP network
- SSL support built into the base specification, distributed server-to-server communication even between XMPP networks like GoogleTalk and iChat.
XMPP principle setup
Why should I care about XMPP?
- XMPP is the currently most popular infrastructure for instant communication, used by systems like iChat, Google Talk and Google Wave. These are just a few of the possible applications we can do on top of XMPP, Twitter and TiVo are rumored to follow
- via the use of a server side contact list of peers in any XMPP communication, suddenly there is a social or trust-like aspect to any XMPP conversation between two or more participating systems, users or devices
What can we do with this?
Now, with all these characteristics in place, we can look at the different emerging platforms for XMPP communication:
Chat - simple text exchange
This is the simple tracking of presence for XMPP clients and the exchange of only human-readable text messages between them. However, a certain coolness is added by being able to distinguish between different clients logged in under the same XMPP account (e.g. different browser windows logging into GTalk and still sending and receiving in the right window). This has been in use for the past 15 years and is nothing new, even if the clients have gotten lighter and fancier over the years (see figure, firstname.lastname@example.org talking from the browser to email@example.com on iChat).
Normal XMPP chat setup
Google Wave - concurrent document editing on steroids
Google Wave even supports extensions to its functionality, see this blog post which means that a lot of the infrastructure can be used to e.g. support new functionality and data packets.
Google Wave setup
LinkedProcess - turn any connected device into a server with a social context
LinkedProcess (LoP), driven by Marko Rodriguez and Joshua Shinavier is taking the approach of providing a set of XMPP tags for sending scripts and code snippets from XMPP clients ("LoP Villeins") to other XMPP peers acting as servers ("LoP Farms"), get them executed there and the result sent back. The thought is to be able to speed up the processing aspect of the emerging Semantic Web/Web of Data by moving the processes to the data instead of the usual move of the data to the processor.
One huge application is the processing of the emerging Semantic Web or Linked Data (Tim Berners Lee talks about that at TED 2009) by sending processing instructions to the big servers holding large chunks of this emerging graph structure instead of having to pull all data onto your own device prior to processing it (see the LinkedProcess introduction).
LinkedProcess distributed processing of LinkedData setup
This has a number of interesting aspects:
- any XMPP capable client (mobile phones, websites etc) can be turned into a server being in direct contact with its peers
- data can stay at one logical place (e.g. the mobile phone) while others can send scripts to operate to the data in order to get ad-hoc queries executed
- code can be spread within the social context, so scripts can be shared and spread through the social network of resources and people rapidly, without special installation hassle, giving birth to truly viral "web- and mobile only" applications and social networks of both humans, content and hardware
- the access to the computing resources and data is controlled via the contact list of the XMPP client executing the script. Thus, it is always known who is trying to access the LinkedProcess server
- via the use of existing or new social chat networks, this extends the social aspect of your contact list to any XMPP speaking resource under your account, persons, devices and software alike.
So, what is social about LinkedProcess?
Well, with all this said, we have suddenly a couple of very interesting concrete scenarios:
1. Personal and Social Could Computing
This is the concept of spreading code to execute on other servers and devices that are available within the social context of the sender - either a number of servers being set up under the same bare account or friends and colleagues providing their resources to others in their social vicinity. E.g. if I want to transcode a HD movie from TED to fit my mobile phone, I could send a script to my home server instructing the server to download the appropriate encoder, download the original high-resolution link and put the result onto a URL and return that to me. Totally Ad Hoc, without any new programs installed in my phone or the server afterwards.
The Social Cloud
2. Totally distributed and viral social apps - my personal Facebook
A user writes, downloads or is recommended a script - "SOClet" (written in e.g. LUA or Python for Android phones, see Android Sctripting Environment) that asks all its friends phones to evaluate if there is any content related to the asking phones owner. If yes, return the URIs of matching content on the friends phones. That results in an aggregated feed on "Pictures of me by my friends, friends statuses etc" - a Facebook- like setup, totally up to every individual to customize and no central storage. Of course if desired there can be a central server as an equal XMPP client in the middle in order to help holding state, much like the Google Wave setup.
Viral apps spreading in the social device context across mobile devices and e.g. web pages
3. Installing servers on phones and other resources
The technical use setup is as the previous one, but here, long running server code is executed on your friends devices and thus, we create new services on top of the LinkedProcess infrastructure, and turn the devices into mini-servers. This serves potential use cases like Opera Unite, although not with a central namespace like Unite but totally distributed. Peter could for instalnce install a script on Maries phone serving an RSS feed back to Peter when he asks for new content every 5 minutes, including the current location. This can easily be displayed as a GeoRSS over a map on Peters phone or used to mash up the feed with other information using e.g. Yahoo Pipes. This could even be done from a web page (e.g. in Facebook), resulting in a Facebook application that talks to the phone directly and can mash up live phone data with the rest of the Facebook data.
4. Privacy and ownership of everybody's personal information
By turning the physical holder of your own data - the phone or your home desktop - into a server that accepts or denies requests for operations on that data, users regain control over the personal data. Imagining different protection zones (private, business, open), access can then be granted via the social contact list to individuals, groups of contacts (e.g. friends, co-workers in a project) or anyone.
If unknown or public clients like e.g. Google bots want to access that information, even commercial transactions can be attached and making the commercial client sending the script or access request pay for access to e.g. the GPS location, thus reversing the current notion of users spreading their data and its connections into multiple commercial cloud services, paying with their copyright, usage patterns and privacy only to be forced to aggregate the total personal information again via services like FriendFeed, Plaxo etc.
In the longer run, the total personal information, turned into a consistent personal graph of information with data models like Neo4j, a Graph Database would of course be held physically at more convenient locations than a non-backed up mobile phone and linked to the other personal sources of new information like desktop computers and embedded devices like cameras and GPS.
Socially controlled access to the personal information
5. Social home automation and media sharing, the Internet Of Things
With media and home automation devices having Internet access (TV, set top boxes, media servers, stereo), installing XMPP aware software on them or providing a DLNA/XMPP gateway on my home computer under my personal account will expose these as different accessible resources on the Internet, without the intervention of firewalls, wireless routers etc. So, now my friends LinkedProcess enabled phone firstname.lastname@example.org/phone1 can discover my living room TV, email@example.com/tv1 since I am in Maries Roster, and the TV is AVAILABLE in XMPP. It discovers the capabilities of the TV much like DLNA and UPnP and then either sends over the latest photo stream to my TV directly, or negotiates means of doing so, e.g. via FTP to a third server. Voila, the home automation is freed onto the Internet and visible and controlled by me and the friends I trust. The same goes for lamps, fridges, home security systems etc with the appropriate bridging in place on a convenient machine, e.g. your home media server. For an actual implementation of light-control via XMPP, see this bridging lab
Home autmomation devices, directly or via an UPnP/XMPP bridge exposed to LinkedProcess
These are just some use cases that one can think of when it comes to merging the key ingredients:
- status aware, realtime, lightweight messaging infrastructure with contact list support
- widely used infrastructure with existing contact networks (GTalk, iChat etc)
- Open Platforms like LinkedProcess providing the protocol for communication and exchange of machine-readable data packets
With the advent of Google Wave, I think the time has come to realize the great potential in Social Computing - introducing social aspects into core programming, security and distribution paradigms.