You can not select more than 25 topics
			Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
		
		
		
		
		
			
		
			
				
					
					
						
							317 lines
						
					
					
						
							13 KiB
						
					
					
				
			
		
		
	
	
							317 lines
						
					
					
						
							13 KiB
						
					
					
				<?php
 | 
						|
/* For licensing terms, see /license.txt */
 | 
						|
 | 
						|
use Chamilo\CourseBundle\Component\CourseCopy\CourseBuilder;
 | 
						|
use Chamilo\CourseBundle\Component\CourseCopy\CourseSelectForm;
 | 
						|
 | 
						|
/**
 | 
						|
 * Special exports
 | 
						|
 *
 | 
						|
 * @author Jhon Hinojosa
 | 
						|
 * @author Julio Montoya Fixing pclzip folder + some clean <gugli100@gmail.com>
 | 
						|
 * @package chamilo.include.export
 | 
						|
 */
 | 
						|
 | 
						|
// including the global file
 | 
						|
$cidReset = true;
 | 
						|
require_once __DIR__.'/../inc/global.inc.php';
 | 
						|
 | 
						|
$this_section = SECTION_PLATFORM_ADMIN;
 | 
						|
$interbreadcrumb[] = array("url" => 'index.php', "name" => get_lang('PlatformAdmin'));
 | 
						|
// Access restrictions
 | 
						|
api_protect_admin_script(true);
 | 
						|
$nameTools = get_lang('SpecialExports');
 | 
						|
$export = '';
 | 
						|
$querypath = '';
 | 
						|
 | 
						|
// include additional libraries
 | 
						|
if (function_exists('ini_set')) {
 | 
						|
    api_set_memory_limit('256M');
 | 
						|
    ini_set('max_execution_time', 0);
 | 
						|
}
 | 
						|
 | 
						|
// Displaying the header
 | 
						|
Display::display_header($nameTools);
 | 
						|
 | 
						|
// Display the tool title
 | 
						|
echo Display::page_header($nameTools);
 | 
						|
 | 
						|
if (count($_POST) == 0) {
 | 
						|
    Display::addFlash(Display::return_message(get_lang('SpecialExportsIntroduction')));
 | 
						|
}
 | 
						|
$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')
 | 
						|
) {
 | 
						|
	$export = false;
 | 
						|
    if (isset($_POST['action']) && $_POST['action'] == 'course_select_form') {
 | 
						|
        $FileZip = create_zip();
 | 
						|
        $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'];
 | 
						|
        }
 | 
						|
 | 
						|
        $groupCondition = " props.to_group_id = $to_group_id";
 | 
						|
        if (empty($to_group_id)) {
 | 
						|
            $groupCondition = " (props.to_group_id = 0 OR props.to_group_id IS NULL)";
 | 
						|
        }
 | 
						|
 | 
						|
        $zip_folder = new PclZip($FileZip['TEMP_FILE_ZIP']);
 | 
						|
        if (!isset($_POST['resource']) || count($_POST['resource']) == 0) {
 | 
						|
            Display::addFlash(Display::return_message(get_lang('ErrorMsgSpecialExport'), 'error'));
 | 
						|
        } else {
 | 
						|
            $Resource = $_POST['resource'];
 | 
						|
 | 
						|
            foreach ($Resource as $Code_course => $Sessions) {
 | 
						|
                $_course = api_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 item to the zip file course
 | 
						|
                $sql = "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 = '0' OR docs.session_id IS NULL)
 | 
						|
                        AND props.visibility<>'2'
 | 
						|
                        AND $groupCondition
 | 
						|
                        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'],
 | 
						|
                        PCLZIP_OPT_ADD_PATH,
 | 
						|
                        $_course['directory'],
 | 
						|
                        PCLZIP_OPT_REMOVE_PATH,
 | 
						|
                        $FileZip['PATH_COURSE'].$_course['directory']."/document".$FileZip['PATH_REMOVE']
 | 
						|
                    );
 | 
						|
                }
 | 
						|
 | 
						|
                foreach ($Sessions as $IdSession => $value) {
 | 
						|
                    $session_id = (int) $IdSession;
 | 
						|
                    //Add tem to the zip file session course
 | 
						|
                    $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 $groupCondition
 | 
						|
                            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'],
 | 
						|
                            PCLZIP_OPT_ADD_PATH,
 | 
						|
                            $_course['directory']."/".$ListSession[$session_id],
 | 
						|
                            PCLZIP_OPT_REMOVE_PATH,
 | 
						|
                            $FileZip['PATH_COURSE'].$_course['directory'].'/document'.$FileZip['PATH_REMOVE']
 | 
						|
                        );
 | 
						|
                    }
 | 
						|
                }
 | 
						|
            }
 | 
						|
            $name = rename_zip($FileZip);
 | 
						|
            $export = true;
 | 
						|
        }
 | 
						|
    } else {
 | 
						|
        $name = fullexportspecial();
 | 
						|
    }
 | 
						|
}
 | 
						|
 | 
						|
