2006-08-12 00:04:12 +00:00
< ? php
2007-08-26 20:06:39 +00:00
/*
$Id : adm_tld . php , v 1.4 2004 / 11 / 29 17 : 27 : 04 anonymous Exp $
----------------------------------------------------------------------
AlternC - Web Hosting System
Copyright ( C ) 2002 by the AlternC Development Team .
http :// alternc . org /
----------------------------------------------------------------------
Based on :
Valentin Lacambre ' s web hosting softwares : http :// altern . org /
----------------------------------------------------------------------
LICENSE
2006-08-12 00:04:12 +00:00
2007-08-26 20:06:39 +00:00
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 .
2006-08-12 00:04:12 +00:00
2007-08-26 20:06:39 +00:00
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
Purpose of file : Manage allowed TLD on the server
----------------------------------------------------------------------
*/
require_once ( " ../class/config.php " );
2009-09-08 05:29:38 +00:00
include_once ( " head.php " );
2012-08-21 08:06:04 +00:00
if ( ! $admin -> enabled ) {
__ ( " This page is restricted to authorized staff " );
exit ;
}
$fields = array (
" uid " => array ( " request " , " integer " , " " ),
" submit " => array ( " post " , " string " , " " ),
" redirect " => array ( " post " , " string " , " " ),
);
getFields ( $fields );
2006-08-12 00:04:12 +00:00
if ( ! $uid ) {
2013-02-08 14:09:40 +00:00
__ ( " Account not found " );
2009-09-08 05:29:38 +00:00
include_once ( " foot.php " );
2006-08-12 00:04:12 +00:00
exit ();
}
2012-08-21 08:06:04 +00:00
if ( ! $admin -> checkcreator ( $uid )) {
2006-08-12 00:04:12 +00:00
__ ( " This page is restricted to authorized staff " );
2009-09-08 05:29:38 +00:00
include_once ( " foot.php " );
2006-08-12 00:04:12 +00:00
exit ();
}
if ( ! $r = $admin -> get ( $uid )) {
__ ( " User does not exist " );
2009-09-08 05:29:38 +00:00
include_once ( " foot.php " );
2006-08-12 00:04:12 +00:00
exit ();
}
2012-08-21 08:06:04 +00:00
$confirmed = ( $submit == _ ( " Confirm " )) ? true : false ;
if ( ! ( $confirmed ) ) {
2006-08-12 00:04:12 +00:00
print '<h2>' . _ ( 'WARNING: experimental feature, use at your own risk' ) . '</h2>' ;
__ ( " The following domains will be deactivated and redirected to the URL entered in the following box. A backup of the domain configuration will be displayed as a serie of SQL request that you can run to restore the current configuration if you want. Click confirm if you are sure you want to deactivate all this user's domains. " );
?>
2012-08-21 08:06:04 +00:00
< form action = " <?php echo $_SERVER['PHP_SELF'] ;?> " method = " POST " >
2012-08-20 08:49:22 +00:00
< input type = " hidden " name = " uid " value = " <?php echo $uid ?> " />
< ? php __ ( " Redirection URL: " ) ?> <input type="text" name="redirect" class="int" value="http://example.com/" />
< input type = " submit " name = " submit " class = " inb " value = " <?php __( " Confirm " )?> " />
2010-04-29 10:43:32 +00:00
< input type = " button " class = " inb " name = " cancel " value = " <?php __( " Cancel " ); ?> " onclick = " document.location='adm_list.php' " />
2006-08-12 00:04:12 +00:00
</ form >< ? php
print " <h3> " . _ ( " Domains of user: " ) . $r [ " login " ] . " </h3> " ;
} else {
2012-08-21 08:06:04 +00:00
if ( empty ( $redirect )) {
2006-08-12 00:04:12 +00:00
__ ( " Missing redirect url. " );
2009-09-08 05:29:38 +00:00
include_once ( " foot.php " );
2006-08-12 00:04:12 +00:00
exit ();
2012-08-21 08:06:04 +00:00
}
2006-08-12 00:04:12 +00:00
}
# this string will contain an SQL request that will be printed at the end of the process and that can be used to reload the old domain configuration
$backup = " " ;
# 1. list the domains of the user
# 1.1 list the domains
global $cuid ;
$old_cuid = $cuid ;
$cuid = $uid ;
$domains = $dom -> enum_domains ();
if ( $confirmed ) {
print " <pre> " ;
printf ( _ ( " -- Redirecting all domains and subdomains of the user %s to %s \n " ), $r [ 'login' ], $redirect );
}
reset ( $domains );
# 1.2 foreach domain, list the subdomains
foreach ( $domains as $key => $domain ) {
if ( ! $confirmed ) print '<h4>' . $domain . '</h4><ul>' ;
$dom -> lock ();
if ( ! $r = $dom -> get_domain_all ( $domain )) {
$error = $err -> errstr ();
}
$dom -> unlock ();
# 2. for each subdomain
2010-04-29 10:43:32 +00:00
if ( is_array ( $r [ 'sub' ])) {
foreach ( $r [ 'sub' ] as $k => $sub ) {
# shortcuts
$type = $sub [ 'type' ];
$dest = $sub [ 'dest' ];
$sub = $sub [ 'name' ];
# if it's a real website
if ( $type == $dom -> type_local ) {
if ( ! $confirmed ) {
print " <li> " ;
if ( $sub ) {
print $sub . '.' ;
}
print " $domain -> $dest </li> " ;
} else {
# 2.1 keep a copy of where it was, in an SQL request
2014-09-24 22:05:47 +00:00
$backup .= " UPDATE `sub_domaines` SET `type`=' $type ', valeur=' $dest ',web_action='UPDATE' WHERE id= " . $r [ 'sub' ][ $k ][ 'id' ] . " ; \n " ;
2010-04-29 10:43:32 +00:00
# 2.2 change the subdomain to redirect to http://spam.koumbit.org/
$dom -> lock ();
2014-09-24 22:05:47 +00:00
if ( ! $db -> query ( " UPDATE `sub_domaines` SET `type`=' " . $dom -> type_url . " ', valeur=' $redirect ',web_action='UPDATE' WHERE id= " . $r [ 'sub' ][ $k ][ 'id' ] . " ; \n " ) ) {
2010-04-29 10:43:32 +00:00
print " -- error in $sub . $domain : " . $err -> errstr () . " \n " ;
}
$dom -> unlock ();
2006-08-12 00:04:12 +00:00
}
}
}
}
if ( ! $confirmed ) print '</ul>' ;
}
2014-10-13 23:08:32 +00:00
$mail_dom = $mail -> enum_domains ();
2014-09-24 22:05:47 +00:00
if ( $confirmed ) {
print " <pre> " ;
printf ( _ ( " -- disabling all the mail passwords \n " ));
}
if ( ! $confirmed ) print " \n <li>mailboxes<ul> \n " ;
reset ( $mail_dom );
# 1.3 foreach mail domain, we list the email hashes
foreach ( $mail_dom as $key => $domain ) {
if ( ! $confirmed ) print '' . $domain [ 'domaine' ] . '</h4><ul>' ;
2014-10-13 23:08:32 +00:00
$mails = $mail -> enum_domain_mails ( $domain [ 'id' ]);
foreach ( $mails as $key => $add ) {
if ( $add [ 'islocal' ]) {
if ( ! $confirmed ) print '<li>' . $add [ 'address' ] . '@' . $domain [ 'domaine' ];
$pass = $add [ 'password' ];
$id = $add [ 'id' ];
2014-10-13 23:10:00 +00:00
$backup .= $b = " update address set password=' $pass ' where id= $id ; \n " ;
2014-09-24 22:05:47 +00:00
if ( ! $confirmed ) print " <!-- $b --></li> \n " ;
if ( $confirmed ) {
2014-10-13 23:10:00 +00:00
$db -> query ( " update `address` set password='! $pass ' where id= $id ; \n " );
2014-09-24 22:05:47 +00:00
}
}
}
2014-10-13 23:08:32 +00:00
if ( ! $confirmed ) print " </ul> " ;
2014-09-24 22:05:47 +00:00
}
if ( ! $confirmed ) print " </ul></li></ul> \n " ;
2006-08-12 00:04:12 +00:00
# 3. wrap up (?)
if ( $confirmed ) {
print " -- The following is a serie of SQL request you can run, as root, to revert the user's domains to their previous state. \n " ;
print $backup ;
print " </pre> " ;
}
$cuid = $old_cuid ;
2007-08-26 20:06:39 +00:00
2009-09-08 05:29:38 +00:00
include_once ( " foot.php " );
2007-08-26 20:06:39 +00:00
?>