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.20 to 0.4.21

4

mongodbQuerier.d.ts

@@ -11,7 +11,7 @@ import { MongoClient, ObjectId } from 'mongodb';

insertMany<E>(entity: Type<E>, payload: E[]): Promise<any[]>;
updateMany<E>(entity: Type<E>, qm: QueryCriteria<E>, payload: E): Promise<number>;
updateMany<E>(entity: Type<E>, payload: E, qm: QueryCriteria<E>): Promise<number>;
findMany<E>(entity: Type<E>, qm: Query<E>): Promise<E[]>;
findOneById<E>(entity: Type<E>, id: ObjectId, qo: QueryOne<E>): Promise<E>;
deleteMany<E>(entity: Type<E>, qm: QueryCriteria<E>): Promise<number>;
count<E>(entity: Type<E>, qm: QueryCriteria<E>): Promise<number>;
count<E>(entity: Type<E>, qm?: QueryCriteria<E>): Promise<number>;
get hasOpenTransaction(): boolean;

@@ -18,0 +18,0 @@ collection<E>(entity: Type<E>): import("mongodb").Collection<any>;

@@ -18,14 +18,39 @@ "use strict";

async insertMany(entity, payload) {
const persistables = payload.map((it) => {
const persistableProperties = util_1.filterPersistableProperties(entity, it);
return persistableProperties.reduce((acc, key) => {
acc[key] = it[key];
return acc;
}, {});
if (payload.length === 0) {
return;
}
payload = util_2.clone(payload);
const meta = decorator_1.getMeta(entity);
const payloads = Array.isArray(payload) ? payload : [payload];
const onInserts = util_2.objectKeys(meta.properties).filter((col) => meta.properties[col].onInsert);
onInserts.forEach((key) => {
payloads.forEach((it) => {
if (it[key] === undefined) {
it[key] = meta.properties[key].onInsert();
}
});
});
core_1.log(persistables);
const res = await this.collection(entity).insertMany(persistables, { session: this.session });
return Object.values(res.insertedIds);
const persistableProperties = util_1.filterPersistableProperties(entity, payloads[0]);
const persistables = payloads.map((it) => persistableProperties.reduce((acc, key) => {
acc[key] = it[key];
return acc;
}, {}));
core_1.log('insertMany', entity.name, persistables);
const { insertedIds } = await this.collection(entity).insertMany(persistables, { session: this.session });
const ids = Object.values(insertedIds);
payloads.forEach((it, index) => {
it[meta.id.property] = ids[index];
});
await this.insertRelations(entity, payloads);
return ids;
}
async updateMany(entity, qm, payload) {
async updateMany(entity, payload, qm) {
payload = util_2.clone(payload);
const meta = decorator_1.getMeta(entity);
const onUpdates = util_2.objectKeys(meta.properties).filter((col) => meta.properties[col].onUpdate);
onUpdates.forEach((key) => {
if (payload[key] === undefined) {
payload[key] = meta.properties[key].onUpdate();
}
});
const persistableProperties = util_1.filterPersistableProperties(entity, payload);

@@ -36,9 +61,10 @@ const persistable = persistableProperties.reduce((acc, key) => {

}, {});
const filter = this.dialect.buildFilter(entity, qm.$filter);
const filter = this.dialect.where(entity, qm.$filter);
const update = { $set: persistable };
core_1.log(filter, update);
const res = await this.collection(entity).updateMany(filter, update, {
core_1.log('updateMany', entity.name, filter, update);
const { modifiedCount } = await this.collection(entity).updateMany(filter, update, {
session: this.session,
});
return res.modifiedCount;
await this.updateRelations(entity, payload, qm);
return modifiedCount;
}

@@ -49,4 +75,4 @@ async findMany(entity, qm) {

if (util_2.hasKeys(qm.$populate)) {
const pipeline = this.dialect.buildAggregationPipeline(entity, qm);
core_1.log(pipeline);
const pipeline = this.dialect.aggregationPipeline(entity, qm);
core_1.log('findMany', entity.name, JSON.stringify(pipeline, null, 2));
documents = await this.collection(entity).aggregate(pipeline, { session: this.session }).toArray();

@@ -59,7 +85,7 @@ normalizeIds(documents, meta);

if (qm.$filter) {
const filter = this.dialect.buildFilter(entity, qm.$filter);
const filter = this.dialect.where(entity, qm.$filter);
cursor.filter(filter);
}
if (qm.$project) {
cursor.project(qm.$project);
cursor.project(this.dialect.project(qm.$project));
}

@@ -75,5 +101,3 @@ if (qm.$sort) {

}
if (core_1.isDebug()) {
cursor.explain((err, result) => core_1.log(err, result));
}
core_1.log('findMany', entity.name, qm);
documents = await cursor.toArray();

@@ -89,4 +113,4 @@ normalizeIds(documents, meta);

async deleteMany(entity, qm) {
const filter = this.dialect.buildFilter(entity, qm.$filter);
core_1.log(filter);
const filter = this.dialect.where(entity, qm.$filter);
core_1.log('deleteMany', entity.name, filter);
const res = await this.collection(entity).deleteMany(filter, {

@@ -97,5 +121,5 @@ session: this.session,

}
count(entity, qm) {
const filter = this.dialect.buildFilter(entity, qm.$filter);
core_1.log(filter);
count(entity, qm = {}) {
const filter = this.dialect.where(entity, qm.$filter);
core_1.log('count', entity.name, filter);
return this.collection(entity).countDocuments(filter, {

@@ -118,3 +142,3 @@ session: this.session,

}
core_1.log('startTransaction');
core_1.log('beginTransaction');
this.session = this.conn.startSession();

@@ -137,3 +161,3 @@ this.session.startTransaction();

}
core_1.log('abortTransaction');
core_1.log('rollbackTransaction');
await this.session.abortTransaction();

@@ -152,5 +176,3 @@ }

if (Array.isArray(docs)) {
for (const doc of docs) {
normalizeId(doc, meta);
}
docs.forEach((doc) => normalizeId(doc, meta));
}

@@ -169,3 +191,3 @@ else {

delete res._id;
for (const relProp of util_2.objectKeys(meta.relations)) {
util_2.objectKeys(meta.relations).forEach((relProp) => {
const relOpts = meta.relations[relProp];

@@ -177,5 +199,5 @@ const relData = res[relProp];

}
}
});
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 { hasKeys, objectKeys } from '@uql/core/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 (hasKeys(qm.$populate)) {\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 objectKeys(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"]}
//# 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 { clone, hasKeys, objectKeys } from '@uql/core/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    if (payload.length === 0) {\n      return;\n    }\n\n    payload = clone(payload);\n\n    const meta = getMeta(entity);\n    const payloads = Array.isArray(payload) ? payload : [payload];\n    const onInserts = objectKeys(meta.properties).filter((col) => meta.properties[col].onInsert);\n\n    onInserts.forEach((key) => {\n      payloads.forEach((it) => {\n        if (it[key] === undefined) {\n          it[key] = meta.properties[key].onInsert();\n        }\n      });\n    });\n\n    const persistableProperties = filterPersistableProperties(entity, payloads[0]);\n\n    const persistables = payloads.map((it) =>\n      persistableProperties.reduce((acc, key) => {\n        acc[key] = it[key];\n        return acc;\n      }, {} as OptionalId<E>)\n    );\n\n    log('insertMany', entity.name, persistables);\n\n    const { insertedIds } = await this.collection(entity).insertMany(persistables, { session: this.session });\n\n    const ids = Object.values(insertedIds);\n\n    payloads.forEach((it, index) => {\n      it[meta.id.property] = ids[index];\n    });\n\n    await this.insertRelations(entity, payloads);\n\n    return ids;\n  }\n\n  async updateMany<E>(entity: Type<E>, payload: E, qm: QueryCriteria<E>) {\n    payload = clone(payload);\n\n    const meta = getMeta(entity);\n    const onUpdates = objectKeys(meta.properties).filter((col) => meta.properties[col].onUpdate);\n\n    onUpdates.forEach((key) => {\n      if (payload[key] === undefined) {\n        payload[key] = meta.properties[key].onUpdate();\n      }\n    });\n\n    const persistableProperties = filterPersistableProperties(entity, payload);\n\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.where(entity, qm.$filter);\n    const update = { $set: persistable };\n\n    log('updateMany', entity.name, filter, update);\n\n    const { modifiedCount } = await this.collection(entity).updateMany(filter, update, {\n      session: this.session,\n    });\n\n    await this.updateRelations(entity, payload, qm);\n\n    return 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 (hasKeys(qm.$populate)) {\n      const pipeline = this.dialect.aggregationPipeline(entity, qm);\n      log('findMany', entity.name, JSON.stringify(pipeline, null, 2));\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.where(entity, qm.$filter);\n        cursor.filter(filter);\n      }\n      if (qm.$project) {\n        cursor.project(this.dialect.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      log('findMany', entity.name, qm);\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.where(entity, qm.$filter);\n    log('deleteMany', entity.name, 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.where(entity, qm.$filter);\n    log('count', entity.name, 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('beginTransaction');\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('rollbackTransaction');\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    docs.forEach((doc) => normalizeId(doc, meta));\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  objectKeys(meta.relations).forEach((relProp) => {\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"]}
import { FilterQuery } from 'mongodb';
import { QueryFilter, Query, Type } from '@uql/core/type';
import { QueryFilter, Query, Type, QueryProject, QueryProjectProperties } from '@uql/core/type';
export declare class MongoDialect {
buildFilter<E>(entity: Type<E>, filter?: QueryFilter<E>): FilterQuery<E>;
buildAggregationPipeline<E>(entity: Type<E>, qm: Query<E>): object[];
where<E>(entity: Type<E>, filter?: QueryFilter<E>): FilterQuery<E>;
project<E>(project: QueryProject<E>): QueryProjectProperties<E>;
aggregationPipeline<E>(entity: Type<E>, qm: Query<E>): object[];
}

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

class MongoDialect {
buildFilter(entity, filter = {}) {
where(entity, filter = {}) {
const meta = decorator_1.getMeta(entity);
return util_1.objectKeys(filter).reduce((acc, prop) => {
const entry = filter[prop];
const value = filter[prop];
if (prop === '$and' || prop === '$or') {
acc[prop] = entry.map((filterIt) => this.buildFilter(entity, filterIt));
acc[prop] = value.map((filterIt) => this.where(entity, filterIt));
}
else {
const { key, val } = obtainFinalKeyValue(prop, entry, meta);
const { key, val } = obtainFinalKeyValue(prop, value, meta);
acc[key] = val;

@@ -23,7 +23,16 @@ }

}
buildAggregationPipeline(entity, qm) {
project(project) {
if (Array.isArray(project)) {
return project.reduce((acc, it) => {
acc[it] = true;
return acc;
}, {});
}
return project;
}
aggregationPipeline(entity, qm) {
const meta = decorator_1.getMeta(entity);
const pipeline = [];
if (util_1.hasKeys(qm.$filter)) {
pipeline.push({ $match: this.buildFilter(entity, qm.$filter) });
pipeline.push({ $match: this.where(entity, qm.$filter) });
}

@@ -45,3 +54,3 @@ for (const relKey in qm.$populate) {

from: relMeta.name,
localField: relKey,
localField: relOpts.references[0].source,
foreignField: '_id',

@@ -53,7 +62,7 @@ as: relKey,

else {
const mappedByKey = relOpts.mappedBy;
const prop = relOpts.mappedBy ? relOpts.references[0].target : relOpts.references[0].source;
pipeline.push({
$lookup: {
from: relMeta.name,
pipeline: [{ $match: { [mappedByKey]: qm.$filter[meta.id.name] } }],
pipeline: [{ $match: { [prop]: qm.$filter[meta.id.property] } }],
as: relKey,

@@ -76,2 +85,2 @@ },

}
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibW9uZ29EaWFsZWN0LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vc3JjL21vbmdvRGlhbGVjdC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7QUFBQSxxQ0FBZ0Q7QUFFaEQsMERBQXFEO0FBQ3JELHlDQUFxRDtBQUVyRCxNQUFhLFlBQVk7SUFDdkIsV0FBVyxDQUFJLE1BQWUsRUFBRSxTQUF5QixFQUFFO1FBQ3pELE1BQU0sSUFBSSxHQUFHLG1CQUFPLENBQUMsTUFBTSxDQUFDLENBQUM7UUFFN0IsT0FBTyxpQkFBVSxDQUFDLE1BQU0sQ0FBQyxDQUFDLE1BQU0sQ0FBQyxDQUFDLEdBQUcsRUFBRSxJQUFJLEVBQUUsRUFBRTtZQUM3QyxNQUFNLEtBQUssR0FBRyxNQUFNLENBQUMsSUFBSSxDQUFDLENBQUM7WUFDM0IsSUFBSSxJQUFJLEtBQUssTUFBTSxJQUFJLElBQUksS0FBSyxLQUFLLEVBQUU7Z0JBQ3JDLEdBQUcsQ0FBQyxJQUFJLENBQUMsR0FBRyxLQUFLLENBQUMsR0FBRyxDQUFDLENBQUMsUUFBd0IsRUFBRSxFQUFFLENBQUMsSUFBSSxDQUFDLFdBQVcsQ0FBQyxNQUFNLEVBQUUsUUFBUSxDQUFDLENBQUMsQ0FBQzthQUN6RjtpQkFBTTtnQkFDTCxNQUFNLEVBQUUsR0FBRyxFQUFFLEdBQUcsRUFBRSxHQUFHLG1CQUFtQixDQUFDLElBQUksRUFBRSxLQUFLLEVBQUUsSUFBSSxDQUFDLENBQUM7Z0JBQzVELEdBQUcsQ0FBQyxHQUFHLENBQUMsR0FBRyxHQUFHLENBQUM7YUFDaEI7WUFDRCxPQUFPLEdBQUcsQ0FBQztRQUNiLENBQUMsRUFBRSxFQUFFLENBQUMsQ0FBQztJQUNULENBQUM7SUFFRCx3QkFBd0IsQ0FBSSxNQUFlLEVBQUUsRUFBWTtRQUN2RCxNQUFNLElBQUksR0FBRyxtQkFBTyxDQUFDLE1BQU0sQ0FBQyxDQUFDO1FBRTdCLE1BQU0sUUFBUSxHQUFhLEVBQUUsQ0FBQztRQUU5QixJQUFJLGNBQU8sQ0FBQyxFQUFFLENBQUMsT0FBTyxDQUFDLEVBQUU7WUFDdkIsUUFBUSxDQUFDLElBQUksQ0FBQyxFQUFFLE1BQU0sRUFBRSxJQUFJLENBQUMsV0FBVyxDQUFDLE1BQU0sRUFBRSxFQUFFLENBQUMsT0FBTyxDQUFDLEVBQUUsQ0FBQyxDQUFDO1NBQ2pFO1FBRUQsS0FBSyxNQUFNLE1BQU0sSUFBSSxFQUFFLENBQUMsU0FBUyxFQUFFO1lBQ2pDLE1BQU0sT0FBTyxHQUFHLElBQUksQ0FBQyxTQUFTLENBQUMsTUFBTSxDQUFDLENBQUM7WUFDdkMsSUFBSSxDQUFDLE9BQU8sRUFBRTtnQkFDWixNQUFNLElBQUksU0FBUyxDQUFDLElBQUksTUFBTSxDQUFDLElBQUksSUFBSSxNQUFNLGtDQUFrQyxDQUFDLENBQUM7YUFDbEY7WUFDRCxJQUFJLE9BQU8sQ0FBQyxXQUFXLEtBQUssSUFBSSxJQUFJLE9BQU8sQ0FBQyxXQUFXLEtBQUssSUFBSSxFQUFFO2dCQUNoRSx5R0FBeUc7Z0JBQ3pHLFNBQVM7YUFDVjtZQUNELE1BQU0sU0FBUyxHQUFHLE9BQU8sQ0FBQyxNQUFNLEVBQUUsQ0FBQztZQUNuQyxNQUFNLE9BQU8sR0FBRyxtQkFBTyxDQUFDLFNBQVMsQ0FBQyxDQUFDO1lBRW5DLElBQUksT0FBTyxDQUFDLFdBQVcsS0FBSyxJQUFJLEVBQUU7Z0JBQ2hDLFFBQVEsQ0FBQyxJQUFJLENBQUM7b0JBQ1osT0FBTyxFQUFFO3dCQUNQLElBQUksRUFBRSxPQUFPLENBQUMsSUFBSTt3QkFDbEIsVUFBVSxFQUFFLE1BQU07d0JBQ2xCLFlBQVksRUFBRSxLQUFLO3dCQUNuQixFQUFFLEVBQUUsTUFBTTtxQkFDWDtpQkFDRixDQUFDLENBQUM7YUFDSjtpQkFBTTtnQkFDTCxNQUFNLFdBQVcsR0FBRyxPQUFPLENBQUMsUUFBa0IsQ0FBQztnQkFDL0MsUUFBUSxDQUFDLElBQUksQ0FBQztvQkFDWixPQUFPLEVBQUU7d0JBQ1AsSUFBSSxFQUFFLE9BQU8sQ0FBQyxJQUFJO3dCQUNsQixRQUFRLEVBQUUsQ0FBQyxFQUFFLE1BQU0sRUFBRSxFQUFFLENBQUMsV0FBVyxDQUFDLEVBQUUsRUFBRSxDQUFDLE9BQU8sQ0FBQyxJQUFJLENBQUMsRUFBRSxDQUFDLElBQUksQ0FBQyxFQUFFLEVBQUUsQ0FBQzt3QkFDbkUsRUFBRSxFQUFFLE1BQU07cUJBQ1g7aUJBQ0YsQ0FBQyxDQUFDO2FBQ0o7WUFFRCxRQUFRLENBQUMsSUFBSSxDQUFDLEVBQUUsT0FBTyxFQUFFLEVBQUUsSUFBSSxFQUFFLElBQUksTUFBTSxFQUFFLEVBQUUsMEJBQTBCLEVBQUUsSUFBSSxFQUFFLEVBQUUsQ0FBQyxDQUFDO1NBQ3RGO1FBRUQsT0FBTyxRQUFRLENBQUM7SUFDbEIsQ0FBQztDQUNGO0FBOURELG9DQThEQztBQUVELFNBQVMsbUJBQW1CLENBQUksR0FBVyxFQUFFLEdBQXNCLEVBQUUsSUFBbUI7SUFDdEYsSUFBSSxHQUFHLEtBQUssS0FBSyxJQUFJLEdBQUcsS0FBSyxJQUFJLENBQUMsRUFBRSxDQUFDLFFBQVEsRUFBRTtRQUM3QyxNQUFNLFFBQVEsR0FBRyxHQUFHLFlBQVksa0JBQVEsQ0FBQyxDQUFDLENBQUMsR0FBRyxDQUFDLENBQUMsQ0FBQyxJQUFJLGtCQUFRLENBQUMsR0FBRyxDQUFDLENBQUM7UUFDbkUsT0FBTyxFQUFFLEdBQUcsRUFBRSxLQUFLLEVBQUUsR0FBRyxFQUFFLFFBQVEsRUFBRSxDQUFDO0tBQ3RDO0lBQ0QsT0FBTyxFQUFFLEdBQUcsRUFBRSxHQUFHLEVBQUUsQ0FBQztBQUN0QixDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgRmlsdGVyUXVlcnksIE9iamVjdElkIH0gZnJvbSAnbW9uZ29kYic7XG5pbXBvcnQgeyBRdWVyeUZpbHRlciwgUXVlcnksIEVudGl0eU1ldGEsIFR5cGUgfSBmcm9tICdAdXFsL2NvcmUvdHlwZSc7XG5pbXBvcnQgeyBnZXRNZXRhIH0gZnJvbSAnQHVxbC9jb3JlL2VudGl0eS9kZWNvcmF0b3InO1xuaW1wb3J0IHsgaGFzS2V5cywgb2JqZWN0S2V5cyB9IGZyb20gJ0B1cWwvY29yZS91dGlsJztcblxuZXhwb3J0IGNsYXNzIE1vbmdvRGlhbGVjdCB7XG4gIGJ1aWxkRmlsdGVyPEU+KGVudGl0eTogVHlwZTxFPiwgZmlsdGVyOiBRdWVyeUZpbHRlcjxFPiA9IHt9KTogRmlsdGVyUXVlcnk8RT4ge1xuICAgIGNvbnN0IG1ldGEgPSBnZXRNZXRhKGVudGl0eSk7XG5cbiAgICByZXR1cm4gb2JqZWN0S2V5cyhmaWx0ZXIpLnJlZHVjZSgoYWNjLCBwcm9wKSA9PiB7XG4gICAgICBjb25zdCBlbnRyeSA9IGZpbHRlcltwcm9wXTtcbiAgICAgIGlmIChwcm9wID09PSAnJGFuZCcgfHwgcHJvcCA9PT0gJyRvcicpIHtcbiAgICAgICAgYWNjW3Byb3BdID0gZW50cnkubWFwKChmaWx0ZXJJdDogUXVlcnlGaWx0ZXI8RT4pID0+IHRoaXMuYnVpbGRGaWx0ZXIoZW50aXR5LCBmaWx0ZXJJdCkpO1xuICAgICAgfSBlbHNlIHtcbiAgICAgICAgY29uc3QgeyBrZXksIHZhbCB9ID0gb2J0YWluRmluYWxLZXlWYWx1ZShwcm9wLCBlbnRyeSwgbWV0YSk7XG4gICAgICAgIGFjY1trZXldID0gdmFsO1xuICAgICAgfVxuICAgICAgcmV0dXJuIGFjYztcbiAgICB9LCB7fSk7XG4gIH1cblxuICBidWlsZEFnZ3JlZ2F0aW9uUGlwZWxpbmU8RT4oZW50aXR5OiBUeXBlPEU+LCBxbTogUXVlcnk8RT4pOiBvYmplY3RbXSB7XG4gICAgY29uc3QgbWV0YSA9IGdldE1ldGEoZW50aXR5KTtcblxuICAgIGNvbnN0IHBpcGVsaW5lOiBvYmplY3RbXSA9IFtdO1xuXG4gICAgaWYgKGhhc0tleXMocW0uJGZpbHRlcikpIHtcbiAgICAgIHBpcGVsaW5lLnB1c2goeyAkbWF0Y2g6IHRoaXMuYnVpbGRGaWx0ZXIoZW50aXR5LCBxbS4kZmlsdGVyKSB9KTtcbiAgICB9XG5cbiAgICBmb3IgKGNvbnN0IHJlbEtleSBpbiBxbS4kcG9wdWxhdGUpIHtcbiAgICAgIGNvbnN0IHJlbE9wdHMgPSBtZXRhLnJlbGF0aW9uc1tyZWxLZXldO1xuICAgICAgaWYgKCFyZWxPcHRzKSB7XG4gICAgICAgIHRocm93IG5ldyBUeXBlRXJyb3IoYCcke2VudGl0eS5uYW1lfS4ke3JlbEtleX0nIGlzIG5vdCBhbm5vdGF0ZWQgYXMgYSByZWxhdGlvbmApO1xuICAgICAgfVxuICAgICAgaWYgKHJlbE9wdHMuY2FyZGluYWxpdHkgIT09ICdtMScgJiYgcmVsT3B0cy5jYXJkaW5hbGl0eSAhPT0gJzExJykge1xuICAgICAgICAvLyAnbWFueVRvTWFueScgYW5kICdvbmVUb01hbnknIHdpbGwgbmVlZCBtdWx0aXBsZSBxdWVyaWVzIChzbyB0aGV5IHNob3VsZCBiZSByZXNvbHZlZCBpbiBhIGhpZ2hlciBsYXllcilcbiAgICAgICAgY29udGludWU7XG4gICAgICB9XG4gICAgICBjb25zdCByZWxFbnRpdHkgPSByZWxPcHRzLmVudGl0eSgpO1xuICAgICAgY29uc3QgcmVsTWV0YSA9IGdldE1ldGEocmVsRW50aXR5KTtcblxuICAgICAgaWYgKHJlbE9wdHMuY2FyZGluYWxpdHkgPT09ICdtMScpIHtcbiAgICAgICAgcGlwZWxpbmUucHVzaCh7XG4gICAgICAgICAgJGxvb2t1cDoge1xuICAgICAgICAgICAgZnJvbTogcmVsTWV0YS5uYW1lLFxuICAgICAgICAgICAgbG9jYWxGaWVsZDogcmVsS2V5LFxuICAgICAgICAgICAgZm9yZWlnbkZpZWxkOiAnX2lkJyxcbiAgICAgICAgICAgIGFzOiByZWxLZXksXG4gICAgICAgICAgfSxcbiAgICAgICAgfSk7XG4gICAgICB9IGVsc2Uge1xuICAgICAgICBjb25zdCBtYXBwZWRCeUtleSA9IHJlbE9wdHMubWFwcGVkQnkgYXMgc3RyaW5nO1xuICAgICAgICBwaXBlbGluZS5wdXNoKHtcbiAgICAgICAgICAkbG9va3VwOiB7XG4gICAgICAgICAgICBmcm9tOiByZWxNZXRhLm5hbWUsXG4gICAgICAgICAgICBwaXBlbGluZTogW3sgJG1hdGNoOiB7IFttYXBwZWRCeUtleV06IHFtLiRmaWx0ZXJbbWV0YS5pZC5uYW1lXSB9IH1dLFxuICAgICAgICAgICAgYXM6IHJlbEtleSxcbiAgICAgICAgICB9LFxuICAgICAgICB9KTtcbiAgICAgIH1cblxuICAgICAgcGlwZWxpbmUucHVzaCh7ICR1bndpbmQ6IHsgcGF0aDogYCQke3JlbEtleX1gLCBwcmVzZXJ2ZU51bGxBbmRFbXB0eUFycmF5czogdHJ1ZSB9IH0pO1xuICAgIH1cblxuICAgIHJldHVybiBwaXBlbGluZTtcbiAgfVxufVxuXG5mdW5jdGlvbiBvYnRhaW5GaW5hbEtleVZhbHVlPEU+KGtleTogc3RyaW5nLCB2YWw6IHN0cmluZyB8IE9iamVjdElkLCBtZXRhOiBFbnRpdHlNZXRhPEU+KSB7XG4gIGlmIChrZXkgPT09ICdfaWQnIHx8IGtleSA9PT0gbWV0YS5pZC5wcm9wZXJ0eSkge1xuICAgIGNvbnN0IG9iamVjdElkID0gdmFsIGluc3RhbmNlb2YgT2JqZWN0SWQgPyB2YWwgOiBuZXcgT2JqZWN0SWQodmFsKTtcbiAgICByZXR1cm4geyBrZXk6ICdfaWQnLCB2YWw6IG9iamVjdElkIH07XG4gIH1cbiAgcmV0dXJuIHsga2V5LCB2YWwgfTtcbn1cbiJdfQ==
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibW9uZ29EaWFsZWN0LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vc3JjL21vbmdvRGlhbGVjdC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7QUFBQSxxQ0FBZ0Q7QUFFaEQsMERBQXFEO0FBQ3JELHlDQUFxRDtBQUVyRCxNQUFhLFlBQVk7SUFDdkIsS0FBSyxDQUFJLE1BQWUsRUFBRSxTQUF5QixFQUFFO1FBQ25ELE1BQU0sSUFBSSxHQUFHLG1CQUFPLENBQUMsTUFBTSxDQUFDLENBQUM7UUFFN0IsT0FBTyxpQkFBVSxDQUFDLE1BQU0sQ0FBQyxDQUFDLE1BQU0sQ0FBQyxDQUFDLEdBQUcsRUFBRSxJQUFJLEVBQUUsRUFBRTtZQUM3QyxNQUFNLEtBQUssR0FBRyxNQUFNLENBQUMsSUFBSSxDQUFDLENBQUM7WUFDM0IsSUFBSSxJQUFJLEtBQUssTUFBTSxJQUFJLElBQUksS0FBSyxLQUFLLEVBQUU7Z0JBQ3JDLEdBQUcsQ0FBQyxJQUFJLENBQUMsR0FBRyxLQUFLLENBQUMsR0FBRyxDQUFDLENBQUMsUUFBd0IsRUFBRSxFQUFFLENBQUMsSUFBSSxDQUFDLEtBQUssQ0FBQyxNQUFNLEVBQUUsUUFBUSxDQUFDLENBQUMsQ0FBQzthQUNuRjtpQkFBTTtnQkFDTCxNQUFNLEVBQUUsR0FBRyxFQUFFLEdBQUcsRUFBRSxHQUFHLG1CQUFtQixDQUFDLElBQUksRUFBRSxLQUFLLEVBQUUsSUFBSSxDQUFDLENBQUM7Z0JBQzVELEdBQUcsQ0FBQyxHQUFHLENBQUMsR0FBRyxHQUFHLENBQUM7YUFDaEI7WUFDRCxPQUFPLEdBQUcsQ0FBQztRQUNiLENBQUMsRUFBRSxFQUFTLENBQUMsQ0FBQztJQUNoQixDQUFDO0lBRUQsT0FBTyxDQUFJLE9BQXdCO1FBQ2pDLElBQUksS0FBSyxDQUFDLE9BQU8sQ0FBQyxPQUFPLENBQUMsRUFBRTtZQUMxQixPQUFPLE9BQU8sQ0FBQyxNQUFNLENBQUMsQ0FBQyxHQUFHLEVBQUUsRUFBRSxFQUFFLEVBQUU7Z0JBQ2hD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LElBQUksa0JBQVEsQ0FBQyxHQUFHLENBQUMsQ0FBQztRQUNuRSxPQUFPLEVBQUUsR0FBRyxFQUFFLEtBQUssRUFBRSxHQUFHLEVBQUUsUUFBUSxFQUFFLENBQUM7S0FDdEM7SUFDRCxPQUFPLEVBQUUsR0FBRyxFQUFFLEdBQUcsRUFBRSxDQUFDO0FBQ3RCLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBGaWx0ZXJRdWVyeSwgT2JqZWN0SWQgfSBmcm9tICdtb25nb2RiJztcbmltcG9ydCB7IFF1ZXJ5RmlsdGVyLCBRdWVyeSwgRW50aXR5TWV0YSwgVHlwZSwgUXVlcnlQcm9qZWN0LCBRdWVyeVByb2plY3RQcm9wZXJ0aWVzIH0gZnJvbSAnQHVxbC9jb3JlL3R5cGUnO1xuaW1wb3J0IHsgZ2V0TWV0YSB9IGZyb20gJ0B1cWwvY29yZS9lbnRpdHkvZGVjb3JhdG9yJztcbmltcG9ydCB7IGhhc0tleXMsIG9iamVjdEtleXMgfSBmcm9tICdAdXFsL2NvcmUvdXRpbCc7XG5cbmV4cG9ydCBjbGFzcyBNb25nb0RpYWxlY3Qge1xuICB3aGVyZTxFPihlbnRpdHk6IFR5cGU8RT4sIGZpbHRlcjogUXVlcnlGaWx0ZXI8RT4gPSB7fSk6IEZpbHRlclF1ZXJ5PEU+IHtcbiAgICBjb25zdCBtZXRhID0gZ2V0TWV0YShlbnRpdHkpO1xuXG4gICAgcmV0dXJuIG9iamVjdEtleXMoZmlsdGVyKS5yZWR1Y2UoKGFjYywgcHJvcCkgPT4ge1xuICAgICAgY29uc3QgdmFsdWUgPSBmaWx0ZXJbcHJvcF07XG4gICAgICBpZiAocHJvcCA9PT0gJyRhbmQnIHx8IHByb3AgPT09ICckb3InKSB7XG4gICAgICAgIGFjY1twcm9wXSA9IHZhbHVlLm1hcCgoZmlsdGVySXQ6IFF1ZXJ5RmlsdGVyPEU+KSA9PiB0aGlzLndoZXJlKGVudGl0eSwgZmlsdGVySXQpKTtcbiAgICAgIH0gZWxzZSB7XG4gICAgICAgIGNvbnN0IHsga2V5LCB2YWwgfSA9IG9idGFpbkZpbmFsS2V5VmFsdWUocHJvcCwgdmFsdWUsIG1ldGEpO1xuICAgICAgICBhY2Nba2V5XSA9IHZhbDtcbiAgICAgIH1cbiAgICAgIHJldHVybiBhY2M7XG4gICAgfSwge30gYXMgYW55KTtcbiAgfVxuXG4gIHByb2plY3Q8RT4ocHJvamVjdDogUXVlcnlQcm9qZWN0PEU+KTogUXVlcnlQcm9qZWN0UHJvcGVydGllczxFPiB7XG4gICAgaWYgKEFycmF5LmlzQXJyYXkocHJvamVjdCkpIHtcbiAgICAgIHJldHVybiBwcm9qZWN0LnJlZHVjZSgoYWNjLCBpdCkgPT4ge1xuICAgICAgICBhY2NbaXRdID0gdHJ1ZTtcbiAgICAgICAgcmV0dXJuIGFjYztcbiAgICAgIH0sIHt9IGFzIFF1ZXJ5UHJvamVjdFByb3BlcnRpZXM8RT4pO1xuICAgIH1cbiAgICByZXR1cm4gcHJvamVjdCBhcyBRdWVyeVByb2plY3RQcm9wZXJ0aWVzPEU+O1xuICB9XG5cbiAgYWdncmVnYXRpb25QaXBlbGluZTxFPihlbnRpdHk6IFR5cGU8RT4sIHFtOiBRdWVyeTxFPik6IG9iamVjdFtdIHtcbiAgICBjb25zdCBtZXRhID0gZ2V0TWV0YShlbnRpdHkpO1xuXG4gICAgY29uc3QgcGlwZWxpbmU6IG9iamVjdFtdID0gW107XG5cbiAgICBpZiAoaGFzS2V5cyhxbS4kZmlsdGVyKSkge1xuICAgICAgcGlwZWxpbmUucHVzaCh7ICRtYXRjaDogdGhpcy53aGVyZShlbnRpdHksIHFtLiRmaWx0ZXIpIH0pO1xuICAgIH1cblxuICAgIGZvciAoY29uc3QgcmVsS2V5IGluIHFtLiRwb3B1bGF0ZSkge1xuICAgICAgY29uc3QgcmVsT3B0cyA9IG1ldGEucmVsYXRpb25zW3JlbEtleV07XG4gICAgICBpZiAoIXJlbE9wdHMpIHtcbiAgICAgICAgdGhyb3cgbmV3IFR5cGVFcnJvcihgJyR7ZW50aXR5Lm5hbWV9LiR7cmVsS2V5fScgaXMgbm90IGFubm90YXRlZCBhcyBhIHJlbGF0aW9uYCk7XG4gICAgICB9XG4gICAgICBpZiAocmVsT3B0cy5jYXJkaW5hbGl0eSAhPT0gJ20xJyAmJiByZWxPcHRzLmNhcmRpbmFsaXR5ICE9PSAnMTEnKSB7XG4gICAgICAgIC8vICdtYW55VG9NYW55JyBhbmQgJ29uZVRvTWFueScgd2lsbCBuZWVkIG11bHRpcGxlIHF1ZXJpZXMgKHNvIHRoZXkgc2hvdWxkIGJlIHJlc29sdmVkIGluIGEgaGlnaGVyIGxheWVyKVxuICAgICAgICBjb250aW51ZTtcbiAgICAgIH1cbiAgICAgIGNvbnN0IHJlbEVudGl0eSA9IHJlbE9wdHMuZW50aXR5KCk7XG4gICAgICBjb25zdCByZWxNZXRhID0gZ2V0TWV0YShyZWxFbnRpdHkpO1xuXG4gICAgICBpZiAocmVsT3B0cy5jYXJkaW5hbGl0eSA9PT0gJ20xJykge1xuICAgICAgICBwaXBlbGluZS5wdXNoKHtcbiAgICAgICAgICAkbG9va3VwOiB7XG4gICAgICAgICAgICBmcm9tOiByZWxNZXRhLm5hbWUsXG4gICAgICAgICAgICBsb2NhbEZpZWxkOiByZWxPcHRzLnJlZmVyZW5jZXNbMF0uc291cmNlLFxuICAgICAgICAgICAgZm9yZWlnbkZpZWxkOiAnX2lkJyxcbiAgICAgICAgICAgIGFzOiByZWxLZXksXG4gICAgICAgICAgfSxcbiAgICAgICAgfSk7XG4gICAgICB9IGVsc2Uge1xuICAgICAgICBjb25zdCBwcm9wID0gcmVsT3B0cy5tYXBwZWRCeSA/IHJlbE9wdHMucmVmZXJlbmNlc1swXS50YXJnZXQgOiByZWxPcHRzLnJlZmVyZW5jZXNbMF0uc291cmNlO1xuICAgICAgICBwaXBlbGluZS5wdXNoKHtcbiAgICAgICAgICAkbG9va3VwOiB7XG4gICAgICAgICAgICBmcm9tOiByZWxNZXRhLm5hbWUsXG4gICAgICAgICAgICBwaXBlbGluZTogW3sgJG1hdGNoOiB7IFtwcm9wXTogcW0uJGZpbHRlclttZXRhLmlkLnByb3BlcnR5XSB9IH1dLFxuICAgICAgICAgICAgYXM6IHJlbEtleSxcbiAgICAgICAgICB9LFxuICAgICAgICB9KTtcbiAgICAgIH1cblxuICAgICAgcGlwZWxpbmUucHVzaCh7ICR1bndpbmQ6IHsgcGF0aDogYCQke3JlbEtleX1gLCBwcmVzZXJ2ZU51bGxBbmRFbXB0eUFycmF5czogdHJ1ZSB9IH0pO1xuICAgIH1cblxuICAgIHJldHVybiBwaXBlbGluZTtcbiAgfVxufVxuXG5mdW5jdGlvbiBvYnRhaW5GaW5hbEtleVZhbHVlPEU+KGtleTogc3RyaW5nLCB2YWw6IGFueSwgbWV0YTogRW50aXR5TWV0YTxFPikge1xuICBpZiAoa2V5ID09PSAnX2lkJyB8fCBrZXkgPT09IG1ldGEuaWQucHJvcGVydHkpIHtcbiAgICBjb25zdCBvYmplY3RJZCA9IHZhbCBpbnN0YW5jZW9mIE9iamVjdElkID8gdmFsIDogbmV3IE9iamVjdElkKHZhbCk7XG4gICAgcmV0dXJuIHsga2V5OiAnX2lkJywgdmFsOiBvYmplY3RJZCB9O1xuICB9XG4gIHJldHVybiB7IGtleSwgdmFsIH07XG59XG4iXX0=

@@ -5,3 +5,3 @@ {

"license": "MIT",
"version": "0.4.20",
"version": "0.4.21",
"main": "index.js",

@@ -19,8 +19,8 @@ "types": "index.d.ts",

"peerDependencies": {
"@uql/core": "^0.4.16"
"@uql/core": "^0.4.20"
},
"devDependencies": {
"@types/mongodb": "^3.6.17",
"@types/node": "^15.12.0",
"@uql/core": "^0.4.20",
"@types/node": "^15.12.2",
"@uql/core": "^0.4.21",
"copyfiles": "^2.4.1",

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

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