phpldapadmin/common.php

138 lines
5.0 KiB
PHP
Raw Normal View History

2009-06-30 18:07:14 +10:00
<?php
/*
* common.php
* 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 18:09:20 +10:00
// Turn on all notices and warnings. This helps us write cleaner code (we hope at least)
error_reporting( E_ALL );
// We require this version or newer (use @ to surpress errors if we are included twice)
@define( 'REQUIRED_PHP_VERSION', '4.1.0' );
2009-06-30 18:10:17 +10:00
@define( 'HTTPS_PORT', 443 );
2009-06-30 18:09:20 +10:00
// config.php might not exist (if the user hasn't configured PLA yet)
// Only include it if it does exist.
2009-06-30 18:07:14 +10:00
if( file_exists( realpath( 'config.php' ) ) ) {
2009-06-30 18:10:17 +10:00
ob_start();
2009-06-30 18:09:20 +10:00
is_readable( realpath( 'config.php' ) ) or pla_error( "Could not read config.php, its permissions are too strict." );
2009-06-30 18:07:14 +10:00
require realpath( 'config.php' );
2009-06-30 18:10:17 +10:00
ob_end_clean();
2009-06-30 18:07:14 +10:00
}
2009-06-30 18:09:20 +10:00
// General functions (pla_ldap_search(), pla_error(), get_object_attrs(), etc.)
is_readable( realpath( 'functions.php' ) )
or pla_error( "Cannot read the file 'functions.php' its permissions are too strict." );
2009-06-30 18:10:17 +10:00
ob_start();
2009-06-30 18:07:14 +10:00
require_once realpath( 'functions.php' );
2009-06-30 18:10:17 +10:00
ob_end_clean();
2009-06-30 18:09:20 +10:00
// Functions for reading the server schema (get_schema_object_classes(), etc.)
is_readable( realpath( 'schema_functions.php' ) )
or pla_error( "Cannot read the file 'schema_functions.php' its permissions are too strict." );
2009-06-30 18:10:17 +10:00
ob_start();
2009-06-30 18:07:14 +10:00
require_once realpath( 'schema_functions.php' );
2009-06-30 18:10:17 +10:00
ob_end_clean();
2009-06-30 18:07:14 +10:00
2009-06-30 18:09:20 +10:00
// Functions that can be defined by the user (preEntryDelete(), postEntryDelete(), etc.)
is_readable( realpath( 'custom_functions.php' ) )
or pla_error( "Cannot read the file 'custom_functions.php' its permissions are too strict." );
2009-06-30 18:10:17 +10:00
ob_start();
2009-06-30 18:09:20 +10:00
require_once realpath( 'custom_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();
// Little bit of sanity checking
if( ! file_exists( realpath( 'lang/recoded' ) ) ) {
pla_error( "Your install of phpLDAPadmin is missing the 'lang/recoded' directory. This should not happen. You can try running 'make' in the lang directory" );
}
// use English as a base-line (in case the selected language is missing strings)
if( file_exists( realpath( 'lang/recoded/en.php' ) ) )
include realpath( 'lang/recoded/en.php' );
else
pla_error( "Error! Missing recoded English language file. Run 'make' in the lang/ directory." );
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];
}
$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" ) ) ) {
include realpath( "lang/recoded/$HTTP_LANG.php" );
break;
}
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" ) ) ) {
include realpath( "lang/recoded/$language.php" );
} else {
pla_error( "Could not read language file 'lang/recoded/$language.php'. Either the file
does not exist, or permissions do not allow phpLDAPadmin to read it." );
}
}
}
}
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)
$templates['custom'] =
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 ) ) {
if( ! function_exists( "array_stripslashes" ) ) {
function array_stripslashes(&$array) {
if( is_array( $array ) )
while ( list( $key ) = each( $array ) )
if ( is_array( $array[$key] ) && $key != $array )
array_stripslashes( $array[$key] );
else
$array[$key] = stripslashes( $array[$key] );
}
}
array_stripslashes($_GET);
2009-06-30 18:09:20 +10:00
array_stripslashes($_POST);
array_stripslashes($_COOKIE);
2009-06-30 18:07:14 +10:00
$slashes_stripped = true;
}
?>