Parcourir la source

Update 'view.php'

125 to 188 lines.
Added new comments and new debuging (admin) function "generateCallTrace()"
leo il y a 1 semaine
Parent
commit
53dec2fa26
1 fichiers modifiés avec 188 ajouts et 125 suppressions
  1. 188 125
      view.php

+ 188 - 125
view.php

@@ -1,125 +1,188 @@
-<?php
-
-/**
- * This php script contains all the stuff to display iAssign.
- * 
- * @author Patricia Alves Rodrigues
- * @author Leo^nidas O. Branda~o
- * @version v 1.0 2012/10/16
- * @package mod_iassign
- * @since 2010/09/27
- * @copyright iMatica (<a href="http://www.matematica.br">iMath</a>) - Computer Science Dep. of IME-USP (Brazil)
- * 
- * <b>License</b> 
- *  - http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later
- */
-
-require_once("../../config.php");
-require_once("lib.php");
-require_once($CFG->libdir . '/completionlib.php');
-require_once($CFG->libdir . '/plagiarismlib.php');
-
-//DEBUG 2020/08/31
-//D require_once("ilm_debug/escreva.php"); //leo REMOVER! xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
-//D $resp = writeContent("", "", "todos_files_iassign.txt", "Teste"); // ($filetype1, $pathbase, $outputFile, $msgToRegister) //leo REMOVER!
-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 * FROM {files} WHERE " . $indices . " ORDER BY timecreated DESC";
-  $all_files = $DB->get_records_sql($str_query);
-
-  $total = count($all_files);
-  $msg = "#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(); //leo REMOVER! xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
-//D Remover todos itens de 'files' tal que: filesize = 0
-
-//Parameters GET e POST (parâmetros GET e 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 {
-  $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);
-
-// Mark viewed by user (if required)
-$completion = new completion_info($course);
-$completion->set_module_viewed($cm);
-
-// About each object
-// - $iassing :: object from table '*_iassign_statement'
-// - $cm      :: object from table '*_course_modules'
-// - $course  :: object from table '*_course_modules_completion'
-
-$write_solution = 1;
-
-// 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);
-
- // ./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()
+<?php
+
+/**
+ * This php script contains all the stuff to present iAssign activity.
+ * 
+ * @author Patricia Alves Rodrigues
+ * @author Leo^nidas O. Branda~o
+ * @version v 1.0 2012/10/16
+ * @package mod_iassign
+ * @since 2010/09/27
+ * @copyeleft LInE (<a href="http://www.matematica.br">iMath</a>)
+ *            iMatica (<a href="http://www.usp.br/line">LInE</a>)
+ *            Computer Science Dep. of IME-USP (Brazil)
+ * 
+ * <b>License</b> 
+ *  - 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 "<pre>generateCallTrace(): " . generateCallTrace() . "</pre><br/>\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()