Huge News!Announcing our $40M Series B led by Abstract Ventures.Learn More
Socket
Sign inDemoInstall
Socket

redink

Package Overview
Dependencies
Maintainers
2
Versions
76
Alerts
File Explorer

Advanced tools

Socket logo

Install Socket

Detect and block malicious and high-risk dependencies

Install

redink - npm Package Compare versions

Comparing version 2.0.0-beta.24 to 2.0.0-beta.25

18

dist/Model.js

@@ -136,2 +136,18 @@ 'use strict';

/**
* Returns the total count of resources.
* @return {Number}
*/
}, {
key: 'count',
value: function count() {
var conn = this.conn;
var schema = this.schema;
var type = schema.type;
return _rethinkdb2.default.table(type).count().run(conn);
}
/**
* Finds resources using the index named `index`.

@@ -395,2 +411,2 @@ *

exports.default = Model;
//# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../src/Model.js"],"names":["Model","conn","type","schema","TypeError","pre","post","table","coerceTo","run","then","records","find","resources","first","index","value","getAll","findByIndex","id","relationship","parentType","relationships","relatedType","relatedSchema","relation","inverse","field","args","get","recordOrRecords","record","checkComplianceAndNormalizeRecord","compliant","Error","createRecord","normalizedRecord","createdRecordId","createdResource","insert","keys","generated_keys","createdRecord","syncRelationshipsArray","do"],"mappings":"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","file":"Model.js","sourcesContent":["import r from 'rethinkdb';\nimport Resource from './Resource';\nimport ResourceArray from './ResourceArray';\nimport isCreateCompliant from './constraints/create';\n\nimport {\n  applyOptions,\n  mergeRelationships,\n  normalizeRecord,\n  requiresIndex,\n  syncRelationships,\n} from './utils';\n\nexport default class Model {\n  /**\n   * Instantiates a Model.\n   *\n   * @class Model\n   * @param {Object} conn - RethinkDB connection object.\n   * @param {String} type\n   * @param {Schema} schema\n   */\n  constructor(conn, type, schema) {\n    if (!conn) {\n      throw new TypeError('A valid RethinkDB connection is required to instantiate a Resource.');\n    }\n\n    if (!type) {\n      throw new TypeError('A valid type is required to instantiate a model.');\n    }\n\n    if (!schema) {\n      throw new TypeError('A valid schema is required to instantiate a model.');\n    }\n\n    this.conn = conn;\n    this.type = type;\n    this.schema = schema;\n  }\n\n  /**\n   * Finds resources that match the criteria in `pre` and `post` options.\n   *\n   * ```\n   * model('user').find({\n   *   filter: { name: 'Dylan' },\n   *   without: { password: true },\n   *   include: {\n   *     pets: {\n   *       filter: (pet) => pet('age').gt(6),\n   *       pluck: {\n   *         favoriteTreat: true,\n   *         color: true,\n   *       },\n   *     },\n   *     company: true,\n   *   },\n   * }).then(users => {\n   *   // ResourceArray\n   * });\n   * ```\n   *\n   * @async\n   * @method find\n   * @param {Object} [pre={}] - Critera before merging relationships.\n   * @param {Object} [post={}] - Critera after merging relationships.\n   * @return {Promise<ResourceArray>}\n   *\n   * @todo Write more docs on `options`\n   */\n  find(pre = {}, post = {}) {\n    const { conn, schema } = this;\n    const { type } = schema;\n\n    let table = r.table(type);\n\n    table = applyOptions(table, pre);\n    table = mergeRelationships(table, schema, pre);\n    table = applyOptions(table, post);\n    table = table.coerceTo('array');\n\n    return table.run(conn)\n      .then(records => new ResourceArray(conn, schema, records));\n  }\n\n  /**\n   * Finds the first resource (out of potentially many) that matches the criteria in `options.`\n   *\n   * @async\n   * @method findOne\n   * @param {Object} [pre={}] - Critera before merging relationships.\n   * @param {Object} [post={}] - Critera after merging relationships.\n   * @return {Promise<Resource>}\n   */\n  findOne(pre = {}, post = {}) {\n    return this.find(pre, post).then(resources => resources.first());\n  }\n\n  /**\n   * Finds resources using the index named `index`.\n   *\n   * ```\n   * model('user').findByIndex('email', 'dylanslack@gmail.com').then(users => {\n   *   // ResourceArray\n   * });\n   * ```\n   *\n   * @async\n   * @method findByIndex\n   * @param {String} index - The index name.\n   * @param {*} value\n   * @param {Object} [pre={}] - Critera before merging relationships.\n   * @param {Object} [post={}] - Critera after merging relationships.\n   * @return {Promise<ResourceArray>}\n   *\n   * @todo Add test.\n   */\n  findByIndex(index, value, pre = {}, post = {}) {\n    const { conn, schema } = this;\n    const { type } = schema;\n\n    let table = r.table(type);\n\n    table = table.getAll(value, { index });\n    table = applyOptions(table, pre);\n    table = mergeRelationships(table, schema, pre);\n    table = applyOptions(table, post);\n    table = table.coerceTo('array');\n\n    return table.run(conn)\n      .then(records => new ResourceArray(conn, schema, records));\n  }\n\n  /**\n   * Finds a single resource from `index` that matches `value` and that matches the criteria in\n   * `options`.\n   *\n   * @async\n   * @method findOneByIndex\n   * @param {String} index - The index name.\n   * @param {*} value\n   * @param {Object} [pre={}] - Critera before merging relationships.\n   * @param {Object} [post={}] - Critera after merging relationships.\n   * @return {Promise<Resource>}\n   */\n  findOneByIndex(index, value, pre = {}, post = {}) {\n    return this.findByIndex(index, value, pre, post).then(resources => resources.first());\n  }\n\n  /**\n   * Retrieves the resource(s) related to a particular resource identified by `id` according to\n   * `relationship`. A relationship with a relation of `hasMany` returns a `ResourceArray`, and a\n   * relationship with a relation of `hasOne` or `belongsTo` returns a `Resource`.\n   *\n   * ```js\n   * // pretend user `1` has a ton of pets\n   * model('user').findRelated('1', 'pets', {\n   *   filter: { species: 'hamster' },\n   * }).then(pets => {\n   *   // ResourceArray\n   * });\n   *\n   * // pretend user `1` has a company\n   * model('user').findRelated('1', 'company').then(company => {\n   *   // Resource\n   * });\n   * ```\n   *\n   * @async\n   * @method findRelated\n   * @param {String} id - The id of the parent resource.\n   * @param {String} relationship - The relationship to the parent.\n   * @param {Object} [pre={}] - Critera before merging relationships.\n   * @param {Object} [post={}] - Critera after merging relationships.\n   * @returns {Promise<Resource|ResourceArray>}\n   */\n  findRelated(id, relationship, pre = {}, post = {}) {\n    const { conn, schema, schema: { type: parentType } } = this;\n\n    const {\n      type: relatedType,\n      schema: relatedSchema,\n      relation,\n      inverse,\n    } = schema.relationships[relationship];\n\n    let table = r.table(relatedType);\n\n    if (relation === 'hasMany') {\n      if (requiresIndex(relation, inverse.relation)) {\n        table = table.getAll(id, { index: inverse.field });\n      } else {\n        table = table.getAll(\n          r.args(r.table(parentType).get(id)(relationship)('id'))\n        );\n      }\n\n      table = table.coerceTo('array');\n    } else {\n      table = table.get(\n        r.table(parentType).get(id)(relationship)('id')\n      );\n    }\n\n    table = applyOptions(table, pre);\n    table = mergeRelationships(table, relatedSchema, pre);\n    table = applyOptions(table, post);\n\n    return table.run(conn)\n      .then(recordOrRecords => {\n        if (relation === 'hasMany') return new ResourceArray(conn, relatedSchema, recordOrRecords);\n        return new Resource(conn, relatedSchema, recordOrRecords);\n      });\n  }\n\n  /**\n   * Retrieves the resource corresponding to `id`.\n   *\n   * ```js\n   * model('user').fetchResource('1').then(user => {\n   *   // Resource\n   * });\n   * ```\n   *\n   * @async\n   * @method fetchResource\n   * @param {String} id - The ID of the resource to retrieve.\n   * @param {Object} [pre={}] - Critera before merging relationships.\n   * @param {Object} [post={}] - Critera after merging relationships.\n   * @returns {Promise<Resource>}\n   */\n  fetchResource(id, pre = {}, post = {}) {\n    const { conn, schema } = this;\n    let table = r.table(schema.type);\n\n    table = table.get(id);\n    table = applyOptions(table, pre);\n    table = mergeRelationships(table, schema, pre);\n    table = applyOptions(table, post);\n\n    return table.run(conn)\n      .then(record => new Resource(conn, schema, record));\n  }\n\n  /**\n   * Persists a record in the database and creates a resource. The 'record' object must be a\n   * flattenen JSON with attributes and relationships. All relationships in `record` must be\n   * represented by either a string for a `hasOne` or `belongsTo` relation, or an array of strings\n   * for a `hasMany` relation.\n   *\n   * ```js\n   * model('user').create({\n   *   name: 'Dylan',\n   *   email: 'dylanslack@gmail.com',\n   *   password: 'hashedpassword',\n   *   pets: [ '1', '2', '3' ],\n   *   company: '1',\n   * }).then(user => {\n   *   // Resource\n   * });\n   * ```\n   *\n   * @async\n   * @method create\n   * @param {Object} record\n   * @param {Object} [pre={}] - Critera before merging relationships.\n   * @param {Object} [post={}] - Critera after merging relationships.\n   * @returns {Promise<Resource>}\n   */\n  create(record, pre = {}, post = {}) {\n    const { conn, schema } = this;\n    const { type } = schema;\n\n    const checkComplianceAndNormalizeRecord = (compliant) => {\n      if (!compliant) {\n        throw new Error(\n          'Tried to create a record, but \\'record\\' had some invalid relationships.'\n        );\n      }\n\n      return normalizeRecord(record, schema);\n    };\n\n    const createRecord = (normalizedRecord) => {\n      let createdRecordId;\n      let createdResource;\n\n      return r.table(type).insert(normalizedRecord).run(conn)\n\n        // retrieve the record that was just created\n        .then(({ generated_keys: keys }) => {\n          let table = r.table(type);\n          createdRecordId = keys[0];\n\n          table = table.get(createdRecordId);\n          table = applyOptions(table, pre);\n          table = mergeRelationships(table, schema, pre);\n          table = applyOptions(table, post);\n\n          return table.run(conn);\n        })\n\n        // create the resource and sync its relationships\n        .then(createdRecord => {\n          createdResource = new Resource(conn, schema, createdRecord);\n          const syncRelationshipsArray = syncRelationships(record, schema, createdRecordId);\n\n          return r.do(syncRelationshipsArray).run(conn);\n        })\n\n        // return the resource\n        .then(() => createdResource);\n    };\n\n    // check record and it's relationships for Redink constraints\n    return isCreateCompliant(record, schema, conn)\n      .then(checkComplianceAndNormalizeRecord)\n      .then(createRecord);\n  }\n}\n"]}
//# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../src/Model.js"],"names":["Model","conn","type","schema","TypeError","pre","post","table","coerceTo","run","then","records","find","resources","first","count","index","value","getAll","findByIndex","id","relationship","parentType","relationships","relatedType","relatedSchema","relation","inverse","field","args","get","recordOrRecords","record","checkComplianceAndNormalizeRecord","compliant","Error","createRecord","normalizedRecord","createdRecordId","createdResource","insert","keys","generated_keys","createdRecord","syncRelationshipsArray","do"],"mappings":"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","file":"Model.js","sourcesContent":["import r from 'rethinkdb';\nimport Resource from './Resource';\nimport ResourceArray from './ResourceArray';\nimport isCreateCompliant from './constraints/create';\n\nimport {\n  applyOptions,\n  mergeRelationships,\n  normalizeRecord,\n  requiresIndex,\n  syncRelationships,\n} from './utils';\n\nexport default class Model {\n  /**\n   * Instantiates a Model.\n   *\n   * @class Model\n   * @param {Object} conn - RethinkDB connection object.\n   * @param {String} type\n   * @param {Schema} schema\n   */\n  constructor(conn, type, schema) {\n    if (!conn) {\n      throw new TypeError('A valid RethinkDB connection is required to instantiate a Resource.');\n    }\n\n    if (!type) {\n      throw new TypeError('A valid type is required to instantiate a model.');\n    }\n\n    if (!schema) {\n      throw new TypeError('A valid schema is required to instantiate a model.');\n    }\n\n    this.conn = conn;\n    this.type = type;\n    this.schema = schema;\n  }\n\n  /**\n   * Finds resources that match the criteria in `pre` and `post` options.\n   *\n   * ```\n   * model('user').find({\n   *   filter: { name: 'Dylan' },\n   *   without: { password: true },\n   *   include: {\n   *     pets: {\n   *       filter: (pet) => pet('age').gt(6),\n   *       pluck: {\n   *         favoriteTreat: true,\n   *         color: true,\n   *       },\n   *     },\n   *     company: true,\n   *   },\n   * }).then(users => {\n   *   // ResourceArray\n   * });\n   * ```\n   *\n   * @async\n   * @method find\n   * @param {Object} [pre={}] - Critera before merging relationships.\n   * @param {Object} [post={}] - Critera after merging relationships.\n   * @return {Promise<ResourceArray>}\n   *\n   * @todo Write more docs on `options`\n   */\n  find(pre = {}, post = {}) {\n    const { conn, schema } = this;\n    const { type } = schema;\n\n    let table = r.table(type);\n\n    table = applyOptions(table, pre);\n    table = mergeRelationships(table, schema, pre);\n    table = applyOptions(table, post);\n    table = table.coerceTo('array');\n\n    return table.run(conn)\n      .then(records => new ResourceArray(conn, schema, records));\n  }\n\n  /**\n   * Finds the first resource (out of potentially many) that matches the criteria in `options.`\n   *\n   * @async\n   * @method findOne\n   * @param {Object} [pre={}] - Critera before merging relationships.\n   * @param {Object} [post={}] - Critera after merging relationships.\n   * @return {Promise<Resource>}\n   */\n  findOne(pre = {}, post = {}) {\n    return this.find(pre, post).then(resources => resources.first());\n  }\n\n  /**\n   * Returns the total count of resources.\n   * @return {Number}\n   */\n  count() {\n    const { conn, schema } = this;\n    const { type } = schema;\n\n    return r.table(type).count().run(conn);\n  }\n\n  /**\n   * Finds resources using the index named `index`.\n   *\n   * ```\n   * model('user').findByIndex('email', 'dylanslack@gmail.com').then(users => {\n   *   // ResourceArray\n   * });\n   * ```\n   *\n   * @async\n   * @method findByIndex\n   * @param {String} index - The index name.\n   * @param {*} value\n   * @param {Object} [pre={}] - Critera before merging relationships.\n   * @param {Object} [post={}] - Critera after merging relationships.\n   * @return {Promise<ResourceArray>}\n   *\n   * @todo Add test.\n   */\n  findByIndex(index, value, pre = {}, post = {}) {\n    const { conn, schema } = this;\n    const { type } = schema;\n\n    let table = r.table(type);\n\n    table = table.getAll(value, { index });\n    table = applyOptions(table, pre);\n    table = mergeRelationships(table, schema, pre);\n    table = applyOptions(table, post);\n    table = table.coerceTo('array');\n\n    return table.run(conn)\n      .then(records => new ResourceArray(conn, schema, records));\n  }\n\n  /**\n   * Finds a single resource from `index` that matches `value` and that matches the criteria in\n   * `options`.\n   *\n   * @async\n   * @method findOneByIndex\n   * @param {String} index - The index name.\n   * @param {*} value\n   * @param {Object} [pre={}] - Critera before merging relationships.\n   * @param {Object} [post={}] - Critera after merging relationships.\n   * @return {Promise<Resource>}\n   */\n  findOneByIndex(index, value, pre = {}, post = {}) {\n    return this.findByIndex(index, value, pre, post).then(resources => resources.first());\n  }\n\n  /**\n   * Retrieves the resource(s) related to a particular resource identified by `id` according to\n   * `relationship`. A relationship with a relation of `hasMany` returns a `ResourceArray`, and a\n   * relationship with a relation of `hasOne` or `belongsTo` returns a `Resource`.\n   *\n   * ```js\n   * // pretend user `1` has a ton of pets\n   * model('user').findRelated('1', 'pets', {\n   *   filter: { species: 'hamster' },\n   * }).then(pets => {\n   *   // ResourceArray\n   * });\n   *\n   * // pretend user `1` has a company\n   * model('user').findRelated('1', 'company').then(company => {\n   *   // Resource\n   * });\n   * ```\n   *\n   * @async\n   * @method findRelated\n   * @param {String} id - The id of the parent resource.\n   * @param {String} relationship - The relationship to the parent.\n   * @param {Object} [pre={}] - Critera before merging relationships.\n   * @param {Object} [post={}] - Critera after merging relationships.\n   * @returns {Promise<Resource|ResourceArray>}\n   */\n  findRelated(id, relationship, pre = {}, post = {}) {\n    const { conn, schema, schema: { type: parentType } } = this;\n\n    const {\n      type: relatedType,\n      schema: relatedSchema,\n      relation,\n      inverse,\n    } = schema.relationships[relationship];\n\n    let table = r.table(relatedType);\n\n    if (relation === 'hasMany') {\n      if (requiresIndex(relation, inverse.relation)) {\n        table = table.getAll(id, { index: inverse.field });\n      } else {\n        table = table.getAll(\n          r.args(r.table(parentType).get(id)(relationship)('id'))\n        );\n      }\n\n      table = table.coerceTo('array');\n    } else {\n      table = table.get(\n        r.table(parentType).get(id)(relationship)('id')\n      );\n    }\n\n    table = applyOptions(table, pre);\n    table = mergeRelationships(table, relatedSchema, pre);\n    table = applyOptions(table, post);\n\n    return table.run(conn)\n      .then(recordOrRecords => {\n        if (relation === 'hasMany') return new ResourceArray(conn, relatedSchema, recordOrRecords);\n        return new Resource(conn, relatedSchema, recordOrRecords);\n      });\n  }\n\n  /**\n   * Retrieves the resource corresponding to `id`.\n   *\n   * ```js\n   * model('user').fetchResource('1').then(user => {\n   *   // Resource\n   * });\n   * ```\n   *\n   * @async\n   * @method fetchResource\n   * @param {String} id - The ID of the resource to retrieve.\n   * @param {Object} [pre={}] - Critera before merging relationships.\n   * @param {Object} [post={}] - Critera after merging relationships.\n   * @returns {Promise<Resource>}\n   */\n  fetchResource(id, pre = {}, post = {}) {\n    const { conn, schema } = this;\n    let table = r.table(schema.type);\n\n    table = table.get(id);\n    table = applyOptions(table, pre);\n    table = mergeRelationships(table, schema, pre);\n    table = applyOptions(table, post);\n\n    return table.run(conn)\n      .then(record => new Resource(conn, schema, record));\n  }\n\n  /**\n   * Persists a record in the database and creates a resource. The 'record' object must be a\n   * flattenen JSON with attributes and relationships. All relationships in `record` must be\n   * represented by either a string for a `hasOne` or `belongsTo` relation, or an array of strings\n   * for a `hasMany` relation.\n   *\n   * ```js\n   * model('user').create({\n   *   name: 'Dylan',\n   *   email: 'dylanslack@gmail.com',\n   *   password: 'hashedpassword',\n   *   pets: [ '1', '2', '3' ],\n   *   company: '1',\n   * }).then(user => {\n   *   // Resource\n   * });\n   * ```\n   *\n   * @async\n   * @method create\n   * @param {Object} record\n   * @param {Object} [pre={}] - Critera before merging relationships.\n   * @param {Object} [post={}] - Critera after merging relationships.\n   * @returns {Promise<Resource>}\n   */\n  create(record, pre = {}, post = {}) {\n    const { conn, schema } = this;\n    const { type } = schema;\n\n    const checkComplianceAndNormalizeRecord = (compliant) => {\n      if (!compliant) {\n        throw new Error(\n          'Tried to create a record, but \\'record\\' had some invalid relationships.'\n        );\n      }\n\n      return normalizeRecord(record, schema);\n    };\n\n    const createRecord = (normalizedRecord) => {\n      let createdRecordId;\n      let createdResource;\n\n      return r.table(type).insert(normalizedRecord).run(conn)\n\n        // retrieve the record that was just created\n        .then(({ generated_keys: keys }) => {\n          let table = r.table(type);\n          createdRecordId = keys[0];\n\n          table = table.get(createdRecordId);\n          table = applyOptions(table, pre);\n          table = mergeRelationships(table, schema, pre);\n          table = applyOptions(table, post);\n\n          return table.run(conn);\n        })\n\n        // create the resource and sync its relationships\n        .then(createdRecord => {\n          createdResource = new Resource(conn, schema, createdRecord);\n          const syncRelationshipsArray = syncRelationships(record, schema, createdRecordId);\n\n          return r.do(syncRelationshipsArray).run(conn);\n        })\n\n        // return the resource\n        .then(() => createdResource);\n    };\n\n    // check record and it's relationships for Redink constraints\n    return isCreateCompliant(record, schema, conn)\n      .then(checkComplianceAndNormalizeRecord)\n      .then(createRecord);\n  }\n}\n"]}

10

dist/utils/mergeRelationships.js

@@ -105,12 +105,14 @@ 'use strict';

var relatedTable = _rethinkdb2.default.table(type);
var inverseField = inverse.field;
var fieldOptions = options.include[field];
if (relation === 'hasMany') {
if ((0, _requiresIndex2.default)(relation, inverse.relation)) {
return mergeWithIndex(relatedTable, record, field, inverse.field, options.include[field]);
return mergeWithIndex(relatedTable, record, field, inverseField, fieldOptions);
}
return record.hasFields(field).branch(mergeWithManyRecords(relatedTable, record, field, options.include[field]), {});
return record.hasFields(field).branch(mergeWithManyRecords(relatedTable, record, field, fieldOptions), {});
}
return record.hasFields(field).branch(mergeWithSingleRecord(relatedTable, record, field, options.include[field]), {});
return record.hasFields(field).branch(mergeWithSingleRecord(relatedTable, record, field, fieldOptions), {});
})));

