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.
		
		
		
		
		
			
		
			
				
					
					
						
							214 lines
						
					
					
						
							6.8 KiB
						
					
					
				
			
		
		
	
	
							214 lines
						
					
					
						
							6.8 KiB
						
					
					
				<?php
 | 
						|
 | 
						|
/* For licensing terms, see /license.txt */
 | 
						|
 | 
						|
use Symfony\Component\Finder\Finder;
 | 
						|
 | 
						|
require_once __DIR__.'/../inc/global.inc.php';
 | 
						|
$current_course_tool = TOOL_STUDENTPUBLICATION;
 | 
						|
 | 
						|
api_protect_course_script(true);
 | 
						|
 | 
						|
// Including necessary files
 | 
						|
require_once 'work.lib.php';
 | 
						|
 | 
						|
$this_section = SECTION_COURSES;
 | 
						|
 | 
						|
$workId = isset($_REQUEST['id']) ? (int) $_REQUEST['id'] : 0;
 | 
						|
 | 
						|
$is_allowed_to_edit = api_is_allowed_to_edit();
 | 
						|
$course_id = api_get_course_int_id();
 | 
						|
$user_id = api_get_user_id();
 | 
						|
$userInfo = api_get_user_info();
 | 
						|
$session_id = api_get_session_id();
 | 
						|
$courseInfo = api_get_course_info();
 | 
						|
$course_code = $courseInfo['code'];
 | 
						|
$group_id = api_get_group_id();
 | 
						|
 | 
						|
if (empty($workId)) {
 | 
						|
    api_not_allowed(true);
 | 
						|
}
 | 
						|
 | 
						|
protectWork($courseInfo, $workId);
 | 
						|
$workInfo = get_work_data_by_id($workId);
 | 
						|
 | 
						|
if (empty($workInfo)) {
 | 
						|
    api_not_allowed(true);
 | 
						|
}
 | 
						|
 | 
						|
$student_can_edit_in_session = api_is_allowed_to_session_edit(false, true);
 | 
						|
 | 
						|
$homework = get_work_assignment_by_id($workInfo['id']);
 | 
						|
$validationStatus = getWorkDateValidationStatus($homework);
 | 
						|
 | 
						|
$interbreadcrumb[] = [
 | 
						|
    'url' => api_get_path(WEB_CODE_PATH).'work/work.php?'.api_get_cidreq(),
 | 
						|
    'name' => get_lang('StudentPublications'),
 | 
						|
];
 | 
						|
$interbreadcrumb[] = [
 | 
						|
    'url' => api_get_path(WEB_CODE_PATH).'work/work_list.php?'.api_get_cidreq().'&id='.$workId,
 | 
						|
    'name' => $workInfo['title'],
 | 
						|
];
 | 
						|
$interbreadcrumb[] = ['url' => '#', 'name' => get_lang('UploadCorrections')];
 | 
						|
 | 
						|
$downloadLink = api_get_path(WEB_CODE_PATH).'work/downloadfolder.inc.php?id='.$workId.'&'.api_get_cidreq();
 | 
						|
 | 
						|
$form = new FormValidator(
 | 
						|
    'form',
 | 
						|
    'POST',
 | 
						|
    api_get_self()."?".api_get_cidreq()."&id=".$workId,
 | 
						|
    '',
 | 
						|
    ['enctype' => "multipart/form-data"]
 | 
						|
);
 | 
						|
 | 
						|
$form->addElement('header', get_lang('UploadCorrections'));
 | 
						|
$form->addHtml(Display::return_message(
 | 
						|
    sprintf(
 | 
						|
        get_lang('UploadCorrectionsExplanationWithDownloadLinkX'),
 | 
						|
        $downloadLink
 | 
						|
    ),
 | 
						|
    'normal',
 | 
						|
    false
 | 
						|
));
 | 
						|
$form->addElement('file', 'file', get_lang('UploadADocument'));
 | 
						|
$form->addProgress();
 | 
						|
$form->addRule('file', get_lang('ThisFieldIsRequired'), 'required');
 | 
						|
$form->addElement('hidden', 'id', $workId);
 | 
						|
$form->addButtonUpload(get_lang('Upload'));
 | 
						|
 | 
						|
$succeed = false;
 | 
						|
