jilo-web/app/helpers/database.php

62 lines
1.9 KiB
PHP
Raw Normal View History

2024-08-10 18:42:44 +00:00
<?php
// connect to database
function connectDB($config, $database = '') {
2024-08-10 18:57:41 +00:00
if ($database === 'jilo') {
2024-08-10 18:42:44 +00:00
try {
$db = new Database([
2024-08-10 18:57:41 +00:00
'type' => 'sqlite',
'dbFile' => $config['jilo_database'],
2024-08-10 18:42:44 +00:00
]);
} catch (Exception $e) {
$error = 'Error: ' . $e->getMessage();
2024-08-12 11:12:24 +00:00
include '../app/templates/block-message.php';
2024-08-10 18:42:44 +00:00
exit();
}
2024-08-10 18:57:41 +00:00
} else {
// sqlite database file
if ($config['db_type'] === 'sqlite') {
try {
$db = new Database([
'type' => $config['db_type'],
'dbFile' => $config['sqlite_file'],
]);
$pdo = $db->getConnection();
} catch (Exception $e) {
$error = 'Error: ' . $e->getMessage();
2024-08-12 11:12:24 +00:00
include '../app/templates/block-message.php';
2024-08-10 18:57:41 +00:00
exit();
}
// mysql/mariadb database
} elseif ($config['db_type'] === 'mysql' || $config['db_type'] === 'mariadb') {
try {
$db = new Database([
'type' => $config['db_type'],
'host' => $config['sql_host'] ?? 'localhost',
'port' => $config['sql_port'] ?? '3306',
'dbname' => $config['sql_database'],
'user' => $config['sql_username'],
'password' => $config['sql_password'],
]);
$pdo = $db->getConnection();
} catch (Exception $e) {
$error = 'Error: ' . $e->getMessage();
2024-08-12 11:12:24 +00:00
include '../app/templates/block-message.php';
2024-08-10 18:57:41 +00:00
exit();
}
// unknown database
} else {
$error = "Error: unknow database type \"{$config['db_type']}\"";
2024-08-12 11:12:24 +00:00
include '../app/templates/block-message.php';
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
return $db;
}
?>