areguera / rpms / mailman

Forked from rpms/mailman 4 years ago
Clone

Blame SOURCES/mailman-2.1.13-FHS.patch

7812c9
diff --git a/Mailman/Defaults.py.in b/Mailman/Defaults.py.in
7812c9
index fb3f4f3..7dde965 100644
7812c9
--- a/Mailman/Defaults.py.in
7812c9
+++ b/Mailman/Defaults.py.in
7812c9
@@ -1431,20 +1431,22 @@ AuthListPoster = 6    # List poster (Approved: <pw> header in posts only)
7812c9
 
7812c9
 # Useful directories
7812c9
 LIST_DATA_DIR   = os.path.join(VAR_PREFIX, 'lists')
7812c9
-LOG_DIR         = os.path.join(VAR_PREFIX, 'logs')
7812c9
-LOCK_DIR        = os.path.join(VAR_PREFIX, 'locks')
7812c9
+LOG_DIR         = '@LOG_DIR@'
7812c9
+LOCK_DIR        = '@LOCK_DIR@'
7812c9
+CONFIG_DIR      = '@CONFIG_DIR@'
7812c9
 DATA_DIR        = os.path.join(VAR_PREFIX, 'data')
7812c9
+PID_DIR         = '@PID_DIR@'
7812c9
 SPAM_DIR        = os.path.join(VAR_PREFIX, 'spam')
7812c9
 WRAPPER_DIR     = os.path.join(EXEC_PREFIX, 'mail')
7812c9
 BIN_DIR         = os.path.join(PREFIX, 'bin')
7812c9
 SCRIPTS_DIR     = os.path.join(PREFIX, 'scripts')
7812c9
-TEMPLATE_DIR    = os.path.join(PREFIX, 'templates')
7812c9
+TEMPLATE_DIR    = '@TEMPLATE_DIR@'
7812c9
 MESSAGES_DIR    = os.path.join(PREFIX, 'messages')
7812c9
 PUBLIC_ARCHIVE_FILE_DIR  = os.path.join(VAR_PREFIX, 'archives', 'public')
7812c9
 PRIVATE_ARCHIVE_FILE_DIR = os.path.join(VAR_PREFIX, 'archives', 'private')
7812c9
 
7812c9
 # Directories used by the qrunner subsystem
7812c9
-QUEUE_DIR       = os.path.join(VAR_PREFIX, 'qfiles')
7812c9
+QUEUE_DIR       = '@QUEUE_DIR@'
7812c9
 INQUEUE_DIR     = os.path.join(QUEUE_DIR, 'in')
7812c9
 OUTQUEUE_DIR    = os.path.join(QUEUE_DIR, 'out')
7812c9
 CMDQUEUE_DIR    = os.path.join(QUEUE_DIR, 'commands')
7812c9
@@ -1458,9 +1460,9 @@ RETRYQUEUE_DIR  = os.path.join(QUEUE_DIR, 'retry')
7812c9
 MAILDIR_DIR     = os.path.join(QUEUE_DIR, 'maildir')
7812c9
 
7812c9
 # Other useful files
7812c9
-PIDFILE = os.path.join(DATA_DIR, 'master-qrunner.pid')
7812c9
-SITE_PW_FILE = os.path.join(DATA_DIR, 'adm.pw')
7812c9
-LISTCREATOR_PW_FILE = os.path.join(DATA_DIR, 'creator.pw')
7812c9
+PIDFILE = os.path.join(PID_DIR, 'master-qrunner.pid')
7812c9
+SITE_PW_FILE = os.path.join(CONFIG_DIR, 'adm.pw')
7812c9
+LISTCREATOR_PW_FILE = os.path.join(CONFIG_DIR, 'creator.pw')
7812c9
 
7812c9
 # Import a bunch of version numbers
7812c9
 from Version import *
