Email Notifications with Subversion

Pre-Flight

Setup

Copy over the sample post-commit hook

Permissions and ownership are vitally important here!

cp hooks/post-commit.tmpl hooks/post-commit
chmod 770 hooks/post-commit
chown apache:apache hooks/post-commit

Now edit hooks/post-commit and add this line:

/usr/share/doc/subversion-1.4.2/tools/hook-scripts/mailer/mailer.py commit "$REPOS" "$REV"

Comment out these lines:

commit-email.pl "$REPOS" "$REV" commit-watchers@example.org
log-commit.py --repository "$REPOS" --revision "$REV"

Configure email alerts for a repository

First copy over the sample mailer config:

cp /usr/share/doc/subversion-1.4.2/tools/hook-scripts/mailer/mailer.conf.example conf/mailer.conf

A general file looks like this:

[general]
mail_command = /usr/sbin/sendmail
smtp_hostname = localhost

[defaults]
diff = /usr/bin/diff -u -L %(label_from)s -L %(label_to)s %(from)s %(to)s
commit_subject_prefix = "[SVN - IT Scripts]"
propchange_subject_prefix =
lock_subject_prefix =
unlock_subject_prefix =
from_addr = donotreply@svn.eng.uiowa.edu
to_addr = foo@uiowa.edu bar@gmail.com
reply_to = donotreply@svn.eng.uiowa.edu
generate_diffs = add copy modify
show_nonmatching_paths = yes
suppress_deletes = yes

[maps]

The various options should be self-explanatory. A test commit should work at this point.

Configuring alerts for specific folders

Let’s say that a specific group of people is to know if commits are made to the firewall_scripts folder. In that case:

[firewall_scripts]
for_paths = ^firewall_scripts($|/)
commit_subject_prefix = "[SVN - Firewall Scripts]"
from_addr = donotreply@svn.eng.uiowa.edu
to_addr = it-admins@genome.uiowa.edu

Testing things out

You don’t necessarily need to commit things to test out the config.

sh hooks/post-commit /home/svn/repository 195

Where the last two arguments are the path to the repo and the revision number.

Tip of the Iceberg

There are tons of things you can do with mailer.conf in a large and/or complicated setting. The best way to get acquainted with its features is to essentially read the default file to figure out what it’s capable of. Reading others’ config files also helps :)