2006-04-26 12:28:53 +00:00
< ? php
/*
$Id : m_mail . php , v 1.31 2006 / 01 / 12 06 : 26 : 16 anarcat Exp $
----------------------------------------------------------------------
LICENSE
This program is free software ; you can redistribute it and / or
modify it under the terms of the GNU General Public License ( GPL )
as published by the Free Software Foundation ; either version 2
of the License , or ( at your option ) any later version .
This program is distributed in the hope that it will be useful ,
but WITHOUT ANY WARRANTY ; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE . See the
GNU General Public License for more details .
To read the license please visit http :// www . gnu . org / copyleft / gpl . html
----------------------------------------------------------------------
Original Author of file : Benjamin Sonntag , Franck Missoum
Purpose of file : Manage Email accounts and aliases .
----------------------------------------------------------------------
*/
2009-09-08 05:29:38 +00:00
2006-04-26 12:28:53 +00:00
/**
2009-09-08 05:29:38 +00:00
* This class handle emails ( pop and / or aliases and even wrapper for internal
* classes ) of hosted users .
2006-04-26 12:28:53 +00:00
*
* Copyleft { @ link http :// alternc . net / AlternC Team }
*
* @ copyright AlternC - Team 2002 - 11 - 01 http :// alternc . net /
*
*/
class m_mail {
2009-09-08 05:29:38 +00:00
/** domain list
2006-04-26 12:28:53 +00:00
* @ access private
*/
var $domains ;
/* ----------------------------------------------------------------- */
/**
2009-09-08 05:29:38 +00:00
* Constructor
2006-04-26 12:28:53 +00:00
*/
function m_mail () {
}
2009-09-08 05:29:38 +00:00
2006-04-26 12:28:53 +00:00
/* ----------------------------------------------------------------- */
/**
2009-09-08 05:29:38 +00:00
* Quota list ( hook for quota class )
2006-04-26 12:28:53 +00:00
*/
function alternc_quota_names () {
return " mail " ;
}
2009-09-08 05:29:38 +00:00
2009-11-30 05:02:53 +00:00
/**
* Password kind used in this class ( hook for admin class )
*/
function alternc_password_policy () {
return array ( " pop " => " POP/IMAP account passwords " );
}
2006-04-26 12:28:53 +00:00
/* ----------------------------------------------------------------- */
2009-09-08 05:29:38 +00:00
/** Returns the list of mail - hosted domains for a user
* @ return array indexed array of hosted domains
2006-04-26 12:28:53 +00:00
*/
function enum_domains () {
global $db , $err , $cuid ;
$err -> log ( " mail " , " enum_domains " );
if ( ! is_array ( $this -> domains )) {
2009-02-06 15:32:28 +00:00
$db -> query ( " select * from domaines where compte=' $cuid ' AND gesmx=1 order by domaine asc; " );
2006-04-26 12:28:53 +00:00
$this -> domains = array ();
if ( $db -> num_rows () > 0 ) {
2011-06-04 13:46:33 +00:00
while ( $db -> next_record ()) {
$this -> domains [] = $db -> f ( " domaine " );
}
2006-04-26 12:28:53 +00:00
}
}
return $this -> domains ;
}
2009-09-08 05:29:38 +00:00
2006-04-26 12:28:53 +00:00
/* ----------------------------------------------------------------- */
2009-09-08 05:29:38 +00:00
/** Returns the first letters used as email for a domain
* @ param string $dom Domain whose mail we want to search for
* @ return array An indexed array of letters or false if something bad happened
2006-04-26 12:28:53 +00:00
*/
function enum_doms_mails_letters ( $dom ) {
global $err , $cuid , $db ;
$err -> log ( " mail " , " enum_doms_mails_letters " , $dom );
2011-06-15 21:58:26 +00:00
$db -> query ( " select distinct left(ad.address,1) as letter from address ad, domaines d where address like '%@ " . addslashes ( $dom ) . " ' and ad.domain_id = d.compte and d.compte=' $cuid ' order by letter; " );
2006-04-26 12:28:53 +00:00
$res = array ();
while ( $db -> next_record ()) {
$res [] = $db -> f ( " letter " );
}
return $res ;
}
2009-09-08 05:29:38 +00:00
2006-04-26 12:28:53 +00:00
/* ----------------------------------------------------------------- */
/** Retourne la liste des mails du domaine $dom et si une lettre est
* d<EFBFBD> finie , cela retourne les mail qui commencent par celle ci
* Retourne un tableau index<EFBFBD> de tableaux associatifs sous la forme :
* $a [ " mail " ] = Adresse email
* $a [ " pop " ] = 1 ou 0 selon s 'il s' agit d ' un compte pop ou pas
* $a [ " size " ] = taille en octets de la boite s 'il s' agit d ' un compte pop .
* @ param string $dom Domaine dont on veut les mails
* @ param integer $sort Champs de tri ( 0 pour non tri<EFBFBD> ( default ), 1 pour email , 2 pour type )
2007-05-11 07:21:23 +00:00
* @ param string $letter Premi<EFBFBD> re lettre des mails <EFBFBD> retourner , ou " " pour les retourner tous
2006-04-26 12:28:53 +00:00
* @ return array Tableau de mails comme indiqu<EFBFBD> ci - dessus ou FALSE si une erreur
* s ' est produite
*/
function enum_doms_mails ( $dom , $sort = 0 , $letter = " " ) {
global $err , $cuid , $db ;
$err -> log ( " mail " , " enum_doms_mails " , $dom );
2006-06-28 23:16:33 +00:00
if ( $letter == " @ " )
2011-06-04 13:46:33 +00:00
$letter = " " ;
2006-06-28 23:16:33 +00:00
else
2011-06-04 13:46:33 +00:00
$letter .= " % " ;
2010-12-20 15:04:19 +00:00
$db -> query ( " SELECT mail,pop,alias,expiration_date FROM mail_domain WHERE mail LIKE ' " . addslashes ( $letter ) . " @ " . addslashes ( $dom ) . " ' AND uid=' $cuid ' AND type=0; " );
2006-04-26 12:28:53 +00:00
$res = array (); $i = 0 ;
while ( $db -> next_record ()) {
2007-05-11 01:29:28 +00:00
if ( $db -> f ( " pop " )) {
2011-06-04 13:46:33 +00:00
$size = 0 ;
2006-04-26 14:26:21 +00:00
$r = mysql_query ( " SELECT size FROM size_mail WHERE alias=' " . str_replace ( " @ " , " _ " , $db -> f ( " mail " )) . " '; " );
list ( $size ) =@ mysql_fetch_array ( $r );
$size = $size * 1024 ;
2006-04-26 12:28:53 +00:00
} else $size = 0 ;
if ( $db -> f ( " pop " )) {
2011-06-04 13:46:33 +00:00
$login = str_replace ( " @ " , " _ " , $db -> f ( " mail " ));
$account = str_replace ( $login , " " , $db -> f ( " alias " ));
2006-04-26 12:28:53 +00:00
} else {
2011-06-04 13:46:33 +00:00
$account = $db -> f ( " alias " );
2006-04-26 12:28:53 +00:00
}
2007-05-11 01:29:28 +00:00
$res [] = array ( " mail " => $db -> f ( " mail " ), " pop " => $db -> f ( " pop " ),
2010-12-20 15:04:19 +00:00
" alias " => $account , " size " => $size , " expiration_date " => $db -> f ( " expiration_date " ));
2006-04-26 12:28:53 +00:00
$i ++ ;
}
if ( $sort == 1 ) {
usort ( $res , array ( " m_mail " , " _cmp_mail " ));
}
if ( $sort == 2 ) {
usort ( $res , array ( " m_mail " , " _cmp_type " ));
}
$res [ " count " ] = $i ;
return $res ;
}
function _cmp_mail ( $a , $b )
{
$al = strtolower ( $a [ " mail " ]);
$bl = strtolower ( $b [ " mail " ]);
if ( $al == $bl ) return 0 ;
return ( $al > $bl ) ? + 1 : - 1 ;
}
function _cmp_type ( $a , $b )
{
$al = strtolower ( $a [ " pop " ]);
$bl = strtolower ( $b [ " pop " ]);
if ( $al == $bl ) {
2011-06-04 13:46:33 +00:00
$al = strtolower ( $a [ " mail " ]);
$bl = strtolower ( $b [ " mail " ]);
if ( $al == $bl ) return 0 ;
2006-04-26 12:28:53 +00:00
}
return ( $al > $bl ) ? + 1 : - 1 ;
}
2009-09-08 05:29:38 +00:00
2006-04-26 12:28:53 +00:00
/* ----------------------------------------------------------------- */
/** Retourne les d<EFBFBD> tails d ' un mail
* Le mail $mail est retourn<EFBFBD> sous la forme d ' un tableaau associatif comme suit :
* $a [ " mail " ] = Adresse email
* $a [ " login " ] = Login pop
* $a [ " password " ] = Mot de passe pop ( crypt<EFBFBD> )
* $a [ " alias " ] = Alias destination , 1 par ligne
* $a [ " pop " ] = 1 ou 0 s 'il s' agit d ' un compte pop
* @ param string $mail Mail dont on veut retourner le d<EFBFBD> tail
* @ return array Tableau associatif comme ci - dessus .
*/
function get_mail_details ( $mail ) {
global $err , $db , $cuid ;
$err -> log ( " mail " , " get_mail_details " , $mail );
2010-12-20 15:04:19 +00:00
$db -> query ( " SELECT mail,pop,alias,expiration_date FROM mail_domain WHERE mail=' $mail ' AND uid=' $cuid '; " );
2007-05-11 01:29:28 +00:00
if ( ! $db -> next_record ()) {
2006-04-26 12:28:53 +00:00
$err -> raise ( " mail " , 3 , $mail );
return false ;
}
2007-05-11 01:29:28 +00:00
$pop = $db -> f ( " pop " );
2010-12-20 15:04:19 +00:00
$trash_info = new m_trash ();
$trash_info -> set_from_db ( $db -> f ( " expiration_date " ));
2006-04-26 12:28:53 +00:00
if ( $pop ) {
$login = str_replace ( " @ " , " _ " , $db -> f ( " mail " ));
2007-05-11 01:29:28 +00:00
$account = str_replace ( $login , " " , $db -> f ( " alias " ));
2006-04-26 12:28:53 +00:00
} else {
$account = $db -> f ( " alias " );
}
2010-12-20 15:04:19 +00:00
return array ( " mail " => $mail , " login " => $login , " alias " => $account , " pop " => $pop , " trash_info " => $trash_info );
2006-04-26 12:28:53 +00:00
}
2009-09-08 05:29:38 +00:00
/* ----------------------------------------------------------------- */
/** Tell if a mail is available or not
* @ param string $mail the email address ( with its fqdn domain )
* @ return boolean true if this email is available , false if it is already defined .
*/
2011-06-15 21:58:26 +00:00
function available ( $mail ) { // NEW OK
2006-04-26 12:28:53 +00:00
global $err , $db , $cuid ;
$err -> log ( " mail " , " available " , $mail );
2011-06-04 13:46:33 +00:00
$db -> query ( " SELECT address FROM address WHERE address=' $mail '; " );
2006-04-26 12:28:53 +00:00
if ( $db -> next_record ()) {
return false ;
} else {
return true ;
}
}
2009-09-08 05:29:38 +00:00
2006-04-26 12:28:53 +00:00
/* ----------------------------------------------------------------- */
2009-09-08 05:29:38 +00:00
/** Create a wrapper for $login @ $domain email
* @ param string $login left part of the @ for the email creation
* @ param string $domain domain - part of the email
* @ param string $command The command we want to execute , without " nor | (raw command)
* @ param string $type now unused ( was a ldap class name )
* @ return boolean TRUE if the wrapper has been created , false if an error occurred .
2006-04-26 12:28:53 +00:00
*/
function add_wrapper ( $login , $domain , $command , $type = " " ) {
global $err , $cuid , $db ;
if ( ! $this -> available ( $login . " @ " . $domain )) {
$err -> raise ( " mail " , 7 , $login . " @ " . $domain );
return false ;
}
$db -> query ( " INSERT INTO mail_domain (mail,alias,uid,pop,type) VALUES (' " . $login . " @ " . $domain . " ',' " . $login . " _ " . $domain . " ',' $cuid ',0,1); " );
$db -> query ( " INSERT INTO mail_alias (mail,alias) VALUES (' " . $login . " _ " . $domain . " ',' \" | $command\ " ' ); " );
return true ;
}
2009-09-08 05:29:38 +00:00
2006-04-26 12:28:53 +00:00
/* ----------------------------------------------------------------- */
2009-09-08 05:29:38 +00:00
/** Delete a wrapper email
* @ param string $login left part of the @ for the email creation
* @ param string $domain domain - part of the email
* @ return boolean TRUE if the wrapper has been deleted , FALSE if an error occurred .
2006-04-26 12:28:53 +00:00
*/
function del_wrapper ( $login , $domain ) {
global $err , $cuid , $db ;
$db -> query ( " DELETE FROM mail_domain WHERE mail=' " . $login . " @ " . $domain . " ' AND uid=' $cuid ' AND type=1; " );
$db -> query ( " DELETE FROM mail_alias WHERE mail=' " . $login . " _ " . $domain . " '; " );
return true ;
}
/* ----------------------------------------------------------------- */
2009-09-08 05:29:38 +00:00
/** Change the password of the email account $mail
* @ param string $mail Pop / Imap email account
* @ param string $pass New password
* @ return boolean TRUE if the password has been changed , FALSE if an error occurred .
2006-04-26 12:28:53 +00:00
*/
2011-06-04 13:46:33 +00:00
function change_password ( $mail , $pass ) { // NEW OK
2006-04-26 12:28:53 +00:00
global $err , $db , $cuid ;
$err -> log ( " mail " , " change_password " , $mail );
$t = explode ( " @ " , $mail );
$email = $t [ 0 ];
$dom = $t [ 1 ];
2011-06-04 13:46:33 +00:00
$db -> query ( " SELECT address FROM address WHERE address=' $mail ' AND uid=' $cuid '; " );
2006-04-26 12:28:53 +00:00
if ( ! $db -> next_record ()) {
$err -> raise ( " mail " , 3 , $mail );
return false ;
}
2010-04-28 19:28:36 +00:00
// Check this password against the password policy using common API :
if ( is_callable ( array ( $admin , " checkPolicy " ))) {
if ( ! $admin -> checkPolicy ( " pop " , $email . " @ " . $dom , $pass )) {
2011-06-04 13:46:33 +00:00
return false ; // The error has been raised by checkPolicy()
2010-04-28 19:28:36 +00:00
}
}
2006-04-26 12:28:53 +00:00
if ( ! $this -> _updatepop ( $email , $dom , $pass )) {
return false ;
}
return true ;
}
2009-09-08 05:29:38 +00:00
2006-04-26 12:28:53 +00:00
/* ----------------------------------------------------------------- */
/** Modifie les param<EFBFBD> tres d ' un compte email
* Tout peut <EFBFBD> tre modifi<EFBFBD> dans l 'email (sauf l' adresse elle - m<EFBFBD> me )
* @ param string $mail Adresse <EFBFBD> modifier . Le domaine doit appartenir au membre
* @ param integer $pop Doit - il etre un compte pop ( 1 ) ou juste un alias ( 0 )
* @ param string $pass Nouveau mot de passe pop , si pop = 1
* @ param string $alias Liste des destinataires auxiliaires , un par ligne .
* @ return boolean TRUE si l 'email a bien <20> t<EFBFBD> modifi<66> , FALSE si une erreur s' est produite .
*/
2010-12-20 15:04:19 +00:00
function put_mail_details ( $mail , $pop , $pass , $alias , $expiration_date = null ) {
2009-11-30 06:01:34 +00:00
global $err , $cuid , $db , $admin ;
2006-04-26 12:28:53 +00:00
$err -> log ( " mail " , " put_mail_details " , $mail );
2009-11-30 23:53:36 +00:00
$mail = trim ( strtolower ( $mail )); // remove spaces also
2006-04-26 12:28:53 +00:00
$t = explode ( " @ " , $mail );
2009-11-30 23:53:36 +00:00
$email = trim ( $t [ 0 ]); // remove spaces also
2006-04-26 12:28:53 +00:00
$dom = $t [ 1 ];
$account = array ();
if ( $pop ) $pop = " 1 " ; else $pop = " 0 " ;
2009-09-08 05:29:38 +00:00
2006-04-26 12:28:53 +00:00
if ( $pop == " 0 " && $alias == " " ) {
$err -> raise ( " mail " , 4 );
return false ;
}
if ( $pop == " 1 " ){
$account [] = $email . " _ " . $dom ;
}
2009-09-08 05:29:38 +00:00
2006-04-26 12:28:53 +00:00
if ( $alias ){
$a = explode ( " \n " , $alias );
if ( count ( $a ) > 0 ) {
2011-06-04 13:46:33 +00:00
reset ( $a );
for ( $i = 0 ; $i < count ( $a ); $i ++ ){
$a [ $i ] = trim ( $a [ $i ]); // remove spaces
if ( $a [ $i ]){
if ( checkmail ( $a [ $i ]) > 1 ){
$err -> raise ( " mail " , 14 );
return false ;
}
}
$account [] = $a [ $i ];
}
2006-04-26 12:28:53 +00:00
}
}
2010-12-20 15:04:19 +00:00
$db -> query ( " SELECT mail,alias,pop,expiration_date FROM mail_domain WHERE mail=' $mail ' AND uid=' $cuid ' AND type=0; " );
2006-04-26 12:28:53 +00:00
if ( ! $db -> next_record ()) {
$err -> raise ( " mail " , 3 , $mail );
return false ;
}
$oldpop = $db -> f ( " pop " );
// When we CREATE a pop account, we MUST give a password
if ( $pop == " 1 " && $oldpop != 1 ) {
if ( ! $pass ) {
2011-06-04 13:46:33 +00:00
$err -> raise ( " mail " , 4 );
return false ;
2006-04-26 12:28:53 +00:00
}
2009-11-30 06:01:34 +00:00
// Check this password against the password policy using common API :
if ( is_callable ( array ( $admin , " checkPolicy " ))) {
2011-06-04 13:46:33 +00:00
if ( ! $admin -> checkPolicy ( " pop " , $email . " @ " . $dom , $pass )) {
return false ; // The error has been raised by checkPolicy()
}
2009-11-30 06:01:34 +00:00
}
2006-04-26 12:28:53 +00:00
}
2010-12-20 15:04:19 +00:00
$expiration_sql = ( is_null ( $expiration_date )) ? " null " : " ' $expiration_date ' " ;
$db -> query ( " UPDATE mail_domain SET alias=' " . implode ( " \n " , $account ) . " ', pop=' $pop ',expiration_date= $expiration_sql WHERE mail=' $mail '; " );
2006-04-26 12:28:53 +00:00
2009-09-08 05:29:38 +00:00
if ( $pop == " 1 " && $oldpop != 1 ) { /* POP Creation */
2006-04-26 12:28:53 +00:00
if ( ! $this -> _createpop ( $email , $dom , $pass )) {
2011-06-04 13:46:33 +00:00
return false ;
2006-04-26 12:28:53 +00:00
}
}
2009-09-08 05:29:38 +00:00
if ( $pop != " 1 " && $oldpop == 1 ) { /* POP Destruction */
2006-04-26 12:28:53 +00:00
if ( ! $this -> _deletepop ( $email , $dom )) {
2011-06-04 13:46:33 +00:00
return false ;
2006-04-26 12:28:53 +00:00
}
}
2009-09-08 05:29:38 +00:00
if ( $pop == " 1 " && $oldpop == 1 && $pass != " " ) { /* POP Account Edition */
2010-04-28 19:28:36 +00:00
// Check this password against the password policy using common API :
if ( is_callable ( array ( $admin , " checkPolicy " ))) {
2011-06-04 13:46:33 +00:00
if ( ! $admin -> checkPolicy ( " pop " , $email . " @ " . $dom , $pass )) {
return false ; // The error has been raised by checkPolicy()
}
2010-04-28 19:28:36 +00:00
}
2006-04-26 12:28:53 +00:00
if ( ! $this -> _updatepop ( $email , $dom , $pass )) {
2011-06-04 13:46:33 +00:00
return false ;
2006-04-26 12:28:53 +00:00
}
}
return true ;
}
2009-09-08 05:29:38 +00:00
2006-04-26 12:28:53 +00:00
/* ----------------------------------------------------------------- */
/** Cr<EFBFBD> e un compte email $mail sur le domaine $dom
* @ param string $dom Domaine concern<EFBFBD> , il doit appartenir au membre
* @ param string $mail Email <EFBFBD> cr<EFBFBD> er , il ne doit pas exister ni en mail , ni en liste .
* @ param integer $pop vaut 1 pour cr<EFBFBD> er un compte pop , 0 pour un alias
* @ param string $alias Liste des alias , un par ligne
* @ return boolean TRUE si le compte a bien <EFBFBD> t<EFBFBD> cr<EFBFBD> <EFBFBD> , FALSE si une erreur s ' est produite .
*/
2010-12-20 15:04:19 +00:00
function add_mail ( $dom , $mail , $pop , $pass , $alias , $expiration_date = null ) {
2010-06-23 23:19:27 +00:00
global $quota , $err , $cuid , $db , $admin , $L_FQDN ;
2006-04-26 12:28:53 +00:00
$err -> log ( " mail " , " add_mail " , $dom . " / " . $mail );
$account = array ();
2009-11-30 23:53:36 +00:00
$mail = trim ( strtolower ( $mail )); // remove spaces also
2006-04-26 12:28:53 +00:00
if ( $pop ) $pop = " 1 " ; else $pop = " 0 " ;
2010-06-23 23:19:27 +00:00
if ( $mail || $dom == $L_FQDN ) {
2006-04-26 12:28:53 +00:00
if ( ! checkloginmail ( $mail )) {
2011-06-04 13:46:33 +00:00
$err -> raise ( " mail " , 13 );
return false ;
2006-04-26 12:28:53 +00:00
}
}
2009-09-08 05:29:38 +00:00
2006-04-26 12:28:53 +00:00
if (( $pop == " 1 " && $pass == " " ) || ( $pop != " 1 " && $alias == " " )){
$err -> raise ( " mail " , 4 );
return false ;
}
2009-11-30 06:01:34 +00:00
if ( $pop == " 1 " ) {
// Check this password against the password policy using common API :
if ( is_callable ( array ( $admin , " checkPolicy " ))) {
2011-06-04 13:46:33 +00:00
if ( ! $admin -> checkPolicy ( " pop " , $mail . " @ " . $dom , $pass )) {
return false ; // The error has been raised by checkPolicy()
}
2009-11-30 06:01:34 +00:00
}
}
2006-04-26 12:28:53 +00:00
if ( $pop == " 1 " ){
$account [] = $mail . " _ " . $dom ;
}
2009-09-08 05:29:38 +00:00
2006-04-26 12:28:53 +00:00
if ( $alias ){
$a = explode ( " \n " , $alias );
if ( count ( $a ) > 0 ) {
2011-06-04 13:46:33 +00:00
reset ( $a );
for ( $i = 0 ; $i < count ( $a ); $i ++ ){
$a [ $i ] = trim ( $a [ $i ]);
if ( $a [ $i ]){
if ( checkmail ( $a [ $i ]) > 1 ){
$err -> raise ( " mail " , 14 );
return false ;
}
}
$account [] = $a [ $i ];
}
2006-04-26 12:28:53 +00:00
}
}
2009-09-08 05:29:38 +00:00
// check that the domain is a user's own ...
2006-04-26 12:28:53 +00:00
$db -> query ( " SELECT domaine FROM domaines WHERE compte=' $cuid ' AND domaine=' $dom '; " );
if ( ! $db -> next_record ()) {
$err -> raise ( " mail " , 6 , $dom );
return false ;
2007-05-11 01:29:28 +00:00
}
2006-04-26 12:28:53 +00:00
$db -> query ( " SELECT mail FROM mail_domain WHERE mail=' " . $mail . " @ " . $dom . " ' AND uid=' $cuid '; " );
if ( $db -> next_record ()) {
$err -> raise ( " mail " , 7 , $mail . " @ " . $dom );
return false ;
2007-05-11 01:29:28 +00:00
}
2006-04-26 12:28:53 +00:00
/* QuotaCheck */
if ( ! $quota -> cancreate ( " mail " )) {
$err -> raise ( " mail " , 8 );
return false ;
}
2010-12-20 15:04:19 +00:00
$expiration_sql = ( is_null ( $expiration_date )) ? " null " : " ' $expiration_date ' " ;
$db -> query ( " INSERT INTO mail_domain (mail,alias,uid,pop,type,expiration_date) VALUES (' " . $mail . " @ " . $dom . " ',' " . implode ( " \n " , $account ) . " ',' $cuid ',' $pop ',0, $expiration_sql ); " );
2006-04-26 12:28:53 +00:00
if ( $pop == " 1 " ) {
if ( ! $this -> _createpop ( $mail , $dom , $pass ))
2011-06-04 13:46:33 +00:00
return false ;
2006-04-26 12:28:53 +00:00
}
return true ;
}
2009-09-08 05:29:38 +00:00
2006-04-26 12:28:53 +00:00
/* ----------------------------------------------------------------- */
2009-09-08 05:29:38 +00:00
/** Delete an email account ( pop or alias ) $mail
* @ param string $mail Email to delete
* @ return boolean TRUE if the email has been deleted , or FALSE if an error occurred
2006-04-26 12:28:53 +00:00
*/
function del_mail ( $mail ) {
global $err , $cuid , $db ;
$err -> log ( " mail " , " del_mail " , $mail );
$mail = strtolower ( $mail );
$db -> query ( " SELECT pop,mail FROM mail_domain WHERE mail=' $mail ' AND uid=' $cuid ' AND type=0; " );
if ( ! $db -> next_record ()) {
$err -> raise ( " mail " , 3 , $dom );
return false ;
2007-05-11 01:29:28 +00:00
}
2006-04-26 12:28:53 +00:00
$t = explode ( " @ " , $mail );
$mdom = $t [ 0 ]; $dom = $t [ 1 ];
$pop = $db -> f ( " pop " );
2007-05-11 01:29:28 +00:00
2006-04-26 12:28:53 +00:00
$db -> query ( " DELETE FROM mail_domain WHERE mail=' $mail ' AND uid=' $cuid '; " );
if ( $pop == " 1 " ) {
if ( ! $this -> _deletepop ( $mdom , $dom )) {
2011-06-04 13:46:33 +00:00
return false ;
2006-04-26 12:28:53 +00:00
}
}
return true ;
}
2006-05-22 09:03:51 +00:00
/* ----------------------------------------------------------------- */
/**
* Check for a slave account ( secondary mx )
2009-09-08 05:29:38 +00:00
* @ param string $login the login to check
* @ param string $pass the password to check
* @ return boolean TRUE if the password is correct , or FALSE if an error occurred .
2006-05-22 09:03:51 +00:00
*/
function check_slave_account ( $login , $pass ) {
global $db , $err ;
$db -> query ( " SELECT * FROM mxaccount WHERE login=' $login ' AND pass=' $pass '; " );
2007-05-11 01:29:28 +00:00
if ( $db -> next_record ()) {
2006-05-22 09:03:51 +00:00
return true ;
}
return false ;
}
2009-09-08 05:29:38 +00:00
2006-05-22 09:03:51 +00:00
/* ----------------------------------------------------------------- */
/**
2007-05-11 01:29:28 +00:00
* Out ( echo ) the complete mx - hosted domain list :
2006-05-22 09:03:51 +00:00
*/
function echo_domain_list () {
global $db , $err ;
$db -> query ( " SELECT domaine FROM domaines WHERE gesmx=1 ORDER BY domaine " );
while ( $db -> next_record ()) {
echo $db -> f ( " domaine " ) . " \n " ;
}
return true ;
}
2009-09-08 05:29:38 +00:00
2006-05-22 09:03:51 +00:00
/* ----------------------------------------------------------------- */
/**
* Return the list of allowed slave accounts ( secondary - mx )
2009-09-08 05:29:38 +00:00
* @ return array
2006-05-22 09:03:51 +00:00
*/
function enum_slave_account () {
global $db , $err ;
$db -> query ( " SELECT * FROM mxaccount; " );
$res = array ();
while ( $db -> next_record ()) {
$res [] = $db -> Record ;
}
if ( ! count ( $res )) return false ;
return $res ;
}
2009-09-08 05:29:38 +00:00
2006-05-22 09:03:51 +00:00
/* ----------------------------------------------------------------- */
/**
* Add a slave account that will be allowed to access the mxdomain list
2009-09-08 05:29:38 +00:00
* @ param string $login the login to add
* @ param string $pass the password to add
* @ return boolean TRUE if the account has been created , or FALSE if an error occurred .
2006-05-22 09:03:51 +00:00
*/
function add_slave_account ( $login , $pass ) {
global $db , $err ;
$db -> query ( " SELECT * FROM mxaccount WHERE login=' $login ' " );
if ( $db -> next_record ()) {
2009-09-08 05:29:38 +00:00
$err -> raise ( " mail " , 16 );
2006-05-22 09:03:51 +00:00
return false ;
}
$db -> query ( " INSERT INTO mxaccount (login,pass) VALUES (' $login ',' $pass ') " );
return true ;
}
2009-09-08 05:29:38 +00:00
2006-05-22 09:03:51 +00:00
/* ----------------------------------------------------------------- */
/**
* Remove a slave account
2009-09-08 05:29:38 +00:00
* @ param string $login the login to delete
2006-05-22 09:03:51 +00:00
*/
function del_slave_account ( $login ) {
global $db , $err ;
$db -> query ( " DELETE FROM mxaccount WHERE login=' $login ' " );
return true ;
}
2009-09-08 05:29:38 +00:00
2006-04-26 12:28:53 +00:00
/* ----------------------------------------------------------------- */
/** Cr<EFBFBD> e le compte pop $mail @ $dom , avec pour mot de passe $pass
* @ param string $mail Compte email <EFBFBD> cr<EFBFBD> er en pop
* @ param string $dom Domaine sur lequel on cr<EFBFBD> e le compte email
* @ param string $pass Mot de passe du compte email .
* @ return boolean TRUE si le compte pop a bien <EFBFBD> t<EFBFBD> cr<EFBFBD> <EFBFBD> , FALSE si une erreur est survenur
* @ access private
*/
function _createpop ( $mail , $dom , $pass ) {
global $err , $cuid , $db ;
$err -> log ( " mail " , " _createpop " , $mail . " @ " . $dom );
$m = substr ( $mail , 0 , 1 );
$gecos = $mail ;
if ( ! $mail ) {
// Cas du CATCH-ALL
$gecos = " Catch-All " ;
$m = " _ " ;
}
$db -> query ( " INSERT INTO mail_users (uid,alias,path,password) VALUES (' $cuid ',' " . $mail . " _ " . $dom . " ','/var/alternc/mail/ " . $m . " / " . $mail . " _ " . $dom . " ',' " . _md5cr ( $pass ) . " '); " );
$db -> query ( " INSERT INTO mail_users (uid,alias,path,password) VALUES (' $cuid ',' " . $mail . " @ " . $dom . " ','/var/alternc/mail/ " . $m . " / " . $mail . " _ " . $dom . " ',' " . _md5cr ( $pass ) . " '); " );
$db -> query ( " INSERT INTO mail_alias (mail,alias) VALUES (' " . $mail . " _ " . $dom . " ','/var/alternc/mail/ " . $m . " / " . $mail . " _ " . $dom . " /Maildir/'); " );
2009-09-08 05:29:38 +00:00
// Webmail data (squirrelmail default preferences)
2006-04-26 12:28:53 +00:00
$f = fopen ( " /var/lib/squirrelmail/data/ " . $mail . " _ " . $dom . " .pref " , " wb " );
2007-08-23 08:18:41 +00:00
$g = 0 ; $g =@ fopen ( " /etc/squirrelmail/default_pref " , " rb " );
2006-04-26 12:28:53 +00:00
fputs ( $f , " email_address= $mail @ $dom\nchosen_theme =default_theme.php \n " );
2007-08-23 08:18:41 +00:00
if ( $g ) {
while ( $s = fgets ( $g , 1024 )) {
2011-06-04 13:46:33 +00:00
if ( substr ( $s , 0 , 14 ) != " email_address= " && substr ( $s , 0 , 13 ) != " chosen_theme= " ) {
fputs ( $f , $s );
}
2007-08-23 08:18:41 +00:00
}
fclose ( $g );
}
2006-04-26 12:28:53 +00:00
fclose ( $f );
2007-08-23 08:18:41 +00:00
@ copy ( " /var/lib/squirrelmail/data/ " . $mail . " _ " . $dom . " .pref " , " /var/lib/squirrelmail/data/ " . $mail . " @ " . $dom . " .pref " );
2006-04-26 12:28:53 +00:00
exec ( " /usr/lib/alternc/mail_add " . $mail . " _ " . $dom . " " . $cuid );
return true ;
}
2009-09-08 05:29:38 +00:00
2006-04-26 12:28:53 +00:00
/* ----------------------------------------------------------------- */
/** Met <EFBFBD> jour un compte pop existant
* @ param string $mail mail <EFBFBD> modifier
* @ param string $dom Domaine dont on modifie le compte pop
* @ param string $pass Nouveau mot de passe .
* @ return boolean TRUE si le compte pop a bien <EFBFBD> t<EFBFBD> modifi<EFBFBD> , FALSE si une erreur s ' est produite .
* @ access private
*/
2011-06-04 13:46:33 +00:00
function _updatepop ( $mail , $dom , $pass ) { // NEW OK
2006-04-26 12:28:53 +00:00
global $err , $cuid , $db ;
$err -> log ( " mail " , " _updatepop " , $mail . " @ " . $dom );
$m = substr ( $mail , 0 , 1 );
$gecos = $mail ;
2011-06-04 13:46:33 +00:00
$db -> query ( " UPDATE address SET password=' " . _md5cr ( $pass ) . " ' WHERE address=' " . $mail . " @ " . $dom . " ' AND uid=' $cuid '; " );
2006-04-26 12:28:53 +00:00
return true ;
}
2009-09-08 05:29:38 +00:00
2006-04-26 12:28:53 +00:00
/* ----------------------------------------------------------------- */
/** D<EFBFBD> truit le compte pop $mail @ $dom .
* @ param string $mail Email dont on souhaite d<EFBFBD> truire le compte pop
* @ param string $dom Domaine dont on souhaite d<EFBFBD> tuire le compte pop .
* @ return boolean TRUE si le compte pop a bien <EFBFBD> t<EFBFBD> d<EFBFBD> truit , FALSE si une erreur s ' est produite .
* @ access private
*/
function _deletepop ( $mail , $dom ) {
global $err , $cuid , $db ;
$err -> log ( " mail " , " _deletepop " , $mail . " @ " . $dom );
$db -> query ( " DELETE FROM mail_users WHERE uid=' $cuid ' AND ( alias=' " . $mail . " _ " . $dom . " ' OR alias=' " . $mail . " @ " . $dom . " ' ) ; " );
$db -> query ( " DELETE FROM mail_alias WHERE mail=' " . $mail . " _ " . $dom . " '; " );
2009-08-04 18:37:14 +00:00
$db -> query ( " DELETE FROM size_mail WHERE alias=' " . $mail . " _ " . $dom . " '; " );
2006-04-26 12:28:53 +00:00
@ unlink ( " /var/lib/squirrelmail/data/ " . $mail . " _ " . $dom . " .pref " );
@ unlink ( " /var/lib/squirrelmail/data/ " . $mail . " _ " . $dom . " .abook " );
@ unlink ( " /var/lib/squirrelmail/data/ " . $mail . " @ " . $dom . " .pref " );
@ unlink ( " /var/lib/squirrelmail/data/ " . $mail . " @ " . $dom . " .abook " );
exec ( " /usr/lib/alternc/mail_del " . $mail . " _ " . $dom );
return true ;
}
2009-09-08 05:29:38 +00:00
2006-04-26 12:28:53 +00:00
/* ----------------------------------------------------------------- */
/** Fonction appell<EFBFBD> e par domaines lorsqu ' un domaine est effac<EFBFBD> .
* Cette fonction efface tous les comptes mails du domaine concern<EFBFBD> .
* @ param string $dom Domaine <EFBFBD> effacer
* @ return boolean TRUE si le domaine a bien <EFBFBD> t<EFBFBD> effac<EFBFBD> , FALSE si une erreur s ' est produite .
* @ access private
*/
function alternc_del_mx_domain ( $dom ) {
global $err , $db , $cuid ;
$err -> error = 0 ;
$err -> log ( " mail " , " alternc_del_mx_domain " , $dom );
2009-09-08 05:29:38 +00:00
/* FIXME / Why on hell is it commented out ?
2006-04-26 12:28:53 +00:00
$db -> query ( " SELECT domaine FROM domaines WHERE compte=' $cuid ' AND domaine=' $dom '; " );
if ( ! $db -> next_record ()) {
$err -> raise ( " mail " , 6 , $dom );
return false ;
2007-05-11 01:29:28 +00:00
}
2006-04-26 12:28:53 +00:00
*/
/* Effacement de tous les mails de ce domaine : */
$a = $this -> enum_doms_mails ( $dom );
if ( is_array ( $a )) {
reset ( $a );
for ( $i = 0 ; $i < $a [ " count " ]; $i ++ ) {
2011-06-04 13:46:33 +00:00
$val = $a [ $i ];
if ( ! $this -> del_mail ( $val [ " mail " ])) {
$err -> raise ( " mail " , 5 );
}
2006-04-26 12:28:53 +00:00
}
}
/* Effacement du domaine himself */
2007-05-11 01:29:28 +00:00
$db -> query ( " DELETE FROM mail_domain WHERE mail LIKE '%@ $dom '; " );
$db -> query ( " DELETE FROM mail_users WHERE alias LIKE '%@ $dom ' OR alias LIKE '% \\ _ $dom '; " );
$db -> query ( " DELETE FROM mail_alias WHERE mail LIKE '% \\ _ $dom '; " );
2006-04-26 12:28:53 +00:00
$db -> query ( " DELETE FROM mail_domain WHERE mail=' $dom '; " );
return true ;
}
2009-09-08 05:29:38 +00:00
2006-04-26 12:28:53 +00:00
/* ----------------------------------------------------------------- */
2009-09-08 05:29:38 +00:00
/** hook function called by AlternC when a domain is created for
* the current user account
* This function create default email accuonts ( postmaster ) for the newly hosted domain
* @ param string $dom Domain that has just been created
* @ return boolean TRUE if the domain has been successfully created in the email db or FALSE if an error occurred .
2006-04-26 12:28:53 +00:00
* @ access private
*/
function alternc_add_mx_domain ( $dom ) {
global $err , $cuid , $db , $mem ;
$err -> log ( " mail " , " alternc_add_mx_domain " , $dom );
2009-09-02 02:21:52 +00:00
$db -> query ( " INSERT INTO mail_domain (mail,alias,uid) VALUES (' $dom ',' $dom ', ' $cuid '); " );
2006-04-26 12:28:53 +00:00
$this -> add_mail ( $dom , " postmaster " , 0 , " " , $mem -> user [ " mail " ]);
return true ;
}
2009-09-08 05:29:38 +00:00
2010-03-04 16:16:13 +00:00
/* ----------------------------------------------------------------- */
/** hook function called by AlternC when a domain is created for
* the current user account using the SLAVE DOMAIN feature
* This function create a CATCHALL to the master domain
* @ param string $dom Domain that has just been created
* @ param string $master Master domain
* @ access private
*/
function alternc_add_slave_domain ( $dom , $slave ) {
global $err ;
$err -> log ( " mail " , " alternc_add_slave_domain " , $dom );
$this -> add_mail ( $dom , " " , 0 , " " , " @ " . $slave );
return true ;
}
2006-04-26 12:28:53 +00:00
/* ----------------------------------------------------------------- */
/**
* Returns the used quota for the $name service for the current user .
* @ param $name string name of the quota
* @ return integer the number of service used or false if an error occured
* @ access private
*/
function alternc_get_quota ( $name ) {
global $db , $err , $cuid ;
if ( $name == " mail " ) {
$err -> log ( " mail " , " getquota " );
$db -> query ( " SELECT COUNT(*) AS cnt FROM mail_domain WHERE type=0 AND uid=' $cuid ' " );
$db -> next_record ();
return $db -> f ( " cnt " );
}
}
/* ----------------------------------------------------------------- */
/**
* Exports all the mail related information for an account .
* @ access private
2007-05-11 01:29:28 +00:00
* EXPERIMENTAL 'sid' function ;)
2006-04-26 12:28:53 +00:00
*/
function alternc_export ( $tmpdir ) {
global $db , $err ;
$err -> log ( " mail " , " export " );
$domain = $this -> enum_domains ();
$str = " <mail> \n " ;
$tmpfile = $tmpdir . " /mail_filelist.txt " ;
$f = fopen ( $tmpfile , " wb " );
$onepop = false ;
foreach ( $domain as $d ) {
$str .= " <domain> \n <name> " . xml_entities ( $d ) . " </name> \n " ;
$s = $this -> enum_doms_mails ( $d );
unset ( $s [ " count " ]);
if ( count ( $s )) {
foreach ( $s as $e ) {
$str .= " <address> \n " ;
$str .= " <mail> " . xml_entities ( $e [ " mail " ]) . " </mail> \n " ;
$str .= " <ispop> " . xml_entities ( $e [ " pop " ]) . " </ispop> \n " ;
$acc = explode ( " \n " , $e [ " alias " ]);
foreach ( $acc as $f ) {
$f = trim ( $f );
if ( $f ) {
$str .= " <alias> " . xml_entities ( $f ) . " </alias> \n " ;
}
}
if ( $e [ " pop " ]) {
$db -> query ( " SELECT path FROM mail_users WHERE alias=' " . str_replace ( " @ " , " _ " , $e [ " mail " ]) . " '; " );
if ( $db -> next_record ()) {
fputs ( $f , $db -> Record [ " path " ] . " \n " );
$onepop = true ;
}
}
$str .= " </address> \n " ;
}
2007-05-11 01:29:28 +00:00
}
2006-04-26 12:28:53 +00:00
$str .= " </domain> \n " ;
}
$str .= " </mail> \n " ;
fclose ( $f );
if ( $onepop ) {
2007-05-11 01:29:28 +00:00
// Now do the tarball of all pop accounts :
exec ( " /bin/tar -czf " . escapeshellarg ( $tmpdir . " /mail.tar.gz " ) . " -T " . escapeshellarg ( $tmpfile ));
2006-04-26 12:28:53 +00:00
}
@ unlink ( $tmpfile );
return $str ;
}
} /* Class m_mail */
?>