7812c9
diff --git a/Mailman/MTA/Postfix.py b/Mailman/MTA/Postfix.py
7812c9
index 801ddc0..8506b9b 100644
7812c9
--- a/Mailman/MTA/Postfix.py
7812c9
+++ b/Mailman/MTA/Postfix.py
7812c9
@@ -32,8 +32,8 @@ from Mailman.MTA.Utils import makealiases
7812c9
 from Mailman.Logging.Syslog import syslog
7812c9
 
7812c9
 LOCKFILE = os.path.join(mm_cfg.LOCK_DIR, 'creator')
7812c9
-ALIASFILE = os.path.join(mm_cfg.DATA_DIR, 'aliases')
7812c9
-VIRTFILE = os.path.join(mm_cfg.DATA_DIR, 'virtual-mailman')
7812c9
+ALIASFILE = os.path.join(mm_cfg.CONFIG_DIR, 'aliases')
7812c9
+VIRTFILE = os.path.join(mm_cfg.CONFIG_DIR, 'virtual-mailman')
7812c9
 
7812c9
 try:
7812c9
     True, False
7812c9
diff --git a/Makefile.in b/Makefile.in
7812c9
index eb40844..289aeee 100644
7812c9
--- a/Makefile.in
7812c9
+++ b/Makefile.in
7812c9
@@ -28,6 +28,12 @@ bindir=		@bindir@
7812c9
 prefix=		@prefix@
7812c9
 exec_prefix=	@exec_prefix@
7812c9
 var_prefix=	@VAR_PREFIX@
7812c9
+configdir=	@CONFIG_DIR@
7812c9
+lockdir=	@LOCK_DIR@
7812c9
+logdir=		@LOG_DIR@
7812c9
+piddir=		@PID_DIR@
7812c9
+queuedir=	@QUEUE_DIR@
7812c9
+templatedir=	@TEMPLATE_DIR@
7812c9
 DESTDIR=
7812c9
 
7812c9
 CC=		@CC@
7812c9
@@ -41,8 +47,11 @@ DEFS=		@DEFS@
7812c9
 OPT=		@OPT@
7812c9
 CFLAGS=		@CFLAGS@ $(OPT) $(DEFS)
7812c9
 
7812c9
+FHS_DIRS= \
7812c9
+	${configdir} ${lockdir} ${logdir} ${piddir} ${queuedir} ${templatedir}
7812c9
+
7812c9
 VAR_DIRS= \
7812c9
-	logs archives lists locks data spam qfiles \
7812c9
+	archives lists data spam \
7812c9
 	archives/private archives/public
7812c9
 
7812c9
 ARCH_INDEP_DIRS= \
7812c9
@@ -105,6 +114,15 @@ doinstall: $(SUBDIRS)
7812c9
 	    else true; \
7812c9
 	    fi; \
7812c9
 	done
7812c9
+	@for d in $(FHS_DIRS); \
7812c9
+	do \
7812c9
+	    dir=$(DESTDIR)/$$d; \
7812c9
+	    if test ! -d $$dir; then \
7812c9
+		echo "Creating directory $$dir"; \
7812c9
+		$(INSTALL) -d -m $(DIRMODE) $$dir; \
7812c9
+	    else true; \
7812c9
+	    fi; \
7812c9
+	done
7812c9
 	chmod o-r $(DESTDIR)$(var_prefix)/archives/private
7812c9
 	@for d in $(ARCH_INDEP_DIRS); \
7812c9
 	do \
7812c9
diff --git a/bin/check_perms b/bin/check_perms
7812c9
index 137ebfb..1f45f84 100755
7812c9
--- a/bin/check_perms
7812c9
+++ b/bin/check_perms
7812c9
@@ -183,7 +183,8 @@ def checkall():
7812c9
         print _('checking mode for %(prefix)s')
7812c9
     dirs = {}
