pdo = new PDO(self::get_dsn(), Config::get(Config::DB_USER), Config::get(Config::DB_PASS)); if ($db_type == 'sqlite') { $this->pdo->query('PRAGMA journal_mode = wal'); } } catch (Exception $e) { user_error($e, E_USER_WARNING); die("Unable to initialize database driver: " . Config::get(Config::DB_TYPE)); } $this->pdo->setAttribute(PDO::ATTR_ERRMODE, PDO::ERRMODE_EXCEPTION); try { ORM::configure(self::get_dsn()); ORM::configure('return_result_sets', true); if ($db_type == 'pgsql') { ORM::configure('username', Config::get(Config::DB_USER)); ORM::configure('password', Config::get(Config::DB_PASS)); ORM::configure('return_result_sets', true); } else { ORM::raw_execute('PRAGMA journal_mode = wal'); } } catch (Exception $e) { user_error($e, E_USER_WARNING); die("Unable to initialize ORM layer."); } } public static function get_dsn() : string { $db_type = Config::get(Config::DB_TYPE); if ($db_type == 'pgsql') { $db_port = Config::get(Config::DB_PORT) ? ';port=' . Config::get(Config::DB_PORT) : ''; $db_host = Config::get(Config::DB_HOST) ? ';host=' . Config::get(Config::DB_HOST) : ''; return $db_type . ':dbname=' . Config::get(Config::DB_NAME) . $db_host . $db_port; } else { return $db_type . ':' . Config::get(Config::SCRATCH_DB); } } public static function pdo() : PDO { if (self::$instance == null) self::$instance = new self(); return self::$instance->pdo; } };