Search moodle.org's
Developer Documentation

See Release Notes

  • Bug fixes for general core bugs in 4.2.x will end 22 April 2024 (12 months).
  • Bug fixes for security issues in 4.2.x will end 7 October 2024 (18 months).
  • PHP version: minimum PHP 8.0.0 Note: minimum PHP version has increased since Moodle 4.1. PHP 8.1.x is supported too.
/user/ -> files.php (source)
<?php
// This file is part of Moodle - http://moodle.org/
//
// Moodle is free software: you can redistribute it and/or modify
// it under the terms of the GNU General Public License as published by
// the Free Software Foundation, either version 3 of the License, or
// (at your option) any later version.
//
// Moodle is distributed in the hope that it will be useful,
// but WITHOUT ANY WARRANTY; without even the implied warranty of
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
// GNU General Public License for more details.
//
// You should have received a copy of the GNU General Public License
// along with Moodle.  If not, see <http://www.gnu.org/licenses/>.

/**
 * Manage files in folder in private area.
 *
 * @package   core_user
 * @category  files
 * @copyright 2010 Petr Skoda (http://skodak.org)
 * @license   http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later
 */

require('../config.php');
< require_once("$CFG->dirroot/user/files_form.php"); < require_once("$CFG->dirroot/repository/lib.php");
require_login(); if (isguestuser()) { die(); }
< $returnurl = optional_param('returnurl', '', PARAM_LOCALURL); < < if (empty($returnurl)) { < $returnurl = new moodle_url('/user/files.php'); < } <
$context = context_user::instance($USER->id); require_capability('moodle/user:manageownfiles', $context); $title = get_string('privatefiles');
< $struser = get_string('user');
$PAGE->set_url('/user/files.php'); $PAGE->set_context($context); $PAGE->set_title($title); $PAGE->set_heading(fullname($USER)); $PAGE->set_pagelayout('standard');
> $PAGE->add_body_class('limitedwidth');
$PAGE->set_pagetype('user-files');
< $maxbytes = $CFG->userquota; < $maxareabytes = $CFG->userquota; < if (has_capability('moodle/user:ignoreuserquota', $context)) { < $maxbytes = USER_CAN_IGNORE_FILE_SIZE_LIMITS; < $maxareabytes = FILE_AREA_MAX_BYTES_UNLIMITED; < } < < $data = new stdClass(); < $data->returnurl = $returnurl; < $options = array('subdirs' => 1, 'maxbytes' => $maxbytes, 'maxfiles' => -1, 'accepted_types' => '*', < 'areamaxbytes' => $maxareabytes); < file_prepare_standard_filemanager($data, 'files', $options, $context, 'user', 'private', 0); < < // Attempt to generate an inbound message address to support e-mail to private files. < $generator = new \core\message\inbound\address_manager(); < $generator->set_handler('\core\message\inbound\private_files_handler'); < $generator->set_data(-1); < $data->emaillink = $generator->generate($USER->id); < < $mform = new user_files_form(null, array('data' => $data, 'options' => $options)); < < if ($mform->is_cancelled()) { < redirect($returnurl); < } else if ($formdata = $mform->get_data()) { < $formdata = file_postupdate_standard_filemanager($formdata, 'files', $options, $context, 'user', 'private', 0); < redirect($returnurl); < } <
echo $OUTPUT->header();
> echo $OUTPUT->heading($title);
echo $OUTPUT->box_start('generalbox');
< // Show file area space usage. < if ($maxareabytes != FILE_AREA_MAX_BYTES_UNLIMITED) { < $fileareainfo = file_get_file_area_info($context->id, 'user', 'private'); < // Display message only if we have files. < if ($fileareainfo['filecount']) { < $a = (object) [ < 'used' => display_size($fileareainfo['filesize_without_references']), < 'total' => display_size($maxareabytes) < ]; < $quotamsg = get_string('quotausage', 'moodle', $a); < $notification = new \core\output\notification($quotamsg, \core\output\notification::NOTIFY_INFO); < echo $OUTPUT->render($notification); < } < }
> echo html_writer::start_div('', ['id' => 'userfilesform']); > $form = new \core_user\form\private_files(); > $form->set_data_for_dynamic_submission(); > $form->display(); > echo html_writer::end_div(); > $PAGE->requires->js_call_amd('core_user/private_files', 'initDynamicForm', > ['#userfilesform', \core_user\form\private_files::class]);
< $mform->display();
echo $OUTPUT->box_end(); echo $OUTPUT->footer();