* Wed Sep 11 2024 Jean-Philippe Pialasse <jpp@koozali.org> 11.0.0-8.sme
- merge dovecot-extra [SME: 12735]
This commit is contained in:
1
root/etc/e-smith/db/configuration/defaults/sieve/TCPPort
Normal file
1
root/etc/e-smith/db/configuration/defaults/sieve/TCPPort
Normal file
@@ -0,0 +1 @@
|
||||
4190
|
1
root/etc/e-smith/db/configuration/defaults/sieve/access
Normal file
1
root/etc/e-smith/db/configuration/defaults/sieve/access
Normal file
@@ -0,0 +1 @@
|
||||
private
|
1
root/etc/e-smith/db/configuration/defaults/sieve/status
Normal file
1
root/etc/e-smith/db/configuration/defaults/sieve/status
Normal file
@@ -0,0 +1 @@
|
||||
enabled
|
1
root/etc/e-smith/db/configuration/defaults/sieve/type
Normal file
1
root/etc/e-smith/db/configuration/defaults/sieve/type
Normal file
@@ -0,0 +1 @@
|
||||
service
|
@@ -0,0 +1 @@
|
||||
enabled
|
89
root/etc/e-smith/events/actions/dovecot-acl
Normal file
89
root/etc/e-smith/events/actions/dovecot-acl
Normal file
@@ -0,0 +1,89 @@
|
||||
#!/usr/bin/perl -w
|
||||
|
||||
|
||||
use esmith::ConfigDB;
|
||||
use esmith::AccountsDB;
|
||||
use File::Find;
|
||||
|
||||
my $c = esmith::ConfigDB->open || die "Couldn't open ConfigDB\n";
|
||||
my $a = esmith::AccountsDB->open_ro || die "Couldn't open AccountsdDB\n";
|
||||
|
||||
my $dovecot = $c->get('dovecot');
|
||||
|
||||
die "couldn't find dovecot service\n" unless ($dovecot);
|
||||
|
||||
my $event = $ARGV[0];
|
||||
|
||||
# SharedMailboxes disabled ?
|
||||
if (($dovecot->prop('SharedMailbox') || 'disabled') eq 'disabled'){
|
||||
if (($dovecot->prop('SharedMailboxAcl') || 'yes') ne 'no'){
|
||||
foreach my $user ($a->users){
|
||||
my $name = $user->key;
|
||||
die "Error removing SharedMailbox ACLs ($name"."'s Maildir)\n" unless (
|
||||
system('/usr/bin/setfacl',
|
||||
'-R',
|
||||
'-x',
|
||||
'g:sharedmailbox',
|
||||
"/home/e-smith/files/users/$name") == 0 &&
|
||||
system('/bin/chmod',
|
||||
'-R',
|
||||
'g-s',
|
||||
"/home/e-smith/files/users/$name/Maildir") == 0
|
||||
);
|
||||
}
|
||||
}
|
||||
$dovecot->set_prop('SharedMailboxAcl','no');
|
||||
exit(0);
|
||||
}
|
||||
|
||||
# If SharedMailbox is enabled
|
||||
|
||||
# Set the correct ACL during user creation
|
||||
if ($event && $event eq 'user-create'){
|
||||
my $user = $ARGV[1];
|
||||
set_acl($user);
|
||||
}
|
||||
|
||||
if (($dovecot->prop('SharedMailboxAcl') || 'no') ne 'yes'){
|
||||
# ACL for existing users haven't been set yet
|
||||
foreach my $user ($a->users){
|
||||
my $name = $user->key;
|
||||
set_acl($name);
|
||||
}
|
||||
$dovecot->set_prop('SharedMailboxAcl','yes');
|
||||
}
|
||||
|
||||
# Set ACL on a user's Maildir
|
||||
sub set_acl {
|
||||
my $user = shift;
|
||||
die "Missing username\n" unless ($user);
|
||||
die "Couldn't find $user"."'s home dir\n" unless (-e "/home/e-smith/files/users/$user");
|
||||
find(\&dirperm, "/home/e-smith/files/users/$user/Maildir");
|
||||
die "Error applying permissions to $user 's Maildir\n" unless (
|
||||
# sharedmailbox group needs read / write access on Maildir
|
||||
system('/usr/bin/setfacl',
|
||||
'-R',
|
||||
'-m',
|
||||
'u::rwX,g::rwX,o::rX,g:sharedmailbox:rwX,d:u::rwX,d:g::rwX,d:g:sharedmailbox:rwX,d:o::rX',
|
||||
"/home/e-smith/files/users/$user/Maildir") == 0 &&
|
||||
# Grant sharedmailbox group permission to go through
|
||||
# the home dir so it can access the Maildir, but don't let it read
|
||||
# anything (except the Maildir)
|
||||
system('/usr/bin/setfacl',
|
||||
'-m',
|
||||
'g:sharedmailbox:x',
|
||||
"/home/e-smith/files/users/$user") == 0
|
||||
);
|
||||
}
|
||||
|
||||
# The kernel will handle group perms when a user
|
||||
# create a dir in another user's Maildir (if IMAP ACL allows it)
|
||||
# This will prevent dovecot errors, see
|
||||
# http://wiki2.dovecot.org/SharedMailboxes/Permissions and
|
||||
# http://wiki2.dovecot.org/Errors/ChgrpNoPerm
|
||||
sub dirperm {
|
||||
system('/bin/chmod',
|
||||
'g+s',
|
||||
"$_") if (-d);
|
||||
}
|
||||
|
9
root/etc/e-smith/events/actions/dovecot-compile-sieve
Normal file
9
root/etc/e-smith/events/actions/dovecot-compile-sieve
Normal file
@@ -0,0 +1,9 @@
|
||||
#!/bin/bash
|
||||
|
||||
status=$(/sbin/e-smith/config getprop spamassassin UseBayes || echo 0)
|
||||
if [ "$status" = "1" ]
|
||||
then
|
||||
systemctl restart dovecot
|
||||
/usr/bin/sievec /usr/libexec/dovecot/sieve/
|
||||
fi
|
||||
#/usr/bin/sievec /usr/libexec/dovecot/sieve/
|
20
root/etc/e-smith/templates-user/.qmail/80DovecotLDA
Normal file
20
root/etc/e-smith/templates-user/.qmail/80DovecotLDA
Normal file
@@ -0,0 +1,20 @@
|
||||
# Dovecot LDA delivery
|
||||
{
|
||||
# vim: ft=perl:
|
||||
use esmith::ConfigDB;
|
||||
my $cdb = esmith::ConfigDB->open_ro || die "Couldn't open ConfigDB\n";
|
||||
my $sieve = $cdb->get('sieve');
|
||||
my $usersieve = $props{Sieve} || 'enabled';
|
||||
my $globalsieve = ($sieve) ? ($sieve->prop('status') || 'disabled') : 'disabled';
|
||||
|
||||
if (($usersieve ne 'enabled') || ($globalsieve ne 'enabled')){
|
||||
$OUT .= "# Sieve is disabled\n";
|
||||
}
|
||||
elsif ($props{EmailForward} !~ /^(local|both)$/) {
|
||||
$OUT .= "# No local delivery (Dovecot LDA)\n";
|
||||
}
|
||||
else{
|
||||
$OUT .= '| /var/qmail/bin/preline -f /usr/libexec/dovecot/dovecot-lda -a "$RECIPIENT"; if [ $? -ne 0 ] ; then exit -1; else exit 99; fi;';
|
||||
}
|
||||
}
|
||||
|
@@ -0,0 +1 @@
|
||||
GID="sharedmailbox"
|
@@ -0,0 +1,6 @@
|
||||
{
|
||||
if (($sieve{'status'} || 'disabled') eq 'enabled'){
|
||||
$proto .= " sieve";
|
||||
}
|
||||
$OUT .= "";
|
||||
}
|
@@ -0,0 +1,19 @@
|
||||
{
|
||||
if (($sieve{'status'} || 'enabled') eq 'enabled'){
|
||||
my $port = $sieve{'TCPPort'} || '4190';
|
||||
my $address = $sieve{'Listen'} || '127.0.0.1';
|
||||
$OUT .=<<"HERE";
|
||||
|
||||
service managesieve-login {
|
||||
inet_listener sieve {
|
||||
port = $port
|
||||
address = $address
|
||||
}
|
||||
}
|
||||
|
||||
HERE
|
||||
}
|
||||
else {
|
||||
$OUT .= "# Sieve is disabled";
|
||||
}
|
||||
}
|
@@ -0,0 +1,89 @@
|
||||
{
|
||||
return "# Mailbox sharing is not enabled"
|
||||
if (($dovecot{'SharedMailbox'} || 'disabled') eq 'disabled') && (($dovecot{'PublicMailbox'} || 'disabled') eq 'disabled');
|
||||
|
||||
push @plugins, 'acl';
|
||||
push @imap_plugins, 'imap_acl';
|
||||
|
||||
my $common =<<'_EOF';
|
||||
|
||||
mail_access_groups = sharedmailbox
|
||||
|
||||
service dict {
|
||||
unix_listener dict {
|
||||
mode = 0660
|
||||
group = sharedmailbox
|
||||
}
|
||||
}
|
||||
|
||||
service auth {
|
||||
unix_listener auth-userdb {
|
||||
mode = 0660
|
||||
group = sharedmailbox
|
||||
}
|
||||
}
|
||||
|
||||
service imap {
|
||||
executable = imap imap-postlogin
|
||||
}
|
||||
|
||||
service imap-postlogin {
|
||||
executable = script-login -d /usr/bin/imap-postlogin
|
||||
unix_listener imap-postlogin {
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
namespace {
|
||||
type = private
|
||||
separator = /
|
||||
prefix =
|
||||
inbox = yes
|
||||
}
|
||||
_EOF
|
||||
|
||||
my $shared_mb = "\n# SharedMailbox is disabled\n";
|
||||
my $public_mb = "\n# PublicMailbox is disabled\n";
|
||||
if (($dovecot{'SharedMailbox'} || 'disabled') eq 'enabled'){
|
||||
$shared_mb =<<'_EOF';
|
||||
namespace {
|
||||
type = shared
|
||||
separator = /
|
||||
prefix = shared/%%u/
|
||||
location = maildir:%%h/Maildir:INDEX=~/Maildir/shared/%%u
|
||||
subscriptions = no
|
||||
list = children
|
||||
}
|
||||
_EOF
|
||||
}
|
||||
if (($dovecot{'PublicMailbox'} || 'disabled') eq 'enabled'){
|
||||
$public_mb =<<'_EOF';
|
||||
namespace {
|
||||
type = public
|
||||
separator = /
|
||||
prefix = public/
|
||||
location = maildir:/home/e-smith/files/public
|
||||
subscriptions = no
|
||||
list = children
|
||||
}
|
||||
_EOF
|
||||
}
|
||||
|
||||
my $acl =<<'_EOF';
|
||||
plugin {
|
||||
acl_shared_dict = file:/home/e-smith/db/dovecot/sharedmailbox.db
|
||||
}
|
||||
|
||||
plugin {
|
||||
acl = vfile
|
||||
}
|
||||
|
||||
plugin {
|
||||
acl_anyone = allow
|
||||
}
|
||||
|
||||
_EOF
|
||||
|
||||
push @conf, $common, $shared_mb, $public_mb, $acl;
|
||||
$OUT .= '';
|
||||
}
|
@@ -0,0 +1,52 @@
|
||||
{
|
||||
# If we have imap_sieve plugin, enable it
|
||||
if (( -e '/usr/lib64/dovecot/lib95_imap_sieve_plugin.so' || -e '/usr/lib/dovecot/lib95_imap_sieve_plugin.so') &&
|
||||
($spamassassin{'UseBayes'} || 'disabled') =~ m/^1|on|yes|enabled$/){
|
||||
push @imap_plugins, 'imap_sieve';
|
||||
my $index = 1;
|
||||
$OUT.= <<'_EOF';
|
||||
|
||||
plugin {
|
||||
sieve_plugins = sieve_imapsieve sieve_extprograms
|
||||
sieve_execute_bin_dir = /usr/libexec/dovecot
|
||||
sieve_pipe_bin_dir = /usr/libexec/dovecot
|
||||
sieve_global_extensions = +vnd.dovecot.pipe +vnd.dovecot.execute
|
||||
|
||||
_EOF
|
||||
|
||||
if (($dovecot{'LearnSpam'} || 'enabled') =~ m/^1|on|yes|enabled$/){
|
||||
$OUT.= <<"_EOF";
|
||||
# Copy from anywhere to junkmail
|
||||
imapsieve_mailbox$index\_name = junkmail
|
||||
imapsieve_mailbox$index\_causes = COPY
|
||||
imapsieve_mailbox$index\_before = file:/usr/libexec/dovecot/sieve/report-spam.sieve
|
||||
_EOF
|
||||
$index++;
|
||||
$OUT.= <<"_EOF";
|
||||
imapsieve_mailbox$index\_name = Junk
|
||||
imapsieve_mailbox$index\_causes = COPY
|
||||
imapsieve_mailbox$index\_before = file:/usr/libexec/dovecot/sieve/report-spam.sieve
|
||||
_EOF
|
||||
$index++;
|
||||
}
|
||||
if (($dovecot{'LearnHam'} || 'enabled') =~ m/^1|on|yes|enabled$/){
|
||||
$OUT.= <<"_EOF";
|
||||
# Copy from junkmail to anywhere
|
||||
imapsieve_mailbox$index\_name = *
|
||||
imapsieve_mailbox$index\_from = junkmail
|
||||
imapsieve_mailbox$index\_causes = COPY
|
||||
imapsieve_mailbox$index\_before = file:/usr/libexec/dovecot/sieve/report-ham.sieve
|
||||
_EOF
|
||||
$index++;
|
||||
$OUT.= <<"_EOF";
|
||||
imapsieve_mailbox$index\_name = *
|
||||
imapsieve_mailbox$index\_from = Junk
|
||||
imapsieve_mailbox$index\_causes = COPY
|
||||
imapsieve_mailbox$index\_before = file:/usr/libexec/dovecot/sieve/report-ham.sieve
|
||||
_EOF
|
||||
$index++;
|
||||
}
|
||||
|
||||
$OUT .= '}';
|
||||
}
|
||||
}
|
19
root/etc/e-smith/templates/etc/dovecot/dovecot.conf/91lda
Normal file
19
root/etc/e-smith/templates/etc/dovecot/dovecot.conf/91lda
Normal file
@@ -0,0 +1,19 @@
|
||||
|
||||
postmaster_address = postmaster@{$DomainName}
|
||||
lda_original_recipient_header = to
|
||||
|
||||
{
|
||||
my $reason = $dovecot{'RejectMessage'} || '';
|
||||
my $subject = $dovecot{'RejectSubject'} || '';
|
||||
if ($reason ne ''){
|
||||
$OUT .= "rejection_reason = $reason\n";
|
||||
}
|
||||
if ($subject ne ''){
|
||||
$OUT .= "rejection_subject = $subject\n";
|
||||
}
|
||||
}
|
||||
|
||||
protocol lda \{
|
||||
mail_plugins = $mail_plugins {$OUT .= (($sieve{'status'} || 'disabled') eq 'enabled') ? 'sieve':''}
|
||||
\}
|
||||
|
@@ -0,0 +1,11 @@
|
||||
{
|
||||
|
||||
if (($dovecot{'PublicMailbox'} || 'disabled') eq 'enabled'){
|
||||
my @PublicMailboxAdmins = split /[,:]/, ($dovecot{PublicMailboxAdmins} || '');
|
||||
$OUT .= "user=admin lrswtipekxa" . "\n";
|
||||
foreach my $PublicMailboxAdmins (sort @PublicMailboxAdmins){
|
||||
$OUT .= 'user=' . "$PublicMailboxAdmins " . 'lrswtipekxa' . "\n";
|
||||
}
|
||||
}
|
||||
|
||||
}
|
Reference in New Issue
Block a user