Estou tentando configurar a Postfix
partir do Entware (um repositório para dispositivos incorporados).
Não há SElinux envolvido e o chroot está desabilitado no master.cf.
# postconf -n
command_directory = /opt/sbin
compatibility_level = 2
config_directory = /opt/etc/postfix
daemon_directory = /opt/libexec/postfix
data_directory = /opt/var/lib/postfix
debug_peer_level = 2
debugger_command = PATH=/bin:/usr/bin:/usr/local/bin:/usr/X11R6/bin ddd $daemon_directory/$process_name $process_id & sleep 5
default_database_type = cdb
inet_protocols = ipv4
mail_spool_directory = /opt/var/mail
manpage_directory = no
myhostname = domain.nl
mynetworks = 1.1.2.1,8.9.1.1
queue_directory = /opt/var/spool/postfix
shlib_directory = /opt/lib/postfix
smtputf8_enable = no
unknown_local_recipient_reject_code = 550
O problema é que postfix set-permissions
não é capaz de descobrir o root
nome de usuário. Esta distribuição vem por padrão com um usuário "root" chamado "admin". Pelo menos eu acho que o nome de usuário é o problema, por causa de:
# postfix set-permissions
find: unknown user root
# ls -lah /opt/sbin/postdrop
-rwxr-xr-x 1 NewRootUser root 246.8K Sep 8 22:33 /opt/sbin/postdrop
Regressão
Com a ajuda de https://wiki.zimbra.com/wiki/Steps_to_fix_permission_and_ownership_of_Postfix_binaries_manually_due_to_bug_on_zmfixperm tenta-se corrigir as diferenças ( 755
já estava definido):
# chown AdminUserName:postdrop /opt/sbin/postdrop
# chown AdminUserName:postdrop /opt/sbin/postqueue
# chmod g+s /opt/sbin/postdrop
# chmod g+s /opt/sbin/postqueue
Resultado:
# postfix check
postsuper: fatal: scan_dir_push: open directory defer: Permission denied
Pergunta
Como fazer postfix set-permissions
aprender o new root
nome de usuário?
Ou como fazer manualmente os passos que postfix set-permissions
deve fazer?
Ou onde no código-fonte do postfix se pode encontrar as ações que são executadas para sinalizar set-permissions
?
Aplicativos que esperam e usam nome de usuário
root
falharão compreensivelmente quando não houver tal usuário no sistema. No entanto, você pode ter mais de um usuário com o mesmo UID. Normalmente, você provavelmente não deve configurar o sistema com vários nomes de usuário com o mesmo UID, da mesma forma que você não deve renomearroot
o usuário.Você pode adicionar outra conta UID 0, que tenha o nome de usuário
root
. Isso possivelmente resolve problemas com aplicativos que usam nomes de usuário em vez de UIDs numéricos. Para adicionar um aliasroot
para UID 0 com senha e login desabilitados, anexe o seguinte a/etc/passwd
:A sintaxe completa é explicada em
man 5 passwd
.Primeiro, deixe-me repetir o ponto de vista de que renomear o
root
usuário é uma má ideia. Dito isto, se você está determinado a fazê-lo ...O comando
postfix set-permissions
parece ser tratado porpostfix/conf/postfix-script
, que por sua vez chamapost-install create-missing
:https://github.com/vdukhovni/postfix/blob/bfff4380a3b6fac2513c73531ee3a79212c08660/postfix/conf/postfix-script#L376
https://github.com/vdukhovni/postfix/blob/bfff4380a3b6fac2513c73531ee3a79212c08660/postfix/conf/post-install#L245
Você pode ter que pesquisar no repositório
"root"
e ajustar qualquer coisa que espere que o nome de usuário do administrador seja "root":https://github.com/vdukhovni/postfix/search?p=3&q=root&unscoped_q=root