7812c9
     for d in (mm_cfg.PREFIX, mm_cfg.EXEC_PREFIX, mm_cfg.VAR_PREFIX,
7812c9
-              mm_cfg.LOG_DIR):
7812c9
+              mm_cfg.CONFIG_DIR, mm_cfg.DATA_DIR, mm_cfg.LOCK_DIR,
7812c9
+              mm_cfg.LOG_DIR, mm_cfg.QUEUE_DIR, mm_cfg.PID_DIR):
7812c9
         dirs[d] = True
7812c9
     for d in dirs.keys():
7812c9
         try:
7812c9
diff --git a/configure.in b/configure.in
7812c9
index f2eb1c0..c01129c 100644
7812c9
--- a/configure.in
7812c9
+++ b/configure.in
7812c9
@@ -305,6 +305,72 @@ else
7812c9
     prefixcheck=$VAR_PREFIX
7812c9
 fi
7812c9
 
7812c9
+# Get the configuration file directory
7812c9
+AC_SUBST(CONFIG_DIR)
7812c9
+AC_MSG_CHECKING(for --with-config-dir)
7812c9
+AC_ARG_WITH(config-dir, dnl
7812c9
+[  --with-config-dir    specify directory for configuration data other than [VAR_]PREFIX/data])
7812c9
+case "$with_config_dir" in
7812c9
+    yes|no|"") CONFIG_DIR="$VAR_PREFIX/data";;
7812c9
+    *)         CONFIG_DIR=$with_config_dir;;
7812c9
+esac
7812c9
+AC_MSG_RESULT($CONFIG_DIR)
7812c9
+
7812c9
+# Get the lock directory
7812c9
+AC_SUBST(LOCK_DIR)
7812c9
+AC_MSG_CHECKING(for --with-lock-dir)
7812c9
+AC_ARG_WITH(lock-dir, dnl
7812c9
+[  --with-lock-dir    specify directory for lock files other than [VAR_]PREFIX/locks])
7812c9
+case "$with_lock_dir" in
7812c9
+    yes|no|"") LOCK_DIR="$VAR_PREFIX/locks";;
7812c9
+    *)         LOCK_DIR=$with_lock_dir;;
7812c9
+esac
7812c9
+AC_MSG_RESULT($LOCK_DIR)
7812c9
+
7812c9
+# Get the log directory
7812c9
+AC_SUBST(LOG_DIR)
7812c9
+AC_MSG_CHECKING(for --with-log-dir)
7812c9
+AC_ARG_WITH(log-dir, dnl
7812c9
+[  --with-log-dir    specify directory for log files other than [VAR_]PREFIX/logs])
7812c9
+case "$with_log_dir" in
7812c9
+    yes|no|"") LOG_DIR="$VAR_PREFIX/logs";;
7812c9
+    *)         LOG_DIR=$with_log_dir;;
7812c9
+esac
7812c9
+AC_MSG_RESULT($LOG_DIR)
7812c9
+
7812c9
+# Get the pid directory
7812c9
+AC_SUBST(PID_DIR)
7812c9
+AC_MSG_CHECKING(for --with-pid-dir)
7812c9
+AC_ARG_WITH(pid-dir, dnl
7812c9
+[  --with-pid-dir    specify directory for the pid file other than [VAR_]PREFIX/data])
7812c9
+case "$with_pid_dir" in
7812c9
+    yes|no|"") PID_DIR="$VAR_PREFIX/data";;
7812c9
+    *)         PID_DIR=$with_pid_dir;;
7812c9
+esac
7812c9
+AC_MSG_RESULT($PID_DIR)
7812c9
+
7812c9
+# Get the queue directory
7812c9
+AC_SUBST(QUEUE_DIR)
7812c9
+AC_MSG_CHECKING(for --with-queue-dir)
7812c9
+AC_ARG_WITH(queue-dir, dnl
7812c9
+[  --with-queue-dir    specify directory for queue files other than [VAR_]PREFIX/qfiles])
7812c9
+case "$with_queue_dir" in
7812c9
+    yes|no|"") QUEUE_DIR="$VAR_PREFIX/qfiles";;
7812c9
+    *)         QUEUE_DIR=$with_queue_dir;;
7812c9
+esac
7812c9
+AC_MSG_RESULT($QUEUE_DIR)
7812c9
+
7812c9
+# Get the template directory
7812c9
+AC_SUBST(TEMPLATE_DIR)
7812c9
+AC_MSG_CHECKING(for --with-template-dir)
7812c9
+AC_ARG_WITH(template-dir, dnl
7812c9
+[  --with-template-dir    specify directory for template files other than [VAR_]PREFIX/templates])
7812c9
+case "$with_template_dir" in
7812c9
+    yes|no|"") TEMPLATE_DIR="$VAR_PREFIX/templates";;
7812c9
+    *)         TEMPLATE_DIR=$with_template_dir;;
7812c9
+esac
7812c9
+AC_MSG_RESULT($TEMPLATE_DIR)
7812c9
+
7812c9
 # new macro for finding group names
