@gensx/storage
Version:
Cloud storage, blobs, sqlite, and vector database providers/hooks for GenSX.
88 lines (83 loc) • 2.87 kB
JavaScript
;
/**
* Check out the docs at https://www.gensx.com/docs
* Find us on Github https://github.com/gensx-inc/gensx
* Find us on Discord https://discord.gg/F5BSU8Kc
*/
var path = require('path');
var config = require('../utils/config.cjs');
var filesystem = require('./filesystem.cjs');
var remote = require('./remote.cjs');
/**
* Client for interacting with database functionality outside of JSX context
*/
class DatabaseClient {
storage;
/**
* Create a new DatabaseClient
* @param options Optional configuration properties for the database storage
*/
constructor(options = {}) {
const kind = options.kind ??
(process.env.GENSX_RUNTIME === "cloud" ? "cloud" : "filesystem");
if (kind === "filesystem") {
const rootDir = options.kind === "filesystem" && options.rootDir
? options.rootDir
: path.join(process.cwd(), ".gensx", "databases");
this.storage = new filesystem.FileSystemDatabaseStorage(rootDir);
}
else {
const { project, environment } = config.getProjectAndEnvironment({
project: options.project,
environment: options.environment,
});
this.storage = new remote.RemoteDatabaseStorage(project, environment);
}
}
/**
* Get a database (ensures it exists first)
* @param name The database name
* @returns A Promise resolving to a Database
*/
async getDatabase(name) {
if (!this.storage.hasEnsuredDatabase(name)) {
await this.storage.ensureDatabase(name);
}
return this.storage.getDatabase(name);
}
/**
* Ensure a database exists (idempotent operation)
* @param name The database name
* @returns A Promise resolving to the ensure result
*/
async ensureDatabase(name) {
return this.storage.ensureDatabase(name);
}
/**
* List all databases
* @param options Optional pagination options
* @returns A Promise resolving to an array of database names and optional next cursor
*/
async listDatabases(options) {
return this.storage.listDatabases(options);
}
/**
* Delete a database
* @param name The database name
* @returns A Promise resolving to the deletion result
*/
async deleteDatabase(name) {
return this.storage.deleteDatabase(name);
}
/**
* Check if a database exists
* @param name The database name
* @returns A Promise resolving to a boolean indicating if the database exists
*/
async databaseExists(name) {
const result = await this.storage.listDatabases();
return result.databases.some((db) => db.name === name);
}
}
exports.DatabaseClient = DatabaseClient;
//# sourceMappingURL=databaseClient.cjs.map