Socket
Socket
Sign inDemoInstall

@cdklabs/tskb

Package Overview
Dependencies
Maintainers
2
Versions
4
Alerts
File Explorer

Advanced tools

Socket logo

Install Socket

Detect and block malicious and high-risk dependencies

Install

@cdklabs/tskb - npm Package Compare versions

Comparing version 0.0.2 to 0.0.3

21

lib/entity.d.ts

@@ -47,3 +47,3 @@ import { sortedMap, SortedMultiMap } from './sorted-map';

*/
export type IndexLookups<P> = P extends string ? StringIndexLookups : {};
export type IndexLookups<P> = [P] extends [string] ? StringIndexLookups : [P] extends [string | undefined] ? OptionalStringIndexLookups : {};
/**

@@ -57,2 +57,8 @@ * All the lookups on 'string' types

}
/**
* All the lookups on 'string | undefined' types
*/
export interface OptionalStringIndexLookups {
equals(x: string | undefined): string[];
}
export declare function entityCollection<A extends Entity>(): EntityCollection<A, {}>;

@@ -76,3 +82,16 @@ /**

export declare function ref<E extends Entity>(x: E | string): Reference<E>;
/**
* Determines whether two strings are equivalent in the current or specified locale.
*/
export declare function stringCmp(a: string, b: string): number;
/**
* Determines whether two numbers are equivalent.
*/
export declare function numberCmp(a: number, b: number): number;
/**
* Creates a comparator to determine equivalent of two values, using a given comparator, but allows values to be optional.
*
* @param frontOrder If `true`, returns so that undefined values are ordered at the front. If `false`, undefined values are ordered at the back.
*/
export declare function optionalCmp<A>(cmp: (a: A, b: A) => number, frontOrder?: boolean): (a: A | undefined, b: A | undefined) => number;
export {};
"use strict";
Object.defineProperty(exports, "__esModule", { value: true });
exports.stringCmp = exports.ref = exports.isEntityCollection = exports.calculatedIndex = exports.fieldIndex = exports.entityCollection = void 0;
exports.optionalCmp = exports.numberCmp = exports.stringCmp = exports.ref = exports.isEntityCollection = exports.calculatedIndex = exports.fieldIndex = exports.entityCollection = void 0;
const sorted_map_1 = require("./sorted-map");

