2
0
mirror of https://github.com/vdukhovni/postfix synced 2025-08-29 21:27:57 +00:00

snapshot-20020113

This commit is contained in:
Wietse Venema 2002-01-13 00:00:00 -05:00 committed by Viktor Dukhovni
parent 654192e3d1
commit 2e7d506175
9 changed files with 726 additions and 390 deletions

View File

@ -5949,6 +5949,13 @@ Apologies for any names omitted.
Feedback: feedback, bugfixes, and brain-dead shell workarounds Feedback: feedback, bugfixes, and brain-dead shell workarounds
for the install scripts by Victor Duchovny and Simon Mudd. for the install scripts by Victor Duchovny and Simon Mudd.
20020113
Rewrote postfix-install. The postfix-files file now controls
what is installed. Refined the semantics of many post-install
operations. post-install now auto-saves settings that override
main.cf.
Open problems: Open problems:
Low: don't do user@domain and @domain lookups in Low: don't do user@domain and @domain lookups in

View File

@ -58,7 +58,7 @@ cleanmakefiles:
tidy: clean tidy: clean
rm -f Makefile */Makefile src/*/Makefile rm -f Makefile */Makefile src/*/Makefile
cp Makefile.init Makefile cp Makefile.init Makefile
rm -f bin/* lib/* include/* libexec/* \ rm -f bin/[!CRS]* lib/[!CRS]* include/[!CRS]* libexec/[!CRS]* \
junk */junk */*/junk \ junk */junk */*/junk \
*core */*core */*/*core \ *core */*core */*/*core \
.nfs* */.nfs* */*/.nfs* \ .nfs* */.nfs* */*/.nfs* \

View File

@ -1,3 +1,13 @@
Incompatible changes with snapshot-20020113
===========================================
Another revision of installation procedures. The command interface
of the postfix-install and $config_directory/post-install scripts
has changed; see embedded documentation. postfix-install no longer has
hard-coded commands to install files: $config_directory/postfix-files
now controls what files are installed. The post-install script now
automatically saves installation parameters to the main.cf file.
Incompatible changes with snapshot-20020111 Incompatible changes with snapshot-20020111
=========================================== ===========================================
@ -10,7 +20,7 @@ parameters such as mail_owner and setgid_group after installing
Postfix, and apply the correct file/directory ownerships and Postfix, and apply the correct file/directory ownerships and
permissions by executing the post-install script as: permissions by executing the post-install script as:
post-install set-permissions config_directory=/etc/postfix post-install set-permissions setgid_group=groupname
Incompatible changes with snapshot-20020110 Incompatible changes with snapshot-20020110
=========================================== ===========================================

View File

@ -17,65 +17,155 @@
# .IP o # .IP o
# While installing Postfix from source code on the local machine, the # While installing Postfix from source code on the local machine, the
# script is run by the postfix-install script to update selected file # script is run by the postfix-install script to update selected file
# or directory permissions and to update selected configuration files. # or directory permissions and to update Postfix configuration files.
# .IP o # .IP o
# While installing Postfix from a pre-built package, the script is run # While installing Postfix from a pre-built package, the script is run
# by the package management procedure to set all file or directory # by the package management procedure to set all file or directory
# permissions and to update existing Postfix configuration files. # permissions and to update Postfix configuration files.
# .IP o
# The script can be used to change installation parameter settings such
# as mail_owner or setgid_group after Postfix is already installed.
# .IP o
# The script can be used to upgrade configuration files and to upgrade
# file/directory permissions of a secondary Postfix instance.
# .IP o # .IP o
# At Postfix start-up time, the script is run from "postfix check" to # At Postfix start-up time, the script is run from "postfix check" to
# create missing queue directories. # create missing queue directories.
# .PP # .PP
# The post-install script is controlled by installation parameters.
# Specific parameters are described at the end of this document.
# All installation parameters must be specified ahead of time via
# one of the methods described below.
#
# Arguments # Arguments
# .IP create-missing # .IP create-missing
# Create missing queue directories with ownerships and permissions # Create missing queue directories with ownerships and permissions
# according to the contents of $config_directory/postfix-files. # according to the contents of $config_directory/postfix-files, using
# the mail_owner and setgid_group parameter settings from the command
# line, process environment or from the installed main.cf file.
# #
# This is required at Postfix start-up time. # This is required at Postfix start-up time.
# .IP set-permissions # .IP set-permissions
# Set all file/directory ownerships and permissions according to the # Set all file/directory ownerships and permissions according to the
# contents of $config_directory/postfix-files. Implies create-missing. # contents of $config_directory/postfix-files, using the mail_owner
# and setgid_group parameter settings from the command line, process
# environment or from the installed main.cf file. Implies create-missing.
# #
# This is required when installing Postfix from a pre-built package. # This is required when installing Postfix from a pre-built package,
# or when changing the mail_owner or setgid_group installation parameter
# settings after Postfix is already installed.
# .IP upgrade-permissions # .IP upgrade-permissions
# Update ownership and permission of selected files/directories as # Update ownership and permission of existing files/directories as
# specified in $config_directory/postfix-files. Implies create-missing. # specified in $config_directory/postfix-files, using the mail_owner
# and setgid_group parameter settings from the command line, process
# environment or from the installed main.cf file. Implies create-missing.
# #
# This is required when installing Postfix from source code, while # This is required when upgrading an existing Postfix instance.
# Postfix was already installed on the machine.
# .IP upgrade-configuration # .IP upgrade-configuration
# Edit the installed main.cf and master.cf files, in order to account # Edit the installed main.cf and master.cf files, in order to account
# for missing services and to fix deprecated parameter settings. # for missing services and to fix deprecated parameter settings.
# #
# This is required when Postfix was already installed on the machine. # This is required when upgrading an existing Postfix instance.
# .IP upgrade-source # .IP upgrade-source
# Short-hand for upgrade-permissions upgrade-configuration. # Short-hand for: upgrade-permissions upgrade-configuration.
# #
# This is recommended when upgrading Postfix from source code. # This is recommended when upgrading Postfix from source code.
# .IP upgrade-package # .IP upgrade-package
# Short-hand for set-permissions upgrade-configuration. # Short-hand for: set-permissions upgrade-configuration.
# #
# This is recommended when upgrading Postfix from a pre-built package. # This is recommended when upgrading Postfix from a pre-built package.
# .IP first-install-reminder # .IP first-install-reminder
# Remind the user that they still need to configure main.cf and the # Remind the user that they still need to configure main.cf and the
# aliases file, and that newaliases needs to be run. # aliases file, and that newaliases still needs to be run.
# #
# This is recommended when Postfix is installed for the first time. # This is recommended when Postfix is installed for the first time.
# .IP config_directory=pathname # MULTIPLE POSTFIX INSTANCES
# Absolute pathname of the directory with Postfix configuration files. # .ad
# This information must be specified if it is not given via the # .fi
# process environment. # Multiple Postfix instances on the same machine can share command and
# .IP command_directory=pathname # daemon program files but must have separate configuration and queue
# Absolute pathname of the directory with the postconf command. # directories.
# This information must be specified if it is not given via the #
# process environment, and if the directory is not a standard # To create a secondary Postfix installation on the same machine,
# system directory. # copy the configuration files from the primary Postfix instance to
# a secondary configuration directory and execute:
#
# post-install config_directory=secondary-config-directory \e
# .in +4
# queue_directory=secondary-queue-directory \e
# .br
# create-missing
# .PP
# This creates secondary Postfix queue directories, sets their access
# permissions, and saves the specified installation parameters to the
# secondary main.cf file.
#
# Be sure to list the secondary configuration directory in the
# alternate_config_directories parameter in the primary main.cf file.
#
# To upgrade a secondary Postfix installation on the same machine,
# execute:
#
# post-install config_directory=secondary-config-directory \e
# .in +4
# upgrade-permissions upgrade-configuration
# INSTALLATION PARAMETER INPUT METHODS
# .ad
# .fi
# Parameter settings can be specified through a variety of
# mechanisms. In order of decreasing precedence these are:
# .IP "command line"
# Parameter settings can be given as name=value arguments on
# the post-install command line. These have the highest precedence.
# Settings that override the installed main.cf file are saved.
# .IP "process environment"
# Parameter settings can be given as name=value environment
# variables.
# Settings that override the installed main.cf file are saved.
# .IP "installed configuration files"
# If a parameter is not specified via the command line or via the
# process environment, post-install will attempt to extract its
# value from the already installed Postfix main.cf configuration file.
# These settings have the lowest precedence.
# INSTALLATION PARAMETER DESCRIPTION
# .ad
# .fi
# The description of installation parameters is as follows:
# .IP config_directory
# The directory for Postfix configuration files.
# .IP daemon_directory
# The directory for Postfix daemon programs. This directory
# should not be in the command search path of any users.
# .IP command_directory
# The directory for Postfix administrative commands. This
# directory should be in the command search path of adminstrative users.
# .IP queue_directory
# The directory for Postfix queues.
# .IP sendmail_path
# The full pathname for the Postfix sendmail command.
# This is the Sendmail-compatible mail posting interface.
# .IP newaliases_path
# The full pathname for the Postfix newaliases command.
# This is the Sendmail-compatible command to build alias databases
# for the Postfix local delivery agent.
# .IP mailq_path
# The full pathname for the Postfix mailq command.
# This is the Sendmail-compatible command to list the mail queue.
# .IP mail_owner
# The owner of the Postfix queue. Its numerical user ID and group ID
# must not be used by any other accounts on the system.
# .IP setgid_group
# The group for mail submission and for queue management commands.
# Its numerical group ID must not be used by any other accounts on the
# system, not even by the mail_owner account.
# .IP manpage_path
# The directory for the Postfix on-line manual pages.
# SEE ALSO # SEE ALSO
# postfix-install(1) Postfix primary installation script. # postfix-install(1) Postfix primary installation script.
# FILES # FILES
# $config_directory/main.cf, Postfix installation configuration. # $config_directory/main.cf, Postfix installation parameters.
# $config_directory/postfix-files, permissions and ownerships. # $config_directory/postfix-files, installation control file.
# This file is created by postfix-install. # $config_directory/install.cf, obsolete configuration file.
# LICENSE # LICENSE
# .ad # .ad
# .fi # .fi
@ -93,25 +183,25 @@ PATH=/bin:/usr/bin:/usr/sbin:/usr/etc:/sbin:/etc:/usr/contrib/bin:/usr/gnu/bin:/
SHELL=/bin/sh SHELL=/bin/sh
IFS=" IFS="
" "
BACKUP_IFS="$IFS"
USAGE="Usage: $0 [name=value] command USAGE="Usage: $0 [name=value] command
create-missing Create missing queue directories. create-missing Create missing queue directories.
upgrade-source Use when upgrading from source. upgrade-source When installing or upgrading from source code.
upgrade-package Use when upgrading from pre-built package. upgrade-package When installing or upgrading from pre-built package.
first-install-reminder Remind of mandatory configuration steps. first-install-reminder Remind of mandatory first-time configuration steps.
config_directory=path Specify an absolute path name. name=value Specify an installation parameter".
command_directory=path Specify an absolute path name."
# Process command-line options and parameter settings. Work around # Process command-line options and parameter settings. Work around
# brain damaged shells. "name=value command" should not make the # brain damaged shells. "IFS=value command" should not make the
# name=value setting permanent. # IFS=value setting permanent. But some broken standard allows it.
create=; set_perms=; upgrade_perms=; upgrade_conf=; first_install_reminder= create=; set_perms=; upgrade_perms=; upgrade_conf=; first_install_reminder=
for arg for arg
do do
case $arg in case $arg in
*=*) SAVED_IFS="$IFS"; IFS= eval $arg; IFS="$SAVED_IFS";; *=*) IFS= eval $arg; IFS="$BACKUP_IFS";;
create-missing) create=1;; create-missing) create=1;;
set-perm*) create=1; set_perms=1;; set-perm*) create=1; set_perms=1;;
upgrade-perm*) create=1; upgrade_perms=1;; upgrade-perm*) create=1; upgrade_perms=1;;
@ -119,8 +209,7 @@ do
upgrade-source) create=1; upgrade_conf=1; upgrade_perms=1;; upgrade-source) create=1; upgrade_conf=1; upgrade_perms=1;;
upgrade-package) create=1; upgrade_conf=1; set_perms=1;; upgrade-package) create=1; upgrade_conf=1; set_perms=1;;
first-install*) first_install_reminder=1;; first-install*) first_install_reminder=1;;
"") break;; *) echo "$0: Error: $USAGE" 1>&2; exit 1;;
*) echo "Error: $USAGE" 1>&2; exit 1;;
esac esac
shift shift
done done
@ -128,23 +217,29 @@ done
# Sanity checks. # Sanity checks.
test -n "$create$upgrade_conf$first_install_reminder" || { test -n "$create$upgrade_conf$first_install_reminder" || {
echo "Error: $USAGE" 1>&2 echo "$0: Error: $USAGE" 1>&2
exit 1 exit 1
} }
test -n "$config_directory" || { # Bootstrapping problem.
echo "Error: no config_directory parameter setting." 1>&2
echo "$USAGE" 1>&2 if [ -n "$command_directory" ]
exit 1 then
} POSTCONF="$command_directory/postconf"
else
POSTCONF="postconf"
fi
test -n "$config_directory" ||
config_directory=`$POSTCONF -d -h config_directory` || exit 1
test -d "$config_directory" || { test -d "$config_directory" || {
echo Error: $config_directory is not a directory. 1>&2 echo $0: Error: $config_directory is not a directory. 1>&2
exit 1 exit 1
} }
test -f $config_directory/postfix-files || { test -f $config_directory/postfix-files || {
Error: $config_directory/postfix-files is not a file. 1>&2 $0: Error: $config_directory/postfix-files is not a file. 1>&2
exit 1 exit 1
} }
@ -159,42 +254,146 @@ else
CHATTR=echo CHATTR=echo
fi fi
# Bootstrapping problem. case `uname -s` in
HP-UX*) FMT=cat;;
*) FMT=fmt;;
esac
if [ -n "$command_directory" ] # If a parameter is not set via the command line or environment,
then # try to use settings from installed configuration files.
POSTCONF="$command_directory/postconf"
else
POSTCONF="postconf"
fi
# Settings from main.cf must override command line or environment settings. # Extract parameter settings from the obsolete install.cf file, as
# a transitional aid.
grep setgid_group $config_directory/main.cf >/dev/null 2>&1 || {
test -f $config_directory/install.cf && {
for name in sendmail_path newaliases_path mailq_path setgid manpages
do
eval : \${$name="\`. $config_directory/install.cf; echo \$$name\`"} \
|| exit 1
done
: ${setgid_group=$setgid}
: ${manpage_path=$manpages}
}
}
# Extract parameter settings from the installed main.cf file.
test -f $config_directory/main.cf && {
for name in daemon_directory command_directory queue_directory mail_owner \ for name in daemon_directory command_directory queue_directory mail_owner \
setgid_group sendmail_path newaliases_path mailq_path manpage_path setgid_group sendmail_path newaliases_path mailq_path manpage_path
do do
eval $name=\`$POSTCONF -c $config_directory -h $name\` || kill $$ eval : \${$name=\`$POSTCONF -c $config_directory -h $name\`} || exit 1
done
}
# Sanity checks
case $manpage_path in
no) echo $0: Error: manpage_path no longer accepts \"no\" values. 1>&2
echo Re-run this script as \"$0 manpage_path=/pathname $*\". 1>&2; exit 1;;
esac
case $setgid_group in
no) echo $0: Error: setgid_group no longer accepts \"no\" values. 1>&2
echo Re-run this script as \"$0 setgid_group=groupname $*\" 1>&2; exit 1;;
esac
for path in $daemon_directory $command_directory \
$queue_directory $sendmail_path $newaliases_path $mailq_path $manpage_path
do
case $path in
/*) ;;
*) echo $0: Error: $path should be an absolute path name. 1>&2; exit 1;;
esac
done done
# Find out what parameters were not specified via command line,
# via environment, or via installed configuration files.
missing=
for name in daemon_directory command_directory queue_directory mail_owner \
setgid_group sendmail_path newaliases_path mailq_path manpage_path
do
eval test -n \"\$$name\" || missing="$missing $name"
done
# All parameters must be specified at this point.
test -n "$non_interactive" -a -n "$missing" && {
cat <<EOF | ${FMT} 1>&2
$0: Error: some required installation parameters are not defined.
- Either the parameters need to be given in the $config_directory/main.cf
file from a recent Postfix installation,
- Or the parameters need to be specified as name=value arguments
on the $0 command line,
- Or the parameters need to be specified through the process
environment.
The following parameters were missing:
$missing
EOF
exit 1
}
POSTCONF="$command_directory/postconf" POSTCONF="$command_directory/postconf"
# Save settings, allowing command line/environment override.
override=
for name in daemon_directory command_directory queue_directory mail_owner \
setgid_group sendmail_path newaliases_path mailq_path manpage_path
do
eval test \"\$$name\" = \"`$POSTCONF -c $config_directory -h $name`\" || {
override=1
break
}
done
test -n "$override" && {
$POSTCONF -c $config_directory -e \
"daemon_directory = $daemon_directory" \
"command_directory = $command_directory" \
"queue_directory = $queue_directory" \
"mail_owner = $mail_owner" \
"setgid_group = $setgid_group" \
"sendmail_path = $sendmail_path" \
"mailq_path = $mailq_path" \
"newaliases_path = $newaliases_path" \
"manpage_path = $manpage_path" \
|| exit 1
}
# Use file/directory status information in $config_directory/postfix-files. # Use file/directory status information in $config_directory/postfix-files.
test -n "$create" && { test -n "$create" && {
while IFS=: read path type owner group mode upgrade_flag create_flag junk exec <$config_directory/postfix-files || exit 1
while IFS=: read path type owner group mode flags junk
do do
IFS="$BACKUP_IFS"
set_permission= set_permission=
# Skip comments.
case $path in case $path in
[$]*) eval path=$path;; [/$]*) ;;
/*) ;;
*) continue;; *) continue;;
esac esac
case $owner in # Expand $name, and canonicalize null fields.
[$]*) eval owner=$owner;; for name in path owner group flags
esac do
case $group in eval junk=\${$name}
[$]*) eval group=$group;; case $junk in
[$]*) eval $name=$junk;;
-) eval $name=;;
*) ;;
esac esac
done
case $flags in *u*) upgrade_flag=1;; *) upgrade_flag=;; esac
case $flags in *c*) create_flag=1;; *) create_flag=;; esac
# Create missing directories with proper owner/group/mode settings. # Create missing directories with proper owner/group/mode settings.
if [ -n "$create" -a "$type" = "d" -a -n "$create_flag" -a ! -d "$path" ] if [ -n "$create" -a "$type" = "d" -a -n "$create_flag" -a ! -d "$path" ]
then then
@ -215,7 +414,7 @@ test -n "$create" && {
test -z "$group" || chgrp $group $path || exit 1 test -z "$group" || chgrp $group $path || exit 1
chmod $mode $path || exit 1 chmod $mode $path || exit 1
} }
done <$config_directory/postfix-files done
} }
# Upgrade existing Postfix configuration files if necessary. # Upgrade existing Postfix configuration files if necessary.
@ -226,7 +425,7 @@ test -n "$upgrade_conf" && {
grep 'flush.*flush' $config_directory/master.cf >/dev/null || { grep 'flush.*flush' $config_directory/master.cf >/dev/null || {
echo Editing $config_directory/master.cf, adding missing entry for flush service echo Editing $config_directory/master.cf, adding missing entry for flush service
cat >>$config_directory/master.cf <<EOF cat >>$config_directory/master.cf <<EOF || exit 1
flush unix - - n 1000? 0 flush flush unix - - n 1000? 0 flush
EOF EOF
} }
@ -236,7 +435,7 @@ EOF
grep "^pickup[ ]*fifo[ ]*n[ ]*n" \ grep "^pickup[ ]*fifo[ ]*n[ ]*n" \
$config_directory/master.cf >/dev/null && { $config_directory/master.cf >/dev/null && {
echo Editing $config_directory/master.cf, making the pickup service unprivileged echo Editing $config_directory/master.cf, making the pickup service unprivileged
ed $config_directory/master.cf <<EOF ed $config_directory/master.cf <<EOF || exit 1
/^pickup[ ]*fifo[ ]*n[ ]*n/ /^pickup[ ]*fifo[ ]*n[ ]*n/
s/\(n[ ]*\)n/\1-/ s/\(n[ ]*\)n/\1-/
p p
@ -252,7 +451,7 @@ EOF
grep "^$name[ ]*unix[ ]*-" \ grep "^$name[ ]*unix[ ]*-" \
$config_directory/master.cf >/dev/null && { $config_directory/master.cf >/dev/null && {
echo Editing $config_directory/master.cf, making the $name service public echo Editing $config_directory/master.cf, making the $name service public
ed $config_directory/master.cf <<EOF ed $config_directory/master.cf <<EOF || exit 1
/^$name[ ]*unix[ ]*-/ /^$name[ ]*unix[ ]*-/
s/-/n/ s/-/n/
p p
@ -281,9 +480,9 @@ EOF
(echo "$found" | grep deferred>/dev/null)|| missing="$missing deferred" (echo "$found" | grep deferred>/dev/null)|| missing="$missing deferred"
test -n "$missing" && { test -n "$missing" && {
echo fixing main.cf hash_queue_names for missing $missing echo fixing main.cf hash_queue_names for missing $missing
$POSTCONF -c $config_directory -e hash_queue_names="$found$missing" $POSTCONF -c $config_directory -e hash_queue_names="$found$missing" ||
exit 1
} }
} }
# A reminder if this is the first time Postfix is being installed. # A reminder if this is the first time Postfix is being installed.
@ -292,7 +491,7 @@ test -n "$first_install_reminder" && {
ALIASES=`$POSTCONF -h alias_database | sed 's/^[^:]*://'` ALIASES=`$POSTCONF -h alias_database | sed 's/^[^:]*://'`
NEWALIASES_PATH=`$POSTCONF -h newaliases_path` NEWALIASES_PATH=`$POSTCONF -h newaliases_path`
cat <<EOF 1>&2 cat <<EOF | ${FMT}
Warning: you still need to edit myorigin/mydestination/mynetworks Warning: you still need to edit myorigin/mydestination/mynetworks
parameter settings in $config_directory/main.cf. parameter settings in $config_directory/main.cf.

164
postfix/conf/postfix-files Normal file
View File

@ -0,0 +1,164 @@
#
# Do not edit this file.
#
# This file controls the postfix-install script for installation of
# Postfix programs, configuration files and documentation, as well
# as the post-install script for setting permissions and for updating
# Postfix configuration files. See the respective manual pages within
# the script files.
#
# Do not list $command_directory in this file, or it will be blown
# away by a future Postfix uninstallation procedure. You would not
# want to lose all files in /usr/sbin.
#
# Each record in this file describes one file or directory.
# Fields are separated by ":". Specify a null field as "-".
# Missing fields or separators at the end are OK.
#
# File format:
# name:type:owner:group:permission:flags
# No group means don't change group ownership.
#
# File types:
# d=directory
# f=regular file
# l=symlink to $sendmail_path
#
# File flags:
# No flag means the flag is not active.
# p=preserve existing file, do not replace (postfix-install).
# u=update owner/group/mode (post-install upgrade-permissions).
# c=create missing directory (post-install create-missing).
#
# Note: the "u" flag is for upgrading the permissions of existing files
# or directories after changes in Postfix architecture.
#
$config_directory:d:root:-:755:u
$daemon_directory:d:root:-:755:u
$queue_directory:d:root:-:755:uc
$queue_directory/active:d:$mail_owner:-:700:uc
$queue_directory/bounce:d:$mail_owner:-:700:uc
$queue_directory/corrupt:d:$mail_owner:-:700:uc
$queue_directory/defer:d:$mail_owner:-:700:uc
$queue_directory/deferred:d:$mail_owner:-:700:uc
$queue_directory/flush:d:$mail_owner:-:700:uc
$queue_directory/incoming:d:$mail_owner:-:700:uc
$queue_directory/private:d:$mail_owner:-:700:uc
$queue_directory/saved:d:$mail_owner:-:700:uc
$queue_directory/maildrop:d:$mail_owner:$setgid_group:730:uc
$queue_directory/public:d:$mail_owner:$setgid_group:710:uc
$queue_directory/pid:d:root:-:755:uc
$daemon_directory/bounce:f:root:-:755
$daemon_directory/cleanup:f:root:-:755
$daemon_directory/error:f:root:-:755
$daemon_directory/flush:f:root:-:755
$daemon_directory/lmtp:f:root:-:755
$daemon_directory/local:f:root:-:755
$daemon_directory/master:f:root:-:755
$daemon_directory/nqmgr:f:root:-:755
$daemon_directory/pickup:f:root:-:755
$daemon_directory/pipe:f:root:-:755
$daemon_directory/qmgr:f:root:-:755
$daemon_directory/qmqpd:f:root:-:755
$daemon_directory/showq:f:root:-:755
$daemon_directory/smtp:f:root:-:755
$daemon_directory/smtpd:f:root:-:755
$daemon_directory/spawn:f:root:-:755
$daemon_directory/trivial-rewrite:f:root:-:755
$daemon_directory/virtual:f:root:-:755
$command_directory/postalias:f:root:-:755
$command_directory/postcat:f:root:-:755
$command_directory/postconf:f:root:-:755
$command_directory/postfix:f:root:-:755
$command_directory/postkick:f:root:-:755
$command_directory/postlock:f:root:-:755
$command_directory/postlog:f:root:-:755
$command_directory/postmap:f:root:-:755
$command_directory/postsuper:f:root:-:755
$command_directory/postdrop:f:root:$setgid_group:2755
$command_directory/postqueue:f:root:$setgid_group:2755
$sendmail_path:f:root:-:755
$newaliases_path:l:root:-:755
$mailq_path:l:root:-:755
$config_directory/LICENSE:f:root:-:644
$config_directory/access:f:root:-:644:p
$config_directory/aliases:f:root:-:644:p
$config_directory/canonical:f:root:-:644:p
$config_directory/main.cf:f:root:-:644:p
$config_directory/main.cf.default:f:root:-:644
$config_directory/master.cf:f:root:-:644:p
$config_directory/pcre_table:f:root:-:644:p
$config_directory/postfix-files:f:root:-:644
$config_directory/regexp_table:f:root:-:644:p
$config_directory/relocated:f:root:-:644:p
$config_directory/sample-aliases.cf:f:root:-:644
$config_directory/sample-auth.cf:f:root:-:644
$config_directory/sample-canonical.cf:f:root:-:644
$config_directory/sample-compatibility.cf:f:root:-:644
$config_directory/sample-debug.cf:f:root:-:644
$config_directory/sample-filter.cf:f:root:-:644
$config_directory/sample-flush.cf:f:root:-:644
$config_directory/sample-ldap.cf:f:root:-:644
$config_directory/sample-lmtp.cf:f:root:-:644
$config_directory/sample-local.cf:f:root:-:644
$config_directory/sample-misc.cf:f:root:-:644
$config_directory/sample-pcre-access.cf:f:root:-:644
$config_directory/sample-pcre-body.cf:f:root:-:644
$config_directory/sample-pcre-header.cf:f:root:-:644
$config_directory/sample-qmqpd.cf:f:root:-:644
$config_directory/sample-rate.cf:f:root:-:644
$config_directory/sample-regexp-access.cf:f:root:-:644
$config_directory/sample-regexp-body.cf:f:root:-:644
$config_directory/sample-regexp-header.cf:f:root:-:644
$config_directory/sample-relocated.cf:f:root:-:644
$config_directory/sample-resource.cf:f:root:-:644
$config_directory/sample-rewrite.cf:f:root:-:644
$config_directory/sample-smtp.cf:f:root:-:644
$config_directory/sample-smtpd.cf:f:root:-:644
$config_directory/sample-transport.cf:f:root:-:644
$config_directory/sample-virtual.cf:f:root:-:644
$config_directory/transport:f:root:-:644:p
$config_directory/virtual:f:root:-:644:p
$config_directory/postfix-script:f:root:-:755
$config_directory/post-install:f:root:-:755
$manpage_path/man1/mailq.1:f:root:-:644
$manpage_path/man1/newaliases.1:f:root:-:644
$manpage_path/man1/postalias.1:f:root:-:644
$manpage_path/man1/postcat.1:f:root:-:644
$manpage_path/man1/postconf.1:f:root:-:644
$manpage_path/man1/postdrop.1:f:root:-:644
$manpage_path/man1/postfix.1:f:root:-:644
$manpage_path/man1/postkick.1:f:root:-:644
$manpage_path/man1/postlock.1:f:root:-:644
$manpage_path/man1/postlog.1:f:root:-:644
$manpage_path/man1/postmap.1:f:root:-:644
$manpage_path/man1/postqueue.1:f:root:-:644
$manpage_path/man1/postsuper.1:f:root:-:644
$manpage_path/man1/sendmail.1:f:root:-:644
$manpage_path/man5/access.5:f:root:-:644
$manpage_path/man5/aliases.5:f:root:-:644
$manpage_path/man5/canonical.5:f:root:-:644
$manpage_path/man5/pcre_table.5:f:root:-:644
$manpage_path/man5/regexp_table.5:f:root:-:644
$manpage_path/man5/relocated.5:f:root:-:644
$manpage_path/man5/transport.5:f:root:-:644
$manpage_path/man5/virtual.5:f:root:-:644
$manpage_path/man8/bounce.8:f:root:-:644
$manpage_path/man8/cleanup.8:f:root:-:644
$manpage_path/man8/defer.8:f:root:-:644
$manpage_path/man8/error.8:f:root:-:644
$manpage_path/man8/flush.8:f:root:-:644
$manpage_path/man8/lmtp.8:f:root:-:644
$manpage_path/man8/local.8:f:root:-:644
$manpage_path/man8/master.8:f:root:-:644
$manpage_path/man8/nqmgr.8:f:root:-:644
$manpage_path/man8/pickup.8:f:root:-:644
$manpage_path/man8/pipe.8:f:root:-:644
$manpage_path/man8/qmgr.8:f:root:-:644
$manpage_path/man8/qmqpd.8:f:root:-:644
$manpage_path/man8/showq.8:f:root:-:644
$manpage_path/man8/smtp.8:f:root:-:644
$manpage_path/man8/smtpd.8:f:root:-:644
$manpage_path/man8/spawn.8:f:root:-:644
$manpage_path/man8/trivial-rewrite.8:f:root:-:644
$manpage_path/man8/virtual.8:f:root:-:644

View File

@ -9,12 +9,12 @@
# SUMMARY # SUMMARY
# Postfix installation procedure # Postfix installation procedure
# SYNOPSIS # SYNOPSIS
# sh postfix-install [-non-interactive] [name=value] ... # sh postfix-install [options] [name=value] ...
# DESCRIPTION # DESCRIPTION
# The postfix-install script is to be run from the top-level # The postfix-install script is to be run from the top-level
# Postfix source directory. It implements the following operations: # Postfix source directory. It implements the following operations:
# .IP o # .IP o
# Install or upgrade Postfix from source code. This mode requires # Install or upgrade Postfix from source code. This requires
# super-user privileges. # super-user privileges.
# .IP o # .IP o
# Build a package that can be distributed to other systems, in order # Build a package that can be distributed to other systems, in order
@ -27,8 +27,8 @@
# Specific parameters are described at the end of this document. # Specific parameters are described at the end of this document.
# #
# By default, postfix-install asks the user for installation # By default, postfix-install asks the user for installation
# parameter settings. Settings are stored in the installed # parameter settings. Most settings are stored in the installed
# main.cf file. These settings are used as site-specific defaults # main.cf file. Stored settings are used as site-specific defaults
# when the postfix-install script is run later. # when the postfix-install script is run later.
# #
# The names of Postfix files and directories, as well as their # The names of Postfix files and directories, as well as their
@ -41,20 +41,17 @@
# #
# Arguments # Arguments
# .IP -non-interactive # .IP -non-interactive
# Do not ask the user for parameter settings. This is useful for # Do not ask the user for parameter settings. Installation parameters
# upgrading an existing Postfix installation from source code, # are specified via one of the non-interactive methods described
# or for preparing a pre-built package for distribution to other # below.
# systems. Installation parameters must be specified via one of
# the non-interactive methods described below.
# INSTALLATION PARAMETER INPUT METHODS # INSTALLATION PARAMETER INPUT METHODS
# .ad # .ad
# .fi # .fi
# Parameter settings can be specified through a variety of # Parameter settings can be specified through a variety of
# mechanisms. In order of decreasing precedence these are: # mechanisms. In order of decreasing precedence these are:
# .IP "interactive mode" # .IP "interactive mode"
# By default, postfix-install will ask the user for # By default, postfix-install will ask the user for installation
# installation parameter settings. These settings have the highest # parameter settings. These settings have the highest precedence.
# precedence.
# .IP "command line" # .IP "command line"
# Parameter settings can be given as name=value arguments on # Parameter settings can be given as name=value arguments on
# the postfix-install command line. # the postfix-install command line.
@ -77,54 +74,65 @@
# Prefix that is prepended to the pathnames of installed files. # Prefix that is prepended to the pathnames of installed files.
# This is useful for creating a pre-built package for distribution to # This is useful for creating a pre-built package for distribution to
# other systems. The built-in default is "/", the local root directory. # other systems. The built-in default is "/", the local root directory.
# This parameter setting is not recorded in the installed main.cf file.
# .IP tempdir # .IP tempdir
# Directory for scratch files while installing Postfix. # Directory for scratch files while installing Postfix.
# You must must have write permission in this directory. # You must must have write permission in this directory.
# The built-in default directory name is the current directory. # The built-in default directory name is the current directory.
# This parameter setting is not recorded in the installed main.cf file.
# .IP config_directory # .IP config_directory
# Destination directory for Postfix configuration files. The # The destination directory for Postfix configuration files.
# built-in default directory name is /etc/postfix. # The built-in default directory name is /etc/postfix.
# This parameter setting is not recorded in the installed main.cf file.
# .IP daemon_directory # .IP daemon_directory
# Destination directory for Postfix daemon programs. This directory # The destination directory for Postfix daemon programs. This directory
# should not be in the command search path of any users. The built-in # should not be in the command search path of any users.
# default directory name is /usr/libexec/postfix. # The built-in default directory name is /usr/libexec/postfix.
# .IP command_directory # .IP command_directory
# Destination directory for Postfix administrative commands. This # The destination directory for Postfix administrative commands. This
# directory should be in the command search path of adminstrative users. # directory should be in the command search path of adminstrative users.
# The built-in default directory name is system dependent. # The built-in default directory name is system dependent.
# This parameter setting is recorded in the installed main.cf file.
# .IP queue_directory # .IP queue_directory
# The destination directory for Postfix queues. The built-in default # The destination directory for Postfix queues.
# directory name is /var/spool/postfix. # The built-in default directory name is /var/spool/postfix.
# This parameter setting is recorded in the installed main.cf file.
# .IP sendmail_path # .IP sendmail_path
# The full destination pathname for the Postfix sendmail command. # The full destination pathname for the Postfix sendmail command.
# This is the Sendmail-compatible mail posting interface. # This is the Sendmail-compatible mail posting interface.
# The built-in default pathname is system dependent. # The built-in default pathname is system dependent.
# This parameter setting is recorded in the installed main.cf file.
# .IP newaliases_path # .IP newaliases_path
# The full destination pathname for the Postfix newaliases command. # The full destination pathname for the Postfix newaliases command.
# This is the Sendmail-compatible command to build alias databases # This is the Sendmail-compatible command to build alias databases
# for the Postfix local delivery agent. # for the Postfix local delivery agent.
# The built-in default pathname is system dependent. # The built-in default pathname is system dependent.
# This parameter setting is recorded in the installed main.cf file.
# .IP mailq_path # .IP mailq_path
# The full destination pathname for the Postfix mailq command. # The full destination pathname for the Postfix mailq command.
# This is the Sendmail-compatible command to list the mail queue. # This is the Sendmail-compatible command to list the mail queue.
# The built-in default pathname is system dependent. # The built-in default pathname is system dependent.
# This parameter setting is recorded in the installed main.cf file.
# .IP mail_owner # .IP mail_owner
# The owner of the Postfix queue. Its numerical user ID and group ID # The owner of the Postfix queue. Its numerical user ID and group ID
# must not be used by any other accounts on the system. The built-in # must not be used by any other accounts on the system.
# default account name is postfix. # The built-in default account name is postfix.
# This parameter setting is recorded in the installed main.cf file.
# .IP setgid_group # .IP setgid_group
# The group for mail submission and for queue management commands. # The group for mail submission and for queue management commands.
# Its numerical group ID must not be used by any other accounts on the # Its numerical group ID must not be used by any other accounts on the
# system, not even by the mail_owner account. The built-in default group # system, not even by the mail_owner account.
# name is postdrop. # The built-in default group name is postdrop.
# This parameter setting is recorded in the installed main.cf file.
# .IP manpage_path # .IP manpage_path
# The destination directory for the Postfix on-line manual pages. # The destination directory for the Postfix on-line manual pages.
# This parameter setting is recorded in the installed main.cf file.
# SEE ALSO # SEE ALSO
# post-install(1) post-installation procedure # post-install(1) post-installation procedure
# FILES # FILES
# $config_directory/main.cf, Postfix installation configuration. # $config_directory/main.cf, Postfix installation configuration.
# $config_directory/postfix-files, permissions and ownerships. # $config_directory/postfix-files, installation control file.
# This file is created by postfix-install. # $config_directory/install.cf, obsolete configuration file.
# LICENSE # LICENSE
# .ad # .ad
# .fi # .fi
@ -144,18 +152,22 @@ PATH=/bin:/usr/bin:/usr/sbin:/usr/etc:/sbin:/etc:/usr/contrib/bin:/usr/gnu/bin:/
SHELL=/bin/sh SHELL=/bin/sh
IFS=" IFS="
" "
BACKUP_IFS="$IFS"
USAGE="Usage: $0 [name=value] [option]
-non-interactive Do not ask for installation parameters.
name=value Specify an installation parameter".
# Process command-line options and parameter settings. Work around # Process command-line options and parameter settings. Work around
# brain damaged shells. "name=value command" should not make the # brain damaged shells. "IFS=value command" should not make the
# name=value setting permanent. # IFS=value setting permanent. But some broken standard allows it.
for arg for arg
do do
case $arg in case $arg in
*=*) SAVED_IFS="$IFS"; IFS= eval $arg; IFS="$SAVED_IFS";; *=*) IFS= eval $arg; IFS="$BACKUP_IFS";;
-non-interactive) non_interactive=1;; -non-int*) non_interactive=1;;
*) echo Error: usage: $0 [-non-interactive] name=value ... 1>&2 *) echo $0: Error: $USAGE 1>&2; exit 1;;
exit 1;;
esac esac
shift shift
done done
@ -163,12 +175,12 @@ done
# Sanity checks. # Sanity checks.
test -z "$non_interactive" -a ! -t 0 && { test -z "$non_interactive" -a ! -t 0 && {
echo Error: for non-interactive use, run: \"$0 -non-interactive\" 1>&2 echo $0: Error: for non-interactive use, run: \"$0 -non-interactive\" 1>&2
exit 1 exit 1
} }
test -x bin/postconf || { test -x bin/postconf || {
echo Error: no bin/postconf file. Did you forget to run \"make\"? 1>&2 echo $0: Error: no bin/postconf file. Did you forget to run \"make\"? 1>&2
exit 1 exit 1
} }
@ -197,20 +209,20 @@ EOF
# when upgrading Postfix on a live machine. It also avoids surprises # when upgrading Postfix on a live machine. It also avoids surprises
# when building a Postfix package for distribution to other systems. # when building a Postfix package for distribution to other systems.
censored_ls() {
ls "$@" | egrep -v '^\.|/\.|CVS|RCS|SCCS'
}
compare_or_replace() { compare_or_replace() {
(cmp $2 $3 >/dev/null 2>&1 && echo Skipping $3...) || { mode=$1
echo Updating $3... owner=$2
group=$3
src=$4
dst=$5
(cmp $src $dst >/dev/null 2>&1 && echo Skipping $dst...) || {
echo Updating $dst...
rm -f $tempdir/junk || exit 1 rm -f $tempdir/junk || exit 1
cp $2 $tempdir/junk || exit 1 cp $src $tempdir/junk || exit 1
test -z "$4" || chgrp $4 $tempdir/junk || exit 1 mv -f $tempdir/junk $dst || exit 1
chmod $1 $tempdir/junk || exit 1 test -z "$owner" || chown $owner $dst || exit 1
mv -f $tempdir/junk $3 || exit 1 test -z "$group" || chgrp $group $dst || exit 1
test -z "$4" || chgrp $4 $3 || exit 1 chmod $mode $dst || exit 1
chmod $1 $3 || exit 1
} }
} }
@ -235,7 +247,7 @@ compare_or_symlink() {
'` '`
ln -s $link $tempdir/junk || exit 1 ln -s $link $tempdir/junk || exit 1
mv -f $tempdir/junk $2 || { mv -f $tempdir/junk $2 || {
echo Error: your mv command is unable to rename symlinks. 1>&2 echo $0: Error: your mv command is unable to rename symlinks. 1>&2
echo If you run Linux, upgrade to GNU fileutils-4.0 or better, 1>&2 echo If you run Linux, upgrade to GNU fileutils-4.0 or better, 1>&2
echo or choose a tempdir that is in the same file system as $2. 1>&2 echo or choose a tempdir that is in the same file system as $2. 1>&2
exit 1 exit 1
@ -243,12 +255,12 @@ compare_or_symlink() {
} }
} }
compare_or_move() { check_parent() {
(cmp $2 $3 >/dev/null 2>&1 && echo Skipping $3...) || { for path
echo Updating $3... do
mv -f $2 $3 || exit 1 dir=`echo $path|sed -e 's/[/][/]*[^/]*$//' -e 's/^$/\//'`
chmod $1 $3 || exit 1 test -d $dir || mkdir -p $dir || exit 1
} done
} }
# How to supress newlines in echo. # How to supress newlines in echo.
@ -325,8 +337,8 @@ do
case $ans in case $ans in
"") break;; "") break;;
*) case $ans in *) case $ans in
/*) eval $name=\$ans; break;; /*) eval $name=$ans; break;;
*) echo; echo Error: $name should be an absolute path name. 1>&2;; *) echo; echo $0: Error: $name should be an absolute path name. 1>&2;;
esac;; esac;;
esac esac
done done
@ -343,76 +355,41 @@ CONFIG_DIRECTORY=$install_root$config_directory
# If a parameter is not set via the command line or environment, # If a parameter is not set via the command line or environment,
# try to use settings from installed configuration files. # try to use settings from installed configuration files.
# Extract parameter settings from the installed main.cf file. # Extract parameter settings from the obsolete install.cf file, as
# a transitional aid.
test -f $CONFIG_DIRECTORY/main.cf && {
for name in daemon_directory command_directory queue_directory mail_owner \
setgid_group sendmail_path newaliases_path mailq_path manpage_path
do
eval : \${$name=\`bin/postconf -c $CONFIG_DIRECTORY -h $name\`} || kill $$
done
}
# Grandfathering: some parameters used to be stored in install.cf.
# They are now part of main.cf. Some names have changed as well.
grep setgid_group $CONFIG_DIRECTORY/main.cf >/dev/null 2>&1 || { grep setgid_group $CONFIG_DIRECTORY/main.cf >/dev/null 2>&1 || {
test -f $CONFIG_DIRECTORY/install.cf && { test -f $CONFIG_DIRECTORY/install.cf && {
for name in sendmail_path newaliases_path mailq_path setgid manpages for name in sendmail_path newaliases_path mailq_path setgid manpages
do do
eval : \${$name=`. $CONFIG_DIRECTORY/install.cf; echo \$name`} eval : \${$name="\`. $CONFIG_DIRECTORY/install.cf; echo \$$name\`"} \
|| exit 1
done done
: ${setgid_group=$setgid} : ${setgid_group=$setgid}
: ${manpage_path=$manpages} : ${manpage_path=$manpages}
} }
} }
# Find out what parameters were not specified via command line, # Extract parameter settings from the installed main.cf file.
# via environment, or via installed configuration files.
missing= test -f $CONFIG_DIRECTORY/main.cf && {
for name in daemon_directory command_directory queue_directory mail_owner \ for name in daemon_directory command_directory queue_directory mail_owner \
setgid_group sendmail_path newaliases_path mailq_path manpage_path setgid_group sendmail_path newaliases_path mailq_path manpage_path
do do
eval test -n \"\$$name\" || missing="$missing $name" eval : \${$name=\`bin/postconf -c $CONFIG_DIRECTORY -h $name\`} ||
done
# In the case of non-interactive installation, all parameters must
# be specified at this point.
test -n "$non_interactive" -a -n "$missing" && {
cat <<EOF | ${FMT} 1>&2
Error: non-interactive installation requires that all parameters
be specified ahead of time.
- Either the parameters must be given in the $CONFIG_DIRECTORY/main.cf
file from a recent Postfix installation,
- Or the parameters need to be specified as name=value arguments
on the $0 command line,
- Or the parameters need to be specified through the process
environment.
The following parameters were missing:
$missing
For interactive installation use "make install".
EOF
exit 1 exit 1
done
} }
# Use built-in defaults for parameters that weren't set via the # Use built-in defaults as the final source of parameter settings.
# environment, via the command line, or via installed configuration
# files.
for name in $missing for name in daemon_directory command_directory queue_directory mail_owner \
setgid_group sendmail_path newaliases_path mailq_path manpage_path
do do
eval : \${$name=\`bin/postconf -d -h $name\`} || kill $$ eval : \${$name=\`bin/postconf -d -h $name\`} || exit 1
done done
# Override default settings. # Override settings manually.
test -z "$non_interactive" && for name in daemon_directory command_directory \ test -z "$non_interactive" && for name in daemon_directory command_directory \
queue_directory sendmail_path newaliases_path mailq_path mail_owner \ queue_directory sendmail_path newaliases_path mailq_path mail_owner \
@ -426,21 +403,27 @@ do
read ans read ans
case $ans in case $ans in
"") break;; "") break;;
*) eval $name=\$ans; break;; *) eval $name=$ans; break;;
esac esac
done done
done done
# Sanity checks # Sanity checks
case $manpage_path in case $setgid_group in
no) echo Error: manpage_path no longer accepts \"no\" values. 1>&2 no) echo $0: Error: the setgid_group parameter no longer accepts 1>&2
echo Re-run this script with \"make install\". 1>&2; exit 1;; echo \"no\" values. Try again with \"setgid_group=groupname\" on the 1>&2
echo command line or execute \"make install\" and specify setgid_group 1>&2
echo interactively. 1>&2
exit 1;;
esac esac
case $setgid_group in case $manpage_path in
no) echo Error: setgid_group no longer accepts \"no\" values. 1>&2 no) echo $0: Error: the manpage_path parameter no longer accepts 1>&2
echo Re-run this script with \"make install\". 1>&2; exit 1;; echo \"no\" values. Try again with \"manpage_path=/path/name\" on the 1>&2
echo command line or execute \"make install\" and specify manpage_path 1>&2
echo interactively. 1>&2
exit 1;;
esac esac
for path in $daemon_directory $command_directory \ for path in $daemon_directory $command_directory \
@ -448,19 +431,44 @@ for path in $daemon_directory $command_directory \
do do
case $path in case $path in
/*) ;; /*) ;;
*) echo Error: $path should be an absolute path name. 1>&2; exit 1;; *) echo $0: Error: $path should be an absolute path name. 1>&2; exit 1;;
esac esac
done done
test -d $tempdir || mkdir -p $tempdir || exit 1 test -d $tempdir || mkdir -p $tempdir || exit 1
trap "rm -f $tempdir/junk" 0 1 2 3 15
( rm -f $tempdir/junk && touch $tempdir/junk ) || { ( rm -f $tempdir/junk && touch $tempdir/junk ) || {
echo Error: you have no write permission to $tempdir. 1>&2 echo $0: Error: you have no write permission to $tempdir. 1>&2
echo Specify an alternative directory for scratch files. 1>&2 echo Specify an alternative directory for scratch files. 1>&2
exit 1 exit 1
} }
rm -f $tempdir/junk test -z "$install_root" && {
chown root $tempdir/junk >/dev/null 2>&1 || {
echo Error: you have no permission to change file ownership. 1>&2
exit 1
}
chown "$mail_owner" $tempdir/junk >/dev/null 2>&1 || {
echo $0: Error: $mail_owner needs an entry in the passwd file. 1>&2
echo Remember, $mail_owner needs a dedicated user id and group id. 1>&2
exit 1
}
chgrp "$setgid_group" $tempdir/junk >/dev/null 2>&1 || {
echo $0: Error: $setgid needs an entry in the group file. 1>&2
echo Remember, $setgid needs a dedicated group id. 1>&2
exit 1
}
}
rm -f $tempdir/junk || exit 1
trap 0 1 2 3 15
# Avoid clumsiness. # Avoid clumsiness.
@ -472,152 +480,122 @@ NEWALIASES_PATH=$install_root$newaliases_path
MAILQ_PATH=$install_root$mailq_path MAILQ_PATH=$install_root$mailq_path
MANPAGE_PATH=$install_root$manpage_path MANPAGE_PATH=$install_root$manpage_path
# Create any missing directories. # Avoid repeated tests for existence of these.
test -d $CONFIG_DIRECTORY || mkdir -p $CONFIG_DIRECTORY || exit 1
test -d $DAEMON_DIRECTORY || mkdir -p $DAEMON_DIRECTORY || exit 1 test -d $DAEMON_DIRECTORY || mkdir -p $DAEMON_DIRECTORY || exit 1
test -d $COMMAND_DIRECTORY || mkdir -p $COMMAND_DIRECTORY || exit 1 test -d $COMMAND_DIRECTORY || mkdir -p $COMMAND_DIRECTORY || exit 1
test -d $QUEUE_DIRECTORY || mkdir -p $QUEUE_DIRECTORY || exit 1
for path in $SENDMAIL_PATH $NEWALIASES_PATH $MAILQ_PATH
do
dir=`echo $path|sed -e 's/[/][/]*[^/]*$//' -e 's/^$/\//'`
test -d $dir || mkdir -p $dir || exit 1
done
# Install files. Keep a record of pathnames, ownerships and permissions # Upgrade or first-time installation?
# so that "postfix check" and "post-install" can do the right thing.
# If building a package for distribution to other systems, don't
# enable execute permission.
if [ -n "$install_root" ]
then
EXE=644
else
EXE=755
fi
cat <<EOF >$CONFIG_DIRECTORY/postfix-files || exit 1
#
# Do not edit. This file was generated by $0.
#
# Do not list \$command_directory here, or it will be blown
# away by a future Postfix uninstallation procedure.
#
# File format:
# name:type:owner:group:permission:upgrade:create
# No group means don't change group ownership.
#
# File flags:
# No flag means the flag is not active.
# update=update owner/group/mode (upgrade mode).
# create=create missing directory.
#
\$config_directory:d:root::755:u
\$daemon_directory:d:root::755:u
\$queue_directory:d:root::755:u:c
EOF
# Generate instructions only for queue subdirectories.
for dir in active bounce corrupt defer deferred flush incoming private saved
do
echo \$queue_directory/$dir:d:\$mail_owner::700:u:c \
>>$CONFIG_DIRECTORY/postfix-files || exit 1
done
echo \$queue_directory/maildrop:d:\$mail_owner:\$setgid_group:730:u:c \
>>$CONFIG_DIRECTORY/postfix-files || exit 1
echo \$queue_directory/public:d:\$mail_owner:\$setgid_group:710:u:c \
>>$CONFIG_DIRECTORY/postfix-files || exit 1
echo \$queue_directory/pid:d:root::755:u:c \
>>$CONFIG_DIRECTORY/postfix-files || exit 1
# Install daemon programs.
for file in `censored_ls libexec`
do
compare_or_replace $EXE libexec/$file $DAEMON_DIRECTORY/$file || exit 1
echo \$daemon_directory/$file:f:root::755 \
>>$CONFIG_DIRECTORY/postfix-files || exit 1
done
# Install administrative commands.
for file in `censored_ls bin | grep '^post' | egrep -v '^post(drop|queue)$'`
do
compare_or_replace $EXE bin/$file $COMMAND_DIRECTORY/$file || exit 1
echo \$command_directory/$file:f:root::755 \
>>$CONFIG_DIRECTORY/postfix-files || exit 1
done
# Don't set privilege bits when building a package for distribution
# to other systems.
if [ -n "$install_root" ]
then
for file in postdrop postqueue
do
compare_or_replace $EXE bin/$file $COMMAND_DIRECTORY/$file || exit 1
echo \$command_directory/$file:f:root:\$setgid_group:2755 \
>>$CONFIG_DIRECTORY/postfix-files || exit 1
done
else
for file in postdrop postqueue
do
compare_or_replace 2$EXE bin/$file $COMMAND_DIRECTORY/$file postdrop \
|| exit 1
echo \$command_directory/$file:f:root:\$setgid_group:2755 \
>>$CONFIG_DIRECTORY/postfix-files || exit 1
done
fi
# Install the Sendmail-compatible user interface.
test -f bin/sendmail && {
compare_or_replace $EXE bin/sendmail $SENDMAIL_PATH || exit 1
compare_or_symlink $SENDMAIL_PATH $NEWALIASES_PATH
compare_or_symlink $SENDMAIL_PATH $MAILQ_PATH
cat <<EOF >>$CONFIG_DIRECTORY/postfix-files || exit 1
\$sendmail_path:f:root::755
\$newaliases_path:f:root::755
\$mailq_path:f:root::755
EOF
}
# Preserve installed configuration files. Update scripts, license, samples.
if [ -f $CONFIG_DIRECTORY/main.cf ] if [ -f $CONFIG_DIRECTORY/main.cf ]
then then
for file in LICENSE `cd conf; censored_ls sample*` main.cf.default post_install_options="upgrade-source"
do
compare_or_replace 644 conf/$file $CONFIG_DIRECTORY/$file || exit 1
done
else else
for file in `censored_ls conf | egrep -v '^(postfix-script|post-install)$'` post_install_options="first-install"
do
compare_or_replace 644 conf/$file $CONFIG_DIRECTORY/$file || exit 1
done
test -z "$install_root" && need_config="create-missing first-install"
fi fi
for file in `censored_ls conf | egrep -v 'postfix-script|post-install'` # Install files, using information from the postfix-files file.
exec < conf/postfix-files || exit 1
while IFS=: read path type owner group mode flags junk
do do
echo \$config_directory/$file:f:root::644 \ IFS="$BACKUP_IFS"
>>$CONFIG_DIRECTORY/postfix-files || exit 1
# Skip comments.
case $path in
[$]*) ;;
*) continue;;
esac
# Skip over files that must be preserved.
case $flags in
*p*) eval test -f $install_root$path && {
eval echo "Skipping $install_root$path..."
continue
};;
esac
# If installing from source code, apply special permissions or ownership.
# If building a package, don't apply special permissions or ownership.
case $install_root in
"") case $owner in
[$]*) eval owner=$owner;;
root) owner=;;
esac
case $group in
[$]*) eval group=$group;;
-) group=;;
esac;;
*) case $mode in
[1-7]755) mode=755;;
esac
owner=
group=;;
esac
# Create directory.
case $type in
d) eval path=$install_root$path
test -d $path || {
mkdir -p $path || exit 1
test -z "$owner" || chown $owner $path || exit 1
test -z "$group" || chgrp $group $path || exit 1
chmod $mode $path || exit 1
}
continue;;
[fl]) ;;
*) echo $0: Error: unknown type for $path in conf/postfix-files; exit 1;;
esac
# Install or replace file.
echo $path | (IFS=/ read prefix file; IFS="$BACKUP_IFS"
case $prefix in
'$daemon_directory')
compare_or_replace $mode "$owner" "$group" libexec/$file \
$DAEMON_DIRECTORY/$file || exit 1;;
'$command_directory')
compare_or_replace $mode "$owner" "$group" bin/$file \
$COMMAND_DIRECTORY/$file || exit 1;;
'$config_directory')
compare_or_replace $mode "$owner" "$group" conf/$file \
$CONFIG_DIRECTORY/$file || exit 1;;
'$sendmail_path')
check_parent $SENDMAIL_PATH || exit 1
compare_or_replace $mode "$owner" "$group" bin/sendmail \
$SENDMAIL_PATH || exit 1;;
'$mailq_path')
check_parent $MAILQ_PATH || exit 1
compare_or_symlink $SENDMAIL_PATH $MAILQ_PATH || exit 1;;
'$newaliases_path')
check_parent $NEWALIASES_PATH || exit 1
compare_or_symlink $SENDMAIL_PATH $NEWALIASES_PATH || exit 1;;
'$manpage_path')
check_parent $MANPAGE_PATH/$file || exit 1
compare_or_replace 644 "$owner" "$group" man/$file \
$MANPAGE_PATH/$file || exit 1;;
*) echo $0: Error: unknown entry $path in conf/postfix-files; exit 1;;
esac) || exit 1
done done
for file in postfix-script post-install # If Postfix is being installed locally from source code, do the
do # post-install processing now. The post-install script will update
compare_or_replace $EXE conf/$file $CONFIG_DIRECTORY/$file || exit 1 # main.cf with actual installaton parameter settings.
echo \$config_directory/$file:f:root::755 \ #
>>$CONFIG_DIRECTORY/postfix-files || exit 1 # If Postfix is being packaged for distribution to other systems,
done # save the installation parameters to main.cf so they can be used
# as default settings when the post-install script is executed.
# Save settings.
if [ -z "$install_root" ]
then
export daemon_directory command_directory queue_directory mail_owner \
setgid_group sendmail_path newaliases_path mailq_path manpage_path
${SHELL} conf/post-install $post_install_options || exit 1
else
bin/postconf -c $CONFIG_DIRECTORY -e \ bin/postconf -c $CONFIG_DIRECTORY -e \
"daemon_directory = $daemon_directory" \ "daemon_directory = $daemon_directory" \
"command_directory = $command_directory" \ "command_directory = $command_directory" \
@ -629,26 +607,4 @@ bin/postconf -c $CONFIG_DIRECTORY -e \
"newaliases_path = $newaliases_path" \ "newaliases_path = $newaliases_path" \
"manpage_path = $manpage_path" \ "manpage_path = $manpage_path" \
|| exit 1 || exit 1
fi
# Install manual pages.
(cd man || exit 1
for dir in man?
do test -d $MANPAGE_PATH/$dir || mkdir -p $MANPAGE_PATH/$dir || exit 1
done
for file in `censored_ls man?/*`
do
compare_or_replace 644 $file $MANPAGE_PATH/$file || exit 1
echo \$manpage_path/$file:f:root::644 \
>>$CONFIG_DIRECTORY/postfix-files || exit 1
done)
# If Postfix is being installed locally from source code, as opposed to
# being packaged for distribution to other systems, do the post-install
# processing now.
test -n "$install_root" && exit 0
export command_directory config_directory
${SHELL} conf/post-install ${need_config-"upgrade-source"}

View File

@ -15,7 +15,7 @@
* Version of this program. * Version of this program.
*/ */
#define VAR_MAIL_VERSION "mail_version" #define VAR_MAIL_VERSION "mail_version"
#define DEF_MAIL_VERSION "Snapshot-20020112" #define DEF_MAIL_VERSION "Snapshot-20020113"
extern char *var_mail_version; extern char *var_mail_version;
/* LICENSE /* LICENSE

View File

@ -92,7 +92,7 @@ int var_dup_filter_limit;
#define STRING_FORMAT "%-10s %8s %-20s %s\n" #define STRING_FORMAT "%-10s %8s %-20s %s\n"
#define DATA_FORMAT "%-10s%c%8ld %20.20s %s\n" #define DATA_FORMAT "%-10s%c%8ld %20.20s %s\n"
#define DROP_FORMAT "%-10s%c%8ld %20.20s (maildrop queue, sender UID %d)\n" #define DROP_FORMAT "%-10s%c%8ld %20.20s (maildrop queue, sender UID %u)\n"
static void showq_reasons(VSTREAM *, BOUNCE_LOG *, HTABLE *); static void showq_reasons(VSTREAM *, BOUNCE_LOG *, HTABLE *);
@ -278,7 +278,7 @@ static void showq_service(VSTREAM *client, char *unused_service, char **argv)
vstream_fprintf(client, DROP_FORMAT, id, ' ', vstream_fprintf(client, DROP_FORMAT, id, ' ',
(long) st.st_size, (long) st.st_size,
asctime(localtime(&st.st_mtime)), asctime(localtime(&st.st_mtime)),
st.st_uid); (unsigned) st.st_uid);
} else if (errno != ENOENT) } else if (errno != ENOENT)
msg_fatal("open %s %s: %m", qp->name, id); msg_fatal("open %s %s: %m", qp->name, id);
file_count++; file_count++;

View File

@ -225,9 +225,9 @@ int deliver_mailbox(LOCAL_STATE state, USER_ATTR usr_attr, int *statusp)
usr_attr.gid = (gid_t) n; usr_attr.gid = (gid_t) n;
if (msg_verbose) if (msg_verbose)
msg_info("%s[%d]: set user_attr: %s, uid = %d, gid = %d", msg_info("%s[%d]: set user_attr: %s, uid = %u, gid = %u",
myname, state.level, myname, state.level, usr_attr.mailbox,
usr_attr.mailbox, usr_attr.uid, usr_attr.gid); (unsigned) usr_attr.uid, (unsigned) usr_attr.gid);
/* /*
* Deliver to mailbox or to external command. * Deliver to mailbox or to external command.