mirror of
https://github.com/zebrajr/node.git
synced 2026-01-15 12:15:26 +00:00
This commit adds support to node:sqlite for defining custom functions that can be invoked from SQL. Fixes: https://github.com/nodejs/node/issues/54349 PR-URL: https://github.com/nodejs/node/pull/55985 Reviewed-By: Zeyu "Alex" Yang <himself65@outlook.com> Reviewed-By: James M Snell <jasnell@gmail.com>
169 lines
5.6 KiB
C++
169 lines
5.6 KiB
C++
#ifndef SRC_NODE_SQLITE_H_
|
|
#define SRC_NODE_SQLITE_H_
|
|
|
|
#if defined(NODE_WANT_INTERNALS) && NODE_WANT_INTERNALS
|
|
|
|
#include "base_object.h"
|
|
#include "node_mem.h"
|
|
#include "sqlite3.h"
|
|
#include "util.h"
|
|
|
|
#include <map>
|
|
#include <unordered_set>
|
|
|
|
namespace node {
|
|
namespace sqlite {
|
|
|
|
class DatabaseOpenConfiguration {
|
|
public:
|
|
explicit DatabaseOpenConfiguration(std::string&& location)
|
|
: location_(std::move(location)) {}
|
|
|
|
inline const std::string& location() const { return location_; }
|
|
|
|
inline bool get_read_only() const { return read_only_; }
|
|
|
|
inline void set_read_only(bool flag) { read_only_ = flag; }
|
|
|
|
inline bool get_enable_foreign_keys() const { return enable_foreign_keys_; }
|
|
|
|
inline void set_enable_foreign_keys(bool flag) {
|
|
enable_foreign_keys_ = flag;
|
|
}
|
|
|
|
inline bool get_enable_dqs() const { return enable_dqs_; }
|
|
|
|
inline void set_enable_dqs(bool flag) { enable_dqs_ = flag; }
|
|
|
|
private:
|
|
std::string location_;
|
|
bool read_only_ = false;
|
|
bool enable_foreign_keys_ = true;
|
|
bool enable_dqs_ = false;
|
|
};
|
|
|
|
class StatementSync;
|
|
|
|
class DatabaseSync : public BaseObject {
|
|
public:
|
|
DatabaseSync(Environment* env,
|
|
v8::Local<v8::Object> object,
|
|
DatabaseOpenConfiguration&& open_config,
|
|
bool open,
|
|
bool allow_load_extension);
|
|
void MemoryInfo(MemoryTracker* tracker) const override;
|
|
static void New(const v8::FunctionCallbackInfo<v8::Value>& args);
|
|
static void Open(const v8::FunctionCallbackInfo<v8::Value>& args);
|
|
static void Close(const v8::FunctionCallbackInfo<v8::Value>& args);
|
|
static void Prepare(const v8::FunctionCallbackInfo<v8::Value>& args);
|
|
static void Exec(const v8::FunctionCallbackInfo<v8::Value>& args);
|
|
static void CustomFunction(const v8::FunctionCallbackInfo<v8::Value>& args);
|
|
static void CreateSession(const v8::FunctionCallbackInfo<v8::Value>& args);
|
|
static void ApplyChangeset(const v8::FunctionCallbackInfo<v8::Value>& args);
|
|
static void EnableLoadExtension(
|
|
const v8::FunctionCallbackInfo<v8::Value>& args);
|
|
static void LoadExtension(const v8::FunctionCallbackInfo<v8::Value>& args);
|
|
void FinalizeStatements();
|
|
void UntrackStatement(StatementSync* statement);
|
|
bool IsOpen();
|
|
sqlite3* Connection();
|
|
|
|
SET_MEMORY_INFO_NAME(DatabaseSync)
|
|
SET_SELF_SIZE(DatabaseSync)
|
|
|
|
private:
|
|
bool Open();
|
|
void DeleteSessions();
|
|
|
|
~DatabaseSync() override;
|
|
DatabaseOpenConfiguration open_config_;
|
|
bool allow_load_extension_;
|
|
bool enable_load_extension_;
|
|
sqlite3* connection_;
|
|
|
|
std::set<sqlite3_session*> sessions_;
|
|
std::unordered_set<StatementSync*> statements_;
|
|
|
|
friend class Session;
|
|
};
|
|
|
|
class StatementSync : public BaseObject {
|
|
public:
|
|
StatementSync(Environment* env,
|
|
v8::Local<v8::Object> object,
|
|
DatabaseSync* db,
|
|
sqlite3_stmt* stmt);
|
|
void MemoryInfo(MemoryTracker* tracker) const override;
|
|
static v8::Local<v8::FunctionTemplate> GetConstructorTemplate(
|
|
Environment* env);
|
|
static BaseObjectPtr<StatementSync> Create(Environment* env,
|
|
DatabaseSync* db,
|
|
sqlite3_stmt* stmt);
|
|
static void All(const v8::FunctionCallbackInfo<v8::Value>& args);
|
|
static void Iterate(const v8::FunctionCallbackInfo<v8::Value>& args);
|
|
static void Get(const v8::FunctionCallbackInfo<v8::Value>& args);
|
|
static void Run(const v8::FunctionCallbackInfo<v8::Value>& args);
|
|
static void SourceSQLGetter(const v8::FunctionCallbackInfo<v8::Value>& args);
|
|
static void ExpandedSQLGetter(
|
|
const v8::FunctionCallbackInfo<v8::Value>& args);
|
|
static void SetAllowBareNamedParameters(
|
|
const v8::FunctionCallbackInfo<v8::Value>& args);
|
|
static void SetReadBigInts(const v8::FunctionCallbackInfo<v8::Value>& args);
|
|
void Finalize();
|
|
bool IsFinalized();
|
|
|
|
SET_MEMORY_INFO_NAME(StatementSync)
|
|
SET_SELF_SIZE(StatementSync)
|
|
|
|
private:
|
|
~StatementSync() override;
|
|
DatabaseSync* db_;
|
|
sqlite3_stmt* statement_;
|
|
bool use_big_ints_;
|
|
bool allow_bare_named_params_;
|
|
std::optional<std::map<std::string, std::string>> bare_named_params_;
|
|
bool BindParams(const v8::FunctionCallbackInfo<v8::Value>& args);
|
|
bool BindValue(const v8::Local<v8::Value>& value, const int index);
|
|
v8::MaybeLocal<v8::Value> ColumnToValue(const int column);
|
|
v8::MaybeLocal<v8::Name> ColumnNameToName(const int column);
|
|
|
|
static void IterateNextCallback(
|
|
const v8::FunctionCallbackInfo<v8::Value>& args);
|
|
static void IterateReturnCallback(
|
|
const v8::FunctionCallbackInfo<v8::Value>& args);
|
|
};
|
|
|
|
using Sqlite3ChangesetGenFunc = int (*)(sqlite3_session*, int*, void**);
|
|
|
|
class Session : public BaseObject {
|
|
public:
|
|
Session(Environment* env,
|
|
v8::Local<v8::Object> object,
|
|
BaseObjectWeakPtr<DatabaseSync> database,
|
|
sqlite3_session* session);
|
|
~Session() override;
|
|
template <Sqlite3ChangesetGenFunc sqliteChangesetFunc>
|
|
static void Changeset(const v8::FunctionCallbackInfo<v8::Value>& args);
|
|
static void Close(const v8::FunctionCallbackInfo<v8::Value>& args);
|
|
static v8::Local<v8::FunctionTemplate> GetConstructorTemplate(
|
|
Environment* env);
|
|
static BaseObjectPtr<Session> Create(Environment* env,
|
|
BaseObjectWeakPtr<DatabaseSync> database,
|
|
sqlite3_session* session);
|
|
|
|
void MemoryInfo(MemoryTracker* tracker) const override;
|
|
SET_MEMORY_INFO_NAME(Session)
|
|
SET_SELF_SIZE(Session)
|
|
|
|
private:
|
|
void Delete();
|
|
sqlite3_session* session_;
|
|
BaseObjectWeakPtr<DatabaseSync> database_; // The Parent Database
|
|
};
|
|
|
|
} // namespace sqlite
|
|
} // namespace node
|
|
|
|
#endif // defined(NODE_WANT_INTERNALS) && NODE_WANT_INTERNALS
|
|
#endif // SRC_NODE_SQLITE_H_
|