A group of four Computer Science grad students will work with Dave Winer, who is a visiting scholar at NYU, on a project to create an open source back-end message system for realtime applications. The work will occur entirely within the Fall 2010 semester. 

A prototype of the system is already running. The resulting software will be compatible with this server, so that apps being developed as front-ends will be able to switch transparently to the new software. The goal is to build a realtime framework that can support an open-ended set of interesting applications. 
The students will not only learn how to code an efficient open source project, but will also learn how to develop and document possible standards, and how to refine protocols for simplicity and wide adoption, as well as work with a global community to promote adoption of the software and the protocols it supports. If the project is successful students will learn how to be leaders in open development. You will also get the satisfaction of knowing that your work made a difference!

The technology 
There are two main entry-points: 
1. getUpdates (username, password) returns array of struct 
2. pushUpdate (username, password, htmltext, type, data) 
The other side of the updating mechanism. Each user that's listening receives a copy of the update struct, which is returned when they next make a request to be updated. 
The identity system is implemented through callbacks, so this system can be hooked into any existing system or new system. We are not trying to implement yet another identity system. There are already many, and lots of discussion of standards here, we don't want to get embroiled in this. 
The API is accessible through a simple REST interface or XML-RPC. 
The server software will be implemented in a high-level language, the data will be stored in memory or in a database. These design decisions will be discussed in the first weekly meetings, and a decision will be made by the Benevolent Dictator of the project (me). We will only produce one implementation in the fall semester. The focus will be on broadest-possible distribution, and best scaling. We want to create a server that can support thousands of simultaneous users receiving updates. 
We will use the tools! 
The group will meet weekly, but will communicate in realtime through the week, using the communication tools we are developing, from the beginning. We will only use open source tools for the project. The goal is to create something usable and fun without selling our souls. 
We will finish the project with a half-day developer conference on the NYU campus where members of the team meet with members of the community to party and talk about the future and boast of our accomplshments.
