AutorÃa | Ultima modificación | Ver Log |
<?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/>.
/**
* @package mod
* @subpackage eduplayer
* @author Humanage Srl <info@humanage.it>
* @copyright 2013 Humanage Srl <info@humanage.it>
* @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later
*/
defined('MOODLE_INTERNAL') || die();
require_once($CFG->libdir.'/filelib.php');
require_once('locallib.php');
////////////////////////////////////////////////////////////////////////////////
// Moodle core API //
////////////////////////////////////////////////////////////////////////////////
/**
* Returns the information on whether the module supports a feature
*
* @see plugin_supports() in lib/moodlelib.php
* @param string $feature FEATURE_xx constant for requested feature
* @return mixed true if the feature is supported, null if unknown
*/
function eduplayer_supports($feature) {
switch($feature) {
case FEATURE_MOD_INTRO: return true;
case FEATURE_GROUPS: return false;
case FEATURE_GROUPINGS: return false;
case FEATURE_GROUPMEMBERSONLY: return true;
case FEATURE_COMPLETION_TRACKS_VIEWS: return true;
case FEATURE_GRADE_HAS_GRADE: return false;
case FEATURE_GRADE_OUTCOMES: return false;
case FEATURE_BACKUP_MOODLE2: return true;
case FEATURE_SHOW_DESCRIPTION: return true;
default: return null;
}
}
/**
* Saves a new instance of the eduplayer into the database
*
* Given an object containing all the necessary data,
* (defined by the form in mod_form.php) this function
* will create a new instance and return the id number
* of the new instance.
*
* @param object $eduplayer An object from the form in mod_form.php
* @param mod_eduplayer_mod_form $mform
* @return int The id of the newly inserted eduplayer record
*/
function eduplayer_add_instance(stdClass $eduplayer, mod_eduplayer_mod_form $mform = null) {
global $DB, $CFG;
$eduplayer->timecreated = time();
$context = get_context_instance(CONTEXT_MODULE, $eduplayer->coursemodule);
$fs = get_file_storage();
if ($eduplayer->urltype == 1) {
$items = array('file', 'image', 'captionsfile');
} else {
$items = array('image', 'captionsfile');
$eduplayer->eduplayerfile = $eduplayer->linkurl;
}
foreach ($items as $value) {
$file = '';
$draftitemid = file_get_submitted_draft_itemid($value);
file_prepare_draft_area($draftitemid, $context->id, 'mod_eduplayer', $value, 0, array('subdirs'=>0));
file_save_draft_area_files($draftitemid, $context->id, 'mod_eduplayer', $value, 0, array('subdirs'=>0));
$file = $fs->get_area_files($context->id, 'mod_eduplayer', $value, 0, 'sortorder DESC, id ASC', false); // TODO: this is not very efficient!!
$file_details = $fs->get_file_by_hash(key($file));
if( empty( $file ) ){
$eduplayer->$value = NULL;
continue;
}
if ($value == 'file') {
$eduplayer->eduplayerfile = $file_details->get_filename();
} else {
if (!empty($file)) {
$eduplayer->$value = $file_details->get_filename();
} else {
$eduplayer->$value = NULL;
}
}
}
$eduplayer->height = normalize_height( $eduplayer );
$eduplayer = file_postupdate_standard_editor($eduplayer, 'notes', array('subdirs'=>0, 'maxfiles'=>3, 'maxbytes'=>$CFG->maxbytes, 'trusttext'=>true, 'context'=>$context), $context, 'mod_eduplayer', 'notes', 0);
$eduplayer = file_postupdate_standard_editor($eduplayer, 'sharemailmessage', array('subdirs'=>0, 'maxfiles'=>3, 'maxbytes'=>$CFG->maxbytes, 'trusttext'=>true, 'context'=>$context), $context, 'mod_eduplayer', 'sharemailmessage', 0);
return $DB->insert_record('eduplayer', $eduplayer);
}
/**
* Updates an instance of the eduplayer in the database
*
* Given an object containing all the necessary data,
* (defined by the form in mod_form.php) this function
* will update an existing instance with new data.
*
* @param object $eduplayer An object from the form in mod_form.php
* @param mod_eduplayer_mod_form $mform
* @return boolean Success/Fail
*/
function eduplayer_update_instance(stdClass $eduplayer, mod_eduplayer_mod_form $mform = null) {
global $DB, $CFG;
$eduplayer->timemodified = time();
$eduplayer->id = $eduplayer->instance;
//$context = get_context_instance(CONTEXT_MODULE, $eduplayer->coursemodule);
//Mihir moodle3.2
$context = context_module::instance($eduplayer->coursemodule);
$fs = get_file_storage();
if ($eduplayer->urltype == 1) {
$items = array('file', 'image', 'captionsfile');
} else {
$items = $items = array('image', 'captionsfile');
$eduplayer->eduplayerfile = $eduplayer->linkurl;
}
foreach ($items as $value) {
$file = '';
$draftitemid = file_get_submitted_draft_itemid($value);
file_prepare_draft_area($draftitemid, $context->id, 'mod_eduplayer', $value, 0, array('subdirs'=>0));
file_save_draft_area_files($draftitemid, $context->id, 'mod_eduplayer', $value, 0, array('subdirs'=>0));
$file = $fs->get_area_files($context->id, 'mod_eduplayer', $value, 0, 'sortorder DESC, id ASC', false); // TODO: this is not very efficient!!
if( empty( $file ) ){
$eduplayer->$value = NULL;
continue;
}
$file_details = $fs->get_file_by_hash(key($file));
if ($value == 'file') {
$eduplayer->eduplayerfile = $file_details->get_filename();
} else {
if (!empty($file)) {
$eduplayer->$value = $file_details->get_filename();
} else {
$eduplayer->$value = NULL;
}
}
}
$eduplayer->height = normalize_height( $eduplayer );
if(!isset($eduplayer->downloadenabled))
$eduplayer->downloadenabled = 0;
$eduplayer = file_postupdate_standard_editor($eduplayer, 'notes', array('subdirs'=>0, 'maxfiles'=>3, 'maxbytes'=>$CFG->maxbytes, 'trusttext'=>true, 'context'=>$context), $context, 'mod_eduplayer', 'notes', 0);
$eduplayer = file_postupdate_standard_editor($eduplayer, 'sharemailmessage', array('subdirs'=>0, 'maxfiles'=>3, 'maxbytes'=>$CFG->maxbytes, 'trusttext'=>true, 'context'=>$context), $context, 'mod_eduplayer', 'sharemailmessage', 0);
return $DB->update_record('eduplayer', $eduplayer);
}
/**
* Removes an instance of the eduplayer from the database
*
* Given an ID of an instance of this module,
* this function will permanently delete the instance
* and any data that depends on it.
*
* @param int $id Id of the module instance
* @return boolean Success/Failure
*/
function eduplayer_delete_instance($id) {
global $DB;
if (! $eduplayer = $DB->get_record('eduplayer', array('id' => $id))) {
return false;
}
$DB->delete_records('eduplayer', array('id' => $eduplayer->id));
return true;
}
/**
* Returns a small object with summary information about what a
* user has done with a given particular instance of this module
* Used for user activity reports.
* $return->time = the time they did it
* $return->info = a short text description
*
* @return stdClass|null
*/
function eduplayer_user_outline($course, $user, $mod, $eduplayer) {
$return = new stdClass();
$return->time = 0;
$return->info = '';
return $return;
}
/**
* Prints a detailed representation of what a user has done with
* a given particular instance of this module, for user activity reports.
*
* @param stdClass $course the current course record
* @param stdClass $user the record of the user we are generating report for
* @param cm_info $mod course module info
* @param stdClass $eduplayer the module instance record
* @return void, is supposed to echp directly
*/
function eduplayer_user_complete($course, $user, $mod, $eduplayer) {
}
/**
* Given a course and a time, this module should find recent activity
* that has occurred in eduplayer activities and print it out.
* Return true if there was output, or false is there was none.
*
* @return boolean
*/
function eduplayer_print_recent_activity($course, $viewfullnames, $timestart) {
return false; // True if anything was printed, otherwise false
}
/**
* Prepares the recent activity data
*
* This callback function is supposed to populate the passed array with
* custom activity records. These records are then rendered into HTML via
* {@link eduplayer_print_recent_mod_activity()}.
*
* @param array $activities sequentially indexed array of objects with the 'cmid' property
* @param int $index the index in the $activities to use for the next record
* @param int $timestart append activity since this time
* @param int $courseid the id of the course we produce the report for
* @param int $cmid course module id
* @param int $userid check for a particular user's activity only, defaults to 0 (all users)
* @param int $groupid check for a particular group's activity only, defaults to 0 (all groups)
* @return void adds items into $activities and increases $index
*/
function eduplayer_get_recent_mod_activity(&$activities, &$index, $timestart, $courseid, $cmid, $userid=0, $groupid=0) {
}
/**
* Prints single activity item prepared by {@see eduplayer_get_recent_mod_activity()}
* @return void
*/
function eduplayer_print_recent_mod_activity($activity, $courseid, $detail, $modnames, $viewfullnames) {
}
/**
* Function to be run periodically according to the moodle cron
* This function searches for things that need to be done, such
* as sending out mail, toggling flags etc ...
*
* @return boolean
* @todo Finish documenting this function
**/
function eduplayer_cron () {
return true;
}
/**
* Returns all other caps used in the module
*
* @example return array('moodle/site:accessallgroups');
* @return array
*/
function eduplayer_get_extra_capabilities() {
return array();
}
////////////////////////////////////////////////////////////////////////////////
// Gradebook API //
////////////////////////////////////////////////////////////////////////////////
/**
* Is a given scale used by the instance of eduplayer?
*
* This function returns if a scale is being used by one eduplayer
* if it has support for grading and scales. Commented code should be
* modified if necessary. See forum, glossary or journal modules
* as reference.
*
* @param int $eduplayerid ID of an instance of this module
* @return bool true if the scale is used by the given eduplayer instance
*/
function eduplayer_scale_used($eduplayerid, $scaleid) {
global $DB;
/** @example */
if ($scaleid and $DB->record_exists('eduplayer', array('id' => $eduplayerid, 'grade' => -$scaleid))) {
return true;
} else {
return false;
}
}
/**
* Checks if scale is being used by any instance of eduplayer.
*
* This is used to find out if scale used anywhere.
*
* @param $scaleid int
* @return boolean true if the scale is used by any eduplayer instance
*/
function eduplayer_scale_used_anywhere($scaleid) {
global $DB;
/** @example */
if ($scaleid and $DB->record_exists('eduplayer', array('grade' => -$scaleid))) {
return true;
} else {
return false;
}
}
/**
* Creates or updates grade item for the give eduplayer instance
*
* Needed by grade_update_mod_grades() in lib/gradelib.php
*
* @param stdClass $eduplayer instance object with extra cmidnumber and modname property
* @return void
*/
function eduplayer_grade_item_update(stdClass $eduplayer) {
global $CFG;
require_once($CFG->libdir.'/gradelib.php');
/** @example */
$item = array();
$item['itemname'] = clean_param($eduplayer->name, PARAM_NOTAGS);
$item['gradetype'] = GRADE_TYPE_VALUE;
$item['grademax'] = $eduplayer->grade;
$item['grademin'] = 0;
grade_update('mod/eduplayer', $eduplayer->course, 'mod', 'eduplayer', $eduplayer->id, 0, null, $item);
}
/**
* Update eduplayer grades in the gradebook
*
* Needed by grade_update_mod_grades() in lib/gradelib.php
*
* @param stdClass $eduplayer instance object with extra cmidnumber and modname property
* @param int $userid update grade of specific user only, 0 means all participants
* @return void
*/
function eduplayer_update_grades(stdClass $eduplayer, $userid = 0) {
global $CFG, $DB;
require_once($CFG->libdir.'/gradelib.php');
/** @example */
$grades = array(); // populate array of grade objects indexed by userid
grade_update('mod/eduplayer', $eduplayer->course, 'mod', 'eduplayer', $eduplayer->id, 0, $grades);
}
////////////////////////////////////////////////////////////////////////////////
// File API //
////////////////////////////////////////////////////////////////////////////////
/**
* Returns the lists of all browsable file areas within the given module context
*
* The file area 'intro' for the activity introduction field is added automatically
* by {@link file_browser::get_file_info_context_module()}
*
* @param stdClass $course
* @param stdClass $cm
* @param stdClass $context
* @return array of [(string)filearea] => (string)description
*/
function eduplayer_get_file_areas($course, $cm, $context) {
$areas = array('file', 'notes', 'image', 'captionsfile');
$areas['file'] = get_string('eduplayerfile', 'eduplayer');
$areas['notes'] = get_string('notes', 'eduplayer');
$areas['image'] = get_string('image', 'eduplayer');
$areas['captionsfile'] = get_string('captionsfile', 'eduplayer');
return $areas;
}
/**
* File browsing support for eduplayer file areas
*
* @package mod_eduplayer
* @category files
*
* @param file_browser $browser
* @param array $areas
* @param stdClass $course
* @param stdClass $cm
* @param stdClass $context
* @param string $filearea
* @param int $itemid
* @param string $filepath
* @param string $filename
* @return file_info instance or null if not found
*/
function eduplayer_get_file_info($browser, $areas, $course, $cm, $context, $filearea, $itemid, $filepath, $filename) {
global $CFG;
if (!has_capability('moodle/course:managefiles', $context)) {
// students can not peak here!
return null;
}
$fs = get_file_storage();
if ($filearea == 'file' || $filearea == 'notes' || $filearea == 'image' || $filearea == 'captionsfile') {
$filepath = is_null($filepath) ? '/' : $filepath;
$filename = is_null($filename) ? '.' : $filename;
$urlbase = $CFG->wwwroot.'/pluginfile.php';
if (!$storedfile = $fs->get_file($context->id, 'mod_eduplayer', $filearea, 0, $filepath, $filename)) {
if ($filepath === '/' and $filename === '.') {
$storedfile = new virtual_root_file($context->id, 'mod_eduplayer', $filearea, 0);
} else {
// not found
return null;
}
}
return new eduplayer_content_file_info($browser, $context, $storedfile, $urlbase, $areas[$filearea], true, true, true, false);
}
// note: resource_intro handled in file_browser automatically
return null;
}
/**
* Serves the files from the eduplayer file areas
*
* @package mod_eduplayer
* @category files
*
* @param stdClass $course the course object
* @param stdClass $cm the course module object
* @param stdClass $context the eduplayer's context
* @param string $filearea the name of the file area
* @param array $args extra arguments (itemid, path)
* @param bool $forcedownload whether or not force download
* @param array $options additional options affecting the file serving
*/
function eduplayer_pluginfile($course, $cm, $context, $filearea, array $args, $forcedownload, array $options=array()) {
global $DB, $CFG;
if ($context->contextlevel != CONTEXT_MODULE) {
send_file_not_found();
}
require_course_login($course, true, $cm);
if (($filearea == 'notes') || ($filearea == 'file') || ($filearea == 'image') || ($filearea == 'captionsfile')) {
#OK Continue..
} else {
return false;
}
$fileid = (int)array_shift($args);
$fs = get_file_storage();
$relativepath = implode('/', $args);
//$fullpath = "/$context->id/mod_eduplayer/$filearea/$fileid/$relativepath";
$fullpath = "/$context->id/mod_eduplayer/$filearea/0/$relativepath";
if (!$file = $fs->get_file_by_hash(sha1($fullpath)) or $file->is_directory() ) {
return false;
}
send_stored_file($file, 360, 0, $forcedownload);
}
/**
* File browsing support class
*/
class eduplayer_content_file_info extends file_info_stored {
public function get_parent() {
if ($this->lf->get_filepath() === '/' and $this->lf->get_filename() === '.') {
return $this->browser->get_file_info($this->context);
}
return parent::get_parent();
}
public function get_visible_name() {
if ($this->lf->get_filepath() === '/' and $this->lf->get_filename() === '.') {
return $this->topvisiblename;
}
return parent::get_visible_name();
}
}
////////////////////////////////////////////////////////////////////////////////
// Navigation API //
////////////////////////////////////////////////////////////////////////////////
/**
* Extends the global navigation tree by adding eduplayer nodes if there is a relevant content
*
* This can be called by an AJAX request so do not rely on $PAGE as it might not be set up properly.
*
* @param navigation_node $navref An object representing the navigation tree node of the eduplayer module instance
* @param stdClass $course
* @param stdClass $module
* @param cm_info $cm
*/
function eduplayer_extend_navigation(navigation_node $navref, stdclass $course, stdclass $module, cm_info $cm) {
}
/**
* Extends the settings navigation with the eduplayer settings
*
* This function is called when the context for the page is a eduplayer module. This is not called by AJAX
* so it is safe to rely on the $PAGE.
*
* @param settings_navigation $settingsnav {@link settings_navigation}
* @param navigation_node $eduplayernode {@link navigation_node}
*/
function eduplayer_extend_settings_navigation(settings_navigation $settingsnav, navigation_node $eduplayernode=null) {
}
/**
* Construct Javascript SWFObject embed code for <body> section of view.php
* Please note: some URLs append a '?'.time(); query to prevent browser caching
*
* @param $eduplayer (mdl_mplayer DB record for current mplayer module instance)
* @return string
*/
function eduplayer_video($eduplayer) {
global $CFG, $COURSE, $CFG;
$cm = get_coursemodule_from_instance('eduplayer', $eduplayer->id, $COURSE->id);
//$context = get_context_instance(CONTEXT_MODULE, $cm->id);
$context = context_module::instance($cm->id); //Moodle 3.2 Mihir
$video = eduplayer_player_helper($eduplayer, $cm, $context);
//Notes
$eduplayer->notes = file_rewrite_pluginfile_urls($eduplayer->notes, 'pluginfile.php', $context->id, 'mod_eduplayer', 'notes', 0);
$video .= html_writer::tag('div', $eduplayer->notes, array('id' => 'videoNotes'));
//If eduplayer type is audio and has no image poster set overflow to every container
if( $eduplayer->type=='audio' && ( $eduplayer->image == '' || is_null( $eduplayer->image ) ) )
$video .= html_writer::tag('style', '.jwplayer{height: 120px !important;} object{outline: none;}');
// $video .= html_writer::tag('style', '#page-content, #region-main-box, #region-main-wrap, #region-main, .region-content{overflow: visible !important;}');
return $video;
}
/*
* Enabled video extensions
*/
function eduplayer_video_extensions() {
$extensions = array(
'.mp4',
'.flv',
'.webm',
'.MP4',
'.FLV',
'.WEBM'
);
return $extensions;
}
/*
* Enabled image extensions
*/
function eduplayer_image_extensions() {
$extensions = array(
'.jpg',
'.jpeg',
'.png',
'.JPG',
'.JPEG',
'.PNG'
);
return $extensions;
}
/*
* Enabled captions extensions
*/
function eduplayer_captions_extensions() {
$extensions = array(
'.vtt',
'.srt',
'.VTT',
'.SRT'
);
return $extensions;
}
/*
* Enabled audio extensions
*/
function eduplayer_audio_extensions() {
$extensions = array(
'.mp3',
'.m4a'
);
return $extensions;
}
/*
* Normalize height for audio format
* If is audio force the height to 35 px only if poster is empty
*/
function normalize_height( $eduplayer ){
if( $eduplayer->type === 'audio' && ( is_null( $eduplayer->image ) || $eduplayer->image=='') ){
$eduplayer->height = '35';
}else if( $eduplayer->type === 'audio' && $eduplayer->image!='' && $eduplayer->height < '360' ){
$eduplayer->height = '360';
}
return $eduplayer->height;
}
/*
* Return
* 'true' if you want show the logo
* 'false' if you don't ant ot
*/
function showlogo(){
return 'false';
}