New Case Study:See how Anthropic automated 95% of dependency reviews with Socket.Learn More
Socket
Sign inDemoInstall
Socket

@uql/mongo

Package Overview
Dependencies
Maintainers
1
Versions
113
Alerts
File Explorer

Advanced tools

Socket logo

Install Socket

Detect and block malicious and high-risk dependencies

Install

@uql/mongo - npm Package Compare versions

Comparing version 0.4.59 to 0.4.60

7

mongodbQuerier.d.ts
import { MongoClient } from 'mongodb';
import { Query, QueryOne, Type, QueryCriteria, QueryOptions, QuerySearch, IdValue } from '@uql/core/type';
import { Query, QueryOne, Type, QueryCriteria, QueryOptions, QuerySearch, IdValue, Logger } from '@uql/core/type';
import { BaseQuerier } from '@uql/core/querier';
import { MongoDialect } from './mongoDialect';
export declare class MongodbQuerier extends BaseQuerier {
readonly dialect: MongoDialect;
readonly conn: MongoClient;
readonly dialect: MongoDialect;
readonly logger?: Logger;
private session;
constructor(conn: MongoClient, dialect?: MongoDialect);
constructor(dialect: MongoDialect, conn: MongoClient, logger?: Logger);
count<E>(entity: Type<E>, qm?: QuerySearch<E>): Promise<number>;

@@ -11,0 +12,0 @@ findOneById<E>(entity: Type<E>, id: IdValue<E>, qo: QueryOne<E>): Promise<E>;

"use strict";
Object.defineProperty(exports, "__esModule", { value: true });
exports.MongodbQuerier = void 0;
const core_1 = require("@uql/core");
const querier_1 = require("@uql/core/querier");
const decorator_1 = require("@uql/core/entity/decorator");
const util_1 = require("@uql/core/util");
const mongoDialect_1 = require("./mongoDialect");
class MongodbQuerier extends querier_1.BaseQuerier {
constructor(conn, dialect = new mongoDialect_1.MongoDialect()) {
constructor(dialect, conn, logger) {
super();
this.dialect = dialect;
this.conn = conn;
this.dialect = dialect;
this.logger = logger;
}
count(entity, qm = {}) {
var _a;
const filter = this.dialect.filter(entity, qm.$filter);
(0, core_1.log)('count', entity.name, filter);
(_a = this.logger) === null || _a === void 0 ? void 0 : _a.call(this, 'count', entity.name, filter);
return this.collection(entity).countDocuments(filter, {

@@ -26,2 +26,3 @@ session: this.session,

async findMany(entity, qm) {
var _a;
const meta = (0, decorator_1.getMeta)(entity);

@@ -32,4 +33,4 @@ let documents;

const pipeline = this.dialect.aggregationPipeline(entity, qm);
if ((0, core_1.isLogging)()) {
(0, core_1.log)('findMany', entity.name, JSON.stringify(pipeline, null, 2));
if (this.logger) {
this.logger('findMany', entity.name, JSON.stringify(pipeline, null, 2));
}

@@ -60,3 +61,3 @@ documents = await this.collection(entity).aggregate(pipeline, { session: this.session }).toArray();

}
(0, core_1.log)('findMany', entity.name, qm);
(_a = this.logger) === null || _a === void 0 ? void 0 : _a.call(this, 'findMany', entity.name, qm);
documents = await cursor.toArray();

@@ -68,2 +69,3 @@ documents = this.dialect.normalizeIds(meta, documents);

async insertMany(entity, payload) {
var _a;
if (!payload.length) {

@@ -76,3 +78,3 @@ return;

const persistables = (0, util_1.getPersistables)(meta, payload, 'onInsert');
(0, core_1.log)('insertMany', entity.name, persistables);
(_a = this.logger) === null || _a === void 0 ? void 0 : _a.call(this, 'insertMany', entity.name, persistables);
const { insertedIds } = await this.collection(entity).insertMany(persistables, { session: this.session });

@@ -87,2 +89,3 @@ const ids = Object.values(insertedIds);

async updateMany(entity, qm, payload) {
var _a;
payload = (0, util_1.clone)(payload);

@@ -93,3 +96,3 @@ const meta = (0, decorator_1.getMeta)(entity);

const update = { $set: persistable };
(0, core_1.log)('updateMany', entity.name, filter, update);
(_a = this.logger) === null || _a === void 0 ? void 0 : _a.call(this, 'updateMany', entity.name, filter, update);
const { matchedCount } = await this.collection(entity).updateMany(filter, update, {

@@ -102,5 +105,6 @@ session: this.session,

async deleteMany(entity, qm, opts = {}) {
var _a;
const meta = (0, decorator_1.getMeta)(entity);
const filter = this.dialect.filter(entity, qm.$filter);
(0, core_1.log)('deleteMany', entity.name, filter, opts);
(_a = this.logger) === null || _a === void 0 ? void 0 : _a.call(this, 'deleteMany', entity.name, filter, opts);
const founds = await this.collection(entity)

@@ -141,7 +145,7 @@ .find(filter, {

async beginTransaction() {
var _a;
var _a, _b;
if ((_a = this.session) === null || _a === void 0 ? void 0 : _a.inTransaction()) {
throw new TypeError('pending transaction');
}
(0, core_1.log)('beginTransaction');
(_b = this.logger) === null || _b === void 0 ? void 0 : _b.call(this, 'beginTransaction');
this.session = this.conn.startSession();

@@ -151,15 +155,15 @@ this.session.startTransaction();

async commitTransaction() {
var _a;
var _a, _b;
if (!((_a = this.session) === null || _a === void 0 ? void 0 : _a.inTransaction())) {
throw new TypeError('not a pending transaction');
}
(0, core_1.log)('commitTransaction');
(_b = this.logger) === null || _b === void 0 ? void 0 : _b.call(this, 'commitTransaction');
await this.session.commitTransaction();
}
async rollbackTransaction() {
var _a;
var _a, _b;
if (!((_a = this.session) === null || _a === void 0 ? void 0 : _a.inTransaction())) {
throw new TypeError('not a pending transaction');
}
(0, core_1.log)('rollbackTransaction');
(_b = this.logger) === null || _b === void 0 ? void 0 : _b.call(this, 'rollbackTransaction');
await this.session.abortTransaction();

@@ -176,2 +180,2 @@ }

exports.MongodbQuerier = MongodbQuerier;
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"mongodbQuerier.js","sourceRoot":"","sources":["../src/mongodbQuerier.ts"],"names":[],"mappings":"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","sourcesContent":["import { MongoClient, ClientSession } from 'mongodb';\nimport { isLogging, log } from '@uql/core';\nimport { Query, QueryOne, Type, QueryCriteria, QueryOptions, QuerySearch, IdValue, FieldValue } from '@uql/core/type';\nimport { BaseQuerier } from '@uql/core/querier';\nimport { getMeta } from '@uql/core/entity/decorator';\nimport { clone, getPersistable, getPersistables, hasKeys, isProjectingRelations } from '@uql/core/util';\n\nimport { MongoDialect } from './mongoDialect';\n\nexport class MongodbQuerier extends BaseQuerier {\n  private session: ClientSession;\n\n  constructor(readonly conn: MongoClient, readonly dialect = new MongoDialect()) {\n    super();\n  }\n\n  override count<E>(entity: Type<E>, qm: QuerySearch<E> = {}) {\n    const filter = this.dialect.filter(entity, qm.$filter);\n    log('count', entity.name, filter);\n    return this.collection(entity).countDocuments(filter, {\n      session: this.session,\n    });\n  }\n\n  override findOneById<E>(entity: Type<E>, id: IdValue<E>, qo: QueryOne<E>) {\n    return this.findOne(entity, { ...qo, $filter: id });\n  }\n\n  override async findMany<E>(entity: Type<E>, qm: Query<E>) {\n    const meta = getMeta(entity);\n\n    let documents: E[];\n    const hasProjectRelations = isProjectingRelations(meta, qm.$project);\n\n    if (hasProjectRelations) {\n      const pipeline = this.dialect.aggregationPipeline(entity, qm);\n      if (isLogging()) {\n        log('findMany', entity.name, JSON.stringify(pipeline, null, 2));\n      }\n      documents = await this.collection(entity).aggregate<E>(pipeline, { session: this.session }).toArray();\n      documents = this.dialect.normalizeIds(meta, documents);\n      await this.findToManyRelations(entity, documents, qm.$project);\n    } else {\n      const cursor = this.collection(entity).find<E>({}, { session: this.session });\n\n      const filter = this.dialect.filter(entity, qm.$filter);\n      if (hasKeys(filter)) {\n        cursor.filter(filter);\n      }\n      const project = this.dialect.project(entity, qm.$project);\n      if (hasKeys(project)) {\n        cursor.project(project);\n      }\n      const sort = this.dialect.sort(entity, qm.$sort);\n      if (hasKeys(sort)) {\n        cursor.sort(sort);\n      }\n      if (qm.$skip) {\n        cursor.skip(qm.$skip);\n      }\n      if (qm.$limit) {\n        cursor.limit(qm.$limit);\n      }\n\n      log('findMany', entity.name, qm);\n\n      documents = await cursor.toArray();\n      documents = this.dialect.normalizeIds(meta, documents);\n    }\n\n    return documents;\n  }\n\n  override async insertMany<E>(entity: Type<E>, payload: E[]) {\n    if (!payload.length) {\n      return;\n    }\n\n    payload = clone(payload);\n\n    const meta = getMeta(entity);\n    const payloads = Array.isArray(payload) ? payload : [payload];\n    const persistables = getPersistables(meta, payload, 'onInsert');\n\n    log('insertMany', entity.name, persistables);\n\n    const { insertedIds } = await this.collection(entity).insertMany(persistables, { session: this.session });\n\n    const ids: IdValue<E>[] = Object.values(insertedIds);\n\n    for (const [index, it] of payloads.entries()) {\n      it[meta.id] = ids[index] as FieldValue<E>;\n    }\n\n    await this.insertRelations(entity, payloads);\n\n    return ids;\n  }\n\n  override async updateMany<E>(entity: Type<E>, qm: QueryCriteria<E>, payload: E) {\n    payload = clone(payload);\n    const meta = getMeta(entity);\n    const persistable = getPersistable(meta, payload, 'onUpdate');\n    const filter = this.dialect.filter(entity, qm.$filter);\n    const update = { $set: persistable };\n\n    log('updateMany', entity.name, filter, update);\n\n    const { matchedCount } = await this.collection(entity).updateMany(filter, update, {\n      session: this.session,\n    });\n\n    await this.updateRelations(entity, qm, payload);\n\n    return matchedCount;\n  }\n\n  override async deleteMany<E>(entity: Type<E>, qm: QueryCriteria<E>, opts: QueryOptions = {}) {\n    const meta = getMeta(entity);\n    const filter = this.dialect.filter(entity, qm.$filter);\n    log('deleteMany', entity.name, filter, opts);\n    const founds: E[] = await this.collection(entity)\n      .find(filter, {\n        projection: { _id: true },\n        session: this.session,\n      })\n      .toArray();\n    if (!founds.length) {\n      return 0;\n    }\n    const ids: IdValue<E>[] = this.dialect.normalizeIds(meta, founds).map((found) => found[meta.id]);\n    let changes: number;\n    if (meta.softDeleteKey && !opts.softDelete) {\n      const updateResult = await this.collection(entity).updateMany(\n        { _id: { $in: ids } },\n        { $set: { [meta.softDeleteKey]: meta.fields[meta.softDeleteKey].onDelete() } },\n        {\n          session: this.session,\n        }\n      );\n      changes = updateResult.matchedCount;\n    } else {\n      const deleteResult = await this.collection(entity).deleteMany(\n        { _id: { $in: ids } },\n        {\n          session: this.session,\n        }\n      );\n      changes = deleteResult.deletedCount;\n    }\n    await this.deleteRelations(entity, ids, opts);\n    return changes;\n  }\n\n  override get hasOpenTransaction() {\n    return this.session?.inTransaction();\n  }\n\n  collection<E>(entity: Type<E>) {\n    const meta = getMeta(entity);\n    return this.conn.db().collection(meta.name);\n  }\n\n  override async beginTransaction() {\n    if (this.session?.inTransaction()) {\n      throw new TypeError('pending transaction');\n    }\n    log('beginTransaction');\n    this.session = this.conn.startSession();\n    this.session.startTransaction();\n  }\n\n  override async commitTransaction() {\n    if (!this.session?.inTransaction()) {\n      throw new TypeError('not a pending transaction');\n    }\n    log('commitTransaction');\n    await this.session.commitTransaction();\n  }\n\n  override async rollbackTransaction() {\n    if (!this.session?.inTransaction()) {\n      throw new TypeError('not a pending transaction');\n    }\n    log('rollbackTransaction');\n    await this.session.abortTransaction();\n  }\n\n  override async release(force?: boolean) {\n    if (this.session?.inTransaction()) {\n      throw new TypeError('pending transaction');\n    }\n    await this.conn.close(force);\n  }\n}\n"]}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"mongodbQuerier.js","sourceRoot":"","sources":["../src/mongodbQuerier.ts"],"names":[],"mappings":"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","sourcesContent":["import { MongoClient, ClientSession } from 'mongodb';\nimport { Query, QueryOne, Type, QueryCriteria, QueryOptions, QuerySearch, IdValue, FieldValue, Logger } from '@uql/core/type';\nimport { BaseQuerier } from '@uql/core/querier';\nimport { getMeta } from '@uql/core/entity/decorator';\nimport { clone, getPersistable, getPersistables, hasKeys, isProjectingRelations } from '@uql/core/util';\n\nimport { MongoDialect } from './mongoDialect';\n\nexport class MongodbQuerier extends BaseQuerier {\n  private session: ClientSession;\n\n  constructor(readonly dialect: MongoDialect, readonly conn: MongoClient, readonly logger?: Logger) {\n    super();\n  }\n\n  override count<E>(entity: Type<E>, qm: QuerySearch<E> = {}) {\n    const filter = this.dialect.filter(entity, qm.$filter);\n    this.logger?.('count', entity.name, filter);\n    return this.collection(entity).countDocuments(filter, {\n      session: this.session,\n    });\n  }\n\n  override findOneById<E>(entity: Type<E>, id: IdValue<E>, qo: QueryOne<E>) {\n    return this.findOne(entity, { ...qo, $filter: id });\n  }\n\n  override async findMany<E>(entity: Type<E>, qm: Query<E>) {\n    const meta = getMeta(entity);\n\n    let documents: E[];\n    const hasProjectRelations = isProjectingRelations(meta, qm.$project);\n\n    if (hasProjectRelations) {\n      const pipeline = this.dialect.aggregationPipeline(entity, qm);\n      if (this.logger) {\n        this.logger('findMany', entity.name, JSON.stringify(pipeline, null, 2));\n      }\n      documents = await this.collection(entity).aggregate<E>(pipeline, { session: this.session }).toArray();\n      documents = this.dialect.normalizeIds(meta, documents);\n      await this.findToManyRelations(entity, documents, qm.$project);\n    } else {\n      const cursor = this.collection(entity).find<E>({}, { session: this.session });\n\n      const filter = this.dialect.filter(entity, qm.$filter);\n      if (hasKeys(filter)) {\n        cursor.filter(filter);\n      }\n      const project = this.dialect.project(entity, qm.$project);\n      if (hasKeys(project)) {\n        cursor.project(project);\n      }\n      const sort = this.dialect.sort(entity, qm.$sort);\n      if (hasKeys(sort)) {\n        cursor.sort(sort);\n      }\n      if (qm.$skip) {\n        cursor.skip(qm.$skip);\n      }\n      if (qm.$limit) {\n        cursor.limit(qm.$limit);\n      }\n\n      this.logger?.('findMany', entity.name, qm);\n\n      documents = await cursor.toArray();\n      documents = this.dialect.normalizeIds(meta, documents);\n    }\n\n    return documents;\n  }\n\n  override async insertMany<E>(entity: Type<E>, payload: E[]) {\n    if (!payload.length) {\n      return;\n    }\n\n    payload = clone(payload);\n\n    const meta = getMeta(entity);\n    const payloads = Array.isArray(payload) ? payload : [payload];\n    const persistables = getPersistables(meta, payload, 'onInsert');\n\n    this.logger?.('insertMany', entity.name, persistables);\n\n    const { insertedIds } = await this.collection(entity).insertMany(persistables, { session: this.session });\n\n    const ids: IdValue<E>[] = Object.values(insertedIds);\n\n    for (const [index, it] of payloads.entries()) {\n      it[meta.id] = ids[index] as FieldValue<E>;\n    }\n\n    await this.insertRelations(entity, payloads);\n\n    return ids;\n  }\n\n  override async updateMany<E>(entity: Type<E>, qm: QueryCriteria<E>, payload: E) {\n    payload = clone(payload);\n    const meta = getMeta(entity);\n    const persistable = getPersistable(meta, payload, 'onUpdate');\n    const filter = this.dialect.filter(entity, qm.$filter);\n    const update = { $set: persistable };\n\n    this.logger?.('updateMany', entity.name, filter, update);\n\n    const { matchedCount } = await this.collection(entity).updateMany(filter, update, {\n      session: this.session,\n    });\n\n    await this.updateRelations(entity, qm, payload);\n\n    return matchedCount;\n  }\n\n  override async deleteMany<E>(entity: Type<E>, qm: QueryCriteria<E>, opts: QueryOptions = {}) {\n    const meta = getMeta(entity);\n    const filter = this.dialect.filter(entity, qm.$filter);\n    this.logger?.('deleteMany', entity.name, filter, opts);\n    const founds: E[] = await this.collection(entity)\n      .find(filter, {\n        projection: { _id: true },\n        session: this.session,\n      })\n      .toArray();\n    if (!founds.length) {\n      return 0;\n    }\n    const ids: IdValue<E>[] = this.dialect.normalizeIds(meta, founds).map((found) => found[meta.id]);\n    let changes: number;\n    if (meta.softDeleteKey && !opts.softDelete) {\n      const updateResult = await this.collection(entity).updateMany(\n        { _id: { $in: ids } },\n        { $set: { [meta.softDeleteKey]: meta.fields[meta.softDeleteKey].onDelete() } },\n        {\n          session: this.session,\n        }\n      );\n      changes = updateResult.matchedCount;\n    } else {\n      const deleteResult = await this.collection(entity).deleteMany(\n        { _id: { $in: ids } },\n        {\n          session: this.session,\n        }\n      );\n      changes = deleteResult.deletedCount;\n    }\n    await this.deleteRelations(entity, ids, opts);\n    return changes;\n  }\n\n  override get hasOpenTransaction() {\n    return this.session?.inTransaction();\n  }\n\n  collection<E>(entity: Type<E>) {\n    const meta = getMeta(entity);\n    return this.conn.db().collection(meta.name);\n  }\n\n  override async beginTransaction() {\n    if (this.session?.inTransaction()) {\n      throw new TypeError('pending transaction');\n    }\n    this.logger?.('beginTransaction');\n    this.session = this.conn.startSession();\n    this.session.startTransaction();\n  }\n\n  override async commitTransaction() {\n    if (!this.session?.inTransaction()) {\n      throw new TypeError('not a pending transaction');\n    }\n    this.logger?.('commitTransaction');\n    await this.session.commitTransaction();\n  }\n\n  override async rollbackTransaction() {\n    if (!this.session?.inTransaction()) {\n      throw new TypeError('not a pending transaction');\n    }\n    this.logger?.('rollbackTransaction');\n    await this.session.abortTransaction();\n  }\n\n  override async release(force?: boolean) {\n    if (this.session?.inTransaction()) {\n      throw new TypeError('pending transaction');\n    }\n    await this.conn.close(force);\n  }\n}\n"]}
import { MongoClientOptions } from 'mongodb';
import { QuerierPool } from '@uql/core/type';
import { Logger, QuerierPool } from '@uql/core/type';
import { MongodbQuerier } from './mongodbQuerier';

@@ -7,6 +7,7 @@ export declare class MongodbQuerierPool implements QuerierPool<MongodbQuerier> {

readonly options?: MongoClientOptions;
readonly logger?: Logger;
private querier;
constructor(uri: string, options?: MongoClientOptions);
constructor(uri: string, options?: MongoClientOptions, logger?: Logger);
getQuerier(): Promise<MongodbQuerier>;
end(): Promise<void>;
}

@@ -6,6 +6,8 @@ "use strict";

const mongodbQuerier_1 = require("./mongodbQuerier");
const mongoDialect_1 = require("./mongoDialect");
class MongodbQuerierPool {
constructor(uri, options) {
constructor(uri, options, logger) {
this.uri = uri;
this.options = options;
this.logger = logger;
}

@@ -15,3 +17,3 @@ async getQuerier() {

const conn = await (0, mongodb_1.connect)(this.uri, this.options);
this.querier = new mongodbQuerier_1.MongodbQuerier(conn);
this.querier = new mongodbQuerier_1.MongodbQuerier(new mongoDialect_1.MongoDialect(), conn, this.logger);
}

@@ -26,2 +28,2 @@ return this.querier;

exports.MongodbQuerierPool = MongodbQuerierPool;
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibW9uZ29kYlF1ZXJpZXJQb29sLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vc3JjL21vbmdvZGJRdWVyaWVyUG9vbC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7QUFBQSxxQ0FBc0Q7QUFFdEQscURBQWtEO0FBRWxELE1BQWEsa0JBQWtCO0lBRzdCLFlBQXFCLEdBQVcsRUFBVyxPQUE0QjtRQUFsRCxRQUFHLEdBQUgsR0FBRyxDQUFRO1FBQVcsWUFBTyxHQUFQLE9BQU8sQ0FBcUI7SUFBRyxDQUFDO0lBRTNFLEtBQUssQ0FBQyxVQUFVO1FBQ2QsSUFBSSxDQUFDLElBQUksQ0FBQyxPQUFPLElBQUksQ0FBQyxJQUFJLENBQUMsT0FBTyxDQUFDLElBQUksQ0FBQyxXQUFXLEVBQUUsRUFBRTtZQUNyRCxNQUFNLElBQUksR0FBRyxNQUFNLElBQUEsaUJBQU8sRUFBQyxJQUFJLENBQUMsR0FBRyxFQUFFLElBQUksQ0FBQyxPQUFPLENBQUMsQ0FBQztZQUNuRCxJQUFJLENBQUMsT0FBTyxHQUFHLElBQUksK0JBQWMsQ0FBQyxJQUFJLENBQUMsQ0FBQztTQUN6QztRQUNELE9BQU8sSUFBSSxDQUFDLE9BQU8sQ0FBQztJQUN0QixDQUFDO0lBRUQsS0FBSyxDQUFDLEdBQUc7UUFDUCxNQUFNLElBQUksQ0FBQyxPQUFPLENBQUMsSUFBSSxDQUFDLEtBQUssRUFBRSxDQUFDO1FBQ2hDLE9BQU8sSUFBSSxDQUFDLE9BQU8sQ0FBQztJQUN0QixDQUFDO0NBQ0Y7QUFqQkQsZ0RBaUJDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgY29ubmVjdCwgTW9uZ29DbGllbnRPcHRpb25zIH0gZnJvbSAnbW9uZ29kYic7XG5pbXBvcnQgeyBRdWVyaWVyUG9vbCB9IGZyb20gJ0B1cWwvY29yZS90eXBlJztcbmltcG9ydCB7IE1vbmdvZGJRdWVyaWVyIH0gZnJvbSAnLi9tb25nb2RiUXVlcmllcic7XG5cbmV4cG9ydCBjbGFzcyBNb25nb2RiUXVlcmllclBvb2wgaW1wbGVtZW50cyBRdWVyaWVyUG9vbDxNb25nb2RiUXVlcmllcj4ge1xuICBwcml2YXRlIHF1ZXJpZXI6IE1vbmdvZGJRdWVyaWVyO1xuXG4gIGNvbnN0cnVjdG9yKHJlYWRvbmx5IHVyaTogc3RyaW5nLCByZWFkb25seSBvcHRpb25zPzogTW9uZ29DbGllbnRPcHRpb25zKSB7fVxuXG4gIGFzeW5jIGdldFF1ZXJpZXIoKSB7XG4gICAgaWYgKCF0aGlzLnF1ZXJpZXIgfHwgIXRoaXMucXVlcmllci5jb25uLmlzQ29ubmVjdGVkKCkpIHtcbiAgICAgIGNvbnN0IGNvbm4gPSBhd2FpdCBjb25uZWN0KHRoaXMudXJpLCB0aGlzLm9wdGlvbnMpO1xuICAgICAgdGhpcy5xdWVyaWVyID0gbmV3IE1vbmdvZGJRdWVyaWVyKGNvbm4pO1xuICAgIH1cbiAgICByZXR1cm4gdGhpcy5xdWVyaWVyO1xuICB9XG5cbiAgYXN5bmMgZW5kKCkge1xuICAgIGF3YWl0IHRoaXMucXVlcmllci5jb25uLmNsb3NlKCk7XG4gICAgZGVsZXRlIHRoaXMucXVlcmllcjtcbiAgfVxufVxuIl19
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibW9uZ29kYlF1ZXJpZXJQb29sLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vc3JjL21vbmdvZGJRdWVyaWVyUG9vbC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7QUFBQSxxQ0FBc0Q7QUFFdEQscURBQWtEO0FBQ2xELGlEQUE4QztBQUU5QyxNQUFhLGtCQUFrQjtJQUc3QixZQUFxQixHQUFXLEVBQVcsT0FBNEIsRUFBVyxNQUFlO1FBQTVFLFFBQUcsR0FBSCxHQUFHLENBQVE7UUFBVyxZQUFPLEdBQVAsT0FBTyxDQUFxQjtRQUFXLFdBQU0sR0FBTixNQUFNLENBQVM7SUFBRyxDQUFDO0lBRXJHLEtBQUssQ0FBQyxVQUFVO1FBQ2QsSUFBSSxDQUFDLElBQUksQ0FBQyxPQUFPLElBQUksQ0FBQyxJQUFJLENBQUMsT0FBTyxDQUFDLElBQUksQ0FBQyxXQUFXLEVBQUUsRUFBRTtZQUNyRCxNQUFNLElBQUksR0FBRyxNQUFNLElBQUEsaUJBQU8sRUFBQyxJQUFJLENBQUMsR0FBRyxFQUFFLElBQUksQ0FBQyxPQUFPLENBQUMsQ0FBQztZQUNuRCxJQUFJLENBQUMsT0FBTyxHQUFHLElBQUksK0JBQWMsQ0FBQyxJQUFJLDJCQUFZLEVBQUUsRUFBRSxJQUFJLEVBQUUsSUFBSSxDQUFDLE1BQU0sQ0FBQyxDQUFDO1NBQzFFO1FBQ0QsT0FBTyxJQUFJLENBQUMsT0FBTyxDQUFDO0lBQ3RCLENBQUM7SUFFRCxLQUFLLENBQUMsR0FBRztRQUNQLE1BQU0sSUFBSSxDQUFDLE9BQU8sQ0FBQyxJQUFJLENBQUMsS0FBSyxFQUFFLENBQUM7UUFDaEMsT0FBTyxJQUFJLENBQUMsT0FBTyxDQUFDO0lBQ3RCLENBQUM7Q0FDRjtBQWpCRCxnREFpQkMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBjb25uZWN0LCBNb25nb0NsaWVudE9wdGlvbnMgfSBmcm9tICdtb25nb2RiJztcbmltcG9ydCB7IExvZ2dlciwgUXVlcmllclBvb2wgfSBmcm9tICdAdXFsL2NvcmUvdHlwZSc7XG5pbXBvcnQgeyBNb25nb2RiUXVlcmllciB9IGZyb20gJy4vbW9uZ29kYlF1ZXJpZXInO1xuaW1wb3J0IHsgTW9uZ29EaWFsZWN0IH0gZnJvbSAnLi9tb25nb0RpYWxlY3QnO1xuXG5leHBvcnQgY2xhc3MgTW9uZ29kYlF1ZXJpZXJQb29sIGltcGxlbWVudHMgUXVlcmllclBvb2w8TW9uZ29kYlF1ZXJpZXI+IHtcbiAgcHJpdmF0ZSBxdWVyaWVyOiBNb25nb2RiUXVlcmllcjtcblxuICBjb25zdHJ1Y3RvcihyZWFkb25seSB1cmk6IHN0cmluZywgcmVhZG9ubHkgb3B0aW9ucz86IE1vbmdvQ2xpZW50T3B0aW9ucywgcmVhZG9ubHkgbG9nZ2VyPzogTG9nZ2VyKSB7fVxuXG4gIGFzeW5jIGdldFF1ZXJpZXIoKSB7XG4gICAgaWYgKCF0aGlzLnF1ZXJpZXIgfHwgIXRoaXMucXVlcmllci5jb25uLmlzQ29ubmVjdGVkKCkpIHtcbiAgICAgIGNvbnN0IGNvbm4gPSBhd2FpdCBjb25uZWN0KHRoaXMudXJpLCB0aGlzLm9wdGlvbnMpO1xuICAgICAgdGhpcy5xdWVyaWVyID0gbmV3IE1vbmdvZGJRdWVyaWVyKG5ldyBNb25nb0RpYWxlY3QoKSwgY29ubiwgdGhpcy5sb2dnZXIpO1xuICAgIH1cbiAgICByZXR1cm4gdGhpcy5xdWVyaWVyO1xuICB9XG5cbiAgYXN5bmMgZW5kKCkge1xuICAgIGF3YWl0IHRoaXMucXVlcmllci5jb25uLmNsb3NlKCk7XG4gICAgZGVsZXRlIHRoaXMucXVlcmllcjtcbiAgfVxufVxuIl19

@@ -6,3 +6,3 @@ {

"license": "MIT",
"version": "0.4.59",
"version": "0.4.60",
"main": "index.js",

@@ -20,3 +20,3 @@ "types": "index.d.ts",

"peerDependencies": {
"@uql/core": "^0.4.57"
"@uql/core": "^0.4.59"
},

@@ -26,3 +26,3 @@ "devDependencies": {

"@types/node": "^16.4.3",
"@uql/core": "^0.4.59",
"@uql/core": "^0.4.60",
"copyfiles": "^2.4.1",

@@ -29,0 +29,0 @@ "rimraf": "^3.0.2",

@@ -49,52 +49,24 @@ # [uql](https://uql.io) &middot; [![license](https://img.shields.io/badge/license-MIT-blue.svg)](https://github.com/impensables/uql/blob/master/LICENSE) [![tests](https://github.com/impensables/uql/actions/workflows/tests.yml/badge.svg)](https://github.com/impensables/uql) [![coverage status](https://coveralls.io/repos/impensables/uql/badge.svg?branch=master)](https://coveralls.io/r/impensables/uql?branch=master) [![npm version](https://badge.fury.io/js/%40uql%2Fcore.svg)](https://badge.fury.io/js/%40uql%2Fcore)

2. Install one of database packages according to your database:
2. Install one of the following packages according to your database:
- for `MySQL` (or `MariaDB`)
| Database | Package |
| ------------ | --------------- |
| `MySQL` | `@uql/mysql` |
| `MariaDB` | `@uql/maria` |
| `PostgreSQL` | `@uql/postgres` |
| `SQLite` | `@uql/sqlite` |
| `MongoDB` | `@uql/mongo` |
```sh
npm install @uql/mysql --save
```
E.g. for `PostgreSQL`
or with _yarn_
```sh
npm install @uql/postgres --save
```
```sh
yarn add @uql/mysql
```
or with _yarn_
- for `PostgreSQL`
```sh
yarn add @uql/postgres
```
```sh
npm install @uql/postgres --save
```
or with _yarn_
```sh
yarn add @uql/postgres
```
- for `SQLite`
```sh
npm install @uql/sqlite --save
```
or with _yarn_
```sh
yarn add @uql/sqlite
```
- for `MongoDB`
```sh
npm install @uql/mongo --save
```
or with _yarn_
```sh
yarn add @uql/mongo
```
3. Additionally, your `tsconfig.json` needs the following flags:

@@ -117,10 +89,11 @@

setOptions({
querierPool: new PgQuerierPool({
host: 'localhost',
user: 'theUser',
password: 'thePassword',
database: 'theDatabase',
}),
logging: true,
logger: console.log,
querierPool: new PgQuerierPool(
{
host: 'localhost',
user: 'theUser',
password: 'thePassword',
database: 'theDatabase',
},
console.log
),
});

@@ -127,0 +100,0 @@ ```

SocketSocket SOC 2 Logo

Product

  • Package Alerts
  • Integrations
  • Docs
  • Pricing
  • FAQ
  • Roadmap
  • Changelog

Packages

npm

Stay in touch

Get open source security insights delivered straight into your inbox.


  • Terms
  • Privacy
  • Security

Made with ⚡️ by Socket Inc