From 7da1e3453abf2f4210b96953d7642c748464d16c Mon Sep 17 00:00:00 2001 From: "James E. Blair" Date: Thu, 10 May 2012 19:19:32 +0000 Subject: [PATCH] Add initial mailman config. Change-Id: I82cda9eb456c1ce3690eab8f558420c8a696ee25 --- files/apache.conf | 73 +++++++++++++++++++++++++ manifests/init.pp | 44 ++++++++++++++++ templates/mm_cfg.py.erb | 114 ++++++++++++++++++++++++++++++++++++++++ 3 files changed, 231 insertions(+) create mode 100644 files/apache.conf create mode 100644 manifests/init.pp create mode 100644 templates/mm_cfg.py.erb diff --git a/files/apache.conf b/files/apache.conf new file mode 100644 index 0000000..a7f421c --- /dev/null +++ b/files/apache.conf @@ -0,0 +1,73 @@ +# Sample configuration for Debian mailman with Apache + +# We can find mailman here: +ScriptAlias /cgi-bin/mailman/ /usr/lib/cgi-bin/mailman/ +# And the public archives: +Alias /pipermail/ /var/lib/mailman/archives/public/ +# Logos: +Alias /images/mailman/ /usr/share/images/mailman/ + +# Use this if you don't want the "cgi-bin" component in your URL: +# In case you want to access mailman through a shorter URL you should enable +# this: +#ScriptAlias /mailman/ /usr/lib/cgi-bin/mailman/ +# In this case you need to set the DEFAULT_URL_PATTERN in +# /etc/mailman/mm_cfg.py to http://%s/mailman/ for the cookie +# authentication code to work. Note that you need to change the base +# URL for all the already-created lists as well. + + + AllowOverride None + Options ExecCGI + AddHandler cgi-script .cgi + Order allow,deny + Allow from all + + + Options FollowSymlinks + AllowOverride None + Order allow,deny + Allow from all + + + AllowOverride None + Order allow,deny + Allow from all + + + +## The following describes how to configure mailman on +## a dedicated virtual host, courtesy Marco d'Itri. + +# Add these lines in /etc/mailman/mm_cfg.py: +#DEFAULT_EMAIL_HOST = 'lists.example.net' +#DEFAULT_URL_HOST = 'lists.example.net' +#DEFAULT_URL_PATTERN = 'http://%s/' + +# +#ServerName lists.example.net +#DocumentRoot /var/www/lists +#ErrorLog /var/log/apache2/lists-error.log +#CustomLog /var/log/apache2/lists-access.log combined +# +# +# Options FollowSymLinks +# AllowOverride None +# +# +#Alias /pipermail/ /var/lib/mailman/archives/public/ +#Alias /images/mailman/ /usr/share/images/mailman/ +#ScriptAlias /admin /usr/lib/cgi-bin/mailman/admin +#ScriptAlias /admindb /usr/lib/cgi-bin/mailman/admindb +#ScriptAlias /confirm /usr/lib/cgi-bin/mailman/confirm +#ScriptAlias /create /usr/lib/cgi-bin/mailman/create +#ScriptAlias /edithtml /usr/lib/cgi-bin/mailman/edithtml +#ScriptAlias /listinfo /usr/lib/cgi-bin/mailman/listinfo +#ScriptAlias /options /usr/lib/cgi-bin/mailman/options +#ScriptAlias /private /usr/lib/cgi-bin/mailman/private +#ScriptAlias /rmlist /usr/lib/cgi-bin/mailman/rmlist +#ScriptAlias /roster /usr/lib/cgi-bin/mailman/roster +#ScriptAlias /subscribe /usr/lib/cgi-bin/mailman/subscribe +#ScriptAlias /mailman/ /usr/lib/cgi-bin/mailman/ +# + diff --git a/manifests/init.pp b/manifests/init.pp new file mode 100644 index 0000000..42b161d --- /dev/null +++ b/manifests/init.pp @@ -0,0 +1,44 @@ +class mailman($mailman_host='') { + + package { "mailman": + ensure => installed, + } + + package { "apache2": + ensure => installed, + } + + file { '/etc/mailman/mm_cfg.py': + owner => 'root', + group => 'root', + mode => 444, + ensure => 'present', + content => template('mailman/mm_cfg.py.erb'), + replace => 'true', + require => Package["mailman"] + } + + file { '/etc/mailman/apache.conf': + owner => 'root', + group => 'root', + mode => 444, + ensure => 'present', + source => 'puppet:///modules/mailman/apache.conf', + replace => 'true', + require => Package["mailman"] + } + + service { 'mailman': + ensure => running, + hasrestart => true, + subscribe => File['/etc/mailman/mm_cfg.py'], + require => Package["mailman"] + } + + service { 'apache2': + ensure => running, + hasrestart => true, + subscribe => File['/etc/mailman/apache.conf'], + require => Package["apache2"] + } +} diff --git a/templates/mm_cfg.py.erb b/templates/mm_cfg.py.erb new file mode 100644 index 0000000..67efe63 --- /dev/null +++ b/templates/mm_cfg.py.erb @@ -0,0 +1,114 @@ +# -*- python -*- + +# Copyright (C) 1998,1999,2000 by the Free Software Foundation, Inc. +# +# This program is free software; you can redistribute it and/or +# modify it under the terms of the GNU General Public License +# as published by the Free Software Foundation; either version 2 +# of the License, or (at your option) any later version. +# +# This program is distributed in the hope that it will be useful, +# but WITHOUT ANY WARRANTY; without even the implied warranty of +# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the +# GNU General Public License for more details. +# +# You should have received a copy of the GNU General Public License +# along with this program; if not, write to the Free Software +# Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA +# 02110-1301 USA + + +"""This is the module which takes your site-specific settings. + +From a raw distribution it should be copied to mm_cfg.py. If you +already have an mm_cfg.py, be careful to add in only the new settings +you want. The complete set of distributed defaults, with annotation, +are in ./Defaults. In mm_cfg, override only those you want to +change, after the + + from Defaults import * + +line (see below). + +Note that these are just default settings - many can be overridden via the +admin and user interfaces on a per-list or per-user basis. + +Note also that some of the settings are resolved against the active list +setting by using the value as a format string against the +list-instance-object's dictionary - see the distributed value of +DEFAULT_MSG_FOOTER for an example.""" + + +####################################################### +# Here's where we get the distributed defaults. # + +from Defaults import * + +############################################################## +# Put YOUR site-specific configuration below, in mm_cfg.py . # +# See Defaults.py for explanations of the values. # + +#------------------------------------------------------------- +# The name of the list Mailman uses to send password reminders +# and similar. Don't change if you want mailman-owner to be +# a valid local part. +MAILMAN_SITE_LIST = 'mailman' + +#------------------------------------------------------------- +# If you change these, you have to configure your http server +# accordingly (Alias and ScriptAlias directives in most httpds) +DEFAULT_URL_PATTERN = 'http://%s/cgi-bin/mailman/' +PRIVATE_ARCHIVE_URL = '/cgi-bin/mailman/private' +IMAGE_LOGOS = '/images/mailman/' + +#------------------------------------------------------------- +# Default domain for email addresses of newly created MLs +DEFAULT_EMAIL_HOST = '<%= mailman_host %>' +#------------------------------------------------------------- +# Default host for web interface of newly created MLs +DEFAULT_URL_HOST = '<%= mailman_host %>' +#------------------------------------------------------------- +# Required when setting any of its arguments. +add_virtualhost(DEFAULT_URL_HOST, DEFAULT_EMAIL_HOST) + +#------------------------------------------------------------- +# The default language for this server. +DEFAULT_SERVER_LANGUAGE = 'en' + +#------------------------------------------------------------- +# Iirc this was used in pre 2.1, leave it for now +USE_ENVELOPE_SENDER = 0 # Still used? + +#------------------------------------------------------------- +# Unset send_reminders on newly created lists +DEFAULT_SEND_REMINDERS = 0 + +#------------------------------------------------------------- +# Uncomment this if you configured your MTA such that it +# automatically recognizes newly created lists. +# (see /usr/share/doc/mailman/README.Exim4.Debian or +# /usr/share/mailman/postfix-to-mailman.py) +MTA=None # Misnomer, suppresses alias output on newlist + +#------------------------------------------------------------- +# Uncomment if you use Postfix virtual domains (but not +# postfix-to-mailman.py), but be sure to see +# /usr/share/doc/mailman/README.Debian first. +# MTA='Postfix' + +#------------------------------------------------------------- +# Uncomment if you want to filter mail with SpamAssassin. For +# more information please visit this website: +# http://www.jamesh.id.au/articles/mailman-spamassassin/ +# GLOBAL_PIPELINE.insert(1, 'SpamAssassin') + +# Note - if you're looking for something that is imported from mm_cfg, but you +# didn't find it above, it's probably in /usr/lib/mailman/Mailman/Defaults.py. + +# Enable VERP, but let Exim create the VERP addresses since it's +# more efficient. --jeblair + +VERP_PASSWORD_REMINDERS = 1 +VERP_PERSONALIZED_DELIVERIES = 1 +VERP_CONFIRMATIONS = 1 +VERP_DELIVERY_INTERVAL = 0