[Pkg-mailman-hackers] Bug#891937: Bug#891937: mailman3-full install issues

Markus Gschwendt markus+debian at runout.at
Wed Apr 18 14:33:11 BST 2018


On Wed, 2018-04-18 at 12:06 +0200, Jonas Meurer wrote:
> do you still encounter this problem?

Yes. At least with mailman3 3.1.1-8

>  I bet there's something wrong on
> your side. Mailman3 works fine with Exim4 and if you configured it
> correctly, it certainly doesn't run the Postfix postmap command.

It's an install of the mailman3-Debian-Sid packages. Nothing else is on
that machine.

exim4: 4.90.1-5
nginx-light: 1.13.12-1
mailman3: 3.1.1-9

I just did upgrade from 3.1.1-8 to 3.1.1-9 and get this on restarting
mailman:

service mailman3 stopTraceback (most recent call last):
  File "/usr/lib/mailman3/bin/master", line 11, in <module>
    load_entry_point('mailman==3.1.1', 'console_scripts', 'master')()
  File "/usr/lib/python3/dist-packages/mailman/bin/master.py", line
528, in main
    with open(config.PID_FILE, 'w') as fp:
PermissionError: [Errno 13] Permission denied:
'/run/mailman3/master.pid'


> If you still encounter this problem, please paste the output of the
> following commands:
> 
> # mailman info

mailman info
GNU Mailman 3.1.1 (Between The Wheels)
Python 3.6.5rc1 (default, Mar 22 2018, 10:45:39) 
[GCC 7.3.0]
config file: /etc/mailman3/mailman.cfg
db url: sqlite:////var/lib/mailman3/data/mailman.db
devmode: DISABLED
REST root url: http://localhost:8001/3.1/
REST credentials: restadmin:xxxxxxxxx


> # mailman conf | grep -F "[mta]"

[mta] configuration: python:mailman.config.exim4
[mta] delivery_retry_period: 5d
[mta] incoming: mailman.mta.exim4.LMTP
[mta] lmtp_host: 127.0.0.1
[mta] lmtp_port: 8024
[mta] max_autoresponses_per_day: 10
[mta] max_delivery_threads: 0
[mta] max_recipients: 500
[mta] max_sessions_per_connection: 0
[mta] outgoing: mailman.mta.deliver.deliver
[mta] remove_dkim_headers: no
[mta] smtp_host: localhost
[mta] smtp_pass: 
[mta] smtp_port: 25
[mta] smtp_user: 
[mta] verp_confirm_format: $address+$cookie
[mta] verp_confirm_regexp:
^(.*<)?(?P<addr>[^+]+?)\+(?P<cookie>[^@]+)@.*$
[mta] verp_confirmations: no
[mta] verp_delimiter: +
[mta] verp_delivery_interval: 0
[mta] verp_format: ${bounces}+${local}=${domain}
[mta] verp_personalized_deliveries: no
[mta] verp_probe_format: $bounces+$token@$domain
[mta] verp_probe_regexp: ^(?P<bounces>[^+]+?)\+(?P<token>[^@]+)@.*$
[mta] verp_probes: no
[mta] verp_regexp:
^(?P<bounces>[^+]+?)\+(?P<local>[^=]+)=(?P<domain>[^@]+)@.*$


> # cat /etc/mailman3/mailman.cfg

# Copyright (C) 2008-2017 by the Free Software Foundation, Inc.
#
# This file is part of GNU Mailman.
#
# GNU Mailman 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 3 of the License, or (at your
option)
# any later version.
#
# GNU Mailman 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
# GNU Mailman.  If not, see <http://www.gnu.org/licenses/>.

# This file contains the Debian configuration for mailman.  It uses
ini-style
# formats under the lazr.config regime to define all system
configuration
# options.  See <https://launchpad.net/lazr.config> for details.


