mirror of
https://github.com/moodle/moodle.git
synced 2025-01-19 06:18:28 +01:00
48 lines
1.6 KiB
PHP
48 lines
1.6 KiB
PHP
<?php //$Id$
|
|
|
|
require('../../config.php');
|
|
require_once('lib.php');
|
|
require_once('database_transfer_form.php');
|
|
|
|
require_login();
|
|
admin_externalpage_setup('dbtransfer');
|
|
|
|
// Create the form
|
|
$form = new database_transfer_form();
|
|
|
|
// If we have valid input.
|
|
if ($data = $form->get_data()) {
|
|
// Connect to the other database.
|
|
list($dbtype, $dblibrary) = explode('/', $data->driver);
|
|
$targetdb = moodle_database::get_driver_instance($dbtype, $dblibrary);
|
|
if (!$targetdb->connect($data->dbhost, $data->dbuser, $data->dbpass, $data->dbname, $data->prefix, null)) {
|
|
throw new dbtransfer_exception('notargetconectexception', null, "$CFG->wwwroot/$CFG->admin/dbtransfer/");
|
|
}
|
|
if ($targetdb->get_tables()) {
|
|
throw new dbtransfer_exception('targetdatabasenotempty', null, "$CFG->wwwroot/$CFG->admin/dbtransfer/");
|
|
}
|
|
|
|
// Start output.
|
|
admin_externalpage_print_header();
|
|
$data->dbtype = $dbtype;
|
|
print_heading(get_string('transferringdbto', 'dbtransfer', $data));
|
|
|
|
// Do the transfer.
|
|
$feedback = new html_list_progress_trace();
|
|
dbtransfer_transfer_database($DB, $targetdb, $feedback);
|
|
$feedback->finished();
|
|
|
|
// Finish up.
|
|
notify(get_string('success'), 'notifysuccess');
|
|
print_continue("$CFG->wwwroot/$CFG->admin/");
|
|
admin_externalpage_print_footer();
|
|
die;
|
|
}
|
|
|
|
// Otherwise display the settings form.
|
|
admin_externalpage_print_header();
|
|
print_heading(get_string('transferdbtoserver', 'dbtransfer'));
|
|
echo '<p>', get_string('transferdbintro', 'dbtransfer'), "</p>\n\n";
|
|
$form->display();
|
|
admin_externalpage_print_footer();
|