@@ -83,2 +83,5 @@ function entityCollection() {

exports.ref = ref;
/**
* Determines whether two strings are equivalent in the current or specified locale.
*/
function stringCmp(a, b) {

@@ -88,2 +91,29 @@ return a.localeCompare(b);

exports.stringCmp = stringCmp;
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"entity.js","sourceRoot":"","sources":["../src/entity.ts"],"names":[],"mappings":"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","sourcesContent":["import { sortedMap, SortedMultiMap } from './sorted-map';\n\nexport interface Entity {\n  readonly $id: string;\n}\n\nexport type Plain<E extends Entity> = Omit<E, '$id'>;\n\ntype Indexes<A extends Entity> = { [K in PropertyKey]: EntityIndex<A, any> };\n\nexport interface EntityCollection<A extends Entity, I extends Indexes<Entity> = {}> {\n  readonly type: 'entities';\n  readonly entities: Map<string, A>;\n  readonly indexes: I;\n\n  add(x: A): void;\n  dehydrate(): any;\n  hydrateFrom(x: any): void;\n\n  /**\n   * Add indexes to this collection\n   *\n   * Creating an indexed collection is a two-step operation so that we can specify the\n   * Entity type, but infer the index types (TypeScript does not allow both specifying AND\n   * inferring generic arguments in a single call).\n   */\n  index<II extends Indexes<A>>(indexes: II): EntityCollection<A, II>;\n}\n\n/**\n * Interface for index objects\n */\nexport interface EntityIndex<A extends Entity, IndexType> {\n  /**\n   * The lookups that the indexed field type affords\n   *\n   * For example, 'equals', 'lessThan', 'prefix', etc.\n   */\n  readonly lookups: IndexLookups<IndexType>;\n\n  /**\n   * The index data store\n   */\n  readonly index: SortedMultiMap<IndexType, string>;\n\n  /**\n   * Add an entity to the index\n   */\n  add(x: A): void;\n}\n\n/**\n * Map a type the types of lookups we can do on that type\n */\nexport type IndexLookups<P> = P extends string ? StringIndexLookups : {};\n\n/**\n * All the lookups on 'string' types\n *\n * We currently only have 'equals' but we could have more :)\n */\nexport interface StringIndexLookups {\n  equals(x: string): string[];\n}\n\nexport function entityCollection<A extends Entity>(): EntityCollection<A, {}> {\n  const entities = new Map<string, A>();\n  const _indexes = {};\n\n  function add(x: A) {\n    entities.set(x.$id, x);\n    for (const index of Object.values(_indexes)) {\n      // FIXME: why can't we type this?\n      (index as any).add(x);\n    }\n  }\n\n  return {\n    type: 'entities',\n    entities,\n    indexes: _indexes as any,\n    add,\n    dehydrate: () => ({\n      type: 'entities',\n      entities: Array.from(validatePlainObjects(entities).values()),\n    }),\n    hydrateFrom: (x) => {\n      entities.clear();\n      for (const e of Object.values(x.entities)) {\n        add(e as any);\n      }\n    },\n    index(indexes) {\n      // This limitation exists purely because I couldn't type it otherwise.\n      // Declaring a return type of `EntityCollection<A, I | II>` would make a lot\n      // of our other type inspection code stop working (the union is hard to pick\n      // apart). Since adding indexes in multiple goes is not really a use case,\n      // the simpler solution is just to type it as if we replaced all indexes\n      // and add a runtime check to make sure the types aren't lying.\n      if (Object.keys(_indexes).length > 0) {\n        throw new Error('You may only call .index() once on a new collection');\n      }\n      Object.assign(_indexes, indexes);\n      return this as any;\n    },\n  };\n}\n\n/**\n * An index that uses the value of an entity's field\n */\nexport function fieldIndex<A extends Entity, P extends keyof A>(\n  propName: P,\n  comparator: sortedMap.Comparator<A[P]>,\n): EntityIndex<A, A[P]> {\n  return calculatedIndex((x) => x[propName], comparator);\n}\n\n/**\n * An index that is calculated based on a function applied to an entity\n */\nexport function calculatedIndex<A extends Entity, B>(fn: (x: A) => B, comparator: sortedMap.Comparator<B>) {\n  const index: SortedMultiMap<B, string> = [];\n  return {\n    add: (x: A) => sortedMap.add(index, comparator, fn(x), x.$id),\n    lookups: {\n      equals: (value: B) => sortedMap.findAll(index, comparator, value),\n    } as any,\n    index,\n  };\n}\n\nexport function isEntityCollection(x: unknown): x is EntityCollection<any> {\n  return typeof x === 'object' && !!x && (x as any).type === 'entities';\n}\n\nfunction validatePlainObjects<A extends object>(xs: Map<string, A>): Map<string, A> {\n  for (const x of xs.values()) {\n    if (x.constructor !== Object) {\n      throw new Error(`Entities should be plain-text objects, got instance of ${x.constructor}`);\n    }\n  }\n  return xs;\n}\n\nexport interface Reference<E extends Entity> {\n  readonly $ref: E['$id'];\n}\n\nexport function ref<E extends Entity>(x: E | string): Reference<E> {\n  return typeof x === 'string' ? { $ref: x } : { $ref: x.$id };\n}\n\nexport function stringCmp(a: string, b: string) {\n  return a.localeCompare(b);\n}\n"]}
/**
* Determines whether two numbers are equivalent.
*/
function numberCmp(a, b) {
return a - b;
}
exports.numberCmp = numberCmp;
/**
* Creates a comparator to determine equivalent of two values, using a given comparator, but allows values to be optional.
*
* @param frontOrder If `true`, returns so that undefined values are ordered at the front. If `false`, undefined values are ordered at the back.
*/
function optionalCmp(cmp, frontOrder = true) {
return (a, b) => {
if (a == undefined && b != undefined) {
return frontOrder ? -1 : 1;
}
if (a != undefined && b == undefined) {
return frontOrder ? 1 : -1;
}
if (a == undefined && b == undefined) {
return 0;
}
return cmp(a, b);
};
}
exports.optionalCmp = optionalCmp;
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"entity.js","sourceRoot":"","sources":["../src/entity.ts"],"names":[],"mappings":"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","sourcesContent":["import { sortedMap, SortedMultiMap } from './sorted-map';\n\nexport interface Entity {\n  readonly $id: string;\n}\n\nexport type Plain<E extends Entity> = Omit<E, '$id'>;\n\ntype Indexes<A extends Entity> = { [K in PropertyKey]: EntityIndex<A, any> };\n\nexport interface EntityCollection<A extends Entity, I extends Indexes<Entity> = {}> {\n  readonly type: 'entities';\n  readonly entities: Map<string, A>;\n  readonly indexes: I;\n\n  add(x: A): void;\n  dehydrate(): any;\n  hydrateFrom(x: any): void;\n\n  /**\n   * Add indexes to this collection\n   *\n   * Creating an indexed collection is a two-step operation so that we can specify the\n   * Entity type, but infer the index types (TypeScript does not allow both specifying AND\n   * inferring generic arguments in a single call).\n   */\n  index<II extends Indexes<A>>(indexes: II): EntityCollection<A, II>;\n}\n\n/**\n * Interface for index objects\n */\nexport interface EntityIndex<A extends Entity, IndexType> {\n  /**\n   * The lookups that the indexed field type affords\n   *\n   * For example, 'equals', 'lessThan', 'prefix', etc.\n   */\n  readonly lookups: IndexLookups<IndexType>;\n\n  /**\n   * The index data store\n   */\n  readonly index: SortedMultiMap<IndexType, string>;\n\n  /**\n   * Add an entity to the index\n   */\n  add(x: A): void;\n}\n\n/**\n * Map a type the types of lookups we can do on that type\n */\nexport type IndexLookups<P> = [P] extends [string]\n  ? StringIndexLookups\n  : [P] extends [string | undefined]\n  ? OptionalStringIndexLookups\n  : {};\n\n/**\n * All the lookups on 'string' types\n *\n * We currently only have 'equals' but we could have more :)\n */\nexport interface StringIndexLookups {\n  equals(x: string): string[];\n}\n\n/**\n * All the lookups on 'string | undefined' types\n */\nexport interface OptionalStringIndexLookups {\n  equals(x: string | undefined): string[];\n}\n\nexport function entityCollection<A extends Entity>(): EntityCollection<A, {}> {\n  const entities = new Map<string, A>();\n  const _indexes = {};\n\n  function add(x: A) {\n    entities.set(x.$id, x);\n    for (const index of Object.values(_indexes)) {\n      // FIXME: why can't we type this?\n      (index as any).add(x);\n    }\n  }\n\n  return {\n    type: 'entities',\n    entities,\n    indexes: _indexes as any,\n    add,\n    dehydrate: () => ({\n      type: 'entities',\n      entities: Array.from(validatePlainObjects(entities).values()),\n    }),\n    hydrateFrom: (x) => {\n      entities.clear();\n      for (const e of Object.values(x.entities)) {\n        add(e as any);\n      }\n    },\n    index(indexes) {\n      // This limitation exists purely because I couldn't type it otherwise.\n      // Declaring a return type of `EntityCollection<A, I | II>` would make a lot\n      // of our other type inspection code stop working (the union is hard to pick\n      // apart). Since adding indexes in multiple goes is not really a use case,\n      // the simpler solution is just to type it as if we replaced all indexes\n      // and add a runtime check to make sure the types aren't lying.\n      if (Object.keys(_indexes).length > 0) {\n        throw new Error('You may only call .index() once on a new collection');\n      }\n      Object.assign(_indexes, indexes);\n      return this as any;\n    },\n  };\n}\n\n/**\n * An index that uses the value of an entity's field\n */\nexport function fieldIndex<A extends Entity, P extends keyof A>(\n  propName: P,\n  comparator: sortedMap.Comparator<A[P]>,\n): EntityIndex<A, A[P]> {\n  return calculatedIndex((x) => x[propName], comparator);\n}\n\n/**\n * An index that is calculated based on a function applied to an entity\n */\nexport function calculatedIndex<A extends Entity, B>(fn: (x: A) => B, comparator: sortedMap.Comparator<B>) {\n  const index: SortedMultiMap<B, string> = [];\n  return {\n    add: (x: A) => sortedMap.add(index, comparator, fn(x), x.$id),\n    lookups: {\n      equals: (value: B) => sortedMap.findAll(index, comparator, value),\n    } as any,\n    index,\n  };\n}\n\nexport function isEntityCollection(x: unknown): x is EntityCollection<any> {\n  return typeof x === 'object' && !!x && (x as any).type === 'entities';\n}\n\nfunction validatePlainObjects<A extends object>(xs: Map<string, A>): Map<string, A> {\n  for (const x of xs.values()) {\n    if (x.constructor !== Object) {\n      throw new Error(`Entities should be plain-text objects, got instance of ${x.constructor}`);\n    }\n  }\n  return xs;\n}\n\nexport interface Reference<E extends Entity> {\n  readonly $ref: E['$id'];\n}\n\nexport function ref<E extends Entity>(x: E | string): Reference<E> {\n  return typeof x === 'string' ? { $ref: x } : { $ref: x.$id };\n}\n\n/**\n * Determines whether two strings are equivalent in the current or specified locale.\n */\nexport function stringCmp(a: string, b: string): number {\n  return a.localeCompare(b);\n}\n\n/**\n * Determines whether two numbers are equivalent.\n */\nexport function numberCmp(a: number, b: number): number {\n  return a - b;\n}\n\n/**\n * Creates a comparator to determine equivalent of two values, using a given comparator, but allows values to be optional.\n *\n * @param frontOrder If `true`, returns so that undefined values are ordered at the front. If `false`, undefined values are ordered at the back.\n */\nexport function optionalCmp<A>(cmp: (a: A, b: A) => number, frontOrder = true) {\n  return (a: A | undefined, b: A | undefined) => {\n    if (a == undefined && b != undefined) {\n      return frontOrder ? -1 : 1;\n    }\n    if (a != undefined && b == undefined) {\n      return frontOrder ? 1 : -1;\n    }\n    if (a == undefined && b == undefined) {\n      return 0;\n    }\n\n    return cmp(a!, b!);\n  };\n}\n"]}

