Gnome Online Desktop

Sunday, April 13th, 2008

Few years ago, the internet is mostly used for information and emails. Over the fast few years, it has changed a lot. Recently(around last two years), the desktop applications started to consume the power of web. Since then, some platforms yet not much popular emerged, like Mozilla Prims, Adobe AIR.

But as for today, generally, the online applications and desktop are separated. Gnome Online Desktop tries to bridge the gap between those two.

This weekend, I gave it a trail run. Here it goes :

Installation

I installed the system on Ubuntu Gusty, which doesn’t have online desktop is repositories (I think only fedora have them). So, I had to build from the sources. I followed the building guide they have given on using jhbuild.

Then, I installed gnome dependencies for ubuntu. There were problems with the installation. “gtk-doc” was not there. So, I just ignored it and installed other packages. Then, there was a conflict between “libxul-dev” and “xulrunner-1.9-dev“. “apt-cache show libxul-dev” indicated that version is “1.8.x.x”, so I only installed “xulrunner-1.9-dev“.

First, I installed jhbuild from repositories(sudo apt-get install jhbuild). Then, created the .jhbuildrc file as it says, and tried the command. But it started to complain about a “lib_packages” variable. I googled for it, and the first hit was from the same page. Apparently, the wiki page have been updated very recently, and the script has been changed(to non-working version). So, I edited “.jhbuildrc” file, and removed “addpath(’PYTHONPATH’, os.path.join(lib_packages, ‘gtk-2.0′))” line. Now, jhbuld is working fine, but for the obvious reasons, apt-getting from ubuntu, doesn’t install the “online-desktop” module. So, I removed it, and got the jhbuild from gnome SVN.

Now, it started to build 101 packages. Normally, if I was emerging in gentoo, I would go for a tea, have a nap and come back later. But since I ignored “gtk-doc” and “libxul-dev“, I knew those two would fire back later. After going through many packages, it complained about the gtk doc. By analyzing the error message, I managed to install “gtk-doc-tool“, and it continued. Then again, some xul errors popped up. It was complaining that some “idl” files are missing. Going through “/usr/share/idl” revealed that both “unstable” and “stable” are installed, thus those are in sub directories. Once I moved to “/usr/share/idl/xulrunner/unstable” to “/usr/share/idl/xulrunner/“, and done same with the “/usr/includes/xulrunner/unstalbe“, it worked fine and compiled all packages. Then, I followed the rest of the guide, and logged out(I created the session “.desktop” on “/usr/share/xsessions/” instead of “/etc/X11sessions“).

Login In

I crossed my fingers, and logged into the gnome online desktop session. Gnome startup splash was followed by the bug-buddy saying mugshot crashed. I just ignored it, and continued. The sidebar said I’m “nobody” and firefox started with the session. Then, I clicked “enable online desktop”, and it took me to “online.gnome.org” which I successfully logged in. But the desktop still says, I’m “nobody”.

I suspected this might be related to mugshot, so I ran mugshot from terminal again. This time, it ran without any problems. Then, I close firefox, and went through the login process again, but it’s the same results. After going through some files, I found there is a firefox extension, and that was not installed. There was a shell script called “firefox-update.sh”, but running it didn’t help, instead it created some broken symlinks. Then, I created a symlink manually to “od/lib/mozilla/extensions/ {longstring}/firefox@mugshot.org” in “/usr/lib/firefox/plugins“. Then, the extension loaded, but still it’s the same results.

Then, I killed few hours with mugshot-client and bigboard source code, but didn’t come up with anything. The last chance was thinking that something is wrong with gconf settings. So, I logged out, created a new user, and logged back in.

Playing Around

Mugshot crashed as usual at the startup, but then I ran it again it gave a black and white tray icon. It was a long shot, but I was lucky! Online authentication worked. The problem with my used account must be either mozilla settings or dbus settings.

However, mugshot icon turned into purple and suddenly it crashed(Just after I logged in from web interface). So, I saved the bug report, and started to play around a little bit. The sidebar downloaded my information(name,photo,online services) from the gnome online account and displayed those, but I already know those :) Of course those are useful as much as bookmarks. Then, the “recent documents” from places menu is moved to sidebar. That’s a good choice, quick access.


The next stock in sidebar is “Applications“. It showed some applications like “Firefox”, “Terminal”. It also showed “Thunderbird” as not installed, which is actually installed and used exclusively :-/ So, I wanted to change the list of applications showed there. The Application Main panel is quite attractive and nicely build. It’s very easy to find applications. However, only very limited set of applications can be added to the sidebar. I can understand everything else, but this? I’ve no clue.

Then the “people” stock was there, but unfortunately I don’t have any friends on my mugshot account. It only showed some generic user called “Gnome Online”(or something similar). I accidentally added another email address to “Gnome Online”, then I found out there is no way to remove that. The only option was to just remove that user(There is no point of keeping a bot with wrong addresses associated with it). Once I logged into gtalk via pidgin, the people stock got filled with my gtalk contacts list. But it’s just some photos+names, nothing else.

