<?php
/*
 * LimeSurvey
 * Copyright (C) 2007 The LimeSurvey Project Team / Carsten Schmitz
 * All rights reserved.
 * License: GNU/GPL License v2 or later, see LICENSE.php
 * LimeSurvey is free software. This version may have been modified pursuant
 * to the GNU General Public License, and as distributed it includes or
 * is derivative of works licensed under the GNU General Public License or
 * other free or open source software licenses.
 * See COPYRIGHT.php for copyright notices and details.
 *
 * $Id: dumpdb.php 9982 2011-04-10 22:01:16Z c_schmitz $
 */

include_once("login_check.php");  //Login Check dies also if the script is started directly

if ($database_exists && ($databasetype=='mysql' || $databasetype=='mysqli') && $demoModeOnly != true && $action=='dumpdb') {

    $export=completedump();

    $file_name = "LimeSurvey_{$databasename}_dump_".date_shift(date("Y-m-d H:i:s"), "Y-m-d", $timeadjust).".sql";
    Header("Content-type: application/octet-stream");
    Header("Content-Disposition: attachment; filename=$file_name");
    Header("Cache-Control: must-revalidate, post-check=0, pre-check=0");
    echo $export;
    exit; // needs to be inside the condition so the updater still can include this file
}


/**
 * Creates a full dump of the current LimeSurvey database
 *
 * @returns string Contains the dumped data
 */
function completedump()
{
    global $connect, $databasename, $dbprefix, $allowexportalldb;
    $tables = $connect->MetaTables();
    $export ="#------------------------------------------"."\n";
    $export .="# LimeSurvey Database Dump of `$databasename`"."\n";
    if ($allowexportalldb==0) {
        $export .="# Only prefixed tables with: ". $dbprefix ."\n";
    }
    $export .="# Date of Dump: ". date("d-M-Y") ."\n";
    $export .="#------------------------------------------"."\n\n\n";

    foreach($tables as $table) {
        if ($allowexportalldb==0) {
            if ($dbprefix==substr($table, 0, strlen($dbprefix))) {
                $export .= defdump($table);
                $export .= datadump($table);
            }
        }
        else {
            $export .= defdump($table);
            $export .= datadump($table);
        }
    }
    return $export;
}



function defdump($tablename)
{
    global $connect;
    $def = "";
    $def .="#\n";
    $def .="# Table definition for {$tablename}"."\n";
    $def .="#\n";
    $def .= "DROP TABLE IF EXISTS {$tablename};"."\n"."\n";
    $def .= "CREATE TABLE {$tablename} ("."\n";
    $result = db_execute_assoc("SHOW COLUMNS FROM {$tablename}") or die("Table $tablename not existing in database");
    while($row = $result->FetchRow())
    {
        $def .= "    `$row[Field]` $row[Type]";
        if (!is_null($row["Default"])) $def .= " DEFAULT '$row[Default]'";
        if ($row["Null"] != "YES") $def .= " NOT NULL";
        if ($row["Extra"] != "") $def .= " $row[Extra]";
        $def .= ",\n";
    }
    $def = preg_replace("#,\n$#","", $def);

    $result = db_execute_assoc("SHOW KEYS FROM $tablename");
    while($row = $result->FetchRow())
    {
        $kname=$row["Key_name"];
        if(($kname != "PRIMARY") && ($row["Non_unique"] == 0)) $kname="UNIQUE|$kname";
        if(!isset($index[$kname])) $index[$kname] = array();
        if ($row["Sub_part"]!='')  $row["Column_name"].=" ({$row["Sub_part"]})";
        $index[$kname][] = $row["Column_name"];
    }

    while(list($x, $columns) = @each($index))
    {
        $def .= ",\n";
        if($x == "PRIMARY") $def .= "   PRIMARY KEY (" . implode($columns, ", ") . ")";
        else if (substr($x,0,6) == "UNIQUE") $def .= "   UNIQUE ".substr($x,7)." (" . implode($columns, ", ") . ")";
        else $def .= "   KEY $x (" . implode($columns, ", ") . ")";
    }
    $def .= "\n);\n\n\n";
    return (stripslashes($def));
}


function datadump ($table) {

    global $connect;

    $result = "#\n";
    $result .="# Table data for $table"."\n";
    $result .="#\n";

    $query = db_execute_num("select * from $table");
    $num_fields = $query->FieldCount();
    $aFieldNames= $connect->MetaColumnNames($table, true);
    $sFieldNames= implode('`,`',$aFieldNames);
    $numrow = $query->RecordCount();

    if ($numrow>0)
    {
        $result .= "INSERT INTO `{$table}` (`{$sFieldNames}`) VALUES";
    while($row=$query->FetchRow()){
        @set_time_limit(5);
            $result .= "(";
        for($j=0; $j<$num_fields; $j++) {
            if (isset($row[$j]) && !is_null($row[$j]))
            {
                $row[$j] = addslashes($row[$j]);
                $row[$j] = preg_replace("#\n#","\\n",$row[$j]);
                $result .= "\"$row[$j]\"";
            }
            else
            {
                $result .= "NULL";
            }

            if ($j<($num_fields-1)) $result .= ",";
        }
            $result .= "),\n";
    } // while
        $result=substr($result,0,-2);
}
    return $result . ";\n\n";
}

?>
