63 lines
2.3 KiB
PHP
63 lines
2.3 KiB
PHP
<?php
|
|
|
|
// connect to database
|
|
function connectDB($config, $database = '', $dbFile = '', $platformId = '') {
|
|
|
|
// connecting ti a jilo sqlite database
|
|
if ($database === 'jilo') {
|
|
try {
|
|
if (!$dbFile || !file_exists($dbFile)) {
|
|
throw new Exception(getError("Invalid platform ID \"{$platformId}\", database file \"{$dbFile}\" not found."));
|
|
}
|
|
$db = new Database([
|
|
'type' => 'sqlite',
|
|
'dbFile' => $dbFile,
|
|
]);
|
|
return ['db' => $db, 'error' => null];
|
|
} catch (Exception $e) {
|
|
return ['db' => null, 'error' => getError('Error connecting to DB.', $e->getMessage())];
|
|
}
|
|
|
|
// connecting to a jilo-web database of the web app
|
|
} else {
|
|
|
|
// sqlite database file
|
|
if ($config['db']['db_type'] === 'sqlite') {
|
|
try {
|
|
$db = new Database([
|
|
'type' => $config['db']['db_type'],
|
|
'dbFile' => $config['db']['sqlite_file'],
|
|
]);
|
|
$pdo = $db->getConnection();
|
|
return ['db' => $db, 'error' => null];
|
|
} catch (Exception $e) {
|
|
return ['db' => null, 'error' => getError('Error connecting to DB.', $e->getMessage())];
|
|
}
|
|
// mysql/mariadb database
|
|
} elseif ($config['db']['db_type'] === 'mysql' || $config['db']['db_type'] === 'mariadb') {
|
|
try {
|
|
$db = new Database([
|
|
'type' => $config['db']['db_type'],
|
|
'host' => $config['db']['sql_host'] ?? 'localhost',
|
|
'port' => $config['db']['sql_port'] ?? '3306',
|
|
'dbname' => $config['db']['sql_database'],
|
|
'user' => $config['db']['sql_username'],
|
|
'password' => $config['db']['sql_password'],
|
|
]);
|
|
$pdo = $db->getConnection();
|
|
return ['db' => $db, 'error' => null];
|
|
} catch (Exception $e) {
|
|
return ['db' => null, 'error' => getError('Error connecting to DB.', $e->getMessage())];
|
|
}
|
|
// unknown database
|
|
} else {
|
|
$error = "Error: unknow database type \"{$config['db']['db_type']}\"";
|
|
Messages::flash('ERROR', 'DEFAULT', $error);
|
|
exit();
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
?>
|