Skip to content
GitLab
Projects
Groups
Snippets
Help
Loading...
Help
Help
Support
Community forum
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in / Register
Toggle navigation
A
alternc
Project overview
Project overview
Details
Activity
Releases
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Issues
0
Issues
0
List
Boards
Labels
Service Desk
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Operations
Operations
Environments
Analytics
Analytics
CI / CD
Repository
Value Stream
Wiki
Wiki
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
domainepublic
alternc
Commits
42b89880
Commit
42b89880
authored
May 23, 2014
by
Alan Garcia
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Qque suggestion sur update_quota_mail
parent
a65afb62
Changes
1
Hide whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
51 additions
and
33 deletions
+51
-33
src/update_quota_mail.sh
src/update_quota_mail.sh
+51
-33
No files found.
src/update_quota_mail.sh
View file @
42b89880
...
...
@@ -4,93 +4,111 @@
#You can call this script either without arguments, inwich case each maildir quotas will be recalculated
#or you can call it with a directory reffering to a maildir to just sync one mailbox
#gerer les options : tout , 1boite , un domaine, un compte
function
showhelp
()
{
echo
"FIXME: some help"
exit
}
# Generate the $maildirs list based on the arguments
while
getopts
"a:m:d:c:"
optname
do
case
"
$optname
"
in
"a"
)
# All mails
# FIXME replace it by a select in da DB
maildirs
=
`
find
"
$ALTERNC_MAIL
/"
-maxdepth
2
-mindepth
2
-type
d
`
;;
"m"
)
# An email
if
[[
"
$OPTARG
"
=
~ ^[^
\@
]
*
@[^
\@
]
*
$
]]
;
then
if
[[
"
$(
mysql_query
"select userdb_home from dovecot_view where user = '
$OPTARG
'"
)
"
]]
;
then
maildirs
=
$(
mysql_query
"select userdb_home from dovecot_view where user = '
$OPTARG
'"
)
else
echo
"Bad mail provided"
showhelp
fi
else
echo
"Bad mail provided"
showhelp
fi
;;
"d"
)
if
[[
"
$OPTARG
"
=
~ ^[a-z
\-
]
+
(
\.
[
a-z
\-
]
+
)
+
$
]]
;
then
if
[[
"
$(
mysql_query
"select domaine from domaines where domaine = '
$OPTARG
'"
)
"
]]
;
then
maildirs
=
$(
mysql_query
"select userdb_home from dovecot_view where user like '%@
$OPTARG
'"
)
else
echo
"Bad domain provided"
fi
else
echo
"Bad domain provided 2"
# Expecting a domain
# Check if domain is well-formed
if
[[
!
"
$OPTARG
"
=
~ ^[a-z
\-
]
+
(
\.
[
a-z
\-
]
+
)
+
$
]]
;
then
echo
"Bad domain provided"
showhelp
fi
# Attemp to get from database.
if
[[
!
"
$(
mysql_query
"select domaine from domaines where domaine = '
$OPTARG
'"
)
"
]]
;
then
# Seem to be empty
echo
"Bad domain provided"
showhelp
fi
maildirs
=
$(
mysql_query
"select userdb_home from dovecot_view where user like '%@
$OPTARG
'"
)
;;
"c"
)
# An account
if
[[
"
$OPTARG
"
=
~ ^[a-z]
*
$
]]
;
then
if
[[
"
$(
mysql_query
"select domaine from domaines where domaine = '
$1
'"
)
"
]]
;
then
maildirs
=
$(
mysql_query
"select userdb_home from dovecot_view where userdb_uid =
$OPTARG
"
)
else
echo
"Bad account provided"
showhelp
fi
else
echo
"Bad account provided"
showhelp
fi
;;
"?"
)
echo
"Unknown option
$OPTARG
- stop processing"
showhelp
exit
;;
":"
)
echo
"No argument value for option
$OPTARG
- stop processing"
showhelp
exit
;;
*
)
# Should not occur
echo
"Unknown error while processing options"
showhelp
exit
;;
esac
done
# Now we have $maildirs, we can work on it
# FIXME add check if maildir is empty
#Then we loop through every maildir to get the maildir size
for
i
in
$maildirs
;
do
if
[
-d
"
$i
"
]
;
then
user
=
`
ls
-l
$i
|
tail
-n
1|cut
-d
' '
-f
3
`
# We grep only mails, not the others files
mails
=
`
find
$i
-type
f | egrep
"(^
$i
)*[0-9]+
\.
M"
`
if
[
!
-d
"
$i
"
]
;
then
echo
"The maildir
$i
does not exists. It's quota won't be resync"
continue
fi
# This part only count mails size
#size=0
#for j in $mails
#do
# size=$(( $size + `du -b $j|awk '{print $1}'`))
#done
# We grep only mails, not the others files
mails
=
`
find
$i
-type
f | egrep
"(^
$i
)*[0-9]+
\.
M"
`
# This part count the total mailbox size (mails + sieve scripts + ...)
size
=
`
du
-b
-s
$i
|awk
'{print $1}'
`
# This part count the total mailbox size (mails + sieve scripts + ...)
size
=
`
du
-b
-s
$i
|awk
'{print $1}'
`
mail_count
=
`
echo
$mails
|wc
-w
`
echo
"folder : "
$i
echo
"mail count : "
$mail_count
echo
"dir size : "
$size
echo
""
#update the mailbox table accordingly
mysql_query
"UPDATE mailbox SET bytes=
$size
WHERE path='
$i
' "
mysql_query
"UPDATE mailbox SET messages=
$mail_count
WHERE path='
$i
' "
else
echo
"The maildir
$i
does not exists. It's quota won't be resync"
fi
mail_count
=
`
echo
$mails
|wc
-w
`
echo
"folder : "
$i
echo
"mail count : "
$mail_count
echo
"dir size : "
$size
echo
""
#update the mailbox table accordingly
mysql_query
"UPDATE mailbox SET bytes=
$size
WHERE path='
$i
' ; "
mysql_query
"UPDATE mailbox SET messages=
$mail_count
WHERE path='
$i
' ; "
done
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment