Notice: This Wiki is now read only and edits are no longer possible. Please see: https://gitlab.eclipse.org/eclipsefdn/helpdesk/-/wikis/Wiki-shutdown-plan for the plan.
Google Wave ECF provider
Student: Sebastian Schmidt
Mentor: Mustafa K. Isik
This project is part of the Google Summer of Code 2010
Contents
Abstract
Google Wave is a real-time collaboration system based upon operational transformation approach to replicated state synchronization. With the Cola System (DocShare), ECF has been using operational transformations, for some time now. I will implement a provider to allow an equinox+ecf based web server to inter-operate with Google Wave.
About Google Wave
With an announcement on 08/04/2010 Google discontinued the development of Google Wave as a standalone product. Anyway, an open source implementation of the Google Wave server is available and the protocol is also open. The Google Wave (aka Federation One) server comes with an implementation of the operational transformation algorithm, which allows you to build real time shared editing applications from the comfort of your eclipse RT / ECF environment using this provider.
Documentation
Prerequisites
- Google Wave / Federation One server, installation instructions
General information
Please find the provider interfaces at org.eclipse.ecf.wave.
Connecting to a Google Wave server
The following example shows how to connect to a Google Wave server using the ECF container modules:
WaveClientContainer container = (WaveClientContainer) ContainerFactory.getDefault().createContainer("ecf.googlewave.client"); Namespace ns = container.getConnectNamespace(); WaveBackendID id id = (WaveBackendID) ns.createInstance(new String[] { "youruser@yourdomain.de" , "yourdomain.de:9876" }); container.connect(id, null);
When the server has wave updates, it sends requests to all connected clients. You can add a listener to the client to get notified about these updates:
container.addWaveletOperationListener(new IWaveletListener() { @Override public void notify(IWavelet wavelet, String author, CoreWaveletOperation operation) { System.out.println(author + "changed " + wavelet.getID().toString()); } @Override public void commit(IWavelet wavelet, ProtocolHashedVersion commitNotice) { } });
Waves
Wavelets
Documents
Project goals
Implementation of a Google Wave ECF provider
that people can use to build their own wave applications on top of
ECF. The provider will handle the basic wave-protocol operations like
managing waves, contacts and documents. Also the provider will provide
an API which allows users to add listeners to wave changes and
implement real time shared editing applications.
Implementation of real time shared editing support
for eclipse. Currently there are
cola and docshare, which
allow document based real time shared editing for two collaborators in
eclipse. With the help of the wave protocol I want to improve this
approach and allow more than two collaborators to work on one document
at the same time. Once you logged into your wave account using the well known ECF
UI, you will be able to share a text-based document for collaborative
editing with your friends on your or any standards compliant third-party wave server.
On the horizon
In their GSoC welcome package Google told us to "think big and have fun". That's why Mustafa and I already have spoken about ideas we have for the time after the end of GSoC 2010. The wave protocol allows to handle more than a single document (= wavelet / blips) in a wave. With an appropriate mapping of Wave components such as Waves to projects and Wavelet/Blips to resources such as sourcecode files, this feature can be adopted to introduce project-based real time shared editing to eclipse. Hopefully we will be able to share a complete project with fellow developers at some point and collaborate with them on multiple files and folders in real time.
Getting the source
The Wave provider is hosted at github.
Open issues
To see all the open issues and feature requests of this project, take a look at this Bugzilla query.
New ideas
Do you have a great idea for the provider? Just open a new feature request or comment on the existing enhancement request.