38

lib/sorted-map.js

@@ -13,3 +13,3 @@ "use strict";

function add(map, cmp, key, value) {
const i = firstNotBefore(map, cmp, key);
const i = lowerBound(map, cmp, key);
map.splice(i, 0, [key, value]);

@@ -19,3 +19,3 @@ }

function find(map, cmp, key) {
const i = firstNotBefore(map, cmp, key);
const i = lowerBound(map, cmp, key);
if (i === map.length) {

@@ -29,3 +29,3 @@ return undefined;

function findAll(map, cmp, key) {
let i = firstNotBefore(map, cmp, key);
let i = lowerBound(map, cmp, key);
const ret = [];

@@ -40,26 +40,24 @@ while (i < map.length && cmp(map[i][0], key) === 0) {

/**
* Return the first index that doesn't come fully before key
* Return the index to the first element in the the sorted map
*
* It is either key itself, or a something after key
* @see https://en.cppreference.com/w/cpp/algorithm/lower_bound#Version_2
*/
function firstNotBefore(map, cmp, key) {
let lo = 0;
let hi = map.length;
while (lo < hi) {
const mid = lo + Math.floor((hi - lo) / 2);
const c = cmp(key, map[mid][0]);
if (c < 0) {
hi = mid;
function lowerBound(map, cmp, key) {
let first = 0;
let count = map.length;
while (count > 0) {
let it = first;
let step = Math.floor(count / 2);
it += step;
if (cmp(map[it][0], key) < 0) {
first = ++it;
count -= step + 1;
}
else if (c > 0) {
lo = mid + 1;
}
else {
// Found it exactly
return mid;
count = step;
}
}
return lo;
return first;
}
})(sortedMap = exports.sortedMap || (exports.sortedMap = {}));
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic29ydGVkLW1hcC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uL3NyYy9zb3J0ZWQtbWFwLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7OztBQUVBOzs7OztHQUtHO0FBQ0gsSUFBaUIsU0FBUyxDQXdEekI7QUF4REQsV0FBaUIsU0FBUztJQUd4QixTQUFnQixHQUFHLENBQU8sR0FBeUIsRUFBRSxHQUFrQixFQUFFLEdBQU0sRUFBRSxLQUFRO1FBQ3ZGLE1BQU0sQ0FBQyxHQUFHLGNBQWMsQ0FBQyxHQUFHLEVBQUUsR0FBRyxFQUFFLEdBQUcsQ0FBQyxDQUFDO1FBQ3hDLEdBQUcsQ0FBQyxNQUFNLENBQUMsQ0FBQyxFQUFFLENBQUMsRUFBRSxDQUFDLEdBQUcsRUFBRSxLQUFLLENBQUMsQ0FBQyxDQUFDO0lBQ2pDLENBQUM7SUFIZSxhQUFHLE1BR2xCLENBQUE7SUFFRCxTQUFnQixJQUFJLENBQU8sR0FBeUIsRUFBRSxHQUFrQixFQUFFLEdBQU07UUFDOUUsTUFBTSxDQUFDLEdBQUcsY0FBYyxDQUFDLEdBQUcsRUFBRSxHQUFHLEVBQUUsR0FBRyxDQUFDLENBQUM7UUFDeEMsSUFBSSxDQUFDLEtBQUssR0FBRyxDQUFDLE1BQU0sRUFBRTtZQUNwQixPQUFPLFNBQVMsQ0FBQztTQUNsQjtRQUVELE1BQU0sQ0FBQyxRQUFRLEVBQUUsS0FBSyxDQUFDLEdBQUcsR0FBRyxDQUFDLENBQUMsQ0FBQyxDQUFDO1FBQ2pDLE9BQU8sR0FBRyxDQUFDLFFBQVEsRUFBRSxHQUFHLENBQUMsS0FBSyxDQUFDLENBQUMsQ0FBQyxDQUFDLEtBQUssQ0FBQyxDQUFDLENBQUMsU0FBUyxDQUFDO0lBQ3RELENBQUM7SUFSZSxjQUFJLE9BUW5CLENBQUE7SUFFRCxTQUFnQixPQUFPLENBQU8sR0FBeUIsRUFBRSxHQUFrQixFQUFFLEdBQU07UUFDakYsSUFBSSxDQUFDLEdBQUcsY0FBYyxDQUFDLEdBQUcsRUFBRSxHQUFHLEVBQUUsR0FBRyxDQUFDLENBQUM7UUFFdEMsTUFBTSxHQUFHLEdBQUcsRUFBRSxDQUFDO1FBQ2YsT0FBTyxDQUFDLEdBQUcsR0FBRyxDQUFDLE1BQU0sSUFBSSxHQUFHLENBQUMsR0FBRyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxFQUFFLEdBQUcsQ0FBQyxLQUFLLENBQUMsRUFBRTtZQUNsRCxHQUFHLENBQUMsSUFBSSxDQUFDLEdBQUcsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDO1lBQ3BCLENBQUMsSUFBSSxDQUFDLENBQUM7U0FDUjtRQUVELE9BQU8sR0FBRyxDQUFDO0lBQ2IsQ0FBQztJQVZlLGlCQUFPLFVBVXRCLENBQUE7SUFFRDs7OztPQUlHO0lBQ0gsU0FBUyxjQUFjLENBQU8sR0FBeUIsRUFBRSxHQUFrQixFQUFFLEdBQU07UUFDakYsSUFBSSxFQUFFLEdBQUcsQ0FBQyxDQUFDO1FBQ1gsSUFBSSxFQUFFLEdBQUcsR0FBRyxDQUFDLE1BQU0sQ0FBQztRQUVwQixPQUFPLEVBQUUsR0FBRyxFQUFFLEVBQUU7WUFDZCxNQUFNLEdBQUcsR0FBRyxFQUFFLEdBQUcsSUFBSSxDQUFDLEtBQUssQ0FBQyxDQUFDLEVBQUUsR0FBRyxFQUFFLENBQUMsR0FBRyxDQUFDLENBQUMsQ0FBQztZQUUzQyxNQUFNLENBQUMsR0FBRyxHQUFHLENBQUMsR0FBRyxFQUFFLEdBQUcsQ0FBQyxHQUFHLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDO1lBRWhDLElBQUksQ0FBQyxHQUFHLENBQUMsRUFBRTtnQkFDVCxFQUFFLEdBQUcsR0FBRyxDQUFDO2FBQ1Y7aUJBQU0sSUFBSSxDQUFDLEdBQUcsQ0FBQyxFQUFFO2dCQUNoQixFQUFFLEdBQUcsR0FBRyxHQUFHLENBQUMsQ0FBQzthQUNkO2lCQUFNO2dCQUNMLG1CQUFtQjtnQkFDbkIsT0FBTyxHQUFHLENBQUM7YUFDWjtTQUNGO1FBRUQsT0FBTyxFQUFFLENBQUM7SUFDWixDQUFDO0FBQ0gsQ0FBQyxFQXhEZ0IsU0FBUyxHQUFULGlCQUFTLEtBQVQsaUJBQVMsUUF3RHpCIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0IHR5cGUgU29ydGVkTXVsdGlNYXA8QSwgQj4gPSBBcnJheTxbQSwgQl0+O1xuXG4vKipcbiAqIEEgc29ydGVkIG1hcCB0aGF0IG1heSBjb250YWluIHRoZSBzYW1lIGtleSBtdWx0aXBsZSB0aW1lc1xuICpcbiAqIFN0b3JlZCBhcyBhIHNvcnRlZCBhcnJheSBvZiBba2V5LCB2YWx1ZV0gcGFpcnMsIHVzaW5nIGJpbmFyeSBzZWFyY2ggdG8gbG9jYXRlXG4gKiBlbnRyaWVzLlxuICovXG5leHBvcnQgbmFtZXNwYWNlIHNvcnRlZE1hcCB7XG4gIGV4cG9ydCB0eXBlIENvbXBhcmF0b3I8QT4gPSAoYTogQSwgYjogQSkgPT4gbnVtYmVyO1xuXG4gIGV4cG9ydCBmdW5jdGlvbiBhZGQ8QSwgQj4obWFwOiBTb3J0ZWRNdWx0aU1hcDxBLCBCPiwgY21wOiBDb21wYXJhdG9yPEE+LCBrZXk6IEEsIHZhbHVlOiBCKSB7XG4gICAgY29uc3QgaSA9IGZpcnN0Tm90QmVmb3JlKG1hcCwgY21wLCBrZXkpO1xuICAgIG1hcC5zcGxpY2UoaSwgMCwgW2tleSwgdmFsdWVdKTtcbiAgfVxuXG4gIGV4cG9ydCBmdW5jdGlvbiBmaW5kPEEsIEI+KG1hcDogU29ydGVkTXVsdGlNYXA8QSwgQj4sIGNtcDogQ29tcGFyYXRvcjxBPiwga2V5OiBBKTogQiB8IHVuZGVmaW5lZCB7XG4gICAgY29uc3QgaSA9IGZpcnN0Tm90QmVmb3JlKG1hcCwgY21wLCBrZXkpO1xuICAgIGlmIChpID09PSBtYXAubGVuZ3RoKSB7XG4gICAgICByZXR1cm4gdW5kZWZpbmVkO1xuICAgIH1cblxuICAgIGNvbnN0IFtmb3VuZEtleSwgdmFsdWVdID0gbWFwW2ldO1xuICAgIHJldHVybiBjbXAoZm91bmRLZXksIGtleSkgPT09IDAgPyB2YWx1ZSA6IHVuZGVmaW5lZDtcbiAgfVxuXG4gIGV4cG9ydCBmdW5jdGlvbiBmaW5kQWxsPEEsIEI+KG1hcDogU29ydGVkTXVsdGlNYXA8QSwgQj4sIGNtcDogQ29tcGFyYXRvcjxBPiwga2V5OiBBKTogQltdIHtcbiAgICBsZXQgaSA9IGZpcnN0Tm90QmVmb3JlKG1hcCwgY21wLCBrZXkpO1xuXG4gICAgY29uc3QgcmV0ID0gW107XG4gICAgd2hpbGUgKGkgPCBtYXAubGVuZ3RoICYmIGNtcChtYXBbaV1bMF0sIGtleSkgPT09IDApIHtcbiAgICAgIHJldC5wdXNoKG1hcFtpXVsxXSk7XG4gICAgICBpICs9IDE7XG4gICAgfVxuXG4gICAgcmV0dXJuIHJldDtcbiAgfVxuXG4gIC8qKlxuICAgKiBSZXR1cm4gdGhlIGZpcnN0IGluZGV4IHRoYXQgZG9lc24ndCBjb21lIGZ1bGx5IGJlZm9yZSBrZXlcbiAgICpcbiAgICogSXQgaXMgZWl0aGVyIGtleSBpdHNlbGYsIG9yIGEgc29tZXRoaW5nIGFmdGVyIGtleVxuICAgKi9cbiAgZnVuY3Rpb24gZmlyc3ROb3RCZWZvcmU8QSwgQj4obWFwOiBTb3J0ZWRNdWx0aU1hcDxBLCBCPiwgY21wOiBDb21wYXJhdG9yPEE+LCBrZXk6IEEpOiBudW1iZXIge1xuICAgIGxldCBsbyA9IDA7XG4gICAgbGV0IGhpID0gbWFwLmxlbmd0aDtcblxuICAgIHdoaWxlIChsbyA8IGhpKSB7XG4gICAgICBjb25zdCBtaWQgPSBsbyArIE1hdGguZmxvb3IoKGhpIC0gbG8pIC8gMik7XG5cbiAgICAgIGNvbnN0IGMgPSBjbXAoa2V5LCBtYXBbbWlkXVswXSk7XG5cbiAgICAgIGlmIChjIDwgMCkge1xuICAgICAgICBoaSA9IG1pZDtcbiAgICAgIH0gZWxzZSBpZiAoYyA+IDApIHtcbiAgICAgICAgbG8gPSBtaWQgKyAxO1xuICAgICAgfSBlbHNlIHtcbiAgICAgICAgLy8gRm91bmQgaXQgZXhhY3RseVxuICAgICAgICByZXR1cm4gbWlkO1xuICAgICAgfVxuICAgIH1cblxuICAgIHJldHVybiBsbztcbiAgfVxufVxuIl19
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic29ydGVkLW1hcC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uL3NyYy9zb3J0ZWQtbWFwLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7OztBQUVBOzs7OztHQUtHO0FBQ0gsSUFBaUIsU0FBUyxDQXNEekI7QUF0REQsV0FBaUIsU0FBUztJQUd4QixTQUFnQixHQUFHLENBQU8sR0FBeUIsRUFBRSxHQUFrQixFQUFFLEdBQU0sRUFBRSxLQUFRO1FBQ3ZGLE1BQU0sQ0FBQyxHQUFHLFVBQVUsQ0FBQyxHQUFHLEVBQUUsR0FBRyxFQUFFLEdBQUcsQ0FBQyxDQUFDO1FBQ3BDLEdBQUcsQ0FBQyxNQUFNLENBQUMsQ0FBQyxFQUFFLENBQUMsRUFBRSxDQUFDLEdBQUcsRUFBRSxLQUFLLENBQUMsQ0FBQyxDQUFDO0lBQ2pDLENBQUM7SUFIZSxhQUFHLE1BR2xCLENBQUE7SUFFRCxTQUFnQixJQUFJLENBQU8sR0FBeUIsRUFBRSxHQUFrQixFQUFFLEdBQU07UUFDOUUsTUFBTSxDQUFDLEdBQUcsVUFBVSxDQUFDLEdBQUcsRUFBRSxHQUFHLEVBQUUsR0FBRyxDQUFDLENBQUM7UUFDcEMsSUFBSSxDQUFDLEtBQUssR0FBRyxDQUFDLE1BQU0sRUFBRTtZQUNwQixPQUFPLFNBQVMsQ0FBQztTQUNsQjtRQUVELE1BQU0sQ0FBQyxRQUFRLEVBQUUsS0FBSyxDQUFDLEdBQUcsR0FBRyxDQUFDLENBQUMsQ0FBQyxDQUFDO1FBQ2pDLE9BQU8sR0FBRyxDQUFDLFFBQVEsRUFBRSxHQUFHLENBQUMsS0FBSyxDQUFDLENBQUMsQ0FBQyxDQUFDLEtBQUssQ0FBQyxDQUFDLENBQUMsU0FBUyxDQUFDO0lBQ3RELENBQUM7SUFSZSxjQUFJLE9BUW5CLENBQUE7SUFFRCxTQUFnQixPQUFPLENBQU8sR0FBeUIsRUFBRSxHQUFrQixFQUFFLEdBQU07UUFDakYsSUFBSSxDQUFDLEdBQUcsVUFBVSxDQUFDLEdBQUcsRUFBRSxHQUFHLEVBQUUsR0FBRyxDQUFDLENBQUM7UUFFbEMsTUFBTSxHQUFHLEdBQUcsRUFBRSxDQUFDO1FBQ2YsT0FBTyxDQUFDLEdBQUcsR0FBRyxDQUFDLE1BQU0sSUFBSSxHQUFHLENBQUMsR0FBRyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxFQUFFLEdBQUcsQ0FBQyxLQUFLLENBQUMsRUFBRTtZQUNsRCxHQUFHLENBQUMsSUFBSSxDQUFDLEdBQUcsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDO1lBQ3BCLENBQUMsSUFBSSxDQUFDLENBQUM7U0FDUjtRQUVELE9BQU8sR0FBRyxDQUFDO0lBQ2IsQ0FBQztJQVZlLGlCQUFPLFVBVXRCLENBQUE7SUFFRDs7OztPQUlHO0lBQ0gsU0FBUyxVQUFVLENBQU8sR0FBeUIsRUFBRSxHQUFrQixFQUFFLEdBQU07UUFDN0UsSUFBSSxLQUFLLEdBQUcsQ0FBQyxDQUFDO1FBQ2QsSUFBSSxLQUFLLEdBQUcsR0FBRyxDQUFDLE1BQU0sQ0FBQztRQUV2QixPQUFPLEtBQUssR0FBRyxDQUFDLEVBQUU7WUFDaEIsSUFBSSxFQUFFLEdBQUcsS0FBSyxDQUFDO1lBQ2YsSUFBSSxJQUFJLEdBQUcsSUFBSSxDQUFDLEtBQUssQ0FBQyxLQUFLLEdBQUcsQ0FBQyxDQUFDLENBQUM7WUFDakMsRUFBRSxJQUFJLElBQUksQ0FBQztZQUVYLElBQUksR0FBRyxDQUFDLEdBQUcsQ0FBQyxFQUFFLENBQUMsQ0FBQyxDQUFDLENBQUMsRUFBRSxHQUFHLENBQUMsR0FBRyxDQUFDLEVBQUU7Z0JBQzVCLEtBQUssR0FBRyxFQUFFLEVBQUUsQ0FBQztnQkFDYixLQUFLLElBQUksSUFBSSxHQUFHLENBQUMsQ0FBQzthQUNuQjtpQkFBTTtnQkFDTCxLQUFLLEdBQUcsSUFBSSxDQUFDO2FBQ2Q7U0FDRjtRQUVELE9BQU8sS0FBSyxDQUFDO0lBQ2YsQ0FBQztBQUNILENBQUMsRUF0RGdCLFNBQVMsR0FBVCxpQkFBUyxLQUFULGlCQUFTLFFBc0R6QiIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCB0eXBlIFNvcnRlZE11bHRpTWFwPEEsIEI+ID0gQXJyYXk8W0EsIEJdPjtcblxuLyoqXG4gKiBBIHNvcnRlZCBtYXAgdGhhdCBtYXkgY29udGFpbiB0aGUgc2FtZSBrZXkgbXVsdGlwbGUgdGltZXNcbiAqXG4gKiBTdG9yZWQgYXMgYSBzb3J0ZWQgYXJyYXkgb2YgW2tleSwgdmFsdWVdIHBhaXJzLCB1c2luZyBiaW5hcnkgc2VhcmNoIHRvIGxvY2F0ZVxuICogZW50cmllcy5cbiAqL1xuZXhwb3J0IG5hbWVzcGFjZSBzb3J0ZWRNYXAge1xuICBleHBvcnQgdHlwZSBDb21wYXJhdG9yPEE+ID0gKGE6IEEsIGI6IEEpID0+IG51bWJlcjtcblxuICBleHBvcnQgZnVuY3Rpb24gYWRkPEEsIEI+KG1hcDogU29ydGVkTXVsdGlNYXA8QSwgQj4sIGNtcDogQ29tcGFyYXRvcjxBPiwga2V5OiBBLCB2YWx1ZTogQikge1xuICAgIGNvbnN0IGkgPSBsb3dlckJvdW5kKG1hcCwgY21wLCBrZXkpO1xuICAgIG1hcC5zcGxpY2UoaSwgMCwgW2tleSwgdmFsdWVdKTtcbiAgfVxuXG4gIGV4cG9ydCBmdW5jdGlvbiBmaW5kPEEsIEI+KG1hcDogU29ydGVkTXVsdGlNYXA8QSwgQj4sIGNtcDogQ29tcGFyYXRvcjxBPiwga2V5OiBBKTogQiB8IHVuZGVmaW5lZCB7XG4gICAgY29uc3QgaSA9IGxvd2VyQm91bmQobWFwLCBjbXAsIGtleSk7XG4gICAgaWYgKGkgPT09IG1hcC5sZW5ndGgpIHtcbiAgICAgIHJldHVybiB1bmRlZmluZWQ7XG4gICAgfVxuXG4gICAgY29uc3QgW2ZvdW5kS2V5LCB2YWx1ZV0gPSBtYXBbaV07XG4gICAgcmV0dXJuIGNtcChmb3VuZEtleSwga2V5KSA9PT0gMCA/IHZhbHVlIDogdW5kZWZpbmVkO1xuICB9XG5cbiAgZXhwb3J0IGZ1bmN0aW9uIGZpbmRBbGw8QSwgQj4obWFwOiBTb3J0ZWRNdWx0aU1hcDxBLCBCPiwgY21wOiBDb21wYXJhdG9yPEE+LCBrZXk6IEEpOiBCW10ge1xuICAgIGxldCBpID0gbG93ZXJCb3VuZChtYXAsIGNtcCwga2V5KTtcblxuICAgIGNvbnN0IHJldCA9IFtdO1xuICAgIHdoaWxlIChpIDwgbWFwLmxlbmd0aCAmJiBjbXAobWFwW2ldWzBdLCBrZXkpID09PSAwKSB7XG4gICAgICByZXQucHVzaChtYXBbaV1bMV0pO1xuICAgICAgaSArPSAxO1xuICAgIH1cblxuICAgIHJldHVybiByZXQ7XG4gIH1cblxuICAvKipcbiAgICogUmV0dXJuIHRoZSBpbmRleCB0byB0aGUgZmlyc3QgZWxlbWVudCBpbiB0aGUgdGhlIHNvcnRlZCBtYXBcbiAgICpcbiAgICogQHNlZSBodHRwczovL2VuLmNwcHJlZmVyZW5jZS5jb20vdy9jcHAvYWxnb3JpdGhtL2xvd2VyX2JvdW5kI1ZlcnNpb25fMlxuICAgKi9cbiAgZnVuY3Rpb24gbG93ZXJCb3VuZDxBLCBCPihtYXA6IFNvcnRlZE11bHRpTWFwPEEsIEI+LCBjbXA6IENvbXBhcmF0b3I8QT4sIGtleTogQSk6IG51bWJlciB7XG4gICAgbGV0IGZpcnN0ID0gMDtcbiAgICBsZXQgY291bnQgPSBtYXAubGVuZ3RoO1xuXG4gICAgd2hpbGUgKGNvdW50ID4gMCkge1xuICAgICAgbGV0IGl0ID0gZmlyc3Q7XG4gICAgICBsZXQgc3RlcCA9IE1hdGguZmxvb3IoY291bnQgLyAyKTtcbiAgICAgIGl0ICs9IHN0ZXA7XG5cbiAgICAgIGlmIChjbXAobWFwW2l0XVswXSwga2V5KSA8IDApIHtcbiAgICAgICAgZmlyc3QgPSArK2l0O1xuICAgICAgICBjb3VudCAtPSBzdGVwICsgMTtcbiAgICAgIH0gZWxzZSB7XG4gICAgICAgIGNvdW50ID0gc3RlcDtcbiAgICAgIH1cbiAgICB9XG5cbiAgICByZXR1cm4gZmlyc3Q7XG4gIH1cbn1cbiJdfQ==

@@ -23,6 +23,7 @@ {

"devDependencies": {
"@types/jest": "^29.5.5",
"@types/jest": "^29.5.7",
"@types/node": "^16",
"@typescript-eslint/eslint-plugin": "^6",
"@typescript-eslint/parser": "^6",
"constructs": "^10.0.0",
"eslint": "^8",

@@ -32,3 +33,3 @@ "eslint-config-prettier": "^8.10.0",

"eslint-import-resolver-typescript": "^3.6.1",
"eslint-plugin-import": "^2.28.1",
"eslint-plugin-import": "^2.29.0",
"eslint-plugin-prettier": "^4.2.1",

@@ -39,3 +40,3 @@ "jest": "^29.7.0",

"prettier": "^2.8.8",
"projen": "^0.73.44",
"projen": "^0.76.17",
"ts-jest": "^29.1.1",

@@ -49,3 +50,3 @@ "typescript": "^4.9.5"

},
"version": "0.0.2",
"version": "0.0.3",
"jest": {

@@ -52,0 +53,0 @@ "testMatch": [

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