/* * Copyright (c) 2021, Jan de Visser * * SPDX-License-Identifier: BSD-2-Clause */ #include #include #include namespace SQLServer { static HashMap> s_connections; static u64 s_next_connection_id = 0; RefPtr DatabaseConnection::connection_for(u64 connection_id) { if (s_connections.contains(connection_id)) return *s_connections.get(connection_id).value(); dbgln_if(SQLSERVER_DEBUG, "Invalid connection_id {}", connection_id); return nullptr; } ErrorOr> DatabaseConnection::create(DeprecatedString database_name, int client_id) { if (LexicalPath path(database_name); (path.title() != database_name) || (path.dirname() != ".")) return Error::from_string_view("Invalid database name"sv); auto database = SQL::Database::construct(DeprecatedString::formatted("/home/anon/sql/{}.db", database_name)); if (auto result = database->open(); result.is_error()) { warnln("Could not open database: {}", result.error().error_string()); return Error::from_string_view("Could not open database"sv); } return adopt_nonnull_ref_or_enomem(new (nothrow) DatabaseConnection(move(database), move(database_name), client_id)); } DatabaseConnection::DatabaseConnection(NonnullRefPtr database, DeprecatedString database_name, int client_id) : Object() , m_database(move(database)) , m_database_name(move(database_name)) , m_connection_id(s_next_connection_id++) , m_client_id(client_id) { dbgln_if(SQLSERVER_DEBUG, "DatabaseConnection {} initiatedconnection with database '{}'", connection_id(), m_database_name); s_connections.set(m_connection_id, *this); } void DatabaseConnection::disconnect() { dbgln_if(SQLSERVER_DEBUG, "DatabaseConnection::disconnect(connection_id {}, database '{}'", connection_id(), m_database_name); s_connections.remove(connection_id()); } SQL::ResultOr DatabaseConnection::prepare_statement(StringView sql) { dbgln_if(SQLSERVER_DEBUG, "DatabaseConnection::prepare_statement(connection_id {}, database '{}', sql '{}'", connection_id(), m_database_name, sql); auto statement = TRY(SQLStatement::create(*this, sql)); return statement->statement_id(); } }