contrib / hooks / multimail / doc / gitolite.rston commit Merge branch 'pw/add-p-recount' into maint (689204c)
   1Setting up git-multimail on gitolite
   2====================================
   3
   4``git-multimail`` supports gitolite 3 natively.
   5The explanations below show an easy way to set up ``git-multimail``,
   6but leave ``git-multimail`` installed and unconfigured for a while. If
   7you run gitolite on a production server, it is advised that you
   8execute the step "Set up the hook" last to avoid confusing your users
   9in the meantime.
  10
  11Set up the hook
  12---------------
  13
  14Log in as your gitolite user.
  15
  16Create a file ``.gitolite/hooks/common/post-receive`` on your gitolite
  17account containing (adapt the path, obviously)::
  18
  19  #!/bin/sh
  20  exec /path/to/git-multimail/git-multimail/git_multimail.py "$@"
  21
  22Make sure it's executable (``chmod +x``). Record the hook in
  23gitolite::
  24
  25  gitolite setup
  26
  27Configuration
  28-------------
  29
  30First, you have to allow the admin to set Git configuration variables.
  31
  32As gitolite user, edit the line containing ``GIT_CONFIG_KEYS`` in file
  33``.gitolite.rc``, to make it look like::
  34
  35  GIT_CONFIG_KEYS                 =>  'multimailhook\..*',
  36
  37You can now log out and return to your normal user.
  38
  39In the ``gitolite-admin`` clone, edit the file ``conf/gitolite.conf``
  40and add::
  41
  42  repo @all
  43      # Not strictly needed as git_multimail.py will chose gitolite if
  44      # $GL_USER is set.
  45      config multimailhook.environment = gitolite
  46      config multimailhook.mailingList = # Where emails should be sent
  47      config multimailhook.from = # From address to use
  48
  49Note that by default, gitolite forbids ``<`` and ``>`` in variable
  50values (for security/paranoia reasons, see
  51`compensating for UNSAFE_PATT
  52<http://gitolite.com/gitolite/git-config/index.html#compensating-for-unsafe95patt>`__
  53in gitolite's documentation for explanations and a way to disable
  54this). As a consequence, you will not be able to use ``First Last
  55<First.Last@example.com>`` as recipient email, but specifying
  56``First.Last@example.com`` alone works.
  57
  58Obviously, you can customize all parameters on a per-repository basis by
  59adding these ``config multimailhook.*`` lines in the section
  60corresponding to a repository or set of repositories.
  61
  62To activate ``git-multimail`` on a per-repository basis, do not set
  63``multimailhook.mailingList`` in the ``@all`` section and set it only
  64for repositories for which you want ``git-multimail``.
  65
  66Alternatively, you can set up the ``From:`` field on a per-user basis
  67by adding a ``BEGIN USER EMAILS``/``END USER EMAILS`` section (see
  68``../README``).
  69
  70Specificities of Gitolite for Configuration
  71-------------------------------------------
  72
  73Empty configuration variables
  74.............................
  75
  76With gitolite, the syntax ``config multimailhook.commitList = ""``
  77unsets the variable instead of setting it to an empty string (see
  78`here
  79<http://gitolite.com/gitolite/git-config.html#an-important-warning-about-deleting-a-config-line>`__).
  80As a result, there is no way to set a variable to the empty string.
  81In all most places where an empty value is required, git-multimail
  82now allows to specify special ``"none"`` value (case-sensitive) to
  83mean the same.
  84
  85Alternatively, one can use ``" "`` (a single space) instead of ``""``.
  86In most cases (in particular ``multimailhook.*List`` variables), this
  87will be equivalent to an empty string.
  88
  89If you have a use-case where ``"none"`` is not an acceptable value and
  90you need ``" "`` or  ``""`` instead, please report it as a bug to
  91git-multimail.
  92
  93Allowing Regular Expressions in Configuration
  94.............................................
  95
  96gitolite has a mechanism to prevent unsafe configuration variable
  97values, which prevent characters like ``|`` commonly used in regular
  98expressions. If you do not need the safety feature of gitolite and
  99need to use regular expressions in your configuration (e.g. for
 100``multimailhook.refFilter*`` variables), set
 101`UNSAFE_PATT
 102<http://gitolite.com/gitolite/git-config.html#unsafe-patt>`__ to a
 103less restrictive value.
 104
 105Troubleshooting
 106---------------
 107
 108Warning: this will disable ``git-multimail`` during the debug, and
 109could confuse your users. Don't run on a production server.
 110
 111To debug configuration issues with ``git-multimail``, you can add the
 112``--stdout`` option when calling ``git_multimail.py`` like this::
 113
 114  #!/bin/sh
 115  exec /path/to/git-multimail/git-multimail/git_multimail.py --stdout "$@"
 116
 117and try pushing from a test repository. You should see the source of
 118the email that would have been sent in the output of ``git push``.