" . get_lang("dwl_update") . "\n";
//This is usefull when you are downloading big files, as it
//will prevent time out of the script
set_time_limit(0);
error_reporting(E_ALL);
ini_set('display_errors',true);
$baseDir = str_replace( "modules" . DIRECTORY_SEPARATOR . $_GET['m'],"",dirname(__FILE__) );
if( !is_writable( $baseDir ) )
{
if ( ! @chmod( $baseDir, 0755 ) )
{
print_failure( get_lang_f( 'base_dir_not_writable', $baseDir ) );
return;
}
}
$temp = get_temp_dir(dirname(__FILE__));
if( is_writable( $temp ) )
{
// Download file to temporary folder
$temp_dwl = $temp . DIRECTORY_SEPARATOR . $_GET['version'] . '.zip';
$dwl = $gitHubURL . REPONAME . '/archive/'.$_GET['version'].'.zip';
$zip_raw_data = file_get_contents($dwl);
if(! $zip_raw_data)
{
print_failure( get_lang_f( 'dwl_failed', $url ) );
return;
}
file_put_contents($temp_dwl, $zip_raw_data);
// Check if the file exists and the size is bigger than a 404 error page from sf.net
if( file_exists( $temp_dwl ) )
{
$stat = stat( $temp_dwl );
}
else
{
print_failure( get_lang_f( 'dwl_failed', $url ) );
return;
}
if( $stat['size'] > 1500 )
{
print_success(get_lang("dwl_complete"));
}
else
{
print_failure( get_lang_f( 'dwl_failed', $url ) );
return;
}
echo "
". get_lang("install_update") . "
\n";
// Set default values for file checkings before installing
$not_writable = get_lang("can_not_update_non_writable_files") . " :
";
$filename = "";
$overwritten = 0;
$new = 0;
$all_writable = TRUE;
$overwritten_files = "";
$new_files = "";
$unwanted_path = REPONAME . "-" . $_GET['version'];
$extract_path = $temp . DIRECTORY_SEPARATOR . "OGP_update";
if( !file_exists($extract_path) )
mkdir($extract_path, 0775);
$blacklist = array ('/install.php',
'/modules/gamemanager/rsync_sites_local.list');
$blacklisted_files = $db->resultQuery('SELECT file_path FROM `OGP_DB_PREFIXupdate_blacklist`;');
if($blacklisted_files !== FALSE)
{
$current_blacklist = array();
foreach($blacklisted_files as $blacklisted_file)
{
$current_blacklist[] = $blacklisted_file['file_path'];
}
$blacklist = array_merge($current_blacklist,$blacklist);
}
include ( 'unzip.php' ); // array|false extractZip( string $zipFile, string $extract_path [, string $remove_path, array $blacklist, array $whitelist] )
$result = extractZipGitUpdateFile($temp_dwl, $extract_path);
if ( is_array( $result['extracted_files'] ) and count($result['extracted_files']) > 0 )
{
// Check file by file if already exists, if it matches, compares both files
// looking for changes determining if the file needs to be updated.
// Also determines if the file is writable
$i = 0;
$i2 = 0;
$newResult = array('ignored_files' => array(), 'extracted_files' => array());
foreach( $result['extracted_files'] as $file )
{
$filename = $file['filename'];
$filenameLocal = str_replace( $unwanted_path, "" , $filename );
$temp_file = $extract_path . DIRECTORY_SEPARATOR . $filename;
$web_file = $baseDir . $filenameLocal;
if(file_exists($temp_file)){
if(file_exists($web_file))
{
$temp = file_get_contents($temp_file);
$web = file_get_contents($web_file);
if( $temp != $web )
{
if( !is_writable( $web_file ) )
{
if ( ! @chmod( $web_file, 0775 ) )
{
$all_writable = FALSE;
$not_writable .= $web_file."
";
}
else
{
$newResult["extracted_files"][$i]["filename"] = $filenameLocal;
copy($temp_file, $web_file);
$i++;
$overwritten_files .= $filenameLocal . "
";
$overwritten++;
}
}
else
{
if( !in_array( $filenameLocal, $blacklist ) )
{
$newResult["extracted_files"][$i]["filename"] = $filenameLocal;
copy($temp_file, $web_file);
$i++;
$overwritten_files .= $filenameLocal . "
";
$overwritten++;
}else{
$newResult["ignored_files"][$i2] = $filenameLocal;
$i2++;
}
}
}
}
else
{
if( !in_array( $filenameLocal, $blacklist ) )
{
$newResult["extracted_files"][$i]["filename"] = $filenameLocal;
$webDir = dirname($web_file);
@mkdir($webDir, 0775, true);
copy($temp_file, $web_file);
$i++;
$new_files .= $filenameLocal . "
";
$new++;
}else{
$newResult["ignored_files"][$i2] = $filenameLocal;
$i2++;
}
}
}
}
}
else
{
echo $result;
$all_writable = FALSE;
}
// Once checking is done the temp folder is removed
if( file_exists( $extract_path ) )
{
rmdir_recurse( $extract_path );
}
if( $all_writable )
{
if( is_array( $newResult['ignored_files'] ) and !empty( $newResult['ignored_files'] ) )
{
print_failure(get_lang_f('ignored_files',count($newResult['ignored_files'])));
echo get_lang_f("not_updated_files_blacklisted", implode("
", $newResult['ignored_files']) );
echo "
";
}
if( is_array( $newResult['extracted_files'] ) )
{
// Updated files
if ( $overwritten > 0 )
{
print_success(get_lang_f('files_overwritten',$overwritten));
echo get_lang_f( "updated_files", $overwritten_files );
}
if ( $new > 0 )
{
print_success(get_lang_f('new_files',$new));
echo get_lang_f( "updated_files", $new_files );
}
// update version info in db
$version = $db->real_escape_string($_GET['version']);
$db->query("UPDATE OGP_DB_PREFIXsettings SET value = '$version' WHERE setting = 'ogp_version'");
$db->query("UPDATE OGP_DB_PREFIXsettings SET value = '$vtype' WHERE setting = 'version_type'");
// Remove the downloaded package
if( file_exists( $temp_dwl ) )
//unlink( $temp_dwl );
// Remove files that are not related to the panel
if( file_exists( $baseDir . DIRECTORY_SEPARATOR . $unwanted_path ) )
{
rmdir_recurse( $baseDir . DIRECTORY_SEPARATOR . $unwanted_path );
}
echo "
\n" . get_lang("updating_modules") ."
\n";
require_once('modules/modulemanager/module_handling.php');
$modules = $db->getInstalledModules();
// update module manager first
foreach ( $modules as $row )
{
if($row['folder'] == 'modulemanager')
{
update_module($db, $row['id'], $row['folder']);
break;
}
}
foreach ( $modules as $row )
{
if($row['folder'] == 'modulemanager')//already updated
continue;
update_module($db, $row['id'], $row['folder']);
}
print_success(get_lang("update_complete"));
// Inject AJAX to run post update operations again (which will reload functions and helpers in case there are changes there we need now that aren't available once this script finishes running
echo '';
// Run post update ops
if(function_exists("runPostUpdateOperations")){
runPostUpdateOperations();
}
}
else
{
echo $result;
}
}
else
{
print_failure($not_writable);
}
}
else
{
print_failure( get_lang_f( 'temp_folder_not_writable', $temp ) );
}
}
?>