Searching the archives

I’ve changed more of mail.gnome.org to the new layout. Thanks to Frederic Peters, I now know how to make Google search a specific part of the site/URL, without showing inurl:$FOO in the search box. This means mail.gnome.org now uses Google instead of Namazu (which was broken for a while). One less thing that needs maintaining. Currently the machine is regenerating the archives to ensure everything has the new layout. It still needs a few fixes (want to use the sidebar, change the footer and change layout of the messages), but at least you can search recent messages.
Note: This means you cannot search private archives anymore. As searching was broken anyway, I’ll leave it for someone else to fix.

GNOME 2.20.1
I’m going to make the GNOME 2.20.1 release. Hopefully everything will go ok.

Dear Menubar, I do not like you

Frederic Peters finished making crash.gnome.org look like a GNOME site. Andreas Nilsson helped by changing the icon to one made by Sebastian Kraft (which Fer still hasn’t committed in a Bug-Buddy version.. hint hint hint). Further, the site now is only accessible via port 80. The port 5000 stuff is gone/firewalled. Nice to get people helping out!

I asked Frederic if he could change the other GNOME sites (except Bugzilla and the soon obsolete www.gnome.org) to use the new style layout as well. Anyone is free to help out with this. Just look for SVN modules ending with ‘-web’.
For mail.gnome.org, Frederic changed the main page and added the CSS + images. After that I copied his stuff and changed the archive index page as well (created by a script in a sysadmin-only SVN module). Until you click a few times, mail.gnome.org looks much better. Note that mailman layout is difficult to change, I only want to concentrate on the archives.

Screenshot:

Unfortunately, mail.gnome.org wasn’t updated automatically from SVN. There is a script to handle most of it in a sysadmin module. So I enabled this for mail.gnome.org. Immediately I got an error message via the mail… forgot that the mail.gnome.org machine (menubar) is RHEL3. The script assumes at least Python 2.4. A lot of sysadmin scripts cannot be improved just because of that one machine still being RHEL3. As it is our mail machine, any downtime will have a noticeable effect. However, I really am annoyed by the RHEL3 + too many custom RPM packages and general hackiness of the setup.
That is why I plan to upgrade the machine on October 20 to RHEL5. This is probably the most uncertain upgrade out of all machines hosted at Red Hat. Many of the packages used by that machine are custom (Postfix, mailman, mhonarc, amavis.. basically everything that should run on the machine is not standard RHEL3). Since the upgrade of the other machines to RHEL5 I haven’t seen much progress towards avoiding anything other than a ‘upgrade and see what happens’.

Crash GNOME org

Fernando Herrera released Bug-Buddy 2.20.1. In this version he added support for submitting crashreports to the GNOME Socorro server. The web frontend for this is available at: http://crash.gnome.org/. Note: it currently redirects to port 5000. However, I’ll change that soon to only allow access from normal port 80; port 5000 will be firewalled again.

This work is all very recent, it requires a bit of work. Stuff that needs doing (by Fernando, you or me):

  • I quickly made the web frontend look more like a GNOME site. However, needs finishing.
  • Finish up the installation instructions. Probably need to ask Fer to add the stuff he did.
  • Add scripts to download the -debug packages for Fedora, see if they are linked against GTK+, or libglib in case of libs and store the symbols. Later goal is to expand for other distributions. However, ideally (when everything works well enough), it would be best if distributions could host their own server.
  • Ensure everything will work well enough to allow distributions to host their own Socorro servers. This can be done already, but there aren’t even example scripts yet to parse -debug packages (AFAIK, maybe Fer has something).
  • Somehow a crash report needs to be forwarded to GNOME Bugzilla. Hopefully Fer has an idea (mainly about how to determine a new crasher and ensure it was not reported already to Bugzilla)

Screenshot:
socorro.png

Because bug-buddy in 2.20 is activated as a GTK module, it will now see crashes from all GTK+ applications. This even if they do not link against libgnome. Ideally we should get these crashreports to the developers/maintainers of these apps. This is related to ensuring that when a server is run by a distribution we will still be able to see the crashreports. There should be something generic enough to either push the top crashers to a project or some kind of pull system (current web interface seems a bit simple).

Note: Fer added DWARF2 to Socorro/Breakpad. However, that was added by hacking in some GPL’d code. This cannot be merged upstream as they use some other license. The GNOME version of this is available as the socorro module in svn.gnome.org.

