\n" ."\n" ."\t\n" ."\t\n" ."
" .$clang->gT("Export Survey")."
\n" ."
" .$clang->gT("Error")."
\n" .$clang->gT("No SID has been provided. Cannot dump survey")."
\n" ."
\n" ."\t
\n" ."\n"; exit; } function getXMLStructure($xmlwriter, $exclude=array()) { global $dbprefix, $surveyid, $connect; $sdump = ""; if ((!isset($exclude) && $exclude['answers'] !== true) || empty($exclude)) { //Answers table $aquery = "SELECT {$dbprefix}answers.* FROM {$dbprefix}answers, {$dbprefix}questions WHERE {$dbprefix}answers.language={$dbprefix}questions.language AND {$dbprefix}answers.qid={$dbprefix}questions.qid AND {$dbprefix}questions.sid=$surveyid"; BuildXMLFromQuery($xmlwriter,$aquery); } // Assessments $query = "SELECT {$dbprefix}assessments.* FROM {$dbprefix}assessments WHERE {$dbprefix}assessments.sid=$surveyid"; BuildXMLFromQuery($xmlwriter,$query); if ((!isset($exclude) && $exclude['conditions'] !== true) || empty($exclude)) { //Conditions table $cquery = "SELECT DISTINCT {$dbprefix}conditions.* FROM {$dbprefix}conditions, {$dbprefix}questions WHERE {$dbprefix}conditions.qid={$dbprefix}questions.qid AND {$dbprefix}questions.sid=$surveyid"; BuildXMLFromQuery($xmlwriter,$cquery); } //Default values $query = "SELECT {$dbprefix}defaultvalues.* FROM {$dbprefix}defaultvalues JOIN {$dbprefix}questions ON {$dbprefix}questions.qid = {$dbprefix}defaultvalues.qid AND {$dbprefix}questions.sid=$surveyid AND {$dbprefix}questions.language={$dbprefix}defaultvalues.language "; BuildXMLFromQuery($xmlwriter,$query); // Groups $gquery = "SELECT * FROM {$dbprefix}groups WHERE sid=$surveyid ORDER BY gid"; BuildXMLFromQuery($xmlwriter,$gquery); //Questions $qquery = "SELECT * FROM {$dbprefix}questions WHERE sid=$surveyid and parent_qid=0 ORDER BY qid"; BuildXMLFromQuery($xmlwriter,$qquery); //Subquestions $qquery = "SELECT * FROM {$dbprefix}questions WHERE sid=$surveyid and parent_qid>0 ORDER BY qid"; BuildXMLFromQuery($xmlwriter,$qquery,'subquestions'); //Question attributes $sBaseLanguage=GetBaseLanguageFromSurveyID($surveyid); if ($connect->databaseType == 'odbc_mssql' || $connect->databaseType == 'odbtp' || $connect->databaseType == 'mssql_n' || $connect->databaseType =='mssqlnative') { $query="SELECT qa.qid, qa.attribute, cast(qa.value as varchar(4000)) as value FROM {$dbprefix}question_attributes qa JOIN {$dbprefix}questions q ON q.qid = qa.qid AND q.sid={$surveyid} where q.language='{$sBaseLanguage}' group by qa.qid, qa.attribute, cast(qa.value as varchar(4000))"; } else { $query="SELECT qa.qid, qa.attribute, qa.value FROM {$dbprefix}question_attributes qa JOIN {$dbprefix}questions q ON q.qid = qa.qid AND q.sid={$surveyid} where q.language='{$sBaseLanguage}' group by qa.qid, qa.attribute, qa.value"; } BuildXMLFromQuery($xmlwriter,$query,'question_attributes'); if ((!isset($exclude) && $exclude['quotas'] !== true) || empty($exclude)) { //Quota $query = "SELECT {$dbprefix}quota.* FROM {$dbprefix}quota WHERE {$dbprefix}quota.sid=$surveyid"; BuildXMLFromQuery($xmlwriter,$query); //1Quota members $query = "SELECT {$dbprefix}quota_members.* FROM {$dbprefix}quota_members WHERE {$dbprefix}quota_members.sid=$surveyid"; BuildXMLFromQuery($xmlwriter,$query); //Quota languagesettings $query = "SELECT {$dbprefix}quota_languagesettings.* FROM {$dbprefix}quota_languagesettings, {$dbprefix}quota WHERE {$dbprefix}quota.id = {$dbprefix}quota_languagesettings.quotals_quota_id AND {$dbprefix}quota.sid=$surveyid"; BuildXMLFromQuery($xmlwriter,$query); } // Surveys $squery = "SELECT * FROM {$dbprefix}surveys WHERE sid=$surveyid"; //Exclude some fields from the export BuildXMLFromQuery($xmlwriter,$squery,'',array('owner_id','active','datecreated')); // Survey language settings $slsquery = "SELECT * FROM {$dbprefix}surveys_languagesettings WHERE surveyls_survey_id=$surveyid"; BuildXMLFromQuery($xmlwriter,$slsquery); } function getXMLData($exclude = array()) { global $dbversionnumber,$surveyid; $xml = getXMLWriter(); $xml->openMemory(); $xml->setIndent(true); $xml->startDocument('1.0', 'UTF-8'); $xml->startElement('document'); $xml->writeElement('LimeSurveyDocType','Survey'); $xml->writeElement('DBVersion',$dbversionnumber); $xml->startElement('languages'); $surveylanguages=GetAdditionalLanguagesFromSurveyID($surveyid); $surveylanguages[]=GetBaseLanguageFromSurveyID($surveyid); foreach ($surveylanguages as $surveylanguage) { $xml->writeElement('language',$surveylanguage); } $xml->endElement(); getXMLStructure($xml,$exclude); $xml->endElement(); // close columns $xml->endDocument(); return $xml->outputMemory(true); } if (!isset($copyfunction)) { $fn = "limesurvey_survey_$surveyid.lss"; header("Content-Type: text/xml"); header("Content-Disposition: attachment; filename=$fn"); header("Expires: Mon, 26 Jul 1997 05:00:00 GMT"); // Date in the past header("Last-Modified: " . gmdate("D, d M Y H:i:s") . " GMT"); header("Cache-Control: must-revalidate, post-check=0, pre-check=0"); header("Pragma: public"); // HTTP/1.0 echo getXMLData(); exit; } ?>