@uql/mongo
Advanced tools
Comparing version 0.4.16 to 0.4.17
@@ -10,4 +10,4 @@ import { MongoClient, ObjectId } from 'mongodb'; | ||
constructor(conn: MongoClient, dialect?: MongoDialect); | ||
insertMany<E>(entity: Type<E>, bodies: E[]): Promise<any[]>; | ||
updateMany<E>(entity: Type<E>, qm: QueryCriteria<E>, body: E): Promise<number>; | ||
insertMany<E>(entity: Type<E>, payload: E[]): Promise<any[]>; | ||
updateMany<E>(entity: Type<E>, qm: QueryCriteria<E>, payload: E): Promise<number>; | ||
findMany<E>(entity: Type<E>, qm: Query<E>): Promise<E[]>; | ||
@@ -14,0 +14,0 @@ findOneById<E>(entity: Type<E>, id: ObjectId, qo: QueryOne<E>): Promise<E>; |
@@ -16,7 +16,7 @@ "use strict"; | ||
} | ||
async insertMany(entity, bodies) { | ||
const persistables = bodies.map((body) => { | ||
const persistableProperties = util_1.filterPersistableProperties(entity, body); | ||
async insertMany(entity, payload) { | ||
const persistables = payload.map((it) => { | ||
const persistableProperties = util_1.filterPersistableProperties(entity, it); | ||
return persistableProperties.reduce((acc, key) => { | ||
acc[key] = body[key]; | ||
acc[key] = it[key]; | ||
return acc; | ||
@@ -29,6 +29,6 @@ }, {}); | ||
} | ||
async updateMany(entity, qm, body) { | ||
const persistableProperties = util_1.filterPersistableProperties(entity, body); | ||
async updateMany(entity, qm, payload) { | ||
const persistableProperties = util_1.filterPersistableProperties(entity, payload); | ||
const persistable = persistableProperties.reduce((acc, key) => { | ||
acc[key] = body[key]; | ||
acc[key] = payload[key]; | ||
return acc; | ||
@@ -157,7 +157,8 @@ }, {}); | ||
} | ||
doc[meta.id.property] = doc._id; | ||
delete doc._id; | ||
const res = doc; | ||
res[meta.id.property] = res._id; | ||
delete res._id; | ||
for (const relProp of Object.keys(meta.relations)) { | ||
const relOpts = meta.relations[relProp]; | ||
const relData = doc[relProp]; | ||
const relData = res[relProp]; | ||
if (typeof relData === 'object' && !(relData instanceof mongodb_1.ObjectId)) { | ||
@@ -168,4 +169,4 @@ const relMeta = decorator_1.getMeta(relOpts.entity()); | ||
} | ||
return doc; | ||
return res; | ||
} | ||
//# 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, OptionalId, ObjectId, UpdateQuery } from 'mongodb';\nimport { isDebug, log } from '@uql/core';\nimport { Query, EntityMeta, QueryOne, Type, QueryCriteria } from '@uql/core/type';\nimport { BaseQuerier } from '@uql/core/querier';\nimport { getMeta } from '@uql/core/entity/decorator';\nimport { filterPersistableProperties } from '@uql/core/entity/util';\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  async insertMany<E>(entity: Type<E>, bodies: E[]) {\n    const persistables = bodies.map((body) => {\n      const persistableProperties = filterPersistableProperties(entity, body);\n      return persistableProperties.reduce((acc, key) => {\n        acc[key] = body[key];\n        return acc;\n      }, {} as OptionalId<E>);\n    });\n\n    log(persistables);\n\n    const res = await this.collection(entity).insertMany(persistables, { session: this.session });\n\n    return Object.values(res.insertedIds);\n  }\n\n  async updateMany<E>(entity: Type<E>, qm: QueryCriteria<E>, body: E) {\n    const persistableProperties = filterPersistableProperties(entity, body);\n    const persistable = persistableProperties.reduce((acc, key) => {\n      acc[key] = body[key];\n      return acc;\n    }, {} as OptionalId<E>);\n\n    const filter = this.dialect.buildFilter(entity, qm.$filter);\n    const update = { $set: persistable };\n\n    log(filter, update);\n\n    const res = await this.collection(entity).updateMany(filter, update, {\n      session: this.session,\n    });\n\n    return res.modifiedCount;\n  }\n\n  async findMany<E>(entity: Type<E>, qm: Query<E>) {\n    const meta = getMeta(entity);\n\n    let documents: E[];\n\n    if (qm.$populate && Object.keys(qm.$populate).length) {\n      const pipeline = this.dialect.buildAggregationPipeline(entity, qm);\n      log(pipeline);\n      documents = await this.collection(entity).aggregate<E>(pipeline, { session: this.session }).toArray();\n      normalizeIds(documents, meta);\n      await this.populateToManyRelations(entity, documents, qm.$populate);\n    } else {\n      const cursor = this.collection(entity).find<E>({}, { session: this.session });\n\n      if (qm.$filter) {\n        const filter = this.dialect.buildFilter(entity, qm.$filter);\n        cursor.filter(filter);\n      }\n      if (qm.$project) {\n        cursor.project(qm.$project);\n      }\n      if (qm.$sort) {\n        cursor.sort(qm.$sort);\n      }\n      if (qm.$skip) {\n        cursor.skip(qm.$skip);\n      }\n      if (qm.$limit) {\n        cursor.limit(qm.$limit);\n      }\n\n      if (isDebug()) {\n        cursor.explain((err, result) => log(err, result));\n      }\n\n      documents = await cursor.toArray();\n      normalizeIds(documents, meta);\n    }\n\n    return documents;\n  }\n\n  findOneById<E>(entity: Type<E>, id: ObjectId, qo: QueryOne<E>) {\n    const meta = getMeta(entity);\n    return this.findOne<E>(entity, { ...qo, $filter: { [meta.id.name]: id } });\n  }\n\n  async deleteMany<E>(entity: Type<E>, qm: QueryCriteria<E>) {\n    const filter = this.dialect.buildFilter(entity, qm.$filter);\n    log(filter);\n    const res = await this.collection(entity).deleteMany(filter, {\n      session: this.session,\n    });\n    return res.deletedCount;\n  }\n\n  count<E>(entity: Type<E>, qm: QueryCriteria<E>) {\n    const filter = this.dialect.buildFilter(entity, qm.$filter);\n    log(filter);\n    return this.collection(entity).countDocuments(filter, {\n      session: this.session,\n    });\n  }\n\n  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  async beginTransaction() {\n    if (this.session?.inTransaction()) {\n      throw new TypeError('pending transaction');\n    }\n    log('startTransaction');\n    this.session = this.conn.startSession();\n    this.session.startTransaction();\n  }\n\n  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    this.session.endSession();\n  }\n\n  async rollbackTransaction() {\n    if (!this.session?.inTransaction()) {\n      throw new TypeError('not a pending transaction');\n    }\n    log('abortTransaction');\n    await this.session.abortTransaction();\n  }\n\n  async release() {\n    if (this.session?.inTransaction()) {\n      throw new TypeError('pending transaction');\n    }\n    return this.conn.close();\n  }\n}\n\nexport function normalizeIds<E>(docs: E | E[], meta: EntityMeta<E>) {\n  if (Array.isArray(docs)) {\n    for (const doc of docs) {\n      normalizeId<E>(doc, meta);\n    }\n  } else {\n    normalizeId<E>(docs, meta);\n  }\n}\n\nfunction normalizeId<E>(doc: E, meta: EntityMeta<E>) {\n  if (!doc) {\n    return;\n  }\n  doc[meta.id.property] = (doc as any)._id;\n  delete (doc as any)._id;\n  for (const relProp of Object.keys(meta.relations)) {\n    const relOpts = meta.relations[relProp];\n    const relData = doc[relProp];\n    if (typeof relData === 'object' && !(relData instanceof ObjectId)) {\n      const relMeta = getMeta(relOpts.entity());\n      normalizeIds(relData, relMeta);\n    }\n  }\n  return doc as E;\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, OptionalId, ObjectId, UpdateQuery } from 'mongodb';\nimport { isDebug, log } from '@uql/core';\nimport { Query, EntityMeta, QueryOne, Type, QueryCriteria } from '@uql/core/type';\nimport { BaseQuerier } from '@uql/core/querier';\nimport { getMeta } from '@uql/core/entity/decorator';\nimport { filterPersistableProperties } from '@uql/core/entity/util';\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  async insertMany<E>(entity: Type<E>, payload: E[]) {\n    const persistables = payload.map((it) => {\n      const persistableProperties = filterPersistableProperties(entity, it);\n      return persistableProperties.reduce((acc, key) => {\n        acc[key] = it[key];\n        return acc;\n      }, {} as OptionalId<E>);\n    });\n\n    log(persistables);\n\n    const res = await this.collection(entity).insertMany(persistables, { session: this.session });\n\n    return Object.values(res.insertedIds);\n  }\n\n  async updateMany<E>(entity: Type<E>, qm: QueryCriteria<E>, payload: E) {\n    const persistableProperties = filterPersistableProperties(entity, payload);\n    const persistable = persistableProperties.reduce((acc, key) => {\n      acc[key] = payload[key];\n      return acc;\n    }, {} as OptionalId<E>);\n\n    const filter = this.dialect.buildFilter(entity, qm.$filter);\n    const update = { $set: persistable };\n\n    log(filter, update);\n\n    const res = await this.collection(entity).updateMany(filter, update, {\n      session: this.session,\n    });\n\n    return res.modifiedCount;\n  }\n\n  async findMany<E>(entity: Type<E>, qm: Query<E>) {\n    const meta = getMeta(entity);\n\n    let documents: E[];\n\n    if (qm.$populate && Object.keys(qm.$populate).length) {\n      const pipeline = this.dialect.buildAggregationPipeline(entity, qm);\n      log(pipeline);\n      documents = await this.collection(entity).aggregate<E>(pipeline, { session: this.session }).toArray();\n      normalizeIds(documents, meta);\n      await this.populateToManyRelations(entity, documents, qm.$populate);\n    } else {\n      const cursor = this.collection(entity).find<E>({}, { session: this.session });\n\n      if (qm.$filter) {\n        const filter = this.dialect.buildFilter(entity, qm.$filter);\n        cursor.filter(filter);\n      }\n      if (qm.$project) {\n        cursor.project(qm.$project);\n      }\n      if (qm.$sort) {\n        cursor.sort(qm.$sort);\n      }\n      if (qm.$skip) {\n        cursor.skip(qm.$skip);\n      }\n      if (qm.$limit) {\n        cursor.limit(qm.$limit);\n      }\n\n      if (isDebug()) {\n        cursor.explain((err, result) => log(err, result));\n      }\n\n      documents = await cursor.toArray();\n      normalizeIds(documents, meta);\n    }\n\n    return documents;\n  }\n\n  findOneById<E>(entity: Type<E>, id: ObjectId, qo: QueryOne<E>) {\n    const meta = getMeta(entity);\n    return this.findOne<E>(entity, { ...qo, $filter: { [meta.id.name]: id } });\n  }\n\n  async deleteMany<E>(entity: Type<E>, qm: QueryCriteria<E>) {\n    const filter = this.dialect.buildFilter(entity, qm.$filter);\n    log(filter);\n    const res = await this.collection(entity).deleteMany(filter, {\n      session: this.session,\n    });\n    return res.deletedCount;\n  }\n\n  count<E>(entity: Type<E>, qm: QueryCriteria<E>) {\n    const filter = this.dialect.buildFilter(entity, qm.$filter);\n    log(filter);\n    return this.collection(entity).countDocuments(filter, {\n      session: this.session,\n    });\n  }\n\n  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  async beginTransaction() {\n    if (this.session?.inTransaction()) {\n      throw new TypeError('pending transaction');\n    }\n    log('startTransaction');\n    this.session = this.conn.startSession();\n    this.session.startTransaction();\n  }\n\n  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    this.session.endSession();\n  }\n\n  async rollbackTransaction() {\n    if (!this.session?.inTransaction()) {\n      throw new TypeError('not a pending transaction');\n    }\n    log('abortTransaction');\n    await this.session.abortTransaction();\n  }\n\n  async release() {\n    if (this.session?.inTransaction()) {\n      throw new TypeError('pending transaction');\n    }\n    return this.conn.close();\n  }\n}\n\nexport function normalizeIds<E>(docs: E | E[], meta: EntityMeta<E>) {\n  if (Array.isArray(docs)) {\n    for (const doc of docs) {\n      normalizeId<E>(doc, meta);\n    }\n  } else {\n    normalizeId<E>(docs, meta);\n  }\n}\n\nfunction normalizeId<E>(doc: E, meta: EntityMeta<E>) {\n  if (!doc) {\n    return;\n  }\n  const res = doc as OptionalId<E>;\n  res[meta.id.property] = res._id;\n  delete res._id;\n  for (const relProp of Object.keys(meta.relations)) {\n    const relOpts = meta.relations[relProp];\n    const relData = res[relProp];\n    if (typeof relData === 'object' && !(relData instanceof ObjectId)) {\n      const relMeta = getMeta(relOpts.entity());\n      normalizeIds(relData, relMeta);\n    }\n  }\n  return res as E;\n}\n"]} |
@@ -71,2 +71,2 @@ "use strict"; | ||
} | ||
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibW9uZ29EaWFsZWN0LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vc3JjL21vbmdvRGlhbGVjdC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7QUFBQSxxQ0FBZ0Q7QUFFaEQsMERBQXFEO0FBRXJELE1BQWEsWUFBWTtJQUN2QixXQUFXLENBQUksTUFBZSxFQUFFLFNBQXlCLEVBQUU7UUFDekQsTUFBTSxJQUFJLEdBQUcsbUJBQU8sQ0FBQyxNQUFNLENBQUMsQ0FBQztRQUU3QixPQUFPLE1BQU0sQ0FBQyxJQUFJLENBQUMsTUFBTSxDQUFDLENBQUMsTUFBTSxDQUFDLENBQUMsR0FBRyxFQUFFLElBQUksRUFBRSxFQUFFO1lBQzlDLE1BQU0sS0FBSyxHQUFHLE1BQU0sQ0FBQyxJQUFJLENBQUMsQ0FBQztZQUMzQixJQUFJLElBQUksS0FBSyxNQUFNLElBQUksSUFBSSxLQUFLLEtBQUssRUFBRTtnQkFDckMsR0FBRyxDQUFDLElBQUksQ0FBQyxHQUFHLEtBQUssQ0FBQyxHQUFHLENBQUMsQ0FBQyxRQUF3QixFQUFFLEVBQUUsQ0FBQyxJQUFJLENBQUMsV0FBVyxDQUFDLE1BQU0sRUFBRSxRQUFRLENBQUMsQ0FBQyxDQUFDO2FBQ3pGO2lCQUFNO2dCQUNMLE1BQU0sRUFBRSxHQUFHLEVBQUUsR0FBRyxFQUFFLEdBQUcsbUJBQW1CLENBQUMsSUFBSSxFQUFFLEtBQUssRUFBRSxJQUFJLENBQUMsQ0FBQztnQkFDNUQsR0FBRyxDQUFDLEdBQUcsQ0FBQyxHQUFHLEdBQUcsQ0FBQzthQUNoQjtZQUNELE9BQU8sR0FBRyxDQUFDO1FBQ2IsQ0FBQyxFQUFFLEVBQUUsQ0FBQyxDQUFDO0lBQ1QsQ0FBQztJQUVELHdCQUF3QixDQUFJLE1BQWUsRUFBRSxFQUFZO1FBQ3ZELE1BQU0sSUFBSSxHQUFHLG1CQUFPLENBQUMsTUFBTSxDQUFDLENBQUM7UUFFN0IsTUFBTSxRQUFRLEdBQWEsRUFBRSxDQUFDO1FBRTlCLElBQUksRUFBRSxDQUFDLE9BQU8sSUFBSSxNQUFNLENBQUMsSUFBSSxDQUFDLEVBQUUsQ0FBQyxPQUFPLENBQUMsQ0FBQyxNQUFNLEVBQUU7WUFDaEQsUUFBUSxDQUFDLElBQUksQ0FBQyxFQUFFLE1BQU0sRUFBRSxJQUFJLENBQUMsV0FBVyxDQUFDLE1BQU0sRUFBRSxFQUFFLENBQUMsT0FBTyxDQUFDLEVBQUUsQ0FBQyxDQUFDO1NBQ2pFO1FBRUQsS0FBSyxNQUFNLE1BQU0sSUFBSSxFQUFFLENBQUMsU0FBUyxFQUFFO1lBQ2pDLE1BQU0sT0FBTyxHQUFHLElBQUksQ0FBQyxTQUFTLENBQUMsTUFBTSxDQUFDLENBQUM7WUFDdkMsSUFBSSxDQUFDLE9BQU8sRUFBRTtnQkFDWixNQUFNLElBQUksU0FBUyxDQUFDLElBQUksTUFBTSxDQUFDLElBQUksSUFBSSxNQUFNLGtDQUFrQyxDQUFDLENBQUM7YUFDbEY7WUFDRCxJQUFJLE9BQU8sQ0FBQyxXQUFXLEtBQUssSUFBSSxJQUFJLE9BQU8sQ0FBQyxXQUFXLEtBQUssSUFBSSxFQUFFO2dCQUNoRSx5R0FBeUc7Z0JBQ3pHLFNBQVM7YUFDVjtZQUNELE1BQU0sU0FBUyxHQUFHLE9BQU8sQ0FBQyxNQUFNLEVBQUUsQ0FBQztZQUNuQyxNQUFNLE9BQU8sR0FBRyxtQkFBTyxDQUFDLFNBQVMsQ0FBQyxDQUFDO1lBRW5DLElBQUksT0FBTyxDQUFDLFdBQVcsS0FBSyxJQUFJLEVBQUU7Z0JBQ2hDLFFBQVEsQ0FBQyxJQUFJLENBQUM7b0JBQ1osT0FBTyxFQUFFO3dCQUNQLElBQUksRUFBRSxPQUFPLENBQUMsSUFBSTt3QkFDbEIsVUFBVSxFQUFFLE1BQU07d0JBQ2xCLFlBQVksRUFBRSxLQUFLO3dCQUNuQixFQUFFLEVBQUUsTUFBTTtxQkFDWDtpQkFDRixDQUFDLENBQUM7YUFDSjtpQkFBTTtnQkFDTCxNQUFNLFdBQVcsR0FBRyxPQUFPLENBQUMsUUFBa0IsQ0FBQztnQkFDL0MsUUFBUSxDQUFDLElBQUksQ0FBQztvQkFDWixPQUFPLEVBQUU7d0JBQ1AsSUFBSSxFQUFFLE9BQU8sQ0FBQyxJQUFJO3dCQUNsQixRQUFRLEVBQUUsQ0FBQyxFQUFFLE1BQU0sRUFBRSxFQUFFLENBQUMsV0FBVyxDQUFDLEVBQUUsRUFBRSxDQUFDLE9BQU8sQ0FBQyxJQUFJLENBQUMsRUFBRSxDQUFDLElBQUksQ0FBQyxFQUFFLEVBQUUsQ0FBQzt3QkFDbkUsRUFBRSxFQUFFLE1BQU07cUJBQ1g7aUJBQ0YsQ0FBQyxDQUFDO2FBQ0o7WUFFRCxRQUFRLENBQUMsSUFBSSxDQUFDLEVBQUUsT0FBTyxFQUFFLEVBQUUsSUFBSSxFQUFFLElBQUksTUFBTSxFQUFFLEVBQUUsMEJBQTBCLEVBQUUsSUFBSSxFQUFFLEVBQUUsQ0FBQyxDQUFDO1NBQ3RGO1FBRUQsT0FBTyxRQUFRLENBQUM7SUFDbEIsQ0FBQztDQUNGO0FBOURELG9DQThEQztBQUVELFNBQVMsbUJBQW1CLENBQUksR0FBVyxFQUFFLEdBQVEsRUFBRSxJQUFtQjtJQUN4RSxJQUFJLEdBQUcsS0FBSyxLQUFLLElBQUksR0FBRyxLQUFLLElBQUksQ0FBQyxFQUFFLENBQUMsUUFBUSxFQUFFO1FBQzdDLE1BQU0sUUFBUSxHQUFHLEdBQUcsWUFBWSxrQkFBUSxDQUFDLENBQUMsQ0FBQyxHQUFHLENBQUMsQ0FBQyxDQUFDLElBQUksa0JBQVEsQ0FBQyxHQUFHLENBQUMsQ0FBQztRQUNuRSxPQUFPLEVBQUUsR0FBRyxFQUFFLEtBQUssRUFBRSxHQUFHLEVBQUUsUUFBUSxFQUFFLENBQUM7S0FDdEM7SUFDRCxPQUFPLEVBQUUsR0FBRyxFQUFFLEdBQUcsRUFBRSxDQUFDO0FBQ3RCLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBGaWx0ZXJRdWVyeSwgT2JqZWN0SWQgfSBmcm9tICdtb25nb2RiJztcbmltcG9ydCB7IFF1ZXJ5RmlsdGVyLCBRdWVyeSwgRW50aXR5TWV0YSwgVHlwZSB9IGZyb20gJ0B1cWwvY29yZS90eXBlJztcbmltcG9ydCB7IGdldE1ldGEgfSBmcm9tICdAdXFsL2NvcmUvZW50aXR5L2RlY29yYXRvcic7XG5cbmV4cG9ydCBjbGFzcyBNb25nb0RpYWxlY3Qge1xuICBidWlsZEZpbHRlcjxFPihlbnRpdHk6IFR5cGU8RT4sIGZpbHRlcjogUXVlcnlGaWx0ZXI8RT4gPSB7fSk6IEZpbHRlclF1ZXJ5PEU+IHtcbiAgICBjb25zdCBtZXRhID0gZ2V0TWV0YShlbnRpdHkpO1xuXG4gICAgcmV0dXJuIE9iamVjdC5rZXlzKGZpbHRlcikucmVkdWNlKChhY2MsIHByb3ApID0+IHtcbiAgICAgIGNvbnN0IGVudHJ5ID0gZmlsdGVyW3Byb3BdO1xuICAgICAgaWYgKHByb3AgPT09ICckYW5kJyB8fCBwcm9wID09PSAnJG9yJykge1xuICAgICAgICBhY2NbcHJvcF0gPSBlbnRyeS5tYXAoKGZpbHRlckl0OiBRdWVyeUZpbHRlcjxFPikgPT4gdGhpcy5idWlsZEZpbHRlcihlbnRpdHksIGZpbHRlckl0KSk7XG4gICAgICB9IGVsc2Uge1xuICAgICAgICBjb25zdCB7IGtleSwgdmFsIH0gPSBvYnRhaW5GaW5hbEtleVZhbHVlKHByb3AsIGVudHJ5LCBtZXRhKTtcbiAgICAgICAgYWNjW2tleV0gPSB2YWw7XG4gICAgICB9XG4gICAgICByZXR1cm4gYWNjO1xuICAgIH0sIHt9KTtcbiAgfVxuXG4gIGJ1aWxkQWdncmVnYXRpb25QaXBlbGluZTxFPihlbnRpdHk6IFR5cGU8RT4sIHFtOiBRdWVyeTxFPik6IG9iamVjdFtdIHtcbiAgICBjb25zdCBtZXRhID0gZ2V0TWV0YShlbnRpdHkpO1xuXG4gICAgY29uc3QgcGlwZWxpbmU6IG9iamVjdFtdID0gW107XG5cbiAgICBpZiAocW0uJGZpbHRlciAmJiBPYmplY3Qua2V5cyhxbS4kZmlsdGVyKS5sZW5ndGgpIHtcbiAgICAgIHBpcGVsaW5lLnB1c2goeyAkbWF0Y2g6IHRoaXMuYnVpbGRGaWx0ZXIoZW50aXR5LCBxbS4kZmlsdGVyKSB9KTtcbiAgICB9XG5cbiAgICBmb3IgKGNvbnN0IHJlbEtleSBpbiBxbS4kcG9wdWxhdGUpIHtcbiAgICAgIGNvbnN0IHJlbE9wdHMgPSBtZXRhLnJlbGF0aW9uc1tyZWxLZXldO1xuICAgICAgaWYgKCFyZWxPcHRzKSB7XG4gICAgICAgIHRocm93IG5ldyBUeXBlRXJyb3IoYCcke2VudGl0eS5uYW1lfS4ke3JlbEtleX0nIGlzIG5vdCBhbm5vdGF0ZWQgYXMgYSByZWxhdGlvbmApO1xuICAgICAgfVxuICAgICAgaWYgKHJlbE9wdHMuY2FyZGluYWxpdHkgIT09ICdtMScgJiYgcmVsT3B0cy5jYXJkaW5hbGl0eSAhPT0gJzExJykge1xuICAgICAgICAvLyAnbWFueVRvTWFueScgYW5kICdvbmVUb01hbnknIHdpbGwgbmVlZCBtdWx0aXBsZSBxdWVyaWVzIChzbyB0aGV5IHNob3VsZCBiZSByZXNvbHZlZCBpbiBhIGhpZ2hlciBsYXllcilcbiAgICAgICAgY29udGludWU7XG4gICAgICB9XG4gICAgICBjb25zdCByZWxFbnRpdHkgPSByZWxPcHRzLmVudGl0eSgpO1xuICAgICAgY29uc3QgcmVsTWV0YSA9IGdldE1ldGEocmVsRW50aXR5KTtcblxuICAgICAgaWYgKHJlbE9wdHMuY2FyZGluYWxpdHkgPT09ICdtMScpIHtcbiAgICAgICAgcGlwZWxpbmUucHVzaCh7XG4gICAgICAgICAgJGxvb2t1cDoge1xuICAgICAgICAgICAgZnJvbTogcmVsTWV0YS5uYW1lLFxuICAgICAgICAgICAgbG9jYWxGaWVsZDogcmVsS2V5LFxuICAgICAgICAgICAgZm9yZWlnbkZpZWxkOiAnX2lkJyxcbiAgICAgICAgICAgIGFzOiByZWxLZXksXG4gICAgICAgICAgfSxcbiAgICAgICAgfSk7XG4gICAgICB9IGVsc2Uge1xuICAgICAgICBjb25zdCBtYXBwZWRCeUtleSA9IHJlbE9wdHMubWFwcGVkQnkgYXMgc3RyaW5nO1xuICAgICAgICBwaXBlbGluZS5wdXNoKHtcbiAgICAgICAgICAkbG9va3VwOiB7XG4gICAgICAgICAgICBmcm9tOiByZWxNZXRhLm5hbWUsXG4gICAgICAgICAgICBwaXBlbGluZTogW3sgJG1hdGNoOiB7IFttYXBwZWRCeUtleV06IHFtLiRmaWx0ZXJbbWV0YS5pZC5uYW1lXSB9IH1dLFxuICAgICAgICAgICAgYXM6IHJlbEtleSxcbiAgICAgICAgICB9LFxuICAgICAgICB9KTtcbiAgICAgIH1cblxuICAgICAgcGlwZWxpbmUucHVzaCh7ICR1bndpbmQ6IHsgcGF0aDogYCQke3JlbEtleX1gLCBwcmVzZXJ2ZU51bGxBbmRFbXB0eUFycmF5czogdHJ1ZSB9IH0pO1xuICAgIH1cblxuICAgIHJldHVybiBwaXBlbGluZTtcbiAgfVxufVxuXG5mdW5jdGlvbiBvYnRhaW5GaW5hbEtleVZhbHVlPEU+KGtleTogc3RyaW5nLCB2YWw6IGFueSwgbWV0YTogRW50aXR5TWV0YTxFPikge1xuICBpZiAoa2V5ID09PSAnX2lkJyB8fCBrZXkgPT09IG1ldGEuaWQucHJvcGVydHkpIHtcbiAgICBjb25zdCBvYmplY3RJZCA9IHZhbCBpbnN0YW5jZW9mIE9iamVjdElkID8gdmFsIDogbmV3IE9iamVjdElkKHZhbCk7XG4gICAgcmV0dXJuIHsga2V5OiAnX2lkJywgdmFsOiBvYmplY3RJZCB9O1xuICB9XG4gIHJldHVybiB7IGtleSwgdmFsIH07XG59XG4iXX0= | ||
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibW9uZ29EaWFsZWN0LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vc3JjL21vbmdvRGlhbGVjdC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7QUFBQSxxQ0FBZ0Q7QUFFaEQsMERBQXFEO0FBRXJELE1BQWEsWUFBWTtJQUN2QixXQUFXLENBQUksTUFBZSxFQUFFLFNBQXlCLEVBQUU7UUFDekQsTUFBTSxJQUFJLEdBQUcsbUJBQU8sQ0FBQyxNQUFNLENBQUMsQ0FBQztRQUU3QixPQUFPLE1BQU0sQ0FBQyxJQUFJLENBQUMsTUFBTSxDQUFDLENBQUMsTUFBTSxDQUFDLENBQUMsR0FBRyxFQUFFLElBQUksRUFBRSxFQUFFO1lBQzlDLE1BQU0sS0FBSyxHQUFHLE1BQU0sQ0FBQyxJQUFJLENBQUMsQ0FBQztZQUMzQixJQUFJLElBQUksS0FBSyxNQUFNLElBQUksSUFBSSxLQUFLLEtBQUssRUFBRTtnQkFDckMsR0FBRyxDQUFDLElBQUksQ0FBQyxHQUFHLEtBQUssQ0FBQyxHQUFHLENBQUMsQ0FBQyxRQUF3QixFQUFFLEVBQUUsQ0FBQyxJQUFJLENBQUMsV0FBVyxDQUFDLE1BQU0sRUFBRSxRQUFRLENBQUMsQ0FBQyxDQUFDO2FBQ3pGO2lCQUFNO2dCQUNMLE1BQU0sRUFBRSxHQUFHLEVBQUUsR0FBRyxFQUFFLEdBQUcsbUJBQW1CLENBQUMsSUFBSSxFQUFFLEtBQUssRUFBRSxJQUFJLENBQUMsQ0FBQztnQkFDNUQsR0FBRyxDQUFDLEdBQUcsQ0FBQyxHQUFHLEdBQUcsQ0FBQzthQUNoQjtZQUNELE9BQU8sR0FBRyxDQUFDO1FBQ2IsQ0FBQyxFQUFFLEVBQUUsQ0FBQyxDQUFDO0lBQ1QsQ0FBQztJQUVELHdCQUF3QixDQUFJLE1BQWUsRUFBRSxFQUFZO1FBQ3ZELE1BQU0sSUFBSSxHQUFHLG1CQUFPLENBQUMsTUFBTSxDQUFDLENBQUM7UUFFN0IsTUFBTSxRQUFRLEdBQWEsRUFBRSxDQUFDO1FBRTlCLElBQUksRUFBRSxDQUFDLE9BQU8sSUFBSSxNQUFNLENBQUMsSUFBSSxDQUFDLEVBQUUsQ0FBQyxPQUFPLENBQUMsQ0FBQyxNQUFNLEVBQUU7WUFDaEQsUUFBUSxDQUFDLElBQUksQ0FBQyxFQUFFLE1BQU0sRUFBRSxJQUFJLENBQUMsV0FBVyxDQUFDLE1BQU0sRUFBRSxFQUFFLENBQUMsT0FBTyxDQUFDLEVBQUUsQ0FBQyxDQUFDO1NBQ2pFO1FBRUQsS0FBSyxNQUFNLE1BQU0sSUFBSSxFQUFFLENBQUMsU0FBUyxFQUFFO1lBQ2pDLE1BQU0sT0FBTyxHQUFHLElBQUksQ0FBQyxTQUFTLENBQUMsTUFBTSxDQUFDLENBQUM7WUFDdkMsSUFBSSxDQUFDLE9BQU8sRUFBRTtnQkFDWixNQUFNLElBQUksU0FBUyxDQUFDLElBQUksTUFBTSxDQUFDLElBQUksSUFBSSxNQUFNLGtDQUFrQyxDQUFDLENBQUM7YUFDbEY7WUFDRCxJQUFJLE9BQU8sQ0FBQyxXQUFXLEtBQUssSUFBSSxJQUFJLE9BQU8sQ0FBQyxXQUFXLEtBQUssSUFBSSxFQUFFO2dCQUNoRSx5R0FBeUc7Z0JBQ3pHLFNBQVM7YUFDVjtZQUNELE1BQU0sU0FBUyxHQUFHLE9BQU8sQ0FBQyxNQUFNLEVBQUUsQ0FBQztZQUNuQyxNQUFNLE9BQU8sR0FBRyxtQkFBTyxDQUFDLFNBQVMsQ0FBQyxDQUFDO1lBRW5DLElBQUksT0FBTyxDQUFDLFdBQVcsS0FBSyxJQUFJLEVBQUU7Z0JBQ2hDLFFBQVEsQ0FBQyxJQUFJLENBQUM7b0JBQ1osT0FBTyxFQUFFO3dCQUNQLElBQUksRUFBRSxPQUFPLENBQUMsSUFBSTt3QkFDbEIsVUFBVSxFQUFFLE1BQU07d0JBQ2xCLFlBQVksRUFBRSxLQUFLO3dCQUNuQixFQUFFLEVBQUUsTUFBTTtxQkFDWDtpQkFDRixDQUFDLENBQUM7YUFDSjtpQkFBTTtnQkFDTCxNQUFNLFdBQVcsR0FBRyxPQUFPLENBQUMsUUFBa0IsQ0FBQztnQkFDL0MsUUFBUSxDQUFDLElBQUksQ0FBQztvQkFDWixPQUFPLEVBQUU7d0JBQ1AsSUFBSSxFQUFFLE9BQU8sQ0FBQyxJQUFJO3dCQUNsQixRQUFRLEVBQUUsQ0FBQyxFQUFFLE1BQU0sRUFBRSxFQUFFLENBQUMsV0FBVyxDQUFDLEVBQUUsRUFBRSxDQUFDLE9BQU8sQ0FBQyxJQUFJLENBQUMsRUFBRSxDQUFDLElBQUksQ0FBQyxFQUFFLEVBQUUsQ0FBQzt3QkFDbkUsRUFBRSxFQUFFLE1BQU07cUJBQ1g7aUJBQ0YsQ0FBQyxDQUFDO2FBQ0o7WUFFRCxRQUFRLENBQUMsSUFBSSxDQUFDLEVBQUUsT0FBTyxFQUFFLEVBQUUsSUFBSSxFQUFFLElBQUksTUFBTSxFQUFFLEVBQUUsMEJBQTBCLEVBQUUsSUFBSSxFQUFFLEVBQUUsQ0FBQyxDQUFDO1NBQ3RGO1FBRUQsT0FBTyxRQUFRLENBQUM7SUFDbEIsQ0FBQztDQUNGO0FBOURELG9DQThEQztBQUVELFNBQVMsbUJBQW1CLENBQUksR0FBVyxFQUFFLEdBQXNCLEVBQUUsSUFBbUI7SUFDdEYsSUFBSSxHQUFHLEtBQUssS0FBSyxJQUFJLEdBQUcsS0FBSyxJQUFJLENBQUMsRUFBRSxDQUFDLFFBQVEsRUFBRTtRQUM3QyxNQUFNLFFBQVEsR0FBRyxHQUFHLFlBQVksa0JBQVEsQ0FBQyxDQUFDLENBQUMsR0FBRyxDQUFDLENBQUMsQ0FBQyxJQUFJLGtCQUFRLENBQUMsR0FBRyxDQUFDLENBQUM7UUFDbkUsT0FBTyxFQUFFLEdBQUcsRUFBRSxLQUFLLEVBQUUsR0FBRyxFQUFFLFFBQVEsRUFBRSxDQUFDO0tBQ3RDO0lBQ0QsT0FBTyxFQUFFLEdBQUcsRUFBRSxHQUFHLEVBQUUsQ0FBQztBQUN0QixDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgRmlsdGVyUXVlcnksIE9iamVjdElkIH0gZnJvbSAnbW9uZ29kYic7XG5pbXBvcnQgeyBRdWVyeUZpbHRlciwgUXVlcnksIEVudGl0eU1ldGEsIFR5cGUgfSBmcm9tICdAdXFsL2NvcmUvdHlwZSc7XG5pbXBvcnQgeyBnZXRNZXRhIH0gZnJvbSAnQHVxbC9jb3JlL2VudGl0eS9kZWNvcmF0b3InO1xuXG5leHBvcnQgY2xhc3MgTW9uZ29EaWFsZWN0IHtcbiAgYnVpbGRGaWx0ZXI8RT4oZW50aXR5OiBUeXBlPEU+LCBmaWx0ZXI6IFF1ZXJ5RmlsdGVyPEU+ID0ge30pOiBGaWx0ZXJRdWVyeTxFPiB7XG4gICAgY29uc3QgbWV0YSA9IGdldE1ldGEoZW50aXR5KTtcblxuICAgIHJldHVybiBPYmplY3Qua2V5cyhmaWx0ZXIpLnJlZHVjZSgoYWNjLCBwcm9wKSA9PiB7XG4gICAgICBjb25zdCBlbnRyeSA9IGZpbHRlcltwcm9wXTtcbiAgICAgIGlmIChwcm9wID09PSAnJGFuZCcgfHwgcHJvcCA9PT0gJyRvcicpIHtcbiAgICAgICAgYWNjW3Byb3BdID0gZW50cnkubWFwKChmaWx0ZXJJdDogUXVlcnlGaWx0ZXI8RT4pID0+IHRoaXMuYnVpbGRGaWx0ZXIoZW50aXR5LCBmaWx0ZXJJdCkpO1xuICAgICAgfSBlbHNlIHtcbiAgICAgICAgY29uc3QgeyBrZXksIHZhbCB9ID0gb2J0YWluRmluYWxLZXlWYWx1ZShwcm9wLCBlbnRyeSwgbWV0YSk7XG4gICAgICAgIGFjY1trZXldID0gdmFsO1xuICAgICAgfVxuICAgICAgcmV0dXJuIGFjYztcbiAgICB9LCB7fSk7XG4gIH1cblxuICBidWlsZEFnZ3JlZ2F0aW9uUGlwZWxpbmU8RT4oZW50aXR5OiBUeXBlPEU+LCBxbTogUXVlcnk8RT4pOiBvYmplY3RbXSB7XG4gICAgY29uc3QgbWV0YSA9IGdldE1ldGEoZW50aXR5KTtcblxuICAgIGNvbnN0IHBpcGVsaW5lOiBvYmplY3RbXSA9IFtdO1xuXG4gICAgaWYgKHFtLiRmaWx0ZXIgJiYgT2JqZWN0LmtleXMocW0uJGZpbHRlcikubGVuZ3RoKSB7XG4gICAgICBwaXBlbGluZS5wdXNoKHsgJG1hdGNoOiB0aGlzLmJ1aWxkRmlsdGVyKGVudGl0eSwgcW0uJGZpbHRlcikgfSk7XG4gICAgfVxuXG4gICAgZm9yIChjb25zdCByZWxLZXkgaW4gcW0uJHBvcHVsYXRlKSB7XG4gICAgICBjb25zdCByZWxPcHRzID0gbWV0YS5yZWxhdGlvbnNbcmVsS2V5XTtcbiAgICAgIGlmICghcmVsT3B0cykge1xuICAgICAgICB0aHJvdyBuZXcgVHlwZUVycm9yKGAnJHtlbnRpdHkubmFtZX0uJHtyZWxLZXl9JyBpcyBub3QgYW5ub3RhdGVkIGFzIGEgcmVsYXRpb25gKTtcbiAgICAgIH1cbiAgICAgIGlmIChyZWxPcHRzLmNhcmRpbmFsaXR5ICE9PSAnbTEnICYmIHJlbE9wdHMuY2FyZGluYWxpdHkgIT09ICcxMScpIHtcbiAgICAgICAgLy8gJ21hbnlUb01hbnknIGFuZCAnb25lVG9NYW55JyB3aWxsIG5lZWQgbXVsdGlwbGUgcXVlcmllcyAoc28gdGhleSBzaG91bGQgYmUgcmVzb2x2ZWQgaW4gYSBoaWdoZXIgbGF5ZXIpXG4gICAgICAgIGNvbnRpbnVlO1xuICAgICAgfVxuICAgICAgY29uc3QgcmVsRW50aXR5ID0gcmVsT3B0cy5lbnRpdHkoKTtcbiAgICAgIGNvbnN0IHJlbE1ldGEgPSBnZXRNZXRhKHJlbEVudGl0eSk7XG5cbiAgICAgIGlmIChyZWxPcHRzLmNhcmRpbmFsaXR5ID09PSAnbTEnKSB7XG4gICAgICAgIHBpcGVsaW5lLnB1c2goe1xuICAgICAgICAgICRsb29rdXA6IHtcbiAgICAgICAgICAgIGZyb206IHJlbE1ldGEubmFtZSxcbiAgICAgICAgICAgIGxvY2FsRmllbGQ6IHJlbEtleSxcbiAgICAgICAgICAgIGZvcmVpZ25GaWVsZDogJ19pZCcsXG4gICAgICAgICAgICBhczogcmVsS2V5LFxuICAgICAgICAgIH0sXG4gICAgICAgIH0pO1xuICAgICAgfSBlbHNlIHtcbiAgICAgICAgY29uc3QgbWFwcGVkQnlLZXkgPSByZWxPcHRzLm1hcHBlZEJ5IGFzIHN0cmluZztcbiAgICAgICAgcGlwZWxpbmUucHVzaCh7XG4gICAgICAgICAgJGxvb2t1cDoge1xuICAgICAgICAgICAgZnJvbTogcmVsTWV0YS5uYW1lLFxuICAgICAgICAgICAgcGlwZWxpbmU6IFt7ICRtYXRjaDogeyBbbWFwcGVkQnlLZXldOiBxbS4kZmlsdGVyW21ldGEuaWQubmFtZV0gfSB9XSxcbiAgICAgICAgICAgIGFzOiByZWxLZXksXG4gICAgICAgICAgfSxcbiAgICAgICAgfSk7XG4gICAgICB9XG5cbiAgICAgIHBpcGVsaW5lLnB1c2goeyAkdW53aW5kOiB7IHBhdGg6IGAkJHtyZWxLZXl9YCwgcHJlc2VydmVOdWxsQW5kRW1wdHlBcnJheXM6IHRydWUgfSB9KTtcbiAgICB9XG5cbiAgICByZXR1cm4gcGlwZWxpbmU7XG4gIH1cbn1cblxuZnVuY3Rpb24gb2J0YWluRmluYWxLZXlWYWx1ZTxFPihrZXk6IHN0cmluZywgdmFsOiBzdHJpbmcgfCBPYmplY3RJZCwgbWV0YTogRW50aXR5TWV0YTxFPikge1xuICBpZiAoa2V5ID09PSAnX2lkJyB8fCBrZXkgPT09IG1ldGEuaWQucHJvcGVydHkpIHtcbiAgICBjb25zdCBvYmplY3RJZCA9IHZhbCBpbnN0YW5jZW9mIE9iamVjdElkID8gdmFsIDogbmV3IE9iamVjdElkKHZhbCk7XG4gICAgcmV0dXJuIHsga2V5OiAnX2lkJywgdmFsOiBvYmplY3RJZCB9O1xuICB9XG4gIHJldHVybiB7IGtleSwgdmFsIH07XG59XG4iXX0= |
@@ -5,3 +5,3 @@ { | ||
"license": "MIT", | ||
"version": "0.4.16", | ||
"version": "0.4.17", | ||
"main": "index.js", | ||
@@ -19,8 +19,8 @@ "types": "index.d.ts", | ||
"peerDependencies": { | ||
"@uql/core": "^0.4.13" | ||
"@uql/core": "^0.4.16" | ||
}, | ||
"devDependencies": { | ||
"@types/mongodb": "^3.6.17", | ||
"@types/node": "^15.6.1", | ||
"@uql/core": "^0.4.16", | ||
"@types/node": "^15.12.0", | ||
"@uql/core": "^0.4.17", | ||
"copyfiles": "^2.4.1", | ||
@@ -27,0 +27,0 @@ "rimraf": "^3.0.2", |
@@ -267,13 +267,13 @@ [![build status](https://travis-ci.org/impensables/uql.svg?branch=master)](https://travis-ci.org/impensables/uql?branch=master) | ||
@Transactional() | ||
async confirmAction(payload: Confirmation, @InjectQuerier() querier?: Querier) { | ||
if (payload.type === 'register') { | ||
async confirmAction(confirmation: Confirmation, @InjectQuerier() querier?: Querier) { | ||
if (confirmation.type === 'register') { | ||
await querier.insertOne(User, { | ||
name: payload.name, | ||
email: payload.email, | ||
password: payload.password, | ||
name: confirmation.name, | ||
email: confirmation.email, | ||
password: confirmation.password, | ||
}); | ||
} else { | ||
await querier.updateOneById(User, { password: payload.password }, payload.userId); | ||
await querier.updateOneById(User, { password: confirmation.password }, confirmation.userId); | ||
} | ||
await querier.updateOneById(Confirmation, { status: CONFIRM_STATUS_VERIFIED }, payload.id); | ||
await querier.updateOneById(Confirmation, { status: CONFIRM_STATUS_VERIFIED }, confirmation.id); | ||
} | ||
@@ -307,16 +307,16 @@ } | ||
async function confirmAction(payload: Confirmation) { | ||
async function confirmAction(confirmation: Confirmation) { | ||
const querier = await getQuerier(); | ||
try { | ||
await querier.beginTransaction(); | ||
if (payload.action === 'signup') { | ||
if (confirmation.action === 'signup') { | ||
await querier.insertOne(User, { | ||
name: payload.name, | ||
email: payload.email, | ||
password: payload.password, | ||
name: confirmation.name, | ||
email: confirmation.email, | ||
password: confirmation.password, | ||
}); | ||
} else { | ||
await querier.updateOneById(User, { password: payload.password }, payload.userId); | ||
await querier.updateOneById(User, { password: confirmation.password }, confirmation.userId); | ||
} | ||
await querier.updateOneById(Confirmation, { status: CONFIRM_STATUS_VERIFIED }, payload.id); | ||
await querier.updateOneById(Confirmation, { status: CONFIRM_STATUS_VERIFIED }, confirmation.id); | ||
await querier.commitTransaction(); | ||
@@ -366,2 +366,14 @@ } catch (error) { | ||
exclude: [Confirmation], | ||
// `extendQuery` callback allows to extend all then queries that are requested to the API, | ||
// so it is a good place to add additional filters to the queries (like for multi tenant apps) | ||
extendQuery<E>(type: Type<E>, qm: Query<E>, req: Request): Query<E> { | ||
qm.limit = obtainValidLimit(qm.limit); | ||
const prefix = qm.populate && Object.keys(qm.populate).length ? type.name + '.' : ''; | ||
qm.filter = { | ||
...qm.filter, | ||
// ensure the user can only see the data belonging to his own company for security | ||
[`${prefix}companyId`]: req.identity.companyId, | ||
}; | ||
return qm; | ||
} | ||
}) | ||
@@ -368,0 +380,0 @@ ); |
50980
303
421