Since the availability of debug packages, people have requested Bug-Buddy to install them. However, with the loads of different package formats/frontends this wasn’t easy to solve (although work is being done to solve this). Further, the debug packages are usually very big in size. Really nice to have a better solution. Thanks Fer!

Mango gone live

The new system to request accounts (Mango) has gone live. Updated instructions for people wanting an SVN account are at: http://live.gnome.org/NewAccounts. The maintainers listed in the various MAINTAINERS files have received instructions on how the system works. This email also contains information regarding another (intended for foundation members) GNOME service you’ll have access to. Suggest to read the email asap.

Note: I haven’t added the translator coordinators yet.

Future

Last 2 weeks I had loads of time to hack on Mango. I will have much less time from now on. There are still a few things I want implemented (by me, Baris, someone else):

  • Move Foundation member information into LDAP
    This is a huge amount of work. Need to rewrite the Mango parts, enhance the LDAP schema (probably new schema + conversion), port all scripts currently using the database, need somehow to setup users (e.g., might not have an LDAP account atm), etc.
  • Allow people to either change their Mango password, or request a new one
    Not hard, mostly worried about security.
  • Allow maintainers to change for their modules who the maintainers are
  • Allow people to change their LDAP details (SSH keys, email address)
    Security regarding SSH keys is ehr.. difficult.
  • Allow existing LDAP users to request additional permissions for their account (e.g., ability to upload modules, or the @gnome.org alias)
  • Export the maintainer data (only module name, username) as XML

For general discussion, please use the gnome-infrastructure mailing list. If you find bugs, please file them in GNOME Bugzilla, Infrastructure, sysadmin, mango.

Sneak preview of Mango

Mango will soon be the new way to request GNOME accounts (usually SVN). Mango was first written by Ross Golder, then enhanced by Baris Cicek during Summer of Code 2007 to handle requesting accounts. After that I also changed a few things. Here is a sneak preview of how it’ll handle requesting accounts. It is a sneak preview as there is some small amount of work left.

This is what the website will look like:

If a user wants a new account, the following form needs to be filled in:

After sending in the form, the email address has to be verified:

The user now has to follow the link in Evolution:

Verifying the email address results in the following page:

The maintainers will be emailed:

After logging in, the maintainers have the ability to reject/approve the account:

The requester gets an update on the status:

At the same time, the Accounts Team is requested to create the user:

The Accounts Team can see all accounts that are ready to be setup:

The new user form loads all details from the requested account:

Finally, the user gets an email regarding the new GNOME account:

Reasons not to blog

Saw a mention of a blog with the following in it:

Remember what today might be a funny and smart post, it can be tomorrow’s reason for an employer to not consider your application […]

I avoid blogging about certain things, but that is my decision. Regarding not blogging because of possibly someone at one certain point getting a wrong impression, I agree with xkcd:

dreams.png

Note that I’m not going into any of the rest of that blog. Just this one reason. If that reason was stated as ‘It shows that you’ (etc), I wouldn’t have a problem with it. Regarding that someone should act different because of possible future jobs: don’t pretend you are someone else.

Dropping those old crasher reports

Diego Escalante Urrelo proposed to drop <= GNOME 2.16 crash reports on desktop-devel-list. The reasoning (as discussed on bugsquad-list) is:

  1. They are really old and most of them are answered “well yes, try SVN/last-release it [might be] fixed there”, or simply ignored. They only make bugzilla noisy, hence making difficult to find useful reports.
  2. It is unlikely any new crasher will occur. As we’ve been triaging these crashers for over a year, the chance of a new 2.16-specific crasher is not worth the amount of time it takes to triage the dupes.

There hasn’t been much response on above proposal. I plan to implement above as per 30 September, this year.

Clarification: As some people are misunderstanding: This is not about closing existing bugreports with a ‘please upgrade’ (this is up to the individual developers of each product). This is about not accepting new incoming crash bugreports coming from GNOME 2.16 or earlier. This as the chance of getting an actual new crasher (instead of a dupe) is highly unlikely. This coming from the people (not me) who look at the thousands of new crash bugreports arriving each week.

Creating your own SVN repository

It is now possible to create your own GNOME SVN repository for everyone having a GNOME SVN account.

The full instructions are at:
http://live.gnome.org/NewSVNRepos

But, they are short enough to repeat:

  1. If you need to import the history of some existing repository (SVN or something else), you still need to mail svnmaster@gnome.org with a link to the dump and your GNOME SVN username.
  2. However:

  3. If you just want an empty SVN repos, execute the following:
      ssh $USERNAME@svn.gnome.org new-svn-repos $REPOS

