You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
59 lines
1.7 KiB
59 lines
1.7 KiB
<?php
|
|
/* For licensing terms, see /license.txt */
|
|
|
|
$plugin = MigrationMoodlePlugin::create();
|
|
|
|
try {
|
|
UserManager::create_extra_field(
|
|
'moodle_password',
|
|
ExtraField::FIELD_TYPE_TEXT,
|
|
$plugin->get_lang('MoodlePassword'),
|
|
''
|
|
);
|
|
|
|
createPluginTables();
|
|
} catch (Exception $exception) {
|
|
$message = sprintf(
|
|
$plugin->get_lang('InstallError'),
|
|
$exception->getMessage()
|
|
);
|
|
|
|
echo Display::return_message($message, 'error');
|
|
}
|
|
|
|
/**
|
|
* Create database tables for this plugin.
|
|
*/
|
|
function createPluginTables()
|
|
{
|
|
$installed = AppPlugin::getInstance()->isInstalled('migrationmoodle');
|
|
|
|
if ($installed) {
|
|
return;
|
|
}
|
|
|
|
$queries = [];
|
|
$queries[] = "CREATE TABLE IF NOT EXISTS plugin_migrationmoodle_task (
|
|
id INT AUTO_INCREMENT NOT NULL,
|
|
name VARCHAR(255) NOT NULL,
|
|
PRIMARY KEY(id)
|
|
) DEFAULT CHARACTER SET utf8 COLLATE utf8_unicode_ci ENGINE = InnoDB";
|
|
$queries[] = "CREATE TABLE IF NOT EXISTS plugin_migrationmoodle_item (
|
|
id INT AUTO_INCREMENT NOT NULL,
|
|
task_id INT NOT NULL,
|
|
hash VARCHAR(255) NOT NULL,
|
|
extracted_id INT NOT NULL,
|
|
loaded_id INT NOT NULL,
|
|
INDEX IDX_HASH (hash),
|
|
INDEX IDX_EXTRACTED_LOADED (extracted_id, loaded_id),
|
|
INDEX IDX_LOADED (loaded_id),
|
|
INDEX IDX_TASK (task_id),
|
|
PRIMARY KEY(id)
|
|
) DEFAULT CHARACTER SET utf8 COLLATE utf8_unicode_ci ENGINE = InnoDB";
|
|
$queries[] = "ALTER TABLE plugin_migrationmoodle_item ADD CONSTRAINT FK_TASK FOREIGN KEY (task_id)
|
|
REFERENCES plugin_migrationmoodle_task (id) ON DELETE CASCADE";
|
|
|
|
foreach ($queries as $query) {
|
|
Database::query($query);
|
|
}
|
|
}
|
|
|