jilo-web/app/includes/database.php

63 lines
2.3 KiB
PHP
Raw Normal View History

2024-08-10 18:42:44 +00:00
<?php
// connect to database
function connectDB($config, $database = '', $dbFile = '', $platformId = '') {
2024-08-10 18:57:41 +00:00
// connecting ti a jilo sqlite database
2024-08-10 18:57:41 +00:00
if ($database === 'jilo') {
2024-08-10 18:42:44 +00:00
try {
2024-08-17 08:20:08 +00:00
if (!$dbFile || !file_exists($dbFile)) {
2024-12-04 14:18:15 +00:00
throw new Exception(getError("Invalid platform ID \"{$platformId}\", database file \"{$dbFile}\" not found."));
}
2024-08-10 18:42:44 +00:00
$db = new Database([
2024-08-10 18:57:41 +00:00
'type' => 'sqlite',
'dbFile' => $dbFile,
2024-08-10 18:42:44 +00:00
]);
2024-11-08 10:38:19 +00:00
return ['db' => $db, 'error' => null];
2024-08-10 18:42:44 +00:00
} catch (Exception $e) {
2024-11-08 10:38:19 +00:00
return ['db' => null, 'error' => getError('Error connecting to DB.', $e->getMessage())];
2024-08-10 18:42:44 +00:00
}
2024-08-10 18:57:41 +00:00
// connecting to a jilo-web database of the web app
2024-08-10 18:57:41 +00:00
} else {
// sqlite database file
2024-08-13 14:53:52 +00:00
if ($config['db']['db_type'] === 'sqlite') {
2024-08-10 18:57:41 +00:00
try {
$db = new Database([
2024-08-13 14:53:52 +00:00
'type' => $config['db']['db_type'],
'dbFile' => $config['db']['sqlite_file'],
2024-08-10 18:57:41 +00:00
]);
$pdo = $db->getConnection();
2024-11-08 10:39:38 +00:00
return ['db' => $db, 'error' => null];
2024-08-10 18:57:41 +00:00
} catch (Exception $e) {
2024-11-08 10:40:32 +00:00
return ['db' => null, 'error' => getError('Error connecting to DB.', $e->getMessage())];
2024-08-10 18:57:41 +00:00
}
// mysql/mariadb database
2024-08-13 14:53:52 +00:00
} elseif ($config['db']['db_type'] === 'mysql' || $config['db']['db_type'] === 'mariadb') {
2024-08-10 18:57:41 +00:00
try {
$db = new Database([
2024-08-13 14:53:52 +00:00
'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'],
2024-08-10 18:57:41 +00:00
]);
$pdo = $db->getConnection();
2024-11-08 10:39:38 +00:00
return ['db' => $db, 'error' => null];
2024-08-10 18:57:41 +00:00
} catch (Exception $e) {
2024-11-08 10:40:32 +00:00
return ['db' => null, 'error' => getError('Error connecting to DB.', $e->getMessage())];
2024-08-10 18:57:41 +00:00
}
// unknown database
} else {
2024-08-13 14:53:52 +00:00
$error = "Error: unknow database type \"{$config['db']['db_type']}\"";
Messages::flash('ERROR', 'DEFAULT', $error);
2024-08-10 18:42:44 +00:00
exit();
}
2024-08-10 18:57:41 +00:00
2024-08-10 18:42:44 +00:00
}
2024-08-10 18:57:41 +00:00
2024-08-10 18:42:44 +00:00
}
?>