2009-06-30 18:07:14 +10:00
|
|
|
<?php
|
2009-06-30 19:24:29 +10:00
|
|
|
// $Header: /cvsroot/phpldapadmin/phpldapadmin/common.php,v 1.59 2005/03/16 11:20:23 wurley Exp $
|
2009-06-30 18:07:14 +10:00
|
|
|
|
2009-06-30 19:24:29 +10:00
|
|
|
/**
|
2009-06-30 18:07:14 +10:00
|
|
|
* Contains code to be executed at the top of each phpLDAPadmin page.
|
|
|
|
* include this file at the top of every PHP file.
|
2009-06-30 19:24:29 +10:00
|
|
|
*
|
|
|
|
* @package phpLDAPadmin
|
2009-06-30 18:07:14 +10:00
|
|
|
*/
|
|
|
|
|
2009-06-30 19:22:30 +10:00
|
|
|
// Work-around to get PLA to work in PHP5
|
|
|
|
if( phpversion() >= "5" )
|
|
|
|
ini_set( "zend.ze1_compatibility_mode", 1 );
|
|
|
|
|
2009-06-30 18:09:20 +10:00
|
|
|
// Turn on all notices and warnings. This helps us write cleaner code (we hope at least)
|
2009-06-30 19:22:30 +10:00
|
|
|
if( phpversion() >= "5" )
|
|
|
|
// E_DEBUG is PHP5 specific and prevents warnings about using 'var' to declar class members
|
|
|
|
error_reporting( 'E_DEBUG' );
|
|
|
|
else
|
|
|
|
// For PHP4
|
|
|
|
error_reporting( E_ALL );
|
2009-06-30 18:09:20 +10:00
|
|
|
|
2009-06-30 19:24:29 +10:00
|
|
|
/**
|
|
|
|
* For PHP5 backward/forward compatibility
|
|
|
|
*/
|
2009-06-30 19:22:30 +10:00
|
|
|
if( ! defined( 'E_STRICT' ) ) {
|
|
|
|
define( 'E_STRICT', 2048 );
|
2009-06-30 18:07:14 +10:00
|
|
|
}
|
2009-06-30 18:09:20 +10:00
|
|
|
|
2009-06-30 19:22:30 +10:00
|
|
|
/** The minimum version of PHP required to run phpLDAPadmin. */
|
|
|
|
@define( 'REQUIRED_PHP_VERSION', '4.1.0' );
|
|
|
|
/** The default setting for $search_deref if unspecified or misconfigured by user. */
|
|
|
|
@define( 'DEFAULT_SEARCH_DEREF_SETTING', LDAP_DEREF_ALWAYS );
|
|
|
|
/** The default setting for $tree_deref if unspecified or misconfigured by user. */
|
|
|
|
@define( 'DEFAULT_TREE_DEREF_SETTING', LDAP_DEREF_NEVER );
|
|
|
|
/** The default setting for $export_deref if unspecified or misconfigured by user. */
|
|
|
|
@define( 'DEFAULT_EXPORT_DEREF_SETTING', LDAP_DEREF_NEVER );
|
|
|
|
/** The default setting for $view_deref if unspecified or misconfigured by user. */
|
|
|
|
@define( 'DEFAULT_VIEW_DEREF_SETTING', LDAP_DEREF_NEVER );
|
|
|
|
|
|
|
|
// General functions needed to proceed (pla_ldap_search(), pla_error(), get_object_attrs(), etc.)
|
2009-06-30 18:10:17 +10:00
|
|
|
ob_start();
|
2009-06-30 19:22:30 +10:00
|
|
|
if( ! file_exists( realpath( './functions.php' ) ) ) {
|
|
|
|
ob_end_clean();
|
|
|
|
die( "Fatal error: Required file 'functions.php' does not exist." );
|
2009-06-30 19:24:29 +10:00
|
|
|
}
|
2009-06-30 19:22:30 +10:00
|
|
|
if( ! is_readable( realpath( './functions.php' ) ) ) {
|
|
|
|
ob_end_clean();
|
|
|
|
die( "Cannot read the file 'functions.php' its permissions are too strict." );
|
|
|
|
}
|
|
|
|
require_once realpath( './functions.php' );
|
2009-06-30 18:10:17 +10:00
|
|
|
ob_end_clean();
|
2009-06-30 18:09:20 +10:00
|
|
|
|
|
|
|
// Our custom error handler receives all error notices that pass the error_reporting()
|
|
|
|
// level set above.
|
|
|
|
set_error_handler( 'pla_error_handler' );
|
|
|
|
|
|
|
|
// Creates the language array which will be populated with localized strings
|
|
|
|
// based on the user-configured language.
|
|
|
|
$lang = array();
|
|
|
|
|
2009-06-30 19:22:30 +10:00
|
|
|
// config.php might not exist (if the user hasn't configured PLA yet)
|
|
|
|
// Only include it if it does exist.
|
|
|
|
if( file_exists( realpath( './config.php' ) ) ) {
|
|
|
|
ob_start();
|
|
|
|
is_readable( realpath( './config.php' ) ) or pla_error( "Could not read config.php, its permissions are too strict." );
|
|
|
|
include realpath( './config.php' );
|
|
|
|
ob_end_clean();
|
|
|
|
}
|
|
|
|
|
2009-06-30 19:24:29 +10:00
|
|
|
$required_files = array(
|
2009-06-30 19:22:30 +10:00
|
|
|
// The base English language strings
|
|
|
|
'./lang/recoded/en.php',
|
2009-06-30 19:24:29 +10:00
|
|
|
// Functions for talking to LDAP servers.
|
|
|
|
'./server_functions.php',
|
2009-06-30 19:22:30 +10:00
|
|
|
// Functions for managing the session (pla_session_start(), etc.)
|
2009-06-30 19:24:29 +10:00
|
|
|
'./session_functions.php',
|
2009-06-30 19:22:30 +10:00
|
|
|
// Functions for reading the server schema (get_schema_object_classes(), etc.)
|
2009-06-30 19:24:29 +10:00
|
|
|
'./schema_functions.php',
|
2009-06-30 19:22:30 +10:00
|
|
|
// Functions that can be defined by the user (preEntryDelete(), postEntryDelete(), etc.)
|
|
|
|
'./custom_functions.php',
|
|
|
|
// Functions for hashing passwords with OpenSSL binary (only if mhash not present)
|
2009-06-30 19:24:29 +10:00
|
|
|
'./emuhash_functions.php',
|
|
|
|
// Functions for sending syslog messages
|
|
|
|
'./syslog.php',
|
|
|
|
// Functions for running various hooks
|
|
|
|
'./hooks.php',
|
|
|
|
// Functions for timeout and automatic logout feature
|
|
|
|
'./timeout_functions.php' );
|
2009-06-30 19:22:30 +10:00
|
|
|
|
|
|
|
// Include each required file and check for sanity.
|
|
|
|
foreach( $required_files as $file_name ) {
|
|
|
|
file_exists( realpath( $file_name ) )
|
|
|
|
or pla_error( "Fatal error: Required file '$file_name' does not exist." );
|
2009-06-30 19:24:29 +10:00
|
|
|
is_readable( realpath( $file_name ) )
|
2009-06-30 19:22:30 +10:00
|
|
|
or pla_error( "Fatal error: Cannot read the file '$file_name', its permissions are too strict." );
|
|
|
|
ob_start();
|
|
|
|
require_once realpath( $file_name );
|
|
|
|
ob_end_clean();
|
2009-06-30 18:09:20 +10:00
|
|
|
}
|
|
|
|
|
2009-06-30 19:22:30 +10:00
|
|
|
if( pla_session_start() )
|
2009-06-30 19:24:29 +10:00
|
|
|
run_hook ( 'post_session_init', array () );
|
2009-06-30 18:07:14 +10:00
|
|
|
|
2009-06-30 18:09:20 +10:00
|
|
|
// Language configuration. Auto or specified?
|
|
|
|
// Shall we attempt to auto-determine the language?
|
|
|
|
if( isset( $language ) ) {
|
|
|
|
if( 0 == strcasecmp( $language, "auto" ) ) {
|
2009-06-30 18:10:17 +10:00
|
|
|
|
|
|
|
// Make sure their browser correctly reports language. If not, skip this.
|
|
|
|
if( isset( $_SERVER['HTTP_ACCEPT_LANGUAGE'] ) ) {
|
|
|
|
|
|
|
|
// get the languages which are spetcified in the HTTP header
|
|
|
|
$HTTP_LANGS1 = preg_split ("/[;,]+/", $_SERVER['HTTP_ACCEPT_LANGUAGE'] );
|
|
|
|
$HTTP_LANGS2 = preg_split ("/[;,]+/", $_SERVER['HTTP_ACCEPT_LANGUAGE'] );
|
|
|
|
foreach( $HTTP_LANGS2 as $key => $value ) {
|
|
|
|
$value=preg_split ("/[-]+/", $value );
|
|
|
|
$HTTP_LANGS2[$key]=$value[0];
|
|
|
|
}
|
2009-06-30 19:24:29 +10:00
|
|
|
|
2009-06-30 18:10:17 +10:00
|
|
|
$HTTP_LANGS = array_merge ($HTTP_LANGS1, $HTTP_LANGS2);
|
|
|
|
foreach( $HTTP_LANGS as $HTTP_LANG) {
|
|
|
|
// try to grab one after the other the language file
|
|
|
|
if( file_exists( realpath( "lang/recoded/$HTTP_LANG.php" ) ) &&
|
|
|
|
is_readable( realpath( "lang/recoded/$HTTP_LANG.php" ) ) ) {
|
2009-06-30 19:22:30 +10:00
|
|
|
ob_start();
|
2009-06-30 18:10:17 +10:00
|
|
|
include realpath( "lang/recoded/$HTTP_LANG.php" );
|
2009-06-30 19:22:30 +10:00
|
|
|
ob_end_clean();
|
2009-06-30 18:10:17 +10:00
|
|
|
break;
|
|
|
|
}
|
2009-06-30 18:09:20 +10:00
|
|
|
}
|
|
|
|
}
|
2009-06-30 19:24:29 +10:00
|
|
|
|
2009-06-30 18:09:20 +10:00
|
|
|
} else {
|
|
|
|
// grab the language file configured in config.php
|
|
|
|
if( $language != null ) {
|
|
|
|
if( 0 == strcmp( $language, 'english' ) )
|
|
|
|
$language = 'en';
|
|
|
|
if( file_exists( realpath( "lang/recoded/$language.php" ) ) &&
|
|
|
|
is_readable( realpath( "lang/recoded/$language.php" ) ) ) {
|
2009-06-30 19:22:30 +10:00
|
|
|
ob_start();
|
2009-06-30 18:09:20 +10:00
|
|
|
include realpath( "lang/recoded/$language.php" );
|
2009-06-30 19:22:30 +10:00
|
|
|
ob_end_clean();
|
2009-06-30 19:24:29 +10:00
|
|
|
} else {
|
|
|
|
pla_error( "Could not read language file 'lang/recoded/$language.php'. Either the file
|
2009-06-30 19:22:30 +10:00
|
|
|
does not exist, or its permissions do not allow phpLDAPadmin to read it." );
|
2009-06-30 18:09:20 +10:00
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
2009-06-30 18:07:14 +10:00
|
|
|
|
2009-06-30 18:09:20 +10:00
|
|
|
// If config.php doesn't create the templates array, create it here.
|
2009-06-30 18:07:14 +10:00
|
|
|
if( ! isset( $templates ) || ! is_array( $templates ) )
|
2009-06-30 18:09:20 +10:00
|
|
|
$templates = array();
|
2009-06-30 18:07:14 +10:00
|
|
|
|
|
|
|
// Always including the 'custom' template (the most generic and flexible)
|
2009-06-30 19:24:29 +10:00
|
|
|
$templates['custom'] =
|
2009-06-30 18:07:14 +10:00
|
|
|
array( 'desc' => 'Custom',
|
|
|
|
'icon' => 'images/object.png',
|
|
|
|
'handler' => 'custom.php' );
|
|
|
|
|
|
|
|
// Strip slashes from GET, POST, and COOKIE variables if this
|
|
|
|
// PHP install is configured to automatically addslashes()
|
|
|
|
if ( get_magic_quotes_gpc() && ( ! isset( $slashes_stripped ) || ! $slashes_stripped ) ) {
|
2009-06-30 19:24:29 +10:00
|
|
|
array_stripslashes($_REQUEST);
|
2009-06-30 18:07:14 +10:00
|
|
|
array_stripslashes($_GET);
|
2009-06-30 18:09:20 +10:00
|
|
|
array_stripslashes($_POST);
|
|
|
|
array_stripslashes($_COOKIE);
|
2009-06-30 19:22:30 +10:00
|
|
|
array_stripslashes($_FILES);
|
2009-06-30 18:07:14 +10:00
|
|
|
$slashes_stripped = true;
|
|
|
|
}
|
|
|
|
|
2009-06-30 19:24:29 +10:00
|
|
|
// Update $_SESSION[ 'activity' ]
|
|
|
|
// for timeout and automatic logout feature
|
|
|
|
if ( isset($_REQUEST['server_id']) ) {
|
|
|
|
$ldapserver = new LDAPServer($_REQUEST['server_id']);
|
|
|
|
if ( $ldapserver->haveAuthInfo() )
|
|
|
|
set_lastactivity( $ldapserver );
|
|
|
|
}
|
2009-06-30 18:07:14 +10:00
|
|
|
?>
|