I added the “Google Mail” account, and it worked without giving out any problems. After a complete swap of the sidebar, It felt like nothing is new in online desktop. So, my next guess was there must be something amazing in mugshot client.

Mugshot Adventure

I googled for a little bit about what mugshot client do, but didn’t find any useful information. Then, I checked mugshot bugzilla to see whether anyone else has got these problems. But I was alone. So, I fired up Xchat, joined #gnome-hackers on GimpNet. However, I didn’t get any replies(that’s my bad timing, the channel was very quite when I was dropping there - probably most of the people are sleeping).

The Online Desktop getting started said something about mugshot-client should be bootstraped. I had no idea what that means, so I logged back into my normal *perfect* gnome desktop(By the way, I’m a big gnome fan :) ), and ran “jhbuild bootstrap“. Then, it installed 14 more packages. So, I cleared the built file from mugshot-client checkout directory using “make clean” and executed the mugshot-client build command(”jhbuild build meta-online-desktop -t mugshot-client“).

Here comes the trouble again - it gave me weird error saying “hippo canvas python module not found” - which the files/headers are there. Then, I rebuild several other modules like “hippo-canvas, desktop-data-model, gnome-settings-daemon, online-desktop” and tried building “mugshot-client” but nothing worked. Then, it must be something I did with the bootstrap command - I’m not even a little bit familiar with jhbuild, so I decided the best thing to do is rebuild everything from scratch.

First, I removed the install directory. Then, cleared the build files in the checkout directory. The “bash” saved me from lot of trouble. I didn’t have to worry too much about going into each directory and running “make clear“. If you are interested, following are the two commands,

for x in `ls *.tar.gz *.tar.bz2`; do rm -rf `echo $x | sed 's/.tar.gz$//;s/.tar.bz2$//'`; done
for x in `find | grep Makefile$`; do make -C `echo $x | sed 's/\/[^\/]*$//’` clean; rm $x; done

After clearing everything, I ran the full build command along with the “time” command. After 1 hour, 59 minutes and 49 seconds, it finished(2.4Ghz dual-core 2GB RAM).

Then, I re login to online desktop and now it’s worst; both bigboard(sidebar) and mugshot-client crashed. They must have just committed a non-working version on bigboard around that time :( However, bigboard bug was simple, they were trying to integrate google docs(good news!!) - and gdata.gdocs package was not there. I simply removed “import gdata.docs as gdocs” line from “bigboard/google.py“, and sidebar is back in business.

The bug-buddy was a real rescue buddy on musgshot-client. I changed few lines of code, and it’s started working again. (I didn’t exactly fix it - Just changed some lines that it wouldn’t crash, just work barely). However, the result was not what I expected, it’s just getting the updates from mugshot site, and displays the notifications.

Speaking of mugshot site, it let users integrate many services into one feed, which seems to be a great idea, but since I don’t have any friends on mugshot, I couldn’t really experience it. My idea is it would be a much easier to keep track with friends this way.

Programmers point of view aka “Thoughts of a coder”

From the users point of view, online desktop doesn’t have any killer features *yet*. Anyhow, reading of some of design documentation enlightened me :) The technology used is online desktop is XMPP, which means, it’s using push technology instead of pull; less bandwidth usage, less server load, quick response time.

Just like most of other opensource products, they also have core libs which helps other developers to tap into the system, and make use of that. This means a real integration between all desktop-online bridging applications.

Conclusion

Simple conclusion, it’s not ready yet. Of course, it should be - I built it from the trunk. Anyhow, considering the large number of gnome developers, and super cool gnome desktop, I feel like online desktop is not upto it’s full potential. A lot of simple yet effective improvements can be done, like improving the “Applcation” stock, or “Workspace Switcher”. I’m not sure why they are only adding people from “Gtalk/XMPP/..” connections to people stock(probably something with the design). Most of my friends are using MSN(may be I’ll check whether I can create a plugin for emesene to throw out some dbus signals).

The good news is, once the basic core framework of online desktop is much stable, developers will create some stunning integration apps.

Precisely, this is something you should checkout, but I’m not exactly sure how soon.

Improve jhbuild downloading

Friday, April 11th, 2008

Yesterday, I tried to install Gnome Online Desktop. Since, this is fairly new, it has to be build from the source. Gnome Online Desktop is a complete branch of gnome desktop, which will of course have many dependencies. It’ll take years to download each and compile manually. That’s why they have jhbuild (it works like gentoo emerge).

This is April, which is supposed to be the best month of Sri Lanka with festivals/celebration. But there is a price to pay, thundering (Last year, lighting took my laptop :( ). My connection goes down for each 10 minutes.

So, while jhbuild downloading a module, the connection goes down, and when I restart jhbuild, download doesn’t continue from where I left off. It downloads the whole file again. So, here is a very simple one line hack to prevent that from happening to you.

In jhbuild/versioncontrol/tarball.py, line 171, add a command line option “-c” to wget command. If you are not happy with “wget”, you can change it to whatever you want(prozilla,aget,d4x).

I’m still building online desktop (101 packages :-/ ), can’t wait to see what it can do.