moodle/mod/survey/save.php

125 lines
3.7 KiB
PHP
Raw Normal View History

<?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
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
}
$id = required_param('id', PARAM_INT); // Course Module ID
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
}
$PAGE->set_url('/mod/survey/save.php', array('id'=>$id));
require_login($course, false, $cm);
2006-08-09 13:39:44 +00:00
$context = get_context_instance(CONTEXT_MODULE, $cm->id);
require_capability('mod/survey:participate', $context);
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
}
add_to_log($course->id, "survey", "submit", "view.php?id=$cm->id", "$survey->id", "$cm->id");
2001-11-22 06:23:56 +00:00
$strsurveysaved = get_string('surveysaved', 'survey');
$PAGE->set_title($strsurveysaved);
$PAGE->set_heading($course->fullname);
echo $OUTPUT->header();
2001-11-22 06:23:56 +00:00
if (survey_already_done($survey->id, $USER->id)) {
notice(get_string("alreadysubmitted", "survey"), $_SERVER["HTTP_REFERER"]);
2001-11-22 06:23:56 +00:00
exit;
}
// Sort through the data and arrange it
// 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
$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") {
if ( substr($key,0,1) == "q") {
$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") {
$realkey = (int) substr($key,1);
2001-11-22 06:23:56 +00:00
$answers[$realkey][1] = $val;
} else {
$answers[$key][0] = $val;
}
}
}
2001-11-22 06:23:56 +00:00
// Now store the data.
$timenow = time();
foreach ($answers as $key => $val) {
if ($key != 'sesskey') {
$newdata = new stdClass();
$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
$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");
2001-11-22 06:23:56 +00:00
exit;
2001-11-22 06:23:56 +00:00