$REPOS should be all lowercase chars, optionally some ‘-‘ thrown in there as well.

Data parsed from MAINTAINERS files

Probably only interesting if you are (or should be) listed in a MAINTAINERS file

In a few days (perhaps more…), people in /trunk/MAINTAINERS will receive new instructions on how to approve SVN account requests (via a system called Mango). These emails will go to everyones email address listed in LDAP. Obviously, that LDAP email address needs to correct. Also, the information in /trunk/MAINTAINERS should have been parsed correctly. I’ve emailed everyone who had a mismatch between the MAINTAINERS email address and LDAP. However, I already noticed for some people their LDAP email address as well as the one in /trunk/MAINTAINERS bounce (oops).

To see the data parsed from the MAINTAINERS files, click here. This file is sorted by account name. It has two lists. One shows possible invalid data. The second list contains all maintainers found from the various MAINTAINERS files.

If you want to ensure there are no mistakes, please check the file and look for your userid. It shows your email address (spam protected) and the modules you are a maintainer of. If you are not listed at all or if some module is missing, please check the /trunk/MAINTAINERS file for typo’s. See lgo/MaintainersCorner if you are interested in the syntax.

Update: If the information between LDAP and the MAINTAINERS file differs on purpose, you can of course ignore the mail you received from Mango.

Shooting yourself in the foot

Last weekend, I replaced a few parts in my pc. This meant I needed to upgrade my distro from ‘i586’ to x86_64. However, this is unfortunately not supported by the distro (RC1 gives weird error messages, the development one tells me it is not supported). The obvious solution is to do it manually.

RPM thought otherwise. It doesn’t let you install x86_64 packages because either it looks at the kernel, or the i586 rpm didn’t allow it. So I used ‘mc’ to install a x86_64 kernel (easier than extracting with cpio). Rebooted, and with the x86_64 kernel (nothing else upgraded), rpm still wouldn’t let me install x86_64 packages. In order to get around that, I manually installed the x86_64 rpm package and all it dependencies (note, this means that if you repeat this, your rpm will NOT work for a while). RPM has too many dependencies 🙁

After installing RPM, I noticed it had a few issues. Namely, it crashed when installing packages. This was due to the /var/lib/rpm files being architecture dependent. I first made a backup of that directory, then used a i586 db_dump (db42-utils) to make a dump of every file. Installed (cpio method) x86_64 db42-utils and restored the files from the dumps. After this RPM sort of worked (sometimes screwed up the rpm database, requiring a rm -f /var/lib/rpm__*). The corruption was solved eventually, but I don’t know how/why.

I then made a script to check for every installed i586 RPM, and upgrade to the x86_64 one (rpm -Uvh). The script knows to change ‘libfoo’ to ‘lib64foo’. It also tried to remove i586 packages if the x86_64 one was already installed (-Uvh didn’t always remove the i586 package.. and of course never for libs). I used a local mirror of a large part of the x86_64 distro for this (15GB or so). Strangely, RPM didn’t really complain about dependency issues (I only ignored them max 3 times, to solve specific problems). Probably the dependencies don’t check the architecture. I had to use –replacefiles more often. The –replacefiles was always due to the i586 libs having the same files as the x86_64 ones (causing conflicts). This didn’t occur too often, I think Mandriva tries to avoid these messages somehow.

Every so often, I used ‘urpmi’ to have it install a few deps. That (perl) command strangely always worked. Even with the mix of i586 and x86_64 packages (I had some perl stuff as i586, some as x86_64.. it still worked).

To check the progress (how many packages still as i586), I used: rpm -qa –queryformat ‘%{NAME}-%{VERSION}-%{RELEASE}.%{ARCH}\n’. In the output, I was only interested in the i586 packages not starting with lib. The amount of those packages started dropping very fast. In the end I looked at ~60 or so packages manually. Some I just removed if I couldn’t find a x86_64 version.

Of course, some stuff broke. E.g., postfix has a deamon_directory in its config file which was correctly updated to the lib64 one. However, pcre in dynamicmaps.cf still pointed to the i586 lib. There was another similar problem (something in /etc/alternatives still pointed to /usr/lib). In total, I have 10 i586 packages left (some packages I made for myself that should actually be noarch, plus things like wine, java plugin, …). This not counting the libs (I did remove the i586 -devel stuff at one point). For something not supported by the distro (Frederic Crozat commented “best way to shoot yourself in the foot”), I expected much worse.