2009-09-17 04:11:46 +00:00
|
|
|
<?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/>.
|
|
|
|
|
|
|
|
/**
|
|
|
|
* This file is responsible for saving the results of a users survey and displaying
|
|
|
|
* the final message.
|
|
|
|
*
|
|
|
|
* @package mod-survey
|
|
|
|
* @copyright 1999 onwards Martin Dougiamas {@link http://moodle.com}
|
|
|
|
* @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later
|
|
|
|
*/
|
2001-11-22 06:23:56 +00:00
|
|
|
|
2004-08-22 14:38:47 +00:00
|
|
|
require_once('../../config.php');
|
|
|
|
require_once('lib.php');
|
2001-11-22 06:23:56 +00:00
|
|
|
|
|
|
|
|
|
|
|
// Make sure this is a legitimate posting
|
|
|
|
|
2009-11-20 08:33:33 +00:00
|
|
|
if (!$formdata = data_submitted() or !confirm_sesskey()) {
|
2008-06-15 09:14:55 +00:00
|
|
|
print_error('cannotcallscript');
|
2001-11-22 06:23:56 +00:00
|
|
|
}
|
|
|
|
|
2005-10-29 16:45:58 +00:00
|
|
|
$id = required_param('id', PARAM_INT); // Course Module ID
|
|
|
|
|
2006-08-08 22:09:55 +00:00
|
|
|
if (! $cm = get_coursemodule_from_id('survey', $id)) {
|
2008-06-15 09:14:55 +00:00
|
|
|
print_error('invalidcoursemodule');
|
2001-11-22 06:23:56 +00:00
|
|
|
}
|
|
|
|
|
2008-06-08 14:43:39 +00:00
|
|
|
if (! $course = $DB->get_record("course", array("id"=>$cm->course))) {
|
2008-06-15 09:14:55 +00:00
|
|
|
print_error('coursemisconf');
|
2001-11-22 06:23:56 +00:00
|
|
|
}
|
|
|
|
|
2010-01-16 15:39:56 +00:00
|
|
|
$PAGE->set_url('/mod/survey/save.php', array('id'=>$id));
|
2012-04-22 17:41:47 +02:00
|
|
|
require_login($course, false, $cm);
|
2009-11-01 15:24:58 +00:00
|
|
|
|
2006-08-09 13:39:44 +00:00
|
|
|
$context = get_context_instance(CONTEXT_MODULE, $cm->id);
|
2006-08-14 05:55:40 +00:00
|
|
|
require_capability('mod/survey:participate', $context);
|
2009-11-01 15:24:58 +00:00
|
|
|
|
2008-06-08 14:43:39 +00:00
|
|
|
if (! $survey = $DB->get_record("survey", array("id"=>$cm->instance))) {
|
2008-06-15 09:14:55 +00:00
|
|
|
print_error('invalidsurveyid', 'survey');
|
2001-11-22 06:23:56 +00:00
|
|
|
}
|
|
|
|
|
2004-02-16 19:31:26 +00:00
|
|
|
add_to_log($course->id, "survey", "submit", "view.php?id=$cm->id", "$survey->id", "$cm->id");
|
2001-11-22 06:23:56 +00:00
|
|
|
|
2008-05-25 14:24:24 +00:00
|
|
|
$strsurveysaved = get_string('surveysaved', 'survey');
|
|
|
|
|
2009-09-08 02:02:03 +00:00
|
|
|
$PAGE->set_title($strsurveysaved);
|
2010-05-28 07:45:26 +00:00
|
|
|
$PAGE->set_heading($course->fullname);
|
2009-09-08 02:02:03 +00:00
|
|
|
echo $OUTPUT->header();
|
2007-04-16 21:29:42 +00:00
|
|
|
|
2001-11-22 06:23:56 +00:00
|
|
|
if (survey_already_done($survey->id, $USER->id)) {
|
2003-01-05 06:45:20 +00:00
|
|
|
notice(get_string("alreadysubmitted", "survey"), $_SERVER["HTTP_REFERER"]);
|
2001-11-22 06:23:56 +00:00
|
|
|
exit;
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
// Sort through the data and arrange it
|
2005-02-16 10:40:48 +00:00
|
|
|
// This is necessary because some of the questions
|
2001-11-22 06:23:56 +00:00
|
|
|
// may have two answers, eg Question 1 -> 1 and P1
|
|
|
|
|
2005-02-16 10:40:48 +00:00
|
|
|
$answers = array();
|
2001-11-22 06:23:56 +00:00
|
|
|
|
2010-09-18 13:55:56 +00:00
|
|
|
foreach ($formdata as $key => $val) {
|
|
|
|
if ($key <> "userid" && $key <> "id") {
|
2005-02-16 10:40:48 +00:00
|
|
|
if ( substr($key,0,1) == "q") {
|
2006-04-27 21:30:18 +00:00
|
|
|
$key = clean_param(substr($key,1), PARAM_ALPHANUM); // keep everything but the 'q', number or Pnumber
|
2001-11-22 06:23:56 +00:00
|
|
|
}
|
|
|
|
if ( substr($key,0,1) == "P") {
|
2006-04-27 21:30:18 +00:00
|
|
|
$realkey = (int) substr($key,1);
|
2001-11-22 06:23:56 +00:00
|
|
|
$answers[$realkey][1] = $val;
|
|
|
|
} else {
|
|
|
|
$answers[$key][0] = $val;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
2005-02-16 10:40:48 +00:00
|
|
|
|
2001-11-22 06:23:56 +00:00
|
|
|
|
|
|
|
// Now store the data.
|
|
|
|
|
|
|
|
$timenow = time();
|
|
|
|
foreach ($answers as $key => $val) {
|
2010-04-23 05:58:43 +00:00
|
|
|
if ($key != 'sesskey') {
|
2010-09-21 08:37:36 +00:00
|
|
|
$newdata = new stdClass();
|
2010-04-23 05:58:43 +00:00
|
|
|
$newdata->time = $timenow;
|
|
|
|
$newdata->userid = $USER->id;
|
|
|
|
$newdata->survey = $survey->id;
|
|
|
|
$newdata->question = $key;
|
|
|
|
if (!empty($val[0])) {
|
|
|
|
$newdata->answer1 = $val[0];
|
|
|
|
} else {
|
|
|
|
$newdata->answer1 = "";
|
|
|
|
}
|
|
|
|
if (!empty($val[1])) {
|
|
|
|
$newdata->answer2 = $val[1];
|
|
|
|
} else {
|
|
|
|
$newdata->answer2 = "";
|
|
|
|
}
|
2002-12-23 05:57:05 +00:00
|
|
|
|
2010-04-23 05:58:43 +00:00
|
|
|
$DB->insert_record("survey_answers", $newdata);
|
2003-01-06 14:01:56 +00:00
|
|
|
}
|
2001-11-22 06:23:56 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
// Print the page and finish up.
|
|
|
|
|
2002-08-12 17:54:13 +00:00
|
|
|
notice(get_string("thanksforanswers","survey", $USER->firstname), "$CFG->wwwroot/course/view.php?id=$course->id");
|
2005-02-16 10:40:48 +00:00
|
|
|
|
2001-11-22 06:23:56 +00:00
|
|
|
exit;
|
2005-02-16 10:40:48 +00:00
|
|
|
|
2001-11-22 06:23:56 +00:00
|
|
|
|
2009-11-01 15:24:58 +00:00
|
|
|
|