if ($form->validate()) {
 | 
						|
    $values = $form->getSubmitValues();
 | 
						|
    $upload = process_uploaded_file($_FILES['file'], false);
 | 
						|
 | 
						|
    if ($upload) {
 | 
						|
        $zip = new PclZip($_FILES['file']['tmp_name']);
 | 
						|
        // Check the zip content (real size and file extension)
 | 
						|
        $zipFileList = (array) $zip->listContent();
 | 
						|
 | 
						|
        $realSize = 0;
 | 
						|
        foreach ($zipFileList as &$this_content) {
 | 
						|
            $realSize += $this_content['size'];
 | 
						|
        }
 | 
						|
 | 
						|
        $maxSpace = DocumentManager::get_course_quota();
 | 
						|
 | 
						|
        if (!DocumentManager::enough_space($realSize, $maxSpace)) {
 | 
						|
            Display::addFlash(
 | 
						|
                Display::return_message(
 | 
						|
                    get_lang('UplNotEnoughSpace'),
 | 
						|
                    'warning'
 | 
						|
                )
 | 
						|
            );
 | 
						|
        }
 | 
						|
 | 
						|
        $folder = api_get_unique_id();
 | 
						|
        $destinationDir = api_get_path(SYS_ARCHIVE_PATH).$folder;
 | 
						|
        mkdir($destinationDir, api_get_permissions_for_new_directories(), true);
 | 
						|
 | 
						|
        // Uncompress zip file
 | 
						|
        // We extract using a callback function that "cleans" the path
 | 
						|
        $zip->extract(
 | 
						|
            PCLZIP_OPT_PATH,
 | 
						|
            $destinationDir,
 | 
						|
            PCLZIP_CB_PRE_EXTRACT,
 | 
						|
            'clean_up_files_in_zip',
 | 
						|
            PCLZIP_OPT_REPLACE_NEWER
 | 
						|
        );
 | 
						|
 | 
						|
        $result = get_work_user_list(null, null, null, null, $workId);
 | 
						|
 | 
						|
        if (empty($result)) {
 | 
						|
            Display::addFlash(
 | 
						|
                Display::return_message(
 | 
						|
                    get_lang('NoDataAvailable'),
 | 
						|
                    'warning'
 | 
						|
                )
 | 
						|
            );
 | 
						|
        }
 | 
						|
 | 
						|
        $finalResult = [];
 | 
						|
        foreach ($result as $item) {
 | 
						|
            $title = $item['title_clean'];
 | 
						|
            $insert_date = str_replace([':', '-', ' '], '_', api_get_local_time($item['sent_date_from_db']));
 | 
						|
            $title = api_replace_dangerous_char($insert_date.'_'.$item['username'].'_'.$title);
 | 
						|
            $finalResult[$title] = $item['id'];
 | 
						|
        }
 | 
						|
 | 
						|
        $coursePath = api_get_path(SYS_COURSE_PATH).$courseInfo['path'].'/';
 | 
						|
        $workDir = api_get_path(SYS_COURSE_PATH).$courseInfo['path'].'/work/';
 | 
						|
        $workDir .= basename($workInfo['url']).'/';
 | 
						|
 | 
						|
        $finder = new Finder();
 | 
						|
        $finder->files()->in($destinationDir);
 | 
						|
        $table = Database::get_course_table(TABLE_STUDENT_PUBLICATION);
 | 
						|
        /** @var SplFileInfo $file */
 | 
						|
        foreach ($finder as $file) {
 | 
						|
            $fileName = $file->getBasename();
 | 
						|
 | 
						|
            if (isset($finalResult[$fileName])) {
 | 
						|
                $workStudentId = $finalResult[$fileName];
 | 
						|
                $workStudent = get_work_data_by_id($workStudentId);
 | 
						|
                if ($workStudent) {
 | 
						|
                    if (!empty($workStudent['url_correction'])) {
 | 
						|
                        $correctionFilePath = $coursePath.$workStudent['url_correction'];
 | 
						|
                        $correctionTitle = $workStudent['title_correction'];
 | 
						|
                    } else {
 | 
						|
                        if (!empty($workStudent['url'])) {
 | 
						|
                            $correctionFilePath = $coursePath.$workStudent['url'].'_correction';
 | 
						|
                            $correctionTitle = $fileName;
 | 
						|
                        }
 | 
						|
                    }
 | 
						|
 | 
						|
                    if (!empty($correctionFilePath)) {
 | 
						|
                        $result = copy(
 | 
						|
                            $file->getRealPath(),
 | 
						|
                            $correctionFilePath
 | 
						|
                        );
 | 
						|
 | 
						|
                        $correctionTitle = Database::escape_string(
 | 
						|
                            $correctionTitle
 | 
						|
                        );
 | 
						|
 | 
						|
                        $correctionFilePath = Database::escape_string(
 | 
						|
                            'work/'.basename($workInfo['url']).'/'.basename($correctionFilePath)
 | 
						|
                        );
 | 
						|
 | 
						|
                        if ($result) {
 | 
						|
                            $sql = "UPDATE $table SET
 | 
						|
                                        url_correction = '".$correctionFilePath."',
 | 
						|
                                        title_correction = '".$correctionTitle."'
 | 
						|
                                    WHERE iid = $workStudentId";
 | 
						|
                            Database::query($sql);
 | 
						|
                        }
 | 
						|
                    }
 | 
						|
                }
 | 
						|
            }
 | 
						|
        }
 | 
						|
 | 
						|
        Display::addFlash(
 | 
						|
            Display::return_message(
 | 
						|
                get_lang('Uploaded')
 | 
						|
            )
 | 
						|
        );
 | 
						|
    }
 | 
						|
 | 
						|
    header('Location: '.api_get_path(WEB_CODE_PATH).'work/work_list_all.php?'.api_get_cidreq().'&id='.$workId);
 | 
						|
    exit;
 | 
						|
}
 | 
						|
 | 
						|
$htmlHeadXtra[] = to_javascript_work();
 | 
						|
Display::display_header(null);
 | 
						|
 | 
						|
if (!empty($workId)) {
 | 
						|
    echo $validationStatus['message'];
 | 
						|
    if ($is_allowed_to_edit) {
 | 
						|
        $form->display();
 | 
						|
    } else {
 | 
						|
        api_not_allowed();
 | 
						|
    }
 | 
						|
} else {
 | 
						|
    api_not_allowed();
 | 
						|
}
 | 
						|
 | 
						|
Display::display_footer();
 | 
						|
 |