iMath)
* iMatica (LInE)
* Computer Science Dep. of IME-USP (Brazil)
*
* License
* - http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later
*/
/// About the relation Moodle/iAssign through "view.php"
/// @calledby locallib.php!view_iassign_current(): onclick="submit_comment('http://.../mod/iassign/view.php?id=...')"
/// @calledby locallib.php!write_comment_submission(): $return = "" . $CFG->wwwroot . "/mod/iassign/view.php?action=viewsubmission&id="...
// 1776/9739 : function add_comment () : com codigo teste invocando "generateCallTrace(.)"
// 1795/9739 : $contexto = $this->generateCallTrace(); // debug_backtrace()
// 3084/9739 : function view_iassign_current () : tem o codigo JS com a funcao JS "function view_iassign_current()"
// onclick="submit_comment('http://localhost/saw/mod/iassign/view.php?id=26981&action=newcomment&iassign_current=6848&iassign_submission_current=35665&userid_iassign=10823&row=6&column=2')
// resultado: submit_comment(url): url=http://localhost/saw/mod/iassign/view.php?id=26981&action=newcomment&iassign_current=6848&iassign_submission_current=35665&userid_iassign=10823&row=6&column=2
// 3790/9739 : [JS] function submit_comment(url) :
// 5610/9739 : function write_comment_submission ()
require_once("../../config.php");
require_once("lib.php");
require_once($CFG->libdir . '/completionlib.php'); // $completion = new completion_info($course); $completion->set_module_viewed($cm);
require_once($CFG->libdir . '/plagiarismlib.php');
//DEBUG To be used in debug process, mainlly when 'view.php' is called by JavaScript (e.g. during send comment, call evaluation)
function generateCallTrace () { //DEBUG @sse locallib.php!generateCallTrace()
// $e = new Exception(); $trace = explode("\n", $e->getTraceAsString());
$trace = debug_print_backtrace();
// reverse array to make steps line up chronologically
if (is_null($trace)) return "";
$trace = array_reverse($trace);
array_shift($trace); // remove {main}
array_pop($trace); // remove call to this method
$length = count($trace);
$result = array();
for ($i = 0; $i < $length; $i++) {
$result[] = ($i + 1) . ')' . substr($trace[$i], strpos($trace[$i], ' ')); // replace '#someNum' with '$i)', set the right ordering
}
return "\t" . implode("\n\t", $result);
}
//DEBUG To trace "view.php" called by JavaScript (e.g. when teacher/nonediting teacher send comment, student calls evaluation)
//DEBUG can use generateCallTrace() to write into "ilm_debug/" throught "ilm_debug/escreva.php".
//DEBUG echo "
generateCallTrace(): " . generateCallTrace() . "
\n"; exit;
//D require_once("ilm_debug/escreva.php");
//D $resp = writeContent("", "", "todos_files_iassign.txt", "Teste"); // ($filetype1, $pathbase, $outputFile, $msgToRegister) //leo REMOVER!
//DEBUG To debug problems with Moodle FileSystem
function get_all_iassign_files () {
// Get all iAssign files on table 'files':
// files = id; contenthash; pathnamehash; contextid; component; filearea; itemid; filepath; filename; userid; filesize; mimetype; status; source; author;
// license; timecreated; timemodified; sortorder; referencefileid
global $DB;
// $all_files = $DB->get_records('files', array('component' => 'mod_iassign')); // pegar os do iAssign
$indices = "id=257279 OR id=257791 OR id=258303 OR id=258559 OR id=127743 OR id=64767 OR id=65023 OR id= 65535 OR id= 87394 OR " .
"id=138498 OR id=138506 OR id=138514 OR id=138522 OR id=50463 OR id=50464 OR id= 50465 OR id=138530 OR id= 50466 OR " .
"id= 50467 OR id= 50468 OR id= 50469 OR id=50470 OR id=50471 OR id=104744 OR id=50472";
$str_query = "SELECT id,contextid,filearea,itemid,filepath,filename,userid,author,timecreated FROM {files}\n" .
"WHERE " . $indices . " ORDER BY timecreated DESC";
$all_files = $DB->get_records_sql($str_query);
$total = count($all_files);
$msg = $str_query . "\n#linhas = " . $total . "\n";
foreach ($all_files as $linha) {
foreach ($linha as $key => $value) {
if ($key == "timecreated") {
$time1 = date('Y-m-d H:i:s', $value - date('Z')); // 12:50:29
$msg .= $time1 . ";" . $value . ";";
}
else
if ($key == "source") {
// $item = str_replace(";", "\;", $value);
$item = addslashes($value);
$msg .= "'" . addslashes($value) . "';";
}
else $msg .= $value . ";";
}
$msg .= "\n";
}
require_once("ilm_debug/escreva.php"); //leo REMOVER! xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
$resp = writeContent("", "", "todos_files_iassign.csv", $msg); // ($filetype1, $pathbase, $outputFile, $msgToRegister) //leo REMOVER!
}
//D get_all_iassign_files(); //REMOVER
//D get_all_iassign_files(); //leo REMOVER! xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
//D Remover todos itens de 'files' tal que: filesize = 0
// Parameters GET and POST
$id = optional_param('id', 0, PARAM_INT); // Course Module ID
$a = optional_param('a', 0, PARAM_INT); // iAssign instance id (from table 'iassign')
$mood_url = new moodle_url('/mod/iassign/view.php');
if ($id) {
// ./lib/datalib.php : function get_coursemodule_from_id($modulename, $cmid, $courseid=0, $sectionnum=false, $strictness=IGNORE_MISSING): returns 'course_modules.*' and 'modules.name'
$cm = get_coursemodule_from_id('iassign', $id);
if (!$cm) { // Moodle function 'get_coursemodule_from_id(...)' returns the object from table '*_iassign_statement'
print_error('invalidcoursemodule');
}
$iassign = $DB->get_record("iassign", array("id" => $cm->instance));
if (!$iassign) { // 'course_modules.instance = iassign.id'
print_error('invalidid', 'iassign');
}
$course = $DB->get_record("course", array("id" => $iassign->course));
if (!$course) {
print_error('coursemisconf', 'iassign');
}
$mood_url->param('id', $id);
}
else {
if (!$a) { // try with 'iassign_current'
$iassign_current = optional_param('iassign_current', 0, PARAM_INT);
if ($iassign_current) { // use {iassign_statement}.id to get {iassign}.id
$iassign_statement = $DB->get_record("iassign_statement", array("id" => $iassign_current));
$a = $iassign_statement->iassignid;
}
}
$iassign = $DB->get_record("iassign", array("id" => $a));
if (!$iassign) {
print_error('invalidid', 'iassign');
}
$course = $DB->get_record("course", array("id" => $iassign->course));
if (!$course) {
print_error('coursemisconf', 'iassign');
}
$cm = get_coursemodule_from_instance("iassign", $iassign->id, $course->id);
if (!$cm) {
print_error('invalidcoursemodule');
}
$mood_url->param('a', $a);
}
$PAGE->set_url($mood_url);
require_login($course, true, $cm);
$PAGE->set_title(format_string($iassign->name));
$PAGE->set_heading($course->fullname);
// About each object/table
// - $iassing :: object from table '*_iassign_statement'
// - $cm :: object from table '*_course_modules'
// - $course :: object from table '*_course_modules_completion'
// Marks a module as viewed, i.e., register in {course_modules_completion} the current {course_modules}.id and {user}.id
// It is necessary: "$CFG->enablecompletion = 1" in "./config.php"
// With "$CFG->enablecompletion = 1" in "config.php" it is possible to set item "Completion tracking" in ./course/edit.php?id=X
// {course} must have 'enablecompletion = 1'
$completion = new completion_info($course);
$completion->set_module_viewed($cm, $USER->id); // ./lib/completionlib.php : set_module_viewed($cm, $userid=0)
// ./lib/completionlib.php : see this
// - public function set_module_viewed($cm, $userid=0): 715/1372 - need {course_modules}.completionview == 1
// cm->completionview=1, COMPLETION_VIEW_NOT_REQUIRED=0, this->is_enabled(cm)=0
// if ($cm->completionview == COMPLETION_VIEW_NOT_REQUIRED || !$this->is_enabled($cm)) return;
// $this->update_state($cm, COMPLETION_COMPLETE, $userid);
// - public function update_state($cm, $possibleresult=COMPLETION_UNKNOWN, $userid=0, $override = false) : 565/1374
// $this->internal_set_data($cm, $current);
// - public function internal_set_data($cm, $data) : 1039/1372
// $event->add_record_snapshot('course_modules_completion', $data);
// - public function is_enabled($cm = null): 279/1374 -- Checks whether completion is enabled in a particular course and possibly activity
// $CFG->enablecompletion, $CFG->enablecompletion != COMPLETION_DISABLED
// $this->course->enablecompletion != COMPLETION_DISABLED == 0 ; COMPLETION_ENABLED == 1
$write_solution = 1;
// ./mod/iassign/locallib.php : class iassign : function __construct ($iassign, $cm, $course)
//$iassigninstance = new iassign($iassign, $cm, $course, array('write_solution' => 1));
$iassigninstance = new iassign($iassign, $cm, $course); // this will provide read iLM content
// ./mod/iassign/locallib.php : in class iassign, actually who display the iAssign whose id is '$id'! (this function ignores parameters)
$iassigninstance->view(); // will call $this->action(), that calls view_iassign_current()