2005-12-08 08:40:10 +00:00
< ? php
// $Id$
2006-01-21 01:42:52 +00:00
define ( 'SCHEMA_UNINSTALLED' , - 1 );
define ( 'SCHEMA_INSTALLED' , 0 );
2005-12-08 08:40:10 +00:00
2006-09-01 09:23:45 +00:00
define ( 'REQUIREMENT_INFO' , - 1 );
2006-09-01 08:44:53 +00:00
define ( 'REQUIREMENT_OK' , 0 );
define ( 'REQUIREMENT_WARNING' , 1 );
define ( 'REQUIREMENT_ERROR' , 2 );
2005-12-08 08:40:10 +00:00
2006-07-13 13:14:25 +00:00
define ( 'FILE_EXIST' , 1 );
define ( 'FILE_READABLE' , 2 );
define ( 'FILE_WRITABLE' , 4 );
define ( 'FILE_EXECUTABLE' , 8 );
define ( 'FILE_NOT_EXIST' , 16 );
define ( 'FILE_NOT_READABLE' , 32 );
define ( 'FILE_NOT_WRITABLE' , 64 );
define ( 'FILE_NOT_EXECUTABLE' , 128 );
2005-12-08 08:40:10 +00:00
2006-07-31 19:24:16 +00:00
/**
* Initialize the update system by loading all installed module ' s . install files .
*/
function drupal_load_updates () {
2006-07-13 13:14:25 +00:00
foreach ( module_list () as $module ) {
2006-08-03 01:02:51 +00:00
module_load_install ( $module );
2005-12-08 08:40:10 +00:00
}
}
/**
2006-04-11 11:33:15 +00:00
* Returns an array of available schema versions for a module .
2005-12-08 08:40:10 +00:00
*
* @ param $module
* A module name .
* @ return
* If the module has updates , an array of available updates . Otherwise ,
* FALSE .
*/
function drupal_get_schema_versions ( $module ) {
2006-11-21 19:56:52 +00:00
$updates = array ();
2005-12-09 15:46:47 +00:00
$functions = get_defined_functions ();
foreach ( $functions [ 'user' ] as $function ) {
2005-12-09 16:14:26 +00:00
if ( strpos ( $function , $module . '_update_' ) === 0 ) {
$version = substr ( $function , strlen ( $module . '_update_' ));
if ( is_numeric ( $version )) {
$updates [] = $version ;
}
2005-12-09 15:46:47 +00:00
}
2005-12-08 08:40:10 +00:00
}
2005-12-09 15:46:47 +00:00
if ( count ( $updates ) == 0 ) {
return FALSE ;
2005-12-08 08:40:10 +00:00
}
2005-12-09 15:46:47 +00:00
return $updates ;
2005-12-08 08:40:10 +00:00
}
/**
* Returns the currently installed schema version for a module .
*
* @ param $module
* A module name .
* @ return
* The currently installed schema version .
*/
function drupal_get_installed_schema_version ( $module , $reset = FALSE ) {
2007-02-04 21:21:44 +00:00
static $versions = array ();
2005-12-08 08:40:10 +00:00
if ( $reset ) {
2007-02-04 21:21:44 +00:00
$versions = array ();
2005-12-08 08:40:10 +00:00
}
if ( ! $versions ) {
$versions = array ();
2007-08-22 08:36:34 +00:00
$result = db_query ( " SELECT name, schema_version FROM { system} WHERE type = '%s' " , 'module' );
2005-12-08 08:40:10 +00:00
while ( $row = db_fetch_object ( $result )) {
$versions [ $row -> name ] = $row -> schema_version ;
}
}
return $versions [ $module ];
}
/**
* Update the installed version information for a module .
*
* @ param $module
* A module name .
* @ param $version
* The new schema version .
*/
function drupal_set_installed_schema_version ( $module , $version ) {
db_query ( " UPDATE { system} SET schema_version = %d WHERE name = '%s' " , $version , $module );
}
2006-07-13 13:14:25 +00:00
/**
* Loads the profile definition , extracting the profile ' s defined name .
*
* @ return
* The name defined in the profile ' s _profile_details () hook .
*/
function drupal_install_profile_name () {
global $profile ;
static $name = NULL ;
if ( ! isset ( $name )) {
// Load profile details.
$function = $profile . '_profile_details' ;
if ( function_exists ( $function )) {
$details = $function ();
}
$name = isset ( $details [ 'name' ]) ? $details [ 'name' ] : 'Drupal' ;
}
return $name ;
}
/**
* Auto detect the base_url with PHP predefined variables .
*
* @ param $file
* The name of the file calling this function so we can strip it out of
* the URI when generating the base_url .
*
* @ return
* The auto - detected $base_url that should be configured in settings . php
*/
function drupal_detect_baseurl ( $file = 'install.php' ) {
global $profile ;
$proto = $_SERVER [ 'HTTPS' ] ? 'https://' : 'http://' ;
$host = $_SERVER [ 'SERVER_NAME' ];
$port = ( $_SERVER [ 'SERVER_PORT' ] == 80 ? '' : ':' . $_SERVER [ 'SERVER_PORT' ]);
2006-09-01 08:44:53 +00:00
$uri = preg_replace ( " / \ ?.*/ " , '' , $_SERVER [ 'REQUEST_URI' ]);
2006-07-13 13:14:25 +00:00
$dir = str_replace ( " / $file " , '' , $uri );
return " $proto $host $port $dir " ;
}
/**
* Detect all databases supported by Drupal that are compiled into the current
* PHP installation .
*
* @ return
* An array of database types compiled into PHP .
*/
function drupal_detect_database_types () {
$databases = array ();
foreach ( array ( 'mysql' , 'mysqli' , 'pgsql' ) as $type ) {
if ( file_exists ( './includes/install.' . $type . '.inc' )) {
include_once './includes/install.' . $type . '.inc' ;
$function = $type . '_is_available' ;
if ( $function ()) {
$databases [ $type ] = $type ;
}
}
}
return $databases ;
}
/**
* Read settings . php into a buffer line by line , changing values specified in
* $settings array , then over - writing the old settings . php file .
*
* @ param $settings
* An array of settings that need to be updated .
*/
function drupal_rewrite_settings ( $settings = array (), $prefix = '' ) {
2007-05-08 16:36:55 +00:00
$default_settings = './sites/default/default.settings.php' ;
2007-07-30 19:22:47 +00:00
$settings_file = './' . conf_path ( FALSE , TRUE ) . '/' . $prefix . 'settings.php' ;
2006-07-13 13:14:25 +00:00
// Build list of setting names and insert the values into the global namespace.
$keys = array ();
foreach ( $settings as $setting => $data ) {
$GLOBALS [ $setting ] = $data [ 'value' ];
$keys [] = $setting ;
}
$buffer = NULL ;
$first = TRUE ;
2007-05-08 16:36:55 +00:00
if ( $fp = fopen ( $default_settings , 'r' )) {
2006-07-13 13:14:25 +00:00
// Step line by line through settings.php.
while ( ! feof ( $fp )) {
$line = fgets ( $fp );
if ( $first && substr ( $line , 0 , 5 ) != '<?php' ) {
$buffer = " <?php \n \n " ;
}
$first = FALSE ;
// Check for constants.
if ( substr ( $line , 0 , 7 ) == 'define(' ) {
preg_match ( '/define\(\s*[\'"]([A-Z_-]+)[\'"]\s*,(.*?)\);/' , $line , $variable );
if ( in_array ( $variable [ 1 ], $keys )) {
$setting = $settings [ $variable [ 1 ]];
$buffer .= str_replace ( $variable [ 2 ], " ' " . $setting [ 'value' ] . " ' " , $line );
unset ( $settings [ $variable [ 1 ]]);
unset ( $settings [ $variable [ 2 ]]);
}
else {
$buffer .= $line ;
}
}
// Check for variables.
elseif ( substr ( $line , 0 , 1 ) == '$' ) {
preg_match ( '/\$([^ ]*) /' , $line , $variable );
if ( in_array ( $variable [ 1 ], $keys )) {
// Write new value to settings.php in the following format:
// $'setting' = 'value'; // 'comment'
$setting = $settings [ $variable [ 1 ]];
2007-03-27 05:13:55 +00:00
$buffer .= '$' . $variable [ 1 ] . " = ' " . $setting [ 'value' ] . " '; " . ( ! empty ( $setting [ 'comment' ]) ? ' // ' . $setting [ 'comment' ] . " \n " : " \n " );
2006-07-13 13:14:25 +00:00
unset ( $settings [ $variable [ 1 ]]);
}
else {
$buffer .= $line ;
}
}
else {
$buffer .= $line ;
}
}
fclose ( $fp );
// Add required settings that were missing from settings.php.
foreach ( $settings as $setting => $data ) {
if ( $data [ 'required' ]) {
$buffer .= " \$ $setting = ' " . $data [ 'value' ] . " '; \n " ;
}
}
$fp = fopen ( $settings_file , 'w' );
if ( $fp && fwrite ( $fp , $buffer ) === FALSE ) {
drupal_set_message ( st ( 'Failed to modify %settings, please verify the file permissions.' , array ( '%settings' => $settings_file )), 'error' );
}
}
else {
drupal_set_message ( st ( 'Failed to open %settings, please verify the file permissions.' , array ( '%settings' => $settings_file )), 'error' );
}
}
/**
* Get list of all . install files .
*
* @ param $module_list
* An array of modules to search for their . install files .
*/
function drupal_get_install_files ( $module_list = array ()) {
$installs = array ();
foreach ( $module_list as $module ) {
$installs = array_merge ( $installs , file_scan_directory ( './modules' , " ^ $module .install $ " , array ( '.' , '..' , 'CVS' ), 0 , TRUE , 'name' , 0 ));
}
return $installs ;
}
/**
2006-08-03 01:02:51 +00:00
* Verify a profile for installation .
2006-07-13 13:14:25 +00:00
*
* @ param profile
2006-08-03 01:02:51 +00:00
* Name of profile to verify .
2006-09-01 05:38:40 +00:00
* @ param locale
* Name of locale used ( if any ) .
2006-08-03 01:02:51 +00:00
* @ return
* The list of modules to install .
2006-07-13 13:14:25 +00:00
*/
2006-09-01 05:38:40 +00:00
function drupal_verify_profile ( $profile , $locale ) {
2006-07-13 13:14:25 +00:00
include_once './includes/file.inc' ;
2006-10-23 06:45:17 +00:00
include_once './includes/common.inc' ;
2006-07-13 13:14:25 +00:00
2006-08-08 21:18:04 +00:00
$profile_file = " ./profiles/ $profile / $profile .profile " ;
2006-07-13 13:14:25 +00:00
if ( ! isset ( $profile ) || ! file_exists ( $profile_file )) {
2006-08-23 08:25:44 +00:00
install_no_profile_error ();
2006-07-13 13:14:25 +00:00
}
require_once ( $profile_file );
// Get a list of modules required by this profile.
$function = $profile . '_profile_modules' ;
2007-05-21 10:56:05 +00:00
$module_list = array_merge ( drupal_required_modules (), $function (), ( $locale != 'en' ? array ( 'locale' ) : array ()));
2006-08-03 07:06:36 +00:00
2006-10-23 06:45:17 +00:00
// Get a list of modules that exist in Drupal's assorted subdirectories.
$present_modules = array ();
2007-01-02 05:05:38 +00:00
foreach ( drupal_system_listing ( '\.module$' , 'modules' , 'name' , 0 ) as $present_module ) {
2006-10-23 06:45:17 +00:00
$present_modules [] = $present_module -> name ;
}
// Verify that all of the profile's required modules are present.
$missing_modules = array_diff ( $module_list , $present_modules );
if ( count ( $missing_modules )) {
2007-01-02 05:05:38 +00:00
foreach ( $missing_modules as $module ) {
2006-08-03 01:02:51 +00:00
drupal_set_message ( st ( 'The %module module is required but was not found. Please move it into the <em>modules</em> subdirectory.' , array ( '%module' => $module )), 'error' );
}
}
2006-10-23 06:45:17 +00:00
else {
return $module_list ;
}
2006-08-03 01:02:51 +00:00
}
2006-07-29 17:56:41 +00:00
2006-08-03 01:02:51 +00:00
/**
* Install a profile ( i . e . a set of modules ) from scratch .
* The profile must be verified first using drupal_verify_profile () .
*
* @ param profile
* The name of the profile to install .
* @ param module_list
* An array of modules to install .
*/
function drupal_install_profile ( $profile , $module_list ) {
// The system module is a special case; we can't bootstrap until it's
// installed, so we can't use the normal installation function.
$module_list = array_diff ( $module_list , array ( 'system' ));
2006-11-24 10:16:50 +00:00
$system_path = dirname ( drupal_get_filename ( 'module' , 'system' , NULL ));
2007-04-13 08:56:59 +00:00
require_once './' . $system_path . '/system.install' ;
2006-08-03 01:02:51 +00:00
module_invoke ( 'system' , 'install' );
$system_versions = drupal_get_schema_versions ( 'system' );
$system_version = $system_versions ? max ( $system_versions ) : SCHEMA_INSTALLED ;
2007-08-22 08:36:34 +00:00
db_query ( " INSERT INTO { system} (filename, name, type, owner, status, throttle, bootstrap, schema_version) VALUES('%s', '%s', '%s', '%s', %d, %d, %d, %d) " , $system_path . '/system.module' , 'system' , 'module' , '' , 1 , 0 , 0 , $system_version );
2006-08-03 01:02:51 +00:00
// Now that we've installed things properly, bootstrap the full Drupal environment
2006-07-19 07:45:35 +00:00
drupal_bootstrap ( DRUPAL_BOOTSTRAP_FULL );
// Install schemas for profile and all its modules.
2006-08-03 01:02:51 +00:00
module_rebuild_cache ();
drupal_install_modules ( $module_list );
2006-07-19 07:45:35 +00:00
}
/**
2006-11-16 08:28:08 +00:00
* Calls the install function and updates the system table for a given list of
* modules .
2006-07-19 07:45:35 +00:00
*
* @ param module_list
2006-08-03 01:02:51 +00:00
* The modules to install .
2006-07-19 07:45:35 +00:00
*/
2006-08-03 01:02:51 +00:00
function drupal_install_modules ( $module_list = array ()) {
2006-11-16 08:28:08 +00:00
$enable_modules = array ();
2006-08-03 01:02:51 +00:00
foreach ( $module_list as $module ) {
2006-11-16 08:28:08 +00:00
if ( drupal_get_installed_schema_version ( $module , TRUE ) == SCHEMA_UNINSTALLED ) {
module_load_install ( $module );
module_invoke ( $module , 'install' );
$versions = drupal_get_schema_versions ( $module );
drupal_set_installed_schema_version ( $module , $versions ? max ( $versions ) : SCHEMA_INSTALLED );
$enable_modules [] = $module ;
}
2006-07-13 13:14:25 +00:00
}
2006-11-16 08:28:08 +00:00
module_enable ( $enable_modules );
2006-07-13 13:14:25 +00:00
}
2006-09-01 07:40:08 +00:00
/**
* Calls the uninstall function and updates the system table for a given module .
*
* @ param $module
* The module to uninstall .
*/
function drupal_uninstall_module ( $module ) {
module_load_install ( $module );
module_invoke ( $module , 'uninstall' );
2007-08-30 19:54:22 +00:00
2007-08-29 20:46:18 +00:00
// Remove menu links for paths declared by this module.
drupal_load ( 'module' , $module );
$paths = module_invoke ( $module , 'menu' );
if ( ! empty ( $paths )) {
$paths = array_keys ( $paths );
// Clean out the names of load functions.
2007-09-04 21:10:45 +00:00
foreach ( $paths as $index => $path ) {
2007-08-29 20:46:18 +00:00
$parts = explode ( '/' , $path , MENU_MAX_PARTS );
foreach ( $parts as $k => $part ) {
if ( preg_match ( '/^%[a-z_]*$/' , $part )) {
$parts [ $k ] = '%' ;
}
}
$paths [ $index ] = implode ( '/' , $parts );
}
$placeholders = implode ( ', ' , array_fill ( 0 , count ( $paths ), " '%s' " ));
2007-08-30 19:54:22 +00:00
2007-08-29 20:46:18 +00:00
$result = db_query ( 'SELECT * FROM {menu_links} WHERE router_path IN (' . $placeholders . ') AND external = 0 ORDER BY depth DESC' , $paths );
// Remove all such items. Starting from those with the greatest depth will
// minimize the amount of re-parenting done by menu_link_delete().
while ( $item = db_fetch_array ( $result )) {
_menu_delete_item ( $item , TRUE );
}
}
2006-09-01 07:40:08 +00:00
drupal_set_installed_schema_version ( $module , SCHEMA_UNINSTALLED );
}
2006-07-13 13:14:25 +00:00
/**
* Verify the state of the specified file .
*
* @ param $file
* The file to check for .
* @ param $mask
* An optional bitmask created from various FILE_ * constants .
* @ param $type
* The type of file . Can be file ( default ), dir , or link .
* @ return
2006-12-05 05:47:37 +00:00
* TRUE on success or FALSE on failure . A message is set for the latter .
2006-07-13 13:14:25 +00:00
*/
function drupal_verify_install_file ( $file , $mask = NULL , $type = 'file' ) {
$return = TRUE ;
// Check for files that shouldn't be there.
if ( isset ( $mask ) && ( $mask & FILE_NOT_EXIST ) && file_exists ( $file )) {
return FALSE ;
}
// Verify that the file is the type of file it is supposed to be.
if ( isset ( $type ) && file_exists ( $file )) {
$check = 'is_' . $type ;
if ( ! function_exists ( $check ) || ! $check ( $file )) {
$return = FALSE ;
}
}
// Verify file permissions.
if ( isset ( $mask )) {
$masks = array ( FILE_EXIST , FILE_READABLE , FILE_WRITABLE , FILE_EXECUTABLE , FILE_NOT_READABLE , FILE_NOT_WRITABLE , FILE_NOT_EXECUTABLE );
foreach ( $masks as $current_mask ) {
if ( $mask & $current_mask ) {
switch ( $current_mask ) {
case FILE_EXIST :
if ( ! file_exists ( $file )) {
if ( $type == 'dir' ) {
drupal_install_mkdir ( $file , $mask );
}
if ( ! file_exists ( $file )) {
$return = FALSE ;
}
}
break ;
case FILE_READABLE :
if ( ! is_readable ( $file ) && ! drupal_install_fix_file ( $file , $mask )) {
$return = FALSE ;
}
break ;
case FILE_WRITABLE :
if ( ! is_writable ( $file ) && ! drupal_install_fix_file ( $file , $mask )) {
$return = FALSE ;
}
break ;
case FILE_EXECUTABLE :
if ( ! is_executable ( $file ) && ! drupal_install_fix_file ( $file , $mask )) {
$return = FALSE ;
}
break ;
case FILE_NOT_READABLE :
if ( is_readable ( $file ) && ! drupal_install_fix_file ( $file , $mask )) {
$return = FALSE ;
}
break ;
case FILE_NOT_WRITABLE :
if ( is_writable ( $file ) && ! drupal_install_fix_file ( $file , $mask )) {
$return = FALSE ;
}
break ;
case FILE_NOT_EXECUTABLE :
if ( is_executable ( $file ) && ! drupal_install_fix_file ( $file , $mask )) {
$return = FALSE ;
}
break ;
}
}
}
}
return $return ;
}
/**
* Create a directory with specified permissions .
*
* @ param file
* The name of the directory to create ;
* @ param mask
* The permissions of the directory to create .
* @ param $message
* ( optional ) Whether to output messages . Defaults to TRUE .
*
* @ return
* TRUE / FALSE whether or not the directory was successfully created .
*/
function drupal_install_mkdir ( $file , $mask , $message = TRUE ) {
$mod = 0 ;
$masks = array ( FILE_READABLE , FILE_WRITABLE , FILE_EXECUTABLE , FILE_NOT_READABLE , FILE_NOT_WRITABLE , FILE_NOT_EXECUTABLE );
foreach ( $masks as $m ) {
if ( $mask & $m ) {
switch ( $m ) {
case FILE_READABLE :
$mod += 444 ;
break ;
case FILE_WRITABLE :
$mod += 222 ;
break ;
case FILE_EXECUTABLE :
$mod += 111 ;
break ;
}
}
}
if ( @ mkdir ( $file , intval ( " 0 $mod " , 8 ))) {
return TRUE ;
}
else {
return FALSE ;
}
}
/**
* Attempt to fix file permissions .
*
2006-12-08 11:54:04 +00:00
* The general approach here is that , because we do not know the security
* setup of the webserver , we apply our permission changes to all three
* digits of the file permission ( i . e . user , group and all ) .
*
* To ensure that the values behave as expected ( and numbers don ' t carry
* from one digit to the next ) we do the calculation on the octal value
* using bitwise operations . This lets us remove , for example , 0222 from
* 0700 and get the correct value of 0500.
*
2006-07-13 13:14:25 +00:00
* @ param $file
* The name of the file with permissions to fix .
* @ param $mask
* The desired permissions for the file .
* @ param $message
* ( optional ) Whether to output messages . Defaults to TRUE .
*
* @ return
* TRUE / FALSE whether or not we were able to fix the file ' s permissions .
*/
function drupal_install_fix_file ( $file , $mask , $message = TRUE ) {
2006-12-08 11:54:04 +00:00
$mod = fileperms ( $file ) & 0777 ;
2006-07-13 13:14:25 +00:00
$masks = array ( FILE_READABLE , FILE_WRITABLE , FILE_EXECUTABLE , FILE_NOT_READABLE , FILE_NOT_WRITABLE , FILE_NOT_EXECUTABLE );
2006-12-08 11:54:04 +00:00
// FILE_READABLE, FILE_WRITABLE, and FILE_EXECUTABLE permission strings
// can theoretically be 0400, 0200, and 0100 respectively, but to be safe
// we set all three access types in case the administrator intends to
// change the owner of settings.php after installation.
2006-07-13 13:14:25 +00:00
foreach ( $masks as $m ) {
if ( $mask & $m ) {
switch ( $m ) {
case FILE_READABLE :
if ( ! is_readable ( $file )) {
2006-12-08 11:54:04 +00:00
$mod |= 0444 ;
2006-07-13 13:14:25 +00:00
}
break ;
case FILE_WRITABLE :
if ( ! is_writable ( $file )) {
2006-12-08 11:54:04 +00:00
$mod |= 0222 ;
2006-07-13 13:14:25 +00:00
}
break ;
case FILE_EXECUTABLE :
if ( ! is_executable ( $file )) {
2006-12-08 11:54:04 +00:00
$mod |= 0111 ;
2006-07-13 13:14:25 +00:00
}
break ;
case FILE_NOT_READABLE :
if ( is_readable ( $file )) {
2006-12-08 11:54:04 +00:00
$mod &= ~ 0444 ;
2006-07-13 13:14:25 +00:00
}
break ;
case FILE_NOT_WRITABLE :
if ( is_writable ( $file )) {
2006-12-08 11:54:04 +00:00
$mod &= ~ 0222 ;
2006-07-13 13:14:25 +00:00
}
break ;
case FILE_NOT_EXECUTABLE :
if ( is_executable ( $file )) {
2006-12-08 11:54:04 +00:00
$mod &= ~ 0111 ;
2006-07-13 13:14:25 +00:00
}
break ;
}
}
}
2006-12-08 11:54:04 +00:00
// chmod() will work if the web server is running as owner of the file.
// If PHP safe_mode is enabled the currently executing script must also
// have the same owner.
if ( @ chmod ( $file , $mod )) {
2006-07-13 13:14:25 +00:00
return TRUE ;
}
else {
return FALSE ;
}
}
2006-07-31 19:24:16 +00:00
/**
* Send the user to a different installer page . This issues an on - site HTTP
* redirect . Messages ( and errors ) are erased .
*
* @ param $path
* An installer path .
*/
function install_goto ( $path ) {
2006-10-12 15:20:08 +00:00
global $base_url ;
2007-04-13 08:56:59 +00:00
header ( 'Location: ' . $base_url . '/' . $path );
2007-09-07 10:48:24 +00:00
header ( 'Cache-Control: no-cache' ); // Not a permanent redirect.
2006-07-31 19:24:16 +00:00
exit ();
}
2006-07-13 13:14:25 +00:00
/**
2007-11-11 16:14:45 +00:00
* Hardcoded function for doing the equivalent of t () during
* the install process , when database , theme , and localization
* system is possibly not yet available .
2006-07-13 13:14:25 +00:00
*/
function st ( $string , $args = array ()) {
2006-09-01 05:38:40 +00:00
static $locale_strings = NULL ;
global $profile , $install_locale ;
if ( ! isset ( $locale_strings )) {
$locale_strings = array ();
2007-06-13 19:39:04 +00:00
$filename = './profiles/' . $profile . '/translations/' . $install_locale . '.po' ;
2006-09-01 05:38:40 +00:00
if ( file_exists ( $filename )) {
require_once './includes/locale.inc' ;
$file = ( object ) array ( 'filepath' => $filename );
_locale_import_read_po ( 'mem-store' , $file );
$locale_strings = _locale_import_one_string ( 'mem-report' );
}
}
2006-07-13 13:14:25 +00:00
require_once './includes/theme.inc' ;
2006-08-18 12:17:00 +00:00
$GLOBALS [ 'theme' ] = 'theme' ;
// Transform arguments before inserting them
2007-01-02 05:05:38 +00:00
foreach ( $args as $key => $value ) {
2006-09-07 08:23:54 +00:00
switch ( $key [ 0 ]) {
// Escaped only
case '@' :
$args [ $key ] = check_plain ( $value );
break ;
// Escaped and placeholder
case '%' :
default :
$args [ $key ] = '<em>' . check_plain ( $value ) . '</em>' ;
break ;
// Pass-through
case '!' :
}
2006-08-18 12:17:00 +00:00
}
2006-09-07 08:23:54 +00:00
return strtr (( ! empty ( $locale_strings [ $string ]) ? $locale_strings [ $string ] : $string ), $args );
2006-08-08 21:18:04 +00:00
}
2006-09-01 08:44:53 +00:00
2006-11-28 03:32:03 +00:00
/**
* Converts a set of tables to UTF - 8 encoding .
*
* This update is designed to be re - usable by contrib modules and is
* used by system_update_169 () .
*/
function _system_update_utf8 ( $tables ) {
// Are we starting this update for the first time?
if ( ! isset ( $_SESSION [ 'update_utf8' ])) {
switch ( $GLOBALS [ 'db_type' ]) {
// Only for MySQL 4.1+
case 'mysqli' :
break ;
case 'mysql' :
if ( version_compare ( mysql_get_server_info ( $GLOBALS [ 'active_db' ]), '4.1.0' , '<' )) {
return array ();
}
break ;
case 'pgsql' :
return array ();
}
// See if database uses UTF-8 already
global $db_url ;
$url = parse_url ( is_array ( $db_url ) ? $db_url [ 'default' ] : $db_url );
$db_name = substr ( $url [ 'path' ], 1 );
$result = db_fetch_array ( db_query ( 'SHOW CREATE DATABASE `%s`' , $db_name ));
if ( preg_match ( '/utf8/i' , array_pop ( $result ))) {
return array ();
}
// Make list of tables to convert
$_SESSION [ 'update_utf8' ] = $tables ;
// Keep track of total for progress bar
$_SESSION [ 'update_utf8_total' ] = count ( $tables );
}
// Fetch remaining tables list and convert next table
$list = & $_SESSION [ 'update_utf8' ];
$ret = update_convert_table_utf8 ( array_shift ( $list ));
// Are we done?
if ( count ( $list ) == 0 ) {
unset ( $_SESSION [ 'update_utf8' ]);
unset ( $_SESSION [ 'update_utf8_total' ]);
return $ret ;
}
// Progress percentage
$ret [ '#finished' ] = 1 - ( count ( $list ) / $_SESSION [ 'update_utf8_total' ]);
return $ret ;
}
2006-09-01 08:44:53 +00:00
/**
* Check a profile ' s requirements .
*
* @ param profile
* Name of profile to check .
*/
function drupal_check_profile ( $profile ) {
include_once './includes/file.inc' ;
$profile_file = " ./profiles/ $profile / $profile .profile " ;
if ( ! isset ( $profile ) || ! file_exists ( $profile_file )) {
install_no_profile_error ();
}
require_once ( $profile_file );
// Get a list of modules required by this profile.
$function = $profile . '_profile_modules' ;
2007-02-04 21:20:50 +00:00
$module_list = array_unique ( array_merge ( drupal_required_modules (), $function ()));
2006-09-01 08:44:53 +00:00
// Get a list of all .install files.
$installs = drupal_get_install_files ( $module_list );
// Collect requirement testing results
$requirements = array ();
foreach ( $installs as $install ) {
require_once $install -> filename ;
2006-09-05 02:28:11 +00:00
if ( module_hook ( $install -> name , 'requirements' )) {
$requirements = array_merge ( $requirements , module_invoke ( $install -> name , 'requirements' , 'install' ));
}
2006-09-01 08:44:53 +00:00
}
return $requirements ;
}
/**
* Extract highest severity from requirements array .
*/
function drupal_requirements_severity ( & $requirements ) {
$severity = REQUIREMENT_OK ;
foreach ( $requirements as $requirement ) {
if ( isset ( $requirement [ 'severity' ])) {
$severity = max ( $severity , $requirement [ 'severity' ]);
}
}
return $severity ;
}
/**
* Check a module ' s requirements .
*/
function drupal_check_module ( $module ) {
// Include install file
$install = drupal_get_install_files ( array ( $module ));
if ( isset ( $install [ $module ])) {
require_once $install [ $module ] -> filename ;
// Check requirements
$requirements = module_invoke ( $module , 'requirements' , 'install' );
if ( is_array ( $requirements ) && drupal_requirements_severity ( $requirements ) == REQUIREMENT_ERROR ) {
// Print any error messages
foreach ( $requirements as $requirement ) {
if ( isset ( $requirement [ 'severity' ]) && $requirement [ 'severity' ] == REQUIREMENT_ERROR ) {
drupal_set_message ( $requirement [ 'description' ] . ' (' . t ( 'Currently using !item !version' , array ( '!item' => $requirement [ 'title' ], '!version' => $requirement [ 'value' ])) . ')' , 'error' );
}
}
return FALSE ;
}
}
return TRUE ;
}