658d2d9d52410fe1e24a75bb524d64343129c63e
[moodle.git] / mod / feedback / complete_guest.php
1 <?php // $Id$
2 /**
3 * prints the form so an anonymous user can fill out the feedback on the mainsite
4 *
5 * @version $Id$
6 * @author Andreas Grabs
7 * @license http://www.gnu.org/copyleft/gpl.html GNU Public License
8 * @package feedback
9 */
11     require_once("../../config.php");
12     require_once("lib.php");
14     $id = required_param('id', PARAM_INT);
15     $completedid = optional_param('completedid', false, PARAM_INT);
16     $preservevalues  = optional_param('preservevalues', 0,  PARAM_INT);
17     $courseid = optional_param('courseid', false, PARAM_INT);
18     $gopage = optional_param('gopage', -1, PARAM_INT);
19     $lastpage = optional_param('lastpage', false, PARAM_INT);
20     $startitempos = optional_param('startitempos', 0, PARAM_INT);
21     $lastitempos = optional_param('lastitempos', 0, PARAM_INT);
23     $highlightrequired = false;
25     if(($formdata = data_submitted('nomatch')) AND !confirm_sesskey()) {
26         error('no sesskey defined');
27     }
28     
29     //if the use hit enter into a textfield so the form should not submit
30     if(isset($formdata->sesskey) AND !isset($formdata->savevalues) AND !isset($formdata->gonextpage) AND !isset($formdata->gopreviouspage)) {
31         $gopage = $formdata->lastpage;
32     }
33     if(isset($formdata->savevalues)) {
34         $savevalues = true;
35     }else {
36         $savevalues = false;
37     }
38     
39     if($gopage < 0 AND !$savevalues) {
40         if(isset($formdata->gonextpage)){
41             $gopage = $lastpage + 1;
42             $gonextpage = true;
43             $gopreviouspage = false;
44         }else if(isset($formdata->gopreviouspage)){
45             $gopage = $lastpage - 1;
46             $gonextpage = false;
47             $gopreviouspage = true;
48         }else {
49             error('parameter (gopage) required');
50         }
51     }else {
52         $gonextpage = $gopreviouspage = false;
53     }
54     
56     if ($id) {
57         if (! $cm = get_coursemodule_from_id('feedback', $id)) {
58             error("Course Module ID was incorrect");
59         }
60      
61         if (! $course = get_record("course", "id", $cm->course)) {
62             error("Course is misconfigured");
63         }
64      
65         if (! $feedback = get_record("feedback", "id", $cm->instance)) {
66             error("Course module is incorrect");
67         }
68     }
70     $capabilities = feedback_load_capabilities($cm->id);
71     
72     //check whether the feedback is anonymous
73     if($feedback->anonymous == FEEDBACK_ANONYMOUS_YES) {
74         $capabilities->complete = true;
75     }else {
76         error(get_string('feedback_is_not_for_anonymous'));
77     }
78     
79     //check whether the user has a session
80     if(!isset($USER->sesskey) OR !$USER->sesskey) {
81         error('error');
82     }
83     
84     //check whether the feedback is located and! started from the mainsite
85     if($course->id == SITEID AND !$courseid) {
86         $courseid = SITEID;
87     }
88     
89     require_course_login($course);
90     
91     if($courseid AND $courseid != SITEID) {
92         $course2 = get_record('course', 'id', $courseid);
93         require_course_login($course2); //this overwrites the object $course :-(
94         $course = get_record("course", "id", $cm->course); // the workaround
95     }
96     
97     if(!$capabilities->complete) {
98         error(get_string('error'));
99     }
101     
102     /// Print the page header
103     $strfeedbacks = get_string("modulenameplural", "feedback");
104     $strfeedback  = get_string("modulename", "feedback");
105     $buttontext = update_module_button($cm->id, $course->id, $strfeedback);
106     
107     $navlinks = array();
108     $navlinks[] = array('name' => $strfeedbacks, 'link' => "index.php?id=$course->id", 'type' => 'activity');
109     $navlinks[] = array('name' => format_string($feedback->name), 'link' => "", 'type' => 'activityinstance');
110     
111     $navigation = build_navigation($navlinks);
112     
113     print_header_simple(format_string($feedback->name), "",
114                  $navigation, "", "", true, $buttontext, navmenu($course, $cm));
116     //ishidden check. hidden feedbacks except feedbacks on mainsite are only accessible with related capabilities
117     if ((empty($cm->visible) and !$capabilities->viewhiddenactivities) AND $course->id != SITEID) {
118         notice(get_string("activityiscurrentlyhidden"));
119     }
121     feedback_print_errors();
122   
123     //check, if the feedback is open (timeopen, timeclose)
124     $checktime = time();
125     if(($feedback->timeopen > $checktime) OR ($feedback->timeclose < $checktime AND $feedback->timeclose > 0)) {
126         // print_simple_box_start('center');
127         print_box_start('generalbox boxaligncenter');
128             echo '<h2><font color="red">'.get_string('feedback_is_not_open', 'feedback').'</font></h2>';
129             print_continue($CFG->wwwroot.'/course/view.php?id='.$course->id);
130         // print_simple_box_end();
131         print_box_end();
132         print_footer($course);
133         exit;
134     }
135     
136     //additional check for multiple-submit (prevent browsers back-button). the main-check is in view.php
137     $feedback_can_submit = true;
138     if($feedback->multiple_submit == 0 ) {
139         // if($multiple_count = get_record('feedback_tracking', 'userid', $USER->id, 'feedback', $feedback->id)) {
140         if(feedback_is_already_submitted($feedback->id, $courseid)) {
141             $feedback_can_submit = false;
142         }
143     }
144     if($feedback_can_submit) {
145         //preserving the items
146         if($preservevalues == 1){
147             if(!$SESSION->feedback->is_started == true)error('error', $CFG->wwwroot.'/course/view.php?id='.$course->id);
148             //check, if all required items have a value
149             if(feedback_check_values($_POST, $startitempos, $lastitempos)) {
150                 $userid = $USER->id; //arb
151                 if($completedid = feedback_save_guest_values($_POST, $USER->sesskey)){
152                     add_to_log($course->id, 'feedback', 'startcomplete', 'view.php?id='.$cm->id, $feedback->id); //arb: log even guest submissions or at least the startcomplete since the other add log event is elsewhere
153                     
154                     if(!$gonextpage AND !$gopreviouspage) $preservevalues = false;//es kann gespeichert werden
155                     
156                 }else {
157                     $savereturn = 'failed';
158                     if(isset($lastpage)) {
159                         $gopage = $lastpage;
160                     }else {
161                         error('parameter failed');
162                     }
163                 }
164             }else {
165                 $savereturn = 'missing';
166                 $highlightrequired = true;
167                 if(isset($lastpage)) {
168                     $gopage = $lastpage;
169                 }else {
170                     error('parameter failed');
171                 }
172             }
173         }
174         
175         //saving the items
176         if($savevalues AND !$preservevalues){
177             //exists there any pagebreak, so there are values in the feedback_valuetmp
178             $userid = $USER->id; //arb changed from 0 to $USER->id - no strict anonymous feedbacks - if it is a guest taking it then I want to know that it was a guest (at least in the data saved in the feedback tables)
180             $feedbackcompletedtmp = get_record('feedback_completedtmp', 'id', $completedid);
181             
182             //fake saving for switchrole
183             $is_switchrole = feedback_check_is_switchrole();
184             if($is_switchrole) {
185                 $savereturn = 'saved';
186                 feedback_delete_completedtmp($completedid);
187             }else if($new_completed_id = feedback_save_tmp_values($feedbackcompletedtmp, false, $userid)) {
188                 $savereturn = 'saved';
189                 feedback_send_email_anonym($cm, $feedback, $course, $userid);
190                 unset($SESSION->feedback->is_started);
191                 
192             }else {
193                 $savereturn = 'failed';
194             }
195         }
198         if($allbreaks = feedback_get_all_break_positions($feedback->id)){
199             if($gopage <= 0) {
200                 $startposition = 0;
201             }else {
202                 $startposition = $allbreaks[$gopage - 1];
203             }
204             $ispagebreak = true;
205         }else {
206             $startposition = 0;
207             $newpage = 0;
208             $ispagebreak = false;
209         }
210         
211         //get the feedbackitems after the last shown pagebreak
212         $feedbackitems = get_records_select('feedback_item', 'feedback = '.$feedback->id.' AND position > '.$startposition, 'position');
213         //get the first pagebreak
214         if($pagebreaks = get_records_select('feedback_item', "feedback = ".$feedback->id." AND typ = 'pagebreak'", 'position')) {
215             $pagebreaks = array_values($pagebreaks);
216             $firstpagebreak = $pagebreaks[0];
217         }else {
218             $firstpagebreak = false;
219         }
220         $maxitemcount = count_records('feedback_item', 'feedback', $feedback->id);
221         $feedbackcompletedtmp = feedback_get_current_completed($feedback->id, true, $courseid, $USER->sesskey);
223         /// Print the main part of the page
224         ///////////////////////////////////////////////////////////////////////////
225         ///////////////////////////////////////////////////////////////////////////
226         ///////////////////////////////////////////////////////////////////////////
227         print_heading(format_text($feedback->name));
228         
229         if(isset($savereturn) && $savereturn == 'saved') {
230             if($feedback->page_after_submit) {
231                 // print_simple_box_start('center', '75%');
232                 print_box_start('generalbox boxaligncenter boxwidthwide');
233                 echo format_text(stripslashes_safe($feedback->page_after_submit));
234                 // print_simple_box_end();
235                 print_box_end();
236             } else {
237                 echo '<p align="center"><b><font color="green">'.get_string('entries_saved','feedback').'</font></b></p>';
238                 if( intval($feedback->publish_stats) == 1) {
239                     echo '<p align="center"><a href="analysis.php?id=' . $id . '&courseid='.$courseid.'">';
240                     echo get_string('completed_feedbacks', 'feedback').'</a>';
241                     echo '</p>';
242                 }
243             }
244             if($feedback->site_after_submit) {
245                 print_continue(feedback_encode_target_url($feedback->site_after_submit));
246             }else {
247                 if($courseid) {
248                     if($courseid == SITEID) {
249                         print_continue($CFG->wwwroot);
250                     }else {
251                         print_continue($CFG->wwwroot.'/course/view.php?id='.$courseid);
252                     }
253                 }else {
254                     if($course->id == SITEID) {
255                         print_continue($CFG->wwwroot);
256                     } else {
257                         print_continue($CFG->wwwroot.'/course/view.php?id='.$course->id);
258                     }
259                 }
260             }
261         }else {
262             if(isset($savereturn) && $savereturn == 'failed') {
263                 echo '<p align="center"><b><font color="red">'.get_string('saving_failed','feedback').'</font></b></p>';
264             }
265     
266             if(isset($savereturn) && $savereturn == 'missing') {
267                 echo '<p align="center"><b><font color="red">'.get_string('saving_failed_because_missing_or_false_values','feedback').'</font></b></p>';
268             }
269     
270             //print the items
271             if(is_array($feedbackitems)){
272                 // print_simple_box_start('center', '75%');
273                 print_box_start('generalbox boxaligncenter boxwidthwide');
274                 echo '<div align="center"><form name="frm" action="'.$ME.'" method="post" onsubmit=" ">';
275                 echo '<table>';
276                 echo '<tr><td colspan="3" align="center">
277                         <input type="hidden" name="anonymous" value="0" />
278                         <input type="hidden" name="anonymous_response" value="'.FEEDBACK_ANONYMOUS_YES.'" />
279                         <input type="hidden" name="sesskey" value="'.$USER->sesskey.'" />
280                         &nbsp;
281                       </td></tr>';
282                 //check, if there exists required-elements
283                 $countreq = count_records('feedback_item', 'feedback', $feedback->id, 'required', 1);
284                 if($countreq > 0) {
285                     echo '<tr><td colspan="3"><font color="red">(*)' . get_string('items_are_required', 'feedback') . '</font></td></tr>';
286                 }
287                 
288                 unset($startitem);
289                 $itemnr = count_records_select('feedback_item', 'feedback = '. $feedback->id . ' AND hasvalue = 1 AND position < '.$startposition);
290                 foreach($feedbackitems as $feedbackitem){
291                     if(!isset($startitem)) {
292                         //avoid showing double pagebreaks
293                         if($feedbackitem->typ == 'pagebreak') continue;
294                         $startitem = $feedbackitem;
295                     }
296                     $value = '';
297                     //get the value
298                     $frmvaluename = $feedbackitem->typ . '_'. $feedbackitem->id;
299                     if(isset($savereturn)) {
300                         $value =  isset($formdata->{$frmvaluename})?$formdata->{$frmvaluename}:NULL;
301                     }else {
302                         if(isset($feedbackcompletedtmp->id)) {
303                             $value = feedback_get_item_value($feedbackcompletedtmp->id, $feedbackitem->id, $USER->sesskey);
304                         }
305                     }
306                     echo '<tr>';
307                     if($feedbackitem->hasvalue == 1 AND $feedback->autonumbering) {
308                         $itemnr++;
309                         echo '<td valign="top">' . $itemnr . '.&nbsp;</td>';
310                     } else {
311                         echo '<td>&nbsp;</td>';
312                     }
313                     if($feedbackitem->typ != 'pagebreak') {
314                         feedback_print_item($feedbackitem, $value, false, false, $highlightrequired);
315                     }
316                     echo '</tr>';
317                     echo '<tr><td>&nbsp;</td></tr>';
318                     
319                     $lastbreakposition = $feedbackitem->position; //last item-pos (item or pagebreak)
320                     if($feedbackitem->typ == 'pagebreak'){
321                         break;
322                     }else {
323                         $lastitem = $feedbackitem;
324                     }
325                 }
326                 echo '</table>';
327                 echo '<input type="hidden" name="id" value="'.$id.'" />';
328                 echo '<input type="hidden" name="feedbackid" value="'.$feedback->id.'" />';
329                 echo '<input type="hidden" name="lastpage" value="'.$gopage.'" />';
330                 echo '<input type="hidden" name="completedid" value="'.(isset($feedbackcompletedtmp->id)?$feedbackcompletedtmp->id:'').'" />';
331                 echo '<input type="hidden" name="courseid" value="'. $courseid . '" />';
332                 echo '<input type="hidden" name="preservevalues" value="1" />';
333                 if(isset($startitem)) {
334                     echo '<input type="hidden" name="startitempos" value="'. $startitem->position . '" />';
335                     echo '<input type="hidden" name="lastitempos" value="'. $lastitem->position . '" />';
336                 }
337                 
338                 if($ispagebreak AND $lastbreakposition > $firstpagebreak->position) {
339                     echo '<input name="gopreviouspage" type="submit" value="'.get_string('previous_page','feedback').'" />';
340                 }
341                 if($lastbreakposition < $maxitemcount){
342                     echo '<input name="gonextpage" type="submit" value="'.get_string('next_page','feedback').'" />';
343                 }
344                 if($lastbreakposition >= $maxitemcount) { //last page
345                     echo '<input name="savevalues" type="submit" value="'.get_string('save_entries','feedback').'" />';
346                 }
347                 
348                 echo '</form>';
349                 
350                 if($courseid) {
351                     echo '<form name="frm" action="'.$CFG->wwwroot.'/course/view.php?id='.$courseid.'" method="post" onsubmit=" ">';
352                 }else{
353                     if($course->id == SITEID) {
354                         echo '<form name="frm" action="'.$CFG->wwwroot.'" method="post" onsubmit=" ">';
355                     } else {
356                         echo '<form name="frm" action="'.$CFG->wwwroot.'/course/view.php?id='.$course->id.'" method="post" onsubmit=" ">';
357                     }
358                 }
359                 echo '<input type="hidden" name="sesskey" value="' . $USER->sesskey . '" />';
360                 echo '<input type="hidden" name="courseid" value="'. $courseid . '" />';
361                 echo '<button type="submit">'.get_string('cancel').'</button>';
362                 echo '</form>';
363                 echo '</div>';
364                 $SESSION->feedback->is_started = true;
365                 // print_simple_box_end();
366                 print_box_end();
367             }
368         }
369     }else {
370         // print_simple_box_start('center');
371         print_box_start('generalbox boxaligncenter');
372             echo '<h2><font color="red">'.get_string('this_feedback_is_already_submitted', 'feedback').'</font></h2>';
373             print_continue($CFG->wwwroot.'/course/view.php?id='.$course->id);
374         // print_simple_box_end();
375         print_box_end();
376     }
377     /// Finish the page
378     ///////////////////////////////////////////////////////////////////////////
379     ///////////////////////////////////////////////////////////////////////////
380     ///////////////////////////////////////////////////////////////////////////
382     print_footer($course);
384 ?>