186 lines
		
	
	
		
			5.4 KiB
		
	
	
	
		
			PHP
		
	
	
	
			
		
		
	
	
			186 lines
		
	
	
		
			5.4 KiB
		
	
	
	
		
			PHP
		
	
	
	
| <?php
 | |
| /*
 | |
|  $Id: config.php,v 1.12 2005/12/18 09:51:32 benjamin 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
 | |
| 
 | |
|  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
 | |
|  Purpose of file: General configuration file for AlternC Desktop
 | |
|  ----------------------------------------------------------------------
 | |
| */
 | |
| 
 | |
| /* Toutes les pages du bureau passent ici. On utilise une sémaphore pour 
 | |
|    s'assurer que personne ne pourra accéder à 2 pages du bureau en même temps.
 | |
| */
 | |
| 
 | |
| /*
 | |
|   Si vous voulez mettre le bureau en maintenance, décommentez le code ci-dessous
 | |
|   et mettez votre ip dans le IF pour que seule votre ip puisse accéder au bureau : 
 | |
| */
 | |
| 
 | |
| /* * /
 | |
| if (getenv("REMOTE_ADDR")!="127.0.0.1") {
 | |
|   echo "Le bureau AlternC est en vacances jusqu'a minuit pour maintenance.<br>
 | |
| Merci de revenir plus tard.";
 | |
|   exit();
 | |
| }
 | |
| /* */
 | |
| 
 | |
| // FIXME: Some constant, we put them here so that we can change them later ;) LFS 
 | |
| define('ALTERNC_MAIL',     "/var/alternc/mail");
 | |
| define('ALTERNC_HTML',     "/var/alternc/html");
 | |
| define('ALTERNC_PANEL',    "/var/alternc/bureau");
 | |
| define('ALTERNC_LOGS',     "/var/alternc/logs");
 | |
| define('ALTERNC_LOCALES',  "/var/alternc/bureau/locales");
 | |
| 
 | |
| // 1. Get a semaphore id for the alternc magic number (18577)
 | |
| $alternc_sem = sem_get ( 18577 );
 | |
| // 2. Declare the shutdown function, that release the semaphore
 | |
| function alternc_shutdown() {
 | |
|   global $alternc_sem;
 | |
|   @sem_release( $alternc_sem );
 | |
| }
 | |
| // 3. Register the shutdown function 
 | |
| register_shutdown_function("alternc_shutdown");
 | |
| // 4. Acquire the semaphore : with that process, 
 | |
| sem_acquire( $alternc_sem );
 | |
| 
 | |
| if (ini_get("safe_mode")) {
 | |
|   echo "SAFE MODE IS ENABLED for the web panel ! It's a bug in your php or apache configuration, please fix it !!";
 | |
|   exit();
 | |
| }
 | |
| 
 | |
| // For people who want to authenticate with HTTP AUTH
 | |
| if (isset($_GET['http_auth'])) $http_auth=strval($_GET['http_auth']);
 | |
| if (isset($http_auth) && $http_auth) {
 | |
|     if (empty($_SERVER['PHP_AUTH_USER']) || empty($_SERVER['PHP_AUTH_PW'])) {
 | |
|         header('WWW-Authenticate: Basic realm="Test Authentication System"');
 | |
|         header('HTTP/1.0 401 Unauthorized');
 | |
| 	exit();
 | |
|     }
 | |
| }
 | |
| if (!empty($_SERVER['PHP_AUTH_USER']) && !empty($_SERVER['PHP_AUTH_PW'])) {
 | |
|   // Gruiiik
 | |
|   $_REQUEST["username"]=$_SERVER['PHP_AUTH_USER'];
 | |
|   $_REQUEST["password"]=$_SERVER['PHP_AUTH_PW'];
 | |
|  }
 | |
| 
 | |
| 
 | |
| $help_baseurl="http://www.aide-alternc.org/";
 | |
| 
 | |
| /* Server Domain Name */
 | |