[mailman]
# This address is the "site owner" address.  Certain messages which
must be
# delivered to a human, but which can't be delivered to a list owner
(e.g. a
# bounce from a list owner), will be sent to this address.  It should
point to
# a human.
site_owner: xxx at example.com

# This is the local-part of an email address used in the From field
whenever a
# message comes from some entity to which there is no natural reply
recipient.
# Mailman will append '@' and the host name of the list involved.  This
# address must not bounce and it must not point to a Mailman process.
noreply_address: noreply

# The default language for this server.
default_language: en

# Membership tests for posting purposes are usually performed by
looking at a
# set of headers, passing the test if any of their values match a
member of
# the list.  Headers are checked in the order given in this
variable.  The
# value From_ means to use the envelope sender.  Field names are case
# insensitive.  This is a space separate list of headers.
sender_headers: from from_ reply-to sender

# Mail command processor will ignore mail command lines after
designated max.
email_commands_max_lines: 10

# Default length of time a pending request is live before it is evicted
from
# the pending database.
pending_request_life: 3d

# How long should files be saved before they are evicted from the
cache?
cache_life: 7d

# A callable to run with no arguments early in the initialization
process.
# This runs before database initialization.
pre_hook:

# A callable to run with no arguments late in the initialization
process.
# This runs after adapters are initialized.
post_hook:

# Which paths.* file system layout to use.
# You should not change this variable.
layout: debian

# Can MIME filtered messages be preserved by list owners?
filtered_messages_are_preservable: no

# How should text/html parts be converted to text/plain when the
mailing list
# is set to convert HTML to plaintext?  This names a command to be
called,
# where the substitution variable $filename is filled in by Mailman,
and
# contains the path to the temporary file that the command should read
from.
# The command should print the converted text to stdout.
html_to_plain_text_command: /usr/bin/lynx -dump $filename

# Specify what characters are allowed in list names.  Characters
outside of
# the class [-_.+=!$*{}~0-9a-z] matched case insensitively are never
allowed,
# but this specifies a subset as the only allowable characters.  This
must be
# a valid character class regexp or the effect on list creation is
# unpredictable.
listname_chars: [-_.0-9a-z]


[shell]
# `mailman shell` (also `withlist`) gives you an interactive prompt
that you
# can use to interact with an initialized and configured Mailman
system.  Use
# --help for more information.  This section allows you to configure
certain
# aspects of this interactive shell.

# Customize the interpreter prompt.
prompt: >>>

# Banner to show on startup.
banner: Welcome to the GNU Mailman shell

# Use IPython as the shell, which must be found on the system.  Valid
values
# are `no`, `yes`, and `debug` where the latter is equivalent to `yes`
except
# that any import errors will be displayed to stderr.
use_ipython: no

# Set this to allow for command line history if readline is
available.  This
# can be as simple as $var_dir/history.py to put the file in the var
directory.
history_file:


[paths.debian]
# Important directories for Mailman operation.  These are defined here
so that
# different layouts can be supported.   For example, a developer layout
would
# be different from a FHS layout.  Most paths are based off the
var_dir, and
# often just setting that will do the right thing for all the other
paths.
# You might also have to set spool_dir though.
#
# Substitutions are allowed, but must be of the form $var where 'var'
names a
# configuration variable in the paths.* section.  Substitutions are
expanded
# recursively until no more $-variables are present.  Beware of
infinite
# expansion loops!
#
# This is the root of the directory structure that Mailman will use to
store
# its run-time data.
var_dir: /var/lib/mailman3
# This is where the Mailman queue files directories will be created.
queue_dir: $var_dir/queue
# This is the directory containing the Mailman 'runner' and 'master'
commands
# if set to the string '$argv', it will be taken as the directory
containing
# the 'mailman' command.
bin_dir: /usr/lib/mailman3/bin
# All list-specific data.
list_data_dir: $var_dir/lists
# Directory where log files go.
log_dir: /var/log/mailman3
# Directory for system-wide locks.
lock_dir: $var_dir/locks
# Directory for system-wide data.
data_dir: $var_dir/data
# Cache files.
cache_dir: $var_dir/cache
# Directory for configuration files and such.
etc_dir: /etc/mailman3
# Directory containing Mailman plugins.
ext_dir: $var_dir/ext
# Directory where the default IMessageStore puts its messages.
messages_dir: $var_dir/messages
# Directory for archive backends to store their messages in.  Archivers
should
# create a subdirectory in here to store their files.
archive_dir: $var_dir/archives
# Root directory for site-specific template override files.
template_dir: $var_dir/templates
# There are also a number of paths to specific file locations that can
be
# defined.  For these, the directory containing the file must already
exist,
# or be one of the directories created by Mailman as per above.
#
# This is where PID file for the master runner is stored.
pid_file: /run/mailman3/master.pid
# Lock file.
lock_file: $lock_dir/master.lck


[database]
# The class implementing the IDatabase.
class: mailman.database.sqlite.SQLiteDatabase
#class: mailman.database.mysql.MySQLDatabase
#class: mailman.database.postgresql.PostgreSQLDatabase

# Use this to set the Storm database engine URL.  You generally have
one
# primary database connection for all of Mailman.  List data and most
rosters
# will store their data in this database, although external rosters may
access
# other databases in their own way.  This string supports standard
# 'configuration' substitutions.
url: sqlite:///$DATA_DIR/mailman.db
#url:
mysql+pymysql://mailman3:mmpass@localhost/mailman3?charset=utf8&use_uni
code=1
#url: postgres://mailman3:mmpass@localhost/mailman3

debug: no


[logging.debian]
# This defines various log settings.  The options available are:
#
# - level     -- Overrides the default level; this may be any of the
#                standard Python logging levels, case insensitive.
# - format    -- Overrides the default format string
# - datefmt   -- Overrides the default date format string
# - path      -- Overrides the default logger path.  This may be a
relative
#                path name, in which case it is relative to Mailman's
LOG_DIR,
#                or it may be an absolute path name.  You cannot change
the
#                handler class that will be used.
# - propagate -- Boolean specifying whether to propagate log message
from this
#                logger to the root "mailman" logger.  You cannot
override
#                settings for the root logger.
#
# In this section, you can define defaults for all loggers, which will
be
# prefixed by 'mailman.'.  Use subsections to override settings for
specific
# loggers.  The names of the available loggers are:
#
# - archiver        --  All archiver output
# - bounce          --  All bounce processing logs go here
# - config          --  Configuration issues
# - database        --  Database logging (SQLAlchemy and Alembic)
# - debug           --  Only used for development
# - error           --  All exceptions go to this log
# - fromusenet      --  Information related to the Usenet to Mailman
gateway
# - http            --  Internal wsgi-based web interface
# - locks           --  Lock state changes
# - mischief        --  Various types of hostile activity
# - runner          --  Runner process start/stops
# - smtp            --  Successful SMTP activity
# - smtp-failure    --  Unsuccessful SMTP activity
# - subscribe       --  Information about leaves/joins
# - vette           --  Message vetting information
format: %(asctime)s (%(process)d) %(message)s
datefmt: %b %d %H:%M:%S %Y
propagate: no
level: info
path: mailman.log

[webservice]
# The hostname at which admin web service resources are exposed.
hostname: localhost

# The port at which the admin web service resources are exposed.
port: 8001

# Whether or not requests to the web service are secured through SSL.
use_https: no

# Whether or not to show tracebacks in an HTTP response for a request
that
# raised an exception.
show_tracebacks: yes

# The API version number for the current (highest) API.
api_version: 3.1

# The administrative username.
admin_user: restadmin

# The administrative password.
admin_pass: xxxxxxxxx

[mta]
# The class defining the interface to the incoming mail transport
agent.
incoming: mailman.mta.exim4.LMTP
#incoming: mailman.mta.postfix.LMTP

# The callable implementing delivery to the outgoing mail transport
agent.
# This must accept three arguments, the mailing list, the message, and
the
# message metadata dictionary.
outgoing: mailman.mta.deliver.deliver

# How to connect to the outgoing MTA.  If smtp_user and smtp_pass is
given,
# then Mailman will attempt to log into the MTA when making a new
connection.
smtp_host: localhost
smtp_port: 25
smtp_user:
smtp_pass:

# Where the LMTP server listens for connections.  Use 127.0.0.1 instead
of
# localhost for Postfix integration, because Postfix only consults DNS
# (e.g. not /etc/hosts).
lmtp_host: 127.0.0.1
lmtp_port: 8024

# Where can we find the mail server specific configuration file?  The
path can
# be either a file system path or a Python import path.  If the value
starts
# with python: then it is a Python import path, otherwise it is a file
system
# path.  File system paths must be absolute since no guarantees are
made about
# the current working directory.  Python paths should not include the
trailing
# .cfg, which the file must end with.
configuration: python:mailman.config.exim4
#configuration: python:mailman.config.postfix

[archiver.hyperkitty]
class: mailman_hyperkitty.Archiver
enable: yes
configuration: /etc/mailman3/hyperkitty.cfg



More information about the Pkg-mailman-hackers mailing list