if ($export && $name) {
 | 
						|
    Display::addFlash(Display::return_message(get_lang('BackupCreated'), 'confirm'));
 | 
						|
    echo '<br /><a class="btn btn-default" href="'.api_get_path(WEB_CODE_PATH).'course_info/download.php?archive_path=&archive='.urlencode($name).'">'.get_lang('Download').'</a>';
 | 
						|
} else {
 | 
						|
    // Display forms especial export
 | 
						|
    if (isset($_POST['backup_option']) && $_POST['backup_option'] == 'select_items') {
 | 
						|
        $cb = new CourseBuilder();
 | 
						|
        $course = $cb->build_session_course();
 | 
						|
        if ($course === false) {
 | 
						|
            Display::addFlash(Display::return_message(get_lang('ErrorMsgSpecialExport'), 'error'));
 | 
						|
            form_special_export();
 | 
						|
        } else {
 | 
						|
            Display::addFlash(Display::return_message(get_lang('ToExportSpecialSelect'), 'normal'));
 | 
						|
            CourseSelectForm :: display_form_session_export($course);
 | 
						|
        }
 | 
						|
    } else {
 | 
						|
        form_special_export();
 | 
						|
    }
 | 
						|
}
 | 
						|
 | 
						|
/* FOOTER */
 | 
						|
Display::display_footer();
 | 
						|
 | 
						|
function form_special_export()
 | 
						|
{
 | 
						|
    $form = new FormValidator('special_exports', 'post');
 | 
						|
    $renderer = $form->defaultRenderer();
 | 
						|
    $renderer->setCustomElementTemplate('<div>{element}</div> ');
 | 
						|
    $form->addElement('radio', 'backup_option', '', get_lang('SpecialCreateFullBackup'), 'full_backup');
 | 
						|
    $form->addElement('radio', 'backup_option', '', get_lang('SpecialLetMeSelectItems'), 'select_items');
 | 
						|
    $form->addElement('html', '<br />');
 | 
						|
    $form->addButtonExport(get_lang('CreateBackup'));
 | 
						|
    $form->addProgress();
 | 
						|
    $values['backup_option'] = 'full_backup';
 | 
						|
    $form->setDefaults($values);
 | 
						|
    $form->display();
 | 
						|
}
 | 
						|
 | 
						|
function create_zip()
 | 
						|
{
 | 
						|
    $path = '';
 | 
						|
    if (empty($path)) {
 | 
						|
        $path = '/';
 | 
						|
    }
 | 
						|
    $remove_dir = ($path != '/') ? substr($path, 0, strlen($path) - strlen(basename($path))) : '/';
 | 
						|
    $sys_archive_path = api_get_path(SYS_ARCHIVE_PATH).'special_export/';
 | 
						|
    $sys_course_path = api_get_path(SYS_COURSE_PATH);
 | 
						|
    $temp_zip_dir = $sys_archive_path;
 | 
						|
    if (!is_dir($temp_zip_dir)) {
 | 
						|
        mkdir($temp_zip_dir, api_get_permissions_for_new_directories());
 | 
						|
    } else {
 | 
						|
        $handle = opendir($temp_zip_dir);
 | 
						|
        while (false !== ($file = readdir($handle))) {
 | 
						|
            if ($file != "." && $file != "..") {
 | 
						|
                $Diff = (time() - filemtime("$temp_zip_dir/$file")) / 60 / 60; //the "age" of the file in hours
 | 
						|
                if ($Diff > 4) {
 | 
						|
                    unlink("$temp_zip_dir/$file");
 | 
						|
                }   //delete files older than 4 hours
 | 
						|
            }
 | 
						|
        }
 | 
						|
        closedir($handle);
 | 
						|
    }
 | 
						|
    $temp_zip_file = $temp_zip_dir."/".md5(time()).".zip"; //create zipfile of given directory
 | 
						|
    return array(
 | 
						|
        'PATH' => $path,
 | 
						|
        'PATH_TEMP_ARCHIVE' => $temp_zip_dir,
 | 
						|
        'PATH_COURSE' => $sys_course_path,
 | 
						|
        'TEMP_FILE_ZIP' => $temp_zip_file,
 | 
						|
        'PATH_REMOVE' => $remove_dir
 | 
						|
    );
 | 
						|
}
 | 
						|
 | 
						|