7812c9
 # returns a comma separated list of quoted group names
7812c9
 # the list is returned in the same order as specified with any duplicates removed
7812c9
diff --git a/misc/Makefile.in b/misc/Makefile.in
7812c9
index af99c04..df50a06 100644
7812c9
--- a/misc/Makefile.in
7812c9
+++ b/misc/Makefile.in
7812c9
@@ -27,6 +27,12 @@ bindir= 	@bindir@
7812c9
 prefix=   	@prefix@
7812c9
 exec_prefix=	@exec_prefix@
7812c9
 var_prefix=	@VAR_PREFIX@
7812c9
+configdir=	@CONFIG_DIR@
7812c9
+lockdir=	@LOCK_DIR@
7812c9
+logdir=		@LOG_DIR@
7812c9
+piddir=		@PID_DIR@
7812c9
+queuedir=	@QUEUE_DIR@
7812c9
+MAILMAN_GROUP=  @MAILMAN_GROUP@
7812c9
 DESTDIR=
7812c9
 
7812c9
 CC=		@CC@
7812c9
@@ -87,7 +93,7 @@ install-other:
7812c9
 	    $(INSTALL) -m $(FILEMODE) paths.py $$dir; \
7812c9
 	done
7812c9
 	$(INSTALL) -m $(EXEMODE) mailman $(DESTDIR)$(SCRIPTSDIR)
7812c9
-	$(INSTALL) -m $(FILEMODE) sitelist.cfg $(DESTDIR)$(DATADIR)
7812c9
+	$(INSTALL) -m $(FILEMODE) sitelist.cfg $(DESTDIR)$(configdir)
7812c9
 
7812c9
 install-packages:
7812c9
 	if [ -z "$(EMAILPKG)" -a -d $(DESTDIR)$(PYTHONLIBDIR)/email ] ; \
7812c9
diff --git a/templates/Makefile.in b/templates/Makefile.in
7812c9
index b23d7c1..16930a2 100644
7812c9
--- a/templates/Makefile.in
7812c9
+++ b/templates/Makefile.in
7812c9
@@ -25,6 +25,7 @@ srcdir= 	@srcdir@
7812c9
 bindir= 	@bindir@
7812c9
 prefix=   	@prefix@
7812c9
 exec_prefix=	@exec_prefix@
7812c9
+template_dir=   @TEMPLATE_DIR@
7812c9
 DESTDIR=
7812c9
 
7812c9
 CC=		@CC@
7812c9
@@ -37,7 +38,7 @@ DEFS=   	@DEFS@
7812c9
 
7812c9
 OPT=		@OPT@
7812c9
 CFLAGS=		$(OPT) $(DEFS)
7812c9
-TEMPLATEDIR= 	$(prefix)/templates
7812c9
+TEMPLATEDIR= 	$(template_dir)
7812c9
 
7812c9
 SHELL=		/bin/sh
7812c9