moodle/mod/survey/save.php

100 lines
2.7 KiB
PHP
Raw Normal View History

<?php // $Id$
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
2008-06-09 16:53:30 +00:00
if (!$formdata = data_submitted()) {
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
}
require_login($course->id, 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');
$navigation = build_navigation('', $cm);
print_header_simple("$strsurveysaved", "", $navigation, "");
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
foreach ($formdata as $key => $val) {
2001-11-22 06:23:56 +00:00
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) {
2002-12-23 05:57:05 +00:00
$newdata->time = $timenow;
$newdata->userid = $USER->id;
2002-12-23 05:57:05 +00:00
$newdata->survey = $survey->id;
$newdata->question = $key;
2003-01-06 14:01:56 +00:00
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
2008-06-08 14:43:39 +00:00
if (! $DB->insert_record("survey_answers", $newdata)) {
2008-06-15 09:14:55 +00:00
print_error('cannotinsertanswer', 'survey');
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
?>