| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188 |
- <?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()
|