| $host=getenv("HTTP_HOST");
 | |
| 
 | |
| /* Global variables (AlternC configuration) */
 | |
| require_once(dirname(__FILE__)."/local.php");
 | |
| /* PHPLIB inclusions : */
 | |
| $root=ALTERNC_PANEL."/";
 | |
| 
 | |
| require_once($root."/class/db_mysql.php");
 | |
| require_once($root."/class/functions.php");
 | |
| require_once($root."class/variables.php");
 | |
| 
 | |
| // Redirection si appel à https://(!fqdn)/
 | |
| if (isset($_SERVER["HTTPS"]) && $_SERVER["HTTPS"]=="on" && $host!=$L_FQDN) {
 | |
|   header("Location: https://$L_FQDN/");
 | |
| }
 | |
| 
 | |
| 
 | |
| // Classe héritée de la classe db de la phplib.
 | |
| /**
 | |
| * Class for MySQL management in the bureau 
 | |
| *
 | |
| * This class heriting from the db class of the phplib manages
 | |
| * the connection to the MySQL database.
 | |
| */
 | |
| 
 | |
| class DB_system extends DB_Sql {
 | |
|   var $Host,$Database,$User,$Password;
 | |
| 
 | |
|   /**
 | |
|   * Creator
 | |
|   */
 | |
|   function DB_system() {
 | |
|     global $L_MYSQL_HOST,$L_MYSQL_DATABASE,$L_MYSQL_LOGIN,$L_MYSQL_PWD;
 | |
|     $this->Host     = $L_MYSQL_HOST;
 | |
|     $this->Database = $L_MYSQL_DATABASE;
 | |
|     $this->User     = $L_MYSQL_LOGIN;
 | |
|     $this->Password = $L_MYSQL_PWD;
 | |
|   }
 | |
| }
 | |
| 
 | |
| $db= new DB_system();
 | |
| 
 | |
| // Current User ID = the user whose commands are made on behalf of.
 | |
| $cuid=0;
 | |
| 
 | |
| 
 | |
| $classes=array();
 | |
| /* CLASSES PHP : automatic include : */
 | |
| $c=opendir($root."class/");
 | |
| while ($di=readdir($c)) {
 | |
|   if (preg_match("#^m_(.*)\\.php$#",$di,$match)) { // $
 | |
|     $name1="m_".$match[1];
 | |
|     $name2=$match[1];
 | |
|     $classes[]=$name2;
 | |
|     require_once($root."class/".$name1.".php");
 | |
|   }
 | |
| }
 | |
| closedir($c);
 | |
| /* THE DEFAULT CLASSES ARE :
 | |
|    dom, ftp, mail, quota, bro, admin, mem, mysql, err
 | |
| */
 | |
| 
 | |
| 
 | |
| /* Language */
 | |
| include_once("lang_env.php");
 | |
| 
 | |
| $mem=new m_mem();
 | |
| $err=new m_err();
 | |
| $authip=new m_authip();
 | |
| 
 | |
| /* Check the User identity (if required) */
 | |
| if (!defined('NOCHECK')) {
 | |
|   if (!$mem->checkid()) {
 | |
|     $error=$err->errstr();
 | |
|     include("index.php");
 | |
|     exit();
 | |
|   }
 | |
| } 
 | |
| 
 | |
| for($i=0;$i<count($classes);$i++) {
 | |
|   $name2=$classes[$i];
 | |
|   if (isset($$name2)) continue; // for already instancied class like mem, err or authip
 | |
|   $name1="m_".$name2;
 | |
|   $$name2= new $name1();
 | |
| }
 | |
| 
 | |
| $oldid=intval(isset($_COOKIE['oldid'])?$_COOKIE['oldid']:'');
 | |
| $isinvited=false;
 | |
| if ($admin->enabled) $isinvited=true;
 | |
| 
 | |
| if ($oldid && $oldid!=$cuid) {
 | |
|   $isinvited=true;
 | |
| }
 | |
| 
 | |
| ?>
 |