@@ -124,2 +126,2 @@ };

};
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy91dGlscy9tZXJnZVJlbGF0aW9uc2hpcHMuanMiXSwibmFtZXMiOlsibWVyZ2VXaXRoSW5kZXgiLCJ0YWJsZSIsInJlY29yZCIsImZpZWxkIiwiaW5kZXgiLCJvcHRpb25zIiwicm93IiwiZ2V0QWxsIiwiY29lcmNlVG8iLCJtZXJnZVdpdGhNYW55UmVjb3JkcyIsImFyZ3MiLCJtZXJnZVdpdGhTaW5nbGVSZWNvcmQiLCJnZXQiLCJzY2hlbWEiLCJyZWxhdGlvbnNoaXBzIiwiZmllbGRzIiwiT2JqZWN0Iiwia2V5cyIsImZpZWxkc1RvTWVyZ2UiLCJtZXJnZSIsIm1hcCIsImluY2x1ZGUiLCJCb29sZWFuIiwidHlwZSIsInJlbGF0aW9uIiwiaW52ZXJzZSIsInJlbGF0ZWRUYWJsZSIsImhhc0ZpZWxkcyIsImJyYW5jaCJdLCJtYXBwaW5ncyI6Ijs7Ozs7O0FBQUE7Ozs7QUFDQTs7OztBQUNBOzs7O0FBQ0E7Ozs7Ozs7O0FBRUEsSUFBTUEsaUJBQWlCLFNBQWpCQSxjQUFpQixDQUFDQyxLQUFELEVBQVFDLE1BQVIsRUFBZ0JDLEtBQWhCLEVBQXVCQyxLQUF2QixFQUE4QkMsT0FBOUIsRUFBMEM7QUFDL0QsTUFBSUMsTUFBTUwsS0FBVjs7QUFFQUssUUFBTUEsSUFBSUMsTUFBSixDQUFXTCxPQUFPLElBQVAsQ0FBWCxFQUF5QixFQUFFRSxZQUFGLEVBQXpCLENBQU47QUFDQUUsUUFBTUEsSUFBSUUsUUFBSixDQUFhLE9BQWIsQ0FBTjtBQUNBRixRQUFNLDRCQUFhQSxHQUFiLEVBQWtCRCxPQUFsQixDQUFOOztBQUVBLDZCQUFVRixLQUFWLEVBQWtCRyxHQUFsQjtBQUNELENBUkQ7O0FBVUEsSUFBTUcsdUJBQXVCLFNBQXZCQSxvQkFBdUIsQ0FBQ1IsS0FBRCxFQUFRQyxNQUFSLEVBQWdCQyxLQUFoQixFQUF1QkUsT0FBdkIsRUFBbUM7QUFDOUQsTUFBSUMsTUFBTUwsS0FBVjs7QUFFQUssUUFBTUEsSUFBSUMsTUFBSixDQUFXLG9CQUFFRyxJQUFGLENBQU9SLE9BQU9DLEtBQVAsRUFBYyxJQUFkLENBQVAsQ0FBWCxDQUFOO0FBQ0FHLFFBQU1BLElBQUlFLFFBQUosQ0FBYSxPQUFiLENBQU47QUFDQUYsUUFBTSw0QkFBYUEsR0FBYixFQUFrQkQsT0FBbEIsQ0FBTjs7QUFFQSw2QkFBVUYsS0FBVixFQUFrQkcsR0FBbEI7QUFDRCxDQVJEOztBQVVBLElBQU1LLHdCQUF3QixTQUF4QkEscUJBQXdCLENBQUNWLEtBQUQsRUFBUUMsTUFBUixFQUFnQkMsS0FBaEIsRUFBdUJFLE9BQXZCLEVBQW1DO0FBQy9ELE1BQUlDLE1BQU1MLEtBQVY7O0FBRUFLLFFBQU1BLElBQUlNLEdBQUosQ0FBUVYsT0FBT0MsS0FBUCxFQUFjLElBQWQsQ0FBUixDQUFOO0FBQ0FHLFFBQU0sNEJBQWFBLEdBQWIsRUFBa0JELE9BQWxCLENBQU47O0FBRUEsNkJBQVVGLEtBQVYsRUFBa0JHLEdBQWxCO0FBQ0QsQ0FQRDs7QUFTQTs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7a0JBK0JlLFVBQUNMLEtBQUQsRUFBUVksTUFBUixFQUFnQlIsT0FBaEIsRUFBNEI7QUFDekMsTUFBSSxFQUFFLGFBQWFBLE9BQWYsQ0FBSixFQUE2QixPQUFPSixLQUFQOztBQURZLE1BR2pDYSxhQUhpQyxHQUdmRCxNQUhlLENBR2pDQyxhQUhpQzs7QUFJekMsTUFBTUMsU0FBU0MsT0FBT0MsSUFBUCxDQUFZSCxhQUFaLENBQWY7O0FBRUEsTUFBTUksZ0JBQWdCLFNBQWhCQSxhQUFnQixDQUFDaEIsTUFBRDtBQUFBLFdBQVkseUJBQUUsRUFBRixFQUFNaUIsS0FBTixDQUFZLG9CQUFFVCxJQUFGLENBQU9LLE9BQU9LLEdBQVAsQ0FBVyxpQkFBUztBQUN2RSxVQUNFLENBQUMsOEJBQWVmLFFBQVFnQixPQUF2QixFQUFnQ2xCLEtBQWhDLENBQUQsSUFDQSxDQUFDbUIsUUFBUWpCLFFBQVFnQixPQUFSLENBQWdCbEIsS0FBaEIsQ0FBUixDQUZILEVBR0UsT0FBTyxFQUFQOztBQUpxRSxpQ0FNbkNXLGNBQWNYLEtBQWQsQ0FObUM7QUFBQSxVQU0vRG9CLElBTitELHdCQU0vREEsSUFOK0Q7QUFBQSxVQU16REMsUUFOeUQsd0JBTXpEQSxRQU55RDtBQUFBLFVBTS9DQyxPQU4rQyx3QkFNL0NBLE9BTitDOztBQU92RSxVQUFNQyxlQUFlLG9CQUFFekIsS0FBRixDQUFRc0IsSUFBUixDQUFyQjs7QUFFQSxVQUFJQyxhQUFhLFNBQWpCLEVBQTRCO0FBQzFCLFlBQUksNkJBQWNBLFFBQWQsRUFBd0JDLFFBQVFELFFBQWhDLENBQUosRUFBK0M7QUFDN0MsaUJBQU94QixlQUNMMEIsWUFESyxFQUVMeEIsTUFGSyxFQUdMQyxLQUhLLEVBSUxzQixRQUFRdEIsS0FKSCxFQUtMRSxRQUFRZ0IsT0FBUixDQUFnQmxCLEtBQWhCLENBTEssQ0FBUDtBQU9EOztBQUVELGVBQU9ELE9BQU95QixTQUFQLENBQWlCeEIsS0FBakIsRUFBd0J5QixNQUF4QixDQUNMbkIscUJBQ0VpQixZQURGLEVBRUV4QixNQUZGLEVBR0VDLEtBSEYsRUFJRUUsUUFBUWdCLE9BQVIsQ0FBZ0JsQixLQUFoQixDQUpGLENBREssRUFPTCxFQVBLLENBQVA7QUFTRDs7QUFFRCxhQUFPRCxPQUFPeUIsU0FBUCxDQUFpQnhCLEtBQWpCLEVBQXdCeUIsTUFBeEIsQ0FDTGpCLHNCQUNFZSxZQURGLEVBRUV4QixNQUZGLEVBR0VDLEtBSEYsRUFJRUUsUUFBUWdCLE9BQVIsQ0FBZ0JsQixLQUFoQixDQUpGLENBREssRUFPTCxFQVBLLENBQVA7QUFTRCxLQXhDb0QsQ0FBUCxDQUFaLENBQVo7QUFBQSxHQUF0Qjs7QUEwQ0E7QUFDQUYsVUFBUUEsTUFBTWtCLEtBQU4sQ0FBWUQsYUFBWixDQUFSOztBQUVBLFNBQU9qQixLQUFQO0FBQ0QsQyIsImZpbGUiOiJtZXJnZVJlbGF0aW9uc2hpcHMuanMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgciBmcm9tICdyZXRoaW5rZGInO1xuaW1wb3J0IGFwcGx5T3B0aW9ucyBmcm9tICcuL2FwcGx5T3B0aW9ucyc7XG5pbXBvcnQgaGFzT3duUHJvcGVydHkgZnJvbSAnLi9oYXNPd25Qcm9wZXJ0eSc7XG5pbXBvcnQgcmVxdWlyZXNJbmRleCBmcm9tICcuL3JlcXVpcmVzSW5kZXgnO1xuXG5jb25zdCBtZXJnZVdpdGhJbmRleCA9ICh0YWJsZSwgcmVjb3JkLCBmaWVsZCwgaW5kZXgsIG9wdGlvbnMpID0+IHtcbiAgbGV0IHJvdyA9IHRhYmxlO1xuXG4gIHJvdyA9IHJvdy5nZXRBbGwocmVjb3JkKCdpZCcpLCB7IGluZGV4IH0pO1xuICByb3cgPSByb3cuY29lcmNlVG8oJ2FycmF5Jyk7XG4gIHJvdyA9IGFwcGx5T3B0aW9ucyhyb3csIG9wdGlvbnMpO1xuXG4gIHJldHVybiB7IFtmaWVsZF06IHJvdyB9O1xufTtcblxuY29uc3QgbWVyZ2VXaXRoTWFueVJlY29yZHMgPSAodGFibGUsIHJlY29yZCwgZmllbGQsIG9wdGlvbnMpID0+IHtcbiAgbGV0IHJvdyA9IHRhYmxlO1xuXG4gIHJvdyA9IHJvdy5nZXRBbGwoci5hcmdzKHJlY29yZChmaWVsZCkoJ2lkJykpKTtcbiAgcm93ID0gcm93LmNvZXJjZVRvKCdhcnJheScpO1xuICByb3cgPSBhcHBseU9wdGlvbnMocm93LCBvcHRpb25zKTtcblxuICByZXR1cm4geyBbZmllbGRdOiByb3cgfTtcbn07XG5cbmNvbnN0IG1lcmdlV2l0aFNpbmdsZVJlY29yZCA9ICh0YWJsZSwgcmVjb3JkLCBmaWVsZCwgb3B0aW9ucykgPT4ge1xuICBsZXQgcm93ID0gdGFibGU7XG5cbiAgcm93ID0gcm93LmdldChyZWNvcmQoZmllbGQpKCdpZCcpKTtcbiAgcm93ID0gYXBwbHlPcHRpb25zKHJvdywgb3B0aW9ucyk7XG5cbiAgcmV0dXJuIHsgW2ZpZWxkXTogcm93IH07XG59O1xuXG4vKipcbiAqIERldGVybWluZXMgd2hpY2ggcmVsYXRpb25zaGlwcyB0byBzaWRlbG9hZCBpbiB0aGUgdGFibGUgYmFzZWQgb2ZmIHRoZSBzY2hlbWEncyByZWxhdGlvbnNoaXBzXG4gKiBhbmQgYG9wdGlvbnMuaW5jbHVkZWAuXG4gKlxuICogYGBgXG4gKiAvLyBleGFtcGxlIG9wdGlvbnNcbiAqIGNvbnN0IG9wdGlvbnMgPSB7XG4gKiAgIGluY2x1ZGU6IHtcbiAqICAgICBwZXRzOiB0cnVlLFxuICogICAgIGNvbXBhbnk6IHRydWUsXG4gKiAgICAgYmxvZ3M6IHtcbiAqICAgICAgIGZpbHRlcjogKGJsb2cpID0+IGJsb2coJ3RpdGxlJykuY29udGFpbnMoJ2phdmFzY3JpcHQnKSxcbiAqICAgICAgIHBsdWNrOiB7XG4gKiAgICAgICAgIHRpdGxlOiB0cnVlLFxuICogICAgICAgICBjcmVhdGVkT246IHRydWUsXG4gKiAgICAgICB9LFxuICogICAgICAgaW5jbHVkZTogeyAvLyBUSElTIFdPTidUIFdPUksgKHlldClcbiAqICAgICAgICAgYXV0aG9yOiB0cnVlXG4gKiAgICAgICB9LFxuICogICAgIH0sXG4gKiAgIH0sXG4gKiB9O1xuICogYGBgXG4gKlxuICogTWlzc2luZyByZWxhdGlvbnNoaXAga2V5cyBpbiBgb3B0aW9uc2AgYXJlIGludGVycHJldGVkIGFzIGBmYWxzZWAuXG4gKlxuICogQHBhcmFtIHtPYmplY3R9IHRhYmxlXG4gKiBAcGFyYW0ge09iamVjdH0gc2NoZW1hXG4gKiBAcGFyYW0ge09iamVjdH0gb3B0aW9uc1xuICogQHJldHVybnMge0Z1bmN0aW9ufVxuICovXG5leHBvcnQgZGVmYXVsdCAodGFibGUsIHNjaGVtYSwgb3B0aW9ucykgPT4ge1xuICBpZiAoISgnaW5jbHVkZScgaW4gb3B0aW9ucykpIHJldHVybiB0YWJsZTtcblxuICBjb25zdCB7IHJlbGF0aW9uc2hpcHMgfSA9IHNjaGVtYTtcbiAgY29uc3QgZmllbGRzID0gT2JqZWN0LmtleXMocmVsYXRpb25zaGlwcyk7XG5cbiAgY29uc3QgZmllbGRzVG9NZXJnZSA9IChyZWNvcmQpID0+IHIoe30pLm1lcmdlKHIuYXJncyhmaWVsZHMubWFwKGZpZWxkID0+IHtcbiAgICBpZiAoXG4gICAgICAhaGFzT3duUHJvcGVydHkob3B0aW9ucy5pbmNsdWRlLCBmaWVsZCkgfHxcbiAgICAgICFCb29sZWFuKG9wdGlvbnMuaW5jbHVkZVtmaWVsZF0pXG4gICAgKSByZXR1cm4ge307XG5cbiAgICBjb25zdCB7IHR5cGUsIHJlbGF0aW9uLCBpbnZlcnNlIH0gPSByZWxhdGlvbnNoaXBzW2ZpZWxkXTtcbiAgICBjb25zdCByZWxhdGVkVGFibGUgPSByLnRhYmxlKHR5cGUpO1xuXG4gICAgaWYgKHJlbGF0aW9uID09PSAnaGFzTWFueScpIHtcbiAgICAgIGlmIChyZXF1aXJlc0luZGV4KHJlbGF0aW9uLCBpbnZlcnNlLnJlbGF0aW9uKSkge1xuICAgICAgICByZXR1cm4gbWVyZ2VXaXRoSW5kZXgoXG4gICAgICAgICAgcmVsYXRlZFRhYmxlLFxuICAgICAgICAgIHJlY29yZCxcbiAgICAgICAgICBmaWVsZCxcbiAgICAgICAgICBpbnZlcnNlLmZpZWxkLFxuICAgICAgICAgIG9wdGlvbnMuaW5jbHVkZVtmaWVsZF0sXG4gICAgICAgICk7XG4gICAgICB9XG5cbiAgICAgIHJldHVybiByZWNvcmQuaGFzRmllbGRzKGZpZWxkKS5icmFuY2goXG4gICAgICAgIG1lcmdlV2l0aE1hbnlSZWNvcmRzKFxuICAgICAgICAgIHJlbGF0ZWRUYWJsZSxcbiAgICAgICAgICByZWNvcmQsXG4gICAgICAgICAgZmllbGQsXG4gICAgICAgICAgb3B0aW9ucy5pbmNsdWRlW2ZpZWxkXSxcbiAgICAgICAgKSxcbiAgICAgICAge30sXG4gICAgICApO1xuICAgIH1cblxuICAgIHJldHVybiByZWNvcmQuaGFzRmllbGRzKGZpZWxkKS5icmFuY2goXG4gICAgICBtZXJnZVdpdGhTaW5nbGVSZWNvcmQoXG4gICAgICAgIHJlbGF0ZWRUYWJsZSxcbiAgICAgICAgcmVjb3JkLFxuICAgICAgICBmaWVsZCxcbiAgICAgICAgb3B0aW9ucy5pbmNsdWRlW2ZpZWxkXSxcbiAgICAgICksXG4gICAgICB7fSxcbiAgICApO1xuICB9KSkpO1xuXG4gIC8vIGVzbGludC1kaXNhYmxlLW5leHQtbGluZVxuICB0YWJsZSA9IHRhYmxlLm1lcmdlKGZpZWxkc1RvTWVyZ2UpO1xuXG4gIHJldHVybiB0YWJsZTtcbn07XG4iXX0=
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy91dGlscy9tZXJnZVJlbGF0aW9uc2hpcHMuanMiXSwibmFtZXMiOlsibWVyZ2VXaXRoSW5kZXgiLCJ0YWJsZSIsInJlY29yZCIsImZpZWxkIiwiaW5kZXgiLCJvcHRpb25zIiwicm93IiwiZ2V0QWxsIiwiY29lcmNlVG8iLCJtZXJnZVdpdGhNYW55UmVjb3JkcyIsImFyZ3MiLCJtZXJnZVdpdGhTaW5nbGVSZWNvcmQiLCJnZXQiLCJzY2hlbWEiLCJyZWxhdGlvbnNoaXBzIiwiZmllbGRzIiwiT2JqZWN0Iiwia2V5cyIsImZpZWxkc1RvTWVyZ2UiLCJtZXJnZSIsIm1hcCIsImluY2x1ZGUiLCJCb29sZWFuIiwidHlwZSIsInJlbGF0aW9uIiwiaW52ZXJzZSIsInJlbGF0ZWRUYWJsZSIsImludmVyc2VGaWVsZCIsImZpZWxkT3B0aW9ucyIsImhhc0ZpZWxkcyIsImJyYW5jaCJdLCJtYXBwaW5ncyI6Ijs7Ozs7O0FBQUE7Ozs7QUFDQTs7OztBQUNBOzs7O0FBQ0E7Ozs7Ozs7O0FBRUEsSUFBTUEsaUJBQWlCLFNBQWpCQSxjQUFpQixDQUFDQyxLQUFELEVBQVFDLE1BQVIsRUFBZ0JDLEtBQWhCLEVBQXVCQyxLQUF2QixFQUE4QkMsT0FBOUIsRUFBMEM7QUFDL0QsTUFBSUMsTUFBTUwsS0FBVjs7QUFFQUssUUFBTUEsSUFBSUMsTUFBSixDQUFXTCxPQUFPLElBQVAsQ0FBWCxFQUF5QixFQUFFRSxZQUFGLEVBQXpCLENBQU47QUFDQUUsUUFBTUEsSUFBSUUsUUFBSixDQUFhLE9BQWIsQ0FBTjtBQUNBRixRQUFNLDRCQUFhQSxHQUFiLEVBQWtCRCxPQUFsQixDQUFOOztBQUVBLDZCQUFVRixLQUFWLEVBQWtCRyxHQUFsQjtBQUNELENBUkQ7O0FBVUEsSUFBTUcsdUJBQXVCLFNBQXZCQSxvQkFBdUIsQ0FBQ1IsS0FBRCxFQUFRQyxNQUFSLEVBQWdCQyxLQUFoQixFQUF1QkUsT0FBdkIsRUFBbUM7QUFDOUQsTUFBSUMsTUFBTUwsS0FBVjs7QUFFQUssUUFBTUEsSUFBSUMsTUFBSixDQUFXLG9CQUFFRyxJQUFGLENBQU9SLE9BQU9DLEtBQVAsRUFBYyxJQUFkLENBQVAsQ0FBWCxDQUFOO0FBQ0FHLFFBQU1BLElBQUlFLFFBQUosQ0FBYSxPQUFiLENBQU47QUFDQUYsUUFBTSw0QkFBYUEsR0FBYixFQUFrQkQsT0FBbEIsQ0FBTjs7QUFFQSw2QkFBVUYsS0FBVixFQUFrQkcsR0FBbEI7QUFDRCxDQVJEOztBQVVBLElBQU1LLHdCQUF3QixTQUF4QkEscUJBQXdCLENBQUNWLEtBQUQsRUFBUUMsTUFBUixFQUFnQkMsS0FBaEIsRUFBdUJFLE9BQXZCLEVBQW1DO0FBQy9ELE1BQUlDLE1BQU1MLEtBQVY7O0FBRUFLLFFBQU1BLElBQUlNLEdBQUosQ0FBUVYsT0FBT0MsS0FBUCxFQUFjLElBQWQsQ0FBUixDQUFOO0FBQ0FHLFFBQU0sNEJBQWFBLEdBQWIsRUFBa0JELE9BQWxCLENBQU47O0FBRUEsNkJBQVVGLEtBQVYsRUFBa0JHLEdBQWxCO0FBQ0QsQ0FQRDs7QUFTQTs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7a0JBK0JlLFVBQUNMLEtBQUQsRUFBUVksTUFBUixFQUFnQlIsT0FBaEIsRUFBNEI7QUFDekMsTUFBSSxFQUFFLGFBQWFBLE9BQWYsQ0FBSixFQUE2QixPQUFPSixLQUFQOztBQURZLE1BR2pDYSxhQUhpQyxHQUdmRCxNQUhlLENBR2pDQyxhQUhpQzs7QUFJekMsTUFBTUMsU0FBU0MsT0FBT0MsSUFBUCxDQUFZSCxhQUFaLENBQWY7O0FBRUEsTUFBTUksZ0JBQWdCLFNBQWhCQSxhQUFnQixDQUFDaEIsTUFBRDtBQUFBLFdBQVkseUJBQUUsRUFBRixFQUFNaUIsS0FBTixDQUFZLG9CQUFFVCxJQUFGLENBQU9LLE9BQU9LLEdBQVAsQ0FBVyxpQkFBUztBQUN2RSxVQUNFLENBQUMsOEJBQWVmLFFBQVFnQixPQUF2QixFQUFnQ2xCLEtBQWhDLENBQUQsSUFDQSxDQUFDbUIsUUFBUWpCLFFBQVFnQixPQUFSLENBQWdCbEIsS0FBaEIsQ0FBUixDQUZILEVBR0UsT0FBTyxFQUFQOztBQUpxRSxpQ0FNbkNXLGNBQWNYLEtBQWQsQ0FObUM7QUFBQSxVQU0vRG9CLElBTitELHdCQU0vREEsSUFOK0Q7QUFBQSxVQU16REMsUUFOeUQsd0JBTXpEQSxRQU55RDtBQUFBLFVBTS9DQyxPQU4rQyx3QkFNL0NBLE9BTitDOztBQU92RSxVQUFNQyxlQUFlLG9CQUFFekIsS0FBRixDQUFRc0IsSUFBUixDQUFyQjtBQUNBLFVBQU1JLGVBQWVGLFFBQVF0QixLQUE3QjtBQUNBLFVBQU15QixlQUFldkIsUUFBUWdCLE9BQVIsQ0FBZ0JsQixLQUFoQixDQUFyQjs7QUFFQSxVQUFJcUIsYUFBYSxTQUFqQixFQUE0QjtBQUMxQixZQUFJLDZCQUFjQSxRQUFkLEVBQXdCQyxRQUFRRCxRQUFoQyxDQUFKLEVBQStDO0FBQzdDLGlCQUFPeEIsZUFDTDBCLFlBREssRUFFTHhCLE1BRkssRUFHTEMsS0FISyxFQUlMd0IsWUFKSyxFQUtMQyxZQUxLLENBQVA7QUFPRDs7QUFFRCxlQUFPMUIsT0FBTzJCLFNBQVAsQ0FBaUIxQixLQUFqQixFQUF3QjJCLE1BQXhCLENBQ0xyQixxQkFDRWlCLFlBREYsRUFFRXhCLE1BRkYsRUFHRUMsS0FIRixFQUlFeUIsWUFKRixDQURLLEVBT0wsRUFQSyxDQUFQO0FBU0Q7O0FBRUQsYUFBTzFCLE9BQU8yQixTQUFQLENBQWlCMUIsS0FBakIsRUFBd0IyQixNQUF4QixDQUNMbkIsc0JBQ0VlLFlBREYsRUFFRXhCLE1BRkYsRUFHRUMsS0FIRixFQUlFeUIsWUFKRixDQURLLEVBT0wsRUFQSyxDQUFQO0FBU0QsS0ExQ29ELENBQVAsQ0FBWixDQUFaO0FBQUEsR0FBdEI7O0FBNENBO0FBQ0EzQixVQUFRQSxNQUFNa0IsS0FBTixDQUFZRCxhQUFaLENBQVI7O0FBRUEsU0FBT2pCLEtBQVA7QUFDRCxDIiwiZmlsZSI6Im1lcmdlUmVsYXRpb25zaGlwcy5qcyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCByIGZyb20gJ3JldGhpbmtkYic7XG5pbXBvcnQgYXBwbHlPcHRpb25zIGZyb20gJy4vYXBwbHlPcHRpb25zJztcbmltcG9ydCBoYXNPd25Qcm9wZXJ0eSBmcm9tICcuL2hhc093blByb3BlcnR5JztcbmltcG9ydCByZXF1aXJlc0luZGV4IGZyb20gJy4vcmVxdWlyZXNJbmRleCc7XG5cbmNvbnN0IG1lcmdlV2l0aEluZGV4ID0gKHRhYmxlLCByZWNvcmQsIGZpZWxkLCBpbmRleCwgb3B0aW9ucykgPT4ge1xuICBsZXQgcm93ID0gdGFibGU7XG5cbiAgcm93ID0gcm93LmdldEFsbChyZWNvcmQoJ2lkJyksIHsgaW5kZXggfSk7XG4gIHJvdyA9IHJvdy5jb2VyY2VUbygnYXJyYXknKTtcbiAgcm93ID0gYXBwbHlPcHRpb25zKHJvdywgb3B0aW9ucyk7XG5cbiAgcmV0dXJuIHsgW2ZpZWxkXTogcm93IH07XG59O1xuXG5jb25zdCBtZXJnZVdpdGhNYW55UmVjb3JkcyA9ICh0YWJsZSwgcmVjb3JkLCBmaWVsZCwgb3B0aW9ucykgPT4ge1xuICBsZXQgcm93ID0gdGFibGU7XG5cbiAgcm93ID0gcm93LmdldEFsbChyLmFyZ3MocmVjb3JkKGZpZWxkKSgnaWQnKSkpO1xuICByb3cgPSByb3cuY29lcmNlVG8oJ2FycmF5Jyk7XG4gIHJvdyA9IGFwcGx5T3B0aW9ucyhyb3csIG9wdGlvbnMpO1xuXG4gIHJldHVybiB7IFtmaWVsZF06IHJvdyB9O1xufTtcblxuY29uc3QgbWVyZ2VXaXRoU2luZ2xlUmVjb3JkID0gKHRhYmxlLCByZWNvcmQsIGZpZWxkLCBvcHRpb25zKSA9PiB7XG4gIGxldCByb3cgPSB0YWJsZTtcblxuICByb3cgPSByb3cuZ2V0KHJlY29yZChmaWVsZCkoJ2lkJykpO1xuICByb3cgPSBhcHBseU9wdGlvbnMocm93LCBvcHRpb25zKTtcblxuICByZXR1cm4geyBbZmllbGRdOiByb3cgfTtcbn07XG5cbi8qKlxuICogRGV0ZXJtaW5lcyB3aGljaCByZWxhdGlvbnNoaXBzIHRvIHNpZGVsb2FkIGluIHRoZSB0YWJsZSBiYXNlZCBvZmYgdGhlIHNjaGVtYSdzIHJlbGF0aW9uc2hpcHNcbiAqIGFuZCBgb3B0aW9ucy5pbmNsdWRlYC5cbiAqXG4gKiBgYGBcbiAqIC8vIGV4YW1wbGUgb3B0aW9uc1xuICogY29uc3Qgb3B0aW9ucyA9IHtcbiAqICAgaW5jbHVkZToge1xuICogICAgIHBldHM6IHRydWUsXG4gKiAgICAgY29tcGFueTogdHJ1ZSxcbiAqICAgICBibG9nczoge1xuICogICAgICAgZmlsdGVyOiAoYmxvZykgPT4gYmxvZygndGl0bGUnKS5jb250YWlucygnamF2YXNjcmlwdCcpLFxuICogICAgICAgcGx1Y2s6IHtcbiAqICAgICAgICAgdGl0bGU6IHRydWUsXG4gKiAgICAgICAgIGNyZWF0ZWRPbjogdHJ1ZSxcbiAqICAgICAgIH0sXG4gKiAgICAgICBpbmNsdWRlOiB7IC8vIFRISVMgV09OJ1QgV09SSyAoeWV0KVxuICogICAgICAgICBhdXRob3I6IHRydWVcbiAqICAgICAgIH0sXG4gKiAgICAgfSxcbiAqICAgfSxcbiAqIH07XG4gKiBgYGBcbiAqXG4gKiBNaXNzaW5nIHJlbGF0aW9uc2hpcCBrZXlzIGluIGBvcHRpb25zYCBhcmUgaW50ZXJwcmV0ZWQgYXMgYGZhbHNlYC5cbiAqXG4gKiBAcGFyYW0ge09iamVjdH0gdGFibGVcbiAqIEBwYXJhbSB7T2JqZWN0fSBzY2hlbWFcbiAqIEBwYXJhbSB7T2JqZWN0fSBvcHRpb25zXG4gKiBAcmV0dXJucyB7RnVuY3Rpb259XG4gKi9cbmV4cG9ydCBkZWZhdWx0ICh0YWJsZSwgc2NoZW1hLCBvcHRpb25zKSA9PiB7XG4gIGlmICghKCdpbmNsdWRlJyBpbiBvcHRpb25zKSkgcmV0dXJuIHRhYmxlO1xuXG4gIGNvbnN0IHsgcmVsYXRpb25zaGlwcyB9ID0gc2NoZW1hO1xuICBjb25zdCBmaWVsZHMgPSBPYmplY3Qua2V5cyhyZWxhdGlvbnNoaXBzKTtcblxuICBjb25zdCBmaWVsZHNUb01lcmdlID0gKHJlY29yZCkgPT4gcih7fSkubWVyZ2Uoci5hcmdzKGZpZWxkcy5tYXAoZmllbGQgPT4ge1xuICAgIGlmIChcbiAgICAgICFoYXNPd25Qcm9wZXJ0eShvcHRpb25zLmluY2x1ZGUsIGZpZWxkKSB8fFxuICAgICAgIUJvb2xlYW4ob3B0aW9ucy5pbmNsdWRlW2ZpZWxkXSlcbiAgICApIHJldHVybiB7fTtcblxuICAgIGNvbnN0IHsgdHlwZSwgcmVsYXRpb24sIGludmVyc2UgfSA9IHJlbGF0aW9uc2hpcHNbZmllbGRdO1xuICAgIGNvbnN0IHJlbGF0ZWRUYWJsZSA9IHIudGFibGUodHlwZSk7XG4gICAgY29uc3QgaW52ZXJzZUZpZWxkID0gaW52ZXJzZS5maWVsZDtcbiAgICBjb25zdCBmaWVsZE9wdGlvbnMgPSBvcHRpb25zLmluY2x1ZGVbZmllbGRdO1xuXG4gICAgaWYgKHJlbGF0aW9uID09PSAnaGFzTWFueScpIHtcbiAgICAgIGlmIChyZXF1aXJlc0luZGV4KHJlbGF0aW9uLCBpbnZlcnNlLnJlbGF0aW9uKSkge1xuICAgICAgICByZXR1cm4gbWVyZ2VXaXRoSW5kZXgoXG4gICAgICAgICAgcmVsYXRlZFRhYmxlLFxuICAgICAgICAgIHJlY29yZCxcbiAgICAgICAgICBmaWVsZCxcbiAgICAgICAgICBpbnZlcnNlRmllbGQsXG4gICAgICAgICAgZmllbGRPcHRpb25zLFxuICAgICAgICApO1xuICAgICAgfVxuXG4gICAgICByZXR1cm4gcmVjb3JkLmhhc0ZpZWxkcyhmaWVsZCkuYnJhbmNoKFxuICAgICAgICBtZXJnZVdpdGhNYW55UmVjb3JkcyhcbiAgICAgICAgICByZWxhdGVkVGFibGUsXG4gICAgICAgICAgcmVjb3JkLFxuICAgICAgICAgIGZpZWxkLFxuICAgICAgICAgIGZpZWxkT3B0aW9ucyxcbiAgICAgICAgKSxcbiAgICAgICAge30sXG4gICAgICApO1xuICAgIH1cblxuICAgIHJldHVybiByZWNvcmQuaGFzRmllbGRzKGZpZWxkKS5icmFuY2goXG4gICAgICBtZXJnZVdpdGhTaW5nbGVSZWNvcmQoXG4gICAgICAgIHJlbGF0ZWRUYWJsZSxcbiAgICAgICAgcmVjb3JkLFxuICAgICAgICBmaWVsZCxcbiAgICAgICAgZmllbGRPcHRpb25zLFxuICAgICAgKSxcbiAgICAgIHt9LFxuICAgICk7XG4gIH0pKSk7XG5cbiAgLy8gZXNsaW50LWRpc2FibGUtbmV4dC1saW5lXG4gIHRhYmxlID0gdGFibGUubWVyZ2UoZmllbGRzVG9NZXJnZSk7XG5cbiAgcmV0dXJuIHRhYmxlO1xufTtcbiJdfQ==
{
"name": "redink",
"version": "2.0.0-beta.24",
"version": "2.0.0-beta.25",
"description": "RethinkDB model layer",

@@ -5,0 +5,0 @@ "main": "dist/index.js",

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