From c2ca7d56f1ab42fb9650d4b90e3a449603ad5d72 Mon Sep 17 00:00:00 2001 From: Julio Montoya Date: Mon, 28 May 2012 11:26:57 +0200 Subject: [PATCH] Fixing special export query see #4809 --- main/admin/special_exports.php | 37 +++++++++++++++++----------------- 1 file changed, 18 insertions(+), 19 deletions(-) diff --git a/main/admin/special_exports.php b/main/admin/special_exports.php index 4656cc7980..b364a6f195 100644 --- a/main/admin/special_exports.php +++ b/main/admin/special_exports.php @@ -30,15 +30,17 @@ require_once '../coursecopy/classes/CourseArchiver.class.php'; require_once '../coursecopy/classes/CourseRestorer.class.php'; require_once '../coursecopy/classes/CourseSelectForm.class.php'; -if(function_exists('ini_set')) { +if (function_exists('ini_set')) { ini_set('memory_limit','256M'); ini_set('max_execution_time',0); } // Displaying the header Display::display_header($nameTools); + // Display the tool title -api_display_tool_title($nameTools); +echo Display::page_header($nameTools); + if (count($_POST) == 0) { Display::display_normal_message(get_lang('SpecialExportsIntroduction')); } @@ -48,40 +50,39 @@ $error =0; $tbl_session = Database::get_main_table(TABLE_MAIN_SESSION); $tbl_session_course = Database::get_main_table(TABLE_MAIN_SESSION_COURSE); -if ((isset ($_POST['action']) && $_POST['action'] == 'course_select_form') || (isset ($_POST['backup_option']) && $_POST['backup_option'] == 'full_backup')) { - require_once api_get_path(LIBRARY_PATH).'document.lib.php'; - require_once api_get_path(LIBRARY_PATH).'pclzip/pclzip.lib.php'; +if ((isset ($_POST['action']) && $_POST['action'] == 'course_select_form') || (isset ($_POST['backup_option']) && $_POST['backup_option'] == 'full_backup')) { $export = false; if (isset ($_POST['action']) && $_POST['action'] == 'course_select_form') { $FileZip = create_zip(); - $to_group_id = 0; - $code_course = ''; + $to_group_id = 0; $sql_session = "SELECT id, name FROM $tbl_session "; $query_session = Database::query($sql_session); $ListSession = array(); while ($rows_session = Database::fetch_assoc($query_session)) { $ListSession[$rows_session['id']] = $rows_session['name']; } + $zip_folder=new PclZip($FileZip['TEMP_FILE_ZIP']); if(!isset($_POST['resource']) || count($_POST['resource']) == 0 ) { Display::display_error_message(get_lang('ErrorMsgSpecialExport')); } else { $Resource = $_POST['resource']; - foreach($Resource as $Code_course => $Sessions) { - $_course = Database::get_course_info($Code_course); + + foreach ($Resource as $Code_course => $Sessions) { + $_course = Database::get_course_info($Code_course); $tbl_document = Database::get_course_table(TABLE_DOCUMENT); $tbl_property = Database::get_course_table(TABLE_ITEM_PROPERTY); $course_id = $_course['real_id']; - //Add tem to the zip file course + //Add item to the zip file course $sql = "SELECT path FROM $tbl_document AS docs, $tbl_property AS props - WHERE props.tool='".TOOL_DOCUMENT."' + WHERE props.tool='".TOOL_DOCUMENT."' AND docs.id=props.ref AND docs.path LIKE '".$querypath."/%' AND docs.filetype='file' AND docs.session_id = '0' AND props.visibility<>'2' - AND props.to_group_id=".$to_group_id." AND docs.c_id = $course_id AND props.c_id = $course_id"; + AND props.to_group_id= $to_group_id AND docs.c_id = $course_id AND props.c_id = $course_id"; $query = Database::query($sql ); while ($rows_course_file = Database::fetch_assoc($query)) { $zip_folder->add($FileZip['PATH_COURSE'].$_course['directory']."/document".$rows_course_file['path'], @@ -89,17 +90,18 @@ if ((isset ($_POST['action']) && $_POST['action'] == 'course_select_form') || (i PCLZIP_OPT_REMOVE_PATH, $FileZip['PATH_COURSE'].$_course['directory']."/document".$FileZip['PATH_REMOVE'] ); } - foreach($Sessions as $IdSession => $value){ + + foreach ($Sessions as $IdSession => $value){ $session_id = Security::remove_XSS($IdSession); //Add tem to the zip file session course - $sql_session_doc = "SELECT path FROM $tbl_document AS docs,$tbl_property AS props + $sql_session_doc = "SELECT path FROM $tbl_document AS docs, $tbl_property AS props WHERE props.tool='".TOOL_DOCUMENT."' AND docs.id=props.ref AND docs.path LIKE '".$querypath."/%' AND docs.filetype='file' AND docs.session_id = '$session_id' AND props.visibility<>'2' - AND props.to_group_id=".$to_group_id.""; + AND props.to_group_id= $to_group_id AND docs.c_id = $course_id AND props.c_id = $course_id"; $query_session_doc = Database::query($sql_session_doc); while ($rows_course_session_file = Database::fetch_assoc($query_session_doc)) { $zip_folder->add($FileZip['PATH_COURSE'].$_course['directory'].'/document'.$rows_course_session_file['path'], @@ -150,8 +152,6 @@ if ($export && $name) { Display::display_footer(); function form_special_export() { - $htlm = get_lang('SelectOptionExport'); - $form = new FormValidator('special_exports','post'); $renderer = $form->defaultRenderer(); $renderer->setElementTemplate('
{element}
'); @@ -168,8 +168,7 @@ function form_special_export() { function create_zip(){ $path = ''; if(empty($path)) { $path='/'; } - $remove_dir = ($path!='/') ? substr($path,0,strlen($path) - strlen(basename($path))) : '/'; - $to_group_id = $_SESSION['_gid']; + $remove_dir = ($path!='/') ? substr($path,0,strlen($path) - strlen(basename($path))) : '/'; $sys_archive_path = api_get_path(SYS_ARCHIVE_PATH); $sys_course_path = api_get_path(SYS_COURSE_PATH); $temp_zip_dir = $sys_archive_path."temp";