drizzle-orm
Version:
Drizzle ORM package for SQL databases
96 lines • 3.48 kB
JavaScript
import { entityKind } from "../entity.js";
import { NoopLogger } from "../logger.js";
import { PgTransaction } from "../pg-core/index.js";
import { PgPreparedQuery, PgSession } from "../pg-core/session.js";
import { fillPlaceholders } from "../sql/sql.js";
import { mapResultRow } from "../utils.js";
class XataHttpPreparedQuery extends PgPreparedQuery {
constructor(client, query, logger, fields, _isResponseInArrayMode, customResultMapper) {
super(query);
this.client = client;
this.logger = logger;
this.fields = fields;
this._isResponseInArrayMode = _isResponseInArrayMode;
this.customResultMapper = customResultMapper;
}
static [entityKind] = "XataHttpPreparedQuery";
async execute(placeholderValues = {}) {
const params = fillPlaceholders(this.query.params, placeholderValues);
this.logger.logQuery(this.query.sql, params);
const { fields, client, query, customResultMapper, joinsNotNullableMap } = this;
if (!fields && !customResultMapper) {
return await client.sql({ statement: query.sql, params });
}
const { rows, warning } = await client.sql({ statement: query.sql, params, responseType: "array" });
if (warning)
console.warn(warning);
return customResultMapper ? customResultMapper(rows) : rows.map((row) => mapResultRow(fields, row, joinsNotNullableMap));
}
all(placeholderValues = {}) {
const params = fillPlaceholders(this.query.params, placeholderValues);
this.logger.logQuery(this.query.sql, params);
return this.client.sql({ statement: this.query.sql, params, responseType: "array" }).then((result) => result.rows);
}
values(placeholderValues = {}) {
const params = fillPlaceholders(this.query.params, placeholderValues);
this.logger.logQuery(this.query.sql, params);
return this.client.sql({ statement: this.query.sql, params }).then((result) => result.records);
}
/** @internal */
isResponseInArrayMode() {
return this._isResponseInArrayMode;
}
}
class XataHttpSession extends PgSession {
constructor(client, dialect, schema, options = {}) {
super(dialect);
this.client = client;
this.schema = schema;
this.options = options;
this.logger = options.logger ?? new NoopLogger();
}
static [entityKind] = "XataHttpSession";
logger;
prepareQuery(query, fields, name, isResponseInArrayMode, customResultMapper) {
return new XataHttpPreparedQuery(
this.client,
query,
this.logger,
fields,
isResponseInArrayMode,
customResultMapper
);
}
async query(query, params) {
this.logger.logQuery(query, params);
const result = await this.client.sql({ statement: query, params, responseType: "array" });
return {
rowCount: result.rows.length,
rows: result.rows,
rowAsArray: true
};
}
async queryObjects(query, params) {
const result = await this.client.sql({ statement: query, params });
return {
rowCount: result.records.length,
rows: result.records,
rowAsArray: false
};
}
async transaction(_transaction, _config = {}) {
throw new Error("No transactions support in Xata Http driver");
}
}
class XataTransaction extends PgTransaction {
static [entityKind] = "XataHttpTransaction";
async transaction(_transaction) {
throw new Error("No transactions support in Xata Http driver");
}
}
export {
XataHttpPreparedQuery,
XataHttpSession,
XataTransaction
};
//# sourceMappingURL=session.js.map