parent
68b8969d74
commit
9750f9e2c4
@ -0,0 +1,131 @@ |
||||
<?php |
||||
/* |
||||
DOKEOS - elearning and course management software |
||||
|
||||
For a full list of contributors, see documentation/credits.html |
||||
|
||||
This program 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 2 |
||||
of the License, or (at your option) any later version. |
||||
See "documentation/licence.html" more details. |
||||
|
||||
Contact: |
||||
Dokeos |
||||
Rue des Palais 44 Paleizenstraat |
||||
B-1030 Brussels - Belgium |
||||
Tel. +32 (2) 211 34 56 |
||||
*/ |
||||
|
||||
|
||||
/** |
||||
* @package dokeos.survey |
||||
* @author Arnaud Ligot <arnaud@cblue.be> |
||||
* @version $Id: $ |
||||
* |
||||
* small peace code to enable user to access images included into survey |
||||
* which are accessible by non authenticated users. This file is included |
||||
* by document/download.php |
||||
*/ |
||||
function check_download_survey($course, $invitation, $doc_url) { |
||||
|
||||
require_once('survey.lib.php'); |
||||
require_once (api_get_path(LIBRARY_PATH)."/course.lib.php"); |
||||
|
||||
// getting all the course information |
||||
$_course = CourseManager::get_course_information($course); |
||||
|
||||
// Database table definitions |
||||
$table_survey = Database :: get_course_table(TABLE_SURVEY, $_course['db_name']); |
||||
$table_survey_question = Database :: get_course_table(TABLE_SURVEY_QUESTION, $_course['db_name']); |
||||
$table_survey_question_option = Database :: get_course_table(TABLE_SURVEY_QUESTION_OPTION, $_course['db_name']); |
||||
$table_course = Database :: get_main_table(TABLE_MAIN_COURSE); |
||||
$table_user = Database :: get_main_table(TABLE_MAIN_USER); |
||||
$table_survey_invitation = Database :: get_course_table(TABLE_SURVEY_INVITATION, $_course['db_name']); |
||||
|
||||
|
||||
// now we check if the invitationcode is valid |
||||
$sql = "SELECT * FROM $table_survey_invitation WHERE invitation_code = '".Database::escape_string($invitation)."'"; |
||||
$result = api_sql_query($sql, __FILE__, __LINE__); |
||||
if (mysql_num_rows($result) < 1) |
||||
{ |
||||
Display :: display_error_message(get_lang('WrongInvitationCode'), false); |
||||
Display :: display_footer(); |
||||
exit; |
||||
} |
||||
$survey_invitation = mysql_fetch_assoc($result); |
||||
|
||||
// now we check if the user already filled the survey |
||||
if ($survey_invitation['answered'] == 1) |
||||
{ |
||||
Display :: display_error_message(get_lang('YouAlreadyFilledThisSurvey'), false); |
||||
Display :: display_footer(); |
||||
exit; |
||||
} |
||||
|
||||
// very basic security check: check if a text field from a survey/answer/option contains the name of the document requested |
||||
|
||||
|
||||
////////////// |
||||
// fetch survey ID |
||||
////////////// |
||||
|
||||
// If this is the case there will be a language choice |
||||
$sql = "SELECT * FROM $table_survey WHERE code='".Database::escape_string($survey_invitation['survey_code'])."'"; |
||||
$result = api_sql_query($sql, __FILE__, __LINE__); |
||||
if (mysql_num_rows($result) > 1) |
||||
{ |
||||
if ($_POST['language']) |
||||
{ |
||||
$survey_invitation['survey_id'] = $_POST['language']; |
||||
} |
||||
else |
||||
{ |
||||
echo '<form id="language" name="language" method="POST" action="'.api_get_self().'?course='.$_GET['course'].'&invitationcode='.$_GET['invitationcode'].'">'; |
||||
echo ' <select name="language">'; |
||||
while ($row=mysql_fetch_assoc($result)) |
||||
{ |
||||
echo '<option value="'.$row['survey_id'].'">'.$row['lang'].'</option>'; |
||||
} |
||||
echo '</select>'; |
||||
echo ' <input type="submit" name="Submit" value="'.get_lang('Ok').'" />'; |
||||
echo '</form>'; |
||||
display::display_footer(); |
||||
exit; |
||||
} |
||||
} |
||||
else |
||||
{ |
||||
$row=mysql_fetch_assoc($result); |
||||
$survey_invitation['survey_id'] = $row['survey_id']; |
||||
} |
||||
$sql = "select count(*) from $table_survey where survey_id = ".$survey_invitation['survey_id']." |
||||
and ( |
||||
title LIKE '%$doc_url%' |
||||
or subtitle LIKE '%$doc_url%' |
||||
or intro LIKE '%$doc_url%' |
||||
or surveythanks LIKE '%$doc_url%' |
||||
) |
||||
union select count(*) from $table_survey_question where survey_id = ".$survey_invitation['survey_id']." |
||||
and ( |
||||
survey_question LIKE '%$doc_url%' |
||||
or survey_question_comment LIKE '%$doc_url%' |
||||
) |
||||
union select count(*) from $table_survey_question_option where survey_id = ".$survey_invitation['survey_id']." |
||||
and ( |
||||
option_text LIKE '%$doc_url%' |
||||
)"; |
||||
$result = api_sql_query($sql, __FILE__, __LINE__); |
||||
|
||||
if (mysql_num_rows($result) == 0) |
||||
{ |
||||
Display :: display_error_message(get_lang('WrongInvitationCode'), false); |
||||
Display :: display_footer(); |
||||
exit; |
||||
} |
||||
|
||||
|
||||
return $_course; |
||||
} |
||||
|
||||
?> |
||||
Loading…
Reference in new issue