function rename_zip($FileZip)
 | 
						|
{
 | 
						|
    Event::event_download(($FileZip['PATH'] == '/') ? 'full_export_'.date('Ymd').'.zip (folder)' : basename($FileZip['PATH']).'.zip (folder)');
 | 
						|
    $name = ($FileZip['PATH'] == '/') ? 'full_export_'.date('Ymd').'.zip' : basename($FileZip['PATH']).'.zip';
 | 
						|
    if (file_exists($FileZip['PATH_TEMP_ARCHIVE'].'/'.$name)) {
 | 
						|
        unlink($FileZip['PATH_TEMP_ARCHIVE'].'/'.$name);
 | 
						|
    }
 | 
						|
    if (file_exists($FileZip['TEMP_FILE_ZIP'])) {
 | 
						|
        rename(
 | 
						|
            $FileZip['TEMP_FILE_ZIP'],
 | 
						|
            $FileZip['PATH_TEMP_ARCHIVE'].'/'.$name
 | 
						|
        );
 | 
						|
 | 
						|
        return $name;
 | 
						|
    } else {
 | 
						|
        return false;
 | 
						|
    }
 | 
						|
 | 
						|
}
 | 
						|
 | 
						|
function fullexportspecial()
 | 
						|
{
 | 
						|
    global $tbl_session, $tbl_session_course, $export;
 | 
						|
    $FileZip = create_zip();
 | 
						|
    $to_group_id = 0;
 | 
						|
    $zip_folder = new PclZip($FileZip['TEMP_FILE_ZIP']);
 | 
						|
    $list_course = CourseManager::get_course_list();
 | 
						|
 | 
						|
    $tbl_document = Database::get_course_table(TABLE_DOCUMENT);
 | 
						|
    $tbl_property = Database::get_course_table(TABLE_ITEM_PROPERTY);
 | 
						|
 | 
						|
    $groupCondition = " props.to_group_id = $to_group_id";
 | 
						|
    if (empty($to_group_id)) {
 | 
						|
        $groupCondition = " (props.to_group_id = 0 OR props.to_group_id IS NULL)";
 | 
						|
    }
 | 
						|
 | 
						|
    if (count($list_course) > 0) {
 | 
						|
        foreach ($list_course as $_course) {
 | 
						|
            if ($FileZip['PATH'] == '/') {
 | 
						|
                $querypath = ''; // to prevent ...path LIKE '//%'... in query
 | 
						|
            } else {
 | 
						|
                $querypath = $FileZip['PATH'];
 | 
						|
            }
 | 
						|
            $course_id = $_course['real_id'];
 | 
						|
 | 
						|
            //Add tem to the zip file course
 | 
						|
            $sql = "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 = '0' OR docs.session_id IS NULL)
 | 
						|
                    AND props.visibility<>'2'
 | 
						|
                    AND $groupCondition
 | 
						|
                    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'],
 | 
						|
                    PCLZIP_OPT_ADD_PATH,
 | 
						|
                    $_course['directory'],
 | 
						|
                    PCLZIP_OPT_REMOVE_PATH, $FileZip['PATH_COURSE'].$_course['directory']."/document".$FileZip['PATH_REMOVE']
 | 
						|
                );
 | 
						|
            }
 | 
						|
 | 
						|
            //Add tem to the zip file session course
 | 
						|
            $sql = "SELECT s.id, name, c_id
 | 
						|
                            FROM $tbl_session_course sc
 | 
						|
                            INNER JOIN $tbl_session  s
 | 
						|
                            ON sc.session_id = s.id
 | 
						|
                            WHERE c_id = '$course_id' ";
 | 
						|
            $query_session = Database::query($sql);
 | 
						|
            while ($rows_session = Database::fetch_assoc($query_session)) {
 | 
						|
                $session_id = $rows_session['id'];
 | 
						|
                $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 $groupCondition
 | 
						|
                        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'],
 | 
						|
                        PCLZIP_OPT_ADD_PATH,
 | 
						|
                        $_course['directory']."/".$rows_session['name'],
 | 
						|
                        PCLZIP_OPT_REMOVE_PATH,
 | 
						|
                        $FileZip['PATH_COURSE'].$_course['directory'].'/document'.$FileZip['PATH_REMOVE']
 | 
						|
                    );
 | 
						|
                }
 | 
						|
            }
 | 
						|
        }
 | 
						|
 | 
						|
        $name = rename_zip($FileZip);
 | 
						|
        if ($name === false) {
 | 
						|
            $export = false;
 | 
						|
 | 
						|
            return false;
 | 
						|
        } else {
 | 
						|
            $export = true;
 | 
						|
 | 
						|
            return $name;
 | 
						|
        }
 | 
						|
    } else {
 | 
						|
        Display::display_error_message(get_lang('ErrorMsgSpecialExport')); //main API
 | 
						|
        $export = false;
 | 
						|
        return false;
 | 
						|
    }
 | 
						|
}
 | 
						|
 |