|
|
<?php
|
|
|
/*
|
|
|
==============================================================================
|
|
|
Dokeos - elearning and course management software
|
|
|
|
|
|
Copyright (c) 2004-2008 Dokeos SPRL
|
|
|
Copyright (c) 2003 Ghent University (UGent)
|
|
|
Copyright (c) 2001 Universite catholique de Louvain (UCL)
|
|
|
Copyright (c) Olivier Brouckaert
|
|
|
Copyright (c) Bart Mollet, Hogeschool Gent
|
|
|
|
|
|
For a full list of contributors, see "credits.txt".
|
|
|
The full license can be read in "license.txt".
|
|
|
|
|
|
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 the GNU General Public License for more details.
|
|
|
|
|
|
Contact address: Dokeos, rue du Corbeau, 108, B-1030 Brussels, Belgium, info@dokeos.com
|
|
|
==============================================================================
|
|
|
*/
|
|
|
|
|
|
/**
|
|
|
==============================================================================
|
|
|
* This is the export library for Dokeos.
|
|
|
* Include/require it in your code to use its functionality.
|
|
|
*
|
|
|
* Several functions below are adaptations from functions distributed by www.nexen.net
|
|
|
*
|
|
|
* @package dokeos.library
|
|
|
==============================================================================
|
|
|
*/
|
|
|
|
|
|
require_once 'document.lib.php';
|
|
|
|
|
|
class Export {
|
|
|
|
|
|
private function __construct() {
|
|
|
|
|
|
}
|
|
|
|
|
|
/**
|
|
|
* Export tabular data to CSV-file
|
|
|
* @param array $data
|
|
|
* @param string $filename
|
|
|
*/
|
|
|
public static function export_table_csv ($data, $filename = 'export') {
|
|
|
$file = api_get_path(SYS_ARCHIVE_PATH).uniqid('').'.csv';
|
|
|
$handle = @fopen($file, 'a+');
|
|
|
|
|
|
if(is_array($data)) {
|
|
|
foreach ($data as $index => $row) {
|
|
|
$line = '';
|
|
|
if(is_array($row)) {
|
|
|
foreach($row as $value) {
|
|
|
$line .= '"'.str_replace('"', '""', $value).'";';
|
|
|
}
|
|
|
}
|
|
|
@fwrite($handle, $line."\n");
|
|
|
}
|
|
|
}
|
|
|
@fclose($handle);
|
|
|
DocumentManager :: file_send_for_download($file, true, $filename.'.csv');
|
|
|
return false;
|
|
|
}
|
|
|
|
|
|
/**
|
|
|
* Export tabular data to XLS-file
|
|
|
* @param array $data
|
|
|
* @param string $filename
|
|
|
*/
|
|
|
public static function export_table_xls ($data, $filename = 'export') {
|
|
|
$file = api_get_path(SYS_ARCHIVE_PATH).uniqid('').'.xls';
|
|
|
$handle = @fopen($file, 'a+');
|
|
|
foreach ($data as $index => $row) {
|
|
|
@fwrite($handle, implode("\t", $row)."\n");
|
|
|
}
|
|
|
@fclose($handle);
|
|
|
DocumentManager :: file_send_for_download($file, true, $filename.'.xls');
|
|
|
return false;
|
|
|
}
|
|
|
|
|
|
/**
|
|
|
* Export tabular data to XML-file
|
|
|
* @param array Simple array of data to put in XML
|
|
|
* @param string Name of file to be given to the user
|
|
|
* @param string Name of common tag to place each line in
|
|
|
* @param string Name of the root element. A root element should always be given.
|
|
|
* @param string Encoding in which the data is provided
|
|
|
*/
|
|
|
public static function export_table_xml ($data, $filename = 'export', $item_tagname = 'item', $wrapper_tagname = null, $encoding = null) {
|
|
|
if (empty($encoding)) {
|
|
|
$encoding = api_get_system_encoding();
|
|
|
}
|
|
|
$file = api_get_path(SYS_ARCHIVE_PATH).'/'.uniqid('').'.xml';
|
|
|
$handle = fopen($file, 'a+');
|
|
|
fwrite($handle, '<?xml version="1.0" encoding="'.$encoding.'"?>'."\n");
|
|
|
if (!is_null($wrapper_tagname)) {
|
|
|
fwrite($handle, "\t".'<'.$wrapper_tagname.'>'."\n");
|
|
|
}
|
|
|
foreach ($data as $index => $row) {
|
|
|
fwrite($handle, '<'.$item_tagname.'>'."\n");
|
|
|
foreach ($row as $key => $value) {
|
|
|
fwrite($handle, "\t\t".'<'.$key.'>'.$value.'</'.$key.'>'."\n");
|
|
|
}
|
|
|
fwrite($handle, "\t".'</'.$item_tagname.'>'."\n");
|
|
|
}
|
|
|
if (!is_null($wrapper_tagname)) {
|
|
|
fwrite($handle, '</'.$wrapper_tagname.'>'."\n");
|
|
|
}
|
|
|
fclose($handle);
|
|
|
DocumentManager :: file_send_for_download($file, true, $filename.'.xml');
|
|
|
return false;
|
|
|
}
|
|
|
|
|
|
/**
|
|
|
* Export hierarchical tabular data to XML-file
|
|
|
* @param array Hierarchical array of data to put in XML, each element presenting a 'name' and a 'value' property
|
|
|
* @param string Name of file to be given to the user
|
|
|
* @param string Name of common tag to place each line in
|
|
|
* @param string Name of the root element. A root element should always be given.
|
|
|
* @param string Encoding in which the data is provided
|
|
|
* @return void Prompts the user for a file download
|
|
|
*/
|
|
|
public static function export_complex_table_xml ($data, $filename = 'export', $wrapper_tagname, $encoding = 'ISO-8859-1') {
|
|
|
$file = api_get_path(SYS_ARCHIVE_PATH).'/'.uniqid('').'.xml';
|
|
|
$handle = fopen($file, 'a+');
|
|
|
fwrite($handle, '<?xml version="1.0" encoding="'.$encoding.'"?>'."\n");
|
|
|
|
|
|
if (!is_null($wrapper_tagname)) {
|
|
|
fwrite($handle, '<'.$wrapper_tagname.'>');
|
|
|
}
|
|
|
$s = self::_export_complex_table_xml_helper($data);
|
|
|
fwrite($handle,$s);
|
|
|
if (!is_null($wrapper_tagname)) {
|
|
|
fwrite($handle, '</'.$wrapper_tagname.'>'."\n");
|
|
|
}
|
|
|
fclose($handle);
|
|
|
DocumentManager :: file_send_for_download($file, true, $filename.'.xml');
|
|
|
return false;
|
|
|
}
|
|
|
|
|
|
/**
|
|
|
* Helper for the hierarchical XML exporter
|
|
|
* @param array Hierarhical array composed of elements of type ('name'=>'xyz','value'=>'...')
|
|
|
* @param int Level of recursivity. Allows the XML to be finely presented
|
|
|
* @return string The XML string to be inserted into the root element
|
|
|
*/
|
|
|
public static function _export_complex_table_xml_helper ($data, $level = 1) {
|
|
|
if (count($data)<1) { return '';}
|
|
|
$string = '';
|
|
|
foreach ($data as $index => $row) {
|
|
|
$string .= "\n".str_repeat("\t",$level).'<'.$row['name'].'>';
|
|
|
if (is_array($row['value'])) {
|
|
|
$string .= self::_export_complex_table_xml_helper($row['value'],$level+1)."\n";
|
|
|
$string .= str_repeat("\t",$level).'</'.$row['name'].'>';
|
|
|
} else {
|
|
|
$string .= $row['value'];
|
|
|
$string .= '</'.$row['name'].'>';
|
|
|
}
|
|
|
}
|
|
|
return $string;
|
|
|
}
|
|
|
|
|
|
}
|
|
|
|
|
|
/*
|
|
|
==============================================================================
|
|
|
FUNCTIONS
|
|
|
==============================================================================
|
|
|
*/
|
|
|
|
|
|
/**
|
|
|
* Backup a db to a file
|
|
|
*
|
|
|
* @param ressource $link lien vers la base de donnees
|
|
|
* @param string $db_name nom de la base de donnees
|
|
|
* @param boolean $structure true => sauvegarde de la structure des tables
|
|
|
* @param boolean $donnees true => sauvegarde des donnes des tables
|
|
|
* @param boolean $format format des donnees
|
|
|
'INSERT' => des clauses SQL INSERT
|
|
|
'CSV' => donnees separees par des virgules
|
|
|
* @param boolean $insertComplet true => clause INSERT avec nom des champs
|
|
|
* @param boolean $verbose true => comment are printed
|
|
|
* @deprecated Function only used in deprecated function makeTheBackup(...)
|
|
|
*/
|
|
|
function backupDatabase($link, $db_name, $structure, $donnees, $format = 'SQL', $whereSave = '.', $insertComplet = '', $verbose = false) {
|
|
|
$errorCode = '';
|
|
|
if (!is_resource($link)) {
|
|
|
global $error_msg, $error_no;
|
|
|
$error_msg['backup'][] = '['.basename(__FILE__).']['.__LINE__.'] link is not a ressource';
|
|
|
$error_no['backup'][] = '1';
|
|
|
return false;
|
|
|
}
|
|
|
mysql_select_db($db_name);
|
|
|
$format = strtolower($format);
|
|
|
$filename = $whereSave.'/courseDbContent.'.$format;
|
|
|
$format = strtoupper($format);
|
|
|
$fp = fopen($filename, 'w');
|
|
|
if (!is_resource($fp)) {
|
|
|
return false;
|
|
|
}
|
|
|
// liste des tables
|
|
|
$res = mysql_list_tables($db_name, $link);
|
|
|
$num_rows = Database::num_rows($res);
|
|
|
$i = 0;
|
|
|
while ($i < $num_rows) {
|
|
|
$tablename = mysql_tablename($res, $i);
|
|
|
|
|
|
if ($format == 'PHP') {
|
|
|
fwrite($fp, "\nmysql_query(\"");
|
|
|
}
|
|
|
if ($format == 'HTML') {
|
|
|
fwrite($fp, "\n<h2>$tablename</h2><table border=\"1\" width=\"100%\">");
|
|
|
}
|
|
|
if ($verbose) {
|
|
|
echo '['.$tablename.'] ';
|
|
|
}
|
|
|
if ($structure === true) {
|
|
|
if ($format == 'PHP' || $format == 'SQL') {
|
|
|
fwrite($fp, "DROP TABLE IF EXISTS `$tablename`;");
|
|
|
}
|
|
|
if ($format == 'PHP') {
|
|
|
fwrite($fp, "\");\n");
|
|
|
}
|
|
|
if ($format == 'PHP') {
|
|
|
fwrite($fp, "\nmysql_query(\"");
|
|
|
}
|
|
|
// requete de creation de la table
|
|
|
$query = "SHOW CREATE TABLE `".$tablename."`";
|
|
|
$resCreate = Database::query($query,__FILE__, __LINE__);
|
|
|
$row = Database::fetch_array($resCreate);
|
|
|
$schema = $row[1].';';
|
|
|
if ($format == 'PHP' || $format == 'SQL') {
|
|
|
fwrite($fp, "$schema");
|
|
|
}
|
|
|
if ($format == 'PHP') {
|
|
|
fwrite($fp, "\");\n\n");
|
|
|
}
|
|
|
}
|
|
|
if ($donnees === true) {
|
|
|
// les donn<EFBFBD>es de la table
|
|
|
$query = "SELECT * FROM $tablename";
|
|
|
$resData = Database::query($query,__FILE__, __LINE__);
|
|
|
if (Database::num_rows($resData) > 0) {
|
|
|
$sFieldnames = '';
|
|
|
if ($insertComplet === true) {
|
|
|
$num_fields = mysql_num_fields($resData);
|
|
|
for ($j = 0; $j < $num_fields; $j ++) {
|
|
|
$sFieldnames .= "`".mysql_field_name($resData, $j)."`, ";
|
|
|
}
|
|
|
$sFieldnames = '('.substr($sFieldnames, 0, -2).')';
|
|
|
}
|
|
|
$sInsert = "INSERT INTO `$tablename` $sFieldnames values ";
|
|
|
while ($rowdata = Database::fetch_array($resData, 'ASSOC')) {
|
|
|
if ($format == 'HTML') {
|
|
|
$lesDonnees = "\n\t<tr>\n\t\t<td>".implode("\n\t\t</td>\n\t\t<td>", $rowdata)."\n\t\t</td></tr>";
|
|
|
}
|
|
|
if ($format == 'SQL' || $format == 'PHP') {
|
|
|
$lesDonnees = '<guillemet>'.implode('<guillemet>,<guillemet>', $rowdata).'<guillemet>';
|
|
|
$lesDonnees = str_replace('<guillemet>', "'", addslashes($lesDonnees));
|
|
|
if ($format == 'SQL') {
|
|
|
$lesDonnees = $sInsert.' ( '.$lesDonnees.' );';
|
|
|
}
|
|
|
if ($format == 'PHP') {
|
|
|
fwrite($fp, "\nmysql_query(\"");
|
|
|
}
|
|
|
}
|
|
|
fwrite($fp, "$lesDonnees");
|
|
|
if ($format == 'PHP') {
|
|
|
fwrite($fp, "\");\n");
|
|
|
}
|
|
|
}
|
|
|
}
|
|
|
}
|
|
|
$i ++;
|
|
|
if ($format == 'HTML') {
|
|
|
fwrite($fp, "\n</table>\n<hr />\n");
|
|
|
}
|
|
|
}
|
|
|
echo 'fin du backup au format :'.$format;
|
|
|
fclose($fp);
|
|
|
}
|
|
|
|
|
|
/**
|
|
|
* @deprecated use function copyDirTo($origDirPath, $destination) in
|
|
|
* fileManagerLib.inc.php
|
|
|
*/
|
|
|
function copydir($origine, $destination, $verbose = false) {
|
|
|
$dossier = @ opendir($origine) or die('<hr />impossible d\'ouvrir '.$origine.' ['.__LINE__.']');
|
|
|
if ($verbose) {
|
|
|
echo "<br /> $origine -> $destination";
|
|
|
}
|
|
|
/*
|
|
|
if (file_exists($destination)) {
|
|
|
echo "la cible existe, ca ne va pas <EFBFBD>tre possible";
|
|
|
return 0;
|
|
|
}
|
|
|
*/
|
|
|
mkpath($destination, 0770);
|
|
|
if ($verbose) {
|
|
|
echo "
|
|
|
<strong>
|
|
|
[".basename($destination)."]
|
|
|
</strong>
|
|
|
<ol>";
|
|
|
}
|
|
|
$total = 0;
|
|
|
while ($fichier = readdir($dossier)) {
|
|
|
$l = array ('.', '..');
|
|
|
if (!in_array($fichier, $l)) {
|
|
|
if (is_dir($origine.'/'.$fichier)) {
|
|
|
if ($verbose) {
|
|
|
echo "
|
|
|
<li>";
|
|
|
}
|
|
|
$total += copydir("$origine/$fichier", "$destination/$fichier", $verbose);
|
|
|
} else {
|
|
|
copy("$origine/$fichier", "$destination/$fichier");
|
|
|
if ($verbose) {
|
|
|
echo "
|
|
|
<li>
|
|
|
$fichier";
|
|
|
}
|
|
|
$total ++;
|
|
|
}
|
|
|
if ($verbose) {
|
|
|
echo "
|
|
|
</li>";
|
|
|
}
|
|
|
}
|
|
|
}
|
|
|
if ($verbose) {
|
|
|
echo "
|
|
|
</ol>";
|
|
|
}
|
|
|
return $total;
|
|
|
}
|
|
|
|
|
|
/**
|
|
|
* Export a course to a zip file
|
|
|
*
|
|
|
* @param integer $currentCourseID needed sysId Of course to be exported
|
|
|
* @param boolean $verbose_backup def FALSE echo step of work
|
|
|
* @param string $ignore def NONE // future param for selected bloc to export.
|
|
|
* @param string $formats def ALL ALL,SQL,PHP,XML,CSV,XLS,HTML
|
|
|
*
|
|
|
* @deprecated Function not in use (old backup system)
|
|
|
*
|
|
|
* 1. Check if all data needed are aivailable
|
|
|
* 2. Build the archive repository tree
|
|
|
* 3. Build exported element and Fill the archive repository tree
|
|
|
* 4. Compress the tree
|
|
|
== tree structure == == here we can found ==
|
|
|
/archivePath/ temporary files of export for the current claroline
|
|
|
/$exportedCourseId temporary files of export for the current course
|
|
|
/$dateBackuping/ root of the future archive
|
|
|
archive.ini course properties
|
|
|
readme.txt
|
|
|
/originalDocs
|
|
|
/html
|
|
|
/sql
|
|
|
/csv
|
|
|
/xml
|
|
|
/php
|
|
|
;
|
|
|
|
|
|
about "ignore"
|
|
|
As we don't know what is add in course by the local admin of claroline,
|
|
|
I prefer follow the logic : save all except ...
|
|
|
|
|
|
|
|
|
*/
|
|
|
function makeTheBackup($exportedCourseId, $verbose_backup = FALSE, $ignore = '', $formats = 'ALL') {
|
|
|
global $error_msg, $error_no, $db, $archiveRepositorySys, $archiveRepositoryWeb,
|
|
|
$appendCourse, $appendMainDb, $archiveName, $_configuration, $_course, $TABLEUSER, $TABLECOURSUSER, $TABLECOURS, $TABLEANNOUNCEMENT;
|
|
|
|
|
|
// ****** 1.2. params.
|
|
|
$errorCode = 0;
|
|
|
$stop = FALSE;
|
|
|
|
|
|
// ****** 1.2.1. params.needed
|
|
|
if (!isset ($exportedCourseId)) {
|
|
|
$error_msg['backup'][] = '['.basename(__FILE__).']['.__LINE__.'] Course Id Missing';
|
|
|
$error_no['backup'][] = '1';
|
|
|
$stop = TRUE;
|
|
|
}
|
|
|
if (!isset ($_configuration['main_database'])) {
|
|
|
$error_msg['backup'][] = '['.basename(__FILE__).']['.__LINE__.'] Main Db name is Missing';
|
|
|
$error_no['backup'][] = '2';
|
|
|
$stop = TRUE;
|
|
|
}
|
|
|
if (!isset ($archiveRepositorySys)) {
|
|
|
$error_msg['backup'][] = '['.basename(__FILE__).']['.__LINE__.'] archive Path not found';
|
|
|
$error_no['backup'][] = '3';
|
|
|
$stop = TRUE;
|
|
|
}
|
|
|
if (!isset ($appendMainDb)) {
|
|
|
$error_msg['backup'][] = '['.basename(__FILE__).']['.__LINE__.'] where place course datas from main db in archive';
|
|
|
$error_no['backup'][] = '4';
|
|
|
$stop = TRUE;
|
|
|
}
|
|
|
if (!isset ($appendCourse)) {
|
|
|
$error_msg['backup'][] = '['.basename(__FILE__).']['.__LINE__.'] where place course datas in archive';
|
|
|
$error_no['backup'][] = '5';
|
|
|
$stop = TRUE;
|
|
|
}
|
|
|
if (!isset ($TABLECOURS)) {
|
|
|
$error_msg['backup'][] = '['.basename(__FILE__).']['.__LINE__.'] name of table of course not defined';
|
|
|
$error_no['backup'][] = '6';
|
|
|
$stop = TRUE;
|
|
|
}
|
|
|
if (!isset ($TABLEUSER)) {
|
|
|
$error_msg['backup'][] = '['.basename(__FILE__).']['.__LINE__.'] name of table of users not defined';
|
|
|
$error_no['backup'][] = '7';
|
|
|
$stop = TRUE;
|
|
|
}
|
|
|
if (!isset ($TABLECOURSUSER)) {
|
|
|
$error_msg['backup'][] = '['.basename(__FILE__).']['.__LINE__.'] name of table of subscription of users in courses not defined';
|
|
|
$error_no['backup'][] = '8';
|
|
|
$stop = TRUE;
|
|
|
}
|
|
|
if ($stop) {
|
|
|
return false;
|
|
|
}
|
|
|
|
|
|
// ****** 1.2.2. params.optional
|
|
|
if (!isset ($verbose_backup)) {
|
|
|
$verbose_backup = false;
|
|
|
}
|
|
|
|
|
|
// ****** 1.3. check if course exist
|
|
|
// not done
|
|
|
//////////////////////////////////////////////
|
|
|
// ****** 2. Build the archive repository tree
|
|
|
// ****** 2.1. fix names
|
|
|
$shortDateBackuping = date('YzBs'); // YEAR - Day in Year - Swatch - second
|
|
|
$archiveFileName = 'archive.'.$exportedCourseId.'.'.$shortDateBackuping.'.zip';
|
|
|
$dateBackuping = $shortDateBackuping;
|
|
|
$archiveDir .= $archiveRepositorySys.$exportedCourseId.'/'.$shortDateBackuping.'/';
|
|
|
$archiveDirOriginalDocs = $archiveDir.'originalDocs/';
|
|
|
$archiveDirHtml = $archiveDir.'HTML/';
|
|
|
$archiveDirCsv = $archiveDir.'CSV/';
|
|
|
$archiveDirXml = $archiveDir.'XML/';
|
|
|
$archiveDirPhp = $archiveDir.'PHP/';
|
|
|
$archiveDirLog = $archiveDir.'LOG/';
|
|
|
$archiveDirSql = $archiveDir.'SQL/';
|
|
|
$systemFileNameOfArchive = 'claroBak-'.$exportedCourseId.'-'.$dateBackuping.'.txt';
|
|
|
$systemFileNameOfArchiveIni = 'archive.ini';
|
|
|
$systemFileNameOfReadMe = 'readme.txt';
|
|
|
$systemFileNameOfarchiveLog = 'readme.txt';
|
|
|
###################
|
|
|
if ($verbose_backup) {
|
|
|
echo '<hr /><u>', get_lang('ArchiveName'), '</u> : ', '<strong>', basename($systemFileNameOfArchive), '</strong><br /><u>', get_lang('ArchiveLocation'), '</u> : ', '<strong>', realpath($systemFileNameOfArchive), '</strong><br /><u>', get_lang('SizeOf'), ' ', realpath('../../'.$exportedCourseId.'/'), '</u> : ', '<strong>', DirSize('../../'.$exportedCourseId.'/'), '</strong> bytes <br />';
|
|
|
if (function_exists(diskfreespace))
|
|
|
echo '<u>'.get_lang('DiskFreeSpace').'</u> : <strong>'.diskfreespace('/').'</strong> bytes';
|
|
|
echo '<hr />';
|
|
|
}
|
|
|
mkpath($archiveDirOriginalDocs.$appendMainDb, $verbose_backup);
|
|
|
mkpath($archiveDirHtml.$appendMainDb, $verbose_backup);
|
|
|
mkpath($archiveDirCsv.$appendMainDb, $verbose_backup);
|
|
|
mkpath($archiveDirXml.$appendMainDb, $verbose_backup);
|
|
|
mkpath($archiveDirPhp.$appendMainDb, $verbose_backup);
|
|
|
mkpath($archiveDirLog.$appendMainDb, $verbose_backup);
|
|
|
mkpath($archiveDirSql.$appendMainDb, $verbose_backup);
|
|
|
mkpath($archiveDirOriginalDocs.$appendCourse, $verbose_backup);
|
|
|
mkpath($archiveDirHtml.$appendCourse, $verbose_backup);
|
|
|
mkpath($archiveDirCsv.$appendCourse, $verbose_backup);
|
|
|
mkpath($archiveDirXml.$appendCourse, $verbose_backup);
|
|
|
mkpath($archiveDirPhp.$appendCourse, $verbose_backup);
|
|
|
mkpath($archiveDirLog.$appendCourse, $verbose_backup);
|
|
|
mkpath($archiveDirSql.$appendCourse, $verbose_backup);
|
|
|
$dirCourBase = $archiveDirSqlCourse;
|
|
|
$dirMainBase = $archiveDirSqlMainDb;
|
|
|
/////////////////////////////////////////////////////////////////////////
|
|
|
// ****** 3. Build exported element and Fill the archive repository tree
|
|
|
if ($verbose_backup) {
|
|
|
echo "
|
|
|
build config file
|
|
|
<hr />";
|
|
|
}
|
|
|
// ********************************************************************
|
|
|
// build config file
|
|
|
// ********************************************************************
|
|
|
$stringConfig = "<?php
|
|
|
/*
|
|
|
+----------------------------------------------------------------------+
|
|
|
Dokeos version ".$dokeos_version."
|
|
|
+----------------------------------------------------------------------+
|
|
|
This file was generate by script ".api_get_self()."
|
|
|
".date("r")." |
|
|
|
+----------------------------------------------------------------------+
|
|
|
| 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 |
|
|
|
*/
|
|
|
|
|
|
// Dokeos Version was : ".$dokeos_version."
|
|
|
// Source was in ".realpath("../../".$exportedCourseId."/")."
|
|
|
// find in ".$archiveDir."/courseBase/courseBase.sql sql to rebuild the course base
|
|
|
// find in ".$archiveDir."/".$exportedCourseId." to content of directory of course
|
|
|
|
|
|
/**
|
|
|
* options
|
|
|
";
|
|
|
$stringConfig .= "
|
|
|
*/";
|
|
|
// ********************************************************************
|
|
|
// Copy of from DB main
|
|
|
// fields about this course
|
|
|
// ********************************************************************
|
|
|
// info about cours
|
|
|
// ********************************************************************
|
|
|
if ($verbose_backup)
|
|
|
echo "
|
|
|
<li>
|
|
|
".get_lang('BUCourseDataOfMainBase')." ".$exportedCourseId."
|
|
|
<hr />
|
|
|
<pre>";
|
|
|
$sqlInsertCourse = "
|
|
|
INSERT INTO course SET ";
|
|
|
$csvInsertCourse = "\n";
|
|
|
$iniCourse = "[".$exportedCourseId."]\n";
|
|
|
$sqlSelectInfoCourse = "Select * from `".$TABLECOURS."` `course` where code = '".$exportedCourseId."' ";
|
|
|
$resInfoCourse = Database::query($sqlSelectInfoCourse, __FILE__, __LINE__);
|
|
|
$infoCourse = Database::fetch_array($resInfoCourse);
|
|
|
for ($noField = 0; $noField < mysql_num_fields($resInfoCourse); $noField ++) {
|
|
|
if ($noField > 0) {
|
|
|
$sqlInsertCourse .= ", ";
|
|
|
}
|
|
|
$nameField = mysql_field_name($resInfoCourse, $noField);
|
|
|
/*echo "
|
|
|
<br />
|
|
|
$nameField -> ".$infoCourse["$nameField"]." ";
|
|
|
*/
|
|
|
$sqlInsertCourse .= "$nameField = '".$infoCourse["$nameField"]."'";
|
|
|
$csvInsertCourse .= "'".addslashes($infoCourse["$nameField"])."';";
|
|
|
}
|
|
|
// buildTheIniFile
|
|
|
$iniCourse .= "name=".strtr($infoCourse['title'], "()", "[]")."\n"."official_code=".strtr($infoCourse['visual_code'], "()", "[]")."\n".// use in echo
|
|
|
"adminCode=".strtr($infoCourse['code'], "()", "[]")."\n".// use as key in db
|
|
|
"path=".strtr($infoCourse['code'], "()", "[]")."\n".// use as key in path
|
|
|
"dbName=".strtr($infoCourse['code'], "()", "[]")."\n".// use as key in db list
|
|
|
"titular=".strtr($infoCourse['titulaire'], "()", "[]")."\n"."language=".strtr($infoCourse['language'], "()", "[]")."\n"."extLinkUrl=".strtr($infoCourse['departementUrl'], "()", "[]")."\n"."extLinkName=".strtr($infoCourse['departementName'], "()", "[]")."\n"."categoryCode=".strtr($infoCourse['faCode'], "()", "[]")."\n"."categoryName=".strtr($infoCourse['faName'], "()", "[]")."\n"."visibility=". ($infoCourse['visibility'] == 2 || $infoCourse['visibility'] == 3)."registrationAllowed=". ($infoCourse['visibility'] == 1 || $infoCourse['visibility'] == 2);
|
|
|
$sqlInsertCourse .= ";";
|
|
|
// echo $csvInsertCourse."<br />";
|
|
|
$stringConfig .= "
|
|
|
# Insert Course
|
|
|
#------------------------
|
|
|
# ".$sqlInsertCourse."
|
|
|
#------------------------
|
|
|
";
|
|
|
if ($verbose_backup) {
|
|
|
echo "</pre>";
|
|
|
}
|
|
|
$fcoursql = fopen($archiveDirSql.$appendMainDb.'course.sql', 'w');
|
|
|
fwrite($fcoursql, $sqlInsertCourse);
|
|
|
fclose($fcoursql);
|
|
|
$fcourcsv = fopen($archiveDirCsv.$appendMainDb.'course.csv', 'w');
|
|
|
fwrite($fcourcsv, $csvInsertCourse);
|
|
|
fclose($fcourcsv);
|
|
|
$fcourini = fopen($archiveDir.$systemFileNameOfArchiveIni, 'w');
|
|
|
fwrite($fcourini, $iniCourse);
|
|
|
fclose($fcourini);
|
|
|
echo $iniCourse, ' ini Course';
|
|
|
// ********************************************************************
|
|
|
// info about users
|
|
|
// ********************************************************************
|
|
|
// if ($backupUser ) {
|
|
|
|
|
|
if ($verbose_backup) {
|
|
|
echo "
|
|
|
<li>
|
|
|
".get_lang('BUUsersInMainBase')." ".$exportedCourseId."
|
|
|
<hr />
|
|
|
<pre>";
|
|
|
}
|
|
|
// recup users
|
|
|
$sqlUserOfTheCourse = "
|
|
|
SELECT
|
|
|
`user`.*
|
|
|
FROM `".$TABLEUSER."`, `".$TABLECOURSUSER."`
|
|
|
WHERE `user`.`user_id`=`".$TABLECOURSUSER."`.`user_id`
|
|
|
AND `".$TABLECOURSUSER."`.`course_code`='".$exportedCourseId."'";
|
|
|
$resUsers = Database::query($sqlUserOfTheCourse, __FILE__, __LINE__);
|
|
|
$nbUsers = Database::num_rows($resUsers);
|
|
|
if ($nbUsers > 0) {
|
|
|
$nbFields = mysql_num_fields($resUsers);
|
|
|
$sqlInsertUsers = '';
|
|
|
$csvInsertUsers = '';
|
|
|
$htmlInsertUsers = "<table>\t<tr>\n";
|
|
|
//
|
|
|
// creation of headers
|
|
|
//
|
|
|
for ($noField = 0; $noField < $nbFields; $noField ++) {
|
|
|
$nameField = mysql_field_name($resUsers, $noField);
|
|
|
$csvInsertUsers .= "'".addslashes($nameField)."';";
|
|
|
$htmlInsertUsers .= "\t\t<th>".$nameField."</th>\n";
|
|
|
}
|
|
|
$htmlInsertUsers .= "\t</tr>\n";
|
|
|
//
|
|
|
// creation of body
|
|
|
//
|
|
|
while ($users = Database::fetch_array($resUsers)) {
|
|
|
$htmlInsertUsers .= "\t<tr>\n";
|
|
|
$sqlInsertUsers .= "
|
|
|
INSERT IGNORE INTO user SET ";
|
|
|
$csvInsertUsers .= "\n";
|
|
|
for ($noField = 0; $noField < $nbFields; $noField ++) {
|
|
|
if ($noField > 0) {
|
|
|
$sqlInsertUsers .= ", ";
|
|
|
}
|
|
|
$nameField = mysql_field_name($resUsers, $noField);
|
|
|
/*echo "
|
|
|
<br />
|
|
|
$nameField -> ".$users["$nameField"]." ";
|
|
|
*/
|
|
|
$sqlInsertUsers .= "$nameField = '".$users["$nameField"]."' ";
|
|
|
$csvInsertUsers .= "'".addslashes($users["$nameField"])."';";
|
|
|
$htmlInsertUsers .= "\t\t<td>".$users["$nameField"]."</td>\n";
|
|
|
}
|
|
|
$sqlInsertUsers .= ";";
|
|
|
$htmlInsertUsers .= "\t</tr>\n";
|
|
|
}
|
|
|
$htmlInsertUsers .= "</TABLE>\n";
|
|
|
$stringConfig .= "
|
|
|
# INSERT Users
|
|
|
#------------------------------------------
|
|
|
# ".$sqlInsertUsers."
|
|
|
#------------------------------------------
|
|
|
";
|
|
|
$fuserssql = fopen($archiveDirSql.$appendMainDb.'users.sql', 'w');
|
|
|
fwrite($fuserssql, $sqlInsertUsers);
|
|
|
fclose($fuserssql);
|
|
|
$fuserscsv = fopen($archiveDirCsv.$appendMainDb.'users.csv', 'w');
|
|
|
fwrite($fuserscsv, $csvInsertUsers);
|
|
|
fclose($fuserscsv);
|
|
|
$fusershtml = fopen($archiveDirHtml.$appendMainDb.'users.html', 'w');
|
|
|
fwrite($fusershtml, $htmlInsertUsers);
|
|
|
fclose($fusershtml);
|
|
|
} else {
|
|
|
if ($verbose_backup) {
|
|
|
echo "<hr /><div align=\"center\">NO user in this course !!!!</div><hr />";
|
|
|
}
|
|
|
}
|
|
|
if ($verbose_backup) {
|
|
|
echo "</pre>";
|
|
|
}
|
|
|
|
|
|
//}
|
|
|
|
|
|
/* End of backup user */
|
|
|
if ($saveAnnouncement) {
|
|
|
// ********************************************************************
|
|
|
// info about announcment
|
|
|
// ********************************************************************
|
|
|
if ($verbose_backup) {
|
|
|
echo "
|
|
|
<li>
|
|
|
".get_lang('BUAnnounceInMainBase')." ".$exportedCourseId."
|
|
|
<hr />
|
|
|
<pre>";
|
|
|
}
|
|
|
// recup annonce
|
|
|
$sqlAnnounceOfTheCourse = "
|
|
|
SELECT
|
|
|
*
|
|
|
FROM `".$TABLEANNOUNCEMENT."`
|
|
|
WHERE course_code='".$exportedCourseId."'";
|
|
|
$resAnn = Database::query($sqlAnnounceOfTheCourse, __FILE__, __LINE__);
|
|
|
$nbFields = mysql_num_fields($resAnn);
|
|
|
$sqlInsertAnn = '';
|
|
|
$csvInsertAnn = '';
|
|
|
$htmlInsertAnn .= "<table>\t<tr>\n";
|
|
|
//
|
|
|
// creation of headers
|
|
|
//
|
|
|
for ($noField = 0; $noField < $nbFields; $noField ++) {
|
|
|
$nameField = mysql_field_name($resUsers, $noField);
|
|
|
$csvInsertAnn .= "'".addslashes($nameField)."';";
|
|
|
$htmlInsertAnn .= "\t\t<th>".$nameField."</th>\n";
|
|
|
}
|
|
|
$htmlInsertAnn .= "\t</tr>\n";
|
|
|
//
|
|
|
// creation of body
|
|
|
//
|
|
|
while ($announce = Database::fetch_array($resAnn)) {
|
|
|
$htmlInsertAnn .= "\t<tr>\n";
|
|
|
$sqlInsertAnn .= "
|
|
|
INSERT INTO users SET ";
|
|
|
$csvInsertAnn .= "\n";
|
|
|
for ($noField = 0; $noField < $nbFields; $noField ++) {
|
|
|
if ($noField > 0)
|
|
|
$sqlInsertAnn .= ", ";
|
|
|
$nameField = mysql_field_name($resAnn, $noField);
|
|
|
/*echo "
|
|
|
<br />
|
|
|
$nameField -> ".$users["$nameField"]." ";
|
|
|
*/
|
|
|
$sqlInsertAnn .= "$nameField = '".addslashes($announce["$nameField"])."' ";
|
|
|
$csvInsertAnn .= "'".addslashes($announce["$nameField"])."';";
|
|
|
$htmlInsertAnn .= "\t\t<td>".$announce["$nameField"]."</td>\n";
|
|
|
}
|
|
|
$sqlInsertAnn .= ";";
|
|
|
$htmlInsertAnn .= "\t</tr>\n";
|
|
|
}
|
|
|
if ($verbose_backup) {
|
|
|
echo "</pre>";
|
|
|
}
|
|
|
$htmlInsertAnn .= "</table>\n";
|
|
|
$stringConfig .= "
|
|
|
#INSERT ANNOUNCE
|
|
|
#------------------------------------------
|
|
|
# ".$sqlInsertAnn."
|
|
|
#------------------------------------------
|
|
|
";
|
|
|
$fannsql = fopen($archiveDirSql.$appendMainDb.'annonces.sql', 'w');
|
|
|
fwrite($fannsql, $sqlInsertAnn);
|
|
|
fclose($fannsql);
|
|
|
$fanncsv = fopen($archiveDirCsv.$appendMainDb.'annnonces.csv', 'w');
|
|
|
fwrite($fanncsv, $csvInsertAnn);
|
|
|
fclose($fanncsv);
|
|
|
$fannhtml = fopen($archiveDirHtml.$appendMainDb.'annonces.html', 'w');
|
|
|
fwrite($fannhtml, $htmlInsertAnn);
|
|
|
fclose($fannhtml);
|
|
|
/* End of backup Annonces */
|
|
|
}
|
|
|
// we can copy file of course
|
|
|
if ($verbose_backup) {
|
|
|
echo '<li>'.get_lang('CopyDirectoryCourse');
|
|
|
}
|
|
|
$nbFiles = copydir(api_get_path(SYS_COURSE_PATH).$_course['path'], $archiveDirOriginalDocs.$appendCourse, $verbose_backup);
|
|
|
if ($verbose_backup) {
|
|
|
echo "
|
|
|
<strong>
|
|
|
".$nbFiles."
|
|
|
</strong>
|
|
|
".get_lang('FileCopied')."
|
|
|
<br />
|
|
|
</li>";
|
|
|
}
|
|
|
$stringConfig .= "
|
|
|
// ".$nbFiles." was in ".realpath($archiveDirOriginalDocs);
|
|
|
// ********************************************************************
|
|
|
// Copy of DB course
|
|
|
// with mysqldump
|
|
|
// ********************************************************************
|
|
|
if ($verbose_backup) {
|
|
|
echo "
|
|
|
<li>
|
|
|
".get_lang('BackupOfDataBase')." ".$exportedCourseId." (SQL)
|
|
|
<hr />";
|
|
|
}
|
|
|
backupDatabase($db, $exportedCourseId, true, true, 'SQL', $archiveDirSql.$appendCourse, true, $verbose_backup);
|
|
|
if ($verbose_backup) {
|
|
|
echo "
|
|
|
</li>
|
|
|
<li>
|
|
|
".get_lang('BackupOfDataBase')." ".$exportedCourseId." (PHP)
|
|
|
<hr />";
|
|
|
}
|
|
|
backupDatabase($db, $exportedCourseId, true, true, 'PHP', $archiveDirPhp.$appendCourse, true, $verbose_backup);
|
|
|
if ($verbose_backup) {
|
|
|
echo "
|
|
|
</li>
|
|
|
<li>
|
|
|
".get_lang('BackupOfDataBase')." ".$exportedCourseId." (CSV)
|
|
|
<hr />";
|
|
|
}
|
|
|
backupDatabase($db, $exportedCourseId, true, true, 'CSV', $archiveDirCsv.$appendCourse, true, $verbose_backup);
|
|
|
if ($verbose_backup) {
|
|
|
echo "
|
|
|
<li>
|
|
|
".get_lang('BackupOfDataBase')." ".$exportedCourseId." (HTML)
|
|
|
<hr />";
|
|
|
}
|
|
|
backupDatabase($db, $exportedCourseId, true, true, 'HTML', $archiveDirHtml.$appendCourse, true, $verbose_backup);
|
|
|
if ($verbose_backup) {
|
|
|
echo "
|
|
|
<li>
|
|
|
".get_lang('BackupOfDataBase')." ".$exportedCourseId." (XML)
|
|
|
<hr />";
|
|
|
}
|
|
|
backupDatabase($db, $exportedCourseId, true, true, 'XML', $archiveDirXml.$appendCourse, true, $verbose_backup);
|
|
|
if ($verbose_backup) {
|
|
|
echo "
|
|
|
<li>
|
|
|
".get_lang('BackupOfDataBase')." ".$exportedCourseId." (LOG)
|
|
|
<hr />";
|
|
|
}
|
|
|
backupDatabase($db, $exportedCourseId, true, true, 'LOG', $archiveDirLog.$appendCourse, true, $verbose_backup);
|
|
|
// ********************************************************************
|
|
|
// Copy of DB course
|
|
|
// with mysqldump
|
|
|
// ********************************************************************
|
|
|
$fdesc = fopen($archiveDir.$systemFileNameOfArchive, "w");
|
|
|
fwrite($fdesc, $stringConfig);
|
|
|
fclose($fdesc);
|
|
|
if ($verbose_backup) {
|
|
|
echo "
|
|
|
</li>
|
|
|
</ol>
|
|
|
|
|
|
<br />";
|
|
|
}
|
|
|
///////////////////////////////////
|
|
|
// ****** 4. Compress the tree
|
|
|
if (extension_loaded('zlib')) {
|
|
|
$whatZip[] = $archiveRepositorySys.$exportedCourseId.'/'.$shortDateBackuping.'/HTML';
|
|
|
$forgetPath = $archiveRepositorySys.$exportedCourseId.'/'.$shortDateBackuping.'/';
|
|
|
$prefixPath = $exportedCourseId;
|
|
|
$zipCourse = new PclZip($archiveRepositorySys.$archiveFileName);
|
|
|
$zipRes = $zipCourse->create($whatZip, PCLZIP_OPT_ADD_PATH, $prefixPath, PCLZIP_OPT_REMOVE_PATH, $forgetPath);
|
|
|
if ($zipRes == 0) {
|
|
|
echo "<font size=\"+1\" color=\"#FF0000\">", $zipCourse->errorInfo(true), "</font>";
|
|
|
} else {
|
|
|
for ($i = 0; $i < sizeof($zipRes); $i ++) {
|
|
|
for (reset($zipRes[$i]); $key = key($zipRes[$i]); next($zipRes[$i])) {
|
|
|
echo "File $i / [$key] = ".$list[$i][$key]."<br />";
|
|
|
}
|
|
|
echo "<br />";
|
|
|
}
|
|
|
}
|
|
|
$pathToArchive = $archiveRepositoryWeb.$archiveFileName;
|
|
|
if ($verbose_backup) {
|
|
|
echo '<hr />'.get_lang('BuildTheCompressedFile');
|
|
|
}
|
|
|
// removeDir($archivePath);
|
|
|
}
|
|
|
return 1;
|
|
|
} // function makeTheBackup()
|
|
|
|