From f5a20ea3e5aef6c1f2be83697d99e65aa863eef8 Mon Sep 17 00:00:00 2001 From: prih Date: Fri, 11 Dec 2020 01:20:39 +0200 Subject: [PATCH 1/8] fix: parse result, prebuild clean, remove GEO type --- lib/data-types.js | 115 ------------------------------ lib/dialects/sqlite/data-types.js | 1 - lib/dialects/sqlite/query.js | 2 +- package.json | 5 +- 4 files changed, 3 insertions(+), 120 deletions(-) diff --git a/lib/data-types.js b/lib/data-types.js index 68272ed..f29c3bd 100644 --- a/lib/data-types.js +++ b/lib/data-types.js @@ -2,7 +2,6 @@ const util = require('util'); const _ = require('lodash'); -const wkx = require('wkx'); const sequelizeErrors = require('./errors'); const Validator = require('./utils/validator-extras').validator; const momentTz = require('moment-timezone'); @@ -778,118 +777,6 @@ class ARRAY extends ABSTRACT { } } -/** - * A column storing Geometry information. - * It is only available in PostgreSQL (with PostGIS), MariaDB or MySQL. - * - * GeoJSON is accepted as input and returned as output. - * - * In PostGIS, the GeoJSON is parsed using the PostGIS function `ST_GeomFromGeoJSON`. - * In MySQL it is parsed using the function `GeomFromText`. - * - * Therefore, one can just follow the [GeoJSON spec](http://geojson.org/geojson-spec.html) for handling geometry objects. See the following examples: - * - * @example Defining a Geometry type attribute - * DataTypes.GEOMETRY - * DataTypes.GEOMETRY('POINT') - * DataTypes.GEOMETRY('POINT', 4326) - * - * @example Create a new point - * const point = { type: 'Point', coordinates: [39.807222,-76.984722]}; - * - * User.create({username: 'username', geometry: point }); - * - * @example Create a new linestring - * const line = { type: 'LineString', 'coordinates': [ [100.0, 0.0], [101.0, 1.0] ] }; - * - * User.create({username: 'username', geometry: line }); - * - * @example Create a new polygon - * const polygon = { type: 'Polygon', coordinates: [ - * [ [100.0, 0.0], [101.0, 0.0], [101.0, 1.0], - * [100.0, 1.0], [100.0, 0.0] ] - * ]}; - * - * User.create({username: 'username', geometry: polygon }); - * - * @example Create a new point with a custom SRID - * const point = { - * type: 'Point', - * coordinates: [39.807222,-76.984722], - * crs: { type: 'name', properties: { name: 'EPSG:4326'} } - * }; - * - * User.create({username: 'username', geometry: point }) - * - * - * @see {@link DataTypes.GEOGRAPHY} - */ -class GEOMETRY extends ABSTRACT { - /** - * @param {string} [type] Type of geometry data - * @param {string} [srid] SRID of type - */ - constructor(type, srid) { - super(); - const options = _.isPlainObject(type) ? type : { type, srid }; - this.options = options; - this.type = options.type; - this.srid = options.srid; - } - _stringify(value, options) { - return `GeomFromText(${options.escape(wkx.Geometry.parseGeoJSON(value).toWkt())})`; - } - _bindParam(value, options) { - return `GeomFromText(${options.bindParam(wkx.Geometry.parseGeoJSON(value).toWkt())})`; - } -} - -GEOMETRY.prototype.escape = false; - -/** - * A geography datatype represents two dimensional spacial objects in an elliptic coord system. - * - * __The difference from geometry and geography type:__ - * - * PostGIS 1.5 introduced a new spatial type called geography, which uses geodetic measurement instead of Cartesian measurement. - * Coordinate points in the geography type are always represented in WGS 84 lon lat degrees (SRID 4326), - * but measurement functions and relationships ST_Distance, ST_DWithin, ST_Length, and ST_Area always return answers in meters or assume inputs in meters. - * - * __What is best to use? It depends:__ - * - * When choosing between the geometry and geography type for data storage, you should consider what you’ll be using it for. - * If all you do are simple measurements and relationship checks on your data, and your data covers a fairly large area, then most likely you’ll be better off storing your data using the new geography type. - * Although the new geography data type can cover the globe, the geometry type is far from obsolete. - * The geometry type has a much richer set of functions than geography, relationship checks are generally faster, and it has wider support currently across desktop and web-mapping tools - * - * @example Defining a Geography type attribute - * DataTypes.GEOGRAPHY - * DataTypes.GEOGRAPHY('POINT') - * DataTypes.GEOGRAPHY('POINT', 4326) - */ -class GEOGRAPHY extends ABSTRACT { - /** - * @param {string} [type] Type of geography data - * @param {string} [srid] SRID of type - */ - constructor(type, srid) { - super(); - const options = _.isPlainObject(type) ? type : { type, srid }; - this.options = options; - this.type = options.type; - this.srid = options.srid; - } - _stringify(value, options) { - return `GeomFromText(${options.escape(wkx.Geometry.parseGeoJSON(value).toWkt())})`; - } - _bindParam(value, options) { - return `GeomFromText(${options.bindParam(wkx.Geometry.parseGeoJSON(value).toWkt())})`; - } -} - - -GEOGRAPHY.prototype.escape = false; - /** * The cidr type holds an IPv4 or IPv6 network specification. Takes 7 or 19 bytes. * @@ -1011,8 +898,6 @@ const DataTypes = module.exports = { REAL, 'DOUBLE PRECISION': DOUBLE, DOUBLE, - GEOMETRY, - GEOGRAPHY, CIDR, INET, MACADDR, diff --git a/lib/dialects/sqlite/data-types.js b/lib/dialects/sqlite/data-types.js index d3a9ff3..eabb0a5 100644 --- a/lib/dialects/sqlite/data-types.js +++ b/lib/dialects/sqlite/data-types.js @@ -45,7 +45,6 @@ module.exports = BaseTypes => { BaseTypes.ENUM.types.sqlite = false; BaseTypes.REAL.types.sqlite = ["REAL"]; BaseTypes.DOUBLE.types.sqlite = ["DOUBLE PRECISION"]; - BaseTypes.GEOMETRY.types.sqlite = false; BaseTypes.JSON.types.sqlite = ["JSON", "JSONB"]; class JSONTYPE extends BaseTypes.JSON { diff --git a/lib/dialects/sqlite/query.js b/lib/dialects/sqlite/query.js index ca9030b..2b2fe3f 100644 --- a/lib/dialects/sqlite/query.js +++ b/lib/dialects/sqlite/query.js @@ -355,7 +355,7 @@ class Query extends AbstractQuery { return null; }; - if (method === "all" && typeof conn.exec === "function") { + if (method === "all") { let tableNames = []; if (this.options && this.options.tableNames) { tableNames = this.options.tableNames; diff --git a/package.json b/package.json index 31d5ae2..c17d4ed 100644 --- a/package.json +++ b/package.json @@ -12,7 +12,7 @@ ], "scripts": { "build": "babel lib --out-dir dist --copy-files --source-maps inline", - "prebuild": "if exist dist RMDIR /Q/S dist 2>nul", + "prebuild": "rm -rf dist && mkdir dist", "publish": "npm publish --access public" }, "bugs": { @@ -45,8 +45,7 @@ "toposort-class": "^1.0.1", "util": "^0.12.1", "uuid": "^3.3.3", - "validator": "^10.11.0", - "wkx": "^0.4.8" + "validator": "^10.11.0" }, "devDependencies": { "@babel/cli": "^7.7.4", From 3dcd7349a7d6b74cec36542b399eb34b905715e1 Mon Sep 17 00:00:00 2001 From: prih Date: Fri, 11 Dec 2020 01:21:24 +0200 Subject: [PATCH 2/8] build --- dist/associations/base.js | 6 +- dist/associations/belongs-to-many.js | 22 +- dist/associations/belongs-to.js | 22 +- dist/associations/has-many.js | 22 +- dist/associations/has-one.js | 22 +- dist/associations/helpers.js | 2 +- dist/associations/index.js | 2 +- dist/associations/mixin.js | 2 +- dist/data-types.js | 455 ++++++------------ dist/deferrable.js | 58 +-- dist/dialects/abstract/connection-manager.js | 6 +- dist/dialects/abstract/index.js | 2 +- dist/dialects/abstract/query-generator.js | 8 +- .../abstract/query-generator/helpers/quote.js | 2 +- .../abstract/query-generator/operators.js | 2 +- .../abstract/query-generator/transaction.js | 2 +- dist/dialects/abstract/query.js | 6 +- dist/dialects/mysql/query-generator.js | 26 +- dist/dialects/parserStore.js | 2 +- dist/dialects/sqlite/connection-manager.js | 26 +- dist/dialects/sqlite/data-types.js | 153 +++--- dist/dialects/sqlite/index.js | 22 +- dist/dialects/sqlite/query-generator.js | 26 +- dist/dialects/sqlite/query-interface.js | 2 +- dist/dialects/sqlite/query.js | 29 +- dist/errors/association-error.js | 22 +- dist/errors/base-error.js | 22 +- dist/errors/bulk-record-error.js | 22 +- dist/errors/connection-error.js | 22 +- dist/errors/connection/access-denied-error.js | 22 +- .../connection-acquire-timeout-error.js | 22 +- .../connection/connection-refused-error.js | 22 +- .../connection/connection-timed-out-error.js | 22 +- .../errors/connection/host-not-found-error.js | 22 +- .../connection/host-not-reachable-error.js | 22 +- .../connection/invalid-connection-error.js | 22 +- dist/errors/database-error.js | 22 +- .../database/exclusion-constraint-error.js | 22 +- .../database/foreign-key-constraint-error.js | 22 +- dist/errors/database/timeout-error.js | 22 +- .../database/unknown-constraint-error.js | 22 +- dist/errors/eager-loading-error.js | 22 +- dist/errors/empty-result-error.js | 22 +- dist/errors/index.js | 2 +- dist/errors/instance-error.js | 22 +- dist/errors/optimistic-lock-error.js | 22 +- dist/errors/query-error.js | 22 +- dist/errors/sequelize-scope-error.js | 22 +- dist/errors/validation-error.js | 26 +- .../validation/unique-constraint-error.js | 22 +- dist/hooks.js | 2 +- dist/index-hints.js | 2 +- dist/instance-validator.js | 6 +- dist/model-manager.js | 6 +- dist/model.js | 38 +- dist/operators.js | 2 +- dist/promise.js | 2 +- dist/query-interface.js | 6 +- dist/query-types.js | 2 +- dist/sequelize.js | 26 +- dist/sql-string.js | 2 +- dist/table-hints.js | 2 +- dist/transaction.js | 6 +- dist/utils.js | 62 +-- dist/utils/classToInvokable.js | 2 +- dist/utils/deprecations.js | 2 +- dist/utils/logger.js | 6 +- dist/utils/validator-extras.js | 2 +- 68 files changed, 805 insertions(+), 832 deletions(-) diff --git a/dist/associations/base.js b/dist/associations/base.js index 0511d92..b06125b 100644 --- a/dist/associations/base.js +++ b/dist/associations/base.js @@ -88,9 +88,7 @@ const { */ -let Association = -/*#__PURE__*/ -function () { +let Association = /*#__PURE__*/function () { function Association(source, target, options = {}) { _classCallCheck(this, Association); @@ -160,4 +158,4 @@ function () { }(); module.exports = Association; -//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../lib/associations/base.js"],"names":["AssociationError","require","Association","source","target","options","scope","isSelfAssociation","as","associationType","hasAlias","input","Array","isArray","map","element","tmpInstance","primaryKeyAttribute","build","isNewRecord","Symbol","for","module","exports"],"mappings":"AAAA;;;;;;;;AAEA,MAAM;AAAEA,EAAAA;AAAF,IAAuBC,OAAO,CAAC,aAAD,CAApC;AAEA;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;IA6EMC,W;;;AACJ,uBAAYC,MAAZ,EAAoBC,MAApB,EAA4BC,OAAO,GAAG,EAAtC,EAA0C;AAAA;;AACxC;;;AAGA,SAAKF,MAAL,GAAcA,MAAd;AAEA;;;;AAGA,SAAKC,MAAL,GAAcA,MAAd;AAEA,SAAKC,OAAL,GAAeA,OAAf;AACA,SAAKC,KAAL,GAAaD,OAAO,CAACC,KAArB;AACA,SAAKC,iBAAL,GAAyB,KAAKJ,MAAL,KAAgB,KAAKC,MAA9C;AACA,SAAKI,EAAL,GAAUH,OAAO,CAACG,EAAlB;AAEA;;;;;AAIA,SAAKC,eAAL,GAAuB,EAAvB;;AAEA,QAAIN,MAAM,CAACO,QAAP,CAAgBL,OAAO,CAACG,EAAxB,CAAJ,EAAiC;AAC/B,YAAM,IAAIR,gBAAJ,CAAsB,2BAA0BK,OAAO,CAACG,EAAG,iCAAtC,GAC3B,gDADM,CAAN;AAGD;AACF;AAED;;;;;;;;;;;;oCAQgBG,K,EAAO;AACrB,UAAI,CAACC,KAAK,CAACC,OAAN,CAAcF,KAAd,CAAL,EAA2B;AACzBA,QAAAA,KAAK,GAAG,CAACA,KAAD,CAAR;AACD;;AAED,aAAOA,KAAK,CAACG,GAAN,CAAUC,OAAO,IAAI;AAC1B,YAAIA,OAAO,YAAY,KAAKX,MAA5B,EAAoC,OAAOW,OAAP;AAEpC,cAAMC,WAAW,GAAG,EAApB;AACAA,QAAAA,WAAW,CAAC,KAAKZ,MAAL,CAAYa,mBAAb,CAAX,GAA+CF,OAA/C;AAEA,eAAO,KAAKX,MAAL,CAAYc,KAAZ,CAAkBF,WAAlB,EAA+B;AAAEG,UAAAA,WAAW,EAAE;AAAf,SAA/B,CAAP;AACD,OAPM,CAAP;AAQD;;SAEAC,MAAM,CAACC,GAAP,CAAW,4BAAX,C;uBAA4C;AAC3C,aAAO,KAAKb,EAAZ;AACD;;;8BAES;AACR,aAAO,KAAKA,EAAZ;AACD;;;;;;AAGHc,MAAM,CAACC,OAAP,GAAiBrB,WAAjB","sourcesContent":["'use strict';\r\n\r\nconst { AssociationError } = require('./../errors');\r\n\r\n/**\r\n * Creating associations in sequelize is done by calling one of the belongsTo / hasOne / hasMany / belongsToMany functions on a model (the source), and providing another model as the first argument to the function (the target).\r\n *\r\n * * hasOne - adds a foreign key to the target and singular association mixins to the source.\r\n * * belongsTo - add a foreign key and singular association mixins to the source.\r\n * * hasMany - adds a foreign key to target and plural association mixins to the source.\r\n * * belongsToMany - creates an N:M association with a join table and adds plural association mixins to the source. The junction table is created with sourceId and targetId.\r\n *\r\n * Creating an association will add a foreign key constraint to the attributes. All associations use `CASCADE` on update and `SET NULL` on delete, except for n:m, which also uses `CASCADE` on delete.\r\n *\r\n * When creating associations, you can provide an alias, via the `as` option. This is useful if the same model is associated twice, or you want your association to be called something other than the name of the target model.\r\n *\r\n * As an example, consider the case where users have many pictures, one of which is their profile picture. All pictures have a `userId`, but in addition the user model also has a `profilePictureId`, to be able to easily load the user's profile picture.\r\n *\r\n * ```js\r\n * User.hasMany(Picture)\r\n * User.belongsTo(Picture, { as: 'ProfilePicture', constraints: false })\r\n *\r\n * user.getPictures() // gets you all pictures\r\n * user.getProfilePicture() // gets you only the profile picture\r\n *\r\n * User.findAll({\r\n *   where: ...,\r\n *   include: [\r\n *     { model: Picture }, // load all pictures\r\n *     { model: Picture, as: 'ProfilePicture' }, // load the profile picture.\r\n *     // Notice that the spelling must be the exact same as the one in the association\r\n *   ]\r\n * })\r\n * ```\r\n * To get full control over the foreign key column added by sequelize, you can use the `foreignKey` option. It can either be a string, that specifies the name, or and object type definition,\r\n * equivalent to those passed to `sequelize.define`.\r\n *\r\n * ```js\r\n * User.hasMany(Picture, { foreignKey: 'uid' })\r\n * ```\r\n *\r\n * The foreign key column in Picture will now be called `uid` instead of the default `userId`.\r\n *\r\n * ```js\r\n * User.hasMany(Picture, {\r\n *   foreignKey: {\r\n *     name: 'uid',\r\n *     allowNull: false\r\n *   }\r\n * })\r\n * ```\r\n *\r\n * This specifies that the `uid` column cannot be null. In most cases this will already be covered by the foreign key constraints, which sequelize creates automatically, but can be useful in case where the foreign keys are disabled, e.g. due to circular references (see `constraints: false` below).\r\n *\r\n * When fetching associated models, you can limit your query to only load some models. These queries are written in the same way as queries to `find`/`findAll`. To only get pictures in JPG, you can do:\r\n *\r\n * ```js\r\n * user.getPictures({\r\n *   where: {\r\n *     format: 'jpg'\r\n *   }\r\n * })\r\n * ```\r\n *\r\n * There are several ways to update and add new associations. Continuing with our example of users and pictures:\r\n * ```js\r\n * user.addPicture(p) // Add a single picture\r\n * user.setPictures([p1, p2]) // Associate user with ONLY these two picture, all other associations will be deleted\r\n * user.addPictures([p1, p2]) // Associate user with these two pictures, but don't touch any current associations\r\n * ```\r\n *\r\n * You don't have to pass in a complete object to the association functions, if your associated model has a single primary key:\r\n *\r\n * ```js\r\n * user.addPicture(req.query.pid) // Here pid is just an integer, representing the primary key of the picture\r\n * ```\r\n *\r\n * In the example above we have specified that a user belongs to his profile picture. Conceptually, this might not make sense, but since we want to add the foreign key to the user model this is the way to do it.\r\n *\r\n * Note how we also specified `constraints: false` for profile picture. This is because we add a foreign key from user to picture (profilePictureId), and from picture to user (userId). If we were to add foreign keys to both, it would create a cyclic dependency, and sequelize would not know which table to create first, since user depends on picture, and picture depends on user. These kinds of problems are detected by sequelize before the models are synced to the database, and you will get an error along the lines of `Error: Cyclic dependency found. 'users' is dependent of itself`. If you encounter this, you should either disable some constraints, or rethink your associations completely.\r\n */\r\nclass Association {\r\n  constructor(source, target, options = {}) {\r\n    /**\r\n     * @type {Model}\r\n     */\r\n    this.source = source;\r\n\r\n    /**\r\n     * @type {Model}\r\n     */\r\n    this.target = target;\r\n\r\n    this.options = options;\r\n    this.scope = options.scope;\r\n    this.isSelfAssociation = this.source === this.target;\r\n    this.as = options.as;\r\n\r\n    /**\r\n     * The type of the association. One of `HasMany`, `BelongsTo`, `HasOne`, `BelongsToMany`\r\n     * @type {string}\r\n     */\r\n    this.associationType = '';\r\n\r\n    if (source.hasAlias(options.as)) {\r\n      throw new AssociationError(`You have used the alias ${options.as} in two separate associations. ` +\r\n      'Aliased associations must have unique aliases.'\r\n      );\r\n    }\r\n  }\r\n\r\n  /**\r\n   * Normalize input\r\n   *\r\n   * @param {Array|string} input it may be array or single obj, instance or primary key\r\n   *\r\n   * @private\r\n   * @returns {Array} built objects\r\n   */\r\n  toInstanceArray(input) {\r\n    if (!Array.isArray(input)) {\r\n      input = [input];\r\n    }\r\n\r\n    return input.map(element => {\r\n      if (element instanceof this.target) return element;\r\n\r\n      const tmpInstance = {};\r\n      tmpInstance[this.target.primaryKeyAttribute] = element;\r\n\r\n      return this.target.build(tmpInstance, { isNewRecord: false });\r\n    });\r\n  }\r\n\r\n  [Symbol.for('nodejs.util.inspect.custom')]() {\r\n    return this.as;\r\n  }\r\n\r\n  inspect() {\r\n    return this.as;\r\n  }\r\n}\r\n\r\nmodule.exports = Association;\r\n"]} \ No newline at end of file +//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../lib/associations/base.js"],"names":["AssociationError","require","Association","source","target","options","scope","isSelfAssociation","as","associationType","hasAlias","input","Array","isArray","map","element","tmpInstance","primaryKeyAttribute","build","isNewRecord","Symbol","for","module","exports"],"mappings":"AAAA;;;;;;;;AAEA,MAAM;AAAEA,EAAAA;AAAF,IAAuBC,OAAO,CAAC,aAAD,CAApC;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;IACMC,W;AACJ,uBAAYC,MAAZ,EAAoBC,MAApB,EAA4BC,OAAO,GAAG,EAAtC,EAA0C;AAAA;;AACxC;AACJ;AACA;AACI,SAAKF,MAAL,GAAcA,MAAd;AAEA;AACJ;AACA;;AACI,SAAKC,MAAL,GAAcA,MAAd;AAEA,SAAKC,OAAL,GAAeA,OAAf;AACA,SAAKC,KAAL,GAAaD,OAAO,CAACC,KAArB;AACA,SAAKC,iBAAL,GAAyB,KAAKJ,MAAL,KAAgB,KAAKC,MAA9C;AACA,SAAKI,EAAL,GAAUH,OAAO,CAACG,EAAlB;AAEA;AACJ;AACA;AACA;;AACI,SAAKC,eAAL,GAAuB,EAAvB;;AAEA,QAAIN,MAAM,CAACO,QAAP,CAAgBL,OAAO,CAACG,EAAxB,CAAJ,EAAiC;AAC/B,YAAM,IAAIR,gBAAJ,CAAsB,2BAA0BK,OAAO,CAACG,EAAG,iCAAtC,GAC3B,gDADM,CAAN;AAGD;AACF;AAED;AACF;AACA;AACA;AACA;AACA;AACA;AACA;;;;;oCACkBG,K,EAAO;AACrB,UAAI,CAACC,KAAK,CAACC,OAAN,CAAcF,KAAd,CAAL,EAA2B;AACzBA,QAAAA,KAAK,GAAG,CAACA,KAAD,CAAR;AACD;;AAED,aAAOA,KAAK,CAACG,GAAN,CAAUC,OAAO,IAAI;AAC1B,YAAIA,OAAO,YAAY,KAAKX,MAA5B,EAAoC,OAAOW,OAAP;AAEpC,cAAMC,WAAW,GAAG,EAApB;AACAA,QAAAA,WAAW,CAAC,KAAKZ,MAAL,CAAYa,mBAAb,CAAX,GAA+CF,OAA/C;AAEA,eAAO,KAAKX,MAAL,CAAYc,KAAZ,CAAkBF,WAAlB,EAA+B;AAAEG,UAAAA,WAAW,EAAE;AAAf,SAA/B,CAAP;AACD,OAPM,CAAP;AAQD;;SAEAC,MAAM,CAACC,GAAP,CAAW,4BAAX,C;uBAA4C;AAC3C,aAAO,KAAKb,EAAZ;AACD;;;8BAES;AACR,aAAO,KAAKA,EAAZ;AACD;;;;;;AAGHc,MAAM,CAACC,OAAP,GAAiBrB,WAAjB","sourcesContent":["'use strict';\n\nconst { AssociationError } = require('./../errors');\n\n/**\n * Creating associations in sequelize is done by calling one of the belongsTo / hasOne / hasMany / belongsToMany functions on a model (the source), and providing another model as the first argument to the function (the target).\n *\n * * hasOne - adds a foreign key to the target and singular association mixins to the source.\n * * belongsTo - add a foreign key and singular association mixins to the source.\n * * hasMany - adds a foreign key to target and plural association mixins to the source.\n * * belongsToMany - creates an N:M association with a join table and adds plural association mixins to the source. The junction table is created with sourceId and targetId.\n *\n * Creating an association will add a foreign key constraint to the attributes. All associations use `CASCADE` on update and `SET NULL` on delete, except for n:m, which also uses `CASCADE` on delete.\n *\n * When creating associations, you can provide an alias, via the `as` option. This is useful if the same model is associated twice, or you want your association to be called something other than the name of the target model.\n *\n * As an example, consider the case where users have many pictures, one of which is their profile picture. All pictures have a `userId`, but in addition the user model also has a `profilePictureId`, to be able to easily load the user's profile picture.\n *\n * ```js\n * User.hasMany(Picture)\n * User.belongsTo(Picture, { as: 'ProfilePicture', constraints: false })\n *\n * user.getPictures() // gets you all pictures\n * user.getProfilePicture() // gets you only the profile picture\n *\n * User.findAll({\n *   where: ...,\n *   include: [\n *     { model: Picture }, // load all pictures\n *     { model: Picture, as: 'ProfilePicture' }, // load the profile picture.\n *     // Notice that the spelling must be the exact same as the one in the association\n *   ]\n * })\n * ```\n * To get full control over the foreign key column added by sequelize, you can use the `foreignKey` option. It can either be a string, that specifies the name, or and object type definition,\n * equivalent to those passed to `sequelize.define`.\n *\n * ```js\n * User.hasMany(Picture, { foreignKey: 'uid' })\n * ```\n *\n * The foreign key column in Picture will now be called `uid` instead of the default `userId`.\n *\n * ```js\n * User.hasMany(Picture, {\n *   foreignKey: {\n *     name: 'uid',\n *     allowNull: false\n *   }\n * })\n * ```\n *\n * This specifies that the `uid` column cannot be null. In most cases this will already be covered by the foreign key constraints, which sequelize creates automatically, but can be useful in case where the foreign keys are disabled, e.g. due to circular references (see `constraints: false` below).\n *\n * When fetching associated models, you can limit your query to only load some models. These queries are written in the same way as queries to `find`/`findAll`. To only get pictures in JPG, you can do:\n *\n * ```js\n * user.getPictures({\n *   where: {\n *     format: 'jpg'\n *   }\n * })\n * ```\n *\n * There are several ways to update and add new associations. Continuing with our example of users and pictures:\n * ```js\n * user.addPicture(p) // Add a single picture\n * user.setPictures([p1, p2]) // Associate user with ONLY these two picture, all other associations will be deleted\n * user.addPictures([p1, p2]) // Associate user with these two pictures, but don't touch any current associations\n * ```\n *\n * You don't have to pass in a complete object to the association functions, if your associated model has a single primary key:\n *\n * ```js\n * user.addPicture(req.query.pid) // Here pid is just an integer, representing the primary key of the picture\n * ```\n *\n * In the example above we have specified that a user belongs to his profile picture. Conceptually, this might not make sense, but since we want to add the foreign key to the user model this is the way to do it.\n *\n * Note how we also specified `constraints: false` for profile picture. This is because we add a foreign key from user to picture (profilePictureId), and from picture to user (userId). If we were to add foreign keys to both, it would create a cyclic dependency, and sequelize would not know which table to create first, since user depends on picture, and picture depends on user. These kinds of problems are detected by sequelize before the models are synced to the database, and you will get an error along the lines of `Error: Cyclic dependency found. 'users' is dependent of itself`. If you encounter this, you should either disable some constraints, or rethink your associations completely.\n */\nclass Association {\n  constructor(source, target, options = {}) {\n    /**\n     * @type {Model}\n     */\n    this.source = source;\n\n    /**\n     * @type {Model}\n     */\n    this.target = target;\n\n    this.options = options;\n    this.scope = options.scope;\n    this.isSelfAssociation = this.source === this.target;\n    this.as = options.as;\n\n    /**\n     * The type of the association. One of `HasMany`, `BelongsTo`, `HasOne`, `BelongsToMany`\n     * @type {string}\n     */\n    this.associationType = '';\n\n    if (source.hasAlias(options.as)) {\n      throw new AssociationError(`You have used the alias ${options.as} in two separate associations. ` +\n      'Aliased associations must have unique aliases.'\n      );\n    }\n  }\n\n  /**\n   * Normalize input\n   *\n   * @param {Array|string} input it may be array or single obj, instance or primary key\n   *\n   * @private\n   * @returns {Array} built objects\n   */\n  toInstanceArray(input) {\n    if (!Array.isArray(input)) {\n      input = [input];\n    }\n\n    return input.map(element => {\n      if (element instanceof this.target) return element;\n\n      const tmpInstance = {};\n      tmpInstance[this.target.primaryKeyAttribute] = element;\n\n      return this.target.build(tmpInstance, { isNewRecord: false });\n    });\n  }\n\n  [Symbol.for('nodejs.util.inspect.custom')]() {\n    return this.as;\n  }\n\n  inspect() {\n    return this.as;\n  }\n}\n\nmodule.exports = Association;\n"]} \ No newline at end of file diff --git a/dist/associations/belongs-to-many.js b/dist/associations/belongs-to-many.js index 49effa6..be7d9e1 100644 --- a/dist/associations/belongs-to-many.js +++ b/dist/associations/belongs-to-many.js @@ -6,15 +6,19 @@ function _defineProperties(target, props) { for (var i = 0; i < props.length; i+ function _createClass(Constructor, protoProps, staticProps) { if (protoProps) _defineProperties(Constructor.prototype, protoProps); if (staticProps) _defineProperties(Constructor, staticProps); return Constructor; } -function _possibleConstructorReturn(self, call) { if (call && (typeof call === "object" || typeof call === "function")) { return call; } return _assertThisInitialized(self); } +function _inherits(subClass, superClass) { if (typeof superClass !== "function" && superClass !== null) { throw new TypeError("Super expression must either be null or a function"); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, writable: true, configurable: true } }); if (superClass) _setPrototypeOf(subClass, superClass); } -function _getPrototypeOf(o) { _getPrototypeOf = Object.setPrototypeOf ? Object.getPrototypeOf : function _getPrototypeOf(o) { return o.__proto__ || Object.getPrototypeOf(o); }; return _getPrototypeOf(o); } +function _setPrototypeOf(o, p) { _setPrototypeOf = Object.setPrototypeOf || function _setPrototypeOf(o, p) { o.__proto__ = p; return o; }; return _setPrototypeOf(o, p); } + +function _createSuper(Derived) { var hasNativeReflectConstruct = _isNativeReflectConstruct(); return function _createSuperInternal() { var Super = _getPrototypeOf(Derived), result; if (hasNativeReflectConstruct) { var NewTarget = _getPrototypeOf(this).constructor; result = Reflect.construct(Super, arguments, NewTarget); } else { result = Super.apply(this, arguments); } return _possibleConstructorReturn(this, result); }; } + +function _possibleConstructorReturn(self, call) { if (call && (typeof call === "object" || typeof call === "function")) { return call; } return _assertThisInitialized(self); } function _assertThisInitialized(self) { if (self === void 0) { throw new ReferenceError("this hasn't been initialised - super() hasn't been called"); } return self; } -function _inherits(subClass, superClass) { if (typeof superClass !== "function" && superClass !== null) { throw new TypeError("Super expression must either be null or a function"); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, writable: true, configurable: true } }); if (superClass) _setPrototypeOf(subClass, superClass); } +function _isNativeReflectConstruct() { if (typeof Reflect === "undefined" || !Reflect.construct) return false; if (Reflect.construct.sham) return false; if (typeof Proxy === "function") return true; try { Date.prototype.toString.call(Reflect.construct(Date, [], function () {})); return true; } catch (e) { return false; } } -function _setPrototypeOf(o, p) { _setPrototypeOf = Object.setPrototypeOf || function _setPrototypeOf(o, p) { o.__proto__ = p; return o; }; return _setPrototypeOf(o, p); } +function _getPrototypeOf(o) { _getPrototypeOf = Object.setPrototypeOf ? Object.getPrototypeOf : function _getPrototypeOf(o) { return o.__proto__ || Object.getPrototypeOf(o); }; return _getPrototypeOf(o); } const Utils = require('./../utils'); @@ -82,17 +86,17 @@ const Op = require('../operators'); */ -let BelongsToMany = -/*#__PURE__*/ -function (_Association) { +let BelongsToMany = /*#__PURE__*/function (_Association) { _inherits(BelongsToMany, _Association); + var _super = _createSuper(BelongsToMany); + function BelongsToMany(source, target, options) { var _this; _classCallCheck(this, BelongsToMany); - _this = _possibleConstructorReturn(this, _getPrototypeOf(BelongsToMany).call(this, source, target, options)); + _this = _super.call(this, source, target, options); if (_this.options.through === undefined || _this.options.through === true || _this.options.through === null) { throw new AssociationError(`${source.name}.belongsToMany(${target.name}) requires through option, pass either a string or a model`); @@ -838,4 +842,4 @@ function (_Association) { module.exports = BelongsToMany; module.exports.BelongsToMany = BelongsToMany; module.exports.default = BelongsToMany; -//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../lib/associations/belongs-to-many.js"],"names":["Utils","require","Helpers","_","Association","BelongsTo","HasMany","HasOne","AssociationError","EmptyResultError","Op","BelongsToMany","source","target","options","through","undefined","name","model","associationType","targetAssociation","sequelize","Object","assign","isMultiAssociation","doubleLinked","as","isSelfAssociation","isAliased","isPlainObject","plural","singular","singularize","combinedTableName","combineTableNames","tableName","each","associations","association","paired","sourceKey","primaryKeyAttribute","sourceKeyField","rawAttributes","field","targetKey","targetKeyField","targetKeyDefault","_createForeignAndOtherKeys","isDefined","define","indexes","paranoid","validate","pick","needInjectPaired","otherKey","otherKeyDefault","foreignKey","_injectAttributes","throughModel","combinedName","associationAccessor","upperFirst","accessors","get","set","addMultiple","add","create","remove","removeMultiple","hasSingle","hasAll","count","isObject","foreignKeyAttribute","fieldName","camelize","join","otherKeyAttribute","identifier","foreignIdentifier","attribute","attributeName","primaryKey","_autoGenerated","primaryKeyDeleted","sourceKeyType","type","targetKeyType","sourceAttribute","defaults","targetAttribute","unique","uniqueKey","constraints","references","getTableName","key","onDelete","onUpdate","refreshAttributes","identifierField","foreignIdentifierField","toSource","manyFromSource","oneFromSource","toTarget","manyFromTarget","oneFromTarget","checkNamingCollision","obj","methods","aliases","mixinMethods","instance","cloneDeep","scopeWhere","throughWhere","scope","clone","where","and","include","push","attributes","joinTableAttributes","required","prototype","hasOwnProperty","call","unscoped","schema","schemaDelimiter","findAll","fn","col","raw","plain","then","result","parseInt","sourceInstance","instances","Array","isArray","instancePrimaryKeys","map","or","associatedObjects","differenceWith","a","b","isEqual","length","newAssociatedObjects","toInstanceArray","updateAssociations","currentRows","obsoleteAssociations","promises","defaultAttributes","unassociatedObjects","filter","some","currentRow","newObj","find","throughAttributes","keys","update","obsoleteAssociation","destroy","bulk","unassociatedObject","bulkCreate","Promise","all","catch","error","newInstances","resolve","newInstance","changedAssociations","existingAssociation","current","assoc","oldAssociatedObjects","values","fields","concat","newAssociatedObject","omit","return","alias","module","exports","default"],"mappings":"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","sourcesContent":["'use strict';\r\n\r\nconst Utils = require('./../utils');\r\nconst Helpers = require('./helpers');\r\nconst _ = require('lodash');\r\nconst Association = require('./base');\r\nconst BelongsTo = require('./belongs-to');\r\nconst HasMany = require('./has-many');\r\nconst HasOne = require('./has-one');\r\nconst AssociationError = require('../errors').AssociationError;\r\nconst EmptyResultError = require('../errors').EmptyResultError;\r\nconst Op = require('../operators');\r\n\r\n/**\r\n * Many-to-many association with a join table.\r\n *\r\n * When the join table has additional attributes, these can be passed in the options object:\r\n *\r\n * ```js\r\n * UserProject = sequelize.define('user_project', {\r\n *   role: Sequelize.STRING\r\n * });\r\n * User.belongsToMany(Project, { through: UserProject });\r\n * Project.belongsToMany(User, { through: UserProject });\r\n * // through is required!\r\n *\r\n * user.addProject(project, { through: { role: 'manager' }});\r\n * ```\r\n *\r\n * All methods allow you to pass either a persisted instance, its primary key, or a mixture:\r\n *\r\n * ```js\r\n * Project.create({ id: 11 }).then(project => {\r\n *   user.addProjects([project, 12]);\r\n * });\r\n * ```\r\n *\r\n * If you want to set several target instances, but with different attributes you have to set the attributes on the instance, using a property with the name of the through model:\r\n *\r\n * ```js\r\n * p1.UserProjects = {\r\n *   started: true\r\n * }\r\n * user.setProjects([p1, p2], { through: { started: false }}) // The default value is false, but p1 overrides that.\r\n * ```\r\n *\r\n * Similarly, when fetching through a join table with custom attributes, these attributes will be available as an object with the name of the through model.\r\n * ```js\r\n * user.getProjects().then(projects => {\r\n   *   let p1 = projects[0]\r\n   *   p1.UserProjects.started // Is this project started yet?\r\n   * })\r\n * ```\r\n *\r\n * In the API reference below, add the name of the association to the method, e.g. for `User.belongsToMany(Project)` the getter will be `user.getProjects()`.\r\n *\r\n * @see {@link Model.belongsToMany}\r\n */\r\nclass BelongsToMany extends Association {\r\n  constructor(source, target, options) {\r\n    super(source, target, options);\r\n\r\n    if (this.options.through === undefined || this.options.through === true || this.options.through === null) {\r\n      throw new AssociationError(`${source.name}.belongsToMany(${target.name}) requires through option, pass either a string or a model`);\r\n    }\r\n\r\n    if (!this.options.through.model) {\r\n      this.options.through = {\r\n        model: options.through\r\n      };\r\n    }\r\n\r\n    this.associationType = 'BelongsToMany';\r\n    this.targetAssociation = null;\r\n    this.sequelize = source.sequelize;\r\n    this.through = Object.assign({}, this.options.through);\r\n    this.isMultiAssociation = true;\r\n    this.doubleLinked = false;\r\n\r\n    if (!this.as && this.isSelfAssociation) {\r\n      throw new AssociationError('\\'as\\' must be defined for many-to-many self-associations');\r\n    }\r\n\r\n    if (this.as) {\r\n      this.isAliased = true;\r\n\r\n      if (_.isPlainObject(this.as)) {\r\n        this.options.name = this.as;\r\n        this.as = this.as.plural;\r\n      } else {\r\n        this.options.name = {\r\n          plural: this.as,\r\n          singular: Utils.singularize(this.as)\r\n        };\r\n      }\r\n    } else {\r\n      this.as = this.target.options.name.plural;\r\n      this.options.name = this.target.options.name;\r\n    }\r\n\r\n    this.combinedTableName = Utils.combineTableNames(\r\n      this.source.tableName,\r\n      this.isSelfAssociation ? this.as || this.target.tableName : this.target.tableName\r\n    );\r\n\r\n    /*\r\n    * If self association, this is the target association - Unless we find a pairing association\r\n    */\r\n    if (this.isSelfAssociation) {\r\n      this.targetAssociation = this;\r\n    }\r\n\r\n    /*\r\n    * Find paired association (if exists)\r\n    */\r\n    _.each(this.target.associations, association => {\r\n      if (association.associationType !== 'BelongsToMany') return;\r\n      if (association.target !== this.source) return;\r\n\r\n      if (this.options.through.model === association.options.through.model) {\r\n        this.paired = association;\r\n        association.paired = this;\r\n      }\r\n    });\r\n\r\n    /*\r\n    * Default/generated source/target keys\r\n    */\r\n    this.sourceKey = this.options.sourceKey || this.source.primaryKeyAttribute;\r\n    this.sourceKeyField = this.source.rawAttributes[this.sourceKey].field || this.sourceKey;\r\n\r\n    if (this.options.targetKey) {\r\n      this.targetKey = this.options.targetKey;\r\n      this.targetKeyField = this.target.rawAttributes[this.targetKey].field || this.targetKey;\r\n    } else {\r\n      this.targetKeyDefault = true;\r\n      this.targetKey = this.target.primaryKeyAttribute;\r\n      this.targetKeyField = this.target.rawAttributes[this.targetKey].field || this.targetKey;\r\n    }\r\n\r\n    this._createForeignAndOtherKeys();\r\n\r\n    if (typeof this.through.model === 'string') {\r\n      if (!this.sequelize.isDefined(this.through.model)) {\r\n        this.through.model = this.sequelize.define(this.through.model, {}, Object.assign(this.options, {\r\n          tableName: this.through.model,\r\n          indexes: [], //we don't want indexes here (as referenced in #2416)\r\n          paranoid: false, // A paranoid join table does not make sense\r\n          validate: {} // Don't propagate model-level validations\r\n        }));\r\n      } else {\r\n        this.through.model = this.sequelize.model(this.through.model);\r\n      }\r\n    }\r\n\r\n    this.options = Object.assign(this.options, _.pick(this.through.model.options, [\r\n      'timestamps', 'createdAt', 'updatedAt', 'deletedAt', 'paranoid'\r\n    ]));\r\n\r\n    if (this.paired) {\r\n      let needInjectPaired = false;\r\n\r\n      if (this.targetKeyDefault) {\r\n        this.targetKey = this.paired.sourceKey;\r\n        this.targetKeyField = this.paired.sourceKeyField;\r\n        this._createForeignAndOtherKeys();\r\n      }\r\n      if (this.paired.targetKeyDefault) {\r\n        // in this case paired.otherKey depends on paired.targetKey,\r\n        // so cleanup previously wrong generated otherKey\r\n        if (this.paired.targetKey !== this.sourceKey) {\r\n          delete this.through.model.rawAttributes[this.paired.otherKey];\r\n          this.paired.targetKey = this.sourceKey;\r\n          this.paired.targetKeyField = this.sourceKeyField;\r\n          this.paired._createForeignAndOtherKeys();\r\n          needInjectPaired = true;\r\n        }\r\n      }\r\n\r\n      if (this.otherKeyDefault) {\r\n        this.otherKey = this.paired.foreignKey;\r\n      }\r\n      if (this.paired.otherKeyDefault) {\r\n        // If paired otherKey was inferred we should make sure to clean it up\r\n        // before adding a new one that matches the foreignKey\r\n        if (this.paired.otherKey !== this.foreignKey) {\r\n          delete this.through.model.rawAttributes[this.paired.otherKey];\r\n          this.paired.otherKey = this.foreignKey;\r\n          needInjectPaired = true;\r\n        }\r\n      }\r\n\r\n      if (needInjectPaired) {\r\n        this.paired._injectAttributes();\r\n      }\r\n    }\r\n\r\n    if (this.through) {\r\n      this.throughModel = this.through.model;\r\n    }\r\n\r\n    this.options.tableName = this.combinedName = this.through.model === Object(this.through.model) ? this.through.model.tableName : this.through.model;\r\n\r\n    this.associationAccessor = this.as;\r\n\r\n    // Get singular and plural names, trying to uppercase the first letter, unless the model forbids it\r\n    const plural = _.upperFirst(this.options.name.plural);\r\n    const singular = _.upperFirst(this.options.name.singular);\r\n\r\n    this.accessors = {\r\n      get: `get${plural}`,\r\n      set: `set${plural}`,\r\n      addMultiple: `add${plural}`,\r\n      add: `add${singular}`,\r\n      create: `create${singular}`,\r\n      remove: `remove${singular}`,\r\n      removeMultiple: `remove${plural}`,\r\n      hasSingle: `has${singular}`,\r\n      hasAll: `has${plural}`,\r\n      count: `count${plural}`\r\n    };\r\n  }\r\n\r\n  _createForeignAndOtherKeys() {\r\n    /*\r\n    * Default/generated foreign/other keys\r\n    */\r\n    if (_.isObject(this.options.foreignKey)) {\r\n      this.foreignKeyAttribute = this.options.foreignKey;\r\n      this.foreignKey = this.foreignKeyAttribute.name || this.foreignKeyAttribute.fieldName;\r\n    } else {\r\n      this.foreignKeyAttribute = {};\r\n      this.foreignKey = this.options.foreignKey || Utils.camelize(\r\n        [\r\n          this.source.options.name.singular,\r\n          this.sourceKey\r\n        ].join('_')\r\n      );\r\n    }\r\n\r\n    if (_.isObject(this.options.otherKey)) {\r\n      this.otherKeyAttribute = this.options.otherKey;\r\n      this.otherKey = this.otherKeyAttribute.name || this.otherKeyAttribute.fieldName;\r\n    } else {\r\n      if (!this.options.otherKey) {\r\n        this.otherKeyDefault = true;\r\n      }\r\n\r\n      this.otherKeyAttribute = {};\r\n      this.otherKey = this.options.otherKey || Utils.camelize(\r\n        [\r\n          this.isSelfAssociation ? Utils.singularize(this.as) : this.target.options.name.singular,\r\n          this.targetKey\r\n        ].join('_')\r\n      );\r\n    }\r\n  }\r\n\r\n  // the id is in the target table\r\n  // or in an extra table which connects two tables\r\n  _injectAttributes() {\r\n    this.identifier = this.foreignKey;\r\n    this.foreignIdentifier = this.otherKey;\r\n\r\n    // remove any PKs previously defined by sequelize\r\n    // but ignore any keys that are part of this association (#5865)\r\n    _.each(this.through.model.rawAttributes, (attribute, attributeName) => {\r\n      if (attribute.primaryKey === true && attribute._autoGenerated === true) {\r\n        if (attributeName === this.foreignKey || attributeName === this.otherKey) {\r\n          // this key is still needed as it's part of the association\r\n          // so just set primaryKey to false\r\n          attribute.primaryKey = false;\r\n        }\r\n        else {\r\n          delete this.through.model.rawAttributes[attributeName];\r\n        }\r\n        this.primaryKeyDeleted = true;\r\n      }\r\n    });\r\n\r\n    const sourceKey = this.source.rawAttributes[this.sourceKey];\r\n    const sourceKeyType = sourceKey.type;\r\n    const sourceKeyField = this.sourceKeyField;\r\n    const targetKey = this.target.rawAttributes[this.targetKey];\r\n    const targetKeyType = targetKey.type;\r\n    const targetKeyField = this.targetKeyField;\r\n    const sourceAttribute = _.defaults({}, this.foreignKeyAttribute, { type: sourceKeyType });\r\n    const targetAttribute = _.defaults({}, this.otherKeyAttribute, { type: targetKeyType });\r\n\r\n    if (this.primaryKeyDeleted === true) {\r\n      targetAttribute.primaryKey = sourceAttribute.primaryKey = true;\r\n    } else if (this.through.unique !== false) {\r\n      let uniqueKey;\r\n      if (typeof this.options.uniqueKey === 'string' && this.options.uniqueKey !== '') {\r\n        uniqueKey = this.options.uniqueKey;\r\n      } else {\r\n        uniqueKey = [this.through.model.tableName, this.foreignKey, this.otherKey, 'unique'].join('_');\r\n      }\r\n      targetAttribute.unique = sourceAttribute.unique = uniqueKey;\r\n    }\r\n\r\n    if (!this.through.model.rawAttributes[this.foreignKey]) {\r\n      this.through.model.rawAttributes[this.foreignKey] = {\r\n        _autoGenerated: true\r\n      };\r\n    }\r\n\r\n    if (!this.through.model.rawAttributes[this.otherKey]) {\r\n      this.through.model.rawAttributes[this.otherKey] = {\r\n        _autoGenerated: true\r\n      };\r\n    }\r\n\r\n    if (this.options.constraints !== false) {\r\n      sourceAttribute.references = {\r\n        model: this.source.getTableName(),\r\n        key: sourceKeyField\r\n      };\r\n      // For the source attribute the passed option is the priority\r\n      sourceAttribute.onDelete = this.options.onDelete || this.through.model.rawAttributes[this.foreignKey].onDelete;\r\n      sourceAttribute.onUpdate = this.options.onUpdate || this.through.model.rawAttributes[this.foreignKey].onUpdate;\r\n\r\n      if (!sourceAttribute.onDelete) sourceAttribute.onDelete = 'CASCADE';\r\n      if (!sourceAttribute.onUpdate) sourceAttribute.onUpdate = 'CASCADE';\r\n\r\n      targetAttribute.references = {\r\n        model: this.target.getTableName(),\r\n        key: targetKeyField\r\n      };\r\n      // But the for target attribute the previously defined option is the priority (since it could've been set by another belongsToMany call)\r\n      targetAttribute.onDelete = this.through.model.rawAttributes[this.otherKey].onDelete || this.options.onDelete;\r\n      targetAttribute.onUpdate = this.through.model.rawAttributes[this.otherKey].onUpdate || this.options.onUpdate;\r\n\r\n      if (!targetAttribute.onDelete) targetAttribute.onDelete = 'CASCADE';\r\n      if (!targetAttribute.onUpdate) targetAttribute.onUpdate = 'CASCADE';\r\n    }\r\n\r\n    this.through.model.rawAttributes[this.foreignKey] = Object.assign(this.through.model.rawAttributes[this.foreignKey], sourceAttribute);\r\n    this.through.model.rawAttributes[this.otherKey] = Object.assign(this.through.model.rawAttributes[this.otherKey], targetAttribute);\r\n\r\n    this.through.model.refreshAttributes();\r\n\r\n    this.identifierField = this.through.model.rawAttributes[this.foreignKey].field || this.foreignKey;\r\n    this.foreignIdentifierField = this.through.model.rawAttributes[this.otherKey].field || this.otherKey;\r\n\r\n    if (this.paired && !this.paired.foreignIdentifierField) {\r\n      this.paired.foreignIdentifierField = this.through.model.rawAttributes[this.paired.otherKey].field || this.paired.otherKey;\r\n    }\r\n\r\n    this.toSource = new BelongsTo(this.through.model, this.source, {\r\n      foreignKey: this.foreignKey\r\n    });\r\n    this.manyFromSource = new HasMany(this.source, this.through.model, {\r\n      foreignKey: this.foreignKey\r\n    });\r\n    this.oneFromSource = new HasOne(this.source, this.through.model, {\r\n      foreignKey: this.foreignKey,\r\n      as: this.through.model.name\r\n    });\r\n\r\n    this.toTarget = new BelongsTo(this.through.model, this.target, {\r\n      foreignKey: this.otherKey\r\n    });\r\n    this.manyFromTarget = new HasMany(this.target, this.through.model, {\r\n      foreignKey: this.otherKey\r\n    });\r\n    this.oneFromTarget = new HasOne(this.target, this.through.model, {\r\n      foreignKey: this.otherKey,\r\n      as: this.through.model.name\r\n    });\r\n\r\n    if (this.paired && this.paired.otherKeyDefault) {\r\n      this.paired.toTarget = new BelongsTo(this.paired.through.model, this.paired.target, {\r\n        foreignKey: this.paired.otherKey\r\n      });\r\n\r\n      this.paired.oneFromTarget = new HasOne(this.paired.target, this.paired.through.model, {\r\n        foreignKey: this.paired.otherKey,\r\n        as: this.paired.through.model.name\r\n      });\r\n    }\r\n\r\n    Helpers.checkNamingCollision(this);\r\n\r\n    return this;\r\n  }\r\n\r\n  mixin(obj) {\r\n    const methods = ['get', 'count', 'hasSingle', 'hasAll', 'set', 'add', 'addMultiple', 'remove', 'removeMultiple', 'create'];\r\n    const aliases = {\r\n      hasSingle: 'has',\r\n      hasAll: 'has',\r\n      addMultiple: 'add',\r\n      removeMultiple: 'remove'\r\n    };\r\n\r\n    Helpers.mixinMethods(this, obj, methods, aliases);\r\n  }\r\n\r\n  /**\r\n   * Get everything currently associated with this, using an optional where clause.\r\n   *\r\n   * @see\r\n   * {@link Model} for a full explanation of options\r\n   *\r\n   * @param {Model} instance instance\r\n   * @param {Object} [options] find options\r\n   * @param {Object} [options.where] An optional where clause to limit the associated models\r\n   * @param {string|boolean} [options.scope] Apply a scope on the related model, or remove its default scope by passing false\r\n   * @param {string} [options.schema] Apply a schema on the related model\r\n   *\r\n   * @returns {Promise<Array<Model>>}\r\n   */\r\n  get(instance, options) {\r\n    options = Utils.cloneDeep(options) || {};\r\n\r\n    const through = this.through;\r\n    let scopeWhere;\r\n    let throughWhere;\r\n\r\n    if (this.scope) {\r\n      scopeWhere = _.clone(this.scope);\r\n    }\r\n\r\n    options.where = {\r\n      [Op.and]: [\r\n        scopeWhere,\r\n        options.where\r\n      ]\r\n    };\r\n\r\n    if (Object(through.model) === through.model) {\r\n      throughWhere = {};\r\n      throughWhere[this.foreignKey] = instance.get(this.sourceKey);\r\n\r\n      if (through.scope) {\r\n        Object.assign(throughWhere, through.scope);\r\n      }\r\n\r\n      //If a user pass a where on the options through options, make an \"and\" with the current throughWhere\r\n      if (options.through && options.through.where) {\r\n        throughWhere = {\r\n          [Op.and]: [throughWhere, options.through.where]\r\n        };\r\n      }\r\n\r\n      options.include = options.include || [];\r\n      options.include.push({\r\n        association: this.oneFromTarget,\r\n        attributes: options.joinTableAttributes,\r\n        required: true,\r\n        where: throughWhere\r\n      });\r\n    }\r\n\r\n    let model = this.target;\r\n    if (Object.prototype.hasOwnProperty.call(options, 'scope')) {\r\n      if (!options.scope) {\r\n        model = model.unscoped();\r\n      } else {\r\n        model = model.scope(options.scope);\r\n      }\r\n    }\r\n\r\n    if (Object.prototype.hasOwnProperty.call(options, 'schema')) {\r\n      model = model.schema(options.schema, options.schemaDelimiter);\r\n    }\r\n\r\n    return model.findAll(options);\r\n  }\r\n\r\n  /**\r\n   * Count everything currently associated with this, using an optional where clause.\r\n   *\r\n   * @param {Model} instance instance\r\n   * @param {Object} [options] find options\r\n   * @param {Object} [options.where] An optional where clause to limit the associated models\r\n   * @param {string|boolean} [options.scope] Apply a scope on the related model, or remove its default scope by passing false\r\n   *\r\n   * @returns {Promise<number>}\r\n   */\r\n  count(instance, options) {\r\n    const sequelize = this.target.sequelize;\r\n\r\n    options = Utils.cloneDeep(options);\r\n    options.attributes = [\r\n      [sequelize.fn('COUNT', sequelize.col([this.target.name, this.targetKeyField].join('.'))), 'count']\r\n    ];\r\n    options.joinTableAttributes = [];\r\n    options.raw = true;\r\n    options.plain = true;\r\n\r\n    return this.get(instance, options).then(result => parseInt(result.count, 10));\r\n  }\r\n\r\n  /**\r\n   * Check if one or more instance(s) are associated with this. If a list of instances is passed, the function returns true if _all_ instances are associated\r\n   *\r\n   * @param {Model} sourceInstance source instance to check for an association with\r\n   * @param {Model|Model[]|string[]|string|number[]|number} [instances] Can be an array of instances or their primary keys\r\n   * @param {Object} [options] Options passed to getAssociations\r\n   *\r\n   * @returns {Promise<boolean>}\r\n   */\r\n  has(sourceInstance, instances, options) {\r\n    if (!Array.isArray(instances)) {\r\n      instances = [instances];\r\n    }\r\n\r\n    options = Object.assign({\r\n      raw: true\r\n    }, options, {\r\n      scope: false,\r\n      attributes: [this.targetKey],\r\n      joinTableAttributes: []\r\n    });\r\n\r\n    const instancePrimaryKeys = instances.map(instance => {\r\n      if (instance instanceof this.target) {\r\n        return instance.where();\r\n      }\r\n      return {\r\n        [this.targetKey]: instance\r\n      };\r\n    });\r\n\r\n    options.where = {\r\n      [Op.and]: [\r\n        { [Op.or]: instancePrimaryKeys },\r\n        options.where\r\n      ]\r\n    };\r\n\r\n    return this.get(sourceInstance, options).then(associatedObjects =>\r\n      _.differenceWith(instancePrimaryKeys, associatedObjects,\r\n        (a, b) => _.isEqual(a[this.targetKey], b[this.targetKey])).length === 0\r\n    );\r\n  }\r\n\r\n  /**\r\n   * Set the associated models by passing an array of instances or their primary keys.\r\n   * Everything that it not in the passed array will be un-associated.\r\n   *\r\n   * @param {Model} sourceInstance source instance to associate new instances with\r\n   * @param {Model|Model[]|string[]|string|number[]|number} [newAssociatedObjects] A single instance or primary key, or a mixed array of persisted instances or primary keys\r\n   * @param {Object} [options] Options passed to `through.findAll`, `bulkCreate`, `update` and `destroy`\r\n   * @param {Object} [options.validate] Run validation for the join model\r\n   * @param {Object} [options.through] Additional attributes for the join table.\r\n   *\r\n   * @returns {Promise}\r\n   */\r\n  set(sourceInstance, newAssociatedObjects, options) {\r\n    options = options || {};\r\n\r\n    const sourceKey = this.sourceKey;\r\n    const targetKey = this.targetKey;\r\n    const identifier = this.identifier;\r\n    const foreignIdentifier = this.foreignIdentifier;\r\n    let where = {};\r\n\r\n    if (newAssociatedObjects === null) {\r\n      newAssociatedObjects = [];\r\n    } else {\r\n      newAssociatedObjects = this.toInstanceArray(newAssociatedObjects);\r\n    }\r\n\r\n    where[identifier] = sourceInstance.get(sourceKey);\r\n    where = Object.assign(where, this.through.scope);\r\n\r\n    const updateAssociations = currentRows => {\r\n      const obsoleteAssociations = [];\r\n      const promises = [];\r\n      const defaultAttributes = options.through || {};\r\n\r\n      const unassociatedObjects = newAssociatedObjects.filter(obj =>\r\n        !currentRows.some(currentRow => currentRow[foreignIdentifier] === obj.get(targetKey))\r\n      );\r\n\r\n      for (const currentRow of currentRows) {\r\n        const newObj = newAssociatedObjects.find(obj => currentRow[foreignIdentifier] === obj.get(targetKey));\r\n\r\n        if (!newObj) {\r\n          obsoleteAssociations.push(currentRow);\r\n        } else {\r\n          let throughAttributes = newObj[this.through.model.name];\r\n          // Quick-fix for subtle bug when using existing objects that might have the through model attached (not as an attribute object)\r\n          if (throughAttributes instanceof this.through.model) {\r\n            throughAttributes = {};\r\n          }\r\n\r\n          const attributes = _.defaults({}, throughAttributes, defaultAttributes);\r\n\r\n          if (Object.keys(attributes).length) {\r\n            promises.push(\r\n              this.through.model.update(attributes, Object.assign(options, {\r\n                where: {\r\n                  [identifier]: sourceInstance.get(sourceKey),\r\n                  [foreignIdentifier]: newObj.get(targetKey)\r\n                }\r\n              }\r\n              ))\r\n            );\r\n          }\r\n        }\r\n      }\r\n\r\n      if (obsoleteAssociations.length > 0) {\r\n        const where = Object.assign({\r\n          [identifier]: sourceInstance.get(sourceKey),\r\n          [foreignIdentifier]: obsoleteAssociations.map(obsoleteAssociation => obsoleteAssociation[foreignIdentifier])\r\n        }, this.through.scope);\r\n        promises.push(\r\n          this.through.model.destroy(_.defaults({\r\n            where\r\n          }, options))\r\n        );\r\n      }\r\n\r\n      if (unassociatedObjects.length > 0) {\r\n        const bulk = unassociatedObjects.map(unassociatedObject => {\r\n          let attributes = {};\r\n\r\n          attributes[identifier] = sourceInstance.get(sourceKey);\r\n          attributes[foreignIdentifier] = unassociatedObject.get(targetKey);\r\n\r\n          attributes = _.defaults(attributes, unassociatedObject[this.through.model.name], defaultAttributes);\r\n\r\n          Object.assign(attributes, this.through.scope);\r\n          attributes = Object.assign(attributes, this.through.scope);\r\n\r\n          return attributes;\r\n        });\r\n\r\n        promises.push(this.through.model.bulkCreate(bulk, Object.assign({ validate: true }, options)));\r\n      }\r\n\r\n      return Utils.Promise.all(promises);\r\n    };\r\n\r\n    return this.through.model.findAll(_.defaults({ where, raw: true }, options))\r\n      .then(currentRows => updateAssociations(currentRows))\r\n      .catch(error => {\r\n        if (error instanceof EmptyResultError) return updateAssociations([]);\r\n        throw error;\r\n      });\r\n  }\r\n\r\n  /**\r\n   * Associate one or several rows with source instance. It will not un-associate any already associated instance\r\n   * that may be missing from `newInstances`.\r\n   *\r\n   * @param {Model} sourceInstance source instance to associate new instances with\r\n   * @param {Model|Model[]|string[]|string|number[]|number} [newInstances] A single instance or primary key, or a mixed array of persisted instances or primary keys\r\n   * @param {Object} [options] Options passed to `through.findAll`, `bulkCreate` and `update`\r\n   * @param {Object} [options.validate] Run validation for the join model.\r\n   * @param {Object} [options.through] Additional attributes for the join table.\r\n   *\r\n   * @returns {Promise}\r\n   */\r\n  add(sourceInstance, newInstances, options) {\r\n    // If newInstances is null or undefined, no-op\r\n    if (!newInstances) return Utils.Promise.resolve();\r\n\r\n    options = _.clone(options) || {};\r\n\r\n    const association = this;\r\n    const sourceKey = association.sourceKey;\r\n    const targetKey = association.targetKey;\r\n    const identifier = association.identifier;\r\n    const foreignIdentifier = association.foreignIdentifier;\r\n    const defaultAttributes = options.through || {};\r\n\r\n    newInstances = association.toInstanceArray(newInstances);\r\n\r\n    const where = {\r\n      [identifier]: sourceInstance.get(sourceKey),\r\n      [foreignIdentifier]: newInstances.map(newInstance => newInstance.get(targetKey))\r\n    };\r\n\r\n    Object.assign(where, association.through.scope);\r\n\r\n    const updateAssociations = currentRows => {\r\n      const promises = [];\r\n      const unassociatedObjects = [];\r\n      const changedAssociations = [];\r\n      for (const obj of newInstances) {\r\n        const existingAssociation = currentRows && currentRows.find(current => current[foreignIdentifier] === obj.get(targetKey));\r\n\r\n        if (!existingAssociation) {\r\n          unassociatedObjects.push(obj);\r\n        } else {\r\n          const throughAttributes = obj[association.through.model.name];\r\n          const attributes = _.defaults({}, throughAttributes, defaultAttributes);\r\n\r\n          if (Object.keys(attributes).some(attribute => attributes[attribute] !== existingAssociation[attribute])) {\r\n            changedAssociations.push(obj);\r\n          }\r\n        }\r\n      }\r\n\r\n      if (unassociatedObjects.length > 0) {\r\n        const bulk = unassociatedObjects.map(unassociatedObject => {\r\n          const throughAttributes = unassociatedObject[association.through.model.name];\r\n          const attributes = _.defaults({}, throughAttributes, defaultAttributes);\r\n\r\n          attributes[identifier] = sourceInstance.get(sourceKey);\r\n          attributes[foreignIdentifier] = unassociatedObject.get(targetKey);\r\n\r\n          Object.assign(attributes, association.through.scope);\r\n\r\n          return attributes;\r\n        });\r\n\r\n        promises.push(association.through.model.bulkCreate(bulk, Object.assign({ validate: true }, options)));\r\n      }\r\n\r\n      for (const assoc of changedAssociations) {\r\n        let throughAttributes = assoc[association.through.model.name];\r\n        const attributes = _.defaults({}, throughAttributes, defaultAttributes);\r\n        // Quick-fix for subtle bug when using existing objects that might have the through model attached (not as an attribute object)\r\n        if (throughAttributes instanceof association.through.model) {\r\n          throughAttributes = {};\r\n        }\r\n        const where = {\r\n          [identifier]: sourceInstance.get(sourceKey),\r\n          [foreignIdentifier]: assoc.get(targetKey)\r\n        };\r\n\r\n\r\n        promises.push(association.through.model.update(attributes, Object.assign(options, { where })));\r\n      }\r\n\r\n      return Utils.Promise.all(promises);\r\n    };\r\n\r\n    return association.through.model.findAll(_.defaults({ where, raw: true }, options))\r\n      .then(currentRows => updateAssociations(currentRows))\r\n      .then(([associations]) => associations)\r\n      .catch(error => {\r\n        if (error instanceof EmptyResultError) return updateAssociations();\r\n        throw error;\r\n      });\r\n  }\r\n\r\n  /**\r\n   * Un-associate one or more instance(s).\r\n   *\r\n   * @param {Model} sourceInstance instance to un associate instances with\r\n   * @param {Model|Model[]|string|string[]|number|number[]} [oldAssociatedObjects] Can be an Instance or its primary key, or a mixed array of instances and primary keys\r\n   * @param {Object} [options] Options passed to `through.destroy`\r\n   *\r\n   * @returns {Promise}\r\n   */\r\n  remove(sourceInstance, oldAssociatedObjects, options) {\r\n    const association = this;\r\n\r\n    options = options || {};\r\n\r\n    oldAssociatedObjects = association.toInstanceArray(oldAssociatedObjects);\r\n\r\n    const where = {\r\n      [association.identifier]: sourceInstance.get(association.sourceKey),\r\n      [association.foreignIdentifier]: oldAssociatedObjects.map(newInstance => newInstance.get(association.targetKey))\r\n    };\r\n\r\n    return association.through.model.destroy(_.defaults({ where }, options));\r\n  }\r\n\r\n  /**\r\n   * Create a new instance of the associated model and associate it with this.\r\n   *\r\n   * @param {Model} sourceInstance source instance\r\n   * @param {Object} [values] values for target model\r\n   * @param {Object} [options] Options passed to create and add\r\n   * @param {Object} [options.through] Additional attributes for the join table\r\n   *\r\n   * @returns {Promise}\r\n   */\r\n  create(sourceInstance, values, options) {\r\n    const association = this;\r\n\r\n    options = options || {};\r\n    values = values || {};\r\n\r\n    if (Array.isArray(options)) {\r\n      options = {\r\n        fields: options\r\n      };\r\n    }\r\n\r\n    if (association.scope) {\r\n      Object.assign(values, association.scope);\r\n      if (options.fields) {\r\n        options.fields = options.fields.concat(Object.keys(association.scope));\r\n      }\r\n    }\r\n\r\n    // Create the related model instance\r\n    return association.target.create(values, options).then(newAssociatedObject =>\r\n      sourceInstance[association.accessors.add](newAssociatedObject, _.omit(options, ['fields'])).return(newAssociatedObject)\r\n    );\r\n  }\r\n\r\n  verifyAssociationAlias(alias) {\r\n    if (typeof alias === 'string') {\r\n      return this.as === alias;\r\n    }\r\n\r\n    if (alias && alias.plural) {\r\n      return this.as === alias.plural;\r\n    }\r\n\r\n    return !this.isAliased;\r\n  }\r\n}\r\n\r\nmodule.exports = BelongsToMany;\r\nmodule.exports.BelongsToMany = BelongsToMany;\r\nmodule.exports.default = BelongsToMany;\r\n"]} \ No newline at end of file +//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../lib/associations/belongs-to-many.js"],"names":["Utils","require","Helpers","_","Association","BelongsTo","HasMany","HasOne","AssociationError","EmptyResultError","Op","BelongsToMany","source","target","options","through","undefined","name","model","associationType","targetAssociation","sequelize","Object","assign","isMultiAssociation","doubleLinked","as","isSelfAssociation","isAliased","isPlainObject","plural","singular","singularize","combinedTableName","combineTableNames","tableName","each","associations","association","paired","sourceKey","primaryKeyAttribute","sourceKeyField","rawAttributes","field","targetKey","targetKeyField","targetKeyDefault","_createForeignAndOtherKeys","isDefined","define","indexes","paranoid","validate","pick","needInjectPaired","otherKey","otherKeyDefault","foreignKey","_injectAttributes","throughModel","combinedName","associationAccessor","upperFirst","accessors","get","set","addMultiple","add","create","remove","removeMultiple","hasSingle","hasAll","count","isObject","foreignKeyAttribute","fieldName","camelize","join","otherKeyAttribute","identifier","foreignIdentifier","attribute","attributeName","primaryKey","_autoGenerated","primaryKeyDeleted","sourceKeyType","type","targetKeyType","sourceAttribute","defaults","targetAttribute","unique","uniqueKey","constraints","references","getTableName","key","onDelete","onUpdate","refreshAttributes","identifierField","foreignIdentifierField","toSource","manyFromSource","oneFromSource","toTarget","manyFromTarget","oneFromTarget","checkNamingCollision","obj","methods","aliases","mixinMethods","instance","cloneDeep","scopeWhere","throughWhere","scope","clone","where","and","include","push","attributes","joinTableAttributes","required","prototype","hasOwnProperty","call","unscoped","schema","schemaDelimiter","findAll","fn","col","raw","plain","then","result","parseInt","sourceInstance","instances","Array","isArray","instancePrimaryKeys","map","or","associatedObjects","differenceWith","a","b","isEqual","length","newAssociatedObjects","toInstanceArray","updateAssociations","currentRows","obsoleteAssociations","promises","defaultAttributes","unassociatedObjects","filter","some","currentRow","newObj","find","throughAttributes","keys","update","obsoleteAssociation","destroy","bulk","unassociatedObject","bulkCreate","Promise","all","catch","error","newInstances","resolve","newInstance","changedAssociations","existingAssociation","current","assoc","oldAssociatedObjects","values","fields","concat","newAssociatedObject","omit","return","alias","module","exports","default"],"mappings":"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","sourcesContent":["'use strict';\n\nconst Utils = require('./../utils');\nconst Helpers = require('./helpers');\nconst _ = require('lodash');\nconst Association = require('./base');\nconst BelongsTo = require('./belongs-to');\nconst HasMany = require('./has-many');\nconst HasOne = require('./has-one');\nconst AssociationError = require('../errors').AssociationError;\nconst EmptyResultError = require('../errors').EmptyResultError;\nconst Op = require('../operators');\n\n/**\n * Many-to-many association with a join table.\n *\n * When the join table has additional attributes, these can be passed in the options object:\n *\n * ```js\n * UserProject = sequelize.define('user_project', {\n *   role: Sequelize.STRING\n * });\n * User.belongsToMany(Project, { through: UserProject });\n * Project.belongsToMany(User, { through: UserProject });\n * // through is required!\n *\n * user.addProject(project, { through: { role: 'manager' }});\n * ```\n *\n * All methods allow you to pass either a persisted instance, its primary key, or a mixture:\n *\n * ```js\n * Project.create({ id: 11 }).then(project => {\n *   user.addProjects([project, 12]);\n * });\n * ```\n *\n * If you want to set several target instances, but with different attributes you have to set the attributes on the instance, using a property with the name of the through model:\n *\n * ```js\n * p1.UserProjects = {\n *   started: true\n * }\n * user.setProjects([p1, p2], { through: { started: false }}) // The default value is false, but p1 overrides that.\n * ```\n *\n * Similarly, when fetching through a join table with custom attributes, these attributes will be available as an object with the name of the through model.\n * ```js\n * user.getProjects().then(projects => {\n   *   let p1 = projects[0]\n   *   p1.UserProjects.started // Is this project started yet?\n   * })\n * ```\n *\n * In the API reference below, add the name of the association to the method, e.g. for `User.belongsToMany(Project)` the getter will be `user.getProjects()`.\n *\n * @see {@link Model.belongsToMany}\n */\nclass BelongsToMany extends Association {\n  constructor(source, target, options) {\n    super(source, target, options);\n\n    if (this.options.through === undefined || this.options.through === true || this.options.through === null) {\n      throw new AssociationError(`${source.name}.belongsToMany(${target.name}) requires through option, pass either a string or a model`);\n    }\n\n    if (!this.options.through.model) {\n      this.options.through = {\n        model: options.through\n      };\n    }\n\n    this.associationType = 'BelongsToMany';\n    this.targetAssociation = null;\n    this.sequelize = source.sequelize;\n    this.through = Object.assign({}, this.options.through);\n    this.isMultiAssociation = true;\n    this.doubleLinked = false;\n\n    if (!this.as && this.isSelfAssociation) {\n      throw new AssociationError('\\'as\\' must be defined for many-to-many self-associations');\n    }\n\n    if (this.as) {\n      this.isAliased = true;\n\n      if (_.isPlainObject(this.as)) {\n        this.options.name = this.as;\n        this.as = this.as.plural;\n      } else {\n        this.options.name = {\n          plural: this.as,\n          singular: Utils.singularize(this.as)\n        };\n      }\n    } else {\n      this.as = this.target.options.name.plural;\n      this.options.name = this.target.options.name;\n    }\n\n    this.combinedTableName = Utils.combineTableNames(\n      this.source.tableName,\n      this.isSelfAssociation ? this.as || this.target.tableName : this.target.tableName\n    );\n\n    /*\n    * If self association, this is the target association - Unless we find a pairing association\n    */\n    if (this.isSelfAssociation) {\n      this.targetAssociation = this;\n    }\n\n    /*\n    * Find paired association (if exists)\n    */\n    _.each(this.target.associations, association => {\n      if (association.associationType !== 'BelongsToMany') return;\n      if (association.target !== this.source) return;\n\n      if (this.options.through.model === association.options.through.model) {\n        this.paired = association;\n        association.paired = this;\n      }\n    });\n\n    /*\n    * Default/generated source/target keys\n    */\n    this.sourceKey = this.options.sourceKey || this.source.primaryKeyAttribute;\n    this.sourceKeyField = this.source.rawAttributes[this.sourceKey].field || this.sourceKey;\n\n    if (this.options.targetKey) {\n      this.targetKey = this.options.targetKey;\n      this.targetKeyField = this.target.rawAttributes[this.targetKey].field || this.targetKey;\n    } else {\n      this.targetKeyDefault = true;\n      this.targetKey = this.target.primaryKeyAttribute;\n      this.targetKeyField = this.target.rawAttributes[this.targetKey].field || this.targetKey;\n    }\n\n    this._createForeignAndOtherKeys();\n\n    if (typeof this.through.model === 'string') {\n      if (!this.sequelize.isDefined(this.through.model)) {\n        this.through.model = this.sequelize.define(this.through.model, {}, Object.assign(this.options, {\n          tableName: this.through.model,\n          indexes: [], //we don't want indexes here (as referenced in #2416)\n          paranoid: false, // A paranoid join table does not make sense\n          validate: {} // Don't propagate model-level validations\n        }));\n      } else {\n        this.through.model = this.sequelize.model(this.through.model);\n      }\n    }\n\n    this.options = Object.assign(this.options, _.pick(this.through.model.options, [\n      'timestamps', 'createdAt', 'updatedAt', 'deletedAt', 'paranoid'\n    ]));\n\n    if (this.paired) {\n      let needInjectPaired = false;\n\n      if (this.targetKeyDefault) {\n        this.targetKey = this.paired.sourceKey;\n        this.targetKeyField = this.paired.sourceKeyField;\n        this._createForeignAndOtherKeys();\n      }\n      if (this.paired.targetKeyDefault) {\n        // in this case paired.otherKey depends on paired.targetKey,\n        // so cleanup previously wrong generated otherKey\n        if (this.paired.targetKey !== this.sourceKey) {\n          delete this.through.model.rawAttributes[this.paired.otherKey];\n          this.paired.targetKey = this.sourceKey;\n          this.paired.targetKeyField = this.sourceKeyField;\n          this.paired._createForeignAndOtherKeys();\n          needInjectPaired = true;\n        }\n      }\n\n      if (this.otherKeyDefault) {\n        this.otherKey = this.paired.foreignKey;\n      }\n      if (this.paired.otherKeyDefault) {\n        // If paired otherKey was inferred we should make sure to clean it up\n        // before adding a new one that matches the foreignKey\n        if (this.paired.otherKey !== this.foreignKey) {\n          delete this.through.model.rawAttributes[this.paired.otherKey];\n          this.paired.otherKey = this.foreignKey;\n          needInjectPaired = true;\n        }\n      }\n\n      if (needInjectPaired) {\n        this.paired._injectAttributes();\n      }\n    }\n\n    if (this.through) {\n      this.throughModel = this.through.model;\n    }\n\n    this.options.tableName = this.combinedName = this.through.model === Object(this.through.model) ? this.through.model.tableName : this.through.model;\n\n    this.associationAccessor = this.as;\n\n    // Get singular and plural names, trying to uppercase the first letter, unless the model forbids it\n    const plural = _.upperFirst(this.options.name.plural);\n    const singular = _.upperFirst(this.options.name.singular);\n\n    this.accessors = {\n      get: `get${plural}`,\n      set: `set${plural}`,\n      addMultiple: `add${plural}`,\n      add: `add${singular}`,\n      create: `create${singular}`,\n      remove: `remove${singular}`,\n      removeMultiple: `remove${plural}`,\n      hasSingle: `has${singular}`,\n      hasAll: `has${plural}`,\n      count: `count${plural}`\n    };\n  }\n\n  _createForeignAndOtherKeys() {\n    /*\n    * Default/generated foreign/other keys\n    */\n    if (_.isObject(this.options.foreignKey)) {\n      this.foreignKeyAttribute = this.options.foreignKey;\n      this.foreignKey = this.foreignKeyAttribute.name || this.foreignKeyAttribute.fieldName;\n    } else {\n      this.foreignKeyAttribute = {};\n      this.foreignKey = this.options.foreignKey || Utils.camelize(\n        [\n          this.source.options.name.singular,\n          this.sourceKey\n        ].join('_')\n      );\n    }\n\n    if (_.isObject(this.options.otherKey)) {\n      this.otherKeyAttribute = this.options.otherKey;\n      this.otherKey = this.otherKeyAttribute.name || this.otherKeyAttribute.fieldName;\n    } else {\n      if (!this.options.otherKey) {\n        this.otherKeyDefault = true;\n      }\n\n      this.otherKeyAttribute = {};\n      this.otherKey = this.options.otherKey || Utils.camelize(\n        [\n          this.isSelfAssociation ? Utils.singularize(this.as) : this.target.options.name.singular,\n          this.targetKey\n        ].join('_')\n      );\n    }\n  }\n\n  // the id is in the target table\n  // or in an extra table which connects two tables\n  _injectAttributes() {\n    this.identifier = this.foreignKey;\n    this.foreignIdentifier = this.otherKey;\n\n    // remove any PKs previously defined by sequelize\n    // but ignore any keys that are part of this association (#5865)\n    _.each(this.through.model.rawAttributes, (attribute, attributeName) => {\n      if (attribute.primaryKey === true && attribute._autoGenerated === true) {\n        if (attributeName === this.foreignKey || attributeName === this.otherKey) {\n          // this key is still needed as it's part of the association\n          // so just set primaryKey to false\n          attribute.primaryKey = false;\n        }\n        else {\n          delete this.through.model.rawAttributes[attributeName];\n        }\n        this.primaryKeyDeleted = true;\n      }\n    });\n\n    const sourceKey = this.source.rawAttributes[this.sourceKey];\n    const sourceKeyType = sourceKey.type;\n    const sourceKeyField = this.sourceKeyField;\n    const targetKey = this.target.rawAttributes[this.targetKey];\n    const targetKeyType = targetKey.type;\n    const targetKeyField = this.targetKeyField;\n    const sourceAttribute = _.defaults({}, this.foreignKeyAttribute, { type: sourceKeyType });\n    const targetAttribute = _.defaults({}, this.otherKeyAttribute, { type: targetKeyType });\n\n    if (this.primaryKeyDeleted === true) {\n      targetAttribute.primaryKey = sourceAttribute.primaryKey = true;\n    } else if (this.through.unique !== false) {\n      let uniqueKey;\n      if (typeof this.options.uniqueKey === 'string' && this.options.uniqueKey !== '') {\n        uniqueKey = this.options.uniqueKey;\n      } else {\n        uniqueKey = [this.through.model.tableName, this.foreignKey, this.otherKey, 'unique'].join('_');\n      }\n      targetAttribute.unique = sourceAttribute.unique = uniqueKey;\n    }\n\n    if (!this.through.model.rawAttributes[this.foreignKey]) {\n      this.through.model.rawAttributes[this.foreignKey] = {\n        _autoGenerated: true\n      };\n    }\n\n    if (!this.through.model.rawAttributes[this.otherKey]) {\n      this.through.model.rawAttributes[this.otherKey] = {\n        _autoGenerated: true\n      };\n    }\n\n    if (this.options.constraints !== false) {\n      sourceAttribute.references = {\n        model: this.source.getTableName(),\n        key: sourceKeyField\n      };\n      // For the source attribute the passed option is the priority\n      sourceAttribute.onDelete = this.options.onDelete || this.through.model.rawAttributes[this.foreignKey].onDelete;\n      sourceAttribute.onUpdate = this.options.onUpdate || this.through.model.rawAttributes[this.foreignKey].onUpdate;\n\n      if (!sourceAttribute.onDelete) sourceAttribute.onDelete = 'CASCADE';\n      if (!sourceAttribute.onUpdate) sourceAttribute.onUpdate = 'CASCADE';\n\n      targetAttribute.references = {\n        model: this.target.getTableName(),\n        key: targetKeyField\n      };\n      // But the for target attribute the previously defined option is the priority (since it could've been set by another belongsToMany call)\n      targetAttribute.onDelete = this.through.model.rawAttributes[this.otherKey].onDelete || this.options.onDelete;\n      targetAttribute.onUpdate = this.through.model.rawAttributes[this.otherKey].onUpdate || this.options.onUpdate;\n\n      if (!targetAttribute.onDelete) targetAttribute.onDelete = 'CASCADE';\n      if (!targetAttribute.onUpdate) targetAttribute.onUpdate = 'CASCADE';\n    }\n\n    this.through.model.rawAttributes[this.foreignKey] = Object.assign(this.through.model.rawAttributes[this.foreignKey], sourceAttribute);\n    this.through.model.rawAttributes[this.otherKey] = Object.assign(this.through.model.rawAttributes[this.otherKey], targetAttribute);\n\n    this.through.model.refreshAttributes();\n\n    this.identifierField = this.through.model.rawAttributes[this.foreignKey].field || this.foreignKey;\n    this.foreignIdentifierField = this.through.model.rawAttributes[this.otherKey].field || this.otherKey;\n\n    if (this.paired && !this.paired.foreignIdentifierField) {\n      this.paired.foreignIdentifierField = this.through.model.rawAttributes[this.paired.otherKey].field || this.paired.otherKey;\n    }\n\n    this.toSource = new BelongsTo(this.through.model, this.source, {\n      foreignKey: this.foreignKey\n    });\n    this.manyFromSource = new HasMany(this.source, this.through.model, {\n      foreignKey: this.foreignKey\n    });\n    this.oneFromSource = new HasOne(this.source, this.through.model, {\n      foreignKey: this.foreignKey,\n      as: this.through.model.name\n    });\n\n    this.toTarget = new BelongsTo(this.through.model, this.target, {\n      foreignKey: this.otherKey\n    });\n    this.manyFromTarget = new HasMany(this.target, this.through.model, {\n      foreignKey: this.otherKey\n    });\n    this.oneFromTarget = new HasOne(this.target, this.through.model, {\n      foreignKey: this.otherKey,\n      as: this.through.model.name\n    });\n\n    if (this.paired && this.paired.otherKeyDefault) {\n      this.paired.toTarget = new BelongsTo(this.paired.through.model, this.paired.target, {\n        foreignKey: this.paired.otherKey\n      });\n\n      this.paired.oneFromTarget = new HasOne(this.paired.target, this.paired.through.model, {\n        foreignKey: this.paired.otherKey,\n        as: this.paired.through.model.name\n      });\n    }\n\n    Helpers.checkNamingCollision(this);\n\n    return this;\n  }\n\n  mixin(obj) {\n    const methods = ['get', 'count', 'hasSingle', 'hasAll', 'set', 'add', 'addMultiple', 'remove', 'removeMultiple', 'create'];\n    const aliases = {\n      hasSingle: 'has',\n      hasAll: 'has',\n      addMultiple: 'add',\n      removeMultiple: 'remove'\n    };\n\n    Helpers.mixinMethods(this, obj, methods, aliases);\n  }\n\n  /**\n   * Get everything currently associated with this, using an optional where clause.\n   *\n   * @see\n   * {@link Model} for a full explanation of options\n   *\n   * @param {Model} instance instance\n   * @param {Object} [options] find options\n   * @param {Object} [options.where] An optional where clause to limit the associated models\n   * @param {string|boolean} [options.scope] Apply a scope on the related model, or remove its default scope by passing false\n   * @param {string} [options.schema] Apply a schema on the related model\n   *\n   * @returns {Promise<Array<Model>>}\n   */\n  get(instance, options) {\n    options = Utils.cloneDeep(options) || {};\n\n    const through = this.through;\n    let scopeWhere;\n    let throughWhere;\n\n    if (this.scope) {\n      scopeWhere = _.clone(this.scope);\n    }\n\n    options.where = {\n      [Op.and]: [\n        scopeWhere,\n        options.where\n      ]\n    };\n\n    if (Object(through.model) === through.model) {\n      throughWhere = {};\n      throughWhere[this.foreignKey] = instance.get(this.sourceKey);\n\n      if (through.scope) {\n        Object.assign(throughWhere, through.scope);\n      }\n\n      //If a user pass a where on the options through options, make an \"and\" with the current throughWhere\n      if (options.through && options.through.where) {\n        throughWhere = {\n          [Op.and]: [throughWhere, options.through.where]\n        };\n      }\n\n      options.include = options.include || [];\n      options.include.push({\n        association: this.oneFromTarget,\n        attributes: options.joinTableAttributes,\n        required: true,\n        where: throughWhere\n      });\n    }\n\n    let model = this.target;\n    if (Object.prototype.hasOwnProperty.call(options, 'scope')) {\n      if (!options.scope) {\n        model = model.unscoped();\n      } else {\n        model = model.scope(options.scope);\n      }\n    }\n\n    if (Object.prototype.hasOwnProperty.call(options, 'schema')) {\n      model = model.schema(options.schema, options.schemaDelimiter);\n    }\n\n    return model.findAll(options);\n  }\n\n  /**\n   * Count everything currently associated with this, using an optional where clause.\n   *\n   * @param {Model} instance instance\n   * @param {Object} [options] find options\n   * @param {Object} [options.where] An optional where clause to limit the associated models\n   * @param {string|boolean} [options.scope] Apply a scope on the related model, or remove its default scope by passing false\n   *\n   * @returns {Promise<number>}\n   */\n  count(instance, options) {\n    const sequelize = this.target.sequelize;\n\n    options = Utils.cloneDeep(options);\n    options.attributes = [\n      [sequelize.fn('COUNT', sequelize.col([this.target.name, this.targetKeyField].join('.'))), 'count']\n    ];\n    options.joinTableAttributes = [];\n    options.raw = true;\n    options.plain = true;\n\n    return this.get(instance, options).then(result => parseInt(result.count, 10));\n  }\n\n  /**\n   * Check if one or more instance(s) are associated with this. If a list of instances is passed, the function returns true if _all_ instances are associated\n   *\n   * @param {Model} sourceInstance source instance to check for an association with\n   * @param {Model|Model[]|string[]|string|number[]|number} [instances] Can be an array of instances or their primary keys\n   * @param {Object} [options] Options passed to getAssociations\n   *\n   * @returns {Promise<boolean>}\n   */\n  has(sourceInstance, instances, options) {\n    if (!Array.isArray(instances)) {\n      instances = [instances];\n    }\n\n    options = Object.assign({\n      raw: true\n    }, options, {\n      scope: false,\n      attributes: [this.targetKey],\n      joinTableAttributes: []\n    });\n\n    const instancePrimaryKeys = instances.map(instance => {\n      if (instance instanceof this.target) {\n        return instance.where();\n      }\n      return {\n        [this.targetKey]: instance\n      };\n    });\n\n    options.where = {\n      [Op.and]: [\n        { [Op.or]: instancePrimaryKeys },\n        options.where\n      ]\n    };\n\n    return this.get(sourceInstance, options).then(associatedObjects =>\n      _.differenceWith(instancePrimaryKeys, associatedObjects,\n        (a, b) => _.isEqual(a[this.targetKey], b[this.targetKey])).length === 0\n    );\n  }\n\n  /**\n   * Set the associated models by passing an array of instances or their primary keys.\n   * Everything that it not in the passed array will be un-associated.\n   *\n   * @param {Model} sourceInstance source instance to associate new instances with\n   * @param {Model|Model[]|string[]|string|number[]|number} [newAssociatedObjects] A single instance or primary key, or a mixed array of persisted instances or primary keys\n   * @param {Object} [options] Options passed to `through.findAll`, `bulkCreate`, `update` and `destroy`\n   * @param {Object} [options.validate] Run validation for the join model\n   * @param {Object} [options.through] Additional attributes for the join table.\n   *\n   * @returns {Promise}\n   */\n  set(sourceInstance, newAssociatedObjects, options) {\n    options = options || {};\n\n    const sourceKey = this.sourceKey;\n    const targetKey = this.targetKey;\n    const identifier = this.identifier;\n    const foreignIdentifier = this.foreignIdentifier;\n    let where = {};\n\n    if (newAssociatedObjects === null) {\n      newAssociatedObjects = [];\n    } else {\n      newAssociatedObjects = this.toInstanceArray(newAssociatedObjects);\n    }\n\n    where[identifier] = sourceInstance.get(sourceKey);\n    where = Object.assign(where, this.through.scope);\n\n    const updateAssociations = currentRows => {\n      const obsoleteAssociations = [];\n      const promises = [];\n      const defaultAttributes = options.through || {};\n\n      const unassociatedObjects = newAssociatedObjects.filter(obj =>\n        !currentRows.some(currentRow => currentRow[foreignIdentifier] === obj.get(targetKey))\n      );\n\n      for (const currentRow of currentRows) {\n        const newObj = newAssociatedObjects.find(obj => currentRow[foreignIdentifier] === obj.get(targetKey));\n\n        if (!newObj) {\n          obsoleteAssociations.push(currentRow);\n        } else {\n          let throughAttributes = newObj[this.through.model.name];\n          // Quick-fix for subtle bug when using existing objects that might have the through model attached (not as an attribute object)\n          if (throughAttributes instanceof this.through.model) {\n            throughAttributes = {};\n          }\n\n          const attributes = _.defaults({}, throughAttributes, defaultAttributes);\n\n          if (Object.keys(attributes).length) {\n            promises.push(\n              this.through.model.update(attributes, Object.assign(options, {\n                where: {\n                  [identifier]: sourceInstance.get(sourceKey),\n                  [foreignIdentifier]: newObj.get(targetKey)\n                }\n              }\n              ))\n            );\n          }\n        }\n      }\n\n      if (obsoleteAssociations.length > 0) {\n        const where = Object.assign({\n          [identifier]: sourceInstance.get(sourceKey),\n          [foreignIdentifier]: obsoleteAssociations.map(obsoleteAssociation => obsoleteAssociation[foreignIdentifier])\n        }, this.through.scope);\n        promises.push(\n          this.through.model.destroy(_.defaults({\n            where\n          }, options))\n        );\n      }\n\n      if (unassociatedObjects.length > 0) {\n        const bulk = unassociatedObjects.map(unassociatedObject => {\n          let attributes = {};\n\n          attributes[identifier] = sourceInstance.get(sourceKey);\n          attributes[foreignIdentifier] = unassociatedObject.get(targetKey);\n\n          attributes = _.defaults(attributes, unassociatedObject[this.through.model.name], defaultAttributes);\n\n          Object.assign(attributes, this.through.scope);\n          attributes = Object.assign(attributes, this.through.scope);\n\n          return attributes;\n        });\n\n        promises.push(this.through.model.bulkCreate(bulk, Object.assign({ validate: true }, options)));\n      }\n\n      return Utils.Promise.all(promises);\n    };\n\n    return this.through.model.findAll(_.defaults({ where, raw: true }, options))\n      .then(currentRows => updateAssociations(currentRows))\n      .catch(error => {\n        if (error instanceof EmptyResultError) return updateAssociations([]);\n        throw error;\n      });\n  }\n\n  /**\n   * Associate one or several rows with source instance. It will not un-associate any already associated instance\n   * that may be missing from `newInstances`.\n   *\n   * @param {Model} sourceInstance source instance to associate new instances with\n   * @param {Model|Model[]|string[]|string|number[]|number} [newInstances] A single instance or primary key, or a mixed array of persisted instances or primary keys\n   * @param {Object} [options] Options passed to `through.findAll`, `bulkCreate` and `update`\n   * @param {Object} [options.validate] Run validation for the join model.\n   * @param {Object} [options.through] Additional attributes for the join table.\n   *\n   * @returns {Promise}\n   */\n  add(sourceInstance, newInstances, options) {\n    // If newInstances is null or undefined, no-op\n    if (!newInstances) return Utils.Promise.resolve();\n\n    options = _.clone(options) || {};\n\n    const association = this;\n    const sourceKey = association.sourceKey;\n    const targetKey = association.targetKey;\n    const identifier = association.identifier;\n    const foreignIdentifier = association.foreignIdentifier;\n    const defaultAttributes = options.through || {};\n\n    newInstances = association.toInstanceArray(newInstances);\n\n    const where = {\n      [identifier]: sourceInstance.get(sourceKey),\n      [foreignIdentifier]: newInstances.map(newInstance => newInstance.get(targetKey))\n    };\n\n    Object.assign(where, association.through.scope);\n\n    const updateAssociations = currentRows => {\n      const promises = [];\n      const unassociatedObjects = [];\n      const changedAssociations = [];\n      for (const obj of newInstances) {\n        const existingAssociation = currentRows && currentRows.find(current => current[foreignIdentifier] === obj.get(targetKey));\n\n        if (!existingAssociation) {\n          unassociatedObjects.push(obj);\n        } else {\n          const throughAttributes = obj[association.through.model.name];\n          const attributes = _.defaults({}, throughAttributes, defaultAttributes);\n\n          if (Object.keys(attributes).some(attribute => attributes[attribute] !== existingAssociation[attribute])) {\n            changedAssociations.push(obj);\n          }\n        }\n      }\n\n      if (unassociatedObjects.length > 0) {\n        const bulk = unassociatedObjects.map(unassociatedObject => {\n          const throughAttributes = unassociatedObject[association.through.model.name];\n          const attributes = _.defaults({}, throughAttributes, defaultAttributes);\n\n          attributes[identifier] = sourceInstance.get(sourceKey);\n          attributes[foreignIdentifier] = unassociatedObject.get(targetKey);\n\n          Object.assign(attributes, association.through.scope);\n\n          return attributes;\n        });\n\n        promises.push(association.through.model.bulkCreate(bulk, Object.assign({ validate: true }, options)));\n      }\n\n      for (const assoc of changedAssociations) {\n        let throughAttributes = assoc[association.through.model.name];\n        const attributes = _.defaults({}, throughAttributes, defaultAttributes);\n        // Quick-fix for subtle bug when using existing objects that might have the through model attached (not as an attribute object)\n        if (throughAttributes instanceof association.through.model) {\n          throughAttributes = {};\n        }\n        const where = {\n          [identifier]: sourceInstance.get(sourceKey),\n          [foreignIdentifier]: assoc.get(targetKey)\n        };\n\n\n        promises.push(association.through.model.update(attributes, Object.assign(options, { where })));\n      }\n\n      return Utils.Promise.all(promises);\n    };\n\n    return association.through.model.findAll(_.defaults({ where, raw: true }, options))\n      .then(currentRows => updateAssociations(currentRows))\n      .then(([associations]) => associations)\n      .catch(error => {\n        if (error instanceof EmptyResultError) return updateAssociations();\n        throw error;\n      });\n  }\n\n  /**\n   * Un-associate one or more instance(s).\n   *\n   * @param {Model} sourceInstance instance to un associate instances with\n   * @param {Model|Model[]|string|string[]|number|number[]} [oldAssociatedObjects] Can be an Instance or its primary key, or a mixed array of instances and primary keys\n   * @param {Object} [options] Options passed to `through.destroy`\n   *\n   * @returns {Promise}\n   */\n  remove(sourceInstance, oldAssociatedObjects, options) {\n    const association = this;\n\n    options = options || {};\n\n    oldAssociatedObjects = association.toInstanceArray(oldAssociatedObjects);\n\n    const where = {\n      [association.identifier]: sourceInstance.get(association.sourceKey),\n      [association.foreignIdentifier]: oldAssociatedObjects.map(newInstance => newInstance.get(association.targetKey))\n    };\n\n    return association.through.model.destroy(_.defaults({ where }, options));\n  }\n\n  /**\n   * Create a new instance of the associated model and associate it with this.\n   *\n   * @param {Model} sourceInstance source instance\n   * @param {Object} [values] values for target model\n   * @param {Object} [options] Options passed to create and add\n   * @param {Object} [options.through] Additional attributes for the join table\n   *\n   * @returns {Promise}\n   */\n  create(sourceInstance, values, options) {\n    const association = this;\n\n    options = options || {};\n    values = values || {};\n\n    if (Array.isArray(options)) {\n      options = {\n        fields: options\n      };\n    }\n\n    if (association.scope) {\n      Object.assign(values, association.scope);\n      if (options.fields) {\n        options.fields = options.fields.concat(Object.keys(association.scope));\n      }\n    }\n\n    // Create the related model instance\n    return association.target.create(values, options).then(newAssociatedObject =>\n      sourceInstance[association.accessors.add](newAssociatedObject, _.omit(options, ['fields'])).return(newAssociatedObject)\n    );\n  }\n\n  verifyAssociationAlias(alias) {\n    if (typeof alias === 'string') {\n      return this.as === alias;\n    }\n\n    if (alias && alias.plural) {\n      return this.as === alias.plural;\n    }\n\n    return !this.isAliased;\n  }\n}\n\nmodule.exports = BelongsToMany;\nmodule.exports.BelongsToMany = BelongsToMany;\nmodule.exports.default = BelongsToMany;\n"]} \ No newline at end of file diff --git a/dist/associations/belongs-to.js b/dist/associations/belongs-to.js index c9bbab9..75d0fea 100644 --- a/dist/associations/belongs-to.js +++ b/dist/associations/belongs-to.js @@ -6,15 +6,19 @@ function _defineProperties(target, props) { for (var i = 0; i < props.length; i+ function _createClass(Constructor, protoProps, staticProps) { if (protoProps) _defineProperties(Constructor.prototype, protoProps); if (staticProps) _defineProperties(Constructor, staticProps); return Constructor; } +function _inherits(subClass, superClass) { if (typeof superClass !== "function" && superClass !== null) { throw new TypeError("Super expression must either be null or a function"); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, writable: true, configurable: true } }); if (superClass) _setPrototypeOf(subClass, superClass); } + +function _setPrototypeOf(o, p) { _setPrototypeOf = Object.setPrototypeOf || function _setPrototypeOf(o, p) { o.__proto__ = p; return o; }; return _setPrototypeOf(o, p); } + +function _createSuper(Derived) { var hasNativeReflectConstruct = _isNativeReflectConstruct(); return function _createSuperInternal() { var Super = _getPrototypeOf(Derived), result; if (hasNativeReflectConstruct) { var NewTarget = _getPrototypeOf(this).constructor; result = Reflect.construct(Super, arguments, NewTarget); } else { result = Super.apply(this, arguments); } return _possibleConstructorReturn(this, result); }; } + function _possibleConstructorReturn(self, call) { if (call && (typeof call === "object" || typeof call === "function")) { return call; } return _assertThisInitialized(self); } function _assertThisInitialized(self) { if (self === void 0) { throw new ReferenceError("this hasn't been initialised - super() hasn't been called"); } return self; } -function _getPrototypeOf(o) { _getPrototypeOf = Object.setPrototypeOf ? Object.getPrototypeOf : function _getPrototypeOf(o) { return o.__proto__ || Object.getPrototypeOf(o); }; return _getPrototypeOf(o); } +function _isNativeReflectConstruct() { if (typeof Reflect === "undefined" || !Reflect.construct) return false; if (Reflect.construct.sham) return false; if (typeof Proxy === "function") return true; try { Date.prototype.toString.call(Reflect.construct(Date, [], function () {})); return true; } catch (e) { return false; } } -function _inherits(subClass, superClass) { if (typeof superClass !== "function" && superClass !== null) { throw new TypeError("Super expression must either be null or a function"); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, writable: true, configurable: true } }); if (superClass) _setPrototypeOf(subClass, superClass); } - -function _setPrototypeOf(o, p) { _setPrototypeOf = Object.setPrototypeOf || function _setPrototypeOf(o, p) { o.__proto__ = p; return o; }; return _setPrototypeOf(o, p); } +function _getPrototypeOf(o) { _getPrototypeOf = Object.setPrototypeOf ? Object.getPrototypeOf : function _getPrototypeOf(o) { return o.__proto__ || Object.getPrototypeOf(o); }; return _getPrototypeOf(o); } const Utils = require('./../utils'); @@ -34,17 +38,17 @@ const Op = require('../operators'); */ -let BelongsTo = -/*#__PURE__*/ -function (_Association) { +let BelongsTo = /*#__PURE__*/function (_Association) { _inherits(BelongsTo, _Association); + var _super = _createSuper(BelongsTo); + function BelongsTo(source, target, options) { var _this; _classCallCheck(this, BelongsTo); - _this = _possibleConstructorReturn(this, _getPrototypeOf(BelongsTo).call(this, source, target, options)); + _this = _super.call(this, source, target, options); _this.associationType = 'BelongsTo'; _this.isSingleAssociation = true; _this.foreignKeyAttribute = {}; @@ -275,4 +279,4 @@ function (_Association) { module.exports = BelongsTo; module.exports.BelongsTo = BelongsTo; module.exports.default = BelongsTo; -//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../lib/associations/belongs-to.js"],"names":["Utils","require","Helpers","_","Association","Op","BelongsTo","source","target","options","associationType","isSingleAssociation","foreignKeyAttribute","as","isAliased","name","singular","isObject","foreignKey","fieldName","camelize","primaryKeyAttribute","join","identifier","rawAttributes","identifierField","field","targetKey","Error","targetKeyField","targetKeyIsPrimary","targetIdentifier","associationAccessor","useHooks","upperFirst","accessors","get","set","create","newAttributes","defaults","type","keyType","allowNull","constraints","onDelete","onUpdate","addForeignKeyConstraints","mergeDefaults","refreshAttributes","checkNamingCollision","obj","methods","mixinMethods","instances","where","Target","instance","cloneDeep","Object","prototype","hasOwnProperty","call","scope","unscoped","schema","schemaDelimiter","Array","isArray","undefined","in","map","findByPk","limit","and","findAll","then","results","result","raw","findOne","sourceInstance","associatedInstance","value","save","assign","fields","association","values","newAssociatedObject","alias","module","exports","default"],"mappings":"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","sourcesContent":["'use strict';\r\n\r\nconst Utils = require('./../utils');\r\nconst Helpers = require('./helpers');\r\nconst _ = require('lodash');\r\nconst Association = require('./base');\r\nconst Op = require('../operators');\r\n\r\n/**\r\n * One-to-one association\r\n *\r\n * In the API reference below, add the name of the association to the method, e.g. for `User.belongsTo(Project)` the getter will be `user.getProject()`.\r\n *\r\n * @see {@link Model.belongsTo}\r\n */\r\nclass BelongsTo extends Association {\r\n  constructor(source, target, options) {\r\n    super(source, target, options);\r\n\r\n    this.associationType = 'BelongsTo';\r\n    this.isSingleAssociation = true;\r\n    this.foreignKeyAttribute = {};\r\n\r\n    if (this.as) {\r\n      this.isAliased = true;\r\n      this.options.name = {\r\n        singular: this.as\r\n      };\r\n    } else {\r\n      this.as = this.target.options.name.singular;\r\n      this.options.name = this.target.options.name;\r\n    }\r\n\r\n    if (_.isObject(this.options.foreignKey)) {\r\n      this.foreignKeyAttribute = this.options.foreignKey;\r\n      this.foreignKey = this.foreignKeyAttribute.name || this.foreignKeyAttribute.fieldName;\r\n    } else if (this.options.foreignKey) {\r\n      this.foreignKey = this.options.foreignKey;\r\n    }\r\n\r\n    if (!this.foreignKey) {\r\n      this.foreignKey = Utils.camelize(\r\n        [\r\n          this.as,\r\n          this.target.primaryKeyAttribute\r\n        ].join('_')\r\n      );\r\n    }\r\n\r\n    this.identifier = this.foreignKey;\r\n    if (this.source.rawAttributes[this.identifier]) {\r\n      this.identifierField = this.source.rawAttributes[this.identifier].field || this.identifier;\r\n    }\r\n\r\n    if (\r\n      this.options.targetKey\r\n      && !this.target.rawAttributes[this.options.targetKey]\r\n    ) {\r\n      throw new Error(`Unknown attribute \"${this.options.targetKey}\" passed as targetKey, define this attribute on model \"${this.target.name}\" first`);\r\n    }\r\n\r\n    this.targetKey = this.options.targetKey || this.target.primaryKeyAttribute;\r\n    this.targetKeyField = this.target.rawAttributes[this.targetKey].field || this.targetKey;\r\n    this.targetKeyIsPrimary = this.targetKey === this.target.primaryKeyAttribute;\r\n    this.targetIdentifier = this.targetKey;\r\n\r\n    this.associationAccessor = this.as;\r\n    this.options.useHooks = options.useHooks;\r\n\r\n    // Get singular name, trying to uppercase the first letter, unless the model forbids it\r\n    const singular = _.upperFirst(this.options.name.singular);\r\n\r\n    this.accessors = {\r\n      get: `get${singular}`,\r\n      set: `set${singular}`,\r\n      create: `create${singular}`\r\n    };\r\n  }\r\n\r\n  // the id is in the source table\r\n  _injectAttributes() {\r\n    const newAttributes = {};\r\n\r\n    newAttributes[this.foreignKey] = _.defaults({}, this.foreignKeyAttribute, {\r\n      type: this.options.keyType || this.target.rawAttributes[this.targetKey].type,\r\n      allowNull: true\r\n    });\r\n\r\n    if (this.options.constraints !== false) {\r\n      const source = this.source.rawAttributes[this.foreignKey] || newAttributes[this.foreignKey];\r\n      this.options.onDelete = this.options.onDelete || (source.allowNull ? 'SET NULL' : 'NO ACTION');\r\n      this.options.onUpdate = this.options.onUpdate || 'CASCADE';\r\n    }\r\n\r\n    Helpers.addForeignKeyConstraints(newAttributes[this.foreignKey], this.target, this.source, this.options, this.targetKeyField);\r\n    Utils.mergeDefaults(this.source.rawAttributes, newAttributes);\r\n\r\n    this.source.refreshAttributes();\r\n\r\n    this.identifierField = this.source.rawAttributes[this.foreignKey].field || this.foreignKey;\r\n\r\n    Helpers.checkNamingCollision(this);\r\n\r\n    return this;\r\n  }\r\n\r\n  mixin(obj) {\r\n    const methods = ['get', 'set', 'create'];\r\n\r\n    Helpers.mixinMethods(this, obj, methods);\r\n  }\r\n\r\n  /**\r\n   * Get the associated instance.\r\n   *\r\n   * @param {Model|Array<Model>} instances source instances\r\n   * @param {Object}         [options] find options\r\n   * @param {string|boolean} [options.scope]  Apply a scope on the related model, or remove its default scope by passing false.\r\n   * @param {string}         [options.schema] Apply a schema on the related model\r\n   *\r\n   * @see\r\n   * {@link Model.findOne} for a full explanation of options\r\n   *\r\n   * @returns {Promise<Model>}\r\n   */\r\n  get(instances, options) {\r\n    const where = {};\r\n    let Target = this.target;\r\n    let instance;\r\n\r\n    options = Utils.cloneDeep(options);\r\n\r\n    if (Object.prototype.hasOwnProperty.call(options, 'scope')) {\r\n      if (!options.scope) {\r\n        Target = Target.unscoped();\r\n      } else {\r\n        Target = Target.scope(options.scope);\r\n      }\r\n    }\r\n\r\n    if (Object.prototype.hasOwnProperty.call(options, 'schema')) {\r\n      Target = Target.schema(options.schema, options.schemaDelimiter);\r\n    }\r\n\r\n    if (!Array.isArray(instances)) {\r\n      instance = instances;\r\n      instances = undefined;\r\n    }\r\n\r\n    if (instances) {\r\n      where[this.targetKey] = {\r\n        [Op.in]: instances.map(instance => instance.get(this.foreignKey))\r\n      };\r\n    } else {\r\n      if (this.targetKeyIsPrimary && !options.where) {\r\n        return Target.findByPk(instance.get(this.foreignKey), options);\r\n      }\r\n      where[this.targetKey] = instance.get(this.foreignKey);\r\n      options.limit = null;\r\n    }\r\n\r\n    options.where = options.where ?\r\n      { [Op.and]: [where, options.where] } :\r\n      where;\r\n\r\n    if (instances) {\r\n      return Target.findAll(options).then(results => {\r\n        const result = {};\r\n        for (const instance of instances) {\r\n          result[instance.get(this.foreignKey, { raw: true })] = null;\r\n        }\r\n\r\n        for (const instance of results) {\r\n          result[instance.get(this.targetKey, { raw: true })] = instance;\r\n        }\r\n\r\n        return result;\r\n      });\r\n    }\r\n\r\n    return Target.findOne(options);\r\n  }\r\n\r\n  /**\r\n   * Set the associated model.\r\n   *\r\n   * @param {Model} sourceInstance the source instance\r\n   * @param {?<Model>|string|number} [associatedInstance] An persisted instance or the primary key of an instance to associate with this. Pass `null` or `undefined` to remove the association.\r\n   * @param {Object} [options={}] options passed to `this.save`\r\n   * @param {boolean} [options.save=true] Skip saving this after setting the foreign key if false.\r\n   *\r\n   *  @returns {Promise}\r\n   */\r\n  set(sourceInstance, associatedInstance, options = {}) {\r\n    let value = associatedInstance;\r\n\r\n    if (associatedInstance instanceof this.target) {\r\n      value = associatedInstance[this.targetKey];\r\n    }\r\n\r\n    sourceInstance.set(this.foreignKey, value);\r\n\r\n    if (options.save === false) return;\r\n\r\n    options = Object.assign({\r\n      fields: [this.foreignKey],\r\n      allowNull: [this.foreignKey],\r\n      association: true\r\n    }, options);\r\n\r\n    // passes the changed field to save, so only that field get updated.\r\n    return sourceInstance.save(options);\r\n  }\r\n\r\n  /**\r\n   * Create a new instance of the associated model and associate it with this.\r\n   *\r\n   * @param {Model} sourceInstance the source instance\r\n   * @param {Object} [values={}] values to create associated model instance with\r\n   * @param {Object} [options={}] Options passed to `target.create` and setAssociation.\r\n   *\r\n   * @see\r\n   * {@link Model#create}  for a full explanation of options\r\n   *\r\n   * @returns {Promise<Model>} The created target model\r\n   */\r\n  create(sourceInstance, values, options) {\r\n    values = values || {};\r\n    options = options || {};\r\n\r\n    return this.target.create(values, options)\r\n      .then(newAssociatedObject => sourceInstance[this.accessors.set](newAssociatedObject, options)\r\n        .then(() => newAssociatedObject)\r\n      );\r\n  }\r\n\r\n  verifyAssociationAlias(alias) {\r\n    if (typeof alias === 'string') {\r\n      return this.as === alias;\r\n    }\r\n\r\n    if (alias && alias.singular) {\r\n      return this.as === alias.singular;\r\n    }\r\n\r\n    return !this.isAliased;\r\n  }\r\n}\r\n\r\nmodule.exports = BelongsTo;\r\nmodule.exports.BelongsTo = BelongsTo;\r\nmodule.exports.default = BelongsTo;\r\n"]} \ No newline at end of file +//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../lib/associations/belongs-to.js"],"names":["Utils","require","Helpers","_","Association","Op","BelongsTo","source","target","options","associationType","isSingleAssociation","foreignKeyAttribute","as","isAliased","name","singular","isObject","foreignKey","fieldName","camelize","primaryKeyAttribute","join","identifier","rawAttributes","identifierField","field","targetKey","Error","targetKeyField","targetKeyIsPrimary","targetIdentifier","associationAccessor","useHooks","upperFirst","accessors","get","set","create","newAttributes","defaults","type","keyType","allowNull","constraints","onDelete","onUpdate","addForeignKeyConstraints","mergeDefaults","refreshAttributes","checkNamingCollision","obj","methods","mixinMethods","instances","where","Target","instance","cloneDeep","Object","prototype","hasOwnProperty","call","scope","unscoped","schema","schemaDelimiter","Array","isArray","undefined","in","map","findByPk","limit","and","findAll","then","results","result","raw","findOne","sourceInstance","associatedInstance","value","save","assign","fields","association","values","newAssociatedObject","alias","module","exports","default"],"mappings":"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","sourcesContent":["'use strict';\n\nconst Utils = require('./../utils');\nconst Helpers = require('./helpers');\nconst _ = require('lodash');\nconst Association = require('./base');\nconst Op = require('../operators');\n\n/**\n * One-to-one association\n *\n * In the API reference below, add the name of the association to the method, e.g. for `User.belongsTo(Project)` the getter will be `user.getProject()`.\n *\n * @see {@link Model.belongsTo}\n */\nclass BelongsTo extends Association {\n  constructor(source, target, options) {\n    super(source, target, options);\n\n    this.associationType = 'BelongsTo';\n    this.isSingleAssociation = true;\n    this.foreignKeyAttribute = {};\n\n    if (this.as) {\n      this.isAliased = true;\n      this.options.name = {\n        singular: this.as\n      };\n    } else {\n      this.as = this.target.options.name.singular;\n      this.options.name = this.target.options.name;\n    }\n\n    if (_.isObject(this.options.foreignKey)) {\n      this.foreignKeyAttribute = this.options.foreignKey;\n      this.foreignKey = this.foreignKeyAttribute.name || this.foreignKeyAttribute.fieldName;\n    } else if (this.options.foreignKey) {\n      this.foreignKey = this.options.foreignKey;\n    }\n\n    if (!this.foreignKey) {\n      this.foreignKey = Utils.camelize(\n        [\n          this.as,\n          this.target.primaryKeyAttribute\n        ].join('_')\n      );\n    }\n\n    this.identifier = this.foreignKey;\n    if (this.source.rawAttributes[this.identifier]) {\n      this.identifierField = this.source.rawAttributes[this.identifier].field || this.identifier;\n    }\n\n    if (\n      this.options.targetKey\n      && !this.target.rawAttributes[this.options.targetKey]\n    ) {\n      throw new Error(`Unknown attribute \"${this.options.targetKey}\" passed as targetKey, define this attribute on model \"${this.target.name}\" first`);\n    }\n\n    this.targetKey = this.options.targetKey || this.target.primaryKeyAttribute;\n    this.targetKeyField = this.target.rawAttributes[this.targetKey].field || this.targetKey;\n    this.targetKeyIsPrimary = this.targetKey === this.target.primaryKeyAttribute;\n    this.targetIdentifier = this.targetKey;\n\n    this.associationAccessor = this.as;\n    this.options.useHooks = options.useHooks;\n\n    // Get singular name, trying to uppercase the first letter, unless the model forbids it\n    const singular = _.upperFirst(this.options.name.singular);\n\n    this.accessors = {\n      get: `get${singular}`,\n      set: `set${singular}`,\n      create: `create${singular}`\n    };\n  }\n\n  // the id is in the source table\n  _injectAttributes() {\n    const newAttributes = {};\n\n    newAttributes[this.foreignKey] = _.defaults({}, this.foreignKeyAttribute, {\n      type: this.options.keyType || this.target.rawAttributes[this.targetKey].type,\n      allowNull: true\n    });\n\n    if (this.options.constraints !== false) {\n      const source = this.source.rawAttributes[this.foreignKey] || newAttributes[this.foreignKey];\n      this.options.onDelete = this.options.onDelete || (source.allowNull ? 'SET NULL' : 'NO ACTION');\n      this.options.onUpdate = this.options.onUpdate || 'CASCADE';\n    }\n\n    Helpers.addForeignKeyConstraints(newAttributes[this.foreignKey], this.target, this.source, this.options, this.targetKeyField);\n    Utils.mergeDefaults(this.source.rawAttributes, newAttributes);\n\n    this.source.refreshAttributes();\n\n    this.identifierField = this.source.rawAttributes[this.foreignKey].field || this.foreignKey;\n\n    Helpers.checkNamingCollision(this);\n\n    return this;\n  }\n\n  mixin(obj) {\n    const methods = ['get', 'set', 'create'];\n\n    Helpers.mixinMethods(this, obj, methods);\n  }\n\n  /**\n   * Get the associated instance.\n   *\n   * @param {Model|Array<Model>} instances source instances\n   * @param {Object}         [options] find options\n   * @param {string|boolean} [options.scope]  Apply a scope on the related model, or remove its default scope by passing false.\n   * @param {string}         [options.schema] Apply a schema on the related model\n   *\n   * @see\n   * {@link Model.findOne} for a full explanation of options\n   *\n   * @returns {Promise<Model>}\n   */\n  get(instances, options) {\n    const where = {};\n    let Target = this.target;\n    let instance;\n\n    options = Utils.cloneDeep(options);\n\n    if (Object.prototype.hasOwnProperty.call(options, 'scope')) {\n      if (!options.scope) {\n        Target = Target.unscoped();\n      } else {\n        Target = Target.scope(options.scope);\n      }\n    }\n\n    if (Object.prototype.hasOwnProperty.call(options, 'schema')) {\n      Target = Target.schema(options.schema, options.schemaDelimiter);\n    }\n\n    if (!Array.isArray(instances)) {\n      instance = instances;\n      instances = undefined;\n    }\n\n    if (instances) {\n      where[this.targetKey] = {\n        [Op.in]: instances.map(instance => instance.get(this.foreignKey))\n      };\n    } else {\n      if (this.targetKeyIsPrimary && !options.where) {\n        return Target.findByPk(instance.get(this.foreignKey), options);\n      }\n      where[this.targetKey] = instance.get(this.foreignKey);\n      options.limit = null;\n    }\n\n    options.where = options.where ?\n      { [Op.and]: [where, options.where] } :\n      where;\n\n    if (instances) {\n      return Target.findAll(options).then(results => {\n        const result = {};\n        for (const instance of instances) {\n          result[instance.get(this.foreignKey, { raw: true })] = null;\n        }\n\n        for (const instance of results) {\n          result[instance.get(this.targetKey, { raw: true })] = instance;\n        }\n\n        return result;\n      });\n    }\n\n    return Target.findOne(options);\n  }\n\n  /**\n   * Set the associated model.\n   *\n   * @param {Model} sourceInstance the source instance\n   * @param {?<Model>|string|number} [associatedInstance] An persisted instance or the primary key of an instance to associate with this. Pass `null` or `undefined` to remove the association.\n   * @param {Object} [options={}] options passed to `this.save`\n   * @param {boolean} [options.save=true] Skip saving this after setting the foreign key if false.\n   *\n   *  @returns {Promise}\n   */\n  set(sourceInstance, associatedInstance, options = {}) {\n    let value = associatedInstance;\n\n    if (associatedInstance instanceof this.target) {\n      value = associatedInstance[this.targetKey];\n    }\n\n    sourceInstance.set(this.foreignKey, value);\n\n    if (options.save === false) return;\n\n    options = Object.assign({\n      fields: [this.foreignKey],\n      allowNull: [this.foreignKey],\n      association: true\n    }, options);\n\n    // passes the changed field to save, so only that field get updated.\n    return sourceInstance.save(options);\n  }\n\n  /**\n   * Create a new instance of the associated model and associate it with this.\n   *\n   * @param {Model} sourceInstance the source instance\n   * @param {Object} [values={}] values to create associated model instance with\n   * @param {Object} [options={}] Options passed to `target.create` and setAssociation.\n   *\n   * @see\n   * {@link Model#create}  for a full explanation of options\n   *\n   * @returns {Promise<Model>} The created target model\n   */\n  create(sourceInstance, values, options) {\n    values = values || {};\n    options = options || {};\n\n    return this.target.create(values, options)\n      .then(newAssociatedObject => sourceInstance[this.accessors.set](newAssociatedObject, options)\n        .then(() => newAssociatedObject)\n      );\n  }\n\n  verifyAssociationAlias(alias) {\n    if (typeof alias === 'string') {\n      return this.as === alias;\n    }\n\n    if (alias && alias.singular) {\n      return this.as === alias.singular;\n    }\n\n    return !this.isAliased;\n  }\n}\n\nmodule.exports = BelongsTo;\nmodule.exports.BelongsTo = BelongsTo;\nmodule.exports.default = BelongsTo;\n"]} \ No newline at end of file diff --git a/dist/associations/has-many.js b/dist/associations/has-many.js index 7a96087..d848a36 100644 --- a/dist/associations/has-many.js +++ b/dist/associations/has-many.js @@ -6,15 +6,19 @@ function _defineProperties(target, props) { for (var i = 0; i < props.length; i+ function _createClass(Constructor, protoProps, staticProps) { if (protoProps) _defineProperties(Constructor.prototype, protoProps); if (staticProps) _defineProperties(Constructor, staticProps); return Constructor; } -function _possibleConstructorReturn(self, call) { if (call && (typeof call === "object" || typeof call === "function")) { return call; } return _assertThisInitialized(self); } +function _inherits(subClass, superClass) { if (typeof superClass !== "function" && superClass !== null) { throw new TypeError("Super expression must either be null or a function"); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, writable: true, configurable: true } }); if (superClass) _setPrototypeOf(subClass, superClass); } -function _getPrototypeOf(o) { _getPrototypeOf = Object.setPrototypeOf ? Object.getPrototypeOf : function _getPrototypeOf(o) { return o.__proto__ || Object.getPrototypeOf(o); }; return _getPrototypeOf(o); } +function _setPrototypeOf(o, p) { _setPrototypeOf = Object.setPrototypeOf || function _setPrototypeOf(o, p) { o.__proto__ = p; return o; }; return _setPrototypeOf(o, p); } + +function _createSuper(Derived) { var hasNativeReflectConstruct = _isNativeReflectConstruct(); return function _createSuperInternal() { var Super = _getPrototypeOf(Derived), result; if (hasNativeReflectConstruct) { var NewTarget = _getPrototypeOf(this).constructor; result = Reflect.construct(Super, arguments, NewTarget); } else { result = Super.apply(this, arguments); } return _possibleConstructorReturn(this, result); }; } + +function _possibleConstructorReturn(self, call) { if (call && (typeof call === "object" || typeof call === "function")) { return call; } return _assertThisInitialized(self); } function _assertThisInitialized(self) { if (self === void 0) { throw new ReferenceError("this hasn't been initialised - super() hasn't been called"); } return self; } -function _inherits(subClass, superClass) { if (typeof superClass !== "function" && superClass !== null) { throw new TypeError("Super expression must either be null or a function"); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, writable: true, configurable: true } }); if (superClass) _setPrototypeOf(subClass, superClass); } +function _isNativeReflectConstruct() { if (typeof Reflect === "undefined" || !Reflect.construct) return false; if (Reflect.construct.sham) return false; if (typeof Proxy === "function") return true; try { Date.prototype.toString.call(Reflect.construct(Date, [], function () {})); return true; } catch (e) { return false; } } -function _setPrototypeOf(o, p) { _setPrototypeOf = Object.setPrototypeOf || function _setPrototypeOf(o, p) { o.__proto__ = p; return o; }; return _setPrototypeOf(o, p); } +function _getPrototypeOf(o) { _getPrototypeOf = Object.setPrototypeOf ? Object.getPrototypeOf : function _getPrototypeOf(o) { return o.__proto__ || Object.getPrototypeOf(o); }; return _getPrototypeOf(o); } const Utils = require('./../utils'); @@ -35,17 +39,17 @@ const Op = require('../operators'); */ -let HasMany = -/*#__PURE__*/ -function (_Association) { +let HasMany = /*#__PURE__*/function (_Association) { _inherits(HasMany, _Association); + var _super = _createSuper(HasMany); + function HasMany(source, target, options) { var _this; _classCallCheck(this, HasMany); - _this = _possibleConstructorReturn(this, _getPrototypeOf(HasMany).call(this, source, target, options)); + _this = _super.call(this, source, target, options); _this.associationType = 'HasMany'; _this.targetAssociation = null; _this.sequelize = source.sequelize; @@ -492,4 +496,4 @@ function (_Association) { module.exports = HasMany; module.exports.HasMany = HasMany; module.exports.default = HasMany; -//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../lib/associations/has-many.js"],"names":["Utils","require","Helpers","_","Association","Op","HasMany","source","target","options","associationType","targetAssociation","sequelize","isMultiAssociation","foreignKeyAttribute","through","Error","isSelfAssociation","as","isAliased","isPlainObject","name","plural","singular","singularize","isObject","foreignKey","fieldName","camelize","primaryKeyAttribute","join","rawAttributes","identifierField","field","foreignKeyField","sourceKey","sourceKeyAttribute","sourceKeyField","primaryKeyField","upperFirst","associationAccessor","accessors","get","set","addMultiple","add","create","remove","removeMultiple","hasSingle","hasAll","count","newAttributes","constraintOptions","clone","defaults","type","keyType","allowNull","constraints","onDelete","onUpdate","addForeignKeyConstraints","mergeDefaults","refreshAttributes","checkNamingCollision","obj","methods","aliases","mixinMethods","instances","where","Model","instance","values","Array","isArray","undefined","Object","assign","scope","map","raw","limit","length","groupedLimit","on","in","and","prototype","hasOwnProperty","call","unscoped","schema","schemaDelimiter","findAll","then","results","result","push","cloneDeep","attributes","fn","col","plain","parseInt","sourceInstance","targetInstances","or","associatedObjects","toInstanceArray","oldAssociations","promises","obsoleteAssociations","filter","old","find","unassociatedObjects","updateWhere","update","associatedObject","unassociatedObject","Promise","all","return","resolve","targetInstance","fields","attribute","keys","alias","module","exports","default"],"mappings":"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","sourcesContent":["'use strict';\r\n\r\nconst Utils = require('./../utils');\r\nconst Helpers = require('./helpers');\r\nconst _ = require('lodash');\r\nconst Association = require('./base');\r\nconst Op = require('../operators');\r\n\r\n/**\r\n * One-to-many association\r\n *\r\n * In the API reference below, add the name of the association to the method, e.g. for `User.hasMany(Project)` the getter will be `user.getProjects()`.\r\n * If the association is aliased, use the alias instead, e.g. `User.hasMany(Project, { as: 'jobs' })` will be `user.getJobs()`.\r\n *\r\n * @see {@link Model.hasMany}\r\n */\r\nclass HasMany extends Association {\r\n  constructor(source, target, options) {\r\n    super(source, target, options);\r\n\r\n    this.associationType = 'HasMany';\r\n    this.targetAssociation = null;\r\n    this.sequelize = source.sequelize;\r\n    this.isMultiAssociation = true;\r\n    this.foreignKeyAttribute = {};\r\n\r\n    if (this.options.through) {\r\n      throw new Error('N:M associations are not supported with hasMany. Use belongsToMany instead');\r\n    }\r\n\r\n    /*\r\n    * If self association, this is the target association\r\n    */\r\n    if (this.isSelfAssociation) {\r\n      this.targetAssociation = this;\r\n    }\r\n\r\n    if (this.as) {\r\n      this.isAliased = true;\r\n\r\n      if (_.isPlainObject(this.as)) {\r\n        this.options.name = this.as;\r\n        this.as = this.as.plural;\r\n      } else {\r\n        this.options.name = {\r\n          plural: this.as,\r\n          singular: Utils.singularize(this.as)\r\n        };\r\n      }\r\n    } else {\r\n      this.as = this.target.options.name.plural;\r\n      this.options.name = this.target.options.name;\r\n    }\r\n\r\n    /*\r\n     * Foreign key setup\r\n     */\r\n    if (_.isObject(this.options.foreignKey)) {\r\n      this.foreignKeyAttribute = this.options.foreignKey;\r\n      this.foreignKey = this.foreignKeyAttribute.name || this.foreignKeyAttribute.fieldName;\r\n    } else if (this.options.foreignKey) {\r\n      this.foreignKey = this.options.foreignKey;\r\n    }\r\n\r\n    if (!this.foreignKey) {\r\n      this.foreignKey = Utils.camelize(\r\n        [\r\n          this.source.options.name.singular,\r\n          this.source.primaryKeyAttribute\r\n        ].join('_')\r\n      );\r\n    }\r\n\r\n    if (this.target.rawAttributes[this.foreignKey]) {\r\n      this.identifierField = this.target.rawAttributes[this.foreignKey].field || this.foreignKey;\r\n      this.foreignKeyField = this.target.rawAttributes[this.foreignKey].field || this.foreignKey;\r\n    }\r\n\r\n    /*\r\n     * Source key setup\r\n     */\r\n    this.sourceKey = this.options.sourceKey || this.source.primaryKeyAttribute;\r\n\r\n    if (this.source.rawAttributes[this.sourceKey]) {\r\n      this.sourceKeyAttribute = this.sourceKey;\r\n      this.sourceKeyField = this.source.rawAttributes[this.sourceKey].field || this.sourceKey;\r\n    } else {\r\n      this.sourceKeyAttribute = this.source.primaryKeyAttribute;\r\n      this.sourceKeyField = this.source.primaryKeyField;\r\n    }\r\n\r\n    // Get singular and plural names\r\n    // try to uppercase the first letter, unless the model forbids it\r\n    const plural = _.upperFirst(this.options.name.plural);\r\n    const singular = _.upperFirst(this.options.name.singular);\r\n\r\n    this.associationAccessor = this.as;\r\n    this.accessors = {\r\n      get: `get${plural}`,\r\n      set: `set${plural}`,\r\n      addMultiple: `add${plural}`,\r\n      add: `add${singular}`,\r\n      create: `create${singular}`,\r\n      remove: `remove${singular}`,\r\n      removeMultiple: `remove${plural}`,\r\n      hasSingle: `has${singular}`,\r\n      hasAll: `has${plural}`,\r\n      count: `count${plural}`\r\n    };\r\n  }\r\n\r\n  // the id is in the target table\r\n  // or in an extra table which connects two tables\r\n  _injectAttributes() {\r\n    const newAttributes = {};\r\n    // Create a new options object for use with addForeignKeyConstraints, to avoid polluting this.options in case it is later used for a n:m\r\n    const constraintOptions = _.clone(this.options);\r\n\r\n    newAttributes[this.foreignKey] = _.defaults({}, this.foreignKeyAttribute, {\r\n      type: this.options.keyType || this.source.rawAttributes[this.sourceKeyAttribute].type,\r\n      allowNull: true\r\n    });\r\n\r\n    if (this.options.constraints !== false) {\r\n      const target = this.target.rawAttributes[this.foreignKey] || newAttributes[this.foreignKey];\r\n      constraintOptions.onDelete = constraintOptions.onDelete || (target.allowNull ? 'SET NULL' : 'CASCADE');\r\n      constraintOptions.onUpdate = constraintOptions.onUpdate || 'CASCADE';\r\n    }\r\n\r\n    Helpers.addForeignKeyConstraints(newAttributes[this.foreignKey], this.source, this.target, constraintOptions, this.sourceKeyField);\r\n    Utils.mergeDefaults(this.target.rawAttributes, newAttributes);\r\n\r\n    this.target.refreshAttributes();\r\n    this.source.refreshAttributes();\r\n\r\n    this.identifierField = this.target.rawAttributes[this.foreignKey].field || this.foreignKey;\r\n    this.foreignKeyField = this.target.rawAttributes[this.foreignKey].field || this.foreignKey;\r\n    this.sourceKeyField = this.source.rawAttributes[this.sourceKey].field || this.sourceKey;\r\n\r\n    Helpers.checkNamingCollision(this);\r\n\r\n    return this;\r\n  }\r\n\r\n  mixin(obj) {\r\n    const methods = ['get', 'count', 'hasSingle', 'hasAll', 'set', 'add', 'addMultiple', 'remove', 'removeMultiple', 'create'];\r\n    const aliases = {\r\n      hasSingle: 'has',\r\n      hasAll: 'has',\r\n      addMultiple: 'add',\r\n      removeMultiple: 'remove'\r\n    };\r\n\r\n    Helpers.mixinMethods(this, obj, methods, aliases);\r\n  }\r\n\r\n  /**\r\n   * Get everything currently associated with this, using an optional where clause.\r\n   *\r\n   * @param {Model|Array<Model>} instances source instances\r\n   * @param {Object} [options] find options\r\n   * @param {Object} [options.where] An optional where clause to limit the associated models\r\n   * @param {string|boolean} [options.scope] Apply a scope on the related model, or remove its default scope by passing false\r\n   * @param {string} [options.schema] Apply a schema on the related model\r\n   *\r\n   * @see\r\n   * {@link Model.findAll}  for a full explanation of options\r\n   *\r\n   * @returns {Promise<Array<Model>>}\r\n   */\r\n  get(instances, options = {}) {\r\n    const where = {};\r\n\r\n    let Model = this.target;\r\n    let instance;\r\n    let values;\r\n\r\n    if (!Array.isArray(instances)) {\r\n      instance = instances;\r\n      instances = undefined;\r\n    }\r\n\r\n    options = Object.assign({}, options);\r\n\r\n    if (this.scope) {\r\n      Object.assign(where, this.scope);\r\n    }\r\n\r\n    if (instances) {\r\n      values = instances.map(instance => instance.get(this.sourceKey, { raw: true }));\r\n\r\n      if (options.limit && instances.length > 1) {\r\n        options.groupedLimit = {\r\n          limit: options.limit,\r\n          on: this, // association\r\n          values\r\n        };\r\n\r\n        delete options.limit;\r\n      } else {\r\n        where[this.foreignKey] = {\r\n          [Op.in]: values\r\n        };\r\n        delete options.groupedLimit;\r\n      }\r\n    } else {\r\n      where[this.foreignKey] = instance.get(this.sourceKey, { raw: true });\r\n    }\r\n\r\n    options.where = options.where ?\r\n      { [Op.and]: [where, options.where] } :\r\n      where;\r\n\r\n    if (Object.prototype.hasOwnProperty.call(options, 'scope')) {\r\n      if (!options.scope) {\r\n        Model = Model.unscoped();\r\n      } else {\r\n        Model = Model.scope(options.scope);\r\n      }\r\n    }\r\n\r\n    if (Object.prototype.hasOwnProperty.call(options, 'schema')) {\r\n      Model = Model.schema(options.schema, options.schemaDelimiter);\r\n    }\r\n\r\n    return Model.findAll(options).then(results => {\r\n      if (instance) return results;\r\n\r\n      const result = {};\r\n      for (const instance of instances) {\r\n        result[instance.get(this.sourceKey, { raw: true })] = [];\r\n      }\r\n\r\n      for (const instance of results) {\r\n        result[instance.get(this.foreignKey, { raw: true })].push(instance);\r\n      }\r\n\r\n      return result;\r\n    });\r\n  }\r\n\r\n  /**\r\n   * Count everything currently associated with this, using an optional where clause.\r\n   *\r\n   * @param {Model}        instance the source instance\r\n   * @param {Object}         [options] find & count options\r\n   * @param {Object}         [options.where] An optional where clause to limit the associated models\r\n   * @param {string|boolean} [options.scope] Apply a scope on the related model, or remove its default scope by passing false\r\n   *\r\n   * @returns {Promise<number>}\r\n   */\r\n  count(instance, options) {\r\n    options = Utils.cloneDeep(options);\r\n\r\n    options.attributes = [\r\n      [\r\n        this.sequelize.fn(\r\n          'COUNT',\r\n          this.sequelize.col(`${this.target.name}.${this.target.primaryKeyField}`)\r\n        ),\r\n        'count'\r\n      ]\r\n    ];\r\n    options.raw = true;\r\n    options.plain = true;\r\n\r\n    return this.get(instance, options).then(result => parseInt(result.count, 10));\r\n  }\r\n\r\n  /**\r\n   * Check if one or more rows are associated with `this`.\r\n   *\r\n   * @param {Model} sourceInstance the source instance\r\n   * @param {Model|Model[]|string[]|string|number[]|number} [targetInstances] Can be an array of instances or their primary keys\r\n   * @param {Object} [options] Options passed to getAssociations\r\n   *\r\n   * @returns {Promise}\r\n   */\r\n  has(sourceInstance, targetInstances, options) {\r\n    const where = {};\r\n\r\n    if (!Array.isArray(targetInstances)) {\r\n      targetInstances = [targetInstances];\r\n    }\r\n\r\n    options = Object.assign({}, options, {\r\n      scope: false,\r\n      attributes: [this.target.primaryKeyAttribute],\r\n      raw: true\r\n    });\r\n\r\n    where[Op.or] = targetInstances.map(instance => {\r\n      if (instance instanceof this.target) {\r\n        return instance.where();\r\n      }\r\n      return {\r\n        [this.target.primaryKeyAttribute]: instance\r\n      };\r\n    });\r\n\r\n    options.where = {\r\n      [Op.and]: [\r\n        where,\r\n        options.where\r\n      ]\r\n    };\r\n\r\n    return this.get(sourceInstance, options).then(associatedObjects => associatedObjects.length === targetInstances.length);\r\n  }\r\n\r\n  /**\r\n   * Set the associated models by passing an array of persisted instances or their primary keys. Everything that is not in the passed array will be un-associated\r\n   *\r\n   * @param {Model} sourceInstance source instance to associate new instances with\r\n   * @param {Model|Model[]|string[]|string|number[]|number} [targetInstances] An array of persisted instances or primary key of instances to associate with this. Pass `null` or `undefined` to remove all associations.\r\n   * @param {Object} [options] Options passed to `target.findAll` and `update`.\r\n   * @param {Object} [options.validate] Run validation for the join model\r\n   *\r\n   * @returns {Promise}\r\n   */\r\n  set(sourceInstance, targetInstances, options) {\r\n    if (targetInstances === null) {\r\n      targetInstances = [];\r\n    } else {\r\n      targetInstances = this.toInstanceArray(targetInstances);\r\n    }\r\n\r\n    return this.get(sourceInstance, _.defaults({ scope: false, raw: true }, options)).then(oldAssociations => {\r\n      const promises = [];\r\n      const obsoleteAssociations = oldAssociations.filter(old =>\r\n        !targetInstances.find(obj =>\r\n          obj[this.target.primaryKeyAttribute] === old[this.target.primaryKeyAttribute]\r\n        )\r\n      );\r\n      const unassociatedObjects = targetInstances.filter(obj =>\r\n        !oldAssociations.find(old =>\r\n          obj[this.target.primaryKeyAttribute] === old[this.target.primaryKeyAttribute]\r\n        )\r\n      );\r\n      let updateWhere;\r\n      let update;\r\n\r\n      if (obsoleteAssociations.length > 0) {\r\n        update = {};\r\n        update[this.foreignKey] = null;\r\n\r\n        updateWhere = {\r\n          [this.target.primaryKeyAttribute]: obsoleteAssociations.map(associatedObject =>\r\n            associatedObject[this.target.primaryKeyAttribute]\r\n          )\r\n        };\r\n\r\n\r\n        promises.push(this.target.unscoped().update(\r\n          update,\r\n          _.defaults({\r\n            where: updateWhere\r\n          }, options)\r\n        ));\r\n      }\r\n\r\n      if (unassociatedObjects.length > 0) {\r\n        updateWhere = {};\r\n\r\n        update = {};\r\n        update[this.foreignKey] = sourceInstance.get(this.sourceKey);\r\n\r\n        Object.assign(update, this.scope);\r\n        updateWhere[this.target.primaryKeyAttribute] = unassociatedObjects.map(unassociatedObject =>\r\n          unassociatedObject[this.target.primaryKeyAttribute]\r\n        );\r\n\r\n        promises.push(this.target.unscoped().update(\r\n          update,\r\n          _.defaults({\r\n            where: updateWhere\r\n          }, options)\r\n        ));\r\n      }\r\n\r\n      return Utils.Promise.all(promises).return(sourceInstance);\r\n    });\r\n  }\r\n\r\n  /**\r\n   * Associate one or more target rows with `this`. This method accepts a Model / string / number to associate a single row,\r\n   * or a mixed array of Model / string / numbers to associate multiple rows.\r\n   *\r\n   * @param {Model} sourceInstance the source instance\r\n   * @param {Model|Model[]|string[]|string|number[]|number} [targetInstances] A single instance or primary key, or a mixed array of persisted instances or primary keys\r\n   * @param {Object} [options] Options passed to `target.update`.\r\n   *\r\n   * @returns {Promise}\r\n   */\r\n  add(sourceInstance, targetInstances, options = {}) {\r\n    if (!targetInstances) return Utils.Promise.resolve();\r\n\r\n    const update = {};\r\n\r\n    targetInstances = this.toInstanceArray(targetInstances);\r\n\r\n    update[this.foreignKey] = sourceInstance.get(this.sourceKey);\r\n    Object.assign(update, this.scope);\r\n\r\n    const where = {\r\n      [this.target.primaryKeyAttribute]: targetInstances.map(unassociatedObject =>\r\n        unassociatedObject.get(this.target.primaryKeyAttribute)\r\n      )\r\n    };\r\n\r\n    return this.target.unscoped().update(update, _.defaults({ where }, options)).return(sourceInstance);\r\n  }\r\n\r\n  /**\r\n   * Un-associate one or several target rows.\r\n   *\r\n   * @param {Model} sourceInstance instance to un associate instances with\r\n   * @param {Model|Model[]|string|string[]|number|number[]} [targetInstances] Can be an Instance or its primary key, or a mixed array of instances and primary keys\r\n   * @param {Object} [options] Options passed to `target.update`\r\n   *\r\n   * @returns {Promise}\r\n   */\r\n  remove(sourceInstance, targetInstances, options = {}) {\r\n    const update = {\r\n      [this.foreignKey]: null\r\n    };\r\n\r\n    targetInstances = this.toInstanceArray(targetInstances);\r\n\r\n    const where = {\r\n      [this.foreignKey]: sourceInstance.get(this.sourceKey),\r\n      [this.target.primaryKeyAttribute]: targetInstances.map(targetInstance =>\r\n        targetInstance.get(this.target.primaryKeyAttribute)\r\n      )\r\n    };\r\n\r\n    return this.target.unscoped().update(update, _.defaults({ where }, options)).return(this);\r\n  }\r\n\r\n  /**\r\n   * Create a new instance of the associated model and associate it with this.\r\n   *\r\n   * @param {Model} sourceInstance source instance\r\n   * @param {Object} [values] values for target model instance\r\n   * @param {Object} [options] Options passed to `target.create`\r\n   *\r\n   * @returns {Promise}\r\n   */\r\n  create(sourceInstance, values, options = {}) {\r\n    if (Array.isArray(options)) {\r\n      options = {\r\n        fields: options\r\n      };\r\n    }\r\n\r\n    if (values === undefined) {\r\n      values = {};\r\n    }\r\n\r\n    if (this.scope) {\r\n      for (const attribute of Object.keys(this.scope)) {\r\n        values[attribute] = this.scope[attribute];\r\n        if (options.fields) options.fields.push(attribute);\r\n      }\r\n    }\r\n\r\n    values[this.foreignKey] = sourceInstance.get(this.sourceKey);\r\n    if (options.fields) options.fields.push(this.foreignKey);\r\n    return this.target.create(values, options);\r\n  }\r\n\r\n  verifyAssociationAlias(alias) {\r\n    if (typeof alias === 'string') {\r\n      return this.as === alias;\r\n    }\r\n\r\n    if (alias && alias.plural) {\r\n      return this.as === alias.plural;\r\n    }\r\n\r\n    return !this.isAliased;\r\n  }\r\n}\r\n\r\nmodule.exports = HasMany;\r\nmodule.exports.HasMany = HasMany;\r\nmodule.exports.default = HasMany;\r\n"]} \ No newline at end of file +//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../lib/associations/has-many.js"],"names":["Utils","require","Helpers","_","Association","Op","HasMany","source","target","options","associationType","targetAssociation","sequelize","isMultiAssociation","foreignKeyAttribute","through","Error","isSelfAssociation","as","isAliased","isPlainObject","name","plural","singular","singularize","isObject","foreignKey","fieldName","camelize","primaryKeyAttribute","join","rawAttributes","identifierField","field","foreignKeyField","sourceKey","sourceKeyAttribute","sourceKeyField","primaryKeyField","upperFirst","associationAccessor","accessors","get","set","addMultiple","add","create","remove","removeMultiple","hasSingle","hasAll","count","newAttributes","constraintOptions","clone","defaults","type","keyType","allowNull","constraints","onDelete","onUpdate","addForeignKeyConstraints","mergeDefaults","refreshAttributes","checkNamingCollision","obj","methods","aliases","mixinMethods","instances","where","Model","instance","values","Array","isArray","undefined","Object","assign","scope","map","raw","limit","length","groupedLimit","on","in","and","prototype","hasOwnProperty","call","unscoped","schema","schemaDelimiter","findAll","then","results","result","push","cloneDeep","attributes","fn","col","plain","parseInt","sourceInstance","targetInstances","or","associatedObjects","toInstanceArray","oldAssociations","promises","obsoleteAssociations","filter","old","find","unassociatedObjects","updateWhere","update","associatedObject","unassociatedObject","Promise","all","return","resolve","targetInstance","fields","attribute","keys","alias","module","exports","default"],"mappings":"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","sourcesContent":["'use strict';\n\nconst Utils = require('./../utils');\nconst Helpers = require('./helpers');\nconst _ = require('lodash');\nconst Association = require('./base');\nconst Op = require('../operators');\n\n/**\n * One-to-many association\n *\n * In the API reference below, add the name of the association to the method, e.g. for `User.hasMany(Project)` the getter will be `user.getProjects()`.\n * If the association is aliased, use the alias instead, e.g. `User.hasMany(Project, { as: 'jobs' })` will be `user.getJobs()`.\n *\n * @see {@link Model.hasMany}\n */\nclass HasMany extends Association {\n  constructor(source, target, options) {\n    super(source, target, options);\n\n    this.associationType = 'HasMany';\n    this.targetAssociation = null;\n    this.sequelize = source.sequelize;\n    this.isMultiAssociation = true;\n    this.foreignKeyAttribute = {};\n\n    if (this.options.through) {\n      throw new Error('N:M associations are not supported with hasMany. Use belongsToMany instead');\n    }\n\n    /*\n    * If self association, this is the target association\n    */\n    if (this.isSelfAssociation) {\n      this.targetAssociation = this;\n    }\n\n    if (this.as) {\n      this.isAliased = true;\n\n      if (_.isPlainObject(this.as)) {\n        this.options.name = this.as;\n        this.as = this.as.plural;\n      } else {\n        this.options.name = {\n          plural: this.as,\n          singular: Utils.singularize(this.as)\n        };\n      }\n    } else {\n      this.as = this.target.options.name.plural;\n      this.options.name = this.target.options.name;\n    }\n\n    /*\n     * Foreign key setup\n     */\n    if (_.isObject(this.options.foreignKey)) {\n      this.foreignKeyAttribute = this.options.foreignKey;\n      this.foreignKey = this.foreignKeyAttribute.name || this.foreignKeyAttribute.fieldName;\n    } else if (this.options.foreignKey) {\n      this.foreignKey = this.options.foreignKey;\n    }\n\n    if (!this.foreignKey) {\n      this.foreignKey = Utils.camelize(\n        [\n          this.source.options.name.singular,\n          this.source.primaryKeyAttribute\n        ].join('_')\n      );\n    }\n\n    if (this.target.rawAttributes[this.foreignKey]) {\n      this.identifierField = this.target.rawAttributes[this.foreignKey].field || this.foreignKey;\n      this.foreignKeyField = this.target.rawAttributes[this.foreignKey].field || this.foreignKey;\n    }\n\n    /*\n     * Source key setup\n     */\n    this.sourceKey = this.options.sourceKey || this.source.primaryKeyAttribute;\n\n    if (this.source.rawAttributes[this.sourceKey]) {\n      this.sourceKeyAttribute = this.sourceKey;\n      this.sourceKeyField = this.source.rawAttributes[this.sourceKey].field || this.sourceKey;\n    } else {\n      this.sourceKeyAttribute = this.source.primaryKeyAttribute;\n      this.sourceKeyField = this.source.primaryKeyField;\n    }\n\n    // Get singular and plural names\n    // try to uppercase the first letter, unless the model forbids it\n    const plural = _.upperFirst(this.options.name.plural);\n    const singular = _.upperFirst(this.options.name.singular);\n\n    this.associationAccessor = this.as;\n    this.accessors = {\n      get: `get${plural}`,\n      set: `set${plural}`,\n      addMultiple: `add${plural}`,\n      add: `add${singular}`,\n      create: `create${singular}`,\n      remove: `remove${singular}`,\n      removeMultiple: `remove${plural}`,\n      hasSingle: `has${singular}`,\n      hasAll: `has${plural}`,\n      count: `count${plural}`\n    };\n  }\n\n  // the id is in the target table\n  // or in an extra table which connects two tables\n  _injectAttributes() {\n    const newAttributes = {};\n    // Create a new options object for use with addForeignKeyConstraints, to avoid polluting this.options in case it is later used for a n:m\n    const constraintOptions = _.clone(this.options);\n\n    newAttributes[this.foreignKey] = _.defaults({}, this.foreignKeyAttribute, {\n      type: this.options.keyType || this.source.rawAttributes[this.sourceKeyAttribute].type,\n      allowNull: true\n    });\n\n    if (this.options.constraints !== false) {\n      const target = this.target.rawAttributes[this.foreignKey] || newAttributes[this.foreignKey];\n      constraintOptions.onDelete = constraintOptions.onDelete || (target.allowNull ? 'SET NULL' : 'CASCADE');\n      constraintOptions.onUpdate = constraintOptions.onUpdate || 'CASCADE';\n    }\n\n    Helpers.addForeignKeyConstraints(newAttributes[this.foreignKey], this.source, this.target, constraintOptions, this.sourceKeyField);\n    Utils.mergeDefaults(this.target.rawAttributes, newAttributes);\n\n    this.target.refreshAttributes();\n    this.source.refreshAttributes();\n\n    this.identifierField = this.target.rawAttributes[this.foreignKey].field || this.foreignKey;\n    this.foreignKeyField = this.target.rawAttributes[this.foreignKey].field || this.foreignKey;\n    this.sourceKeyField = this.source.rawAttributes[this.sourceKey].field || this.sourceKey;\n\n    Helpers.checkNamingCollision(this);\n\n    return this;\n  }\n\n  mixin(obj) {\n    const methods = ['get', 'count', 'hasSingle', 'hasAll', 'set', 'add', 'addMultiple', 'remove', 'removeMultiple', 'create'];\n    const aliases = {\n      hasSingle: 'has',\n      hasAll: 'has',\n      addMultiple: 'add',\n      removeMultiple: 'remove'\n    };\n\n    Helpers.mixinMethods(this, obj, methods, aliases);\n  }\n\n  /**\n   * Get everything currently associated with this, using an optional where clause.\n   *\n   * @param {Model|Array<Model>} instances source instances\n   * @param {Object} [options] find options\n   * @param {Object} [options.where] An optional where clause to limit the associated models\n   * @param {string|boolean} [options.scope] Apply a scope on the related model, or remove its default scope by passing false\n   * @param {string} [options.schema] Apply a schema on the related model\n   *\n   * @see\n   * {@link Model.findAll}  for a full explanation of options\n   *\n   * @returns {Promise<Array<Model>>}\n   */\n  get(instances, options = {}) {\n    const where = {};\n\n    let Model = this.target;\n    let instance;\n    let values;\n\n    if (!Array.isArray(instances)) {\n      instance = instances;\n      instances = undefined;\n    }\n\n    options = Object.assign({}, options);\n\n    if (this.scope) {\n      Object.assign(where, this.scope);\n    }\n\n    if (instances) {\n      values = instances.map(instance => instance.get(this.sourceKey, { raw: true }));\n\n      if (options.limit && instances.length > 1) {\n        options.groupedLimit = {\n          limit: options.limit,\n          on: this, // association\n          values\n        };\n\n        delete options.limit;\n      } else {\n        where[this.foreignKey] = {\n          [Op.in]: values\n        };\n        delete options.groupedLimit;\n      }\n    } else {\n      where[this.foreignKey] = instance.get(this.sourceKey, { raw: true });\n    }\n\n    options.where = options.where ?\n      { [Op.and]: [where, options.where] } :\n      where;\n\n    if (Object.prototype.hasOwnProperty.call(options, 'scope')) {\n      if (!options.scope) {\n        Model = Model.unscoped();\n      } else {\n        Model = Model.scope(options.scope);\n      }\n    }\n\n    if (Object.prototype.hasOwnProperty.call(options, 'schema')) {\n      Model = Model.schema(options.schema, options.schemaDelimiter);\n    }\n\n    return Model.findAll(options).then(results => {\n      if (instance) return results;\n\n      const result = {};\n      for (const instance of instances) {\n        result[instance.get(this.sourceKey, { raw: true })] = [];\n      }\n\n      for (const instance of results) {\n        result[instance.get(this.foreignKey, { raw: true })].push(instance);\n      }\n\n      return result;\n    });\n  }\n\n  /**\n   * Count everything currently associated with this, using an optional where clause.\n   *\n   * @param {Model}        instance the source instance\n   * @param {Object}         [options] find & count options\n   * @param {Object}         [options.where] An optional where clause to limit the associated models\n   * @param {string|boolean} [options.scope] Apply a scope on the related model, or remove its default scope by passing false\n   *\n   * @returns {Promise<number>}\n   */\n  count(instance, options) {\n    options = Utils.cloneDeep(options);\n\n    options.attributes = [\n      [\n        this.sequelize.fn(\n          'COUNT',\n          this.sequelize.col(`${this.target.name}.${this.target.primaryKeyField}`)\n        ),\n        'count'\n      ]\n    ];\n    options.raw = true;\n    options.plain = true;\n\n    return this.get(instance, options).then(result => parseInt(result.count, 10));\n  }\n\n  /**\n   * Check if one or more rows are associated with `this`.\n   *\n   * @param {Model} sourceInstance the source instance\n   * @param {Model|Model[]|string[]|string|number[]|number} [targetInstances] Can be an array of instances or their primary keys\n   * @param {Object} [options] Options passed to getAssociations\n   *\n   * @returns {Promise}\n   */\n  has(sourceInstance, targetInstances, options) {\n    const where = {};\n\n    if (!Array.isArray(targetInstances)) {\n      targetInstances = [targetInstances];\n    }\n\n    options = Object.assign({}, options, {\n      scope: false,\n      attributes: [this.target.primaryKeyAttribute],\n      raw: true\n    });\n\n    where[Op.or] = targetInstances.map(instance => {\n      if (instance instanceof this.target) {\n        return instance.where();\n      }\n      return {\n        [this.target.primaryKeyAttribute]: instance\n      };\n    });\n\n    options.where = {\n      [Op.and]: [\n        where,\n        options.where\n      ]\n    };\n\n    return this.get(sourceInstance, options).then(associatedObjects => associatedObjects.length === targetInstances.length);\n  }\n\n  /**\n   * Set the associated models by passing an array of persisted instances or their primary keys. Everything that is not in the passed array will be un-associated\n   *\n   * @param {Model} sourceInstance source instance to associate new instances with\n   * @param {Model|Model[]|string[]|string|number[]|number} [targetInstances] An array of persisted instances or primary key of instances to associate with this. Pass `null` or `undefined` to remove all associations.\n   * @param {Object} [options] Options passed to `target.findAll` and `update`.\n   * @param {Object} [options.validate] Run validation for the join model\n   *\n   * @returns {Promise}\n   */\n  set(sourceInstance, targetInstances, options) {\n    if (targetInstances === null) {\n      targetInstances = [];\n    } else {\n      targetInstances = this.toInstanceArray(targetInstances);\n    }\n\n    return this.get(sourceInstance, _.defaults({ scope: false, raw: true }, options)).then(oldAssociations => {\n      const promises = [];\n      const obsoleteAssociations = oldAssociations.filter(old =>\n        !targetInstances.find(obj =>\n          obj[this.target.primaryKeyAttribute] === old[this.target.primaryKeyAttribute]\n        )\n      );\n      const unassociatedObjects = targetInstances.filter(obj =>\n        !oldAssociations.find(old =>\n          obj[this.target.primaryKeyAttribute] === old[this.target.primaryKeyAttribute]\n        )\n      );\n      let updateWhere;\n      let update;\n\n      if (obsoleteAssociations.length > 0) {\n        update = {};\n        update[this.foreignKey] = null;\n\n        updateWhere = {\n          [this.target.primaryKeyAttribute]: obsoleteAssociations.map(associatedObject =>\n            associatedObject[this.target.primaryKeyAttribute]\n          )\n        };\n\n\n        promises.push(this.target.unscoped().update(\n          update,\n          _.defaults({\n            where: updateWhere\n          }, options)\n        ));\n      }\n\n      if (unassociatedObjects.length > 0) {\n        updateWhere = {};\n\n        update = {};\n        update[this.foreignKey] = sourceInstance.get(this.sourceKey);\n\n        Object.assign(update, this.scope);\n        updateWhere[this.target.primaryKeyAttribute] = unassociatedObjects.map(unassociatedObject =>\n          unassociatedObject[this.target.primaryKeyAttribute]\n        );\n\n        promises.push(this.target.unscoped().update(\n          update,\n          _.defaults({\n            where: updateWhere\n          }, options)\n        ));\n      }\n\n      return Utils.Promise.all(promises).return(sourceInstance);\n    });\n  }\n\n  /**\n   * Associate one or more target rows with `this`. This method accepts a Model / string / number to associate a single row,\n   * or a mixed array of Model / string / numbers to associate multiple rows.\n   *\n   * @param {Model} sourceInstance the source instance\n   * @param {Model|Model[]|string[]|string|number[]|number} [targetInstances] A single instance or primary key, or a mixed array of persisted instances or primary keys\n   * @param {Object} [options] Options passed to `target.update`.\n   *\n   * @returns {Promise}\n   */\n  add(sourceInstance, targetInstances, options = {}) {\n    if (!targetInstances) return Utils.Promise.resolve();\n\n    const update = {};\n\n    targetInstances = this.toInstanceArray(targetInstances);\n\n    update[this.foreignKey] = sourceInstance.get(this.sourceKey);\n    Object.assign(update, this.scope);\n\n    const where = {\n      [this.target.primaryKeyAttribute]: targetInstances.map(unassociatedObject =>\n        unassociatedObject.get(this.target.primaryKeyAttribute)\n      )\n    };\n\n    return this.target.unscoped().update(update, _.defaults({ where }, options)).return(sourceInstance);\n  }\n\n  /**\n   * Un-associate one or several target rows.\n   *\n   * @param {Model} sourceInstance instance to un associate instances with\n   * @param {Model|Model[]|string|string[]|number|number[]} [targetInstances] Can be an Instance or its primary key, or a mixed array of instances and primary keys\n   * @param {Object} [options] Options passed to `target.update`\n   *\n   * @returns {Promise}\n   */\n  remove(sourceInstance, targetInstances, options = {}) {\n    const update = {\n      [this.foreignKey]: null\n    };\n\n    targetInstances = this.toInstanceArray(targetInstances);\n\n    const where = {\n      [this.foreignKey]: sourceInstance.get(this.sourceKey),\n      [this.target.primaryKeyAttribute]: targetInstances.map(targetInstance =>\n        targetInstance.get(this.target.primaryKeyAttribute)\n      )\n    };\n\n    return this.target.unscoped().update(update, _.defaults({ where }, options)).return(this);\n  }\n\n  /**\n   * Create a new instance of the associated model and associate it with this.\n   *\n   * @param {Model} sourceInstance source instance\n   * @param {Object} [values] values for target model instance\n   * @param {Object} [options] Options passed to `target.create`\n   *\n   * @returns {Promise}\n   */\n  create(sourceInstance, values, options = {}) {\n    if (Array.isArray(options)) {\n      options = {\n        fields: options\n      };\n    }\n\n    if (values === undefined) {\n      values = {};\n    }\n\n    if (this.scope) {\n      for (const attribute of Object.keys(this.scope)) {\n        values[attribute] = this.scope[attribute];\n        if (options.fields) options.fields.push(attribute);\n      }\n    }\n\n    values[this.foreignKey] = sourceInstance.get(this.sourceKey);\n    if (options.fields) options.fields.push(this.foreignKey);\n    return this.target.create(values, options);\n  }\n\n  verifyAssociationAlias(alias) {\n    if (typeof alias === 'string') {\n      return this.as === alias;\n    }\n\n    if (alias && alias.plural) {\n      return this.as === alias.plural;\n    }\n\n    return !this.isAliased;\n  }\n}\n\nmodule.exports = HasMany;\nmodule.exports.HasMany = HasMany;\nmodule.exports.default = HasMany;\n"]} \ No newline at end of file diff --git a/dist/associations/has-one.js b/dist/associations/has-one.js index 58b0f77..3bf7a9f 100644 --- a/dist/associations/has-one.js +++ b/dist/associations/has-one.js @@ -6,15 +6,19 @@ function _defineProperties(target, props) { for (var i = 0; i < props.length; i+ function _createClass(Constructor, protoProps, staticProps) { if (protoProps) _defineProperties(Constructor.prototype, protoProps); if (staticProps) _defineProperties(Constructor, staticProps); return Constructor; } +function _inherits(subClass, superClass) { if (typeof superClass !== "function" && superClass !== null) { throw new TypeError("Super expression must either be null or a function"); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, writable: true, configurable: true } }); if (superClass) _setPrototypeOf(subClass, superClass); } + +function _setPrototypeOf(o, p) { _setPrototypeOf = Object.setPrototypeOf || function _setPrototypeOf(o, p) { o.__proto__ = p; return o; }; return _setPrototypeOf(o, p); } + +function _createSuper(Derived) { var hasNativeReflectConstruct = _isNativeReflectConstruct(); return function _createSuperInternal() { var Super = _getPrototypeOf(Derived), result; if (hasNativeReflectConstruct) { var NewTarget = _getPrototypeOf(this).constructor; result = Reflect.construct(Super, arguments, NewTarget); } else { result = Super.apply(this, arguments); } return _possibleConstructorReturn(this, result); }; } + function _possibleConstructorReturn(self, call) { if (call && (typeof call === "object" || typeof call === "function")) { return call; } return _assertThisInitialized(self); } function _assertThisInitialized(self) { if (self === void 0) { throw new ReferenceError("this hasn't been initialised - super() hasn't been called"); } return self; } -function _getPrototypeOf(o) { _getPrototypeOf = Object.setPrototypeOf ? Object.getPrototypeOf : function _getPrototypeOf(o) { return o.__proto__ || Object.getPrototypeOf(o); }; return _getPrototypeOf(o); } +function _isNativeReflectConstruct() { if (typeof Reflect === "undefined" || !Reflect.construct) return false; if (Reflect.construct.sham) return false; if (typeof Proxy === "function") return true; try { Date.prototype.toString.call(Reflect.construct(Date, [], function () {})); return true; } catch (e) { return false; } } -function _inherits(subClass, superClass) { if (typeof superClass !== "function" && superClass !== null) { throw new TypeError("Super expression must either be null or a function"); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, writable: true, configurable: true } }); if (superClass) _setPrototypeOf(subClass, superClass); } - -function _setPrototypeOf(o, p) { _setPrototypeOf = Object.setPrototypeOf || function _setPrototypeOf(o, p) { o.__proto__ = p; return o; }; return _setPrototypeOf(o, p); } +function _getPrototypeOf(o) { _getPrototypeOf = Object.setPrototypeOf ? Object.getPrototypeOf : function _getPrototypeOf(o) { return o.__proto__ || Object.getPrototypeOf(o); }; return _getPrototypeOf(o); } const Utils = require('./../utils'); @@ -35,17 +39,17 @@ const Op = require('../operators'); */ -let HasOne = -/*#__PURE__*/ -function (_Association) { +let HasOne = /*#__PURE__*/function (_Association) { _inherits(HasOne, _Association); + var _super = _createSuper(HasOne); + function HasOne(source, target, options) { var _this; _classCallCheck(this, HasOne); - _this = _possibleConstructorReturn(this, _getPrototypeOf(HasOne).call(this, source, target, options)); + _this = _super.call(this, source, target, options); _this.associationType = 'HasOne'; _this.isSingleAssociation = true; _this.foreignKeyAttribute = {}; @@ -309,4 +313,4 @@ function (_Association) { }(Association); module.exports = HasOne; -//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../lib/associations/has-one.js"],"names":["Utils","require","Helpers","_","Association","Op","HasOne","source","target","options","associationType","isSingleAssociation","foreignKeyAttribute","as","isAliased","name","singular","isObject","foreignKey","fieldName","camelize","singularize","primaryKeyAttribute","join","sourceKey","rawAttributes","Error","sourceKeyAttribute","sourceKeyField","field","sourceKeyIsPrimary","associationAccessor","useHooks","identifierField","upperFirst","accessors","get","set","create","newAttributes","defaults","type","keyType","allowNull","constraints","onDelete","onUpdate","addForeignKeyConstraints","mergeDefaults","refreshAttributes","checkNamingCollision","obj","methods","mixinMethods","instances","where","Target","instance","cloneDeep","Object","prototype","hasOwnProperty","call","scope","unscoped","schema","schemaDelimiter","Array","isArray","undefined","in","map","assign","and","findAll","then","results","result","raw","findOne","sourceInstance","associatedInstance","alreadyAssociated","oldInstance","primaryKeyAttributes","every","attribute","save","fields","association","tmpInstance","build","isNewRecord","values","keys","push","alias","module","exports"],"mappings":"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","sourcesContent":["'use strict';\r\n\r\nconst Utils = require('./../utils');\r\nconst Helpers = require('./helpers');\r\nconst _ = require('lodash');\r\nconst Association = require('./base');\r\nconst Op = require('../operators');\r\n\r\n/**\r\n * One-to-one association\r\n *\r\n * In the API reference below, add the name of the association to the method, e.g. for `User.hasOne(Project)` the getter will be `user.getProject()`.\r\n * This is almost the same as `belongsTo` with one exception - The foreign key will be defined on the target model.\r\n *\r\n * @see {@link Model.hasOne}\r\n */\r\nclass HasOne extends Association {\r\n  constructor(source, target, options) {\r\n    super(source, target, options);\r\n\r\n    this.associationType = 'HasOne';\r\n    this.isSingleAssociation = true;\r\n    this.foreignKeyAttribute = {};\r\n\r\n    if (this.as) {\r\n      this.isAliased = true;\r\n      this.options.name = {\r\n        singular: this.as\r\n      };\r\n    } else {\r\n      this.as = this.target.options.name.singular;\r\n      this.options.name = this.target.options.name;\r\n    }\r\n\r\n    if (_.isObject(this.options.foreignKey)) {\r\n      this.foreignKeyAttribute = this.options.foreignKey;\r\n      this.foreignKey = this.foreignKeyAttribute.name || this.foreignKeyAttribute.fieldName;\r\n    } else if (this.options.foreignKey) {\r\n      this.foreignKey = this.options.foreignKey;\r\n    }\r\n\r\n    if (!this.foreignKey) {\r\n      this.foreignKey = Utils.camelize(\r\n        [\r\n          Utils.singularize(this.options.as || this.source.name),\r\n          this.source.primaryKeyAttribute\r\n        ].join('_')\r\n      );\r\n    }\r\n\r\n    if (\r\n      this.options.sourceKey\r\n      && !this.source.rawAttributes[this.options.sourceKey]\r\n    ) {\r\n      throw new Error(`Unknown attribute \"${this.options.sourceKey}\" passed as sourceKey, define this attribute on model \"${this.source.name}\" first`);\r\n    }\r\n\r\n    this.sourceKey = this.sourceKeyAttribute = this.options.sourceKey || this.source.primaryKeyAttribute;\r\n    this.sourceKeyField = this.source.rawAttributes[this.sourceKey].field || this.sourceKey;\r\n    this.sourceKeyIsPrimary = this.sourceKey === this.source.primaryKeyAttribute;\r\n\r\n    this.associationAccessor = this.as;\r\n    this.options.useHooks = options.useHooks;\r\n\r\n    if (this.target.rawAttributes[this.foreignKey]) {\r\n      this.identifierField = this.target.rawAttributes[this.foreignKey].field || this.foreignKey;\r\n    }\r\n\r\n    // Get singular name, trying to uppercase the first letter, unless the model forbids it\r\n    const singular = _.upperFirst(this.options.name.singular);\r\n\r\n    this.accessors = {\r\n      get: `get${singular}`,\r\n      set: `set${singular}`,\r\n      create: `create${singular}`\r\n    };\r\n  }\r\n\r\n  // the id is in the target table\r\n  _injectAttributes() {\r\n    const newAttributes = {};\r\n\r\n    newAttributes[this.foreignKey] = _.defaults({}, this.foreignKeyAttribute, {\r\n      type: this.options.keyType || this.source.rawAttributes[this.sourceKey].type,\r\n      allowNull: true\r\n    });\r\n\r\n    if (this.options.constraints !== false) {\r\n      const target = this.target.rawAttributes[this.foreignKey] || newAttributes[this.foreignKey];\r\n      this.options.onDelete = this.options.onDelete || (target.allowNull ? 'SET NULL' : 'CASCADE');\r\n      this.options.onUpdate = this.options.onUpdate || 'CASCADE';\r\n    }\r\n\r\n    Helpers.addForeignKeyConstraints(newAttributes[this.foreignKey], this.source, this.target, this.options, this.sourceKeyField);\r\n    Utils.mergeDefaults(this.target.rawAttributes, newAttributes);\r\n\r\n    this.target.refreshAttributes();\r\n\r\n    this.identifierField = this.target.rawAttributes[this.foreignKey].field || this.foreignKey;\r\n\r\n    Helpers.checkNamingCollision(this);\r\n\r\n    return this;\r\n  }\r\n\r\n  mixin(obj) {\r\n    const methods = ['get', 'set', 'create'];\r\n\r\n    Helpers.mixinMethods(this, obj, methods);\r\n  }\r\n\r\n  /**\r\n   * Get the associated instance.\r\n   *\r\n   * @param {Model|Array<Model>} instances source instances\r\n   * @param {Object}         [options] find options\r\n   * @param {string|boolean} [options.scope] Apply a scope on the related model, or remove its default scope by passing false\r\n   * @param {string} [options.schema] Apply a schema on the related model\r\n   *\r\n   * @see\r\n   * {@link Model.findOne} for a full explanation of options\r\n   *\r\n   * @returns {Promise<Model>}\r\n   */\r\n  get(instances, options) {\r\n    const where = {};\r\n\r\n    let Target = this.target;\r\n    let instance;\r\n\r\n    options = Utils.cloneDeep(options);\r\n\r\n    if (Object.prototype.hasOwnProperty.call(options, 'scope')) {\r\n      if (!options.scope) {\r\n        Target = Target.unscoped();\r\n      } else {\r\n        Target = Target.scope(options.scope);\r\n      }\r\n    }\r\n\r\n    if (Object.prototype.hasOwnProperty.call(options, 'schema')) {\r\n      Target = Target.schema(options.schema, options.schemaDelimiter);\r\n    }\r\n\r\n    if (!Array.isArray(instances)) {\r\n      instance = instances;\r\n      instances = undefined;\r\n    }\r\n\r\n    if (instances) {\r\n      where[this.foreignKey] = {\r\n        [Op.in]: instances.map(instance => instance.get(this.sourceKey))\r\n      };\r\n    } else {\r\n      where[this.foreignKey] = instance.get(this.sourceKey);\r\n    }\r\n\r\n    if (this.scope) {\r\n      Object.assign(where, this.scope);\r\n    }\r\n\r\n    options.where = options.where ?\r\n      { [Op.and]: [where, options.where] } :\r\n      where;\r\n\r\n    if (instances) {\r\n      return Target.findAll(options).then(results => {\r\n        const result = {};\r\n        for (const instance of instances) {\r\n          result[instance.get(this.sourceKey, { raw: true })] = null;\r\n        }\r\n\r\n        for (const instance of results) {\r\n          result[instance.get(this.foreignKey, { raw: true })] = instance;\r\n        }\r\n\r\n        return result;\r\n      });\r\n    }\r\n\r\n    return Target.findOne(options);\r\n  }\r\n\r\n  /**\r\n   * Set the associated model.\r\n   *\r\n   * @param {Model} sourceInstance the source instance\r\n   * @param {?<Model>|string|number} [associatedInstance] An persisted instance or the primary key of an instance to associate with this. Pass `null` or `undefined` to remove the association.\r\n   * @param {Object} [options] Options passed to getAssociation and `target.save`\r\n   *\r\n   * @returns {Promise}\r\n   */\r\n  set(sourceInstance, associatedInstance, options) {\r\n    let alreadyAssociated;\r\n\r\n    options = Object.assign({}, options, {\r\n      scope: false\r\n    });\r\n\r\n    return sourceInstance[this.accessors.get](options).then(oldInstance => {\r\n      // TODO Use equals method once #5605 is resolved\r\n      alreadyAssociated = oldInstance && associatedInstance && this.target.primaryKeyAttributes.every(attribute =>\r\n        oldInstance.get(attribute, { raw: true }) === (associatedInstance.get ? associatedInstance.get(attribute, { raw: true }) : associatedInstance)\r\n      );\r\n\r\n      if (oldInstance && !alreadyAssociated) {\r\n        oldInstance[this.foreignKey] = null;\r\n        return oldInstance.save(Object.assign({}, options, {\r\n          fields: [this.foreignKey],\r\n          allowNull: [this.foreignKey],\r\n          association: true\r\n        }));\r\n      }\r\n    }).then(() => {\r\n      if (associatedInstance && !alreadyAssociated) {\r\n        if (!(associatedInstance instanceof this.target)) {\r\n          const tmpInstance = {};\r\n          tmpInstance[this.target.primaryKeyAttribute] = associatedInstance;\r\n          associatedInstance = this.target.build(tmpInstance, {\r\n            isNewRecord: false\r\n          });\r\n        }\r\n\r\n        Object.assign(associatedInstance, this.scope);\r\n        associatedInstance.set(this.foreignKey, sourceInstance.get(this.sourceKeyAttribute));\r\n\r\n        return associatedInstance.save(options);\r\n      }\r\n\r\n      return null;\r\n    });\r\n  }\r\n\r\n  /**\r\n   * Create a new instance of the associated model and associate it with this.\r\n   *\r\n   * @param {Model} sourceInstance the source instance\r\n   * @param {Object} [values={}] values to create associated model instance with\r\n   * @param {Object} [options] Options passed to `target.create` and setAssociation.\r\n   *\r\n   * @see\r\n   * {@link Model#create} for a full explanation of options\r\n   *\r\n   * @returns {Promise<Model>} The created target model\r\n   */\r\n  create(sourceInstance, values, options) {\r\n    values = values || {};\r\n    options = options || {};\r\n\r\n    if (this.scope) {\r\n      for (const attribute of Object.keys(this.scope)) {\r\n        values[attribute] = this.scope[attribute];\r\n        if (options.fields) {\r\n          options.fields.push(attribute);\r\n        }\r\n      }\r\n    }\r\n\r\n    values[this.foreignKey] = sourceInstance.get(this.sourceKeyAttribute);\r\n    if (options.fields) {\r\n      options.fields.push(this.foreignKey);\r\n    }\r\n\r\n    return this.target.create(values, options);\r\n  }\r\n\r\n  verifyAssociationAlias(alias) {\r\n    if (typeof alias === 'string') {\r\n      return this.as === alias;\r\n    }\r\n\r\n    if (alias && alias.singular) {\r\n      return this.as === alias.singular;\r\n    }\r\n\r\n    return !this.isAliased;\r\n  }\r\n}\r\n\r\nmodule.exports = HasOne;\r\n"]} \ No newline at end of file +//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../lib/associations/has-one.js"],"names":["Utils","require","Helpers","_","Association","Op","HasOne","source","target","options","associationType","isSingleAssociation","foreignKeyAttribute","as","isAliased","name","singular","isObject","foreignKey","fieldName","camelize","singularize","primaryKeyAttribute","join","sourceKey","rawAttributes","Error","sourceKeyAttribute","sourceKeyField","field","sourceKeyIsPrimary","associationAccessor","useHooks","identifierField","upperFirst","accessors","get","set","create","newAttributes","defaults","type","keyType","allowNull","constraints","onDelete","onUpdate","addForeignKeyConstraints","mergeDefaults","refreshAttributes","checkNamingCollision","obj","methods","mixinMethods","instances","where","Target","instance","cloneDeep","Object","prototype","hasOwnProperty","call","scope","unscoped","schema","schemaDelimiter","Array","isArray","undefined","in","map","assign","and","findAll","then","results","result","raw","findOne","sourceInstance","associatedInstance","alreadyAssociated","oldInstance","primaryKeyAttributes","every","attribute","save","fields","association","tmpInstance","build","isNewRecord","values","keys","push","alias","module","exports"],"mappings":"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","sourcesContent":["'use strict';\n\nconst Utils = require('./../utils');\nconst Helpers = require('./helpers');\nconst _ = require('lodash');\nconst Association = require('./base');\nconst Op = require('../operators');\n\n/**\n * One-to-one association\n *\n * In the API reference below, add the name of the association to the method, e.g. for `User.hasOne(Project)` the getter will be `user.getProject()`.\n * This is almost the same as `belongsTo` with one exception - The foreign key will be defined on the target model.\n *\n * @see {@link Model.hasOne}\n */\nclass HasOne extends Association {\n  constructor(source, target, options) {\n    super(source, target, options);\n\n    this.associationType = 'HasOne';\n    this.isSingleAssociation = true;\n    this.foreignKeyAttribute = {};\n\n    if (this.as) {\n      this.isAliased = true;\n      this.options.name = {\n        singular: this.as\n      };\n    } else {\n      this.as = this.target.options.name.singular;\n      this.options.name = this.target.options.name;\n    }\n\n    if (_.isObject(this.options.foreignKey)) {\n      this.foreignKeyAttribute = this.options.foreignKey;\n      this.foreignKey = this.foreignKeyAttribute.name || this.foreignKeyAttribute.fieldName;\n    } else if (this.options.foreignKey) {\n      this.foreignKey = this.options.foreignKey;\n    }\n\n    if (!this.foreignKey) {\n      this.foreignKey = Utils.camelize(\n        [\n          Utils.singularize(this.options.as || this.source.name),\n          this.source.primaryKeyAttribute\n        ].join('_')\n      );\n    }\n\n    if (\n      this.options.sourceKey\n      && !this.source.rawAttributes[this.options.sourceKey]\n    ) {\n      throw new Error(`Unknown attribute \"${this.options.sourceKey}\" passed as sourceKey, define this attribute on model \"${this.source.name}\" first`);\n    }\n\n    this.sourceKey = this.sourceKeyAttribute = this.options.sourceKey || this.source.primaryKeyAttribute;\n    this.sourceKeyField = this.source.rawAttributes[this.sourceKey].field || this.sourceKey;\n    this.sourceKeyIsPrimary = this.sourceKey === this.source.primaryKeyAttribute;\n\n    this.associationAccessor = this.as;\n    this.options.useHooks = options.useHooks;\n\n    if (this.target.rawAttributes[this.foreignKey]) {\n      this.identifierField = this.target.rawAttributes[this.foreignKey].field || this.foreignKey;\n    }\n\n    // Get singular name, trying to uppercase the first letter, unless the model forbids it\n    const singular = _.upperFirst(this.options.name.singular);\n\n    this.accessors = {\n      get: `get${singular}`,\n      set: `set${singular}`,\n      create: `create${singular}`\n    };\n  }\n\n  // the id is in the target table\n  _injectAttributes() {\n    const newAttributes = {};\n\n    newAttributes[this.foreignKey] = _.defaults({}, this.foreignKeyAttribute, {\n      type: this.options.keyType || this.source.rawAttributes[this.sourceKey].type,\n      allowNull: true\n    });\n\n    if (this.options.constraints !== false) {\n      const target = this.target.rawAttributes[this.foreignKey] || newAttributes[this.foreignKey];\n      this.options.onDelete = this.options.onDelete || (target.allowNull ? 'SET NULL' : 'CASCADE');\n      this.options.onUpdate = this.options.onUpdate || 'CASCADE';\n    }\n\n    Helpers.addForeignKeyConstraints(newAttributes[this.foreignKey], this.source, this.target, this.options, this.sourceKeyField);\n    Utils.mergeDefaults(this.target.rawAttributes, newAttributes);\n\n    this.target.refreshAttributes();\n\n    this.identifierField = this.target.rawAttributes[this.foreignKey].field || this.foreignKey;\n\n    Helpers.checkNamingCollision(this);\n\n    return this;\n  }\n\n  mixin(obj) {\n    const methods = ['get', 'set', 'create'];\n\n    Helpers.mixinMethods(this, obj, methods);\n  }\n\n  /**\n   * Get the associated instance.\n   *\n   * @param {Model|Array<Model>} instances source instances\n   * @param {Object}         [options] find options\n   * @param {string|boolean} [options.scope] Apply a scope on the related model, or remove its default scope by passing false\n   * @param {string} [options.schema] Apply a schema on the related model\n   *\n   * @see\n   * {@link Model.findOne} for a full explanation of options\n   *\n   * @returns {Promise<Model>}\n   */\n  get(instances, options) {\n    const where = {};\n\n    let Target = this.target;\n    let instance;\n\n    options = Utils.cloneDeep(options);\n\n    if (Object.prototype.hasOwnProperty.call(options, 'scope')) {\n      if (!options.scope) {\n        Target = Target.unscoped();\n      } else {\n        Target = Target.scope(options.scope);\n      }\n    }\n\n    if (Object.prototype.hasOwnProperty.call(options, 'schema')) {\n      Target = Target.schema(options.schema, options.schemaDelimiter);\n    }\n\n    if (!Array.isArray(instances)) {\n      instance = instances;\n      instances = undefined;\n    }\n\n    if (instances) {\n      where[this.foreignKey] = {\n        [Op.in]: instances.map(instance => instance.get(this.sourceKey))\n      };\n    } else {\n      where[this.foreignKey] = instance.get(this.sourceKey);\n    }\n\n    if (this.scope) {\n      Object.assign(where, this.scope);\n    }\n\n    options.where = options.where ?\n      { [Op.and]: [where, options.where] } :\n      where;\n\n    if (instances) {\n      return Target.findAll(options).then(results => {\n        const result = {};\n        for (const instance of instances) {\n          result[instance.get(this.sourceKey, { raw: true })] = null;\n        }\n\n        for (const instance of results) {\n          result[instance.get(this.foreignKey, { raw: true })] = instance;\n        }\n\n        return result;\n      });\n    }\n\n    return Target.findOne(options);\n  }\n\n  /**\n   * Set the associated model.\n   *\n   * @param {Model} sourceInstance the source instance\n   * @param {?<Model>|string|number} [associatedInstance] An persisted instance or the primary key of an instance to associate with this. Pass `null` or `undefined` to remove the association.\n   * @param {Object} [options] Options passed to getAssociation and `target.save`\n   *\n   * @returns {Promise}\n   */\n  set(sourceInstance, associatedInstance, options) {\n    let alreadyAssociated;\n\n    options = Object.assign({}, options, {\n      scope: false\n    });\n\n    return sourceInstance[this.accessors.get](options).then(oldInstance => {\n      // TODO Use equals method once #5605 is resolved\n      alreadyAssociated = oldInstance && associatedInstance && this.target.primaryKeyAttributes.every(attribute =>\n        oldInstance.get(attribute, { raw: true }) === (associatedInstance.get ? associatedInstance.get(attribute, { raw: true }) : associatedInstance)\n      );\n\n      if (oldInstance && !alreadyAssociated) {\n        oldInstance[this.foreignKey] = null;\n        return oldInstance.save(Object.assign({}, options, {\n          fields: [this.foreignKey],\n          allowNull: [this.foreignKey],\n          association: true\n        }));\n      }\n    }).then(() => {\n      if (associatedInstance && !alreadyAssociated) {\n        if (!(associatedInstance instanceof this.target)) {\n          const tmpInstance = {};\n          tmpInstance[this.target.primaryKeyAttribute] = associatedInstance;\n          associatedInstance = this.target.build(tmpInstance, {\n            isNewRecord: false\n          });\n        }\n\n        Object.assign(associatedInstance, this.scope);\n        associatedInstance.set(this.foreignKey, sourceInstance.get(this.sourceKeyAttribute));\n\n        return associatedInstance.save(options);\n      }\n\n      return null;\n    });\n  }\n\n  /**\n   * Create a new instance of the associated model and associate it with this.\n   *\n   * @param {Model} sourceInstance the source instance\n   * @param {Object} [values={}] values to create associated model instance with\n   * @param {Object} [options] Options passed to `target.create` and setAssociation.\n   *\n   * @see\n   * {@link Model#create} for a full explanation of options\n   *\n   * @returns {Promise<Model>} The created target model\n   */\n  create(sourceInstance, values, options) {\n    values = values || {};\n    options = options || {};\n\n    if (this.scope) {\n      for (const attribute of Object.keys(this.scope)) {\n        values[attribute] = this.scope[attribute];\n        if (options.fields) {\n          options.fields.push(attribute);\n        }\n      }\n    }\n\n    values[this.foreignKey] = sourceInstance.get(this.sourceKeyAttribute);\n    if (options.fields) {\n      options.fields.push(this.foreignKey);\n    }\n\n    return this.target.create(values, options);\n  }\n\n  verifyAssociationAlias(alias) {\n    if (typeof alias === 'string') {\n      return this.as === alias;\n    }\n\n    if (alias && alias.singular) {\n      return this.as === alias.singular;\n    }\n\n    return !this.isAliased;\n  }\n}\n\nmodule.exports = HasOne;\n"]} \ No newline at end of file diff --git a/dist/associations/helpers.js b/dist/associations/helpers.js index 6baa849..5c9147f 100644 --- a/dist/associations/helpers.js +++ b/dist/associations/helpers.js @@ -66,4 +66,4 @@ function mixinMethods(association, obj, methods, aliases) { } exports.mixinMethods = mixinMethods; -//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uL2xpYi9hc3NvY2lhdGlvbnMvaGVscGVycy5qcyJdLCJuYW1lcyI6WyJjaGVja05hbWluZ0NvbGxpc2lvbiIsImFzc29jaWF0aW9uIiwiT2JqZWN0IiwicHJvdG90eXBlIiwiaGFzT3duUHJvcGVydHkiLCJjYWxsIiwic291cmNlIiwicmF3QXR0cmlidXRlcyIsImFzIiwiRXJyb3IiLCJuYW1lIiwiZXhwb3J0cyIsImFkZEZvcmVpZ25LZXlDb25zdHJhaW50cyIsIm5ld0F0dHJpYnV0ZSIsInRhcmdldCIsIm9wdGlvbnMiLCJrZXkiLCJmb3JlaWduS2V5Q29uc3RyYWludCIsIm9uRGVsZXRlIiwib25VcGRhdGUiLCJwcmltYXJ5S2V5cyIsImtleXMiLCJtYXAiLCJwcmltYXJ5S2V5QXR0cmlidXRlIiwiZmllbGQiLCJsZW5ndGgiLCJpbmNsdWRlcyIsIl9zY2hlbWEiLCJyZWZlcmVuY2VzIiwibW9kZWwiLCJzZXF1ZWxpemUiLCJnZXRRdWVyeUludGVyZmFjZSIsIlF1ZXJ5R2VuZXJhdG9yIiwiYWRkU2NoZW1hIiwidGFibGVOYW1lIiwiX3NjaGVtYURlbGltaXRlciIsIm1peGluTWV0aG9kcyIsIm9iaiIsIm1ldGhvZHMiLCJhbGlhc2VzIiwibWV0aG9kIiwiYWNjZXNzb3JzIiwicmVhbE1ldGhvZCIsIkFycmF5IiwiZnJvbSIsImFyZ3VtZW50cyJdLCJtYXBwaW5ncyI6IkFBQUE7O0FBRUEsU0FBU0Esb0JBQVQsQ0FBOEJDLFdBQTlCLEVBQTJDO0FBQ3pDLE1BQUlDLE1BQU0sQ0FBQ0MsU0FBUCxDQUFpQkMsY0FBakIsQ0FBZ0NDLElBQWhDLENBQXFDSixXQUFXLENBQUNLLE1BQVosQ0FBbUJDLGFBQXhELEVBQXVFTixXQUFXLENBQUNPLEVBQW5GLENBQUosRUFBNEY7QUFDMUYsVUFBTSxJQUFJQyxLQUFKLENBQ0gsdUNBQXNDUixXQUFXLENBQUNPLEVBQUcsR0FBdEQsR0FDQyxxQkFBb0JQLFdBQVcsQ0FBQ08sRUFBRyxjQUFhUCxXQUFXLENB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WyIndXNlIHN0cmljdCc7XHJcblxyXG5mdW5jdGlvbiBjaGVja05hbWluZ0NvbGxpc2lvbihhc3NvY2lhdGlvbikge1xyXG4gIGlmIChPYmplY3QucHJvdG90eXBlLmhhc093blByb3BlcnR5LmNhbGwoYXNzb2NpYXRpb24uc291cmNlLnJhd0F0dHJpYnV0ZXMsIGFzc29jaWF0aW9uLmFzKSkge1xyXG4gICAgdGhyb3cgbmV3IEVycm9yKFxyXG4gICAgICBgTmFtaW5nIGNvbGxpc2lvbiBiZXR3ZWVuIGF0dHJpYnV0ZSAnJHthc3NvY2lhdGlvbi5hc30nYCArXHJcbiAgICAgIGAgYW5kIGFzc29jaWF0aW9uICcke2Fzc29jaWF0aW9uLmFzfScgb24gbW9kZWwgJHthc3NvY2lhdGlvbi5zb3VyY2UubmFtZX1gICtcclxuICAgICAgJy4gVG8gcmVtZWR5IHRoaXMsIGNoYW5nZSBlaXRoZXIgZm9yZWlnbktleSBvciBhcyBpbiB5b3VyIGFzc29jaWF0aW9uIGRlZmluaXRpb24nXHJcbiAgICApO1xyXG4gIH1cclxufVxyXG5leHBvcnRzLmNoZWNrTmFtaW5nQ29sbGlzaW9uID0gY2hlY2tOYW1pbmdDb2xsaXNpb247XHJcblxyXG5mdW5jdGlvbiBhZGRGb3JlaWduS2V5Q29uc3RyYWludHMobmV3QXR0cmlidXRlLCBzb3VyY2UsIHRhcmdldCwgb3B0aW9ucywga2V5KSB7XHJcbiAgLy8gRksgY29uc3RyYWludHMgYXJlIG9wdC1pbjogdXNlcnMgbXVzdCBlaXRoZXIgc2V0IGBmb3JlaWduS2V5Q29uc3RyYWludHNgXHJcbiAgLy8gb24gdGhlIGFzc29jaWF0aW9uLCBvciByZXF1ZXN0IGFuIGBvbkRlbGV0ZWAgb3IgYG9uVXBkYXRlYCBiZWhhdmlvclxyXG5cclxuICBpZiAob3B0aW9ucy5mb3JlaWduS2V5Q29uc3RyYWludCB8fCBvcHRpb25zLm9uRGVsZXRlIHx8IG9wdGlvbnMub25VcGRhdGUpIHtcclxuICAgIC8vIEZpbmQgcHJpbWFyeSBrZXlzOiBjb21wb3NpdGUga2V5cyBub3Qgc3VwcG9ydGVkIHdpdGggdGhpcyBhcHByb2FjaFxyXG4gICAgY29uc3QgcHJpbWFyeUtleXMgPSBPYmplY3Qua2V5cyhzb3VyY2UucHJpbWFyeUtleXMpXHJcbiAgICAgIC5tYXAocHJpbWFyeUtleUF0dHJpYnV0ZSA9PiBzb3VyY2UucmF3QXR0cmlidXRlc1twcmltYXJ5S2V5QXR0cmlidXRlXS5maWVsZCB8fCBwcmltYXJ5S2V5QXR0cmlidXRlKTtcclxuXHJcbiAgICBpZiAocHJpbWFyeUtleXMubGVuZ3RoID09PSAxIHx8ICFwcmltYXJ5S2V5cy5pbmNsdWRlcyhrZXkpKSB7XHJcbiAgICAgIGlmIChzb3VyY2UuX3NjaGVtYSkge1xyXG4gICAgICAgIG5ld0F0dHJpYnV0ZS5yZWZlcmVuY2VzID0ge1xyXG4gICAgICAgICAgbW9kZWw6IHNvdXJjZS5zZXF1ZWxpemUuZ2V0UXVlcnlJbnRlcmZhY2UoKS5RdWVyeUdlbmVyYXRvci5hZGRTY2hlbWEoe1xyXG4gICAgICAgICAgICB0YWJsZU5hbWU6IHNvdXJjZS50YWJsZU5hbWUsXHJcbiAgICAgICAgICAgIF9zY2hlbWE6IHNvdXJjZS5fc2NoZW1hLFxyXG4gICAgICAgICAgICBfc2NoZW1hRGVsaW1pdGVyOiBzb3VyY2UuX3NjaGVtYURlbGltaXRlclxyXG4gICAgICAgICAgfSlcclxuICAgICAgICB9O1xyXG4gICAgICB9IGVsc2Uge1xyXG4gICAgICAgIG5ld0F0dHJpYnV0ZS5yZWZlcmVuY2VzID0geyBtb2RlbDogc291cmNlLnRhYmxlTmFtZSB9O1xyXG4gICAgICB9XHJcblxyXG4gICAgICBuZXdBdHRyaWJ1dGUucmVmZXJlbmNlcy5rZXkgPSBrZXkgfHwgcHJpbWFyeUtleXNbMF07XHJcbiAgICAgIG5ld0F0dHJpYnV0ZS5vbkRlbGV0ZSA9IG9wdGlvbnMub25EZWxldGU7XHJcbiAgICAgIG5ld0F0dHJpYnV0ZS5vblVwZGF0ZSA9IG9wdGlvbnMub25VcGRhdGU7XHJcbiAgICB9XHJcbiAgfVxyXG59XHJcbmV4cG9ydHMuYWRkRm9yZWlnbktleUNvbnN0cmFpbnRzID0gYWRkRm9yZWlnbktleUNvbnN0cmFpbnRzO1xyXG5cclxuLyoqXHJcbiAqIE1peGluIChpbmplY3QpIGFzc29jaWF0aW9uIG1ldGhvZHMgdG8gbW9kZWwgcHJvdG90eXBlXHJcbiAqXHJcbiAqIEBwcml2YXRlXHJcbiAqXHJcbiAqIEBwYXJhbSB7T2JqZWN0fSBhc3NvY2lhdGlvbiBpbnN0YW5jZVxyXG4gKiBAcGFyYW0ge09iamVjdH0gb2JqIE1vZGVsIHByb3RvdHlwZVxyXG4gKiBAcGFyYW0ge0FycmF5fSBtZXRob2RzIE1ldGhvZCBuYW1lcyB0byBpbmplY3RcclxuICogQHBhcmFtIHtPYmplY3R9IGFsaWFzZXMgTWFwcGluZyBiZXR3ZWVuIG1vZGVsIGFuZCBhc3NvY2lhdGlvbiBtZXRob2QgbmFtZXNcclxuICpcclxuICovXHJcbmZ1bmN0aW9uIG1peGluTWV0aG9kcyhhc3NvY2lhdGlvbiwgb2JqLCBtZXRob2RzLCBhbGlhc2VzKSB7XHJcbiAgYWxpYXNlcyA9IGFsaWFzZXMgfHwge307XHJcblxyXG4gIGZvciAoY29uc3QgbWV0aG9kIG9mIG1ldGhvZHMpIHtcclxuICAgIC8vIGRvbid0IG92ZXJyaWRlIGN1c3RvbSBtZXRob2RzXHJcbiAgICBpZiAoIU9iamVjdC5wcm90b3R5cGUuaGFzT3duUHJvcGVydHkuY2FsbChvYmosIGFzc29jaWF0aW9uLmFjY2Vzc29yc1ttZXRob2RdKSkge1xyXG4gICAgICBjb25zdCByZWFsTWV0aG9kID0gYWxpYXNlc1ttZXRob2RdIHx8IG1ldGhvZDtcclxuXHJcbiAgICAgIG9ialthc3NvY2lhdGlvbi5hY2Nlc3NvcnNbbWV0aG9kXV0gPSBmdW5jdGlvbigpIHtcclxuICAgICAgICByZXR1cm4gYXNzb2NpYXRpb25bcmVhbE1ldGhvZF0odGhpcywgLi4uQXJyYXkuZnJvbShhcmd1bWVudHMpKTtcclxuICAgICAgfTtcclxuICAgIH1cclxuICB9XHJcbn1cclxuZXhwb3J0cy5taXhpbk1ldGhvZHMgPSBtaXhpbk1ldGhvZHM7XHJcbiJdfQ== \ No newline at end of file +//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uL2xpYi9hc3NvY2lhdGlvbnMvaGVscGVycy5qcyJdLCJuYW1lcyI6WyJjaGVja05hbWluZ0NvbGxpc2lvbiIsImFzc29jaWF0aW9uIiwiT2JqZWN0IiwicHJvdG90eXBlIiwiaGFzT3duUHJvcGVydHkiLCJjYWxsIiwic291cmNlIiwicmF3QXR0cmlidXRlcyIsImFzIiwiRXJyb3IiLCJuYW1lIiwiZXhwb3J0cyIsImFkZEZvcmVpZ25LZXlDb25zdHJhaW50cyIsIm5ld0F0dHJpYnV0ZSIsInRhcmdldCIsIm9wdGlvbnMiLCJrZXkiLCJmb3JlaWduS2V5Q29uc3RyYWludCIsIm9uRGVsZXRlIiwib25VcGRhdGUiLCJwcmltYXJ5S2V5cyIsImtleXMiLCJtYXAiLCJwcmltYXJ5S2V5QXR0cmlidXRlIiwiZmllbGQiLCJsZW5ndGgiLCJpbmNsdWRlcyIsIl9zY2hlbWEiLCJyZWZlcmVuY2VzIiwibW9kZWwiLCJzZXF1ZWxpemUiLCJnZXRRdWVyeUludGVyZmFjZSIsIlF1ZXJ5R2VuZXJhdG9yIiwiYWRkU2NoZW1hIiwidGFibGVOYW1lIiwiX3NjaGVtYURlbGltaXRlciIsIm1peGluTWV0aG9kcyIsIm9iaiIsIm1ldGhvZHMiLCJhbGlhc2VzIiwibWV0aG9kIiwiYWNjZXNzb3JzIiwicmVhbE1ldGhvZCIsIkFycmF5IiwiZnJvbSIsImFyZ3VtZW50cyJdLCJtYXBwaW5ncyI6IkFBQUE7O0FBRUEsU0FBU0Esb0JBQVQsQ0FBOEJDLFdBQTlCLEVBQTJDO0FBQ3pDLE1BQUlDLE1BQU0sQ0FBQ0MsU0FBUCxDQUFpQkMsY0FBakIsQ0FBZ0NDLElBQWhDLENBQXFDSixXQUFXLENBQUNLLE1BQVosQ0FBbUJDLGFBQXhELEVBQXVFTixXQUFXLENBQUNPLEVBQW5GLENBQUosRUFBNEY7QUFDMUYsVUFBTSxJQUFJQyxLQUFKLENBQ0gsdUNBQXNDUixXQUFXLENBQUNPLEVBQUcsR0FBdEQsR0FDQyxxQkFBb0JQLFdBQVcsQ0FBQ08sRUFBRyxjQUFhUCxXQUFXLENB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Q3lCLFlBQVIsR0FBdUJBLFlBQXZCIiwic291cmNlc0NvbnRlbnQiOlsiJ3VzZSBzdHJpY3QnO1xuXG5mdW5jdGlvbiBjaGVja05hbWluZ0NvbGxpc2lvbihhc3NvY2lhdGlvbikge1xuICBpZiAoT2JqZWN0LnByb3RvdHlwZS5oYXNPd25Qcm9wZXJ0eS5jYWxsKGFzc29jaWF0aW9uLnNvdXJjZS5yYXdBdHRyaWJ1dGVzLCBhc3NvY2lhdGlvbi5hcykpIHtcbiAgICB0aHJvdyBuZXcgRXJyb3IoXG4gICAgICBgTmFtaW5nIGNvbGxpc2lvbiBiZXR3ZWVuIGF0dHJpYnV0ZSAnJHthc3NvY2lhdGlvbi5hc30nYCArXG4gICAgICBgIGFuZCBhc3NvY2lhdGlvbiAnJHthc3NvY2lhdGlvbi5hc30nIG9uIG1vZGVsICR7YXNzb2NpYXRpb24uc291cmNlLm5hbWV9YCArXG4gICAgICAnLiBUbyByZW1lZHkgdGhpcywgY2hhbmdlIGVpdGhlciBmb3JlaWduS2V5IG9yIGFzIGluIHlvdXIgYXNzb2NpYXRpb24gZGVmaW5pdGlvbidcbiAgICApO1xuICB9XG59XG5leHBvcnRzLmNoZWNrTmFtaW5nQ29sbGlzaW9uID0gY2hlY2tOYW1pbmdDb2xsaXNpb247XG5cbmZ1bmN0aW9uIGFkZEZvcmVpZ25LZXlDb25zdHJhaW50cyhuZXdBdHRyaWJ1dGUsIHNvdXJjZSwgdGFyZ2V0LCBvcHRpb25zLCBrZXkpIHtcbiAgLy8gRksgY29uc3RyYWludHMgYXJlIG9wdC1pbjogdXNlcnMgbXVzdCBlaXRoZXIgc2V0IGBmb3JlaWduS2V5Q29uc3RyYWludHNgXG4gIC8vIG9uIHRoZSBhc3NvY2lhdGlvbiwgb3IgcmVxdWVzdCBhbiBgb25EZWxldGVgIG9yIGBvblVwZGF0ZWAgYmVoYXZpb3JcblxuICBpZiAob3B0aW9ucy5mb3JlaWduS2V5Q29uc3RyYWludCB8fCBvcHRpb25zLm9uRGVsZXRlIHx8IG9wdGlvbnMub25VcGRhdGUpIHtcbiAgICAvLyBGaW5kIHByaW1hcnkga2V5czogY29tcG9zaXRlIGtleXMgbm90IHN1cHBvcnRlZCB3aXRoIHRoaXMgYXBwcm9hY2hcbiAgICBjb25zdCBwcmltYXJ5S2V5cyA9IE9iamVjdC5rZXlzKHNvdXJjZS5wcmltYXJ5S2V5cylcbiAgICAgIC5tYXAocHJpbWFyeUtleUF0dHJpYnV0ZSA9PiBzb3VyY2UucmF3QXR0cmlidXRlc1twcmltYXJ5S2V5QXR0cmlidXRlXS5maWVsZCB8fCBwcmltYXJ5S2V5QXR0cmlidXRlKTtcblxuICAgIGlmIChwcmltYXJ5S2V5cy5sZW5ndGggPT09IDEgfHwgIXByaW1hcnlLZXlzLmluY2x1ZGVzKGtleSkpIHtcbiAgICAgIGlmIChzb3VyY2UuX3NjaGVtYSkge1xuICAgICAgICBuZXdBdHRyaWJ1dGUucmVmZXJlbmNlcyA9IHtcbiAgICAgICAgICBtb2RlbDogc291cmNlLnNlcXVlbGl6ZS5nZXRRdWVyeUludGVyZmFjZSgpLlF1ZXJ5R2VuZXJhdG9yLmFkZFNjaGVtYSh7XG4gICAgICAgICAgICB0YWJsZU5hbWU6IHNvdXJjZS50YWJsZU5hbWUsXG4gICAgICAgICAgICBfc2NoZW1hOiBzb3VyY2UuX3NjaGVtYSxcbiAgICAgICAgICAgIF9zY2hlbWFEZWxpbWl0ZXI6IHNvdXJjZS5fc2NoZW1hRGVsaW1pdGVyXG4gICAgICAgICAgfSlcbiAgICAgICAgfTtcbiAgICAgIH0gZWxzZSB7XG4gICAgICAgIG5ld0F0dHJpYnV0ZS5yZWZlcmVuY2VzID0geyBtb2RlbDogc291cmNlLnRhYmxlTmFtZSB9O1xuICAgICAgfVxuXG4gICAgICBuZXdBdHRyaWJ1dGUucmVmZXJlbmNlcy5rZXkgPSBrZXkgfHwgcHJpbWFyeUtleXNbMF07XG4gICAgICBuZXdBdHRyaWJ1dGUub25EZWxldGUgPSBvcHRpb25zLm9uRGVsZXRlO1xuICAgICAgbmV3QXR0cmlidXRlLm9uVXBkYXRlID0gb3B0aW9ucy5vblVwZGF0ZTtcbiAgICB9XG4gIH1cbn1cbmV4cG9ydHMuYWRkRm9yZWlnbktleUNvbnN0cmFpbnRzID0gYWRkRm9yZWlnbktleUNvbnN0cmFpbnRzO1xuXG4vKipcbiAqIE1peGluIChpbmplY3QpIGFzc29jaWF0aW9uIG1ldGhvZHMgdG8gbW9kZWwgcHJvdG90eXBlXG4gKlxuICogQHByaXZhdGVcbiAqXG4gKiBAcGFyYW0ge09iamVjdH0gYXNzb2NpYXRpb24gaW5zdGFuY2VcbiAqIEBwYXJhbSB7T2JqZWN0fSBvYmogTW9kZWwgcHJvdG90eXBlXG4gKiBAcGFyYW0ge0FycmF5fSBtZXRob2RzIE1ldGhvZCBuYW1lcyB0byBpbmplY3RcbiAqIEBwYXJhbSB7T2JqZWN0fSBhbGlhc2VzIE1hcHBpbmcgYmV0d2VlbiBtb2RlbCBhbmQgYXNzb2NpYXRpb24gbWV0aG9kIG5hbWVzXG4gKlxuICovXG5mdW5jdGlvbiBtaXhpbk1ldGhvZHMoYXNzb2NpYXRpb24sIG9iaiwgbWV0aG9kcywgYWxpYXNlcykge1xuICBhbGlhc2VzID0gYWxpYXNlcyB8fCB7fTtcblxuICBmb3IgKGNvbnN0IG1ldGhvZCBvZiBtZXRob2RzKSB7XG4gICAgLy8gZG9uJ3Qgb3ZlcnJpZGUgY3VzdG9tIG1ldGhvZHNcbiAgICBpZiAoIU9iamVjdC5wcm90b3R5cGUuaGFzT3duUHJvcGVydHkuY2FsbChvYmosIGFzc29jaWF0aW9uLmFjY2Vzc29yc1ttZXRob2RdKSkge1xuICAgICAgY29uc3QgcmVhbE1ldGhvZCA9IGFsaWFzZXNbbWV0aG9kXSB8fCBtZXRob2Q7XG5cbiAgICAgIG9ialthc3NvY2lhdGlvbi5hY2Nlc3NvcnNbbWV0aG9kXV0gPSBmdW5jdGlvbigpIHtcbiAgICAgICAgcmV0dXJuIGFzc29jaWF0aW9uW3JlYWxNZXRob2RdKHRoaXMsIC4uLkFycmF5LmZyb20oYXJndW1lbnRzKSk7XG4gICAgICB9O1xuICAgIH1cbiAgfVxufVxuZXhwb3J0cy5taXhpbk1ldGhvZHMgPSBtaXhpbk1ldGhvZHM7XG4iXX0= \ No newline at end of file diff --git a/dist/associations/index.js b/dist/associations/index.js index 9f13d36..6eb38a6 100644 --- a/dist/associations/index.js +++ b/dist/associations/index.js @@ -9,4 +9,4 @@ Association.BelongsToMany = require('./belongs-to-many'); module.exports = Association; module.exports.default = Association; module.exports.Association = Association; -//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uL2xpYi9hc3NvY2lhdGlvbnMvaW5kZXguanMiXSwibmFtZXMiOlsiQXNzb2NpYXRpb24iLCJyZXF1aXJlIiwiQmVsb25nc1RvIiwiSGFzT25lIiwiSGFzTWFueSIsIkJlbG9uZ3NUb01hbnkiLCJtb2R1bGUiLCJleHBvcnRzIiwiZGVmYXVsdCJdLCJtYXBwaW5ncyI6IkFBQUE7O0FBRUEsTUFBTUEsV0FBVyxHQUFHQyxPQUFPLENBQUMsUUFBRCxDQUEzQjs7QUFFQUQsV0FBVyxDQUFDRSxTQUFaLEdBQXdCRCxPQUFPLENBQUMsY0FBRCxDQUEvQjtBQUNBRCxXQUFXLENBQUNHLE1BQVosR0FBcUJGLE9BQU8sQ0FBQyxXQUFELENBQTVCO0FBQ0FELFdBQVcsQ0FBQ0ksT0FBWixHQUFzQkgsT0FBTyxDQUFDLFlBQUQsQ0FBN0I7QUFDQUQsV0FBVyxDQUFDSyxhQUFaLEdBQTRCSixPQUFPLENBQUMsbUJBQUQsQ0FBbkM7QUFFQUssTUFBTSxDQUFDQyxPQUFQLEdBQWlCUCxXQUFqQjtBQUNBTSxNQUFNLENBQUNDLE9BQVAsQ0FBZUMsT0FBZixHQUF5QlIsV0FBekI7QUFDQU0sTUFBTSxDQUFDQyxPQUFQLENBQWVQLFdBQWYsR0FBNkJBLFdBQTdCIiwic291cmNlc0NvbnRlbnQiOlsiJ3VzZSBzdHJpY3QnO1xyXG5cclxuY29uc3QgQXNzb2NpYXRpb24gPSByZXF1aXJlKCcuL2Jhc2UnKTtcclxuXHJcbkFzc29jaWF0aW9uLkJlbG9uZ3NUbyA9IHJlcXVpcmUoJy4vYmVsb25ncy10bycpO1xyXG5Bc3NvY2lhdGlvbi5IYXNPbmUgPSByZXF1aXJlKCcuL2hhcy1vbmUnKTtcclxuQXNzb2NpYXRpb24uSGFzTWFueSA9IHJlcXVpcmUoJy4vaGFzLW1hbnknKTtcclxuQXNzb2NpYXRpb24uQmVsb25nc1RvTWFueSA9IHJlcXVpcmUoJy4vYmVsb25ncy10by1tYW55Jyk7XHJcblxyXG5tb2R1bGUuZXhwb3J0cyA9IEFzc29jaWF0aW9uO1xyXG5tb2R1bGUuZXhwb3J0cy5kZWZhdWx0ID0gQXNzb2NpYXRpb247XHJcbm1vZHVsZS5leHBvcnRzLkFzc29jaWF0aW9uID0gQXNzb2NpYXRpb247XHJcbiJdfQ== \ No newline at end of file +//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uL2xpYi9hc3NvY2lhdGlvbnMvaW5kZXguanMiXSwibmFtZXMiOlsiQXNzb2NpYXRpb24iLCJyZXF1aXJlIiwiQmVsb25nc1RvIiwiSGFzT25lIiwiSGFzTWFueSIsIkJlbG9uZ3NUb01hbnkiLCJtb2R1bGUiLCJleHBvcnRzIiwiZGVmYXVsdCJdLCJtYXBwaW5ncyI6IkFBQUE7O0FBRUEsTUFBTUEsV0FBVyxHQUFHQyxPQUFPLENBQUMsUUFBRCxDQUEzQjs7QUFFQUQsV0FBVyxDQUFDRSxTQUFaLEdBQXdCRCxPQUFPLENBQUMsY0FBRCxDQUEvQjtBQUNBRCxXQUFXLENBQUNHLE1BQVosR0FBcUJGLE9BQU8sQ0FBQyxXQUFELENBQTVCO0FBQ0FELFdBQVcsQ0FBQ0ksT0FBWixHQUFzQkgsT0FBTyxDQUFDLFlBQUQsQ0FBN0I7QUFDQUQsV0FBVyxDQUFDSyxhQUFaLEdBQTRCSixPQUFPLENBQUMsbUJBQUQsQ0FBbkM7QUFFQUssTUFBTSxDQUFDQyxPQUFQLEdBQWlCUCxXQUFqQjtBQUNBTSxNQUFNLENBQUNDLE9BQVAsQ0FBZUMsT0FBZixHQUF5QlIsV0FBekI7QUFDQU0sTUFBTSxDQUFDQyxPQUFQLENBQWVQLFdBQWYsR0FBNkJBLFdBQTdCIiwic291cmNlc0NvbnRlbnQiOlsiJ3VzZSBzdHJpY3QnO1xuXG5jb25zdCBBc3NvY2lhdGlvbiA9IHJlcXVpcmUoJy4vYmFzZScpO1xuXG5Bc3NvY2lhdGlvbi5CZWxvbmdzVG8gPSByZXF1aXJlKCcuL2JlbG9uZ3MtdG8nKTtcbkFzc29jaWF0aW9uLkhhc09uZSA9IHJlcXVpcmUoJy4vaGFzLW9uZScpO1xuQXNzb2NpYXRpb24uSGFzTWFueSA9IHJlcXVpcmUoJy4vaGFzLW1hbnknKTtcbkFzc29jaWF0aW9uLkJlbG9uZ3NUb01hbnkgPSByZXF1aXJlKCcuL2JlbG9uZ3MtdG8tbWFueScpO1xuXG5tb2R1bGUuZXhwb3J0cyA9IEFzc29jaWF0aW9uO1xubW9kdWxlLmV4cG9ydHMuZGVmYXVsdCA9IEFzc29jaWF0aW9uO1xubW9kdWxlLmV4cG9ydHMuQXNzb2NpYXRpb24gPSBBc3NvY2lhdGlvbjtcbiJdfQ== \ No newline at end of file diff --git a/dist/associations/mixin.js b/dist/associations/mixin.js index e382252..e3e42a9 100644 --- a/dist/associations/mixin.js +++ b/dist/associations/mixin.js @@ -152,4 +152,4 @@ Mixin.belongsTo = singleLinked(BelongsTo); module.exports = Mixin; module.exports.Mixin = Mixin; module.exports.default = Mixin; -//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../lib/associations/mixin.js"],"names":["_","require","HasOne","HasMany","BelongsToMany","BelongsTo","isModel","model","sequelize","prototype","Sequelize","Model","Mixin","hasMany","target","options","Error","name","source","hooks","undefined","Boolean","useHooks","Object","assign","omit","runHooks","type","association","associations","associationAccessor","_injectAttributes","mixin","belongsToMany","timestamps","getAssociations","values","filter","getAssociationForAlias","alias","find","verifyAssociationAlias","singleLinked","Type","lowerFirst","hasOne","belongsTo","module","exports","default"],"mappings":"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","sourcesContent":["'use strict';\r\n\r\nconst _ = require('lodash');\r\nconst HasOne = require('./has-one');\r\nconst HasMany = require('./has-many');\r\nconst BelongsToMany = require('./belongs-to-many');\r\nconst BelongsTo = require('./belongs-to');\r\n\r\nfunction isModel(model, sequelize) {\r\n  return model\r\n    && model.prototype\r\n    && model.prototype instanceof sequelize.Sequelize.Model;\r\n}\r\n\r\nconst Mixin = {\r\n  hasMany(target, options = {}) {\r\n    if (!isModel(target, this.sequelize)) {\r\n      throw new Error(`${this.name}.hasMany called with something that's not a subclass of Sequelize.Model`);\r\n    }\r\n\r\n    const source = this;\r\n\r\n    // Since this is a mixin, we'll need a unique letiable name for hooks (since Model will override our hooks option)\r\n    options.hooks = options.hooks === undefined ? false : Boolean(options.hooks);\r\n    options.useHooks = options.hooks;\r\n\r\n    options = Object.assign(options, _.omit(source.options, ['hooks']));\r\n\r\n    if (options.useHooks) {\r\n      this.runHooks('beforeAssociate', { source, target, type: HasMany }, options);\r\n    }\r\n\r\n    // the id is in the foreign table or in a connecting table\r\n    const association = new HasMany(source, target, options);\r\n    source.associations[association.associationAccessor] = association;\r\n\r\n    association._injectAttributes();\r\n    association.mixin(source.prototype);\r\n\r\n    if (options.useHooks) {\r\n      this.runHooks('afterAssociate', { source, target, type: HasMany, association }, options);\r\n    }\r\n\r\n    return association;\r\n  },\r\n\r\n  belongsToMany(target, options = {}) {\r\n    if (!isModel(target, this.sequelize)) {\r\n      throw new Error(`${this.name}.belongsToMany called with something that's not a subclass of Sequelize.Model`);\r\n    }\r\n\r\n    const source = this;\r\n\r\n    // Since this is a mixin, we'll need a unique letiable name for hooks (since Model will override our hooks option)\r\n    options.hooks = options.hooks === undefined ? false : Boolean(options.hooks);\r\n    options.useHooks = options.hooks;\r\n    options.timestamps = options.timestamps === undefined ? this.sequelize.options.timestamps : options.timestamps;\r\n    options = Object.assign(options, _.omit(source.options, ['hooks', 'timestamps', 'scopes', 'defaultScope']));\r\n\r\n    if (options.useHooks) {\r\n      this.runHooks('beforeAssociate', { source, target, type: BelongsToMany }, options);\r\n    }\r\n    // the id is in the foreign table or in a connecting table\r\n    const association = new BelongsToMany(source, target, options);\r\n    source.associations[association.associationAccessor] = association;\r\n\r\n    association._injectAttributes();\r\n    association.mixin(source.prototype);\r\n\r\n    if (options.useHooks) {\r\n      this.runHooks('afterAssociate', { source, target, type: BelongsToMany, association }, options);\r\n    }\r\n\r\n    return association;\r\n  },\r\n\r\n  getAssociations(target) {\r\n    return _.values(this.associations).filter(association => association.target.name === target.name);\r\n  },\r\n\r\n  getAssociationForAlias(target, alias) {\r\n    // Two associations cannot have the same alias, so we can use find instead of filter\r\n    return this.getAssociations(target).find(association => association.verifyAssociationAlias(alias)) || null;\r\n  }\r\n};\r\n\r\n// The logic for hasOne and belongsTo is exactly the same\r\nfunction singleLinked(Type) {\r\n  return function(target, options = {}) {\r\n    // eslint-disable-next-line no-invalid-this\r\n    const source = this;\r\n    if (!isModel(target, source.sequelize)) {\r\n      throw new Error(`${source.name}.${_.lowerFirst(Type.name)} called with something that's not a subclass of Sequelize.Model`);\r\n    }\r\n\r\n\r\n    // Since this is a mixin, we'll need a unique letiable name for hooks (since Model will override our hooks option)\r\n    options.hooks = options.hooks === undefined ? false : Boolean(options.hooks);\r\n    options.useHooks = options.hooks;\r\n\r\n    if (options.useHooks) {\r\n      source.runHooks('beforeAssociate', { source, target, type: Type }, options);\r\n    }\r\n    // the id is in the foreign table\r\n    const association = new Type(source, target, Object.assign(options, source.options));\r\n    source.associations[association.associationAccessor] = association;\r\n\r\n    association._injectAttributes();\r\n    association.mixin(source.prototype);\r\n\r\n    if (options.useHooks) {\r\n      source.runHooks('afterAssociate', { source, target, type: Type, association }, options);\r\n    }\r\n\r\n    return association;\r\n  };\r\n}\r\n\r\nMixin.hasOne = singleLinked(HasOne);\r\nMixin.belongsTo = singleLinked(BelongsTo);\r\n\r\nmodule.exports = Mixin;\r\nmodule.exports.Mixin = Mixin;\r\nmodule.exports.default = Mixin;\r\n"]} \ No newline at end of file +//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../lib/associations/mixin.js"],"names":["_","require","HasOne","HasMany","BelongsToMany","BelongsTo","isModel","model","sequelize","prototype","Sequelize","Model","Mixin","hasMany","target","options","Error","name","source","hooks","undefined","Boolean","useHooks","Object","assign","omit","runHooks","type","association","associations","associationAccessor","_injectAttributes","mixin","belongsToMany","timestamps","getAssociations","values","filter","getAssociationForAlias","alias","find","verifyAssociationAlias","singleLinked","Type","lowerFirst","hasOne","belongsTo","module","exports","default"],"mappings":"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","sourcesContent":["'use strict';\n\nconst _ = require('lodash');\nconst HasOne = require('./has-one');\nconst HasMany = require('./has-many');\nconst BelongsToMany = require('./belongs-to-many');\nconst BelongsTo = require('./belongs-to');\n\nfunction isModel(model, sequelize) {\n  return model\n    && model.prototype\n    && model.prototype instanceof sequelize.Sequelize.Model;\n}\n\nconst Mixin = {\n  hasMany(target, options = {}) {\n    if (!isModel(target, this.sequelize)) {\n      throw new Error(`${this.name}.hasMany called with something that's not a subclass of Sequelize.Model`);\n    }\n\n    const source = this;\n\n    // Since this is a mixin, we'll need a unique letiable name for hooks (since Model will override our hooks option)\n    options.hooks = options.hooks === undefined ? false : Boolean(options.hooks);\n    options.useHooks = options.hooks;\n\n    options = Object.assign(options, _.omit(source.options, ['hooks']));\n\n    if (options.useHooks) {\n      this.runHooks('beforeAssociate', { source, target, type: HasMany }, options);\n    }\n\n    // the id is in the foreign table or in a connecting table\n    const association = new HasMany(source, target, options);\n    source.associations[association.associationAccessor] = association;\n\n    association._injectAttributes();\n    association.mixin(source.prototype);\n\n    if (options.useHooks) {\n      this.runHooks('afterAssociate', { source, target, type: HasMany, association }, options);\n    }\n\n    return association;\n  },\n\n  belongsToMany(target, options = {}) {\n    if (!isModel(target, this.sequelize)) {\n      throw new Error(`${this.name}.belongsToMany called with something that's not a subclass of Sequelize.Model`);\n    }\n\n    const source = this;\n\n    // Since this is a mixin, we'll need a unique letiable name for hooks (since Model will override our hooks option)\n    options.hooks = options.hooks === undefined ? false : Boolean(options.hooks);\n    options.useHooks = options.hooks;\n    options.timestamps = options.timestamps === undefined ? this.sequelize.options.timestamps : options.timestamps;\n    options = Object.assign(options, _.omit(source.options, ['hooks', 'timestamps', 'scopes', 'defaultScope']));\n\n    if (options.useHooks) {\n      this.runHooks('beforeAssociate', { source, target, type: BelongsToMany }, options);\n    }\n    // the id is in the foreign table or in a connecting table\n    const association = new BelongsToMany(source, target, options);\n    source.associations[association.associationAccessor] = association;\n\n    association._injectAttributes();\n    association.mixin(source.prototype);\n\n    if (options.useHooks) {\n      this.runHooks('afterAssociate', { source, target, type: BelongsToMany, association }, options);\n    }\n\n    return association;\n  },\n\n  getAssociations(target) {\n    return _.values(this.associations).filter(association => association.target.name === target.name);\n  },\n\n  getAssociationForAlias(target, alias) {\n    // Two associations cannot have the same alias, so we can use find instead of filter\n    return this.getAssociations(target).find(association => association.verifyAssociationAlias(alias)) || null;\n  }\n};\n\n// The logic for hasOne and belongsTo is exactly the same\nfunction singleLinked(Type) {\n  return function(target, options = {}) {\n    // eslint-disable-next-line no-invalid-this\n    const source = this;\n    if (!isModel(target, source.sequelize)) {\n      throw new Error(`${source.name}.${_.lowerFirst(Type.name)} called with something that's not a subclass of Sequelize.Model`);\n    }\n\n\n    // Since this is a mixin, we'll need a unique letiable name for hooks (since Model will override our hooks option)\n    options.hooks = options.hooks === undefined ? false : Boolean(options.hooks);\n    options.useHooks = options.hooks;\n\n    if (options.useHooks) {\n      source.runHooks('beforeAssociate', { source, target, type: Type }, options);\n    }\n    // the id is in the foreign table\n    const association = new Type(source, target, Object.assign(options, source.options));\n    source.associations[association.associationAccessor] = association;\n\n    association._injectAttributes();\n    association.mixin(source.prototype);\n\n    if (options.useHooks) {\n      source.runHooks('afterAssociate', { source, target, type: Type, association }, options);\n    }\n\n    return association;\n  };\n}\n\nMixin.hasOne = singleLinked(HasOne);\nMixin.belongsTo = singleLinked(BelongsTo);\n\nmodule.exports = Mixin;\nmodule.exports.Mixin = Mixin;\nmodule.exports.default = Mixin;\n"]} \ No newline at end of file diff --git a/dist/data-types.js b/dist/data-types.js index a5b6207..cb8ce17 100644 --- a/dist/data-types.js +++ b/dist/data-types.js @@ -1,14 +1,18 @@ 'use strict'; +function _inherits(subClass, superClass) { if (typeof superClass !== "function" && superClass !== null) { throw new TypeError("Super expression must either be null or a function"); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, writable: true, configurable: true } }); if (superClass) _setPrototypeOf(subClass, superClass); } + +function _setPrototypeOf(o, p) { _setPrototypeOf = Object.setPrototypeOf || function _setPrototypeOf(o, p) { o.__proto__ = p; return o; }; return _setPrototypeOf(o, p); } + +function _createSuper(Derived) { var hasNativeReflectConstruct = _isNativeReflectConstruct(); return function _createSuperInternal() { var Super = _getPrototypeOf(Derived), result; if (hasNativeReflectConstruct) { var NewTarget = _getPrototypeOf(this).constructor; result = Reflect.construct(Super, arguments, NewTarget); } else { result = Super.apply(this, arguments); } return _possibleConstructorReturn(this, result); }; } + function _possibleConstructorReturn(self, call) { if (call && (typeof call === "object" || typeof call === "function")) { return call; } return _assertThisInitialized(self); } function _assertThisInitialized(self) { if (self === void 0) { throw new ReferenceError("this hasn't been initialised - super() hasn't been called"); } return self; } -function _getPrototypeOf(o) { _getPrototypeOf = Object.setPrototypeOf ? Object.getPrototypeOf : function _getPrototypeOf(o) { return o.__proto__ || Object.getPrototypeOf(o); }; return _getPrototypeOf(o); } - -function _inherits(subClass, superClass) { if (typeof superClass !== "function" && superClass !== null) { throw new TypeError("Super expression must either be null or a function"); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, writable: true, configurable: true } }); if (superClass) _setPrototypeOf(subClass, superClass); } +function _isNativeReflectConstruct() { if (typeof Reflect === "undefined" || !Reflect.construct) return false; if (Reflect.construct.sham) return false; if (typeof Proxy === "function") return true; try { Date.prototype.toString.call(Reflect.construct(Date, [], function () {})); return true; } catch (e) { return false; } } -function _setPrototypeOf(o, p) { _setPrototypeOf = Object.setPrototypeOf || function _setPrototypeOf(o, p) { o.__proto__ = p; return o; }; return _setPrototypeOf(o, p); } +function _getPrototypeOf(o) { _getPrototypeOf = Object.setPrototypeOf ? Object.getPrototypeOf : function _getPrototypeOf(o) { return o.__proto__ || Object.getPrototypeOf(o); }; return _getPrototypeOf(o); } function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } } @@ -20,8 +24,6 @@ const util = require('util'); const _ = require('lodash'); -const wkx = require('wkx'); - const sequelizeErrors = require('./errors'); const Validator = require('./utils/validator-extras').validator; @@ -40,9 +42,7 @@ const { classToInvokable } = require('./utils/classToInvokable'); -let ABSTRACT = -/*#__PURE__*/ -function () { +let ABSTRACT = /*#__PURE__*/function () { function ABSTRACT() { _classCallCheck(this, ABSTRACT); } @@ -103,11 +103,11 @@ ABSTRACT.prototype.dialectTypes = ''; * STRING A variable length string */ -let STRING = -/*#__PURE__*/ -function (_ABSTRACT) { +let STRING = /*#__PURE__*/function (_ABSTRACT) { _inherits(STRING, _ABSTRACT); + var _super = _createSuper(STRING); + /** * @param {number} [length=255] length of string * @param {boolean} [binary=false] Is this binary? @@ -117,7 +117,7 @@ function (_ABSTRACT) { _classCallCheck(this, STRING); - _this = _possibleConstructorReturn(this, _getPrototypeOf(STRING).call(this)); + _this = _super.call(this); const options = typeof length === 'object' && length || { length, binary @@ -167,11 +167,11 @@ function (_ABSTRACT) { */ -let CHAR = -/*#__PURE__*/ -function (_STRING) { +let CHAR = /*#__PURE__*/function (_STRING) { _inherits(CHAR, _STRING); + var _super2 = _createSuper(CHAR); + /** * @param {number} [length=255] length of string * @param {boolean} [binary=false] Is this binary? @@ -179,10 +179,10 @@ function (_STRING) { function CHAR(length, binary) { _classCallCheck(this, CHAR); - return _possibleConstructorReturn(this, _getPrototypeOf(CHAR).call(this, typeof length === 'object' && length || { + return _super2.call(this, typeof length === 'object' && length || { length, binary - })); + }); } _createClass(CHAR, [{ @@ -199,11 +199,11 @@ function (_STRING) { */ -let TEXT = -/*#__PURE__*/ -function (_ABSTRACT2) { +let TEXT = /*#__PURE__*/function (_ABSTRACT2) { _inherits(TEXT, _ABSTRACT2); + var _super3 = _createSuper(TEXT); + /** * @param {string} [length=''] could be tiny, medium, long. */ @@ -212,7 +212,7 @@ function (_ABSTRACT2) { _classCallCheck(this, TEXT); - _this2 = _possibleConstructorReturn(this, _getPrototypeOf(TEXT).call(this)); + _this2 = _super3.call(this); const options = typeof length === 'object' && length || { length }; @@ -259,15 +259,15 @@ function (_ABSTRACT2) { */ -let CITEXT = -/*#__PURE__*/ -function (_ABSTRACT3) { +let CITEXT = /*#__PURE__*/function (_ABSTRACT3) { _inherits(CITEXT, _ABSTRACT3); + var _super4 = _createSuper(CITEXT); + function CITEXT() { _classCallCheck(this, CITEXT); - return _possibleConstructorReturn(this, _getPrototypeOf(CITEXT).apply(this, arguments)); + return _super4.apply(this, arguments); } _createClass(CITEXT, [{ @@ -293,11 +293,11 @@ function (_ABSTRACT3) { */ -let NUMBER = -/*#__PURE__*/ -function (_ABSTRACT4) { +let NUMBER = /*#__PURE__*/function (_ABSTRACT4) { _inherits(NUMBER, _ABSTRACT4); + var _super5 = _createSuper(NUMBER); + /** * @param {Object} options type options * @param {string|number} [options.length] length of type, like `INT(4)` @@ -312,7 +312,7 @@ function (_ABSTRACT4) { _classCallCheck(this, NUMBER); - _this3 = _possibleConstructorReturn(this, _getPrototypeOf(NUMBER).call(this)); + _this3 = _super5.call(this); if (typeof options === 'number') { options = { @@ -410,15 +410,15 @@ function (_ABSTRACT4) { */ -let INTEGER = -/*#__PURE__*/ -function (_NUMBER) { +let INTEGER = /*#__PURE__*/function (_NUMBER) { _inherits(INTEGER, _NUMBER); + var _super6 = _createSuper(INTEGER); + function INTEGER() { _classCallCheck(this, INTEGER); - return _possibleConstructorReturn(this, _getPrototypeOf(INTEGER).apply(this, arguments)); + return _super6.apply(this, arguments); } _createClass(INTEGER, [{ @@ -439,15 +439,15 @@ function (_NUMBER) { */ -let TINYINT = -/*#__PURE__*/ -function (_INTEGER) { +let TINYINT = /*#__PURE__*/function (_INTEGER) { _inherits(TINYINT, _INTEGER); + var _super7 = _createSuper(TINYINT); + function TINYINT() { _classCallCheck(this, TINYINT); - return _possibleConstructorReturn(this, _getPrototypeOf(TINYINT).apply(this, arguments)); + return _super7.apply(this, arguments); } return TINYINT; @@ -457,15 +457,15 @@ function (_INTEGER) { */ -let SMALLINT = -/*#__PURE__*/ -function (_INTEGER2) { +let SMALLINT = /*#__PURE__*/function (_INTEGER2) { _inherits(SMALLINT, _INTEGER2); + var _super8 = _createSuper(SMALLINT); + function SMALLINT() { _classCallCheck(this, SMALLINT); - return _possibleConstructorReturn(this, _getPrototypeOf(SMALLINT).apply(this, arguments)); + return _super8.apply(this, arguments); } return SMALLINT; @@ -475,15 +475,15 @@ function (_INTEGER2) { */ -let MEDIUMINT = -/*#__PURE__*/ -function (_INTEGER3) { +let MEDIUMINT = /*#__PURE__*/function (_INTEGER3) { _inherits(MEDIUMINT, _INTEGER3); + var _super9 = _createSuper(MEDIUMINT); + function MEDIUMINT() { _classCallCheck(this, MEDIUMINT); - return _possibleConstructorReturn(this, _getPrototypeOf(MEDIUMINT).apply(this, arguments)); + return _super9.apply(this, arguments); } return MEDIUMINT; @@ -493,15 +493,15 @@ function (_INTEGER3) { */ -let BIGINT = -/*#__PURE__*/ -function (_INTEGER4) { +let BIGINT = /*#__PURE__*/function (_INTEGER4) { _inherits(BIGINT, _INTEGER4); + var _super10 = _createSuper(BIGINT); + function BIGINT() { _classCallCheck(this, BIGINT); - return _possibleConstructorReturn(this, _getPrototypeOf(BIGINT).apply(this, arguments)); + return _super10.apply(this, arguments); } return BIGINT; @@ -511,11 +511,11 @@ function (_INTEGER4) { */ -let FLOAT = -/*#__PURE__*/ -function (_NUMBER2) { +let FLOAT = /*#__PURE__*/function (_NUMBER2) { _inherits(FLOAT, _NUMBER2); + var _super11 = _createSuper(FLOAT); + /** * @param {string|number} [length] length of type, like `FLOAT(4)` * @param {string|number} [decimals] number of decimal points, used with length `FLOAT(5, 4)` @@ -523,10 +523,10 @@ function (_NUMBER2) { function FLOAT(length, decimals) { _classCallCheck(this, FLOAT); - return _possibleConstructorReturn(this, _getPrototypeOf(FLOAT).call(this, typeof length === 'object' && length || { + return _super11.call(this, typeof length === 'object' && length || { length, decimals - })); + }); } _createClass(FLOAT, [{ @@ -547,11 +547,11 @@ function (_NUMBER2) { */ -let REAL = -/*#__PURE__*/ -function (_NUMBER3) { +let REAL = /*#__PURE__*/function (_NUMBER3) { _inherits(REAL, _NUMBER3); + var _super12 = _createSuper(REAL); + /** * @param {string|number} [length] length of type, like `REAL(4)` * @param {string|number} [decimals] number of decimal points, used with length `REAL(5, 4)` @@ -559,10 +559,10 @@ function (_NUMBER3) { function REAL(length, decimals) { _classCallCheck(this, REAL); - return _possibleConstructorReturn(this, _getPrototypeOf(REAL).call(this, typeof length === 'object' && length || { + return _super12.call(this, typeof length === 'object' && length || { length, decimals - })); + }); } return REAL; @@ -572,11 +572,11 @@ function (_NUMBER3) { */ -let DOUBLE = -/*#__PURE__*/ -function (_NUMBER4) { +let DOUBLE = /*#__PURE__*/function (_NUMBER4) { _inherits(DOUBLE, _NUMBER4); + var _super13 = _createSuper(DOUBLE); + /** * @param {string|number} [length] length of type, like `DOUBLE PRECISION(25)` * @param {string|number} [decimals] number of decimal points, used with length `DOUBLE PRECISION(25, 10)` @@ -584,10 +584,10 @@ function (_NUMBER4) { function DOUBLE(length, decimals) { _classCallCheck(this, DOUBLE); - return _possibleConstructorReturn(this, _getPrototypeOf(DOUBLE).call(this, typeof length === 'object' && length || { + return _super13.call(this, typeof length === 'object' && length || { length, decimals - })); + }); } return DOUBLE; @@ -597,11 +597,11 @@ function (_NUMBER4) { */ -let DECIMAL = -/*#__PURE__*/ -function (_NUMBER5) { +let DECIMAL = /*#__PURE__*/function (_NUMBER5) { _inherits(DECIMAL, _NUMBER5); + var _super14 = _createSuper(DECIMAL); + /** * @param {string|number} [precision] defines precision * @param {string|number} [scale] defines scale @@ -609,10 +609,10 @@ function (_NUMBER5) { function DECIMAL(precision, scale) { _classCallCheck(this, DECIMAL); - return _possibleConstructorReturn(this, _getPrototypeOf(DECIMAL).call(this, typeof precision === 'object' && precision || { + return _super14.call(this, typeof precision === 'object' && precision || { precision, scale - })); + }); } _createClass(DECIMAL, [{ @@ -673,15 +673,15 @@ for (const floating of [FLOAT, DOUBLE, REAL]) { */ -let BOOLEAN = -/*#__PURE__*/ -function (_ABSTRACT5) { +let BOOLEAN = /*#__PURE__*/function (_ABSTRACT5) { _inherits(BOOLEAN, _ABSTRACT5); + var _super15 = _createSuper(BOOLEAN); + function BOOLEAN() { _classCallCheck(this, BOOLEAN); - return _possibleConstructorReturn(this, _getPrototypeOf(BOOLEAN).apply(this, arguments)); + return _super15.apply(this, arguments); } _createClass(BOOLEAN, [{ @@ -733,15 +733,15 @@ BOOLEAN.parse = BOOLEAN.prototype._sanitize; * */ -let TIME = -/*#__PURE__*/ -function (_ABSTRACT6) { +let TIME = /*#__PURE__*/function (_ABSTRACT6) { _inherits(TIME, _ABSTRACT6); + var _super16 = _createSuper(TIME); + function TIME() { _classCallCheck(this, TIME); - return _possibleConstructorReturn(this, _getPrototypeOf(TIME).apply(this, arguments)); + return _super16.apply(this, arguments); } _createClass(TIME, [{ @@ -758,11 +758,11 @@ function (_ABSTRACT6) { */ -let DATE = -/*#__PURE__*/ -function (_ABSTRACT7) { +let DATE = /*#__PURE__*/function (_ABSTRACT7) { _inherits(DATE, _ABSTRACT7); + var _super17 = _createSuper(DATE); + /** * @param {string|number} [length] precision to allow storing milliseconds */ @@ -771,7 +771,7 @@ function (_ABSTRACT7) { _classCallCheck(this, DATE); - _this4 = _possibleConstructorReturn(this, _getPrototypeOf(DATE).call(this)); + _this4 = _super17.call(this); const options = typeof length === 'object' && length || { length }; @@ -846,15 +846,15 @@ function (_ABSTRACT7) { */ -let DATEONLY = -/*#__PURE__*/ -function (_ABSTRACT8) { +let DATEONLY = /*#__PURE__*/function (_ABSTRACT8) { _inherits(DATEONLY, _ABSTRACT8); + var _super18 = _createSuper(DATEONLY); + function DATEONLY() { _classCallCheck(this, DATEONLY); - return _possibleConstructorReturn(this, _getPrototypeOf(DATEONLY).apply(this, arguments)); + return _super18.apply(this, arguments); } _createClass(DATEONLY, [{ @@ -899,15 +899,15 @@ function (_ABSTRACT8) { */ -let HSTORE = -/*#__PURE__*/ -function (_ABSTRACT9) { +let HSTORE = /*#__PURE__*/function (_ABSTRACT9) { _inherits(HSTORE, _ABSTRACT9); + var _super19 = _createSuper(HSTORE); + function HSTORE() { _classCallCheck(this, HSTORE); - return _possibleConstructorReturn(this, _getPrototypeOf(HSTORE).apply(this, arguments)); + return _super19.apply(this, arguments); } _createClass(HSTORE, [{ @@ -928,15 +928,15 @@ function (_ABSTRACT9) { */ -let JSONTYPE = -/*#__PURE__*/ -function (_ABSTRACT10) { +let JSONTYPE = /*#__PURE__*/function (_ABSTRACT10) { _inherits(JSONTYPE, _ABSTRACT10); + var _super20 = _createSuper(JSONTYPE); + function JSONTYPE() { _classCallCheck(this, JSONTYPE); - return _possibleConstructorReturn(this, _getPrototypeOf(JSONTYPE).apply(this, arguments)); + return _super20.apply(this, arguments); } _createClass(JSONTYPE, [{ @@ -958,15 +958,15 @@ function (_ABSTRACT10) { */ -let JSONB = -/*#__PURE__*/ -function (_JSONTYPE) { +let JSONB = /*#__PURE__*/function (_JSONTYPE) { _inherits(JSONB, _JSONTYPE); + var _super21 = _createSuper(JSONB); + function JSONB() { _classCallCheck(this, JSONB); - return _possibleConstructorReturn(this, _getPrototypeOf(JSONB).apply(this, arguments)); + return _super21.apply(this, arguments); } return JSONB; @@ -976,15 +976,15 @@ function (_JSONTYPE) { */ -let NOW = -/*#__PURE__*/ -function (_ABSTRACT11) { +let NOW = /*#__PURE__*/function (_ABSTRACT11) { _inherits(NOW, _ABSTRACT11); + var _super22 = _createSuper(NOW); + function NOW() { _classCallCheck(this, NOW); - return _possibleConstructorReturn(this, _getPrototypeOf(NOW).apply(this, arguments)); + return _super22.apply(this, arguments); } return NOW; @@ -994,11 +994,11 @@ function (_ABSTRACT11) { */ -let BLOB = -/*#__PURE__*/ -function (_ABSTRACT12) { +let BLOB = /*#__PURE__*/function (_ABSTRACT12) { _inherits(BLOB, _ABSTRACT12); + var _super23 = _createSuper(BLOB); + /** * @param {string} [length=''] could be tiny, medium, long. */ @@ -1007,7 +1007,7 @@ function (_ABSTRACT12) { _classCallCheck(this, BLOB); - _this5 = _possibleConstructorReturn(this, _getPrototypeOf(BLOB).call(this)); + _this5 = _super23.call(this); const options = typeof length === 'object' && length || { length }; @@ -1085,11 +1085,11 @@ BLOB.prototype.escape = false; * Only available in Postgres. See [the Postgres documentation](http://www.postgresql.org/docs/9.4/static/rangetypes.html) for more details */ -let RANGE = -/*#__PURE__*/ -function (_ABSTRACT13) { +let RANGE = /*#__PURE__*/function (_ABSTRACT13) { _inherits(RANGE, _ABSTRACT13); + var _super24 = _createSuper(RANGE); + /** * @param {ABSTRACT} subtype A subtype for range, like RANGE(DATE) */ @@ -1098,7 +1098,7 @@ function (_ABSTRACT13) { _classCallCheck(this, RANGE); - _this6 = _possibleConstructorReturn(this, _getPrototypeOf(RANGE).call(this)); + _this6 = _super24.call(this); const options = _.isPlainObject(subtype) ? subtype : { subtype }; @@ -1136,15 +1136,15 @@ function (_ABSTRACT13) { */ -let UUID = -/*#__PURE__*/ -function (_ABSTRACT14) { +let UUID = /*#__PURE__*/function (_ABSTRACT14) { _inherits(UUID, _ABSTRACT14); + var _super25 = _createSuper(UUID); + function UUID() { _classCallCheck(this, UUID); - return _possibleConstructorReturn(this, _getPrototypeOf(UUID).apply(this, arguments)); + return _super25.apply(this, arguments); } _createClass(UUID, [{ @@ -1165,15 +1165,15 @@ function (_ABSTRACT14) { */ -let UUIDV1 = -/*#__PURE__*/ -function (_ABSTRACT15) { +let UUIDV1 = /*#__PURE__*/function (_ABSTRACT15) { _inherits(UUIDV1, _ABSTRACT15); + var _super26 = _createSuper(UUIDV1); + function UUIDV1() { _classCallCheck(this, UUIDV1); - return _possibleConstructorReturn(this, _getPrototypeOf(UUIDV1).apply(this, arguments)); + return _super26.apply(this, arguments); } _createClass(UUIDV1, [{ @@ -1194,15 +1194,15 @@ function (_ABSTRACT15) { */ -let UUIDV4 = -/*#__PURE__*/ -function (_ABSTRACT16) { +let UUIDV4 = /*#__PURE__*/function (_ABSTRACT16) { _inherits(UUIDV4, _ABSTRACT16); + var _super27 = _createSuper(UUIDV4); + function UUIDV4() { _classCallCheck(this, UUIDV4); - return _possibleConstructorReturn(this, _getPrototypeOf(UUIDV4).apply(this, arguments)); + return _super27.apply(this, arguments); } _createClass(UUIDV4, [{ @@ -1260,11 +1260,11 @@ function (_ABSTRACT16) { */ -let VIRTUAL = -/*#__PURE__*/ -function (_ABSTRACT17) { +let VIRTUAL = /*#__PURE__*/function (_ABSTRACT17) { _inherits(VIRTUAL, _ABSTRACT17); + var _super28 = _createSuper(VIRTUAL); + /** * @param {ABSTRACT} [ReturnType] return type for virtual type * @param {Array} [fields] array of fields this virtual type is dependent on @@ -1274,7 +1274,7 @@ function (_ABSTRACT17) { _classCallCheck(this, VIRTUAL); - _this7 = _possibleConstructorReturn(this, _getPrototypeOf(VIRTUAL).call(this)); + _this7 = _super28.call(this); if (typeof ReturnType === 'function') ReturnType = new ReturnType(); _this7.returnType = ReturnType; _this7.fields = fields; @@ -1295,11 +1295,11 @@ function (_ABSTRACT17) { */ -let ENUM = -/*#__PURE__*/ -function (_ABSTRACT18) { +let ENUM = /*#__PURE__*/function (_ABSTRACT18) { _inherits(ENUM, _ABSTRACT18); + var _super29 = _createSuper(ENUM); + /** * @param {...any|{ values: any[] }|any[]} args either array of values or options object with values array. It also supports variadic values */ @@ -1308,7 +1308,7 @@ function (_ABSTRACT18) { _classCallCheck(this, ENUM); - _this8 = _possibleConstructorReturn(this, _getPrototypeOf(ENUM).call(this)); + _this8 = _super29.call(this); const value = args[0]; const options = typeof value === 'object' && !Array.isArray(value) && value || { values: args.reduce((result, element) => { @@ -1341,11 +1341,11 @@ function (_ABSTRACT18) { */ -let ARRAY = -/*#__PURE__*/ -function (_ABSTRACT19) { +let ARRAY = /*#__PURE__*/function (_ABSTRACT19) { _inherits(ARRAY, _ABSTRACT19); + var _super30 = _createSuper(ARRAY); + /** * @param {ABSTRACT} type type of array values */ @@ -1354,7 +1354,7 @@ function (_ABSTRACT19) { _classCallCheck(this, ARRAY); - _this9 = _possibleConstructorReturn(this, _getPrototypeOf(ARRAY).call(this)); + _this9 = _super30.call(this); const options = _.isPlainObject(type) ? type : { type }; @@ -1386,173 +1386,22 @@ function (_ABSTRACT19) { return ARRAY; }(ABSTRACT); -/** - * A column storing Geometry information. - * It is only available in PostgreSQL (with PostGIS), MariaDB or MySQL. - * - * GeoJSON is accepted as input and returned as output. - * - * In PostGIS, the GeoJSON is parsed using the PostGIS function `ST_GeomFromGeoJSON`. - * In MySQL it is parsed using the function `GeomFromText`. - * - * Therefore, one can just follow the [GeoJSON spec](http://geojson.org/geojson-spec.html) for handling geometry objects. See the following examples: - * - * @example Defining a Geometry type attribute - * DataTypes.GEOMETRY - * DataTypes.GEOMETRY('POINT') - * DataTypes.GEOMETRY('POINT', 4326) - * - * @example Create a new point - * const point = { type: 'Point', coordinates: [39.807222,-76.984722]}; - * - * User.create({username: 'username', geometry: point }); - * - * @example Create a new linestring - * const line = { type: 'LineString', 'coordinates': [ [100.0, 0.0], [101.0, 1.0] ] }; - * - * User.create({username: 'username', geometry: line }); - * - * @example Create a new polygon - * const polygon = { type: 'Polygon', coordinates: [ - * [ [100.0, 0.0], [101.0, 0.0], [101.0, 1.0], - * [100.0, 1.0], [100.0, 0.0] ] - * ]}; - * - * User.create({username: 'username', geometry: polygon }); - * - * @example Create a new point with a custom SRID - * const point = { - * type: 'Point', - * coordinates: [39.807222,-76.984722], - * crs: { type: 'name', properties: { name: 'EPSG:4326'} } - * }; - * - * User.create({username: 'username', geometry: point }) - * - * - * @see {@link DataTypes.GEOGRAPHY} - */ - - -let GEOMETRY = -/*#__PURE__*/ -function (_ABSTRACT20) { - _inherits(GEOMETRY, _ABSTRACT20); - - /** - * @param {string} [type] Type of geometry data - * @param {string} [srid] SRID of type - */ - function GEOMETRY(type, srid) { - var _this10; - - _classCallCheck(this, GEOMETRY); - - _this10 = _possibleConstructorReturn(this, _getPrototypeOf(GEOMETRY).call(this)); - const options = _.isPlainObject(type) ? type : { - type, - srid - }; - _this10.options = options; - _this10.type = options.type; - _this10.srid = options.srid; - return _this10; - } - - _createClass(GEOMETRY, [{ - key: "_stringify", - value: function _stringify(value, options) { - return `GeomFromText(${options.escape(wkx.Geometry.parseGeoJSON(value).toWkt())})`; - } - }, { - key: "_bindParam", - value: function _bindParam(value, options) { - return `GeomFromText(${options.bindParam(wkx.Geometry.parseGeoJSON(value).toWkt())})`; - } - }]); - - return GEOMETRY; -}(ABSTRACT); - -GEOMETRY.prototype.escape = false; -/** - * A geography datatype represents two dimensional spacial objects in an elliptic coord system. - * - * __The difference from geometry and geography type:__ - * - * PostGIS 1.5 introduced a new spatial type called geography, which uses geodetic measurement instead of Cartesian measurement. - * Coordinate points in the geography type are always represented in WGS 84 lon lat degrees (SRID 4326), - * but measurement functions and relationships ST_Distance, ST_DWithin, ST_Length, and ST_Area always return answers in meters or assume inputs in meters. - * - * __What is best to use? It depends:__ - * - * When choosing between the geometry and geography type for data storage, you should consider what you’ll be using it for. - * If all you do are simple measurements and relationship checks on your data, and your data covers a fairly large area, then most likely you’ll be better off storing your data using the new geography type. - * Although the new geography data type can cover the globe, the geometry type is far from obsolete. - * The geometry type has a much richer set of functions than geography, relationship checks are generally faster, and it has wider support currently across desktop and web-mapping tools - * - * @example Defining a Geography type attribute - * DataTypes.GEOGRAPHY - * DataTypes.GEOGRAPHY('POINT') - * DataTypes.GEOGRAPHY('POINT', 4326) - */ - -let GEOGRAPHY = -/*#__PURE__*/ -function (_ABSTRACT21) { - _inherits(GEOGRAPHY, _ABSTRACT21); - - /** - * @param {string} [type] Type of geography data - * @param {string} [srid] SRID of type - */ - function GEOGRAPHY(type, srid) { - var _this11; - - _classCallCheck(this, GEOGRAPHY); - - _this11 = _possibleConstructorReturn(this, _getPrototypeOf(GEOGRAPHY).call(this)); - const options = _.isPlainObject(type) ? type : { - type, - srid - }; - _this11.options = options; - _this11.type = options.type; - _this11.srid = options.srid; - return _this11; - } - - _createClass(GEOGRAPHY, [{ - key: "_stringify", - value: function _stringify(value, options) { - return `GeomFromText(${options.escape(wkx.Geometry.parseGeoJSON(value).toWkt())})`; - } - }, { - key: "_bindParam", - value: function _bindParam(value, options) { - return `GeomFromText(${options.bindParam(wkx.Geometry.parseGeoJSON(value).toWkt())})`; - } - }]); - - return GEOGRAPHY; -}(ABSTRACT); - -GEOGRAPHY.prototype.escape = false; /** * The cidr type holds an IPv4 or IPv6 network specification. Takes 7 or 19 bytes. * * Only available for Postgres */ -let CIDR = -/*#__PURE__*/ -function (_ABSTRACT22) { - _inherits(CIDR, _ABSTRACT22); + +let CIDR = /*#__PURE__*/function (_ABSTRACT20) { + _inherits(CIDR, _ABSTRACT20); + + var _super31 = _createSuper(CIDR); function CIDR() { _classCallCheck(this, CIDR); - return _possibleConstructorReturn(this, _getPrototypeOf(CIDR).apply(this, arguments)); + return _super31.apply(this, arguments); } _createClass(CIDR, [{ @@ -1575,15 +1424,15 @@ function (_ABSTRACT22) { */ -let INET = -/*#__PURE__*/ -function (_ABSTRACT23) { - _inherits(INET, _ABSTRACT23); +let INET = /*#__PURE__*/function (_ABSTRACT21) { + _inherits(INET, _ABSTRACT21); + + var _super32 = _createSuper(INET); function INET() { _classCallCheck(this, INET); - return _possibleConstructorReturn(this, _getPrototypeOf(INET).apply(this, arguments)); + return _super32.apply(this, arguments); } _createClass(INET, [{ @@ -1607,15 +1456,15 @@ function (_ABSTRACT23) { */ -let MACADDR = -/*#__PURE__*/ -function (_ABSTRACT24) { - _inherits(MACADDR, _ABSTRACT24); +let MACADDR = /*#__PURE__*/function (_ABSTRACT22) { + _inherits(MACADDR, _ABSTRACT22); + + var _super33 = _createSuper(MACADDR); function MACADDR() { _classCallCheck(this, MACADDR); - return _possibleConstructorReturn(this, _getPrototypeOf(MACADDR).apply(this, arguments)); + return _super33.apply(this, arguments); } _createClass(MACADDR, [{ @@ -1711,8 +1560,6 @@ const DataTypes = module.exports = { REAL, 'DOUBLE PRECISION': DOUBLE, DOUBLE, - GEOMETRY, - GEOGRAPHY, CIDR, INET, MACADDR, @@ -1753,4 +1600,4 @@ for (const dataTypes of [DataTypes, ...dialectList]) { } Object.assign(DataTypes, dialectMap); -//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../lib/data-types.js"],"names":["util","require","_","wkx","sequelizeErrors","Validator","validator","momentTz","moment","logger","warnings","classToInvokable","ABSTRACT","options","toSql","key","value","_stringify","_bindParam","bindParam","stringify","name","link","text","warn","oldType","prototype","dialectTypes","STRING","length","binary","_binary","_length","Object","toString","call","Buffer","isBuffer","ValidationError","format","BINARY","CHAR","TEXT","toLowerCase","CITEXT","NUMBER","_zerofill","zerofill","_decimals","decimals","_precision","precision","_scale","scale","_unsigned","unsigned","result","isFloat","String","number","undefined","UNSIGNED","ZEROFILL","INTEGER","isInt","TINYINT","SMALLINT","MEDIUMINT","BIGINT","FLOAT","REAL","DOUBLE","DECIMAL","filter","identity","join","isDecimal","protoExtensions","escape","_value","isNaN","isFinite","sign","floating","assign","BOOLEAN","isBoolean","type","parse","_sanitize","TIME","DATE","isDate","raw","Date","originalValue","getTime","date","timezone","tz","zone","utcOffset","_applyTimezone","DATEONLY","HSTORE","isPlainObject","JSONTYPE","JSON","JSONB","NOW","BLOB","Array","isArray","from","hex","_hexify","RANGE","subtype","_subtype","UUID","isUUID","acceptStrings","UUIDV1","UUIDV4","VIRTUAL","ReturnType","fields","returnType","ENUM","args","values","reduce","element","concat","includes","ARRAY","obj","GEOMETRY","srid","Geometry","parseGeoJSON","toWkt","GEOGRAPHY","CIDR","isIPRange","INET","isIP","MACADDR","isMACAddress","DataTypes","module","exports","NUMERIC","each","dataType","hasOwnProperty","types","dialectMap","sqlite","dialectList","dataTypes","DataType"],"mappings":"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","sourcesContent":["'use strict';\r\n\r\nconst util = require('util');\r\nconst _ = require('lodash');\r\nconst wkx = require('wkx');\r\nconst sequelizeErrors = require('./errors');\r\nconst Validator = require('./utils/validator-extras').validator;\r\nconst momentTz = require('moment-timezone');\r\nconst moment = require('moment');\r\nconst { logger } = require('./utils/logger');\r\nconst warnings = {};\r\nconst { classToInvokable } = require('./utils/classToInvokable');\r\n\r\nclass ABSTRACT {\r\n  toString(options) {\r\n    return this.toSql(options);\r\n  }\r\n  toSql() {\r\n    return this.key;\r\n  }\r\n  stringify(value, options) {\r\n    if (this._stringify) {\r\n      return this._stringify(value, options);\r\n    }\r\n    return value;\r\n  }\r\n  bindParam(value, options) {\r\n    if (this._bindParam) {\r\n      return this._bindParam(value, options);\r\n    }\r\n    return options.bindParam(this.stringify(value, options));\r\n  }\r\n  static toString() {\r\n    return this.name;\r\n  }\r\n  static warn(link, text) {\r\n    if (!warnings[text]) {\r\n      warnings[text] = true;\r\n      logger.warn(`${text} \\n>> Check: ${link}`);\r\n    }\r\n  }\r\n  static extend(oldType) {\r\n    return new this(oldType.options);\r\n  }\r\n}\r\n\r\nABSTRACT.prototype.dialectTypes = '';\r\n\r\n/**\r\n * STRING A variable length string\r\n */\r\nclass STRING extends ABSTRACT {\r\n  /**\r\n   * @param {number} [length=255] length of string\r\n   * @param {boolean} [binary=false] Is this binary?\r\n   */\r\n  constructor(length, binary) {\r\n    super();\r\n    const options = typeof length === 'object' && length || { length, binary };\r\n    this.options = options;\r\n    this._binary = options.binary;\r\n    this._length = options.length || 255;\r\n  }\r\n  toSql() {\r\n    return `VARCHAR(${this._length})${this._binary ? ' BINARY' : ''}`;\r\n  }\r\n  validate(value) {\r\n    if (Object.prototype.toString.call(value) !== '[object String]') {\r\n      if (this.options.binary && Buffer.isBuffer(value) || typeof value === 'number') {\r\n        return true;\r\n      }\r\n      throw new sequelizeErrors.ValidationError(util.format('%j is not a valid string', value));\r\n    }\r\n    return true;\r\n  }\r\n\r\n  get BINARY() {\r\n    this._binary = true;\r\n    this.options.binary = true;\r\n    return this;\r\n  }\r\n\r\n  static get BINARY() {\r\n    return new this().BINARY;\r\n  }\r\n}\r\n\r\n/**\r\n * CHAR A fixed length string\r\n */\r\nclass CHAR extends STRING {\r\n  /**\r\n   * @param {number} [length=255] length of string\r\n   * @param {boolean} [binary=false] Is this binary?\r\n   */\r\n  constructor(length, binary) {\r\n    super(typeof length === 'object' && length || { length, binary });\r\n  }\r\n  toSql() {\r\n    return `CHAR(${this._length})${this._binary ? ' BINARY' : ''}`;\r\n  }\r\n}\r\n\r\n/**\r\n * Unlimited length TEXT column\r\n */\r\nclass TEXT extends ABSTRACT {\r\n  /**\r\n   * @param {string} [length=''] could be tiny, medium, long.\r\n   */\r\n  constructor(length) {\r\n    super();\r\n    const options = typeof length === 'object' && length || { length };\r\n    this.options = options;\r\n    this._length = options.length || '';\r\n  }\r\n  toSql() {\r\n    switch (this._length.toLowerCase()) {\r\n      case 'tiny':\r\n        return 'TINYTEXT';\r\n      case 'medium':\r\n        return 'MEDIUMTEXT';\r\n      case 'long':\r\n        return 'LONGTEXT';\r\n      default:\r\n        return this.key;\r\n    }\r\n  }\r\n  validate(value) {\r\n    if (typeof value !== 'string') {\r\n      throw new sequelizeErrors.ValidationError(util.format('%j is not a valid string', value));\r\n    }\r\n    return true;\r\n  }\r\n}\r\n\r\n/**\r\n * An unlimited length case-insensitive text column.\r\n * Original case is preserved but acts case-insensitive when comparing values (such as when finding or unique constraints).\r\n * Only available in Postgres and SQLite.\r\n *\r\n */\r\nclass CITEXT extends ABSTRACT {\r\n  toSql() {\r\n    return 'CITEXT';\r\n  }\r\n  validate(value) {\r\n    if (typeof value !== 'string') {\r\n      throw new sequelizeErrors.ValidationError(util.format('%j is not a valid string', value));\r\n    }\r\n    return true;\r\n  }\r\n}\r\n\r\n/**\r\n * Base number type which is used to build other types\r\n */\r\nclass NUMBER extends ABSTRACT {\r\n  /**\r\n   * @param {Object} options type options\r\n   * @param {string|number} [options.length] length of type, like `INT(4)`\r\n   * @param {boolean} [options.zerofill] Is zero filled?\r\n   * @param {boolean} [options.unsigned] Is unsigned?\r\n   * @param {string|number} [options.decimals] number of decimal points, used with length `FLOAT(5, 4)`\r\n   * @param {string|number} [options.precision] defines precision for decimal type\r\n   * @param {string|number} [options.scale] defines scale for decimal type\r\n   */\r\n  constructor(options = {}) {\r\n    super();\r\n    if (typeof options === 'number') {\r\n      options = {\r\n        length: options\r\n      };\r\n    }\r\n    this.options = options;\r\n    this._length = options.length;\r\n    this._zerofill = options.zerofill;\r\n    this._decimals = options.decimals;\r\n    this._precision = options.precision;\r\n    this._scale = options.scale;\r\n    this._unsigned = options.unsigned;\r\n  }\r\n  toSql() {\r\n    let result = this.key;\r\n    if (this._length) {\r\n      result += `(${this._length}`;\r\n      if (typeof this._decimals === 'number') {\r\n        result += `,${this._decimals}`;\r\n      }\r\n      result += ')';\r\n    }\r\n    if (this._unsigned) {\r\n      result += ' UNSIGNED';\r\n    }\r\n    if (this._zerofill) {\r\n      result += ' ZEROFILL';\r\n    }\r\n    return result;\r\n  }\r\n  validate(value) {\r\n    if (!Validator.isFloat(String(value))) {\r\n      throw new sequelizeErrors.ValidationError(util.format(`%j is not a valid ${this.key.toLowerCase()}`, value));\r\n    }\r\n    return true;\r\n  }\r\n  _stringify(number) {\r\n    if (typeof number === 'number' || typeof number === 'boolean' || number === null || number === undefined) {\r\n      return number;\r\n    }\r\n    if (typeof number.toString === 'function') {\r\n      return number.toString();\r\n    }\r\n    return number;\r\n  }\r\n\r\n  get UNSIGNED() {\r\n    this._unsigned = true;\r\n    this.options.unsigned = true;\r\n    return this;\r\n  }\r\n\r\n  get ZEROFILL() {\r\n    this._zerofill = true;\r\n    this.options.zerofill = true;\r\n    return this;\r\n  }\r\n\r\n  static get UNSIGNED() {\r\n    return new this().UNSIGNED;\r\n  }\r\n\r\n  static get ZEROFILL() {\r\n    return new this().ZEROFILL;\r\n  }\r\n}\r\n\r\n/**\r\n * A 32 bit integer\r\n */\r\nclass INTEGER extends NUMBER {\r\n  validate(value) {\r\n    if (!Validator.isInt(String(value))) {\r\n      throw new sequelizeErrors.ValidationError(util.format(`%j is not a valid ${this.key.toLowerCase()}`, value));\r\n    }\r\n    return true;\r\n  }\r\n}\r\n\r\n/**\r\n * A 8 bit integer\r\n */\r\nclass TINYINT extends INTEGER {\r\n}\r\n\r\n/**\r\n * A 16 bit integer\r\n */\r\nclass SMALLINT extends INTEGER {\r\n}\r\n\r\n/**\r\n * A 24 bit integer\r\n */\r\nclass MEDIUMINT extends INTEGER {\r\n}\r\n\r\n/**\r\n * A 64 bit integer\r\n */\r\nclass BIGINT extends INTEGER {\r\n}\r\n\r\n/**\r\n * Floating point number (4-byte precision).\r\n */\r\nclass FLOAT extends NUMBER {\r\n  /**\r\n   * @param {string|number} [length] length of type, like `FLOAT(4)`\r\n   * @param {string|number} [decimals] number of decimal points, used with length `FLOAT(5, 4)`\r\n   */\r\n  constructor(length, decimals) {\r\n    super(typeof length === 'object' && length || { length, decimals });\r\n  }\r\n  validate(value) {\r\n    if (!Validator.isFloat(String(value))) {\r\n      throw new sequelizeErrors.ValidationError(util.format('%j is not a valid float', value));\r\n    }\r\n    return true;\r\n  }\r\n}\r\n\r\n/**\r\n * Floating point number (4-byte precision).\r\n */\r\nclass REAL extends NUMBER {\r\n  /**\r\n   * @param {string|number} [length] length of type, like `REAL(4)`\r\n   * @param {string|number} [decimals] number of decimal points, used with length `REAL(5, 4)`\r\n   */\r\n  constructor(length, decimals) {\r\n    super(typeof length === 'object' && length || { length, decimals });\r\n  }\r\n}\r\n\r\n/**\r\n * Floating point number (8-byte precision).\r\n */\r\nclass DOUBLE extends NUMBER {\r\n  /**\r\n   * @param {string|number} [length] length of type, like `DOUBLE PRECISION(25)`\r\n   * @param {string|number} [decimals] number of decimal points, used with length `DOUBLE PRECISION(25, 10)`\r\n   */\r\n  constructor(length, decimals) {\r\n    super(typeof length === 'object' && length || { length, decimals });\r\n  }\r\n}\r\n\r\n/**\r\n * Decimal type, variable precision, take length as specified by user\r\n */\r\nclass DECIMAL extends NUMBER {\r\n  /**\r\n   * @param {string|number} [precision] defines precision\r\n   * @param {string|number} [scale] defines scale\r\n   */\r\n  constructor(precision, scale) {\r\n    super(typeof precision === 'object' && precision || { precision, scale });\r\n  }\r\n  toSql() {\r\n    if (this._precision || this._scale) {\r\n      return `DECIMAL(${[this._precision, this._scale].filter(_.identity).join(',')})`;\r\n    }\r\n    return 'DECIMAL';\r\n  }\r\n  validate(value) {\r\n    if (!Validator.isDecimal(String(value))) {\r\n      throw new sequelizeErrors.ValidationError(util.format('%j is not a valid decimal', value));\r\n    }\r\n    return true;\r\n  }\r\n}\r\n\r\n// TODO: Create intermediate class\r\nconst protoExtensions = {\r\n  escape: false,\r\n  _value(value) {\r\n    if (isNaN(value)) {\r\n      return 'NaN';\r\n    }\r\n    if (!isFinite(value)) {\r\n      const sign = value < 0 ? '-' : '';\r\n      return `${sign}Infinity`;\r\n    }\r\n\r\n    return value;\r\n  },\r\n  _stringify(value) {\r\n    return `'${this._value(value)}'`;\r\n  },\r\n  _bindParam(value, options) {\r\n    return options.bindParam(this._value(value));\r\n  }\r\n};\r\n\r\nfor (const floating of [FLOAT, DOUBLE, REAL]) {\r\n  Object.assign(floating.prototype, protoExtensions);\r\n}\r\n\r\n/**\r\n * A boolean / tinyint column, depending on dialect\r\n */\r\nclass BOOLEAN extends ABSTRACT {\r\n  toSql() {\r\n    return 'TINYINT(1)';\r\n  }\r\n  validate(value) {\r\n    if (!Validator.isBoolean(String(value))) {\r\n      throw new sequelizeErrors.ValidationError(util.format('%j is not a valid boolean', value));\r\n    }\r\n    return true;\r\n  }\r\n  _sanitize(value) {\r\n    if (value !== null && value !== undefined) {\r\n      if (Buffer.isBuffer(value) && value.length === 1) {\r\n        // Bit fields are returned as buffers\r\n        value = value[0];\r\n      }\r\n      const type = typeof value;\r\n      if (type === 'string') {\r\n        // Only take action on valid boolean strings.\r\n        return value === 'true' ? true : value === 'false' ? false : value;\r\n      }\r\n      if (type === 'number') {\r\n        // Only take action on valid boolean integers.\r\n        return value === 1 ? true : value === 0 ? false : value;\r\n      }\r\n    }\r\n    return value;\r\n  }\r\n}\r\n\r\n\r\nBOOLEAN.parse = BOOLEAN.prototype._sanitize;\r\n\r\n/**\r\n * A time column\r\n *\r\n */\r\nclass TIME extends ABSTRACT {\r\n  toSql() {\r\n    return 'TIME';\r\n  }\r\n}\r\n\r\n/**\r\n * Date column with timezone, default is UTC\r\n */\r\nclass DATE extends ABSTRACT {\r\n  /**\r\n   * @param {string|number} [length] precision to allow storing milliseconds\r\n   */\r\n  constructor(length) {\r\n    super();\r\n    const options = typeof length === 'object' && length || { length };\r\n    this.options = options;\r\n    this._length = options.length || '';\r\n  }\r\n  toSql() {\r\n    return 'DATETIME';\r\n  }\r\n  validate(value) {\r\n    if (!Validator.isDate(String(value))) {\r\n      throw new sequelizeErrors.ValidationError(util.format('%j is not a valid date', value));\r\n    }\r\n    return true;\r\n  }\r\n  _sanitize(value, options) {\r\n    if ((!options || options && !options.raw) && !(value instanceof Date) && !!value) {\r\n      return new Date(value);\r\n    }\r\n    return value;\r\n  }\r\n  _isChanged(value, originalValue) {\r\n    if (originalValue && !!value &&\r\n      (value === originalValue ||\r\n        value instanceof Date && originalValue instanceof Date && value.getTime() === originalValue.getTime())) {\r\n      return false;\r\n    }\r\n    // not changed when set to same empty value\r\n    if (!originalValue && !value && originalValue === value) {\r\n      return false;\r\n    }\r\n    return true;\r\n  }\r\n  _applyTimezone(date, options) {\r\n    if (options.timezone) {\r\n      if (momentTz.tz.zone(options.timezone)) {\r\n        return momentTz(date).tz(options.timezone);\r\n      }\r\n      return date = moment(date).utcOffset(options.timezone);\r\n    }\r\n    return momentTz(date);\r\n  }\r\n  _stringify(date, options) {\r\n    date = this._applyTimezone(date, options);\r\n    // Z here means current timezone, _not_ UTC\r\n    return date.format('YYYY-MM-DD HH:mm:ss.SSS Z');\r\n  }\r\n}\r\n\r\n/**\r\n * A date only column (no timestamp)\r\n */\r\nclass DATEONLY extends ABSTRACT {\r\n  toSql() {\r\n    return 'DATE';\r\n  }\r\n  _stringify(date) {\r\n    return moment(date).format('YYYY-MM-DD');\r\n  }\r\n  _sanitize(value, options) {\r\n    if ((!options || options && !options.raw) && !!value) {\r\n      return moment(value).format('YYYY-MM-DD');\r\n    }\r\n    return value;\r\n  }\r\n  _isChanged(value, originalValue) {\r\n    if (originalValue && !!value && originalValue === value) {\r\n      return false;\r\n    }\r\n    // not changed when set to same empty value\r\n    if (!originalValue && !value && originalValue === value) {\r\n      return false;\r\n    }\r\n    return true;\r\n  }\r\n}\r\n\r\n/**\r\n * A key / value store column. Only available in Postgres.\r\n */\r\nclass HSTORE extends ABSTRACT {\r\n  validate(value) {\r\n    if (!_.isPlainObject(value)) {\r\n      throw new sequelizeErrors.ValidationError(util.format('%j is not a valid hstore', value));\r\n    }\r\n    return true;\r\n  }\r\n}\r\n\r\n/**\r\n * A JSON string column. Available in MySQL, Postgres and SQLite\r\n */\r\nclass JSONTYPE extends ABSTRACT {\r\n  validate() {\r\n    return true;\r\n  }\r\n  _stringify(value) {\r\n    return JSON.stringify(value);\r\n  }\r\n}\r\n\r\n/**\r\n * A binary storage JSON column. Only available in Postgres.\r\n */\r\nclass JSONB extends JSONTYPE {\r\n}\r\n\r\n/**\r\n * A default value of the current timestamp\r\n */\r\nclass NOW extends ABSTRACT {\r\n}\r\n\r\n/**\r\n * Binary storage\r\n */\r\nclass BLOB extends ABSTRACT {\r\n  /**\r\n   * @param {string} [length=''] could be tiny, medium, long.\r\n   */\r\n  constructor(length) {\r\n    super();\r\n    const options = typeof length === 'object' && length || { length };\r\n    this.options = options;\r\n    this._length = options.length || '';\r\n  }\r\n  toSql() {\r\n    switch (this._length.toLowerCase()) {\r\n      case 'tiny':\r\n        return 'TINYBLOB';\r\n      case 'medium':\r\n        return 'MEDIUMBLOB';\r\n      case 'long':\r\n        return 'LONGBLOB';\r\n      default:\r\n        return this.key;\r\n    }\r\n  }\r\n  validate(value) {\r\n    if (typeof value !== 'string' && !Buffer.isBuffer(value)) {\r\n      throw new sequelizeErrors.ValidationError(util.format('%j is not a valid blob', value));\r\n    }\r\n    return true;\r\n  }\r\n  _stringify(value) {\r\n    if (!Buffer.isBuffer(value)) {\r\n      if (Array.isArray(value)) {\r\n        value = Buffer.from(value);\r\n      }\r\n      else {\r\n        value = Buffer.from(value.toString());\r\n      }\r\n    }\r\n    const hex = value.toString('hex');\r\n    return this._hexify(hex);\r\n  }\r\n  _hexify(hex) {\r\n    return `X'${hex}'`;\r\n  }\r\n  _bindParam(value, options) {\r\n    if (!Buffer.isBuffer(value)) {\r\n      if (Array.isArray(value)) {\r\n        value = Buffer.from(value);\r\n      }\r\n      else {\r\n        value = Buffer.from(value.toString());\r\n      }\r\n    }\r\n    return options.bindParam(value);\r\n  }\r\n}\r\n\r\n\r\nBLOB.prototype.escape = false;\r\n\r\n/**\r\n * Range types are data types representing a range of values of some element type (called the range's subtype).\r\n * Only available in Postgres. See [the Postgres documentation](http://www.postgresql.org/docs/9.4/static/rangetypes.html) for more details\r\n */\r\nclass RANGE extends ABSTRACT {\r\n  /**\r\n   * @param {ABSTRACT} subtype A subtype for range, like RANGE(DATE)\r\n   */\r\n  constructor(subtype) {\r\n    super();\r\n    const options = _.isPlainObject(subtype) ? subtype : { subtype };\r\n    if (!options.subtype)\r\n      options.subtype = new INTEGER();\r\n    if (typeof options.subtype === 'function') {\r\n      options.subtype = new options.subtype();\r\n    }\r\n    this._subtype = options.subtype.key;\r\n    this.options = options;\r\n  }\r\n  validate(value) {\r\n    if (!Array.isArray(value)) {\r\n      throw new sequelizeErrors.ValidationError(util.format('%j is not a valid range', value));\r\n    }\r\n    if (value.length !== 2) {\r\n      throw new sequelizeErrors.ValidationError('A range must be an array with two elements');\r\n    }\r\n    return true;\r\n  }\r\n}\r\n\r\n/**\r\n * A column storing a unique universal identifier.\r\n * Use with `UUIDV1` or `UUIDV4` for default values.\r\n */\r\nclass UUID extends ABSTRACT {\r\n  validate(value, options) {\r\n    if (typeof value !== 'string' || !Validator.isUUID(value) && (!options || !options.acceptStrings)) {\r\n      throw new sequelizeErrors.ValidationError(util.format('%j is not a valid uuid', value));\r\n    }\r\n    return true;\r\n  }\r\n}\r\n\r\n/**\r\n * A default unique universal identifier generated following the UUID v1 standard\r\n */\r\nclass UUIDV1 extends ABSTRACT {\r\n  validate(value, options) {\r\n    if (typeof value !== 'string' || !Validator.isUUID(value) && (!options || !options.acceptStrings)) {\r\n      throw new sequelizeErrors.ValidationError(util.format('%j is not a valid uuid', value));\r\n    }\r\n    return true;\r\n  }\r\n}\r\n\r\n/**\r\n * A default unique universal identifier generated following the UUID v4 standard\r\n */\r\nclass UUIDV4 extends ABSTRACT {\r\n  validate(value, options) {\r\n    if (typeof value !== 'string' || !Validator.isUUID(value, 4) && (!options || !options.acceptStrings)) {\r\n      throw new sequelizeErrors.ValidationError(util.format('%j is not a valid uuidv4', value));\r\n    }\r\n    return true;\r\n  }\r\n}\r\n\r\n/**\r\n * A virtual value that is not stored in the DB. This could for example be useful if you want to provide a default value in your model that is returned to the user but not stored in the DB.\r\n *\r\n * You could also use it to validate a value before permuting and storing it. VIRTUAL also takes a return type and dependency fields as arguments\r\n * If a virtual attribute is present in `attributes` it will automatically pull in the extra fields as well.\r\n * Return type is mostly useful for setups that rely on types like GraphQL.\r\n *\r\n * @example <caption>Checking password length before hashing it</caption>\r\n * sequelize.define('user', {\r\n *   password_hash: DataTypes.STRING,\r\n *   password: {\r\n *     type: DataTypes.VIRTUAL,\r\n *     set: function (val) {\r\n *        // Remember to set the data value, otherwise it won't be validated\r\n *        this.setDataValue('password', val);\r\n *        this.setDataValue('password_hash', this.salt + val);\r\n *      },\r\n *      validate: {\r\n *         isLongEnough: function (val) {\r\n *           if (val.length < 7) {\r\n *             throw new Error(\"Please choose a longer password\")\r\n *          }\r\n *       }\r\n *     }\r\n *   }\r\n * })\r\n *\r\n * # In the above code the password is stored plainly in the password field so it can be validated, but is never stored in the DB.\r\n *\r\n * @example <caption>Virtual with dependency fields</caption>\r\n * {\r\n *   active: {\r\n *     type: new DataTypes.VIRTUAL(DataTypes.BOOLEAN, ['createdAt']),\r\n *     get: function() {\r\n *       return this.get('createdAt') > Date.now() - (7 * 24 * 60 * 60 * 1000)\r\n *     }\r\n *   }\r\n * }\r\n *\r\n */\r\nclass VIRTUAL extends ABSTRACT {\r\n  /**\r\n   * @param {ABSTRACT} [ReturnType] return type for virtual type\r\n   * @param {Array} [fields] array of fields this virtual type is dependent on\r\n   */\r\n  constructor(ReturnType, fields) {\r\n    super();\r\n    if (typeof ReturnType === 'function')\r\n      ReturnType = new ReturnType();\r\n    this.returnType = ReturnType;\r\n    this.fields = fields;\r\n  }\r\n}\r\n\r\n/**\r\n * An enumeration, Postgres Only\r\n *\r\n * @example\r\n * DataTypes.ENUM('value', 'another value')\r\n * DataTypes.ENUM(['value', 'another value'])\r\n * DataTypes.ENUM({\r\n *   values: ['value', 'another value']\r\n * })\r\n */\r\nclass ENUM extends ABSTRACT {\r\n  /**\r\n   * @param {...any|{ values: any[] }|any[]} args either array of values or options object with values array. It also supports variadic values\r\n   */\r\n  constructor(...args) {\r\n    super();\r\n    const value = args[0];\r\n    const options = typeof value === 'object' && !Array.isArray(value) && value || {\r\n      values: args.reduce((result, element) => {\r\n        return result.concat(Array.isArray(element) ? element : [element]);\r\n      }, [])\r\n    };\r\n    this.values = options.values;\r\n    this.options = options;\r\n  }\r\n  validate(value) {\r\n    if (!this.values.includes(value)) {\r\n      throw new sequelizeErrors.ValidationError(util.format('%j is not a valid choice in %j', value, this.values));\r\n    }\r\n    return true;\r\n  }\r\n}\r\n\r\n/**\r\n * An array of `type`. Only available in Postgres.\r\n *\r\n * @example\r\n * DataTypes.ARRAY(DataTypes.DECIMAL)\r\n */\r\nclass ARRAY extends ABSTRACT {\r\n  /**\r\n   * @param {ABSTRACT} type type of array values\r\n   */\r\n  constructor(type) {\r\n    super();\r\n    const options = _.isPlainObject(type) ? type : { type };\r\n    this.options = options;\r\n    this.type = typeof options.type === 'function' ? new options.type() : options.type;\r\n  }\r\n  toSql() {\r\n    return `${this.type.toSql()}[]`;\r\n  }\r\n  validate(value) {\r\n    if (!Array.isArray(value)) {\r\n      throw new sequelizeErrors.ValidationError(util.format('%j is not a valid array', value));\r\n    }\r\n    return true;\r\n  }\r\n  static is(obj, type) {\r\n    return obj instanceof ARRAY && obj.type instanceof type;\r\n  }\r\n}\r\n\r\n/**\r\n * A column storing Geometry information.\r\n * It is only available in PostgreSQL (with PostGIS), MariaDB or MySQL.\r\n *\r\n * GeoJSON is accepted as input and returned as output.\r\n *\r\n * In PostGIS, the GeoJSON is parsed using the PostGIS function `ST_GeomFromGeoJSON`.\r\n * In MySQL it is parsed using the function `GeomFromText`.\r\n *\r\n * Therefore, one can just follow the [GeoJSON spec](http://geojson.org/geojson-spec.html) for handling geometry objects.  See the following examples:\r\n *\r\n * @example <caption>Defining a Geometry type attribute</caption>\r\n * DataTypes.GEOMETRY\r\n * DataTypes.GEOMETRY('POINT')\r\n * DataTypes.GEOMETRY('POINT', 4326)\r\n *\r\n * @example <caption>Create a new point</caption>\r\n * const point = { type: 'Point', coordinates: [39.807222,-76.984722]};\r\n *\r\n * User.create({username: 'username', geometry: point });\r\n *\r\n * @example <caption>Create a new linestring</caption>\r\n * const line = { type: 'LineString', 'coordinates': [ [100.0, 0.0], [101.0, 1.0] ] };\r\n *\r\n * User.create({username: 'username', geometry: line });\r\n *\r\n * @example <caption>Create a new polygon</caption>\r\n * const polygon = { type: 'Polygon', coordinates: [\r\n *                 [ [100.0, 0.0], [101.0, 0.0], [101.0, 1.0],\r\n *                   [100.0, 1.0], [100.0, 0.0] ]\r\n *                 ]};\r\n *\r\n * User.create({username: 'username', geometry: polygon });\r\n *\r\n * @example <caption>Create a new point with a custom SRID</caption>\r\n * const point = {\r\n *   type: 'Point',\r\n *   coordinates: [39.807222,-76.984722],\r\n *   crs: { type: 'name', properties: { name: 'EPSG:4326'} }\r\n * };\r\n *\r\n * User.create({username: 'username', geometry: point })\r\n *\r\n *\r\n * @see {@link DataTypes.GEOGRAPHY}\r\n */\r\nclass GEOMETRY extends ABSTRACT {\r\n  /**\r\n   * @param {string} [type] Type of geometry data\r\n   * @param {string} [srid] SRID of type\r\n   */\r\n  constructor(type, srid) {\r\n    super();\r\n    const options = _.isPlainObject(type) ? type : { type, srid };\r\n    this.options = options;\r\n    this.type = options.type;\r\n    this.srid = options.srid;\r\n  }\r\n  _stringify(value, options) {\r\n    return `GeomFromText(${options.escape(wkx.Geometry.parseGeoJSON(value).toWkt())})`;\r\n  }\r\n  _bindParam(value, options) {\r\n    return `GeomFromText(${options.bindParam(wkx.Geometry.parseGeoJSON(value).toWkt())})`;\r\n  }\r\n}\r\n\r\nGEOMETRY.prototype.escape = false;\r\n\r\n/**\r\n * A geography datatype represents two dimensional spacial objects in an elliptic coord system.\r\n *\r\n * __The difference from geometry and geography type:__\r\n *\r\n * PostGIS 1.5 introduced a new spatial type called geography, which uses geodetic measurement instead of Cartesian measurement.\r\n * Coordinate points in the geography type are always represented in WGS 84 lon lat degrees (SRID 4326),\r\n * but measurement functions and relationships ST_Distance, ST_DWithin, ST_Length, and ST_Area always return answers in meters or assume inputs in meters.\r\n *\r\n * __What is best to use? It depends:__\r\n *\r\n * When choosing between the geometry and geography type for data storage, you should consider what you’ll be using it for.\r\n * If all you do are simple measurements and relationship checks on your data, and your data covers a fairly large area, then most likely you’ll be better off storing your data using the new geography type.\r\n * Although the new geography data type can cover the globe, the geometry type is far from obsolete.\r\n * The geometry type has a much richer set of functions than geography, relationship checks are generally faster, and it has wider support currently across desktop and web-mapping tools\r\n *\r\n * @example <caption>Defining a Geography type attribute</caption>\r\n * DataTypes.GEOGRAPHY\r\n * DataTypes.GEOGRAPHY('POINT')\r\n * DataTypes.GEOGRAPHY('POINT', 4326)\r\n */\r\nclass GEOGRAPHY extends ABSTRACT {\r\n  /**\r\n   * @param {string} [type] Type of geography data\r\n   * @param {string} [srid] SRID of type\r\n   */\r\n  constructor(type, srid) {\r\n    super();\r\n    const options = _.isPlainObject(type) ? type : { type, srid };\r\n    this.options = options;\r\n    this.type = options.type;\r\n    this.srid = options.srid;\r\n  }\r\n  _stringify(value, options) {\r\n    return `GeomFromText(${options.escape(wkx.Geometry.parseGeoJSON(value).toWkt())})`;\r\n  }\r\n  _bindParam(value, options) {\r\n    return `GeomFromText(${options.bindParam(wkx.Geometry.parseGeoJSON(value).toWkt())})`;\r\n  }\r\n}\r\n\r\n\r\nGEOGRAPHY.prototype.escape = false;\r\n\r\n/**\r\n * The cidr type holds an IPv4 or IPv6 network specification. Takes 7 or 19 bytes.\r\n *\r\n * Only available for Postgres\r\n */\r\nclass CIDR extends ABSTRACT {\r\n  validate(value) {\r\n    if (typeof value !== 'string' || !Validator.isIPRange(value)) {\r\n      throw new sequelizeErrors.ValidationError(util.format('%j is not a valid CIDR', value));\r\n    }\r\n    return true;\r\n  }\r\n}\r\n\r\n/**\r\n * The INET type holds an IPv4 or IPv6 host address, and optionally its subnet. Takes 7 or 19 bytes\r\n *\r\n * Only available for Postgres\r\n */\r\nclass INET extends ABSTRACT {\r\n  validate(value) {\r\n    if (typeof value !== 'string' || !Validator.isIP(value)) {\r\n      throw new sequelizeErrors.ValidationError(util.format('%j is not a valid INET', value));\r\n    }\r\n    return true;\r\n  }\r\n}\r\n\r\n/**\r\n * The MACADDR type stores MAC addresses. Takes 6 bytes\r\n *\r\n * Only available for Postgres\r\n *\r\n */\r\nclass MACADDR extends ABSTRACT {\r\n  validate(value) {\r\n    if (typeof value !== 'string' || !Validator.isMACAddress(value)) {\r\n      throw new sequelizeErrors.ValidationError(util.format('%j is not a valid MACADDR', value));\r\n    }\r\n    return true;\r\n  }\r\n}\r\n\r\n/**\r\n * A convenience class holding commonly used data types. The data types are used when defining a new model using `Sequelize.define`, like this:\r\n * ```js\r\n * sequelize.define('model', {\r\n *   column: DataTypes.INTEGER\r\n * })\r\n * ```\r\n * When defining a model you can just as easily pass a string as type, but often using the types defined here is beneficial. For example, using `DataTypes.BLOB`, mean\r\n * that that column will be returned as an instance of `Buffer` when being fetched by sequelize.\r\n *\r\n * To provide a length for the data type, you can invoke it like a function: `INTEGER(2)`\r\n *\r\n * Some data types have special properties that can be accessed in order to change the data type.\r\n * For example, to get an unsigned integer with zerofill you can do `DataTypes.INTEGER.UNSIGNED.ZEROFILL`.\r\n * The order you access the properties in do not matter, so `DataTypes.INTEGER.ZEROFILL.UNSIGNED` is fine as well.\r\n *\r\n * * All number types (`INTEGER`, `BIGINT`, `FLOAT`, `DOUBLE`, `REAL`, `DECIMAL`) expose the properties `UNSIGNED` and `ZEROFILL`\r\n * * The `CHAR` and `STRING` types expose the `BINARY` property\r\n *\r\n * Three of the values provided here (`NOW`, `UUIDV1` and `UUIDV4`) are special default values, that should not be used to define types. Instead they are used as shorthands for\r\n * defining default values. For example, to get a uuid field with a default value generated following v1 of the UUID standard:\r\n * ```js\r\n * sequelize.define('model', {\r\n *   uuid: {\r\n *     type: DataTypes.UUID,\r\n *     defaultValue: DataTypes.UUIDV1,\r\n *     primaryKey: true\r\n *   }\r\n * })\r\n * ```\r\n * There may be times when you want to generate your own UUID conforming to some other algorithm. This is accomplished\r\n * using the defaultValue property as well, but instead of specifying one of the supplied UUID types, you return a value\r\n * from a function.\r\n * ```js\r\n * sequelize.define('model', {\r\n *   uuid: {\r\n *     type: DataTypes.UUID,\r\n *     defaultValue: function() {\r\n *       return generateMyId()\r\n *     },\r\n *     primaryKey: true\r\n *   }\r\n * })\r\n * ```\r\n */\r\nconst DataTypes = module.exports = {\r\n  ABSTRACT,\r\n  STRING,\r\n  CHAR,\r\n  TEXT,\r\n  NUMBER,\r\n  TINYINT,\r\n  SMALLINT,\r\n  MEDIUMINT,\r\n  INTEGER,\r\n  BIGINT,\r\n  FLOAT,\r\n  TIME,\r\n  DATE,\r\n  DATEONLY,\r\n  BOOLEAN,\r\n  NOW,\r\n  BLOB,\r\n  DECIMAL,\r\n  NUMERIC: DECIMAL,\r\n  UUID,\r\n  UUIDV1,\r\n  UUIDV4,\r\n  HSTORE,\r\n  JSON: JSONTYPE,\r\n  JSONB,\r\n  VIRTUAL,\r\n  ARRAY,\r\n  ENUM,\r\n  RANGE,\r\n  REAL,\r\n  'DOUBLE PRECISION': DOUBLE,\r\n  DOUBLE,\r\n  GEOMETRY,\r\n  GEOGRAPHY,\r\n  CIDR,\r\n  INET,\r\n  MACADDR,\r\n  CITEXT\r\n};\r\n\r\n_.each(DataTypes, (dataType, name) => {\r\n  // guard for aliases\r\n  if (!Object.prototype.hasOwnProperty.call(dataType, 'key')) {\r\n    dataType.types = {};\r\n    dataType.key = dataType.prototype.key = name;\r\n  }\r\n});\r\n\r\nconst dialectMap = {};\r\n/* dialectMap.postgres = require('./dialects/postgres/data-types')(DataTypes);\r\ndialectMap.mysql = require('./dialects/mysql/data-types')(DataTypes);\r\ndialectMap.mariadb = require('./dialects/mariadb/data-types')(DataTypes); */\r\ndialectMap.sqlite = require('./dialects/sqlite/data-types')(DataTypes);\r\n/* dialectMap.mssql = require('./dialects/mssql/data-types')(DataTypes); */\r\n\r\nconst dialectList = _.values(dialectMap);\r\n\r\nfor (const dataTypes of dialectList) {\r\n  _.each(dataTypes, (DataType, key) => {\r\n    if (!DataType.key) {\r\n      DataType.key = DataType.prototype.key = key;\r\n    }\r\n  });\r\n}\r\n\r\n// Wrap all data types to not require `new`\r\nfor (const dataTypes of [DataTypes, ...dialectList]) {\r\n  _.each(dataTypes, (DataType, key) => {\r\n    dataTypes[key] = classToInvokable(DataType);\r\n  });\r\n}\r\n\r\nObject.assign(DataTypes, dialectMap);\r\n"]} \ No newline at end of file +//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../lib/data-types.js"],"names":["util","require","_","sequelizeErrors","Validator","validator","momentTz","moment","logger","warnings","classToInvokable","ABSTRACT","options","toSql","key","value","_stringify","_bindParam","bindParam","stringify","name","link","text","warn","oldType","prototype","dialectTypes","STRING","length","binary","_binary","_length","Object","toString","call","Buffer","isBuffer","ValidationError","format","BINARY","CHAR","TEXT","toLowerCase","CITEXT","NUMBER","_zerofill","zerofill","_decimals","decimals","_precision","precision","_scale","scale","_unsigned","unsigned","result","isFloat","String","number","undefined","UNSIGNED","ZEROFILL","INTEGER","isInt","TINYINT","SMALLINT","MEDIUMINT","BIGINT","FLOAT","REAL","DOUBLE","DECIMAL","filter","identity","join","isDecimal","protoExtensions","escape","_value","isNaN","isFinite","sign","floating","assign","BOOLEAN","isBoolean","type","parse","_sanitize","TIME","DATE","isDate","raw","Date","originalValue","getTime","date","timezone","tz","zone","utcOffset","_applyTimezone","DATEONLY","HSTORE","isPlainObject","JSONTYPE","JSON","JSONB","NOW","BLOB","Array","isArray","from","hex","_hexify","RANGE","subtype","_subtype","UUID","isUUID","acceptStrings","UUIDV1","UUIDV4","VIRTUAL","ReturnType","fields","returnType","ENUM","args","values","reduce","element","concat","includes","ARRAY","obj","CIDR","isIPRange","INET","isIP","MACADDR","isMACAddress","DataTypes","module","exports","NUMERIC","each","dataType","hasOwnProperty","types","dialectMap","sqlite","dialectList","dataTypes","DataType"],"mappings":"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","sourcesContent":["'use strict';\n\nconst util = require('util');\nconst _ = require('lodash');\nconst sequelizeErrors = require('./errors');\nconst Validator = require('./utils/validator-extras').validator;\nconst momentTz = require('moment-timezone');\nconst moment = require('moment');\nconst { logger } = require('./utils/logger');\nconst warnings = {};\nconst { classToInvokable } = require('./utils/classToInvokable');\n\nclass ABSTRACT {\n  toString(options) {\n    return this.toSql(options);\n  }\n  toSql() {\n    return this.key;\n  }\n  stringify(value, options) {\n    if (this._stringify) {\n      return this._stringify(value, options);\n    }\n    return value;\n  }\n  bindParam(value, options) {\n    if (this._bindParam) {\n      return this._bindParam(value, options);\n    }\n    return options.bindParam(this.stringify(value, options));\n  }\n  static toString() {\n    return this.name;\n  }\n  static warn(link, text) {\n    if (!warnings[text]) {\n      warnings[text] = true;\n      logger.warn(`${text} \\n>> Check: ${link}`);\n    }\n  }\n  static extend(oldType) {\n    return new this(oldType.options);\n  }\n}\n\nABSTRACT.prototype.dialectTypes = '';\n\n/**\n * STRING A variable length string\n */\nclass STRING extends ABSTRACT {\n  /**\n   * @param {number} [length=255] length of string\n   * @param {boolean} [binary=false] Is this binary?\n   */\n  constructor(length, binary) {\n    super();\n    const options = typeof length === 'object' && length || { length, binary };\n    this.options = options;\n    this._binary = options.binary;\n    this._length = options.length || 255;\n  }\n  toSql() {\n    return `VARCHAR(${this._length})${this._binary ? ' BINARY' : ''}`;\n  }\n  validate(value) {\n    if (Object.prototype.toString.call(value) !== '[object String]') {\n      if (this.options.binary && Buffer.isBuffer(value) || typeof value === 'number') {\n        return true;\n      }\n      throw new sequelizeErrors.ValidationError(util.format('%j is not a valid string', value));\n    }\n    return true;\n  }\n\n  get BINARY() {\n    this._binary = true;\n    this.options.binary = true;\n    return this;\n  }\n\n  static get BINARY() {\n    return new this().BINARY;\n  }\n}\n\n/**\n * CHAR A fixed length string\n */\nclass CHAR extends STRING {\n  /**\n   * @param {number} [length=255] length of string\n   * @param {boolean} [binary=false] Is this binary?\n   */\n  constructor(length, binary) {\n    super(typeof length === 'object' && length || { length, binary });\n  }\n  toSql() {\n    return `CHAR(${this._length})${this._binary ? ' BINARY' : ''}`;\n  }\n}\n\n/**\n * Unlimited length TEXT column\n */\nclass TEXT extends ABSTRACT {\n  /**\n   * @param {string} [length=''] could be tiny, medium, long.\n   */\n  constructor(length) {\n    super();\n    const options = typeof length === 'object' && length || { length };\n    this.options = options;\n    this._length = options.length || '';\n  }\n  toSql() {\n    switch (this._length.toLowerCase()) {\n      case 'tiny':\n        return 'TINYTEXT';\n      case 'medium':\n        return 'MEDIUMTEXT';\n      case 'long':\n        return 'LONGTEXT';\n      default:\n        return this.key;\n    }\n  }\n  validate(value) {\n    if (typeof value !== 'string') {\n      throw new sequelizeErrors.ValidationError(util.format('%j is not a valid string', value));\n    }\n    return true;\n  }\n}\n\n/**\n * An unlimited length case-insensitive text column.\n * Original case is preserved but acts case-insensitive when comparing values (such as when finding or unique constraints).\n * Only available in Postgres and SQLite.\n *\n */\nclass CITEXT extends ABSTRACT {\n  toSql() {\n    return 'CITEXT';\n  }\n  validate(value) {\n    if (typeof value !== 'string') {\n      throw new sequelizeErrors.ValidationError(util.format('%j is not a valid string', value));\n    }\n    return true;\n  }\n}\n\n/**\n * Base number type which is used to build other types\n */\nclass NUMBER extends ABSTRACT {\n  /**\n   * @param {Object} options type options\n   * @param {string|number} [options.length] length of type, like `INT(4)`\n   * @param {boolean} [options.zerofill] Is zero filled?\n   * @param {boolean} [options.unsigned] Is unsigned?\n   * @param {string|number} [options.decimals] number of decimal points, used with length `FLOAT(5, 4)`\n   * @param {string|number} [options.precision] defines precision for decimal type\n   * @param {string|number} [options.scale] defines scale for decimal type\n   */\n  constructor(options = {}) {\n    super();\n    if (typeof options === 'number') {\n      options = {\n        length: options\n      };\n    }\n    this.options = options;\n    this._length = options.length;\n    this._zerofill = options.zerofill;\n    this._decimals = options.decimals;\n    this._precision = options.precision;\n    this._scale = options.scale;\n    this._unsigned = options.unsigned;\n  }\n  toSql() {\n    let result = this.key;\n    if (this._length) {\n      result += `(${this._length}`;\n      if (typeof this._decimals === 'number') {\n        result += `,${this._decimals}`;\n      }\n      result += ')';\n    }\n    if (this._unsigned) {\n      result += ' UNSIGNED';\n    }\n    if (this._zerofill) {\n      result += ' ZEROFILL';\n    }\n    return result;\n  }\n  validate(value) {\n    if (!Validator.isFloat(String(value))) {\n      throw new sequelizeErrors.ValidationError(util.format(`%j is not a valid ${this.key.toLowerCase()}`, value));\n    }\n    return true;\n  }\n  _stringify(number) {\n    if (typeof number === 'number' || typeof number === 'boolean' || number === null || number === undefined) {\n      return number;\n    }\n    if (typeof number.toString === 'function') {\n      return number.toString();\n    }\n    return number;\n  }\n\n  get UNSIGNED() {\n    this._unsigned = true;\n    this.options.unsigned = true;\n    return this;\n  }\n\n  get ZEROFILL() {\n    this._zerofill = true;\n    this.options.zerofill = true;\n    return this;\n  }\n\n  static get UNSIGNED() {\n    return new this().UNSIGNED;\n  }\n\n  static get ZEROFILL() {\n    return new this().ZEROFILL;\n  }\n}\n\n/**\n * A 32 bit integer\n */\nclass INTEGER extends NUMBER {\n  validate(value) {\n    if (!Validator.isInt(String(value))) {\n      throw new sequelizeErrors.ValidationError(util.format(`%j is not a valid ${this.key.toLowerCase()}`, value));\n    }\n    return true;\n  }\n}\n\n/**\n * A 8 bit integer\n */\nclass TINYINT extends INTEGER {\n}\n\n/**\n * A 16 bit integer\n */\nclass SMALLINT extends INTEGER {\n}\n\n/**\n * A 24 bit integer\n */\nclass MEDIUMINT extends INTEGER {\n}\n\n/**\n * A 64 bit integer\n */\nclass BIGINT extends INTEGER {\n}\n\n/**\n * Floating point number (4-byte precision).\n */\nclass FLOAT extends NUMBER {\n  /**\n   * @param {string|number} [length] length of type, like `FLOAT(4)`\n   * @param {string|number} [decimals] number of decimal points, used with length `FLOAT(5, 4)`\n   */\n  constructor(length, decimals) {\n    super(typeof length === 'object' && length || { length, decimals });\n  }\n  validate(value) {\n    if (!Validator.isFloat(String(value))) {\n      throw new sequelizeErrors.ValidationError(util.format('%j is not a valid float', value));\n    }\n    return true;\n  }\n}\n\n/**\n * Floating point number (4-byte precision).\n */\nclass REAL extends NUMBER {\n  /**\n   * @param {string|number} [length] length of type, like `REAL(4)`\n   * @param {string|number} [decimals] number of decimal points, used with length `REAL(5, 4)`\n   */\n  constructor(length, decimals) {\n    super(typeof length === 'object' && length || { length, decimals });\n  }\n}\n\n/**\n * Floating point number (8-byte precision).\n */\nclass DOUBLE extends NUMBER {\n  /**\n   * @param {string|number} [length] length of type, like `DOUBLE PRECISION(25)`\n   * @param {string|number} [decimals] number of decimal points, used with length `DOUBLE PRECISION(25, 10)`\n   */\n  constructor(length, decimals) {\n    super(typeof length === 'object' && length || { length, decimals });\n  }\n}\n\n/**\n * Decimal type, variable precision, take length as specified by user\n */\nclass DECIMAL extends NUMBER {\n  /**\n   * @param {string|number} [precision] defines precision\n   * @param {string|number} [scale] defines scale\n   */\n  constructor(precision, scale) {\n    super(typeof precision === 'object' && precision || { precision, scale });\n  }\n  toSql() {\n    if (this._precision || this._scale) {\n      return `DECIMAL(${[this._precision, this._scale].filter(_.identity).join(',')})`;\n    }\n    return 'DECIMAL';\n  }\n  validate(value) {\n    if (!Validator.isDecimal(String(value))) {\n      throw new sequelizeErrors.ValidationError(util.format('%j is not a valid decimal', value));\n    }\n    return true;\n  }\n}\n\n// TODO: Create intermediate class\nconst protoExtensions = {\n  escape: false,\n  _value(value) {\n    if (isNaN(value)) {\n      return 'NaN';\n    }\n    if (!isFinite(value)) {\n      const sign = value < 0 ? '-' : '';\n      return `${sign}Infinity`;\n    }\n\n    return value;\n  },\n  _stringify(value) {\n    return `'${this._value(value)}'`;\n  },\n  _bindParam(value, options) {\n    return options.bindParam(this._value(value));\n  }\n};\n\nfor (const floating of [FLOAT, DOUBLE, REAL]) {\n  Object.assign(floating.prototype, protoExtensions);\n}\n\n/**\n * A boolean / tinyint column, depending on dialect\n */\nclass BOOLEAN extends ABSTRACT {\n  toSql() {\n    return 'TINYINT(1)';\n  }\n  validate(value) {\n    if (!Validator.isBoolean(String(value))) {\n      throw new sequelizeErrors.ValidationError(util.format('%j is not a valid boolean', value));\n    }\n    return true;\n  }\n  _sanitize(value) {\n    if (value !== null && value !== undefined) {\n      if (Buffer.isBuffer(value) && value.length === 1) {\n        // Bit fields are returned as buffers\n        value = value[0];\n      }\n      const type = typeof value;\n      if (type === 'string') {\n        // Only take action on valid boolean strings.\n        return value === 'true' ? true : value === 'false' ? false : value;\n      }\n      if (type === 'number') {\n        // Only take action on valid boolean integers.\n        return value === 1 ? true : value === 0 ? false : value;\n      }\n    }\n    return value;\n  }\n}\n\n\nBOOLEAN.parse = BOOLEAN.prototype._sanitize;\n\n/**\n * A time column\n *\n */\nclass TIME extends ABSTRACT {\n  toSql() {\n    return 'TIME';\n  }\n}\n\n/**\n * Date column with timezone, default is UTC\n */\nclass DATE extends ABSTRACT {\n  /**\n   * @param {string|number} [length] precision to allow storing milliseconds\n   */\n  constructor(length) {\n    super();\n    const options = typeof length === 'object' && length || { length };\n    this.options = options;\n    this._length = options.length || '';\n  }\n  toSql() {\n    return 'DATETIME';\n  }\n  validate(value) {\n    if (!Validator.isDate(String(value))) {\n      throw new sequelizeErrors.ValidationError(util.format('%j is not a valid date', value));\n    }\n    return true;\n  }\n  _sanitize(value, options) {\n    if ((!options || options && !options.raw) && !(value instanceof Date) && !!value) {\n      return new Date(value);\n    }\n    return value;\n  }\n  _isChanged(value, originalValue) {\n    if (originalValue && !!value &&\n      (value === originalValue ||\n        value instanceof Date && originalValue instanceof Date && value.getTime() === originalValue.getTime())) {\n      return false;\n    }\n    // not changed when set to same empty value\n    if (!originalValue && !value && originalValue === value) {\n      return false;\n    }\n    return true;\n  }\n  _applyTimezone(date, options) {\n    if (options.timezone) {\n      if (momentTz.tz.zone(options.timezone)) {\n        return momentTz(date).tz(options.timezone);\n      }\n      return date = moment(date).utcOffset(options.timezone);\n    }\n    return momentTz(date);\n  }\n  _stringify(date, options) {\n    date = this._applyTimezone(date, options);\n    // Z here means current timezone, _not_ UTC\n    return date.format('YYYY-MM-DD HH:mm:ss.SSS Z');\n  }\n}\n\n/**\n * A date only column (no timestamp)\n */\nclass DATEONLY extends ABSTRACT {\n  toSql() {\n    return 'DATE';\n  }\n  _stringify(date) {\n    return moment(date).format('YYYY-MM-DD');\n  }\n  _sanitize(value, options) {\n    if ((!options || options && !options.raw) && !!value) {\n      return moment(value).format('YYYY-MM-DD');\n    }\n    return value;\n  }\n  _isChanged(value, originalValue) {\n    if (originalValue && !!value && originalValue === value) {\n      return false;\n    }\n    // not changed when set to same empty value\n    if (!originalValue && !value && originalValue === value) {\n      return false;\n    }\n    return true;\n  }\n}\n\n/**\n * A key / value store column. Only available in Postgres.\n */\nclass HSTORE extends ABSTRACT {\n  validate(value) {\n    if (!_.isPlainObject(value)) {\n      throw new sequelizeErrors.ValidationError(util.format('%j is not a valid hstore', value));\n    }\n    return true;\n  }\n}\n\n/**\n * A JSON string column. Available in MySQL, Postgres and SQLite\n */\nclass JSONTYPE extends ABSTRACT {\n  validate() {\n    return true;\n  }\n  _stringify(value) {\n    return JSON.stringify(value);\n  }\n}\n\n/**\n * A binary storage JSON column. Only available in Postgres.\n */\nclass JSONB extends JSONTYPE {\n}\n\n/**\n * A default value of the current timestamp\n */\nclass NOW extends ABSTRACT {\n}\n\n/**\n * Binary storage\n */\nclass BLOB extends ABSTRACT {\n  /**\n   * @param {string} [length=''] could be tiny, medium, long.\n   */\n  constructor(length) {\n    super();\n    const options = typeof length === 'object' && length || { length };\n    this.options = options;\n    this._length = options.length || '';\n  }\n  toSql() {\n    switch (this._length.toLowerCase()) {\n      case 'tiny':\n        return 'TINYBLOB';\n      case 'medium':\n        return 'MEDIUMBLOB';\n      case 'long':\n        return 'LONGBLOB';\n      default:\n        return this.key;\n    }\n  }\n  validate(value) {\n    if (typeof value !== 'string' && !Buffer.isBuffer(value)) {\n      throw new sequelizeErrors.ValidationError(util.format('%j is not a valid blob', value));\n    }\n    return true;\n  }\n  _stringify(value) {\n    if (!Buffer.isBuffer(value)) {\n      if (Array.isArray(value)) {\n        value = Buffer.from(value);\n      }\n      else {\n        value = Buffer.from(value.toString());\n      }\n    }\n    const hex = value.toString('hex');\n    return this._hexify(hex);\n  }\n  _hexify(hex) {\n    return `X'${hex}'`;\n  }\n  _bindParam(value, options) {\n    if (!Buffer.isBuffer(value)) {\n      if (Array.isArray(value)) {\n        value = Buffer.from(value);\n      }\n      else {\n        value = Buffer.from(value.toString());\n      }\n    }\n    return options.bindParam(value);\n  }\n}\n\n\nBLOB.prototype.escape = false;\n\n/**\n * Range types are data types representing a range of values of some element type (called the range's subtype).\n * Only available in Postgres. See [the Postgres documentation](http://www.postgresql.org/docs/9.4/static/rangetypes.html) for more details\n */\nclass RANGE extends ABSTRACT {\n  /**\n   * @param {ABSTRACT} subtype A subtype for range, like RANGE(DATE)\n   */\n  constructor(subtype) {\n    super();\n    const options = _.isPlainObject(subtype) ? subtype : { subtype };\n    if (!options.subtype)\n      options.subtype = new INTEGER();\n    if (typeof options.subtype === 'function') {\n      options.subtype = new options.subtype();\n    }\n    this._subtype = options.subtype.key;\n    this.options = options;\n  }\n  validate(value) {\n    if (!Array.isArray(value)) {\n      throw new sequelizeErrors.ValidationError(util.format('%j is not a valid range', value));\n    }\n    if (value.length !== 2) {\n      throw new sequelizeErrors.ValidationError('A range must be an array with two elements');\n    }\n    return true;\n  }\n}\n\n/**\n * A column storing a unique universal identifier.\n * Use with `UUIDV1` or `UUIDV4` for default values.\n */\nclass UUID extends ABSTRACT {\n  validate(value, options) {\n    if (typeof value !== 'string' || !Validator.isUUID(value) && (!options || !options.acceptStrings)) {\n      throw new sequelizeErrors.ValidationError(util.format('%j is not a valid uuid', value));\n    }\n    return true;\n  }\n}\n\n/**\n * A default unique universal identifier generated following the UUID v1 standard\n */\nclass UUIDV1 extends ABSTRACT {\n  validate(value, options) {\n    if (typeof value !== 'string' || !Validator.isUUID(value) && (!options || !options.acceptStrings)) {\n      throw new sequelizeErrors.ValidationError(util.format('%j is not a valid uuid', value));\n    }\n    return true;\n  }\n}\n\n/**\n * A default unique universal identifier generated following the UUID v4 standard\n */\nclass UUIDV4 extends ABSTRACT {\n  validate(value, options) {\n    if (typeof value !== 'string' || !Validator.isUUID(value, 4) && (!options || !options.acceptStrings)) {\n      throw new sequelizeErrors.ValidationError(util.format('%j is not a valid uuidv4', value));\n    }\n    return true;\n  }\n}\n\n/**\n * A virtual value that is not stored in the DB. This could for example be useful if you want to provide a default value in your model that is returned to the user but not stored in the DB.\n *\n * You could also use it to validate a value before permuting and storing it. VIRTUAL also takes a return type and dependency fields as arguments\n * If a virtual attribute is present in `attributes` it will automatically pull in the extra fields as well.\n * Return type is mostly useful for setups that rely on types like GraphQL.\n *\n * @example <caption>Checking password length before hashing it</caption>\n * sequelize.define('user', {\n *   password_hash: DataTypes.STRING,\n *   password: {\n *     type: DataTypes.VIRTUAL,\n *     set: function (val) {\n *        // Remember to set the data value, otherwise it won't be validated\n *        this.setDataValue('password', val);\n *        this.setDataValue('password_hash', this.salt + val);\n *      },\n *      validate: {\n *         isLongEnough: function (val) {\n *           if (val.length < 7) {\n *             throw new Error(\"Please choose a longer password\")\n *          }\n *       }\n *     }\n *   }\n * })\n *\n * # In the above code the password is stored plainly in the password field so it can be validated, but is never stored in the DB.\n *\n * @example <caption>Virtual with dependency fields</caption>\n * {\n *   active: {\n *     type: new DataTypes.VIRTUAL(DataTypes.BOOLEAN, ['createdAt']),\n *     get: function() {\n *       return this.get('createdAt') > Date.now() - (7 * 24 * 60 * 60 * 1000)\n *     }\n *   }\n * }\n *\n */\nclass VIRTUAL extends ABSTRACT {\n  /**\n   * @param {ABSTRACT} [ReturnType] return type for virtual type\n   * @param {Array} [fields] array of fields this virtual type is dependent on\n   */\n  constructor(ReturnType, fields) {\n    super();\n    if (typeof ReturnType === 'function')\n      ReturnType = new ReturnType();\n    this.returnType = ReturnType;\n    this.fields = fields;\n  }\n}\n\n/**\n * An enumeration, Postgres Only\n *\n * @example\n * DataTypes.ENUM('value', 'another value')\n * DataTypes.ENUM(['value', 'another value'])\n * DataTypes.ENUM({\n *   values: ['value', 'another value']\n * })\n */\nclass ENUM extends ABSTRACT {\n  /**\n   * @param {...any|{ values: any[] }|any[]} args either array of values or options object with values array. It also supports variadic values\n   */\n  constructor(...args) {\n    super();\n    const value = args[0];\n    const options = typeof value === 'object' && !Array.isArray(value) && value || {\n      values: args.reduce((result, element) => {\n        return result.concat(Array.isArray(element) ? element : [element]);\n      }, [])\n    };\n    this.values = options.values;\n    this.options = options;\n  }\n  validate(value) {\n    if (!this.values.includes(value)) {\n      throw new sequelizeErrors.ValidationError(util.format('%j is not a valid choice in %j', value, this.values));\n    }\n    return true;\n  }\n}\n\n/**\n * An array of `type`. Only available in Postgres.\n *\n * @example\n * DataTypes.ARRAY(DataTypes.DECIMAL)\n */\nclass ARRAY extends ABSTRACT {\n  /**\n   * @param {ABSTRACT} type type of array values\n   */\n  constructor(type) {\n    super();\n    const options = _.isPlainObject(type) ? type : { type };\n    this.options = options;\n    this.type = typeof options.type === 'function' ? new options.type() : options.type;\n  }\n  toSql() {\n    return `${this.type.toSql()}[]`;\n  }\n  validate(value) {\n    if (!Array.isArray(value)) {\n      throw new sequelizeErrors.ValidationError(util.format('%j is not a valid array', value));\n    }\n    return true;\n  }\n  static is(obj, type) {\n    return obj instanceof ARRAY && obj.type instanceof type;\n  }\n}\n\n/**\n * The cidr type holds an IPv4 or IPv6 network specification. Takes 7 or 19 bytes.\n *\n * Only available for Postgres\n */\nclass CIDR extends ABSTRACT {\n  validate(value) {\n    if (typeof value !== 'string' || !Validator.isIPRange(value)) {\n      throw new sequelizeErrors.ValidationError(util.format('%j is not a valid CIDR', value));\n    }\n    return true;\n  }\n}\n\n/**\n * The INET type holds an IPv4 or IPv6 host address, and optionally its subnet. Takes 7 or 19 bytes\n *\n * Only available for Postgres\n */\nclass INET extends ABSTRACT {\n  validate(value) {\n    if (typeof value !== 'string' || !Validator.isIP(value)) {\n      throw new sequelizeErrors.ValidationError(util.format('%j is not a valid INET', value));\n    }\n    return true;\n  }\n}\n\n/**\n * The MACADDR type stores MAC addresses. Takes 6 bytes\n *\n * Only available for Postgres\n *\n */\nclass MACADDR extends ABSTRACT {\n  validate(value) {\n    if (typeof value !== 'string' || !Validator.isMACAddress(value)) {\n      throw new sequelizeErrors.ValidationError(util.format('%j is not a valid MACADDR', value));\n    }\n    return true;\n  }\n}\n\n/**\n * A convenience class holding commonly used data types. The data types are used when defining a new model using `Sequelize.define`, like this:\n * ```js\n * sequelize.define('model', {\n *   column: DataTypes.INTEGER\n * })\n * ```\n * When defining a model you can just as easily pass a string as type, but often using the types defined here is beneficial. For example, using `DataTypes.BLOB`, mean\n * that that column will be returned as an instance of `Buffer` when being fetched by sequelize.\n *\n * To provide a length for the data type, you can invoke it like a function: `INTEGER(2)`\n *\n * Some data types have special properties that can be accessed in order to change the data type.\n * For example, to get an unsigned integer with zerofill you can do `DataTypes.INTEGER.UNSIGNED.ZEROFILL`.\n * The order you access the properties in do not matter, so `DataTypes.INTEGER.ZEROFILL.UNSIGNED` is fine as well.\n *\n * * All number types (`INTEGER`, `BIGINT`, `FLOAT`, `DOUBLE`, `REAL`, `DECIMAL`) expose the properties `UNSIGNED` and `ZEROFILL`\n * * The `CHAR` and `STRING` types expose the `BINARY` property\n *\n * Three of the values provided here (`NOW`, `UUIDV1` and `UUIDV4`) are special default values, that should not be used to define types. Instead they are used as shorthands for\n * defining default values. For example, to get a uuid field with a default value generated following v1 of the UUID standard:\n * ```js\n * sequelize.define('model', {\n *   uuid: {\n *     type: DataTypes.UUID,\n *     defaultValue: DataTypes.UUIDV1,\n *     primaryKey: true\n *   }\n * })\n * ```\n * There may be times when you want to generate your own UUID conforming to some other algorithm. This is accomplished\n * using the defaultValue property as well, but instead of specifying one of the supplied UUID types, you return a value\n * from a function.\n * ```js\n * sequelize.define('model', {\n *   uuid: {\n *     type: DataTypes.UUID,\n *     defaultValue: function() {\n *       return generateMyId()\n *     },\n *     primaryKey: true\n *   }\n * })\n * ```\n */\nconst DataTypes = module.exports = {\n  ABSTRACT,\n  STRING,\n  CHAR,\n  TEXT,\n  NUMBER,\n  TINYINT,\n  SMALLINT,\n  MEDIUMINT,\n  INTEGER,\n  BIGINT,\n  FLOAT,\n  TIME,\n  DATE,\n  DATEONLY,\n  BOOLEAN,\n  NOW,\n  BLOB,\n  DECIMAL,\n  NUMERIC: DECIMAL,\n  UUID,\n  UUIDV1,\n  UUIDV4,\n  HSTORE,\n  JSON: JSONTYPE,\n  JSONB,\n  VIRTUAL,\n  ARRAY,\n  ENUM,\n  RANGE,\n  REAL,\n  'DOUBLE PRECISION': DOUBLE,\n  DOUBLE,\n  CIDR,\n  INET,\n  MACADDR,\n  CITEXT\n};\n\n_.each(DataTypes, (dataType, name) => {\n  // guard for aliases\n  if (!Object.prototype.hasOwnProperty.call(dataType, 'key')) {\n    dataType.types = {};\n    dataType.key = dataType.prototype.key = name;\n  }\n});\n\nconst dialectMap = {};\n/* dialectMap.postgres = require('./dialects/postgres/data-types')(DataTypes);\ndialectMap.mysql = require('./dialects/mysql/data-types')(DataTypes);\ndialectMap.mariadb = require('./dialects/mariadb/data-types')(DataTypes); */\ndialectMap.sqlite = require('./dialects/sqlite/data-types')(DataTypes);\n/* dialectMap.mssql = require('./dialects/mssql/data-types')(DataTypes); */\n\nconst dialectList = _.values(dialectMap);\n\nfor (const dataTypes of dialectList) {\n  _.each(dataTypes, (DataType, key) => {\n    if (!DataType.key) {\n      DataType.key = DataType.prototype.key = key;\n    }\n  });\n}\n\n// Wrap all data types to not require `new`\nfor (const dataTypes of [DataTypes, ...dialectList]) {\n  _.each(dataTypes, (DataType, key) => {\n    dataTypes[key] = classToInvokable(DataType);\n  });\n}\n\nObject.assign(DataTypes, dialectMap);\n"]} \ No newline at end of file diff --git a/dist/deferrable.js b/dist/deferrable.js index 05a4650..c0db00a 100644 --- a/dist/deferrable.js +++ b/dist/deferrable.js @@ -1,14 +1,18 @@ 'use strict'; +function _inherits(subClass, superClass) { if (typeof superClass !== "function" && superClass !== null) { throw new TypeError("Super expression must either be null or a function"); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, writable: true, configurable: true } }); if (superClass) _setPrototypeOf(subClass, superClass); } + +function _setPrototypeOf(o, p) { _setPrototypeOf = Object.setPrototypeOf || function _setPrototypeOf(o, p) { o.__proto__ = p; return o; }; return _setPrototypeOf(o, p); } + +function _createSuper(Derived) { var hasNativeReflectConstruct = _isNativeReflectConstruct(); return function _createSuperInternal() { var Super = _getPrototypeOf(Derived), result; if (hasNativeReflectConstruct) { var NewTarget = _getPrototypeOf(this).constructor; result = Reflect.construct(Super, arguments, NewTarget); } else { result = Super.apply(this, arguments); } return _possibleConstructorReturn(this, result); }; } + function _possibleConstructorReturn(self, call) { if (call && (typeof call === "object" || typeof call === "function")) { return call; } return _assertThisInitialized(self); } function _assertThisInitialized(self) { if (self === void 0) { throw new ReferenceError("this hasn't been initialised - super() hasn't been called"); } return self; } -function _getPrototypeOf(o) { _getPrototypeOf = Object.setPrototypeOf ? Object.getPrototypeOf : function _getPrototypeOf(o) { return o.__proto__ || Object.getPrototypeOf(o); }; return _getPrototypeOf(o); } - -function _inherits(subClass, superClass) { if (typeof superClass !== "function" && superClass !== null) { throw new TypeError("Super expression must either be null or a function"); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, writable: true, configurable: true } }); if (superClass) _setPrototypeOf(subClass, superClass); } +function _isNativeReflectConstruct() { if (typeof Reflect === "undefined" || !Reflect.construct) return false; if (Reflect.construct.sham) return false; if (typeof Proxy === "function") return true; try { Date.prototype.toString.call(Reflect.construct(Date, [], function () {})); return true; } catch (e) { return false; } } -function _setPrototypeOf(o, p) { _setPrototypeOf = Object.setPrototypeOf || function _setPrototypeOf(o, p) { o.__proto__ = p; return o; }; return _setPrototypeOf(o, p); } +function _getPrototypeOf(o) { _getPrototypeOf = Object.setPrototypeOf ? Object.getPrototypeOf : function _getPrototypeOf(o) { return o.__proto__ || Object.getPrototypeOf(o); }; return _getPrototypeOf(o); } function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } } @@ -20,9 +24,7 @@ const { classToInvokable } = require('./utils'); -let ABSTRACT = -/*#__PURE__*/ -function () { +let ABSTRACT = /*#__PURE__*/function () { function ABSTRACT() { _classCallCheck(this, ABSTRACT); } @@ -47,15 +49,15 @@ function () { return ABSTRACT; }(); -let INITIALLY_DEFERRED = -/*#__PURE__*/ -function (_ABSTRACT) { +let INITIALLY_DEFERRED = /*#__PURE__*/function (_ABSTRACT) { _inherits(INITIALLY_DEFERRED, _ABSTRACT); + var _super = _createSuper(INITIALLY_DEFERRED); + function INITIALLY_DEFERRED() { _classCallCheck(this, INITIALLY_DEFERRED); - return _possibleConstructorReturn(this, _getPrototypeOf(INITIALLY_DEFERRED).apply(this, arguments)); + return _super.apply(this, arguments); } _createClass(INITIALLY_DEFERRED, [{ @@ -68,15 +70,15 @@ function (_ABSTRACT) { return INITIALLY_DEFERRED; }(ABSTRACT); -let INITIALLY_IMMEDIATE = -/*#__PURE__*/ -function (_ABSTRACT2) { +let INITIALLY_IMMEDIATE = /*#__PURE__*/function (_ABSTRACT2) { _inherits(INITIALLY_IMMEDIATE, _ABSTRACT2); + var _super2 = _createSuper(INITIALLY_IMMEDIATE); + function INITIALLY_IMMEDIATE() { _classCallCheck(this, INITIALLY_IMMEDIATE); - return _possibleConstructorReturn(this, _getPrototypeOf(INITIALLY_IMMEDIATE).apply(this, arguments)); + return _super2.apply(this, arguments); } _createClass(INITIALLY_IMMEDIATE, [{ @@ -89,15 +91,15 @@ function (_ABSTRACT2) { return INITIALLY_IMMEDIATE; }(ABSTRACT); -let NOT = -/*#__PURE__*/ -function (_ABSTRACT3) { +let NOT = /*#__PURE__*/function (_ABSTRACT3) { _inherits(NOT, _ABSTRACT3); + var _super3 = _createSuper(NOT); + function NOT() { _classCallCheck(this, NOT); - return _possibleConstructorReturn(this, _getPrototypeOf(NOT).apply(this, arguments)); + return _super3.apply(this, arguments); } _createClass(NOT, [{ @@ -110,17 +112,17 @@ function (_ABSTRACT3) { return NOT; }(ABSTRACT); -let SET_DEFERRED = -/*#__PURE__*/ -function (_ABSTRACT4) { +let SET_DEFERRED = /*#__PURE__*/function (_ABSTRACT4) { _inherits(SET_DEFERRED, _ABSTRACT4); + var _super4 = _createSuper(SET_DEFERRED); + function SET_DEFERRED(constraints) { var _this; _classCallCheck(this, SET_DEFERRED); - _this = _possibleConstructorReturn(this, _getPrototypeOf(SET_DEFERRED).call(this)); + _this = _super4.call(this); _this.constraints = constraints; return _this; } @@ -135,17 +137,17 @@ function (_ABSTRACT4) { return SET_DEFERRED; }(ABSTRACT); -let SET_IMMEDIATE = -/*#__PURE__*/ -function (_ABSTRACT5) { +let SET_IMMEDIATE = /*#__PURE__*/function (_ABSTRACT5) { _inherits(SET_IMMEDIATE, _ABSTRACT5); + var _super5 = _createSuper(SET_IMMEDIATE); + function SET_IMMEDIATE(constraints) { var _this2; _classCallCheck(this, SET_IMMEDIATE); - _this2 = _possibleConstructorReturn(this, _getPrototypeOf(SET_IMMEDIATE).call(this)); + _this2 = _super5.call(this); _this2.constraints = constraints; return _this2; } @@ -206,4 +208,4 @@ const Deferrable = module.exports = { SET_DEFERRED: classToInvokable(SET_DEFERRED), SET_IMMEDIATE: classToInvokable(SET_IMMEDIATE) }; -//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uL2xpYi9kZWZlcnJhYmxlLmpzIl0sIm5hbWVzIjpbImNsYXNzVG9JbnZva2FibGUiLCJyZXF1aXJlIiwiQUJTVFJBQ1QiLCJhcmdzIiwidG9TcWwiLCJFcnJvciIsInRvU3RyaW5nIiwiSU5JVElBTExZX0RFRkVSUkVEIiwiSU5JVElBTExZX0lNTUVESUFURSIsIk5PVCIsIlNFVF9ERUZFUlJFRCIsImNvbnN0cmFpbnRzIiwicXVlcnlHZW5lcmF0b3IiLCJzZXREZWZlcnJlZFF1ZXJ5IiwiU0VUX0lNTUVESUFURSIsInNldEltbWVkaWF0ZVF1ZXJ5IiwiRGVmZXJyYWJsZSIsIm1vZHVsZSIsImV4cG9ydHMiXSwibWFwcGluZ3MiOiJBQUFBOzs7Ozs7Ozs7Ozs7Ozs7Ozs7QUFFQSxNQUFNO0FBQUVBLEVBQUFBO0FBQUYsSUFBdUJDLE9BQU8sQ0FBQyxTQUFELENBQXBDOztJQUVNQyxROzs7Ozs7Ozs7NkJBS0ssR0FBR0MsSSxFQUFNO0FBQ2hCLGFBQU8sS0FBS0MsS0FBTCxDQUFXLEdBQUdELElBQWQsQ0FBUDtBQUNEOzs7NEJBRU87QUFDTixZQUFNLElBQUlFLEtBQUosQ0FBVSw4QkFBVixDQUFOO0FBQ0Q7Ozs2QkFWZSxHQUFHRixJLEVBQU07QUFDdkIsYUFBTyxJQUFJLElBQUosR0FBV0csUUFBWCxDQUFvQixHQUFHSCxJQUF2QixDQUFQO0FBQ0Q7Ozs7OztJQVdHSSxrQjs7Ozs7Ozs7Ozs7Ozs0QkFDSTtBQUNOLGFBQU8sK0JBQVA7QUFDRDs7OztFQUg4QkwsUTs7SUFNM0JNLG1COzs7Ozs7Ozs7Ozs7OzRCQUNJO0FBQ04sYUFBTyxnQ0FBUDtBQUNEOzs7O0VBSCtCTixROztJQU01Qk8sRzs7Ozs7Ozs7Ozs7Ozs0QkFDSTtBQUNOLGFBQU8sZ0JBQVA7QUFDRDs7OztFQUhlUCxROztJQU1aUSxZOzs7OztBQUNKLHdCQUFZQyxXQUFaLEVBQXlCO0FBQUE7O0FBQUE7O0FBQ3ZCO0FBQ0EsVUFBS0EsV0FBTCxHQUFtQkEsV0FBbkI7QUFGdUI7QUFHeEI7Ozs7MEJBRUtDLGMsRUFBZ0I7QUFDcEIsYUFBT0EsY0FBYyxDQUFDQyxnQkFBZixDQUFnQyxLQUFLRixXQUFyQyxDQUFQO0FBQ0Q7Ozs7RUFSd0JULFE7O0lBV3JCWSxhOzs7OztBQUNKLHlCQUFZSCxXQUFaLEVBQXlCO0FBQUE7O0FBQUE7O0FBQ3ZCO0FBQ0EsV0FBS0EsV0FBTCxHQUFtQkEsV0FBbkI7QUFGdUI7QUFHeEI7Ozs7MEJBRUtDLGMsRUFBZ0I7QUFDcEIsYUFBT0EsY0FBYyxDQUFDRyxpQkFBZixDQUFpQyxLQUFLSixXQUF0QyxDQUFQO0FBQ0Q7Ozs7RUFSeUJULFE7QUFXNUI7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7OztBQXNDQSxNQUFNYyxVQUFVLEdBQUdDLE1BQU0sQ0FBQ0MsT0FBUCxHQUFpQjtBQUFFO0FBQ3BDWCxFQUFBQSxrQkFBa0IsRUFBRVAsZ0JBQWdCLENBQUNPLGtCQUFELENBREY7QUFFbENDLEVBQUFBLG1CQUFtQixFQUFFUixnQkFBZ0IsQ0FBQ1EsbUJBQUQsQ0FGSDtBQUdsQ0MsRUFBQUEsR0FBRyxFQUFFVCxnQkFBZ0IsQ0FBQ1MsR0FBRCxDQUhhO0FBSWxDQyxFQUFBQSxZQUFZLEVBQUVWLGdCQUFnQixDQUFDVSxZQUFELENBSkk7QUFLbENJLEVBQUFBLGFBQWEsRUFBRWQsZ0JBQWdCLENBQUNjLGFBQUQ7QUFMRyxDQUFwQyIsInNvdXJjZXNDb250ZW50IjpbIid1c2Ugc3RyaWN0JztcclxuXHJcbmNvbnN0IHsgY2xhc3NUb0ludm9rYWJsZSB9ID0gcmVxdWlyZSgnLi91dGlscycpO1xyXG5cclxuY2xhc3MgQUJTVFJBQ1Qge1xyXG4gIHN0YXRpYyB0b1N0cmluZyguLi5hcmdzKSB7XHJcbiAgICByZXR1cm4gbmV3IHRoaXMoKS50b1N0cmluZyguLi5hcmdzKTtcclxuICB9XHJcblxyXG4gIHRvU3RyaW5nKC4uLmFyZ3MpIHtcclxuICAgIHJldHVybiB0aGlzLnRvU3FsKC4uLmFyZ3MpO1xyXG4gIH1cclxuXHJcbiAgdG9TcWwoKSB7XHJcbiAgICB0aHJvdyBuZXcgRXJyb3IoJ3RvU3FsIGltcGxlbWVudGF0aW9uIG1pc3NpbmcnKTtcclxuICB9XHJcbn1cclxuXHJcbmNsYXNzIElOSVRJQUxMWV9ERUZFUlJFRCBleHRlbmRzIEFCU1RSQUNUIHtcclxuICB0b1NxbCgpIHtcclxuICAgIHJldHVybiAnREVGRVJSQUJMRSBJTklUSUFMTFkgREVGRVJSRUQnO1xyXG4gIH1cclxufVxyXG5cclxuY2xhc3MgSU5JVElBTExZX0lNTUVESUFURSBleHRlbmRzIEFCU1RSQUNUIHtcclxuICB0b1NxbCgpIHtcclxuICAgIHJldHVybiAnREVGRVJSQUJMRSBJTklUSUFMTFkgSU1NRURJQVRFJztcclxuICB9XHJcbn1cclxuXHJcbmNsYXNzIE5PVCBleHRlbmRzIEFCU1RSQUNUIHtcclxuICB0b1NxbCgpIHtcclxuICAgIHJldHVybiAnTk9UIERFRkVSUkFCTEUnO1xyXG4gIH1cclxufVxyXG5cclxuY2xhc3MgU0VUX0RFRkVSUkVEIGV4dGVuZHMgQUJTVFJBQ1Qge1xyXG4gIGNvbnN0cnVjdG9yKGNvbnN0cmFpbnRzKSB7XHJcbiAgICBzdXBlcigpO1xyXG4gICAgdGhpcy5jb25zdHJhaW50cyA9IGNvbnN0cmFpbnRzO1xyXG4gIH1cclxuXHJcbiAgdG9TcWwocXVlcnlHZW5lcmF0b3IpIHtcclxuICAgIHJldHVybiBxdWVyeUdlbmVyYXRvci5zZXREZWZlcnJlZFF1ZXJ5KHRoaXMuY29uc3RyYWludHMpO1xyXG4gIH1cclxufVxyXG5cclxuY2xhc3MgU0VUX0lNTUVESUFURSBleHRlbmRzIEFCU1RSQUNUIHtcclxuICBjb25zdHJ1Y3Rvcihjb25zdHJhaW50cykge1xyXG4gICAgc3VwZXIoKTtcclxuICAgIHRoaXMuY29uc3RyYWludHMgPSBjb25zdHJhaW50cztcclxuICB9XHJcblxyXG4gIHRvU3FsKHF1ZXJ5R2VuZXJhdG9yKSB7XHJcbiAgICByZXR1cm4gcXVlcnlHZW5lcmF0b3Iuc2V0SW1tZWRpYXRlUXVlcnkodGhpcy5jb25zdHJhaW50cyk7XHJcbiAgfVxyXG59XHJcblxyXG4vKipcclxuICogQSBjb2xsZWN0aW9uIG9mIHByb3BlcnRpZXMgcmVsYXRlZCB0byBkZWZlcnJhYmxlIGNvbnN0cmFpbnRzLiBJdCBjYW4gYmUgdXNlZCB0b1xyXG4gKiBtYWtlIGZvcmVpZ24ga2V5IGNvbnN0cmFpbnRzIGRlZmVycmFibGUgYW5kIHRvIHNldCB0aGUgY29uc3RyYWludHMgd2l0aGluIGFcclxuICogdHJhbnNhY3Rpb24uIFRoaXMgaXMgb25seSBzdXBwb3J0ZWQgaW4gUG9zdGdyZVNRTC5cclxuICpcclxuICogVGhlIGZvcmVpZ24ga2V5cyBjYW4gYmUgY29uZmlndXJlZCBsaWtlIHRoaXMuIEl0IHdpbGwgY3JlYXRlIGEgZm9yZWlnbiBrZXlcclxuICogdGhhdCB3aWxsIGNoZWNrIHRoZSBjb25zdHJhaW50cyBpbW1lZGlhdGVseSB3aGVuIHRoZSBkYXRhIHdhcyBpbnNlcnRlZC5cclxuICpcclxuICogYGBganNcclxuICogc2VxdWVsaXplLmRlZmluZSgnTW9kZWwnLCB7XHJcbiAqICAgZm9yZWlnbl9pZDoge1xyXG4gKiAgICAgdHlwZTogU2VxdWVsaXplLklOVEVHRVIsXHJcbiAqICAgICByZWZlcmVuY2VzOiB7XHJcbiAqICAgICAgIG1vZGVsOiBPdGhlck1vZGVsLFxyXG4gKiAgICAgICBrZXk6ICdpZCcsXHJcbiAqICAgICAgIGRlZmVycmFibGU6IFNlcXVlbGl6ZS5EZWZlcnJhYmxlLklOSVRJQUxMWV9JTU1FRElBVEVcclxuICogICAgIH1cclxuICogICB9XHJcbiAqIH0pO1xyXG4gKiBgYGBcclxuICpcclxuICogVGhlIGNvbnN0cmFpbnRzIGNhbiBiZSBjb25maWd1cmVkIGluIGEgdHJhbnNhY3Rpb24gbGlrZSB0aGlzLiBJdCB3aWxsXHJcbiAqIHRyaWdnZXIgYSBxdWVyeSBvbmNlIHRoZSB0cmFuc2FjdGlvbiBoYXMgYmVlbiBzdGFydGVkIGFuZCBzZXQgdGhlIGNvbnN0cmFpbnRzXHJcbiAqIHRvIGJlIGNoZWNrZWQgYXQgdGhlIHZlcnkgZW5kIG9mIHRoZSB0cmFuc2FjdGlvbi5cclxuICpcclxuICogYGBganNcclxuICogc2VxdWVsaXplLnRyYW5zYWN0aW9uKHtcclxuICogICBkZWZlcnJhYmxlOiBTZXF1ZWxpemUuRGVmZXJyYWJsZS5TRVRfREVGRVJSRURcclxuICogfSk7XHJcbiAqIGBgYFxyXG4gKlxyXG4gKiBAcHJvcGVydHkgSU5JVElBTExZX0RFRkVSUkVEIERlZmVyIGNvbnN0cmFpbnRzIGNoZWNrcyB0byB0aGUgZW5kIG9mIHRyYW5zYWN0aW9ucy5cclxuICogQHByb3BlcnR5IElOSVRJQUxMWV9JTU1FRElBVEUgVHJpZ2dlciB0aGUgY29uc3RyYWludCBjaGVja3MgaW1tZWRpYXRlbHlcclxuICogQHByb3BlcnR5IE5PVCBTZXQgdGhlIGNvbnN0cmFpbnRzIHRvIG5vdCBkZWZlcnJlZC4gVGhpcyBpcyB0aGUgZGVmYXVsdCBpbiBQb3N0Z3JlU1FMIGFuZCBpdCBtYWtlIGl0IGltcG9zc2libGUgdG8gZHluYW1pY2FsbHkgZGVmZXIgdGhlIGNvbnN0cmFpbnRzIHdpdGhpbiBhIHRyYW5zYWN0aW9uLlxyXG4gKiBAcHJvcGVydHkgU0VUX0RFRkVSUkVEXHJcbiAqIEBwcm9wZXJ0eSBTRVRfSU1NRURJQVRFXHJcbiAqL1xyXG5cclxuY29uc3QgRGVmZXJyYWJsZSA9IG1vZHVsZS5leHBvcnRzID0geyAvLyBlc2xpbnQtZGlzYWJsZS1saW5lXHJcbiAgSU5JVElBTExZX0RFRkVSUkVEOiBjbGFzc1RvSW52b2thYmxlKElOSVRJQUxMWV9ERUZFUlJFRCksXHJcbiAgSU5JVElBTExZX0lNTUVESUFURTogY2xhc3NUb0ludm9rYWJsZShJTklUSUFMTFlfSU1NRURJQVRFKSxcclxuICBOT1Q6IGNsYXNzVG9JbnZva2FibGUoTk9UKSxcclxuICBTRVRfREVGRVJSRUQ6IGNsYXNzVG9JbnZva2FibGUoU0VUX0RFRkVSUkVEKSxcclxuICBTRVRfSU1NRURJQVRFOiBjbGFzc1RvSW52b2thYmxlKFNFVF9JTU1FRElBVEUpXHJcbn07XHJcbiJdfQ== \ No newline at end of file +//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uL2xpYi9kZWZlcnJhYmxlLmpzIl0sIm5hbWVzIjpbImNsYXNzVG9JbnZva2FibGUiLCJyZXF1aXJlIiwiQUJTVFJBQ1QiLCJhcmdzIiwidG9TcWwiLCJFcnJvciIsInRvU3RyaW5nIiwiSU5JVElBTExZX0RFRkVSUkVEIiwiSU5JVElBTExZX0lNTUVESUFURSIsIk5PVCIsIlNFVF9ERUZFUlJFRCIsImNvbnN0cmFpbnRzIiwicXVlcnlHZW5lcmF0b3IiLCJzZXREZWZlcnJlZFF1ZXJ5IiwiU0VUX0lNTUVESUFURSIsInNldEltbWVkaWF0ZVF1ZXJ5IiwiRGVmZXJyYWJsZSIsIm1vZHVsZSIsImV4cG9ydHMiXSwibWFwcGluZ3MiOiJBQUFBOzs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7O0FBRUEsTUFBTTtBQUFFQSxFQUFBQTtBQUFGLElBQXVCQyxPQUFPLENBQUMsU0FBRCxDQUFwQzs7SUFFTUMsUTs7Ozs7Ozs2QkFLSyxHQUFHQyxJLEVBQU07QUFDaEIsYUFBTyxLQUFLQyxLQUFMLENBQVcsR0FBR0QsSUFBZCxDQUFQO0FBQ0Q7Ozs0QkFFTztBQUNOLFlBQU0sSUFBSUUsS0FBSixDQUFVLDhCQUFWLENBQU47QUFDRDs7OzZCQVZlLEdBQUdGLEksRUFBTTtBQUN2QixhQUFPLElBQUksSUFBSixHQUFXRyxRQUFYLENBQW9CLEdBQUdILElBQXZCLENBQVA7QUFDRDs7Ozs7O0lBV0dJLGtCOzs7Ozs7Ozs7Ozs7OzRCQUNJO0FBQ04sYUFBTywrQkFBUDtBQUNEOzs7O0VBSDhCTCxROztJQU0zQk0sbUI7Ozs7Ozs7Ozs7Ozs7NEJBQ0k7QUFDTixhQUFPLGdDQUFQO0FBQ0Q7Ozs7RUFIK0JOLFE7O0lBTTVCTyxHOzs7Ozs7Ozs7Ozs7OzRCQUNJO0FBQ04sYUFBTyxnQkFBUDtBQUNEOzs7O0VBSGVQLFE7O0lBTVpRLFk7Ozs7O0FBQ0osd0JBQVlDLFdBQVosRUFBeUI7QUFBQTs7QUFBQTs7QUFDdkI7QUFDQSxVQUFLQSxXQUFMLEdBQW1CQSxXQUFuQjtBQUZ1QjtBQUd4Qjs7OzswQkFFS0MsYyxFQUFnQjtBQUNwQixhQUFPQSxjQUFjLENBQUNDLGdCQUFmLENBQWdDLEtBQUtGLFdBQXJDLENBQVA7QUFDRDs7OztFQVJ3QlQsUTs7SUFXckJZLGE7Ozs7O0FBQ0oseUJBQVlILFdBQVosRUFBeUI7QUFBQTs7QUFBQTs7QUFDdkI7QUFDQSxXQUFLQSxXQUFMLEdBQW1CQSxXQUFuQjtBQUZ1QjtBQUd4Qjs7OzswQkFFS0MsYyxFQUFnQjtBQUNwQixhQUFPQSxjQUFjLENBQUNHLGlCQUFmLENBQWlDLEtBQUtKLFdBQXRDLENBQVA7QUFDRDs7OztFQVJ5QlQsUTtBQVc1QjtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7O0FBRUEsTUFBTWMsVUFBVSxHQUFHQyxNQUFNLENBQUNDLE9BQVAsR0FBaUI7QUFBRTtBQUNwQ1gsRUFBQUEsa0JBQWtCLEVBQUVQLGdCQUFnQixDQUFDTyxrQkFBRCxDQURGO0FBRWxDQyxFQUFBQSxtQkFBbUIsRUFBRVIsZ0JBQWdCLENBQUNRLG1CQUFELENBRkg7QUFHbENDLEVBQUFBLEdBQUcsRUFBRVQsZ0JBQWdCLENBQUNTLEdBQUQsQ0FIYTtBQUlsQ0MsRUFBQUEsWUFBWSxFQUFFVixnQkFBZ0IsQ0FBQ1UsWUFBRCxDQUpJO0FBS2xDSSxFQUFBQSxhQUFhLEVBQUVkLGdCQUFnQixDQUFDYyxhQUFEO0FBTEcsQ0FBcEMiLCJzb3VyY2VzQ29udGVudCI6WyIndXNlIHN0cmljdCc7XG5cbmNvbnN0IHsgY2xhc3NUb0ludm9rYWJsZSB9ID0gcmVxdWlyZSgnLi91dGlscycpO1xuXG5jbGFzcyBBQlNUUkFDVCB7XG4gIHN0YXRpYyB0b1N0cmluZyguLi5hcmdzKSB7XG4gICAgcmV0dXJuIG5ldyB0aGlzKCkudG9TdHJpbmcoLi4uYXJncyk7XG4gIH1cblxuICB0b1N0cmluZyguLi5hcmdzKSB7XG4gICAgcmV0dXJuIHRoaXMudG9TcWwoLi4uYXJncyk7XG4gIH1cblxuICB0b1NxbCgpIHtcbiAgICB0aHJvdyBuZXcgRXJyb3IoJ3RvU3FsIGltcGxlbWVudGF0aW9uIG1pc3NpbmcnKTtcbiAgfVxufVxuXG5jbGFzcyBJTklUSUFMTFlfREVGRVJSRUQgZXh0ZW5kcyBBQlNUUkFDVCB7XG4gIHRvU3FsKCkge1xuICAgIHJldHVybiAnREVGRVJSQUJMRSBJTklUSUFMTFkgREVGRVJSRUQnO1xuICB9XG59XG5cbmNsYXNzIElOSVRJQUxMWV9JTU1FRElBVEUgZXh0ZW5kcyBBQlNUUkFDVCB7XG4gIHRvU3FsKCkge1xuICAgIHJldHVybiAnREVGRVJSQUJMRSBJTklUSUFMTFkgSU1NRURJQVRFJztcbiAgfVxufVxuXG5jbGFzcyBOT1QgZXh0ZW5kcyBBQlNUUkFDVCB7XG4gIHRvU3FsKCkge1xuICAgIHJldHVybiAnTk9UIERFRkVSUkFCTEUnO1xuICB9XG59XG5cbmNsYXNzIFNFVF9ERUZFUlJFRCBleHRlbmRzIEFCU1RSQUNUIHtcbiAgY29uc3RydWN0b3IoY29uc3RyYWludHMpIHtcbiAgICBzdXBlcigpO1xuICAgIHRoaXMuY29uc3RyYWludHMgPSBjb25zdHJhaW50cztcbiAgfVxuXG4gIHRvU3FsKHF1ZXJ5R2VuZXJhdG9yKSB7XG4gICAgcmV0dXJuIHF1ZXJ5R2VuZXJhdG9yLnNldERlZmVycmVkUXVlcnkodGhpcy5jb25zdHJhaW50cyk7XG4gIH1cbn1cblxuY2xhc3MgU0VUX0lNTUVESUFURSBleHRlbmRzIEFCU1RSQUNUIHtcbiAgY29uc3RydWN0b3IoY29uc3RyYWludHMpIHtcbiAgICBzdXBlcigpO1xuICAgIHRoaXMuY29uc3RyYWludHMgPSBjb25zdHJhaW50cztcbiAgfVxuXG4gIHRvU3FsKHF1ZXJ5R2VuZXJhdG9yKSB7XG4gICAgcmV0dXJuIHF1ZXJ5R2VuZXJhdG9yLnNldEltbWVkaWF0ZVF1ZXJ5KHRoaXMuY29uc3RyYWludHMpO1xuICB9XG59XG5cbi8qKlxuICogQSBjb2xsZWN0aW9uIG9mIHByb3BlcnRpZXMgcmVsYXRlZCB0byBkZWZlcnJhYmxlIGNvbnN0cmFpbnRzLiBJdCBjYW4gYmUgdXNlZCB0b1xuICogbWFrZSBmb3JlaWduIGtleSBjb25zdHJhaW50cyBkZWZlcnJhYmxlIGFuZCB0byBzZXQgdGhlIGNvbnN0cmFpbnRzIHdpdGhpbiBhXG4gKiB0cmFuc2FjdGlvbi4gVGhpcyBpcyBvbmx5IHN1cHBvcnRlZCBpbiBQb3N0Z3JlU1FMLlxuICpcbiAqIFRoZSBmb3JlaWduIGtleXMgY2FuIGJlIGNvbmZpZ3VyZWQgbGlrZSB0aGlzLiBJdCB3aWxsIGNyZWF0ZSBhIGZvcmVpZ24ga2V5XG4gKiB0aGF0IHdpbGwgY2hlY2sgdGhlIGNvbnN0cmFpbnRzIGltbWVkaWF0ZWx5IHdoZW4gdGhlIGRhdGEgd2FzIGluc2VydGVkLlxuICpcbiAqIGBgYGpzXG4gKiBzZXF1ZWxpemUuZGVmaW5lKCdNb2RlbCcsIHtcbiAqICAgZm9yZWlnbl9pZDoge1xuICogICAgIHR5cGU6IFNlcXVlbGl6ZS5JTlRFR0VSLFxuICogICAgIHJlZmVyZW5jZXM6IHtcbiAqICAgICAgIG1vZGVsOiBPdGhlck1vZGVsLFxuICogICAgICAga2V5OiAnaWQnLFxuICogICAgICAgZGVmZXJyYWJsZTogU2VxdWVsaXplLkRlZmVycmFibGUuSU5JVElBTExZX0lNTUVESUFURVxuICogICAgIH1cbiAqICAgfVxuICogfSk7XG4gKiBgYGBcbiAqXG4gKiBUaGUgY29uc3RyYWludHMgY2FuIGJlIGNvbmZpZ3VyZWQgaW4gYSB0cmFuc2FjdGlvbiBsaWtlIHRoaXMuIEl0IHdpbGxcbiAqIHRyaWdnZXIgYSBxdWVyeSBvbmNlIHRoZSB0cmFuc2FjdGlvbiBoYXMgYmVlbiBzdGFydGVkIGFuZCBzZXQgdGhlIGNvbnN0cmFpbnRzXG4gKiB0byBiZSBjaGVja2VkIGF0IHRoZSB2ZXJ5IGVuZCBvZiB0aGUgdHJhbnNhY3Rpb24uXG4gKlxuICogYGBganNcbiAqIHNlcXVlbGl6ZS50cmFuc2FjdGlvbih7XG4gKiAgIGRlZmVycmFibGU6IFNlcXVlbGl6ZS5EZWZlcnJhYmxlLlNFVF9ERUZFUlJFRFxuICogfSk7XG4gKiBgYGBcbiAqXG4gKiBAcHJvcGVydHkgSU5JVElBTExZX0RFRkVSUkVEIERlZmVyIGNvbnN0cmFpbnRzIGNoZWNrcyB0byB0aGUgZW5kIG9mIHRyYW5zYWN0aW9ucy5cbiAqIEBwcm9wZXJ0eSBJTklUSUFMTFlfSU1NRURJQVRFIFRyaWdnZXIgdGhlIGNvbnN0cmFpbnQgY2hlY2tzIGltbWVkaWF0ZWx5XG4gKiBAcHJvcGVydHkgTk9UIFNldCB0aGUgY29uc3RyYWludHMgdG8gbm90IGRlZmVycmVkLiBUaGlzIGlzIHRoZSBkZWZhdWx0IGluIFBvc3RncmVTUUwgYW5kIGl0IG1ha2UgaXQgaW1wb3NzaWJsZSB0byBkeW5hbWljYWxseSBkZWZlciB0aGUgY29uc3RyYWludHMgd2l0aGluIGEgdHJhbnNhY3Rpb24uXG4gKiBAcHJvcGVydHkgU0VUX0RFRkVSUkVEXG4gKiBAcHJvcGVydHkgU0VUX0lNTUVESUFURVxuICovXG5cbmNvbnN0IERlZmVycmFibGUgPSBtb2R1bGUuZXhwb3J0cyA9IHsgLy8gZXNsaW50LWRpc2FibGUtbGluZVxuICBJTklUSUFMTFlfREVGRVJSRUQ6IGNsYXNzVG9JbnZva2FibGUoSU5JVElBTExZX0RFRkVSUkVEKSxcbiAgSU5JVElBTExZX0lNTUVESUFURTogY2xhc3NUb0ludm9rYWJsZShJTklUSUFMTFlfSU1NRURJQVRFKSxcbiAgTk9UOiBjbGFzc1RvSW52b2thYmxlKE5PVCksXG4gIFNFVF9ERUZFUlJFRDogY2xhc3NUb0ludm9rYWJsZShTRVRfREVGRVJSRUQpLFxuICBTRVRfSU1NRURJQVRFOiBjbGFzc1RvSW52b2thYmxlKFNFVF9JTU1FRElBVEUpXG59O1xuIl19 \ No newline at end of file diff --git a/dist/dialects/abstract/connection-manager.js b/dist/dialects/abstract/connection-manager.js index 64a3dfc..8de677e 100644 --- a/dist/dialects/abstract/connection-manager.js +++ b/dist/dialects/abstract/connection-manager.js @@ -33,9 +33,7 @@ const debug = logger.debugContext("pool"); * @private */ -let ConnectionManager = -/*#__PURE__*/ -function () { +let ConnectionManager = /*#__PURE__*/function () { function ConnectionManager(dialect, sequelize) { _classCallCheck(this, ConnectionManager); @@ -366,4 +364,4 @@ function () { module.exports = ConnectionManager; module.exports.ConnectionManager = ConnectionManager; module.exports.default = ConnectionManager; -//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../lib/dialects/abstract/connection-manager.js"],"names":["Pool","TimeoutError","require","_","semver","Promise","errors","logger","debug","debugContext","ConnectionManager","dialect","sequelize","config","cloneDeep","versionPromise","dialectName","options","pool","Error","defaults","max","min","idle","acquire","evict","validate","_validate","bind","initPools","dataTypes","each","dataType","Object","prototype","hasOwnProperty","call","types","_refreshTypeParser","key","dialectModule","window","dialectModulePath","resolve","drain","then","destroyAllNow","getConnection","reject","_onProcessExit","replication","name","create","_connect","destroy","connection","_disconnect","tap","acquireTimeoutMillis","idleTimeoutMillis","reapIntervalMillis","Array","isArray","read","write","omit","map","readConfig","reads","release","client","queryType","useMaster","undefined","join","nextRead","length","promise","databaseVersion","_options","transaction","logging","__testLoggingFn","version","parsedVersion","get","coerce","valid","defaultVersion","catch","err","type","error","ConnectionAcquireTimeoutError","try","runHooks","connectionManager","connect","return","disconnect","module","exports","default"],"mappings":"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","sourcesContent":["\"use strict\";\r\n\r\nconst { Pool, TimeoutError } = require(\"sequelize-pool\");\r\nconst _ = require(\"lodash\");\r\nconst semver = require(\"semver\");\r\nconst Promise = require(\"../../promise\");\r\nconst errors = require(\"../../errors\");\r\nconst { logger } = require(\"../../utils/logger\");\r\nconst debug = logger.debugContext(\"pool\");\r\n\r\n/**\r\n * Abstract Connection Manager\r\n *\r\n * Connection manager which handles pooling & replication.\r\n * Uses sequelize-pool for pooling\r\n *\r\n * @private\r\n */\r\nclass ConnectionManager {\r\n  constructor(dialect, sequelize) {\r\n    const config = _.cloneDeep(sequelize.config);\r\n\r\n    this.sequelize = sequelize;\r\n    this.config = config;\r\n    this.dialect = dialect;\r\n    this.versionPromise = null;\r\n    this.dialectName = this.sequelize.options.dialect;\r\n\r\n    if (config.pool === false) {\r\n      throw new Error(\"Support for pool:false was removed in v4.0\");\r\n    }\r\n\r\n    config.pool = _.defaults(config.pool || {}, {\r\n      max: 5,\r\n      min: 0,\r\n      idle: 10000,\r\n      acquire: 60000,\r\n      evict: 1000,\r\n      validate: this._validate.bind(this)\r\n    });\r\n\r\n    this.initPools();\r\n  }\r\n\r\n  refreshTypeParser(dataTypes) {\r\n    _.each(dataTypes, dataType => {\r\n      if (Object.prototype.hasOwnProperty.call(dataType, \"parse\")) {\r\n        if (dataType.types[this.dialectName]) {\r\n          this._refreshTypeParser(dataType);\r\n        } else {\r\n          throw new Error(\r\n            `Parse function not supported for type ${dataType.key} in dialect ${this.dialectName}`\r\n          );\r\n        }\r\n      }\r\n    });\r\n  }\r\n\r\n  /**\r\n   * Try to load dialect module from various configured options.\r\n   * Priority goes like dialectModulePath > dialectModule > require(default)\r\n   *\r\n   *\r\n   * @private\r\n   * @returns {Object}\r\n   */\r\n  _loadDialectModule() {\r\n    const dialectModule = this.sequelize.config.dialectModule || window;\r\n    if (!dialectModule) {\r\n      if (this.sequelize.config.dialectModulePath) {\r\n        throw new Error(\r\n          `Unable to load dialectModule at ${this.sequelize.config.dialectModule}`\r\n        );\r\n      }\r\n      throw new Error(`Please add parameter dialectModule in config manually`);\r\n    }\r\n    return dialectModule;\r\n  }\r\n\r\n  /**\r\n   * Handler which executes on process exit or connection manager shutdown\r\n   *\r\n   * @private\r\n   * @returns {Promise}\r\n   */\r\n  _onProcessExit() {\r\n    if (!this.pool) {\r\n      return Promise.resolve();\r\n    }\r\n\r\n    return this.pool.drain().then(() => {\r\n      debug(\"connection drain due to process exit\");\r\n      return this.pool.destroyAllNow();\r\n    });\r\n  }\r\n\r\n  /**\r\n   * Drain the pool and close it permanently\r\n   *\r\n   * @returns {Promise}\r\n   */\r\n  close() {\r\n    // Mark close of pool\r\n    this.getConnection = function getConnection() {\r\n      return Promise.reject(\r\n        new Error(\r\n          \"ConnectionManager.getConnection was called after the connection manager was closed!\"\r\n        )\r\n      );\r\n    };\r\n\r\n    return this._onProcessExit();\r\n  }\r\n\r\n  /**\r\n   * Initialize connection pool. By default pool autostart is set to false, so no connection will be\r\n   * be created unless `pool.acquire` is called.\r\n   */\r\n  initPools() {\r\n    const config = this.config;\r\n\r\n    if (!config.replication) {\r\n      this.pool = new Pool({\r\n        name: \"sequelize\",\r\n        create: () => this._connect(config),\r\n        destroy: connection => {\r\n          return this._disconnect(connection).tap(() => {\r\n            debug(\"connection destroy\");\r\n          });\r\n        },\r\n        validate: config.pool.validate,\r\n        max: config.pool.max,\r\n        min: config.pool.min,\r\n        acquireTimeoutMillis: config.pool.acquire,\r\n        idleTimeoutMillis: config.pool.idle,\r\n        reapIntervalMillis: config.pool.evict\r\n      });\r\n\r\n      debug(\r\n        `pool created with max/min: ${config.pool.max}/${config.pool.min}, no replication`\r\n      );\r\n\r\n      return;\r\n    }\r\n\r\n    if (!Array.isArray(config.replication.read)) {\r\n      config.replication.read = [config.replication.read];\r\n    }\r\n\r\n    // Map main connection config\r\n    config.replication.write = _.defaults(\r\n      config.replication.write,\r\n      _.omit(config, \"replication\")\r\n    );\r\n\r\n    // Apply defaults to each read config\r\n    config.replication.read = config.replication.read.map(readConfig =>\r\n      _.defaults(readConfig, _.omit(this.config, \"replication\"))\r\n    );\r\n\r\n    // custom pooling for replication (original author @janmeier)\r\n    let reads = 0;\r\n    this.pool = {\r\n      release: client => {\r\n        if (client.queryType === \"read\") {\r\n          this.pool.read.release(client);\r\n        } else {\r\n          this.pool.write.release(client);\r\n        }\r\n      },\r\n      acquire: (queryType, useMaster) => {\r\n        useMaster = useMaster === undefined ? false : useMaster;\r\n        if (queryType === \"SELECT\" && !useMaster) {\r\n          return this.pool.read.acquire();\r\n        }\r\n        return this.pool.write.acquire();\r\n      },\r\n      destroy: connection => {\r\n        this.pool[connection.queryType].destroy(connection);\r\n        debug(\"connection destroy\");\r\n      },\r\n      destroyAllNow: () => {\r\n        return Promise.join(\r\n          this.pool.read.destroyAllNow(),\r\n          this.pool.write.destroyAllNow()\r\n        ).tap(() => {\r\n          debug(\"all connections destroyed\");\r\n        });\r\n      },\r\n      drain: () => {\r\n        return Promise.join(this.pool.write.drain(), this.pool.read.drain());\r\n      },\r\n      read: new Pool({\r\n        name: \"sequelize:read\",\r\n        create: () => {\r\n          // round robin config\r\n          const nextRead = reads++ % config.replication.read.length;\r\n          return this._connect(config.replication.read[nextRead]).tap(\r\n            connection => {\r\n              connection.queryType = \"read\";\r\n            }\r\n          );\r\n        },\r\n        destroy: connection => this._disconnect(connection),\r\n        validate: config.pool.validate,\r\n        max: config.pool.max,\r\n        min: config.pool.min,\r\n        acquireTimeoutMillis: config.pool.acquire,\r\n        idleTimeoutMillis: config.pool.idle,\r\n        reapIntervalMillis: config.pool.evict\r\n      }),\r\n      write: new Pool({\r\n        name: \"sequelize:write\",\r\n        create: () => {\r\n          return this._connect(config.replication.write).tap(connection => {\r\n            connection.queryType = \"write\";\r\n          });\r\n        },\r\n        destroy: connection => this._disconnect(connection),\r\n        validate: config.pool.validate,\r\n        max: config.pool.max,\r\n        min: config.pool.min,\r\n        acquireTimeoutMillis: config.pool.acquire,\r\n        idleTimeoutMillis: config.pool.idle,\r\n        reapIntervalMillis: config.pool.evict\r\n      })\r\n    };\r\n\r\n    debug(\r\n      `pool created with max/min: ${config.pool.max}/${config.pool.min}, with replication`\r\n    );\r\n  }\r\n\r\n  /**\r\n   * Get connection from pool. It sets database version if it's not already set.\r\n   * Call pool.acquire to get a connection\r\n   *\r\n   * @param {Object}   [options]                 Pool options\r\n   * @param {string}   [options.type]            Set which replica to use. Available options are `read` and `write`\r\n   * @param {boolean}  [options.useMaster=false] Force master or write replica to get connection from\r\n   *\r\n   * @returns {Promise<Connection>}\r\n   */\r\n  getConnection(options) {\r\n    options = options || {};\r\n\r\n    let promise;\r\n    if (this.sequelize.options.databaseVersion === 0) {\r\n      if (this.versionPromise) {\r\n        promise = this.versionPromise;\r\n      } else {\r\n        promise = this.versionPromise = this._connect(\r\n          this.config.replication.write || this.config\r\n        )\r\n          .then(connection => {\r\n            const _options = {};\r\n\r\n            _options.transaction = { connection }; // Cheat .query to use our private connection\r\n            _options.logging = () => {};\r\n            _options.logging.__testLoggingFn = true;\r\n\r\n            //connection might have set databaseVersion value at initialization,\r\n            //avoiding a useless round trip\r\n            if (this.sequelize.options.databaseVersion === 0) {\r\n              return this.sequelize.databaseVersion(_options).then(version => {\r\n                const parsedVersion =\r\n                  _.get(semver.coerce(version), \"version\") || version;\r\n                this.sequelize.options.databaseVersion = semver.valid(\r\n                  parsedVersion\r\n                )\r\n                  ? parsedVersion\r\n                  : this.defaultVersion;\r\n                this.versionPromise = null;\r\n                return this._disconnect(connection);\r\n              });\r\n            }\r\n\r\n            this.versionPromise = null;\r\n            return this._disconnect(connection);\r\n          })\r\n          .catch(err => {\r\n            this.versionPromise = null;\r\n            throw err;\r\n          });\r\n      }\r\n    } else {\r\n      promise = Promise.resolve();\r\n    }\r\n\r\n    return promise\r\n      .then(() => {\r\n        return this.pool\r\n          .acquire(options.type, options.useMaster)\r\n          .catch(error => {\r\n            if (error instanceof TimeoutError)\r\n              throw new errors.ConnectionAcquireTimeoutError(error);\r\n            throw error;\r\n          });\r\n      })\r\n      .tap(() => {\r\n        debug(\"connection acquired\");\r\n      });\r\n  }\r\n\r\n  /**\r\n   * Release a pooled connection so it can be utilized by other connection requests\r\n   *\r\n   * @param {Connection} connection\r\n   *\r\n   * @returns {Promise}\r\n   */\r\n  releaseConnection(connection) {\r\n    return Promise.try(() => {\r\n      this.pool.release(connection);\r\n      debug(\"connection released\");\r\n    });\r\n  }\r\n\r\n  /**\r\n   * Call dialect library to get connection\r\n   *\r\n   * @param {*} config Connection config\r\n   * @private\r\n   * @returns {Promise<Connection>}\r\n   */\r\n  _connect(config) {\r\n    return this.sequelize\r\n      .runHooks(\"beforeConnect\", config)\r\n      .then(() => this.dialect.connectionManager.connect(config))\r\n      .then(connection =>\r\n        this.sequelize\r\n          .runHooks(\"afterConnect\", connection, config)\r\n          .return(connection)\r\n      );\r\n  }\r\n\r\n  /**\r\n   * Call dialect library to disconnect a connection\r\n   *\r\n   * @param {Connection} connection\r\n   * @private\r\n   * @returns {Promise}\r\n   */\r\n  _disconnect(connection) {\r\n    return this.sequelize\r\n      .runHooks(\"beforeDisconnect\", connection)\r\n      .then(() => this.dialect.connectionManager.disconnect(connection))\r\n      .then(() => this.sequelize.runHooks(\"afterDisconnect\", connection));\r\n  }\r\n\r\n  /**\r\n   * Determine if a connection is still valid or not\r\n   *\r\n   * @param {Connection} connection\r\n   *\r\n   * @returns {boolean}\r\n   */\r\n  _validate(connection) {\r\n    if (!this.dialect.connectionManager.validate) {\r\n      return true;\r\n    }\r\n\r\n    return this.dialect.connectionManager.validate(connection);\r\n  }\r\n}\r\n\r\nmodule.exports = ConnectionManager;\r\nmodule.exports.ConnectionManager = ConnectionManager;\r\nmodule.exports.default = ConnectionManager;\r\n"]} \ No newline at end of file +//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../lib/dialects/abstract/connection-manager.js"],"names":["Pool","TimeoutError","require","_","semver","Promise","errors","logger","debug","debugContext","ConnectionManager","dialect","sequelize","config","cloneDeep","versionPromise","dialectName","options","pool","Error","defaults","max","min","idle","acquire","evict","validate","_validate","bind","initPools","dataTypes","each","dataType","Object","prototype","hasOwnProperty","call","types","_refreshTypeParser","key","dialectModule","window","dialectModulePath","resolve","drain","then","destroyAllNow","getConnection","reject","_onProcessExit","replication","name","create","_connect","destroy","connection","_disconnect","tap","acquireTimeoutMillis","idleTimeoutMillis","reapIntervalMillis","Array","isArray","read","write","omit","map","readConfig","reads","release","client","queryType","useMaster","undefined","join","nextRead","length","promise","databaseVersion","_options","transaction","logging","__testLoggingFn","version","parsedVersion","get","coerce","valid","defaultVersion","catch","err","type","error","ConnectionAcquireTimeoutError","try","runHooks","connectionManager","connect","return","disconnect","module","exports","default"],"mappings":"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","sourcesContent":["\"use strict\";\n\nconst { Pool, TimeoutError } = require(\"sequelize-pool\");\nconst _ = require(\"lodash\");\nconst semver = require(\"semver\");\nconst Promise = require(\"../../promise\");\nconst errors = require(\"../../errors\");\nconst { logger } = require(\"../../utils/logger\");\nconst debug = logger.debugContext(\"pool\");\n\n/**\n * Abstract Connection Manager\n *\n * Connection manager which handles pooling & replication.\n * Uses sequelize-pool for pooling\n *\n * @private\n */\nclass ConnectionManager {\n  constructor(dialect, sequelize) {\n    const config = _.cloneDeep(sequelize.config);\n\n    this.sequelize = sequelize;\n    this.config = config;\n    this.dialect = dialect;\n    this.versionPromise = null;\n    this.dialectName = this.sequelize.options.dialect;\n\n    if (config.pool === false) {\n      throw new Error(\"Support for pool:false was removed in v4.0\");\n    }\n\n    config.pool = _.defaults(config.pool || {}, {\n      max: 5,\n      min: 0,\n      idle: 10000,\n      acquire: 60000,\n      evict: 1000,\n      validate: this._validate.bind(this)\n    });\n\n    this.initPools();\n  }\n\n  refreshTypeParser(dataTypes) {\n    _.each(dataTypes, dataType => {\n      if (Object.prototype.hasOwnProperty.call(dataType, \"parse\")) {\n        if (dataType.types[this.dialectName]) {\n          this._refreshTypeParser(dataType);\n        } else {\n          throw new Error(\n            `Parse function not supported for type ${dataType.key} in dialect ${this.dialectName}`\n          );\n        }\n      }\n    });\n  }\n\n  /**\n   * Try to load dialect module from various configured options.\n   * Priority goes like dialectModulePath > dialectModule > require(default)\n   *\n   *\n   * @private\n   * @returns {Object}\n   */\n  _loadDialectModule() {\n    const dialectModule = this.sequelize.config.dialectModule || window;\n    if (!dialectModule) {\n      if (this.sequelize.config.dialectModulePath) {\n        throw new Error(\n          `Unable to load dialectModule at ${this.sequelize.config.dialectModule}`\n        );\n      }\n      throw new Error(`Please add parameter dialectModule in config manually`);\n    }\n    return dialectModule;\n  }\n\n  /**\n   * Handler which executes on process exit or connection manager shutdown\n   *\n   * @private\n   * @returns {Promise}\n   */\n  _onProcessExit() {\n    if (!this.pool) {\n      return Promise.resolve();\n    }\n\n    return this.pool.drain().then(() => {\n      debug(\"connection drain due to process exit\");\n      return this.pool.destroyAllNow();\n    });\n  }\n\n  /**\n   * Drain the pool and close it permanently\n   *\n   * @returns {Promise}\n   */\n  close() {\n    // Mark close of pool\n    this.getConnection = function getConnection() {\n      return Promise.reject(\n        new Error(\n          \"ConnectionManager.getConnection was called after the connection manager was closed!\"\n        )\n      );\n    };\n\n    return this._onProcessExit();\n  }\n\n  /**\n   * Initialize connection pool. By default pool autostart is set to false, so no connection will be\n   * be created unless `pool.acquire` is called.\n   */\n  initPools() {\n    const config = this.config;\n\n    if (!config.replication) {\n      this.pool = new Pool({\n        name: \"sequelize\",\n        create: () => this._connect(config),\n        destroy: connection => {\n          return this._disconnect(connection).tap(() => {\n            debug(\"connection destroy\");\n          });\n        },\n        validate: config.pool.validate,\n        max: config.pool.max,\n        min: config.pool.min,\n        acquireTimeoutMillis: config.pool.acquire,\n        idleTimeoutMillis: config.pool.idle,\n        reapIntervalMillis: config.pool.evict\n      });\n\n      debug(\n        `pool created with max/min: ${config.pool.max}/${config.pool.min}, no replication`\n      );\n\n      return;\n    }\n\n    if (!Array.isArray(config.replication.read)) {\n      config.replication.read = [config.replication.read];\n    }\n\n    // Map main connection config\n    config.replication.write = _.defaults(\n      config.replication.write,\n      _.omit(config, \"replication\")\n    );\n\n    // Apply defaults to each read config\n    config.replication.read = config.replication.read.map(readConfig =>\n      _.defaults(readConfig, _.omit(this.config, \"replication\"))\n    );\n\n    // custom pooling for replication (original author @janmeier)\n    let reads = 0;\n    this.pool = {\n      release: client => {\n        if (client.queryType === \"read\") {\n          this.pool.read.release(client);\n        } else {\n          this.pool.write.release(client);\n        }\n      },\n      acquire: (queryType, useMaster) => {\n        useMaster = useMaster === undefined ? false : useMaster;\n        if (queryType === \"SELECT\" && !useMaster) {\n          return this.pool.read.acquire();\n        }\n        return this.pool.write.acquire();\n      },\n      destroy: connection => {\n        this.pool[connection.queryType].destroy(connection);\n        debug(\"connection destroy\");\n      },\n      destroyAllNow: () => {\n        return Promise.join(\n          this.pool.read.destroyAllNow(),\n          this.pool.write.destroyAllNow()\n        ).tap(() => {\n          debug(\"all connections destroyed\");\n        });\n      },\n      drain: () => {\n        return Promise.join(this.pool.write.drain(), this.pool.read.drain());\n      },\n      read: new Pool({\n        name: \"sequelize:read\",\n        create: () => {\n          // round robin config\n          const nextRead = reads++ % config.replication.read.length;\n          return this._connect(config.replication.read[nextRead]).tap(\n            connection => {\n              connection.queryType = \"read\";\n            }\n          );\n        },\n        destroy: connection => this._disconnect(connection),\n        validate: config.pool.validate,\n        max: config.pool.max,\n        min: config.pool.min,\n        acquireTimeoutMillis: config.pool.acquire,\n        idleTimeoutMillis: config.pool.idle,\n        reapIntervalMillis: config.pool.evict\n      }),\n      write: new Pool({\n        name: \"sequelize:write\",\n        create: () => {\n          return this._connect(config.replication.write).tap(connection => {\n            connection.queryType = \"write\";\n          });\n        },\n        destroy: connection => this._disconnect(connection),\n        validate: config.pool.validate,\n        max: config.pool.max,\n        min: config.pool.min,\n        acquireTimeoutMillis: config.pool.acquire,\n        idleTimeoutMillis: config.pool.idle,\n        reapIntervalMillis: config.pool.evict\n      })\n    };\n\n    debug(\n      `pool created with max/min: ${config.pool.max}/${config.pool.min}, with replication`\n    );\n  }\n\n  /**\n   * Get connection from pool. It sets database version if it's not already set.\n   * Call pool.acquire to get a connection\n   *\n   * @param {Object}   [options]                 Pool options\n   * @param {string}   [options.type]            Set which replica to use. Available options are `read` and `write`\n   * @param {boolean}  [options.useMaster=false] Force master or write replica to get connection from\n   *\n   * @returns {Promise<Connection>}\n   */\n  getConnection(options) {\n    options = options || {};\n\n    let promise;\n    if (this.sequelize.options.databaseVersion === 0) {\n      if (this.versionPromise) {\n        promise = this.versionPromise;\n      } else {\n        promise = this.versionPromise = this._connect(\n          this.config.replication.write || this.config\n        )\n          .then(connection => {\n            const _options = {};\n\n            _options.transaction = { connection }; // Cheat .query to use our private connection\n            _options.logging = () => {};\n            _options.logging.__testLoggingFn = true;\n\n            //connection might have set databaseVersion value at initialization,\n            //avoiding a useless round trip\n            if (this.sequelize.options.databaseVersion === 0) {\n              return this.sequelize.databaseVersion(_options).then(version => {\n                const parsedVersion =\n                  _.get(semver.coerce(version), \"version\") || version;\n                this.sequelize.options.databaseVersion = semver.valid(\n                  parsedVersion\n                )\n                  ? parsedVersion\n                  : this.defaultVersion;\n                this.versionPromise = null;\n                return this._disconnect(connection);\n              });\n            }\n\n            this.versionPromise = null;\n            return this._disconnect(connection);\n          })\n          .catch(err => {\n            this.versionPromise = null;\n            throw err;\n          });\n      }\n    } else {\n      promise = Promise.resolve();\n    }\n\n    return promise\n      .then(() => {\n        return this.pool\n          .acquire(options.type, options.useMaster)\n          .catch(error => {\n            if (error instanceof TimeoutError)\n              throw new errors.ConnectionAcquireTimeoutError(error);\n            throw error;\n          });\n      })\n      .tap(() => {\n        debug(\"connection acquired\");\n      });\n  }\n\n  /**\n   * Release a pooled connection so it can be utilized by other connection requests\n   *\n   * @param {Connection} connection\n   *\n   * @returns {Promise}\n   */\n  releaseConnection(connection) {\n    return Promise.try(() => {\n      this.pool.release(connection);\n      debug(\"connection released\");\n    });\n  }\n\n  /**\n   * Call dialect library to get connection\n   *\n   * @param {*} config Connection config\n   * @private\n   * @returns {Promise<Connection>}\n   */\n  _connect(config) {\n    return this.sequelize\n      .runHooks(\"beforeConnect\", config)\n      .then(() => this.dialect.connectionManager.connect(config))\n      .then(connection =>\n        this.sequelize\n          .runHooks(\"afterConnect\", connection, config)\n          .return(connection)\n      );\n  }\n\n  /**\n   * Call dialect library to disconnect a connection\n   *\n   * @param {Connection} connection\n   * @private\n   * @returns {Promise}\n   */\n  _disconnect(connection) {\n    return this.sequelize\n      .runHooks(\"beforeDisconnect\", connection)\n      .then(() => this.dialect.connectionManager.disconnect(connection))\n      .then(() => this.sequelize.runHooks(\"afterDisconnect\", connection));\n  }\n\n  /**\n   * Determine if a connection is still valid or not\n   *\n   * @param {Connection} connection\n   *\n   * @returns {boolean}\n   */\n  _validate(connection) {\n    if (!this.dialect.connectionManager.validate) {\n      return true;\n    }\n\n    return this.dialect.connectionManager.validate(connection);\n  }\n}\n\nmodule.exports = ConnectionManager;\nmodule.exports.ConnectionManager = ConnectionManager;\nmodule.exports.default = ConnectionManager;\n"]} \ No newline at end of file diff --git a/dist/dialects/abstract/index.js b/dist/dialects/abstract/index.js index 348cce6..230aed9 100644 --- a/dist/dialects/abstract/index.js +++ b/dist/dialects/abstract/index.js @@ -81,4 +81,4 @@ AbstractDialect.prototype.supports = { module.exports = AbstractDialect; module.exports.AbstractDialect = AbstractDialect; module.exports.default = AbstractDialect; -//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uLy4uL2xpYi9kaWFsZWN0cy9hYnN0cmFjdC9pbmRleC5qcyJdLCJuYW1lcyI6WyJBYnN0cmFjdERpYWxlY3QiLCJwcm90b3R5cGUiLCJzdXBwb3J0cyIsInJldHVyblZhbHVlcyIsImF1dG9JbmNyZW1lbnQiLCJpZGVudGl0eUluc2VydCIsImRlZmF1bHRWYWx1ZSIsInVwZGF0ZSIsImJ1bGtEZWZhdWx0Iiwic2NoZW1hcyIsInRyYW5zYWN0aW9ucyIsInNldHRpbmdJc29sYXRpb25MZXZlbER1cmluZ1RyYW5zYWN0aW9uIiwidHJhbnNhY3Rpb25PcHRpb25zIiwidHlwZSIsIm1pZ3JhdGlvbnMiLCJ1cHNlcnRzIiwiaW5zZXJ0cyIsImlnbm9yZUR1cGxpY2F0ZXMiLCJ1cGRhdGVPbkR1cGxpY2F0ZSIsIm9uQ29uZmxpY3REb05vdGhpbmciLCJjb25zdHJhaW50cyIsInJlc3RyaWN0IiwiYWRkQ29uc3RyYWludCIsImRyb3BDb25zdHJhaW50IiwidW5pcXVlIiwiZGVmYXVsdCIsImNoZWNrIiwiZm9yZWlnbktleSIsInByaW1hcnlLZXkiLCJpbmRleCIsImNvbGxhdGUiLCJsZW5ndGgiLCJwYXJzZXIiLCJjb25jdXJyZW50bHkiLCJ1c2luZyIsImZ1bmN0aW9uQmFzZWQiLCJqb2luVGFibGVEZXBlbmRlbnQiLCJncm91cGVkTGltaXQiLCJpbmRleFZpYUFsdGVyIiwiSlNPTiIsImRlZmVycmFibGVDb25zdHJhaW50cyIsIm1vZHVsZSIsImV4cG9ydHMiXSwibWFwcGluZ3MiOiJBQUFBOzs7O0lBRU1BLGU7Ozs7QUFFTkEsZUFBZSxDQUFDQyxTQUFoQixDQUEwQkMsUUFBMUIsR0FBcUM7QUFDbkMsYUFBVyxJQUR3QjtBQUVuQyxvQkFBa0IsS0FGaUI7QUFHbkMsZUFBYSxLQUhzQjtBQUluQyxxQkFBbUIsS0FKZ0I7QUFLbkMsc0JBQW9CLElBTGU7QUFNbkMsaUJBQWUsS0FOb0I7QUFPbkMsV0FBUyxJQVAwQjtBQVFuQyxlQUFhLElBUnNCO0FBU25DLGdCQUFjLElBVHFCOztBQVduQztBQUNBQyxFQUFBQSxZQUFZLEVBQUUsS0FacUI7O0FBY25DO0FBQ0FDLEVBQUFBLGFBQWEsRUFBRTtBQUNiO0FBQ0FDLElBQUFBLGNBQWMsRUFBRSxLQUZIOztBQUliO0FBQ0FDLElBQUFBLFlBQVksRUFBRSxJQUxEOztBQU9iO0FBQ0FDLElBQUFBLE1BQU0sRUFBRTtBQVJLLEdBZm9COztBQXlCbkM7QUFDQUMsRUFBQUEsV0FBVyxFQUFFLEtBMUJzQjtBQTJCbkNDLEVBQUFBLE9BQU8sRUFBRSxLQTNCMEI7QUE0Qm5DQyxFQUFBQSxZQUFZLEVBQUUsSUE1QnFCO0FBNkJuQ0MsRUFBQUEsc0NBQXNDLEVBQUUsSUE3Qkw7QUE4Qm5DQyxFQUFBQSxrQkFBa0IsRUFBRTtBQUNsQkMsSUFBQUEsSUFBSSxFQUFFO0FBRFksR0E5QmU7QUFpQ25DQyxFQUFBQSxVQUFVLEVBQUUsSUFqQ3VCO0FBa0NuQ0MsRUFBQUEsT0FBTyxFQUFFLElBbEMwQjtBQW1DbkNDLEVBQUFBLE9BQU8sRUFBRTtBQUNQQyxJQUFBQSxnQkFBZ0IsRUFBRSxFQURYOztBQUNlO0FBQ3RCQyxJQUFBQSxpQkFBaUIsRUFBRSxLQUZaOztBQUVtQjtBQUMxQkMsSUFBQUEsbUJBQW1CLEVBQUU7QUFBRzs7QUFIakIsR0FuQzBCO0FBd0NuQ0MsRUFBQUEsV0FBVyxFQUFFO0FBQ1hDLElBQUFBLFFBQVEsRUFBRSxJQURDO0FBRVhDLElBQUFBLGFBQWEsRUFBRSxJQUZKO0FBR1hDLElBQUFBLGNBQWMsRUFBRSxJQUhMO0FBSVhDLElBQUFBLE1BQU0sRUFBRSxJQUpHO0FBS1hDLElBQUFBLE9BQU8sRUFBRSxLQUxFO0FBTVhDLElBQUFBLEtBQUssRUFBRSxJQU5JO0FBT1hDLElBQUFBLFVBQVUsRUFBRSxJQVBEO0FBUVhDLElBQUFBLFVBQVUsRUFBRTtBQVJELEdBeENzQjtBQWtEbkNDLEVBQUFBLEtBQUssRUFBRTtBQUNMQyxJQUFBQSxPQUFPLEVBQUUsSUFESjtBQUVMQyxJQUFBQSxNQUFNLEVBQUUsS0FGSDtBQUdMQyxJQUFBQSxNQUFNLEVBQUUsS0FISDtBQUlMQyxJQUFBQSxZQUFZLEVBQUUsS0FKVDtBQUtMcEIsSUFBQUEsSUFBSSxFQUFFLEtBTEQ7QUFNTHFCLElBQUFBLEtBQUssRUFBRSxJQU5GO0FBT0xDLElBQUFBLGFBQWEsRUFBRTtBQVBWLEdBbEQ0QjtBQTJEbkNDLEVBQUFBLGtCQUFrQixFQUFFLElBM0RlO0FBNERuQ0MsRUFBQUEsWUFBWSxFQUFFLElBNURxQjtBQTZEbkNDLEVBQUFBLGFBQWEsRUFBRSxLQTdEb0I7QUE4RG5DQyxFQUFBQSxJQUFJLEVBQUUsS0E5RDZCO0FBK0RuQ0MsRUFBQUEscUJBQXFCLEVBQUU7QUEvRFksQ0FBckM7QUFrRUFDLE1BQU0sQ0FBQ0MsT0FBUCxHQUFpQjFDLGVBQWpCO0FBQ0F5QyxNQUFNLENBQUNDLE9BQVAsQ0FBZTFDLGVBQWYsR0FBaUNBLGVBQWpDO0FBQ0F5QyxNQUFNLENBQUNDLE9BQVAsQ0FBZWpCLE9BQWYsR0FBeUJ6QixlQUF6QiIsInNvdXJjZXNDb250ZW50IjpbIid1c2Ugc3RyaWN0JztcclxuXHJcbmNsYXNzIEFic3RyYWN0RGlhbGVjdCB7fVxyXG5cclxuQWJzdHJhY3REaWFsZWN0LnByb3RvdHlwZS5zdXBwb3J0cyA9IHtcclxuICAnREVGQVVMVCc6IHRydWUsXHJcbiAgJ0RFRkFVTFQgVkFMVUVTJzogZmFsc2UsXHJcbiAgJ1ZBTFVFUyAoKSc6IGZhbHNlLFxyXG4gICdMSU1JVCBPTiBVUERBVEUnOiBmYWxzZSxcclxuICAnT04gRFVQTElDQVRFIEtFWSc6IHRydWUsXHJcbiAgJ09SREVSIE5VTExTJzogZmFsc2UsXHJcbiAgJ1VOSU9OJzogdHJ1ZSxcclxuICAnVU5JT04gQUxMJzogdHJ1ZSxcclxuICAnUklHSFQgSk9JTic6IHRydWUsXHJcblxyXG4gIC8qIGRvZXMgdGhlIGRpYWxlY3Qgc3VwcG9ydCByZXR1cm5pbmcgdmFsdWVzIGZvciBpbnNlcnRlZC91cGRhdGVkIGZpZWxkcyAqL1xyXG4gIHJldHVyblZhbHVlczogZmFsc2UsXHJcblxyXG4gIC8qIGZlYXR1cmVzIHNwZWNpZmljIHRvIGF1dG9JbmNyZW1lbnQgdmFsdWVzICovXHJcbiAgYXV0b0luY3JlbWVudDoge1xyXG4gICAgLyogZG9lcyB0aGUgZGlhbGVjdCByZXF1aXJlIG1vZGlmaWNhdGlvbiBvZiBpbnNlcnQgcXVlcmllcyB3aGVuIGluc2VydGluZyBhdXRvIGluY3JlbWVudCBmaWVsZHMgKi9cclxuICAgIGlkZW50aXR5SW5zZXJ0OiBmYWxzZSxcclxuXHJcbiAgICAvKiBkb2VzIHRoZSBkaWFsZWN0IHN1cHBvcnQgaW5zZXJ0aW5nIGRlZmF1bHQvbnVsbCB2YWx1ZXMgZm9yIGF1dG9pbmNyZW1lbnQgZmllbGRzICovXHJcbiAgICBkZWZhdWx0VmFsdWU6IHRydWUsXHJcblxyXG4gICAgLyogZG9lcyB0aGUgZGlhbGVjdCBzdXBwb3J0IHVwZGF0aW5nIGF1dG9pbmNyZW1lbnQgZmllbGRzICovXHJcbiAgICB1cGRhdGU6IHRydWVcclxuICB9LFxyXG4gIC8qIERvIHdlIG5lZWQgdG8gc2F5IERFRkFVTFQgZm9yIGJ1bGsgaW5zZXJ0ICovXHJcbiAgYnVsa0RlZmF1bHQ6IGZhbHNlLFxyXG4gIHNjaGVtYXM6IGZhbHNlLFxyXG4gIHRyYW5zYWN0aW9uczogdHJ1ZSxcclxuICBzZXR0aW5nSXNvbGF0aW9uTGV2ZWxEdXJpbmdUcmFuc2FjdGlvbjogdHJ1ZSxcclxuICB0cmFuc2FjdGlvbk9wdGlvbnM6IHtcclxuICAgIHR5cGU6IGZhbHNlXHJcbiAgfSxcclxuICBtaWdyYXRpb25zOiB0cnVlLFxyXG4gIHVwc2VydHM6IHRydWUsXHJcbiAgaW5zZXJ0czoge1xyXG4gICAgaWdub3JlRHVwbGljYXRlczogJycsIC8qIGRpYWxlY3Qgc3BlY2lmaWMgd29yZHMgZm9yIElOU0VSVCBJR05PUkUgb3IgRE8gTk9USElORyAqL1xyXG4gICAgdXBkYXRlT25EdXBsaWNhdGU6IGZhbHNlLCAvKiB3aGV0aGVyIGRpYWxlY3Qgc3VwcG9ydHMgT04gRFVQTElDQVRFIEtFWSBVUERBVEUgKi9cclxuICAgIG9uQ29uZmxpY3REb05vdGhpbmc6ICcnIC8qIGRpYWxlY3Qgc3BlY2lmaWMgd29yZHMgZm9yIE9OIENPTkZMSUNUIERPIE5PVEhJTkcgKi9cclxuICB9LFxyXG4gIGNvbnN0cmFpbnRzOiB7XHJcbiAgICByZXN0cmljdDogdHJ1ZSxcclxuICAgIGFkZENvbnN0cmFpbnQ6IHRydWUsXHJcbiAgICBkcm9wQ29uc3RyYWludDogdHJ1ZSxcclxuICAgIHVuaXF1ZTogdHJ1ZSxcclxuICAgIGRlZmF1bHQ6IGZhbHNlLFxyXG4gICAgY2hlY2s6IHRydWUsXHJcbiAgICBmb3JlaWduS2V5OiB0cnVlLFxyXG4gICAgcHJpbWFyeUtleTogdHJ1ZVxyXG4gIH0sXHJcbiAgaW5kZXg6IHtcclxuICAgIGNvbGxhdGU6IHRydWUsXHJcbiAgICBsZW5ndGg6IGZhbHNlLFxyXG4gICAgcGFyc2VyOiBmYWxzZSxcclxuICAgIGNvbmN1cnJlbnRseTogZmFsc2UsXHJcbiAgICB0eXBlOiBmYWxzZSxcclxuICAgIHVzaW5nOiB0cnVlLFxyXG4gICAgZnVuY3Rpb25CYXNlZDogZmFsc2VcclxuICB9LFxyXG4gIGpvaW5UYWJsZURlcGVuZGVudDogdHJ1ZSxcclxuICBncm91cGVkTGltaXQ6IHRydWUsXHJcbiAgaW5kZXhWaWFBbHRlcjogZmFsc2UsXHJcbiAgSlNPTjogZmFsc2UsXHJcbiAgZGVmZXJyYWJsZUNvbnN0cmFpbnRzOiBmYWxzZVxyXG59O1xyXG5cclxubW9kdWxlLmV4cG9ydHMgPSBBYnN0cmFjdERpYWxlY3Q7XHJcbm1vZHVsZS5leHBvcnRzLkFic3RyYWN0RGlhbGVjdCA9IEFic3RyYWN0RGlhbGVjdDtcclxubW9kdWxlLmV4cG9ydHMuZGVmYXVsdCA9IEFic3RyYWN0RGlhbGVjdDtcclxuIl19 \ No newline at end of file +//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uLy4uL2xpYi9kaWFsZWN0cy9hYnN0cmFjdC9pbmRleC5qcyJdLCJuYW1lcyI6WyJBYnN0cmFjdERpYWxlY3QiLCJwcm90b3R5cGUiLCJzdXBwb3J0cyIsInJldHVyblZhbHVlcyIsImF1dG9JbmNyZW1lbnQiLCJpZGVudGl0eUluc2VydCIsImRlZmF1bHRWYWx1ZSIsInVwZGF0ZSIsImJ1bGtEZWZhdWx0Iiwic2NoZW1hcyIsInRyYW5zYWN0aW9ucyIsInNldHRpbmdJc29sYXRpb25MZXZlbER1cmluZ1RyYW5zYWN0aW9uIiwidHJhbnNhY3Rpb25PcHRpb25zIiwidHlwZSIsIm1pZ3JhdGlvbnMiLCJ1cHNlcnRzIiwiaW5zZXJ0cyIsImlnbm9yZUR1cGxpY2F0ZXMiLCJ1cGRhdGVPbkR1cGxpY2F0ZSIsIm9uQ29uZmxpY3REb05vdGhpbmciLCJjb25zdHJhaW50cyIsInJlc3RyaWN0IiwiYWRkQ29uc3RyYWludCIsImRyb3BDb25zdHJhaW50IiwidW5pcXVlIiwiZGVmYXVsdCIsImNoZWNrIiwiZm9yZWlnbktleSIsInByaW1hcnlLZXkiLCJpbmRleCIsImNvbGxhdGUiLCJsZW5ndGgiLCJwYXJzZXIiLCJjb25jdXJyZW50bHkiLCJ1c2luZyIsImZ1bmN0aW9uQmFzZWQiLCJqb2luVGFibGVEZXBlbmRlbnQiLCJncm91cGVkTGltaXQiLCJpbmRleFZpYUFsdGVyIiwiSlNPTiIsImRlZmVycmFibGVDb25zdHJhaW50cyIsIm1vZHVsZSIsImV4cG9ydHMiXSwibWFwcGluZ3MiOiJBQUFBOzs7O0lBRU1BLGU7Ozs7QUFFTkEsZUFBZSxDQUFDQyxTQUFoQixDQUEwQkMsUUFBMUIsR0FBcUM7QUFDbkMsYUFBVyxJQUR3QjtBQUVuQyxvQkFBa0IsS0FGaUI7QUFHbkMsZUFBYSxLQUhzQjtBQUluQyxxQkFBbUIsS0FKZ0I7QUFLbkMsc0JBQW9CLElBTGU7QUFNbkMsaUJBQWUsS0FOb0I7QUFPbkMsV0FBUyxJQVAwQjtBQVFuQyxlQUFhLElBUnNCO0FBU25DLGdCQUFjLElBVHFCOztBQVduQztBQUNBQyxFQUFBQSxZQUFZLEVBQUUsS0FacUI7O0FBY25DO0FBQ0FDLEVBQUFBLGFBQWEsRUFBRTtBQUNiO0FBQ0FDLElBQUFBLGNBQWMsRUFBRSxLQUZIOztBQUliO0FBQ0FDLElBQUFBLFlBQVksRUFBRSxJQUxEOztBQU9iO0FBQ0FDLElBQUFBLE1BQU0sRUFBRTtBQVJLLEdBZm9COztBQXlCbkM7QUFDQUMsRUFBQUEsV0FBVyxFQUFFLEtBMUJzQjtBQTJCbkNDLEVBQUFBLE9BQU8sRUFBRSxLQTNCMEI7QUE0Qm5DQyxFQUFBQSxZQUFZLEVBQUUsSUE1QnFCO0FBNkJuQ0MsRUFBQUEsc0NBQXNDLEVBQUUsSUE3Qkw7QUE4Qm5DQyxFQUFBQSxrQkFBa0IsRUFBRTtBQUNsQkMsSUFBQUEsSUFBSSxFQUFFO0FBRFksR0E5QmU7QUFpQ25DQyxFQUFBQSxVQUFVLEVBQUUsSUFqQ3VCO0FBa0NuQ0MsRUFBQUEsT0FBTyxFQUFFLElBbEMwQjtBQW1DbkNDLEVBQUFBLE9BQU8sRUFBRTtBQUNQQyxJQUFBQSxnQkFBZ0IsRUFBRSxFQURYOztBQUNlO0FBQ3RCQyxJQUFBQSxpQkFBaUIsRUFBRSxLQUZaOztBQUVtQjtBQUMxQkMsSUFBQUEsbUJBQW1CLEVBQUU7QUFBRzs7QUFIakIsR0FuQzBCO0FBd0NuQ0MsRUFBQUEsV0FBVyxFQUFFO0FBQ1hDLElBQUFBLFFBQVEsRUFBRSxJQURDO0FBRVhDLElBQUFBLGFBQWEsRUFBRSxJQUZKO0FBR1hDLElBQUFBLGNBQWMsRUFBRSxJQUhMO0FBSVhDLElBQUFBLE1BQU0sRUFBRSxJQUpHO0FBS1hDLElBQUFBLE9BQU8sRUFBRSxLQUxFO0FBTVhDLElBQUFBLEtBQUssRUFBRSxJQU5JO0FBT1hDLElBQUFBLFVBQVUsRUFBRSxJQVBEO0FBUVhDLElBQUFBLFVBQVUsRUFBRTtBQVJELEdBeENzQjtBQWtEbkNDLEVBQUFBLEtBQUssRUFBRTtBQUNMQyxJQUFBQSxPQUFPLEVBQUUsSUFESjtBQUVMQyxJQUFBQSxNQUFNLEVBQUUsS0FGSDtBQUdMQyxJQUFBQSxNQUFNLEVBQUUsS0FISDtBQUlMQyxJQUFBQSxZQUFZLEVBQUUsS0FKVDtBQUtMcEIsSUFBQUEsSUFBSSxFQUFFLEtBTEQ7QUFNTHFCLElBQUFBLEtBQUssRUFBRSxJQU5GO0FBT0xDLElBQUFBLGFBQWEsRUFBRTtBQVBWLEdBbEQ0QjtBQTJEbkNDLEVBQUFBLGtCQUFrQixFQUFFLElBM0RlO0FBNERuQ0MsRUFBQUEsWUFBWSxFQUFFLElBNURxQjtBQTZEbkNDLEVBQUFBLGFBQWEsRUFBRSxLQTdEb0I7QUE4RG5DQyxFQUFBQSxJQUFJLEVBQUUsS0E5RDZCO0FBK0RuQ0MsRUFBQUEscUJBQXFCLEVBQUU7QUEvRFksQ0FBckM7QUFrRUFDLE1BQU0sQ0FBQ0MsT0FBUCxHQUFpQjFDLGVBQWpCO0FBQ0F5QyxNQUFNLENBQUNDLE9BQVAsQ0FBZTFDLGVBQWYsR0FBaUNBLGVBQWpDO0FBQ0F5QyxNQUFNLENBQUNDLE9BQVAsQ0FBZWpCLE9BQWYsR0FBeUJ6QixlQUF6QiIsInNvdXJjZXNDb250ZW50IjpbIid1c2Ugc3RyaWN0JztcblxuY2xhc3MgQWJzdHJhY3REaWFsZWN0IHt9XG5cbkFic3RyYWN0RGlhbGVjdC5wcm90b3R5cGUuc3VwcG9ydHMgPSB7XG4gICdERUZBVUxUJzogdHJ1ZSxcbiAgJ0RFRkFVTFQgVkFMVUVTJzogZmFsc2UsXG4gICdWQUxVRVMgKCknOiBmYWxzZSxcbiAgJ0xJTUlUIE9OIFVQREFURSc6IGZhbHNlLFxuICAnT04gRFVQTElDQVRFIEtFWSc6IHRydWUsXG4gICdPUkRFUiBOVUxMUyc6IGZhbHNlLFxuICAnVU5JT04nOiB0cnVlLFxuICAnVU5JT04gQUxMJzogdHJ1ZSxcbiAgJ1JJR0hUIEpPSU4nOiB0cnVlLFxuXG4gIC8qIGRvZXMgdGhlIGRpYWxlY3Qgc3VwcG9ydCByZXR1cm5pbmcgdmFsdWVzIGZvciBpbnNlcnRlZC91cGRhdGVkIGZpZWxkcyAqL1xuICByZXR1cm5WYWx1ZXM6IGZhbHNlLFxuXG4gIC8qIGZlYXR1cmVzIHNwZWNpZmljIHRvIGF1dG9JbmNyZW1lbnQgdmFsdWVzICovXG4gIGF1dG9JbmNyZW1lbnQ6IHtcbiAgICAvKiBkb2VzIHRoZSBkaWFsZWN0IHJlcXVpcmUgbW9kaWZpY2F0aW9uIG9mIGluc2VydCBxdWVyaWVzIHdoZW4gaW5zZXJ0aW5nIGF1dG8gaW5jcmVtZW50IGZpZWxkcyAqL1xuICAgIGlkZW50aXR5SW5zZXJ0OiBmYWxzZSxcblxuICAgIC8qIGRvZXMgdGhlIGRpYWxlY3Qgc3VwcG9ydCBpbnNlcnRpbmcgZGVmYXVsdC9udWxsIHZhbHVlcyBmb3IgYXV0b2luY3JlbWVudCBmaWVsZHMgKi9cbiAgICBkZWZhdWx0VmFsdWU6IHRydWUsXG5cbiAgICAvKiBkb2VzIHRoZSBkaWFsZWN0IHN1cHBvcnQgdXBkYXRpbmcgYXV0b2luY3JlbWVudCBmaWVsZHMgKi9cbiAgICB1cGRhdGU6IHRydWVcbiAgfSxcbiAgLyogRG8gd2UgbmVlZCB0byBzYXkgREVGQVVMVCBmb3IgYnVsayBpbnNlcnQgKi9cbiAgYnVsa0RlZmF1bHQ6IGZhbHNlLFxuICBzY2hlbWFzOiBmYWxzZSxcbiAgdHJhbnNhY3Rpb25zOiB0cnVlLFxuICBzZXR0aW5nSXNvbGF0aW9uTGV2ZWxEdXJpbmdUcmFuc2FjdGlvbjogdHJ1ZSxcbiAgdHJhbnNhY3Rpb25PcHRpb25zOiB7XG4gICAgdHlwZTogZmFsc2VcbiAgfSxcbiAgbWlncmF0aW9uczogdHJ1ZSxcbiAgdXBzZXJ0czogdHJ1ZSxcbiAgaW5zZXJ0czoge1xuICAgIGlnbm9yZUR1cGxpY2F0ZXM6ICcnLCAvKiBkaWFsZWN0IHNwZWNpZmljIHdvcmRzIGZvciBJTlNFUlQgSUdOT1JFIG9yIERPIE5PVEhJTkcgKi9cbiAgICB1cGRhdGVPbkR1cGxpY2F0ZTogZmFsc2UsIC8qIHdoZXRoZXIgZGlhbGVjdCBzdXBwb3J0cyBPTiBEVVBMSUNBVEUgS0VZIFVQREFURSAqL1xuICAgIG9uQ29uZmxpY3REb05vdGhpbmc6ICcnIC8qIGRpYWxlY3Qgc3BlY2lmaWMgd29yZHMgZm9yIE9OIENPTkZMSUNUIERPIE5PVEhJTkcgKi9cbiAgfSxcbiAgY29uc3RyYWludHM6IHtcbiAgICByZXN0cmljdDogdHJ1ZSxcbiAgICBhZGRDb25zdHJhaW50OiB0cnVlLFxuICAgIGRyb3BDb25zdHJhaW50OiB0cnVlLFxuICAgIHVuaXF1ZTogdHJ1ZSxcbiAgICBkZWZhdWx0OiBmYWxzZSxcbiAgICBjaGVjazogdHJ1ZSxcbiAgICBmb3JlaWduS2V5OiB0cnVlLFxuICAgIHByaW1hcnlLZXk6IHRydWVcbiAgfSxcbiAgaW5kZXg6IHtcbiAgICBjb2xsYXRlOiB0cnVlLFxuICAgIGxlbmd0aDogZmFsc2UsXG4gICAgcGFyc2VyOiBmYWxzZSxcbiAgICBjb25jdXJyZW50bHk6IGZhbHNlLFxuICAgIHR5cGU6IGZhbHNlLFxuICAgIHVzaW5nOiB0cnVlLFxuICAgIGZ1bmN0aW9uQmFzZWQ6IGZhbHNlXG4gIH0sXG4gIGpvaW5UYWJsZURlcGVuZGVudDogdHJ1ZSxcbiAgZ3JvdXBlZExpbWl0OiB0cnVlLFxuICBpbmRleFZpYUFsdGVyOiBmYWxzZSxcbiAgSlNPTjogZmFsc2UsXG4gIGRlZmVycmFibGVDb25zdHJhaW50czogZmFsc2Vcbn07XG5cbm1vZHVsZS5leHBvcnRzID0gQWJzdHJhY3REaWFsZWN0O1xubW9kdWxlLmV4cG9ydHMuQWJzdHJhY3REaWFsZWN0ID0gQWJzdHJhY3REaWFsZWN0O1xubW9kdWxlLmV4cG9ydHMuZGVmYXVsdCA9IEFic3RyYWN0RGlhbGVjdDtcbiJdfQ== \ No newline at end of file diff --git a/dist/dialects/abstract/query-generator.js b/dist/dialects/abstract/query-generator.js index 3112537..6a0ad13 100644 --- a/dist/dialects/abstract/query-generator.js +++ b/dist/dialects/abstract/query-generator.js @@ -46,9 +46,7 @@ const QuoteHelper = require('./query-generator/helpers/quote'); */ -let QueryGenerator = -/*#__PURE__*/ -function () { +let QueryGenerator = /*#__PURE__*/function () { function QueryGenerator(options) { _classCallCheck(this, QueryGenerator); @@ -771,7 +769,7 @@ function () { the values of cols (which is assumed to be an array), quoted and joined with ', ', unless they are themselves objects * If direction is set, should be prepended - Currently this function is only used for ordering / grouping columns and Sequelize.col(), but it could + Currently this function is only used for ordering / grouping columns and Sequelize.col(), but it could potentially also be used for other places where we want to be able to call SQL functions (e.g. as default values) @private */ @@ -2800,4 +2798,4 @@ function () { Object.assign(QueryGenerator.prototype, require('./query-generator/operators')); Object.assign(QueryGenerator.prototype, require('./query-generator/transaction')); module.exports = QueryGenerator; -//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../lib/dialects/abstract/query-generator.js"],"names":["util","require","_","uuidv4","semver","Utils","deprecations","SqlString","DataTypes","Model","Association","BelongsTo","BelongsToMany","HasMany","Op","sequelizeError","IndexHints","QuoteHelper","QueryGenerator","options","sequelize","Error","_dialect","dialect","name","tableName","schema","isPlainObject","delimiter","param","_schema","self","table","_schemaDelimiter","toString","quoteTable","dropTableQuery","schemaDelimiter","addSchema","before","after","valueHash","modelAttributes","defaults","modelAttributeMap","fields","values","bind","quotedTable","bindParam","undefined","query","valueQuery","emptyQuery","outputFragment","identityWrapperRequired","tmpTable","each","attribute","key","field","supports","returnValues","returning","output","hasTrigger","tmpTableTrigger","tmpColumns","outputColumns","modelKey","type","VIRTUAL","length","quoteIdentifier","toSql","selectFromTmp","get","searchPath","EXCEPTION","exception","removeNullValuesFromHash","omitNull","Object","prototype","hasOwnProperty","call","value","push","autoIncrement","defaultValue","splice","DEFAULT","escape","SequelizeMethod","context","format","replacements","ignoreDuplicates","inserts","onConflictDoNothing","attributes","join","gte","databaseVersion","replace","onDuplicate","identityInsert","result","fieldValueHashes","fieldMappedAttributes","tuples","serials","allAttributes","onDuplicateKeyUpdate","fieldValueHash","forOwn","includes","map","bulkDefault","updateOnDuplicate","conflictKeys","upsertKeys","attr","updateKeys","valueKeys","Array","isArray","attrValueHash","where","suffix","limit","mapToModel","update","whereOptions","whereQuery","trim","operator","returningFragment","rawTablename","prefix","fieldsSql","handleSequelizeMethod","inspect","index","collate","order","nameIndex","_conformIndex","quoteIdentifiers","concurrently","ind","indexViaAlter","concat","unique","using","parser","compact","constraintSnippet","getConstraintSnippet","constraintName","fieldsSqlQuotedString","fieldsSqlString","toUpperCase","whereItemsQuery","references","referencesSnippet","onUpdate","onDelete","collection","parent","connector","validOrderOptions","forEach","item","previous","previousAssociation","previousModel","target","model","as","through","getAssociationForAlias","orderIndex","indexOf","literal","associations","rawAttributes","itemSplit","split","JSON","identifier","path","slice","jsonPathExtractionQuery","collectionLength","tableNames","i","_modelAttribute","sql","collectionItem","quote","fieldName","raw","force","identifiers","head","tail","alias","isObject","schemas","validate","stringify","simpleEscape","escVal","timezone","operation","identity","typeValidation","isList","error","ValidationError","errors","ValidationErrorItem","message","isIdentifierQuoted","column","paths","toPath","pathStr","quotedColumn","subPath","test","addTicks","__","digit","mainQueryItems","subQueryItems","subQuery","hasMultiAssociation","main","mainTable","quotedName","topLevelInfo","names","mainJoinQueries","subJoinQueries","minifyAliases","aliasesMapping","Map","aliasesByTable","tableAs","t","keyAtt","primaryKeyAttributes","some","escapeAttributes","include","groupedLimit","separate","joinQueries","generateInclude","externalAs","internalAs","mainQuery","uniq","selectFromTableFragment","assign","groupedLimitOrder","whereKey","groupedTableName","on","foreignKeyField","manyFromSource","groupedLimitOptions","_validateIncludedElements","association","duplicating","required","placeholder","hasJoin","includeMap","includeNames","baseQuery","selectQuery","offset","placeHolder","whereItemQuery","splicePos","groupWhere","foreignIdentifierField","spliceStr","getWhereConditions","startsWith","group","aliasGrouping","having","orders","getQueryOrders","mainQueryOrder","subQueryOrder","limitOrder","addLimitAndOffset","lock","level","lockKey","forShare","lockOf","of","skipLocked","src","_getAliasForField","mainTableAs","addTable","noRawAttributes","_getMinifiedAlias","TICK_CHAR","quoteAttribute","isEmpty","parentTableName","mainChildIncludes","subChildIncludes","requiredMismatch","includeAs","joinQuery","keysEscaped","includeIgnoreAttributes","_expandAttributes","mapFinderOptions","includeAttributes","attrAs","verbatim","Literal","Cast","Fn","val","generateThroughJoin","_generateSubQueryFilter","generateJoin","childInclude","_pseudo","childJoinQueries","body","condition","match","minifiedAlias","size","set","parentIsTop","$parent","joinWhere","left","source","attrLeft","sourceKeyAttribute","primaryKeyAttribute","fieldLeft","identifierField","asLeft","right","tableRight","getTableName","fieldRight","targetIdentifier","asRight","joinOn","subqueryAttributes","joinSource","or","throughTable","throughAs","externalThroughAs","throughAttributes","tableSource","identSource","tableTarget","identTarget","attrTarget","targetKeyField","joinType","joinBody","joinCondition","attrSource","sourceKey","sourceJoinOn","targetJoinOn","throughWhere","targetWhere","sourceKeyField","mainModel","aliasedSource","joinTableDependent","subQueryFilter","child","nestedIncludes","_getRequiredClosure","topInclude","topParent","topAssociation","primaryKeyField","toTarget","and","isBelongsTo","associationType","sourceField","targetField","copy","filter","inc","subQueryAttribute","find","a","modelName","Col","tables","fragment","indexHints","hint","indexName","smth","factory","prepend","OperatorMap","comparator","Where","logic","booleanValue","fn","args","arg","col","binding","getComplexSize","items","getComplexKeys","prop","keyParts","tmp","_findField","fieldType","OperatorsAliasMap","_replaceAliases","opValue","_joinKeyValue","is","eq","canTreatArrayAsAnd","not","_whereGroupBind","_whereBind","ARRAY","json","_whereJSON","_whereParseSingleValueObject","in","fieldRawAttributesMap","outerBinding","itemQuery","baseKey","getOperators","op","_traverseJSON","cast","pathKey","_toJSONValue","_castKey","itemProp","_getJsonCast","Date","_getSafeKey","_prefixKey","isColString","substr","notIn","ne","any","all","between","notBetween","like","endsWith","substring","escapeOptions","acceptStrings","primaryKeys","keys","Buffer","isBuffer","_smth","conditions","reduce","parseConditionObject","module","exports"],"mappings":"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","sourcesContent":["'use strict';\r\n\r\nconst util = require('util');\r\nconst _ = require('lodash');\r\nconst uuidv4 = require('uuid/v4');\r\nconst semver = require('semver');\r\n\r\nconst Utils = require('../../utils');\r\nconst deprecations = require('../../utils/deprecations');\r\nconst SqlString = require('../../sql-string');\r\nconst DataTypes = require('../../data-types');\r\nconst Model = require('../../model');\r\nconst Association = require('../../associations/base');\r\nconst BelongsTo = require('../../associations/belongs-to');\r\nconst BelongsToMany = require('../../associations/belongs-to-many');\r\nconst HasMany = require('../../associations/has-many');\r\nconst Op = require('../../operators');\r\nconst sequelizeError = require('../../errors');\r\nconst IndexHints = require('../../index-hints');\r\n\r\nconst QuoteHelper = require('./query-generator/helpers/quote');\r\n\r\n/**\r\n * Abstract Query Generator\r\n *\r\n * @private\r\n */\r\nclass QueryGenerator {\r\n  constructor(options) {\r\n    if (!options.sequelize) throw new Error('QueryGenerator initialized without options.sequelize');\r\n    if (!options._dialect) throw new Error('QueryGenerator initialized without options._dialect');\r\n\r\n    this.sequelize = options.sequelize;\r\n    this.options = options.sequelize.options;\r\n\r\n    // dialect name\r\n    this.dialect = options._dialect.name;\r\n    this._dialect = options._dialect;\r\n  }\r\n\r\n  extractTableDetails(tableName, options) {\r\n    options = options || {};\r\n    tableName = tableName || {};\r\n    return {\r\n      schema: tableName.schema || options.schema || 'public',\r\n      tableName: _.isPlainObject(tableName) ? tableName.tableName : tableName,\r\n      delimiter: tableName.delimiter || options.delimiter || '.'\r\n    };\r\n  }\r\n\r\n  addSchema(param) {\r\n    if (!param._schema) return param.tableName || param;\r\n    const self = this;\r\n    return {\r\n      tableName: param.tableName || param,\r\n      table: param.tableName || param,\r\n      name: param.name || param,\r\n      schema: param._schema,\r\n      delimiter: param._schemaDelimiter || '.',\r\n      toString() {\r\n        return self.quoteTable(this);\r\n      }\r\n    };\r\n  }\r\n\r\n  dropSchema(tableName, options) {\r\n    return this.dropTableQuery(tableName, options);\r\n  }\r\n\r\n  describeTableQuery(tableName, schema, schemaDelimiter) {\r\n    const table = this.quoteTable(\r\n      this.addSchema({\r\n        tableName,\r\n        _schema: schema,\r\n        _schemaDelimiter: schemaDelimiter\r\n      })\r\n    );\r\n\r\n    return `DESCRIBE ${table};`;\r\n  }\r\n\r\n  dropTableQuery(tableName) {\r\n    return `DROP TABLE IF EXISTS ${this.quoteTable(tableName)};`;\r\n  }\r\n\r\n  renameTableQuery(before, after) {\r\n    return `ALTER TABLE ${this.quoteTable(before)} RENAME TO ${this.quoteTable(after)};`;\r\n  }\r\n\r\n  /**\r\n   * Returns an insert into command\r\n   *\r\n   * @param {string} table\r\n   * @param {Object} valueHash       attribute value pairs\r\n   * @param {Object} modelAttributes\r\n   * @param {Object} [options]\r\n   *\r\n   * @private\r\n   */\r\n  insertQuery(table, valueHash, modelAttributes, options) {\r\n    options = options || {};\r\n    _.defaults(options, this.options);\r\n\r\n    const modelAttributeMap = {};\r\n    const fields = [];\r\n    const values = [];\r\n    const bind = [];\r\n    const quotedTable = this.quoteTable(table);\r\n    const bindParam = options.bindParam === undefined ? this.bindParam(bind) : options.bindParam;\r\n    let query;\r\n    let valueQuery = '';\r\n    let emptyQuery = '';\r\n    let outputFragment = '';\r\n    let identityWrapperRequired = false;\r\n    let tmpTable = ''; //tmpTable declaration for trigger\r\n\r\n    if (modelAttributes) {\r\n      _.each(modelAttributes, (attribute, key) => {\r\n        modelAttributeMap[key] = attribute;\r\n        if (attribute.field) {\r\n          modelAttributeMap[attribute.field] = attribute;\r\n        }\r\n      });\r\n    }\r\n\r\n    if (this._dialect.supports['DEFAULT VALUES']) {\r\n      emptyQuery += ' DEFAULT VALUES';\r\n    } else if (this._dialect.supports['VALUES ()']) {\r\n      emptyQuery += ' VALUES ()';\r\n    }\r\n\r\n    if (this._dialect.supports.returnValues && options.returning) {\r\n      if (this._dialect.supports.returnValues.returning) {\r\n        valueQuery += ' RETURNING *';\r\n        emptyQuery += ' RETURNING *';\r\n      } else if (this._dialect.supports.returnValues.output) {\r\n        outputFragment = ' OUTPUT INSERTED.*';\r\n\r\n        //To capture output rows when there is a trigger on MSSQL DB\r\n        if (modelAttributes && options.hasTrigger && this._dialect.supports.tmpTableTrigger) {\r\n\r\n          let tmpColumns = '';\r\n          let outputColumns = '';\r\n\r\n          for (const modelKey in modelAttributes) {\r\n            const attribute = modelAttributes[modelKey];\r\n            if (!(attribute.type instanceof DataTypes.VIRTUAL)) {\r\n              if (tmpColumns.length > 0) {\r\n                tmpColumns += ',';\r\n                outputColumns += ',';\r\n              }\r\n\r\n              tmpColumns += `${this.quoteIdentifier(attribute.field)} ${attribute.type.toSql()}`;\r\n              outputColumns += `INSERTED.${this.quoteIdentifier(attribute.field)}`;\r\n            }\r\n          }\r\n\r\n          tmpTable = `declare @tmp table (${tmpColumns});`;\r\n          outputFragment = ` OUTPUT ${outputColumns} into @tmp`;\r\n          const selectFromTmp = ';select * from @tmp';\r\n\r\n          valueQuery += selectFromTmp;\r\n          emptyQuery += selectFromTmp;\r\n        }\r\n      }\r\n    }\r\n\r\n    if (_.get(this, ['sequelize', 'options', 'dialectOptions', 'prependSearchPath']) || options.searchPath) {\r\n      // Not currently supported with search path (requires output of multiple queries)\r\n      options.bindParam = false;\r\n    }\r\n\r\n    if (this._dialect.supports.EXCEPTION && options.exception) {\r\n      // Not currently supported with bind parameters (requires output of multiple queries)\r\n      options.bindParam = false;\r\n    }\r\n\r\n    valueHash = Utils.removeNullValuesFromHash(valueHash, this.options.omitNull);\r\n    for (const key in valueHash) {\r\n      if (Object.prototype.hasOwnProperty.call(valueHash, key)) {\r\n        const value = valueHash[key];\r\n        fields.push(this.quoteIdentifier(key));\r\n\r\n        // SERIALS' can't be NULL in postgresql, use DEFAULT where supported\r\n        if (modelAttributeMap && modelAttributeMap[key] && modelAttributeMap[key].autoIncrement === true && !value) {\r\n          if (!this._dialect.supports.autoIncrement.defaultValue) {\r\n            fields.splice(-1, 1);\r\n          } else if (this._dialect.supports.DEFAULT) {\r\n            values.push('DEFAULT');\r\n          } else {\r\n            values.push(this.escape(null));\r\n          }\r\n        } else {\r\n          if (modelAttributeMap && modelAttributeMap[key] && modelAttributeMap[key].autoIncrement === true) {\r\n            identityWrapperRequired = true;\r\n          }\r\n\r\n          if (value instanceof Utils.SequelizeMethod || options.bindParam === false) {\r\n            values.push(this.escape(value, modelAttributeMap && modelAttributeMap[key] || undefined, { context: 'INSERT' }));\r\n          } else {\r\n            values.push(this.format(value, modelAttributeMap && modelAttributeMap[key] || undefined, { context: 'INSERT' }, bindParam));\r\n          }\r\n        }\r\n      }\r\n    }\r\n\r\n    const replacements = {\r\n      ignoreDuplicates: options.ignoreDuplicates ? this._dialect.supports.inserts.ignoreDuplicates : '',\r\n      onConflictDoNothing: options.ignoreDuplicates ? this._dialect.supports.inserts.onConflictDoNothing : '',\r\n      attributes: fields.join(','),\r\n      output: outputFragment,\r\n      values: values.join(','),\r\n      tmpTable\r\n    };\r\n\r\n    valueQuery = `${tmpTable}INSERT${replacements.ignoreDuplicates} INTO ${quotedTable} (${replacements.attributes})${replacements.output} VALUES (${replacements.values})${replacements.onConflictDoNothing}${valueQuery}`;\r\n    emptyQuery = `${tmpTable}INSERT${replacements.ignoreDuplicates} INTO ${quotedTable}${replacements.output}${replacements.onConflictDoNothing}${emptyQuery}`;\r\n\r\n    if (this._dialect.supports.EXCEPTION && options.exception) {\r\n      // Mostly for internal use, so we expect the user to know what he's doing!\r\n      // pg_temp functions are private per connection, so we never risk this function interfering with another one.\r\n      if (semver.gte(this.sequelize.options.databaseVersion, '9.2.0')) {\r\n        // >= 9.2 - Use a UUID but prefix with 'func_' (numbers first not allowed)\r\n        const delimiter = `$func_${uuidv4().replace(/-/g, '')}$`;\r\n\r\n        options.exception = 'WHEN unique_violation THEN GET STACKED DIAGNOSTICS sequelize_caught_exception = PG_EXCEPTION_DETAIL;';\r\n        valueQuery = `${`CREATE OR REPLACE FUNCTION pg_temp.testfunc(OUT response ${quotedTable}, OUT sequelize_caught_exception text) RETURNS RECORD AS ${delimiter}` +\r\n          ' BEGIN '}${valueQuery} INTO response; EXCEPTION ${options.exception} END ${delimiter\r\n        } LANGUAGE plpgsql; SELECT (testfunc.response).*, testfunc.sequelize_caught_exception FROM pg_temp.testfunc(); DROP FUNCTION IF EXISTS pg_temp.testfunc()`;\r\n      } else {\r\n        options.exception = 'WHEN unique_violation THEN NULL;';\r\n        valueQuery = `CREATE OR REPLACE FUNCTION pg_temp.testfunc() RETURNS SETOF ${quotedTable} AS $body$ BEGIN RETURN QUERY ${valueQuery}; EXCEPTION ${options.exception} END; $body$ LANGUAGE plpgsql; SELECT * FROM pg_temp.testfunc(); DROP FUNCTION IF EXISTS pg_temp.testfunc();`;\r\n      }\r\n    }\r\n\r\n    if (this._dialect.supports['ON DUPLICATE KEY'] && options.onDuplicate) {\r\n      valueQuery += ` ON DUPLICATE KEY ${options.onDuplicate}`;\r\n      emptyQuery += ` ON DUPLICATE KEY ${options.onDuplicate}`;\r\n    }\r\n\r\n    query = `${replacements.attributes.length ? valueQuery : emptyQuery};`;\r\n    if (identityWrapperRequired && this._dialect.supports.autoIncrement.identityInsert) {\r\n      query = `SET IDENTITY_INSERT ${quotedTable} ON; ${query} SET IDENTITY_INSERT ${quotedTable} OFF;`;\r\n    }\r\n\r\n    // Used by Postgres upsertQuery and calls to here with options.exception set to true\r\n    const result = { query };\r\n    if (options.bindParam !== false) {\r\n      result.bind = bind;\r\n    }\r\n    return result;\r\n  }\r\n\r\n  /**\r\n   * Returns an insert into command for multiple values.\r\n   *\r\n   * @param {string} tableName\r\n   * @param {Object} fieldValueHashes\r\n   * @param {Object} options\r\n   * @param {Object} fieldMappedAttributes\r\n   *\r\n   * @private\r\n   */\r\n  bulkInsertQuery(tableName, fieldValueHashes, options, fieldMappedAttributes) {\r\n    options = options || {};\r\n    fieldMappedAttributes = fieldMappedAttributes || {};\r\n\r\n    const tuples = [];\r\n    const serials = {};\r\n    const allAttributes = [];\r\n    let onDuplicateKeyUpdate = '';\r\n\r\n    for (const fieldValueHash of fieldValueHashes) {\r\n      _.forOwn(fieldValueHash, (value, key) => {\r\n        if (!allAttributes.includes(key)) {\r\n          allAttributes.push(key);\r\n        }\r\n        if (\r\n          fieldMappedAttributes[key]\r\n          && fieldMappedAttributes[key].autoIncrement === true\r\n        ) {\r\n          serials[key] = true;\r\n        }\r\n      });\r\n    }\r\n\r\n    for (const fieldValueHash of fieldValueHashes) {\r\n      const values = allAttributes.map(key => {\r\n        if (\r\n          this._dialect.supports.bulkDefault\r\n          && serials[key] === true\r\n        ) {\r\n          return fieldValueHash[key] || 'DEFAULT';\r\n        }\r\n\r\n        return this.escape(fieldValueHash[key], fieldMappedAttributes[key], { context: 'INSERT' });\r\n      });\r\n\r\n      tuples.push(`(${values.join(',')})`);\r\n    }\r\n\r\n    if (this._dialect.supports.inserts.updateOnDuplicate && options.updateOnDuplicate) {\r\n      if (this._dialect.supports.inserts.updateOnDuplicate == ' ON CONFLICT DO UPDATE SET') { // postgres / sqlite\r\n        // If no conflict target columns were specified, use the primary key names from options.upsertKeys\r\n        const conflictKeys = options.upsertKeys.map(attr => this.quoteIdentifier(attr));\r\n        const updateKeys = options.updateOnDuplicate.map(attr => `${this.quoteIdentifier(attr)}=EXCLUDED.${this.quoteIdentifier(attr)}`);\r\n        onDuplicateKeyUpdate = ` ON CONFLICT (${conflictKeys.join(',')}) DO UPDATE SET ${updateKeys.join(',')}`;\r\n      } else { // mysql / maria\r\n        const valueKeys = options.updateOnDuplicate.map(attr => `${this.quoteIdentifier(attr)}=VALUES(${this.quoteIdentifier(attr)})`);\r\n        onDuplicateKeyUpdate = `${this._dialect.supports.inserts.updateOnDuplicate} ${valueKeys.join(',')}`;\r\n      }\r\n    }\r\n\r\n    const ignoreDuplicates = options.ignoreDuplicates ? this._dialect.supports.inserts.ignoreDuplicates : '';\r\n    const attributes = allAttributes.map(attr => this.quoteIdentifier(attr)).join(',');\r\n    const onConflictDoNothing = options.ignoreDuplicates ? this._dialect.supports.inserts.onConflictDoNothing : '';\r\n    let returning = '';\r\n\r\n    if (this._dialect.supports.returnValues && Array.isArray(options.returning)) {\r\n      const fields = options.returning.map(field => this.quoteIdentifier(field)).join(',');\r\n      returning += ` RETURNING ${fields}`;\r\n    } else {\r\n      returning += this._dialect.supports.returnValues && options.returning ? ' RETURNING *' : '';\r\n    }\r\n\r\n    return `INSERT${ignoreDuplicates} INTO ${this.quoteTable(tableName)} (${attributes}) VALUES ${tuples.join(',')}${onDuplicateKeyUpdate}${onConflictDoNothing}${returning};`;\r\n  }\r\n\r\n  /**\r\n   * Returns an update query\r\n   *\r\n   * @param {string} tableName\r\n   * @param {Object} attrValueHash\r\n   * @param {Object} where A hash with conditions (e.g. {name: 'foo'}) OR an ID as integer\r\n   * @param {Object} options\r\n   * @param {Object} attributes\r\n   *\r\n   * @private\r\n   */\r\n  updateQuery(tableName, attrValueHash, where, options, attributes) {\r\n    options = options || {};\r\n    _.defaults(options, this.options);\r\n\r\n    attrValueHash = Utils.removeNullValuesFromHash(attrValueHash, options.omitNull, options);\r\n\r\n    const values = [];\r\n    const bind = [];\r\n    const modelAttributeMap = {};\r\n    let outputFragment = '';\r\n    let tmpTable = ''; // tmpTable declaration for trigger\r\n    let selectFromTmp = ''; // Select statement for trigger\r\n    let suffix = '';\r\n\r\n    if (_.get(this, ['sequelize', 'options', 'dialectOptions', 'prependSearchPath']) || options.searchPath) {\r\n      // Not currently supported with search path (requires output of multiple queries)\r\n      options.bindParam = false;\r\n    }\r\n\r\n    const bindParam = options.bindParam === undefined ? this.bindParam(bind) : options.bindParam;\r\n\r\n    if (this._dialect.supports['LIMIT ON UPDATE'] && options.limit) {\r\n      if (this.dialect !== 'mssql') {\r\n        suffix = ` LIMIT ${this.escape(options.limit)} `;\r\n      }\r\n    }\r\n\r\n    if (this._dialect.supports.returnValues) {\r\n      if (this._dialect.supports.returnValues.output) {\r\n        // we always need this for mssql\r\n        outputFragment = ' OUTPUT INSERTED.*';\r\n\r\n        //To capture output rows when there is a trigger on MSSQL DB\r\n        if (attributes && options.hasTrigger && this._dialect.supports.tmpTableTrigger) {\r\n          let tmpColumns = '';\r\n          let outputColumns = '';\r\n\r\n          for (const modelKey in attributes) {\r\n            const attribute = attributes[modelKey];\r\n            if (!(attribute.type instanceof DataTypes.VIRTUAL)) {\r\n              if (tmpColumns.length > 0) {\r\n                tmpColumns += ',';\r\n                outputColumns += ',';\r\n              }\r\n\r\n              tmpColumns += `${this.quoteIdentifier(attribute.field)} ${attribute.type.toSql()}`;\r\n              outputColumns += `INSERTED.${this.quoteIdentifier(attribute.field)}`;\r\n            }\r\n          }\r\n\r\n          tmpTable = `declare @tmp table (${tmpColumns}); `;\r\n          outputFragment = ` OUTPUT ${outputColumns} into @tmp`;\r\n          selectFromTmp = ';select * from @tmp';\r\n\r\n          suffix += selectFromTmp;\r\n        }\r\n      } else if (this._dialect.supports.returnValues && options.returning) {\r\n        // ensure that the return output is properly mapped to model fields.\r\n        options.mapToModel = true;\r\n        suffix += ' RETURNING *';\r\n      }\r\n    }\r\n\r\n    if (attributes) {\r\n      _.each(attributes, (attribute, key) => {\r\n        modelAttributeMap[key] = attribute;\r\n        if (attribute.field) {\r\n          modelAttributeMap[attribute.field] = attribute;\r\n        }\r\n      });\r\n    }\r\n\r\n    for (const key in attrValueHash) {\r\n      if (modelAttributeMap && modelAttributeMap[key] &&\r\n        modelAttributeMap[key].autoIncrement === true &&\r\n        !this._dialect.supports.autoIncrement.update) {\r\n        // not allowed to update identity column\r\n        continue;\r\n      }\r\n\r\n      const value = attrValueHash[key];\r\n\r\n      if (value instanceof Utils.SequelizeMethod || options.bindParam === false) {\r\n        values.push(`${this.quoteIdentifier(key)}=${this.escape(value, modelAttributeMap && modelAttributeMap[key] || undefined, { context: 'UPDATE' })}`);\r\n      } else {\r\n        values.push(`${this.quoteIdentifier(key)}=${this.format(value, modelAttributeMap && modelAttributeMap[key] || undefined, { context: 'UPDATE' }, bindParam)}`);\r\n      }\r\n    }\r\n\r\n    const whereOptions = _.defaults({ bindParam }, options);\r\n\r\n    if (values.length === 0) {\r\n      return '';\r\n    }\r\n\r\n    const query = `${tmpTable}UPDATE ${this.quoteTable(tableName)} SET ${values.join(',')}${outputFragment} ${this.whereQuery(where, whereOptions)}${suffix}`.trim();\r\n    // Used by Postgres upsertQuery and calls to here with options.exception set to true\r\n    const result = { query };\r\n    if (options.bindParam !== false) {\r\n      result.bind = bind;\r\n    }\r\n    return result;\r\n  }\r\n\r\n  /**\r\n   * Returns an update query using arithmetic operator\r\n   *\r\n   * @param {string} operator      String with the arithmetic operator (e.g. '+' or '-')\r\n   * @param {string} tableName     Name of the table\r\n   * @param {Object} attrValueHash A hash with attribute-value-pairs\r\n   * @param {Object} where         A hash with conditions (e.g. {name: 'foo'}) OR an ID as integer\r\n   * @param {Object} options\r\n   * @param {Object} attributes\r\n   */\r\n  arithmeticQuery(operator, tableName, attrValueHash, where, options, attributes) {\r\n    options = options || {};\r\n    _.defaults(options, { returning: true });\r\n\r\n    attrValueHash = Utils.removeNullValuesFromHash(attrValueHash, this.options.omitNull);\r\n\r\n    const values = [];\r\n    let outputFragment = '';\r\n    let returningFragment = '';\r\n\r\n    if (this._dialect.supports.returnValues && options.returning) {\r\n      if (this._dialect.supports.returnValues.returning) {\r\n        options.mapToModel = true;\r\n        returningFragment = 'RETURNING *';\r\n      } else if (this._dialect.supports.returnValues.output) {\r\n        outputFragment = ' OUTPUT INSERTED.*';\r\n      }\r\n    }\r\n\r\n    for (const key in attrValueHash) {\r\n      const value = attrValueHash[key];\r\n      values.push(`${this.quoteIdentifier(key)}=${this.quoteIdentifier(key)}${operator} ${this.escape(value)}`);\r\n    }\r\n\r\n    attributes = attributes || {};\r\n    for (const key in attributes) {\r\n      const value = attributes[key];\r\n      values.push(`${this.quoteIdentifier(key)}=${this.escape(value)}`);\r\n    }\r\n\r\n    return `UPDATE ${this.quoteTable(tableName)} SET ${values.join(',')}${outputFragment} ${this.whereQuery(where)} ${returningFragment}`.trim();\r\n  }\r\n\r\n  /*\r\n    Returns an add index query.\r\n    Parameters:\r\n      - tableName -> Name of an existing table, possibly with schema.\r\n      - options:\r\n        - type: UNIQUE|FULLTEXT|SPATIAL\r\n        - name: The name of the index. Default is <table>_<attr1>_<attr2>\r\n        - fields: An array of attributes as string or as hash.\r\n                  If the attribute is a hash, it must have the following content:\r\n                  - name: The name of the attribute/column\r\n                  - length: An integer. Optional\r\n                  - order: 'ASC' or 'DESC'. Optional\r\n        - parser\r\n        - using\r\n        - operator\r\n        - concurrently: Pass CONCURRENT so other operations run while the index is created\r\n      - rawTablename, the name of the table, without schema. Used to create the name of the index\r\n   @private\r\n  */\r\n  addIndexQuery(tableName, attributes, options, rawTablename) {\r\n    options = options || {};\r\n\r\n    if (!Array.isArray(attributes)) {\r\n      options = attributes;\r\n      attributes = undefined;\r\n    } else {\r\n      options.fields = attributes;\r\n    }\r\n\r\n    options.prefix = options.prefix || rawTablename || tableName;\r\n    if (options.prefix && typeof options.prefix === 'string') {\r\n      options.prefix = options.prefix.replace(/\\./g, '_');\r\n      options.prefix = options.prefix.replace(/(\"|')/g, '');\r\n    }\r\n\r\n    const fieldsSql = options.fields.map(field => {\r\n      if (typeof field === 'string') {\r\n        return this.quoteIdentifier(field);\r\n      }\r\n      if (field instanceof Utils.SequelizeMethod) {\r\n        return this.handleSequelizeMethod(field);\r\n      }\r\n      let result = '';\r\n\r\n      if (field.attribute) {\r\n        field.name = field.attribute;\r\n      }\r\n\r\n      if (!field.name) {\r\n        throw new Error(`The following index field has no name: ${util.inspect(field)}`);\r\n      }\r\n\r\n      result += this.quoteIdentifier(field.name);\r\n\r\n      if (this._dialect.supports.index.collate && field.collate) {\r\n        result += ` COLLATE ${this.quoteIdentifier(field.collate)}`;\r\n      }\r\n\r\n      if (this._dialect.supports.index.length && field.length) {\r\n        result += `(${field.length})`;\r\n      }\r\n\r\n      if (field.order) {\r\n        result += ` ${field.order}`;\r\n      }\r\n\r\n      return result;\r\n    });\r\n\r\n    if (!options.name) {\r\n      // Mostly for cases where addIndex is called directly by the user without an options object (for example in migrations)\r\n      // All calls that go through sequelize should already have a name\r\n      options = Utils.nameIndex(options, options.prefix);\r\n    }\r\n\r\n    options = Model._conformIndex(options);\r\n\r\n    if (!this._dialect.supports.index.type) {\r\n      delete options.type;\r\n    }\r\n\r\n    if (options.where) {\r\n      options.where = this.whereQuery(options.where);\r\n    }\r\n\r\n    if (typeof tableName === 'string') {\r\n      tableName = this.quoteIdentifiers(tableName);\r\n    } else {\r\n      tableName = this.quoteTable(tableName);\r\n    }\r\n\r\n    const concurrently = this._dialect.supports.index.concurrently && options.concurrently ? 'CONCURRENTLY' : undefined;\r\n    let ind;\r\n    if (this._dialect.supports.indexViaAlter) {\r\n      ind = [\r\n        'ALTER TABLE',\r\n        tableName,\r\n        concurrently,\r\n        'ADD'\r\n      ];\r\n    } else {\r\n      ind = ['CREATE'];\r\n    }\r\n\r\n    ind = ind.concat(\r\n      options.unique ? 'UNIQUE' : '',\r\n      options.type, 'INDEX',\r\n      !this._dialect.supports.indexViaAlter ? concurrently : undefined,\r\n      this.quoteIdentifiers(options.name),\r\n      this._dialect.supports.index.using === 1 && options.using ? `USING ${options.using}` : '',\r\n      !this._dialect.supports.indexViaAlter ? `ON ${tableName}` : undefined,\r\n      this._dialect.supports.index.using === 2 && options.using ? `USING ${options.using}` : '',\r\n      `(${fieldsSql.join(', ')}${options.operator ? ` ${options.operator}` : ''})`,\r\n      this._dialect.supports.index.parser && options.parser ? `WITH PARSER ${options.parser}` : undefined,\r\n      this._dialect.supports.index.where && options.where ? options.where : undefined\r\n    );\r\n\r\n    return _.compact(ind).join(' ');\r\n  }\r\n\r\n  addConstraintQuery(tableName, options) {\r\n    options = options || {};\r\n    const constraintSnippet = this.getConstraintSnippet(tableName, options);\r\n\r\n    if (typeof tableName === 'string') {\r\n      tableName = this.quoteIdentifiers(tableName);\r\n    } else {\r\n      tableName = this.quoteTable(tableName);\r\n    }\r\n\r\n    return `ALTER TABLE ${tableName} ADD ${constraintSnippet};`;\r\n  }\r\n\r\n  getConstraintSnippet(tableName, options) {\r\n    let constraintSnippet, constraintName;\r\n\r\n    const fieldsSql = options.fields.map(field => {\r\n      if (typeof field === 'string') {\r\n        return this.quoteIdentifier(field);\r\n      }\r\n      if (field instanceof Utils.SequelizeMethod) {\r\n        return this.handleSequelizeMethod(field);\r\n      }\r\n      if (field.attribute) {\r\n        field.name = field.attribute;\r\n      }\r\n\r\n      if (!field.name) {\r\n        throw new Error(`The following index field has no name: ${field}`);\r\n      }\r\n\r\n      return this.quoteIdentifier(field.name);\r\n    });\r\n\r\n    const fieldsSqlQuotedString = fieldsSql.join(', ');\r\n    const fieldsSqlString = fieldsSql.join('_');\r\n\r\n    switch (options.type.toUpperCase()) {\r\n      case 'UNIQUE':\r\n        constraintName = this.quoteIdentifier(options.name || `${tableName}_${fieldsSqlString}_uk`);\r\n        constraintSnippet = `CONSTRAINT ${constraintName} UNIQUE (${fieldsSqlQuotedString})`;\r\n        break;\r\n      case 'CHECK':\r\n        options.where = this.whereItemsQuery(options.where);\r\n        constraintName = this.quoteIdentifier(options.name || `${tableName}_${fieldsSqlString}_ck`);\r\n        constraintSnippet = `CONSTRAINT ${constraintName} CHECK (${options.where})`;\r\n        break;\r\n      case 'DEFAULT':\r\n        if (options.defaultValue === undefined) {\r\n          throw new Error('Default value must be specifed for DEFAULT CONSTRAINT');\r\n        }\r\n\r\n        if (this._dialect.name !== 'mssql') {\r\n          throw new Error('Default constraints are supported only for MSSQL dialect.');\r\n        }\r\n\r\n        constraintName = this.quoteIdentifier(options.name || `${tableName}_${fieldsSqlString}_df`);\r\n        constraintSnippet = `CONSTRAINT ${constraintName} DEFAULT (${this.escape(options.defaultValue)}) FOR ${fieldsSql[0]}`;\r\n        break;\r\n      case 'PRIMARY KEY':\r\n        constraintName = this.quoteIdentifier(options.name || `${tableName}_${fieldsSqlString}_pk`);\r\n        constraintSnippet = `CONSTRAINT ${constraintName} PRIMARY KEY (${fieldsSqlQuotedString})`;\r\n        break;\r\n      case 'FOREIGN KEY':\r\n        const references = options.references;\r\n        if (!references || !references.table || !references.field) {\r\n          throw new Error('references object with table and field must be specified');\r\n        }\r\n        constraintName = this.quoteIdentifier(options.name || `${tableName}_${fieldsSqlString}_${references.table}_fk`);\r\n        const referencesSnippet = `${this.quoteTable(references.table)} (${this.quoteIdentifier(references.field)})`;\r\n        constraintSnippet = `CONSTRAINT ${constraintName} `;\r\n        constraintSnippet += `FOREIGN KEY (${fieldsSqlQuotedString}) REFERENCES ${referencesSnippet}`;\r\n        if (options.onUpdate) {\r\n          constraintSnippet += ` ON UPDATE ${options.onUpdate.toUpperCase()}`;\r\n        }\r\n        if (options.onDelete) {\r\n          constraintSnippet += ` ON DELETE ${options.onDelete.toUpperCase()}`;\r\n        }\r\n        break;\r\n      default: throw new Error(`${options.type} is invalid.`);\r\n    }\r\n    return constraintSnippet;\r\n  }\r\n\r\n  removeConstraintQuery(tableName, constraintName) {\r\n    if (typeof tableName === 'string') {\r\n      tableName = this.quoteIdentifiers(tableName);\r\n    } else {\r\n      tableName = this.quoteTable(tableName);\r\n    }\r\n\r\n    return `ALTER TABLE ${tableName} DROP CONSTRAINT ${this.quoteIdentifiers(constraintName)}`;\r\n  }\r\n\r\n  /*\r\n    Quote an object based on its type. This is a more general version of quoteIdentifiers\r\n    Strings: should proxy to quoteIdentifiers\r\n    Arrays:\r\n      * Expects array in the form: [<model> (optional), <model> (optional),... String, String (optional)]\r\n        Each <model> can be a model, or an object {model: Model, as: String}, matching include, or an\r\n        association object, or the name of an association.\r\n      * Zero or more models can be included in the array and are used to trace a path through the tree of\r\n        included nested associations. This produces the correct table name for the ORDER BY/GROUP BY SQL\r\n        and quotes it.\r\n      * If a single string is appended to end of array, it is quoted.\r\n        If two strings appended, the 1st string is quoted, the 2nd string unquoted.\r\n    Objects:\r\n      * If raw is set, that value should be returned verbatim, without quoting\r\n      * If fn is set, the string should start with the value of fn, starting paren, followed by\r\n        the values of cols (which is assumed to be an array), quoted and joined with ', ',\r\n        unless they are themselves objects\r\n      * If direction is set, should be prepended\r\n\r\n    Currently this function is only used for ordering / grouping columns and Sequelize.col(), but it could\r\n    potentially also be used for other places where we want to be able to call SQL functions (e.g. as default values)\r\n   @private\r\n  */\r\n  quote(collection, parent, connector) {\r\n    // init\r\n    const validOrderOptions = [\r\n      'ASC',\r\n      'DESC',\r\n      'ASC NULLS LAST',\r\n      'DESC NULLS LAST',\r\n      'ASC NULLS FIRST',\r\n      'DESC NULLS FIRST',\r\n      'NULLS FIRST',\r\n      'NULLS LAST'\r\n    ];\r\n\r\n    // default\r\n    connector = connector || '.';\r\n\r\n    // just quote as identifiers if string\r\n    if (typeof collection === 'string') {\r\n      return this.quoteIdentifiers(collection);\r\n    }\r\n    if (Array.isArray(collection)) {\r\n      // iterate through the collection and mutate objects into associations\r\n      collection.forEach((item, index) => {\r\n        const previous = collection[index - 1];\r\n        let previousAssociation;\r\n        let previousModel;\r\n\r\n        // set the previous as the parent when previous is undefined or the target of the association\r\n        if (!previous && parent !== undefined) {\r\n          previousModel = parent;\r\n        } else if (previous && previous instanceof Association) {\r\n          previousAssociation = previous;\r\n          previousModel = previous.target;\r\n        }\r\n\r\n        // if the previous item is a model, then attempt getting an association\r\n        if (previousModel && previousModel.prototype instanceof Model) {\r\n          let model;\r\n          let as;\r\n\r\n          if (typeof item === 'function' && item.prototype instanceof Model) {\r\n            // set\r\n            model = item;\r\n          } else if (_.isPlainObject(item) && item.model && item.model.prototype instanceof Model) {\r\n            // set\r\n            model = item.model;\r\n            as = item.as;\r\n          }\r\n\r\n          if (model) {\r\n            // set the as to either the through name or the model name\r\n            if (!as && previousAssociation && previousAssociation instanceof Association && previousAssociation.through && previousAssociation.through.model === model) {\r\n              // get from previous association\r\n              item = new Association(previousModel, model, {\r\n                as: model.name\r\n              });\r\n            } else {\r\n              // get association from previous model\r\n              item = previousModel.getAssociationForAlias(model, as);\r\n\r\n              // attempt to use the model name if the item is still null\r\n              if (!item) {\r\n                item = previousModel.getAssociationForAlias(model, model.name);\r\n              }\r\n            }\r\n\r\n            // make sure we have an association\r\n            if (!(item instanceof Association)) {\r\n              throw new Error(util.format('Unable to find a valid association for model, \\'%s\\'', model.name));\r\n            }\r\n          }\r\n        }\r\n\r\n        if (typeof item === 'string') {\r\n          // get order index\r\n          const orderIndex = validOrderOptions.indexOf(item.toUpperCase());\r\n\r\n          // see if this is an order\r\n          if (index > 0 && orderIndex !== -1) {\r\n            item = this.sequelize.literal(` ${validOrderOptions[orderIndex]}`);\r\n          } else if (previousModel && previousModel.prototype instanceof Model) {\r\n            // only go down this path if we have preivous model and check only once\r\n            if (previousModel.associations !== undefined && previousModel.associations[item]) {\r\n              // convert the item to an association\r\n              item = previousModel.associations[item];\r\n            } else if (previousModel.rawAttributes !== undefined && previousModel.rawAttributes[item] && item !== previousModel.rawAttributes[item].field) {\r\n              // convert the item attribute from its alias\r\n              item = previousModel.rawAttributes[item].field;\r\n            } else if (\r\n              item.includes('.')\r\n              && previousModel.rawAttributes !== undefined\r\n            ) {\r\n              const itemSplit = item.split('.');\r\n\r\n              if (previousModel.rawAttributes[itemSplit[0]].type instanceof DataTypes.JSON) {\r\n                // just quote identifiers for now\r\n                const identifier = this.quoteIdentifiers(`${previousModel.name}.${previousModel.rawAttributes[itemSplit[0]].field}`);\r\n\r\n                // get path\r\n                const path = itemSplit.slice(1);\r\n\r\n                // extract path\r\n                item = this.jsonPathExtractionQuery(identifier, path);\r\n\r\n                // literal because we don't want to append the model name when string\r\n                item = this.sequelize.literal(item);\r\n              }\r\n            }\r\n          }\r\n        }\r\n\r\n        collection[index] = item;\r\n      }, this);\r\n\r\n      // loop through array, adding table names of models to quoted\r\n      const collectionLength = collection.length;\r\n      const tableNames = [];\r\n      let item;\r\n      let i = 0;\r\n\r\n      for (i = 0; i < collectionLength - 1; i++) {\r\n        item = collection[i];\r\n        if (typeof item === 'string' || item._modelAttribute || item instanceof Utils.SequelizeMethod) {\r\n          break;\r\n        } else if (item instanceof Association) {\r\n          tableNames[i] = item.as;\r\n        }\r\n      }\r\n\r\n      // start building sql\r\n      let sql = '';\r\n\r\n      if (i > 0) {\r\n        sql += `${this.quoteIdentifier(tableNames.join(connector))}.`;\r\n      } else if (typeof collection[0] === 'string' && parent) {\r\n        sql += `${this.quoteIdentifier(parent.name)}.`;\r\n      }\r\n\r\n      // loop through everything past i and append to the sql\r\n      collection.slice(i).forEach(collectionItem => {\r\n        sql += this.quote(collectionItem, parent, connector);\r\n      }, this);\r\n\r\n      return sql;\r\n    }\r\n    if (collection._modelAttribute) {\r\n      return `${this.quoteTable(collection.Model.name)}.${this.quoteIdentifier(collection.fieldName)}`;\r\n    }\r\n    if (collection instanceof Utils.SequelizeMethod) {\r\n      return this.handleSequelizeMethod(collection);\r\n    }\r\n    if (_.isPlainObject(collection) && collection.raw) {\r\n      // simple objects with raw is no longer supported\r\n      throw new Error('The `{raw: \"...\"}` syntax is no longer supported.  Use `sequelize.literal` instead.');\r\n    }\r\n    throw new Error(`Unknown structure passed to order / group: ${util.inspect(collection)}`);\r\n  }\r\n\r\n  /**\r\n   * Split a list of identifiers by \".\" and quote each part\r\n   *\r\n   * @param {string} identifier\r\n   * @param {boolean} force\r\n   *\r\n   * @returns {string}\r\n   */\r\n  quoteIdentifier(identifier, force) {\r\n    return QuoteHelper.quoteIdentifier(this.dialect, identifier, {\r\n      force,\r\n      quoteIdentifiers: this.options.quoteIdentifiers\r\n    });\r\n  }\r\n\r\n  quoteIdentifiers(identifiers) {\r\n    if (identifiers.includes('.')) {\r\n      identifiers = identifiers.split('.');\r\n\r\n      const head = identifiers.slice(0, identifiers.length - 1).join('->');\r\n      const tail = identifiers[identifiers.length - 1];\r\n\r\n      return `${this.quoteIdentifier(head)}.${this.quoteIdentifier(tail)}`;\r\n    }\r\n\r\n    return this.quoteIdentifier(identifiers);\r\n  }\r\n\r\n  quoteAttribute(attribute, model) {\r\n    if (model && attribute in model.rawAttributes) {\r\n      return this.quoteIdentifier(attribute);\r\n    }\r\n    return this.quoteIdentifiers(attribute);\r\n  }\r\n\r\n  /**\r\n   * Quote table name with optional alias and schema attribution\r\n   *\r\n   * @param {string|Object}  param table string or object\r\n   * @param {string|boolean} alias alias name\r\n   *\r\n   * @returns {string}\r\n   */\r\n  quoteTable(param, alias) {\r\n    let table = '';\r\n\r\n    if (alias === true) {\r\n      alias = param.as || param.name || param;\r\n    }\r\n\r\n    if (_.isObject(param)) {\r\n      if (this._dialect.supports.schemas) {\r\n        if (param.schema) {\r\n          table += `${this.quoteIdentifier(param.schema)}.`;\r\n        }\r\n\r\n        table += this.quoteIdentifier(param.tableName);\r\n      } else {\r\n        if (param.schema) {\r\n          table += param.schema + (param.delimiter || '.');\r\n        }\r\n\r\n        table += param.tableName;\r\n        table = this.quoteIdentifier(table);\r\n      }\r\n    } else {\r\n      table = this.quoteIdentifier(param);\r\n    }\r\n\r\n    if (alias) {\r\n      table += ` AS ${this.quoteIdentifier(alias)}`;\r\n    }\r\n\r\n    return table;\r\n  }\r\n\r\n  /*\r\n    Escape a value (e.g. a string, number or date)\r\n    @private\r\n  */\r\n  escape(value, field, options) {\r\n    options = options || {};\r\n\r\n    if (value !== null && value !== undefined) {\r\n      if (value instanceof Utils.SequelizeMethod) {\r\n        return this.handleSequelizeMethod(value);\r\n      }\r\n      if (field && field.type) {\r\n        this.validate(value, field, options);\r\n\r\n        if (field.type.stringify) {\r\n          // Users shouldn't have to worry about these args - just give them a function that takes a single arg\r\n          const simpleEscape = escVal => SqlString.escape(escVal, this.options.timezone, this.dialect);\r\n\r\n          value = field.type.stringify(value, { escape: simpleEscape, field, timezone: this.options.timezone, operation: options.operation });\r\n\r\n          if (field.type.escape === false) {\r\n            // The data-type already did the required escaping\r\n            return value;\r\n          }\r\n        }\r\n      }\r\n    }\r\n\r\n    return SqlString.escape(value, this.options.timezone, this.dialect);\r\n  }\r\n\r\n  bindParam(bind) {\r\n    return value => {\r\n      bind.push(value);\r\n      return `$${bind.length}`;\r\n    };\r\n  }\r\n\r\n  /*\r\n    Returns a bind parameter representation of a value (e.g. a string, number or date)\r\n    @private\r\n  */\r\n  format(value, field, options, bindParam) {\r\n    options = options || {};\r\n\r\n    if (value !== null && value !== undefined) {\r\n      if (value instanceof Utils.SequelizeMethod) {\r\n        throw new Error('Cannot pass SequelizeMethod as a bind parameter - use escape instead');\r\n      }\r\n      if (field && field.type) {\r\n        this.validate(value, field, options);\r\n\r\n        if (field.type.bindParam) {\r\n          return field.type.bindParam(value, { escape: _.identity, field, timezone: this.options.timezone, operation: options.operation, bindParam });\r\n        }\r\n      }\r\n    }\r\n\r\n    return bindParam(value);\r\n  }\r\n\r\n  /*\r\n    Validate a value against a field specification\r\n    @private\r\n  */\r\n  validate(value, field, options) {\r\n    if (this.typeValidation && field.type.validate && value) {\r\n      try {\r\n        if (options.isList && Array.isArray(value)) {\r\n          for (const item of value) {\r\n            field.type.validate(item, options);\r\n          }\r\n        } else {\r\n          field.type.validate(value, options);\r\n        }\r\n      } catch (error) {\r\n        if (error instanceof sequelizeError.ValidationError) {\r\n          error.errors.push(new sequelizeError.ValidationErrorItem(\r\n            error.message,\r\n            'Validation error',\r\n            field.fieldName,\r\n            value,\r\n            null,\r\n            `${field.type.key} validator`\r\n          ));\r\n        }\r\n\r\n        throw error;\r\n      }\r\n    }\r\n  }\r\n\r\n  isIdentifierQuoted(identifier) {\r\n    return QuoteHelper.isIdentifierQuoted(identifier);\r\n  }\r\n\r\n  /**\r\n   * Generates an SQL query that extract JSON property of given path.\r\n   *\r\n   * @param   {string}               column  The JSON column\r\n   * @param   {string|Array<string>} [path]  The path to extract (optional)\r\n   * @returns {string}                       The generated sql query\r\n   * @private\r\n   */\r\n  jsonPathExtractionQuery(column, path) {\r\n    let paths = _.toPath(path);\r\n    let pathStr;\r\n    const quotedColumn = this.isIdentifierQuoted(column)\r\n      ? column\r\n      : this.quoteIdentifier(column);\r\n\r\n    switch (this.dialect) {\r\n      case 'mysql':\r\n      case 'mariadb':\r\n      case 'sqlite':\r\n        /**\r\n         * Non digit sub paths need to be quoted as ECMAScript identifiers\r\n         * https://bugs.mysql.com/bug.php?id=81896\r\n         */\r\n        if (this.dialect === 'mysql') {\r\n          paths = paths.map(subPath => {\r\n            return /\\D/.test(subPath)\r\n              ? Utils.addTicks(subPath, '\"')\r\n              : subPath;\r\n          });\r\n        }\r\n\r\n        pathStr = this.escape(['$']\r\n          .concat(paths)\r\n          .join('.')\r\n          .replace(/\\.(\\d+)(?:(?=\\.)|$)/g, (__, digit) => `[${digit}]`));\r\n\r\n        if (this.dialect === 'sqlite') {\r\n          return `json_extract(${quotedColumn},${pathStr})`;\r\n        }\r\n\r\n        return `json_unquote(json_extract(${quotedColumn},${pathStr}))`;\r\n\r\n      case 'postgres':\r\n        pathStr = this.escape(`{${paths.join(',')}}`);\r\n        return `(${quotedColumn}#>>${pathStr})`;\r\n\r\n      default:\r\n        throw new Error(`Unsupported ${this.dialect} for JSON operations`);\r\n    }\r\n  }\r\n\r\n  /*\r\n    Returns a query for selecting elements in the table <tableName>.\r\n    Options:\r\n      - attributes -> An array of attributes (e.g. ['name', 'birthday']). Default: *\r\n      - where -> A hash with conditions (e.g. {name: 'foo'})\r\n                 OR an ID as integer\r\n      - order -> e.g. 'id DESC'\r\n      - group\r\n      - limit -> The maximum count you want to get.\r\n      - offset -> An offset value to start from. Only useable with limit!\r\n   @private\r\n  */\r\n  selectQuery(tableName, options, model) {\r\n    options = options || {};\r\n    const limit = options.limit;\r\n    const mainQueryItems = [];\r\n    const subQueryItems = [];\r\n    const subQuery = options.subQuery === undefined ? limit && options.hasMultiAssociation : options.subQuery;\r\n    const attributes = {\r\n      main: options.attributes && options.attributes.slice(),\r\n      subQuery: null\r\n    };\r\n    const mainTable = {\r\n      name: tableName,\r\n      quotedName: null,\r\n      as: null,\r\n      model\r\n    };\r\n    const topLevelInfo = {\r\n      names: mainTable,\r\n      options,\r\n      subQuery\r\n    };\r\n    let mainJoinQueries = [];\r\n    let subJoinQueries = [];\r\n    let query;\r\n\r\n    // Aliases can be passed through subqueries and we don't want to reset them\r\n    if (this.options.minifyAliases && !options.aliasesMapping) {\r\n      options.aliasesMapping = new Map();\r\n      options.aliasesByTable = {};\r\n    }\r\n\r\n    // resolve table name options\r\n    if (options.tableAs) {\r\n      mainTable.as = this.quoteIdentifier(options.tableAs);\r\n    } else if (!Array.isArray(mainTable.name) && mainTable.model) {\r\n      mainTable.as = this.quoteIdentifier(mainTable.model.name);\r\n    }\r\n\r\n    mainTable.quotedName = !Array.isArray(mainTable.name) ? this.quoteTable(mainTable.name) : tableName.map(t => {\r\n      return Array.isArray(t) ? this.quoteTable(t[0], t[1]) : this.quoteTable(t, true);\r\n    }).join(', ');\r\n\r\n    if (subQuery && attributes.main) {\r\n      for (const keyAtt of mainTable.model.primaryKeyAttributes) {\r\n        // Check if mainAttributes contain the primary key of the model either as a field or an aliased field\r\n        if (!attributes.main.some(attr => keyAtt === attr || keyAtt === attr[0] || keyAtt === attr[1])) {\r\n          attributes.main.push(mainTable.model.rawAttributes[keyAtt].field ? [keyAtt, mainTable.model.rawAttributes[keyAtt].field] : keyAtt);\r\n        }\r\n      }\r\n    }\r\n\r\n    attributes.main = this.escapeAttributes(attributes.main, options, mainTable.as);\r\n    attributes.main = attributes.main || (options.include ? [`${mainTable.as}.*`] : ['*']);\r\n\r\n    // If subquery, we add the mainAttributes to the subQuery and set the mainAttributes to select * from subquery\r\n    if (subQuery || options.groupedLimit) {\r\n      // We need primary keys\r\n      attributes.subQuery = attributes.main;\r\n      attributes.main = [`${mainTable.as || mainTable.quotedName}.*`];\r\n    }\r\n\r\n    if (options.include) {\r\n      for (const include of options.include) {\r\n        if (include.separate) {\r\n          continue;\r\n        }\r\n        const joinQueries = this.generateInclude(include, { externalAs: mainTable.as, internalAs: mainTable.as }, topLevelInfo);\r\n\r\n        subJoinQueries = subJoinQueries.concat(joinQueries.subQuery);\r\n        mainJoinQueries = mainJoinQueries.concat(joinQueries.mainQuery);\r\n\r\n        if (joinQueries.attributes.main.length > 0) {\r\n          attributes.main = _.uniq(attributes.main.concat(joinQueries.attributes.main));\r\n        }\r\n        if (joinQueries.attributes.subQuery.length > 0) {\r\n          attributes.subQuery = _.uniq(attributes.subQuery.concat(joinQueries.attributes.subQuery));\r\n        }\r\n      }\r\n    }\r\n\r\n    if (subQuery) {\r\n      subQueryItems.push(this.selectFromTableFragment(options, mainTable.model, attributes.subQuery, mainTable.quotedName, mainTable.as));\r\n      subQueryItems.push(subJoinQueries.join(''));\r\n    } else {\r\n      if (options.groupedLimit) {\r\n        if (!mainTable.as) {\r\n          mainTable.as = mainTable.quotedName;\r\n        }\r\n        const where = Object.assign({}, options.where);\r\n        let groupedLimitOrder,\r\n          whereKey,\r\n          include,\r\n          groupedTableName = mainTable.as;\r\n\r\n        if (typeof options.groupedLimit.on === 'string') {\r\n          whereKey = options.groupedLimit.on;\r\n        } else if (options.groupedLimit.on instanceof HasMany) {\r\n          whereKey = options.groupedLimit.on.foreignKeyField;\r\n        }\r\n\r\n        if (options.groupedLimit.on instanceof BelongsToMany) {\r\n          // BTM includes needs to join the through table on to check ID\r\n          groupedTableName = options.groupedLimit.on.manyFromSource.as;\r\n          const groupedLimitOptions = Model._validateIncludedElements({\r\n            include: [{\r\n              association: options.groupedLimit.on.manyFromSource,\r\n              duplicating: false, // The UNION'ed query may contain duplicates, but each sub-query cannot\r\n              required: true,\r\n              where: Object.assign({\r\n                [Op.placeholder]: true\r\n              }, options.groupedLimit.through && options.groupedLimit.through.where)\r\n            }],\r\n            model\r\n          });\r\n\r\n          // Make sure attributes from the join table are mapped back to models\r\n          options.hasJoin = true;\r\n          options.hasMultiAssociation = true;\r\n          options.includeMap = Object.assign(groupedLimitOptions.includeMap, options.includeMap);\r\n          options.includeNames = groupedLimitOptions.includeNames.concat(options.includeNames || []);\r\n          include = groupedLimitOptions.include;\r\n\r\n          if (Array.isArray(options.order)) {\r\n            // We need to make sure the order by attributes are available to the parent query\r\n            options.order.forEach((order, i) => {\r\n              if (Array.isArray(order)) {\r\n                order = order[0];\r\n              }\r\n\r\n              let alias = `subquery_order_${i}`;\r\n              options.attributes.push([order, alias]);\r\n\r\n              // We don't want to prepend model name when we alias the attributes, so quote them here\r\n              alias = this.sequelize.literal(this.quote(alias));\r\n\r\n              if (Array.isArray(options.order[i])) {\r\n                options.order[i][0] = alias;\r\n              } else {\r\n                options.order[i] = alias;\r\n              }\r\n            });\r\n            groupedLimitOrder = options.order;\r\n          }\r\n        } else {\r\n          // Ordering is handled by the subqueries, so ordering the UNION'ed result is not needed\r\n          groupedLimitOrder = options.order;\r\n          delete options.order;\r\n          where[Op.placeholder] = true;\r\n        }\r\n\r\n        // Caching the base query and splicing the where part into it is consistently > twice\r\n        // as fast than generating from scratch each time for values.length >= 5\r\n        const baseQuery = `SELECT * FROM (${this.selectQuery(\r\n          tableName,\r\n          {\r\n            attributes: options.attributes,\r\n            offset: options.offset,\r\n            limit: options.groupedLimit.limit,\r\n            order: groupedLimitOrder,\r\n            aliasesMapping: options.aliasesMapping,\r\n            aliasesByTable: options.aliasesByTable,\r\n            where,\r\n            include,\r\n            model\r\n          },\r\n          model\r\n        ).replace(/;$/, '')}) AS sub`; // Every derived table must have its own alias\r\n        const placeHolder = this.whereItemQuery(Op.placeholder, true, { model });\r\n        const splicePos = baseQuery.indexOf(placeHolder);\r\n\r\n        mainQueryItems.push(this.selectFromTableFragment(options, mainTable.model, attributes.main, `(${\r\n          options.groupedLimit.values.map(value => {\r\n            let groupWhere;\r\n            if (whereKey) {\r\n              groupWhere = {\r\n                [whereKey]: value\r\n              };\r\n            }\r\n            if (include) {\r\n              groupWhere = {\r\n                [options.groupedLimit.on.foreignIdentifierField]: value\r\n              };\r\n            }\r\n\r\n            return Utils.spliceStr(baseQuery, splicePos, placeHolder.length, this.getWhereConditions(groupWhere, groupedTableName));\r\n          }).join(\r\n            this._dialect.supports['UNION ALL'] ? ' UNION ALL ' : ' UNION '\r\n          )\r\n        })`, mainTable.as));\r\n      } else {\r\n        mainQueryItems.push(this.selectFromTableFragment(options, mainTable.model, attributes.main, mainTable.quotedName, mainTable.as));\r\n      }\r\n\r\n      mainQueryItems.push(mainJoinQueries.join(''));\r\n    }\r\n\r\n    // Add WHERE to sub or main query\r\n    if (Object.prototype.hasOwnProperty.call(options, 'where') && !options.groupedLimit) {\r\n      options.where = this.getWhereConditions(options.where, mainTable.as || tableName, model, options);\r\n      if (options.where) {\r\n        if (subQuery) {\r\n          subQueryItems.push(` WHERE ${options.where}`);\r\n        } else {\r\n          mainQueryItems.push(` WHERE ${options.where}`);\r\n          // Walk the main query to update all selects\r\n          mainQueryItems.forEach((value, key) => {\r\n            if (value.startsWith('SELECT')) {\r\n              mainQueryItems[key] = this.selectFromTableFragment(options, model, attributes.main, mainTable.quotedName, mainTable.as, options.where);\r\n            }\r\n          });\r\n        }\r\n      }\r\n    }\r\n\r\n    // Add GROUP BY to sub or main query\r\n    if (options.group) {\r\n      options.group = Array.isArray(options.group) ? options.group.map(t => this.aliasGrouping(t, model, mainTable.as, options)).join(', ') : this.aliasGrouping(options.group, model, mainTable.as, options);\r\n\r\n      if (subQuery) {\r\n        subQueryItems.push(` GROUP BY ${options.group}`);\r\n      } else {\r\n        mainQueryItems.push(` GROUP BY ${options.group}`);\r\n      }\r\n    }\r\n\r\n    // Add HAVING to sub or main query\r\n    if (Object.prototype.hasOwnProperty.call(options, 'having')) {\r\n      options.having = this.getWhereConditions(options.having, tableName, model, options, false);\r\n      if (options.having) {\r\n        if (subQuery) {\r\n          subQueryItems.push(` HAVING ${options.having}`);\r\n        } else {\r\n          mainQueryItems.push(` HAVING ${options.having}`);\r\n        }\r\n      }\r\n    }\r\n\r\n    // Add ORDER to sub or main query\r\n    if (options.order) {\r\n      const orders = this.getQueryOrders(options, model, subQuery);\r\n      if (orders.mainQueryOrder.length) {\r\n        mainQueryItems.push(` ORDER BY ${orders.mainQueryOrder.join(', ')}`);\r\n      }\r\n      if (orders.subQueryOrder.length) {\r\n        subQueryItems.push(` ORDER BY ${orders.subQueryOrder.join(', ')}`);\r\n      }\r\n    }\r\n\r\n    // Add LIMIT, OFFSET to sub or main query\r\n    const limitOrder = this.addLimitAndOffset(options, mainTable.model);\r\n    if (limitOrder && !options.groupedLimit) {\r\n      if (subQuery) {\r\n        subQueryItems.push(limitOrder);\r\n      } else {\r\n        mainQueryItems.push(limitOrder);\r\n      }\r\n    }\r\n\r\n    if (subQuery) {\r\n      query = `SELECT ${attributes.main.join(', ')} FROM (${subQueryItems.join('')}) AS ${mainTable.as}${mainJoinQueries.join('')}${mainQueryItems.join('')}`;\r\n    } else {\r\n      query = mainQueryItems.join('');\r\n    }\r\n\r\n    if (options.lock && this._dialect.supports.lock) {\r\n      let lock = options.lock;\r\n      if (typeof options.lock === 'object') {\r\n        lock = options.lock.level;\r\n      }\r\n      if (this._dialect.supports.lockKey && (lock === 'KEY SHARE' || lock === 'NO KEY UPDATE')) {\r\n        query += ` FOR ${lock}`;\r\n      } else if (lock === 'SHARE') {\r\n        query += ` ${this._dialect.supports.forShare}`;\r\n      } else {\r\n        query += ' FOR UPDATE';\r\n      }\r\n      if (this._dialect.supports.lockOf && options.lock.of && options.lock.of.prototype instanceof Model) {\r\n        query += ` OF ${this.quoteTable(options.lock.of.name)}`;\r\n      }\r\n      if (this._dialect.supports.skipLocked && options.skipLocked) {\r\n        query += ' SKIP LOCKED';\r\n      }\r\n    }\r\n\r\n    return `${query};`;\r\n  }\r\n\r\n  aliasGrouping(field, model, tableName, options) {\r\n    const src = Array.isArray(field) ? field[0] : field;\r\n\r\n    return this.quote(this._getAliasForField(tableName, src, options) || src, model);\r\n  }\r\n\r\n  escapeAttributes(attributes, options, mainTableAs) {\r\n    return attributes && attributes.map(attr => {\r\n      let addTable = true;\r\n\r\n      if (attr instanceof Utils.SequelizeMethod) {\r\n        return this.handleSequelizeMethod(attr);\r\n      }\r\n      if (Array.isArray(attr)) {\r\n        if (attr.length !== 2) {\r\n          throw new Error(`${JSON.stringify(attr)} is not a valid attribute definition. Please use the following format: ['attribute definition', 'alias']`);\r\n        }\r\n        attr = attr.slice();\r\n\r\n        if (attr[0] instanceof Utils.SequelizeMethod) {\r\n          attr[0] = this.handleSequelizeMethod(attr[0]);\r\n          addTable = false;\r\n        } else if (!attr[0].includes('(') && !attr[0].includes(')')) {\r\n          attr[0] = this.quoteIdentifier(attr[0]);\r\n        } else {\r\n          deprecations.noRawAttributes();\r\n        }\r\n        let alias = attr[1];\r\n\r\n        if (this.options.minifyAliases) {\r\n          alias = this._getMinifiedAlias(alias, mainTableAs, options);\r\n        }\r\n\r\n        attr = [attr[0], this.quoteIdentifier(alias)].join(' AS ');\r\n      } else {\r\n        attr = !attr.includes(Utils.TICK_CHAR) && !attr.includes('\"')\r\n          ? this.quoteAttribute(attr, options.model)\r\n          : this.escape(attr);\r\n      }\r\n      if (!_.isEmpty(options.include) && !attr.includes('.') && addTable) {\r\n        attr = `${mainTableAs}.${attr}`;\r\n      }\r\n\r\n      return attr;\r\n    });\r\n  }\r\n\r\n  generateInclude(include, parentTableName, topLevelInfo) {\r\n    const joinQueries = {\r\n      mainQuery: [],\r\n      subQuery: []\r\n    };\r\n    const mainChildIncludes = [];\r\n    const subChildIncludes = [];\r\n    let requiredMismatch = false;\r\n    const includeAs = {\r\n      internalAs: include.as,\r\n      externalAs: include.as\r\n    };\r\n    const attributes = {\r\n      main: [],\r\n      subQuery: []\r\n    };\r\n    let joinQuery;\r\n\r\n    topLevelInfo.options.keysEscaped = true;\r\n\r\n    if (topLevelInfo.names.name !== parentTableName.externalAs && topLevelInfo.names.as !== parentTableName.externalAs) {\r\n      includeAs.internalAs = `${parentTableName.internalAs}->${include.as}`;\r\n      includeAs.externalAs = `${parentTableName.externalAs}.${include.as}`;\r\n    }\r\n\r\n    // includeIgnoreAttributes is used by aggregate functions\r\n    if (topLevelInfo.options.includeIgnoreAttributes !== false) {\r\n      include.model._expandAttributes(include);\r\n      Utils.mapFinderOptions(include, include.model);\r\n\r\n      const includeAttributes = include.attributes.map(attr => {\r\n        let attrAs = attr;\r\n        let verbatim = false;\r\n\r\n        if (Array.isArray(attr) && attr.length === 2) {\r\n          if (attr[0] instanceof Utils.SequelizeMethod && (\r\n            attr[0] instanceof Utils.Literal ||\r\n            attr[0] instanceof Utils.Cast ||\r\n            attr[0] instanceof Utils.Fn\r\n          )) {\r\n            verbatim = true;\r\n          }\r\n\r\n          attr = attr.map(attr => attr instanceof Utils.SequelizeMethod ? this.handleSequelizeMethod(attr) : attr);\r\n\r\n          attrAs = attr[1];\r\n          attr = attr[0];\r\n        }\r\n        if (attr instanceof Utils.Literal) {\r\n          return attr.val; // We trust the user to rename the field correctly\r\n        }\r\n        if (attr instanceof Utils.Cast || attr instanceof Utils.Fn) {\r\n          throw new Error(\r\n            'Tried to select attributes using Sequelize.cast or Sequelize.fn without specifying an alias for the result, during eager loading. ' +\r\n            'This means the attribute will not be added to the returned instance'\r\n          );\r\n        }\r\n\r\n        let prefix;\r\n        if (verbatim === true) {\r\n          prefix = attr;\r\n        } else if (/#>>|->>/.test(attr)) {\r\n          prefix = `(${this.quoteIdentifier(includeAs.internalAs)}.${attr.replace(/\\(|\\)/g, '')})`;\r\n        } else if (/json_extract\\(/.test(attr)) {\r\n          prefix = attr.replace(/json_extract\\(/i, `json_extract(${this.quoteIdentifier(includeAs.internalAs)}.`);\r\n        } else {\r\n          prefix = `${this.quoteIdentifier(includeAs.internalAs)}.${this.quoteIdentifier(attr)}`;\r\n        }\r\n        let alias = `${includeAs.externalAs}.${attrAs}`;\r\n\r\n        if (this.options.minifyAliases) {\r\n          alias = this._getMinifiedAlias(alias, includeAs.internalAs, topLevelInfo.options);\r\n        }\r\n\r\n        return `${prefix} AS ${this.quoteIdentifier(alias, true)}`;\r\n      });\r\n      if (include.subQuery && topLevelInfo.subQuery) {\r\n        for (const attr of includeAttributes) {\r\n          attributes.subQuery.push(attr);\r\n        }\r\n      } else {\r\n        for (const attr of includeAttributes) {\r\n          attributes.main.push(attr);\r\n        }\r\n      }\r\n    }\r\n\r\n    //through\r\n    if (include.through) {\r\n      joinQuery = this.generateThroughJoin(include, includeAs, parentTableName.internalAs, topLevelInfo);\r\n    } else {\r\n      this._generateSubQueryFilter(include, includeAs, topLevelInfo);\r\n      joinQuery = this.generateJoin(include, topLevelInfo);\r\n    }\r\n\r\n    // handle possible new attributes created in join\r\n    if (joinQuery.attributes.main.length > 0) {\r\n      attributes.main = attributes.main.concat(joinQuery.attributes.main);\r\n    }\r\n\r\n    if (joinQuery.attributes.subQuery.length > 0) {\r\n      attributes.subQuery = attributes.subQuery.concat(joinQuery.attributes.subQuery);\r\n    }\r\n\r\n    if (include.include) {\r\n      for (const childInclude of include.include) {\r\n        if (childInclude.separate || childInclude._pseudo) {\r\n          continue;\r\n        }\r\n\r\n        const childJoinQueries = this.generateInclude(childInclude, includeAs, topLevelInfo);\r\n\r\n        if (include.required === false && childInclude.required === true) {\r\n          requiredMismatch = true;\r\n        }\r\n        // if the child is a sub query we just give it to the\r\n        if (childInclude.subQuery && topLevelInfo.subQuery) {\r\n          subChildIncludes.push(childJoinQueries.subQuery);\r\n        }\r\n        if (childJoinQueries.mainQuery) {\r\n          mainChildIncludes.push(childJoinQueries.mainQuery);\r\n        }\r\n        if (childJoinQueries.attributes.main.length > 0) {\r\n          attributes.main = attributes.main.concat(childJoinQueries.attributes.main);\r\n        }\r\n        if (childJoinQueries.attributes.subQuery.length > 0) {\r\n          attributes.subQuery = attributes.subQuery.concat(childJoinQueries.attributes.subQuery);\r\n        }\r\n      }\r\n    }\r\n\r\n    if (include.subQuery && topLevelInfo.subQuery) {\r\n      if (requiredMismatch && subChildIncludes.length > 0) {\r\n        joinQueries.subQuery.push(` ${joinQuery.join} ( ${joinQuery.body}${subChildIncludes.join('')} ) ON ${joinQuery.condition}`);\r\n      } else {\r\n        joinQueries.subQuery.push(` ${joinQuery.join} ${joinQuery.body} ON ${joinQuery.condition}`);\r\n        if (subChildIncludes.length > 0) {\r\n          joinQueries.subQuery.push(subChildIncludes.join(''));\r\n        }\r\n      }\r\n      joinQueries.mainQuery.push(mainChildIncludes.join(''));\r\n    } else {\r\n      if (requiredMismatch && mainChildIncludes.length > 0) {\r\n        joinQueries.mainQuery.push(` ${joinQuery.join} ( ${joinQuery.body}${mainChildIncludes.join('')} ) ON ${joinQuery.condition}`);\r\n      } else {\r\n        joinQueries.mainQuery.push(` ${joinQuery.join} ${joinQuery.body} ON ${joinQuery.condition}`);\r\n        if (mainChildIncludes.length > 0) {\r\n          joinQueries.mainQuery.push(mainChildIncludes.join(''));\r\n        }\r\n      }\r\n      joinQueries.subQuery.push(subChildIncludes.join(''));\r\n    }\r\n\r\n    return {\r\n      mainQuery: joinQueries.mainQuery.join(''),\r\n      subQuery: joinQueries.subQuery.join(''),\r\n      attributes\r\n    };\r\n  }\r\n\r\n  _getMinifiedAlias(alias, tableName, options) {\r\n    // We do not want to re-alias in case of a subquery\r\n    if (options.aliasesByTable[`${tableName}${alias}`]) {\r\n      return options.aliasesByTable[`${tableName}${alias}`];\r\n    }\r\n\r\n    // Do not alias custom suquery_orders\r\n    if (alias.match(/subquery_order_[0-9]/)) {\r\n      return alias;\r\n    }\r\n\r\n    const minifiedAlias = `_${options.aliasesMapping.size}`;\r\n\r\n    options.aliasesMapping.set(minifiedAlias, alias);\r\n    options.aliasesByTable[`${tableName}${alias}`] = minifiedAlias;\r\n\r\n    return minifiedAlias;\r\n  }\r\n\r\n  _getAliasForField(tableName, field, options) {\r\n    if (this.options.minifyAliases) {\r\n      if (options.aliasesByTable[`${tableName}${field}`]) {\r\n        return options.aliasesByTable[`${tableName}${field}`];\r\n      }\r\n    }\r\n    return null;\r\n  }\r\n\r\n  generateJoin(include, topLevelInfo) {\r\n    const association = include.association;\r\n    const parent = include.parent;\r\n    const parentIsTop = !!parent && !include.parent.association && include.parent.model.name === topLevelInfo.options.model.name;\r\n    let $parent;\r\n    let joinWhere;\r\n    /* Attributes for the left side */\r\n    const left = association.source;\r\n    const attrLeft = association instanceof BelongsTo ?\r\n      association.identifier :\r\n      association.sourceKeyAttribute || left.primaryKeyAttribute;\r\n    const fieldLeft = association instanceof BelongsTo ?\r\n      association.identifierField :\r\n      left.rawAttributes[association.sourceKeyAttribute || left.primaryKeyAttribute].field;\r\n    let asLeft;\r\n    /* Attributes for the right side */\r\n    const right = include.model;\r\n    const tableRight = right.getTableName();\r\n    const fieldRight = association instanceof BelongsTo ?\r\n      right.rawAttributes[association.targetIdentifier || right.primaryKeyAttribute].field :\r\n      association.identifierField;\r\n    let asRight = include.as;\r\n\r\n    while (($parent = $parent && $parent.parent || include.parent) && $parent.association) {\r\n      if (asLeft) {\r\n        asLeft = `${$parent.as}->${asLeft}`;\r\n      } else {\r\n        asLeft = $parent.as;\r\n      }\r\n    }\r\n\r\n    if (!asLeft) asLeft = parent.as || parent.model.name;\r\n    else asRight = `${asLeft}->${asRight}`;\r\n\r\n    let joinOn = `${this.quoteTable(asLeft)}.${this.quoteIdentifier(fieldLeft)}`;\r\n    const subqueryAttributes = [];\r\n\r\n    if (topLevelInfo.options.groupedLimit && parentIsTop || topLevelInfo.subQuery && include.parent.subQuery && !include.subQuery) {\r\n      if (parentIsTop) {\r\n        // The main model attributes is not aliased to a prefix\r\n        const tableName = this.quoteTable(parent.as || parent.model.name);\r\n\r\n        // Check for potential aliased JOIN condition\r\n        joinOn = this._getAliasForField(tableName, attrLeft, topLevelInfo.options) || `${tableName}.${this.quoteIdentifier(attrLeft)}`;\r\n\r\n        if (topLevelInfo.subQuery) {\r\n          subqueryAttributes.push(`${tableName}.${this.quoteIdentifier(fieldLeft)}`);\r\n        }\r\n      } else {\r\n        const joinSource = `${asLeft.replace(/->/g, '.')}.${attrLeft}`;\r\n\r\n        // Check for potential aliased JOIN condition\r\n        joinOn = this._getAliasForField(asLeft, joinSource, topLevelInfo.options) || this.quoteIdentifier(joinSource);\r\n      }\r\n    }\r\n\r\n    joinOn += ` = ${this.quoteIdentifier(asRight)}.${this.quoteIdentifier(fieldRight)}`;\r\n\r\n    if (include.on) {\r\n      joinOn = this.whereItemsQuery(include.on, {\r\n        prefix: this.sequelize.literal(this.quoteIdentifier(asRight)),\r\n        model: include.model\r\n      });\r\n    }\r\n\r\n    if (include.where) {\r\n      joinWhere = this.whereItemsQuery(include.where, {\r\n        prefix: this.sequelize.literal(this.quoteIdentifier(asRight)),\r\n        model: include.model\r\n      });\r\n      if (joinWhere) {\r\n        if (include.or) {\r\n          joinOn += ` OR ${joinWhere}`;\r\n        } else {\r\n          joinOn += ` AND ${joinWhere}`;\r\n        }\r\n      }\r\n    }\r\n\r\n    return {\r\n      join: include.required ? 'INNER JOIN' : include.right && this._dialect.supports['RIGHT JOIN'] ? 'RIGHT OUTER JOIN' : 'LEFT OUTER JOIN',\r\n      body: this.quoteTable(tableRight, asRight),\r\n      condition: joinOn,\r\n      attributes: {\r\n        main: [],\r\n        subQuery: subqueryAttributes\r\n      }\r\n    };\r\n  }\r\n\r\n  generateThroughJoin(include, includeAs, parentTableName, topLevelInfo) {\r\n    const through = include.through;\r\n    const throughTable = through.model.getTableName();\r\n    const throughAs = `${includeAs.internalAs}->${through.as}`;\r\n    const externalThroughAs = `${includeAs.externalAs}.${through.as}`;\r\n    const throughAttributes = through.attributes.map(attr => {\r\n      let alias = `${externalThroughAs}.${Array.isArray(attr) ? attr[1] : attr}`;\r\n\r\n      if (this.options.minifyAliases) {\r\n        alias = this._getMinifiedAlias(alias, throughAs, topLevelInfo.options);\r\n      }\r\n\r\n      return `${this.quoteIdentifier(throughAs)}.${this.quoteIdentifier(Array.isArray(attr) ? attr[0] : attr)\r\n      } AS ${\r\n        this.quoteIdentifier(alias)}`;\r\n    });\r\n    const association = include.association;\r\n    const parentIsTop = !include.parent.association && include.parent.model.name === topLevelInfo.options.model.name;\r\n    const tableSource = parentTableName;\r\n    const identSource = association.identifierField;\r\n    const tableTarget = includeAs.internalAs;\r\n    const identTarget = association.foreignIdentifierField;\r\n    const attrTarget = association.targetKeyField;\r\n\r\n    const joinType = include.required ? 'INNER JOIN' : include.right && this._dialect.supports['RIGHT JOIN'] ? 'RIGHT OUTER JOIN' : 'LEFT OUTER JOIN';\r\n    let joinBody;\r\n    let joinCondition;\r\n    const attributes = {\r\n      main: [],\r\n      subQuery: []\r\n    };\r\n    let attrSource = association.sourceKey;\r\n    let sourceJoinOn;\r\n    let targetJoinOn;\r\n    let throughWhere;\r\n    let targetWhere;\r\n\r\n    if (topLevelInfo.options.includeIgnoreAttributes !== false) {\r\n      // Through includes are always hasMany, so we need to add the attributes to the mainAttributes no matter what (Real join will never be executed in subquery)\r\n      for (const attr of throughAttributes) {\r\n        attributes.main.push(attr);\r\n      }\r\n    }\r\n\r\n    // Figure out if we need to use field or attribute\r\n    if (!topLevelInfo.subQuery) {\r\n      attrSource = association.sourceKeyField;\r\n    }\r\n    if (topLevelInfo.subQuery && !include.subQuery && !include.parent.subQuery && include.parent.model !== topLevelInfo.options.mainModel) {\r\n      attrSource = association.sourceKeyField;\r\n    }\r\n\r\n    // Filter statement for left side of through\r\n    // Used by both join and subquery where\r\n    // If parent include was in a subquery need to join on the aliased attribute\r\n    if (topLevelInfo.subQuery && !include.subQuery && include.parent.subQuery && !parentIsTop) {\r\n      // If we are minifying aliases and our JOIN target has been minified, we need to use the alias instead of the original column name\r\n      const joinSource = this._getAliasForField(tableSource, `${tableSource}.${attrSource}`, topLevelInfo.options) || `${tableSource}.${attrSource}`;\r\n\r\n      sourceJoinOn = `${this.quoteIdentifier(joinSource)} = `;\r\n    } else {\r\n      // If we are minifying aliases and our JOIN target has been minified, we need to use the alias instead of the original column name\r\n      const aliasedSource = this._getAliasForField(tableSource, attrSource, topLevelInfo.options) || attrSource;\r\n\r\n      sourceJoinOn = `${this.quoteTable(tableSource)}.${this.quoteIdentifier(aliasedSource)} = `;\r\n    }\r\n    sourceJoinOn += `${this.quoteIdentifier(throughAs)}.${this.quoteIdentifier(identSource)}`;\r\n\r\n    // Filter statement for right side of through\r\n    // Used by both join and subquery where\r\n    targetJoinOn = `${this.quoteIdentifier(tableTarget)}.${this.quoteIdentifier(attrTarget)} = `;\r\n    targetJoinOn += `${this.quoteIdentifier(throughAs)}.${this.quoteIdentifier(identTarget)}`;\r\n\r\n    if (through.where) {\r\n      throughWhere = this.getWhereConditions(through.where, this.sequelize.literal(this.quoteIdentifier(throughAs)), through.model);\r\n    }\r\n\r\n    if (this._dialect.supports.joinTableDependent) {\r\n      // Generate a wrapped join so that the through table join can be dependent on the target join\r\n      joinBody = `( ${this.quoteTable(throughTable, throughAs)} INNER JOIN ${this.quoteTable(include.model.getTableName(), includeAs.internalAs)} ON ${targetJoinOn}`;\r\n      if (throughWhere) {\r\n        joinBody += ` AND ${throughWhere}`;\r\n      }\r\n      joinBody += ')';\r\n      joinCondition = sourceJoinOn;\r\n    } else {\r\n      // Generate join SQL for left side of through\r\n      joinBody = `${this.quoteTable(throughTable, throughAs)} ON ${sourceJoinOn} ${joinType} ${this.quoteTable(include.model.getTableName(), includeAs.internalAs)}`;\r\n      joinCondition = targetJoinOn;\r\n      if (throughWhere) {\r\n        joinCondition += ` AND ${throughWhere}`;\r\n      }\r\n    }\r\n\r\n    if (include.where || include.through.where) {\r\n      if (include.where) {\r\n        targetWhere = this.getWhereConditions(include.where, this.sequelize.literal(this.quoteIdentifier(includeAs.internalAs)), include.model, topLevelInfo.options);\r\n        if (targetWhere) {\r\n          joinCondition += ` AND ${targetWhere}`;\r\n        }\r\n      }\r\n    }\r\n\r\n    this._generateSubQueryFilter(include, includeAs, topLevelInfo);\r\n\r\n    return {\r\n      join: joinType,\r\n      body: joinBody,\r\n      condition: joinCondition,\r\n      attributes\r\n    };\r\n  }\r\n\r\n  /*\r\n   * Generates subQueryFilter - a select nested in the where clause of the subQuery.\r\n   * For a given include a query is generated that contains all the way from the subQuery\r\n   * table to the include table plus everything that's in required transitive closure of the\r\n   * given include.\r\n   */\r\n  _generateSubQueryFilter(include, includeAs, topLevelInfo) {\r\n    if (!topLevelInfo.subQuery || !include.subQueryFilter) {\r\n      return;\r\n    }\r\n\r\n    if (!topLevelInfo.options.where) {\r\n      topLevelInfo.options.where = {};\r\n    }\r\n    let parent = include;\r\n    let child = include;\r\n    let nestedIncludes = this._getRequiredClosure(include).include;\r\n    let query;\r\n\r\n    while ((parent = parent.parent)) { // eslint-disable-line\r\n      if (parent.parent && !parent.required) {\r\n        return; // only generate subQueryFilter if all the parents of this include are required\r\n      }\r\n\r\n      if (parent.subQueryFilter) {\r\n        // the include is already handled as this parent has the include on its required closure\r\n        // skip to prevent duplicate subQueryFilter\r\n        return;\r\n      }\r\n\r\n      nestedIncludes = [Object.assign({}, child, { include: nestedIncludes, attributes: [] })];\r\n      child = parent;\r\n    }\r\n\r\n    const topInclude = nestedIncludes[0];\r\n    const topParent = topInclude.parent;\r\n    const topAssociation = topInclude.association;\r\n    topInclude.association = undefined;\r\n\r\n    if (topInclude.through && Object(topInclude.through.model) === topInclude.through.model) {\r\n      query = this.selectQuery(topInclude.through.model.getTableName(), {\r\n        attributes: [topInclude.through.model.primaryKeyField],\r\n        include: Model._validateIncludedElements({\r\n          model: topInclude.through.model,\r\n          include: [{\r\n            association: topAssociation.toTarget,\r\n            required: true,\r\n            where: topInclude.where,\r\n            include: topInclude.include\r\n          }]\r\n        }).include,\r\n        model: topInclude.through.model,\r\n        where: {\r\n          [Op.and]: [\r\n            this.sequelize.literal([\r\n              `${this.quoteTable(topParent.model.name)}.${this.quoteIdentifier(topParent.model.primaryKeyField)}`,\r\n              `${this.quoteIdentifier(topInclude.through.model.name)}.${this.quoteIdentifier(topAssociation.identifierField)}`\r\n            ].join(' = ')),\r\n            topInclude.through.where\r\n          ]\r\n        },\r\n        limit: 1,\r\n        includeIgnoreAttributes: false\r\n      }, topInclude.through.model);\r\n    } else {\r\n      const isBelongsTo = topAssociation.associationType === 'BelongsTo';\r\n      const sourceField = isBelongsTo ? topAssociation.identifierField : topAssociation.sourceKeyField || topParent.model.primaryKeyField;\r\n      const targetField = isBelongsTo ? topAssociation.sourceKeyField || topInclude.model.primaryKeyField : topAssociation.identifierField;\r\n\r\n      const join = [\r\n        `${this.quoteIdentifier(topInclude.as)}.${this.quoteIdentifier(targetField)}`,\r\n        `${this.quoteTable(topParent.as || topParent.model.name)}.${this.quoteIdentifier(sourceField)}`\r\n      ].join(' = ');\r\n\r\n      query = this.selectQuery(topInclude.model.getTableName(), {\r\n        attributes: [targetField],\r\n        include: Model._validateIncludedElements(topInclude).include,\r\n        model: topInclude.model,\r\n        where: {\r\n          [Op.and]: [\r\n            topInclude.where,\r\n            { [Op.join]: this.sequelize.literal(join) }\r\n          ]\r\n        },\r\n        limit: 1,\r\n        tableAs: topInclude.as,\r\n        includeIgnoreAttributes: false\r\n      }, topInclude.model);\r\n    }\r\n\r\n    if (!topLevelInfo.options.where[Op.and]) {\r\n      topLevelInfo.options.where[Op.and] = [];\r\n    }\r\n\r\n    topLevelInfo.options.where[`__${includeAs.internalAs}`] = this.sequelize.literal([\r\n      '(',\r\n      query.replace(/;$/, ''),\r\n      ')',\r\n      'IS NOT NULL'\r\n    ].join(' '));\r\n  }\r\n\r\n  /*\r\n   * For a given include hierarchy creates a copy of it where only the required includes\r\n   * are preserved.\r\n   */\r\n  _getRequiredClosure(include) {\r\n    const copy = Object.assign({}, include, { attributes: [], include: [] });\r\n\r\n    if (Array.isArray(include.include)) {\r\n      copy.include = include.include\r\n        .filter(i => i.required)\r\n        .map(inc => this._getRequiredClosure(inc));\r\n    }\r\n\r\n    return copy;\r\n  }\r\n\r\n  getQueryOrders(options, model, subQuery) {\r\n    const mainQueryOrder = [];\r\n    const subQueryOrder = [];\r\n\r\n    if (Array.isArray(options.order)) {\r\n      for (let order of options.order) {\r\n\r\n        // wrap if not array\r\n        if (!Array.isArray(order)) {\r\n          order = [order];\r\n        }\r\n\r\n        if (\r\n          subQuery\r\n          && Array.isArray(order)\r\n          && order[0]\r\n          && !(order[0] instanceof Association)\r\n          && !(typeof order[0] === 'function' && order[0].prototype instanceof Model)\r\n          && !(typeof order[0].model === 'function' && order[0].model.prototype instanceof Model)\r\n          && !(typeof order[0] === 'string' && model && model.associations !== undefined && model.associations[order[0]])\r\n        ) {\r\n          subQueryOrder.push(this.quote(order, model, '->'));\r\n        }\r\n\r\n        if (subQuery) {\r\n          // Handle case where sub-query renames attribute we want to order by,\r\n          // see https://github.com/sequelize/sequelize/issues/8739\r\n          const subQueryAttribute = options.attributes.find(a => Array.isArray(a) && a[0] === order[0] && a[1]);\r\n          if (subQueryAttribute) {\r\n            const modelName = this.quoteIdentifier(model.name);\r\n\r\n            order[0] = new Utils.Col(this._getAliasForField(modelName, subQueryAttribute[1], options) || subQueryAttribute[1]);\r\n          }\r\n        }\r\n\r\n        mainQueryOrder.push(this.quote(order, model, '->'));\r\n      }\r\n    } else if (options.order instanceof Utils.SequelizeMethod) {\r\n      const sql = this.quote(options.order, model, '->');\r\n      if (subQuery) {\r\n        subQueryOrder.push(sql);\r\n      }\r\n      mainQueryOrder.push(sql);\r\n    } else {\r\n      throw new Error('Order must be type of array or instance of a valid sequelize method.');\r\n    }\r\n\r\n    return { mainQueryOrder, subQueryOrder };\r\n  }\r\n\r\n  selectFromTableFragment(options, model, attributes, tables, mainTableAs) {\r\n    let fragment = `SELECT ${attributes.join(', ')} FROM ${tables}`;\r\n\r\n    if (mainTableAs) {\r\n      fragment += ` AS ${mainTableAs}`;\r\n    }\r\n\r\n    if (options.indexHints && this._dialect.supports.indexHints) {\r\n      for (const hint of options.indexHints) {\r\n        if (IndexHints[hint.type]) {\r\n          fragment += ` ${IndexHints[hint.type]} INDEX (${hint.values.map(indexName => this.quoteIdentifiers(indexName)).join(',')})`;\r\n        }\r\n      }\r\n    }\r\n\r\n    return fragment;\r\n  }\r\n\r\n  /**\r\n   * Returns an SQL fragment for adding result constraints.\r\n   *\r\n   * @param  {Object} options An object with selectQuery options.\r\n   * @returns {string}         The generated sql query.\r\n   * @private\r\n   */\r\n  addLimitAndOffset(options) {\r\n    let fragment = '';\r\n\r\n    /* eslint-disable */\r\n    if (options.offset != null && options.limit == null) {\r\n      fragment += ' LIMIT ' + this.escape(options.offset) + ', ' + 10000000000000;\r\n    } else if (options.limit != null) {\r\n      if (options.offset != null) {\r\n        fragment += ' LIMIT ' + this.escape(options.offset) + ', ' + this.escape(options.limit);\r\n      } else {\r\n        fragment += ' LIMIT ' + this.escape(options.limit);\r\n      }\r\n    }\r\n    /* eslint-enable */\r\n\r\n    return fragment;\r\n  }\r\n\r\n  handleSequelizeMethod(smth, tableName, factory, options, prepend) {\r\n    let result;\r\n\r\n    if (Object.prototype.hasOwnProperty.call(this.OperatorMap, smth.comparator)) {\r\n      smth.comparator = this.OperatorMap[smth.comparator];\r\n    }\r\n\r\n    if (smth instanceof Utils.Where) {\r\n      let value = smth.logic;\r\n      let key;\r\n\r\n      if (smth.attribute instanceof Utils.SequelizeMethod) {\r\n        key = this.getWhereConditions(smth.attribute, tableName, factory, options, prepend);\r\n      } else {\r\n        key = `${this.quoteTable(smth.attribute.Model.name)}.${this.quoteIdentifier(smth.attribute.field || smth.attribute.fieldName)}`;\r\n      }\r\n\r\n      if (value && value instanceof Utils.SequelizeMethod) {\r\n        value = this.getWhereConditions(value, tableName, factory, options, prepend);\r\n\r\n        if (value === 'NULL') {\r\n          if (smth.comparator === '=') {\r\n            smth.comparator = 'IS';\r\n          }\r\n          if (smth.comparator === '!=') {\r\n            smth.comparator = 'IS NOT';\r\n          }\r\n        }\r\n\r\n        return [key, value].join(` ${smth.comparator} `);\r\n      }\r\n      if (_.isPlainObject(value)) {\r\n        return this.whereItemQuery(smth.attribute, value, {\r\n          model: factory\r\n        });\r\n      }\r\n      if (typeof value === 'boolean') {\r\n        value = this.booleanValue(value);\r\n      } else {\r\n        value = this.escape(value);\r\n      }\r\n\r\n      if (value === 'NULL') {\r\n        if (smth.comparator === '=') {\r\n          smth.comparator = 'IS';\r\n        }\r\n        if (smth.comparator === '!=') {\r\n          smth.comparator = 'IS NOT';\r\n        }\r\n      }\r\n\r\n      return [key, value].join(` ${smth.comparator} `);\r\n    }\r\n    if (smth instanceof Utils.Literal) {\r\n      return smth.val;\r\n    }\r\n    if (smth instanceof Utils.Cast) {\r\n      if (smth.val instanceof Utils.SequelizeMethod) {\r\n        result = this.handleSequelizeMethod(smth.val, tableName, factory, options, prepend);\r\n      } else if (_.isPlainObject(smth.val)) {\r\n        result = this.whereItemsQuery(smth.val);\r\n      } else {\r\n        result = this.escape(smth.val);\r\n      }\r\n\r\n      return `CAST(${result} AS ${smth.type.toUpperCase()})`;\r\n    }\r\n    if (smth instanceof Utils.Fn) {\r\n      return `${smth.fn}(${smth.args.map(arg => {\r\n        if (arg instanceof Utils.SequelizeMethod) {\r\n          return this.handleSequelizeMethod(arg, tableName, factory, options, prepend);\r\n        }\r\n        if (_.isPlainObject(arg)) {\r\n          return this.whereItemsQuery(arg);\r\n        }\r\n        return this.escape(arg);\r\n      }).join(', ')})`;\r\n    }\r\n    if (smth instanceof Utils.Col) {\r\n      if (Array.isArray(smth.col) && !factory) {\r\n        throw new Error('Cannot call Sequelize.col() with array outside of order / group clause');\r\n      }\r\n      if (smth.col.startsWith('*')) {\r\n        return '*';\r\n      }\r\n      return this.quote(smth.col, factory);\r\n    }\r\n    return smth.toString(this, factory);\r\n  }\r\n\r\n  whereQuery(where, options) {\r\n    const query = this.whereItemsQuery(where, options);\r\n    if (query && query.length) {\r\n      return `WHERE ${query}`;\r\n    }\r\n    return '';\r\n  }\r\n\r\n  whereItemsQuery(where, options, binding) {\r\n    if (\r\n      where === null ||\r\n      where === undefined ||\r\n      Utils.getComplexSize(where) === 0\r\n    ) {\r\n      // NO OP\r\n      return '';\r\n    }\r\n\r\n    if (typeof where === 'string') {\r\n      throw new Error('Support for `{where: \\'raw query\\'}` has been removed.');\r\n    }\r\n\r\n    const items = [];\r\n\r\n    binding = binding || 'AND';\r\n    if (binding[0] !== ' ') binding = ` ${binding} `;\r\n\r\n    if (_.isPlainObject(where)) {\r\n      Utils.getComplexKeys(where).forEach(prop => {\r\n        const item = where[prop];\r\n        items.push(this.whereItemQuery(prop, item, options));\r\n      });\r\n    } else {\r\n      items.push(this.whereItemQuery(undefined, where, options));\r\n    }\r\n\r\n    return items.length && items.filter(item => item && item.length).join(binding) || '';\r\n  }\r\n\r\n  whereItemQuery(key, value, options = {}) {\r\n    if (value === undefined) {\r\n      throw new Error(`WHERE parameter \"${key}\" has invalid \"undefined\" value`);\r\n    }\r\n\r\n    if (typeof key === 'string' && key.includes('.') && options.model) {\r\n      const keyParts = key.split('.');\r\n      if (options.model.rawAttributes[keyParts[0]] && options.model.rawAttributes[keyParts[0]].type instanceof DataTypes.JSON) {\r\n        const tmp = {};\r\n        const field = options.model.rawAttributes[keyParts[0]];\r\n        _.set(tmp, keyParts.slice(1), value);\r\n        return this.whereItemQuery(field.field || keyParts[0], tmp, Object.assign({ field }, options));\r\n      }\r\n    }\r\n\r\n    const field = this._findField(key, options);\r\n    const fieldType = field && field.type || options.type;\r\n\r\n    const isPlainObject = _.isPlainObject(value);\r\n    const isArray = !isPlainObject && Array.isArray(value);\r\n    key = this.OperatorsAliasMap && this.OperatorsAliasMap[key] || key;\r\n    if (isPlainObject) {\r\n      value = this._replaceAliases(value);\r\n    }\r\n    const valueKeys = isPlainObject && Utils.getComplexKeys(value);\r\n\r\n    if (key === undefined) {\r\n      if (typeof value === 'string') {\r\n        return value;\r\n      }\r\n\r\n      if (isPlainObject && valueKeys.length === 1) {\r\n        return this.whereItemQuery(valueKeys[0], value[valueKeys[0]], options);\r\n      }\r\n    }\r\n\r\n    if (value === null) {\r\n      const opValue = options.bindParam ? 'NULL' : this.escape(value, field);\r\n      return this._joinKeyValue(key, opValue, this.OperatorMap[Op.is], options.prefix);\r\n    }\r\n\r\n    if (!value) {\r\n      const opValue = options.bindParam ? this.format(value, field, options, options.bindParam) : this.escape(value, field);\r\n      return this._joinKeyValue(key, opValue, this.OperatorMap[Op.eq], options.prefix);\r\n    }\r\n\r\n    if (value instanceof Utils.SequelizeMethod && !(key !== undefined && value instanceof Utils.Fn)) {\r\n      return this.handleSequelizeMethod(value);\r\n    }\r\n\r\n    // Convert where: [] to Op.and if possible, else treat as literal/replacements\r\n    if (key === undefined && isArray) {\r\n      if (Utils.canTreatArrayAsAnd(value)) {\r\n        key = Op.and;\r\n      } else {\r\n        throw new Error('Support for literal replacements in the `where` object has been removed.');\r\n      }\r\n    }\r\n\r\n    if (key === Op.or || key === Op.and || key === Op.not) {\r\n      return this._whereGroupBind(key, value, options);\r\n    }\r\n\r\n\r\n    if (value[Op.or]) {\r\n      return this._whereBind(this.OperatorMap[Op.or], key, value[Op.or], options);\r\n    }\r\n\r\n    if (value[Op.and]) {\r\n      return this._whereBind(this.OperatorMap[Op.and], key, value[Op.and], options);\r\n    }\r\n\r\n    if (isArray && fieldType instanceof DataTypes.ARRAY) {\r\n      const opValue = options.bindParam ? this.format(value, field, options, options.bindParam) : this.escape(value, field);\r\n      return this._joinKeyValue(key, opValue, this.OperatorMap[Op.eq], options.prefix);\r\n    }\r\n\r\n    if (isPlainObject && fieldType instanceof DataTypes.JSON && options.json !== false) {\r\n      return this._whereJSON(key, value, options);\r\n    }\r\n    // If multiple keys we combine the different logic conditions\r\n    if (isPlainObject && valueKeys.length > 1) {\r\n      return this._whereBind(this.OperatorMap[Op.and], key, value, options);\r\n    }\r\n\r\n    if (isArray) {\r\n      return this._whereParseSingleValueObject(key, field, Op.in, value, options);\r\n    }\r\n    if (isPlainObject) {\r\n      if (this.OperatorMap[valueKeys[0]]) {\r\n        return this._whereParseSingleValueObject(key, field, valueKeys[0], value[valueKeys[0]], options);\r\n      }\r\n      return this._whereParseSingleValueObject(key, field, this.OperatorMap[Op.eq], value, options);\r\n    }\r\n\r\n    if (key === Op.placeholder) {\r\n      const opValue = options.bindParam ? this.format(value, field, options, options.bindParam) : this.escape(value, field);\r\n      return this._joinKeyValue(this.OperatorMap[key], opValue, this.OperatorMap[Op.eq], options.prefix);\r\n    }\r\n\r\n    const opValue = options.bindParam ? this.format(value, field, options, options.bindParam) : this.escape(value, field);\r\n    return this._joinKeyValue(key, opValue, this.OperatorMap[Op.eq], options.prefix);\r\n  }\r\n\r\n  _findField(key, options) {\r\n    if (options.field) {\r\n      return options.field;\r\n    }\r\n\r\n    if (options.model && options.model.rawAttributes && options.model.rawAttributes[key]) {\r\n      return options.model.rawAttributes[key];\r\n    }\r\n\r\n    if (options.model && options.model.fieldRawAttributesMap && options.model.fieldRawAttributesMap[key]) {\r\n      return options.model.fieldRawAttributesMap[key];\r\n    }\r\n  }\r\n\r\n  // OR/AND/NOT grouping logic\r\n  _whereGroupBind(key, value, options) {\r\n    const binding = key === Op.or ? this.OperatorMap[Op.or] : this.OperatorMap[Op.and];\r\n    const outerBinding = key === Op.not ? 'NOT ' : '';\r\n\r\n    if (Array.isArray(value)) {\r\n      value = value.map(item => {\r\n        let itemQuery = this.whereItemsQuery(item, options, this.OperatorMap[Op.and]);\r\n        if (itemQuery && itemQuery.length && (Array.isArray(item) || _.isPlainObject(item)) && Utils.getComplexSize(item) > 1) {\r\n          itemQuery = `(${itemQuery})`;\r\n        }\r\n        return itemQuery;\r\n      }).filter(item => item && item.length);\r\n\r\n      value = value.length && value.join(binding);\r\n    } else {\r\n      value = this.whereItemsQuery(value, options, binding);\r\n    }\r\n    // Op.or: [] should return no data.\r\n    // Op.not of no restriction should also return no data\r\n    if ((key === Op.or || key === Op.not) && !value) {\r\n      return '0 = 1';\r\n    }\r\n\r\n    return value ? `${outerBinding}(${value})` : undefined;\r\n  }\r\n\r\n  _whereBind(binding, key, value, options) {\r\n    if (_.isPlainObject(value)) {\r\n      value = Utils.getComplexKeys(value).map(prop => {\r\n        const item = value[prop];\r\n        return this.whereItemQuery(key, { [prop]: item }, options);\r\n      });\r\n    } else {\r\n      value = value.map(item => this.whereItemQuery(key, item, options));\r\n    }\r\n\r\n    value = value.filter(item => item && item.length);\r\n\r\n    return value.length ? `(${value.join(binding)})` : undefined;\r\n  }\r\n\r\n  _whereJSON(key, value, options) {\r\n    const items = [];\r\n    let baseKey = this.quoteIdentifier(key);\r\n    if (options.prefix) {\r\n      if (options.prefix instanceof Utils.Literal) {\r\n        baseKey = `${this.handleSequelizeMethod(options.prefix)}.${baseKey}`;\r\n      } else {\r\n        baseKey = `${this.quoteTable(options.prefix)}.${baseKey}`;\r\n      }\r\n    }\r\n\r\n    Utils.getOperators(value).forEach(op => {\r\n      const where = {\r\n        [op]: value[op]\r\n      };\r\n      items.push(this.whereItemQuery(key, where, Object.assign({}, options, { json: false })));\r\n    });\r\n\r\n    _.forOwn(value, (item, prop) => {\r\n      this._traverseJSON(items, baseKey, prop, item, [prop]);\r\n    });\r\n\r\n    const result = items.join(this.OperatorMap[Op.and]);\r\n    return items.length > 1 ? `(${result})` : result;\r\n  }\r\n\r\n  _traverseJSON(items, baseKey, prop, item, path) {\r\n    let cast;\r\n\r\n    if (path[path.length - 1].includes('::')) {\r\n      const tmp = path[path.length - 1].split('::');\r\n      cast = tmp[1];\r\n      path[path.length - 1] = tmp[0];\r\n    }\r\n\r\n    const pathKey = this.jsonPathExtractionQuery(baseKey, path);\r\n\r\n    if (_.isPlainObject(item)) {\r\n      Utils.getOperators(item).forEach(op => {\r\n        const value = this._toJSONValue(item[op]);\r\n        items.push(this.whereItemQuery(this._castKey(pathKey, value, cast), { [op]: value }));\r\n      });\r\n      _.forOwn(item, (value, itemProp) => {\r\n        this._traverseJSON(items, baseKey, itemProp, value, path.concat([itemProp]));\r\n      });\r\n\r\n      return;\r\n    }\r\n\r\n    item = this._toJSONValue(item);\r\n    items.push(this.whereItemQuery(this._castKey(pathKey, item, cast), { [Op.eq]: item }));\r\n  }\r\n\r\n  _toJSONValue(value) {\r\n    return value;\r\n  }\r\n\r\n  _castKey(key, value, cast, json) {\r\n    cast = cast || this._getJsonCast(Array.isArray(value) ? value[0] : value);\r\n    if (cast) {\r\n      return new Utils.Literal(this.handleSequelizeMethod(new Utils.Cast(new Utils.Literal(key), cast, json)));\r\n    }\r\n\r\n    return new Utils.Literal(key);\r\n  }\r\n\r\n  _getJsonCast(value) {\r\n    if (typeof value === 'number') {\r\n      return 'double precision';\r\n    }\r\n    if (value instanceof Date) {\r\n      return 'timestamptz';\r\n    }\r\n    if (typeof value === 'boolean') {\r\n      return 'boolean';\r\n    }\r\n    return;\r\n  }\r\n\r\n  _joinKeyValue(key, value, comparator, prefix) {\r\n    if (!key) {\r\n      return value;\r\n    }\r\n    if (comparator === undefined) {\r\n      throw new Error(`${key} and ${value} has no comparator`);\r\n    }\r\n    key = this._getSafeKey(key, prefix);\r\n    return [key, value].join(` ${comparator} `);\r\n  }\r\n\r\n  _getSafeKey(key, prefix) {\r\n    if (key instanceof Utils.SequelizeMethod) {\r\n      key = this.handleSequelizeMethod(key);\r\n      return this._prefixKey(this.handleSequelizeMethod(key), prefix);\r\n    }\r\n\r\n    if (Utils.isColString(key)) {\r\n      key = key.substr(1, key.length - 2).split('.');\r\n\r\n      if (key.length > 2) {\r\n        key = [\r\n          // join the tables by -> to match out internal namings\r\n          key.slice(0, -1).join('->'),\r\n          key[key.length - 1]\r\n        ];\r\n      }\r\n\r\n      return key.map(identifier => this.quoteIdentifier(identifier)).join('.');\r\n    }\r\n\r\n    return this._prefixKey(this.quoteIdentifier(key), prefix);\r\n  }\r\n\r\n  _prefixKey(key, prefix) {\r\n    if (prefix) {\r\n      if (prefix instanceof Utils.Literal) {\r\n        return [this.handleSequelizeMethod(prefix), key].join('.');\r\n      }\r\n\r\n      return [this.quoteTable(prefix), key].join('.');\r\n    }\r\n\r\n    return key;\r\n  }\r\n\r\n  _whereParseSingleValueObject(key, field, prop, value, options) {\r\n    if (prop === Op.not) {\r\n      if (Array.isArray(value)) {\r\n        prop = Op.notIn;\r\n      } else if (value !== null && value !== true && value !== false) {\r\n        prop = Op.ne;\r\n      }\r\n    }\r\n\r\n    let comparator = this.OperatorMap[prop] || this.OperatorMap[Op.eq];\r\n\r\n    switch (prop) {\r\n      case Op.in:\r\n      case Op.notIn:\r\n        if (value instanceof Utils.Literal) {\r\n          return this._joinKeyValue(key, value.val, comparator, options.prefix);\r\n        }\r\n\r\n        if (value.length) {\r\n          return this._joinKeyValue(key, `(${value.map(item => this.escape(item, field)).join(', ')})`, comparator, options.prefix);\r\n        }\r\n\r\n        if (comparator === this.OperatorMap[Op.in]) {\r\n          return this._joinKeyValue(key, '(NULL)', comparator, options.prefix);\r\n        }\r\n\r\n        return '';\r\n      case Op.any:\r\n      case Op.all:\r\n        comparator = `${this.OperatorMap[Op.eq]} ${comparator}`;\r\n        if (value[Op.values]) {\r\n          return this._joinKeyValue(key, `(VALUES ${value[Op.values].map(item => `(${this.escape(item)})`).join(', ')})`, comparator, options.prefix);\r\n        }\r\n\r\n        return this._joinKeyValue(key, `(${this.escape(value, field)})`, comparator, options.prefix);\r\n      case Op.between:\r\n      case Op.notBetween:\r\n        return this._joinKeyValue(key, `${this.escape(value[0], field)} AND ${this.escape(value[1], field)}`, comparator, options.prefix);\r\n      case Op.raw:\r\n        throw new Error('The `$raw` where property is no longer supported.  Use `sequelize.literal` instead.');\r\n      case Op.col:\r\n        comparator = this.OperatorMap[Op.eq];\r\n        value = value.split('.');\r\n\r\n        if (value.length > 2) {\r\n          value = [\r\n            // join the tables by -> to match out internal namings\r\n            value.slice(0, -1).join('->'),\r\n            value[value.length - 1]\r\n          ];\r\n        }\r\n\r\n        return this._joinKeyValue(key, value.map(identifier => this.quoteIdentifier(identifier)).join('.'), comparator, options.prefix);\r\n      case Op.startsWith:\r\n        comparator = this.OperatorMap[Op.like];\r\n        return this._joinKeyValue(key, this.escape(`${value}%`), comparator, options.prefix);\r\n      case Op.endsWith:\r\n        comparator = this.OperatorMap[Op.like];\r\n        return this._joinKeyValue(key, this.escape(`%${value}`), comparator, options.prefix);\r\n      case Op.substring:\r\n        comparator = this.OperatorMap[Op.like];\r\n        return this._joinKeyValue(key, this.escape(`%${value}%`), comparator, options.prefix);\r\n    }\r\n\r\n    const escapeOptions = {\r\n      acceptStrings: comparator.includes(this.OperatorMap[Op.like])\r\n    };\r\n\r\n    if (_.isPlainObject(value)) {\r\n      if (value[Op.col]) {\r\n        return this._joinKeyValue(key, this.whereItemQuery(null, value), comparator, options.prefix);\r\n      }\r\n      if (value[Op.any]) {\r\n        escapeOptions.isList = true;\r\n        return this._joinKeyValue(key, `(${this.escape(value[Op.any], field, escapeOptions)})`, `${comparator} ${this.OperatorMap[Op.any]}`, options.prefix);\r\n      }\r\n      if (value[Op.all]) {\r\n        escapeOptions.isList = true;\r\n        return this._joinKeyValue(key, `(${this.escape(value[Op.all], field, escapeOptions)})`, `${comparator} ${this.OperatorMap[Op.all]}`, options.prefix);\r\n      }\r\n    }\r\n\r\n    if (value === null && comparator === this.OperatorMap[Op.eq]) {\r\n      return this._joinKeyValue(key, this.escape(value, field, escapeOptions), this.OperatorMap[Op.is], options.prefix);\r\n    }\r\n    if (value === null && comparator === this.OperatorMap[Op.ne]) {\r\n      return this._joinKeyValue(key, this.escape(value, field, escapeOptions), this.OperatorMap[Op.not], options.prefix);\r\n    }\r\n\r\n    return this._joinKeyValue(key, this.escape(value, field, escapeOptions), comparator, options.prefix);\r\n  }\r\n\r\n  /*\r\n    Takes something and transforms it into values of a where condition.\r\n   @private\r\n  */\r\n  getWhereConditions(smth, tableName, factory, options, prepend) {\r\n    const where = {};\r\n\r\n    if (Array.isArray(tableName)) {\r\n      tableName = tableName[0];\r\n      if (Array.isArray(tableName)) {\r\n        tableName = tableName[1];\r\n      }\r\n    }\r\n\r\n    options = options || {};\r\n\r\n    if (prepend === undefined) {\r\n      prepend = true;\r\n    }\r\n\r\n    if (smth && smth instanceof Utils.SequelizeMethod) { // Checking a property is cheaper than a lot of instanceof calls\r\n      return this.handleSequelizeMethod(smth, tableName, factory, options, prepend);\r\n    }\r\n    if (_.isPlainObject(smth)) {\r\n      return this.whereItemsQuery(smth, {\r\n        model: factory,\r\n        prefix: prepend && tableName,\r\n        type: options.type\r\n      });\r\n    }\r\n    if (typeof smth === 'number') {\r\n      let primaryKeys = factory ? Object.keys(factory.primaryKeys) : [];\r\n\r\n      if (primaryKeys.length > 0) {\r\n        // Since we're just a number, assume only the first key\r\n        primaryKeys = primaryKeys[0];\r\n      } else {\r\n        primaryKeys = 'id';\r\n      }\r\n\r\n      where[primaryKeys] = smth;\r\n\r\n      return this.whereItemsQuery(where, {\r\n        model: factory,\r\n        prefix: prepend && tableName\r\n      });\r\n    }\r\n    if (typeof smth === 'string') {\r\n      return this.whereItemsQuery(smth, {\r\n        model: factory,\r\n        prefix: prepend && tableName\r\n      });\r\n    }\r\n    if (Buffer.isBuffer(smth)) {\r\n      return this.escape(smth);\r\n    }\r\n    if (Array.isArray(smth)) {\r\n      if (smth.length === 0 || smth.length > 0 && smth[0].length === 0) return '1=1';\r\n      if (Utils.canTreatArrayAsAnd(smth)) {\r\n        const _smth = { [Op.and]: smth };\r\n        return this.getWhereConditions(_smth, tableName, factory, options, prepend);\r\n      }\r\n      throw new Error('Support for literal replacements in the `where` object has been removed.');\r\n    }\r\n    if (smth === null) {\r\n      return this.whereItemsQuery(smth, {\r\n        model: factory,\r\n        prefix: prepend && tableName\r\n      });\r\n    }\r\n\r\n    return '1=1';\r\n  }\r\n\r\n  // A recursive parser for nested where conditions\r\n  parseConditionObject(conditions, path) {\r\n    path = path || [];\r\n    return _.reduce(conditions, (result, value, key) => {\r\n      if (_.isObject(value)) {\r\n        return result.concat(this.parseConditionObject(value, path.concat(key))); // Recursively parse objects\r\n      }\r\n      result.push({ path: path.concat(key), value });\r\n      return result;\r\n    }, []);\r\n  }\r\n\r\n  booleanValue(value) {\r\n    return value;\r\n  }\r\n}\r\n\r\nObject.assign(QueryGenerator.prototype, require('./query-generator/operators'));\r\nObject.assign(QueryGenerator.prototype, require('./query-generator/transaction'));\r\n\r\nmodule.exports = QueryGenerator;\r\n"]} \ No newline at end of file +//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../lib/dialects/abstract/query-generator.js"],"names":["util","require","_","uuidv4","semver","Utils","deprecations","SqlString","DataTypes","Model","Association","BelongsTo","BelongsToMany","HasMany","Op","sequelizeError","IndexHints","QuoteHelper","QueryGenerator","options","sequelize","Error","_dialect","dialect","name","tableName","schema","isPlainObject","delimiter","param","_schema","self","table","_schemaDelimiter","toString","quoteTable","dropTableQuery","schemaDelimiter","addSchema","before","after","valueHash","modelAttributes","defaults","modelAttributeMap","fields","values","bind","quotedTable","bindParam","undefined","query","valueQuery","emptyQuery","outputFragment","identityWrapperRequired","tmpTable","each","attribute","key","field","supports","returnValues","returning","output","hasTrigger","tmpTableTrigger","tmpColumns","outputColumns","modelKey","type","VIRTUAL","length","quoteIdentifier","toSql","selectFromTmp","get","searchPath","EXCEPTION","exception","removeNullValuesFromHash","omitNull","Object","prototype","hasOwnProperty","call","value","push","autoIncrement","defaultValue","splice","DEFAULT","escape","SequelizeMethod","context","format","replacements","ignoreDuplicates","inserts","onConflictDoNothing","attributes","join","gte","databaseVersion","replace","onDuplicate","identityInsert","result","fieldValueHashes","fieldMappedAttributes","tuples","serials","allAttributes","onDuplicateKeyUpdate","fieldValueHash","forOwn","includes","map","bulkDefault","updateOnDuplicate","conflictKeys","upsertKeys","attr","updateKeys","valueKeys","Array","isArray","attrValueHash","where","suffix","limit","mapToModel","update","whereOptions","whereQuery","trim","operator","returningFragment","rawTablename","prefix","fieldsSql","handleSequelizeMethod","inspect","index","collate","order","nameIndex","_conformIndex","quoteIdentifiers","concurrently","ind","indexViaAlter","concat","unique","using","parser","compact","constraintSnippet","getConstraintSnippet","constraintName","fieldsSqlQuotedString","fieldsSqlString","toUpperCase","whereItemsQuery","references","referencesSnippet","onUpdate","onDelete","collection","parent","connector","validOrderOptions","forEach","item","previous","previousAssociation","previousModel","target","model","as","through","getAssociationForAlias","orderIndex","indexOf","literal","associations","rawAttributes","itemSplit","split","JSON","identifier","path","slice","jsonPathExtractionQuery","collectionLength","tableNames","i","_modelAttribute","sql","collectionItem","quote","fieldName","raw","force","identifiers","head","tail","alias","isObject","schemas","validate","stringify","simpleEscape","escVal","timezone","operation","identity","typeValidation","isList","error","ValidationError","errors","ValidationErrorItem","message","isIdentifierQuoted","column","paths","toPath","pathStr","quotedColumn","subPath","test","addTicks","__","digit","mainQueryItems","subQueryItems","subQuery","hasMultiAssociation","main","mainTable","quotedName","topLevelInfo","names","mainJoinQueries","subJoinQueries","minifyAliases","aliasesMapping","Map","aliasesByTable","tableAs","t","keyAtt","primaryKeyAttributes","some","escapeAttributes","include","groupedLimit","separate","joinQueries","generateInclude","externalAs","internalAs","mainQuery","uniq","selectFromTableFragment","assign","groupedLimitOrder","whereKey","groupedTableName","on","foreignKeyField","manyFromSource","groupedLimitOptions","_validateIncludedElements","association","duplicating","required","placeholder","hasJoin","includeMap","includeNames","baseQuery","selectQuery","offset","placeHolder","whereItemQuery","splicePos","groupWhere","foreignIdentifierField","spliceStr","getWhereConditions","startsWith","group","aliasGrouping","having","orders","getQueryOrders","mainQueryOrder","subQueryOrder","limitOrder","addLimitAndOffset","lock","level","lockKey","forShare","lockOf","of","skipLocked","src","_getAliasForField","mainTableAs","addTable","noRawAttributes","_getMinifiedAlias","TICK_CHAR","quoteAttribute","isEmpty","parentTableName","mainChildIncludes","subChildIncludes","requiredMismatch","includeAs","joinQuery","keysEscaped","includeIgnoreAttributes","_expandAttributes","mapFinderOptions","includeAttributes","attrAs","verbatim","Literal","Cast","Fn","val","generateThroughJoin","_generateSubQueryFilter","generateJoin","childInclude","_pseudo","childJoinQueries","body","condition","match","minifiedAlias","size","set","parentIsTop","$parent","joinWhere","left","source","attrLeft","sourceKeyAttribute","primaryKeyAttribute","fieldLeft","identifierField","asLeft","right","tableRight","getTableName","fieldRight","targetIdentifier","asRight","joinOn","subqueryAttributes","joinSource","or","throughTable","throughAs","externalThroughAs","throughAttributes","tableSource","identSource","tableTarget","identTarget","attrTarget","targetKeyField","joinType","joinBody","joinCondition","attrSource","sourceKey","sourceJoinOn","targetJoinOn","throughWhere","targetWhere","sourceKeyField","mainModel","aliasedSource","joinTableDependent","subQueryFilter","child","nestedIncludes","_getRequiredClosure","topInclude","topParent","topAssociation","primaryKeyField","toTarget","and","isBelongsTo","associationType","sourceField","targetField","copy","filter","inc","subQueryAttribute","find","a","modelName","Col","tables","fragment","indexHints","hint","indexName","smth","factory","prepend","OperatorMap","comparator","Where","logic","booleanValue","fn","args","arg","col","binding","getComplexSize","items","getComplexKeys","prop","keyParts","tmp","_findField","fieldType","OperatorsAliasMap","_replaceAliases","opValue","_joinKeyValue","is","eq","canTreatArrayAsAnd","not","_whereGroupBind","_whereBind","ARRAY","json","_whereJSON","_whereParseSingleValueObject","in","fieldRawAttributesMap","outerBinding","itemQuery","baseKey","getOperators","op","_traverseJSON","cast","pathKey","_toJSONValue","_castKey","itemProp","_getJsonCast","Date","_getSafeKey","_prefixKey","isColString","substr","notIn","ne","any","all","between","notBetween","like","endsWith","substring","escapeOptions","acceptStrings","primaryKeys","keys","Buffer","isBuffer","_smth","conditions","reduce","parseConditionObject","module","exports"],"mappings":"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","sourcesContent":["'use strict';\n\nconst util = require('util');\nconst _ = require('lodash');\nconst uuidv4 = require('uuid/v4');\nconst semver = require('semver');\n\nconst Utils = require('../../utils');\nconst deprecations = require('../../utils/deprecations');\nconst SqlString = require('../../sql-string');\nconst DataTypes = require('../../data-types');\nconst Model = require('../../model');\nconst Association = require('../../associations/base');\nconst BelongsTo = require('../../associations/belongs-to');\nconst BelongsToMany = require('../../associations/belongs-to-many');\nconst HasMany = require('../../associations/has-many');\nconst Op = require('../../operators');\nconst sequelizeError = require('../../errors');\nconst IndexHints = require('../../index-hints');\n\nconst QuoteHelper = require('./query-generator/helpers/quote');\n\n/**\n * Abstract Query Generator\n *\n * @private\n */\nclass QueryGenerator {\n  constructor(options) {\n    if (!options.sequelize) throw new Error('QueryGenerator initialized without options.sequelize');\n    if (!options._dialect) throw new Error('QueryGenerator initialized without options._dialect');\n\n    this.sequelize = options.sequelize;\n    this.options = options.sequelize.options;\n\n    // dialect name\n    this.dialect = options._dialect.name;\n    this._dialect = options._dialect;\n  }\n\n  extractTableDetails(tableName, options) {\n    options = options || {};\n    tableName = tableName || {};\n    return {\n      schema: tableName.schema || options.schema || 'public',\n      tableName: _.isPlainObject(tableName) ? tableName.tableName : tableName,\n      delimiter: tableName.delimiter || options.delimiter || '.'\n    };\n  }\n\n  addSchema(param) {\n    if (!param._schema) return param.tableName || param;\n    const self = this;\n    return {\n      tableName: param.tableName || param,\n      table: param.tableName || param,\n      name: param.name || param,\n      schema: param._schema,\n      delimiter: param._schemaDelimiter || '.',\n      toString() {\n        return self.quoteTable(this);\n      }\n    };\n  }\n\n  dropSchema(tableName, options) {\n    return this.dropTableQuery(tableName, options);\n  }\n\n  describeTableQuery(tableName, schema, schemaDelimiter) {\n    const table = this.quoteTable(\n      this.addSchema({\n        tableName,\n        _schema: schema,\n        _schemaDelimiter: schemaDelimiter\n      })\n    );\n\n    return `DESCRIBE ${table};`;\n  }\n\n  dropTableQuery(tableName) {\n    return `DROP TABLE IF EXISTS ${this.quoteTable(tableName)};`;\n  }\n\n  renameTableQuery(before, after) {\n    return `ALTER TABLE ${this.quoteTable(before)} RENAME TO ${this.quoteTable(after)};`;\n  }\n\n  /**\n   * Returns an insert into command\n   *\n   * @param {string} table\n   * @param {Object} valueHash       attribute value pairs\n   * @param {Object} modelAttributes\n   * @param {Object} [options]\n   *\n   * @private\n   */\n  insertQuery(table, valueHash, modelAttributes, options) {\n    options = options || {};\n    _.defaults(options, this.options);\n\n    const modelAttributeMap = {};\n    const fields = [];\n    const values = [];\n    const bind = [];\n    const quotedTable = this.quoteTable(table);\n    const bindParam = options.bindParam === undefined ? this.bindParam(bind) : options.bindParam;\n    let query;\n    let valueQuery = '';\n    let emptyQuery = '';\n    let outputFragment = '';\n    let identityWrapperRequired = false;\n    let tmpTable = ''; //tmpTable declaration for trigger\n\n    if (modelAttributes) {\n      _.each(modelAttributes, (attribute, key) => {\n        modelAttributeMap[key] = attribute;\n        if (attribute.field) {\n          modelAttributeMap[attribute.field] = attribute;\n        }\n      });\n    }\n\n    if (this._dialect.supports['DEFAULT VALUES']) {\n      emptyQuery += ' DEFAULT VALUES';\n    } else if (this._dialect.supports['VALUES ()']) {\n      emptyQuery += ' VALUES ()';\n    }\n\n    if (this._dialect.supports.returnValues && options.returning) {\n      if (this._dialect.supports.returnValues.returning) {\n        valueQuery += ' RETURNING *';\n        emptyQuery += ' RETURNING *';\n      } else if (this._dialect.supports.returnValues.output) {\n        outputFragment = ' OUTPUT INSERTED.*';\n\n        //To capture output rows when there is a trigger on MSSQL DB\n        if (modelAttributes && options.hasTrigger && this._dialect.supports.tmpTableTrigger) {\n\n          let tmpColumns = '';\n          let outputColumns = '';\n\n          for (const modelKey in modelAttributes) {\n            const attribute = modelAttributes[modelKey];\n            if (!(attribute.type instanceof DataTypes.VIRTUAL)) {\n              if (tmpColumns.length > 0) {\n                tmpColumns += ',';\n                outputColumns += ',';\n              }\n\n              tmpColumns += `${this.quoteIdentifier(attribute.field)} ${attribute.type.toSql()}`;\n              outputColumns += `INSERTED.${this.quoteIdentifier(attribute.field)}`;\n            }\n          }\n\n          tmpTable = `declare @tmp table (${tmpColumns});`;\n          outputFragment = ` OUTPUT ${outputColumns} into @tmp`;\n          const selectFromTmp = ';select * from @tmp';\n\n          valueQuery += selectFromTmp;\n          emptyQuery += selectFromTmp;\n        }\n      }\n    }\n\n    if (_.get(this, ['sequelize', 'options', 'dialectOptions', 'prependSearchPath']) || options.searchPath) {\n      // Not currently supported with search path (requires output of multiple queries)\n      options.bindParam = false;\n    }\n\n    if (this._dialect.supports.EXCEPTION && options.exception) {\n      // Not currently supported with bind parameters (requires output of multiple queries)\n      options.bindParam = false;\n    }\n\n    valueHash = Utils.removeNullValuesFromHash(valueHash, this.options.omitNull);\n    for (const key in valueHash) {\n      if (Object.prototype.hasOwnProperty.call(valueHash, key)) {\n        const value = valueHash[key];\n        fields.push(this.quoteIdentifier(key));\n\n        // SERIALS' can't be NULL in postgresql, use DEFAULT where supported\n        if (modelAttributeMap && modelAttributeMap[key] && modelAttributeMap[key].autoIncrement === true && !value) {\n          if (!this._dialect.supports.autoIncrement.defaultValue) {\n            fields.splice(-1, 1);\n          } else if (this._dialect.supports.DEFAULT) {\n            values.push('DEFAULT');\n          } else {\n            values.push(this.escape(null));\n          }\n        } else {\n          if (modelAttributeMap && modelAttributeMap[key] && modelAttributeMap[key].autoIncrement === true) {\n            identityWrapperRequired = true;\n          }\n\n          if (value instanceof Utils.SequelizeMethod || options.bindParam === false) {\n            values.push(this.escape(value, modelAttributeMap && modelAttributeMap[key] || undefined, { context: 'INSERT' }));\n          } else {\n            values.push(this.format(value, modelAttributeMap && modelAttributeMap[key] || undefined, { context: 'INSERT' }, bindParam));\n          }\n        }\n      }\n    }\n\n    const replacements = {\n      ignoreDuplicates: options.ignoreDuplicates ? this._dialect.supports.inserts.ignoreDuplicates : '',\n      onConflictDoNothing: options.ignoreDuplicates ? this._dialect.supports.inserts.onConflictDoNothing : '',\n      attributes: fields.join(','),\n      output: outputFragment,\n      values: values.join(','),\n      tmpTable\n    };\n\n    valueQuery = `${tmpTable}INSERT${replacements.ignoreDuplicates} INTO ${quotedTable} (${replacements.attributes})${replacements.output} VALUES (${replacements.values})${replacements.onConflictDoNothing}${valueQuery}`;\n    emptyQuery = `${tmpTable}INSERT${replacements.ignoreDuplicates} INTO ${quotedTable}${replacements.output}${replacements.onConflictDoNothing}${emptyQuery}`;\n\n    if (this._dialect.supports.EXCEPTION && options.exception) {\n      // Mostly for internal use, so we expect the user to know what he's doing!\n      // pg_temp functions are private per connection, so we never risk this function interfering with another one.\n      if (semver.gte(this.sequelize.options.databaseVersion, '9.2.0')) {\n        // >= 9.2 - Use a UUID but prefix with 'func_' (numbers first not allowed)\n        const delimiter = `$func_${uuidv4().replace(/-/g, '')}$`;\n\n        options.exception = 'WHEN unique_violation THEN GET STACKED DIAGNOSTICS sequelize_caught_exception = PG_EXCEPTION_DETAIL;';\n        valueQuery = `${`CREATE OR REPLACE FUNCTION pg_temp.testfunc(OUT response ${quotedTable}, OUT sequelize_caught_exception text) RETURNS RECORD AS ${delimiter}` +\n          ' BEGIN '}${valueQuery} INTO response; EXCEPTION ${options.exception} END ${delimiter\n        } LANGUAGE plpgsql; SELECT (testfunc.response).*, testfunc.sequelize_caught_exception FROM pg_temp.testfunc(); DROP FUNCTION IF EXISTS pg_temp.testfunc()`;\n      } else {\n        options.exception = 'WHEN unique_violation THEN NULL;';\n        valueQuery = `CREATE OR REPLACE FUNCTION pg_temp.testfunc() RETURNS SETOF ${quotedTable} AS $body$ BEGIN RETURN QUERY ${valueQuery}; EXCEPTION ${options.exception} END; $body$ LANGUAGE plpgsql; SELECT * FROM pg_temp.testfunc(); DROP FUNCTION IF EXISTS pg_temp.testfunc();`;\n      }\n    }\n\n    if (this._dialect.supports['ON DUPLICATE KEY'] && options.onDuplicate) {\n      valueQuery += ` ON DUPLICATE KEY ${options.onDuplicate}`;\n      emptyQuery += ` ON DUPLICATE KEY ${options.onDuplicate}`;\n    }\n\n    query = `${replacements.attributes.length ? valueQuery : emptyQuery};`;\n    if (identityWrapperRequired && this._dialect.supports.autoIncrement.identityInsert) {\n      query = `SET IDENTITY_INSERT ${quotedTable} ON; ${query} SET IDENTITY_INSERT ${quotedTable} OFF;`;\n    }\n\n    // Used by Postgres upsertQuery and calls to here with options.exception set to true\n    const result = { query };\n    if (options.bindParam !== false) {\n      result.bind = bind;\n    }\n    return result;\n  }\n\n  /**\n   * Returns an insert into command for multiple values.\n   *\n   * @param {string} tableName\n   * @param {Object} fieldValueHashes\n   * @param {Object} options\n   * @param {Object} fieldMappedAttributes\n   *\n   * @private\n   */\n  bulkInsertQuery(tableName, fieldValueHashes, options, fieldMappedAttributes) {\n    options = options || {};\n    fieldMappedAttributes = fieldMappedAttributes || {};\n\n    const tuples = [];\n    const serials = {};\n    const allAttributes = [];\n    let onDuplicateKeyUpdate = '';\n\n    for (const fieldValueHash of fieldValueHashes) {\n      _.forOwn(fieldValueHash, (value, key) => {\n        if (!allAttributes.includes(key)) {\n          allAttributes.push(key);\n        }\n        if (\n          fieldMappedAttributes[key]\n          && fieldMappedAttributes[key].autoIncrement === true\n        ) {\n          serials[key] = true;\n        }\n      });\n    }\n\n    for (const fieldValueHash of fieldValueHashes) {\n      const values = allAttributes.map(key => {\n        if (\n          this._dialect.supports.bulkDefault\n          && serials[key] === true\n        ) {\n          return fieldValueHash[key] || 'DEFAULT';\n        }\n\n        return this.escape(fieldValueHash[key], fieldMappedAttributes[key], { context: 'INSERT' });\n      });\n\n      tuples.push(`(${values.join(',')})`);\n    }\n\n    if (this._dialect.supports.inserts.updateOnDuplicate && options.updateOnDuplicate) {\n      if (this._dialect.supports.inserts.updateOnDuplicate == ' ON CONFLICT DO UPDATE SET') { // postgres / sqlite\n        // If no conflict target columns were specified, use the primary key names from options.upsertKeys\n        const conflictKeys = options.upsertKeys.map(attr => this.quoteIdentifier(attr));\n        const updateKeys = options.updateOnDuplicate.map(attr => `${this.quoteIdentifier(attr)}=EXCLUDED.${this.quoteIdentifier(attr)}`);\n        onDuplicateKeyUpdate = ` ON CONFLICT (${conflictKeys.join(',')}) DO UPDATE SET ${updateKeys.join(',')}`;\n      } else { // mysql / maria\n        const valueKeys = options.updateOnDuplicate.map(attr => `${this.quoteIdentifier(attr)}=VALUES(${this.quoteIdentifier(attr)})`);\n        onDuplicateKeyUpdate = `${this._dialect.supports.inserts.updateOnDuplicate} ${valueKeys.join(',')}`;\n      }\n    }\n\n    const ignoreDuplicates = options.ignoreDuplicates ? this._dialect.supports.inserts.ignoreDuplicates : '';\n    const attributes = allAttributes.map(attr => this.quoteIdentifier(attr)).join(',');\n    const onConflictDoNothing = options.ignoreDuplicates ? this._dialect.supports.inserts.onConflictDoNothing : '';\n    let returning = '';\n\n    if (this._dialect.supports.returnValues && Array.isArray(options.returning)) {\n      const fields = options.returning.map(field => this.quoteIdentifier(field)).join(',');\n      returning += ` RETURNING ${fields}`;\n    } else {\n      returning += this._dialect.supports.returnValues && options.returning ? ' RETURNING *' : '';\n    }\n\n    return `INSERT${ignoreDuplicates} INTO ${this.quoteTable(tableName)} (${attributes}) VALUES ${tuples.join(',')}${onDuplicateKeyUpdate}${onConflictDoNothing}${returning};`;\n  }\n\n  /**\n   * Returns an update query\n   *\n   * @param {string} tableName\n   * @param {Object} attrValueHash\n   * @param {Object} where A hash with conditions (e.g. {name: 'foo'}) OR an ID as integer\n   * @param {Object} options\n   * @param {Object} attributes\n   *\n   * @private\n   */\n  updateQuery(tableName, attrValueHash, where, options, attributes) {\n    options = options || {};\n    _.defaults(options, this.options);\n\n    attrValueHash = Utils.removeNullValuesFromHash(attrValueHash, options.omitNull, options);\n\n    const values = [];\n    const bind = [];\n    const modelAttributeMap = {};\n    let outputFragment = '';\n    let tmpTable = ''; // tmpTable declaration for trigger\n    let selectFromTmp = ''; // Select statement for trigger\n    let suffix = '';\n\n    if (_.get(this, ['sequelize', 'options', 'dialectOptions', 'prependSearchPath']) || options.searchPath) {\n      // Not currently supported with search path (requires output of multiple queries)\n      options.bindParam = false;\n    }\n\n    const bindParam = options.bindParam === undefined ? this.bindParam(bind) : options.bindParam;\n\n    if (this._dialect.supports['LIMIT ON UPDATE'] && options.limit) {\n      if (this.dialect !== 'mssql') {\n        suffix = ` LIMIT ${this.escape(options.limit)} `;\n      }\n    }\n\n    if (this._dialect.supports.returnValues) {\n      if (this._dialect.supports.returnValues.output) {\n        // we always need this for mssql\n        outputFragment = ' OUTPUT INSERTED.*';\n\n        //To capture output rows when there is a trigger on MSSQL DB\n        if (attributes && options.hasTrigger && this._dialect.supports.tmpTableTrigger) {\n          let tmpColumns = '';\n          let outputColumns = '';\n\n          for (const modelKey in attributes) {\n            const attribute = attributes[modelKey];\n            if (!(attribute.type instanceof DataTypes.VIRTUAL)) {\n              if (tmpColumns.length > 0) {\n                tmpColumns += ',';\n                outputColumns += ',';\n              }\n\n              tmpColumns += `${this.quoteIdentifier(attribute.field)} ${attribute.type.toSql()}`;\n              outputColumns += `INSERTED.${this.quoteIdentifier(attribute.field)}`;\n            }\n          }\n\n          tmpTable = `declare @tmp table (${tmpColumns}); `;\n          outputFragment = ` OUTPUT ${outputColumns} into @tmp`;\n          selectFromTmp = ';select * from @tmp';\n\n          suffix += selectFromTmp;\n        }\n      } else if (this._dialect.supports.returnValues && options.returning) {\n        // ensure that the return output is properly mapped to model fields.\n        options.mapToModel = true;\n        suffix += ' RETURNING *';\n      }\n    }\n\n    if (attributes) {\n      _.each(attributes, (attribute, key) => {\n        modelAttributeMap[key] = attribute;\n        if (attribute.field) {\n          modelAttributeMap[attribute.field] = attribute;\n        }\n      });\n    }\n\n    for (const key in attrValueHash) {\n      if (modelAttributeMap && modelAttributeMap[key] &&\n        modelAttributeMap[key].autoIncrement === true &&\n        !this._dialect.supports.autoIncrement.update) {\n        // not allowed to update identity column\n        continue;\n      }\n\n      const value = attrValueHash[key];\n\n      if (value instanceof Utils.SequelizeMethod || options.bindParam === false) {\n        values.push(`${this.quoteIdentifier(key)}=${this.escape(value, modelAttributeMap && modelAttributeMap[key] || undefined, { context: 'UPDATE' })}`);\n      } else {\n        values.push(`${this.quoteIdentifier(key)}=${this.format(value, modelAttributeMap && modelAttributeMap[key] || undefined, { context: 'UPDATE' }, bindParam)}`);\n      }\n    }\n\n    const whereOptions = _.defaults({ bindParam }, options);\n\n    if (values.length === 0) {\n      return '';\n    }\n\n    const query = `${tmpTable}UPDATE ${this.quoteTable(tableName)} SET ${values.join(',')}${outputFragment} ${this.whereQuery(where, whereOptions)}${suffix}`.trim();\n    // Used by Postgres upsertQuery and calls to here with options.exception set to true\n    const result = { query };\n    if (options.bindParam !== false) {\n      result.bind = bind;\n    }\n    return result;\n  }\n\n  /**\n   * Returns an update query using arithmetic operator\n   *\n   * @param {string} operator      String with the arithmetic operator (e.g. '+' or '-')\n   * @param {string} tableName     Name of the table\n   * @param {Object} attrValueHash A hash with attribute-value-pairs\n   * @param {Object} where         A hash with conditions (e.g. {name: 'foo'}) OR an ID as integer\n   * @param {Object} options\n   * @param {Object} attributes\n   */\n  arithmeticQuery(operator, tableName, attrValueHash, where, options, attributes) {\n    options = options || {};\n    _.defaults(options, { returning: true });\n\n    attrValueHash = Utils.removeNullValuesFromHash(attrValueHash, this.options.omitNull);\n\n    const values = [];\n    let outputFragment = '';\n    let returningFragment = '';\n\n    if (this._dialect.supports.returnValues && options.returning) {\n      if (this._dialect.supports.returnValues.returning) {\n        options.mapToModel = true;\n        returningFragment = 'RETURNING *';\n      } else if (this._dialect.supports.returnValues.output) {\n        outputFragment = ' OUTPUT INSERTED.*';\n      }\n    }\n\n    for (const key in attrValueHash) {\n      const value = attrValueHash[key];\n      values.push(`${this.quoteIdentifier(key)}=${this.quoteIdentifier(key)}${operator} ${this.escape(value)}`);\n    }\n\n    attributes = attributes || {};\n    for (const key in attributes) {\n      const value = attributes[key];\n      values.push(`${this.quoteIdentifier(key)}=${this.escape(value)}`);\n    }\n\n    return `UPDATE ${this.quoteTable(tableName)} SET ${values.join(',')}${outputFragment} ${this.whereQuery(where)} ${returningFragment}`.trim();\n  }\n\n  /*\n    Returns an add index query.\n    Parameters:\n      - tableName -> Name of an existing table, possibly with schema.\n      - options:\n        - type: UNIQUE|FULLTEXT|SPATIAL\n        - name: The name of the index. Default is <table>_<attr1>_<attr2>\n        - fields: An array of attributes as string or as hash.\n                  If the attribute is a hash, it must have the following content:\n                  - name: The name of the attribute/column\n                  - length: An integer. Optional\n                  - order: 'ASC' or 'DESC'. Optional\n        - parser\n        - using\n        - operator\n        - concurrently: Pass CONCURRENT so other operations run while the index is created\n      - rawTablename, the name of the table, without schema. Used to create the name of the index\n   @private\n  */\n  addIndexQuery(tableName, attributes, options, rawTablename) {\n    options = options || {};\n\n    if (!Array.isArray(attributes)) {\n      options = attributes;\n      attributes = undefined;\n    } else {\n      options.fields = attributes;\n    }\n\n    options.prefix = options.prefix || rawTablename || tableName;\n    if (options.prefix && typeof options.prefix === 'string') {\n      options.prefix = options.prefix.replace(/\\./g, '_');\n      options.prefix = options.prefix.replace(/(\"|')/g, '');\n    }\n\n    const fieldsSql = options.fields.map(field => {\n      if (typeof field === 'string') {\n        return this.quoteIdentifier(field);\n      }\n      if (field instanceof Utils.SequelizeMethod) {\n        return this.handleSequelizeMethod(field);\n      }\n      let result = '';\n\n      if (field.attribute) {\n        field.name = field.attribute;\n      }\n\n      if (!field.name) {\n        throw new Error(`The following index field has no name: ${util.inspect(field)}`);\n      }\n\n      result += this.quoteIdentifier(field.name);\n\n      if (this._dialect.supports.index.collate && field.collate) {\n        result += ` COLLATE ${this.quoteIdentifier(field.collate)}`;\n      }\n\n      if (this._dialect.supports.index.length && field.length) {\n        result += `(${field.length})`;\n      }\n\n      if (field.order) {\n        result += ` ${field.order}`;\n      }\n\n      return result;\n    });\n\n    if (!options.name) {\n      // Mostly for cases where addIndex is called directly by the user without an options object (for example in migrations)\n      // All calls that go through sequelize should already have a name\n      options = Utils.nameIndex(options, options.prefix);\n    }\n\n    options = Model._conformIndex(options);\n\n    if (!this._dialect.supports.index.type) {\n      delete options.type;\n    }\n\n    if (options.where) {\n      options.where = this.whereQuery(options.where);\n    }\n\n    if (typeof tableName === 'string') {\n      tableName = this.quoteIdentifiers(tableName);\n    } else {\n      tableName = this.quoteTable(tableName);\n    }\n\n    const concurrently = this._dialect.supports.index.concurrently && options.concurrently ? 'CONCURRENTLY' : undefined;\n    let ind;\n    if (this._dialect.supports.indexViaAlter) {\n      ind = [\n        'ALTER TABLE',\n        tableName,\n        concurrently,\n        'ADD'\n      ];\n    } else {\n      ind = ['CREATE'];\n    }\n\n    ind = ind.concat(\n      options.unique ? 'UNIQUE' : '',\n      options.type, 'INDEX',\n      !this._dialect.supports.indexViaAlter ? concurrently : undefined,\n      this.quoteIdentifiers(options.name),\n      this._dialect.supports.index.using === 1 && options.using ? `USING ${options.using}` : '',\n      !this._dialect.supports.indexViaAlter ? `ON ${tableName}` : undefined,\n      this._dialect.supports.index.using === 2 && options.using ? `USING ${options.using}` : '',\n      `(${fieldsSql.join(', ')}${options.operator ? ` ${options.operator}` : ''})`,\n      this._dialect.supports.index.parser && options.parser ? `WITH PARSER ${options.parser}` : undefined,\n      this._dialect.supports.index.where && options.where ? options.where : undefined\n    );\n\n    return _.compact(ind).join(' ');\n  }\n\n  addConstraintQuery(tableName, options) {\n    options = options || {};\n    const constraintSnippet = this.getConstraintSnippet(tableName, options);\n\n    if (typeof tableName === 'string') {\n      tableName = this.quoteIdentifiers(tableName);\n    } else {\n      tableName = this.quoteTable(tableName);\n    }\n\n    return `ALTER TABLE ${tableName} ADD ${constraintSnippet};`;\n  }\n\n  getConstraintSnippet(tableName, options) {\n    let constraintSnippet, constraintName;\n\n    const fieldsSql = options.fields.map(field => {\n      if (typeof field === 'string') {\n        return this.quoteIdentifier(field);\n      }\n      if (field instanceof Utils.SequelizeMethod) {\n        return this.handleSequelizeMethod(field);\n      }\n      if (field.attribute) {\n        field.name = field.attribute;\n      }\n\n      if (!field.name) {\n        throw new Error(`The following index field has no name: ${field}`);\n      }\n\n      return this.quoteIdentifier(field.name);\n    });\n\n    const fieldsSqlQuotedString = fieldsSql.join(', ');\n    const fieldsSqlString = fieldsSql.join('_');\n\n    switch (options.type.toUpperCase()) {\n      case 'UNIQUE':\n        constraintName = this.quoteIdentifier(options.name || `${tableName}_${fieldsSqlString}_uk`);\n        constraintSnippet = `CONSTRAINT ${constraintName} UNIQUE (${fieldsSqlQuotedString})`;\n        break;\n      case 'CHECK':\n        options.where = this.whereItemsQuery(options.where);\n        constraintName = this.quoteIdentifier(options.name || `${tableName}_${fieldsSqlString}_ck`);\n        constraintSnippet = `CONSTRAINT ${constraintName} CHECK (${options.where})`;\n        break;\n      case 'DEFAULT':\n        if (options.defaultValue === undefined) {\n          throw new Error('Default value must be specifed for DEFAULT CONSTRAINT');\n        }\n\n        if (this._dialect.name !== 'mssql') {\n          throw new Error('Default constraints are supported only for MSSQL dialect.');\n        }\n\n        constraintName = this.quoteIdentifier(options.name || `${tableName}_${fieldsSqlString}_df`);\n        constraintSnippet = `CONSTRAINT ${constraintName} DEFAULT (${this.escape(options.defaultValue)}) FOR ${fieldsSql[0]}`;\n        break;\n      case 'PRIMARY KEY':\n        constraintName = this.quoteIdentifier(options.name || `${tableName}_${fieldsSqlString}_pk`);\n        constraintSnippet = `CONSTRAINT ${constraintName} PRIMARY KEY (${fieldsSqlQuotedString})`;\n        break;\n      case 'FOREIGN KEY':\n        const references = options.references;\n        if (!references || !references.table || !references.field) {\n          throw new Error('references object with table and field must be specified');\n        }\n        constraintName = this.quoteIdentifier(options.name || `${tableName}_${fieldsSqlString}_${references.table}_fk`);\n        const referencesSnippet = `${this.quoteTable(references.table)} (${this.quoteIdentifier(references.field)})`;\n        constraintSnippet = `CONSTRAINT ${constraintName} `;\n        constraintSnippet += `FOREIGN KEY (${fieldsSqlQuotedString}) REFERENCES ${referencesSnippet}`;\n        if (options.onUpdate) {\n          constraintSnippet += ` ON UPDATE ${options.onUpdate.toUpperCase()}`;\n        }\n        if (options.onDelete) {\n          constraintSnippet += ` ON DELETE ${options.onDelete.toUpperCase()}`;\n        }\n        break;\n      default: throw new Error(`${options.type} is invalid.`);\n    }\n    return constraintSnippet;\n  }\n\n  removeConstraintQuery(tableName, constraintName) {\n    if (typeof tableName === 'string') {\n      tableName = this.quoteIdentifiers(tableName);\n    } else {\n      tableName = this.quoteTable(tableName);\n    }\n\n    return `ALTER TABLE ${tableName} DROP CONSTRAINT ${this.quoteIdentifiers(constraintName)}`;\n  }\n\n  /*\n    Quote an object based on its type. This is a more general version of quoteIdentifiers\n    Strings: should proxy to quoteIdentifiers\n    Arrays:\n      * Expects array in the form: [<model> (optional), <model> (optional),... String, String (optional)]\n        Each <model> can be a model, or an object {model: Model, as: String}, matching include, or an\n        association object, or the name of an association.\n      * Zero or more models can be included in the array and are used to trace a path through the tree of\n        included nested associations. This produces the correct table name for the ORDER BY/GROUP BY SQL\n        and quotes it.\n      * If a single string is appended to end of array, it is quoted.\n        If two strings appended, the 1st string is quoted, the 2nd string unquoted.\n    Objects:\n      * If raw is set, that value should be returned verbatim, without quoting\n      * If fn is set, the string should start with the value of fn, starting paren, followed by\n        the values of cols (which is assumed to be an array), quoted and joined with ', ',\n        unless they are themselves objects\n      * If direction is set, should be prepended\n\n    Currently this function is only used for ordering / grouping columns and Sequelize.col(), but it could\n    potentially also be used for other places where we want to be able to call SQL functions (e.g. as default values)\n   @private\n  */\n  quote(collection, parent, connector) {\n    // init\n    const validOrderOptions = [\n      'ASC',\n      'DESC',\n      'ASC NULLS LAST',\n      'DESC NULLS LAST',\n      'ASC NULLS FIRST',\n      'DESC NULLS FIRST',\n      'NULLS FIRST',\n      'NULLS LAST'\n    ];\n\n    // default\n    connector = connector || '.';\n\n    // just quote as identifiers if string\n    if (typeof collection === 'string') {\n      return this.quoteIdentifiers(collection);\n    }\n    if (Array.isArray(collection)) {\n      // iterate through the collection and mutate objects into associations\n      collection.forEach((item, index) => {\n        const previous = collection[index - 1];\n        let previousAssociation;\n        let previousModel;\n\n        // set the previous as the parent when previous is undefined or the target of the association\n        if (!previous && parent !== undefined) {\n          previousModel = parent;\n        } else if (previous && previous instanceof Association) {\n          previousAssociation = previous;\n          previousModel = previous.target;\n        }\n\n        // if the previous item is a model, then attempt getting an association\n        if (previousModel && previousModel.prototype instanceof Model) {\n          let model;\n          let as;\n\n          if (typeof item === 'function' && item.prototype instanceof Model) {\n            // set\n            model = item;\n          } else if (_.isPlainObject(item) && item.model && item.model.prototype instanceof Model) {\n            // set\n            model = item.model;\n            as = item.as;\n          }\n\n          if (model) {\n            // set the as to either the through name or the model name\n            if (!as && previousAssociation && previousAssociation instanceof Association && previousAssociation.through && previousAssociation.through.model === model) {\n              // get from previous association\n              item = new Association(previousModel, model, {\n                as: model.name\n              });\n            } else {\n              // get association from previous model\n              item = previousModel.getAssociationForAlias(model, as);\n\n              // attempt to use the model name if the item is still null\n              if (!item) {\n                item = previousModel.getAssociationForAlias(model, model.name);\n              }\n            }\n\n            // make sure we have an association\n            if (!(item instanceof Association)) {\n              throw new Error(util.format('Unable to find a valid association for model, \\'%s\\'', model.name));\n            }\n          }\n        }\n\n        if (typeof item === 'string') {\n          // get order index\n          const orderIndex = validOrderOptions.indexOf(item.toUpperCase());\n\n          // see if this is an order\n          if (index > 0 && orderIndex !== -1) {\n            item = this.sequelize.literal(` ${validOrderOptions[orderIndex]}`);\n          } else if (previousModel && previousModel.prototype instanceof Model) {\n            // only go down this path if we have preivous model and check only once\n            if (previousModel.associations !== undefined && previousModel.associations[item]) {\n              // convert the item to an association\n              item = previousModel.associations[item];\n            } else if (previousModel.rawAttributes !== undefined && previousModel.rawAttributes[item] && item !== previousModel.rawAttributes[item].field) {\n              // convert the item attribute from its alias\n              item = previousModel.rawAttributes[item].field;\n            } else if (\n              item.includes('.')\n              && previousModel.rawAttributes !== undefined\n            ) {\n              const itemSplit = item.split('.');\n\n              if (previousModel.rawAttributes[itemSplit[0]].type instanceof DataTypes.JSON) {\n                // just quote identifiers for now\n                const identifier = this.quoteIdentifiers(`${previousModel.name}.${previousModel.rawAttributes[itemSplit[0]].field}`);\n\n                // get path\n                const path = itemSplit.slice(1);\n\n                // extract path\n                item = this.jsonPathExtractionQuery(identifier, path);\n\n                // literal because we don't want to append the model name when string\n                item = this.sequelize.literal(item);\n              }\n            }\n          }\n        }\n\n        collection[index] = item;\n      }, this);\n\n      // loop through array, adding table names of models to quoted\n      const collectionLength = collection.length;\n      const tableNames = [];\n      let item;\n      let i = 0;\n\n      for (i = 0; i < collectionLength - 1; i++) {\n        item = collection[i];\n        if (typeof item === 'string' || item._modelAttribute || item instanceof Utils.SequelizeMethod) {\n          break;\n        } else if (item instanceof Association) {\n          tableNames[i] = item.as;\n        }\n      }\n\n      // start building sql\n      let sql = '';\n\n      if (i > 0) {\n        sql += `${this.quoteIdentifier(tableNames.join(connector))}.`;\n      } else if (typeof collection[0] === 'string' && parent) {\n        sql += `${this.quoteIdentifier(parent.name)}.`;\n      }\n\n      // loop through everything past i and append to the sql\n      collection.slice(i).forEach(collectionItem => {\n        sql += this.quote(collectionItem, parent, connector);\n      }, this);\n\n      return sql;\n    }\n    if (collection._modelAttribute) {\n      return `${this.quoteTable(collection.Model.name)}.${this.quoteIdentifier(collection.fieldName)}`;\n    }\n    if (collection instanceof Utils.SequelizeMethod) {\n      return this.handleSequelizeMethod(collection);\n    }\n    if (_.isPlainObject(collection) && collection.raw) {\n      // simple objects with raw is no longer supported\n      throw new Error('The `{raw: \"...\"}` syntax is no longer supported.  Use `sequelize.literal` instead.');\n    }\n    throw new Error(`Unknown structure passed to order / group: ${util.inspect(collection)}`);\n  }\n\n  /**\n   * Split a list of identifiers by \".\" and quote each part\n   *\n   * @param {string} identifier\n   * @param {boolean} force\n   *\n   * @returns {string}\n   */\n  quoteIdentifier(identifier, force) {\n    return QuoteHelper.quoteIdentifier(this.dialect, identifier, {\n      force,\n      quoteIdentifiers: this.options.quoteIdentifiers\n    });\n  }\n\n  quoteIdentifiers(identifiers) {\n    if (identifiers.includes('.')) {\n      identifiers = identifiers.split('.');\n\n      const head = identifiers.slice(0, identifiers.length - 1).join('->');\n      const tail = identifiers[identifiers.length - 1];\n\n      return `${this.quoteIdentifier(head)}.${this.quoteIdentifier(tail)}`;\n    }\n\n    return this.quoteIdentifier(identifiers);\n  }\n\n  quoteAttribute(attribute, model) {\n    if (model && attribute in model.rawAttributes) {\n      return this.quoteIdentifier(attribute);\n    }\n    return this.quoteIdentifiers(attribute);\n  }\n\n  /**\n   * Quote table name with optional alias and schema attribution\n   *\n   * @param {string|Object}  param table string or object\n   * @param {string|boolean} alias alias name\n   *\n   * @returns {string}\n   */\n  quoteTable(param, alias) {\n    let table = '';\n\n    if (alias === true) {\n      alias = param.as || param.name || param;\n    }\n\n    if (_.isObject(param)) {\n      if (this._dialect.supports.schemas) {\n        if (param.schema) {\n          table += `${this.quoteIdentifier(param.schema)}.`;\n        }\n\n        table += this.quoteIdentifier(param.tableName);\n      } else {\n        if (param.schema) {\n          table += param.schema + (param.delimiter || '.');\n        }\n\n        table += param.tableName;\n        table = this.quoteIdentifier(table);\n      }\n    } else {\n      table = this.quoteIdentifier(param);\n    }\n\n    if (alias) {\n      table += ` AS ${this.quoteIdentifier(alias)}`;\n    }\n\n    return table;\n  }\n\n  /*\n    Escape a value (e.g. a string, number or date)\n    @private\n  */\n  escape(value, field, options) {\n    options = options || {};\n\n    if (value !== null && value !== undefined) {\n      if (value instanceof Utils.SequelizeMethod) {\n        return this.handleSequelizeMethod(value);\n      }\n      if (field && field.type) {\n        this.validate(value, field, options);\n\n        if (field.type.stringify) {\n          // Users shouldn't have to worry about these args - just give them a function that takes a single arg\n          const simpleEscape = escVal => SqlString.escape(escVal, this.options.timezone, this.dialect);\n\n          value = field.type.stringify(value, { escape: simpleEscape, field, timezone: this.options.timezone, operation: options.operation });\n\n          if (field.type.escape === false) {\n            // The data-type already did the required escaping\n            return value;\n          }\n        }\n      }\n    }\n\n    return SqlString.escape(value, this.options.timezone, this.dialect);\n  }\n\n  bindParam(bind) {\n    return value => {\n      bind.push(value);\n      return `$${bind.length}`;\n    };\n  }\n\n  /*\n    Returns a bind parameter representation of a value (e.g. a string, number or date)\n    @private\n  */\n  format(value, field, options, bindParam) {\n    options = options || {};\n\n    if (value !== null && value !== undefined) {\n      if (value instanceof Utils.SequelizeMethod) {\n        throw new Error('Cannot pass SequelizeMethod as a bind parameter - use escape instead');\n      }\n      if (field && field.type) {\n        this.validate(value, field, options);\n\n        if (field.type.bindParam) {\n          return field.type.bindParam(value, { escape: _.identity, field, timezone: this.options.timezone, operation: options.operation, bindParam });\n        }\n      }\n    }\n\n    return bindParam(value);\n  }\n\n  /*\n    Validate a value against a field specification\n    @private\n  */\n  validate(value, field, options) {\n    if (this.typeValidation && field.type.validate && value) {\n      try {\n        if (options.isList && Array.isArray(value)) {\n          for (const item of value) {\n            field.type.validate(item, options);\n          }\n        } else {\n          field.type.validate(value, options);\n        }\n      } catch (error) {\n        if (error instanceof sequelizeError.ValidationError) {\n          error.errors.push(new sequelizeError.ValidationErrorItem(\n            error.message,\n            'Validation error',\n            field.fieldName,\n            value,\n            null,\n            `${field.type.key} validator`\n          ));\n        }\n\n        throw error;\n      }\n    }\n  }\n\n  isIdentifierQuoted(identifier) {\n    return QuoteHelper.isIdentifierQuoted(identifier);\n  }\n\n  /**\n   * Generates an SQL query that extract JSON property of given path.\n   *\n   * @param   {string}               column  The JSON column\n   * @param   {string|Array<string>} [path]  The path to extract (optional)\n   * @returns {string}                       The generated sql query\n   * @private\n   */\n  jsonPathExtractionQuery(column, path) {\n    let paths = _.toPath(path);\n    let pathStr;\n    const quotedColumn = this.isIdentifierQuoted(column)\n      ? column\n      : this.quoteIdentifier(column);\n\n    switch (this.dialect) {\n      case 'mysql':\n      case 'mariadb':\n      case 'sqlite':\n        /**\n         * Non digit sub paths need to be quoted as ECMAScript identifiers\n         * https://bugs.mysql.com/bug.php?id=81896\n         */\n        if (this.dialect === 'mysql') {\n          paths = paths.map(subPath => {\n            return /\\D/.test(subPath)\n              ? Utils.addTicks(subPath, '\"')\n              : subPath;\n          });\n        }\n\n        pathStr = this.escape(['$']\n          .concat(paths)\n          .join('.')\n          .replace(/\\.(\\d+)(?:(?=\\.)|$)/g, (__, digit) => `[${digit}]`));\n\n        if (this.dialect === 'sqlite') {\n          return `json_extract(${quotedColumn},${pathStr})`;\n        }\n\n        return `json_unquote(json_extract(${quotedColumn},${pathStr}))`;\n\n      case 'postgres':\n        pathStr = this.escape(`{${paths.join(',')}}`);\n        return `(${quotedColumn}#>>${pathStr})`;\n\n      default:\n        throw new Error(`Unsupported ${this.dialect} for JSON operations`);\n    }\n  }\n\n  /*\n    Returns a query for selecting elements in the table <tableName>.\n    Options:\n      - attributes -> An array of attributes (e.g. ['name', 'birthday']). Default: *\n      - where -> A hash with conditions (e.g. {name: 'foo'})\n                 OR an ID as integer\n      - order -> e.g. 'id DESC'\n      - group\n      - limit -> The maximum count you want to get.\n      - offset -> An offset value to start from. Only useable with limit!\n   @private\n  */\n  selectQuery(tableName, options, model) {\n    options = options || {};\n    const limit = options.limit;\n    const mainQueryItems = [];\n    const subQueryItems = [];\n    const subQuery = options.subQuery === undefined ? limit && options.hasMultiAssociation : options.subQuery;\n    const attributes = {\n      main: options.attributes && options.attributes.slice(),\n      subQuery: null\n    };\n    const mainTable = {\n      name: tableName,\n      quotedName: null,\n      as: null,\n      model\n    };\n    const topLevelInfo = {\n      names: mainTable,\n      options,\n      subQuery\n    };\n    let mainJoinQueries = [];\n    let subJoinQueries = [];\n    let query;\n\n    // Aliases can be passed through subqueries and we don't want to reset them\n    if (this.options.minifyAliases && !options.aliasesMapping) {\n      options.aliasesMapping = new Map();\n      options.aliasesByTable = {};\n    }\n\n    // resolve table name options\n    if (options.tableAs) {\n      mainTable.as = this.quoteIdentifier(options.tableAs);\n    } else if (!Array.isArray(mainTable.name) && mainTable.model) {\n      mainTable.as = this.quoteIdentifier(mainTable.model.name);\n    }\n\n    mainTable.quotedName = !Array.isArray(mainTable.name) ? this.quoteTable(mainTable.name) : tableName.map(t => {\n      return Array.isArray(t) ? this.quoteTable(t[0], t[1]) : this.quoteTable(t, true);\n    }).join(', ');\n\n    if (subQuery && attributes.main) {\n      for (const keyAtt of mainTable.model.primaryKeyAttributes) {\n        // Check if mainAttributes contain the primary key of the model either as a field or an aliased field\n        if (!attributes.main.some(attr => keyAtt === attr || keyAtt === attr[0] || keyAtt === attr[1])) {\n          attributes.main.push(mainTable.model.rawAttributes[keyAtt].field ? [keyAtt, mainTable.model.rawAttributes[keyAtt].field] : keyAtt);\n        }\n      }\n    }\n\n    attributes.main = this.escapeAttributes(attributes.main, options, mainTable.as);\n    attributes.main = attributes.main || (options.include ? [`${mainTable.as}.*`] : ['*']);\n\n    // If subquery, we add the mainAttributes to the subQuery and set the mainAttributes to select * from subquery\n    if (subQuery || options.groupedLimit) {\n      // We need primary keys\n      attributes.subQuery = attributes.main;\n      attributes.main = [`${mainTable.as || mainTable.quotedName}.*`];\n    }\n\n    if (options.include) {\n      for (const include of options.include) {\n        if (include.separate) {\n          continue;\n        }\n        const joinQueries = this.generateInclude(include, { externalAs: mainTable.as, internalAs: mainTable.as }, topLevelInfo);\n\n        subJoinQueries = subJoinQueries.concat(joinQueries.subQuery);\n        mainJoinQueries = mainJoinQueries.concat(joinQueries.mainQuery);\n\n        if (joinQueries.attributes.main.length > 0) {\n          attributes.main = _.uniq(attributes.main.concat(joinQueries.attributes.main));\n        }\n        if (joinQueries.attributes.subQuery.length > 0) {\n          attributes.subQuery = _.uniq(attributes.subQuery.concat(joinQueries.attributes.subQuery));\n        }\n      }\n    }\n\n    if (subQuery) {\n      subQueryItems.push(this.selectFromTableFragment(options, mainTable.model, attributes.subQuery, mainTable.quotedName, mainTable.as));\n      subQueryItems.push(subJoinQueries.join(''));\n    } else {\n      if (options.groupedLimit) {\n        if (!mainTable.as) {\n          mainTable.as = mainTable.quotedName;\n        }\n        const where = Object.assign({}, options.where);\n        let groupedLimitOrder,\n          whereKey,\n          include,\n          groupedTableName = mainTable.as;\n\n        if (typeof options.groupedLimit.on === 'string') {\n          whereKey = options.groupedLimit.on;\n        } else if (options.groupedLimit.on instanceof HasMany) {\n          whereKey = options.groupedLimit.on.foreignKeyField;\n        }\n\n        if (options.groupedLimit.on instanceof BelongsToMany) {\n          // BTM includes needs to join the through table on to check ID\n          groupedTableName = options.groupedLimit.on.manyFromSource.as;\n          const groupedLimitOptions = Model._validateIncludedElements({\n            include: [{\n              association: options.groupedLimit.on.manyFromSource,\n              duplicating: false, // The UNION'ed query may contain duplicates, but each sub-query cannot\n              required: true,\n              where: Object.assign({\n                [Op.placeholder]: true\n              }, options.groupedLimit.through && options.groupedLimit.through.where)\n            }],\n            model\n          });\n\n          // Make sure attributes from the join table are mapped back to models\n          options.hasJoin = true;\n          options.hasMultiAssociation = true;\n          options.includeMap = Object.assign(groupedLimitOptions.includeMap, options.includeMap);\n          options.includeNames = groupedLimitOptions.includeNames.concat(options.includeNames || []);\n          include = groupedLimitOptions.include;\n\n          if (Array.isArray(options.order)) {\n            // We need to make sure the order by attributes are available to the parent query\n            options.order.forEach((order, i) => {\n              if (Array.isArray(order)) {\n                order = order[0];\n              }\n\n              let alias = `subquery_order_${i}`;\n              options.attributes.push([order, alias]);\n\n              // We don't want to prepend model name when we alias the attributes, so quote them here\n              alias = this.sequelize.literal(this.quote(alias));\n\n              if (Array.isArray(options.order[i])) {\n                options.order[i][0] = alias;\n              } else {\n                options.order[i] = alias;\n              }\n            });\n            groupedLimitOrder = options.order;\n          }\n        } else {\n          // Ordering is handled by the subqueries, so ordering the UNION'ed result is not needed\n          groupedLimitOrder = options.order;\n          delete options.order;\n          where[Op.placeholder] = true;\n        }\n\n        // Caching the base query and splicing the where part into it is consistently > twice\n        // as fast than generating from scratch each time for values.length >= 5\n        const baseQuery = `SELECT * FROM (${this.selectQuery(\n          tableName,\n          {\n            attributes: options.attributes,\n            offset: options.offset,\n            limit: options.groupedLimit.limit,\n            order: groupedLimitOrder,\n            aliasesMapping: options.aliasesMapping,\n            aliasesByTable: options.aliasesByTable,\n            where,\n            include,\n            model\n          },\n          model\n        ).replace(/;$/, '')}) AS sub`; // Every derived table must have its own alias\n        const placeHolder = this.whereItemQuery(Op.placeholder, true, { model });\n        const splicePos = baseQuery.indexOf(placeHolder);\n\n        mainQueryItems.push(this.selectFromTableFragment(options, mainTable.model, attributes.main, `(${\n          options.groupedLimit.values.map(value => {\n            let groupWhere;\n            if (whereKey) {\n              groupWhere = {\n                [whereKey]: value\n              };\n            }\n            if (include) {\n              groupWhere = {\n                [options.groupedLimit.on.foreignIdentifierField]: value\n              };\n            }\n\n            return Utils.spliceStr(baseQuery, splicePos, placeHolder.length, this.getWhereConditions(groupWhere, groupedTableName));\n          }).join(\n            this._dialect.supports['UNION ALL'] ? ' UNION ALL ' : ' UNION '\n          )\n        })`, mainTable.as));\n      } else {\n        mainQueryItems.push(this.selectFromTableFragment(options, mainTable.model, attributes.main, mainTable.quotedName, mainTable.as));\n      }\n\n      mainQueryItems.push(mainJoinQueries.join(''));\n    }\n\n    // Add WHERE to sub or main query\n    if (Object.prototype.hasOwnProperty.call(options, 'where') && !options.groupedLimit) {\n      options.where = this.getWhereConditions(options.where, mainTable.as || tableName, model, options);\n      if (options.where) {\n        if (subQuery) {\n          subQueryItems.push(` WHERE ${options.where}`);\n        } else {\n          mainQueryItems.push(` WHERE ${options.where}`);\n          // Walk the main query to update all selects\n          mainQueryItems.forEach((value, key) => {\n            if (value.startsWith('SELECT')) {\n              mainQueryItems[key] = this.selectFromTableFragment(options, model, attributes.main, mainTable.quotedName, mainTable.as, options.where);\n            }\n          });\n        }\n      }\n    }\n\n    // Add GROUP BY to sub or main query\n    if (options.group) {\n      options.group = Array.isArray(options.group) ? options.group.map(t => this.aliasGrouping(t, model, mainTable.as, options)).join(', ') : this.aliasGrouping(options.group, model, mainTable.as, options);\n\n      if (subQuery) {\n        subQueryItems.push(` GROUP BY ${options.group}`);\n      } else {\n        mainQueryItems.push(` GROUP BY ${options.group}`);\n      }\n    }\n\n    // Add HAVING to sub or main query\n    if (Object.prototype.hasOwnProperty.call(options, 'having')) {\n      options.having = this.getWhereConditions(options.having, tableName, model, options, false);\n      if (options.having) {\n        if (subQuery) {\n          subQueryItems.push(` HAVING ${options.having}`);\n        } else {\n          mainQueryItems.push(` HAVING ${options.having}`);\n        }\n      }\n    }\n\n    // Add ORDER to sub or main query\n    if (options.order) {\n      const orders = this.getQueryOrders(options, model, subQuery);\n      if (orders.mainQueryOrder.length) {\n        mainQueryItems.push(` ORDER BY ${orders.mainQueryOrder.join(', ')}`);\n      }\n      if (orders.subQueryOrder.length) {\n        subQueryItems.push(` ORDER BY ${orders.subQueryOrder.join(', ')}`);\n      }\n    }\n\n    // Add LIMIT, OFFSET to sub or main query\n    const limitOrder = this.addLimitAndOffset(options, mainTable.model);\n    if (limitOrder && !options.groupedLimit) {\n      if (subQuery) {\n        subQueryItems.push(limitOrder);\n      } else {\n        mainQueryItems.push(limitOrder);\n      }\n    }\n\n    if (subQuery) {\n      query = `SELECT ${attributes.main.join(', ')} FROM (${subQueryItems.join('')}) AS ${mainTable.as}${mainJoinQueries.join('')}${mainQueryItems.join('')}`;\n    } else {\n      query = mainQueryItems.join('');\n    }\n\n    if (options.lock && this._dialect.supports.lock) {\n      let lock = options.lock;\n      if (typeof options.lock === 'object') {\n        lock = options.lock.level;\n      }\n      if (this._dialect.supports.lockKey && (lock === 'KEY SHARE' || lock === 'NO KEY UPDATE')) {\n        query += ` FOR ${lock}`;\n      } else if (lock === 'SHARE') {\n        query += ` ${this._dialect.supports.forShare}`;\n      } else {\n        query += ' FOR UPDATE';\n      }\n      if (this._dialect.supports.lockOf && options.lock.of && options.lock.of.prototype instanceof Model) {\n        query += ` OF ${this.quoteTable(options.lock.of.name)}`;\n      }\n      if (this._dialect.supports.skipLocked && options.skipLocked) {\n        query += ' SKIP LOCKED';\n      }\n    }\n\n    return `${query};`;\n  }\n\n  aliasGrouping(field, model, tableName, options) {\n    const src = Array.isArray(field) ? field[0] : field;\n\n    return this.quote(this._getAliasForField(tableName, src, options) || src, model);\n  }\n\n  escapeAttributes(attributes, options, mainTableAs) {\n    return attributes && attributes.map(attr => {\n      let addTable = true;\n\n      if (attr instanceof Utils.SequelizeMethod) {\n        return this.handleSequelizeMethod(attr);\n      }\n      if (Array.isArray(attr)) {\n        if (attr.length !== 2) {\n          throw new Error(`${JSON.stringify(attr)} is not a valid attribute definition. Please use the following format: ['attribute definition', 'alias']`);\n        }\n        attr = attr.slice();\n\n        if (attr[0] instanceof Utils.SequelizeMethod) {\n          attr[0] = this.handleSequelizeMethod(attr[0]);\n          addTable = false;\n        } else if (!attr[0].includes('(') && !attr[0].includes(')')) {\n          attr[0] = this.quoteIdentifier(attr[0]);\n        } else {\n          deprecations.noRawAttributes();\n        }\n        let alias = attr[1];\n\n        if (this.options.minifyAliases) {\n          alias = this._getMinifiedAlias(alias, mainTableAs, options);\n        }\n\n        attr = [attr[0], this.quoteIdentifier(alias)].join(' AS ');\n      } else {\n        attr = !attr.includes(Utils.TICK_CHAR) && !attr.includes('\"')\n          ? this.quoteAttribute(attr, options.model)\n          : this.escape(attr);\n      }\n      if (!_.isEmpty(options.include) && !attr.includes('.') && addTable) {\n        attr = `${mainTableAs}.${attr}`;\n      }\n\n      return attr;\n    });\n  }\n\n  generateInclude(include, parentTableName, topLevelInfo) {\n    const joinQueries = {\n      mainQuery: [],\n      subQuery: []\n    };\n    const mainChildIncludes = [];\n    const subChildIncludes = [];\n    let requiredMismatch = false;\n    const includeAs = {\n      internalAs: include.as,\n      externalAs: include.as\n    };\n    const attributes = {\n      main: [],\n      subQuery: []\n    };\n    let joinQuery;\n\n    topLevelInfo.options.keysEscaped = true;\n\n    if (topLevelInfo.names.name !== parentTableName.externalAs && topLevelInfo.names.as !== parentTableName.externalAs) {\n      includeAs.internalAs = `${parentTableName.internalAs}->${include.as}`;\n      includeAs.externalAs = `${parentTableName.externalAs}.${include.as}`;\n    }\n\n    // includeIgnoreAttributes is used by aggregate functions\n    if (topLevelInfo.options.includeIgnoreAttributes !== false) {\n      include.model._expandAttributes(include);\n      Utils.mapFinderOptions(include, include.model);\n\n      const includeAttributes = include.attributes.map(attr => {\n        let attrAs = attr;\n        let verbatim = false;\n\n        if (Array.isArray(attr) && attr.length === 2) {\n          if (attr[0] instanceof Utils.SequelizeMethod && (\n            attr[0] instanceof Utils.Literal ||\n            attr[0] instanceof Utils.Cast ||\n            attr[0] instanceof Utils.Fn\n          )) {\n            verbatim = true;\n          }\n\n          attr = attr.map(attr => attr instanceof Utils.SequelizeMethod ? this.handleSequelizeMethod(attr) : attr);\n\n          attrAs = attr[1];\n          attr = attr[0];\n        }\n        if (attr instanceof Utils.Literal) {\n          return attr.val; // We trust the user to rename the field correctly\n        }\n        if (attr instanceof Utils.Cast || attr instanceof Utils.Fn) {\n          throw new Error(\n            'Tried to select attributes using Sequelize.cast or Sequelize.fn without specifying an alias for the result, during eager loading. ' +\n            'This means the attribute will not be added to the returned instance'\n          );\n        }\n\n        let prefix;\n        if (verbatim === true) {\n          prefix = attr;\n        } else if (/#>>|->>/.test(attr)) {\n          prefix = `(${this.quoteIdentifier(includeAs.internalAs)}.${attr.replace(/\\(|\\)/g, '')})`;\n        } else if (/json_extract\\(/.test(attr)) {\n          prefix = attr.replace(/json_extract\\(/i, `json_extract(${this.quoteIdentifier(includeAs.internalAs)}.`);\n        } else {\n          prefix = `${this.quoteIdentifier(includeAs.internalAs)}.${this.quoteIdentifier(attr)}`;\n        }\n        let alias = `${includeAs.externalAs}.${attrAs}`;\n\n        if (this.options.minifyAliases) {\n          alias = this._getMinifiedAlias(alias, includeAs.internalAs, topLevelInfo.options);\n        }\n\n        return `${prefix} AS ${this.quoteIdentifier(alias, true)}`;\n      });\n      if (include.subQuery && topLevelInfo.subQuery) {\n        for (const attr of includeAttributes) {\n          attributes.subQuery.push(attr);\n        }\n      } else {\n        for (const attr of includeAttributes) {\n          attributes.main.push(attr);\n        }\n      }\n    }\n\n    //through\n    if (include.through) {\n      joinQuery = this.generateThroughJoin(include, includeAs, parentTableName.internalAs, topLevelInfo);\n    } else {\n      this._generateSubQueryFilter(include, includeAs, topLevelInfo);\n      joinQuery = this.generateJoin(include, topLevelInfo);\n    }\n\n    // handle possible new attributes created in join\n    if (joinQuery.attributes.main.length > 0) {\n      attributes.main = attributes.main.concat(joinQuery.attributes.main);\n    }\n\n    if (joinQuery.attributes.subQuery.length > 0) {\n      attributes.subQuery = attributes.subQuery.concat(joinQuery.attributes.subQuery);\n    }\n\n    if (include.include) {\n      for (const childInclude of include.include) {\n        if (childInclude.separate || childInclude._pseudo) {\n          continue;\n        }\n\n        const childJoinQueries = this.generateInclude(childInclude, includeAs, topLevelInfo);\n\n        if (include.required === false && childInclude.required === true) {\n          requiredMismatch = true;\n        }\n        // if the child is a sub query we just give it to the\n        if (childInclude.subQuery && topLevelInfo.subQuery) {\n          subChildIncludes.push(childJoinQueries.subQuery);\n        }\n        if (childJoinQueries.mainQuery) {\n          mainChildIncludes.push(childJoinQueries.mainQuery);\n        }\n        if (childJoinQueries.attributes.main.length > 0) {\n          attributes.main = attributes.main.concat(childJoinQueries.attributes.main);\n        }\n        if (childJoinQueries.attributes.subQuery.length > 0) {\n          attributes.subQuery = attributes.subQuery.concat(childJoinQueries.attributes.subQuery);\n        }\n      }\n    }\n\n    if (include.subQuery && topLevelInfo.subQuery) {\n      if (requiredMismatch && subChildIncludes.length > 0) {\n        joinQueries.subQuery.push(` ${joinQuery.join} ( ${joinQuery.body}${subChildIncludes.join('')} ) ON ${joinQuery.condition}`);\n      } else {\n        joinQueries.subQuery.push(` ${joinQuery.join} ${joinQuery.body} ON ${joinQuery.condition}`);\n        if (subChildIncludes.length > 0) {\n          joinQueries.subQuery.push(subChildIncludes.join(''));\n        }\n      }\n      joinQueries.mainQuery.push(mainChildIncludes.join(''));\n    } else {\n      if (requiredMismatch && mainChildIncludes.length > 0) {\n        joinQueries.mainQuery.push(` ${joinQuery.join} ( ${joinQuery.body}${mainChildIncludes.join('')} ) ON ${joinQuery.condition}`);\n      } else {\n        joinQueries.mainQuery.push(` ${joinQuery.join} ${joinQuery.body} ON ${joinQuery.condition}`);\n        if (mainChildIncludes.length > 0) {\n          joinQueries.mainQuery.push(mainChildIncludes.join(''));\n        }\n      }\n      joinQueries.subQuery.push(subChildIncludes.join(''));\n    }\n\n    return {\n      mainQuery: joinQueries.mainQuery.join(''),\n      subQuery: joinQueries.subQuery.join(''),\n      attributes\n    };\n  }\n\n  _getMinifiedAlias(alias, tableName, options) {\n    // We do not want to re-alias in case of a subquery\n    if (options.aliasesByTable[`${tableName}${alias}`]) {\n      return options.aliasesByTable[`${tableName}${alias}`];\n    }\n\n    // Do not alias custom suquery_orders\n    if (alias.match(/subquery_order_[0-9]/)) {\n      return alias;\n    }\n\n    const minifiedAlias = `_${options.aliasesMapping.size}`;\n\n    options.aliasesMapping.set(minifiedAlias, alias);\n    options.aliasesByTable[`${tableName}${alias}`] = minifiedAlias;\n\n    return minifiedAlias;\n  }\n\n  _getAliasForField(tableName, field, options) {\n    if (this.options.minifyAliases) {\n      if (options.aliasesByTable[`${tableName}${field}`]) {\n        return options.aliasesByTable[`${tableName}${field}`];\n      }\n    }\n    return null;\n  }\n\n  generateJoin(include, topLevelInfo) {\n    const association = include.association;\n    const parent = include.parent;\n    const parentIsTop = !!parent && !include.parent.association && include.parent.model.name === topLevelInfo.options.model.name;\n    let $parent;\n    let joinWhere;\n    /* Attributes for the left side */\n    const left = association.source;\n    const attrLeft = association instanceof BelongsTo ?\n      association.identifier :\n      association.sourceKeyAttribute || left.primaryKeyAttribute;\n    const fieldLeft = association instanceof BelongsTo ?\n      association.identifierField :\n      left.rawAttributes[association.sourceKeyAttribute || left.primaryKeyAttribute].field;\n    let asLeft;\n    /* Attributes for the right side */\n    const right = include.model;\n    const tableRight = right.getTableName();\n    const fieldRight = association instanceof BelongsTo ?\n      right.rawAttributes[association.targetIdentifier || right.primaryKeyAttribute].field :\n      association.identifierField;\n    let asRight = include.as;\n\n    while (($parent = $parent && $parent.parent || include.parent) && $parent.association) {\n      if (asLeft) {\n        asLeft = `${$parent.as}->${asLeft}`;\n      } else {\n        asLeft = $parent.as;\n      }\n    }\n\n    if (!asLeft) asLeft = parent.as || parent.model.name;\n    else asRight = `${asLeft}->${asRight}`;\n\n    let joinOn = `${this.quoteTable(asLeft)}.${this.quoteIdentifier(fieldLeft)}`;\n    const subqueryAttributes = [];\n\n    if (topLevelInfo.options.groupedLimit && parentIsTop || topLevelInfo.subQuery && include.parent.subQuery && !include.subQuery) {\n      if (parentIsTop) {\n        // The main model attributes is not aliased to a prefix\n        const tableName = this.quoteTable(parent.as || parent.model.name);\n\n        // Check for potential aliased JOIN condition\n        joinOn = this._getAliasForField(tableName, attrLeft, topLevelInfo.options) || `${tableName}.${this.quoteIdentifier(attrLeft)}`;\n\n        if (topLevelInfo.subQuery) {\n          subqueryAttributes.push(`${tableName}.${this.quoteIdentifier(fieldLeft)}`);\n        }\n      } else {\n        const joinSource = `${asLeft.replace(/->/g, '.')}.${attrLeft}`;\n\n        // Check for potential aliased JOIN condition\n        joinOn = this._getAliasForField(asLeft, joinSource, topLevelInfo.options) || this.quoteIdentifier(joinSource);\n      }\n    }\n\n    joinOn += ` = ${this.quoteIdentifier(asRight)}.${this.quoteIdentifier(fieldRight)}`;\n\n    if (include.on) {\n      joinOn = this.whereItemsQuery(include.on, {\n        prefix: this.sequelize.literal(this.quoteIdentifier(asRight)),\n        model: include.model\n      });\n    }\n\n    if (include.where) {\n      joinWhere = this.whereItemsQuery(include.where, {\n        prefix: this.sequelize.literal(this.quoteIdentifier(asRight)),\n        model: include.model\n      });\n      if (joinWhere) {\n        if (include.or) {\n          joinOn += ` OR ${joinWhere}`;\n        } else {\n          joinOn += ` AND ${joinWhere}`;\n        }\n      }\n    }\n\n    return {\n      join: include.required ? 'INNER JOIN' : include.right && this._dialect.supports['RIGHT JOIN'] ? 'RIGHT OUTER JOIN' : 'LEFT OUTER JOIN',\n      body: this.quoteTable(tableRight, asRight),\n      condition: joinOn,\n      attributes: {\n        main: [],\n        subQuery: subqueryAttributes\n      }\n    };\n  }\n\n  generateThroughJoin(include, includeAs, parentTableName, topLevelInfo) {\n    const through = include.through;\n    const throughTable = through.model.getTableName();\n    const throughAs = `${includeAs.internalAs}->${through.as}`;\n    const externalThroughAs = `${includeAs.externalAs}.${through.as}`;\n    const throughAttributes = through.attributes.map(attr => {\n      let alias = `${externalThroughAs}.${Array.isArray(attr) ? attr[1] : attr}`;\n\n      if (this.options.minifyAliases) {\n        alias = this._getMinifiedAlias(alias, throughAs, topLevelInfo.options);\n      }\n\n      return `${this.quoteIdentifier(throughAs)}.${this.quoteIdentifier(Array.isArray(attr) ? attr[0] : attr)\n      } AS ${\n        this.quoteIdentifier(alias)}`;\n    });\n    const association = include.association;\n    const parentIsTop = !include.parent.association && include.parent.model.name === topLevelInfo.options.model.name;\n    const tableSource = parentTableName;\n    const identSource = association.identifierField;\n    const tableTarget = includeAs.internalAs;\n    const identTarget = association.foreignIdentifierField;\n    const attrTarget = association.targetKeyField;\n\n    const joinType = include.required ? 'INNER JOIN' : include.right && this._dialect.supports['RIGHT JOIN'] ? 'RIGHT OUTER JOIN' : 'LEFT OUTER JOIN';\n    let joinBody;\n    let joinCondition;\n    const attributes = {\n      main: [],\n      subQuery: []\n    };\n    let attrSource = association.sourceKey;\n    let sourceJoinOn;\n    let targetJoinOn;\n    let throughWhere;\n    let targetWhere;\n\n    if (topLevelInfo.options.includeIgnoreAttributes !== false) {\n      // Through includes are always hasMany, so we need to add the attributes to the mainAttributes no matter what (Real join will never be executed in subquery)\n      for (const attr of throughAttributes) {\n        attributes.main.push(attr);\n      }\n    }\n\n    // Figure out if we need to use field or attribute\n    if (!topLevelInfo.subQuery) {\n      attrSource = association.sourceKeyField;\n    }\n    if (topLevelInfo.subQuery && !include.subQuery && !include.parent.subQuery && include.parent.model !== topLevelInfo.options.mainModel) {\n      attrSource = association.sourceKeyField;\n    }\n\n    // Filter statement for left side of through\n    // Used by both join and subquery where\n    // If parent include was in a subquery need to join on the aliased attribute\n    if (topLevelInfo.subQuery && !include.subQuery && include.parent.subQuery && !parentIsTop) {\n      // If we are minifying aliases and our JOIN target has been minified, we need to use the alias instead of the original column name\n      const joinSource = this._getAliasForField(tableSource, `${tableSource}.${attrSource}`, topLevelInfo.options) || `${tableSource}.${attrSource}`;\n\n      sourceJoinOn = `${this.quoteIdentifier(joinSource)} = `;\n    } else {\n      // If we are minifying aliases and our JOIN target has been minified, we need to use the alias instead of the original column name\n      const aliasedSource = this._getAliasForField(tableSource, attrSource, topLevelInfo.options) || attrSource;\n\n      sourceJoinOn = `${this.quoteTable(tableSource)}.${this.quoteIdentifier(aliasedSource)} = `;\n    }\n    sourceJoinOn += `${this.quoteIdentifier(throughAs)}.${this.quoteIdentifier(identSource)}`;\n\n    // Filter statement for right side of through\n    // Used by both join and subquery where\n    targetJoinOn = `${this.quoteIdentifier(tableTarget)}.${this.quoteIdentifier(attrTarget)} = `;\n    targetJoinOn += `${this.quoteIdentifier(throughAs)}.${this.quoteIdentifier(identTarget)}`;\n\n    if (through.where) {\n      throughWhere = this.getWhereConditions(through.where, this.sequelize.literal(this.quoteIdentifier(throughAs)), through.model);\n    }\n\n    if (this._dialect.supports.joinTableDependent) {\n      // Generate a wrapped join so that the through table join can be dependent on the target join\n      joinBody = `( ${this.quoteTable(throughTable, throughAs)} INNER JOIN ${this.quoteTable(include.model.getTableName(), includeAs.internalAs)} ON ${targetJoinOn}`;\n      if (throughWhere) {\n        joinBody += ` AND ${throughWhere}`;\n      }\n      joinBody += ')';\n      joinCondition = sourceJoinOn;\n    } else {\n      // Generate join SQL for left side of through\n      joinBody = `${this.quoteTable(throughTable, throughAs)} ON ${sourceJoinOn} ${joinType} ${this.quoteTable(include.model.getTableName(), includeAs.internalAs)}`;\n      joinCondition = targetJoinOn;\n      if (throughWhere) {\n        joinCondition += ` AND ${throughWhere}`;\n      }\n    }\n\n    if (include.where || include.through.where) {\n      if (include.where) {\n        targetWhere = this.getWhereConditions(include.where, this.sequelize.literal(this.quoteIdentifier(includeAs.internalAs)), include.model, topLevelInfo.options);\n        if (targetWhere) {\n          joinCondition += ` AND ${targetWhere}`;\n        }\n      }\n    }\n\n    this._generateSubQueryFilter(include, includeAs, topLevelInfo);\n\n    return {\n      join: joinType,\n      body: joinBody,\n      condition: joinCondition,\n      attributes\n    };\n  }\n\n  /*\n   * Generates subQueryFilter - a select nested in the where clause of the subQuery.\n   * For a given include a query is generated that contains all the way from the subQuery\n   * table to the include table plus everything that's in required transitive closure of the\n   * given include.\n   */\n  _generateSubQueryFilter(include, includeAs, topLevelInfo) {\n    if (!topLevelInfo.subQuery || !include.subQueryFilter) {\n      return;\n    }\n\n    if (!topLevelInfo.options.where) {\n      topLevelInfo.options.where = {};\n    }\n    let parent = include;\n    let child = include;\n    let nestedIncludes = this._getRequiredClosure(include).include;\n    let query;\n\n    while ((parent = parent.parent)) { // eslint-disable-line\n      if (parent.parent && !parent.required) {\n        return; // only generate subQueryFilter if all the parents of this include are required\n      }\n\n      if (parent.subQueryFilter) {\n        // the include is already handled as this parent has the include on its required closure\n        // skip to prevent duplicate subQueryFilter\n        return;\n      }\n\n      nestedIncludes = [Object.assign({}, child, { include: nestedIncludes, attributes: [] })];\n      child = parent;\n    }\n\n    const topInclude = nestedIncludes[0];\n    const topParent = topInclude.parent;\n    const topAssociation = topInclude.association;\n    topInclude.association = undefined;\n\n    if (topInclude.through && Object(topInclude.through.model) === topInclude.through.model) {\n      query = this.selectQuery(topInclude.through.model.getTableName(), {\n        attributes: [topInclude.through.model.primaryKeyField],\n        include: Model._validateIncludedElements({\n          model: topInclude.through.model,\n          include: [{\n            association: topAssociation.toTarget,\n            required: true,\n            where: topInclude.where,\n            include: topInclude.include\n          }]\n        }).include,\n        model: topInclude.through.model,\n        where: {\n          [Op.and]: [\n            this.sequelize.literal([\n              `${this.quoteTable(topParent.model.name)}.${this.quoteIdentifier(topParent.model.primaryKeyField)}`,\n              `${this.quoteIdentifier(topInclude.through.model.name)}.${this.quoteIdentifier(topAssociation.identifierField)}`\n            ].join(' = ')),\n            topInclude.through.where\n          ]\n        },\n        limit: 1,\n        includeIgnoreAttributes: false\n      }, topInclude.through.model);\n    } else {\n      const isBelongsTo = topAssociation.associationType === 'BelongsTo';\n      const sourceField = isBelongsTo ? topAssociation.identifierField : topAssociation.sourceKeyField || topParent.model.primaryKeyField;\n      const targetField = isBelongsTo ? topAssociation.sourceKeyField || topInclude.model.primaryKeyField : topAssociation.identifierField;\n\n      const join = [\n        `${this.quoteIdentifier(topInclude.as)}.${this.quoteIdentifier(targetField)}`,\n        `${this.quoteTable(topParent.as || topParent.model.name)}.${this.quoteIdentifier(sourceField)}`\n      ].join(' = ');\n\n      query = this.selectQuery(topInclude.model.getTableName(), {\n        attributes: [targetField],\n        include: Model._validateIncludedElements(topInclude).include,\n        model: topInclude.model,\n        where: {\n          [Op.and]: [\n            topInclude.where,\n            { [Op.join]: this.sequelize.literal(join) }\n          ]\n        },\n        limit: 1,\n        tableAs: topInclude.as,\n        includeIgnoreAttributes: false\n      }, topInclude.model);\n    }\n\n    if (!topLevelInfo.options.where[Op.and]) {\n      topLevelInfo.options.where[Op.and] = [];\n    }\n\n    topLevelInfo.options.where[`__${includeAs.internalAs}`] = this.sequelize.literal([\n      '(',\n      query.replace(/;$/, ''),\n      ')',\n      'IS NOT NULL'\n    ].join(' '));\n  }\n\n  /*\n   * For a given include hierarchy creates a copy of it where only the required includes\n   * are preserved.\n   */\n  _getRequiredClosure(include) {\n    const copy = Object.assign({}, include, { attributes: [], include: [] });\n\n    if (Array.isArray(include.include)) {\n      copy.include = include.include\n        .filter(i => i.required)\n        .map(inc => this._getRequiredClosure(inc));\n    }\n\n    return copy;\n  }\n\n  getQueryOrders(options, model, subQuery) {\n    const mainQueryOrder = [];\n    const subQueryOrder = [];\n\n    if (Array.isArray(options.order)) {\n      for (let order of options.order) {\n\n        // wrap if not array\n        if (!Array.isArray(order)) {\n          order = [order];\n        }\n\n        if (\n          subQuery\n          && Array.isArray(order)\n          && order[0]\n          && !(order[0] instanceof Association)\n          && !(typeof order[0] === 'function' && order[0].prototype instanceof Model)\n          && !(typeof order[0].model === 'function' && order[0].model.prototype instanceof Model)\n          && !(typeof order[0] === 'string' && model && model.associations !== undefined && model.associations[order[0]])\n        ) {\n          subQueryOrder.push(this.quote(order, model, '->'));\n        }\n\n        if (subQuery) {\n          // Handle case where sub-query renames attribute we want to order by,\n          // see https://github.com/sequelize/sequelize/issues/8739\n          const subQueryAttribute = options.attributes.find(a => Array.isArray(a) && a[0] === order[0] && a[1]);\n          if (subQueryAttribute) {\n            const modelName = this.quoteIdentifier(model.name);\n\n            order[0] = new Utils.Col(this._getAliasForField(modelName, subQueryAttribute[1], options) || subQueryAttribute[1]);\n          }\n        }\n\n        mainQueryOrder.push(this.quote(order, model, '->'));\n      }\n    } else if (options.order instanceof Utils.SequelizeMethod) {\n      const sql = this.quote(options.order, model, '->');\n      if (subQuery) {\n        subQueryOrder.push(sql);\n      }\n      mainQueryOrder.push(sql);\n    } else {\n      throw new Error('Order must be type of array or instance of a valid sequelize method.');\n    }\n\n    return { mainQueryOrder, subQueryOrder };\n  }\n\n  selectFromTableFragment(options, model, attributes, tables, mainTableAs) {\n    let fragment = `SELECT ${attributes.join(', ')} FROM ${tables}`;\n\n    if (mainTableAs) {\n      fragment += ` AS ${mainTableAs}`;\n    }\n\n    if (options.indexHints && this._dialect.supports.indexHints) {\n      for (const hint of options.indexHints) {\n        if (IndexHints[hint.type]) {\n          fragment += ` ${IndexHints[hint.type]} INDEX (${hint.values.map(indexName => this.quoteIdentifiers(indexName)).join(',')})`;\n        }\n      }\n    }\n\n    return fragment;\n  }\n\n  /**\n   * Returns an SQL fragment for adding result constraints.\n   *\n   * @param  {Object} options An object with selectQuery options.\n   * @returns {string}         The generated sql query.\n   * @private\n   */\n  addLimitAndOffset(options) {\n    let fragment = '';\n\n    /* eslint-disable */\n    if (options.offset != null && options.limit == null) {\n      fragment += ' LIMIT ' + this.escape(options.offset) + ', ' + 10000000000000;\n    } else if (options.limit != null) {\n      if (options.offset != null) {\n        fragment += ' LIMIT ' + this.escape(options.offset) + ', ' + this.escape(options.limit);\n      } else {\n        fragment += ' LIMIT ' + this.escape(options.limit);\n      }\n    }\n    /* eslint-enable */\n\n    return fragment;\n  }\n\n  handleSequelizeMethod(smth, tableName, factory, options, prepend) {\n    let result;\n\n    if (Object.prototype.hasOwnProperty.call(this.OperatorMap, smth.comparator)) {\n      smth.comparator = this.OperatorMap[smth.comparator];\n    }\n\n    if (smth instanceof Utils.Where) {\n      let value = smth.logic;\n      let key;\n\n      if (smth.attribute instanceof Utils.SequelizeMethod) {\n        key = this.getWhereConditions(smth.attribute, tableName, factory, options, prepend);\n      } else {\n        key = `${this.quoteTable(smth.attribute.Model.name)}.${this.quoteIdentifier(smth.attribute.field || smth.attribute.fieldName)}`;\n      }\n\n      if (value && value instanceof Utils.SequelizeMethod) {\n        value = this.getWhereConditions(value, tableName, factory, options, prepend);\n\n        if (value === 'NULL') {\n          if (smth.comparator === '=') {\n            smth.comparator = 'IS';\n          }\n          if (smth.comparator === '!=') {\n            smth.comparator = 'IS NOT';\n          }\n        }\n\n        return [key, value].join(` ${smth.comparator} `);\n      }\n      if (_.isPlainObject(value)) {\n        return this.whereItemQuery(smth.attribute, value, {\n          model: factory\n        });\n      }\n      if (typeof value === 'boolean') {\n        value = this.booleanValue(value);\n      } else {\n        value = this.escape(value);\n      }\n\n      if (value === 'NULL') {\n        if (smth.comparator === '=') {\n          smth.comparator = 'IS';\n        }\n        if (smth.comparator === '!=') {\n          smth.comparator = 'IS NOT';\n        }\n      }\n\n      return [key, value].join(` ${smth.comparator} `);\n    }\n    if (smth instanceof Utils.Literal) {\n      return smth.val;\n    }\n    if (smth instanceof Utils.Cast) {\n      if (smth.val instanceof Utils.SequelizeMethod) {\n        result = this.handleSequelizeMethod(smth.val, tableName, factory, options, prepend);\n      } else if (_.isPlainObject(smth.val)) {\n        result = this.whereItemsQuery(smth.val);\n      } else {\n        result = this.escape(smth.val);\n      }\n\n      return `CAST(${result} AS ${smth.type.toUpperCase()})`;\n    }\n    if (smth instanceof Utils.Fn) {\n      return `${smth.fn}(${smth.args.map(arg => {\n        if (arg instanceof Utils.SequelizeMethod) {\n          return this.handleSequelizeMethod(arg, tableName, factory, options, prepend);\n        }\n        if (_.isPlainObject(arg)) {\n          return this.whereItemsQuery(arg);\n        }\n        return this.escape(arg);\n      }).join(', ')})`;\n    }\n    if (smth instanceof Utils.Col) {\n      if (Array.isArray(smth.col) && !factory) {\n        throw new Error('Cannot call Sequelize.col() with array outside of order / group clause');\n      }\n      if (smth.col.startsWith('*')) {\n        return '*';\n      }\n      return this.quote(smth.col, factory);\n    }\n    return smth.toString(this, factory);\n  }\n\n  whereQuery(where, options) {\n    const query = this.whereItemsQuery(where, options);\n    if (query && query.length) {\n      return `WHERE ${query}`;\n    }\n    return '';\n  }\n\n  whereItemsQuery(where, options, binding) {\n    if (\n      where === null ||\n      where === undefined ||\n      Utils.getComplexSize(where) === 0\n    ) {\n      // NO OP\n      return '';\n    }\n\n    if (typeof where === 'string') {\n      throw new Error('Support for `{where: \\'raw query\\'}` has been removed.');\n    }\n\n    const items = [];\n\n    binding = binding || 'AND';\n    if (binding[0] !== ' ') binding = ` ${binding} `;\n\n    if (_.isPlainObject(where)) {\n      Utils.getComplexKeys(where).forEach(prop => {\n        const item = where[prop];\n        items.push(this.whereItemQuery(prop, item, options));\n      });\n    } else {\n      items.push(this.whereItemQuery(undefined, where, options));\n    }\n\n    return items.length && items.filter(item => item && item.length).join(binding) || '';\n  }\n\n  whereItemQuery(key, value, options = {}) {\n    if (value === undefined) {\n      throw new Error(`WHERE parameter \"${key}\" has invalid \"undefined\" value`);\n    }\n\n    if (typeof key === 'string' && key.includes('.') && options.model) {\n      const keyParts = key.split('.');\n      if (options.model.rawAttributes[keyParts[0]] && options.model.rawAttributes[keyParts[0]].type instanceof DataTypes.JSON) {\n        const tmp = {};\n        const field = options.model.rawAttributes[keyParts[0]];\n        _.set(tmp, keyParts.slice(1), value);\n        return this.whereItemQuery(field.field || keyParts[0], tmp, Object.assign({ field }, options));\n      }\n    }\n\n    const field = this._findField(key, options);\n    const fieldType = field && field.type || options.type;\n\n    const isPlainObject = _.isPlainObject(value);\n    const isArray = !isPlainObject && Array.isArray(value);\n    key = this.OperatorsAliasMap && this.OperatorsAliasMap[key] || key;\n    if (isPlainObject) {\n      value = this._replaceAliases(value);\n    }\n    const valueKeys = isPlainObject && Utils.getComplexKeys(value);\n\n    if (key === undefined) {\n      if (typeof value === 'string') {\n        return value;\n      }\n\n      if (isPlainObject && valueKeys.length === 1) {\n        return this.whereItemQuery(valueKeys[0], value[valueKeys[0]], options);\n      }\n    }\n\n    if (value === null) {\n      const opValue = options.bindParam ? 'NULL' : this.escape(value, field);\n      return this._joinKeyValue(key, opValue, this.OperatorMap[Op.is], options.prefix);\n    }\n\n    if (!value) {\n      const opValue = options.bindParam ? this.format(value, field, options, options.bindParam) : this.escape(value, field);\n      return this._joinKeyValue(key, opValue, this.OperatorMap[Op.eq], options.prefix);\n    }\n\n    if (value instanceof Utils.SequelizeMethod && !(key !== undefined && value instanceof Utils.Fn)) {\n      return this.handleSequelizeMethod(value);\n    }\n\n    // Convert where: [] to Op.and if possible, else treat as literal/replacements\n    if (key === undefined && isArray) {\n      if (Utils.canTreatArrayAsAnd(value)) {\n        key = Op.and;\n      } else {\n        throw new Error('Support for literal replacements in the `where` object has been removed.');\n      }\n    }\n\n    if (key === Op.or || key === Op.and || key === Op.not) {\n      return this._whereGroupBind(key, value, options);\n    }\n\n\n    if (value[Op.or]) {\n      return this._whereBind(this.OperatorMap[Op.or], key, value[Op.or], options);\n    }\n\n    if (value[Op.and]) {\n      return this._whereBind(this.OperatorMap[Op.and], key, value[Op.and], options);\n    }\n\n    if (isArray && fieldType instanceof DataTypes.ARRAY) {\n      const opValue = options.bindParam ? this.format(value, field, options, options.bindParam) : this.escape(value, field);\n      return this._joinKeyValue(key, opValue, this.OperatorMap[Op.eq], options.prefix);\n    }\n\n    if (isPlainObject && fieldType instanceof DataTypes.JSON && options.json !== false) {\n      return this._whereJSON(key, value, options);\n    }\n    // If multiple keys we combine the different logic conditions\n    if (isPlainObject && valueKeys.length > 1) {\n      return this._whereBind(this.OperatorMap[Op.and], key, value, options);\n    }\n\n    if (isArray) {\n      return this._whereParseSingleValueObject(key, field, Op.in, value, options);\n    }\n    if (isPlainObject) {\n      if (this.OperatorMap[valueKeys[0]]) {\n        return this._whereParseSingleValueObject(key, field, valueKeys[0], value[valueKeys[0]], options);\n      }\n      return this._whereParseSingleValueObject(key, field, this.OperatorMap[Op.eq], value, options);\n    }\n\n    if (key === Op.placeholder) {\n      const opValue = options.bindParam ? this.format(value, field, options, options.bindParam) : this.escape(value, field);\n      return this._joinKeyValue(this.OperatorMap[key], opValue, this.OperatorMap[Op.eq], options.prefix);\n    }\n\n    const opValue = options.bindParam ? this.format(value, field, options, options.bindParam) : this.escape(value, field);\n    return this._joinKeyValue(key, opValue, this.OperatorMap[Op.eq], options.prefix);\n  }\n\n  _findField(key, options) {\n    if (options.field) {\n      return options.field;\n    }\n\n    if (options.model && options.model.rawAttributes && options.model.rawAttributes[key]) {\n      return options.model.rawAttributes[key];\n    }\n\n    if (options.model && options.model.fieldRawAttributesMap && options.model.fieldRawAttributesMap[key]) {\n      return options.model.fieldRawAttributesMap[key];\n    }\n  }\n\n  // OR/AND/NOT grouping logic\n  _whereGroupBind(key, value, options) {\n    const binding = key === Op.or ? this.OperatorMap[Op.or] : this.OperatorMap[Op.and];\n    const outerBinding = key === Op.not ? 'NOT ' : '';\n\n    if (Array.isArray(value)) {\n      value = value.map(item => {\n        let itemQuery = this.whereItemsQuery(item, options, this.OperatorMap[Op.and]);\n        if (itemQuery && itemQuery.length && (Array.isArray(item) || _.isPlainObject(item)) && Utils.getComplexSize(item) > 1) {\n          itemQuery = `(${itemQuery})`;\n        }\n        return itemQuery;\n      }).filter(item => item && item.length);\n\n      value = value.length && value.join(binding);\n    } else {\n      value = this.whereItemsQuery(value, options, binding);\n    }\n    // Op.or: [] should return no data.\n    // Op.not of no restriction should also return no data\n    if ((key === Op.or || key === Op.not) && !value) {\n      return '0 = 1';\n    }\n\n    return value ? `${outerBinding}(${value})` : undefined;\n  }\n\n  _whereBind(binding, key, value, options) {\n    if (_.isPlainObject(value)) {\n      value = Utils.getComplexKeys(value).map(prop => {\n        const item = value[prop];\n        return this.whereItemQuery(key, { [prop]: item }, options);\n      });\n    } else {\n      value = value.map(item => this.whereItemQuery(key, item, options));\n    }\n\n    value = value.filter(item => item && item.length);\n\n    return value.length ? `(${value.join(binding)})` : undefined;\n  }\n\n  _whereJSON(key, value, options) {\n    const items = [];\n    let baseKey = this.quoteIdentifier(key);\n    if (options.prefix) {\n      if (options.prefix instanceof Utils.Literal) {\n        baseKey = `${this.handleSequelizeMethod(options.prefix)}.${baseKey}`;\n      } else {\n        baseKey = `${this.quoteTable(options.prefix)}.${baseKey}`;\n      }\n    }\n\n    Utils.getOperators(value).forEach(op => {\n      const where = {\n        [op]: value[op]\n      };\n      items.push(this.whereItemQuery(key, where, Object.assign({}, options, { json: false })));\n    });\n\n    _.forOwn(value, (item, prop) => {\n      this._traverseJSON(items, baseKey, prop, item, [prop]);\n    });\n\n    const result = items.join(this.OperatorMap[Op.and]);\n    return items.length > 1 ? `(${result})` : result;\n  }\n\n  _traverseJSON(items, baseKey, prop, item, path) {\n    let cast;\n\n    if (path[path.length - 1].includes('::')) {\n      const tmp = path[path.length - 1].split('::');\n      cast = tmp[1];\n      path[path.length - 1] = tmp[0];\n    }\n\n    const pathKey = this.jsonPathExtractionQuery(baseKey, path);\n\n    if (_.isPlainObject(item)) {\n      Utils.getOperators(item).forEach(op => {\n        const value = this._toJSONValue(item[op]);\n        items.push(this.whereItemQuery(this._castKey(pathKey, value, cast), { [op]: value }));\n      });\n      _.forOwn(item, (value, itemProp) => {\n        this._traverseJSON(items, baseKey, itemProp, value, path.concat([itemProp]));\n      });\n\n      return;\n    }\n\n    item = this._toJSONValue(item);\n    items.push(this.whereItemQuery(this._castKey(pathKey, item, cast), { [Op.eq]: item }));\n  }\n\n  _toJSONValue(value) {\n    return value;\n  }\n\n  _castKey(key, value, cast, json) {\n    cast = cast || this._getJsonCast(Array.isArray(value) ? value[0] : value);\n    if (cast) {\n      return new Utils.Literal(this.handleSequelizeMethod(new Utils.Cast(new Utils.Literal(key), cast, json)));\n    }\n\n    return new Utils.Literal(key);\n  }\n\n  _getJsonCast(value) {\n    if (typeof value === 'number') {\n      return 'double precision';\n    }\n    if (value instanceof Date) {\n      return 'timestamptz';\n    }\n    if (typeof value === 'boolean') {\n      return 'boolean';\n    }\n    return;\n  }\n\n  _joinKeyValue(key, value, comparator, prefix) {\n    if (!key) {\n      return value;\n    }\n    if (comparator === undefined) {\n      throw new Error(`${key} and ${value} has no comparator`);\n    }\n    key = this._getSafeKey(key, prefix);\n    return [key, value].join(` ${comparator} `);\n  }\n\n  _getSafeKey(key, prefix) {\n    if (key instanceof Utils.SequelizeMethod) {\n      key = this.handleSequelizeMethod(key);\n      return this._prefixKey(this.handleSequelizeMethod(key), prefix);\n    }\n\n    if (Utils.isColString(key)) {\n      key = key.substr(1, key.length - 2).split('.');\n\n      if (key.length > 2) {\n        key = [\n          // join the tables by -> to match out internal namings\n          key.slice(0, -1).join('->'),\n          key[key.length - 1]\n        ];\n      }\n\n      return key.map(identifier => this.quoteIdentifier(identifier)).join('.');\n    }\n\n    return this._prefixKey(this.quoteIdentifier(key), prefix);\n  }\n\n  _prefixKey(key, prefix) {\n    if (prefix) {\n      if (prefix instanceof Utils.Literal) {\n        return [this.handleSequelizeMethod(prefix), key].join('.');\n      }\n\n      return [this.quoteTable(prefix), key].join('.');\n    }\n\n    return key;\n  }\n\n  _whereParseSingleValueObject(key, field, prop, value, options) {\n    if (prop === Op.not) {\n      if (Array.isArray(value)) {\n        prop = Op.notIn;\n      } else if (value !== null && value !== true && value !== false) {\n        prop = Op.ne;\n      }\n    }\n\n    let comparator = this.OperatorMap[prop] || this.OperatorMap[Op.eq];\n\n    switch (prop) {\n      case Op.in:\n      case Op.notIn:\n        if (value instanceof Utils.Literal) {\n          return this._joinKeyValue(key, value.val, comparator, options.prefix);\n        }\n\n        if (value.length) {\n          return this._joinKeyValue(key, `(${value.map(item => this.escape(item, field)).join(', ')})`, comparator, options.prefix);\n        }\n\n        if (comparator === this.OperatorMap[Op.in]) {\n          return this._joinKeyValue(key, '(NULL)', comparator, options.prefix);\n        }\n\n        return '';\n      case Op.any:\n      case Op.all:\n        comparator = `${this.OperatorMap[Op.eq]} ${comparator}`;\n        if (value[Op.values]) {\n          return this._joinKeyValue(key, `(VALUES ${value[Op.values].map(item => `(${this.escape(item)})`).join(', ')})`, comparator, options.prefix);\n        }\n\n        return this._joinKeyValue(key, `(${this.escape(value, field)})`, comparator, options.prefix);\n      case Op.between:\n      case Op.notBetween:\n        return this._joinKeyValue(key, `${this.escape(value[0], field)} AND ${this.escape(value[1], field)}`, comparator, options.prefix);\n      case Op.raw:\n        throw new Error('The `$raw` where property is no longer supported.  Use `sequelize.literal` instead.');\n      case Op.col:\n        comparator = this.OperatorMap[Op.eq];\n        value = value.split('.');\n\n        if (value.length > 2) {\n          value = [\n            // join the tables by -> to match out internal namings\n            value.slice(0, -1).join('->'),\n            value[value.length - 1]\n          ];\n        }\n\n        return this._joinKeyValue(key, value.map(identifier => this.quoteIdentifier(identifier)).join('.'), comparator, options.prefix);\n      case Op.startsWith:\n        comparator = this.OperatorMap[Op.like];\n        return this._joinKeyValue(key, this.escape(`${value}%`), comparator, options.prefix);\n      case Op.endsWith:\n        comparator = this.OperatorMap[Op.like];\n        return this._joinKeyValue(key, this.escape(`%${value}`), comparator, options.prefix);\n      case Op.substring:\n        comparator = this.OperatorMap[Op.like];\n        return this._joinKeyValue(key, this.escape(`%${value}%`), comparator, options.prefix);\n    }\n\n    const escapeOptions = {\n      acceptStrings: comparator.includes(this.OperatorMap[Op.like])\n    };\n\n    if (_.isPlainObject(value)) {\n      if (value[Op.col]) {\n        return this._joinKeyValue(key, this.whereItemQuery(null, value), comparator, options.prefix);\n      }\n      if (value[Op.any]) {\n        escapeOptions.isList = true;\n        return this._joinKeyValue(key, `(${this.escape(value[Op.any], field, escapeOptions)})`, `${comparator} ${this.OperatorMap[Op.any]}`, options.prefix);\n      }\n      if (value[Op.all]) {\n        escapeOptions.isList = true;\n        return this._joinKeyValue(key, `(${this.escape(value[Op.all], field, escapeOptions)})`, `${comparator} ${this.OperatorMap[Op.all]}`, options.prefix);\n      }\n    }\n\n    if (value === null && comparator === this.OperatorMap[Op.eq]) {\n      return this._joinKeyValue(key, this.escape(value, field, escapeOptions), this.OperatorMap[Op.is], options.prefix);\n    }\n    if (value === null && comparator === this.OperatorMap[Op.ne]) {\n      return this._joinKeyValue(key, this.escape(value, field, escapeOptions), this.OperatorMap[Op.not], options.prefix);\n    }\n\n    return this._joinKeyValue(key, this.escape(value, field, escapeOptions), comparator, options.prefix);\n  }\n\n  /*\n    Takes something and transforms it into values of a where condition.\n   @private\n  */\n  getWhereConditions(smth, tableName, factory, options, prepend) {\n    const where = {};\n\n    if (Array.isArray(tableName)) {\n      tableName = tableName[0];\n      if (Array.isArray(tableName)) {\n        tableName = tableName[1];\n      }\n    }\n\n    options = options || {};\n\n    if (prepend === undefined) {\n      prepend = true;\n    }\n\n    if (smth && smth instanceof Utils.SequelizeMethod) { // Checking a property is cheaper than a lot of instanceof calls\n      return this.handleSequelizeMethod(smth, tableName, factory, options, prepend);\n    }\n    if (_.isPlainObject(smth)) {\n      return this.whereItemsQuery(smth, {\n        model: factory,\n        prefix: prepend && tableName,\n        type: options.type\n      });\n    }\n    if (typeof smth === 'number') {\n      let primaryKeys = factory ? Object.keys(factory.primaryKeys) : [];\n\n      if (primaryKeys.length > 0) {\n        // Since we're just a number, assume only the first key\n        primaryKeys = primaryKeys[0];\n      } else {\n        primaryKeys = 'id';\n      }\n\n      where[primaryKeys] = smth;\n\n      return this.whereItemsQuery(where, {\n        model: factory,\n        prefix: prepend && tableName\n      });\n    }\n    if (typeof smth === 'string') {\n      return this.whereItemsQuery(smth, {\n        model: factory,\n        prefix: prepend && tableName\n      });\n    }\n    if (Buffer.isBuffer(smth)) {\n      return this.escape(smth);\n    }\n    if (Array.isArray(smth)) {\n      if (smth.length === 0 || smth.length > 0 && smth[0].length === 0) return '1=1';\n      if (Utils.canTreatArrayAsAnd(smth)) {\n        const _smth = { [Op.and]: smth };\n        return this.getWhereConditions(_smth, tableName, factory, options, prepend);\n      }\n      throw new Error('Support for literal replacements in the `where` object has been removed.');\n    }\n    if (smth === null) {\n      return this.whereItemsQuery(smth, {\n        model: factory,\n        prefix: prepend && tableName\n      });\n    }\n\n    return '1=1';\n  }\n\n  // A recursive parser for nested where conditions\n  parseConditionObject(conditions, path) {\n    path = path || [];\n    return _.reduce(conditions, (result, value, key) => {\n      if (_.isObject(value)) {\n        return result.concat(this.parseConditionObject(value, path.concat(key))); // Recursively parse objects\n      }\n      result.push({ path: path.concat(key), value });\n      return result;\n    }, []);\n  }\n\n  booleanValue(value) {\n    return value;\n  }\n}\n\nObject.assign(QueryGenerator.prototype, require('./query-generator/operators'));\nObject.assign(QueryGenerator.prototype, require('./query-generator/transaction'));\n\nmodule.exports = QueryGenerator;\n"]} \ No newline at end of file diff --git a/dist/dialects/abstract/query-generator/helpers/quote.js b/dist/dialects/abstract/query-generator/helpers/quote.js index 9026a0a..0f00dbe 100644 --- a/dist/dialects/abstract/query-generator/helpers/quote.js +++ b/dist/dialects/abstract/query-generator/helpers/quote.js @@ -82,4 +82,4 @@ function isIdentifierQuoted(identifier) { } module.exports.isIdentifierQuoted = isIdentifierQuoted; -//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL2xpYi9kaWFsZWN0cy9hYnN0cmFjdC9xdWVyeS1nZW5lcmF0b3IvaGVscGVycy9xdW90ZS5qcyJdLCJuYW1lcyI6WyJVdGlscyIsInJlcXVpcmUiLCJwb3N0Z3Jlc1Jlc2VydmVkV29yZHMiLCJzcGxpdCIsInF1b3RlSWRlbnRpZmllciIsImRpYWxlY3QiLCJpZGVudGlmaWVyIiwib3B0aW9ucyIsImRlZmF1bHRzIiwiZm9yY2UiLCJxdW90ZUlkZW50aWZpZXJzIiwiYWRkVGlja3MiLCJyZW1vdmVUaWNrcyIsInJhd0lkZW50aWZpZXIiLCJpbmNsdWRlcyIsInRvTG93ZXJDYXNlIiwicmVwbGFjZSIsIkVycm9yIiwibW9kdWxlIiwiZXhwb3J0cyIsImlzSWRlbnRpZmllclF1b3RlZCIsInRlc3QiXSwibWFwcGluZ3MiOiJBQUFBOzs7Ozs7Ozs7O0FBV0E7O0FBRUEsTUFBTUEsS0FBSyxHQUFHQyxPQUFPLENBQUMsbUJBQUQsQ0FBckI7QUFFQTs7Ozs7Ozs7QUFNQSxNQUFNQyxxQkFBcUIsR0FBRyxpdUJBQWl1QkMsS0FBanVCLENBQXV1QixHQUF2dUIsQ0FBOUI7QUFFQTs7Ozs7Ozs7Ozs7O0FBV0EsU0FBU0MsZUFBVCxDQUF5QkMsT0FBekIsRUFBa0NDLFVBQWxDLEVBQThDQyxPQUE5QyxFQUF1RDtBQUNyRCxNQUFJRCxVQUFVLEtBQUssR0FBbkIsRUFBd0IsT0FBT0EsVUFBUDtBQUV4QkMsRUFBQUEsT0FBTyxHQUFHUCxLQUFLLENBQUNRLFFBQU4sQ0FBZUQsT0FBTyxJQUFJLEVBQTFCLEVBQThCO0FBQ3RDRSxJQUFBQSxLQUFLLEVBQUUsS0FEK0I7QUFFdENDLElBQUFBLGdCQUFnQixFQUFFO0FBRm9CLEdBQTlCLENBQVY7O0FBS0EsVUFBUUwsT0FBUjtBQUNFLFNBQUssUUFBTDtBQUNBLFNBQUssU0FBTDtBQUNBLFNBQUssT0FBTDtBQUNFLGFBQU9MLEtBQUssQ0FBQ1csUUFBTixDQUFlWCxLQUFLLENBQUNZLFdBQU4sQ0FBa0JOLFVBQWxCLEVBQThCLEdBQTlCLENBQWYsRUFBbUQsR0FBbkQsQ0FBUDs7QUFFRixTQUFLLFVBQUw7QUFDRSxZQUFNTyxhQUFhLEdBQUdiLEtBQUssQ0FBQ1ksV0FBTixDQUFrQk4sVUFBbEIsRUFBOEIsR0FBOUIsQ0FBdEI7O0FBRUEsVUFDRUMsT0FBTyxDQUFDRSxLQUFSLEtBQWtCLElBQWxCLElBQ0FGLE9BQU8sQ0FBQ0csZ0JBQVIsS0FBNkIsS0FEN0IsSUFFQSxDQUFDSixVQUFVLENBQUNRLFFBQVgsQ0FBb0IsR0FBcEIsQ0FGRCxJQUdBLENBQUNSLFVBQVUsQ0FBQ1EsUUFBWCxDQUFvQixJQUFwQixDQUhELElBSUEsQ0FBQ1oscUJBQXFCLENBQUNZLFFBQXRCLENBQStCRCxhQUFhLENBQUNFLFdBQWQsRUFBL0IsQ0FMSCxFQU1FO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLGVBQU9GLGFBQVA7QUFDRDs7QUFDRCxhQUFPYixLQUFLLENBQUNXLFFBQU4sQ0FBZUUsYUFBZixFQUE4QixHQUE5QixDQUFQOztBQUNGLFNBQUssT0FBTDtBQUNFLGFBQVEsSUFBR1AsVUFBVSxDQUFDVSxPQUFYLENBQW1CLFVBQW5CLEVBQStCLEVBQS9CLENBQW1DLEdBQTlDOztBQUVGO0FBQ0UsWUFBTSxJQUFJQyxLQUFKLENBQVcsWUFBV1osT0FBUSxvQkFBOUIsQ0FBTjtBQTVCSjtBQThCRDs7QUFDRGEsTUFBTSxDQUFDQyxPQUFQLENBQWVmLGVBQWYsR0FBaUNBLGVBQWpDO0FBRUE7Ozs7Ozs7OztBQVFBLFNBQVNnQixrQkFBVCxDQUE0QmQsVUFBNUIsRUFBd0M7QUFDdEMsU0FBTywrQ0FBK0NlLElBQS9DLENBQW9EZixVQUFwRCxDQUFQO0FBQ0Q7O0FBQ0RZLE1BQU0sQ0FBQ0MsT0FBUCxDQUFlQyxrQkFBZixHQUFvQ0Esa0JBQXBDIiwic291cmNlc0NvbnRlbnQiOlsiLyoqXHJcbiAqIFF1b3RlIGhlbHBlcnMgaW1wbGVtZW50IHF1b3RlIGFiaWxpdHkgZm9yIGFsbCBkaWFsZWN0cy5cclxuICogVGhlc2UgYXJlIGJhc2ljIGJsb2NrIG9mIHF1ZXJ5IGJ1aWxkaW5nXHJcbiAqXHJcbiAqIEl0cyBiZXR0ZXIgdG8gaW1wbGVtZW50IGFsbCBkaWFsZWN0IGltcGxlbWVudGF0aW9uIHRvZ2V0aGVyIGhlcmUuIFdoaWNoIHdpbGwgYWxsb3dcclxuICogZXZlbiBhYnN0cmFjdCBnZW5lcmF0b3IgdG8gdXNlIHRoZW0gYnkganVzdCBzcGVjaWZ5aW5nIGRpYWxlY3QgdHlwZS5cclxuICpcclxuICogRGVmaW5pbmcgdGhlc2UgaGVscGVycyBpbiBlYWNoIHF1ZXJ5IGRpYWxlY3Qgd2lsbCBsZWF2ZVxyXG4gKiBjb2RlIGluIGR1YWwgZGVwZW5kZW5jeSBvZiBhYnN0cmFjdCA8LT4gc3BlY2lmaWMgZGlhbGVjdFxyXG4gKi9cclxuXHJcbid1c2Ugc3RyaWN0JztcclxuXHJcbmNvbnN0IFV0aWxzID0gcmVxdWlyZSgnLi4vLi4vLi4vLi4vdXRpbHMnKTtcclxuXHJcbi8qKlxyXG4gKiBsaXN0IG9mIHJlc2VydmVkIHdvcmRzIGluIFBvc3RncmVTUUwgMTBcclxuICogc291cmNlOiBodHRwczovL3d3dy5wb3N0Z3Jlc3FsLm9yZy9kb2NzLzEwL3N0YXRpYy9zcWwta2V5d29yZHMtYXBwZW5kaXguaHRtbFxyXG4gKlxyXG4gKiBAcHJpdmF0ZVxyXG4gKi9cclxuY29uc3QgcG9zdGdyZXNSZXNlcnZlZFdvcmRzID0gJ2FsbCxhbmFseXNlLGFuYWx5emUsYW5kLGFueSxhcnJheSxhcyxhc2MsYXN5bW1ldHJpYyxhdXRob3JpemF0aW9uLGJpbmFyeSxib3RoLGNhc2UsY2FzdCxjaGVjayxjb2xsYXRlLGNvbGxhdGlvbixjb2x1bW4sY29uY3VycmVudGx5LGNvbnN0cmFpbnQsY3JlYXRlLGNyb3NzLGN1cnJlbnRfY2F0YWxvZyxjdXJyZW50X2RhdGUsY3VycmVudF9yb2xlLGN1cnJlbnRfc2NoZW1hLGN1cnJlbnRfdGltZSxjdXJyZW50X3RpbWVzdGFtcCxjdXJyZW50X3VzZXIsZGVmYXVsdCxkZWZlcnJhYmxlLGRlc2MsZGlzdGluY3QsZG8sZWxzZSxlbmQsZXhjZXB0LGZhbHNlLGZldGNoLGZvcixmb3JlaWduLGZyZWV6ZSxmcm9tLGZ1bGwsZ3JhbnQsZ3JvdXAsaGF2aW5nLGlsaWtlLGluLGluaXRpYWxseSxpbm5lcixpbnRlcnNlY3QsaW50byxpcyxpc251bGwsam9pbixsYXRlcmFsLGxlYWRpbmcsbGVmdCxsaWtlLGxpbWl0LGxvY2FsdGltZSxsb2NhbHRpbWVzdGFtcCxuYXR1cmFsLG5vdCxub3RudWxsLG51bGwsb2Zmc2V0LG9uLG9ubHksb3Isb3JkZXIsb3V0ZXIsb3ZlcmxhcHMscGxhY2luZyxwcmltYXJ5LHJlZmVyZW5jZXMscmV0dXJuaW5nLHJpZ2h0LHNlbGVjdCxzZXNzaW9uX3VzZXIsc2ltaWxhcixzb21lLHN5bW1ldHJpYyx0YWJsZSx0YWJsZXNhbXBsZSx0aGVuLHRvLHRyYWlsaW5nLHRydWUsdW5pb24sdW5pcXVlLHVzZXIsdXNpbmcsdmFyaWFkaWMsdmVyYm9zZSx3aGVuLHdoZXJlLHdpbmRvdyx3aXRoJy5zcGxpdCgnLCcpO1xyXG5cclxuLyoqXHJcbiAqXHJcbiAqIEBwYXJhbSB7c3RyaW5nfSAgZGlhbGVjdCAgICAgICAgIERpYWxlY3QgbmFtZVxyXG4gKiBAcGFyYW0ge3N0cmluZ30gIGlkZW50aWZpZXIgICAgICBJZGVudGlmaWVyIHRvIHF1b3RlXHJcbiAqIEBwYXJhbSB7T2JqZWN0fSAgW29wdGlvbnNdXHJcbiAqIEBwYXJhbSB7Ym9vbGVhbn0gW29wdGlvbnMuZm9yY2U9ZmFsc2VdXHJcbiAqIEBwYXJhbSB7Ym9vbGVhbn0gW29wdGlvbnMucXVvdGVJZGVudGlmaWVycz10cnVlXVxyXG4gKlxyXG4gKiBAcmV0dXJucyB7c3RyaW5nfVxyXG4gKiBAcHJpdmF0ZVxyXG4gKi9cclxuZnVuY3Rpb24gcXVvdGVJZGVudGlmaWVyKGRpYWxlY3QsIGlkZW50aWZpZXIsIG9wdGlvbnMpIHtcclxuICBpZiAoaWRlbnRpZmllciA9PT0gJyonKSByZXR1cm4gaWRlbnRpZmllcjtcclxuXHJcbiAgb3B0aW9ucyA9IFV0aWxzLmRlZmF1bHRzKG9wdGlvbnMgfHwge30sIHtcclxuICAgIGZvcmNlOiBmYWxzZSxcclxuICAgIHF1b3RlSWRlbnRpZmllcnM6IHRydWVcclxuICB9KTtcclxuXHJcbiAgc3dpdGNoIChkaWFsZWN0KSB7XHJcbiAgICBjYXNlICdzcWxpdGUnOlxyXG4gICAgY2FzZSAnbWFyaWFkYic6XHJcbiAgICBjYXNlICdteXNxbCc6XHJcbiAgICAgIHJldHVybiBVdGlscy5hZGRUaWNrcyhVdGlscy5yZW1vdmVUaWNrcyhpZGVudGlmaWVyLCAnYCcpLCAnYCcpO1xyXG5cclxuICAgIGNhc2UgJ3Bvc3RncmVzJzpcclxuICAgICAgY29uc3QgcmF3SWRlbnRpZmllciA9IFV0aWxzLnJlbW92ZVRpY2tzKGlkZW50aWZpZXIsICdcIicpO1xyXG5cclxuICAgICAgaWYgKFxyXG4gICAgICAgIG9wdGlvbnMuZm9yY2UgIT09IHRydWUgJiZcclxuICAgICAgICBvcHRpb25zLnF1b3RlSWRlbnRpZmllcnMgPT09IGZhbHNlICYmXHJcbiAgICAgICAgIWlkZW50aWZpZXIuaW5jbHVkZXMoJy4nKSAmJlxyXG4gICAgICAgICFpZGVudGlmaWVyLmluY2x1ZGVzKCctPicpICYmXHJcbiAgICAgICAgIXBvc3RncmVzUmVzZXJ2ZWRXb3Jkcy5pbmNsdWRlcyhyYXdJZGVudGlmaWVyLnRvTG93ZXJDYXNlKCkpXHJcbiAgICAgICkge1xyXG4gICAgICAgIC8vIEluIFBvc3RncmVzLCBpZiB0YWJsZXMgb3IgYXR0cmlidXRlcyBhcmUgY3JlYXRlZCBkb3VibGUtcXVvdGVkLFxyXG4gICAgICAgIC8vIHRoZXkgYXJlIGFsc28gY2FzZSBzZW5zaXRpdmUuIElmIHRoZXkgY29udGFpbiBhbnkgdXBwZXJjYXNlXHJcbiAgICAgICAgLy8gY2hhcmFjdGVycywgdGhleSBtdXN0IGFsd2F5cyBiZSBkb3VibGUtcXVvdGVkLiBUaGlzIG1ha2VzIGl0XHJcbiAgICAgICAgLy8gaW1wb3NzaWJsZSB0byB3cml0ZSBxdWVyaWVzIGluIHBvcnRhYmxlIFNRTCBpZiB0YWJsZXMgYXJlIGNyZWF0ZWQgaW5cclxuICAgICAgICAvLyB0aGlzIHdheS4gSGVuY2UsIHdlIHN0cmlwIHF1b3RlcyBpZiB3ZSBkb24ndCB3YW50IGNhc2Ugc2Vuc2l0aXZpdHkuXHJcbiAgICAgICAgcmV0dXJuIHJhd0lkZW50aWZpZXI7XHJcbiAgICAgIH1cclxuICAgICAgcmV0dXJuIFV0aWxzLmFkZFRpY2tzKHJhd0lkZW50aWZpZXIsICdcIicpO1xyXG4gICAgY2FzZSAnbXNzcWwnOlxyXG4gICAgICByZXR1cm4gYFske2lkZW50aWZpZXIucmVwbGFjZSgvW1tcXF0nXSsvZywgJycpfV1gO1xyXG5cclxuICAgIGRlZmF1bHQ6XHJcbiAgICAgIHRocm93IG5ldyBFcnJvcihgRGlhbGVjdCBcIiR7ZGlhbGVjdH1cIiBpcyBub3Qgc3VwcG9ydGVkYCk7XHJcbiAgfVxyXG59XHJcbm1vZHVsZS5leHBvcnRzLnF1b3RlSWRlbnRpZmllciA9IHF1b3RlSWRlbnRpZmllcjtcclxuXHJcbi8qKlxyXG4gKiBUZXN0IGlmIGEgZ2l2ZSBzdHJpbmcgaXMgYWxyZWFkeSBxdW90ZWRcclxuICpcclxuICogQHBhcmFtIHtzdHJpbmd9IGlkZW50aWZpZXJcclxuICpcclxuICogQHJldHVybnMge2Jvb2xlYW59XHJcbiAqIEBwcml2YXRlXHJcbiAqL1xyXG5mdW5jdGlvbiBpc0lkZW50aWZpZXJRdW90ZWQoaWRlbnRpZmllcikge1xyXG4gIHJldHVybiAvXlxccyooPzooW2BcIiddKSg/Oig/IVxcMSkufFxcMXsyfSkqXFwxXFwuPykrXFxzKiQvaS50ZXN0KGlkZW50aWZpZXIpO1xyXG59XHJcbm1vZHVsZS5leHBvcnRzLmlzSWRlbnRpZmllclF1b3RlZCA9IGlzSWRlbnRpZmllclF1b3RlZDtcclxuIl19 \ No newline at end of file +//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL2xpYi9kaWFsZWN0cy9hYnN0cmFjdC9xdWVyeS1nZW5lcmF0b3IvaGVscGVycy9xdW90ZS5qcyJdLCJuYW1lcyI6WyJVdGlscyIsInJlcXVpcmUiLCJwb3N0Z3Jlc1Jlc2VydmVkV29yZHMiLCJzcGxpdCIsInF1b3RlSWRlbnRpZmllciIsImRpYWxlY3QiLCJpZGVudGlmaWVyIiwib3B0aW9ucyIsImRlZmF1bHRzIiwiZm9yY2UiLCJxdW90ZUlkZW50aWZpZXJzIiwiYWRkVGlja3MiLCJyZW1vdmVUaWNrcyIsInJhd0lkZW50aWZpZXIiLCJpbmNsdWRlcyIsInRvTG93ZXJDYXNlIiwicmVwbGFjZSIsIkVycm9yIiwibW9kdWxlIiwiZXhwb3J0cyIsImlzSWRlbnRpZmllclF1b3RlZCIsInRlc3QiXSwibWFwcGluZ3MiOiJBQUFBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBRUE7O0FBRUEsTUFBTUEsS0FBSyxHQUFHQyxPQUFPLENBQUMsbUJBQUQsQ0FBckI7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7OztBQUNBLE1BQU1DLHFCQUFxQixHQUFHLGl1QkFBaXVCQyxLQUFqdUIsQ0FBdXVCLEdBQXZ1QixDQUE5QjtBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBQ0EsU0FBU0MsZUFBVCxDQUF5QkMsT0FBekIsRUFBa0NDLFVBQWxDLEVBQThDQyxPQUE5QyxFQUF1RDtBQUNyRCxNQUFJRCxVQUFVLEtBQUssR0FBbkIsRUFBd0IsT0FBT0EsVUFBUDtBQUV4QkMsRUFBQUEsT0FBTyxHQUFHUCxLQUFLLENBQUNRLFFBQU4sQ0FBZUQsT0FBTyxJQUFJLEVBQTFCLEVBQThCO0FBQ3RDRSxJQUFBQSxLQUFLLEVBQUUsS0FEK0I7QUFFdENDLElBQUFBLGdCQUFnQixFQUFFO0FBRm9CLEdBQTlCLENBQVY7O0FBS0EsVUFBUUwsT0FBUjtBQUNFLFNBQUssUUFBTDtBQUNBLFNBQUssU0FBTDtBQUNBLFNBQUssT0FBTDtBQUNFLGFBQU9MLEtBQUssQ0FBQ1csUUFBTixDQUFlWCxLQUFLLENBQUNZLFdBQU4sQ0FBa0JOLFVBQWxCLEVBQThCLEdBQTlCLENBQWYsRUFBbUQsR0FBbkQsQ0FBUDs7QUFFRixTQUFLLFVBQUw7QUFDRSxZQUFNTyxhQUFhLEdBQUdiLEtBQUssQ0FBQ1ksV0FBTixDQUFrQk4sVUFBbEIsRUFBOEIsR0FBOUIsQ0FBdEI7O0FBRUEsVUFDRUMsT0FBTyxDQUFDRSxLQUFSLEtBQWtCLElBQWxCLElBQ0FGLE9BQU8sQ0FBQ0csZ0JBQVIsS0FBNkIsS0FEN0IsSUFFQSxDQUFDSixVQUFVLENBQUNRLFFBQVgsQ0FBb0IsR0FBcEIsQ0FGRCxJQUdBLENBQUNSLFVBQVUsQ0FBQ1EsUUFBWCxDQUFvQixJQUFwQixDQUhELElBSUEsQ0FBQ1oscUJBQXFCLENBQUNZLFFBQXRCLENBQStCRCxhQUFhLENBQUNFLFdBQWQsRUFBL0IsQ0FMSCxFQU1FO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLGVBQU9GLGFBQVA7QUFDRDs7QUFDRCxhQUFPYixLQUFLLENBQUNXLFFBQU4sQ0FBZUUsYUFBZixFQUE4QixHQUE5QixDQUFQOztBQUNGLFNBQUssT0FBTDtBQUNFLGFBQVEsSUFBR1AsVUFBVSxDQUFDVSxPQUFYLENBQW1CLFVBQW5CLEVBQStCLEVBQS9CLENBQW1DLEdBQTlDOztBQUVGO0FBQ0UsWUFBTSxJQUFJQyxLQUFKLENBQVcsWUFBV1osT0FBUSxvQkFBOUIsQ0FBTjtBQTVCSjtBQThCRDs7QUFDRGEsTUFBTSxDQUFDQyxPQUFQLENBQWVmLGVBQWYsR0FBaUNBLGVBQWpDO0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFDQSxTQUFTZ0Isa0JBQVQsQ0FBNEJkLFVBQTVCLEVBQXdDO0FBQ3RDLFNBQU8sK0NBQStDZSxJQUEvQyxDQUFvRGYsVUFBcEQsQ0FBUDtBQUNEOztBQUNEWSxNQUFNLENBQUNDLE9BQVAsQ0FBZUMsa0JBQWYsR0FBb0NBLGtCQUFwQyIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogUXVvdGUgaGVscGVycyBpbXBsZW1lbnQgcXVvdGUgYWJpbGl0eSBmb3IgYWxsIGRpYWxlY3RzLlxuICogVGhlc2UgYXJlIGJhc2ljIGJsb2NrIG9mIHF1ZXJ5IGJ1aWxkaW5nXG4gKlxuICogSXRzIGJldHRlciB0byBpbXBsZW1lbnQgYWxsIGRpYWxlY3QgaW1wbGVtZW50YXRpb24gdG9nZXRoZXIgaGVyZS4gV2hpY2ggd2lsbCBhbGxvd1xuICogZXZlbiBhYnN0cmFjdCBnZW5lcmF0b3IgdG8gdXNlIHRoZW0gYnkganVzdCBzcGVjaWZ5aW5nIGRpYWxlY3QgdHlwZS5cbiAqXG4gKiBEZWZpbmluZyB0aGVzZSBoZWxwZXJzIGluIGVhY2ggcXVlcnkgZGlhbGVjdCB3aWxsIGxlYXZlXG4gKiBjb2RlIGluIGR1YWwgZGVwZW5kZW5jeSBvZiBhYnN0cmFjdCA8LT4gc3BlY2lmaWMgZGlhbGVjdFxuICovXG5cbid1c2Ugc3RyaWN0JztcblxuY29uc3QgVXRpbHMgPSByZXF1aXJlKCcuLi8uLi8uLi8uLi91dGlscycpO1xuXG4vKipcbiAqIGxpc3Qgb2YgcmVzZXJ2ZWQgd29yZHMgaW4gUG9zdGdyZVNRTCAxMFxuICogc291cmNlOiBodHRwczovL3d3dy5wb3N0Z3Jlc3FsLm9yZy9kb2NzLzEwL3N0YXRpYy9zcWwta2V5d29yZHMtYXBwZW5kaXguaHRtbFxuICpcbiAqIEBwcml2YXRlXG4gKi9cbmNvbnN0IHBvc3RncmVzUmVzZXJ2ZWRXb3JkcyA9ICdhbGwsYW5hbHlzZSxhbmFseXplLGFuZCxhbnksYXJyYXksYXMsYXNjLGFzeW1tZXRyaWMsYXV0aG9yaXphdGlvbixiaW5hcnksYm90aCxjYXNlLGNhc3QsY2hlY2ssY29sbGF0ZSxjb2xsYXRpb24sY29sdW1uLGNvbmN1cnJlbnRseSxjb25zdHJhaW50LGNyZWF0ZSxjcm9zcyxjdXJyZW50X2NhdGFsb2csY3VycmVudF9kYXRlLGN1cnJlbnRfcm9sZSxjdXJyZW50X3NjaGVtYSxjdXJyZW50X3RpbWUsY3VycmVudF90aW1lc3RhbXAsY3VycmVudF91c2VyLGRlZmF1bHQsZGVmZXJyYWJsZSxkZXNjLGRpc3RpbmN0LGRvLGVsc2UsZW5kLGV4Y2VwdCxmYWxzZSxmZXRjaCxmb3IsZm9yZWlnbixmcmVlemUsZnJvbSxmdWxsLGdyYW50LGdyb3VwLGhhdmluZyxpbGlrZSxpbixpbml0aWFsbHksaW5uZXIsaW50ZXJzZWN0LGludG8saXMsaXNudWxsLGpvaW4sbGF0ZXJhbCxsZWFkaW5nLGxlZnQsbGlrZSxsaW1pdCxsb2NhbHRpbWUsbG9jYWx0aW1lc3RhbXAsbmF0dXJhbCxub3Qsbm90bnVsbCxudWxsLG9mZnNldCxvbixvbmx5LG9yLG9yZGVyLG91dGVyLG92ZXJsYXBzLHBsYWNpbmcscHJpbWFyeSxyZWZlcmVuY2VzLHJldHVybmluZyxyaWdodCxzZWxlY3Qsc2Vzc2lvbl91c2VyLHNpbWlsYXIsc29tZSxzeW1tZXRyaWMsdGFibGUsdGFibGVzYW1wbGUsdGhlbix0byx0cmFpbGluZyx0cnVlLHVuaW9uLHVuaXF1ZSx1c2VyLHVzaW5nLHZhcmlhZGljLHZlcmJvc2Usd2hlbix3aGVyZSx3aW5kb3csd2l0aCcuc3BsaXQoJywnKTtcblxuLyoqXG4gKlxuICogQHBhcmFtIHtzdHJpbmd9ICBkaWFsZWN0ICAgICAgICAgRGlhbGVjdCBuYW1lXG4gKiBAcGFyYW0ge3N0cmluZ30gIGlkZW50aWZpZXIgICAgICBJZGVudGlmaWVyIHRvIHF1b3RlXG4gKiBAcGFyYW0ge09iamVjdH0gIFtvcHRpb25zXVxuICogQHBhcmFtIHtib29sZWFufSBbb3B0aW9ucy5mb3JjZT1mYWxzZV1cbiAqIEBwYXJhbSB7Ym9vbGVhbn0gW29wdGlvbnMucXVvdGVJZGVudGlmaWVycz10cnVlXVxuICpcbiAqIEByZXR1cm5zIHtzdHJpbmd9XG4gKiBAcHJpdmF0ZVxuICovXG5mdW5jdGlvbiBxdW90ZUlkZW50aWZpZXIoZGlhbGVjdCwgaWRlbnRpZmllciwgb3B0aW9ucykge1xuICBpZiAoaWRlbnRpZmllciA9PT0gJyonKSByZXR1cm4gaWRlbnRpZmllcjtcblxuICBvcHRpb25zID0gVXRpbHMuZGVmYXVsdHMob3B0aW9ucyB8fCB7fSwge1xuICAgIGZvcmNlOiBmYWxzZSxcbiAgICBxdW90ZUlkZW50aWZpZXJzOiB0cnVlXG4gIH0pO1xuXG4gIHN3aXRjaCAoZGlhbGVjdCkge1xuICAgIGNhc2UgJ3NxbGl0ZSc6XG4gICAgY2FzZSAnbWFyaWFkYic6XG4gICAgY2FzZSAnbXlzcWwnOlxuICAgICAgcmV0dXJuIFV0aWxzLmFkZFRpY2tzKFV0aWxzLnJlbW92ZVRpY2tzKGlkZW50aWZpZXIsICdgJyksICdgJyk7XG5cbiAgICBjYXNlICdwb3N0Z3Jlcyc6XG4gICAgICBjb25zdCByYXdJZGVudGlmaWVyID0gVXRpbHMucmVtb3ZlVGlja3MoaWRlbnRpZmllciwgJ1wiJyk7XG5cbiAgICAgIGlmIChcbiAgICAgICAgb3B0aW9ucy5mb3JjZSAhPT0gdHJ1ZSAmJlxuICAgICAgICBvcHRpb25zLnF1b3RlSWRlbnRpZmllcnMgPT09IGZhbHNlICYmXG4gICAgICAgICFpZGVudGlmaWVyLmluY2x1ZGVzKCcuJykgJiZcbiAgICAgICAgIWlkZW50aWZpZXIuaW5jbHVkZXMoJy0+JykgJiZcbiAgICAgICAgIXBvc3RncmVzUmVzZXJ2ZWRXb3Jkcy5pbmNsdWRlcyhyYXdJZGVudGlmaWVyLnRvTG93ZXJDYXNlKCkpXG4gICAgICApIHtcbiAgICAgICAgLy8gSW4gUG9zdGdyZXMsIGlmIHRhYmxlcyBvciBhdHRyaWJ1dGVzIGFyZSBjcmVhdGVkIGRvdWJsZS1xdW90ZWQsXG4gICAgICAgIC8vIHRoZXkgYXJlIGFsc28gY2FzZSBzZW5zaXRpdmUuIElmIHRoZXkgY29udGFpbiBhbnkgdXBwZXJjYXNlXG4gICAgICAgIC8vIGNoYXJhY3RlcnMsIHRoZXkgbXVzdCBhbHdheXMgYmUgZG91YmxlLXF1b3RlZC4gVGhpcyBtYWtlcyBpdFxuICAgICAgICAvLyBpbXBvc3NpYmxlIHRvIHdyaXRlIHF1ZXJpZXMgaW4gcG9ydGFibGUgU1FMIGlmIHRhYmxlcyBhcmUgY3JlYXRlZCBpblxuICAgICAgICAvLyB0aGlzIHdheS4gSGVuY2UsIHdlIHN0cmlwIHF1b3RlcyBpZiB3ZSBkb24ndCB3YW50IGNhc2Ugc2Vuc2l0aXZpdHkuXG4gICAgICAgIHJldHVybiByYXdJZGVudGlmaWVyO1xuICAgICAgfVxuICAgICAgcmV0dXJuIFV0aWxzLmFkZFRpY2tzKHJhd0lkZW50aWZpZXIsICdcIicpO1xuICAgIGNhc2UgJ21zc3FsJzpcbiAgICAgIHJldHVybiBgWyR7aWRlbnRpZmllci5yZXBsYWNlKC9bW1xcXSddKy9nLCAnJyl9XWA7XG5cbiAgICBkZWZhdWx0OlxuICAgICAgdGhyb3cgbmV3IEVycm9yKGBEaWFsZWN0IFwiJHtkaWFsZWN0fVwiIGlzIG5vdCBzdXBwb3J0ZWRgKTtcbiAgfVxufVxubW9kdWxlLmV4cG9ydHMucXVvdGVJZGVudGlmaWVyID0gcXVvdGVJZGVudGlmaWVyO1xuXG4vKipcbiAqIFRlc3QgaWYgYSBnaXZlIHN0cmluZyBpcyBhbHJlYWR5IHF1b3RlZFxuICpcbiAqIEBwYXJhbSB7c3RyaW5nfSBpZGVudGlmaWVyXG4gKlxuICogQHJldHVybnMge2Jvb2xlYW59XG4gKiBAcHJpdmF0ZVxuICovXG5mdW5jdGlvbiBpc0lkZW50aWZpZXJRdW90ZWQoaWRlbnRpZmllcikge1xuICByZXR1cm4gL15cXHMqKD86KFtgXCInXSkoPzooPyFcXDEpLnxcXDF7Mn0pKlxcMVxcLj8pK1xccyokL2kudGVzdChpZGVudGlmaWVyKTtcbn1cbm1vZHVsZS5leHBvcnRzLmlzSWRlbnRpZmllclF1b3RlZCA9IGlzSWRlbnRpZmllclF1b3RlZDtcbiJdfQ== \ No newline at end of file diff --git a/dist/dialects/abstract/query-generator/operators.js b/dist/dialects/abstract/query-generator/operators.js index 9a12c78..503608f 100644 --- a/dist/dialects/abstract/query-generator/operators.js +++ b/dist/dialects/abstract/query-generator/operators.js @@ -88,4 +88,4 @@ const OperatorHelpers = { }; module.exports = OperatorHelpers; -//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL2xpYi9kaWFsZWN0cy9hYnN0cmFjdC9xdWVyeS1nZW5lcmF0b3Ivb3BlcmF0b3JzLmpzIl0sIm5hbWVzIjpbIl8iLCJyZXF1aXJlIiwiT3AiLCJVdGlscyIsIk9wZXJhdG9ySGVscGVycyIsIk9wZXJhdG9yTWFwIiwiZXEiLCJuZSIsImd0ZSIsImd0IiwibHRlIiwibHQiLCJub3QiLCJpcyIsImluIiwibm90SW4iLCJsaWtlIiwibm90TGlrZSIsImlMaWtlIiwibm90SUxpa2UiLCJzdGFydHNXaXRoIiwiZW5kc1dpdGgiLCJzdWJzdHJpbmciLCJyZWdleHAiLCJub3RSZWdleHAiLCJpUmVnZXhwIiwibm90SVJlZ2V4cCIsImJldHdlZW4iLCJub3RCZXR3ZWVuIiwib3ZlcmxhcCIsImNvbnRhaW5zIiwiY29udGFpbmVkIiwiYWRqYWNlbnQiLCJzdHJpY3RMZWZ0Iiwic3RyaWN0UmlnaHQiLCJub0V4dGVuZFJpZ2h0Iiwibm9FeHRlbmRMZWZ0IiwiYW55IiwiYWxsIiwiYW5kIiwib3IiLCJjb2wiLCJwbGFjZWhvbGRlciIsIk9wZXJhdG9yc0FsaWFzTWFwIiwic2V0T3BlcmF0b3JzQWxpYXNlcyIsImFsaWFzZXMiLCJpc0VtcHR5IiwiT2JqZWN0IiwiYXNzaWduIiwiX3JlcGxhY2VBbGlhc2VzIiwib3JpZyIsIm9iaiIsImdldE9wZXJhdG9ycyIsImZvckVhY2giLCJvcCIsIml0ZW0iLCJpc1BsYWluT2JqZWN0IiwiZm9yT3duIiwicHJvcCIsIm1vZHVsZSIsImV4cG9ydHMiXSwibWFwcGluZ3MiOiJBQUFBOztBQUVBLE1BQU1BLENBQUMsR0FBR0MsT0FBTyxDQUFDLFFBQUQsQ0FBakI7O0FBQ0EsTUFBTUMsRUFBRSxHQUFHRCxPQUFPLENBQUMsb0JBQUQsQ0FBbEI7O0FBQ0EsTUFBTUUsS0FBSyxHQUFHRixPQUFPLENBQUMsZ0JBQUQsQ0FBckI7O0FBRUEsTUFBTUcsZUFBZSxHQUFHO0FBQ3RCQyxFQUFBQSxXQUFXLEVBQUU7QUFDWCxL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RUFBWjs7QUFDQSxRQUFJLENBQUMsS0FBS1IsaUJBQVYsRUFBNkI7QUFDM0IsYUFBT08sSUFBUDtBQUNEOztBQUVEL0MsSUFBQUEsS0FBSyxDQUFDaUQsWUFBTixDQUFtQkYsSUFBbkIsRUFBeUJHLE9BQXpCLENBQWlDQyxFQUFFLElBQUk7QUFDckMsWUFBTUMsSUFBSSxHQUFHTCxJQUFJLENBQUNJLEVBQUQsQ0FBakI7O0FBQ0EsVUFBSXRELENBQUMsQ0FBQ3dELGFBQUYsQ0FBZ0JELElBQWhCLENBQUosRUFBMkI7QUFDekJKLFFBQUFBLEdBQUcsQ0FBQ0csRUFBRCxDQUFILEdBQVUsS0FBS0wsZUFBTCxDQUFxQk0sSUFBckIsQ0FBVjtBQUNELE9BRkQsTUFFTztBQUNMSixRQUFBQSxHQUFHLENBQUNHLEVBQUQsQ0FBSCxHQUFVQyxJQUFWO0FBQ0Q7QUFDRixLQVBEOztBQVNBdkQsSUFBQUEsQ0FBQyxDQUFDeUQsTUFBRixDQUFTUCxJQUFULEVBQWUsQ0FBQ0ssSUFBRCxFQUFPRyxJQUFQLEtBQWdCO0FBQzdCQSxNQUFBQSxJQUFJLEdBQUcsS0FBS2YsaUJBQUwsQ0FBdUJlLElBQXZCLEtBQWdDQSxJQUF2Qzs7QUFDQSxVQUFJMUQsQ0FBQyxDQUFDd0QsYUFBRixDQUFnQkQsSUFBaEIsQ0FBSixFQUEyQjtBQUN6QkEsUUFBQUEsSUFBSSxHQUFHLEtBQUtOLGVBQUwsQ0FBcUJNLElBQXJCLENBQVA7QUFDRDs7QUFDREosTUFBQUEsR0FBRyxDQUFDTyxJQUFELENBQUgsR0FBWUgsSUFBWjtBQUNELEtBTkQ7O0FBT0EsV0FBT0osR0FBUDtBQUNEOztBQTFFcUIsQ0FBeEI7QUE2RUFRLE1BQU0sQ0FBQ0MsT0FBUCxHQUFpQnhELGVBQWpCIiwic291cmNlc0NvbnRlbnQiOlsiJ3VzZSBzdHJpY3QnO1xyXG5cclxuY29uc3QgXyA9IHJlcXVpcmUoJ2xvZGFzaCcpO1xyXG5jb25zdCBPcCA9IHJlcXVpcmUoJy4uLy4uLy4uL29wZXJhdG9ycycpO1xyXG5jb25zdCBVdGlscyA9IHJlcXVpcmUoJy4uLy4uLy4uL3V0aWxzJyk7XHJcblxyXG5jb25zdCBPcGVyYXRvckhlbHBlcnMgPSB7XHJcbiAgT3BlcmF0b3JNYXA6IHtcclxuICAgIFtPcC5lcV06ICc9JyxcclxuICAgIFtPcC5uZV06ICchPScsXHJcbiAgICBbT3AuZ3RlXTogJz49JyxcclxuICAgIFtPcC5ndF06ICc+JyxcclxuICAgIFtPcC5sdGVdOiAnPD0nLFxyXG4gICAgW09wLmx0XTogJzwnLFxyXG4gICAgW09wLm5vdF06ICdJUyBOT1QnLFxyXG4gICAgW09wLmlzXTogJ0lTJyxcclxuICAgIFtPcC5pbl06ICdJTicsXHJcbiAgICBbT3Aubm90SW5dOiAnTk9UIElOJyxcclxuICAgIFtPcC5saWtlXTogJ0xJS0UnLFxyXG4gICAgW09wLm5vdExpa2VdOiAnTk9UIExJS0UnLFxyXG4gICAgW09wLmlMaWtlXTogJ0lMSUtFJyxcclxuICAgIFtPcC5ub3RJTGlrZV06ICdOT1QgSUxJS0UnLFxyXG4gICAgW09wLnN0YXJ0c1dpdGhdOiAnTElLRScsXHJcbiAgICBbT3AuZW5kc1dpdGhdOiAnTElLRScsXHJcbiAgICBbT3Auc3Vic3RyaW5nXTogJ0xJS0UnLFxyXG4gICAgW09wLnJlZ2V4cF06ICd+JyxcclxuICAgIFtPcC5ub3RSZWdleHBdOiAnIX4nLFxyXG4gICAgW09wLmlSZWdleHBdOiAnfionLFxyXG4gICAgW09wLm5vdElSZWdleHBdOiAnIX4qJyxcclxuICAgIFtPcC5iZXR3ZWVuXTogJ0JFVFdFRU4nLFxyXG4gICAgW09wLm5vdEJldHdlZW5dOiAnTk9UIEJFVFdFRU4nLFxyXG4gICAgW09wLm92ZXJsYXBdOiAnJiYnLFxyXG4gICAgW09wLmNvbnRhaW5zXTogJ0A+JyxcclxuICAgIFtPcC5jb250YWluZWRdOiAnPEAnLFxyXG4gICAgW09wLmFkamFjZW50XTogJy18LScsXHJcbiAgICBbT3Auc3RyaWN0TGVmdF06ICc8PCcsXHJcbiAgICBbT3Auc3RyaWN0UmlnaHRdOiAnPj4nLFxyXG4gICAgW09wLm5vRXh0ZW5kUmlnaHRdOiAnJjwnLFxyXG4gICAgW09wLm5vRXh0ZW5kTGVmdF06ICcmPicsXHJcbiAgICBbT3AuYW55XTogJ0FOWScsXHJcbiAgICBbT3AuYWxsXTogJ0FMTCcsXHJcbiAgICBbT3AuYW5kXTogJyBBTkQgJyxcclxuICAgIFtPcC5vcl06ICcgT1IgJyxcclxuICAgIFtPcC5jb2xdOiAnQ09MJyxcclxuICAgIFtPcC5wbGFjZWhvbGRlcl06ICckJFBMQUNFSE9MREVSJCQnXHJcbiAgfSxcclxuXHJcbiAgT3BlcmF0b3JzQWxpYXNNYXA6IHt9LFxyXG5cclxuICBzZXRPcGVyYXRvcnNBbGlhc2VzKGFsaWFzZXMpIHtcclxuICAgIGlmICghYWxpYXNlcyB8fCBfLmlzRW1wdHkoYWxpYXNlcykpIHtcclxuICAgICAgdGhpcy5PcGVyYXRvcnNBbGlhc01hcCA9IGZhbHNlO1xyXG4gICAgfSBlbHNlIHtcclxuICAgICAgdGhpcy5PcGVyYXRvcnNBbGlhc01hcCA9IE9iamVjdC5hc3NpZ24oe30sIGFsaWFzZXMpO1xyXG4gICAgfVxyXG4gIH0sXHJcblxyXG4gIF9yZXBsYWNlQWxpYXNlcyhvcmlnKSB7XHJcbiAgICBjb25zdCBvYmogPSB7fTtcclxuICAgIGlmICghdGhpcy5PcGVyYXRvcnNBbGlhc01hcCkge1xyXG4gICAgICByZXR1cm4gb3JpZztcclxuICAgIH1cclxuXHJcbiAgICBVdGlscy5nZXRPcGVyYXRvcnMob3JpZykuZm9yRWFjaChvcCA9PiB7XHJcbiAgICAgIGNvbnN0IGl0ZW0gPSBvcmlnW29wXTtcclxuICAgICAgaWYgKF8uaXNQbGFpbk9iamVjdChpdGVtKSkge1xyXG4gICAgICAgIG9ialtvcF0gPSB0aGlzLl9yZXBsYWNlQWxpYXNlcyhpdGVtKTtcclxuICAgICAgfSBlbHNlIHtcclxuICAgICAgICBvYmpbb3BdID0gaXRlbTtcclxuICAgICAgfVxyXG4gICAgfSk7XHJcblxyXG4gICAgXy5mb3JPd24ob3JpZywgKGl0ZW0sIHByb3ApID0+IHtcclxuICAgICAgcHJvcCA9IHRoaXMuT3BlcmF0b3JzQWxpYXNNYXBbcHJvcF0gfHwgcHJvcDtcclxuICAgICAgaWYgKF8uaXNQbGFpbk9iamVjdChpdGVtKSkge1xyXG4gICAgICAgIGl0ZW0gPSB0aGlzLl9yZXBsYWNlQWxpYXNlcyhpdGVtKTtcclxuICAgICAgfVxyXG4gICAgICBvYmpbcHJvcF0gPSBpdGVtO1xyXG4gICAgfSk7XHJcbiAgICByZXR1cm4gb2JqO1xyXG4gIH1cclxufTtcclxuXHJcbm1vZHVsZS5leHBvcnRzID0gT3BlcmF0b3JIZWxwZXJzO1xyXG4iXX0= \ No newline at end of file +//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL2xpYi9kaWFsZWN0cy9hYnN0cmFjdC9xdWVyeS1nZW5lcmF0b3Ivb3BlcmF0b3JzLmpzIl0sIm5hbWVzIjpbIl8iLCJyZXF1aXJlIiwiT3AiLCJVdGlscyIsIk9wZXJhdG9ySGVscGVycyIsIk9wZXJhdG9yTWFwIiwiZXEiLCJuZSIsImd0ZSIsImd0IiwibHRlIiwibHQiLCJub3QiLCJpcyIsImluIiwibm90SW4iLCJsaWtlIiwibm90TGlrZSIsImlMaWtlIiwibm90SUxpa2UiLCJzdGFydHNXaXRoIiwiZW5kc1dpdGgiLCJzdWJzdHJpbmciLCJyZWdleHAiLCJub3RSZWdleHAiLCJpUmVnZXhwIiwibm90SVJlZ2V4cCIsImJldHdlZW4iLCJub3RCZXR3ZWVuIiwib3ZlcmxhcCIsImNvbnRhaW5zIiwiY29udGFpbmVkIiwiYWRqYWNlbnQiLCJzdHJpY3RMZWZ0Iiwic3RyaWN0UmlnaHQiLCJub0V4dGVuZFJpZ2h0Iiwibm9FeHRlbmRMZWZ0IiwiYW55IiwiYWxsIiwiYW5kIiwib3IiLCJjb2wiLCJwbGFjZWhvbGRlciIsIk9wZXJhdG9yc0FsaWFzTWFwIiwic2V0T3BlcmF0b3JzQWxpYXNlcyIsImFsaWFzZXMiLCJpc0VtcHR5IiwiT2JqZWN0IiwiYXNzaWduIiwiX3JlcGxhY2VBbGlhc2VzIiwib3JpZyIsIm9iaiIsImdldE9wZXJhdG9ycyIsImZvckVhY2giLCJvcCIsIml0ZW0iLCJpc1BsYWluT2JqZWN0IiwiZm9yT3duIiwicHJvcCIsIm1vZHVsZSIsImV4cG9ydHMiXSwibWFwcGluZ3MiOiJBQUFBOztBQUVBLE1BQU1BLENBQUMsR0FBR0MsT0FBTyxDQUFDLFFBQUQsQ0FBakI7O0FBQ0EsTUFBTUMsRUFBRSxHQUFHRCxPQUFPLENBQUMsb0JBQUQsQ0FBbEI7O0FBQ0EsTUFBTUUsS0FBSyxHQUFHRixPQUFPLENBQUMsZ0JBQUQsQ0FBckI7O0FBRUEsTUFBTUcsZUFBZSxHQUFHO0FBQ3RCQyxFQUFBQSxXQUFXLEVBQUU7QUFDWCxLQUFDSCxFQUFFLENBQUNJLEVBQUosR0FBUyxHQURFO0FBRVgsS0FBQ0osRUFBRSxDQUFDSyxFQUFKLEdBQVMsSUFGRTtBQUdYLEtBQUNMLEVBQUUsQ0FBQ00sR0FBSixHQUFVLElBSEM7QUFJWCxLQUFDTixFQUFFLENBQUNPLEVBQUosR0FBUyxHQUpFO0FBS1gsS0FBQ1AsRUFBRSxDQUFDUSxHQUFKLEdBQVUsSUFMQztBQU1YLEtBQUNSLEVBQUUsQ0FBQ1MsRUFBSixHQUFTLEdBTkU7QUFPWCxLQUFDVCxFQUFFLENBQUNVLEdBQUosR0FBVSxRQVBDO0FBUVgsS0FBQ1YsRUFBRSxDQUFDVyxFQUFKLEdBQVMsSUFSRTtBQVNYLEtBQUNYLEVBQUUsQ0FBQ1ksRUFBSixHQUFTLElBVEU7QUFVWCxLQUFDWixFQUFFLENBQUNhLEtBQUosR0FBWSxRQVZEO0FBV1gsS0FBQ2IsRUFBRSxDQUFDYyxJQUFKLEdBQVcsTUFYQTtBQVlYLEtBQUNkLEVBQUUsQ0FBQ2UsT0FBSixHQUFjLFVBWkg7QUFhWCxLQUFDZixFQUFFLENBQUNnQixLQUFKLEdBQVksT0FiRDtBQWNYLEtBQUNoQixFQUFFLENBQUNpQixRQUFKLEdBQWUsV0FkSjtBQWVYLEtBQUNqQixFQUFFLENBQUNrQixVQUFKLEdBQWlCLE1BZk47QUFnQlgsS0FBQ2xCLEVBQUUsQ0FBQ21CLFFBQUosR0FBZSxNQWhCSjtBQWlCWCxLQUFDbkIsRUFBRSxDQUFDb0IsU0FBSixHQUFnQixNQWpCTDtBQWtCWCxLQUFDcEIsRUFBRSxDQUFDcUIsTUFBSixHQUFhLEdBbEJGO0FBbUJYLEtBQUNyQixFQUFFLENBQUNzQixTQUFKLEdBQWdCLElBbkJMO0FBb0JYLEtBQUN0QixFQUFFLENBQUN1QixPQUFKLEdBQWMsSUFwQkg7QUFxQlgsS0FBQ3ZCLEVBQUUsQ0FBQ3dCLFVBQUosR0FBaUIsS0FyQk47QUFzQlgsS0FBQ3hCLEVBQUUsQ0FBQ3lCLE9BQUosR0FBYyxTQXRCSDtBQXVCWCxLQUFDekIsRUFBRSxDQUFDMEIsVUFBSixHQUFpQixhQXZCTjtBQXdCWCxLQUFDMUIsRUFBRSxDQUFDMkIsT0FBSixHQUFjLElBeEJIO0FBeUJYLEtBQUMzQixFQUFFLENBQUM0QixRQUFKLEdBQWUsSUF6Qko7QUEwQlgsS0FBQzVCLEVBQUUsQ0FBQzZCLFNBQUosR0FBZ0IsSUExQkw7QUEyQlgsS0FBQzdCLEVBQUUsQ0FBQzhCLFFBQUosR0FBZSxLQTNCSjtBQTRCWCxLQUFDOUIsRUFBRSxDQUFDK0IsVUFBSixHQUFpQixJQTVCTjtBQTZCWCxLQUFDL0IsRUFBRSxDQUFDZ0MsV0FBSixHQUFrQixJQTdCUDtBQThCWCxLQUFDaEMsRUFBRSxDQUFDaUMsYUFBSixHQUFvQixJQTlCVDtBQStCWCxLQUFDakMsRUFBRSxDQUFDa0MsWUFBSixHQUFtQixJQS9CUjtBQWdDWCxLQUFDbEMsRUFBRSxDQUFDbUMsR0FBSixHQUFVLEtBaENDO0FBaUNYLEtBQUNuQyxFQUFFLENBQUNvQyxHQUFKLEdBQVUsS0FqQ0M7QUFrQ1gsS0FBQ3BDLEVBQUUsQ0FBQ3FDLEdBQUosR0FBVSxPQWxDQztBQW1DWCxLQUFDckMsRUFBRSxDQUFDc0MsRUFBSixHQUFTLE1BbkNFO0FBb0NYLEtBQUN0QyxFQUFFLENBQUN1QyxHQUFKLEdBQVUsS0FwQ0M7QUFxQ1gsS0FBQ3ZDLEVBQUUsQ0FBQ3dDLFdBQUosR0FBa0I7QUFyQ1AsR0FEUztBQXlDdEJDLEVBQUFBLGlCQUFpQixFQUFFLEVBekNHOztBQTJDdEJDLEVBQUFBLG1CQUFtQixDQUFDQyxPQUFELEVBQVU7QUFDM0IsUUFBSSxDQUFDQSxPQUFELElBQVk3QyxDQUFDLENBQUM4QyxPQUFGLENBQVVELE9BQVYsQ0FBaEIsRUFBb0M7QUFDbEMsV0FBS0YsaUJBQUwsR0FBeUIsS0FBekI7QUFDRCxLQUZELE1BRU87QUFDTCxXQUFLQSxpQkFBTCxHQUF5QkksTUFBTSxDQUFDQyxNQUFQLENBQWMsRUFBZCxFQUFrQkgsT0FBbEIsQ0FBekI7QUFDRDtBQUNGLEdBakRxQjs7QUFtRHRCSSxFQUFBQSxlQUFlLENBQUNDLElBQUQsRUFBTztBQUNwQixVQUFNQyxHQUFHLEdBQUcsRUFBWjs7QUFDQSxRQUFJLENBQUMsS0FBS1IsaUJBQVYsRUFBNkI7QUFDM0IsYUFBT08sSUFBUDtBQUNEOztBQUVEL0MsSUFBQUEsS0FBSyxDQUFDaUQsWUFBTixDQUFtQkYsSUFBbkIsRUFBeUJHLE9BQXpCLENBQWlDQyxFQUFFLElBQUk7QUFDckMsWUFBTUMsSUFBSSxHQUFHTCxJQUFJLENBQUNJLEVBQUQsQ0FBakI7O0FBQ0EsVUFBSXRELENBQUMsQ0FBQ3dELGFBQUYsQ0FBZ0JELElBQWhCLENBQUosRUFBMkI7QUFDekJKLFFBQUFBLEdBQUcsQ0FBQ0csRUFBRCxDQUFILEdBQVUsS0FBS0wsZUFBTCxDQUFxQk0sSUFBckIsQ0FBVjtBQUNELE9BRkQsTUFFTztBQUNMSixRQUFBQSxHQUFHLENBQUNHLEVBQUQsQ0FBSCxHQUFVQyxJQUFWO0FBQ0Q7QUFDRixLQVBEOztBQVNBdkQsSUFBQUEsQ0FBQyxDQUFDeUQsTUFBRixDQUFTUCxJQUFULEVBQWUsQ0FBQ0ssSUFBRCxFQUFPRyxJQUFQLEtBQWdCO0FBQzdCQSxNQUFBQSxJQUFJLEdBQUcsS0FBS2YsaUJBQUwsQ0FBdUJlLElBQXZCLEtBQWdDQSxJQUF2Qzs7QUFDQSxVQUFJMUQsQ0FBQyxDQUFDd0QsYUFBRixDQUFnQkQsSUFBaEIsQ0FBSixFQUEyQjtBQUN6QkEsUUFBQUEsSUFBSSxHQUFHLEtBQUtOLGVBQUwsQ0FBcUJNLElBQXJCLENBQVA7QUFDRDs7QUFDREosTUFBQUEsR0FBRyxDQUFDTyxJQUFELENBQUgsR0FBWUgsSUFBWjtBQUNELEtBTkQ7O0FBT0EsV0FBT0osR0FBUDtBQUNEOztBQTFFcUIsQ0FBeEI7QUE2RUFRLE1BQU0sQ0FBQ0MsT0FBUCxHQUFpQnhELGVBQWpCIiwic291cmNlc0NvbnRlbnQiOlsiJ3VzZSBzdHJpY3QnO1xuXG5jb25zdCBfID0gcmVxdWlyZSgnbG9kYXNoJyk7XG5jb25zdCBPcCA9IHJlcXVpcmUoJy4uLy4uLy4uL29wZXJhdG9ycycpO1xuY29uc3QgVXRpbHMgPSByZXF1aXJlKCcuLi8uLi8uLi91dGlscycpO1xuXG5jb25zdCBPcGVyYXRvckhlbHBlcnMgPSB7XG4gIE9wZXJhdG9yTWFwOiB7XG4gICAgW09wLmVxXTogJz0nLFxuICAgIFtPcC5uZV06ICchPScsXG4gICAgW09wLmd0ZV06ICc+PScsXG4gICAgW09wLmd0XTogJz4nLFxuICAgIFtPcC5sdGVdOiAnPD0nLFxuICAgIFtPcC5sdF06ICc8JyxcbiAgICBbT3Aubm90XTogJ0lTIE5PVCcsXG4gICAgW09wLmlzXTogJ0lTJyxcbiAgICBbT3AuaW5dOiAnSU4nLFxuICAgIFtPcC5ub3RJbl06ICdOT1QgSU4nLFxuICAgIFtPcC5saWtlXTogJ0xJS0UnLFxuICAgIFtPcC5ub3RMaWtlXTogJ05PVCBMSUtFJyxcbiAgICBbT3AuaUxpa2VdOiAnSUxJS0UnLFxuICAgIFtPcC5ub3RJTGlrZV06ICdOT1QgSUxJS0UnLFxuICAgIFtPcC5zdGFydHNXaXRoXTogJ0xJS0UnLFxuICAgIFtPcC5lbmRzV2l0aF06ICdMSUtFJyxcbiAgICBbT3Auc3Vic3RyaW5nXTogJ0xJS0UnLFxuICAgIFtPcC5yZWdleHBdOiAnficsXG4gICAgW09wLm5vdFJlZ2V4cF06ICchficsXG4gICAgW09wLmlSZWdleHBdOiAnfionLFxuICAgIFtPcC5ub3RJUmVnZXhwXTogJyF+KicsXG4gICAgW09wLmJldHdlZW5dOiAnQkVUV0VFTicsXG4gICAgW09wLm5vdEJldHdlZW5dOiAnTk9UIEJFVFdFRU4nLFxuICAgIFtPcC5vdmVybGFwXTogJyYmJyxcbiAgICBbT3AuY29udGFpbnNdOiAnQD4nLFxuICAgIFtPcC5jb250YWluZWRdOiAnPEAnLFxuICAgIFtPcC5hZGphY2VudF06ICctfC0nLFxuICAgIFtPcC5zdHJpY3RMZWZ0XTogJzw8JyxcbiAgICBbT3Auc3RyaWN0UmlnaHRdOiAnPj4nLFxuICAgIFtPcC5ub0V4dGVuZFJpZ2h0XTogJyY8JyxcbiAgICBbT3Aubm9FeHRlbmRMZWZ0XTogJyY+JyxcbiAgICBbT3AuYW55XTogJ0FOWScsXG4gICAgW09wLmFsbF06ICdBTEwnLFxuICAgIFtPcC5hbmRdOiAnIEFORCAnLFxuICAgIFtPcC5vcl06ICcgT1IgJyxcbiAgICBbT3AuY29sXTogJ0NPTCcsXG4gICAgW09wLnBsYWNlaG9sZGVyXTogJyQkUExBQ0VIT0xERVIkJCdcbiAgfSxcblxuICBPcGVyYXRvcnNBbGlhc01hcDoge30sXG5cbiAgc2V0T3BlcmF0b3JzQWxpYXNlcyhhbGlhc2VzKSB7XG4gICAgaWYgKCFhbGlhc2VzIHx8IF8uaXNFbXB0eShhbGlhc2VzKSkge1xuICAgICAgdGhpcy5PcGVyYXRvcnNBbGlhc01hcCA9IGZhbHNlO1xuICAgIH0gZWxzZSB7XG4gICAgICB0aGlzLk9wZXJhdG9yc0FsaWFzTWFwID0gT2JqZWN0LmFzc2lnbih7fSwgYWxpYXNlcyk7XG4gICAgfVxuICB9LFxuXG4gIF9yZXBsYWNlQWxpYXNlcyhvcmlnKSB7XG4gICAgY29uc3Qgb2JqID0ge307XG4gICAgaWYgKCF0aGlzLk9wZXJhdG9yc0FsaWFzTWFwKSB7XG4gICAgICByZXR1cm4gb3JpZztcbiAgICB9XG5cbiAgICBVdGlscy5nZXRPcGVyYXRvcnMob3JpZykuZm9yRWFjaChvcCA9PiB7XG4gICAgICBjb25zdCBpdGVtID0gb3JpZ1tvcF07XG4gICAgICBpZiAoXy5pc1BsYWluT2JqZWN0KGl0ZW0pKSB7XG4gICAgICAgIG9ialtvcF0gPSB0aGlzLl9yZXBsYWNlQWxpYXNlcyhpdGVtKTtcbiAgICAgIH0gZWxzZSB7XG4gICAgICAgIG9ialtvcF0gPSBpdGVtO1xuICAgICAgfVxuICAgIH0pO1xuXG4gICAgXy5mb3JPd24ob3JpZywgKGl0ZW0sIHByb3ApID0+IHtcbiAgICAgIHByb3AgPSB0aGlzLk9wZXJhdG9yc0FsaWFzTWFwW3Byb3BdIHx8IHByb3A7XG4gICAgICBpZiAoXy5pc1BsYWluT2JqZWN0KGl0ZW0pKSB7XG4gICAgICAgIGl0ZW0gPSB0aGlzLl9yZXBsYWNlQWxpYXNlcyhpdGVtKTtcbiAgICAgIH1cbiAgICAgIG9ialtwcm9wXSA9IGl0ZW07XG4gICAgfSk7XG4gICAgcmV0dXJuIG9iajtcbiAgfVxufTtcblxubW9kdWxlLmV4cG9ydHMgPSBPcGVyYXRvckhlbHBlcnM7XG4iXX0= \ No newline at end of file diff --git a/dist/dialects/abstract/query-generator/transaction.js b/dist/dialects/abstract/query-generator/transaction.js index 9abfdb5..95efae2 100644 --- a/dist/dialects/abstract/query-generator/transaction.js +++ b/dist/dialects/abstract/query-generator/transaction.js @@ -80,4 +80,4 @@ const TransactionQueries = { }; module.exports = TransactionQueries; -//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL2xpYi9kaWFsZWN0cy9hYnN0cmFjdC9xdWVyeS1nZW5lcmF0b3IvdHJhbnNhY3Rpb24uanMiXSwibmFtZXMiOlsidXVpZHY0IiwicmVxdWlyZSIsIlRyYW5zYWN0aW9uUXVlcmllcyIsInNldElzb2xhdGlvbkxldmVsUXVlcnkiLCJ2YWx1ZSIsIm9wdGlvbnMiLCJwYXJlbnQiLCJnZW5lcmF0ZVRyYW5zYWN0aW9uSWQiLCJzdGFydFRyYW5zYWN0aW9uUXVlcnkiLCJ0cmFuc2FjdGlvbiIsInF1b3RlSWRlbnRpZmllciIsIm5hbWUiLCJkZWZlckNvbnN0cmFpbnRzUXVlcnkiLCJzZXRDb25zdHJhaW50UXVlcnkiLCJzZXREZWZlcnJlZFF1ZXJ5Iiwic2V0SW1tZWRpYXRlUXVlcnkiLCJjb21taXRUcmFuc2FjdGlvblF1ZXJ5Iiwicm9sbGJhY2tUcmFuc2FjdGlvblF1ZXJ5IiwibW9kdWxlIiwiZXhwb3J0cyJdLCJtYXBwaW5ncyI6IkFBQUE7O0FBRUEsTUFBTUEsTUFBTSxHQUFHQyxPQUFPLENBQUMsU0FBRCxDQUF0Qjs7QUFFQSxNQUFNQyxrQkFBa0IsR0FBRztBQUN6Qjs7Ozs7Ozs7QUFRQUMsRUFBQUEsc0JBQXNCLENBQUNDLEtBQUQsRUFBUUMsT0FBUixFQUFpQjtBQUNyQyxRQUFJQSxPQUFPLENBQUNDLE1BQVosRUFBb0I7QUFDbEI7QUFDRDs7QUFFRCxXQUFRLG1DQUFrQ0YsS0FBTSxHQUFoRDtBQUNELEdBZndCOztBQWlCekJHLEVBQUFBLHFCQUFxQixHQUFHO0FBQ3RCLFdBQU9QLE1BQU0sRUFBYjtBQUNELEdBbkJ3Qjs7QUFxQnpCOzs7Ozs7O0FBT0FRLEVBQUFBLHFCQUFxQixDQUFDQyxXQUFELEVBQWM7QUFDakMsUUFBSUEsV0FBVyxDQUFDSCxNQUFoQixFQUF3QjtBQUN0QjtBQUNBLGFBQVEsYUFBWSxLQUFLSSxlQUFMLENBQXFCRCxXQUFXLENBQUNFLElBQWpDLEVBQXVDLElBQXZDLENBQTZDLEdBQWpFO0FBQ0Q7O0FBRUQsV0FBTyxvQkFBUDtBQUNELEdBbkN3Qjs7QUFxQ3pCQyxFQUFBQSxxQkFBcUIsR0FBRyxDQUFFLENBckNEOztBQXVDekJDLEVBQUFBLGtCQUFrQixHQUFHLENBQUUsQ0F2Q0U7O0FBd0N6QkMsRUFBQUEsZ0JBQWdCLEdBQUcsQ0FBRSxDQXhDSTs7QUF5Q3pCQyxFQUFBQSxpQkFBaUIsR0FBRyxDQUFFLENBekNHOztBQTJDekI7Ozs7Ozs7QUFPQUMsRUFBQUEsc0JBQXNCLENBQUNQLFdBQUQsRUFBYztBQUNsQyxRQUFJQSxXQUFXLENBQUNILE1BQWhCLEVBQXdCO0FBQ3RCO0FBQ0Q7O0FBRUQsV0FBTyxTQUFQO0FBQ0QsR0F4RHdCOztBQTBEekI7Ozs7Ozs7QUFPQVcsRUFBQUEsd0JBQXdCLENBQUNSLFdBQUQsRUFBYztBQUNwQyxRQUFJQSxXQUFXLENBQUNILE1BQWhCLEVBQXdCO0FBQ3RCO0FBQ0EsYUFBUSx5QkFBd0IsS0FBS0ksZUFBTCxDQUFxQkQsV0FBVyxDQUFDRSxJQUFqQyxFQUF1QyxJQUF2QyxDQUE2QyxHQUE3RTtBQUNEOztBQUVELFdBQU8sV0FBUDtBQUNEOztBQXhFd0IsQ0FBM0I7QUEyRUFPLE1BQU0sQ0FBQ0MsT0FBUCxHQUFpQmpCLGtCQUFqQiIsInNvdXJjZXNDb250ZW50IjpbIid1c2Ugc3RyaWN0JztcclxuXHJcbmNvbnN0IHV1aWR2NCA9IHJlcXVpcmUoJ3V1aWQvdjQnKTtcclxuXHJcbmNvbnN0IFRyYW5zYWN0aW9uUXVlcmllcyA9IHtcclxuICAvKipcclxuICAgKiBSZXR1cm5zIGEgcXVlcnkgdGhhdCBzZXRzIHRoZSB0cmFuc2FjdGlvbiBpc29sYXRpb24gbGV2ZWwuXHJcbiAgICpcclxuICAgKiBAcGFyYW0gIHtzdHJpbmd9IHZhbHVlICAgVGhlIGlzb2xhdGlvbiBsZXZlbC5cclxuICAgKiBAcGFyYW0gIHtPYmplY3R9IG9wdGlvbnMgQW4gb2JqZWN0IHdpdGggb3B0aW9ucy5cclxuICAgKiBAcmV0dXJucyB7c3RyaW5nfSAgICAgICAgIFRoZSBnZW5lcmF0ZWQgc3FsIHF1ZXJ5LlxyXG4gICAqIEBwcml2YXRlXHJcbiAgICovXHJcbiAgc2V0SXNvbGF0aW9uTGV2ZWxRdWVyeSh2YWx1ZSwgb3B0aW9ucykge1xyXG4gICAgaWYgKG9wdGlvbnMucGFyZW50KSB7XHJcbiAgICAgIHJldHVybjtcclxuICAgIH1cclxuXHJcbiAgICByZXR1cm4gYFNFVCBUUkFOU0FDVElPTiBJU09MQVRJT04gTEVWRUwgJHt2YWx1ZX07YDtcclxuICB9LFxyXG5cclxuICBnZW5lcmF0ZVRyYW5zYWN0aW9uSWQoKSB7XHJcbiAgICByZXR1cm4gdXVpZHY0KCk7XHJcbiAgfSxcclxuXHJcbiAgLyoqXHJcbiAgICogUmV0dXJucyBhIHF1ZXJ5IHRoYXQgc3RhcnRzIGEgdHJhbnNhY3Rpb24uXHJcbiAgICpcclxuICAgKiBAcGFyYW0gIHtUcmFuc2FjdGlvbn0gdHJhbnNhY3Rpb25cclxuICAgKiBAcmV0dXJucyB7c3RyaW5nfSAgICAgICAgIFRoZSBnZW5lcmF0ZWQgc3FsIHF1ZXJ5LlxyXG4gICAqIEBwcml2YXRlXHJcbiAgICovXHJcbiAgc3RhcnRUcmFuc2FjdGlvblF1ZXJ5KHRyYW5zYWN0aW9uKSB7XHJcbiAgICBpZiAodHJhbnNhY3Rpb24ucGFyZW50KSB7XHJcbiAgICAgIC8vIGZvcmNlIHF1b3Rpbmcgb2Ygc2F2ZXBvaW50IGlkZW50aWZpZXJzIGZvciBwb3N0Z3Jlc1xyXG4gICAgICByZXR1cm4gYFNBVkVQT0lOVCAke3RoaXMucXVvdGVJZGVudGlmaWVyKHRyYW5zYWN0aW9uLm5hbWUsIHRydWUpfTtgO1xyXG4gICAgfVxyXG5cclxuICAgIHJldHVybiAnU1RBUlQgVFJBTlNBQ1RJT047JztcclxuICB9LFxyXG5cclxuICBkZWZlckNvbnN0cmFpbnRzUXVlcnkoKSB7fSxcclxuXHJcbiAgc2V0Q29uc3RyYWludFF1ZXJ5KCkge30sXHJcbiAgc2V0RGVmZXJyZWRRdWVyeSgpIHt9LFxyXG4gIHNldEltbWVkaWF0ZVF1ZXJ5KCkge30sXHJcblxyXG4gIC8qKlxyXG4gICAqIFJldHVybnMgYSBxdWVyeSB0aGF0IGNvbW1pdHMgYSB0cmFuc2FjdGlvbi5cclxuICAgKlxyXG4gICAqIEBwYXJhbSAge1RyYW5zYWN0aW9ufSB0cmFuc2FjdGlvbiBBbiBvYmplY3Qgd2l0aCBvcHRpb25zLlxyXG4gICAqIEByZXR1cm5zIHtzdHJpbmd9ICAgICAgICAgVGhlIGdlbmVyYXRlZCBzcWwgcXVlcnkuXHJcbiAgICogQHByaXZhdGVcclxuICAgKi9cclxuICBjb21taXRUcmFuc2FjdGlvblF1ZXJ5KHRyYW5zYWN0aW9uKSB7XHJcbiAgICBpZiAodHJhbnNhY3Rpb24ucGFyZW50KSB7XHJcbiAgICAgIHJldHVybjtcclxuICAgIH1cclxuXHJcbiAgICByZXR1cm4gJ0NPTU1JVDsnO1xyXG4gIH0sXHJcblxyXG4gIC8qKlxyXG4gICAqIFJldHVybnMgYSBxdWVyeSB0aGF0IHJvbGxiYWNrcyBhIHRyYW5zYWN0aW9uLlxyXG4gICAqXHJcbiAgICogQHBhcmFtICB7VHJhbnNhY3Rpb259IHRyYW5zYWN0aW9uXHJcbiAgICogQHJldHVybnMge3N0cmluZ30gICAgICAgICBUaGUgZ2VuZXJhdGVkIHNxbCBxdWVyeS5cclxuICAgKiBAcHJpdmF0ZVxyXG4gICAqL1xyXG4gIHJvbGxiYWNrVHJhbnNhY3Rpb25RdWVyeSh0cmFuc2FjdGlvbikge1xyXG4gICAgaWYgKHRyYW5zYWN0aW9uLnBhcmVudCkge1xyXG4gICAgICAvLyBmb3JjZSBxdW90aW5nIG9mIHNhdmVwb2ludCBpZGVudGlmaWVycyBmb3IgcG9zdGdyZXNcclxuICAgICAgcmV0dXJuIGBST0xMQkFDSyBUTyBTQVZFUE9JTlQgJHt0aGlzLnF1b3RlSWRlbnRpZmllcih0cmFuc2FjdGlvbi5uYW1lLCB0cnVlKX07YDtcclxuICAgIH1cclxuXHJcbiAgICByZXR1cm4gJ1JPTExCQUNLOyc7XHJcbiAgfVxyXG59O1xyXG5cclxubW9kdWxlLmV4cG9ydHMgPSBUcmFuc2FjdGlvblF1ZXJpZXM7XHJcbiJdfQ== \ No newline at end of file +//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL2xpYi9kaWFsZWN0cy9hYnN0cmFjdC9xdWVyeS1nZW5lcmF0b3IvdHJhbnNhY3Rpb24uanMiXSwibmFtZXMiOlsidXVpZHY0IiwicmVxdWlyZSIsIlRyYW5zYWN0aW9uUXVlcmllcyIsInNldElzb2xhdGlvbkxldmVsUXVlcnkiLCJ2YWx1ZSIsIm9wdGlvbnMiLCJwYXJlbnQiLCJnZW5lcmF0ZVRyYW5zYWN0aW9uSWQiLCJzdGFydFRyYW5zYWN0aW9uUXVlcnkiLCJ0cmFuc2FjdGlvbiIsInF1b3RlSWRlbnRpZmllciIsIm5hbWUiLCJkZWZlckNvbnN0cmFpbnRzUXVlcnkiLCJzZXRDb25zdHJhaW50UXVlcnkiLCJzZXREZWZlcnJlZFF1ZXJ5Iiwic2V0SW1tZWRpYXRlUXVlcnkiLCJjb21taXRUcmFuc2FjdGlvblF1ZXJ5Iiwicm9sbGJhY2tUcmFuc2FjdGlvblF1ZXJ5IiwibW9kdWxlIiwiZXhwb3J0cyJdLCJtYXBwaW5ncyI6IkFBQUE7O0FBRUEsTUFBTUEsTUFBTSxHQUFHQyxPQUFPLENBQUMsU0FBRCxDQUF0Qjs7QUFFQSxNQUFNQyxrQkFBa0IsR0FBRztBQUN6QjtBQUNGO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0VDLEVBQUFBLHNCQUFzQixDQUFDQyxLQUFELEVBQVFDLE9BQVIsRUFBaUI7QUFDckMsUUFBSUEsT0FBTyxDQUFDQyxNQUFaLEVBQW9CO0FBQ2xCO0FBQ0Q7O0FBRUQsV0FBUSxtQ0FBa0NGLEtBQU0sR0FBaEQ7QUFDRCxHQWZ3Qjs7QUFpQnpCRyxFQUFBQSxxQkFBcUIsR0FBRztBQUN0QixXQUFPUCxNQUFNLEVBQWI7QUFDRCxHQW5Cd0I7O0FBcUJ6QjtBQUNGO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNFUSxFQUFBQSxxQkFBcUIsQ0FBQ0MsV0FBRCxFQUFjO0FBQ2pDLFFBQUlBLFdBQVcsQ0FBQ0gsTUFBaEIsRUFBd0I7QUFDdEI7QUFDQSxhQUFRLGFBQVksS0FBS0ksZUFBTCxDQUFxQkQsV0FBVyxDQUFDRSxJQUFqQyxFQUF1QyxJQUF2QyxDQUE2QyxHQUFqRTtBQUNEOztBQUVELFdBQU8sb0JBQVA7QUFDRCxHQW5Dd0I7O0FBcUN6QkMsRUFBQUEscUJBQXFCLEdBQUcsQ0FBRSxDQXJDRDs7QUF1Q3pCQyxFQUFBQSxrQkFBa0IsR0FBRyxDQUFFLENBdkNFOztBQXdDekJDLEVBQUFBLGdCQUFnQixHQUFHLENBQUUsQ0F4Q0k7O0FBeUN6QkMsRUFBQUEsaUJBQWlCLEdBQUcsQ0FBRSxDQXpDRzs7QUEyQ3pCO0FBQ0Y7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0VDLEVBQUFBLHNCQUFzQixDQUFDUCxXQUFELEVBQWM7QUFDbEMsUUFBSUEsV0FBVyxDQUFDSCxNQUFoQixFQUF3QjtBQUN0QjtBQUNEOztBQUVELFdBQU8sU0FBUDtBQUNELEdBeER3Qjs7QUEwRHpCO0FBQ0Y7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0VXLEVBQUFBLHdCQUF3QixDQUFDUixXQUFELEVBQWM7QUFDcEMsUUFBSUEsV0FBVyxDQUFDSCxNQUFoQixFQUF3QjtBQUN0QjtBQUNBLGFBQVEseUJBQXdCLEtBQUtJLGVBQUwsQ0FBcUJELFdBQVcsQ0FBQ0UsSUFBakMsRUFBdUMsSUFBdkMsQ0FBNkMsR0FBN0U7QUFDRDs7QUFFRCxXQUFPLFdBQVA7QUFDRDs7QUF4RXdCLENBQTNCO0FBMkVBTyxNQUFNLENBQUNDLE9BQVAsR0FBaUJqQixrQkFBakIiLCJzb3VyY2VzQ29udGVudCI6WyIndXNlIHN0cmljdCc7XG5cbmNvbnN0IHV1aWR2NCA9IHJlcXVpcmUoJ3V1aWQvdjQnKTtcblxuY29uc3QgVHJhbnNhY3Rpb25RdWVyaWVzID0ge1xuICAvKipcbiAgICogUmV0dXJucyBhIHF1ZXJ5IHRoYXQgc2V0cyB0aGUgdHJhbnNhY3Rpb24gaXNvbGF0aW9uIGxldmVsLlxuICAgKlxuICAgKiBAcGFyYW0gIHtzdHJpbmd9IHZhbHVlICAgVGhlIGlzb2xhdGlvbiBsZXZlbC5cbiAgICogQHBhcmFtICB7T2JqZWN0fSBvcHRpb25zIEFuIG9iamVjdCB3aXRoIG9wdGlvbnMuXG4gICAqIEByZXR1cm5zIHtzdHJpbmd9ICAgICAgICAgVGhlIGdlbmVyYXRlZCBzcWwgcXVlcnkuXG4gICAqIEBwcml2YXRlXG4gICAqL1xuICBzZXRJc29sYXRpb25MZXZlbFF1ZXJ5KHZhbHVlLCBvcHRpb25zKSB7XG4gICAgaWYgKG9wdGlvbnMucGFyZW50KSB7XG4gICAgICByZXR1cm47XG4gICAgfVxuXG4gICAgcmV0dXJuIGBTRVQgVFJBTlNBQ1RJT04gSVNPTEFUSU9OIExFVkVMICR7dmFsdWV9O2A7XG4gIH0sXG5cbiAgZ2VuZXJhdGVUcmFuc2FjdGlvbklkKCkge1xuICAgIHJldHVybiB1dWlkdjQoKTtcbiAgfSxcblxuICAvKipcbiAgICogUmV0dXJucyBhIHF1ZXJ5IHRoYXQgc3RhcnRzIGEgdHJhbnNhY3Rpb24uXG4gICAqXG4gICAqIEBwYXJhbSAge1RyYW5zYWN0aW9ufSB0cmFuc2FjdGlvblxuICAgKiBAcmV0dXJucyB7c3RyaW5nfSAgICAgICAgIFRoZSBnZW5lcmF0ZWQgc3FsIHF1ZXJ5LlxuICAgKiBAcHJpdmF0ZVxuICAgKi9cbiAgc3RhcnRUcmFuc2FjdGlvblF1ZXJ5KHRyYW5zYWN0aW9uKSB7XG4gICAgaWYgKHRyYW5zYWN0aW9uLnBhcmVudCkge1xuICAgICAgLy8gZm9yY2UgcXVvdGluZyBvZiBzYXZlcG9pbnQgaWRlbnRpZmllcnMgZm9yIHBvc3RncmVzXG4gICAgICByZXR1cm4gYFNBVkVQT0lOVCAke3RoaXMucXVvdGVJZGVudGlmaWVyKHRyYW5zYWN0aW9uLm5hbWUsIHRydWUpfTtgO1xuICAgIH1cblxuICAgIHJldHVybiAnU1RBUlQgVFJBTlNBQ1RJT047JztcbiAgfSxcblxuICBkZWZlckNvbnN0cmFpbnRzUXVlcnkoKSB7fSxcblxuICBzZXRDb25zdHJhaW50UXVlcnkoKSB7fSxcbiAgc2V0RGVmZXJyZWRRdWVyeSgpIHt9LFxuICBzZXRJbW1lZGlhdGVRdWVyeSgpIHt9LFxuXG4gIC8qKlxuICAgKiBSZXR1cm5zIGEgcXVlcnkgdGhhdCBjb21taXRzIGEgdHJhbnNhY3Rpb24uXG4gICAqXG4gICAqIEBwYXJhbSAge1RyYW5zYWN0aW9ufSB0cmFuc2FjdGlvbiBBbiBvYmplY3Qgd2l0aCBvcHRpb25zLlxuICAgKiBAcmV0dXJucyB7c3RyaW5nfSAgICAgICAgIFRoZSBnZW5lcmF0ZWQgc3FsIHF1ZXJ5LlxuICAgKiBAcHJpdmF0ZVxuICAgKi9cbiAgY29tbWl0VHJhbnNhY3Rpb25RdWVyeSh0cmFuc2FjdGlvbikge1xuICAgIGlmICh0cmFuc2FjdGlvbi5wYXJlbnQpIHtcbiAgICAgIHJldHVybjtcbiAgICB9XG5cbiAgICByZXR1cm4gJ0NPTU1JVDsnO1xuICB9LFxuXG4gIC8qKlxuICAgKiBSZXR1cm5zIGEgcXVlcnkgdGhhdCByb2xsYmFja3MgYSB0cmFuc2FjdGlvbi5cbiAgICpcbiAgICogQHBhcmFtICB7VHJhbnNhY3Rpb259IHRyYW5zYWN0aW9uXG4gICAqIEByZXR1cm5zIHtzdHJpbmd9ICAgICAgICAgVGhlIGdlbmVyYXRlZCBzcWwgcXVlcnkuXG4gICAqIEBwcml2YXRlXG4gICAqL1xuICByb2xsYmFja1RyYW5zYWN0aW9uUXVlcnkodHJhbnNhY3Rpb24pIHtcbiAgICBpZiAodHJhbnNhY3Rpb24ucGFyZW50KSB7XG4gICAgICAvLyBmb3JjZSBxdW90aW5nIG9mIHNhdmVwb2ludCBpZGVudGlmaWVycyBmb3IgcG9zdGdyZXNcbiAgICAgIHJldHVybiBgUk9MTEJBQ0sgVE8gU0FWRVBPSU5UICR7dGhpcy5xdW90ZUlkZW50aWZpZXIodHJhbnNhY3Rpb24ubmFtZSwgdHJ1ZSl9O2A7XG4gICAgfVxuXG4gICAgcmV0dXJuICdST0xMQkFDSzsnO1xuICB9XG59O1xuXG5tb2R1bGUuZXhwb3J0cyA9IFRyYW5zYWN0aW9uUXVlcmllcztcbiJdfQ== \ No newline at end of file diff --git a/dist/dialects/abstract/query.js b/dist/dialects/abstract/query.js index 32735c3..f3b046c 100644 --- a/dist/dialects/abstract/query.js +++ b/dist/dialects/abstract/query.js @@ -18,9 +18,7 @@ const deprecations = require('../../utils/deprecations'); const uuid = require('uuid/v4'); -let AbstractQuery = -/*#__PURE__*/ -function () { +let AbstractQuery = /*#__PURE__*/function () { function AbstractQuery(connection, sequelize, options) { _classCallCheck(this, AbstractQuery); @@ -819,4 +817,4 @@ function () { module.exports = AbstractQuery; module.exports.AbstractQuery = AbstractQuery; module.exports.default = AbstractQuery; -//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../lib/dialects/abstract/query.js"],"names":["_","require","SqlString","QueryTypes","Dot","deprecations","uuid","AbstractQuery","connection","sequelize","options","instance","model","Object","assign","plain","raw","logging","console","log","checkLoggingOption","Error","noTrueLogging","field","message","key","keys","uniqueKeys","fields","includes","replace","msg","type","RAW","VERSION","UPSERT","results","metaData","result","INSERT","sql","toLowerCase","startsWith","prototype","hasOwnProperty","call","getInsertIdField","autoIncrementAttribute","id","SHOWTABLES","flatten","map","resultSet","values","SHOWINDEXES","SHOWCONSTRAINTS","DESCRIBE","SELECT","BULKUPDATE","BULKDELETE","FOREIGNKEYS","UPDATE","fieldMap","reduce","name","undefined","o","nest","transform","hasJoin","_groupJoinData","includeMap","includeNames","checkExisting","hasMultiAssociation","bulkBuild","isNewRecord","include","includeValidated","attributes","originalAttributes","length","debugContext","parameters","benchmark","logQueryParameters","startTime","Date","now","logParameter","delimiter","endsWith","paramStr","Array","isArray","p","JSON","stringify","join","fmt","afterMsg","dialect","replacementFunc","skipValueReplace","match","timeZone","escape","origReplacementFunc","list","skipUnescape","replVal","rows","includeOptions","i","$i","$length","rowsI","row","rowsLength","keyI","keyLength","prevKey","topValues","topExists","itemHash","parentHash","topHash","resultMap","$keyPrefix","$keyPrefixString","$prevKeyPrefixString","$prevKeyPrefix","$lastKeyPrefix","$current","$parent","previousPiece","buildIncludeMap","piece","keyPrefixStringMemo","keyPrefixString","memo","substr","lastIndexOf","removeKeyPrefixMemo","removeKeyPrefix","index","keyPrefixMemo","keyPrefix","prefixString","split","lastKeyPrefixMemo","lastKeyPrefix","prefix","getUniqueKeyAttributes","uniqueKeyAttributes","chain","findKey","chr","value","obj","Buffer","toString","primaryKeyAttributes","isEmpty","forEach","association","isSingleAssociation","push","module","exports","default"],"mappings":"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","sourcesContent":["'use strict';\r\n\r\nconst _ = require('lodash');\r\nconst SqlString = require('../../sql-string');\r\nconst QueryTypes = require('../../query-types');\r\nconst Dot = require('dottie');\r\nconst deprecations = require('../../utils/deprecations');\r\nconst uuid = require('uuid/v4');\r\n\r\nclass AbstractQuery {\r\n\r\n  constructor(connection, sequelize, options) {\r\n    this.uuid = uuid();\r\n    this.connection = connection;\r\n    this.instance = options.instance;\r\n    this.model = options.model;\r\n    this.sequelize = sequelize;\r\n    this.options = Object.assign({\r\n      plain: false,\r\n      raw: false,\r\n      // eslint-disable-next-line no-console\r\n      logging: console.log\r\n    }, options || {});\r\n    this.checkLoggingOption();\r\n  }\r\n\r\n  /**\r\n   * rewrite query with parameters\r\n   *\r\n   * Examples:\r\n   *\r\n   *   query.formatBindParameters('select $1 as foo', ['fooval']);\r\n   *\r\n   *   query.formatBindParameters('select $foo as foo', { foo: 'fooval' });\r\n   *\r\n   * Options\r\n   *   skipUnescape: bool, skip unescaping $$\r\n   *   skipValueReplace: bool, do not replace (but do unescape $$). Check correct syntax and if all values are available\r\n   *\r\n   * @param {string} sql\r\n   * @param {Object|Array} values\r\n   * @param {string} dialect\r\n   * @param {Function} [replacementFunc]\r\n   * @param {Object} [options]\r\n   * @private\r\n   */\r\n  static formatBindParameters(sql, values, dialect, replacementFunc, options) {\r\n    if (!values) {\r\n      return [sql, []];\r\n    }\r\n\r\n    options = options || {};\r\n    if (typeof replacementFunc !== 'function') {\r\n      options = replacementFunc || {};\r\n      replacementFunc = undefined;\r\n    }\r\n\r\n    if (!replacementFunc) {\r\n      if (options.skipValueReplace) {\r\n        replacementFunc = (match, key, values) => {\r\n          if (values[key] !== undefined) {\r\n            return match;\r\n          }\r\n          return undefined;\r\n        };\r\n      } else {\r\n        replacementFunc = (match, key, values, timeZone, dialect) => {\r\n          if (values[key] !== undefined) {\r\n            return SqlString.escape(values[key], timeZone, dialect);\r\n          }\r\n          return undefined;\r\n        };\r\n      }\r\n    } else if (options.skipValueReplace) {\r\n      const origReplacementFunc = replacementFunc;\r\n      replacementFunc = (match, key, values, timeZone, dialect, options) => {\r\n        if (origReplacementFunc(match, key, values, timeZone, dialect, options) !== undefined) {\r\n          return match;\r\n        }\r\n        return undefined;\r\n      };\r\n    }\r\n\r\n    const timeZone = null;\r\n    const list = Array.isArray(values);\r\n\r\n    sql = sql.replace(/\\$(\\$|\\w+)/g, (match, key) => {\r\n      if ('$' === key) {\r\n        return options.skipUnescape ? match : key;\r\n      }\r\n\r\n      let replVal;\r\n      if (list) {\r\n        if (key.match(/^[1-9]\\d*$/)) {\r\n          key = key - 1;\r\n          replVal = replacementFunc(match, key, values, timeZone, dialect, options);\r\n        }\r\n      } else if (!key.match(/^\\d*$/)) {\r\n        replVal = replacementFunc(match, key, values, timeZone, dialect, options);\r\n      }\r\n      if (replVal === undefined) {\r\n        throw new Error(`Named bind parameter \"${match}\" has no value in the given object.`);\r\n      }\r\n      return replVal;\r\n    });\r\n    return [sql, []];\r\n  }\r\n\r\n  /**\r\n   * Execute the passed sql query.\r\n   *\r\n   * Examples:\r\n   *\r\n   *     query.run('SELECT 1')\r\n   *\r\n   * @private\r\n   */\r\n  run() {\r\n    throw new Error('The run method wasn\\'t overwritten!');\r\n  }\r\n\r\n  /**\r\n   * Check the logging option of the instance and print deprecation warnings.\r\n   *\r\n   * @private\r\n   */\r\n  checkLoggingOption() {\r\n    if (this.options.logging === true) {\r\n      deprecations.noTrueLogging();\r\n      // eslint-disable-next-line no-console\r\n      this.options.logging = console.log;\r\n    }\r\n  }\r\n\r\n  /**\r\n   * Get the attributes of an insert query, which contains the just inserted id.\r\n   *\r\n   * @returns {string} The field name.\r\n   * @private\r\n   */\r\n  getInsertIdField() {\r\n    return 'insertId';\r\n  }\r\n\r\n  getUniqueConstraintErrorMessage(field) {\r\n    let message = field ? `${field} must be unique` : 'Must be unique';\r\n\r\n    if (field && this.model) {\r\n      for (const key of Object.keys(this.model.uniqueKeys)) {\r\n        if (this.model.uniqueKeys[key].fields.includes(field.replace(/\"/g, ''))) {\r\n          if (this.model.uniqueKeys[key].msg) {\r\n            message = this.model.uniqueKeys[key].msg;\r\n          }\r\n        }\r\n      }\r\n    }\r\n    return message;\r\n  }\r\n\r\n  isRawQuery() {\r\n    return this.options.type === QueryTypes.RAW;\r\n  }\r\n\r\n  isVersionQuery() {\r\n    return this.options.type === QueryTypes.VERSION;\r\n  }\r\n\r\n  isUpsertQuery() {\r\n    return this.options.type === QueryTypes.UPSERT;\r\n  }\r\n\r\n  isInsertQuery(results, metaData) {\r\n    let result = true;\r\n\r\n    if (this.options.type === QueryTypes.INSERT) {\r\n      return true;\r\n    }\r\n\r\n    // is insert query if sql contains insert into\r\n    result = result && this.sql.toLowerCase().startsWith('insert into');\r\n\r\n    // is insert query if no results are passed or if the result has the inserted id\r\n    result = result && (!results || Object.prototype.hasOwnProperty.call(results, this.getInsertIdField()));\r\n\r\n    // is insert query if no metadata are passed or if the metadata has the inserted id\r\n    result = result && (!metaData || Object.prototype.hasOwnProperty.call(metaData, this.getInsertIdField()));\r\n\r\n    return result;\r\n  }\r\n\r\n  handleInsertQuery(results, metaData) {\r\n    if (this.instance) {\r\n      // add the inserted row id to the instance\r\n      const autoIncrementAttribute = this.model.autoIncrementAttribute;\r\n      let id = null;\r\n\r\n      id = id || results && results[this.getInsertIdField()];\r\n      id = id || metaData && metaData[this.getInsertIdField()];\r\n\r\n      this.instance[autoIncrementAttribute] = id;\r\n    }\r\n  }\r\n\r\n  isShowTablesQuery() {\r\n    return this.options.type === QueryTypes.SHOWTABLES;\r\n  }\r\n\r\n  handleShowTablesQuery(results) {\r\n    return _.flatten(results.map(resultSet => _.values(resultSet)));\r\n  }\r\n\r\n  isShowIndexesQuery() {\r\n    return this.options.type === QueryTypes.SHOWINDEXES;\r\n  }\r\n\r\n  isShowConstraintsQuery() {\r\n    return this.options.type === QueryTypes.SHOWCONSTRAINTS;\r\n  }\r\n\r\n  isDescribeQuery() {\r\n    return this.options.type === QueryTypes.DESCRIBE;\r\n  }\r\n\r\n  isSelectQuery() {\r\n    return this.options.type === QueryTypes.SELECT;\r\n  }\r\n\r\n  isBulkUpdateQuery() {\r\n    return this.options.type === QueryTypes.BULKUPDATE;\r\n  }\r\n\r\n  isBulkDeleteQuery() {\r\n    return this.options.type === QueryTypes.BULKDELETE;\r\n  }\r\n\r\n  isForeignKeysQuery() {\r\n    return this.options.type === QueryTypes.FOREIGNKEYS;\r\n  }\r\n\r\n  isUpdateQuery() {\r\n    return this.options.type === QueryTypes.UPDATE;\r\n  }\r\n\r\n  handleSelectQuery(results) {\r\n    let result = null;\r\n\r\n    // Map raw fields to names if a mapping is provided\r\n    if (this.options.fieldMap) {\r\n      const fieldMap = this.options.fieldMap;\r\n      results = results.map(result => _.reduce(fieldMap, (result, name, field) => {\r\n        if (result[field] !== undefined && name !== field) {\r\n          result[name] = result[field];\r\n          delete result[field];\r\n        }\r\n        return result;\r\n      }, result));\r\n    }\r\n\r\n    // Raw queries\r\n    if (this.options.raw) {\r\n      result = results.map(result => {\r\n        let o = {};\r\n\r\n        for (const key in result) {\r\n          if (Object.prototype.hasOwnProperty.call(result, key)) {\r\n            o[key] = result[key];\r\n          }\r\n        }\r\n\r\n        if (this.options.nest) {\r\n          o = Dot.transform(o);\r\n        }\r\n\r\n        return o;\r\n      });\r\n    // Queries with include\r\n    } else if (this.options.hasJoin === true) {\r\n      results = AbstractQuery._groupJoinData(results, {\r\n        model: this.model,\r\n        includeMap: this.options.includeMap,\r\n        includeNames: this.options.includeNames\r\n      }, {\r\n        checkExisting: this.options.hasMultiAssociation\r\n      });\r\n\r\n      result = this.model.bulkBuild(results, {\r\n        isNewRecord: false,\r\n        include: this.options.include,\r\n        includeNames: this.options.includeNames,\r\n        includeMap: this.options.includeMap,\r\n        includeValidated: true,\r\n        attributes: this.options.originalAttributes || this.options.attributes,\r\n        raw: true\r\n      });\r\n    // Regular queries\r\n    } else {\r\n      result = this.model.bulkBuild(results, {\r\n        isNewRecord: false,\r\n        raw: true,\r\n        attributes: this.options.originalAttributes || this.options.attributes\r\n      });\r\n    }\r\n\r\n    // return the first real model instance if options.plain is set (e.g. Model.find)\r\n    if (this.options.plain) {\r\n      result = result.length === 0 ? null : result[0];\r\n    }\r\n    return result;\r\n  }\r\n\r\n  isShowOrDescribeQuery() {\r\n    let result = false;\r\n\r\n    result = result || this.sql.toLowerCase().startsWith('show');\r\n    result = result || this.sql.toLowerCase().startsWith('describe');\r\n\r\n    return result;\r\n  }\r\n\r\n  isCallQuery() {\r\n    return this.sql.toLowerCase().startsWith('call');\r\n  }\r\n\r\n  /**\r\n   * @param {string} sql\r\n   * @param {Function} debugContext\r\n   * @param {Array|Object} parameters\r\n   * @protected\r\n   * @returns {Function} A function to call after the query was completed.\r\n   */\r\n  _logQuery(sql, debugContext, parameters) {\r\n    const { connection, options } = this;\r\n    const benchmark = this.sequelize.options.benchmark || options.benchmark;\r\n    const logQueryParameters = this.sequelize.options.logQueryParameters || options.logQueryParameters;\r\n    const startTime = Date.now();\r\n    let logParameter = '';\r\n    \r\n    if (logQueryParameters && parameters) {\r\n      const delimiter = sql.endsWith(';') ? '' : ';';\r\n      let paramStr;\r\n      if (Array.isArray(parameters)) {\r\n        paramStr = parameters.map(p=>JSON.stringify(p)).join(', ');\r\n      } else {\r\n        paramStr = JSON.stringify(parameters);\r\n      }\r\n      logParameter = `${delimiter} ${paramStr}`;\r\n    }\r\n    const fmt = `(${connection.uuid || 'default'}): ${sql}${logParameter}`;\r\n    const msg = `Executing ${fmt}`;\r\n    debugContext(msg);\r\n    if (!benchmark) {\r\n      this.sequelize.log(`Executing ${fmt}`, options);\r\n    }\r\n    return () => {\r\n      const afterMsg = `Executed ${fmt}`;\r\n      debugContext(afterMsg);\r\n      if (benchmark) {\r\n        this.sequelize.log(afterMsg, Date.now() - startTime, options);\r\n      }\r\n    };\r\n  }\r\n\r\n  /**\r\n   * The function takes the result of the query execution and groups\r\n   * the associated data by the callee.\r\n   *\r\n   * Example:\r\n   *   groupJoinData([\r\n   *     {\r\n   *       some: 'data',\r\n   *       id: 1,\r\n   *       association: { foo: 'bar', id: 1 }\r\n   *     }, {\r\n   *       some: 'data',\r\n   *       id: 1,\r\n   *       association: { foo: 'bar', id: 2 }\r\n   *     }, {\r\n   *       some: 'data',\r\n   *       id: 1,\r\n   *       association: { foo: 'bar', id: 3 }\r\n   *     }\r\n   *   ])\r\n   *\r\n   * Result:\r\n   *   Something like this:\r\n   *\r\n   *   [\r\n   *     {\r\n   *       some: 'data',\r\n   *       id: 1,\r\n   *       association: [\r\n   *         { foo: 'bar', id: 1 },\r\n   *         { foo: 'bar', id: 2 },\r\n   *         { foo: 'bar', id: 3 }\r\n   *       ]\r\n   *     }\r\n   *   ]\r\n   *\r\n   * @param {Array} rows\r\n   * @param {Object} includeOptions\r\n   * @param {Object} options\r\n   * @private\r\n   */\r\n  static _groupJoinData(rows, includeOptions, options) {\r\n\r\n    /*\r\n     * Assumptions\r\n     * ID is not necessarily the first field\r\n     * All fields for a level is grouped in the same set (i.e. Panel.id, Task.id, Panel.title is not possible)\r\n     * Parent keys will be seen before any include/child keys\r\n     * Previous set won't necessarily be parent set (one parent could have two children, one child would then be previous set for the other)\r\n     */\r\n\r\n    /*\r\n     * Author (MH) comment: This code is an unreadable mess, but it's performant.\r\n     * groupJoinData is a performance critical function so we prioritize perf over readability.\r\n     */\r\n    if (!rows.length) {\r\n      return [];\r\n    }\r\n\r\n    // Generic looping\r\n    let i;\r\n    let length;\r\n    let $i;\r\n    let $length;\r\n    // Row specific looping\r\n    let rowsI;\r\n    let row;\r\n    const rowsLength = rows.length;\r\n    // Key specific looping\r\n    let keys;\r\n    let key;\r\n    let keyI;\r\n    let keyLength;\r\n    let prevKey;\r\n    let values;\r\n    let topValues;\r\n    let topExists;\r\n    const checkExisting = options.checkExisting;\r\n    // If we don't have to deduplicate we can pre-allocate the resulting array\r\n    let itemHash;\r\n    let parentHash;\r\n    let topHash;\r\n    const results = checkExisting ? [] : new Array(rowsLength);\r\n    const resultMap = {};\r\n    const includeMap = {};\r\n    // Result variables for the respective functions\r\n    let $keyPrefix;\r\n    let $keyPrefixString;\r\n    let $prevKeyPrefixString; // eslint-disable-line\r\n    let $prevKeyPrefix;\r\n    let $lastKeyPrefix;\r\n    let $current;\r\n    let $parent;\r\n    // Map each key to an include option\r\n    let previousPiece;\r\n    const buildIncludeMap = piece => {\r\n      if (Object.prototype.hasOwnProperty.call($current.includeMap, piece)) {\r\n        includeMap[key] = $current = $current.includeMap[piece];\r\n        if (previousPiece) {\r\n          previousPiece = `${previousPiece}.${piece}`;\r\n        } else {\r\n          previousPiece = piece;\r\n        }\r\n        includeMap[previousPiece] = $current;\r\n      }\r\n    };\r\n    // Calculate the string prefix of a key ('User.Results' for 'User.Results.id')\r\n    const keyPrefixStringMemo = {};\r\n    const keyPrefixString = (key, memo) => {\r\n      if (!Object.prototype.hasOwnProperty.call(memo, key)) {\r\n        memo[key] = key.substr(0, key.lastIndexOf('.'));\r\n      }\r\n      return memo[key];\r\n    };\r\n    // Removes the prefix from a key ('id' for 'User.Results.id')\r\n    const removeKeyPrefixMemo = {};\r\n    const removeKeyPrefix = key => {\r\n      if (!Object.prototype.hasOwnProperty.call(removeKeyPrefixMemo, key)) {\r\n        const index = key.lastIndexOf('.');\r\n        removeKeyPrefixMemo[key] = key.substr(index === -1 ? 0 : index + 1);\r\n      }\r\n      return removeKeyPrefixMemo[key];\r\n    };\r\n    // Calculates the array prefix of a key (['User', 'Results'] for 'User.Results.id')\r\n    const keyPrefixMemo = {};\r\n    const keyPrefix = key => {\r\n      // We use a double memo and keyPrefixString so that different keys with the same prefix will receive the same array instead of differnet arrays with equal values\r\n      if (!Object.prototype.hasOwnProperty.call(keyPrefixMemo, key)) {\r\n        const prefixString = keyPrefixString(key, keyPrefixStringMemo);\r\n        if (!Object.prototype.hasOwnProperty.call(keyPrefixMemo, prefixString)) {\r\n          keyPrefixMemo[prefixString] = prefixString ? prefixString.split('.') : [];\r\n        }\r\n        keyPrefixMemo[key] = keyPrefixMemo[prefixString];\r\n      }\r\n      return keyPrefixMemo[key];\r\n    };\r\n    // Calcuate the last item in the array prefix ('Results' for 'User.Results.id')\r\n    const lastKeyPrefixMemo = {};\r\n    const lastKeyPrefix = key => {\r\n      if (!Object.prototype.hasOwnProperty.call(lastKeyPrefixMemo, key)) {\r\n        const prefix = keyPrefix(key);\r\n        const length = prefix.length;\r\n\r\n        lastKeyPrefixMemo[key] = !length ? '' : prefix[length - 1];\r\n      }\r\n      return lastKeyPrefixMemo[key];\r\n    };\r\n    const getUniqueKeyAttributes = model => {\r\n      let uniqueKeyAttributes = _.chain(model.uniqueKeys);\r\n      uniqueKeyAttributes = uniqueKeyAttributes\r\n        .result(`${uniqueKeyAttributes.findKey()}.fields`)\r\n        .map(field => _.findKey(model.attributes, chr => chr.field === field))\r\n        .value();\r\n\r\n      return uniqueKeyAttributes;\r\n    };\r\n    const stringify = obj => obj instanceof Buffer ? obj.toString('hex') : obj;\r\n    let primaryKeyAttributes;\r\n    let uniqueKeyAttributes;\r\n    let prefix;\r\n\r\n    for (rowsI = 0; rowsI < rowsLength; rowsI++) {\r\n      row = rows[rowsI];\r\n\r\n      // Keys are the same for all rows, so only need to compute them on the first row\r\n      if (rowsI === 0) {\r\n        keys = Object.keys(row);\r\n        keyLength = keys.length;\r\n      }\r\n\r\n      if (checkExisting) {\r\n        topExists = false;\r\n\r\n        // Compute top level hash key (this is usually just the primary key values)\r\n        $length = includeOptions.model.primaryKeyAttributes.length;\r\n        topHash = '';\r\n        if ($length === 1) {\r\n          topHash = stringify(row[includeOptions.model.primaryKeyAttributes[0]]);\r\n        }\r\n        else if ($length > 1) {\r\n          for ($i = 0; $i < $length; $i++) {\r\n            topHash += stringify(row[includeOptions.model.primaryKeyAttributes[$i]]);\r\n          }\r\n        }\r\n        else if (!_.isEmpty(includeOptions.model.uniqueKeys)) {\r\n          uniqueKeyAttributes = getUniqueKeyAttributes(includeOptions.model);\r\n          for ($i = 0; $i < uniqueKeyAttributes.length; $i++) {\r\n            topHash += row[uniqueKeyAttributes[$i]];\r\n          }\r\n        }\r\n      }\r\n\r\n      topValues = values = {};\r\n      $prevKeyPrefix = undefined;\r\n      for (keyI = 0; keyI < keyLength; keyI++) {\r\n        key = keys[keyI];\r\n\r\n        // The string prefix isn't actualy needed\r\n        // We use it so keyPrefix for different keys will resolve to the same array if they have the same prefix\r\n        // TODO: Find a better way?\r\n        $keyPrefixString = keyPrefixString(key, keyPrefixStringMemo);\r\n        $keyPrefix = keyPrefix(key);\r\n\r\n        // On the first row we compute the includeMap\r\n        if (rowsI === 0 && !Object.prototype.hasOwnProperty.call(includeMap, key)) {\r\n          if (!$keyPrefix.length) {\r\n            includeMap[key] = includeMap[''] = includeOptions;\r\n          } else {\r\n            $current = includeOptions;\r\n            previousPiece = undefined;\r\n            $keyPrefix.forEach(buildIncludeMap);\r\n          }\r\n        }\r\n        // End of key set\r\n        if ($prevKeyPrefix !== undefined && $prevKeyPrefix !== $keyPrefix) {\r\n          if (checkExisting) {\r\n            // Compute hash key for this set instance\r\n            // TODO: Optimize\r\n            length = $prevKeyPrefix.length;\r\n            $parent = null;\r\n            parentHash = null;\r\n\r\n            if (length) {\r\n              for (i = 0; i < length; i++) {\r\n                prefix = $parent ? `${$parent}.${$prevKeyPrefix[i]}` : $prevKeyPrefix[i];\r\n                primaryKeyAttributes = includeMap[prefix].model.primaryKeyAttributes;\r\n                $length = primaryKeyAttributes.length;\r\n                itemHash = prefix;\r\n                if ($length === 1) {\r\n                  itemHash += stringify(row[`${prefix}.${primaryKeyAttributes[0]}`]);\r\n                }\r\n                else if ($length > 1) {\r\n                  for ($i = 0; $i < $length; $i++) {\r\n                    itemHash += stringify(row[`${prefix}.${primaryKeyAttributes[$i]}`]);\r\n                  }\r\n                }\r\n                else if (!_.isEmpty(includeMap[prefix].model.uniqueKeys)) {\r\n                  uniqueKeyAttributes = getUniqueKeyAttributes(includeMap[prefix].model);\r\n                  for ($i = 0; $i < uniqueKeyAttributes.length; $i++) {\r\n                    itemHash += row[`${prefix}.${uniqueKeyAttributes[$i]}`];\r\n                  }\r\n                }\r\n                if (!parentHash) {\r\n                  parentHash = topHash;\r\n                }\r\n\r\n                itemHash = parentHash + itemHash;\r\n                $parent = prefix;\r\n                if (i < length - 1) {\r\n                  parentHash = itemHash;\r\n                }\r\n              }\r\n            } else {\r\n              itemHash = topHash;\r\n            }\r\n\r\n            if (itemHash === topHash) {\r\n              if (!resultMap[itemHash]) {\r\n                resultMap[itemHash] = values;\r\n              } else {\r\n                topExists = true;\r\n              }\r\n            } else if (!resultMap[itemHash]) {\r\n              $parent = resultMap[parentHash];\r\n              $lastKeyPrefix = lastKeyPrefix(prevKey);\r\n\r\n              if (includeMap[prevKey].association.isSingleAssociation) {\r\n                if ($parent) {\r\n                  $parent[$lastKeyPrefix] = resultMap[itemHash] = values;\r\n                }\r\n              } else {\r\n                if (!$parent[$lastKeyPrefix]) {\r\n                  $parent[$lastKeyPrefix] = [];\r\n                }\r\n                $parent[$lastKeyPrefix].push(resultMap[itemHash] = values);\r\n              }\r\n            }\r\n\r\n            // Reset values\r\n            values = {};\r\n          } else {\r\n            // If checkExisting is false it's because there's only 1:1 associations in this query\r\n            // However we still need to map onto the appropriate parent\r\n            // For 1:1 we map forward, initializing the value object on the parent to be filled in the next iterations of the loop\r\n            $current = topValues;\r\n            length = $keyPrefix.length;\r\n            if (length) {\r\n              for (i = 0; i < length; i++) {\r\n                if (i === length - 1) {\r\n                  values = $current[$keyPrefix[i]] = {};\r\n                }\r\n                $current = $current[$keyPrefix[i]] || {};\r\n              }\r\n            }\r\n          }\r\n        }\r\n\r\n        // End of iteration, set value and set prev values (for next iteration)\r\n        values[removeKeyPrefix(key)] = row[key];\r\n        prevKey = key;\r\n        $prevKeyPrefix = $keyPrefix;\r\n        $prevKeyPrefixString = $keyPrefixString;\r\n      }\r\n\r\n      if (checkExisting) {\r\n        length = $prevKeyPrefix.length;\r\n        $parent = null;\r\n        parentHash = null;\r\n\r\n        if (length) {\r\n          for (i = 0; i < length; i++) {\r\n            prefix = $parent ? `${$parent}.${$prevKeyPrefix[i]}` : $prevKeyPrefix[i];\r\n            primaryKeyAttributes = includeMap[prefix].model.primaryKeyAttributes;\r\n            $length = primaryKeyAttributes.length;\r\n            itemHash = prefix;\r\n            if ($length === 1) {\r\n              itemHash += stringify(row[`${prefix}.${primaryKeyAttributes[0]}`]);\r\n            }\r\n            else if ($length > 0) {\r\n              for ($i = 0; $i < $length; $i++) {\r\n                itemHash += stringify(row[`${prefix}.${primaryKeyAttributes[$i]}`]);\r\n              }\r\n            }\r\n            else if (!_.isEmpty(includeMap[prefix].model.uniqueKeys)) {\r\n              uniqueKeyAttributes = getUniqueKeyAttributes(includeMap[prefix].model);\r\n              for ($i = 0; $i < uniqueKeyAttributes.length; $i++) {\r\n                itemHash += row[`${prefix}.${uniqueKeyAttributes[$i]}`];\r\n              }\r\n            }\r\n            if (!parentHash) {\r\n              parentHash = topHash;\r\n            }\r\n\r\n            itemHash = parentHash + itemHash;\r\n            $parent = prefix;\r\n            if (i < length - 1) {\r\n              parentHash = itemHash;\r\n            }\r\n          }\r\n        } else {\r\n          itemHash = topHash;\r\n        }\r\n\r\n        if (itemHash === topHash) {\r\n          if (!resultMap[itemHash]) {\r\n            resultMap[itemHash] = values;\r\n          } else {\r\n            topExists = true;\r\n          }\r\n        } else if (!resultMap[itemHash]) {\r\n          $parent = resultMap[parentHash];\r\n          $lastKeyPrefix = lastKeyPrefix(prevKey);\r\n\r\n          if (includeMap[prevKey].association.isSingleAssociation) {\r\n            if ($parent) {\r\n              $parent[$lastKeyPrefix] = resultMap[itemHash] = values;\r\n            }\r\n          } else {\r\n            if (!$parent[$lastKeyPrefix]) {\r\n              $parent[$lastKeyPrefix] = [];\r\n            }\r\n            $parent[$lastKeyPrefix].push(resultMap[itemHash] = values);\r\n          }\r\n        }\r\n        if (!topExists) {\r\n          results.push(topValues);\r\n        }\r\n      } else {\r\n        results[rowsI] = topValues;\r\n      }\r\n    }\r\n\r\n    return results;\r\n  }\r\n}\r\n\r\nmodule.exports = AbstractQuery;\r\nmodule.exports.AbstractQuery = AbstractQuery;\r\nmodule.exports.default = AbstractQuery;\r\n"]} \ No newline at end of file +//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../lib/dialects/abstract/query.js"],"names":["_","require","SqlString","QueryTypes","Dot","deprecations","uuid","AbstractQuery","connection","sequelize","options","instance","model","Object","assign","plain","raw","logging","console","log","checkLoggingOption","Error","noTrueLogging","field","message","key","keys","uniqueKeys","fields","includes","replace","msg","type","RAW","VERSION","UPSERT","results","metaData","result","INSERT","sql","toLowerCase","startsWith","prototype","hasOwnProperty","call","getInsertIdField","autoIncrementAttribute","id","SHOWTABLES","flatten","map","resultSet","values","SHOWINDEXES","SHOWCONSTRAINTS","DESCRIBE","SELECT","BULKUPDATE","BULKDELETE","FOREIGNKEYS","UPDATE","fieldMap","reduce","name","undefined","o","nest","transform","hasJoin","_groupJoinData","includeMap","includeNames","checkExisting","hasMultiAssociation","bulkBuild","isNewRecord","include","includeValidated","attributes","originalAttributes","length","debugContext","parameters","benchmark","logQueryParameters","startTime","Date","now","logParameter","delimiter","endsWith","paramStr","Array","isArray","p","JSON","stringify","join","fmt","afterMsg","dialect","replacementFunc","skipValueReplace","match","timeZone","escape","origReplacementFunc","list","skipUnescape","replVal","rows","includeOptions","i","$i","$length","rowsI","row","rowsLength","keyI","keyLength","prevKey","topValues","topExists","itemHash","parentHash","topHash","resultMap","$keyPrefix","$keyPrefixString","$prevKeyPrefixString","$prevKeyPrefix","$lastKeyPrefix","$current","$parent","previousPiece","buildIncludeMap","piece","keyPrefixStringMemo","keyPrefixString","memo","substr","lastIndexOf","removeKeyPrefixMemo","removeKeyPrefix","index","keyPrefixMemo","keyPrefix","prefixString","split","lastKeyPrefixMemo","lastKeyPrefix","prefix","getUniqueKeyAttributes","uniqueKeyAttributes","chain","findKey","chr","value","obj","Buffer","toString","primaryKeyAttributes","isEmpty","forEach","association","isSingleAssociation","push","module","exports","default"],"mappings":"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","sourcesContent":["'use strict';\n\nconst _ = require('lodash');\nconst SqlString = require('../../sql-string');\nconst QueryTypes = require('../../query-types');\nconst Dot = require('dottie');\nconst deprecations = require('../../utils/deprecations');\nconst uuid = require('uuid/v4');\n\nclass AbstractQuery {\n\n  constructor(connection, sequelize, options) {\n    this.uuid = uuid();\n    this.connection = connection;\n    this.instance = options.instance;\n    this.model = options.model;\n    this.sequelize = sequelize;\n    this.options = Object.assign({\n      plain: false,\n      raw: false,\n      // eslint-disable-next-line no-console\n      logging: console.log\n    }, options || {});\n    this.checkLoggingOption();\n  }\n\n  /**\n   * rewrite query with parameters\n   *\n   * Examples:\n   *\n   *   query.formatBindParameters('select $1 as foo', ['fooval']);\n   *\n   *   query.formatBindParameters('select $foo as foo', { foo: 'fooval' });\n   *\n   * Options\n   *   skipUnescape: bool, skip unescaping $$\n   *   skipValueReplace: bool, do not replace (but do unescape $$). Check correct syntax and if all values are available\n   *\n   * @param {string} sql\n   * @param {Object|Array} values\n   * @param {string} dialect\n   * @param {Function} [replacementFunc]\n   * @param {Object} [options]\n   * @private\n   */\n  static formatBindParameters(sql, values, dialect, replacementFunc, options) {\n    if (!values) {\n      return [sql, []];\n    }\n\n    options = options || {};\n    if (typeof replacementFunc !== 'function') {\n      options = replacementFunc || {};\n      replacementFunc = undefined;\n    }\n\n    if (!replacementFunc) {\n      if (options.skipValueReplace) {\n        replacementFunc = (match, key, values) => {\n          if (values[key] !== undefined) {\n            return match;\n          }\n          return undefined;\n        };\n      } else {\n        replacementFunc = (match, key, values, timeZone, dialect) => {\n          if (values[key] !== undefined) {\n            return SqlString.escape(values[key], timeZone, dialect);\n          }\n          return undefined;\n        };\n      }\n    } else if (options.skipValueReplace) {\n      const origReplacementFunc = replacementFunc;\n      replacementFunc = (match, key, values, timeZone, dialect, options) => {\n        if (origReplacementFunc(match, key, values, timeZone, dialect, options) !== undefined) {\n          return match;\n        }\n        return undefined;\n      };\n    }\n\n    const timeZone = null;\n    const list = Array.isArray(values);\n\n    sql = sql.replace(/\\$(\\$|\\w+)/g, (match, key) => {\n      if ('$' === key) {\n        return options.skipUnescape ? match : key;\n      }\n\n      let replVal;\n      if (list) {\n        if (key.match(/^[1-9]\\d*$/)) {\n          key = key - 1;\n          replVal = replacementFunc(match, key, values, timeZone, dialect, options);\n        }\n      } else if (!key.match(/^\\d*$/)) {\n        replVal = replacementFunc(match, key, values, timeZone, dialect, options);\n      }\n      if (replVal === undefined) {\n        throw new Error(`Named bind parameter \"${match}\" has no value in the given object.`);\n      }\n      return replVal;\n    });\n    return [sql, []];\n  }\n\n  /**\n   * Execute the passed sql query.\n   *\n   * Examples:\n   *\n   *     query.run('SELECT 1')\n   *\n   * @private\n   */\n  run() {\n    throw new Error('The run method wasn\\'t overwritten!');\n  }\n\n  /**\n   * Check the logging option of the instance and print deprecation warnings.\n   *\n   * @private\n   */\n  checkLoggingOption() {\n    if (this.options.logging === true) {\n      deprecations.noTrueLogging();\n      // eslint-disable-next-line no-console\n      this.options.logging = console.log;\n    }\n  }\n\n  /**\n   * Get the attributes of an insert query, which contains the just inserted id.\n   *\n   * @returns {string} The field name.\n   * @private\n   */\n  getInsertIdField() {\n    return 'insertId';\n  }\n\n  getUniqueConstraintErrorMessage(field) {\n    let message = field ? `${field} must be unique` : 'Must be unique';\n\n    if (field && this.model) {\n      for (const key of Object.keys(this.model.uniqueKeys)) {\n        if (this.model.uniqueKeys[key].fields.includes(field.replace(/\"/g, ''))) {\n          if (this.model.uniqueKeys[key].msg) {\n            message = this.model.uniqueKeys[key].msg;\n          }\n        }\n      }\n    }\n    return message;\n  }\n\n  isRawQuery() {\n    return this.options.type === QueryTypes.RAW;\n  }\n\n  isVersionQuery() {\n    return this.options.type === QueryTypes.VERSION;\n  }\n\n  isUpsertQuery() {\n    return this.options.type === QueryTypes.UPSERT;\n  }\n\n  isInsertQuery(results, metaData) {\n    let result = true;\n\n    if (this.options.type === QueryTypes.INSERT) {\n      return true;\n    }\n\n    // is insert query if sql contains insert into\n    result = result && this.sql.toLowerCase().startsWith('insert into');\n\n    // is insert query if no results are passed or if the result has the inserted id\n    result = result && (!results || Object.prototype.hasOwnProperty.call(results, this.getInsertIdField()));\n\n    // is insert query if no metadata are passed or if the metadata has the inserted id\n    result = result && (!metaData || Object.prototype.hasOwnProperty.call(metaData, this.getInsertIdField()));\n\n    return result;\n  }\n\n  handleInsertQuery(results, metaData) {\n    if (this.instance) {\n      // add the inserted row id to the instance\n      const autoIncrementAttribute = this.model.autoIncrementAttribute;\n      let id = null;\n\n      id = id || results && results[this.getInsertIdField()];\n      id = id || metaData && metaData[this.getInsertIdField()];\n\n      this.instance[autoIncrementAttribute] = id;\n    }\n  }\n\n  isShowTablesQuery() {\n    return this.options.type === QueryTypes.SHOWTABLES;\n  }\n\n  handleShowTablesQuery(results) {\n    return _.flatten(results.map(resultSet => _.values(resultSet)));\n  }\n\n  isShowIndexesQuery() {\n    return this.options.type === QueryTypes.SHOWINDEXES;\n  }\n\n  isShowConstraintsQuery() {\n    return this.options.type === QueryTypes.SHOWCONSTRAINTS;\n  }\n\n  isDescribeQuery() {\n    return this.options.type === QueryTypes.DESCRIBE;\n  }\n\n  isSelectQuery() {\n    return this.options.type === QueryTypes.SELECT;\n  }\n\n  isBulkUpdateQuery() {\n    return this.options.type === QueryTypes.BULKUPDATE;\n  }\n\n  isBulkDeleteQuery() {\n    return this.options.type === QueryTypes.BULKDELETE;\n  }\n\n  isForeignKeysQuery() {\n    return this.options.type === QueryTypes.FOREIGNKEYS;\n  }\n\n  isUpdateQuery() {\n    return this.options.type === QueryTypes.UPDATE;\n  }\n\n  handleSelectQuery(results) {\n    let result = null;\n\n    // Map raw fields to names if a mapping is provided\n    if (this.options.fieldMap) {\n      const fieldMap = this.options.fieldMap;\n      results = results.map(result => _.reduce(fieldMap, (result, name, field) => {\n        if (result[field] !== undefined && name !== field) {\n          result[name] = result[field];\n          delete result[field];\n        }\n        return result;\n      }, result));\n    }\n\n    // Raw queries\n    if (this.options.raw) {\n      result = results.map(result => {\n        let o = {};\n\n        for (const key in result) {\n          if (Object.prototype.hasOwnProperty.call(result, key)) {\n            o[key] = result[key];\n          }\n        }\n\n        if (this.options.nest) {\n          o = Dot.transform(o);\n        }\n\n        return o;\n      });\n    // Queries with include\n    } else if (this.options.hasJoin === true) {\n      results = AbstractQuery._groupJoinData(results, {\n        model: this.model,\n        includeMap: this.options.includeMap,\n        includeNames: this.options.includeNames\n      }, {\n        checkExisting: this.options.hasMultiAssociation\n      });\n\n      result = this.model.bulkBuild(results, {\n        isNewRecord: false,\n        include: this.options.include,\n        includeNames: this.options.includeNames,\n        includeMap: this.options.includeMap,\n        includeValidated: true,\n        attributes: this.options.originalAttributes || this.options.attributes,\n        raw: true\n      });\n    // Regular queries\n    } else {\n      result = this.model.bulkBuild(results, {\n        isNewRecord: false,\n        raw: true,\n        attributes: this.options.originalAttributes || this.options.attributes\n      });\n    }\n\n    // return the first real model instance if options.plain is set (e.g. Model.find)\n    if (this.options.plain) {\n      result = result.length === 0 ? null : result[0];\n    }\n    return result;\n  }\n\n  isShowOrDescribeQuery() {\n    let result = false;\n\n    result = result || this.sql.toLowerCase().startsWith('show');\n    result = result || this.sql.toLowerCase().startsWith('describe');\n\n    return result;\n  }\n\n  isCallQuery() {\n    return this.sql.toLowerCase().startsWith('call');\n  }\n\n  /**\n   * @param {string} sql\n   * @param {Function} debugContext\n   * @param {Array|Object} parameters\n   * @protected\n   * @returns {Function} A function to call after the query was completed.\n   */\n  _logQuery(sql, debugContext, parameters) {\n    const { connection, options } = this;\n    const benchmark = this.sequelize.options.benchmark || options.benchmark;\n    const logQueryParameters = this.sequelize.options.logQueryParameters || options.logQueryParameters;\n    const startTime = Date.now();\n    let logParameter = '';\n    \n    if (logQueryParameters && parameters) {\n      const delimiter = sql.endsWith(';') ? '' : ';';\n      let paramStr;\n      if (Array.isArray(parameters)) {\n        paramStr = parameters.map(p=>JSON.stringify(p)).join(', ');\n      } else {\n        paramStr = JSON.stringify(parameters);\n      }\n      logParameter = `${delimiter} ${paramStr}`;\n    }\n    const fmt = `(${connection.uuid || 'default'}): ${sql}${logParameter}`;\n    const msg = `Executing ${fmt}`;\n    debugContext(msg);\n    if (!benchmark) {\n      this.sequelize.log(`Executing ${fmt}`, options);\n    }\n    return () => {\n      const afterMsg = `Executed ${fmt}`;\n      debugContext(afterMsg);\n      if (benchmark) {\n        this.sequelize.log(afterMsg, Date.now() - startTime, options);\n      }\n    };\n  }\n\n  /**\n   * The function takes the result of the query execution and groups\n   * the associated data by the callee.\n   *\n   * Example:\n   *   groupJoinData([\n   *     {\n   *       some: 'data',\n   *       id: 1,\n   *       association: { foo: 'bar', id: 1 }\n   *     }, {\n   *       some: 'data',\n   *       id: 1,\n   *       association: { foo: 'bar', id: 2 }\n   *     }, {\n   *       some: 'data',\n   *       id: 1,\n   *       association: { foo: 'bar', id: 3 }\n   *     }\n   *   ])\n   *\n   * Result:\n   *   Something like this:\n   *\n   *   [\n   *     {\n   *       some: 'data',\n   *       id: 1,\n   *       association: [\n   *         { foo: 'bar', id: 1 },\n   *         { foo: 'bar', id: 2 },\n   *         { foo: 'bar', id: 3 }\n   *       ]\n   *     }\n   *   ]\n   *\n   * @param {Array} rows\n   * @param {Object} includeOptions\n   * @param {Object} options\n   * @private\n   */\n  static _groupJoinData(rows, includeOptions, options) {\n\n    /*\n     * Assumptions\n     * ID is not necessarily the first field\n     * All fields for a level is grouped in the same set (i.e. Panel.id, Task.id, Panel.title is not possible)\n     * Parent keys will be seen before any include/child keys\n     * Previous set won't necessarily be parent set (one parent could have two children, one child would then be previous set for the other)\n     */\n\n    /*\n     * Author (MH) comment: This code is an unreadable mess, but it's performant.\n     * groupJoinData is a performance critical function so we prioritize perf over readability.\n     */\n    if (!rows.length) {\n      return [];\n    }\n\n    // Generic looping\n    let i;\n    let length;\n    let $i;\n    let $length;\n    // Row specific looping\n    let rowsI;\n    let row;\n    const rowsLength = rows.length;\n    // Key specific looping\n    let keys;\n    let key;\n    let keyI;\n    let keyLength;\n    let prevKey;\n    let values;\n    let topValues;\n    let topExists;\n    const checkExisting = options.checkExisting;\n    // If we don't have to deduplicate we can pre-allocate the resulting array\n    let itemHash;\n    let parentHash;\n    let topHash;\n    const results = checkExisting ? [] : new Array(rowsLength);\n    const resultMap = {};\n    const includeMap = {};\n    // Result variables for the respective functions\n    let $keyPrefix;\n    let $keyPrefixString;\n    let $prevKeyPrefixString; // eslint-disable-line\n    let $prevKeyPrefix;\n    let $lastKeyPrefix;\n    let $current;\n    let $parent;\n    // Map each key to an include option\n    let previousPiece;\n    const buildIncludeMap = piece => {\n      if (Object.prototype.hasOwnProperty.call($current.includeMap, piece)) {\n        includeMap[key] = $current = $current.includeMap[piece];\n        if (previousPiece) {\n          previousPiece = `${previousPiece}.${piece}`;\n        } else {\n          previousPiece = piece;\n        }\n        includeMap[previousPiece] = $current;\n      }\n    };\n    // Calculate the string prefix of a key ('User.Results' for 'User.Results.id')\n    const keyPrefixStringMemo = {};\n    const keyPrefixString = (key, memo) => {\n      if (!Object.prototype.hasOwnProperty.call(memo, key)) {\n        memo[key] = key.substr(0, key.lastIndexOf('.'));\n      }\n      return memo[key];\n    };\n    // Removes the prefix from a key ('id' for 'User.Results.id')\n    const removeKeyPrefixMemo = {};\n    const removeKeyPrefix = key => {\n      if (!Object.prototype.hasOwnProperty.call(removeKeyPrefixMemo, key)) {\n        const index = key.lastIndexOf('.');\n        removeKeyPrefixMemo[key] = key.substr(index === -1 ? 0 : index + 1);\n      }\n      return removeKeyPrefixMemo[key];\n    };\n    // Calculates the array prefix of a key (['User', 'Results'] for 'User.Results.id')\n    const keyPrefixMemo = {};\n    const keyPrefix = key => {\n      // We use a double memo and keyPrefixString so that different keys with the same prefix will receive the same array instead of differnet arrays with equal values\n      if (!Object.prototype.hasOwnProperty.call(keyPrefixMemo, key)) {\n        const prefixString = keyPrefixString(key, keyPrefixStringMemo);\n        if (!Object.prototype.hasOwnProperty.call(keyPrefixMemo, prefixString)) {\n          keyPrefixMemo[prefixString] = prefixString ? prefixString.split('.') : [];\n        }\n        keyPrefixMemo[key] = keyPrefixMemo[prefixString];\n      }\n      return keyPrefixMemo[key];\n    };\n    // Calcuate the last item in the array prefix ('Results' for 'User.Results.id')\n    const lastKeyPrefixMemo = {};\n    const lastKeyPrefix = key => {\n      if (!Object.prototype.hasOwnProperty.call(lastKeyPrefixMemo, key)) {\n        const prefix = keyPrefix(key);\n        const length = prefix.length;\n\n        lastKeyPrefixMemo[key] = !length ? '' : prefix[length - 1];\n      }\n      return lastKeyPrefixMemo[key];\n    };\n    const getUniqueKeyAttributes = model => {\n      let uniqueKeyAttributes = _.chain(model.uniqueKeys);\n      uniqueKeyAttributes = uniqueKeyAttributes\n        .result(`${uniqueKeyAttributes.findKey()}.fields`)\n        .map(field => _.findKey(model.attributes, chr => chr.field === field))\n        .value();\n\n      return uniqueKeyAttributes;\n    };\n    const stringify = obj => obj instanceof Buffer ? obj.toString('hex') : obj;\n    let primaryKeyAttributes;\n    let uniqueKeyAttributes;\n    let prefix;\n\n    for (rowsI = 0; rowsI < rowsLength; rowsI++) {\n      row = rows[rowsI];\n\n      // Keys are the same for all rows, so only need to compute them on the first row\n      if (rowsI === 0) {\n        keys = Object.keys(row);\n        keyLength = keys.length;\n      }\n\n      if (checkExisting) {\n        topExists = false;\n\n        // Compute top level hash key (this is usually just the primary key values)\n        $length = includeOptions.model.primaryKeyAttributes.length;\n        topHash = '';\n        if ($length === 1) {\n          topHash = stringify(row[includeOptions.model.primaryKeyAttributes[0]]);\n        }\n        else if ($length > 1) {\n          for ($i = 0; $i < $length; $i++) {\n            topHash += stringify(row[includeOptions.model.primaryKeyAttributes[$i]]);\n          }\n        }\n        else if (!_.isEmpty(includeOptions.model.uniqueKeys)) {\n          uniqueKeyAttributes = getUniqueKeyAttributes(includeOptions.model);\n          for ($i = 0; $i < uniqueKeyAttributes.length; $i++) {\n            topHash += row[uniqueKeyAttributes[$i]];\n          }\n        }\n      }\n\n      topValues = values = {};\n      $prevKeyPrefix = undefined;\n      for (keyI = 0; keyI < keyLength; keyI++) {\n        key = keys[keyI];\n\n        // The string prefix isn't actualy needed\n        // We use it so keyPrefix for different keys will resolve to the same array if they have the same prefix\n        // TODO: Find a better way?\n        $keyPrefixString = keyPrefixString(key, keyPrefixStringMemo);\n        $keyPrefix = keyPrefix(key);\n\n        // On the first row we compute the includeMap\n        if (rowsI === 0 && !Object.prototype.hasOwnProperty.call(includeMap, key)) {\n          if (!$keyPrefix.length) {\n            includeMap[key] = includeMap[''] = includeOptions;\n          } else {\n            $current = includeOptions;\n            previousPiece = undefined;\n            $keyPrefix.forEach(buildIncludeMap);\n          }\n        }\n        // End of key set\n        if ($prevKeyPrefix !== undefined && $prevKeyPrefix !== $keyPrefix) {\n          if (checkExisting) {\n            // Compute hash key for this set instance\n            // TODO: Optimize\n            length = $prevKeyPrefix.length;\n            $parent = null;\n            parentHash = null;\n\n            if (length) {\n              for (i = 0; i < length; i++) {\n                prefix = $parent ? `${$parent}.${$prevKeyPrefix[i]}` : $prevKeyPrefix[i];\n                primaryKeyAttributes = includeMap[prefix].model.primaryKeyAttributes;\n                $length = primaryKeyAttributes.length;\n                itemHash = prefix;\n                if ($length === 1) {\n                  itemHash += stringify(row[`${prefix}.${primaryKeyAttributes[0]}`]);\n                }\n                else if ($length > 1) {\n                  for ($i = 0; $i < $length; $i++) {\n                    itemHash += stringify(row[`${prefix}.${primaryKeyAttributes[$i]}`]);\n                  }\n                }\n                else if (!_.isEmpty(includeMap[prefix].model.uniqueKeys)) {\n                  uniqueKeyAttributes = getUniqueKeyAttributes(includeMap[prefix].model);\n                  for ($i = 0; $i < uniqueKeyAttributes.length; $i++) {\n                    itemHash += row[`${prefix}.${uniqueKeyAttributes[$i]}`];\n                  }\n                }\n                if (!parentHash) {\n                  parentHash = topHash;\n                }\n\n                itemHash = parentHash + itemHash;\n                $parent = prefix;\n                if (i < length - 1) {\n                  parentHash = itemHash;\n                }\n              }\n            } else {\n              itemHash = topHash;\n            }\n\n            if (itemHash === topHash) {\n              if (!resultMap[itemHash]) {\n                resultMap[itemHash] = values;\n              } else {\n                topExists = true;\n              }\n            } else if (!resultMap[itemHash]) {\n              $parent = resultMap[parentHash];\n              $lastKeyPrefix = lastKeyPrefix(prevKey);\n\n              if (includeMap[prevKey].association.isSingleAssociation) {\n                if ($parent) {\n                  $parent[$lastKeyPrefix] = resultMap[itemHash] = values;\n                }\n              } else {\n                if (!$parent[$lastKeyPrefix]) {\n                  $parent[$lastKeyPrefix] = [];\n                }\n                $parent[$lastKeyPrefix].push(resultMap[itemHash] = values);\n              }\n            }\n\n            // Reset values\n            values = {};\n          } else {\n            // If checkExisting is false it's because there's only 1:1 associations in this query\n            // However we still need to map onto the appropriate parent\n            // For 1:1 we map forward, initializing the value object on the parent to be filled in the next iterations of the loop\n            $current = topValues;\n            length = $keyPrefix.length;\n            if (length) {\n              for (i = 0; i < length; i++) {\n                if (i === length - 1) {\n                  values = $current[$keyPrefix[i]] = {};\n                }\n                $current = $current[$keyPrefix[i]] || {};\n              }\n            }\n          }\n        }\n\n        // End of iteration, set value and set prev values (for next iteration)\n        values[removeKeyPrefix(key)] = row[key];\n        prevKey = key;\n        $prevKeyPrefix = $keyPrefix;\n        $prevKeyPrefixString = $keyPrefixString;\n      }\n\n      if (checkExisting) {\n        length = $prevKeyPrefix.length;\n        $parent = null;\n        parentHash = null;\n\n        if (length) {\n          for (i = 0; i < length; i++) {\n            prefix = $parent ? `${$parent}.${$prevKeyPrefix[i]}` : $prevKeyPrefix[i];\n            primaryKeyAttributes = includeMap[prefix].model.primaryKeyAttributes;\n            $length = primaryKeyAttributes.length;\n            itemHash = prefix;\n            if ($length === 1) {\n              itemHash += stringify(row[`${prefix}.${primaryKeyAttributes[0]}`]);\n            }\n            else if ($length > 0) {\n              for ($i = 0; $i < $length; $i++) {\n                itemHash += stringify(row[`${prefix}.${primaryKeyAttributes[$i]}`]);\n              }\n            }\n            else if (!_.isEmpty(includeMap[prefix].model.uniqueKeys)) {\n              uniqueKeyAttributes = getUniqueKeyAttributes(includeMap[prefix].model);\n              for ($i = 0; $i < uniqueKeyAttributes.length; $i++) {\n                itemHash += row[`${prefix}.${uniqueKeyAttributes[$i]}`];\n              }\n            }\n            if (!parentHash) {\n              parentHash = topHash;\n            }\n\n            itemHash = parentHash + itemHash;\n            $parent = prefix;\n            if (i < length - 1) {\n              parentHash = itemHash;\n            }\n          }\n        } else {\n          itemHash = topHash;\n        }\n\n        if (itemHash === topHash) {\n          if (!resultMap[itemHash]) {\n            resultMap[itemHash] = values;\n          } else {\n            topExists = true;\n          }\n        } else if (!resultMap[itemHash]) {\n          $parent = resultMap[parentHash];\n          $lastKeyPrefix = lastKeyPrefix(prevKey);\n\n          if (includeMap[prevKey].association.isSingleAssociation) {\n            if ($parent) {\n              $parent[$lastKeyPrefix] = resultMap[itemHash] = values;\n            }\n          } else {\n            if (!$parent[$lastKeyPrefix]) {\n              $parent[$lastKeyPrefix] = [];\n            }\n            $parent[$lastKeyPrefix].push(resultMap[itemHash] = values);\n          }\n        }\n        if (!topExists) {\n          results.push(topValues);\n        }\n      } else {\n        results[rowsI] = topValues;\n      }\n    }\n\n    return results;\n  }\n}\n\nmodule.exports = AbstractQuery;\nmodule.exports.AbstractQuery = AbstractQuery;\nmodule.exports.default = AbstractQuery;\n"]} \ No newline at end of file diff --git a/dist/dialects/mysql/query-generator.js b/dist/dialects/mysql/query-generator.js index 07f38e1..6c4f04d 100644 --- a/dist/dialects/mysql/query-generator.js +++ b/dist/dialects/mysql/query-generator.js @@ -6,20 +6,24 @@ function _defineProperties(target, props) { for (var i = 0; i < props.length; i+ function _createClass(Constructor, protoProps, staticProps) { if (protoProps) _defineProperties(Constructor.prototype, protoProps); if (staticProps) _defineProperties(Constructor, staticProps); return Constructor; } -function _possibleConstructorReturn(self, call) { if (call && (typeof call === "object" || typeof call === "function")) { return call; } return _assertThisInitialized(self); } - -function _assertThisInitialized(self) { if (self === void 0) { throw new ReferenceError("this hasn't been initialised - super() hasn't been called"); } return self; } - function _get(target, property, receiver) { if (typeof Reflect !== "undefined" && Reflect.get) { _get = Reflect.get; } else { _get = function _get(target, property, receiver) { var base = _superPropBase(target, property); if (!base) return; var desc = Object.getOwnPropertyDescriptor(base, property); if (desc.get) { return desc.get.call(receiver); } return desc.value; }; } return _get(target, property, receiver || target); } function _superPropBase(object, property) { while (!Object.prototype.hasOwnProperty.call(object, property)) { object = _getPrototypeOf(object); if (object === null) break; } return object; } -function _getPrototypeOf(o) { _getPrototypeOf = Object.setPrototypeOf ? Object.getPrototypeOf : function _getPrototypeOf(o) { return o.__proto__ || Object.getPrototypeOf(o); }; return _getPrototypeOf(o); } - function _inherits(subClass, superClass) { if (typeof superClass !== "function" && superClass !== null) { throw new TypeError("Super expression must either be null or a function"); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, writable: true, configurable: true } }); if (superClass) _setPrototypeOf(subClass, superClass); } function _setPrototypeOf(o, p) { _setPrototypeOf = Object.setPrototypeOf || function _setPrototypeOf(o, p) { o.__proto__ = p; return o; }; return _setPrototypeOf(o, p); } +function _createSuper(Derived) { var hasNativeReflectConstruct = _isNativeReflectConstruct(); return function _createSuperInternal() { var Super = _getPrototypeOf(Derived), result; if (hasNativeReflectConstruct) { var NewTarget = _getPrototypeOf(this).constructor; result = Reflect.construct(Super, arguments, NewTarget); } else { result = Super.apply(this, arguments); } return _possibleConstructorReturn(this, result); }; } + +function _possibleConstructorReturn(self, call) { if (call && (typeof call === "object" || typeof call === "function")) { return call; } return _assertThisInitialized(self); } + +function _assertThisInitialized(self) { if (self === void 0) { throw new ReferenceError("this hasn't been initialised - super() hasn't been called"); } return self; } + +function _isNativeReflectConstruct() { if (typeof Reflect === "undefined" || !Reflect.construct) return false; if (Reflect.construct.sham) return false; if (typeof Proxy === "function") return true; try { Date.prototype.toString.call(Reflect.construct(Date, [], function () {})); return true; } catch (e) { return false; } } + +function _getPrototypeOf(o) { _getPrototypeOf = Object.setPrototypeOf ? Object.getPrototypeOf : function _getPrototypeOf(o) { return o.__proto__ || Object.getPrototypeOf(o); }; return _getPrototypeOf(o); } + const _ = require('lodash'); const Utils = require('../../utils'); @@ -36,17 +40,17 @@ const tokenCaptureRegex = /^\s*((?:([`"'])(?:(?!\2).|\2{2})*\2)|[\w\d\s]+|[().,; const foreignKeyFields = 'CONSTRAINT_NAME as constraint_name,' + 'CONSTRAINT_NAME as constraintName,' + 'CONSTRAINT_SCHEMA as constraintSchema,' + 'CONSTRAINT_SCHEMA as constraintCatalog,' + 'TABLE_NAME as tableName,' + 'TABLE_SCHEMA as tableSchema,' + 'TABLE_SCHEMA as tableCatalog,' + 'COLUMN_NAME as columnName,' + 'REFERENCED_TABLE_SCHEMA as referencedTableSchema,' + 'REFERENCED_TABLE_SCHEMA as referencedTableCatalog,' + 'REFERENCED_TABLE_NAME as referencedTableName,' + 'REFERENCED_COLUMN_NAME as referencedColumnName'; const typeWithoutDefault = new Set(['BLOB', 'TEXT', 'GEOMETRY', 'JSON']); -let MySQLQueryGenerator = -/*#__PURE__*/ -function (_AbstractQueryGenerat) { +let MySQLQueryGenerator = /*#__PURE__*/function (_AbstractQueryGenerat) { _inherits(MySQLQueryGenerator, _AbstractQueryGenerat); + var _super = _createSuper(MySQLQueryGenerator); + function MySQLQueryGenerator(options) { var _this; _classCallCheck(this, MySQLQueryGenerator); - _this = _possibleConstructorReturn(this, _getPrototypeOf(MySQLQueryGenerator).call(this, options)); + _this = _super.call(this, options); _this.OperatorMap = Object.assign({}, _this.OperatorMap, { [Op.regexp]: 'REGEXP', [Op.notRegexp]: 'NOT REGEXP' @@ -576,4 +580,4 @@ function wrapSingleQuote(identifier) { } module.exports = MySQLQueryGenerator; -//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../lib/dialects/mysql/query-generator.js"],"names":["_","require","Utils","AbstractQueryGenerator","util","Op","jsonFunctionRegex","jsonOperatorRegex","tokenCaptureRegex","foreignKeyFields","typeWithoutDefault","Set","MySQLQueryGenerator","options","OperatorMap","Object","assign","regexp","notRegexp","databaseName","charset","collate","database","quoteIdentifier","escape","trim","tableName","attributes","engine","rowFormat","primaryKeys","foreignKeys","attrStr","attr","prototype","hasOwnProperty","call","dataType","match","includes","push","replace","table","quoteTable","attributesClause","join","comment","collation","initialAutoIncrement","pkString","map","pk","uniqueKeys","each","columns","indexName","customIndex","fields","field","length","fkey","schema","schemaDelimiter","addSchema","_schema","_schemaDelimiter","query","key","definition","attributeToSQL","context","foreignKey","attributeName","attrString","constraintString","attrName","finalQuery","attrBefore","smth","factory","prepend","Json","conditions","parseConditionObject","condition","jsonPathExtractionQuery","path","tail","value","str","_checkValidJsonStatement","paths","toPath","column","shift","format","Cast","test","type","json","toString","insertValues","updateValues","where","model","onDuplicate","keys","insertQuery","rawAttributes","limit","getWhereConditions","constraintName","schemaName","sql","indexNameOrAttributes","underscore","attribute","isPlainObject","attributeString","bind","template","allowNull","autoIncrement","has","_binary","defaultValueSchemable","defaultValue","unique","primaryKey","first","after","references","fkName","onDelete","toUpperCase","onUpdate","result","stmt","currentIndex","openingBrackets","closingBrackets","hasJsonFunction","hasInvalidToken","string","substr","functionMatches","exec","indexOf","operatorMatches","tokenMatches","capturedToken","Error","columnName","quotedSchemaName","wrapSingleQuote","quotedTableName","quotedColumnName","identifier","addTicks","module","exports"],"mappings":"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","sourcesContent":["'use strict';\r\n\r\nconst _ = require('lodash');\r\nconst Utils = require('../../utils');\r\nconst AbstractQueryGenerator = require('../abstract/query-generator');\r\nconst util = require('util');\r\nconst Op = require('../../operators');\r\n\r\n\r\nconst jsonFunctionRegex = /^\\s*((?:[a-z]+_){0,2}jsonb?(?:_[a-z]+){0,2})\\([^)]*\\)/i;\r\nconst jsonOperatorRegex = /^\\s*(->>?|@>|<@|\\?[|&]?|\\|{2}|#-)/i;\r\nconst tokenCaptureRegex = /^\\s*((?:([`\"'])(?:(?!\\2).|\\2{2})*\\2)|[\\w\\d\\s]+|[().,;+-])/i;\r\nconst foreignKeyFields = 'CONSTRAINT_NAME as constraint_name,'\r\n  + 'CONSTRAINT_NAME as constraintName,'\r\n  + 'CONSTRAINT_SCHEMA as constraintSchema,'\r\n  + 'CONSTRAINT_SCHEMA as constraintCatalog,'\r\n  + 'TABLE_NAME as tableName,'\r\n  + 'TABLE_SCHEMA as tableSchema,'\r\n  + 'TABLE_SCHEMA as tableCatalog,'\r\n  + 'COLUMN_NAME as columnName,'\r\n  + 'REFERENCED_TABLE_SCHEMA as referencedTableSchema,'\r\n  + 'REFERENCED_TABLE_SCHEMA as referencedTableCatalog,'\r\n  + 'REFERENCED_TABLE_NAME as referencedTableName,'\r\n  + 'REFERENCED_COLUMN_NAME as referencedColumnName';\r\n\r\nconst typeWithoutDefault = new Set(['BLOB', 'TEXT', 'GEOMETRY', 'JSON']);\r\n\r\nclass MySQLQueryGenerator extends AbstractQueryGenerator {\r\n  constructor(options) {\r\n    super(options);\r\n\r\n    this.OperatorMap = Object.assign({}, this.OperatorMap, {\r\n      [Op.regexp]: 'REGEXP',\r\n      [Op.notRegexp]: 'NOT REGEXP'\r\n    });\r\n  }\r\n\r\n  createDatabaseQuery(databaseName, options) {\r\n    options = Object.assign({\r\n      charset: null,\r\n      collate: null\r\n    }, options || {});\r\n\r\n    const database = this.quoteIdentifier(databaseName);\r\n    const charset = options.charset ? ` DEFAULT CHARACTER SET ${this.escape(options.charset)}` : '';\r\n    const collate = options.collate ? ` DEFAULT COLLATE ${this.escape(options.collate)}` : '';\r\n\r\n    return `${`CREATE DATABASE IF NOT EXISTS ${database}${charset}${collate}`.trim()};`;\r\n  }\r\n\r\n  dropDatabaseQuery(databaseName) {\r\n    return `DROP DATABASE IF EXISTS ${this.quoteIdentifier(databaseName).trim()};`;\r\n  }\r\n\r\n  createSchema() {\r\n    return 'SHOW TABLES';\r\n  }\r\n\r\n  showSchemasQuery() {\r\n    return 'SHOW TABLES';\r\n  }\r\n\r\n  versionQuery() {\r\n    return 'SELECT VERSION() as `version`';\r\n  }\r\n\r\n  createTableQuery(tableName, attributes, options) {\r\n    options = Object.assign({\r\n      engine: 'InnoDB',\r\n      charset: null,\r\n      rowFormat: null\r\n    }, options || {});\r\n\r\n    const primaryKeys = [];\r\n    const foreignKeys = {};\r\n    const attrStr = [];\r\n\r\n    for (const attr in attributes) {\r\n      if (!Object.prototype.hasOwnProperty.call(attributes, attr)) continue;\r\n      const dataType = attributes[attr];\r\n      let match;\r\n\r\n      if (dataType.includes('PRIMARY KEY')) {\r\n        primaryKeys.push(attr);\r\n\r\n        if (dataType.includes('REFERENCES')) {\r\n          // MySQL doesn't support inline REFERENCES declarations: move to the end\r\n          match = dataType.match(/^(.+) (REFERENCES.*)$/);\r\n          attrStr.push(`${this.quoteIdentifier(attr)} ${match[1].replace('PRIMARY KEY', '')}`);\r\n          foreignKeys[attr] = match[2];\r\n        } else {\r\n          attrStr.push(`${this.quoteIdentifier(attr)} ${dataType.replace('PRIMARY KEY', '')}`);\r\n        }\r\n      } else if (dataType.includes('REFERENCES')) {\r\n        // MySQL doesn't support inline REFERENCES declarations: move to the end\r\n        match = dataType.match(/^(.+) (REFERENCES.*)$/);\r\n        attrStr.push(`${this.quoteIdentifier(attr)} ${match[1]}`);\r\n        foreignKeys[attr] = match[2];\r\n      } else {\r\n        attrStr.push(`${this.quoteIdentifier(attr)} ${dataType}`);\r\n      }\r\n    }\r\n\r\n    const table = this.quoteTable(tableName);\r\n    let attributesClause = attrStr.join(', ');\r\n    const comment = options.comment && typeof options.comment === 'string' ? ` COMMENT ${this.escape(options.comment)}` : '';\r\n    const engine = options.engine;\r\n    const charset = options.charset ? ` DEFAULT CHARSET=${options.charset}` : '';\r\n    const collation = options.collate ? ` COLLATE ${options.collate}` : '';\r\n    const rowFormat = options.rowFormat ? ` ROW_FORMAT=${options.rowFormat}` : '';\r\n    const initialAutoIncrement = options.initialAutoIncrement ? ` AUTO_INCREMENT=${options.initialAutoIncrement}` : '';\r\n    const pkString = primaryKeys.map(pk => this.quoteIdentifier(pk)).join(', ');\r\n\r\n    if (options.uniqueKeys) {\r\n      _.each(options.uniqueKeys, (columns, indexName) => {\r\n        if (columns.customIndex) {\r\n          if (typeof indexName !== 'string') {\r\n            indexName = `uniq_${tableName}_${columns.fields.join('_')}`;\r\n          }\r\n          attributesClause += `, UNIQUE ${this.quoteIdentifier(indexName)} (${columns.fields.map(field => this.quoteIdentifier(field)).join(', ')})`;\r\n        }\r\n      });\r\n    }\r\n\r\n    if (pkString.length > 0) {\r\n      attributesClause += `, PRIMARY KEY (${pkString})`;\r\n    }\r\n\r\n    for (const fkey in foreignKeys) {\r\n      if (Object.prototype.hasOwnProperty.call(foreignKeys, fkey)) {\r\n        attributesClause += `, FOREIGN KEY (${this.quoteIdentifier(fkey)}) ${foreignKeys[fkey]}`;\r\n      }\r\n    }\r\n\r\n    return `CREATE TABLE IF NOT EXISTS ${table} (${attributesClause}) ENGINE=${engine}${comment}${charset}${collation}${initialAutoIncrement}${rowFormat};`;\r\n  }\r\n\r\n\r\n  describeTableQuery(tableName, schema, schemaDelimiter) {\r\n    const table = this.quoteTable(\r\n      this.addSchema({\r\n        tableName,\r\n        _schema: schema,\r\n        _schemaDelimiter: schemaDelimiter\r\n      })\r\n    );\r\n\r\n    return `SHOW FULL COLUMNS FROM ${table};`;\r\n  }\r\n\r\n  showTablesQuery(database) {\r\n    let query = 'SELECT TABLE_NAME FROM INFORMATION_SCHEMA.TABLES WHERE TABLE_TYPE = \\'BASE TABLE\\'';\r\n    if (database) {\r\n      query += ` AND TABLE_SCHEMA = ${this.escape(database)}`;\r\n    } else {\r\n      query += ' AND TABLE_SCHEMA NOT IN (\\'MYSQL\\', \\'INFORMATION_SCHEMA\\', \\'PERFORMANCE_SCHEMA\\', \\'SYS\\')';\r\n    }\r\n    return `${query};`;\r\n  }\r\n\r\n  addColumnQuery(table, key, dataType) {\r\n    const definition = this.attributeToSQL(dataType, {\r\n      context: 'addColumn',\r\n      tableName: table,\r\n      foreignKey: key\r\n    });\r\n\r\n    return `ALTER TABLE ${this.quoteTable(table)} ADD ${this.quoteIdentifier(key)} ${definition};`;\r\n  }\r\n\r\n  removeColumnQuery(tableName, attributeName) {\r\n    return `ALTER TABLE ${this.quoteTable(tableName)} DROP ${this.quoteIdentifier(attributeName)};`;\r\n  }\r\n\r\n  changeColumnQuery(tableName, attributes) {\r\n    const attrString = [];\r\n    const constraintString = [];\r\n\r\n    for (const attributeName in attributes) {\r\n      let definition = attributes[attributeName];\r\n      if (definition.includes('REFERENCES')) {\r\n        const attrName = this.quoteIdentifier(attributeName);\r\n        definition = definition.replace(/.+?(?=REFERENCES)/, '');\r\n        constraintString.push(`FOREIGN KEY (${attrName}) ${definition}`);\r\n      } else {\r\n        attrString.push(`\\`${attributeName}\\` \\`${attributeName}\\` ${definition}`);\r\n      }\r\n    }\r\n\r\n    let finalQuery = '';\r\n    if (attrString.length) {\r\n      finalQuery += `CHANGE ${attrString.join(', ')}`;\r\n      finalQuery += constraintString.length ? ' ' : '';\r\n    }\r\n    if (constraintString.length) {\r\n      finalQuery += `ADD ${constraintString.join(', ')}`;\r\n    }\r\n\r\n    return `ALTER TABLE ${this.quoteTable(tableName)} ${finalQuery};`;\r\n  }\r\n\r\n  renameColumnQuery(tableName, attrBefore, attributes) {\r\n    const attrString = [];\r\n\r\n    for (const attrName in attributes) {\r\n      const definition = attributes[attrName];\r\n      attrString.push(`\\`${attrBefore}\\` \\`${attrName}\\` ${definition}`);\r\n    }\r\n\r\n    return `ALTER TABLE ${this.quoteTable(tableName)} CHANGE ${attrString.join(', ')};`;\r\n  }\r\n\r\n  handleSequelizeMethod(smth, tableName, factory, options, prepend) {\r\n    if (smth instanceof Utils.Json) {\r\n      // Parse nested object\r\n      if (smth.conditions) {\r\n        const conditions = this.parseConditionObject(smth.conditions).map(condition =>\r\n          `${this.jsonPathExtractionQuery(condition.path[0], _.tail(condition.path))} = '${condition.value}'`\r\n        );\r\n\r\n        return conditions.join(' AND ');\r\n      }\r\n      if (smth.path) {\r\n        let str;\r\n\r\n        // Allow specifying conditions using the sqlite json functions\r\n        if (this._checkValidJsonStatement(smth.path)) {\r\n          str = smth.path;\r\n        } else {\r\n          // Also support json property accessors\r\n          const paths = _.toPath(smth.path);\r\n          const column = paths.shift();\r\n          str = this.jsonPathExtractionQuery(column, paths);\r\n        }\r\n\r\n        if (smth.value) {\r\n          str += util.format(' = %s', this.escape(smth.value));\r\n        }\r\n\r\n        return str;\r\n      }\r\n    } else if (smth instanceof Utils.Cast) {\r\n      if (/timestamp/i.test(smth.type)) {\r\n        smth.type = 'datetime';\r\n      } else if (smth.json && /boolean/i.test(smth.type)) {\r\n        // true or false cannot be casted as booleans within a JSON structure\r\n        smth.type = 'char';\r\n      } else if (/double precision/i.test(smth.type) || /boolean/i.test(smth.type) || /integer/i.test(smth.type)) {\r\n        smth.type = 'decimal';\r\n      } else if (/text/i.test(smth.type)) {\r\n        smth.type = 'char';\r\n      }\r\n    }\r\n\r\n    return super.handleSequelizeMethod(smth, tableName, factory, options, prepend);\r\n  }\r\n\r\n  _toJSONValue(value) {\r\n    // true/false are stored as strings in mysql\r\n    if (typeof value === 'boolean') {\r\n      return value.toString();\r\n    }\r\n    // null is stored as a string in mysql\r\n    if (value === null) {\r\n      return 'null';\r\n    }\r\n    return value;\r\n  }\r\n\r\n  upsertQuery(tableName, insertValues, updateValues, where, model, options) {\r\n    options.onDuplicate = 'UPDATE ';\r\n\r\n    options.onDuplicate += Object.keys(updateValues).map(key => {\r\n      key = this.quoteIdentifier(key);\r\n      return `${key}=VALUES(${key})`;\r\n    }).join(', ');\r\n\r\n    return this.insertQuery(tableName, insertValues, model.rawAttributes, options);\r\n  }\r\n\r\n  truncateTableQuery(tableName) {\r\n    return `TRUNCATE ${this.quoteTable(tableName)}`;\r\n  }\r\n\r\n  deleteQuery(tableName, where, options = {}, model) {\r\n    let limit = '';\r\n    let query = `DELETE FROM ${this.quoteTable(tableName)}`;\r\n\r\n    if (options.limit) {\r\n      limit = ` LIMIT ${this.escape(options.limit)}`;\r\n    }\r\n\r\n    where = this.getWhereConditions(where, null, model, options);\r\n\r\n    if (where) {\r\n      query += ` WHERE ${where}`;\r\n    }\r\n\r\n    return query + limit;\r\n  }\r\n\r\n  showIndexesQuery(tableName, options) {\r\n    return `SHOW INDEX FROM ${this.quoteTable(tableName)}${(options || {}).database ? ` FROM \\`${options.database}\\`` : ''}`;\r\n  }\r\n\r\n  showConstraintsQuery(table, constraintName) {\r\n    const tableName = table.tableName || table;\r\n    const schemaName = table.schema;\r\n\r\n    let sql = [\r\n      'SELECT CONSTRAINT_CATALOG AS constraintCatalog,',\r\n      'CONSTRAINT_NAME AS constraintName,',\r\n      'CONSTRAINT_SCHEMA AS constraintSchema,',\r\n      'CONSTRAINT_TYPE AS constraintType,',\r\n      'TABLE_NAME AS tableName,',\r\n      'TABLE_SCHEMA AS tableSchema',\r\n      'from INFORMATION_SCHEMA.TABLE_CONSTRAINTS',\r\n      `WHERE table_name='${tableName}'`\r\n    ].join(' ');\r\n\r\n    if (constraintName) {\r\n      sql += ` AND constraint_name = '${constraintName}'`;\r\n    }\r\n\r\n    if (schemaName) {\r\n      sql += ` AND TABLE_SCHEMA = '${schemaName}'`;\r\n    }\r\n\r\n    return `${sql};`;\r\n  }\r\n\r\n  removeIndexQuery(tableName, indexNameOrAttributes) {\r\n    let indexName = indexNameOrAttributes;\r\n\r\n    if (typeof indexName !== 'string') {\r\n      indexName = Utils.underscore(`${tableName}_${indexNameOrAttributes.join('_')}`);\r\n    }\r\n\r\n    return `DROP INDEX ${this.quoteIdentifier(indexName)} ON ${this.quoteTable(tableName)}`;\r\n  }\r\n\r\n  attributeToSQL(attribute, options) {\r\n    if (!_.isPlainObject(attribute)) {\r\n      attribute = {\r\n        type: attribute\r\n      };\r\n    }\r\n\r\n    const attributeString = attribute.type.toString({ escape: this.escape.bind(this) });\r\n    let template = attributeString;\r\n\r\n    if (attribute.allowNull === false) {\r\n      template += ' NOT NULL';\r\n    }\r\n\r\n    if (attribute.autoIncrement) {\r\n      template += ' auto_increment';\r\n    }\r\n\r\n    // BLOB/TEXT/GEOMETRY/JSON cannot have a default value\r\n    if (!typeWithoutDefault.has(attributeString)\r\n      && attribute.type._binary !== true\r\n      && Utils.defaultValueSchemable(attribute.defaultValue)) {\r\n      template += ` DEFAULT ${this.escape(attribute.defaultValue)}`;\r\n    }\r\n\r\n    if (attribute.unique === true) {\r\n      template += ' UNIQUE';\r\n    }\r\n\r\n    if (attribute.primaryKey) {\r\n      template += ' PRIMARY KEY';\r\n    }\r\n\r\n    if (attribute.comment) {\r\n      template += ` COMMENT ${this.escape(attribute.comment)}`;\r\n    }\r\n\r\n    if (attribute.first) {\r\n      template += ' FIRST';\r\n    }\r\n    if (attribute.after) {\r\n      template += ` AFTER ${this.quoteIdentifier(attribute.after)}`;\r\n    }\r\n\r\n    if (attribute.references) {\r\n\r\n      if (options && options.context === 'addColumn' && options.foreignKey) {\r\n        const attrName = this.quoteIdentifier(options.foreignKey);\r\n        const fkName = this.quoteIdentifier(`${options.tableName}_${attrName}_foreign_idx`);\r\n\r\n        template += `, ADD CONSTRAINT ${fkName} FOREIGN KEY (${attrName})`;\r\n      }\r\n\r\n      template += ` REFERENCES ${this.quoteTable(attribute.references.model)}`;\r\n\r\n      if (attribute.references.key) {\r\n        template += ` (${this.quoteIdentifier(attribute.references.key)})`;\r\n      } else {\r\n        template += ` (${this.quoteIdentifier('id')})`;\r\n      }\r\n\r\n      if (attribute.onDelete) {\r\n        template += ` ON DELETE ${attribute.onDelete.toUpperCase()}`;\r\n      }\r\n\r\n      if (attribute.onUpdate) {\r\n        template += ` ON UPDATE ${attribute.onUpdate.toUpperCase()}`;\r\n      }\r\n    }\r\n\r\n    return template;\r\n  }\r\n\r\n  attributesToSQL(attributes, options) {\r\n    const result = {};\r\n\r\n    for (const key in attributes) {\r\n      const attribute = attributes[key];\r\n      result[attribute.field || key] = this.attributeToSQL(attribute, options);\r\n    }\r\n\r\n    return result;\r\n  }\r\n\r\n  /**\r\n   * Check whether the statmement is json function or simple path\r\n   *\r\n   * @param   {string}  stmt  The statement to validate\r\n   * @returns {boolean}       true if the given statement is json function\r\n   * @throws  {Error}         throw if the statement looks like json function but has invalid token\r\n   * @private\r\n   */\r\n  _checkValidJsonStatement(stmt) {\r\n    if (typeof stmt !== 'string') {\r\n      return false;\r\n    }\r\n\r\n    let currentIndex = 0;\r\n    let openingBrackets = 0;\r\n    let closingBrackets = 0;\r\n    let hasJsonFunction = false;\r\n    let hasInvalidToken = false;\r\n\r\n    while (currentIndex < stmt.length) {\r\n      const string = stmt.substr(currentIndex);\r\n      const functionMatches = jsonFunctionRegex.exec(string);\r\n      if (functionMatches) {\r\n        currentIndex += functionMatches[0].indexOf('(');\r\n        hasJsonFunction = true;\r\n        continue;\r\n      }\r\n\r\n      const operatorMatches = jsonOperatorRegex.exec(string);\r\n      if (operatorMatches) {\r\n        currentIndex += operatorMatches[0].length;\r\n        hasJsonFunction = true;\r\n        continue;\r\n      }\r\n\r\n      const tokenMatches = tokenCaptureRegex.exec(string);\r\n      if (tokenMatches) {\r\n        const capturedToken = tokenMatches[1];\r\n        if (capturedToken === '(') {\r\n          openingBrackets++;\r\n        } else if (capturedToken === ')') {\r\n          closingBrackets++;\r\n        } else if (capturedToken === ';') {\r\n          hasInvalidToken = true;\r\n          break;\r\n        }\r\n        currentIndex += tokenMatches[0].length;\r\n        continue;\r\n      }\r\n\r\n      break;\r\n    }\r\n\r\n    // Check invalid json statement\r\n    if (hasJsonFunction && (hasInvalidToken || openingBrackets !== closingBrackets)) {\r\n      throw new Error(`Invalid json statement: ${stmt}`);\r\n    }\r\n\r\n    // return true if the statement has valid json function\r\n    return hasJsonFunction;\r\n  }\r\n\r\n  /**\r\n   * Generates an SQL query that returns all foreign keys of a table.\r\n   *\r\n   * @param  {Object} table  The table.\r\n   * @param  {string} schemaName The name of the schema.\r\n   * @returns {string}            The generated sql query.\r\n   * @private\r\n   */\r\n  getForeignKeysQuery(table, schemaName) {\r\n    const tableName = table.tableName || table;\r\n    return `SELECT ${foreignKeyFields} FROM INFORMATION_SCHEMA.KEY_COLUMN_USAGE where TABLE_NAME = '${tableName}' AND CONSTRAINT_NAME!='PRIMARY' AND CONSTRAINT_SCHEMA='${schemaName}' AND REFERENCED_TABLE_NAME IS NOT NULL;`;\r\n  }\r\n\r\n  /**\r\n   * Generates an SQL query that returns the foreign key constraint of a given column.\r\n   *\r\n   * @param  {Object} table  The table.\r\n   * @param  {string} columnName The name of the column.\r\n   * @returns {string}            The generated sql query.\r\n   * @private\r\n   */\r\n  getForeignKeyQuery(table, columnName) {\r\n    const quotedSchemaName = table.schema ? wrapSingleQuote(table.schema) : '';\r\n    const quotedTableName = wrapSingleQuote(table.tableName || table);\r\n    const quotedColumnName = wrapSingleQuote(columnName);\r\n\r\n    return `SELECT ${foreignKeyFields} FROM INFORMATION_SCHEMA.KEY_COLUMN_USAGE`\r\n      + ` WHERE (REFERENCED_TABLE_NAME = ${quotedTableName}${table.schema\r\n        ? ` AND REFERENCED_TABLE_SCHEMA = ${quotedSchemaName}`\r\n        : ''} AND REFERENCED_COLUMN_NAME = ${quotedColumnName})`\r\n      + ` OR (TABLE_NAME = ${quotedTableName}${table.schema ?\r\n        ` AND TABLE_SCHEMA = ${quotedSchemaName}` : ''} AND COLUMN_NAME = ${quotedColumnName} AND REFERENCED_TABLE_NAME IS NOT NULL)`;\r\n  }\r\n\r\n  /**\r\n   * Generates an SQL query that removes a foreign key from a table.\r\n   *\r\n   * @param  {string} tableName  The name of the table.\r\n   * @param  {string} foreignKey The name of the foreign key constraint.\r\n   * @returns {string}            The generated sql query.\r\n   * @private\r\n   */\r\n  dropForeignKeyQuery(tableName, foreignKey) {\r\n    return `ALTER TABLE ${this.quoteTable(tableName)}\r\n      DROP FOREIGN KEY ${this.quoteIdentifier(foreignKey)};`;\r\n  }\r\n}\r\n\r\n// private methods\r\nfunction wrapSingleQuote(identifier) {\r\n  return Utils.addTicks(identifier, '\\'');\r\n}\r\n\r\nmodule.exports = MySQLQueryGenerator;"]} \ No newline at end of file +//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../lib/dialects/mysql/query-generator.js"],"names":["_","require","Utils","AbstractQueryGenerator","util","Op","jsonFunctionRegex","jsonOperatorRegex","tokenCaptureRegex","foreignKeyFields","typeWithoutDefault","Set","MySQLQueryGenerator","options","OperatorMap","Object","assign","regexp","notRegexp","databaseName","charset","collate","database","quoteIdentifier","escape","trim","tableName","attributes","engine","rowFormat","primaryKeys","foreignKeys","attrStr","attr","prototype","hasOwnProperty","call","dataType","match","includes","push","replace","table","quoteTable","attributesClause","join","comment","collation","initialAutoIncrement","pkString","map","pk","uniqueKeys","each","columns","indexName","customIndex","fields","field","length","fkey","schema","schemaDelimiter","addSchema","_schema","_schemaDelimiter","query","key","definition","attributeToSQL","context","foreignKey","attributeName","attrString","constraintString","attrName","finalQuery","attrBefore","smth","factory","prepend","Json","conditions","parseConditionObject","condition","jsonPathExtractionQuery","path","tail","value","str","_checkValidJsonStatement","paths","toPath","column","shift","format","Cast","test","type","json","toString","insertValues","updateValues","where","model","onDuplicate","keys","insertQuery","rawAttributes","limit","getWhereConditions","constraintName","schemaName","sql","indexNameOrAttributes","underscore","attribute","isPlainObject","attributeString","bind","template","allowNull","autoIncrement","has","_binary","defaultValueSchemable","defaultValue","unique","primaryKey","first","after","references","fkName","onDelete","toUpperCase","onUpdate","result","stmt","currentIndex","openingBrackets","closingBrackets","hasJsonFunction","hasInvalidToken","string","substr","functionMatches","exec","indexOf","operatorMatches","tokenMatches","capturedToken","Error","columnName","quotedSchemaName","wrapSingleQuote","quotedTableName","quotedColumnName","identifier","addTicks","module","exports"],"mappings":"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","sourcesContent":["'use strict';\n\nconst _ = require('lodash');\nconst Utils = require('../../utils');\nconst AbstractQueryGenerator = require('../abstract/query-generator');\nconst util = require('util');\nconst Op = require('../../operators');\n\n\nconst jsonFunctionRegex = /^\\s*((?:[a-z]+_){0,2}jsonb?(?:_[a-z]+){0,2})\\([^)]*\\)/i;\nconst jsonOperatorRegex = /^\\s*(->>?|@>|<@|\\?[|&]?|\\|{2}|#-)/i;\nconst tokenCaptureRegex = /^\\s*((?:([`\"'])(?:(?!\\2).|\\2{2})*\\2)|[\\w\\d\\s]+|[().,;+-])/i;\nconst foreignKeyFields = 'CONSTRAINT_NAME as constraint_name,'\n  + 'CONSTRAINT_NAME as constraintName,'\n  + 'CONSTRAINT_SCHEMA as constraintSchema,'\n  + 'CONSTRAINT_SCHEMA as constraintCatalog,'\n  + 'TABLE_NAME as tableName,'\n  + 'TABLE_SCHEMA as tableSchema,'\n  + 'TABLE_SCHEMA as tableCatalog,'\n  + 'COLUMN_NAME as columnName,'\n  + 'REFERENCED_TABLE_SCHEMA as referencedTableSchema,'\n  + 'REFERENCED_TABLE_SCHEMA as referencedTableCatalog,'\n  + 'REFERENCED_TABLE_NAME as referencedTableName,'\n  + 'REFERENCED_COLUMN_NAME as referencedColumnName';\n\nconst typeWithoutDefault = new Set(['BLOB', 'TEXT', 'GEOMETRY', 'JSON']);\n\nclass MySQLQueryGenerator extends AbstractQueryGenerator {\n  constructor(options) {\n    super(options);\n\n    this.OperatorMap = Object.assign({}, this.OperatorMap, {\n      [Op.regexp]: 'REGEXP',\n      [Op.notRegexp]: 'NOT REGEXP'\n    });\n  }\n\n  createDatabaseQuery(databaseName, options) {\n    options = Object.assign({\n      charset: null,\n      collate: null\n    }, options || {});\n\n    const database = this.quoteIdentifier(databaseName);\n    const charset = options.charset ? ` DEFAULT CHARACTER SET ${this.escape(options.charset)}` : '';\n    const collate = options.collate ? ` DEFAULT COLLATE ${this.escape(options.collate)}` : '';\n\n    return `${`CREATE DATABASE IF NOT EXISTS ${database}${charset}${collate}`.trim()};`;\n  }\n\n  dropDatabaseQuery(databaseName) {\n    return `DROP DATABASE IF EXISTS ${this.quoteIdentifier(databaseName).trim()};`;\n  }\n\n  createSchema() {\n    return 'SHOW TABLES';\n  }\n\n  showSchemasQuery() {\n    return 'SHOW TABLES';\n  }\n\n  versionQuery() {\n    return 'SELECT VERSION() as `version`';\n  }\n\n  createTableQuery(tableName, attributes, options) {\n    options = Object.assign({\n      engine: 'InnoDB',\n      charset: null,\n      rowFormat: null\n    }, options || {});\n\n    const primaryKeys = [];\n    const foreignKeys = {};\n    const attrStr = [];\n\n    for (const attr in attributes) {\n      if (!Object.prototype.hasOwnProperty.call(attributes, attr)) continue;\n      const dataType = attributes[attr];\n      let match;\n\n      if (dataType.includes('PRIMARY KEY')) {\n        primaryKeys.push(attr);\n\n        if (dataType.includes('REFERENCES')) {\n          // MySQL doesn't support inline REFERENCES declarations: move to the end\n          match = dataType.match(/^(.+) (REFERENCES.*)$/);\n          attrStr.push(`${this.quoteIdentifier(attr)} ${match[1].replace('PRIMARY KEY', '')}`);\n          foreignKeys[attr] = match[2];\n        } else {\n          attrStr.push(`${this.quoteIdentifier(attr)} ${dataType.replace('PRIMARY KEY', '')}`);\n        }\n      } else if (dataType.includes('REFERENCES')) {\n        // MySQL doesn't support inline REFERENCES declarations: move to the end\n        match = dataType.match(/^(.+) (REFERENCES.*)$/);\n        attrStr.push(`${this.quoteIdentifier(attr)} ${match[1]}`);\n        foreignKeys[attr] = match[2];\n      } else {\n        attrStr.push(`${this.quoteIdentifier(attr)} ${dataType}`);\n      }\n    }\n\n    const table = this.quoteTable(tableName);\n    let attributesClause = attrStr.join(', ');\n    const comment = options.comment && typeof options.comment === 'string' ? ` COMMENT ${this.escape(options.comment)}` : '';\n    const engine = options.engine;\n    const charset = options.charset ? ` DEFAULT CHARSET=${options.charset}` : '';\n    const collation = options.collate ? ` COLLATE ${options.collate}` : '';\n    const rowFormat = options.rowFormat ? ` ROW_FORMAT=${options.rowFormat}` : '';\n    const initialAutoIncrement = options.initialAutoIncrement ? ` AUTO_INCREMENT=${options.initialAutoIncrement}` : '';\n    const pkString = primaryKeys.map(pk => this.quoteIdentifier(pk)).join(', ');\n\n    if (options.uniqueKeys) {\n      _.each(options.uniqueKeys, (columns, indexName) => {\n        if (columns.customIndex) {\n          if (typeof indexName !== 'string') {\n            indexName = `uniq_${tableName}_${columns.fields.join('_')}`;\n          }\n          attributesClause += `, UNIQUE ${this.quoteIdentifier(indexName)} (${columns.fields.map(field => this.quoteIdentifier(field)).join(', ')})`;\n        }\n      });\n    }\n\n    if (pkString.length > 0) {\n      attributesClause += `, PRIMARY KEY (${pkString})`;\n    }\n\n    for (const fkey in foreignKeys) {\n      if (Object.prototype.hasOwnProperty.call(foreignKeys, fkey)) {\n        attributesClause += `, FOREIGN KEY (${this.quoteIdentifier(fkey)}) ${foreignKeys[fkey]}`;\n      }\n    }\n\n    return `CREATE TABLE IF NOT EXISTS ${table} (${attributesClause}) ENGINE=${engine}${comment}${charset}${collation}${initialAutoIncrement}${rowFormat};`;\n  }\n\n\n  describeTableQuery(tableName, schema, schemaDelimiter) {\n    const table = this.quoteTable(\n      this.addSchema({\n        tableName,\n        _schema: schema,\n        _schemaDelimiter: schemaDelimiter\n      })\n    );\n\n    return `SHOW FULL COLUMNS FROM ${table};`;\n  }\n\n  showTablesQuery(database) {\n    let query = 'SELECT TABLE_NAME FROM INFORMATION_SCHEMA.TABLES WHERE TABLE_TYPE = \\'BASE TABLE\\'';\n    if (database) {\n      query += ` AND TABLE_SCHEMA = ${this.escape(database)}`;\n    } else {\n      query += ' AND TABLE_SCHEMA NOT IN (\\'MYSQL\\', \\'INFORMATION_SCHEMA\\', \\'PERFORMANCE_SCHEMA\\', \\'SYS\\')';\n    }\n    return `${query};`;\n  }\n\n  addColumnQuery(table, key, dataType) {\n    const definition = this.attributeToSQL(dataType, {\n      context: 'addColumn',\n      tableName: table,\n      foreignKey: key\n    });\n\n    return `ALTER TABLE ${this.quoteTable(table)} ADD ${this.quoteIdentifier(key)} ${definition};`;\n  }\n\n  removeColumnQuery(tableName, attributeName) {\n    return `ALTER TABLE ${this.quoteTable(tableName)} DROP ${this.quoteIdentifier(attributeName)};`;\n  }\n\n  changeColumnQuery(tableName, attributes) {\n    const attrString = [];\n    const constraintString = [];\n\n    for (const attributeName in attributes) {\n      let definition = attributes[attributeName];\n      if (definition.includes('REFERENCES')) {\n        const attrName = this.quoteIdentifier(attributeName);\n        definition = definition.replace(/.+?(?=REFERENCES)/, '');\n        constraintString.push(`FOREIGN KEY (${attrName}) ${definition}`);\n      } else {\n        attrString.push(`\\`${attributeName}\\` \\`${attributeName}\\` ${definition}`);\n      }\n    }\n\n    let finalQuery = '';\n    if (attrString.length) {\n      finalQuery += `CHANGE ${attrString.join(', ')}`;\n      finalQuery += constraintString.length ? ' ' : '';\n    }\n    if (constraintString.length) {\n      finalQuery += `ADD ${constraintString.join(', ')}`;\n    }\n\n    return `ALTER TABLE ${this.quoteTable(tableName)} ${finalQuery};`;\n  }\n\n  renameColumnQuery(tableName, attrBefore, attributes) {\n    const attrString = [];\n\n    for (const attrName in attributes) {\n      const definition = attributes[attrName];\n      attrString.push(`\\`${attrBefore}\\` \\`${attrName}\\` ${definition}`);\n    }\n\n    return `ALTER TABLE ${this.quoteTable(tableName)} CHANGE ${attrString.join(', ')};`;\n  }\n\n  handleSequelizeMethod(smth, tableName, factory, options, prepend) {\n    if (smth instanceof Utils.Json) {\n      // Parse nested object\n      if (smth.conditions) {\n        const conditions = this.parseConditionObject(smth.conditions).map(condition =>\n          `${this.jsonPathExtractionQuery(condition.path[0], _.tail(condition.path))} = '${condition.value}'`\n        );\n\n        return conditions.join(' AND ');\n      }\n      if (smth.path) {\n        let str;\n\n        // Allow specifying conditions using the sqlite json functions\n        if (this._checkValidJsonStatement(smth.path)) {\n          str = smth.path;\n        } else {\n          // Also support json property accessors\n          const paths = _.toPath(smth.path);\n          const column = paths.shift();\n          str = this.jsonPathExtractionQuery(column, paths);\n        }\n\n        if (smth.value) {\n          str += util.format(' = %s', this.escape(smth.value));\n        }\n\n        return str;\n      }\n    } else if (smth instanceof Utils.Cast) {\n      if (/timestamp/i.test(smth.type)) {\n        smth.type = 'datetime';\n      } else if (smth.json && /boolean/i.test(smth.type)) {\n        // true or false cannot be casted as booleans within a JSON structure\n        smth.type = 'char';\n      } else if (/double precision/i.test(smth.type) || /boolean/i.test(smth.type) || /integer/i.test(smth.type)) {\n        smth.type = 'decimal';\n      } else if (/text/i.test(smth.type)) {\n        smth.type = 'char';\n      }\n    }\n\n    return super.handleSequelizeMethod(smth, tableName, factory, options, prepend);\n  }\n\n  _toJSONValue(value) {\n    // true/false are stored as strings in mysql\n    if (typeof value === 'boolean') {\n      return value.toString();\n    }\n    // null is stored as a string in mysql\n    if (value === null) {\n      return 'null';\n    }\n    return value;\n  }\n\n  upsertQuery(tableName, insertValues, updateValues, where, model, options) {\n    options.onDuplicate = 'UPDATE ';\n\n    options.onDuplicate += Object.keys(updateValues).map(key => {\n      key = this.quoteIdentifier(key);\n      return `${key}=VALUES(${key})`;\n    }).join(', ');\n\n    return this.insertQuery(tableName, insertValues, model.rawAttributes, options);\n  }\n\n  truncateTableQuery(tableName) {\n    return `TRUNCATE ${this.quoteTable(tableName)}`;\n  }\n\n  deleteQuery(tableName, where, options = {}, model) {\n    let limit = '';\n    let query = `DELETE FROM ${this.quoteTable(tableName)}`;\n\n    if (options.limit) {\n      limit = ` LIMIT ${this.escape(options.limit)}`;\n    }\n\n    where = this.getWhereConditions(where, null, model, options);\n\n    if (where) {\n      query += ` WHERE ${where}`;\n    }\n\n    return query + limit;\n  }\n\n  showIndexesQuery(tableName, options) {\n    return `SHOW INDEX FROM ${this.quoteTable(tableName)}${(options || {}).database ? ` FROM \\`${options.database}\\`` : ''}`;\n  }\n\n  showConstraintsQuery(table, constraintName) {\n    const tableName = table.tableName || table;\n    const schemaName = table.schema;\n\n    let sql = [\n      'SELECT CONSTRAINT_CATALOG AS constraintCatalog,',\n      'CONSTRAINT_NAME AS constraintName,',\n      'CONSTRAINT_SCHEMA AS constraintSchema,',\n      'CONSTRAINT_TYPE AS constraintType,',\n      'TABLE_NAME AS tableName,',\n      'TABLE_SCHEMA AS tableSchema',\n      'from INFORMATION_SCHEMA.TABLE_CONSTRAINTS',\n      `WHERE table_name='${tableName}'`\n    ].join(' ');\n\n    if (constraintName) {\n      sql += ` AND constraint_name = '${constraintName}'`;\n    }\n\n    if (schemaName) {\n      sql += ` AND TABLE_SCHEMA = '${schemaName}'`;\n    }\n\n    return `${sql};`;\n  }\n\n  removeIndexQuery(tableName, indexNameOrAttributes) {\n    let indexName = indexNameOrAttributes;\n\n    if (typeof indexName !== 'string') {\n      indexName = Utils.underscore(`${tableName}_${indexNameOrAttributes.join('_')}`);\n    }\n\n    return `DROP INDEX ${this.quoteIdentifier(indexName)} ON ${this.quoteTable(tableName)}`;\n  }\n\n  attributeToSQL(attribute, options) {\n    if (!_.isPlainObject(attribute)) {\n      attribute = {\n        type: attribute\n      };\n    }\n\n    const attributeString = attribute.type.toString({ escape: this.escape.bind(this) });\n    let template = attributeString;\n\n    if (attribute.allowNull === false) {\n      template += ' NOT NULL';\n    }\n\n    if (attribute.autoIncrement) {\n      template += ' auto_increment';\n    }\n\n    // BLOB/TEXT/GEOMETRY/JSON cannot have a default value\n    if (!typeWithoutDefault.has(attributeString)\n      && attribute.type._binary !== true\n      && Utils.defaultValueSchemable(attribute.defaultValue)) {\n      template += ` DEFAULT ${this.escape(attribute.defaultValue)}`;\n    }\n\n    if (attribute.unique === true) {\n      template += ' UNIQUE';\n    }\n\n    if (attribute.primaryKey) {\n      template += ' PRIMARY KEY';\n    }\n\n    if (attribute.comment) {\n      template += ` COMMENT ${this.escape(attribute.comment)}`;\n    }\n\n    if (attribute.first) {\n      template += ' FIRST';\n    }\n    if (attribute.after) {\n      template += ` AFTER ${this.quoteIdentifier(attribute.after)}`;\n    }\n\n    if (attribute.references) {\n\n      if (options && options.context === 'addColumn' && options.foreignKey) {\n        const attrName = this.quoteIdentifier(options.foreignKey);\n        const fkName = this.quoteIdentifier(`${options.tableName}_${attrName}_foreign_idx`);\n\n        template += `, ADD CONSTRAINT ${fkName} FOREIGN KEY (${attrName})`;\n      }\n\n      template += ` REFERENCES ${this.quoteTable(attribute.references.model)}`;\n\n      if (attribute.references.key) {\n        template += ` (${this.quoteIdentifier(attribute.references.key)})`;\n      } else {\n        template += ` (${this.quoteIdentifier('id')})`;\n      }\n\n      if (attribute.onDelete) {\n        template += ` ON DELETE ${attribute.onDelete.toUpperCase()}`;\n      }\n\n      if (attribute.onUpdate) {\n        template += ` ON UPDATE ${attribute.onUpdate.toUpperCase()}`;\n      }\n    }\n\n    return template;\n  }\n\n  attributesToSQL(attributes, options) {\n    const result = {};\n\n    for (const key in attributes) {\n      const attribute = attributes[key];\n      result[attribute.field || key] = this.attributeToSQL(attribute, options);\n    }\n\n    return result;\n  }\n\n  /**\n   * Check whether the statmement is json function or simple path\n   *\n   * @param   {string}  stmt  The statement to validate\n   * @returns {boolean}       true if the given statement is json function\n   * @throws  {Error}         throw if the statement looks like json function but has invalid token\n   * @private\n   */\n  _checkValidJsonStatement(stmt) {\n    if (typeof stmt !== 'string') {\n      return false;\n    }\n\n    let currentIndex = 0;\n    let openingBrackets = 0;\n    let closingBrackets = 0;\n    let hasJsonFunction = false;\n    let hasInvalidToken = false;\n\n    while (currentIndex < stmt.length) {\n      const string = stmt.substr(currentIndex);\n      const functionMatches = jsonFunctionRegex.exec(string);\n      if (functionMatches) {\n        currentIndex += functionMatches[0].indexOf('(');\n        hasJsonFunction = true;\n        continue;\n      }\n\n      const operatorMatches = jsonOperatorRegex.exec(string);\n      if (operatorMatches) {\n        currentIndex += operatorMatches[0].length;\n        hasJsonFunction = true;\n        continue;\n      }\n\n      const tokenMatches = tokenCaptureRegex.exec(string);\n      if (tokenMatches) {\n        const capturedToken = tokenMatches[1];\n        if (capturedToken === '(') {\n          openingBrackets++;\n        } else if (capturedToken === ')') {\n          closingBrackets++;\n        } else if (capturedToken === ';') {\n          hasInvalidToken = true;\n          break;\n        }\n        currentIndex += tokenMatches[0].length;\n        continue;\n      }\n\n      break;\n    }\n\n    // Check invalid json statement\n    if (hasJsonFunction && (hasInvalidToken || openingBrackets !== closingBrackets)) {\n      throw new Error(`Invalid json statement: ${stmt}`);\n    }\n\n    // return true if the statement has valid json function\n    return hasJsonFunction;\n  }\n\n  /**\n   * Generates an SQL query that returns all foreign keys of a table.\n   *\n   * @param  {Object} table  The table.\n   * @param  {string} schemaName The name of the schema.\n   * @returns {string}            The generated sql query.\n   * @private\n   */\n  getForeignKeysQuery(table, schemaName) {\n    const tableName = table.tableName || table;\n    return `SELECT ${foreignKeyFields} FROM INFORMATION_SCHEMA.KEY_COLUMN_USAGE where TABLE_NAME = '${tableName}' AND CONSTRAINT_NAME!='PRIMARY' AND CONSTRAINT_SCHEMA='${schemaName}' AND REFERENCED_TABLE_NAME IS NOT NULL;`;\n  }\n\n  /**\n   * Generates an SQL query that returns the foreign key constraint of a given column.\n   *\n   * @param  {Object} table  The table.\n   * @param  {string} columnName The name of the column.\n   * @returns {string}            The generated sql query.\n   * @private\n   */\n  getForeignKeyQuery(table, columnName) {\n    const quotedSchemaName = table.schema ? wrapSingleQuote(table.schema) : '';\n    const quotedTableName = wrapSingleQuote(table.tableName || table);\n    const quotedColumnName = wrapSingleQuote(columnName);\n\n    return `SELECT ${foreignKeyFields} FROM INFORMATION_SCHEMA.KEY_COLUMN_USAGE`\n      + ` WHERE (REFERENCED_TABLE_NAME = ${quotedTableName}${table.schema\n        ? ` AND REFERENCED_TABLE_SCHEMA = ${quotedSchemaName}`\n        : ''} AND REFERENCED_COLUMN_NAME = ${quotedColumnName})`\n      + ` OR (TABLE_NAME = ${quotedTableName}${table.schema ?\n        ` AND TABLE_SCHEMA = ${quotedSchemaName}` : ''} AND COLUMN_NAME = ${quotedColumnName} AND REFERENCED_TABLE_NAME IS NOT NULL)`;\n  }\n\n  /**\n   * Generates an SQL query that removes a foreign key from a table.\n   *\n   * @param  {string} tableName  The name of the table.\n   * @param  {string} foreignKey The name of the foreign key constraint.\n   * @returns {string}            The generated sql query.\n   * @private\n   */\n  dropForeignKeyQuery(tableName, foreignKey) {\n    return `ALTER TABLE ${this.quoteTable(tableName)}\n      DROP FOREIGN KEY ${this.quoteIdentifier(foreignKey)};`;\n  }\n}\n\n// private methods\nfunction wrapSingleQuote(identifier) {\n  return Utils.addTicks(identifier, '\\'');\n}\n\nmodule.exports = MySQLQueryGenerator;"]} \ No newline at end of file diff --git a/dist/dialects/parserStore.js b/dist/dialects/parserStore.js index be441ee..0600109 100644 --- a/dist/dialects/parserStore.js +++ b/dist/dialects/parserStore.js @@ -24,4 +24,4 @@ module.exports = dialect => { }; }; -//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uL2xpYi9kaWFsZWN0cy9wYXJzZXJTdG9yZS5qcyJdLCJuYW1lcyI6WyJzdG9yZXMiLCJNYXAiLCJtb2R1bGUiLCJleHBvcnRzIiwiZGlhbGVjdCIsImhhcyIsInNldCIsImNsZWFyIiwiZ2V0IiwicmVmcmVzaCIsImRhdGFUeXBlIiwidHlwZSIsInR5cGVzIiwicGFyc2UiXSwibWFwcGluZ3MiOiJBQUFBOztBQUVBLE1BQU1BLE1BQU0sR0FBRyxJQUFJQyxHQUFKLEVBQWY7O0FBRUFDLE1BQU0sQ0FBQ0MsT0FBUCxHQUFpQkMsT0FBTyxJQUFJO0FBQzFCLE1BQUksQ0FBQ0osTUFBTSxDQUFDSyxHQUFQLENBQVdELE9BQVgsQ0FBTCxFQUEwQjtBQUN4QkosSUFBQUEsTUFBTSxDQUFDTSxHQUFQLENBQVdGLE9BQVgsRUFBb0IsSUFBSUgsR0FBSixFQUFwQjtBQUNEOztBQUVELFNBQU87QUFDTE0sSUFBQUEsS0FBSyxHQUFHO0FBQ05QLE1BQUFBLE1BQU0sQ0FBQ1EsR0FBUCxDQUFXSixPQUFYLEVBQW9CRyxLQUFwQjtBQUNELEtBSEk7O0FBSUxFLElBQUFBLE9BQU8sQ0FBQ0MsUUFBRCxFQUFXO0FBQ2hCLFdBQUssTUFBTUMsSUFBWCxJQUFtQkQsUUFBUSxDQUFDRSxLQUFULENBQWVSLE9BQWYsQ0FBbkIsRUFBNEM7QUFDMUNKLFFBQUFBLE1BQU0sQ0FBQ1EsR0FBUCxDQUFXSixPQUFYLEVBQW9CRSxHQUFwQixDQUF3QkssSUFBeEIsRUFBOEJELFFBQVEsQ0FBQ0csS0FBdkM7QUFDRDtBQUNGLEtBUkk7O0FBU0xMLElBQUFBLEdBQUcsQ0FBQ0csSUFBRCxFQUFPO0FBQ1IsYUFBT1gsTUFBTSxDQUFDUSxHQUFQLENBQVdKLE9BQVgsRUFBb0JJLEdBQXBCLENBQXdCRyxJQUF4QixDQUFQO0FBQ0Q7O0FBWEksR0FBUDtBQWFELENBbEJEIiwic291cmNlc0NvbnRlbnQiOlsiJ3VzZSBzdHJpY3QnO1xyXG5cclxuY29uc3Qgc3RvcmVzID0gbmV3IE1hcCgpO1xyXG5cclxubW9kdWxlLmV4cG9ydHMgPSBkaWFsZWN0ID0+IHtcclxuICBpZiAoIXN0b3Jlcy5oYXMoZGlhbGVjdCkpIHtcclxuICAgIHN0b3Jlcy5zZXQoZGlhbGVjdCwgbmV3IE1hcCgpKTtcclxuICB9XHJcblxyXG4gIHJldHVybiB7XHJcbiAgICBjbGVhcigpIHtcclxuICAgICAgc3RvcmVzLmdldChkaWFsZWN0KS5jbGVhcigpO1xyXG4gICAgfSxcclxuICAgIHJlZnJlc2goZGF0YVR5cGUpIHtcclxuICAgICAgZm9yIChjb25zdCB0eXBlIG9mIGRhdGFUeXBlLnR5cGVzW2RpYWxlY3RdKSB7XHJcbiAgICAgICAgc3RvcmVzLmdldChkaWFsZWN0KS5zZXQodHlwZSwgZGF0YVR5cGUucGFyc2UpO1xyXG4gICAgICB9XHJcbiAgICB9LFxyXG4gICAgZ2V0KHR5cGUpIHtcclxuICAgICAgcmV0dXJuIHN0b3Jlcy5nZXQoZGlhbGVjdCkuZ2V0KHR5cGUpO1xyXG4gICAgfVxyXG4gIH07XHJcbn07XHJcbiJdfQ== \ No newline at end of file +//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uL2xpYi9kaWFsZWN0cy9wYXJzZXJTdG9yZS5qcyJdLCJuYW1lcyI6WyJzdG9yZXMiLCJNYXAiLCJtb2R1bGUiLCJleHBvcnRzIiwiZGlhbGVjdCIsImhhcyIsInNldCIsImNsZWFyIiwiZ2V0IiwicmVmcmVzaCIsImRhdGFUeXBlIiwidHlwZSIsInR5cGVzIiwicGFyc2UiXSwibWFwcGluZ3MiOiJBQUFBOztBQUVBLE1BQU1BLE1BQU0sR0FBRyxJQUFJQyxHQUFKLEVBQWY7O0FBRUFDLE1BQU0sQ0FBQ0MsT0FBUCxHQUFpQkMsT0FBTyxJQUFJO0FBQzFCLE1BQUksQ0FBQ0osTUFBTSxDQUFDSyxHQUFQLENBQVdELE9BQVgsQ0FBTCxFQUEwQjtBQUN4QkosSUFBQUEsTUFBTSxDQUFDTSxHQUFQLENBQVdGLE9BQVgsRUFBb0IsSUFBSUgsR0FBSixFQUFwQjtBQUNEOztBQUVELFNBQU87QUFDTE0sSUFBQUEsS0FBSyxHQUFHO0FBQ05QLE1BQUFBLE1BQU0sQ0FBQ1EsR0FBUCxDQUFXSixPQUFYLEVBQW9CRyxLQUFwQjtBQUNELEtBSEk7O0FBSUxFLElBQUFBLE9BQU8sQ0FBQ0MsUUFBRCxFQUFXO0FBQ2hCLFdBQUssTUFBTUMsSUFBWCxJQUFtQkQsUUFBUSxDQUFDRSxLQUFULENBQWVSLE9BQWYsQ0FBbkIsRUFBNEM7QUFDMUNKLFFBQUFBLE1BQU0sQ0FBQ1EsR0FBUCxDQUFXSixPQUFYLEVBQW9CRSxHQUFwQixDQUF3QkssSUFBeEIsRUFBOEJELFFBQVEsQ0FBQ0csS0FBdkM7QUFDRDtBQUNGLEtBUkk7O0FBU0xMLElBQUFBLEdBQUcsQ0FBQ0csSUFBRCxFQUFPO0FBQ1IsYUFBT1gsTUFBTSxDQUFDUSxHQUFQLENBQVdKLE9BQVgsRUFBb0JJLEdBQXBCLENBQXdCRyxJQUF4QixDQUFQO0FBQ0Q7O0FBWEksR0FBUDtBQWFELENBbEJEIiwic291cmNlc0NvbnRlbnQiOlsiJ3VzZSBzdHJpY3QnO1xuXG5jb25zdCBzdG9yZXMgPSBuZXcgTWFwKCk7XG5cbm1vZHVsZS5leHBvcnRzID0gZGlhbGVjdCA9PiB7XG4gIGlmICghc3RvcmVzLmhhcyhkaWFsZWN0KSkge1xuICAgIHN0b3Jlcy5zZXQoZGlhbGVjdCwgbmV3IE1hcCgpKTtcbiAgfVxuXG4gIHJldHVybiB7XG4gICAgY2xlYXIoKSB7XG4gICAgICBzdG9yZXMuZ2V0KGRpYWxlY3QpLmNsZWFyKCk7XG4gICAgfSxcbiAgICByZWZyZXNoKGRhdGFUeXBlKSB7XG4gICAgICBmb3IgKGNvbnN0IHR5cGUgb2YgZGF0YVR5cGUudHlwZXNbZGlhbGVjdF0pIHtcbiAgICAgICAgc3RvcmVzLmdldChkaWFsZWN0KS5zZXQodHlwZSwgZGF0YVR5cGUucGFyc2UpO1xuICAgICAgfVxuICAgIH0sXG4gICAgZ2V0KHR5cGUpIHtcbiAgICAgIHJldHVybiBzdG9yZXMuZ2V0KGRpYWxlY3QpLmdldCh0eXBlKTtcbiAgICB9XG4gIH07XG59O1xuIl19 \ No newline at end of file diff --git a/dist/dialects/sqlite/connection-manager.js b/dist/dialects/sqlite/connection-manager.js index fe562cc..8e5d486 100644 --- a/dist/dialects/sqlite/connection-manager.js +++ b/dist/dialects/sqlite/connection-manager.js @@ -6,20 +6,24 @@ function _defineProperties(target, props) { for (var i = 0; i < props.length; i+ function _createClass(Constructor, protoProps, staticProps) { if (protoProps) _defineProperties(Constructor.prototype, protoProps); if (staticProps) _defineProperties(Constructor, staticProps); return Constructor; } -function _possibleConstructorReturn(self, call) { if (call && (typeof call === "object" || typeof call === "function")) { return call; } return _assertThisInitialized(self); } - -function _assertThisInitialized(self) { if (self === void 0) { throw new ReferenceError("this hasn't been initialised - super() hasn't been called"); } return self; } - function _get(target, property, receiver) { if (typeof Reflect !== "undefined" && Reflect.get) { _get = Reflect.get; } else { _get = function _get(target, property, receiver) { var base = _superPropBase(target, property); if (!base) return; var desc = Object.getOwnPropertyDescriptor(base, property); if (desc.get) { return desc.get.call(receiver); } return desc.value; }; } return _get(target, property, receiver || target); } function _superPropBase(object, property) { while (!Object.prototype.hasOwnProperty.call(object, property)) { object = _getPrototypeOf(object); if (object === null) break; } return object; } -function _getPrototypeOf(o) { _getPrototypeOf = Object.setPrototypeOf ? Object.getPrototypeOf : function _getPrototypeOf(o) { return o.__proto__ || Object.getPrototypeOf(o); }; return _getPrototypeOf(o); } - function _inherits(subClass, superClass) { if (typeof superClass !== "function" && superClass !== null) { throw new TypeError("Super expression must either be null or a function"); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, writable: true, configurable: true } }); if (superClass) _setPrototypeOf(subClass, superClass); } function _setPrototypeOf(o, p) { _setPrototypeOf = Object.setPrototypeOf || function _setPrototypeOf(o, p) { o.__proto__ = p; return o; }; return _setPrototypeOf(o, p); } +function _createSuper(Derived) { var hasNativeReflectConstruct = _isNativeReflectConstruct(); return function _createSuperInternal() { var Super = _getPrototypeOf(Derived), result; if (hasNativeReflectConstruct) { var NewTarget = _getPrototypeOf(this).constructor; result = Reflect.construct(Super, arguments, NewTarget); } else { result = Super.apply(this, arguments); } return _possibleConstructorReturn(this, result); }; } + +function _possibleConstructorReturn(self, call) { if (call && (typeof call === "object" || typeof call === "function")) { return call; } return _assertThisInitialized(self); } + +function _assertThisInitialized(self) { if (self === void 0) { throw new ReferenceError("this hasn't been initialised - super() hasn't been called"); } return self; } + +function _isNativeReflectConstruct() { if (typeof Reflect === "undefined" || !Reflect.construct) return false; if (Reflect.construct.sham) return false; if (typeof Proxy === "function") return true; try { Date.prototype.toString.call(Reflect.construct(Date, [], function () {})); return true; } catch (e) { return false; } } + +function _getPrototypeOf(o) { _getPrototypeOf = Object.setPrototypeOf ? Object.getPrototypeOf : function _getPrototypeOf(o) { return o.__proto__ || Object.getPrototypeOf(o); }; return _getPrototypeOf(o); } + const AbstractConnectionManager = require("../abstract/connection-manager"); const Promise = require("../../promise"); @@ -36,17 +40,17 @@ const sequelizeErrors = require("../../errors"); const parserStore = require("../parserStore")("sqlite"); -let ConnectionManager = -/*#__PURE__*/ -function (_AbstractConnectionMa) { +let ConnectionManager = /*#__PURE__*/function (_AbstractConnectionMa) { _inherits(ConnectionManager, _AbstractConnectionMa); + var _super = _createSuper(ConnectionManager); + function ConnectionManager(dialect, sequelize) { var _this; _classCallCheck(this, ConnectionManager); - _this = _possibleConstructorReturn(this, _getPrototypeOf(ConnectionManager).call(this, dialect, sequelize)); + _this = _super.call(this, dialect, sequelize); _this.connections = {}; const { @@ -137,4 +141,4 @@ function (_AbstractConnectionMa) { module.exports = ConnectionManager; module.exports.ConnectionManager = ConnectionManager; module.exports.default = ConnectionManager; -//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../lib/dialects/sqlite/connection-manager.js"],"names":["AbstractConnectionManager","require","Promise","logger","debug","debugContext","dataTypes","sqlite","sequelizeErrors","parserStore","ConnectionManager","dialect","sequelize","connections","openDatabase","_loadDialectModule","options","database","dialectOptions","version","description","size","conn","refreshTypeParser","promises","Object","getOwnPropertyNames","map","connection","fromCallback","callback","close","all","then","bind","dataType","refresh","clear","uuid","resolve","reject","ConnectionError","Error","tap","config","password","exec","sql","escape","args","foreignKeys","force","undefined","module","exports","default"],"mappings":"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","sourcesContent":["\"use strict\";\r\n\r\nconst AbstractConnectionManager = require(\"../abstract/connection-manager\");\r\nconst Promise = require(\"../../promise\");\r\nconst { logger } = require(\"../../utils/logger\");\r\nconst debug = logger.debugContext(\"connection:sqlite\");\r\nconst dataTypes = require(\"../../data-types\").sqlite;\r\nconst sequelizeErrors = require(\"../../errors\");\r\nconst parserStore = require(\"../parserStore\")(\"sqlite\");\r\n\r\nclass ConnectionManager extends AbstractConnectionManager {\r\n  constructor(dialect, sequelize) {\r\n    super(dialect, sequelize);\r\n\r\n    this.connections = {};\r\n    const { openDatabase } = this._loadDialectModule();\r\n    this.openDatabase = () =>\r\n      openDatabase(\r\n        this.sequelize.options.database,\r\n        this.sequelize.options.dialectOptions.version || \"1.0\",\r\n        this.sequelize.options.dialectOptions.description ||\r\n          this.sequelize.options.database,\r\n        this.sequelize.options.dialectOptions.size || 4 * 1024 * 1024\r\n      );\r\n    this.conn = this.openDatabase();\r\n    this.refreshTypeParser(dataTypes);\r\n  }\r\n\r\n  _onProcessExit() {\r\n    const promises = Object.getOwnPropertyNames(\r\n      this.connections\r\n    ).map(connection =>\r\n      Promise.fromCallback(callback =>\r\n        this.connections[connection].close(callback)\r\n      )\r\n    );\r\n\r\n    return Promise.all(promises).then(super._onProcessExit.bind(this));\r\n  }\r\n\r\n  // Expose this as a method so that the parsing may be updated when the user has added additional, custom types\r\n  _refreshTypeParser(dataType) {\r\n    parserStore.refresh(dataType);\r\n  }\r\n\r\n  _clearTypeParser() {\r\n    parserStore.clear();\r\n  }\r\n\r\n  getConnection(options) {\r\n    options = options || {};\r\n    options.uuid = options.uuid || \"default\";\r\n\r\n    if (this.connections[options.uuid]) {\r\n      return Promise.resolve(this.connections[options.uuid]);\r\n    }\r\n\r\n    return new Promise((resolve, reject) => {\r\n      this.connections[options.uuid] = !this.conn\r\n        ? this.openDatabase()\r\n        : this.conn;\r\n      debug(`connection acquired ${options.uuid}`);\r\n      if (!this.connections[options.uuid])\r\n        return reject(\r\n          new sequelizeErrors.ConnectionError(\r\n            new Error(\"Database reference no found!\")\r\n          )\r\n        );\r\n      resolve(this.connections[options.uuid]);\r\n    }).tap(connection => {\r\n      if (this.sequelize.config.password) {\r\n        // Make it possible to define and use password for sqlite encryption plugin like sqlcipher\r\n        if (connection && connection.exec) {\r\n          connection.exec(\r\n            [\r\n              {\r\n                sql: `PRAGMA KEY=${this.sequelize.escape(\r\n                  this.sequelize.config.password\r\n                )};`,\r\n                args: []\r\n              }\r\n            ],\r\n            false,\r\n            () => {}\r\n          );\r\n        }\r\n      }\r\n      if (this.sequelize.options.foreignKeys !== false) {\r\n        // Make it possible to define and use foreign key constraints unless\r\n        // explicitly disallowed. It's still opt-in per relation\r\n        if (connection && connection.exec) {\r\n          connection.exec(\r\n            [{ sql: \"PRAGMA FOREIGN_KEYS=ON\", args: [] }],\r\n            false,\r\n            () => {}\r\n          );\r\n        }\r\n      }\r\n    });\r\n  }\r\n\r\n  releaseConnection(connection, force) {\r\n    if (force !== true) return;\r\n\r\n    if (connection.uuid) {\r\n      connection.close && connection.close();\r\n      this.conn = undefined;\r\n      debug(`connection released ${connection.uuid}`);\r\n      delete this.connections[connection.uuid];\r\n    }\r\n  }\r\n}\r\n\r\nmodule.exports = ConnectionManager;\r\nmodule.exports.ConnectionManager = ConnectionManager;\r\nmodule.exports.default = ConnectionManager;\r\n"]} \ No newline at end of file +//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../lib/dialects/sqlite/connection-manager.js"],"names":["AbstractConnectionManager","require","Promise","logger","debug","debugContext","dataTypes","sqlite","sequelizeErrors","parserStore","ConnectionManager","dialect","sequelize","connections","openDatabase","_loadDialectModule","options","database","dialectOptions","version","description","size","conn","refreshTypeParser","promises","Object","getOwnPropertyNames","map","connection","fromCallback","callback","close","all","then","bind","dataType","refresh","clear","uuid","resolve","reject","ConnectionError","Error","tap","config","password","exec","sql","escape","args","foreignKeys","force","undefined","module","exports","default"],"mappings":"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","sourcesContent":["\"use strict\";\n\nconst AbstractConnectionManager = require(\"../abstract/connection-manager\");\nconst Promise = require(\"../../promise\");\nconst { logger } = require(\"../../utils/logger\");\nconst debug = logger.debugContext(\"connection:sqlite\");\nconst dataTypes = require(\"../../data-types\").sqlite;\nconst sequelizeErrors = require(\"../../errors\");\nconst parserStore = require(\"../parserStore\")(\"sqlite\");\n\nclass ConnectionManager extends AbstractConnectionManager {\n  constructor(dialect, sequelize) {\n    super(dialect, sequelize);\n\n    this.connections = {};\n    const { openDatabase } = this._loadDialectModule();\n    this.openDatabase = () =>\n      openDatabase(\n        this.sequelize.options.database,\n        this.sequelize.options.dialectOptions.version || \"1.0\",\n        this.sequelize.options.dialectOptions.description ||\n          this.sequelize.options.database,\n        this.sequelize.options.dialectOptions.size || 4 * 1024 * 1024\n      );\n    this.conn = this.openDatabase();\n    this.refreshTypeParser(dataTypes);\n  }\n\n  _onProcessExit() {\n    const promises = Object.getOwnPropertyNames(\n      this.connections\n    ).map(connection =>\n      Promise.fromCallback(callback =>\n        this.connections[connection].close(callback)\n      )\n    );\n\n    return Promise.all(promises).then(super._onProcessExit.bind(this));\n  }\n\n  // Expose this as a method so that the parsing may be updated when the user has added additional, custom types\n  _refreshTypeParser(dataType) {\n    parserStore.refresh(dataType);\n  }\n\n  _clearTypeParser() {\n    parserStore.clear();\n  }\n\n  getConnection(options) {\n    options = options || {};\n    options.uuid = options.uuid || \"default\";\n\n    if (this.connections[options.uuid]) {\n      return Promise.resolve(this.connections[options.uuid]);\n    }\n\n    return new Promise((resolve, reject) => {\n      this.connections[options.uuid] = !this.conn\n        ? this.openDatabase()\n        : this.conn;\n      debug(`connection acquired ${options.uuid}`);\n      if (!this.connections[options.uuid])\n        return reject(\n          new sequelizeErrors.ConnectionError(\n            new Error(\"Database reference no found!\")\n          )\n        );\n      resolve(this.connections[options.uuid]);\n    }).tap(connection => {\n      if (this.sequelize.config.password) {\n        // Make it possible to define and use password for sqlite encryption plugin like sqlcipher\n        if (connection && connection.exec) {\n          connection.exec(\n            [\n              {\n                sql: `PRAGMA KEY=${this.sequelize.escape(\n                  this.sequelize.config.password\n                )};`,\n                args: []\n              }\n            ],\n            false,\n            () => {}\n          );\n        }\n      }\n      if (this.sequelize.options.foreignKeys !== false) {\n        // Make it possible to define and use foreign key constraints unless\n        // explicitly disallowed. It's still opt-in per relation\n        if (connection && connection.exec) {\n          connection.exec(\n            [{ sql: \"PRAGMA FOREIGN_KEYS=ON\", args: [] }],\n            false,\n            () => {}\n          );\n        }\n      }\n    });\n  }\n\n  releaseConnection(connection, force) {\n    if (force !== true) return;\n\n    if (connection.uuid) {\n      connection.close && connection.close();\n      this.conn = undefined;\n      debug(`connection released ${connection.uuid}`);\n      delete this.connections[connection.uuid];\n    }\n  }\n}\n\nmodule.exports = ConnectionManager;\nmodule.exports.ConnectionManager = ConnectionManager;\nmodule.exports.default = ConnectionManager;\n"]} \ No newline at end of file diff --git a/dist/dialects/sqlite/data-types.js b/dist/dialects/sqlite/data-types.js index 11e3223..923ae8c 100644 --- a/dist/dialects/sqlite/data-types.js +++ b/dist/dialects/sqlite/data-types.js @@ -10,15 +10,19 @@ function _defineProperties(target, props) { for (var i = 0; i < props.length; i+ function _createClass(Constructor, protoProps, staticProps) { if (protoProps) _defineProperties(Constructor.prototype, protoProps); if (staticProps) _defineProperties(Constructor, staticProps); return Constructor; } +function _inherits(subClass, superClass) { if (typeof superClass !== "function" && superClass !== null) { throw new TypeError("Super expression must either be null or a function"); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, writable: true, configurable: true } }); if (superClass) _setPrototypeOf(subClass, superClass); } + +function _setPrototypeOf(o, p) { _setPrototypeOf = Object.setPrototypeOf || function _setPrototypeOf(o, p) { o.__proto__ = p; return o; }; return _setPrototypeOf(o, p); } + +function _createSuper(Derived) { var hasNativeReflectConstruct = _isNativeReflectConstruct(); return function _createSuperInternal() { var Super = _getPrototypeOf(Derived), result; if (hasNativeReflectConstruct) { var NewTarget = _getPrototypeOf(this).constructor; result = Reflect.construct(Super, arguments, NewTarget); } else { result = Super.apply(this, arguments); } return _possibleConstructorReturn(this, result); }; } + function _possibleConstructorReturn(self, call) { if (call && (typeof call === "object" || typeof call === "function")) { return call; } return _assertThisInitialized(self); } function _assertThisInitialized(self) { if (self === void 0) { throw new ReferenceError("this hasn't been initialised - super() hasn't been called"); } return self; } -function _getPrototypeOf(o) { _getPrototypeOf = Object.setPrototypeOf ? Object.getPrototypeOf : function _getPrototypeOf(o) { return o.__proto__ || Object.getPrototypeOf(o); }; return _getPrototypeOf(o); } - -function _inherits(subClass, superClass) { if (typeof superClass !== "function" && superClass !== null) { throw new TypeError("Super expression must either be null or a function"); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, writable: true, configurable: true } }); if (superClass) _setPrototypeOf(subClass, superClass); } +function _isNativeReflectConstruct() { if (typeof Reflect === "undefined" || !Reflect.construct) return false; if (Reflect.construct.sham) return false; if (typeof Proxy === "function") return true; try { Date.prototype.toString.call(Reflect.construct(Date, [], function () {})); return true; } catch (e) { return false; } } -function _setPrototypeOf(o, p) { _setPrototypeOf = Object.setPrototypeOf || function _setPrototypeOf(o, p) { o.__proto__ = p; return o; }; return _setPrototypeOf(o, p); } +function _getPrototypeOf(o) { _getPrototypeOf = Object.setPrototypeOf ? Object.getPrototypeOf : function _getPrototypeOf(o) { return o.__proto__ || Object.getPrototypeOf(o); }; return _getPrototypeOf(o); } module.exports = BaseTypes => { const warn = BaseTypes.ABSTRACT.warn.bind(undefined, "https://www.sqlite.org/datatype3.html"); @@ -60,18 +64,17 @@ module.exports = BaseTypes => { BaseTypes.ENUM.types.sqlite = false; BaseTypes.REAL.types.sqlite = ["REAL"]; BaseTypes.DOUBLE.types.sqlite = ["DOUBLE PRECISION"]; - BaseTypes.GEOMETRY.types.sqlite = false; BaseTypes.JSON.types.sqlite = ["JSON", "JSONB"]; - let JSONTYPE = - /*#__PURE__*/ - function (_BaseTypes$JSON) { + let JSONTYPE = /*#__PURE__*/function (_BaseTypes$JSON) { _inherits(JSONTYPE, _BaseTypes$JSON); + var _super = _createSuper(JSONTYPE); + function JSONTYPE() { _classCallCheck(this, JSONTYPE); - return _possibleConstructorReturn(this, _getPrototypeOf(JSONTYPE).apply(this, arguments)); + return _super.apply(this, arguments); } _createClass(JSONTYPE, null, [{ @@ -84,36 +87,36 @@ module.exports = BaseTypes => { return JSONTYPE; }(BaseTypes.JSON); - let DATE = - /*#__PURE__*/ - function (_BaseTypes$DATE) { + let DATE = /*#__PURE__*/function (_BaseTypes$DATE) { _inherits(DATE, _BaseTypes$DATE); + var _super2 = _createSuper(DATE); + function DATE() { _classCallCheck(this, DATE); - return _possibleConstructorReturn(this, _getPrototypeOf(DATE).apply(this, arguments)); + return _super2.apply(this, arguments); } _createClass(DATE, null, [{ key: "parse", value: function parse(date, options) { - return new Date(date.replace(" ", "T").replace(" " + options.timezone, "+0000")); // We already have a timezone stored in the string + return new Date(date.replace(' ', 'T').replace(' +00:00', 'Z')); // We already have a timezone stored in the string } }]); return DATE; }(BaseTypes.DATE); - let DATEONLY = - /*#__PURE__*/ - function (_BaseTypes$DATEONLY) { + let DATEONLY = /*#__PURE__*/function (_BaseTypes$DATEONLY) { _inherits(DATEONLY, _BaseTypes$DATEONLY); + var _super3 = _createSuper(DATEONLY); + function DATEONLY() { _classCallCheck(this, DATEONLY); - return _possibleConstructorReturn(this, _getPrototypeOf(DATEONLY).apply(this, arguments)); + return _super3.apply(this, arguments); } _createClass(DATEONLY, null, [{ @@ -126,15 +129,15 @@ module.exports = BaseTypes => { return DATEONLY; }(BaseTypes.DATEONLY); - let STRING = - /*#__PURE__*/ - function (_BaseTypes$STRING) { + let STRING = /*#__PURE__*/function (_BaseTypes$STRING) { _inherits(STRING, _BaseTypes$STRING); + var _super4 = _createSuper(STRING); + function STRING() { _classCallCheck(this, STRING); - return _possibleConstructorReturn(this, _getPrototypeOf(STRING).apply(this, arguments)); + return _super4.apply(this, arguments); } _createClass(STRING, [{ @@ -151,15 +154,15 @@ module.exports = BaseTypes => { return STRING; }(BaseTypes.STRING); - let TEXT = - /*#__PURE__*/ - function (_BaseTypes$TEXT) { + let TEXT = /*#__PURE__*/function (_BaseTypes$TEXT) { _inherits(TEXT, _BaseTypes$TEXT); + var _super5 = _createSuper(TEXT); + function TEXT() { _classCallCheck(this, TEXT); - return _possibleConstructorReturn(this, _getPrototypeOf(TEXT).apply(this, arguments)); + return _super5.apply(this, arguments); } _createClass(TEXT, [{ @@ -177,15 +180,15 @@ module.exports = BaseTypes => { return TEXT; }(BaseTypes.TEXT); - let CITEXT = - /*#__PURE__*/ - function (_BaseTypes$CITEXT) { + let CITEXT = /*#__PURE__*/function (_BaseTypes$CITEXT) { _inherits(CITEXT, _BaseTypes$CITEXT); + var _super6 = _createSuper(CITEXT); + function CITEXT() { _classCallCheck(this, CITEXT); - return _possibleConstructorReturn(this, _getPrototypeOf(CITEXT).apply(this, arguments)); + return _super6.apply(this, arguments); } _createClass(CITEXT, [{ @@ -198,15 +201,15 @@ module.exports = BaseTypes => { return CITEXT; }(BaseTypes.CITEXT); - let CHAR = - /*#__PURE__*/ - function (_BaseTypes$CHAR) { + let CHAR = /*#__PURE__*/function (_BaseTypes$CHAR) { _inherits(CHAR, _BaseTypes$CHAR); + var _super7 = _createSuper(CHAR); + function CHAR() { _classCallCheck(this, CHAR); - return _possibleConstructorReturn(this, _getPrototypeOf(CHAR).apply(this, arguments)); + return _super7.apply(this, arguments); } _createClass(CHAR, [{ @@ -223,15 +226,15 @@ module.exports = BaseTypes => { return CHAR; }(BaseTypes.CHAR); - let NUMBER = - /*#__PURE__*/ - function (_BaseTypes$NUMBER) { + let NUMBER = /*#__PURE__*/function (_BaseTypes$NUMBER) { _inherits(NUMBER, _BaseTypes$NUMBER); + var _super8 = _createSuper(NUMBER); + function NUMBER() { _classCallCheck(this, NUMBER); - return _possibleConstructorReturn(this, _getPrototypeOf(NUMBER).apply(this, arguments)); + return _super8.apply(this, arguments); } _createClass(NUMBER, [{ @@ -264,17 +267,17 @@ module.exports = BaseTypes => { return NUMBER; }(BaseTypes.NUMBER); - let TINYINT = - /*#__PURE__*/ - function (_BaseTypes$TINYINT) { + let TINYINT = /*#__PURE__*/function (_BaseTypes$TINYINT) { _inherits(TINYINT, _BaseTypes$TINYINT); + var _super9 = _createSuper(TINYINT); + function TINYINT(length) { var _this; _classCallCheck(this, TINYINT); - _this = _possibleConstructorReturn(this, _getPrototypeOf(TINYINT).call(this, length)); + _this = _super9.call(this, length); removeUnsupportedIntegerOptions(_assertThisInitialized(_this)); return _this; } @@ -282,17 +285,17 @@ module.exports = BaseTypes => { return TINYINT; }(BaseTypes.TINYINT); - let SMALLINT = - /*#__PURE__*/ - function (_BaseTypes$SMALLINT) { + let SMALLINT = /*#__PURE__*/function (_BaseTypes$SMALLINT) { _inherits(SMALLINT, _BaseTypes$SMALLINT); + var _super10 = _createSuper(SMALLINT); + function SMALLINT(length) { var _this2; _classCallCheck(this, SMALLINT); - _this2 = _possibleConstructorReturn(this, _getPrototypeOf(SMALLINT).call(this, length)); + _this2 = _super10.call(this, length); removeUnsupportedIntegerOptions(_assertThisInitialized(_this2)); return _this2; } @@ -300,17 +303,17 @@ module.exports = BaseTypes => { return SMALLINT; }(BaseTypes.SMALLINT); - let MEDIUMINT = - /*#__PURE__*/ - function (_BaseTypes$MEDIUMINT) { + let MEDIUMINT = /*#__PURE__*/function (_BaseTypes$MEDIUMINT) { _inherits(MEDIUMINT, _BaseTypes$MEDIUMINT); + var _super11 = _createSuper(MEDIUMINT); + function MEDIUMINT(length) { var _this3; _classCallCheck(this, MEDIUMINT); - _this3 = _possibleConstructorReturn(this, _getPrototypeOf(MEDIUMINT).call(this, length)); + _this3 = _super11.call(this, length); removeUnsupportedIntegerOptions(_assertThisInitialized(_this3)); return _this3; } @@ -318,17 +321,17 @@ module.exports = BaseTypes => { return MEDIUMINT; }(BaseTypes.MEDIUMINT); - let INTEGER = - /*#__PURE__*/ - function (_BaseTypes$INTEGER) { + let INTEGER = /*#__PURE__*/function (_BaseTypes$INTEGER) { _inherits(INTEGER, _BaseTypes$INTEGER); + var _super12 = _createSuper(INTEGER); + function INTEGER(length) { var _this4; _classCallCheck(this, INTEGER); - _this4 = _possibleConstructorReturn(this, _getPrototypeOf(INTEGER).call(this, length)); + _this4 = _super12.call(this, length); removeUnsupportedIntegerOptions(_assertThisInitialized(_this4)); return _this4; } @@ -336,17 +339,17 @@ module.exports = BaseTypes => { return INTEGER; }(BaseTypes.INTEGER); - let BIGINT = - /*#__PURE__*/ - function (_BaseTypes$BIGINT) { + let BIGINT = /*#__PURE__*/function (_BaseTypes$BIGINT) { _inherits(BIGINT, _BaseTypes$BIGINT); + var _super13 = _createSuper(BIGINT); + function BIGINT(length) { var _this5; _classCallCheck(this, BIGINT); - _this5 = _possibleConstructorReturn(this, _getPrototypeOf(BIGINT).call(this, length)); + _this5 = _super13.call(this, length); removeUnsupportedIntegerOptions(_assertThisInitialized(_this5)); return _this5; } @@ -354,43 +357,43 @@ module.exports = BaseTypes => { return BIGINT; }(BaseTypes.BIGINT); - let FLOAT = - /*#__PURE__*/ - function (_BaseTypes$FLOAT) { + let FLOAT = /*#__PURE__*/function (_BaseTypes$FLOAT) { _inherits(FLOAT, _BaseTypes$FLOAT); + var _super14 = _createSuper(FLOAT); + function FLOAT() { _classCallCheck(this, FLOAT); - return _possibleConstructorReturn(this, _getPrototypeOf(FLOAT).apply(this, arguments)); + return _super14.apply(this, arguments); } return FLOAT; }(BaseTypes.FLOAT); - let DOUBLE = - /*#__PURE__*/ - function (_BaseTypes$DOUBLE) { + let DOUBLE = /*#__PURE__*/function (_BaseTypes$DOUBLE) { _inherits(DOUBLE, _BaseTypes$DOUBLE); + var _super15 = _createSuper(DOUBLE); + function DOUBLE() { _classCallCheck(this, DOUBLE); - return _possibleConstructorReturn(this, _getPrototypeOf(DOUBLE).apply(this, arguments)); + return _super15.apply(this, arguments); } return DOUBLE; }(BaseTypes.DOUBLE); - let REAL = - /*#__PURE__*/ - function (_BaseTypes$REAL) { + let REAL = /*#__PURE__*/function (_BaseTypes$REAL) { _inherits(REAL, _BaseTypes$REAL); + var _super16 = _createSuper(REAL); + function REAL() { _classCallCheck(this, REAL); - return _possibleConstructorReturn(this, _getPrototypeOf(REAL).apply(this, arguments)); + return _super16.apply(this, arguments); } return REAL; @@ -422,15 +425,15 @@ module.exports = BaseTypes => { num.prototype.toSql = NUMBER.prototype.toSql; } - let ENUM = - /*#__PURE__*/ - function (_BaseTypes$ENUM) { + let ENUM = /*#__PURE__*/function (_BaseTypes$ENUM) { _inherits(ENUM, _BaseTypes$ENUM); + var _super17 = _createSuper(ENUM); + function ENUM() { _classCallCheck(this, ENUM); - return _possibleConstructorReturn(this, _getPrototypeOf(ENUM).apply(this, arguments)); + return _super17.apply(this, arguments); } _createClass(ENUM, [{ @@ -463,4 +466,4 @@ module.exports = BaseTypes => { CITEXT }; }; -//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../lib/dialects/sqlite/data-types.js"],"names":["module","exports","BaseTypes","warn","ABSTRACT","bind","undefined","removeUnsupportedIntegerOptions","dataType","_zerofill","_unsigned","key","DATE","types","sqlite","STRING","CHAR","TEXT","TINYINT","SMALLINT","MEDIUMINT","INTEGER","BIGINT","FLOAT","TIME","DATEONLY","BOOLEAN","BLOB","DECIMAL","UUID","ENUM","REAL","DOUBLE","GEOMETRY","JSON","JSONTYPE","data","parse","date","options","Date","replace","timezone","_binary","_length","CITEXT","NUMBER","result","_decimals","length","parseFloating","value","NaN","Infinity","floating","num","prototype","toSql"],"mappings":"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","sourcesContent":["\"use strict\";\r\n\r\nmodule.exports = BaseTypes => {\r\n  const warn = BaseTypes.ABSTRACT.warn.bind(\r\n    undefined,\r\n    \"https://www.sqlite.org/datatype3.html\"\r\n  );\r\n\r\n  /**\r\n   * Removes unsupported SQLite options, i.e., UNSIGNED and ZEROFILL, for the integer data types.\r\n   *\r\n   * @param {Object} dataType The base integer data type.\r\n   * @private\r\n   */\r\n  function removeUnsupportedIntegerOptions(dataType) {\r\n    if (dataType._zerofill || dataType._unsigned) {\r\n      warn(\r\n        `SQLite does not support '${dataType.key}' with UNSIGNED or ZEROFILL. Plain '${dataType.key}' will be used instead.`\r\n      );\r\n      dataType._unsigned = undefined;\r\n      dataType._zerofill = undefined;\r\n    }\r\n  }\r\n\r\n  /**\r\n   * @see https://sqlite.org/datatype3.html\r\n   */\r\n\r\n  BaseTypes.DATE.types.sqlite = [\"DATETIME\"];\r\n  BaseTypes.STRING.types.sqlite = [\"VARCHAR\", \"VARCHAR BINARY\"];\r\n  BaseTypes.CHAR.types.sqlite = [\"CHAR\", \"CHAR BINARY\"];\r\n  BaseTypes.TEXT.types.sqlite = [\"TEXT\"];\r\n  BaseTypes.TINYINT.types.sqlite = [\"TINYINT\"];\r\n  BaseTypes.SMALLINT.types.sqlite = [\"SMALLINT\"];\r\n  BaseTypes.MEDIUMINT.types.sqlite = [\"MEDIUMINT\"];\r\n  BaseTypes.INTEGER.types.sqlite = [\"INTEGER\"];\r\n  BaseTypes.BIGINT.types.sqlite = [\"BIGINT\"];\r\n  BaseTypes.FLOAT.types.sqlite = [\"FLOAT\"];\r\n  BaseTypes.TIME.types.sqlite = [\"TIME\"];\r\n  BaseTypes.DATEONLY.types.sqlite = [\"DATE\"];\r\n  BaseTypes.BOOLEAN.types.sqlite = [\"TINYINT\"];\r\n  BaseTypes.BLOB.types.sqlite = [\"TINYBLOB\", \"BLOB\", \"LONGBLOB\"];\r\n  BaseTypes.DECIMAL.types.sqlite = [\"DECIMAL\"];\r\n  BaseTypes.UUID.types.sqlite = [\"UUID\"];\r\n  BaseTypes.ENUM.types.sqlite = false;\r\n  BaseTypes.REAL.types.sqlite = [\"REAL\"];\r\n  BaseTypes.DOUBLE.types.sqlite = [\"DOUBLE PRECISION\"];\r\n  BaseTypes.GEOMETRY.types.sqlite = false;\r\n  BaseTypes.JSON.types.sqlite = [\"JSON\", \"JSONB\"];\r\n\r\n  class JSONTYPE extends BaseTypes.JSON {\r\n    static parse(data) {\r\n      return JSON.parse(data);\r\n    }\r\n  }\r\n\r\n  class DATE extends BaseTypes.DATE {\r\n    static parse(date, options) {\r\n      return new Date(\r\n        date.replace(\" \", \"T\").replace(\" \" + options.timezone, \"+0000\")\r\n      ); // We already have a timezone stored in the string\r\n    }\r\n  }\r\n\r\n  class DATEONLY extends BaseTypes.DATEONLY {\r\n    static parse(date) {\r\n      return date;\r\n    }\r\n  }\r\n\r\n  class STRING extends BaseTypes.STRING {\r\n    toSql() {\r\n      if (this._binary) {\r\n        return `VARCHAR BINARY(${this._length})`;\r\n      }\r\n      return super.toSql(this);\r\n    }\r\n  }\r\n\r\n  class TEXT extends BaseTypes.TEXT {\r\n    toSql() {\r\n      if (this._length) {\r\n        warn(\r\n          \"SQLite does not support TEXT with options. Plain `TEXT` will be used instead.\"\r\n        );\r\n        this._length = undefined;\r\n      }\r\n      return \"TEXT\";\r\n    }\r\n  }\r\n\r\n  class CITEXT extends BaseTypes.CITEXT {\r\n    toSql() {\r\n      return \"TEXT COLLATE NOCASE\";\r\n    }\r\n  }\r\n\r\n  class CHAR extends BaseTypes.CHAR {\r\n    toSql() {\r\n      if (this._binary) {\r\n        return `CHAR BINARY(${this._length})`;\r\n      }\r\n      return super.toSql();\r\n    }\r\n  }\r\n\r\n  class NUMBER extends BaseTypes.NUMBER {\r\n    toSql() {\r\n      let result = this.key;\r\n      if (this._unsigned) {\r\n        result += \" UNSIGNED\";\r\n      }\r\n      if (this._zerofill) {\r\n        result += \" ZEROFILL\";\r\n      }\r\n      if (this._length) {\r\n        result += `(${this._length}`;\r\n        if (typeof this._decimals === \"number\") {\r\n          result += `,${this._decimals}`;\r\n        }\r\n        result += \")\";\r\n      }\r\n      return result;\r\n    }\r\n  }\r\n\r\n  class TINYINT extends BaseTypes.TINYINT {\r\n    constructor(length) {\r\n      super(length);\r\n      removeUnsupportedIntegerOptions(this);\r\n    }\r\n  }\r\n\r\n  class SMALLINT extends BaseTypes.SMALLINT {\r\n    constructor(length) {\r\n      super(length);\r\n      removeUnsupportedIntegerOptions(this);\r\n    }\r\n  }\r\n\r\n  class MEDIUMINT extends BaseTypes.MEDIUMINT {\r\n    constructor(length) {\r\n      super(length);\r\n      removeUnsupportedIntegerOptions(this);\r\n    }\r\n  }\r\n\r\n  class INTEGER extends BaseTypes.INTEGER {\r\n    constructor(length) {\r\n      super(length);\r\n      removeUnsupportedIntegerOptions(this);\r\n    }\r\n  }\r\n\r\n  class BIGINT extends BaseTypes.BIGINT {\r\n    constructor(length) {\r\n      super(length);\r\n      removeUnsupportedIntegerOptions(this);\r\n    }\r\n  }\r\n\r\n  class FLOAT extends BaseTypes.FLOAT {}\r\n\r\n  class DOUBLE extends BaseTypes.DOUBLE {}\r\n\r\n  class REAL extends BaseTypes.REAL {}\r\n\r\n  function parseFloating(value) {\r\n    if (typeof value !== \"string\") {\r\n      return value;\r\n    }\r\n    if (value === \"NaN\") {\r\n      return NaN;\r\n    }\r\n    if (value === \"Infinity\") {\r\n      return Infinity;\r\n    }\r\n    if (value === \"-Infinity\") {\r\n      return -Infinity;\r\n    }\r\n  }\r\n  for (const floating of [FLOAT, DOUBLE, REAL]) {\r\n    floating.parse = parseFloating;\r\n  }\r\n\r\n  for (const num of [\r\n    FLOAT,\r\n    DOUBLE,\r\n    REAL,\r\n    TINYINT,\r\n    SMALLINT,\r\n    MEDIUMINT,\r\n    INTEGER,\r\n    BIGINT\r\n  ]) {\r\n    num.prototype.toSql = NUMBER.prototype.toSql;\r\n  }\r\n\r\n  class ENUM extends BaseTypes.ENUM {\r\n    toSql() {\r\n      return \"TEXT\";\r\n    }\r\n  }\r\n\r\n  return {\r\n    DATE,\r\n    DATEONLY,\r\n    STRING,\r\n    CHAR,\r\n    NUMBER,\r\n    FLOAT,\r\n    REAL,\r\n    \"DOUBLE PRECISION\": DOUBLE,\r\n    TINYINT,\r\n    SMALLINT,\r\n    MEDIUMINT,\r\n    INTEGER,\r\n    BIGINT,\r\n    TEXT,\r\n    ENUM,\r\n    JSON: JSONTYPE,\r\n    CITEXT\r\n  };\r\n};\r\n"]} \ No newline at end of file +//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../lib/dialects/sqlite/data-types.js"],"names":["module","exports","BaseTypes","warn","ABSTRACT","bind","undefined","removeUnsupportedIntegerOptions","dataType","_zerofill","_unsigned","key","DATE","types","sqlite","STRING","CHAR","TEXT","TINYINT","SMALLINT","MEDIUMINT","INTEGER","BIGINT","FLOAT","TIME","DATEONLY","BOOLEAN","BLOB","DECIMAL","UUID","ENUM","REAL","DOUBLE","JSON","JSONTYPE","data","parse","date","options","Date","replace","_binary","_length","CITEXT","NUMBER","result","_decimals","length","parseFloating","value","NaN","Infinity","floating","num","prototype","toSql"],"mappings":"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","sourcesContent":["\"use strict\";\n\nmodule.exports = BaseTypes => {\n  const warn = BaseTypes.ABSTRACT.warn.bind(\n    undefined,\n    \"https://www.sqlite.org/datatype3.html\"\n  );\n\n  /**\n   * Removes unsupported SQLite options, i.e., UNSIGNED and ZEROFILL, for the integer data types.\n   *\n   * @param {Object} dataType The base integer data type.\n   * @private\n   */\n  function removeUnsupportedIntegerOptions(dataType) {\n    if (dataType._zerofill || dataType._unsigned) {\n      warn(\n        `SQLite does not support '${dataType.key}' with UNSIGNED or ZEROFILL. Plain '${dataType.key}' will be used instead.`\n      );\n      dataType._unsigned = undefined;\n      dataType._zerofill = undefined;\n    }\n  }\n\n  /**\n   * @see https://sqlite.org/datatype3.html\n   */\n\n  BaseTypes.DATE.types.sqlite = [\"DATETIME\"];\n  BaseTypes.STRING.types.sqlite = [\"VARCHAR\", \"VARCHAR BINARY\"];\n  BaseTypes.CHAR.types.sqlite = [\"CHAR\", \"CHAR BINARY\"];\n  BaseTypes.TEXT.types.sqlite = [\"TEXT\"];\n  BaseTypes.TINYINT.types.sqlite = [\"TINYINT\"];\n  BaseTypes.SMALLINT.types.sqlite = [\"SMALLINT\"];\n  BaseTypes.MEDIUMINT.types.sqlite = [\"MEDIUMINT\"];\n  BaseTypes.INTEGER.types.sqlite = [\"INTEGER\"];\n  BaseTypes.BIGINT.types.sqlite = [\"BIGINT\"];\n  BaseTypes.FLOAT.types.sqlite = [\"FLOAT\"];\n  BaseTypes.TIME.types.sqlite = [\"TIME\"];\n  BaseTypes.DATEONLY.types.sqlite = [\"DATE\"];\n  BaseTypes.BOOLEAN.types.sqlite = [\"TINYINT\"];\n  BaseTypes.BLOB.types.sqlite = [\"TINYBLOB\", \"BLOB\", \"LONGBLOB\"];\n  BaseTypes.DECIMAL.types.sqlite = [\"DECIMAL\"];\n  BaseTypes.UUID.types.sqlite = [\"UUID\"];\n  BaseTypes.ENUM.types.sqlite = false;\n  BaseTypes.REAL.types.sqlite = [\"REAL\"];\n  BaseTypes.DOUBLE.types.sqlite = [\"DOUBLE PRECISION\"];\n  BaseTypes.JSON.types.sqlite = [\"JSON\", \"JSONB\"];\n\n  class JSONTYPE extends BaseTypes.JSON {\n    static parse(data) {\n      return JSON.parse(data);\n    }\n  }\n\n  class DATE extends BaseTypes.DATE {\n    static parse(date, options) {\n      return new Date(date.replace(' ','T').replace(' +00:00','Z')); // We already have a timezone stored in the string\n    }\n  }\n\n  class DATEONLY extends BaseTypes.DATEONLY {\n    static parse(date) {\n      return date;\n    }\n  }\n\n  class STRING extends BaseTypes.STRING {\n    toSql() {\n      if (this._binary) {\n        return `VARCHAR BINARY(${this._length})`;\n      }\n      return super.toSql(this);\n    }\n  }\n\n  class TEXT extends BaseTypes.TEXT {\n    toSql() {\n      if (this._length) {\n        warn(\n          \"SQLite does not support TEXT with options. Plain `TEXT` will be used instead.\"\n        );\n        this._length = undefined;\n      }\n      return \"TEXT\";\n    }\n  }\n\n  class CITEXT extends BaseTypes.CITEXT {\n    toSql() {\n      return \"TEXT COLLATE NOCASE\";\n    }\n  }\n\n  class CHAR extends BaseTypes.CHAR {\n    toSql() {\n      if (this._binary) {\n        return `CHAR BINARY(${this._length})`;\n      }\n      return super.toSql();\n    }\n  }\n\n  class NUMBER extends BaseTypes.NUMBER {\n    toSql() {\n      let result = this.key;\n      if (this._unsigned) {\n        result += \" UNSIGNED\";\n      }\n      if (this._zerofill) {\n        result += \" ZEROFILL\";\n      }\n      if (this._length) {\n        result += `(${this._length}`;\n        if (typeof this._decimals === \"number\") {\n          result += `,${this._decimals}`;\n        }\n        result += \")\";\n      }\n      return result;\n    }\n  }\n\n  class TINYINT extends BaseTypes.TINYINT {\n    constructor(length) {\n      super(length);\n      removeUnsupportedIntegerOptions(this);\n    }\n  }\n\n  class SMALLINT extends BaseTypes.SMALLINT {\n    constructor(length) {\n      super(length);\n      removeUnsupportedIntegerOptions(this);\n    }\n  }\n\n  class MEDIUMINT extends BaseTypes.MEDIUMINT {\n    constructor(length) {\n      super(length);\n      removeUnsupportedIntegerOptions(this);\n    }\n  }\n\n  class INTEGER extends BaseTypes.INTEGER {\n    constructor(length) {\n      super(length);\n      removeUnsupportedIntegerOptions(this);\n    }\n  }\n\n  class BIGINT extends BaseTypes.BIGINT {\n    constructor(length) {\n      super(length);\n      removeUnsupportedIntegerOptions(this);\n    }\n  }\n\n  class FLOAT extends BaseTypes.FLOAT {}\n\n  class DOUBLE extends BaseTypes.DOUBLE {}\n\n  class REAL extends BaseTypes.REAL {}\n\n  function parseFloating(value) {\n    if (typeof value !== \"string\") {\n      return value;\n    }\n    if (value === \"NaN\") {\n      return NaN;\n    }\n    if (value === \"Infinity\") {\n      return Infinity;\n    }\n    if (value === \"-Infinity\") {\n      return -Infinity;\n    }\n  }\n  for (const floating of [FLOAT, DOUBLE, REAL]) {\n    floating.parse = parseFloating;\n  }\n\n  for (const num of [\n    FLOAT,\n    DOUBLE,\n    REAL,\n    TINYINT,\n    SMALLINT,\n    MEDIUMINT,\n    INTEGER,\n    BIGINT\n  ]) {\n    num.prototype.toSql = NUMBER.prototype.toSql;\n  }\n\n  class ENUM extends BaseTypes.ENUM {\n    toSql() {\n      return \"TEXT\";\n    }\n  }\n\n  return {\n    DATE,\n    DATEONLY,\n    STRING,\n    CHAR,\n    NUMBER,\n    FLOAT,\n    REAL,\n    \"DOUBLE PRECISION\": DOUBLE,\n    TINYINT,\n    SMALLINT,\n    MEDIUMINT,\n    INTEGER,\n    BIGINT,\n    TEXT,\n    ENUM,\n    JSON: JSONTYPE,\n    CITEXT\n  };\n};\n"]} \ No newline at end of file diff --git a/dist/dialects/sqlite/index.js b/dist/dialects/sqlite/index.js index 62f5b6e..b25c3a4 100644 --- a/dist/dialects/sqlite/index.js +++ b/dist/dialects/sqlite/index.js @@ -2,15 +2,19 @@ function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } } -function _possibleConstructorReturn(self, call) { if (call && (typeof call === "object" || typeof call === "function")) { return call; } return _assertThisInitialized(self); } +function _inherits(subClass, superClass) { if (typeof superClass !== "function" && superClass !== null) { throw new TypeError("Super expression must either be null or a function"); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, writable: true, configurable: true } }); if (superClass) _setPrototypeOf(subClass, superClass); } -function _getPrototypeOf(o) { _getPrototypeOf = Object.setPrototypeOf ? Object.getPrototypeOf : function _getPrototypeOf(o) { return o.__proto__ || Object.getPrototypeOf(o); }; return _getPrototypeOf(o); } +function _setPrototypeOf(o, p) { _setPrototypeOf = Object.setPrototypeOf || function _setPrototypeOf(o, p) { o.__proto__ = p; return o; }; return _setPrototypeOf(o, p); } + +function _createSuper(Derived) { var hasNativeReflectConstruct = _isNativeReflectConstruct(); return function _createSuperInternal() { var Super = _getPrototypeOf(Derived), result; if (hasNativeReflectConstruct) { var NewTarget = _getPrototypeOf(this).constructor; result = Reflect.construct(Super, arguments, NewTarget); } else { result = Super.apply(this, arguments); } return _possibleConstructorReturn(this, result); }; } + +function _possibleConstructorReturn(self, call) { if (call && (typeof call === "object" || typeof call === "function")) { return call; } return _assertThisInitialized(self); } function _assertThisInitialized(self) { if (self === void 0) { throw new ReferenceError("this hasn't been initialised - super() hasn't been called"); } return self; } -function _inherits(subClass, superClass) { if (typeof superClass !== "function" && superClass !== null) { throw new TypeError("Super expression must either be null or a function"); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, writable: true, configurable: true } }); if (superClass) _setPrototypeOf(subClass, superClass); } +function _isNativeReflectConstruct() { if (typeof Reflect === "undefined" || !Reflect.construct) return false; if (Reflect.construct.sham) return false; if (typeof Proxy === "function") return true; try { Date.prototype.toString.call(Reflect.construct(Date, [], function () {})); return true; } catch (e) { return false; } } -function _setPrototypeOf(o, p) { _setPrototypeOf = Object.setPrototypeOf || function _setPrototypeOf(o, p) { o.__proto__ = p; return o; }; return _setPrototypeOf(o, p); } +function _getPrototypeOf(o) { _getPrototypeOf = Object.setPrototypeOf ? Object.getPrototypeOf : function _getPrototypeOf(o) { return o.__proto__ || Object.getPrototypeOf(o); }; return _getPrototypeOf(o); } const _ = require('lodash'); @@ -24,17 +28,17 @@ const QueryGenerator = require('./query-generator'); const DataTypes = require('../../data-types').sqlite; -let SqliteDialect = -/*#__PURE__*/ -function (_AbstractDialect) { +let SqliteDialect = /*#__PURE__*/function (_AbstractDialect) { _inherits(SqliteDialect, _AbstractDialect); + var _super = _createSuper(SqliteDialect); + function SqliteDialect(sequelize) { var _this; _classCallCheck(this, SqliteDialect); - _this = _possibleConstructorReturn(this, _getPrototypeOf(SqliteDialect).call(this)); + _this = _super.call(this); _this.sequelize = sequelize; _this.connectionManager = new ConnectionManager(_assertThisInitialized(_this), sequelize); _this.QueryGenerator = new QueryGenerator({ @@ -82,4 +86,4 @@ SqliteDialect.prototype.TICK_CHAR_RIGHT = SqliteDialect.prototype.TICK_CHAR; module.exports = SqliteDialect; module.exports.SqliteDialect = SqliteDialect; module.exports.default = SqliteDialect; -//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uLy4uL2xpYi9kaWFsZWN0cy9zcWxpdGUvaW5kZXguanMiXSwibmFtZXMiOlsiXyIsInJlcXVpcmUiLCJBYnN0cmFjdERpYWxlY3QiLCJDb25uZWN0aW9uTWFuYWdlciIsIlF1ZXJ5IiwiUXVlcnlHZW5lcmF0b3IiLCJEYXRhVHlwZXMiLCJzcWxpdGUiLCJTcWxpdGVEaWFsZWN0Iiwic2VxdWVsaXplIiwiY29ubmVjdGlvbk1hbmFnZXIiLCJfZGlhbGVjdCIsInByb3RvdHlwZSIsInN1cHBvcnRzIiwibWVyZ2UiLCJjbG9uZURlZXAiLCJpbnNlcnRzIiwiaWdub3JlRHVwbGljYXRlcyIsInVwZGF0ZU9uRHVwbGljYXRlIiwiaW5kZXgiLCJ1c2luZyIsIndoZXJlIiwiZnVuY3Rpb25CYXNlZCIsInRyYW5zYWN0aW9uT3B0aW9ucyIsInR5cGUiLCJjb25zdHJhaW50cyIsImFkZENvbnN0cmFpbnQiLCJkcm9wQ29uc3RyYWludCIsImpvaW5UYWJsZURlcGVuZGVudCIsImdyb3VwZWRMaW1pdCIsIkpTT04iLCJkZWZhdWx0VmVyc2lvbiIsIm5hbWUiLCJUSUNLX0NIQVIiLCJUSUNLX0NIQVJfTEVGVCIsIlRJQ0tfQ0hBUl9SSUdIVCIsIm1vZHVsZSIsImV4cG9ydHMiLCJkZWZhdWx0Il0sIm1hcHBpbmdzIjoiQUFBQTs7Ozs7Ozs7Ozs7Ozs7QUFFQSxNQUFNQSxDQUFDLEdBQUdDLE9BQU8sQ0FBQyxRQUFELENBQWpCOztBQUNBLE1BQU1DLGVBQWUsR0FBR0QsT0FBTyxDQUFDLGFBQUQsQ0FBL0I7O0FBQ0EsTUFBTUUsaUJBQWlCLEdBQUdGLE9BQU8sQ0FBQyxzQkFBRCxDQUFqQzs7QUFDQSxNQUFNRyxLQUFLLEdBQUdILE9BQU8sQ0FBQyxTQUFELENBQXJCOztBQUNBLE1BQU1JLGNBQWMsR0FBR0osT0FBTyxDQUFDLG1CQUFELENBQTlCOztBQUNBLE1BQU1LLFNBQVMsR0FBR0wsT0FBTyxDQUFDLGtCQUFELENBQVAsQ0FBNEJNLE1BQTlDOztJQUVNQyxhOzs7OztBQUNKLHlCQUFZQyxTQUFaLEVBQXVCO0FBQUE7O0FBQUE7O0FBQ3JCO0FBQ0EsVUFBS0EsU0FBTCxHQUFpQkEsU0FBakI7QUFDQSxVQUFLQyxpQkFBTCxHQUF5QixJQUFJUCxpQkFBSixnQ0FBNEJNLFNBQTVCLENBQXpCO0FBQ0EsVUFBS0osY0FBTCxHQUFzQixJQUFJQSxjQUFKLENBQW1CO0FBQ3ZDTSxNQUFBQSxRQUFRLCtCQUQrQjtBQUV2Q0YsTUFBQUE7QUFGdUMsS0FBbkIsQ0FBdEI7QUFKcUI7QUFRdEI7OztFQVR5QlAsZTs7QUFZNUJNLGFBQWEsQ0FBQ0ksU0FBZCxDQUF3QkMsUUFBeEIsR0FBbUNiLENBQUMsQ0FBQ2MsS0FBRixDQUFRZCxDQUFDLENBQUNlLFNBQUYsQ0FBWWIsZUFBZSxDQUFDVSxTQUFoQixDQUEwQkMsUUFBdEMsQ0FBUixFQUF5RDtBQUMxRixhQUFXLEtBRCtFO0FBRTFGLG9CQUFrQixJQUZ3RTtBQUcxRixlQUFhLEtBSDZFO0FBSTFGLGdCQUFjLEtBSjRFO0FBSzFGRyxFQUFBQSxPQUFPLEVBQUU7QUFDUEMsSUFBQUEsZ0JBQWdCLEVBQUUsWUFEWDtBQUVQQyxJQUFBQSxpQkFBaUIsRUFBRTtBQUZaLEdBTGlGO0FBUzFGQyxFQUFBQSxLQUFLLEVBQUU7QUFDTEMsSUFBQUEsS0FBSyxFQUFFLEtBREY7QUFFTEMsSUFBQUEsS0FBSyxFQUFFLElBRkY7QUFHTEMsSUFBQUEsYUFBYSxFQUFFO0FBSFYsR0FUbUY7QUFjMUZDLEVBQUFBLGtCQUFrQixFQUFFO0FBQ2xCQyxJQUFBQSxJQUFJLEVBQUU7QUFEWSxHQWRzRTtBQWlCMUZDLEVBQUFBLFdBQVcsRUFBRTtBQUNYQyxJQUFBQSxhQUFhLEVBQUUsS0FESjtBQUVYQyxJQUFBQSxjQUFjLEVBQUU7QUFGTCxHQWpCNkU7QUFxQjFGQyxFQUFBQSxrQkFBa0IsRUFBRSxLQXJCc0U7QUFzQjFGQyxFQUFBQSxZQUFZLEVBQUUsS0F0QjRFO0FBdUIxRkMsRUFBQUEsSUFBSSxFQUFFO0FBdkJvRixDQUF6RCxDQUFuQztBQTBCQTNCLGlCQUFpQixDQUFDUyxTQUFsQixDQUE0Qm1CLGNBQTVCLEdBQTZDLE9BQTdDO0FBQ0F2QixhQUFhLENBQUNJLFNBQWQsQ0FBd0JSLEtBQXhCLEdBQWdDQSxLQUFoQztBQUNBSSxhQUFhLENBQUNJLFNBQWQsQ0FBd0JOLFNBQXhCLEdBQW9DQSxTQUFwQztBQUNBRSxhQUFhLENBQUNJLFNBQWQsQ0FBd0JvQixJQUF4QixHQUErQixRQUEvQjtBQUNBeEIsYUFBYSxDQUFDSSxTQUFkLENBQXdCcUIsU0FBeEIsR0FBb0MsR0FBcEM7QUFDQXpCLGFBQWEsQ0FBQ0ksU0FBZCxDQUF3QnNCLGNBQXhCLEdBQXlDMUIsYUFBYSxDQUFDSSxTQUFkLENBQXdCcUIsU0FBakU7QUFDQXpCLGFBQWEsQ0FBQ0ksU0FBZCxDQUF3QnVCLGVBQXhCLEdBQTBDM0IsYUFBYSxDQUFDSSxTQUFkLENBQXdCcUIsU0FBbEU7QUFFQUcsTUFBTSxDQUFDQyxPQUFQLEdBQWlCN0IsYUFBakI7QUFDQTRCLE1BQU0sQ0FBQ0MsT0FBUCxDQUFlN0IsYUFBZixHQUErQkEsYUFBL0I7QUFDQTRCLE1BQU0sQ0FBQ0MsT0FBUCxDQUFlQyxPQUFmLEdBQXlCOUIsYUFBekIiLCJzb3VyY2VzQ29udGVudCI6WyIndXNlIHN0cmljdCc7XHJcblxyXG5jb25zdCBfID0gcmVxdWlyZSgnbG9kYXNoJyk7XHJcbmNvbnN0IEFic3RyYWN0RGlhbGVjdCA9IHJlcXVpcmUoJy4uL2Fic3RyYWN0Jyk7XHJcbmNvbnN0IENvbm5lY3Rpb25NYW5hZ2VyID0gcmVxdWlyZSgnLi9jb25uZWN0aW9uLW1hbmFnZXInKTtcclxuY29uc3QgUXVlcnkgPSByZXF1aXJlKCcuL3F1ZXJ5Jyk7XHJcbmNvbnN0IFF1ZXJ5R2VuZXJhdG9yID0gcmVxdWlyZSgnLi9xdWVyeS1nZW5lcmF0b3InKTtcclxuY29uc3QgRGF0YVR5cGVzID0gcmVxdWlyZSgnLi4vLi4vZGF0YS10eXBlcycpLnNxbGl0ZTtcclxuXHJcbmNsYXNzIFNxbGl0ZURpYWxlY3QgZXh0ZW5kcyBBYnN0cmFjdERpYWxlY3Qge1xyXG4gIGNvbnN0cnVjdG9yKHNlcXVlbGl6ZSkge1xyXG4gICAgc3VwZXIoKTtcclxuICAgIHRoaXMuc2VxdWVsaXplID0gc2VxdWVsaXplO1xyXG4gICAgdGhpcy5jb25uZWN0aW9uTWFuYWdlciA9IG5ldyBDb25uZWN0aW9uTWFuYWdlcih0aGlzLCBzZXF1ZWxpemUpO1xyXG4gICAgdGhpcy5RdWVyeUdlbmVyYXRvciA9IG5ldyBRdWVyeUdlbmVyYXRvcih7XHJcbiAgICAgIF9kaWFsZWN0OiB0aGlzLFxyXG4gICAgICBzZXF1ZWxpemVcclxuICAgIH0pO1xyXG4gIH1cclxufVxyXG5cclxuU3FsaXRlRGlhbGVjdC5wcm90b3R5cGUuc3VwcG9ydHMgPSBfLm1lcmdlKF8uY2xvbmVEZWVwKEFic3RyYWN0RGlhbGVjdC5wcm90b3R5cGUuc3VwcG9ydHMpLCB7XHJcbiAgJ0RFRkFVTFQnOiBmYWxzZSxcclxuICAnREVGQVVMVCBWQUxVRVMnOiB0cnVlLFxyXG4gICdVTklPTiBBTEwnOiBmYWxzZSxcclxuICAnUklHSFQgSk9JTic6IGZhbHNlLFxyXG4gIGluc2VydHM6IHtcclxuICAgIGlnbm9yZUR1cGxpY2F0ZXM6ICcgT1IgSUdOT1JFJyxcclxuICAgIHVwZGF0ZU9uRHVwbGljYXRlOiAnIE9OIENPTkZMSUNUIERPIFVQREFURSBTRVQnXHJcbiAgfSxcclxuICBpbmRleDoge1xyXG4gICAgdXNpbmc6IGZhbHNlLFxyXG4gICAgd2hlcmU6IHRydWUsXHJcbiAgICBmdW5jdGlvbkJhc2VkOiB0cnVlXHJcbiAgfSxcclxuICB0cmFuc2FjdGlvbk9wdGlvbnM6IHtcclxuICAgIHR5cGU6IHRydWVcclxuICB9LFxyXG4gIGNvbnN0cmFpbnRzOiB7XHJcbiAgICBhZGRDb25zdHJhaW50OiBmYWxzZSxcclxuICAgIGRyb3BDb25zdHJhaW50OiBmYWxzZVxyXG4gIH0sXHJcbiAgam9pblRhYmxlRGVwZW5kZW50OiBmYWxzZSxcclxuICBncm91cGVkTGltaXQ6IGZhbHNlLFxyXG4gIEpTT046IHRydWVcclxufSk7XHJcblxyXG5Db25uZWN0aW9uTWFuYWdlci5wcm90b3R5cGUuZGVmYXVsdFZlcnNpb24gPSAnMy44LjAnO1xyXG5TcWxpdGVEaWFsZWN0LnByb3RvdHlwZS5RdWVyeSA9IFF1ZXJ5O1xyXG5TcWxpdGVEaWFsZWN0LnByb3RvdHlwZS5EYXRhVHlwZXMgPSBEYXRhVHlwZXM7XHJcblNxbGl0ZURpYWxlY3QucHJvdG90eXBlLm5hbWUgPSAnc3FsaXRlJztcclxuU3FsaXRlRGlhbGVjdC5wcm90b3R5cGUuVElDS19DSEFSID0gJ2AnO1xyXG5TcWxpdGVEaWFsZWN0LnByb3RvdHlwZS5USUNLX0NIQVJfTEVGVCA9IFNxbGl0ZURpYWxlY3QucHJvdG90eXBlLlRJQ0tfQ0hBUjtcclxuU3FsaXRlRGlhbGVjdC5wcm90b3R5cGUuVElDS19DSEFSX1JJR0hUID0gU3FsaXRlRGlhbGVjdC5wcm90b3R5cGUuVElDS19DSEFSO1xyXG5cclxubW9kdWxlLmV4cG9ydHMgPSBTcWxpdGVEaWFsZWN0O1xyXG5tb2R1bGUuZXhwb3J0cy5TcWxpdGVEaWFsZWN0ID0gU3FsaXRlRGlhbGVjdDtcclxubW9kdWxlLmV4cG9ydHMuZGVmYXVsdCA9IFNxbGl0ZURpYWxlY3Q7XHJcbiJdfQ== \ No newline at end of file +//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uLy4uL2xpYi9kaWFsZWN0cy9zcWxpdGUvaW5kZXguanMiXSwibmFtZXMiOlsiXyIsInJlcXVpcmUiLCJBYnN0cmFjdERpYWxlY3QiLCJDb25uZWN0aW9uTWFuYWdlciIsIlF1ZXJ5IiwiUXVlcnlHZW5lcmF0b3IiLCJEYXRhVHlwZXMiLCJzcWxpdGUiLCJTcWxpdGVEaWFsZWN0Iiwic2VxdWVsaXplIiwiY29ubmVjdGlvbk1hbmFnZXIiLCJfZGlhbGVjdCIsInByb3RvdHlwZSIsInN1cHBvcnRzIiwibWVyZ2UiLCJjbG9uZURlZXAiLCJpbnNlcnRzIiwiaWdub3JlRHVwbGljYXRlcyIsInVwZGF0ZU9uRHVwbGljYXRlIiwiaW5kZXgiLCJ1c2luZyIsIndoZXJlIiwiZnVuY3Rpb25CYXNlZCIsInRyYW5zYWN0aW9uT3B0aW9ucyIsInR5cGUiLCJjb25zdHJhaW50cyIsImFkZENvbnN0cmFpbnQiLCJkcm9wQ29uc3RyYWludCIsImpvaW5UYWJsZURlcGVuZGVudCIsImdyb3VwZWRMaW1pdCIsIkpTT04iLCJkZWZhdWx0VmVyc2lvbiIsIm5hbWUiLCJUSUNLX0NIQVIiLCJUSUNLX0NIQVJfTEVGVCIsIlRJQ0tfQ0hBUl9SSUdIVCIsIm1vZHVsZSIsImV4cG9ydHMiLCJkZWZhdWx0Il0sIm1hcHBpbmdzIjoiQUFBQTs7Ozs7Ozs7Ozs7Ozs7Ozs7O0FBRUEsTUFBTUEsQ0FBQyxHQUFHQyxPQUFPLENBQUMsUUFBRCxDQUFqQjs7QUFDQSxNQUFNQyxlQUFlLEdBQUdELE9BQU8sQ0FBQyxhQUFELENBQS9COztBQUNBLE1BQU1FLGlCQUFpQixHQUFHRixPQUFPLENBQUMsc0JBQUQsQ0FBakM7O0FBQ0EsTUFBTUcsS0FBSyxHQUFHSCxPQUFPLENBQUMsU0FBRCxDQUFyQjs7QUFDQSxNQUFNSSxjQUFjLEdBQUdKLE9BQU8sQ0FBQyxtQkFBRCxDQUE5Qjs7QUFDQSxNQUFNSyxTQUFTLEdBQUdMLE9BQU8sQ0FBQyxrQkFBRCxDQUFQLENBQTRCTSxNQUE5Qzs7SUFFTUMsYTs7Ozs7QUFDSix5QkFBWUMsU0FBWixFQUF1QjtBQUFBOztBQUFBOztBQUNyQjtBQUNBLFVBQUtBLFNBQUwsR0FBaUJBLFNBQWpCO0FBQ0EsVUFBS0MsaUJBQUwsR0FBeUIsSUFBSVAsaUJBQUosZ0NBQTRCTSxTQUE1QixDQUF6QjtBQUNBLFVBQUtKLGNBQUwsR0FBc0IsSUFBSUEsY0FBSixDQUFtQjtBQUN2Q00sTUFBQUEsUUFBUSwrQkFEK0I7QUFFdkNGLE1BQUFBO0FBRnVDLEtBQW5CLENBQXRCO0FBSnFCO0FBUXRCOzs7RUFUeUJQLGU7O0FBWTVCTSxhQUFhLENBQUNJLFNBQWQsQ0FBd0JDLFFBQXhCLEdBQW1DYixDQUFDLENBQUNjLEtBQUYsQ0FBUWQsQ0FBQyxDQUFDZSxTQUFGLENBQVliLGVBQWUsQ0FBQ1UsU0FBaEIsQ0FBMEJDLFFBQXRDLENBQVIsRUFBeUQ7QUFDMUYsYUFBVyxLQUQrRTtBQUUxRixvQkFBa0IsSUFGd0U7QUFHMUYsZUFBYSxLQUg2RTtBQUkxRixnQkFBYyxLQUo0RTtBQUsxRkcsRUFBQUEsT0FBTyxFQUFFO0FBQ1BDLElBQUFBLGdCQUFnQixFQUFFLFlBRFg7QUFFUEMsSUFBQUEsaUJBQWlCLEVBQUU7QUFGWixHQUxpRjtBQVMxRkMsRUFBQUEsS0FBSyxFQUFFO0FBQ0xDLElBQUFBLEtBQUssRUFBRSxLQURGO0FBRUxDLElBQUFBLEtBQUssRUFBRSxJQUZGO0FBR0xDLElBQUFBLGFBQWEsRUFBRTtBQUhWLEdBVG1GO0FBYzFGQyxFQUFBQSxrQkFBa0IsRUFBRTtBQUNsQkMsSUFBQUEsSUFBSSxFQUFFO0FBRFksR0Fkc0U7QUFpQjFGQyxFQUFBQSxXQUFXLEVBQUU7QUFDWEMsSUFBQUEsYUFBYSxFQUFFLEtBREo7QUFFWEMsSUFBQUEsY0FBYyxFQUFFO0FBRkwsR0FqQjZFO0FBcUIxRkMsRUFBQUEsa0JBQWtCLEVBQUUsS0FyQnNFO0FBc0IxRkMsRUFBQUEsWUFBWSxFQUFFLEtBdEI0RTtBQXVCMUZDLEVBQUFBLElBQUksRUFBRTtBQXZCb0YsQ0FBekQsQ0FBbkM7QUEwQkEzQixpQkFBaUIsQ0FBQ1MsU0FBbEIsQ0FBNEJtQixjQUE1QixHQUE2QyxPQUE3QztBQUNBdkIsYUFBYSxDQUFDSSxTQUFkLENBQXdCUixLQUF4QixHQUFnQ0EsS0FBaEM7QUFDQUksYUFBYSxDQUFDSSxTQUFkLENBQXdCTixTQUF4QixHQUFvQ0EsU0FBcEM7QUFDQUUsYUFBYSxDQUFDSSxTQUFkLENBQXdCb0IsSUFBeEIsR0FBK0IsUUFBL0I7QUFDQXhCLGFBQWEsQ0FBQ0ksU0FBZCxDQUF3QnFCLFNBQXhCLEdBQW9DLEdBQXBDO0FBQ0F6QixhQUFhLENBQUNJLFNBQWQsQ0FBd0JzQixjQUF4QixHQUF5QzFCLGFBQWEsQ0FBQ0ksU0FBZCxDQUF3QnFCLFNBQWpFO0FBQ0F6QixhQUFhLENBQUNJLFNBQWQsQ0FBd0J1QixlQUF4QixHQUEwQzNCLGFBQWEsQ0FBQ0ksU0FBZCxDQUF3QnFCLFNBQWxFO0FBRUFHLE1BQU0sQ0FBQ0MsT0FBUCxHQUFpQjdCLGFBQWpCO0FBQ0E0QixNQUFNLENBQUNDLE9BQVAsQ0FBZTdCLGFBQWYsR0FBK0JBLGFBQS9CO0FBQ0E0QixNQUFNLENBQUNDLE9BQVAsQ0FBZUMsT0FBZixHQUF5QjlCLGFBQXpCIiwic291cmNlc0NvbnRlbnQiOlsiJ3VzZSBzdHJpY3QnO1xuXG5jb25zdCBfID0gcmVxdWlyZSgnbG9kYXNoJyk7XG5jb25zdCBBYnN0cmFjdERpYWxlY3QgPSByZXF1aXJlKCcuLi9hYnN0cmFjdCcpO1xuY29uc3QgQ29ubmVjdGlvbk1hbmFnZXIgPSByZXF1aXJlKCcuL2Nvbm5lY3Rpb24tbWFuYWdlcicpO1xuY29uc3QgUXVlcnkgPSByZXF1aXJlKCcuL3F1ZXJ5Jyk7XG5jb25zdCBRdWVyeUdlbmVyYXRvciA9IHJlcXVpcmUoJy4vcXVlcnktZ2VuZXJhdG9yJyk7XG5jb25zdCBEYXRhVHlwZXMgPSByZXF1aXJlKCcuLi8uLi9kYXRhLXR5cGVzJykuc3FsaXRlO1xuXG5jbGFzcyBTcWxpdGVEaWFsZWN0IGV4dGVuZHMgQWJzdHJhY3REaWFsZWN0IHtcbiAgY29uc3RydWN0b3Ioc2VxdWVsaXplKSB7XG4gICAgc3VwZXIoKTtcbiAgICB0aGlzLnNlcXVlbGl6ZSA9IHNlcXVlbGl6ZTtcbiAgICB0aGlzLmNvbm5lY3Rpb25NYW5hZ2VyID0gbmV3IENvbm5lY3Rpb25NYW5hZ2VyKHRoaXMsIHNlcXVlbGl6ZSk7XG4gICAgdGhpcy5RdWVyeUdlbmVyYXRvciA9IG5ldyBRdWVyeUdlbmVyYXRvcih7XG4gICAgICBfZGlhbGVjdDogdGhpcyxcbiAgICAgIHNlcXVlbGl6ZVxuICAgIH0pO1xuICB9XG59XG5cblNxbGl0ZURpYWxlY3QucHJvdG90eXBlLnN1cHBvcnRzID0gXy5tZXJnZShfLmNsb25lRGVlcChBYnN0cmFjdERpYWxlY3QucHJvdG90eXBlLnN1cHBvcnRzKSwge1xuICAnREVGQVVMVCc6IGZhbHNlLFxuICAnREVGQVVMVCBWQUxVRVMnOiB0cnVlLFxuICAnVU5JT04gQUxMJzogZmFsc2UsXG4gICdSSUdIVCBKT0lOJzogZmFsc2UsXG4gIGluc2VydHM6IHtcbiAgICBpZ25vcmVEdXBsaWNhdGVzOiAnIE9SIElHTk9SRScsXG4gICAgdXBkYXRlT25EdXBsaWNhdGU6ICcgT04gQ09ORkxJQ1QgRE8gVVBEQVRFIFNFVCdcbiAgfSxcbiAgaW5kZXg6IHtcbiAgICB1c2luZzogZmFsc2UsXG4gICAgd2hlcmU6IHRydWUsXG4gICAgZnVuY3Rpb25CYXNlZDogdHJ1ZVxuICB9LFxuICB0cmFuc2FjdGlvbk9wdGlvbnM6IHtcbiAgICB0eXBlOiB0cnVlXG4gIH0sXG4gIGNvbnN0cmFpbnRzOiB7XG4gICAgYWRkQ29uc3RyYWludDogZmFsc2UsXG4gICAgZHJvcENvbnN0cmFpbnQ6IGZhbHNlXG4gIH0sXG4gIGpvaW5UYWJsZURlcGVuZGVudDogZmFsc2UsXG4gIGdyb3VwZWRMaW1pdDogZmFsc2UsXG4gIEpTT046IHRydWVcbn0pO1xuXG5Db25uZWN0aW9uTWFuYWdlci5wcm90b3R5cGUuZGVmYXVsdFZlcnNpb24gPSAnMy44LjAnO1xuU3FsaXRlRGlhbGVjdC5wcm90b3R5cGUuUXVlcnkgPSBRdWVyeTtcblNxbGl0ZURpYWxlY3QucHJvdG90eXBlLkRhdGFUeXBlcyA9IERhdGFUeXBlcztcblNxbGl0ZURpYWxlY3QucHJvdG90eXBlLm5hbWUgPSAnc3FsaXRlJztcblNxbGl0ZURpYWxlY3QucHJvdG90eXBlLlRJQ0tfQ0hBUiA9ICdgJztcblNxbGl0ZURpYWxlY3QucHJvdG90eXBlLlRJQ0tfQ0hBUl9MRUZUID0gU3FsaXRlRGlhbGVjdC5wcm90b3R5cGUuVElDS19DSEFSO1xuU3FsaXRlRGlhbGVjdC5wcm90b3R5cGUuVElDS19DSEFSX1JJR0hUID0gU3FsaXRlRGlhbGVjdC5wcm90b3R5cGUuVElDS19DSEFSO1xuXG5tb2R1bGUuZXhwb3J0cyA9IFNxbGl0ZURpYWxlY3Q7XG5tb2R1bGUuZXhwb3J0cy5TcWxpdGVEaWFsZWN0ID0gU3FsaXRlRGlhbGVjdDtcbm1vZHVsZS5leHBvcnRzLmRlZmF1bHQgPSBTcWxpdGVEaWFsZWN0O1xuIl19 \ No newline at end of file diff --git a/dist/dialects/sqlite/query-generator.js b/dist/dialects/sqlite/query-generator.js index 8060172..4493267 100644 --- a/dist/dialects/sqlite/query-generator.js +++ b/dist/dialects/sqlite/query-generator.js @@ -6,20 +6,24 @@ function _defineProperties(target, props) { for (var i = 0; i < props.length; i+ function _createClass(Constructor, protoProps, staticProps) { if (protoProps) _defineProperties(Constructor.prototype, protoProps); if (staticProps) _defineProperties(Constructor, staticProps); return Constructor; } -function _possibleConstructorReturn(self, call) { if (call && (typeof call === "object" || typeof call === "function")) { return call; } return _assertThisInitialized(self); } - -function _assertThisInitialized(self) { if (self === void 0) { throw new ReferenceError("this hasn't been initialised - super() hasn't been called"); } return self; } - function _get(target, property, receiver) { if (typeof Reflect !== "undefined" && Reflect.get) { _get = Reflect.get; } else { _get = function _get(target, property, receiver) { var base = _superPropBase(target, property); if (!base) return; var desc = Object.getOwnPropertyDescriptor(base, property); if (desc.get) { return desc.get.call(receiver); } return desc.value; }; } return _get(target, property, receiver || target); } function _superPropBase(object, property) { while (!Object.prototype.hasOwnProperty.call(object, property)) { object = _getPrototypeOf(object); if (object === null) break; } return object; } -function _getPrototypeOf(o) { _getPrototypeOf = Object.setPrototypeOf ? Object.getPrototypeOf : function _getPrototypeOf(o) { return o.__proto__ || Object.getPrototypeOf(o); }; return _getPrototypeOf(o); } - function _inherits(subClass, superClass) { if (typeof superClass !== "function" && superClass !== null) { throw new TypeError("Super expression must either be null or a function"); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, writable: true, configurable: true } }); if (superClass) _setPrototypeOf(subClass, superClass); } function _setPrototypeOf(o, p) { _setPrototypeOf = Object.setPrototypeOf || function _setPrototypeOf(o, p) { o.__proto__ = p; return o; }; return _setPrototypeOf(o, p); } +function _createSuper(Derived) { var hasNativeReflectConstruct = _isNativeReflectConstruct(); return function _createSuperInternal() { var Super = _getPrototypeOf(Derived), result; if (hasNativeReflectConstruct) { var NewTarget = _getPrototypeOf(this).constructor; result = Reflect.construct(Super, arguments, NewTarget); } else { result = Super.apply(this, arguments); } return _possibleConstructorReturn(this, result); }; } + +function _possibleConstructorReturn(self, call) { if (call && (typeof call === "object" || typeof call === "function")) { return call; } return _assertThisInitialized(self); } + +function _assertThisInitialized(self) { if (self === void 0) { throw new ReferenceError("this hasn't been initialised - super() hasn't been called"); } return self; } + +function _isNativeReflectConstruct() { if (typeof Reflect === "undefined" || !Reflect.construct) return false; if (Reflect.construct.sham) return false; if (typeof Proxy === "function") return true; try { Date.prototype.toString.call(Reflect.construct(Date, [], function () {})); return true; } catch (e) { return false; } } + +function _getPrototypeOf(o) { _getPrototypeOf = Object.setPrototypeOf ? Object.getPrototypeOf : function _getPrototypeOf(o) { return o.__proto__ || Object.getPrototypeOf(o); }; return _getPrototypeOf(o); } + const Utils = require('../../utils'); const Transaction = require('../../transaction'); @@ -30,15 +34,15 @@ const MySqlQueryGenerator = require('../mysql/query-generator'); const AbstractQueryGenerator = require('../abstract/query-generator'); -let SQLiteQueryGenerator = -/*#__PURE__*/ -function (_MySqlQueryGenerator) { +let SQLiteQueryGenerator = /*#__PURE__*/function (_MySqlQueryGenerator) { _inherits(SQLiteQueryGenerator, _MySqlQueryGenerator); + var _super = _createSuper(SQLiteQueryGenerator); + function SQLiteQueryGenerator() { _classCallCheck(this, SQLiteQueryGenerator); - return _possibleConstructorReturn(this, _getPrototypeOf(SQLiteQueryGenerator).apply(this, arguments)); + return _super.apply(this, arguments); } _createClass(SQLiteQueryGenerator, [{ @@ -541,4 +545,4 @@ function (_MySqlQueryGenerator) { }(MySqlQueryGenerator); module.exports = SQLiteQueryGenerator; -//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../lib/dialects/sqlite/query-generator.js"],"names":["Utils","require","Transaction","_","MySqlQueryGenerator","AbstractQueryGenerator","SQLiteQueryGenerator","tableName","attributes","options","primaryKeys","needsMultiplePrimaryKeys","values","filter","definition","includes","length","attrArray","attr","Object","prototype","hasOwnProperty","call","dataType","containsAutoIncrement","dataTypeString","substr","indexOf","push","replace","quoteIdentifier","table","quoteTable","attrStr","join","pkString","map","pk","uniqueKeys","each","columns","customIndex","fields","field","sql","replaceBooleanDefaults","value","stmt","jsonFunctionRegex","tokenCaptureRegex","currentIndex","openingBrackets","closingBrackets","hasJsonFunction","hasInvalidToken","string","functionMatches","exec","tokenMatches","capturedToken","Error","Date","toISOString","Array","isArray","val","smth","factory","prepend","Json","Cast","test","type","handleSequelizeMethod","key","attributesToSQL","context","attribute","insertValues","updateValues","where","model","ignoreDuplicates","bind","bindParam","upsertOptions","defaults","insert","insertQuery","rawAttributes","update","updateQuery","query","attrValueHash","removeNullValuesFromHash","omitNull","modelAttributeMap","SequelizeMethod","escape","undefined","format","whereOptions","limit","whereQuery","restartIdentity","addTicks","removeTicks","whereClause","getWhereConditions","result","name","fieldName","isObject","toString","allowNull","defaultValueSchemable","defaultValue","unique","primaryKey","autoIncrement","references","referencesTable","referencesKey","onDelete","toUpperCase","onUpdate","constraintName","indexNameOrAttributes","indexName","underscore","schema","schemaDelimiter","_schema","_schemaDelimiter","addSchema","backupTableName","quotedTableName","quotedBackupTableName","attributeNames","keys","createTableQuery","createTableSql","attrNameBefore","attrNameAfter","attributeNamesImport","attributeNamesExport","transaction","parent","ISOLATION_LEVELS","REPEATABLE_READ","READ_UNCOMMITTED","READ_COMMITTED","SERIALIZABLE","module","exports"],"mappings":"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","sourcesContent":["'use strict';\r\n\r\nconst Utils = require('../../utils');\r\nconst Transaction = require('../../transaction');\r\nconst _ = require('lodash');\r\nconst MySqlQueryGenerator = require('../mysql/query-generator');\r\nconst AbstractQueryGenerator = require('../abstract/query-generator');\r\n\r\nclass SQLiteQueryGenerator extends MySqlQueryGenerator {\r\n  createSchema() {\r\n    return \"SELECT name FROM `sqlite_master` WHERE type='table' and name!='sqlite_sequence';\";\r\n  }\r\n\r\n  showSchemasQuery() {\r\n    return \"SELECT name FROM `sqlite_master` WHERE type='table' and name!='sqlite_sequence';\";\r\n  }\r\n\r\n  versionQuery() {\r\n    return 'SELECT sqlite_version() as `version`';\r\n  }\r\n\r\n  createTableQuery(tableName, attributes, options) {\r\n    options = options || {};\r\n\r\n    const primaryKeys = [];\r\n    const needsMultiplePrimaryKeys = _.values(attributes).filter(definition => definition.includes('PRIMARY KEY')).length > 1;\r\n    const attrArray = [];\r\n\r\n    for (const attr in attributes) {\r\n      if (Object.prototype.hasOwnProperty.call(attributes, attr)) {\r\n        const dataType = attributes[attr];\r\n        const containsAutoIncrement = dataType.includes('AUTOINCREMENT');\r\n\r\n        let dataTypeString = dataType;\r\n        if (dataType.includes('PRIMARY KEY')) {\r\n          if (dataType.includes('INT')) {\r\n            // Only INTEGER is allowed for primary key, see https://github.com/sequelize/sequelize/issues/969 (no lenght, unsigned etc)\r\n            dataTypeString = containsAutoIncrement ? 'INTEGER PRIMARY KEY AUTOINCREMENT' : 'INTEGER PRIMARY KEY';\r\n\r\n            if (dataType.includes(' REFERENCES')) {\r\n              dataTypeString += dataType.substr(dataType.indexOf(' REFERENCES'));\r\n            }\r\n          }\r\n\r\n          if (needsMultiplePrimaryKeys) {\r\n            primaryKeys.push(attr);\r\n            dataTypeString = dataType.replace('PRIMARY KEY', 'NOT NULL');\r\n          }\r\n        }\r\n        attrArray.push(`${this.quoteIdentifier(attr)} ${dataTypeString}`);\r\n      }\r\n    }\r\n\r\n    const table = this.quoteTable(tableName);\r\n    let attrStr = attrArray.join(', ');\r\n    const pkString = primaryKeys.map(pk => this.quoteIdentifier(pk)).join(', ');\r\n\r\n    if (options.uniqueKeys) {\r\n      _.each(options.uniqueKeys, columns => {\r\n        if (columns.customIndex) {\r\n          attrStr += `, UNIQUE (${columns.fields.map(field => this.quoteIdentifier(field)).join(', ')})`;\r\n        }\r\n      });\r\n    }\r\n\r\n    if (pkString.length > 0) {\r\n      attrStr += `, PRIMARY KEY (${pkString})`;\r\n    }\r\n\r\n    const sql = `CREATE TABLE IF NOT EXISTS ${table} (${attrStr});`;\r\n    return this.replaceBooleanDefaults(sql);\r\n  }\r\n\r\n  booleanValue(value) {\r\n    return value ? 1 : 0;\r\n  }\r\n\r\n  /**\r\n   * Check whether the statmement is json function or simple path\r\n   *\r\n   * @param   {string}  stmt  The statement to validate\r\n   * @returns {boolean}       true if the given statement is json function\r\n   * @throws  {Error}         throw if the statement looks like json function but has invalid token\r\n   */\r\n  _checkValidJsonStatement(stmt) {\r\n    if (typeof stmt !== 'string') {\r\n      return false;\r\n    }\r\n\r\n    // https://sqlite.org/json1.html\r\n    const jsonFunctionRegex = /^\\s*(json(?:_[a-z]+){0,2})\\([^)]*\\)/i;\r\n    const tokenCaptureRegex = /^\\s*((?:([`\"'])(?:(?!\\2).|\\2{2})*\\2)|[\\w\\d\\s]+|[().,;+-])/i;\r\n\r\n    let currentIndex = 0;\r\n    let openingBrackets = 0;\r\n    let closingBrackets = 0;\r\n    let hasJsonFunction = false;\r\n    let hasInvalidToken = false;\r\n\r\n    while (currentIndex < stmt.length) {\r\n      const string = stmt.substr(currentIndex);\r\n      const functionMatches = jsonFunctionRegex.exec(string);\r\n      if (functionMatches) {\r\n        currentIndex += functionMatches[0].indexOf('(');\r\n        hasJsonFunction = true;\r\n        continue;\r\n      }\r\n\r\n      const tokenMatches = tokenCaptureRegex.exec(string);\r\n      if (tokenMatches) {\r\n        const capturedToken = tokenMatches[1];\r\n        if (capturedToken === '(') {\r\n          openingBrackets++;\r\n        } else if (capturedToken === ')') {\r\n          closingBrackets++;\r\n        } else if (capturedToken === ';') {\r\n          hasInvalidToken = true;\r\n          break;\r\n        }\r\n        currentIndex += tokenMatches[0].length;\r\n        continue;\r\n      }\r\n\r\n      break;\r\n    }\r\n\r\n    // Check invalid json statement\r\n    hasInvalidToken |= openingBrackets !== closingBrackets;\r\n    if (hasJsonFunction && hasInvalidToken) {\r\n      throw new Error(`Invalid json statement: ${stmt}`);\r\n    }\r\n\r\n    // return true if the statement has valid json function\r\n    return hasJsonFunction;\r\n  }\r\n\r\n  //sqlite can't cast to datetime so we need to convert date values to their ISO strings\r\n  _toJSONValue(value) {\r\n    if (value instanceof Date) {\r\n      return value.toISOString();\r\n    }\r\n    if (Array.isArray(value) && value[0] instanceof Date) {\r\n      return value.map(val => val.toISOString());\r\n    }\r\n    return value;\r\n  }\r\n\r\n\r\n  handleSequelizeMethod(smth, tableName, factory, options, prepend) {\r\n    if (smth instanceof Utils.Json) {\r\n      return super.handleSequelizeMethod(smth, tableName, factory, options, prepend);\r\n    }\r\n\r\n    if (smth instanceof Utils.Cast) {\r\n      if (/timestamp/i.test(smth.type)) {\r\n        smth.type = 'datetime';\r\n      }\r\n    }\r\n\r\n    return AbstractQueryGenerator.prototype.handleSequelizeMethod.call(this, smth, tableName, factory, options, prepend);\r\n  }\r\n\r\n  addColumnQuery(table, key, dataType) {\r\n    const attributes = {};\r\n    attributes[key] = dataType;\r\n    const fields = this.attributesToSQL(attributes, { context: 'addColumn' });\r\n    const attribute = `${this.quoteIdentifier(key)} ${fields[key]}`;\r\n\r\n    const sql = `ALTER TABLE ${this.quoteTable(table)} ADD ${attribute};`;\r\n\r\n    return this.replaceBooleanDefaults(sql);\r\n  }\r\n\r\n  showTablesQuery() {\r\n    return 'SELECT name FROM `sqlite_master` WHERE type=\\'table\\' and name!=\\'sqlite_sequence\\';';\r\n  }\r\n\r\n  upsertQuery(tableName, insertValues, updateValues, where, model, options) {\r\n    options.ignoreDuplicates = true;\r\n\r\n    const bind = [];\r\n    const bindParam = this.bindParam(bind);\r\n\r\n    const upsertOptions = _.defaults({ bindParam }, options);\r\n    const insert = this.insertQuery(tableName, insertValues, model.rawAttributes, upsertOptions);\r\n    const update = this.updateQuery(tableName, updateValues, where, upsertOptions, model.rawAttributes);\r\n\r\n    const query = `${insert.query} ${update.query}`;\r\n\r\n    return { query, bind };\r\n  }\r\n\r\n  updateQuery(tableName, attrValueHash, where, options, attributes) {\r\n    options = options || {};\r\n    _.defaults(options, this.options);\r\n\r\n    attrValueHash = Utils.removeNullValuesFromHash(attrValueHash, options.omitNull, options);\r\n\r\n    const modelAttributeMap = {};\r\n    const values = [];\r\n    const bind = [];\r\n    const bindParam = options.bindParam || this.bindParam(bind);\r\n\r\n    if (attributes) {\r\n      _.each(attributes, (attribute, key) => {\r\n        modelAttributeMap[key] = attribute;\r\n        if (attribute.field) {\r\n          modelAttributeMap[attribute.field] = attribute;\r\n        }\r\n      });\r\n    }\r\n\r\n    for (const key in attrValueHash) {\r\n      const value = attrValueHash[key];\r\n\r\n      if (value instanceof Utils.SequelizeMethod || options.bindParam === false) {\r\n        values.push(`${this.quoteIdentifier(key)}=${this.escape(value, modelAttributeMap && modelAttributeMap[key] || undefined, { context: 'UPDATE' })}`);\r\n      } else {\r\n        values.push(`${this.quoteIdentifier(key)}=${this.format(value, modelAttributeMap && modelAttributeMap[key] || undefined, { context: 'UPDATE' }, bindParam)}`);\r\n      }\r\n    }\r\n\r\n    let query;\r\n    const whereOptions = _.defaults({ bindParam }, options);\r\n\r\n    if (options.limit) {\r\n      query = `UPDATE ${this.quoteTable(tableName)} SET ${values.join(',')} WHERE rowid IN (SELECT rowid FROM ${this.quoteTable(tableName)} ${this.whereQuery(where, whereOptions)} LIMIT ${this.escape(options.limit)})`;\r\n    } else {\r\n      query = `UPDATE ${this.quoteTable(tableName)} SET ${values.join(',')} ${this.whereQuery(where, whereOptions)}`;\r\n    }\r\n\r\n    return { query, bind };\r\n  }\r\n\r\n  truncateTableQuery(tableName, options = {}) {\r\n    return [\r\n      `DELETE FROM ${this.quoteTable(tableName)}`,\r\n      options.restartIdentity ? `; DELETE FROM ${this.quoteTable('sqlite_sequence')} WHERE ${this.quoteIdentifier('name')} = ${Utils.addTicks(Utils.removeTicks(this.quoteTable(tableName), '`'), \"'\")};` : ''\r\n    ].join('');\r\n  }\r\n\r\n  deleteQuery(tableName, where, options = {}, model) {\r\n    _.defaults(options, this.options);\r\n\r\n    let whereClause = this.getWhereConditions(where, null, model, options);\r\n\r\n    if (whereClause) {\r\n      whereClause = `WHERE ${whereClause}`;\r\n    }\r\n\r\n    if (options.limit) {\r\n      whereClause = `WHERE rowid IN (SELECT rowid FROM ${this.quoteTable(tableName)} ${whereClause} LIMIT ${this.escape(options.limit)})`;\r\n    }\r\n\r\n    return `DELETE FROM ${this.quoteTable(tableName)} ${whereClause}`;\r\n  }\r\n\r\n  attributesToSQL(attributes) {\r\n    const result = {};\r\n\r\n    for (const name in attributes) {\r\n      const dataType = attributes[name];\r\n      const fieldName = dataType.field || name;\r\n\r\n      if (_.isObject(dataType)) {\r\n        let sql = dataType.type.toString();\r\n\r\n        if (Object.prototype.hasOwnProperty.call(dataType, 'allowNull') && !dataType.allowNull) {\r\n          sql += ' NOT NULL';\r\n        }\r\n\r\n        if (Utils.defaultValueSchemable(dataType.defaultValue)) {\r\n          // TODO thoroughly check that DataTypes.NOW will properly\r\n          // get populated on all databases as DEFAULT value\r\n          // i.e. mysql requires: DEFAULT CURRENT_TIMESTAMP\r\n          sql += ` DEFAULT ${this.escape(dataType.defaultValue, dataType)}`;\r\n        }\r\n\r\n        if (dataType.unique === true) {\r\n          sql += ' UNIQUE';\r\n        }\r\n\r\n        if (dataType.primaryKey) {\r\n          sql += ' PRIMARY KEY';\r\n\r\n          if (dataType.autoIncrement) {\r\n            sql += ' AUTOINCREMENT';\r\n          }\r\n        }\r\n\r\n        if (dataType.references) {\r\n          const referencesTable = this.quoteTable(dataType.references.model);\r\n\r\n          let referencesKey;\r\n          if (dataType.references.key) {\r\n            referencesKey = this.quoteIdentifier(dataType.references.key);\r\n          } else {\r\n            referencesKey = this.quoteIdentifier('id');\r\n          }\r\n\r\n          sql += ` REFERENCES ${referencesTable} (${referencesKey})`;\r\n\r\n          if (dataType.onDelete) {\r\n            sql += ` ON DELETE ${dataType.onDelete.toUpperCase()}`;\r\n          }\r\n\r\n          if (dataType.onUpdate) {\r\n            sql += ` ON UPDATE ${dataType.onUpdate.toUpperCase()}`;\r\n          }\r\n\r\n        }\r\n\r\n        result[fieldName] = sql;\r\n      } else {\r\n        result[fieldName] = dataType;\r\n      }\r\n    }\r\n\r\n    return result;\r\n  }\r\n\r\n  showIndexesQuery(tableName) {\r\n    return `PRAGMA INDEX_LIST(${this.quoteTable(tableName)})`;\r\n  }\r\n\r\n  showConstraintsQuery(tableName, constraintName) {\r\n    let sql = `SELECT sql FROM sqlite_master WHERE tbl_name='${tableName}'`;\r\n\r\n    if (constraintName) {\r\n      sql += ` AND sql LIKE '%${constraintName}%'`;\r\n    }\r\n\r\n    return `${sql};`;\r\n  }\r\n\r\n  removeIndexQuery(tableName, indexNameOrAttributes) {\r\n    let indexName = indexNameOrAttributes;\r\n\r\n    if (typeof indexName !== 'string') {\r\n      indexName = Utils.underscore(`${tableName}_${indexNameOrAttributes.join('_')}`);\r\n    }\r\n\r\n    return `DROP INDEX IF EXISTS ${this.quoteIdentifier(indexName)}`;\r\n  }\r\n\r\n  describeTableQuery(tableName, schema, schemaDelimiter) {\r\n    const table = {\r\n      _schema: schema,\r\n      _schemaDelimiter: schemaDelimiter,\r\n      tableName\r\n    };\r\n    return `PRAGMA TABLE_INFO(${this.quoteTable(this.addSchema(table))});`;\r\n  }\r\n\r\n  describeCreateTableQuery(tableName) {\r\n    return `SELECT sql FROM sqlite_master WHERE tbl_name='${tableName}';`;\r\n  }\r\n\r\n  removeColumnQuery(tableName, attributes) {\r\n\r\n    attributes = this.attributesToSQL(attributes);\r\n\r\n    let backupTableName;\r\n    if (typeof tableName === 'object') {\r\n      backupTableName = {\r\n        tableName: `${tableName.tableName}_backup`,\r\n        schema: tableName.schema\r\n      };\r\n    } else {\r\n      backupTableName = `${tableName}_backup`;\r\n    }\r\n\r\n    const quotedTableName = this.quoteTable(tableName);\r\n    const quotedBackupTableName = this.quoteTable(backupTableName);\r\n    const attributeNames = Object.keys(attributes).map(attr => this.quoteIdentifier(attr)).join(', ');\r\n\r\n    // Temporary table cannot work for foreign keys.\r\n    return `${this.createTableQuery(backupTableName, attributes)\r\n    }INSERT INTO ${quotedBackupTableName} SELECT ${attributeNames} FROM ${quotedTableName};`\r\n      + `DROP TABLE ${quotedTableName};${\r\n        this.createTableQuery(tableName, attributes)\r\n      }INSERT INTO ${quotedTableName} SELECT ${attributeNames} FROM ${quotedBackupTableName};`\r\n      + `DROP TABLE ${quotedBackupTableName};`;\r\n  }\r\n\r\n  _alterConstraintQuery(tableName, attributes, createTableSql) {\r\n    let backupTableName;\r\n\r\n    attributes = this.attributesToSQL(attributes);\r\n\r\n    if (typeof tableName === 'object') {\r\n      backupTableName = {\r\n        tableName: `${tableName.tableName}_backup`,\r\n        schema: tableName.schema\r\n      };\r\n    } else {\r\n      backupTableName = `${tableName}_backup`;\r\n    }\r\n    const quotedTableName = this.quoteTable(tableName);\r\n    const quotedBackupTableName = this.quoteTable(backupTableName);\r\n    const attributeNames = Object.keys(attributes).map(attr => this.quoteIdentifier(attr)).join(', ');\r\n\r\n    return `${createTableSql\r\n      .replace(`CREATE TABLE ${quotedTableName}`, `CREATE TABLE ${quotedBackupTableName}`)\r\n      .replace(`CREATE TABLE ${quotedTableName.replace(/`/g, '\"')}`, `CREATE TABLE ${quotedBackupTableName}`)\r\n    }INSERT INTO ${quotedBackupTableName} SELECT ${attributeNames} FROM ${quotedTableName};`\r\n      + `DROP TABLE ${quotedTableName};`\r\n      + `ALTER TABLE ${quotedBackupTableName} RENAME TO ${quotedTableName};`;\r\n  }\r\n\r\n  renameColumnQuery(tableName, attrNameBefore, attrNameAfter, attributes) {\r\n\r\n    let backupTableName;\r\n\r\n    attributes = this.attributesToSQL(attributes);\r\n\r\n    if (typeof tableName === 'object') {\r\n      backupTableName = {\r\n        tableName: `${tableName.tableName}_backup`,\r\n        schema: tableName.schema\r\n      };\r\n    } else {\r\n      backupTableName = `${tableName}_backup`;\r\n    }\r\n\r\n    const quotedTableName = this.quoteTable(tableName);\r\n    const quotedBackupTableName = this.quoteTable(backupTableName);\r\n    const attributeNamesImport = Object.keys(attributes).map(attr =>\r\n      attrNameAfter === attr ? `${this.quoteIdentifier(attrNameBefore)} AS ${this.quoteIdentifier(attr)}` : this.quoteIdentifier(attr)\r\n    ).join(', ');\r\n    const attributeNamesExport = Object.keys(attributes).map(attr => this.quoteIdentifier(attr)).join(', ');\r\n\r\n    return `${this.createTableQuery(backupTableName, attributes).replace('CREATE TABLE', 'CREATE TEMPORARY TABLE')\r\n    }INSERT INTO ${quotedBackupTableName} SELECT ${attributeNamesImport} FROM ${quotedTableName};`\r\n      + `DROP TABLE ${quotedTableName};${\r\n        this.createTableQuery(tableName, attributes)\r\n      }INSERT INTO ${quotedTableName} SELECT ${attributeNamesExport} FROM ${quotedBackupTableName};`\r\n      + `DROP TABLE ${quotedBackupTableName};`;\r\n  }\r\n\r\n  startTransactionQuery(transaction) {\r\n    if (transaction.parent) {\r\n      return `SAVEPOINT ${this.quoteIdentifier(transaction.name)};`;\r\n    }\r\n\r\n    return `BEGIN ${transaction.options.type} TRANSACTION;`;\r\n  }\r\n\r\n  setIsolationLevelQuery(value) {\r\n    switch (value) {\r\n      case Transaction.ISOLATION_LEVELS.REPEATABLE_READ:\r\n        return '-- SQLite is not able to choose the isolation level REPEATABLE READ.';\r\n      case Transaction.ISOLATION_LEVELS.READ_UNCOMMITTED:\r\n        return 'PRAGMA read_uncommitted = ON;';\r\n      case Transaction.ISOLATION_LEVELS.READ_COMMITTED:\r\n        return 'PRAGMA read_uncommitted = OFF;';\r\n      case Transaction.ISOLATION_LEVELS.SERIALIZABLE:\r\n        return '-- SQLite\\'s default isolation level is SERIALIZABLE. Nothing to do.';\r\n      default:\r\n        throw new Error(`Unknown isolation level: ${value}`);\r\n    }\r\n  }\r\n\r\n  replaceBooleanDefaults(sql) {\r\n    return sql.replace(/DEFAULT '?false'?/g, 'DEFAULT 0').replace(/DEFAULT '?true'?/g, 'DEFAULT 1');\r\n  }\r\n\r\n  /**\r\n   * Generates an SQL query that returns all foreign keys of a table.\r\n   *\r\n   * @param  {string} tableName  The name of the table.\r\n   * @returns {string}            The generated sql query.\r\n   * @private\r\n   */\r\n  getForeignKeysQuery(tableName) {\r\n    return `PRAGMA foreign_key_list(${tableName})`;\r\n  }\r\n}\r\n\r\nmodule.exports = SQLiteQueryGenerator;\r\n"]} \ No newline at end of file +//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../lib/dialects/sqlite/query-generator.js"],"names":["Utils","require","Transaction","_","MySqlQueryGenerator","AbstractQueryGenerator","SQLiteQueryGenerator","tableName","attributes","options","primaryKeys","needsMultiplePrimaryKeys","values","filter","definition","includes","length","attrArray","attr","Object","prototype","hasOwnProperty","call","dataType","containsAutoIncrement","dataTypeString","substr","indexOf","push","replace","quoteIdentifier","table","quoteTable","attrStr","join","pkString","map","pk","uniqueKeys","each","columns","customIndex","fields","field","sql","replaceBooleanDefaults","value","stmt","jsonFunctionRegex","tokenCaptureRegex","currentIndex","openingBrackets","closingBrackets","hasJsonFunction","hasInvalidToken","string","functionMatches","exec","tokenMatches","capturedToken","Error","Date","toISOString","Array","isArray","val","smth","factory","prepend","Json","Cast","test","type","handleSequelizeMethod","key","attributesToSQL","context","attribute","insertValues","updateValues","where","model","ignoreDuplicates","bind","bindParam","upsertOptions","defaults","insert","insertQuery","rawAttributes","update","updateQuery","query","attrValueHash","removeNullValuesFromHash","omitNull","modelAttributeMap","SequelizeMethod","escape","undefined","format","whereOptions","limit","whereQuery","restartIdentity","addTicks","removeTicks","whereClause","getWhereConditions","result","name","fieldName","isObject","toString","allowNull","defaultValueSchemable","defaultValue","unique","primaryKey","autoIncrement","references","referencesTable","referencesKey","onDelete","toUpperCase","onUpdate","constraintName","indexNameOrAttributes","indexName","underscore","schema","schemaDelimiter","_schema","_schemaDelimiter","addSchema","backupTableName","quotedTableName","quotedBackupTableName","attributeNames","keys","createTableQuery","createTableSql","attrNameBefore","attrNameAfter","attributeNamesImport","attributeNamesExport","transaction","parent","ISOLATION_LEVELS","REPEATABLE_READ","READ_UNCOMMITTED","READ_COMMITTED","SERIALIZABLE","module","exports"],"mappings":"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","sourcesContent":["'use strict';\n\nconst Utils = require('../../utils');\nconst Transaction = require('../../transaction');\nconst _ = require('lodash');\nconst MySqlQueryGenerator = require('../mysql/query-generator');\nconst AbstractQueryGenerator = require('../abstract/query-generator');\n\nclass SQLiteQueryGenerator extends MySqlQueryGenerator {\n  createSchema() {\n    return \"SELECT name FROM `sqlite_master` WHERE type='table' and name!='sqlite_sequence';\";\n  }\n\n  showSchemasQuery() {\n    return \"SELECT name FROM `sqlite_master` WHERE type='table' and name!='sqlite_sequence';\";\n  }\n\n  versionQuery() {\n    return 'SELECT sqlite_version() as `version`';\n  }\n\n  createTableQuery(tableName, attributes, options) {\n    options = options || {};\n\n    const primaryKeys = [];\n    const needsMultiplePrimaryKeys = _.values(attributes).filter(definition => definition.includes('PRIMARY KEY')).length > 1;\n    const attrArray = [];\n\n    for (const attr in attributes) {\n      if (Object.prototype.hasOwnProperty.call(attributes, attr)) {\n        const dataType = attributes[attr];\n        const containsAutoIncrement = dataType.includes('AUTOINCREMENT');\n\n        let dataTypeString = dataType;\n        if (dataType.includes('PRIMARY KEY')) {\n          if (dataType.includes('INT')) {\n            // Only INTEGER is allowed for primary key, see https://github.com/sequelize/sequelize/issues/969 (no lenght, unsigned etc)\n            dataTypeString = containsAutoIncrement ? 'INTEGER PRIMARY KEY AUTOINCREMENT' : 'INTEGER PRIMARY KEY';\n\n            if (dataType.includes(' REFERENCES')) {\n              dataTypeString += dataType.substr(dataType.indexOf(' REFERENCES'));\n            }\n          }\n\n          if (needsMultiplePrimaryKeys) {\n            primaryKeys.push(attr);\n            dataTypeString = dataType.replace('PRIMARY KEY', 'NOT NULL');\n          }\n        }\n        attrArray.push(`${this.quoteIdentifier(attr)} ${dataTypeString}`);\n      }\n    }\n\n    const table = this.quoteTable(tableName);\n    let attrStr = attrArray.join(', ');\n    const pkString = primaryKeys.map(pk => this.quoteIdentifier(pk)).join(', ');\n\n    if (options.uniqueKeys) {\n      _.each(options.uniqueKeys, columns => {\n        if (columns.customIndex) {\n          attrStr += `, UNIQUE (${columns.fields.map(field => this.quoteIdentifier(field)).join(', ')})`;\n        }\n      });\n    }\n\n    if (pkString.length > 0) {\n      attrStr += `, PRIMARY KEY (${pkString})`;\n    }\n\n    const sql = `CREATE TABLE IF NOT EXISTS ${table} (${attrStr});`;\n    return this.replaceBooleanDefaults(sql);\n  }\n\n  booleanValue(value) {\n    return value ? 1 : 0;\n  }\n\n  /**\n   * Check whether the statmement is json function or simple path\n   *\n   * @param   {string}  stmt  The statement to validate\n   * @returns {boolean}       true if the given statement is json function\n   * @throws  {Error}         throw if the statement looks like json function but has invalid token\n   */\n  _checkValidJsonStatement(stmt) {\n    if (typeof stmt !== 'string') {\n      return false;\n    }\n\n    // https://sqlite.org/json1.html\n    const jsonFunctionRegex = /^\\s*(json(?:_[a-z]+){0,2})\\([^)]*\\)/i;\n    const tokenCaptureRegex = /^\\s*((?:([`\"'])(?:(?!\\2).|\\2{2})*\\2)|[\\w\\d\\s]+|[().,;+-])/i;\n\n    let currentIndex = 0;\n    let openingBrackets = 0;\n    let closingBrackets = 0;\n    let hasJsonFunction = false;\n    let hasInvalidToken = false;\n\n    while (currentIndex < stmt.length) {\n      const string = stmt.substr(currentIndex);\n      const functionMatches = jsonFunctionRegex.exec(string);\n      if (functionMatches) {\n        currentIndex += functionMatches[0].indexOf('(');\n        hasJsonFunction = true;\n        continue;\n      }\n\n      const tokenMatches = tokenCaptureRegex.exec(string);\n      if (tokenMatches) {\n        const capturedToken = tokenMatches[1];\n        if (capturedToken === '(') {\n          openingBrackets++;\n        } else if (capturedToken === ')') {\n          closingBrackets++;\n        } else if (capturedToken === ';') {\n          hasInvalidToken = true;\n          break;\n        }\n        currentIndex += tokenMatches[0].length;\n        continue;\n      }\n\n      break;\n    }\n\n    // Check invalid json statement\n    hasInvalidToken |= openingBrackets !== closingBrackets;\n    if (hasJsonFunction && hasInvalidToken) {\n      throw new Error(`Invalid json statement: ${stmt}`);\n    }\n\n    // return true if the statement has valid json function\n    return hasJsonFunction;\n  }\n\n  //sqlite can't cast to datetime so we need to convert date values to their ISO strings\n  _toJSONValue(value) {\n    if (value instanceof Date) {\n      return value.toISOString();\n    }\n    if (Array.isArray(value) && value[0] instanceof Date) {\n      return value.map(val => val.toISOString());\n    }\n    return value;\n  }\n\n\n  handleSequelizeMethod(smth, tableName, factory, options, prepend) {\n    if (smth instanceof Utils.Json) {\n      return super.handleSequelizeMethod(smth, tableName, factory, options, prepend);\n    }\n\n    if (smth instanceof Utils.Cast) {\n      if (/timestamp/i.test(smth.type)) {\n        smth.type = 'datetime';\n      }\n    }\n\n    return AbstractQueryGenerator.prototype.handleSequelizeMethod.call(this, smth, tableName, factory, options, prepend);\n  }\n\n  addColumnQuery(table, key, dataType) {\n    const attributes = {};\n    attributes[key] = dataType;\n    const fields = this.attributesToSQL(attributes, { context: 'addColumn' });\n    const attribute = `${this.quoteIdentifier(key)} ${fields[key]}`;\n\n    const sql = `ALTER TABLE ${this.quoteTable(table)} ADD ${attribute};`;\n\n    return this.replaceBooleanDefaults(sql);\n  }\n\n  showTablesQuery() {\n    return 'SELECT name FROM `sqlite_master` WHERE type=\\'table\\' and name!=\\'sqlite_sequence\\';';\n  }\n\n  upsertQuery(tableName, insertValues, updateValues, where, model, options) {\n    options.ignoreDuplicates = true;\n\n    const bind = [];\n    const bindParam = this.bindParam(bind);\n\n    const upsertOptions = _.defaults({ bindParam }, options);\n    const insert = this.insertQuery(tableName, insertValues, model.rawAttributes, upsertOptions);\n    const update = this.updateQuery(tableName, updateValues, where, upsertOptions, model.rawAttributes);\n\n    const query = `${insert.query} ${update.query}`;\n\n    return { query, bind };\n  }\n\n  updateQuery(tableName, attrValueHash, where, options, attributes) {\n    options = options || {};\n    _.defaults(options, this.options);\n\n    attrValueHash = Utils.removeNullValuesFromHash(attrValueHash, options.omitNull, options);\n\n    const modelAttributeMap = {};\n    const values = [];\n    const bind = [];\n    const bindParam = options.bindParam || this.bindParam(bind);\n\n    if (attributes) {\n      _.each(attributes, (attribute, key) => {\n        modelAttributeMap[key] = attribute;\n        if (attribute.field) {\n          modelAttributeMap[attribute.field] = attribute;\n        }\n      });\n    }\n\n    for (const key in attrValueHash) {\n      const value = attrValueHash[key];\n\n      if (value instanceof Utils.SequelizeMethod || options.bindParam === false) {\n        values.push(`${this.quoteIdentifier(key)}=${this.escape(value, modelAttributeMap && modelAttributeMap[key] || undefined, { context: 'UPDATE' })}`);\n      } else {\n        values.push(`${this.quoteIdentifier(key)}=${this.format(value, modelAttributeMap && modelAttributeMap[key] || undefined, { context: 'UPDATE' }, bindParam)}`);\n      }\n    }\n\n    let query;\n    const whereOptions = _.defaults({ bindParam }, options);\n\n    if (options.limit) {\n      query = `UPDATE ${this.quoteTable(tableName)} SET ${values.join(',')} WHERE rowid IN (SELECT rowid FROM ${this.quoteTable(tableName)} ${this.whereQuery(where, whereOptions)} LIMIT ${this.escape(options.limit)})`;\n    } else {\n      query = `UPDATE ${this.quoteTable(tableName)} SET ${values.join(',')} ${this.whereQuery(where, whereOptions)}`;\n    }\n\n    return { query, bind };\n  }\n\n  truncateTableQuery(tableName, options = {}) {\n    return [\n      `DELETE FROM ${this.quoteTable(tableName)}`,\n      options.restartIdentity ? `; DELETE FROM ${this.quoteTable('sqlite_sequence')} WHERE ${this.quoteIdentifier('name')} = ${Utils.addTicks(Utils.removeTicks(this.quoteTable(tableName), '`'), \"'\")};` : ''\n    ].join('');\n  }\n\n  deleteQuery(tableName, where, options = {}, model) {\n    _.defaults(options, this.options);\n\n    let whereClause = this.getWhereConditions(where, null, model, options);\n\n    if (whereClause) {\n      whereClause = `WHERE ${whereClause}`;\n    }\n\n    if (options.limit) {\n      whereClause = `WHERE rowid IN (SELECT rowid FROM ${this.quoteTable(tableName)} ${whereClause} LIMIT ${this.escape(options.limit)})`;\n    }\n\n    return `DELETE FROM ${this.quoteTable(tableName)} ${whereClause}`;\n  }\n\n  attributesToSQL(attributes) {\n    const result = {};\n\n    for (const name in attributes) {\n      const dataType = attributes[name];\n      const fieldName = dataType.field || name;\n\n      if (_.isObject(dataType)) {\n        let sql = dataType.type.toString();\n\n        if (Object.prototype.hasOwnProperty.call(dataType, 'allowNull') && !dataType.allowNull) {\n          sql += ' NOT NULL';\n        }\n\n        if (Utils.defaultValueSchemable(dataType.defaultValue)) {\n          // TODO thoroughly check that DataTypes.NOW will properly\n          // get populated on all databases as DEFAULT value\n          // i.e. mysql requires: DEFAULT CURRENT_TIMESTAMP\n          sql += ` DEFAULT ${this.escape(dataType.defaultValue, dataType)}`;\n        }\n\n        if (dataType.unique === true) {\n          sql += ' UNIQUE';\n        }\n\n        if (dataType.primaryKey) {\n          sql += ' PRIMARY KEY';\n\n          if (dataType.autoIncrement) {\n            sql += ' AUTOINCREMENT';\n          }\n        }\n\n        if (dataType.references) {\n          const referencesTable = this.quoteTable(dataType.references.model);\n\n          let referencesKey;\n          if (dataType.references.key) {\n            referencesKey = this.quoteIdentifier(dataType.references.key);\n          } else {\n            referencesKey = this.quoteIdentifier('id');\n          }\n\n          sql += ` REFERENCES ${referencesTable} (${referencesKey})`;\n\n          if (dataType.onDelete) {\n            sql += ` ON DELETE ${dataType.onDelete.toUpperCase()}`;\n          }\n\n          if (dataType.onUpdate) {\n            sql += ` ON UPDATE ${dataType.onUpdate.toUpperCase()}`;\n          }\n\n        }\n\n        result[fieldName] = sql;\n      } else {\n        result[fieldName] = dataType;\n      }\n    }\n\n    return result;\n  }\n\n  showIndexesQuery(tableName) {\n    return `PRAGMA INDEX_LIST(${this.quoteTable(tableName)})`;\n  }\n\n  showConstraintsQuery(tableName, constraintName) {\n    let sql = `SELECT sql FROM sqlite_master WHERE tbl_name='${tableName}'`;\n\n    if (constraintName) {\n      sql += ` AND sql LIKE '%${constraintName}%'`;\n    }\n\n    return `${sql};`;\n  }\n\n  removeIndexQuery(tableName, indexNameOrAttributes) {\n    let indexName = indexNameOrAttributes;\n\n    if (typeof indexName !== 'string') {\n      indexName = Utils.underscore(`${tableName}_${indexNameOrAttributes.join('_')}`);\n    }\n\n    return `DROP INDEX IF EXISTS ${this.quoteIdentifier(indexName)}`;\n  }\n\n  describeTableQuery(tableName, schema, schemaDelimiter) {\n    const table = {\n      _schema: schema,\n      _schemaDelimiter: schemaDelimiter,\n      tableName\n    };\n    return `PRAGMA TABLE_INFO(${this.quoteTable(this.addSchema(table))});`;\n  }\n\n  describeCreateTableQuery(tableName) {\n    return `SELECT sql FROM sqlite_master WHERE tbl_name='${tableName}';`;\n  }\n\n  removeColumnQuery(tableName, attributes) {\n\n    attributes = this.attributesToSQL(attributes);\n\n    let backupTableName;\n    if (typeof tableName === 'object') {\n      backupTableName = {\n        tableName: `${tableName.tableName}_backup`,\n        schema: tableName.schema\n      };\n    } else {\n      backupTableName = `${tableName}_backup`;\n    }\n\n    const quotedTableName = this.quoteTable(tableName);\n    const quotedBackupTableName = this.quoteTable(backupTableName);\n    const attributeNames = Object.keys(attributes).map(attr => this.quoteIdentifier(attr)).join(', ');\n\n    // Temporary table cannot work for foreign keys.\n    return `${this.createTableQuery(backupTableName, attributes)\n    }INSERT INTO ${quotedBackupTableName} SELECT ${attributeNames} FROM ${quotedTableName};`\n      + `DROP TABLE ${quotedTableName};${\n        this.createTableQuery(tableName, attributes)\n      }INSERT INTO ${quotedTableName} SELECT ${attributeNames} FROM ${quotedBackupTableName};`\n      + `DROP TABLE ${quotedBackupTableName};`;\n  }\n\n  _alterConstraintQuery(tableName, attributes, createTableSql) {\n    let backupTableName;\n\n    attributes = this.attributesToSQL(attributes);\n\n    if (typeof tableName === 'object') {\n      backupTableName = {\n        tableName: `${tableName.tableName}_backup`,\n        schema: tableName.schema\n      };\n    } else {\n      backupTableName = `${tableName}_backup`;\n    }\n    const quotedTableName = this.quoteTable(tableName);\n    const quotedBackupTableName = this.quoteTable(backupTableName);\n    const attributeNames = Object.keys(attributes).map(attr => this.quoteIdentifier(attr)).join(', ');\n\n    return `${createTableSql\n      .replace(`CREATE TABLE ${quotedTableName}`, `CREATE TABLE ${quotedBackupTableName}`)\n      .replace(`CREATE TABLE ${quotedTableName.replace(/`/g, '\"')}`, `CREATE TABLE ${quotedBackupTableName}`)\n    }INSERT INTO ${quotedBackupTableName} SELECT ${attributeNames} FROM ${quotedTableName};`\n      + `DROP TABLE ${quotedTableName};`\n      + `ALTER TABLE ${quotedBackupTableName} RENAME TO ${quotedTableName};`;\n  }\n\n  renameColumnQuery(tableName, attrNameBefore, attrNameAfter, attributes) {\n\n    let backupTableName;\n\n    attributes = this.attributesToSQL(attributes);\n\n    if (typeof tableName === 'object') {\n      backupTableName = {\n        tableName: `${tableName.tableName}_backup`,\n        schema: tableName.schema\n      };\n    } else {\n      backupTableName = `${tableName}_backup`;\n    }\n\n    const quotedTableName = this.quoteTable(tableName);\n    const quotedBackupTableName = this.quoteTable(backupTableName);\n    const attributeNamesImport = Object.keys(attributes).map(attr =>\n      attrNameAfter === attr ? `${this.quoteIdentifier(attrNameBefore)} AS ${this.quoteIdentifier(attr)}` : this.quoteIdentifier(attr)\n    ).join(', ');\n    const attributeNamesExport = Object.keys(attributes).map(attr => this.quoteIdentifier(attr)).join(', ');\n\n    return `${this.createTableQuery(backupTableName, attributes).replace('CREATE TABLE', 'CREATE TEMPORARY TABLE')\n    }INSERT INTO ${quotedBackupTableName} SELECT ${attributeNamesImport} FROM ${quotedTableName};`\n      + `DROP TABLE ${quotedTableName};${\n        this.createTableQuery(tableName, attributes)\n      }INSERT INTO ${quotedTableName} SELECT ${attributeNamesExport} FROM ${quotedBackupTableName};`\n      + `DROP TABLE ${quotedBackupTableName};`;\n  }\n\n  startTransactionQuery(transaction) {\n    if (transaction.parent) {\n      return `SAVEPOINT ${this.quoteIdentifier(transaction.name)};`;\n    }\n\n    return `BEGIN ${transaction.options.type} TRANSACTION;`;\n  }\n\n  setIsolationLevelQuery(value) {\n    switch (value) {\n      case Transaction.ISOLATION_LEVELS.REPEATABLE_READ:\n        return '-- SQLite is not able to choose the isolation level REPEATABLE READ.';\n      case Transaction.ISOLATION_LEVELS.READ_UNCOMMITTED:\n        return 'PRAGMA read_uncommitted = ON;';\n      case Transaction.ISOLATION_LEVELS.READ_COMMITTED:\n        return 'PRAGMA read_uncommitted = OFF;';\n      case Transaction.ISOLATION_LEVELS.SERIALIZABLE:\n        return '-- SQLite\\'s default isolation level is SERIALIZABLE. Nothing to do.';\n      default:\n        throw new Error(`Unknown isolation level: ${value}`);\n    }\n  }\n\n  replaceBooleanDefaults(sql) {\n    return sql.replace(/DEFAULT '?false'?/g, 'DEFAULT 0').replace(/DEFAULT '?true'?/g, 'DEFAULT 1');\n  }\n\n  /**\n   * Generates an SQL query that returns all foreign keys of a table.\n   *\n   * @param  {string} tableName  The name of the table.\n   * @returns {string}            The generated sql query.\n   * @private\n   */\n  getForeignKeysQuery(tableName) {\n    return `PRAGMA foreign_key_list(${tableName})`;\n  }\n}\n\nmodule.exports = SQLiteQueryGenerator;\n"]} \ No newline at end of file diff --git a/dist/dialects/sqlite/query-interface.js b/dist/dialects/sqlite/query-interface.js index 7e42cfd..9d09032 100644 --- a/dist/dialects/sqlite/query-interface.js +++ b/dist/dialects/sqlite/query-interface.js @@ -211,4 +211,4 @@ function getForeignKeyReferencesForTable(qi, tableName, options) { } exports.getForeignKeyReferencesForTable = getForeignKeyReferencesForTable; -//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../lib/dialects/sqlite/query-interface.js"],"names":["_","require","Promise","sequelizeErrors","QueryTypes","removeColumn","qi","tableName","attributeName","options","describeTable","then","fields","sql","QueryGenerator","removeColumnQuery","subQueries","split","filter","q","each","subQuery","sequelize","query","Object","assign","raw","exports","changeColumn","attributes","keys","renameColumn","attrNameBefore","attrNameAfter","clone","renameColumnQuery","removeConstraint","constraintName","createTableSql","showConstraint","constraints","constraint","find","constaint","quoteIdentifier","constraintSnippet","constraintType","constraintCondition","referenceTableName","quoteTable","referenceTableKeys","map","columnName","join","updateAction","deleteAction","replace","UnknownConstraintError","message","table","_alterConstraintQuery","addConstraint","getConstraintSnippet","describeCreateTableSql","describeCreateTableQuery","type","SELECT","index","length","substr","getForeignKeyReferencesForTable","database","config","getForeignKeysQuery","result","row","from","referencedTableName","referencedColumnName","to","tableCatalog","referencedTableCatalog"],"mappings":"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","sourcesContent":["'use strict';\r\n\r\nconst _ = require('lodash');\r\nconst Promise = require('../../promise');\r\nconst sequelizeErrors = require('../../errors');\r\nconst QueryTypes = require('../../query-types');\r\n\r\n/**\r\n Returns an object that treats SQLite's inabilities to do certain queries.\r\n\r\n @class QueryInterface\r\n @static\r\n @private\r\n */\r\n\r\n/**\r\n  A wrapper that fixes SQLite's inability to remove columns from existing tables.\r\n  It will create a backup of the table, drop the table afterwards and create a\r\n  new table with the same name but without the obsolete column.\r\n\r\n  @param  {QueryInterface} qi\r\n  @param  {string} tableName     The name of the table.\r\n  @param  {string} attributeName The name of the attribute that we want to remove.\r\n  @param  {Object} options\r\n  @param  {boolean|Function} [options.logging] A function that logs the sql queries, or false for explicitly not logging these queries\r\n\r\n  @since 1.6.0\r\n  @private\r\n */\r\nfunction removeColumn(qi, tableName, attributeName, options) {\r\n  options = options || {};\r\n\r\n  return qi.describeTable(tableName, options).then(fields => {\r\n    delete fields[attributeName];\r\n\r\n    const sql = qi.QueryGenerator.removeColumnQuery(tableName, fields);\r\n    const subQueries = sql.split(';').filter(q => q !== '');\r\n\r\n    return Promise.each(subQueries, subQuery => qi.sequelize.query(`${subQuery};`, Object.assign({ raw: true }, options)));\r\n  });\r\n}\r\nexports.removeColumn = removeColumn;\r\n\r\n/**\r\n  A wrapper that fixes SQLite's inability to change columns from existing tables.\r\n  It will create a backup of the table, drop the table afterwards and create a\r\n  new table with the same name but with a modified version of the respective column.\r\n\r\n  @param  {QueryInterface} qi\r\n  @param  {string} tableName The name of the table.\r\n  @param  {Object} attributes An object with the attribute's name as key and its options as value object.\r\n  @param  {Object} options\r\n  @param  {boolean|Function} [options.logging] A function that logs the sql queries, or false for explicitly not logging these queries\r\n\r\n  @since 1.6.0\r\n  @private\r\n */\r\nfunction changeColumn(qi, tableName, attributes, options) {\r\n  const attributeName = Object.keys(attributes)[0];\r\n  options = options || {};\r\n\r\n  return qi.describeTable(tableName, options).then(fields => {\r\n    fields[attributeName] = attributes[attributeName];\r\n\r\n    const sql = qi.QueryGenerator.removeColumnQuery(tableName, fields);\r\n    const subQueries = sql.split(';').filter(q => q !== '');\r\n\r\n    return Promise.each(subQueries, subQuery => qi.sequelize.query(`${subQuery};`, Object.assign({ raw: true }, options)));\r\n  });\r\n}\r\nexports.changeColumn = changeColumn;\r\n\r\n/**\r\n  A wrapper that fixes SQLite's inability to rename columns from existing tables.\r\n  It will create a backup of the table, drop the table afterwards and create a\r\n  new table with the same name but with a renamed version of the respective column.\r\n\r\n  @param  {QueryInterface} qi\r\n  @param  {string} tableName The name of the table.\r\n  @param  {string} attrNameBefore The name of the attribute before it was renamed.\r\n  @param  {string} attrNameAfter The name of the attribute after it was renamed.\r\n  @param  {Object} options\r\n  @param  {boolean|Function} [options.logging] A function that logs the sql queries, or false for explicitly not logging these queries\r\n\r\n  @since 1.6.0\r\n  @private\r\n */\r\nfunction renameColumn(qi, tableName, attrNameBefore, attrNameAfter, options) {\r\n  options = options || {};\r\n\r\n  return qi.describeTable(tableName, options).then(fields => {\r\n    fields[attrNameAfter] = _.clone(fields[attrNameBefore]);\r\n    delete fields[attrNameBefore];\r\n\r\n    const sql = qi.QueryGenerator.renameColumnQuery(tableName, attrNameBefore, attrNameAfter, fields);\r\n    const subQueries = sql.split(';').filter(q => q !== '');\r\n\r\n    return Promise.each(subQueries, subQuery => qi.sequelize.query(`${subQuery};`, Object.assign({ raw: true }, options)));\r\n  });\r\n}\r\nexports.renameColumn = renameColumn;\r\n\r\n/**\r\n * @param {QueryInterface} qi\r\n * @param {string} tableName\r\n * @param {string} constraintName\r\n * @param {Object} options\r\n *\r\n * @private\r\n */\r\nfunction removeConstraint(qi, tableName, constraintName, options) {\r\n  let createTableSql;\r\n\r\n  return qi.showConstraint(tableName, constraintName)\r\n    .then(constraints => {\r\n      // sqlite can't show only one constraint, so we find here the one to remove\r\n      const constraint = constraints.find(constaint => constaint.constraintName === constraintName);\r\n\r\n      if (constraint) {\r\n        createTableSql = constraint.sql;\r\n        constraint.constraintName = qi.QueryGenerator.quoteIdentifier(constraint.constraintName);\r\n        let constraintSnippet = `, CONSTRAINT ${constraint.constraintName} ${constraint.constraintType} ${constraint.constraintCondition}`;\r\n\r\n        if (constraint.constraintType === 'FOREIGN KEY') {\r\n          const referenceTableName = qi.QueryGenerator.quoteTable(constraint.referenceTableName);\r\n          constraint.referenceTableKeys = constraint.referenceTableKeys.map(columnName => qi.QueryGenerator.quoteIdentifier(columnName));\r\n          const referenceTableKeys = constraint.referenceTableKeys.join(', ');\r\n          constraintSnippet += ` REFERENCES ${referenceTableName} (${referenceTableKeys})`;\r\n          constraintSnippet += ` ON UPDATE ${constraint.updateAction}`;\r\n          constraintSnippet += ` ON DELETE ${constraint.deleteAction}`;\r\n        }\r\n\r\n        createTableSql = createTableSql.replace(constraintSnippet, '');\r\n        createTableSql += ';';\r\n\r\n        return qi.describeTable(tableName, options);\r\n      }\r\n      throw new sequelizeErrors.UnknownConstraintError({\r\n        message: `Constraint ${constraintName} on table ${tableName} does not exist`,\r\n        constraint: constraintName,\r\n        table: tableName\r\n      });\r\n    })\r\n    .then(fields => {\r\n      const sql = qi.QueryGenerator._alterConstraintQuery(tableName, fields, createTableSql);\r\n      const subQueries = sql.split(';').filter(q => q !== '');\r\n\r\n      return Promise.each(subQueries, subQuery => qi.sequelize.query(`${subQuery};`, Object.assign({ raw: true }, options)));\r\n    });\r\n}\r\nexports.removeConstraint = removeConstraint;\r\n\r\n/**\r\n * @param {QueryInterface} qi\r\n * @param {string} tableName\r\n * @param {Object} options\r\n *\r\n * @private\r\n */\r\nfunction addConstraint(qi, tableName, options) {\r\n  const constraintSnippet = qi.QueryGenerator.getConstraintSnippet(tableName, options);\r\n  const describeCreateTableSql = qi.QueryGenerator.describeCreateTableQuery(tableName);\r\n  let createTableSql;\r\n\r\n  return qi.sequelize.query(describeCreateTableSql, Object.assign({}, options, { type: QueryTypes.SELECT, raw: true }))\r\n    .then(constraints => {\r\n      const sql = constraints[0].sql;\r\n      const index = sql.length - 1;\r\n      //Replace ending ')' with constraint snippet - Simulates String.replaceAt\r\n      //http://stackoverflow.com/questions/1431094\r\n      createTableSql = `${sql.substr(0, index)}, ${constraintSnippet})${sql.substr(index + 1)};`;\r\n\r\n      return qi.describeTable(tableName, options);\r\n    })\r\n    .then(fields => {\r\n      const sql = qi.QueryGenerator._alterConstraintQuery(tableName, fields, createTableSql);\r\n      const subQueries = sql.split(';').filter(q => q !== '');\r\n\r\n      return Promise.each(subQueries, subQuery => qi.sequelize.query(`${subQuery};`, Object.assign({ raw: true }, options)));\r\n    });\r\n}\r\nexports.addConstraint = addConstraint;\r\n\r\n/**\r\n * @param {QueryInterface} qi\r\n * @param {string} tableName\r\n * @param {Object} options  Query Options\r\n *\r\n * @private\r\n * @returns {Promise}\r\n */\r\nfunction getForeignKeyReferencesForTable(qi, tableName, options) {\r\n  const database = qi.sequelize.config.database;\r\n  const query = qi.QueryGenerator.getForeignKeysQuery(tableName, database);\r\n  return qi.sequelize.query(query, options)\r\n    .then(result => {\r\n      return result.map(row => ({\r\n        tableName,\r\n        columnName: row.from,\r\n        referencedTableName: row.table,\r\n        referencedColumnName: row.to,\r\n        tableCatalog: database,\r\n        referencedTableCatalog: database\r\n      }));\r\n    });\r\n}\r\n\r\nexports.getForeignKeyReferencesForTable = getForeignKeyReferencesForTable;\r\n"]} \ No newline at end of file +//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../lib/dialects/sqlite/query-interface.js"],"names":["_","require","Promise","sequelizeErrors","QueryTypes","removeColumn","qi","tableName","attributeName","options","describeTable","then","fields","sql","QueryGenerator","removeColumnQuery","subQueries","split","filter","q","each","subQuery","sequelize","query","Object","assign","raw","exports","changeColumn","attributes","keys","renameColumn","attrNameBefore","attrNameAfter","clone","renameColumnQuery","removeConstraint","constraintName","createTableSql","showConstraint","constraints","constraint","find","constaint","quoteIdentifier","constraintSnippet","constraintType","constraintCondition","referenceTableName","quoteTable","referenceTableKeys","map","columnName","join","updateAction","deleteAction","replace","UnknownConstraintError","message","table","_alterConstraintQuery","addConstraint","getConstraintSnippet","describeCreateTableSql","describeCreateTableQuery","type","SELECT","index","length","substr","getForeignKeyReferencesForTable","database","config","getForeignKeysQuery","result","row","from","referencedTableName","referencedColumnName","to","tableCatalog","referencedTableCatalog"],"mappings":"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","sourcesContent":["'use strict';\n\nconst _ = require('lodash');\nconst Promise = require('../../promise');\nconst sequelizeErrors = require('../../errors');\nconst QueryTypes = require('../../query-types');\n\n/**\n Returns an object that treats SQLite's inabilities to do certain queries.\n\n @class QueryInterface\n @static\n @private\n */\n\n/**\n  A wrapper that fixes SQLite's inability to remove columns from existing tables.\n  It will create a backup of the table, drop the table afterwards and create a\n  new table with the same name but without the obsolete column.\n\n  @param  {QueryInterface} qi\n  @param  {string} tableName     The name of the table.\n  @param  {string} attributeName The name of the attribute that we want to remove.\n  @param  {Object} options\n  @param  {boolean|Function} [options.logging] A function that logs the sql queries, or false for explicitly not logging these queries\n\n  @since 1.6.0\n  @private\n */\nfunction removeColumn(qi, tableName, attributeName, options) {\n  options = options || {};\n\n  return qi.describeTable(tableName, options).then(fields => {\n    delete fields[attributeName];\n\n    const sql = qi.QueryGenerator.removeColumnQuery(tableName, fields);\n    const subQueries = sql.split(';').filter(q => q !== '');\n\n    return Promise.each(subQueries, subQuery => qi.sequelize.query(`${subQuery};`, Object.assign({ raw: true }, options)));\n  });\n}\nexports.removeColumn = removeColumn;\n\n/**\n  A wrapper that fixes SQLite's inability to change columns from existing tables.\n  It will create a backup of the table, drop the table afterwards and create a\n  new table with the same name but with a modified version of the respective column.\n\n  @param  {QueryInterface} qi\n  @param  {string} tableName The name of the table.\n  @param  {Object} attributes An object with the attribute's name as key and its options as value object.\n  @param  {Object} options\n  @param  {boolean|Function} [options.logging] A function that logs the sql queries, or false for explicitly not logging these queries\n\n  @since 1.6.0\n  @private\n */\nfunction changeColumn(qi, tableName, attributes, options) {\n  const attributeName = Object.keys(attributes)[0];\n  options = options || {};\n\n  return qi.describeTable(tableName, options).then(fields => {\n    fields[attributeName] = attributes[attributeName];\n\n    const sql = qi.QueryGenerator.removeColumnQuery(tableName, fields);\n    const subQueries = sql.split(';').filter(q => q !== '');\n\n    return Promise.each(subQueries, subQuery => qi.sequelize.query(`${subQuery};`, Object.assign({ raw: true }, options)));\n  });\n}\nexports.changeColumn = changeColumn;\n\n/**\n  A wrapper that fixes SQLite's inability to rename columns from existing tables.\n  It will create a backup of the table, drop the table afterwards and create a\n  new table with the same name but with a renamed version of the respective column.\n\n  @param  {QueryInterface} qi\n  @param  {string} tableName The name of the table.\n  @param  {string} attrNameBefore The name of the attribute before it was renamed.\n  @param  {string} attrNameAfter The name of the attribute after it was renamed.\n  @param  {Object} options\n  @param  {boolean|Function} [options.logging] A function that logs the sql queries, or false for explicitly not logging these queries\n\n  @since 1.6.0\n  @private\n */\nfunction renameColumn(qi, tableName, attrNameBefore, attrNameAfter, options) {\n  options = options || {};\n\n  return qi.describeTable(tableName, options).then(fields => {\n    fields[attrNameAfter] = _.clone(fields[attrNameBefore]);\n    delete fields[attrNameBefore];\n\n    const sql = qi.QueryGenerator.renameColumnQuery(tableName, attrNameBefore, attrNameAfter, fields);\n    const subQueries = sql.split(';').filter(q => q !== '');\n\n    return Promise.each(subQueries, subQuery => qi.sequelize.query(`${subQuery};`, Object.assign({ raw: true }, options)));\n  });\n}\nexports.renameColumn = renameColumn;\n\n/**\n * @param {QueryInterface} qi\n * @param {string} tableName\n * @param {string} constraintName\n * @param {Object} options\n *\n * @private\n */\nfunction removeConstraint(qi, tableName, constraintName, options) {\n  let createTableSql;\n\n  return qi.showConstraint(tableName, constraintName)\n    .then(constraints => {\n      // sqlite can't show only one constraint, so we find here the one to remove\n      const constraint = constraints.find(constaint => constaint.constraintName === constraintName);\n\n      if (constraint) {\n        createTableSql = constraint.sql;\n        constraint.constraintName = qi.QueryGenerator.quoteIdentifier(constraint.constraintName);\n        let constraintSnippet = `, CONSTRAINT ${constraint.constraintName} ${constraint.constraintType} ${constraint.constraintCondition}`;\n\n        if (constraint.constraintType === 'FOREIGN KEY') {\n          const referenceTableName = qi.QueryGenerator.quoteTable(constraint.referenceTableName);\n          constraint.referenceTableKeys = constraint.referenceTableKeys.map(columnName => qi.QueryGenerator.quoteIdentifier(columnName));\n          const referenceTableKeys = constraint.referenceTableKeys.join(', ');\n          constraintSnippet += ` REFERENCES ${referenceTableName} (${referenceTableKeys})`;\n          constraintSnippet += ` ON UPDATE ${constraint.updateAction}`;\n          constraintSnippet += ` ON DELETE ${constraint.deleteAction}`;\n        }\n\n        createTableSql = createTableSql.replace(constraintSnippet, '');\n        createTableSql += ';';\n\n        return qi.describeTable(tableName, options);\n      }\n      throw new sequelizeErrors.UnknownConstraintError({\n        message: `Constraint ${constraintName} on table ${tableName} does not exist`,\n        constraint: constraintName,\n        table: tableName\n      });\n    })\n    .then(fields => {\n      const sql = qi.QueryGenerator._alterConstraintQuery(tableName, fields, createTableSql);\n      const subQueries = sql.split(';').filter(q => q !== '');\n\n      return Promise.each(subQueries, subQuery => qi.sequelize.query(`${subQuery};`, Object.assign({ raw: true }, options)));\n    });\n}\nexports.removeConstraint = removeConstraint;\n\n/**\n * @param {QueryInterface} qi\n * @param {string} tableName\n * @param {Object} options\n *\n * @private\n */\nfunction addConstraint(qi, tableName, options) {\n  const constraintSnippet = qi.QueryGenerator.getConstraintSnippet(tableName, options);\n  const describeCreateTableSql = qi.QueryGenerator.describeCreateTableQuery(tableName);\n  let createTableSql;\n\n  return qi.sequelize.query(describeCreateTableSql, Object.assign({}, options, { type: QueryTypes.SELECT, raw: true }))\n    .then(constraints => {\n      const sql = constraints[0].sql;\n      const index = sql.length - 1;\n      //Replace ending ')' with constraint snippet - Simulates String.replaceAt\n      //http://stackoverflow.com/questions/1431094\n      createTableSql = `${sql.substr(0, index)}, ${constraintSnippet})${sql.substr(index + 1)};`;\n\n      return qi.describeTable(tableName, options);\n    })\n    .then(fields => {\n      const sql = qi.QueryGenerator._alterConstraintQuery(tableName, fields, createTableSql);\n      const subQueries = sql.split(';').filter(q => q !== '');\n\n      return Promise.each(subQueries, subQuery => qi.sequelize.query(`${subQuery};`, Object.assign({ raw: true }, options)));\n    });\n}\nexports.addConstraint = addConstraint;\n\n/**\n * @param {QueryInterface} qi\n * @param {string} tableName\n * @param {Object} options  Query Options\n *\n * @private\n * @returns {Promise}\n */\nfunction getForeignKeyReferencesForTable(qi, tableName, options) {\n  const database = qi.sequelize.config.database;\n  const query = qi.QueryGenerator.getForeignKeysQuery(tableName, database);\n  return qi.sequelize.query(query, options)\n    .then(result => {\n      return result.map(row => ({\n        tableName,\n        columnName: row.from,\n        referencedTableName: row.table,\n        referencedColumnName: row.to,\n        tableCatalog: database,\n        referencedTableCatalog: database\n      }));\n    });\n}\n\nexports.getForeignKeyReferencesForTable = getForeignKeyReferencesForTable;\n"]} \ No newline at end of file diff --git a/dist/dialects/sqlite/query.js b/dist/dialects/sqlite/query.js index 2c2296a..ee64954 100644 --- a/dist/dialects/sqlite/query.js +++ b/dist/dialects/sqlite/query.js @@ -6,15 +6,19 @@ function _defineProperties(target, props) { for (var i = 0; i < props.length; i+ function _createClass(Constructor, protoProps, staticProps) { if (protoProps) _defineProperties(Constructor.prototype, protoProps); if (staticProps) _defineProperties(Constructor, staticProps); return Constructor; } +function _inherits(subClass, superClass) { if (typeof superClass !== "function" && superClass !== null) { throw new TypeError("Super expression must either be null or a function"); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, writable: true, configurable: true } }); if (superClass) _setPrototypeOf(subClass, superClass); } + +function _setPrototypeOf(o, p) { _setPrototypeOf = Object.setPrototypeOf || function _setPrototypeOf(o, p) { o.__proto__ = p; return o; }; return _setPrototypeOf(o, p); } + +function _createSuper(Derived) { var hasNativeReflectConstruct = _isNativeReflectConstruct(); return function _createSuperInternal() { var Super = _getPrototypeOf(Derived), result; if (hasNativeReflectConstruct) { var NewTarget = _getPrototypeOf(this).constructor; result = Reflect.construct(Super, arguments, NewTarget); } else { result = Super.apply(this, arguments); } return _possibleConstructorReturn(this, result); }; } + function _possibleConstructorReturn(self, call) { if (call && (typeof call === "object" || typeof call === "function")) { return call; } return _assertThisInitialized(self); } function _assertThisInitialized(self) { if (self === void 0) { throw new ReferenceError("this hasn't been initialised - super() hasn't been called"); } return self; } -function _getPrototypeOf(o) { _getPrototypeOf = Object.setPrototypeOf ? Object.getPrototypeOf : function _getPrototypeOf(o) { return o.__proto__ || Object.getPrototypeOf(o); }; return _getPrototypeOf(o); } - -function _inherits(subClass, superClass) { if (typeof superClass !== "function" && superClass !== null) { throw new TypeError("Super expression must either be null or a function"); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, writable: true, configurable: true } }); if (superClass) _setPrototypeOf(subClass, superClass); } +function _isNativeReflectConstruct() { if (typeof Reflect === "undefined" || !Reflect.construct) return false; if (Reflect.construct.sham) return false; if (typeof Proxy === "function") return true; try { Date.prototype.toString.call(Reflect.construct(Date, [], function () {})); return true; } catch (e) { return false; } } -function _setPrototypeOf(o, p) { _setPrototypeOf = Object.setPrototypeOf || function _setPrototypeOf(o, p) { o.__proto__ = p; return o; }; return _setPrototypeOf(o, p); } +function _getPrototypeOf(o) { _getPrototypeOf = Object.setPrototypeOf ? Object.getPrototypeOf : function _getPrototypeOf(o) { return o.__proto__ || Object.getPrototypeOf(o); }; return _getPrototypeOf(o); } const _ = require("lodash"); @@ -47,15 +51,15 @@ const getMethods = obj => { return [...properties.keys()].filter(item => typeof obj[item] === "function"); }; -let Query = -/*#__PURE__*/ -function (_AbstractQuery) { +let Query = /*#__PURE__*/function (_AbstractQuery) { _inherits(Query, _AbstractQuery); + var _super = _createSuper(Query); + function Query() { _classCallCheck(this, Query); - return _possibleConstructorReturn(this, _getPrototypeOf(Query).apply(this, arguments)); + return _super.apply(this, arguments); } _createClass(Query, [{ @@ -364,7 +368,7 @@ function (_AbstractQuery) { return null; }; - if (method === "all" && typeof conn.exec === "function") { + if (method === "all") { let tableNames = []; if (this.options && this.options.tableNames) { @@ -420,8 +424,11 @@ function (_AbstractQuery) { } } //console.log(columnTypes) + + if (index === tableNames.length - 1) resolve(); + }, function (_, error) { + if (index === tableNames.length - 1) resolve(); }); - if (index === tableNames.length - 1) resolve(); }); }); } @@ -647,4 +654,4 @@ function (_AbstractQuery) { module.exports = Query; module.exports.Query = Query; module.exports.default = Query; -//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../lib/dialects/sqlite/query.js"],"names":["_","require","Utils","Promise","AbstractQuery","QueryTypes","sequelizeErrors","parserStore","logger","debug","debugContext","getMethods","obj","properties","Set","currentObj","Object","getOwnPropertyNames","map","item","add","getPrototypeOf","keys","filter","Query","include","prefix","ret","_include","key","as","model","merge","_collectModels","metaData","columnTypes","err","results","sql","formatError","result","instance","isInsertQuery","handleInsertQuery","autoIncrementAttribute","primaryKeyAttribute","rawAttributes","startId","getInsertIdField","changes","i","push","field","isShowTablesQuery","row","name","isShowConstraintsQuery","parseConstraintsFromSql","isSelectQuery","options","raw","handleSelectQuery","prefixes","mapValues","value","includes","lastind","lastIndexOf","substr","tableName","getTableName","toString","replace","tableTypes","forOwn","attribute","prototype","hasOwnProperty","call","applyParsers","isShowOrDescribeQuery","handleShowIndexesQuery","Array","isArray","defaultValue","_result","dflt_value","undefined","type","allowNull","notnull","primaryKey","pk","BULKUPDATE","BULKDELETE","UPSERT","VERSION","version","RAW","isUpdateQuery","parameters","formatBindParameters","bind","dialect","skipUnescape","method","getDatabaseMethod","complete","_logQuery","query","self","conn","connection","resolve","executeSql","startsWith","reject","exec","args","executionError","convertToArray","_handleQueryResponse","error","transaction","t","successCallback","rowsAffected","insertId","e","errorCallback","tableNames","length","sqlCommands","sqlCmd","rows","forEach","index","table","columns","match","col","colName","colType","trim","split","then","constraints","referenceTableName","referenceTableKeys","updateAction","deleteAction","splice","constraintSql","referencesRegex","referenceConditions","removeTicks","columnNames","column","constraintCondition","constraint","constraintName","constraintType","indexOf","toUpperCase","parse","get","timezone","sequelize","code","message","ForeignKeyConstraintError","parent","fields","columnWithTable","errors","ValidationErrorItem","getUniqueConstraintErrorMessage","uniqueKeys","isEqual","msg","UniqueConstraintError","TimeoutError","DatabaseError","data","reverse","primary","unique","run","seqno","order","isBulkUpdateQuery","toLowerCase","array","_array","values","bindParam","v","skipValueReplace","k","module","exports","default"],"mappings":"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","sourcesContent":["\"use strict\";\r\n\r\nconst _ = require(\"lodash\");\r\nconst Utils = require(\"../../utils\");\r\nconst Promise = require(\"../../promise\");\r\nconst AbstractQuery = require(\"../abstract/query\");\r\nconst QueryTypes = require(\"../../query-types\");\r\nconst sequelizeErrors = require(\"../../errors\");\r\nconst parserStore = require(\"../parserStore\")(\"sqlite\");\r\nconst { logger } = require(\"../../utils/logger\");\r\n\r\nconst debug = logger.debugContext(\"sql:sqlite\");\r\nconst getMethods = obj => {\r\n  let properties = new Set();\r\n  let currentObj = obj;\r\n  do {\r\n    Object.getOwnPropertyNames(currentObj).map(item => properties.add(item));\r\n  } while ((currentObj = Object.getPrototypeOf(currentObj)));\r\n  return [...properties.keys()].filter(item => typeof obj[item] === \"function\");\r\n};\r\nclass Query extends AbstractQuery {\r\n  getInsertIdField() {\r\n    return \"lastID\";\r\n  }\r\n\r\n  /**\r\n   * rewrite query with parameters.\r\n   *\r\n   * @param {string} sql\r\n   * @param {Array|Object} values\r\n   * @param {string} dialect\r\n   * @private\r\n   */\r\n  static formatBindParameters(sql, values, dialect) {\r\n    let bindParam;\r\n    if (Array.isArray(values)) {\r\n      bindParam = {};\r\n      values.forEach((v, i) => {\r\n        bindParam[`$${i + 1}`] = v;\r\n      });\r\n      sql = AbstractQuery.formatBindParameters(sql, values, dialect, {\r\n        skipValueReplace: true\r\n      })[0];\r\n    } else {\r\n      bindParam = {};\r\n      if (typeof values === \"object\") {\r\n        for (const k of Object.keys(values)) {\r\n          bindParam[`$${k}`] = values[k];\r\n        }\r\n      }\r\n      sql = AbstractQuery.formatBindParameters(sql, values, dialect, {\r\n        skipValueReplace: true\r\n      })[0];\r\n    }\r\n    return [sql, bindParam];\r\n  }\r\n\r\n  _collectModels(include, prefix) {\r\n    const ret = {};\r\n\r\n    if (include) {\r\n      for (const _include of include) {\r\n        let key;\r\n        if (!prefix) {\r\n          key = _include.as;\r\n        } else {\r\n          key = `${prefix}.${_include.as}`;\r\n        }\r\n        ret[key] = _include.model;\r\n\r\n        if (_include.include) {\r\n          _.merge(ret, this._collectModels(_include.include, key));\r\n        }\r\n      }\r\n    }\r\n\r\n    return ret;\r\n  }\r\n\r\n  _handleQueryResponse(metaData, columnTypes, err, results) {\r\n    if (err) {\r\n      err.sql = this.sql;\r\n      throw this.formatError(err);\r\n    }\r\n    let result = this.instance;\r\n    // add the inserted row id to the instance\r\n    if (this.isInsertQuery(results, metaData)) {\r\n      this.handleInsertQuery(results, metaData);\r\n      if (!this.instance) {\r\n        // handle bulkCreate AI primary key\r\n        if (\r\n          /*  metaData.constructor.name === \"Statement\" && */\r\n          this.model &&\r\n          this.model.autoIncrementAttribute &&\r\n          this.model.autoIncrementAttribute ===\r\n            this.model.primaryKeyAttribute &&\r\n          this.model.rawAttributes[this.model.primaryKeyAttribute]\r\n        ) {\r\n          const startId =\r\n            metaData[this.getInsertIdField()] - metaData.changes + 1;\r\n\r\n          result = [];\r\n          for (let i = startId; i < startId + metaData.changes; i++) {\r\n            result.push({\r\n              [this.model.rawAttributes[this.model.primaryKeyAttribute]\r\n                .field]: i\r\n            });\r\n          }\r\n        } else {\r\n          result = metaData[this.getInsertIdField()];\r\n        }\r\n      }\r\n    }\r\n\r\n    if (this.isShowTablesQuery()) {\r\n      return results.map(row => row.name);\r\n    }\r\n    if (this.isShowConstraintsQuery()) {\r\n      result = results;\r\n      if (results && results[0] && results[0].sql) {\r\n        result = this.parseConstraintsFromSql(results[0].sql);\r\n      }\r\n      return result;\r\n    }\r\n    if (this.isSelectQuery()) {\r\n      if (this.options.raw) {\r\n        return this.handleSelectQuery(results);\r\n      }\r\n      // This is a map of prefix strings to models, e.g. user.projects -> Project model\r\n      const prefixes = this._collectModels(this.options.include);\r\n\r\n      results = results.map(result => {\r\n        return _.mapValues(result, (value, name) => {\r\n          let model;\r\n          if (name.includes(\".\")) {\r\n            const lastind = name.lastIndexOf(\".\");\r\n\r\n            model = prefixes[name.substr(0, lastind)];\r\n\r\n            name = name.substr(lastind + 1);\r\n          } else {\r\n            model = this.options.model;\r\n          }\r\n\r\n          const tableName = model\r\n            .getTableName()\r\n            .toString()\r\n            .replace(/`/g, \"\");\r\n          const tableTypes = columnTypes[tableName] || {};\r\n\r\n          if (tableTypes && !(name in tableTypes)) {\r\n            // The column is aliased\r\n            _.forOwn(model.rawAttributes, (attribute, key) => {\r\n              if (name === key && attribute.field) {\r\n                name = attribute.field;\r\n                return false;\r\n              }\r\n            });\r\n          }\r\n\r\n          return Object.prototype.hasOwnProperty.call(tableTypes, name)\r\n            ? this.applyParsers(tableTypes[name], value)\r\n            : value;\r\n        });\r\n      });\r\n\r\n      return this.handleSelectQuery(results);\r\n    }\r\n    if (this.isShowOrDescribeQuery()) {\r\n      return results;\r\n    }\r\n    if (this.sql.includes(\"PRAGMA INDEX_LIST\")) {\r\n      return this.handleShowIndexesQuery(results);\r\n    }\r\n    if (this.sql.includes(\"PRAGMA INDEX_INFO\")) {\r\n      return results;\r\n    }\r\n    if (this.sql.includes(\"PRAGMA TABLE_INFO\")) {\r\n      // this is the sqlite way of getting the metadata of a table\r\n      result = {};\r\n\r\n      if (Array.isArray(results)) {\r\n        let defaultValue;\r\n        for (const _result of results) {\r\n          if (_result.dflt_value === null) {\r\n            // Column schema omits any \"DEFAULT ...\"\r\n            defaultValue = undefined;\r\n          } else if (_result.dflt_value === \"NULL\") {\r\n            // Column schema is a \"DEFAULT NULL\"\r\n            defaultValue = null;\r\n          } else {\r\n            defaultValue = _result.dflt_value;\r\n          }\r\n\r\n          result[_result.name] = {\r\n            type: _result.type,\r\n            allowNull: _result.notnull === 0,\r\n            defaultValue,\r\n            primaryKey: _result.pk !== 0\r\n          };\r\n\r\n          if (result[_result.name].type === \"TINYINT(1)\") {\r\n            result[_result.name].defaultValue = { \"0\": false, \"1\": true }[\r\n              result[_result.name].defaultValue\r\n            ];\r\n          }\r\n\r\n          if (typeof result[_result.name].defaultValue === \"string\") {\r\n            result[_result.name].defaultValue = result[\r\n              _result.name\r\n            ].defaultValue.replace(/'/g, \"\");\r\n          }\r\n        }\r\n      }\r\n\r\n      return result;\r\n    }\r\n    if (this.sql.includes(\"PRAGMA foreign_keys;\")) {\r\n      return results[0];\r\n    }\r\n    if (this.sql.includes(\"PRAGMA foreign_keys\")) {\r\n      return results;\r\n    }\r\n    if (this.sql.includes(\"PRAGMA foreign_key_list\")) {\r\n      return results;\r\n    }\r\n    if (\r\n      [QueryTypes.BULKUPDATE, QueryTypes.BULKDELETE].includes(this.options.type)\r\n    ) {\r\n      return metaData.changes;\r\n    }\r\n    if (this.options.type === QueryTypes.UPSERT) {\r\n      return undefined;\r\n    }\r\n    if (this.options.type === QueryTypes.VERSION) {\r\n      return results[0].version;\r\n    }\r\n    if (this.options.type === QueryTypes.RAW) {\r\n      return [results, metaData];\r\n    }\r\n    if (this.isUpdateQuery() || this.isInsertQuery()) {\r\n      return [result, metaData.changes];\r\n    }\r\n    return result;\r\n  }\r\n  // websql : polyfill foreign key https://justatheory.com/2004/11/sqlite-foreign-key-triggers/\r\n  run(sql, parameters) {\r\n    // exec does not support bind parameter\r\n    this.sql = AbstractQuery.formatBindParameters(\r\n      sql,\r\n      this.options.bind,\r\n      this.options.dialect || \"sqlite\",\r\n      { skipUnescape: false }\r\n    )[0];\r\n    const method = this.getDatabaseMethod();\r\n    const complete = this._logQuery(this.sql, debug, parameters);\r\n    const query = this;\r\n    const self = this;\r\n    const conn = this.connection;\r\n\r\n    return new Promise(resolve => {\r\n      const columnTypes = {};\r\n      // eslint-disable-next-line\r\n      const executeSql = () => {\r\n        if (sql.startsWith(\"-- \")) {\r\n          return resolve();\r\n        }\r\n        resolve(\r\n          new Promise((resolve, reject) => {\r\n            if (method === \"exec\") {\r\n              if (typeof conn.exec === \"function\") {\r\n                conn.exec(\r\n                  [{ sql: self.sql, args: [] }],\r\n                  false,\r\n                  (executionError, results) => {\r\n                    try {\r\n                      complete();\r\n                      // TODO: Check return PRAGMA INDEX_LIST and INDEX_INFO\r\n                      results = query.convertToArray(results[0]);\r\n                      // `this` is passed from sqlite, we have no control over this.\r\n                      // eslint-disable-next-line no-invalid-this\r\n                      resolve(\r\n                        query._handleQueryResponse(\r\n                          self,\r\n                          columnTypes,\r\n                          executionError,\r\n                          results\r\n                        )\r\n                      );\r\n                      return;\r\n                    } catch (error) {\r\n                      reject(error);\r\n                    }\r\n                  }\r\n                );\r\n              } else {\r\n                resolve();\r\n              }\r\n            } else {\r\n              conn.transaction(function(t) {\r\n                // cannot use arrow function here because the function is bound to the statement\r\n                // eslint-disable-next-line\r\n                var successCallback = function(_, results) {\r\n                  try {\r\n                    complete();\r\n                    // `self` is passed from sqlite, we have no control over this.\r\n                    // eslint-disable-next-line no-invalid-this\r\n                    if (results.rowsAffected) {\r\n                      try {\r\n                        self[self.getInsertIdField()] = results.insertId\r\n                      } catch (e) {\r\n                        delete self[self.getInsertIdField()];\r\n                      }\r\n                    }\r\n                    self.changes = results.rowsAffected;\r\n                    results = query.convertToArray(results);\r\n                    resolve(\r\n                      query._handleQueryResponse(\r\n                        self,\r\n                        columnTypes,\r\n                        undefined,\r\n                        results\r\n                      )\r\n                    );\r\n                    return;\r\n                  } catch (error) {\r\n                    debug(error);\r\n                    reject(error);\r\n                  }\r\n                };\r\n                // eslint-disable-next-line\r\n                var errorCallback = function(_, err) {\r\n                  try {\r\n                    complete();\r\n                    // `self` is passed from sqlite, we have no control over this.\r\n                    // eslint-disable-next-line no-invalid-this\r\n                    resolve(query._handleQueryResponse(self, columnTypes, err));\r\n                  } catch (error) {\r\n                    reject(error);\r\n                  }\r\n                };\r\n                if (typeof conn.exec === \"function\") {\r\n                  parameters = parameters || [];\r\n                } else parameters = [];\r\n                t.executeSql(\r\n                  self.sql,\r\n                  parameters,\r\n                  successCallback,\r\n                  errorCallback\r\n                );\r\n              });\r\n            }\r\n          })\r\n        );\r\n        return null;\r\n      };\r\n\r\n      if (method === \"all\" && typeof conn.exec === \"function\") {\r\n        let tableNames = [];\r\n        if (this.options && this.options.tableNames) {\r\n          tableNames = this.options.tableNames;\r\n        } else if (/FROM `(.*?)`/i.exec(this.sql)) {\r\n          tableNames.push(/FROM `(.*?)`/i.exec(this.sql)[1]);\r\n        }\r\n\r\n        // If we already have the metadata for the table, there's no need to ask for it again\r\n        tableNames = tableNames.filter(\r\n          tableName =>\r\n            !(tableName in columnTypes) && tableName !== \"sqlite_master\"\r\n        );\r\n        if (!tableNames.length) {\r\n          return executeSql();\r\n        }\r\n        return new Promise(resolve => {\r\n          if (typeof conn.exec === \"function\") {\r\n            const sqlCommands = tableNames.map(tableName => {\r\n              tableName = tableName.replace(/`/g, \"\");\r\n              columnTypes[tableName] = {};\r\n              return [`PRAGMA table_info(\\`${tableName}\\`)`, tableName];\r\n            });\r\n            conn.exec(\r\n              sqlCommands.map(sqlCmd => ({\r\n                sql: sqlCmd[0],\r\n                args: []\r\n              })),\r\n              false,\r\n              (err, results) => {\r\n                if (!err) {\r\n                  for (let i = 0; i < sqlCommands.length; i++) {\r\n                    const tableName = sqlCommands[i][1];\r\n                    for (const result of results[i].rows) {\r\n                      columnTypes[tableName][result.name] = result.type;\r\n                    }\r\n                  }\r\n                }\r\n                resolve();\r\n              }\r\n            );\r\n          } else {\r\n            conn.transaction(function(t) {\r\n              tableNames.forEach((tableName, index) => {\r\n                t.executeSql(\r\n                  `SELECT sql FROM sqlite_master WHERE tbl_name='${tableName}' and type='table'`,\r\n                  [],\r\n                  function(_, result) {\r\n                    const table = result.rows.item(0);\r\n                    if (\r\n                      typeof table === \"object\" &&\r\n                      \"sql\" in table &&\r\n                      typeof table.sql === \"string\"\r\n                    ) {\r\n                      columnTypes[tableName] = {};\r\n                      //match column name with data types\r\n                      const columns = table.sql.match(\r\n                        /(`\\w+`)((\\s([A-Z]+)((\\(\\d+\\)))?))/g\r\n                      );\r\n                      // split column names with data type\r\n                      for (const col of columns) {\r\n                        const [colName, colType] = col\r\n                          .trim()\r\n                          .replace(/\\s+/g, \" \")\r\n                          .replace(/`/g, \"\")\r\n                          .split(\" \");\r\n                        columnTypes[tableName][colName] = colType.trim();\r\n                      }\r\n                    }\r\n                    //console.log(columnTypes)\r\n                  }\r\n                );\r\n                if (index === tableNames.length - 1) resolve();\r\n              });\r\n            });\r\n          }\r\n        }).then(executeSql);\r\n      }\r\n      return executeSql();\r\n    });\r\n  }\r\n\r\n  parseConstraintsFromSql(sql) {\r\n    let constraints = sql.split(\"CONSTRAINT \");\r\n    let referenceTableName, referenceTableKeys, updateAction, deleteAction;\r\n    constraints.splice(0, 1);\r\n    constraints = constraints.map(constraintSql => {\r\n      //Parse foreign key snippets\r\n      if (constraintSql.includes(\"REFERENCES\")) {\r\n        //Parse out the constraint condition form sql string\r\n        updateAction = constraintSql.match(\r\n          /ON UPDATE (CASCADE|SET NULL|RESTRICT|NO ACTION|SET DEFAULT){1}/\r\n        );\r\n        deleteAction = constraintSql.match(\r\n          /ON DELETE (CASCADE|SET NULL|RESTRICT|NO ACTION|SET DEFAULT){1}/\r\n        );\r\n\r\n        if (updateAction) {\r\n          updateAction = updateAction[1];\r\n        }\r\n\r\n        if (deleteAction) {\r\n          deleteAction = deleteAction[1];\r\n        }\r\n\r\n        const referencesRegex = /REFERENCES.+\\((?:[^)(]+|\\((?:[^)(]+|\\([^)(]*\\))*\\))*\\)/;\r\n        const referenceConditions = constraintSql\r\n          .match(referencesRegex)[0]\r\n          .split(\" \");\r\n        referenceTableName = Utils.removeTicks(referenceConditions[1]);\r\n        let columnNames = referenceConditions[2];\r\n        columnNames = columnNames.replace(/\\(|\\)/g, \"\").split(\", \");\r\n        referenceTableKeys = columnNames.map(column =>\r\n          Utils.removeTicks(column)\r\n        );\r\n      }\r\n\r\n      const constraintCondition = constraintSql.match(\r\n        /\\((?:[^)(]+|\\((?:[^)(]+|\\([^)(]*\\))*\\))*\\)/\r\n      )[0];\r\n      constraintSql = constraintSql.replace(/\\(.+\\)/, \"\");\r\n      const constraint = constraintSql.split(\" \");\r\n\r\n      if (constraint[1] === \"PRIMARY\" || constraint[1] === \"FOREIGN\") {\r\n        constraint[1] += \" KEY\";\r\n      }\r\n\r\n      return {\r\n        constraintName: Utils.removeTicks(constraint[0]),\r\n        constraintType: constraint[1],\r\n        updateAction,\r\n        deleteAction,\r\n        sql: sql.replace(/\"/g, \"`\"), //Sqlite returns double quotes for table name\r\n        constraintCondition,\r\n        referenceTableName,\r\n        referenceTableKeys\r\n      };\r\n    });\r\n\r\n    return constraints;\r\n  }\r\n\r\n  applyParsers(type, value) {\r\n    if (type.includes(\"(\")) {\r\n      // Remove the length part\r\n      type = type.substr(0, type.indexOf(\"(\"));\r\n    }\r\n    type = type.replace(\"UNSIGNED\", \"\").replace(\"ZEROFILL\", \"\");\r\n    type = type.trim().toUpperCase();\r\n    const parse = parserStore.get(type);\r\n    if (value !== null && parse) {\r\n      return parse(value, { timezone: this.sequelize.options.timezone });\r\n    }\r\n    return value;\r\n  }\r\n\r\n  formatError(err) {\r\n    switch (err.code) {\r\n      case \"SQLITE_CONSTRAINT\": {\r\n        if (err.message.includes(\"FOREIGN KEY constraint failed\")) {\r\n          return new sequelizeErrors.ForeignKeyConstraintError({\r\n            parent: err\r\n          });\r\n        }\r\n\r\n        let fields = [];\r\n\r\n        // Sqlite pre 2.2 behavior - Error: SQLITE_CONSTRAINT: columns x, y are not unique\r\n        let match = err.message.match(/columns (.*?) are/);\r\n        if (match !== null && match.length >= 2) {\r\n          fields = match[1].split(\", \");\r\n        } else {\r\n          // Sqlite post 2.2 behavior - Error: SQLITE_CONSTRAINT: UNIQUE constraint failed: table.x, table.y\r\n          match = err.message.match(/UNIQUE constraint failed: (.*)/);\r\n          if (match !== null && match.length >= 2) {\r\n            fields = match[1]\r\n              .split(\", \")\r\n              .map(columnWithTable => columnWithTable.split(\".\")[1]);\r\n          }\r\n        }\r\n\r\n        const errors = [];\r\n        let message = \"Validation error\";\r\n\r\n        for (const field of fields) {\r\n          errors.push(\r\n            new sequelizeErrors.ValidationErrorItem(\r\n              this.getUniqueConstraintErrorMessage(field),\r\n              \"unique violation\", // sequelizeErrors.ValidationErrorItem.Origins.DB,\r\n              field,\r\n              this.instance && this.instance[field],\r\n              this.instance,\r\n              \"not_unique\"\r\n            )\r\n          );\r\n        }\r\n\r\n        if (this.model) {\r\n          _.forOwn(this.model.uniqueKeys, constraint => {\r\n            if (_.isEqual(constraint.fields, fields) && !!constraint.msg) {\r\n              message = constraint.msg;\r\n              return false;\r\n            }\r\n          });\r\n        }\r\n\r\n        return new sequelizeErrors.UniqueConstraintError({\r\n          message,\r\n          errors,\r\n          parent: err,\r\n          fields\r\n        });\r\n      }\r\n      case \"SQLITE_BUSY\":\r\n        return new sequelizeErrors.TimeoutError(err);\r\n\r\n      default:\r\n        return new sequelizeErrors.DatabaseError(err);\r\n    }\r\n  }\r\n\r\n  handleShowIndexesQuery(data) {\r\n    // Sqlite returns indexes so the one that was defined last is returned first. Lets reverse that!\r\n    return Promise.map(data.reverse(), item => {\r\n      item.fields = [];\r\n      item.primary = false;\r\n      item.unique = !!item.unique;\r\n      item.constraintName = item.name;\r\n      return this.run(`PRAGMA INDEX_INFO(\\`${item.name}\\`)`).then(columns => {\r\n        for (const column of columns) {\r\n          item.fields[column.seqno] = {\r\n            attribute: column.name,\r\n            length: undefined,\r\n            order: undefined\r\n          };\r\n        }\r\n\r\n        return item;\r\n      });\r\n    });\r\n  }\r\n\r\n  getDatabaseMethod() {\r\n    if (\r\n      this.sql.includes(\"PRAGMA\") ||\r\n      this.sql.includes(\"COMMIT\") ||\r\n      this.sql.includes(\"ROLLBACK\") ||\r\n      this.sql.includes(\"TRANSACTION\")\r\n    ) {\r\n      return \"exec\"; // Needed to run no-op transaction\r\n    }\r\n    if (\r\n      this.isInsertQuery() ||\r\n      this.isUpdateQuery() ||\r\n      this.isBulkUpdateQuery() ||\r\n      this.sql.toLowerCase().includes(\"CREATE TEMPORARY TABLE\".toLowerCase()) ||\r\n      this.options.type === QueryTypes.BULKDELETE\r\n    ) {\r\n      return \"run\";\r\n    }\r\n    return \"all\";\r\n  }\r\n  convertToArray(results) {\r\n    if (!results.rows) return [];\r\n    if (\"array\" in results || \"_array\" in results.rows)\r\n      return results.array || results.rows._array;\r\n    if (!results.rows.item) return results.rows;\r\n    const data = new Array(results.rows.length);\r\n    for (let i = 0; i < results.rows.length; i++) {\r\n      data[i] = results.rows.item(i);\r\n    }\r\n    return data;\r\n  }\r\n}\r\n\r\nmodule.exports = Query;\r\nmodule.exports.Query = Query;\r\nmodule.exports.default = Query;\r\n"]} \ No newline at end of file +//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../lib/dialects/sqlite/query.js"],"names":["_","require","Utils","Promise","AbstractQuery","QueryTypes","sequelizeErrors","parserStore","logger","debug","debugContext","getMethods","obj","properties","Set","currentObj","Object","getOwnPropertyNames","map","item","add","getPrototypeOf","keys","filter","Query","include","prefix","ret","_include","key","as","model","merge","_collectModels","metaData","columnTypes","err","results","sql","formatError","result","instance","isInsertQuery","handleInsertQuery","autoIncrementAttribute","primaryKeyAttribute","rawAttributes","startId","getInsertIdField","changes","i","push","field","isShowTablesQuery","row","name","isShowConstraintsQuery","parseConstraintsFromSql","isSelectQuery","options","raw","handleSelectQuery","prefixes","mapValues","value","includes","lastind","lastIndexOf","substr","tableName","getTableName","toString","replace","tableTypes","forOwn","attribute","prototype","hasOwnProperty","call","applyParsers","isShowOrDescribeQuery","handleShowIndexesQuery","Array","isArray","defaultValue","_result","dflt_value","undefined","type","allowNull","notnull","primaryKey","pk","BULKUPDATE","BULKDELETE","UPSERT","VERSION","version","RAW","isUpdateQuery","parameters","formatBindParameters","bind","dialect","skipUnescape","method","getDatabaseMethod","complete","_logQuery","query","self","conn","connection","resolve","executeSql","startsWith","reject","exec","args","executionError","convertToArray","_handleQueryResponse","error","transaction","t","successCallback","rowsAffected","insertId","e","errorCallback","tableNames","length","sqlCommands","sqlCmd","rows","forEach","index","table","columns","match","col","colName","colType","trim","split","then","constraints","referenceTableName","referenceTableKeys","updateAction","deleteAction","splice","constraintSql","referencesRegex","referenceConditions","removeTicks","columnNames","column","constraintCondition","constraint","constraintName","constraintType","indexOf","toUpperCase","parse","get","timezone","sequelize","code","message","ForeignKeyConstraintError","parent","fields","columnWithTable","errors","ValidationErrorItem","getUniqueConstraintErrorMessage","uniqueKeys","isEqual","msg","UniqueConstraintError","TimeoutError","DatabaseError","data","reverse","primary","unique","run","seqno","order","isBulkUpdateQuery","toLowerCase","array","_array","values","bindParam","v","skipValueReplace","k","module","exports","default"],"mappings":"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","sourcesContent":["\"use strict\";\n\nconst _ = require(\"lodash\");\nconst Utils = require(\"../../utils\");\nconst Promise = require(\"../../promise\");\nconst AbstractQuery = require(\"../abstract/query\");\nconst QueryTypes = require(\"../../query-types\");\nconst sequelizeErrors = require(\"../../errors\");\nconst parserStore = require(\"../parserStore\")(\"sqlite\");\nconst { logger } = require(\"../../utils/logger\");\n\nconst debug = logger.debugContext(\"sql:sqlite\");\nconst getMethods = obj => {\n  let properties = new Set();\n  let currentObj = obj;\n  do {\n    Object.getOwnPropertyNames(currentObj).map(item => properties.add(item));\n  } while ((currentObj = Object.getPrototypeOf(currentObj)));\n  return [...properties.keys()].filter(item => typeof obj[item] === \"function\");\n};\nclass Query extends AbstractQuery {\n  getInsertIdField() {\n    return \"lastID\";\n  }\n\n  /**\n   * rewrite query with parameters.\n   *\n   * @param {string} sql\n   * @param {Array|Object} values\n   * @param {string} dialect\n   * @private\n   */\n  static formatBindParameters(sql, values, dialect) {\n    let bindParam;\n    if (Array.isArray(values)) {\n      bindParam = {};\n      values.forEach((v, i) => {\n        bindParam[`$${i + 1}`] = v;\n      });\n      sql = AbstractQuery.formatBindParameters(sql, values, dialect, {\n        skipValueReplace: true\n      })[0];\n    } else {\n      bindParam = {};\n      if (typeof values === \"object\") {\n        for (const k of Object.keys(values)) {\n          bindParam[`$${k}`] = values[k];\n        }\n      }\n      sql = AbstractQuery.formatBindParameters(sql, values, dialect, {\n        skipValueReplace: true\n      })[0];\n    }\n    return [sql, bindParam];\n  }\n\n  _collectModels(include, prefix) {\n    const ret = {};\n\n    if (include) {\n      for (const _include of include) {\n        let key;\n        if (!prefix) {\n          key = _include.as;\n        } else {\n          key = `${prefix}.${_include.as}`;\n        }\n        ret[key] = _include.model;\n\n        if (_include.include) {\n          _.merge(ret, this._collectModels(_include.include, key));\n        }\n      }\n    }\n\n    return ret;\n  }\n\n  _handleQueryResponse(metaData, columnTypes, err, results) {\n    if (err) {\n      err.sql = this.sql;\n      throw this.formatError(err);\n    }\n    let result = this.instance;\n    // add the inserted row id to the instance\n    if (this.isInsertQuery(results, metaData)) {\n      this.handleInsertQuery(results, metaData);\n      if (!this.instance) {\n        // handle bulkCreate AI primary key\n        if (\n          /*  metaData.constructor.name === \"Statement\" && */\n          this.model &&\n          this.model.autoIncrementAttribute &&\n          this.model.autoIncrementAttribute ===\n            this.model.primaryKeyAttribute &&\n          this.model.rawAttributes[this.model.primaryKeyAttribute]\n        ) {\n          const startId =\n            metaData[this.getInsertIdField()] - metaData.changes + 1;\n\n          result = [];\n          for (let i = startId; i < startId + metaData.changes; i++) {\n            result.push({\n              [this.model.rawAttributes[this.model.primaryKeyAttribute]\n                .field]: i\n            });\n          }\n        } else {\n          result = metaData[this.getInsertIdField()];\n        }\n      }\n    }\n\n    if (this.isShowTablesQuery()) {\n      return results.map(row => row.name);\n    }\n    if (this.isShowConstraintsQuery()) {\n      result = results;\n      if (results && results[0] && results[0].sql) {\n        result = this.parseConstraintsFromSql(results[0].sql);\n      }\n      return result;\n    }\n    if (this.isSelectQuery()) {\n      if (this.options.raw) {\n        return this.handleSelectQuery(results);\n      }\n      // This is a map of prefix strings to models, e.g. user.projects -> Project model\n      const prefixes = this._collectModels(this.options.include);\n\n      results = results.map(result => {\n        return _.mapValues(result, (value, name) => {\n          let model;\n          if (name.includes(\".\")) {\n            const lastind = name.lastIndexOf(\".\");\n\n            model = prefixes[name.substr(0, lastind)];\n\n            name = name.substr(lastind + 1);\n          } else {\n            model = this.options.model;\n          }\n\n          const tableName = model\n            .getTableName()\n            .toString()\n            .replace(/`/g, \"\");\n          const tableTypes = columnTypes[tableName] || {};\n\n          if (tableTypes && !(name in tableTypes)) {\n            // The column is aliased\n            _.forOwn(model.rawAttributes, (attribute, key) => {\n              if (name === key && attribute.field) {\n                name = attribute.field;\n                return false;\n              }\n            });\n          }\n\n          return Object.prototype.hasOwnProperty.call(tableTypes, name)\n            ? this.applyParsers(tableTypes[name], value)\n            : value;\n        });\n      });\n\n      return this.handleSelectQuery(results);\n    }\n    if (this.isShowOrDescribeQuery()) {\n      return results;\n    }\n    if (this.sql.includes(\"PRAGMA INDEX_LIST\")) {\n      return this.handleShowIndexesQuery(results);\n    }\n    if (this.sql.includes(\"PRAGMA INDEX_INFO\")) {\n      return results;\n    }\n    if (this.sql.includes(\"PRAGMA TABLE_INFO\")) {\n      // this is the sqlite way of getting the metadata of a table\n      result = {};\n\n      if (Array.isArray(results)) {\n        let defaultValue;\n        for (const _result of results) {\n          if (_result.dflt_value === null) {\n            // Column schema omits any \"DEFAULT ...\"\n            defaultValue = undefined;\n          } else if (_result.dflt_value === \"NULL\") {\n            // Column schema is a \"DEFAULT NULL\"\n            defaultValue = null;\n          } else {\n            defaultValue = _result.dflt_value;\n          }\n\n          result[_result.name] = {\n            type: _result.type,\n            allowNull: _result.notnull === 0,\n            defaultValue,\n            primaryKey: _result.pk !== 0\n          };\n\n          if (result[_result.name].type === \"TINYINT(1)\") {\n            result[_result.name].defaultValue = { \"0\": false, \"1\": true }[\n              result[_result.name].defaultValue\n            ];\n          }\n\n          if (typeof result[_result.name].defaultValue === \"string\") {\n            result[_result.name].defaultValue = result[\n              _result.name\n            ].defaultValue.replace(/'/g, \"\");\n          }\n        }\n      }\n\n      return result;\n    }\n    if (this.sql.includes(\"PRAGMA foreign_keys;\")) {\n      return results[0];\n    }\n    if (this.sql.includes(\"PRAGMA foreign_keys\")) {\n      return results;\n    }\n    if (this.sql.includes(\"PRAGMA foreign_key_list\")) {\n      return results;\n    }\n    if (\n      [QueryTypes.BULKUPDATE, QueryTypes.BULKDELETE].includes(this.options.type)\n    ) {\n      return metaData.changes;\n    }\n    if (this.options.type === QueryTypes.UPSERT) {\n      return undefined;\n    }\n    if (this.options.type === QueryTypes.VERSION) {\n      return results[0].version;\n    }\n    if (this.options.type === QueryTypes.RAW) {\n      return [results, metaData];\n    }\n    if (this.isUpdateQuery() || this.isInsertQuery()) {\n      return [result, metaData.changes];\n    }\n    return result;\n  }\n  // websql : polyfill foreign key https://justatheory.com/2004/11/sqlite-foreign-key-triggers/\n  run(sql, parameters) {\n    // exec does not support bind parameter\n    this.sql = AbstractQuery.formatBindParameters(\n      sql,\n      this.options.bind,\n      this.options.dialect || \"sqlite\",\n      { skipUnescape: false }\n    )[0];\n    const method = this.getDatabaseMethod();\n    const complete = this._logQuery(this.sql, debug, parameters);\n    const query = this;\n    const self = this;\n    const conn = this.connection;\n\n    return new Promise(resolve => {\n      const columnTypes = {};\n      // eslint-disable-next-line\n      const executeSql = () => {\n        if (sql.startsWith(\"-- \")) {\n          return resolve();\n        }\n        resolve(\n          new Promise((resolve, reject) => {\n            if (method === \"exec\") {\n              if (typeof conn.exec === \"function\") {\n                conn.exec(\n                  [{ sql: self.sql, args: [] }],\n                  false,\n                  (executionError, results) => {\n                    try {\n                      complete();\n                      // TODO: Check return PRAGMA INDEX_LIST and INDEX_INFO\n                      results = query.convertToArray(results[0]);\n                      // `this` is passed from sqlite, we have no control over this.\n                      // eslint-disable-next-line no-invalid-this\n                      resolve(\n                        query._handleQueryResponse(\n                          self,\n                          columnTypes,\n                          executionError,\n                          results\n                        )\n                      );\n                      return;\n                    } catch (error) {\n                      reject(error);\n                    }\n                  }\n                );\n              } else {\n                resolve();\n              }\n            } else {\n              conn.transaction(function(t) {\n                // cannot use arrow function here because the function is bound to the statement\n                // eslint-disable-next-line\n                var successCallback = function(_, results) {\n                  try {\n                    complete();\n                    // `self` is passed from sqlite, we have no control over this.\n                    // eslint-disable-next-line no-invalid-this\n                    if (results.rowsAffected) {\n                      try {\n                        self[self.getInsertIdField()] = results.insertId;\n                      } catch (e) {\n                        delete self[self.getInsertIdField()];\n                      }\n                    }\n                    self.changes = results.rowsAffected;\n                    results = query.convertToArray(results);\n                    resolve(\n                      query._handleQueryResponse(\n                        self,\n                        columnTypes,\n                        undefined,\n                        results\n                      )\n                    );\n                    return;\n                  } catch (error) {\n                    debug(error);\n                    reject(error);\n                  }\n                };\n                // eslint-disable-next-line\n                var errorCallback = function(_, err) {\n                  try {\n                    complete();\n                    // `self` is passed from sqlite, we have no control over this.\n                    // eslint-disable-next-line no-invalid-this\n                    resolve(query._handleQueryResponse(self, columnTypes, err));\n                  } catch (error) {\n                    reject(error);\n                  }\n                };\n                if (typeof conn.exec === \"function\") {\n                  parameters = parameters || [];\n                } else parameters = [];\n                t.executeSql(\n                  self.sql,\n                  parameters,\n                  successCallback,\n                  errorCallback\n                );\n              });\n            }\n          })\n        );\n        return null;\n      };\n\n      if (method === \"all\") {\n        let tableNames = [];\n        if (this.options && this.options.tableNames) {\n          tableNames = this.options.tableNames;\n        } else if (/FROM `(.*?)`/i.exec(this.sql)) {\n          tableNames.push(/FROM `(.*?)`/i.exec(this.sql)[1]);\n        }\n\n        // If we already have the metadata for the table, there's no need to ask for it again\n        tableNames = tableNames.filter(\n          tableName =>\n            !(tableName in columnTypes) && tableName !== \"sqlite_master\"\n        );\n        if (!tableNames.length) {\n          return executeSql();\n        }\n        return new Promise(resolve => {\n          if (typeof conn.exec === \"function\") {\n            const sqlCommands = tableNames.map(tableName => {\n              tableName = tableName.replace(/`/g, \"\");\n              columnTypes[tableName] = {};\n              return [`PRAGMA table_info(\\`${tableName}\\`)`, tableName];\n            });\n            conn.exec(\n              sqlCommands.map(sqlCmd => ({\n                sql: sqlCmd[0],\n                args: []\n              })),\n              false,\n              (err, results) => {\n                if (!err) {\n                  for (let i = 0; i < sqlCommands.length; i++) {\n                    const tableName = sqlCommands[i][1];\n                    for (const result of results[i].rows) {\n                      columnTypes[tableName][result.name] = result.type;\n                    }\n                  }\n                }\n                resolve();\n              }\n            );\n          } else {\n            conn.transaction(function(t) {\n              tableNames.forEach((tableName, index) => {\n                t.executeSql(\n                  `SELECT sql FROM sqlite_master WHERE tbl_name='${tableName}' and type='table'`,\n                  [],\n                  function(_, result) {\n                    const table = result.rows.item(0);\n                    if (\n                      typeof table === \"object\" &&\n                      \"sql\" in table &&\n                      typeof table.sql === \"string\"\n                    ) {\n                      columnTypes[tableName] = {};\n                      //match column name with data types\n                      const columns = table.sql.match(\n                        /(`\\w+`)((\\s([A-Z]+)((\\(\\d+\\)))?))/g\n                      );\n                      // split column names with data type\n                      for (const col of columns) {\n                        const [colName, colType] = col\n                          .trim()\n                          .replace(/\\s+/g, \" \")\n                          .replace(/`/g, \"\")\n                          .split(\" \");\n                        columnTypes[tableName][colName] = colType.trim();\n                      }\n                    }\n                    //console.log(columnTypes)\n                    if (index === tableNames.length - 1) resolve();\n                  },\n                  function(_, error) {\n                    if (index === tableNames.length - 1) resolve();\n                  }\n                );\n              });\n            });\n          }\n        }).then(executeSql);\n      }\n      return executeSql();\n    });\n  }\n\n  parseConstraintsFromSql(sql) {\n    let constraints = sql.split(\"CONSTRAINT \");\n    let referenceTableName, referenceTableKeys, updateAction, deleteAction;\n    constraints.splice(0, 1);\n    constraints = constraints.map(constraintSql => {\n      //Parse foreign key snippets\n      if (constraintSql.includes(\"REFERENCES\")) {\n        //Parse out the constraint condition form sql string\n        updateAction = constraintSql.match(\n          /ON UPDATE (CASCADE|SET NULL|RESTRICT|NO ACTION|SET DEFAULT){1}/\n        );\n        deleteAction = constraintSql.match(\n          /ON DELETE (CASCADE|SET NULL|RESTRICT|NO ACTION|SET DEFAULT){1}/\n        );\n\n        if (updateAction) {\n          updateAction = updateAction[1];\n        }\n\n        if (deleteAction) {\n          deleteAction = deleteAction[1];\n        }\n\n        const referencesRegex = /REFERENCES.+\\((?:[^)(]+|\\((?:[^)(]+|\\([^)(]*\\))*\\))*\\)/;\n        const referenceConditions = constraintSql\n          .match(referencesRegex)[0]\n          .split(\" \");\n        referenceTableName = Utils.removeTicks(referenceConditions[1]);\n        let columnNames = referenceConditions[2];\n        columnNames = columnNames.replace(/\\(|\\)/g, \"\").split(\", \");\n        referenceTableKeys = columnNames.map(column =>\n          Utils.removeTicks(column)\n        );\n      }\n\n      const constraintCondition = constraintSql.match(\n        /\\((?:[^)(]+|\\((?:[^)(]+|\\([^)(]*\\))*\\))*\\)/\n      )[0];\n      constraintSql = constraintSql.replace(/\\(.+\\)/, \"\");\n      const constraint = constraintSql.split(\" \");\n\n      if (constraint[1] === \"PRIMARY\" || constraint[1] === \"FOREIGN\") {\n        constraint[1] += \" KEY\";\n      }\n\n      return {\n        constraintName: Utils.removeTicks(constraint[0]),\n        constraintType: constraint[1],\n        updateAction,\n        deleteAction,\n        sql: sql.replace(/\"/g, \"`\"), //Sqlite returns double quotes for table name\n        constraintCondition,\n        referenceTableName,\n        referenceTableKeys\n      };\n    });\n\n    return constraints;\n  }\n\n  applyParsers(type, value) {\n    if (type.includes(\"(\")) {\n      // Remove the length part\n      type = type.substr(0, type.indexOf(\"(\"));\n    }\n    type = type.replace(\"UNSIGNED\", \"\").replace(\"ZEROFILL\", \"\");\n    type = type.trim().toUpperCase();\n    const parse = parserStore.get(type);\n    if (value !== null && parse) {\n      return parse(value, { timezone: this.sequelize.options.timezone });\n    }\n    return value;\n  }\n\n  formatError(err) {\n    switch (err.code) {\n      case \"SQLITE_CONSTRAINT\": {\n        if (err.message.includes(\"FOREIGN KEY constraint failed\")) {\n          return new sequelizeErrors.ForeignKeyConstraintError({\n            parent: err\n          });\n        }\n\n        let fields = [];\n\n        // Sqlite pre 2.2 behavior - Error: SQLITE_CONSTRAINT: columns x, y are not unique\n        let match = err.message.match(/columns (.*?) are/);\n        if (match !== null && match.length >= 2) {\n          fields = match[1].split(\", \");\n        } else {\n          // Sqlite post 2.2 behavior - Error: SQLITE_CONSTRAINT: UNIQUE constraint failed: table.x, table.y\n          match = err.message.match(/UNIQUE constraint failed: (.*)/);\n          if (match !== null && match.length >= 2) {\n            fields = match[1]\n              .split(\", \")\n              .map(columnWithTable => columnWithTable.split(\".\")[1]);\n          }\n        }\n\n        const errors = [];\n        let message = \"Validation error\";\n\n        for (const field of fields) {\n          errors.push(\n            new sequelizeErrors.ValidationErrorItem(\n              this.getUniqueConstraintErrorMessage(field),\n              \"unique violation\", // sequelizeErrors.ValidationErrorItem.Origins.DB,\n              field,\n              this.instance && this.instance[field],\n              this.instance,\n              \"not_unique\"\n            )\n          );\n        }\n\n        if (this.model) {\n          _.forOwn(this.model.uniqueKeys, constraint => {\n            if (_.isEqual(constraint.fields, fields) && !!constraint.msg) {\n              message = constraint.msg;\n              return false;\n            }\n          });\n        }\n\n        return new sequelizeErrors.UniqueConstraintError({\n          message,\n          errors,\n          parent: err,\n          fields\n        });\n      }\n      case \"SQLITE_BUSY\":\n        return new sequelizeErrors.TimeoutError(err);\n\n      default:\n        return new sequelizeErrors.DatabaseError(err);\n    }\n  }\n\n  handleShowIndexesQuery(data) {\n    // Sqlite returns indexes so the one that was defined last is returned first. Lets reverse that!\n    return Promise.map(data.reverse(), item => {\n      item.fields = [];\n      item.primary = false;\n      item.unique = !!item.unique;\n      item.constraintName = item.name;\n      return this.run(`PRAGMA INDEX_INFO(\\`${item.name}\\`)`).then(columns => {\n        for (const column of columns) {\n          item.fields[column.seqno] = {\n            attribute: column.name,\n            length: undefined,\n            order: undefined\n          };\n        }\n\n        return item;\n      });\n    });\n  }\n\n  getDatabaseMethod() {\n    if (\n      this.sql.includes(\"PRAGMA\") ||\n      this.sql.includes(\"COMMIT\") ||\n      this.sql.includes(\"ROLLBACK\") ||\n      this.sql.includes(\"TRANSACTION\")\n    ) {\n      return \"exec\"; // Needed to run no-op transaction\n    }\n    if (\n      this.isInsertQuery() ||\n      this.isUpdateQuery() ||\n      this.isBulkUpdateQuery() ||\n      this.sql.toLowerCase().includes(\"CREATE TEMPORARY TABLE\".toLowerCase()) ||\n      this.options.type === QueryTypes.BULKDELETE\n    ) {\n      return \"run\";\n    }\n    return \"all\";\n  }\n  convertToArray(results) {\n    if (!results.rows) return [];\n    if (\"array\" in results || \"_array\" in results.rows)\n      return results.array || results.rows._array;\n    if (!results.rows.item) return results.rows;\n    const data = new Array(results.rows.length);\n    for (let i = 0; i < results.rows.length; i++) {\n      data[i] = results.rows.item(i);\n    }\n    return data;\n  }\n}\n\nmodule.exports = Query;\nmodule.exports.Query = Query;\nmodule.exports.default = Query;\n"]} \ No newline at end of file diff --git a/dist/errors/association-error.js b/dist/errors/association-error.js index 4759e37..a7dcbbe 100644 --- a/dist/errors/association-error.js +++ b/dist/errors/association-error.js @@ -2,15 +2,19 @@ function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } } -function _possibleConstructorReturn(self, call) { if (call && (typeof call === "object" || typeof call === "function")) { return call; } return _assertThisInitialized(self); } +function _inherits(subClass, superClass) { if (typeof superClass !== "function" && superClass !== null) { throw new TypeError("Super expression must either be null or a function"); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, writable: true, configurable: true } }); if (superClass) _setPrototypeOf(subClass, superClass); } -function _getPrototypeOf(o) { _getPrototypeOf = Object.setPrototypeOf ? Object.getPrototypeOf : function _getPrototypeOf(o) { return o.__proto__ || Object.getPrototypeOf(o); }; return _getPrototypeOf(o); } +function _setPrototypeOf(o, p) { _setPrototypeOf = Object.setPrototypeOf || function _setPrototypeOf(o, p) { o.__proto__ = p; return o; }; return _setPrototypeOf(o, p); } + +function _createSuper(Derived) { var hasNativeReflectConstruct = _isNativeReflectConstruct(); return function _createSuperInternal() { var Super = _getPrototypeOf(Derived), result; if (hasNativeReflectConstruct) { var NewTarget = _getPrototypeOf(this).constructor; result = Reflect.construct(Super, arguments, NewTarget); } else { result = Super.apply(this, arguments); } return _possibleConstructorReturn(this, result); }; } + +function _possibleConstructorReturn(self, call) { if (call && (typeof call === "object" || typeof call === "function")) { return call; } return _assertThisInitialized(self); } function _assertThisInitialized(self) { if (self === void 0) { throw new ReferenceError("this hasn't been initialised - super() hasn't been called"); } return self; } -function _inherits(subClass, superClass) { if (typeof superClass !== "function" && superClass !== null) { throw new TypeError("Super expression must either be null or a function"); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, writable: true, configurable: true } }); if (superClass) _setPrototypeOf(subClass, superClass); } +function _isNativeReflectConstruct() { if (typeof Reflect === "undefined" || !Reflect.construct) return false; if (Reflect.construct.sham) return false; if (typeof Proxy === "function") return true; try { Date.prototype.toString.call(Reflect.construct(Date, [], function () {})); return true; } catch (e) { return false; } } -function _setPrototypeOf(o, p) { _setPrototypeOf = Object.setPrototypeOf || function _setPrototypeOf(o, p) { o.__proto__ = p; return o; }; return _setPrototypeOf(o, p); } +function _getPrototypeOf(o) { _getPrototypeOf = Object.setPrototypeOf ? Object.getPrototypeOf : function _getPrototypeOf(o) { return o.__proto__ || Object.getPrototypeOf(o); }; return _getPrototypeOf(o); } const BaseError = require('./base-error'); /** @@ -18,17 +22,17 @@ const BaseError = require('./base-error'); */ -let AssociationError = -/*#__PURE__*/ -function (_BaseError) { +let AssociationError = /*#__PURE__*/function (_BaseError) { _inherits(AssociationError, _BaseError); + var _super = _createSuper(AssociationError); + function AssociationError(message) { var _this; _classCallCheck(this, AssociationError); - _this = _possibleConstructorReturn(this, _getPrototypeOf(AssociationError).call(this, message)); + _this = _super.call(this, message); _this.name = 'SequelizeAssociationError'; Error.captureStackTrace(_assertThisInitialized(_this), _this.constructor); return _this; @@ -38,4 +42,4 @@ function (_BaseError) { }(BaseError); module.exports = AssociationError; -//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uL2xpYi9lcnJvcnMvYXNzb2NpYXRpb24tZXJyb3IuanMiXSwibmFtZXMiOlsiQmFzZUVycm9yIiwicmVxdWlyZSIsIkFzc29jaWF0aW9uRXJyb3IiLCJtZXNzYWdlIiwibmFtZSIsIkVycm9yIiwiY2FwdHVyZVN0YWNrVHJhY2UiLCJjb25zdHJ1Y3RvciIsIm1vZHVsZSIsImV4cG9ydHMiXSwibWFwcGluZ3MiOiJBQUFBOzs7Ozs7Ozs7Ozs7OztBQUVBLE1BQU1BLFNBQVMsR0FBR0MsT0FBTyxDQUFDLGNBQUQsQ0FBekI7QUFFQTs7Ozs7SUFHTUMsZ0I7Ozs7O0FBQ0osNEJBQVlDLE9BQVosRUFBcUI7QUFBQTs7QUFBQTs7QUFDbkIsMEZBQU1BLE9BQU47QUFDQSxVQUFLQyxJQUFMLEdBQVksMkJBQVo7QUFDQUMsSUFBQUEsS0FBSyxDQUFDQyxpQkFBTixnQ0FBOEIsTUFBS0MsV0FBbkM7QUFIbUI7QUFJcEI7OztFQUw0QlAsUzs7QUFRL0JRLE1BQU0sQ0FBQ0MsT0FBUCxHQUFpQlAsZ0JBQWpCIiwic291cmNlc0NvbnRlbnQiOlsiJ3VzZSBzdHJpY3QnO1xyXG5cclxuY29uc3QgQmFzZUVycm9yID0gcmVxdWlyZSgnLi9iYXNlLWVycm9yJyk7XHJcblxyXG4vKipcclxuICogVGhyb3duIHdoZW4gYW4gYXNzb2NpYXRpb24gaXMgaW1wcm9wZXJseSBjb25zdHJ1Y3RlZCAoc2VlIG1lc3NhZ2UgZm9yIGRldGFpbHMpXHJcbiAqL1xyXG5jbGFzcyBBc3NvY2lhdGlvbkVycm9yIGV4dGVuZHMgQmFzZUVycm9yIHtcclxuICBjb25zdHJ1Y3RvcihtZXNzYWdlKSB7XHJcbiAgICBzdXBlcihtZXNzYWdlKTtcclxuICAgIHRoaXMubmFtZSA9ICdTZXF1ZWxpemVBc3NvY2lhdGlvbkVycm9yJztcclxuICAgIEVycm9yLmNhcHR1cmVTdGFja1RyYWNlKHRoaXMsIHRoaXMuY29uc3RydWN0b3IpO1xyXG4gIH1cclxufVxyXG5cclxubW9kdWxlLmV4cG9ydHMgPSBBc3NvY2lhdGlvbkVycm9yO1xyXG4iXX0= \ No newline at end of file +//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uL2xpYi9lcnJvcnMvYXNzb2NpYXRpb24tZXJyb3IuanMiXSwibmFtZXMiOlsiQmFzZUVycm9yIiwicmVxdWlyZSIsIkFzc29jaWF0aW9uRXJyb3IiLCJtZXNzYWdlIiwibmFtZSIsIkVycm9yIiwiY2FwdHVyZVN0YWNrVHJhY2UiLCJjb25zdHJ1Y3RvciIsIm1vZHVsZSIsImV4cG9ydHMiXSwibWFwcGluZ3MiOiJBQUFBOzs7Ozs7Ozs7Ozs7Ozs7Ozs7QUFFQSxNQUFNQSxTQUFTLEdBQUdDLE9BQU8sQ0FBQyxjQUFELENBQXpCO0FBRUE7QUFDQTtBQUNBOzs7SUFDTUMsZ0I7Ozs7O0FBQ0osNEJBQVlDLE9BQVosRUFBcUI7QUFBQTs7QUFBQTs7QUFDbkIsOEJBQU1BLE9BQU47QUFDQSxVQUFLQyxJQUFMLEdBQVksMkJBQVo7QUFDQUMsSUFBQUEsS0FBSyxDQUFDQyxpQkFBTixnQ0FBOEIsTUFBS0MsV0FBbkM7QUFIbUI7QUFJcEI7OztFQUw0QlAsUzs7QUFRL0JRLE1BQU0sQ0FBQ0MsT0FBUCxHQUFpQlAsZ0JBQWpCIiwic291cmNlc0NvbnRlbnQiOlsiJ3VzZSBzdHJpY3QnO1xuXG5jb25zdCBCYXNlRXJyb3IgPSByZXF1aXJlKCcuL2Jhc2UtZXJyb3InKTtcblxuLyoqXG4gKiBUaHJvd24gd2hlbiBhbiBhc3NvY2lhdGlvbiBpcyBpbXByb3Blcmx5IGNvbnN0cnVjdGVkIChzZWUgbWVzc2FnZSBmb3IgZGV0YWlscylcbiAqL1xuY2xhc3MgQXNzb2NpYXRpb25FcnJvciBleHRlbmRzIEJhc2VFcnJvciB7XG4gIGNvbnN0cnVjdG9yKG1lc3NhZ2UpIHtcbiAgICBzdXBlcihtZXNzYWdlKTtcbiAgICB0aGlzLm5hbWUgPSAnU2VxdWVsaXplQXNzb2NpYXRpb25FcnJvcic7XG4gICAgRXJyb3IuY2FwdHVyZVN0YWNrVHJhY2UodGhpcywgdGhpcy5jb25zdHJ1Y3Rvcik7XG4gIH1cbn1cblxubW9kdWxlLmV4cG9ydHMgPSBBc3NvY2lhdGlvbkVycm9yO1xuIl19 \ No newline at end of file diff --git a/dist/errors/base-error.js b/dist/errors/base-error.js index 8cdc812..d87c0d8 100644 --- a/dist/errors/base-error.js +++ b/dist/errors/base-error.js @@ -9,17 +9,19 @@ function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } } +function _inherits(subClass, superClass) { if (typeof superClass !== "function" && superClass !== null) { throw new TypeError("Super expression must either be null or a function"); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, writable: true, configurable: true } }); if (superClass) _setPrototypeOf(subClass, superClass); } + +function _createSuper(Derived) { var hasNativeReflectConstruct = _isNativeReflectConstruct(); return function _createSuperInternal() { var Super = _getPrototypeOf(Derived), result; if (hasNativeReflectConstruct) { var NewTarget = _getPrototypeOf(this).constructor; result = Reflect.construct(Super, arguments, NewTarget); } else { result = Super.apply(this, arguments); } return _possibleConstructorReturn(this, result); }; } + function _possibleConstructorReturn(self, call) { if (call && (typeof call === "object" || typeof call === "function")) { return call; } return _assertThisInitialized(self); } function _assertThisInitialized(self) { if (self === void 0) { throw new ReferenceError("this hasn't been initialised - super() hasn't been called"); } return self; } -function _inherits(subClass, superClass) { if (typeof superClass !== "function" && superClass !== null) { throw new TypeError("Super expression must either be null or a function"); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, writable: true, configurable: true } }); if (superClass) _setPrototypeOf(subClass, superClass); } - function _wrapNativeSuper(Class) { var _cache = typeof Map === "function" ? new Map() : undefined; _wrapNativeSuper = function _wrapNativeSuper(Class) { if (Class === null || !_isNativeFunction(Class)) return Class; if (typeof Class !== "function") { throw new TypeError("Super expression must either be null or a function"); } if (typeof _cache !== "undefined") { if (_cache.has(Class)) return _cache.get(Class); _cache.set(Class, Wrapper); } function Wrapper() { return _construct(Class, arguments, _getPrototypeOf(this).constructor); } Wrapper.prototype = Object.create(Class.prototype, { constructor: { value: Wrapper, enumerable: false, writable: true, configurable: true } }); return _setPrototypeOf(Wrapper, Class); }; return _wrapNativeSuper(Class); } -function isNativeReflectConstruct() { if (typeof Reflect === "undefined" || !Reflect.construct) return false; if (Reflect.construct.sham) return false; if (typeof Proxy === "function") return true; try { Date.prototype.toString.call(Reflect.construct(Date, [], function () {})); return true; } catch (e) { return false; } } +function _construct(Parent, args, Class) { if (_isNativeReflectConstruct()) { _construct = Reflect.construct; } else { _construct = function _construct(Parent, args, Class) { var a = [null]; a.push.apply(a, args); var Constructor = Function.bind.apply(Parent, a); var instance = new Constructor(); if (Class) _setPrototypeOf(instance, Class.prototype); return instance; }; } return _construct.apply(null, arguments); } -function _construct(Parent, args, Class) { if (isNativeReflectConstruct()) { _construct = Reflect.construct; } else { _construct = function _construct(Parent, args, Class) { var a = [null]; a.push.apply(a, args); var Constructor = Function.bind.apply(Parent, a); var instance = new Constructor(); if (Class) _setPrototypeOf(instance, Class.prototype); return instance; }; } return _construct.apply(null, arguments); } +function _isNativeReflectConstruct() { if (typeof Reflect === "undefined" || !Reflect.construct) return false; if (Reflect.construct.sham) return false; if (typeof Proxy === "function") return true; try { Date.prototype.toString.call(Reflect.construct(Date, [], function () {})); return true; } catch (e) { return false; } } function _isNativeFunction(fn) { return Function.toString.call(fn).indexOf("[native code]") !== -1; } @@ -27,24 +29,24 @@ function _setPrototypeOf(o, p) { _setPrototypeOf = Object.setPrototypeOf || func function _getPrototypeOf(o) { _getPrototypeOf = Object.setPrototypeOf ? Object.getPrototypeOf : function _getPrototypeOf(o) { return o.__proto__ || Object.getPrototypeOf(o); }; return _getPrototypeOf(o); } -let BaseError = -/*#__PURE__*/ -function (_Error) { +let BaseError = /*#__PURE__*/function (_Error) { _inherits(BaseError, _Error); + var _super = _createSuper(BaseError); + function BaseError(message) { var _this; _classCallCheck(this, BaseError); - _this = _possibleConstructorReturn(this, _getPrototypeOf(BaseError).call(this, message)); + _this = _super.call(this, message); _this.name = 'SequelizeBaseError'; Error.captureStackTrace(_assertThisInitialized(_this), _this.constructor); return _this; } return BaseError; -}(_wrapNativeSuper(Error)); +}( /*#__PURE__*/_wrapNativeSuper(Error)); module.exports = BaseError; -//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uL2xpYi9lcnJvcnMvYmFzZS1lcnJvci5qcyJdLCJuYW1lcyI6WyJCYXNlRXJyb3IiLCJtZXNzYWdlIiwibmFtZSIsIkVycm9yIiwiY2FwdHVyZVN0YWNrVHJhY2UiLCJjb25zdHJ1Y3RvciIsIm1vZHVsZSIsImV4cG9ydHMiXSwibWFwcGluZ3MiOiJBQUFBO0FBRUE7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7SUFPTUEsUzs7Ozs7QUFDSixxQkFBWUMsT0FBWixFQUFxQjtBQUFBOztBQUFBOztBQUNuQixtRkFBTUEsT0FBTjtBQUNBLFVBQUtDLElBQUwsR0FBWSxvQkFBWjtBQUNBQyxJQUFBQSxLQUFLLENBQUNDLGlCQUFOLGdDQUE4QixNQUFLQyxXQUFuQztBQUhtQjtBQUlwQjs7O21CQUxxQkYsSzs7QUFReEJHLE1BQU0sQ0FBQ0MsT0FBUCxHQUFpQlAsU0FBakIiLCJzb3VyY2VzQ29udGVudCI6WyIndXNlIHN0cmljdCc7XHJcblxyXG4vKipcclxuICogU2VxdWVsaXplIHByb3ZpZGVzIGEgaG9zdCBvZiBjdXN0b20gZXJyb3IgY2xhc3NlcywgdG8gYWxsb3cgeW91IHRvIGRvIGVhc2llciBkZWJ1Z2dpbmcuIEFsbCBvZiB0aGVzZSBlcnJvcnMgYXJlIGV4cG9zZWQgb24gdGhlIHNlcXVlbGl6ZSBvYmplY3QgYW5kIHRoZSBzZXF1ZWxpemUgY29uc3RydWN0b3IuXHJcbiAqIEFsbCBzZXF1ZWxpemUgZXJyb3JzIGluaGVyaXQgZnJvbSB0aGUgYmFzZSBKUyBlcnJvciBvYmplY3QuXHJcbiAqXHJcbiAqIFRoaXMgbWVhbnMgdGhhdCBlcnJvcnMgY2FuIGJlIGFjY2Vzc2VkIHVzaW5nIGBTZXF1ZWxpemUuVmFsaWRhdGlvbkVycm9yYFxyXG4gKiBUaGUgQmFzZSBFcnJvciBhbGwgU2VxdWVsaXplIEVycm9ycyBpbmhlcml0IGZyb20uXHJcbiAqL1xyXG5jbGFzcyBCYXNlRXJyb3IgZXh0ZW5kcyBFcnJvciB7XHJcbiAgY29uc3RydWN0b3IobWVzc2FnZSkge1xyXG4gICAgc3VwZXIobWVzc2FnZSk7XHJcbiAgICB0aGlzLm5hbWUgPSAnU2VxdWVsaXplQmFzZUVycm9yJztcclxuICAgIEVycm9yLmNhcHR1cmVTdGFja1RyYWNlKHRoaXMsIHRoaXMuY29uc3RydWN0b3IpO1xyXG4gIH1cclxufVxyXG5cclxubW9kdWxlLmV4cG9ydHMgPSBCYXNlRXJyb3I7XHJcbiJdfQ== \ No newline at end of file +//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uL2xpYi9lcnJvcnMvYmFzZS1lcnJvci5qcyJdLCJuYW1lcyI6WyJCYXNlRXJyb3IiLCJtZXNzYWdlIiwibmFtZSIsIkVycm9yIiwiY2FwdHVyZVN0YWNrVHJhY2UiLCJjb25zdHJ1Y3RvciIsIm1vZHVsZSIsImV4cG9ydHMiXSwibWFwcGluZ3MiOiJBQUFBO0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7OztJQUNNQSxTOzs7OztBQUNKLHFCQUFZQyxPQUFaLEVBQXFCO0FBQUE7O0FBQUE7O0FBQ25CLDhCQUFNQSxPQUFOO0FBQ0EsVUFBS0MsSUFBTCxHQUFZLG9CQUFaO0FBQ0FDLElBQUFBLEtBQUssQ0FBQ0MsaUJBQU4sZ0NBQThCLE1BQUtDLFdBQW5DO0FBSG1CO0FBSXBCOzs7aUNBTHFCRixLOztBQVF4QkcsTUFBTSxDQUFDQyxPQUFQLEdBQWlCUCxTQUFqQiIsInNvdXJjZXNDb250ZW50IjpbIid1c2Ugc3RyaWN0JztcblxuLyoqXG4gKiBTZXF1ZWxpemUgcHJvdmlkZXMgYSBob3N0IG9mIGN1c3RvbSBlcnJvciBjbGFzc2VzLCB0byBhbGxvdyB5b3UgdG8gZG8gZWFzaWVyIGRlYnVnZ2luZy4gQWxsIG9mIHRoZXNlIGVycm9ycyBhcmUgZXhwb3NlZCBvbiB0aGUgc2VxdWVsaXplIG9iamVjdCBhbmQgdGhlIHNlcXVlbGl6ZSBjb25zdHJ1Y3Rvci5cbiAqIEFsbCBzZXF1ZWxpemUgZXJyb3JzIGluaGVyaXQgZnJvbSB0aGUgYmFzZSBKUyBlcnJvciBvYmplY3QuXG4gKlxuICogVGhpcyBtZWFucyB0aGF0IGVycm9ycyBjYW4gYmUgYWNjZXNzZWQgdXNpbmcgYFNlcXVlbGl6ZS5WYWxpZGF0aW9uRXJyb3JgXG4gKiBUaGUgQmFzZSBFcnJvciBhbGwgU2VxdWVsaXplIEVycm9ycyBpbmhlcml0IGZyb20uXG4gKi9cbmNsYXNzIEJhc2VFcnJvciBleHRlbmRzIEVycm9yIHtcbiAgY29uc3RydWN0b3IobWVzc2FnZSkge1xuICAgIHN1cGVyKG1lc3NhZ2UpO1xuICAgIHRoaXMubmFtZSA9ICdTZXF1ZWxpemVCYXNlRXJyb3InO1xuICAgIEVycm9yLmNhcHR1cmVTdGFja1RyYWNlKHRoaXMsIHRoaXMuY29uc3RydWN0b3IpO1xuICB9XG59XG5cbm1vZHVsZS5leHBvcnRzID0gQmFzZUVycm9yO1xuIl19 \ No newline at end of file diff --git a/dist/errors/bulk-record-error.js b/dist/errors/bulk-record-error.js index f8a819e..bbd9680 100644 --- a/dist/errors/bulk-record-error.js +++ b/dist/errors/bulk-record-error.js @@ -2,15 +2,19 @@ function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } } -function _possibleConstructorReturn(self, call) { if (call && (typeof call === "object" || typeof call === "function")) { return call; } return _assertThisInitialized(self); } +function _inherits(subClass, superClass) { if (typeof superClass !== "function" && superClass !== null) { throw new TypeError("Super expression must either be null or a function"); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, writable: true, configurable: true } }); if (superClass) _setPrototypeOf(subClass, superClass); } -function _getPrototypeOf(o) { _getPrototypeOf = Object.setPrototypeOf ? Object.getPrototypeOf : function _getPrototypeOf(o) { return o.__proto__ || Object.getPrototypeOf(o); }; return _getPrototypeOf(o); } +function _setPrototypeOf(o, p) { _setPrototypeOf = Object.setPrototypeOf || function _setPrototypeOf(o, p) { o.__proto__ = p; return o; }; return _setPrototypeOf(o, p); } + +function _createSuper(Derived) { var hasNativeReflectConstruct = _isNativeReflectConstruct(); return function _createSuperInternal() { var Super = _getPrototypeOf(Derived), result; if (hasNativeReflectConstruct) { var NewTarget = _getPrototypeOf(this).constructor; result = Reflect.construct(Super, arguments, NewTarget); } else { result = Super.apply(this, arguments); } return _possibleConstructorReturn(this, result); }; } + +function _possibleConstructorReturn(self, call) { if (call && (typeof call === "object" || typeof call === "function")) { return call; } return _assertThisInitialized(self); } function _assertThisInitialized(self) { if (self === void 0) { throw new ReferenceError("this hasn't been initialised - super() hasn't been called"); } return self; } -function _inherits(subClass, superClass) { if (typeof superClass !== "function" && superClass !== null) { throw new TypeError("Super expression must either be null or a function"); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, writable: true, configurable: true } }); if (superClass) _setPrototypeOf(subClass, superClass); } +function _isNativeReflectConstruct() { if (typeof Reflect === "undefined" || !Reflect.construct) return false; if (Reflect.construct.sham) return false; if (typeof Proxy === "function") return true; try { Date.prototype.toString.call(Reflect.construct(Date, [], function () {})); return true; } catch (e) { return false; } } -function _setPrototypeOf(o, p) { _setPrototypeOf = Object.setPrototypeOf || function _setPrototypeOf(o, p) { o.__proto__ = p; return o; }; return _setPrototypeOf(o, p); } +function _getPrototypeOf(o) { _getPrototypeOf = Object.setPrototypeOf ? Object.getPrototypeOf : function _getPrototypeOf(o) { return o.__proto__ || Object.getPrototypeOf(o); }; return _getPrototypeOf(o); } const BaseError = require('./base-error'); /** @@ -22,17 +26,17 @@ const BaseError = require('./base-error'); */ -let BulkRecordError = -/*#__PURE__*/ -function (_BaseError) { +let BulkRecordError = /*#__PURE__*/function (_BaseError) { _inherits(BulkRecordError, _BaseError); + var _super = _createSuper(BulkRecordError); + function BulkRecordError(error, record) { var _this; _classCallCheck(this, BulkRecordError); - _this = _possibleConstructorReturn(this, _getPrototypeOf(BulkRecordError).call(this, error.message)); + _this = _super.call(this, error.message); _this.name = 'SequelizeBulkRecordError'; _this.errors = error; _this.record = record; @@ -44,4 +48,4 @@ function (_BaseError) { }(BaseError); module.exports = BulkRecordError; -//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uL2xpYi9lcnJvcnMvYnVsay1yZWNvcmQtZXJyb3IuanMiXSwibmFtZXMiOlsiQmFzZUVycm9yIiwicmVxdWlyZSIsIkJ1bGtSZWNvcmRFcnJvciIsImVycm9yIiwicmVjb3JkIiwibWVzc2FnZSIsIm5hbWUiLCJlcnJvcnMiLCJFcnJvciIsImNhcHR1cmVTdGFja1RyYWNlIiwiY29uc3RydWN0b3IiLCJtb2R1bGUiLCJleHBvcnRzIl0sIm1hcHBpbmdzIjoiQUFBQTs7Ozs7Ozs7Ozs7Ozs7QUFFQSxNQUFNQSxTQUFTLEdBQUdDLE9BQU8sQ0FBQyxjQUFELENBQXpCO0FBRUE7Ozs7Ozs7OztJQU9NQyxlOzs7OztBQUNKLDJCQUFZQyxLQUFaLEVBQW1CQyxNQUFuQixFQUEyQjtBQUFBOztBQUFBOztBQUN6Qix5RkFBTUQsS0FBSyxDQUFDRSxPQUFaO0FBQ0EsVUFBS0MsSUFBTCxHQUFZLDBCQUFaO0FBQ0EsVUFBS0MsTUFBTCxHQUFjSixLQUFkO0FBQ0EsVUFBS0MsTUFBTCxHQUFjQSxNQUFkO0FBQ0FJLElBQUFBLEtBQUssQ0FBQ0MsaUJBQU4sZ0NBQThCLE1BQUtDLFdBQW5DO0FBTHlCO0FBTTFCOzs7RUFQMkJWLFM7O0FBVTlCVyxNQUFNLENBQUNDLE9BQVAsR0FBaUJWLGVBQWpCIiwic291cmNlc0NvbnRlbnQiOlsiJ3VzZSBzdHJpY3QnO1xyXG5cclxuY29uc3QgQmFzZUVycm9yID0gcmVxdWlyZSgnLi9iYXNlLWVycm9yJyk7XHJcblxyXG4vKipcclxuICogVGhyb3duIHdoZW4gYnVsayBvcGVyYXRpb24gZmFpbHMsIGl0IHJlcHJlc2VudCBwZXIgcmVjb3JkIGxldmVsIGVycm9yLlxyXG4gKiBVc2VkIHdpdGggUHJvbWlzZS5BZ2dyZWdhdGVFcnJvclxyXG4gKlxyXG4gKiBAcGFyYW0ge0Vycm9yfSAgZXJyb3IgICBFcnJvciBmb3IgYSBnaXZlbiByZWNvcmQvaW5zdGFuY2VcclxuICogQHBhcmFtIHtPYmplY3R9IHJlY29yZCAgREFPIGluc3RhbmNlIHRoYXQgZXJyb3IgYmVsb25ncyB0b1xyXG4gKi9cclxuY2xhc3MgQnVsa1JlY29yZEVycm9yIGV4dGVuZHMgQmFzZUVycm9yIHtcclxuICBjb25zdHJ1Y3RvcihlcnJvciwgcmVjb3JkKSB7XHJcbiAgICBzdXBlcihlcnJvci5tZXNzYWdlKTtcclxuICAgIHRoaXMubmFtZSA9ICdTZXF1ZWxpemVCdWxrUmVjb3JkRXJyb3InO1xyXG4gICAgdGhpcy5lcnJvcnMgPSBlcnJvcjtcclxuICAgIHRoaXMucmVjb3JkID0gcmVjb3JkO1xyXG4gICAgRXJyb3IuY2FwdHVyZVN0YWNrVHJhY2UodGhpcywgdGhpcy5jb25zdHJ1Y3Rvcik7XHJcbiAgfVxyXG59XHJcblxyXG5tb2R1bGUuZXhwb3J0cyA9IEJ1bGtSZWNvcmRFcnJvcjtcclxuIl19 \ No newline at end of file +//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uL2xpYi9lcnJvcnMvYnVsay1yZWNvcmQtZXJyb3IuanMiXSwibmFtZXMiOlsiQmFzZUVycm9yIiwicmVxdWlyZSIsIkJ1bGtSZWNvcmRFcnJvciIsImVycm9yIiwicmVjb3JkIiwibWVzc2FnZSIsIm5hbWUiLCJlcnJvcnMiLCJFcnJvciIsImNhcHR1cmVTdGFja1RyYWNlIiwiY29uc3RydWN0b3IiLCJtb2R1bGUiLCJleHBvcnRzIl0sIm1hcHBpbmdzIjoiQUFBQTs7Ozs7Ozs7Ozs7Ozs7Ozs7O0FBRUEsTUFBTUEsU0FBUyxHQUFHQyxPQUFPLENBQUMsY0FBRCxDQUF6QjtBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOzs7SUFDTUMsZTs7Ozs7QUFDSiwyQkFBWUMsS0FBWixFQUFtQkMsTUFBbkIsRUFBMkI7QUFBQTs7QUFBQTs7QUFDekIsOEJBQU1ELEtBQUssQ0FBQ0UsT0FBWjtBQUNBLFVBQUtDLElBQUwsR0FBWSwwQkFBWjtBQUNBLFVBQUtDLE1BQUwsR0FBY0osS0FBZDtBQUNBLFVBQUtDLE1BQUwsR0FBY0EsTUFBZDtBQUNBSSxJQUFBQSxLQUFLLENBQUNDLGlCQUFOLGdDQUE4QixNQUFLQyxXQUFuQztBQUx5QjtBQU0xQjs7O0VBUDJCVixTOztBQVU5QlcsTUFBTSxDQUFDQyxPQUFQLEdBQWlCVixlQUFqQiIsInNvdXJjZXNDb250ZW50IjpbIid1c2Ugc3RyaWN0JztcblxuY29uc3QgQmFzZUVycm9yID0gcmVxdWlyZSgnLi9iYXNlLWVycm9yJyk7XG5cbi8qKlxuICogVGhyb3duIHdoZW4gYnVsayBvcGVyYXRpb24gZmFpbHMsIGl0IHJlcHJlc2VudCBwZXIgcmVjb3JkIGxldmVsIGVycm9yLlxuICogVXNlZCB3aXRoIFByb21pc2UuQWdncmVnYXRlRXJyb3JcbiAqXG4gKiBAcGFyYW0ge0Vycm9yfSAgZXJyb3IgICBFcnJvciBmb3IgYSBnaXZlbiByZWNvcmQvaW5zdGFuY2VcbiAqIEBwYXJhbSB7T2JqZWN0fSByZWNvcmQgIERBTyBpbnN0YW5jZSB0aGF0IGVycm9yIGJlbG9uZ3MgdG9cbiAqL1xuY2xhc3MgQnVsa1JlY29yZEVycm9yIGV4dGVuZHMgQmFzZUVycm9yIHtcbiAgY29uc3RydWN0b3IoZXJyb3IsIHJlY29yZCkge1xuICAgIHN1cGVyKGVycm9yLm1lc3NhZ2UpO1xuICAgIHRoaXMubmFtZSA9ICdTZXF1ZWxpemVCdWxrUmVjb3JkRXJyb3InO1xuICAgIHRoaXMuZXJyb3JzID0gZXJyb3I7XG4gICAgdGhpcy5yZWNvcmQgPSByZWNvcmQ7XG4gICAgRXJyb3IuY2FwdHVyZVN0YWNrVHJhY2UodGhpcywgdGhpcy5jb25zdHJ1Y3Rvcik7XG4gIH1cbn1cblxubW9kdWxlLmV4cG9ydHMgPSBCdWxrUmVjb3JkRXJyb3I7XG4iXX0= \ No newline at end of file diff --git a/dist/errors/connection-error.js b/dist/errors/connection-error.js index 2d64537..3e958f4 100644 --- a/dist/errors/connection-error.js +++ b/dist/errors/connection-error.js @@ -2,15 +2,19 @@ function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } } -function _possibleConstructorReturn(self, call) { if (call && (typeof call === "object" || typeof call === "function")) { return call; } return _assertThisInitialized(self); } +function _inherits(subClass, superClass) { if (typeof superClass !== "function" && superClass !== null) { throw new TypeError("Super expression must either be null or a function"); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, writable: true, configurable: true } }); if (superClass) _setPrototypeOf(subClass, superClass); } -function _getPrototypeOf(o) { _getPrototypeOf = Object.setPrototypeOf ? Object.getPrototypeOf : function _getPrototypeOf(o) { return o.__proto__ || Object.getPrototypeOf(o); }; return _getPrototypeOf(o); } +function _setPrototypeOf(o, p) { _setPrototypeOf = Object.setPrototypeOf || function _setPrototypeOf(o, p) { o.__proto__ = p; return o; }; return _setPrototypeOf(o, p); } + +function _createSuper(Derived) { var hasNativeReflectConstruct = _isNativeReflectConstruct(); return function _createSuperInternal() { var Super = _getPrototypeOf(Derived), result; if (hasNativeReflectConstruct) { var NewTarget = _getPrototypeOf(this).constructor; result = Reflect.construct(Super, arguments, NewTarget); } else { result = Super.apply(this, arguments); } return _possibleConstructorReturn(this, result); }; } + +function _possibleConstructorReturn(self, call) { if (call && (typeof call === "object" || typeof call === "function")) { return call; } return _assertThisInitialized(self); } function _assertThisInitialized(self) { if (self === void 0) { throw new ReferenceError("this hasn't been initialised - super() hasn't been called"); } return self; } -function _inherits(subClass, superClass) { if (typeof superClass !== "function" && superClass !== null) { throw new TypeError("Super expression must either be null or a function"); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, writable: true, configurable: true } }); if (superClass) _setPrototypeOf(subClass, superClass); } +function _isNativeReflectConstruct() { if (typeof Reflect === "undefined" || !Reflect.construct) return false; if (Reflect.construct.sham) return false; if (typeof Proxy === "function") return true; try { Date.prototype.toString.call(Reflect.construct(Date, [], function () {})); return true; } catch (e) { return false; } } -function _setPrototypeOf(o, p) { _setPrototypeOf = Object.setPrototypeOf || function _setPrototypeOf(o, p) { o.__proto__ = p; return o; }; return _setPrototypeOf(o, p); } +function _getPrototypeOf(o) { _getPrototypeOf = Object.setPrototypeOf ? Object.getPrototypeOf : function _getPrototypeOf(o) { return o.__proto__ || Object.getPrototypeOf(o); }; return _getPrototypeOf(o); } const BaseError = require('./base-error'); /** @@ -18,17 +22,17 @@ const BaseError = require('./base-error'); */ -let ConnectionError = -/*#__PURE__*/ -function (_BaseError) { +let ConnectionError = /*#__PURE__*/function (_BaseError) { _inherits(ConnectionError, _BaseError); + var _super = _createSuper(ConnectionError); + function ConnectionError(parent) { var _this; _classCallCheck(this, ConnectionError); - _this = _possibleConstructorReturn(this, _getPrototypeOf(ConnectionError).call(this, parent ? parent.message : '')); + _this = _super.call(this, parent ? parent.message : ''); _this.name = 'SequelizeConnectionError'; /** * The connection specific error which triggered this one @@ -45,4 +49,4 @@ function (_BaseError) { }(BaseError); module.exports = ConnectionError; -//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uL2xpYi9lcnJvcnMvY29ubmVjdGlvbi1lcnJvci5qcyJdLCJuYW1lcyI6WyJCYXNlRXJyb3IiLCJyZXF1aXJlIiwiQ29ubmVjdGlvbkVycm9yIiwicGFyZW50IiwibWVzc2FnZSIsIm5hbWUiLCJvcmlnaW5hbCIsIkVycm9yIiwiY2FwdHVyZVN0YWNrVHJhY2UiLCJjb25zdHJ1Y3RvciIsIm1vZHVsZSIsImV4cG9ydHMiXSwibWFwcGluZ3MiOiJBQUFBOzs7Ozs7Ozs7Ozs7OztBQUVBLE1BQU1BLFNBQVMsR0FBR0MsT0FBTyxDQUFDLGNBQUQsQ0FBekI7QUFFQTs7Ozs7SUFHTUMsZTs7Ozs7QUFDSiwyQkFBWUMsTUFBWixFQUFvQjtBQUFBOztBQUFBOztBQUNsQix5RkFBTUEsTUFBTSxHQUFHQSxNQUFNLENBQUNDLE9BQVYsR0FBb0IsRUFBaEM7QUFDQSxVQUFLQyxJQUFMLEdBQVksMEJBQVo7QUFDQTs7Ozs7QUFJQSxVQUFLRixNQUFMLEdBQWNBLE1BQWQ7QUFDQSxVQUFLRyxRQUFMLEdBQWdCSCxNQUFoQjtBQUNBSSxJQUFBQSxLQUFLLENBQUNDLGlCQUFOLGdDQUE4QixNQUFLQyxXQUFuQztBQVRrQjtBQVVuQjs7O0VBWDJCVCxTOztBQWM5QlUsTUFBTSxDQUFDQyxPQUFQLEdBQWlCVCxlQUFqQiIsInNvdXJjZXNDb250ZW50IjpbIid1c2Ugc3RyaWN0JztcclxuXHJcbmNvbnN0IEJhc2VFcnJvciA9IHJlcXVpcmUoJy4vYmFzZS1lcnJvcicpO1xyXG5cclxuLyoqXHJcbiAqIEEgYmFzZSBjbGFzcyBmb3IgYWxsIGNvbm5lY3Rpb24gcmVsYXRlZCBlcnJvcnMuXHJcbiAqL1xyXG5jbGFzcyBDb25uZWN0aW9uRXJyb3IgZXh0ZW5kcyBCYXNlRXJyb3Ige1xyXG4gIGNvbnN0cnVjdG9yKHBhcmVudCkge1xyXG4gICAgc3VwZXIocGFyZW50ID8gcGFyZW50Lm1lc3NhZ2UgOiAnJyk7XHJcbiAgICB0aGlzLm5hbWUgPSAnU2VxdWVsaXplQ29ubmVjdGlvbkVycm9yJztcclxuICAgIC8qKlxyXG4gICAgICogVGhlIGNvbm5lY3Rpb24gc3BlY2lmaWMgZXJyb3Igd2hpY2ggdHJpZ2dlcmVkIHRoaXMgb25lXHJcbiAgICAgKiBAdHlwZSB7RXJyb3J9XHJcbiAgICAgKi9cclxuICAgIHRoaXMucGFyZW50ID0gcGFyZW50O1xyXG4gICAgdGhpcy5vcmlnaW5hbCA9IHBhcmVudDtcclxuICAgIEVycm9yLmNhcHR1cmVTdGFja1RyYWNlKHRoaXMsIHRoaXMuY29uc3RydWN0b3IpO1xyXG4gIH1cclxufVxyXG5cclxubW9kdWxlLmV4cG9ydHMgPSBDb25uZWN0aW9uRXJyb3I7XHJcbiJdfQ== \ No newline at end of file +//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uL2xpYi9lcnJvcnMvY29ubmVjdGlvbi1lcnJvci5qcyJdLCJuYW1lcyI6WyJCYXNlRXJyb3IiLCJyZXF1aXJlIiwiQ29ubmVjdGlvbkVycm9yIiwicGFyZW50IiwibWVzc2FnZSIsIm5hbWUiLCJvcmlnaW5hbCIsIkVycm9yIiwiY2FwdHVyZVN0YWNrVHJhY2UiLCJjb25zdHJ1Y3RvciIsIm1vZHVsZSIsImV4cG9ydHMiXSwibWFwcGluZ3MiOiJBQUFBOzs7Ozs7Ozs7Ozs7Ozs7Ozs7QUFFQSxNQUFNQSxTQUFTLEdBQUdDLE9BQU8sQ0FBQyxjQUFELENBQXpCO0FBRUE7QUFDQTtBQUNBOzs7SUFDTUMsZTs7Ozs7QUFDSiwyQkFBWUMsTUFBWixFQUFvQjtBQUFBOztBQUFBOztBQUNsQiw4QkFBTUEsTUFBTSxHQUFHQSxNQUFNLENBQUNDLE9BQVYsR0FBb0IsRUFBaEM7QUFDQSxVQUFLQyxJQUFMLEdBQVksMEJBQVo7QUFDQTtBQUNKO0FBQ0E7QUFDQTs7QUFDSSxVQUFLRixNQUFMLEdBQWNBLE1BQWQ7QUFDQSxVQUFLRyxRQUFMLEdBQWdCSCxNQUFoQjtBQUNBSSxJQUFBQSxLQUFLLENBQUNDLGlCQUFOLGdDQUE4QixNQUFLQyxXQUFuQztBQVRrQjtBQVVuQjs7O0VBWDJCVCxTOztBQWM5QlUsTUFBTSxDQUFDQyxPQUFQLEdBQWlCVCxlQUFqQiIsInNvdXJjZXNDb250ZW50IjpbIid1c2Ugc3RyaWN0JztcblxuY29uc3QgQmFzZUVycm9yID0gcmVxdWlyZSgnLi9iYXNlLWVycm9yJyk7XG5cbi8qKlxuICogQSBiYXNlIGNsYXNzIGZvciBhbGwgY29ubmVjdGlvbiByZWxhdGVkIGVycm9ycy5cbiAqL1xuY2xhc3MgQ29ubmVjdGlvbkVycm9yIGV4dGVuZHMgQmFzZUVycm9yIHtcbiAgY29uc3RydWN0b3IocGFyZW50KSB7XG4gICAgc3VwZXIocGFyZW50ID8gcGFyZW50Lm1lc3NhZ2UgOiAnJyk7XG4gICAgdGhpcy5uYW1lID0gJ1NlcXVlbGl6ZUNvbm5lY3Rpb25FcnJvcic7XG4gICAgLyoqXG4gICAgICogVGhlIGNvbm5lY3Rpb24gc3BlY2lmaWMgZXJyb3Igd2hpY2ggdHJpZ2dlcmVkIHRoaXMgb25lXG4gICAgICogQHR5cGUge0Vycm9yfVxuICAgICAqL1xuICAgIHRoaXMucGFyZW50ID0gcGFyZW50O1xuICAgIHRoaXMub3JpZ2luYWwgPSBwYXJlbnQ7XG4gICAgRXJyb3IuY2FwdHVyZVN0YWNrVHJhY2UodGhpcywgdGhpcy5jb25zdHJ1Y3Rvcik7XG4gIH1cbn1cblxubW9kdWxlLmV4cG9ydHMgPSBDb25uZWN0aW9uRXJyb3I7XG4iXX0= \ No newline at end of file diff --git a/dist/errors/connection/access-denied-error.js b/dist/errors/connection/access-denied-error.js index c45047e..d91d821 100644 --- a/dist/errors/connection/access-denied-error.js +++ b/dist/errors/connection/access-denied-error.js @@ -2,15 +2,19 @@ function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } } -function _possibleConstructorReturn(self, call) { if (call && (typeof call === "object" || typeof call === "function")) { return call; } return _assertThisInitialized(self); } +function _inherits(subClass, superClass) { if (typeof superClass !== "function" && superClass !== null) { throw new TypeError("Super expression must either be null or a function"); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, writable: true, configurable: true } }); if (superClass) _setPrototypeOf(subClass, superClass); } -function _getPrototypeOf(o) { _getPrototypeOf = Object.setPrototypeOf ? Object.getPrototypeOf : function _getPrototypeOf(o) { return o.__proto__ || Object.getPrototypeOf(o); }; return _getPrototypeOf(o); } +function _setPrototypeOf(o, p) { _setPrototypeOf = Object.setPrototypeOf || function _setPrototypeOf(o, p) { o.__proto__ = p; return o; }; return _setPrototypeOf(o, p); } + +function _createSuper(Derived) { var hasNativeReflectConstruct = _isNativeReflectConstruct(); return function _createSuperInternal() { var Super = _getPrototypeOf(Derived), result; if (hasNativeReflectConstruct) { var NewTarget = _getPrototypeOf(this).constructor; result = Reflect.construct(Super, arguments, NewTarget); } else { result = Super.apply(this, arguments); } return _possibleConstructorReturn(this, result); }; } + +function _possibleConstructorReturn(self, call) { if (call && (typeof call === "object" || typeof call === "function")) { return call; } return _assertThisInitialized(self); } function _assertThisInitialized(self) { if (self === void 0) { throw new ReferenceError("this hasn't been initialised - super() hasn't been called"); } return self; } -function _inherits(subClass, superClass) { if (typeof superClass !== "function" && superClass !== null) { throw new TypeError("Super expression must either be null or a function"); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, writable: true, configurable: true } }); if (superClass) _setPrototypeOf(subClass, superClass); } +function _isNativeReflectConstruct() { if (typeof Reflect === "undefined" || !Reflect.construct) return false; if (Reflect.construct.sham) return false; if (typeof Proxy === "function") return true; try { Date.prototype.toString.call(Reflect.construct(Date, [], function () {})); return true; } catch (e) { return false; } } -function _setPrototypeOf(o, p) { _setPrototypeOf = Object.setPrototypeOf || function _setPrototypeOf(o, p) { o.__proto__ = p; return o; }; return _setPrototypeOf(o, p); } +function _getPrototypeOf(o) { _getPrototypeOf = Object.setPrototypeOf ? Object.getPrototypeOf : function _getPrototypeOf(o) { return o.__proto__ || Object.getPrototypeOf(o); }; return _getPrototypeOf(o); } const ConnectionError = require('./../connection-error'); /** @@ -18,17 +22,17 @@ const ConnectionError = require('./../connection-error'); */ -let AccessDeniedError = -/*#__PURE__*/ -function (_ConnectionError) { +let AccessDeniedError = /*#__PURE__*/function (_ConnectionError) { _inherits(AccessDeniedError, _ConnectionError); + var _super = _createSuper(AccessDeniedError); + function AccessDeniedError(parent) { var _this; _classCallCheck(this, AccessDeniedError); - _this = _possibleConstructorReturn(this, _getPrototypeOf(AccessDeniedError).call(this, parent)); + _this = _super.call(this, parent); _this.name = 'SequelizeAccessDeniedError'; Error.captureStackTrace(_assertThisInitialized(_this), _this.constructor); return _this; @@ -38,4 +42,4 @@ function (_ConnectionError) { }(ConnectionError); module.exports = AccessDeniedError; -//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uLy4uL2xpYi9lcnJvcnMvY29ubmVjdGlvbi9hY2Nlc3MtZGVuaWVkLWVycm9yLmpzIl0sIm5hbWVzIjpbIkNvbm5lY3Rpb25FcnJvciIsInJlcXVpcmUiLCJBY2Nlc3NEZW5pZWRFcnJvciIsInBhcmVudCIsIm5hbWUiLCJFcnJvciIsImNhcHR1cmVTdGFja1RyYWNlIiwiY29uc3RydWN0b3IiLCJtb2R1bGUiLCJleHBvcnRzIl0sIm1hcHBpbmdzIjoiQUFBQTs7Ozs7Ozs7Ozs7Ozs7QUFFQSxNQUFNQSxlQUFlLEdBQUdDLE9BQU8sQ0FBQyx1QkFBRCxDQUEvQjtBQUVBOzs7OztJQUdNQyxpQjs7Ozs7QUFDSiw2QkFBWUMsTUFBWixFQUFvQjtBQUFBOztBQUFBOztBQUNsQiwyRkFBTUEsTUFBTjtBQUNBLFVBQUtDLElBQUwsR0FBWSw0QkFBWjtBQUNBQyxJQUFBQSxLQUFLLENBQUNDLGlCQUFOLGdDQUE4QixNQUFLQyxXQUFuQztBQUhrQjtBQUluQjs7O0VBTDZCUCxlOztBQVFoQ1EsTUFBTSxDQUFDQyxPQUFQLEdBQWlCUCxpQkFBakIiLCJzb3VyY2VzQ29udGVudCI6WyIndXNlIHN0cmljdCc7XHJcblxyXG5jb25zdCBDb25uZWN0aW9uRXJyb3IgPSByZXF1aXJlKCcuLy4uL2Nvbm5lY3Rpb24tZXJyb3InKTtcclxuXHJcbi8qKlxyXG4gKiBUaHJvd24gd2hlbiBhIGNvbm5lY3Rpb24gdG8gYSBkYXRhYmFzZSBpcyByZWZ1c2VkIGR1ZSB0byBpbnN1ZmZpY2llbnQgcHJpdmlsZWdlc1xyXG4gKi9cclxuY2xhc3MgQWNjZXNzRGVuaWVkRXJyb3IgZXh0ZW5kcyBDb25uZWN0aW9uRXJyb3Ige1xyXG4gIGNvbnN0cnVjdG9yKHBhcmVudCkge1xyXG4gICAgc3VwZXIocGFyZW50KTtcclxuICAgIHRoaXMubmFtZSA9ICdTZXF1ZWxpemVBY2Nlc3NEZW5pZWRFcnJvcic7XHJcbiAgICBFcnJvci5jYXB0dXJlU3RhY2tUcmFjZSh0aGlzLCB0aGlzLmNvbnN0cnVjdG9yKTtcclxuICB9XHJcbn1cclxuXHJcbm1vZHVsZS5leHBvcnRzID0gQWNjZXNzRGVuaWVkRXJyb3I7XHJcbiJdfQ== \ No newline at end of file +//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uLy4uL2xpYi9lcnJvcnMvY29ubmVjdGlvbi9hY2Nlc3MtZGVuaWVkLWVycm9yLmpzIl0sIm5hbWVzIjpbIkNvbm5lY3Rpb25FcnJvciIsInJlcXVpcmUiLCJBY2Nlc3NEZW5pZWRFcnJvciIsInBhcmVudCIsIm5hbWUiLCJFcnJvciIsImNhcHR1cmVTdGFja1RyYWNlIiwiY29uc3RydWN0b3IiLCJtb2R1bGUiLCJleHBvcnRzIl0sIm1hcHBpbmdzIjoiQUFBQTs7Ozs7Ozs7Ozs7Ozs7Ozs7O0FBRUEsTUFBTUEsZUFBZSxHQUFHQyxPQUFPLENBQUMsdUJBQUQsQ0FBL0I7QUFFQTtBQUNBO0FBQ0E7OztJQUNNQyxpQjs7Ozs7QUFDSiw2QkFBWUMsTUFBWixFQUFvQjtBQUFBOztBQUFBOztBQUNsQiw4QkFBTUEsTUFBTjtBQUNBLFVBQUtDLElBQUwsR0FBWSw0QkFBWjtBQUNBQyxJQUFBQSxLQUFLLENBQUNDLGlCQUFOLGdDQUE4QixNQUFLQyxXQUFuQztBQUhrQjtBQUluQjs7O0VBTDZCUCxlOztBQVFoQ1EsTUFBTSxDQUFDQyxPQUFQLEdBQWlCUCxpQkFBakIiLCJzb3VyY2VzQ29udGVudCI6WyIndXNlIHN0cmljdCc7XG5cbmNvbnN0IENvbm5lY3Rpb25FcnJvciA9IHJlcXVpcmUoJy4vLi4vY29ubmVjdGlvbi1lcnJvcicpO1xuXG4vKipcbiAqIFRocm93biB3aGVuIGEgY29ubmVjdGlvbiB0byBhIGRhdGFiYXNlIGlzIHJlZnVzZWQgZHVlIHRvIGluc3VmZmljaWVudCBwcml2aWxlZ2VzXG4gKi9cbmNsYXNzIEFjY2Vzc0RlbmllZEVycm9yIGV4dGVuZHMgQ29ubmVjdGlvbkVycm9yIHtcbiAgY29uc3RydWN0b3IocGFyZW50KSB7XG4gICAgc3VwZXIocGFyZW50KTtcbiAgICB0aGlzLm5hbWUgPSAnU2VxdWVsaXplQWNjZXNzRGVuaWVkRXJyb3InO1xuICAgIEVycm9yLmNhcHR1cmVTdGFja1RyYWNlKHRoaXMsIHRoaXMuY29uc3RydWN0b3IpO1xuICB9XG59XG5cbm1vZHVsZS5leHBvcnRzID0gQWNjZXNzRGVuaWVkRXJyb3I7XG4iXX0= \ No newline at end of file diff --git a/dist/errors/connection/connection-acquire-timeout-error.js b/dist/errors/connection/connection-acquire-timeout-error.js index 5caabd9..be81d90 100644 --- a/dist/errors/connection/connection-acquire-timeout-error.js +++ b/dist/errors/connection/connection-acquire-timeout-error.js @@ -2,15 +2,19 @@ function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } } -function _possibleConstructorReturn(self, call) { if (call && (typeof call === "object" || typeof call === "function")) { return call; } return _assertThisInitialized(self); } +function _inherits(subClass, superClass) { if (typeof superClass !== "function" && superClass !== null) { throw new TypeError("Super expression must either be null or a function"); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, writable: true, configurable: true } }); if (superClass) _setPrototypeOf(subClass, superClass); } -function _getPrototypeOf(o) { _getPrototypeOf = Object.setPrototypeOf ? Object.getPrototypeOf : function _getPrototypeOf(o) { return o.__proto__ || Object.getPrototypeOf(o); }; return _getPrototypeOf(o); } +function _setPrototypeOf(o, p) { _setPrototypeOf = Object.setPrototypeOf || function _setPrototypeOf(o, p) { o.__proto__ = p; return o; }; return _setPrototypeOf(o, p); } + +function _createSuper(Derived) { var hasNativeReflectConstruct = _isNativeReflectConstruct(); return function _createSuperInternal() { var Super = _getPrototypeOf(Derived), result; if (hasNativeReflectConstruct) { var NewTarget = _getPrototypeOf(this).constructor; result = Reflect.construct(Super, arguments, NewTarget); } else { result = Super.apply(this, arguments); } return _possibleConstructorReturn(this, result); }; } + +function _possibleConstructorReturn(self, call) { if (call && (typeof call === "object" || typeof call === "function")) { return call; } return _assertThisInitialized(self); } function _assertThisInitialized(self) { if (self === void 0) { throw new ReferenceError("this hasn't been initialised - super() hasn't been called"); } return self; } -function _inherits(subClass, superClass) { if (typeof superClass !== "function" && superClass !== null) { throw new TypeError("Super expression must either be null or a function"); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, writable: true, configurable: true } }); if (superClass) _setPrototypeOf(subClass, superClass); } +function _isNativeReflectConstruct() { if (typeof Reflect === "undefined" || !Reflect.construct) return false; if (Reflect.construct.sham) return false; if (typeof Proxy === "function") return true; try { Date.prototype.toString.call(Reflect.construct(Date, [], function () {})); return true; } catch (e) { return false; } } -function _setPrototypeOf(o, p) { _setPrototypeOf = Object.setPrototypeOf || function _setPrototypeOf(o, p) { o.__proto__ = p; return o; }; return _setPrototypeOf(o, p); } +function _getPrototypeOf(o) { _getPrototypeOf = Object.setPrototypeOf ? Object.getPrototypeOf : function _getPrototypeOf(o) { return o.__proto__ || Object.getPrototypeOf(o); }; return _getPrototypeOf(o); } const ConnectionError = require('./../connection-error'); /** @@ -18,17 +22,17 @@ const ConnectionError = require('./../connection-error'); */ -let ConnectionAcquireTimeoutError = -/*#__PURE__*/ -function (_ConnectionError) { +let ConnectionAcquireTimeoutError = /*#__PURE__*/function (_ConnectionError) { _inherits(ConnectionAcquireTimeoutError, _ConnectionError); + var _super = _createSuper(ConnectionAcquireTimeoutError); + function ConnectionAcquireTimeoutError(parent) { var _this; _classCallCheck(this, ConnectionAcquireTimeoutError); - _this = _possibleConstructorReturn(this, _getPrototypeOf(ConnectionAcquireTimeoutError).call(this, parent)); + _this = _super.call(this, parent); _this.name = 'SequelizeConnectionAcquireTimeoutError'; Error.captureStackTrace(_assertThisInitialized(_this), _this.constructor); return _this; @@ -38,4 +42,4 @@ function (_ConnectionError) { }(ConnectionError); module.exports = ConnectionAcquireTimeoutError; -//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uLy4uL2xpYi9lcnJvcnMvY29ubmVjdGlvbi9jb25uZWN0aW9uLWFjcXVpcmUtdGltZW91dC1lcnJvci5qcyJdLCJuYW1lcyI6WyJDb25uZWN0aW9uRXJyb3IiLCJyZXF1aXJlIiwiQ29ubmVjdGlvbkFjcXVpcmVUaW1lb3V0RXJyb3IiLCJwYXJlbnQiLCJuYW1lIiwiRXJyb3IiLCJjYXB0dXJlU3RhY2tUcmFjZSIsImNvbnN0cnVjdG9yIiwibW9kdWxlIiwiZXhwb3J0cyJdLCJtYXBwaW5ncyI6IkFBQUE7Ozs7Ozs7Ozs7Ozs7O0FBRUEsTUFBTUEsZUFBZSxHQUFHQyxPQUFPLENBQUMsdUJBQUQsQ0FBL0I7QUFFQTs7Ozs7SUFHTUMsNkI7Ozs7O0FBQ0oseUNBQVlDLE1BQVosRUFBb0I7QUFBQTs7QUFBQTs7QUFDbEIsdUdBQU1BLE1BQU47QUFDQSxVQUFLQyxJQUFMLEdBQVksd0NBQVo7QUFDQUMsSUFBQUEsS0FBSyxDQUFDQyxpQkFBTixnQ0FBOEIsTUFBS0MsV0FBbkM7QUFIa0I7QUFJbkI7OztFQUx5Q1AsZTs7QUFRNUNRLE1BQU0sQ0FBQ0MsT0FBUCxHQUFpQlAsNkJBQWpCIiwic291cmNlc0NvbnRlbnQiOlsiJ3VzZSBzdHJpY3QnO1xyXG5cclxuY29uc3QgQ29ubmVjdGlvbkVycm9yID0gcmVxdWlyZSgnLi8uLi9jb25uZWN0aW9uLWVycm9yJyk7XHJcblxyXG4vKipcclxuICogVGhyb3duIHdoZW4gY29ubmVjdGlvbiBpcyBub3QgYWNxdWlyZWQgZHVlIHRvIHRpbWVvdXRcclxuICovXHJcbmNsYXNzIENvbm5lY3Rpb25BY3F1aXJlVGltZW91dEVycm9yIGV4dGVuZHMgQ29ubmVjdGlvbkVycm9yIHtcclxuICBjb25zdHJ1Y3RvcihwYXJlbnQpIHtcclxuICAgIHN1cGVyKHBhcmVudCk7XHJcbiAgICB0aGlzLm5hbWUgPSAnU2VxdWVsaXplQ29ubmVjdGlvbkFjcXVpcmVUaW1lb3V0RXJyb3InO1xyXG4gICAgRXJyb3IuY2FwdHVyZVN0YWNrVHJhY2UodGhpcywgdGhpcy5jb25zdHJ1Y3Rvcik7XHJcbiAgfVxyXG59XHJcblxyXG5tb2R1bGUuZXhwb3J0cyA9IENvbm5lY3Rpb25BY3F1aXJlVGltZW91dEVycm9yO1xyXG4iXX0= \ No newline at end of file +//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uLy4uL2xpYi9lcnJvcnMvY29ubmVjdGlvbi9jb25uZWN0aW9uLWFjcXVpcmUtdGltZW91dC1lcnJvci5qcyJdLCJuYW1lcyI6WyJDb25uZWN0aW9uRXJyb3IiLCJyZXF1aXJlIiwiQ29ubmVjdGlvbkFjcXVpcmVUaW1lb3V0RXJyb3IiLCJwYXJlbnQiLCJuYW1lIiwiRXJyb3IiLCJjYXB0dXJlU3RhY2tUcmFjZSIsImNvbnN0cnVjdG9yIiwibW9kdWxlIiwiZXhwb3J0cyJdLCJtYXBwaW5ncyI6IkFBQUE7Ozs7Ozs7Ozs7Ozs7Ozs7OztBQUVBLE1BQU1BLGVBQWUsR0FBR0MsT0FBTyxDQUFDLHVCQUFELENBQS9CO0FBRUE7QUFDQTtBQUNBOzs7SUFDTUMsNkI7Ozs7O0FBQ0oseUNBQVlDLE1BQVosRUFBb0I7QUFBQTs7QUFBQTs7QUFDbEIsOEJBQU1BLE1BQU47QUFDQSxVQUFLQyxJQUFMLEdBQVksd0NBQVo7QUFDQUMsSUFBQUEsS0FBSyxDQUFDQyxpQkFBTixnQ0FBOEIsTUFBS0MsV0FBbkM7QUFIa0I7QUFJbkI7OztFQUx5Q1AsZTs7QUFRNUNRLE1BQU0sQ0FBQ0MsT0FBUCxHQUFpQlAsNkJBQWpCIiwic291cmNlc0NvbnRlbnQiOlsiJ3VzZSBzdHJpY3QnO1xuXG5jb25zdCBDb25uZWN0aW9uRXJyb3IgPSByZXF1aXJlKCcuLy4uL2Nvbm5lY3Rpb24tZXJyb3InKTtcblxuLyoqXG4gKiBUaHJvd24gd2hlbiBjb25uZWN0aW9uIGlzIG5vdCBhY3F1aXJlZCBkdWUgdG8gdGltZW91dFxuICovXG5jbGFzcyBDb25uZWN0aW9uQWNxdWlyZVRpbWVvdXRFcnJvciBleHRlbmRzIENvbm5lY3Rpb25FcnJvciB7XG4gIGNvbnN0cnVjdG9yKHBhcmVudCkge1xuICAgIHN1cGVyKHBhcmVudCk7XG4gICAgdGhpcy5uYW1lID0gJ1NlcXVlbGl6ZUNvbm5lY3Rpb25BY3F1aXJlVGltZW91dEVycm9yJztcbiAgICBFcnJvci5jYXB0dXJlU3RhY2tUcmFjZSh0aGlzLCB0aGlzLmNvbnN0cnVjdG9yKTtcbiAgfVxufVxuXG5tb2R1bGUuZXhwb3J0cyA9IENvbm5lY3Rpb25BY3F1aXJlVGltZW91dEVycm9yO1xuIl19 \ No newline at end of file diff --git a/dist/errors/connection/connection-refused-error.js b/dist/errors/connection/connection-refused-error.js index 8bcf487..7c38063 100644 --- a/dist/errors/connection/connection-refused-error.js +++ b/dist/errors/connection/connection-refused-error.js @@ -2,15 +2,19 @@ function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } } -function _possibleConstructorReturn(self, call) { if (call && (typeof call === "object" || typeof call === "function")) { return call; } return _assertThisInitialized(self); } +function _inherits(subClass, superClass) { if (typeof superClass !== "function" && superClass !== null) { throw new TypeError("Super expression must either be null or a function"); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, writable: true, configurable: true } }); if (superClass) _setPrototypeOf(subClass, superClass); } -function _getPrototypeOf(o) { _getPrototypeOf = Object.setPrototypeOf ? Object.getPrototypeOf : function _getPrototypeOf(o) { return o.__proto__ || Object.getPrototypeOf(o); }; return _getPrototypeOf(o); } +function _setPrototypeOf(o, p) { _setPrototypeOf = Object.setPrototypeOf || function _setPrototypeOf(o, p) { o.__proto__ = p; return o; }; return _setPrototypeOf(o, p); } + +function _createSuper(Derived) { var hasNativeReflectConstruct = _isNativeReflectConstruct(); return function _createSuperInternal() { var Super = _getPrototypeOf(Derived), result; if (hasNativeReflectConstruct) { var NewTarget = _getPrototypeOf(this).constructor; result = Reflect.construct(Super, arguments, NewTarget); } else { result = Super.apply(this, arguments); } return _possibleConstructorReturn(this, result); }; } + +function _possibleConstructorReturn(self, call) { if (call && (typeof call === "object" || typeof call === "function")) { return call; } return _assertThisInitialized(self); } function _assertThisInitialized(self) { if (self === void 0) { throw new ReferenceError("this hasn't been initialised - super() hasn't been called"); } return self; } -function _inherits(subClass, superClass) { if (typeof superClass !== "function" && superClass !== null) { throw new TypeError("Super expression must either be null or a function"); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, writable: true, configurable: true } }); if (superClass) _setPrototypeOf(subClass, superClass); } +function _isNativeReflectConstruct() { if (typeof Reflect === "undefined" || !Reflect.construct) return false; if (Reflect.construct.sham) return false; if (typeof Proxy === "function") return true; try { Date.prototype.toString.call(Reflect.construct(Date, [], function () {})); return true; } catch (e) { return false; } } -function _setPrototypeOf(o, p) { _setPrototypeOf = Object.setPrototypeOf || function _setPrototypeOf(o, p) { o.__proto__ = p; return o; }; return _setPrototypeOf(o, p); } +function _getPrototypeOf(o) { _getPrototypeOf = Object.setPrototypeOf ? Object.getPrototypeOf : function _getPrototypeOf(o) { return o.__proto__ || Object.getPrototypeOf(o); }; return _getPrototypeOf(o); } const ConnectionError = require('./../connection-error'); /** @@ -18,17 +22,17 @@ const ConnectionError = require('./../connection-error'); */ -let ConnectionRefusedError = -/*#__PURE__*/ -function (_ConnectionError) { +let ConnectionRefusedError = /*#__PURE__*/function (_ConnectionError) { _inherits(ConnectionRefusedError, _ConnectionError); + var _super = _createSuper(ConnectionRefusedError); + function ConnectionRefusedError(parent) { var _this; _classCallCheck(this, ConnectionRefusedError); - _this = _possibleConstructorReturn(this, _getPrototypeOf(ConnectionRefusedError).call(this, parent)); + _this = _super.call(this, parent); _this.name = 'SequelizeConnectionRefusedError'; Error.captureStackTrace(_assertThisInitialized(_this), _this.constructor); return _this; @@ -38,4 +42,4 @@ function (_ConnectionError) { }(ConnectionError); module.exports = ConnectionRefusedError; -//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uLy4uL2xpYi9lcnJvcnMvY29ubmVjdGlvbi9jb25uZWN0aW9uLXJlZnVzZWQtZXJyb3IuanMiXSwibmFtZXMiOlsiQ29ubmVjdGlvbkVycm9yIiwicmVxdWlyZSIsIkNvbm5lY3Rpb25SZWZ1c2VkRXJyb3IiLCJwYXJlbnQiLCJuYW1lIiwiRXJyb3IiLCJjYXB0dXJlU3RhY2tUcmFjZSIsImNvbnN0cnVjdG9yIiwibW9kdWxlIiwiZXhwb3J0cyJdLCJtYXBwaW5ncyI6IkFBQUE7Ozs7Ozs7Ozs7Ozs7O0FBRUEsTUFBTUEsZUFBZSxHQUFHQyxPQUFPLENBQUMsdUJBQUQsQ0FBL0I7QUFFQTs7Ozs7SUFHTUMsc0I7Ozs7O0FBQ0osa0NBQVlDLE1BQVosRUFBb0I7QUFBQTs7QUFBQTs7QUFDbEIsZ0dBQU1BLE1BQU47QUFDQSxVQUFLQyxJQUFMLEdBQVksaUNBQVo7QUFDQUMsSUFBQUEsS0FBSyxDQUFDQyxpQkFBTixnQ0FBOEIsTUFBS0MsV0FBbkM7QUFIa0I7QUFJbkI7OztFQUxrQ1AsZTs7QUFRckNRLE1BQU0sQ0FBQ0MsT0FBUCxHQUFpQlAsc0JBQWpCIiwic291cmNlc0NvbnRlbnQiOlsiJ3VzZSBzdHJpY3QnO1xyXG5cclxuY29uc3QgQ29ubmVjdGlvbkVycm9yID0gcmVxdWlyZSgnLi8uLi9jb25uZWN0aW9uLWVycm9yJyk7XHJcblxyXG4vKipcclxuICogVGhyb3duIHdoZW4gYSBjb25uZWN0aW9uIHRvIGEgZGF0YWJhc2UgaXMgcmVmdXNlZFxyXG4gKi9cclxuY2xhc3MgQ29ubmVjdGlvblJlZnVzZWRFcnJvciBleHRlbmRzIENvbm5lY3Rpb25FcnJvciB7XHJcbiAgY29uc3RydWN0b3IocGFyZW50KSB7XHJcbiAgICBzdXBlcihwYXJlbnQpO1xyXG4gICAgdGhpcy5uYW1lID0gJ1NlcXVlbGl6ZUNvbm5lY3Rpb25SZWZ1c2VkRXJyb3InO1xyXG4gICAgRXJyb3IuY2FwdHVyZVN0YWNrVHJhY2UodGhpcywgdGhpcy5jb25zdHJ1Y3Rvcik7XHJcbiAgfVxyXG59XHJcblxyXG5tb2R1bGUuZXhwb3J0cyA9IENvbm5lY3Rpb25SZWZ1c2VkRXJyb3I7XHJcbiJdfQ== \ No newline at end of file +//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uLy4uL2xpYi9lcnJvcnMvY29ubmVjdGlvbi9jb25uZWN0aW9uLXJlZnVzZWQtZXJyb3IuanMiXSwibmFtZXMiOlsiQ29ubmVjdGlvbkVycm9yIiwicmVxdWlyZSIsIkNvbm5lY3Rpb25SZWZ1c2VkRXJyb3IiLCJwYXJlbnQiLCJuYW1lIiwiRXJyb3IiLCJjYXB0dXJlU3RhY2tUcmFjZSIsImNvbnN0cnVjdG9yIiwibW9kdWxlIiwiZXhwb3J0cyJdLCJtYXBwaW5ncyI6IkFBQUE7Ozs7Ozs7Ozs7Ozs7Ozs7OztBQUVBLE1BQU1BLGVBQWUsR0FBR0MsT0FBTyxDQUFDLHVCQUFELENBQS9CO0FBRUE7QUFDQTtBQUNBOzs7SUFDTUMsc0I7Ozs7O0FBQ0osa0NBQVlDLE1BQVosRUFBb0I7QUFBQTs7QUFBQTs7QUFDbEIsOEJBQU1BLE1BQU47QUFDQSxVQUFLQyxJQUFMLEdBQVksaUNBQVo7QUFDQUMsSUFBQUEsS0FBSyxDQUFDQyxpQkFBTixnQ0FBOEIsTUFBS0MsV0FBbkM7QUFIa0I7QUFJbkI7OztFQUxrQ1AsZTs7QUFRckNRLE1BQU0sQ0FBQ0MsT0FBUCxHQUFpQlAsc0JBQWpCIiwic291cmNlc0NvbnRlbnQiOlsiJ3VzZSBzdHJpY3QnO1xuXG5jb25zdCBDb25uZWN0aW9uRXJyb3IgPSByZXF1aXJlKCcuLy4uL2Nvbm5lY3Rpb24tZXJyb3InKTtcblxuLyoqXG4gKiBUaHJvd24gd2hlbiBhIGNvbm5lY3Rpb24gdG8gYSBkYXRhYmFzZSBpcyByZWZ1c2VkXG4gKi9cbmNsYXNzIENvbm5lY3Rpb25SZWZ1c2VkRXJyb3IgZXh0ZW5kcyBDb25uZWN0aW9uRXJyb3Ige1xuICBjb25zdHJ1Y3RvcihwYXJlbnQpIHtcbiAgICBzdXBlcihwYXJlbnQpO1xuICAgIHRoaXMubmFtZSA9ICdTZXF1ZWxpemVDb25uZWN0aW9uUmVmdXNlZEVycm9yJztcbiAgICBFcnJvci5jYXB0dXJlU3RhY2tUcmFjZSh0aGlzLCB0aGlzLmNvbnN0cnVjdG9yKTtcbiAgfVxufVxuXG5tb2R1bGUuZXhwb3J0cyA9IENvbm5lY3Rpb25SZWZ1c2VkRXJyb3I7XG4iXX0= \ No newline at end of file diff --git a/dist/errors/connection/connection-timed-out-error.js b/dist/errors/connection/connection-timed-out-error.js index 8ae3b70..0cfc57f 100644 --- a/dist/errors/connection/connection-timed-out-error.js +++ b/dist/errors/connection/connection-timed-out-error.js @@ -2,15 +2,19 @@ function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } } -function _possibleConstructorReturn(self, call) { if (call && (typeof call === "object" || typeof call === "function")) { return call; } return _assertThisInitialized(self); } +function _inherits(subClass, superClass) { if (typeof superClass !== "function" && superClass !== null) { throw new TypeError("Super expression must either be null or a function"); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, writable: true, configurable: true } }); if (superClass) _setPrototypeOf(subClass, superClass); } -function _getPrototypeOf(o) { _getPrototypeOf = Object.setPrototypeOf ? Object.getPrototypeOf : function _getPrototypeOf(o) { return o.__proto__ || Object.getPrototypeOf(o); }; return _getPrototypeOf(o); } +function _setPrototypeOf(o, p) { _setPrototypeOf = Object.setPrototypeOf || function _setPrototypeOf(o, p) { o.__proto__ = p; return o; }; return _setPrototypeOf(o, p); } + +function _createSuper(Derived) { var hasNativeReflectConstruct = _isNativeReflectConstruct(); return function _createSuperInternal() { var Super = _getPrototypeOf(Derived), result; if (hasNativeReflectConstruct) { var NewTarget = _getPrototypeOf(this).constructor; result = Reflect.construct(Super, arguments, NewTarget); } else { result = Super.apply(this, arguments); } return _possibleConstructorReturn(this, result); }; } + +function _possibleConstructorReturn(self, call) { if (call && (typeof call === "object" || typeof call === "function")) { return call; } return _assertThisInitialized(self); } function _assertThisInitialized(self) { if (self === void 0) { throw new ReferenceError("this hasn't been initialised - super() hasn't been called"); } return self; } -function _inherits(subClass, superClass) { if (typeof superClass !== "function" && superClass !== null) { throw new TypeError("Super expression must either be null or a function"); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, writable: true, configurable: true } }); if (superClass) _setPrototypeOf(subClass, superClass); } +function _isNativeReflectConstruct() { if (typeof Reflect === "undefined" || !Reflect.construct) return false; if (Reflect.construct.sham) return false; if (typeof Proxy === "function") return true; try { Date.prototype.toString.call(Reflect.construct(Date, [], function () {})); return true; } catch (e) { return false; } } -function _setPrototypeOf(o, p) { _setPrototypeOf = Object.setPrototypeOf || function _setPrototypeOf(o, p) { o.__proto__ = p; return o; }; return _setPrototypeOf(o, p); } +function _getPrototypeOf(o) { _getPrototypeOf = Object.setPrototypeOf ? Object.getPrototypeOf : function _getPrototypeOf(o) { return o.__proto__ || Object.getPrototypeOf(o); }; return _getPrototypeOf(o); } const ConnectionError = require('./../connection-error'); /** @@ -18,17 +22,17 @@ const ConnectionError = require('./../connection-error'); */ -let ConnectionTimedOutError = -/*#__PURE__*/ -function (_ConnectionError) { +let ConnectionTimedOutError = /*#__PURE__*/function (_ConnectionError) { _inherits(ConnectionTimedOutError, _ConnectionError); + var _super = _createSuper(ConnectionTimedOutError); + function ConnectionTimedOutError(parent) { var _this; _classCallCheck(this, ConnectionTimedOutError); - _this = _possibleConstructorReturn(this, _getPrototypeOf(ConnectionTimedOutError).call(this, parent)); + _this = _super.call(this, parent); _this.name = 'SequelizeConnectionTimedOutError'; Error.captureStackTrace(_assertThisInitialized(_this), _this.constructor); return _this; @@ -38,4 +42,4 @@ function (_ConnectionError) { }(ConnectionError); module.exports = ConnectionTimedOutError; -//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uLy4uL2xpYi9lcnJvcnMvY29ubmVjdGlvbi9jb25uZWN0aW9uLXRpbWVkLW91dC1lcnJvci5qcyJdLCJuYW1lcyI6WyJDb25uZWN0aW9uRXJyb3IiLCJyZXF1aXJlIiwiQ29ubmVjdGlvblRpbWVkT3V0RXJyb3IiLCJwYXJlbnQiLCJuYW1lIiwiRXJyb3IiLCJjYXB0dXJlU3RhY2tUcmFjZSIsImNvbnN0cnVjdG9yIiwibW9kdWxlIiwiZXhwb3J0cyJdLCJtYXBwaW5ncyI6IkFBQUE7Ozs7Ozs7Ozs7Ozs7O0FBRUEsTUFBTUEsZUFBZSxHQUFHQyxPQUFPLENBQUMsdUJBQUQsQ0FBL0I7QUFFQTs7Ozs7SUFHTUMsdUI7Ozs7O0FBQ0osbUNBQVlDLE1BQVosRUFBb0I7QUFBQTs7QUFBQTs7QUFDbEIsaUdBQU1BLE1BQU47QUFDQSxVQUFLQyxJQUFMLEdBQVksa0NBQVo7QUFDQUMsSUFBQUEsS0FBSyxDQUFDQyxpQkFBTixnQ0FBOEIsTUFBS0MsV0FBbkM7QUFIa0I7QUFJbkI7OztFQUxtQ1AsZTs7QUFRdENRLE1BQU0sQ0FBQ0MsT0FBUCxHQUFpQlAsdUJBQWpCIiwic291cmNlc0NvbnRlbnQiOlsiJ3VzZSBzdHJpY3QnO1xyXG5cclxuY29uc3QgQ29ubmVjdGlvbkVycm9yID0gcmVxdWlyZSgnLi8uLi9jb25uZWN0aW9uLWVycm9yJyk7XHJcblxyXG4vKipcclxuICogVGhyb3duIHdoZW4gYSBjb25uZWN0aW9uIHRvIGEgZGF0YWJhc2UgdGltZXMgb3V0XHJcbiAqL1xyXG5jbGFzcyBDb25uZWN0aW9uVGltZWRPdXRFcnJvciBleHRlbmRzIENvbm5lY3Rpb25FcnJvciB7XHJcbiAgY29uc3RydWN0b3IocGFyZW50KSB7XHJcbiAgICBzdXBlcihwYXJlbnQpO1xyXG4gICAgdGhpcy5uYW1lID0gJ1NlcXVlbGl6ZUNvbm5lY3Rpb25UaW1lZE91dEVycm9yJztcclxuICAgIEVycm9yLmNhcHR1cmVTdGFja1RyYWNlKHRoaXMsIHRoaXMuY29uc3RydWN0b3IpO1xyXG4gIH1cclxufVxyXG5cclxubW9kdWxlLmV4cG9ydHMgPSBDb25uZWN0aW9uVGltZWRPdXRFcnJvcjtcclxuIl19 \ No newline at end of file +//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uLy4uL2xpYi9lcnJvcnMvY29ubmVjdGlvbi9jb25uZWN0aW9uLXRpbWVkLW91dC1lcnJvci5qcyJdLCJuYW1lcyI6WyJDb25uZWN0aW9uRXJyb3IiLCJyZXF1aXJlIiwiQ29ubmVjdGlvblRpbWVkT3V0RXJyb3IiLCJwYXJlbnQiLCJuYW1lIiwiRXJyb3IiLCJjYXB0dXJlU3RhY2tUcmFjZSIsImNvbnN0cnVjdG9yIiwibW9kdWxlIiwiZXhwb3J0cyJdLCJtYXBwaW5ncyI6IkFBQUE7Ozs7Ozs7Ozs7Ozs7Ozs7OztBQUVBLE1BQU1BLGVBQWUsR0FBR0MsT0FBTyxDQUFDLHVCQUFELENBQS9CO0FBRUE7QUFDQTtBQUNBOzs7SUFDTUMsdUI7Ozs7O0FBQ0osbUNBQVlDLE1BQVosRUFBb0I7QUFBQTs7QUFBQTs7QUFDbEIsOEJBQU1BLE1BQU47QUFDQSxVQUFLQyxJQUFMLEdBQVksa0NBQVo7QUFDQUMsSUFBQUEsS0FBSyxDQUFDQyxpQkFBTixnQ0FBOEIsTUFBS0MsV0FBbkM7QUFIa0I7QUFJbkI7OztFQUxtQ1AsZTs7QUFRdENRLE1BQU0sQ0FBQ0MsT0FBUCxHQUFpQlAsdUJBQWpCIiwic291cmNlc0NvbnRlbnQiOlsiJ3VzZSBzdHJpY3QnO1xuXG5jb25zdCBDb25uZWN0aW9uRXJyb3IgPSByZXF1aXJlKCcuLy4uL2Nvbm5lY3Rpb24tZXJyb3InKTtcblxuLyoqXG4gKiBUaHJvd24gd2hlbiBhIGNvbm5lY3Rpb24gdG8gYSBkYXRhYmFzZSB0aW1lcyBvdXRcbiAqL1xuY2xhc3MgQ29ubmVjdGlvblRpbWVkT3V0RXJyb3IgZXh0ZW5kcyBDb25uZWN0aW9uRXJyb3Ige1xuICBjb25zdHJ1Y3RvcihwYXJlbnQpIHtcbiAgICBzdXBlcihwYXJlbnQpO1xuICAgIHRoaXMubmFtZSA9ICdTZXF1ZWxpemVDb25uZWN0aW9uVGltZWRPdXRFcnJvcic7XG4gICAgRXJyb3IuY2FwdHVyZVN0YWNrVHJhY2UodGhpcywgdGhpcy5jb25zdHJ1Y3Rvcik7XG4gIH1cbn1cblxubW9kdWxlLmV4cG9ydHMgPSBDb25uZWN0aW9uVGltZWRPdXRFcnJvcjtcbiJdfQ== \ No newline at end of file diff --git a/dist/errors/connection/host-not-found-error.js b/dist/errors/connection/host-not-found-error.js index 5399ce6..4af4455 100644 --- a/dist/errors/connection/host-not-found-error.js +++ b/dist/errors/connection/host-not-found-error.js @@ -2,15 +2,19 @@ function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } } -function _possibleConstructorReturn(self, call) { if (call && (typeof call === "object" || typeof call === "function")) { return call; } return _assertThisInitialized(self); } +function _inherits(subClass, superClass) { if (typeof superClass !== "function" && superClass !== null) { throw new TypeError("Super expression must either be null or a function"); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, writable: true, configurable: true } }); if (superClass) _setPrototypeOf(subClass, superClass); } -function _getPrototypeOf(o) { _getPrototypeOf = Object.setPrototypeOf ? Object.getPrototypeOf : function _getPrototypeOf(o) { return o.__proto__ || Object.getPrototypeOf(o); }; return _getPrototypeOf(o); } +function _setPrototypeOf(o, p) { _setPrototypeOf = Object.setPrototypeOf || function _setPrototypeOf(o, p) { o.__proto__ = p; return o; }; return _setPrototypeOf(o, p); } + +function _createSuper(Derived) { var hasNativeReflectConstruct = _isNativeReflectConstruct(); return function _createSuperInternal() { var Super = _getPrototypeOf(Derived), result; if (hasNativeReflectConstruct) { var NewTarget = _getPrototypeOf(this).constructor; result = Reflect.construct(Super, arguments, NewTarget); } else { result = Super.apply(this, arguments); } return _possibleConstructorReturn(this, result); }; } + +function _possibleConstructorReturn(self, call) { if (call && (typeof call === "object" || typeof call === "function")) { return call; } return _assertThisInitialized(self); } function _assertThisInitialized(self) { if (self === void 0) { throw new ReferenceError("this hasn't been initialised - super() hasn't been called"); } return self; } -function _inherits(subClass, superClass) { if (typeof superClass !== "function" && superClass !== null) { throw new TypeError("Super expression must either be null or a function"); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, writable: true, configurable: true } }); if (superClass) _setPrototypeOf(subClass, superClass); } +function _isNativeReflectConstruct() { if (typeof Reflect === "undefined" || !Reflect.construct) return false; if (Reflect.construct.sham) return false; if (typeof Proxy === "function") return true; try { Date.prototype.toString.call(Reflect.construct(Date, [], function () {})); return true; } catch (e) { return false; } } -function _setPrototypeOf(o, p) { _setPrototypeOf = Object.setPrototypeOf || function _setPrototypeOf(o, p) { o.__proto__ = p; return o; }; return _setPrototypeOf(o, p); } +function _getPrototypeOf(o) { _getPrototypeOf = Object.setPrototypeOf ? Object.getPrototypeOf : function _getPrototypeOf(o) { return o.__proto__ || Object.getPrototypeOf(o); }; return _getPrototypeOf(o); } const ConnectionError = require('./../connection-error'); /** @@ -18,17 +22,17 @@ const ConnectionError = require('./../connection-error'); */ -let HostNotFoundError = -/*#__PURE__*/ -function (_ConnectionError) { +let HostNotFoundError = /*#__PURE__*/function (_ConnectionError) { _inherits(HostNotFoundError, _ConnectionError); + var _super = _createSuper(HostNotFoundError); + function HostNotFoundError(parent) { var _this; _classCallCheck(this, HostNotFoundError); - _this = _possibleConstructorReturn(this, _getPrototypeOf(HostNotFoundError).call(this, parent)); + _this = _super.call(this, parent); _this.name = 'SequelizeHostNotFoundError'; Error.captureStackTrace(_assertThisInitialized(_this), _this.constructor); return _this; @@ -38,4 +42,4 @@ function (_ConnectionError) { }(ConnectionError); module.exports = HostNotFoundError; -//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uLy4uL2xpYi9lcnJvcnMvY29ubmVjdGlvbi9ob3N0LW5vdC1mb3VuZC1lcnJvci5qcyJdLCJuYW1lcyI6WyJDb25uZWN0aW9uRXJyb3IiLCJyZXF1aXJlIiwiSG9zdE5vdEZvdW5kRXJyb3IiLCJwYXJlbnQiLCJuYW1lIiwiRXJyb3IiLCJjYXB0dXJlU3RhY2tUcmFjZSIsImNvbnN0cnVjdG9yIiwibW9kdWxlIiwiZXhwb3J0cyJdLCJtYXBwaW5ncyI6IkFBQUE7Ozs7Ozs7Ozs7Ozs7O0FBRUEsTUFBTUEsZUFBZSxHQUFHQyxPQUFPLENBQUMsdUJBQUQsQ0FBL0I7QUFFQTs7Ozs7SUFHTUMsaUI7Ozs7O0FBQ0osNkJBQVlDLE1BQVosRUFBb0I7QUFBQTs7QUFBQTs7QUFDbEIsMkZBQU1BLE1BQU47QUFDQSxVQUFLQyxJQUFMLEdBQVksNEJBQVo7QUFDQUMsSUFBQUEsS0FBSyxDQUFDQyxpQkFBTixnQ0FBOEIsTUFBS0MsV0FBbkM7QUFIa0I7QUFJbkI7OztFQUw2QlAsZTs7QUFRaENRLE1BQU0sQ0FBQ0MsT0FBUCxHQUFpQlAsaUJBQWpCIiwic291cmNlc0NvbnRlbnQiOlsiJ3VzZSBzdHJpY3QnO1xyXG5cclxuY29uc3QgQ29ubmVjdGlvbkVycm9yID0gcmVxdWlyZSgnLi8uLi9jb25uZWN0aW9uLWVycm9yJyk7XHJcblxyXG4vKipcclxuICogVGhyb3duIHdoZW4gYSBjb25uZWN0aW9uIHRvIGEgZGF0YWJhc2UgaGFzIGEgaG9zdG5hbWUgdGhhdCB3YXMgbm90IGZvdW5kXHJcbiAqL1xyXG5jbGFzcyBIb3N0Tm90Rm91bmRFcnJvciBleHRlbmRzIENvbm5lY3Rpb25FcnJvciB7XHJcbiAgY29uc3RydWN0b3IocGFyZW50KSB7XHJcbiAgICBzdXBlcihwYXJlbnQpO1xyXG4gICAgdGhpcy5uYW1lID0gJ1NlcXVlbGl6ZUhvc3ROb3RGb3VuZEVycm9yJztcclxuICAgIEVycm9yLmNhcHR1cmVTdGFja1RyYWNlKHRoaXMsIHRoaXMuY29uc3RydWN0b3IpO1xyXG4gIH1cclxufVxyXG5cclxubW9kdWxlLmV4cG9ydHMgPSBIb3N0Tm90Rm91bmRFcnJvcjtcclxuIl19 \ No newline at end of file +//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uLy4uL2xpYi9lcnJvcnMvY29ubmVjdGlvbi9ob3N0LW5vdC1mb3VuZC1lcnJvci5qcyJdLCJuYW1lcyI6WyJDb25uZWN0aW9uRXJyb3IiLCJyZXF1aXJlIiwiSG9zdE5vdEZvdW5kRXJyb3IiLCJwYXJlbnQiLCJuYW1lIiwiRXJyb3IiLCJjYXB0dXJlU3RhY2tUcmFjZSIsImNvbnN0cnVjdG9yIiwibW9kdWxlIiwiZXhwb3J0cyJdLCJtYXBwaW5ncyI6IkFBQUE7Ozs7Ozs7Ozs7Ozs7Ozs7OztBQUVBLE1BQU1BLGVBQWUsR0FBR0MsT0FBTyxDQUFDLHVCQUFELENBQS9CO0FBRUE7QUFDQTtBQUNBOzs7SUFDTUMsaUI7Ozs7O0FBQ0osNkJBQVlDLE1BQVosRUFBb0I7QUFBQTs7QUFBQTs7QUFDbEIsOEJBQU1BLE1BQU47QUFDQSxVQUFLQyxJQUFMLEdBQVksNEJBQVo7QUFDQUMsSUFBQUEsS0FBSyxDQUFDQyxpQkFBTixnQ0FBOEIsTUFBS0MsV0FBbkM7QUFIa0I7QUFJbkI7OztFQUw2QlAsZTs7QUFRaENRLE1BQU0sQ0FBQ0MsT0FBUCxHQUFpQlAsaUJBQWpCIiwic291cmNlc0NvbnRlbnQiOlsiJ3VzZSBzdHJpY3QnO1xuXG5jb25zdCBDb25uZWN0aW9uRXJyb3IgPSByZXF1aXJlKCcuLy4uL2Nvbm5lY3Rpb24tZXJyb3InKTtcblxuLyoqXG4gKiBUaHJvd24gd2hlbiBhIGNvbm5lY3Rpb24gdG8gYSBkYXRhYmFzZSBoYXMgYSBob3N0bmFtZSB0aGF0IHdhcyBub3QgZm91bmRcbiAqL1xuY2xhc3MgSG9zdE5vdEZvdW5kRXJyb3IgZXh0ZW5kcyBDb25uZWN0aW9uRXJyb3Ige1xuICBjb25zdHJ1Y3RvcihwYXJlbnQpIHtcbiAgICBzdXBlcihwYXJlbnQpO1xuICAgIHRoaXMubmFtZSA9ICdTZXF1ZWxpemVIb3N0Tm90Rm91bmRFcnJvcic7XG4gICAgRXJyb3IuY2FwdHVyZVN0YWNrVHJhY2UodGhpcywgdGhpcy5jb25zdHJ1Y3Rvcik7XG4gIH1cbn1cblxubW9kdWxlLmV4cG9ydHMgPSBIb3N0Tm90Rm91bmRFcnJvcjtcbiJdfQ== \ No newline at end of file diff --git a/dist/errors/connection/host-not-reachable-error.js b/dist/errors/connection/host-not-reachable-error.js index 2493ac9..3bf13b1 100644 --- a/dist/errors/connection/host-not-reachable-error.js +++ b/dist/errors/connection/host-not-reachable-error.js @@ -2,15 +2,19 @@ function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } } -function _possibleConstructorReturn(self, call) { if (call && (typeof call === "object" || typeof call === "function")) { return call; } return _assertThisInitialized(self); } +function _inherits(subClass, superClass) { if (typeof superClass !== "function" && superClass !== null) { throw new TypeError("Super expression must either be null or a function"); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, writable: true, configurable: true } }); if (superClass) _setPrototypeOf(subClass, superClass); } -function _getPrototypeOf(o) { _getPrototypeOf = Object.setPrototypeOf ? Object.getPrototypeOf : function _getPrototypeOf(o) { return o.__proto__ || Object.getPrototypeOf(o); }; return _getPrototypeOf(o); } +function _setPrototypeOf(o, p) { _setPrototypeOf = Object.setPrototypeOf || function _setPrototypeOf(o, p) { o.__proto__ = p; return o; }; return _setPrototypeOf(o, p); } + +function _createSuper(Derived) { var hasNativeReflectConstruct = _isNativeReflectConstruct(); return function _createSuperInternal() { var Super = _getPrototypeOf(Derived), result; if (hasNativeReflectConstruct) { var NewTarget = _getPrototypeOf(this).constructor; result = Reflect.construct(Super, arguments, NewTarget); } else { result = Super.apply(this, arguments); } return _possibleConstructorReturn(this, result); }; } + +function _possibleConstructorReturn(self, call) { if (call && (typeof call === "object" || typeof call === "function")) { return call; } return _assertThisInitialized(self); } function _assertThisInitialized(self) { if (self === void 0) { throw new ReferenceError("this hasn't been initialised - super() hasn't been called"); } return self; } -function _inherits(subClass, superClass) { if (typeof superClass !== "function" && superClass !== null) { throw new TypeError("Super expression must either be null or a function"); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, writable: true, configurable: true } }); if (superClass) _setPrototypeOf(subClass, superClass); } +function _isNativeReflectConstruct() { if (typeof Reflect === "undefined" || !Reflect.construct) return false; if (Reflect.construct.sham) return false; if (typeof Proxy === "function") return true; try { Date.prototype.toString.call(Reflect.construct(Date, [], function () {})); return true; } catch (e) { return false; } } -function _setPrototypeOf(o, p) { _setPrototypeOf = Object.setPrototypeOf || function _setPrototypeOf(o, p) { o.__proto__ = p; return o; }; return _setPrototypeOf(o, p); } +function _getPrototypeOf(o) { _getPrototypeOf = Object.setPrototypeOf ? Object.getPrototypeOf : function _getPrototypeOf(o) { return o.__proto__ || Object.getPrototypeOf(o); }; return _getPrototypeOf(o); } const ConnectionError = require('./../connection-error'); /** @@ -18,17 +22,17 @@ const ConnectionError = require('./../connection-error'); */ -let HostNotReachableError = -/*#__PURE__*/ -function (_ConnectionError) { +let HostNotReachableError = /*#__PURE__*/function (_ConnectionError) { _inherits(HostNotReachableError, _ConnectionError); + var _super = _createSuper(HostNotReachableError); + function HostNotReachableError(parent) { var _this; _classCallCheck(this, HostNotReachableError); - _this = _possibleConstructorReturn(this, _getPrototypeOf(HostNotReachableError).call(this, parent)); + _this = _super.call(this, parent); _this.name = 'SequelizeHostNotReachableError'; Error.captureStackTrace(_assertThisInitialized(_this), _this.constructor); return _this; @@ -38,4 +42,4 @@ function (_ConnectionError) { }(ConnectionError); module.exports = HostNotReachableError; -//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uLy4uL2xpYi9lcnJvcnMvY29ubmVjdGlvbi9ob3N0LW5vdC1yZWFjaGFibGUtZXJyb3IuanMiXSwibmFtZXMiOlsiQ29ubmVjdGlvbkVycm9yIiwicmVxdWlyZSIsIkhvc3ROb3RSZWFjaGFibGVFcnJvciIsInBhcmVudCIsIm5hbWUiLCJFcnJvciIsImNhcHR1cmVTdGFja1RyYWNlIiwiY29uc3RydWN0b3IiLCJtb2R1bGUiLCJleHBvcnRzIl0sIm1hcHBpbmdzIjoiQUFBQTs7Ozs7Ozs7Ozs7Ozs7QUFFQSxNQUFNQSxlQUFlLEdBQUdDLE9BQU8sQ0FBQyx1QkFBRCxDQUEvQjtBQUVBOzs7OztJQUdNQyxxQjs7Ozs7QUFDSixpQ0FBWUMsTUFBWixFQUFvQjtBQUFBOztBQUFBOztBQUNsQiwrRkFBTUEsTUFBTjtBQUNBLFVBQUtDLElBQUwsR0FBWSxnQ0FBWjtBQUNBQyxJQUFBQSxLQUFLLENBQUNDLGlCQUFOLGdDQUE4QixNQUFLQyxXQUFuQztBQUhrQjtBQUluQjs7O0VBTGlDUCxlOztBQVFwQ1EsTUFBTSxDQUFDQyxPQUFQLEdBQWlCUCxxQkFBakIiLCJzb3VyY2VzQ29udGVudCI6WyIndXNlIHN0cmljdCc7XHJcblxyXG5jb25zdCBDb25uZWN0aW9uRXJyb3IgPSByZXF1aXJlKCcuLy4uL2Nvbm5lY3Rpb24tZXJyb3InKTtcclxuXHJcbi8qKlxyXG4gKiBUaHJvd24gd2hlbiBhIGNvbm5lY3Rpb24gdG8gYSBkYXRhYmFzZSBoYXMgYSBob3N0bmFtZSB0aGF0IHdhcyBub3QgcmVhY2hhYmxlXHJcbiAqL1xyXG5jbGFzcyBIb3N0Tm90UmVhY2hhYmxlRXJyb3IgZXh0ZW5kcyBDb25uZWN0aW9uRXJyb3Ige1xyXG4gIGNvbnN0cnVjdG9yKHBhcmVudCkge1xyXG4gICAgc3VwZXIocGFyZW50KTtcclxuICAgIHRoaXMubmFtZSA9ICdTZXF1ZWxpemVIb3N0Tm90UmVhY2hhYmxlRXJyb3InO1xyXG4gICAgRXJyb3IuY2FwdHVyZVN0YWNrVHJhY2UodGhpcywgdGhpcy5jb25zdHJ1Y3Rvcik7XHJcbiAgfVxyXG59XHJcblxyXG5tb2R1bGUuZXhwb3J0cyA9IEhvc3ROb3RSZWFjaGFibGVFcnJvcjtcclxuIl19 \ No newline at end of file +//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uLy4uL2xpYi9lcnJvcnMvY29ubmVjdGlvbi9ob3N0LW5vdC1yZWFjaGFibGUtZXJyb3IuanMiXSwibmFtZXMiOlsiQ29ubmVjdGlvbkVycm9yIiwicmVxdWlyZSIsIkhvc3ROb3RSZWFjaGFibGVFcnJvciIsInBhcmVudCIsIm5hbWUiLCJFcnJvciIsImNhcHR1cmVTdGFja1RyYWNlIiwiY29uc3RydWN0b3IiLCJtb2R1bGUiLCJleHBvcnRzIl0sIm1hcHBpbmdzIjoiQUFBQTs7Ozs7Ozs7Ozs7Ozs7Ozs7O0FBRUEsTUFBTUEsZUFBZSxHQUFHQyxPQUFPLENBQUMsdUJBQUQsQ0FBL0I7QUFFQTtBQUNBO0FBQ0E7OztJQUNNQyxxQjs7Ozs7QUFDSixpQ0FBWUMsTUFBWixFQUFvQjtBQUFBOztBQUFBOztBQUNsQiw4QkFBTUEsTUFBTjtBQUNBLFVBQUtDLElBQUwsR0FBWSxnQ0FBWjtBQUNBQyxJQUFBQSxLQUFLLENBQUNDLGlCQUFOLGdDQUE4QixNQUFLQyxXQUFuQztBQUhrQjtBQUluQjs7O0VBTGlDUCxlOztBQVFwQ1EsTUFBTSxDQUFDQyxPQUFQLEdBQWlCUCxxQkFBakIiLCJzb3VyY2VzQ29udGVudCI6WyIndXNlIHN0cmljdCc7XG5cbmNvbnN0IENvbm5lY3Rpb25FcnJvciA9IHJlcXVpcmUoJy4vLi4vY29ubmVjdGlvbi1lcnJvcicpO1xuXG4vKipcbiAqIFRocm93biB3aGVuIGEgY29ubmVjdGlvbiB0byBhIGRhdGFiYXNlIGhhcyBhIGhvc3RuYW1lIHRoYXQgd2FzIG5vdCByZWFjaGFibGVcbiAqL1xuY2xhc3MgSG9zdE5vdFJlYWNoYWJsZUVycm9yIGV4dGVuZHMgQ29ubmVjdGlvbkVycm9yIHtcbiAgY29uc3RydWN0b3IocGFyZW50KSB7XG4gICAgc3VwZXIocGFyZW50KTtcbiAgICB0aGlzLm5hbWUgPSAnU2VxdWVsaXplSG9zdE5vdFJlYWNoYWJsZUVycm9yJztcbiAgICBFcnJvci5jYXB0dXJlU3RhY2tUcmFjZSh0aGlzLCB0aGlzLmNvbnN0cnVjdG9yKTtcbiAgfVxufVxuXG5tb2R1bGUuZXhwb3J0cyA9IEhvc3ROb3RSZWFjaGFibGVFcnJvcjtcbiJdfQ== \ No newline at end of file diff --git a/dist/errors/connection/invalid-connection-error.js b/dist/errors/connection/invalid-connection-error.js index 52bd6b8..f88526b 100644 --- a/dist/errors/connection/invalid-connection-error.js +++ b/dist/errors/connection/invalid-connection-error.js @@ -2,15 +2,19 @@ function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } } -function _possibleConstructorReturn(self, call) { if (call && (typeof call === "object" || typeof call === "function")) { return call; } return _assertThisInitialized(self); } +function _inherits(subClass, superClass) { if (typeof superClass !== "function" && superClass !== null) { throw new TypeError("Super expression must either be null or a function"); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, writable: true, configurable: true } }); if (superClass) _setPrototypeOf(subClass, superClass); } -function _getPrototypeOf(o) { _getPrototypeOf = Object.setPrototypeOf ? Object.getPrototypeOf : function _getPrototypeOf(o) { return o.__proto__ || Object.getPrototypeOf(o); }; return _getPrototypeOf(o); } +function _setPrototypeOf(o, p) { _setPrototypeOf = Object.setPrototypeOf || function _setPrototypeOf(o, p) { o.__proto__ = p; return o; }; return _setPrototypeOf(o, p); } + +function _createSuper(Derived) { var hasNativeReflectConstruct = _isNativeReflectConstruct(); return function _createSuperInternal() { var Super = _getPrototypeOf(Derived), result; if (hasNativeReflectConstruct) { var NewTarget = _getPrototypeOf(this).constructor; result = Reflect.construct(Super, arguments, NewTarget); } else { result = Super.apply(this, arguments); } return _possibleConstructorReturn(this, result); }; } + +function _possibleConstructorReturn(self, call) { if (call && (typeof call === "object" || typeof call === "function")) { return call; } return _assertThisInitialized(self); } function _assertThisInitialized(self) { if (self === void 0) { throw new ReferenceError("this hasn't been initialised - super() hasn't been called"); } return self; } -function _inherits(subClass, superClass) { if (typeof superClass !== "function" && superClass !== null) { throw new TypeError("Super expression must either be null or a function"); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, writable: true, configurable: true } }); if (superClass) _setPrototypeOf(subClass, superClass); } +function _isNativeReflectConstruct() { if (typeof Reflect === "undefined" || !Reflect.construct) return false; if (Reflect.construct.sham) return false; if (typeof Proxy === "function") return true; try { Date.prototype.toString.call(Reflect.construct(Date, [], function () {})); return true; } catch (e) { return false; } } -function _setPrototypeOf(o, p) { _setPrototypeOf = Object.setPrototypeOf || function _setPrototypeOf(o, p) { o.__proto__ = p; return o; }; return _setPrototypeOf(o, p); } +function _getPrototypeOf(o) { _getPrototypeOf = Object.setPrototypeOf ? Object.getPrototypeOf : function _getPrototypeOf(o) { return o.__proto__ || Object.getPrototypeOf(o); }; return _getPrototypeOf(o); } const ConnectionError = require('./../connection-error'); /** @@ -18,17 +22,17 @@ const ConnectionError = require('./../connection-error'); */ -let InvalidConnectionError = -/*#__PURE__*/ -function (_ConnectionError) { +let InvalidConnectionError = /*#__PURE__*/function (_ConnectionError) { _inherits(InvalidConnectionError, _ConnectionError); + var _super = _createSuper(InvalidConnectionError); + function InvalidConnectionError(parent) { var _this; _classCallCheck(this, InvalidConnectionError); - _this = _possibleConstructorReturn(this, _getPrototypeOf(InvalidConnectionError).call(this, parent)); + _this = _super.call(this, parent); _this.name = 'SequelizeInvalidConnectionError'; Error.captureStackTrace(_assertThisInitialized(_this), _this.constructor); return _this; @@ -38,4 +42,4 @@ function (_ConnectionError) { }(ConnectionError); module.exports = InvalidConnectionError; -//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uLy4uL2xpYi9lcnJvcnMvY29ubmVjdGlvbi9pbnZhbGlkLWNvbm5lY3Rpb24tZXJyb3IuanMiXSwibmFtZXMiOlsiQ29ubmVjdGlvbkVycm9yIiwicmVxdWlyZSIsIkludmFsaWRDb25uZWN0aW9uRXJyb3IiLCJwYXJlbnQiLCJuYW1lIiwiRXJyb3IiLCJjYXB0dXJlU3RhY2tUcmFjZSIsImNvbnN0cnVjdG9yIiwibW9kdWxlIiwiZXhwb3J0cyJdLCJtYXBwaW5ncyI6IkFBQUE7Ozs7Ozs7Ozs7Ozs7O0FBRUEsTUFBTUEsZUFBZSxHQUFHQyxPQUFPLENBQUMsdUJBQUQsQ0FBL0I7QUFFQTs7Ozs7SUFHTUMsc0I7Ozs7O0FBQ0osa0NBQVlDLE1BQVosRUFBb0I7QUFBQTs7QUFBQTs7QUFDbEIsZ0dBQU1BLE1BQU47QUFDQSxVQUFLQyxJQUFMLEdBQVksaUNBQVo7QUFDQUMsSUFBQUEsS0FBSyxDQUFDQyxpQkFBTixnQ0FBOEIsTUFBS0MsV0FBbkM7QUFIa0I7QUFJbkI7OztFQUxrQ1AsZTs7QUFRckNRLE1BQU0sQ0FBQ0MsT0FBUCxHQUFpQlAsc0JBQWpCIiwic291cmNlc0NvbnRlbnQiOlsiJ3VzZSBzdHJpY3QnO1xyXG5cclxuY29uc3QgQ29ubmVjdGlvbkVycm9yID0gcmVxdWlyZSgnLi8uLi9jb25uZWN0aW9uLWVycm9yJyk7XHJcblxyXG4vKipcclxuICogVGhyb3duIHdoZW4gYSBjb25uZWN0aW9uIHRvIGEgZGF0YWJhc2UgaGFzIGludmFsaWQgdmFsdWVzIGZvciBhbnkgb2YgdGhlIGNvbm5lY3Rpb24gcGFyYW1ldGVyc1xyXG4gKi9cclxuY2xhc3MgSW52YWxpZENvbm5lY3Rpb25FcnJvciBleHRlbmRzIENvbm5lY3Rpb25FcnJvciB7XHJcbiAgY29uc3RydWN0b3IocGFyZW50KSB7XHJcbiAgICBzdXBlcihwYXJlbnQpO1xyXG4gICAgdGhpcy5uYW1lID0gJ1NlcXVlbGl6ZUludmFsaWRDb25uZWN0aW9uRXJyb3InO1xyXG4gICAgRXJyb3IuY2FwdHVyZVN0YWNrVHJhY2UodGhpcywgdGhpcy5jb25zdHJ1Y3Rvcik7XHJcbiAgfVxyXG59XHJcblxyXG5tb2R1bGUuZXhwb3J0cyA9IEludmFsaWRDb25uZWN0aW9uRXJyb3I7XHJcbiJdfQ== \ No newline at end of file +//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uLy4uL2xpYi9lcnJvcnMvY29ubmVjdGlvbi9pbnZhbGlkLWNvbm5lY3Rpb24tZXJyb3IuanMiXSwibmFtZXMiOlsiQ29ubmVjdGlvbkVycm9yIiwicmVxdWlyZSIsIkludmFsaWRDb25uZWN0aW9uRXJyb3IiLCJwYXJlbnQiLCJuYW1lIiwiRXJyb3IiLCJjYXB0dXJlU3RhY2tUcmFjZSIsImNvbnN0cnVjdG9yIiwibW9kdWxlIiwiZXhwb3J0cyJdLCJtYXBwaW5ncyI6IkFBQUE7Ozs7Ozs7Ozs7Ozs7Ozs7OztBQUVBLE1BQU1BLGVBQWUsR0FBR0MsT0FBTyxDQUFDLHVCQUFELENBQS9CO0FBRUE7QUFDQTtBQUNBOzs7SUFDTUMsc0I7Ozs7O0FBQ0osa0NBQVlDLE1BQVosRUFBb0I7QUFBQTs7QUFBQTs7QUFDbEIsOEJBQU1BLE1BQU47QUFDQSxVQUFLQyxJQUFMLEdBQVksaUNBQVo7QUFDQUMsSUFBQUEsS0FBSyxDQUFDQyxpQkFBTixnQ0FBOEIsTUFBS0MsV0FBbkM7QUFIa0I7QUFJbkI7OztFQUxrQ1AsZTs7QUFRckNRLE1BQU0sQ0FBQ0MsT0FBUCxHQUFpQlAsc0JBQWpCIiwic291cmNlc0NvbnRlbnQiOlsiJ3VzZSBzdHJpY3QnO1xuXG5jb25zdCBDb25uZWN0aW9uRXJyb3IgPSByZXF1aXJlKCcuLy4uL2Nvbm5lY3Rpb24tZXJyb3InKTtcblxuLyoqXG4gKiBUaHJvd24gd2hlbiBhIGNvbm5lY3Rpb24gdG8gYSBkYXRhYmFzZSBoYXMgaW52YWxpZCB2YWx1ZXMgZm9yIGFueSBvZiB0aGUgY29ubmVjdGlvbiBwYXJhbWV0ZXJzXG4gKi9cbmNsYXNzIEludmFsaWRDb25uZWN0aW9uRXJyb3IgZXh0ZW5kcyBDb25uZWN0aW9uRXJyb3Ige1xuICBjb25zdHJ1Y3RvcihwYXJlbnQpIHtcbiAgICBzdXBlcihwYXJlbnQpO1xuICAgIHRoaXMubmFtZSA9ICdTZXF1ZWxpemVJbnZhbGlkQ29ubmVjdGlvbkVycm9yJztcbiAgICBFcnJvci5jYXB0dXJlU3RhY2tUcmFjZSh0aGlzLCB0aGlzLmNvbnN0cnVjdG9yKTtcbiAgfVxufVxuXG5tb2R1bGUuZXhwb3J0cyA9IEludmFsaWRDb25uZWN0aW9uRXJyb3I7XG4iXX0= \ No newline at end of file diff --git a/dist/errors/database-error.js b/dist/errors/database-error.js index 04bb451..264c25e 100644 --- a/dist/errors/database-error.js +++ b/dist/errors/database-error.js @@ -2,15 +2,19 @@ function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } } -function _possibleConstructorReturn(self, call) { if (call && (typeof call === "object" || typeof call === "function")) { return call; } return _assertThisInitialized(self); } +function _inherits(subClass, superClass) { if (typeof superClass !== "function" && superClass !== null) { throw new TypeError("Super expression must either be null or a function"); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, writable: true, configurable: true } }); if (superClass) _setPrototypeOf(subClass, superClass); } -function _getPrototypeOf(o) { _getPrototypeOf = Object.setPrototypeOf ? Object.getPrototypeOf : function _getPrototypeOf(o) { return o.__proto__ || Object.getPrototypeOf(o); }; return _getPrototypeOf(o); } +function _setPrototypeOf(o, p) { _setPrototypeOf = Object.setPrototypeOf || function _setPrototypeOf(o, p) { o.__proto__ = p; return o; }; return _setPrototypeOf(o, p); } + +function _createSuper(Derived) { var hasNativeReflectConstruct = _isNativeReflectConstruct(); return function _createSuperInternal() { var Super = _getPrototypeOf(Derived), result; if (hasNativeReflectConstruct) { var NewTarget = _getPrototypeOf(this).constructor; result = Reflect.construct(Super, arguments, NewTarget); } else { result = Super.apply(this, arguments); } return _possibleConstructorReturn(this, result); }; } + +function _possibleConstructorReturn(self, call) { if (call && (typeof call === "object" || typeof call === "function")) { return call; } return _assertThisInitialized(self); } function _assertThisInitialized(self) { if (self === void 0) { throw new ReferenceError("this hasn't been initialised - super() hasn't been called"); } return self; } -function _inherits(subClass, superClass) { if (typeof superClass !== "function" && superClass !== null) { throw new TypeError("Super expression must either be null or a function"); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, writable: true, configurable: true } }); if (superClass) _setPrototypeOf(subClass, superClass); } +function _isNativeReflectConstruct() { if (typeof Reflect === "undefined" || !Reflect.construct) return false; if (Reflect.construct.sham) return false; if (typeof Proxy === "function") return true; try { Date.prototype.toString.call(Reflect.construct(Date, [], function () {})); return true; } catch (e) { return false; } } -function _setPrototypeOf(o, p) { _setPrototypeOf = Object.setPrototypeOf || function _setPrototypeOf(o, p) { o.__proto__ = p; return o; }; return _setPrototypeOf(o, p); } +function _getPrototypeOf(o) { _getPrototypeOf = Object.setPrototypeOf ? Object.getPrototypeOf : function _getPrototypeOf(o) { return o.__proto__ || Object.getPrototypeOf(o); }; return _getPrototypeOf(o); } const BaseError = require('./base-error'); /** @@ -18,17 +22,17 @@ const BaseError = require('./base-error'); */ -let DatabaseError = -/*#__PURE__*/ -function (_BaseError) { +let DatabaseError = /*#__PURE__*/function (_BaseError) { _inherits(DatabaseError, _BaseError); + var _super = _createSuper(DatabaseError); + function DatabaseError(parent) { var _this; _classCallCheck(this, DatabaseError); - _this = _possibleConstructorReturn(this, _getPrototypeOf(DatabaseError).call(this, parent.message)); + _this = _super.call(this, parent.message); _this.name = 'SequelizeDatabaseError'; /** * @type {Error} @@ -60,4 +64,4 @@ function (_BaseError) { }(BaseError); module.exports = DatabaseError; -//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uL2xpYi9lcnJvcnMvZGF0YWJhc2UtZXJyb3IuanMiXSwibmFtZXMiOlsiQmFzZUVycm9yIiwicmVxdWlyZSIsIkRhdGFiYXNlRXJyb3IiLCJwYXJlbnQiLCJtZXNzYWdlIiwibmFtZSIsIm9yaWdpbmFsIiwic3FsIiwicGFyYW1ldGVycyIsIkVycm9yIiwiY2FwdHVyZVN0YWNrVHJhY2UiLCJjb25zdHJ1Y3RvciIsIm1vZHVsZSIsImV4cG9ydHMiXSwibWFwcGluZ3MiOiJBQUFBOzs7Ozs7Ozs7Ozs7OztBQUVBLE1BQU1BLFNBQVMsR0FBR0MsT0FBTyxDQUFDLGNBQUQsQ0FBekI7QUFFQTs7Ozs7SUFHTUMsYTs7Ozs7QUFDSix5QkFBWUMsTUFBWixFQUFvQjtBQUFBOztBQUFBOztBQUNsQix1RkFBTUEsTUFBTSxDQUFDQyxPQUFiO0FBQ0EsVUFBS0MsSUFBTCxHQUFZLHdCQUFaO0FBQ0E7Ozs7QUFHQSxVQUFLRixNQUFMLEdBQWNBLE1BQWQ7QUFDQTs7OztBQUdBLFVBQUtHLFFBQUwsR0FBZ0JILE1BQWhCO0FBQ0E7Ozs7O0FBSUEsVUFBS0ksR0FBTCxHQUFXSixNQUFNLENBQUNJLEdBQWxCO0FBQ0E7Ozs7O0FBSUEsVUFBS0MsVUFBTCxHQUFrQkwsTUFBTSxDQUFDSyxVQUF6QjtBQUNBQyxJQUFBQSxLQUFLLENBQUNDLGlCQUFOLGdDQUE4QixNQUFLQyxXQUFuQztBQXJCa0I7QUFzQm5COzs7RUF2QnlCWCxTOztBQTBCNUJZLE1BQU0sQ0FBQ0MsT0FBUCxHQUFpQlgsYUFBakIiLCJzb3VyY2VzQ29udGVudCI6WyIndXNlIHN0cmljdCc7XHJcblxyXG5jb25zdCBCYXNlRXJyb3IgPSByZXF1aXJlKCcuL2Jhc2UtZXJyb3InKTtcclxuXHJcbi8qKlxyXG4gKiBBIGJhc2UgY2xhc3MgZm9yIGFsbCBkYXRhYmFzZSByZWxhdGVkIGVycm9ycy5cclxuICovXHJcbmNsYXNzIERhdGFiYXNlRXJyb3IgZXh0ZW5kcyBCYXNlRXJyb3Ige1xyXG4gIGNvbnN0cnVjdG9yKHBhcmVudCkge1xyXG4gICAgc3VwZXIocGFyZW50Lm1lc3NhZ2UpO1xyXG4gICAgdGhpcy5uYW1lID0gJ1NlcXVlbGl6ZURhdGFiYXNlRXJyb3InO1xyXG4gICAgLyoqXHJcbiAgICAgKiBAdHlwZSB7RXJyb3J9XHJcbiAgICAgKi9cclxuICAgIHRoaXMucGFyZW50ID0gcGFyZW50O1xyXG4gICAgLyoqXHJcbiAgICAgKiBAdHlwZSB7RXJyb3J9XHJcbiAgICAgKi9cclxuICAgIHRoaXMub3JpZ2luYWwgPSBwYXJlbnQ7XHJcbiAgICAvKipcclxuICAgICAqIFRoZSBTUUwgdGhhdCB0cmlnZ2VyZWQgdGhlIGVycm9yXHJcbiAgICAgKiBAdHlwZSB7c3RyaW5nfVxyXG4gICAgICovXHJcbiAgICB0aGlzLnNxbCA9IHBhcmVudC5zcWw7XHJcbiAgICAvKipcclxuICAgICAqIFRoZSBwYXJhbWV0ZXJzIGZvciB0aGUgc3FsIHRoYXQgdHJpZ2dlcmVkIHRoZSBlcnJvclxyXG4gICAgICogQHR5cGUge0FycmF5PGFueT59XHJcbiAgICAgKi9cclxuICAgIHRoaXMucGFyYW1ldGVycyA9IHBhcmVudC5wYXJhbWV0ZXJzO1xyXG4gICAgRXJyb3IuY2FwdHVyZVN0YWNrVHJhY2UodGhpcywgdGhpcy5jb25zdHJ1Y3Rvcik7XHJcbiAgfVxyXG59XHJcblxyXG5tb2R1bGUuZXhwb3J0cyA9IERhdGFiYXNlRXJyb3I7XHJcbiJdfQ== \ No newline at end of file +//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uL2xpYi9lcnJvcnMvZGF0YWJhc2UtZXJyb3IuanMiXSwibmFtZXMiOlsiQmFzZUVycm9yIiwicmVxdWlyZSIsIkRhdGFiYXNlRXJyb3IiLCJwYXJlbnQiLCJtZXNzYWdlIiwibmFtZSIsIm9yaWdpbmFsIiwic3FsIiwicGFyYW1ldGVycyIsIkVycm9yIiwiY2FwdHVyZVN0YWNrVHJhY2UiLCJjb25zdHJ1Y3RvciIsIm1vZHVsZSIsImV4cG9ydHMiXSwibWFwcGluZ3MiOiJBQUFBOzs7Ozs7Ozs7Ozs7Ozs7Ozs7QUFFQSxNQUFNQSxTQUFTLEdBQUdDLE9BQU8sQ0FBQyxjQUFELENBQXpCO0FBRUE7QUFDQTtBQUNBOzs7SUFDTUMsYTs7Ozs7QUFDSix5QkFBWUMsTUFBWixFQUFvQjtBQUFBOztBQUFBOztBQUNsQiw4QkFBTUEsTUFBTSxDQUFDQyxPQUFiO0FBQ0EsVUFBS0MsSUFBTCxHQUFZLHdCQUFaO0FBQ0E7QUFDSjtBQUNBOztBQUNJLFVBQUtGLE1BQUwsR0FBY0EsTUFBZDtBQUNBO0FBQ0o7QUFDQTs7QUFDSSxVQUFLRyxRQUFMLEdBQWdCSCxNQUFoQjtBQUNBO0FBQ0o7QUFDQTtBQUNBOztBQUNJLFVBQUtJLEdBQUwsR0FBV0osTUFBTSxDQUFDSSxHQUFsQjtBQUNBO0FBQ0o7QUFDQTtBQUNBOztBQUNJLFVBQUtDLFVBQUwsR0FBa0JMLE1BQU0sQ0FBQ0ssVUFBekI7QUFDQUMsSUFBQUEsS0FBSyxDQUFDQyxpQkFBTixnQ0FBOEIsTUFBS0MsV0FBbkM7QUFyQmtCO0FBc0JuQjs7O0VBdkJ5QlgsUzs7QUEwQjVCWSxNQUFNLENBQUNDLE9BQVAsR0FBaUJYLGFBQWpCIiwic291cmNlc0NvbnRlbnQiOlsiJ3VzZSBzdHJpY3QnO1xuXG5jb25zdCBCYXNlRXJyb3IgPSByZXF1aXJlKCcuL2Jhc2UtZXJyb3InKTtcblxuLyoqXG4gKiBBIGJhc2UgY2xhc3MgZm9yIGFsbCBkYXRhYmFzZSByZWxhdGVkIGVycm9ycy5cbiAqL1xuY2xhc3MgRGF0YWJhc2VFcnJvciBleHRlbmRzIEJhc2VFcnJvciB7XG4gIGNvbnN0cnVjdG9yKHBhcmVudCkge1xuICAgIHN1cGVyKHBhcmVudC5tZXNzYWdlKTtcbiAgICB0aGlzLm5hbWUgPSAnU2VxdWVsaXplRGF0YWJhc2VFcnJvcic7XG4gICAgLyoqXG4gICAgICogQHR5cGUge0Vycm9yfVxuICAgICAqL1xuICAgIHRoaXMucGFyZW50ID0gcGFyZW50O1xuICAgIC8qKlxuICAgICAqIEB0eXBlIHtFcnJvcn1cbiAgICAgKi9cbiAgICB0aGlzLm9yaWdpbmFsID0gcGFyZW50O1xuICAgIC8qKlxuICAgICAqIFRoZSBTUUwgdGhhdCB0cmlnZ2VyZWQgdGhlIGVycm9yXG4gICAgICogQHR5cGUge3N0cmluZ31cbiAgICAgKi9cbiAgICB0aGlzLnNxbCA9IHBhcmVudC5zcWw7XG4gICAgLyoqXG4gICAgICogVGhlIHBhcmFtZXRlcnMgZm9yIHRoZSBzcWwgdGhhdCB0cmlnZ2VyZWQgdGhlIGVycm9yXG4gICAgICogQHR5cGUge0FycmF5PGFueT59XG4gICAgICovXG4gICAgdGhpcy5wYXJhbWV0ZXJzID0gcGFyZW50LnBhcmFtZXRlcnM7XG4gICAgRXJyb3IuY2FwdHVyZVN0YWNrVHJhY2UodGhpcywgdGhpcy5jb25zdHJ1Y3Rvcik7XG4gIH1cbn1cblxubW9kdWxlLmV4cG9ydHMgPSBEYXRhYmFzZUVycm9yO1xuIl19 \ No newline at end of file diff --git a/dist/errors/database/exclusion-constraint-error.js b/dist/errors/database/exclusion-constraint-error.js index 96734f3..8f065cd 100644 --- a/dist/errors/database/exclusion-constraint-error.js +++ b/dist/errors/database/exclusion-constraint-error.js @@ -2,15 +2,19 @@ function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } } -function _possibleConstructorReturn(self, call) { if (call && (typeof call === "object" || typeof call === "function")) { return call; } return _assertThisInitialized(self); } +function _inherits(subClass, superClass) { if (typeof superClass !== "function" && superClass !== null) { throw new TypeError("Super expression must either be null or a function"); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, writable: true, configurable: true } }); if (superClass) _setPrototypeOf(subClass, superClass); } -function _getPrototypeOf(o) { _getPrototypeOf = Object.setPrototypeOf ? Object.getPrototypeOf : function _getPrototypeOf(o) { return o.__proto__ || Object.getPrototypeOf(o); }; return _getPrototypeOf(o); } +function _setPrototypeOf(o, p) { _setPrototypeOf = Object.setPrototypeOf || function _setPrototypeOf(o, p) { o.__proto__ = p; return o; }; return _setPrototypeOf(o, p); } + +function _createSuper(Derived) { var hasNativeReflectConstruct = _isNativeReflectConstruct(); return function _createSuperInternal() { var Super = _getPrototypeOf(Derived), result; if (hasNativeReflectConstruct) { var NewTarget = _getPrototypeOf(this).constructor; result = Reflect.construct(Super, arguments, NewTarget); } else { result = Super.apply(this, arguments); } return _possibleConstructorReturn(this, result); }; } + +function _possibleConstructorReturn(self, call) { if (call && (typeof call === "object" || typeof call === "function")) { return call; } return _assertThisInitialized(self); } function _assertThisInitialized(self) { if (self === void 0) { throw new ReferenceError("this hasn't been initialised - super() hasn't been called"); } return self; } -function _inherits(subClass, superClass) { if (typeof superClass !== "function" && superClass !== null) { throw new TypeError("Super expression must either be null or a function"); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, writable: true, configurable: true } }); if (superClass) _setPrototypeOf(subClass, superClass); } +function _isNativeReflectConstruct() { if (typeof Reflect === "undefined" || !Reflect.construct) return false; if (Reflect.construct.sham) return false; if (typeof Proxy === "function") return true; try { Date.prototype.toString.call(Reflect.construct(Date, [], function () {})); return true; } catch (e) { return false; } } -function _setPrototypeOf(o, p) { _setPrototypeOf = Object.setPrototypeOf || function _setPrototypeOf(o, p) { o.__proto__ = p; return o; }; return _setPrototypeOf(o, p); } +function _getPrototypeOf(o) { _getPrototypeOf = Object.setPrototypeOf ? Object.getPrototypeOf : function _getPrototypeOf(o) { return o.__proto__ || Object.getPrototypeOf(o); }; return _getPrototypeOf(o); } const DatabaseError = require('./../database-error'); /** @@ -18,11 +22,11 @@ const DatabaseError = require('./../database-error'); */ -let ExclusionConstraintError = -/*#__PURE__*/ -function (_DatabaseError) { +let ExclusionConstraintError = /*#__PURE__*/function (_DatabaseError) { _inherits(ExclusionConstraintError, _DatabaseError); + var _super = _createSuper(ExclusionConstraintError); + function ExclusionConstraintError(options) { var _this; @@ -32,7 +36,7 @@ function (_DatabaseError) { options.parent = options.parent || { sql: '' }; - _this = _possibleConstructorReturn(this, _getPrototypeOf(ExclusionConstraintError).call(this, options.parent)); + _this = _super.call(this, options.parent); _this.name = 'SequelizeExclusionConstraintError'; _this.message = options.message || options.parent.message || ''; _this.constraint = options.constraint; @@ -46,4 +50,4 @@ function (_DatabaseError) { }(DatabaseError); module.exports = ExclusionConstraintError; -//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uLy4uL2xpYi9lcnJvcnMvZGF0YWJhc2UvZXhjbHVzaW9uLWNvbnN0cmFpbnQtZXJyb3IuanMiXSwibmFtZXMiOlsiRGF0YWJhc2VFcnJvciIsInJlcXVpcmUiLCJFeGNsdXNpb25Db25zdHJhaW50RXJyb3IiLCJvcHRpb25zIiwicGFyZW50Iiwic3FsIiwibmFtZSIsIm1lc3NhZ2UiLCJjb25zdHJhaW50IiwiZmllbGRzIiwidGFibGUiLCJFcnJvciIsImNhcHR1cmVTdGFja1RyYWNlIiwiY29uc3RydWN0b3IiLCJtb2R1bGUiLCJleHBvcnRzIl0sIm1hcHBpbmdzIjoiQUFBQTs7Ozs7Ozs7Ozs7Ozs7QUFFQSxNQUFNQSxhQUFhLEdBQUdDLE9BQU8sQ0FBQyxxQkFBRCxDQUE3QjtBQUVBOzs7OztJQUdNQyx3Qjs7Ozs7QUFDSixvQ0FBWUMsT0FBWixFQUFxQjtBQUFBOztBQUFBOztBQUNuQkEsSUFBQUEsT0FBTyxHQUFHQSxPQUFPLElBQUksRUFBckI7QUFDQUEsSUFBQUEsT0FBTyxDQUFDQyxNQUFSLEdBQWlCRCxPQUFPLENBQUNDLE1BQVIsSUFBa0I7QUFBRUMsTUFBQUEsR0FBRyxFQUFFO0FBQVAsS0FBbkM7QUFFQSxrR0FBTUYsT0FBTyxDQUFDQyxNQUFkO0FBQ0EsVUFBS0UsSUFBTCxHQUFZLG1DQUFaO0FBRUEsVUFBS0MsT0FBTCxHQUFlSixPQUFPLENBQUNJLE9BQVIsSUFBbUJKLE9BQU8sQ0FBQ0MsTUFBUixDQUFlRyxPQUFsQyxJQUE2QyxFQUE1RDtBQUNBLFVBQUtDLFVBQUwsR0FBa0JMLE9BQU8sQ0FBQ0ssVUFBMUI7QUFDQSxVQUFLQyxNQUFMLEdBQWNOLE9BQU8sQ0FBQ00sTUFBdEI7QUFDQSxVQUFLQyxLQUFMLEdBQWFQLE9BQU8sQ0FBQ08sS0FBckI7QUFDQUMsSUFBQUEsS0FBSyxDQUFDQyxpQkFBTixnQ0FBOEIsTUFBS0MsV0FBbkM7QUFYbUI7QUFZcEI7OztFQWJvQ2IsYTs7QUFnQnZDYyxNQUFNLENBQUNDLE9BQVAsR0FBaUJiLHdCQUFqQiIsInNvdXJjZXNDb250ZW50IjpbIid1c2Ugc3RyaWN0JztcclxuXHJcbmNvbnN0IERhdGFiYXNlRXJyb3IgPSByZXF1aXJlKCcuLy4uL2RhdGFiYXNlLWVycm9yJyk7XHJcblxyXG4vKipcclxuICogVGhyb3duIHdoZW4gYW4gZXhjbHVzaW9uIGNvbnN0cmFpbnQgaXMgdmlvbGF0ZWQgaW4gdGhlIGRhdGFiYXNlXHJcbiAqL1xyXG5jbGFzcyBFeGNsdXNpb25Db25zdHJhaW50RXJyb3IgZXh0ZW5kcyBEYXRhYmFzZUVycm9yIHtcclxuICBjb25zdHJ1Y3RvcihvcHRpb25zKSB7XHJcbiAgICBvcHRpb25zID0gb3B0aW9ucyB8fCB7fTtcclxuICAgIG9wdGlvbnMucGFyZW50ID0gb3B0aW9ucy5wYXJlbnQgfHwgeyBzcWw6ICcnIH07XHJcblxyXG4gICAgc3VwZXIob3B0aW9ucy5wYXJlbnQpO1xyXG4gICAgdGhpcy5uYW1lID0gJ1NlcXVlbGl6ZUV4Y2x1c2lvbkNvbnN0cmFpbnRFcnJvcic7XHJcblxyXG4gICAgdGhpcy5tZXNzYWdlID0gb3B0aW9ucy5tZXNzYWdlIHx8IG9wdGlvbnMucGFyZW50Lm1lc3NhZ2UgfHwgJyc7XHJcbiAgICB0aGlzLmNvbnN0cmFpbnQgPSBvcHRpb25zLmNvbnN0cmFpbnQ7XHJcbiAgICB0aGlzLmZpZWxkcyA9IG9wdGlvbnMuZmllbGRzO1xyXG4gICAgdGhpcy50YWJsZSA9IG9wdGlvbnMudGFibGU7XHJcbiAgICBFcnJvci5jYXB0dXJlU3RhY2tUcmFjZSh0aGlzLCB0aGlzLmNvbnN0cnVjdG9yKTtcclxuICB9XHJcbn1cclxuXHJcbm1vZHVsZS5leHBvcnRzID0gRXhjbHVzaW9uQ29uc3RyYWludEVycm9yO1xyXG4iXX0= \ No newline at end of file +//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uLy4uL2xpYi9lcnJvcnMvZGF0YWJhc2UvZXhjbHVzaW9uLWNvbnN0cmFpbnQtZXJyb3IuanMiXSwibmFtZXMiOlsiRGF0YWJhc2VFcnJvciIsInJlcXVpcmUiLCJFeGNsdXNpb25Db25zdHJhaW50RXJyb3IiLCJvcHRpb25zIiwicGFyZW50Iiwic3FsIiwibmFtZSIsIm1lc3NhZ2UiLCJjb25zdHJhaW50IiwiZmllbGRzIiwidGFibGUiLCJFcnJvciIsImNhcHR1cmVTdGFja1RyYWNlIiwiY29uc3RydWN0b3IiLCJtb2R1bGUiLCJleHBvcnRzIl0sIm1hcHBpbmdzIjoiQUFBQTs7Ozs7Ozs7Ozs7Ozs7Ozs7O0FBRUEsTUFBTUEsYUFBYSxHQUFHQyxPQUFPLENBQUMscUJBQUQsQ0FBN0I7QUFFQTtBQUNBO0FBQ0E7OztJQUNNQyx3Qjs7Ozs7QUFDSixvQ0FBWUMsT0FBWixFQUFxQjtBQUFBOztBQUFBOztBQUNuQkEsSUFBQUEsT0FBTyxHQUFHQSxPQUFPLElBQUksRUFBckI7QUFDQUEsSUFBQUEsT0FBTyxDQUFDQyxNQUFSLEdBQWlCRCxPQUFPLENBQUNDLE1BQVIsSUFBa0I7QUFBRUMsTUFBQUEsR0FBRyxFQUFFO0FBQVAsS0FBbkM7QUFFQSw4QkFBTUYsT0FBTyxDQUFDQyxNQUFkO0FBQ0EsVUFBS0UsSUFBTCxHQUFZLG1DQUFaO0FBRUEsVUFBS0MsT0FBTCxHQUFlSixPQUFPLENBQUNJLE9BQVIsSUFBbUJKLE9BQU8sQ0FBQ0MsTUFBUixDQUFlRyxPQUFsQyxJQUE2QyxFQUE1RDtBQUNBLFVBQUtDLFVBQUwsR0FBa0JMLE9BQU8sQ0FBQ0ssVUFBMUI7QUFDQSxVQUFLQyxNQUFMLEdBQWNOLE9BQU8sQ0FBQ00sTUFBdEI7QUFDQSxVQUFLQyxLQUFMLEdBQWFQLE9BQU8sQ0FBQ08sS0FBckI7QUFDQUMsSUFBQUEsS0FBSyxDQUFDQyxpQkFBTixnQ0FBOEIsTUFBS0MsV0FBbkM7QUFYbUI7QUFZcEI7OztFQWJvQ2IsYTs7QUFnQnZDYyxNQUFNLENBQUNDLE9BQVAsR0FBaUJiLHdCQUFqQiIsInNvdXJjZXNDb250ZW50IjpbIid1c2Ugc3RyaWN0JztcblxuY29uc3QgRGF0YWJhc2VFcnJvciA9IHJlcXVpcmUoJy4vLi4vZGF0YWJhc2UtZXJyb3InKTtcblxuLyoqXG4gKiBUaHJvd24gd2hlbiBhbiBleGNsdXNpb24gY29uc3RyYWludCBpcyB2aW9sYXRlZCBpbiB0aGUgZGF0YWJhc2VcbiAqL1xuY2xhc3MgRXhjbHVzaW9uQ29uc3RyYWludEVycm9yIGV4dGVuZHMgRGF0YWJhc2VFcnJvciB7XG4gIGNvbnN0cnVjdG9yKG9wdGlvbnMpIHtcbiAgICBvcHRpb25zID0gb3B0aW9ucyB8fCB7fTtcbiAgICBvcHRpb25zLnBhcmVudCA9IG9wdGlvbnMucGFyZW50IHx8IHsgc3FsOiAnJyB9O1xuXG4gICAgc3VwZXIob3B0aW9ucy5wYXJlbnQpO1xuICAgIHRoaXMubmFtZSA9ICdTZXF1ZWxpemVFeGNsdXNpb25Db25zdHJhaW50RXJyb3InO1xuXG4gICAgdGhpcy5tZXNzYWdlID0gb3B0aW9ucy5tZXNzYWdlIHx8IG9wdGlvbnMucGFyZW50Lm1lc3NhZ2UgfHwgJyc7XG4gICAgdGhpcy5jb25zdHJhaW50ID0gb3B0aW9ucy5jb25zdHJhaW50O1xuICAgIHRoaXMuZmllbGRzID0gb3B0aW9ucy5maWVsZHM7XG4gICAgdGhpcy50YWJsZSA9IG9wdGlvbnMudGFibGU7XG4gICAgRXJyb3IuY2FwdHVyZVN0YWNrVHJhY2UodGhpcywgdGhpcy5jb25zdHJ1Y3Rvcik7XG4gIH1cbn1cblxubW9kdWxlLmV4cG9ydHMgPSBFeGNsdXNpb25Db25zdHJhaW50RXJyb3I7XG4iXX0= \ No newline at end of file diff --git a/dist/errors/database/foreign-key-constraint-error.js b/dist/errors/database/foreign-key-constraint-error.js index 066b972..59bddc7 100644 --- a/dist/errors/database/foreign-key-constraint-error.js +++ b/dist/errors/database/foreign-key-constraint-error.js @@ -2,15 +2,19 @@ function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } } -function _possibleConstructorReturn(self, call) { if (call && (typeof call === "object" || typeof call === "function")) { return call; } return _assertThisInitialized(self); } +function _inherits(subClass, superClass) { if (typeof superClass !== "function" && superClass !== null) { throw new TypeError("Super expression must either be null or a function"); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, writable: true, configurable: true } }); if (superClass) _setPrototypeOf(subClass, superClass); } -function _getPrototypeOf(o) { _getPrototypeOf = Object.setPrototypeOf ? Object.getPrototypeOf : function _getPrototypeOf(o) { return o.__proto__ || Object.getPrototypeOf(o); }; return _getPrototypeOf(o); } +function _setPrototypeOf(o, p) { _setPrototypeOf = Object.setPrototypeOf || function _setPrototypeOf(o, p) { o.__proto__ = p; return o; }; return _setPrototypeOf(o, p); } + +function _createSuper(Derived) { var hasNativeReflectConstruct = _isNativeReflectConstruct(); return function _createSuperInternal() { var Super = _getPrototypeOf(Derived), result; if (hasNativeReflectConstruct) { var NewTarget = _getPrototypeOf(this).constructor; result = Reflect.construct(Super, arguments, NewTarget); } else { result = Super.apply(this, arguments); } return _possibleConstructorReturn(this, result); }; } + +function _possibleConstructorReturn(self, call) { if (call && (typeof call === "object" || typeof call === "function")) { return call; } return _assertThisInitialized(self); } function _assertThisInitialized(self) { if (self === void 0) { throw new ReferenceError("this hasn't been initialised - super() hasn't been called"); } return self; } -function _inherits(subClass, superClass) { if (typeof superClass !== "function" && superClass !== null) { throw new TypeError("Super expression must either be null or a function"); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, writable: true, configurable: true } }); if (superClass) _setPrototypeOf(subClass, superClass); } +function _isNativeReflectConstruct() { if (typeof Reflect === "undefined" || !Reflect.construct) return false; if (Reflect.construct.sham) return false; if (typeof Proxy === "function") return true; try { Date.prototype.toString.call(Reflect.construct(Date, [], function () {})); return true; } catch (e) { return false; } } -function _setPrototypeOf(o, p) { _setPrototypeOf = Object.setPrototypeOf || function _setPrototypeOf(o, p) { o.__proto__ = p; return o; }; return _setPrototypeOf(o, p); } +function _getPrototypeOf(o) { _getPrototypeOf = Object.setPrototypeOf ? Object.getPrototypeOf : function _getPrototypeOf(o) { return o.__proto__ || Object.getPrototypeOf(o); }; return _getPrototypeOf(o); } const DatabaseError = require('./../database-error'); /** @@ -18,11 +22,11 @@ const DatabaseError = require('./../database-error'); */ -let ForeignKeyConstraintError = -/*#__PURE__*/ -function (_DatabaseError) { +let ForeignKeyConstraintError = /*#__PURE__*/function (_DatabaseError) { _inherits(ForeignKeyConstraintError, _DatabaseError); + var _super = _createSuper(ForeignKeyConstraintError); + function ForeignKeyConstraintError(options) { var _this; @@ -32,7 +36,7 @@ function (_DatabaseError) { options.parent = options.parent || { sql: '' }; - _this = _possibleConstructorReturn(this, _getPrototypeOf(ForeignKeyConstraintError).call(this, options.parent)); + _this = _super.call(this, options.parent); _this.name = 'SequelizeForeignKeyConstraintError'; _this.message = options.message || options.parent.message || 'Database Error'; _this.fields = options.fields; @@ -48,4 +52,4 @@ function (_DatabaseError) { }(DatabaseError); module.exports = ForeignKeyConstraintError; -//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uLy4uL2xpYi9lcnJvcnMvZGF0YWJhc2UvZm9yZWlnbi1rZXktY29uc3RyYWludC1lcnJvci5qcyJdLCJuYW1lcyI6WyJEYXRhYmFzZUVycm9yIiwicmVxdWlyZSIsIkZvcmVpZ25LZXlDb25zdHJhaW50RXJyb3IiLCJvcHRpb25zIiwicGFyZW50Iiwic3FsIiwibmFtZSIsIm1lc3NhZ2UiLCJmaWVsZHMiLCJ0YWJsZSIsInZhbHVlIiwiaW5kZXgiLCJyZWx0eXBlIiwiRXJyb3IiLCJjYXB0dXJlU3RhY2tUcmFjZSIsImNvbnN0cnVjdG9yIiwibW9kdWxlIiwiZXhwb3J0cyJdLCJtYXBwaW5ncyI6IkFBQUE7Ozs7Ozs7Ozs7Ozs7O0FBRUEsTUFBTUEsYUFBYSxHQUFHQyxPQUFPLENBQUMscUJBQUQsQ0FBN0I7QUFFQTs7Ozs7SUFHTUMseUI7Ozs7O0FBQ0oscUNBQVlDLE9BQVosRUFBcUI7QUFBQTs7QUFBQTs7QUFDbkJBLElBQUFBLE9BQU8sR0FBR0EsT0FBTyxJQUFJLEVBQXJCO0FBQ0FBLElBQUFBLE9BQU8sQ0FBQ0MsTUFBUixHQUFpQkQsT0FBTyxDQUFDQyxNQUFSLElBQWtCO0FBQUVDLE1BQUFBLEdBQUcsRUFBRTtBQUFQLEtBQW5DO0FBRUEsbUdBQU1GLE9BQU8sQ0FBQ0MsTUFBZDtBQUNBLFVBQUtFLElBQUwsR0FBWSxvQ0FBWjtBQUVBLFVBQUtDLE9BQUwsR0FBZUosT0FBTyxDQUFDSSxPQUFSLElBQW1CSixPQUFPLENBQUNDLE1BQVIsQ0FBZUcsT0FBbEMsSUFBNkMsZ0JBQTVEO0FBQ0EsVUFBS0MsTUFBTCxHQUFjTCxPQUFPLENBQUNLLE1BQXRCO0FBQ0EsVUFBS0MsS0FBTCxHQUFhTixPQUFPLENBQUNNLEtBQXJCO0FBQ0EsVUFBS0MsS0FBTCxHQUFhUCxPQUFPLENBQUNPLEtBQXJCO0FBQ0EsVUFBS0MsS0FBTCxHQUFhUixPQUFPLENBQUNRLEtBQXJCO0FBQ0EsVUFBS0MsT0FBTCxHQUFlVCxPQUFPLENBQUNTLE9BQXZCO0FBQ0FDLElBQUFBLEtBQUssQ0FBQ0MsaUJBQU4sZ0NBQThCLE1BQUtDLFdBQW5DO0FBYm1CO0FBY3BCOzs7RUFmcUNmLGE7O0FBa0J4Q2dCLE1BQU0sQ0FBQ0MsT0FBUCxHQUFpQmYseUJBQWpCIiwic291cmNlc0NvbnRlbnQiOlsiJ3VzZSBzdHJpY3QnO1xyXG5cclxuY29uc3QgRGF0YWJhc2VFcnJvciA9IHJlcXVpcmUoJy4vLi4vZGF0YWJhc2UtZXJyb3InKTtcclxuXHJcbi8qKlxyXG4gKiBUaHJvd24gd2hlbiBhIGZvcmVpZ24ga2V5IGNvbnN0cmFpbnQgaXMgdmlvbGF0ZWQgaW4gdGhlIGRhdGFiYXNlXHJcbiAqL1xyXG5jbGFzcyBGb3JlaWduS2V5Q29uc3RyYWludEVycm9yIGV4dGVuZHMgRGF0YWJhc2VFcnJvciB7XHJcbiAgY29uc3RydWN0b3Iob3B0aW9ucykge1xyXG4gICAgb3B0aW9ucyA9IG9wdGlvbnMgfHwge307XHJcbiAgICBvcHRpb25zLnBhcmVudCA9IG9wdGlvbnMucGFyZW50IHx8IHsgc3FsOiAnJyB9O1xyXG5cclxuICAgIHN1cGVyKG9wdGlvbnMucGFyZW50KTtcclxuICAgIHRoaXMubmFtZSA9ICdTZXF1ZWxpemVGb3JlaWduS2V5Q29uc3RyYWludEVycm9yJztcclxuXHJcbiAgICB0aGlzLm1lc3NhZ2UgPSBvcHRpb25zLm1lc3NhZ2UgfHwgb3B0aW9ucy5wYXJlbnQubWVzc2FnZSB8fCAnRGF0YWJhc2UgRXJyb3InO1xyXG4gICAgdGhpcy5maWVsZHMgPSBvcHRpb25zLmZpZWxkcztcclxuICAgIHRoaXMudGFibGUgPSBvcHRpb25zLnRhYmxlO1xyXG4gICAgdGhpcy52YWx1ZSA9IG9wdGlvbnMudmFsdWU7XHJcbiAgICB0aGlzLmluZGV4ID0gb3B0aW9ucy5pbmRleDtcclxuICAgIHRoaXMucmVsdHlwZSA9IG9wdGlvbnMucmVsdHlwZTtcclxuICAgIEVycm9yLmNhcHR1cmVTdGFja1RyYWNlKHRoaXMsIHRoaXMuY29uc3RydWN0b3IpO1xyXG4gIH1cclxufVxyXG5cclxubW9kdWxlLmV4cG9ydHMgPSBGb3JlaWduS2V5Q29uc3RyYWludEVycm9yO1xyXG4iXX0= \ No newline at end of file +//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uLy4uL2xpYi9lcnJvcnMvZGF0YWJhc2UvZm9yZWlnbi1rZXktY29uc3RyYWludC1lcnJvci5qcyJdLCJuYW1lcyI6WyJEYXRhYmFzZUVycm9yIiwicmVxdWlyZSIsIkZvcmVpZ25LZXlDb25zdHJhaW50RXJyb3IiLCJvcHRpb25zIiwicGFyZW50Iiwic3FsIiwibmFtZSIsIm1lc3NhZ2UiLCJmaWVsZHMiLCJ0YWJsZSIsInZhbHVlIiwiaW5kZXgiLCJyZWx0eXBlIiwiRXJyb3IiLCJjYXB0dXJlU3RhY2tUcmFjZSIsImNvbnN0cnVjdG9yIiwibW9kdWxlIiwiZXhwb3J0cyJdLCJtYXBwaW5ncyI6IkFBQUE7Ozs7Ozs7Ozs7Ozs7Ozs7OztBQUVBLE1BQU1BLGFBQWEsR0FBR0MsT0FBTyxDQUFDLHFCQUFELENBQTdCO0FBRUE7QUFDQTtBQUNBOzs7SUFDTUMseUI7Ozs7O0FBQ0oscUNBQVlDLE9BQVosRUFBcUI7QUFBQTs7QUFBQTs7QUFDbkJBLElBQUFBLE9BQU8sR0FBR0EsT0FBTyxJQUFJLEVBQXJCO0FBQ0FBLElBQUFBLE9BQU8sQ0FBQ0MsTUFBUixHQUFpQkQsT0FBTyxDQUFDQyxNQUFSLElBQWtCO0FBQUVDLE1BQUFBLEdBQUcsRUFBRTtBQUFQLEtBQW5DO0FBRUEsOEJBQU1GLE9BQU8sQ0FBQ0MsTUFBZDtBQUNBLFVBQUtFLElBQUwsR0FBWSxvQ0FBWjtBQUVBLFVBQUtDLE9BQUwsR0FBZUosT0FBTyxDQUFDSSxPQUFSLElBQW1CSixPQUFPLENBQUNDLE1BQVIsQ0FBZUcsT0FBbEMsSUFBNkMsZ0JBQTVEO0FBQ0EsVUFBS0MsTUFBTCxHQUFjTCxPQUFPLENBQUNLLE1BQXRCO0FBQ0EsVUFBS0MsS0FBTCxHQUFhTixPQUFPLENBQUNNLEtBQXJCO0FBQ0EsVUFBS0MsS0FBTCxHQUFhUCxPQUFPLENBQUNPLEtBQXJCO0FBQ0EsVUFBS0MsS0FBTCxHQUFhUixPQUFPLENBQUNRLEtBQXJCO0FBQ0EsVUFBS0MsT0FBTCxHQUFlVCxPQUFPLENBQUNTLE9BQXZCO0FBQ0FDLElBQUFBLEtBQUssQ0FBQ0MsaUJBQU4sZ0NBQThCLE1BQUtDLFdBQW5DO0FBYm1CO0FBY3BCOzs7RUFmcUNmLGE7O0FBa0J4Q2dCLE1BQU0sQ0FBQ0MsT0FBUCxHQUFpQmYseUJBQWpCIiwic291cmNlc0NvbnRlbnQiOlsiJ3VzZSBzdHJpY3QnO1xuXG5jb25zdCBEYXRhYmFzZUVycm9yID0gcmVxdWlyZSgnLi8uLi9kYXRhYmFzZS1lcnJvcicpO1xuXG4vKipcbiAqIFRocm93biB3aGVuIGEgZm9yZWlnbiBrZXkgY29uc3RyYWludCBpcyB2aW9sYXRlZCBpbiB0aGUgZGF0YWJhc2VcbiAqL1xuY2xhc3MgRm9yZWlnbktleUNvbnN0cmFpbnRFcnJvciBleHRlbmRzIERhdGFiYXNlRXJyb3Ige1xuICBjb25zdHJ1Y3RvcihvcHRpb25zKSB7XG4gICAgb3B0aW9ucyA9IG9wdGlvbnMgfHwge307XG4gICAgb3B0aW9ucy5wYXJlbnQgPSBvcHRpb25zLnBhcmVudCB8fCB7IHNxbDogJycgfTtcblxuICAgIHN1cGVyKG9wdGlvbnMucGFyZW50KTtcbiAgICB0aGlzLm5hbWUgPSAnU2VxdWVsaXplRm9yZWlnbktleUNvbnN0cmFpbnRFcnJvcic7XG5cbiAgICB0aGlzLm1lc3NhZ2UgPSBvcHRpb25zLm1lc3NhZ2UgfHwgb3B0aW9ucy5wYXJlbnQubWVzc2FnZSB8fCAnRGF0YWJhc2UgRXJyb3InO1xuICAgIHRoaXMuZmllbGRzID0gb3B0aW9ucy5maWVsZHM7XG4gICAgdGhpcy50YWJsZSA9IG9wdGlvbnMudGFibGU7XG4gICAgdGhpcy52YWx1ZSA9IG9wdGlvbnMudmFsdWU7XG4gICAgdGhpcy5pbmRleCA9IG9wdGlvbnMuaW5kZXg7XG4gICAgdGhpcy5yZWx0eXBlID0gb3B0aW9ucy5yZWx0eXBlO1xuICAgIEVycm9yLmNhcHR1cmVTdGFja1RyYWNlKHRoaXMsIHRoaXMuY29uc3RydWN0b3IpO1xuICB9XG59XG5cbm1vZHVsZS5leHBvcnRzID0gRm9yZWlnbktleUNvbnN0cmFpbnRFcnJvcjtcbiJdfQ== \ No newline at end of file diff --git a/dist/errors/database/timeout-error.js b/dist/errors/database/timeout-error.js index 91f27c1..49325ca 100644 --- a/dist/errors/database/timeout-error.js +++ b/dist/errors/database/timeout-error.js @@ -2,15 +2,19 @@ function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } } -function _possibleConstructorReturn(self, call) { if (call && (typeof call === "object" || typeof call === "function")) { return call; } return _assertThisInitialized(self); } +function _inherits(subClass, superClass) { if (typeof superClass !== "function" && superClass !== null) { throw new TypeError("Super expression must either be null or a function"); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, writable: true, configurable: true } }); if (superClass) _setPrototypeOf(subClass, superClass); } -function _getPrototypeOf(o) { _getPrototypeOf = Object.setPrototypeOf ? Object.getPrototypeOf : function _getPrototypeOf(o) { return o.__proto__ || Object.getPrototypeOf(o); }; return _getPrototypeOf(o); } +function _setPrototypeOf(o, p) { _setPrototypeOf = Object.setPrototypeOf || function _setPrototypeOf(o, p) { o.__proto__ = p; return o; }; return _setPrototypeOf(o, p); } + +function _createSuper(Derived) { var hasNativeReflectConstruct = _isNativeReflectConstruct(); return function _createSuperInternal() { var Super = _getPrototypeOf(Derived), result; if (hasNativeReflectConstruct) { var NewTarget = _getPrototypeOf(this).constructor; result = Reflect.construct(Super, arguments, NewTarget); } else { result = Super.apply(this, arguments); } return _possibleConstructorReturn(this, result); }; } + +function _possibleConstructorReturn(self, call) { if (call && (typeof call === "object" || typeof call === "function")) { return call; } return _assertThisInitialized(self); } function _assertThisInitialized(self) { if (self === void 0) { throw new ReferenceError("this hasn't been initialised - super() hasn't been called"); } return self; } -function _inherits(subClass, superClass) { if (typeof superClass !== "function" && superClass !== null) { throw new TypeError("Super expression must either be null or a function"); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, writable: true, configurable: true } }); if (superClass) _setPrototypeOf(subClass, superClass); } +function _isNativeReflectConstruct() { if (typeof Reflect === "undefined" || !Reflect.construct) return false; if (Reflect.construct.sham) return false; if (typeof Proxy === "function") return true; try { Date.prototype.toString.call(Reflect.construct(Date, [], function () {})); return true; } catch (e) { return false; } } -function _setPrototypeOf(o, p) { _setPrototypeOf = Object.setPrototypeOf || function _setPrototypeOf(o, p) { o.__proto__ = p; return o; }; return _setPrototypeOf(o, p); } +function _getPrototypeOf(o) { _getPrototypeOf = Object.setPrototypeOf ? Object.getPrototypeOf : function _getPrototypeOf(o) { return o.__proto__ || Object.getPrototypeOf(o); }; return _getPrototypeOf(o); } const DatabaseError = require('./../database-error'); /** @@ -18,17 +22,17 @@ const DatabaseError = require('./../database-error'); */ -let TimeoutError = -/*#__PURE__*/ -function (_DatabaseError) { +let TimeoutError = /*#__PURE__*/function (_DatabaseError) { _inherits(TimeoutError, _DatabaseError); + var _super = _createSuper(TimeoutError); + function TimeoutError(parent) { var _this; _classCallCheck(this, TimeoutError); - _this = _possibleConstructorReturn(this, _getPrototypeOf(TimeoutError).call(this, parent)); + _this = _super.call(this, parent); _this.name = 'SequelizeTimeoutError'; Error.captureStackTrace(_assertThisInitialized(_this), _this.constructor); return _this; @@ -38,4 +42,4 @@ function (_DatabaseError) { }(DatabaseError); module.exports = TimeoutError; -//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uLy4uL2xpYi9lcnJvcnMvZGF0YWJhc2UvdGltZW91dC1lcnJvci5qcyJdLCJuYW1lcyI6WyJEYXRhYmFzZUVycm9yIiwicmVxdWlyZSIsIlRpbWVvdXRFcnJvciIsInBhcmVudCIsIm5hbWUiLCJFcnJvciIsImNhcHR1cmVTdGFja1RyYWNlIiwiY29uc3RydWN0b3IiLCJtb2R1bGUiLCJleHBvcnRzIl0sIm1hcHBpbmdzIjoiQUFBQTs7Ozs7Ozs7Ozs7Ozs7QUFFQSxNQUFNQSxhQUFhLEdBQUdDLE9BQU8sQ0FBQyxxQkFBRCxDQUE3QjtBQUVBOzs7OztJQUdNQyxZOzs7OztBQUNKLHdCQUFZQyxNQUFaLEVBQW9CO0FBQUE7O0FBQUE7O0FBQ2xCLHNGQUFNQSxNQUFOO0FBQ0EsVUFBS0MsSUFBTCxHQUFZLHVCQUFaO0FBQ0FDLElBQUFBLEtBQUssQ0FBQ0MsaUJBQU4sZ0NBQThCLE1BQUtDLFdBQW5DO0FBSGtCO0FBSW5COzs7RUFMd0JQLGE7O0FBUTNCUSxNQUFNLENBQUNDLE9BQVAsR0FBaUJQLFlBQWpCIiwic291cmNlc0NvbnRlbnQiOlsiJ3VzZSBzdHJpY3QnO1xyXG5cclxuY29uc3QgRGF0YWJhc2VFcnJvciA9IHJlcXVpcmUoJy4vLi4vZGF0YWJhc2UtZXJyb3InKTtcclxuXHJcbi8qKlxyXG4gKiBUaHJvd24gd2hlbiBhIGRhdGFiYXNlIHF1ZXJ5IHRpbWVzIG91dCBiZWNhdXNlIG9mIGEgZGVhZGxvY2tcclxuICovXHJcbmNsYXNzIFRpbWVvdXRFcnJvciBleHRlbmRzIERhdGFiYXNlRXJyb3Ige1xyXG4gIGNvbnN0cnVjdG9yKHBhcmVudCkge1xyXG4gICAgc3VwZXIocGFyZW50KTtcclxuICAgIHRoaXMubmFtZSA9ICdTZXF1ZWxpemVUaW1lb3V0RXJyb3InO1xyXG4gICAgRXJyb3IuY2FwdHVyZVN0YWNrVHJhY2UodGhpcywgdGhpcy5jb25zdHJ1Y3Rvcik7XHJcbiAgfVxyXG59XHJcblxyXG5tb2R1bGUuZXhwb3J0cyA9IFRpbWVvdXRFcnJvcjtcclxuIl19 \ No newline at end of file +//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uLy4uL2xpYi9lcnJvcnMvZGF0YWJhc2UvdGltZW91dC1lcnJvci5qcyJdLCJuYW1lcyI6WyJEYXRhYmFzZUVycm9yIiwicmVxdWlyZSIsIlRpbWVvdXRFcnJvciIsInBhcmVudCIsIm5hbWUiLCJFcnJvciIsImNhcHR1cmVTdGFja1RyYWNlIiwiY29uc3RydWN0b3IiLCJtb2R1bGUiLCJleHBvcnRzIl0sIm1hcHBpbmdzIjoiQUFBQTs7Ozs7Ozs7Ozs7Ozs7Ozs7O0FBRUEsTUFBTUEsYUFBYSxHQUFHQyxPQUFPLENBQUMscUJBQUQsQ0FBN0I7QUFFQTtBQUNBO0FBQ0E7OztJQUNNQyxZOzs7OztBQUNKLHdCQUFZQyxNQUFaLEVBQW9CO0FBQUE7O0FBQUE7O0FBQ2xCLDhCQUFNQSxNQUFOO0FBQ0EsVUFBS0MsSUFBTCxHQUFZLHVCQUFaO0FBQ0FDLElBQUFBLEtBQUssQ0FBQ0MsaUJBQU4sZ0NBQThCLE1BQUtDLFdBQW5DO0FBSGtCO0FBSW5COzs7RUFMd0JQLGE7O0FBUTNCUSxNQUFNLENBQUNDLE9BQVAsR0FBaUJQLFlBQWpCIiwic291cmNlc0NvbnRlbnQiOlsiJ3VzZSBzdHJpY3QnO1xuXG5jb25zdCBEYXRhYmFzZUVycm9yID0gcmVxdWlyZSgnLi8uLi9kYXRhYmFzZS1lcnJvcicpO1xuXG4vKipcbiAqIFRocm93biB3aGVuIGEgZGF0YWJhc2UgcXVlcnkgdGltZXMgb3V0IGJlY2F1c2Ugb2YgYSBkZWFkbG9ja1xuICovXG5jbGFzcyBUaW1lb3V0RXJyb3IgZXh0ZW5kcyBEYXRhYmFzZUVycm9yIHtcbiAgY29uc3RydWN0b3IocGFyZW50KSB7XG4gICAgc3VwZXIocGFyZW50KTtcbiAgICB0aGlzLm5hbWUgPSAnU2VxdWVsaXplVGltZW91dEVycm9yJztcbiAgICBFcnJvci5jYXB0dXJlU3RhY2tUcmFjZSh0aGlzLCB0aGlzLmNvbnN0cnVjdG9yKTtcbiAgfVxufVxuXG5tb2R1bGUuZXhwb3J0cyA9IFRpbWVvdXRFcnJvcjtcbiJdfQ== \ No newline at end of file diff --git a/dist/errors/database/unknown-constraint-error.js b/dist/errors/database/unknown-constraint-error.js index c9d7a10..4d5c2f0 100644 --- a/dist/errors/database/unknown-constraint-error.js +++ b/dist/errors/database/unknown-constraint-error.js @@ -2,15 +2,19 @@ function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } } -function _possibleConstructorReturn(self, call) { if (call && (typeof call === "object" || typeof call === "function")) { return call; } return _assertThisInitialized(self); } +function _inherits(subClass, superClass) { if (typeof superClass !== "function" && superClass !== null) { throw new TypeError("Super expression must either be null or a function"); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, writable: true, configurable: true } }); if (superClass) _setPrototypeOf(subClass, superClass); } -function _getPrototypeOf(o) { _getPrototypeOf = Object.setPrototypeOf ? Object.getPrototypeOf : function _getPrototypeOf(o) { return o.__proto__ || Object.getPrototypeOf(o); }; return _getPrototypeOf(o); } +function _setPrototypeOf(o, p) { _setPrototypeOf = Object.setPrototypeOf || function _setPrototypeOf(o, p) { o.__proto__ = p; return o; }; return _setPrototypeOf(o, p); } + +function _createSuper(Derived) { var hasNativeReflectConstruct = _isNativeReflectConstruct(); return function _createSuperInternal() { var Super = _getPrototypeOf(Derived), result; if (hasNativeReflectConstruct) { var NewTarget = _getPrototypeOf(this).constructor; result = Reflect.construct(Super, arguments, NewTarget); } else { result = Super.apply(this, arguments); } return _possibleConstructorReturn(this, result); }; } + +function _possibleConstructorReturn(self, call) { if (call && (typeof call === "object" || typeof call === "function")) { return call; } return _assertThisInitialized(self); } function _assertThisInitialized(self) { if (self === void 0) { throw new ReferenceError("this hasn't been initialised - super() hasn't been called"); } return self; } -function _inherits(subClass, superClass) { if (typeof superClass !== "function" && superClass !== null) { throw new TypeError("Super expression must either be null or a function"); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, writable: true, configurable: true } }); if (superClass) _setPrototypeOf(subClass, superClass); } +function _isNativeReflectConstruct() { if (typeof Reflect === "undefined" || !Reflect.construct) return false; if (Reflect.construct.sham) return false; if (typeof Proxy === "function") return true; try { Date.prototype.toString.call(Reflect.construct(Date, [], function () {})); return true; } catch (e) { return false; } } -function _setPrototypeOf(o, p) { _setPrototypeOf = Object.setPrototypeOf || function _setPrototypeOf(o, p) { o.__proto__ = p; return o; }; return _setPrototypeOf(o, p); } +function _getPrototypeOf(o) { _getPrototypeOf = Object.setPrototypeOf ? Object.getPrototypeOf : function _getPrototypeOf(o) { return o.__proto__ || Object.getPrototypeOf(o); }; return _getPrototypeOf(o); } const DatabaseError = require('./../database-error'); /** @@ -18,11 +22,11 @@ const DatabaseError = require('./../database-error'); */ -let UnknownConstraintError = -/*#__PURE__*/ -function (_DatabaseError) { +let UnknownConstraintError = /*#__PURE__*/function (_DatabaseError) { _inherits(UnknownConstraintError, _DatabaseError); + var _super = _createSuper(UnknownConstraintError); + function UnknownConstraintError(options) { var _this; @@ -32,7 +36,7 @@ function (_DatabaseError) { options.parent = options.parent || { sql: '' }; - _this = _possibleConstructorReturn(this, _getPrototypeOf(UnknownConstraintError).call(this, options.parent)); + _this = _super.call(this, options.parent); _this.name = 'SequelizeUnknownConstraintError'; _this.message = options.message || 'The specified constraint does not exist'; _this.constraint = options.constraint; @@ -46,4 +50,4 @@ function (_DatabaseError) { }(DatabaseError); module.exports = UnknownConstraintError; -//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uLy4uL2xpYi9lcnJvcnMvZGF0YWJhc2UvdW5rbm93bi1jb25zdHJhaW50LWVycm9yLmpzIl0sIm5hbWVzIjpbIkRhdGFiYXNlRXJyb3IiLCJyZXF1aXJlIiwiVW5rbm93bkNvbnN0cmFpbnRFcnJvciIsIm9wdGlvbnMiLCJwYXJlbnQiLCJzcWwiLCJuYW1lIiwibWVzc2FnZSIsImNvbnN0cmFpbnQiLCJmaWVsZHMiLCJ0YWJsZSIsIkVycm9yIiwiY2FwdHVyZVN0YWNrVHJhY2UiLCJjb25zdHJ1Y3RvciIsIm1vZHVsZSIsImV4cG9ydHMiXSwibWFwcGluZ3MiOiJBQUFBOzs7Ozs7Ozs7Ozs7OztBQUVBLE1BQU1BLGFBQWEsR0FBR0MsT0FBTyxDQUFDLHFCQUFELENBQTdCO0FBRUE7Ozs7O0lBR01DLHNCOzs7OztBQUNKLGtDQUFZQyxPQUFaLEVBQXFCO0FBQUE7O0FBQUE7O0FBQ25CQSxJQUFBQSxPQUFPLEdBQUdBLE9BQU8sSUFBSSxFQUFyQjtBQUNBQSxJQUFBQSxPQUFPLENBQUNDLE1BQVIsR0FBaUJELE9BQU8sQ0FBQ0MsTUFBUixJQUFrQjtBQUFFQyxNQUFBQSxHQUFHLEVBQUU7QUFBUCxLQUFuQztBQUVBLGdHQUFNRixPQUFPLENBQUNDLE1BQWQ7QUFDQSxVQUFLRSxJQUFMLEdBQVksaUNBQVo7QUFFQSxVQUFLQyxPQUFMLEdBQWVKLE9BQU8sQ0FBQ0ksT0FBUixJQUFtQix5Q0FBbEM7QUFDQSxVQUFLQyxVQUFMLEdBQWtCTCxPQUFPLENBQUNLLFVBQTFCO0FBQ0EsVUFBS0MsTUFBTCxHQUFjTixPQUFPLENBQUNNLE1BQXRCO0FBQ0EsVUFBS0MsS0FBTCxHQUFhUCxPQUFPLENBQUNPLEtBQXJCO0FBQ0FDLElBQUFBLEtBQUssQ0FBQ0MsaUJBQU4sZ0NBQThCLE1BQUtDLFdBQW5DO0FBWG1CO0FBWXBCOzs7RUFia0NiLGE7O0FBZ0JyQ2MsTUFBTSxDQUFDQyxPQUFQLEdBQWlCYixzQkFBakIiLCJzb3VyY2VzQ29udGVudCI6WyIndXNlIHN0cmljdCc7XHJcblxyXG5jb25zdCBEYXRhYmFzZUVycm9yID0gcmVxdWlyZSgnLi8uLi9kYXRhYmFzZS1lcnJvcicpO1xyXG5cclxuLyoqXHJcbiAqIFRocm93biB3aGVuIGNvbnN0cmFpbnQgbmFtZSBpcyBub3QgZm91bmQgaW4gdGhlIGRhdGFiYXNlXHJcbiAqL1xyXG5jbGFzcyBVbmtub3duQ29uc3RyYWludEVycm9yIGV4dGVuZHMgRGF0YWJhc2VFcnJvciB7XHJcbiAgY29uc3RydWN0b3Iob3B0aW9ucykge1xyXG4gICAgb3B0aW9ucyA9IG9wdGlvbnMgfHwge307XHJcbiAgICBvcHRpb25zLnBhcmVudCA9IG9wdGlvbnMucGFyZW50IHx8IHsgc3FsOiAnJyB9O1xyXG5cclxuICAgIHN1cGVyKG9wdGlvbnMucGFyZW50KTtcclxuICAgIHRoaXMubmFtZSA9ICdTZXF1ZWxpemVVbmtub3duQ29uc3RyYWludEVycm9yJztcclxuXHJcbiAgICB0aGlzLm1lc3NhZ2UgPSBvcHRpb25zLm1lc3NhZ2UgfHwgJ1RoZSBzcGVjaWZpZWQgY29uc3RyYWludCBkb2VzIG5vdCBleGlzdCc7XHJcbiAgICB0aGlzLmNvbnN0cmFpbnQgPSBvcHRpb25zLmNvbnN0cmFpbnQ7XHJcbiAgICB0aGlzLmZpZWxkcyA9IG9wdGlvbnMuZmllbGRzO1xyXG4gICAgdGhpcy50YWJsZSA9IG9wdGlvbnMudGFibGU7XHJcbiAgICBFcnJvci5jYXB0dXJlU3RhY2tUcmFjZSh0aGlzLCB0aGlzLmNvbnN0cnVjdG9yKTtcclxuICB9XHJcbn1cclxuXHJcbm1vZHVsZS5leHBvcnRzID0gVW5rbm93bkNvbnN0cmFpbnRFcnJvcjtcclxuIl19 \ No newline at end of file +//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uLy4uL2xpYi9lcnJvcnMvZGF0YWJhc2UvdW5rbm93bi1jb25zdHJhaW50LWVycm9yLmpzIl0sIm5hbWVzIjpbIkRhdGFiYXNlRXJyb3IiLCJyZXF1aXJlIiwiVW5rbm93bkNvbnN0cmFpbnRFcnJvciIsIm9wdGlvbnMiLCJwYXJlbnQiLCJzcWwiLCJuYW1lIiwibWVzc2FnZSIsImNvbnN0cmFpbnQiLCJmaWVsZHMiLCJ0YWJsZSIsIkVycm9yIiwiY2FwdHVyZVN0YWNrVHJhY2UiLCJjb25zdHJ1Y3RvciIsIm1vZHVsZSIsImV4cG9ydHMiXSwibWFwcGluZ3MiOiJBQUFBOzs7Ozs7Ozs7Ozs7Ozs7Ozs7QUFFQSxNQUFNQSxhQUFhLEdBQUdDLE9BQU8sQ0FBQyxxQkFBRCxDQUE3QjtBQUVBO0FBQ0E7QUFDQTs7O0lBQ01DLHNCOzs7OztBQUNKLGtDQUFZQyxPQUFaLEVBQXFCO0FBQUE7O0FBQUE7O0FBQ25CQSxJQUFBQSxPQUFPLEdBQUdBLE9BQU8sSUFBSSxFQUFyQjtBQUNBQSxJQUFBQSxPQUFPLENBQUNDLE1BQVIsR0FBaUJELE9BQU8sQ0FBQ0MsTUFBUixJQUFrQjtBQUFFQyxNQUFBQSxHQUFHLEVBQUU7QUFBUCxLQUFuQztBQUVBLDhCQUFNRixPQUFPLENBQUNDLE1BQWQ7QUFDQSxVQUFLRSxJQUFMLEdBQVksaUNBQVo7QUFFQSxVQUFLQyxPQUFMLEdBQWVKLE9BQU8sQ0FBQ0ksT0FBUixJQUFtQix5Q0FBbEM7QUFDQSxVQUFLQyxVQUFMLEdBQWtCTCxPQUFPLENBQUNLLFVBQTFCO0FBQ0EsVUFBS0MsTUFBTCxHQUFjTixPQUFPLENBQUNNLE1BQXRCO0FBQ0EsVUFBS0MsS0FBTCxHQUFhUCxPQUFPLENBQUNPLEtBQXJCO0FBQ0FDLElBQUFBLEtBQUssQ0FBQ0MsaUJBQU4sZ0NBQThCLE1BQUtDLFdBQW5DO0FBWG1CO0FBWXBCOzs7RUFia0NiLGE7O0FBZ0JyQ2MsTUFBTSxDQUFDQyxPQUFQLEdBQWlCYixzQkFBakIiLCJzb3VyY2VzQ29udGVudCI6WyIndXNlIHN0cmljdCc7XG5cbmNvbnN0IERhdGFiYXNlRXJyb3IgPSByZXF1aXJlKCcuLy4uL2RhdGFiYXNlLWVycm9yJyk7XG5cbi8qKlxuICogVGhyb3duIHdoZW4gY29uc3RyYWludCBuYW1lIGlzIG5vdCBmb3VuZCBpbiB0aGUgZGF0YWJhc2VcbiAqL1xuY2xhc3MgVW5rbm93bkNvbnN0cmFpbnRFcnJvciBleHRlbmRzIERhdGFiYXNlRXJyb3Ige1xuICBjb25zdHJ1Y3RvcihvcHRpb25zKSB7XG4gICAgb3B0aW9ucyA9IG9wdGlvbnMgfHwge307XG4gICAgb3B0aW9ucy5wYXJlbnQgPSBvcHRpb25zLnBhcmVudCB8fCB7IHNxbDogJycgfTtcblxuICAgIHN1cGVyKG9wdGlvbnMucGFyZW50KTtcbiAgICB0aGlzLm5hbWUgPSAnU2VxdWVsaXplVW5rbm93bkNvbnN0cmFpbnRFcnJvcic7XG5cbiAgICB0aGlzLm1lc3NhZ2UgPSBvcHRpb25zLm1lc3NhZ2UgfHwgJ1RoZSBzcGVjaWZpZWQgY29uc3RyYWludCBkb2VzIG5vdCBleGlzdCc7XG4gICAgdGhpcy5jb25zdHJhaW50ID0gb3B0aW9ucy5jb25zdHJhaW50O1xuICAgIHRoaXMuZmllbGRzID0gb3B0aW9ucy5maWVsZHM7XG4gICAgdGhpcy50YWJsZSA9IG9wdGlvbnMudGFibGU7XG4gICAgRXJyb3IuY2FwdHVyZVN0YWNrVHJhY2UodGhpcywgdGhpcy5jb25zdHJ1Y3Rvcik7XG4gIH1cbn1cblxubW9kdWxlLmV4cG9ydHMgPSBVbmtub3duQ29uc3RyYWludEVycm9yO1xuIl19 \ No newline at end of file diff --git a/dist/errors/eager-loading-error.js b/dist/errors/eager-loading-error.js index 05ce691..82b6c2f 100644 --- a/dist/errors/eager-loading-error.js +++ b/dist/errors/eager-loading-error.js @@ -2,15 +2,19 @@ function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } } -function _possibleConstructorReturn(self, call) { if (call && (typeof call === "object" || typeof call === "function")) { return call; } return _assertThisInitialized(self); } +function _inherits(subClass, superClass) { if (typeof superClass !== "function" && superClass !== null) { throw new TypeError("Super expression must either be null or a function"); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, writable: true, configurable: true } }); if (superClass) _setPrototypeOf(subClass, superClass); } -function _getPrototypeOf(o) { _getPrototypeOf = Object.setPrototypeOf ? Object.getPrototypeOf : function _getPrototypeOf(o) { return o.__proto__ || Object.getPrototypeOf(o); }; return _getPrototypeOf(o); } +function _setPrototypeOf(o, p) { _setPrototypeOf = Object.setPrototypeOf || function _setPrototypeOf(o, p) { o.__proto__ = p; return o; }; return _setPrototypeOf(o, p); } + +function _createSuper(Derived) { var hasNativeReflectConstruct = _isNativeReflectConstruct(); return function _createSuperInternal() { var Super = _getPrototypeOf(Derived), result; if (hasNativeReflectConstruct) { var NewTarget = _getPrototypeOf(this).constructor; result = Reflect.construct(Super, arguments, NewTarget); } else { result = Super.apply(this, arguments); } return _possibleConstructorReturn(this, result); }; } + +function _possibleConstructorReturn(self, call) { if (call && (typeof call === "object" || typeof call === "function")) { return call; } return _assertThisInitialized(self); } function _assertThisInitialized(self) { if (self === void 0) { throw new ReferenceError("this hasn't been initialised - super() hasn't been called"); } return self; } -function _inherits(subClass, superClass) { if (typeof superClass !== "function" && superClass !== null) { throw new TypeError("Super expression must either be null or a function"); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, writable: true, configurable: true } }); if (superClass) _setPrototypeOf(subClass, superClass); } +function _isNativeReflectConstruct() { if (typeof Reflect === "undefined" || !Reflect.construct) return false; if (Reflect.construct.sham) return false; if (typeof Proxy === "function") return true; try { Date.prototype.toString.call(Reflect.construct(Date, [], function () {})); return true; } catch (e) { return false; } } -function _setPrototypeOf(o, p) { _setPrototypeOf = Object.setPrototypeOf || function _setPrototypeOf(o, p) { o.__proto__ = p; return o; }; return _setPrototypeOf(o, p); } +function _getPrototypeOf(o) { _getPrototypeOf = Object.setPrototypeOf ? Object.getPrototypeOf : function _getPrototypeOf(o) { return o.__proto__ || Object.getPrototypeOf(o); }; return _getPrototypeOf(o); } const BaseError = require('./base-error'); /** @@ -18,17 +22,17 @@ const BaseError = require('./base-error'); */ -let EagerLoadingError = -/*#__PURE__*/ -function (_BaseError) { +let EagerLoadingError = /*#__PURE__*/function (_BaseError) { _inherits(EagerLoadingError, _BaseError); + var _super = _createSuper(EagerLoadingError); + function EagerLoadingError(message) { var _this; _classCallCheck(this, EagerLoadingError); - _this = _possibleConstructorReturn(this, _getPrototypeOf(EagerLoadingError).call(this, message)); + _this = _super.call(this, message); _this.name = 'SequelizeEagerLoadingError'; Error.captureStackTrace(_assertThisInitialized(_this), _this.constructor); return _this; @@ -38,4 +42,4 @@ function (_BaseError) { }(BaseError); module.exports = EagerLoadingError; -//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uL2xpYi9lcnJvcnMvZWFnZXItbG9hZGluZy1lcnJvci5qcyJdLCJuYW1lcyI6WyJCYXNlRXJyb3IiLCJyZXF1aXJlIiwiRWFnZXJMb2FkaW5nRXJyb3IiLCJtZXNzYWdlIiwibmFtZSIsIkVycm9yIiwiY2FwdHVyZVN0YWNrVHJhY2UiLCJjb25zdHJ1Y3RvciIsIm1vZHVsZSIsImV4cG9ydHMiXSwibWFwcGluZ3MiOiJBQUFBOzs7Ozs7Ozs7Ozs7OztBQUVBLE1BQU1BLFNBQVMsR0FBR0MsT0FBTyxDQUFDLGNBQUQsQ0FBekI7QUFFQTs7Ozs7SUFHTUMsaUI7Ozs7O0FBQ0osNkJBQVlDLE9BQVosRUFBcUI7QUFBQTs7QUFBQTs7QUFDbkIsMkZBQU1BLE9BQU47QUFDQSxVQUFLQyxJQUFMLEdBQVksNEJBQVo7QUFDQUMsSUFBQUEsS0FBSyxDQUFDQyxpQkFBTixnQ0FBOEIsTUFBS0MsV0FBbkM7QUFIbUI7QUFJcEI7OztFQUw2QlAsUzs7QUFRaENRLE1BQU0sQ0FBQ0MsT0FBUCxHQUFpQlAsaUJBQWpCIiwic291cmNlc0NvbnRlbnQiOlsiJ3VzZSBzdHJpY3QnO1xyXG5cclxuY29uc3QgQmFzZUVycm9yID0gcmVxdWlyZSgnLi9iYXNlLWVycm9yJyk7XHJcblxyXG4vKipcclxuICogVGhyb3duIHdoZW4gYW4gaW5jbHVkZSBzdGF0ZW1lbnQgaXMgaW1wcm9wZXJseSBjb25zdHJ1Y3RlZCAoc2VlIG1lc3NhZ2UgZm9yIGRldGFpbHMpXHJcbiAqL1xyXG5jbGFzcyBFYWdlckxvYWRpbmdFcnJvciBleHRlbmRzIEJhc2VFcnJvciB7XHJcbiAgY29uc3RydWN0b3IobWVzc2FnZSkge1xyXG4gICAgc3VwZXIobWVzc2FnZSk7XHJcbiAgICB0aGlzLm5hbWUgPSAnU2VxdWVsaXplRWFnZXJMb2FkaW5nRXJyb3InO1xyXG4gICAgRXJyb3IuY2FwdHVyZVN0YWNrVHJhY2UodGhpcywgdGhpcy5jb25zdHJ1Y3Rvcik7XHJcbiAgfVxyXG59XHJcblxyXG5tb2R1bGUuZXhwb3J0cyA9IEVhZ2VyTG9hZGluZ0Vycm9yO1xyXG4iXX0= \ No newline at end of file +//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uL2xpYi9lcnJvcnMvZWFnZXItbG9hZGluZy1lcnJvci5qcyJdLCJuYW1lcyI6WyJCYXNlRXJyb3IiLCJyZXF1aXJlIiwiRWFnZXJMb2FkaW5nRXJyb3IiLCJtZXNzYWdlIiwibmFtZSIsIkVycm9yIiwiY2FwdHVyZVN0YWNrVHJhY2UiLCJjb25zdHJ1Y3RvciIsIm1vZHVsZSIsImV4cG9ydHMiXSwibWFwcGluZ3MiOiJBQUFBOzs7Ozs7Ozs7Ozs7Ozs7Ozs7QUFFQSxNQUFNQSxTQUFTLEdBQUdDLE9BQU8sQ0FBQyxjQUFELENBQXpCO0FBRUE7QUFDQTtBQUNBOzs7SUFDTUMsaUI7Ozs7O0FBQ0osNkJBQVlDLE9BQVosRUFBcUI7QUFBQTs7QUFBQTs7QUFDbkIsOEJBQU1BLE9BQU47QUFDQSxVQUFLQyxJQUFMLEdBQVksNEJBQVo7QUFDQUMsSUFBQUEsS0FBSyxDQUFDQyxpQkFBTixnQ0FBOEIsTUFBS0MsV0FBbkM7QUFIbUI7QUFJcEI7OztFQUw2QlAsUzs7QUFRaENRLE1BQU0sQ0FBQ0MsT0FBUCxHQUFpQlAsaUJBQWpCIiwic291cmNlc0NvbnRlbnQiOlsiJ3VzZSBzdHJpY3QnO1xuXG5jb25zdCBCYXNlRXJyb3IgPSByZXF1aXJlKCcuL2Jhc2UtZXJyb3InKTtcblxuLyoqXG4gKiBUaHJvd24gd2hlbiBhbiBpbmNsdWRlIHN0YXRlbWVudCBpcyBpbXByb3Blcmx5IGNvbnN0cnVjdGVkIChzZWUgbWVzc2FnZSBmb3IgZGV0YWlscylcbiAqL1xuY2xhc3MgRWFnZXJMb2FkaW5nRXJyb3IgZXh0ZW5kcyBCYXNlRXJyb3Ige1xuICBjb25zdHJ1Y3RvcihtZXNzYWdlKSB7XG4gICAgc3VwZXIobWVzc2FnZSk7XG4gICAgdGhpcy5uYW1lID0gJ1NlcXVlbGl6ZUVhZ2VyTG9hZGluZ0Vycm9yJztcbiAgICBFcnJvci5jYXB0dXJlU3RhY2tUcmFjZSh0aGlzLCB0aGlzLmNvbnN0cnVjdG9yKTtcbiAgfVxufVxuXG5tb2R1bGUuZXhwb3J0cyA9IEVhZ2VyTG9hZGluZ0Vycm9yO1xuIl19 \ No newline at end of file diff --git a/dist/errors/empty-result-error.js b/dist/errors/empty-result-error.js index 357f379..707d8dd 100644 --- a/dist/errors/empty-result-error.js +++ b/dist/errors/empty-result-error.js @@ -2,15 +2,19 @@ function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } } -function _possibleConstructorReturn(self, call) { if (call && (typeof call === "object" || typeof call === "function")) { return call; } return _assertThisInitialized(self); } +function _inherits(subClass, superClass) { if (typeof superClass !== "function" && superClass !== null) { throw new TypeError("Super expression must either be null or a function"); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, writable: true, configurable: true } }); if (superClass) _setPrototypeOf(subClass, superClass); } -function _getPrototypeOf(o) { _getPrototypeOf = Object.setPrototypeOf ? Object.getPrototypeOf : function _getPrototypeOf(o) { return o.__proto__ || Object.getPrototypeOf(o); }; return _getPrototypeOf(o); } +function _setPrototypeOf(o, p) { _setPrototypeOf = Object.setPrototypeOf || function _setPrototypeOf(o, p) { o.__proto__ = p; return o; }; return _setPrototypeOf(o, p); } + +function _createSuper(Derived) { var hasNativeReflectConstruct = _isNativeReflectConstruct(); return function _createSuperInternal() { var Super = _getPrototypeOf(Derived), result; if (hasNativeReflectConstruct) { var NewTarget = _getPrototypeOf(this).constructor; result = Reflect.construct(Super, arguments, NewTarget); } else { result = Super.apply(this, arguments); } return _possibleConstructorReturn(this, result); }; } + +function _possibleConstructorReturn(self, call) { if (call && (typeof call === "object" || typeof call === "function")) { return call; } return _assertThisInitialized(self); } function _assertThisInitialized(self) { if (self === void 0) { throw new ReferenceError("this hasn't been initialised - super() hasn't been called"); } return self; } -function _inherits(subClass, superClass) { if (typeof superClass !== "function" && superClass !== null) { throw new TypeError("Super expression must either be null or a function"); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, writable: true, configurable: true } }); if (superClass) _setPrototypeOf(subClass, superClass); } +function _isNativeReflectConstruct() { if (typeof Reflect === "undefined" || !Reflect.construct) return false; if (Reflect.construct.sham) return false; if (typeof Proxy === "function") return true; try { Date.prototype.toString.call(Reflect.construct(Date, [], function () {})); return true; } catch (e) { return false; } } -function _setPrototypeOf(o, p) { _setPrototypeOf = Object.setPrototypeOf || function _setPrototypeOf(o, p) { o.__proto__ = p; return o; }; return _setPrototypeOf(o, p); } +function _getPrototypeOf(o) { _getPrototypeOf = Object.setPrototypeOf ? Object.getPrototypeOf : function _getPrototypeOf(o) { return o.__proto__ || Object.getPrototypeOf(o); }; return _getPrototypeOf(o); } const BaseError = require('./base-error'); /** @@ -18,17 +22,17 @@ const BaseError = require('./base-error'); */ -let EmptyResultError = -/*#__PURE__*/ -function (_BaseError) { +let EmptyResultError = /*#__PURE__*/function (_BaseError) { _inherits(EmptyResultError, _BaseError); + var _super = _createSuper(EmptyResultError); + function EmptyResultError(message) { var _this; _classCallCheck(this, EmptyResultError); - _this = _possibleConstructorReturn(this, _getPrototypeOf(EmptyResultError).call(this, message)); + _this = _super.call(this, message); _this.name = 'SequelizeEmptyResultError'; Error.captureStackTrace(_assertThisInitialized(_this), _this.constructor); return _this; @@ -38,4 +42,4 @@ function (_BaseError) { }(BaseError); module.exports = EmptyResultError; -//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uL2xpYi9lcnJvcnMvZW1wdHktcmVzdWx0LWVycm9yLmpzIl0sIm5hbWVzIjpbIkJhc2VFcnJvciIsInJlcXVpcmUiLCJFbXB0eVJlc3VsdEVycm9yIiwibWVzc2FnZSIsIm5hbWUiLCJFcnJvciIsImNhcHR1cmVTdGFja1RyYWNlIiwiY29uc3RydWN0b3IiLCJtb2R1bGUiLCJleHBvcnRzIl0sIm1hcHBpbmdzIjoiQUFBQTs7Ozs7Ozs7Ozs7Ozs7QUFFQSxNQUFNQSxTQUFTLEdBQUdDLE9BQU8sQ0FBQyxjQUFELENBQXpCO0FBRUE7Ozs7O0lBR01DLGdCOzs7OztBQUNKLDRCQUFZQyxPQUFaLEVBQXFCO0FBQUE7O0FBQUE7O0FBQ25CLDBGQUFNQSxPQUFOO0FBQ0EsVUFBS0MsSUFBTCxHQUFZLDJCQUFaO0FBQ0FDLElBQUFBLEtBQUssQ0FBQ0MsaUJBQU4sZ0NBQThCLE1BQUtDLFdBQW5DO0FBSG1CO0FBSXBCOzs7RUFMNEJQLFM7O0FBUS9CUSxNQUFNLENBQUNDLE9BQVAsR0FBaUJQLGdCQUFqQiIsInNvdXJjZXNDb250ZW50IjpbIid1c2Ugc3RyaWN0JztcclxuXHJcbmNvbnN0IEJhc2VFcnJvciA9IHJlcXVpcmUoJy4vYmFzZS1lcnJvcicpO1xyXG5cclxuLyoqXHJcbiAqIFRocm93biB3aGVuIGEgcmVjb3JkIHdhcyBub3QgZm91bmQsIFVzdWFsbHkgdXNlZCB3aXRoIHJlamVjdE9uRW1wdHkgbW9kZSAoc2VlIG1lc3NhZ2UgZm9yIGRldGFpbHMpXHJcbiAqL1xyXG5jbGFzcyBFbXB0eVJlc3VsdEVycm9yIGV4dGVuZHMgQmFzZUVycm9yIHtcclxuICBjb25zdHJ1Y3RvcihtZXNzYWdlKSB7XHJcbiAgICBzdXBlcihtZXNzYWdlKTtcclxuICAgIHRoaXMubmFtZSA9ICdTZXF1ZWxpemVFbXB0eVJlc3VsdEVycm9yJztcclxuICAgIEVycm9yLmNhcHR1cmVTdGFja1RyYWNlKHRoaXMsIHRoaXMuY29uc3RydWN0b3IpO1xyXG4gIH1cclxufVxyXG5cclxubW9kdWxlLmV4cG9ydHMgPSBFbXB0eVJlc3VsdEVycm9yO1xyXG4iXX0= \ No newline at end of file +//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uL2xpYi9lcnJvcnMvZW1wdHktcmVzdWx0LWVycm9yLmpzIl0sIm5hbWVzIjpbIkJhc2VFcnJvciIsInJlcXVpcmUiLCJFbXB0eVJlc3VsdEVycm9yIiwibWVzc2FnZSIsIm5hbWUiLCJFcnJvciIsImNhcHR1cmVTdGFja1RyYWNlIiwiY29uc3RydWN0b3IiLCJtb2R1bGUiLCJleHBvcnRzIl0sIm1hcHBpbmdzIjoiQUFBQTs7Ozs7Ozs7Ozs7Ozs7Ozs7O0FBRUEsTUFBTUEsU0FBUyxHQUFHQyxPQUFPLENBQUMsY0FBRCxDQUF6QjtBQUVBO0FBQ0E7QUFDQTs7O0lBQ01DLGdCOzs7OztBQUNKLDRCQUFZQyxPQUFaLEVBQXFCO0FBQUE7O0FBQUE7O0FBQ25CLDhCQUFNQSxPQUFOO0FBQ0EsVUFBS0MsSUFBTCxHQUFZLDJCQUFaO0FBQ0FDLElBQUFBLEtBQUssQ0FBQ0MsaUJBQU4sZ0NBQThCLE1BQUtDLFdBQW5DO0FBSG1CO0FBSXBCOzs7RUFMNEJQLFM7O0FBUS9CUSxNQUFNLENBQUNDLE9BQVAsR0FBaUJQLGdCQUFqQiIsInNvdXJjZXNDb250ZW50IjpbIid1c2Ugc3RyaWN0JztcblxuY29uc3QgQmFzZUVycm9yID0gcmVxdWlyZSgnLi9iYXNlLWVycm9yJyk7XG5cbi8qKlxuICogVGhyb3duIHdoZW4gYSByZWNvcmQgd2FzIG5vdCBmb3VuZCwgVXN1YWxseSB1c2VkIHdpdGggcmVqZWN0T25FbXB0eSBtb2RlIChzZWUgbWVzc2FnZSBmb3IgZGV0YWlscylcbiAqL1xuY2xhc3MgRW1wdHlSZXN1bHRFcnJvciBleHRlbmRzIEJhc2VFcnJvciB7XG4gIGNvbnN0cnVjdG9yKG1lc3NhZ2UpIHtcbiAgICBzdXBlcihtZXNzYWdlKTtcbiAgICB0aGlzLm5hbWUgPSAnU2VxdWVsaXplRW1wdHlSZXN1bHRFcnJvcic7XG4gICAgRXJyb3IuY2FwdHVyZVN0YWNrVHJhY2UodGhpcywgdGhpcy5jb25zdHJ1Y3Rvcik7XG4gIH1cbn1cblxubW9kdWxlLmV4cG9ydHMgPSBFbXB0eVJlc3VsdEVycm9yO1xuIl19 \ No newline at end of file diff --git a/dist/errors/index.js b/dist/errors/index.js index 87c0beb..c3dcdbc 100644 --- a/dist/errors/index.js +++ b/dist/errors/index.js @@ -25,4 +25,4 @@ exports.ForeignKeyConstraintError = require('./database/foreign-key-constraint-e exports.TimeoutError = require('./database/timeout-error'); exports.UnknownConstraintError = require('./database/unknown-constraint-error'); exports.UniqueConstraintError = require('./validation/unique-constraint-error'); -//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uL2xpYi9lcnJvcnMvaW5kZXguanMiXSwibmFtZXMiOlsiZXhwb3J0cyIsIkJhc2VFcnJvciIsInJlcXVpcmUiLCJBc3NvY2lhdGlvbkVycm9yIiwiQnVsa1JlY29yZEVycm9yIiwiQ29ubmVjdGlvbkVycm9yIiwiRGF0YWJhc2VFcnJvciIsIkVhZ2VyTG9hZGluZ0Vycm9yIiwiRW1wdHlSZXN1bHRFcnJvciIsIkluc3RhbmNlRXJyb3IiLCJPcHRpbWlzdGljTG9ja0Vycm9yIiwiUXVlcnlFcnJvciIsIlNlcXVlbGl6ZVNjb3BlRXJyb3IiLCJWYWxpZGF0aW9uRXJyb3IiLCJWYWxpZGF0aW9uRXJyb3JJdGVtIiwiQWNjZXNzRGVuaWVkRXJyb3IiLCJDb25uZWN0aW9uQWNxdWlyZVRpbWVvdXRFcnJvciIsIkNvbm5lY3Rpb25SZWZ1c2VkRXJyb3IiLCJDb25uZWN0aW9uVGltZWRPdXRFcnJvciIsIkhvc3ROb3RGb3VuZEVycm9yIiwiSG9zdE5vdFJlYWNoYWJsZUVycm9yIiwiSW52YWxpZENvbm5lY3Rpb25FcnJvciIsIkV4Y2x1c2lvbkNvbnN0cmFpbnRFcnJvciIsIkZvcmVpZ25LZXlDb25zdHJhaW50RXJyb3IiLCJUaW1lb3V0RXJyb3IiLCJVbmtub3duQ29uc3RyYWludEVycm9yIiwiVW5pcXVlQ29uc3RyYWludEVycm9yIl0sIm1hcHBpbmdzIjoiQUFBQTs7QUFFQUEsT0FBTyxDQUFDQyxTQUFSLEdBQW9CQyxPQUFPLENBQUMsY0FBRCxDQUEzQjtBQUVBRixPQUFPLENBQUNHLGdCQUFSLEdBQTJCRCxPQUFPLENBQUMscUJBQUQsQ0FBbEM7QUFDQUYsT0FBTyxDQUFDSSxlQUFSLEdBQTBCRixPQUFPLENBQUMscUJBQUQsQ0FBakM7QUFDQUYsT0FBTyxDQUFDSyxlQUFSLEdBQTBCSCxPQUFPLENBQUMsb0JBQUQsQ0FBakM7QUFDQUYsT0FBTyxDQUFDTSxhQUFSLEdBQXdCSixPQUFPLENBQUMsa0JBQUQsQ0FBL0I7QUFDQUYsT0FBTyxDQUFDTyxpQkFBUixHQUE0QkwsT0FBTyxDQUFDLHVCQUFELENBQW5DO0FBQ0FGLE9BQU8sQ0FBQ1EsZ0JBQVIsR0FBMkJOLE9BQU8sQ0FBQyxzQkFBRCxDQUFsQztBQUNBRixPQUFPLENBQUNTLGFBQVIsR0FBd0JQLE9BQU8sQ0FBQyxrQkFBRCxDQUEvQjtBQUNBRixPQUFPLENBQUNVLG1CQUFSLEdBQThCUixPQUFPLENBQUMseUJBQUQsQ0FBckM7QUFDQUYsT0FBTyxDQUFDVyxVQUFSLEdBQXFCVCxPQUFPLENBQUMsZUFBRCxDQUE1QjtBQUNBRixPQUFPLENBQUNZLG1CQUFSLEdBQThCVixPQUFPLENBQUMseUJBQUQsQ0FBckM7QUFDQUYsT0FBTyxDQUFDYSxlQUFSLEdBQTBCWCxPQUFPLENBQUMsb0JBQUQsQ0FBakM7QUFDQUYsT0FBTyxDQUFDYyxtQkFBUixHQUE4QmQsT0FBTyxDQUFDYSxlQUFSLENBQXdCQyxtQkFBdEQ7QUFFQWQsT0FBTyxDQUFDZSxpQkFBUixHQUE0QmIsT0FBTyxDQUFDLGtDQUFELENBQW5DO0FBQ0FGLE9BQU8sQ0FBQ2dCLDZCQUFSLEdBQXdDZCxPQUFPLENBQUMsK0NBQUQsQ0FBL0M7QUFDQUYsT0FBTyxDQUFDaUIsc0JBQVIsR0FBaUNmLE9BQU8sQ0FBQyx1Q0FBRCxDQUF4QztBQUNBRixPQUFPLENBQUNrQix1QkFBUixHQUFrQ2hCLE9BQU8sQ0FBQyx5Q0FBRCxDQUF6QztBQUNBRixPQUFPLENBQUNtQixpQkFBUixHQUE0QmpCLE9BQU8sQ0FBQyxtQ0FBRCxDQUFuQztBQUNBRixPQUFPLENBQUNvQixxQkFBUixHQUFnQ2xCLE9BQU8sQ0FBQyx1Q0FBRCxDQUF2QztBQUNBRixPQUFPLENBQUNxQixzQkFBUixHQUFpQ25CLE9BQU8sQ0FBQyx1Q0FBRCxDQUF4QztBQUVBRixPQUFPLENBQUNzQix3QkFBUixHQUFtQ3BCLE9BQU8sQ0FBQyx1Q0FBRCxDQUExQztBQUNBRixPQUFPLENBQUN1Qix5QkFBUixHQUFvQ3JCLE9BQU8sQ0FBQyx5Q0FBRCxDQUEzQztBQUNBRixPQUFPLENBQUN3QixZQUFSLEdBQXVCdEIsT0FBTyxDQUFDLDBCQUFELENBQTlCO0FBQ0FGLE9BQU8sQ0FBQ3lCLHNCQUFSLEdBQWlDdkIsT0FBTyxDQUFDLHFDQUFELENBQXhDO0FBRUFGLE9BQU8sQ0FBQzBCLHFCQUFSLEdBQWdDeEIsT0FBTyxDQUFDLHNDQUFELENBQXZDIiwic291cmNlc0NvbnRlbnQiOlsiJ3VzZSBzdHJpY3QnO1xyXG5cclxuZXhwb3J0cy5CYXNlRXJyb3IgPSByZXF1aXJlKCcuL2Jhc2UtZXJyb3InKTtcclxuXHJcbmV4cG9ydHMuQXNzb2NpYXRpb25FcnJvciA9IHJlcXVpcmUoJy4vYXNzb2NpYXRpb24tZXJyb3InKTtcclxuZXhwb3J0cy5CdWxrUmVjb3JkRXJyb3IgPSByZXF1aXJlKCcuL2J1bGstcmVjb3JkLWVycm9yJyk7XHJcbmV4cG9ydHMuQ29ubmVjdGlvbkVycm9yID0gcmVxdWlyZSgnLi9jb25uZWN0aW9uLWVycm9yJyk7XHJcbmV4cG9ydHMuRGF0YWJhc2VFcnJvciA9IHJlcXVpcmUoJy4vZGF0YWJhc2UtZXJyb3InKTtcclxuZXhwb3J0cy5FYWdlckxvYWRpbmdFcnJvciA9IHJlcXVpcmUoJy4vZWFnZXItbG9hZGluZy1lcnJvcicpO1xyXG5leHBvcnRzLkVtcHR5UmVzdWx0RXJyb3IgPSByZXF1aXJlKCcuL2VtcHR5LXJlc3VsdC1lcnJvcicpO1xyXG5leHBvcnRzLkluc3RhbmNlRXJyb3IgPSByZXF1aXJlKCcuL2luc3RhbmNlLWVycm9yJyk7XHJcbmV4cG9ydHMuT3B0aW1pc3RpY0xvY2tFcnJvciA9IHJlcXVpcmUoJy4vb3B0aW1pc3RpYy1sb2NrLWVycm9yJyk7XHJcbmV4cG9ydHMuUXVlcnlFcnJvciA9IHJlcXVpcmUoJy4vcXVlcnktZXJyb3InKTtcclxuZXhwb3J0cy5TZXF1ZWxpemVTY29wZUVycm9yID0gcmVxdWlyZSgnLi9zZXF1ZWxpemUtc2NvcGUtZXJyb3InKTtcclxuZXhwb3J0cy5WYWxpZGF0aW9uRXJyb3IgPSByZXF1aXJlKCcuL3ZhbGlkYXRpb24tZXJyb3InKTtcclxuZXhwb3J0cy5WYWxpZGF0aW9uRXJyb3JJdGVtID0gZXhwb3J0cy5WYWxpZGF0aW9uRXJyb3IuVmFsaWRhdGlvbkVycm9ySXRlbTtcclxuXHJcbmV4cG9ydHMuQWNjZXNzRGVuaWVkRXJyb3IgPSByZXF1aXJlKCcuL2Nvbm5lY3Rpb24vYWNjZXNzLWRlbmllZC1lcnJvcicpO1xyXG5leHBvcnRzLkNvbm5lY3Rpb25BY3F1aXJlVGltZW91dEVycm9yID0gcmVxdWlyZSgnLi9jb25uZWN0aW9uL2Nvbm5lY3Rpb24tYWNxdWlyZS10aW1lb3V0LWVycm9yJyk7XHJcbmV4cG9ydHMuQ29ubmVjdGlvblJlZnVzZWRFcnJvciA9IHJlcXVpcmUoJy4vY29ubmVjdGlvbi9jb25uZWN0aW9uLXJlZnVzZWQtZXJyb3InKTtcclxuZXhwb3J0cy5Db25uZWN0aW9uVGltZWRPdXRFcnJvciA9IHJlcXVpcmUoJy4vY29ubmVjdGlvbi9jb25uZWN0aW9uLXRpbWVkLW91dC1lcnJvcicpO1xyXG5leHBvcnRzLkhvc3ROb3RGb3VuZEVycm9yID0gcmVxdWlyZSgnLi9jb25uZWN0aW9uL2hvc3Qtbm90LWZvdW5kLWVycm9yJyk7XHJcbmV4cG9ydHMuSG9zdE5vdFJlYWNoYWJsZUVycm9yID0gcmVxdWlyZSgnLi9jb25uZWN0aW9uL2hvc3Qtbm90LXJlYWNoYWJsZS1lcnJvcicpO1xyXG5leHBvcnRzLkludmFsaWRDb25uZWN0aW9uRXJyb3IgPSByZXF1aXJlKCcuL2Nvbm5lY3Rpb24vaW52YWxpZC1jb25uZWN0aW9uLWVycm9yJyk7XHJcblxyXG5leHBvcnRzLkV4Y2x1c2lvbkNvbnN0cmFpbnRFcnJvciA9IHJlcXVpcmUoJy4vZGF0YWJhc2UvZXhjbHVzaW9uLWNvbnN0cmFpbnQtZXJyb3InKTtcclxuZXhwb3J0cy5Gb3JlaWduS2V5Q29uc3RyYWludEVycm9yID0gcmVxdWlyZSgnLi9kYXRhYmFzZS9mb3JlaWduLWtleS1jb25zdHJhaW50LWVycm9yJyk7XHJcbmV4cG9ydHMuVGltZW91dEVycm9yID0gcmVxdWlyZSgnLi9kYXRhYmFzZS90aW1lb3V0LWVycm9yJyk7XHJcbmV4cG9ydHMuVW5rbm93bkNvbnN0cmFpbnRFcnJvciA9IHJlcXVpcmUoJy4vZGF0YWJhc2UvdW5rbm93bi1jb25zdHJhaW50LWVycm9yJyk7XHJcblxyXG5leHBvcnRzLlVuaXF1ZUNvbnN0cmFpbnRFcnJvciA9IHJlcXVpcmUoJy4vdmFsaWRhdGlvbi91bmlxdWUtY29uc3RyYWludC1lcnJvcicpO1xyXG4iXX0= \ No newline at end of file +//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uL2xpYi9lcnJvcnMvaW5kZXguanMiXSwibmFtZXMiOlsiZXhwb3J0cyIsIkJhc2VFcnJvciIsInJlcXVpcmUiLCJBc3NvY2lhdGlvbkVycm9yIiwiQnVsa1JlY29yZEVycm9yIiwiQ29ubmVjdGlvbkVycm9yIiwiRGF0YWJhc2VFcnJvciIsIkVhZ2VyTG9hZGluZ0Vycm9yIiwiRW1wdHlSZXN1bHRFcnJvciIsIkluc3RhbmNlRXJyb3IiLCJPcHRpbWlzdGljTG9ja0Vycm9yIiwiUXVlcnlFcnJvciIsIlNlcXVlbGl6ZVNjb3BlRXJyb3IiLCJWYWxpZGF0aW9uRXJyb3IiLCJWYWxpZGF0aW9uRXJyb3JJdGVtIiwiQWNjZXNzRGVuaWVkRXJyb3IiLCJDb25uZWN0aW9uQWNxdWlyZVRpbWVvdXRFcnJvciIsIkNvbm5lY3Rpb25SZWZ1c2VkRXJyb3IiLCJDb25uZWN0aW9uVGltZWRPdXRFcnJvciIsIkhvc3ROb3RGb3VuZEVycm9yIiwiSG9zdE5vdFJlYWNoYWJsZUVycm9yIiwiSW52YWxpZENvbm5lY3Rpb25FcnJvciIsIkV4Y2x1c2lvbkNvbnN0cmFpbnRFcnJvciIsIkZvcmVpZ25LZXlDb25zdHJhaW50RXJyb3IiLCJUaW1lb3V0RXJyb3IiLCJVbmtub3duQ29uc3RyYWludEVycm9yIiwiVW5pcXVlQ29uc3RyYWludEVycm9yIl0sIm1hcHBpbmdzIjoiQUFBQTs7QUFFQUEsT0FBTyxDQUFDQyxTQUFSLEdBQW9CQyxPQUFPLENBQUMsY0FBRCxDQUEzQjtBQUVBRixPQUFPLENBQUNHLGdCQUFSLEdBQTJCRCxPQUFPLENBQUMscUJBQUQsQ0FBbEM7QUFDQUYsT0FBTyxDQUFDSSxlQUFSLEdBQTBCRixPQUFPLENBQUMscUJBQUQsQ0FBakM7QUFDQUYsT0FBTyxDQUFDSyxlQUFSLEdBQTBCSCxPQUFPLENBQUMsb0JBQUQsQ0FBakM7QUFDQUYsT0FBTyxDQUFDTSxhQUFSLEdBQXdCSixPQUFPLENBQUMsa0JBQUQsQ0FBL0I7QUFDQUYsT0FBTyxDQUFDTyxpQkFBUixHQUE0QkwsT0FBTyxDQUFDLHVCQUFELENBQW5DO0FBQ0FGLE9BQU8sQ0FBQ1EsZ0JBQVIsR0FBMkJOLE9BQU8sQ0FBQyxzQkFBRCxDQUFsQztBQUNBRixPQUFPLENBQUNTLGFBQVIsR0FBd0JQLE9BQU8sQ0FBQyxrQkFBRCxDQUEvQjtBQUNBRixPQUFPLENBQUNVLG1CQUFSLEdBQThCUixPQUFPLENBQUMseUJBQUQsQ0FBckM7QUFDQUYsT0FBTyxDQUFDVyxVQUFSLEdBQXFCVCxPQUFPLENBQUMsZUFBRCxDQUE1QjtBQUNBRixPQUFPLENBQUNZLG1CQUFSLEdBQThCVixPQUFPLENBQUMseUJBQUQsQ0FBckM7QUFDQUYsT0FBTyxDQUFDYSxlQUFSLEdBQTBCWCxPQUFPLENBQUMsb0JBQUQsQ0FBakM7QUFDQUYsT0FBTyxDQUFDYyxtQkFBUixHQUE4QmQsT0FBTyxDQUFDYSxlQUFSLENBQXdCQyxtQkFBdEQ7QUFFQWQsT0FBTyxDQUFDZSxpQkFBUixHQUE0QmIsT0FBTyxDQUFDLGtDQUFELENBQW5DO0FBQ0FGLE9BQU8sQ0FBQ2dCLDZCQUFSLEdBQXdDZCxPQUFPLENBQUMsK0NBQUQsQ0FBL0M7QUFDQUYsT0FBTyxDQUFDaUIsc0JBQVIsR0FBaUNmLE9BQU8sQ0FBQyx1Q0FBRCxDQUF4QztBQUNBRixPQUFPLENBQUNrQix1QkFBUixHQUFrQ2hCLE9BQU8sQ0FBQyx5Q0FBRCxDQUF6QztBQUNBRixPQUFPLENBQUNtQixpQkFBUixHQUE0QmpCLE9BQU8sQ0FBQyxtQ0FBRCxDQUFuQztBQUNBRixPQUFPLENBQUNvQixxQkFBUixHQUFnQ2xCLE9BQU8sQ0FBQyx1Q0FBRCxDQUF2QztBQUNBRixPQUFPLENBQUNxQixzQkFBUixHQUFpQ25CLE9BQU8sQ0FBQyx1Q0FBRCxDQUF4QztBQUVBRixPQUFPLENBQUNzQix3QkFBUixHQUFtQ3BCLE9BQU8sQ0FBQyx1Q0FBRCxDQUExQztBQUNBRixPQUFPLENBQUN1Qix5QkFBUixHQUFvQ3JCLE9BQU8sQ0FBQyx5Q0FBRCxDQUEzQztBQUNBRixPQUFPLENBQUN3QixZQUFSLEdBQXVCdEIsT0FBTyxDQUFDLDBCQUFELENBQTlCO0FBQ0FGLE9BQU8sQ0FBQ3lCLHNCQUFSLEdBQWlDdkIsT0FBTyxDQUFDLHFDQUFELENBQXhDO0FBRUFGLE9BQU8sQ0FBQzBCLHFCQUFSLEdBQWdDeEIsT0FBTyxDQUFDLHNDQUFELENBQXZDIiwic291cmNlc0NvbnRlbnQiOlsiJ3VzZSBzdHJpY3QnO1xuXG5leHBvcnRzLkJhc2VFcnJvciA9IHJlcXVpcmUoJy4vYmFzZS1lcnJvcicpO1xuXG5leHBvcnRzLkFzc29jaWF0aW9uRXJyb3IgPSByZXF1aXJlKCcuL2Fzc29jaWF0aW9uLWVycm9yJyk7XG5leHBvcnRzLkJ1bGtSZWNvcmRFcnJvciA9IHJlcXVpcmUoJy4vYnVsay1yZWNvcmQtZXJyb3InKTtcbmV4cG9ydHMuQ29ubmVjdGlvbkVycm9yID0gcmVxdWlyZSgnLi9jb25uZWN0aW9uLWVycm9yJyk7XG5leHBvcnRzLkRhdGFiYXNlRXJyb3IgPSByZXF1aXJlKCcuL2RhdGFiYXNlLWVycm9yJyk7XG5leHBvcnRzLkVhZ2VyTG9hZGluZ0Vycm9yID0gcmVxdWlyZSgnLi9lYWdlci1sb2FkaW5nLWVycm9yJyk7XG5leHBvcnRzLkVtcHR5UmVzdWx0RXJyb3IgPSByZXF1aXJlKCcuL2VtcHR5LXJlc3VsdC1lcnJvcicpO1xuZXhwb3J0cy5JbnN0YW5jZUVycm9yID0gcmVxdWlyZSgnLi9pbnN0YW5jZS1lcnJvcicpO1xuZXhwb3J0cy5PcHRpbWlzdGljTG9ja0Vycm9yID0gcmVxdWlyZSgnLi9vcHRpbWlzdGljLWxvY2stZXJyb3InKTtcbmV4cG9ydHMuUXVlcnlFcnJvciA9IHJlcXVpcmUoJy4vcXVlcnktZXJyb3InKTtcbmV4cG9ydHMuU2VxdWVsaXplU2NvcGVFcnJvciA9IHJlcXVpcmUoJy4vc2VxdWVsaXplLXNjb3BlLWVycm9yJyk7XG5leHBvcnRzLlZhbGlkYXRpb25FcnJvciA9IHJlcXVpcmUoJy4vdmFsaWRhdGlvbi1lcnJvcicpO1xuZXhwb3J0cy5WYWxpZGF0aW9uRXJyb3JJdGVtID0gZXhwb3J0cy5WYWxpZGF0aW9uRXJyb3IuVmFsaWRhdGlvbkVycm9ySXRlbTtcblxuZXhwb3J0cy5BY2Nlc3NEZW5pZWRFcnJvciA9IHJlcXVpcmUoJy4vY29ubmVjdGlvbi9hY2Nlc3MtZGVuaWVkLWVycm9yJyk7XG5leHBvcnRzLkNvbm5lY3Rpb25BY3F1aXJlVGltZW91dEVycm9yID0gcmVxdWlyZSgnLi9jb25uZWN0aW9uL2Nvbm5lY3Rpb24tYWNxdWlyZS10aW1lb3V0LWVycm9yJyk7XG5leHBvcnRzLkNvbm5lY3Rpb25SZWZ1c2VkRXJyb3IgPSByZXF1aXJlKCcuL2Nvbm5lY3Rpb24vY29ubmVjdGlvbi1yZWZ1c2VkLWVycm9yJyk7XG5leHBvcnRzLkNvbm5lY3Rpb25UaW1lZE91dEVycm9yID0gcmVxdWlyZSgnLi9jb25uZWN0aW9uL2Nvbm5lY3Rpb24tdGltZWQtb3V0LWVycm9yJyk7XG5leHBvcnRzLkhvc3ROb3RGb3VuZEVycm9yID0gcmVxdWlyZSgnLi9jb25uZWN0aW9uL2hvc3Qtbm90LWZvdW5kLWVycm9yJyk7XG5leHBvcnRzLkhvc3ROb3RSZWFjaGFibGVFcnJvciA9IHJlcXVpcmUoJy4vY29ubmVjdGlvbi9ob3N0LW5vdC1yZWFjaGFibGUtZXJyb3InKTtcbmV4cG9ydHMuSW52YWxpZENvbm5lY3Rpb25FcnJvciA9IHJlcXVpcmUoJy4vY29ubmVjdGlvbi9pbnZhbGlkLWNvbm5lY3Rpb24tZXJyb3InKTtcblxuZXhwb3J0cy5FeGNsdXNpb25Db25zdHJhaW50RXJyb3IgPSByZXF1aXJlKCcuL2RhdGFiYXNlL2V4Y2x1c2lvbi1jb25zdHJhaW50LWVycm9yJyk7XG5leHBvcnRzLkZvcmVpZ25LZXlDb25zdHJhaW50RXJyb3IgPSByZXF1aXJlKCcuL2RhdGFiYXNlL2ZvcmVpZ24ta2V5LWNvbnN0cmFpbnQtZXJyb3InKTtcbmV4cG9ydHMuVGltZW91dEVycm9yID0gcmVxdWlyZSgnLi9kYXRhYmFzZS90aW1lb3V0LWVycm9yJyk7XG5leHBvcnRzLlVua25vd25Db25zdHJhaW50RXJyb3IgPSByZXF1aXJlKCcuL2RhdGFiYXNlL3Vua25vd24tY29uc3RyYWludC1lcnJvcicpO1xuXG5leHBvcnRzLlVuaXF1ZUNvbnN0cmFpbnRFcnJvciA9IHJlcXVpcmUoJy4vdmFsaWRhdGlvbi91bmlxdWUtY29uc3RyYWludC1lcnJvcicpO1xuIl19 \ No newline at end of file diff --git a/dist/errors/instance-error.js b/dist/errors/instance-error.js index 899c3d4..60cd94f 100644 --- a/dist/errors/instance-error.js +++ b/dist/errors/instance-error.js @@ -2,15 +2,19 @@ function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } } -function _possibleConstructorReturn(self, call) { if (call && (typeof call === "object" || typeof call === "function")) { return call; } return _assertThisInitialized(self); } +function _inherits(subClass, superClass) { if (typeof superClass !== "function" && superClass !== null) { throw new TypeError("Super expression must either be null or a function"); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, writable: true, configurable: true } }); if (superClass) _setPrototypeOf(subClass, superClass); } -function _getPrototypeOf(o) { _getPrototypeOf = Object.setPrototypeOf ? Object.getPrototypeOf : function _getPrototypeOf(o) { return o.__proto__ || Object.getPrototypeOf(o); }; return _getPrototypeOf(o); } +function _setPrototypeOf(o, p) { _setPrototypeOf = Object.setPrototypeOf || function _setPrototypeOf(o, p) { o.__proto__ = p; return o; }; return _setPrototypeOf(o, p); } + +function _createSuper(Derived) { var hasNativeReflectConstruct = _isNativeReflectConstruct(); return function _createSuperInternal() { var Super = _getPrototypeOf(Derived), result; if (hasNativeReflectConstruct) { var NewTarget = _getPrototypeOf(this).constructor; result = Reflect.construct(Super, arguments, NewTarget); } else { result = Super.apply(this, arguments); } return _possibleConstructorReturn(this, result); }; } + +function _possibleConstructorReturn(self, call) { if (call && (typeof call === "object" || typeof call === "function")) { return call; } return _assertThisInitialized(self); } function _assertThisInitialized(self) { if (self === void 0) { throw new ReferenceError("this hasn't been initialised - super() hasn't been called"); } return self; } -function _inherits(subClass, superClass) { if (typeof superClass !== "function" && superClass !== null) { throw new TypeError("Super expression must either be null or a function"); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, writable: true, configurable: true } }); if (superClass) _setPrototypeOf(subClass, superClass); } +function _isNativeReflectConstruct() { if (typeof Reflect === "undefined" || !Reflect.construct) return false; if (Reflect.construct.sham) return false; if (typeof Proxy === "function") return true; try { Date.prototype.toString.call(Reflect.construct(Date, [], function () {})); return true; } catch (e) { return false; } } -function _setPrototypeOf(o, p) { _setPrototypeOf = Object.setPrototypeOf || function _setPrototypeOf(o, p) { o.__proto__ = p; return o; }; return _setPrototypeOf(o, p); } +function _getPrototypeOf(o) { _getPrototypeOf = Object.setPrototypeOf ? Object.getPrototypeOf : function _getPrototypeOf(o) { return o.__proto__ || Object.getPrototypeOf(o); }; return _getPrototypeOf(o); } const BaseError = require('./base-error'); /** @@ -18,17 +22,17 @@ const BaseError = require('./base-error'); */ -let InstanceError = -/*#__PURE__*/ -function (_BaseError) { +let InstanceError = /*#__PURE__*/function (_BaseError) { _inherits(InstanceError, _BaseError); + var _super = _createSuper(InstanceError); + function InstanceError(message) { var _this; _classCallCheck(this, InstanceError); - _this = _possibleConstructorReturn(this, _getPrototypeOf(InstanceError).call(this, message)); + _this = _super.call(this, message); _this.name = 'SequelizeInstanceError'; Error.captureStackTrace(_assertThisInitialized(_this), _this.constructor); return _this; @@ -38,4 +42,4 @@ function (_BaseError) { }(BaseError); module.exports = InstanceError; -//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uL2xpYi9lcnJvcnMvaW5zdGFuY2UtZXJyb3IuanMiXSwibmFtZXMiOlsiQmFzZUVycm9yIiwicmVxdWlyZSIsIkluc3RhbmNlRXJyb3IiLCJtZXNzYWdlIiwibmFtZSIsIkVycm9yIiwiY2FwdHVyZVN0YWNrVHJhY2UiLCJjb25zdHJ1Y3RvciIsIm1vZHVsZSIsImV4cG9ydHMiXSwibWFwcGluZ3MiOiJBQUFBOzs7Ozs7Ozs7Ozs7OztBQUVBLE1BQU1BLFNBQVMsR0FBR0MsT0FBTyxDQUFDLGNBQUQsQ0FBekI7QUFFQTs7Ozs7SUFHTUMsYTs7Ozs7QUFDSix5QkFBWUMsT0FBWixFQUFxQjtBQUFBOztBQUFBOztBQUNuQix1RkFBTUEsT0FBTjtBQUNBLFVBQUtDLElBQUwsR0FBWSx3QkFBWjtBQUNBQyxJQUFBQSxLQUFLLENBQUNDLGlCQUFOLGdDQUE4QixNQUFLQyxXQUFuQztBQUhtQjtBQUlwQjs7O0VBTHlCUCxTOztBQVE1QlEsTUFBTSxDQUFDQyxPQUFQLEdBQWlCUCxhQUFqQiIsInNvdXJjZXNDb250ZW50IjpbIid1c2Ugc3RyaWN0JztcclxuXHJcbmNvbnN0IEJhc2VFcnJvciA9IHJlcXVpcmUoJy4vYmFzZS1lcnJvcicpO1xyXG5cclxuLyoqXHJcbiAqIFRocm93biB3aGVuIGEgc29tZSBwcm9ibGVtIG9jY3VycmVkIHdpdGggSW5zdGFuY2UgbWV0aG9kcyAoc2VlIG1lc3NhZ2UgZm9yIGRldGFpbHMpXHJcbiAqL1xyXG5jbGFzcyBJbnN0YW5jZUVycm9yIGV4dGVuZHMgQmFzZUVycm9yIHtcclxuICBjb25zdHJ1Y3RvcihtZXNzYWdlKSB7XHJcbiAgICBzdXBlcihtZXNzYWdlKTtcclxuICAgIHRoaXMubmFtZSA9ICdTZXF1ZWxpemVJbnN0YW5jZUVycm9yJztcclxuICAgIEVycm9yLmNhcHR1cmVTdGFja1RyYWNlKHRoaXMsIHRoaXMuY29uc3RydWN0b3IpO1xyXG4gIH1cclxufVxyXG5cclxubW9kdWxlLmV4cG9ydHMgPSBJbnN0YW5jZUVycm9yO1xyXG4iXX0= \ No newline at end of file +//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uL2xpYi9lcnJvcnMvaW5zdGFuY2UtZXJyb3IuanMiXSwibmFtZXMiOlsiQmFzZUVycm9yIiwicmVxdWlyZSIsIkluc3RhbmNlRXJyb3IiLCJtZXNzYWdlIiwibmFtZSIsIkVycm9yIiwiY2FwdHVyZVN0YWNrVHJhY2UiLCJjb25zdHJ1Y3RvciIsIm1vZHVsZSIsImV4cG9ydHMiXSwibWFwcGluZ3MiOiJBQUFBOzs7Ozs7Ozs7Ozs7Ozs7Ozs7QUFFQSxNQUFNQSxTQUFTLEdBQUdDLE9BQU8sQ0FBQyxjQUFELENBQXpCO0FBRUE7QUFDQTtBQUNBOzs7SUFDTUMsYTs7Ozs7QUFDSix5QkFBWUMsT0FBWixFQUFxQjtBQUFBOztBQUFBOztBQUNuQiw4QkFBTUEsT0FBTjtBQUNBLFVBQUtDLElBQUwsR0FBWSx3QkFBWjtBQUNBQyxJQUFBQSxLQUFLLENBQUNDLGlCQUFOLGdDQUE4QixNQUFLQyxXQUFuQztBQUhtQjtBQUlwQjs7O0VBTHlCUCxTOztBQVE1QlEsTUFBTSxDQUFDQyxPQUFQLEdBQWlCUCxhQUFqQiIsInNvdXJjZXNDb250ZW50IjpbIid1c2Ugc3RyaWN0JztcblxuY29uc3QgQmFzZUVycm9yID0gcmVxdWlyZSgnLi9iYXNlLWVycm9yJyk7XG5cbi8qKlxuICogVGhyb3duIHdoZW4gYSBzb21lIHByb2JsZW0gb2NjdXJyZWQgd2l0aCBJbnN0YW5jZSBtZXRob2RzIChzZWUgbWVzc2FnZSBmb3IgZGV0YWlscylcbiAqL1xuY2xhc3MgSW5zdGFuY2VFcnJvciBleHRlbmRzIEJhc2VFcnJvciB7XG4gIGNvbnN0cnVjdG9yKG1lc3NhZ2UpIHtcbiAgICBzdXBlcihtZXNzYWdlKTtcbiAgICB0aGlzLm5hbWUgPSAnU2VxdWVsaXplSW5zdGFuY2VFcnJvcic7XG4gICAgRXJyb3IuY2FwdHVyZVN0YWNrVHJhY2UodGhpcywgdGhpcy5jb25zdHJ1Y3Rvcik7XG4gIH1cbn1cblxubW9kdWxlLmV4cG9ydHMgPSBJbnN0YW5jZUVycm9yO1xuIl19 \ No newline at end of file diff --git a/dist/errors/optimistic-lock-error.js b/dist/errors/optimistic-lock-error.js index a783938..f4dc678 100644 --- a/dist/errors/optimistic-lock-error.js +++ b/dist/errors/optimistic-lock-error.js @@ -2,15 +2,19 @@ function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } } -function _possibleConstructorReturn(self, call) { if (call && (typeof call === "object" || typeof call === "function")) { return call; } return _assertThisInitialized(self); } +function _inherits(subClass, superClass) { if (typeof superClass !== "function" && superClass !== null) { throw new TypeError("Super expression must either be null or a function"); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, writable: true, configurable: true } }); if (superClass) _setPrototypeOf(subClass, superClass); } -function _getPrototypeOf(o) { _getPrototypeOf = Object.setPrototypeOf ? Object.getPrototypeOf : function _getPrototypeOf(o) { return o.__proto__ || Object.getPrototypeOf(o); }; return _getPrototypeOf(o); } +function _setPrototypeOf(o, p) { _setPrototypeOf = Object.setPrototypeOf || function _setPrototypeOf(o, p) { o.__proto__ = p; return o; }; return _setPrototypeOf(o, p); } + +function _createSuper(Derived) { var hasNativeReflectConstruct = _isNativeReflectConstruct(); return function _createSuperInternal() { var Super = _getPrototypeOf(Derived), result; if (hasNativeReflectConstruct) { var NewTarget = _getPrototypeOf(this).constructor; result = Reflect.construct(Super, arguments, NewTarget); } else { result = Super.apply(this, arguments); } return _possibleConstructorReturn(this, result); }; } + +function _possibleConstructorReturn(self, call) { if (call && (typeof call === "object" || typeof call === "function")) { return call; } return _assertThisInitialized(self); } function _assertThisInitialized(self) { if (self === void 0) { throw new ReferenceError("this hasn't been initialised - super() hasn't been called"); } return self; } -function _inherits(subClass, superClass) { if (typeof superClass !== "function" && superClass !== null) { throw new TypeError("Super expression must either be null or a function"); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, writable: true, configurable: true } }); if (superClass) _setPrototypeOf(subClass, superClass); } +function _isNativeReflectConstruct() { if (typeof Reflect === "undefined" || !Reflect.construct) return false; if (Reflect.construct.sham) return false; if (typeof Proxy === "function") return true; try { Date.prototype.toString.call(Reflect.construct(Date, [], function () {})); return true; } catch (e) { return false; } } -function _setPrototypeOf(o, p) { _setPrototypeOf = Object.setPrototypeOf || function _setPrototypeOf(o, p) { o.__proto__ = p; return o; }; return _setPrototypeOf(o, p); } +function _getPrototypeOf(o) { _getPrototypeOf = Object.setPrototypeOf ? Object.getPrototypeOf : function _getPrototypeOf(o) { return o.__proto__ || Object.getPrototypeOf(o); }; return _getPrototypeOf(o); } const BaseError = require('./base-error'); /** @@ -18,11 +22,11 @@ const BaseError = require('./base-error'); */ -let OptimisticLockError = -/*#__PURE__*/ -function (_BaseError) { +let OptimisticLockError = /*#__PURE__*/function (_BaseError) { _inherits(OptimisticLockError, _BaseError); + var _super = _createSuper(OptimisticLockError); + function OptimisticLockError(options) { var _this; @@ -30,7 +34,7 @@ function (_BaseError) { options = options || {}; options.message = options.message || `Attempting to update a stale model instance: ${options.modelName}`; - _this = _possibleConstructorReturn(this, _getPrototypeOf(OptimisticLockError).call(this, options.message)); + _this = _super.call(this, options.message); _this.name = 'SequelizeOptimisticLockError'; /** * The name of the model on which the update was attempted @@ -58,4 +62,4 @@ function (_BaseError) { }(BaseError); module.exports = OptimisticLockError; -//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uL2xpYi9lcnJvcnMvb3B0aW1pc3RpYy1sb2NrLWVycm9yLmpzIl0sIm5hbWVzIjpbIkJhc2VFcnJvciIsInJlcXVpcmUiLCJPcHRpbWlzdGljTG9ja0Vycm9yIiwib3B0aW9ucyIsIm1lc3NhZ2UiLCJtb2RlbE5hbWUiLCJuYW1lIiwidmFsdWVzIiwid2hlcmUiLCJFcnJvciIsImNhcHR1cmVTdGFja1RyYWNlIiwiY29uc3RydWN0b3IiLCJtb2R1bGUiLCJleHBvcnRzIl0sIm1hcHBpbmdzIjoiQUFBQTs7Ozs7Ozs7Ozs7Ozs7QUFFQSxNQUFNQSxTQUFTLEdBQUdDLE9BQU8sQ0FBQyxjQUFELENBQXpCO0FBRUE7Ozs7O0lBR01DLG1COzs7OztBQUNKLCtCQUFZQyxPQUFaLEVBQXFCO0FBQUE7O0FBQUE7O0FBQ25CQSxJQUFBQSxPQUFPLEdBQUdBLE9BQU8sSUFBSSxFQUFyQjtBQUNBQSxJQUFBQSxPQUFPLENBQUNDLE9BQVIsR0FBa0JELE9BQU8sQ0FBQ0MsT0FBUixJQUFvQixnREFBK0NELE9BQU8sQ0FBQ0UsU0FBVSxFQUF2RztBQUNBLDZGQUFNRixPQUFPLENBQUNDLE9BQWQ7QUFDQSxVQUFLRSxJQUFMLEdBQVksOEJBQVo7QUFDQTs7Ozs7QUFJQSxVQUFLRCxTQUFMLEdBQWlCRixPQUFPLENBQUNFLFNBQXpCO0FBQ0E7Ozs7O0FBSUEsVUFBS0UsTUFBTCxHQUFjSixPQUFPLENBQUNJLE1BQXRCO0FBQ0E7Ozs7O0FBSUEsVUFBS0MsS0FBTCxHQUFhTCxPQUFPLENBQUNLLEtBQXJCO0FBQ0FDLElBQUFBLEtBQUssQ0FBQ0MsaUJBQU4sZ0NBQThCLE1BQUtDLFdBQW5DO0FBcEJtQjtBQXFCcEI7OztFQXRCK0JYLFM7O0FBeUJsQ1ksTUFBTSxDQUFDQyxPQUFQLEdBQWlCWCxtQkFBakIiLCJzb3VyY2VzQ29udGVudCI6WyIndXNlIHN0cmljdCc7XHJcblxyXG5jb25zdCBCYXNlRXJyb3IgPSByZXF1aXJlKCcuL2Jhc2UtZXJyb3InKTtcclxuXHJcbi8qKlxyXG4gKiBUaHJvd24gd2hlbiBhdHRlbXB0aW5nIHRvIHVwZGF0ZSBhIHN0YWxlIG1vZGVsIGluc3RhbmNlXHJcbiAqL1xyXG5jbGFzcyBPcHRpbWlzdGljTG9ja0Vycm9yIGV4dGVuZHMgQmFzZUVycm9yIHtcclxuICBjb25zdHJ1Y3RvcihvcHRpb25zKSB7XHJcbiAgICBvcHRpb25zID0gb3B0aW9ucyB8fCB7fTtcclxuICAgIG9wdGlvbnMubWVzc2FnZSA9IG9wdGlvbnMubWVzc2FnZSB8fCBgQXR0ZW1wdGluZyB0byB1cGRhdGUgYSBzdGFsZSBtb2RlbCBpbnN0YW5jZTogJHtvcHRpb25zLm1vZGVsTmFtZX1gO1xyXG4gICAgc3VwZXIob3B0aW9ucy5tZXNzYWdlKTtcclxuICAgIHRoaXMubmFtZSA9ICdTZXF1ZWxpemVPcHRpbWlzdGljTG9ja0Vycm9yJztcclxuICAgIC8qKlxyXG4gICAgICogVGhlIG5hbWUgb2YgdGhlIG1vZGVsIG9uIHdoaWNoIHRoZSB1cGRhdGUgd2FzIGF0dGVtcHRlZFxyXG4gICAgICogQHR5cGUge3N0cmluZ31cclxuICAgICAqL1xyXG4gICAgdGhpcy5tb2RlbE5hbWUgPSBvcHRpb25zLm1vZGVsTmFtZTtcclxuICAgIC8qKlxyXG4gICAgICogVGhlIHZhbHVlcyBvZiB0aGUgYXR0ZW1wdGVkIHVwZGF0ZVxyXG4gICAgICogQHR5cGUge29iamVjdH1cclxuICAgICAqL1xyXG4gICAgdGhpcy52YWx1ZXMgPSBvcHRpb25zLnZhbHVlcztcclxuICAgIC8qKlxyXG4gICAgICpcclxuICAgICAqIEB0eXBlIHtvYmplY3R9XHJcbiAgICAgKi9cclxuICAgIHRoaXMud2hlcmUgPSBvcHRpb25zLndoZXJlO1xyXG4gICAgRXJyb3IuY2FwdHVyZVN0YWNrVHJhY2UodGhpcywgdGhpcy5jb25zdHJ1Y3Rvcik7XHJcbiAgfVxyXG59XHJcblxyXG5tb2R1bGUuZXhwb3J0cyA9IE9wdGltaXN0aWNMb2NrRXJyb3I7XHJcbiJdfQ== \ No newline at end of file +//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uL2xpYi9lcnJvcnMvb3B0aW1pc3RpYy1sb2NrLWVycm9yLmpzIl0sIm5hbWVzIjpbIkJhc2VFcnJvciIsInJlcXVpcmUiLCJPcHRpbWlzdGljTG9ja0Vycm9yIiwib3B0aW9ucyIsIm1lc3NhZ2UiLCJtb2RlbE5hbWUiLCJuYW1lIiwidmFsdWVzIiwid2hlcmUiLCJFcnJvciIsImNhcHR1cmVTdGFja1RyYWNlIiwiY29uc3RydWN0b3IiLCJtb2R1bGUiLCJleHBvcnRzIl0sIm1hcHBpbmdzIjoiQUFBQTs7Ozs7Ozs7Ozs7Ozs7Ozs7O0FBRUEsTUFBTUEsU0FBUyxHQUFHQyxPQUFPLENBQUMsY0FBRCxDQUF6QjtBQUVBO0FBQ0E7QUFDQTs7O0lBQ01DLG1COzs7OztBQUNKLCtCQUFZQyxPQUFaLEVBQXFCO0FBQUE7O0FBQUE7O0FBQ25CQSxJQUFBQSxPQUFPLEdBQUdBLE9BQU8sSUFBSSxFQUFyQjtBQUNBQSxJQUFBQSxPQUFPLENBQUNDLE9BQVIsR0FBa0JELE9BQU8sQ0FBQ0MsT0FBUixJQUFvQixnREFBK0NELE9BQU8sQ0FBQ0UsU0FBVSxFQUF2RztBQUNBLDhCQUFNRixPQUFPLENBQUNDLE9BQWQ7QUFDQSxVQUFLRSxJQUFMLEdBQVksOEJBQVo7QUFDQTtBQUNKO0FBQ0E7QUFDQTs7QUFDSSxVQUFLRCxTQUFMLEdBQWlCRixPQUFPLENBQUNFLFNBQXpCO0FBQ0E7QUFDSjtBQUNBO0FBQ0E7O0FBQ0ksVUFBS0UsTUFBTCxHQUFjSixPQUFPLENBQUNJLE1BQXRCO0FBQ0E7QUFDSjtBQUNBO0FBQ0E7O0FBQ0ksVUFBS0MsS0FBTCxHQUFhTCxPQUFPLENBQUNLLEtBQXJCO0FBQ0FDLElBQUFBLEtBQUssQ0FBQ0MsaUJBQU4sZ0NBQThCLE1BQUtDLFdBQW5DO0FBcEJtQjtBQXFCcEI7OztFQXRCK0JYLFM7O0FBeUJsQ1ksTUFBTSxDQUFDQyxPQUFQLEdBQWlCWCxtQkFBakIiLCJzb3VyY2VzQ29udGVudCI6WyIndXNlIHN0cmljdCc7XG5cbmNvbnN0IEJhc2VFcnJvciA9IHJlcXVpcmUoJy4vYmFzZS1lcnJvcicpO1xuXG4vKipcbiAqIFRocm93biB3aGVuIGF0dGVtcHRpbmcgdG8gdXBkYXRlIGEgc3RhbGUgbW9kZWwgaW5zdGFuY2VcbiAqL1xuY2xhc3MgT3B0aW1pc3RpY0xvY2tFcnJvciBleHRlbmRzIEJhc2VFcnJvciB7XG4gIGNvbnN0cnVjdG9yKG9wdGlvbnMpIHtcbiAgICBvcHRpb25zID0gb3B0aW9ucyB8fCB7fTtcbiAgICBvcHRpb25zLm1lc3NhZ2UgPSBvcHRpb25zLm1lc3NhZ2UgfHwgYEF0dGVtcHRpbmcgdG8gdXBkYXRlIGEgc3RhbGUgbW9kZWwgaW5zdGFuY2U6ICR7b3B0aW9ucy5tb2RlbE5hbWV9YDtcbiAgICBzdXBlcihvcHRpb25zLm1lc3NhZ2UpO1xuICAgIHRoaXMubmFtZSA9ICdTZXF1ZWxpemVPcHRpbWlzdGljTG9ja0Vycm9yJztcbiAgICAvKipcbiAgICAgKiBUaGUgbmFtZSBvZiB0aGUgbW9kZWwgb24gd2hpY2ggdGhlIHVwZGF0ZSB3YXMgYXR0ZW1wdGVkXG4gICAgICogQHR5cGUge3N0cmluZ31cbiAgICAgKi9cbiAgICB0aGlzLm1vZGVsTmFtZSA9IG9wdGlvbnMubW9kZWxOYW1lO1xuICAgIC8qKlxuICAgICAqIFRoZSB2YWx1ZXMgb2YgdGhlIGF0dGVtcHRlZCB1cGRhdGVcbiAgICAgKiBAdHlwZSB7b2JqZWN0fVxuICAgICAqL1xuICAgIHRoaXMudmFsdWVzID0gb3B0aW9ucy52YWx1ZXM7XG4gICAgLyoqXG4gICAgICpcbiAgICAgKiBAdHlwZSB7b2JqZWN0fVxuICAgICAqL1xuICAgIHRoaXMud2hlcmUgPSBvcHRpb25zLndoZXJlO1xuICAgIEVycm9yLmNhcHR1cmVTdGFja1RyYWNlKHRoaXMsIHRoaXMuY29uc3RydWN0b3IpO1xuICB9XG59XG5cbm1vZHVsZS5leHBvcnRzID0gT3B0aW1pc3RpY0xvY2tFcnJvcjtcbiJdfQ== \ No newline at end of file diff --git a/dist/errors/query-error.js b/dist/errors/query-error.js index 98bfcea..1f80913 100644 --- a/dist/errors/query-error.js +++ b/dist/errors/query-error.js @@ -2,15 +2,19 @@ function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } } -function _possibleConstructorReturn(self, call) { if (call && (typeof call === "object" || typeof call === "function")) { return call; } return _assertThisInitialized(self); } +function _inherits(subClass, superClass) { if (typeof superClass !== "function" && superClass !== null) { throw new TypeError("Super expression must either be null or a function"); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, writable: true, configurable: true } }); if (superClass) _setPrototypeOf(subClass, superClass); } -function _getPrototypeOf(o) { _getPrototypeOf = Object.setPrototypeOf ? Object.getPrototypeOf : function _getPrototypeOf(o) { return o.__proto__ || Object.getPrototypeOf(o); }; return _getPrototypeOf(o); } +function _setPrototypeOf(o, p) { _setPrototypeOf = Object.setPrototypeOf || function _setPrototypeOf(o, p) { o.__proto__ = p; return o; }; return _setPrototypeOf(o, p); } + +function _createSuper(Derived) { var hasNativeReflectConstruct = _isNativeReflectConstruct(); return function _createSuperInternal() { var Super = _getPrototypeOf(Derived), result; if (hasNativeReflectConstruct) { var NewTarget = _getPrototypeOf(this).constructor; result = Reflect.construct(Super, arguments, NewTarget); } else { result = Super.apply(this, arguments); } return _possibleConstructorReturn(this, result); }; } + +function _possibleConstructorReturn(self, call) { if (call && (typeof call === "object" || typeof call === "function")) { return call; } return _assertThisInitialized(self); } function _assertThisInitialized(self) { if (self === void 0) { throw new ReferenceError("this hasn't been initialised - super() hasn't been called"); } return self; } -function _inherits(subClass, superClass) { if (typeof superClass !== "function" && superClass !== null) { throw new TypeError("Super expression must either be null or a function"); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, writable: true, configurable: true } }); if (superClass) _setPrototypeOf(subClass, superClass); } +function _isNativeReflectConstruct() { if (typeof Reflect === "undefined" || !Reflect.construct) return false; if (Reflect.construct.sham) return false; if (typeof Proxy === "function") return true; try { Date.prototype.toString.call(Reflect.construct(Date, [], function () {})); return true; } catch (e) { return false; } } -function _setPrototypeOf(o, p) { _setPrototypeOf = Object.setPrototypeOf || function _setPrototypeOf(o, p) { o.__proto__ = p; return o; }; return _setPrototypeOf(o, p); } +function _getPrototypeOf(o) { _getPrototypeOf = Object.setPrototypeOf ? Object.getPrototypeOf : function _getPrototypeOf(o) { return o.__proto__ || Object.getPrototypeOf(o); }; return _getPrototypeOf(o); } const BaseError = require('./base-error'); /** @@ -18,17 +22,17 @@ const BaseError = require('./base-error'); */ -let QueryError = -/*#__PURE__*/ -function (_BaseError) { +let QueryError = /*#__PURE__*/function (_BaseError) { _inherits(QueryError, _BaseError); + var _super = _createSuper(QueryError); + function QueryError(message) { var _this; _classCallCheck(this, QueryError); - _this = _possibleConstructorReturn(this, _getPrototypeOf(QueryError).call(this, message)); + _this = _super.call(this, message); _this.name = 'SequelizeQueryError'; Error.captureStackTrace(_assertThisInitialized(_this), _this.constructor); return _this; @@ -38,4 +42,4 @@ function (_BaseError) { }(BaseError); module.exports = QueryError; -//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uL2xpYi9lcnJvcnMvcXVlcnktZXJyb3IuanMiXSwibmFtZXMiOlsiQmFzZUVycm9yIiwicmVxdWlyZSIsIlF1ZXJ5RXJyb3IiLCJtZXNzYWdlIiwibmFtZSIsIkVycm9yIiwiY2FwdHVyZVN0YWNrVHJhY2UiLCJjb25zdHJ1Y3RvciIsIm1vZHVsZSIsImV4cG9ydHMiXSwibWFwcGluZ3MiOiJBQUFBOzs7Ozs7Ozs7Ozs7OztBQUVBLE1BQU1BLFNBQVMsR0FBR0MsT0FBTyxDQUFDLGNBQUQsQ0FBekI7QUFFQTs7Ozs7SUFHTUMsVTs7Ozs7QUFDSixzQkFBWUMsT0FBWixFQUFxQjtBQUFBOztBQUFBOztBQUNuQixvRkFBTUEsT0FBTjtBQUNBLFVBQUtDLElBQUwsR0FBWSxxQkFBWjtBQUNBQyxJQUFBQSxLQUFLLENBQUNDLGlCQUFOLGdDQUE4QixNQUFLQyxXQUFuQztBQUhtQjtBQUlwQjs7O0VBTHNCUCxTOztBQVF6QlEsTUFBTSxDQUFDQyxPQUFQLEdBQWlCUCxVQUFqQiIsInNvdXJjZXNDb250ZW50IjpbIid1c2Ugc3RyaWN0JztcclxuXHJcbmNvbnN0IEJhc2VFcnJvciA9IHJlcXVpcmUoJy4vYmFzZS1lcnJvcicpO1xyXG5cclxuLyoqXHJcbiAqIFRocm93biB3aGVuIGEgcXVlcnkgaXMgcGFzc2VkIGludmFsaWQgb3B0aW9ucyAoc2VlIG1lc3NhZ2UgZm9yIGRldGFpbHMpXHJcbiAqL1xyXG5jbGFzcyBRdWVyeUVycm9yIGV4dGVuZHMgQmFzZUVycm9yIHtcclxuICBjb25zdHJ1Y3RvcihtZXNzYWdlKSB7XHJcbiAgICBzdXBlcihtZXNzYWdlKTtcclxuICAgIHRoaXMubmFtZSA9ICdTZXF1ZWxpemVRdWVyeUVycm9yJztcclxuICAgIEVycm9yLmNhcHR1cmVTdGFja1RyYWNlKHRoaXMsIHRoaXMuY29uc3RydWN0b3IpO1xyXG4gIH1cclxufVxyXG5cclxubW9kdWxlLmV4cG9ydHMgPSBRdWVyeUVycm9yO1xyXG4iXX0= \ No newline at end of file +//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uL2xpYi9lcnJvcnMvcXVlcnktZXJyb3IuanMiXSwibmFtZXMiOlsiQmFzZUVycm9yIiwicmVxdWlyZSIsIlF1ZXJ5RXJyb3IiLCJtZXNzYWdlIiwibmFtZSIsIkVycm9yIiwiY2FwdHVyZVN0YWNrVHJhY2UiLCJjb25zdHJ1Y3RvciIsIm1vZHVsZSIsImV4cG9ydHMiXSwibWFwcGluZ3MiOiJBQUFBOzs7Ozs7Ozs7Ozs7Ozs7Ozs7QUFFQSxNQUFNQSxTQUFTLEdBQUdDLE9BQU8sQ0FBQyxjQUFELENBQXpCO0FBRUE7QUFDQTtBQUNBOzs7SUFDTUMsVTs7Ozs7QUFDSixzQkFBWUMsT0FBWixFQUFxQjtBQUFBOztBQUFBOztBQUNuQiw4QkFBTUEsT0FBTjtBQUNBLFVBQUtDLElBQUwsR0FBWSxxQkFBWjtBQUNBQyxJQUFBQSxLQUFLLENBQUNDLGlCQUFOLGdDQUE4QixNQUFLQyxXQUFuQztBQUhtQjtBQUlwQjs7O0VBTHNCUCxTOztBQVF6QlEsTUFBTSxDQUFDQyxPQUFQLEdBQWlCUCxVQUFqQiIsInNvdXJjZXNDb250ZW50IjpbIid1c2Ugc3RyaWN0JztcblxuY29uc3QgQmFzZUVycm9yID0gcmVxdWlyZSgnLi9iYXNlLWVycm9yJyk7XG5cbi8qKlxuICogVGhyb3duIHdoZW4gYSBxdWVyeSBpcyBwYXNzZWQgaW52YWxpZCBvcHRpb25zIChzZWUgbWVzc2FnZSBmb3IgZGV0YWlscylcbiAqL1xuY2xhc3MgUXVlcnlFcnJvciBleHRlbmRzIEJhc2VFcnJvciB7XG4gIGNvbnN0cnVjdG9yKG1lc3NhZ2UpIHtcbiAgICBzdXBlcihtZXNzYWdlKTtcbiAgICB0aGlzLm5hbWUgPSAnU2VxdWVsaXplUXVlcnlFcnJvcic7XG4gICAgRXJyb3IuY2FwdHVyZVN0YWNrVHJhY2UodGhpcywgdGhpcy5jb25zdHJ1Y3Rvcik7XG4gIH1cbn1cblxubW9kdWxlLmV4cG9ydHMgPSBRdWVyeUVycm9yO1xuIl19 \ No newline at end of file diff --git a/dist/errors/sequelize-scope-error.js b/dist/errors/sequelize-scope-error.js index 7772803..1753f54 100644 --- a/dist/errors/sequelize-scope-error.js +++ b/dist/errors/sequelize-scope-error.js @@ -2,15 +2,19 @@ function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } } -function _possibleConstructorReturn(self, call) { if (call && (typeof call === "object" || typeof call === "function")) { return call; } return _assertThisInitialized(self); } +function _inherits(subClass, superClass) { if (typeof superClass !== "function" && superClass !== null) { throw new TypeError("Super expression must either be null or a function"); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, writable: true, configurable: true } }); if (superClass) _setPrototypeOf(subClass, superClass); } -function _getPrototypeOf(o) { _getPrototypeOf = Object.setPrototypeOf ? Object.getPrototypeOf : function _getPrototypeOf(o) { return o.__proto__ || Object.getPrototypeOf(o); }; return _getPrototypeOf(o); } +function _setPrototypeOf(o, p) { _setPrototypeOf = Object.setPrototypeOf || function _setPrototypeOf(o, p) { o.__proto__ = p; return o; }; return _setPrototypeOf(o, p); } + +function _createSuper(Derived) { var hasNativeReflectConstruct = _isNativeReflectConstruct(); return function _createSuperInternal() { var Super = _getPrototypeOf(Derived), result; if (hasNativeReflectConstruct) { var NewTarget = _getPrototypeOf(this).constructor; result = Reflect.construct(Super, arguments, NewTarget); } else { result = Super.apply(this, arguments); } return _possibleConstructorReturn(this, result); }; } + +function _possibleConstructorReturn(self, call) { if (call && (typeof call === "object" || typeof call === "function")) { return call; } return _assertThisInitialized(self); } function _assertThisInitialized(self) { if (self === void 0) { throw new ReferenceError("this hasn't been initialised - super() hasn't been called"); } return self; } -function _inherits(subClass, superClass) { if (typeof superClass !== "function" && superClass !== null) { throw new TypeError("Super expression must either be null or a function"); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, writable: true, configurable: true } }); if (superClass) _setPrototypeOf(subClass, superClass); } +function _isNativeReflectConstruct() { if (typeof Reflect === "undefined" || !Reflect.construct) return false; if (Reflect.construct.sham) return false; if (typeof Proxy === "function") return true; try { Date.prototype.toString.call(Reflect.construct(Date, [], function () {})); return true; } catch (e) { return false; } } -function _setPrototypeOf(o, p) { _setPrototypeOf = Object.setPrototypeOf || function _setPrototypeOf(o, p) { o.__proto__ = p; return o; }; return _setPrototypeOf(o, p); } +function _getPrototypeOf(o) { _getPrototypeOf = Object.setPrototypeOf ? Object.getPrototypeOf : function _getPrototypeOf(o) { return o.__proto__ || Object.getPrototypeOf(o); }; return _getPrototypeOf(o); } const BaseError = require('./base-error'); /** @@ -18,17 +22,17 @@ const BaseError = require('./base-error'); */ -let SequelizeScopeError = -/*#__PURE__*/ -function (_BaseError) { +let SequelizeScopeError = /*#__PURE__*/function (_BaseError) { _inherits(SequelizeScopeError, _BaseError); + var _super = _createSuper(SequelizeScopeError); + function SequelizeScopeError(parent) { var _this; _classCallCheck(this, SequelizeScopeError); - _this = _possibleConstructorReturn(this, _getPrototypeOf(SequelizeScopeError).call(this, parent)); + _this = _super.call(this, parent); _this.name = 'SequelizeScopeError'; Error.captureStackTrace(_assertThisInitialized(_this), _this.constructor); return _this; @@ -38,4 +42,4 @@ function (_BaseError) { }(BaseError); module.exports = SequelizeScopeError; -//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uL2xpYi9lcnJvcnMvc2VxdWVsaXplLXNjb3BlLWVycm9yLmpzIl0sIm5hbWVzIjpbIkJhc2VFcnJvciIsInJlcXVpcmUiLCJTZXF1ZWxpemVTY29wZUVycm9yIiwicGFyZW50IiwibmFtZSIsIkVycm9yIiwiY2FwdHVyZVN0YWNrVHJhY2UiLCJjb25zdHJ1Y3RvciIsIm1vZHVsZSIsImV4cG9ydHMiXSwibWFwcGluZ3MiOiJBQUFBOzs7Ozs7Ozs7Ozs7OztBQUVBLE1BQU1BLFNBQVMsR0FBR0MsT0FBTyxDQUFDLGNBQUQsQ0FBekI7QUFFQTs7Ozs7SUFHTUMsbUI7Ozs7O0FBQ0osK0JBQVlDLE1BQVosRUFBb0I7QUFBQTs7QUFBQTs7QUFDbEIsNkZBQU1BLE1BQU47QUFDQSxVQUFLQyxJQUFMLEdBQVkscUJBQVo7QUFDQUMsSUFBQUEsS0FBSyxDQUFDQyxpQkFBTixnQ0FBOEIsTUFBS0MsV0FBbkM7QUFIa0I7QUFJbkI7OztFQUwrQlAsUzs7QUFRbENRLE1BQU0sQ0FBQ0MsT0FBUCxHQUFpQlAsbUJBQWpCIiwic291cmNlc0NvbnRlbnQiOlsiJ3VzZSBzdHJpY3QnO1xyXG5cclxuY29uc3QgQmFzZUVycm9yID0gcmVxdWlyZSgnLi9iYXNlLWVycm9yJyk7XHJcblxyXG4vKipcclxuICogU2NvcGUgRXJyb3IuIFRocm93biB3aGVuIHRoZSBzZXF1ZWxpemUgY2Fubm90IHF1ZXJ5IHRoZSBzcGVjaWZpZWQgc2NvcGUuXHJcbiAqL1xyXG5jbGFzcyBTZXF1ZWxpemVTY29wZUVycm9yIGV4dGVuZHMgQmFzZUVycm9yIHtcclxuICBjb25zdHJ1Y3RvcihwYXJlbnQpIHtcclxuICAgIHN1cGVyKHBhcmVudCk7XHJcbiAgICB0aGlzLm5hbWUgPSAnU2VxdWVsaXplU2NvcGVFcnJvcic7XHJcbiAgICBFcnJvci5jYXB0dXJlU3RhY2tUcmFjZSh0aGlzLCB0aGlzLmNvbnN0cnVjdG9yKTtcclxuICB9XHJcbn1cclxuXHJcbm1vZHVsZS5leHBvcnRzID0gU2VxdWVsaXplU2NvcGVFcnJvcjtcclxuIl19 \ No newline at end of file +//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uL2xpYi9lcnJvcnMvc2VxdWVsaXplLXNjb3BlLWVycm9yLmpzIl0sIm5hbWVzIjpbIkJhc2VFcnJvciIsInJlcXVpcmUiLCJTZXF1ZWxpemVTY29wZUVycm9yIiwicGFyZW50IiwibmFtZSIsIkVycm9yIiwiY2FwdHVyZVN0YWNrVHJhY2UiLCJjb25zdHJ1Y3RvciIsIm1vZHVsZSIsImV4cG9ydHMiXSwibWFwcGluZ3MiOiJBQUFBOzs7Ozs7Ozs7Ozs7Ozs7Ozs7QUFFQSxNQUFNQSxTQUFTLEdBQUdDLE9BQU8sQ0FBQyxjQUFELENBQXpCO0FBRUE7QUFDQTtBQUNBOzs7SUFDTUMsbUI7Ozs7O0FBQ0osK0JBQVlDLE1BQVosRUFBb0I7QUFBQTs7QUFBQTs7QUFDbEIsOEJBQU1BLE1BQU47QUFDQSxVQUFLQyxJQUFMLEdBQVkscUJBQVo7QUFDQUMsSUFBQUEsS0FBSyxDQUFDQyxpQkFBTixnQ0FBOEIsTUFBS0MsV0FBbkM7QUFIa0I7QUFJbkI7OztFQUwrQlAsUzs7QUFRbENRLE1BQU0sQ0FBQ0MsT0FBUCxHQUFpQlAsbUJBQWpCIiwic291cmNlc0NvbnRlbnQiOlsiJ3VzZSBzdHJpY3QnO1xuXG5jb25zdCBCYXNlRXJyb3IgPSByZXF1aXJlKCcuL2Jhc2UtZXJyb3InKTtcblxuLyoqXG4gKiBTY29wZSBFcnJvci4gVGhyb3duIHdoZW4gdGhlIHNlcXVlbGl6ZSBjYW5ub3QgcXVlcnkgdGhlIHNwZWNpZmllZCBzY29wZS5cbiAqL1xuY2xhc3MgU2VxdWVsaXplU2NvcGVFcnJvciBleHRlbmRzIEJhc2VFcnJvciB7XG4gIGNvbnN0cnVjdG9yKHBhcmVudCkge1xuICAgIHN1cGVyKHBhcmVudCk7XG4gICAgdGhpcy5uYW1lID0gJ1NlcXVlbGl6ZVNjb3BlRXJyb3InO1xuICAgIEVycm9yLmNhcHR1cmVTdGFja1RyYWNlKHRoaXMsIHRoaXMuY29uc3RydWN0b3IpO1xuICB9XG59XG5cbm1vZHVsZS5leHBvcnRzID0gU2VxdWVsaXplU2NvcGVFcnJvcjtcbiJdfQ== \ No newline at end of file diff --git a/dist/errors/validation-error.js b/dist/errors/validation-error.js index 8668853..952dab8 100644 --- a/dist/errors/validation-error.js +++ b/dist/errors/validation-error.js @@ -6,15 +6,19 @@ function _defineProperties(target, props) { for (var i = 0; i < props.length; i+ function _createClass(Constructor, protoProps, staticProps) { if (protoProps) _defineProperties(Constructor.prototype, protoProps); if (staticProps) _defineProperties(Constructor, staticProps); return Constructor; } -function _possibleConstructorReturn(self, call) { if (call && (typeof call === "object" || typeof call === "function")) { return call; } return _assertThisInitialized(self); } +function _inherits(subClass, superClass) { if (typeof superClass !== "function" && superClass !== null) { throw new TypeError("Super expression must either be null or a function"); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, writable: true, configurable: true } }); if (superClass) _setPrototypeOf(subClass, superClass); } -function _getPrototypeOf(o) { _getPrototypeOf = Object.setPrototypeOf ? Object.getPrototypeOf : function _getPrototypeOf(o) { return o.__proto__ || Object.getPrototypeOf(o); }; return _getPrototypeOf(o); } +function _setPrototypeOf(o, p) { _setPrototypeOf = Object.setPrototypeOf || function _setPrototypeOf(o, p) { o.__proto__ = p; return o; }; return _setPrototypeOf(o, p); } + +function _createSuper(Derived) { var hasNativeReflectConstruct = _isNativeReflectConstruct(); return function _createSuperInternal() { var Super = _getPrototypeOf(Derived), result; if (hasNativeReflectConstruct) { var NewTarget = _getPrototypeOf(this).constructor; result = Reflect.construct(Super, arguments, NewTarget); } else { result = Super.apply(this, arguments); } return _possibleConstructorReturn(this, result); }; } + +function _possibleConstructorReturn(self, call) { if (call && (typeof call === "object" || typeof call === "function")) { return call; } return _assertThisInitialized(self); } function _assertThisInitialized(self) { if (self === void 0) { throw new ReferenceError("this hasn't been initialised - super() hasn't been called"); } return self; } -function _inherits(subClass, superClass) { if (typeof superClass !== "function" && superClass !== null) { throw new TypeError("Super expression must either be null or a function"); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, writable: true, configurable: true } }); if (superClass) _setPrototypeOf(subClass, superClass); } +function _isNativeReflectConstruct() { if (typeof Reflect === "undefined" || !Reflect.construct) return false; if (Reflect.construct.sham) return false; if (typeof Proxy === "function") return true; try { Date.prototype.toString.call(Reflect.construct(Date, [], function () {})); return true; } catch (e) { return false; } } -function _setPrototypeOf(o, p) { _setPrototypeOf = Object.setPrototypeOf || function _setPrototypeOf(o, p) { o.__proto__ = p; return o; }; return _setPrototypeOf(o, p); } +function _getPrototypeOf(o) { _getPrototypeOf = Object.setPrototypeOf ? Object.getPrototypeOf : function _getPrototypeOf(o) { return o.__proto__ || Object.getPrototypeOf(o); }; return _getPrototypeOf(o); } const BaseError = require('./base-error'); /** @@ -28,17 +32,17 @@ const BaseError = require('./base-error'); */ -let ValidationError = -/*#__PURE__*/ -function (_BaseError) { +let ValidationError = /*#__PURE__*/function (_BaseError) { _inherits(ValidationError, _BaseError); + var _super = _createSuper(ValidationError); + function ValidationError(message, errors) { var _this; _classCallCheck(this, ValidationError); - _this = _possibleConstructorReturn(this, _getPrototypeOf(ValidationError).call(this, message)); + _this = _super.call(this, message); _this.name = 'SequelizeValidationError'; _this.message = 'Validation Error'; /** @@ -87,9 +91,7 @@ function (_BaseError) { */ -let ValidationErrorItem = -/*#__PURE__*/ -function () { +let ValidationErrorItem = /*#__PURE__*/function () { /** * Creates new validation error item * @@ -247,4 +249,4 @@ ValidationErrorItem.TypeStringMap = { }; module.exports = ValidationError; module.exports.ValidationErrorItem = ValidationErrorItem; -//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../lib/errors/validation-error.js"],"names":["BaseError","require","ValidationError","message","errors","name","length","map","err","type","origin","join","Error","captureStackTrace","constructor","path","reduce","reduced","error","push","ValidationErrorItem","value","inst","validatorKey","fnName","fnArgs","undefined","instance","validatorName","validatorArgs","Origins","lowercaseType","toLowerCase","trim","realType","TypeStringMap","useTypeAsNS","NSSeparator","useTANS","NSSep","key","useNS","CORE","DB","FUNCTION","module","exports"],"mappings":"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","sourcesContent":["'use strict';\r\n\r\nconst BaseError = require('./base-error');\r\n\r\n/**\r\n * Validation Error. Thrown when the sequelize validation has failed. The error contains an `errors` property,\r\n * which is an array with 1 or more ValidationErrorItems, one for each validation that failed.\r\n *\r\n * @param {string} message Error message\r\n * @param {Array} [errors] Array of ValidationErrorItem objects describing the validation errors\r\n *\r\n * @property errors {ValidationErrorItems[]}\r\n */\r\nclass ValidationError extends BaseError {\r\n  constructor(message, errors) {\r\n    super(message);\r\n    this.name = 'SequelizeValidationError';\r\n    this.message = 'Validation Error';\r\n    /**\r\n     *\r\n     * @type {ValidationErrorItem[]}\r\n     */\r\n    this.errors = errors || [];\r\n\r\n    // Use provided error message if available...\r\n    if (message) {\r\n      this.message = message;\r\n\r\n      // ... otherwise create a concatenated message out of existing errors.\r\n    } else if (this.errors.length > 0 && this.errors[0].message) {\r\n      this.message = this.errors.map(err => `${err.type || err.origin}: ${err.message}`).join(',\\n');\r\n    }\r\n    Error.captureStackTrace(this, this.constructor);\r\n  }\r\n\r\n  /**\r\n   * Gets all validation error items for the path / field specified.\r\n   *\r\n   * @param {string} path The path to be checked for error items\r\n   *\r\n   * @returns {Array<ValidationErrorItem>} Validation error items for the specified path\r\n   */\r\n  get(path) {\r\n    return this.errors.reduce((reduced, error) => {\r\n      if (error.path === path) {\r\n        reduced.push(error);\r\n      }\r\n      return reduced;\r\n    }, []);\r\n  }\r\n}\r\n\r\n/**\r\n * Validation Error Item\r\n * Instances of this class are included in the `ValidationError.errors` property.\r\n */\r\nclass ValidationErrorItem {\r\n  /**\r\n   * Creates new validation error item\r\n   *\r\n   * @param {string} message An error message\r\n   * @param {string} type The type/origin of the validation error\r\n   * @param {string} path The field that triggered the validation error\r\n   * @param {string} value The value that generated the error\r\n   * @param {Object} [inst] the DAO instance that caused the validation error\r\n   * @param {Object} [validatorKey] a validation \"key\", used for identification\r\n   * @param {string} [fnName] property name of the BUILT-IN validator function that caused the validation error (e.g. \"in\" or \"len\"), if applicable\r\n   * @param {string} [fnArgs] parameters used with the BUILT-IN validator function, if applicable\r\n   */\r\n  constructor(message, type, path, value, inst, validatorKey, fnName, fnArgs) {\r\n    /**\r\n     * An error message\r\n     *\r\n     * @type {string} message\r\n     */\r\n    this.message = message || '';\r\n\r\n    /**\r\n     * The type/origin of the validation error\r\n     *\r\n     * @type {string}\r\n     */\r\n    this.type = null;\r\n\r\n    /**\r\n     * The field that triggered the validation error\r\n     *\r\n     * @type {string}\r\n     */\r\n    this.path = path || null;\r\n\r\n    /**\r\n     * The value that generated the error\r\n     *\r\n     * @type {string}\r\n     */\r\n    this.value = value !== undefined ? value : null;\r\n\r\n    this.origin = null;\r\n\r\n    /**\r\n     * The DAO instance that caused the validation error\r\n     *\r\n     * @type {Model}\r\n     */\r\n    this.instance = inst || null;\r\n\r\n    /**\r\n     * A validation \"key\", used for identification\r\n     *\r\n     * @type {string}\r\n     */\r\n    this.validatorKey = validatorKey || null;\r\n\r\n    /**\r\n     * Property name of the BUILT-IN validator function that caused the validation error (e.g. \"in\" or \"len\"), if applicable\r\n     *\r\n     * @type {string}\r\n     */\r\n    this.validatorName = fnName || null;\r\n\r\n    /**\r\n     * Parameters used with the BUILT-IN validator function, if applicable\r\n     *\r\n     * @type {string}\r\n     */\r\n    this.validatorArgs = fnArgs || [];\r\n\r\n    if (type) {\r\n      if (ValidationErrorItem.Origins[ type ]) {\r\n        this.origin = type;\r\n      } else {\r\n        const lowercaseType = `${type}`.toLowerCase().trim();\r\n        const realType = ValidationErrorItem.TypeStringMap[ lowercaseType ];\r\n\r\n        if (realType && ValidationErrorItem.Origins[ realType ]) {\r\n          this.origin = realType;\r\n          this.type = type;\r\n        }\r\n      }\r\n    }\r\n\r\n    // This doesn't need captureStackTrace because it's not a subclass of Error\r\n  }\r\n\r\n  /**\r\n   * return a lowercase, trimmed string \"key\" that identifies the validator.\r\n   *\r\n   * Note: the string will be empty if the instance has neither a valid `validatorKey` property nor a valid `validatorName` property\r\n   *\r\n   * @param   {boolean} [useTypeAsNS=true]      controls whether the returned value is \"namespace\",\r\n   *                                            this parameter is ignored if the validator's `type` is not one of ValidationErrorItem.Origins\r\n   * @param   {string}  [NSSeparator='.']       a separator string for concatenating the namespace, must be not be empty,\r\n   *                                            defaults to \".\" (fullstop). only used and validated if useTypeAsNS is TRUE.\r\n   * @throws  {Error}                           thrown if NSSeparator is found to be invalid.\r\n   * @returns  {string}\r\n   *\r\n   * @private\r\n   */\r\n  getValidatorKey(useTypeAsNS, NSSeparator) {\r\n    const useTANS = useTypeAsNS === undefined || !!useTypeAsNS;\r\n    const NSSep = NSSeparator === undefined ? '.' : NSSeparator;\r\n\r\n    const type = this.origin;\r\n    const key = this.validatorKey || this.validatorName;\r\n    const useNS = useTANS && type && ValidationErrorItem.Origins[ type ];\r\n\r\n    if (useNS && (typeof NSSep !== 'string' || !NSSep.length)) {\r\n      throw new Error('Invalid namespace separator given, must be a non-empty string');\r\n    }\r\n\r\n    if (!(typeof key === 'string' && key.length)) {\r\n      return '';\r\n    }\r\n\r\n    return (useNS ? [type, key].join(NSSep) : key).toLowerCase().trim();\r\n  }\r\n}\r\n\r\n/**\r\n * An enum that defines valid ValidationErrorItem `origin` values\r\n *\r\n * @type {Object}\r\n * @property CORE       {string}  specifies errors that originate from the sequelize \"core\"\r\n * @property DB         {string}  specifies validation errors that originate from the storage engine\r\n * @property FUNCTION   {string}  specifies validation errors that originate from validator functions (both built-in and custom) defined for a given attribute\r\n */\r\nValidationErrorItem.Origins = {\r\n  CORE: 'CORE',\r\n  DB: 'DB',\r\n  FUNCTION: 'FUNCTION'\r\n};\r\n\r\n/**\r\n * An object that is used internally by the `ValidationErrorItem` class\r\n * that maps current `type` strings (as given to ValidationErrorItem.constructor()) to\r\n * our new `origin` values.\r\n *\r\n * @type {Object}\r\n */\r\nValidationErrorItem.TypeStringMap = {\r\n  'notnull violation': 'CORE',\r\n  'string violation': 'CORE',\r\n  'unique violation': 'DB',\r\n  'validation error': 'FUNCTION'\r\n};\r\n\r\nmodule.exports = ValidationError;\r\nmodule.exports.ValidationErrorItem = ValidationErrorItem;\r\n"]} \ No newline at end of file +//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../lib/errors/validation-error.js"],"names":["BaseError","require","ValidationError","message","errors","name","length","map","err","type","origin","join","Error","captureStackTrace","constructor","path","reduce","reduced","error","push","ValidationErrorItem","value","inst","validatorKey","fnName","fnArgs","undefined","instance","validatorName","validatorArgs","Origins","lowercaseType","toLowerCase","trim","realType","TypeStringMap","useTypeAsNS","NSSeparator","useTANS","NSSep","key","useNS","CORE","DB","FUNCTION","module","exports"],"mappings":"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","sourcesContent":["'use strict';\n\nconst BaseError = require('./base-error');\n\n/**\n * Validation Error. Thrown when the sequelize validation has failed. The error contains an `errors` property,\n * which is an array with 1 or more ValidationErrorItems, one for each validation that failed.\n *\n * @param {string} message Error message\n * @param {Array} [errors] Array of ValidationErrorItem objects describing the validation errors\n *\n * @property errors {ValidationErrorItems[]}\n */\nclass ValidationError extends BaseError {\n  constructor(message, errors) {\n    super(message);\n    this.name = 'SequelizeValidationError';\n    this.message = 'Validation Error';\n    /**\n     *\n     * @type {ValidationErrorItem[]}\n     */\n    this.errors = errors || [];\n\n    // Use provided error message if available...\n    if (message) {\n      this.message = message;\n\n      // ... otherwise create a concatenated message out of existing errors.\n    } else if (this.errors.length > 0 && this.errors[0].message) {\n      this.message = this.errors.map(err => `${err.type || err.origin}: ${err.message}`).join(',\\n');\n    }\n    Error.captureStackTrace(this, this.constructor);\n  }\n\n  /**\n   * Gets all validation error items for the path / field specified.\n   *\n   * @param {string} path The path to be checked for error items\n   *\n   * @returns {Array<ValidationErrorItem>} Validation error items for the specified path\n   */\n  get(path) {\n    return this.errors.reduce((reduced, error) => {\n      if (error.path === path) {\n        reduced.push(error);\n      }\n      return reduced;\n    }, []);\n  }\n}\n\n/**\n * Validation Error Item\n * Instances of this class are included in the `ValidationError.errors` property.\n */\nclass ValidationErrorItem {\n  /**\n   * Creates new validation error item\n   *\n   * @param {string} message An error message\n   * @param {string} type The type/origin of the validation error\n   * @param {string} path The field that triggered the validation error\n   * @param {string} value The value that generated the error\n   * @param {Object} [inst] the DAO instance that caused the validation error\n   * @param {Object} [validatorKey] a validation \"key\", used for identification\n   * @param {string} [fnName] property name of the BUILT-IN validator function that caused the validation error (e.g. \"in\" or \"len\"), if applicable\n   * @param {string} [fnArgs] parameters used with the BUILT-IN validator function, if applicable\n   */\n  constructor(message, type, path, value, inst, validatorKey, fnName, fnArgs) {\n    /**\n     * An error message\n     *\n     * @type {string} message\n     */\n    this.message = message || '';\n\n    /**\n     * The type/origin of the validation error\n     *\n     * @type {string}\n     */\n    this.type = null;\n\n    /**\n     * The field that triggered the validation error\n     *\n     * @type {string}\n     */\n    this.path = path || null;\n\n    /**\n     * The value that generated the error\n     *\n     * @type {string}\n     */\n    this.value = value !== undefined ? value : null;\n\n    this.origin = null;\n\n    /**\n     * The DAO instance that caused the validation error\n     *\n     * @type {Model}\n     */\n    this.instance = inst || null;\n\n    /**\n     * A validation \"key\", used for identification\n     *\n     * @type {string}\n     */\n    this.validatorKey = validatorKey || null;\n\n    /**\n     * Property name of the BUILT-IN validator function that caused the validation error (e.g. \"in\" or \"len\"), if applicable\n     *\n     * @type {string}\n     */\n    this.validatorName = fnName || null;\n\n    /**\n     * Parameters used with the BUILT-IN validator function, if applicable\n     *\n     * @type {string}\n     */\n    this.validatorArgs = fnArgs || [];\n\n    if (type) {\n      if (ValidationErrorItem.Origins[ type ]) {\n        this.origin = type;\n      } else {\n        const lowercaseType = `${type}`.toLowerCase().trim();\n        const realType = ValidationErrorItem.TypeStringMap[ lowercaseType ];\n\n        if (realType && ValidationErrorItem.Origins[ realType ]) {\n          this.origin = realType;\n          this.type = type;\n        }\n      }\n    }\n\n    // This doesn't need captureStackTrace because it's not a subclass of Error\n  }\n\n  /**\n   * return a lowercase, trimmed string \"key\" that identifies the validator.\n   *\n   * Note: the string will be empty if the instance has neither a valid `validatorKey` property nor a valid `validatorName` property\n   *\n   * @param   {boolean} [useTypeAsNS=true]      controls whether the returned value is \"namespace\",\n   *                                            this parameter is ignored if the validator's `type` is not one of ValidationErrorItem.Origins\n   * @param   {string}  [NSSeparator='.']       a separator string for concatenating the namespace, must be not be empty,\n   *                                            defaults to \".\" (fullstop). only used and validated if useTypeAsNS is TRUE.\n   * @throws  {Error}                           thrown if NSSeparator is found to be invalid.\n   * @returns  {string}\n   *\n   * @private\n   */\n  getValidatorKey(useTypeAsNS, NSSeparator) {\n    const useTANS = useTypeAsNS === undefined || !!useTypeAsNS;\n    const NSSep = NSSeparator === undefined ? '.' : NSSeparator;\n\n    const type = this.origin;\n    const key = this.validatorKey || this.validatorName;\n    const useNS = useTANS && type && ValidationErrorItem.Origins[ type ];\n\n    if (useNS && (typeof NSSep !== 'string' || !NSSep.length)) {\n      throw new Error('Invalid namespace separator given, must be a non-empty string');\n    }\n\n    if (!(typeof key === 'string' && key.length)) {\n      return '';\n    }\n\n    return (useNS ? [type, key].join(NSSep) : key).toLowerCase().trim();\n  }\n}\n\n/**\n * An enum that defines valid ValidationErrorItem `origin` values\n *\n * @type {Object}\n * @property CORE       {string}  specifies errors that originate from the sequelize \"core\"\n * @property DB         {string}  specifies validation errors that originate from the storage engine\n * @property FUNCTION   {string}  specifies validation errors that originate from validator functions (both built-in and custom) defined for a given attribute\n */\nValidationErrorItem.Origins = {\n  CORE: 'CORE',\n  DB: 'DB',\n  FUNCTION: 'FUNCTION'\n};\n\n/**\n * An object that is used internally by the `ValidationErrorItem` class\n * that maps current `type` strings (as given to ValidationErrorItem.constructor()) to\n * our new `origin` values.\n *\n * @type {Object}\n */\nValidationErrorItem.TypeStringMap = {\n  'notnull violation': 'CORE',\n  'string violation': 'CORE',\n  'unique violation': 'DB',\n  'validation error': 'FUNCTION'\n};\n\nmodule.exports = ValidationError;\nmodule.exports.ValidationErrorItem = ValidationErrorItem;\n"]} \ No newline at end of file diff --git a/dist/errors/validation/unique-constraint-error.js b/dist/errors/validation/unique-constraint-error.js index bd5d058..e17475a 100644 --- a/dist/errors/validation/unique-constraint-error.js +++ b/dist/errors/validation/unique-constraint-error.js @@ -2,15 +2,19 @@ function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } } -function _possibleConstructorReturn(self, call) { if (call && (typeof call === "object" || typeof call === "function")) { return call; } return _assertThisInitialized(self); } +function _inherits(subClass, superClass) { if (typeof superClass !== "function" && superClass !== null) { throw new TypeError("Super expression must either be null or a function"); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, writable: true, configurable: true } }); if (superClass) _setPrototypeOf(subClass, superClass); } -function _getPrototypeOf(o) { _getPrototypeOf = Object.setPrototypeOf ? Object.getPrototypeOf : function _getPrototypeOf(o) { return o.__proto__ || Object.getPrototypeOf(o); }; return _getPrototypeOf(o); } +function _setPrototypeOf(o, p) { _setPrototypeOf = Object.setPrototypeOf || function _setPrototypeOf(o, p) { o.__proto__ = p; return o; }; return _setPrototypeOf(o, p); } + +function _createSuper(Derived) { var hasNativeReflectConstruct = _isNativeReflectConstruct(); return function _createSuperInternal() { var Super = _getPrototypeOf(Derived), result; if (hasNativeReflectConstruct) { var NewTarget = _getPrototypeOf(this).constructor; result = Reflect.construct(Super, arguments, NewTarget); } else { result = Super.apply(this, arguments); } return _possibleConstructorReturn(this, result); }; } + +function _possibleConstructorReturn(self, call) { if (call && (typeof call === "object" || typeof call === "function")) { return call; } return _assertThisInitialized(self); } function _assertThisInitialized(self) { if (self === void 0) { throw new ReferenceError("this hasn't been initialised - super() hasn't been called"); } return self; } -function _inherits(subClass, superClass) { if (typeof superClass !== "function" && superClass !== null) { throw new TypeError("Super expression must either be null or a function"); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, writable: true, configurable: true } }); if (superClass) _setPrototypeOf(subClass, superClass); } +function _isNativeReflectConstruct() { if (typeof Reflect === "undefined" || !Reflect.construct) return false; if (Reflect.construct.sham) return false; if (typeof Proxy === "function") return true; try { Date.prototype.toString.call(Reflect.construct(Date, [], function () {})); return true; } catch (e) { return false; } } -function _setPrototypeOf(o, p) { _setPrototypeOf = Object.setPrototypeOf || function _setPrototypeOf(o, p) { o.__proto__ = p; return o; }; return _setPrototypeOf(o, p); } +function _getPrototypeOf(o) { _getPrototypeOf = Object.setPrototypeOf ? Object.getPrototypeOf : function _getPrototypeOf(o) { return o.__proto__ || Object.getPrototypeOf(o); }; return _getPrototypeOf(o); } const ValidationError = require('./../validation-error'); /** @@ -18,11 +22,11 @@ const ValidationError = require('./../validation-error'); */ -let UniqueConstraintError = -/*#__PURE__*/ -function (_ValidationError) { +let UniqueConstraintError = /*#__PURE__*/function (_ValidationError) { _inherits(UniqueConstraintError, _ValidationError); + var _super = _createSuper(UniqueConstraintError); + function UniqueConstraintError(options) { var _this; @@ -34,7 +38,7 @@ function (_ValidationError) { }; options.message = options.message || options.parent.message || 'Validation Error'; options.errors = options.errors || {}; - _this = _possibleConstructorReturn(this, _getPrototypeOf(UniqueConstraintError).call(this, options.message, options.errors)); + _this = _super.call(this, options.message, options.errors); _this.name = 'SequelizeUniqueConstraintError'; _this.errors = options.errors; _this.fields = options.fields; @@ -49,4 +53,4 @@ function (_ValidationError) { }(ValidationError); module.exports = UniqueConstraintError; -//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uLy4uL2xpYi9lcnJvcnMvdmFsaWRhdGlvbi91bmlxdWUtY29uc3RyYWludC1lcnJvci5qcyJdLCJuYW1lcyI6WyJWYWxpZGF0aW9uRXJyb3IiLCJyZXF1aXJlIiwiVW5pcXVlQ29uc3RyYWludEVycm9yIiwib3B0aW9ucyIsInBhcmVudCIsInNxbCIsIm1lc3NhZ2UiLCJlcnJvcnMiLCJuYW1lIiwiZmllbGRzIiwib3JpZ2luYWwiLCJFcnJvciIsImNhcHR1cmVTdGFja1RyYWNlIiwiY29uc3RydWN0b3IiLCJtb2R1bGUiLCJleHBvcnRzIl0sIm1hcHBpbmdzIjoiQUFBQTs7Ozs7Ozs7Ozs7Ozs7QUFFQSxNQUFNQSxlQUFlLEdBQUdDLE9BQU8sQ0FBQyx1QkFBRCxDQUEvQjtBQUVBOzs7OztJQUdNQyxxQjs7Ozs7QUFDSixpQ0FBWUMsT0FBWixFQUFxQjtBQUFBOztBQUFBOztBQUNuQkEsSUFBQUEsT0FBTyxHQUFHQSxPQUFPLElBQUksRUFBckI7QUFDQUEsSUFBQUEsT0FBTyxDQUFDQyxNQUFSLEdBQWlCRCxPQUFPLENBQUNDLE1BQVIsSUFBa0I7QUFBRUMsTUFBQUEsR0FBRyxFQUFFO0FBQVAsS0FBbkM7QUFDQUYsSUFBQUEsT0FBTyxDQUFDRyxPQUFSLEdBQWtCSCxPQUFPLENBQUNHLE9BQVIsSUFBbUJILE9BQU8sQ0FBQ0MsTUFBUixDQUFlRSxPQUFsQyxJQUE2QyxrQkFBL0Q7QUFDQUgsSUFBQUEsT0FBTyxDQUFDSSxNQUFSLEdBQWlCSixPQUFPLENBQUNJLE1BQVIsSUFBa0IsRUFBbkM7QUFDQSwrRkFBTUosT0FBTyxDQUFDRyxPQUFkLEVBQXVCSCxPQUFPLENBQUNJLE1BQS9CO0FBRUEsVUFBS0MsSUFBTCxHQUFZLGdDQUFaO0FBQ0EsVUFBS0QsTUFBTCxHQUFjSixPQUFPLENBQUNJLE1BQXRCO0FBQ0EsVUFBS0UsTUFBTCxHQUFjTixPQUFPLENBQUNNLE1BQXRCO0FBQ0EsVUFBS0wsTUFBTCxHQUFjRCxPQUFPLENBQUNDLE1BQXRCO0FBQ0EsVUFBS00sUUFBTCxHQUFnQlAsT0FBTyxDQUFDQyxNQUF4QjtBQUNBLFVBQUtDLEdBQUwsR0FBV0YsT0FBTyxDQUFDQyxNQUFSLENBQWVDLEdBQTFCO0FBQ0FNLElBQUFBLEtBQUssQ0FBQ0MsaUJBQU4sZ0NBQThCLE1BQUtDLFdBQW5DO0FBYm1CO0FBY3BCOzs7RUFmaUNiLGU7O0FBa0JwQ2MsTUFBTSxDQUFDQyxPQUFQLEdBQWlCYixxQkFBakIiLCJzb3VyY2VzQ29udGVudCI6WyIndXNlIHN0cmljdCc7XHJcblxyXG5jb25zdCBWYWxpZGF0aW9uRXJyb3IgPSByZXF1aXJlKCcuLy4uL3ZhbGlkYXRpb24tZXJyb3InKTtcclxuXHJcbi8qKlxyXG4gKiBUaHJvd24gd2hlbiBhIHVuaXF1ZSBjb25zdHJhaW50IGlzIHZpb2xhdGVkIGluIHRoZSBkYXRhYmFzZVxyXG4gKi9cclxuY2xhc3MgVW5pcXVlQ29uc3RyYWludEVycm9yIGV4dGVuZHMgVmFsaWRhdGlvbkVycm9yIHtcclxuICBjb25zdHJ1Y3RvcihvcHRpb25zKSB7XHJcbiAgICBvcHRpb25zID0gb3B0aW9ucyB8fCB7fTtcclxuICAgIG9wdGlvbnMucGFyZW50ID0gb3B0aW9ucy5wYXJlbnQgfHwgeyBzcWw6ICcnIH07XHJcbiAgICBvcHRpb25zLm1lc3NhZ2UgPSBvcHRpb25zLm1lc3NhZ2UgfHwgb3B0aW9ucy5wYXJlbnQubWVzc2FnZSB8fCAnVmFsaWRhdGlvbiBFcnJvcic7XHJcbiAgICBvcHRpb25zLmVycm9ycyA9IG9wdGlvbnMuZXJyb3JzIHx8IHt9O1xyXG4gICAgc3VwZXIob3B0aW9ucy5tZXNzYWdlLCBvcHRpb25zLmVycm9ycyk7XHJcblxyXG4gICAgdGhpcy5uYW1lID0gJ1NlcXVlbGl6ZVVuaXF1ZUNvbnN0cmFpbnRFcnJvcic7XHJcbiAgICB0aGlzLmVycm9ycyA9IG9wdGlvbnMuZXJyb3JzO1xyXG4gICAgdGhpcy5maWVsZHMgPSBvcHRpb25zLmZpZWxkcztcclxuICAgIHRoaXMucGFyZW50ID0gb3B0aW9ucy5wYXJlbnQ7XHJcbiAgICB0aGlzLm9yaWdpbmFsID0gb3B0aW9ucy5wYXJlbnQ7XHJcbiAgICB0aGlzLnNxbCA9IG9wdGlvbnMucGFyZW50LnNxbDtcclxuICAgIEVycm9yLmNhcHR1cmVTdGFja1RyYWNlKHRoaXMsIHRoaXMuY29uc3RydWN0b3IpO1xyXG4gIH1cclxufVxyXG5cclxubW9kdWxlLmV4cG9ydHMgPSBVbmlxdWVDb25zdHJhaW50RXJyb3I7XHJcbiJdfQ== \ No newline at end of file +//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uLy4uL2xpYi9lcnJvcnMvdmFsaWRhdGlvbi91bmlxdWUtY29uc3RyYWludC1lcnJvci5qcyJdLCJuYW1lcyI6WyJWYWxpZGF0aW9uRXJyb3IiLCJyZXF1aXJlIiwiVW5pcXVlQ29uc3RyYWludEVycm9yIiwib3B0aW9ucyIsInBhcmVudCIsInNxbCIsIm1lc3NhZ2UiLCJlcnJvcnMiLCJuYW1lIiwiZmllbGRzIiwib3JpZ2luYWwiLCJFcnJvciIsImNhcHR1cmVTdGFja1RyYWNlIiwiY29uc3RydWN0b3IiLCJtb2R1bGUiLCJleHBvcnRzIl0sIm1hcHBpbmdzIjoiQUFBQTs7Ozs7Ozs7Ozs7Ozs7Ozs7O0FBRUEsTUFBTUEsZUFBZSxHQUFHQyxPQUFPLENBQUMsdUJBQUQsQ0FBL0I7QUFFQTtBQUNBO0FBQ0E7OztJQUNNQyxxQjs7Ozs7QUFDSixpQ0FBWUMsT0FBWixFQUFxQjtBQUFBOztBQUFBOztBQUNuQkEsSUFBQUEsT0FBTyxHQUFHQSxPQUFPLElBQUksRUFBckI7QUFDQUEsSUFBQUEsT0FBTyxDQUFDQyxNQUFSLEdBQWlCRCxPQUFPLENBQUNDLE1BQVIsSUFBa0I7QUFBRUMsTUFBQUEsR0FBRyxFQUFFO0FBQVAsS0FBbkM7QUFDQUYsSUFBQUEsT0FBTyxDQUFDRyxPQUFSLEdBQWtCSCxPQUFPLENBQUNHLE9BQVIsSUFBbUJILE9BQU8sQ0FBQ0MsTUFBUixDQUFlRSxPQUFsQyxJQUE2QyxrQkFBL0Q7QUFDQUgsSUFBQUEsT0FBTyxDQUFDSSxNQUFSLEdBQWlCSixPQUFPLENBQUNJLE1BQVIsSUFBa0IsRUFBbkM7QUFDQSw4QkFBTUosT0FBTyxDQUFDRyxPQUFkLEVBQXVCSCxPQUFPLENBQUNJLE1BQS9CO0FBRUEsVUFBS0MsSUFBTCxHQUFZLGdDQUFaO0FBQ0EsVUFBS0QsTUFBTCxHQUFjSixPQUFPLENBQUNJLE1BQXRCO0FBQ0EsVUFBS0UsTUFBTCxHQUFjTixPQUFPLENBQUNNLE1BQXRCO0FBQ0EsVUFBS0wsTUFBTCxHQUFjRCxPQUFPLENBQUNDLE1BQXRCO0FBQ0EsVUFBS00sUUFBTCxHQUFnQlAsT0FBTyxDQUFDQyxNQUF4QjtBQUNBLFVBQUtDLEdBQUwsR0FBV0YsT0FBTyxDQUFDQyxNQUFSLENBQWVDLEdBQTFCO0FBQ0FNLElBQUFBLEtBQUssQ0FBQ0MsaUJBQU4sZ0NBQThCLE1BQUtDLFdBQW5DO0FBYm1CO0FBY3BCOzs7RUFmaUNiLGU7O0FBa0JwQ2MsTUFBTSxDQUFDQyxPQUFQLEdBQWlCYixxQkFBakIiLCJzb3VyY2VzQ29udGVudCI6WyIndXNlIHN0cmljdCc7XG5cbmNvbnN0IFZhbGlkYXRpb25FcnJvciA9IHJlcXVpcmUoJy4vLi4vdmFsaWRhdGlvbi1lcnJvcicpO1xuXG4vKipcbiAqIFRocm93biB3aGVuIGEgdW5pcXVlIGNvbnN0cmFpbnQgaXMgdmlvbGF0ZWQgaW4gdGhlIGRhdGFiYXNlXG4gKi9cbmNsYXNzIFVuaXF1ZUNvbnN0cmFpbnRFcnJvciBleHRlbmRzIFZhbGlkYXRpb25FcnJvciB7XG4gIGNvbnN0cnVjdG9yKG9wdGlvbnMpIHtcbiAgICBvcHRpb25zID0gb3B0aW9ucyB8fCB7fTtcbiAgICBvcHRpb25zLnBhcmVudCA9IG9wdGlvbnMucGFyZW50IHx8IHsgc3FsOiAnJyB9O1xuICAgIG9wdGlvbnMubWVzc2FnZSA9IG9wdGlvbnMubWVzc2FnZSB8fCBvcHRpb25zLnBhcmVudC5tZXNzYWdlIHx8ICdWYWxpZGF0aW9uIEVycm9yJztcbiAgICBvcHRpb25zLmVycm9ycyA9IG9wdGlvbnMuZXJyb3JzIHx8IHt9O1xuICAgIHN1cGVyKG9wdGlvbnMubWVzc2FnZSwgb3B0aW9ucy5lcnJvcnMpO1xuXG4gICAgdGhpcy5uYW1lID0gJ1NlcXVlbGl6ZVVuaXF1ZUNvbnN0cmFpbnRFcnJvcic7XG4gICAgdGhpcy5lcnJvcnMgPSBvcHRpb25zLmVycm9ycztcbiAgICB0aGlzLmZpZWxkcyA9IG9wdGlvbnMuZmllbGRzO1xuICAgIHRoaXMucGFyZW50ID0gb3B0aW9ucy5wYXJlbnQ7XG4gICAgdGhpcy5vcmlnaW5hbCA9IG9wdGlvbnMucGFyZW50O1xuICAgIHRoaXMuc3FsID0gb3B0aW9ucy5wYXJlbnQuc3FsO1xuICAgIEVycm9yLmNhcHR1cmVTdGFja1RyYWNlKHRoaXMsIHRoaXMuY29uc3RydWN0b3IpO1xuICB9XG59XG5cbm1vZHVsZS5leHBvcnRzID0gVW5pcXVlQ29uc3RyYWludEVycm9yO1xuIl19 \ No newline at end of file diff --git a/dist/hooks.js b/dist/hooks.js index 5275748..a8b52e5 100644 --- a/dist/hooks.js +++ b/dist/hooks.js @@ -662,4 +662,4 @@ exports.applyTo = applyTo; * @name afterBulkSync * @memberof Sequelize */ -//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../lib/hooks.js"],"names":["_","require","logger","Promise","debug","debugContext","hookTypes","beforeValidate","params","afterValidate","validationFailed","beforeCreate","afterCreate","beforeDestroy","afterDestroy","beforeRestore","afterRestore","beforeUpdate","afterUpdate","beforeSave","proxies","afterSave","beforeUpsert","afterUpsert","beforeBulkCreate","afterBulkCreate","beforeBulkDestroy","afterBulkDestroy","beforeBulkRestore","afterBulkRestore","beforeBulkUpdate","afterBulkUpdate","beforeFind","beforeFindAfterExpandIncludeAll","beforeFindAfterOptions","afterFind","beforeCount","beforeDefine","sync","noModel","afterDefine","beforeInit","afterInit","beforeAssociate","afterAssociate","beforeConnect","afterConnect","beforeDisconnect","afterDisconnect","beforeSync","afterSync","beforeBulkSync","afterBulkSync","beforeQuery","afterQuery","exports","hooks","getProxiedHooks","hookType","concat","getHooks","hooked","options","Hooks","_setupHooks","map","hooksArray","hookName","Array","isArray","forEach","hookFn","addHook","runHooks","hookArgs","Error","sequelize","hook","fn","apply","each","return","name","type","push","removeHook","isReference","hasHook","filter","length","hasHooks","applyTo","target","isModel","mixin","Object","keys","callback"],"mappings":"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","sourcesContent":["'use strict';\r\n\r\nconst _ = require('lodash');\r\nconst { logger } = require('./utils/logger');\r\nconst Promise = require('./promise');\r\nconst debug = logger.debugContext('hooks');\r\n\r\nconst hookTypes = {\r\n  beforeValidate: { params: 2 },\r\n  afterValidate: { params: 2 },\r\n  validationFailed: { params: 3 },\r\n  beforeCreate: { params: 2 },\r\n  afterCreate: { params: 2 },\r\n  beforeDestroy: { params: 2 },\r\n  afterDestroy: { params: 2 },\r\n  beforeRestore: { params: 2 },\r\n  afterRestore: { params: 2 },\r\n  beforeUpdate: { params: 2 },\r\n  afterUpdate: { params: 2 },\r\n  beforeSave: { params: 2, proxies: ['beforeUpdate', 'beforeCreate'] },\r\n  afterSave: { params: 2, proxies: ['afterUpdate', 'afterCreate'] },\r\n  beforeUpsert: { params: 2 },\r\n  afterUpsert: { params: 2 },\r\n  beforeBulkCreate: { params: 2 },\r\n  afterBulkCreate: { params: 2 },\r\n  beforeBulkDestroy: { params: 1 },\r\n  afterBulkDestroy: { params: 1 },\r\n  beforeBulkRestore: { params: 1 },\r\n  afterBulkRestore: { params: 1 },\r\n  beforeBulkUpdate: { params: 1 },\r\n  afterBulkUpdate: { params: 1 },\r\n  beforeFind: { params: 1 },\r\n  beforeFindAfterExpandIncludeAll: { params: 1 },\r\n  beforeFindAfterOptions: { params: 1 },\r\n  afterFind: { params: 2 },\r\n  beforeCount: { params: 1 },\r\n  beforeDefine: { params: 2, sync: true, noModel: true },\r\n  afterDefine: { params: 1, sync: true, noModel: true },\r\n  beforeInit: { params: 2, sync: true, noModel: true },\r\n  afterInit: { params: 1, sync: true, noModel: true },\r\n  beforeAssociate: { params: 2, sync: true },\r\n  afterAssociate: { params: 2, sync: true },\r\n  beforeConnect: { params: 1, noModel: true },\r\n  afterConnect: { params: 2, noModel: true },\r\n  beforeDisconnect: { params: 1, noModel: true },\r\n  afterDisconnect: { params: 1, noModel: true },\r\n  beforeSync: { params: 1 },\r\n  afterSync: { params: 1 },\r\n  beforeBulkSync: { params: 1 },\r\n  afterBulkSync: { params: 1 },\r\n  beforeQuery: { params: 2 },\r\n  afterQuery: { params: 2 }\r\n};\r\nexports.hooks = hookTypes;\r\n\r\n\r\n/**\r\n * get array of current hook and its proxies combined\r\n *\r\n * @param {string} hookType any hook type @see {@link hookTypes}\r\n *\r\n * @private\r\n */\r\nconst getProxiedHooks = hookType =>\r\n  hookTypes[hookType].proxies\r\n    ? hookTypes[hookType].proxies.concat(hookType)\r\n    : [hookType]\r\n;\r\n\r\nfunction getHooks(hooked, hookType) {\r\n  return (hooked.options.hooks || {})[hookType] || [];\r\n}\r\n\r\nconst Hooks = {\r\n  /**\r\n   * Process user supplied hooks definition\r\n   *\r\n   * @param {Object} hooks hooks definition\r\n   *\r\n   * @private\r\n   * @memberof Sequelize\r\n   * @memberof Sequelize.Model\r\n   */\r\n  _setupHooks(hooks) {\r\n    this.options.hooks = {};\r\n    _.map(hooks || {}, (hooksArray, hookName) => {\r\n      if (!Array.isArray(hooksArray)) hooksArray = [hooksArray];\r\n      hooksArray.forEach(hookFn => this.addHook(hookName, hookFn));\r\n    });\r\n  },\r\n\r\n  runHooks(hooks, ...hookArgs) {\r\n    if (!hooks) throw new Error('runHooks requires at least 1 argument');\r\n\r\n    let hookType;\r\n\r\n    if (typeof hooks === 'string') {\r\n      hookType = hooks;\r\n      hooks = getHooks(this, hookType);\r\n\r\n      if (this.sequelize) {\r\n        hooks = hooks.concat(getHooks(this.sequelize, hookType));\r\n      }\r\n    }\r\n\r\n    if (!Array.isArray(hooks)) {\r\n      hooks = [hooks];\r\n    }\r\n\r\n    // synchronous hooks\r\n    if (hookTypes[hookType] && hookTypes[hookType].sync) {\r\n      for (let hook of hooks) {\r\n        if (typeof hook === 'object') {\r\n          hook = hook.fn;\r\n        }\r\n\r\n        debug(`running hook(sync) ${hookType}`);\r\n        hook.apply(this, hookArgs);\r\n      }\r\n      return;\r\n    }\r\n\r\n    // asynchronous hooks (default)\r\n    return Promise.each(hooks, hook => {\r\n      if (typeof hook === 'object') {\r\n        hook = hook.fn;\r\n      }\r\n\r\n      debug(`running hook ${hookType}`);\r\n      return hook.apply(this, hookArgs);\r\n    }).return();\r\n  },\r\n\r\n  /**\r\n   * Add a hook to the model\r\n   *\r\n   * @param {string}          hookType hook name @see {@link hookTypes}\r\n   * @param {string|Function} [name] Provide a name for the hook function. It can be used to remove the hook later or to order hooks based on some sort of priority system in the future.\r\n   * @param {Function}        fn The hook function\r\n   *\r\n   * @memberof Sequelize\r\n   * @memberof Sequelize.Model\r\n   */\r\n  addHook(hookType, name, fn) {\r\n    if (typeof name === 'function') {\r\n      fn = name;\r\n      name = null;\r\n    }\r\n\r\n    debug(`adding hook ${hookType}`);\r\n    // check for proxies, add them too\r\n    hookType = getProxiedHooks(hookType);\r\n\r\n    hookType.forEach(type => {\r\n      const hooks = getHooks(this, type);\r\n      hooks.push(name ? { name, fn } : fn);\r\n      this.options.hooks[type] = hooks;\r\n    });\r\n\r\n    return this;\r\n  },\r\n\r\n  /**\r\n   * Remove hook from the model\r\n   *\r\n   * @param {string} hookType @see {@link hookTypes}\r\n   * @param {string|Function} name name of hook or function reference which was attached\r\n   *\r\n   * @memberof Sequelize\r\n   * @memberof Sequelize.Model\r\n   */\r\n  removeHook(hookType, name) {\r\n    const isReference = typeof name === 'function' ? true : false;\r\n\r\n    if (!this.hasHook(hookType)) {\r\n      return this;\r\n    }\r\n\r\n    debug(`removing hook ${hookType}`);\r\n\r\n    // check for proxies, add them too\r\n    hookType = getProxiedHooks(hookType);\r\n\r\n    for (const type of hookType) {\r\n      this.options.hooks[type] = this.options.hooks[type].filter(hook => {\r\n        if (isReference && typeof hook === 'function') {\r\n          return hook !== name; // check if same method\r\n        }\r\n        if (!isReference && typeof hook === 'object') {\r\n          return hook.name !== name;\r\n        }\r\n        return true;\r\n      });\r\n    }\r\n\r\n    return this;\r\n  },\r\n\r\n  /**\r\n   * Check whether the mode has any hooks of this type\r\n   *\r\n   * @param {string} hookType @see {@link hookTypes}\r\n   *\r\n   * @alias hasHooks\r\n   *\r\n   * @memberof Sequelize\r\n   * @memberof Sequelize.Model\r\n   */\r\n  hasHook(hookType) {\r\n    return this.options.hooks[hookType] && !!this.options.hooks[hookType].length;\r\n  }\r\n};\r\nHooks.hasHooks = Hooks.hasHook;\r\n\r\n\r\nfunction applyTo(target, isModel = false) {\r\n  _.mixin(target, Hooks);\r\n\r\n  for (const hook of Object.keys(hookTypes)) {\r\n    if (isModel && hookTypes[hook].noModel) {\r\n      continue;\r\n    }\r\n    target[hook] = function(name, callback) {\r\n      return this.addHook(hook, name, callback);\r\n    };\r\n  }\r\n}\r\nexports.applyTo = applyTo;\r\n\r\n/**\r\n * A hook that is run before validation\r\n * @param {string}   name\r\n * @param {Function} fn   A callback function that is called with instance, options\r\n * @name beforeValidate\r\n * @memberof Sequelize.Model\r\n */\r\n\r\n/**\r\n * A hook that is run after validation\r\n * @param {string}   name\r\n * @param {Function} fn   A callback function that is called with instance, options\r\n * @name afterValidate\r\n * @memberof Sequelize.Model\r\n */\r\n\r\n/**\r\n * A hook that is run when validation fails\r\n * @param {string}   name\r\n * @param {Function} fn   A callback function that is called with instance, options, error. Error is the\r\n * SequelizeValidationError. If the callback throws an error, it will replace the original validation error.\r\n * @name validationFailed\r\n * @memberof Sequelize.Model\r\n */\r\n\r\n/**\r\n * A hook that is run before creating a single instance\r\n * @param {string}   name\r\n * @param {Function} fn   A callback function that is called with attributes, options\r\n * @name beforeCreate\r\n * @memberof Sequelize.Model\r\n */\r\n\r\n/**\r\n * A hook that is run after creating a single instance\r\n * @param {string}   name\r\n * @param {Function} fn   A callback function that is called with attributes, options\r\n * @name afterCreate\r\n * @memberof Sequelize.Model\r\n */\r\n\r\n/**\r\n * A hook that is run before creating or updating a single instance, It proxies `beforeCreate` and `beforeUpdate`\r\n * @param {string}   name\r\n * @param {Function} fn   A callback function that is called with attributes, options\r\n * @name beforeSave\r\n * @memberof Sequelize.Model\r\n */\r\n\r\n/**\r\n * A hook that is run before upserting\r\n * @param {string}   name\r\n * @param {Function} fn   A callback function that is called with attributes, options\r\n * @name beforeUpsert\r\n * @memberof Sequelize.Model\r\n */\r\n\r\n/**\r\n * A hook that is run after upserting\r\n * @param {string}   name\r\n * @param {Function} fn   A callback function that is called with the result of upsert(), options\r\n * @name afterUpsert\r\n * @memberof Sequelize.Model\r\n */\r\n\r\n/**\r\n  * A hook that is run after creating or updating a single instance, It proxies `afterCreate` and `afterUpdate`\r\n  * @param {string}   name\r\n  * @param {Function} fn   A callback function that is called with attributes, options\r\n  * @name afterSave\r\n  * @memberof Sequelize.Model\r\n  */\r\n\r\n/**\r\n * A hook that is run before destroying a single instance\r\n * @param {string}   name\r\n * @param {Function} fn   A callback function that is called with instance, options\r\n *\r\n * @name beforeDestroy\r\n * @memberof Sequelize.Model\r\n */\r\n\r\n/**\r\n * A hook that is run after destroying a single instance\r\n * @param {string}   name\r\n * @param {Function} fn   A callback function that is called with instance, options\r\n *\r\n * @name afterDestroy\r\n * @memberof Sequelize.Model\r\n */\r\n\r\n/**\r\n * A hook that is run before restoring a single instance\r\n * @param {string}   name\r\n * @param {Function} fn   A callback function that is called with instance, options\r\n *\r\n * @name beforeRestore\r\n * @memberof Sequelize.Model\r\n */\r\n\r\n/**\r\n * A hook that is run after restoring a single instance\r\n * @param {string}   name\r\n * @param {Function} fn   A callback function that is called with instance, options\r\n *\r\n * @name afterRestore\r\n * @memberof Sequelize.Model\r\n */\r\n\r\n/**\r\n * A hook that is run before updating a single instance\r\n * @param {string}   name\r\n * @param {Function} fn   A callback function that is called with instance, options\r\n * @name beforeUpdate\r\n * @memberof Sequelize.Model\r\n */\r\n\r\n/**\r\n * A hook that is run after updating a single instance\r\n * @param {string}   name\r\n * @param {Function} fn   A callback function that is called with instance, options\r\n * @name afterUpdate\r\n * @memberof Sequelize.Model\r\n */\r\n\r\n/**\r\n * A hook that is run before creating instances in bulk\r\n * @param {string}   name\r\n * @param {Function} fn   A callback function that is called with instances, options\r\n * @name beforeBulkCreate\r\n * @memberof Sequelize.Model\r\n */\r\n\r\n/**\r\n * A hook that is run after creating instances in bulk\r\n * @param {string}   name\r\n * @param {Function} fn   A callback function that is called with instances, options\r\n * @name afterBulkCreate\r\n * @memberof Sequelize.Model\r\n */\r\n\r\n/**\r\n * A hook that is run before destroying instances in bulk\r\n * @param {string}   name\r\n * @param {Function} fn   A callback function that is called with options\r\n *\r\n * @name beforeBulkDestroy\r\n * @memberof Sequelize.Model\r\n */\r\n\r\n/**\r\n * A hook that is run after destroying instances in bulk\r\n * @param {string}   name\r\n * @param {Function} fn   A callback function that is called with options\r\n *\r\n * @name afterBulkDestroy\r\n * @memberof Sequelize.Model\r\n */\r\n\r\n/**\r\n * A hook that is run before restoring instances in bulk\r\n * @param {string}   name\r\n * @param {Function} fn   A callback function that is called with options\r\n *\r\n * @name beforeBulkRestore\r\n * @memberof Sequelize.Model\r\n */\r\n\r\n/**\r\n * A hook that is run after restoring instances in bulk\r\n * @param {string}   name\r\n * @param {Function} fn   A callback function that is called with options\r\n *\r\n * @name afterBulkRestore\r\n * @memberof Sequelize.Model\r\n */\r\n\r\n/**\r\n * A hook that is run before updating instances in bulk\r\n * @param {string}   name\r\n * @param {Function} fn   A callback function that is called with options\r\n * @name beforeBulkUpdate\r\n * @memberof Sequelize.Model\r\n */\r\n\r\n/**\r\n * A hook that is run after updating instances in bulk\r\n * @param {string}   name\r\n * @param {Function} fn   A callback function that is called with options\r\n * @name afterBulkUpdate\r\n * @memberof Sequelize.Model\r\n */\r\n\r\n/**\r\n * A hook that is run before a find (select) query\r\n * @param {string}   name\r\n * @param {Function} fn   A callback function that is called with options\r\n * @name beforeFind\r\n * @memberof Sequelize.Model\r\n */\r\n\r\n/**\r\n * A hook that is run before a find (select) query, after any { include: {all: ...} } options are expanded\r\n * @param {string}   name\r\n * @param {Function} fn   A callback function that is called with options\r\n * @name beforeFindAfterExpandIncludeAll\r\n * @memberof Sequelize.Model\r\n */\r\n\r\n/**\r\n * A hook that is run before a find (select) query, after all option parsing is complete\r\n * @param {string}   name\r\n * @param {Function} fn   A callback function that is called with options\r\n * @name beforeFindAfterOptions\r\n * @memberof Sequelize.Model\r\n */\r\n\r\n/**\r\n * A hook that is run after a find (select) query\r\n * @param {string}   name\r\n * @param {Function} fn   A callback function that is called with instance(s), options\r\n * @name afterFind\r\n * @memberof Sequelize.Model\r\n */\r\n\r\n/**\r\n * A hook that is run before a count query\r\n * @param {string}   name\r\n * @param {Function} fn   A callback function that is called with options\r\n * @name beforeCount\r\n * @memberof Sequelize.Model\r\n */\r\n\r\n/**\r\n * A hook that is run before a define call\r\n * @param {string}   name\r\n * @param {Function} fn   A callback function that is called with attributes, options\r\n * @name beforeDefine\r\n * @memberof Sequelize\r\n */\r\n\r\n/**\r\n * A hook that is run after a define call\r\n * @param {string}   name\r\n * @param {Function} fn   A callback function that is called with factory\r\n * @name afterDefine\r\n * @memberof Sequelize\r\n */\r\n\r\n/**\r\n * A hook that is run before Sequelize() call\r\n * @param {string}   name\r\n * @param {Function} fn   A callback function that is called with config, options\r\n * @name beforeInit\r\n * @memberof Sequelize\r\n */\r\n\r\n/**\r\n * A hook that is run after Sequelize() call\r\n * @param {string}   name\r\n * @param {Function} fn   A callback function that is called with sequelize\r\n * @name afterInit\r\n * @memberof Sequelize\r\n */\r\n\r\n/**\r\n * A hook that is run before a connection is created\r\n * @param {string}   name\r\n * @param {Function} fn   A callback function that is called with config passed to connection\r\n * @name beforeConnect\r\n * @memberof Sequelize\r\n */\r\n\r\n/**\r\n * A hook that is run after a connection is created\r\n * @param {string}   name\r\n * @param {Function} fn   A callback function that is called with the connection object and the config passed to connection\r\n * @name afterConnect\r\n * @memberof Sequelize\r\n */\r\n\r\n/**\r\n * A hook that is run before a connection is disconnected\r\n * @param {string}   name\r\n * @param {Function} fn   A callback function that is called with the connection object\r\n * @name beforeDisconnect\r\n * @memberof Sequelize\r\n */\r\n\r\n/**\r\n * A hook that is run after a connection is disconnected\r\n * @param {string}   name\r\n * @param {Function} fn   A callback function that is called with the connection object\r\n * @name afterDisconnect\r\n * @memberof Sequelize\r\n */\r\n\r\n/**\r\n * A hook that is run before Model.sync call\r\n * @param {string}   name\r\n * @param {Function} fn   A callback function that is called with options passed to Model.sync\r\n * @name beforeSync\r\n * @memberof Sequelize\r\n */\r\n\r\n/**\r\n * A hook that is run after Model.sync call\r\n * @param {string}   name\r\n * @param {Function} fn   A callback function that is called with options passed to Model.sync\r\n * @name afterSync\r\n * @memberof Sequelize\r\n */\r\n\r\n/**\r\n  * A hook that is run before sequelize.sync call\r\n  * @param {string}   name\r\n  * @param {Function} fn   A callback function that is called with options passed to sequelize.sync\r\n  * @name beforeBulkSync\r\n  * @memberof Sequelize\r\n  */\r\n\r\n/**\r\n  * A hook that is run after sequelize.sync call\r\n  * @param {string}   name\r\n  * @param {Function} fn   A callback function that is called with options passed to sequelize.sync\r\n  * @name afterBulkSync\r\n  * @memberof Sequelize\r\n  */\r\n"]} \ No newline at end of file +//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../lib/hooks.js"],"names":["_","require","logger","Promise","debug","debugContext","hookTypes","beforeValidate","params","afterValidate","validationFailed","beforeCreate","afterCreate","beforeDestroy","afterDestroy","beforeRestore","afterRestore","beforeUpdate","afterUpdate","beforeSave","proxies","afterSave","beforeUpsert","afterUpsert","beforeBulkCreate","afterBulkCreate","beforeBulkDestroy","afterBulkDestroy","beforeBulkRestore","afterBulkRestore","beforeBulkUpdate","afterBulkUpdate","beforeFind","beforeFindAfterExpandIncludeAll","beforeFindAfterOptions","afterFind","beforeCount","beforeDefine","sync","noModel","afterDefine","beforeInit","afterInit","beforeAssociate","afterAssociate","beforeConnect","afterConnect","beforeDisconnect","afterDisconnect","beforeSync","afterSync","beforeBulkSync","afterBulkSync","beforeQuery","afterQuery","exports","hooks","getProxiedHooks","hookType","concat","getHooks","hooked","options","Hooks","_setupHooks","map","hooksArray","hookName","Array","isArray","forEach","hookFn","addHook","runHooks","hookArgs","Error","sequelize","hook","fn","apply","each","return","name","type","push","removeHook","isReference","hasHook","filter","length","hasHooks","applyTo","target","isModel","mixin","Object","keys","callback"],"mappings":"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B,OAAL,CAAaK,IAAb,EAAmBK,IAAnB,EAAyBe,QAAzB,CAAP;AACD,KAFD;AAGD;AACF;;AACD1C,OAAO,CAACoC,OAAR,GAAkBA,OAAlB;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA","sourcesContent":["'use strict';\n\nconst _ = require('lodash');\nconst { logger } = require('./utils/logger');\nconst Promise = require('./promise');\nconst debug = logger.debugContext('hooks');\n\nconst hookTypes = {\n  beforeValidate: { params: 2 },\n  afterValidate: { params: 2 },\n  validationFailed: { params: 3 },\n  beforeCreate: { params: 2 },\n  afterCreate: { params: 2 },\n  beforeDestroy: { params: 2 },\n  afterDestroy: { params: 2 },\n  beforeRestore: { params: 2 },\n  afterRestore: { params: 2 },\n  beforeUpdate: { params: 2 },\n  afterUpdate: { params: 2 },\n  beforeSave: { params: 2, proxies: ['beforeUpdate', 'beforeCreate'] },\n  afterSave: { params: 2, proxies: ['afterUpdate', 'afterCreate'] },\n  beforeUpsert: { params: 2 },\n  afterUpsert: { params: 2 },\n  beforeBulkCreate: { params: 2 },\n  afterBulkCreate: { params: 2 },\n  beforeBulkDestroy: { params: 1 },\n  afterBulkDestroy: { params: 1 },\n  beforeBulkRestore: { params: 1 },\n  afterBulkRestore: { params: 1 },\n  beforeBulkUpdate: { params: 1 },\n  afterBulkUpdate: { params: 1 },\n  beforeFind: { params: 1 },\n  beforeFindAfterExpandIncludeAll: { params: 1 },\n  beforeFindAfterOptions: { params: 1 },\n  afterFind: { params: 2 },\n  beforeCount: { params: 1 },\n  beforeDefine: { params: 2, sync: true, noModel: true },\n  afterDefine: { params: 1, sync: true, noModel: true },\n  beforeInit: { params: 2, sync: true, noModel: true },\n  afterInit: { params: 1, sync: true, noModel: true },\n  beforeAssociate: { params: 2, sync: true },\n  afterAssociate: { params: 2, sync: true },\n  beforeConnect: { params: 1, noModel: true },\n  afterConnect: { params: 2, noModel: true },\n  beforeDisconnect: { params: 1, noModel: true },\n  afterDisconnect: { params: 1, noModel: true },\n  beforeSync: { params: 1 },\n  afterSync: { params: 1 },\n  beforeBulkSync: { params: 1 },\n  afterBulkSync: { params: 1 },\n  beforeQuery: { params: 2 },\n  afterQuery: { params: 2 }\n};\nexports.hooks = hookTypes;\n\n\n/**\n * get array of current hook and its proxies combined\n *\n * @param {string} hookType any hook type @see {@link hookTypes}\n *\n * @private\n */\nconst getProxiedHooks = hookType =>\n  hookTypes[hookType].proxies\n    ? hookTypes[hookType].proxies.concat(hookType)\n    : [hookType]\n;\n\nfunction getHooks(hooked, hookType) {\n  return (hooked.options.hooks || {})[hookType] || [];\n}\n\nconst Hooks = {\n  /**\n   * Process user supplied hooks definition\n   *\n   * @param {Object} hooks hooks definition\n   *\n   * @private\n   * @memberof Sequelize\n   * @memberof Sequelize.Model\n   */\n  _setupHooks(hooks) {\n    this.options.hooks = {};\n    _.map(hooks || {}, (hooksArray, hookName) => {\n      if (!Array.isArray(hooksArray)) hooksArray = [hooksArray];\n      hooksArray.forEach(hookFn => this.addHook(hookName, hookFn));\n    });\n  },\n\n  runHooks(hooks, ...hookArgs) {\n    if (!hooks) throw new Error('runHooks requires at least 1 argument');\n\n    let hookType;\n\n    if (typeof hooks === 'string') {\n      hookType = hooks;\n      hooks = getHooks(this, hookType);\n\n      if (this.sequelize) {\n        hooks = hooks.concat(getHooks(this.sequelize, hookType));\n      }\n    }\n\n    if (!Array.isArray(hooks)) {\n      hooks = [hooks];\n    }\n\n    // synchronous hooks\n    if (hookTypes[hookType] && hookTypes[hookType].sync) {\n      for (let hook of hooks) {\n        if (typeof hook === 'object') {\n          hook = hook.fn;\n        }\n\n        debug(`running hook(sync) ${hookType}`);\n        hook.apply(this, hookArgs);\n      }\n      return;\n    }\n\n    // asynchronous hooks (default)\n    return Promise.each(hooks, hook => {\n      if (typeof hook === 'object') {\n        hook = hook.fn;\n      }\n\n      debug(`running hook ${hookType}`);\n      return hook.apply(this, hookArgs);\n    }).return();\n  },\n\n  /**\n   * Add a hook to the model\n   *\n   * @param {string}          hookType hook name @see {@link hookTypes}\n   * @param {string|Function} [name] Provide a name for the hook function. It can be used to remove the hook later or to order hooks based on some sort of priority system in the future.\n   * @param {Function}        fn The hook function\n   *\n   * @memberof Sequelize\n   * @memberof Sequelize.Model\n   */\n  addHook(hookType, name, fn) {\n    if (typeof name === 'function') {\n      fn = name;\n      name = null;\n    }\n\n    debug(`adding hook ${hookType}`);\n    // check for proxies, add them too\n    hookType = getProxiedHooks(hookType);\n\n    hookType.forEach(type => {\n      const hooks = getHooks(this, type);\n      hooks.push(name ? { name, fn } : fn);\n      this.options.hooks[type] = hooks;\n    });\n\n    return this;\n  },\n\n  /**\n   * Remove hook from the model\n   *\n   * @param {string} hookType @see {@link hookTypes}\n   * @param {string|Function} name name of hook or function reference which was attached\n   *\n   * @memberof Sequelize\n   * @memberof Sequelize.Model\n   */\n  removeHook(hookType, name) {\n    const isReference = typeof name === 'function' ? true : false;\n\n    if (!this.hasHook(hookType)) {\n      return this;\n    }\n\n    debug(`removing hook ${hookType}`);\n\n    // check for proxies, add them too\n    hookType = getProxiedHooks(hookType);\n\n    for (const type of hookType) {\n      this.options.hooks[type] = this.options.hooks[type].filter(hook => {\n        if (isReference && typeof hook === 'function') {\n          return hook !== name; // check if same method\n        }\n        if (!isReference && typeof hook === 'object') {\n          return hook.name !== name;\n        }\n        return true;\n      });\n    }\n\n    return this;\n  },\n\n  /**\n   * Check whether the mode has any hooks of this type\n   *\n   * @param {string} hookType @see {@link hookTypes}\n   *\n   * @alias hasHooks\n   *\n   * @memberof Sequelize\n   * @memberof Sequelize.Model\n   */\n  hasHook(hookType) {\n    return this.options.hooks[hookType] && !!this.options.hooks[hookType].length;\n  }\n};\nHooks.hasHooks = Hooks.hasHook;\n\n\nfunction applyTo(target, isModel = false) {\n  _.mixin(target, Hooks);\n\n  for (const hook of Object.keys(hookTypes)) {\n    if (isModel && hookTypes[hook].noModel) {\n      continue;\n    }\n    target[hook] = function(name, callback) {\n      return this.addHook(hook, name, callback);\n    };\n  }\n}\nexports.applyTo = applyTo;\n\n/**\n * A hook that is run before validation\n * @param {string}   name\n * @param {Function} fn   A callback function that is called with instance, options\n * @name beforeValidate\n * @memberof Sequelize.Model\n */\n\n/**\n * A hook that is run after validation\n * @param {string}   name\n * @param {Function} fn   A callback function that is called with instance, options\n * @name afterValidate\n * @memberof Sequelize.Model\n */\n\n/**\n * A hook that is run when validation fails\n * @param {string}   name\n * @param {Function} fn   A callback function that is called with instance, options, error. Error is the\n * SequelizeValidationError. If the callback throws an error, it will replace the original validation error.\n * @name validationFailed\n * @memberof Sequelize.Model\n */\n\n/**\n * A hook that is run before creating a single instance\n * @param {string}   name\n * @param {Function} fn   A callback function that is called with attributes, options\n * @name beforeCreate\n * @memberof Sequelize.Model\n */\n\n/**\n * A hook that is run after creating a single instance\n * @param {string}   name\n * @param {Function} fn   A callback function that is called with attributes, options\n * @name afterCreate\n * @memberof Sequelize.Model\n */\n\n/**\n * A hook that is run before creating or updating a single instance, It proxies `beforeCreate` and `beforeUpdate`\n * @param {string}   name\n * @param {Function} fn   A callback function that is called with attributes, options\n * @name beforeSave\n * @memberof Sequelize.Model\n */\n\n/**\n * A hook that is run before upserting\n * @param {string}   name\n * @param {Function} fn   A callback function that is called with attributes, options\n * @name beforeUpsert\n * @memberof Sequelize.Model\n */\n\n/**\n * A hook that is run after upserting\n * @param {string}   name\n * @param {Function} fn   A callback function that is called with the result of upsert(), options\n * @name afterUpsert\n * @memberof Sequelize.Model\n */\n\n/**\n  * A hook that is run after creating or updating a single instance, It proxies `afterCreate` and `afterUpdate`\n  * @param {string}   name\n  * @param {Function} fn   A callback function that is called with attributes, options\n  * @name afterSave\n  * @memberof Sequelize.Model\n  */\n\n/**\n * A hook that is run before destroying a single instance\n * @param {string}   name\n * @param {Function} fn   A callback function that is called with instance, options\n *\n * @name beforeDestroy\n * @memberof Sequelize.Model\n */\n\n/**\n * A hook that is run after destroying a single instance\n * @param {string}   name\n * @param {Function} fn   A callback function that is called with instance, options\n *\n * @name afterDestroy\n * @memberof Sequelize.Model\n */\n\n/**\n * A hook that is run before restoring a single instance\n * @param {string}   name\n * @param {Function} fn   A callback function that is called with instance, options\n *\n * @name beforeRestore\n * @memberof Sequelize.Model\n */\n\n/**\n * A hook that is run after restoring a single instance\n * @param {string}   name\n * @param {Function} fn   A callback function that is called with instance, options\n *\n * @name afterRestore\n * @memberof Sequelize.Model\n */\n\n/**\n * A hook that is run before updating a single instance\n * @param {string}   name\n * @param {Function} fn   A callback function that is called with instance, options\n * @name beforeUpdate\n * @memberof Sequelize.Model\n */\n\n/**\n * A hook that is run after updating a single instance\n * @param {string}   name\n * @param {Function} fn   A callback function that is called with instance, options\n * @name afterUpdate\n * @memberof Sequelize.Model\n */\n\n/**\n * A hook that is run before creating instances in bulk\n * @param {string}   name\n * @param {Function} fn   A callback function that is called with instances, options\n * @name beforeBulkCreate\n * @memberof Sequelize.Model\n */\n\n/**\n * A hook that is run after creating instances in bulk\n * @param {string}   name\n * @param {Function} fn   A callback function that is called with instances, options\n * @name afterBulkCreate\n * @memberof Sequelize.Model\n */\n\n/**\n * A hook that is run before destroying instances in bulk\n * @param {string}   name\n * @param {Function} fn   A callback function that is called with options\n *\n * @name beforeBulkDestroy\n * @memberof Sequelize.Model\n */\n\n/**\n * A hook that is run after destroying instances in bulk\n * @param {string}   name\n * @param {Function} fn   A callback function that is called with options\n *\n * @name afterBulkDestroy\n * @memberof Sequelize.Model\n */\n\n/**\n * A hook that is run before restoring instances in bulk\n * @param {string}   name\n * @param {Function} fn   A callback function that is called with options\n *\n * @name beforeBulkRestore\n * @memberof Sequelize.Model\n */\n\n/**\n * A hook that is run after restoring instances in bulk\n * @param {string}   name\n * @param {Function} fn   A callback function that is called with options\n *\n * @name afterBulkRestore\n * @memberof Sequelize.Model\n */\n\n/**\n * A hook that is run before updating instances in bulk\n * @param {string}   name\n * @param {Function} fn   A callback function that is called with options\n * @name beforeBulkUpdate\n * @memberof Sequelize.Model\n */\n\n/**\n * A hook that is run after updating instances in bulk\n * @param {string}   name\n * @param {Function} fn   A callback function that is called with options\n * @name afterBulkUpdate\n * @memberof Sequelize.Model\n */\n\n/**\n * A hook that is run before a find (select) query\n * @param {string}   name\n * @param {Function} fn   A callback function that is called with options\n * @name beforeFind\n * @memberof Sequelize.Model\n */\n\n/**\n * A hook that is run before a find (select) query, after any { include: {all: ...} } options are expanded\n * @param {string}   name\n * @param {Function} fn   A callback function that is called with options\n * @name beforeFindAfterExpandIncludeAll\n * @memberof Sequelize.Model\n */\n\n/**\n * A hook that is run before a find (select) query, after all option parsing is complete\n * @param {string}   name\n * @param {Function} fn   A callback function that is called with options\n * @name beforeFindAfterOptions\n * @memberof Sequelize.Model\n */\n\n/**\n * A hook that is run after a find (select) query\n * @param {string}   name\n * @param {Function} fn   A callback function that is called with instance(s), options\n * @name afterFind\n * @memberof Sequelize.Model\n */\n\n/**\n * A hook that is run before a count query\n * @param {string}   name\n * @param {Function} fn   A callback function that is called with options\n * @name beforeCount\n * @memberof Sequelize.Model\n */\n\n/**\n * A hook that is run before a define call\n * @param {string}   name\n * @param {Function} fn   A callback function that is called with attributes, options\n * @name beforeDefine\n * @memberof Sequelize\n */\n\n/**\n * A hook that is run after a define call\n * @param {string}   name\n * @param {Function} fn   A callback function that is called with factory\n * @name afterDefine\n * @memberof Sequelize\n */\n\n/**\n * A hook that is run before Sequelize() call\n * @param {string}   name\n * @param {Function} fn   A callback function that is called with config, options\n * @name beforeInit\n * @memberof Sequelize\n */\n\n/**\n * A hook that is run after Sequelize() call\n * @param {string}   name\n * @param {Function} fn   A callback function that is called with sequelize\n * @name afterInit\n * @memberof Sequelize\n */\n\n/**\n * A hook that is run before a connection is created\n * @param {string}   name\n * @param {Function} fn   A callback function that is called with config passed to connection\n * @name beforeConnect\n * @memberof Sequelize\n */\n\n/**\n * A hook that is run after a connection is created\n * @param {string}   name\n * @param {Function} fn   A callback function that is called with the connection object and the config passed to connection\n * @name afterConnect\n * @memberof Sequelize\n */\n\n/**\n * A hook that is run before a connection is disconnected\n * @param {string}   name\n * @param {Function} fn   A callback function that is called with the connection object\n * @name beforeDisconnect\n * @memberof Sequelize\n */\n\n/**\n * A hook that is run after a connection is disconnected\n * @param {string}   name\n * @param {Function} fn   A callback function that is called with the connection object\n * @name afterDisconnect\n * @memberof Sequelize\n */\n\n/**\n * A hook that is run before Model.sync call\n * @param {string}   name\n * @param {Function} fn   A callback function that is called with options passed to Model.sync\n * @name beforeSync\n * @memberof Sequelize\n */\n\n/**\n * A hook that is run after Model.sync call\n * @param {string}   name\n * @param {Function} fn   A callback function that is called with options passed to Model.sync\n * @name afterSync\n * @memberof Sequelize\n */\n\n/**\n  * A hook that is run before sequelize.sync call\n  * @param {string}   name\n  * @param {Function} fn   A callback function that is called with options passed to sequelize.sync\n  * @name beforeBulkSync\n  * @memberof Sequelize\n  */\n\n/**\n  * A hook that is run after sequelize.sync call\n  * @param {string}   name\n  * @param {Function} fn   A callback function that is called with options passed to sequelize.sync\n  * @name afterBulkSync\n  * @memberof Sequelize\n  */\n"]} \ No newline at end of file diff --git a/dist/index-hints.js b/dist/index-hints.js index 73abb6a..ab0af97 100644 --- a/dist/index-hints.js +++ b/dist/index-hints.js @@ -13,4 +13,4 @@ const IndexHints = module.exports = { FORCE: 'FORCE', IGNORE: 'IGNORE' }; -//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uL2xpYi9pbmRleC1oaW50cy5qcyJdLCJuYW1lcyI6WyJJbmRleEhpbnRzIiwibW9kdWxlIiwiZXhwb3J0cyIsIlVTRSIsIkZPUkNFIiwiSUdOT1JFIl0sIm1hcHBpbmdzIjoiQUFBQTtBQUVBOzs7Ozs7OztBQU9BLE1BQU1BLFVBQVUsR0FBR0MsTUFBTSxDQUFDQyxPQUFQLEdBQWlCO0FBQUU7QUFDcENDLEVBQUFBLEdBQUcsRUFBRSxLQUQ2QjtBQUVsQ0MsRUFBQUEsS0FBSyxFQUFFLE9BRjJCO0FBR2xDQyxFQUFBQSxNQUFNLEVBQUU7QUFIMEIsQ0FBcEMiLCJzb3VyY2VzQ29udGVudCI6WyIndXNlIHN0cmljdCc7XHJcblxyXG4vKipcclxuICogQW4gZW51bSBvZiBpbmRleCBoaW50cyB0byBiZSB1c2VkIGluIG15c3FsIGZvciBxdWVyeWluZyB3aXRoIGluZGV4IGhpbnRzXHJcbiAqXHJcbiAqIEBwcm9wZXJ0eSBVU0VcclxuICogQHByb3BlcnR5IEZPUkNFXHJcbiAqIEBwcm9wZXJ0eSBJR05PUkVcclxuICovXHJcbmNvbnN0IEluZGV4SGludHMgPSBtb2R1bGUuZXhwb3J0cyA9IHsgLy8gZXNsaW50LWRpc2FibGUtbGluZVxyXG4gIFVTRTogJ1VTRScsXHJcbiAgRk9SQ0U6ICdGT1JDRScsXHJcbiAgSUdOT1JFOiAnSUdOT1JFJ1xyXG59O1xyXG4iXX0= \ No newline at end of file +//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uL2xpYi9pbmRleC1oaW50cy5qcyJdLCJuYW1lcyI6WyJJbmRleEhpbnRzIiwibW9kdWxlIiwiZXhwb3J0cyIsIlVTRSIsIkZPUkNFIiwiSUdOT1JFIl0sIm1hcHBpbmdzIjoiQUFBQTtBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUNBLE1BQU1BLFVBQVUsR0FBR0MsTUFBTSxDQUFDQyxPQUFQLEdBQWlCO0FBQUU7QUFDcENDLEVBQUFBLEdBQUcsRUFBRSxLQUQ2QjtBQUVsQ0MsRUFBQUEsS0FBSyxFQUFFLE9BRjJCO0FBR2xDQyxFQUFBQSxNQUFNLEVBQUU7QUFIMEIsQ0FBcEMiLCJzb3VyY2VzQ29udGVudCI6WyIndXNlIHN0cmljdCc7XG5cbi8qKlxuICogQW4gZW51bSBvZiBpbmRleCBoaW50cyB0byBiZSB1c2VkIGluIG15c3FsIGZvciBxdWVyeWluZyB3aXRoIGluZGV4IGhpbnRzXG4gKlxuICogQHByb3BlcnR5IFVTRVxuICogQHByb3BlcnR5IEZPUkNFXG4gKiBAcHJvcGVydHkgSUdOT1JFXG4gKi9cbmNvbnN0IEluZGV4SGludHMgPSBtb2R1bGUuZXhwb3J0cyA9IHsgLy8gZXNsaW50LWRpc2FibGUtbGluZVxuICBVU0U6ICdVU0UnLFxuICBGT1JDRTogJ0ZPUkNFJyxcbiAgSUdOT1JFOiAnSUdOT1JFJ1xufTtcbiJdfQ== \ No newline at end of file diff --git a/dist/instance-validator.js b/dist/instance-validator.js index 7f66c7d..ed7b822 100644 --- a/dist/instance-validator.js +++ b/dist/instance-validator.js @@ -29,9 +29,7 @@ const validator = require('./utils/validator-extras').validator; */ -let InstanceValidator = -/*#__PURE__*/ -function () { +let InstanceValidator = /*#__PURE__*/function () { function InstanceValidator(modelInstance, options) { _classCallCheck(this, InstanceValidator); @@ -446,4 +444,4 @@ InstanceValidator.RAW_KEY_NAME = 'original'; module.exports = InstanceValidator; module.exports.InstanceValidator = InstanceValidator; module.exports.default = InstanceValidator; -//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../lib/instance-validator.js"],"names":["_","require","Utils","sequelizeError","Promise","DataTypes","BelongsTo","validator","InstanceValidator","modelInstance","options","clone","fields","skip","difference","Object","keys","constructor","rawAttributes","defaults","hooks","errors","inProgress","Error","all","_perAttributeValidators","reflect","_customValidators","then","length","ValidationError","_validateAndRunHooks","_validate","runHooks","bind","catch","error","newError","return","validators","forIn","rawAttribute","field","includes","value","dataValues","SequelizeMethod","_autoGenerated","autoIncrement","_validateSchema","prototype","hasOwnProperty","call","push","_singleAttrValidate","allowNull","each","_modelOptions","validate","validatorType","valprom","_invokeCustomValidator","undefined","resolve","test","msg","validatorPromise","_invokeBuiltinValidator","results","_handleReflectedResult","optAttrDefined","optValue","optField","validatorFunction","isAsync","validatorArity","asyncArity","errorKey","invokeArgs","promisify","e","_pushError","try","valueString","String","validatorArgs","_extractValidatorArgs","assign","validatorName","args","isLocalizedValidator","Array","isArray","slice","association","values","associations","find","foreignKey","fieldName","get","associationAccessor","errMsg","name","ValidationErrorItem","type","STRING","TEXT","CITEXT","isObject","Buffer","isBuffer","promiseInspections","promiseInspection","isRejected","rejection","isBuiltIn","isBuiltin","rawError","fnName","fnArgs","message","RAW_KEY_NAME","module","exports","default"],"mappings":"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","sourcesContent":["'use strict';\r\n\r\nconst _ = require('lodash');\r\nconst Utils = require('./utils');\r\nconst sequelizeError = require('./errors');\r\nconst Promise = require('./promise');\r\nconst DataTypes = require('./data-types');\r\nconst BelongsTo = require('./associations/belongs-to');\r\nconst validator = require('./utils/validator-extras').validator;\r\n\r\n/**\r\n * Instance Validator.\r\n *\r\n * @param {Instance} modelInstance The model instance.\r\n * @param {Object} options A dictionary with options.\r\n *\r\n * @private\r\n */\r\nclass InstanceValidator {\r\n  constructor(modelInstance, options) {\r\n    options = _.clone(options) || {};\r\n\r\n    if (options.fields && !options.skip) {\r\n      options.skip = _.difference(Object.keys(modelInstance.constructor.rawAttributes), options.fields);\r\n    }\r\n\r\n    // assign defined and default options\r\n    this.options = _.defaults(options, {\r\n      skip: [],\r\n      hooks: true\r\n    });\r\n\r\n    this.modelInstance = modelInstance;\r\n\r\n    /**\r\n     * Exposes a reference to validator.js. This allows you to add custom validations using `validator.extend`\r\n     * @name validator\r\n     * @private\r\n     */\r\n    this.validator = validator;\r\n\r\n    /**\r\n     *  All errors will be stored here from the validations.\r\n     *\r\n     * @type {Array} Will contain keys that correspond to attributes which will\r\n     *   be Arrays of Errors.\r\n     * @private\r\n     */\r\n    this.errors = [];\r\n\r\n    /**\r\n     * @type {boolean} Indicates if validations are in progress\r\n     * @private\r\n     */\r\n    this.inProgress = false;\r\n  }\r\n\r\n  /**\r\n   * The main entry point for the Validation module, invoke to start the dance.\r\n   *\r\n   * @returns {Promise}\r\n   * @private\r\n   */\r\n  _validate() {\r\n    if (this.inProgress) throw new Error('Validations already in progress.');\r\n\r\n    this.inProgress = true;\r\n\r\n    return Promise.all([\r\n      this._perAttributeValidators().reflect(),\r\n      this._customValidators().reflect()\r\n    ]).then(() => {\r\n      if (this.errors.length) {\r\n        throw new sequelizeError.ValidationError(null, this.errors);\r\n      }\r\n    });\r\n  }\r\n\r\n  /**\r\n   * Invoke the Validation sequence and run validation hooks if defined\r\n   *   - Before Validation Model Hooks\r\n   *   - Validation\r\n   *   - On validation success: After Validation Model Hooks\r\n   *   - On validation failure: Validation Failed Model Hooks\r\n   *\r\n   * @returns {Promise}\r\n   * @private\r\n   */\r\n  validate() {\r\n    return this.options.hooks ? this._validateAndRunHooks() : this._validate();\r\n  }\r\n\r\n  /**\r\n   * Invoke the Validation sequence and run hooks\r\n   *   - Before Validation Model Hooks\r\n   *   - Validation\r\n   *   - On validation success: After Validation Model Hooks\r\n   *   - On validation failure: Validation Failed Model Hooks\r\n   *\r\n   * @returns {Promise}\r\n   * @private\r\n   */\r\n  _validateAndRunHooks() {\r\n    const runHooks = this.modelInstance.constructor.runHooks.bind(this.modelInstance.constructor);\r\n    return runHooks('beforeValidate', this.modelInstance, this.options)\r\n      .then(() =>\r\n        this._validate()\r\n          .catch(error => runHooks('validationFailed', this.modelInstance, this.options, error)\r\n            .then(newError => { throw newError || error; }))\r\n      )\r\n      .then(() => runHooks('afterValidate', this.modelInstance, this.options))\r\n      .return(this.modelInstance);\r\n  }\r\n\r\n  /**\r\n   * Will run all the validators defined per attribute (built-in validators and custom validators)\r\n   *\r\n   * @returns {Promise<Array.<Promise.PromiseInspection>>} A promise from .reflect().\r\n   * @private\r\n   */\r\n  _perAttributeValidators() {\r\n    // promisify all attribute invocations\r\n    const validators = [];\r\n\r\n    _.forIn(this.modelInstance.rawAttributes, (rawAttribute, field) => {\r\n      if (this.options.skip.includes(field)) {\r\n        return;\r\n      }\r\n\r\n      const value = this.modelInstance.dataValues[field];\r\n\r\n      if (value instanceof Utils.SequelizeMethod) {\r\n        return;\r\n      }\r\n\r\n      if (!rawAttribute._autoGenerated && !rawAttribute.autoIncrement) {\r\n        // perform validations based on schema\r\n        this._validateSchema(rawAttribute, field, value);\r\n      }\r\n\r\n      if (Object.prototype.hasOwnProperty.call(this.modelInstance.validators, field)) {\r\n        validators.push(this._singleAttrValidate(value, field, rawAttribute.allowNull).reflect());\r\n      }\r\n    });\r\n\r\n    return Promise.all(validators);\r\n  }\r\n\r\n  /**\r\n   * Will run all the custom validators defined in the model's options.\r\n   *\r\n   * @returns {Promise<Array.<Promise.PromiseInspection>>} A promise from .reflect().\r\n   * @private\r\n   */\r\n  _customValidators() {\r\n    const validators = [];\r\n    _.each(this.modelInstance._modelOptions.validate, (validator, validatorType) => {\r\n      if (this.options.skip.includes(validatorType)) {\r\n        return;\r\n      }\r\n\r\n      const valprom = this._invokeCustomValidator(validator, validatorType)\r\n        // errors are handled in settling, stub this\r\n        .catch(() => {})\r\n        .reflect();\r\n\r\n      validators.push(valprom);\r\n    });\r\n\r\n    return Promise.all(validators);\r\n  }\r\n\r\n  /**\r\n   * Validate a single attribute with all the defined built-in validators and custom validators.\r\n   *\r\n   * @private\r\n   *\r\n   * @param {*} value Anything.\r\n   * @param {string} field The field name.\r\n   * @param {boolean} allowNull Whether or not the schema allows null values\r\n   *\r\n   * @returns {Promise} A promise, will always resolve, auto populates error on this.error local object.\r\n   */\r\n  _singleAttrValidate(value, field, allowNull) {\r\n    // If value is null and allowNull is false, no validators should run (see #9143)\r\n    if ((value === null || value === undefined) && !allowNull) {\r\n      // The schema validator (_validateSchema) has already generated the validation error. Nothing to do here.\r\n      return Promise.resolve();\r\n    }\r\n\r\n    // Promisify each validator\r\n    const validators = [];\r\n    _.forIn(this.modelInstance.validators[field], (test, validatorType) => {\r\n\r\n      if (validatorType === 'isUrl' || validatorType === 'isURL' || validatorType === 'isEmail') {\r\n        // Preserve backwards compat. Validator.js now expects the second param to isURL and isEmail to be an object\r\n        if (typeof test === 'object' && test !== null && test.msg) {\r\n          test = {\r\n            msg: test.msg\r\n          };\r\n        } else if (test === true) {\r\n          test = {};\r\n        }\r\n      }\r\n\r\n      // Custom validators should always run, except if value is null and allowNull is false (see #9143)\r\n      if (typeof test === 'function') {\r\n        validators.push(this._invokeCustomValidator(test, validatorType, true, value, field).reflect());\r\n        return;\r\n      }\r\n\r\n      // If value is null, built-in validators should not run (only custom validators have to run) (see #9134).\r\n      if (value === null || value === undefined) {\r\n        return;\r\n      }\r\n\r\n      const validatorPromise = this._invokeBuiltinValidator(value, test, validatorType, field);\r\n      // errors are handled in settling, stub this\r\n      validatorPromise.catch(() => {});\r\n      validators.push(validatorPromise.reflect());\r\n    });\r\n\r\n    return Promise\r\n      .all(validators)\r\n      .then(results => this._handleReflectedResult(field, value, results));\r\n  }\r\n\r\n  /**\r\n   * Prepare and invoke a custom validator.\r\n   *\r\n   * @private\r\n   *\r\n   * @param {Function} validator The custom validator.\r\n   * @param {string} validatorType the custom validator type (name).\r\n   * @param {boolean} optAttrDefined Set to true if custom validator was defined from the attribute\r\n   * @param {*} optValue value for attribute\r\n   * @param {string} optField field for attribute\r\n   *\r\n   * @returns {Promise} A promise.\r\n   */\r\n  _invokeCustomValidator(validator, validatorType, optAttrDefined, optValue, optField) {\r\n    let validatorFunction = null; // the validation function to call\r\n    let isAsync = false;\r\n\r\n    const validatorArity = validator.length;\r\n    // check if validator is async and requires a callback\r\n    let asyncArity = 1;\r\n    let errorKey = validatorType;\r\n    let invokeArgs;\r\n    if (optAttrDefined) {\r\n      asyncArity = 2;\r\n      invokeArgs = optValue;\r\n      errorKey = optField;\r\n    }\r\n    if (validatorArity === asyncArity) {\r\n      isAsync = true;\r\n    }\r\n\r\n    if (isAsync) {\r\n      if (optAttrDefined) {\r\n        validatorFunction = Promise.promisify(validator.bind(this.modelInstance, invokeArgs));\r\n      } else {\r\n        validatorFunction = Promise.promisify(validator.bind(this.modelInstance));\r\n      }\r\n      return validatorFunction()\r\n        .catch(e => this._pushError(false, errorKey, e, optValue, validatorType));\r\n    }\r\n    return Promise\r\n      .try(() => validator.call(this.modelInstance, invokeArgs))\r\n      .catch(e => this._pushError(false, errorKey, e, optValue, validatorType));\r\n  }\r\n\r\n  /**\r\n   * Prepare and invoke a build-in validator.\r\n   *\r\n   * @private\r\n   *\r\n   * @param {*} value Anything.\r\n   * @param {*} test The test case.\r\n   * @param {string} validatorType One of known to Sequelize validators.\r\n   * @param {string} field The field that is being validated\r\n   *\r\n   * @returns {Object} An object with specific keys to invoke the validator.\r\n   */\r\n  _invokeBuiltinValidator(value, test, validatorType, field) {\r\n    return Promise.try(() => {\r\n      // Cast value as string to pass new Validator.js string requirement\r\n      const valueString = String(value);\r\n      // check if Validator knows that kind of validation test\r\n      if (typeof validator[validatorType] !== 'function') {\r\n        throw new Error(`Invalid validator function: ${validatorType}`);\r\n      }\r\n\r\n      const validatorArgs = this._extractValidatorArgs(test, validatorType, field);\r\n\r\n      if (!validator[validatorType](valueString, ...validatorArgs)) {\r\n        throw Object.assign(new Error(test.msg || `Validation ${validatorType} on ${field} failed`), { validatorName: validatorType, validatorArgs });\r\n      }\r\n    });\r\n  }\r\n\r\n  /**\r\n   * Will extract arguments for the validator.\r\n   *\r\n   * @param {*} test The test case.\r\n   * @param {string} validatorType One of known to Sequelize validators.\r\n   * @param {string} field The field that is being validated.\r\n   *\r\n   * @private\r\n   */\r\n  _extractValidatorArgs(test, validatorType, field) {\r\n    let validatorArgs = test.args || test;\r\n    const isLocalizedValidator = typeof validatorArgs !== 'string' && (validatorType === 'isAlpha' || validatorType === 'isAlphanumeric' || validatorType === 'isMobilePhone');\r\n\r\n    if (!Array.isArray(validatorArgs)) {\r\n      if (validatorType === 'isImmutable') {\r\n        validatorArgs = [validatorArgs, field, this.modelInstance];\r\n      } else if (isLocalizedValidator || validatorType === 'isIP') {\r\n        validatorArgs = [];\r\n      } else {\r\n        validatorArgs = [validatorArgs];\r\n      }\r\n    } else {\r\n      validatorArgs = validatorArgs.slice(0);\r\n    }\r\n    return validatorArgs;\r\n  }\r\n\r\n  /**\r\n   * Will validate a single field against its schema definition (isnull).\r\n   *\r\n   * @param {Object} rawAttribute As defined in the Schema.\r\n   * @param {string} field The field name.\r\n   * @param {*} value anything.\r\n   *\r\n   * @private\r\n   */\r\n  _validateSchema(rawAttribute, field, value) {\r\n    if (rawAttribute.allowNull === false && (value === null || value === undefined)) {\r\n      const association = _.values(this.modelInstance.constructor.associations).find(association => association instanceof BelongsTo && association.foreignKey === rawAttribute.fieldName);\r\n      if (!association || !this.modelInstance.get(association.associationAccessor)) {\r\n        const validators = this.modelInstance.validators[field];\r\n        const errMsg = _.get(validators, 'notNull.msg', `${this.modelInstance.constructor.name}.${field} cannot be null`);\r\n\r\n        this.errors.push(new sequelizeError.ValidationErrorItem(\r\n          errMsg,\r\n          'notNull Violation', // sequelizeError.ValidationErrorItem.Origins.CORE,\r\n          field,\r\n          value,\r\n          this.modelInstance,\r\n          'is_null'\r\n        ));\r\n      }\r\n    }\r\n\r\n    if (rawAttribute.type instanceof DataTypes.STRING || rawAttribute.type instanceof DataTypes.TEXT || rawAttribute.type instanceof DataTypes.CITEXT) {\r\n      if (Array.isArray(value) || _.isObject(value) && !(value instanceof Utils.SequelizeMethod) && !Buffer.isBuffer(value)) {\r\n        this.errors.push(new sequelizeError.ValidationErrorItem(\r\n          `${field} cannot be an array or an object`,\r\n          'string violation', // sequelizeError.ValidationErrorItem.Origins.CORE,\r\n          field,\r\n          value,\r\n          this.modelInstance,\r\n          'not_a_string'\r\n        ));\r\n      }\r\n    }\r\n  }\r\n\r\n\r\n  /**\r\n   * Handles the returned result of a Promise.reflect.\r\n   *\r\n   * If errors are found it populates this.error.\r\n   *\r\n   * @param {string} field The attribute name.\r\n   * @param {string|number} value The data value.\r\n   * @param {Array<Promise.PromiseInspection>} promiseInspections objects.\r\n   *\r\n   * @private\r\n   */\r\n  _handleReflectedResult(field, value, promiseInspections) {\r\n    for (const promiseInspection of promiseInspections) {\r\n      if (promiseInspection.isRejected()) {\r\n        const rejection = promiseInspection.error();\r\n        const isBuiltIn = !!rejection.validatorName;\r\n\r\n        this._pushError(isBuiltIn, field, rejection, value, rejection.validatorName, rejection.validatorArgs);\r\n      }\r\n    }\r\n  }\r\n\r\n  /**\r\n   * Signs all errors retaining the original.\r\n   *\r\n   * @param {boolean}       isBuiltin   - Determines if error is from builtin validator.\r\n   * @param {string}        errorKey    - name of invalid attribute.\r\n   * @param {Error|string}  rawError    - The original error.\r\n   * @param {string|number} value       - The data that triggered the error.\r\n   * @param {string}        fnName      - Name of the validator, if any\r\n   * @param {Array}         fnArgs      - Arguments for the validator [function], if any\r\n   *\r\n   * @private\r\n   */\r\n  _pushError(isBuiltin, errorKey, rawError, value, fnName, fnArgs) {\r\n    const message = rawError.message || rawError || 'Validation error';\r\n    const error = new sequelizeError.ValidationErrorItem(\r\n      message,\r\n      'Validation error', // sequelizeError.ValidationErrorItem.Origins.FUNCTION,\r\n      errorKey,\r\n      value,\r\n      this.modelInstance,\r\n      fnName,\r\n      isBuiltin ? fnName : undefined,\r\n      isBuiltin ? fnArgs : undefined\r\n    );\r\n\r\n    error[InstanceValidator.RAW_KEY_NAME] = rawError;\r\n\r\n    this.errors.push(error);\r\n  }\r\n}\r\n/**\r\n * @define {string} The error key for arguments as passed by custom validators\r\n * @private\r\n */\r\nInstanceValidator.RAW_KEY_NAME = 'original';\r\n\r\nmodule.exports = InstanceValidator;\r\nmodule.exports.InstanceValidator = InstanceValidator;\r\nmodule.exports.default = InstanceValidator;\r\n"]} \ No newline at end of file +//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../lib/instance-validator.js"],"names":["_","require","Utils","sequelizeError","Promise","DataTypes","BelongsTo","validator","InstanceValidator","modelInstance","options","clone","fields","skip","difference","Object","keys","constructor","rawAttributes","defaults","hooks","errors","inProgress","Error","all","_perAttributeValidators","reflect","_customValidators","then","length","ValidationError","_validateAndRunHooks","_validate","runHooks","bind","catch","error","newError","return","validators","forIn","rawAttribute","field","includes","value","dataValues","SequelizeMethod","_autoGenerated","autoIncrement","_validateSchema","prototype","hasOwnProperty","call","push","_singleAttrValidate","allowNull","each","_modelOptions","validate","validatorType","valprom","_invokeCustomValidator","undefined","resolve","test","msg","validatorPromise","_invokeBuiltinValidator","results","_handleReflectedResult","optAttrDefined","optValue","optField","validatorFunction","isAsync","validatorArity","asyncArity","errorKey","invokeArgs","promisify","e","_pushError","try","valueString","String","validatorArgs","_extractValidatorArgs","assign","validatorName","args","isLocalizedValidator","Array","isArray","slice","association","values","associations","find","foreignKey","fieldName","get","associationAccessor","errMsg","name","ValidationErrorItem","type","STRING","TEXT","CITEXT","isObject","Buffer","isBuffer","promiseInspections","promiseInspection","isRejected","rejection","isBuiltIn","isBuiltin","rawError","fnName","fnArgs","message","RAW_KEY_NAME","module","exports","default"],"mappings":"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","sourcesContent":["'use strict';\n\nconst _ = require('lodash');\nconst Utils = require('./utils');\nconst sequelizeError = require('./errors');\nconst Promise = require('./promise');\nconst DataTypes = require('./data-types');\nconst BelongsTo = require('./associations/belongs-to');\nconst validator = require('./utils/validator-extras').validator;\n\n/**\n * Instance Validator.\n *\n * @param {Instance} modelInstance The model instance.\n * @param {Object} options A dictionary with options.\n *\n * @private\n */\nclass InstanceValidator {\n  constructor(modelInstance, options) {\n    options = _.clone(options) || {};\n\n    if (options.fields && !options.skip) {\n      options.skip = _.difference(Object.keys(modelInstance.constructor.rawAttributes), options.fields);\n    }\n\n    // assign defined and default options\n    this.options = _.defaults(options, {\n      skip: [],\n      hooks: true\n    });\n\n    this.modelInstance = modelInstance;\n\n    /**\n     * Exposes a reference to validator.js. This allows you to add custom validations using `validator.extend`\n     * @name validator\n     * @private\n     */\n    this.validator = validator;\n\n    /**\n     *  All errors will be stored here from the validations.\n     *\n     * @type {Array} Will contain keys that correspond to attributes which will\n     *   be Arrays of Errors.\n     * @private\n     */\n    this.errors = [];\n\n    /**\n     * @type {boolean} Indicates if validations are in progress\n     * @private\n     */\n    this.inProgress = false;\n  }\n\n  /**\n   * The main entry point for the Validation module, invoke to start the dance.\n   *\n   * @returns {Promise}\n   * @private\n   */\n  _validate() {\n    if (this.inProgress) throw new Error('Validations already in progress.');\n\n    this.inProgress = true;\n\n    return Promise.all([\n      this._perAttributeValidators().reflect(),\n      this._customValidators().reflect()\n    ]).then(() => {\n      if (this.errors.length) {\n        throw new sequelizeError.ValidationError(null, this.errors);\n      }\n    });\n  }\n\n  /**\n   * Invoke the Validation sequence and run validation hooks if defined\n   *   - Before Validation Model Hooks\n   *   - Validation\n   *   - On validation success: After Validation Model Hooks\n   *   - On validation failure: Validation Failed Model Hooks\n   *\n   * @returns {Promise}\n   * @private\n   */\n  validate() {\n    return this.options.hooks ? this._validateAndRunHooks() : this._validate();\n  }\n\n  /**\n   * Invoke the Validation sequence and run hooks\n   *   - Before Validation Model Hooks\n   *   - Validation\n   *   - On validation success: After Validation Model Hooks\n   *   - On validation failure: Validation Failed Model Hooks\n   *\n   * @returns {Promise}\n   * @private\n   */\n  _validateAndRunHooks() {\n    const runHooks = this.modelInstance.constructor.runHooks.bind(this.modelInstance.constructor);\n    return runHooks('beforeValidate', this.modelInstance, this.options)\n      .then(() =>\n        this._validate()\n          .catch(error => runHooks('validationFailed', this.modelInstance, this.options, error)\n            .then(newError => { throw newError || error; }))\n      )\n      .then(() => runHooks('afterValidate', this.modelInstance, this.options))\n      .return(this.modelInstance);\n  }\n\n  /**\n   * Will run all the validators defined per attribute (built-in validators and custom validators)\n   *\n   * @returns {Promise<Array.<Promise.PromiseInspection>>} A promise from .reflect().\n   * @private\n   */\n  _perAttributeValidators() {\n    // promisify all attribute invocations\n    const validators = [];\n\n    _.forIn(this.modelInstance.rawAttributes, (rawAttribute, field) => {\n      if (this.options.skip.includes(field)) {\n        return;\n      }\n\n      const value = this.modelInstance.dataValues[field];\n\n      if (value instanceof Utils.SequelizeMethod) {\n        return;\n      }\n\n      if (!rawAttribute._autoGenerated && !rawAttribute.autoIncrement) {\n        // perform validations based on schema\n        this._validateSchema(rawAttribute, field, value);\n      }\n\n      if (Object.prototype.hasOwnProperty.call(this.modelInstance.validators, field)) {\n        validators.push(this._singleAttrValidate(value, field, rawAttribute.allowNull).reflect());\n      }\n    });\n\n    return Promise.all(validators);\n  }\n\n  /**\n   * Will run all the custom validators defined in the model's options.\n   *\n   * @returns {Promise<Array.<Promise.PromiseInspection>>} A promise from .reflect().\n   * @private\n   */\n  _customValidators() {\n    const validators = [];\n    _.each(this.modelInstance._modelOptions.validate, (validator, validatorType) => {\n      if (this.options.skip.includes(validatorType)) {\n        return;\n      }\n\n      const valprom = this._invokeCustomValidator(validator, validatorType)\n        // errors are handled in settling, stub this\n        .catch(() => {})\n        .reflect();\n\n      validators.push(valprom);\n    });\n\n    return Promise.all(validators);\n  }\n\n  /**\n   * Validate a single attribute with all the defined built-in validators and custom validators.\n   *\n   * @private\n   *\n   * @param {*} value Anything.\n   * @param {string} field The field name.\n   * @param {boolean} allowNull Whether or not the schema allows null values\n   *\n   * @returns {Promise} A promise, will always resolve, auto populates error on this.error local object.\n   */\n  _singleAttrValidate(value, field, allowNull) {\n    // If value is null and allowNull is false, no validators should run (see #9143)\n    if ((value === null || value === undefined) && !allowNull) {\n      // The schema validator (_validateSchema) has already generated the validation error. Nothing to do here.\n      return Promise.resolve();\n    }\n\n    // Promisify each validator\n    const validators = [];\n    _.forIn(this.modelInstance.validators[field], (test, validatorType) => {\n\n      if (validatorType === 'isUrl' || validatorType === 'isURL' || validatorType === 'isEmail') {\n        // Preserve backwards compat. Validator.js now expects the second param to isURL and isEmail to be an object\n        if (typeof test === 'object' && test !== null && test.msg) {\n          test = {\n            msg: test.msg\n          };\n        } else if (test === true) {\n          test = {};\n        }\n      }\n\n      // Custom validators should always run, except if value is null and allowNull is false (see #9143)\n      if (typeof test === 'function') {\n        validators.push(this._invokeCustomValidator(test, validatorType, true, value, field).reflect());\n        return;\n      }\n\n      // If value is null, built-in validators should not run (only custom validators have to run) (see #9134).\n      if (value === null || value === undefined) {\n        return;\n      }\n\n      const validatorPromise = this._invokeBuiltinValidator(value, test, validatorType, field);\n      // errors are handled in settling, stub this\n      validatorPromise.catch(() => {});\n      validators.push(validatorPromise.reflect());\n    });\n\n    return Promise\n      .all(validators)\n      .then(results => this._handleReflectedResult(field, value, results));\n  }\n\n  /**\n   * Prepare and invoke a custom validator.\n   *\n   * @private\n   *\n   * @param {Function} validator The custom validator.\n   * @param {string} validatorType the custom validator type (name).\n   * @param {boolean} optAttrDefined Set to true if custom validator was defined from the attribute\n   * @param {*} optValue value for attribute\n   * @param {string} optField field for attribute\n   *\n   * @returns {Promise} A promise.\n   */\n  _invokeCustomValidator(validator, validatorType, optAttrDefined, optValue, optField) {\n    let validatorFunction = null; // the validation function to call\n    let isAsync = false;\n\n    const validatorArity = validator.length;\n    // check if validator is async and requires a callback\n    let asyncArity = 1;\n    let errorKey = validatorType;\n    let invokeArgs;\n    if (optAttrDefined) {\n      asyncArity = 2;\n      invokeArgs = optValue;\n      errorKey = optField;\n    }\n    if (validatorArity === asyncArity) {\n      isAsync = true;\n    }\n\n    if (isAsync) {\n      if (optAttrDefined) {\n        validatorFunction = Promise.promisify(validator.bind(this.modelInstance, invokeArgs));\n      } else {\n        validatorFunction = Promise.promisify(validator.bind(this.modelInstance));\n      }\n      return validatorFunction()\n        .catch(e => this._pushError(false, errorKey, e, optValue, validatorType));\n    }\n    return Promise\n      .try(() => validator.call(this.modelInstance, invokeArgs))\n      .catch(e => this._pushError(false, errorKey, e, optValue, validatorType));\n  }\n\n  /**\n   * Prepare and invoke a build-in validator.\n   *\n   * @private\n   *\n   * @param {*} value Anything.\n   * @param {*} test The test case.\n   * @param {string} validatorType One of known to Sequelize validators.\n   * @param {string} field The field that is being validated\n   *\n   * @returns {Object} An object with specific keys to invoke the validator.\n   */\n  _invokeBuiltinValidator(value, test, validatorType, field) {\n    return Promise.try(() => {\n      // Cast value as string to pass new Validator.js string requirement\n      const valueString = String(value);\n      // check if Validator knows that kind of validation test\n      if (typeof validator[validatorType] !== 'function') {\n        throw new Error(`Invalid validator function: ${validatorType}`);\n      }\n\n      const validatorArgs = this._extractValidatorArgs(test, validatorType, field);\n\n      if (!validator[validatorType](valueString, ...validatorArgs)) {\n        throw Object.assign(new Error(test.msg || `Validation ${validatorType} on ${field} failed`), { validatorName: validatorType, validatorArgs });\n      }\n    });\n  }\n\n  /**\n   * Will extract arguments for the validator.\n   *\n   * @param {*} test The test case.\n   * @param {string} validatorType One of known to Sequelize validators.\n   * @param {string} field The field that is being validated.\n   *\n   * @private\n   */\n  _extractValidatorArgs(test, validatorType, field) {\n    let validatorArgs = test.args || test;\n    const isLocalizedValidator = typeof validatorArgs !== 'string' && (validatorType === 'isAlpha' || validatorType === 'isAlphanumeric' || validatorType === 'isMobilePhone');\n\n    if (!Array.isArray(validatorArgs)) {\n      if (validatorType === 'isImmutable') {\n        validatorArgs = [validatorArgs, field, this.modelInstance];\n      } else if (isLocalizedValidator || validatorType === 'isIP') {\n        validatorArgs = [];\n      } else {\n        validatorArgs = [validatorArgs];\n      }\n    } else {\n      validatorArgs = validatorArgs.slice(0);\n    }\n    return validatorArgs;\n  }\n\n  /**\n   * Will validate a single field against its schema definition (isnull).\n   *\n   * @param {Object} rawAttribute As defined in the Schema.\n   * @param {string} field The field name.\n   * @param {*} value anything.\n   *\n   * @private\n   */\n  _validateSchema(rawAttribute, field, value) {\n    if (rawAttribute.allowNull === false && (value === null || value === undefined)) {\n      const association = _.values(this.modelInstance.constructor.associations).find(association => association instanceof BelongsTo && association.foreignKey === rawAttribute.fieldName);\n      if (!association || !this.modelInstance.get(association.associationAccessor)) {\n        const validators = this.modelInstance.validators[field];\n        const errMsg = _.get(validators, 'notNull.msg', `${this.modelInstance.constructor.name}.${field} cannot be null`);\n\n        this.errors.push(new sequelizeError.ValidationErrorItem(\n          errMsg,\n          'notNull Violation', // sequelizeError.ValidationErrorItem.Origins.CORE,\n          field,\n          value,\n          this.modelInstance,\n          'is_null'\n        ));\n      }\n    }\n\n    if (rawAttribute.type instanceof DataTypes.STRING || rawAttribute.type instanceof DataTypes.TEXT || rawAttribute.type instanceof DataTypes.CITEXT) {\n      if (Array.isArray(value) || _.isObject(value) && !(value instanceof Utils.SequelizeMethod) && !Buffer.isBuffer(value)) {\n        this.errors.push(new sequelizeError.ValidationErrorItem(\n          `${field} cannot be an array or an object`,\n          'string violation', // sequelizeError.ValidationErrorItem.Origins.CORE,\n          field,\n          value,\n          this.modelInstance,\n          'not_a_string'\n        ));\n      }\n    }\n  }\n\n\n  /**\n   * Handles the returned result of a Promise.reflect.\n   *\n   * If errors are found it populates this.error.\n   *\n   * @param {string} field The attribute name.\n   * @param {string|number} value The data value.\n   * @param {Array<Promise.PromiseInspection>} promiseInspections objects.\n   *\n   * @private\n   */\n  _handleReflectedResult(field, value, promiseInspections) {\n    for (const promiseInspection of promiseInspections) {\n      if (promiseInspection.isRejected()) {\n        const rejection = promiseInspection.error();\n        const isBuiltIn = !!rejection.validatorName;\n\n        this._pushError(isBuiltIn, field, rejection, value, rejection.validatorName, rejection.validatorArgs);\n      }\n    }\n  }\n\n  /**\n   * Signs all errors retaining the original.\n   *\n   * @param {boolean}       isBuiltin   - Determines if error is from builtin validator.\n   * @param {string}        errorKey    - name of invalid attribute.\n   * @param {Error|string}  rawError    - The original error.\n   * @param {string|number} value       - The data that triggered the error.\n   * @param {string}        fnName      - Name of the validator, if any\n   * @param {Array}         fnArgs      - Arguments for the validator [function], if any\n   *\n   * @private\n   */\n  _pushError(isBuiltin, errorKey, rawError, value, fnName, fnArgs) {\n    const message = rawError.message || rawError || 'Validation error';\n    const error = new sequelizeError.ValidationErrorItem(\n      message,\n      'Validation error', // sequelizeError.ValidationErrorItem.Origins.FUNCTION,\n      errorKey,\n      value,\n      this.modelInstance,\n      fnName,\n      isBuiltin ? fnName : undefined,\n      isBuiltin ? fnArgs : undefined\n    );\n\n    error[InstanceValidator.RAW_KEY_NAME] = rawError;\n\n    this.errors.push(error);\n  }\n}\n/**\n * @define {string} The error key for arguments as passed by custom validators\n * @private\n */\nInstanceValidator.RAW_KEY_NAME = 'original';\n\nmodule.exports = InstanceValidator;\nmodule.exports.InstanceValidator = InstanceValidator;\nmodule.exports.default = InstanceValidator;\n"]} \ No newline at end of file diff --git a/dist/model-manager.js b/dist/model-manager.js index 1f0fcf0..47181ff 100644 --- a/dist/model-manager.js +++ b/dist/model-manager.js @@ -10,9 +10,7 @@ const Toposort = require('toposort-class'); const _ = require('lodash'); -let ModelManager = -/*#__PURE__*/ -function () { +let ModelManager = /*#__PURE__*/function () { function ModelManager(sequelize) { _classCallCheck(this, ModelManager); @@ -114,4 +112,4 @@ function () { module.exports = ModelManager; module.exports.ModelManager = ModelManager; module.exports.default = ModelManager; -//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uL2xpYi9tb2RlbC1tYW5hZ2VyLmpzIl0sIm5hbWVzIjpbIlRvcG9zb3J0IiwicmVxdWlyZSIsIl8iLCJNb2RlbE1hbmFnZXIiLCJzZXF1ZWxpemUiLCJtb2RlbHMiLCJtb2RlbCIsInB1c2giLCJuYW1lIiwibW9kZWxUb1JlbW92ZSIsImZpbHRlciIsImFnYWluc3QiLCJvcHRpb25zIiwiZGVmYXVsdHMiLCJhdHRyaWJ1dGUiLCJmaW5kIiwiaXRlcmF0b3IiLCJzb3J0ZXIiLCJzb3J0ZWQiLCJkZXAiLCJyZXZlcnNlIiwiZGVwcyIsInRhYmxlTmFtZSIsImdldFRhYmxlTmFtZSIsImlzT2JqZWN0Iiwic2NoZW1hIiwiYXR0ck5hbWUiLCJyYXdBdHRyaWJ1dGVzIiwiT2JqZWN0IiwicHJvdG90eXBlIiwiaGFzT3duUHJvcGVydHkiLCJjYWxsIiwicmVmZXJlbmNlcyIsImFkZCIsInNvcnQiLCJtb2R1bGUiLCJleHBvcnRzIiwiZGVmYXVsdCJdLCJtYXBwaW5ncyI6IkFBQUE7Ozs7Ozs7O0FBRUEsTUFBTUEsUUFBUSxHQUFHQyxPQUFPLENBQUMsZ0JBQUQsQ0FBeEI7O0FBQ0EsTUFBTUMsQ0FBQyxHQUFHRCxPQUFPLENBQUMsUUFBRCxDQUFqQjs7SUFFTUUsWTs7O0FBQ0osd0JBQVlDLFNBQVosRUFBdUI7QUFBQTs7QUFDckIsU0FBS0MsTUFBTCxHQUFjLEVBQWQ7QUFDQSxTQUFLRCxTQUFMLEdBQWlCQSxTQUFqQjtBQUNEOzs7OzZCQUVRRSxLLEVBQU87QUFDZCxXQUFLRCxNQUFMLENBQVlFLElBQVosQ0FBaUJELEtBQWpCO0FBQ0EsV0FBS0YsU0FBTCxDQUFlQyxNQUFmLENBQXNCQyxLQUFLLENBQUNFLElBQTVCLElBQW9DRixLQUFwQztBQUVBLGFBQU9BLEtBQVA7QUFDRDs7O2dDQUVXRyxhLEVBQWU7QUFDekIsV0FBS0osTUFBTCxHQUFjLEtBQUtBLE1BQUwsQ0FBWUssTUFBWixDQUFtQkosS0FBSyxJQUFJQSxLQUFLLENBQUNFLElBQU4sS0FBZUMs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QyxPQUFQLEdBQWlCakMsWUFBakI7QUFDQWdDLE1BQU0sQ0FBQ0MsT0FBUCxDQUFlakMsWUFBZixHQUE4QkEsWUFBOUI7QUFDQWdDLE1BQU0sQ0FBQ0MsT0FBUCxDQUFlQyxPQUFmLEdBQXlCbEMsWUFBekIiLCJzb3VyY2VzQ29udGVudCI6WyIndXNlIHN0cmljdCc7XHJcblxyXG5jb25zdCBUb3Bvc29ydCA9IHJlcXVpcmUoJ3RvcG9zb3J0LWNsYXNzJyk7XHJcbmNvbnN0IF8gPSByZXF1aXJlKCdsb2Rhc2gnKTtcclxuXHJcbmNsYXNzIE1vZGVsTWFuYWdlciB7XHJcbiAgY29uc3RydWN0b3Ioc2VxdWVsaXplKSB7XHJcbiAgICB0aGlzLm1vZGVscyA9IFtdO1xyXG4gICAgdGhpcy5zZXF1ZWxpemUgPSBzZXF1ZWxpemU7XHJcbiAgfVxyXG5cclxuICBhZGRNb2RlbChtb2RlbCkge1xyXG4gICAgdGhpcy5tb2RlbHMucHVzaChtb2RlbCk7XHJcbiAgICB0aGlzLnNlcXVlbGl6ZS5tb2RlbHNbbW9kZWwubmFtZV0gPSBtb2RlbDtcclxuXHJcbiAgICByZXR1cm4gbW9kZWw7XHJcbiAgfVxyXG5cclxuICByZW1vdmVNb2RlbChtb2RlbFRvUmVtb3ZlKSB7XHJcbiAgICB0aGlzLm1vZGVscyA9IHRoaXMubW9kZWxzLmZpbHRlcihtb2RlbCA9PiBtb2RlbC5uYW1lICE9PSBtb2RlbFRvUmVtb3ZlLm5hbWUpO1xyXG5cclxuICAgIGRlbGV0ZSB0aGlzLnNlcXVlbGl6ZS5tb2RlbHNbbW9kZWxUb1JlbW92ZS5uYW1lXTtcclxuICB9XHJcblxyXG4gIGdldE1vZGVsKGFnYWluc3QsIG9wdGlvbnMpIHtcclxuICAgIG9wdGlvbnMgPSBfLmRlZmF1bHRzKG9wdGlvbnMgfHwge30sIHtcclxuICAgICAgYXR0cmlidXRlOiAnbmFtZSdcclxuICAgIH0pO1xyXG5cclxuICAgIHJldHVybiB0aGlzLm1vZGVscy5maW5kKG1vZGVsID0+IG1vZGVsW29wdGlvbnMuYXR0cmlidXRlXSA9PT0gYWdhaW5zdCk7XHJcbiAgfVxyXG5cclxuICBnZXQgYWxsKCkge1xyXG4gICAgcmV0dXJuIHRoaXMubW9kZWxzO1xyXG4gIH1cclxuXHJcbiAgLyoqXHJcbiAgICogSXRlcmF0ZSBvdmVyIE1vZGVscyBpbiBhbiBvcmRlciBzdWl0YWJsZSBmb3IgZS5nLiBjcmVhdGluZyB0YWJsZXMuXHJcbiAgICogV2lsbCB0YWtlIGZvcmVpZ24ga2V5IGNvbnN0cmFpbnRzIGludG8gYWNjb3VudCBzbyB0aGF0IGRlcGVuZGVuY2llcyBhcmUgdmlzaXRlZCBiZWZvcmUgZGVwZW5kZW50cy5cclxuICAgKlxyXG4gICAqIEBwYXJhbSB7RnVuY3Rpb259IGl0ZXJhdG9yIG1ldGhvZCB0byBleGVjdXRlIG9uIGVhY2ggbW9kZWxcclxuICAgKiBAcGFyYW0ge09iamVjdH0gW29wdGlvbnNdIGl0ZXJhdG9yIG9wdGlvbnNcclxuICAgKiBAcHJpdmF0ZVxyXG4gICAqL1xyXG4gIGZvckVhY2hNb2RlbChpdGVyYXRvciwgb3B0aW9ucykge1xyXG4gICAgY29uc3QgbW9kZWxzID0ge307XHJcbiAgICBjb25zdCBzb3J0ZXIgPSBuZXcgVG9wb3NvcnQoKTtcclxuICAgIGxldCBzb3J0ZWQ7XHJcbiAgICBsZXQgZGVwO1xyXG5cclxuICAgIG9wdGlvbnMgPSBfLmRlZmF1bHRzKG9wdGlvbnMgfHwge30sIHtcclxuICAgICAgcmV2ZXJzZTogdHJ1ZVxyXG4gICAgfSk7XHJcblxyXG4gICAgZm9yIChjb25zdCBtb2RlbCBvZiB0aGlzLm1vZGVscykge1xyXG4gICAgICBsZXQgZGVwcyA9IFtdO1xyXG4gICAgICBsZXQgdGFibGVOYW1lID0gbW9kZWwuZ2V0VGFibGVOYW1lKCk7XHJcblxyXG4gICAgICBpZiAoXy5pc09iamVjdCh0YWJsZU5hbWUpKSB7XHJcbiAgICAgICAgdGFibGVOYW1lID0gYCR7dGFibGVOYW1lLnNjaGVtYX0uJHt0YWJsZU5hbWUudGFibGVOYW1lfWA7XHJcbiAgICAgIH1cclxuXHJcbiAgICAgIG1vZGVsc1t0YWJsZU5hbWVdID0gbW9kZWw7XHJcblxyXG4gICAgICBmb3IgKGNvbnN0IGF0dHJOYW1lIGluIG1vZGVsLnJhd0F0dHJpYnV0ZXMpIHtcclxuICAgICAgICBpZiAoT2JqZWN0LnByb3RvdHlwZS5oYXNPd25Qcm9wZXJ0eS5jYWxsKG1vZGVsLnJhd0F0dHJpYnV0ZXMsIGF0dHJOYW1lKSkge1xyXG4gICAgICAgICAgY29uc3QgYXR0cmlidXRlID0gbW9kZWwucmF3QXR0cmlidXRlc1thdHRyTmFtZV07XHJcblxyXG4gICAgICAgICAgaWYgKGF0dHJpYnV0ZS5yZWZlcmVuY2VzKSB7XHJcbiAgICAgICAgICAgIGRlcCA9IGF0dHJpYnV0ZS5yZWZlcmVuY2VzLm1vZGVsO1xyXG5cclxuICAgICAgICAgICAgaWYgKF8uaXNPYmplY3QoZGVwKSkge1xyXG4gICAgICAgICAgICAgIGRlcCA9IGAke2RlcC5zY2hlbWF9LiR7ZGVwLnRhYmxlTmFtZX1gO1xyXG4gICAgICAgICAgICB9XHJcblxyXG4gICAgICAgICAgICBkZXBzLnB1c2goZGVwKTtcclxuICAgICAgICAgIH1cclxuICAgICAgICB9XHJcbiAgICAgIH1cclxuXHJcbiAgICAgIGRlcHMgPSBkZXBzLmZpbHRlcihkZXAgPT4gdGFibGVOYW1lICE9PSBkZXApO1xyXG5cclxuICAgICAgc29ydGVyLmFkZCh0YWJsZU5hbWUsIGRlcHMpO1xyXG4gICAgfVxyXG5cclxuICAgIHNvcnRlZCA9IHNvcnRlci5zb3J0KCk7XHJcbiAgICBpZiAob3B0aW9ucy5yZXZlcnNlKSB7XHJcbiAgICAgIHNvcnRlZCA9IHNvcnRlZC5yZXZlcnNlKCk7XHJcbiAgICB9XHJcbiAgICBmb3IgKGNvbnN0IG5hbWUgb2Ygc29ydGVkKSB7XHJcbiAgICAgIGl0ZXJhdG9yKG1vZGVsc1tuYW1lXSwgbmFtZSk7XHJcbiAgICB9XHJcbiAgfVxyXG59XHJcblxyXG5tb2R1bGUuZXhwb3J0cyA9IE1vZGVsTWFuYWdlcjtcclxubW9kdWxlLmV4cG9ydHMuTW9kZWxNYW5hZ2VyID0gTW9kZWxNYW5hZ2VyO1xyXG5tb2R1bGUuZXhwb3J0cy5kZWZhdWx0ID0gTW9kZWxNYW5hZ2VyO1xyXG4iXX0= \ No newline at end of file +//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uL2xpYi9tb2RlbC1tYW5hZ2VyLmpzIl0sIm5hbWVzIjpbIlRvcG9zb3J0IiwicmVxdWlyZSIsIl8iLCJNb2RlbE1hbmFnZXIiLCJzZXF1ZWxpemUiLCJtb2RlbHMiLCJtb2RlbCIsInB1c2giLCJuYW1lIiwibW9kZWxUb1JlbW92ZSIsImZpbHRlciIsImFnYWluc3QiLCJvcHRpb25zIiwiZGVmYXVsdHMiLCJhdHRyaWJ1dGUiLCJmaW5kIiwiaXRlcmF0b3IiLCJzb3J0ZXIiLCJzb3J0ZWQiLCJkZXAiLCJyZXZlcnNlIiwiZGVwcyIsInRhYmxlTmFtZSIsImdldFRhYmxlTmFtZSIsImlzT2JqZWN0Iiwic2NoZW1hIiwiYXR0ck5hbWUiLCJyYXdBdHRyaWJ1dGVzIiwiT2JqZWN0IiwicHJvdG90eXBlIiwiaGFzT3duUHJvcGVydHkiLCJjYWxsIiwicmVmZXJlbmNlcyIsImFkZCIsInNvcnQiLCJtb2R1bGUiLCJleHBvcnRzIiwiZGVmYXVsdCJdLCJtYXBwaW5ncyI6IkFBQUE7Ozs7Ozs7O0FBRUEsTUFBTUEsUUFBUSxHQUFHQyxPQUFPLENBQUMsZ0JBQUQsQ0FBeEI7O0FBQ0EsTUFBTUMsQ0FBQyxHQUFHRCxPQUFPLENBQUMsUUFBRCxDQUFqQjs7SUFFTUUsWTtBQUNKLHdCQUFZQyxTQUFaLEVBQXVCO0FBQUE7O0FBQ3JCLFNBQUtDLE1BQUwsR0FBYyxFQUFkO0FBQ0EsU0FBS0QsU0FBTCxHQUFpQkEsU0FBakI7QUFDRDs7Ozs2QkFFUUUsSyxFQUFPO0FBQ2QsV0FBS0QsTUFBTCxDQUFZRSxJQUFaLENBQWlCRCxLQUFqQjtBQUNBLFdBQUtGLFNBQUwsQ0FBZUMsTUFBZixDQUFzQkMsS0FBSyxDQUFDRSxJQUE1QixJQUFvQ0YsS0FBcEM7QUFFQSxhQUFPQSxLQUFQO0FBQ0Q7OztnQ0FFV0csYSxFQUFlO0FBQ3pCLFdBQUtKLE1BQUwsR0FBYyxLQUFLQSxNQUFMLENBQVlLLE1BQVosQ0FBbUJKLEtBQUssSUFBSUEsS0FBSyxDQUFDRSxJQUFOLEtBQWVDLGFB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QUNEOzs7Ozs7QUE2REg4QixNQUFNLENBQUNDLE9BQVAsR0FBaUJqQyxZQUFqQjtBQUNBZ0MsTUFBTSxDQUFDQyxPQUFQLENBQWVqQyxZQUFmLEdBQThCQSxZQUE5QjtBQUNBZ0MsTUFBTSxDQUFDQyxPQUFQLENBQWVDLE9BQWYsR0FBeUJsQyxZQUF6QiIsInNvdXJjZXNDb250ZW50IjpbIid1c2Ugc3RyaWN0JztcblxuY29uc3QgVG9wb3NvcnQgPSByZXF1aXJlKCd0b3Bvc29ydC1jbGFzcycpO1xuY29uc3QgXyA9IHJlcXVpcmUoJ2xvZGFzaCcpO1xuXG5jbGFzcyBNb2RlbE1hbmFnZXIge1xuICBjb25zdHJ1Y3RvcihzZXF1ZWxpemUpIHtcbiAgICB0aGlzLm1vZGVscyA9IFtdO1xuICAgIHRoaXMuc2VxdWVsaXplID0gc2VxdWVsaXplO1xuICB9XG5cbiAgYWRkTW9kZWwobW9kZWwpIHtcbiAgICB0aGlzLm1vZGVscy5wdXNoKG1vZGVsKTtcbiAgICB0aGlzLnNlcXVlbGl6ZS5tb2RlbHNbbW9kZWwubmFtZV0gPSBtb2RlbDtcblxuICAgIHJldHVybiBtb2RlbDtcbiAgfVxuXG4gIHJlbW92ZU1vZGVsKG1vZGVsVG9SZW1vdmUpIHtcbiAgICB0aGlzLm1vZGVscyA9IHRoaXMubW9kZWxzLmZpbHRlcihtb2RlbCA9PiBtb2RlbC5uYW1lICE9PSBtb2RlbFRvUmVtb3ZlLm5hbWUpO1xuXG4gICAgZGVsZXRlIHRoaXMuc2VxdWVsaXplLm1vZGVsc1ttb2RlbFRvUmVtb3ZlLm5hbWVdO1xuICB9XG5cbiAgZ2V0TW9kZWwoYWdhaW5zdCwgb3B0aW9ucykge1xuICAgIG9wdGlvbnMgPSBfLmRlZmF1bHRzKG9wdGlvbnMgfHwge30sIHtcbiAgICAgIGF0dHJpYnV0ZTogJ25hbWUnXG4gICAgfSk7XG5cbiAgICByZXR1cm4gdGhpcy5tb2RlbHMuZmluZChtb2RlbCA9PiBtb2RlbFtvcHRpb25zLmF0dHJpYnV0ZV0gPT09IGFnYWluc3QpO1xuICB9XG5cbiAgZ2V0IGFsbCgpIHtcbiAgICByZXR1cm4gdGhpcy5tb2RlbHM7XG4gIH1cblxuICAvKipcbiAgICogSXRlcmF0ZSBvdmVyIE1vZGVscyBpbiBhbiBvcmRlciBzdWl0YWJsZSBmb3IgZS5nLiBjcmVhdGluZyB0YWJsZXMuXG4gICAqIFdpbGwgdGFrZSBmb3JlaWduIGtleSBjb25zdHJhaW50cyBpbnRvIGFjY291bnQgc28gdGhhdCBkZXBlbmRlbmNpZXMgYXJlIHZpc2l0ZWQgYmVmb3JlIGRlcGVuZGVudHMuXG4gICAqXG4gICAqIEBwYXJhbSB7RnVuY3Rpb259IGl0ZXJhdG9yIG1ldGhvZCB0byBleGVjdXRlIG9uIGVhY2ggbW9kZWxcbiAgICogQHBhcmFtIHtPYmplY3R9IFtvcHRpb25zXSBpdGVyYXRvciBvcHRpb25zXG4gICAqIEBwcml2YXRlXG4gICAqL1xuICBmb3JFYWNoTW9kZWwoaXRlcmF0b3IsIG9wdGlvbnMpIHtcbiAgICBjb25zdCBtb2RlbHMgPSB7fTtcbiAgICBjb25zdCBzb3J0ZXIgPSBuZXcgVG9wb3NvcnQoKTtcbiAgICBsZXQgc29ydGVkO1xuICAgIGxldCBkZXA7XG5cbiAgICBvcHRpb25zID0gXy5kZWZhdWx0cyhvcHRpb25zIHx8IHt9LCB7XG4gICAgICByZXZlcnNlOiB0cnVlXG4gICAgfSk7XG5cbiAgICBmb3IgKGNvbnN0IG1vZGVsIG9mIHRoaXMubW9kZWxzKSB7XG4gICAgICBsZXQgZGVwcyA9IFtdO1xuICAgICAgbGV0IHRhYmxlTmFtZSA9IG1vZGVsLmdldFRhYmxlTmFtZSgpO1xuXG4gICAgICBpZiAoXy5pc09iamVjdCh0YWJsZU5hbWUpKSB7XG4gICAgICAgIHRhYmxlTmFtZSA9IGAke3RhYmxlTmFtZS5zY2hlbWF9LiR7dGFibGVOYW1lLnRhYmxlTmFtZX1gO1xuICAgICAgfVxuXG4gICAgICBtb2RlbHNbdGFibGVOYW1lXSA9IG1vZGVsO1xuXG4gICAgICBmb3IgKGNvbnN0IGF0dHJOYW1lIGluIG1vZGVsLnJhd0F0dHJpYnV0ZXMpIHtcbiAgICAgICAgaWYgKE9iamVjdC5wcm90b3R5cGUuaGFzT3duUHJvcGVydHkuY2FsbChtb2RlbC5yYXdBdHRyaWJ1dGVzLCBhdHRyTmFtZSkpIHtcbiAgICAgICAgICBjb25zdCBhdHRyaWJ1dGUgPSBtb2RlbC5yYXdBdHRyaWJ1dGVzW2F0dHJOYW1lXTtcblxuICAgICAgICAgIGlmIChhdHRyaWJ1dGUucmVmZXJlbmNlcykge1xuICAgICAgICAgICAgZGVwID0gYXR0cmlidXRlLnJlZmVyZW5jZXMubW9kZWw7XG5cbiAgICAgICAgICAgIGlmIChfLmlzT2JqZWN0KGRlcCkpIHtcbiAgICAgICAgICAgICAgZGVwID0gYCR7ZGVwLnNjaGVtYX0uJHtkZXAudGFibGVOYW1lfWA7XG4gICAgICAgICAgICB9XG5cbiAgICAgICAgICAgIGRlcHMucHVzaChkZXApO1xuICAgICAgICAgIH1cbiAgICAgICAgfVxuICAgICAgfVxuXG4gICAgICBkZXBzID0gZGVwcy5maWx0ZXIoZGVwID0+IHRhYmxlTmFtZSAhPT0gZGVwKTtcblxuICAgICAgc29ydGVyLmFkZCh0YWJsZU5hbWUsIGRlcHMpO1xuICAgIH1cblxuICAgIHNvcnRlZCA9IHNvcnRlci5zb3J0KCk7XG4gICAgaWYgKG9wdGlvbnMucmV2ZXJzZSkge1xuICAgICAgc29ydGVkID0gc29ydGVkLnJldmVyc2UoKTtcbiAgICB9XG4gICAgZm9yIChjb25zdCBuYW1lIG9mIHNvcnRlZCkge1xuICAgICAgaXRlcmF0b3IobW9kZWxzW25hbWVdLCBuYW1lKTtcbiAgICB9XG4gIH1cbn1cblxubW9kdWxlLmV4cG9ydHMgPSBNb2RlbE1hbmFnZXI7XG5tb2R1bGUuZXhwb3J0cy5Nb2RlbE1hbmFnZXIgPSBNb2RlbE1hbmFnZXI7XG5tb2R1bGUuZXhwb3J0cy5kZWZhdWx0ID0gTW9kZWxNYW5hZ2VyO1xuIl19 \ No newline at end of file diff --git a/dist/model.js b/dist/model.js index cdec9f5..22607de 100644 --- a/dist/model.js +++ b/dist/model.js @@ -1,14 +1,18 @@ 'use strict'; +function _inherits(subClass, superClass) { if (typeof superClass !== "function" && superClass !== null) { throw new TypeError("Super expression must either be null or a function"); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, writable: true, configurable: true } }); if (superClass) _setPrototypeOf(subClass, superClass); } + +function _setPrototypeOf(o, p) { _setPrototypeOf = Object.setPrototypeOf || function _setPrototypeOf(o, p) { o.__proto__ = p; return o; }; return _setPrototypeOf(o, p); } + +function _createSuper(Derived) { var hasNativeReflectConstruct = _isNativeReflectConstruct(); return function _createSuperInternal() { var Super = _getPrototypeOf(Derived), result; if (hasNativeReflectConstruct) { var NewTarget = _getPrototypeOf(this).constructor; result = Reflect.construct(Super, arguments, NewTarget); } else { result = Super.apply(this, arguments); } return _possibleConstructorReturn(this, result); }; } + function _possibleConstructorReturn(self, call) { if (call && (typeof call === "object" || typeof call === "function")) { return call; } return _assertThisInitialized(self); } function _assertThisInitialized(self) { if (self === void 0) { throw new ReferenceError("this hasn't been initialised - super() hasn't been called"); } return self; } -function _getPrototypeOf(o) { _getPrototypeOf = Object.setPrototypeOf ? Object.getPrototypeOf : function _getPrototypeOf(o) { return o.__proto__ || Object.getPrototypeOf(o); }; return _getPrototypeOf(o); } - -function _inherits(subClass, superClass) { if (typeof superClass !== "function" && superClass !== null) { throw new TypeError("Super expression must either be null or a function"); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, writable: true, configurable: true } }); if (superClass) _setPrototypeOf(subClass, superClass); } +function _isNativeReflectConstruct() { if (typeof Reflect === "undefined" || !Reflect.construct) return false; if (Reflect.construct.sham) return false; if (typeof Proxy === "function") return true; try { Date.prototype.toString.call(Reflect.construct(Date, [], function () {})); return true; } catch (e) { return false; } } -function _setPrototypeOf(o, p) { _setPrototypeOf = Object.setPrototypeOf || function _setPrototypeOf(o, p) { o.__proto__ = p; return o; }; return _setPrototypeOf(o, p); } +function _getPrototypeOf(o) { _getPrototypeOf = Object.setPrototypeOf ? Object.getPrototypeOf : function _getPrototypeOf(o) { return o.__proto__ || Object.getPrototypeOf(o); }; return _getPrototypeOf(o); } function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } } @@ -82,9 +86,7 @@ const nonCascadingOptions = ['include', 'attributes', 'originalAttributes', 'ord * @mixes Hooks */ -let Model = -/*#__PURE__*/ -function () { +let Model = /*#__PURE__*/function () { _createClass(Model, [{ key: "sequelize", @@ -2541,15 +2543,15 @@ function () { }, { key: "schema", value: function schema(_schema, options) { - const clone = - /*#__PURE__*/ - function (_this) { + const clone = /*#__PURE__*/function (_this) { _inherits(clone, _this); + var _super = _createSuper(clone); + function clone() { _classCallCheck(this, clone); - return _possibleConstructorReturn(this, _getPrototypeOf(clone).apply(this, arguments)); + return _super.apply(this, arguments); } return clone; @@ -2670,15 +2672,15 @@ function () { }, { key: "scope", value: function scope(option) { - const self = - /*#__PURE__*/ - function (_this2) { + const self = /*#__PURE__*/function (_this2) { _inherits(self, _this2); + var _super2 = _createSuper(self); + function self() { _classCallCheck(this, self); - return _possibleConstructorReturn(this, _getPrototypeOf(self).apply(this, arguments)); + return _super2.apply(this, arguments); } return self; @@ -3352,7 +3354,7 @@ function () { } /** * Builds a new model instance and calls save on it. - * @see + * @see * {@link Model.build} * @see * {@link Model.save} @@ -4595,7 +4597,7 @@ function () { * @see * {@link Model#reload} * @since 4.36.0 - * @returns {Promise} returns an array of affected rows and affected count with `options.returning: true`, whenever supported by dialect + * @returns {Promise} returns an array of affected rows and affected count with `options.returning: true`, whenever supported by dialect */ }, { @@ -4711,4 +4713,4 @@ function () { Object.assign(Model, associationsMixin); Hooks.applyTo(Model, true); module.exports = Model; -//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../lib/model.js"],"names":["assert","require","_","Dottie","Utils","logger","BelongsTo","BelongsToMany","InstanceValidator","QueryTypes","sequelizeErrors","Promise","Association","HasMany","DataTypes","Hooks","associationsMixin","Op","noDoubleNestedGroup","validQueryKeywords","Set","nonCascadingOptions","Model","constructor","sequelize","getQueryInterface","QueryInterface","QueryGenerator","values","options","Object","assign","isNewRecord","_schema","_schemaDelimiter","attributes","map","attribute","Array","isArray","includeValidated","_conformIncludes","include","_expandIncludeAll","_validateIncludedElements","dataValues","_previousDataValues","_changed","_modelOptions","_options","_initValues","defaults","key","clone","_hasDefaultValues","mapValues","_defaultValues","valueFn","value","SequelizeMethod","cloneDeep","primaryKeyAttributes","length","forEach","primaryKeyAttribute","prototype","hasOwnProperty","call","_timestampAttributes","createdAt","toDefaultValue","dialect","updatedAt","deletedAt","keys","undefined","set","raw","checkVersion","where","reduce","result","get","size","whereCollection","versionAttr","_versionAttribute","mapWhereFieldNames","name","originalValue","isPrimitive","changed","_customGetters","plain","includeNames","includes","instance","_hasCustomGetters","_key","reset","_hasDateAttributes","_hasBooleanAttributes","setKeys","data","k","_hasVirtualAttributes","_virtualAttributes","_customSetters","newValue","_setInclude","_isAttribute","_jsonAttributes","has","split","previousNestedValue","isEqual","_hasPrimaryKeys","_isPrimaryKey","_hasReadOnlyAttributes","_readOnlyAttributes","_dataTypeSanitizers","_dataTypeChanges","updates","filter","pickBy","includeMap","association","accessor","model","childOptions","originalAttributes","isEmpty","isSingleAssociation","build","bulkBuild","arguments","Error","hooks","validate","fields","rawAttributes","intersection","defaultFields","returning","primaryKeyName","createdAtAttr","hook","wasNewRecord","now","updatedAtAttr","push","silent","remove","val","defaultValue","unshift","_getDefaultTimestamp","try","then","beforeHookValues","pick","ignoreChanged","difference","hookChanged","afterHookValues","without","runHooks","uniq","concat","skip","as","resolve","includeOptions","omit","transaction","logging","parentRecord","save","accessors","realFields","field","versionFieldName","mapValueFieldNames","query","args","getTableName","parseInt","rowsUpdated","OptimisticLockError","modelName","attr","tap","parent","instances","foreignKey","otherKey","through","scope","_autoGenerated","throughModel","create","sourceKey","findOne","reload","InstanceError","omitBy","changedBefore","setOptions","sideEffects","union","force","attributeName","currentValue","getDataValue","undefinedOrNull","setDataValue","Date","delete","type","DELETE","limit","deletedAtAttribute","isSet","deletedAtCol","deletedAtDefaultValue","omitNull","identifier","increment","return","by","other","every","others","some","equals","validators","_paranoidClause","groupedLimit","timestamps","paranoid","deletedAtObject","eq","isWhereEmpty","and","tail","head","tableName","id","INTEGER","allowNull","primaryKey","autoIncrement","DATE","existingAttributes","each","primaryKeys","autoIncrementAttribute","definition","self","_conformInclude","associations","_pseudo","_transformStringAssociation","target","source","isPlainObject","all","validTypes","HasOne","One","Has","Many","i","types","EagerLoadingError","splice","j","nested","used","addAllIncludes","associationType","predicate","thisInclude","pop","tableNames","hasSingleAssociation","hasMultiAssociation","topModel","topLimit","_validateIncludedElement","duplicating","isMultiAssociation","hasDuplicating","hasRequired","required","hasWhere","hasParentWhere","hasParentRequired","subQuery","subQueryFilter","hasIncludeWhere","hasIncludeRequired","_expandAttributes","_injectDependentVirtualAttributes","mapFinderOptions","includeAttr","tableAttributes","_getIncludedAssociation","scoped","_injectScope","separate","flattenDepth","targetModel","targetAlias","getAssociations","getAssociationForAlias","existingAliases","join","index","_expandIncludeAllElement","parser","toLowerCase","unique","groupBy","_assignOptions","assignWith","_uniqIncludes","objValue","srcValue","_baseMerge","_mergeFunction","opts","globalOptions","merge","define","plural","pluralize","singular","singularize","indexes","schema","defineProperty","freezeTableName","underscored","rejectOnEmpty","schemaDelimiter","defaultScope","scopes","isDefined","modelManager","removeModel","getModel","_setupHooks","underscoredIf","validator","validatorType","normalizeAttribute","references","_indexes","nameIndex","_conformIndex","add","version","_addDefaultAttributes","refreshAttributes","_findAutoIncrementAttribute","_scope","_scopeNames","addModel","attributeManipulation","opt","funcs","isObject","_custom","method","fct","configurable","fieldRawAttributesMap","uniqueKeys","normalizeDataType","fieldName","_modelAttribute","_sanitize","_isChanged","BOOLEAN","DATEONLY","JSON","VIRTUAL","idxName","idx","msg","column","customIndex","JSONB","using","fieldAttributeMap","_hasJsonAttributes","_a","_hasCustomSetters","log","primaryKeyField","drop","createTable","alter","describeTable","getForeignKeyReferencesForTable","tableInfos","columns","foreignKeyReferences","changes","removedConstraints","columnDesc","columnName","addColumn","currentAttribute","removeColumn","database","config","foreignKeyReference","constraintName","tableCatalog","tableSchema","referencedTableName","referencedColumnName","referencedTableSchema","removeConstraint","changeColumn","f","showIndex","item1","item2","sort","index1","index2","concurrently","addIndex","benchmark","dropTable","dropSchema","addSchema","override","option","scopeName","flatten","apply","slice","SequelizeScopeError","QueryError","warnOnInvalidOptions","hasJoin","group","selectOptions","select","results","EmptyResultError","_findSeparate","validColumnNames","unrecognizedOptions","unexpectedModelAttributes","warn","original","memo","len","param","Buffer","isBuffer","uniqueSingleColumns","chain","c","findAll","aggregateFunction","prevAttributes","attrOptions","aggregateColumn","col","distinct","fn","unionBy","a","dataType","FLOAT","mapOptionFieldNames","rawSelect","includeIgnoreAttributes","offset","order","aggregate","countOptions","count","rows","valueSets","unknownDefaults","_cls","t","internalTransaction","exception","UniqueConstraintError","catch","err","flattenedWhere","flattenObjectDeep","flattenedWhereKeys","last","whereFields","errFieldKeys","errFieldsWhereIntersects","intersects","toString","finally","commit","hasPrimary","updatedDataValues","insertValues","updateValues","upsert","created","findByPk","record","records","recursiveBulkCreate","individualHooks","ignoreDuplicates","reject","updateOnDuplicate","errors","AggregateError","validateOptions","BulkRecordError","individualOptions","associationInstances","associationInstanceIndexToInstanceMap","associationInstance","out","fieldMappedAttributes","upsertKeys","bulkInsert","find","associated","throughOptions","throughInstances","truncate","destroy","cascade","restartIdentity","BULKDELETE","_instances","BULKUPDATE","attrValueHash","bulkUpdate","bulkDelete","RAW","_optionsMustContainWhere","valuesUse","changedValues","different","forIn","thisChangedValues","hasTrigger","affectedRows","exclude","elem","_defaultsOptions","Symbol","for","alias","updatedAtAttribute","promise","decrement","applyTo","module","exports"],"mappings":"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","sourcesContent":["'use strict';\r\n\r\nconst assert = require('assert');\r\nconst _ = require('lodash');\r\nconst Dottie = require('dottie');\r\n\r\nconst Utils = require('./utils');\r\nconst { logger } = require('./utils/logger');\r\nconst BelongsTo = require('./associations/belongs-to');\r\nconst BelongsToMany = require('./associations/belongs-to-many');\r\nconst InstanceValidator = require('./instance-validator');\r\nconst QueryTypes = require('./query-types');\r\nconst sequelizeErrors = require('./errors');\r\nconst Promise = require('./promise');\r\nconst Association = require('./associations/base');\r\nconst HasMany = require('./associations/has-many');\r\nconst DataTypes = require('./data-types');\r\nconst Hooks = require('./hooks');\r\nconst associationsMixin = require('./associations/mixin');\r\nconst Op = require('./operators');\r\nconst { noDoubleNestedGroup } = require('./utils/deprecations');\r\n\r\n\r\n// This list will quickly become dated, but failing to maintain this list just means\r\n// we won't throw a warning when we should. At least most common cases will forever be covered\r\n// so we stop throwing erroneous warnings when we shouldn't.\r\nconst validQueryKeywords = new Set(['where', 'attributes', 'paranoid', 'include', 'order', 'limit', 'offset',\r\n  'transaction', 'lock', 'raw', 'logging', 'benchmark', 'having', 'searchPath', 'rejectOnEmpty', 'plain',\r\n  'scope', 'group', 'through', 'defaults', 'distinct', 'primary', 'exception', 'type', 'hooks', 'force',\r\n  'name']);\r\n\r\n// List of attributes that should not be implicitly passed into subqueries/includes.\r\nconst nonCascadingOptions = ['include', 'attributes', 'originalAttributes', 'order', 'where', 'limit', 'offset', 'plain', 'group', 'having'];\r\n\r\n/**\r\n * A Model represents a table in the database. Instances of this class represent a database row.\r\n *\r\n * Model instances operate with the concept of a `dataValues` property, which stores the actual values represented by the instance.\r\n * By default, the values from dataValues can also be accessed directly from the Instance, that is:\r\n * ```js\r\n * instance.field\r\n * // is the same as\r\n * instance.get('field')\r\n * // is the same as\r\n * instance.getDataValue('field')\r\n * ```\r\n * However, if getters and/or setters are defined for `field` they will be invoked, instead of returning the value from `dataValues`.\r\n * Accessing properties directly or using `get` is preferred for regular use, `getDataValue` should only be used for custom getters.\r\n *\r\n * @see\r\n   * {@link Sequelize#define} for more information about getters and setters\r\n * @mixes Hooks\r\n */\r\nclass Model {\r\n  static get QueryInterface() {\r\n    return this.sequelize.getQueryInterface();\r\n  }\r\n\r\n  static get QueryGenerator() {\r\n    return this.QueryInterface.QueryGenerator;\r\n  }\r\n\r\n  /**\r\n   * A reference to the sequelize instance\r\n   *\r\n   * @see\r\n   * {@link Sequelize}\r\n   *\r\n   * @property sequelize\r\n   *\r\n   * @returns {Sequelize}\r\n   */\r\n  get sequelize() {\r\n    return this.constructor.sequelize;\r\n  }\r\n\r\n  /**\r\n   * Builds a new model instance.\r\n   *\r\n   * @param {Object}  [values={}] an object of key value pairs\r\n   * @param {Object}  [options] instance construction options\r\n   * @param {boolean} [options.raw=false] If set to true, values will ignore field and virtual setters.\r\n   * @param {boolean} [options.isNewRecord=true] Is this a new record\r\n   * @param {Array}   [options.include] an array of include options - Used to build prefetched/included model instances. See `set`\r\n   */\r\n  constructor(values = {}, options = {}) {\r\n    options = Object.assign({\r\n      isNewRecord: true,\r\n      _schema: this.constructor._schema,\r\n      _schemaDelimiter: this.constructor._schemaDelimiter\r\n    }, options || {});\r\n\r\n    if (options.attributes) {\r\n      options.attributes = options.attributes.map(attribute => Array.isArray(attribute) ? attribute[1] : attribute);\r\n    }\r\n\r\n    if (!options.includeValidated) {\r\n      this.constructor._conformIncludes(options, this.constructor);\r\n      if (options.include) {\r\n        this.constructor._expandIncludeAll(options);\r\n        this.constructor._validateIncludedElements(options);\r\n      }\r\n    }\r\n\r\n    this.dataValues = {};\r\n    this._previousDataValues = {};\r\n    this._changed = {};\r\n    this._modelOptions = this.constructor.options;\r\n    this._options = options || {};\r\n\r\n    /**\r\n     * Returns true if this instance has not yet been persisted to the database\r\n     * @property isNewRecord\r\n     * @returns {boolean}\r\n     */\r\n    this.isNewRecord = options.isNewRecord;\r\n\r\n    this._initValues(values, options);\r\n  }\r\n\r\n  _initValues(values, options) {\r\n    let defaults;\r\n    let key;\r\n\r\n    values = values && _.clone(values) || {};\r\n\r\n    if (options.isNewRecord) {\r\n      defaults = {};\r\n\r\n      if (this.constructor._hasDefaultValues) {\r\n        defaults = _.mapValues(this.constructor._defaultValues, valueFn => {\r\n          const value = valueFn();\r\n          return value && value instanceof Utils.SequelizeMethod ? value : _.cloneDeep(value);\r\n        });\r\n      }\r\n\r\n      // set id to null if not passed as value, a newly created dao has no id\r\n      // removing this breaks bulkCreate\r\n      // do after default values since it might have UUID as a default value\r\n      if (this.constructor.primaryKeyAttributes.length) {\r\n        this.constructor.primaryKeyAttributes.forEach(primaryKeyAttribute => {\r\n          if (!Object.prototype.hasOwnProperty.call(defaults, primaryKeyAttribute)) {\r\n            defaults[primaryKeyAttribute] = null;\r\n          }\r\n        });\r\n      }\r\n\r\n      if (this.constructor._timestampAttributes.createdAt && defaults[this.constructor._timestampAttributes.createdAt]) {\r\n        this.dataValues[this.constructor._timestampAttributes.createdAt] = Utils.toDefaultValue(defaults[this.constructor._timestampAttributes.createdAt], this.sequelize.options.dialect);\r\n        delete defaults[this.constructor._timestampAttributes.createdAt];\r\n      }\r\n\r\n      if (this.constructor._timestampAttributes.updatedAt && defaults[this.constructor._timestampAttributes.updatedAt]) {\r\n        this.dataValues[this.constructor._timestampAttributes.updatedAt] = Utils.toDefaultValue(defaults[this.constructor._timestampAttributes.updatedAt], this.sequelize.options.dialect);\r\n        delete defaults[this.constructor._timestampAttributes.updatedAt];\r\n      }\r\n\r\n      if (this.constructor._timestampAttributes.deletedAt && defaults[this.constructor._timestampAttributes.deletedAt]) {\r\n        this.dataValues[this.constructor._timestampAttributes.deletedAt] = Utils.toDefaultValue(defaults[this.constructor._timestampAttributes.deletedAt], this.sequelize.options.dialect);\r\n        delete defaults[this.constructor._timestampAttributes.deletedAt];\r\n      }\r\n\r\n      if (Object.keys(defaults).length) {\r\n        for (key in defaults) {\r\n          if (values[key] === undefined) {\r\n            this.set(key, Utils.toDefaultValue(defaults[key], this.sequelize.options.dialect), { raw: true });\r\n            delete values[key];\r\n          }\r\n        }\r\n      }\r\n    }\r\n\r\n    this.set(values, options);\r\n  }\r\n\r\n  // validateIncludedElements should have been called before this method\r\n  static _paranoidClause(model, options = {}) {\r\n    // Apply on each include\r\n    // This should be handled before handling where conditions because of logic with returns\r\n    // otherwise this code will never run on includes of a already conditionable where\r\n    if (options.include) {\r\n      for (const include of options.include) {\r\n        this._paranoidClause(include.model, include);\r\n      }\r\n    }\r\n\r\n    // apply paranoid when groupedLimit is used\r\n    if (_.get(options, 'groupedLimit.on.options.paranoid')) {\r\n      const throughModel = _.get(options, 'groupedLimit.on.through.model');\r\n      if (throughModel) {\r\n        options.groupedLimit.through = this._paranoidClause(throughModel, options.groupedLimit.through);\r\n      }\r\n    }\r\n\r\n    if (!model.options.timestamps || !model.options.paranoid || options.paranoid === false) {\r\n      // This model is not paranoid, nothing to do here;\r\n      return options;\r\n    }\r\n\r\n    const deletedAtCol = model._timestampAttributes.deletedAt;\r\n    const deletedAtAttribute = model.rawAttributes[deletedAtCol];\r\n    const deletedAtObject = {};\r\n\r\n    let deletedAtDefaultValue = Object.prototype.hasOwnProperty.call(deletedAtAttribute, 'defaultValue') ? deletedAtAttribute.defaultValue : null;\r\n\r\n    deletedAtDefaultValue = deletedAtDefaultValue || {\r\n      [Op.eq]: null\r\n    };\r\n\r\n    deletedAtObject[deletedAtAttribute.field || deletedAtCol] = deletedAtDefaultValue;\r\n\r\n    if (Utils.isWhereEmpty(options.where)) {\r\n      options.where = deletedAtObject;\r\n    } else {\r\n      options.where = { [Op.and]: [deletedAtObject, options.where] };\r\n    }\r\n\r\n    return options;\r\n  }\r\n\r\n  static _addDefaultAttributes() {\r\n    const tail = {};\r\n    let head = {};\r\n\r\n    // Add id if no primary key was manually added to definition\r\n    // Can't use this.primaryKeys here, since this function is called before PKs are identified\r\n    if (!_.some(this.rawAttributes, 'primaryKey')) {\r\n      if ('id' in this.rawAttributes) {\r\n        // Something is fishy here!\r\n        throw new Error(`A column called 'id' was added to the attributes of '${this.tableName}' but not marked with 'primaryKey: true'`);\r\n      }\r\n\r\n      head = {\r\n        id: {\r\n          type: new DataTypes.INTEGER(),\r\n          allowNull: false,\r\n          primaryKey: true,\r\n          autoIncrement: true,\r\n          _autoGenerated: true\r\n        }\r\n      };\r\n    }\r\n\r\n    if (this._timestampAttributes.createdAt) {\r\n      tail[this._timestampAttributes.createdAt] = {\r\n        type: DataTypes.DATE,\r\n        allowNull: false,\r\n        _autoGenerated: true\r\n      };\r\n    }\r\n\r\n    if (this._timestampAttributes.updatedAt) {\r\n      tail[this._timestampAttributes.updatedAt] = {\r\n        type: DataTypes.DATE,\r\n        allowNull: false,\r\n        _autoGenerated: true\r\n      };\r\n    }\r\n\r\n    if (this._timestampAttributes.deletedAt) {\r\n      tail[this._timestampAttributes.deletedAt] = {\r\n        type: DataTypes.DATE,\r\n        _autoGenerated: true\r\n      };\r\n    }\r\n\r\n    if (this._versionAttribute) {\r\n      tail[this._versionAttribute] = {\r\n        type: DataTypes.INTEGER,\r\n        allowNull: false,\r\n        defaultValue: 0,\r\n        _autoGenerated: true\r\n      };\r\n    }\r\n\r\n    const existingAttributes = _.clone(this.rawAttributes);\r\n    this.rawAttributes = {};\r\n\r\n    _.each(head, (value, attr) => {\r\n      this.rawAttributes[attr] = value;\r\n    });\r\n\r\n    _.each(existingAttributes, (value, attr) => {\r\n      this.rawAttributes[attr] = value;\r\n    });\r\n\r\n    _.each(tail, (value, attr) => {\r\n      if (this.rawAttributes[attr] === undefined) {\r\n        this.rawAttributes[attr] = value;\r\n      }\r\n    });\r\n\r\n    if (!Object.keys(this.primaryKeys).length) {\r\n      this.primaryKeys.id = this.rawAttributes.id;\r\n    }\r\n  }\r\n\r\n  static _findAutoIncrementAttribute() {\r\n    this.autoIncrementAttribute = null;\r\n\r\n    for (const name in this.rawAttributes) {\r\n      if (Object.prototype.hasOwnProperty.call(this.rawAttributes, name)) {\r\n        const definition = this.rawAttributes[name];\r\n        if (definition && definition.autoIncrement) {\r\n          if (this.autoIncrementAttribute) {\r\n            throw new Error('Invalid Instance definition. Only one autoincrement field allowed.');\r\n          }\r\n          this.autoIncrementAttribute = name;\r\n        }\r\n      }\r\n    }\r\n  }\r\n\r\n  static _conformIncludes(options, self) {\r\n    if (!options.include) return;\r\n\r\n    // if include is not an array, wrap in an array\r\n    if (!Array.isArray(options.include)) {\r\n      options.include = [options.include];\r\n    } else if (!options.include.length) {\r\n      delete options.include;\r\n      return;\r\n    }\r\n\r\n    // convert all included elements to { model: Model } form\r\n    options.include = options.include.map(include => this._conformInclude(include, self));\r\n  }\r\n\r\n  static _transformStringAssociation(include, self) {\r\n    if (self && typeof include === 'string') {\r\n      if (!Object.prototype.hasOwnProperty.call(self.associations, include)) {\r\n        throw new Error(`Association with alias \"${include}\" does not exist on ${self.name}`);\r\n      }\r\n      return self.associations[include];\r\n    }\r\n    return include;\r\n  }\r\n\r\n  static _conformInclude(include, self) {\r\n    if (include) {\r\n      let model;\r\n\r\n      if (include._pseudo) return include;\r\n\r\n      include = this._transformStringAssociation(include, self);\r\n\r\n      if (include instanceof Association) {\r\n        if (self && include.target.name === self.name) {\r\n          model = include.source;\r\n        } else {\r\n          model = include.target;\r\n        }\r\n\r\n        return { model, association: include, as: include.as };\r\n      }\r\n\r\n      if (include.prototype && include.prototype instanceof Model) {\r\n        return { model: include };\r\n      }\r\n\r\n      if (_.isPlainObject(include)) {\r\n        if (include.association) {\r\n          include.association = this._transformStringAssociation(include.association, self);\r\n\r\n          if (self && include.association.target.name === self.name) {\r\n            model = include.association.source;\r\n          } else {\r\n            model = include.association.target;\r\n          }\r\n\r\n          if (!include.model) include.model = model;\r\n          if (!include.as) include.as = include.association.as;\r\n\r\n          this._conformIncludes(include, model);\r\n          return include;\r\n        }\r\n\r\n        if (include.model) {\r\n          this._conformIncludes(include, include.model);\r\n          return include;\r\n        }\r\n\r\n        if (include.all) {\r\n          this._conformIncludes(include);\r\n          return include;\r\n        }\r\n      }\r\n    }\r\n\r\n    throw new Error('Include unexpected. Element has to be either a Model, an Association or an object.');\r\n  }\r\n\r\n  static _expandIncludeAllElement(includes, include) {\r\n    // check 'all' attribute provided is valid\r\n    let all = include.all;\r\n    delete include.all;\r\n\r\n    if (all !== true) {\r\n      if (!Array.isArray(all)) {\r\n        all = [all];\r\n      }\r\n\r\n      const validTypes = {\r\n        BelongsTo: true,\r\n        HasOne: true,\r\n        HasMany: true,\r\n        One: ['BelongsTo', 'HasOne'],\r\n        Has: ['HasOne', 'HasMany'],\r\n        Many: ['HasMany']\r\n      };\r\n\r\n      for (let i = 0; i < all.length; i++) {\r\n        const type = all[i];\r\n        if (type === 'All') {\r\n          all = true;\r\n          break;\r\n        }\r\n\r\n        const types = validTypes[type];\r\n        if (!types) {\r\n          throw new sequelizeErrors.EagerLoadingError(`include all '${type}' is not valid - must be BelongsTo, HasOne, HasMany, One, Has, Many or All`);\r\n        }\r\n\r\n        if (types !== true) {\r\n          // replace type placeholder e.g. 'One' with its constituent types e.g. 'HasOne', 'BelongsTo'\r\n          all.splice(i, 1);\r\n          i--;\r\n          for (let j = 0; j < types.length; j++) {\r\n            if (!all.includes(types[j])) {\r\n              all.unshift(types[j]);\r\n              i++;\r\n            }\r\n          }\r\n        }\r\n      }\r\n    }\r\n\r\n    // add all associations of types specified to includes\r\n    const nested = include.nested;\r\n    if (nested) {\r\n      delete include.nested;\r\n\r\n      if (!include.include) {\r\n        include.include = [];\r\n      } else if (!Array.isArray(include.include)) {\r\n        include.include = [include.include];\r\n      }\r\n    }\r\n\r\n    const used = [];\r\n    (function addAllIncludes(parent, includes) {\r\n      _.forEach(parent.associations, association => {\r\n        if (all !== true && !all.includes(association.associationType)) {\r\n          return;\r\n        }\r\n\r\n        // check if model already included, and skip if so\r\n        const model = association.target;\r\n        const as = association.options.as;\r\n\r\n        const predicate = { model };\r\n        if (as) {\r\n          // We only add 'as' to the predicate if it actually exists\r\n          predicate.as = as;\r\n        }\r\n\r\n        if (_.some(includes, predicate)) {\r\n          return;\r\n        }\r\n\r\n        // skip if recursing over a model already nested\r\n        if (nested && used.includes(model)) {\r\n          return;\r\n        }\r\n        used.push(parent);\r\n\r\n        // include this model\r\n        const thisInclude = Utils.cloneDeep(include);\r\n        thisInclude.model = model;\r\n        if (as) {\r\n          thisInclude.as = as;\r\n        }\r\n        includes.push(thisInclude);\r\n\r\n        // run recursively if nested\r\n        if (nested) {\r\n          addAllIncludes(model, thisInclude.include);\r\n          if (thisInclude.include.length === 0) delete thisInclude.include;\r\n        }\r\n      });\r\n      used.pop();\r\n    })(this, includes);\r\n  }\r\n\r\n  static _validateIncludedElements(options, tableNames) {\r\n    if (!options.model) options.model = this;\r\n\r\n    tableNames = tableNames || {};\r\n    options.includeNames = [];\r\n    options.includeMap = {};\r\n\r\n    /* Legacy */\r\n    options.hasSingleAssociation = false;\r\n    options.hasMultiAssociation = false;\r\n\r\n    if (!options.parent) {\r\n      options.topModel = options.model;\r\n      options.topLimit = options.limit;\r\n    }\r\n\r\n    options.include = options.include.map(include => {\r\n      include = this._conformInclude(include);\r\n      include.parent = options;\r\n      include.topLimit = options.topLimit;\r\n\r\n      this._validateIncludedElement.call(options.model, include, tableNames, options);\r\n\r\n      if (include.duplicating === undefined) {\r\n        include.duplicating = include.association.isMultiAssociation;\r\n      }\r\n\r\n      include.hasDuplicating = include.hasDuplicating || include.duplicating;\r\n      include.hasRequired = include.hasRequired || include.required;\r\n\r\n      options.hasDuplicating = options.hasDuplicating || include.hasDuplicating;\r\n      options.hasRequired = options.hasRequired || include.required;\r\n\r\n      options.hasWhere = options.hasWhere || include.hasWhere || !!include.where;\r\n      return include;\r\n    });\r\n\r\n    for (const include of options.include) {\r\n      include.hasParentWhere = options.hasParentWhere || !!options.where;\r\n      include.hasParentRequired = options.hasParentRequired || !!options.required;\r\n\r\n      if (include.subQuery !== false && options.hasDuplicating && options.topLimit) {\r\n        if (include.duplicating) {\r\n          include.subQuery = false;\r\n          include.subQueryFilter = include.hasRequired;\r\n        } else {\r\n          include.subQuery = include.hasRequired;\r\n          include.subQueryFilter = false;\r\n        }\r\n      } else {\r\n        include.subQuery = include.subQuery || false;\r\n        if (include.duplicating) {\r\n          include.subQueryFilter = include.subQuery;\r\n          include.subQuery = false;\r\n        } else {\r\n          include.subQueryFilter = false;\r\n          include.subQuery = include.subQuery || include.hasParentRequired && include.hasRequired;\r\n        }\r\n      }\r\n\r\n      options.includeMap[include.as] = include;\r\n      options.includeNames.push(include.as);\r\n\r\n      // Set top level options\r\n      if (options.topModel === options.model && options.subQuery === undefined && options.topLimit) {\r\n        if (include.subQuery) {\r\n          options.subQuery = include.subQuery;\r\n        } else if (include.hasDuplicating) {\r\n          options.subQuery = true;\r\n        }\r\n      }\r\n\r\n      /* Legacy */\r\n      options.hasIncludeWhere = options.hasIncludeWhere || include.hasIncludeWhere || !!include.where;\r\n      options.hasIncludeRequired = options.hasIncludeRequired || include.hasIncludeRequired || !!include.required;\r\n\r\n      if (include.association.isMultiAssociation || include.hasMultiAssociation) {\r\n        options.hasMultiAssociation = true;\r\n      }\r\n      if (include.association.isSingleAssociation || include.hasSingleAssociation) {\r\n        options.hasSingleAssociation = true;\r\n      }\r\n    }\r\n\r\n    if (options.topModel === options.model && options.subQuery === undefined) {\r\n      options.subQuery = false;\r\n    }\r\n    return options;\r\n  }\r\n\r\n  static _validateIncludedElement(include, tableNames, options) {\r\n    tableNames[include.model.getTableName()] = true;\r\n\r\n    if (include.attributes && !options.raw) {\r\n      include.model._expandAttributes(include);\r\n\r\n      include.originalAttributes = this._injectDependentVirtualAttributes(include.attributes);\r\n\r\n      include = Utils.mapFinderOptions(include, include.model);\r\n\r\n      if (include.attributes.length) {\r\n        _.each(include.model.primaryKeys, (attr, key) => {\r\n          // Include the primary key if it's not already included - take into account that the pk might be aliased (due to a .field prop)\r\n          if (!include.attributes.some(includeAttr => {\r\n            if (attr.field !== key) {\r\n              return Array.isArray(includeAttr) && includeAttr[0] === attr.field && includeAttr[1] === key;\r\n            }\r\n            return includeAttr === key;\r\n          })) {\r\n            include.attributes.unshift(key);\r\n          }\r\n        });\r\n      }\r\n    } else {\r\n      include = Utils.mapFinderOptions(include, include.model);\r\n    }\r\n\r\n    // pseudo include just needed the attribute logic, return\r\n    if (include._pseudo) {\r\n      include.attributes = Object.keys(include.model.tableAttributes);\r\n      return Utils.mapFinderOptions(include, include.model);\r\n    }\r\n\r\n    // check if the current Model is actually associated with the passed Model - or it's a pseudo include\r\n    const association = include.association || this._getIncludedAssociation(include.model, include.as);\r\n\r\n    include.association = association;\r\n    include.as = association.as;\r\n\r\n    // If through, we create a pseudo child include, to ease our parsing later on\r\n    if (include.association.through && Object(include.association.through.model) === include.association.through.model) {\r\n      if (!include.include) include.include = [];\r\n      const through = include.association.through;\r\n\r\n      include.through = _.defaults(include.through || {}, {\r\n        model: through.model,\r\n        as: through.model.name,\r\n        association: {\r\n          isSingleAssociation: true\r\n        },\r\n        _pseudo: true,\r\n        parent: include\r\n      });\r\n\r\n\r\n      if (through.scope) {\r\n        include.through.where = include.through.where ? { [Op.and]: [include.through.where, through.scope] } : through.scope;\r\n      }\r\n\r\n      include.include.push(include.through);\r\n      tableNames[through.tableName] = true;\r\n    }\r\n\r\n    // include.model may be the main model, while the association target may be scoped - thus we need to look at association.target/source\r\n    let model;\r\n    if (include.model.scoped === true) {\r\n      // If the passed model is already scoped, keep that\r\n      model = include.model;\r\n    } else {\r\n      // Otherwise use the model that was originally passed to the association\r\n      model = include.association.target.name === include.model.name ? include.association.target : include.association.source;\r\n    }\r\n\r\n    model._injectScope(include);\r\n\r\n    // This check should happen after injecting the scope, since the scope may contain a .attributes\r\n    if (!include.attributes) {\r\n      include.attributes = Object.keys(include.model.tableAttributes);\r\n    }\r\n\r\n    include = Utils.mapFinderOptions(include, include.model);\r\n\r\n    if (include.required === undefined) {\r\n      include.required = !!include.where;\r\n    }\r\n\r\n    if (include.association.scope) {\r\n      include.where = include.where ? { [Op.and]: [include.where, include.association.scope] } : include.association.scope;\r\n    }\r\n\r\n    if (include.limit && include.separate === undefined) {\r\n      include.separate = true;\r\n    }\r\n\r\n    if (include.separate === true) {\r\n      if (!(include.association instanceof HasMany)) {\r\n        throw new Error('Only HasMany associations support include.separate');\r\n      }\r\n\r\n      include.duplicating = false;\r\n\r\n      if (\r\n        options.attributes\r\n        && options.attributes.length\r\n        && !_.flattenDepth(options.attributes, 2).includes(association.sourceKey)\r\n      ) {\r\n        options.attributes.push(association.sourceKey);\r\n      }\r\n\r\n      if (\r\n        include.attributes\r\n        && include.attributes.length\r\n        && !_.flattenDepth(include.attributes, 2).includes(association.foreignKey)\r\n      ) {\r\n        include.attributes.push(association.foreignKey);\r\n      }\r\n    }\r\n\r\n    // Validate child includes\r\n    if (Object.prototype.hasOwnProperty.call(include, 'include')) {\r\n      this._validateIncludedElements.call(include.model, include, tableNames);\r\n    }\r\n\r\n    return include;\r\n  }\r\n\r\n  static _getIncludedAssociation(targetModel, targetAlias) {\r\n    const associations = this.getAssociations(targetModel);\r\n    let association = null;\r\n    if (associations.length === 0) {\r\n      throw new sequelizeErrors.EagerLoadingError(`${targetModel.name} is not associated to ${this.name}!`);\r\n    }\r\n    if (associations.length === 1) {\r\n      association = this.getAssociationForAlias(targetModel, targetAlias);\r\n      if (association) {\r\n        return association;\r\n      }\r\n      if (targetAlias) {\r\n        const existingAliases = this.getAssociations(targetModel).map(association => association.as);\r\n        throw new sequelizeErrors.EagerLoadingError(`${targetModel.name} is associated to ${this.name} using an alias. ` +\r\n          `You've included an alias (${targetAlias}), but it does not match the alias(es) defined in your association (${existingAliases.join(', ')}).`);\r\n      }\r\n      throw new sequelizeErrors.EagerLoadingError(`${targetModel.name} is associated to ${this.name} using an alias. ` +\r\n        'You must use the \\'as\\' keyword to specify the alias within your include statement.');\r\n    }\r\n    association = this.getAssociationForAlias(targetModel, targetAlias);\r\n    if (!association) {\r\n      throw new sequelizeErrors.EagerLoadingError(`${targetModel.name} is associated to ${this.name} multiple times. ` +\r\n        'To identify the correct association, you must use the \\'as\\' keyword to specify the alias of the association you want to include.');\r\n    }\r\n    return association;\r\n  }\r\n\r\n\r\n  static _expandIncludeAll(options) {\r\n    const includes = options.include;\r\n    if (!includes) {\r\n      return;\r\n    }\r\n\r\n    for (let index = 0; index < includes.length; index++) {\r\n      const include = includes[index];\r\n\r\n      if (include.all) {\r\n        includes.splice(index, 1);\r\n        index--;\r\n\r\n        this._expandIncludeAllElement(includes, include);\r\n      }\r\n    }\r\n\r\n    includes.forEach(include => {\r\n      this._expandIncludeAll.call(include.model, include);\r\n    });\r\n  }\r\n\r\n  static _conformIndex(index) {\r\n    if (!index.fields) {\r\n      throw new Error('Missing \"fields\" property for index definition');\r\n    }\r\n\r\n    index = _.defaults(index, {\r\n      type: '',\r\n      parser: null\r\n    });\r\n\r\n    if (index.type && index.type.toLowerCase() === 'unique') {\r\n      index.unique = true;\r\n      delete index.type;\r\n    }\r\n\r\n    return index;\r\n  }\r\n\r\n\r\n  static _uniqIncludes(options) {\r\n    if (!options.include) return;\r\n\r\n    options.include = _(options.include)\r\n      .groupBy(include => `${include.model && include.model.name}-${include.as}`)\r\n      .map(includes => this._assignOptions(...includes))\r\n      .value();\r\n  }\r\n\r\n  static _baseMerge(...args) {\r\n    _.assignWith(...args);\r\n    this._conformIncludes(args[0], this);\r\n    this._uniqIncludes(args[0]);\r\n    return args[0];\r\n  }\r\n\r\n  static _mergeFunction(objValue, srcValue, key) {\r\n    if (Array.isArray(objValue) && Array.isArray(srcValue)) {\r\n      return _.union(objValue, srcValue);\r\n    }\r\n    if (key === 'where' || key === 'having') {\r\n      if (srcValue instanceof Utils.SequelizeMethod) {\r\n        srcValue = { [Op.and]: srcValue };\r\n      }\r\n      if (_.isPlainObject(objValue) && _.isPlainObject(srcValue)) {\r\n        return Object.assign(objValue, srcValue);\r\n      }\r\n    } else if (key === 'attributes' && _.isPlainObject(objValue) && _.isPlainObject(srcValue)) {\r\n      return _.assignWith(objValue, srcValue, (objValue, srcValue) => {\r\n        if (Array.isArray(objValue) && Array.isArray(srcValue)) {\r\n          return _.union(objValue, srcValue);\r\n        }\r\n      });\r\n    }\r\n    // If we have a possible object/array to clone, we try it.\r\n    // Otherwise, we return the original value when it's not undefined,\r\n    // or the resulting object in that case.\r\n    if (srcValue) {\r\n      return Utils.cloneDeep(srcValue, true);\r\n    }\r\n    return srcValue === undefined ? objValue : srcValue;\r\n  }\r\n\r\n  static _assignOptions(...args) {\r\n    return this._baseMerge(...args, this._mergeFunction);\r\n  }\r\n\r\n  static _defaultsOptions(target, opts) {\r\n    return this._baseMerge(target, opts, (srcValue, objValue, key) => {\r\n      return this._mergeFunction(objValue, srcValue, key);\r\n    });\r\n  }\r\n\r\n  /**\r\n   * Initialize a model, representing a table in the DB, with attributes and options.\r\n   *\r\n   * The table columns are defined by the hash that is given as the first argument.\r\n   * Each attribute of the hash represents a column.\r\n   *\r\n   * For more about <a href=\"/manual/tutorial/models-definition.html#validations\"/>Validations</a>\r\n   *\r\n   * More examples, <a href=\"/manual/tutorial/models-definition.html\"/>Model Definition</a>\r\n   *\r\n   * @example\r\n   * Project.init({\r\n   *   columnA: {\r\n   *     type: Sequelize.BOOLEAN,\r\n   *     validate: {\r\n   *       is: ['[a-z]','i'],        // will only allow letters\r\n   *       max: 23,                  // only allow values <= 23\r\n   *       isIn: {\r\n   *         args: [['en', 'zh']],\r\n   *         msg: \"Must be English or Chinese\"\r\n   *       }\r\n   *     },\r\n   *     field: 'column_a'\r\n   *     // Other attributes here\r\n   *   },\r\n   *   columnB: Sequelize.STRING,\r\n   *   columnC: 'MY VERY OWN COLUMN TYPE'\r\n   * }, {sequelize})\r\n   *\r\n   * sequelize.models.modelName // The model will now be available in models under the class name\r\n   *\r\n   * @see\r\n   * {@link DataTypes}\r\n   * @see\r\n   * {@link Hooks}\r\n   *\r\n   * @param {Object}                  attributes An object, where each attribute is a column of the table. Each column can be either a DataType, a string or a type-description object, with the properties described below:\r\n   * @param {string|DataTypes|Object} attributes.column The description of a database column\r\n   * @param {string|DataTypes}        attributes.column.type A string or a data type\r\n   * @param {boolean}                 [attributes.column.allowNull=true] If false, the column will have a NOT NULL constraint, and a not null validation will be run before an instance is saved.\r\n   * @param {any}                     [attributes.column.defaultValue=null] A literal default value, a JavaScript function, or an SQL function (see `sequelize.fn`)\r\n   * @param {string|boolean}          [attributes.column.unique=false] If true, the column will get a unique constraint. If a string is provided, the column will be part of a composite unique index. If multiple columns have the same string, they will be part of the same unique index\r\n   * @param {boolean}                 [attributes.column.primaryKey=false] If true, this attribute will be marked as primary key\r\n   * @param {string}                  [attributes.column.field=null] If set, sequelize will map the attribute name to a different name in the database\r\n   * @param {boolean}                 [attributes.column.autoIncrement=false] If true, this column will be set to auto increment\r\n   * @param {boolean}                 [attributes.column.autoIncrementIdentity=false] If true, combined with autoIncrement=true, will use Postgres `GENERATED BY DEFAULT AS IDENTITY` instead of `SERIAL`. Postgres 10+ only.\r\n   * @param {string}                  [attributes.column.comment=null] Comment for this column\r\n   * @param {string|Model}            [attributes.column.references=null] An object with reference configurations\r\n   * @param {string|Model}            [attributes.column.references.model] If this column references another table, provide it here as a Model, or a string\r\n   * @param {string}                  [attributes.column.references.key='id'] The column of the foreign table that this column references\r\n   * @param {string}                  [attributes.column.onUpdate] What should happen when the referenced key is updated. One of CASCADE, RESTRICT, SET DEFAULT, SET NULL or NO ACTION\r\n   * @param {string}                  [attributes.column.onDelete] What should happen when the referenced key is deleted. One of CASCADE, RESTRICT, SET DEFAULT, SET NULL or NO ACTION\r\n   * @param {Function}                [attributes.column.get] Provide a custom getter for this column. Use `this.getDataValue(String)` to manipulate the underlying values.\r\n   * @param {Function}                [attributes.column.set] Provide a custom setter for this column. Use `this.setDataValue(String, Value)` to manipulate the underlying values.\r\n   * @param {Object}                  [attributes.column.validate] An object of validations to execute for this column every time the model is saved. Can be either the name of a validation provided by validator.js, a validation function provided by extending validator.js (see the `DAOValidator` property for more details), or a custom validation function. Custom validation functions are called with the value of the field and the instance itself as the `this` binding, and can possibly take a second callback argument, to signal that they are asynchronous. If the validator is sync, it should throw in the case of a failed validation; if it is async, the callback should be called with the error text.\r\n   * @param {Object}                  options These options are merged with the default define options provided to the Sequelize constructor\r\n   * @param {Object}                  options.sequelize Define the sequelize instance to attach to the new Model. Throw error if none is provided.\r\n   * @param {string}                  [options.modelName] Set name of the model. By default its same as Class name.\r\n   * @param {Object}                  [options.defaultScope={}] Define the default search scope to use for this model. Scopes have the same form as the options passed to find / findAll\r\n   * @param {Object}                  [options.scopes] More scopes, defined in the same way as defaultScope above. See `Model.scope` for more information about how scopes are defined, and what you can do with them\r\n   * @param {boolean}                 [options.omitNull] Don't persist null values. This means that all columns with null values will not be saved\r\n   * @param {boolean}                 [options.timestamps=true] Adds createdAt and updatedAt timestamps to the model.\r\n   * @param {boolean}                 [options.paranoid=false] Calling `destroy` will not delete the model, but instead set a `deletedAt` timestamp if this is true. Needs `timestamps=true` to work\r\n   * @param {boolean}                 [options.underscored=false] Add underscored field to all attributes, this covers user defined attributes, timestamps and foreign keys. Will not affect attributes with explicitly set `field` option\r\n   * @param {boolean}                 [options.freezeTableName=false] If freezeTableName is true, sequelize will not try to alter the model name to get the table name. Otherwise, the model name will be pluralized\r\n   * @param {Object}                  [options.name] An object with two attributes, `singular` and `plural`, which are used when this model is associated to others.\r\n   * @param {string}                  [options.name.singular=Utils.singularize(modelName)] Singular name for model\r\n   * @param {string}                  [options.name.plural=Utils.pluralize(modelName)] Plural name for model\r\n   * @param {Array<Object>}           [options.indexes] indexes definitions\r\n   * @param {string}                  [options.indexes[].name] The name of the index. Defaults to model name + _ + fields concatenated\r\n   * @param {string}                  [options.indexes[].type] Index type. Only used by mysql. One of `UNIQUE`, `FULLTEXT` and `SPATIAL`\r\n   * @param {string}                  [options.indexes[].using] The method to create the index by (`USING` statement in SQL). BTREE and HASH are supported by mysql and postgres, and postgres additionally supports GIST and GIN.\r\n   * @param {string}                  [options.indexes[].operator] Specify index operator.\r\n   * @param {boolean}                 [options.indexes[].unique=false] Should the index by unique? Can also be triggered by setting type to `UNIQUE`\r\n   * @param {boolean}                 [options.indexes[].concurrently=false] PostgresSQL will build the index without taking any write locks. Postgres only\r\n   * @param {Array<string|Object>}    [options.indexes[].fields] An array of the fields to index. Each field can either be a string containing the name of the field, a sequelize object (e.g `sequelize.fn`), or an object with the following attributes: `attribute` (field name), `length` (create a prefix index of length chars), `order` (the direction the column should be sorted in), `collate` (the collation (sort order) for the column)\r\n   * @param {string|boolean}          [options.createdAt] Override the name of the createdAt attribute if a string is provided, or disable it if false. Timestamps must be true. Underscored field will be set with underscored setting.\r\n   * @param {string|boolean}          [options.updatedAt] Override the name of the updatedAt attribute if a string is provided, or disable it if false. Timestamps must be true. Underscored field will be set with underscored setting.\r\n   * @param {string|boolean}          [options.deletedAt] Override the name of the deletedAt attribute if a string is provided, or disable it if false. Timestamps must be true. Underscored field will be set with underscored setting.\r\n   * @param {string}                  [options.tableName] Defaults to pluralized model name, unless freezeTableName is true, in which case it uses model name verbatim\r\n   * @param {string}                  [options.schema='public'] schema\r\n   * @param {string}                  [options.engine] Specify engine for model's table\r\n   * @param {string}                  [options.charset] Specify charset for model's table\r\n   * @param {string}                  [options.comment] Specify comment for model's table\r\n   * @param {string}                  [options.collate] Specify collation for model's table\r\n   * @param {string}                  [options.initialAutoIncrement] Set the initial AUTO_INCREMENT value for the table in MySQL.\r\n   * @param {Object}                  [options.hooks] An object of hook function that are called before and after certain lifecycle events. The possible hooks are: beforeValidate, afterValidate, validationFailed, beforeBulkCreate, beforeBulkDestroy, beforeBulkUpdate, beforeCreate, beforeDestroy, beforeUpdate, afterCreate, beforeSave, afterDestroy, afterUpdate, afterBulkCreate, afterSave, afterBulkDestroy and afterBulkUpdate. See Hooks for more information about hook functions and their signatures. Each property can either be a function, or an array of functions.\r\n   * @param {Object}                  [options.validate] An object of model wide validations. Validations have access to all model values via `this`. If the validator function takes an argument, it is assumed to be async, and is called with a callback that accepts an optional error.\r\n   *\r\n   * @returns {Model}\r\n   */\r\n  static init(attributes, options = {}) {\r\n    if (!options.sequelize) {\r\n      throw new Error('No Sequelize instance passed');\r\n    }\r\n\r\n    this.sequelize = options.sequelize;\r\n\r\n    const globalOptions = this.sequelize.options;\r\n\r\n    options = Utils.merge(_.cloneDeep(globalOptions.define), options);\r\n\r\n    if (!options.modelName) {\r\n      options.modelName = this.name;\r\n    }\r\n\r\n    options = Utils.merge({\r\n      name: {\r\n        plural: Utils.pluralize(options.modelName),\r\n        singular: Utils.singularize(options.modelName)\r\n      },\r\n      indexes: [],\r\n      omitNull: globalOptions.omitNull,\r\n      schema: globalOptions.schema\r\n    }, options);\r\n\r\n    this.sequelize.runHooks('beforeDefine', attributes, options);\r\n\r\n    if (options.modelName !== this.name) {\r\n      Object.defineProperty(this, 'name', { value: options.modelName });\r\n    }\r\n    delete options.modelName;\r\n\r\n    this.options = Object.assign({\r\n      timestamps: true,\r\n      validate: {},\r\n      freezeTableName: false,\r\n      underscored: false,\r\n      paranoid: false,\r\n      rejectOnEmpty: false,\r\n      whereCollection: null,\r\n      schema: null,\r\n      schemaDelimiter: '',\r\n      defaultScope: {},\r\n      scopes: {},\r\n      indexes: []\r\n    }, options);\r\n\r\n    // if you call \"define\" multiple times for the same modelName, do not clutter the factory\r\n    if (this.sequelize.isDefined(this.name)) {\r\n      this.sequelize.modelManager.removeModel(this.sequelize.modelManager.getModel(this.name));\r\n    }\r\n\r\n    this.associations = {};\r\n    this._setupHooks(options.hooks);\r\n\r\n    this.underscored = this.options.underscored;\r\n\r\n    if (!this.options.tableName) {\r\n      this.tableName = this.options.freezeTableName ? this.name : Utils.underscoredIf(Utils.pluralize(this.name), this.underscored);\r\n    } else {\r\n      this.tableName = this.options.tableName;\r\n    }\r\n\r\n    this._schema = this.options.schema;\r\n    this._schemaDelimiter = this.options.schemaDelimiter;\r\n\r\n    // error check options\r\n    _.each(options.validate, (validator, validatorType) => {\r\n      if (Object.prototype.hasOwnProperty.call(attributes, validatorType)) {\r\n        throw new Error(`A model validator function must not have the same name as a field. Model: ${this.name}, field/validation name: ${validatorType}`);\r\n      }\r\n\r\n      if (typeof validator !== 'function') {\r\n        throw new Error(`Members of the validate option must be functions. Model: ${this.name}, error with validate member ${validatorType}`);\r\n      }\r\n    });\r\n\r\n    this.rawAttributes = _.mapValues(attributes, (attribute, name) => {\r\n      attribute = this.sequelize.normalizeAttribute(attribute);\r\n\r\n      if (attribute.type === undefined) {\r\n        throw new Error(`Unrecognized datatype for attribute \"${this.name}.${name}\"`);\r\n      }\r\n\r\n      if (attribute.allowNull !== false && _.get(attribute, 'validate.notNull')) {\r\n        throw new Error(`Invalid definition for \"${this.name}.${name}\", \"notNull\" validator is only allowed with \"allowNull:false\"`);\r\n      }\r\n\r\n      if (_.get(attribute, 'references.model.prototype') instanceof Model) {\r\n        attribute.references.model = attribute.references.model.getTableName();\r\n      }\r\n\r\n      return attribute;\r\n    });\r\n\r\n    const tableName = this.getTableName();\r\n    this._indexes = this.options.indexes\r\n      .map(index => Utils.nameIndex(this._conformIndex(index), tableName));\r\n\r\n    this.primaryKeys = {};\r\n    this._readOnlyAttributes = new Set();\r\n    this._timestampAttributes = {};\r\n\r\n    // setup names of timestamp attributes\r\n    if (this.options.timestamps) {\r\n      if (this.options.createdAt !== false) {\r\n        this._timestampAttributes.createdAt = this.options.createdAt || 'createdAt';\r\n        this._readOnlyAttributes.add(this._timestampAttributes.createdAt);\r\n      }\r\n      if (this.options.updatedAt !== false) {\r\n        this._timestampAttributes.updatedAt = this.options.updatedAt || 'updatedAt';\r\n        this._readOnlyAttributes.add(this._timestampAttributes.updatedAt);\r\n      }\r\n      if (this.options.paranoid && this.options.deletedAt !== false) {\r\n        this._timestampAttributes.deletedAt = this.options.deletedAt || 'deletedAt';\r\n        this._readOnlyAttributes.add(this._timestampAttributes.deletedAt);\r\n      }\r\n    }\r\n\r\n    // setup name for version attribute\r\n    if (this.options.version) {\r\n      this._versionAttribute = typeof this.options.version === 'string' ? this.options.version : 'version';\r\n      this._readOnlyAttributes.add(this._versionAttribute);\r\n    }\r\n\r\n    this._hasReadOnlyAttributes = this._readOnlyAttributes.size > 0;\r\n\r\n    // Add head and tail default attributes (id, timestamps)\r\n    this._addDefaultAttributes();\r\n    this.refreshAttributes();\r\n    this._findAutoIncrementAttribute();\r\n\r\n    this._scope = this.options.defaultScope;\r\n    this._scopeNames = ['defaultScope'];\r\n\r\n    this.sequelize.modelManager.addModel(this);\r\n    this.sequelize.runHooks('afterDefine', this);\r\n\r\n    return this;\r\n  }\r\n\r\n  static refreshAttributes() {\r\n    const attributeManipulation = {};\r\n\r\n    this.prototype._customGetters = {};\r\n    this.prototype._customSetters = {};\r\n\r\n    ['get', 'set'].forEach(type => {\r\n      const opt = `${type}terMethods`;\r\n      const funcs = _.clone(_.isObject(this.options[opt]) ? this.options[opt] : {});\r\n      const _custom = type === 'get' ? this.prototype._customGetters : this.prototype._customSetters;\r\n\r\n      _.each(funcs, (method, attribute) => {\r\n        _custom[attribute] = method;\r\n\r\n        if (type === 'get') {\r\n          funcs[attribute] = function() {\r\n            return this.get(attribute);\r\n          };\r\n        }\r\n        if (type === 'set') {\r\n          funcs[attribute] = function(value) {\r\n            return this.set(attribute, value);\r\n          };\r\n        }\r\n      });\r\n\r\n      _.each(this.rawAttributes, (options, attribute) => {\r\n        if (Object.prototype.hasOwnProperty.call(options, type)) {\r\n          _custom[attribute] = options[type];\r\n        }\r\n\r\n        if (type === 'get') {\r\n          funcs[attribute] = function() {\r\n            return this.get(attribute);\r\n          };\r\n        }\r\n        if (type === 'set') {\r\n          funcs[attribute] = function(value) {\r\n            return this.set(attribute, value);\r\n          };\r\n        }\r\n      });\r\n\r\n      _.each(funcs, (fct, name) => {\r\n        if (!attributeManipulation[name]) {\r\n          attributeManipulation[name] = {\r\n            configurable: true\r\n          };\r\n        }\r\n        attributeManipulation[name][type] = fct;\r\n      });\r\n    });\r\n\r\n    this._dataTypeChanges = {};\r\n    this._dataTypeSanitizers = {};\r\n\r\n    this._hasBooleanAttributes = false;\r\n    this._hasDateAttributes = false;\r\n    this._jsonAttributes = new Set();\r\n    this._virtualAttributes = new Set();\r\n    this._defaultValues = {};\r\n    this.prototype.validators = {};\r\n\r\n    this.fieldRawAttributesMap = {};\r\n\r\n    this.primaryKeys = {};\r\n    this.uniqueKeys = {};\r\n\r\n    _.each(this.rawAttributes, (definition, name) => {\r\n      definition.type = this.sequelize.normalizeDataType(definition.type);\r\n\r\n      definition.Model = this;\r\n      definition.fieldName = name;\r\n      definition._modelAttribute = true;\r\n\r\n      if (definition.field === undefined) {\r\n        definition.field = Utils.underscoredIf(name, this.underscored);\r\n      }\r\n\r\n      if (definition.primaryKey === true) {\r\n        this.primaryKeys[name] = definition;\r\n      }\r\n\r\n      this.fieldRawAttributesMap[definition.field] = definition;\r\n\r\n      if (definition.type._sanitize) {\r\n        this._dataTypeSanitizers[name] = definition.type._sanitize;\r\n      }\r\n\r\n      if (definition.type._isChanged) {\r\n        this._dataTypeChanges[name] = definition.type._isChanged;\r\n      }\r\n\r\n      if (definition.type instanceof DataTypes.BOOLEAN) {\r\n        this._hasBooleanAttributes = true;\r\n      } else if (definition.type instanceof DataTypes.DATE || definition.type instanceof DataTypes.DATEONLY) {\r\n        this._hasDateAttributes = true;\r\n      } else if (definition.type instanceof DataTypes.JSON) {\r\n        this._jsonAttributes.add(name);\r\n      } else if (definition.type instanceof DataTypes.VIRTUAL) {\r\n        this._virtualAttributes.add(name);\r\n      }\r\n\r\n      if (Object.prototype.hasOwnProperty.call(definition, 'defaultValue')) {\r\n        this._defaultValues[name] = () => Utils.toDefaultValue(definition.defaultValue, this.sequelize.options.dialect);\r\n      }\r\n\r\n      if (Object.prototype.hasOwnProperty.call(definition, 'unique') && definition.unique) {\r\n        let idxName;\r\n        if (\r\n          typeof definition.unique === 'object' &&\r\n          Object.prototype.hasOwnProperty.call(definition.unique, 'name')\r\n        ) {\r\n          idxName = definition.unique.name;\r\n        } else if (typeof definition.unique === 'string') {\r\n          idxName = definition.unique;\r\n        } else {\r\n          idxName = `${this.tableName}_${name}_unique`;\r\n        }\r\n\r\n        const idx = this.uniqueKeys[idxName] || { fields: [] };\r\n\r\n        idx.fields.push(definition.field);\r\n        idx.msg = idx.msg || definition.unique.msg || null;\r\n        idx.name = idxName || false;\r\n        idx.column = name;\r\n        idx.customIndex = definition.unique !== true;\r\n\r\n        this.uniqueKeys[idxName] = idx;\r\n      }\r\n\r\n      if (Object.prototype.hasOwnProperty.call(definition, 'validate')) {\r\n        this.prototype.validators[name] = definition.validate;\r\n      }\r\n\r\n      if (definition.index === true && definition.type instanceof DataTypes.JSONB) {\r\n        this._indexes.push(\r\n          Utils.nameIndex(\r\n            this._conformIndex({\r\n              fields: [definition.field || name],\r\n              using: 'gin'\r\n            }),\r\n            this.getTableName()\r\n          )\r\n        );\r\n\r\n        delete definition.index;\r\n      }\r\n    });\r\n\r\n    // Create a map of field to attribute names\r\n    this.fieldAttributeMap = _.reduce(this.fieldRawAttributesMap, (map, value, key) => {\r\n      if (key !== value.fieldName) {\r\n        map[key] = value.fieldName;\r\n      }\r\n      return map;\r\n    }, {});\r\n\r\n    this._hasJsonAttributes = !!this._jsonAttributes.size;\r\n\r\n    this._hasVirtualAttributes = !!this._virtualAttributes.size;\r\n\r\n    this._hasDefaultValues = !_.isEmpty(this._defaultValues);\r\n\r\n    this.tableAttributes = _.omitBy(this.rawAttributes, (_a, key) => this._virtualAttributes.has(key));\r\n\r\n    this.prototype._hasCustomGetters = Object.keys(this.prototype._customGetters).length;\r\n    this.prototype._hasCustomSetters = Object.keys(this.prototype._customSetters).length;\r\n\r\n    for (const key of Object.keys(attributeManipulation)) {\r\n      if (Object.prototype.hasOwnProperty.call(Model.prototype, key)) {\r\n        this.sequelize.log(`Not overriding built-in method from model attribute: ${key}`);\r\n        continue;\r\n      }\r\n      Object.defineProperty(this.prototype, key, attributeManipulation[key]);\r\n    }\r\n\r\n    this.prototype.rawAttributes = this.rawAttributes;\r\n    this.prototype._isAttribute = key => Object.prototype.hasOwnProperty.call(this.prototype.rawAttributes, key);\r\n\r\n    // Primary key convenience constiables\r\n    this.primaryKeyAttributes = Object.keys(this.primaryKeys);\r\n    this.primaryKeyAttribute = this.primaryKeyAttributes[0];\r\n    if (this.primaryKeyAttribute) {\r\n      this.primaryKeyField = this.rawAttributes[this.primaryKeyAttribute].field || this.primaryKeyAttribute;\r\n    }\r\n\r\n    this._hasPrimaryKeys = this.primaryKeyAttributes.length > 0;\r\n    this._isPrimaryKey = key => this.primaryKeyAttributes.includes(key);\r\n  }\r\n\r\n  /**\r\n   * Remove attribute from model definition\r\n   *\r\n   * @param {string} attribute name of attribute to remove\r\n   */\r\n  static removeAttribute(attribute) {\r\n    delete this.rawAttributes[attribute];\r\n    this.refreshAttributes();\r\n  }\r\n\r\n  /**\r\n   * Sync this Model to the DB, that is create the table.\r\n   *\r\n   * @param {Object} [options] sync options\r\n   *\r\n   * @see\r\n   * {@link Sequelize#sync} for options\r\n   *\r\n   * @returns {Promise<Model>}\r\n   */\r\n  static sync(options) {\r\n    options = Object.assign({}, this.options, options);\r\n    options.hooks = options.hooks === undefined ? true : !!options.hooks;\r\n\r\n    const attributes = this.tableAttributes;\r\n    const rawAttributes = this.fieldRawAttributesMap;\r\n\r\n    return Promise.try(() => {\r\n      if (options.hooks) {\r\n        return this.runHooks('beforeSync', options);\r\n      }\r\n    }).then(() => {\r\n      if (options.force) {\r\n        return this.drop(options);\r\n      }\r\n    })\r\n      .then(() => this.QueryInterface.createTable(this.getTableName(options), attributes, options, this))\r\n      .then(() => {\r\n        if (!options.alter) {\r\n          return;\r\n        }\r\n        return Promise.all([\r\n          this.QueryInterface.describeTable(this.getTableName(options)),\r\n          this.QueryInterface.getForeignKeyReferencesForTable(this.getTableName(options))\r\n        ])\r\n          .then(tableInfos => {\r\n            const columns = tableInfos[0];\r\n            // Use for alter foreign keys\r\n            const foreignKeyReferences = tableInfos[1];\r\n\r\n            const changes = []; // array of promises to run\r\n            const removedConstraints = {};\r\n\r\n            _.each(attributes, (columnDesc, columnName) => {\r\n              if (!columns[columnName] && !columns[attributes[columnName].field]) {\r\n                changes.push(() => this.QueryInterface.addColumn(this.getTableName(options), attributes[columnName].field || columnName, attributes[columnName]));\r\n              }\r\n            });\r\n            _.each(columns, (columnDesc, columnName) => {\r\n              const currentAttribute = rawAttributes[columnName];\r\n              if (!currentAttribute) {\r\n                changes.push(() => this.QueryInterface.removeColumn(this.getTableName(options), columnName, options));\r\n              } else if (!currentAttribute.primaryKey) {\r\n                // Check foreign keys. If it's a foreign key, it should remove constraint first.\r\n                const references = currentAttribute.references;\r\n                if (currentAttribute.references) {\r\n                  const database = this.sequelize.config.database;\r\n                  const schema = this.sequelize.config.schema;\r\n                  // Find existed foreign keys\r\n                  _.each(foreignKeyReferences, foreignKeyReference => {\r\n                    const constraintName = foreignKeyReference.constraintName;\r\n                    if (!!constraintName\r\n                      && foreignKeyReference.tableCatalog === database\r\n                      && (schema ? foreignKeyReference.tableSchema === schema : true)\r\n                      && foreignKeyReference.referencedTableName === references.model\r\n                      && foreignKeyReference.referencedColumnName === references.key\r\n                      && (schema ? foreignKeyReference.referencedTableSchema === schema : true)\r\n                      && !removedConstraints[constraintName]) {\r\n                      // Remove constraint on foreign keys.\r\n                      changes.push(() => this.QueryInterface.removeConstraint(this.getTableName(options), constraintName, options));\r\n                      removedConstraints[constraintName] = true;\r\n                    }\r\n                  });\r\n                }\r\n                changes.push(() => this.QueryInterface.changeColumn(this.getTableName(options), columnName, currentAttribute));\r\n              }\r\n            });\r\n            return Promise.each(changes, f => f());\r\n          });\r\n      })\r\n      .then(() => this.QueryInterface.showIndex(this.getTableName(options), options))\r\n      .then(indexes => {\r\n        indexes = this._indexes.filter(item1 =>\r\n          !indexes.some(item2 => item1.name === item2.name)\r\n        ).sort((index1, index2) => {\r\n          if (this.sequelize.options.dialect === 'postgres') {\r\n          // move concurrent indexes to the bottom to avoid weird deadlocks\r\n            if (index1.concurrently === true) return 1;\r\n            if (index2.concurrently === true) return -1;\r\n          }\r\n\r\n          return 0;\r\n        });\r\n\r\n        return Promise.each(indexes, index => this.QueryInterface.addIndex(\r\n          this.getTableName(options),\r\n          Object.assign({\r\n            logging: options.logging,\r\n            benchmark: options.benchmark,\r\n            transaction: options.transaction,\r\n            schema: options.schema\r\n          }, index),\r\n          this.tableName\r\n        ));\r\n      }).then(() => {\r\n        if (options.hooks) {\r\n          return this.runHooks('afterSync', options);\r\n        }\r\n      }).return(this);\r\n  }\r\n\r\n  /**\r\n   * Drop the table represented by this Model\r\n   *\r\n   * @param {Object}   [options] drop options\r\n   * @param {boolean}  [options.cascade=false]   Also drop all objects depending on this table, such as views. Only works in postgres\r\n   * @param {Function} [options.logging=false]   A function that gets executed while running the query to log the sql.\r\n   * @param {boolean}  [options.benchmark=false] Pass query execution time in milliseconds as second argument to logging function (options.logging).\r\n   *\r\n   * @returns {Promise}\r\n   */\r\n  static drop(options) {\r\n    return this.QueryInterface.dropTable(this.getTableName(options), options);\r\n  }\r\n\r\n  static dropSchema(schema) {\r\n    return this.QueryInterface.dropSchema(schema);\r\n  }\r\n\r\n  /**\r\n   * Apply a schema to this model. For postgres, this will actually place the schema in front of the table name - `\"schema\".\"tableName\"`,\r\n   * while the schema will be prepended to the table name for mysql and sqlite - `'schema.tablename'`.\r\n   *\r\n   * This method is intended for use cases where the same model is needed in multiple schemas. In such a use case it is important\r\n   * to call `model.schema(schema, [options]).sync()` for each model to ensure the models are created in the correct schema.\r\n   *\r\n   * If a single default schema per model is needed, set the `options.schema='schema'` parameter during the `define()` call\r\n   * for the model.\r\n   *\r\n   * @param {string}   schema The name of the schema\r\n   * @param {Object}   [options] schema options\r\n   * @param {string}   [options.schemaDelimiter='.'] The character(s) that separates the schema name from the table name\r\n   * @param {Function} [options.logging=false] A function that gets executed while running the query to log the sql.\r\n   * @param {boolean}  [options.benchmark=false] Pass query execution time in milliseconds as second argument to logging function (options.logging).\r\n   *\r\n   * @see\r\n   * {@link Sequelize#define} for more information about setting a default schema.\r\n   *\r\n   * @returns {Model}\r\n   */\r\n  static schema(schema, options) {\r\n\r\n    const clone = class extends this {};\r\n    Object.defineProperty(clone, 'name', { value: this.name });\r\n\r\n    clone._schema = schema;\r\n\r\n    if (options) {\r\n      if (typeof options === 'string') {\r\n        clone._schemaDelimiter = options;\r\n      } else if (options.schemaDelimiter) {\r\n        clone._schemaDelimiter = options.schemaDelimiter;\r\n      }\r\n    }\r\n\r\n    return clone;\r\n  }\r\n\r\n  /**\r\n   * Get the table name of the model, taking schema into account. The method will return The name as a string if the model has no schema,\r\n   * or an object with `tableName`, `schema` and `delimiter` properties.\r\n   *\r\n   * @returns {string|Object}\r\n   */\r\n  static getTableName() {\r\n    return this.QueryGenerator.addSchema(this);\r\n  }\r\n\r\n  /**\r\n   * Get un-scoped model\r\n   *\r\n   * @returns {Model}\r\n   */\r\n  static unscoped() {\r\n    return this.scope();\r\n  }\r\n\r\n  /**\r\n   * Add a new scope to the model. This is especially useful for adding scopes with includes, when the model you want to include is not available at the time this model is defined.\r\n   *\r\n   * By default this will throw an error if a scope with that name already exists. Pass `override: true` in the options object to silence this error.\r\n   *\r\n   * @param {string}          name The name of the scope. Use `defaultScope` to override the default scope\r\n   * @param {Object|Function} scope scope or options\r\n   * @param {Object}          [options] scope options\r\n   * @param {boolean}         [options.override=false] override old scope if already defined\r\n   */\r\n  static addScope(name, scope, options) {\r\n    options = Object.assign({\r\n      override: false\r\n    }, options);\r\n\r\n    if ((name === 'defaultScope' && Object.keys(this.options.defaultScope).length > 0 || name in this.options.scopes) && options.override === false) {\r\n      throw new Error(`The scope ${name} already exists. Pass { override: true } as options to silence this error`);\r\n    }\r\n\r\n    if (name === 'defaultScope') {\r\n      this.options.defaultScope = this._scope = scope;\r\n    } else {\r\n      this.options.scopes[name] = scope;\r\n    }\r\n  }\r\n\r\n  /**\r\n   * Apply a scope created in `define` to the model.\r\n   *\r\n   * @example <caption>how to create scopes</caption>\r\n   * const Model = sequelize.define('model', attributes, {\r\n   *   defaultScope: {\r\n   *     where: {\r\n   *       username: 'dan'\r\n   *     },\r\n   *     limit: 12\r\n   *   },\r\n   *   scopes: {\r\n   *     isALie: {\r\n   *       where: {\r\n   *         stuff: 'cake'\r\n   *       }\r\n   *     },\r\n   *     complexFunction: function(email, accessLevel) {\r\n   *       return {\r\n   *         where: {\r\n   *           email: {\r\n   *             [Op.like]: email\r\n   *           },\r\n   *           access_level {\r\n   *             [Op.gte]: accessLevel\r\n   *           }\r\n   *         }\r\n   *       }\r\n   *     }\r\n   *   }\r\n   * })\r\n   *\r\n   * # As you have defined a default scope, every time you do Model.find, the default scope is appended to your query. Here's a couple of examples:\r\n   *\r\n   * Model.findAll() // WHERE username = 'dan'\r\n   * Model.findAll({ where: { age: { [Op.gt]: 12 } } }) // WHERE age > 12 AND username = 'dan'\r\n   *\r\n   * @example <caption>To invoke scope functions you can do</caption>\r\n   * Model.scope({ method: ['complexFunction', 'dan@sequelize.com', 42]}).findAll()\r\n   * // WHERE email like 'dan@sequelize.com%' AND access_level >= 42\r\n   *\r\n   * @param {?Array|Object|string} [option] The scope(s) to apply. Scopes can either be passed as consecutive arguments, or as an array of arguments. To apply simple scopes and scope functions with no arguments, pass them as strings. For scope function, pass an object, with a `method` property. The value can either be a string, if the method does not take any arguments, or an array, where the first element is the name of the method, and consecutive elements are arguments to that method. Pass null to remove all scopes, including the default.\r\n   *\r\n   * @returns {Model} A reference to the model, with the scope(s) applied. Calling scope again on the returned model will clear the previous scope.\r\n   */\r\n  static scope(option) {\r\n    const self = class extends this {};\r\n    let scope;\r\n    let scopeName;\r\n\r\n    Object.defineProperty(self, 'name', { value: this.name });\r\n\r\n    self._scope = {};\r\n    self._scopeNames = [];\r\n    self.scoped = true;\r\n\r\n    if (!option) {\r\n      return self;\r\n    }\r\n\r\n    const options = _.flatten(arguments);\r\n\r\n    for (const option of options) {\r\n      scope = null;\r\n      scopeName = null;\r\n\r\n      if (_.isPlainObject(option)) {\r\n        if (option.method) {\r\n          if (Array.isArray(option.method) && !!self.options.scopes[option.method[0]]) {\r\n            scopeName = option.method[0];\r\n            scope = self.options.scopes[scopeName].apply(self, option.method.slice(1));\r\n          }\r\n          else if (self.options.scopes[option.method]) {\r\n            scopeName = option.method;\r\n            scope = self.options.scopes[scopeName].apply(self);\r\n          }\r\n        } else {\r\n          scope = option;\r\n        }\r\n      } else if (option === 'defaultScope' && _.isPlainObject(self.options.defaultScope)) {\r\n        scope = self.options.defaultScope;\r\n      } else {\r\n        scopeName = option;\r\n        scope = self.options.scopes[scopeName];\r\n        if (typeof scope === 'function') {\r\n          scope = scope();\r\n        }\r\n      }\r\n\r\n      if (scope) {\r\n        this._conformIncludes(scope, this);\r\n        this._assignOptions(self._scope, scope);\r\n        self._scopeNames.push(scopeName ? scopeName : 'defaultScope');\r\n      } else {\r\n        throw new sequelizeErrors.SequelizeScopeError(`Invalid scope ${scopeName} called.`);\r\n      }\r\n    }\r\n\r\n    return self;\r\n  }\r\n\r\n  /**\r\n   * Search for multiple instances.\r\n   *\r\n   * @example <caption>Simple search using AND and =</caption>\r\n   * Model.findAll({\r\n   *   where: {\r\n   *     attr1: 42,\r\n   *     attr2: 'cake'\r\n   *   }\r\n   * })\r\n   *\r\n   * # WHERE attr1 = 42 AND attr2 = 'cake'\r\n   *\r\n   * @example <caption>Using greater than, less than etc.</caption>\r\n   * const {gt, lte, ne, in: opIn} = Sequelize.Op;\r\n   *\r\n   * Model.findAll({\r\n   *   where: {\r\n   *     attr1: {\r\n   *       [gt]: 50\r\n   *     },\r\n   *     attr2: {\r\n   *       [lte]: 45\r\n   *     },\r\n   *     attr3: {\r\n   *       [opIn]: [1,2,3]\r\n   *     },\r\n   *     attr4: {\r\n   *       [ne]: 5\r\n   *     }\r\n   *   }\r\n   * })\r\n   *\r\n   * # WHERE attr1 > 50 AND attr2 <= 45 AND attr3 IN (1,2,3) AND attr4 != 5\r\n   *\r\n   * @example <caption>Queries using OR</caption>\r\n   * const {or, and, gt, lt} = Sequelize.Op;\r\n   *\r\n   * Model.findAll({\r\n   *   where: {\r\n   *     name: 'a project',\r\n   *     [or]: [\r\n   *       {id: [1, 2, 3]},\r\n   *       {\r\n   *         [and]: [\r\n   *           {id: {[gt]: 10}},\r\n   *           {id: {[lt]: 100}}\r\n   *         ]\r\n   *       }\r\n   *     ]\r\n   *   }\r\n   * });\r\n   *\r\n   * # WHERE `Model`.`name` = 'a project' AND (`Model`.`id` IN (1, 2, 3) OR (`Model`.`id` > 10 AND `Model`.`id` < 100));\r\n   *\r\n   * @see\r\n   * {@link Operators} for possible operators\r\n   * __Alias__: _all_\r\n   *\r\n   * The promise is resolved with an array of Model instances if the query succeeds._\r\n   *\r\n   * @param  {Object}                                                    [options] A hash of options to describe the scope of the search\r\n   * @param  {Object}                                                    [options.where] A hash of attributes to describe your search. See above for examples.\r\n   * @param  {Array<string>|Object}                                      [options.attributes] A list of the attributes that you want to select, or an object with `include` and `exclude` keys. To rename an attribute, you can pass an array, with two elements - the first is the name of the attribute in the DB (or some kind of expression such as `Sequelize.literal`, `Sequelize.fn` and so on), and the second is the name you want the attribute to have in the returned instance\r\n   * @param  {Array<string>}                                             [options.attributes.include] Select all the attributes of the model, plus some additional ones. Useful for aggregations, e.g. `{ attributes: { include: [[sequelize.fn('COUNT', sequelize.col('id')), 'total']] }`\r\n   * @param  {Array<string>}                                             [options.attributes.exclude] Select all the attributes of the model, except some few. Useful for security purposes e.g. `{ attributes: { exclude: ['password'] } }`\r\n   * @param  {boolean}                                                   [options.paranoid=true] If true, only non-deleted records will be returned. If false, both deleted and non-deleted records will be returned. Only applies if `options.paranoid` is true for the model.\r\n   * @param  {Array<Object|Model|string>}                                [options.include] A list of associations to eagerly load using a left join. Supported is either `{ include: [ Model1, Model2, ...]}` or `{ include: [{ model: Model1, as: 'Alias' }]}` or `{ include: ['Alias']}`. If your association are set up with an `as` (eg. `X.hasMany(Y, { as: 'Z }`, you need to specify Z in the as attribute when eager loading Y).\r\n   * @param  {Model}                                                     [options.include[].model] The model you want to eagerly load\r\n   * @param  {string}                                                    [options.include[].as] The alias of the relation, in case the model you want to eagerly load is aliased. For `hasOne` / `belongsTo`, this should be the singular name, and for `hasMany`, it should be the plural\r\n   * @param  {Association}                                               [options.include[].association] The association you want to eagerly load. (This can be used instead of providing a model/as pair)\r\n   * @param  {Object}                                                    [options.include[].where] Where clauses to apply to the child models. Note that this converts the eager load to an inner join, unless you explicitly set `required: false`\r\n   * @param  {boolean}                                                   [options.include[].or=false] Whether to bind the ON and WHERE clause together by OR instead of AND.\r\n   * @param  {Object}                                                    [options.include[].on] Supply your own ON condition for the join.\r\n   * @param  {Array<string>}                                             [options.include[].attributes] A list of attributes to select from the child model\r\n   * @param  {boolean}                                                   [options.include[].required] If true, converts to an inner join, which means that the parent model will only be loaded if it has any matching children. True if `include.where` is set, false otherwise.\r\n   * @param  {boolean}                                                   [options.include[].right] If true, converts to a right join if dialect support it. Ignored if `include.required` is true.\r\n   * @param  {boolean}                                                   [options.include[].separate] If true, runs a separate query to fetch the associated instances, only supported for hasMany associations\r\n   * @param  {number}                                                    [options.include[].limit] Limit the joined rows, only supported with include.separate=true\r\n   * @param  {Object}                                                    [options.include[].through.where] Filter on the join model for belongsToMany relations\r\n   * @param  {Array}                                                     [options.include[].through.attributes] A list of attributes to select from the join model for belongsToMany relations\r\n   * @param  {Array<Object|Model|string>}                                [options.include[].include] Load further nested related models\r\n   * @param  {boolean}                                                   [options.include[].duplicating] Mark the include as duplicating, will prevent a subquery from being used.\r\n   * @param  {Array|Sequelize.fn|Sequelize.col|Sequelize.literal}        [options.order] Specifies an ordering. Using an array, you can provide several columns / functions to order by. Each element can be further wrapped in a two-element array. The first element is the column / function to order by, the second is the direction. For example: `order: [['name', 'DESC']]`. In this way the column will be escaped, but the direction will not.\r\n   * @param  {number}                                                    [options.limit] Limit for result\r\n   * @param  {number}                                                    [options.offset] Offset for result\r\n   * @param  {Transaction}                                               [options.transaction] Transaction to run query under\r\n   * @param  {string|Object}                                             [options.lock] Lock the selected rows. Possible options are transaction.LOCK.UPDATE and transaction.LOCK.SHARE. Postgres also supports transaction.LOCK.KEY_SHARE, transaction.LOCK.NO_KEY_UPDATE and specific model locks with joins. See [transaction.LOCK for an example](transaction#lock)\r\n   * @param  {boolean}                                                   [options.skipLocked] Skip locked rows. Only supported in Postgres.\r\n   * @param  {boolean}                                                   [options.raw] Return raw result. See sequelize.query for more information.\r\n   * @param  {Function}                                                  [options.logging=false] A function that gets executed while running the query to log the sql.\r\n   * @param  {boolean}                                                   [options.benchmark=false] Pass query execution time in milliseconds as second argument to logging function (options.logging).\r\n   * @param  {Object}                                                    [options.having] Having options\r\n   * @param  {string}                                                    [options.searchPath=DEFAULT] An optional parameter to specify the schema search_path (Postgres only)\r\n   * @param  {boolean|Error}                                             [options.rejectOnEmpty=false] Throws an error when no records found\r\n   *\r\n   * @see\r\n   * {@link Sequelize#query}\r\n   *\r\n   * @returns {Promise<Array<Model>>}\r\n   */\r\n  static findAll(options) {\r\n    if (options !== undefined && !_.isPlainObject(options)) {\r\n      throw new sequelizeErrors.QueryError('The argument passed to findAll must be an options object, use findByPk if you wish to pass a single primary key value');\r\n    }\r\n\r\n    if (options !== undefined && options.attributes) {\r\n      if (!Array.isArray(options.attributes) && !_.isPlainObject(options.attributes)) {\r\n        throw new sequelizeErrors.QueryError('The attributes option must be an array of column names or an object');\r\n      }\r\n    }\r\n\r\n    this.warnOnInvalidOptions(options, Object.keys(this.rawAttributes));\r\n\r\n    const tableNames = {};\r\n\r\n    tableNames[this.getTableName(options)] = true;\r\n    options = Utils.cloneDeep(options);\r\n\r\n    _.defaults(options, { hooks: true });\r\n\r\n    // set rejectOnEmpty option, defaults to model options\r\n    options.rejectOnEmpty = Object.prototype.hasOwnProperty.call(options, 'rejectOnEmpty')\r\n      ? options.rejectOnEmpty\r\n      : this.options.rejectOnEmpty;\r\n\r\n    return Promise.try(() => {\r\n      this._injectScope(options);\r\n\r\n      if (options.hooks) {\r\n        return this.runHooks('beforeFind', options);\r\n      }\r\n    }).then(() => {\r\n      this._conformIncludes(options, this);\r\n      this._expandAttributes(options);\r\n      this._expandIncludeAll(options);\r\n\r\n      if (options.hooks) {\r\n        return this.runHooks('beforeFindAfterExpandIncludeAll', options);\r\n      }\r\n    }).then(() => {\r\n      options.originalAttributes = this._injectDependentVirtualAttributes(options.attributes);\r\n\r\n      if (options.include) {\r\n        options.hasJoin = true;\r\n\r\n        this._validateIncludedElements(options, tableNames);\r\n\r\n        // If we're not raw, we have to make sure we include the primary key for de-duplication\r\n        if (\r\n          options.attributes\r\n          && !options.raw\r\n          && this.primaryKeyAttribute\r\n          && !options.attributes.includes(this.primaryKeyAttribute)\r\n          && (!options.group || !options.hasSingleAssociation || options.hasMultiAssociation)\r\n        ) {\r\n          options.attributes = [this.primaryKeyAttribute].concat(options.attributes);\r\n        }\r\n      }\r\n\r\n      if (!options.attributes) {\r\n        options.attributes = Object.keys(this.rawAttributes);\r\n        options.originalAttributes = this._injectDependentVirtualAttributes(options.attributes);\r\n      }\r\n\r\n      // whereCollection is used for non-primary key updates\r\n      this.options.whereCollection = options.where || null;\r\n\r\n      Utils.mapFinderOptions(options, this);\r\n\r\n      options = this._paranoidClause(this, options);\r\n\r\n      if (options.hooks) {\r\n        return this.runHooks('beforeFindAfterOptions', options);\r\n      }\r\n    }).then(() => {\r\n      const selectOptions = Object.assign({}, options, { tableNames: Object.keys(tableNames) });\r\n      return this.QueryInterface.select(this, this.getTableName(selectOptions), selectOptions);\r\n    }).tap(results => {\r\n      if (options.hooks) {\r\n        return this.runHooks('afterFind', results, options);\r\n      }\r\n    }).then(results => {\r\n\r\n      //rejectOnEmpty mode\r\n      if (_.isEmpty(results) && options.rejectOnEmpty) {\r\n        if (typeof options.rejectOnEmpty === 'function') {\r\n          throw new options.rejectOnEmpty();\r\n        }\r\n        if (typeof options.rejectOnEmpty === 'object') {\r\n          throw options.rejectOnEmpty;\r\n        }\r\n        throw new sequelizeErrors.EmptyResultError();\r\n      }\r\n\r\n      return Model._findSeparate(results, options);\r\n    });\r\n  }\r\n\r\n  static warnOnInvalidOptions(options, validColumnNames) {\r\n    if (!_.isPlainObject(options)) {\r\n      return;\r\n    }\r\n\r\n    const unrecognizedOptions = Object.keys(options).filter(k => !validQueryKeywords.has(k));\r\n    const unexpectedModelAttributes = _.intersection(unrecognizedOptions, validColumnNames);\r\n    if (!options.where && unexpectedModelAttributes.length > 0) {\r\n      logger.warn(`Model attributes (${unexpectedModelAttributes.join(', ')}) passed into finder method options of model ${this.name}, but the options.where object is empty. Did you forget to use options.where?`);\r\n    }\r\n  }\r\n\r\n  static _injectDependentVirtualAttributes(attributes) {\r\n    if (!this._hasVirtualAttributes) return attributes;\r\n    if (!attributes || !Array.isArray(attributes)) return attributes;\r\n\r\n    for (const attribute of attributes) {\r\n      if (\r\n        this._virtualAttributes.has(attribute)\r\n        && this.rawAttributes[attribute].type.fields\r\n      ) {\r\n        attributes = attributes.concat(this.rawAttributes[attribute].type.fields);\r\n      }\r\n    }\r\n\r\n    attributes = _.uniq(attributes);\r\n\r\n    return attributes;\r\n  }\r\n\r\n  static _findSeparate(results, options) {\r\n    if (!options.include || options.raw || !results) return Promise.resolve(results);\r\n\r\n    const original = results;\r\n    if (options.plain) results = [results];\r\n\r\n    if (!results.length) return original;\r\n\r\n    return Promise.map(options.include, include => {\r\n      if (!include.separate) {\r\n        return Model._findSeparate(\r\n          results.reduce((memo, result) => {\r\n            let associations = result.get(include.association.as);\r\n\r\n            // Might be an empty belongsTo relation\r\n            if (!associations) return memo;\r\n\r\n            // Force array so we can concat no matter if it's 1:1 or :M\r\n            if (!Array.isArray(associations)) associations = [associations];\r\n\r\n            for (let i = 0, len = associations.length; i !== len; ++i) {\r\n              memo.push(associations[i]);\r\n            }\r\n            return memo;\r\n          }, []),\r\n          Object.assign(\r\n            {},\r\n            _.omit(options, 'include', 'attributes', 'order', 'where', 'limit', 'offset', 'plain', 'scope'),\r\n            { include: include.include || [] }\r\n          )\r\n        );\r\n      }\r\n\r\n      return include.association.get(results, Object.assign(\r\n        {},\r\n        _.omit(options, nonCascadingOptions),\r\n        _.omit(include, ['parent', 'association', 'as', 'originalAttributes'])\r\n      )).then(map => {\r\n        for (const result of results) {\r\n          result.set(\r\n            include.association.as,\r\n            map[result.get(include.association.sourceKey)],\r\n            { raw: true }\r\n          );\r\n        }\r\n      });\r\n    }).return(original);\r\n  }\r\n\r\n  /**\r\n   * Search for a single instance by its primary key._\r\n   *\r\n   * @param  {number|string|Buffer}      param The value of the desired instance's primary key.\r\n   * @param  {Object}                    [options] find options\r\n   * @param  {Transaction}               [options.transaction] Transaction to run query under\r\n   * @param  {string}                    [options.searchPath=DEFAULT] An optional parameter to specify the schema search_path (Postgres only)\r\n   *\r\n   * @see\r\n   * {@link Model.findAll}           for a full explanation of options, Note that options.where is not supported.\r\n   *\r\n   * @returns {Promise<Model>}\r\n   */\r\n  static findByPk(param, options) {\r\n    // return Promise resolved with null if no arguments are passed\r\n    if ([null, undefined].includes(param)) {\r\n      return Promise.resolve(null);\r\n    }\r\n\r\n    options = Utils.cloneDeep(options) || {};\r\n\r\n    if (typeof param === 'number' || typeof param === 'string' || Buffer.isBuffer(param)) {\r\n      options.where = {\r\n        [this.primaryKeyAttribute]: param\r\n      };\r\n    } else {\r\n      throw new Error(`Argument passed to findByPk is invalid: ${param}`);\r\n    }\r\n\r\n    // Bypass a possible overloaded findOne\r\n    return this.findOne(options);\r\n  }\r\n\r\n  /**\r\n   * Search for a single instance. This applies LIMIT 1, so the listener will always be called with a single instance.\r\n   *\r\n   * __Alias__: _find_\r\n   *\r\n   * @param  {Object}       [options] A hash of options to describe the scope of the search\r\n   * @param  {Transaction}  [options.transaction] Transaction to run query under\r\n   * @param  {string}       [options.searchPath=DEFAULT] An optional parameter to specify the schema search_path (Postgres only)\r\n   *\r\n   * @see\r\n   * {@link Model.findAll} for an explanation of options\r\n   *\r\n   * @returns {Promise<Model>}\r\n   */\r\n  static findOne(options) {\r\n    if (options !== undefined && !_.isPlainObject(options)) {\r\n      throw new Error('The argument passed to findOne must be an options object, use findByPk if you wish to pass a single primary key value');\r\n    }\r\n    options = Utils.cloneDeep(options);\r\n\r\n    if (options.limit === undefined) {\r\n      const uniqueSingleColumns = _.chain(this.uniqueKeys).values().filter(c => c.fields.length === 1).map('column').value();\r\n\r\n      // Don't add limit if querying directly on the pk or a unique column\r\n      if (!options.where || !_.some(options.where, (value, key) =>\r\n        (key === this.primaryKeyAttribute || uniqueSingleColumns.includes(key)) &&\r\n          (Utils.isPrimitive(value) || Buffer.isBuffer(value))\r\n      )) {\r\n        options.limit = 1;\r\n      }\r\n    }\r\n\r\n    // Bypass a possible overloaded findAll.\r\n    return this.findAll(_.defaults(options, {\r\n      plain: true\r\n    }));\r\n  }\r\n\r\n  /**\r\n   * Run an aggregation method on the specified field\r\n   *\r\n   * @param {string}          attribute The attribute to aggregate over. Can be a field name or *\r\n   * @param {string}          aggregateFunction The function to use for aggregation, e.g. sum, max etc.\r\n   * @param {Object}          [options] Query options. See sequelize.query for full options\r\n   * @param {Object}          [options.where] A hash of search attributes.\r\n   * @param {Function}        [options.logging=false] A function that gets executed while running the query to log the sql.\r\n   * @param {boolean}         [options.benchmark=false] Pass query execution time in milliseconds as second argument to logging function (options.logging).\r\n   * @param {DataTypes|string} [options.dataType] The type of the result. If `field` is a field in this Model, the default will be the type of that field, otherwise defaults to float.\r\n   * @param {boolean}         [options.distinct] Applies DISTINCT to the field being aggregated over\r\n   * @param {Transaction}     [options.transaction] Transaction to run query under\r\n   * @param {boolean}         [options.plain] When `true`, the first returned value of `aggregateFunction` is cast to `dataType` and returned. If additional attributes are specified, along with `group` clauses, set `plain` to `false` to return all values of all returned rows.  Defaults to `true`\r\n   *\r\n   * @returns {Promise<DataTypes|Object>} Returns the aggregate result cast to `options.dataType`, unless `options.plain` is false, in which case the complete data result is returned.\r\n   */\r\n  static aggregate(attribute, aggregateFunction, options) {\r\n    options = Utils.cloneDeep(options);\r\n\r\n    // We need to preserve attributes here as the `injectScope` call would inject non aggregate columns.\r\n    const prevAttributes = options.attributes;\r\n    this._injectScope(options);\r\n    options.attributes = prevAttributes;\r\n    this._conformIncludes(options, this);\r\n\r\n    if (options.include) {\r\n      this._expandIncludeAll(options);\r\n      this._validateIncludedElements(options);\r\n    }\r\n\r\n    const attrOptions = this.rawAttributes[attribute];\r\n    const field = attrOptions && attrOptions.field || attribute;\r\n    let aggregateColumn = this.sequelize.col(field);\r\n\r\n    if (options.distinct) {\r\n      aggregateColumn = this.sequelize.fn('DISTINCT', aggregateColumn);\r\n    }\r\n\r\n    let { group } = options;\r\n    if (Array.isArray(group) && Array.isArray(group[0])) {\r\n      noDoubleNestedGroup();\r\n      group = _.flatten(group);\r\n    }\r\n    options.attributes = _.unionBy(\r\n      options.attributes,\r\n      group,\r\n      [[this.sequelize.fn(aggregateFunction, aggregateColumn), aggregateFunction]],\r\n      a => Array.isArray(a) ? a[1] : a\r\n    );\r\n\r\n    if (!options.dataType) {\r\n      if (attrOptions) {\r\n        options.dataType = attrOptions.type;\r\n      } else {\r\n        // Use FLOAT as fallback\r\n        options.dataType = new DataTypes.FLOAT();\r\n      }\r\n    } else {\r\n      options.dataType = this.sequelize.normalizeDataType(options.dataType);\r\n    }\r\n\r\n    Utils.mapOptionFieldNames(options, this);\r\n    options = this._paranoidClause(this, options);\r\n\r\n    return this.QueryInterface.rawSelect(this.getTableName(options), options, aggregateFunction, this).then( value => {\r\n      if (value === null) {\r\n        return 0;\r\n      }\r\n      return value;\r\n    });\r\n  }\r\n\r\n  /**\r\n   * Count the number of records matching the provided where clause.\r\n   *\r\n   * If you provide an `include` option, the number of matching associations will be counted instead.\r\n   *\r\n   * @param {Object}        [options] options\r\n   * @param {Object}        [options.where] A hash of search attributes.\r\n   * @param {Object}        [options.include] Include options. See `find` for details\r\n   * @param {boolean}       [options.paranoid=true] Set `true` to count only non-deleted records. Can be used on models with `paranoid` enabled\r\n   * @param {boolean}       [options.distinct] Apply COUNT(DISTINCT(col)) on primary key or on options.col.\r\n   * @param {string}        [options.col] Column on which COUNT() should be applied\r\n   * @param {Array}         [options.attributes] Used in conjunction with `group`\r\n   * @param {Array}         [options.group] For creating complex counts. Will return multiple rows as needed.\r\n   * @param {Transaction}   [options.transaction] Transaction to run query under\r\n   * @param {Function}      [options.logging=false] A function that gets executed while running the query to log the sql.\r\n   * @param {boolean}       [options.benchmark=false] Pass query execution time in milliseconds as second argument to logging function (options.logging).\r\n   * @param {string}        [options.searchPath=DEFAULT] An optional parameter to specify the schema search_path (Postgres only)\r\n   *\r\n   * @returns {Promise<number>}\r\n   */\r\n  static count(options) {\r\n    return Promise.try(() => {\r\n      options = Utils.cloneDeep(options);\r\n      options = _.defaults(options, { hooks: true });\r\n      options.raw = true;\r\n      if (options.hooks) {\r\n        return this.runHooks('beforeCount', options);\r\n      }\r\n    }).then(() => {\r\n      let col = options.col || '*';\r\n      if (options.include) {\r\n        col = `${this.name}.${options.col || this.primaryKeyField}`;\r\n      }\r\n\r\n      options.plain = !options.group;\r\n      options.dataType = new DataTypes.INTEGER();\r\n      options.includeIgnoreAttributes = false;\r\n\r\n      // No limit, offset or order for the options max be given to count()\r\n      // Set them to null to prevent scopes setting those values\r\n      options.limit = null;\r\n      options.offset = null;\r\n      options.order = null;\r\n\r\n      return this.aggregate(col, 'count', options);\r\n    });\r\n  }\r\n\r\n  /**\r\n   * Find all the rows matching your query, within a specified offset / limit, and get the total number of rows matching your query. This is very useful for paging\r\n   *\r\n   * @example\r\n   * Model.findAndCountAll({\r\n   *   where: ...,\r\n   *   limit: 12,\r\n   *   offset: 12\r\n   * }).then(result => {\r\n   *   ...\r\n   * })\r\n   *\r\n   * # In the above example, `result.rows` will contain rows 13 through 24, while `result.count` will return the total number of rows that matched your query.\r\n   *\r\n   * # When you add includes, only those which are required (either because they have a where clause, or because `required` is explicitly set to true on the include) will be added to the count part.\r\n   *\r\n   * # Suppose you want to find all users who have a profile attached:\r\n   *\r\n   * User.findAndCountAll({\r\n   *   include: [\r\n   *      { model: Profile, required: true}\r\n   *   ],\r\n   *   limit 3\r\n   * });\r\n   *\r\n   * # Because the include for `Profile` has `required` set it will result in an inner join, and only the users who have a profile will be counted. If we remove `required` from the include, both users with and without profiles will be counted\r\n   *\r\n   * @param {Object} [options] See findAll options\r\n   *\r\n   * @see\r\n   * {@link Model.findAll} for a specification of find and query options\r\n   * @see\r\n   * {@link Model.count} for a specification of count options\r\n   *\r\n   * @returns {Promise<{count: number, rows: Model[]}>}\r\n   */\r\n  static findAndCountAll(options) {\r\n    if (options !== undefined && !_.isPlainObject(options)) {\r\n      throw new Error('The argument passed to findAndCountAll must be an options object, use findByPk if you wish to pass a single primary key value');\r\n    }\r\n\r\n    const countOptions = Utils.cloneDeep(options);\r\n\r\n    if (countOptions.attributes) {\r\n      countOptions.attributes = undefined;\r\n    }\r\n\r\n    return Promise.all([\r\n      this.count(countOptions),\r\n      this.findAll(options)\r\n    ])\r\n      .then(([count, rows]) => ({\r\n        count,\r\n        rows: count === 0 ? [] : rows\r\n      }));\r\n  }\r\n\r\n  /**\r\n   * Find the maximum value of field\r\n   *\r\n   * @param {string} field attribute / field name\r\n   * @param {Object} [options] See aggregate\r\n   *\r\n   * @see\r\n   * {@link Model.aggregate} for options\r\n   *\r\n   * @returns {Promise<*>}\r\n   */\r\n  static max(field, options) {\r\n    return this.aggregate(field, 'max', options);\r\n  }\r\n\r\n  /**\r\n   * Find the minimum value of field\r\n   *\r\n   * @param {string} field attribute / field name\r\n   * @param {Object} [options] See aggregate\r\n   *\r\n   * @see\r\n   * {@link Model.aggregate} for options\r\n   *\r\n   * @returns {Promise<*>}\r\n   */\r\n  static min(field, options) {\r\n    return this.aggregate(field, 'min', options);\r\n  }\r\n\r\n  /**\r\n   * Find the sum of field\r\n   *\r\n   * @param {string} field attribute / field name\r\n   * @param {Object} [options] See aggregate\r\n   *\r\n   * @see\r\n   * {@link Model.aggregate} for options\r\n   *\r\n   * @returns {Promise<number>}\r\n   */\r\n  static sum(field, options) {\r\n    return this.aggregate(field, 'sum', options);\r\n  }\r\n\r\n  /**\r\n   * Builds a new model instance.\r\n   *\r\n   * @param {Object|Array} values An object of key value pairs or an array of such. If an array, the function will return an array of instances.\r\n   * @param {Object}  [options] Instance build options\r\n   * @param {boolean} [options.raw=false] If set to true, values will ignore field and virtual setters.\r\n   * @param {boolean} [options.isNewRecord=true] Is this new record\r\n   * @param {Array}   [options.include] an array of include options - Used to build prefetched/included model instances. See `set`\r\n   *\r\n   * @returns {Model|Array<Model>}\r\n   */\r\n  static build(values, options) {\r\n    if (Array.isArray(values)) {\r\n      return this.bulkBuild(values, options);\r\n    }\r\n    return new this(values, options);\r\n  }\r\n\r\n  static bulkBuild(valueSets, options) {\r\n    options = Object.assign({\r\n      isNewRecord: true\r\n    }, options || {});\r\n\r\n    if (!options.includeValidated) {\r\n      this._conformIncludes(options, this);\r\n      if (options.include) {\r\n        this._expandIncludeAll(options);\r\n        this._validateIncludedElements(options);\r\n      }\r\n    }\r\n\r\n    if (options.attributes) {\r\n      options.attributes = options.attributes.map(attribute => Array.isArray(attribute) ? attribute[1] : attribute);\r\n    }\r\n\r\n    return valueSets.map(values => this.build(values, options));\r\n  }\r\n\r\n  /**\r\n   * Builds a new model instance and calls save on it.\r\n\r\n   * @see\r\n   * {@link Model.build}\r\n   * @see\r\n   * {@link Model.save}\r\n   *\r\n   * @param {Object}        values hash of data values to create new record with\r\n   * @param {Object}        [options] build and query options\r\n   * @param {boolean}       [options.raw=false] If set to true, values will ignore field and virtual setters.\r\n   * @param {boolean}       [options.isNewRecord=true] Is this new record\r\n   * @param {Array}         [options.include] an array of include options - Used to build prefetched/included model instances. See `set`\r\n   * @param {Array}         [options.fields] If set, only columns matching those in fields will be saved\r\n   * @param {string[]}      [options.fields] An optional array of strings, representing database columns. If fields is provided, only those columns will be validated and saved.\r\n   * @param {boolean}       [options.silent=false] If true, the updatedAt timestamp will not be updated.\r\n   * @param {boolean}       [options.validate=true] If false, validations won't be run.\r\n   * @param {boolean}       [options.hooks=true] Run before and after create / update + validate hooks\r\n   * @param {Function}      [options.logging=false] A function that gets executed while running the query to log the sql.\r\n   * @param {boolean}       [options.benchmark=false] Pass query execution time in milliseconds as second argument to logging function (options.logging).\r\n   * @param {Transaction}   [options.transaction] Transaction to run query under\r\n   * @param {string}        [options.searchPath=DEFAULT] An optional parameter to specify the schema search_path (Postgres only)\r\n   * @param {boolean}       [options.returning=true] Return the affected rows (only for postgres)\r\n   *\r\n   * @returns {Promise<Model>}\r\n   *\r\n   */\r\n  static create(values, options) {\r\n    options = Utils.cloneDeep(options || {});\r\n\r\n    return this.build(values, {\r\n      isNewRecord: true,\r\n      attributes: options.fields,\r\n      include: options.include,\r\n      raw: options.raw,\r\n      silent: options.silent\r\n    }).save(options);\r\n  }\r\n\r\n  /**\r\n   * Find a row that matches the query, or build (but don't save) the row if none is found.\r\n   * The successful result of the promise will be (instance, built)\r\n   *\r\n   * @param {Object}   options find options\r\n   * @param {Object}   options.where A hash of search attributes. If `where` is a plain object it will be appended with defaults to build a new instance.\r\n   * @param {Object}   [options.defaults] Default values to use if building a new instance\r\n   * @param {Object}   [options.transaction] Transaction to run query under\r\n   *\r\n   * @returns {Promise<Model,boolean>}\r\n   */\r\n  static findOrBuild(options) {\r\n    if (!options || !options.where || arguments.length > 1) {\r\n      throw new Error(\r\n        'Missing where attribute in the options parameter passed to findOrBuild. ' +\r\n        'Please note that the API has changed, and is now options only (an object with where, defaults keys, transaction etc.)'\r\n      );\r\n    }\r\n\r\n    let values;\r\n\r\n    return this.findOne(options).then(instance => {\r\n      if (instance === null) {\r\n        values = _.clone(options.defaults) || {};\r\n        if (_.isPlainObject(options.where)) {\r\n          values = Utils.defaults(values, options.where);\r\n        }\r\n\r\n        instance = this.build(values, options);\r\n\r\n        return Promise.resolve([instance, true]);\r\n      }\r\n\r\n      return Promise.resolve([instance, false]);\r\n    });\r\n  }\r\n\r\n  /**\r\n   * Find a row that matches the query, or build and save the row if none is found\r\n   * The successful result of the promise will be (instance, created)\r\n   *\r\n   * If no transaction is passed in the `options` object, a new transaction will be created internally, to prevent the race condition where a matching row is created by another connection after the find but before the insert call.\r\n   * However, it is not always possible to handle this case in SQLite, specifically if one transaction inserts and another tries to select before the first one has committed. In this case, an instance of sequelize. TimeoutError will be thrown instead.\r\n   * If a transaction is created, a savepoint will be created instead, and any unique constraint violation will be handled internally.\r\n   *\r\n   * @see\r\n   * {@link Model.findAll} for a full specification of find and options\r\n   *\r\n   * @param {Object}      options find and create options\r\n   * @param {Object}      options.where where A hash of search attributes. If `where` is a plain object it will be appended with defaults to build a new instance.\r\n   * @param {Object}      [options.defaults] Default values to use if creating a new instance\r\n   * @param {Transaction} [options.transaction] Transaction to run query under\r\n   *\r\n   * @returns {Promise<Model,boolean>}\r\n   */\r\n  static findOrCreate(options) {\r\n    if (!options || !options.where || arguments.length > 1) {\r\n      throw new Error(\r\n        'Missing where attribute in the options parameter passed to findOrCreate. ' +\r\n        'Please note that the API has changed, and is now options only (an object with where, defaults keys, transaction etc.)'\r\n      );\r\n    }\r\n\r\n    options = Object.assign({}, options);\r\n\r\n    if (options.defaults) {\r\n      const defaults = Object.keys(options.defaults);\r\n      const unknownDefaults = defaults.filter(name => !this.rawAttributes[name]);\r\n\r\n      if (unknownDefaults.length) {\r\n        logger.warn(`Unknown attributes (${unknownDefaults}) passed to defaults option of findOrCreate`);\r\n      }\r\n    }\r\n\r\n    if (options.transaction === undefined && this.sequelize.constructor._cls) {\r\n      const t = this.sequelize.constructor._cls.get('transaction');\r\n      if (t) {\r\n        options.transaction = t;\r\n      }\r\n    }\r\n\r\n    const internalTransaction = !options.transaction;\r\n    let values;\r\n    let transaction;\r\n\r\n    // Create a transaction or a savepoint, depending on whether a transaction was passed in\r\n    return this.sequelize.transaction(options).then(t => {\r\n      transaction = t;\r\n      options.transaction = t;\r\n\r\n      return this.findOne(Utils.defaults({ transaction }, options));\r\n    }).then(instance => {\r\n      if (instance !== null) {\r\n        return [instance, false];\r\n      }\r\n\r\n      values = _.clone(options.defaults) || {};\r\n      if (_.isPlainObject(options.where)) {\r\n        values = Utils.defaults(values, options.where);\r\n      }\r\n\r\n      options.exception = true;\r\n\r\n      return this.create(values, options).then(instance => {\r\n        if (instance.get(this.primaryKeyAttribute, { raw: true }) === null) {\r\n          // If the query returned an empty result for the primary key, we know that this was actually a unique constraint violation\r\n          throw new sequelizeErrors.UniqueConstraintError();\r\n        }\r\n\r\n        return [instance, true];\r\n      }).catch(sequelizeErrors.UniqueConstraintError, err => {\r\n        const flattenedWhere = Utils.flattenObjectDeep(options.where);\r\n        const flattenedWhereKeys = Object.keys(flattenedWhere).map(name => _.last(name.split('.')));\r\n        const whereFields = flattenedWhereKeys.map(name => _.get(this.rawAttributes, `${name}.field`, name));\r\n        const defaultFields = options.defaults && Object.keys(options.defaults)\r\n          .filter(name => this.rawAttributes[name])\r\n          .map(name => this.rawAttributes[name].field || name);\r\n\r\n        const errFieldKeys = Object.keys(err.fields);\r\n        const errFieldsWhereIntersects = Utils.intersects(errFieldKeys, whereFields);\r\n        if (defaultFields && !errFieldsWhereIntersects && Utils.intersects(errFieldKeys, defaultFields)) {\r\n          throw err;\r\n        }\r\n\r\n        if (errFieldsWhereIntersects) {\r\n          _.each(err.fields, (value, key) => {\r\n            const name = this.fieldRawAttributesMap[key].fieldName;\r\n            if (value.toString() !== options.where[name].toString()) {\r\n              throw new Error(`${this.name}#findOrCreate: value used for ${name} was not equal for both the find and the create calls, '${options.where[name]}' vs '${value}'`);\r\n            }\r\n          });\r\n        }\r\n\r\n        // Someone must have created a matching instance inside the same transaction since we last did a find. Let's find it!\r\n        return this.findOne(Utils.defaults({\r\n          transaction: internalTransaction ? null : transaction\r\n        }, options)).then(instance => {\r\n          // Sanity check, ideally we caught this at the defaultFeilds/err.fields check\r\n          // But if we didn't and instance is null, we will throw\r\n          if (instance === null) throw err;\r\n          return [instance, false];\r\n        });\r\n      });\r\n    }).finally(() => {\r\n      if (internalTransaction && transaction) {\r\n        // If we created a transaction internally (and not just a savepoint), we should clean it up\r\n        return transaction.commit();\r\n      }\r\n    });\r\n  }\r\n\r\n  /**\r\n   * A more performant findOrCreate that will not work under a transaction (at least not in postgres)\r\n   * Will execute a find call, if empty then attempt to create, if unique constraint then attempt to find again\r\n   *\r\n   * @see\r\n   * {@link Model.findAll} for a full specification of find and options\r\n   *\r\n   * @param {Object} options find options\r\n   * @param {Object} options.where A hash of search attributes. If `where` is a plain object it will be appended with defaults to build a new instance.\r\n   * @param {Object} [options.defaults] Default values to use if creating a new instance\r\n   *\r\n   * @returns {Promise<Model,boolean>}\r\n   */\r\n  static findCreateFind(options) {\r\n    if (!options || !options.where) {\r\n      throw new Error(\r\n        'Missing where attribute in the options parameter passed to findCreateFind.'\r\n      );\r\n    }\r\n\r\n    let values = _.clone(options.defaults) || {};\r\n    if (_.isPlainObject(options.where)) {\r\n      values = Utils.defaults(values, options.where);\r\n    }\r\n\r\n\r\n    return this.findOne(options).then(result => {\r\n      if (result) return [result, false];\r\n\r\n      return this.create(values, options)\r\n        .then(result => [result, true])\r\n        .catch(sequelizeErrors.UniqueConstraintError, () => this.findOne(options).then(result => [result, false]));\r\n    });\r\n  }\r\n\r\n  /**\r\n   * Insert or update a single row. An update will be executed if a row which matches the supplied values on either the primary key or a unique key is found. Note that the unique index must be defined in your sequelize model and not just in the table. Otherwise you may experience a unique constraint violation, because sequelize fails to identify the row that should be updated.\r\n   *\r\n   * **Implementation details:**\r\n   *\r\n   * * MySQL - Implemented as a single query `INSERT values ON DUPLICATE KEY UPDATE values`\r\n   * * PostgreSQL - Implemented as a temporary function with exception handling: INSERT EXCEPTION WHEN unique_constraint UPDATE\r\n   * * SQLite - Implemented as two queries `INSERT; UPDATE`. This means that the update is executed regardless of whether the row already existed or not\r\n   * * MSSQL - Implemented as a single query using `MERGE` and `WHEN (NOT) MATCHED THEN`\r\n   * **Note** that SQLite returns undefined for created, no matter if the row was created or updated. This is because SQLite always runs INSERT OR IGNORE + UPDATE, in a single query, so there is no way to know whether the row was inserted or not.\r\n   *\r\n   * @param  {Object}       values hash of values to upsert\r\n   * @param  {Object}       [options] upsert options\r\n   * @param  {boolean}      [options.validate=true] Run validations before the row is inserted\r\n   * @param  {Array}        [options.fields=Object.keys(this.attributes)] The fields to insert / update. Defaults to all changed fields\r\n   * @param  {boolean}      [options.hooks=true]  Run before / after upsert hooks?\r\n   * @param  {boolean}      [options.returning=false] Append RETURNING * to get back auto generated values (Postgres only)\r\n   * @param  {Transaction}  [options.transaction] Transaction to run query under\r\n   * @param  {Function}     [options.logging=false] A function that gets executed while running the query to log the sql.\r\n   * @param  {boolean}      [options.benchmark=false] Pass query execution time in milliseconds as second argument to logging function (options.logging).\r\n   * @param  {string}       [options.searchPath=DEFAULT] An optional parameter to specify the schema search_path (Postgres only)\r\n   *\r\n   * @returns {Promise<boolean>} Returns a boolean indicating whether the row was created or updated. For MySQL/MariaDB, it returns `true` when inserted and `false` when updated. For Postgres/MSSQL with (options.returning=true), it returns record and created boolean with signature `<Model, created>`.\r\n   */\r\n  static upsert(values, options) {\r\n    options = Object.assign({\r\n      hooks: true,\r\n      returning: false,\r\n      validate: true\r\n    }, Utils.cloneDeep(options || {}));\r\n\r\n    options.model = this;\r\n\r\n    const createdAtAttr = this._timestampAttributes.createdAt;\r\n    const updatedAtAttr = this._timestampAttributes.updatedAt;\r\n    const hasPrimary = this.primaryKeyField in values || this.primaryKeyAttribute in values;\r\n    const instance = this.build(values);\r\n\r\n    if (!options.fields) {\r\n      options.fields = Object.keys(instance._changed);\r\n    }\r\n\r\n    return Promise.try(() => {\r\n      if (options.validate) {\r\n        return instance.validate(options);\r\n      }\r\n    }).then(() => {\r\n      // Map field names\r\n      const updatedDataValues = _.pick(instance.dataValues, Object.keys(instance._changed));\r\n      const insertValues = Utils.mapValueFieldNames(instance.dataValues, Object.keys(instance.rawAttributes), this);\r\n      const updateValues = Utils.mapValueFieldNames(updatedDataValues, options.fields, this);\r\n      const now = Utils.now(this.sequelize.options.dialect);\r\n\r\n      // Attach createdAt\r\n      if (createdAtAttr && !updateValues[createdAtAttr]) {\r\n        const field = this.rawAttributes[createdAtAttr].field || createdAtAttr;\r\n        insertValues[field] = this._getDefaultTimestamp(createdAtAttr) || now;\r\n      }\r\n      if (updatedAtAttr && !insertValues[updatedAtAttr]) {\r\n        const field = this.rawAttributes[updatedAtAttr].field || updatedAtAttr;\r\n        insertValues[field] = updateValues[field] = this._getDefaultTimestamp(updatedAtAttr) || now;\r\n      }\r\n\r\n      // Build adds a null value for the primary key, if none was given by the user.\r\n      // We need to remove that because of some Postgres technicalities.\r\n      if (!hasPrimary && this.primaryKeyAttribute && !this.rawAttributes[this.primaryKeyAttribute].defaultValue) {\r\n        delete insertValues[this.primaryKeyField];\r\n        delete updateValues[this.primaryKeyField];\r\n      }\r\n\r\n      return Promise.try(() => {\r\n        if (options.hooks) {\r\n          return this.runHooks('beforeUpsert', values, options);\r\n        }\r\n      })\r\n        .then(() => {\r\n          return this.QueryInterface.upsert(this.getTableName(options), insertValues, updateValues, instance.where(), this, options);\r\n        })\r\n        .then(([created, primaryKey]) => {\r\n          if (options.returning === true && primaryKey) {\r\n            return this.findByPk(primaryKey, options).then(record => [record, created]);\r\n          }\r\n\r\n          return created;\r\n        })\r\n        .tap(result => {\r\n          if (options.hooks) {\r\n            return this.runHooks('afterUpsert', result, options);\r\n          }\r\n        });\r\n    });\r\n  }\r\n\r\n  /**\r\n   * Create and insert multiple instances in bulk.\r\n   *\r\n   * The success handler is passed an array of instances, but please notice that these may not completely represent the state of the rows in the DB. This is because MySQL\r\n   * and SQLite do not make it easy to obtain back automatically generated IDs and other default values in a way that can be mapped to multiple records.\r\n   * To obtain Instances for the newly created values, you will need to query for them again.\r\n   *\r\n   * If validation fails, the promise is rejected with an array-like [AggregateError](http://bluebirdjs.com/docs/api/aggregateerror.html)\r\n   *\r\n   * @param  {Array}        records                          List of objects (key/value pairs) to create instances from\r\n   * @param  {Object}       [options]                        Bulk create options\r\n   * @param  {Array}        [options.fields]                 Fields to insert (defaults to all fields)\r\n   * @param  {boolean}      [options.validate=false]         Should each row be subject to validation before it is inserted. The whole insert will fail if one row fails validation\r\n   * @param  {boolean}      [options.hooks=true]             Run before / after bulk create hooks?\r\n   * @param  {boolean}      [options.individualHooks=false]  Run before / after create hooks for each individual Instance? BulkCreate hooks will still be run if options.hooks is true.\r\n   * @param  {boolean}      [options.ignoreDuplicates=false] Ignore duplicate values for primary keys? (not supported by MSSQL or Postgres < 9.5)\r\n   * @param  {Array}        [options.updateOnDuplicate]      Fields to update if row key already exists (on duplicate key update)? (only supported by MySQL, MariaDB, SQLite >= 3.24.0 & Postgres >= 9.5). By default, all fields are updated.\r\n   * @param  {Transaction}  [options.transaction]            Transaction to run query under\r\n   * @param  {Function}     [options.logging=false]          A function that gets executed while running the query to log the sql.\r\n   * @param  {boolean}      [options.benchmark=false]        Pass query execution time in milliseconds as second argument to logging function (options.logging).\r\n   * @param  {boolean|Array} [options.returning=false]       If true, append RETURNING * to get back all values; if an array of column names, append RETURNING <columns> to get back specific columns (Postgres only)\r\n   * @param  {string}       [options.searchPath=DEFAULT]     An optional parameter to specify the schema search_path (Postgres only)\r\n   *\r\n   * @returns {Promise<Array<Model>>}\r\n   */\r\n  static bulkCreate(records, options = {}) {\r\n    if (!records.length) {\r\n      return Promise.resolve([]);\r\n    }\r\n\r\n    const dialect = this.sequelize.options.dialect;\r\n    const now = Utils.now(this.sequelize.options.dialect);\r\n\r\n    options.model = this;\r\n\r\n    if (!options.includeValidated) {\r\n      this._conformIncludes(options, this);\r\n      if (options.include) {\r\n        this._expandIncludeAll(options);\r\n        this._validateIncludedElements(options);\r\n      }\r\n    }\r\n\r\n    const instances = records.map(values => this.build(values, { isNewRecord: true, include: options.include }));\r\n\r\n    const recursiveBulkCreate = (instances, options) => {\r\n      options = Object.assign({\r\n        validate: false,\r\n        hooks: true,\r\n        individualHooks: false,\r\n        ignoreDuplicates: false\r\n      }, options);\r\n\r\n      if (options.returning === undefined) {\r\n        if (options.association) {\r\n          options.returning = false;\r\n        } else {\r\n          options.returning = true;\r\n        }\r\n      }\r\n\r\n      if (options.ignoreDuplicates && ['mssql'].includes(dialect)) {\r\n        return Promise.reject(new Error(`${dialect} does not support the ignoreDuplicates option.`));\r\n      }\r\n      if (options.updateOnDuplicate && (dialect !== 'mysql' && dialect !== 'mariadb' && dialect !== 'sqlite' && dialect !== 'postgres')) {\r\n        return Promise.reject(new Error(`${dialect} does not support the updateOnDuplicate option.`));\r\n      }\r\n\r\n      const model = options.model;\r\n\r\n      options.fields = options.fields || Object.keys(model.rawAttributes);\r\n      const createdAtAttr = model._timestampAttributes.createdAt;\r\n      const updatedAtAttr = model._timestampAttributes.updatedAt;\r\n\r\n      if (options.updateOnDuplicate !== undefined) {\r\n        if (Array.isArray(options.updateOnDuplicate) && options.updateOnDuplicate.length) {\r\n          options.updateOnDuplicate = _.intersection(\r\n            _.without(Object.keys(model.tableAttributes), createdAtAttr),\r\n            options.updateOnDuplicate\r\n          );\r\n        } else {\r\n          return Promise.reject(new Error('updateOnDuplicate option only supports non-empty array.'));\r\n        }\r\n      }\r\n\r\n      return Promise.try(() => {\r\n        // Run before hook\r\n        if (options.hooks) {\r\n          return model.runHooks('beforeBulkCreate', instances, options);\r\n        }\r\n      }).then(() => {\r\n        // Validate\r\n        if (options.validate) {\r\n          const errors = new Promise.AggregateError();\r\n          const validateOptions = _.clone(options);\r\n          validateOptions.hooks = options.individualHooks;\r\n\r\n          return Promise.map(instances, instance =>\r\n            instance.validate(validateOptions).catch(err => {\r\n              errors.push(new sequelizeErrors.BulkRecordError(err, instance));\r\n            })\r\n          ).then(() => {\r\n            delete options.skip;\r\n            if (errors.length) {\r\n              throw errors;\r\n            }\r\n          });\r\n        }\r\n      }).then(() => {\r\n        if (options.individualHooks) {\r\n          // Create each instance individually\r\n          return Promise.map(instances, instance => {\r\n            const individualOptions = _.clone(options);\r\n            delete individualOptions.fields;\r\n            delete individualOptions.individualHooks;\r\n            delete individualOptions.ignoreDuplicates;\r\n            individualOptions.validate = false;\r\n            individualOptions.hooks = true;\r\n\r\n            return instance.save(individualOptions);\r\n          });\r\n        }\r\n\r\n        return Promise.resolve().then(() => {\r\n          if (!options.include || !options.include.length) return;\r\n\r\n          // Nested creation for BelongsTo relations\r\n          return Promise.map(options.include.filter(include => include.association instanceof BelongsTo), include => {\r\n            const associationInstances = [];\r\n            const associationInstanceIndexToInstanceMap = [];\r\n\r\n            for (const instance of instances) {\r\n              const associationInstance = instance.get(include.as);\r\n              if (associationInstance) {\r\n                associationInstances.push(associationInstance);\r\n                associationInstanceIndexToInstanceMap.push(instance);\r\n              }\r\n            }\r\n\r\n            if (!associationInstances.length) {\r\n              return;\r\n            }\r\n\r\n            const includeOptions = _(Utils.cloneDeep(include))\r\n              .omit(['association'])\r\n              .defaults({\r\n                transaction: options.transaction,\r\n                logging: options.logging\r\n              }).value();\r\n\r\n            return recursiveBulkCreate(associationInstances, includeOptions).then(associationInstances => {\r\n              for (const idx in associationInstances) {\r\n                const associationInstance = associationInstances[idx];\r\n                const instance = associationInstanceIndexToInstanceMap[idx];\r\n\r\n                instance[include.association.accessors.set](associationInstance, { save: false, logging: options.logging });\r\n              }\r\n            });\r\n          });\r\n        }).then(() => {\r\n          // Create all in one query\r\n          // Recreate records from instances to represent any changes made in hooks or validation\r\n          records = instances.map(instance => {\r\n            const values = instance.dataValues;\r\n\r\n            // set createdAt/updatedAt attributes\r\n            if (createdAtAttr && !values[createdAtAttr]) {\r\n              values[createdAtAttr] = now;\r\n              if (!options.fields.includes(createdAtAttr)) {\r\n                options.fields.push(createdAtAttr);\r\n              }\r\n            }\r\n            if (updatedAtAttr && !values[updatedAtAttr]) {\r\n              values[updatedAtAttr] = now;\r\n              if (!options.fields.includes(updatedAtAttr)) {\r\n                options.fields.push(updatedAtAttr);\r\n              }\r\n            }\r\n\r\n            const out = Object.assign({}, Utils.mapValueFieldNames(values, options.fields, model));\r\n            for (const key of model._virtualAttributes) {\r\n              delete out[key];\r\n            }\r\n            return out;\r\n          });\r\n\r\n          // Map attributes to fields for serial identification\r\n          const fieldMappedAttributes = {};\r\n          for (const attr in model.tableAttributes) {\r\n            fieldMappedAttributes[model.rawAttributes[attr].field || attr] = model.rawAttributes[attr];\r\n          }\r\n\r\n          // Map updateOnDuplicate attributes to fields\r\n          if (options.updateOnDuplicate) {\r\n            options.updateOnDuplicate = options.updateOnDuplicate.map(attr => model.rawAttributes[attr].field || attr);\r\n            // Get primary keys for postgres to enable updateOnDuplicate\r\n            options.upsertKeys = _.chain(model.primaryKeys).values().map('field').value();\r\n            if (Object.keys(model.uniqueKeys).length > 0) {\r\n              options.upsertKeys = _.chain(model.uniqueKeys).values().filter(c => c.fields.length === 1).map('column').value();\r\n            }\r\n          }\r\n\r\n          // Map returning attributes to fields\r\n          if (options.returning && Array.isArray(options.returning)) {\r\n            options.returning = options.returning.map(attr => model.rawAttributes[attr].field || attr);\r\n          }\r\n\r\n          return model.QueryInterface.bulkInsert(model.getTableName(options), records, options, fieldMappedAttributes).then(results => {\r\n            if (Array.isArray(results)) {\r\n              results.forEach((result, i) => {\r\n                const instance = instances[i];\r\n\r\n                for (const key in result) {\r\n                  if (!instance || key === model.primaryKeyAttribute &&\r\n                    instance.get(model.primaryKeyAttribute) &&\r\n                    ['mysql', 'mariadb', 'sqlite'].includes(dialect)) {\r\n                    // The query.js for these DBs is blind, it autoincrements the\r\n                    // primarykey value, even if it was set manually. Also, it can\r\n                    // return more results than instances, bug?.\r\n                    continue;\r\n                  }\r\n                  if (Object.prototype.hasOwnProperty.call(result, key)) {\r\n                    const record = result[key];\r\n\r\n                    const attr = _.find(model.rawAttributes, attribute => attribute.fieldName === key || attribute.field === key);\r\n\r\n                    instance.dataValues[attr && attr.fieldName || key] = record;\r\n                  }\r\n                }\r\n              });\r\n            }\r\n            return results;\r\n          });\r\n        });\r\n      }).then(() => {\r\n        if (!options.include || !options.include.length) return;\r\n\r\n        // Nested creation for HasOne/HasMany/BelongsToMany relations\r\n        return Promise.map(options.include.filter(include => !(include.association instanceof BelongsTo ||\r\n          include.parent && include.parent.association instanceof BelongsToMany)), include => {\r\n          const associationInstances = [];\r\n          const associationInstanceIndexToInstanceMap = [];\r\n\r\n          for (const instance of instances) {\r\n            let associated = instance.get(include.as);\r\n            if (!Array.isArray(associated)) associated = [associated];\r\n\r\n            for (const associationInstance of associated) {\r\n              if (associationInstance) {\r\n                if (!(include.association instanceof BelongsToMany)) {\r\n                  associationInstance.set(include.association.foreignKey, instance.get(include.association.sourceKey || instance.constructor.primaryKeyAttribute, { raw: true }), { raw: true });\r\n                  Object.assign(associationInstance, include.association.scope);\r\n                }\r\n                associationInstances.push(associationInstance);\r\n                associationInstanceIndexToInstanceMap.push(instance);\r\n              }\r\n            }\r\n          }\r\n\r\n          if (!associationInstances.length) {\r\n            return;\r\n          }\r\n\r\n          const includeOptions = _(Utils.cloneDeep(include))\r\n            .omit(['association'])\r\n            .defaults({\r\n              transaction: options.transaction,\r\n              logging: options.logging\r\n            }).value();\r\n\r\n          return recursiveBulkCreate(associationInstances, includeOptions).then(associationInstances => {\r\n            if (include.association instanceof BelongsToMany) {\r\n              const valueSets = [];\r\n\r\n              for (const idx in associationInstances) {\r\n                const associationInstance = associationInstances[idx];\r\n                const instance = associationInstanceIndexToInstanceMap[idx];\r\n\r\n                const values = {};\r\n                values[include.association.foreignKey] = instance.get(instance.constructor.primaryKeyAttribute, { raw: true });\r\n                values[include.association.otherKey] = associationInstance.get(associationInstance.constructor.primaryKeyAttribute, { raw: true });\r\n\r\n                // Include values defined in the association\r\n                Object.assign(values, include.association.through.scope);\r\n                if (associationInstance[include.association.through.model.name]) {\r\n                  for (const attr of Object.keys(include.association.through.model.rawAttributes)) {\r\n                    if (include.association.through.model.rawAttributes[attr]._autoGenerated ||\r\n                      attr === include.association.foreignKey ||\r\n                      attr === include.association.otherKey ||\r\n                      typeof associationInstance[include.association.through.model.name][attr] === undefined) {\r\n                      continue;\r\n                    }\r\n                    values[attr] = associationInstance[include.association.through.model.name][attr];\r\n                  }\r\n                }\r\n\r\n                valueSets.push(values);\r\n              }\r\n\r\n              const throughOptions = _(Utils.cloneDeep(include))\r\n                .omit(['association', 'attributes'])\r\n                .defaults({\r\n                  transaction: options.transaction,\r\n                  logging: options.logging\r\n                }).value();\r\n              throughOptions.model = include.association.throughModel;\r\n              const throughInstances = include.association.throughModel.bulkBuild(valueSets, throughOptions);\r\n\r\n              return recursiveBulkCreate(throughInstances, throughOptions);\r\n            }\r\n          });\r\n        });\r\n      }).then(() => {\r\n        // map fields back to attributes\r\n        instances.forEach(instance => {\r\n          for (const attr in model.rawAttributes) {\r\n            if (model.rawAttributes[attr].field &&\r\n                instance.dataValues[model.rawAttributes[attr].field] !== undefined &&\r\n                model.rawAttributes[attr].field !== attr\r\n            ) {\r\n              instance.dataValues[attr] = instance.dataValues[model.rawAttributes[attr].field];\r\n              delete instance.dataValues[model.rawAttributes[attr].field];\r\n            }\r\n            instance._previousDataValues[attr] = instance.dataValues[attr];\r\n            instance.changed(attr, false);\r\n          }\r\n          instance.isNewRecord = false;\r\n        });\r\n\r\n        // Run after hook\r\n        if (options.hooks) {\r\n          return model.runHooks('afterBulkCreate', instances, options);\r\n        }\r\n      }).then(() => instances);\r\n    };\r\n\r\n    return recursiveBulkCreate(instances, options);\r\n  }\r\n\r\n  /**\r\n   * Truncate all instances of the model. This is a convenient method for Model.destroy({ truncate: true }).\r\n   *\r\n   * @param {Object}           [options] The options passed to Model.destroy in addition to truncate\r\n   * @param {boolean|Function} [options.cascade = false] Truncates all tables that have foreign-key references to the named table, or to any tables added to the group due to CASCADE.\r\n   * @param {boolean}          [options.restartIdentity=false] Automatically restart sequences owned by columns of the truncated table.\r\n   * @param {Transaction}      [options.transaction] Transaction to run query under\r\n   * @param {boolean|Function} [options.logging] A function that logs sql queries, or false for no logging\r\n   * @param {boolean}          [options.benchmark=false] Pass query execution time in milliseconds as second argument to logging function (options.logging).\r\n   * @param {string}           [options.searchPath=DEFAULT] An optional parameter to specify the schema search_path (Postgres only)\r\n   *\r\n   * @returns {Promise}\r\n   *\r\n   * @see\r\n   * {@link Model.destroy} for more information\r\n   */\r\n  static truncate(options) {\r\n    options = Utils.cloneDeep(options) || {};\r\n    options.truncate = true;\r\n    return this.destroy(options);\r\n  }\r\n\r\n  /**\r\n   * Delete multiple instances, or set their deletedAt timestamp to the current time if `paranoid` is enabled.\r\n   *\r\n   * @param  {Object}       options                         destroy options\r\n   * @param  {Object}       [options.where]                 Filter the destroy\r\n   * @param  {boolean}      [options.hooks=true]            Run before / after bulk destroy hooks?\r\n   * @param  {boolean}      [options.individualHooks=false] If set to true, destroy will SELECT all records matching the where parameter and will execute before / after destroy hooks on each row\r\n   * @param  {number}       [options.limit]                 How many rows to delete\r\n   * @param  {boolean}      [options.force=false]           Delete instead of setting deletedAt to current timestamp (only applicable if `paranoid` is enabled)\r\n   * @param  {boolean}      [options.truncate=false]        If set to true, dialects that support it will use TRUNCATE instead of DELETE FROM. If a table is truncated the where and limit options are ignored\r\n   * @param  {boolean}      [options.cascade=false]         Only used in conjunction with TRUNCATE. Truncates  all tables that have foreign-key references to the named table, or to any tables added to the group due to CASCADE.\r\n   * @param  {boolean}      [options.restartIdentity=false] Only used in conjunction with TRUNCATE. Automatically restart sequences owned by columns of the truncated table.\r\n   * @param  {Transaction}  [options.transaction] Transaction to run query under\r\n   * @param  {Function}     [options.logging=false]         A function that gets executed while running the query to log the sql.\r\n   * @param  {boolean}      [options.benchmark=false]       Pass query execution time in milliseconds as second argument to logging function (options.logging).\r\n   *\r\n   * @returns {Promise<number>} The number of destroyed rows\r\n   */\r\n  static destroy(options) {\r\n    options = Utils.cloneDeep(options);\r\n\r\n    this._injectScope(options);\r\n\r\n    if (!options || !(options.where || options.truncate)) {\r\n      throw new Error('Missing where or truncate attribute in the options parameter of model.destroy.');\r\n    }\r\n\r\n    if (!options.truncate && !_.isPlainObject(options.where) && !Array.isArray(options.where) && !(options.where instanceof Utils.SequelizeMethod)) {\r\n      throw new Error('Expected plain object, array or sequelize method in the options.where parameter of model.destroy.');\r\n    }\r\n\r\n    options = _.defaults(options, {\r\n      hooks: true,\r\n      individualHooks: false,\r\n      force: false,\r\n      cascade: false,\r\n      restartIdentity: false\r\n    });\r\n\r\n    options.type = QueryTypes.BULKDELETE;\r\n\r\n    Utils.mapOptionFieldNames(options, this);\r\n    options.model = this;\r\n\r\n    let instances;\r\n\r\n    return Promise.try(() => {\r\n      // Run before hook\r\n      if (options.hooks) {\r\n        return this.runHooks('beforeBulkDestroy', options);\r\n      }\r\n    }).then(() => {\r\n      // Get daos and run beforeDestroy hook on each record individually\r\n      if (options.individualHooks) {\r\n        return this.findAll({ where: options.where, transaction: options.transaction, logging: options.logging, benchmark: options.benchmark })\r\n          .map(instance => this.runHooks('beforeDestroy', instance, options).then(() => instance))\r\n          .then(_instances => {\r\n            instances = _instances;\r\n          });\r\n      }\r\n    }).then(() => {\r\n      // Run delete query (or update if paranoid)\r\n      if (this._timestampAttributes.deletedAt && !options.force) {\r\n        // Set query type appropriately when running soft delete\r\n        options.type = QueryTypes.BULKUPDATE;\r\n\r\n        const attrValueHash = {};\r\n        const deletedAtAttribute = this.rawAttributes[this._timestampAttributes.deletedAt];\r\n        const field = this.rawAttributes[this._timestampAttributes.deletedAt].field;\r\n        const where = {\r\n          [field]: Object.prototype.hasOwnProperty.call(deletedAtAttribute, 'defaultValue') ? deletedAtAttribute.defaultValue : null\r\n        };\r\n\r\n\r\n        attrValueHash[field] = Utils.now(this.sequelize.options.dialect);\r\n        return this.QueryInterface.bulkUpdate(this.getTableName(options), attrValueHash, Object.assign(where, options.where), options, this.rawAttributes);\r\n      }\r\n      return this.QueryInterface.bulkDelete(this.getTableName(options), options.where, options, this);\r\n    }).tap(() => {\r\n      // Run afterDestroy hook on each record individually\r\n      if (options.individualHooks) {\r\n        return Promise.map(instances, instance => this.runHooks('afterDestroy', instance, options));\r\n      }\r\n    }).tap(() => {\r\n      // Run after hook\r\n      if (options.hooks) {\r\n        return this.runHooks('afterBulkDestroy', options);\r\n      }\r\n    });\r\n  }\r\n\r\n  /**\r\n   * Restore multiple instances if `paranoid` is enabled.\r\n   *\r\n   * @param  {Object}       options                         restore options\r\n   * @param  {Object}       [options.where]                 Filter the restore\r\n   * @param  {boolean}      [options.hooks=true]            Run before / after bulk restore hooks?\r\n   * @param  {boolean}      [options.individualHooks=false] If set to true, restore will find all records within the where parameter and will execute before / after bulkRestore hooks on each row\r\n   * @param  {number}       [options.limit]                 How many rows to undelete (only for mysql)\r\n   * @param  {Function}     [options.logging=false]         A function that gets executed while running the query to log the sql.\r\n   * @param  {boolean}      [options.benchmark=false]       Pass query execution time in milliseconds as second argument to logging function (options.logging).\r\n   * @param  {Transaction}  [options.transaction]           Transaction to run query under\r\n   *\r\n   * @returns {Promise}\r\n   */\r\n  static restore(options) {\r\n    if (!this._timestampAttributes.deletedAt) throw new Error('Model is not paranoid');\r\n\r\n    options = Object.assign({\r\n      hooks: true,\r\n      individualHooks: false\r\n    }, options || {});\r\n\r\n    options.type = QueryTypes.RAW;\r\n    options.model = this;\r\n\r\n    let instances;\r\n\r\n    Utils.mapOptionFieldNames(options, this);\r\n\r\n    return Promise.try(() => {\r\n      // Run before hook\r\n      if (options.hooks) {\r\n        return this.runHooks('beforeBulkRestore', options);\r\n      }\r\n    }).then(() => {\r\n      // Get daos and run beforeRestore hook on each record individually\r\n      if (options.individualHooks) {\r\n        return this.findAll({ where: options.where, transaction: options.transaction, logging: options.logging, benchmark: options.benchmark, paranoid: false })\r\n          .map(instance => this.runHooks('beforeRestore', instance, options).then(() => instance))\r\n          .then(_instances => {\r\n            instances = _instances;\r\n          });\r\n      }\r\n    }).then(() => {\r\n      // Run undelete query\r\n      const attrValueHash = {};\r\n      const deletedAtCol = this._timestampAttributes.deletedAt;\r\n      const deletedAtAttribute = this.rawAttributes[deletedAtCol];\r\n      const deletedAtDefaultValue = Object.prototype.hasOwnProperty.call(deletedAtAttribute, 'defaultValue') ? deletedAtAttribute.defaultValue : null;\r\n\r\n      attrValueHash[deletedAtAttribute.field || deletedAtCol] = deletedAtDefaultValue;\r\n      options.omitNull = false;\r\n      return this.QueryInterface.bulkUpdate(this.getTableName(options), attrValueHash, options.where, options, this.rawAttributes);\r\n    }).tap(() => {\r\n      // Run afterDestroy hook on each record individually\r\n      if (options.individualHooks) {\r\n        return Promise.map(instances, instance => this.runHooks('afterRestore', instance, options));\r\n      }\r\n    }).tap(() => {\r\n      // Run after hook\r\n      if (options.hooks) {\r\n        return this.runHooks('afterBulkRestore', options);\r\n      }\r\n    });\r\n  }\r\n\r\n  /**\r\n   * Update multiple instances that match the where options.\r\n   *\r\n   * @param  {Object}       values                          hash of values to update\r\n   * @param  {Object}       options                         update options\r\n   * @param  {Object}       options.where                   Options to describe the scope of the search.\r\n   * @param  {boolean}      [options.paranoid=true]         If true, only non-deleted records will be updated. If false, both deleted and non-deleted records will be updated. Only applies if `options.paranoid` is true for the model.\r\n   * @param  {Array}        [options.fields]                Fields to update (defaults to all fields)\r\n   * @param  {boolean}      [options.validate=true]         Should each row be subject to validation before it is inserted. The whole insert will fail if one row fails validation\r\n   * @param  {boolean}      [options.hooks=true]            Run before / after bulk update hooks?\r\n   * @param  {boolean}      [options.sideEffects=true]      Whether or not to update the side effects of any virtual setters.\r\n   * @param  {boolean}      [options.individualHooks=false] Run before / after update hooks?. If true, this will execute a SELECT followed by individual UPDATEs. A select is needed, because the row data needs to be passed to the hooks\r\n   * @param  {boolean}      [options.returning=false]       Return the affected rows (only for postgres)\r\n   * @param  {number}       [options.limit]                 How many rows to update (only for mysql and mariadb, implemented as TOP(n) for MSSQL; for sqlite it is supported only when rowid is present)\r\n   * @param  {Function}     [options.logging=false]         A function that gets executed while running the query to log the sql.\r\n   * @param  {boolean}      [options.benchmark=false]       Pass query execution time in milliseconds as second argument to logging function (options.logging).\r\n   * @param  {Transaction}  [options.transaction]           Transaction to run query under\r\n   * @param  {boolean}      [options.silent=false]          If true, the updatedAt timestamp will not be updated.\r\n   *\r\n   * @returns {Promise<Array<number,number>>}  The promise returns an array with one or two elements. The first element is always the number\r\n   * of affected rows, while the second element is the actual affected rows (only supported in postgres with `options.returning` true.)\r\n   *\r\n   */\r\n  static update(values, options) {\r\n    options = Utils.cloneDeep(options);\r\n\r\n    this._injectScope(options);\r\n    this._optionsMustContainWhere(options);\r\n\r\n    options = this._paranoidClause(this, _.defaults(options, {\r\n      validate: true,\r\n      hooks: true,\r\n      individualHooks: false,\r\n      returning: false,\r\n      force: false,\r\n      sideEffects: true\r\n    }));\r\n\r\n    options.type = QueryTypes.BULKUPDATE;\r\n\r\n    // Clone values so it doesn't get modified for caller scope and ignore undefined values\r\n    values = _.omitBy(values, value => value === undefined);\r\n\r\n    // Remove values that are not in the options.fields\r\n    if (options.fields && options.fields instanceof Array) {\r\n      for (const key of Object.keys(values)) {\r\n        if (!options.fields.includes(key)) {\r\n          delete values[key];\r\n        }\r\n      }\r\n    } else {\r\n      const updatedAtAttr = this._timestampAttributes.updatedAt;\r\n      options.fields = _.intersection(Object.keys(values), Object.keys(this.tableAttributes));\r\n      if (updatedAtAttr && !options.fields.includes(updatedAtAttr)) {\r\n        options.fields.push(updatedAtAttr);\r\n      }\r\n    }\r\n\r\n    if (this._timestampAttributes.updatedAt && !options.silent) {\r\n      values[this._timestampAttributes.updatedAt] = this._getDefaultTimestamp(this._timestampAttributes.updatedAt) || Utils.now(this.sequelize.options.dialect);\r\n    }\r\n\r\n    options.model = this;\r\n\r\n    let instances;\r\n    let valuesUse;\r\n\r\n    return Promise.try(() => {\r\n      // Validate\r\n      if (options.validate) {\r\n        const build = this.build(values);\r\n        build.set(this._timestampAttributes.updatedAt, values[this._timestampAttributes.updatedAt], { raw: true });\r\n\r\n        if (options.sideEffects) {\r\n          values = Object.assign(values, _.pick(build.get(), build.changed()));\r\n          options.fields = _.union(options.fields, Object.keys(values));\r\n        }\r\n\r\n        // We want to skip validations for all other fields\r\n        options.skip = _.difference(Object.keys(this.rawAttributes), Object.keys(values));\r\n        return build.validate(options).then(attributes => {\r\n          options.skip = undefined;\r\n          if (attributes && attributes.dataValues) {\r\n            values = _.pick(attributes.dataValues, Object.keys(values));\r\n          }\r\n        });\r\n      }\r\n      return null;\r\n    }).then(() => {\r\n      // Run before hook\r\n      if (options.hooks) {\r\n        options.attributes = values;\r\n        return this.runHooks('beforeBulkUpdate', options).then(() => {\r\n          values = options.attributes;\r\n          delete options.attributes;\r\n        });\r\n      }\r\n      return null;\r\n    }).then(() => {\r\n      valuesUse = values;\r\n\r\n      // Get instances and run beforeUpdate hook on each record individually\r\n      if (options.individualHooks) {\r\n        return this.findAll({\r\n          where: options.where,\r\n          transaction: options.transaction,\r\n          logging: options.logging,\r\n          benchmark: options.benchmark,\r\n          paranoid: options.paranoid\r\n        }).then(_instances => {\r\n          instances = _instances;\r\n          if (!instances.length) {\r\n            return [];\r\n          }\r\n\r\n          // Run beforeUpdate hooks on each record and check whether beforeUpdate hook changes values uniformly\r\n          // i.e. whether they change values for each record in the same way\r\n          let changedValues;\r\n          let different = false;\r\n\r\n          return Promise.map(instances, instance => {\r\n            // Record updates in instances dataValues\r\n            Object.assign(instance.dataValues, values);\r\n            // Set the changed fields on the instance\r\n            _.forIn(valuesUse, (newValue, attr) => {\r\n              if (newValue !== instance._previousDataValues[attr]) {\r\n                instance.setDataValue(attr, newValue);\r\n              }\r\n            });\r\n\r\n            // Run beforeUpdate hook\r\n            return this.runHooks('beforeUpdate', instance, options).then(() => {\r\n              if (!different) {\r\n                const thisChangedValues = {};\r\n                _.forIn(instance.dataValues, (newValue, attr) => {\r\n                  if (newValue !== instance._previousDataValues[attr]) {\r\n                    thisChangedValues[attr] = newValue;\r\n                  }\r\n                });\r\n\r\n                if (!changedValues) {\r\n                  changedValues = thisChangedValues;\r\n                } else {\r\n                  different = !_.isEqual(changedValues, thisChangedValues);\r\n                }\r\n              }\r\n\r\n              return instance;\r\n            });\r\n          }).then(_instances => {\r\n            instances = _instances;\r\n\r\n            if (!different) {\r\n              const keys = Object.keys(changedValues);\r\n              // Hooks do not change values or change them uniformly\r\n              if (keys.length) {\r\n                // Hooks change values - record changes in valuesUse so they are executed\r\n                valuesUse = changedValues;\r\n                options.fields = _.union(options.fields, keys);\r\n              }\r\n              return;\r\n            }\r\n            // Hooks change values in a different way for each record\r\n            // Do not run original query but save each record individually\r\n            return Promise.map(instances, instance => {\r\n              const individualOptions = _.clone(options);\r\n              delete individualOptions.individualHooks;\r\n              individualOptions.hooks = false;\r\n              individualOptions.validate = false;\r\n\r\n              return instance.save(individualOptions);\r\n            }).tap(_instances => {\r\n              instances = _instances;\r\n            });\r\n          });\r\n        });\r\n      }\r\n    }).then(results => {\r\n      // Update already done row-by-row - exit\r\n      if (results) {\r\n        return [results.length, results];\r\n      }\r\n\r\n      // only updatedAt is being passed, then skip update\r\n      if (\r\n        _.isEmpty(valuesUse)\r\n         || Object.keys(valuesUse).length === 1 && valuesUse[this._timestampAttributes.updatedAt]\r\n      ) {\r\n        return [0];\r\n      }\r\n\r\n      valuesUse = Utils.mapValueFieldNames(valuesUse, options.fields, this);\r\n      options = Utils.mapOptionFieldNames(options, this);\r\n      options.hasTrigger = this.options ? this.options.hasTrigger : false;\r\n\r\n      // Run query to update all rows\r\n      return this.QueryInterface.bulkUpdate(this.getTableName(options), valuesUse, options.where, options, this.tableAttributes).then(affectedRows => {\r\n        if (options.returning) {\r\n          instances = affectedRows;\r\n          return [affectedRows.length, affectedRows];\r\n        }\r\n\r\n        return [affectedRows];\r\n      });\r\n    }).tap(result => {\r\n      if (options.individualHooks) {\r\n        return Promise.map(instances, instance => {\r\n          return this.runHooks('afterUpdate', instance, options);\r\n        }).then(() => {\r\n          result[1] = instances;\r\n        });\r\n      }\r\n    }).tap(() => {\r\n      // Run after hook\r\n      if (options.hooks) {\r\n        options.attributes = values;\r\n        return this.runHooks('afterBulkUpdate', options).then(() => {\r\n          delete options.attributes;\r\n        });\r\n      }\r\n    });\r\n  }\r\n\r\n  /**\r\n   * Run a describe query on the table.\r\n   *\r\n   * @param {string} [schema] schema name to search table in\r\n   * @param {Object} [options] query options\r\n   *\r\n   * @returns {Promise} hash of attributes and their types\r\n   */\r\n  static describe(schema, options) {\r\n    return this.QueryInterface.describeTable(this.tableName, Object.assign({ schema: schema || this._schema || undefined }, options));\r\n  }\r\n\r\n  static _getDefaultTimestamp(attr) {\r\n    if (!!this.rawAttributes[attr] && !!this.rawAttributes[attr].defaultValue) {\r\n      return Utils.toDefaultValue(this.rawAttributes[attr].defaultValue, this.sequelize.options.dialect);\r\n    }\r\n    return undefined;\r\n  }\r\n\r\n  static _expandAttributes(options) {\r\n    if (!_.isPlainObject(options.attributes)) {\r\n      return;\r\n    }\r\n    let attributes = Object.keys(this.rawAttributes);\r\n\r\n    if (options.attributes.exclude) {\r\n      attributes = attributes.filter(elem => !options.attributes.exclude.includes(elem));\r\n    }\r\n\r\n    if (options.attributes.include) {\r\n      attributes = attributes.concat(options.attributes.include);\r\n    }\r\n\r\n    options.attributes = attributes;\r\n  }\r\n\r\n  // Inject _scope into options.\r\n  static _injectScope(options) {\r\n    const scope = Utils.cloneDeep(this._scope);\r\n    this._defaultsOptions(options, scope);\r\n  }\r\n\r\n  static [Symbol.for('nodejs.util.inspect.custom')]() {\r\n    return this.name;\r\n  }\r\n\r\n  static inspect() {\r\n    return this.name;\r\n  }\r\n\r\n  static hasAlias(alias) {\r\n    return Object.prototype.hasOwnProperty.call(this.associations, alias);\r\n  }\r\n\r\n  /**\r\n   * Increment the value of one or more columns. This is done in the database, which means it does not use the values currently stored on the Instance. The increment is done using a\r\n   * ``` SET column = column + X WHERE foo = 'bar' ``` query. To get the correct value after an increment into the Instance you should do a reload.\r\n   *\r\n   * @example <caption>increment number by 1</caption>\r\n   * Model.increment('number', { where: { foo: 'bar' });\r\n   *\r\n   * @example <caption>increment number and count by 2</caption>\r\n   * Model.increment(['number', 'count'], { by: 2, where: { foo: 'bar' } });\r\n   *\r\n   * @example <caption>increment answer by 42, and decrement tries by 1</caption>\r\n   * // `by` is ignored, as each column has its own value\r\n   * Model.increment({ answer: 42, tries: -1}, { by: 2, where: { foo: 'bar' } });\r\n   *\r\n   * @see\r\n   * {@link Model#reload}\r\n   *\r\n   * @param {string|Array|Object} fields If a string is provided, that column is incremented by the value of `by` given in options. If an array is provided, the same is true for each column. If and object is provided, each column is incremented by the value given.\r\n   * @param {Object} options increment options\r\n   * @param {Object} options.where conditions hash\r\n   * @param {number} [options.by=1] The number to increment by\r\n   * @param {boolean} [options.silent=false] If true, the updatedAt timestamp will not be updated.\r\n   * @param {Function} [options.logging=false] A function that gets executed while running the query to log the sql.\r\n   * @param {Transaction} [options.transaction] Transaction to run query under\r\n   * @param {string} [options.searchPath=DEFAULT] An optional parameter to specify the schema search_path (Postgres only)\r\n   *\r\n   * @returns {Promise<Model[],?number>} returns an array of affected rows and affected count with `options.returning: true`, whenever supported by dialect\r\n   */\r\n  static increment(fields, options) {\r\n    options = options || {};\r\n\r\n    this._injectScope(options);\r\n    this._optionsMustContainWhere(options);\r\n\r\n    const updatedAtAttr = this._timestampAttributes.updatedAt;\r\n    const versionAttr = this._versionAttribute;\r\n    const updatedAtAttribute = this.rawAttributes[updatedAtAttr];\r\n    options = Utils.defaults({}, options, {\r\n      by: 1,\r\n      attributes: {},\r\n      where: {},\r\n      increment: true\r\n    });\r\n\r\n    Utils.mapOptionFieldNames(options, this);\r\n\r\n    const where = Object.assign({}, options.where);\r\n    let values = {};\r\n\r\n    if (typeof fields === 'string') {\r\n      values[fields] = options.by;\r\n    } else if (Array.isArray(fields)) {\r\n      fields.forEach(field => {\r\n        values[field] = options.by;\r\n      });\r\n    } else { // Assume fields is key-value pairs\r\n      values = fields;\r\n    }\r\n\r\n    if (!options.silent && updatedAtAttr && !values[updatedAtAttr]) {\r\n      options.attributes[updatedAtAttribute.field || updatedAtAttr] = this._getDefaultTimestamp(updatedAtAttr) || Utils.now(this.sequelize.options.dialect);\r\n    }\r\n    if (versionAttr) {\r\n      values[versionAttr] = options.increment ? 1 : -1;\r\n    }\r\n\r\n    for (const attr of Object.keys(values)) {\r\n      // Field name mapping\r\n      if (this.rawAttributes[attr] && this.rawAttributes[attr].field && this.rawAttributes[attr].field !== attr) {\r\n        values[this.rawAttributes[attr].field] = values[attr];\r\n        delete values[attr];\r\n      }\r\n    }\r\n\r\n    let promise;\r\n    if (!options.increment) {\r\n      promise = this.QueryInterface.decrement(this, this.getTableName(options), values, where, options);\r\n    } else {\r\n      promise = this.QueryInterface.increment(this, this.getTableName(options), values, where, options);\r\n    }\r\n\r\n    return promise.then(affectedRows => {\r\n      if (options.returning) {\r\n        return [affectedRows, affectedRows.length];\r\n      }\r\n\r\n      return [affectedRows];\r\n    });\r\n  }\r\n\r\n  /**\r\n   * Decrement the value of one or more columns. This is done in the database, which means it does not use the values currently stored on the Instance. The decrement is done using a\r\n   * ```sql SET column = column - X WHERE foo = 'bar'``` query. To get the correct value after a decrement into the Instance you should do a reload.\r\n   *\r\n   * @example <caption>decrement number by 1</caption>\r\n   * Model.decrement('number', { where: { foo: 'bar' });\r\n   *\r\n   * @example <caption>decrement number and count by 2</caption>\r\n   * Model.decrement(['number', 'count'], { by: 2, where: { foo: 'bar' } });\r\n   *\r\n   * @example <caption>decrement answer by 42, and decrement tries by -1</caption>\r\n   * // `by` is ignored, since each column has its own value\r\n   * Model.decrement({ answer: 42, tries: -1}, { by: 2, where: { foo: 'bar' } });\r\n   *\r\n   * @param {string|Array|Object} fields If a string is provided, that column is incremented by the value of `by` given in options. If an array is provided, the same is true for each column. If and object is provided, each column is incremented by the value given.\r\n   * @param {Object} options decrement options, similar to increment\r\n   *\r\n   * @see\r\n   * {@link Model.increment}\r\n   * @see\r\n   * {@link Model#reload}\r\n   * @since 4.36.0\r\n\r\n   * @returns {Promise<Model[],?number>} returns an array of affected rows and affected count with `options.returning: true`, whenever supported by dialect\r\n   */\r\n  static decrement(fields, options) {\r\n    options = _.defaults({ increment: false }, options, {\r\n      by: 1\r\n    });\r\n\r\n    return this.increment(fields, options);\r\n  }\r\n\r\n  static _optionsMustContainWhere(options) {\r\n    assert(options && options.where, 'Missing where attribute in the options parameter');\r\n    assert(_.isPlainObject(options.where) || Array.isArray(options.where) || options.where instanceof Utils.SequelizeMethod,\r\n      'Expected plain object, array or sequelize method in the options.where parameter');\r\n  }\r\n\r\n  /**\r\n   * Get an object representing the query for this instance, use with `options.where`\r\n   *\r\n   * @param {boolean} [checkVersion=false] include version attribute in where hash\r\n   *\r\n   * @returns {Object}\r\n   */\r\n  where(checkVersion) {\r\n    const where = this.constructor.primaryKeyAttributes.reduce((result, attribute) => {\r\n      result[attribute] = this.get(attribute, { raw: true });\r\n      return result;\r\n    }, {});\r\n\r\n    if (_.size(where) === 0) {\r\n      return this._modelOptions.whereCollection;\r\n    }\r\n    const versionAttr = this.constructor._versionAttribute;\r\n    if (checkVersion && versionAttr) {\r\n      where[versionAttr] = this.get(versionAttr, { raw: true });\r\n    }\r\n    return Utils.mapWhereFieldNames(where, this.constructor);\r\n  }\r\n\r\n  toString() {\r\n    return `[object SequelizeInstance:${this.constructor.name}]`;\r\n  }\r\n\r\n  /**\r\n   * Get the value of the underlying data value\r\n   *\r\n   * @param {string} key key to look in instance data store\r\n   *\r\n   * @returns {any}\r\n   */\r\n  getDataValue(key) {\r\n    return this.dataValues[key];\r\n  }\r\n\r\n  /**\r\n   * Update the underlying data value\r\n   *\r\n   * @param {string} key key to set in instance data store\r\n   * @param {any} value new value for given key\r\n   *\r\n   */\r\n  setDataValue(key, value) {\r\n    const originalValue = this._previousDataValues[key];\r\n\r\n    if (!Utils.isPrimitive(value) && value !== null || value !== originalValue) {\r\n      this.changed(key, true);\r\n    }\r\n\r\n    this.dataValues[key] = value;\r\n  }\r\n\r\n  /**\r\n   * If no key is given, returns all values of the instance, also invoking virtual getters.\r\n   *\r\n   * If key is given and a field or virtual getter is present for the key it will call that getter - else it will return the value for key.\r\n   *\r\n   * @param {string}  [key] key to get value of\r\n   * @param {Object}  [options] get options\r\n   * @param {boolean} [options.plain=false] If set to true, included instances will be returned as plain objects\r\n   * @param {boolean} [options.raw=false] If set to true, field and virtual setters will be ignored\r\n   *\r\n   * @returns {Object|any}\r\n   */\r\n  get(key, options) {\r\n    if (options === undefined && typeof key === 'object') {\r\n      options = key;\r\n      key = undefined;\r\n    }\r\n\r\n    options = options || {};\r\n\r\n    if (key) {\r\n      if (Object.prototype.hasOwnProperty.call(this._customGetters, key) && !options.raw) {\r\n        return this._customGetters[key].call(this, key, options);\r\n      }\r\n\r\n      if (options.plain && this._options.include && this._options.includeNames.includes(key)) {\r\n        if (Array.isArray(this.dataValues[key])) {\r\n          return this.dataValues[key].map(instance => instance.get(options));\r\n        }\r\n        if (this.dataValues[key] instanceof Model) {\r\n          return this.dataValues[key].get(options);\r\n        }\r\n        return this.dataValues[key];\r\n      }\r\n\r\n      return this.dataValues[key];\r\n    }\r\n\r\n    if (\r\n      this._hasCustomGetters\r\n      || options.plain && this._options.include\r\n      || options.clone\r\n    ) {\r\n      const values = {};\r\n      let _key;\r\n\r\n      if (this._hasCustomGetters) {\r\n        for (_key in this._customGetters) {\r\n          if (\r\n            this._options.attributes\r\n            && !this._options.attributes.includes(_key)\r\n          ) {\r\n            continue;\r\n          }\r\n\r\n          if (Object.prototype.hasOwnProperty.call(this._customGetters, _key)) {\r\n            values[_key] = this.get(_key, options);\r\n          }\r\n        }\r\n      }\r\n\r\n      for (_key in this.dataValues) {\r\n        if (\r\n          !Object.prototype.hasOwnProperty.call(values, _key)\r\n          && Object.prototype.hasOwnProperty.call(this.dataValues, _key)\r\n        ) {\r\n          values[_key] = this.get(_key, options);\r\n        }\r\n      }\r\n\r\n      return values;\r\n    }\r\n\r\n    return this.dataValues;\r\n  }\r\n\r\n  /**\r\n   * Set is used to update values on the instance (the sequelize representation of the instance that is, remember that nothing will be persisted before you actually call `save`).\r\n   * In its most basic form `set` will update a value stored in the underlying `dataValues` object. However, if a custom setter function is defined for the key, that function\r\n   * will be called instead. To bypass the setter, you can pass `raw: true` in the options object.\r\n   *\r\n   * If set is called with an object, it will loop over the object, and call set recursively for each key, value pair. If you set raw to true, the underlying dataValues will either be\r\n   * set directly to the object passed, or used to extend dataValues, if dataValues already contain values.\r\n   *\r\n   * When set is called, the previous value of the field is stored and sets a changed flag(see `changed`).\r\n   *\r\n   * Set can also be used to build instances for associations, if you have values for those.\r\n   * When using set with associations you need to make sure the property key matches the alias of the association\r\n   * while also making sure that the proper include options have been set (from .build() or .findOne())\r\n   *\r\n   * If called with a dot.separated key on a JSON/JSONB attribute it will set the value nested and flag the entire object as changed.\r\n   *\r\n   * @see\r\n   * {@link Model.findAll} for more information about includes\r\n   *\r\n   * @param {string|Object} key key to set, it can be string or object. When string it will set that key, for object it will loop over all object properties nd set them.\r\n   * @param {any} value value to set\r\n   * @param {Object} [options] set options\r\n   * @param {boolean} [options.raw=false] If set to true, field and virtual setters will be ignored\r\n   * @param {boolean} [options.reset=false] Clear all previously set data values\r\n   *\r\n   * @returns {Model}\r\n   */\r\n  set(key, value, options) {\r\n    let values;\r\n    let originalValue;\r\n\r\n    if (typeof key === 'object' && key !== null) {\r\n      values = key;\r\n      options = value || {};\r\n\r\n      if (options.reset) {\r\n        this.dataValues = {};\r\n        for (const key in values) {\r\n          this.changed(key, false);\r\n        }\r\n      }\r\n\r\n      // If raw, and we're not dealing with includes or special attributes, just set it straight on the dataValues object\r\n      if (options.raw && !(this._options && this._options.include) && !(options && options.attributes) && !this.constructor._hasDateAttributes && !this.constructor._hasBooleanAttributes) {\r\n        if (Object.keys(this.dataValues).length) {\r\n          this.dataValues = Object.assign(this.dataValues, values);\r\n        } else {\r\n          this.dataValues = values;\r\n        }\r\n        // If raw, .changed() shouldn't be true\r\n        this._previousDataValues = _.clone(this.dataValues);\r\n      } else {\r\n        // Loop and call set\r\n        if (options.attributes) {\r\n          const setKeys = data => {\r\n            for (const k of data) {\r\n              if (values[k] === undefined) {\r\n                continue;\r\n              }\r\n              this.set(k, values[k], options);\r\n            }\r\n          };\r\n          setKeys(options.attributes);\r\n          if (this.constructor._hasVirtualAttributes) {\r\n            setKeys(this.constructor._virtualAttributes);\r\n          }\r\n          if (this._options.includeNames) {\r\n            setKeys(this._options.includeNames);\r\n          }\r\n        } else {\r\n          for (const key in values) {\r\n            this.set(key, values[key], options);\r\n          }\r\n        }\r\n\r\n        if (options.raw) {\r\n          // If raw, .changed() shouldn't be true\r\n          this._previousDataValues = _.clone(this.dataValues);\r\n        }\r\n      }\r\n      return this;\r\n    }\r\n    if (!options)\r\n      options = {};\r\n    if (!options.raw) {\r\n      originalValue = this.dataValues[key];\r\n    }\r\n\r\n    // If not raw, and there's a custom setter\r\n    if (!options.raw && this._customSetters[key]) {\r\n      this._customSetters[key].call(this, value, key);\r\n      // custom setter should have changed value, get that changed value\r\n      // TODO: v5 make setters return new value instead of changing internal store\r\n      const newValue = this.dataValues[key];\r\n      if (!Utils.isPrimitive(newValue) && newValue !== null || newValue !== originalValue) {\r\n        this._previousDataValues[key] = originalValue;\r\n        this.changed(key, true);\r\n      }\r\n    } else {\r\n      // Check if we have included models, and if this key matches the include model names/aliases\r\n      if (this._options && this._options.include && this._options.includeNames.includes(key)) {\r\n        // Pass it on to the include handler\r\n        this._setInclude(key, value, options);\r\n        return this;\r\n      }\r\n      // Bunch of stuff we won't do when it's raw\r\n      if (!options.raw) {\r\n        // If attribute is not in model definition, return\r\n        if (!this._isAttribute(key)) {\r\n          if (key.includes('.') && this.constructor._jsonAttributes.has(key.split('.')[0])) {\r\n            const previousNestedValue = Dottie.get(this.dataValues, key);\r\n            if (!_.isEqual(previousNestedValue, value)) {\r\n              Dottie.set(this.dataValues, key, value);\r\n              this.changed(key.split('.')[0], true);\r\n            }\r\n          }\r\n          return this;\r\n        }\r\n\r\n        // If attempting to set primary key and primary key is already defined, return\r\n        if (this.constructor._hasPrimaryKeys && originalValue && this.constructor._isPrimaryKey(key)) {\r\n          return this;\r\n        }\r\n\r\n        // If attempting to set read only attributes, return\r\n        if (!this.isNewRecord && this.constructor._hasReadOnlyAttributes && this.constructor._readOnlyAttributes.has(key)) {\r\n          return this;\r\n        }\r\n      }\r\n\r\n      // If there's a data type sanitizer\r\n      if (\r\n        !(value instanceof Utils.SequelizeMethod)\r\n        && Object.prototype.hasOwnProperty.call(this.constructor._dataTypeSanitizers, key)\r\n      ) {\r\n        value = this.constructor._dataTypeSanitizers[key].call(this, value, options);\r\n      }\r\n\r\n      // Set when the value has changed and not raw\r\n      if (\r\n        !options.raw &&\r\n        (\r\n          // True when sequelize method\r\n          value instanceof Utils.SequelizeMethod ||\r\n          // Check for data type type comparators\r\n          !(value instanceof Utils.SequelizeMethod) && this.constructor._dataTypeChanges[key] && this.constructor._dataTypeChanges[key].call(this, value, originalValue, options) ||\r\n          // Check default\r\n          !this.constructor._dataTypeChanges[key] && (!Utils.isPrimitive(value) && value !== null || value !== originalValue)\r\n        )\r\n      ) {\r\n        this._previousDataValues[key] = originalValue;\r\n        this.changed(key, true);\r\n      }\r\n\r\n      // set data value\r\n      this.dataValues[key] = value;\r\n    }\r\n    return this;\r\n  }\r\n\r\n  setAttributes(updates) {\r\n    return this.set(updates);\r\n  }\r\n\r\n  /**\r\n   * If changed is called with a string it will return a boolean indicating whether the value of that key in `dataValues` is different from the value in `_previousDataValues`.\r\n   *\r\n   * If changed is called without an argument, it will return an array of keys that have changed.\r\n   *\r\n   * If changed is called without an argument and no keys have changed, it will return `false`.\r\n   *\r\n   * @param {string} [key] key to check or change status of\r\n   * @param {any} [value] value to set\r\n   *\r\n   * @returns {boolean|Array}\r\n   */\r\n  changed(key, value) {\r\n    if (key) {\r\n      if (value !== undefined) {\r\n        this._changed[key] = value;\r\n        return this;\r\n      }\r\n      return this._changed[key] || false;\r\n    }\r\n\r\n    const changed = Object.keys(this.dataValues).filter(key => this.changed(key));\r\n\r\n    return changed.length ? changed : false;\r\n  }\r\n\r\n  /**\r\n   * Returns the previous value for key from `_previousDataValues`.\r\n   *\r\n   * If called without a key, returns the previous values for all values which have changed\r\n   *\r\n   * @param {string} [key] key to get previous value of\r\n   *\r\n   * @returns {any|Array<any>}\r\n   */\r\n  previous(key) {\r\n    if (key) {\r\n      return this._previousDataValues[key];\r\n    }\r\n\r\n    return _.pickBy(this._previousDataValues, (value, key) => this.changed(key));\r\n  }\r\n\r\n  _setInclude(key, value, options) {\r\n    if (!Array.isArray(value)) value = [value];\r\n    if (value[0] instanceof Model) {\r\n      value = value.map(instance => instance.dataValues);\r\n    }\r\n\r\n    const include = this._options.includeMap[key];\r\n    const association = include.association;\r\n    const accessor = key;\r\n    const primaryKeyAttribute = include.model.primaryKeyAttribute;\r\n    const childOptions = {\r\n      isNewRecord: this.isNewRecord,\r\n      include: include.include,\r\n      includeNames: include.includeNames,\r\n      includeMap: include.includeMap,\r\n      includeValidated: true,\r\n      raw: options.raw,\r\n      attributes: include.originalAttributes\r\n    };\r\n    let isEmpty;\r\n\r\n    if (include.originalAttributes === undefined || include.originalAttributes.length) {\r\n      if (association.isSingleAssociation) {\r\n        if (Array.isArray(value)) {\r\n          value = value[0];\r\n        }\r\n        isEmpty = value && value[primaryKeyAttribute] === null || value === null;\r\n        this[accessor] = this.dataValues[accessor] = isEmpty ? null : include.model.build(value, childOptions);\r\n      } else {\r\n        isEmpty = value[0] && value[0][primaryKeyAttribute] === null;\r\n        this[accessor] = this.dataValues[accessor] = isEmpty ? [] : include.model.bulkBuild(value, childOptions);\r\n      }\r\n    }\r\n  }\r\n\r\n  /**\r\n   * Validate this instance, and if the validation passes, persist it to the database. It will only save changed fields, and do nothing if no fields have changed.\r\n   *\r\n   * On success, the callback will be called with this instance. On validation error, the callback will be called with an instance of `Sequelize.ValidationError`.\r\n   * This error will have a property for each of the fields for which validation failed, with the error message for that field.\r\n   *\r\n   * @param {Object}      [options] save options\r\n   * @param {string[]}    [options.fields] An optional array of strings, representing database columns. If fields is provided, only those columns will be validated and saved.\r\n   * @param {boolean}     [options.silent=false] If true, the updatedAt timestamp will not be updated.\r\n   * @param {boolean}     [options.validate=true] If false, validations won't be run.\r\n   * @param {boolean}     [options.hooks=true] Run before and after create / update + validate hooks\r\n   * @param {Function}    [options.logging=false] A function that gets executed while running the query to log the sql.\r\n   * @param {Transaction} [options.transaction] Transaction to run query under\r\n   * @param {string}      [options.searchPath=DEFAULT] An optional parameter to specify the schema search_path (Postgres only)\r\n   * @param {boolean}     [options.returning] Append RETURNING * to get back auto generated values (Postgres only)\r\n   *\r\n   * @returns {Promise<Model>}\r\n   */\r\n  save(options) {\r\n    if (arguments.length > 1) {\r\n      throw new Error('The second argument was removed in favor of the options object.');\r\n    }\r\n\r\n    options = Utils.cloneDeep(options);\r\n    options = _.defaults(options, {\r\n      hooks: true,\r\n      validate: true\r\n    });\r\n\r\n    if (!options.fields) {\r\n      if (this.isNewRecord) {\r\n        options.fields = Object.keys(this.constructor.rawAttributes);\r\n      } else {\r\n        options.fields = _.intersection(this.changed(), Object.keys(this.constructor.rawAttributes));\r\n      }\r\n\r\n      options.defaultFields = options.fields;\r\n    }\r\n\r\n    if (options.returning === undefined) {\r\n      if (options.association) {\r\n        options.returning = false;\r\n      } else if (this.isNewRecord) {\r\n        options.returning = true;\r\n      }\r\n    }\r\n\r\n    const primaryKeyName = this.constructor.primaryKeyAttribute;\r\n    const primaryKeyAttribute = primaryKeyName && this.constructor.rawAttributes[primaryKeyName];\r\n    const createdAtAttr = this.constructor._timestampAttributes.createdAt;\r\n    const versionAttr = this.constructor._versionAttribute;\r\n    const hook = this.isNewRecord ? 'Create' : 'Update';\r\n    const wasNewRecord = this.isNewRecord;\r\n    const now = Utils.now(this.sequelize.options.dialect);\r\n    let updatedAtAttr = this.constructor._timestampAttributes.updatedAt;\r\n\r\n    if (updatedAtAttr && options.fields.length >= 1 && !options.fields.includes(updatedAtAttr)) {\r\n      options.fields.push(updatedAtAttr);\r\n    }\r\n    if (versionAttr && options.fields.length >= 1 && !options.fields.includes(versionAttr)) {\r\n      options.fields.push(versionAttr);\r\n    }\r\n\r\n    if (options.silent === true && !(this.isNewRecord && this.get(updatedAtAttr, { raw: true }))) {\r\n      // UpdateAtAttr might have been added as a result of Object.keys(Model.rawAttributes). In that case we have to remove it again\r\n      _.remove(options.fields, val => val === updatedAtAttr);\r\n      updatedAtAttr = false;\r\n    }\r\n\r\n    if (this.isNewRecord === true) {\r\n      if (createdAtAttr && !options.fields.includes(createdAtAttr)) {\r\n        options.fields.push(createdAtAttr);\r\n      }\r\n\r\n      if (primaryKeyAttribute && primaryKeyAttribute.defaultValue && !options.fields.includes(primaryKeyName)) {\r\n        options.fields.unshift(primaryKeyName);\r\n      }\r\n    }\r\n\r\n    if (this.isNewRecord === false) {\r\n      if (primaryKeyName && this.get(primaryKeyName, { raw: true }) === undefined) {\r\n        throw new Error('You attempted to save an instance with no primary key, this is not allowed since it would result in a global update');\r\n      }\r\n    }\r\n\r\n    if (updatedAtAttr && !options.silent && options.fields.includes(updatedAtAttr)) {\r\n      this.dataValues[updatedAtAttr] = this.constructor._getDefaultTimestamp(updatedAtAttr) || now;\r\n    }\r\n\r\n    if (this.isNewRecord && createdAtAttr && !this.dataValues[createdAtAttr]) {\r\n      this.dataValues[createdAtAttr] = this.constructor._getDefaultTimestamp(createdAtAttr) || now;\r\n    }\r\n\r\n    return Promise.try(() => {\r\n      // Validate\r\n      if (options.validate) {\r\n        return this.validate(options);\r\n      }\r\n    }).then(() => {\r\n      // Run before hook\r\n      if (options.hooks) {\r\n        const beforeHookValues = _.pick(this.dataValues, options.fields);\r\n        let ignoreChanged = _.difference(this.changed(), options.fields); // In case of update where it's only supposed to update the passed values and the hook values\r\n        let hookChanged;\r\n        let afterHookValues;\r\n\r\n        if (updatedAtAttr && options.fields.includes(updatedAtAttr)) {\r\n          ignoreChanged = _.without(ignoreChanged, updatedAtAttr);\r\n        }\r\n\r\n        return this.constructor.runHooks(`before${hook}`, this, options)\r\n          .then(() => {\r\n            if (options.defaultFields && !this.isNewRecord) {\r\n              afterHookValues = _.pick(this.dataValues, _.difference(this.changed(), ignoreChanged));\r\n\r\n              hookChanged = [];\r\n              for (const key of Object.keys(afterHookValues)) {\r\n                if (afterHookValues[key] !== beforeHookValues[key]) {\r\n                  hookChanged.push(key);\r\n                }\r\n              }\r\n\r\n              options.fields = _.uniq(options.fields.concat(hookChanged));\r\n            }\r\n\r\n            if (hookChanged) {\r\n              if (options.validate) {\r\n              // Validate again\r\n\r\n                options.skip = _.difference(Object.keys(this.constructor.rawAttributes), hookChanged);\r\n                return this.validate(options).then(() => {\r\n                  delete options.skip;\r\n                });\r\n              }\r\n            }\r\n          });\r\n      }\r\n    }).then(() => {\r\n      if (!options.fields.length) return this;\r\n      if (!this.isNewRecord) return this;\r\n      if (!this._options.include || !this._options.include.length) return this;\r\n\r\n      // Nested creation for BelongsTo relations\r\n      return Promise.map(this._options.include.filter(include => include.association instanceof BelongsTo), include => {\r\n        const instance = this.get(include.as);\r\n        if (!instance) return Promise.resolve();\r\n\r\n        const includeOptions = _(Utils.cloneDeep(include))\r\n          .omit(['association'])\r\n          .defaults({\r\n            transaction: options.transaction,\r\n            logging: options.logging,\r\n            parentRecord: this\r\n          }).value();\r\n\r\n        return instance.save(includeOptions).then(() => this[include.association.accessors.set](instance, { save: false, logging: options.logging }));\r\n      });\r\n    }).then(() => {\r\n      const realFields = options.fields.filter(field => !this.constructor._virtualAttributes.has(field));\r\n      if (!realFields.length) return this;\r\n      if (!this.changed() && !this.isNewRecord) return this;\r\n\r\n      const versionFieldName = _.get(this.constructor.rawAttributes[versionAttr], 'field') || versionAttr;\r\n      let values = Utils.mapValueFieldNames(this.dataValues, options.fields, this.constructor);\r\n      let query = null;\r\n      let args = [];\r\n      let where;\r\n\r\n      if (this.isNewRecord) {\r\n        query = 'insert';\r\n        args = [this, this.constructor.getTableName(options), values, options];\r\n      } else {\r\n        where = this.where(true);\r\n        if (versionAttr) {\r\n          values[versionFieldName] = parseInt(values[versionFieldName], 10) + 1;\r\n        }\r\n        query = 'update';\r\n        args = [this, this.constructor.getTableName(options), values, where, options];\r\n      }\r\n\r\n      return this.constructor.QueryInterface[query](...args)\r\n        .then(([result, rowsUpdated])=> {\r\n          if (versionAttr) {\r\n            // Check to see that a row was updated, otherwise it's an optimistic locking error.\r\n            if (rowsUpdated < 1) {\r\n              throw new sequelizeErrors.OptimisticLockError({\r\n                modelName: this.constructor.name,\r\n                values,\r\n                where\r\n              });\r\n            } else {\r\n              result.dataValues[versionAttr] = values[versionFieldName];\r\n            }\r\n          }\r\n\r\n          // Transfer database generated values (defaults, autoincrement, etc)\r\n          for (const attr of Object.keys(this.constructor.rawAttributes)) {\r\n            if (this.constructor.rawAttributes[attr].field &&\r\n                values[this.constructor.rawAttributes[attr].field] !== undefined &&\r\n                this.constructor.rawAttributes[attr].field !== attr\r\n            ) {\r\n              values[attr] = values[this.constructor.rawAttributes[attr].field];\r\n              delete values[this.constructor.rawAttributes[attr].field];\r\n            }\r\n          }\r\n          values = Object.assign(values, result.dataValues);\r\n\r\n          result.dataValues = Object.assign(result.dataValues, values);\r\n          return result;\r\n        })\r\n        .tap(() => {\r\n          if (!wasNewRecord) return this;\r\n          if (!this._options.include || !this._options.include.length) return this;\r\n\r\n          // Nested creation for HasOne/HasMany/BelongsToMany relations\r\n          return Promise.map(this._options.include.filter(include => !(include.association instanceof BelongsTo ||\r\n            include.parent && include.parent.association instanceof BelongsToMany)), include => {\r\n            let instances = this.get(include.as);\r\n\r\n            if (!instances) return Promise.resolve();\r\n            if (!Array.isArray(instances)) instances = [instances];\r\n            if (!instances.length) return Promise.resolve();\r\n\r\n            const includeOptions = _(Utils.cloneDeep(include))\r\n              .omit(['association'])\r\n              .defaults({\r\n                transaction: options.transaction,\r\n                logging: options.logging,\r\n                parentRecord: this\r\n              }).value();\r\n\r\n            // Instances will be updated in place so we can safely treat HasOne like a HasMany\r\n            return Promise.map(instances, instance => {\r\n              if (include.association instanceof BelongsToMany) {\r\n                return instance.save(includeOptions).then(() => {\r\n                  const values = {};\r\n                  values[include.association.foreignKey] = this.get(this.constructor.primaryKeyAttribute, { raw: true });\r\n                  values[include.association.otherKey] = instance.get(instance.constructor.primaryKeyAttribute, { raw: true });\r\n\r\n                  // Include values defined in the association\r\n                  Object.assign(values, include.association.through.scope);\r\n                  if (instance[include.association.through.model.name]) {\r\n                    for (const attr of Object.keys(include.association.through.model.rawAttributes)) {\r\n                      if (include.association.through.model.rawAttributes[attr]._autoGenerated ||\r\n                        attr === include.association.foreignKey ||\r\n                        attr === include.association.otherKey ||\r\n                        typeof instance[include.association.through.model.name][attr] === undefined) {\r\n                        continue;\r\n                      }\r\n                      values[attr] = instance[include.association.through.model.name][attr];\r\n                    }\r\n                  }\r\n\r\n                  return include.association.throughModel.create(values, includeOptions);\r\n                });\r\n              }\r\n              instance.set(include.association.foreignKey, this.get(include.association.sourceKey || this.constructor.primaryKeyAttribute, { raw: true }), { raw: true });\r\n              Object.assign(instance, include.association.scope);\r\n              return instance.save(includeOptions);\r\n            });\r\n          });\r\n        })\r\n        .tap(result => {\r\n          // Run after hook\r\n          if (options.hooks) {\r\n            return this.constructor.runHooks(`after${hook}`, result, options);\r\n          }\r\n        })\r\n        .then(result => {\r\n          for (const field of options.fields) {\r\n            result._previousDataValues[field] = result.dataValues[field];\r\n            this.changed(field, false);\r\n          }\r\n          this.isNewRecord = false;\r\n          return result;\r\n        });\r\n    });\r\n  }\r\n\r\n  /**\r\n   * Refresh the current instance in-place, i.e. update the object with current data from the DB and return the same object.\r\n   * This is different from doing a `find(Instance.id)`, because that would create and return a new instance. With this method,\r\n   * all references to the Instance are updated with the new data and no new objects are created.\r\n   *\r\n   * @see\r\n   * {@link Model.findAll}\r\n   *\r\n   * @param {Object} [options] Options that are passed on to `Model.find`\r\n   * @param {Function} [options.logging=false] A function that gets executed while running the query to log the sql.\r\n   *\r\n   * @returns {Promise<Model>}\r\n   */\r\n  reload(options) {\r\n    options = Utils.defaults({}, options, {\r\n      where: this.where(),\r\n      include: this._options.include || null\r\n    });\r\n\r\n    return this.constructor.findOne(options)\r\n      .tap(reload => {\r\n        if (!reload) {\r\n          throw new sequelizeErrors.InstanceError(\r\n            'Instance could not be reloaded because it does not exist anymore (find call returned null)'\r\n          );\r\n        }\r\n      })\r\n      .then(reload => {\r\n      // update the internal options of the instance\r\n        this._options = reload._options;\r\n        // re-set instance values\r\n        this.set(reload.dataValues, {\r\n          raw: true,\r\n          reset: true && !options.attributes\r\n        });\r\n        return this;\r\n      });\r\n  }\r\n\r\n  /**\r\n  * Validate the attributes of this instance according to validation rules set in the model definition.\r\n  *\r\n  * The promise fulfills if and only if validation successful; otherwise it rejects an Error instance containing { field name : [error msgs] } entries.\r\n  *\r\n  * @param {Object} [options] Options that are passed to the validator\r\n  * @param {Array} [options.skip] An array of strings. All properties that are in this array will not be validated\r\n  * @param {Array} [options.fields] An array of strings. Only the properties that are in this array will be validated\r\n  * @param {boolean} [options.hooks=true] Run before and after validate hooks\r\n  *\r\n  * @returns {Promise}\r\n  */\r\n  validate(options) {\r\n    return new InstanceValidator(this, options).validate();\r\n  }\r\n\r\n  /**\r\n   * This is the same as calling `set` and then calling `save` but it only saves the\r\n   * exact values passed to it, making it more atomic and safer.\r\n   *\r\n   * @see\r\n   * {@link Model#set}\r\n   * @see\r\n   * {@link Model#save}\r\n   *\r\n   * @param {Object} values See `set`\r\n   * @param {Object} options See `save`\r\n   *\r\n   * @returns {Promise<Model>}\r\n   */\r\n  update(values, options) {\r\n    // Clone values so it doesn't get modified for caller scope and ignore undefined values\r\n    values = _.omitBy(values, value => value === undefined);\r\n\r\n    const changedBefore = this.changed() || [];\r\n\r\n    options = options || {};\r\n    if (Array.isArray(options)) options = { fields: options };\r\n\r\n    options = Utils.cloneDeep(options);\r\n    const setOptions = Utils.cloneDeep(options);\r\n    setOptions.attributes = options.fields;\r\n    this.set(values, setOptions);\r\n\r\n    // Now we need to figure out which fields were actually affected by the setter.\r\n    const sideEffects = _.without(this.changed(), ...changedBefore);\r\n    const fields = _.union(Object.keys(values), sideEffects);\r\n\r\n    if (!options.fields) {\r\n      options.fields = _.intersection(fields, this.changed());\r\n      options.defaultFields = options.fields;\r\n    }\r\n\r\n    return this.save(options);\r\n  }\r\n\r\n  /**\r\n   * Destroy the row corresponding to this instance. Depending on your setting for paranoid, the row will either be completely deleted, or have its deletedAt timestamp set to the current time.\r\n   *\r\n   * @param {Object}      [options={}] destroy options\r\n   * @param {boolean}     [options.force=false] If set to true, paranoid models will actually be deleted\r\n   * @param {Function}    [options.logging=false] A function that gets executed while running the query to log the sql.\r\n   * @param {Transaction} [options.transaction] Transaction to run query under\r\n   * @param {string}      [options.searchPath=DEFAULT] An optional parameter to specify the schema search_path (Postgres only)\r\n   *\r\n   * @returns {Promise}\r\n   */\r\n  destroy(options) {\r\n    options = Object.assign({\r\n      hooks: true,\r\n      force: false\r\n    }, options);\r\n\r\n    return Promise.try(() => {\r\n      // Run before hook\r\n      if (options.hooks) {\r\n        return this.constructor.runHooks('beforeDestroy', this, options);\r\n      }\r\n    }).then(() => {\r\n      const where = this.where(true);\r\n\r\n      if (this.constructor._timestampAttributes.deletedAt && options.force === false) {\r\n        const attributeName = this.constructor._timestampAttributes.deletedAt;\r\n        const attribute = this.constructor.rawAttributes[attributeName];\r\n        const defaultValue = Object.prototype.hasOwnProperty.call(attribute, 'defaultValue')\r\n          ? attribute.defaultValue\r\n          : null;\r\n        const currentValue = this.getDataValue(attributeName);\r\n        const undefinedOrNull = currentValue == null && defaultValue == null;\r\n        if (undefinedOrNull || _.isEqual(currentValue, defaultValue)) {\r\n          // only update timestamp if it wasn't already set\r\n          this.setDataValue(attributeName, new Date());\r\n        }\r\n\r\n        return this.save(_.defaults({ hooks: false }, options));\r\n      }\r\n      return this.constructor.QueryInterface.delete(this, this.constructor.getTableName(options), where, Object.assign({ type: QueryTypes.DELETE, limit: null }, options));\r\n    }).tap(() => {\r\n      // Run after hook\r\n      if (options.hooks) {\r\n        return this.constructor.runHooks('afterDestroy', this, options);\r\n      }\r\n    });\r\n  }\r\n\r\n  /**\r\n   * Helper method to determine if a instance is \"soft deleted\".  This is\r\n   * particularly useful if the implementer renamed the `deletedAt` attribute\r\n   * to something different.  This method requires `paranoid` to be enabled.\r\n   *\r\n   * @returns {boolean}\r\n   */\r\n  isSoftDeleted() {\r\n    if (!this.constructor._timestampAttributes.deletedAt) {\r\n      throw new Error('Model is not paranoid');\r\n    }\r\n\r\n    const deletedAtAttribute = this.constructor.rawAttributes[this.constructor._timestampAttributes.deletedAt];\r\n    const defaultValue = Object.prototype.hasOwnProperty.call(deletedAtAttribute, 'defaultValue') ? deletedAtAttribute.defaultValue : null;\r\n    const deletedAt = this.get(this.constructor._timestampAttributes.deletedAt) || null;\r\n    const isSet = deletedAt !== defaultValue;\r\n\r\n    return isSet;\r\n  }\r\n\r\n  /**\r\n   * Restore the row corresponding to this instance. Only available for paranoid models.\r\n   *\r\n   * @param {Object}      [options={}] restore options\r\n   * @param {Function}    [options.logging=false] A function that gets executed while running the query to log the sql.\r\n   * @param {Transaction} [options.transaction] Transaction to run query under\r\n   *\r\n   * @returns {Promise}\r\n   */\r\n  restore(options) {\r\n    if (!this.constructor._timestampAttributes.deletedAt) throw new Error('Model is not paranoid');\r\n\r\n    options = Object.assign({\r\n      hooks: true,\r\n      force: false\r\n    }, options);\r\n\r\n    return Promise.try(() => {\r\n      // Run before hook\r\n      if (options.hooks) {\r\n        return this.constructor.runHooks('beforeRestore', this, options);\r\n      }\r\n    }).then(() => {\r\n      const deletedAtCol = this.constructor._timestampAttributes.deletedAt;\r\n      const deletedAtAttribute = this.constructor.rawAttributes[deletedAtCol];\r\n      const deletedAtDefaultValue = Object.prototype.hasOwnProperty.call(deletedAtAttribute, 'defaultValue') ? deletedAtAttribute.defaultValue : null;\r\n\r\n      this.setDataValue(deletedAtCol, deletedAtDefaultValue);\r\n      return this.save(Object.assign({}, options, { hooks: false, omitNull: false }));\r\n    }).tap(() => {\r\n      // Run after hook\r\n      if (options.hooks) {\r\n        return this.constructor.runHooks('afterRestore', this, options);\r\n      }\r\n    });\r\n  }\r\n\r\n  /**\r\n   * Increment the value of one or more columns. This is done in the database, which means it does not use the values currently stored on the Instance. The increment is done using a\r\n   * ```sql\r\n   * SET column = column + X\r\n   * ```\r\n   * query. The updated instance will be returned by default in Postgres. However, in other dialects, you will need to do a reload to get the new values.\r\n   *\r\n   * @example\r\n   * instance.increment('number') // increment number by 1\r\n   *\r\n   * instance.increment(['number', 'count'], { by: 2 }) // increment number and count by 2\r\n   *\r\n   * // increment answer by 42, and tries by 1.\r\n   * // `by` is ignored, since each column has its own value\r\n   * instance.increment({ answer: 42, tries: 1}, { by: 2 })\r\n   *\r\n   * @see\r\n   * {@link Model#reload}\r\n   *\r\n   * @param {string|Array|Object} fields If a string is provided, that column is incremented by the value of `by` given in options. If an array is provided, the same is true for each column. If and object is provided, each column is incremented by the value given.\r\n   * @param {Object} [options] options\r\n   * @param {number} [options.by=1] The number to increment by\r\n   * @param {boolean} [options.silent=false] If true, the updatedAt timestamp will not be updated.\r\n   * @param {Function} [options.logging=false] A function that gets executed while running the query to log the sql.\r\n   * @param {Transaction} [options.transaction] Transaction to run query under\r\n   * @param {string} [options.searchPath=DEFAULT] An optional parameter to specify the schema search_path (Postgres only)\r\n   * @param {boolean} [options.returning=true] Append RETURNING * to get back auto generated values (Postgres only)\r\n   *\r\n   * @returns {Promise<Model>}\r\n   * @since 4.0.0\r\n   */\r\n  increment(fields, options) {\r\n    const identifier = this.where();\r\n\r\n    options = Utils.cloneDeep(options);\r\n    options.where = Object.assign({}, options.where, identifier);\r\n    options.instance = this;\r\n\r\n    return this.constructor.increment(fields, options).return(this);\r\n  }\r\n\r\n  /**\r\n   * Decrement the value of one or more columns. This is done in the database, which means it does not use the values currently stored on the Instance. The decrement is done using a\r\n   * ```sql\r\n   * SET column = column - X\r\n   * ```\r\n   * query. The updated instance will be returned by default in Postgres. However, in other dialects, you will need to do a reload to get the new values.\r\n   *\r\n   * @example\r\n   * instance.decrement('number') // decrement number by 1\r\n   *\r\n   * instance.decrement(['number', 'count'], { by: 2 }) // decrement number and count by 2\r\n   *\r\n   * // decrement answer by 42, and tries by 1.\r\n   * // `by` is ignored, since each column has its own value\r\n   * instance.decrement({ answer: 42, tries: 1}, { by: 2 })\r\n   *\r\n   * @see\r\n   * {@link Model#reload}\r\n   * @param {string|Array|Object} fields If a string is provided, that column is decremented by the value of `by` given in options. If an array is provided, the same is true for each column. If and object is provided, each column is decremented by the value given\r\n   * @param {Object}      [options] decrement options\r\n   * @param {number}      [options.by=1] The number to decrement by\r\n   * @param {boolean}     [options.silent=false] If true, the updatedAt timestamp will not be updated.\r\n   * @param {Function}    [options.logging=false] A function that gets executed while running the query to log the sql.\r\n   * @param {Transaction} [options.transaction] Transaction to run query under\r\n   * @param {string}      [options.searchPath=DEFAULT] An optional parameter to specify the schema search_path (Postgres only)\r\n   * @param {boolean}     [options.returning=true] Append RETURNING * to get back auto generated values (Postgres only)\r\n   *\r\n   * @returns {Promise}\r\n   */\r\n  decrement(fields, options) {\r\n    options = _.defaults({ increment: false }, options, {\r\n      by: 1\r\n    });\r\n\r\n    return this.increment(fields, options);\r\n  }\r\n\r\n  /**\r\n   * Check whether this and `other` Instance refer to the same row\r\n   *\r\n   * @param {Model} other Other instance to compare against\r\n   *\r\n   * @returns {boolean}\r\n   */\r\n  equals(other) {\r\n    if (!other || !other.constructor) {\r\n      return false;\r\n    }\r\n\r\n    if (!(other instanceof this.constructor)) {\r\n      return false;\r\n    }\r\n\r\n    return this.constructor.primaryKeyAttributes.every(attribute => this.get(attribute, { raw: true }) === other.get(attribute, { raw: true }));\r\n  }\r\n\r\n  /**\r\n   * Check if this is equal to one of `others` by calling equals\r\n   *\r\n   * @param {Array<Model>} others An array of instances to check against\r\n   *\r\n   * @returns {boolean}\r\n   */\r\n  equalsOneOf(others) {\r\n    return others.some(other => this.equals(other));\r\n  }\r\n\r\n  setValidators(attribute, validators) {\r\n    this.validators[attribute] = validators;\r\n  }\r\n\r\n  /**\r\n   * Convert the instance to a JSON representation.\r\n   * Proxies to calling `get` with no keys.\r\n   * This means get all values gotten from the DB, and apply all custom getters.\r\n   *\r\n   * @see\r\n   * {@link Model#get}\r\n   *\r\n   * @returns {Object}\r\n   */\r\n  toJSON() {\r\n    return _.cloneDeep(\r\n      this.get({\r\n        plain: true\r\n      })\r\n    );\r\n  }\r\n\r\n  /**\r\n   * Creates a 1:m association between this (the source) and the provided target.\r\n   * The foreign key is added on the target.\r\n   *\r\n   * @param {Model}               target Target model\r\n   * @param {Object}              [options] hasMany association options\r\n   * @param {boolean}             [options.hooks=false] Set to true to run before-/afterDestroy hooks when an associated model is deleted because of a cascade. For example if `User.hasOne(Profile, {onDelete: 'cascade', hooks:true})`, the before-/afterDestroy hooks for profile will be called when a user is deleted. Otherwise the profile will be deleted without invoking any hooks\r\n   * @param {string|Object}       [options.as] The alias of this model. If you provide a string, it should be plural, and will be singularized using node.inflection. If you want to control the singular version yourself, provide an object with `plural` and `singular` keys. See also the `name` option passed to `sequelize.define`. If you create multiple associations between the same tables, you should provide an alias to be able to distinguish between them. If you provide an alias when creating the association, you should provide the same alias when eager loading and when getting associated models. Defaults to the pluralized name of target\r\n   * @param {string|Object}       [options.foreignKey] The name of the foreign key in the target table or an object representing the type definition for the foreign column (see `Sequelize.define` for syntax). When using an object, you can add a `name` property to set the name of the column. Defaults to the name of source + primary key of source\r\n   * @param {string}              [options.sourceKey] The name of the field to use as the key for the association in the source table. Defaults to the primary key of the source table\r\n   * @param {Object}              [options.scope] A key/value set that will be used for association create and find defaults on the target. (sqlite not supported for N:M)\r\n   * @param {string}              [options.onDelete='SET&nbsp;NULL|CASCADE'] SET NULL if foreignKey allows nulls, CASCADE if otherwise\r\n   * @param {string}              [options.onUpdate='CASCADE'] Set `ON UPDATE`\r\n   * @param {boolean}             [options.constraints=true] Should on update and on delete constraints be enabled on the foreign key.\r\n   *\r\n   * @returns {HasMany}\r\n   *\r\n   * @example\r\n   * User.hasMany(Profile) // This will add userId to the profile table\r\n   */\r\n  static hasMany(target, options) {} // eslint-disable-line\r\n\r\n  /**\r\n   * Create an N:M association with a join table. Defining `through` is required.\r\n   *\r\n   * @param {Model}               target Target model\r\n   * @param {Object}              options belongsToMany association options\r\n   * @param {boolean}             [options.hooks=false] Set to true to run before-/afterDestroy hooks when an associated model is deleted because of a cascade. For example if `User.hasOne(Profile, {onDelete: 'cascade', hooks:true})`, the before-/afterDestroy hooks for profile will be called when a user is deleted. Otherwise the profile will be deleted without invoking any hooks\r\n   * @param {Model|string|Object} options.through The name of the table that is used to join source and target in n:m associations. Can also be a sequelize model if you want to define the junction table yourself and add extra attributes to it.\r\n   * @param {Model}               [options.through.model] The model used to join both sides of the N:M association.\r\n   * @param {Object}              [options.through.scope] A key/value set that will be used for association create and find defaults on the through model. (Remember to add the attributes to the through model)\r\n   * @param {boolean}             [options.through.unique=true] If true a unique key will be generated from the foreign keys used (might want to turn this off and create specific unique keys when using scopes)\r\n   * @param {string|Object}       [options.as] The alias of this association. If you provide a string, it should be plural, and will be singularized using node.inflection. If you want to control the singular version yourself, provide an object with `plural` and `singular` keys. See also the `name` option passed to `sequelize.define`. If you create multiple associations between the same tables, you should provide an alias to be able to distinguish between them. If you provide an alias when creating the association, you should provide the same alias when eager loading and when getting associated models. Defaults to the pluralized name of target\r\n   * @param {string|Object}       [options.foreignKey] The name of the foreign key in the join table (representing the source model) or an object representing the type definition for the foreign column (see `Sequelize.define` for syntax). When using an object, you can add a `name` property to set the name of the column. Defaults to the name of source + primary key of source\r\n   * @param {string|Object}       [options.otherKey] The name of the foreign key in the join table (representing the target model) or an object representing the type definition for the other column (see `Sequelize.define` for syntax). When using an object, you can add a `name` property to set the name of the column. Defaults to the name of target + primary key of target\r\n   * @param {Object}              [options.scope] A key/value set that will be used for association create and find defaults on the target. (sqlite not supported for N:M)\r\n   * @param {boolean}             [options.timestamps=sequelize.options.timestamps] Should the join model have timestamps\r\n   * @param {string}              [options.onDelete='SET&nbsp;NULL|CASCADE'] Cascade if this is a n:m, and set null if it is a 1:m\r\n   * @param {string}              [options.onUpdate='CASCADE'] Sets `ON UPDATE`\r\n   * @param {boolean}             [options.constraints=true] Should on update and on delete constraints be enabled on the foreign key.\r\n   *\r\n   * @returns {BelongsToMany}\r\n   *\r\n   * @example\r\n   * // Automagically generated join model\r\n   * User.belongsToMany(Project, { through: 'UserProjects' })\r\n   * Project.belongsToMany(User, { through: 'UserProjects' })\r\n   *\r\n   * // Join model with additional attributes\r\n   * const UserProjects = sequelize.define('UserProjects', {\r\n   *   started: Sequelize.BOOLEAN\r\n   * })\r\n   * User.belongsToMany(Project, { through: UserProjects })\r\n   * Project.belongsToMany(User, { through: UserProjects })\r\n   */\r\n  static belongsToMany(target, options) {} // eslint-disable-line\r\n\r\n  /**\r\n   * Creates an association between this (the source) and the provided target. The foreign key is added on the target.\r\n   *\r\n   * @param {Model}           target Target model\r\n   * @param {Object}          [options] hasOne association options\r\n   * @param {boolean}         [options.hooks=false] Set to true to run before-/afterDestroy hooks when an associated model is deleted because of a cascade. For example if `User.hasOne(Profile, {onDelete: 'cascade', hooks:true})`, the before-/afterDestroy hooks for profile will be called when a user is deleted. Otherwise the profile will be deleted without invoking any hooks\r\n   * @param {string}          [options.as] The alias of this model, in singular form. See also the `name` option passed to `sequelize.define`. If you create multiple associations between the same tables, you should provide an alias to be able to distinguish between them. If you provide an alias when creating the association, you should provide the same alias when eager loading and when getting associated models. Defaults to the singularized name of target\r\n   * @param {string|Object}   [options.foreignKey] The name of the foreign key attribute in the target model or an object representing the type definition for the foreign column (see `Sequelize.define` for syntax). When using an object, you can add a `name` property to set the name of the column. Defaults to the name of source + primary key of source\r\n   * @param {string}          [options.sourceKey] The name of the attribute to use as the key for the association in the source table. Defaults to the primary key of the source table\r\n   * @param {string}          [options.onDelete='SET&nbsp;NULL|CASCADE'] SET NULL if foreignKey allows nulls, CASCADE if otherwise\r\n   * @param {string}          [options.onUpdate='CASCADE'] Sets 'ON UPDATE'\r\n   * @param {boolean}         [options.constraints=true] Should on update and on delete constraints be enabled on the foreign key.\r\n   * @param {string}          [options.uniqueKey] The custom name for unique constraint.\r\n   *\r\n   * @returns {HasOne}\r\n   *\r\n   * @example\r\n   * User.hasOne(Profile) // This will add userId to the profile table\r\n   */\r\n  static hasOne(target, options) {} // eslint-disable-line\r\n\r\n  /**\r\n   * Creates an association between this (the source) and the provided target. The foreign key is added on the source.\r\n   *\r\n   * @param {Model}           target The target model\r\n   * @param {Object}          [options] belongsTo association options\r\n   * @param {boolean}         [options.hooks=false] Set to true to run before-/afterDestroy hooks when an associated model is deleted because of a cascade. For example if `User.hasOne(Profile, {onDelete: 'cascade', hooks:true})`, the before-/afterDestroy hooks for profile will be called when a user is deleted. Otherwise the profile will be deleted without invoking any hooks\r\n   * @param {string}          [options.as] The alias of this model, in singular form. See also the `name` option passed to `sequelize.define`. If you create multiple associations between the same tables, you should provide an alias to be able to distinguish between them. If you provide an alias when creating the association, you should provide the same alias when eager loading and when getting associated models. Defaults to the singularized name of target\r\n   * @param {string|Object}   [options.foreignKey] The name of the foreign key attribute in the source table or an object representing the type definition for the foreign column (see `Sequelize.define` for syntax). When using an object, you can add a `name` property to set the name of the column. Defaults to the name of target + primary key of target\r\n   * @param {string}          [options.targetKey] The name of the attribute to use as the key for the association in the target table. Defaults to the primary key of the target table\r\n   * @param {string}          [options.onDelete='SET&nbsp;NULL|NO&nbsp;ACTION'] SET NULL if foreignKey allows nulls, NO ACTION if otherwise\r\n   * @param {string}          [options.onUpdate='CASCADE'] Sets 'ON UPDATE'\r\n   * @param {boolean}         [options.constraints=true] Should on update and on delete constraints be enabled on the foreign key.\r\n   *\r\n   * @returns {BelongsTo}\r\n   *\r\n   * @example\r\n   * Profile.belongsTo(User) // This will add userId to the profile table\r\n   */\r\n  static belongsTo(target, options) {} // eslint-disable-line\r\n}\r\n\r\nObject.assign(Model, associationsMixin);\r\nHooks.applyTo(Model, true);\r\n\r\nmodule.exports = Model;\r\n"]} \ No newline at end of file +//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../lib/model.js"],"names":["assert","require","_","Dottie","Utils","logger","BelongsTo","BelongsToMany","InstanceValidator","QueryTypes","sequelizeErrors","Promise","Association","HasMany","DataTypes","Hooks","associationsMixin","Op","noDoubleNestedGroup","validQueryKeywords","Set","nonCascadingOptions","Model","constructor","sequelize","getQueryInterface","QueryInterface","QueryGenerator","values","options","Object","assign","isNewRecord","_schema","_schemaDelimiter","attributes","map","attribute","Array","isArray","includeValidated","_conformIncludes","include","_expandIncludeAll","_validateIncludedElements","dataValues","_previousDataValues","_changed","_modelOptions","_options","_initValues","defaults","key","clone","_hasDefaultValues","mapValues","_defaultValues","valueFn","value","SequelizeMethod","cloneDeep","primaryKeyAttributes","length","forEach","primaryKeyAttribute","prototype","hasOwnProperty","call","_timestampAttributes","createdAt","toDefaultValue","dialect","updatedAt","deletedAt","keys","undefined","set","raw","checkVersion","where","reduce","result","get","size","whereCollection","versionAttr","_versionAttribute","mapWhereFieldNames","name","originalValue","isPrimitive","changed","_customGetters","plain","includeNames","includes","instance","_hasCustomGetters","_key","reset","_hasDateAttributes","_hasBooleanAttributes","setKeys","data","k","_hasVirtualAttributes","_virtualAttributes","_customSetters","newValue","_setInclude","_isAttribute","_jsonAttributes","has","split","previousNestedValue","isEqual","_hasPrimaryKeys","_isPrimaryKey","_hasReadOnlyAttributes","_readOnlyAttributes","_dataTypeSanitizers","_dataTypeChanges","updates","filter","pickBy","includeMap","association","accessor","model","childOptions","originalAttributes","isEmpty","isSingleAssociation","build","bulkBuild","arguments","Error","hooks","validate","fields","rawAttributes","intersection","defaultFields","returning","primaryKeyName","createdAtAttr","hook","wasNewRecord","now","updatedAtAttr","push","silent","remove","val","defaultValue","unshift","_getDefaultTimestamp","try","then","beforeHookValues","pick","ignoreChanged","difference","hookChanged","afterHookValues","without","runHooks","uniq","concat","skip","as","resolve","includeOptions","omit","transaction","logging","parentRecord","save","accessors","realFields","field","versionFieldName","mapValueFieldNames","query","args","getTableName","parseInt","rowsUpdated","OptimisticLockError","modelName","attr","tap","parent","instances","foreignKey","otherKey","through","scope","_autoGenerated","throughModel","create","sourceKey","findOne","reload","InstanceError","omitBy","changedBefore","setOptions","sideEffects","union","force","attributeName","currentValue","getDataValue","undefinedOrNull","setDataValue","Date","delete","type","DELETE","limit","deletedAtAttribute","isSet","deletedAtCol","deletedAtDefaultValue","omitNull","identifier","increment","return","by","other","every","others","some","equals","validators","_paranoidClause","groupedLimit","timestamps","paranoid","deletedAtObject","eq","isWhereEmpty","and","tail","head","tableName","id","INTEGER","allowNull","primaryKey","autoIncrement","DATE","existingAttributes","each","primaryKeys","autoIncrementAttribute","definition","self","_conformInclude","associations","_pseudo","_transformStringAssociation","target","source","isPlainObject","all","validTypes","HasOne","One","Has","Many","i","types","EagerLoadingError","splice","j","nested","used","addAllIncludes","associationType","predicate","thisInclude","pop","tableNames","hasSingleAssociation","hasMultiAssociation","topModel","topLimit","_validateIncludedElement","duplicating","isMultiAssociation","hasDuplicating","hasRequired","required","hasWhere","hasParentWhere","hasParentRequired","subQuery","subQueryFilter","hasIncludeWhere","hasIncludeRequired","_expandAttributes","_injectDependentVirtualAttributes","mapFinderOptions","includeAttr","tableAttributes","_getIncludedAssociation","scoped","_injectScope","separate","flattenDepth","targetModel","targetAlias","getAssociations","getAssociationForAlias","existingAliases","join","index","_expandIncludeAllElement","parser","toLowerCase","unique","groupBy","_assignOptions","assignWith","_uniqIncludes","objValue","srcValue","_baseMerge","_mergeFunction","opts","globalOptions","merge","define","plural","pluralize","singular","singularize","indexes","schema","defineProperty","freezeTableName","underscored","rejectOnEmpty","schemaDelimiter","defaultScope","scopes","isDefined","modelManager","removeModel","getModel","_setupHooks","underscoredIf","validator","validatorType","normalizeAttribute","references","_indexes","nameIndex","_conformIndex","add","version","_addDefaultAttributes","refreshAttributes","_findAutoIncrementAttribute","_scope","_scopeNames","addModel","attributeManipulation","opt","funcs","isObject","_custom","method","fct","configurable","fieldRawAttributesMap","uniqueKeys","normalizeDataType","fieldName","_modelAttribute","_sanitize","_isChanged","BOOLEAN","DATEONLY","JSON","VIRTUAL","idxName","idx","msg","column","customIndex","JSONB","using","fieldAttributeMap","_hasJsonAttributes","_a","_hasCustomSetters","log","primaryKeyField","drop","createTable","alter","describeTable","getForeignKeyReferencesForTable","tableInfos","columns","foreignKeyReferences","changes","removedConstraints","columnDesc","columnName","addColumn","currentAttribute","removeColumn","database","config","foreignKeyReference","constraintName","tableCatalog","tableSchema","referencedTableName","referencedColumnName","referencedTableSchema","removeConstraint","changeColumn","f","showIndex","item1","item2","sort","index1","index2","concurrently","addIndex","benchmark","dropTable","dropSchema","addSchema","override","option","scopeName","flatten","apply","slice","SequelizeScopeError","QueryError","warnOnInvalidOptions","hasJoin","group","selectOptions","select","results","EmptyResultError","_findSeparate","validColumnNames","unrecognizedOptions","unexpectedModelAttributes","warn","original","memo","len","param","Buffer","isBuffer","uniqueSingleColumns","chain","c","findAll","aggregateFunction","prevAttributes","attrOptions","aggregateColumn","col","distinct","fn","unionBy","a","dataType","FLOAT","mapOptionFieldNames","rawSelect","includeIgnoreAttributes","offset","order","aggregate","countOptions","count","rows","valueSets","unknownDefaults","_cls","t","internalTransaction","exception","UniqueConstraintError","catch","err","flattenedWhere","flattenObjectDeep","flattenedWhereKeys","last","whereFields","errFieldKeys","errFieldsWhereIntersects","intersects","toString","finally","commit","hasPrimary","updatedDataValues","insertValues","updateValues","upsert","created","findByPk","record","records","recursiveBulkCreate","individualHooks","ignoreDuplicates","reject","updateOnDuplicate","errors","AggregateError","validateOptions","BulkRecordError","individualOptions","associationInstances","associationInstanceIndexToInstanceMap","associationInstance","out","fieldMappedAttributes","upsertKeys","bulkInsert","find","associated","throughOptions","throughInstances","truncate","destroy","cascade","restartIdentity","BULKDELETE","_instances","BULKUPDATE","attrValueHash","bulkUpdate","bulkDelete","RAW","_optionsMustContainWhere","valuesUse","changedValues","different","forIn","thisChangedValues","hasTrigger","affectedRows","exclude","elem","_defaultsOptions","Symbol","for","alias","updatedAtAttribute","promise","decrement","applyTo","module","exports"],"mappings":"AAAA;;;;;;;;;;;;;;;;;;;;;;AAEA,MAAMA,MAAM,GAAGC,OAAO,CAAC,QAAD,CAAtB;;AACA,MAAMC,CAAC,GAAGD,OAAO,CAAC,QAAD,CAAjB;;AACA,MAAME,MAAM,GAAGF,OAAO,CAAC,QAAD,CAAtB;;AAEA,MAAMG,KAAK,GAAGH,OAAO,CAAC,SAAD,CAArB;;AACA,MAAM;AAAEI,EAAAA;AAAF,IAAaJ,OAAO,CAAC,gBAAD,CAA1B;;AACA,MAAMK,SAAS,GAAGL,OAAO,CAAC,2BAAD,CAAzB;;AACA,MAAMM,aAAa,GAAGN,OAAO,CAAC,gCAAD,CAA7B;;AACA,MAAMO,iBAAiB,GAAGP,OAAO,CAAC,sBAAD,CAAjC;;AACA,MAAMQ,UAAU,GAAGR,OAAO,CAAC,eAAD,CAA1B;;AACA,MAAMS,eAAe,GAAGT,OAAO,CAAC,UAAD,CAA/B;;AACA,MAAMU,OAAO,GAAGV,OAAO,CAAC,WAAD,CAAvB;;AACA,MAAMW,WAAW,GAAGX,OAAO,CAAC,qBAAD,CAA3B;;AACA,MAAMY,OAAO,GAAGZ,OAAO,CAAC,yBAAD,CAAvB;;AACA,MAAMa,SAAS,GAAGb,OAAO,CAAC,cAAD,CAAzB;;AACA,MAAMc,KAAK,GAAGd,OAAO,CAAC,SAAD,CAArB;;AACA,MAAMe,iBAAiB,GAAGf,OAAO,CAAC,sBAAD,CAAjC;;AACA,MAAMgB,EAAE,GAAGhB,OAAO,CAAC,aAAD,CAAlB;;AACA,MAAM;AAAEiB,EAAAA;AAAF,IAA0BjB,OAAO,CAAC,sBAAD,CAAvC,C,CAGA;AACA;AACA;;;AACA,MAAMkB,kBAAkB,GAAG,IAAIC,GAAJ,CAAQ,CAAC,OAAD,EAAU,YAAV,EAAwB,UAAxB,EAAoC,SAApC,EAA+C,OAA/C,EAAwD,OAAxD,EAAiE,QAAjE,EACjC,aADiC,EAClB,MADkB,EACV,KADU,EACH,SADG,EACQ,WADR,EACqB,QADrB,EAC+B,YAD/B,EAC6C,eAD7C,EAC8D,OAD9D,EAEjC,OAFiC,EAExB,OAFwB,EAEf,SAFe,EAEJ,UAFI,EAEQ,UAFR,EAEoB,SAFpB,EAE+B,WAF/B,EAE4C,MAF5C,EAEoD,OAFpD,EAE6D,OAF7D,EAGjC,MAHiC,CAAR,CAA3B,C,CAKA;;AACA,MAAMC,mBAAmB,GAAG,CAAC,SAAD,EAAY,YAAZ,EAA0B,oBAA1B,EAAgD,OAAhD,EAAyD,OAAzD,EAAkE,OAAlE,EAA2E,QAA3E,EAAqF,OAArF,EAA8F,OAA9F,EAAuG,QAAvG,CAA5B;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;IACMC,K;;;;AASJ;AACF;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;qBACkB;AACd,aAAO,KAAKC,WAAL,CAAiBC,SAAxB;AACD;AAED;AACF;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;qBA9B8B;AAC1B,aAAO,KAAKA,SAAL,CAAeC,iBAAf,EAAP;AACD;;;qBAE2B;AAC1B,aAAO,KAAKC,cAAL,CAAoBC,cAA3B;AACD;;;AAyBD,iBAAYC,MAAM,GAAG,EAArB,EAAyBC,OAAO,GAAG,EAAnC,EAAuC;AAAA;;AACrCA,IAAAA,OAAO,GAAGC,MAAM,CAACC,MAAP,CAAc;AACtBC,MAAAA,WAAW,EAAE,IADS;AAEtBC,MAAAA,OAAO,EAAE,KAAKV,WAAL,CAAiBU,OAFJ;AAGtBC,MAAAA,gBAAgB,EAAE,KAAKX,WAAL,CAAiBW;AAHb,KAAd,EAIPL,OAAO,IAAI,EAJJ,CAAV;;AAMA,QAAIA,OAAO,CAACM,UAAZ,EAAwB;AACtBN,MAAAA,OAAO,CAACM,UAAR,GAAqBN,OAAO,CAACM,UAAR,CAAmBC,GAAnB,CAAuBC,SAAS,IAAIC,KAAK,CAACC,OAAN,CAAcF,SAAd,IAA2BA,SAAS,CAAC,CAAD,CAApC,GAA0CA,SAA9E,CAArB;AACD;;AAED,QAAI,CAACR,OAAO,CAACW,gBAAb,EAA+B;AAC7B,WAAKjB,WAAL,CAAiBkB,gBAAjB,CAAkCZ,OAAlC,EAA2C,KAAKN,WAAhD;;AACA,UAAIM,OAAO,CAACa,OAAZ,EAAqB;AACnB,aAAKnB,WAAL,CAAiBoB,iBAAjB,CAAmCd,OAAnC;;AACA,aAAKN,WAAL,CAAiBqB,yBAAjB,CAA2Cf,OAA3C;AACD;AACF;;AAED,SAAKgB,UAAL,GAAkB,EAAlB;AACA,SAAKC,mBAAL,GAA2B,EAA3B;AACA,SAAKC,QAAL,GAAgB,EAAhB;AACA,SAAKC,aAAL,GAAqB,KAAKzB,WAAL,CAAiBM,OAAtC;AACA,SAAKoB,QAAL,GAAgBpB,OAAO,IAAI,EAA3B;AAEA;AACJ;AACA;AACA;AACA;;AACI,SAAKG,WAAL,GAAmBH,OAAO,CAACG,WAA3B;;AAEA,SAAKkB,WAAL,CAAiBtB,MAAjB,EAAyBC,OAAzB;AACD;;;;gCAEWD,M,EAAQC,O,EAAS;AAC3B,UAAIsB,QAAJ;AACA,UAAIC,GAAJ;AAEAxB,MAAAA,MAAM,GAAGA,MAAM,IAAI1B,CAAC,CAACmD,KAAF,CAAQzB,MAAR,CAAV,IAA6B,EAAtC;;AAEA,UAAIC,OAAO,CAACG,WAAZ,EAAyB;AACvBmB,QAAAA,QAAQ,GAAG,EAAX;;AAEA,YAAI,KAAK5B,WAAL,CAAiB+B,iBAArB,EAAwC;AACtCH,UAAAA,QAAQ,GAAGjD,CAAC,CAACqD,SAAF,CAAY,KAAKhC,WAAL,CAAiBiC,cAA7B,EAA6CC,OAAO,IAAI;AACjE,kBAAMC,KAAK,GAAGD,OAAO,EAArB;AACA,mBAAOC,KAAK,IAAIA,KAAK,YAAYtD,KAAK,CAACuD,eAAhC,GAAkDD,KAAlD,GAA0DxD,CAAC,CAAC0D,SAAF,CAAYF,KAAZ,CAAjE;AACD,WAHU,CAAX;AAID,SARsB,CAUvB;AACA;AACA;;;AACA,YAAI,KAAKnC,WAAL,CAAiBsC,oBAAjB,CAAsCC,MAA1C,EAAkD;AAChD,eAAKvC,WAAL,CAAiBsC,oBAAjB,CAAsCE,OAAtC,CAA8CC,mBAAmB,IAAI;AACnE,gBAAI,CAAClC,MAAM,CAACmC,SAAP,CAAiBC,cAAjB,CAAgCC,IAAhC,CAAqChB,QAArC,EAA+Ca,mBAA/C,CAAL,EAA0E;AACxEb,cAAAA,QAAQ,CAACa,mBAAD,CAAR,GAAgC,IAAhC;AACD;AACF,WAJD;AAKD;;AAED,YAAI,KAAKzC,WAAL,CAAiB6C,oBAAjB,CAAsCC,SAAtC,IAAmDlB,QAAQ,CAAC,KAAK5B,WAAL,CAAiB6C,oBAAjB,CAAsCC,SAAvC,CAA/D,EAAkH;AAChH,eAAKxB,UAAL,CAAgB,KAAKtB,WAAL,CAAiB6C,oBAAjB,CAAsCC,SAAtD,IAAmEjE,KAAK,CAACkE,cAAN,CAAqBnB,QAAQ,CAAC,KAAK5B,WAAL,CAAiB6C,oBAAjB,CAAsCC,SAAvC,CAA7B,EAAgF,KAAK7C,SAAL,CAAeK,OAAf,CAAuB0C,OAAvG,CAAnE;AACA,iBAAOpB,QAAQ,CAAC,KAAK5B,WAAL,CAAiB6C,oBAAjB,CAAsCC,SAAvC,CAAf;AACD;;AAED,YAAI,KAAK9C,WAAL,CAAiB6C,oBAAjB,CAAsCI,SAAtC,IAAmDrB,QAAQ,CAAC,KAAK5B,WAAL,CAAiB6C,oBAAjB,CAAsCI,SAAvC,CAA/D,EAAkH;AAChH,eAAK3B,UAAL,CAAgB,KAAKtB,WAAL,CAAiB6C,oBAAjB,CAAsCI,SAAtD,IAAmEpE,KAAK,CAACkE,cAAN,CAAqBnB,QAAQ,CAAC,KAAK5B,WAAL,CAAiB6C,oBAAjB,CAAsCI,SAAvC,CAA7B,EAAgF,KAAKhD,SAAL,CAAeK,OAAf,CAAuB0C,OAAvG,CAAnE;AACA,iBAAOpB,QAAQ,CAAC,KAAK5B,WAAL,CAAiB6C,oBAAjB,CAAsCI,SAAvC,CAAf;AACD;;AAED,YAAI,KAAKjD,WAAL,CAAiB6C,oBAAjB,CAAsCK,SAAtC,IAAmDtB,QAAQ,CAAC,KAAK5B,WAAL,CAAiB6C,oBAAjB,CAAsCK,SAAvC,CAA/D,EAAkH;AAChH,eAAK5B,UAAL,CAAgB,KAAKtB,WAAL,CAAiB6C,oBAAjB,CAAsCK,SAAtD,IAAmErE,KAAK,CAACkE,cAAN,CAAqBnB,QAAQ,CAAC,KAAK5B,WAAL,CAAiB6C,oBAAjB,CAAsCK,SAAvC,CAA7B,EAAgF,KAAKjD,SAAL,CAAeK,OAAf,CAAuB0C,OAAvG,CAAnE;AACA,iBAAOpB,QAAQ,CAAC,KAAK5B,WAAL,CAAiB6C,oBAAjB,CAAsCK,SAAvC,CAAf;AACD;;AAED,YAAI3C,MAAM,CAAC4C,IAAP,CAAYvB,QAAZ,EAAsBW,MAA1B,EAAkC;AAChC,eAAKV,GAAL,IAAYD,QAAZ,EAAsB;AACpB,gBAAIvB,MAAM,CAACwB,GAAD,CAAN,KAAgBuB,SAApB,EAA+B;AAC7B,mBAAKC,GAAL,CAASxB,GAAT,EAAchD,KAAK,CAACkE,cAAN,CAAqBnB,QAAQ,CAACC,GAAD,CAA7B,EAAoC,KAAK5B,SAAL,CAAeK,OAAf,CAAuB0C,OAA3D,CAAd,EAAmF;AAAEM,gBAAAA,GAAG,EAAE;AAAP,eAAnF;AACA,qBAAOjD,MAAM,CAACwB,GAAD,CAAb;AACD;AACF;AACF;AACF;;AAED,WAAKwB,GAAL,CAAShD,MAAT,EAAiBC,OAAjB;AACD,K,CAED;;;;;AAurGA;AACF;AACA;AACA;AACA;AACA;AACA;0BACQiD,Y,EAAc;AAClB,YAAMC,KAAK,GAAG,KAAKxD,WAAL,CAAiBsC,oBAAjB,CAAsCmB,MAAtC,CAA6C,CAACC,MAAD,EAAS5C,SAAT,KAAuB;AAChF4C,QAAAA,MAAM,CAAC5C,SAAD,CAAN,GAAoB,KAAK6C,GAAL,CAAS7C,SAAT,EAAoB;AAAEwC,UAAAA,GAAG,EAAE;AAAP,SAApB,CAApB;AACA,eAAOI,MAAP;AACD,OAHa,EAGX,EAHW,CAAd;;AAKA,UAAI/E,CAAC,CAACiF,IAAF,CAAOJ,KAAP,MAAkB,CAAtB,EAAyB;AACvB,eAAO,KAAK/B,aAAL,CAAmBoC,eAA1B;AACD;;AACD,YAAMC,WAAW,GAAG,KAAK9D,WAAL,CAAiB+D,iBAArC;;AACA,UAAIR,YAAY,IAAIO,WAApB,EAAiC;AAC/BN,QAAAA,KAAK,CAACM,WAAD,CAAL,GAAqB,KAAKH,GAAL,CAASG,WAAT,EAAsB;AAAER,UAAAA,GAAG,EAAE;AAAP,SAAtB,CAArB;AACD;;AACD,aAAOzE,KAAK,CAACmF,kBAAN,CAAyBR,KAAzB,EAAgC,KAAKxD,WAArC,CAAP;AACD;;;+BAEU;AACT,aAAQ,6BAA4B,KAAKA,WAAL,CAAiBiE,IAAK,GAA1D;AACD;AAED;AACF;AACA;AACA;AACA;AACA;AACA;;;;iCACepC,G,EAAK;AAChB,aAAO,KAAKP,UAAL,CAAgBO,GAAhB,CAAP;AACD;AAED;AACF;AACA;AACA;AACA;AACA;AACA;;;;iCACeA,G,EAAKM,K,EAAO;AACvB,YAAM+B,aAAa,GAAG,KAAK3C,mBAAL,CAAyBM,GAAzB,CAAtB;;AAEA,UAAI,CAAChD,KAAK,CAACsF,WAAN,CAAkBhC,KAAlB,CAAD,IAA6BA,KAAK,KAAK,IAAvC,IAA+CA,KAAK,KAAK+B,aAA7D,EAA4E;AAC1E,aAAKE,OAAL,CAAavC,GAAb,EAAkB,IAAlB;AACD;;AAED,WAAKP,UAAL,CAAgBO,GAAhB,IAAuBM,KAAvB;AACD;AAED;AACF;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;wBACMN,G,EAAKvB,O,EAAS;AAChB,UAAIA,OAAO,KAAK8C,SAAZ,IAAyB,OAAOvB,GAAP,KAAe,QAA5C,EAAsD;AACpDvB,QAAAA,OAAO,GAAGuB,GAAV;AACAA,QAAAA,GAAG,GAAGuB,SAAN;AACD;;AAED9C,MAAAA,OAAO,GAAGA,OAAO,IAAI,EAArB;;AAEA,UAAIuB,GAAJ,EAAS;AACP,YAAItB,MAAM,CAACmC,SAAP,CAAiBC,cAAjB,CAAgCC,IAAhC,CAAqC,KAAKyB,cAA1C,EAA0DxC,GAA1D,KAAkE,CAACvB,OAAO,CAACgD,GAA/E,EAAoF;AAClF,iBAAO,KAAKe,cAAL,CAAoBxC,GAApB,EAAyBe,IAAzB,CAA8B,IAA9B,EAAoCf,GAApC,EAAyCvB,OAAzC,CAAP;AACD;;AAED,YAAIA,OAAO,CAACgE,KAAR,IAAiB,KAAK5C,QAAL,CAAcP,OAA/B,IAA0C,KAAKO,QAAL,CAAc6C,YAAd,CAA2BC,QAA3B,CAAoC3C,GAApC,CAA9C,EAAwF;AACtF,cAAId,KAAK,CAACC,OAAN,CAAc,KAAKM,UAAL,CAAgBO,GAAhB,CAAd,CAAJ,EAAyC;AACvC,mBAAO,KAAKP,UAAL,CAAgBO,GAAhB,EAAqBhB,GAArB,CAAyB4D,QAAQ,IAAIA,QAAQ,CAACd,GAAT,CAAarD,OAAb,CAArC,CAAP;AACD;;AACD,cAAI,KAAKgB,UAAL,CAAgBO,GAAhB,aAAgC9B,KAApC,EAA2C;AACzC,mBAAO,KAAKuB,UAAL,CAAgBO,GAAhB,EAAqB8B,GAArB,CAAyBrD,OAAzB,CAAP;AACD;;AACD,iBAAO,KAAKgB,UAAL,CAAgBO,GAAhB,CAAP;AACD;;AAED,eAAO,KAAKP,UAAL,CAAgBO,GAAhB,CAAP;AACD;;AAED,UACE,KAAK6C,iBAAL,IACGpE,OAAO,CAACgE,KAAR,IAAiB,KAAK5C,QAAL,CAAcP,OADlC,IAEGb,OAAO,CAACwB,KAHb,EAIE;AACA,cAAMzB,MAAM,GAAG,EAAf;;AACA,YAAIsE,IAAJ;;AAEA,YAAI,KAAKD,iBAAT,EAA4B;AAC1B,eAAKC,IAAL,IAAa,KAAKN,cAAlB,EAAkC;AAChC,gBACE,KAAK3C,QAAL,CAAcd,UAAd,IACG,CAAC,KAAKc,QAAL,CAAcd,UAAd,CAAyB4D,QAAzB,CAAkCG,IAAlC,CAFN,EAGE;AACA;AACD;;AAED,gBAAIpE,MAAM,CAACmC,SAAP,CAAiBC,cAAjB,CAAgCC,IAAhC,CAAqC,KAAKyB,cAA1C,EAA0DM,IAA1D,CAAJ,EAAqE;AACnEtE,cAAAA,MAAM,CAACsE,IAAD,CAAN,GAAe,KAAKhB,GAAL,CAASgB,IAAT,EAAerE,OAAf,CAAf;AACD;AACF;AACF;;AAED,aAAKqE,IAAL,IAAa,KAAKrD,UAAlB,EAA8B;AAC5B,cACE,CAACf,MAAM,CAACmC,SAAP,CAAiBC,cAAjB,CAAgCC,IAAhC,CAAqCvC,MAArC,EAA6CsE,IAA7C,CAAD,IACGpE,MAAM,CAACmC,SAAP,CAAiBC,cAAjB,CAAgCC,IAAhC,CAAqC,KAAKtB,UAA1C,EAAsDqD,IAAtD,CAFL,EAGE;AACAtE,YAAAA,MAAM,CAACsE,IAAD,CAAN,GAAe,KAAKhB,GAAL,CAASgB,IAAT,EAAerE,OAAf,CAAf;AACD;AACF;;AAED,eAAOD,MAAP;AACD;;AAED,aAAO,KAAKiB,UAAZ;AACD;AAED;AACF;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;wBACMO,G,EAAKM,K,EAAO7B,O,EAAS;AACvB,UAAID,MAAJ;AACA,UAAI6D,aAAJ;;AAEA,UAAI,OAAOrC,GAAP,KAAe,QAAf,IAA2BA,GAAG,KAAK,IAAvC,EAA6C;AAC3CxB,QAAAA,MAAM,GAAGwB,GAAT;AACAvB,QAAAA,OAAO,GAAG6B,KAAK,IAAI,EAAnB;;AAEA,YAAI7B,OAAO,CAACsE,KAAZ,EAAmB;AACjB,eAAKtD,UAAL,GAAkB,EAAlB;;AACA,eAAK,MAAMO,GAAX,IAAkBxB,MAAlB,EAA0B;AACxB,iBAAK+D,OAAL,CAAavC,GAAb,EAAkB,KAAlB;AACD;AACF,SAT0C,CAW3C;;;AACA,YAAIvB,OAAO,CAACgD,GAAR,IAAe,EAAE,KAAK5B,QAAL,IAAiB,KAAKA,QAAL,CAAcP,OAAjC,CAAf,IAA4D,EAAEb,OAAO,IAAIA,OAAO,CAACM,UAArB,CAA5D,IAAgG,CAAC,KAAKZ,WAAL,CAAiB6E,kBAAlH,IAAwI,CAAC,KAAK7E,WAAL,CAAiB8E,qBAA9J,EAAqL;AACnL,cAAIvE,MAAM,CAAC4C,IAAP,CAAY,KAAK7B,UAAjB,EAA6BiB,MAAjC,EAAyC;AACvC,iBAAKjB,UAAL,GAAkBf,MAAM,CAACC,MAAP,CAAc,KAAKc,UAAnB,EAA+BjB,MAA/B,CAAlB;AACD,WAFD,MAEO;AACL,iBAAKiB,UAAL,GAAkBjB,MAAlB;AACD,WALkL,CAMnL;;;AACA,eAAKkB,mBAAL,GAA2B5C,CAAC,CAACmD,KAAF,CAAQ,KAAKR,UAAb,CAA3B;AACD,SARD,MAQO;AACL;AACA,cAAIhB,OAAO,CAACM,UAAZ,EAAwB;AACtB,kBAAMmE,OAAO,GAAGC,IAAI,IAAI;AACtB,mBAAK,MAAMC,CAAX,IAAgBD,IAAhB,EAAsB;AACpB,oBAAI3E,MAAM,CAAC4E,CAAD,CAAN,KAAc7B,SAAlB,EAA6B;AAC3B;AACD;;AACD,qBAAKC,GAAL,CAAS4B,CAAT,EAAY5E,MAAM,CAAC4E,CAAD,CAAlB,EAAuB3E,OAAvB;AACD;AACF,aAPD;;AAQAyE,YAAAA,OAAO,CAACzE,OAAO,CAACM,UAAT,CAAP;;AACA,gBAAI,KAAKZ,WAAL,CAAiBkF,qBAArB,EAA4C;AAC1CH,cAAAA,OAAO,CAAC,KAAK/E,WAAL,CAAiBmF,kBAAlB,CAAP;AACD;;AACD,gBAAI,KAAKzD,QAAL,CAAc6C,YAAlB,EAAgC;AAC9BQ,cAAAA,OAAO,CAAC,KAAKrD,QAAL,CAAc6C,YAAf,CAAP;AACD;AACF,WAhBD,MAgBO;AACL,iBAAK,MAAM1C,GAAX,IAAkBxB,MAAlB,EAA0B;AACxB,mBAAKgD,GAAL,CAASxB,GAAT,EAAcxB,MAAM,CAACwB,GAAD,CAApB,EAA2BvB,OAA3B;AACD;AACF;;AAED,cAAIA,OAAO,CAACgD,GAAZ,EAAiB;AACf;AACA,iBAAK/B,mBAAL,GAA2B5C,CAAC,CAACmD,KAAF,CAAQ,KAAKR,UAAb,CAA3B;AACD;AACF;;AACD,eAAO,IAAP;AACD;;AACD,UAAI,CAAChB,OAAL,EACEA,OAAO,GAAG,EAAV;;AACF,UAAI,CAACA,OAAO,CAACgD,GAAb,EAAkB;AAChBY,QAAAA,aAAa,GAAG,KAAK5C,UAAL,CAAgBO,GAAhB,CAAhB;AACD,OA3DsB,CA6DvB;;;AACA,UAAI,CAACvB,OAAO,CAACgD,GAAT,IAAgB,KAAK8B,cAAL,CAAoBvD,GAApB,CAApB,EAA8C;AAC5C,aAAKuD,cAAL,CAAoBvD,GAApB,EAAyBe,IAAzB,CAA8B,IAA9B,EAAoCT,KAApC,EAA2CN,GAA3C,EAD4C,CAE5C;AACA;;;AACA,cAAMwD,QAAQ,GAAG,KAAK/D,UAAL,CAAgBO,GAAhB,CAAjB;;AACA,YAAI,CAAChD,KAAK,CAACsF,WAAN,CAAkBkB,QAAlB,CAAD,IAAgCA,QAAQ,KAAK,IAA7C,IAAqDA,QAAQ,KAAKnB,aAAtE,EAAqF;AACnF,eAAK3C,mBAAL,CAAyBM,GAAzB,IAAgCqC,aAAhC;AACA,eAAKE,OAAL,CAAavC,GAAb,EAAkB,IAAlB;AACD;AACF,OATD,MASO;AACL;AACA,YAAI,KAAKH,QAAL,IAAiB,KAAKA,QAAL,CAAcP,OAA/B,IAA0C,KAAKO,QAAL,CAAc6C,YAAd,CAA2BC,QAA3B,CAAoC3C,GAApC,CAA9C,EAAwF;AACtF;AACA,eAAKyD,WAAL,CAAiBzD,GAAjB,EAAsBM,KAAtB,EAA6B7B,OAA7B;;AACA,iBAAO,IAAP;AACD,SANI,CAOL;;;AACA,YAAI,CAACA,OAAO,CAACgD,GAAb,EAAkB;AAChB;AACA,cAAI,CAAC,KAAKiC,YAAL,CAAkB1D,GAAlB,CAAL,EAA6B;AAC3B,gBAAIA,GAAG,CAAC2C,QAAJ,CAAa,GAAb,KAAqB,KAAKxE,WAAL,CAAiBwF,eAAjB,CAAiCC,GAAjC,CAAqC5D,GAAG,CAAC6D,KAAJ,CAAU,GAAV,EAAe,CAAf,CAArC,CAAzB,EAAkF;AAChF,oBAAMC,mBAAmB,GAAG/G,MAAM,CAAC+E,GAAP,CAAW,KAAKrC,UAAhB,EAA4BO,GAA5B,CAA5B;;AACA,kBAAI,CAAClD,CAAC,CAACiH,OAAF,CAAUD,mBAAV,EAA+BxD,KAA/B,CAAL,EAA4C;AAC1CvD,gBAAAA,MAAM,CAACyE,GAAP,CAAW,KAAK/B,UAAhB,EAA4BO,GAA5B,EAAiCM,KAAjC;AACA,qBAAKiC,OAAL,CAAavC,GAAG,CAAC6D,KAAJ,CAAU,GAAV,EAAe,CAAf,CAAb,EAAgC,IAAhC;AACD;AACF;;AACD,mBAAO,IAAP;AACD,WAXe,CAahB;;;AACA,cAAI,KAAK1F,WAAL,CAAiB6F,eAAjB,IAAoC3B,aAApC,IAAqD,KAAKlE,WAAL,CAAiB8F,aAAjB,CAA+BjE,GAA/B,CAAzD,EAA8F;AAC5F,mBAAO,IAAP;AACD,WAhBe,CAkBhB;;;AACA,cAAI,CAAC,KAAKpB,WAAN,IAAqB,KAAKT,WAAL,CAAiB+F,sBAAtC,IAAgE,KAAK/F,WAAL,CAAiBgG,mBAAjB,CAAqCP,GAArC,CAAyC5D,GAAzC,CAApE,EAAmH;AACjH,mBAAO,IAAP;AACD;AACF,SA9BI,CAgCL;;;AACA,YACE,EAAEM,KAAK,YAAYtD,KAAK,CAACuD,eAAzB,KACG7B,MAAM,CAACmC,SAAP,CAAiBC,cAAjB,CAAgCC,IAAhC,CAAqC,KAAK5C,WAAL,CAAiBiG,mBAAtD,EAA2EpE,GAA3E,CAFL,EAGE;AACAM,UAAAA,KAAK,GAAG,KAAKnC,WAAL,CAAiBiG,mBAAjB,CAAqCpE,GAArC,EAA0Ce,IAA1C,CAA+C,IAA/C,EAAqDT,KAArD,EAA4D7B,OAA5D,CAAR;AACD,SAtCI,CAwCL;;;AACA,YACE,CAACA,OAAO,CAACgD,GAAT,MAEE;AACAnB,QAAAA,KAAK,YAAYtD,KAAK,CAACuD,eAAvB,IACA;AACA,UAAED,KAAK,YAAYtD,KAAK,CAACuD,eAAzB,KAA6C,KAAKpC,WAAL,CAAiBkG,gBAAjB,CAAkCrE,GAAlC,CAA7C,IAAuF,KAAK7B,WAAL,CAAiBkG,gBAAjB,CAAkCrE,GAAlC,EAAuCe,IAAvC,CAA4C,IAA5C,EAAkDT,KAAlD,EAAyD+B,aAAzD,EAAwE5D,OAAxE,CAFvF,IAGA;AACA,SAAC,KAAKN,WAAL,CAAiBkG,gBAAjB,CAAkCrE,GAAlC,CAAD,KAA4C,CAAChD,KAAK,CAACsF,WAAN,CAAkBhC,KAAlB,CAAD,IAA6BA,KAAK,KAAK,IAAvC,IAA+CA,KAAK,KAAK+B,aAArG,CAPF,CADF,EAUE;AACA,eAAK3C,mBAAL,CAAyBM,GAAzB,IAAgCqC,aAAhC;AACA,eAAKE,OAAL,CAAavC,GAAb,EAAkB,IAAlB;AACD,SAtDI,CAwDL;;;AACA,aAAKP,UAAL,CAAgBO,GAAhB,IAAuBM,KAAvB;AACD;;AACD,aAAO,IAAP;AACD;;;kCAEagE,O,EAAS;AACrB,aAAO,KAAK9C,GAAL,CAAS8C,OAAT,CAAP;AACD;AAED;AACF;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;4BACUtE,G,EAAKM,K,EAAO;AAClB,UAAIN,GAAJ,EAAS;AACP,YAAIM,KAAK,KAAKiB,SAAd,EAAyB;AACvB,eAAK5B,QAAL,CAAcK,GAAd,IAAqBM,KAArB;AACA,iBAAO,IAAP;AACD;;AACD,eAAO,KAAKX,QAAL,CAAcK,GAAd,KAAsB,KAA7B;AACD;;AAED,YAAMuC,OAAO,GAAG7D,MAAM,CAAC4C,IAAP,CAAY,KAAK7B,UAAjB,EAA6B8E,MAA7B,CAAoCvE,GAAG,IAAI,KAAKuC,OAAL,CAAavC,GAAb,CAA3C,CAAhB;AAEA,aAAOuC,OAAO,CAAC7B,MAAR,GAAiB6B,OAAjB,GAA2B,KAAlC;AACD;AAED;AACF;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;6BACWvC,G,EAAK;AACZ,UAAIA,GAAJ,EAAS;AACP,eAAO,KAAKN,mBAAL,CAAyBM,GAAzB,CAAP;AACD;;AAED,aAAOlD,CAAC,CAAC0H,MAAF,CAAS,KAAK9E,mBAAd,EAAmC,CAACY,KAAD,EAAQN,GAAR,KAAgB,KAAKuC,OAAL,CAAavC,GAAb,CAAnD,CAAP;AACD;;;gCAEWA,G,EAAKM,K,EAAO7B,O,EAAS;AAC/B,UAAI,CAACS,KAAK,CAACC,OAAN,CAAcmB,KAAd,CAAL,EAA2BA,KAAK,GAAG,CAACA,KAAD,CAAR;;AAC3B,UAAIA,KAAK,CAAC,CAAD,CAAL,YAAoBpC,KAAxB,EAA+B;AAC7BoC,QAAAA,KAAK,GAAGA,KAAK,CAACtB,GAAN,CAAU4D,QAAQ,IAAIA,QAAQ,CAACnD,UAA/B,CAAR;AACD;;AAED,YAAMH,OAAO,GAAG,KAAKO,QAAL,CAAc4E,UAAd,CAAyBzE,GAAzB,CAAhB;AACA,YAAM0E,WAAW,GAAGpF,OAAO,CAACoF,WAA5B;AACA,YAAMC,QAAQ,GAAG3E,GAAjB;AACA,YAAMY,mBAAmB,GAAGtB,OAAO,CAACsF,KAAR,CAAchE,mBAA1C;AACA,YAAMiE,YAAY,GAAG;AACnBjG,QAAAA,WAAW,EAAE,KAAKA,WADC;AAEnBU,QAAAA,OAAO,EAAEA,OAAO,CAACA,OAFE;AAGnBoD,QAAAA,YAAY,EAAEpD,OAAO,CAACoD,YAHH;AAInB+B,QAAAA,UAAU,EAAEnF,OAAO,CAACmF,UAJD;AAKnBrF,QAAAA,gBAAgB,EAAE,IALC;AAMnBqC,QAAAA,GAAG,EAAEhD,OAAO,CAACgD,GANM;AAOnB1C,QAAAA,UAAU,EAAEO,OAAO,CAACwF;AAPD,OAArB;AASA,UAAIC,OAAJ;;AAEA,UAAIzF,OAAO,CAACwF,kBAAR,KAA+BvD,SAA/B,IAA4CjC,OAAO,CAACwF,kBAAR,CAA2BpE,MAA3E,EAAmF;AACjF,YAAIgE,WAAW,CAACM,mBAAhB,EAAqC;AACnC,cAAI9F,KAAK,CAACC,OAAN,CAAcmB,KAAd,CAAJ,EAA0B;AACxBA,YAAAA,KAAK,GAAGA,KAAK,CAAC,CAAD,CAAb;AACD;;AACDyE,UAAAA,OAAO,GAAGzE,KAAK,IAAIA,KAAK,CAACM,mBAAD,CAAL,KAA+B,IAAxC,IAAgDN,KAAK,KAAK,IAApE;AACA,eAAKqE,QAAL,IAAiB,KAAKlF,UAAL,CAAgBkF,QAAhB,IAA4BI,OAAO,GAAG,IAAH,GAAUzF,OAAO,CAACsF,KAAR,CAAcK,KAAd,CAAoB3E,KAApB,EAA2BuE,YAA3B,CAA9D;AACD,SAND,MAMO;AACLE,UAAAA,OAAO,GAAGzE,KAAK,CAAC,CAAD,CAAL,IAAYA,KAAK,CAAC,CAAD,CAAL,CAASM,mBAAT,MAAkC,IAAxD;AACA,eAAK+D,QAAL,IAAiB,KAAKlF,UAAL,CAAgBkF,QAAhB,IAA4BI,OAAO,GAAG,EAAH,GAAQzF,OAAO,CAACsF,KAAR,CAAcM,SAAd,CAAwB5E,KAAxB,EAA+BuE,YAA/B,CAA5D;AACD;AACF;AACF;AAED;AACF;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;yBACOpG,O,EAAS;AACZ,UAAI0G,SAAS,CAACzE,MAAV,GAAmB,CAAvB,EAA0B;AACxB,cAAM,IAAI0E,KAAJ,CAAU,iEAAV,CAAN;AACD;;AAED3G,MAAAA,OAAO,GAAGzB,KAAK,CAACwD,SAAN,CAAgB/B,OAAhB,CAAV;AACAA,MAAAA,OAAO,GAAG3B,CAAC,CAACiD,QAAF,CAAWtB,OAAX,EAAoB;AAC5B4G,QAAAA,KAAK,EAAE,IADqB;AAE5BC,QAAAA,QAAQ,EAAE;AAFkB,OAApB,CAAV;;AAKA,UAAI,CAAC7G,OAAO,CAAC8G,MAAb,EAAqB;AACnB,YAAI,KAAK3G,WAAT,EAAsB;AACpBH,UAAAA,OAAO,CAAC8G,MAAR,GAAiB7G,MAAM,CAAC4C,IAAP,CAAY,KAAKnD,WAAL,CAAiBqH,aAA7B,CAAjB;AACD,SAFD,MAEO;AACL/G,UAAAA,OAAO,CAAC8G,MAAR,GAAiBzI,CAAC,CAAC2I,YAAF,CAAe,KAAKlD,OAAL,EAAf,EAA+B7D,MAAM,CAAC4C,IAAP,CAAY,KAAKnD,WAAL,CAAiBqH,aAA7B,CAA/B,CAAjB;AACD;;AAED/G,QAAAA,OAAO,CAACiH,aAAR,GAAwBjH,OAAO,CAAC8G,MAAhC;AACD;;AAED,UAAI9G,OAAO,CAACkH,SAAR,KAAsBpE,SAA1B,EAAqC;AACnC,YAAI9C,OAAO,CAACiG,WAAZ,EAAyB;AACvBjG,UAAAA,OAAO,CAACkH,SAAR,GAAoB,KAApB;AACD,SAFD,MAEO,IAAI,KAAK/G,WAAT,EAAsB;AAC3BH,UAAAA,OAAO,CAACkH,SAAR,GAAoB,IAApB;AACD;AACF;;AAED,YAAMC,cAAc,GAAG,KAAKzH,WAAL,CAAiByC,mBAAxC;AACA,YAAMA,mBAAmB,GAAGgF,cAAc,IAAI,KAAKzH,WAAL,CAAiBqH,aAAjB,CAA+BI,cAA/B,CAA9C;AACA,YAAMC,aAAa,GAAG,KAAK1H,WAAL,CAAiB6C,oBAAjB,CAAsCC,SAA5D;AACA,YAAMgB,WAAW,GAAG,KAAK9D,WAAL,CAAiB+D,iBAArC;AACA,YAAM4D,IAAI,GAAG,KAAKlH,WAAL,GAAmB,QAAnB,GAA8B,QAA3C;AACA,YAAMmH,YAAY,GAAG,KAAKnH,WAA1B;AACA,YAAMoH,GAAG,GAAGhJ,KAAK,CAACgJ,GAAN,CAAU,KAAK5H,SAAL,CAAeK,OAAf,CAAuB0C,OAAjC,CAAZ;AACA,UAAI8E,aAAa,GAAG,KAAK9H,WAAL,CAAiB6C,oBAAjB,CAAsCI,SAA1D;;AAEA,UAAI6E,aAAa,IAAIxH,OAAO,CAAC8G,MAAR,CAAe7E,MAAf,IAAyB,CAA1C,IAA+C,CAACjC,OAAO,CAAC8G,MAAR,CAAe5C,QAAf,CAAwBsD,aAAxB,CAApD,EAA4F;AAC1FxH,QAAAA,OAAO,CAAC8G,MAAR,CAAeW,IAAf,CAAoBD,aAApB;AACD;;AACD,UAAIhE,WAAW,IAAIxD,OAAO,CAAC8G,MAAR,CAAe7E,MAAf,IAAyB,CAAxC,IAA6C,CAACjC,OAAO,CAAC8G,MAAR,CAAe5C,QAAf,CAAwBV,WAAxB,CAAlD,EAAwF;AACtFxD,QAAAA,OAAO,CAAC8G,MAAR,CAAeW,IAAf,CAAoBjE,WAApB;AACD;;AAED,UAAIxD,OAAO,CAAC0H,MAAR,KAAmB,IAAnB,IAA2B,EAAE,KAAKvH,WAAL,IAAoB,KAAKkD,GAAL,CAASmE,aAAT,EAAwB;AAAExE,QAAAA,GAAG,EAAE;AAAP,OAAxB,CAAtB,CAA/B,EAA8F;AAC5F;AACA3E,QAAAA,CAAC,CAACsJ,MAAF,CAAS3H,OAAO,CAAC8G,MAAjB,EAAyBc,GAAG,IAAIA,GAAG,KAAKJ,aAAxC;;AACAA,QAAAA,aAAa,GAAG,KAAhB;AACD;;AAED,UAAI,KAAKrH,WAAL,KAAqB,IAAzB,EAA+B;AAC7B,YAAIiH,aAAa,IAAI,CAACpH,OAAO,CAAC8G,MAAR,CAAe5C,QAAf,CAAwBkD,aAAxB,CAAtB,EAA8D;AAC5DpH,UAAAA,OAAO,CAAC8G,MAAR,CAAeW,IAAf,CAAoBL,aAApB;AACD;;AAED,YAAIjF,mBAAmB,IAAIA,mBAAmB,CAAC0F,YAA3C,IAA2D,CAAC7H,OAAO,CAAC8G,MAAR,CAAe5C,QAAf,CAAwBiD,cAAxB,CAAhE,EAAyG;AACvGnH,UAAAA,OAAO,CAAC8G,MAAR,CAAegB,OAAf,CAAuBX,cAAvB;AACD;AACF;;AAED,UAAI,KAAKhH,WAAL,KAAqB,KAAzB,EAAgC;AAC9B,YAAIgH,cAAc,IAAI,KAAK9D,GAAL,CAAS8D,cAAT,EAAyB;AAAEnE,UAAAA,GAAG,EAAE;AAAP,SAAzB,MAA4CF,SAAlE,EAA6E;AAC3E,gBAAM,IAAI6D,KAAJ,CAAU,qHAAV,CAAN;AACD;AACF;;AAED,UAAIa,aAAa,IAAI,CAACxH,OAAO,CAAC0H,MAA1B,IAAoC1H,OAAO,CAAC8G,MAAR,CAAe5C,QAAf,CAAwBsD,aAAxB,CAAxC,EAAgF;AAC9E,aAAKxG,UAAL,CAAgBwG,aAAhB,IAAiC,KAAK9H,WAAL,CAAiBqI,oBAAjB,CAAsCP,aAAtC,KAAwDD,GAAzF;AACD;;AAED,UAAI,KAAKpH,WAAL,IAAoBiH,aAApB,IAAqC,CAAC,KAAKpG,UAAL,CAAgBoG,aAAhB,CAA1C,EAA0E;AACxE,aAAKpG,UAAL,CAAgBoG,aAAhB,IAAiC,KAAK1H,WAAL,CAAiBqI,oBAAjB,CAAsCX,aAAtC,KAAwDG,GAAzF;AACD;;AAED,aAAOzI,OAAO,CAACkJ,GAAR,CAAY,MAAM;AACvB;AACA,YAAIhI,OAAO,CAAC6G,QAAZ,EAAsB;AACpB,iBAAO,KAAKA,QAAL,CAAc7G,OAAd,CAAP;AACD;AACF,OALM,EAKJiI,IALI,CAKC,MAAM;AACZ;AACA,YAAIjI,OAAO,CAAC4G,KAAZ,EAAmB;AACjB,gBAAMsB,gBAAgB,GAAG7J,CAAC,CAAC8J,IAAF,CAAO,KAAKnH,UAAZ,EAAwBhB,OAAO,CAAC8G,MAAhC,CAAzB;;AACA,cAAIsB,aAAa,GAAG/J,CAAC,CAACgK,UAAF,CAAa,KAAKvE,OAAL,EAAb,EAA6B9D,OAAO,CAAC8G,MAArC,CAApB,CAFiB,CAEiD;;;AAClE,cAAIwB,WAAJ;AACA,cAAIC,eAAJ;;AAEA,cAAIf,aAAa,IAAIxH,OAAO,CAAC8G,MAAR,CAAe5C,QAAf,CAAwBsD,aAAxB,CAArB,EAA6D;AAC3DY,YAAAA,aAAa,GAAG/J,CAAC,CAACmK,OAAF,CAAUJ,aAAV,EAAyBZ,aAAzB,CAAhB;AACD;;AAED,iBAAO,KAAK9H,WAAL,CAAiB+I,QAAjB,CAA2B,SAAQpB,IAAK,EAAxC,EAA2C,IAA3C,EAAiDrH,OAAjD,EACJiI,IADI,CACC,MAAM;AACV,gBAAIjI,OAAO,CAACiH,aAAR,IAAyB,CAAC,KAAK9G,WAAnC,EAAgD;AAC9CoI,cAAAA,eAAe,GAAGlK,CAAC,CAAC8J,IAAF,CAAO,KAAKnH,UAAZ,EAAwB3C,CAAC,CAACgK,UAAF,CAAa,KAAKvE,OAAL,EAAb,EAA6BsE,aAA7B,CAAxB,CAAlB;AAEAE,cAAAA,WAAW,GAAG,EAAd;;AACA,mBAAK,MAAM/G,GAAX,IAAkBtB,MAAM,CAAC4C,IAAP,CAAY0F,eAAZ,CAAlB,EAAgD;AAC9C,oBAAIA,eAAe,CAAChH,GAAD,CAAf,KAAyB2G,gBAAgB,CAAC3G,GAAD,CAA7C,EAAoD;AAClD+G,kBAAAA,WAAW,CAACb,IAAZ,CAAiBlG,GAAjB;AACD;AACF;;AAEDvB,cAAAA,OAAO,CAAC8G,MAAR,GAAiBzI,CAAC,CAACqK,IAAF,CAAO1I,OAAO,CAAC8G,MAAR,CAAe6B,MAAf,CAAsBL,WAAtB,CAAP,CAAjB;AACD;;AAED,gBAAIA,WAAJ,EAAiB;AACf,kBAAItI,OAAO,CAAC6G,QAAZ,EAAsB;AACtB;AAEE7G,gBAAAA,OAAO,CAAC4I,IAAR,GAAevK,CAAC,CAACgK,UAAF,CAAapI,MAAM,CAAC4C,IAAP,CAAY,KAAKnD,WAAL,CAAiBqH,aAA7B,CAAb,EAA0DuB,WAA1D,CAAf;AACA,uBAAO,KAAKzB,QAAL,CAAc7G,OAAd,EAAuBiI,IAAvB,CAA4B,MAAM;AACvC,yBAAOjI,OAAO,CAAC4I,IAAf;AACD,iBAFM,CAAP;AAGD;AACF;AACF,WAzBI,CAAP;AA0BD;AACF,OA5CM,EA4CJX,IA5CI,CA4CC,MAAM;AACZ,YAAI,CAACjI,OAAO,CAAC8G,MAAR,CAAe7E,MAApB,EAA4B,OAAO,IAAP;AAC5B,YAAI,CAAC,KAAK9B,WAAV,EAAuB,OAAO,IAAP;AACvB,YAAI,CAAC,KAAKiB,QAAL,CAAcP,OAAf,IAA0B,CAAC,KAAKO,QAAL,CAAcP,OAAd,CAAsBoB,MAArD,EAA6D,OAAO,IAAP,CAHjD,CAKZ;;AACA,eAAOnD,OAAO,CAACyB,GAAR,CAAY,KAAKa,QAAL,CAAcP,OAAd,CAAsBiF,MAAtB,CAA6BjF,OAAO,IAAIA,OAAO,CAACoF,WAAR,YAA+BxH,SAAvE,CAAZ,EAA+FoC,OAAO,IAAI;AAC/G,gBAAMsD,QAAQ,GAAG,KAAKd,GAAL,CAASxC,OAAO,CAACgI,EAAjB,CAAjB;AACA,cAAI,CAAC1E,QAAL,EAAe,OAAOrF,OAAO,CAACgK,OAAR,EAAP;;AAEf,gBAAMC,cAAc,GAAG1K,CAAC,CAACE,KAAK,CAACwD,SAAN,CAAgBlB,OAAhB,CAAD,CAAD,CACpBmI,IADoB,CACf,CAAC,aAAD,CADe,EAEpB1H,QAFoB,CAEX;AACR2H,YAAAA,WAAW,EAAEjJ,OAAO,CAACiJ,WADb;AAERC,YAAAA,OAAO,EAAElJ,OAAO,CAACkJ,OAFT;AAGRC,YAAAA,YAAY,EAAE;AAHN,WAFW,EAMlBtH,KANkB,EAAvB;;AAQA,iBAAOsC,QAAQ,CAACiF,IAAT,CAAcL,cAAd,EAA8Bd,IAA9B,CAAmC,MAAM,KAAKpH,OAAO,CAACoF,WAAR,CAAoBoD,SAApB,CAA8BtG,GAAnC,EAAwCoB,QAAxC,EAAkD;AAAEiF,YAAAA,IAAI,EAAE,KAAR;AAAeF,YAAAA,OAAO,EAAElJ,OAAO,CAACkJ;AAAhC,WAAlD,CAAzC,CAAP;AACD,SAbM,CAAP;AAcD,OAhEM,EAgEJjB,IAhEI,CAgEC,MAAM;AACZ,cAAMqB,UAAU,GAAGtJ,OAAO,CAAC8G,MAAR,CAAehB,MAAf,CAAsByD,KAAK,IAAI,CAAC,KAAK7J,WAAL,CAAiBmF,kBAAjB,CAAoCM,GAApC,CAAwCoE,KAAxC,CAAhC,CAAnB;AACA,YAAI,CAACD,UAAU,CAACrH,MAAhB,EAAwB,OAAO,IAAP;AACxB,YAAI,CAAC,KAAK6B,OAAL,EAAD,IAAmB,CAAC,KAAK3D,WAA7B,EAA0C,OAAO,IAAP;AAE1C,cAAMqJ,gBAAgB,GAAGnL,CAAC,CAACgF,GAAF,CAAM,KAAK3D,WAAL,CAAiBqH,aAAjB,CAA+BvD,WAA/B,CAAN,EAAmD,OAAnD,KAA+DA,WAAxF;AACA,YAAIzD,MAAM,GAAGxB,KAAK,CAACkL,kBAAN,CAAyB,KAAKzI,UAA9B,EAA0ChB,OAAO,CAAC8G,MAAlD,EAA0D,KAAKpH,WAA/D,CAAb;AACA,YAAIgK,KAAK,GAAG,IAAZ;AACA,YAAIC,IAAI,GAAG,EAAX;AACA,YAAIzG,KAAJ;;AAEA,YAAI,KAAK/C,WAAT,EAAsB;AACpBuJ,UAAAA,KAAK,GAAG,QAAR;AACAC,UAAAA,IAAI,GAAG,CAAC,IAAD,EAAO,KAAKjK,WAAL,CAAiBkK,YAAjB,CAA8B5J,OAA9B,CAAP,EAA+CD,MAA/C,EAAuDC,OAAvD,CAAP;AACD,SAHD,MAGO;AACLkD,UAAAA,KAAK,GAAG,KAAKA,KAAL,CAAW,IAAX,CAAR;;AACA,cAAIM,WAAJ,EAAiB;AACfzD,YAAAA,MAAM,CAACyJ,gBAAD,CAAN,GAA2BK,QAAQ,CAAC9J,MAAM,CAACyJ,gBAAD,CAAP,EAA2B,EAA3B,CAAR,GAAyC,CAApE;AACD;;AACDE,UAAAA,KAAK,GAAG,QAAR;AACAC,UAAAA,IAAI,GAAG,CAAC,IAAD,EAAO,KAAKjK,WAAL,CAAiBkK,YAAjB,CAA8B5J,OAA9B,CAAP,EAA+CD,MAA/C,EAAuDmD,KAAvD,EAA8DlD,OAA9D,CAAP;AACD;;AAED,eAAO,KAAKN,WAAL,CAAiBG,cAAjB,CAAgC6J,KAAhC,EAAuC,GAAGC,IAA1C,EACJ1B,IADI,CACC,CAAC,CAAC7E,MAAD,EAAS0G,WAAT,CAAD,KAA0B;AAC9B,cAAItG,WAAJ,EAAiB;AACf;AACA,gBAAIsG,WAAW,GAAG,CAAlB,EAAqB;AACnB,oBAAM,IAAIjL,eAAe,CAACkL,mBAApB,CAAwC;AAC5CC,gBAAAA,SAAS,EAAE,KAAKtK,WAAL,CAAiBiE,IADgB;AAE5C5D,gBAAAA,MAF4C;AAG5CmD,gBAAAA;AAH4C,eAAxC,CAAN;AAKD,aAND,MAMO;AACLE,cAAAA,MAAM,CAACpC,UAAP,CAAkBwC,WAAlB,IAAiCzD,MAAM,CAACyJ,gBAAD,CAAvC;AACD;AACF,WAZ6B,CAc9B;;;AACA,eAAK,MAAMS,IAAX,IAAmBhK,MAAM,CAAC4C,IAAP,CAAY,KAAKnD,WAAL,CAAiBqH,aAA7B,CAAnB,EAAgE;AAC9D,gBAAI,KAAKrH,WAAL,CAAiBqH,aAAjB,CAA+BkD,IAA/B,EAAqCV,KAArC,IACAxJ,MAAM,CAAC,KAAKL,WAAL,CAAiBqH,aAAjB,CAA+BkD,IAA/B,EAAqCV,KAAtC,CAAN,KAAuDzG,SADvD,IAEA,KAAKpD,WAAL,CAAiBqH,aAAjB,CAA+BkD,IAA/B,EAAqCV,KAArC,KAA+CU,IAFnD,EAGE;AACAlK,cAAAA,MAAM,CAACkK,IAAD,CAAN,GAAelK,MAAM,CAAC,KAAKL,WAAL,CAAiBqH,aAAjB,CAA+BkD,IAA/B,EAAqCV,KAAtC,CAArB;AACA,qBAAOxJ,MAAM,CAAC,KAAKL,WAAL,CAAiBqH,aAAjB,CAA+BkD,IAA/B,EAAqCV,KAAtC,CAAb;AACD;AACF;;AACDxJ,UAAAA,MAAM,GAAGE,MAAM,CAACC,MAAP,CAAcH,MAAd,EAAsBqD,MAAM,CAACpC,UAA7B,CAAT;AAEAoC,UAAAA,MAAM,CAACpC,UAAP,GAAoBf,MAAM,CAACC,MAAP,CAAckD,MAAM,CAACpC,UAArB,EAAiCjB,MAAjC,CAApB;AACA,iBAAOqD,MAAP;AACD,SA7BI,EA8BJ8G,GA9BI,CA8BA,MAAM;AACT,cAAI,CAAC5C,YAAL,EAAmB,OAAO,IAAP;AACnB,cAAI,CAAC,KAAKlG,QAAL,CAAcP,OAAf,IAA0B,CAAC,KAAKO,QAAL,CAAcP,OAAd,CAAsBoB,MAArD,EAA6D,OAAO,IAAP,CAFpD,CAIT;;AACA,iBAAOnD,OAAO,CAACyB,GAAR,CAAY,KAAKa,QAAL,CAAcP,OAAd,CAAsBiF,MAAtB,CAA6BjF,OAAO,IAAI,EAAEA,OAAO,CAACoF,WAAR,YAA+BxH,SAA/B,IAC3DoC,OAAO,CAACsJ,MAAR,IAAkBtJ,OAAO,CAACsJ,MAAR,CAAelE,WAAf,YAAsCvH,aADC,CAAxC,CAAZ,EACoEmC,OAAO,IAAI;AACpF,gBAAIuJ,SAAS,GAAG,KAAK/G,GAAL,CAASxC,OAAO,CAACgI,EAAjB,CAAhB;AAEA,gBAAI,CAACuB,SAAL,EAAgB,OAAOtL,OAAO,CAACgK,OAAR,EAAP;AAChB,gBAAI,CAACrI,KAAK,CAACC,OAAN,CAAc0J,SAAd,CAAL,EAA+BA,SAAS,GAAG,CAACA,SAAD,CAAZ;AAC/B,gBAAI,CAACA,SAAS,CAACnI,MAAf,EAAuB,OAAOnD,OAAO,CAACgK,OAAR,EAAP;;AAEvB,kBAAMC,cAAc,GAAG1K,CAAC,CAACE,KAAK,CAACwD,SAAN,CAAgBlB,OAAhB,CAAD,CAAD,CACpBmI,IADoB,CACf,CAAC,aAAD,CADe,EAEpB1H,QAFoB,CAEX;AACR2H,cAAAA,WAAW,EAAEjJ,OAAO,CAACiJ,WADb;AAERC,cAAAA,OAAO,EAAElJ,OAAO,CAACkJ,OAFT;AAGRC,cAAAA,YAAY,EAAE;AAHN,aAFW,EAMlBtH,KANkB,EAAvB,CAPoF,CAepF;;;AACA,mBAAO/C,OAAO,CAACyB,GAAR,CAAY6J,SAAZ,EAAuBjG,QAAQ,IAAI;AACxC,kBAAItD,OAAO,CAACoF,WAAR,YAA+BvH,aAAnC,EAAkD;AAChD,uBAAOyF,QAAQ,CAACiF,IAAT,CAAcL,cAAd,EAA8Bd,IAA9B,CAAmC,MAAM;AAC9C,wBAAMlI,MAAM,GAAG,EAAf;AACAA,kBAAAA,MAAM,CAACc,OAAO,CAACoF,WAAR,CAAoBoE,UAArB,CAAN,GAAyC,KAAKhH,GAAL,CAAS,KAAK3D,WAAL,CAAiByC,mBAA1B,EAA+C;AAAEa,oBAAAA,GAAG,EAAE;AAAP,mBAA/C,CAAzC;AACAjD,kBAAAA,MAAM,CAACc,OAAO,CAACoF,WAAR,CAAoBqE,QAArB,CAAN,GAAuCnG,QAAQ,CAACd,GAAT,CAAac,QAAQ,CAACzE,WAAT,CAAqByC,mBAAlC,EAAuD;AAAEa,oBAAAA,GAAG,EAAE;AAAP,mBAAvD,CAAvC,CAH8C,CAK9C;;AACA/C,kBAAAA,MAAM,CAACC,MAAP,CAAcH,MAAd,EAAsBc,OAAO,CAACoF,WAAR,CAAoBsE,OAApB,CAA4BC,KAAlD;;AACA,sBAAIrG,QAAQ,CAACtD,OAAO,CAACoF,WAAR,CAAoBsE,OAApB,CAA4BpE,KAA5B,CAAkCxC,IAAnC,CAAZ,EAAsD;AACpD,yBAAK,MAAMsG,IAAX,IAAmBhK,MAAM,CAAC4C,IAAP,CAAYhC,OAAO,CAACoF,WAAR,CAAoBsE,OAApB,CAA4BpE,KAA5B,CAAkCY,aAA9C,CAAnB,EAAiF;AAC/E,0BAAIlG,OAAO,CAACoF,WAAR,CAAoBsE,OAApB,CAA4BpE,KAA5B,CAAkCY,aAAlC,CAAgDkD,IAAhD,EAAsDQ,cAAtD,IACFR,IAAI,KAAKpJ,OAAO,CAACoF,WAAR,CAAoBoE,UAD3B,IAEFJ,IAAI,KAAKpJ,OAAO,CAACoF,WAAR,CAAoBqE,QAF3B,IAGF,OAAOnG,QAAQ,CAACtD,OAAO,CAACoF,WAAR,CAAoBsE,OAApB,CAA4BpE,KAA5B,CAAkCxC,IAAnC,CAAR,CAAiDsG,IAAjD,CAAP,KAAkEnH,SAHpE,EAG+E;AAC7E;AACD;;AACD/C,sBAAAA,MAAM,CAACkK,IAAD,CAAN,GAAe9F,QAAQ,CAACtD,OAAO,CAACoF,WAAR,CAAoBsE,OAApB,CAA4BpE,KAA5B,CAAkCxC,IAAnC,CAAR,CAAiDsG,IAAjD,CAAf;AACD;AACF;;AAED,yBAAOpJ,OAAO,CAACoF,WAAR,CAAoByE,YAApB,CAAiCC,MAAjC,CAAwC5K,MAAxC,EAAgDgJ,cAAhD,CAAP;AACD,iBApBM,CAAP;AAqBD;;AACD5E,cAAAA,QAAQ,CAACpB,GAAT,CAAalC,OAAO,CAACoF,WAAR,CAAoBoE,UAAjC,EAA6C,KAAKhH,GAAL,CAASxC,OAAO,CAACoF,WAAR,CAAoB2E,SAApB,IAAiC,KAAKlL,WAAL,CAAiByC,mBAA3D,EAAgF;AAAEa,gBAAAA,GAAG,EAAE;AAAP,eAAhF,CAA7C,EAA6I;AAAEA,gBAAAA,GAAG,EAAE;AAAP,eAA7I;AACA/C,cAAAA,MAAM,CAACC,MAAP,CAAciE,QAAd,EAAwBtD,OAAO,CAACoF,WAAR,CAAoBuE,KAA5C;AACA,qBAAOrG,QAAQ,CAACiF,IAAT,CAAcL,cAAd,CAAP;AACD,aA3BM,CAAP;AA4BD,WA7CM,CAAP;AA8CD,SAjFI,EAkFJmB,GAlFI,CAkFA9G,MAAM,IAAI;AACb;AACA,cAAIpD,OAAO,CAAC4G,KAAZ,EAAmB;AACjB,mBAAO,KAAKlH,WAAL,CAAiB+I,QAAjB,CAA2B,QAAOpB,IAAK,EAAvC,EAA0CjE,MAA1C,EAAkDpD,OAAlD,CAAP;AACD;AACF,SAvFI,EAwFJiI,IAxFI,CAwFC7E,MAAM,IAAI;AACd,eAAK,MAAMmG,KAAX,IAAoBvJ,OAAO,CAAC8G,MAA5B,EAAoC;AAClC1D,YAAAA,MAAM,CAACnC,mBAAP,CAA2BsI,KAA3B,IAAoCnG,MAAM,CAACpC,UAAP,CAAkBuI,KAAlB,CAApC;AACA,iBAAKzF,OAAL,CAAayF,KAAb,EAAoB,KAApB;AACD;;AACD,eAAKpJ,WAAL,GAAmB,KAAnB;AACA,iBAAOiD,MAAP;AACD,SA/FI,CAAP;AAgGD,OAvLM,CAAP;AAwLD;AAED;AACF;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;2BACSpD,O,EAAS;AACdA,MAAAA,OAAO,GAAGzB,KAAK,CAAC+C,QAAN,CAAe,EAAf,EAAmBtB,OAAnB,EAA4B;AACpCkD,QAAAA,KAAK,EAAE,KAAKA,KAAL,EAD6B;AAEpCrC,QAAAA,OAAO,EAAE,KAAKO,QAAL,CAAcP,OAAd,IAAyB;AAFE,OAA5B,CAAV;AAKA,aAAO,KAAKnB,WAAL,CAAiBmL,OAAjB,CAAyB7K,OAAzB,EACJkK,GADI,CACAY,MAAM,IAAI;AACb,YAAI,CAACA,MAAL,EAAa;AACX,gBAAM,IAAIjM,eAAe,CAACkM,aAApB,CACJ,4FADI,CAAN;AAGD;AACF,OAPI,EAQJ9C,IARI,CAQC6C,MAAM,IAAI;AAChB;AACE,aAAK1J,QAAL,GAAgB0J,MAAM,CAAC1J,QAAvB,CAFc,CAGd;;AACA,aAAK2B,GAAL,CAAS+H,MAAM,CAAC9J,UAAhB,EAA4B;AAC1BgC,UAAAA,GAAG,EAAE,IADqB;AAE1BsB,UAAAA,KAAK,EAAE,QAAQ,CAACtE,OAAO,CAACM;AAFE,SAA5B;AAIA,eAAO,IAAP;AACD,OAjBI,CAAP;AAkBD;AAED;AACF;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;6BACWN,O,EAAS;AAChB,aAAO,IAAIrB,iBAAJ,CAAsB,IAAtB,EAA4BqB,OAA5B,EAAqC6G,QAArC,EAAP;AACD;AAED;AACF;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;2BACS9G,M,EAAQC,O,EAAS;AACtB;AACAD,MAAAA,MAAM,GAAG1B,CAAC,CAAC2M,MAAF,CAASjL,MAAT,EAAiB8B,KAAK,IAAIA,KAAK,KAAKiB,SAApC,CAAT;AAEA,YAAMmI,aAAa,GAAG,KAAKnH,OAAL,MAAkB,EAAxC;AAEA9D,MAAAA,OAAO,GAAGA,OAAO,IAAI,EAArB;AACA,UAAIS,KAAK,CAACC,OAAN,CAAcV,OAAd,CAAJ,EAA4BA,OAAO,GAAG;AAAE8G,QAAAA,MAAM,EAAE9G;AAAV,OAAV;AAE5BA,MAAAA,OAAO,GAAGzB,KAAK,CAACwD,SAAN,CAAgB/B,OAAhB,CAAV;AACA,YAAMkL,UAAU,GAAG3M,KAAK,CAACwD,SAAN,CAAgB/B,OAAhB,CAAnB;AACAkL,MAAAA,UAAU,CAAC5K,UAAX,GAAwBN,OAAO,CAAC8G,MAAhC;AACA,WAAK/D,GAAL,CAAShD,MAAT,EAAiBmL,UAAjB,EAZsB,CActB;;AACA,YAAMC,WAAW,GAAG9M,CAAC,CAACmK,OAAF,CAAU,KAAK1E,OAAL,EAAV,EAA0B,GAAGmH,aAA7B,CAApB;;AACA,YAAMnE,MAAM,GAAGzI,CAAC,CAAC+M,KAAF,CAAQnL,MAAM,CAAC4C,IAAP,CAAY9C,MAAZ,CAAR,EAA6BoL,WAA7B,CAAf;;AAEA,UAAI,CAACnL,OAAO,CAAC8G,MAAb,EAAqB;AACnB9G,QAAAA,OAAO,CAAC8G,MAAR,GAAiBzI,CAAC,CAAC2I,YAAF,CAAeF,MAAf,EAAuB,KAAKhD,OAAL,EAAvB,CAAjB;AACA9D,QAAAA,OAAO,CAACiH,aAAR,GAAwBjH,OAAO,CAAC8G,MAAhC;AACD;;AAED,aAAO,KAAKsC,IAAL,CAAUpJ,OAAV,CAAP;AACD;AAED;AACF;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;4BACUA,O,EAAS;AACfA,MAAAA,OAAO,GAAGC,MAAM,CAACC,MAAP,CAAc;AACtB0G,QAAAA,KAAK,EAAE,IADe;AAEtByE,QAAAA,KAAK,EAAE;AAFe,OAAd,EAGPrL,OAHO,CAAV;AAKA,aAAOlB,OAAO,CAACkJ,GAAR,CAAY,MAAM;AACvB;AACA,YAAIhI,OAAO,CAAC4G,KAAZ,EAAmB;AACjB,iBAAO,KAAKlH,WAAL,CAAiB+I,QAAjB,CAA0B,eAA1B,EAA2C,IAA3C,EAAiDzI,OAAjD,CAAP;AACD;AACF,OALM,EAKJiI,IALI,CAKC,MAAM;AACZ,cAAM/E,KAAK,GAAG,KAAKA,KAAL,CAAW,IAAX,CAAd;;AAEA,YAAI,KAAKxD,WAAL,CAAiB6C,oBAAjB,CAAsCK,SAAtC,IAAmD5C,OAAO,CAACqL,KAAR,KAAkB,KAAzE,EAAgF;AAC9E,gBAAMC,aAAa,GAAG,KAAK5L,WAAL,CAAiB6C,oBAAjB,CAAsCK,SAA5D;AACA,gBAAMpC,SAAS,GAAG,KAAKd,WAAL,CAAiBqH,aAAjB,CAA+BuE,aAA/B,CAAlB;AACA,gBAAMzD,YAAY,GAAG5H,MAAM,CAACmC,SAAP,CAAiBC,cAAjB,CAAgCC,IAAhC,CAAqC9B,SAArC,EAAgD,cAAhD,IACjBA,SAAS,CAACqH,YADO,GAEjB,IAFJ;AAGA,gBAAM0D,YAAY,GAAG,KAAKC,YAAL,CAAkBF,aAAlB,CAArB;AACA,gBAAMG,eAAe,GAAGF,YAAY,IAAI,IAAhB,IAAwB1D,YAAY,IAAI,IAAhE;;AACA,cAAI4D,eAAe,IAAIpN,CAAC,CAACiH,OAAF,CAAUiG,YAAV,EAAwB1D,YAAxB,CAAvB,EAA8D;AAC5D;AACA,iBAAK6D,YAAL,CAAkBJ,aAAlB,EAAiC,IAAIK,IAAJ,EAAjC;AACD;;AAED,iBAAO,KAAKvC,IAAL,CAAU/K,CAAC,CAACiD,QAAF,CAAW;AAAEsF,YAAAA,KAAK,EAAE;AAAT,WAAX,EAA6B5G,OAA7B,CAAV,CAAP;AACD;;AACD,eAAO,KAAKN,WAAL,CAAiBG,cAAjB,CAAgC+L,MAAhC,CAAuC,IAAvC,EAA6C,KAAKlM,WAAL,CAAiBkK,YAAjB,CAA8B5J,OAA9B,CAA7C,EAAqFkD,KAArF,EAA4FjD,MAAM,CAACC,MAAP,CAAc;AAAE2L,UAAAA,IAAI,EAAEjN,UAAU,CAACkN,MAAnB;AAA2BC,UAAAA,KAAK,EAAE;AAAlC,SAAd,EAAwD/L,OAAxD,CAA5F,CAAP;AACD,OAxBM,EAwBJkK,GAxBI,CAwBA,MAAM;AACX;AACA,YAAIlK,OAAO,CAAC4G,KAAZ,EAAmB;AACjB,iBAAO,KAAKlH,WAAL,CAAiB+I,QAAjB,CAA0B,cAA1B,EAA0C,IAA1C,EAAgDzI,OAAhD,CAAP;AACD;AACF,OA7BM,CAAP;AA8BD;AAED;AACF;AACA;AACA;AACA;AACA;AACA;;;;oCACkB;AACd,UAAI,CAAC,KAAKN,WAAL,CAAiB6C,oBAAjB,CAAsCK,SAA3C,EAAsD;AACpD,cAAM,IAAI+D,KAAJ,CAAU,uBAAV,CAAN;AACD;;AAED,YAAMqF,kBAAkB,GAAG,KAAKtM,WAAL,CAAiBqH,aAAjB,CAA+B,KAAKrH,WAAL,CAAiB6C,oBAAjB,CAAsCK,SAArE,CAA3B;AACA,YAAMiF,YAAY,GAAG5H,MAAM,CAACmC,SAAP,CAAiBC,cAAjB,CAAgCC,IAAhC,CAAqC0J,kBAArC,EAAyD,cAAzD,IAA2EA,kBAAkB,CAACnE,YAA9F,GAA6G,IAAlI;AACA,YAAMjF,SAAS,GAAG,KAAKS,GAAL,CAAS,KAAK3D,WAAL,CAAiB6C,oBAAjB,CAAsCK,SAA/C,KAA6D,IAA/E;AACA,YAAMqJ,KAAK,GAAGrJ,SAAS,KAAKiF,YAA5B;AAEA,aAAOoE,KAAP;AACD;AAED;AACF;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;4BACUjM,O,EAAS;AACf,UAAI,CAAC,KAAKN,WAAL,CAAiB6C,oBAAjB,CAAsCK,SAA3C,EAAsD,MAAM,IAAI+D,KAAJ,CAAU,uBAAV,CAAN;AAEtD3G,MAAAA,OAAO,GAAGC,MAAM,CAACC,MAAP,CAAc;AACtB0G,QAAAA,KAAK,EAAE,IADe;AAEtByE,QAAAA,KAAK,EAAE;AAFe,OAAd,EAGPrL,OAHO,CAAV;AAKA,aAAOlB,OAAO,CAACkJ,GAAR,CAAY,MAAM;AACvB;AACA,YAAIhI,OAAO,CAAC4G,KAAZ,EAAmB;AACjB,iBAAO,KAAKlH,WAAL,CAAiB+I,QAAjB,CAA0B,eAA1B,EAA2C,IAA3C,EAAiDzI,OAAjD,CAAP;AACD;AACF,OALM,EAKJiI,IALI,CAKC,MAAM;AACZ,cAAMiE,YAAY,GAAG,KAAKxM,WAAL,CAAiB6C,oBAAjB,CAAsCK,SAA3D;AACA,cAAMoJ,kBAAkB,GAAG,KAAKtM,WAAL,CAAiBqH,aAAjB,CAA+BmF,YAA/B,CAA3B;AACA,cAAMC,qBAAqB,GAAGlM,MAAM,CAACmC,SAAP,CAAiBC,cAAjB,CAAgCC,IAAhC,CAAqC0J,kBAArC,EAAyD,cAAzD,IAA2EA,kBAAkB,CAACnE,YAA9F,GAA6G,IAA3I;AAEA,aAAK6D,YAAL,CAAkBQ,YAAlB,EAAgCC,qBAAhC;AACA,eAAO,KAAK/C,IAAL,CAAUnJ,MAAM,CAACC,MAAP,CAAc,EAAd,EAAkBF,OAAlB,EAA2B;AAAE4G,UAAAA,KAAK,EAAE,KAAT;AAAgBwF,UAAAA,QAAQ,EAAE;AAA1B,SAA3B,CAAV,CAAP;AACD,OAZM,EAYJlC,GAZI,CAYA,MAAM;AACX;AACA,YAAIlK,OAAO,CAAC4G,KAAZ,EAAmB;AACjB,iBAAO,KAAKlH,WAAL,CAAiB+I,QAAjB,CAA0B,cAA1B,EAA0C,IAA1C,EAAgDzI,OAAhD,CAAP;AACD;AACF,OAjBM,CAAP;AAkBD;AAED;AACF;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;8BACY8G,M,EAAQ9G,O,EAAS;AACzB,YAAMqM,UAAU,GAAG,KAAKnJ,KAAL,EAAnB;AAEAlD,MAAAA,OAAO,GAAGzB,KAAK,CAACwD,SAAN,CAAgB/B,OAAhB,CAAV;AACAA,MAAAA,OAAO,CAACkD,KAAR,GAAgBjD,MAAM,CAACC,MAAP,CAAc,EAAd,EAAkBF,OAAO,CAACkD,KAA1B,EAAiCmJ,UAAjC,CAAhB;AACArM,MAAAA,OAAO,CAACmE,QAAR,GAAmB,IAAnB;AAEA,aAAO,KAAKzE,WAAL,CAAiB4M,SAAjB,CAA2BxF,MAA3B,EAAmC9G,OAAnC,EAA4CuM,MAA5C,CAAmD,IAAnD,CAAP;AACD;AAED;AACF;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;8BACYzF,M,EAAQ9G,O,EAAS;AACzBA,MAAAA,OAAO,GAAG3B,CAAC,CAACiD,QAAF,CAAW;AAAEgL,QAAAA,SAAS,EAAE;AAAb,OAAX,EAAiCtM,OAAjC,EAA0C;AAClDwM,QAAAA,EAAE,EAAE;AAD8C,OAA1C,CAAV;AAIA,aAAO,KAAKF,SAAL,CAAexF,MAAf,EAAuB9G,OAAvB,CAAP;AACD;AAED;AACF;AACA;AACA;AACA;AACA;AACA;;;;2BACSyM,K,EAAO;AACZ,UAAI,CAACA,KAAD,IAAU,CAACA,KAAK,CAAC/M,WAArB,EAAkC;AAChC,eAAO,KAAP;AACD;;AAED,UAAI,EAAE+M,KAAK,YAAY,KAAK/M,WAAxB,CAAJ,EAA0C;AACxC,eAAO,KAAP;AACD;;AAED,aAAO,KAAKA,WAAL,CAAiBsC,oBAAjB,CAAsC0K,KAAtC,CAA4ClM,SAAS,IAAI,KAAK6C,GAAL,CAAS7C,SAAT,EAAoB;AAAEwC,QAAAA,GAAG,EAAE;AAAP,OAApB,MAAuCyJ,KAAK,CAACpJ,GAAN,CAAU7C,SAAV,EAAqB;AAAEwC,QAAAA,GAAG,EAAE;AAAP,OAArB,CAAhG,CAAP;AACD;AAED;AACF;AACA;AACA;AACA;AACA;AACA;;;;gCACc2J,M,EAAQ;AAClB,aAAOA,MAAM,CAACC,IAAP,CAAYH,KAAK,IAAI,KAAKI,MAAL,CAAYJ,KAAZ,CAArB,CAAP;AACD;;;kCAEajM,S,EAAWsM,U,EAAY;AACnC,WAAKA,UAAL,CAAgBtM,SAAhB,IAA6BsM,UAA7B;AACD;AAED;AACF;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;6BACW;AACP,aAAOzO,CAAC,CAAC0D,SAAF,CACL,KAAKsB,GAAL,CAAS;AACPW,QAAAA,KAAK,EAAE;AADA,OAAT,CADK,CAAP;AAKD;AAED;AACF;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;oCAhqIyBmC,K,EAAOnG,OAAO,GAAG,E,EAAI;AAC1C;AACA;AACA;AACA,UAAIA,OAAO,CAACa,OAAZ,EAAqB;AACnB,aAAK,MAAMA,OAAX,IAAsBb,OAAO,CAACa,OAA9B,EAAuC;AACrC,eAAKkM,eAAL,CAAqBlM,OAAO,CAACsF,KAA7B,EAAoCtF,OAApC;AACD;AACF,OARyC,CAU1C;;;AACA,UAAIxC,CAAC,CAACgF,GAAF,CAAMrD,OAAN,EAAe,kCAAf,CAAJ,EAAwD;AACtD,cAAM0K,YAAY,GAAGrM,CAAC,CAACgF,GAAF,CAAMrD,OAAN,EAAe,+BAAf,CAArB;;AACA,YAAI0K,YAAJ,EAAkB;AAChB1K,UAAAA,OAAO,CAACgN,YAAR,CAAqBzC,OAArB,GAA+B,KAAKwC,eAAL,CAAqBrC,YAArB,EAAmC1K,OAAO,CAACgN,YAAR,CAAqBzC,OAAxD,CAA/B;AACD;AACF;;AAED,UAAI,CAACpE,KAAK,CAACnG,OAAN,CAAciN,UAAf,IAA6B,CAAC9G,KAAK,CAACnG,OAAN,CAAckN,QAA5C,IAAwDlN,OAAO,CAACkN,QAAR,KAAqB,KAAjF,EAAwF;AACtF;AACA,eAAOlN,OAAP;AACD;;AAED,YAAMkM,YAAY,GAAG/F,KAAK,CAAC5D,oBAAN,CAA2BK,SAAhD;AACA,YAAMoJ,kBAAkB,GAAG7F,KAAK,CAACY,aAAN,CAAoBmF,YAApB,CAA3B;AACA,YAAMiB,eAAe,GAAG,EAAxB;AAEA,UAAIhB,qBAAqB,GAAGlM,MAAM,CAACmC,SAAP,CAAiBC,cAAjB,CAAgCC,IAAhC,CAAqC0J,kBAArC,EAAyD,cAAzD,IAA2EA,kBAAkB,CAACnE,YAA9F,GAA6G,IAAzI;AAEAsE,MAAAA,qBAAqB,GAAGA,qBAAqB,IAAI;AAC/C,SAAC/M,EAAE,CAACgO,EAAJ,GAAS;AADsC,OAAjD;AAIAD,MAAAA,eAAe,CAACnB,kBAAkB,CAACzC,KAAnB,IAA4B2C,YAA7B,CAAf,GAA4DC,qBAA5D;;AAEA,UAAI5N,KAAK,CAAC8O,YAAN,CAAmBrN,OAAO,CAACkD,KAA3B,CAAJ,EAAuC;AACrClD,QAAAA,OAAO,CAACkD,KAAR,GAAgBiK,eAAhB;AACD,OAFD,MAEO;AACLnN,QAAAA,OAAO,CAACkD,KAAR,GAAgB;AAAE,WAAC9D,EAAE,CAACkO,GAAJ,GAAU,CAACH,eAAD,EAAkBnN,OAAO,CAACkD,KAA1B;AAAZ,SAAhB;AACD;;AAED,aAAOlD,OAAP;AACD;;;4CAE8B;AAC7B,YAAMuN,IAAI,GAAG,EAAb;AACA,UAAIC,IAAI,GAAG,EAAX,CAF6B,CAI7B;AACA;;AACA,UAAI,CAACnP,CAAC,CAACuO,IAAF,CAAO,KAAK7F,aAAZ,EAA2B,YAA3B,CAAL,EAA+C;AAC7C,YAAI,QAAQ,KAAKA,aAAjB,EAAgC;AAC9B;AACA,gBAAM,IAAIJ,KAAJ,CAAW,wDAAuD,KAAK8G,SAAU,0CAAjF,CAAN;AACD;;AAEDD,QAAAA,IAAI,GAAG;AACLE,UAAAA,EAAE,EAAE;AACF7B,YAAAA,IAAI,EAAE,IAAI5M,SAAS,CAAC0O,OAAd,EADJ;AAEFC,YAAAA,SAAS,EAAE,KAFT;AAGFC,YAAAA,UAAU,EAAE,IAHV;AAIFC,YAAAA,aAAa,EAAE,IAJb;AAKFrD,YAAAA,cAAc,EAAE;AALd;AADC,SAAP;AASD;;AAED,UAAI,KAAKlI,oBAAL,CAA0BC,SAA9B,EAAyC;AACvC+K,QAAAA,IAAI,CAAC,KAAKhL,oBAAL,CAA0BC,SAA3B,CAAJ,GAA4C;AAC1CqJ,UAAAA,IAAI,EAAE5M,SAAS,CAAC8O,IAD0B;AAE1CH,UAAAA,SAAS,EAAE,KAF+B;AAG1CnD,UAAAA,cAAc,EAAE;AAH0B,SAA5C;AAKD;;AAED,UAAI,KAAKlI,oBAAL,CAA0BI,SAA9B,EAAyC;AACvC4K,QAAAA,IAAI,CAAC,KAAKhL,oBAAL,CAA0BI,SAA3B,CAAJ,GAA4C;AAC1CkJ,UAAAA,IAAI,EAAE5M,SAAS,CAAC8O,IAD0B;AAE1CH,UAAAA,SAAS,EAAE,KAF+B;AAG1CnD,UAAAA,cAAc,EAAE;AAH0B,SAA5C;AAKD;;AAED,UAAI,KAAKlI,oBAAL,CAA0BK,SAA9B,EAAyC;AACvC2K,QAAAA,IAAI,CAAC,KAAKhL,oBAAL,CAA0BK,SAA3B,CAAJ,GAA4C;AAC1CiJ,UAAAA,IAAI,EAAE5M,SAAS,CAAC8O,IAD0B;AAE1CtD,UAAAA,cAAc,EAAE;AAF0B,SAA5C;AAID;;AAED,UAAI,KAAKhH,iBAAT,EAA4B;AAC1B8J,QAAAA,IAAI,CAAC,KAAK9J,iBAAN,CAAJ,GAA+B;AAC7BoI,UAAAA,IAAI,EAAE5M,SAAS,CAAC0O,OADa;AAE7BC,UAAAA,SAAS,EAAE,KAFkB;AAG7B/F,UAAAA,YAAY,EAAE,CAHe;AAI7B4C,UAAAA,cAAc,EAAE;AAJa,SAA/B;AAMD;;AAED,YAAMuD,kBAAkB,GAAG3P,CAAC,CAACmD,KAAF,CAAQ,KAAKuF,aAAb,CAA3B;;AACA,WAAKA,aAAL,GAAqB,EAArB;;AAEA1I,MAAAA,CAAC,CAAC4P,IAAF,CAAOT,IAAP,EAAa,CAAC3L,KAAD,EAAQoI,IAAR,KAAiB;AAC5B,aAAKlD,aAAL,CAAmBkD,IAAnB,IAA2BpI,KAA3B;AACD,OAFD;;AAIAxD,MAAAA,CAAC,CAAC4P,IAAF,CAAOD,kBAAP,EAA2B,CAACnM,KAAD,EAAQoI,IAAR,KAAiB;AAC1C,aAAKlD,aAAL,CAAmBkD,IAAnB,IAA2BpI,KAA3B;AACD,OAFD;;AAIAxD,MAAAA,CAAC,CAAC4P,IAAF,CAAOV,IAAP,EAAa,CAAC1L,KAAD,EAAQoI,IAAR,KAAiB;AAC5B,YAAI,KAAKlD,aAAL,CAAmBkD,IAAnB,MAA6BnH,SAAjC,EAA4C;AAC1C,eAAKiE,aAAL,CAAmBkD,IAAnB,IAA2BpI,KAA3B;AACD;AACF,OAJD;;AAMA,UAAI,CAAC5B,MAAM,CAAC4C,IAAP,CAAY,KAAKqL,WAAjB,EAA8BjM,MAAnC,EAA2C;AACzC,aAAKiM,WAAL,CAAiBR,EAAjB,GAAsB,KAAK3G,aAAL,CAAmB2G,EAAzC;AACD;AACF;;;kDAEoC;AACnC,WAAKS,sBAAL,GAA8B,IAA9B;;AAEA,WAAK,MAAMxK,IAAX,IAAmB,KAAKoD,aAAxB,EAAuC;AACrC,YAAI9G,MAAM,CAACmC,SAAP,CAAiBC,cAAjB,CAAgCC,IAAhC,CAAqC,KAAKyE,aAA1C,EAAyDpD,IAAzD,CAAJ,EAAoE;AAClE,gBAAMyK,UAAU,GAAG,KAAKrH,aAAL,CAAmBpD,IAAnB,CAAnB;;AACA,cAAIyK,UAAU,IAAIA,UAAU,CAACN,aAA7B,EAA4C;AAC1C,gBAAI,KAAKK,sBAAT,EAAiC;AAC/B,oBAAM,IAAIxH,KAAJ,CAAU,oEAAV,CAAN;AACD;;AACD,iBAAKwH,sBAAL,GAA8BxK,IAA9B;AACD;AACF;AACF;AACF;;;qCAEuB3D,O,EAASqO,I,EAAM;AACrC,UAAI,CAACrO,OAAO,CAACa,OAAb,EAAsB,OADe,CAGrC;;AACA,UAAI,CAACJ,KAAK,CAACC,OAAN,CAAcV,OAAO,CAACa,OAAtB,CAAL,EAAqC;AACnCb,QAAAA,OAAO,CAACa,OAAR,GAAkB,CAACb,OAAO,CAACa,OAAT,CAAlB;AACD,OAFD,MAEO,IAAI,CAACb,OAAO,CAACa,OAAR,CAAgBoB,MAArB,EAA6B;AAClC,eAAOjC,OAAO,CAACa,OAAf;AACA;AACD,OAToC,CAWrC;;;AACAb,MAAAA,OAAO,CAACa,OAAR,GAAkBb,OAAO,CAACa,OAAR,CAAgBN,GAAhB,CAAoBM,OAAO,IAAI,KAAKyN,eAAL,CAAqBzN,OAArB,EAA8BwN,IAA9B,CAA/B,CAAlB;AACD;;;gDAEkCxN,O,EAASwN,I,EAAM;AAChD,UAAIA,IAAI,IAAI,OAAOxN,OAAP,KAAmB,QAA/B,EAAyC;AACvC,YAAI,CAACZ,MAAM,CAACmC,SAAP,CAAiBC,cAAjB,CAAgCC,IAAhC,CAAqC+L,IAAI,CAACE,YAA1C,EAAwD1N,OAAxD,CAAL,EAAuE;AACrE,gBAAM,IAAI8F,KAAJ,CAAW,2BAA0B9F,OAAQ,uBAAsBwN,IAAI,CAAC1K,IAAK,EAA7E,CAAN;AACD;;AACD,eAAO0K,IAAI,CAACE,YAAL,CAAkB1N,OAAlB,CAAP;AACD;;AACD,aAAOA,OAAP;AACD;;;oCAEsBA,O,EAASwN,I,EAAM;AACpC,UAAIxN,OAAJ,EAAa;AACX,YAAIsF,KAAJ;AAEA,YAAItF,OAAO,CAAC2N,OAAZ,EAAqB,OAAO3N,OAAP;AAErBA,QAAAA,OAAO,GAAG,KAAK4N,2BAAL,CAAiC5N,OAAjC,EAA0CwN,IAA1C,CAAV;;AAEA,YAAIxN,OAAO,YAAY9B,WAAvB,EAAoC;AAClC,cAAIsP,IAAI,IAAIxN,OAAO,CAAC6N,MAAR,CAAe/K,IAAf,KAAwB0K,IAAI,CAAC1K,IAAzC,EAA+C;AAC7CwC,YAAAA,KAAK,GAAGtF,OAAO,CAAC8N,MAAhB;AACD,WAFD,MAEO;AACLxI,YAAAA,KAAK,GAAGtF,OAAO,CAAC6N,MAAhB;AACD;;AAED,iBAAO;AAAEvI,YAAAA,KAAF;AAASF,YAAAA,WAAW,EAAEpF,OAAtB;AAA+BgI,YAAAA,EAAE,EAAEhI,OAAO,CAACgI;AAA3C,WAAP;AACD;;AAED,YAAIhI,OAAO,CAACuB,SAAR,IAAqBvB,OAAO,CAACuB,SAAR,YAA6B3C,KAAtD,EAA6D;AAC3D,iBAAO;AAAE0G,YAAAA,KAAK,EAAEtF;AAAT,WAAP;AACD;;AAED,YAAIxC,CAAC,CAACuQ,aAAF,CAAgB/N,OAAhB,CAAJ,EAA8B;AAC5B,cAAIA,OAAO,CAACoF,WAAZ,EAAyB;AACvBpF,YAAAA,OAAO,CAACoF,WAAR,GAAsB,KAAKwI,2BAAL,CAAiC5N,OAAO,CAACoF,WAAzC,EAAsDoI,IAAtD,CAAtB;;AAEA,gBAAIA,IAAI,IAAIxN,OAAO,CAACoF,WAAR,CAAoByI,MAApB,CAA2B/K,IAA3B,KAAoC0K,IAAI,CAAC1K,IAArD,EAA2D;AACzDwC,cAAAA,KAAK,GAAGtF,OAAO,CAACoF,WAAR,CAAoB0I,MAA5B;AACD,aAFD,MAEO;AACLxI,cAAAA,KAAK,GAAGtF,OAAO,CAACoF,WAAR,CAAoByI,MAA5B;AACD;;AAED,gBAAI,CAAC7N,OAAO,CAACsF,KAAb,EAAoBtF,OAAO,CAACsF,KAAR,GAAgBA,KAAhB;AACpB,gBAAI,CAACtF,OAAO,CAACgI,EAAb,EAAiBhI,OAAO,CAACgI,EAAR,GAAahI,OAAO,CAACoF,WAAR,CAAoB4C,EAAjC;;AAEjB,iBAAKjI,gBAAL,CAAsBC,OAAtB,EAA+BsF,KAA/B;;AACA,mBAAOtF,OAAP;AACD;;AAED,cAAIA,OAAO,CAACsF,KAAZ,EAAmB;AACjB,iBAAKvF,gBAAL,CAAsBC,OAAtB,EAA+BA,OAAO,CAACsF,KAAvC;;AACA,mBAAOtF,OAAP;AACD;;AAED,cAAIA,OAAO,CAACgO,GAAZ,EAAiB;AACf,iBAAKjO,gBAAL,CAAsBC,OAAtB;;AACA,mBAAOA,OAAP;AACD;AACF;AACF;;AAED,YAAM,IAAI8F,KAAJ,CAAU,oFAAV,CAAN;AACD;;;6CAE+BzC,Q,EAAUrD,O,EAAS;AACjD;AACA,UAAIgO,GAAG,GAAGhO,OAAO,CAACgO,GAAlB;AACA,aAAOhO,OAAO,CAACgO,GAAf;;AAEA,UAAIA,GAAG,KAAK,IAAZ,EAAkB;AAChB,YAAI,CAACpO,KAAK,CAACC,OAAN,CAAcmO,GAAd,CAAL,EAAyB;AACvBA,UAAAA,GAAG,GAAG,CAACA,GAAD,CAAN;AACD;;AAED,cAAMC,UAAU,GAAG;AACjBrQ,UAAAA,SAAS,EAAE,IADM;AAEjBsQ,UAAAA,MAAM,EAAE,IAFS;AAGjB/P,UAAAA,OAAO,EAAE,IAHQ;AAIjBgQ,UAAAA,GAAG,EAAE,CAAC,WAAD,EAAc,QAAd,CAJY;AAKjBC,UAAAA,GAAG,EAAE,CAAC,QAAD,EAAW,SAAX,CALY;AAMjBC,UAAAA,IAAI,EAAE,CAAC,SAAD;AANW,SAAnB;;AASA,aAAK,IAAIC,CAAC,GAAG,CAAb,EAAgBA,CAAC,GAAGN,GAAG,CAAC5M,MAAxB,EAAgCkN,CAAC,EAAjC,EAAqC;AACnC,gBAAMtD,IAAI,GAAGgD,GAAG,CAACM,CAAD,CAAhB;;AACA,cAAItD,IAAI,KAAK,KAAb,EAAoB;AAClBgD,YAAAA,GAAG,GAAG,IAAN;AACA;AACD;;AAED,gBAAMO,KAAK,GAAGN,UAAU,CAACjD,IAAD,CAAxB;;AACA,cAAI,CAACuD,KAAL,EAAY;AACV,kBAAM,IAAIvQ,eAAe,CAACwQ,iBAApB,CAAuC,gBAAexD,IAAK,4EAA3D,CAAN;AACD;;AAED,cAAIuD,KAAK,KAAK,IAAd,EAAoB;AAClB;AACAP,YAAAA,GAAG,CAACS,MAAJ,CAAWH,CAAX,EAAc,CAAd;AACAA,YAAAA,CAAC;;AACD,iBAAK,IAAII,CAAC,GAAG,CAAb,EAAgBA,CAAC,GAAGH,KAAK,CAACnN,MAA1B,EAAkCsN,CAAC,EAAnC,EAAuC;AACrC,kBAAI,CAACV,GAAG,CAAC3K,QAAJ,CAAakL,KAAK,CAACG,CAAD,CAAlB,CAAL,EAA6B;AAC3BV,gBAAAA,GAAG,CAAC/G,OAAJ,CAAYsH,KAAK,CAACG,CAAD,CAAjB;AACAJ,gBAAAA,CAAC;AACF;AACF;AACF;AACF;AACF,OA3CgD,CA6CjD;;;AACA,YAAMK,MAAM,GAAG3O,OAAO,CAAC2O,MAAvB;;AACA,UAAIA,MAAJ,EAAY;AACV,eAAO3O,OAAO,CAAC2O,MAAf;;AAEA,YAAI,CAAC3O,OAAO,CAACA,OAAb,EAAsB;AACpBA,UAAAA,OAAO,CAACA,OAAR,GAAkB,EAAlB;AACD,SAFD,MAEO,IAAI,CAACJ,KAAK,CAACC,OAAN,CAAcG,OAAO,CAACA,OAAtB,CAAL,EAAqC;AAC1CA,UAAAA,OAAO,CAACA,OAAR,GAAkB,CAACA,OAAO,CAACA,OAAT,CAAlB;AACD;AACF;;AAED,YAAM4O,IAAI,GAAG,EAAb;;AACA,OAAC,SAASC,cAAT,CAAwBvF,MAAxB,EAAgCjG,QAAhC,EAA0C;AACzC7F,QAAAA,CAAC,CAAC6D,OAAF,CAAUiI,MAAM,CAACoE,YAAjB,EAA+BtI,WAAW,IAAI;AAC5C,cAAI4I,GAAG,KAAK,IAAR,IAAgB,CAACA,GAAG,CAAC3K,QAAJ,CAAa+B,WAAW,CAAC0J,eAAzB,CAArB,EAAgE;AAC9D;AACD,WAH2C,CAK5C;;;AACA,gBAAMxJ,KAAK,GAAGF,WAAW,CAACyI,MAA1B;AACA,gBAAM7F,EAAE,GAAG5C,WAAW,CAACjG,OAAZ,CAAoB6I,EAA/B;AAEA,gBAAM+G,SAAS,GAAG;AAAEzJ,YAAAA;AAAF,WAAlB;;AACA,cAAI0C,EAAJ,EAAQ;AACN;AACA+G,YAAAA,SAAS,CAAC/G,EAAV,GAAeA,EAAf;AACD;;AAED,cAAIxK,CAAC,CAACuO,IAAF,CAAO1I,QAAP,EAAiB0L,SAAjB,CAAJ,EAAiC;AAC/B;AACD,WAjB2C,CAmB5C;;;AACA,cAAIJ,MAAM,IAAIC,IAAI,CAACvL,QAAL,CAAciC,KAAd,CAAd,EAAoC;AAClC;AACD;;AACDsJ,UAAAA,IAAI,CAAChI,IAAL,CAAU0C,MAAV,EAvB4C,CAyB5C;;AACA,gBAAM0F,WAAW,GAAGtR,KAAK,CAACwD,SAAN,CAAgBlB,OAAhB,CAApB;AACAgP,UAAAA,WAAW,CAAC1J,KAAZ,GAAoBA,KAApB;;AACA,cAAI0C,EAAJ,EAAQ;AACNgH,YAAAA,WAAW,CAAChH,EAAZ,GAAiBA,EAAjB;AACD;;AACD3E,UAAAA,QAAQ,CAACuD,IAAT,CAAcoI,WAAd,EA/B4C,CAiC5C;;AACA,cAAIL,MAAJ,EAAY;AACVE,YAAAA,cAAc,CAACvJ,KAAD,EAAQ0J,WAAW,CAAChP,OAApB,CAAd;AACA,gBAAIgP,WAAW,CAAChP,OAAZ,CAAoBoB,MAApB,KAA+B,CAAnC,EAAsC,OAAO4N,WAAW,CAAChP,OAAnB;AACvC;AACF,SAtCD;;AAuCA4O,QAAAA,IAAI,CAACK,GAAL;AACD,OAzCD,EAyCG,IAzCH,EAyCS5L,QAzCT;AA0CD;;;8CAEgClE,O,EAAS+P,U,EAAY;AACpD,UAAI,CAAC/P,OAAO,CAACmG,KAAb,EAAoBnG,OAAO,CAACmG,KAAR,GAAgB,IAAhB;AAEpB4J,MAAAA,UAAU,GAAGA,UAAU,IAAI,EAA3B;AACA/P,MAAAA,OAAO,CAACiE,YAAR,GAAuB,EAAvB;AACAjE,MAAAA,OAAO,CAACgG,UAAR,GAAqB,EAArB;AAEA;;AACAhG,MAAAA,OAAO,CAACgQ,oBAAR,GAA+B,KAA/B;AACAhQ,MAAAA,OAAO,CAACiQ,mBAAR,GAA8B,KAA9B;;AAEA,UAAI,CAACjQ,OAAO,CAACmK,MAAb,EAAqB;AACnBnK,QAAAA,OAAO,CAACkQ,QAAR,GAAmBlQ,OAAO,CAACmG,KAA3B;AACAnG,QAAAA,OAAO,CAACmQ,QAAR,GAAmBnQ,OAAO,CAAC+L,KAA3B;AACD;;AAED/L,MAAAA,OAAO,CAACa,OAAR,GAAkBb,OAAO,CAACa,OAAR,CAAgBN,GAAhB,CAAoBM,OAAO,IAAI;AAC/CA,QAAAA,OAAO,GAAG,KAAKyN,eAAL,CAAqBzN,OAArB,CAAV;AACAA,QAAAA,OAAO,CAACsJ,MAAR,GAAiBnK,OAAjB;AACAa,QAAAA,OAAO,CAACsP,QAAR,GAAmBnQ,OAAO,CAACmQ,QAA3B;;AAEA,aAAKC,wBAAL,CAA8B9N,IAA9B,CAAmCtC,OAAO,CAACmG,KAA3C,EAAkDtF,OAAlD,EAA2DkP,UAA3D,EAAuE/P,OAAvE;;AAEA,YAAIa,OAAO,CAACwP,WAAR,KAAwBvN,SAA5B,EAAuC;AACrCjC,UAAAA,OAAO,CAACwP,WAAR,GAAsBxP,OAAO,CAACoF,WAAR,CAAoBqK,kBAA1C;AACD;;AAEDzP,QAAAA,OAAO,CAAC0P,cAAR,GAAyB1P,OAAO,CAAC0P,cAAR,IAA0B1P,OAAO,CAACwP,WAA3D;AACAxP,QAAAA,OAAO,CAAC2P,WAAR,GAAsB3P,OAAO,CAAC2P,WAAR,IAAuB3P,OAAO,CAAC4P,QAArD;AAEAzQ,QAAAA,OAAO,CAACuQ,cAAR,GAAyBvQ,OAAO,CAACuQ,cAAR,IAA0B1P,OAAO,CAAC0P,cAA3D;AACAvQ,QAAAA,OAAO,CAACwQ,WAAR,GAAsBxQ,OAAO,CAACwQ,WAAR,IAAuB3P,OAAO,CAAC4P,QAArD;AAEAzQ,QAAAA,OAAO,CAAC0Q,QAAR,GAAmB1Q,OAAO,CAAC0Q,QAAR,IAAoB7P,OAAO,CAAC6P,QAA5B,IAAwC,CAAC,CAAC7P,OAAO,CAACqC,KAArE;AACA,eAAOrC,OAAP;AACD,OAnBiB,CAAlB;;AAqBA,WAAK,MAAMA,OAAX,IAAsBb,OAAO,CAACa,OAA9B,EAAuC;AACrCA,QAAAA,OAAO,CAAC8P,cAAR,GAAyB3Q,OAAO,CAAC2Q,cAAR,IAA0B,CAAC,CAAC3Q,OAAO,CAACkD,KAA7D;AACArC,QAAAA,OAAO,CAAC+P,iBAAR,GAA4B5Q,OAAO,CAAC4Q,iBAAR,IAA6B,CAAC,CAAC5Q,OAAO,CAACyQ,QAAnE;;AAEA,YAAI5P,OAAO,CAACgQ,QAAR,KAAqB,KAArB,IAA8B7Q,OAAO,CAACuQ,cAAtC,IAAwDvQ,OAAO,CAACmQ,QAApE,EAA8E;AAC5E,cAAItP,OAAO,CAACwP,WAAZ,EAAyB;AACvBxP,YAAAA,OAAO,CAACgQ,QAAR,GAAmB,KAAnB;AACAhQ,YAAAA,OAAO,CAACiQ,cAAR,GAAyBjQ,OAAO,CAAC2P,WAAjC;AACD,WAHD,MAGO;AACL3P,YAAAA,OAAO,CAACgQ,QAAR,GAAmBhQ,OAAO,CAAC2P,WAA3B;AACA3P,YAAAA,OAAO,CAACiQ,cAAR,GAAyB,KAAzB;AACD;AACF,SARD,MAQO;AACLjQ,UAAAA,OAAO,CAACgQ,QAAR,GAAmBhQ,OAAO,CAACgQ,QAAR,IAAoB,KAAvC;;AACA,cAAIhQ,OAAO,CAACwP,WAAZ,EAAyB;AACvBxP,YAAAA,OAAO,CAACiQ,cAAR,GAAyBjQ,OAAO,CAACgQ,QAAjC;AACAhQ,YAAAA,OAAO,CAACgQ,QAAR,GAAmB,KAAnB;AACD,WAHD,MAGO;AACLhQ,YAAAA,OAAO,CAACiQ,cAAR,GAAyB,KAAzB;AACAjQ,YAAAA,OAAO,CAACgQ,QAAR,GAAmBhQ,OAAO,CAACgQ,QAAR,IAAoBhQ,OAAO,CAAC+P,iBAAR,IAA6B/P,OAAO,CAAC2P,WAA5E;AACD;AACF;;AAEDxQ,QAAAA,OAAO,CAACgG,UAAR,CAAmBnF,OAAO,CAACgI,EAA3B,IAAiChI,OAAjC;AACAb,QAAAA,OAAO,CAACiE,YAAR,CAAqBwD,IAArB,CAA0B5G,OAAO,CAACgI,EAAlC,EAxBqC,CA0BrC;;AACA,YAAI7I,OAAO,CAACkQ,QAAR,KAAqBlQ,OAAO,CAACmG,KAA7B,IAAsCnG,OAAO,CAAC6Q,QAAR,KAAqB/N,SAA3D,IAAwE9C,OAAO,CAACmQ,QAApF,EAA8F;AAC5F,cAAItP,OAAO,CAACgQ,QAAZ,EAAsB;AACpB7Q,YAAAA,OAAO,CAAC6Q,QAAR,GAAmBhQ,OAAO,CAACgQ,QAA3B;AACD,WAFD,MAEO,IAAIhQ,OAAO,CAAC0P,cAAZ,EAA4B;AACjCvQ,YAAAA,OAAO,CAAC6Q,QAAR,GAAmB,IAAnB;AACD;AACF;AAED;;;AACA7Q,QAAAA,OAAO,CAAC+Q,eAAR,GAA0B/Q,OAAO,CAAC+Q,eAAR,IAA2BlQ,OAAO,CAACkQ,eAAnC,IAAsD,CAAC,CAAClQ,OAAO,CAACqC,KAA1F;AACAlD,QAAAA,OAAO,CAACgR,kBAAR,GAA6BhR,OAAO,CAACgR,kBAAR,IAA8BnQ,OAAO,CAACmQ,kBAAtC,IAA4D,CAAC,CAACnQ,OAAO,CAAC4P,QAAnG;;AAEA,YAAI5P,OAAO,CAACoF,WAAR,CAAoBqK,kBAApB,IAA0CzP,OAAO,CAACoP,mBAAtD,EAA2E;AACzEjQ,UAAAA,OAAO,CAACiQ,mBAAR,GAA8B,IAA9B;AACD;;AACD,YAAIpP,OAAO,CAACoF,WAAR,CAAoBM,mBAApB,IAA2C1F,OAAO,CAACmP,oBAAvD,EAA6E;AAC3EhQ,UAAAA,OAAO,CAACgQ,oBAAR,GAA+B,IAA/B;AACD;AACF;;AAED,UAAIhQ,OAAO,CAACkQ,QAAR,KAAqBlQ,OAAO,CAACmG,KAA7B,IAAsCnG,OAAO,CAAC6Q,QAAR,KAAqB/N,SAA/D,EAA0E;AACxE9C,QAAAA,OAAO,CAAC6Q,QAAR,GAAmB,KAAnB;AACD;;AACD,aAAO7Q,OAAP;AACD;;;6CAE+Ba,O,EAASkP,U,EAAY/P,O,EAAS;AAC5D+P,MAAAA,UAAU,CAAClP,OAAO,CAACsF,KAAR,CAAcyD,YAAd,EAAD,CAAV,GAA2C,IAA3C;;AAEA,UAAI/I,OAAO,CAACP,UAAR,IAAsB,CAACN,OAAO,CAACgD,GAAnC,EAAwC;AACtCnC,QAAAA,OAAO,CAACsF,KAAR,CAAc8K,iBAAd,CAAgCpQ,OAAhC;;AAEAA,QAAAA,OAAO,CAACwF,kBAAR,GAA6B,KAAK6K,iCAAL,CAAuCrQ,OAAO,CAACP,UAA/C,CAA7B;AAEAO,QAAAA,OAAO,GAAGtC,KAAK,CAAC4S,gBAAN,CAAuBtQ,OAAvB,EAAgCA,OAAO,CAACsF,KAAxC,CAAV;;AAEA,YAAItF,OAAO,CAACP,UAAR,CAAmB2B,MAAvB,EAA+B;AAC7B5D,UAAAA,CAAC,CAAC4P,IAAF,CAAOpN,OAAO,CAACsF,KAAR,CAAc+H,WAArB,EAAkC,CAACjE,IAAD,EAAO1I,GAAP,KAAe;AAC/C;AACA,gBAAI,CAACV,OAAO,CAACP,UAAR,CAAmBsM,IAAnB,CAAwBwE,WAAW,IAAI;AAC1C,kBAAInH,IAAI,CAACV,KAAL,KAAehI,GAAnB,EAAwB;AACtB,uBAAOd,KAAK,CAACC,OAAN,CAAc0Q,WAAd,KAA8BA,WAAW,CAAC,CAAD,CAAX,KAAmBnH,IAAI,CAACV,KAAtD,IAA+D6H,WAAW,CAAC,CAAD,CAAX,KAAmB7P,GAAzF;AACD;;AACD,qBAAO6P,WAAW,KAAK7P,GAAvB;AACD,aALI,CAAL,EAKI;AACFV,cAAAA,OAAO,CAACP,UAAR,CAAmBwH,OAAnB,CAA2BvG,GAA3B;AACD;AACF,WAVD;AAWD;AACF,OApBD,MAoBO;AACLV,QAAAA,OAAO,GAAGtC,KAAK,CAAC4S,gBAAN,CAAuBtQ,OAAvB,EAAgCA,OAAO,CAACsF,KAAxC,CAAV;AACD,OAzB2D,CA2B5D;;;AACA,UAAItF,OAAO,CAAC2N,OAAZ,EAAqB;AACnB3N,QAAAA,OAAO,CAACP,UAAR,GAAqBL,MAAM,CAAC4C,IAAP,CAAYhC,OAAO,CAACsF,KAAR,CAAckL,eAA1B,CAArB;AACA,eAAO9S,KAAK,CAAC4S,gBAAN,CAAuBtQ,OAAvB,EAAgCA,OAAO,CAACsF,KAAxC,CAAP;AACD,OA/B2D,CAiC5D;;;AACA,YAAMF,WAAW,GAAGpF,OAAO,CAACoF,WAAR,IAAuB,KAAKqL,uBAAL,CAA6BzQ,OAAO,CAACsF,KAArC,EAA4CtF,OAAO,CAACgI,EAApD,CAA3C;;AAEAhI,MAAAA,OAAO,CAACoF,WAAR,GAAsBA,WAAtB;AACApF,MAAAA,OAAO,CAACgI,EAAR,GAAa5C,WAAW,CAAC4C,EAAzB,CArC4D,CAuC5D;;AACA,UAAIhI,OAAO,CAACoF,WAAR,CAAoBsE,OAApB,IAA+BtK,MAAM,CAACY,OAAO,CAACoF,WAAR,CAAoBsE,OAApB,CAA4BpE,KAA7B,CAAN,KAA8CtF,OAAO,CAACoF,WAAR,CAAoBsE,OAApB,CAA4BpE,KAA7G,EAAoH;AAClH,YAAI,CAACtF,OAAO,CAACA,OAAb,EAAsBA,OAAO,CAACA,OAAR,GAAkB,EAAlB;AACtB,cAAM0J,OAAO,GAAG1J,OAAO,CAACoF,WAAR,CAAoBsE,OAApC;AAEA1J,QAAAA,OAAO,CAAC0J,OAAR,GAAkBlM,CAAC,CAACiD,QAAF,CAAWT,OAAO,CAAC0J,OAAR,IAAmB,EAA9B,EAAkC;AAClDpE,UAAAA,KAAK,EAAEoE,OAAO,CAACpE,KADmC;AAElD0C,UAAAA,EAAE,EAAE0B,OAAO,CAACpE,KAAR,CAAcxC,IAFgC;AAGlDsC,UAAAA,WAAW,EAAE;AACXM,YAAAA,mBAAmB,EAAE;AADV,WAHqC;AAMlDiI,UAAAA,OAAO,EAAE,IANyC;AAOlDrE,UAAAA,MAAM,EAAEtJ;AAP0C,SAAlC,CAAlB;;AAWA,YAAI0J,OAAO,CAACC,KAAZ,EAAmB;AACjB3J,UAAAA,OAAO,CAAC0J,OAAR,CAAgBrH,KAAhB,GAAwBrC,OAAO,CAAC0J,OAAR,CAAgBrH,KAAhB,GAAwB;AAAE,aAAC9D,EAAE,CAACkO,GAAJ,GAAU,CAACzM,OAAO,CAAC0J,OAAR,CAAgBrH,KAAjB,EAAwBqH,OAAO,CAACC,KAAhC;AAAZ,WAAxB,GAA+ED,OAAO,CAACC,KAA/G;AACD;;AAED3J,QAAAA,OAAO,CAACA,OAAR,CAAgB4G,IAAhB,CAAqB5G,OAAO,CAAC0J,OAA7B;AACAwF,QAAAA,UAAU,CAACxF,OAAO,CAACkD,SAAT,CAAV,GAAgC,IAAhC;AACD,OA7D2D,CA+D5D;;;AACA,UAAItH,KAAJ;;AACA,UAAItF,OAAO,CAACsF,KAAR,CAAcoL,MAAd,KAAyB,IAA7B,EAAmC;AACjC;AACApL,QAAAA,KAAK,GAAGtF,OAAO,CAACsF,KAAhB;AACD,OAHD,MAGO;AACL;AACAA,QAAAA,KAAK,GAAGtF,OAAO,CAACoF,WAAR,CAAoByI,MAApB,CAA2B/K,IAA3B,KAAoC9C,OAAO,CAACsF,KAAR,CAAcxC,IAAlD,GAAyD9C,OAAO,CAACoF,WAAR,CAAoByI,MAA7E,GAAsF7N,OAAO,CAACoF,WAAR,CAAoB0I,MAAlH;AACD;;AAEDxI,MAAAA,KAAK,CAACqL,YAAN,CAAmB3Q,OAAnB,EAzE4D,CA2E5D;;;AACA,UAAI,CAACA,OAAO,CAACP,UAAb,EAAyB;AACvBO,QAAAA,OAAO,CAACP,UAAR,GAAqBL,MAAM,CAAC4C,IAAP,CAAYhC,OAAO,CAACsF,KAAR,CAAckL,eAA1B,CAArB;AACD;;AAEDxQ,MAAAA,OAAO,GAAGtC,KAAK,CAAC4S,gBAAN,CAAuBtQ,OAAvB,EAAgCA,OAAO,CAACsF,KAAxC,CAAV;;AAEA,UAAItF,OAAO,CAAC4P,QAAR,KAAqB3N,SAAzB,EAAoC;AAClCjC,QAAAA,OAAO,CAAC4P,QAAR,GAAmB,CAAC,CAAC5P,OAAO,CAACqC,KAA7B;AACD;;AAED,UAAIrC,OAAO,CAACoF,WAAR,CAAoBuE,KAAxB,EAA+B;AAC7B3J,QAAAA,OAAO,CAACqC,KAAR,GAAgBrC,OAAO,CAACqC,KAAR,GAAgB;AAAE,WAAC9D,EAAE,CAACkO,GAAJ,GAAU,CAACzM,OAAO,CAACqC,KAAT,EAAgBrC,OAAO,CAACoF,WAAR,CAAoBuE,KAApC;AAAZ,SAAhB,GAA2E3J,OAAO,CAACoF,WAAR,CAAoBuE,KAA/G;AACD;;AAED,UAAI3J,OAAO,CAACkL,KAAR,IAAiBlL,OAAO,CAAC4Q,QAAR,KAAqB3O,SAA1C,EAAqD;AACnDjC,QAAAA,OAAO,CAAC4Q,QAAR,GAAmB,IAAnB;AACD;;AAED,UAAI5Q,OAAO,CAAC4Q,QAAR,KAAqB,IAAzB,EAA+B;AAC7B,YAAI,EAAE5Q,OAAO,CAACoF,WAAR,YAA+BjH,OAAjC,CAAJ,EAA+C;AAC7C,gBAAM,IAAI2H,KAAJ,CAAU,oDAAV,CAAN;AACD;;AAED9F,QAAAA,OAAO,CAACwP,WAAR,GAAsB,KAAtB;;AAEA,YACErQ,OAAO,CAACM,UAAR,IACGN,OAAO,CAACM,UAAR,CAAmB2B,MADtB,IAEG,CAAC5D,CAAC,CAACqT,YAAF,CAAe1R,OAAO,CAACM,UAAvB,EAAmC,CAAnC,EAAsC4D,QAAtC,CAA+C+B,WAAW,CAAC2E,SAA3D,CAHN,EAIE;AACA5K,UAAAA,OAAO,CAACM,UAAR,CAAmBmH,IAAnB,CAAwBxB,WAAW,CAAC2E,SAApC;AACD;;AAED,YACE/J,OAAO,CAACP,UAAR,IACGO,OAAO,CAACP,UAAR,CAAmB2B,MADtB,IAEG,CAAC5D,CAAC,CAACqT,YAAF,CAAe7Q,OAAO,CAACP,UAAvB,EAAmC,CAAnC,EAAsC4D,QAAtC,CAA+C+B,WAAW,CAACoE,UAA3D,CAHN,EAIE;AACAxJ,UAAAA,OAAO,CAACP,UAAR,CAAmBmH,IAAnB,CAAwBxB,WAAW,CAACoE,UAApC;AACD;AACF,OApH2D,CAsH5D;;;AACA,UAAIpK,MAAM,CAACmC,SAAP,CAAiBC,cAAjB,CAAgCC,IAAhC,CAAqCzB,OAArC,EAA8C,SAA9C,CAAJ,EAA8D;AAC5D,aAAKE,yBAAL,CAA+BuB,IAA/B,CAAoCzB,OAAO,CAACsF,KAA5C,EAAmDtF,OAAnD,EAA4DkP,UAA5D;AACD;;AAED,aAAOlP,OAAP;AACD;;;4CAE8B8Q,W,EAAaC,W,EAAa;AACvD,YAAMrD,YAAY,GAAG,KAAKsD,eAAL,CAAqBF,WAArB,CAArB;AACA,UAAI1L,WAAW,GAAG,IAAlB;;AACA,UAAIsI,YAAY,CAACtM,MAAb,KAAwB,CAA5B,EAA+B;AAC7B,cAAM,IAAIpD,eAAe,CAACwQ,iBAApB,CAAuC,GAAEsC,WAAW,CAAChO,IAAK,yBAAwB,KAAKA,IAAK,GAA5F,CAAN;AACD;;AACD,UAAI4K,YAAY,CAACtM,MAAb,KAAwB,CAA5B,EAA+B;AAC7BgE,QAAAA,WAAW,GAAG,KAAK6L,sBAAL,CAA4BH,WAA5B,EAAyCC,WAAzC,CAAd;;AACA,YAAI3L,WAAJ,EAAiB;AACf,iBAAOA,WAAP;AACD;;AACD,YAAI2L,WAAJ,EAAiB;AACf,gBAAMG,eAAe,GAAG,KAAKF,eAAL,CAAqBF,WAArB,EAAkCpR,GAAlC,CAAsC0F,WAAW,IAAIA,WAAW,CAAC4C,EAAjE,CAAxB;AACA,gBAAM,IAAIhK,eAAe,CAACwQ,iBAApB,CAAuC,GAAEsC,WAAW,CAAChO,IAAK,qBAAoB,KAAKA,IAAK,mBAAlD,GACzC,6BAA4BiO,WAAY,uEAAsEG,eAAe,CAACC,IAAhB,CAAqB,IAArB,CAA2B,IADtI,CAAN;AAED;;AACD,cAAM,IAAInT,eAAe,CAACwQ,iBAApB,CAAuC,GAAEsC,WAAW,CAAChO,IAAK,qBAAoB,KAAKA,IAAK,mBAAlD,GAC1C,qFADI,CAAN;AAED;;AACDsC,MAAAA,WAAW,GAAG,KAAK6L,sBAAL,CAA4BH,WAA5B,EAAyCC,WAAzC,CAAd;;AACA,UAAI,CAAC3L,WAAL,EAAkB;AAChB,cAAM,IAAIpH,eAAe,CAACwQ,iBAApB,CAAuC,GAAEsC,WAAW,CAAChO,IAAK,qBAAoB,KAAKA,IAAK,mBAAlD,GAC1C,mIADI,CAAN;AAED;;AACD,aAAOsC,WAAP;AACD;;;sCAGwBjG,O,EAAS;AAChC,YAAMkE,QAAQ,GAAGlE,OAAO,CAACa,OAAzB;;AACA,UAAI,CAACqD,QAAL,EAAe;AACb;AACD;;AAED,WAAK,IAAI+N,KAAK,GAAG,CAAjB,EAAoBA,KAAK,GAAG/N,QAAQ,CAACjC,MAArC,EAA6CgQ,KAAK,EAAlD,EAAsD;AACpD,cAAMpR,OAAO,GAAGqD,QAAQ,CAAC+N,KAAD,CAAxB;;AAEA,YAAIpR,OAAO,CAACgO,GAAZ,EAAiB;AACf3K,UAAAA,QAAQ,CAACoL,MAAT,CAAgB2C,KAAhB,EAAuB,CAAvB;AACAA,UAAAA,KAAK;;AAEL,eAAKC,wBAAL,CAA8BhO,QAA9B,EAAwCrD,OAAxC;AACD;AACF;;AAEDqD,MAAAA,QAAQ,CAAChC,OAAT,CAAiBrB,OAAO,IAAI;AAC1B,aAAKC,iBAAL,CAAuBwB,IAAvB,CAA4BzB,OAAO,CAACsF,KAApC,EAA2CtF,OAA3C;AACD,OAFD;AAGD;;;kCAEoBoR,K,EAAO;AAC1B,UAAI,CAACA,KAAK,CAACnL,MAAX,EAAmB;AACjB,cAAM,IAAIH,KAAJ,CAAU,gDAAV,CAAN;AACD;;AAEDsL,MAAAA,KAAK,GAAG5T,CAAC,CAACiD,QAAF,CAAW2Q,KAAX,EAAkB;AACxBpG,QAAAA,IAAI,EAAE,EADkB;AAExBsG,QAAAA,MAAM,EAAE;AAFgB,OAAlB,CAAR;;AAKA,UAAIF,KAAK,CAACpG,IAAN,IAAcoG,KAAK,CAACpG,IAAN,CAAWuG,WAAX,OAA6B,QAA/C,EAAyD;AACvDH,QAAAA,KAAK,CAACI,MAAN,GAAe,IAAf;AACA,eAAOJ,KAAK,CAACpG,IAAb;AACD;;AAED,aAAOoG,KAAP;AACD;;;kCAGoBjS,O,EAAS;AAC5B,UAAI,CAACA,OAAO,CAACa,OAAb,EAAsB;AAEtBb,MAAAA,OAAO,CAACa,OAAR,GAAkBxC,CAAC,CAAC2B,OAAO,CAACa,OAAT,CAAD,CACfyR,OADe,CACPzR,OAAO,IAAK,GAAEA,OAAO,CAACsF,KAAR,IAAiBtF,OAAO,CAACsF,KAAR,CAAcxC,IAAK,IAAG9C,OAAO,CAACgI,EAAG,EADzD,EAEftI,GAFe,CAEX2D,QAAQ,IAAI,KAAKqO,cAAL,CAAoB,GAAGrO,QAAvB,CAFD,EAGfrC,KAHe,EAAlB;AAID;;;+BAEiB,GAAG8H,I,EAAM;AACzBtL,MAAAA,CAAC,CAACmU,UAAF,CAAa,GAAG7I,IAAhB;;AACA,WAAK/I,gBAAL,CAAsB+I,IAAI,CAAC,CAAD,CAA1B,EAA+B,IAA/B;;AACA,WAAK8I,aAAL,CAAmB9I,IAAI,CAAC,CAAD,CAAvB;;AACA,aAAOA,IAAI,CAAC,CAAD,CAAX;AACD;;;mCAEqB+I,Q,EAAUC,Q,EAAUpR,G,EAAK;AAC7C,UAAId,KAAK,CAACC,OAAN,CAAcgS,QAAd,KAA2BjS,KAAK,CAACC,OAAN,CAAciS,QAAd,CAA/B,EAAwD;AACtD,eAAOtU,CAAC,CAAC+M,KAAF,CAAQsH,QAAR,EAAkBC,QAAlB,CAAP;AACD;;AACD,UAAIpR,GAAG,KAAK,OAAR,IAAmBA,GAAG,KAAK,QAA/B,EAAyC;AACvC,YAAIoR,QAAQ,YAAYpU,KAAK,CAACuD,eAA9B,EAA+C;AAC7C6Q,UAAAA,QAAQ,GAAG;AAAE,aAACvT,EAAE,CAACkO,GAAJ,GAAUqF;AAAZ,WAAX;AACD;;AACD,YAAItU,CAAC,CAACuQ,aAAF,CAAgB8D,QAAhB,KAA6BrU,CAAC,CAACuQ,aAAF,CAAgB+D,QAAhB,CAAjC,EAA4D;AAC1D,iBAAO1S,MAAM,CAACC,MAAP,CAAcwS,QAAd,EAAwBC,QAAxB,CAAP;AACD;AACF,OAPD,MAOO,IAAIpR,GAAG,KAAK,YAAR,IAAwBlD,CAAC,CAACuQ,aAAF,CAAgB8D,QAAhB,CAAxB,IAAqDrU,CAAC,CAACuQ,aAAF,CAAgB+D,QAAhB,CAAzD,EAAoF;AACzF,eAAOtU,CAAC,CAACmU,UAAF,CAAaE,QAAb,EAAuBC,QAAvB,EAAiC,CAACD,QAAD,EAAWC,QAAX,KAAwB;AAC9D,cAAIlS,KAAK,CAACC,OAAN,CAAcgS,QAAd,KAA2BjS,KAAK,CAACC,OAAN,CAAciS,QAAd,CAA/B,EAAwD;AACtD,mBAAOtU,CAAC,CAAC+M,KAAF,CAAQsH,QAAR,EAAkBC,QAAlB,CAAP;AACD;AACF,SAJM,CAAP;AAKD,OAjB4C,CAkB7C;AACA;AACA;;;AACA,UAAIA,QAAJ,EAAc;AACZ,eAAOpU,KAAK,CAACwD,SAAN,CAAgB4Q,QAAhB,EAA0B,IAA1B,CAAP;AACD;;AACD,aAAOA,QAAQ,KAAK7P,SAAb,GAAyB4P,QAAzB,GAAoCC,QAA3C;AACD;;;mCAEqB,GAAGhJ,I,EAAM;AAC7B,aAAO,KAAKiJ,UAAL,CAAgB,GAAGjJ,IAAnB,EAAyB,KAAKkJ,cAA9B,CAAP;AACD;;;qCAEuBnE,M,EAAQoE,I,EAAM;AACpC,aAAO,KAAKF,UAAL,CAAgBlE,MAAhB,EAAwBoE,IAAxB,EAA8B,CAACH,QAAD,EAAWD,QAAX,EAAqBnR,GAArB,KAA6B;AAChE,eAAO,KAAKsR,cAAL,CAAoBH,QAApB,EAA8BC,QAA9B,EAAwCpR,GAAxC,CAAP;AACD,OAFM,CAAP;AAGD;AAED;AACF;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;yBACcjB,U,EAAYN,OAAO,GAAG,E,EAAI;AACpC,UAAI,CAACA,OAAO,CAACL,SAAb,EAAwB;AACtB,cAAM,IAAIgH,KAAJ,CAAU,8BAAV,CAAN;AACD;;AAED,WAAKhH,SAAL,GAAiBK,OAAO,CAACL,SAAzB;AAEA,YAAMoT,aAAa,GAAG,KAAKpT,SAAL,CAAeK,OAArC;AAEAA,MAAAA,OAAO,GAAGzB,KAAK,CAACyU,KAAN,CAAY3U,CAAC,CAAC0D,SAAF,CAAYgR,aAAa,CAACE,MAA1B,CAAZ,EAA+CjT,OAA/C,CAAV;;AAEA,UAAI,CAACA,OAAO,CAACgK,SAAb,EAAwB;AACtBhK,QAAAA,OAAO,CAACgK,SAAR,GAAoB,KAAKrG,IAAzB;AACD;;AAED3D,MAAAA,OAAO,GAAGzB,KAAK,CAACyU,KAAN,CAAY;AACpBrP,QAAAA,IAAI,EAAE;AACJuP,UAAAA,MAAM,EAAE3U,KAAK,CAAC4U,SAAN,CAAgBnT,OAAO,CAACgK,SAAxB,CADJ;AAEJoJ,UAAAA,QAAQ,EAAE7U,KAAK,CAAC8U,WAAN,CAAkBrT,OAAO,CAACgK,SAA1B;AAFN,SADc;AAKpBsJ,QAAAA,OAAO,EAAE,EALW;AAMpBlH,QAAAA,QAAQ,EAAE2G,aAAa,CAAC3G,QANJ;AAOpBmH,QAAAA,MAAM,EAAER,aAAa,CAACQ;AAPF,OAAZ,EAQPvT,OARO,CAAV;AAUA,WAAKL,SAAL,CAAe8I,QAAf,CAAwB,cAAxB,EAAwCnI,UAAxC,EAAoDN,OAApD;;AAEA,UAAIA,OAAO,CAACgK,SAAR,KAAsB,KAAKrG,IAA/B,EAAqC;AACnC1D,QAAAA,MAAM,CAACuT,cAAP,CAAsB,IAAtB,EAA4B,MAA5B,EAAoC;AAAE3R,UAAAA,KAAK,EAAE7B,OAAO,CAACgK;AAAjB,SAApC;AACD;;AACD,aAAOhK,OAAO,CAACgK,SAAf;AAEA,WAAKhK,OAAL,GAAeC,MAAM,CAACC,MAAP,CAAc;AAC3B+M,QAAAA,UAAU,EAAE,IADe;AAE3BpG,QAAAA,QAAQ,EAAE,EAFiB;AAG3B4M,QAAAA,eAAe,EAAE,KAHU;AAI3BC,QAAAA,WAAW,EAAE,KAJc;AAK3BxG,QAAAA,QAAQ,EAAE,KALiB;AAM3ByG,QAAAA,aAAa,EAAE,KANY;AAO3BpQ,QAAAA,eAAe,EAAE,IAPU;AAQ3BgQ,QAAAA,MAAM,EAAE,IARmB;AAS3BK,QAAAA,eAAe,EAAE,EATU;AAU3BC,QAAAA,YAAY,EAAE,EAVa;AAW3BC,QAAAA,MAAM,EAAE,EAXmB;AAY3BR,QAAAA,OAAO,EAAE;AAZkB,OAAd,EAaZtT,OAbY,CAAf,CAhCoC,CA+CpC;;AACA,UAAI,KAAKL,SAAL,CAAeoU,SAAf,CAAyB,KAAKpQ,IAA9B,CAAJ,EAAyC;AACvC,aAAKhE,SAAL,CAAeqU,YAAf,CAA4BC,WAA5B,CAAwC,KAAKtU,SAAL,CAAeqU,YAAf,CAA4BE,QAA5B,CAAqC,KAAKvQ,IAA1C,CAAxC;AACD;;AAED,WAAK4K,YAAL,GAAoB,EAApB;;AACA,WAAK4F,WAAL,CAAiBnU,OAAO,CAAC4G,KAAzB;;AAEA,WAAK8M,WAAL,GAAmB,KAAK1T,OAAL,CAAa0T,WAAhC;;AAEA,UAAI,CAAC,KAAK1T,OAAL,CAAayN,SAAlB,EAA6B;AAC3B,aAAKA,SAAL,GAAiB,KAAKzN,OAAL,CAAayT,eAAb,GAA+B,KAAK9P,IAApC,GAA2CpF,KAAK,CAAC6V,aAAN,CAAoB7V,KAAK,CAAC4U,SAAN,CAAgB,KAAKxP,IAArB,CAApB,EAAgD,KAAK+P,WAArD,CAA5D;AACD,OAFD,MAEO;AACL,aAAKjG,SAAL,GAAiB,KAAKzN,OAAL,CAAayN,SAA9B;AACD;;AAED,WAAKrN,OAAL,GAAe,KAAKJ,OAAL,CAAauT,MAA5B;AACA,WAAKlT,gBAAL,GAAwB,KAAKL,OAAL,CAAa4T,eAArC,CAhEoC,CAkEpC;;AACAvV,MAAAA,CAAC,CAAC4P,IAAF,CAAOjO,OAAO,CAAC6G,QAAf,EAAyB,CAACwN,SAAD,EAAYC,aAAZ,KAA8B;AACrD,YAAIrU,MAAM,CAACmC,SAAP,CAAiBC,cAAjB,CAAgCC,IAAhC,CAAqChC,UAArC,EAAiDgU,aAAjD,CAAJ,EAAqE;AACnE,gBAAM,IAAI3N,KAAJ,CAAW,6EAA4E,KAAKhD,IAAK,4BAA2B2Q,aAAc,EAA1I,CAAN;AACD;;AAED,YAAI,OAAOD,SAAP,KAAqB,UAAzB,EAAqC;AACnC,gBAAM,IAAI1N,KAAJ,CAAW,4DAA2D,KAAKhD,IAAK,gCAA+B2Q,aAAc,EAA7H,CAAN;AACD;AACF,OARD;;AAUA,WAAKvN,aAAL,GAAqB1I,CAAC,CAACqD,SAAF,CAAYpB,UAAZ,EAAwB,CAACE,SAAD,EAAYmD,IAAZ,KAAqB;AAChEnD,QAAAA,SAAS,GAAG,KAAKb,SAAL,CAAe4U,kBAAf,CAAkC/T,SAAlC,CAAZ;;AAEA,YAAIA,SAAS,CAACqL,IAAV,KAAmB/I,SAAvB,EAAkC;AAChC,gBAAM,IAAI6D,KAAJ,CAAW,wCAAuC,KAAKhD,IAAK,IAAGA,IAAK,GAApE,CAAN;AACD;;AAED,YAAInD,SAAS,CAACoN,SAAV,KAAwB,KAAxB,IAAiCvP,CAAC,CAACgF,GAAF,CAAM7C,SAAN,EAAiB,kBAAjB,CAArC,EAA2E;AACzE,gBAAM,IAAImG,KAAJ,CAAW,2BAA0B,KAAKhD,IAAK,IAAGA,IAAK,+DAAvD,CAAN;AACD;;AAED,YAAItF,CAAC,CAACgF,GAAF,CAAM7C,SAAN,EAAiB,4BAAjB,aAA0Df,KAA9D,EAAqE;AACnEe,UAAAA,SAAS,CAACgU,UAAV,CAAqBrO,KAArB,GAA6B3F,SAAS,CAACgU,UAAV,CAAqBrO,KAArB,CAA2ByD,YAA3B,EAA7B;AACD;;AAED,eAAOpJ,SAAP;AACD,OAhBoB,CAArB;AAkBA,YAAMiN,SAAS,GAAG,KAAK7D,YAAL,EAAlB;AACA,WAAK6K,QAAL,GAAgB,KAAKzU,OAAL,CAAasT,OAAb,CACb/S,GADa,CACT0R,KAAK,IAAI1T,KAAK,CAACmW,SAAN,CAAgB,KAAKC,aAAL,CAAmB1C,KAAnB,CAAhB,EAA2CxE,SAA3C,CADA,CAAhB;AAGA,WAAKS,WAAL,GAAmB,EAAnB;AACA,WAAKxI,mBAAL,GAA2B,IAAInG,GAAJ,EAA3B;AACA,WAAKgD,oBAAL,GAA4B,EAA5B,CArGoC,CAuGpC;;AACA,UAAI,KAAKvC,OAAL,CAAaiN,UAAjB,EAA6B;AAC3B,YAAI,KAAKjN,OAAL,CAAawC,SAAb,KAA2B,KAA/B,EAAsC;AACpC,eAAKD,oBAAL,CAA0BC,SAA1B,GAAsC,KAAKxC,OAAL,CAAawC,SAAb,IAA0B,WAAhE;;AACA,eAAKkD,mBAAL,CAAyBkP,GAAzB,CAA6B,KAAKrS,oBAAL,CAA0BC,SAAvD;AACD;;AACD,YAAI,KAAKxC,OAAL,CAAa2C,SAAb,KAA2B,KAA/B,EAAsC;AACpC,eAAKJ,oBAAL,CAA0BI,SAA1B,GAAsC,KAAK3C,OAAL,CAAa2C,SAAb,IAA0B,WAAhE;;AACA,eAAK+C,mBAAL,CAAyBkP,GAAzB,CAA6B,KAAKrS,oBAAL,CAA0BI,SAAvD;AACD;;AACD,YAAI,KAAK3C,OAAL,CAAakN,QAAb,IAAyB,KAAKlN,OAAL,CAAa4C,SAAb,KAA2B,KAAxD,EAA+D;AAC7D,eAAKL,oBAAL,CAA0BK,SAA1B,GAAsC,KAAK5C,OAAL,CAAa4C,SAAb,IAA0B,WAAhE;;AACA,eAAK8C,mBAAL,CAAyBkP,GAAzB,CAA6B,KAAKrS,oBAAL,CAA0BK,SAAvD;AACD;AACF,OArHmC,CAuHpC;;;AACA,UAAI,KAAK5C,OAAL,CAAa6U,OAAjB,EAA0B;AACxB,aAAKpR,iBAAL,GAAyB,OAAO,KAAKzD,OAAL,CAAa6U,OAApB,KAAgC,QAAhC,GAA2C,KAAK7U,OAAL,CAAa6U,OAAxD,GAAkE,SAA3F;;AACA,aAAKnP,mBAAL,CAAyBkP,GAAzB,CAA6B,KAAKnR,iBAAlC;AACD;;AAED,WAAKgC,sBAAL,GAA8B,KAAKC,mBAAL,CAAyBpC,IAAzB,GAAgC,CAA9D,CA7HoC,CA+HpC;;AACA,WAAKwR,qBAAL;;AACA,WAAKC,iBAAL;;AACA,WAAKC,2BAAL;;AAEA,WAAKC,MAAL,GAAc,KAAKjV,OAAL,CAAa6T,YAA3B;AACA,WAAKqB,WAAL,GAAmB,CAAC,cAAD,CAAnB;AAEA,WAAKvV,SAAL,CAAeqU,YAAf,CAA4BmB,QAA5B,CAAqC,IAArC;AACA,WAAKxV,SAAL,CAAe8I,QAAf,CAAwB,aAAxB,EAAuC,IAAvC;AAEA,aAAO,IAAP;AACD;;;wCAE0B;AACzB,YAAM2M,qBAAqB,GAAG,EAA9B;AAEA,WAAKhT,SAAL,CAAe2B,cAAf,GAAgC,EAAhC;AACA,WAAK3B,SAAL,CAAe0C,cAAf,GAAgC,EAAhC;AAEA,OAAC,KAAD,EAAQ,KAAR,EAAe5C,OAAf,CAAuB2J,IAAI,IAAI;AAC7B,cAAMwJ,GAAG,GAAI,GAAExJ,IAAK,YAApB;;AACA,cAAMyJ,KAAK,GAAGjX,CAAC,CAACmD,KAAF,CAAQnD,CAAC,CAACkX,QAAF,CAAW,KAAKvV,OAAL,CAAaqV,GAAb,CAAX,IAAgC,KAAKrV,OAAL,CAAaqV,GAAb,CAAhC,GAAoD,EAA5D,CAAd;;AACA,cAAMG,OAAO,GAAG3J,IAAI,KAAK,KAAT,GAAiB,KAAKzJ,SAAL,CAAe2B,cAAhC,GAAiD,KAAK3B,SAAL,CAAe0C,cAAhF;;AAEAzG,QAAAA,CAAC,CAAC4P,IAAF,CAAOqH,KAAP,EAAc,CAACG,MAAD,EAASjV,SAAT,KAAuB;AACnCgV,UAAAA,OAAO,CAAChV,SAAD,CAAP,GAAqBiV,MAArB;;AAEA,cAAI5J,IAAI,KAAK,KAAb,EAAoB;AAClByJ,YAAAA,KAAK,CAAC9U,SAAD,CAAL,GAAmB,YAAW;AAC5B,qBAAO,KAAK6C,GAAL,CAAS7C,SAAT,CAAP;AACD,aAFD;AAGD;;AACD,cAAIqL,IAAI,KAAK,KAAb,EAAoB;AAClByJ,YAAAA,KAAK,CAAC9U,SAAD,CAAL,GAAmB,UAASqB,KAAT,EAAgB;AACjC,qBAAO,KAAKkB,GAAL,CAASvC,SAAT,EAAoBqB,KAApB,CAAP;AACD,aAFD;AAGD;AACF,SAbD;;AAeAxD,QAAAA,CAAC,CAAC4P,IAAF,CAAO,KAAKlH,aAAZ,EAA2B,CAAC/G,OAAD,EAAUQ,SAAV,KAAwB;AACjD,cAAIP,MAAM,CAACmC,SAAP,CAAiBC,cAAjB,CAAgCC,IAAhC,CAAqCtC,OAArC,EAA8C6L,IAA9C,CAAJ,EAAyD;AACvD2J,YAAAA,OAAO,CAAChV,SAAD,CAAP,GAAqBR,OAAO,CAAC6L,IAAD,CAA5B;AACD;;AAED,cAAIA,IAAI,KAAK,KAAb,EAAoB;AAClByJ,YAAAA,KAAK,CAAC9U,SAAD,CAAL,GAAmB,YAAW;AAC5B,qBAAO,KAAK6C,GAAL,CAAS7C,SAAT,CAAP;AACD,aAFD;AAGD;;AACD,cAAIqL,IAAI,KAAK,KAAb,EAAoB;AAClByJ,YAAAA,KAAK,CAAC9U,SAAD,CAAL,GAAmB,UAASqB,KAAT,EAAgB;AACjC,qBAAO,KAAKkB,GAAL,CAASvC,SAAT,EAAoBqB,KAApB,CAAP;AACD,aAFD;AAGD;AACF,SAfD;;AAiBAxD,QAAAA,CAAC,CAAC4P,IAAF,CAAOqH,KAAP,EAAc,CAACI,GAAD,EAAM/R,IAAN,KAAe;AAC3B,cAAI,CAACyR,qBAAqB,CAACzR,IAAD,CAA1B,EAAkC;AAChCyR,YAAAA,qBAAqB,CAACzR,IAAD,CAArB,GAA8B;AAC5BgS,cAAAA,YAAY,EAAE;AADc,aAA9B;AAGD;;AACDP,UAAAA,qBAAqB,CAACzR,IAAD,CAArB,CAA4BkI,IAA5B,IAAoC6J,GAApC;AACD,SAPD;AAQD,OA7CD;AA+CA,WAAK9P,gBAAL,GAAwB,EAAxB;AACA,WAAKD,mBAAL,GAA2B,EAA3B;AAEA,WAAKnB,qBAAL,GAA6B,KAA7B;AACA,WAAKD,kBAAL,GAA0B,KAA1B;AACA,WAAKW,eAAL,GAAuB,IAAI3F,GAAJ,EAAvB;AACA,WAAKsF,kBAAL,GAA0B,IAAItF,GAAJ,EAA1B;AACA,WAAKoC,cAAL,GAAsB,EAAtB;AACA,WAAKS,SAAL,CAAe0K,UAAf,GAA4B,EAA5B;AAEA,WAAK8I,qBAAL,GAA6B,EAA7B;AAEA,WAAK1H,WAAL,GAAmB,EAAnB;AACA,WAAK2H,UAAL,GAAkB,EAAlB;;AAEAxX,MAAAA,CAAC,CAAC4P,IAAF,CAAO,KAAKlH,aAAZ,EAA2B,CAACqH,UAAD,EAAazK,IAAb,KAAsB;AAC/CyK,QAAAA,UAAU,CAACvC,IAAX,GAAkB,KAAKlM,SAAL,CAAemW,iBAAf,CAAiC1H,UAAU,CAACvC,IAA5C,CAAlB;AAEAuC,QAAAA,UAAU,CAAC3O,KAAX,GAAmB,IAAnB;AACA2O,QAAAA,UAAU,CAAC2H,SAAX,GAAuBpS,IAAvB;AACAyK,QAAAA,UAAU,CAAC4H,eAAX,GAA6B,IAA7B;;AAEA,YAAI5H,UAAU,CAAC7E,KAAX,KAAqBzG,SAAzB,EAAoC;AAClCsL,UAAAA,UAAU,CAAC7E,KAAX,GAAmBhL,KAAK,CAAC6V,aAAN,CAAoBzQ,IAApB,EAA0B,KAAK+P,WAA/B,CAAnB;AACD;;AAED,YAAItF,UAAU,CAACP,UAAX,KAA0B,IAA9B,EAAoC;AAClC,eAAKK,WAAL,CAAiBvK,IAAjB,IAAyByK,UAAzB;AACD;;AAED,aAAKwH,qBAAL,CAA2BxH,UAAU,CAAC7E,KAAtC,IAA+C6E,UAA/C;;AAEA,YAAIA,UAAU,CAACvC,IAAX,CAAgBoK,SAApB,EAA+B;AAC7B,eAAKtQ,mBAAL,CAAyBhC,IAAzB,IAAiCyK,UAAU,CAACvC,IAAX,CAAgBoK,SAAjD;AACD;;AAED,YAAI7H,UAAU,CAACvC,IAAX,CAAgBqK,UAApB,EAAgC;AAC9B,eAAKtQ,gBAAL,CAAsBjC,IAAtB,IAA8ByK,UAAU,CAACvC,IAAX,CAAgBqK,UAA9C;AACD;;AAED,YAAI9H,UAAU,CAACvC,IAAX,YAA2B5M,SAAS,CAACkX,OAAzC,EAAkD;AAChD,eAAK3R,qBAAL,GAA6B,IAA7B;AACD,SAFD,MAEO,IAAI4J,UAAU,CAACvC,IAAX,YAA2B5M,SAAS,CAAC8O,IAArC,IAA6CK,UAAU,CAACvC,IAAX,YAA2B5M,SAAS,CAACmX,QAAtF,EAAgG;AACrG,eAAK7R,kBAAL,GAA0B,IAA1B;AACD,SAFM,MAEA,IAAI6J,UAAU,CAACvC,IAAX,YAA2B5M,SAAS,CAACoX,IAAzC,EAA+C;AACpD,eAAKnR,eAAL,CAAqB0P,GAArB,CAAyBjR,IAAzB;AACD,SAFM,MAEA,IAAIyK,UAAU,CAACvC,IAAX,YAA2B5M,SAAS,CAACqX,OAAzC,EAAkD;AACvD,eAAKzR,kBAAL,CAAwB+P,GAAxB,CAA4BjR,IAA5B;AACD;;AAED,YAAI1D,MAAM,CAACmC,SAAP,CAAiBC,cAAjB,CAAgCC,IAAhC,CAAqC8L,UAArC,EAAiD,cAAjD,CAAJ,EAAsE;AACpE,eAAKzM,cAAL,CAAoBgC,IAApB,IAA4B,MAAMpF,KAAK,CAACkE,cAAN,CAAqB2L,UAAU,CAACvG,YAAhC,EAA8C,KAAKlI,SAAL,CAAeK,OAAf,CAAuB0C,OAArE,CAAlC;AACD;;AAED,YAAIzC,MAAM,CAACmC,SAAP,CAAiBC,cAAjB,CAAgCC,IAAhC,CAAqC8L,UAArC,EAAiD,QAAjD,KAA8DA,UAAU,CAACiE,MAA7E,EAAqF;AACnF,cAAIkE,OAAJ;;AACA,cACE,OAAOnI,UAAU,CAACiE,MAAlB,KAA6B,QAA7B,IACApS,MAAM,CAACmC,SAAP,CAAiBC,cAAjB,CAAgCC,IAAhC,CAAqC8L,UAAU,CAACiE,MAAhD,EAAwD,MAAxD,CAFF,EAGE;AACAkE,YAAAA,OAAO,GAAGnI,UAAU,CAACiE,MAAX,CAAkB1O,IAA5B;AACD,WALD,MAKO,IAAI,OAAOyK,UAAU,CAACiE,MAAlB,KAA6B,QAAjC,EAA2C;AAChDkE,YAAAA,OAAO,GAAGnI,UAAU,CAACiE,MAArB;AACD,WAFM,MAEA;AACLkE,YAAAA,OAAO,GAAI,GAAE,KAAK9I,SAAU,IAAG9J,IAAK,SAApC;AACD;;AAED,gBAAM6S,GAAG,GAAG,KAAKX,UAAL,CAAgBU,OAAhB,KAA4B;AAAEzP,YAAAA,MAAM,EAAE;AAAV,WAAxC;AAEA0P,UAAAA,GAAG,CAAC1P,MAAJ,CAAWW,IAAX,CAAgB2G,UAAU,CAAC7E,KAA3B;AACAiN,UAAAA,GAAG,CAACC,GAAJ,GAAUD,GAAG,CAACC,GAAJ,IAAWrI,UAAU,CAACiE,MAAX,CAAkBoE,GAA7B,IAAoC,IAA9C;AACAD,UAAAA,GAAG,CAAC7S,IAAJ,GAAW4S,OAAO,IAAI,KAAtB;AACAC,UAAAA,GAAG,CAACE,MAAJ,GAAa/S,IAAb;AACA6S,UAAAA,GAAG,CAACG,WAAJ,GAAkBvI,UAAU,CAACiE,MAAX,KAAsB,IAAxC;AAEA,eAAKwD,UAAL,CAAgBU,OAAhB,IAA2BC,GAA3B;AACD;;AAED,YAAIvW,MAAM,CAACmC,SAAP,CAAiBC,cAAjB,CAAgCC,IAAhC,CAAqC8L,UAArC,EAAiD,UAAjD,CAAJ,EAAkE;AAChE,eAAKhM,SAAL,CAAe0K,UAAf,CAA0BnJ,IAA1B,IAAkCyK,UAAU,CAACvH,QAA7C;AACD;;AAED,YAAIuH,UAAU,CAAC6D,KAAX,KAAqB,IAArB,IAA6B7D,UAAU,CAACvC,IAAX,YAA2B5M,SAAS,CAAC2X,KAAtE,EAA6E;AAC3E,eAAKnC,QAAL,CAAchN,IAAd,CACElJ,KAAK,CAACmW,SAAN,CACE,KAAKC,aAAL,CAAmB;AACjB7N,YAAAA,MAAM,EAAE,CAACsH,UAAU,CAAC7E,KAAX,IAAoB5F,IAArB,CADS;AAEjBkT,YAAAA,KAAK,EAAE;AAFU,WAAnB,CADF,EAKE,KAAKjN,YAAL,EALF,CADF;;AAUA,iBAAOwE,UAAU,CAAC6D,KAAlB;AACD;AACF,OAhFD,EApEyB,CAsJzB;;;AACA,WAAK6E,iBAAL,GAAyBzY,CAAC,CAAC8E,MAAF,CAAS,KAAKyS,qBAAd,EAAqC,CAACrV,GAAD,EAAMsB,KAAN,EAAaN,GAAb,KAAqB;AACjF,YAAIA,GAAG,KAAKM,KAAK,CAACkU,SAAlB,EAA6B;AAC3BxV,UAAAA,GAAG,CAACgB,GAAD,CAAH,GAAWM,KAAK,CAACkU,SAAjB;AACD;;AACD,eAAOxV,GAAP;AACD,OALwB,EAKtB,EALsB,CAAzB;AAOA,WAAKwW,kBAAL,GAA0B,CAAC,CAAC,KAAK7R,eAAL,CAAqB5B,IAAjD;AAEA,WAAKsB,qBAAL,GAA6B,CAAC,CAAC,KAAKC,kBAAL,CAAwBvB,IAAvD;AAEA,WAAK7B,iBAAL,GAAyB,CAACpD,CAAC,CAACiI,OAAF,CAAU,KAAK3E,cAAf,CAA1B;AAEA,WAAK0P,eAAL,GAAuBhT,CAAC,CAAC2M,MAAF,CAAS,KAAKjE,aAAd,EAA6B,CAACiQ,EAAD,EAAKzV,GAAL,KAAa,KAAKsD,kBAAL,CAAwBM,GAAxB,CAA4B5D,GAA5B,CAA1C,CAAvB;AAEA,WAAKa,SAAL,CAAegC,iBAAf,GAAmCnE,MAAM,CAAC4C,IAAP,CAAY,KAAKT,SAAL,CAAe2B,cAA3B,EAA2C9B,MAA9E;AACA,WAAKG,SAAL,CAAe6U,iBAAf,GAAmChX,MAAM,CAAC4C,IAAP,CAAY,KAAKT,SAAL,CAAe0C,cAA3B,EAA2C7C,MAA9E;;AAEA,WAAK,MAAMV,GAAX,IAAkBtB,MAAM,CAAC4C,IAAP,CAAYuS,qBAAZ,CAAlB,EAAsD;AACpD,YAAInV,MAAM,CAACmC,SAAP,CAAiBC,cAAjB,CAAgCC,IAAhC,CAAqC7C,KAAK,CAAC2C,SAA3C,EAAsDb,GAAtD,CAAJ,EAAgE;AAC9D,eAAK5B,SAAL,CAAeuX,GAAf,CAAoB,wDAAuD3V,GAAI,EAA/E;AACA;AACD;;AACDtB,QAAAA,MAAM,CAACuT,cAAP,CAAsB,KAAKpR,SAA3B,EAAsCb,GAAtC,EAA2C6T,qBAAqB,CAAC7T,GAAD,CAAhE;AACD;;AAED,WAAKa,SAAL,CAAe2E,aAAf,GAA+B,KAAKA,aAApC;;AACA,WAAK3E,SAAL,CAAe6C,YAAf,GAA8B1D,GAAG,IAAItB,MAAM,CAACmC,SAAP,CAAiBC,cAAjB,CAAgCC,IAAhC,CAAqC,KAAKF,SAAL,CAAe2E,aAApD,EAAmExF,GAAnE,CAArC,CAlLyB,CAoLzB;;;AACA,WAAKS,oBAAL,GAA4B/B,MAAM,CAAC4C,IAAP,CAAY,KAAKqL,WAAjB,CAA5B;AACA,WAAK/L,mBAAL,GAA2B,KAAKH,oBAAL,CAA0B,CAA1B,CAA3B;;AACA,UAAI,KAAKG,mBAAT,EAA8B;AAC5B,aAAKgV,eAAL,GAAuB,KAAKpQ,aAAL,CAAmB,KAAK5E,mBAAxB,EAA6CoH,KAA7C,IAAsD,KAAKpH,mBAAlF;AACD;;AAED,WAAKoD,eAAL,GAAuB,KAAKvD,oBAAL,CAA0BC,MAA1B,GAAmC,CAA1D;;AACA,WAAKuD,aAAL,GAAqBjE,GAAG,IAAI,KAAKS,oBAAL,CAA0BkC,QAA1B,CAAmC3C,GAAnC,CAA5B;AACD;AAED;AACF;AACA;AACA;AACA;;;;oCACyBf,S,EAAW;AAChC,aAAO,KAAKuG,aAAL,CAAmBvG,SAAnB,CAAP;AACA,WAAKuU,iBAAL;AACD;AAED;AACF;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;yBACc/U,O,EAAS;AACnBA,MAAAA,OAAO,GAAGC,MAAM,CAACC,MAAP,CAAc,EAAd,EAAkB,KAAKF,OAAvB,EAAgCA,OAAhC,CAAV;AACAA,MAAAA,OAAO,CAAC4G,KAAR,GAAgB5G,OAAO,CAAC4G,KAAR,KAAkB9D,SAAlB,GAA8B,IAA9B,GAAqC,CAAC,CAAC9C,OAAO,CAAC4G,KAA/D;AAEA,YAAMtG,UAAU,GAAG,KAAK+Q,eAAxB;AACA,YAAMtK,aAAa,GAAG,KAAK6O,qBAA3B;AAEA,aAAO9W,OAAO,CAACkJ,GAAR,CAAY,MAAM;AACvB,YAAIhI,OAAO,CAAC4G,KAAZ,EAAmB;AACjB,iBAAO,KAAK6B,QAAL,CAAc,YAAd,EAA4BzI,OAA5B,CAAP;AACD;AACF,OAJM,EAIJiI,IAJI,CAIC,MAAM;AACZ,YAAIjI,OAAO,CAACqL,KAAZ,EAAmB;AACjB,iBAAO,KAAK+L,IAAL,CAAUpX,OAAV,CAAP;AACD;AACF,OARM,EASJiI,IATI,CASC,MAAM,KAAKpI,cAAL,CAAoBwX,WAApB,CAAgC,KAAKzN,YAAL,CAAkB5J,OAAlB,CAAhC,EAA4DM,UAA5D,EAAwEN,OAAxE,EAAiF,IAAjF,CATP,EAUJiI,IAVI,CAUC,MAAM;AACV,YAAI,CAACjI,OAAO,CAACsX,KAAb,EAAoB;AAClB;AACD;;AACD,eAAOxY,OAAO,CAAC+P,GAAR,CAAY,CACjB,KAAKhP,cAAL,CAAoB0X,aAApB,CAAkC,KAAK3N,YAAL,CAAkB5J,OAAlB,CAAlC,CADiB,EAEjB,KAAKH,cAAL,CAAoB2X,+BAApB,CAAoD,KAAK5N,YAAL,CAAkB5J,OAAlB,CAApD,CAFiB,CAAZ,EAIJiI,IAJI,CAICwP,UAAU,IAAI;AAClB,gBAAMC,OAAO,GAAGD,UAAU,CAAC,CAAD,CAA1B,CADkB,CAElB;;AACA,gBAAME,oBAAoB,GAAGF,UAAU,CAAC,CAAD,CAAvC;AAEA,gBAAMG,OAAO,GAAG,EAAhB,CALkB,CAKE;;AACpB,gBAAMC,kBAAkB,GAAG,EAA3B;;AAEAxZ,UAAAA,CAAC,CAAC4P,IAAF,CAAO3N,UAAP,EAAmB,CAACwX,UAAD,EAAaC,UAAb,KAA4B;AAC7C,gBAAI,CAACL,OAAO,CAACK,UAAD,CAAR,IAAwB,CAACL,OAAO,CAACpX,UAAU,CAACyX,UAAD,CAAV,CAAuBxO,KAAxB,CAApC,EAAoE;AAClEqO,cAAAA,OAAO,CAACnQ,IAAR,CAAa,MAAM,KAAK5H,cAAL,CAAoBmY,SAApB,CAA8B,KAAKpO,YAAL,CAAkB5J,OAAlB,CAA9B,EAA0DM,UAAU,CAACyX,UAAD,CAAV,CAAuBxO,KAAvB,IAAgCwO,UAA1F,EAAsGzX,UAAU,CAACyX,UAAD,CAAhH,CAAnB;AACD;AACF,WAJD;;AAKA1Z,UAAAA,CAAC,CAAC4P,IAAF,CAAOyJ,OAAP,EAAgB,CAACI,UAAD,EAAaC,UAAb,KAA4B;AAC1C,kBAAME,gBAAgB,GAAGlR,aAAa,CAACgR,UAAD,CAAtC;;AACA,gBAAI,CAACE,gBAAL,EAAuB;AACrBL,cAAAA,OAAO,CAACnQ,IAAR,CAAa,MAAM,KAAK5H,cAAL,CAAoBqY,YAApB,CAAiC,KAAKtO,YAAL,CAAkB5J,OAAlB,CAAjC,EAA6D+X,UAA7D,EAAyE/X,OAAzE,CAAnB;AACD,aAFD,MAEO,IAAI,CAACiY,gBAAgB,CAACpK,UAAtB,EAAkC;AACvC;AACA,oBAAM2G,UAAU,GAAGyD,gBAAgB,CAACzD,UAApC;;AACA,kBAAIyD,gBAAgB,CAACzD,UAArB,EAAiC;AAC/B,sBAAM2D,QAAQ,GAAG,KAAKxY,SAAL,CAAeyY,MAAf,CAAsBD,QAAvC;AACA,sBAAM5E,MAAM,GAAG,KAAK5T,SAAL,CAAeyY,MAAf,CAAsB7E,MAArC,CAF+B,CAG/B;;AACAlV,gBAAAA,CAAC,CAAC4P,IAAF,CAAO0J,oBAAP,EAA6BU,mBAAmB,IAAI;AAClD,wBAAMC,cAAc,GAAGD,mBAAmB,CAACC,cAA3C;;AACA,sBAAI,CAAC,CAACA,cAAF,IACCD,mBAAmB,CAACE,YAApB,KAAqCJ,QADtC,KAEE5E,MAAM,GAAG8E,mBAAmB,CAACG,WAApB,KAAoCjF,MAAvC,GAAgD,IAFxD,KAGC8E,mBAAmB,CAACI,mBAApB,KAA4CjE,UAAU,CAACrO,KAHxD,IAICkS,mBAAmB,CAACK,oBAApB,KAA6ClE,UAAU,CAACjT,GAJzD,KAKEgS,MAAM,GAAG8E,mBAAmB,CAACM,qBAApB,KAA8CpF,MAAjD,GAA0D,IALlE,KAMC,CAACsE,kBAAkB,CAACS,cAAD,CANxB,EAM0C;AACxC;AACAV,oBAAAA,OAAO,CAACnQ,IAAR,CAAa,MAAM,KAAK5H,cAAL,CAAoB+Y,gBAApB,CAAqC,KAAKhP,YAAL,CAAkB5J,OAAlB,CAArC,EAAiEsY,cAAjE,EAAiFtY,OAAjF,CAAnB;AACA6X,oBAAAA,kBAAkB,CAACS,cAAD,CAAlB,GAAqC,IAArC;AACD;AACF,iBAbD;AAcD;;AACDV,cAAAA,OAAO,CAACnQ,IAAR,CAAa,MAAM,KAAK5H,cAAL,CAAoBgZ,YAApB,CAAiC,KAAKjP,YAAL,CAAkB5J,OAAlB,CAAjC,EAA6D+X,UAA7D,EAAyEE,gBAAzE,CAAnB;AACD;AACF,WA5BD;;AA6BA,iBAAOnZ,OAAO,CAACmP,IAAR,CAAa2J,OAAb,EAAsBkB,CAAC,IAAIA,CAAC,EAA5B,CAAP;AACD,SA/CI,CAAP;AAgDD,OA9DI,EA+DJ7Q,IA/DI,CA+DC,MAAM,KAAKpI,cAAL,CAAoBkZ,SAApB,CAA8B,KAAKnP,YAAL,CAAkB5J,OAAlB,CAA9B,EAA0DA,OAA1D,CA/DP,EAgEJiI,IAhEI,CAgECqL,OAAO,IAAI;AACfA,QAAAA,OAAO,GAAG,KAAKmB,QAAL,CAAc3O,MAAd,CAAqBkT,KAAK,IAClC,CAAC1F,OAAO,CAAC1G,IAAR,CAAaqM,KAAK,IAAID,KAAK,CAACrV,IAAN,KAAesV,KAAK,CAACtV,IAA3C,CADO,EAERuV,IAFQ,CAEH,CAACC,MAAD,EAASC,MAAT,KAAoB;AACzB,cAAI,KAAKzZ,SAAL,CAAeK,OAAf,CAAuB0C,OAAvB,KAAmC,UAAvC,EAAmD;AACnD;AACE,gBAAIyW,MAAM,CAACE,YAAP,KAAwB,IAA5B,EAAkC,OAAO,CAAP;AAClC,gBAAID,MAAM,CAACC,YAAP,KAAwB,IAA5B,EAAkC,OAAO,CAAC,CAAR;AACnC;;AAED,iBAAO,CAAP;AACD,SAVS,CAAV;AAYA,eAAOva,OAAO,CAACmP,IAAR,CAAaqF,OAAb,EAAsBrB,KAAK,IAAI,KAAKpS,cAAL,CAAoByZ,QAApB,CACpC,KAAK1P,YAAL,CAAkB5J,OAAlB,CADoC,EAEpCC,MAAM,CAACC,MAAP,CAAc;AACZgJ,UAAAA,OAAO,EAAElJ,OAAO,CAACkJ,OADL;AAEZqQ,UAAAA,SAAS,EAAEvZ,OAAO,CAACuZ,SAFP;AAGZtQ,UAAAA,WAAW,EAAEjJ,OAAO,CAACiJ,WAHT;AAIZsK,UAAAA,MAAM,EAAEvT,OAAO,CAACuT;AAJJ,SAAd,EAKGtB,KALH,CAFoC,EAQpC,KAAKxE,SAR+B,CAA/B,CAAP;AAUD,OAvFI,EAuFFxF,IAvFE,CAuFG,MAAM;AACZ,YAAIjI,OAAO,CAAC4G,KAAZ,EAAmB;AACjB,iBAAO,KAAK6B,QAAL,CAAc,WAAd,EAA2BzI,OAA3B,CAAP;AACD;AACF,OA3FI,EA2FFuM,MA3FE,CA2FK,IA3FL,CAAP;AA4FD;AAED;AACF;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;yBACcvM,O,EAAS;AACnB,aAAO,KAAKH,cAAL,CAAoB2Z,SAApB,CAA8B,KAAK5P,YAAL,CAAkB5J,OAAlB,CAA9B,EAA0DA,OAA1D,CAAP;AACD;;;+BAEiBuT,M,EAAQ;AACxB,aAAO,KAAK1T,cAAL,CAAoB4Z,UAApB,CAA+BlG,MAA/B,CAAP;AACD;AAED;AACF;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;2BACgBA,O,EAAQvT,O,EAAS;AAE7B,YAAMwB,KAAK;AAAA;;AAAA;;AAAA;AAAA;;AAAA;AAAA;;AAAA;AAAA,QAAiB,IAAjB,CAAX;;AACAvB,MAAAA,MAAM,CAACuT,cAAP,CAAsBhS,KAAtB,EAA6B,MAA7B,EAAqC;AAAEK,QAAAA,KAAK,EAAE,KAAK8B;AAAd,OAArC;AAEAnC,MAAAA,KAAK,CAACpB,OAAN,GAAgBmT,OAAhB;;AAEA,UAAIvT,OAAJ,EAAa;AACX,YAAI,OAAOA,OAAP,KAAmB,QAAvB,EAAiC;AAC/BwB,UAAAA,KAAK,CAACnB,gBAAN,GAAyBL,OAAzB;AACD,SAFD,MAEO,IAAIA,OAAO,CAAC4T,eAAZ,EAA6B;AAClCpS,UAAAA,KAAK,CAACnB,gBAAN,GAAyBL,OAAO,CAAC4T,eAAjC;AACD;AACF;;AAED,aAAOpS,KAAP;AACD;AAED;AACF;AACA;AACA;AACA;AACA;;;;mCACwB;AACpB,aAAO,KAAK1B,cAAL,CAAoB4Z,SAApB,CAA8B,IAA9B,CAAP;AACD;AAED;AACF;AACA;AACA;AACA;;;;+BACoB;AAChB,aAAO,KAAKlP,KAAL,EAAP;AACD;AAED;AACF;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;6BACkB7G,I,EAAM6G,K,EAAOxK,O,EAAS;AACpCA,MAAAA,OAAO,GAAGC,MAAM,CAACC,MAAP,CAAc;AACtByZ,QAAAA,QAAQ,EAAE;AADY,OAAd,EAEP3Z,OAFO,CAAV;;AAIA,UAAI,CAAC2D,IAAI,KAAK,cAAT,IAA2B1D,MAAM,CAAC4C,IAAP,CAAY,KAAK7C,OAAL,CAAa6T,YAAzB,EAAuC5R,MAAvC,GAAgD,CAA3E,IAAgF0B,IAAI,IAAI,KAAK3D,OAAL,CAAa8T,MAAtG,KAAiH9T,OAAO,CAAC2Z,QAAR,KAAqB,KAA1I,EAAiJ;AAC/I,cAAM,IAAIhT,KAAJ,CAAW,aAAYhD,IAAK,2EAA5B,CAAN;AACD;;AAED,UAAIA,IAAI,KAAK,cAAb,EAA6B;AAC3B,aAAK3D,OAAL,CAAa6T,YAAb,GAA4B,KAAKoB,MAAL,GAAczK,KAA1C;AACD,OAFD,MAEO;AACL,aAAKxK,OAAL,CAAa8T,MAAb,CAAoBnQ,IAApB,IAA4B6G,KAA5B;AACD;AACF;AAED;AACF;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;0BACeoP,M,EAAQ;AACnB,YAAMvL,IAAI;AAAA;;AAAA;;AAAA;AAAA;;AAAA;AAAA;;AAAA;AAAA,QAAiB,IAAjB,CAAV;;AACA,UAAI7D,KAAJ;AACA,UAAIqP,SAAJ;AAEA5Z,MAAAA,MAAM,CAACuT,cAAP,CAAsBnF,IAAtB,EAA4B,MAA5B,EAAoC;AAAExM,QAAAA,KAAK,EAAE,KAAK8B;AAAd,OAApC;AAEA0K,MAAAA,IAAI,CAAC4G,MAAL,GAAc,EAAd;AACA5G,MAAAA,IAAI,CAAC6G,WAAL,GAAmB,EAAnB;AACA7G,MAAAA,IAAI,CAACkD,MAAL,GAAc,IAAd;;AAEA,UAAI,CAACqI,MAAL,EAAa;AACX,eAAOvL,IAAP;AACD;;AAED,YAAMrO,OAAO,GAAG3B,CAAC,CAACyb,OAAF,CAAUpT,SAAV,CAAhB;;AAEA,WAAK,MAAMkT,MAAX,IAAqB5Z,OAArB,EAA8B;AAC5BwK,QAAAA,KAAK,GAAG,IAAR;AACAqP,QAAAA,SAAS,GAAG,IAAZ;;AAEA,YAAIxb,CAAC,CAACuQ,aAAF,CAAgBgL,MAAhB,CAAJ,EAA6B;AAC3B,cAAIA,MAAM,CAACnE,MAAX,EAAmB;AACjB,gBAAIhV,KAAK,CAACC,OAAN,CAAckZ,MAAM,CAACnE,MAArB,KAAgC,CAAC,CAACpH,IAAI,CAACrO,OAAL,CAAa8T,MAAb,CAAoB8F,MAAM,CAACnE,MAAP,CAAc,CAAd,CAApB,CAAtC,EAA6E;AAC3EoE,cAAAA,SAAS,GAAGD,MAAM,CAACnE,MAAP,CAAc,CAAd,CAAZ;AACAjL,cAAAA,KAAK,GAAG6D,IAAI,CAACrO,OAAL,CAAa8T,MAAb,CAAoB+F,SAApB,EAA+BE,KAA/B,CAAqC1L,IAArC,EAA2CuL,MAAM,CAACnE,MAAP,CAAcuE,KAAd,CAAoB,CAApB,CAA3C,CAAR;AACD,aAHD,MAIK,IAAI3L,IAAI,CAACrO,OAAL,CAAa8T,MAAb,CAAoB8F,MAAM,CAACnE,MAA3B,CAAJ,EAAwC;AAC3CoE,cAAAA,SAAS,GAAGD,MAAM,CAACnE,MAAnB;AACAjL,cAAAA,KAAK,GAAG6D,IAAI,CAACrO,OAAL,CAAa8T,MAAb,CAAoB+F,SAApB,EAA+BE,KAA/B,CAAqC1L,IAArC,CAAR;AACD;AACF,WATD,MASO;AACL7D,YAAAA,KAAK,GAAGoP,MAAR;AACD;AACF,SAbD,MAaO,IAAIA,MAAM,KAAK,cAAX,IAA6Bvb,CAAC,CAACuQ,aAAF,CAAgBP,IAAI,CAACrO,OAAL,CAAa6T,YAA7B,CAAjC,EAA6E;AAClFrJ,UAAAA,KAAK,GAAG6D,IAAI,CAACrO,OAAL,CAAa6T,YAArB;AACD,SAFM,MAEA;AACLgG,UAAAA,SAAS,GAAGD,MAAZ;AACApP,UAAAA,KAAK,GAAG6D,IAAI,CAACrO,OAAL,CAAa8T,MAAb,CAAoB+F,SAApB,CAAR;;AACA,cAAI,OAAOrP,KAAP,KAAiB,UAArB,EAAiC;AAC/BA,YAAAA,KAAK,GAAGA,KAAK,EAAb;AACD;AACF;;AAED,YAAIA,KAAJ,EAAW;AACT,eAAK5J,gBAAL,CAAsB4J,KAAtB,EAA6B,IAA7B;;AACA,eAAK+H,cAAL,CAAoBlE,IAAI,CAAC4G,MAAzB,EAAiCzK,KAAjC;;AACA6D,UAAAA,IAAI,CAAC6G,WAAL,CAAiBzN,IAAjB,CAAsBoS,SAAS,GAAGA,SAAH,GAAe,cAA9C;AACD,SAJD,MAIO;AACL,gBAAM,IAAIhb,eAAe,CAACob,mBAApB,CAAyC,iBAAgBJ,SAAU,UAAnE,CAAN;AACD;AACF;;AAED,aAAOxL,IAAP;AACD;AAED;AACF;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;4BACiBrO,O,EAAS;AACtB,UAAIA,OAAO,KAAK8C,SAAZ,IAAyB,CAACzE,CAAC,CAACuQ,aAAF,CAAgB5O,OAAhB,CAA9B,EAAwD;AACtD,cAAM,IAAInB,eAAe,CAACqb,UAApB,CAA+B,uHAA/B,CAAN;AACD;;AAED,UAAIla,OAAO,KAAK8C,SAAZ,IAAyB9C,OAAO,CAACM,UAArC,EAAiD;AAC/C,YAAI,CAACG,KAAK,CAA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ACkD,KAApB,EAA2B,kDAA3B,CAAN;AACA/E,MAAAA,MAAM,CAACE,CAAC,CAACuQ,aAAF,CAAgB5O,OAAO,CAACkD,KAAxB,KAAkCzC,KAAK,CAACC,OAAN,CAAcV,OAAO,CAACkD,KAAtB,CAAlC,IAAkElD,OAAO,CAACkD,KAAR,YAAyB3E,KAAK,CAACuD,eAAlG,EACJ,iFADI,CAAN;AAED;;;4BA6+Bc4M,M,EAAQ1O,O,EAAS,CAAE,C,CAAC;;AAEnC;AACF;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;kCACuB0O,M,EAAQ1O,O,EAAS,CAAE,C,CAAC;;AAEzC;AACF;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;2BACgB0O,M,EAAQ1O,O,EAAS,CAAE,C,CAAC;;AAElC;AACF;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;8BACmB0O,M,EAAQ1O,O,EAAS,CAAE,C,CAAC;;;;;;;AAGvCC,MAAM,CAACC,MAAP,CAAcT,KAAd,EAAqBN,iBAArB;AACAD,KAAK,CAACyiB,OAAN,CAAcliB,KAAd,EAAqB,IAArB;AAEAmiB,MAAM,CAACC,OAAP,GAAiBpiB,KAAjB","sourcesContent":["'use strict';\n\nconst assert = require('assert');\nconst _ = require('lodash');\nconst Dottie = require('dottie');\n\nconst Utils = require('./utils');\nconst { logger } = require('./utils/logger');\nconst BelongsTo = require('./associations/belongs-to');\nconst BelongsToMany = require('./associations/belongs-to-many');\nconst InstanceValidator = require('./instance-validator');\nconst QueryTypes = require('./query-types');\nconst sequelizeErrors = require('./errors');\nconst Promise = require('./promise');\nconst Association = require('./associations/base');\nconst HasMany = require('./associations/has-many');\nconst DataTypes = require('./data-types');\nconst Hooks = require('./hooks');\nconst associationsMixin = require('./associations/mixin');\nconst Op = require('./operators');\nconst { noDoubleNestedGroup } = require('./utils/deprecations');\n\n\n// This list will quickly become dated, but failing to maintain this list just means\n// we won't throw a warning when we should. At least most common cases will forever be covered\n// so we stop throwing erroneous warnings when we shouldn't.\nconst validQueryKeywords = new Set(['where', 'attributes', 'paranoid', 'include', 'order', 'limit', 'offset',\n  'transaction', 'lock', 'raw', 'logging', 'benchmark', 'having', 'searchPath', 'rejectOnEmpty', 'plain',\n  'scope', 'group', 'through', 'defaults', 'distinct', 'primary', 'exception', 'type', 'hooks', 'force',\n  'name']);\n\n// List of attributes that should not be implicitly passed into subqueries/includes.\nconst nonCascadingOptions = ['include', 'attributes', 'originalAttributes', 'order', 'where', 'limit', 'offset', 'plain', 'group', 'having'];\n\n/**\n * A Model represents a table in the database. Instances of this class represent a database row.\n *\n * Model instances operate with the concept of a `dataValues` property, which stores the actual values represented by the instance.\n * By default, the values from dataValues can also be accessed directly from the Instance, that is:\n * ```js\n * instance.field\n * // is the same as\n * instance.get('field')\n * // is the same as\n * instance.getDataValue('field')\n * ```\n * However, if getters and/or setters are defined for `field` they will be invoked, instead of returning the value from `dataValues`.\n * Accessing properties directly or using `get` is preferred for regular use, `getDataValue` should only be used for custom getters.\n *\n * @see\n   * {@link Sequelize#define} for more information about getters and setters\n * @mixes Hooks\n */\nclass Model {\n  static get QueryInterface() {\n    return this.sequelize.getQueryInterface();\n  }\n\n  static get QueryGenerator() {\n    return this.QueryInterface.QueryGenerator;\n  }\n\n  /**\n   * A reference to the sequelize instance\n   *\n   * @see\n   * {@link Sequelize}\n   *\n   * @property sequelize\n   *\n   * @returns {Sequelize}\n   */\n  get sequelize() {\n    return this.constructor.sequelize;\n  }\n\n  /**\n   * Builds a new model instance.\n   *\n   * @param {Object}  [values={}] an object of key value pairs\n   * @param {Object}  [options] instance construction options\n   * @param {boolean} [options.raw=false] If set to true, values will ignore field and virtual setters.\n   * @param {boolean} [options.isNewRecord=true] Is this a new record\n   * @param {Array}   [options.include] an array of include options - Used to build prefetched/included model instances. See `set`\n   */\n  constructor(values = {}, options = {}) {\n    options = Object.assign({\n      isNewRecord: true,\n      _schema: this.constructor._schema,\n      _schemaDelimiter: this.constructor._schemaDelimiter\n    }, options || {});\n\n    if (options.attributes) {\n      options.attributes = options.attributes.map(attribute => Array.isArray(attribute) ? attribute[1] : attribute);\n    }\n\n    if (!options.includeValidated) {\n      this.constructor._conformIncludes(options, this.constructor);\n      if (options.include) {\n        this.constructor._expandIncludeAll(options);\n        this.constructor._validateIncludedElements(options);\n      }\n    }\n\n    this.dataValues = {};\n    this._previousDataValues = {};\n    this._changed = {};\n    this._modelOptions = this.constructor.options;\n    this._options = options || {};\n\n    /**\n     * Returns true if this instance has not yet been persisted to the database\n     * @property isNewRecord\n     * @returns {boolean}\n     */\n    this.isNewRecord = options.isNewRecord;\n\n    this._initValues(values, options);\n  }\n\n  _initValues(values, options) {\n    let defaults;\n    let key;\n\n    values = values && _.clone(values) || {};\n\n    if (options.isNewRecord) {\n      defaults = {};\n\n      if (this.constructor._hasDefaultValues) {\n        defaults = _.mapValues(this.constructor._defaultValues, valueFn => {\n          const value = valueFn();\n          return value && value instanceof Utils.SequelizeMethod ? value : _.cloneDeep(value);\n        });\n      }\n\n      // set id to null if not passed as value, a newly created dao has no id\n      // removing this breaks bulkCreate\n      // do after default values since it might have UUID as a default value\n      if (this.constructor.primaryKeyAttributes.length) {\n        this.constructor.primaryKeyAttributes.forEach(primaryKeyAttribute => {\n          if (!Object.prototype.hasOwnProperty.call(defaults, primaryKeyAttribute)) {\n            defaults[primaryKeyAttribute] = null;\n          }\n        });\n      }\n\n      if (this.constructor._timestampAttributes.createdAt && defaults[this.constructor._timestampAttributes.createdAt]) {\n        this.dataValues[this.constructor._timestampAttributes.createdAt] = Utils.toDefaultValue(defaults[this.constructor._timestampAttributes.createdAt], this.sequelize.options.dialect);\n        delete defaults[this.constructor._timestampAttributes.createdAt];\n      }\n\n      if (this.constructor._timestampAttributes.updatedAt && defaults[this.constructor._timestampAttributes.updatedAt]) {\n        this.dataValues[this.constructor._timestampAttributes.updatedAt] = Utils.toDefaultValue(defaults[this.constructor._timestampAttributes.updatedAt], this.sequelize.options.dialect);\n        delete defaults[this.constructor._timestampAttributes.updatedAt];\n      }\n\n      if (this.constructor._timestampAttributes.deletedAt && defaults[this.constructor._timestampAttributes.deletedAt]) {\n        this.dataValues[this.constructor._timestampAttributes.deletedAt] = Utils.toDefaultValue(defaults[this.constructor._timestampAttributes.deletedAt], this.sequelize.options.dialect);\n        delete defaults[this.constructor._timestampAttributes.deletedAt];\n      }\n\n      if (Object.keys(defaults).length) {\n        for (key in defaults) {\n          if (values[key] === undefined) {\n            this.set(key, Utils.toDefaultValue(defaults[key], this.sequelize.options.dialect), { raw: true });\n            delete values[key];\n          }\n        }\n      }\n    }\n\n    this.set(values, options);\n  }\n\n  // validateIncludedElements should have been called before this method\n  static _paranoidClause(model, options = {}) {\n    // Apply on each include\n    // This should be handled before handling where conditions because of logic with returns\n    // otherwise this code will never run on includes of a already conditionable where\n    if (options.include) {\n      for (const include of options.include) {\n        this._paranoidClause(include.model, include);\n      }\n    }\n\n    // apply paranoid when groupedLimit is used\n    if (_.get(options, 'groupedLimit.on.options.paranoid')) {\n      const throughModel = _.get(options, 'groupedLimit.on.through.model');\n      if (throughModel) {\n        options.groupedLimit.through = this._paranoidClause(throughModel, options.groupedLimit.through);\n      }\n    }\n\n    if (!model.options.timestamps || !model.options.paranoid || options.paranoid === false) {\n      // This model is not paranoid, nothing to do here;\n      return options;\n    }\n\n    const deletedAtCol = model._timestampAttributes.deletedAt;\n    const deletedAtAttribute = model.rawAttributes[deletedAtCol];\n    const deletedAtObject = {};\n\n    let deletedAtDefaultValue = Object.prototype.hasOwnProperty.call(deletedAtAttribute, 'defaultValue') ? deletedAtAttribute.defaultValue : null;\n\n    deletedAtDefaultValue = deletedAtDefaultValue || {\n      [Op.eq]: null\n    };\n\n    deletedAtObject[deletedAtAttribute.field || deletedAtCol] = deletedAtDefaultValue;\n\n    if (Utils.isWhereEmpty(options.where)) {\n      options.where = deletedAtObject;\n    } else {\n      options.where = { [Op.and]: [deletedAtObject, options.where] };\n    }\n\n    return options;\n  }\n\n  static _addDefaultAttributes() {\n    const tail = {};\n    let head = {};\n\n    // Add id if no primary key was manually added to definition\n    // Can't use this.primaryKeys here, since this function is called before PKs are identified\n    if (!_.some(this.rawAttributes, 'primaryKey')) {\n      if ('id' in this.rawAttributes) {\n        // Something is fishy here!\n        throw new Error(`A column called 'id' was added to the attributes of '${this.tableName}' but not marked with 'primaryKey: true'`);\n      }\n\n      head = {\n        id: {\n          type: new DataTypes.INTEGER(),\n          allowNull: false,\n          primaryKey: true,\n          autoIncrement: true,\n          _autoGenerated: true\n        }\n      };\n    }\n\n    if (this._timestampAttributes.createdAt) {\n      tail[this._timestampAttributes.createdAt] = {\n        type: DataTypes.DATE,\n        allowNull: false,\n        _autoGenerated: true\n      };\n    }\n\n    if (this._timestampAttributes.updatedAt) {\n      tail[this._timestampAttributes.updatedAt] = {\n        type: DataTypes.DATE,\n        allowNull: false,\n        _autoGenerated: true\n      };\n    }\n\n    if (this._timestampAttributes.deletedAt) {\n      tail[this._timestampAttributes.deletedAt] = {\n        type: DataTypes.DATE,\n        _autoGenerated: true\n      };\n    }\n\n    if (this._versionAttribute) {\n      tail[this._versionAttribute] = {\n        type: DataTypes.INTEGER,\n        allowNull: false,\n        defaultValue: 0,\n        _autoGenerated: true\n      };\n    }\n\n    const existingAttributes = _.clone(this.rawAttributes);\n    this.rawAttributes = {};\n\n    _.each(head, (value, attr) => {\n      this.rawAttributes[attr] = value;\n    });\n\n    _.each(existingAttributes, (value, attr) => {\n      this.rawAttributes[attr] = value;\n    });\n\n    _.each(tail, (value, attr) => {\n      if (this.rawAttributes[attr] === undefined) {\n        this.rawAttributes[attr] = value;\n      }\n    });\n\n    if (!Object.keys(this.primaryKeys).length) {\n      this.primaryKeys.id = this.rawAttributes.id;\n    }\n  }\n\n  static _findAutoIncrementAttribute() {\n    this.autoIncrementAttribute = null;\n\n    for (const name in this.rawAttributes) {\n      if (Object.prototype.hasOwnProperty.call(this.rawAttributes, name)) {\n        const definition = this.rawAttributes[name];\n        if (definition && definition.autoIncrement) {\n          if (this.autoIncrementAttribute) {\n            throw new Error('Invalid Instance definition. Only one autoincrement field allowed.');\n          }\n          this.autoIncrementAttribute = name;\n        }\n      }\n    }\n  }\n\n  static _conformIncludes(options, self) {\n    if (!options.include) return;\n\n    // if include is not an array, wrap in an array\n    if (!Array.isArray(options.include)) {\n      options.include = [options.include];\n    } else if (!options.include.length) {\n      delete options.include;\n      return;\n    }\n\n    // convert all included elements to { model: Model } form\n    options.include = options.include.map(include => this._conformInclude(include, self));\n  }\n\n  static _transformStringAssociation(include, self) {\n    if (self && typeof include === 'string') {\n      if (!Object.prototype.hasOwnProperty.call(self.associations, include)) {\n        throw new Error(`Association with alias \"${include}\" does not exist on ${self.name}`);\n      }\n      return self.associations[include];\n    }\n    return include;\n  }\n\n  static _conformInclude(include, self) {\n    if (include) {\n      let model;\n\n      if (include._pseudo) return include;\n\n      include = this._transformStringAssociation(include, self);\n\n      if (include instanceof Association) {\n        if (self && include.target.name === self.name) {\n          model = include.source;\n        } else {\n          model = include.target;\n        }\n\n        return { model, association: include, as: include.as };\n      }\n\n      if (include.prototype && include.prototype instanceof Model) {\n        return { model: include };\n      }\n\n      if (_.isPlainObject(include)) {\n        if (include.association) {\n          include.association = this._transformStringAssociation(include.association, self);\n\n          if (self && include.association.target.name === self.name) {\n            model = include.association.source;\n          } else {\n            model = include.association.target;\n          }\n\n          if (!include.model) include.model = model;\n          if (!include.as) include.as = include.association.as;\n\n          this._conformIncludes(include, model);\n          return include;\n        }\n\n        if (include.model) {\n          this._conformIncludes(include, include.model);\n          return include;\n        }\n\n        if (include.all) {\n          this._conformIncludes(include);\n          return include;\n        }\n      }\n    }\n\n    throw new Error('Include unexpected. Element has to be either a Model, an Association or an object.');\n  }\n\n  static _expandIncludeAllElement(includes, include) {\n    // check 'all' attribute provided is valid\n    let all = include.all;\n    delete include.all;\n\n    if (all !== true) {\n      if (!Array.isArray(all)) {\n        all = [all];\n      }\n\n      const validTypes = {\n        BelongsTo: true,\n        HasOne: true,\n        HasMany: true,\n        One: ['BelongsTo', 'HasOne'],\n        Has: ['HasOne', 'HasMany'],\n        Many: ['HasMany']\n      };\n\n      for (let i = 0; i < all.length; i++) {\n        const type = all[i];\n        if (type === 'All') {\n          all = true;\n          break;\n        }\n\n        const types = validTypes[type];\n        if (!types) {\n          throw new sequelizeErrors.EagerLoadingError(`include all '${type}' is not valid - must be BelongsTo, HasOne, HasMany, One, Has, Many or All`);\n        }\n\n        if (types !== true) {\n          // replace type placeholder e.g. 'One' with its constituent types e.g. 'HasOne', 'BelongsTo'\n          all.splice(i, 1);\n          i--;\n          for (let j = 0; j < types.length; j++) {\n            if (!all.includes(types[j])) {\n              all.unshift(types[j]);\n              i++;\n            }\n          }\n        }\n      }\n    }\n\n    // add all associations of types specified to includes\n    const nested = include.nested;\n    if (nested) {\n      delete include.nested;\n\n      if (!include.include) {\n        include.include = [];\n      } else if (!Array.isArray(include.include)) {\n        include.include = [include.include];\n      }\n    }\n\n    const used = [];\n    (function addAllIncludes(parent, includes) {\n      _.forEach(parent.associations, association => {\n        if (all !== true && !all.includes(association.associationType)) {\n          return;\n        }\n\n        // check if model already included, and skip if so\n        const model = association.target;\n        const as = association.options.as;\n\n        const predicate = { model };\n        if (as) {\n          // We only add 'as' to the predicate if it actually exists\n          predicate.as = as;\n        }\n\n        if (_.some(includes, predicate)) {\n          return;\n        }\n\n        // skip if recursing over a model already nested\n        if (nested && used.includes(model)) {\n          return;\n        }\n        used.push(parent);\n\n        // include this model\n        const thisInclude = Utils.cloneDeep(include);\n        thisInclude.model = model;\n        if (as) {\n          thisInclude.as = as;\n        }\n        includes.push(thisInclude);\n\n        // run recursively if nested\n        if (nested) {\n          addAllIncludes(model, thisInclude.include);\n          if (thisInclude.include.length === 0) delete thisInclude.include;\n        }\n      });\n      used.pop();\n    })(this, includes);\n  }\n\n  static _validateIncludedElements(options, tableNames) {\n    if (!options.model) options.model = this;\n\n    tableNames = tableNames || {};\n    options.includeNames = [];\n    options.includeMap = {};\n\n    /* Legacy */\n    options.hasSingleAssociation = false;\n    options.hasMultiAssociation = false;\n\n    if (!options.parent) {\n      options.topModel = options.model;\n      options.topLimit = options.limit;\n    }\n\n    options.include = options.include.map(include => {\n      include = this._conformInclude(include);\n      include.parent = options;\n      include.topLimit = options.topLimit;\n\n      this._validateIncludedElement.call(options.model, include, tableNames, options);\n\n      if (include.duplicating === undefined) {\n        include.duplicating = include.association.isMultiAssociation;\n      }\n\n      include.hasDuplicating = include.hasDuplicating || include.duplicating;\n      include.hasRequired = include.hasRequired || include.required;\n\n      options.hasDuplicating = options.hasDuplicating || include.hasDuplicating;\n      options.hasRequired = options.hasRequired || include.required;\n\n      options.hasWhere = options.hasWhere || include.hasWhere || !!include.where;\n      return include;\n    });\n\n    for (const include of options.include) {\n      include.hasParentWhere = options.hasParentWhere || !!options.where;\n      include.hasParentRequired = options.hasParentRequired || !!options.required;\n\n      if (include.subQuery !== false && options.hasDuplicating && options.topLimit) {\n        if (include.duplicating) {\n          include.subQuery = false;\n          include.subQueryFilter = include.hasRequired;\n        } else {\n          include.subQuery = include.hasRequired;\n          include.subQueryFilter = false;\n        }\n      } else {\n        include.subQuery = include.subQuery || false;\n        if (include.duplicating) {\n          include.subQueryFilter = include.subQuery;\n          include.subQuery = false;\n        } else {\n          include.subQueryFilter = false;\n          include.subQuery = include.subQuery || include.hasParentRequired && include.hasRequired;\n        }\n      }\n\n      options.includeMap[include.as] = include;\n      options.includeNames.push(include.as);\n\n      // Set top level options\n      if (options.topModel === options.model && options.subQuery === undefined && options.topLimit) {\n        if (include.subQuery) {\n          options.subQuery = include.subQuery;\n        } else if (include.hasDuplicating) {\n          options.subQuery = true;\n        }\n      }\n\n      /* Legacy */\n      options.hasIncludeWhere = options.hasIncludeWhere || include.hasIncludeWhere || !!include.where;\n      options.hasIncludeRequired = options.hasIncludeRequired || include.hasIncludeRequired || !!include.required;\n\n      if (include.association.isMultiAssociation || include.hasMultiAssociation) {\n        options.hasMultiAssociation = true;\n      }\n      if (include.association.isSingleAssociation || include.hasSingleAssociation) {\n        options.hasSingleAssociation = true;\n      }\n    }\n\n    if (options.topModel === options.model && options.subQuery === undefined) {\n      options.subQuery = false;\n    }\n    return options;\n  }\n\n  static _validateIncludedElement(include, tableNames, options) {\n    tableNames[include.model.getTableName()] = true;\n\n    if (include.attributes && !options.raw) {\n      include.model._expandAttributes(include);\n\n      include.originalAttributes = this._injectDependentVirtualAttributes(include.attributes);\n\n      include = Utils.mapFinderOptions(include, include.model);\n\n      if (include.attributes.length) {\n        _.each(include.model.primaryKeys, (attr, key) => {\n          // Include the primary key if it's not already included - take into account that the pk might be aliased (due to a .field prop)\n          if (!include.attributes.some(includeAttr => {\n            if (attr.field !== key) {\n              return Array.isArray(includeAttr) && includeAttr[0] === attr.field && includeAttr[1] === key;\n            }\n            return includeAttr === key;\n          })) {\n            include.attributes.unshift(key);\n          }\n        });\n      }\n    } else {\n      include = Utils.mapFinderOptions(include, include.model);\n    }\n\n    // pseudo include just needed the attribute logic, return\n    if (include._pseudo) {\n      include.attributes = Object.keys(include.model.tableAttributes);\n      return Utils.mapFinderOptions(include, include.model);\n    }\n\n    // check if the current Model is actually associated with the passed Model - or it's a pseudo include\n    const association = include.association || this._getIncludedAssociation(include.model, include.as);\n\n    include.association = association;\n    include.as = association.as;\n\n    // If through, we create a pseudo child include, to ease our parsing later on\n    if (include.association.through && Object(include.association.through.model) === include.association.through.model) {\n      if (!include.include) include.include = [];\n      const through = include.association.through;\n\n      include.through = _.defaults(include.through || {}, {\n        model: through.model,\n        as: through.model.name,\n        association: {\n          isSingleAssociation: true\n        },\n        _pseudo: true,\n        parent: include\n      });\n\n\n      if (through.scope) {\n        include.through.where = include.through.where ? { [Op.and]: [include.through.where, through.scope] } : through.scope;\n      }\n\n      include.include.push(include.through);\n      tableNames[through.tableName] = true;\n    }\n\n    // include.model may be the main model, while the association target may be scoped - thus we need to look at association.target/source\n    let model;\n    if (include.model.scoped === true) {\n      // If the passed model is already scoped, keep that\n      model = include.model;\n    } else {\n      // Otherwise use the model that was originally passed to the association\n      model = include.association.target.name === include.model.name ? include.association.target : include.association.source;\n    }\n\n    model._injectScope(include);\n\n    // This check should happen after injecting the scope, since the scope may contain a .attributes\n    if (!include.attributes) {\n      include.attributes = Object.keys(include.model.tableAttributes);\n    }\n\n    include = Utils.mapFinderOptions(include, include.model);\n\n    if (include.required === undefined) {\n      include.required = !!include.where;\n    }\n\n    if (include.association.scope) {\n      include.where = include.where ? { [Op.and]: [include.where, include.association.scope] } : include.association.scope;\n    }\n\n    if (include.limit && include.separate === undefined) {\n      include.separate = true;\n    }\n\n    if (include.separate === true) {\n      if (!(include.association instanceof HasMany)) {\n        throw new Error('Only HasMany associations support include.separate');\n      }\n\n      include.duplicating = false;\n\n      if (\n        options.attributes\n        && options.attributes.length\n        && !_.flattenDepth(options.attributes, 2).includes(association.sourceKey)\n      ) {\n        options.attributes.push(association.sourceKey);\n      }\n\n      if (\n        include.attributes\n        && include.attributes.length\n        && !_.flattenDepth(include.attributes, 2).includes(association.foreignKey)\n      ) {\n        include.attributes.push(association.foreignKey);\n      }\n    }\n\n    // Validate child includes\n    if (Object.prototype.hasOwnProperty.call(include, 'include')) {\n      this._validateIncludedElements.call(include.model, include, tableNames);\n    }\n\n    return include;\n  }\n\n  static _getIncludedAssociation(targetModel, targetAlias) {\n    const associations = this.getAssociations(targetModel);\n    let association = null;\n    if (associations.length === 0) {\n      throw new sequelizeErrors.EagerLoadingError(`${targetModel.name} is not associated to ${this.name}!`);\n    }\n    if (associations.length === 1) {\n      association = this.getAssociationForAlias(targetModel, targetAlias);\n      if (association) {\n        return association;\n      }\n      if (targetAlias) {\n        const existingAliases = this.getAssociations(targetModel).map(association => association.as);\n        throw new sequelizeErrors.EagerLoadingError(`${targetModel.name} is associated to ${this.name} using an alias. ` +\n          `You've included an alias (${targetAlias}), but it does not match the alias(es) defined in your association (${existingAliases.join(', ')}).`);\n      }\n      throw new sequelizeErrors.EagerLoadingError(`${targetModel.name} is associated to ${this.name} using an alias. ` +\n        'You must use the \\'as\\' keyword to specify the alias within your include statement.');\n    }\n    association = this.getAssociationForAlias(targetModel, targetAlias);\n    if (!association) {\n      throw new sequelizeErrors.EagerLoadingError(`${targetModel.name} is associated to ${this.name} multiple times. ` +\n        'To identify the correct association, you must use the \\'as\\' keyword to specify the alias of the association you want to include.');\n    }\n    return association;\n  }\n\n\n  static _expandIncludeAll(options) {\n    const includes = options.include;\n    if (!includes) {\n      return;\n    }\n\n    for (let index = 0; index < includes.length; index++) {\n      const include = includes[index];\n\n      if (include.all) {\n        includes.splice(index, 1);\n        index--;\n\n        this._expandIncludeAllElement(includes, include);\n      }\n    }\n\n    includes.forEach(include => {\n      this._expandIncludeAll.call(include.model, include);\n    });\n  }\n\n  static _conformIndex(index) {\n    if (!index.fields) {\n      throw new Error('Missing \"fields\" property for index definition');\n    }\n\n    index = _.defaults(index, {\n      type: '',\n      parser: null\n    });\n\n    if (index.type && index.type.toLowerCase() === 'unique') {\n      index.unique = true;\n      delete index.type;\n    }\n\n    return index;\n  }\n\n\n  static _uniqIncludes(options) {\n    if (!options.include) return;\n\n    options.include = _(options.include)\n      .groupBy(include => `${include.model && include.model.name}-${include.as}`)\n      .map(includes => this._assignOptions(...includes))\n      .value();\n  }\n\n  static _baseMerge(...args) {\n    _.assignWith(...args);\n    this._conformIncludes(args[0], this);\n    this._uniqIncludes(args[0]);\n    return args[0];\n  }\n\n  static _mergeFunction(objValue, srcValue, key) {\n    if (Array.isArray(objValue) && Array.isArray(srcValue)) {\n      return _.union(objValue, srcValue);\n    }\n    if (key === 'where' || key === 'having') {\n      if (srcValue instanceof Utils.SequelizeMethod) {\n        srcValue = { [Op.and]: srcValue };\n      }\n      if (_.isPlainObject(objValue) && _.isPlainObject(srcValue)) {\n        return Object.assign(objValue, srcValue);\n      }\n    } else if (key === 'attributes' && _.isPlainObject(objValue) && _.isPlainObject(srcValue)) {\n      return _.assignWith(objValue, srcValue, (objValue, srcValue) => {\n        if (Array.isArray(objValue) && Array.isArray(srcValue)) {\n          return _.union(objValue, srcValue);\n        }\n      });\n    }\n    // If we have a possible object/array to clone, we try it.\n    // Otherwise, we return the original value when it's not undefined,\n    // or the resulting object in that case.\n    if (srcValue) {\n      return Utils.cloneDeep(srcValue, true);\n    }\n    return srcValue === undefined ? objValue : srcValue;\n  }\n\n  static _assignOptions(...args) {\n    return this._baseMerge(...args, this._mergeFunction);\n  }\n\n  static _defaultsOptions(target, opts) {\n    return this._baseMerge(target, opts, (srcValue, objValue, key) => {\n      return this._mergeFunction(objValue, srcValue, key);\n    });\n  }\n\n  /**\n   * Initialize a model, representing a table in the DB, with attributes and options.\n   *\n   * The table columns are defined by the hash that is given as the first argument.\n   * Each attribute of the hash represents a column.\n   *\n   * For more about <a href=\"/manual/tutorial/models-definition.html#validations\"/>Validations</a>\n   *\n   * More examples, <a href=\"/manual/tutorial/models-definition.html\"/>Model Definition</a>\n   *\n   * @example\n   * Project.init({\n   *   columnA: {\n   *     type: Sequelize.BOOLEAN,\n   *     validate: {\n   *       is: ['[a-z]','i'],        // will only allow letters\n   *       max: 23,                  // only allow values <= 23\n   *       isIn: {\n   *         args: [['en', 'zh']],\n   *         msg: \"Must be English or Chinese\"\n   *       }\n   *     },\n   *     field: 'column_a'\n   *     // Other attributes here\n   *   },\n   *   columnB: Sequelize.STRING,\n   *   columnC: 'MY VERY OWN COLUMN TYPE'\n   * }, {sequelize})\n   *\n   * sequelize.models.modelName // The model will now be available in models under the class name\n   *\n   * @see\n   * {@link DataTypes}\n   * @see\n   * {@link Hooks}\n   *\n   * @param {Object}                  attributes An object, where each attribute is a column of the table. Each column can be either a DataType, a string or a type-description object, with the properties described below:\n   * @param {string|DataTypes|Object} attributes.column The description of a database column\n   * @param {string|DataTypes}        attributes.column.type A string or a data type\n   * @param {boolean}                 [attributes.column.allowNull=true] If false, the column will have a NOT NULL constraint, and a not null validation will be run before an instance is saved.\n   * @param {any}                     [attributes.column.defaultValue=null] A literal default value, a JavaScript function, or an SQL function (see `sequelize.fn`)\n   * @param {string|boolean}          [attributes.column.unique=false] If true, the column will get a unique constraint. If a string is provided, the column will be part of a composite unique index. If multiple columns have the same string, they will be part of the same unique index\n   * @param {boolean}                 [attributes.column.primaryKey=false] If true, this attribute will be marked as primary key\n   * @param {string}                  [attributes.column.field=null] If set, sequelize will map the attribute name to a different name in the database\n   * @param {boolean}                 [attributes.column.autoIncrement=false] If true, this column will be set to auto increment\n   * @param {boolean}                 [attributes.column.autoIncrementIdentity=false] If true, combined with autoIncrement=true, will use Postgres `GENERATED BY DEFAULT AS IDENTITY` instead of `SERIAL`. Postgres 10+ only.\n   * @param {string}                  [attributes.column.comment=null] Comment for this column\n   * @param {string|Model}            [attributes.column.references=null] An object with reference configurations\n   * @param {string|Model}            [attributes.column.references.model] If this column references another table, provide it here as a Model, or a string\n   * @param {string}                  [attributes.column.references.key='id'] The column of the foreign table that this column references\n   * @param {string}                  [attributes.column.onUpdate] What should happen when the referenced key is updated. One of CASCADE, RESTRICT, SET DEFAULT, SET NULL or NO ACTION\n   * @param {string}                  [attributes.column.onDelete] What should happen when the referenced key is deleted. One of CASCADE, RESTRICT, SET DEFAULT, SET NULL or NO ACTION\n   * @param {Function}                [attributes.column.get] Provide a custom getter for this column. Use `this.getDataValue(String)` to manipulate the underlying values.\n   * @param {Function}                [attributes.column.set] Provide a custom setter for this column. Use `this.setDataValue(String, Value)` to manipulate the underlying values.\n   * @param {Object}                  [attributes.column.validate] An object of validations to execute for this column every time the model is saved. Can be either the name of a validation provided by validator.js, a validation function provided by extending validator.js (see the `DAOValidator` property for more details), or a custom validation function. Custom validation functions are called with the value of the field and the instance itself as the `this` binding, and can possibly take a second callback argument, to signal that they are asynchronous. If the validator is sync, it should throw in the case of a failed validation; if it is async, the callback should be called with the error text.\n   * @param {Object}                  options These options are merged with the default define options provided to the Sequelize constructor\n   * @param {Object}                  options.sequelize Define the sequelize instance to attach to the new Model. Throw error if none is provided.\n   * @param {string}                  [options.modelName] Set name of the model. By default its same as Class name.\n   * @param {Object}                  [options.defaultScope={}] Define the default search scope to use for this model. Scopes have the same form as the options passed to find / findAll\n   * @param {Object}                  [options.scopes] More scopes, defined in the same way as defaultScope above. See `Model.scope` for more information about how scopes are defined, and what you can do with them\n   * @param {boolean}                 [options.omitNull] Don't persist null values. This means that all columns with null values will not be saved\n   * @param {boolean}                 [options.timestamps=true] Adds createdAt and updatedAt timestamps to the model.\n   * @param {boolean}                 [options.paranoid=false] Calling `destroy` will not delete the model, but instead set a `deletedAt` timestamp if this is true. Needs `timestamps=true` to work\n   * @param {boolean}                 [options.underscored=false] Add underscored field to all attributes, this covers user defined attributes, timestamps and foreign keys. Will not affect attributes with explicitly set `field` option\n   * @param {boolean}                 [options.freezeTableName=false] If freezeTableName is true, sequelize will not try to alter the model name to get the table name. Otherwise, the model name will be pluralized\n   * @param {Object}                  [options.name] An object with two attributes, `singular` and `plural`, which are used when this model is associated to others.\n   * @param {string}                  [options.name.singular=Utils.singularize(modelName)] Singular name for model\n   * @param {string}                  [options.name.plural=Utils.pluralize(modelName)] Plural name for model\n   * @param {Array<Object>}           [options.indexes] indexes definitions\n   * @param {string}                  [options.indexes[].name] The name of the index. Defaults to model name + _ + fields concatenated\n   * @param {string}                  [options.indexes[].type] Index type. Only used by mysql. One of `UNIQUE`, `FULLTEXT` and `SPATIAL`\n   * @param {string}                  [options.indexes[].using] The method to create the index by (`USING` statement in SQL). BTREE and HASH are supported by mysql and postgres, and postgres additionally supports GIST and GIN.\n   * @param {string}                  [options.indexes[].operator] Specify index operator.\n   * @param {boolean}                 [options.indexes[].unique=false] Should the index by unique? Can also be triggered by setting type to `UNIQUE`\n   * @param {boolean}                 [options.indexes[].concurrently=false] PostgresSQL will build the index without taking any write locks. Postgres only\n   * @param {Array<string|Object>}    [options.indexes[].fields] An array of the fields to index. Each field can either be a string containing the name of the field, a sequelize object (e.g `sequelize.fn`), or an object with the following attributes: `attribute` (field name), `length` (create a prefix index of length chars), `order` (the direction the column should be sorted in), `collate` (the collation (sort order) for the column)\n   * @param {string|boolean}          [options.createdAt] Override the name of the createdAt attribute if a string is provided, or disable it if false. Timestamps must be true. Underscored field will be set with underscored setting.\n   * @param {string|boolean}          [options.updatedAt] Override the name of the updatedAt attribute if a string is provided, or disable it if false. Timestamps must be true. Underscored field will be set with underscored setting.\n   * @param {string|boolean}          [options.deletedAt] Override the name of the deletedAt attribute if a string is provided, or disable it if false. Timestamps must be true. Underscored field will be set with underscored setting.\n   * @param {string}                  [options.tableName] Defaults to pluralized model name, unless freezeTableName is true, in which case it uses model name verbatim\n   * @param {string}                  [options.schema='public'] schema\n   * @param {string}                  [options.engine] Specify engine for model's table\n   * @param {string}                  [options.charset] Specify charset for model's table\n   * @param {string}                  [options.comment] Specify comment for model's table\n   * @param {string}                  [options.collate] Specify collation for model's table\n   * @param {string}                  [options.initialAutoIncrement] Set the initial AUTO_INCREMENT value for the table in MySQL.\n   * @param {Object}                  [options.hooks] An object of hook function that are called before and after certain lifecycle events. The possible hooks are: beforeValidate, afterValidate, validationFailed, beforeBulkCreate, beforeBulkDestroy, beforeBulkUpdate, beforeCreate, beforeDestroy, beforeUpdate, afterCreate, beforeSave, afterDestroy, afterUpdate, afterBulkCreate, afterSave, afterBulkDestroy and afterBulkUpdate. See Hooks for more information about hook functions and their signatures. Each property can either be a function, or an array of functions.\n   * @param {Object}                  [options.validate] An object of model wide validations. Validations have access to all model values via `this`. If the validator function takes an argument, it is assumed to be async, and is called with a callback that accepts an optional error.\n   *\n   * @returns {Model}\n   */\n  static init(attributes, options = {}) {\n    if (!options.sequelize) {\n      throw new Error('No Sequelize instance passed');\n    }\n\n    this.sequelize = options.sequelize;\n\n    const globalOptions = this.sequelize.options;\n\n    options = Utils.merge(_.cloneDeep(globalOptions.define), options);\n\n    if (!options.modelName) {\n      options.modelName = this.name;\n    }\n\n    options = Utils.merge({\n      name: {\n        plural: Utils.pluralize(options.modelName),\n        singular: Utils.singularize(options.modelName)\n      },\n      indexes: [],\n      omitNull: globalOptions.omitNull,\n      schema: globalOptions.schema\n    }, options);\n\n    this.sequelize.runHooks('beforeDefine', attributes, options);\n\n    if (options.modelName !== this.name) {\n      Object.defineProperty(this, 'name', { value: options.modelName });\n    }\n    delete options.modelName;\n\n    this.options = Object.assign({\n      timestamps: true,\n      validate: {},\n      freezeTableName: false,\n      underscored: false,\n      paranoid: false,\n      rejectOnEmpty: false,\n      whereCollection: null,\n      schema: null,\n      schemaDelimiter: '',\n      defaultScope: {},\n      scopes: {},\n      indexes: []\n    }, options);\n\n    // if you call \"define\" multiple times for the same modelName, do not clutter the factory\n    if (this.sequelize.isDefined(this.name)) {\n      this.sequelize.modelManager.removeModel(this.sequelize.modelManager.getModel(this.name));\n    }\n\n    this.associations = {};\n    this._setupHooks(options.hooks);\n\n    this.underscored = this.options.underscored;\n\n    if (!this.options.tableName) {\n      this.tableName = this.options.freezeTableName ? this.name : Utils.underscoredIf(Utils.pluralize(this.name), this.underscored);\n    } else {\n      this.tableName = this.options.tableName;\n    }\n\n    this._schema = this.options.schema;\n    this._schemaDelimiter = this.options.schemaDelimiter;\n\n    // error check options\n    _.each(options.validate, (validator, validatorType) => {\n      if (Object.prototype.hasOwnProperty.call(attributes, validatorType)) {\n        throw new Error(`A model validator function must not have the same name as a field. Model: ${this.name}, field/validation name: ${validatorType}`);\n      }\n\n      if (typeof validator !== 'function') {\n        throw new Error(`Members of the validate option must be functions. Model: ${this.name}, error with validate member ${validatorType}`);\n      }\n    });\n\n    this.rawAttributes = _.mapValues(attributes, (attribute, name) => {\n      attribute = this.sequelize.normalizeAttribute(attribute);\n\n      if (attribute.type === undefined) {\n        throw new Error(`Unrecognized datatype for attribute \"${this.name}.${name}\"`);\n      }\n\n      if (attribute.allowNull !== false && _.get(attribute, 'validate.notNull')) {\n        throw new Error(`Invalid definition for \"${this.name}.${name}\", \"notNull\" validator is only allowed with \"allowNull:false\"`);\n      }\n\n      if (_.get(attribute, 'references.model.prototype') instanceof Model) {\n        attribute.references.model = attribute.references.model.getTableName();\n      }\n\n      return attribute;\n    });\n\n    const tableName = this.getTableName();\n    this._indexes = this.options.indexes\n      .map(index => Utils.nameIndex(this._conformIndex(index), tableName));\n\n    this.primaryKeys = {};\n    this._readOnlyAttributes = new Set();\n    this._timestampAttributes = {};\n\n    // setup names of timestamp attributes\n    if (this.options.timestamps) {\n      if (this.options.createdAt !== false) {\n        this._timestampAttributes.createdAt = this.options.createdAt || 'createdAt';\n        this._readOnlyAttributes.add(this._timestampAttributes.createdAt);\n      }\n      if (this.options.updatedAt !== false) {\n        this._timestampAttributes.updatedAt = this.options.updatedAt || 'updatedAt';\n        this._readOnlyAttributes.add(this._timestampAttributes.updatedAt);\n      }\n      if (this.options.paranoid && this.options.deletedAt !== false) {\n        this._timestampAttributes.deletedAt = this.options.deletedAt || 'deletedAt';\n        this._readOnlyAttributes.add(this._timestampAttributes.deletedAt);\n      }\n    }\n\n    // setup name for version attribute\n    if (this.options.version) {\n      this._versionAttribute = typeof this.options.version === 'string' ? this.options.version : 'version';\n      this._readOnlyAttributes.add(this._versionAttribute);\n    }\n\n    this._hasReadOnlyAttributes = this._readOnlyAttributes.size > 0;\n\n    // Add head and tail default attributes (id, timestamps)\n    this._addDefaultAttributes();\n    this.refreshAttributes();\n    this._findAutoIncrementAttribute();\n\n    this._scope = this.options.defaultScope;\n    this._scopeNames = ['defaultScope'];\n\n    this.sequelize.modelManager.addModel(this);\n    this.sequelize.runHooks('afterDefine', this);\n\n    return this;\n  }\n\n  static refreshAttributes() {\n    const attributeManipulation = {};\n\n    this.prototype._customGetters = {};\n    this.prototype._customSetters = {};\n\n    ['get', 'set'].forEach(type => {\n      const opt = `${type}terMethods`;\n      const funcs = _.clone(_.isObject(this.options[opt]) ? this.options[opt] : {});\n      const _custom = type === 'get' ? this.prototype._customGetters : this.prototype._customSetters;\n\n      _.each(funcs, (method, attribute) => {\n        _custom[attribute] = method;\n\n        if (type === 'get') {\n          funcs[attribute] = function() {\n            return this.get(attribute);\n          };\n        }\n        if (type === 'set') {\n          funcs[attribute] = function(value) {\n            return this.set(attribute, value);\n          };\n        }\n      });\n\n      _.each(this.rawAttributes, (options, attribute) => {\n        if (Object.prototype.hasOwnProperty.call(options, type)) {\n          _custom[attribute] = options[type];\n        }\n\n        if (type === 'get') {\n          funcs[attribute] = function() {\n            return this.get(attribute);\n          };\n        }\n        if (type === 'set') {\n          funcs[attribute] = function(value) {\n            return this.set(attribute, value);\n          };\n        }\n      });\n\n      _.each(funcs, (fct, name) => {\n        if (!attributeManipulation[name]) {\n          attributeManipulation[name] = {\n            configurable: true\n          };\n        }\n        attributeManipulation[name][type] = fct;\n      });\n    });\n\n    this._dataTypeChanges = {};\n    this._dataTypeSanitizers = {};\n\n    this._hasBooleanAttributes = false;\n    this._hasDateAttributes = false;\n    this._jsonAttributes = new Set();\n    this._virtualAttributes = new Set();\n    this._defaultValues = {};\n    this.prototype.validators = {};\n\n    this.fieldRawAttributesMap = {};\n\n    this.primaryKeys = {};\n    this.uniqueKeys = {};\n\n    _.each(this.rawAttributes, (definition, name) => {\n      definition.type = this.sequelize.normalizeDataType(definition.type);\n\n      definition.Model = this;\n      definition.fieldName = name;\n      definition._modelAttribute = true;\n\n      if (definition.field === undefined) {\n        definition.field = Utils.underscoredIf(name, this.underscored);\n      }\n\n      if (definition.primaryKey === true) {\n        this.primaryKeys[name] = definition;\n      }\n\n      this.fieldRawAttributesMap[definition.field] = definition;\n\n      if (definition.type._sanitize) {\n        this._dataTypeSanitizers[name] = definition.type._sanitize;\n      }\n\n      if (definition.type._isChanged) {\n        this._dataTypeChanges[name] = definition.type._isChanged;\n      }\n\n      if (definition.type instanceof DataTypes.BOOLEAN) {\n        this._hasBooleanAttributes = true;\n      } else if (definition.type instanceof DataTypes.DATE || definition.type instanceof DataTypes.DATEONLY) {\n        this._hasDateAttributes = true;\n      } else if (definition.type instanceof DataTypes.JSON) {\n        this._jsonAttributes.add(name);\n      } else if (definition.type instanceof DataTypes.VIRTUAL) {\n        this._virtualAttributes.add(name);\n      }\n\n      if (Object.prototype.hasOwnProperty.call(definition, 'defaultValue')) {\n        this._defaultValues[name] = () => Utils.toDefaultValue(definition.defaultValue, this.sequelize.options.dialect);\n      }\n\n      if (Object.prototype.hasOwnProperty.call(definition, 'unique') && definition.unique) {\n        let idxName;\n        if (\n          typeof definition.unique === 'object' &&\n          Object.prototype.hasOwnProperty.call(definition.unique, 'name')\n        ) {\n          idxName = definition.unique.name;\n        } else if (typeof definition.unique === 'string') {\n          idxName = definition.unique;\n        } else {\n          idxName = `${this.tableName}_${name}_unique`;\n        }\n\n        const idx = this.uniqueKeys[idxName] || { fields: [] };\n\n        idx.fields.push(definition.field);\n        idx.msg = idx.msg || definition.unique.msg || null;\n        idx.name = idxName || false;\n        idx.column = name;\n        idx.customIndex = definition.unique !== true;\n\n        this.uniqueKeys[idxName] = idx;\n      }\n\n      if (Object.prototype.hasOwnProperty.call(definition, 'validate')) {\n        this.prototype.validators[name] = definition.validate;\n      }\n\n      if (definition.index === true && definition.type instanceof DataTypes.JSONB) {\n        this._indexes.push(\n          Utils.nameIndex(\n            this._conformIndex({\n              fields: [definition.field || name],\n              using: 'gin'\n            }),\n            this.getTableName()\n          )\n        );\n\n        delete definition.index;\n      }\n    });\n\n    // Create a map of field to attribute names\n    this.fieldAttributeMap = _.reduce(this.fieldRawAttributesMap, (map, value, key) => {\n      if (key !== value.fieldName) {\n        map[key] = value.fieldName;\n      }\n      return map;\n    }, {});\n\n    this._hasJsonAttributes = !!this._jsonAttributes.size;\n\n    this._hasVirtualAttributes = !!this._virtualAttributes.size;\n\n    this._hasDefaultValues = !_.isEmpty(this._defaultValues);\n\n    this.tableAttributes = _.omitBy(this.rawAttributes, (_a, key) => this._virtualAttributes.has(key));\n\n    this.prototype._hasCustomGetters = Object.keys(this.prototype._customGetters).length;\n    this.prototype._hasCustomSetters = Object.keys(this.prototype._customSetters).length;\n\n    for (const key of Object.keys(attributeManipulation)) {\n      if (Object.prototype.hasOwnProperty.call(Model.prototype, key)) {\n        this.sequelize.log(`Not overriding built-in method from model attribute: ${key}`);\n        continue;\n      }\n      Object.defineProperty(this.prototype, key, attributeManipulation[key]);\n    }\n\n    this.prototype.rawAttributes = this.rawAttributes;\n    this.prototype._isAttribute = key => Object.prototype.hasOwnProperty.call(this.prototype.rawAttributes, key);\n\n    // Primary key convenience constiables\n    this.primaryKeyAttributes = Object.keys(this.primaryKeys);\n    this.primaryKeyAttribute = this.primaryKeyAttributes[0];\n    if (this.primaryKeyAttribute) {\n      this.primaryKeyField = this.rawAttributes[this.primaryKeyAttribute].field || this.primaryKeyAttribute;\n    }\n\n    this._hasPrimaryKeys = this.primaryKeyAttributes.length > 0;\n    this._isPrimaryKey = key => this.primaryKeyAttributes.includes(key);\n  }\n\n  /**\n   * Remove attribute from model definition\n   *\n   * @param {string} attribute name of attribute to remove\n   */\n  static removeAttribute(attribute) {\n    delete this.rawAttributes[attribute];\n    this.refreshAttributes();\n  }\n\n  /**\n   * Sync this Model to the DB, that is create the table.\n   *\n   * @param {Object} [options] sync options\n   *\n   * @see\n   * {@link Sequelize#sync} for options\n   *\n   * @returns {Promise<Model>}\n   */\n  static sync(options) {\n    options = Object.assign({}, this.options, options);\n    options.hooks = options.hooks === undefined ? true : !!options.hooks;\n\n    const attributes = this.tableAttributes;\n    const rawAttributes = this.fieldRawAttributesMap;\n\n    return Promise.try(() => {\n      if (options.hooks) {\n        return this.runHooks('beforeSync', options);\n      }\n    }).then(() => {\n      if (options.force) {\n        return this.drop(options);\n      }\n    })\n      .then(() => this.QueryInterface.createTable(this.getTableName(options), attributes, options, this))\n      .then(() => {\n        if (!options.alter) {\n          return;\n        }\n        return Promise.all([\n          this.QueryInterface.describeTable(this.getTableName(options)),\n          this.QueryInterface.getForeignKeyReferencesForTable(this.getTableName(options))\n        ])\n          .then(tableInfos => {\n            const columns = tableInfos[0];\n            // Use for alter foreign keys\n            const foreignKeyReferences = tableInfos[1];\n\n            const changes = []; // array of promises to run\n            const removedConstraints = {};\n\n            _.each(attributes, (columnDesc, columnName) => {\n              if (!columns[columnName] && !columns[attributes[columnName].field]) {\n                changes.push(() => this.QueryInterface.addColumn(this.getTableName(options), attributes[columnName].field || columnName, attributes[columnName]));\n              }\n            });\n            _.each(columns, (columnDesc, columnName) => {\n              const currentAttribute = rawAttributes[columnName];\n              if (!currentAttribute) {\n                changes.push(() => this.QueryInterface.removeColumn(this.getTableName(options), columnName, options));\n              } else if (!currentAttribute.primaryKey) {\n                // Check foreign keys. If it's a foreign key, it should remove constraint first.\n                const references = currentAttribute.references;\n                if (currentAttribute.references) {\n                  const database = this.sequelize.config.database;\n                  const schema = this.sequelize.config.schema;\n                  // Find existed foreign keys\n                  _.each(foreignKeyReferences, foreignKeyReference => {\n                    const constraintName = foreignKeyReference.constraintName;\n                    if (!!constraintName\n                      && foreignKeyReference.tableCatalog === database\n                      && (schema ? foreignKeyReference.tableSchema === schema : true)\n                      && foreignKeyReference.referencedTableName === references.model\n                      && foreignKeyReference.referencedColumnName === references.key\n                      && (schema ? foreignKeyReference.referencedTableSchema === schema : true)\n                      && !removedConstraints[constraintName]) {\n                      // Remove constraint on foreign keys.\n                      changes.push(() => this.QueryInterface.removeConstraint(this.getTableName(options), constraintName, options));\n                      removedConstraints[constraintName] = true;\n                    }\n                  });\n                }\n                changes.push(() => this.QueryInterface.changeColumn(this.getTableName(options), columnName, currentAttribute));\n              }\n            });\n            return Promise.each(changes, f => f());\n          });\n      })\n      .then(() => this.QueryInterface.showIndex(this.getTableName(options), options))\n      .then(indexes => {\n        indexes = this._indexes.filter(item1 =>\n          !indexes.some(item2 => item1.name === item2.name)\n        ).sort((index1, index2) => {\n          if (this.sequelize.options.dialect === 'postgres') {\n          // move concurrent indexes to the bottom to avoid weird deadlocks\n            if (index1.concurrently === true) return 1;\n            if (index2.concurrently === true) return -1;\n          }\n\n          return 0;\n        });\n\n        return Promise.each(indexes, index => this.QueryInterface.addIndex(\n          this.getTableName(options),\n          Object.assign({\n            logging: options.logging,\n            benchmark: options.benchmark,\n            transaction: options.transaction,\n            schema: options.schema\n          }, index),\n          this.tableName\n        ));\n      }).then(() => {\n        if (options.hooks) {\n          return this.runHooks('afterSync', options);\n        }\n      }).return(this);\n  }\n\n  /**\n   * Drop the table represented by this Model\n   *\n   * @param {Object}   [options] drop options\n   * @param {boolean}  [options.cascade=false]   Also drop all objects depending on this table, such as views. Only works in postgres\n   * @param {Function} [options.logging=false]   A function that gets executed while running the query to log the sql.\n   * @param {boolean}  [options.benchmark=false] Pass query execution time in milliseconds as second argument to logging function (options.logging).\n   *\n   * @returns {Promise}\n   */\n  static drop(options) {\n    return this.QueryInterface.dropTable(this.getTableName(options), options);\n  }\n\n  static dropSchema(schema) {\n    return this.QueryInterface.dropSchema(schema);\n  }\n\n  /**\n   * Apply a schema to this model. For postgres, this will actually place the schema in front of the table name - `\"schema\".\"tableName\"`,\n   * while the schema will be prepended to the table name for mysql and sqlite - `'schema.tablename'`.\n   *\n   * This method is intended for use cases where the same model is needed in multiple schemas. In such a use case it is important\n   * to call `model.schema(schema, [options]).sync()` for each model to ensure the models are created in the correct schema.\n   *\n   * If a single default schema per model is needed, set the `options.schema='schema'` parameter during the `define()` call\n   * for the model.\n   *\n   * @param {string}   schema The name of the schema\n   * @param {Object}   [options] schema options\n   * @param {string}   [options.schemaDelimiter='.'] The character(s) that separates the schema name from the table name\n   * @param {Function} [options.logging=false] A function that gets executed while running the query to log the sql.\n   * @param {boolean}  [options.benchmark=false] Pass query execution time in milliseconds as second argument to logging function (options.logging).\n   *\n   * @see\n   * {@link Sequelize#define} for more information about setting a default schema.\n   *\n   * @returns {Model}\n   */\n  static schema(schema, options) {\n\n    const clone = class extends this {};\n    Object.defineProperty(clone, 'name', { value: this.name });\n\n    clone._schema = schema;\n\n    if (options) {\n      if (typeof options === 'string') {\n        clone._schemaDelimiter = options;\n      } else if (options.schemaDelimiter) {\n        clone._schemaDelimiter = options.schemaDelimiter;\n      }\n    }\n\n    return clone;\n  }\n\n  /**\n   * Get the table name of the model, taking schema into account. The method will return The name as a string if the model has no schema,\n   * or an object with `tableName`, `schema` and `delimiter` properties.\n   *\n   * @returns {string|Object}\n   */\n  static getTableName() {\n    return this.QueryGenerator.addSchema(this);\n  }\n\n  /**\n   * Get un-scoped model\n   *\n   * @returns {Model}\n   */\n  static unscoped() {\n    return this.scope();\n  }\n\n  /**\n   * Add a new scope to the model. This is especially useful for adding scopes with includes, when the model you want to include is not available at the time this model is defined.\n   *\n   * By default this will throw an error if a scope with that name already exists. Pass `override: true` in the options object to silence this error.\n   *\n   * @param {string}          name The name of the scope. Use `defaultScope` to override the default scope\n   * @param {Object|Function} scope scope or options\n   * @param {Object}          [options] scope options\n   * @param {boolean}         [options.override=false] override old scope if already defined\n   */\n  static addScope(name, scope, options) {\n    options = Object.assign({\n      override: false\n    }, options);\n\n    if ((name === 'defaultScope' && Object.keys(this.options.defaultScope).length > 0 || name in this.options.scopes) && options.override === false) {\n      throw new Error(`The scope ${name} already exists. Pass { override: true } as options to silence this error`);\n    }\n\n    if (name === 'defaultScope') {\n      this.options.defaultScope = this._scope = scope;\n    } else {\n      this.options.scopes[name] = scope;\n    }\n  }\n\n  /**\n   * Apply a scope created in `define` to the model.\n   *\n   * @example <caption>how to create scopes</caption>\n   * const Model = sequelize.define('model', attributes, {\n   *   defaultScope: {\n   *     where: {\n   *       username: 'dan'\n   *     },\n   *     limit: 12\n   *   },\n   *   scopes: {\n   *     isALie: {\n   *       where: {\n   *         stuff: 'cake'\n   *       }\n   *     },\n   *     complexFunction: function(email, accessLevel) {\n   *       return {\n   *         where: {\n   *           email: {\n   *             [Op.like]: email\n   *           },\n   *           access_level {\n   *             [Op.gte]: accessLevel\n   *           }\n   *         }\n   *       }\n   *     }\n   *   }\n   * })\n   *\n   * # As you have defined a default scope, every time you do Model.find, the default scope is appended to your query. Here's a couple of examples:\n   *\n   * Model.findAll() // WHERE username = 'dan'\n   * Model.findAll({ where: { age: { [Op.gt]: 12 } } }) // WHERE age > 12 AND username = 'dan'\n   *\n   * @example <caption>To invoke scope functions you can do</caption>\n   * Model.scope({ method: ['complexFunction', 'dan@sequelize.com', 42]}).findAll()\n   * // WHERE email like 'dan@sequelize.com%' AND access_level >= 42\n   *\n   * @param {?Array|Object|string} [option] The scope(s) to apply. Scopes can either be passed as consecutive arguments, or as an array of arguments. To apply simple scopes and scope functions with no arguments, pass them as strings. For scope function, pass an object, with a `method` property. The value can either be a string, if the method does not take any arguments, or an array, where the first element is the name of the method, and consecutive elements are arguments to that method. Pass null to remove all scopes, including the default.\n   *\n   * @returns {Model} A reference to the model, with the scope(s) applied. Calling scope again on the returned model will clear the previous scope.\n   */\n  static scope(option) {\n    const self = class extends this {};\n    let scope;\n    let scopeName;\n\n    Object.defineProperty(self, 'name', { value: this.name });\n\n    self._scope = {};\n    self._scopeNames = [];\n    self.scoped = true;\n\n    if (!option) {\n      return self;\n    }\n\n    const options = _.flatten(arguments);\n\n    for (const option of options) {\n      scope = null;\n      scopeName = null;\n\n      if (_.isPlainObject(option)) {\n        if (option.method) {\n          if (Array.isArray(option.method) && !!self.options.scopes[option.method[0]]) {\n            scopeName = option.method[0];\n            scope = self.options.scopes[scopeName].apply(self, option.method.slice(1));\n          }\n          else if (self.options.scopes[option.method]) {\n            scopeName = option.method;\n            scope = self.options.scopes[scopeName].apply(self);\n          }\n        } else {\n          scope = option;\n        }\n      } else if (option === 'defaultScope' && _.isPlainObject(self.options.defaultScope)) {\n        scope = self.options.defaultScope;\n      } else {\n        scopeName = option;\n        scope = self.options.scopes[scopeName];\n        if (typeof scope === 'function') {\n          scope = scope();\n        }\n      }\n\n      if (scope) {\n        this._conformIncludes(scope, this);\n        this._assignOptions(self._scope, scope);\n        self._scopeNames.push(scopeName ? scopeName : 'defaultScope');\n      } else {\n        throw new sequelizeErrors.SequelizeScopeError(`Invalid scope ${scopeName} called.`);\n      }\n    }\n\n    return self;\n  }\n\n  /**\n   * Search for multiple instances.\n   *\n   * @example <caption>Simple search using AND and =</caption>\n   * Model.findAll({\n   *   where: {\n   *     attr1: 42,\n   *     attr2: 'cake'\n   *   }\n   * })\n   *\n   * # WHERE attr1 = 42 AND attr2 = 'cake'\n   *\n   * @example <caption>Using greater than, less than etc.</caption>\n   * const {gt, lte, ne, in: opIn} = Sequelize.Op;\n   *\n   * Model.findAll({\n   *   where: {\n   *     attr1: {\n   *       [gt]: 50\n   *     },\n   *     attr2: {\n   *       [lte]: 45\n   *     },\n   *     attr3: {\n   *       [opIn]: [1,2,3]\n   *     },\n   *     attr4: {\n   *       [ne]: 5\n   *     }\n   *   }\n   * })\n   *\n   * # WHERE attr1 > 50 AND attr2 <= 45 AND attr3 IN (1,2,3) AND attr4 != 5\n   *\n   * @example <caption>Queries using OR</caption>\n   * const {or, and, gt, lt} = Sequelize.Op;\n   *\n   * Model.findAll({\n   *   where: {\n   *     name: 'a project',\n   *     [or]: [\n   *       {id: [1, 2, 3]},\n   *       {\n   *         [and]: [\n   *           {id: {[gt]: 10}},\n   *           {id: {[lt]: 100}}\n   *         ]\n   *       }\n   *     ]\n   *   }\n   * });\n   *\n   * # WHERE `Model`.`name` = 'a project' AND (`Model`.`id` IN (1, 2, 3) OR (`Model`.`id` > 10 AND `Model`.`id` < 100));\n   *\n   * @see\n   * {@link Operators} for possible operators\n   * __Alias__: _all_\n   *\n   * The promise is resolved with an array of Model instances if the query succeeds._\n   *\n   * @param  {Object}                                                    [options] A hash of options to describe the scope of the search\n   * @param  {Object}                                                    [options.where] A hash of attributes to describe your search. See above for examples.\n   * @param  {Array<string>|Object}                                      [options.attributes] A list of the attributes that you want to select, or an object with `include` and `exclude` keys. To rename an attribute, you can pass an array, with two elements - the first is the name of the attribute in the DB (or some kind of expression such as `Sequelize.literal`, `Sequelize.fn` and so on), and the second is the name you want the attribute to have in the returned instance\n   * @param  {Array<string>}                                             [options.attributes.include] Select all the attributes of the model, plus some additional ones. Useful for aggregations, e.g. `{ attributes: { include: [[sequelize.fn('COUNT', sequelize.col('id')), 'total']] }`\n   * @param  {Array<string>}                                             [options.attributes.exclude] Select all the attributes of the model, except some few. Useful for security purposes e.g. `{ attributes: { exclude: ['password'] } }`\n   * @param  {boolean}                                                   [options.paranoid=true] If true, only non-deleted records will be returned. If false, both deleted and non-deleted records will be returned. Only applies if `options.paranoid` is true for the model.\n   * @param  {Array<Object|Model|string>}                                [options.include] A list of associations to eagerly load using a left join. Supported is either `{ include: [ Model1, Model2, ...]}` or `{ include: [{ model: Model1, as: 'Alias' }]}` or `{ include: ['Alias']}`. If your association are set up with an `as` (eg. `X.hasMany(Y, { as: 'Z }`, you need to specify Z in the as attribute when eager loading Y).\n   * @param  {Model}                                                     [options.include[].model] The model you want to eagerly load\n   * @param  {string}                                                    [options.include[].as] The alias of the relation, in case the model you want to eagerly load is aliased. For `hasOne` / `belongsTo`, this should be the singular name, and for `hasMany`, it should be the plural\n   * @param  {Association}                                               [options.include[].association] The association you want to eagerly load. (This can be used instead of providing a model/as pair)\n   * @param  {Object}                                                    [options.include[].where] Where clauses to apply to the child models. Note that this converts the eager load to an inner join, unless you explicitly set `required: false`\n   * @param  {boolean}                                                   [options.include[].or=false] Whether to bind the ON and WHERE clause together by OR instead of AND.\n   * @param  {Object}                                                    [options.include[].on] Supply your own ON condition for the join.\n   * @param  {Array<string>}                                             [options.include[].attributes] A list of attributes to select from the child model\n   * @param  {boolean}                                                   [options.include[].required] If true, converts to an inner join, which means that the parent model will only be loaded if it has any matching children. True if `include.where` is set, false otherwise.\n   * @param  {boolean}                                                   [options.include[].right] If true, converts to a right join if dialect support it. Ignored if `include.required` is true.\n   * @param  {boolean}                                                   [options.include[].separate] If true, runs a separate query to fetch the associated instances, only supported for hasMany associations\n   * @param  {number}                                                    [options.include[].limit] Limit the joined rows, only supported with include.separate=true\n   * @param  {Object}                                                    [options.include[].through.where] Filter on the join model for belongsToMany relations\n   * @param  {Array}                                                     [options.include[].through.attributes] A list of attributes to select from the join model for belongsToMany relations\n   * @param  {Array<Object|Model|string>}                                [options.include[].include] Load further nested related models\n   * @param  {boolean}                                                   [options.include[].duplicating] Mark the include as duplicating, will prevent a subquery from being used.\n   * @param  {Array|Sequelize.fn|Sequelize.col|Sequelize.literal}        [options.order] Specifies an ordering. Using an array, you can provide several columns / functions to order by. Each element can be further wrapped in a two-element array. The first element is the column / function to order by, the second is the direction. For example: `order: [['name', 'DESC']]`. In this way the column will be escaped, but the direction will not.\n   * @param  {number}                                                    [options.limit] Limit for result\n   * @param  {number}                                                    [options.offset] Offset for result\n   * @param  {Transaction}                                               [options.transaction] Transaction to run query under\n   * @param  {string|Object}                                             [options.lock] Lock the selected rows. Possible options are transaction.LOCK.UPDATE and transaction.LOCK.SHARE. Postgres also supports transaction.LOCK.KEY_SHARE, transaction.LOCK.NO_KEY_UPDATE and specific model locks with joins. See [transaction.LOCK for an example](transaction#lock)\n   * @param  {boolean}                                                   [options.skipLocked] Skip locked rows. Only supported in Postgres.\n   * @param  {boolean}                                                   [options.raw] Return raw result. See sequelize.query for more information.\n   * @param  {Function}                                                  [options.logging=false] A function that gets executed while running the query to log the sql.\n   * @param  {boolean}                                                   [options.benchmark=false] Pass query execution time in milliseconds as second argument to logging function (options.logging).\n   * @param  {Object}                                                    [options.having] Having options\n   * @param  {string}                                                    [options.searchPath=DEFAULT] An optional parameter to specify the schema search_path (Postgres only)\n   * @param  {boolean|Error}                                             [options.rejectOnEmpty=false] Throws an error when no records found\n   *\n   * @see\n   * {@link Sequelize#query}\n   *\n   * @returns {Promise<Array<Model>>}\n   */\n  static findAll(options) {\n    if (options !== undefined && !_.isPlainObject(options)) {\n      throw new sequelizeErrors.QueryError('The argument passed to findAll must be an options object, use findByPk if you wish to pass a single primary key value');\n    }\n\n    if (options !== undefined && options.attributes) {\n      if (!Array.isArray(options.attributes) && !_.isPlainObject(options.attributes)) {\n        throw new sequelizeErrors.QueryError('The attributes option must be an array of column names or an object');\n      }\n    }\n\n    this.warnOnInvalidOptions(options, Object.keys(this.rawAttributes));\n\n    const tableNames = {};\n\n    tableNames[this.getTableName(options)] = true;\n    options = Utils.cloneDeep(options);\n\n    _.defaults(options, { hooks: true });\n\n    // set rejectOnEmpty option, defaults to model options\n    options.rejectOnEmpty = Object.prototype.hasOwnProperty.call(options, 'rejectOnEmpty')\n      ? options.rejectOnEmpty\n      : this.options.rejectOnEmpty;\n\n    return Promise.try(() => {\n      this._injectScope(options);\n\n      if (options.hooks) {\n        return this.runHooks('beforeFind', options);\n      }\n    }).then(() => {\n      this._conformIncludes(options, this);\n      this._expandAttributes(options);\n      this._expandIncludeAll(options);\n\n      if (options.hooks) {\n        return this.runHooks('beforeFindAfterExpandIncludeAll', options);\n      }\n    }).then(() => {\n      options.originalAttributes = this._injectDependentVirtualAttributes(options.attributes);\n\n      if (options.include) {\n        options.hasJoin = true;\n\n        this._validateIncludedElements(options, tableNames);\n\n        // If we're not raw, we have to make sure we include the primary key for de-duplication\n        if (\n          options.attributes\n          && !options.raw\n          && this.primaryKeyAttribute\n          && !options.attributes.includes(this.primaryKeyAttribute)\n          && (!options.group || !options.hasSingleAssociation || options.hasMultiAssociation)\n        ) {\n          options.attributes = [this.primaryKeyAttribute].concat(options.attributes);\n        }\n      }\n\n      if (!options.attributes) {\n        options.attributes = Object.keys(this.rawAttributes);\n        options.originalAttributes = this._injectDependentVirtualAttributes(options.attributes);\n      }\n\n      // whereCollection is used for non-primary key updates\n      this.options.whereCollection = options.where || null;\n\n      Utils.mapFinderOptions(options, this);\n\n      options = this._paranoidClause(this, options);\n\n      if (options.hooks) {\n        return this.runHooks('beforeFindAfterOptions', options);\n      }\n    }).then(() => {\n      const selectOptions = Object.assign({}, options, { tableNames: Object.keys(tableNames) });\n      return this.QueryInterface.select(this, this.getTableName(selectOptions), selectOptions);\n    }).tap(results => {\n      if (options.hooks) {\n        return this.runHooks('afterFind', results, options);\n      }\n    }).then(results => {\n\n      //rejectOnEmpty mode\n      if (_.isEmpty(results) && options.rejectOnEmpty) {\n        if (typeof options.rejectOnEmpty === 'function') {\n          throw new options.rejectOnEmpty();\n        }\n        if (typeof options.rejectOnEmpty === 'object') {\n          throw options.rejectOnEmpty;\n        }\n        throw new sequelizeErrors.EmptyResultError();\n      }\n\n      return Model._findSeparate(results, options);\n    });\n  }\n\n  static warnOnInvalidOptions(options, validColumnNames) {\n    if (!_.isPlainObject(options)) {\n      return;\n    }\n\n    const unrecognizedOptions = Object.keys(options).filter(k => !validQueryKeywords.has(k));\n    const unexpectedModelAttributes = _.intersection(unrecognizedOptions, validColumnNames);\n    if (!options.where && unexpectedModelAttributes.length > 0) {\n      logger.warn(`Model attributes (${unexpectedModelAttributes.join(', ')}) passed into finder method options of model ${this.name}, but the options.where object is empty. Did you forget to use options.where?`);\n    }\n  }\n\n  static _injectDependentVirtualAttributes(attributes) {\n    if (!this._hasVirtualAttributes) return attributes;\n    if (!attributes || !Array.isArray(attributes)) return attributes;\n\n    for (const attribute of attributes) {\n      if (\n        this._virtualAttributes.has(attribute)\n        && this.rawAttributes[attribute].type.fields\n      ) {\n        attributes = attributes.concat(this.rawAttributes[attribute].type.fields);\n      }\n    }\n\n    attributes = _.uniq(attributes);\n\n    return attributes;\n  }\n\n  static _findSeparate(results, options) {\n    if (!options.include || options.raw || !results) return Promise.resolve(results);\n\n    const original = results;\n    if (options.plain) results = [results];\n\n    if (!results.length) return original;\n\n    return Promise.map(options.include, include => {\n      if (!include.separate) {\n        return Model._findSeparate(\n          results.reduce((memo, result) => {\n            let associations = result.get(include.association.as);\n\n            // Might be an empty belongsTo relation\n            if (!associations) return memo;\n\n            // Force array so we can concat no matter if it's 1:1 or :M\n            if (!Array.isArray(associations)) associations = [associations];\n\n            for (let i = 0, len = associations.length; i !== len; ++i) {\n              memo.push(associations[i]);\n            }\n            return memo;\n          }, []),\n          Object.assign(\n            {},\n            _.omit(options, 'include', 'attributes', 'order', 'where', 'limit', 'offset', 'plain', 'scope'),\n            { include: include.include || [] }\n          )\n        );\n      }\n\n      return include.association.get(results, Object.assign(\n        {},\n        _.omit(options, nonCascadingOptions),\n        _.omit(include, ['parent', 'association', 'as', 'originalAttributes'])\n      )).then(map => {\n        for (const result of results) {\n          result.set(\n            include.association.as,\n            map[result.get(include.association.sourceKey)],\n            { raw: true }\n          );\n        }\n      });\n    }).return(original);\n  }\n\n  /**\n   * Search for a single instance by its primary key._\n   *\n   * @param  {number|string|Buffer}      param The value of the desired instance's primary key.\n   * @param  {Object}                    [options] find options\n   * @param  {Transaction}               [options.transaction] Transaction to run query under\n   * @param  {string}                    [options.searchPath=DEFAULT] An optional parameter to specify the schema search_path (Postgres only)\n   *\n   * @see\n   * {@link Model.findAll}           for a full explanation of options, Note that options.where is not supported.\n   *\n   * @returns {Promise<Model>}\n   */\n  static findByPk(param, options) {\n    // return Promise resolved with null if no arguments are passed\n    if ([null, undefined].includes(param)) {\n      return Promise.resolve(null);\n    }\n\n    options = Utils.cloneDeep(options) || {};\n\n    if (typeof param === 'number' || typeof param === 'string' || Buffer.isBuffer(param)) {\n      options.where = {\n        [this.primaryKeyAttribute]: param\n      };\n    } else {\n      throw new Error(`Argument passed to findByPk is invalid: ${param}`);\n    }\n\n    // Bypass a possible overloaded findOne\n    return this.findOne(options);\n  }\n\n  /**\n   * Search for a single instance. This applies LIMIT 1, so the listener will always be called with a single instance.\n   *\n   * __Alias__: _find_\n   *\n   * @param  {Object}       [options] A hash of options to describe the scope of the search\n   * @param  {Transaction}  [options.transaction] Transaction to run query under\n   * @param  {string}       [options.searchPath=DEFAULT] An optional parameter to specify the schema search_path (Postgres only)\n   *\n   * @see\n   * {@link Model.findAll} for an explanation of options\n   *\n   * @returns {Promise<Model>}\n   */\n  static findOne(options) {\n    if (options !== undefined && !_.isPlainObject(options)) {\n      throw new Error('The argument passed to findOne must be an options object, use findByPk if you wish to pass a single primary key value');\n    }\n    options = Utils.cloneDeep(options);\n\n    if (options.limit === undefined) {\n      const uniqueSingleColumns = _.chain(this.uniqueKeys).values().filter(c => c.fields.length === 1).map('column').value();\n\n      // Don't add limit if querying directly on the pk or a unique column\n      if (!options.where || !_.some(options.where, (value, key) =>\n        (key === this.primaryKeyAttribute || uniqueSingleColumns.includes(key)) &&\n          (Utils.isPrimitive(value) || Buffer.isBuffer(value))\n      )) {\n        options.limit = 1;\n      }\n    }\n\n    // Bypass a possible overloaded findAll.\n    return this.findAll(_.defaults(options, {\n      plain: true\n    }));\n  }\n\n  /**\n   * Run an aggregation method on the specified field\n   *\n   * @param {string}          attribute The attribute to aggregate over. Can be a field name or *\n   * @param {string}          aggregateFunction The function to use for aggregation, e.g. sum, max etc.\n   * @param {Object}          [options] Query options. See sequelize.query for full options\n   * @param {Object}          [options.where] A hash of search attributes.\n   * @param {Function}        [options.logging=false] A function that gets executed while running the query to log the sql.\n   * @param {boolean}         [options.benchmark=false] Pass query execution time in milliseconds as second argument to logging function (options.logging).\n   * @param {DataTypes|string} [options.dataType] The type of the result. If `field` is a field in this Model, the default will be the type of that field, otherwise defaults to float.\n   * @param {boolean}         [options.distinct] Applies DISTINCT to the field being aggregated over\n   * @param {Transaction}     [options.transaction] Transaction to run query under\n   * @param {boolean}         [options.plain] When `true`, the first returned value of `aggregateFunction` is cast to `dataType` and returned. If additional attributes are specified, along with `group` clauses, set `plain` to `false` to return all values of all returned rows.  Defaults to `true`\n   *\n   * @returns {Promise<DataTypes|Object>} Returns the aggregate result cast to `options.dataType`, unless `options.plain` is false, in which case the complete data result is returned.\n   */\n  static aggregate(attribute, aggregateFunction, options) {\n    options = Utils.cloneDeep(options);\n\n    // We need to preserve attributes here as the `injectScope` call would inject non aggregate columns.\n    const prevAttributes = options.attributes;\n    this._injectScope(options);\n    options.attributes = prevAttributes;\n    this._conformIncludes(options, this);\n\n    if (options.include) {\n      this._expandIncludeAll(options);\n      this._validateIncludedElements(options);\n    }\n\n    const attrOptions = this.rawAttributes[attribute];\n    const field = attrOptions && attrOptions.field || attribute;\n    let aggregateColumn = this.sequelize.col(field);\n\n    if (options.distinct) {\n      aggregateColumn = this.sequelize.fn('DISTINCT', aggregateColumn);\n    }\n\n    let { group } = options;\n    if (Array.isArray(group) && Array.isArray(group[0])) {\n      noDoubleNestedGroup();\n      group = _.flatten(group);\n    }\n    options.attributes = _.unionBy(\n      options.attributes,\n      group,\n      [[this.sequelize.fn(aggregateFunction, aggregateColumn), aggregateFunction]],\n      a => Array.isArray(a) ? a[1] : a\n    );\n\n    if (!options.dataType) {\n      if (attrOptions) {\n        options.dataType = attrOptions.type;\n      } else {\n        // Use FLOAT as fallback\n        options.dataType = new DataTypes.FLOAT();\n      }\n    } else {\n      options.dataType = this.sequelize.normalizeDataType(options.dataType);\n    }\n\n    Utils.mapOptionFieldNames(options, this);\n    options = this._paranoidClause(this, options);\n\n    return this.QueryInterface.rawSelect(this.getTableName(options), options, aggregateFunction, this).then( value => {\n      if (value === null) {\n        return 0;\n      }\n      return value;\n    });\n  }\n\n  /**\n   * Count the number of records matching the provided where clause.\n   *\n   * If you provide an `include` option, the number of matching associations will be counted instead.\n   *\n   * @param {Object}        [options] options\n   * @param {Object}        [options.where] A hash of search attributes.\n   * @param {Object}        [options.include] Include options. See `find` for details\n   * @param {boolean}       [options.paranoid=true] Set `true` to count only non-deleted records. Can be used on models with `paranoid` enabled\n   * @param {boolean}       [options.distinct] Apply COUNT(DISTINCT(col)) on primary key or on options.col.\n   * @param {string}        [options.col] Column on which COUNT() should be applied\n   * @param {Array}         [options.attributes] Used in conjunction with `group`\n   * @param {Array}         [options.group] For creating complex counts. Will return multiple rows as needed.\n   * @param {Transaction}   [options.transaction] Transaction to run query under\n   * @param {Function}      [options.logging=false] A function that gets executed while running the query to log the sql.\n   * @param {boolean}       [options.benchmark=false] Pass query execution time in milliseconds as second argument to logging function (options.logging).\n   * @param {string}        [options.searchPath=DEFAULT] An optional parameter to specify the schema search_path (Postgres only)\n   *\n   * @returns {Promise<number>}\n   */\n  static count(options) {\n    return Promise.try(() => {\n      options = Utils.cloneDeep(options);\n      options = _.defaults(options, { hooks: true });\n      options.raw = true;\n      if (options.hooks) {\n        return this.runHooks('beforeCount', options);\n      }\n    }).then(() => {\n      let col = options.col || '*';\n      if (options.include) {\n        col = `${this.name}.${options.col || this.primaryKeyField}`;\n      }\n\n      options.plain = !options.group;\n      options.dataType = new DataTypes.INTEGER();\n      options.includeIgnoreAttributes = false;\n\n      // No limit, offset or order for the options max be given to count()\n      // Set them to null to prevent scopes setting those values\n      options.limit = null;\n      options.offset = null;\n      options.order = null;\n\n      return this.aggregate(col, 'count', options);\n    });\n  }\n\n  /**\n   * Find all the rows matching your query, within a specified offset / limit, and get the total number of rows matching your query. This is very useful for paging\n   *\n   * @example\n   * Model.findAndCountAll({\n   *   where: ...,\n   *   limit: 12,\n   *   offset: 12\n   * }).then(result => {\n   *   ...\n   * })\n   *\n   * # In the above example, `result.rows` will contain rows 13 through 24, while `result.count` will return the total number of rows that matched your query.\n   *\n   * # When you add includes, only those which are required (either because they have a where clause, or because `required` is explicitly set to true on the include) will be added to the count part.\n   *\n   * # Suppose you want to find all users who have a profile attached:\n   *\n   * User.findAndCountAll({\n   *   include: [\n   *      { model: Profile, required: true}\n   *   ],\n   *   limit 3\n   * });\n   *\n   * # Because the include for `Profile` has `required` set it will result in an inner join, and only the users who have a profile will be counted. If we remove `required` from the include, both users with and without profiles will be counted\n   *\n   * @param {Object} [options] See findAll options\n   *\n   * @see\n   * {@link Model.findAll} for a specification of find and query options\n   * @see\n   * {@link Model.count} for a specification of count options\n   *\n   * @returns {Promise<{count: number, rows: Model[]}>}\n   */\n  static findAndCountAll(options) {\n    if (options !== undefined && !_.isPlainObject(options)) {\n      throw new Error('The argument passed to findAndCountAll must be an options object, use findByPk if you wish to pass a single primary key value');\n    }\n\n    const countOptions = Utils.cloneDeep(options);\n\n    if (countOptions.attributes) {\n      countOptions.attributes = undefined;\n    }\n\n    return Promise.all([\n      this.count(countOptions),\n      this.findAll(options)\n    ])\n      .then(([count, rows]) => ({\n        count,\n        rows: count === 0 ? [] : rows\n      }));\n  }\n\n  /**\n   * Find the maximum value of field\n   *\n   * @param {string} field attribute / field name\n   * @param {Object} [options] See aggregate\n   *\n   * @see\n   * {@link Model.aggregate} for options\n   *\n   * @returns {Promise<*>}\n   */\n  static max(field, options) {\n    return this.aggregate(field, 'max', options);\n  }\n\n  /**\n   * Find the minimum value of field\n   *\n   * @param {string} field attribute / field name\n   * @param {Object} [options] See aggregate\n   *\n   * @see\n   * {@link Model.aggregate} for options\n   *\n   * @returns {Promise<*>}\n   */\n  static min(field, options) {\n    return this.aggregate(field, 'min', options);\n  }\n\n  /**\n   * Find the sum of field\n   *\n   * @param {string} field attribute / field name\n   * @param {Object} [options] See aggregate\n   *\n   * @see\n   * {@link Model.aggregate} for options\n   *\n   * @returns {Promise<number>}\n   */\n  static sum(field, options) {\n    return this.aggregate(field, 'sum', options);\n  }\n\n  /**\n   * Builds a new model instance.\n   *\n   * @param {Object|Array} values An object of key value pairs or an array of such. If an array, the function will return an array of instances.\n   * @param {Object}  [options] Instance build options\n   * @param {boolean} [options.raw=false] If set to true, values will ignore field and virtual setters.\n   * @param {boolean} [options.isNewRecord=true] Is this new record\n   * @param {Array}   [options.include] an array of include options - Used to build prefetched/included model instances. See `set`\n   *\n   * @returns {Model|Array<Model>}\n   */\n  static build(values, options) {\n    if (Array.isArray(values)) {\n      return this.bulkBuild(values, options);\n    }\n    return new this(values, options);\n  }\n\n  static bulkBuild(valueSets, options) {\n    options = Object.assign({\n      isNewRecord: true\n    }, options || {});\n\n    if (!options.includeValidated) {\n      this._conformIncludes(options, this);\n      if (options.include) {\n        this._expandIncludeAll(options);\n        this._validateIncludedElements(options);\n      }\n    }\n\n    if (options.attributes) {\n      options.attributes = options.attributes.map(attribute => Array.isArray(attribute) ? attribute[1] : attribute);\n    }\n\n    return valueSets.map(values => this.build(values, options));\n  }\n\n  /**\n   * Builds a new model instance and calls save on it.\n\n   * @see\n   * {@link Model.build}\n   * @see\n   * {@link Model.save}\n   *\n   * @param {Object}        values hash of data values to create new record with\n   * @param {Object}        [options] build and query options\n   * @param {boolean}       [options.raw=false] If set to true, values will ignore field and virtual setters.\n   * @param {boolean}       [options.isNewRecord=true] Is this new record\n   * @param {Array}         [options.include] an array of include options - Used to build prefetched/included model instances. See `set`\n   * @param {Array}         [options.fields] If set, only columns matching those in fields will be saved\n   * @param {string[]}      [options.fields] An optional array of strings, representing database columns. If fields is provided, only those columns will be validated and saved.\n   * @param {boolean}       [options.silent=false] If true, the updatedAt timestamp will not be updated.\n   * @param {boolean}       [options.validate=true] If false, validations won't be run.\n   * @param {boolean}       [options.hooks=true] Run before and after create / update + validate hooks\n   * @param {Function}      [options.logging=false] A function that gets executed while running the query to log the sql.\n   * @param {boolean}       [options.benchmark=false] Pass query execution time in milliseconds as second argument to logging function (options.logging).\n   * @param {Transaction}   [options.transaction] Transaction to run query under\n   * @param {string}        [options.searchPath=DEFAULT] An optional parameter to specify the schema search_path (Postgres only)\n   * @param {boolean}       [options.returning=true] Return the affected rows (only for postgres)\n   *\n   * @returns {Promise<Model>}\n   *\n   */\n  static create(values, options) {\n    options = Utils.cloneDeep(options || {});\n\n    return this.build(values, {\n      isNewRecord: true,\n      attributes: options.fields,\n      include: options.include,\n      raw: options.raw,\n      silent: options.silent\n    }).save(options);\n  }\n\n  /**\n   * Find a row that matches the query, or build (but don't save) the row if none is found.\n   * The successful result of the promise will be (instance, built)\n   *\n   * @param {Object}   options find options\n   * @param {Object}   options.where A hash of search attributes. If `where` is a plain object it will be appended with defaults to build a new instance.\n   * @param {Object}   [options.defaults] Default values to use if building a new instance\n   * @param {Object}   [options.transaction] Transaction to run query under\n   *\n   * @returns {Promise<Model,boolean>}\n   */\n  static findOrBuild(options) {\n    if (!options || !options.where || arguments.length > 1) {\n      throw new Error(\n        'Missing where attribute in the options parameter passed to findOrBuild. ' +\n        'Please note that the API has changed, and is now options only (an object with where, defaults keys, transaction etc.)'\n      );\n    }\n\n    let values;\n\n    return this.findOne(options).then(instance => {\n      if (instance === null) {\n        values = _.clone(options.defaults) || {};\n        if (_.isPlainObject(options.where)) {\n          values = Utils.defaults(values, options.where);\n        }\n\n        instance = this.build(values, options);\n\n        return Promise.resolve([instance, true]);\n      }\n\n      return Promise.resolve([instance, false]);\n    });\n  }\n\n  /**\n   * Find a row that matches the query, or build and save the row if none is found\n   * The successful result of the promise will be (instance, created)\n   *\n   * If no transaction is passed in the `options` object, a new transaction will be created internally, to prevent the race condition where a matching row is created by another connection after the find but before the insert call.\n   * However, it is not always possible to handle this case in SQLite, specifically if one transaction inserts and another tries to select before the first one has committed. In this case, an instance of sequelize. TimeoutError will be thrown instead.\n   * If a transaction is created, a savepoint will be created instead, and any unique constraint violation will be handled internally.\n   *\n   * @see\n   * {@link Model.findAll} for a full specification of find and options\n   *\n   * @param {Object}      options find and create options\n   * @param {Object}      options.where where A hash of search attributes. If `where` is a plain object it will be appended with defaults to build a new instance.\n   * @param {Object}      [options.defaults] Default values to use if creating a new instance\n   * @param {Transaction} [options.transaction] Transaction to run query under\n   *\n   * @returns {Promise<Model,boolean>}\n   */\n  static findOrCreate(options) {\n    if (!options || !options.where || arguments.length > 1) {\n      throw new Error(\n        'Missing where attribute in the options parameter passed to findOrCreate. ' +\n        'Please note that the API has changed, and is now options only (an object with where, defaults keys, transaction etc.)'\n      );\n    }\n\n    options = Object.assign({}, options);\n\n    if (options.defaults) {\n      const defaults = Object.keys(options.defaults);\n      const unknownDefaults = defaults.filter(name => !this.rawAttributes[name]);\n\n      if (unknownDefaults.length) {\n        logger.warn(`Unknown attributes (${unknownDefaults}) passed to defaults option of findOrCreate`);\n      }\n    }\n\n    if (options.transaction === undefined && this.sequelize.constructor._cls) {\n      const t = this.sequelize.constructor._cls.get('transaction');\n      if (t) {\n        options.transaction = t;\n      }\n    }\n\n    const internalTransaction = !options.transaction;\n    let values;\n    let transaction;\n\n    // Create a transaction or a savepoint, depending on whether a transaction was passed in\n    return this.sequelize.transaction(options).then(t => {\n      transaction = t;\n      options.transaction = t;\n\n      return this.findOne(Utils.defaults({ transaction }, options));\n    }).then(instance => {\n      if (instance !== null) {\n        return [instance, false];\n      }\n\n      values = _.clone(options.defaults) || {};\n      if (_.isPlainObject(options.where)) {\n        values = Utils.defaults(values, options.where);\n      }\n\n      options.exception = true;\n\n      return this.create(values, options).then(instance => {\n        if (instance.get(this.primaryKeyAttribute, { raw: true }) === null) {\n          // If the query returned an empty result for the primary key, we know that this was actually a unique constraint violation\n          throw new sequelizeErrors.UniqueConstraintError();\n        }\n\n        return [instance, true];\n      }).catch(sequelizeErrors.UniqueConstraintError, err => {\n        const flattenedWhere = Utils.flattenObjectDeep(options.where);\n        const flattenedWhereKeys = Object.keys(flattenedWhere).map(name => _.last(name.split('.')));\n        const whereFields = flattenedWhereKeys.map(name => _.get(this.rawAttributes, `${name}.field`, name));\n        const defaultFields = options.defaults && Object.keys(options.defaults)\n          .filter(name => this.rawAttributes[name])\n          .map(name => this.rawAttributes[name].field || name);\n\n        const errFieldKeys = Object.keys(err.fields);\n        const errFieldsWhereIntersects = Utils.intersects(errFieldKeys, whereFields);\n        if (defaultFields && !errFieldsWhereIntersects && Utils.intersects(errFieldKeys, defaultFields)) {\n          throw err;\n        }\n\n        if (errFieldsWhereIntersects) {\n          _.each(err.fields, (value, key) => {\n            const name = this.fieldRawAttributesMap[key].fieldName;\n            if (value.toString() !== options.where[name].toString()) {\n              throw new Error(`${this.name}#findOrCreate: value used for ${name} was not equal for both the find and the create calls, '${options.where[name]}' vs '${value}'`);\n            }\n          });\n        }\n\n        // Someone must have created a matching instance inside the same transaction since we last did a find. Let's find it!\n        return this.findOne(Utils.defaults({\n          transaction: internalTransaction ? null : transaction\n        }, options)).then(instance => {\n          // Sanity check, ideally we caught this at the defaultFeilds/err.fields check\n          // But if we didn't and instance is null, we will throw\n          if (instance === null) throw err;\n          return [instance, false];\n        });\n      });\n    }).finally(() => {\n      if (internalTransaction && transaction) {\n        // If we created a transaction internally (and not just a savepoint), we should clean it up\n        return transaction.commit();\n      }\n    });\n  }\n\n  /**\n   * A more performant findOrCreate that will not work under a transaction (at least not in postgres)\n   * Will execute a find call, if empty then attempt to create, if unique constraint then attempt to find again\n   *\n   * @see\n   * {@link Model.findAll} for a full specification of find and options\n   *\n   * @param {Object} options find options\n   * @param {Object} options.where A hash of search attributes. If `where` is a plain object it will be appended with defaults to build a new instance.\n   * @param {Object} [options.defaults] Default values to use if creating a new instance\n   *\n   * @returns {Promise<Model,boolean>}\n   */\n  static findCreateFind(options) {\n    if (!options || !options.where) {\n      throw new Error(\n        'Missing where attribute in the options parameter passed to findCreateFind.'\n      );\n    }\n\n    let values = _.clone(options.defaults) || {};\n    if (_.isPlainObject(options.where)) {\n      values = Utils.defaults(values, options.where);\n    }\n\n\n    return this.findOne(options).then(result => {\n      if (result) return [result, false];\n\n      return this.create(values, options)\n        .then(result => [result, true])\n        .catch(sequelizeErrors.UniqueConstraintError, () => this.findOne(options).then(result => [result, false]));\n    });\n  }\n\n  /**\n   * Insert or update a single row. An update will be executed if a row which matches the supplied values on either the primary key or a unique key is found. Note that the unique index must be defined in your sequelize model and not just in the table. Otherwise you may experience a unique constraint violation, because sequelize fails to identify the row that should be updated.\n   *\n   * **Implementation details:**\n   *\n   * * MySQL - Implemented as a single query `INSERT values ON DUPLICATE KEY UPDATE values`\n   * * PostgreSQL - Implemented as a temporary function with exception handling: INSERT EXCEPTION WHEN unique_constraint UPDATE\n   * * SQLite - Implemented as two queries `INSERT; UPDATE`. This means that the update is executed regardless of whether the row already existed or not\n   * * MSSQL - Implemented as a single query using `MERGE` and `WHEN (NOT) MATCHED THEN`\n   * **Note** that SQLite returns undefined for created, no matter if the row was created or updated. This is because SQLite always runs INSERT OR IGNORE + UPDATE, in a single query, so there is no way to know whether the row was inserted or not.\n   *\n   * @param  {Object}       values hash of values to upsert\n   * @param  {Object}       [options] upsert options\n   * @param  {boolean}      [options.validate=true] Run validations before the row is inserted\n   * @param  {Array}        [options.fields=Object.keys(this.attributes)] The fields to insert / update. Defaults to all changed fields\n   * @param  {boolean}      [options.hooks=true]  Run before / after upsert hooks?\n   * @param  {boolean}      [options.returning=false] Append RETURNING * to get back auto generated values (Postgres only)\n   * @param  {Transaction}  [options.transaction] Transaction to run query under\n   * @param  {Function}     [options.logging=false] A function that gets executed while running the query to log the sql.\n   * @param  {boolean}      [options.benchmark=false] Pass query execution time in milliseconds as second argument to logging function (options.logging).\n   * @param  {string}       [options.searchPath=DEFAULT] An optional parameter to specify the schema search_path (Postgres only)\n   *\n   * @returns {Promise<boolean>} Returns a boolean indicating whether the row was created or updated. For MySQL/MariaDB, it returns `true` when inserted and `false` when updated. For Postgres/MSSQL with (options.returning=true), it returns record and created boolean with signature `<Model, created>`.\n   */\n  static upsert(values, options) {\n    options = Object.assign({\n      hooks: true,\n      returning: false,\n      validate: true\n    }, Utils.cloneDeep(options || {}));\n\n    options.model = this;\n\n    const createdAtAttr = this._timestampAttributes.createdAt;\n    const updatedAtAttr = this._timestampAttributes.updatedAt;\n    const hasPrimary = this.primaryKeyField in values || this.primaryKeyAttribute in values;\n    const instance = this.build(values);\n\n    if (!options.fields) {\n      options.fields = Object.keys(instance._changed);\n    }\n\n    return Promise.try(() => {\n      if (options.validate) {\n        return instance.validate(options);\n      }\n    }).then(() => {\n      // Map field names\n      const updatedDataValues = _.pick(instance.dataValues, Object.keys(instance._changed));\n      const insertValues = Utils.mapValueFieldNames(instance.dataValues, Object.keys(instance.rawAttributes), this);\n      const updateValues = Utils.mapValueFieldNames(updatedDataValues, options.fields, this);\n      const now = Utils.now(this.sequelize.options.dialect);\n\n      // Attach createdAt\n      if (createdAtAttr && !updateValues[createdAtAttr]) {\n        const field = this.rawAttributes[createdAtAttr].field || createdAtAttr;\n        insertValues[field] = this._getDefaultTimestamp(createdAtAttr) || now;\n      }\n      if (updatedAtAttr && !insertValues[updatedAtAttr]) {\n        const field = this.rawAttributes[updatedAtAttr].field || updatedAtAttr;\n        insertValues[field] = updateValues[field] = this._getDefaultTimestamp(updatedAtAttr) || now;\n      }\n\n      // Build adds a null value for the primary key, if none was given by the user.\n      // We need to remove that because of some Postgres technicalities.\n      if (!hasPrimary && this.primaryKeyAttribute && !this.rawAttributes[this.primaryKeyAttribute].defaultValue) {\n        delete insertValues[this.primaryKeyField];\n        delete updateValues[this.primaryKeyField];\n      }\n\n      return Promise.try(() => {\n        if (options.hooks) {\n          return this.runHooks('beforeUpsert', values, options);\n        }\n      })\n        .then(() => {\n          return this.QueryInterface.upsert(this.getTableName(options), insertValues, updateValues, instance.where(), this, options);\n        })\n        .then(([created, primaryKey]) => {\n          if (options.returning === true && primaryKey) {\n            return this.findByPk(primaryKey, options).then(record => [record, created]);\n          }\n\n          return created;\n        })\n        .tap(result => {\n          if (options.hooks) {\n            return this.runHooks('afterUpsert', result, options);\n          }\n        });\n    });\n  }\n\n  /**\n   * Create and insert multiple instances in bulk.\n   *\n   * The success handler is passed an array of instances, but please notice that these may not completely represent the state of the rows in the DB. This is because MySQL\n   * and SQLite do not make it easy to obtain back automatically generated IDs and other default values in a way that can be mapped to multiple records.\n   * To obtain Instances for the newly created values, you will need to query for them again.\n   *\n   * If validation fails, the promise is rejected with an array-like [AggregateError](http://bluebirdjs.com/docs/api/aggregateerror.html)\n   *\n   * @param  {Array}        records                          List of objects (key/value pairs) to create instances from\n   * @param  {Object}       [options]                        Bulk create options\n   * @param  {Array}        [options.fields]                 Fields to insert (defaults to all fields)\n   * @param  {boolean}      [options.validate=false]         Should each row be subject to validation before it is inserted. The whole insert will fail if one row fails validation\n   * @param  {boolean}      [options.hooks=true]             Run before / after bulk create hooks?\n   * @param  {boolean}      [options.individualHooks=false]  Run before / after create hooks for each individual Instance? BulkCreate hooks will still be run if options.hooks is true.\n   * @param  {boolean}      [options.ignoreDuplicates=false] Ignore duplicate values for primary keys? (not supported by MSSQL or Postgres < 9.5)\n   * @param  {Array}        [options.updateOnDuplicate]      Fields to update if row key already exists (on duplicate key update)? (only supported by MySQL, MariaDB, SQLite >= 3.24.0 & Postgres >= 9.5). By default, all fields are updated.\n   * @param  {Transaction}  [options.transaction]            Transaction to run query under\n   * @param  {Function}     [options.logging=false]          A function that gets executed while running the query to log the sql.\n   * @param  {boolean}      [options.benchmark=false]        Pass query execution time in milliseconds as second argument to logging function (options.logging).\n   * @param  {boolean|Array} [options.returning=false]       If true, append RETURNING * to get back all values; if an array of column names, append RETURNING <columns> to get back specific columns (Postgres only)\n   * @param  {string}       [options.searchPath=DEFAULT]     An optional parameter to specify the schema search_path (Postgres only)\n   *\n   * @returns {Promise<Array<Model>>}\n   */\n  static bulkCreate(records, options = {}) {\n    if (!records.length) {\n      return Promise.resolve([]);\n    }\n\n    const dialect = this.sequelize.options.dialect;\n    const now = Utils.now(this.sequelize.options.dialect);\n\n    options.model = this;\n\n    if (!options.includeValidated) {\n      this._conformIncludes(options, this);\n      if (options.include) {\n        this._expandIncludeAll(options);\n        this._validateIncludedElements(options);\n      }\n    }\n\n    const instances = records.map(values => this.build(values, { isNewRecord: true, include: options.include }));\n\n    const recursiveBulkCreate = (instances, options) => {\n      options = Object.assign({\n        validate: false,\n        hooks: true,\n        individualHooks: false,\n        ignoreDuplicates: false\n      }, options);\n\n      if (options.returning === undefined) {\n        if (options.association) {\n          options.returning = false;\n        } else {\n          options.returning = true;\n        }\n      }\n\n      if (options.ignoreDuplicates && ['mssql'].includes(dialect)) {\n        return Promise.reject(new Error(`${dialect} does not support the ignoreDuplicates option.`));\n      }\n      if (options.updateOnDuplicate && (dialect !== 'mysql' && dialect !== 'mariadb' && dialect !== 'sqlite' && dialect !== 'postgres')) {\n        return Promise.reject(new Error(`${dialect} does not support the updateOnDuplicate option.`));\n      }\n\n      const model = options.model;\n\n      options.fields = options.fields || Object.keys(model.rawAttributes);\n      const createdAtAttr = model._timestampAttributes.createdAt;\n      const updatedAtAttr = model._timestampAttributes.updatedAt;\n\n      if (options.updateOnDuplicate !== undefined) {\n        if (Array.isArray(options.updateOnDuplicate) && options.updateOnDuplicate.length) {\n          options.updateOnDuplicate = _.intersection(\n            _.without(Object.keys(model.tableAttributes), createdAtAttr),\n            options.updateOnDuplicate\n          );\n        } else {\n          return Promise.reject(new Error('updateOnDuplicate option only supports non-empty array.'));\n        }\n      }\n\n      return Promise.try(() => {\n        // Run before hook\n        if (options.hooks) {\n          return model.runHooks('beforeBulkCreate', instances, options);\n        }\n      }).then(() => {\n        // Validate\n        if (options.validate) {\n          const errors = new Promise.AggregateError();\n          const validateOptions = _.clone(options);\n          validateOptions.hooks = options.individualHooks;\n\n          return Promise.map(instances, instance =>\n            instance.validate(validateOptions).catch(err => {\n              errors.push(new sequelizeErrors.BulkRecordError(err, instance));\n            })\n          ).then(() => {\n            delete options.skip;\n            if (errors.length) {\n              throw errors;\n            }\n          });\n        }\n      }).then(() => {\n        if (options.individualHooks) {\n          // Create each instance individually\n          return Promise.map(instances, instance => {\n            const individualOptions = _.clone(options);\n            delete individualOptions.fields;\n            delete individualOptions.individualHooks;\n            delete individualOptions.ignoreDuplicates;\n            individualOptions.validate = false;\n            individualOptions.hooks = true;\n\n            return instance.save(individualOptions);\n          });\n        }\n\n        return Promise.resolve().then(() => {\n          if (!options.include || !options.include.length) return;\n\n          // Nested creation for BelongsTo relations\n          return Promise.map(options.include.filter(include => include.association instanceof BelongsTo), include => {\n            const associationInstances = [];\n            const associationInstanceIndexToInstanceMap = [];\n\n            for (const instance of instances) {\n              const associationInstance = instance.get(include.as);\n              if (associationInstance) {\n                associationInstances.push(associationInstance);\n                associationInstanceIndexToInstanceMap.push(instance);\n              }\n            }\n\n            if (!associationInstances.length) {\n              return;\n            }\n\n            const includeOptions = _(Utils.cloneDeep(include))\n              .omit(['association'])\n              .defaults({\n                transaction: options.transaction,\n                logging: options.logging\n              }).value();\n\n            return recursiveBulkCreate(associationInstances, includeOptions).then(associationInstances => {\n              for (const idx in associationInstances) {\n                const associationInstance = associationInstances[idx];\n                const instance = associationInstanceIndexToInstanceMap[idx];\n\n                instance[include.association.accessors.set](associationInstance, { save: false, logging: options.logging });\n              }\n            });\n          });\n        }).then(() => {\n          // Create all in one query\n          // Recreate records from instances to represent any changes made in hooks or validation\n          records = instances.map(instance => {\n            const values = instance.dataValues;\n\n            // set createdAt/updatedAt attributes\n            if (createdAtAttr && !values[createdAtAttr]) {\n              values[createdAtAttr] = now;\n              if (!options.fields.includes(createdAtAttr)) {\n                options.fields.push(createdAtAttr);\n              }\n            }\n            if (updatedAtAttr && !values[updatedAtAttr]) {\n              values[updatedAtAttr] = now;\n              if (!options.fields.includes(updatedAtAttr)) {\n                options.fields.push(updatedAtAttr);\n              }\n            }\n\n            const out = Object.assign({}, Utils.mapValueFieldNames(values, options.fields, model));\n            for (const key of model._virtualAttributes) {\n              delete out[key];\n            }\n            return out;\n          });\n\n          // Map attributes to fields for serial identification\n          const fieldMappedAttributes = {};\n          for (const attr in model.tableAttributes) {\n            fieldMappedAttributes[model.rawAttributes[attr].field || attr] = model.rawAttributes[attr];\n          }\n\n          // Map updateOnDuplicate attributes to fields\n          if (options.updateOnDuplicate) {\n            options.updateOnDuplicate = options.updateOnDuplicate.map(attr => model.rawAttributes[attr].field || attr);\n            // Get primary keys for postgres to enable updateOnDuplicate\n            options.upsertKeys = _.chain(model.primaryKeys).values().map('field').value();\n            if (Object.keys(model.uniqueKeys).length > 0) {\n              options.upsertKeys = _.chain(model.uniqueKeys).values().filter(c => c.fields.length === 1).map('column').value();\n            }\n          }\n\n          // Map returning attributes to fields\n          if (options.returning && Array.isArray(options.returning)) {\n            options.returning = options.returning.map(attr => model.rawAttributes[attr].field || attr);\n          }\n\n          return model.QueryInterface.bulkInsert(model.getTableName(options), records, options, fieldMappedAttributes).then(results => {\n            if (Array.isArray(results)) {\n              results.forEach((result, i) => {\n                const instance = instances[i];\n\n                for (const key in result) {\n                  if (!instance || key === model.primaryKeyAttribute &&\n                    instance.get(model.primaryKeyAttribute) &&\n                    ['mysql', 'mariadb', 'sqlite'].includes(dialect)) {\n                    // The query.js for these DBs is blind, it autoincrements the\n                    // primarykey value, even if it was set manually. Also, it can\n                    // return more results than instances, bug?.\n                    continue;\n                  }\n                  if (Object.prototype.hasOwnProperty.call(result, key)) {\n                    const record = result[key];\n\n                    const attr = _.find(model.rawAttributes, attribute => attribute.fieldName === key || attribute.field === key);\n\n                    instance.dataValues[attr && attr.fieldName || key] = record;\n                  }\n                }\n              });\n            }\n            return results;\n          });\n        });\n      }).then(() => {\n        if (!options.include || !options.include.length) return;\n\n        // Nested creation for HasOne/HasMany/BelongsToMany relations\n        return Promise.map(options.include.filter(include => !(include.association instanceof BelongsTo ||\n          include.parent && include.parent.association instanceof BelongsToMany)), include => {\n          const associationInstances = [];\n          const associationInstanceIndexToInstanceMap = [];\n\n          for (const instance of instances) {\n            let associated = instance.get(include.as);\n            if (!Array.isArray(associated)) associated = [associated];\n\n            for (const associationInstance of associated) {\n              if (associationInstance) {\n                if (!(include.association instanceof BelongsToMany)) {\n                  associationInstance.set(include.association.foreignKey, instance.get(include.association.sourceKey || instance.constructor.primaryKeyAttribute, { raw: true }), { raw: true });\n                  Object.assign(associationInstance, include.association.scope);\n                }\n                associationInstances.push(associationInstance);\n                associationInstanceIndexToInstanceMap.push(instance);\n              }\n            }\n          }\n\n          if (!associationInstances.length) {\n            return;\n          }\n\n          const includeOptions = _(Utils.cloneDeep(include))\n            .omit(['association'])\n            .defaults({\n              transaction: options.transaction,\n              logging: options.logging\n            }).value();\n\n          return recursiveBulkCreate(associationInstances, includeOptions).then(associationInstances => {\n            if (include.association instanceof BelongsToMany) {\n              const valueSets = [];\n\n              for (const idx in associationInstances) {\n                const associationInstance = associationInstances[idx];\n                const instance = associationInstanceIndexToInstanceMap[idx];\n\n                const values = {};\n                values[include.association.foreignKey] = instance.get(instance.constructor.primaryKeyAttribute, { raw: true });\n                values[include.association.otherKey] = associationInstance.get(associationInstance.constructor.primaryKeyAttribute, { raw: true });\n\n                // Include values defined in the association\n                Object.assign(values, include.association.through.scope);\n                if (associationInstance[include.association.through.model.name]) {\n                  for (const attr of Object.keys(include.association.through.model.rawAttributes)) {\n                    if (include.association.through.model.rawAttributes[attr]._autoGenerated ||\n                      attr === include.association.foreignKey ||\n                      attr === include.association.otherKey ||\n                      typeof associationInstance[include.association.through.model.name][attr] === undefined) {\n                      continue;\n                    }\n                    values[attr] = associationInstance[include.association.through.model.name][attr];\n                  }\n                }\n\n                valueSets.push(values);\n              }\n\n              const throughOptions = _(Utils.cloneDeep(include))\n                .omit(['association', 'attributes'])\n                .defaults({\n                  transaction: options.transaction,\n                  logging: options.logging\n                }).value();\n              throughOptions.model = include.association.throughModel;\n              const throughInstances = include.association.throughModel.bulkBuild(valueSets, throughOptions);\n\n              return recursiveBulkCreate(throughInstances, throughOptions);\n            }\n          });\n        });\n      }).then(() => {\n        // map fields back to attributes\n        instances.forEach(instance => {\n          for (const attr in model.rawAttributes) {\n            if (model.rawAttributes[attr].field &&\n                instance.dataValues[model.rawAttributes[attr].field] !== undefined &&\n                model.rawAttributes[attr].field !== attr\n            ) {\n              instance.dataValues[attr] = instance.dataValues[model.rawAttributes[attr].field];\n              delete instance.dataValues[model.rawAttributes[attr].field];\n            }\n            instance._previousDataValues[attr] = instance.dataValues[attr];\n            instance.changed(attr, false);\n          }\n          instance.isNewRecord = false;\n        });\n\n        // Run after hook\n        if (options.hooks) {\n          return model.runHooks('afterBulkCreate', instances, options);\n        }\n      }).then(() => instances);\n    };\n\n    return recursiveBulkCreate(instances, options);\n  }\n\n  /**\n   * Truncate all instances of the model. This is a convenient method for Model.destroy({ truncate: true }).\n   *\n   * @param {Object}           [options] The options passed to Model.destroy in addition to truncate\n   * @param {boolean|Function} [options.cascade = false] Truncates all tables that have foreign-key references to the named table, or to any tables added to the group due to CASCADE.\n   * @param {boolean}          [options.restartIdentity=false] Automatically restart sequences owned by columns of the truncated table.\n   * @param {Transaction}      [options.transaction] Transaction to run query under\n   * @param {boolean|Function} [options.logging] A function that logs sql queries, or false for no logging\n   * @param {boolean}          [options.benchmark=false] Pass query execution time in milliseconds as second argument to logging function (options.logging).\n   * @param {string}           [options.searchPath=DEFAULT] An optional parameter to specify the schema search_path (Postgres only)\n   *\n   * @returns {Promise}\n   *\n   * @see\n   * {@link Model.destroy} for more information\n   */\n  static truncate(options) {\n    options = Utils.cloneDeep(options) || {};\n    options.truncate = true;\n    return this.destroy(options);\n  }\n\n  /**\n   * Delete multiple instances, or set their deletedAt timestamp to the current time if `paranoid` is enabled.\n   *\n   * @param  {Object}       options                         destroy options\n   * @param  {Object}       [options.where]                 Filter the destroy\n   * @param  {boolean}      [options.hooks=true]            Run before / after bulk destroy hooks?\n   * @param  {boolean}      [options.individualHooks=false] If set to true, destroy will SELECT all records matching the where parameter and will execute before / after destroy hooks on each row\n   * @param  {number}       [options.limit]                 How many rows to delete\n   * @param  {boolean}      [options.force=false]           Delete instead of setting deletedAt to current timestamp (only applicable if `paranoid` is enabled)\n   * @param  {boolean}      [options.truncate=false]        If set to true, dialects that support it will use TRUNCATE instead of DELETE FROM. If a table is truncated the where and limit options are ignored\n   * @param  {boolean}      [options.cascade=false]         Only used in conjunction with TRUNCATE. Truncates  all tables that have foreign-key references to the named table, or to any tables added to the group due to CASCADE.\n   * @param  {boolean}      [options.restartIdentity=false] Only used in conjunction with TRUNCATE. Automatically restart sequences owned by columns of the truncated table.\n   * @param  {Transaction}  [options.transaction] Transaction to run query under\n   * @param  {Function}     [options.logging=false]         A function that gets executed while running the query to log the sql.\n   * @param  {boolean}      [options.benchmark=false]       Pass query execution time in milliseconds as second argument to logging function (options.logging).\n   *\n   * @returns {Promise<number>} The number of destroyed rows\n   */\n  static destroy(options) {\n    options = Utils.cloneDeep(options);\n\n    this._injectScope(options);\n\n    if (!options || !(options.where || options.truncate)) {\n      throw new Error('Missing where or truncate attribute in the options parameter of model.destroy.');\n    }\n\n    if (!options.truncate && !_.isPlainObject(options.where) && !Array.isArray(options.where) && !(options.where instanceof Utils.SequelizeMethod)) {\n      throw new Error('Expected plain object, array or sequelize method in the options.where parameter of model.destroy.');\n    }\n\n    options = _.defaults(options, {\n      hooks: true,\n      individualHooks: false,\n      force: false,\n      cascade: false,\n      restartIdentity: false\n    });\n\n    options.type = QueryTypes.BULKDELETE;\n\n    Utils.mapOptionFieldNames(options, this);\n    options.model = this;\n\n    let instances;\n\n    return Promise.try(() => {\n      // Run before hook\n      if (options.hooks) {\n        return this.runHooks('beforeBulkDestroy', options);\n      }\n    }).then(() => {\n      // Get daos and run beforeDestroy hook on each record individually\n      if (options.individualHooks) {\n        return this.findAll({ where: options.where, transaction: options.transaction, logging: options.logging, benchmark: options.benchmark })\n          .map(instance => this.runHooks('beforeDestroy', instance, options).then(() => instance))\n          .then(_instances => {\n            instances = _instances;\n          });\n      }\n    }).then(() => {\n      // Run delete query (or update if paranoid)\n      if (this._timestampAttributes.deletedAt && !options.force) {\n        // Set query type appropriately when running soft delete\n        options.type = QueryTypes.BULKUPDATE;\n\n        const attrValueHash = {};\n        const deletedAtAttribute = this.rawAttributes[this._timestampAttributes.deletedAt];\n        const field = this.rawAttributes[this._timestampAttributes.deletedAt].field;\n        const where = {\n          [field]: Object.prototype.hasOwnProperty.call(deletedAtAttribute, 'defaultValue') ? deletedAtAttribute.defaultValue : null\n        };\n\n\n        attrValueHash[field] = Utils.now(this.sequelize.options.dialect);\n        return this.QueryInterface.bulkUpdate(this.getTableName(options), attrValueHash, Object.assign(where, options.where), options, this.rawAttributes);\n      }\n      return this.QueryInterface.bulkDelete(this.getTableName(options), options.where, options, this);\n    }).tap(() => {\n      // Run afterDestroy hook on each record individually\n      if (options.individualHooks) {\n        return Promise.map(instances, instance => this.runHooks('afterDestroy', instance, options));\n      }\n    }).tap(() => {\n      // Run after hook\n      if (options.hooks) {\n        return this.runHooks('afterBulkDestroy', options);\n      }\n    });\n  }\n\n  /**\n   * Restore multiple instances if `paranoid` is enabled.\n   *\n   * @param  {Object}       options                         restore options\n   * @param  {Object}       [options.where]                 Filter the restore\n   * @param  {boolean}      [options.hooks=true]            Run before / after bulk restore hooks?\n   * @param  {boolean}      [options.individualHooks=false] If set to true, restore will find all records within the where parameter and will execute before / after bulkRestore hooks on each row\n   * @param  {number}       [options.limit]                 How many rows to undelete (only for mysql)\n   * @param  {Function}     [options.logging=false]         A function that gets executed while running the query to log the sql.\n   * @param  {boolean}      [options.benchmark=false]       Pass query execution time in milliseconds as second argument to logging function (options.logging).\n   * @param  {Transaction}  [options.transaction]           Transaction to run query under\n   *\n   * @returns {Promise}\n   */\n  static restore(options) {\n    if (!this._timestampAttributes.deletedAt) throw new Error('Model is not paranoid');\n\n    options = Object.assign({\n      hooks: true,\n      individualHooks: false\n    }, options || {});\n\n    options.type = QueryTypes.RAW;\n    options.model = this;\n\n    let instances;\n\n    Utils.mapOptionFieldNames(options, this);\n\n    return Promise.try(() => {\n      // Run before hook\n      if (options.hooks) {\n        return this.runHooks('beforeBulkRestore', options);\n      }\n    }).then(() => {\n      // Get daos and run beforeRestore hook on each record individually\n      if (options.individualHooks) {\n        return this.findAll({ where: options.where, transaction: options.transaction, logging: options.logging, benchmark: options.benchmark, paranoid: false })\n          .map(instance => this.runHooks('beforeRestore', instance, options).then(() => instance))\n          .then(_instances => {\n            instances = _instances;\n          });\n      }\n    }).then(() => {\n      // Run undelete query\n      const attrValueHash = {};\n      const deletedAtCol = this._timestampAttributes.deletedAt;\n      const deletedAtAttribute = this.rawAttributes[deletedAtCol];\n      const deletedAtDefaultValue = Object.prototype.hasOwnProperty.call(deletedAtAttribute, 'defaultValue') ? deletedAtAttribute.defaultValue : null;\n\n      attrValueHash[deletedAtAttribute.field || deletedAtCol] = deletedAtDefaultValue;\n      options.omitNull = false;\n      return this.QueryInterface.bulkUpdate(this.getTableName(options), attrValueHash, options.where, options, this.rawAttributes);\n    }).tap(() => {\n      // Run afterDestroy hook on each record individually\n      if (options.individualHooks) {\n        return Promise.map(instances, instance => this.runHooks('afterRestore', instance, options));\n      }\n    }).tap(() => {\n      // Run after hook\n      if (options.hooks) {\n        return this.runHooks('afterBulkRestore', options);\n      }\n    });\n  }\n\n  /**\n   * Update multiple instances that match the where options.\n   *\n   * @param  {Object}       values                          hash of values to update\n   * @param  {Object}       options                         update options\n   * @param  {Object}       options.where                   Options to describe the scope of the search.\n   * @param  {boolean}      [options.paranoid=true]         If true, only non-deleted records will be updated. If false, both deleted and non-deleted records will be updated. Only applies if `options.paranoid` is true for the model.\n   * @param  {Array}        [options.fields]                Fields to update (defaults to all fields)\n   * @param  {boolean}      [options.validate=true]         Should each row be subject to validation before it is inserted. The whole insert will fail if one row fails validation\n   * @param  {boolean}      [options.hooks=true]            Run before / after bulk update hooks?\n   * @param  {boolean}      [options.sideEffects=true]      Whether or not to update the side effects of any virtual setters.\n   * @param  {boolean}      [options.individualHooks=false] Run before / after update hooks?. If true, this will execute a SELECT followed by individual UPDATEs. A select is needed, because the row data needs to be passed to the hooks\n   * @param  {boolean}      [options.returning=false]       Return the affected rows (only for postgres)\n   * @param  {number}       [options.limit]                 How many rows to update (only for mysql and mariadb, implemented as TOP(n) for MSSQL; for sqlite it is supported only when rowid is present)\n   * @param  {Function}     [options.logging=false]         A function that gets executed while running the query to log the sql.\n   * @param  {boolean}      [options.benchmark=false]       Pass query execution time in milliseconds as second argument to logging function (options.logging).\n   * @param  {Transaction}  [options.transaction]           Transaction to run query under\n   * @param  {boolean}      [options.silent=false]          If true, the updatedAt timestamp will not be updated.\n   *\n   * @returns {Promise<Array<number,number>>}  The promise returns an array with one or two elements. The first element is always the number\n   * of affected rows, while the second element is the actual affected rows (only supported in postgres with `options.returning` true.)\n   *\n   */\n  static update(values, options) {\n    options = Utils.cloneDeep(options);\n\n    this._injectScope(options);\n    this._optionsMustContainWhere(options);\n\n    options = this._paranoidClause(this, _.defaults(options, {\n      validate: true,\n      hooks: true,\n      individualHooks: false,\n      returning: false,\n      force: false,\n      sideEffects: true\n    }));\n\n    options.type = QueryTypes.BULKUPDATE;\n\n    // Clone values so it doesn't get modified for caller scope and ignore undefined values\n    values = _.omitBy(values, value => value === undefined);\n\n    // Remove values that are not in the options.fields\n    if (options.fields && options.fields instanceof Array) {\n      for (const key of Object.keys(values)) {\n        if (!options.fields.includes(key)) {\n          delete values[key];\n        }\n      }\n    } else {\n      const updatedAtAttr = this._timestampAttributes.updatedAt;\n      options.fields = _.intersection(Object.keys(values), Object.keys(this.tableAttributes));\n      if (updatedAtAttr && !options.fields.includes(updatedAtAttr)) {\n        options.fields.push(updatedAtAttr);\n      }\n    }\n\n    if (this._timestampAttributes.updatedAt && !options.silent) {\n      values[this._timestampAttributes.updatedAt] = this._getDefaultTimestamp(this._timestampAttributes.updatedAt) || Utils.now(this.sequelize.options.dialect);\n    }\n\n    options.model = this;\n\n    let instances;\n    let valuesUse;\n\n    return Promise.try(() => {\n      // Validate\n      if (options.validate) {\n        const build = this.build(values);\n        build.set(this._timestampAttributes.updatedAt, values[this._timestampAttributes.updatedAt], { raw: true });\n\n        if (options.sideEffects) {\n          values = Object.assign(values, _.pick(build.get(), build.changed()));\n          options.fields = _.union(options.fields, Object.keys(values));\n        }\n\n        // We want to skip validations for all other fields\n        options.skip = _.difference(Object.keys(this.rawAttributes), Object.keys(values));\n        return build.validate(options).then(attributes => {\n          options.skip = undefined;\n          if (attributes && attributes.dataValues) {\n            values = _.pick(attributes.dataValues, Object.keys(values));\n          }\n        });\n      }\n      return null;\n    }).then(() => {\n      // Run before hook\n      if (options.hooks) {\n        options.attributes = values;\n        return this.runHooks('beforeBulkUpdate', options).then(() => {\n          values = options.attributes;\n          delete options.attributes;\n        });\n      }\n      return null;\n    }).then(() => {\n      valuesUse = values;\n\n      // Get instances and run beforeUpdate hook on each record individually\n      if (options.individualHooks) {\n        return this.findAll({\n          where: options.where,\n          transaction: options.transaction,\n          logging: options.logging,\n          benchmark: options.benchmark,\n          paranoid: options.paranoid\n        }).then(_instances => {\n          instances = _instances;\n          if (!instances.length) {\n            return [];\n          }\n\n          // Run beforeUpdate hooks on each record and check whether beforeUpdate hook changes values uniformly\n          // i.e. whether they change values for each record in the same way\n          let changedValues;\n          let different = false;\n\n          return Promise.map(instances, instance => {\n            // Record updates in instances dataValues\n            Object.assign(instance.dataValues, values);\n            // Set the changed fields on the instance\n            _.forIn(valuesUse, (newValue, attr) => {\n              if (newValue !== instance._previousDataValues[attr]) {\n                instance.setDataValue(attr, newValue);\n              }\n            });\n\n            // Run beforeUpdate hook\n            return this.runHooks('beforeUpdate', instance, options).then(() => {\n              if (!different) {\n                const thisChangedValues = {};\n                _.forIn(instance.dataValues, (newValue, attr) => {\n                  if (newValue !== instance._previousDataValues[attr]) {\n                    thisChangedValues[attr] = newValue;\n                  }\n                });\n\n                if (!changedValues) {\n                  changedValues = thisChangedValues;\n                } else {\n                  different = !_.isEqual(changedValues, thisChangedValues);\n                }\n              }\n\n              return instance;\n            });\n          }).then(_instances => {\n            instances = _instances;\n\n            if (!different) {\n              const keys = Object.keys(changedValues);\n              // Hooks do not change values or change them uniformly\n              if (keys.length) {\n                // Hooks change values - record changes in valuesUse so they are executed\n                valuesUse = changedValues;\n                options.fields = _.union(options.fields, keys);\n              }\n              return;\n            }\n            // Hooks change values in a different way for each record\n            // Do not run original query but save each record individually\n            return Promise.map(instances, instance => {\n              const individualOptions = _.clone(options);\n              delete individualOptions.individualHooks;\n              individualOptions.hooks = false;\n              individualOptions.validate = false;\n\n              return instance.save(individualOptions);\n            }).tap(_instances => {\n              instances = _instances;\n            });\n          });\n        });\n      }\n    }).then(results => {\n      // Update already done row-by-row - exit\n      if (results) {\n        return [results.length, results];\n      }\n\n      // only updatedAt is being passed, then skip update\n      if (\n        _.isEmpty(valuesUse)\n         || Object.keys(valuesUse).length === 1 && valuesUse[this._timestampAttributes.updatedAt]\n      ) {\n        return [0];\n      }\n\n      valuesUse = Utils.mapValueFieldNames(valuesUse, options.fields, this);\n      options = Utils.mapOptionFieldNames(options, this);\n      options.hasTrigger = this.options ? this.options.hasTrigger : false;\n\n      // Run query to update all rows\n      return this.QueryInterface.bulkUpdate(this.getTableName(options), valuesUse, options.where, options, this.tableAttributes).then(affectedRows => {\n        if (options.returning) {\n          instances = affectedRows;\n          return [affectedRows.length, affectedRows];\n        }\n\n        return [affectedRows];\n      });\n    }).tap(result => {\n      if (options.individualHooks) {\n        return Promise.map(instances, instance => {\n          return this.runHooks('afterUpdate', instance, options);\n        }).then(() => {\n          result[1] = instances;\n        });\n      }\n    }).tap(() => {\n      // Run after hook\n      if (options.hooks) {\n        options.attributes = values;\n        return this.runHooks('afterBulkUpdate', options).then(() => {\n          delete options.attributes;\n        });\n      }\n    });\n  }\n\n  /**\n   * Run a describe query on the table.\n   *\n   * @param {string} [schema] schema name to search table in\n   * @param {Object} [options] query options\n   *\n   * @returns {Promise} hash of attributes and their types\n   */\n  static describe(schema, options) {\n    return this.QueryInterface.describeTable(this.tableName, Object.assign({ schema: schema || this._schema || undefined }, options));\n  }\n\n  static _getDefaultTimestamp(attr) {\n    if (!!this.rawAttributes[attr] && !!this.rawAttributes[attr].defaultValue) {\n      return Utils.toDefaultValue(this.rawAttributes[attr].defaultValue, this.sequelize.options.dialect);\n    }\n    return undefined;\n  }\n\n  static _expandAttributes(options) {\n    if (!_.isPlainObject(options.attributes)) {\n      return;\n    }\n    let attributes = Object.keys(this.rawAttributes);\n\n    if (options.attributes.exclude) {\n      attributes = attributes.filter(elem => !options.attributes.exclude.includes(elem));\n    }\n\n    if (options.attributes.include) {\n      attributes = attributes.concat(options.attributes.include);\n    }\n\n    options.attributes = attributes;\n  }\n\n  // Inject _scope into options.\n  static _injectScope(options) {\n    const scope = Utils.cloneDeep(this._scope);\n    this._defaultsOptions(options, scope);\n  }\n\n  static [Symbol.for('nodejs.util.inspect.custom')]() {\n    return this.name;\n  }\n\n  static inspect() {\n    return this.name;\n  }\n\n  static hasAlias(alias) {\n    return Object.prototype.hasOwnProperty.call(this.associations, alias);\n  }\n\n  /**\n   * Increment the value of one or more columns. This is done in the database, which means it does not use the values currently stored on the Instance. The increment is done using a\n   * ``` SET column = column + X WHERE foo = 'bar' ``` query. To get the correct value after an increment into the Instance you should do a reload.\n   *\n   * @example <caption>increment number by 1</caption>\n   * Model.increment('number', { where: { foo: 'bar' });\n   *\n   * @example <caption>increment number and count by 2</caption>\n   * Model.increment(['number', 'count'], { by: 2, where: { foo: 'bar' } });\n   *\n   * @example <caption>increment answer by 42, and decrement tries by 1</caption>\n   * // `by` is ignored, as each column has its own value\n   * Model.increment({ answer: 42, tries: -1}, { by: 2, where: { foo: 'bar' } });\n   *\n   * @see\n   * {@link Model#reload}\n   *\n   * @param {string|Array|Object} fields If a string is provided, that column is incremented by the value of `by` given in options. If an array is provided, the same is true for each column. If and object is provided, each column is incremented by the value given.\n   * @param {Object} options increment options\n   * @param {Object} options.where conditions hash\n   * @param {number} [options.by=1] The number to increment by\n   * @param {boolean} [options.silent=false] If true, the updatedAt timestamp will not be updated.\n   * @param {Function} [options.logging=false] A function that gets executed while running the query to log the sql.\n   * @param {Transaction} [options.transaction] Transaction to run query under\n   * @param {string} [options.searchPath=DEFAULT] An optional parameter to specify the schema search_path (Postgres only)\n   *\n   * @returns {Promise<Model[],?number>} returns an array of affected rows and affected count with `options.returning: true`, whenever supported by dialect\n   */\n  static increment(fields, options) {\n    options = options || {};\n\n    this._injectScope(options);\n    this._optionsMustContainWhere(options);\n\n    const updatedAtAttr = this._timestampAttributes.updatedAt;\n    const versionAttr = this._versionAttribute;\n    const updatedAtAttribute = this.rawAttributes[updatedAtAttr];\n    options = Utils.defaults({}, options, {\n      by: 1,\n      attributes: {},\n      where: {},\n      increment: true\n    });\n\n    Utils.mapOptionFieldNames(options, this);\n\n    const where = Object.assign({}, options.where);\n    let values = {};\n\n    if (typeof fields === 'string') {\n      values[fields] = options.by;\n    } else if (Array.isArray(fields)) {\n      fields.forEach(field => {\n        values[field] = options.by;\n      });\n    } else { // Assume fields is key-value pairs\n      values = fields;\n    }\n\n    if (!options.silent && updatedAtAttr && !values[updatedAtAttr]) {\n      options.attributes[updatedAtAttribute.field || updatedAtAttr] = this._getDefaultTimestamp(updatedAtAttr) || Utils.now(this.sequelize.options.dialect);\n    }\n    if (versionAttr) {\n      values[versionAttr] = options.increment ? 1 : -1;\n    }\n\n    for (const attr of Object.keys(values)) {\n      // Field name mapping\n      if (this.rawAttributes[attr] && this.rawAttributes[attr].field && this.rawAttributes[attr].field !== attr) {\n        values[this.rawAttributes[attr].field] = values[attr];\n        delete values[attr];\n      }\n    }\n\n    let promise;\n    if (!options.increment) {\n      promise = this.QueryInterface.decrement(this, this.getTableName(options), values, where, options);\n    } else {\n      promise = this.QueryInterface.increment(this, this.getTableName(options), values, where, options);\n    }\n\n    return promise.then(affectedRows => {\n      if (options.returning) {\n        return [affectedRows, affectedRows.length];\n      }\n\n      return [affectedRows];\n    });\n  }\n\n  /**\n   * Decrement the value of one or more columns. This is done in the database, which means it does not use the values currently stored on the Instance. The decrement is done using a\n   * ```sql SET column = column - X WHERE foo = 'bar'``` query. To get the correct value after a decrement into the Instance you should do a reload.\n   *\n   * @example <caption>decrement number by 1</caption>\n   * Model.decrement('number', { where: { foo: 'bar' });\n   *\n   * @example <caption>decrement number and count by 2</caption>\n   * Model.decrement(['number', 'count'], { by: 2, where: { foo: 'bar' } });\n   *\n   * @example <caption>decrement answer by 42, and decrement tries by -1</caption>\n   * // `by` is ignored, since each column has its own value\n   * Model.decrement({ answer: 42, tries: -1}, { by: 2, where: { foo: 'bar' } });\n   *\n   * @param {string|Array|Object} fields If a string is provided, that column is incremented by the value of `by` given in options. If an array is provided, the same is true for each column. If and object is provided, each column is incremented by the value given.\n   * @param {Object} options decrement options, similar to increment\n   *\n   * @see\n   * {@link Model.increment}\n   * @see\n   * {@link Model#reload}\n   * @since 4.36.0\n\n   * @returns {Promise<Model[],?number>} returns an array of affected rows and affected count with `options.returning: true`, whenever supported by dialect\n   */\n  static decrement(fields, options) {\n    options = _.defaults({ increment: false }, options, {\n      by: 1\n    });\n\n    return this.increment(fields, options);\n  }\n\n  static _optionsMustContainWhere(options) {\n    assert(options && options.where, 'Missing where attribute in the options parameter');\n    assert(_.isPlainObject(options.where) || Array.isArray(options.where) || options.where instanceof Utils.SequelizeMethod,\n      'Expected plain object, array or sequelize method in the options.where parameter');\n  }\n\n  /**\n   * Get an object representing the query for this instance, use with `options.where`\n   *\n   * @param {boolean} [checkVersion=false] include version attribute in where hash\n   *\n   * @returns {Object}\n   */\n  where(checkVersion) {\n    const where = this.constructor.primaryKeyAttributes.reduce((result, attribute) => {\n      result[attribute] = this.get(attribute, { raw: true });\n      return result;\n    }, {});\n\n    if (_.size(where) === 0) {\n      return this._modelOptions.whereCollection;\n    }\n    const versionAttr = this.constructor._versionAttribute;\n    if (checkVersion && versionAttr) {\n      where[versionAttr] = this.get(versionAttr, { raw: true });\n    }\n    return Utils.mapWhereFieldNames(where, this.constructor);\n  }\n\n  toString() {\n    return `[object SequelizeInstance:${this.constructor.name}]`;\n  }\n\n  /**\n   * Get the value of the underlying data value\n   *\n   * @param {string} key key to look in instance data store\n   *\n   * @returns {any}\n   */\n  getDataValue(key) {\n    return this.dataValues[key];\n  }\n\n  /**\n   * Update the underlying data value\n   *\n   * @param {string} key key to set in instance data store\n   * @param {any} value new value for given key\n   *\n   */\n  setDataValue(key, value) {\n    const originalValue = this._previousDataValues[key];\n\n    if (!Utils.isPrimitive(value) && value !== null || value !== originalValue) {\n      this.changed(key, true);\n    }\n\n    this.dataValues[key] = value;\n  }\n\n  /**\n   * If no key is given, returns all values of the instance, also invoking virtual getters.\n   *\n   * If key is given and a field or virtual getter is present for the key it will call that getter - else it will return the value for key.\n   *\n   * @param {string}  [key] key to get value of\n   * @param {Object}  [options] get options\n   * @param {boolean} [options.plain=false] If set to true, included instances will be returned as plain objects\n   * @param {boolean} [options.raw=false] If set to true, field and virtual setters will be ignored\n   *\n   * @returns {Object|any}\n   */\n  get(key, options) {\n    if (options === undefined && typeof key === 'object') {\n      options = key;\n      key = undefined;\n    }\n\n    options = options || {};\n\n    if (key) {\n      if (Object.prototype.hasOwnProperty.call(this._customGetters, key) && !options.raw) {\n        return this._customGetters[key].call(this, key, options);\n      }\n\n      if (options.plain && this._options.include && this._options.includeNames.includes(key)) {\n        if (Array.isArray(this.dataValues[key])) {\n          return this.dataValues[key].map(instance => instance.get(options));\n        }\n        if (this.dataValues[key] instanceof Model) {\n          return this.dataValues[key].get(options);\n        }\n        return this.dataValues[key];\n      }\n\n      return this.dataValues[key];\n    }\n\n    if (\n      this._hasCustomGetters\n      || options.plain && this._options.include\n      || options.clone\n    ) {\n      const values = {};\n      let _key;\n\n      if (this._hasCustomGetters) {\n        for (_key in this._customGetters) {\n          if (\n            this._options.attributes\n            && !this._options.attributes.includes(_key)\n          ) {\n            continue;\n          }\n\n          if (Object.prototype.hasOwnProperty.call(this._customGetters, _key)) {\n            values[_key] = this.get(_key, options);\n          }\n        }\n      }\n\n      for (_key in this.dataValues) {\n        if (\n          !Object.prototype.hasOwnProperty.call(values, _key)\n          && Object.prototype.hasOwnProperty.call(this.dataValues, _key)\n        ) {\n          values[_key] = this.get(_key, options);\n        }\n      }\n\n      return values;\n    }\n\n    return this.dataValues;\n  }\n\n  /**\n   * Set is used to update values on the instance (the sequelize representation of the instance that is, remember that nothing will be persisted before you actually call `save`).\n   * In its most basic form `set` will update a value stored in the underlying `dataValues` object. However, if a custom setter function is defined for the key, that function\n   * will be called instead. To bypass the setter, you can pass `raw: true` in the options object.\n   *\n   * If set is called with an object, it will loop over the object, and call set recursively for each key, value pair. If you set raw to true, the underlying dataValues will either be\n   * set directly to the object passed, or used to extend dataValues, if dataValues already contain values.\n   *\n   * When set is called, the previous value of the field is stored and sets a changed flag(see `changed`).\n   *\n   * Set can also be used to build instances for associations, if you have values for those.\n   * When using set with associations you need to make sure the property key matches the alias of the association\n   * while also making sure that the proper include options have been set (from .build() or .findOne())\n   *\n   * If called with a dot.separated key on a JSON/JSONB attribute it will set the value nested and flag the entire object as changed.\n   *\n   * @see\n   * {@link Model.findAll} for more information about includes\n   *\n   * @param {string|Object} key key to set, it can be string or object. When string it will set that key, for object it will loop over all object properties nd set them.\n   * @param {any} value value to set\n   * @param {Object} [options] set options\n   * @param {boolean} [options.raw=false] If set to true, field and virtual setters will be ignored\n   * @param {boolean} [options.reset=false] Clear all previously set data values\n   *\n   * @returns {Model}\n   */\n  set(key, value, options) {\n    let values;\n    let originalValue;\n\n    if (typeof key === 'object' && key !== null) {\n      values = key;\n      options = value || {};\n\n      if (options.reset) {\n        this.dataValues = {};\n        for (const key in values) {\n          this.changed(key, false);\n        }\n      }\n\n      // If raw, and we're not dealing with includes or special attributes, just set it straight on the dataValues object\n      if (options.raw && !(this._options && this._options.include) && !(options && options.attributes) && !this.constructor._hasDateAttributes && !this.constructor._hasBooleanAttributes) {\n        if (Object.keys(this.dataValues).length) {\n          this.dataValues = Object.assign(this.dataValues, values);\n        } else {\n          this.dataValues = values;\n        }\n        // If raw, .changed() shouldn't be true\n        this._previousDataValues = _.clone(this.dataValues);\n      } else {\n        // Loop and call set\n        if (options.attributes) {\n          const setKeys = data => {\n            for (const k of data) {\n              if (values[k] === undefined) {\n                continue;\n              }\n              this.set(k, values[k], options);\n            }\n          };\n          setKeys(options.attributes);\n          if (this.constructor._hasVirtualAttributes) {\n            setKeys(this.constructor._virtualAttributes);\n          }\n          if (this._options.includeNames) {\n            setKeys(this._options.includeNames);\n          }\n        } else {\n          for (const key in values) {\n            this.set(key, values[key], options);\n          }\n        }\n\n        if (options.raw) {\n          // If raw, .changed() shouldn't be true\n          this._previousDataValues = _.clone(this.dataValues);\n        }\n      }\n      return this;\n    }\n    if (!options)\n      options = {};\n    if (!options.raw) {\n      originalValue = this.dataValues[key];\n    }\n\n    // If not raw, and there's a custom setter\n    if (!options.raw && this._customSetters[key]) {\n      this._customSetters[key].call(this, value, key);\n      // custom setter should have changed value, get that changed value\n      // TODO: v5 make setters return new value instead of changing internal store\n      const newValue = this.dataValues[key];\n      if (!Utils.isPrimitive(newValue) && newValue !== null || newValue !== originalValue) {\n        this._previousDataValues[key] = originalValue;\n        this.changed(key, true);\n      }\n    } else {\n      // Check if we have included models, and if this key matches the include model names/aliases\n      if (this._options && this._options.include && this._options.includeNames.includes(key)) {\n        // Pass it on to the include handler\n        this._setInclude(key, value, options);\n        return this;\n      }\n      // Bunch of stuff we won't do when it's raw\n      if (!options.raw) {\n        // If attribute is not in model definition, return\n        if (!this._isAttribute(key)) {\n          if (key.includes('.') && this.constructor._jsonAttributes.has(key.split('.')[0])) {\n            const previousNestedValue = Dottie.get(this.dataValues, key);\n            if (!_.isEqual(previousNestedValue, value)) {\n              Dottie.set(this.dataValues, key, value);\n              this.changed(key.split('.')[0], true);\n            }\n          }\n          return this;\n        }\n\n        // If attempting to set primary key and primary key is already defined, return\n        if (this.constructor._hasPrimaryKeys && originalValue && this.constructor._isPrimaryKey(key)) {\n          return this;\n        }\n\n        // If attempting to set read only attributes, return\n        if (!this.isNewRecord && this.constructor._hasReadOnlyAttributes && this.constructor._readOnlyAttributes.has(key)) {\n          return this;\n        }\n      }\n\n      // If there's a data type sanitizer\n      if (\n        !(value instanceof Utils.SequelizeMethod)\n        && Object.prototype.hasOwnProperty.call(this.constructor._dataTypeSanitizers, key)\n      ) {\n        value = this.constructor._dataTypeSanitizers[key].call(this, value, options);\n      }\n\n      // Set when the value has changed and not raw\n      if (\n        !options.raw &&\n        (\n          // True when sequelize method\n          value instanceof Utils.SequelizeMethod ||\n          // Check for data type type comparators\n          !(value instanceof Utils.SequelizeMethod) && this.constructor._dataTypeChanges[key] && this.constructor._dataTypeChanges[key].call(this, value, originalValue, options) ||\n          // Check default\n          !this.constructor._dataTypeChanges[key] && (!Utils.isPrimitive(value) && value !== null || value !== originalValue)\n        )\n      ) {\n        this._previousDataValues[key] = originalValue;\n        this.changed(key, true);\n      }\n\n      // set data value\n      this.dataValues[key] = value;\n    }\n    return this;\n  }\n\n  setAttributes(updates) {\n    return this.set(updates);\n  }\n\n  /**\n   * If changed is called with a string it will return a boolean indicating whether the value of that key in `dataValues` is different from the value in `_previousDataValues`.\n   *\n   * If changed is called without an argument, it will return an array of keys that have changed.\n   *\n   * If changed is called without an argument and no keys have changed, it will return `false`.\n   *\n   * @param {string} [key] key to check or change status of\n   * @param {any} [value] value to set\n   *\n   * @returns {boolean|Array}\n   */\n  changed(key, value) {\n    if (key) {\n      if (value !== undefined) {\n        this._changed[key] = value;\n        return this;\n      }\n      return this._changed[key] || false;\n    }\n\n    const changed = Object.keys(this.dataValues).filter(key => this.changed(key));\n\n    return changed.length ? changed : false;\n  }\n\n  /**\n   * Returns the previous value for key from `_previousDataValues`.\n   *\n   * If called without a key, returns the previous values for all values which have changed\n   *\n   * @param {string} [key] key to get previous value of\n   *\n   * @returns {any|Array<any>}\n   */\n  previous(key) {\n    if (key) {\n      return this._previousDataValues[key];\n    }\n\n    return _.pickBy(this._previousDataValues, (value, key) => this.changed(key));\n  }\n\n  _setInclude(key, value, options) {\n    if (!Array.isArray(value)) value = [value];\n    if (value[0] instanceof Model) {\n      value = value.map(instance => instance.dataValues);\n    }\n\n    const include = this._options.includeMap[key];\n    const association = include.association;\n    const accessor = key;\n    const primaryKeyAttribute = include.model.primaryKeyAttribute;\n    const childOptions = {\n      isNewRecord: this.isNewRecord,\n      include: include.include,\n      includeNames: include.includeNames,\n      includeMap: include.includeMap,\n      includeValidated: true,\n      raw: options.raw,\n      attributes: include.originalAttributes\n    };\n    let isEmpty;\n\n    if (include.originalAttributes === undefined || include.originalAttributes.length) {\n      if (association.isSingleAssociation) {\n        if (Array.isArray(value)) {\n          value = value[0];\n        }\n        isEmpty = value && value[primaryKeyAttribute] === null || value === null;\n        this[accessor] = this.dataValues[accessor] = isEmpty ? null : include.model.build(value, childOptions);\n      } else {\n        isEmpty = value[0] && value[0][primaryKeyAttribute] === null;\n        this[accessor] = this.dataValues[accessor] = isEmpty ? [] : include.model.bulkBuild(value, childOptions);\n      }\n    }\n  }\n\n  /**\n   * Validate this instance, and if the validation passes, persist it to the database. It will only save changed fields, and do nothing if no fields have changed.\n   *\n   * On success, the callback will be called with this instance. On validation error, the callback will be called with an instance of `Sequelize.ValidationError`.\n   * This error will have a property for each of the fields for which validation failed, with the error message for that field.\n   *\n   * @param {Object}      [options] save options\n   * @param {string[]}    [options.fields] An optional array of strings, representing database columns. If fields is provided, only those columns will be validated and saved.\n   * @param {boolean}     [options.silent=false] If true, the updatedAt timestamp will not be updated.\n   * @param {boolean}     [options.validate=true] If false, validations won't be run.\n   * @param {boolean}     [options.hooks=true] Run before and after create / update + validate hooks\n   * @param {Function}    [options.logging=false] A function that gets executed while running the query to log the sql.\n   * @param {Transaction} [options.transaction] Transaction to run query under\n   * @param {string}      [options.searchPath=DEFAULT] An optional parameter to specify the schema search_path (Postgres only)\n   * @param {boolean}     [options.returning] Append RETURNING * to get back auto generated values (Postgres only)\n   *\n   * @returns {Promise<Model>}\n   */\n  save(options) {\n    if (arguments.length > 1) {\n      throw new Error('The second argument was removed in favor of the options object.');\n    }\n\n    options = Utils.cloneDeep(options);\n    options = _.defaults(options, {\n      hooks: true,\n      validate: true\n    });\n\n    if (!options.fields) {\n      if (this.isNewRecord) {\n        options.fields = Object.keys(this.constructor.rawAttributes);\n      } else {\n        options.fields = _.intersection(this.changed(), Object.keys(this.constructor.rawAttributes));\n      }\n\n      options.defaultFields = options.fields;\n    }\n\n    if (options.returning === undefined) {\n      if (options.association) {\n        options.returning = false;\n      } else if (this.isNewRecord) {\n        options.returning = true;\n      }\n    }\n\n    const primaryKeyName = this.constructor.primaryKeyAttribute;\n    const primaryKeyAttribute = primaryKeyName && this.constructor.rawAttributes[primaryKeyName];\n    const createdAtAttr = this.constructor._timestampAttributes.createdAt;\n    const versionAttr = this.constructor._versionAttribute;\n    const hook = this.isNewRecord ? 'Create' : 'Update';\n    const wasNewRecord = this.isNewRecord;\n    const now = Utils.now(this.sequelize.options.dialect);\n    let updatedAtAttr = this.constructor._timestampAttributes.updatedAt;\n\n    if (updatedAtAttr && options.fields.length >= 1 && !options.fields.includes(updatedAtAttr)) {\n      options.fields.push(updatedAtAttr);\n    }\n    if (versionAttr && options.fields.length >= 1 && !options.fields.includes(versionAttr)) {\n      options.fields.push(versionAttr);\n    }\n\n    if (options.silent === true && !(this.isNewRecord && this.get(updatedAtAttr, { raw: true }))) {\n      // UpdateAtAttr might have been added as a result of Object.keys(Model.rawAttributes). In that case we have to remove it again\n      _.remove(options.fields, val => val === updatedAtAttr);\n      updatedAtAttr = false;\n    }\n\n    if (this.isNewRecord === true) {\n      if (createdAtAttr && !options.fields.includes(createdAtAttr)) {\n        options.fields.push(createdAtAttr);\n      }\n\n      if (primaryKeyAttribute && primaryKeyAttribute.defaultValue && !options.fields.includes(primaryKeyName)) {\n        options.fields.unshift(primaryKeyName);\n      }\n    }\n\n    if (this.isNewRecord === false) {\n      if (primaryKeyName && this.get(primaryKeyName, { raw: true }) === undefined) {\n        throw new Error('You attempted to save an instance with no primary key, this is not allowed since it would result in a global update');\n      }\n    }\n\n    if (updatedAtAttr && !options.silent && options.fields.includes(updatedAtAttr)) {\n      this.dataValues[updatedAtAttr] = this.constructor._getDefaultTimestamp(updatedAtAttr) || now;\n    }\n\n    if (this.isNewRecord && createdAtAttr && !this.dataValues[createdAtAttr]) {\n      this.dataValues[createdAtAttr] = this.constructor._getDefaultTimestamp(createdAtAttr) || now;\n    }\n\n    return Promise.try(() => {\n      // Validate\n      if (options.validate) {\n        return this.validate(options);\n      }\n    }).then(() => {\n      // Run before hook\n      if (options.hooks) {\n        const beforeHookValues = _.pick(this.dataValues, options.fields);\n        let ignoreChanged = _.difference(this.changed(), options.fields); // In case of update where it's only supposed to update the passed values and the hook values\n        let hookChanged;\n        let afterHookValues;\n\n        if (updatedAtAttr && options.fields.includes(updatedAtAttr)) {\n          ignoreChanged = _.without(ignoreChanged, updatedAtAttr);\n        }\n\n        return this.constructor.runHooks(`before${hook}`, this, options)\n          .then(() => {\n            if (options.defaultFields && !this.isNewRecord) {\n              afterHookValues = _.pick(this.dataValues, _.difference(this.changed(), ignoreChanged));\n\n              hookChanged = [];\n              for (const key of Object.keys(afterHookValues)) {\n                if (afterHookValues[key] !== beforeHookValues[key]) {\n                  hookChanged.push(key);\n                }\n              }\n\n              options.fields = _.uniq(options.fields.concat(hookChanged));\n            }\n\n            if (hookChanged) {\n              if (options.validate) {\n              // Validate again\n\n                options.skip = _.difference(Object.keys(this.constructor.rawAttributes), hookChanged);\n                return this.validate(options).then(() => {\n                  delete options.skip;\n                });\n              }\n            }\n          });\n      }\n    }).then(() => {\n      if (!options.fields.length) return this;\n      if (!this.isNewRecord) return this;\n      if (!this._options.include || !this._options.include.length) return this;\n\n      // Nested creation for BelongsTo relations\n      return Promise.map(this._options.include.filter(include => include.association instanceof BelongsTo), include => {\n        const instance = this.get(include.as);\n        if (!instance) return Promise.resolve();\n\n        const includeOptions = _(Utils.cloneDeep(include))\n          .omit(['association'])\n          .defaults({\n            transaction: options.transaction,\n            logging: options.logging,\n            parentRecord: this\n          }).value();\n\n        return instance.save(includeOptions).then(() => this[include.association.accessors.set](instance, { save: false, logging: options.logging }));\n      });\n    }).then(() => {\n      const realFields = options.fields.filter(field => !this.constructor._virtualAttributes.has(field));\n      if (!realFields.length) return this;\n      if (!this.changed() && !this.isNewRecord) return this;\n\n      const versionFieldName = _.get(this.constructor.rawAttributes[versionAttr], 'field') || versionAttr;\n      let values = Utils.mapValueFieldNames(this.dataValues, options.fields, this.constructor);\n      let query = null;\n      let args = [];\n      let where;\n\n      if (this.isNewRecord) {\n        query = 'insert';\n        args = [this, this.constructor.getTableName(options), values, options];\n      } else {\n        where = this.where(true);\n        if (versionAttr) {\n          values[versionFieldName] = parseInt(values[versionFieldName], 10) + 1;\n        }\n        query = 'update';\n        args = [this, this.constructor.getTableName(options), values, where, options];\n      }\n\n      return this.constructor.QueryInterface[query](...args)\n        .then(([result, rowsUpdated])=> {\n          if (versionAttr) {\n            // Check to see that a row was updated, otherwise it's an optimistic locking error.\n            if (rowsUpdated < 1) {\n              throw new sequelizeErrors.OptimisticLockError({\n                modelName: this.constructor.name,\n                values,\n                where\n              });\n            } else {\n              result.dataValues[versionAttr] = values[versionFieldName];\n            }\n          }\n\n          // Transfer database generated values (defaults, autoincrement, etc)\n          for (const attr of Object.keys(this.constructor.rawAttributes)) {\n            if (this.constructor.rawAttributes[attr].field &&\n                values[this.constructor.rawAttributes[attr].field] !== undefined &&\n                this.constructor.rawAttributes[attr].field !== attr\n            ) {\n              values[attr] = values[this.constructor.rawAttributes[attr].field];\n              delete values[this.constructor.rawAttributes[attr].field];\n            }\n          }\n          values = Object.assign(values, result.dataValues);\n\n          result.dataValues = Object.assign(result.dataValues, values);\n          return result;\n        })\n        .tap(() => {\n          if (!wasNewRecord) return this;\n          if (!this._options.include || !this._options.include.length) return this;\n\n          // Nested creation for HasOne/HasMany/BelongsToMany relations\n          return Promise.map(this._options.include.filter(include => !(include.association instanceof BelongsTo ||\n            include.parent && include.parent.association instanceof BelongsToMany)), include => {\n            let instances = this.get(include.as);\n\n            if (!instances) return Promise.resolve();\n            if (!Array.isArray(instances)) instances = [instances];\n            if (!instances.length) return Promise.resolve();\n\n            const includeOptions = _(Utils.cloneDeep(include))\n              .omit(['association'])\n              .defaults({\n                transaction: options.transaction,\n                logging: options.logging,\n                parentRecord: this\n              }).value();\n\n            // Instances will be updated in place so we can safely treat HasOne like a HasMany\n            return Promise.map(instances, instance => {\n              if (include.association instanceof BelongsToMany) {\n                return instance.save(includeOptions).then(() => {\n                  const values = {};\n                  values[include.association.foreignKey] = this.get(this.constructor.primaryKeyAttribute, { raw: true });\n                  values[include.association.otherKey] = instance.get(instance.constructor.primaryKeyAttribute, { raw: true });\n\n                  // Include values defined in the association\n                  Object.assign(values, include.association.through.scope);\n                  if (instance[include.association.through.model.name]) {\n                    for (const attr of Object.keys(include.association.through.model.rawAttributes)) {\n                      if (include.association.through.model.rawAttributes[attr]._autoGenerated ||\n                        attr === include.association.foreignKey ||\n                        attr === include.association.otherKey ||\n                        typeof instance[include.association.through.model.name][attr] === undefined) {\n                        continue;\n                      }\n                      values[attr] = instance[include.association.through.model.name][attr];\n                    }\n                  }\n\n                  return include.association.throughModel.create(values, includeOptions);\n                });\n              }\n              instance.set(include.association.foreignKey, this.get(include.association.sourceKey || this.constructor.primaryKeyAttribute, { raw: true }), { raw: true });\n              Object.assign(instance, include.association.scope);\n              return instance.save(includeOptions);\n            });\n          });\n        })\n        .tap(result => {\n          // Run after hook\n          if (options.hooks) {\n            return this.constructor.runHooks(`after${hook}`, result, options);\n          }\n        })\n        .then(result => {\n          for (const field of options.fields) {\n            result._previousDataValues[field] = result.dataValues[field];\n            this.changed(field, false);\n          }\n          this.isNewRecord = false;\n          return result;\n        });\n    });\n  }\n\n  /**\n   * Refresh the current instance in-place, i.e. update the object with current data from the DB and return the same object.\n   * This is different from doing a `find(Instance.id)`, because that would create and return a new instance. With this method,\n   * all references to the Instance are updated with the new data and no new objects are created.\n   *\n   * @see\n   * {@link Model.findAll}\n   *\n   * @param {Object} [options] Options that are passed on to `Model.find`\n   * @param {Function} [options.logging=false] A function that gets executed while running the query to log the sql.\n   *\n   * @returns {Promise<Model>}\n   */\n  reload(options) {\n    options = Utils.defaults({}, options, {\n      where: this.where(),\n      include: this._options.include || null\n    });\n\n    return this.constructor.findOne(options)\n      .tap(reload => {\n        if (!reload) {\n          throw new sequelizeErrors.InstanceError(\n            'Instance could not be reloaded because it does not exist anymore (find call returned null)'\n          );\n        }\n      })\n      .then(reload => {\n      // update the internal options of the instance\n        this._options = reload._options;\n        // re-set instance values\n        this.set(reload.dataValues, {\n          raw: true,\n          reset: true && !options.attributes\n        });\n        return this;\n      });\n  }\n\n  /**\n  * Validate the attributes of this instance according to validation rules set in the model definition.\n  *\n  * The promise fulfills if and only if validation successful; otherwise it rejects an Error instance containing { field name : [error msgs] } entries.\n  *\n  * @param {Object} [options] Options that are passed to the validator\n  * @param {Array} [options.skip] An array of strings. All properties that are in this array will not be validated\n  * @param {Array} [options.fields] An array of strings. Only the properties that are in this array will be validated\n  * @param {boolean} [options.hooks=true] Run before and after validate hooks\n  *\n  * @returns {Promise}\n  */\n  validate(options) {\n    return new InstanceValidator(this, options).validate();\n  }\n\n  /**\n   * This is the same as calling `set` and then calling `save` but it only saves the\n   * exact values passed to it, making it more atomic and safer.\n   *\n   * @see\n   * {@link Model#set}\n   * @see\n   * {@link Model#save}\n   *\n   * @param {Object} values See `set`\n   * @param {Object} options See `save`\n   *\n   * @returns {Promise<Model>}\n   */\n  update(values, options) {\n    // Clone values so it doesn't get modified for caller scope and ignore undefined values\n    values = _.omitBy(values, value => value === undefined);\n\n    const changedBefore = this.changed() || [];\n\n    options = options || {};\n    if (Array.isArray(options)) options = { fields: options };\n\n    options = Utils.cloneDeep(options);\n    const setOptions = Utils.cloneDeep(options);\n    setOptions.attributes = options.fields;\n    this.set(values, setOptions);\n\n    // Now we need to figure out which fields were actually affected by the setter.\n    const sideEffects = _.without(this.changed(), ...changedBefore);\n    const fields = _.union(Object.keys(values), sideEffects);\n\n    if (!options.fields) {\n      options.fields = _.intersection(fields, this.changed());\n      options.defaultFields = options.fields;\n    }\n\n    return this.save(options);\n  }\n\n  /**\n   * Destroy the row corresponding to this instance. Depending on your setting for paranoid, the row will either be completely deleted, or have its deletedAt timestamp set to the current time.\n   *\n   * @param {Object}      [options={}] destroy options\n   * @param {boolean}     [options.force=false] If set to true, paranoid models will actually be deleted\n   * @param {Function}    [options.logging=false] A function that gets executed while running the query to log the sql.\n   * @param {Transaction} [options.transaction] Transaction to run query under\n   * @param {string}      [options.searchPath=DEFAULT] An optional parameter to specify the schema search_path (Postgres only)\n   *\n   * @returns {Promise}\n   */\n  destroy(options) {\n    options = Object.assign({\n      hooks: true,\n      force: false\n    }, options);\n\n    return Promise.try(() => {\n      // Run before hook\n      if (options.hooks) {\n        return this.constructor.runHooks('beforeDestroy', this, options);\n      }\n    }).then(() => {\n      const where = this.where(true);\n\n      if (this.constructor._timestampAttributes.deletedAt && options.force === false) {\n        const attributeName = this.constructor._timestampAttributes.deletedAt;\n        const attribute = this.constructor.rawAttributes[attributeName];\n        const defaultValue = Object.prototype.hasOwnProperty.call(attribute, 'defaultValue')\n          ? attribute.defaultValue\n          : null;\n        const currentValue = this.getDataValue(attributeName);\n        const undefinedOrNull = currentValue == null && defaultValue == null;\n        if (undefinedOrNull || _.isEqual(currentValue, defaultValue)) {\n          // only update timestamp if it wasn't already set\n          this.setDataValue(attributeName, new Date());\n        }\n\n        return this.save(_.defaults({ hooks: false }, options));\n      }\n      return this.constructor.QueryInterface.delete(this, this.constructor.getTableName(options), where, Object.assign({ type: QueryTypes.DELETE, limit: null }, options));\n    }).tap(() => {\n      // Run after hook\n      if (options.hooks) {\n        return this.constructor.runHooks('afterDestroy', this, options);\n      }\n    });\n  }\n\n  /**\n   * Helper method to determine if a instance is \"soft deleted\".  This is\n   * particularly useful if the implementer renamed the `deletedAt` attribute\n   * to something different.  This method requires `paranoid` to be enabled.\n   *\n   * @returns {boolean}\n   */\n  isSoftDeleted() {\n    if (!this.constructor._timestampAttributes.deletedAt) {\n      throw new Error('Model is not paranoid');\n    }\n\n    const deletedAtAttribute = this.constructor.rawAttributes[this.constructor._timestampAttributes.deletedAt];\n    const defaultValue = Object.prototype.hasOwnProperty.call(deletedAtAttribute, 'defaultValue') ? deletedAtAttribute.defaultValue : null;\n    const deletedAt = this.get(this.constructor._timestampAttributes.deletedAt) || null;\n    const isSet = deletedAt !== defaultValue;\n\n    return isSet;\n  }\n\n  /**\n   * Restore the row corresponding to this instance. Only available for paranoid models.\n   *\n   * @param {Object}      [options={}] restore options\n   * @param {Function}    [options.logging=false] A function that gets executed while running the query to log the sql.\n   * @param {Transaction} [options.transaction] Transaction to run query under\n   *\n   * @returns {Promise}\n   */\n  restore(options) {\n    if (!this.constructor._timestampAttributes.deletedAt) throw new Error('Model is not paranoid');\n\n    options = Object.assign({\n      hooks: true,\n      force: false\n    }, options);\n\n    return Promise.try(() => {\n      // Run before hook\n      if (options.hooks) {\n        return this.constructor.runHooks('beforeRestore', this, options);\n      }\n    }).then(() => {\n      const deletedAtCol = this.constructor._timestampAttributes.deletedAt;\n      const deletedAtAttribute = this.constructor.rawAttributes[deletedAtCol];\n      const deletedAtDefaultValue = Object.prototype.hasOwnProperty.call(deletedAtAttribute, 'defaultValue') ? deletedAtAttribute.defaultValue : null;\n\n      this.setDataValue(deletedAtCol, deletedAtDefaultValue);\n      return this.save(Object.assign({}, options, { hooks: false, omitNull: false }));\n    }).tap(() => {\n      // Run after hook\n      if (options.hooks) {\n        return this.constructor.runHooks('afterRestore', this, options);\n      }\n    });\n  }\n\n  /**\n   * Increment the value of one or more columns. This is done in the database, which means it does not use the values currently stored on the Instance. The increment is done using a\n   * ```sql\n   * SET column = column + X\n   * ```\n   * query. The updated instance will be returned by default in Postgres. However, in other dialects, you will need to do a reload to get the new values.\n   *\n   * @example\n   * instance.increment('number') // increment number by 1\n   *\n   * instance.increment(['number', 'count'], { by: 2 }) // increment number and count by 2\n   *\n   * // increment answer by 42, and tries by 1.\n   * // `by` is ignored, since each column has its own value\n   * instance.increment({ answer: 42, tries: 1}, { by: 2 })\n   *\n   * @see\n   * {@link Model#reload}\n   *\n   * @param {string|Array|Object} fields If a string is provided, that column is incremented by the value of `by` given in options. If an array is provided, the same is true for each column. If and object is provided, each column is incremented by the value given.\n   * @param {Object} [options] options\n   * @param {number} [options.by=1] The number to increment by\n   * @param {boolean} [options.silent=false] If true, the updatedAt timestamp will not be updated.\n   * @param {Function} [options.logging=false] A function that gets executed while running the query to log the sql.\n   * @param {Transaction} [options.transaction] Transaction to run query under\n   * @param {string} [options.searchPath=DEFAULT] An optional parameter to specify the schema search_path (Postgres only)\n   * @param {boolean} [options.returning=true] Append RETURNING * to get back auto generated values (Postgres only)\n   *\n   * @returns {Promise<Model>}\n   * @since 4.0.0\n   */\n  increment(fields, options) {\n    const identifier = this.where();\n\n    options = Utils.cloneDeep(options);\n    options.where = Object.assign({}, options.where, identifier);\n    options.instance = this;\n\n    return this.constructor.increment(fields, options).return(this);\n  }\n\n  /**\n   * Decrement the value of one or more columns. This is done in the database, which means it does not use the values currently stored on the Instance. The decrement is done using a\n   * ```sql\n   * SET column = column - X\n   * ```\n   * query. The updated instance will be returned by default in Postgres. However, in other dialects, you will need to do a reload to get the new values.\n   *\n   * @example\n   * instance.decrement('number') // decrement number by 1\n   *\n   * instance.decrement(['number', 'count'], { by: 2 }) // decrement number and count by 2\n   *\n   * // decrement answer by 42, and tries by 1.\n   * // `by` is ignored, since each column has its own value\n   * instance.decrement({ answer: 42, tries: 1}, { by: 2 })\n   *\n   * @see\n   * {@link Model#reload}\n   * @param {string|Array|Object} fields If a string is provided, that column is decremented by the value of `by` given in options. If an array is provided, the same is true for each column. If and object is provided, each column is decremented by the value given\n   * @param {Object}      [options] decrement options\n   * @param {number}      [options.by=1] The number to decrement by\n   * @param {boolean}     [options.silent=false] If true, the updatedAt timestamp will not be updated.\n   * @param {Function}    [options.logging=false] A function that gets executed while running the query to log the sql.\n   * @param {Transaction} [options.transaction] Transaction to run query under\n   * @param {string}      [options.searchPath=DEFAULT] An optional parameter to specify the schema search_path (Postgres only)\n   * @param {boolean}     [options.returning=true] Append RETURNING * to get back auto generated values (Postgres only)\n   *\n   * @returns {Promise}\n   */\n  decrement(fields, options) {\n    options = _.defaults({ increment: false }, options, {\n      by: 1\n    });\n\n    return this.increment(fields, options);\n  }\n\n  /**\n   * Check whether this and `other` Instance refer to the same row\n   *\n   * @param {Model} other Other instance to compare against\n   *\n   * @returns {boolean}\n   */\n  equals(other) {\n    if (!other || !other.constructor) {\n      return false;\n    }\n\n    if (!(other instanceof this.constructor)) {\n      return false;\n    }\n\n    return this.constructor.primaryKeyAttributes.every(attribute => this.get(attribute, { raw: true }) === other.get(attribute, { raw: true }));\n  }\n\n  /**\n   * Check if this is equal to one of `others` by calling equals\n   *\n   * @param {Array<Model>} others An array of instances to check against\n   *\n   * @returns {boolean}\n   */\n  equalsOneOf(others) {\n    return others.some(other => this.equals(other));\n  }\n\n  setValidators(attribute, validators) {\n    this.validators[attribute] = validators;\n  }\n\n  /**\n   * Convert the instance to a JSON representation.\n   * Proxies to calling `get` with no keys.\n   * This means get all values gotten from the DB, and apply all custom getters.\n   *\n   * @see\n   * {@link Model#get}\n   *\n   * @returns {Object}\n   */\n  toJSON() {\n    return _.cloneDeep(\n      this.get({\n        plain: true\n      })\n    );\n  }\n\n  /**\n   * Creates a 1:m association between this (the source) and the provided target.\n   * The foreign key is added on the target.\n   *\n   * @param {Model}               target Target model\n   * @param {Object}              [options] hasMany association options\n   * @param {boolean}             [options.hooks=false] Set to true to run before-/afterDestroy hooks when an associated model is deleted because of a cascade. For example if `User.hasOne(Profile, {onDelete: 'cascade', hooks:true})`, the before-/afterDestroy hooks for profile will be called when a user is deleted. Otherwise the profile will be deleted without invoking any hooks\n   * @param {string|Object}       [options.as] The alias of this model. If you provide a string, it should be plural, and will be singularized using node.inflection. If you want to control the singular version yourself, provide an object with `plural` and `singular` keys. See also the `name` option passed to `sequelize.define`. If you create multiple associations between the same tables, you should provide an alias to be able to distinguish between them. If you provide an alias when creating the association, you should provide the same alias when eager loading and when getting associated models. Defaults to the pluralized name of target\n   * @param {string|Object}       [options.foreignKey] The name of the foreign key in the target table or an object representing the type definition for the foreign column (see `Sequelize.define` for syntax). When using an object, you can add a `name` property to set the name of the column. Defaults to the name of source + primary key of source\n   * @param {string}              [options.sourceKey] The name of the field to use as the key for the association in the source table. Defaults to the primary key of the source table\n   * @param {Object}              [options.scope] A key/value set that will be used for association create and find defaults on the target. (sqlite not supported for N:M)\n   * @param {string}              [options.onDelete='SET&nbsp;NULL|CASCADE'] SET NULL if foreignKey allows nulls, CASCADE if otherwise\n   * @param {string}              [options.onUpdate='CASCADE'] Set `ON UPDATE`\n   * @param {boolean}             [options.constraints=true] Should on update and on delete constraints be enabled on the foreign key.\n   *\n   * @returns {HasMany}\n   *\n   * @example\n   * User.hasMany(Profile) // This will add userId to the profile table\n   */\n  static hasMany(target, options) {} // eslint-disable-line\n\n  /**\n   * Create an N:M association with a join table. Defining `through` is required.\n   *\n   * @param {Model}               target Target model\n   * @param {Object}              options belongsToMany association options\n   * @param {boolean}             [options.hooks=false] Set to true to run before-/afterDestroy hooks when an associated model is deleted because of a cascade. For example if `User.hasOne(Profile, {onDelete: 'cascade', hooks:true})`, the before-/afterDestroy hooks for profile will be called when a user is deleted. Otherwise the profile will be deleted without invoking any hooks\n   * @param {Model|string|Object} options.through The name of the table that is used to join source and target in n:m associations. Can also be a sequelize model if you want to define the junction table yourself and add extra attributes to it.\n   * @param {Model}               [options.through.model] The model used to join both sides of the N:M association.\n   * @param {Object}              [options.through.scope] A key/value set that will be used for association create and find defaults on the through model. (Remember to add the attributes to the through model)\n   * @param {boolean}             [options.through.unique=true] If true a unique key will be generated from the foreign keys used (might want to turn this off and create specific unique keys when using scopes)\n   * @param {string|Object}       [options.as] The alias of this association. If you provide a string, it should be plural, and will be singularized using node.inflection. If you want to control the singular version yourself, provide an object with `plural` and `singular` keys. See also the `name` option passed to `sequelize.define`. If you create multiple associations between the same tables, you should provide an alias to be able to distinguish between them. If you provide an alias when creating the association, you should provide the same alias when eager loading and when getting associated models. Defaults to the pluralized name of target\n   * @param {string|Object}       [options.foreignKey] The name of the foreign key in the join table (representing the source model) or an object representing the type definition for the foreign column (see `Sequelize.define` for syntax). When using an object, you can add a `name` property to set the name of the column. Defaults to the name of source + primary key of source\n   * @param {string|Object}       [options.otherKey] The name of the foreign key in the join table (representing the target model) or an object representing the type definition for the other column (see `Sequelize.define` for syntax). When using an object, you can add a `name` property to set the name of the column. Defaults to the name of target + primary key of target\n   * @param {Object}              [options.scope] A key/value set that will be used for association create and find defaults on the target. (sqlite not supported for N:M)\n   * @param {boolean}             [options.timestamps=sequelize.options.timestamps] Should the join model have timestamps\n   * @param {string}              [options.onDelete='SET&nbsp;NULL|CASCADE'] Cascade if this is a n:m, and set null if it is a 1:m\n   * @param {string}              [options.onUpdate='CASCADE'] Sets `ON UPDATE`\n   * @param {boolean}             [options.constraints=true] Should on update and on delete constraints be enabled on the foreign key.\n   *\n   * @returns {BelongsToMany}\n   *\n   * @example\n   * // Automagically generated join model\n   * User.belongsToMany(Project, { through: 'UserProjects' })\n   * Project.belongsToMany(User, { through: 'UserProjects' })\n   *\n   * // Join model with additional attributes\n   * const UserProjects = sequelize.define('UserProjects', {\n   *   started: Sequelize.BOOLEAN\n   * })\n   * User.belongsToMany(Project, { through: UserProjects })\n   * Project.belongsToMany(User, { through: UserProjects })\n   */\n  static belongsToMany(target, options) {} // eslint-disable-line\n\n  /**\n   * Creates an association between this (the source) and the provided target. The foreign key is added on the target.\n   *\n   * @param {Model}           target Target model\n   * @param {Object}          [options] hasOne association options\n   * @param {boolean}         [options.hooks=false] Set to true to run before-/afterDestroy hooks when an associated model is deleted because of a cascade. For example if `User.hasOne(Profile, {onDelete: 'cascade', hooks:true})`, the before-/afterDestroy hooks for profile will be called when a user is deleted. Otherwise the profile will be deleted without invoking any hooks\n   * @param {string}          [options.as] The alias of this model, in singular form. See also the `name` option passed to `sequelize.define`. If you create multiple associations between the same tables, you should provide an alias to be able to distinguish between them. If you provide an alias when creating the association, you should provide the same alias when eager loading and when getting associated models. Defaults to the singularized name of target\n   * @param {string|Object}   [options.foreignKey] The name of the foreign key attribute in the target model or an object representing the type definition for the foreign column (see `Sequelize.define` for syntax). When using an object, you can add a `name` property to set the name of the column. Defaults to the name of source + primary key of source\n   * @param {string}          [options.sourceKey] The name of the attribute to use as the key for the association in the source table. Defaults to the primary key of the source table\n   * @param {string}          [options.onDelete='SET&nbsp;NULL|CASCADE'] SET NULL if foreignKey allows nulls, CASCADE if otherwise\n   * @param {string}          [options.onUpdate='CASCADE'] Sets 'ON UPDATE'\n   * @param {boolean}         [options.constraints=true] Should on update and on delete constraints be enabled on the foreign key.\n   * @param {string}          [options.uniqueKey] The custom name for unique constraint.\n   *\n   * @returns {HasOne}\n   *\n   * @example\n   * User.hasOne(Profile) // This will add userId to the profile table\n   */\n  static hasOne(target, options) {} // eslint-disable-line\n\n  /**\n   * Creates an association between this (the source) and the provided target. The foreign key is added on the source.\n   *\n   * @param {Model}           target The target model\n   * @param {Object}          [options] belongsTo association options\n   * @param {boolean}         [options.hooks=false] Set to true to run before-/afterDestroy hooks when an associated model is deleted because of a cascade. For example if `User.hasOne(Profile, {onDelete: 'cascade', hooks:true})`, the before-/afterDestroy hooks for profile will be called when a user is deleted. Otherwise the profile will be deleted without invoking any hooks\n   * @param {string}          [options.as] The alias of this model, in singular form. See also the `name` option passed to `sequelize.define`. If you create multiple associations between the same tables, you should provide an alias to be able to distinguish between them. If you provide an alias when creating the association, you should provide the same alias when eager loading and when getting associated models. Defaults to the singularized name of target\n   * @param {string|Object}   [options.foreignKey] The name of the foreign key attribute in the source table or an object representing the type definition for the foreign column (see `Sequelize.define` for syntax). When using an object, you can add a `name` property to set the name of the column. Defaults to the name of target + primary key of target\n   * @param {string}          [options.targetKey] The name of the attribute to use as the key for the association in the target table. Defaults to the primary key of the target table\n   * @param {string}          [options.onDelete='SET&nbsp;NULL|NO&nbsp;ACTION'] SET NULL if foreignKey allows nulls, NO ACTION if otherwise\n   * @param {string}          [options.onUpdate='CASCADE'] Sets 'ON UPDATE'\n   * @param {boolean}         [options.constraints=true] Should on update and on delete constraints be enabled on the foreign key.\n   *\n   * @returns {BelongsTo}\n   *\n   * @example\n   * Profile.belongsTo(User) // This will add userId to the profile table\n   */\n  static belongsTo(target, options) {} // eslint-disable-line\n}\n\nObject.assign(Model, associationsMixin);\nHooks.applyTo(Model, true);\n\nmodule.exports = Model;\n"]} \ No newline at end of file diff --git a/dist/operators.js b/dist/operators.js index 47eb156..3d7dd42 100644 --- a/dist/operators.js +++ b/dist/operators.js @@ -87,4 +87,4 @@ const Op = { join: Symbol.for('join') }; module.exports = Op; -//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uL2xpYi9vcGVyYXRvcnMuanMiXSwibmFtZXMiOlsiT3AiLCJlcSIsIlN5bWJvbCIsImZvciIsIm5lIiwiZ3RlIiwiZ3QiLCJsdGUiLCJsdCIsIm5vdCIsImlzIiwiaW4iLCJub3RJbiIsImxpa2UiLCJub3RMaWtlIiwiaUxpa2UiLCJub3RJTGlrZSIsInN0YXJ0c1dpdGgiLCJlbmRzV2l0aCIsInN1YnN0cmluZyIsInJlZ2V4cCIsIm5vdFJlZ2V4cCIsImlSZWdleHAiLCJub3RJUmVnZXhwIiwiYmV0d2VlbiIsIm5vdEJldHdlZW4iLCJvdmVybGFwIiwiY29udGFpbnMiLCJjb250YWluZWQiLCJhZGphY2VudCIsInN0cmljdExlZnQiLCJzdHJpY3RSaWdodCIsIm5vRXh0ZW5kUmlnaHQiLCJub0V4dGVuZExlZnQiLCJhbmQiLCJvciIsImFueSIsImFsbCIsInZhbHVlcyIsImNvbCIsInBsYWNlaG9sZGVyIiwiam9pbiIsIm1vZHVsZSIsImV4cG9ydHMiXSwibWFwcGluZ3MiOiJBQUNBO0FBQ0E7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7QUE2Q0EsTUFBTUEsRUFBRSxHQUFHO0FBQ1RDLEVBQUFBLEVBQUUsRUFBRUMsTUFBTSxDQUFDQyxHQUFQLENBQVcsSUFBWCxDQURLO0FBRVRDLEVBQUFBLEVBQUUsRUFBRUYsTUFBTSxDQUFDQyxHQUFQLENBQVcsSUFBWCxDQUZLO0FBR1RFLEVBQUFBLEdBQUcsRUFBRUgsTUFBTSxDQUFDQyxHQUFQLENBQVcsS0FBWCxDQUhJO0FBSVRHLEVBQUFBLEVBQUUsRUFBRUosTUFBTSxDQUFDQyxHQUFQLENBQVcsSUFBWCxDQUpLO0FBS1RJLEVBQUFBLEdBQUcsRUFBRUwsTUFBTSxDQUFDQyxHQUFQLENBQVcsS0FBWCxDQUxJO0FBTVRLLEVBQUFBLEVBQUUsRUFBRU4sTUFBTSxDQUFDQyxHQUFQLENBQVcsSUFBWCxDQU5LO0FBT1RNLEVBQUFBLEdBQUcsRUFBRVAsTUFBTSxDQUFDQyxH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QUksRUFBRXZDLE1BQU0sQ0FBQ0MsR0FBUCxDQUFXLE1BQVg7QUF2Q0csQ0FBWDtBQTBDQXVDLE1BQU0sQ0FBQ0MsT0FBUCxHQUFpQjNDLEVBQWpCIiwic291cmNlc0NvbnRlbnQiOlsiXHJcbid1c2Ugc3RyaWN0JztcclxuLyoqXHJcbiAqIE9wZXJhdG9yIHN5bWJvbHMgdG8gYmUgdXNlZCB3aGVuIHF1ZXJ5aW5nIGRhdGFcclxuICpcclxuICogQHNlZSB7QGxpbmsgTW9kZWwjd2hlcmV9XHJcbiAqXHJcbiAqIEBwcm9wZXJ0eSBlcVxyXG4gKiBAcHJvcGVydHkgbmVcclxuICogQHByb3BlcnR5IGd0ZVxyXG4gKiBAcHJvcGVydHkgZ3RcclxuICogQHByb3BlcnR5IGx0ZVxyXG4gKiBAcHJvcGVydHkgbHRcclxuICogQHByb3BlcnR5IG5vdFxyXG4gKiBAcHJvcGVydHkgaXNcclxuICogQHByb3BlcnR5IGluXHJcbiAqIEBwcm9wZXJ0eSBub3RJblxyXG4gKiBAcHJvcGVydHkgbGlrZVxyXG4gKiBAcHJvcGVydHkgbm90TGlrZVxyXG4gKiBAcHJvcGVydHkgaUxpa2VcclxuICogQHByb3BlcnR5IG5vdElMaWtlXHJcbiAqIEBwcm9wZXJ0eSBzdGFydHNXaXRoXHJcbiAqIEBwcm9wZXJ0eSBlbmRzV2l0aFxyXG4gKiBAcHJvcGVydHkgc3Vic3RyaW5nXHJcbiAqIEBwcm9wZXJ0eSByZWdleHBcclxuICogQHByb3BlcnR5IG5vdFJlZ2V4cFxyXG4gKiBAcHJvcGVydHkgaVJlZ2V4cFxyXG4gKiBAcHJvcGVydHkgbm90SVJlZ2V4cFxyXG4gKiBAcHJvcGVydHkgYmV0d2VlblxyXG4gKiBAcHJvcGVydHkgbm90QmV0d2VlblxyXG4gKiBAcHJvcGVydHkgb3ZlcmxhcFxyXG4gKiBAcHJvcGVydHkgY29udGFpbnNcclxuICogQHByb3BlcnR5IGNvbnRhaW5lZFxyXG4gKiBAcHJvcGVydHkgYWRqYWNlbnRcclxuICogQHByb3BlcnR5IHN0cmljdExlZnRcclxuICogQHByb3BlcnR5IHN0cmljdFJpZ2h0XHJcbiAqIEBwcm9wZXJ0eSBub0V4dGVuZFJpZ2h0XHJcbiAqIEBwcm9wZXJ0eSBub0V4dGVuZExlZnRcclxuICogQHByb3BlcnR5IGFuZFxyXG4gKiBAcHJvcGVydHkgb3JcclxuICogQHByb3BlcnR5IGFueVxyXG4gKiBAcHJvcGVydHkgYWxsXHJcbiAqIEBwcm9wZXJ0eSB2YWx1ZXNcclxuICogQHByb3BlcnR5IGNvbFxyXG4gKiBAcHJvcGVydHkgcGxhY2Vob2xkZXJcclxuICogQHByb3BlcnR5IGpvaW5cclxuICovXHJcbmNvbnN0IE9wID0ge1xyXG4gIGVxOiBTeW1ib2wuZm9yKCdlcScpLFxyXG4gIG5lOiBTeW1ib2wuZm9yKCduZScpLFxyXG4gIGd0ZTogU3ltYm9sLmZvcignZ3RlJyksXHJcbiAgZ3Q6IFN5bWJvbC5mb3IoJ2d0JyksXHJcbiAgbHRlOiBTeW1ib2wuZm9yKCdsdGUnKSxcclxuICBsdDogU3ltYm9sLmZvcignbHQnKSxcclxuICBub3Q6IFN5bWJvbC5mb3IoJ25vdCcpLFxyXG4gIGlzOiBTeW1ib2wuZm9yKCdpcycpLFxyXG4gIGluOiBTeW1ib2wuZm9yKCdpbicpLFxyXG4gIG5vdEluOiBTeW1ib2wuZm9yKCdub3RJbicpLFxyXG4gIGxpa2U6IFN5bWJvbC5mb3IoJ2xpa2UnKSxcclxuICBub3RMaWtlOiBTeW1ib2wuZm9yKCdub3RMaWtlJyksXHJcbiAgaUxpa2U6IFN5bWJvbC5mb3IoJ2lMaWtlJyksXHJcbiAgbm90SUxpa2U6IFN5bWJvbC5mb3IoJ25vdElMaWtlJyksXHJcbiAgc3RhcnRzV2l0aDogU3ltYm9sLmZvcignc3RhcnRzV2l0aCcpLFxyXG4gIGVuZHNXaXRoOiBTeW1ib2wuZm9yKCdlbmRzV2l0aCcpLFxyXG4gIHN1YnN0cmluZzogU3ltYm9sLmZvcignc3Vic3RyaW5nJyksXHJcbiAgcmVnZXhwOiBTeW1ib2wuZm9yKCdyZWdleHAnKSxcclxuICBub3RSZWdleHA6IFN5bWJvbC5mb3IoJ25vdFJlZ2V4cCcpLFxyXG4gIGlSZWdleHA6IFN5bWJvbC5mb3IoJ2lSZWdleHAnKSxcclxuICBub3RJUmVnZXhwOiBTeW1ib2wuZm9yKCdub3RJUmVnZXhwJyksXHJcbiAgYmV0d2VlbjogU3ltYm9sLmZvcignYmV0d2VlbicpLFxyXG4gIG5vdEJldHdlZW46IFN5bWJvbC5mb3IoJ25vdEJldHdlZW4nKSxcclxuICBvdmVybGFwOiBTeW1ib2wuZm9yKCdvdmVybGFwJyksXHJcbiAgY29udGFpbnM6IFN5bWJvbC5mb3IoJ2NvbnRhaW5zJyksXHJcbiAgY29udGFpbmVkOiBTeW1ib2wuZm9yKCdjb250YWluZWQnKSxcclxuICBhZGphY2VudDogU3ltYm9sLmZvcignYWRqYWNlbnQnKSxcclxuICBzdHJpY3RMZWZ0OiBTeW1ib2wuZm9yKCdzdHJpY3RMZWZ0JyksXHJcbiAgc3RyaWN0UmlnaHQ6IFN5bWJvbC5mb3IoJ3N0cmljdFJpZ2h0JyksXHJcbiAgbm9FeHRlbmRSaWdodDogU3ltYm9sLmZvcignbm9FeHRlbmRSaWdodCcpLFxyXG4gIG5vRXh0ZW5kTGVmdDogU3ltYm9sLmZvcignbm9FeHRlbmRMZWZ0JyksXHJcbiAgYW5kOiBTeW1ib2wuZm9yKCdhbmQnKSxcclxuICBvcjogU3ltYm9sLmZvcignb3InKSxcclxuICBhbnk6IFN5bWJvbC5mb3IoJ2FueScpLFxyXG4gIGFsbDogU3ltYm9sLmZvcignYWxsJyksXHJcbiAgdmFsdWVzOiBTeW1ib2wuZm9yKCd2YWx1ZXMnKSxcclxuICBjb2w6IFN5bWJvbC5mb3IoJ2NvbCcpLFxyXG4gIHBsYWNlaG9sZGVyOiBTeW1ib2wuZm9yKCdwbGFjZWhvbGRlcicpLFxyXG4gIGpvaW46IFN5bWJvbC5mb3IoJ2pvaW4nKVxyXG59O1xyXG5cclxubW9kdWxlLmV4cG9ydHMgPSBPcDtcclxuIl19 \ No newline at end of file +//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uL2xpYi9vcGVyYXRvcnMuanMiXSwibmFtZXMiOlsiT3AiLCJlcSIsIlN5bWJvbCIsImZvciIsIm5lIiwiZ3RlIiwiZ3QiLCJsdGUiLCJsdCIsIm5vdCIsImlzIiwiaW4iLCJub3RJbiIsImxpa2UiLCJub3RMaWtlIiwiaUxpa2UiLCJub3RJTGlrZSIsInN0YXJ0c1dpdGgiLCJlbmRzV2l0aCIsInN1YnN0cmluZyIsInJlZ2V4cCIsIm5vdFJlZ2V4cCIsImlSZWdleHAiLCJub3RJUmVnZXhwIiwiYmV0d2VlbiIsIm5vdEJldHdlZW4iLCJvdmVybGFwIiwiY29udGFpbnMiLCJjb250YWluZWQiLCJhZGphY2VudCIsInN0cmljdExlZnQiLCJzdHJpY3RSaWdodCIsIm5vRXh0ZW5kUmlnaHQiLCJub0V4dGVuZExlZnQiLCJhbmQiLCJvciIsImFueSIsImFsbCIsInZhbHVlcyIsImNvbCIsInBsYWNlaG9sZGVyIiwiam9pbiIsIm1vZHVsZSIsImV4cG9ydHMiXSwibWFwcGluZ3MiOiJBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUNBLE1BQU1BLEVBQUUsR0FBRztBQUNUQyxFQUFBQSxFQUFFLEVBQUVDLE1BQU0sQ0FBQ0MsR0FBUCxDQUFXLElBQVgsQ0FESztBQUVUQyxFQUFBQSxFQUFFLEVBQUVGLE1BQU0sQ0FBQ0MsR0FBUCxDQUFXLElBQVgsQ0FGSztBQUdURSxFQUFBQSxHQUFHLEVBQUVILE1BQU0sQ0FBQ0MsR0FBUCxDQUFXLEtBQVgsQ0FISTtBQUlURyxFQUFBQSxFQUFFLEVBQUVK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QUFNLEVBQUVwQyxNQUFNLENBQUNDLEdBQVAsQ0FBVyxRQUFYLENBcENDO0FBcUNUb0MsRUFBQUEsR0FBRyxFQUFFckMsTUFBTSxDQUFDQyxHQUFQLENBQVcsS0FBWCxDQXJDSTtBQXNDVHFDLEVBQUFBLFdBQVcsRUFBRXRDLE1BQU0sQ0FBQ0MsR0FBUCxDQUFXLGFBQVgsQ0F0Q0o7QUF1Q1RzQyxFQUFBQSxJQUFJLEVBQUV2QyxNQUFNLENBQUNDLEdBQVAsQ0FBVyxNQUFYO0FBdkNHLENBQVg7QUEwQ0F1QyxNQUFNLENBQUNDLE9BQVAsR0FBaUIzQyxFQUFqQiIsInNvdXJjZXNDb250ZW50IjpbIlxuJ3VzZSBzdHJpY3QnO1xuLyoqXG4gKiBPcGVyYXRvciBzeW1ib2xzIHRvIGJlIHVzZWQgd2hlbiBxdWVyeWluZyBkYXRhXG4gKlxuICogQHNlZSB7QGxpbmsgTW9kZWwjd2hlcmV9XG4gKlxuICogQHByb3BlcnR5IGVxXG4gKiBAcHJvcGVydHkgbmVcbiAqIEBwcm9wZXJ0eSBndGVcbiAqIEBwcm9wZXJ0eSBndFxuICogQHByb3BlcnR5IGx0ZVxuICogQHByb3BlcnR5IGx0XG4gKiBAcHJvcGVydHkgbm90XG4gKiBAcHJvcGVydHkgaXNcbiAqIEBwcm9wZXJ0eSBpblxuICogQHByb3BlcnR5IG5vdEluXG4gKiBAcHJvcGVydHkgbGlrZVxuICogQHByb3BlcnR5IG5vdExpa2VcbiAqIEBwcm9wZXJ0eSBpTGlrZVxuICogQHByb3BlcnR5IG5vdElMaWtlXG4gKiBAcHJvcGVydHkgc3RhcnRzV2l0aFxuICogQHByb3BlcnR5IGVuZHNXaXRoXG4gKiBAcHJvcGVydHkgc3Vic3RyaW5nXG4gKiBAcHJvcGVydHkgcmVnZXhwXG4gKiBAcHJvcGVydHkgbm90UmVnZXhwXG4gKiBAcHJvcGVydHkgaVJlZ2V4cFxuICogQHByb3BlcnR5IG5vdElSZWdleHBcbiAqIEBwcm9wZXJ0eSBiZXR3ZWVuXG4gKiBAcHJvcGVydHkgbm90QmV0d2VlblxuICogQHByb3BlcnR5IG92ZXJsYXBcbiAqIEBwcm9wZXJ0eSBjb250YWluc1xuICogQHByb3BlcnR5IGNvbnRhaW5lZFxuICogQHByb3BlcnR5IGFkamFjZW50XG4gKiBAcHJvcGVydHkgc3RyaWN0TGVmdFxuICogQHByb3BlcnR5IHN0cmljdFJpZ2h0XG4gKiBAcHJvcGVydHkgbm9FeHRlbmRSaWdodFxuICogQHByb3BlcnR5IG5vRXh0ZW5kTGVmdFxuICogQHByb3BlcnR5IGFuZFxuICogQHByb3BlcnR5IG9yXG4gKiBAcHJvcGVydHkgYW55XG4gKiBAcHJvcGVydHkgYWxsXG4gKiBAcHJvcGVydHkgdmFsdWVzXG4gKiBAcHJvcGVydHkgY29sXG4gKiBAcHJvcGVydHkgcGxhY2Vob2xkZXJcbiAqIEBwcm9wZXJ0eSBqb2luXG4gKi9cbmNvbnN0IE9wID0ge1xuICBlcTogU3ltYm9sLmZvcignZXEnKSxcbiAgbmU6IFN5bWJvbC5mb3IoJ25lJyksXG4gIGd0ZTogU3ltYm9sLmZvcignZ3RlJyksXG4gIGd0OiBTeW1ib2wuZm9yKCdndCcpLFxuICBsdGU6IFN5bWJvbC5mb3IoJ2x0ZScpLFxuICBsdDogU3ltYm9sLmZvcignbHQnKSxcbiAgbm90OiBTeW1ib2wuZm9yKCdub3QnKSxcbiAgaXM6IFN5bWJvbC5mb3IoJ2lzJyksXG4gIGluOiBTeW1ib2wuZm9yKCdpbicpLFxuICBub3RJbjogU3ltYm9sLmZvcignbm90SW4nKSxcbiAgbGlrZTogU3ltYm9sLmZvcignbGlrZScpLFxuICBub3RMaWtlOiBTeW1ib2wuZm9yKCdub3RMaWtlJyksXG4gIGlMaWtlOiBTeW1ib2wuZm9yKCdpTGlrZScpLFxuICBub3RJTGlrZTogU3ltYm9sLmZvcignbm90SUxpa2UnKSxcbiAgc3RhcnRzV2l0aDogU3ltYm9sLmZvcignc3RhcnRzV2l0aCcpLFxuICBlbmRzV2l0aDogU3ltYm9sLmZvcignZW5kc1dpdGgnKSxcbiAgc3Vic3RyaW5nOiBTeW1ib2wuZm9yKCdzdWJzdHJpbmcnKSxcbiAgcmVnZXhwOiBTeW1ib2wuZm9yKCdyZWdleHAnKSxcbiAgbm90UmVnZXhwOiBTeW1ib2wuZm9yKCdub3RSZWdleHAnKSxcbiAgaVJlZ2V4cDogU3ltYm9sLmZvcignaVJlZ2V4cCcpLFxuICBub3RJUmVnZXhwOiBTeW1ib2wuZm9yKCdub3RJUmVnZXhwJyksXG4gIGJldHdlZW46IFN5bWJvbC5mb3IoJ2JldHdlZW4nKSxcbiAgbm90QmV0d2VlbjogU3ltYm9sLmZvcignbm90QmV0d2VlbicpLFxuICBvdmVybGFwOiBTeW1ib2wuZm9yKCdvdmVybGFwJyksXG4gIGNvbnRhaW5zOiBTeW1ib2wuZm9yKCdjb250YWlucycpLFxuICBjb250YWluZWQ6IFN5bWJvbC5mb3IoJ2NvbnRhaW5lZCcpLFxuICBhZGphY2VudDogU3ltYm9sLmZvcignYWRqYWNlbnQnKSxcbiAgc3RyaWN0TGVmdDogU3ltYm9sLmZvcignc3RyaWN0TGVmdCcpLFxuICBzdHJpY3RSaWdodDogU3ltYm9sLmZvcignc3RyaWN0UmlnaHQnKSxcbiAgbm9FeHRlbmRSaWdodDogU3ltYm9sLmZvcignbm9FeHRlbmRSaWdodCcpLFxuICBub0V4dGVuZExlZnQ6IFN5bWJvbC5mb3IoJ25vRXh0ZW5kTGVmdCcpLFxuICBhbmQ6IFN5bWJvbC5mb3IoJ2FuZCcpLFxuICBvcjogU3ltYm9sLmZvcignb3InKSxcbiAgYW55OiBTeW1ib2wuZm9yKCdhbnknKSxcbiAgYWxsOiBTeW1ib2wuZm9yKCdhbGwnKSxcbiAgdmFsdWVzOiBTeW1ib2wuZm9yKCd2YWx1ZXMnKSxcbiAgY29sOiBTeW1ib2wuZm9yKCdjb2wnKSxcbiAgcGxhY2Vob2xkZXI6IFN5bWJvbC5mb3IoJ3BsYWNlaG9sZGVyJyksXG4gIGpvaW46IFN5bWJvbC5mb3IoJ2pvaW4nKVxufTtcblxubW9kdWxlLmV4cG9ydHMgPSBPcDtcbiJdfQ== \ No newline at end of file diff --git a/dist/promise.js b/dist/promise.js index 30458c7..2b80075 100644 --- a/dist/promise.js +++ b/dist/promise.js @@ -5,4 +5,4 @@ const Promise = require('bluebird').getNewLibraryCopy(); module.exports = Promise; module.exports.Promise = Promise; module.exports.default = Promise; -//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uL2xpYi9wcm9taXNlLmpzIl0sIm5hbWVzIjpbIlByb21pc2UiLCJyZXF1aXJlIiwiZ2V0TmV3TGlicmFyeUNvcHkiLCJtb2R1bGUiLCJleHBvcnRzIiwiZGVmYXVsdCJdLCJtYXBwaW5ncyI6IkFBQUE7O0FBRUEsTUFBTUEsT0FBTyxHQUFHQyxPQUFPLENBQUMsVUFBRCxDQUFQLENBQW9CQyxpQkFBcEIsRUFBaEI7O0FBRUFDLE1BQU0sQ0FBQ0MsT0FBUCxHQUFpQkosT0FBakI7QUFDQUcsTUFBTSxDQUFDQyxPQUFQLENBQWVKLE9BQWYsR0FBeUJBLE9BQXpCO0FBQ0FHLE1BQU0sQ0FBQ0MsT0FBUCxDQUFlQyxPQUFmLEdBQXlCTCxPQUF6QiIsInNvdXJjZXNDb250ZW50IjpbIid1c2Ugc3RyaWN0JztcclxuXHJcbmNvbnN0IFByb21pc2UgPSByZXF1aXJlKCdibHVlYmlyZCcpLmdldE5ld0xpYnJhcnlDb3B5KCk7XHJcblxyXG5tb2R1bGUuZXhwb3J0cyA9IFByb21pc2U7XHJcbm1vZHVsZS5leHBvcnRzLlByb21pc2UgPSBQcm9taXNlO1xyXG5tb2R1bGUuZXhwb3J0cy5kZWZhdWx0ID0gUHJvbWlzZTtcclxuIl19 \ No newline at end of file +//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uL2xpYi9wcm9taXNlLmpzIl0sIm5hbWVzIjpbIlByb21pc2UiLCJyZXF1aXJlIiwiZ2V0TmV3TGlicmFyeUNvcHkiLCJtb2R1bGUiLCJleHBvcnRzIiwiZGVmYXVsdCJdLCJtYXBwaW5ncyI6IkFBQUE7O0FBRUEsTUFBTUEsT0FBTyxHQUFHQyxPQUFPLENBQUMsVUFBRCxDQUFQLENBQW9CQyxpQkFBcEIsRUFBaEI7O0FBRUFDLE1BQU0sQ0FBQ0MsT0FBUCxHQUFpQkosT0FBakI7QUFDQUcsTUFBTSxDQUFDQyxPQUFQLENBQWVKLE9BQWYsR0FBeUJBLE9BQXpCO0FBQ0FHLE1BQU0sQ0FBQ0MsT0FBUCxDQUFlQyxPQUFmLEdBQXlCTCxPQUF6QiIsInNvdXJjZXNDb250ZW50IjpbIid1c2Ugc3RyaWN0JztcblxuY29uc3QgUHJvbWlzZSA9IHJlcXVpcmUoJ2JsdWViaXJkJykuZ2V0TmV3TGlicmFyeUNvcHkoKTtcblxubW9kdWxlLmV4cG9ydHMgPSBQcm9taXNlO1xubW9kdWxlLmV4cG9ydHMuUHJvbWlzZSA9IFByb21pc2U7XG5tb2R1bGUuZXhwb3J0cy5kZWZhdWx0ID0gUHJvbWlzZTtcbiJdfQ== \ No newline at end of file diff --git a/dist/query-interface.js b/dist/query-interface.js index 1f586b3..cdd7435 100644 --- a/dist/query-interface.js +++ b/dist/query-interface.js @@ -28,9 +28,7 @@ const Op = require('./operators'); */ -let QueryInterface = -/*#__PURE__*/ -function () { +let QueryInterface = /*#__PURE__*/function () { function QueryInterface(sequelize) { _classCallCheck(this, QueryInterface); @@ -1507,4 +1505,4 @@ function () { module.exports = QueryInterface; module.exports.QueryInterface = QueryInterface; module.exports.default = QueryInterface; -//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../lib/query-interface.js"],"names":["_","require","Utils","DataTypes","SQLiteQueryInterface","Transaction","Promise","QueryTypes","Op","QueryInterface","sequelize","QueryGenerator","dialect","database","options","sql","createDatabaseQuery","query","dropDatabaseQuery","schema","createSchema","dropSchema","_dialect","supports","schemas","drop","showAllSchemas","map","schemaName","Object","assign","raw","type","SELECT","showSchemasSql","showSchemasQuery","then","schemaNames","flatten","value","schema_name","versionQuery","VERSION","tableName","attributes","model","promise","clone","uniqueKeys","forOwn","uniqueKey","customIndex","undefined","mapValues","attribute","normalizeAttribute","PostgresQueryInterface","ensureEnums","resolve","_schema","addSchema","attributesToSQL","table","context","createTableQuery","cascade","force","dropTableQuery","promises","instanceTable","modelManager","getModel","getTableName","keys","rawAttributes","keyLen","length","i","ENUM","pgEnumDrop","supportsSearchPath","push","all","get","skip","dropAllTables","tableNames","each","includes","dropTable","showAllTables","result","foreignKeysAreEnabled","foreign_keys","getForeignKeysForTables","foreignKeys","queries","forEach","normalizedTableName","isObject","foreignKey","dropForeignKeyQuery","q","enumName","getDialect","pgEscapeAndQuote","pgListEnums","enum_name","plain","before","after","renameTableQuery","SHOWTABLES","showTablesSql","showTablesQuery","config","schemaDelimiter","describeTableQuery","DESCRIBE","data","isEmpty","Error","catch","e","original","code","key","addColumnQuery","attributeName","removeColumn","removeColumnQuery","dataTypeOrOptions","values","allowNull","changeColumn","changeColumnQuery","attrNameBefore","attrNameAfter","describeTable","_options","defaultValue","renameColumn","renameColumnQuery","rawTablename","Array","isArray","fields","cloneDeep","addIndexQuery","showIndexesQuery","SHOWINDEXES","FOREIGNKEYS","getForeignKeysQuery","results","r","constraint_name","filter","identity","queryOptions","catalogName","getForeignKeyReferencesForTable","indexNameOrAttributes","removeIndexQuery","name","addConstraint","addConstraintQuery","constraintName","showConstraintsQuery","SHOWCONSTRAINTS","removeConstraint","removeConstraintQuery","instance","hasTrigger","constructor","insertQuery","INSERT","isNewRecord","insertValues","updateValues","where","wheres","indexes","indexFields","isWhereEmpty","_indexes","unique","field","isPlainObject","index","intersection","or","UPSERT","upsertQuery","records","bulkInsertQuery","identifier","_modelOptions","updateQuery","UPDATE","find","models","BULKUPDATE","cascades","deleteQuery","associations","association","onDelete","toLowerCase","useHooks","accessors","instances","destroy","defaults","limit","truncate","truncateTableQuery","optionsArg","selectQuery","arithmeticQuery","attributeSelector","Model","dataType","DECIMAL","FLOAT","parseFloat","INTEGER","BIGINT","parseInt","DATE","Date","triggerName","timingType","fireOnArray","functionName","functionParams","optionsArray","createTrigger","dropTrigger","oldTriggerName","newTriggerName","renameTrigger","params","returnType","language","body","createFunction","dropFunction","oldFunctionName","newFunctionName","renameFunction","quoteIdentifier","quoteTable","identifiers","quoteIdentifiers","escape","transaction","parent","setIsolationLevelQuery","startTransactionQuery","deferConstraintsQuery","completesTransaction","commitTransactionQuery","finished","rollbackTransactionQuery","module","exports","default"],"mappings":"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","sourcesContent":["'use strict';\r\n\r\nconst _ = require('lodash');\r\n\r\nconst Utils = require('./utils');\r\nconst DataTypes = require('./data-types');\r\nconst SQLiteQueryInterface = require('./dialects/sqlite/query-interface');\r\nconst Transaction = require('./transaction');\r\nconst Promise = require('./promise');\r\nconst QueryTypes = require('./query-types');\r\nconst Op = require('./operators');\r\n\r\n/**\r\n * The interface that Sequelize uses to talk to all databases\r\n *\r\n * @class QueryInterface\r\n */\r\nclass QueryInterface {\r\n  constructor(sequelize) {\r\n    this.sequelize = sequelize;\r\n    this.QueryGenerator = this.sequelize.dialect.QueryGenerator;\r\n  }\r\n\r\n  /**\r\n   * Create a database\r\n   *\r\n   * @param {string} database  Database name to create\r\n   * @param {Object} [options] Query options\r\n   * @param {string} [options.charset] Database default character set, MYSQL only\r\n   * @param {string} [options.collate] Database default collation\r\n   * @param {string} [options.encoding] Database default character set, PostgreSQL only\r\n   * @param {string} [options.ctype] Database character classification, PostgreSQL only\r\n   * @param {string} [options.template] The name of the template from which to create the new database, PostgreSQL only\r\n   *\r\n   * @returns {Promise}\r\n   */\r\n  createDatabase(database, options) {\r\n    options = options || {};\r\n    const sql = this.QueryGenerator.createDatabaseQuery(database, options);\r\n    return this.sequelize.query(sql, options);\r\n  }\r\n\r\n  /**\r\n   * Drop a database\r\n   *\r\n   * @param {string} database  Database name to drop\r\n   * @param {Object} [options] Query options\r\n   *\r\n   * @returns {Promise}\r\n   */\r\n  dropDatabase(database, options) {\r\n    options = options || {};\r\n    const sql = this.QueryGenerator.dropDatabaseQuery(database);\r\n    return this.sequelize.query(sql, options);\r\n  }\r\n\r\n  /**\r\n   * Create a schema\r\n   *\r\n   * @param {string} schema    Schema name to create\r\n   * @param {Object} [options] Query options\r\n   *\r\n   * @returns {Promise}\r\n   */\r\n  createSchema(schema, options) {\r\n    options = options || {};\r\n    const sql = this.QueryGenerator.createSchema(schema);\r\n    return this.sequelize.query(sql, options);\r\n  }\r\n\r\n  /**\r\n   * Drop a schema\r\n   *\r\n   * @param {string} schema    Schema name to drop\r\n   * @param {Object} [options] Query options\r\n   *\r\n   * @returns {Promise}\r\n   */\r\n  dropSchema(schema, options) {\r\n    options = options || {};\r\n    const sql = this.QueryGenerator.dropSchema(schema);\r\n    return this.sequelize.query(sql, options);\r\n  }\r\n\r\n  /**\r\n   * Drop all schemas\r\n   *\r\n   * @param {Object} [options] Query options\r\n   *\r\n   * @returns {Promise}\r\n   */\r\n  dropAllSchemas(options) {\r\n    options = options || {};\r\n\r\n    if (!this.QueryGenerator._dialect.supports.schemas) {\r\n      return this.sequelize.drop(options);\r\n    }\r\n    return this.showAllSchemas(options).map(schemaName => this.dropSchema(schemaName, options));\r\n  }\r\n\r\n  /**\r\n   * Show all schemas\r\n   *\r\n   * @param {Object} [options] Query options\r\n   *\r\n   * @returns {Promise<Array>}\r\n   */\r\n  showAllSchemas(options) {\r\n    options = Object.assign({}, options, {\r\n      raw: true,\r\n      type: this.sequelize.QueryTypes.SELECT\r\n    });\r\n\r\n    const showSchemasSql = this.QueryGenerator.showSchemasQuery(options);\r\n\r\n    return this.sequelize.query(showSchemasSql, options).then(schemaNames => _.flatten(\r\n      schemaNames.map(value => value.schema_name ? value.schema_name : value)\r\n    ));\r\n  }\r\n\r\n  /**\r\n   * Return database version\r\n   *\r\n   * @param {Object}    [options]      Query options\r\n   * @param {QueryType} [options.type] Query type\r\n   *\r\n   * @returns {Promise}\r\n   * @private\r\n   */\r\n  databaseVersion(options) {\r\n    return this.sequelize.query(\r\n      this.QueryGenerator.versionQuery(),\r\n      Object.assign({}, options, { type: QueryTypes.VERSION })\r\n    );\r\n  }\r\n\r\n  /**\r\n   * Create a table with given set of attributes\r\n   *\r\n   * ```js\r\n   * queryInterface.createTable(\r\n   *   'nameOfTheNewTable',\r\n   *   {\r\n   *     id: {\r\n   *       type: Sequelize.INTEGER,\r\n   *       primaryKey: true,\r\n   *       autoIncrement: true\r\n   *     },\r\n   *     createdAt: {\r\n   *       type: Sequelize.DATE\r\n   *     },\r\n   *     updatedAt: {\r\n   *       type: Sequelize.DATE\r\n   *     },\r\n   *     attr1: Sequelize.STRING,\r\n   *     attr2: Sequelize.INTEGER,\r\n   *     attr3: {\r\n   *       type: Sequelize.BOOLEAN,\r\n   *       defaultValue: false,\r\n   *       allowNull: false\r\n   *     },\r\n   *     //foreign key usage\r\n   *     attr4: {\r\n   *       type: Sequelize.INTEGER,\r\n   *       references: {\r\n   *         model: 'another_table_name',\r\n   *         key: 'id'\r\n   *       },\r\n   *       onUpdate: 'cascade',\r\n   *       onDelete: 'cascade'\r\n   *     }\r\n   *   },\r\n   *   {\r\n   *     engine: 'MYISAM',    // default: 'InnoDB'\r\n   *     charset: 'latin1',   // default: null\r\n   *     schema: 'public',    // default: public, PostgreSQL only.\r\n   *     comment: 'my table', // comment for table\r\n   *     collate: 'latin1_danish_ci' // collation, MYSQL only\r\n   *   }\r\n   * )\r\n   * ```\r\n   *\r\n   * @param {string} tableName  Name of table to create\r\n   * @param {Object} attributes Object representing a list of table attributes to create\r\n   * @param {Object} [options] create table and query options\r\n   * @param {Model}  [model] model class\r\n   *\r\n   * @returns {Promise}\r\n   */\r\n  createTable(tableName, attributes, options, model) {\r\n    let sql = '';\r\n    let promise;\r\n\r\n    options = _.clone(options) || {};\r\n\r\n    if (options && options.uniqueKeys) {\r\n      _.forOwn(options.uniqueKeys, uniqueKey => {\r\n        if (uniqueKey.customIndex === undefined) {\r\n          uniqueKey.customIndex = true;\r\n        }\r\n      });\r\n    }\r\n\r\n    if (model) {\r\n      options.uniqueKeys = options.uniqueKeys || model.uniqueKeys;\r\n    }\r\n\r\n    attributes = _.mapValues(\r\n      attributes,\r\n      attribute => this.sequelize.normalizeAttribute(attribute)\r\n    );\r\n\r\n    // Postgres requires special SQL commands for ENUM/ENUM[]\r\n    if (this.sequelize.options.dialect === 'postgres') {\r\n      promise = PostgresQueryInterface.ensureEnums(this, tableName, attributes, options, model);\r\n    } else {\r\n      promise = Promise.resolve();\r\n    }\r\n\r\n    if (\r\n      !tableName.schema &&\r\n      (options.schema || !!model && model._schema)\r\n    ) {\r\n      tableName = this.QueryGenerator.addSchema({\r\n        tableName,\r\n        _schema: !!model && model._schema || options.schema\r\n      });\r\n    }\r\n\r\n    attributes = this.QueryGenerator.attributesToSQL(attributes, { table: tableName, context: 'createTable' });\r\n    sql = this.QueryGenerator.createTableQuery(tableName, attributes, options);\r\n\r\n    return promise.then(() => this.sequelize.query(sql, options));\r\n  }\r\n\r\n  /**\r\n   * Drop a table from database\r\n   *\r\n   * @param {string} tableName Table name to drop\r\n   * @param {Object} options   Query options\r\n   *\r\n   * @returns {Promise}\r\n   */\r\n  dropTable(tableName, options) {\r\n    // if we're forcing we should be cascading unless explicitly stated otherwise\r\n    options = _.clone(options) || {};\r\n    options.cascade = options.cascade || options.force || false;\r\n\r\n    let sql = this.QueryGenerator.dropTableQuery(tableName, options);\r\n\r\n    return this.sequelize.query(sql, options).then(() => {\r\n      const promises = [];\r\n\r\n      // Since postgres has a special case for enums, we should drop the related\r\n      // enum type within the table and attribute\r\n      if (this.sequelize.options.dialect === 'postgres') {\r\n        const instanceTable = this.sequelize.modelManager.getModel(tableName, { attribute: 'tableName' });\r\n\r\n        if (instanceTable) {\r\n          const getTableName = (!options || !options.schema || options.schema === 'public' ? '' : `${options.schema}_`) + tableName;\r\n\r\n          const keys = Object.keys(instanceTable.rawAttributes);\r\n          const keyLen = keys.length;\r\n\r\n          for (let i = 0; i < keyLen; i++) {\r\n            if (instanceTable.rawAttributes[keys[i]].type instanceof DataTypes.ENUM) {\r\n              sql = this.QueryGenerator.pgEnumDrop(getTableName, keys[i]);\r\n              options.supportsSearchPath = false;\r\n              promises.push(this.sequelize.query(sql, Object.assign({}, options, { raw: true })));\r\n            }\r\n          }\r\n        }\r\n      }\r\n\r\n      return Promise.all(promises).get(0);\r\n    });\r\n  }\r\n\r\n  /**\r\n   * Drop all tables from database\r\n   *\r\n   * @param {Object} [options] query options\r\n   * @param {Array}  [options.skip] List of table to skip\r\n   *\r\n   * @returns {Promise}\r\n   */\r\n  dropAllTables(options) {\r\n    options = options || {};\r\n    const skip = options.skip || [];\r\n\r\n    const dropAllTables = tableNames => Promise.each(tableNames, tableName => {\r\n      // if tableName is not in the Array of tables names then don't drop it\r\n      if (!skip.includes(tableName.tableName || tableName)) {\r\n        return this.dropTable(tableName, Object.assign({}, options, { cascade: true }) );\r\n      }\r\n    });\r\n\r\n    return this.showAllTables(options).then(tableNames => {\r\n      if (this.sequelize.options.dialect === 'sqlite') {\r\n        return this.sequelize.query('PRAGMA foreign_keys;', options).then(result => {\r\n          const foreignKeysAreEnabled = result.foreign_keys === 1;\r\n\r\n          if (foreignKeysAreEnabled) {\r\n            return this.sequelize.query('PRAGMA foreign_keys = OFF', options)\r\n              .then(() => dropAllTables(tableNames))\r\n              .then(() => this.sequelize.query('PRAGMA foreign_keys = ON', options));\r\n          }\r\n          return dropAllTables(tableNames);\r\n        });\r\n      }\r\n      return this.getForeignKeysForTables(tableNames, options).then(foreignKeys => {\r\n        const queries = [];\r\n\r\n        tableNames.forEach(tableName => {\r\n          let normalizedTableName = tableName;\r\n          if (_.isObject(tableName)) {\r\n            normalizedTableName = `${tableName.schema}.${tableName.tableName}`;\r\n          }\r\n\r\n          foreignKeys[normalizedTableName].forEach(foreignKey => {\r\n            queries.push(this.QueryGenerator.dropForeignKeyQuery(tableName, foreignKey));\r\n          });\r\n        });\r\n\r\n        return Promise.each(queries, q => this.sequelize.query(q, options))\r\n          .then(() => dropAllTables(tableNames));\r\n      });\r\n    });\r\n  }\r\n\r\n  /**\r\n   * Drop specified enum from database (Postgres only)\r\n   *\r\n   * @param {string} [enumName]  Enum name to drop\r\n   * @param {Object} options Query options\r\n   *\r\n   * @returns {Promise}\r\n   * @private\r\n   */\r\n  dropEnum(enumName, options) {\r\n    if (this.sequelize.getDialect() !== 'postgres') {\r\n      return Promise.resolve();\r\n    }\r\n\r\n    options = options || {};\r\n\r\n    return this.sequelize.query(\r\n      this.QueryGenerator.pgEnumDrop(null, null, this.QueryGenerator.pgEscapeAndQuote(enumName)),\r\n      Object.assign({}, options, { raw: true })\r\n    );\r\n  }\r\n\r\n  /**\r\n   * Drop all enums from database (Postgres only)\r\n   *\r\n   * @param {Object} options Query options\r\n   *\r\n   * @returns {Promise}\r\n   * @private\r\n   */\r\n  dropAllEnums(options) {\r\n    if (this.sequelize.getDialect() !== 'postgres') {\r\n      return Promise.resolve();\r\n    }\r\n\r\n    options = options || {};\r\n\r\n    return this.pgListEnums(null, options).map(result => this.sequelize.query(\r\n      this.QueryGenerator.pgEnumDrop(null, null, this.QueryGenerator.pgEscapeAndQuote(result.enum_name)),\r\n      Object.assign({}, options, { raw: true })\r\n    ));\r\n  }\r\n\r\n  /**\r\n   * List all enums (Postgres only)\r\n   *\r\n   * @param {string} [tableName]  Table whose enum to list\r\n   * @param {Object} [options]    Query options\r\n   *\r\n   * @returns {Promise}\r\n   * @private\r\n   */\r\n  pgListEnums(tableName, options) {\r\n    options = options || {};\r\n    const sql = this.QueryGenerator.pgListEnums(tableName);\r\n    return this.sequelize.query(sql, Object.assign({}, options, { plain: false, raw: true, type: QueryTypes.SELECT }));\r\n  }\r\n\r\n  /**\r\n   * Rename a table\r\n   *\r\n   * @param {string} before    Current name of table\r\n   * @param {string} after     New name from table\r\n   * @param {Object} [options] Query options\r\n   *\r\n   * @returns {Promise}\r\n   */\r\n  renameTable(before, after, options) {\r\n    options = options || {};\r\n    const sql = this.QueryGenerator.renameTableQuery(before, after);\r\n    return this.sequelize.query(sql, options);\r\n  }\r\n\r\n  /**\r\n   * Get all tables in current database\r\n   *\r\n   * @param {Object}    [options] Query options\r\n   * @param {boolean}   [options.raw=true] Run query in raw mode\r\n   * @param {QueryType} [options.type=QueryType.SHOWTABLE] query type\r\n   *\r\n   * @returns {Promise<Array>}\r\n   * @private\r\n   */\r\n  showAllTables(options) {\r\n    options = Object.assign({}, options, {\r\n      raw: true,\r\n      type: QueryTypes.SHOWTABLES\r\n    });\r\n\r\n    const showTablesSql = this.QueryGenerator.showTablesQuery(this.sequelize.config.database);\r\n    return this.sequelize.query(showTablesSql, options).then(tableNames => _.flatten(tableNames));\r\n  }\r\n\r\n  /**\r\n   * Describe a table structure\r\n   *\r\n   * This method returns an array of hashes containing information about all attributes in the table.\r\n   *\r\n   * ```js\r\n   * {\r\n   *    name: {\r\n   *      type:         'VARCHAR(255)', // this will be 'CHARACTER VARYING' for pg!\r\n   *      allowNull:    true,\r\n   *      defaultValue: null\r\n   *    },\r\n   *    isBetaMember: {\r\n   *      type:         'TINYINT(1)', // this will be 'BOOLEAN' for pg!\r\n   *      allowNull:    false,\r\n   *      defaultValue: false\r\n   *    }\r\n   * }\r\n   * ```\r\n   *\r\n   * @param {string} tableName table name\r\n   * @param {Object} [options] Query options\r\n   *\r\n   * @returns {Promise<Object>}\r\n   */\r\n  describeTable(tableName, options) {\r\n    let schema = null;\r\n    let schemaDelimiter = null;\r\n\r\n    if (typeof options === 'string') {\r\n      schema = options;\r\n    } else if (typeof options === 'object' && options !== null) {\r\n      schema = options.schema || null;\r\n      schemaDelimiter = options.schemaDelimiter || null;\r\n    }\r\n\r\n    if (typeof tableName === 'object' && tableName !== null) {\r\n      schema = tableName.schema;\r\n      tableName = tableName.tableName;\r\n    }\r\n\r\n    const sql = this.QueryGenerator.describeTableQuery(tableName, schema, schemaDelimiter);\r\n    options = Object.assign({}, options, { type: QueryTypes.DESCRIBE });\r\n\r\n    return this.sequelize.query(sql, options).then(data => {\r\n      /*\r\n       * If no data is returned from the query, then the table name may be wrong.\r\n       * Query generators that use information_schema for retrieving table info will just return an empty result set,\r\n       * it will not throw an error like built-ins do (e.g. DESCRIBE on MySql).\r\n       */\r\n      if (_.isEmpty(data)) {\r\n        throw new Error(`No description found for \"${tableName}\" table. Check the table name and schema; remember, they _are_ case sensitive.`);\r\n      }\r\n\r\n      return data;\r\n    }).catch(e => {\r\n      if (e.original && e.original.code === 'ER_NO_SUCH_TABLE') {\r\n        throw Error(`No description found for \"${tableName}\" table. Check the table name and schema; remember, they _are_ case sensitive.`);\r\n      }\r\n\r\n      throw e;\r\n    });\r\n  }\r\n\r\n  /**\r\n   * Add a new column to a table\r\n   *\r\n   * ```js\r\n   * queryInterface.addColumn('tableA', 'columnC', Sequelize.STRING, {\r\n   *    after: 'columnB' // after option is only supported by MySQL\r\n   * });\r\n   * ```\r\n   *\r\n   * @param {string} table     Table to add column to\r\n   * @param {string} key       Column name\r\n   * @param {Object} attribute Attribute definition\r\n   * @param {Object} [options] Query options\r\n   *\r\n   * @returns {Promise}\r\n   */\r\n  addColumn(table, key, attribute, options) {\r\n    if (!table || !key || !attribute) {\r\n      throw new Error('addColumn takes at least 3 arguments (table, attribute name, attribute definition)');\r\n    }\r\n\r\n    options = options || {};\r\n    attribute = this.sequelize.normalizeAttribute(attribute);\r\n    return this.sequelize.query(this.QueryGenerator.addColumnQuery(table, key, attribute), options);\r\n  }\r\n\r\n  /**\r\n   * Remove a column from a table\r\n   *\r\n   * @param {string} tableName      Table to remove column from\r\n   * @param {string} attributeName  Column name to remove\r\n   * @param {Object} [options]      Query options\r\n   *\r\n   * @returns {Promise}\r\n   */\r\n  removeColumn(tableName, attributeName, options) {\r\n    options = options || {};\r\n    switch (this.sequelize.options.dialect) {\r\n      case 'sqlite':\r\n        // sqlite needs some special treatment as it cannot drop a column\r\n        return SQLiteQueryInterface.removeColumn(this, tableName, attributeName, options);\r\n      default:\r\n        return this.sequelize.query(this.QueryGenerator.removeColumnQuery(tableName, attributeName), options);\r\n    }\r\n  }\r\n\r\n  /**\r\n   * Change a column definition\r\n   *\r\n   * @param {string} tableName          Table name to change from\r\n   * @param {string} attributeName      Column name\r\n   * @param {Object} dataTypeOrOptions  Attribute definition for new column\r\n   * @param {Object} [options]          Query options\r\n   *\r\n   * @returns {Promise}\r\n   */\r\n  changeColumn(tableName, attributeName, dataTypeOrOptions, options) {\r\n    const attributes = {};\r\n    options = options || {};\r\n\r\n    if (_.values(DataTypes).includes(dataTypeOrOptions)) {\r\n      attributes[attributeName] = { type: dataTypeOrOptions, allowNull: true };\r\n    } else {\r\n      attributes[attributeName] = dataTypeOrOptions;\r\n    }\r\n\r\n    attributes[attributeName] = this.sequelize.normalizeAttribute(attributes[attributeName]);\r\n\r\n    if (this.sequelize.options.dialect === 'sqlite') {\r\n      // sqlite needs some special treatment as it cannot change a column\r\n      return SQLiteQueryInterface.changeColumn(this, tableName, attributes, options);\r\n    }\r\n    const query = this.QueryGenerator.attributesToSQL(attributes, {\r\n      context: 'changeColumn',\r\n      table: tableName\r\n    });\r\n    const sql = this.QueryGenerator.changeColumnQuery(tableName, query);\r\n\r\n    return this.sequelize.query(sql, options);\r\n  }\r\n\r\n  /**\r\n   * Rename a column\r\n   *\r\n   * @param {string} tableName        Table name whose column to rename\r\n   * @param {string} attrNameBefore   Current column name\r\n   * @param {string} attrNameAfter    New column name\r\n   * @param {Object} [options]        Query option\r\n   *\r\n   * @returns {Promise}\r\n   */\r\n  renameColumn(tableName, attrNameBefore, attrNameAfter, options) {\r\n    options = options || {};\r\n    return this.describeTable(tableName, options).then(data => {\r\n      if (!data[attrNameBefore]) {\r\n        throw new Error(`Table ${tableName} doesn't have the column ${attrNameBefore}`);\r\n      }\r\n\r\n      data = data[attrNameBefore] || {};\r\n\r\n      const _options = {};\r\n\r\n      _options[attrNameAfter] = {\r\n        attribute: attrNameAfter,\r\n        type: data.type,\r\n        allowNull: data.allowNull,\r\n        defaultValue: data.defaultValue\r\n      };\r\n\r\n      // fix: a not-null column cannot have null as default value\r\n      if (data.defaultValue === null && !data.allowNull) {\r\n        delete _options[attrNameAfter].defaultValue;\r\n      }\r\n\r\n      if (this.sequelize.options.dialect === 'sqlite') {\r\n        // sqlite needs some special treatment as it cannot rename a column\r\n        return SQLiteQueryInterface.renameColumn(this, tableName, attrNameBefore, attrNameAfter, options);\r\n      }\r\n      const sql = this.QueryGenerator.renameColumnQuery(\r\n        tableName,\r\n        attrNameBefore,\r\n        this.QueryGenerator.attributesToSQL(_options)\r\n      );\r\n      return this.sequelize.query(sql, options);\r\n    });\r\n  }\r\n\r\n  /**\r\n   * Add an index to a column\r\n   *\r\n   * @param {string|Object}  tableName Table name to add index on, can be a object with schema\r\n   * @param {Array}   [attributes]     Use options.fields instead, List of attributes to add index on\r\n   * @param {Object}  options          indexes options\r\n   * @param {Array}   options.fields   List of attributes to add index on\r\n   * @param {boolean} [options.concurrently] Pass CONCURRENT so other operations run while the index is created\r\n   * @param {boolean} [options.unique] Create a unique index\r\n   * @param {string}  [options.using]  Useful for GIN indexes\r\n   * @param {string}  [options.operator] Index operator\r\n   * @param {string}  [options.type]   Type of index, available options are UNIQUE|FULLTEXT|SPATIAL\r\n   * @param {string}  [options.name]   Name of the index. Default is <table>_<attr1>_<attr2>\r\n   * @param {Object}  [options.where]  Where condition on index, for partial indexes\r\n   * @param {string}  [rawTablename]   table name, this is just for backward compatibiity\r\n   *\r\n   * @returns {Promise}\r\n   */\r\n  addIndex(tableName, attributes, options, rawTablename) {\r\n    // Support for passing tableName, attributes, options or tableName, options (with a fields param which is the attributes)\r\n    if (!Array.isArray(attributes)) {\r\n      rawTablename = options;\r\n      options = attributes;\r\n      attributes = options.fields;\r\n    }\r\n\r\n    if (!rawTablename) {\r\n      // Map for backwards compat\r\n      rawTablename = tableName;\r\n    }\r\n\r\n    options = Utils.cloneDeep(options);\r\n    options.fields = attributes;\r\n    const sql = this.QueryGenerator.addIndexQuery(tableName, options, rawTablename);\r\n    return this.sequelize.query(sql, Object.assign({}, options, { supportsSearchPath: false }));\r\n  }\r\n\r\n  /**\r\n   * Show indexes on a table\r\n   *\r\n   * @param {string} tableName table name\r\n   * @param {Object} [options]   Query options\r\n   *\r\n   * @returns {Promise<Array>}\r\n   * @private\r\n   */\r\n  showIndex(tableName, options) {\r\n    const sql = this.QueryGenerator.showIndexesQuery(tableName, options);\r\n    return this.sequelize.query(sql, Object.assign({}, options, { type: QueryTypes.SHOWINDEXES }));\r\n  }\r\n\r\n  getForeignKeysForTables(tableNames, options) {\r\n    if (tableNames.length === 0) {\r\n      return Promise.resolve({});\r\n    }\r\n\r\n    options = Object.assign({}, options || {}, { type: QueryTypes.FOREIGNKEYS });\r\n\r\n    return Promise.map(tableNames, tableName =>\r\n      this.sequelize.query(this.QueryGenerator.getForeignKeysQuery(tableName, this.sequelize.config.database), options)\r\n    ).then(results => {\r\n      const result = {};\r\n\r\n      tableNames.forEach((tableName, i) => {\r\n        if (_.isObject(tableName)) {\r\n          tableName = `${tableName.schema}.${tableName.tableName}`;\r\n        }\r\n\r\n        result[tableName] = Array.isArray(results[i])\r\n          ? results[i].map(r => r.constraint_name)\r\n          : [results[i] && results[i].constraint_name];\r\n\r\n        result[tableName] = result[tableName].filter(_.identity);\r\n      });\r\n\r\n      return result;\r\n    });\r\n  }\r\n\r\n  /**\r\n   * Get foreign key references details for the table\r\n   *\r\n   * Those details contains constraintSchema, constraintName, constraintCatalog\r\n   * tableCatalog, tableSchema, tableName, columnName,\r\n   * referencedTableCatalog, referencedTableCatalog, referencedTableSchema, referencedTableName, referencedColumnName.\r\n   * Remind: constraint informations won't return if it's sqlite.\r\n   *\r\n   * @param {string} tableName table name\r\n   * @param {Object} [options]  Query options\r\n   *\r\n   * @returns {Promise}\r\n   */\r\n  getForeignKeyReferencesForTable(tableName, options) {\r\n    const queryOptions = Object.assign({}, options, {\r\n      type: QueryTypes.FOREIGNKEYS\r\n    });\r\n    const catalogName = this.sequelize.config.database;\r\n    switch (this.sequelize.options.dialect) {\r\n      case 'sqlite':\r\n        // sqlite needs some special treatment.\r\n        return SQLiteQueryInterface.getForeignKeyReferencesForTable(this, tableName, queryOptions);\r\n      default: {\r\n        const query = this.QueryGenerator.getForeignKeysQuery(tableName, catalogName);\r\n        return this.sequelize.query(query, queryOptions);\r\n      }\r\n    }\r\n  }\r\n\r\n  /**\r\n   * Remove an already existing index from a table\r\n   *\r\n   * @param {string} tableName             Table name to drop index from\r\n   * @param {string} indexNameOrAttributes Index name\r\n   * @param {Object} [options]             Query options\r\n   *\r\n   * @returns {Promise}\r\n   */\r\n  removeIndex(tableName, indexNameOrAttributes, options) {\r\n    options = options || {};\r\n    const sql = this.QueryGenerator.removeIndexQuery(tableName, indexNameOrAttributes);\r\n    return this.sequelize.query(sql, options);\r\n  }\r\n\r\n  /**\r\n   * Add a constraint to a table\r\n   *\r\n   * Available constraints:\r\n   * - UNIQUE\r\n   * - DEFAULT (MSSQL only)\r\n   * - CHECK (MySQL - Ignored by the database engine )\r\n   * - FOREIGN KEY\r\n   * - PRIMARY KEY\r\n   *\r\n   * @example <caption>UNIQUE</caption>\r\n   * queryInterface.addConstraint('Users', ['email'], {\r\n   *   type: 'unique',\r\n   *   name: 'custom_unique_constraint_name'\r\n   * });\r\n   *\r\n   * @example <caption>CHECK</caption>\r\n   * queryInterface.addConstraint('Users', ['roles'], {\r\n   *   type: 'check',\r\n   *   where: {\r\n   *      roles: ['user', 'admin', 'moderator', 'guest']\r\n   *   }\r\n   * });\r\n   *\r\n   * @example <caption>Default - MSSQL only</caption>\r\n   * queryInterface.addConstraint('Users', ['roles'], {\r\n   *    type: 'default',\r\n   *    defaultValue: 'guest'\r\n   * });\r\n   *\r\n   * @example <caption>Primary Key</caption>\r\n   * queryInterface.addConstraint('Users', ['username'], {\r\n   *    type: 'primary key',\r\n   *    name: 'custom_primary_constraint_name'\r\n   * });\r\n   *\r\n   * @example <caption>Foreign Key</caption>\r\n   * queryInterface.addConstraint('Posts', ['username'], {\r\n   *   type: 'foreign key',\r\n   *   name: 'custom_fkey_constraint_name',\r\n   *   references: { //Required field\r\n   *     table: 'target_table_name',\r\n   *     field: 'target_column_name'\r\n   *   },\r\n   *   onDelete: 'cascade',\r\n   *   onUpdate: 'cascade'\r\n   * });\r\n   *\r\n   * @param {string} tableName                  Table name where you want to add a constraint\r\n   * @param {Array}  attributes                 Array of column names to apply the constraint over\r\n   * @param {Object} options                    An object to define the constraint name, type etc\r\n   * @param {string} options.type               Type of constraint. One of the values in available constraints(case insensitive)\r\n   * @param {string} [options.name]             Name of the constraint. If not specified, sequelize automatically creates a named constraint based on constraint type, table & column names\r\n   * @param {string} [options.defaultValue]     The value for the default constraint\r\n   * @param {Object} [options.where]            Where clause/expression for the CHECK constraint\r\n   * @param {Object} [options.references]       Object specifying target table, column name to create foreign key constraint\r\n   * @param {string} [options.references.table] Target table name\r\n   * @param {string} [options.references.field] Target column name\r\n   * @param {string} [rawTablename]             Table name, for backward compatibility\r\n   *\r\n   * @returns {Promise}\r\n   */\r\n  addConstraint(tableName, attributes, options, rawTablename) {\r\n    if (!Array.isArray(attributes)) {\r\n      rawTablename = options;\r\n      options = attributes;\r\n      attributes = options.fields;\r\n    }\r\n\r\n    if (!options.type) {\r\n      throw new Error('Constraint type must be specified through options.type');\r\n    }\r\n\r\n    if (!rawTablename) {\r\n      // Map for backwards compat\r\n      rawTablename = tableName;\r\n    }\r\n\r\n    options = Utils.cloneDeep(options);\r\n    options.fields = attributes;\r\n\r\n    if (this.sequelize.dialect.name === 'sqlite') {\r\n      return SQLiteQueryInterface.addConstraint(this, tableName, options, rawTablename);\r\n    }\r\n    const sql = this.QueryGenerator.addConstraintQuery(tableName, options, rawTablename);\r\n    return this.sequelize.query(sql, options);\r\n  }\r\n\r\n  showConstraint(tableName, constraintName, options) {\r\n    const sql = this.QueryGenerator.showConstraintsQuery(tableName, constraintName);\r\n    return this.sequelize.query(sql, Object.assign({}, options, { type: QueryTypes.SHOWCONSTRAINTS }));\r\n  }\r\n\r\n  /**\r\n   * Remove a constraint from a table\r\n   *\r\n   * @param {string} tableName       Table name to drop constraint from\r\n   * @param {string} constraintName  Constraint name\r\n   * @param {Object} options         Query options\r\n   *\r\n   * @returns {Promise}\r\n   */\r\n  removeConstraint(tableName, constraintName, options) {\r\n    options = options || {};\r\n\r\n    switch (this.sequelize.options.dialect) {\r\n      case 'sqlite':\r\n        return SQLiteQueryInterface.removeConstraint(this, tableName, constraintName, options);\r\n      default:\r\n        const sql = this.QueryGenerator.removeConstraintQuery(tableName, constraintName);\r\n        return this.sequelize.query(sql, options);\r\n    }\r\n  }\r\n\r\n  insert(instance, tableName, values, options) {\r\n    options = Utils.cloneDeep(options);\r\n    options.hasTrigger = instance && instance.constructor.options.hasTrigger;\r\n    const sql = this.QueryGenerator.insertQuery(tableName, values, instance && instance.constructor.rawAttributes, options);\r\n\r\n    options.type = QueryTypes.INSERT;\r\n    options.instance = instance;\r\n\r\n    return this.sequelize.query(sql, options).then(results => {\r\n      if (instance) results[0].isNewRecord = false;\r\n      return results;\r\n    });\r\n  }\r\n\r\n  /**\r\n   * Upsert\r\n   *\r\n   * @param {string} tableName    table to upsert on\r\n   * @param {Object} insertValues values to be inserted, mapped to field name\r\n   * @param {Object} updateValues values to be updated, mapped to field name\r\n   * @param {Object} where        various conditions\r\n   * @param {Model}  model        Model to upsert on\r\n   * @param {Object} options      query options\r\n   *\r\n   * @returns {Promise<boolean,?number>} Resolves an array with <created, primaryKey>\r\n   */\r\n  upsert(tableName, insertValues, updateValues, where, model, options) {\r\n    const wheres = [];\r\n    const attributes = Object.keys(insertValues);\r\n    let indexes = [];\r\n    let indexFields;\r\n\r\n    options = _.clone(options);\r\n\r\n    if (!Utils.isWhereEmpty(where)) {\r\n      wheres.push(where);\r\n    }\r\n\r\n    // Lets combine unique keys and indexes into one\r\n    indexes = _.map(model.uniqueKeys, value => {\r\n      return value.fields;\r\n    });\r\n\r\n    model._indexes.forEach(value => {\r\n      if (value.unique) {\r\n        // fields in the index may both the strings or objects with an attribute property - lets sanitize that\r\n        indexFields = value.fields.map(field => {\r\n          if (_.isPlainObject(field)) {\r\n            return field.attribute;\r\n          }\r\n          return field;\r\n        });\r\n        indexes.push(indexFields);\r\n      }\r\n    });\r\n\r\n    for (const index of indexes) {\r\n      if (_.intersection(attributes, index).length === index.length) {\r\n        where = {};\r\n        for (const field of index) {\r\n          where[field] = insertValues[field];\r\n        }\r\n        wheres.push(where);\r\n      }\r\n    }\r\n\r\n    where = { [Op.or]: wheres };\r\n\r\n    options.type = QueryTypes.UPSERT;\r\n    options.raw = true;\r\n\r\n    const sql = this.QueryGenerator.upsertQuery(tableName, insertValues, updateValues, where, model, options);\r\n    return this.sequelize.query(sql, options).then(result => {\r\n      switch (this.sequelize.options.dialect) {\r\n        default:\r\n          return [result, undefined];\r\n      }\r\n    });\r\n  }\r\n\r\n  /**\r\n   * Insert multiple records into a table\r\n   *\r\n   * @example\r\n   * queryInterface.bulkInsert('roles', [{\r\n   *    label: 'user',\r\n   *    createdAt: new Date(),\r\n   *    updatedAt: new Date()\r\n   *  }, {\r\n   *    label: 'admin',\r\n   *    createdAt: new Date(),\r\n   *    updatedAt: new Date()\r\n   *  }]);\r\n   *\r\n   * @param {string} tableName   Table name to insert record to\r\n   * @param {Array}  records     List of records to insert\r\n   * @param {Object} options     Various options, please see Model.bulkCreate options\r\n   * @param {Object} attributes  Various attributes mapped by field name\r\n   *\r\n   * @returns {Promise}\r\n   */\r\n  bulkInsert(tableName, records, options, attributes) {\r\n    options = _.clone(options) || {};\r\n    options.type = QueryTypes.INSERT;\r\n\r\n    return this.sequelize.query(\r\n      this.QueryGenerator.bulkInsertQuery(tableName, records, options, attributes),\r\n      options\r\n    ).then(results => results[0]);\r\n  }\r\n\r\n  update(instance, tableName, values, identifier, options) {\r\n    options = _.clone(options || {});\r\n    options.hasTrigger = !!(instance && instance._modelOptions && instance._modelOptions.hasTrigger);\r\n\r\n    const sql = this.QueryGenerator.updateQuery(tableName, values, identifier, options, instance.constructor.rawAttributes);\r\n\r\n    options.type = QueryTypes.UPDATE;\r\n\r\n    options.instance = instance;\r\n    return this.sequelize.query(sql, options);\r\n  }\r\n\r\n  /**\r\n   * Update multiple records of a table\r\n   *\r\n   * @example\r\n   * queryInterface.bulkUpdate('roles', {\r\n   *     label: 'admin',\r\n   *   }, {\r\n   *     userType: 3,\r\n   *   },\r\n   * );\r\n   *\r\n   * @param {string} tableName     Table name to update\r\n   * @param {Object} values        Values to be inserted, mapped to field name\r\n   * @param {Object} identifier    A hash with conditions OR an ID as integer OR a string with conditions\r\n   * @param {Object} [options]     Various options, please see Model.bulkCreate options\r\n   * @param {Object} [attributes]  Attributes on return objects if supported by SQL dialect\r\n   *\r\n   * @returns {Promise}\r\n   */\r\n  bulkUpdate(tableName, values, identifier, options, attributes) {\r\n    options = Utils.cloneDeep(options);\r\n    if (typeof identifier === 'object') identifier = Utils.cloneDeep(identifier);\r\n\r\n    const sql = this.QueryGenerator.updateQuery(tableName, values, identifier, options, attributes);\r\n    const table = _.isObject(tableName) ? tableName : { tableName };\r\n    const model = _.find(this.sequelize.modelManager.models, { tableName: table.tableName });\r\n\r\n    options.type = QueryTypes.BULKUPDATE;\r\n    options.model = model;\r\n    return this.sequelize.query(sql, options);\r\n  }\r\n\r\n  delete(instance, tableName, identifier, options) {\r\n    const cascades = [];\r\n    const sql = this.QueryGenerator.deleteQuery(tableName, identifier, {}, instance.constructor);\r\n\r\n    options = _.clone(options) || {};\r\n\r\n    // Check for a restrict field\r\n    if (!!instance.constructor && !!instance.constructor.associations) {\r\n      const keys = Object.keys(instance.constructor.associations);\r\n      const length = keys.length;\r\n      let association;\r\n\r\n      for (let i = 0; i < length; i++) {\r\n        association = instance.constructor.associations[keys[i]];\r\n        if (association.options && association.options.onDelete &&\r\n          association.options.onDelete.toLowerCase() === 'cascade' &&\r\n          association.options.useHooks === true) {\r\n          cascades.push(association.accessors.get);\r\n        }\r\n      }\r\n    }\r\n\r\n    return Promise.each(cascades, cascade => {\r\n      return instance[cascade](options).then(instances => {\r\n        // Check for hasOne relationship with non-existing associate (\"has zero\")\r\n        if (!instances) {\r\n          return Promise.resolve();\r\n        }\r\n\r\n        if (!Array.isArray(instances)) instances = [instances];\r\n\r\n        return Promise.each(instances, instance => instance.destroy(options));\r\n      });\r\n    }).then(() => {\r\n      options.instance = instance;\r\n      return this.sequelize.query(sql, options);\r\n    });\r\n  }\r\n\r\n  /**\r\n   * Delete multiple records from a table\r\n   *\r\n   * @param {string}  tableName            table name from where to delete records\r\n   * @param {Object}  where                where conditions to find records to delete\r\n   * @param {Object}  [options]            options\r\n   * @param {boolean} [options.truncate]   Use truncate table command   \r\n   * @param {boolean} [options.cascade=false]         Only used in conjunction with TRUNCATE. Truncates  all tables that have foreign-key references to the named table, or to any tables added to the group due to CASCADE.\r\n   * @param {boolean} [options.restartIdentity=false] Only used in conjunction with TRUNCATE. Automatically restart sequences owned by columns of the truncated table.\r\n   * @param {Model}   [model]              Model\r\n   *\r\n   * @returns {Promise}\r\n   */\r\n  bulkDelete(tableName, where, options, model) {\r\n    options = Utils.cloneDeep(options);\r\n    options = _.defaults(options, { limit: null });\r\n\r\n    if (options.truncate === true) {\r\n      return this.sequelize.query(\r\n        this.QueryGenerator.truncateTableQuery(tableName, options),\r\n        options\r\n      );\r\n    }\r\n\r\n    if (typeof identifier === 'object') where = Utils.cloneDeep(where);\r\n\r\n    return this.sequelize.query(\r\n      this.QueryGenerator.deleteQuery(tableName, where, options, model),\r\n      options\r\n    );\r\n  }\r\n\r\n  select(model, tableName, optionsArg) {\r\n    const options = Object.assign({}, optionsArg, { type: QueryTypes.SELECT, model });\r\n\r\n    return this.sequelize.query(\r\n      this.QueryGenerator.selectQuery(tableName, options, model),\r\n      options\r\n    );\r\n  }\r\n\r\n  increment(model, tableName, values, identifier, options) {\r\n    options = Utils.cloneDeep(options);\r\n\r\n    const sql = this.QueryGenerator.arithmeticQuery('+', tableName, values, identifier, options, options.attributes);\r\n\r\n    options.type = QueryTypes.UPDATE;\r\n    options.model = model;\r\n\r\n    return this.sequelize.query(sql, options);\r\n  }\r\n\r\n  decrement(model, tableName, values, identifier, options) {\r\n    options = Utils.cloneDeep(options);\r\n\r\n    const sql = this.QueryGenerator.arithmeticQuery('-', tableName, values, identifier, options, options.attributes);\r\n\r\n    options.type = QueryTypes.UPDATE;\r\n    options.model = model;\r\n\r\n    return this.sequelize.query(sql, options);\r\n  }\r\n\r\n  rawSelect(tableName, options, attributeSelector, Model) {\r\n    options = Utils.cloneDeep(options);\r\n    options = _.defaults(options, {\r\n      raw: true,\r\n      plain: true,\r\n      type: QueryTypes.SELECT\r\n    });\r\n\r\n    const sql = this.QueryGenerator.selectQuery(tableName, options, Model);\r\n\r\n    if (attributeSelector === undefined) {\r\n      throw new Error('Please pass an attribute selector!');\r\n    }\r\n\r\n    return this.sequelize.query(sql, options).then(data => {\r\n      if (!options.plain) {\r\n        return data;\r\n      }\r\n\r\n      const result = data ? data[attributeSelector] : null;\r\n\r\n      if (!options || !options.dataType) {\r\n        return result;\r\n      }\r\n\r\n      const dataType = options.dataType;\r\n\r\n      if (dataType instanceof DataTypes.DECIMAL || dataType instanceof DataTypes.FLOAT) {\r\n        if (result !== null) {\r\n          return parseFloat(result);\r\n        }\r\n      }\r\n      if (dataType instanceof DataTypes.INTEGER || dataType instanceof DataTypes.BIGINT) {\r\n        return parseInt(result, 10);\r\n      }\r\n      if (dataType instanceof DataTypes.DATE) {\r\n        if (result !== null && !(result instanceof Date)) {\r\n          return new Date(result);\r\n        }\r\n      }\r\n      return result;\r\n    });\r\n  }\r\n\r\n  createTrigger(tableName, triggerName, timingType, fireOnArray, functionName, functionParams, optionsArray, options) {\r\n    const sql = this.QueryGenerator.createTrigger(tableName, triggerName, timingType, fireOnArray, functionName, functionParams, optionsArray);\r\n    options = options || {};\r\n    if (sql) {\r\n      return this.sequelize.query(sql, options);\r\n    }\r\n    return Promise.resolve();\r\n  }\r\n\r\n  dropTrigger(tableName, triggerName, options) {\r\n    const sql = this.QueryGenerator.dropTrigger(tableName, triggerName);\r\n    options = options || {};\r\n\r\n    if (sql) {\r\n      return this.sequelize.query(sql, options);\r\n    }\r\n    return Promise.resolve();\r\n  }\r\n\r\n  renameTrigger(tableName, oldTriggerName, newTriggerName, options) {\r\n    const sql = this.QueryGenerator.renameTrigger(tableName, oldTriggerName, newTriggerName);\r\n    options = options || {};\r\n\r\n    if (sql) {\r\n      return this.sequelize.query(sql, options);\r\n    }\r\n    return Promise.resolve();\r\n  }\r\n\r\n  /**\r\n   * Create an SQL function\r\n   *\r\n   * @example\r\n   * queryInterface.createFunction(\r\n   *   'someFunction',\r\n   *   [\r\n   *     {type: 'integer', name: 'param', direction: 'IN'}\r\n   *   ],\r\n   *   'integer',\r\n   *   'plpgsql',\r\n   *   'RETURN param + 1;',\r\n   *   [\r\n   *     'IMMUTABLE',\r\n   *     'LEAKPROOF'\r\n   *   ],\r\n   *   {\r\n   *    variables:\r\n   *      [\r\n   *        {type: 'integer', name: 'myVar', default: 100}\r\n   *      ],\r\n   *      force: true\r\n   *   };\r\n   * );\r\n   *\r\n   * @param {string}  functionName  Name of SQL function to create\r\n   * @param {Array}   params        List of parameters declared for SQL function\r\n   * @param {string}  returnType    SQL type of function returned value\r\n   * @param {string}  language      The name of the language that the function is implemented in\r\n   * @param {string}  body          Source code of function\r\n   * @param {Array}   optionsArray  Extra-options for creation\r\n   * @param {Object}  [options]     query options\r\n   * @param {boolean} options.force If force is true, any existing functions with the same parameters will be replaced. For postgres, this means using `CREATE OR REPLACE FUNCTION` instead of `CREATE FUNCTION`. Default is false\r\n   * @param {Array<Object>}   options.variables List of declared variables. Each variable should be an object with string fields `type` and `name`, and optionally having a `default` field as well.\r\n   *\r\n   * @returns {Promise}\r\n   */\r\n  createFunction(functionName, params, returnType, language, body, optionsArray, options) {\r\n    const sql = this.QueryGenerator.createFunction(functionName, params, returnType, language, body, optionsArray, options);\r\n    options = options || {};\r\n\r\n    if (sql) {\r\n      return this.sequelize.query(sql, options);\r\n    }\r\n    return Promise.resolve();\r\n  }\r\n\r\n  /**\r\n   * Drop an SQL function\r\n   *\r\n   * @example\r\n   * queryInterface.dropFunction(\r\n   *   'someFunction',\r\n   *   [\r\n   *     {type: 'varchar', name: 'param1', direction: 'IN'},\r\n   *     {type: 'integer', name: 'param2', direction: 'INOUT'}\r\n   *   ]\r\n   * );\r\n   *\r\n   * @param {string} functionName Name of SQL function to drop\r\n   * @param {Array}  params       List of parameters declared for SQL function\r\n   * @param {Object} [options]    query options\r\n   *\r\n   * @returns {Promise}\r\n   */\r\n  dropFunction(functionName, params, options) {\r\n    const sql = this.QueryGenerator.dropFunction(functionName, params);\r\n    options = options || {};\r\n\r\n    if (sql) {\r\n      return this.sequelize.query(sql, options);\r\n    }\r\n    return Promise.resolve();\r\n  }\r\n\r\n  /**\r\n   * Rename an SQL function\r\n   *\r\n   * @example\r\n   * queryInterface.renameFunction(\r\n   *   'fooFunction',\r\n   *   [\r\n   *     {type: 'varchar', name: 'param1', direction: 'IN'},\r\n   *     {type: 'integer', name: 'param2', direction: 'INOUT'}\r\n   *   ],\r\n   *   'barFunction'\r\n   * );\r\n   *\r\n   * @param {string} oldFunctionName  Current name of function\r\n   * @param {Array}  params           List of parameters declared for SQL function\r\n   * @param {string} newFunctionName  New name of function\r\n   * @param {Object} [options]        query options\r\n   *\r\n   * @returns {Promise}\r\n   */\r\n  renameFunction(oldFunctionName, params, newFunctionName, options) {\r\n    const sql = this.QueryGenerator.renameFunction(oldFunctionName, params, newFunctionName);\r\n    options = options || {};\r\n\r\n    if (sql) {\r\n      return this.sequelize.query(sql, options);\r\n    }\r\n    return Promise.resolve();\r\n  }\r\n\r\n  // Helper methods useful for querying\r\n\r\n  /**\r\n   * Escape an identifier (e.g. a table or attribute name)\r\n   *\r\n   * @param {string} identifier identifier to quote\r\n   * @param {boolean} [force]   If force is true,the identifier will be quoted even if the `quoteIdentifiers` option is false.\r\n   *\r\n   * @private\r\n   */\r\n  quoteIdentifier(identifier, force) {\r\n    return this.QueryGenerator.quoteIdentifier(identifier, force);\r\n  }\r\n\r\n  quoteTable(identifier) {\r\n    return this.QueryGenerator.quoteTable(identifier);\r\n  }\r\n\r\n  /**\r\n   * Quote array of identifiers at once\r\n   *\r\n   * @param {string[]} identifiers array of identifiers to quote\r\n   * @param {boolean} [force]   If force is true,the identifier will be quoted even if the `quoteIdentifiers` option is false.\r\n   *\r\n   * @private\r\n   */\r\n  quoteIdentifiers(identifiers, force) {\r\n    return this.QueryGenerator.quoteIdentifiers(identifiers, force);\r\n  }\r\n\r\n  /**\r\n   * Escape a value (e.g. a string, number or date)\r\n   *\r\n   * @param {string} value string to escape\r\n   *\r\n   * @private\r\n   */\r\n  escape(value) {\r\n    return this.QueryGenerator.escape(value);\r\n  }\r\n\r\n  setIsolationLevel(transaction, value, options) {\r\n    if (!transaction || !(transaction instanceof Transaction)) {\r\n      throw new Error('Unable to set isolation level for a transaction without transaction object!');\r\n    }\r\n\r\n    if (transaction.parent || !value) {\r\n      // Not possible to set a separate isolation level for savepoints\r\n      return Promise.resolve();\r\n    }\r\n\r\n    options = Object.assign({}, options, {\r\n      transaction: transaction.parent || transaction\r\n    });\r\n\r\n    const sql = this.QueryGenerator.setIsolationLevelQuery(value, {\r\n      parent: transaction.parent\r\n    });\r\n\r\n    if (!sql) return Promise.resolve();\r\n\r\n    return this.sequelize.query(sql, options);\r\n  }\r\n\r\n  startTransaction(transaction, options) {\r\n    if (!transaction || !(transaction instanceof Transaction)) {\r\n      throw new Error('Unable to start a transaction without transaction object!');\r\n    }\r\n\r\n    options = Object.assign({}, options, {\r\n      transaction: transaction.parent || transaction\r\n    });\r\n    options.transaction.name = transaction.parent ? transaction.name : undefined;\r\n    const sql = this.QueryGenerator.startTransactionQuery(transaction);\r\n\r\n    return this.sequelize.query(sql, options);\r\n  }\r\n\r\n  deferConstraints(transaction, options) {\r\n    options = Object.assign({}, options, {\r\n      transaction: transaction.parent || transaction\r\n    });\r\n\r\n    const sql = this.QueryGenerator.deferConstraintsQuery(options);\r\n\r\n    if (sql) {\r\n      return this.sequelize.query(sql, options);\r\n    }\r\n\r\n    return Promise.resolve();\r\n  }\r\n\r\n  commitTransaction(transaction, options) {\r\n    if (!transaction || !(transaction instanceof Transaction)) {\r\n      throw new Error('Unable to commit a transaction without transaction object!');\r\n    }\r\n    if (transaction.parent) {\r\n      // Savepoints cannot be committed\r\n      return Promise.resolve();\r\n    }\r\n\r\n    options = Object.assign({}, options, {\r\n      transaction: transaction.parent || transaction,\r\n      supportsSearchPath: false,\r\n      completesTransaction: true\r\n    });\r\n\r\n    const sql = this.QueryGenerator.commitTransactionQuery(transaction);\r\n    const promise = this.sequelize.query(sql, options);\r\n\r\n    transaction.finished = 'commit';\r\n\r\n    return promise;\r\n  }\r\n\r\n  rollbackTransaction(transaction, options) {\r\n    if (!transaction || !(transaction instanceof Transaction)) {\r\n      throw new Error('Unable to rollback a transaction without transaction object!');\r\n    }\r\n\r\n    options = Object.assign({}, options, {\r\n      transaction: transaction.parent || transaction,\r\n      supportsSearchPath: false,\r\n      completesTransaction: true\r\n    });\r\n    options.transaction.name = transaction.parent ? transaction.name : undefined;\r\n    const sql = this.QueryGenerator.rollbackTransactionQuery(transaction);\r\n    const promise = this.sequelize.query(sql, options);\r\n\r\n    transaction.finished = 'rollback';\r\n\r\n    return promise;\r\n  }\r\n}\r\n\r\nmodule.exports = QueryInterface;\r\nmodule.exports.QueryInterface = QueryInterface;\r\nmodule.exports.default = QueryInterface;\r\n"]} \ No newline at end of file +//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../lib/query-interface.js"],"names":["_","require","Utils","DataTypes","SQLiteQueryInterface","Transaction","Promise","QueryTypes","Op","QueryInterface","sequelize","QueryGenerator","dialect","database","options","sql","createDatabaseQuery","query","dropDatabaseQuery","schema","createSchema","dropSchema","_dialect","supports","schemas","drop","showAllSchemas","map","schemaName","Object","assign","raw","type","SELECT","showSchemasSql","showSchemasQuery","then","schemaNames","flatten","value","schema_name","versionQuery","VERSION","tableName","attributes","model","promise","clone","uniqueKeys","forOwn","uniqueKey","customIndex","undefined","mapValues","attribute","normalizeAttribute","PostgresQueryInterface","ensureEnums","resolve","_schema","addSchema","attributesToSQL","table","context","createTableQuery","cascade","force","dropTableQuery","promises","instanceTable","modelManager","getModel","getTableName","keys","rawAttributes","keyLen","length","i","ENUM","pgEnumDrop","supportsSearchPath","push","all","get","skip","dropAllTables","tableNames","each","includes","dropTable","showAllTables","result","foreignKeysAreEnabled","foreign_keys","getForeignKeysForTables","foreignKeys","queries","forEach","normalizedTableName","isObject","foreignKey","dropForeignKeyQuery","q","enumName","getDialect","pgEscapeAndQuote","pgListEnums","enum_name","plain","before","after","renameTableQuery","SHOWTABLES","showTablesSql","showTablesQuery","config","schemaDelimiter","describeTableQuery","DESCRIBE","data","isEmpty","Error","catch","e","original","code","key","addColumnQuery","attributeName","removeColumn","removeColumnQuery","dataTypeOrOptions","values","allowNull","changeColumn","changeColumnQuery","attrNameBefore","attrNameAfter","describeTable","_options","defaultValue","renameColumn","renameColumnQuery","rawTablename","Array","isArray","fields","cloneDeep","addIndexQuery","showIndexesQuery","SHOWINDEXES","FOREIGNKEYS","getForeignKeysQuery","results","r","constraint_name","filter","identity","queryOptions","catalogName","getForeignKeyReferencesForTable","indexNameOrAttributes","removeIndexQuery","name","addConstraint","addConstraintQuery","constraintName","showConstraintsQuery","SHOWCONSTRAINTS","removeConstraint","removeConstraintQuery","instance","hasTrigger","constructor","insertQuery","INSERT","isNewRecord","insertValues","updateValues","where","wheres","indexes","indexFields","isWhereEmpty","_indexes","unique","field","isPlainObject","index","intersection","or","UPSERT","upsertQuery","records","bulkInsertQuery","identifier","_modelOptions","updateQuery","UPDATE","find","models","BULKUPDATE","cascades","deleteQuery","associations","association","onDelete","toLowerCase","useHooks","accessors","instances","destroy","defaults","limit","truncate","truncateTableQuery","optionsArg","selectQuery","arithmeticQuery","attributeSelector","Model","dataType","DECIMAL","FLOAT","parseFloat","INTEGER","BIGINT","parseInt","DATE","Date","triggerName","timingType","fireOnArray","functionName","functionParams","optionsArray","createTrigger","dropTrigger","oldTriggerName","newTriggerName","renameTrigger","params","returnType","language","body","createFunction","dropFunction","oldFunctionName","newFunctionName","renameFunction","quoteIdentifier","quoteTable","identifiers","quoteIdentifiers","escape","transaction","parent","setIsolationLevelQuery","startTransactionQuery","deferConstraintsQuery","completesTransaction","commitTransactionQuery","finished","rollbackTransactionQuery","module","exports","default"],"mappings":"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","sourcesContent":["'use strict';\n\nconst _ = require('lodash');\n\nconst Utils = require('./utils');\nconst DataTypes = require('./data-types');\nconst SQLiteQueryInterface = require('./dialects/sqlite/query-interface');\nconst Transaction = require('./transaction');\nconst Promise = require('./promise');\nconst QueryTypes = require('./query-types');\nconst Op = require('./operators');\n\n/**\n * The interface that Sequelize uses to talk to all databases\n *\n * @class QueryInterface\n */\nclass QueryInterface {\n  constructor(sequelize) {\n    this.sequelize = sequelize;\n    this.QueryGenerator = this.sequelize.dialect.QueryGenerator;\n  }\n\n  /**\n   * Create a database\n   *\n   * @param {string} database  Database name to create\n   * @param {Object} [options] Query options\n   * @param {string} [options.charset] Database default character set, MYSQL only\n   * @param {string} [options.collate] Database default collation\n   * @param {string} [options.encoding] Database default character set, PostgreSQL only\n   * @param {string} [options.ctype] Database character classification, PostgreSQL only\n   * @param {string} [options.template] The name of the template from which to create the new database, PostgreSQL only\n   *\n   * @returns {Promise}\n   */\n  createDatabase(database, options) {\n    options = options || {};\n    const sql = this.QueryGenerator.createDatabaseQuery(database, options);\n    return this.sequelize.query(sql, options);\n  }\n\n  /**\n   * Drop a database\n   *\n   * @param {string} database  Database name to drop\n   * @param {Object} [options] Query options\n   *\n   * @returns {Promise}\n   */\n  dropDatabase(database, options) {\n    options = options || {};\n    const sql = this.QueryGenerator.dropDatabaseQuery(database);\n    return this.sequelize.query(sql, options);\n  }\n\n  /**\n   * Create a schema\n   *\n   * @param {string} schema    Schema name to create\n   * @param {Object} [options] Query options\n   *\n   * @returns {Promise}\n   */\n  createSchema(schema, options) {\n    options = options || {};\n    const sql = this.QueryGenerator.createSchema(schema);\n    return this.sequelize.query(sql, options);\n  }\n\n  /**\n   * Drop a schema\n   *\n   * @param {string} schema    Schema name to drop\n   * @param {Object} [options] Query options\n   *\n   * @returns {Promise}\n   */\n  dropSchema(schema, options) {\n    options = options || {};\n    const sql = this.QueryGenerator.dropSchema(schema);\n    return this.sequelize.query(sql, options);\n  }\n\n  /**\n   * Drop all schemas\n   *\n   * @param {Object} [options] Query options\n   *\n   * @returns {Promise}\n   */\n  dropAllSchemas(options) {\n    options = options || {};\n\n    if (!this.QueryGenerator._dialect.supports.schemas) {\n      return this.sequelize.drop(options);\n    }\n    return this.showAllSchemas(options).map(schemaName => this.dropSchema(schemaName, options));\n  }\n\n  /**\n   * Show all schemas\n   *\n   * @param {Object} [options] Query options\n   *\n   * @returns {Promise<Array>}\n   */\n  showAllSchemas(options) {\n    options = Object.assign({}, options, {\n      raw: true,\n      type: this.sequelize.QueryTypes.SELECT\n    });\n\n    const showSchemasSql = this.QueryGenerator.showSchemasQuery(options);\n\n    return this.sequelize.query(showSchemasSql, options).then(schemaNames => _.flatten(\n      schemaNames.map(value => value.schema_name ? value.schema_name : value)\n    ));\n  }\n\n  /**\n   * Return database version\n   *\n   * @param {Object}    [options]      Query options\n   * @param {QueryType} [options.type] Query type\n   *\n   * @returns {Promise}\n   * @private\n   */\n  databaseVersion(options) {\n    return this.sequelize.query(\n      this.QueryGenerator.versionQuery(),\n      Object.assign({}, options, { type: QueryTypes.VERSION })\n    );\n  }\n\n  /**\n   * Create a table with given set of attributes\n   *\n   * ```js\n   * queryInterface.createTable(\n   *   'nameOfTheNewTable',\n   *   {\n   *     id: {\n   *       type: Sequelize.INTEGER,\n   *       primaryKey: true,\n   *       autoIncrement: true\n   *     },\n   *     createdAt: {\n   *       type: Sequelize.DATE\n   *     },\n   *     updatedAt: {\n   *       type: Sequelize.DATE\n   *     },\n   *     attr1: Sequelize.STRING,\n   *     attr2: Sequelize.INTEGER,\n   *     attr3: {\n   *       type: Sequelize.BOOLEAN,\n   *       defaultValue: false,\n   *       allowNull: false\n   *     },\n   *     //foreign key usage\n   *     attr4: {\n   *       type: Sequelize.INTEGER,\n   *       references: {\n   *         model: 'another_table_name',\n   *         key: 'id'\n   *       },\n   *       onUpdate: 'cascade',\n   *       onDelete: 'cascade'\n   *     }\n   *   },\n   *   {\n   *     engine: 'MYISAM',    // default: 'InnoDB'\n   *     charset: 'latin1',   // default: null\n   *     schema: 'public',    // default: public, PostgreSQL only.\n   *     comment: 'my table', // comment for table\n   *     collate: 'latin1_danish_ci' // collation, MYSQL only\n   *   }\n   * )\n   * ```\n   *\n   * @param {string} tableName  Name of table to create\n   * @param {Object} attributes Object representing a list of table attributes to create\n   * @param {Object} [options] create table and query options\n   * @param {Model}  [model] model class\n   *\n   * @returns {Promise}\n   */\n  createTable(tableName, attributes, options, model) {\n    let sql = '';\n    let promise;\n\n    options = _.clone(options) || {};\n\n    if (options && options.uniqueKeys) {\n      _.forOwn(options.uniqueKeys, uniqueKey => {\n        if (uniqueKey.customIndex === undefined) {\n          uniqueKey.customIndex = true;\n        }\n      });\n    }\n\n    if (model) {\n      options.uniqueKeys = options.uniqueKeys || model.uniqueKeys;\n    }\n\n    attributes = _.mapValues(\n      attributes,\n      attribute => this.sequelize.normalizeAttribute(attribute)\n    );\n\n    // Postgres requires special SQL commands for ENUM/ENUM[]\n    if (this.sequelize.options.dialect === 'postgres') {\n      promise = PostgresQueryInterface.ensureEnums(this, tableName, attributes, options, model);\n    } else {\n      promise = Promise.resolve();\n    }\n\n    if (\n      !tableName.schema &&\n      (options.schema || !!model && model._schema)\n    ) {\n      tableName = this.QueryGenerator.addSchema({\n        tableName,\n        _schema: !!model && model._schema || options.schema\n      });\n    }\n\n    attributes = this.QueryGenerator.attributesToSQL(attributes, { table: tableName, context: 'createTable' });\n    sql = this.QueryGenerator.createTableQuery(tableName, attributes, options);\n\n    return promise.then(() => this.sequelize.query(sql, options));\n  }\n\n  /**\n   * Drop a table from database\n   *\n   * @param {string} tableName Table name to drop\n   * @param {Object} options   Query options\n   *\n   * @returns {Promise}\n   */\n  dropTable(tableName, options) {\n    // if we're forcing we should be cascading unless explicitly stated otherwise\n    options = _.clone(options) || {};\n    options.cascade = options.cascade || options.force || false;\n\n    let sql = this.QueryGenerator.dropTableQuery(tableName, options);\n\n    return this.sequelize.query(sql, options).then(() => {\n      const promises = [];\n\n      // Since postgres has a special case for enums, we should drop the related\n      // enum type within the table and attribute\n      if (this.sequelize.options.dialect === 'postgres') {\n        const instanceTable = this.sequelize.modelManager.getModel(tableName, { attribute: 'tableName' });\n\n        if (instanceTable) {\n          const getTableName = (!options || !options.schema || options.schema === 'public' ? '' : `${options.schema}_`) + tableName;\n\n          const keys = Object.keys(instanceTable.rawAttributes);\n          const keyLen = keys.length;\n\n          for (let i = 0; i < keyLen; i++) {\n            if (instanceTable.rawAttributes[keys[i]].type instanceof DataTypes.ENUM) {\n              sql = this.QueryGenerator.pgEnumDrop(getTableName, keys[i]);\n              options.supportsSearchPath = false;\n              promises.push(this.sequelize.query(sql, Object.assign({}, options, { raw: true })));\n            }\n          }\n        }\n      }\n\n      return Promise.all(promises).get(0);\n    });\n  }\n\n  /**\n   * Drop all tables from database\n   *\n   * @param {Object} [options] query options\n   * @param {Array}  [options.skip] List of table to skip\n   *\n   * @returns {Promise}\n   */\n  dropAllTables(options) {\n    options = options || {};\n    const skip = options.skip || [];\n\n    const dropAllTables = tableNames => Promise.each(tableNames, tableName => {\n      // if tableName is not in the Array of tables names then don't drop it\n      if (!skip.includes(tableName.tableName || tableName)) {\n        return this.dropTable(tableName, Object.assign({}, options, { cascade: true }) );\n      }\n    });\n\n    return this.showAllTables(options).then(tableNames => {\n      if (this.sequelize.options.dialect === 'sqlite') {\n        return this.sequelize.query('PRAGMA foreign_keys;', options).then(result => {\n          const foreignKeysAreEnabled = result.foreign_keys === 1;\n\n          if (foreignKeysAreEnabled) {\n            return this.sequelize.query('PRAGMA foreign_keys = OFF', options)\n              .then(() => dropAllTables(tableNames))\n              .then(() => this.sequelize.query('PRAGMA foreign_keys = ON', options));\n          }\n          return dropAllTables(tableNames);\n        });\n      }\n      return this.getForeignKeysForTables(tableNames, options).then(foreignKeys => {\n        const queries = [];\n\n        tableNames.forEach(tableName => {\n          let normalizedTableName = tableName;\n          if (_.isObject(tableName)) {\n            normalizedTableName = `${tableName.schema}.${tableName.tableName}`;\n          }\n\n          foreignKeys[normalizedTableName].forEach(foreignKey => {\n            queries.push(this.QueryGenerator.dropForeignKeyQuery(tableName, foreignKey));\n          });\n        });\n\n        return Promise.each(queries, q => this.sequelize.query(q, options))\n          .then(() => dropAllTables(tableNames));\n      });\n    });\n  }\n\n  /**\n   * Drop specified enum from database (Postgres only)\n   *\n   * @param {string} [enumName]  Enum name to drop\n   * @param {Object} options Query options\n   *\n   * @returns {Promise}\n   * @private\n   */\n  dropEnum(enumName, options) {\n    if (this.sequelize.getDialect() !== 'postgres') {\n      return Promise.resolve();\n    }\n\n    options = options || {};\n\n    return this.sequelize.query(\n      this.QueryGenerator.pgEnumDrop(null, null, this.QueryGenerator.pgEscapeAndQuote(enumName)),\n      Object.assign({}, options, { raw: true })\n    );\n  }\n\n  /**\n   * Drop all enums from database (Postgres only)\n   *\n   * @param {Object} options Query options\n   *\n   * @returns {Promise}\n   * @private\n   */\n  dropAllEnums(options) {\n    if (this.sequelize.getDialect() !== 'postgres') {\n      return Promise.resolve();\n    }\n\n    options = options || {};\n\n    return this.pgListEnums(null, options).map(result => this.sequelize.query(\n      this.QueryGenerator.pgEnumDrop(null, null, this.QueryGenerator.pgEscapeAndQuote(result.enum_name)),\n      Object.assign({}, options, { raw: true })\n    ));\n  }\n\n  /**\n   * List all enums (Postgres only)\n   *\n   * @param {string} [tableName]  Table whose enum to list\n   * @param {Object} [options]    Query options\n   *\n   * @returns {Promise}\n   * @private\n   */\n  pgListEnums(tableName, options) {\n    options = options || {};\n    const sql = this.QueryGenerator.pgListEnums(tableName);\n    return this.sequelize.query(sql, Object.assign({}, options, { plain: false, raw: true, type: QueryTypes.SELECT }));\n  }\n\n  /**\n   * Rename a table\n   *\n   * @param {string} before    Current name of table\n   * @param {string} after     New name from table\n   * @param {Object} [options] Query options\n   *\n   * @returns {Promise}\n   */\n  renameTable(before, after, options) {\n    options = options || {};\n    const sql = this.QueryGenerator.renameTableQuery(before, after);\n    return this.sequelize.query(sql, options);\n  }\n\n  /**\n   * Get all tables in current database\n   *\n   * @param {Object}    [options] Query options\n   * @param {boolean}   [options.raw=true] Run query in raw mode\n   * @param {QueryType} [options.type=QueryType.SHOWTABLE] query type\n   *\n   * @returns {Promise<Array>}\n   * @private\n   */\n  showAllTables(options) {\n    options = Object.assign({}, options, {\n      raw: true,\n      type: QueryTypes.SHOWTABLES\n    });\n\n    const showTablesSql = this.QueryGenerator.showTablesQuery(this.sequelize.config.database);\n    return this.sequelize.query(showTablesSql, options).then(tableNames => _.flatten(tableNames));\n  }\n\n  /**\n   * Describe a table structure\n   *\n   * This method returns an array of hashes containing information about all attributes in the table.\n   *\n   * ```js\n   * {\n   *    name: {\n   *      type:         'VARCHAR(255)', // this will be 'CHARACTER VARYING' for pg!\n   *      allowNull:    true,\n   *      defaultValue: null\n   *    },\n   *    isBetaMember: {\n   *      type:         'TINYINT(1)', // this will be 'BOOLEAN' for pg!\n   *      allowNull:    false,\n   *      defaultValue: false\n   *    }\n   * }\n   * ```\n   *\n   * @param {string} tableName table name\n   * @param {Object} [options] Query options\n   *\n   * @returns {Promise<Object>}\n   */\n  describeTable(tableName, options) {\n    let schema = null;\n    let schemaDelimiter = null;\n\n    if (typeof options === 'string') {\n      schema = options;\n    } else if (typeof options === 'object' && options !== null) {\n      schema = options.schema || null;\n      schemaDelimiter = options.schemaDelimiter || null;\n    }\n\n    if (typeof tableName === 'object' && tableName !== null) {\n      schema = tableName.schema;\n      tableName = tableName.tableName;\n    }\n\n    const sql = this.QueryGenerator.describeTableQuery(tableName, schema, schemaDelimiter);\n    options = Object.assign({}, options, { type: QueryTypes.DESCRIBE });\n\n    return this.sequelize.query(sql, options).then(data => {\n      /*\n       * If no data is returned from the query, then the table name may be wrong.\n       * Query generators that use information_schema for retrieving table info will just return an empty result set,\n       * it will not throw an error like built-ins do (e.g. DESCRIBE on MySql).\n       */\n      if (_.isEmpty(data)) {\n        throw new Error(`No description found for \"${tableName}\" table. Check the table name and schema; remember, they _are_ case sensitive.`);\n      }\n\n      return data;\n    }).catch(e => {\n      if (e.original && e.original.code === 'ER_NO_SUCH_TABLE') {\n        throw Error(`No description found for \"${tableName}\" table. Check the table name and schema; remember, they _are_ case sensitive.`);\n      }\n\n      throw e;\n    });\n  }\n\n  /**\n   * Add a new column to a table\n   *\n   * ```js\n   * queryInterface.addColumn('tableA', 'columnC', Sequelize.STRING, {\n   *    after: 'columnB' // after option is only supported by MySQL\n   * });\n   * ```\n   *\n   * @param {string} table     Table to add column to\n   * @param {string} key       Column name\n   * @param {Object} attribute Attribute definition\n   * @param {Object} [options] Query options\n   *\n   * @returns {Promise}\n   */\n  addColumn(table, key, attribute, options) {\n    if (!table || !key || !attribute) {\n      throw new Error('addColumn takes at least 3 arguments (table, attribute name, attribute definition)');\n    }\n\n    options = options || {};\n    attribute = this.sequelize.normalizeAttribute(attribute);\n    return this.sequelize.query(this.QueryGenerator.addColumnQuery(table, key, attribute), options);\n  }\n\n  /**\n   * Remove a column from a table\n   *\n   * @param {string} tableName      Table to remove column from\n   * @param {string} attributeName  Column name to remove\n   * @param {Object} [options]      Query options\n   *\n   * @returns {Promise}\n   */\n  removeColumn(tableName, attributeName, options) {\n    options = options || {};\n    switch (this.sequelize.options.dialect) {\n      case 'sqlite':\n        // sqlite needs some special treatment as it cannot drop a column\n        return SQLiteQueryInterface.removeColumn(this, tableName, attributeName, options);\n      default:\n        return this.sequelize.query(this.QueryGenerator.removeColumnQuery(tableName, attributeName), options);\n    }\n  }\n\n  /**\n   * Change a column definition\n   *\n   * @param {string} tableName          Table name to change from\n   * @param {string} attributeName      Column name\n   * @param {Object} dataTypeOrOptions  Attribute definition for new column\n   * @param {Object} [options]          Query options\n   *\n   * @returns {Promise}\n   */\n  changeColumn(tableName, attributeName, dataTypeOrOptions, options) {\n    const attributes = {};\n    options = options || {};\n\n    if (_.values(DataTypes).includes(dataTypeOrOptions)) {\n      attributes[attributeName] = { type: dataTypeOrOptions, allowNull: true };\n    } else {\n      attributes[attributeName] = dataTypeOrOptions;\n    }\n\n    attributes[attributeName] = this.sequelize.normalizeAttribute(attributes[attributeName]);\n\n    if (this.sequelize.options.dialect === 'sqlite') {\n      // sqlite needs some special treatment as it cannot change a column\n      return SQLiteQueryInterface.changeColumn(this, tableName, attributes, options);\n    }\n    const query = this.QueryGenerator.attributesToSQL(attributes, {\n      context: 'changeColumn',\n      table: tableName\n    });\n    const sql = this.QueryGenerator.changeColumnQuery(tableName, query);\n\n    return this.sequelize.query(sql, options);\n  }\n\n  /**\n   * Rename a column\n   *\n   * @param {string} tableName        Table name whose column to rename\n   * @param {string} attrNameBefore   Current column name\n   * @param {string} attrNameAfter    New column name\n   * @param {Object} [options]        Query option\n   *\n   * @returns {Promise}\n   */\n  renameColumn(tableName, attrNameBefore, attrNameAfter, options) {\n    options = options || {};\n    return this.describeTable(tableName, options).then(data => {\n      if (!data[attrNameBefore]) {\n        throw new Error(`Table ${tableName} doesn't have the column ${attrNameBefore}`);\n      }\n\n      data = data[attrNameBefore] || {};\n\n      const _options = {};\n\n      _options[attrNameAfter] = {\n        attribute: attrNameAfter,\n        type: data.type,\n        allowNull: data.allowNull,\n        defaultValue: data.defaultValue\n      };\n\n      // fix: a not-null column cannot have null as default value\n      if (data.defaultValue === null && !data.allowNull) {\n        delete _options[attrNameAfter].defaultValue;\n      }\n\n      if (this.sequelize.options.dialect === 'sqlite') {\n        // sqlite needs some special treatment as it cannot rename a column\n        return SQLiteQueryInterface.renameColumn(this, tableName, attrNameBefore, attrNameAfter, options);\n      }\n      const sql = this.QueryGenerator.renameColumnQuery(\n        tableName,\n        attrNameBefore,\n        this.QueryGenerator.attributesToSQL(_options)\n      );\n      return this.sequelize.query(sql, options);\n    });\n  }\n\n  /**\n   * Add an index to a column\n   *\n   * @param {string|Object}  tableName Table name to add index on, can be a object with schema\n   * @param {Array}   [attributes]     Use options.fields instead, List of attributes to add index on\n   * @param {Object}  options          indexes options\n   * @param {Array}   options.fields   List of attributes to add index on\n   * @param {boolean} [options.concurrently] Pass CONCURRENT so other operations run while the index is created\n   * @param {boolean} [options.unique] Create a unique index\n   * @param {string}  [options.using]  Useful for GIN indexes\n   * @param {string}  [options.operator] Index operator\n   * @param {string}  [options.type]   Type of index, available options are UNIQUE|FULLTEXT|SPATIAL\n   * @param {string}  [options.name]   Name of the index. Default is <table>_<attr1>_<attr2>\n   * @param {Object}  [options.where]  Where condition on index, for partial indexes\n   * @param {string}  [rawTablename]   table name, this is just for backward compatibiity\n   *\n   * @returns {Promise}\n   */\n  addIndex(tableName, attributes, options, rawTablename) {\n    // Support for passing tableName, attributes, options or tableName, options (with a fields param which is the attributes)\n    if (!Array.isArray(attributes)) {\n      rawTablename = options;\n      options = attributes;\n      attributes = options.fields;\n    }\n\n    if (!rawTablename) {\n      // Map for backwards compat\n      rawTablename = tableName;\n    }\n\n    options = Utils.cloneDeep(options);\n    options.fields = attributes;\n    const sql = this.QueryGenerator.addIndexQuery(tableName, options, rawTablename);\n    return this.sequelize.query(sql, Object.assign({}, options, { supportsSearchPath: false }));\n  }\n\n  /**\n   * Show indexes on a table\n   *\n   * @param {string} tableName table name\n   * @param {Object} [options]   Query options\n   *\n   * @returns {Promise<Array>}\n   * @private\n   */\n  showIndex(tableName, options) {\n    const sql = this.QueryGenerator.showIndexesQuery(tableName, options);\n    return this.sequelize.query(sql, Object.assign({}, options, { type: QueryTypes.SHOWINDEXES }));\n  }\n\n  getForeignKeysForTables(tableNames, options) {\n    if (tableNames.length === 0) {\n      return Promise.resolve({});\n    }\n\n    options = Object.assign({}, options || {}, { type: QueryTypes.FOREIGNKEYS });\n\n    return Promise.map(tableNames, tableName =>\n      this.sequelize.query(this.QueryGenerator.getForeignKeysQuery(tableName, this.sequelize.config.database), options)\n    ).then(results => {\n      const result = {};\n\n      tableNames.forEach((tableName, i) => {\n        if (_.isObject(tableName)) {\n          tableName = `${tableName.schema}.${tableName.tableName}`;\n        }\n\n        result[tableName] = Array.isArray(results[i])\n          ? results[i].map(r => r.constraint_name)\n          : [results[i] && results[i].constraint_name];\n\n        result[tableName] = result[tableName].filter(_.identity);\n      });\n\n      return result;\n    });\n  }\n\n  /**\n   * Get foreign key references details for the table\n   *\n   * Those details contains constraintSchema, constraintName, constraintCatalog\n   * tableCatalog, tableSchema, tableName, columnName,\n   * referencedTableCatalog, referencedTableCatalog, referencedTableSchema, referencedTableName, referencedColumnName.\n   * Remind: constraint informations won't return if it's sqlite.\n   *\n   * @param {string} tableName table name\n   * @param {Object} [options]  Query options\n   *\n   * @returns {Promise}\n   */\n  getForeignKeyReferencesForTable(tableName, options) {\n    const queryOptions = Object.assign({}, options, {\n      type: QueryTypes.FOREIGNKEYS\n    });\n    const catalogName = this.sequelize.config.database;\n    switch (this.sequelize.options.dialect) {\n      case 'sqlite':\n        // sqlite needs some special treatment.\n        return SQLiteQueryInterface.getForeignKeyReferencesForTable(this, tableName, queryOptions);\n      default: {\n        const query = this.QueryGenerator.getForeignKeysQuery(tableName, catalogName);\n        return this.sequelize.query(query, queryOptions);\n      }\n    }\n  }\n\n  /**\n   * Remove an already existing index from a table\n   *\n   * @param {string} tableName             Table name to drop index from\n   * @param {string} indexNameOrAttributes Index name\n   * @param {Object} [options]             Query options\n   *\n   * @returns {Promise}\n   */\n  removeIndex(tableName, indexNameOrAttributes, options) {\n    options = options || {};\n    const sql = this.QueryGenerator.removeIndexQuery(tableName, indexNameOrAttributes);\n    return this.sequelize.query(sql, options);\n  }\n\n  /**\n   * Add a constraint to a table\n   *\n   * Available constraints:\n   * - UNIQUE\n   * - DEFAULT (MSSQL only)\n   * - CHECK (MySQL - Ignored by the database engine )\n   * - FOREIGN KEY\n   * - PRIMARY KEY\n   *\n   * @example <caption>UNIQUE</caption>\n   * queryInterface.addConstraint('Users', ['email'], {\n   *   type: 'unique',\n   *   name: 'custom_unique_constraint_name'\n   * });\n   *\n   * @example <caption>CHECK</caption>\n   * queryInterface.addConstraint('Users', ['roles'], {\n   *   type: 'check',\n   *   where: {\n   *      roles: ['user', 'admin', 'moderator', 'guest']\n   *   }\n   * });\n   *\n   * @example <caption>Default - MSSQL only</caption>\n   * queryInterface.addConstraint('Users', ['roles'], {\n   *    type: 'default',\n   *    defaultValue: 'guest'\n   * });\n   *\n   * @example <caption>Primary Key</caption>\n   * queryInterface.addConstraint('Users', ['username'], {\n   *    type: 'primary key',\n   *    name: 'custom_primary_constraint_name'\n   * });\n   *\n   * @example <caption>Foreign Key</caption>\n   * queryInterface.addConstraint('Posts', ['username'], {\n   *   type: 'foreign key',\n   *   name: 'custom_fkey_constraint_name',\n   *   references: { //Required field\n   *     table: 'target_table_name',\n   *     field: 'target_column_name'\n   *   },\n   *   onDelete: 'cascade',\n   *   onUpdate: 'cascade'\n   * });\n   *\n   * @param {string} tableName                  Table name where you want to add a constraint\n   * @param {Array}  attributes                 Array of column names to apply the constraint over\n   * @param {Object} options                    An object to define the constraint name, type etc\n   * @param {string} options.type               Type of constraint. One of the values in available constraints(case insensitive)\n   * @param {string} [options.name]             Name of the constraint. If not specified, sequelize automatically creates a named constraint based on constraint type, table & column names\n   * @param {string} [options.defaultValue]     The value for the default constraint\n   * @param {Object} [options.where]            Where clause/expression for the CHECK constraint\n   * @param {Object} [options.references]       Object specifying target table, column name to create foreign key constraint\n   * @param {string} [options.references.table] Target table name\n   * @param {string} [options.references.field] Target column name\n   * @param {string} [rawTablename]             Table name, for backward compatibility\n   *\n   * @returns {Promise}\n   */\n  addConstraint(tableName, attributes, options, rawTablename) {\n    if (!Array.isArray(attributes)) {\n      rawTablename = options;\n      options = attributes;\n      attributes = options.fields;\n    }\n\n    if (!options.type) {\n      throw new Error('Constraint type must be specified through options.type');\n    }\n\n    if (!rawTablename) {\n      // Map for backwards compat\n      rawTablename = tableName;\n    }\n\n    options = Utils.cloneDeep(options);\n    options.fields = attributes;\n\n    if (this.sequelize.dialect.name === 'sqlite') {\n      return SQLiteQueryInterface.addConstraint(this, tableName, options, rawTablename);\n    }\n    const sql = this.QueryGenerator.addConstraintQuery(tableName, options, rawTablename);\n    return this.sequelize.query(sql, options);\n  }\n\n  showConstraint(tableName, constraintName, options) {\n    const sql = this.QueryGenerator.showConstraintsQuery(tableName, constraintName);\n    return this.sequelize.query(sql, Object.assign({}, options, { type: QueryTypes.SHOWCONSTRAINTS }));\n  }\n\n  /**\n   * Remove a constraint from a table\n   *\n   * @param {string} tableName       Table name to drop constraint from\n   * @param {string} constraintName  Constraint name\n   * @param {Object} options         Query options\n   *\n   * @returns {Promise}\n   */\n  removeConstraint(tableName, constraintName, options) {\n    options = options || {};\n\n    switch (this.sequelize.options.dialect) {\n      case 'sqlite':\n        return SQLiteQueryInterface.removeConstraint(this, tableName, constraintName, options);\n      default:\n        const sql = this.QueryGenerator.removeConstraintQuery(tableName, constraintName);\n        return this.sequelize.query(sql, options);\n    }\n  }\n\n  insert(instance, tableName, values, options) {\n    options = Utils.cloneDeep(options);\n    options.hasTrigger = instance && instance.constructor.options.hasTrigger;\n    const sql = this.QueryGenerator.insertQuery(tableName, values, instance && instance.constructor.rawAttributes, options);\n\n    options.type = QueryTypes.INSERT;\n    options.instance = instance;\n\n    return this.sequelize.query(sql, options).then(results => {\n      if (instance) results[0].isNewRecord = false;\n      return results;\n    });\n  }\n\n  /**\n   * Upsert\n   *\n   * @param {string} tableName    table to upsert on\n   * @param {Object} insertValues values to be inserted, mapped to field name\n   * @param {Object} updateValues values to be updated, mapped to field name\n   * @param {Object} where        various conditions\n   * @param {Model}  model        Model to upsert on\n   * @param {Object} options      query options\n   *\n   * @returns {Promise<boolean,?number>} Resolves an array with <created, primaryKey>\n   */\n  upsert(tableName, insertValues, updateValues, where, model, options) {\n    const wheres = [];\n    const attributes = Object.keys(insertValues);\n    let indexes = [];\n    let indexFields;\n\n    options = _.clone(options);\n\n    if (!Utils.isWhereEmpty(where)) {\n      wheres.push(where);\n    }\n\n    // Lets combine unique keys and indexes into one\n    indexes = _.map(model.uniqueKeys, value => {\n      return value.fields;\n    });\n\n    model._indexes.forEach(value => {\n      if (value.unique) {\n        // fields in the index may both the strings or objects with an attribute property - lets sanitize that\n        indexFields = value.fields.map(field => {\n          if (_.isPlainObject(field)) {\n            return field.attribute;\n          }\n          return field;\n        });\n        indexes.push(indexFields);\n      }\n    });\n\n    for (const index of indexes) {\n      if (_.intersection(attributes, index).length === index.length) {\n        where = {};\n        for (const field of index) {\n          where[field] = insertValues[field];\n        }\n        wheres.push(where);\n      }\n    }\n\n    where = { [Op.or]: wheres };\n\n    options.type = QueryTypes.UPSERT;\n    options.raw = true;\n\n    const sql = this.QueryGenerator.upsertQuery(tableName, insertValues, updateValues, where, model, options);\n    return this.sequelize.query(sql, options).then(result => {\n      switch (this.sequelize.options.dialect) {\n        default:\n          return [result, undefined];\n      }\n    });\n  }\n\n  /**\n   * Insert multiple records into a table\n   *\n   * @example\n   * queryInterface.bulkInsert('roles', [{\n   *    label: 'user',\n   *    createdAt: new Date(),\n   *    updatedAt: new Date()\n   *  }, {\n   *    label: 'admin',\n   *    createdAt: new Date(),\n   *    updatedAt: new Date()\n   *  }]);\n   *\n   * @param {string} tableName   Table name to insert record to\n   * @param {Array}  records     List of records to insert\n   * @param {Object} options     Various options, please see Model.bulkCreate options\n   * @param {Object} attributes  Various attributes mapped by field name\n   *\n   * @returns {Promise}\n   */\n  bulkInsert(tableName, records, options, attributes) {\n    options = _.clone(options) || {};\n    options.type = QueryTypes.INSERT;\n\n    return this.sequelize.query(\n      this.QueryGenerator.bulkInsertQuery(tableName, records, options, attributes),\n      options\n    ).then(results => results[0]);\n  }\n\n  update(instance, tableName, values, identifier, options) {\n    options = _.clone(options || {});\n    options.hasTrigger = !!(instance && instance._modelOptions && instance._modelOptions.hasTrigger);\n\n    const sql = this.QueryGenerator.updateQuery(tableName, values, identifier, options, instance.constructor.rawAttributes);\n\n    options.type = QueryTypes.UPDATE;\n\n    options.instance = instance;\n    return this.sequelize.query(sql, options);\n  }\n\n  /**\n   * Update multiple records of a table\n   *\n   * @example\n   * queryInterface.bulkUpdate('roles', {\n   *     label: 'admin',\n   *   }, {\n   *     userType: 3,\n   *   },\n   * );\n   *\n   * @param {string} tableName     Table name to update\n   * @param {Object} values        Values to be inserted, mapped to field name\n   * @param {Object} identifier    A hash with conditions OR an ID as integer OR a string with conditions\n   * @param {Object} [options]     Various options, please see Model.bulkCreate options\n   * @param {Object} [attributes]  Attributes on return objects if supported by SQL dialect\n   *\n   * @returns {Promise}\n   */\n  bulkUpdate(tableName, values, identifier, options, attributes) {\n    options = Utils.cloneDeep(options);\n    if (typeof identifier === 'object') identifier = Utils.cloneDeep(identifier);\n\n    const sql = this.QueryGenerator.updateQuery(tableName, values, identifier, options, attributes);\n    const table = _.isObject(tableName) ? tableName : { tableName };\n    const model = _.find(this.sequelize.modelManager.models, { tableName: table.tableName });\n\n    options.type = QueryTypes.BULKUPDATE;\n    options.model = model;\n    return this.sequelize.query(sql, options);\n  }\n\n  delete(instance, tableName, identifier, options) {\n    const cascades = [];\n    const sql = this.QueryGenerator.deleteQuery(tableName, identifier, {}, instance.constructor);\n\n    options = _.clone(options) || {};\n\n    // Check for a restrict field\n    if (!!instance.constructor && !!instance.constructor.associations) {\n      const keys = Object.keys(instance.constructor.associations);\n      const length = keys.length;\n      let association;\n\n      for (let i = 0; i < length; i++) {\n        association = instance.constructor.associations[keys[i]];\n        if (association.options && association.options.onDelete &&\n          association.options.onDelete.toLowerCase() === 'cascade' &&\n          association.options.useHooks === true) {\n          cascades.push(association.accessors.get);\n        }\n      }\n    }\n\n    return Promise.each(cascades, cascade => {\n      return instance[cascade](options).then(instances => {\n        // Check for hasOne relationship with non-existing associate (\"has zero\")\n        if (!instances) {\n          return Promise.resolve();\n        }\n\n        if (!Array.isArray(instances)) instances = [instances];\n\n        return Promise.each(instances, instance => instance.destroy(options));\n      });\n    }).then(() => {\n      options.instance = instance;\n      return this.sequelize.query(sql, options);\n    });\n  }\n\n  /**\n   * Delete multiple records from a table\n   *\n   * @param {string}  tableName            table name from where to delete records\n   * @param {Object}  where                where conditions to find records to delete\n   * @param {Object}  [options]            options\n   * @param {boolean} [options.truncate]   Use truncate table command   \n   * @param {boolean} [options.cascade=false]         Only used in conjunction with TRUNCATE. Truncates  all tables that have foreign-key references to the named table, or to any tables added to the group due to CASCADE.\n   * @param {boolean} [options.restartIdentity=false] Only used in conjunction with TRUNCATE. Automatically restart sequences owned by columns of the truncated table.\n   * @param {Model}   [model]              Model\n   *\n   * @returns {Promise}\n   */\n  bulkDelete(tableName, where, options, model) {\n    options = Utils.cloneDeep(options);\n    options = _.defaults(options, { limit: null });\n\n    if (options.truncate === true) {\n      return this.sequelize.query(\n        this.QueryGenerator.truncateTableQuery(tableName, options),\n        options\n      );\n    }\n\n    if (typeof identifier === 'object') where = Utils.cloneDeep(where);\n\n    return this.sequelize.query(\n      this.QueryGenerator.deleteQuery(tableName, where, options, model),\n      options\n    );\n  }\n\n  select(model, tableName, optionsArg) {\n    const options = Object.assign({}, optionsArg, { type: QueryTypes.SELECT, model });\n\n    return this.sequelize.query(\n      this.QueryGenerator.selectQuery(tableName, options, model),\n      options\n    );\n  }\n\n  increment(model, tableName, values, identifier, options) {\n    options = Utils.cloneDeep(options);\n\n    const sql = this.QueryGenerator.arithmeticQuery('+', tableName, values, identifier, options, options.attributes);\n\n    options.type = QueryTypes.UPDATE;\n    options.model = model;\n\n    return this.sequelize.query(sql, options);\n  }\n\n  decrement(model, tableName, values, identifier, options) {\n    options = Utils.cloneDeep(options);\n\n    const sql = this.QueryGenerator.arithmeticQuery('-', tableName, values, identifier, options, options.attributes);\n\n    options.type = QueryTypes.UPDATE;\n    options.model = model;\n\n    return this.sequelize.query(sql, options);\n  }\n\n  rawSelect(tableName, options, attributeSelector, Model) {\n    options = Utils.cloneDeep(options);\n    options = _.defaults(options, {\n      raw: true,\n      plain: true,\n      type: QueryTypes.SELECT\n    });\n\n    const sql = this.QueryGenerator.selectQuery(tableName, options, Model);\n\n    if (attributeSelector === undefined) {\n      throw new Error('Please pass an attribute selector!');\n    }\n\n    return this.sequelize.query(sql, options).then(data => {\n      if (!options.plain) {\n        return data;\n      }\n\n      const result = data ? data[attributeSelector] : null;\n\n      if (!options || !options.dataType) {\n        return result;\n      }\n\n      const dataType = options.dataType;\n\n      if (dataType instanceof DataTypes.DECIMAL || dataType instanceof DataTypes.FLOAT) {\n        if (result !== null) {\n          return parseFloat(result);\n        }\n      }\n      if (dataType instanceof DataTypes.INTEGER || dataType instanceof DataTypes.BIGINT) {\n        return parseInt(result, 10);\n      }\n      if (dataType instanceof DataTypes.DATE) {\n        if (result !== null && !(result instanceof Date)) {\n          return new Date(result);\n        }\n      }\n      return result;\n    });\n  }\n\n  createTrigger(tableName, triggerName, timingType, fireOnArray, functionName, functionParams, optionsArray, options) {\n    const sql = this.QueryGenerator.createTrigger(tableName, triggerName, timingType, fireOnArray, functionName, functionParams, optionsArray);\n    options = options || {};\n    if (sql) {\n      return this.sequelize.query(sql, options);\n    }\n    return Promise.resolve();\n  }\n\n  dropTrigger(tableName, triggerName, options) {\n    const sql = this.QueryGenerator.dropTrigger(tableName, triggerName);\n    options = options || {};\n\n    if (sql) {\n      return this.sequelize.query(sql, options);\n    }\n    return Promise.resolve();\n  }\n\n  renameTrigger(tableName, oldTriggerName, newTriggerName, options) {\n    const sql = this.QueryGenerator.renameTrigger(tableName, oldTriggerName, newTriggerName);\n    options = options || {};\n\n    if (sql) {\n      return this.sequelize.query(sql, options);\n    }\n    return Promise.resolve();\n  }\n\n  /**\n   * Create an SQL function\n   *\n   * @example\n   * queryInterface.createFunction(\n   *   'someFunction',\n   *   [\n   *     {type: 'integer', name: 'param', direction: 'IN'}\n   *   ],\n   *   'integer',\n   *   'plpgsql',\n   *   'RETURN param + 1;',\n   *   [\n   *     'IMMUTABLE',\n   *     'LEAKPROOF'\n   *   ],\n   *   {\n   *    variables:\n   *      [\n   *        {type: 'integer', name: 'myVar', default: 100}\n   *      ],\n   *      force: true\n   *   };\n   * );\n   *\n   * @param {string}  functionName  Name of SQL function to create\n   * @param {Array}   params        List of parameters declared for SQL function\n   * @param {string}  returnType    SQL type of function returned value\n   * @param {string}  language      The name of the language that the function is implemented in\n   * @param {string}  body          Source code of function\n   * @param {Array}   optionsArray  Extra-options for creation\n   * @param {Object}  [options]     query options\n   * @param {boolean} options.force If force is true, any existing functions with the same parameters will be replaced. For postgres, this means using `CREATE OR REPLACE FUNCTION` instead of `CREATE FUNCTION`. Default is false\n   * @param {Array<Object>}   options.variables List of declared variables. Each variable should be an object with string fields `type` and `name`, and optionally having a `default` field as well.\n   *\n   * @returns {Promise}\n   */\n  createFunction(functionName, params, returnType, language, body, optionsArray, options) {\n    const sql = this.QueryGenerator.createFunction(functionName, params, returnType, language, body, optionsArray, options);\n    options = options || {};\n\n    if (sql) {\n      return this.sequelize.query(sql, options);\n    }\n    return Promise.resolve();\n  }\n\n  /**\n   * Drop an SQL function\n   *\n   * @example\n   * queryInterface.dropFunction(\n   *   'someFunction',\n   *   [\n   *     {type: 'varchar', name: 'param1', direction: 'IN'},\n   *     {type: 'integer', name: 'param2', direction: 'INOUT'}\n   *   ]\n   * );\n   *\n   * @param {string} functionName Name of SQL function to drop\n   * @param {Array}  params       List of parameters declared for SQL function\n   * @param {Object} [options]    query options\n   *\n   * @returns {Promise}\n   */\n  dropFunction(functionName, params, options) {\n    const sql = this.QueryGenerator.dropFunction(functionName, params);\n    options = options || {};\n\n    if (sql) {\n      return this.sequelize.query(sql, options);\n    }\n    return Promise.resolve();\n  }\n\n  /**\n   * Rename an SQL function\n   *\n   * @example\n   * queryInterface.renameFunction(\n   *   'fooFunction',\n   *   [\n   *     {type: 'varchar', name: 'param1', direction: 'IN'},\n   *     {type: 'integer', name: 'param2', direction: 'INOUT'}\n   *   ],\n   *   'barFunction'\n   * );\n   *\n   * @param {string} oldFunctionName  Current name of function\n   * @param {Array}  params           List of parameters declared for SQL function\n   * @param {string} newFunctionName  New name of function\n   * @param {Object} [options]        query options\n   *\n   * @returns {Promise}\n   */\n  renameFunction(oldFunctionName, params, newFunctionName, options) {\n    const sql = this.QueryGenerator.renameFunction(oldFunctionName, params, newFunctionName);\n    options = options || {};\n\n    if (sql) {\n      return this.sequelize.query(sql, options);\n    }\n    return Promise.resolve();\n  }\n\n  // Helper methods useful for querying\n\n  /**\n   * Escape an identifier (e.g. a table or attribute name)\n   *\n   * @param {string} identifier identifier to quote\n   * @param {boolean} [force]   If force is true,the identifier will be quoted even if the `quoteIdentifiers` option is false.\n   *\n   * @private\n   */\n  quoteIdentifier(identifier, force) {\n    return this.QueryGenerator.quoteIdentifier(identifier, force);\n  }\n\n  quoteTable(identifier) {\n    return this.QueryGenerator.quoteTable(identifier);\n  }\n\n  /**\n   * Quote array of identifiers at once\n   *\n   * @param {string[]} identifiers array of identifiers to quote\n   * @param {boolean} [force]   If force is true,the identifier will be quoted even if the `quoteIdentifiers` option is false.\n   *\n   * @private\n   */\n  quoteIdentifiers(identifiers, force) {\n    return this.QueryGenerator.quoteIdentifiers(identifiers, force);\n  }\n\n  /**\n   * Escape a value (e.g. a string, number or date)\n   *\n   * @param {string} value string to escape\n   *\n   * @private\n   */\n  escape(value) {\n    return this.QueryGenerator.escape(value);\n  }\n\n  setIsolationLevel(transaction, value, options) {\n    if (!transaction || !(transaction instanceof Transaction)) {\n      throw new Error('Unable to set isolation level for a transaction without transaction object!');\n    }\n\n    if (transaction.parent || !value) {\n      // Not possible to set a separate isolation level for savepoints\n      return Promise.resolve();\n    }\n\n    options = Object.assign({}, options, {\n      transaction: transaction.parent || transaction\n    });\n\n    const sql = this.QueryGenerator.setIsolationLevelQuery(value, {\n      parent: transaction.parent\n    });\n\n    if (!sql) return Promise.resolve();\n\n    return this.sequelize.query(sql, options);\n  }\n\n  startTransaction(transaction, options) {\n    if (!transaction || !(transaction instanceof Transaction)) {\n      throw new Error('Unable to start a transaction without transaction object!');\n    }\n\n    options = Object.assign({}, options, {\n      transaction: transaction.parent || transaction\n    });\n    options.transaction.name = transaction.parent ? transaction.name : undefined;\n    const sql = this.QueryGenerator.startTransactionQuery(transaction);\n\n    return this.sequelize.query(sql, options);\n  }\n\n  deferConstraints(transaction, options) {\n    options = Object.assign({}, options, {\n      transaction: transaction.parent || transaction\n    });\n\n    const sql = this.QueryGenerator.deferConstraintsQuery(options);\n\n    if (sql) {\n      return this.sequelize.query(sql, options);\n    }\n\n    return Promise.resolve();\n  }\n\n  commitTransaction(transaction, options) {\n    if (!transaction || !(transaction instanceof Transaction)) {\n      throw new Error('Unable to commit a transaction without transaction object!');\n    }\n    if (transaction.parent) {\n      // Savepoints cannot be committed\n      return Promise.resolve();\n    }\n\n    options = Object.assign({}, options, {\n      transaction: transaction.parent || transaction,\n      supportsSearchPath: false,\n      completesTransaction: true\n    });\n\n    const sql = this.QueryGenerator.commitTransactionQuery(transaction);\n    const promise = this.sequelize.query(sql, options);\n\n    transaction.finished = 'commit';\n\n    return promise;\n  }\n\n  rollbackTransaction(transaction, options) {\n    if (!transaction || !(transaction instanceof Transaction)) {\n      throw new Error('Unable to rollback a transaction without transaction object!');\n    }\n\n    options = Object.assign({}, options, {\n      transaction: transaction.parent || transaction,\n      supportsSearchPath: false,\n      completesTransaction: true\n    });\n    options.transaction.name = transaction.parent ? transaction.name : undefined;\n    const sql = this.QueryGenerator.rollbackTransactionQuery(transaction);\n    const promise = this.sequelize.query(sql, options);\n\n    transaction.finished = 'rollback';\n\n    return promise;\n  }\n}\n\nmodule.exports = QueryInterface;\nmodule.exports.QueryInterface = QueryInterface;\nmodule.exports.default = QueryInterface;\n"]} \ No newline at end of file diff --git a/dist/query-types.js b/dist/query-types.js index 399f4e4..ec97c9a 100644 --- a/dist/query-types.js +++ b/dist/query-types.js @@ -37,4 +37,4 @@ const QueryTypes = module.exports = { FOREIGNKEYS: 'FOREIGNKEYS', SHOWCONSTRAINTS: 'SHOWCONSTRAINTS' }; -//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uL2xpYi9xdWVyeS10eXBlcy5qcyJdLCJuYW1lcyI6WyJRdWVyeVR5cGVzIiwibW9kdWxlIiwiZXhwb3J0cyIsIlNFTEVDVCIsIklOU0VSVCIsIlVQREFURSIsIkJVTEtVUERBVEUiLCJCVUxLREVMRVRFIiwiREVMRVRFIiwiVVBTRVJUIiwiVkVSU0lPTiIsIlNIT1dUQUJMRVMiLCJTSE9XSU5ERVhFUyIsIkRFU0NSSUJFIiwiUkFXIiwiRk9SRUlHTktFWVMiLCJTSE9XQ09OU1RSQUlOVFMiXSwibWFwcGluZ3MiOiJBQUFBO0FBRUE7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7OztBQW9CQSxNQUFNQSxVQUFVLEdBQUdDLE1BQU0sQ0FBQ0MsT0FBUCxHQUFpQjtBQUFFO0FBQ3BDQyxFQUFBQSxNQUFNLEVBQUUsUUFEMEI7QUFFbENDLEVBQUFBLE1BQU0sRUFBRSxRQUYwQjtBQUdsQ0MsRUFBQUEsTUFBTSxFQUFFLFFBSDBCO0FBSWxDQyxFQUFBQSxVQUFVLEVBQUUsWUFKc0I7QUFLbENDLEVBQUFBLFVBQVUsRUFBRSxZQUxzQjtBQU1sQ0MsRUFBQUEsTUFBTSxFQUFFLFFBTjBCO0FBT2xDQyxFQUFBQSxNQUFNLEVBQUUsUUFQMEI7QUFRbENDLEVBQUFBLE9BQU8sRUFBRSxTQVJ5QjtBQVNsQ0MsRUFBQUEsVUFBVSxFQUFFLFlBVHNCO0FBVWxDQyxFQUFBQSxXQUFXLEVBQUUsYUFWcUI7QUFXbENDLEVBQUFBLFFBQVEsRUFBRSxVQVh3QjtBQVlsQ0MsRUFBQUEsR0FBRyxFQUFFLEtBWjZCO0FBYWxDQyxFQUFBQSxXQUFXLEVBQUUsYUFicUI7QUFjbENDLEVBQUFBLGVBQWUsRUFBRTtBQWRpQixDQUFwQyIsInNvdXJjZXNDb250ZW50IjpbIid1c2Ugc3RyaWN0JztcclxuXHJcbi8qKlxyXG4gKiBBbiBlbnVtIG9mIHF1ZXJ5IHR5cGVzIHVzZWQgYnkgYHNlcXVlbGl6ZS5xdWVyeWBcclxuICpcclxuICogQHNlZSB7QGxpbmsgU2VxdWVsaXplI3F1ZXJ5fVxyXG4gKlxyXG4gKiBAcHJvcGVydHkgU0VMRUNUXHJcbiAqIEBwcm9wZXJ0eSBJTlNFUlRcclxuICogQHByb3BlcnR5IFVQREFURVxyXG4gKiBAcHJvcGVydHkgQlVMS1VQREFURVxyXG4gKiBAcHJvcGVydHkgQlVMS0RFTEVURVxyXG4gKiBAcHJvcGVydHkgREVMRVRFXHJcbiAqIEBwcm9wZXJ0eSBVUFNFUlRcclxuICogQHByb3BlcnR5IFZFUlNJT05cclxuICogQHByb3BlcnR5IFNIT1dUQUJMRVNcclxuICogQHByb3BlcnR5IFNIT1dJTkRFWEVTXHJcbiAqIEBwcm9wZXJ0eSBERVNDUklCRVxyXG4gKiBAcHJvcGVydHkgUkFXXHJcbiAqIEBwcm9wZXJ0eSBGT1JFSUdOS0VZU1xyXG4gKiBAcHJvcGVydHkgU0hPV0NPTlNUUkFJTlRTXHJcbiAqL1xyXG5jb25zdCBRdWVyeVR5cGVzID0gbW9kdWxlLmV4cG9ydHMgPSB7IC8vIGVzbGludC1kaXNhYmxlLWxpbmVcclxuICBTRUxFQ1Q6ICdTRUxFQ1QnLFxyXG4gIElOU0VSVDogJ0lOU0VSVCcsXHJcbiAgVVBEQVRFOiAnVVBEQVRFJyxcclxuICBCVUxLVVBEQVRFOiAnQlVMS1VQREFURScsXHJcbiAgQlVMS0RFTEVURTogJ0JVTEtERUxFVEUnLFxyXG4gIERFTEVURTogJ0RFTEVURScsXHJcbiAgVVBTRVJUOiAnVVBTRVJUJyxcclxuICBWRVJTSU9OOiAnVkVSU0lPTicsXHJcbiAgU0hPV1RBQkxFUzogJ1NIT1dUQUJMRVMnLFxyXG4gIFNIT1dJTkRFWEVTOiAnU0hPV0lOREVYRVMnLFxyXG4gIERFU0NSSUJFOiAnREVTQ1JJQkUnLFxyXG4gIFJBVzogJ1JBVycsXHJcbiAgRk9SRUlHTktFWVM6ICdGT1JFSUdOS0VZUycsXHJcbiAgU0hPV0NPTlNUUkFJTlRTOiAnU0hPV0NPTlNUUkFJTlRTJ1xyXG59O1xyXG4iXX0= \ No newline at end of file +//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uL2xpYi9xdWVyeS10eXBlcy5qcyJdLCJuYW1lcyI6WyJRdWVyeVR5cGVzIiwibW9kdWxlIiwiZXhwb3J0cyIsIlNFTEVDVCIsIklOU0VSVCIsIlVQREFURSIsIkJVTEtVUERBVEUiLCJCVUxLREVMRVRFIiwiREVMRVRFIiwiVVBTRVJUIiwiVkVSU0lPTiIsIlNIT1dUQUJMRVMiLCJTSE9XSU5ERVhFUyIsIkRFU0NSSUJFIiwiUkFXIiwiRk9SRUlHTktFWVMiLCJTSE9XQ09OU1RSQUlOVFMiXSwibWFwcGluZ3MiOiJBQUFBO0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFDQSxNQUFNQSxVQUFVLEdBQUdDLE1BQU0sQ0FBQ0MsT0FBUCxHQUFpQjtBQUFFO0FBQ3BDQyxFQUFBQSxNQUFNLEVBQUUsUUFEMEI7QUFFbENDLEVBQUFBLE1BQU0sRUFBRSxRQUYwQjtBQUdsQ0MsRUFBQUEsTUFBTSxFQUFFLFFBSDBCO0FBSWxDQyxFQUFBQSxVQUFVLEVBQUUsWUFKc0I7QUFLbENDLEVBQUFBLFVBQVUsRUFBRSxZQUxzQjtBQU1sQ0MsRUFBQUEsTUFBTSxFQUFFLFFBTjBCO0FBT2xDQyxFQUFBQSxNQUFNLEVBQUUsUUFQMEI7QUFRbENDLEVBQUFBLE9BQU8sRUFBRSxTQVJ5QjtBQVNsQ0MsRUFBQUEsVUFBVSxFQUFFLFlBVHNCO0FBVWxDQyxFQUFBQSxXQUFXLEVBQUUsYUFWcUI7QUFXbENDLEVBQUFBLFFBQVEsRUFBRSxVQVh3QjtBQVlsQ0MsRUFBQUEsR0FBRyxFQUFFLEtBWjZCO0FBYWxDQyxFQUFBQSxXQUFXLEVBQUUsYUFicUI7QUFjbENDLEVBQUFBLGVBQWUsRUFBRTtBQWRpQixDQUFwQyIsInNvdXJjZXNDb250ZW50IjpbIid1c2Ugc3RyaWN0JztcblxuLyoqXG4gKiBBbiBlbnVtIG9mIHF1ZXJ5IHR5cGVzIHVzZWQgYnkgYHNlcXVlbGl6ZS5xdWVyeWBcbiAqXG4gKiBAc2VlIHtAbGluayBTZXF1ZWxpemUjcXVlcnl9XG4gKlxuICogQHByb3BlcnR5IFNFTEVDVFxuICogQHByb3BlcnR5IElOU0VSVFxuICogQHByb3BlcnR5IFVQREFURVxuICogQHByb3BlcnR5IEJVTEtVUERBVEVcbiAqIEBwcm9wZXJ0eSBCVUxLREVMRVRFXG4gKiBAcHJvcGVydHkgREVMRVRFXG4gKiBAcHJvcGVydHkgVVBTRVJUXG4gKiBAcHJvcGVydHkgVkVSU0lPTlxuICogQHByb3BlcnR5IFNIT1dUQUJMRVNcbiAqIEBwcm9wZXJ0eSBTSE9XSU5ERVhFU1xuICogQHByb3BlcnR5IERFU0NSSUJFXG4gKiBAcHJvcGVydHkgUkFXXG4gKiBAcHJvcGVydHkgRk9SRUlHTktFWVNcbiAqIEBwcm9wZXJ0eSBTSE9XQ09OU1RSQUlOVFNcbiAqL1xuY29uc3QgUXVlcnlUeXBlcyA9IG1vZHVsZS5leHBvcnRzID0geyAvLyBlc2xpbnQtZGlzYWJsZS1saW5lXG4gIFNFTEVDVDogJ1NFTEVDVCcsXG4gIElOU0VSVDogJ0lOU0VSVCcsXG4gIFVQREFURTogJ1VQREFURScsXG4gIEJVTEtVUERBVEU6ICdCVUxLVVBEQVRFJyxcbiAgQlVMS0RFTEVURTogJ0JVTEtERUxFVEUnLFxuICBERUxFVEU6ICdERUxFVEUnLFxuICBVUFNFUlQ6ICdVUFNFUlQnLFxuICBWRVJTSU9OOiAnVkVSU0lPTicsXG4gIFNIT1dUQUJMRVM6ICdTSE9XVEFCTEVTJyxcbiAgU0hPV0lOREVYRVM6ICdTSE9XSU5ERVhFUycsXG4gIERFU0NSSUJFOiAnREVTQ1JJQkUnLFxuICBSQVc6ICdSQVcnLFxuICBGT1JFSUdOS0VZUzogJ0ZPUkVJR05LRVlTJyxcbiAgU0hPV0NPTlNUUkFJTlRTOiAnU0hPV0NPTlNUUkFJTlRTJ1xufTtcbiJdfQ== \ No newline at end of file diff --git a/dist/sequelize.js b/dist/sequelize.js index ff66996..a4cf3cf 100644 --- a/dist/sequelize.js +++ b/dist/sequelize.js @@ -1,14 +1,18 @@ "use strict"; +function _inherits(subClass, superClass) { if (typeof superClass !== "function" && superClass !== null) { throw new TypeError("Super expression must either be null or a function"); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, writable: true, configurable: true } }); if (superClass) _setPrototypeOf(subClass, superClass); } + +function _setPrototypeOf(o, p) { _setPrototypeOf = Object.setPrototypeOf || function _setPrototypeOf(o, p) { o.__proto__ = p; return o; }; return _setPrototypeOf(o, p); } + +function _createSuper(Derived) { var hasNativeReflectConstruct = _isNativeReflectConstruct(); return function _createSuperInternal() { var Super = _getPrototypeOf(Derived), result; if (hasNativeReflectConstruct) { var NewTarget = _getPrototypeOf(this).constructor; result = Reflect.construct(Super, arguments, NewTarget); } else { result = Super.apply(this, arguments); } return _possibleConstructorReturn(this, result); }; } + function _possibleConstructorReturn(self, call) { if (call && (typeof call === "object" || typeof call === "function")) { return call; } return _assertThisInitialized(self); } function _assertThisInitialized(self) { if (self === void 0) { throw new ReferenceError("this hasn't been initialised - super() hasn't been called"); } return self; } -function _getPrototypeOf(o) { _getPrototypeOf = Object.setPrototypeOf ? Object.getPrototypeOf : function _getPrototypeOf(o) { return o.__proto__ || Object.getPrototypeOf(o); }; return _getPrototypeOf(o); } +function _isNativeReflectConstruct() { if (typeof Reflect === "undefined" || !Reflect.construct) return false; if (Reflect.construct.sham) return false; if (typeof Proxy === "function") return true; try { Date.prototype.toString.call(Reflect.construct(Date, [], function () {})); return true; } catch (e) { return false; } } -function _inherits(subClass, superClass) { if (typeof superClass !== "function" && superClass !== null) { throw new TypeError("Super expression must either be null or a function"); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, writable: true, configurable: true } }); if (superClass) _setPrototypeOf(subClass, superClass); } - -function _setPrototypeOf(o, p) { _setPrototypeOf = Object.setPrototypeOf || function _setPrototypeOf(o, p) { o.__proto__ = p; return o; }; return _setPrototypeOf(o, p); } +function _getPrototypeOf(o) { _getPrototypeOf = Object.setPrototypeOf ? Object.getPrototypeOf : function _getPrototypeOf(o) { return o.__proto__ || Object.getPrototypeOf(o); }; return _getPrototypeOf(o); } function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } } @@ -60,9 +64,7 @@ const deprecations = require("./utils/deprecations"); */ -let Sequelize = -/*#__PURE__*/ -function () { +let Sequelize = /*#__PURE__*/function () { /** * Instantiate sequelize with name of database, username and password. * @@ -424,15 +426,15 @@ function () { options.modelName = modelName; options.sequelize = this; - const model = - /*#__PURE__*/ - function (_Model) { + const model = /*#__PURE__*/function (_Model) { _inherits(model, _Model); + var _super = _createSuper(model); + function model() { _classCallCheck(this, model); - return _possibleConstructorReturn(this, _getPrototypeOf(model).apply(this, arguments)); + return _super.apply(this, arguments); } return model; @@ -1402,4 +1404,4 @@ for (const error of Object.keys(sequelizeErrors)) { module.exports = Sequelize; module.exports.Sequelize = Sequelize; module.exports.default = Sequelize; -//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../lib/sequelize.js"],"names":["retry","require","clsBluebird","_","Utils","Model","DataTypes","Deferrable","ModelManager","QueryInterface","Transaction","QueryTypes","TableHints","IndexHints","sequelizeErrors","Promise","Hooks","Association","Validator","validator","Op","deprecations","Sequelize","database","username","password","options","config","arguments","length","pick","runHooks","Object","assign","dialect","dialectModule","dialectModulePath","host","protocol","define","query","sync","timezone","clientMinMessages","standardConformingStrings","logging","console","log","omitNull","native","replication","ssl","undefined","pool","quoteIdentifiers","hooks","max","match","transactionType","TYPES","DEFERRED","isolationLevel","databaseVersion","typeValidation","benchmark","minifyAliases","logQueryParameters","Error","noTrueLogging","_setupHooks","port","keepDefaultTimezone","dialectOptions","Dialect","getDialect","QueryGenerator","isPlainObject","operatorsAliases","noStringOperators","setOperatorsAliases","noBoolOperatorAliases","queryInterface","models","modelManager","connectionManager","importCache","refreshTypeParser","modelName","attributes","sequelize","model","init","isDefined","getModel","find","name","importPath","sql","instance","constructor","raw","mapToModel","fieldMap","get","defaults","prototype","hasOwnProperty","call","searchPath","type","nest","plain","SELECT","RAW","supports","prependSearchPath","supportsSearchPath","try","values","replacements","bind","trim","Array","isArray","format","concat","formatNamedParameters","bindParameters","Query","formatBindParameters","checkTransaction","transaction","finished","completesTransaction","error","id","retryOptions","resolve","_cls","connection","getConnection","then","run","finally","releaseConnection","variables","set","TypeError","map","v","k","join","value","getQueryInterface","escape","schema","createSchema","showAllSchemas","dropSchema","dropAllSchemas","clone","test","reject","force","drop","forEachModel","push","authenticate","each","return","reverse","truncateModel","truncate","cascade","dia","fn","autoCallback","prepareEnvironment","_clsRun","tap","commit","catch","err","rollback","throw","args","last","splice","close","Type","dialectTypes","key","extend","ARRAY","attribute","normalizeDataType","defaultValue","NOW","UUIDV1","UUIDV4","ENUM","Fn","col","Col","val","Cast","Literal","and","or","conditionsOrPath","Json","attr","comparator","logic","Where","ns","res","context","cast","literal","json","where","validate","version","dataType","useInflection","applyTo","BaseError","keys","module","exports","default"],"mappings":"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","sourcesContent":["\"use strict\";\r\nconst retry = require(\"retry-as-promised\");\r\nconst clsBluebird = require(\"cls-bluebird\");\r\nconst _ = require(\"lodash\");\r\n\r\nconst Utils = require(\"./utils\");\r\nconst Model = require(\"./model\");\r\nconst DataTypes = require(\"./data-types\");\r\nconst Deferrable = require(\"./deferrable\");\r\nconst ModelManager = require(\"./model-manager\");\r\nconst QueryInterface = require(\"./query-interface\");\r\nconst Transaction = require(\"./transaction\");\r\nconst QueryTypes = require(\"./query-types\");\r\nconst TableHints = require(\"./table-hints\");\r\nconst IndexHints = require(\"./index-hints\");\r\nconst sequelizeErrors = require(\"./errors\");\r\nconst Promise = require(\"./promise\");\r\nconst Hooks = require(\"./hooks\");\r\nconst Association = require(\"./associations/index\");\r\nconst Validator = require(\"./utils/validator-extras\").validator;\r\nconst Op = require(\"./operators\");\r\nconst deprecations = require(\"./utils/deprecations\");\r\n\r\n/**\r\n * This is the main class, the entry point to sequelize.\r\n */\r\nclass Sequelize {\r\n  /**\r\n   * Instantiate sequelize with name of database, username and password.\r\n   *\r\n   * @example\r\n   * // without password / with blank password\r\n   * const sequelize = new Sequelize('database', 'username', null, {\r\n   *   dialect: 'mysql'\r\n   * })\r\n   *\r\n   * // with password and options\r\n   * const sequelize = new Sequelize('my_database', 'john', 'doe', {\r\n   *   dialect: 'postgres'\r\n   * })\r\n   *\r\n   * // with database, username, and password in the options object\r\n   * const sequelize = new Sequelize({ database, username, password, dialect: 'mssql' });\r\n   *\r\n   * // with uri\r\n   * const sequelize = new Sequelize('mysql://localhost:3306/database', {})\r\n   *\r\n   * // option examples\r\n   * const sequelize = new Sequelize('database', 'username', 'password', {\r\n   *   // the sql dialect of the database\r\n   *   // currently supported: 'mysql', 'sqlite', 'postgres', 'mssql'\r\n   *   dialect: 'mysql',\r\n   *\r\n   *   // custom host; default: localhost\r\n   *   host: 'my.server.tld',\r\n   *   // for postgres, you can also specify an absolute path to a directory\r\n   *   // containing a UNIX socket to connect over\r\n   *   // host: '/sockets/psql_sockets'.\r\n   *\r\n   *   // custom port; default: dialect default\r\n   *   port: 12345,\r\n   *\r\n   *   // custom protocol; default: 'tcp'\r\n   *   // postgres only, useful for Heroku\r\n   *   protocol: null,\r\n   *\r\n   *   // disable logging or provide a custom logging function; default: console.log\r\n   *   logging: false,\r\n   *\r\n   *   // you can also pass any dialect options to the underlying dialect library\r\n   *   // - default is empty\r\n   *   // - currently supported: 'mysql', 'postgres', 'mssql'\r\n   *   dialectOptions: {\r\n   *     socketPath: '/Applications/MAMP/tmp/mysql/mysql.sock',\r\n   *     supportBigNumbers: true,\r\n   *     bigNumberStrings: true\r\n   *   },\r\n   *\r\n   *   // the storage engine for sqlite\r\n   *   // - default ':memory:'\r\n   *   storage: 'path/to/database.sqlite',\r\n   *\r\n   *   // disable inserting undefined values as NULL\r\n   *   // - default: false\r\n   *   omitNull: true,\r\n   *\r\n   *   // a flag for using a native library or not.\r\n   *   // in the case of 'pg' -- set this to true will allow SSL support\r\n   *   // - default: false\r\n   *   native: true,\r\n   *\r\n   *   // Specify options, which are used when sequelize.define is called.\r\n   *   // The following example:\r\n   *   //   define: { timestamps: false }\r\n   *   // is basically the same as:\r\n   *   //   Model.init(attributes, { timestamps: false });\r\n   *   //   sequelize.define(name, attributes, { timestamps: false });\r\n   *   // so defining the timestamps for each model will be not necessary\r\n   *   define: {\r\n   *     underscored: false,\r\n   *     freezeTableName: false,\r\n   *     charset: 'utf8',\r\n   *     dialectOptions: {\r\n   *       collate: 'utf8_general_ci'\r\n   *     },\r\n   *     timestamps: true\r\n   *   },\r\n   *\r\n   *   // similar for sync: you can define this to always force sync for models\r\n   *   sync: { force: true },\r\n   *\r\n   *   // pool configuration used to pool database connections\r\n   *   pool: {\r\n   *     max: 5,\r\n   *     idle: 30000,\r\n   *     acquire: 60000,\r\n   *   },\r\n   *\r\n   *   // isolation level of each transaction\r\n   *   // defaults to dialect default\r\n   *   isolationLevel: Transaction.ISOLATION_LEVELS.REPEATABLE_READ\r\n   * })\r\n   *\r\n   * @param {string}   [database] The name of the database\r\n   * @param {string}   [username=null] The username which is used to authenticate against the database.\r\n   * @param {string}   [password=null] The password which is used to authenticate against the database. Supports SQLCipher encryption for SQLite.\r\n   * @param {Object}   [options={}] An object with options.\r\n   * @param {string}   [options.host='localhost'] The host of the relational database.\r\n   * @param {number}   [options.port=] The port of the relational database.\r\n   * @param {string}   [options.username=null] The username which is used to authenticate against the database.\r\n   * @param {string}   [options.password=null] The password which is used to authenticate against the database.\r\n   * @param {string}   [options.database=null] The name of the database\r\n   * @param {string}   [options.dialect] The dialect of the database you are connecting to. One of mysql, postgres, sqlite and mssql.\r\n   * @param {string}   [options.dialectModule=null] If specified, use this dialect library. For example, if you want to use pg.js instead of pg when connecting to a pg database, you should specify 'require(\"pg.js\")' here\r\n   * @param {string}   [options.dialectModulePath=null] If specified, load the dialect library from this path. For example, if you want to use pg.js instead of pg when connecting to a pg database, you should specify '/path/to/pg.js' here\r\n   * @param {Object}   [options.dialectOptions] An object of additional options, which are passed directly to the connection library\r\n   * @param {string}   [options.storage] Only used by sqlite. Defaults to ':memory:'\r\n   * @param {string}   [options.protocol='tcp'] The protocol of the relational database.\r\n   * @param {Object}   [options.define={}] Default options for model definitions. See {@link Model.init}.\r\n   * @param {Object}   [options.query={}] Default options for sequelize.query\r\n   * @param {string}   [options.schema=null] A schema to use\r\n   * @param {Object}   [options.set={}] Default options for sequelize.set\r\n   * @param {Object}   [options.sync={}] Default options for sequelize.sync\r\n   * @param {string}   [options.timezone='+00:00'] The timezone used when converting a date from the database into a JavaScript date. The timezone is also used to SET TIMEZONE when connecting to the server, to ensure that the result of NOW, CURRENT_TIMESTAMP and other time related functions have in the right timezone. For best cross platform performance use the format +/-HH:MM. Will also accept string versions of timezones used by moment.js (e.g. 'America/Los_Angeles'); this is useful to capture daylight savings time changes.\r\n   * @param {string|boolean} [options.clientMinMessages='warning'] The PostgreSQL `client_min_messages` session parameter. Set to `false` to not override the database's default.\r\n   * @param {boolean}  [options.standardConformingStrings=true] The PostgreSQL `standard_conforming_strings` session parameter. Set to `false` to not set the option. WARNING: Setting this to false may expose vulnerabilities and is not recommended!\r\n   * @param {Function} [options.logging=console.log] A function that gets executed every time Sequelize would log something.\r\n   * @param {boolean}  [options.benchmark=false] Pass query execution time in milliseconds as second argument to logging function (options.logging).\r\n   * @param {boolean}  [options.omitNull=false] A flag that defines if null values should be passed to SQL queries or not.\r\n   * @param {boolean}  [options.native=false] A flag that defines if native library shall be used or not. Currently only has an effect for postgres\r\n   * @param {boolean}  [options.replication=false] Use read / write replication. To enable replication, pass an object, with two properties, read and write. Write should be an object (a single server for handling writes), and read an array of object (several servers to handle reads). Each read/write server can have the following properties: `host`, `port`, `username`, `password`, `database`\r\n   * @param {Object}   [options.pool] sequelize connection pool configuration\r\n   * @param {number}   [options.pool.max=5] Maximum number of connection in pool\r\n   * @param {number}   [options.pool.min=0] Minimum number of connection in pool\r\n   * @param {number}   [options.pool.idle=10000] The maximum time, in milliseconds, that a connection can be idle before being released.\r\n   * @param {number}   [options.pool.acquire=60000] The maximum time, in milliseconds, that pool will try to get connection before throwing error\r\n   * @param {number}   [options.pool.evict=1000] The time interval, in milliseconds, after which sequelize-pool will remove idle connections.\r\n   * @param {Function} [options.pool.validate] A function that validates a connection. Called with client. The default function checks that client is an object, and that its state is not disconnected\r\n   * @param {boolean}  [options.quoteIdentifiers=true] Set to `false` to make table names and attributes case-insensitive on Postgres and skip double quoting of them.  WARNING: Setting this to false may expose vulnerabilities and is not recommended!\r\n   * @param {string}   [options.transactionType='DEFERRED'] Set the default transaction type. See `Sequelize.Transaction.TYPES` for possible options. Sqlite only.\r\n   * @param {string}   [options.isolationLevel] Set the default transaction isolation level. See `Sequelize.Transaction.ISOLATION_LEVELS` for possible options.\r\n   * @param {Object}   [options.retry] Set of flags that control when a query is automatically retried.\r\n   * @param {Array}    [options.retry.match] Only retry a query if the error matches one of these strings.\r\n   * @param {number}   [options.retry.max] How many times a failing query is automatically retried.  Set to 0 to disable retrying on SQL_BUSY error.\r\n   * @param {boolean}  [options.typeValidation=false] Run built-in type validators on insert and update, and select with where clause, e.g. validate that arguments passed to integer fields are integer-like.\r\n   * @param {Object}   [options.operatorsAliases] String based operator alias. Pass object to limit set of aliased operators.\r\n   * @param {Object}   [options.hooks] An object of global hook functions that are called before and after certain lifecycle events. Global hooks will run after any model-specific hooks defined for the same event (See `Sequelize.Model.init()` for a list).  Additionally, `beforeConnect()`, `afterConnect()`, `beforeDisconnect()`, and `afterDisconnect()` hooks may be defined here.\r\n   * @param {boolean}  [options.minifyAliases=false] A flag that defines if aliases should be minified (mostly useful to avoid Postgres alias character limit of 64)\r\n   * @param {boolean}  [options.logQueryParameters=false] A flag that defines if show bind patameters in log.\r\n   */\r\n  constructor(database, username, password, options) {\r\n    let config;\r\n\r\n    if (arguments.length === 1 && typeof database === \"object\") {\r\n      // new Sequelize({ ... options })\r\n      options = database;\r\n      config = _.pick(\r\n        options,\r\n        \"host\",\r\n        \"port\",\r\n        \"database\",\r\n        \"username\",\r\n        \"password\"\r\n      );\r\n    } else if (\r\n      (arguments.length === 1 && typeof database === \"string\") ||\r\n      (arguments.length === 2 && typeof username === \"object\")\r\n    ) {\r\n      // new Sequelize(URI, { ... options })\r\n\r\n      config = {};\r\n      options = username || {};\r\n    } else {\r\n      // new Sequelize(database, username, password, { ... options })\r\n      options = options || {};\r\n      config = { database, username, password };\r\n    }\r\n\r\n    Sequelize.runHooks(\"beforeInit\", config, options);\r\n\r\n    this.options = Object.assign(\r\n      {\r\n        dialect: \"sqlite\",\r\n        dialectModule: null,\r\n        dialectModulePath: null,\r\n        host: \"localhost\",\r\n        protocol: \"tcp\",\r\n        define: {},\r\n        query: {},\r\n        sync: {},\r\n        timezone: \"+00:00\",\r\n        clientMinMessages: \"warning\",\r\n        standardConformingStrings: true,\r\n        // eslint-disable-next-line no-console\r\n        logging: console.log,\r\n        omitNull: false,\r\n        native: false,\r\n        replication: false,\r\n        ssl: undefined,\r\n        pool: {},\r\n        quoteIdentifiers: true,\r\n        hooks: {},\r\n        retry: {\r\n          max: 5,\r\n          match: [\"SQLITE_BUSY: database is locked\"]\r\n        },\r\n        transactionType: Transaction.TYPES.DEFERRED,\r\n        isolationLevel: null,\r\n        databaseVersion: 0,\r\n        typeValidation: false,\r\n        benchmark: false,\r\n        minifyAliases: false,\r\n        logQueryParameters: false\r\n      },\r\n      options || {}\r\n    );\r\n\r\n    if (!this.options.dialect) {\r\n      throw new Error(\"Dialect needs to be explicitly supplied as of v4.0.0\");\r\n    }\r\n\r\n    if (this.options.dialect === \"postgresql\") {\r\n      this.options.dialect = \"postgres\";\r\n    }\r\n\r\n    if (\r\n      this.options.dialect === \"sqlite\" &&\r\n      this.options.timezone !== \"+00:00\"\r\n    ) {\r\n      throw new Error(\r\n        \"Setting a custom timezone is not supported by SQLite, dates are always returned as UTC. Please remove the custom timezone parameter.\"\r\n      );\r\n    }\r\n\r\n    if (this.options.logging === true) {\r\n      deprecations.noTrueLogging();\r\n      // eslint-disable-next-line no-console\r\n      this.options.logging = console.log;\r\n    }\r\n\r\n    this._setupHooks(options.hooks);\r\n\r\n    this.config = {\r\n      database: config.database || this.options.database,\r\n      username: config.username || this.options.username,\r\n      password: config.password || this.options.password || null,\r\n      host: config.host || this.options.host,\r\n      port: config.port || this.options.port,\r\n      pool: this.options.pool,\r\n      protocol: this.options.protocol,\r\n      native: this.options.native,\r\n      ssl: this.options.ssl,\r\n      replication: this.options.replication,\r\n      dialectModule: this.options.dialectModule,\r\n      dialectModulePath: this.options.dialectModulePath,\r\n      keepDefaultTimezone: this.options.keepDefaultTimezone,\r\n      dialectOptions: this.options.dialectOptions\r\n    };\r\n\r\n    let Dialect;\r\n    // Requiring the dialect in a switch-case to keep the\r\n    // require calls static. (Browserify fix)\r\n    switch (this.getDialect()) {\r\n      case \"sqlite\":\r\n        // eslint-disable-next-line\r\n        Dialect = require(\"./dialects/sqlite\");\r\n        break;\r\n      default:\r\n        throw new Error(\r\n          `The dialect ${this.getDialect()} is not supported. Supported dialects: sqlite.`\r\n        );\r\n    }\r\n\r\n    this.dialect = new Dialect(this);\r\n    this.dialect.QueryGenerator.typeValidation = options.typeValidation;\r\n\r\n    if (_.isPlainObject(this.options.operatorsAliases)) {\r\n      deprecations.noStringOperators();\r\n      this.dialect.QueryGenerator.setOperatorsAliases(\r\n        this.options.operatorsAliases\r\n      );\r\n    } else if (typeof this.options.operatorsAliases === \"boolean\") {\r\n      deprecations.noBoolOperatorAliases();\r\n    }\r\n\r\n    this.queryInterface = new QueryInterface(this);\r\n\r\n    /**\r\n     * Models are stored here under the name given to `sequelize.define`\r\n     */\r\n    this.models = {};\r\n    this.modelManager = new ModelManager(this);\r\n    this.connectionManager = this.dialect.connectionManager;\r\n\r\n    this.importCache = {};\r\n\r\n    Sequelize.runHooks(\"afterInit\", this);\r\n  }\r\n\r\n  /**\r\n   * Refresh data types and parsers.\r\n   *\r\n   * @private\r\n   */\r\n  refreshTypes() {\r\n    this.connectionManager.refreshTypeParser(DataTypes);\r\n  }\r\n\r\n  /**\r\n   * Returns the specified dialect.\r\n   *\r\n   * @returns {string} The specified dialect.\r\n   */\r\n  getDialect() {\r\n    return this.options.dialect;\r\n  }\r\n\r\n  /**\r\n   * Returns the database name.\r\n   *\r\n   * @returns {string} The database name.\r\n   */\r\n  getDatabaseName() {\r\n    return this.config.database;\r\n  }\r\n\r\n  /**\r\n   * Returns an instance of QueryInterface.\r\n   *\r\n   * @returns {QueryInterface} An instance (singleton) of QueryInterface.\r\n   */\r\n  getQueryInterface() {\r\n    this.queryInterface = this.queryInterface || new QueryInterface(this);\r\n    return this.queryInterface;\r\n  }\r\n\r\n  /**\r\n   * Define a new model, representing a table in the database.\r\n   *\r\n   * The table columns are defined by the object that is given as the second argument. Each key of the object represents a column\r\n   *\r\n   * @param {string} modelName The name of the model. The model will be stored in `sequelize.models` under this name\r\n   * @param {Object} attributes An object, where each attribute is a column of the table. See {@link Model.init}\r\n   * @param {Object} [options] These options are merged with the default define options provided to the Sequelize constructor and passed to Model.init()\r\n   *\r\n   * @see\r\n   * {@link Model.init} for a more comprehensive specification of the `options` and `attributes` objects.\r\n   * @see <a href=\"/manual/tutorial/models-definition.html\">Model definition</a> Manual related to model definition\r\n   * @see\r\n   * {@link DataTypes} For a list of possible data types\r\n   *\r\n   * @returns {Model} Newly defined model\r\n   *\r\n   * @example\r\n   * sequelize.define('modelName', {\r\n   *   columnA: {\r\n   *       type: Sequelize.BOOLEAN,\r\n   *       validate: {\r\n   *         is: [\"[a-z]\",'i'],        // will only allow letters\r\n   *         max: 23,                  // only allow values <= 23\r\n   *         isIn: {\r\n   *           args: [['en', 'zh']],\r\n   *           msg: \"Must be English or Chinese\"\r\n   *         }\r\n   *       },\r\n   *       field: 'column_a'\r\n   *   },\r\n   *   columnB: Sequelize.STRING,\r\n   *   columnC: 'MY VERY OWN COLUMN TYPE'\r\n   * });\r\n   *\r\n   * sequelize.models.modelName // The model will now be available in models under the name given to define\r\n   */\r\n  define(modelName, attributes, options = {}) {\r\n    options.modelName = modelName;\r\n    options.sequelize = this;\r\n\r\n    const model = class extends Model {};\r\n\r\n    model.init(attributes, options);\r\n\r\n    return model;\r\n  }\r\n\r\n  /**\r\n   * Fetch a Model which is already defined\r\n   *\r\n   * @param {string} modelName The name of a model defined with Sequelize.define\r\n   *\r\n   * @throws Will throw an error if the model is not defined (that is, if sequelize#isDefined returns false)\r\n   * @returns {Model} Specified model\r\n   */\r\n  model(modelName) {\r\n    if (!this.isDefined(modelName)) {\r\n      throw new Error(`${modelName} has not been defined`);\r\n    }\r\n\r\n    return this.modelManager.getModel(modelName);\r\n  }\r\n\r\n  /**\r\n   * Checks whether a model with the given name is defined\r\n   *\r\n   * @param {string} modelName The name of a model defined with Sequelize.define\r\n   *\r\n   * @returns {boolean} Returns true if model is already defined, otherwise false\r\n   */\r\n  isDefined(modelName) {\r\n    return !!this.modelManager.models.find(model => model.name === modelName);\r\n  }\r\n\r\n  /**\r\n   * Imports a model defined in another file. Imported models are cached, so multiple\r\n   * calls to import with the same path will not load the file multiple times.\r\n   *\r\n   * @tutorial https://github.com/sequelize/express-example\r\n   *\r\n   * @param {string} importPath The path to the file that holds the model you want to import. If the part is relative, it will be resolved relatively to the calling file\r\n   *\r\n   * @returns {Model} Imported model, returned from cache if was already imported\r\n   */\r\n  import(importPath) {}\r\n\r\n  /**\r\n   * Execute a query on the DB, optionally bypassing all the Sequelize goodness.\r\n   *\r\n   * By default, the function will return two arguments: an array of results, and a metadata object, containing number of affected rows etc.\r\n   *\r\n   * If you are running a type of query where you don't need the metadata, for example a `SELECT` query, you can pass in a query type to make sequelize format the results:\r\n   *\r\n   * ```js\r\n   * sequelize.query('SELECT...').then(([results, metadata]) => {\r\n   *   // Raw query - use then plus array spread\r\n   * });\r\n   *\r\n   * sequelize.query('SELECT...', { type: sequelize.QueryTypes.SELECT }).then(results => {\r\n   *   // SELECT query - use then\r\n   * })\r\n   * ```\r\n   *\r\n   * @param {string}          sql\r\n   * @param {Object}          [options={}] Query options.\r\n   * @param {boolean}         [options.raw] If true, sequelize will not try to format the results of the query, or build an instance of a model from the result\r\n   * @param {Transaction}     [options.transaction=null] The transaction that the query should be executed under\r\n   * @param {QueryTypes}      [options.type='RAW'] The type of query you are executing. The query type affects how results are formatted before they are passed back. The type is a string, but `Sequelize.QueryTypes` is provided as convenience shortcuts.\r\n   * @param {boolean}         [options.nest=false] If true, transforms objects with `.` separated property names into nested objects using [dottie.js](https://github.com/mickhansen/dottie.js). For example { 'user.username': 'john' } becomes { user: { username: 'john' }}. When `nest` is true, the query type is assumed to be `'SELECT'`, unless otherwise specified\r\n   * @param {boolean}         [options.plain=false] Sets the query type to `SELECT` and return a single row\r\n   * @param {Object|Array}    [options.replacements] Either an object of named parameter replacements in the format `:param` or an array of unnamed replacements to replace `?` in your SQL.\r\n   * @param {Object|Array}    [options.bind] Either an object of named bind parameter in the format `_param` or an array of unnamed bind parameter to replace `$1, $2, ...` in your SQL.\r\n   * @param {boolean}         [options.useMaster=false] Force the query to use the write pool, regardless of the query type.\r\n   * @param {Function}        [options.logging=false] A function that gets executed while running the query to log the sql.\r\n   * @param {new Model()}     [options.instance] A sequelize instance used to build the return instance\r\n   * @param {Model}           [options.model] A sequelize model used to build the returned model instances (used to be called callee)\r\n   * @param {Object}          [options.retry] Set of flags that control when a query is automatically retried.\r\n   * @param {Array}           [options.retry.match] Only retry a query if the error matches one of these strings.\r\n   * @param {Integer}         [options.retry.max] How many times a failing query is automatically retried.\r\n   * @param {string}          [options.searchPath=DEFAULT] An optional parameter to specify the schema search_path (Postgres only)\r\n   * @param {boolean}         [options.supportsSearchPath] If false do not prepend the query with the search_path (Postgres only)\r\n   * @param {boolean}         [options.mapToModel=false] Map returned fields to model's fields if `options.model` or `options.instance` is present. Mapping will occur before building the model instance.\r\n   * @param {Object}          [options.fieldMap] Map returned fields to arbitrary names for `SELECT` query type.\r\n   *\r\n   * @returns {Promise}\r\n   *\r\n   * @see {@link Model.build} for more information about instance option.\r\n   */\r\n\r\n  query(sql, options) {\r\n    options = Object.assign({}, this.options.query, options);\r\n\r\n    if (options.instance && !options.model) {\r\n      options.model = options.instance.constructor;\r\n    }\r\n\r\n    if (!options.instance && !options.model) {\r\n      options.raw = true;\r\n    }\r\n\r\n    // map raw fields to model attributes\r\n    if (options.mapToModel) {\r\n      options.fieldMap = _.get(options, \"model.fieldAttributeMap\", {});\r\n    }\r\n\r\n    options = _.defaults(options, {\r\n      // eslint-disable-next-line no-console\r\n      logging: Object.prototype.hasOwnProperty.call(this.options, \"logging\")\r\n        ? this.options.logging\r\n        : console.log,\r\n      searchPath: Object.prototype.hasOwnProperty.call(\r\n        this.options,\r\n        \"searchPath\"\r\n      )\r\n        ? this.options.searchPath\r\n        : \"DEFAULT\"\r\n    });\r\n\r\n    if (!options.type) {\r\n      if (options.model || options.nest || options.plain) {\r\n        options.type = QueryTypes.SELECT;\r\n      } else {\r\n        options.type = QueryTypes.RAW;\r\n      }\r\n    }\r\n\r\n    //if dialect doesn't support search_path or dialect option\r\n    //to prepend searchPath is not true delete the searchPath option\r\n    if (\r\n      !this.dialect.supports.searchPath ||\r\n      !this.options.dialectOptions ||\r\n      !this.options.dialectOptions.prependSearchPath ||\r\n      options.supportsSearchPath === false\r\n    ) {\r\n      delete options.searchPath;\r\n    } else if (!options.searchPath) {\r\n      //if user wants to always prepend searchPath (dialectOptions.preprendSearchPath = true)\r\n      //then set to DEFAULT if none is provided\r\n      options.searchPath = \"DEFAULT\";\r\n    }\r\n\r\n    return Promise.try(() => {\r\n      if (typeof sql === \"object\") {\r\n        if (sql.values !== undefined) {\r\n          if (options.replacements !== undefined) {\r\n            throw new Error(\r\n              \"Both `sql.values` and `options.replacements` cannot be set at the same time\"\r\n            );\r\n          }\r\n          options.replacements = sql.values;\r\n        }\r\n\r\n        if (sql.bind !== undefined) {\r\n          if (options.bind !== undefined) {\r\n            throw new Error(\r\n              \"Both `sql.bind` and `options.bind` cannot be set at the same time\"\r\n            );\r\n          }\r\n          options.bind = sql.bind;\r\n        }\r\n\r\n        if (sql.query !== undefined) {\r\n          sql = sql.query;\r\n        }\r\n      }\r\n\r\n      sql = sql.trim();\r\n\r\n      if (options.replacements && options.bind) {\r\n        throw new Error(\r\n          \"Both `replacements` and `bind` cannot be set at the same time\"\r\n        );\r\n      }\r\n\r\n      if (options.replacements) {\r\n        if (Array.isArray(options.replacements)) {\r\n          sql = Utils.format(\r\n            [sql].concat(options.replacements),\r\n            this.options.dialect\r\n          );\r\n        } else {\r\n          sql = Utils.formatNamedParameters(\r\n            sql,\r\n            options.replacements,\r\n            this.options.dialect\r\n          );\r\n        }\r\n      }\r\n\r\n      let bindParameters;\r\n\r\n      if (options.bind) {\r\n        [sql, bindParameters] = this.dialect.Query.formatBindParameters(\r\n          sql,\r\n          options.bind,\r\n          this.options.dialect\r\n        );\r\n      }\r\n\r\n      const checkTransaction = () => {\r\n        if (\r\n          options.transaction &&\r\n          options.transaction.finished &&\r\n          !options.completesTransaction\r\n        ) {\r\n          const error = new Error(\r\n            `${options.transaction.finished} has been called on this transaction(${options.transaction.id}), you can no longer use it. (The rejected query is attached as the 'sql' property of this error)`\r\n          );\r\n          error.sql = sql;\r\n          throw error;\r\n        }\r\n      };\r\n\r\n      const retryOptions = Object.assign(\r\n        {},\r\n        this.options.retry,\r\n        options.retry || {}\r\n      );\r\n\r\n      return Promise.resolve(\r\n        retry(\r\n          () =>\r\n            Promise.try(() => {\r\n              if (options.transaction === undefined && Sequelize._cls) {\r\n                options.transaction = Sequelize._cls.get(\"transaction\");\r\n              }\r\n\r\n              checkTransaction();\r\n\r\n              return options.transaction\r\n                ? options.transaction.connection\r\n                : this.connectionManager.getConnection(options);\r\n            }).then(connection => {\r\n              const query = new this.dialect.Query(connection, this, options);\r\n              return this.runHooks(\"beforeQuery\", options, query)\r\n                .then(() => checkTransaction())\r\n                .then(() => query.run(sql, bindParameters))\r\n                .finally(() => this.runHooks(\"afterQuery\", options, query))\r\n                .finally(() => {\r\n                  if (!options.transaction) {\r\n                    return this.connectionManager.releaseConnection(connection);\r\n                  }\r\n                });\r\n            }),\r\n          retryOptions\r\n        )\r\n      );\r\n    });\r\n  }\r\n\r\n  /**\r\n   * Execute a query which would set an environment or user variable. The variables are set per connection, so this function needs a transaction.\r\n   * Only works for MySQL.\r\n   *\r\n   * @param {Object}        variables Object with multiple variables.\r\n   * @param {Object}        [options] query options.\r\n   * @param {Transaction}   [options.transaction] The transaction that the query should be executed under\r\n   *\r\n   * @memberof Sequelize\r\n   *\r\n   * @returns {Promise}\r\n   */\r\n  set(variables, options) {\r\n    // Prepare options\r\n    options = Object.assign(\r\n      {},\r\n      this.options.set,\r\n      typeof options === \"object\" && options\r\n    );\r\n\r\n    if (this.options.dialect !== \"mysql\") {\r\n      throw new Error(\"sequelize.set is only supported for mysql\");\r\n    }\r\n    if (!options.transaction || !(options.transaction instanceof Transaction)) {\r\n      throw new TypeError(\"options.transaction is required\");\r\n    }\r\n\r\n    // Override some options, since this isn't a SELECT\r\n    options.raw = true;\r\n    options.plain = true;\r\n    options.type = \"SET\";\r\n\r\n    // Generate SQL Query\r\n    const query = `SET ${_.map(\r\n      variables,\r\n      (v, k) => `@${k} := ${typeof v === \"string\" ? `\"${v}\"` : v}`\r\n    ).join(\", \")}`;\r\n\r\n    return this.query(query, options);\r\n  }\r\n\r\n  /**\r\n   * Escape value.\r\n   *\r\n   * @param {string} value string value to escape\r\n   *\r\n   * @returns {string}\r\n   */\r\n  escape(value) {\r\n    return this.getQueryInterface().escape(value);\r\n  }\r\n\r\n  /**\r\n   * Create a new database schema.\r\n   *\r\n   * **Note:** this is a schema in the [postgres sense of the word](http://www.postgresql.org/docs/9.1/static/ddl-schemas.html),\r\n   * not a database table. In mysql and sqlite, this command will do nothing.\r\n   *\r\n   * @see\r\n   * {@link Model.schema}\r\n   *\r\n   * @param {string} schema Name of the schema\r\n   * @param {Object} [options={}] query options\r\n   * @param {boolean|Function} [options.logging] A function that logs sql queries, or false for no logging\r\n   *\r\n   * @returns {Promise}\r\n   */\r\n  createSchema(schema, options) {\r\n    return this.getQueryInterface().createSchema(schema, options);\r\n  }\r\n\r\n  /**\r\n   * Show all defined schemas\r\n   *\r\n   * **Note:** this is a schema in the [postgres sense of the word](http://www.postgresql.org/docs/9.1/static/ddl-schemas.html),\r\n   * not a database table. In mysql and sqlite, this will show all tables.\r\n   *\r\n   * @param {Object} [options={}] query options\r\n   * @param {boolean|Function} [options.logging] A function that logs sql queries, or false for no logging\r\n   *\r\n   * @returns {Promise}\r\n   */\r\n  showAllSchemas(options) {\r\n    return this.getQueryInterface().showAllSchemas(options);\r\n  }\r\n\r\n  /**\r\n   * Drop a single schema\r\n   *\r\n   * **Note:** this is a schema in the [postgres sense of the word](http://www.postgresql.org/docs/9.1/static/ddl-schemas.html),\r\n   * not a database table. In mysql and sqlite, this drop a table matching the schema name\r\n   *\r\n   * @param {string} schema Name of the schema\r\n   * @param {Object} [options={}] query options\r\n   * @param {boolean|Function} [options.logging] A function that logs sql queries, or false for no logging\r\n   *\r\n   * @returns {Promise}\r\n   */\r\n  dropSchema(schema, options) {\r\n    return this.getQueryInterface().dropSchema(schema, options);\r\n  }\r\n\r\n  /**\r\n   * Drop all schemas.\r\n   *\r\n   * **Note:** this is a schema in the [postgres sense of the word](http://www.postgresql.org/docs/9.1/static/ddl-schemas.html),\r\n   * not a database table. In mysql and sqlite, this is the equivalent of drop all tables.\r\n   *\r\n   * @param {Object} [options={}] query options\r\n   * @param {boolean|Function} [options.logging] A function that logs sql queries, or false for no logging\r\n   *\r\n   * @returns {Promise}\r\n   */\r\n  dropAllSchemas(options) {\r\n    return this.getQueryInterface().dropAllSchemas(options);\r\n  }\r\n\r\n  /**\r\n   * Sync all defined models to the DB.\r\n   *\r\n   * @param {Object} [options={}] sync options\r\n   * @param {boolean} [options.force=false] If force is true, each Model will run `DROP TABLE IF EXISTS`, before it tries to create its own table\r\n   * @param {RegExp} [options.match] Match a regex against the database name before syncing, a safety check for cases where force: true is used in tests but not live code\r\n   * @param {boolean|Function} [options.logging=console.log] A function that logs sql queries, or false for no logging\r\n   * @param {string} [options.schema='public'] The schema that the tables should be created in. This can be overridden for each table in sequelize.define\r\n   * @param {string} [options.searchPath=DEFAULT] An optional parameter to specify the schema search_path (Postgres only)\r\n   * @param {boolean} [options.hooks=true] If hooks is true then beforeSync, afterSync, beforeBulkSync, afterBulkSync hooks will be called\r\n   * @param {boolean} [options.alter=false] Alters tables to fit models. Not recommended for production use. Deletes data in columns that were removed or had their type changed in the model.\r\n   *\r\n   * @returns {Promise}\r\n   */\r\n  sync(options) {\r\n    options = _.clone(options) || {};\r\n    options.hooks = options.hooks === undefined ? true : !!options.hooks;\r\n    options = _.defaults(options, this.options.sync, this.options);\r\n\r\n    if (options.match) {\r\n      if (!options.match.test(this.config.database)) {\r\n        return Promise.reject(\r\n          new Error(\r\n            `Database \"${this.config.database}\" does not match sync match parameter \"${options.match}\"`\r\n          )\r\n        );\r\n      }\r\n    }\r\n\r\n    return Promise.try(() => {\r\n      if (options.hooks) {\r\n        return this.runHooks(\"beforeBulkSync\", options);\r\n      }\r\n    })\r\n      .then(() => {\r\n        if (options.force) {\r\n          return this.drop(options);\r\n        }\r\n      })\r\n      .then(() => {\r\n        const models = [];\r\n\r\n        // Topologically sort by foreign key constraints to give us an appropriate\r\n        // creation order\r\n        this.modelManager.forEachModel(model => {\r\n          if (model) {\r\n            models.push(model);\r\n          } else {\r\n            // DB should throw an SQL error if referencing non-existent table\r\n          }\r\n        });\r\n\r\n        // no models defined, just authenticate\r\n        if (!models.length) return this.authenticate(options);\r\n\r\n        return Promise.each(models, model => model.sync(options));\r\n      })\r\n      .then(() => {\r\n        if (options.hooks) {\r\n          return this.runHooks(\"afterBulkSync\", options);\r\n        }\r\n      })\r\n      .return(this);\r\n  }\r\n\r\n  /**\r\n   * Truncate all tables defined through the sequelize models.\r\n   * This is done by calling `Model.truncate()` on each model.\r\n   *\r\n   * @param {Object} [options] The options passed to Model.destroy in addition to truncate\r\n   * @param {boolean|Function} [options.logging] A function that logs sql queries, or false for no logging\r\n   * @returns {Promise}\r\n   *\r\n   * @see\r\n   * {@link Model.truncate} for more information\r\n   */\r\n  truncate(options) {\r\n    const models = [];\r\n\r\n    this.modelManager.forEachModel(\r\n      model => {\r\n        if (model) {\r\n          models.push(model);\r\n        }\r\n      },\r\n      { reverse: false }\r\n    );\r\n\r\n    const truncateModel = model => model.truncate(options);\r\n\r\n    if (options && options.cascade) {\r\n      return Promise.each(models, truncateModel);\r\n    }\r\n    return Promise.map(models, truncateModel);\r\n  }\r\n\r\n  /**\r\n   * Drop all tables defined through this sequelize instance.\r\n   * This is done by calling Model.drop on each model.\r\n   *\r\n   * @see\r\n   * {@link Model.drop} for options\r\n   *\r\n   * @param {Object} [options] The options passed to each call to Model.drop\r\n   * @param {boolean|Function} [options.logging] A function that logs sql queries, or false for no logging\r\n   *\r\n   * @returns {Promise}\r\n   */\r\n  drop(options) {\r\n    const models = [];\r\n\r\n    this.modelManager.forEachModel(\r\n      model => {\r\n        if (model) {\r\n          models.push(model);\r\n        }\r\n      },\r\n      { reverse: false }\r\n    );\r\n\r\n    return Promise.each(models, model => model.drop(options));\r\n  }\r\n\r\n  /**\r\n   * Test the connection by trying to authenticate. It runs `SELECT 1+1 AS result` query.\r\n   *\r\n   * @param {Object} [options={}] query options\r\n   *\r\n   * @returns {Promise}\r\n   */\r\n  authenticate(options) {\r\n    options = Object.assign(\r\n      {\r\n        raw: true,\r\n        plain: true,\r\n        type: QueryTypes.SELECT\r\n      },\r\n      options\r\n    );\r\n\r\n    return this.query(\"SELECT 1+1 AS result\", options).return();\r\n  }\r\n\r\n  databaseVersion(options) {\r\n    return this.getQueryInterface().databaseVersion(options);\r\n  }\r\n\r\n  /**\r\n   * Get the fn for random based on the dialect\r\n   *\r\n   * @returns {Sequelize.fn}\r\n   */\r\n  random() {\r\n    const dia = this.getDialect();\r\n    if (dia === \"postgres\" || dia === \"sqlite\") {\r\n      return this.fn(\"RANDOM\");\r\n    }\r\n    return this.fn(\"RAND\");\r\n  }\r\n\r\n  /**\r\n   * Creates an object representing a database function. This can be used in search queries, both in where and order parts, and as default values in column definitions.\r\n   * If you want to refer to columns in your function, you should use `sequelize.col`, so that the columns are properly interpreted as columns and not a strings.\r\n   *\r\n   * @see\r\n   * {@link Model.findAll}\r\n   * @see\r\n   * {@link Sequelize.define}\r\n   * @see\r\n   * {@link Sequelize.col}\r\n   *\r\n   * @param {string} fn The function you want to call\r\n   * @param {any} args All further arguments will be passed as arguments to the function\r\n   *\r\n   * @since v2.0.0-dev3\r\n   * @memberof Sequelize\r\n   * @returns {Sequelize.fn}\r\n   *\r\n   * @example <caption>Convert a user's username to upper case</caption>\r\n   * instance.update({\r\n   *   username: sequelize.fn('upper', sequelize.col('username'))\r\n   * });\r\n   */\r\n  static fn(fn, ...args) {\r\n    return new Utils.Fn(fn, args);\r\n  }\r\n\r\n  /**\r\n   * Creates an object which represents a column in the DB, this allows referencing another column in your query. This is often useful in conjunction with `sequelize.fn`, since raw string arguments to fn will be escaped.\r\n   *\r\n   * @see\r\n   * {@link Sequelize#fn}\r\n   *\r\n   * @param {string} col The name of the column\r\n   * @since v2.0.0-dev3\r\n   * @memberof Sequelize\r\n   *\r\n   * @returns {Sequelize.col}\r\n   */\r\n  static col(col) {\r\n    return new Utils.Col(col);\r\n  }\r\n\r\n  /**\r\n   * Creates an object representing a call to the cast function.\r\n   *\r\n   * @param {any} val The value to cast\r\n   * @param {string} type The type to cast it to\r\n   * @since v2.0.0-dev3\r\n   * @memberof Sequelize\r\n   *\r\n   * @returns {Sequelize.cast}\r\n   */\r\n  static cast(val, type) {\r\n    return new Utils.Cast(val, type);\r\n  }\r\n\r\n  /**\r\n   * Creates an object representing a literal, i.e. something that will not be escaped.\r\n   *\r\n   * @param {any} val literal value\r\n   * @since v2.0.0-dev3\r\n   * @memberof Sequelize\r\n   *\r\n   * @returns {Sequelize.literal}\r\n   */\r\n  static literal(val) {\r\n    return new Utils.Literal(val);\r\n  }\r\n\r\n  /**\r\n   * An AND query\r\n   *\r\n   * @see\r\n   * {@link Model.findAll}\r\n   *\r\n   * @param {...string|Object} args Each argument will be joined by AND\r\n   * @since v2.0.0-dev3\r\n   * @memberof Sequelize\r\n   *\r\n   * @returns {Sequelize.and}\r\n   */\r\n  static and(...args) {\r\n    return { [Op.and]: args };\r\n  }\r\n\r\n  /**\r\n   * An OR query\r\n   *\r\n   * @see\r\n   * {@link Model.findAll}\r\n   *\r\n   * @param {...string|Object} args Each argument will be joined by OR\r\n   * @since v2.0.0-dev3\r\n   * @memberof Sequelize\r\n   *\r\n   * @returns {Sequelize.or}\r\n   */\r\n  static or(...args) {\r\n    return { [Op.or]: args };\r\n  }\r\n\r\n  /**\r\n   * Creates an object representing nested where conditions for postgres/sqlite/mysql json data-type.\r\n   *\r\n   * @see\r\n   * {@link Model.findAll}\r\n   *\r\n   * @param {string|Object} conditionsOrPath A hash containing strings/numbers or other nested hash, a string using dot notation or a string using postgres/sqlite/mysql json syntax.\r\n   * @param {string|number|boolean} [value] An optional value to compare against. Produces a string of the form \"<json path> = '<value>'\".\r\n   * @memberof Sequelize\r\n   *\r\n   * @returns {Sequelize.json}\r\n   */\r\n  static json(conditionsOrPath, value) {\r\n    return new Utils.Json(conditionsOrPath, value);\r\n  }\r\n\r\n  /**\r\n   * A way of specifying attr = condition.\r\n   *\r\n   * The attr can either be an object taken from `Model.rawAttributes` (for example `Model.rawAttributes.id` or `Model.rawAttributes.name`). The\r\n   * attribute should be defined in your model definition. The attribute can also be an object from one of the sequelize utility functions (`sequelize.fn`, `sequelize.col` etc.)\r\n   *\r\n   * For string attributes, use the regular `{ where: { attr: something }}` syntax. If you don't want your string to be escaped, use `sequelize.literal`.\r\n   *\r\n   * @see\r\n   * {@link Model.findAll}\r\n   *\r\n   * @param {Object} attr The attribute, which can be either an attribute object from `Model.rawAttributes` or a sequelize object, for example an instance of `sequelize.fn`. For simple string attributes, use the POJO syntax\r\n   * @param {Symbol} [comparator='Op.eq'] operator\r\n   * @param {string|Object} logic The condition. Can be both a simply type, or a further condition (`or`, `and`, `.literal` etc.)\r\n   * @since v2.0.0-dev3\r\n   */\r\n  static where(attr, comparator, logic) {\r\n    return new Utils.Where(attr, comparator, logic);\r\n  }\r\n\r\n  /**\r\n   * Start a transaction. When using transactions, you should pass the transaction in the options argument in order for the query to happen under that transaction @see {@link Transaction}\r\n   *\r\n   * If you have [CLS](https://github.com/othiym23/node-continuation-local-storage) enabled, the transaction will automatically be passed to any query that runs within the callback\r\n   *\r\n   * @example\r\n   * sequelize.transaction().then(transaction => {\r\n   *   return User.findOne(..., {transaction})\r\n   *     .then(user => user.update(..., {transaction}))\r\n   *     .then(() => transaction.commit())\r\n   *     .catch(() => transaction.rollback());\r\n   * })\r\n   *\r\n   * @example <caption>A syntax for automatically committing or rolling back based on the promise chain resolution is also supported</caption>\r\n   *\r\n   * sequelize.transaction(transaction => { // Note that we use a callback rather than a promise.then()\r\n   *   return User.findOne(..., {transaction})\r\n   *     .then(user => user.update(..., {transaction}))\r\n   * }).then(() => {\r\n   *   // Committed\r\n   * }).catch(err => {\r\n   *   // Rolled back\r\n   *   console.error(err);\r\n   * });\r\n   *\r\n   * @example <caption>To enable CLS, add it do your project, create a namespace and set it on the sequelize constructor:</caption>\r\n   *\r\n   * const cls = require('continuation-local-storage');\r\n   * const ns = cls.createNamespace('....');\r\n   * const Sequelize = require('sequelize');\r\n   * Sequelize.useCLS(ns);\r\n   *\r\n   * // Note, that CLS is enabled for all sequelize instances, and all instances will share the same namespace\r\n   *\r\n   * @param {Object}   [options] Transaction options\r\n   * @param {string}   [options.type='DEFERRED'] See `Sequelize.Transaction.TYPES` for possible options. Sqlite only.\r\n   * @param {string}   [options.isolationLevel] See `Sequelize.Transaction.ISOLATION_LEVELS` for possible options\r\n   * @param {string}   [options.deferrable] Sets the constraints to be deferred or immediately checked. See `Sequelize.Deferrable`. PostgreSQL Only\r\n   * @param {Function} [options.logging=false] A function that gets executed while running the query to log the sql.\r\n   * @param {Function} [autoCallback] The callback is called with the transaction object, and should return a promise. If the promise is resolved, the transaction commits; if the promise rejects, the transaction rolls back\r\n   *\r\n   * @returns {Promise}\r\n   */\r\n  transaction(options, autoCallback) {\r\n    if (typeof options === \"function\") {\r\n      autoCallback = options;\r\n      options = undefined;\r\n    }\r\n\r\n    const transaction = new Transaction(this, options);\r\n\r\n    if (!autoCallback)\r\n      return transaction.prepareEnvironment(false).return(transaction);\r\n\r\n    // autoCallback provided\r\n    return Sequelize._clsRun(() => {\r\n      return transaction\r\n        .prepareEnvironment()\r\n        .then(() => autoCallback(transaction))\r\n        .tap(() => transaction.commit())\r\n        .catch(err => {\r\n          // Rollback transaction if not already finished (commit, rollback, etc)\r\n          // and reject with original error (ignore any error in rollback)\r\n          return Promise.try(() => {\r\n            if (!transaction.finished)\r\n              return transaction.rollback().catch(() => {});\r\n          }).throw(err);\r\n        });\r\n    });\r\n  }\r\n\r\n  /**\r\n   * Use CLS with Sequelize.\r\n   * CLS namespace provided is stored as `Sequelize._cls`\r\n   * and bluebird Promise is patched to use the namespace, using `cls-bluebird` module.\r\n   *\r\n   * @param {Object} ns CLS namespace\r\n   * @returns {Object} Sequelize constructor\r\n   */\r\n  static useCLS(ns) {\r\n    // check `ns` is valid CLS namespace\r\n    if (\r\n      !ns ||\r\n      typeof ns !== \"object\" ||\r\n      typeof ns.bind !== \"function\" ||\r\n      typeof ns.run !== \"function\"\r\n    )\r\n      throw new Error(\"Must provide CLS namespace\");\r\n\r\n    // save namespace as `Sequelize._cls`\r\n    this._cls = ns;\r\n\r\n    // patch bluebird to bind all promise callbacks to CLS namespace\r\n    clsBluebird(ns, Promise);\r\n\r\n    // return Sequelize for chaining\r\n    return this;\r\n  }\r\n\r\n  /**\r\n   * Run function in CLS context.\r\n   * If no CLS context in use, just runs the function normally\r\n   *\r\n   * @private\r\n   * @param {Function} fn Function to run\r\n   * @returns {*} Return value of function\r\n   */\r\n  static _clsRun(fn) {\r\n    const ns = Sequelize._cls;\r\n    if (!ns) return fn();\r\n\r\n    let res;\r\n    ns.run(context => (res = fn(context)));\r\n    return res;\r\n  }\r\n\r\n  log(...args) {\r\n    let options;\r\n\r\n    const last = _.last(args);\r\n\r\n    if (\r\n      last &&\r\n      _.isPlainObject(last) &&\r\n      Object.prototype.hasOwnProperty.call(last, \"logging\")\r\n    ) {\r\n      options = last;\r\n\r\n      // remove options from set of logged arguments if options.logging is equal to console.log\r\n      // eslint-disable-next-line no-console\r\n      if (options.logging === console.log) {\r\n        args.splice(args.length - 1, 1);\r\n      }\r\n    } else {\r\n      options = this.options;\r\n    }\r\n\r\n    if (options.logging) {\r\n      if (options.logging === true) {\r\n        deprecations.noTrueLogging();\r\n        // eslint-disable-next-line no-console\r\n        options.logging = console.log;\r\n      }\r\n\r\n      // second argument is sql-timings, when benchmarking option enabled\r\n      // eslint-disable-next-line no-console\r\n      if (\r\n        (this.options.benchmark || options.benchmark) &&\r\n        options.logging === console.log\r\n      ) {\r\n        args = [`${args[0]} Elapsed time: ${args[1]}ms`];\r\n      }\r\n\r\n      options.logging(...args);\r\n    }\r\n  }\r\n\r\n  /**\r\n   * Close all connections used by this sequelize instance, and free all references so the instance can be garbage collected.\r\n   *\r\n   * Normally this is done on process exit, so you only need to call this method if you are creating multiple instances, and want\r\n   * to garbage collect some of them.\r\n   *\r\n   * @returns {Promise}\r\n   */\r\n  close() {\r\n    return this.connectionManager.close();\r\n  }\r\n\r\n  normalizeDataType(Type) {\r\n    let type = typeof Type === \"function\" ? new Type() : Type;\r\n    const dialectTypes = this.dialect.DataTypes || {};\r\n\r\n    if (dialectTypes[type.key]) {\r\n      type = dialectTypes[type.key].extend(type);\r\n    }\r\n\r\n    if (type instanceof DataTypes.ARRAY) {\r\n      if (!type.type) {\r\n        throw new Error(\"ARRAY is missing type definition for its values.\");\r\n      }\r\n      if (dialectTypes[type.type.key]) {\r\n        type.type = dialectTypes[type.type.key].extend(type.type);\r\n      }\r\n    }\r\n\r\n    return type;\r\n  }\r\n\r\n  normalizeAttribute(attribute) {\r\n    if (!_.isPlainObject(attribute)) {\r\n      attribute = { type: attribute };\r\n    }\r\n\r\n    if (!attribute.type) return attribute;\r\n\r\n    attribute.type = this.normalizeDataType(attribute.type);\r\n\r\n    if (Object.prototype.hasOwnProperty.call(attribute, \"defaultValue\")) {\r\n      if (\r\n        typeof attribute.defaultValue === \"function\" &&\r\n        (attribute.defaultValue === DataTypes.NOW ||\r\n          attribute.defaultValue === DataTypes.UUIDV1 ||\r\n          attribute.defaultValue === DataTypes.UUIDV4)\r\n      ) {\r\n        attribute.defaultValue = new attribute.defaultValue();\r\n      }\r\n    }\r\n\r\n    if (attribute.type instanceof DataTypes.ENUM) {\r\n      // The ENUM is a special case where the type is an object containing the values\r\n      if (attribute.values) {\r\n        attribute.type.values = attribute.type.options.values =\r\n          attribute.values;\r\n      } else {\r\n        attribute.values = attribute.type.values;\r\n      }\r\n\r\n      if (!attribute.values.length) {\r\n        throw new Error(\"Values for ENUM have not been defined.\");\r\n      }\r\n    }\r\n\r\n    return attribute;\r\n  }\r\n}\r\n\r\n// Aliases\r\nSequelize.prototype.fn = Sequelize.fn;\r\nSequelize.prototype.col = Sequelize.col;\r\nSequelize.prototype.cast = Sequelize.cast;\r\nSequelize.prototype.literal = Sequelize.literal;\r\nSequelize.prototype.and = Sequelize.and;\r\nSequelize.prototype.or = Sequelize.or;\r\nSequelize.prototype.json = Sequelize.json;\r\nSequelize.prototype.where = Sequelize.where;\r\nSequelize.prototype.validate = Sequelize.prototype.authenticate;\r\n\r\n/**\r\n * Sequelize version number.\r\n */\r\nSequelize.version = require(\"../package.json\").version;\r\n\r\nSequelize.options = { hooks: {} };\r\n\r\n/**\r\n * @private\r\n */\r\nSequelize.Utils = Utils;\r\n\r\n/**\r\n * Operators symbols to be used for querying data\r\n * @see  {@link Operators}\r\n */\r\nSequelize.Op = Op;\r\n\r\n/**\r\n * A handy reference to the bluebird Promise class\r\n */\r\nSequelize.Promise = Promise;\r\n\r\n/**\r\n * Available table hints to be used for querying data in mssql for table hints\r\n * @see {@link TableHints}\r\n */\r\nSequelize.TableHints = TableHints;\r\n\r\n/**\r\n * Available index hints to be used for querying data in mysql for index hints\r\n * @see {@link IndexHints}\r\n */\r\nSequelize.IndexHints = IndexHints;\r\n\r\n/**\r\n * A reference to the sequelize transaction class. Use this to access isolationLevels and types when creating a transaction\r\n * @see {@link Transaction}\r\n * @see {@link Sequelize.transaction}\r\n */\r\nSequelize.Transaction = Transaction;\r\n\r\n/**\r\n * A reference to Sequelize constructor from sequelize. Useful for accessing DataTypes, Errors etc.\r\n * @see {@link Sequelize}\r\n */\r\nSequelize.prototype.Sequelize = Sequelize;\r\n\r\n/**\r\n * Available query types for use with `sequelize.query`\r\n * @see {@link QueryTypes}\r\n */\r\nSequelize.prototype.QueryTypes = Sequelize.QueryTypes = QueryTypes;\r\n\r\n/**\r\n * Exposes the validator.js object, so you can extend it with custom validation functions. The validator is exposed both on the instance, and on the constructor.\r\n * @see https://github.com/chriso/validator.js\r\n */\r\nSequelize.prototype.Validator = Sequelize.Validator = Validator;\r\n\r\nSequelize.Model = Model;\r\n\r\nSequelize.DataTypes = DataTypes;\r\nfor (const dataType in DataTypes) {\r\n  Sequelize[dataType] = DataTypes[dataType];\r\n}\r\n\r\n/**\r\n * A reference to the deferrable collection. Use this to access the different deferrable options.\r\n * @see {@link Transaction.Deferrable}\r\n * @see {@link Sequelize#transaction}\r\n */\r\nSequelize.Deferrable = Deferrable;\r\n\r\n/**\r\n * A reference to the sequelize association class.\r\n * @see {@link Association}\r\n */\r\nSequelize.prototype.Association = Sequelize.Association = Association;\r\n\r\n/**\r\n * Provide alternative version of `inflection` module to be used by `Utils.pluralize` etc.\r\n * @param {Object} _inflection - `inflection` module\r\n */\r\nSequelize.useInflection = Utils.useInflection;\r\n\r\n/**\r\n * Allow hooks to be defined on Sequelize + on sequelize instance as universal hooks to run on all models\r\n * and on Sequelize/sequelize methods e.g. Sequelize(), Sequelize#define()\r\n */\r\nHooks.applyTo(Sequelize);\r\nHooks.applyTo(Sequelize.prototype);\r\n\r\n/**\r\n * Expose various errors available\r\n */\r\n\r\n// expose alias to BaseError\r\nSequelize.Error = sequelizeErrors.BaseError;\r\n\r\nfor (const error of Object.keys(sequelizeErrors)) {\r\n  Sequelize[error] = sequelizeErrors[error];\r\n}\r\n\r\nmodule.exports = Sequelize;\r\nmodule.exports.Sequelize = Sequelize;\r\nmodule.exports.default = Sequelize;\r\n"]} \ No newline at end of file +//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../lib/sequelize.js"],"names":["retry","require","clsBluebird","_","Utils","Model","DataTypes","Deferrable","ModelManager","QueryInterface","Transaction","QueryTypes","TableHints","IndexHints","sequelizeErrors","Promise","Hooks","Association","Validator","validator","Op","deprecations","Sequelize","database","username","password","options","config","arguments","length","pick","runHooks","Object","assign","dialect","dialectModule","dialectModulePath","host","protocol","define","query","sync","timezone","clientMinMessages","standardConformingStrings","logging","console","log","omitNull","native","replication","ssl","undefined","pool","quoteIdentifiers","hooks","max","match","transactionType","TYPES","DEFERRED","isolationLevel","databaseVersion","typeValidation","benchmark","minifyAliases","logQueryParameters","Error","noTrueLogging","_setupHooks","port","keepDefaultTimezone","dialectOptions","Dialect","getDialect","QueryGenerator","isPlainObject","operatorsAliases","noStringOperators","setOperatorsAliases","noBoolOperatorAliases","queryInterface","models","modelManager","connectionManager","importCache","refreshTypeParser","modelName","attributes","sequelize","model","init","isDefined","getModel","find","name","importPath","sql","instance","constructor","raw","mapToModel","fieldMap","get","defaults","prototype","hasOwnProperty","call","searchPath","type","nest","plain","SELECT","RAW","supports","prependSearchPath","supportsSearchPath","try","values","replacements","bind","trim","Array","isArray","format","concat","formatNamedParameters","bindParameters","Query","formatBindParameters","checkTransaction","transaction","finished","completesTransaction","error","id","retryOptions","resolve","_cls","connection","getConnection","then","run","finally","releaseConnection","variables","set","TypeError","map","v","k","join","value","getQueryInterface","escape","schema","createSchema","showAllSchemas","dropSchema","dropAllSchemas","clone","test","reject","force","drop","forEachModel","push","authenticate","each","return","reverse","truncateModel","truncate","cascade","dia","fn","autoCallback","prepareEnvironment","_clsRun","tap","commit","catch","err","rollback","throw","args","last","splice","close","Type","dialectTypes","key","extend","ARRAY","attribute","normalizeDataType","defaultValue","NOW","UUIDV1","UUIDV4","ENUM","Fn","col","Col","val","Cast","Literal","and","or","conditionsOrPath","Json","attr","comparator","logic","Where","ns","res","context","cast","literal","json","where","validate","version","dataType","useInflection","applyTo","BaseError","keys","module","exports","default"],"mappings":"AAAA;;;;;;;;;;;;;;;;;;;;;;AACA,MAAMA,KAAK,GAAGC,OAAO,CAAC,mBAAD,CAArB;;AACA,MAAMC,WAAW,GAAGD,OAAO,CAAC,cAAD,CAA3B;;AACA,MAAME,CAAC,GAAGF,OAAO,CAAC,QAAD,CAAjB;;AAEA,MAAMG,KAAK,GAAGH,OAAO,CAAC,SAAD,CAArB;;AACA,MAAMI,KAAK,GAAGJ,OAAO,CAAC,SAAD,CAArB;;AACA,MAAMK,SAAS,GAAGL,OAAO,CAAC,cAAD,CAAzB;;AACA,MAAMM,UAAU,GAAGN,OAAO,CAAC,cAAD,CAA1B;;AACA,MAAMO,YAAY,GAAGP,OAAO,CAAC,iBAAD,CAA5B;;AACA,MAAMQ,cAAc,GAAGR,OAAO,CAAC,mBAAD,CAA9B;;AACA,MAAMS,WAAW,GAAGT,OAAO,CAAC,eAAD,CAA3B;;AACA,MAAMU,UAAU,GAAGV,OAAO,CAAC,eAAD,CAA1B;;AACA,MAAMW,UAAU,GAAGX,OAAO,CAAC,eAAD,CAA1B;;AACA,MAAMY,UAAU,GAAGZ,OAAO,CAAC,eAAD,CAA1B;;AACA,MAAMa,eAAe,GAAGb,OAAO,CAAC,UAAD,CAA/B;;AACA,MAAMc,OAAO,GAAGd,OAAO,CAAC,WAAD,CAAvB;;AACA,MAAMe,KAAK,GAAGf,OAAO,CAAC,SAAD,CAArB;;AACA,MAAMgB,WAAW,GAAGhB,OAAO,CAAC,sBAAD,CAA3B;;AACA,MAAMiB,SAAS,GAAGjB,OAAO,CAAC,0BAAD,CAAP,CAAoCkB,SAAtD;;AACA,MAAMC,EAAE,GAAGnB,OAAO,CAAC,aAAD,CAAlB;;AACA,MAAMoB,YAAY,GAAGpB,OAAO,CAAC,sBAAD,CAA5B;AAEA;AACA;AACA;;;IACMqB,S;AACJ;AACF;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACE,qBAAYC,QAAZ,EAAsBC,QAAtB,EAAgCC,QAAhC,EAA0CC,OAA1C,EAAmD;AAAA;;AACjD,QAAIC,MAAJ;;AAEA,QAAIC,SAAS,CAACC,MAAV,KAAqB,CAArB,IAA0B,OAAON,QAAP,KAAoB,QAAlD,EAA4D;AAC1D;AACAG,MAAAA,OAAO,GAAGH,QAAV;AACAI,MAAAA,MAAM,GAAGxB,CAAC,CAAC2B,IAAF,CACPJ,OADO,EAEP,MAFO,EAGP,MAHO,EAIP,UAJO,EAKP,UALO,EAMP,UANO,CAAT;AAQD,KAXD,MAWO,IACJE,SAAS,CAACC,MAAV,KAAqB,CAArB,IAA0B,OAAON,QAAP,KAAoB,QAA/C,IACCK,SAAS,CAACC,MAAV,KAAqB,CAArB,IAA0B,OAAOL,QAAP,KAAoB,QAF1C,EAGL;AACA;AAEAG,MAAAA,MAAM,GAAG,EAAT;AACAD,MAAAA,OAAO,GAAGF,QAAQ,IAAI,EAAtB;AACD,KARM,MAQA;AACL;AACAE,MAAAA,OAAO,GAAGA,OAAO,IAAI,EAArB;AACAC,MAAAA,MAAM,GAAG;AAAEJ,QAAAA,QAAF;AAAYC,QAAAA,QAAZ;AAAsBC,QAAAA;AAAtB,OAAT;AACD;;AAEDH,IAAAA,SAAS,CAACS,QAAV,CAAmB,YAAnB,EAAiCJ,MAAjC,EAAyCD,OAAzC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","sourcesContent":["\"use strict\";\nconst retry = require(\"retry-as-promised\");\nconst clsBluebird = require(\"cls-bluebird\");\nconst _ = require(\"lodash\");\n\nconst Utils = require(\"./utils\");\nconst Model = require(\"./model\");\nconst DataTypes = require(\"./data-types\");\nconst Deferrable = require(\"./deferrable\");\nconst ModelManager = require(\"./model-manager\");\nconst QueryInterface = require(\"./query-interface\");\nconst Transaction = require(\"./transaction\");\nconst QueryTypes = require(\"./query-types\");\nconst TableHints = require(\"./table-hints\");\nconst IndexHints = require(\"./index-hints\");\nconst sequelizeErrors = require(\"./errors\");\nconst Promise = require(\"./promise\");\nconst Hooks = require(\"./hooks\");\nconst Association = require(\"./associations/index\");\nconst Validator = require(\"./utils/validator-extras\").validator;\nconst Op = require(\"./operators\");\nconst deprecations = require(\"./utils/deprecations\");\n\n/**\n * This is the main class, the entry point to sequelize.\n */\nclass Sequelize {\n  /**\n   * Instantiate sequelize with name of database, username and password.\n   *\n   * @example\n   * // without password / with blank password\n   * const sequelize = new Sequelize('database', 'username', null, {\n   *   dialect: 'mysql'\n   * })\n   *\n   * // with password and options\n   * const sequelize = new Sequelize('my_database', 'john', 'doe', {\n   *   dialect: 'postgres'\n   * })\n   *\n   * // with database, username, and password in the options object\n   * const sequelize = new Sequelize({ database, username, password, dialect: 'mssql' });\n   *\n   * // with uri\n   * const sequelize = new Sequelize('mysql://localhost:3306/database', {})\n   *\n   * // option examples\n   * const sequelize = new Sequelize('database', 'username', 'password', {\n   *   // the sql dialect of the database\n   *   // currently supported: 'mysql', 'sqlite', 'postgres', 'mssql'\n   *   dialect: 'mysql',\n   *\n   *   // custom host; default: localhost\n   *   host: 'my.server.tld',\n   *   // for postgres, you can also specify an absolute path to a directory\n   *   // containing a UNIX socket to connect over\n   *   // host: '/sockets/psql_sockets'.\n   *\n   *   // custom port; default: dialect default\n   *   port: 12345,\n   *\n   *   // custom protocol; default: 'tcp'\n   *   // postgres only, useful for Heroku\n   *   protocol: null,\n   *\n   *   // disable logging or provide a custom logging function; default: console.log\n   *   logging: false,\n   *\n   *   // you can also pass any dialect options to the underlying dialect library\n   *   // - default is empty\n   *   // - currently supported: 'mysql', 'postgres', 'mssql'\n   *   dialectOptions: {\n   *     socketPath: '/Applications/MAMP/tmp/mysql/mysql.sock',\n   *     supportBigNumbers: true,\n   *     bigNumberStrings: true\n   *   },\n   *\n   *   // the storage engine for sqlite\n   *   // - default ':memory:'\n   *   storage: 'path/to/database.sqlite',\n   *\n   *   // disable inserting undefined values as NULL\n   *   // - default: false\n   *   omitNull: true,\n   *\n   *   // a flag for using a native library or not.\n   *   // in the case of 'pg' -- set this to true will allow SSL support\n   *   // - default: false\n   *   native: true,\n   *\n   *   // Specify options, which are used when sequelize.define is called.\n   *   // The following example:\n   *   //   define: { timestamps: false }\n   *   // is basically the same as:\n   *   //   Model.init(attributes, { timestamps: false });\n   *   //   sequelize.define(name, attributes, { timestamps: false });\n   *   // so defining the timestamps for each model will be not necessary\n   *   define: {\n   *     underscored: false,\n   *     freezeTableName: false,\n   *     charset: 'utf8',\n   *     dialectOptions: {\n   *       collate: 'utf8_general_ci'\n   *     },\n   *     timestamps: true\n   *   },\n   *\n   *   // similar for sync: you can define this to always force sync for models\n   *   sync: { force: true },\n   *\n   *   // pool configuration used to pool database connections\n   *   pool: {\n   *     max: 5,\n   *     idle: 30000,\n   *     acquire: 60000,\n   *   },\n   *\n   *   // isolation level of each transaction\n   *   // defaults to dialect default\n   *   isolationLevel: Transaction.ISOLATION_LEVELS.REPEATABLE_READ\n   * })\n   *\n   * @param {string}   [database] The name of the database\n   * @param {string}   [username=null] The username which is used to authenticate against the database.\n   * @param {string}   [password=null] The password which is used to authenticate against the database. Supports SQLCipher encryption for SQLite.\n   * @param {Object}   [options={}] An object with options.\n   * @param {string}   [options.host='localhost'] The host of the relational database.\n   * @param {number}   [options.port=] The port of the relational database.\n   * @param {string}   [options.username=null] The username which is used to authenticate against the database.\n   * @param {string}   [options.password=null] The password which is used to authenticate against the database.\n   * @param {string}   [options.database=null] The name of the database\n   * @param {string}   [options.dialect] The dialect of the database you are connecting to. One of mysql, postgres, sqlite and mssql.\n   * @param {string}   [options.dialectModule=null] If specified, use this dialect library. For example, if you want to use pg.js instead of pg when connecting to a pg database, you should specify 'require(\"pg.js\")' here\n   * @param {string}   [options.dialectModulePath=null] If specified, load the dialect library from this path. For example, if you want to use pg.js instead of pg when connecting to a pg database, you should specify '/path/to/pg.js' here\n   * @param {Object}   [options.dialectOptions] An object of additional options, which are passed directly to the connection library\n   * @param {string}   [options.storage] Only used by sqlite. Defaults to ':memory:'\n   * @param {string}   [options.protocol='tcp'] The protocol of the relational database.\n   * @param {Object}   [options.define={}] Default options for model definitions. See {@link Model.init}.\n   * @param {Object}   [options.query={}] Default options for sequelize.query\n   * @param {string}   [options.schema=null] A schema to use\n   * @param {Object}   [options.set={}] Default options for sequelize.set\n   * @param {Object}   [options.sync={}] Default options for sequelize.sync\n   * @param {string}   [options.timezone='+00:00'] The timezone used when converting a date from the database into a JavaScript date. The timezone is also used to SET TIMEZONE when connecting to the server, to ensure that the result of NOW, CURRENT_TIMESTAMP and other time related functions have in the right timezone. For best cross platform performance use the format +/-HH:MM. Will also accept string versions of timezones used by moment.js (e.g. 'America/Los_Angeles'); this is useful to capture daylight savings time changes.\n   * @param {string|boolean} [options.clientMinMessages='warning'] The PostgreSQL `client_min_messages` session parameter. Set to `false` to not override the database's default.\n   * @param {boolean}  [options.standardConformingStrings=true] The PostgreSQL `standard_conforming_strings` session parameter. Set to `false` to not set the option. WARNING: Setting this to false may expose vulnerabilities and is not recommended!\n   * @param {Function} [options.logging=console.log] A function that gets executed every time Sequelize would log something.\n   * @param {boolean}  [options.benchmark=false] Pass query execution time in milliseconds as second argument to logging function (options.logging).\n   * @param {boolean}  [options.omitNull=false] A flag that defines if null values should be passed to SQL queries or not.\n   * @param {boolean}  [options.native=false] A flag that defines if native library shall be used or not. Currently only has an effect for postgres\n   * @param {boolean}  [options.replication=false] Use read / write replication. To enable replication, pass an object, with two properties, read and write. Write should be an object (a single server for handling writes), and read an array of object (several servers to handle reads). Each read/write server can have the following properties: `host`, `port`, `username`, `password`, `database`\n   * @param {Object}   [options.pool] sequelize connection pool configuration\n   * @param {number}   [options.pool.max=5] Maximum number of connection in pool\n   * @param {number}   [options.pool.min=0] Minimum number of connection in pool\n   * @param {number}   [options.pool.idle=10000] The maximum time, in milliseconds, that a connection can be idle before being released.\n   * @param {number}   [options.pool.acquire=60000] The maximum time, in milliseconds, that pool will try to get connection before throwing error\n   * @param {number}   [options.pool.evict=1000] The time interval, in milliseconds, after which sequelize-pool will remove idle connections.\n   * @param {Function} [options.pool.validate] A function that validates a connection. Called with client. The default function checks that client is an object, and that its state is not disconnected\n   * @param {boolean}  [options.quoteIdentifiers=true] Set to `false` to make table names and attributes case-insensitive on Postgres and skip double quoting of them.  WARNING: Setting this to false may expose vulnerabilities and is not recommended!\n   * @param {string}   [options.transactionType='DEFERRED'] Set the default transaction type. See `Sequelize.Transaction.TYPES` for possible options. Sqlite only.\n   * @param {string}   [options.isolationLevel] Set the default transaction isolation level. See `Sequelize.Transaction.ISOLATION_LEVELS` for possible options.\n   * @param {Object}   [options.retry] Set of flags that control when a query is automatically retried.\n   * @param {Array}    [options.retry.match] Only retry a query if the error matches one of these strings.\n   * @param {number}   [options.retry.max] How many times a failing query is automatically retried.  Set to 0 to disable retrying on SQL_BUSY error.\n   * @param {boolean}  [options.typeValidation=false] Run built-in type validators on insert and update, and select with where clause, e.g. validate that arguments passed to integer fields are integer-like.\n   * @param {Object}   [options.operatorsAliases] String based operator alias. Pass object to limit set of aliased operators.\n   * @param {Object}   [options.hooks] An object of global hook functions that are called before and after certain lifecycle events. Global hooks will run after any model-specific hooks defined for the same event (See `Sequelize.Model.init()` for a list).  Additionally, `beforeConnect()`, `afterConnect()`, `beforeDisconnect()`, and `afterDisconnect()` hooks may be defined here.\n   * @param {boolean}  [options.minifyAliases=false] A flag that defines if aliases should be minified (mostly useful to avoid Postgres alias character limit of 64)\n   * @param {boolean}  [options.logQueryParameters=false] A flag that defines if show bind patameters in log.\n   */\n  constructor(database, username, password, options) {\n    let config;\n\n    if (arguments.length === 1 && typeof database === \"object\") {\n      // new Sequelize({ ... options })\n      options = database;\n      config = _.pick(\n        options,\n        \"host\",\n        \"port\",\n        \"database\",\n        \"username\",\n        \"password\"\n      );\n    } else if (\n      (arguments.length === 1 && typeof database === \"string\") ||\n      (arguments.length === 2 && typeof username === \"object\")\n    ) {\n      // new Sequelize(URI, { ... options })\n\n      config = {};\n      options = username || {};\n    } else {\n      // new Sequelize(database, username, password, { ... options })\n      options = options || {};\n      config = { database, username, password };\n    }\n\n    Sequelize.runHooks(\"beforeInit\", config, options);\n\n    this.options = Object.assign(\n      {\n        dialect: \"sqlite\",\n        dialectModule: null,\n        dialectModulePath: null,\n        host: \"localhost\",\n        protocol: \"tcp\",\n        define: {},\n        query: {},\n        sync: {},\n        timezone: \"+00:00\",\n        clientMinMessages: \"warning\",\n        standardConformingStrings: true,\n        // eslint-disable-next-line no-console\n        logging: console.log,\n        omitNull: false,\n        native: false,\n        replication: false,\n        ssl: undefined,\n        pool: {},\n        quoteIdentifiers: true,\n        hooks: {},\n        retry: {\n          max: 5,\n          match: [\"SQLITE_BUSY: database is locked\"]\n        },\n        transactionType: Transaction.TYPES.DEFERRED,\n        isolationLevel: null,\n        databaseVersion: 0,\n        typeValidation: false,\n        benchmark: false,\n        minifyAliases: false,\n        logQueryParameters: false\n      },\n      options || {}\n    );\n\n    if (!this.options.dialect) {\n      throw new Error(\"Dialect needs to be explicitly supplied as of v4.0.0\");\n    }\n\n    if (this.options.dialect === \"postgresql\") {\n      this.options.dialect = \"postgres\";\n    }\n\n    if (\n      this.options.dialect === \"sqlite\" &&\n      this.options.timezone !== \"+00:00\"\n    ) {\n      throw new Error(\n        \"Setting a custom timezone is not supported by SQLite, dates are always returned as UTC. Please remove the custom timezone parameter.\"\n      );\n    }\n\n    if (this.options.logging === true) {\n      deprecations.noTrueLogging();\n      // eslint-disable-next-line no-console\n      this.options.logging = console.log;\n    }\n\n    this._setupHooks(options.hooks);\n\n    this.config = {\n      database: config.database || this.options.database,\n      username: config.username || this.options.username,\n      password: config.password || this.options.password || null,\n      host: config.host || this.options.host,\n      port: config.port || this.options.port,\n      pool: this.options.pool,\n      protocol: this.options.protocol,\n      native: this.options.native,\n      ssl: this.options.ssl,\n      replication: this.options.replication,\n      dialectModule: this.options.dialectModule,\n      dialectModulePath: this.options.dialectModulePath,\n      keepDefaultTimezone: this.options.keepDefaultTimezone,\n      dialectOptions: this.options.dialectOptions\n    };\n\n    let Dialect;\n    // Requiring the dialect in a switch-case to keep the\n    // require calls static. (Browserify fix)\n    switch (this.getDialect()) {\n      case \"sqlite\":\n        // eslint-disable-next-line\n        Dialect = require(\"./dialects/sqlite\");\n        break;\n      default:\n        throw new Error(\n          `The dialect ${this.getDialect()} is not supported. Supported dialects: sqlite.`\n        );\n    }\n\n    this.dialect = new Dialect(this);\n    this.dialect.QueryGenerator.typeValidation = options.typeValidation;\n\n    if (_.isPlainObject(this.options.operatorsAliases)) {\n      deprecations.noStringOperators();\n      this.dialect.QueryGenerator.setOperatorsAliases(\n        this.options.operatorsAliases\n      );\n    } else if (typeof this.options.operatorsAliases === \"boolean\") {\n      deprecations.noBoolOperatorAliases();\n    }\n\n    this.queryInterface = new QueryInterface(this);\n\n    /**\n     * Models are stored here under the name given to `sequelize.define`\n     */\n    this.models = {};\n    this.modelManager = new ModelManager(this);\n    this.connectionManager = this.dialect.connectionManager;\n\n    this.importCache = {};\n\n    Sequelize.runHooks(\"afterInit\", this);\n  }\n\n  /**\n   * Refresh data types and parsers.\n   *\n   * @private\n   */\n  refreshTypes() {\n    this.connectionManager.refreshTypeParser(DataTypes);\n  }\n\n  /**\n   * Returns the specified dialect.\n   *\n   * @returns {string} The specified dialect.\n   */\n  getDialect() {\n    return this.options.dialect;\n  }\n\n  /**\n   * Returns the database name.\n   *\n   * @returns {string} The database name.\n   */\n  getDatabaseName() {\n    return this.config.database;\n  }\n\n  /**\n   * Returns an instance of QueryInterface.\n   *\n   * @returns {QueryInterface} An instance (singleton) of QueryInterface.\n   */\n  getQueryInterface() {\n    this.queryInterface = this.queryInterface || new QueryInterface(this);\n    return this.queryInterface;\n  }\n\n  /**\n   * Define a new model, representing a table in the database.\n   *\n   * The table columns are defined by the object that is given as the second argument. Each key of the object represents a column\n   *\n   * @param {string} modelName The name of the model. The model will be stored in `sequelize.models` under this name\n   * @param {Object} attributes An object, where each attribute is a column of the table. See {@link Model.init}\n   * @param {Object} [options] These options are merged with the default define options provided to the Sequelize constructor and passed to Model.init()\n   *\n   * @see\n   * {@link Model.init} for a more comprehensive specification of the `options` and `attributes` objects.\n   * @see <a href=\"/manual/tutorial/models-definition.html\">Model definition</a> Manual related to model definition\n   * @see\n   * {@link DataTypes} For a list of possible data types\n   *\n   * @returns {Model} Newly defined model\n   *\n   * @example\n   * sequelize.define('modelName', {\n   *   columnA: {\n   *       type: Sequelize.BOOLEAN,\n   *       validate: {\n   *         is: [\"[a-z]\",'i'],        // will only allow letters\n   *         max: 23,                  // only allow values <= 23\n   *         isIn: {\n   *           args: [['en', 'zh']],\n   *           msg: \"Must be English or Chinese\"\n   *         }\n   *       },\n   *       field: 'column_a'\n   *   },\n   *   columnB: Sequelize.STRING,\n   *   columnC: 'MY VERY OWN COLUMN TYPE'\n   * });\n   *\n   * sequelize.models.modelName // The model will now be available in models under the name given to define\n   */\n  define(modelName, attributes, options = {}) {\n    options.modelName = modelName;\n    options.sequelize = this;\n\n    const model = class extends Model {};\n\n    model.init(attributes, options);\n\n    return model;\n  }\n\n  /**\n   * Fetch a Model which is already defined\n   *\n   * @param {string} modelName The name of a model defined with Sequelize.define\n   *\n   * @throws Will throw an error if the model is not defined (that is, if sequelize#isDefined returns false)\n   * @returns {Model} Specified model\n   */\n  model(modelName) {\n    if (!this.isDefined(modelName)) {\n      throw new Error(`${modelName} has not been defined`);\n    }\n\n    return this.modelManager.getModel(modelName);\n  }\n\n  /**\n   * Checks whether a model with the given name is defined\n   *\n   * @param {string} modelName The name of a model defined with Sequelize.define\n   *\n   * @returns {boolean} Returns true if model is already defined, otherwise false\n   */\n  isDefined(modelName) {\n    return !!this.modelManager.models.find(model => model.name === modelName);\n  }\n\n  /**\n   * Imports a model defined in another file. Imported models are cached, so multiple\n   * calls to import with the same path will not load the file multiple times.\n   *\n   * @tutorial https://github.com/sequelize/express-example\n   *\n   * @param {string} importPath The path to the file that holds the model you want to import. If the part is relative, it will be resolved relatively to the calling file\n   *\n   * @returns {Model} Imported model, returned from cache if was already imported\n   */\n  import(importPath) {}\n\n  /**\n   * Execute a query on the DB, optionally bypassing all the Sequelize goodness.\n   *\n   * By default, the function will return two arguments: an array of results, and a metadata object, containing number of affected rows etc.\n   *\n   * If you are running a type of query where you don't need the metadata, for example a `SELECT` query, you can pass in a query type to make sequelize format the results:\n   *\n   * ```js\n   * sequelize.query('SELECT...').then(([results, metadata]) => {\n   *   // Raw query - use then plus array spread\n   * });\n   *\n   * sequelize.query('SELECT...', { type: sequelize.QueryTypes.SELECT }).then(results => {\n   *   // SELECT query - use then\n   * })\n   * ```\n   *\n   * @param {string}          sql\n   * @param {Object}          [options={}] Query options.\n   * @param {boolean}         [options.raw] If true, sequelize will not try to format the results of the query, or build an instance of a model from the result\n   * @param {Transaction}     [options.transaction=null] The transaction that the query should be executed under\n   * @param {QueryTypes}      [options.type='RAW'] The type of query you are executing. The query type affects how results are formatted before they are passed back. The type is a string, but `Sequelize.QueryTypes` is provided as convenience shortcuts.\n   * @param {boolean}         [options.nest=false] If true, transforms objects with `.` separated property names into nested objects using [dottie.js](https://github.com/mickhansen/dottie.js). For example { 'user.username': 'john' } becomes { user: { username: 'john' }}. When `nest` is true, the query type is assumed to be `'SELECT'`, unless otherwise specified\n   * @param {boolean}         [options.plain=false] Sets the query type to `SELECT` and return a single row\n   * @param {Object|Array}    [options.replacements] Either an object of named parameter replacements in the format `:param` or an array of unnamed replacements to replace `?` in your SQL.\n   * @param {Object|Array}    [options.bind] Either an object of named bind parameter in the format `_param` or an array of unnamed bind parameter to replace `$1, $2, ...` in your SQL.\n   * @param {boolean}         [options.useMaster=false] Force the query to use the write pool, regardless of the query type.\n   * @param {Function}        [options.logging=false] A function that gets executed while running the query to log the sql.\n   * @param {new Model()}     [options.instance] A sequelize instance used to build the return instance\n   * @param {Model}           [options.model] A sequelize model used to build the returned model instances (used to be called callee)\n   * @param {Object}          [options.retry] Set of flags that control when a query is automatically retried.\n   * @param {Array}           [options.retry.match] Only retry a query if the error matches one of these strings.\n   * @param {Integer}         [options.retry.max] How many times a failing query is automatically retried.\n   * @param {string}          [options.searchPath=DEFAULT] An optional parameter to specify the schema search_path (Postgres only)\n   * @param {boolean}         [options.supportsSearchPath] If false do not prepend the query with the search_path (Postgres only)\n   * @param {boolean}         [options.mapToModel=false] Map returned fields to model's fields if `options.model` or `options.instance` is present. Mapping will occur before building the model instance.\n   * @param {Object}          [options.fieldMap] Map returned fields to arbitrary names for `SELECT` query type.\n   *\n   * @returns {Promise}\n   *\n   * @see {@link Model.build} for more information about instance option.\n   */\n\n  query(sql, options) {\n    options = Object.assign({}, this.options.query, options);\n\n    if (options.instance && !options.model) {\n      options.model = options.instance.constructor;\n    }\n\n    if (!options.instance && !options.model) {\n      options.raw = true;\n    }\n\n    // map raw fields to model attributes\n    if (options.mapToModel) {\n      options.fieldMap = _.get(options, \"model.fieldAttributeMap\", {});\n    }\n\n    options = _.defaults(options, {\n      // eslint-disable-next-line no-console\n      logging: Object.prototype.hasOwnProperty.call(this.options, \"logging\")\n        ? this.options.logging\n        : console.log,\n      searchPath: Object.prototype.hasOwnProperty.call(\n        this.options,\n        \"searchPath\"\n      )\n        ? this.options.searchPath\n        : \"DEFAULT\"\n    });\n\n    if (!options.type) {\n      if (options.model || options.nest || options.plain) {\n        options.type = QueryTypes.SELECT;\n      } else {\n        options.type = QueryTypes.RAW;\n      }\n    }\n\n    //if dialect doesn't support search_path or dialect option\n    //to prepend searchPath is not true delete the searchPath option\n    if (\n      !this.dialect.supports.searchPath ||\n      !this.options.dialectOptions ||\n      !this.options.dialectOptions.prependSearchPath ||\n      options.supportsSearchPath === false\n    ) {\n      delete options.searchPath;\n    } else if (!options.searchPath) {\n      //if user wants to always prepend searchPath (dialectOptions.preprendSearchPath = true)\n      //then set to DEFAULT if none is provided\n      options.searchPath = \"DEFAULT\";\n    }\n\n    return Promise.try(() => {\n      if (typeof sql === \"object\") {\n        if (sql.values !== undefined) {\n          if (options.replacements !== undefined) {\n            throw new Error(\n              \"Both `sql.values` and `options.replacements` cannot be set at the same time\"\n            );\n          }\n          options.replacements = sql.values;\n        }\n\n        if (sql.bind !== undefined) {\n          if (options.bind !== undefined) {\n            throw new Error(\n              \"Both `sql.bind` and `options.bind` cannot be set at the same time\"\n            );\n          }\n          options.bind = sql.bind;\n        }\n\n        if (sql.query !== undefined) {\n          sql = sql.query;\n        }\n      }\n\n      sql = sql.trim();\n\n      if (options.replacements && options.bind) {\n        throw new Error(\n          \"Both `replacements` and `bind` cannot be set at the same time\"\n        );\n      }\n\n      if (options.replacements) {\n        if (Array.isArray(options.replacements)) {\n          sql = Utils.format(\n            [sql].concat(options.replacements),\n            this.options.dialect\n          );\n        } else {\n          sql = Utils.formatNamedParameters(\n            sql,\n            options.replacements,\n            this.options.dialect\n          );\n        }\n      }\n\n      let bindParameters;\n\n      if (options.bind) {\n        [sql, bindParameters] = this.dialect.Query.formatBindParameters(\n          sql,\n          options.bind,\n          this.options.dialect\n        );\n      }\n\n      const checkTransaction = () => {\n        if (\n          options.transaction &&\n          options.transaction.finished &&\n          !options.completesTransaction\n        ) {\n          const error = new Error(\n            `${options.transaction.finished} has been called on this transaction(${options.transaction.id}), you can no longer use it. (The rejected query is attached as the 'sql' property of this error)`\n          );\n          error.sql = sql;\n          throw error;\n        }\n      };\n\n      const retryOptions = Object.assign(\n        {},\n        this.options.retry,\n        options.retry || {}\n      );\n\n      return Promise.resolve(\n        retry(\n          () =>\n            Promise.try(() => {\n              if (options.transaction === undefined && Sequelize._cls) {\n                options.transaction = Sequelize._cls.get(\"transaction\");\n              }\n\n              checkTransaction();\n\n              return options.transaction\n                ? options.transaction.connection\n                : this.connectionManager.getConnection(options);\n            }).then(connection => {\n              const query = new this.dialect.Query(connection, this, options);\n              return this.runHooks(\"beforeQuery\", options, query)\n                .then(() => checkTransaction())\n                .then(() => query.run(sql, bindParameters))\n                .finally(() => this.runHooks(\"afterQuery\", options, query))\n                .finally(() => {\n                  if (!options.transaction) {\n                    return this.connectionManager.releaseConnection(connection);\n                  }\n                });\n            }),\n          retryOptions\n        )\n      );\n    });\n  }\n\n  /**\n   * Execute a query which would set an environment or user variable. The variables are set per connection, so this function needs a transaction.\n   * Only works for MySQL.\n   *\n   * @param {Object}        variables Object with multiple variables.\n   * @param {Object}        [options] query options.\n   * @param {Transaction}   [options.transaction] The transaction that the query should be executed under\n   *\n   * @memberof Sequelize\n   *\n   * @returns {Promise}\n   */\n  set(variables, options) {\n    // Prepare options\n    options = Object.assign(\n      {},\n      this.options.set,\n      typeof options === \"object\" && options\n    );\n\n    if (this.options.dialect !== \"mysql\") {\n      throw new Error(\"sequelize.set is only supported for mysql\");\n    }\n    if (!options.transaction || !(options.transaction instanceof Transaction)) {\n      throw new TypeError(\"options.transaction is required\");\n    }\n\n    // Override some options, since this isn't a SELECT\n    options.raw = true;\n    options.plain = true;\n    options.type = \"SET\";\n\n    // Generate SQL Query\n    const query = `SET ${_.map(\n      variables,\n      (v, k) => `@${k} := ${typeof v === \"string\" ? `\"${v}\"` : v}`\n    ).join(\", \")}`;\n\n    return this.query(query, options);\n  }\n\n  /**\n   * Escape value.\n   *\n   * @param {string} value string value to escape\n   *\n   * @returns {string}\n   */\n  escape(value) {\n    return this.getQueryInterface().escape(value);\n  }\n\n  /**\n   * Create a new database schema.\n   *\n   * **Note:** this is a schema in the [postgres sense of the word](http://www.postgresql.org/docs/9.1/static/ddl-schemas.html),\n   * not a database table. In mysql and sqlite, this command will do nothing.\n   *\n   * @see\n   * {@link Model.schema}\n   *\n   * @param {string} schema Name of the schema\n   * @param {Object} [options={}] query options\n   * @param {boolean|Function} [options.logging] A function that logs sql queries, or false for no logging\n   *\n   * @returns {Promise}\n   */\n  createSchema(schema, options) {\n    return this.getQueryInterface().createSchema(schema, options);\n  }\n\n  /**\n   * Show all defined schemas\n   *\n   * **Note:** this is a schema in the [postgres sense of the word](http://www.postgresql.org/docs/9.1/static/ddl-schemas.html),\n   * not a database table. In mysql and sqlite, this will show all tables.\n   *\n   * @param {Object} [options={}] query options\n   * @param {boolean|Function} [options.logging] A function that logs sql queries, or false for no logging\n   *\n   * @returns {Promise}\n   */\n  showAllSchemas(options) {\n    return this.getQueryInterface().showAllSchemas(options);\n  }\n\n  /**\n   * Drop a single schema\n   *\n   * **Note:** this is a schema in the [postgres sense of the word](http://www.postgresql.org/docs/9.1/static/ddl-schemas.html),\n   * not a database table. In mysql and sqlite, this drop a table matching the schema name\n   *\n   * @param {string} schema Name of the schema\n   * @param {Object} [options={}] query options\n   * @param {boolean|Function} [options.logging] A function that logs sql queries, or false for no logging\n   *\n   * @returns {Promise}\n   */\n  dropSchema(schema, options) {\n    return this.getQueryInterface().dropSchema(schema, options);\n  }\n\n  /**\n   * Drop all schemas.\n   *\n   * **Note:** this is a schema in the [postgres sense of the word](http://www.postgresql.org/docs/9.1/static/ddl-schemas.html),\n   * not a database table. In mysql and sqlite, this is the equivalent of drop all tables.\n   *\n   * @param {Object} [options={}] query options\n   * @param {boolean|Function} [options.logging] A function that logs sql queries, or false for no logging\n   *\n   * @returns {Promise}\n   */\n  dropAllSchemas(options) {\n    return this.getQueryInterface().dropAllSchemas(options);\n  }\n\n  /**\n   * Sync all defined models to the DB.\n   *\n   * @param {Object} [options={}] sync options\n   * @param {boolean} [options.force=false] If force is true, each Model will run `DROP TABLE IF EXISTS`, before it tries to create its own table\n   * @param {RegExp} [options.match] Match a regex against the database name before syncing, a safety check for cases where force: true is used in tests but not live code\n   * @param {boolean|Function} [options.logging=console.log] A function that logs sql queries, or false for no logging\n   * @param {string} [options.schema='public'] The schema that the tables should be created in. This can be overridden for each table in sequelize.define\n   * @param {string} [options.searchPath=DEFAULT] An optional parameter to specify the schema search_path (Postgres only)\n   * @param {boolean} [options.hooks=true] If hooks is true then beforeSync, afterSync, beforeBulkSync, afterBulkSync hooks will be called\n   * @param {boolean} [options.alter=false] Alters tables to fit models. Not recommended for production use. Deletes data in columns that were removed or had their type changed in the model.\n   *\n   * @returns {Promise}\n   */\n  sync(options) {\n    options = _.clone(options) || {};\n    options.hooks = options.hooks === undefined ? true : !!options.hooks;\n    options = _.defaults(options, this.options.sync, this.options);\n\n    if (options.match) {\n      if (!options.match.test(this.config.database)) {\n        return Promise.reject(\n          new Error(\n            `Database \"${this.config.database}\" does not match sync match parameter \"${options.match}\"`\n          )\n        );\n      }\n    }\n\n    return Promise.try(() => {\n      if (options.hooks) {\n        return this.runHooks(\"beforeBulkSync\", options);\n      }\n    })\n      .then(() => {\n        if (options.force) {\n          return this.drop(options);\n        }\n      })\n      .then(() => {\n        const models = [];\n\n        // Topologically sort by foreign key constraints to give us an appropriate\n        // creation order\n        this.modelManager.forEachModel(model => {\n          if (model) {\n            models.push(model);\n          } else {\n            // DB should throw an SQL error if referencing non-existent table\n          }\n        });\n\n        // no models defined, just authenticate\n        if (!models.length) return this.authenticate(options);\n\n        return Promise.each(models, model => model.sync(options));\n      })\n      .then(() => {\n        if (options.hooks) {\n          return this.runHooks(\"afterBulkSync\", options);\n        }\n      })\n      .return(this);\n  }\n\n  /**\n   * Truncate all tables defined through the sequelize models.\n   * This is done by calling `Model.truncate()` on each model.\n   *\n   * @param {Object} [options] The options passed to Model.destroy in addition to truncate\n   * @param {boolean|Function} [options.logging] A function that logs sql queries, or false for no logging\n   * @returns {Promise}\n   *\n   * @see\n   * {@link Model.truncate} for more information\n   */\n  truncate(options) {\n    const models = [];\n\n    this.modelManager.forEachModel(\n      model => {\n        if (model) {\n          models.push(model);\n        }\n      },\n      { reverse: false }\n    );\n\n    const truncateModel = model => model.truncate(options);\n\n    if (options && options.cascade) {\n      return Promise.each(models, truncateModel);\n    }\n    return Promise.map(models, truncateModel);\n  }\n\n  /**\n   * Drop all tables defined through this sequelize instance.\n   * This is done by calling Model.drop on each model.\n   *\n   * @see\n   * {@link Model.drop} for options\n   *\n   * @param {Object} [options] The options passed to each call to Model.drop\n   * @param {boolean|Function} [options.logging] A function that logs sql queries, or false for no logging\n   *\n   * @returns {Promise}\n   */\n  drop(options) {\n    const models = [];\n\n    this.modelManager.forEachModel(\n      model => {\n        if (model) {\n          models.push(model);\n        }\n      },\n      { reverse: false }\n    );\n\n    return Promise.each(models, model => model.drop(options));\n  }\n\n  /**\n   * Test the connection by trying to authenticate. It runs `SELECT 1+1 AS result` query.\n   *\n   * @param {Object} [options={}] query options\n   *\n   * @returns {Promise}\n   */\n  authenticate(options) {\n    options = Object.assign(\n      {\n        raw: true,\n        plain: true,\n        type: QueryTypes.SELECT\n      },\n      options\n    );\n\n    return this.query(\"SELECT 1+1 AS result\", options).return();\n  }\n\n  databaseVersion(options) {\n    return this.getQueryInterface().databaseVersion(options);\n  }\n\n  /**\n   * Get the fn for random based on the dialect\n   *\n   * @returns {Sequelize.fn}\n   */\n  random() {\n    const dia = this.getDialect();\n    if (dia === \"postgres\" || dia === \"sqlite\") {\n      return this.fn(\"RANDOM\");\n    }\n    return this.fn(\"RAND\");\n  }\n\n  /**\n   * Creates an object representing a database function. This can be used in search queries, both in where and order parts, and as default values in column definitions.\n   * If you want to refer to columns in your function, you should use `sequelize.col`, so that the columns are properly interpreted as columns and not a strings.\n   *\n   * @see\n   * {@link Model.findAll}\n   * @see\n   * {@link Sequelize.define}\n   * @see\n   * {@link Sequelize.col}\n   *\n   * @param {string} fn The function you want to call\n   * @param {any} args All further arguments will be passed as arguments to the function\n   *\n   * @since v2.0.0-dev3\n   * @memberof Sequelize\n   * @returns {Sequelize.fn}\n   *\n   * @example <caption>Convert a user's username to upper case</caption>\n   * instance.update({\n   *   username: sequelize.fn('upper', sequelize.col('username'))\n   * });\n   */\n  static fn(fn, ...args) {\n    return new Utils.Fn(fn, args);\n  }\n\n  /**\n   * Creates an object which represents a column in the DB, this allows referencing another column in your query. This is often useful in conjunction with `sequelize.fn`, since raw string arguments to fn will be escaped.\n   *\n   * @see\n   * {@link Sequelize#fn}\n   *\n   * @param {string} col The name of the column\n   * @since v2.0.0-dev3\n   * @memberof Sequelize\n   *\n   * @returns {Sequelize.col}\n   */\n  static col(col) {\n    return new Utils.Col(col);\n  }\n\n  /**\n   * Creates an object representing a call to the cast function.\n   *\n   * @param {any} val The value to cast\n   * @param {string} type The type to cast it to\n   * @since v2.0.0-dev3\n   * @memberof Sequelize\n   *\n   * @returns {Sequelize.cast}\n   */\n  static cast(val, type) {\n    return new Utils.Cast(val, type);\n  }\n\n  /**\n   * Creates an object representing a literal, i.e. something that will not be escaped.\n   *\n   * @param {any} val literal value\n   * @since v2.0.0-dev3\n   * @memberof Sequelize\n   *\n   * @returns {Sequelize.literal}\n   */\n  static literal(val) {\n    return new Utils.Literal(val);\n  }\n\n  /**\n   * An AND query\n   *\n   * @see\n   * {@link Model.findAll}\n   *\n   * @param {...string|Object} args Each argument will be joined by AND\n   * @since v2.0.0-dev3\n   * @memberof Sequelize\n   *\n   * @returns {Sequelize.and}\n   */\n  static and(...args) {\n    return { [Op.and]: args };\n  }\n\n  /**\n   * An OR query\n   *\n   * @see\n   * {@link Model.findAll}\n   *\n   * @param {...string|Object} args Each argument will be joined by OR\n   * @since v2.0.0-dev3\n   * @memberof Sequelize\n   *\n   * @returns {Sequelize.or}\n   */\n  static or(...args) {\n    return { [Op.or]: args };\n  }\n\n  /**\n   * Creates an object representing nested where conditions for postgres/sqlite/mysql json data-type.\n   *\n   * @see\n   * {@link Model.findAll}\n   *\n   * @param {string|Object} conditionsOrPath A hash containing strings/numbers or other nested hash, a string using dot notation or a string using postgres/sqlite/mysql json syntax.\n   * @param {string|number|boolean} [value] An optional value to compare against. Produces a string of the form \"<json path> = '<value>'\".\n   * @memberof Sequelize\n   *\n   * @returns {Sequelize.json}\n   */\n  static json(conditionsOrPath, value) {\n    return new Utils.Json(conditionsOrPath, value);\n  }\n\n  /**\n   * A way of specifying attr = condition.\n   *\n   * The attr can either be an object taken from `Model.rawAttributes` (for example `Model.rawAttributes.id` or `Model.rawAttributes.name`). The\n   * attribute should be defined in your model definition. The attribute can also be an object from one of the sequelize utility functions (`sequelize.fn`, `sequelize.col` etc.)\n   *\n   * For string attributes, use the regular `{ where: { attr: something }}` syntax. If you don't want your string to be escaped, use `sequelize.literal`.\n   *\n   * @see\n   * {@link Model.findAll}\n   *\n   * @param {Object} attr The attribute, which can be either an attribute object from `Model.rawAttributes` or a sequelize object, for example an instance of `sequelize.fn`. For simple string attributes, use the POJO syntax\n   * @param {Symbol} [comparator='Op.eq'] operator\n   * @param {string|Object} logic The condition. Can be both a simply type, or a further condition (`or`, `and`, `.literal` etc.)\n   * @since v2.0.0-dev3\n   */\n  static where(attr, comparator, logic) {\n    return new Utils.Where(attr, comparator, logic);\n  }\n\n  /**\n   * Start a transaction. When using transactions, you should pass the transaction in the options argument in order for the query to happen under that transaction @see {@link Transaction}\n   *\n   * If you have [CLS](https://github.com/othiym23/node-continuation-local-storage) enabled, the transaction will automatically be passed to any query that runs within the callback\n   *\n   * @example\n   * sequelize.transaction().then(transaction => {\n   *   return User.findOne(..., {transaction})\n   *     .then(user => user.update(..., {transaction}))\n   *     .then(() => transaction.commit())\n   *     .catch(() => transaction.rollback());\n   * })\n   *\n   * @example <caption>A syntax for automatically committing or rolling back based on the promise chain resolution is also supported</caption>\n   *\n   * sequelize.transaction(transaction => { // Note that we use a callback rather than a promise.then()\n   *   return User.findOne(..., {transaction})\n   *     .then(user => user.update(..., {transaction}))\n   * }).then(() => {\n   *   // Committed\n   * }).catch(err => {\n   *   // Rolled back\n   *   console.error(err);\n   * });\n   *\n   * @example <caption>To enable CLS, add it do your project, create a namespace and set it on the sequelize constructor:</caption>\n   *\n   * const cls = require('continuation-local-storage');\n   * const ns = cls.createNamespace('....');\n   * const Sequelize = require('sequelize');\n   * Sequelize.useCLS(ns);\n   *\n   * // Note, that CLS is enabled for all sequelize instances, and all instances will share the same namespace\n   *\n   * @param {Object}   [options] Transaction options\n   * @param {string}   [options.type='DEFERRED'] See `Sequelize.Transaction.TYPES` for possible options. Sqlite only.\n   * @param {string}   [options.isolationLevel] See `Sequelize.Transaction.ISOLATION_LEVELS` for possible options\n   * @param {string}   [options.deferrable] Sets the constraints to be deferred or immediately checked. See `Sequelize.Deferrable`. PostgreSQL Only\n   * @param {Function} [options.logging=false] A function that gets executed while running the query to log the sql.\n   * @param {Function} [autoCallback] The callback is called with the transaction object, and should return a promise. If the promise is resolved, the transaction commits; if the promise rejects, the transaction rolls back\n   *\n   * @returns {Promise}\n   */\n  transaction(options, autoCallback) {\n    if (typeof options === \"function\") {\n      autoCallback = options;\n      options = undefined;\n    }\n\n    const transaction = new Transaction(this, options);\n\n    if (!autoCallback)\n      return transaction.prepareEnvironment(false).return(transaction);\n\n    // autoCallback provided\n    return Sequelize._clsRun(() => {\n      return transaction\n        .prepareEnvironment()\n        .then(() => autoCallback(transaction))\n        .tap(() => transaction.commit())\n        .catch(err => {\n          // Rollback transaction if not already finished (commit, rollback, etc)\n          // and reject with original error (ignore any error in rollback)\n          return Promise.try(() => {\n            if (!transaction.finished)\n              return transaction.rollback().catch(() => {});\n          }).throw(err);\n        });\n    });\n  }\n\n  /**\n   * Use CLS with Sequelize.\n   * CLS namespace provided is stored as `Sequelize._cls`\n   * and bluebird Promise is patched to use the namespace, using `cls-bluebird` module.\n   *\n   * @param {Object} ns CLS namespace\n   * @returns {Object} Sequelize constructor\n   */\n  static useCLS(ns) {\n    // check `ns` is valid CLS namespace\n    if (\n      !ns ||\n      typeof ns !== \"object\" ||\n      typeof ns.bind !== \"function\" ||\n      typeof ns.run !== \"function\"\n    )\n      throw new Error(\"Must provide CLS namespace\");\n\n    // save namespace as `Sequelize._cls`\n    this._cls = ns;\n\n    // patch bluebird to bind all promise callbacks to CLS namespace\n    clsBluebird(ns, Promise);\n\n    // return Sequelize for chaining\n    return this;\n  }\n\n  /**\n   * Run function in CLS context.\n   * If no CLS context in use, just runs the function normally\n   *\n   * @private\n   * @param {Function} fn Function to run\n   * @returns {*} Return value of function\n   */\n  static _clsRun(fn) {\n    const ns = Sequelize._cls;\n    if (!ns) return fn();\n\n    let res;\n    ns.run(context => (res = fn(context)));\n    return res;\n  }\n\n  log(...args) {\n    let options;\n\n    const last = _.last(args);\n\n    if (\n      last &&\n      _.isPlainObject(last) &&\n      Object.prototype.hasOwnProperty.call(last, \"logging\")\n    ) {\n      options = last;\n\n      // remove options from set of logged arguments if options.logging is equal to console.log\n      // eslint-disable-next-line no-console\n      if (options.logging === console.log) {\n        args.splice(args.length - 1, 1);\n      }\n    } else {\n      options = this.options;\n    }\n\n    if (options.logging) {\n      if (options.logging === true) {\n        deprecations.noTrueLogging();\n        // eslint-disable-next-line no-console\n        options.logging = console.log;\n      }\n\n      // second argument is sql-timings, when benchmarking option enabled\n      // eslint-disable-next-line no-console\n      if (\n        (this.options.benchmark || options.benchmark) &&\n        options.logging === console.log\n      ) {\n        args = [`${args[0]} Elapsed time: ${args[1]}ms`];\n      }\n\n      options.logging(...args);\n    }\n  }\n\n  /**\n   * Close all connections used by this sequelize instance, and free all references so the instance can be garbage collected.\n   *\n   * Normally this is done on process exit, so you only need to call this method if you are creating multiple instances, and want\n   * to garbage collect some of them.\n   *\n   * @returns {Promise}\n   */\n  close() {\n    return this.connectionManager.close();\n  }\n\n  normalizeDataType(Type) {\n    let type = typeof Type === \"function\" ? new Type() : Type;\n    const dialectTypes = this.dialect.DataTypes || {};\n\n    if (dialectTypes[type.key]) {\n      type = dialectTypes[type.key].extend(type);\n    }\n\n    if (type instanceof DataTypes.ARRAY) {\n      if (!type.type) {\n        throw new Error(\"ARRAY is missing type definition for its values.\");\n      }\n      if (dialectTypes[type.type.key]) {\n        type.type = dialectTypes[type.type.key].extend(type.type);\n      }\n    }\n\n    return type;\n  }\n\n  normalizeAttribute(attribute) {\n    if (!_.isPlainObject(attribute)) {\n      attribute = { type: attribute };\n    }\n\n    if (!attribute.type) return attribute;\n\n    attribute.type = this.normalizeDataType(attribute.type);\n\n    if (Object.prototype.hasOwnProperty.call(attribute, \"defaultValue\")) {\n      if (\n        typeof attribute.defaultValue === \"function\" &&\n        (attribute.defaultValue === DataTypes.NOW ||\n          attribute.defaultValue === DataTypes.UUIDV1 ||\n          attribute.defaultValue === DataTypes.UUIDV4)\n      ) {\n        attribute.defaultValue = new attribute.defaultValue();\n      }\n    }\n\n    if (attribute.type instanceof DataTypes.ENUM) {\n      // The ENUM is a special case where the type is an object containing the values\n      if (attribute.values) {\n        attribute.type.values = attribute.type.options.values =\n          attribute.values;\n      } else {\n        attribute.values = attribute.type.values;\n      }\n\n      if (!attribute.values.length) {\n        throw new Error(\"Values for ENUM have not been defined.\");\n      }\n    }\n\n    return attribute;\n  }\n}\n\n// Aliases\nSequelize.prototype.fn = Sequelize.fn;\nSequelize.prototype.col = Sequelize.col;\nSequelize.prototype.cast = Sequelize.cast;\nSequelize.prototype.literal = Sequelize.literal;\nSequelize.prototype.and = Sequelize.and;\nSequelize.prototype.or = Sequelize.or;\nSequelize.prototype.json = Sequelize.json;\nSequelize.prototype.where = Sequelize.where;\nSequelize.prototype.validate = Sequelize.prototype.authenticate;\n\n/**\n * Sequelize version number.\n */\nSequelize.version = require(\"../package.json\").version;\n\nSequelize.options = { hooks: {} };\n\n/**\n * @private\n */\nSequelize.Utils = Utils;\n\n/**\n * Operators symbols to be used for querying data\n * @see  {@link Operators}\n */\nSequelize.Op = Op;\n\n/**\n * A handy reference to the bluebird Promise class\n */\nSequelize.Promise = Promise;\n\n/**\n * Available table hints to be used for querying data in mssql for table hints\n * @see {@link TableHints}\n */\nSequelize.TableHints = TableHints;\n\n/**\n * Available index hints to be used for querying data in mysql for index hints\n * @see {@link IndexHints}\n */\nSequelize.IndexHints = IndexHints;\n\n/**\n * A reference to the sequelize transaction class. Use this to access isolationLevels and types when creating a transaction\n * @see {@link Transaction}\n * @see {@link Sequelize.transaction}\n */\nSequelize.Transaction = Transaction;\n\n/**\n * A reference to Sequelize constructor from sequelize. Useful for accessing DataTypes, Errors etc.\n * @see {@link Sequelize}\n */\nSequelize.prototype.Sequelize = Sequelize;\n\n/**\n * Available query types for use with `sequelize.query`\n * @see {@link QueryTypes}\n */\nSequelize.prototype.QueryTypes = Sequelize.QueryTypes = QueryTypes;\n\n/**\n * Exposes the validator.js object, so you can extend it with custom validation functions. The validator is exposed both on the instance, and on the constructor.\n * @see https://github.com/chriso/validator.js\n */\nSequelize.prototype.Validator = Sequelize.Validator = Validator;\n\nSequelize.Model = Model;\n\nSequelize.DataTypes = DataTypes;\nfor (const dataType in DataTypes) {\n  Sequelize[dataType] = DataTypes[dataType];\n}\n\n/**\n * A reference to the deferrable collection. Use this to access the different deferrable options.\n * @see {@link Transaction.Deferrable}\n * @see {@link Sequelize#transaction}\n */\nSequelize.Deferrable = Deferrable;\n\n/**\n * A reference to the sequelize association class.\n * @see {@link Association}\n */\nSequelize.prototype.Association = Sequelize.Association = Association;\n\n/**\n * Provide alternative version of `inflection` module to be used by `Utils.pluralize` etc.\n * @param {Object} _inflection - `inflection` module\n */\nSequelize.useInflection = Utils.useInflection;\n\n/**\n * Allow hooks to be defined on Sequelize + on sequelize instance as universal hooks to run on all models\n * and on Sequelize/sequelize methods e.g. Sequelize(), Sequelize#define()\n */\nHooks.applyTo(Sequelize);\nHooks.applyTo(Sequelize.prototype);\n\n/**\n * Expose various errors available\n */\n\n// expose alias to BaseError\nSequelize.Error = sequelizeErrors.BaseError;\n\nfor (const error of Object.keys(sequelizeErrors)) {\n  Sequelize[error] = sequelizeErrors[error];\n}\n\nmodule.exports = Sequelize;\nmodule.exports.Sequelize = Sequelize;\nmodule.exports.default = Sequelize;\n"]} \ No newline at end of file diff --git a/dist/sql-string.js b/dist/sql-string.js index 3e5e182..538f332 100644 --- a/dist/sql-string.js +++ b/dist/sql-string.js @@ -157,4 +157,4 @@ function formatNamedParameters(sql, values, timeZone, dialect) { } exports.formatNamedParameters = formatNamedParameters; -//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../lib/sql-string.js"],"names":["dataTypes","require","logger","arrayToList","array","timeZone","dialect","format","reduce","sql","val","i","Array","isArray","escape","exports","prependN","undefined","toString","Date","DATE","prototype","stringify","timezone","Buffer","isBuffer","BLOB","partialEscape","escVal","ARRAY","replace","Error","inspect","s","values","concat","match","length","shift","formatNamedParameters","value","key","slice"],"mappings":"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","sourcesContent":["'use strict';\r\n\r\nconst dataTypes = require('./data-types');\r\nconst { logger } = require('./utils/logger');\r\n\r\nfunction arrayToList(array, timeZone, dialect, format) {\r\n  return array.reduce((sql, val, i) => {\r\n    if (i !== 0) {\r\n      sql += ', ';\r\n    }\r\n    if (Array.isArray(val)) {\r\n      sql += `(${arrayToList(val, timeZone, dialect, format)})`;\r\n    } else {\r\n      sql += escape(val, timeZone, dialect, format);\r\n    }\r\n    return sql;\r\n  }, '');\r\n}\r\nexports.arrayToList = arrayToList;\r\n\r\nfunction escape(val, timeZone, dialect, format) {\r\n  let prependN = false;\r\n  if (val === undefined || val === null) {\r\n    return 'NULL';\r\n  }\r\n  switch (typeof val) {\r\n    case 'boolean':\r\n    // SQLite doesn't have true/false support. MySQL aliases true/false to 1/0\r\n    // for us. Postgres actually has a boolean type with true/false literals,\r\n    // but sequelize doesn't use it yet.\r\n      if (dialect === 'sqlite' || dialect === 'mssql') {\r\n        return +!!val;\r\n      }\r\n      return (!!val).toString();\r\n    case 'number':\r\n      return val.toString();\r\n    case 'string':\r\n    // In mssql, prepend N to all quoted vals which are originally a string (for\r\n    // unicode compatibility)\r\n      prependN = dialect === 'mssql';\r\n      break;\r\n  }\r\n\r\n  if (val instanceof Date) {\r\n    val = dataTypes[dialect].DATE.prototype.stringify(val, { timezone: timeZone });\r\n  }\r\n\r\n  if (Buffer.isBuffer(val)) {\r\n    if (dataTypes[dialect].BLOB) {\r\n      return dataTypes[dialect].BLOB.prototype.stringify(val);\r\n    }\r\n\r\n    return dataTypes.BLOB.prototype.stringify(val);\r\n  }\r\n\r\n  if (Array.isArray(val)) {\r\n    const partialEscape = escVal => escape(escVal, timeZone, dialect, format);\r\n    if (dialect === 'postgres' && !format) {\r\n      return dataTypes.ARRAY.prototype.stringify(val, { escape: partialEscape });\r\n    }\r\n    return arrayToList(val, timeZone, dialect, format);\r\n  }\r\n\r\n  if (!val.replace) {\r\n    throw new Error(`Invalid value ${logger.inspect(val)}`);\r\n  }\r\n\r\n  if (dialect === 'postgres' || dialect === 'sqlite' || dialect === 'mssql') {\r\n    // http://www.postgresql.org/docs/8.2/static/sql-syntax-lexical.html#SQL-SYNTAX-STRINGS\r\n    // http://stackoverflow.com/q/603572/130598\r\n    val = val.replace(/'/g, \"''\");\r\n\r\n    if (dialect === 'postgres') {\r\n      // null character is not allowed in Postgres\r\n      val = val.replace(/\\0/g, '\\\\0');\r\n    }\r\n  } else {\r\n    // eslint-disable-next-line no-control-regex\r\n    val = val.replace(/[\\0\\n\\r\\b\\t\\\\'\"\\x1a]/g, s => {\r\n      switch (s) {\r\n        case '\\0': return '\\\\0';\r\n        case '\\n': return '\\\\n';\r\n        case '\\r': return '\\\\r';\r\n        case '\\b': return '\\\\b';\r\n        case '\\t': return '\\\\t';\r\n        case '\\x1a': return '\\\\Z';\r\n        default: return `\\\\${s}`;\r\n      }\r\n    });\r\n  }\r\n  return `${(prependN ? \"N'\" : \"'\") + val}'`;\r\n}\r\nexports.escape = escape;\r\n\r\nfunction format(sql, values, timeZone, dialect) {\r\n  values = [].concat(values);\r\n\r\n  if (typeof sql !== 'string') {\r\n    throw new Error(`Invalid SQL string provided: ${sql}`);\r\n  }\r\n\r\n  return sql.replace(/\\?/g, match => {\r\n    if (!values.length) {\r\n      return match;\r\n    }\r\n\r\n    return escape(values.shift(), timeZone, dialect, true);\r\n  });\r\n}\r\nexports.format = format;\r\n\r\nfunction formatNamedParameters(sql, values, timeZone, dialect) {\r\n  return sql.replace(/:+(?!\\d)(\\w+)/g, (value, key) => {\r\n    if ('postgres' === dialect && '::' === value.slice(0, 2)) {\r\n      return value;\r\n    }\r\n\r\n    if (values[key] !== undefined) {\r\n      return escape(values[key], timeZone, dialect, true);\r\n    }\r\n    throw new Error(`Named parameter \"${value}\" has no value in the given object.`);\r\n  });\r\n}\r\nexports.formatNamedParameters = formatNamedParameters;\r\n"]} \ No newline at end of file +//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../lib/sql-string.js"],"names":["dataTypes","require","logger","arrayToList","array","timeZone","dialect","format","reduce","sql","val","i","Array","isArray","escape","exports","prependN","undefined","toString","Date","DATE","prototype","stringify","timezone","Buffer","isBuffer","BLOB","partialEscape","escVal","ARRAY","replace","Error","inspect","s","values","concat","match","length","shift","formatNamedParameters","value","key","slice"],"mappings":"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","sourcesContent":["'use strict';\n\nconst dataTypes = require('./data-types');\nconst { logger } = require('./utils/logger');\n\nfunction arrayToList(array, timeZone, dialect, format) {\n  return array.reduce((sql, val, i) => {\n    if (i !== 0) {\n      sql += ', ';\n    }\n    if (Array.isArray(val)) {\n      sql += `(${arrayToList(val, timeZone, dialect, format)})`;\n    } else {\n      sql += escape(val, timeZone, dialect, format);\n    }\n    return sql;\n  }, '');\n}\nexports.arrayToList = arrayToList;\n\nfunction escape(val, timeZone, dialect, format) {\n  let prependN = false;\n  if (val === undefined || val === null) {\n    return 'NULL';\n  }\n  switch (typeof val) {\n    case 'boolean':\n    // SQLite doesn't have true/false support. MySQL aliases true/false to 1/0\n    // for us. Postgres actually has a boolean type with true/false literals,\n    // but sequelize doesn't use it yet.\n      if (dialect === 'sqlite' || dialect === 'mssql') {\n        return +!!val;\n      }\n      return (!!val).toString();\n    case 'number':\n      return val.toString();\n    case 'string':\n    // In mssql, prepend N to all quoted vals which are originally a string (for\n    // unicode compatibility)\n      prependN = dialect === 'mssql';\n      break;\n  }\n\n  if (val instanceof Date) {\n    val = dataTypes[dialect].DATE.prototype.stringify(val, { timezone: timeZone });\n  }\n\n  if (Buffer.isBuffer(val)) {\n    if (dataTypes[dialect].BLOB) {\n      return dataTypes[dialect].BLOB.prototype.stringify(val);\n    }\n\n    return dataTypes.BLOB.prototype.stringify(val);\n  }\n\n  if (Array.isArray(val)) {\n    const partialEscape = escVal => escape(escVal, timeZone, dialect, format);\n    if (dialect === 'postgres' && !format) {\n      return dataTypes.ARRAY.prototype.stringify(val, { escape: partialEscape });\n    }\n    return arrayToList(val, timeZone, dialect, format);\n  }\n\n  if (!val.replace) {\n    throw new Error(`Invalid value ${logger.inspect(val)}`);\n  }\n\n  if (dialect === 'postgres' || dialect === 'sqlite' || dialect === 'mssql') {\n    // http://www.postgresql.org/docs/8.2/static/sql-syntax-lexical.html#SQL-SYNTAX-STRINGS\n    // http://stackoverflow.com/q/603572/130598\n    val = val.replace(/'/g, \"''\");\n\n    if (dialect === 'postgres') {\n      // null character is not allowed in Postgres\n      val = val.replace(/\\0/g, '\\\\0');\n    }\n  } else {\n    // eslint-disable-next-line no-control-regex\n    val = val.replace(/[\\0\\n\\r\\b\\t\\\\'\"\\x1a]/g, s => {\n      switch (s) {\n        case '\\0': return '\\\\0';\n        case '\\n': return '\\\\n';\n        case '\\r': return '\\\\r';\n        case '\\b': return '\\\\b';\n        case '\\t': return '\\\\t';\n        case '\\x1a': return '\\\\Z';\n        default: return `\\\\${s}`;\n      }\n    });\n  }\n  return `${(prependN ? \"N'\" : \"'\") + val}'`;\n}\nexports.escape = escape;\n\nfunction format(sql, values, timeZone, dialect) {\n  values = [].concat(values);\n\n  if (typeof sql !== 'string') {\n    throw new Error(`Invalid SQL string provided: ${sql}`);\n  }\n\n  return sql.replace(/\\?/g, match => {\n    if (!values.length) {\n      return match;\n    }\n\n    return escape(values.shift(), timeZone, dialect, true);\n  });\n}\nexports.format = format;\n\nfunction formatNamedParameters(sql, values, timeZone, dialect) {\n  return sql.replace(/:+(?!\\d)(\\w+)/g, (value, key) => {\n    if ('postgres' === dialect && '::' === value.slice(0, 2)) {\n      return value;\n    }\n\n    if (values[key] !== undefined) {\n      return escape(values[key], timeZone, dialect, true);\n    }\n    throw new Error(`Named parameter \"${value}\" has no value in the given object.`);\n  });\n}\nexports.formatNamedParameters = formatNamedParameters;\n"]} \ No newline at end of file diff --git a/dist/table-hints.js b/dist/table-hints.js index 89122b0..c5237d5 100644 --- a/dist/table-hints.js +++ b/dist/table-hints.js @@ -37,4 +37,4 @@ const TableHints = module.exports = { SNAPSHOT: 'SNAPSHOT', NOEXPAND: 'NOEXPAND' }; -//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uL2xpYi90YWJsZS1oaW50cy5qcyJdLCJuYW1lcyI6WyJUYWJsZUhpbnRzIiwibW9kdWxlIiwiZXhwb3J0cyIsIk5PTE9DSyIsIlJFQURVTkNPTU1JVFRFRCIsIlVQRExPQ0siLCJSRVBFQVRBQkxFUkVBRCIsIlNFUklBTElaQUJMRSIsIlJFQURDT01NSVRURUQiLCJUQUJMT0NLIiwiVEFCTE9DS1giLCJQQUdMT0NLIiwiUk9XTE9DSyIsIk5PV0FJVCIsIlJFQURQQVNUIiwiWExPQ0siLCJTTkFQU0hPVCIsIk5PRVhQQU5EIl0sIm1hcHBpbmdzIjoiQUFBQTtBQUVBOzs7Ozs7Ozs7Ozs7Ozs7Ozs7OztBQW1CQSxNQUFNQSxVQUFVLEdBQUdDLE1BQU0sQ0FBQ0MsT0FBUCxHQUFpQjtBQUFFO0FBQ3BDQyxFQUFBQSxNQUFNLEVBQUUsUUFEMEI7QUFFbENDLEVBQUFBLGVBQWUsRUFBRSxpQkFGaUI7QUFHbENDLEVBQUFBLE9BQU8sRUFBRSxTQUh5QjtBQUlsQ0MsRUFBQUEsY0FBYyxFQUFFLGdCQUprQjtBQUtsQ0MsRUFBQUEsWUFBWSxFQUFFLGNBTG9CO0FBTWxDQyxFQUFBQSxhQUFhLEVBQUUsZUFObUI7QUFPbENDLEVBQUFBLE9BQU8sRUFBRSxTQVB5QjtBQVFsQ0MsRUFBQUEsUUFBUSxFQUFFLFVBUndCO0FBU2xDQyxFQUFBQSxPQUFPLEVBQUUsU0FUeUI7QUFVbENDLEVBQUFBLE9BQU8sRUFBRSxTQVZ5QjtBQVdsQ0MsRUFBQUEsTUFBTSxFQUFFLFFBWDBCO0FBWWxDQyxFQUFBQSxRQUFRLEVBQUUsVUFad0I7QUFhbENDLEVBQUFBLEtBQUssRUFBRSxPQWIyQjtBQWNsQ0MsRUFBQUEsUUFBUSxFQUFFLFVBZHdCO0FBZWxDQyxFQUFBQSxRQUFRLEVBQUU7QUFmd0IsQ0FBcEMiLCJzb3VyY2VzQ29udGVudCI6WyIndXNlIHN0cmljdCc7XHJcblxyXG4vKipcclxuICogQW4gZW51bSBvZiB0YWJsZSBoaW50cyB0byBiZSB1c2VkIGluIG1zc3FsIGZvciBxdWVyeWluZyB3aXRoIHRhYmxlIGhpbnRzXHJcbiAqXHJcbiAqIEBwcm9wZXJ0eSBOT0xPQ0tcclxuICogQHByb3BlcnR5IFJFQURVTkNPTU1JVFRFRFxyXG4gKiBAcHJvcGVydHkgVVBETE9DS1xyXG4gKiBAcHJvcGVydHkgUkVQRUFUQUJMRVJFQURcclxuICogQHByb3BlcnR5IFNFUklBTElaQUJMRVxyXG4gKiBAcHJvcGVydHkgUkVBRENPTU1JVFRFRFxyXG4gKiBAcHJvcGVydHkgVEFCTE9DS1xyXG4gKiBAcHJvcGVydHkgVEFCTE9DS1hcclxuICogQHByb3BlcnR5IFBBR0xPQ0tcclxuICogQHByb3BlcnR5IFJPV0xPQ0tcclxuICogQHByb3BlcnR5IE5PV0FJVFxyXG4gKiBAcHJvcGVydHkgUkVBRFBBU1RcclxuICogQHByb3BlcnR5IFhMT0NLXHJcbiAqIEBwcm9wZXJ0eSBTTkFQU0hPVFxyXG4gKiBAcHJvcGVydHkgTk9FWFBBTkRcclxuICovXHJcbmNvbnN0IFRhYmxlSGludHMgPSBtb2R1bGUuZXhwb3J0cyA9IHsgLy8gZXNsaW50LWRpc2FibGUtbGluZVxyXG4gIE5PTE9DSzogJ05PTE9DSycsXHJcbiAgUkVBRFVOQ09NTUlUVEVEOiAnUkVBRFVOQ09NTUlUVEVEJyxcclxuICBVUERMT0NLOiAnVVBETE9DSycsXHJcbiAgUkVQRUFUQUJMRVJFQUQ6ICdSRVBFQVRBQkxFUkVBRCcsXHJcbiAgU0VSSUFMSVpBQkxFOiAnU0VSSUFMSVpBQkxFJyxcclxuICBSRUFEQ09NTUlUVEVEOiAnUkVBRENPTU1JVFRFRCcsXHJcbiAgVEFCTE9DSzogJ1RBQkxPQ0snLFxyXG4gIFRBQkxPQ0tYOiAnVEFCTE9DS1gnLFxyXG4gIFBBR0xPQ0s6ICdQQUdMT0NLJyxcclxuICBST1dMT0NLOiAnUk9XTE9DSycsXHJcbiAgTk9XQUlUOiAnTk9XQUlUJyxcclxuICBSRUFEUEFTVDogJ1JFQURQQVNUJyxcclxuICBYTE9DSzogJ1hMT0NLJyxcclxuICBTTkFQU0hPVDogJ1NOQVBTSE9UJyxcclxuICBOT0VYUEFORDogJ05PRVhQQU5EJ1xyXG59O1xyXG4iXX0= \ No newline at end of file +//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uL2xpYi90YWJsZS1oaW50cy5qcyJdLCJuYW1lcyI6WyJUYWJsZUhpbnRzIiwibW9kdWxlIiwiZXhwb3J0cyIsIk5PTE9DSyIsIlJFQURVTkNPTU1JVFRFRCIsIlVQRExPQ0siLCJSRVBFQVRBQkxFUkVBRCIsIlNFUklBTElaQUJMRSIsIlJFQURDT01NSVRURUQiLCJUQUJMT0NLIiwiVEFCTE9DS1giLCJQQUdMT0NLIiwiUk9XTE9DSyIsIk5PV0FJVCIsIlJFQURQQVNUIiwiWExPQ0siLCJTTkFQU0hPVCIsIk5PRVhQQU5EIl0sIm1hcHBpbmdzIjoiQUFBQTtBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUNBLE1BQU1BLFVBQVUsR0FBR0MsTUFBTSxDQUFDQyxPQUFQLEdBQWlCO0FBQUU7QUFDcENDLEVBQUFBLE1BQU0sRUFBRSxRQUQwQjtBQUVsQ0MsRUFBQUEsZUFBZSxFQUFFLGlCQUZpQjtBQUdsQ0MsRUFBQUEsT0FBTyxFQUFFLFNBSHlCO0FBSWxDQyxFQUFBQSxjQUFjLEVBQUUsZ0JBSmtCO0FBS2xDQyxFQUFBQSxZQUFZLEVBQUUsY0FMb0I7QUFNbENDLEVBQUFBLGFBQWEsRUFBRSxlQU5tQjtBQU9sQ0MsRUFBQUEsT0FBTyxFQUFFLFNBUHlCO0FBUWxDQyxFQUFBQSxRQUFRLEVBQUUsVUFSd0I7QUFTbENDLEVBQUFBLE9BQU8sRUFBRSxTQVR5QjtBQVVsQ0MsRUFBQUEsT0FBTyxFQUFFLFNBVnlCO0FBV2xDQyxFQUFBQSxNQUFNLEVBQUUsUUFYMEI7QUFZbENDLEVBQUFBLFFBQVEsRUFBRSxVQVp3QjtBQWFsQ0MsRUFBQUEsS0FBSyxFQUFFLE9BYjJCO0FBY2xDQyxFQUFBQSxRQUFRLEVBQUUsVUFkd0I7QUFlbENDLEVBQUFBLFFBQVEsRUFBRTtBQWZ3QixDQUFwQyIsInNvdXJjZXNDb250ZW50IjpbIid1c2Ugc3RyaWN0JztcblxuLyoqXG4gKiBBbiBlbnVtIG9mIHRhYmxlIGhpbnRzIHRvIGJlIHVzZWQgaW4gbXNzcWwgZm9yIHF1ZXJ5aW5nIHdpdGggdGFibGUgaGludHNcbiAqXG4gKiBAcHJvcGVydHkgTk9MT0NLXG4gKiBAcHJvcGVydHkgUkVBRFVOQ09NTUlUVEVEXG4gKiBAcHJvcGVydHkgVVBETE9DS1xuICogQHByb3BlcnR5IFJFUEVBVEFCTEVSRUFEXG4gKiBAcHJvcGVydHkgU0VSSUFMSVpBQkxFXG4gKiBAcHJvcGVydHkgUkVBRENPTU1JVFRFRFxuICogQHByb3BlcnR5IFRBQkxPQ0tcbiAqIEBwcm9wZXJ0eSBUQUJMT0NLWFxuICogQHByb3BlcnR5IFBBR0xPQ0tcbiAqIEBwcm9wZXJ0eSBST1dMT0NLXG4gKiBAcHJvcGVydHkgTk9XQUlUXG4gKiBAcHJvcGVydHkgUkVBRFBBU1RcbiAqIEBwcm9wZXJ0eSBYTE9DS1xuICogQHByb3BlcnR5IFNOQVBTSE9UXG4gKiBAcHJvcGVydHkgTk9FWFBBTkRcbiAqL1xuY29uc3QgVGFibGVIaW50cyA9IG1vZHVsZS5leHBvcnRzID0geyAvLyBlc2xpbnQtZGlzYWJsZS1saW5lXG4gIE5PTE9DSzogJ05PTE9DSycsXG4gIFJFQURVTkNPTU1JVFRFRDogJ1JFQURVTkNPTU1JVFRFRCcsXG4gIFVQRExPQ0s6ICdVUERMT0NLJyxcbiAgUkVQRUFUQUJMRVJFQUQ6ICdSRVBFQVRBQkxFUkVBRCcsXG4gIFNFUklBTElaQUJMRTogJ1NFUklBTElaQUJMRScsXG4gIFJFQURDT01NSVRURUQ6ICdSRUFEQ09NTUlUVEVEJyxcbiAgVEFCTE9DSzogJ1RBQkxPQ0snLFxuICBUQUJMT0NLWDogJ1RBQkxPQ0tYJyxcbiAgUEFHTE9DSzogJ1BBR0xPQ0snLFxuICBST1dMT0NLOiAnUk9XTE9DSycsXG4gIE5PV0FJVDogJ05PV0FJVCcsXG4gIFJFQURQQVNUOiAnUkVBRFBBU1QnLFxuICBYTE9DSzogJ1hMT0NLJyxcbiAgU05BUFNIT1Q6ICdTTkFQU0hPVCcsXG4gIE5PRVhQQU5EOiAnTk9FWFBBTkQnXG59O1xuIl19 \ No newline at end of file diff --git a/dist/transaction.js b/dist/transaction.js index d39c590..b0e381f 100644 --- a/dist/transaction.js +++ b/dist/transaction.js @@ -17,9 +17,7 @@ const Promise = require('./promise'); */ -let Transaction = -/*#__PURE__*/ -function () { +let Transaction = /*#__PURE__*/function () { /** * Creates a new transaction instance * @@ -331,4 +329,4 @@ function () { module.exports = Transaction; module.exports.Transaction = Transaction; module.exports.default = Transaction; -//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../lib/transaction.js"],"names":["Promise","require","Transaction","sequelize","options","savepoints","_afterCommitHooks","generateTransactionId","dialect","QueryGenerator","Object","assign","type","transactionType","isolationLevel","readOnly","parent","transaction","id","push","name","length","finished","reject","Error","_clearCls","getQueryInterface","commitTransaction","finally","cleanup","tap","each","hook","resolve","apply","connection","rollbackTransaction","useCLS","connectionPromise","undefined","acquireOptions","uuid","connectionManager","getConnection","then","begin","setDeferrable","catch","setupErr","rollback","constructor","_cls","set","deferrable","deferConstraints","queryInterface","supports","settingIsolationLevelDuringTransaction","startTransaction","setIsolationLevel","res","releaseConnection","cls","get","fn","LOCK","DEFERRED","IMMEDIATE","EXCLUSIVE","READ_UNCOMMITTED","READ_COMMITTED","REPEATABLE_READ","SERIALIZABLE","UPDATE","SHARE","KEY_SHARE","NO_KEY_UPDATE","module","exports","default"],"mappings":"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","sourcesContent":["'use strict';\r\n\r\nconst Promise = require('./promise');\r\n\r\n/**\r\n * The transaction object is used to identify a running transaction.\r\n * It is created by calling `Sequelize.transaction()`.\r\n * To run a query under a transaction, you should pass the transaction in the options object.\r\n *\r\n * @class Transaction\r\n * @see {@link Sequelize.transaction}\r\n */\r\nclass Transaction {\r\n  /**\r\n   * Creates a new transaction instance\r\n   *\r\n   * @param {Sequelize} sequelize A configured sequelize Instance\r\n   * @param {Object} options An object with options\r\n   * @param {string} [options.type] Sets the type of the transaction. Sqlite only\r\n   * @param {string} [options.isolationLevel] Sets the isolation level of the transaction.\r\n   * @param {string} [options.deferrable] Sets the constraints to be deferred or immediately checked. PostgreSQL only\r\n   */\r\n  constructor(sequelize, options) {\r\n    this.sequelize = sequelize;\r\n    this.savepoints = [];\r\n    this._afterCommitHooks = [];\r\n\r\n    // get dialect specific transaction options\r\n    const generateTransactionId = this.sequelize.dialect.QueryGenerator.generateTransactionId;\r\n\r\n    this.options = Object.assign({\r\n      type: sequelize.options.transactionType,\r\n      isolationLevel: sequelize.options.isolationLevel,\r\n      readOnly: false\r\n    }, options || {});\r\n\r\n    this.parent = this.options.transaction;\r\n\r\n    if (this.parent) {\r\n      this.id = this.parent.id;\r\n      this.parent.savepoints.push(this);\r\n      this.name = `${this.id}-sp-${this.parent.savepoints.length}`;\r\n    } else {\r\n      this.id = this.name = generateTransactionId();\r\n    }\r\n\r\n    delete this.options.transaction;\r\n  }\r\n\r\n  /**\r\n   * Commit the transaction\r\n   *\r\n   * @returns {Promise}\r\n   */\r\n  commit() {\r\n    if (this.finished) {\r\n      return Promise.reject(new Error(`Transaction cannot be committed because it has been finished with state: ${this.finished}`));\r\n    }\r\n\r\n    this._clearCls();\r\n\r\n    return this\r\n      .sequelize\r\n      .getQueryInterface()\r\n      .commitTransaction(this, this.options)\r\n      .finally(() => {\r\n        this.finished = 'commit';\r\n        if (!this.parent) {\r\n          return this.cleanup();\r\n        }\r\n        return null;\r\n      }).tap(\r\n        () => Promise.each(\r\n          this._afterCommitHooks,\r\n          hook => Promise.resolve(hook.apply(this, [this])))\r\n      );\r\n  }\r\n\r\n  /**\r\n   * Rollback (abort) the transaction\r\n   *\r\n   * @returns {Promise}\r\n   */\r\n  rollback() {\r\n    if (this.finished) {\r\n      return Promise.reject(new Error(`Transaction cannot be rolled back because it has been finished with state: ${this.finished}`));\r\n    }\r\n\r\n    if (!this.connection) {\r\n      return Promise.reject(new Error('Transaction cannot be rolled back because it never started'));\r\n    }\r\n\r\n    this._clearCls();\r\n\r\n    return this\r\n      .sequelize\r\n      .getQueryInterface()\r\n      .rollbackTransaction(this, this.options)\r\n      .finally(() => {\r\n        if (!this.parent) {\r\n          return this.cleanup();\r\n        }\r\n        return this;\r\n      });\r\n  }\r\n\r\n  prepareEnvironment(useCLS) {\r\n    let connectionPromise;\r\n\r\n    if (useCLS === undefined) {\r\n      useCLS = true;\r\n    }\r\n\r\n    if (this.parent) {\r\n      connectionPromise = Promise.resolve(this.parent.connection);\r\n    } else {\r\n      const acquireOptions = { uuid: this.id };\r\n      if (this.options.readOnly) {\r\n        acquireOptions.type = 'SELECT';\r\n      }\r\n      connectionPromise = this.sequelize.connectionManager.getConnection(acquireOptions);\r\n    }\r\n\r\n    return connectionPromise\r\n      .then(connection => {\r\n        this.connection = connection;\r\n        this.connection.uuid = this.id;\r\n      })\r\n      .then(() => {\r\n        return this.begin()\r\n          .then(() => this.setDeferrable())\r\n          .catch(setupErr => this.rollback().finally(() => {\r\n            throw setupErr;\r\n          }));\r\n      })\r\n      .tap(() => {\r\n        if (useCLS && this.sequelize.constructor._cls) {\r\n          this.sequelize.constructor._cls.set('transaction', this);\r\n        }\r\n        return null;\r\n      });\r\n  }\r\n\r\n  setDeferrable() {\r\n    if (this.options.deferrable) {\r\n      return this\r\n        .sequelize\r\n        .getQueryInterface()\r\n        .deferConstraints(this, this.options);\r\n    }\r\n  }\r\n\r\n  begin() {\r\n    const queryInterface = this.sequelize.getQueryInterface();\r\n\r\n    if ( this.sequelize.dialect.supports.settingIsolationLevelDuringTransaction ) {\r\n      return queryInterface.startTransaction(this, this.options).then(() => {\r\n        return queryInterface.setIsolationLevel(this, this.options.isolationLevel, this.options);\r\n      });\r\n    }\r\n\r\n    return queryInterface.setIsolationLevel(this, this.options.isolationLevel, this.options).then(() => {\r\n      return queryInterface.startTransaction(this, this.options);\r\n    });\r\n  }\r\n\r\n  cleanup() {\r\n    const res = this.sequelize.connectionManager.releaseConnection(this.connection);\r\n    this.connection.uuid = undefined;\r\n    return res;\r\n  }\r\n\r\n  _clearCls() {\r\n    const cls = this.sequelize.constructor._cls;\r\n\r\n    if (cls) {\r\n      if (cls.get('transaction') === this) {\r\n        cls.set('transaction', null);\r\n      }\r\n    }\r\n  }\r\n\r\n  /**\r\n   * A hook that is run after a transaction is committed\r\n   *\r\n   * @param {Function} fn   A callback function that is called with the committed transaction\r\n   * @name afterCommit\r\n   * @memberof Sequelize.Transaction\r\n   */\r\n  afterCommit(fn) {\r\n    if (!fn || typeof fn !== 'function') {\r\n      throw new Error('\"fn\" must be a function');\r\n    }\r\n    this._afterCommitHooks.push(fn);\r\n  }\r\n\r\n  /**\r\n   * Types can be set per-transaction by passing `options.type` to `sequelize.transaction`.\r\n   * Default to `DEFERRED` but you can override the default type by passing `options.transactionType` in `new Sequelize`.\r\n   * Sqlite only.\r\n   *\r\n   * Pass in the desired level as the first argument:\r\n   *\r\n   * @example\r\n   * return sequelize.transaction({type: Sequelize.Transaction.TYPES.EXCLUSIVE}, transaction => {\r\n   *   // your transactions\r\n   * }).then(result => {\r\n   *   // transaction has been committed. Do something after the commit if required.\r\n   * }).catch(err => {\r\n   *   // do something with the err.\r\n   * });\r\n   *\r\n   * @property DEFERRED\r\n   * @property IMMEDIATE\r\n   * @property EXCLUSIVE\r\n   */\r\n  static get TYPES() {\r\n    return {\r\n      DEFERRED: 'DEFERRED',\r\n      IMMEDIATE: 'IMMEDIATE',\r\n      EXCLUSIVE: 'EXCLUSIVE'\r\n    };\r\n  }\r\n\r\n  /**\r\n   * Isolation levels can be set per-transaction by passing `options.isolationLevel` to `sequelize.transaction`.\r\n   * Sequelize uses the default isolation level of the database, you can override this by passing `options.isolationLevel` in Sequelize constructor options.\r\n   *\r\n   * Pass in the desired level as the first argument:\r\n   *\r\n   * @example\r\n   * return sequelize.transaction({isolationLevel: Sequelize.Transaction.ISOLATION_LEVELS.SERIALIZABLE}, transaction => {\r\n   *   // your transactions\r\n   * }).then(result => {\r\n   *   // transaction has been committed. Do something after the commit if required.\r\n   * }).catch(err => {\r\n   *   // do something with the err.\r\n   * });\r\n   *\r\n   * @property READ_UNCOMMITTED\r\n   * @property READ_COMMITTED\r\n   * @property REPEATABLE_READ\r\n   * @property SERIALIZABLE\r\n   */\r\n  static get ISOLATION_LEVELS() {\r\n    return {\r\n      READ_UNCOMMITTED: 'READ UNCOMMITTED',\r\n      READ_COMMITTED: 'READ COMMITTED',\r\n      REPEATABLE_READ: 'REPEATABLE READ',\r\n      SERIALIZABLE: 'SERIALIZABLE'\r\n    };\r\n  }\r\n\r\n\r\n  /**\r\n   * Possible options for row locking. Used in conjunction with `find` calls:\r\n   *\r\n   * @example\r\n   * // t1 is a transaction\r\n   * Model.findAll({\r\n   *   where: ...,\r\n   *   transaction: t1,\r\n   *   lock: t1.LOCK...\r\n   * });\r\n   *\r\n   * @example <caption>Postgres also supports specific locks while eager loading by using OF:</caption>\r\n   * UserModel.findAll({\r\n   *   where: ...,\r\n   *   include: [TaskModel, ...],\r\n   *   transaction: t1,\r\n   *   lock: {\r\n   *     level: t1.LOCK...,\r\n   *     of: UserModel\r\n   *   }\r\n   * });\r\n   *\r\n   * # UserModel will be locked but TaskModel won't!\r\n   *\r\n   * @example <caption>You can also skip locked rows:</caption>\r\n   * // t1 is a transaction\r\n   * Model.findAll({\r\n   *   where: ...,\r\n   *   transaction: t1,\r\n   *   lock: true,\r\n   *   skipLocked: true\r\n   * });\r\n   * # The query will now return any rows that aren't locked by another transaction\r\n   *\r\n   * @returns {Object}\r\n   * @property UPDATE\r\n   * @property SHARE\r\n   * @property KEY_SHARE Postgres 9.3+ only\r\n   * @property NO_KEY_UPDATE Postgres 9.3+ only\r\n   */\r\n  static get LOCK() {\r\n    return {\r\n      UPDATE: 'UPDATE',\r\n      SHARE: 'SHARE',\r\n      KEY_SHARE: 'KEY SHARE',\r\n      NO_KEY_UPDATE: 'NO KEY UPDATE'\r\n    };\r\n  }\r\n\r\n  /**\r\n   * Please see {@link Transaction.LOCK}\r\n   */\r\n  get LOCK() {\r\n    return Transaction.LOCK;\r\n  }\r\n}\r\n\r\nmodule.exports = Transaction;\r\nmodule.exports.Transaction = Transaction;\r\nmodule.exports.default = Transaction;\r\n"]} \ No newline at end of file +//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../lib/transaction.js"],"names":["Promise","require","Transaction","sequelize","options","savepoints","_afterCommitHooks","generateTransactionId","dialect","QueryGenerator","Object","assign","type","transactionType","isolationLevel","readOnly","parent","transaction","id","push","name","length","finished","reject","Error","_clearCls","getQueryInterface","commitTransaction","finally","cleanup","tap","each","hook","resolve","apply","connection","rollbackTransaction","useCLS","connectionPromise","undefined","acquireOptions","uuid","connectionManager","getConnection","then","begin","setDeferrable","catch","setupErr","rollback","constructor","_cls","set","deferrable","deferConstraints","queryInterface","supports","settingIsolationLevelDuringTransaction","startTransaction","setIsolationLevel","res","releaseConnection","cls","get","fn","LOCK","DEFERRED","IMMEDIATE","EXCLUSIVE","READ_UNCOMMITTED","READ_COMMITTED","REPEATABLE_READ","SERIALIZABLE","UPDATE","SHARE","KEY_SHARE","NO_KEY_UPDATE","module","exports","default"],"mappings":"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","sourcesContent":["'use strict';\n\nconst Promise = require('./promise');\n\n/**\n * The transaction object is used to identify a running transaction.\n * It is created by calling `Sequelize.transaction()`.\n * To run a query under a transaction, you should pass the transaction in the options object.\n *\n * @class Transaction\n * @see {@link Sequelize.transaction}\n */\nclass Transaction {\n  /**\n   * Creates a new transaction instance\n   *\n   * @param {Sequelize} sequelize A configured sequelize Instance\n   * @param {Object} options An object with options\n   * @param {string} [options.type] Sets the type of the transaction. Sqlite only\n   * @param {string} [options.isolationLevel] Sets the isolation level of the transaction.\n   * @param {string} [options.deferrable] Sets the constraints to be deferred or immediately checked. PostgreSQL only\n   */\n  constructor(sequelize, options) {\n    this.sequelize = sequelize;\n    this.savepoints = [];\n    this._afterCommitHooks = [];\n\n    // get dialect specific transaction options\n    const generateTransactionId = this.sequelize.dialect.QueryGenerator.generateTransactionId;\n\n    this.options = Object.assign({\n      type: sequelize.options.transactionType,\n      isolationLevel: sequelize.options.isolationLevel,\n      readOnly: false\n    }, options || {});\n\n    this.parent = this.options.transaction;\n\n    if (this.parent) {\n      this.id = this.parent.id;\n      this.parent.savepoints.push(this);\n      this.name = `${this.id}-sp-${this.parent.savepoints.length}`;\n    } else {\n      this.id = this.name = generateTransactionId();\n    }\n\n    delete this.options.transaction;\n  }\n\n  /**\n   * Commit the transaction\n   *\n   * @returns {Promise}\n   */\n  commit() {\n    if (this.finished) {\n      return Promise.reject(new Error(`Transaction cannot be committed because it has been finished with state: ${this.finished}`));\n    }\n\n    this._clearCls();\n\n    return this\n      .sequelize\n      .getQueryInterface()\n      .commitTransaction(this, this.options)\n      .finally(() => {\n        this.finished = 'commit';\n        if (!this.parent) {\n          return this.cleanup();\n        }\n        return null;\n      }).tap(\n        () => Promise.each(\n          this._afterCommitHooks,\n          hook => Promise.resolve(hook.apply(this, [this])))\n      );\n  }\n\n  /**\n   * Rollback (abort) the transaction\n   *\n   * @returns {Promise}\n   */\n  rollback() {\n    if (this.finished) {\n      return Promise.reject(new Error(`Transaction cannot be rolled back because it has been finished with state: ${this.finished}`));\n    }\n\n    if (!this.connection) {\n      return Promise.reject(new Error('Transaction cannot be rolled back because it never started'));\n    }\n\n    this._clearCls();\n\n    return this\n      .sequelize\n      .getQueryInterface()\n      .rollbackTransaction(this, this.options)\n      .finally(() => {\n        if (!this.parent) {\n          return this.cleanup();\n        }\n        return this;\n      });\n  }\n\n  prepareEnvironment(useCLS) {\n    let connectionPromise;\n\n    if (useCLS === undefined) {\n      useCLS = true;\n    }\n\n    if (this.parent) {\n      connectionPromise = Promise.resolve(this.parent.connection);\n    } else {\n      const acquireOptions = { uuid: this.id };\n      if (this.options.readOnly) {\n        acquireOptions.type = 'SELECT';\n      }\n      connectionPromise = this.sequelize.connectionManager.getConnection(acquireOptions);\n    }\n\n    return connectionPromise\n      .then(connection => {\n        this.connection = connection;\n        this.connection.uuid = this.id;\n      })\n      .then(() => {\n        return this.begin()\n          .then(() => this.setDeferrable())\n          .catch(setupErr => this.rollback().finally(() => {\n            throw setupErr;\n          }));\n      })\n      .tap(() => {\n        if (useCLS && this.sequelize.constructor._cls) {\n          this.sequelize.constructor._cls.set('transaction', this);\n        }\n        return null;\n      });\n  }\n\n  setDeferrable() {\n    if (this.options.deferrable) {\n      return this\n        .sequelize\n        .getQueryInterface()\n        .deferConstraints(this, this.options);\n    }\n  }\n\n  begin() {\n    const queryInterface = this.sequelize.getQueryInterface();\n\n    if ( this.sequelize.dialect.supports.settingIsolationLevelDuringTransaction ) {\n      return queryInterface.startTransaction(this, this.options).then(() => {\n        return queryInterface.setIsolationLevel(this, this.options.isolationLevel, this.options);\n      });\n    }\n\n    return queryInterface.setIsolationLevel(this, this.options.isolationLevel, this.options).then(() => {\n      return queryInterface.startTransaction(this, this.options);\n    });\n  }\n\n  cleanup() {\n    const res = this.sequelize.connectionManager.releaseConnection(this.connection);\n    this.connection.uuid = undefined;\n    return res;\n  }\n\n  _clearCls() {\n    const cls = this.sequelize.constructor._cls;\n\n    if (cls) {\n      if (cls.get('transaction') === this) {\n        cls.set('transaction', null);\n      }\n    }\n  }\n\n  /**\n   * A hook that is run after a transaction is committed\n   *\n   * @param {Function} fn   A callback function that is called with the committed transaction\n   * @name afterCommit\n   * @memberof Sequelize.Transaction\n   */\n  afterCommit(fn) {\n    if (!fn || typeof fn !== 'function') {\n      throw new Error('\"fn\" must be a function');\n    }\n    this._afterCommitHooks.push(fn);\n  }\n\n  /**\n   * Types can be set per-transaction by passing `options.type` to `sequelize.transaction`.\n   * Default to `DEFERRED` but you can override the default type by passing `options.transactionType` in `new Sequelize`.\n   * Sqlite only.\n   *\n   * Pass in the desired level as the first argument:\n   *\n   * @example\n   * return sequelize.transaction({type: Sequelize.Transaction.TYPES.EXCLUSIVE}, transaction => {\n   *   // your transactions\n   * }).then(result => {\n   *   // transaction has been committed. Do something after the commit if required.\n   * }).catch(err => {\n   *   // do something with the err.\n   * });\n   *\n   * @property DEFERRED\n   * @property IMMEDIATE\n   * @property EXCLUSIVE\n   */\n  static get TYPES() {\n    return {\n      DEFERRED: 'DEFERRED',\n      IMMEDIATE: 'IMMEDIATE',\n      EXCLUSIVE: 'EXCLUSIVE'\n    };\n  }\n\n  /**\n   * Isolation levels can be set per-transaction by passing `options.isolationLevel` to `sequelize.transaction`.\n   * Sequelize uses the default isolation level of the database, you can override this by passing `options.isolationLevel` in Sequelize constructor options.\n   *\n   * Pass in the desired level as the first argument:\n   *\n   * @example\n   * return sequelize.transaction({isolationLevel: Sequelize.Transaction.ISOLATION_LEVELS.SERIALIZABLE}, transaction => {\n   *   // your transactions\n   * }).then(result => {\n   *   // transaction has been committed. Do something after the commit if required.\n   * }).catch(err => {\n   *   // do something with the err.\n   * });\n   *\n   * @property READ_UNCOMMITTED\n   * @property READ_COMMITTED\n   * @property REPEATABLE_READ\n   * @property SERIALIZABLE\n   */\n  static get ISOLATION_LEVELS() {\n    return {\n      READ_UNCOMMITTED: 'READ UNCOMMITTED',\n      READ_COMMITTED: 'READ COMMITTED',\n      REPEATABLE_READ: 'REPEATABLE READ',\n      SERIALIZABLE: 'SERIALIZABLE'\n    };\n  }\n\n\n  /**\n   * Possible options for row locking. Used in conjunction with `find` calls:\n   *\n   * @example\n   * // t1 is a transaction\n   * Model.findAll({\n   *   where: ...,\n   *   transaction: t1,\n   *   lock: t1.LOCK...\n   * });\n   *\n   * @example <caption>Postgres also supports specific locks while eager loading by using OF:</caption>\n   * UserModel.findAll({\n   *   where: ...,\n   *   include: [TaskModel, ...],\n   *   transaction: t1,\n   *   lock: {\n   *     level: t1.LOCK...,\n   *     of: UserModel\n   *   }\n   * });\n   *\n   * # UserModel will be locked but TaskModel won't!\n   *\n   * @example <caption>You can also skip locked rows:</caption>\n   * // t1 is a transaction\n   * Model.findAll({\n   *   where: ...,\n   *   transaction: t1,\n   *   lock: true,\n   *   skipLocked: true\n   * });\n   * # The query will now return any rows that aren't locked by another transaction\n   *\n   * @returns {Object}\n   * @property UPDATE\n   * @property SHARE\n   * @property KEY_SHARE Postgres 9.3+ only\n   * @property NO_KEY_UPDATE Postgres 9.3+ only\n   */\n  static get LOCK() {\n    return {\n      UPDATE: 'UPDATE',\n      SHARE: 'SHARE',\n      KEY_SHARE: 'KEY SHARE',\n      NO_KEY_UPDATE: 'NO KEY UPDATE'\n    };\n  }\n\n  /**\n   * Please see {@link Transaction.LOCK}\n   */\n  get LOCK() {\n    return Transaction.LOCK;\n  }\n}\n\nmodule.exports = Transaction;\nmodule.exports.Transaction = Transaction;\nmodule.exports.default = Transaction;\n"]} \ No newline at end of file diff --git a/dist/utils.js b/dist/utils.js index 0d5ff09..99aeefa 100644 --- a/dist/utils.js +++ b/dist/utils.js @@ -4,15 +4,19 @@ function _defineProperties(target, props) { for (var i = 0; i < props.length; i+ function _createClass(Constructor, protoProps, staticProps) { if (protoProps) _defineProperties(Constructor.prototype, protoProps); if (staticProps) _defineProperties(Constructor, staticProps); return Constructor; } +function _inherits(subClass, superClass) { if (typeof superClass !== "function" && superClass !== null) { throw new TypeError("Super expression must either be null or a function"); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, writable: true, configurable: true } }); if (superClass) _setPrototypeOf(subClass, superClass); } + +function _setPrototypeOf(o, p) { _setPrototypeOf = Object.setPrototypeOf || function _setPrototypeOf(o, p) { o.__proto__ = p; return o; }; return _setPrototypeOf(o, p); } + +function _createSuper(Derived) { var hasNativeReflectConstruct = _isNativeReflectConstruct(); return function _createSuperInternal() { var Super = _getPrototypeOf(Derived), result; if (hasNativeReflectConstruct) { var NewTarget = _getPrototypeOf(this).constructor; result = Reflect.construct(Super, arguments, NewTarget); } else { result = Super.apply(this, arguments); } return _possibleConstructorReturn(this, result); }; } + function _possibleConstructorReturn(self, call) { if (call && (typeof call === "object" || typeof call === "function")) { return call; } return _assertThisInitialized(self); } function _assertThisInitialized(self) { if (self === void 0) { throw new ReferenceError("this hasn't been initialised - super() hasn't been called"); } return self; } -function _getPrototypeOf(o) { _getPrototypeOf = Object.setPrototypeOf ? Object.getPrototypeOf : function _getPrototypeOf(o) { return o.__proto__ || Object.getPrototypeOf(o); }; return _getPrototypeOf(o); } - -function _inherits(subClass, superClass) { if (typeof superClass !== "function" && superClass !== null) { throw new TypeError("Super expression must either be null or a function"); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, writable: true, configurable: true } }); if (superClass) _setPrototypeOf(subClass, superClass); } +function _isNativeReflectConstruct() { if (typeof Reflect === "undefined" || !Reflect.construct) return false; if (Reflect.construct.sham) return false; if (typeof Proxy === "function") return true; try { Date.prototype.toString.call(Reflect.construct(Date, [], function () {})); return true; } catch (e) { return false; } } -function _setPrototypeOf(o, p) { _setPrototypeOf = Object.setPrototypeOf || function _setPrototypeOf(o, p) { o.__proto__ = p; return o; }; return _setPrototypeOf(o, p); } +function _getPrototypeOf(o) { _getPrototypeOf = Object.setPrototypeOf ? Object.getPrototypeOf : function _getPrototypeOf(o) { return o.__proto__ || Object.getPrototypeOf(o); }; return _getPrototypeOf(o); } function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } } @@ -475,17 +479,17 @@ let SequelizeMethod = function SequelizeMethod() { exports.SequelizeMethod = SequelizeMethod; -let Fn = -/*#__PURE__*/ -function (_SequelizeMethod) { +let Fn = /*#__PURE__*/function (_SequelizeMethod) { _inherits(Fn, _SequelizeMethod); + var _super = _createSuper(Fn); + function Fn(fn, args) { var _this; _classCallCheck(this, Fn); - _this = _possibleConstructorReturn(this, _getPrototypeOf(Fn).call(this)); + _this = _super.call(this); _this.fn = fn; _this.args = args; return _this; @@ -503,17 +507,17 @@ function (_SequelizeMethod) { exports.Fn = Fn; -let Col = -/*#__PURE__*/ -function (_SequelizeMethod2) { +let Col = /*#__PURE__*/function (_SequelizeMethod2) { _inherits(Col, _SequelizeMethod2); + var _super2 = _createSuper(Col); + function Col(col, ...args) { var _this2; _classCallCheck(this, Col); - _this2 = _possibleConstructorReturn(this, _getPrototypeOf(Col).call(this)); + _this2 = _super2.call(this); if (args.length > 0) { col = args; @@ -528,17 +532,17 @@ function (_SequelizeMethod2) { exports.Col = Col; -let Cast = -/*#__PURE__*/ -function (_SequelizeMethod3) { +let Cast = /*#__PURE__*/function (_SequelizeMethod3) { _inherits(Cast, _SequelizeMethod3); + var _super3 = _createSuper(Cast); + function Cast(val, type, json) { var _this3; _classCallCheck(this, Cast); - _this3 = _possibleConstructorReturn(this, _getPrototypeOf(Cast).call(this)); + _this3 = _super3.call(this); _this3.val = val; _this3.type = (type || '').trim(); _this3.json = json || false; @@ -550,17 +554,17 @@ function (_SequelizeMethod3) { exports.Cast = Cast; -let Literal = -/*#__PURE__*/ -function (_SequelizeMethod4) { +let Literal = /*#__PURE__*/function (_SequelizeMethod4) { _inherits(Literal, _SequelizeMethod4); + var _super4 = _createSuper(Literal); + function Literal(val) { var _this4; _classCallCheck(this, Literal); - _this4 = _possibleConstructorReturn(this, _getPrototypeOf(Literal).call(this)); + _this4 = _super4.call(this); _this4.val = val; return _this4; } @@ -570,17 +574,17 @@ function (_SequelizeMethod4) { exports.Literal = Literal; -let Json = -/*#__PURE__*/ -function (_SequelizeMethod5) { +let Json = /*#__PURE__*/function (_SequelizeMethod5) { _inherits(Json, _SequelizeMethod5); + var _super5 = _createSuper(Json); + function Json(conditionsOrPath, value) { var _this5; _classCallCheck(this, Json); - _this5 = _possibleConstructorReturn(this, _getPrototypeOf(Json).call(this)); + _this5 = _super5.call(this); if (_.isObject(conditionsOrPath)) { _this5.conditions = conditionsOrPath; @@ -600,17 +604,17 @@ function (_SequelizeMethod5) { exports.Json = Json; -let Where = -/*#__PURE__*/ -function (_SequelizeMethod6) { +let Where = /*#__PURE__*/function (_SequelizeMethod6) { _inherits(Where, _SequelizeMethod6); + var _super6 = _createSuper(Where); + function Where(attribute, comparator, logic) { var _this6; _classCallCheck(this, Where); - _this6 = _possibleConstructorReturn(this, _getPrototypeOf(Where).call(this)); + _this6 = _super6.call(this); if (logic === undefined) { logic = comparator; @@ -779,4 +783,4 @@ function intersects(arr1, arr2) { } exports.intersects = intersects; -//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../lib/utils.js"],"names":["DataTypes","require","SqlString","_","uuidv1","uuidv4","Promise","operators","operatorsSet","Set","values","inflection","exports","classToInvokable","useInflection","_inflection","camelizeIf","str","condition","result","camelize","underscoredIf","underscore","isPrimitive","val","type","mergeDefaults","a","b","mergeWith","objectValue","isPlainObject","undefined","merge","obj","arguments","forOwn","value","key","Array","isArray","concat","spliceStr","index","count","add","slice","trim","replace","match","c","toUpperCase","singularize","pluralize","format","arr","dialect","timeZone","formatNamedParameters","sql","parameters","cloneDeep","onlyPlain","cloneDeepWith","elem","clone","mapFinderOptions","options","Model","attributes","_injectDependentVirtualAttributes","filter","v","_virtualAttributes","has","mapOptionFieldNames","map","attr","rawAttributes","field","where","mapWhereFieldNames","getComplexKeys","forEach","attribute","rawAttribute","fieldName","HSTORE","JSON","mapValueFieldNames","dataValues","fields","isColString","length","canTreatArrayAsAnd","some","arg","Where","combineTableNames","tableName1","tableName2","toLowerCase","toDefaultValue","tmp","ABSTRACT","toSql","UUIDV1","UUIDV4","NOW","now","defaultValueSchemable","removeNullValuesFromHash","hash","omitNull","allowNull","_hash","forIn","includes","endsWith","stack","orig","Error","prepareStackTrace","err","captureStackTrace","errStack","dialects","d","Date","setMilliseconds","TICK_CHAR","addTicks","s","tickChar","removeTicks","RegExp","flattenObjectDeep","flattenedObj","flattenObject","subPath","Object","keys","pathToProperty","get","SequelizeMethod","Fn","fn","args","Col","col","Cast","json","Literal","Json","conditionsOrPath","isObject","conditions","path","comparator","logic","getOperators","getOwnPropertySymbols","getComplexSize","isWhereEmpty","isEmpty","generateEnumName","tableName","columnName","camelizeObjectKeys","newObj","defaults","object","sources","source","eq","prototype","hasOwnProperty","call","nameIndex","name","join","intersects","arr1","arr2"],"mappings":"AAAA;;;;;;;;;;;;;;;;;;AAEA,MAAMA,SAAS,GAAGC,OAAO,CAAC,cAAD,CAAzB;;AACA,MAAMC,SAAS,GAAGD,OAAO,CAAC,cAAD,CAAzB;;AACA,MAAME,CAAC,GAAGF,OAAO,CAAC,QAAD,CAAjB;;AACA,MAAMG,MAAM,GAAGH,OAAO,CAAC,SAAD,CAAtB;;AACA,MAAMI,MAAM,GAAGJ,OAAO,CAAC,SAAD,CAAtB;;AACA,MAAMK,OAAO,GAAGL,OAAO,CAAC,WAAD,CAAvB;;AACA,MAAMM,SAAS,GAAGN,OAAO,CAAC,aAAD,CAAzB;;AACA,MAAMO,YAAY,GAAG,IAAIC,GAAJ,CAAQN,CAAC,CAACO,MAAF,CAASH,SAAT,CAAR,CAArB;;AAEA,IAAII,UAAU,GAAGV,OAAO,CAAC,YAAD,CAAxB;;AAEAW,OAAO,CAACC,gBAAR,GAA2BZ,OAAO,CAAC,0BAAD,CAAP,CAAoCY,gBAA/D;AAEAD,OAAO,CAACN,OAAR,GAAkBA,OAAlB;;AAEA,SAASQ,aAAT,CAAuBC,WAAvB,EAAoC;AAClCJ,EAAAA,UAAU,GAAGI,WAAb;AACD;;AACDH,OAAO,CAACE,aAAR,GAAwBA,aAAxB;;AAEA,SAASE,UAAT,CAAoBC,GAApB,EAAyBC,SAAzB,EAAoC;AAClC,MAAIC,MAAM,GAAGF,GAAb;;AAEA,MAAIC,SAAJ,EAAe;AACbC,IAAAA,MAAM,GAAGC,QAAQ,CAACH,GAAD,CAAjB;AACD;;AAED,SAAOE,MAAP;AACD;;AACDP,OAAO,CAACI,UAAR,GAAqBA,UAArB;;AAEA,SAASK,aAAT,CAAuBJ,GAAvB,EAA4BC,SAA5B,EAAuC;AACrC,MAAIC,MAAM,GAAGF,GAAb;;AAEA,MAAIC,SAAJ,EAAe;AACbC,IAAAA,MAAM,GAAGG,UAAU,CAACL,GAAD,CAAnB;AACD;;AAED,SAAOE,MAAP;AACD;;AACDP,OAAO,CAACS,aAAR,GAAwBA,aAAxB;;AAEA,SAASE,WAAT,CAAqBC,GAArB,EAA0B;AACxB,QAAMC,IAAI,GAAG,OAAOD,GAApB;AACA,SAAOC,IAAI,KAAK,QAAT,IAAqBA,IAAI,KAAK,QAA9B,IAA0CA,IAAI,KAAK,SAA1D;AACD;;AACDb,OAAO,CAACW,WAAR,GAAsBA,WAAtB,C,CAEA;;AACA,SAASG,aAAT,CAAuBC,CAAvB,EAA0BC,CAA1B,EAA6B;AAC3B,SAAOzB,CAAC,CAAC0B,SAAF,CAAYF,CAAZ,EAAeC,CAAf,EAAkBE,WAAW,IAAI;AACtC;AACA,QAAI,CAAC3B,CAAC,CAAC4B,aAAF,CAAgBD,WAAhB,CAAD,IAAiCA,WAAW,KAAKE,SAArD,EAAgE;AAC9D,aAAOF,WAAP;AACD;AACF,GALM,CAAP;AAMD;;AACDlB,OAAO,CAACc,aAAR,GAAwBA,aAAxB,C,CAEA;AACA;AACA;;AACA,SAASO,KAAT,GAAiB;AACf,QAAMd,MAAM,GAAG,EAAf;;AAEA,OAAK,MAAMe,GAAX,IAAkBC,SAAlB,EAA6B;AAC3BhC,IAAAA,CAAC,CAACiC,MAAF,CAASF,GAAT,EAAc,CAACG,KAAD,EAAQC,GAAR,KAAgB;AAC5B,UAAID,KAAK,KAAKL,SAAd,EAAyB;AACvB,YAAI,CAACb,MAAM,CAACmB,GAAD,CAAX,EAAkB;AAChBnB,UAAAA,MAAM,CAACmB,GAAD,CAAN,GAAcD,KAAd;AACD,SAFD,MAEO,IAAIlC,CAAC,CAAC4B,aAAF,CAAgBM,KAAhB,KAA0BlC,CAAC,CAAC4B,aAAF,CAAgBZ,MAAM,CAACmB,GAAD,CAAtB,CAA9B,EAA4D;AACjEnB,UAAAA,MAAM,CAACmB,GAAD,CAAN,GAAcL,KAAK,CAACd,MAAM,CAACmB,GAAD,CAAP,EAAcD,KAAd,CAAnB;AACD,SAFM,MAEA,IAAIE,KAAK,CAACC,OAAN,CAAcH,KAAd,KAAwBE,KAAK,CAACC,OAAN,CAAcrB,MAAM,CAACmB,GAAD,CAApB,CAA5B,EAAwD;AAC7DnB,UAAAA,MAAM,CAACmB,GAAD,CAAN,GAAcD,KAAK,CAACI,MAAN,CAAatB,MAAM,CAACmB,GAAD,CAAnB,CAAd;AACD,SAFM,MAEA;AACLnB,UAAAA,MAAM,CAACmB,GAAD,CAAN,GAAcD,KAAd;AACD;AACF;AACF,KAZD;AAaD;;AAED,SAAOlB,MAAP;AACD;;AACDP,OAAO,CAACqB,KAAR,GAAgBA,KAAhB;;AAEA,SAASS,SAAT,CAAmBzB,GAAnB,EAAwB0B,KAAxB,EAA+BC,KAA/B,EAAsCC,GAAtC,EAA2C;AACzC,SAAO5B,GAAG,CAAC6B,KAAJ,CAAU,CAAV,EAAaH,KAAb,IAAsBE,GAAtB,GAA4B5B,GAAG,CAAC6B,KAAJ,CAAUH,KAAK,GAAGC,KAAlB,CAAnC;AACD;;AACDhC,OAAO,CAAC8B,SAAR,GAAoBA,SAApB;;AAEA,SAAStB,QAAT,CAAkBH,GAAlB,EAAuB;AACrB,SAAOA,GAAG,CAAC8B,IAAJ,GAAWC,OAAX,CAAmB,cAAnB,EAAmC,CAACC,KAAD,EAAQC,CAAR,KAAcA,CAAC,CAACC,WAAF,EAAjD,CAAP;AACD;;AACDvC,OAAO,CAACQ,QAAR,GAAmBA,QAAnB;;AAEA,SAASE,UAAT,CAAoBL,GAApB,EAAyB;AACvB,SAAON,UAAU,CAACW,UAAX,CAAsBL,GAAtB,CAAP;AACD;;AACDL,OAAO,CAACU,UAAR,GAAqBA,UAArB;;AAEA,SAAS8B,WAAT,CAAqBnC,GAArB,EAA0B;AACxB,SAAON,UAAU,CAACyC,WAAX,CAAuBnC,GAAvB,CAAP;AACD;;AACDL,OAAO,CAACwC,WAAR,GAAsBA,WAAtB;;AAEA,SAASC,SAAT,CAAmBpC,GAAnB,EAAwB;AACtB,SAAON,UAAU,CAAC0C,SAAX,CAAqBpC,GAArB,CAAP;AACD;;AACDL,OAAO,CAACyC,SAAR,GAAoBA,SAApB;;AAEA,SAASC,MAAT,CAAgBC,GAAhB,EAAqBC,OAArB,EAA8B;AAC5B,QAAMC,QAAQ,GAAG,IAAjB,CAD4B,CAE5B;;AACA,SAAOvD,SAAS,CAACoD,MAAV,CAAiBC,GAAG,CAAC,CAAD,CAApB,EAAyBA,GAAG,CAACT,KAAJ,CAAU,CAAV,CAAzB,EAAuCW,QAAvC,EAAiDD,OAAjD,CAAP;AACD;;AACD5C,OAAO,CAAC0C,MAAR,GAAiBA,MAAjB;;AAEA,SAASI,qBAAT,CAA+BC,GAA/B,EAAoCC,UAApC,EAAgDJ,OAAhD,EAAyD;AACvD,QAAMC,QAAQ,GAAG,IAAjB;AACA,SAAOvD,SAAS,CAACwD,qBAAV,CAAgCC,GAAhC,EAAqCC,UAArC,EAAiDH,QAAjD,EAA2DD,OAA3D,CAAP;AACD;;AACD5C,OAAO,CAAC8C,qBAAR,GAAgCA,qBAAhC;;AAEA,SAASG,SAAT,CAAmB3B,GAAnB,EAAwB4B,SAAxB,EAAmC;AACjC5B,EAAAA,GAAG,GAAGA,GAAG,IAAI,EAAb;AACA,SAAO/B,CAAC,CAAC4D,aAAF,CAAgB7B,GAAhB,EAAqB8B,IAAI,IAAI;AAClC;AACA,QAAIzB,KAAK,CAACC,OAAN,CAAcwB,IAAd,KAAuB7D,CAAC,CAAC4B,aAAF,CAAgBiC,IAAhB,CAA3B,EAAkD;AAChD,aAAOhC,SAAP;AACD,KAJiC,CAMlC;AACA;;;AACA,QAAI8B,SAAS,IAAI,OAAOE,IAAP,KAAgB,QAAjC,EAA2C;AACzC,aAAOA,IAAP;AACD,KAViC,CAYlC;;;AACA,QAAIA,IAAI,IAAI,OAAOA,IAAI,CAACC,KAAZ,KAAsB,UAAlC,EAA8C;AAC5C,aAAOD,IAAI,CAACC,KAAL,EAAP;AACD;AACF,GAhBM,CAAP;AAiBD;;AACDrD,OAAO,CAACiD,SAAR,GAAoBA,SAApB;AAEA;;AACA,SAASK,gBAAT,CAA0BC,OAA1B,EAAmCC,KAAnC,EAA0C;AACxC,MAAID,OAAO,CAACE,UAAR,IAAsB9B,KAAK,CAACC,OAAN,CAAc2B,OAAO,CAACE,UAAtB,CAA1B,EAA6D;AAC3DF,IAAAA,OAAO,CAACE,UAAR,GAAqBD,KAAK,CAACE,iCAAN,CAAwCH,OAAO,CAACE,UAAhD,CAArB;AACAF,IAAAA,OAAO,CAACE,UAAR,GAAqBF,OAAO,CAACE,UAAR,CAAmBE,MAAnB,CAA0BC,CAAC,IAAI,CAACJ,KAAK,CAACK,kBAAN,CAAyBC,GAAzB,CAA6BF,CAA7B,CAAhC,CAArB;AACD;;AAEDG,EAAAA,mBAAmB,CAACR,OAAD,EAAUC,KAAV,CAAnB;AAEA,SAAOD,OAAP;AACD;;AACDvD,OAAO,CAACsD,gBAAR,GAA2BA,gBAA3B;AAEA;;AACA,SAASS,mBAAT,CAA6BR,OAA7B,EAAsCC,KAAtC,EAA6C;AAC3C,MAAI7B,KAAK,CAACC,OAAN,CAAc2B,OAAO,CAACE,UAAtB,CAAJ,EAAuC;AACrCF,IAAAA,OAAO,CAACE,UAAR,GAAqBF,OAAO,CAACE,UAAR,CAAmBO,GAAnB,CAAuBC,IAAI,IAAI;AAClD;AACA,UAAI,OAAOA,IAAP,KAAgB,QAApB,EAA8B,OAAOA,IAAP,CAFoB,CAGlD;;AACA,UAAIT,KAAK,CAACU,aAAN,CAAoBD,IAApB,KAA6BA,IAAI,KAAKT,KAAK,CAACU,aAAN,CAAoBD,IAApB,EAA0BE,KAApE,EAA2E;AACzE,eAAO,CAACX,KAAK,CAACU,aAAN,CAAoBD,IAApB,EAA0BE,KAA3B,EAAkCF,IAAlC,CAAP;AACD;;AACD,aAAOA,IAAP;AACD,KARoB,CAArB;AASD;;AAED,MAAIV,OAAO,CAACa,KAAR,IAAiB7E,CAAC,CAAC4B,aAAF,CAAgBoC,OAAO,CAACa,KAAxB,CAArB,EAAqD;AACnDb,IAAAA,OAAO,CAACa,KAAR,GAAgBC,kBAAkB,CAACd,OAAO,CAACa,KAAT,EAAgBZ,KAAhB,CAAlC;AACD;;AAED,SAAOD,OAAP;AACD;;AACDvD,OAAO,CAAC+D,mBAAR,GAA8BA,mBAA9B;;AAEA,SAASM,kBAAT,CAA4BZ,UAA5B,EAAwCD,KAAxC,EAA+C;AAC7C,MAAIC,UAAJ,EAAgB;AACda,IAAAA,cAAc,CAACb,UAAD,CAAd,CAA2Bc,OAA3B,CAAmCC,SAAS,IAAI;AAC9C,YAAMC,YAAY,GAAGjB,KAAK,CAACU,aAAN,CAAoBM,SAApB,CAArB;;AAEA,UAAIC,YAAY,IAAIA,YAAY,CAACN,KAAb,KAAuBM,YAAY,CAACC,SAAxD,EAAmE;AACjEjB,QAAAA,UAAU,CAACgB,YAAY,CAACN,KAAd,CAAV,GAAiCV,UAAU,CAACe,SAAD,CAA3C;AACA,eAAOf,UAAU,CAACe,SAAD,CAAjB;AACD;;AAED,UAAIjF,CAAC,CAAC4B,aAAF,CAAgBsC,UAAU,CAACe,SAAD,CAA1B,KACC,EAAEC,YAAY,KACfA,YAAY,CAAC5D,IAAb,YAA6BzB,SAAS,CAACuF,MAAvC,IACGF,YAAY,CAAC5D,IAAb,YAA6BzB,SAAS,CAACwF,IAF3B,CAAd,CADL,EAGsD;AAAE;AACtDnB,QAAAA,UAAU,CAACe,SAAD,CAAV,GAAwBT,mBAAmB,CAAC;AAC1CK,UAAAA,KAAK,EAAEX,UAAU,CAACe,SAAD;AADyB,SAAD,EAExChB,KAFwC,CAAnB,CAEdY,KAFV;AAGD;;AAED,UAAIzC,KAAK,CAACC,OAAN,CAAc6B,UAAU,CAACe,SAAD,CAAxB,CAAJ,EAA0C;AACxCf,QAAAA,UAAU,CAACe,SAAD,CAAV,CAAsBD,OAAtB,CAA8B,CAACH,KAAD,EAAQrC,KAAR,KAAkB;AAC9C,cAAIxC,CAAC,CAAC4B,aAAF,CAAgBiD,KAAhB,CAAJ,EAA4B;AAC1BX,YAAAA,UAAU,CAACe,SAAD,CAAV,CAAsBzC,KAAtB,IAA+BsC,kBAAkB,CAACD,KAAD,EAAQZ,KAAR,CAAjD;AACD;AACF,SAJD;AAKD;AAEF,KAzBD;AA0BD;;AAED,SAAOC,UAAP;AACD;;AACDzD,OAAO,CAACqE,kBAAR,GAA6BA,kBAA7B;AAEA;;AACA,SAASQ,kBAAT,CAA4BC,UAA5B,EAAwCC,MAAxC,EAAgDvB,KAAhD,EAAuD;AACrD,QAAM1D,MAAM,GAAG,EAAf;;AAEA,OAAK,MAAMmE,IAAX,IAAmBc,MAAnB,EAA2B;AACzB,QAAID,UAAU,CAACb,IAAD,CAAV,KAAqB7C,SAArB,IAAkC,CAACoC,KAAK,CAACK,kBAAN,CAAyBC,GAAzB,CAA6BG,IAA7B,CAAvC,EAA2E;AACzE;AACA,UAAIT,KAAK,CAACU,aAAN,CAAoBD,IAApB,KAA6BT,KAAK,CAACU,aAAN,CAAoBD,IAApB,EAA0BE,KAAvD,IAAgEX,KAAK,CAACU,aAAN,CAAoBD,IAApB,EAA0BE,KAA1B,KAAoCF,IAAxG,EAA8G;AAC5GnE,QAAAA,MAAM,CAAC0D,KAAK,CAACU,aAAN,CAAoBD,IAApB,EAA0BE,KAA3B,CAAN,GAA0CW,UAAU,CAACb,IAAD,CAApD;AACD,OAFD,MAEO;AACLnE,QAAAA,MAAM,CAACmE,IAAD,CAAN,GAAea,UAAU,CAACb,IAAD,CAAzB;AACD;AACF;AACF;;AAED,SAAOnE,MAAP;AACD;;AACDE,OAAO,CAAC6E,kBAAR,GAA6BA,kBAA7B;;AAEA,SAASG,WAAT,CAAqBvD,KAArB,EAA4B;AAC1B,SAAO,OAAOA,KAAP,KAAiB,QAAjB,IAA6BA,KAAK,CAAC,CAAD,CAAL,KAAa,GAA1C,IAAiDA,KAAK,CAACA,KAAK,CAACwD,MAAN,GAAe,CAAhB,CAAL,KAA4B,GAApF;AACD;;AACDjF,OAAO,CAACgF,WAAR,GAAsBA,WAAtB;;AAEA,SAASE,kBAAT,CAA4BvC,GAA5B,EAAiC;AAC/B,SAAOA,GAAG,CAACwC,IAAJ,CAASC,GAAG,IAAI7F,CAAC,CAAC4B,aAAF,CAAgBiE,GAAhB,KAAwBA,GAAG,YAAYC,KAAvD,CAAP;AACD;;AACDrF,OAAO,CAACkF,kBAAR,GAA6BA,kBAA7B;;AAEA,SAASI,iBAAT,CAA2BC,UAA3B,EAAuCC,UAAvC,EAAmD;AACjD,SAAOD,UAAU,CAACE,WAAX,KAA2BD,UAAU,CAACC,WAAX,EAA3B,GAAsDF,UAAU,GAAGC,UAAnE,GAAgFA,UAAU,GAAGD,UAApG;AACD;;AACDvF,OAAO,CAACsF,iBAAR,GAA4BA,iBAA5B;;AAEA,SAASI,cAAT,CAAwBjE,KAAxB,EAA+BmB,OAA/B,EAAwC;AACtC,MAAI,OAAOnB,KAAP,KAAiB,UAArB,EAAiC;AAC/B,UAAMkE,GAAG,GAAGlE,KAAK,EAAjB;;AACA,QAAIkE,GAAG,YAAYvG,SAAS,CAACwG,QAA7B,EAAuC;AACrC,aAAOD,GAAG,CAACE,KAAJ,EAAP;AACD;;AACD,WAAOF,GAAP;AACD;;AACD,MAAIlE,KAAK,YAAYrC,SAAS,CAAC0G,MAA/B,EAAuC;AACrC,WAAOtG,MAAM,EAAb;AACD;;AACD,MAAIiC,KAAK,YAAYrC,SAAS,CAAC2G,MAA/B,EAAuC;AACrC,WAAOtG,MAAM,EAAb;AACD;;AACD,MAAIgC,KAAK,YAAYrC,SAAS,CAAC4G,GAA/B,EAAoC;AAClC,WAAOC,GAAG,CAACrD,OAAD,CAAV;AACD;;AACD,MAAIrD,CAAC,CAAC4B,aAAF,CAAgBM,KAAhB,KAA0BE,KAAK,CAACC,OAAN,CAAcH,KAAd,CAA9B,EAAoD;AAClD,WAAOlC,CAAC,CAAC8D,KAAF,CAAQ5B,KAAR,CAAP;AACD;;AACD,SAAOA,KAAP;AACD;;AACDzB,OAAO,CAAC0F,cAAR,GAAyBA,cAAzB;AAEA;;;;;;;;;AAQA,SAASQ,qBAAT,CAA+BzE,KAA/B,EAAsC;AACpC,MAAIA,KAAK,KAAKL,SAAd,EAAyB;AAAE,WAAO,KAAP;AAAe,GADN,CAGpC;AACA;;;AACA,MAAIK,KAAK,YAAYrC,SAAS,CAAC4G,GAA/B,EAAoC;AAAE,WAAO,KAAP;AAAe;;AAErD,MAAIvE,KAAK,YAAYrC,SAAS,CAAC0G,MAA3B,IAAqCrE,KAAK,YAAYrC,SAAS,CAAC2G,MAApE,EAA4E;AAAE,WAAO,KAAP;AAAe;;AAE7F,SAAO,OAAOtE,KAAP,KAAiB,UAAxB;AACD;;AACDzB,OAAO,CAACkG,qBAAR,GAAgCA,qBAAhC;;AAEA,SAASC,wBAAT,CAAkCC,IAAlC,EAAwCC,QAAxC,EAAkD9C,OAAlD,EAA2D;AACzD,MAAIhD,MAAM,GAAG6F,IAAb;AAEA7C,EAAAA,OAAO,GAAGA,OAAO,IAAI,EAArB;AACAA,EAAAA,OAAO,CAAC+C,SAAR,GAAoB/C,OAAO,CAAC+C,SAAR,IAAqB,EAAzC;;AAEA,MAAID,QAAJ,EAAc;AACZ,UAAME,KAAK,GAAG,EAAd;;AAEAhH,IAAAA,CAAC,CAACiH,KAAF,CAAQJ,IAAR,EAAc,CAACxF,GAAD,EAAMc,GAAN,KAAc;AAC1B,UAAI6B,OAAO,CAAC+C,SAAR,CAAkBG,QAAlB,CAA2B/E,GAA3B,KAAmCA,GAAG,CAACgF,QAAJ,CAAa,IAAb,CAAnC,IAAyD9F,GAAG,KAAK,IAAR,IAAgBA,GAAG,KAAKQ,SAArF,EAAgG;AAC9FmF,QAAAA,KAAK,CAAC7E,GAAD,CAAL,GAAad,GAAb;AACD;AACF,KAJD;;AAMAL,IAAAA,MAAM,GAAGgG,KAAT;AACD;;AAED,SAAOhG,MAAP;AACD;;AACDP,OAAO,CAACmG,wBAAR,GAAmCA,wBAAnC;;AAEA,SAASQ,KAAT,GAAiB;AACf,QAAMC,IAAI,GAAGC,KAAK,CAACC,iBAAnB;;AACAD,EAAAA,KAAK,CAACC,iBAAN,GAA0B,CAACvH,CAAD,EAAIoH,KAAJ,KAAcA,KAAxC;;AACA,QAAMI,GAAG,GAAG,IAAIF,KAAJ,EAAZ;AACAA,EAAAA,KAAK,CAACG,iBAAN,CAAwBD,GAAxB,EAA6BJ,KAA7B;AACA,QAAMM,QAAQ,GAAGF,GAAG,CAACJ,KAArB;AACAE,EAAAA,KAAK,CAACC,iBAAN,GAA0BF,IAA1B;AACA,SAAOK,QAAP;AACD;;AACDjH,OAAO,CAAC2G,KAAR,GAAgBA,KAAhB;AAEA,MAAMO,QAAQ,GAAG,IAAIrH,GAAJ,CAAQ,CAAC,SAAD,EAAY,OAAZ,EAAqB,UAArB,EAAiC,QAAjC,EAA2C,OAA3C,CAAR,CAAjB;;AAEA,SAASoG,GAAT,CAAarD,OAAb,EAAsB;AACpB,QAAMuE,CAAC,GAAG,IAAIC,IAAJ,EAAV;;AACA,MAAI,CAACF,QAAQ,CAACpD,GAAT,CAAalB,OAAb,CAAL,EAA4B;AAC1BuE,IAAAA,CAAC,CAACE,eAAF,CAAkB,CAAlB;AACD;;AACD,SAAOF,CAAP;AACD;;AACDnH,OAAO,CAACiG,GAAR,GAAcA,GAAd,C,CAEA;AACA;;AAEA,MAAMqB,SAAS,GAAG,GAAlB;AACAtH,OAAO,CAACsH,SAAR,GAAoBA,SAApB;;AAEA,SAASC,QAAT,CAAkBC,CAAlB,EAAqBC,QAArB,EAA+B;AAC7BA,EAAAA,QAAQ,GAAGA,QAAQ,IAAIH,SAAvB;AACA,SAAOG,QAAQ,GAAGC,WAAW,CAACF,CAAD,EAAIC,QAAJ,CAAtB,GAAsCA,QAA7C;AACD;;AACDzH,OAAO,CAACuH,QAAR,GAAmBA,QAAnB;;AAEA,SAASG,WAAT,CAAqBF,CAArB,EAAwBC,QAAxB,EAAkC;AAChCA,EAAAA,QAAQ,GAAGA,QAAQ,IAAIH,SAAvB;AACA,SAAOE,CAAC,CAACpF,OAAF,CAAU,IAAIuF,MAAJ,CAAWF,QAAX,EAAqB,GAArB,CAAV,EAAqC,EAArC,CAAP;AACD;;AACDzH,OAAO,CAAC0H,WAAR,GAAsBA,WAAtB;AAEA;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AA6BA,SAASE,iBAAT,CAA2BnG,KAA3B,EAAkC;AAChC,MAAI,CAAClC,CAAC,CAAC4B,aAAF,CAAgBM,KAAhB,CAAL,EAA6B,OAAOA,KAAP;AAC7B,QAAMoG,YAAY,GAAG,EAArB;;AAEA,WAASC,aAAT,CAAuBxG,GAAvB,EAA4ByG,OAA5B,EAAqC;AACnCC,IAAAA,MAAM,CAACC,IAAP,CAAY3G,GAAZ,EAAiBiD,OAAjB,CAAyB7C,GAAG,IAAI;AAC9B,YAAMwG,cAAc,GAAGH,OAAO,GAAI,GAAEA,OAAQ,IAAGrG,GAAI,EAArB,GAAyBA,GAAvD;;AACA,UAAI,OAAOJ,GAAG,CAACI,GAAD,CAAV,KAAoB,QAApB,IAAgCJ,GAAG,CAACI,GAAD,CAAH,KAAa,IAAjD,EAAuD;AACrDoG,QAAAA,aAAa,CAACxG,GAAG,CAACI,GAAD,CAAJ,EAAWwG,cAAX,CAAb;AACD,OAFD,MAEO;AACLL,QAAAA,YAAY,CAACK,cAAD,CAAZ,GAA+B3I,CAAC,CAAC4I,GAAF,CAAM7G,GAAN,EAAWI,GAAX,CAA/B;AACD;AACF,KAPD;AAQA,WAAOmG,YAAP;AACD;;AAED,SAAOC,aAAa,CAACrG,KAAD,EAAQL,SAAR,CAApB;AACD;;AACDpB,OAAO,CAAC4H,iBAAR,GAA4BA,iBAA5B;AAEA;;;;;;IAKMQ,e;;;;AACNpI,OAAO,CAACoI,eAAR,GAA0BA,eAA1B;;IAEMC,E;;;;;AACJ,cAAYC,EAAZ,EAAgBC,IAAhB,EAAsB;AAAA;;AAAA;;AACpB;AACA,UAAKD,EAAL,GAAUA,EAAV;AACA,UAAKC,IAAL,GAAYA,IAAZ;AAHoB;AAIrB;;;;4BACO;AACN,aAAO,IAAIF,EAAJ,CAAO,KAAKC,EAAZ,EAAgB,KAAKC,IAArB,CAAP;AACD;;;;EARcH,e;;AAUjBpI,OAAO,CAACqI,EAAR,GAAaA,EAAb;;IAEMG,G;;;;;AACJ,eAAYC,GAAZ,EAAiB,GAAGF,IAApB,EAA0B;AAAA;;AAAA;;AACxB;;AACA,QAAIA,IAAI,CAACtD,MAAL,GAAc,CAAlB,EAAqB;AACnBwD,MAAAA,GAAG,GAAGF,IAAN;AACD;;AACD,WAAKE,GAAL,GAAWA,GAAX;AALwB;AAMzB;;;EAPeL,e;;AASlBpI,OAAO,CAACwI,GAAR,GAAcA,GAAd;;IAEME,I;;;;;AACJ,gBAAY9H,GAAZ,EAAiBC,IAAjB,EAAuB8H,IAAvB,EAA6B;AAAA;;AAAA;;AAC3B;AACA,WAAK/H,GAAL,GAAWA,GAAX;AACA,WAAKC,IAAL,GAAY,CAACA,IAAI,IAAI,EAAT,EAAasB,IAAb,EAAZ;AACA,WAAKwG,IAAL,GAAYA,IAAI,IAAI,KAApB;AAJ2B;AAK5B;;;EANgBP,e;;AAQnBpI,OAAO,CAAC0I,IAAR,GAAeA,IAAf;;IAEME,O;;;;;AACJ,mBAAYhI,GAAZ,EAAiB;AAAA;;AAAA;;AACf;AACA,WAAKA,GAAL,GAAWA,GAAX;AAFe;AAGhB;;;EAJmBwH,e;;AAMtBpI,OAAO,CAAC4I,OAAR,GAAkBA,OAAlB;;IAEMC,I;;;;;AACJ,gBAAYC,gBAAZ,EAA8BrH,KAA9B,EAAqC;AAAA;;AAAA;;AACnC;;AACA,QAAIlC,CAAC,CAACwJ,QAAF,CAAWD,gBAAX,CAAJ,EAAkC;AAChC,aAAKE,UAAL,GAAkBF,gBAAlB;AACD,KAFD,MAEO;AACL,aAAKG,IAAL,GAAYH,gBAAZ;;AACA,UAAIrH,KAAJ,EAAW;AACT,eAAKA,KAAL,GAAaA,KAAb;AACD;AACF;;AATkC;AAUpC;;;EAXgB2G,e;;AAanBpI,OAAO,CAAC6I,IAAR,GAAeA,IAAf;;IAEMxD,K;;;;;AACJ,iBAAYb,SAAZ,EAAuB0E,UAAvB,EAAmCC,KAAnC,EAA0C;AAAA;;AAAA;;AACxC;;AACA,QAAIA,KAAK,KAAK/H,SAAd,EAAyB;AACvB+H,MAAAA,KAAK,GAAGD,UAAR;AACAA,MAAAA,UAAU,GAAG,GAAb;AACD;;AAED,WAAK1E,SAAL,GAAiBA,SAAjB;AACA,WAAK0E,UAAL,GAAkBA,UAAlB;AACA,WAAKC,KAAL,GAAaA,KAAb;AATwC;AAUzC;;;EAXiBf,e;;AAapBpI,OAAO,CAACqF,KAAR,GAAgBA,KAAhB,C,CAEA;;AAEA;;;;;;;;AAOA,SAAS+D,YAAT,CAAsB9H,GAAtB,EAA2B;AACzB,SAAO0G,MAAM,CAACqB,qBAAP,CAA6B/H,GAA7B,EAAkCqC,MAAlC,CAAyC6D,CAAC,IAAI5H,YAAY,CAACkE,GAAb,CAAiB0D,CAAjB,CAA9C,CAAP;AACD;;AACDxH,OAAO,CAACoJ,YAAR,GAAuBA,YAAvB;AAEA;;;;;;;;AAOA,SAAS9E,cAAT,CAAwBhD,GAAxB,EAA6B;AAC3B,SAAO8H,YAAY,CAAC9H,GAAD,CAAZ,CAAkBO,MAAlB,CAAyBmG,MAAM,CAACC,IAAP,CAAY3G,GAAZ,CAAzB,CAAP;AACD;;AACDtB,OAAO,CAACsE,cAAR,GAAyBA,cAAzB;AAEA;;;;;;;;AAOA,SAASgF,cAAT,CAAwBhI,GAAxB,EAA6B;AAC3B,SAAOK,KAAK,CAACC,OAAN,CAAcN,GAAd,IAAqBA,GAAG,CAAC2D,MAAzB,GAAkCX,cAAc,CAAChD,GAAD,CAAd,CAAoB2D,MAA7D;AACD;;AACDjF,OAAO,CAACsJ,cAAR,GAAyBA,cAAzB;AAEA;;;;;;;;AAOA,SAASC,YAAT,CAAsBjI,GAAtB,EAA2B;AACzB,SAAO,CAAC,CAACA,GAAF,IAAS/B,CAAC,CAACiK,OAAF,CAAUlI,GAAV,CAAT,IAA2B8H,YAAY,CAAC9H,GAAD,CAAZ,CAAkB2D,MAAlB,KAA6B,CAA/D;AACD;;AACDjF,OAAO,CAACuJ,YAAR,GAAuBA,YAAvB;AAEA;;;;;;;;;AAQA,SAASE,gBAAT,CAA0BC,SAA1B,EAAqCC,UAArC,EAAiD;AAC/C,SAAQ,QAAOD,SAAU,IAAGC,UAAW,EAAvC;AACD;;AACD3J,OAAO,CAACyJ,gBAAR,GAA2BA,gBAA3B;AAEA;;;;;;;;AAOA,SAASG,kBAAT,CAA4BtI,GAA5B,EAAiC;AAC/B,QAAMuI,MAAM,GAAG,IAAI7B,MAAJ,EAAf;AACAA,EAAAA,MAAM,CAACC,IAAP,CAAY3G,GAAZ,EAAiBiD,OAAjB,CAAyB7C,GAAG,IAAI;AAC9BmI,IAAAA,MAAM,CAACrJ,QAAQ,CAACkB,GAAD,CAAT,CAAN,GAAwBJ,GAAG,CAACI,GAAD,CAA3B;AACD,GAFD;AAGA,SAAOmI,MAAP;AACD;;AACD7J,OAAO,CAAC4J,kBAAR,GAA6BA,kBAA7B;AAEA;;;;;;;;;;;;;;AAaA,SAASE,QAAT,CAAkBC,MAAlB,EAA0B,GAAGC,OAA7B,EAAsC;AACpCD,EAAAA,MAAM,GAAG/B,MAAM,CAAC+B,MAAD,CAAf;AAEAC,EAAAA,OAAO,CAACzF,OAAR,CAAgB0F,MAAM,IAAI;AACxB,QAAIA,MAAJ,EAAY;AACVA,MAAAA,MAAM,GAAGjC,MAAM,CAACiC,MAAD,CAAf;AAEA3F,MAAAA,cAAc,CAAC2F,MAAD,CAAd,CAAuB1F,OAAvB,CAA+B7C,GAAG,IAAI;AACpC,cAAMD,KAAK,GAAGsI,MAAM,CAACrI,GAAD,CAApB;;AACA,YACED,KAAK,KAAKL,SAAV,IACE7B,CAAC,CAAC2K,EAAF,CAAKzI,KAAL,EAAYuG,MAAM,CAACmC,SAAP,CAAiBzI,GAAjB,CAAZ,KACA,CAACsG,MAAM,CAACmC,SAAP,CAAiBC,cAAjB,CAAgCC,IAAhC,CAAqCN,MAArC,EAA6CrI,GAA7C,CAHL,EAKE;AACAqI,UAAAA,MAAM,CAACrI,GAAD,CAAN,GAAcuI,MAAM,CAACvI,GAAD,CAApB;AACD;AACF,OAVD;AAWD;AACF,GAhBD;AAkBA,SAAOqI,MAAP;AACD;;AACD/J,OAAO,CAAC8J,QAAR,GAAmBA,QAAnB;AAEA;;;;;;;;;;;AAUA,SAASQ,SAAT,CAAmBvI,KAAnB,EAA0B2H,SAA1B,EAAqC;AACnC,MAAIA,SAAS,CAACA,SAAd,EAAyBA,SAAS,GAAGA,SAAS,CAACA,SAAtB;;AAEzB,MAAI,CAAC1B,MAAM,CAACmC,SAAP,CAAiBC,cAAjB,CAAgCC,IAAhC,CAAqCtI,KAArC,EAA4C,MAA5C,CAAL,EAA0D;AACxD,UAAMgD,MAAM,GAAGhD,KAAK,CAACgD,MAAN,CAAaf,GAAb,CACbG,KAAK,IAAI,OAAOA,KAAP,KAAiB,QAAjB,GAA4BA,KAA5B,GAAoCA,KAAK,CAACoG,IAAN,IAAcpG,KAAK,CAACK,SADpD,CAAf;AAGAzC,IAAAA,KAAK,CAACwI,IAAN,GAAa7J,UAAU,CAAE,GAAEgJ,SAAU,IAAG3E,MAAM,CAACyF,IAAP,CAAY,GAAZ,CAAiB,EAAlC,CAAvB;AACD;;AAED,SAAOzI,KAAP;AACD;;AACD/B,OAAO,CAACsK,SAAR,GAAoBA,SAApB;AAEA;;;;;;;;AAOA,SAASG,UAAT,CAAoBC,IAApB,EAA0BC,IAA1B,EAAgC;AAC9B,SAAOD,IAAI,CAACvF,IAAL,CAAUvB,CAAC,IAAI+G,IAAI,CAAClE,QAAL,CAAc7C,CAAd,CAAf,CAAP;AACD;;AACD5D,OAAO,CAACyK,UAAR,GAAqBA,UAArB","sourcesContent":["'use strict';\r\n\r\nconst DataTypes = require('./data-types');\r\nconst SqlString = require('./sql-string');\r\nconst _ = require('lodash');\r\nconst uuidv1 = require('uuid/v1');\r\nconst uuidv4 = require('uuid/v4');\r\nconst Promise = require('./promise');\r\nconst operators = require('./operators');\r\nconst operatorsSet = new Set(_.values(operators));\r\n\r\nlet inflection = require('inflection');\r\n\r\nexports.classToInvokable = require('./utils/classToInvokable').classToInvokable;\r\n\r\nexports.Promise = Promise;\r\n\r\nfunction useInflection(_inflection) {\r\n  inflection = _inflection;\r\n}\r\nexports.useInflection = useInflection;\r\n\r\nfunction camelizeIf(str, condition) {\r\n  let result = str;\r\n\r\n  if (condition) {\r\n    result = camelize(str);\r\n  }\r\n\r\n  return result;\r\n}\r\nexports.camelizeIf = camelizeIf;\r\n\r\nfunction underscoredIf(str, condition) {\r\n  let result = str;\r\n\r\n  if (condition) {\r\n    result = underscore(str);\r\n  }\r\n\r\n  return result;\r\n}\r\nexports.underscoredIf = underscoredIf;\r\n\r\nfunction isPrimitive(val) {\r\n  const type = typeof val;\r\n  return type === 'string' || type === 'number' || type === 'boolean';\r\n}\r\nexports.isPrimitive = isPrimitive;\r\n\r\n// Same concept as _.merge, but don't overwrite properties that have already been assigned\r\nfunction mergeDefaults(a, b) {\r\n  return _.mergeWith(a, b, objectValue => {\r\n    // If it's an object, let _ handle it this time, we will be called again for each property\r\n    if (!_.isPlainObject(objectValue) && objectValue !== undefined) {\r\n      return objectValue;\r\n    }\r\n  });\r\n}\r\nexports.mergeDefaults = mergeDefaults;\r\n\r\n// An alternative to _.merge, which doesn't clone its arguments\r\n// Cloning is a bad idea because options arguments may contain references to sequelize\r\n// models - which again reference database libs which don't like to be cloned (in particular pg-native)\r\nfunction merge() {\r\n  const result = {};\r\n\r\n  for (const obj of arguments) {\r\n    _.forOwn(obj, (value, key) => {\r\n      if (value !== undefined) {\r\n        if (!result[key]) {\r\n          result[key] = value;\r\n        } else if (_.isPlainObject(value) && _.isPlainObject(result[key])) {\r\n          result[key] = merge(result[key], value);\r\n        } else if (Array.isArray(value) && Array.isArray(result[key])) {\r\n          result[key] = value.concat(result[key]);\r\n        } else {\r\n          result[key] = value;\r\n        }\r\n      }\r\n    });\r\n  }\r\n\r\n  return result;\r\n}\r\nexports.merge = merge;\r\n\r\nfunction spliceStr(str, index, count, add) {\r\n  return str.slice(0, index) + add + str.slice(index + count);\r\n}\r\nexports.spliceStr = spliceStr;\r\n\r\nfunction camelize(str) {\r\n  return str.trim().replace(/[-_\\s]+(.)?/g, (match, c) => c.toUpperCase());\r\n}\r\nexports.camelize = camelize;\r\n\r\nfunction underscore(str) {\r\n  return inflection.underscore(str);\r\n}\r\nexports.underscore = underscore;\r\n\r\nfunction singularize(str) {\r\n  return inflection.singularize(str);\r\n}\r\nexports.singularize = singularize;\r\n\r\nfunction pluralize(str) {\r\n  return inflection.pluralize(str);\r\n}\r\nexports.pluralize = pluralize;\r\n\r\nfunction format(arr, dialect) {\r\n  const timeZone = null;\r\n  // Make a clone of the array beacuse format modifies the passed args\r\n  return SqlString.format(arr[0], arr.slice(1), timeZone, dialect);\r\n}\r\nexports.format = format;\r\n\r\nfunction formatNamedParameters(sql, parameters, dialect) {\r\n  const timeZone = null;\r\n  return SqlString.formatNamedParameters(sql, parameters, timeZone, dialect);\r\n}\r\nexports.formatNamedParameters = formatNamedParameters;\r\n\r\nfunction cloneDeep(obj, onlyPlain) {\r\n  obj = obj || {};\r\n  return _.cloneDeepWith(obj, elem => {\r\n    // Do not try to customize cloning of arrays or POJOs\r\n    if (Array.isArray(elem) || _.isPlainObject(elem)) {\r\n      return undefined;\r\n    }\r\n\r\n    // If we specified to clone only plain objects & arrays, we ignore everyhing else\r\n    // In any case, don't clone stuff that's an object, but not a plain one - fx example sequelize models and instances\r\n    if (onlyPlain || typeof elem === 'object') {\r\n      return elem;\r\n    }\r\n\r\n    // Preserve special data-types like `fn` across clones. _.get() is used for checking up the prototype chain\r\n    if (elem && typeof elem.clone === 'function') {\r\n      return elem.clone();\r\n    }\r\n  });\r\n}\r\nexports.cloneDeep = cloneDeep;\r\n\r\n/* Expand and normalize finder options */\r\nfunction mapFinderOptions(options, Model) {\r\n  if (options.attributes && Array.isArray(options.attributes)) {\r\n    options.attributes = Model._injectDependentVirtualAttributes(options.attributes);\r\n    options.attributes = options.attributes.filter(v => !Model._virtualAttributes.has(v));\r\n  }\r\n\r\n  mapOptionFieldNames(options, Model);\r\n\r\n  return options;\r\n}\r\nexports.mapFinderOptions = mapFinderOptions;\r\n\r\n/* Used to map field names in attributes and where conditions */\r\nfunction mapOptionFieldNames(options, Model) {\r\n  if (Array.isArray(options.attributes)) {\r\n    options.attributes = options.attributes.map(attr => {\r\n      // Object lookups will force any variable to strings, we don't want that for special objects etc\r\n      if (typeof attr !== 'string') return attr;\r\n      // Map attributes to aliased syntax attributes\r\n      if (Model.rawAttributes[attr] && attr !== Model.rawAttributes[attr].field) {\r\n        return [Model.rawAttributes[attr].field, attr];\r\n      }\r\n      return attr;\r\n    });\r\n  }\r\n\r\n  if (options.where && _.isPlainObject(options.where)) {\r\n    options.where = mapWhereFieldNames(options.where, Model);\r\n  }\r\n\r\n  return options;\r\n}\r\nexports.mapOptionFieldNames = mapOptionFieldNames;\r\n\r\nfunction mapWhereFieldNames(attributes, Model) {\r\n  if (attributes) {\r\n    getComplexKeys(attributes).forEach(attribute => {\r\n      const rawAttribute = Model.rawAttributes[attribute];\r\n\r\n      if (rawAttribute && rawAttribute.field !== rawAttribute.fieldName) {\r\n        attributes[rawAttribute.field] = attributes[attribute];\r\n        delete attributes[attribute];\r\n      }\r\n\r\n      if (_.isPlainObject(attributes[attribute])\r\n        && !(rawAttribute && (\r\n          rawAttribute.type instanceof DataTypes.HSTORE\r\n          || rawAttribute.type instanceof DataTypes.JSON))) { // Prevent renaming of HSTORE & JSON fields\r\n        attributes[attribute] = mapOptionFieldNames({\r\n          where: attributes[attribute]\r\n        }, Model).where;\r\n      }\r\n\r\n      if (Array.isArray(attributes[attribute])) {\r\n        attributes[attribute].forEach((where, index) => {\r\n          if (_.isPlainObject(where)) {\r\n            attributes[attribute][index] = mapWhereFieldNames(where, Model);\r\n          }\r\n        });\r\n      }\r\n\r\n    });\r\n  }\r\n\r\n  return attributes;\r\n}\r\nexports.mapWhereFieldNames = mapWhereFieldNames;\r\n\r\n/* Used to map field names in values */\r\nfunction mapValueFieldNames(dataValues, fields, Model) {\r\n  const values = {};\r\n\r\n  for (const attr of fields) {\r\n    if (dataValues[attr] !== undefined && !Model._virtualAttributes.has(attr)) {\r\n      // Field name mapping\r\n      if (Model.rawAttributes[attr] && Model.rawAttributes[attr].field && Model.rawAttributes[attr].field !== attr) {\r\n        values[Model.rawAttributes[attr].field] = dataValues[attr];\r\n      } else {\r\n        values[attr] = dataValues[attr];\r\n      }\r\n    }\r\n  }\r\n\r\n  return values;\r\n}\r\nexports.mapValueFieldNames = mapValueFieldNames;\r\n\r\nfunction isColString(value) {\r\n  return typeof value === 'string' && value[0] === '$' && value[value.length - 1] === '$';\r\n}\r\nexports.isColString = isColString;\r\n\r\nfunction canTreatArrayAsAnd(arr) {\r\n  return arr.some(arg => _.isPlainObject(arg) || arg instanceof Where);\r\n}\r\nexports.canTreatArrayAsAnd = canTreatArrayAsAnd;\r\n\r\nfunction combineTableNames(tableName1, tableName2) {\r\n  return tableName1.toLowerCase() < tableName2.toLowerCase() ? tableName1 + tableName2 : tableName2 + tableName1;\r\n}\r\nexports.combineTableNames = combineTableNames;\r\n\r\nfunction toDefaultValue(value, dialect) {\r\n  if (typeof value === 'function') {\r\n    const tmp = value();\r\n    if (tmp instanceof DataTypes.ABSTRACT) {\r\n      return tmp.toSql();\r\n    }\r\n    return tmp;\r\n  }\r\n  if (value instanceof DataTypes.UUIDV1) {\r\n    return uuidv1();\r\n  }\r\n  if (value instanceof DataTypes.UUIDV4) {\r\n    return uuidv4();\r\n  }\r\n  if (value instanceof DataTypes.NOW) {\r\n    return now(dialect);\r\n  }\r\n  if (_.isPlainObject(value) || Array.isArray(value)) {\r\n    return _.clone(value);\r\n  }\r\n  return value;\r\n}\r\nexports.toDefaultValue = toDefaultValue;\r\n\r\n/**\r\n * Determine if the default value provided exists and can be described\r\n * in a db schema using the DEFAULT directive.\r\n *\r\n * @param  {*} value Any default value.\r\n * @returns {boolean} yes / no.\r\n * @private\r\n */\r\nfunction defaultValueSchemable(value) {\r\n  if (value === undefined) { return false; }\r\n\r\n  // TODO this will be schemable when all supported db\r\n  // have been normalized for this case\r\n  if (value instanceof DataTypes.NOW) { return false; }\r\n\r\n  if (value instanceof DataTypes.UUIDV1 || value instanceof DataTypes.UUIDV4) { return false; }\r\n\r\n  return typeof value !== 'function';\r\n}\r\nexports.defaultValueSchemable = defaultValueSchemable;\r\n\r\nfunction removeNullValuesFromHash(hash, omitNull, options) {\r\n  let result = hash;\r\n\r\n  options = options || {};\r\n  options.allowNull = options.allowNull || [];\r\n\r\n  if (omitNull) {\r\n    const _hash = {};\r\n\r\n    _.forIn(hash, (val, key) => {\r\n      if (options.allowNull.includes(key) || key.endsWith('Id') || val !== null && val !== undefined) {\r\n        _hash[key] = val;\r\n      }\r\n    });\r\n\r\n    result = _hash;\r\n  }\r\n\r\n  return result;\r\n}\r\nexports.removeNullValuesFromHash = removeNullValuesFromHash;\r\n\r\nfunction stack() {\r\n  const orig = Error.prepareStackTrace;\r\n  Error.prepareStackTrace = (_, stack) => stack;\r\n  const err = new Error();\r\n  Error.captureStackTrace(err, stack);\r\n  const errStack = err.stack;\r\n  Error.prepareStackTrace = orig;\r\n  return errStack;\r\n}\r\nexports.stack = stack;\r\n\r\nconst dialects = new Set(['mariadb', 'mysql', 'postgres', 'sqlite', 'mssql']);\r\n\r\nfunction now(dialect) {\r\n  const d = new Date();\r\n  if (!dialects.has(dialect)) {\r\n    d.setMilliseconds(0);\r\n  }\r\n  return d;\r\n}\r\nexports.now = now;\r\n\r\n// Note: Use the `quoteIdentifier()` and `escape()` methods on the\r\n// `QueryInterface` instead for more portable code.\r\n\r\nconst TICK_CHAR = '`';\r\nexports.TICK_CHAR = TICK_CHAR;\r\n\r\nfunction addTicks(s, tickChar) {\r\n  tickChar = tickChar || TICK_CHAR;\r\n  return tickChar + removeTicks(s, tickChar) + tickChar;\r\n}\r\nexports.addTicks = addTicks;\r\n\r\nfunction removeTicks(s, tickChar) {\r\n  tickChar = tickChar || TICK_CHAR;\r\n  return s.replace(new RegExp(tickChar, 'g'), '');\r\n}\r\nexports.removeTicks = removeTicks;\r\n\r\n/**\r\n * Receives a tree-like object and returns a plain object which depth is 1.\r\n *\r\n * - Input:\r\n *\r\n *  {\r\n *    name: 'John',\r\n *    address: {\r\n *      street: 'Fake St. 123',\r\n *      coordinates: {\r\n *        longitude: 55.6779627,\r\n *        latitude: 12.5964313\r\n *      }\r\n *    }\r\n *  }\r\n *\r\n * - Output:\r\n *\r\n *  {\r\n *    name: 'John',\r\n *    address.street: 'Fake St. 123',\r\n *    address.coordinates.latitude: 55.6779627,\r\n *    address.coordinates.longitude: 12.5964313\r\n *  }\r\n *\r\n * @param {Object} value an Object\r\n * @returns {Object} a flattened object\r\n * @private\r\n */\r\nfunction flattenObjectDeep(value) {\r\n  if (!_.isPlainObject(value)) return value;\r\n  const flattenedObj = {};\r\n\r\n  function flattenObject(obj, subPath) {\r\n    Object.keys(obj).forEach(key => {\r\n      const pathToProperty = subPath ? `${subPath}.${key}` : key;\r\n      if (typeof obj[key] === 'object' && obj[key] !== null) {\r\n        flattenObject(obj[key], pathToProperty);\r\n      } else {\r\n        flattenedObj[pathToProperty] = _.get(obj, key);\r\n      }\r\n    });\r\n    return flattenedObj;\r\n  }\r\n\r\n  return flattenObject(value, undefined);\r\n}\r\nexports.flattenObjectDeep = flattenObjectDeep;\r\n\r\n/**\r\n * Utility functions for representing SQL functions, and columns that should be escaped.\r\n * Please do not use these functions directly, use Sequelize.fn and Sequelize.col instead.\r\n * @private\r\n */\r\nclass SequelizeMethod {}\r\nexports.SequelizeMethod = SequelizeMethod;\r\n\r\nclass Fn extends SequelizeMethod {\r\n  constructor(fn, args) {\r\n    super();\r\n    this.fn = fn;\r\n    this.args = args;\r\n  }\r\n  clone() {\r\n    return new Fn(this.fn, this.args);\r\n  }\r\n}\r\nexports.Fn = Fn;\r\n\r\nclass Col extends SequelizeMethod {\r\n  constructor(col, ...args) {\r\n    super();\r\n    if (args.length > 0) {\r\n      col = args;\r\n    }\r\n    this.col = col;\r\n  }\r\n}\r\nexports.Col = Col;\r\n\r\nclass Cast extends SequelizeMethod {\r\n  constructor(val, type, json) {\r\n    super();\r\n    this.val = val;\r\n    this.type = (type || '').trim();\r\n    this.json = json || false;\r\n  }\r\n}\r\nexports.Cast = Cast;\r\n\r\nclass Literal extends SequelizeMethod {\r\n  constructor(val) {\r\n    super();\r\n    this.val = val;\r\n  }\r\n}\r\nexports.Literal = Literal;\r\n\r\nclass Json extends SequelizeMethod {\r\n  constructor(conditionsOrPath, value) {\r\n    super();\r\n    if (_.isObject(conditionsOrPath)) {\r\n      this.conditions = conditionsOrPath;\r\n    } else {\r\n      this.path = conditionsOrPath;\r\n      if (value) {\r\n        this.value = value;\r\n      }\r\n    }\r\n  }\r\n}\r\nexports.Json = Json;\r\n\r\nclass Where extends SequelizeMethod {\r\n  constructor(attribute, comparator, logic) {\r\n    super();\r\n    if (logic === undefined) {\r\n      logic = comparator;\r\n      comparator = '=';\r\n    }\r\n\r\n    this.attribute = attribute;\r\n    this.comparator = comparator;\r\n    this.logic = logic;\r\n  }\r\n}\r\nexports.Where = Where;\r\n\r\n//Collection of helper methods to make it easier to work with symbol operators\r\n\r\n/**\r\n * getOperators\r\n *\r\n * @param  {Object} obj\r\n * @returns {Array<Symbol>} All operators properties of obj\r\n * @private\r\n */\r\nfunction getOperators(obj) {\r\n  return Object.getOwnPropertySymbols(obj).filter(s => operatorsSet.has(s));\r\n}\r\nexports.getOperators = getOperators;\r\n\r\n/**\r\n * getComplexKeys\r\n *\r\n * @param  {Object} obj\r\n * @returns {Array<string|Symbol>} All keys including operators\r\n * @private\r\n */\r\nfunction getComplexKeys(obj) {\r\n  return getOperators(obj).concat(Object.keys(obj));\r\n}\r\nexports.getComplexKeys = getComplexKeys;\r\n\r\n/**\r\n * getComplexSize\r\n *\r\n * @param  {Object|Array} obj\r\n * @returns {number}      Length of object properties including operators if obj is array returns its length\r\n * @private\r\n */\r\nfunction getComplexSize(obj) {\r\n  return Array.isArray(obj) ? obj.length : getComplexKeys(obj).length;\r\n}\r\nexports.getComplexSize = getComplexSize;\r\n\r\n/**\r\n * Returns true if a where clause is empty, even with Symbols\r\n *\r\n * @param  {Object} obj\r\n * @returns {boolean}\r\n * @private\r\n */\r\nfunction isWhereEmpty(obj) {\r\n  return !!obj && _.isEmpty(obj) && getOperators(obj).length === 0;\r\n}\r\nexports.isWhereEmpty = isWhereEmpty;\r\n\r\n/**\r\n * Returns ENUM name by joining table and column name\r\n *\r\n * @param {string} tableName\r\n * @param {string} columnName\r\n * @returns {string}\r\n * @private\r\n */\r\nfunction generateEnumName(tableName, columnName) {\r\n  return `enum_${tableName}_${columnName}`;\r\n}\r\nexports.generateEnumName = generateEnumName;\r\n\r\n/**\r\n * Returns an new Object which keys are camelized\r\n *\r\n * @param {Object} obj\r\n * @returns {string}\r\n * @private\r\n */\r\nfunction camelizeObjectKeys(obj) {\r\n  const newObj = new Object();\r\n  Object.keys(obj).forEach(key => {\r\n    newObj[camelize(key)] = obj[key];\r\n  });\r\n  return newObj;\r\n}\r\nexports.camelizeObjectKeys = camelizeObjectKeys;\r\n\r\n/**\r\n * Assigns own and inherited enumerable string and symbol keyed properties of source\r\n * objects to the destination object.\r\n *\r\n * https://lodash.com/docs/4.17.4#defaults\r\n *\r\n * **Note:** This method mutates `object`.\r\n *\r\n * @param {Object} object The destination object.\r\n * @param {...Object} [sources] The source objects.\r\n * @returns {Object} Returns `object`.\r\n * @private\r\n */\r\nfunction defaults(object, ...sources) {\r\n  object = Object(object);\r\n\r\n  sources.forEach(source => {\r\n    if (source) {\r\n      source = Object(source);\r\n\r\n      getComplexKeys(source).forEach(key => {\r\n        const value = object[key];\r\n        if (\r\n          value === undefined ||\r\n            _.eq(value, Object.prototype[key]) &&\r\n            !Object.prototype.hasOwnProperty.call(object, key)\r\n\r\n        ) {\r\n          object[key] = source[key];\r\n        }\r\n      });\r\n    }\r\n  });\r\n\r\n  return object;\r\n}\r\nexports.defaults = defaults;\r\n\r\n/**\r\n *\r\n * @param {Object} index\r\n * @param {Array}  index.fields\r\n * @param {string} [index.name]\r\n * @param {string|Object} tableName\r\n *\r\n * @returns {Object}\r\n * @private\r\n */\r\nfunction nameIndex(index, tableName) {\r\n  if (tableName.tableName) tableName = tableName.tableName;\r\n\r\n  if (!Object.prototype.hasOwnProperty.call(index, 'name')) {\r\n    const fields = index.fields.map(\r\n      field => typeof field === 'string' ? field : field.name || field.attribute\r\n    );\r\n    index.name = underscore(`${tableName}_${fields.join('_')}`);\r\n  }\r\n\r\n  return index;\r\n}\r\nexports.nameIndex = nameIndex;\r\n\r\n/**\r\n * Checks if 2 arrays intersect.\r\n *\r\n * @param {Array} arr1\r\n * @param {Array} arr2\r\n * @private\r\n */\r\nfunction intersects(arr1, arr2) {\r\n  return arr1.some(v => arr2.includes(v));\r\n}\r\nexports.intersects = intersects;\r\n"]} \ No newline at end of file +//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../lib/utils.js"],"names":["DataTypes","require","SqlString","_","uuidv1","uuidv4","Promise","operators","operatorsSet","Set","values","inflection","exports","classToInvokable","useInflection","_inflection","camelizeIf","str","condition","result","camelize","underscoredIf","underscore","isPrimitive","val","type","mergeDefaults","a","b","mergeWith","objectValue","isPlainObject","undefined","merge","obj","arguments","forOwn","value","key","Array","isArray","concat","spliceStr","index","count","add","slice","trim","replace","match","c","toUpperCase","singularize","pluralize","format","arr","dialect","timeZone","formatNamedParameters","sql","parameters","cloneDeep","onlyPlain","cloneDeepWith","elem","clone","mapFinderOptions","options","Model","attributes","_injectDependentVirtualAttributes","filter","v","_virtualAttributes","has","mapOptionFieldNames","map","attr","rawAttributes","field","where","mapWhereFieldNames","getComplexKeys","forEach","attribute","rawAttribute","fieldName","HSTORE","JSON","mapValueFieldNames","dataValues","fields","isColString","length","canTreatArrayAsAnd","some","arg","Where","combineTableNames","tableName1","tableName2","toLowerCase","toDefaultValue","tmp","ABSTRACT","toSql","UUIDV1","UUIDV4","NOW","now","defaultValueSchemable","removeNullValuesFromHash","hash","omitNull","allowNull","_hash","forIn","includes","endsWith","stack","orig","Error","prepareStackTrace","err","captureStackTrace","errStack","dialects","d","Date","setMilliseconds","TICK_CHAR","addTicks","s","tickChar","removeTicks","RegExp","flattenObjectDeep","flattenedObj","flattenObject","subPath","Object","keys","pathToProperty","get","SequelizeMethod","Fn","fn","args","Col","col","Cast","json","Literal","Json","conditionsOrPath","isObject","conditions","path","comparator","logic","getOperators","getOwnPropertySymbols","getComplexSize","isWhereEmpty","isEmpty","generateEnumName","tableName","columnName","camelizeObjectKeys","newObj","defaults","object","sources","source","eq","prototype","hasOwnProperty","call","nameIndex","name","join","intersects","arr1","arr2"],"mappings":"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","sourcesContent":["'use strict';\n\nconst DataTypes = require('./data-types');\nconst SqlString = require('./sql-string');\nconst _ = require('lodash');\nconst uuidv1 = require('uuid/v1');\nconst uuidv4 = require('uuid/v4');\nconst Promise = require('./promise');\nconst operators = require('./operators');\nconst operatorsSet = new Set(_.values(operators));\n\nlet inflection = require('inflection');\n\nexports.classToInvokable = require('./utils/classToInvokable').classToInvokable;\n\nexports.Promise = Promise;\n\nfunction useInflection(_inflection) {\n  inflection = _inflection;\n}\nexports.useInflection = useInflection;\n\nfunction camelizeIf(str, condition) {\n  let result = str;\n\n  if (condition) {\n    result = camelize(str);\n  }\n\n  return result;\n}\nexports.camelizeIf = camelizeIf;\n\nfunction underscoredIf(str, condition) {\n  let result = str;\n\n  if (condition) {\n    result = underscore(str);\n  }\n\n  return result;\n}\nexports.underscoredIf = underscoredIf;\n\nfunction isPrimitive(val) {\n  const type = typeof val;\n  return type === 'string' || type === 'number' || type === 'boolean';\n}\nexports.isPrimitive = isPrimitive;\n\n// Same concept as _.merge, but don't overwrite properties that have already been assigned\nfunction mergeDefaults(a, b) {\n  return _.mergeWith(a, b, objectValue => {\n    // If it's an object, let _ handle it this time, we will be called again for each property\n    if (!_.isPlainObject(objectValue) && objectValue !== undefined) {\n      return objectValue;\n    }\n  });\n}\nexports.mergeDefaults = mergeDefaults;\n\n// An alternative to _.merge, which doesn't clone its arguments\n// Cloning is a bad idea because options arguments may contain references to sequelize\n// models - which again reference database libs which don't like to be cloned (in particular pg-native)\nfunction merge() {\n  const result = {};\n\n  for (const obj of arguments) {\n    _.forOwn(obj, (value, key) => {\n      if (value !== undefined) {\n        if (!result[key]) {\n          result[key] = value;\n        } else if (_.isPlainObject(value) && _.isPlainObject(result[key])) {\n          result[key] = merge(result[key], value);\n        } else if (Array.isArray(value) && Array.isArray(result[key])) {\n          result[key] = value.concat(result[key]);\n        } else {\n          result[key] = value;\n        }\n      }\n    });\n  }\n\n  return result;\n}\nexports.merge = merge;\n\nfunction spliceStr(str, index, count, add) {\n  return str.slice(0, index) + add + str.slice(index + count);\n}\nexports.spliceStr = spliceStr;\n\nfunction camelize(str) {\n  return str.trim().replace(/[-_\\s]+(.)?/g, (match, c) => c.toUpperCase());\n}\nexports.camelize = camelize;\n\nfunction underscore(str) {\n  return inflection.underscore(str);\n}\nexports.underscore = underscore;\n\nfunction singularize(str) {\n  return inflection.singularize(str);\n}\nexports.singularize = singularize;\n\nfunction pluralize(str) {\n  return inflection.pluralize(str);\n}\nexports.pluralize = pluralize;\n\nfunction format(arr, dialect) {\n  const timeZone = null;\n  // Make a clone of the array beacuse format modifies the passed args\n  return SqlString.format(arr[0], arr.slice(1), timeZone, dialect);\n}\nexports.format = format;\n\nfunction formatNamedParameters(sql, parameters, dialect) {\n  const timeZone = null;\n  return SqlString.formatNamedParameters(sql, parameters, timeZone, dialect);\n}\nexports.formatNamedParameters = formatNamedParameters;\n\nfunction cloneDeep(obj, onlyPlain) {\n  obj = obj || {};\n  return _.cloneDeepWith(obj, elem => {\n    // Do not try to customize cloning of arrays or POJOs\n    if (Array.isArray(elem) || _.isPlainObject(elem)) {\n      return undefined;\n    }\n\n    // If we specified to clone only plain objects & arrays, we ignore everyhing else\n    // In any case, don't clone stuff that's an object, but not a plain one - fx example sequelize models and instances\n    if (onlyPlain || typeof elem === 'object') {\n      return elem;\n    }\n\n    // Preserve special data-types like `fn` across clones. _.get() is used for checking up the prototype chain\n    if (elem && typeof elem.clone === 'function') {\n      return elem.clone();\n    }\n  });\n}\nexports.cloneDeep = cloneDeep;\n\n/* Expand and normalize finder options */\nfunction mapFinderOptions(options, Model) {\n  if (options.attributes && Array.isArray(options.attributes)) {\n    options.attributes = Model._injectDependentVirtualAttributes(options.attributes);\n    options.attributes = options.attributes.filter(v => !Model._virtualAttributes.has(v));\n  }\n\n  mapOptionFieldNames(options, Model);\n\n  return options;\n}\nexports.mapFinderOptions = mapFinderOptions;\n\n/* Used to map field names in attributes and where conditions */\nfunction mapOptionFieldNames(options, Model) {\n  if (Array.isArray(options.attributes)) {\n    options.attributes = options.attributes.map(attr => {\n      // Object lookups will force any variable to strings, we don't want that for special objects etc\n      if (typeof attr !== 'string') return attr;\n      // Map attributes to aliased syntax attributes\n      if (Model.rawAttributes[attr] && attr !== Model.rawAttributes[attr].field) {\n        return [Model.rawAttributes[attr].field, attr];\n      }\n      return attr;\n    });\n  }\n\n  if (options.where && _.isPlainObject(options.where)) {\n    options.where = mapWhereFieldNames(options.where, Model);\n  }\n\n  return options;\n}\nexports.mapOptionFieldNames = mapOptionFieldNames;\n\nfunction mapWhereFieldNames(attributes, Model) {\n  if (attributes) {\n    getComplexKeys(attributes).forEach(attribute => {\n      const rawAttribute = Model.rawAttributes[attribute];\n\n      if (rawAttribute && rawAttribute.field !== rawAttribute.fieldName) {\n        attributes[rawAttribute.field] = attributes[attribute];\n        delete attributes[attribute];\n      }\n\n      if (_.isPlainObject(attributes[attribute])\n        && !(rawAttribute && (\n          rawAttribute.type instanceof DataTypes.HSTORE\n          || rawAttribute.type instanceof DataTypes.JSON))) { // Prevent renaming of HSTORE & JSON fields\n        attributes[attribute] = mapOptionFieldNames({\n          where: attributes[attribute]\n        }, Model).where;\n      }\n\n      if (Array.isArray(attributes[attribute])) {\n        attributes[attribute].forEach((where, index) => {\n          if (_.isPlainObject(where)) {\n            attributes[attribute][index] = mapWhereFieldNames(where, Model);\n          }\n        });\n      }\n\n    });\n  }\n\n  return attributes;\n}\nexports.mapWhereFieldNames = mapWhereFieldNames;\n\n/* Used to map field names in values */\nfunction mapValueFieldNames(dataValues, fields, Model) {\n  const values = {};\n\n  for (const attr of fields) {\n    if (dataValues[attr] !== undefined && !Model._virtualAttributes.has(attr)) {\n      // Field name mapping\n      if (Model.rawAttributes[attr] && Model.rawAttributes[attr].field && Model.rawAttributes[attr].field !== attr) {\n        values[Model.rawAttributes[attr].field] = dataValues[attr];\n      } else {\n        values[attr] = dataValues[attr];\n      }\n    }\n  }\n\n  return values;\n}\nexports.mapValueFieldNames = mapValueFieldNames;\n\nfunction isColString(value) {\n  return typeof value === 'string' && value[0] === '$' && value[value.length - 1] === '$';\n}\nexports.isColString = isColString;\n\nfunction canTreatArrayAsAnd(arr) {\n  return arr.some(arg => _.isPlainObject(arg) || arg instanceof Where);\n}\nexports.canTreatArrayAsAnd = canTreatArrayAsAnd;\n\nfunction combineTableNames(tableName1, tableName2) {\n  return tableName1.toLowerCase() < tableName2.toLowerCase() ? tableName1 + tableName2 : tableName2 + tableName1;\n}\nexports.combineTableNames = combineTableNames;\n\nfunction toDefaultValue(value, dialect) {\n  if (typeof value === 'function') {\n    const tmp = value();\n    if (tmp instanceof DataTypes.ABSTRACT) {\n      return tmp.toSql();\n    }\n    return tmp;\n  }\n  if (value instanceof DataTypes.UUIDV1) {\n    return uuidv1();\n  }\n  if (value instanceof DataTypes.UUIDV4) {\n    return uuidv4();\n  }\n  if (value instanceof DataTypes.NOW) {\n    return now(dialect);\n  }\n  if (_.isPlainObject(value) || Array.isArray(value)) {\n    return _.clone(value);\n  }\n  return value;\n}\nexports.toDefaultValue = toDefaultValue;\n\n/**\n * Determine if the default value provided exists and can be described\n * in a db schema using the DEFAULT directive.\n *\n * @param  {*} value Any default value.\n * @returns {boolean} yes / no.\n * @private\n */\nfunction defaultValueSchemable(value) {\n  if (value === undefined) { return false; }\n\n  // TODO this will be schemable when all supported db\n  // have been normalized for this case\n  if (value instanceof DataTypes.NOW) { return false; }\n\n  if (value instanceof DataTypes.UUIDV1 || value instanceof DataTypes.UUIDV4) { return false; }\n\n  return typeof value !== 'function';\n}\nexports.defaultValueSchemable = defaultValueSchemable;\n\nfunction removeNullValuesFromHash(hash, omitNull, options) {\n  let result = hash;\n\n  options = options || {};\n  options.allowNull = options.allowNull || [];\n\n  if (omitNull) {\n    const _hash = {};\n\n    _.forIn(hash, (val, key) => {\n      if (options.allowNull.includes(key) || key.endsWith('Id') || val !== null && val !== undefined) {\n        _hash[key] = val;\n      }\n    });\n\n    result = _hash;\n  }\n\n  return result;\n}\nexports.removeNullValuesFromHash = removeNullValuesFromHash;\n\nfunction stack() {\n  const orig = Error.prepareStackTrace;\n  Error.prepareStackTrace = (_, stack) => stack;\n  const err = new Error();\n  Error.captureStackTrace(err, stack);\n  const errStack = err.stack;\n  Error.prepareStackTrace = orig;\n  return errStack;\n}\nexports.stack = stack;\n\nconst dialects = new Set(['mariadb', 'mysql', 'postgres', 'sqlite', 'mssql']);\n\nfunction now(dialect) {\n  const d = new Date();\n  if (!dialects.has(dialect)) {\n    d.setMilliseconds(0);\n  }\n  return d;\n}\nexports.now = now;\n\n// Note: Use the `quoteIdentifier()` and `escape()` methods on the\n// `QueryInterface` instead for more portable code.\n\nconst TICK_CHAR = '`';\nexports.TICK_CHAR = TICK_CHAR;\n\nfunction addTicks(s, tickChar) {\n  tickChar = tickChar || TICK_CHAR;\n  return tickChar + removeTicks(s, tickChar) + tickChar;\n}\nexports.addTicks = addTicks;\n\nfunction removeTicks(s, tickChar) {\n  tickChar = tickChar || TICK_CHAR;\n  return s.replace(new RegExp(tickChar, 'g'), '');\n}\nexports.removeTicks = removeTicks;\n\n/**\n * Receives a tree-like object and returns a plain object which depth is 1.\n *\n * - Input:\n *\n *  {\n *    name: 'John',\n *    address: {\n *      street: 'Fake St. 123',\n *      coordinates: {\n *        longitude: 55.6779627,\n *        latitude: 12.5964313\n *      }\n *    }\n *  }\n *\n * - Output:\n *\n *  {\n *    name: 'John',\n *    address.street: 'Fake St. 123',\n *    address.coordinates.latitude: 55.6779627,\n *    address.coordinates.longitude: 12.5964313\n *  }\n *\n * @param {Object} value an Object\n * @returns {Object} a flattened object\n * @private\n */\nfunction flattenObjectDeep(value) {\n  if (!_.isPlainObject(value)) return value;\n  const flattenedObj = {};\n\n  function flattenObject(obj, subPath) {\n    Object.keys(obj).forEach(key => {\n      const pathToProperty = subPath ? `${subPath}.${key}` : key;\n      if (typeof obj[key] === 'object' && obj[key] !== null) {\n        flattenObject(obj[key], pathToProperty);\n      } else {\n        flattenedObj[pathToProperty] = _.get(obj, key);\n      }\n    });\n    return flattenedObj;\n  }\n\n  return flattenObject(value, undefined);\n}\nexports.flattenObjectDeep = flattenObjectDeep;\n\n/**\n * Utility functions for representing SQL functions, and columns that should be escaped.\n * Please do not use these functions directly, use Sequelize.fn and Sequelize.col instead.\n * @private\n */\nclass SequelizeMethod {}\nexports.SequelizeMethod = SequelizeMethod;\n\nclass Fn extends SequelizeMethod {\n  constructor(fn, args) {\n    super();\n    this.fn = fn;\n    this.args = args;\n  }\n  clone() {\n    return new Fn(this.fn, this.args);\n  }\n}\nexports.Fn = Fn;\n\nclass Col extends SequelizeMethod {\n  constructor(col, ...args) {\n    super();\n    if (args.length > 0) {\n      col = args;\n    }\n    this.col = col;\n  }\n}\nexports.Col = Col;\n\nclass Cast extends SequelizeMethod {\n  constructor(val, type, json) {\n    super();\n    this.val = val;\n    this.type = (type || '').trim();\n    this.json = json || false;\n  }\n}\nexports.Cast = Cast;\n\nclass Literal extends SequelizeMethod {\n  constructor(val) {\n    super();\n    this.val = val;\n  }\n}\nexports.Literal = Literal;\n\nclass Json extends SequelizeMethod {\n  constructor(conditionsOrPath, value) {\n    super();\n    if (_.isObject(conditionsOrPath)) {\n      this.conditions = conditionsOrPath;\n    } else {\n      this.path = conditionsOrPath;\n      if (value) {\n        this.value = value;\n      }\n    }\n  }\n}\nexports.Json = Json;\n\nclass Where extends SequelizeMethod {\n  constructor(attribute, comparator, logic) {\n    super();\n    if (logic === undefined) {\n      logic = comparator;\n      comparator = '=';\n    }\n\n    this.attribute = attribute;\n    this.comparator = comparator;\n    this.logic = logic;\n  }\n}\nexports.Where = Where;\n\n//Collection of helper methods to make it easier to work with symbol operators\n\n/**\n * getOperators\n *\n * @param  {Object} obj\n * @returns {Array<Symbol>} All operators properties of obj\n * @private\n */\nfunction getOperators(obj) {\n  return Object.getOwnPropertySymbols(obj).filter(s => operatorsSet.has(s));\n}\nexports.getOperators = getOperators;\n\n/**\n * getComplexKeys\n *\n * @param  {Object} obj\n * @returns {Array<string|Symbol>} All keys including operators\n * @private\n */\nfunction getComplexKeys(obj) {\n  return getOperators(obj).concat(Object.keys(obj));\n}\nexports.getComplexKeys = getComplexKeys;\n\n/**\n * getComplexSize\n *\n * @param  {Object|Array} obj\n * @returns {number}      Length of object properties including operators if obj is array returns its length\n * @private\n */\nfunction getComplexSize(obj) {\n  return Array.isArray(obj) ? obj.length : getComplexKeys(obj).length;\n}\nexports.getComplexSize = getComplexSize;\n\n/**\n * Returns true if a where clause is empty, even with Symbols\n *\n * @param  {Object} obj\n * @returns {boolean}\n * @private\n */\nfunction isWhereEmpty(obj) {\n  return !!obj && _.isEmpty(obj) && getOperators(obj).length === 0;\n}\nexports.isWhereEmpty = isWhereEmpty;\n\n/**\n * Returns ENUM name by joining table and column name\n *\n * @param {string} tableName\n * @param {string} columnName\n * @returns {string}\n * @private\n */\nfunction generateEnumName(tableName, columnName) {\n  return `enum_${tableName}_${columnName}`;\n}\nexports.generateEnumName = generateEnumName;\n\n/**\n * Returns an new Object which keys are camelized\n *\n * @param {Object} obj\n * @returns {string}\n * @private\n */\nfunction camelizeObjectKeys(obj) {\n  const newObj = new Object();\n  Object.keys(obj).forEach(key => {\n    newObj[camelize(key)] = obj[key];\n  });\n  return newObj;\n}\nexports.camelizeObjectKeys = camelizeObjectKeys;\n\n/**\n * Assigns own and inherited enumerable string and symbol keyed properties of source\n * objects to the destination object.\n *\n * https://lodash.com/docs/4.17.4#defaults\n *\n * **Note:** This method mutates `object`.\n *\n * @param {Object} object The destination object.\n * @param {...Object} [sources] The source objects.\n * @returns {Object} Returns `object`.\n * @private\n */\nfunction defaults(object, ...sources) {\n  object = Object(object);\n\n  sources.forEach(source => {\n    if (source) {\n      source = Object(source);\n\n      getComplexKeys(source).forEach(key => {\n        const value = object[key];\n        if (\n          value === undefined ||\n            _.eq(value, Object.prototype[key]) &&\n            !Object.prototype.hasOwnProperty.call(object, key)\n\n        ) {\n          object[key] = source[key];\n        }\n      });\n    }\n  });\n\n  return object;\n}\nexports.defaults = defaults;\n\n/**\n *\n * @param {Object} index\n * @param {Array}  index.fields\n * @param {string} [index.name]\n * @param {string|Object} tableName\n *\n * @returns {Object}\n * @private\n */\nfunction nameIndex(index, tableName) {\n  if (tableName.tableName) tableName = tableName.tableName;\n\n  if (!Object.prototype.hasOwnProperty.call(index, 'name')) {\n    const fields = index.fields.map(\n      field => typeof field === 'string' ? field : field.name || field.attribute\n    );\n    index.name = underscore(`${tableName}_${fields.join('_')}`);\n  }\n\n  return index;\n}\nexports.nameIndex = nameIndex;\n\n/**\n * Checks if 2 arrays intersect.\n *\n * @param {Array} arr1\n * @param {Array} arr2\n * @private\n */\nfunction intersects(arr1, arr2) {\n  return arr1.some(v => arr2.includes(v));\n}\nexports.intersects = intersects;\n"]} \ No newline at end of file diff --git a/dist/utils/classToInvokable.js b/dist/utils/classToInvokable.js index d844cf7..68c6fa5 100644 --- a/dist/utils/classToInvokable.js +++ b/dist/utils/classToInvokable.js @@ -26,4 +26,4 @@ function classToInvokable(Class) { } exports.classToInvokable = classToInvokable; -//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uL2xpYi91dGlscy9jbGFzc1RvSW52b2thYmxlLmpzIl0sIm5hbWVzIjpbImNsYXNzVG9JbnZva2FibGUiLCJDbGFzcyIsIlByb3h5IiwiYXBwbHkiLCJUYXJnZXQiLCJ0aGlzQXJnIiwiYXJncyIsImNvbnN0cnVjdCIsImdldCIsInRhcmdldCIsInAiLCJleHBvcnRzIl0sIm1hcHBpbmdzIjoiQUFBQTtBQUVBOzs7Ozs7Ozs7QUFRQSxTQUFTQSxnQkFBVCxDQUEwQkMsS0FBMUIsRUFBaUM7QUFDL0IsU0FBTyxJQUFJQyxLQUFKLENBQVVELEtBQVYsRUFBaUI7QUFDdEJFLElBQUFBLEtBQUssQ0FBQ0MsTUFBRCxFQUFTQyxPQUFULEVBQWtCQyxJQUFsQixFQUF3QjtBQUMzQixhQUFPLElBQUlGLE1BQUosQ0FBVyxHQUFHRSxJQUFkLENBQVA7QUFDRCxLQUhxQjs7QUFJdEJDLElBQUFBLFNBQVMsQ0FBQ0gsTUFBRCxFQUFTRSxJQUFULEVBQWU7QUFDdEIsYUFBTyxJQUFJRixNQUFKLENBQVcsR0FBR0UsSUFBZCxDQUFQO0FBQ0QsS0FOcUI7O0FBT3RCRSxJQUFBQSxHQUFHLENBQUNDLE1BQUQsRUFBU0MsQ0FBVCxFQUFZO0FBQ2IsYUFBT0QsTUFBTSxDQUFDQyxDQUFELENBQWI7QUFDRDs7QUFUcUIsR0FBakIsQ0FBUDtBQVdEOztBQUNEQyxPQUFPLENBQUNYLGdCQUFSLEdBQTJCQSxnQkFBM0IiLCJzb3VyY2VzQ29udGVudCI6WyIndXNlIHN0cmljdCc7XHJcblxyXG4vKipcclxuICogV3JhcHMgYSBjb25zdHJ1Y3RvciB0byBub3QgbmVlZCB0aGUgYG5ld2Aga2V5d29yZCB1c2luZyBhIHByb3h5LlxyXG4gKiBPbmx5IHVzZWQgZm9yIGRhdGEgdHlwZXMuXHJcbiAqXHJcbiAqIEBwYXJhbSB7RnVuY3Rpb259IENsYXNzIFRoZSBjbGFzcyBpbnN0YW5jZSB0byB3cmFwIGFzIGludm9jYWJsZS5cclxuICogQHJldHVybnMge1Byb3h5fSBXcmFwcGVkIGNsYXNzIGluc3RhbmNlLlxyXG4gKiBAcHJpdmF0ZVxyXG4gKi9cclxuZnVuY3Rpb24gY2xhc3NUb0ludm9rYWJsZShDbGFzcykge1xyXG4gIHJldHVybiBuZXcgUHJveHkoQ2xhc3MsIHtcclxuICAgIGFwcGx5KFRhcmdldCwgdGhpc0FyZywgYXJncykge1xyXG4gICAgICByZXR1cm4gbmV3IFRhcmdldCguLi5hcmdzKTtcclxuICAgIH0sXHJcbiAgICBjb25zdHJ1Y3QoVGFyZ2V0LCBhcmdzKSB7XHJcbiAgICAgIHJldHVybiBuZXcgVGFyZ2V0KC4uLmFyZ3MpO1xyXG4gICAgfSxcclxuICAgIGdldCh0YXJnZXQsIHApIHtcclxuICAgICAgcmV0dXJuIHRhcmdldFtwXTtcclxuICAgIH1cclxuICB9KTtcclxufVxyXG5leHBvcnRzLmNsYXNzVG9JbnZva2FibGUgPSBjbGFzc1RvSW52b2thYmxlO1xyXG4iXX0= \ No newline at end of file +//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uL2xpYi91dGlscy9jbGFzc1RvSW52b2thYmxlLmpzIl0sIm5hbWVzIjpbImNsYXNzVG9JbnZva2FibGUiLCJDbGFzcyIsIlByb3h5IiwiYXBwbHkiLCJUYXJnZXQiLCJ0aGlzQXJnIiwiYXJncyIsImNvbnN0cnVjdCIsImdldCIsInRhcmdldCIsInAiLCJleHBvcnRzIl0sIm1hcHBpbmdzIjoiQUFBQTtBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBQ0EsU0FBU0EsZ0JBQVQsQ0FBMEJDLEtBQTFCLEVBQWlDO0FBQy9CLFNBQU8sSUFBSUMsS0FBSixDQUFVRCxLQUFWLEVBQWlCO0FBQ3RCRSxJQUFBQSxLQUFLLENBQUNDLE1BQUQsRUFBU0MsT0FBVCxFQUFrQkMsSUFBbEIsRUFBd0I7QUFDM0IsYUFBTyxJQUFJRixNQUFKLENBQVcsR0FBR0UsSUFBZCxDQUFQO0FBQ0QsS0FIcUI7O0FBSXRCQyxJQUFBQSxTQUFTLENBQUNILE1BQUQsRUFBU0UsSUFBVCxFQUFlO0FBQ3RCLGFBQU8sSUFBSUYsTUFBSixDQUFXLEdBQUdFLElBQWQsQ0FBUDtBQUNELEtBTnFCOztBQU90QkUsSUFBQUEsR0FBRyxDQUFDQyxNQUFELEVBQVNDLENBQVQsRUFBWTtBQUNiLGFBQU9ELE1BQU0sQ0FBQ0MsQ0FBRCxDQUFiO0FBQ0Q7O0FBVHFCLEdBQWpCLENBQVA7QUFXRDs7QUFDREMsT0FBTyxDQUFDWCxnQkFBUixHQUEyQkEsZ0JBQTNCIiwic291cmNlc0NvbnRlbnQiOlsiJ3VzZSBzdHJpY3QnO1xuXG4vKipcbiAqIFdyYXBzIGEgY29uc3RydWN0b3IgdG8gbm90IG5lZWQgdGhlIGBuZXdgIGtleXdvcmQgdXNpbmcgYSBwcm94eS5cbiAqIE9ubHkgdXNlZCBmb3IgZGF0YSB0eXBlcy5cbiAqXG4gKiBAcGFyYW0ge0Z1bmN0aW9ufSBDbGFzcyBUaGUgY2xhc3MgaW5zdGFuY2UgdG8gd3JhcCBhcyBpbnZvY2FibGUuXG4gKiBAcmV0dXJucyB7UHJveHl9IFdyYXBwZWQgY2xhc3MgaW5zdGFuY2UuXG4gKiBAcHJpdmF0ZVxuICovXG5mdW5jdGlvbiBjbGFzc1RvSW52b2thYmxlKENsYXNzKSB7XG4gIHJldHVybiBuZXcgUHJveHkoQ2xhc3MsIHtcbiAgICBhcHBseShUYXJnZXQsIHRoaXNBcmcsIGFyZ3MpIHtcbiAgICAgIHJldHVybiBuZXcgVGFyZ2V0KC4uLmFyZ3MpO1xuICAgIH0sXG4gICAgY29uc3RydWN0KFRhcmdldCwgYXJncykge1xuICAgICAgcmV0dXJuIG5ldyBUYXJnZXQoLi4uYXJncyk7XG4gICAgfSxcbiAgICBnZXQodGFyZ2V0LCBwKSB7XG4gICAgICByZXR1cm4gdGFyZ2V0W3BdO1xuICAgIH1cbiAgfSk7XG59XG5leHBvcnRzLmNsYXNzVG9JbnZva2FibGUgPSBjbGFzc1RvSW52b2thYmxlO1xuIl19 \ No newline at end of file diff --git a/dist/utils/deprecations.js b/dist/utils/deprecations.js index eda3831..a9d5cf5 100644 --- a/dist/utils/deprecations.js +++ b/dist/utils/deprecations.js @@ -11,4 +11,4 @@ exports.noTrueLogging = deprecate(noop, 'The logging-option should be either a f exports.noStringOperators = deprecate(noop, 'String based operators are deprecated. Please use Symbol based operators for better security, read more at https://sequelize.org/master/manual/querying.html#operators', 'SEQUELIZE0003'); exports.noBoolOperatorAliases = deprecate(noop, 'A boolean value was passed to options.operatorsAliases. This is a no-op with v5 and should be removed.', 'SEQUELIZE0004'); exports.noDoubleNestedGroup = deprecate(noop, 'Passing a double nested nested array to `group` is unsupported and will be removed in v6.', 'SEQUELIZE0005'); -//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uL2xpYi91dGlscy9kZXByZWNhdGlvbnMuanMiXSwibmFtZXMiOlsiZGVwcmVjYXRlIiwicmVxdWlyZSIsIm5vb3AiLCJleHBvcnRzIiwibm9SYXdBdHRyaWJ1dGVzIiwibm9UcnVlTG9nZ2luZyIsIm5vU3RyaW5nT3BlcmF0b3JzIiwibm9Cb29sT3BlcmF0b3JBbGlhc2VzIiwibm9Eb3VibGVOZXN0ZWRHcm91cCJdLCJtYXBwaW5ncyI6IkFBQUE7O0FBRUEsTUFBTTtBQUFFQSxFQUFBQTtBQUFGLElBQWdCQyxPQUFPLENBQUMsTUFBRCxDQUE3Qjs7QUFFQSxNQUFNQyxJQUFJLEdBQUcsTUFBTSxDQUFFLENBQXJCOztBQUVBQyxPQUFPLENBQUNDLGVBQVIsR0FBMEJKLFNBQVMsQ0FBQ0UsSUFBRCxFQUFPLDhEQUFQLEVBQXVFLGVBQXZFLENBQW5DO0FBQ0FDLE9BQU8sQ0FBQ0UsYUFBUixHQUF3QkwsU0FBUyxDQUFDRSxJQUFELEVBQU8sK0VBQVAsRUFBd0YsZUFBeEYsQ0FBakM7QUFDQUMsT0FBTyxDQUFDRyxpQkFBUixHQUE0Qk4sU0FBUyxDQUFDRSxJQUFELEVBQU8sd0tBQVAsRUFBaUwsZUFBakwsQ0FBckM7QUFDQUMsT0FBTyxDQUFDSSxxQkFBUixHQUFnQ1AsU0FBUyxDQUFDRSxJQUFELEVBQU8sd0dBQVAsRUFBaUgsZUFBakgsQ0FBekM7QUFDQUMsT0FBTyxDQUFDSyxtQkFBUixHQUE4QlIsU0FBUyxDQUFDRSxJQUFELEVBQU8sMkZBQVAsRUFBb0csZUFBcEcsQ0FBdkMiLCJzb3VyY2VzQ29udGVudCI6WyIndXNlIHN0cmljdCc7XHJcblxyXG5jb25zdCB7IGRlcHJlY2F0ZSB9ID0gcmVxdWlyZSgndXRpbCcpO1xyXG5cclxuY29uc3Qgbm9vcCA9ICgpID0+IHt9O1xyXG5cclxuZXhwb3J0cy5ub1Jhd0F0dHJpYnV0ZXMgPSBkZXByZWNhdGUobm9vcCwgJ1VzZSBzZXF1ZWxpemUuZm4gLyBzZXF1ZWxpemUubGl0ZXJhbCB0byBjb25zdHJ1Y3QgYXR0cmlidXRlcycsICdTRVFVRUxJWkUwMDAxJyk7XHJcbmV4cG9ydHMubm9UcnVlTG9nZ2luZyA9IGRlcHJlY2F0ZShub29wLCAnVGhlIGxvZ2dpbmctb3B0aW9uIHNob3VsZCBiZSBlaXRoZXIgYSBmdW5jdGlvbiBvciBmYWxzZS4gRGVmYXVsdDogY29uc29sZS5sb2cnLCAnU0VRVUVMSVpFMDAwMicpO1xyXG5leHBvcnRzLm5vU3RyaW5nT3BlcmF0b3JzID0gZGVwcmVjYXRlKG5vb3AsICdTdHJpbmcgYmFzZWQgb3BlcmF0b3JzIGFyZSBkZXByZWNhdGVkLiBQbGVhc2UgdXNlIFN5bWJvbCBiYXNlZCBvcGVyYXRvcnMgZm9yIGJldHRlciBzZWN1cml0eSwgcmVhZCBtb3JlIGF0IGh0dHBzOi8vc2VxdWVsaXplLm9yZy9tYXN0ZXIvbWFudWFsL3F1ZXJ5aW5nLmh0bWwjb3BlcmF0b3JzJywgJ1NFUVVFTElaRTAwMDMnKTtcclxuZXhwb3J0cy5ub0Jvb2xPcGVyYXRvckFsaWFzZXMgPSBkZXByZWNhdGUobm9vcCwgJ0EgYm9vbGVhbiB2YWx1ZSB3YXMgcGFzc2VkIHRvIG9wdGlvbnMub3BlcmF0b3JzQWxpYXNlcy4gVGhpcyBpcyBhIG5vLW9wIHdpdGggdjUgYW5kIHNob3VsZCBiZSByZW1vdmVkLicsICdTRVFVRUxJWkUwMDA0Jyk7XHJcbmV4cG9ydHMubm9Eb3VibGVOZXN0ZWRHcm91cCA9IGRlcHJlY2F0ZShub29wLCAnUGFzc2luZyBhIGRvdWJsZSBuZXN0ZWQgbmVzdGVkIGFycmF5IHRvIGBncm91cGAgaXMgdW5zdXBwb3J0ZWQgYW5kIHdpbGwgYmUgcmVtb3ZlZCBpbiB2Ni4nLCAnU0VRVUVMSVpFMDAwNScpO1xyXG4iXX0= \ No newline at end of file +//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uL2xpYi91dGlscy9kZXByZWNhdGlvbnMuanMiXSwibmFtZXMiOlsiZGVwcmVjYXRlIiwicmVxdWlyZSIsIm5vb3AiLCJleHBvcnRzIiwibm9SYXdBdHRyaWJ1dGVzIiwibm9UcnVlTG9nZ2luZyIsIm5vU3RyaW5nT3BlcmF0b3JzIiwibm9Cb29sT3BlcmF0b3JBbGlhc2VzIiwibm9Eb3VibGVOZXN0ZWRHcm91cCJdLCJtYXBwaW5ncyI6IkFBQUE7O0FBRUEsTUFBTTtBQUFFQSxFQUFBQTtBQUFGLElBQWdCQyxPQUFPLENBQUMsTUFBRCxDQUE3Qjs7QUFFQSxNQUFNQyxJQUFJLEdBQUcsTUFBTSxDQUFFLENBQXJCOztBQUVBQyxPQUFPLENBQUNDLGVBQVIsR0FBMEJKLFNBQVMsQ0FBQ0UsSUFBRCxFQUFPLDhEQUFQLEVBQXVFLGVBQXZFLENBQW5DO0FBQ0FDLE9BQU8sQ0FBQ0UsYUFBUixHQUF3QkwsU0FBUyxDQUFDRSxJQUFELEVBQU8sK0VBQVAsRUFBd0YsZUFBeEYsQ0FBakM7QUFDQUMsT0FBTyxDQUFDRyxpQkFBUixHQUE0Qk4sU0FBUyxDQUFDRSxJQUFELEVBQU8sd0tBQVAsRUFBaUwsZUFBakwsQ0FBckM7QUFDQUMsT0FBTyxDQUFDSSxxQkFBUixHQUFnQ1AsU0FBUyxDQUFDRSxJQUFELEVBQU8sd0dBQVAsRUFBaUgsZUFBakgsQ0FBekM7QUFDQUMsT0FBTyxDQUFDSyxtQkFBUixHQUE4QlIsU0FBUyxDQUFDRSxJQUFELEVBQU8sMkZBQVAsRUFBb0csZUFBcEcsQ0FBdkMiLCJzb3VyY2VzQ29udGVudCI6WyIndXNlIHN0cmljdCc7XG5cbmNvbnN0IHsgZGVwcmVjYXRlIH0gPSByZXF1aXJlKCd1dGlsJyk7XG5cbmNvbnN0IG5vb3AgPSAoKSA9PiB7fTtcblxuZXhwb3J0cy5ub1Jhd0F0dHJpYnV0ZXMgPSBkZXByZWNhdGUobm9vcCwgJ1VzZSBzZXF1ZWxpemUuZm4gLyBzZXF1ZWxpemUubGl0ZXJhbCB0byBjb25zdHJ1Y3QgYXR0cmlidXRlcycsICdTRVFVRUxJWkUwMDAxJyk7XG5leHBvcnRzLm5vVHJ1ZUxvZ2dpbmcgPSBkZXByZWNhdGUobm9vcCwgJ1RoZSBsb2dnaW5nLW9wdGlvbiBzaG91bGQgYmUgZWl0aGVyIGEgZnVuY3Rpb24gb3IgZmFsc2UuIERlZmF1bHQ6IGNvbnNvbGUubG9nJywgJ1NFUVVFTElaRTAwMDInKTtcbmV4cG9ydHMubm9TdHJpbmdPcGVyYXRvcnMgPSBkZXByZWNhdGUobm9vcCwgJ1N0cmluZyBiYXNlZCBvcGVyYXRvcnMgYXJlIGRlcHJlY2F0ZWQuIFBsZWFzZSB1c2UgU3ltYm9sIGJhc2VkIG9wZXJhdG9ycyBmb3IgYmV0dGVyIHNlY3VyaXR5LCByZWFkIG1vcmUgYXQgaHR0cHM6Ly9zZXF1ZWxpemUub3JnL21hc3Rlci9tYW51YWwvcXVlcnlpbmcuaHRtbCNvcGVyYXRvcnMnLCAnU0VRVUVMSVpFMDAwMycpO1xuZXhwb3J0cy5ub0Jvb2xPcGVyYXRvckFsaWFzZXMgPSBkZXByZWNhdGUobm9vcCwgJ0EgYm9vbGVhbiB2YWx1ZSB3YXMgcGFzc2VkIHRvIG9wdGlvbnMub3BlcmF0b3JzQWxpYXNlcy4gVGhpcyBpcyBhIG5vLW9wIHdpdGggdjUgYW5kIHNob3VsZCBiZSByZW1vdmVkLicsICdTRVFVRUxJWkUwMDA0Jyk7XG5leHBvcnRzLm5vRG91YmxlTmVzdGVkR3JvdXAgPSBkZXByZWNhdGUobm9vcCwgJ1Bhc3NpbmcgYSBkb3VibGUgbmVzdGVkIG5lc3RlZCBhcnJheSB0byBgZ3JvdXBgIGlzIHVuc3VwcG9ydGVkIGFuZCB3aWxsIGJlIHJlbW92ZWQgaW4gdjYuJywgJ1NFUVVFTElaRTAwMDUnKTtcbiJdfQ== \ No newline at end of file diff --git a/dist/utils/logger.js b/dist/utils/logger.js index b61654d..cc45ca8 100644 --- a/dist/utils/logger.js +++ b/dist/utils/logger.js @@ -17,9 +17,7 @@ const debug = require('debug'); const util = require('util'); -let Logger = -/*#__PURE__*/ -function () { +let Logger = /*#__PURE__*/function () { function Logger(config) { _classCallCheck(this, Logger); @@ -52,4 +50,4 @@ function () { exports.logger = new Logger(); exports.Logger = Logger; -//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uL2xpYi91dGlscy9sb2dnZXIuanMiXSwibmFtZXMiOlsiZGVidWciLCJyZXF1aXJlIiwidXRpbCIsIkxvZ2dlciIsImNvbmZpZyIsIk9iamVjdCIsImFzc2lnbiIsImNvbnRleHQiLCJtZXNzYWdlIiwiY29uc29sZSIsIndhcm4iLCJ2YWx1ZSIsImluc3BlY3QiLCJuYW1lIiwiZXhwb3J0cyIsImxvZ2dlciJdLCJtYXBwaW5ncyI6IkFBQUE7QUFFQTs7Ozs7Ozs7Ozs7Ozs7QUFRQSxNQUFNQSxLQUFLLEdBQUdDLE9BQU8sQ0FBQyxPQUFELENBQXJCOztBQUNBLE1BQU1DLElBQUksR0FBR0QsT0FBTyxDQUFDLE1BQUQsQ0FBcEI7O0lBRU1FLE07OztBQUNKLGtCQUFZQyxNQUFaLEVBQW9CO0FBQUE7O0FBRWxCLFNBQUtBLE1BQUwsR0FBY0MsTUFBTSxDQUFDQyxNQUFQLENBQWM7QUFDMUJDLE1BQUFBLE9BQU8sRUFBRSxXQURpQjtBQUUxQlAsTUFBQUEsS0FBSyxFQUFFO0FBRm1CLEtBQWQsRUFHWEksTUFIVyxDQUFkO0FBSUQ7Ozs7eUJBRUlJLE8sRUFBUztBQUNaO0FBQ0FDLE1BQUFBLE9BQU8sQ0FBQ0MsSUFBUixDQUFjLElBQUcsS0FBS04sTUFBTCxDQUFZRyxPQUFRLGNBQWFDLE9BQVEsRUFBMUQ7QUFDRDs7OzRCQUVPRyxLLEVBQU87QUFDYixhQUFPVCxJQUFJLENBQUNVLE9BQUwsQ0FBYUQsS0FBYixFQUFvQixLQUFwQixFQUEyQixDQUEzQixDQUFQO0FBQ0Q7OztpQ0FFWUUsSSxFQUFNO0FBQ2pCLGFBQU9iLEtBQUssQ0FBRSxHQUFFLEtBQUtJLE1BQUwsQ0FBWUcsT0FBUSxJQUFHTSxJQUFLLEVBQWhDLENBQVo7QUFDRDs7Ozs7O0FBR0hDLE9BQU8sQ0FBQ0MsTUFBUixHQUFpQixJQUFJWixNQUFKLEVBQWpCO0FBRUFXLE9BQU8sQ0FBQ1gsTUFBUixHQUFpQkEsTUFBakIiLCJzb3VyY2VzQ29udGVudCI6WyIndXNlIHN0cmljdCc7XHJcblxyXG4vKipcclxuICogU2VxdWVsaXplIG1vZHVsZSBmb3IgZGVidWcgYW5kIGRlcHJlY2F0aW9uIG1lc3NhZ2VzLlxyXG4gKiBJdCByZXF1aXJlIGEgYGNvbnRleHRgIGZvciB3aGljaCBtZXNzYWdlcyB3aWxsIGJlIHByaW50ZWQuXHJcbiAqXHJcbiAqIEBtb2R1bGUgbG9nZ2luZ1xyXG4gKiBAcHJpdmF0ZVxyXG4gKi9cclxuXHJcbmNvbnN0IGRlYnVnID0gcmVxdWlyZSgnZGVidWcnKTtcclxuY29uc3QgdXRpbCA9IHJlcXVpcmUoJ3V0aWwnKTtcclxuXHJcbmNsYXNzIExvZ2dlciB7XHJcbiAgY29uc3RydWN0b3IoY29uZmlnKSB7XHJcblxyXG4gICAgdGhpcy5jb25maWcgPSBPYmplY3QuYXNzaWduKHtcclxuICAgICAgY29udGV4dDogJ3NlcXVlbGl6ZScsXHJcbiAgICAgIGRlYnVnOiB0cnVlXHJcbiAgICB9LCBjb25maWcpO1xyXG4gIH1cclxuXHJcbiAgd2FybihtZXNzYWdlKSB7XHJcbiAgICAvLyBlc2xpbnQtZGlzYWJsZS1uZXh0LWxpbmUgbm8tY29uc29sZVxyXG4gICAgY29uc29sZS53YXJuKGAoJHt0aGlzLmNvbmZpZy5jb250ZXh0fSkgV2FybmluZzogJHttZXNzYWdlfWApO1xyXG4gIH1cclxuXHJcbiAgaW5zcGVjdCh2YWx1ZSkge1xyXG4gICAgcmV0dXJuIHV0aWwuaW5zcGVjdCh2YWx1ZSwgZmFsc2UsIDMpO1xyXG4gIH1cclxuXHJcbiAgZGVidWdDb250ZXh0KG5hbWUpIHtcclxuICAgIHJldHVybiBkZWJ1ZyhgJHt0aGlzLmNvbmZpZy5jb250ZXh0fToke25hbWV9YCk7XHJcbiAgfVxyXG59XHJcblxyXG5leHBvcnRzLmxvZ2dlciA9IG5ldyBMb2dnZXIoKTtcclxuXHJcbmV4cG9ydHMuTG9nZ2VyID0gTG9nZ2VyO1xyXG4iXX0= \ No newline at end of file +//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uL2xpYi91dGlscy9sb2dnZXIuanMiXSwibmFtZXMiOlsiZGVidWciLCJyZXF1aXJlIiwidXRpbCIsIkxvZ2dlciIsImNvbmZpZyIsIk9iamVjdCIsImFzc2lnbiIsImNvbnRleHQiLCJtZXNzYWdlIiwiY29uc29sZSIsIndhcm4iLCJ2YWx1ZSIsImluc3BlY3QiLCJuYW1lIiwiZXhwb3J0cyIsImxvZ2dlciJdLCJtYXBwaW5ncyI6IkFBQUE7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7Ozs7Ozs7QUFFQSxNQUFNQSxLQUFLLEdBQUdDLE9BQU8sQ0FBQyxPQUFELENBQXJCOztBQUNBLE1BQU1DLElBQUksR0FBR0QsT0FBTyxDQUFDLE1BQUQsQ0FBcEI7O0lBRU1FLE07QUFDSixrQkFBWUMsTUFBWixFQUFvQjtBQUFBOztBQUVsQixTQUFLQSxNQUFMLEdBQWNDLE1BQU0sQ0FBQ0MsTUFBUCxDQUFjO0FBQzFCQyxNQUFBQSxPQUFPLEVBQUUsV0FEaUI7QUFFMUJQLE1BQUFBLEtBQUssRUFBRTtBQUZtQixLQUFkLEVBR1hJLE1BSFcsQ0FBZDtBQUlEOzs7O3lCQUVJSSxPLEVBQVM7QUFDWjtBQUNBQyxNQUFBQSxPQUFPLENBQUNDLElBQVIsQ0FBYyxJQUFHLEtBQUtOLE1BQUwsQ0FBWUcsT0FBUSxjQUFhQyxPQUFRLEVBQTFEO0FBQ0Q7Ozs0QkFFT0csSyxFQUFPO0FBQ2IsYUFBT1QsSUFBSSxDQUFDVSxPQUFMLENBQWFELEtBQWIsRUFBb0IsS0FBcEIsRUFBMkIsQ0FBM0IsQ0FBUDtBQUNEOzs7aUNBRVlFLEksRUFBTTtBQUNqQixhQUFPYixLQUFLLENBQUUsR0FBRSxLQUFLSSxNQUFMLENBQVlHLE9BQVEsSUFBR00sSUFBSyxFQUFoQyxDQUFaO0FBQ0Q7Ozs7OztBQUdIQyxPQUFPLENBQUNDLE1BQVIsR0FBaUIsSUFBSVosTUFBSixFQUFqQjtBQUVBVyxPQUFPLENBQUNYLE1BQVIsR0FBaUJBLE1BQWpCIiwic291cmNlc0NvbnRlbnQiOlsiJ3VzZSBzdHJpY3QnO1xuXG4vKipcbiAqIFNlcXVlbGl6ZSBtb2R1bGUgZm9yIGRlYnVnIGFuZCBkZXByZWNhdGlvbiBtZXNzYWdlcy5cbiAqIEl0IHJlcXVpcmUgYSBgY29udGV4dGAgZm9yIHdoaWNoIG1lc3NhZ2VzIHdpbGwgYmUgcHJpbnRlZC5cbiAqXG4gKiBAbW9kdWxlIGxvZ2dpbmdcbiAqIEBwcml2YXRlXG4gKi9cblxuY29uc3QgZGVidWcgPSByZXF1aXJlKCdkZWJ1ZycpO1xuY29uc3QgdXRpbCA9IHJlcXVpcmUoJ3V0aWwnKTtcblxuY2xhc3MgTG9nZ2VyIHtcbiAgY29uc3RydWN0b3IoY29uZmlnKSB7XG5cbiAgICB0aGlzLmNvbmZpZyA9IE9iamVjdC5hc3NpZ24oe1xuICAgICAgY29udGV4dDogJ3NlcXVlbGl6ZScsXG4gICAgICBkZWJ1ZzogdHJ1ZVxuICAgIH0sIGNvbmZpZyk7XG4gIH1cblxuICB3YXJuKG1lc3NhZ2UpIHtcbiAgICAvLyBlc2xpbnQtZGlzYWJsZS1uZXh0LWxpbmUgbm8tY29uc29sZVxuICAgIGNvbnNvbGUud2FybihgKCR7dGhpcy5jb25maWcuY29udGV4dH0pIFdhcm5pbmc6ICR7bWVzc2FnZX1gKTtcbiAgfVxuXG4gIGluc3BlY3QodmFsdWUpIHtcbiAgICByZXR1cm4gdXRpbC5pbnNwZWN0KHZhbHVlLCBmYWxzZSwgMyk7XG4gIH1cblxuICBkZWJ1Z0NvbnRleHQobmFtZSkge1xuICAgIHJldHVybiBkZWJ1ZyhgJHt0aGlzLmNvbmZpZy5jb250ZXh0fToke25hbWV9YCk7XG4gIH1cbn1cblxuZXhwb3J0cy5sb2dnZXIgPSBuZXcgTG9nZ2VyKCk7XG5cbmV4cG9ydHMuTG9nZ2VyID0gTG9nZ2VyO1xuIl19 \ No newline at end of file diff --git a/dist/utils/validator-extras.js b/dist/utils/validator-extras.js index 30e248c..f975538 100644 --- a/dist/utils/validator-extras.js +++ b/dist/utils/validator-extras.js @@ -119,4 +119,4 @@ validator.isDate = function (dateString) { }; exports.validator = validator; -//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../lib/utils/validator-extras.js"],"names":["_","require","validator","cloneDeep","moment","extensions","extend","name","fn","notEmpty","str","match","len","min","max","isLength","isUrl","isURL","isIPv6","isIP","isIPv4","notIn","values","isIn","regex","pattern","modifiers","Object","prototype","toString","call","slice","RegExp","notRegex","isDecimal","val","number","parseFloat","isNaN","not","contains","elem","includes","notContains","is","exports","isImmutable","value","validatorArgs","field","modelInstance","isNewRecord","dataValues","_previousDataValues","notNull","undefined","forEach","key","isNull","isEmpty","isDate","dateString","parsed","Date","parse","date","toISOString","isValid"],"mappings":"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","sourcesContent":["'use strict';\r\n\r\nconst _ = require('lodash');\r\nconst validator = _.cloneDeep(require('validator'));\r\nconst moment = require('moment');\r\n\r\nconst extensions = {\r\n  extend(name, fn) {\r\n    this[name] = fn;\r\n\r\n    return this;\r\n  },\r\n  notEmpty(str) {\r\n    return !str.match(/^[\\s\\t\\r\\n]*$/);\r\n  },\r\n  len(str, min, max) {\r\n    return this.isLength(str, min, max);\r\n  },\r\n  isUrl(str) {\r\n    return this.isURL(str);\r\n  },\r\n  isIPv6(str) {\r\n    return this.isIP(str, 6);\r\n  },\r\n  isIPv4(str) {\r\n    return this.isIP(str, 4);\r\n  },\r\n  notIn(str, values) {\r\n    return !this.isIn(str, values);\r\n  },\r\n  regex(str, pattern, modifiers) {\r\n    str += '';\r\n    if (Object.prototype.toString.call(pattern).slice(8, -1) !== 'RegExp') {\r\n      pattern = new RegExp(pattern, modifiers);\r\n    }\r\n    return str.match(pattern);\r\n  },\r\n  notRegex(str, pattern, modifiers) {\r\n    return !this.regex(str, pattern, modifiers);\r\n  },\r\n  isDecimal(str) {\r\n    return str !== '' && !!str.match(/^(?:-?(?:[0-9]+))?(?:\\.[0-9]*)?(?:[eE][+-]?(?:[0-9]+))?$/);\r\n  },\r\n  min(str, val) {\r\n    const number = parseFloat(str);\r\n    return isNaN(number) || number >= val;\r\n  },\r\n  max(str, val) {\r\n    const number = parseFloat(str);\r\n    return isNaN(number) || number <= val;\r\n  },\r\n  not(str, pattern, modifiers) {\r\n    return this.notRegex(str, pattern, modifiers);\r\n  },\r\n  contains(str, elem) {\r\n    return !!elem && str.includes(elem);\r\n  },\r\n  notContains(str, elem) {\r\n    return !this.contains(str, elem);\r\n  },\r\n  is(str, pattern, modifiers) {\r\n    return this.regex(str, pattern, modifiers);\r\n  }\r\n};\r\nexports.extensions = extensions;\r\n\r\n// instance based validators\r\nvalidator.isImmutable = function(value, validatorArgs, field, modelInstance) {\r\n  return modelInstance.isNewRecord || modelInstance.dataValues[field] === modelInstance._previousDataValues[field];\r\n};\r\n\r\n// extra validators\r\nvalidator.notNull = function(val) {\r\n  return val !== null && val !== undefined;\r\n};\r\n\r\n// https://github.com/chriso/validator.js/blob/6.2.0/validator.js\r\n_.forEach(extensions, (extend, key) => {\r\n  validator[key] = extend;\r\n});\r\n\r\n// map isNull to isEmpty\r\n// https://github.com/chriso/validator.js/commit/e33d38a26ee2f9666b319adb67c7fc0d3dea7125\r\nvalidator.isNull = validator.isEmpty;\r\n\r\n// isDate removed in 7.0.0\r\n// https://github.com/chriso/validator.js/commit/095509fc707a4dc0e99f85131df1176ad6389fc9\r\nvalidator.isDate = function(dateString) {\r\n  // avoid http://momentjs.com/guides/#/warnings/js-date/\r\n  // by doing a preliminary check on `dateString`\r\n  const parsed = Date.parse(dateString);\r\n  if (isNaN(parsed)) {\r\n    // fail if we can't parse it\r\n    return false;\r\n  }\r\n  // otherwise convert to ISO 8601 as moment prefers\r\n  // http://momentjs.com/docs/#/parsing/string/\r\n  const date = new Date(parsed);\r\n  return moment(date.toISOString()).isValid();\r\n};\r\n\r\nexports.validator = validator;\r\n"]} \ No newline at end of file +//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../lib/utils/validator-extras.js"],"names":["_","require","validator","cloneDeep","moment","extensions","extend","name","fn","notEmpty","str","match","len","min","max","isLength","isUrl","isURL","isIPv6","isIP","isIPv4","notIn","values","isIn","regex","pattern","modifiers","Object","prototype","toString","call","slice","RegExp","notRegex","isDecimal","val","number","parseFloat","isNaN","not","contains","elem","includes","notContains","is","exports","isImmutable","value","validatorArgs","field","modelInstance","isNewRecord","dataValues","_previousDataValues","notNull","undefined","forEach","key","isNull","isEmpty","isDate","dateString","parsed","Date","parse","date","toISOString","isValid"],"mappings":"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","sourcesContent":["'use strict';\n\nconst _ = require('lodash');\nconst validator = _.cloneDeep(require('validator'));\nconst moment = require('moment');\n\nconst extensions = {\n  extend(name, fn) {\n    this[name] = fn;\n\n    return this;\n  },\n  notEmpty(str) {\n    return !str.match(/^[\\s\\t\\r\\n]*$/);\n  },\n  len(str, min, max) {\n    return this.isLength(str, min, max);\n  },\n  isUrl(str) {\n    return this.isURL(str);\n  },\n  isIPv6(str) {\n    return this.isIP(str, 6);\n  },\n  isIPv4(str) {\n    return this.isIP(str, 4);\n  },\n  notIn(str, values) {\n    return !this.isIn(str, values);\n  },\n  regex(str, pattern, modifiers) {\n    str += '';\n    if (Object.prototype.toString.call(pattern).slice(8, -1) !== 'RegExp') {\n      pattern = new RegExp(pattern, modifiers);\n    }\n    return str.match(pattern);\n  },\n  notRegex(str, pattern, modifiers) {\n    return !this.regex(str, pattern, modifiers);\n  },\n  isDecimal(str) {\n    return str !== '' && !!str.match(/^(?:-?(?:[0-9]+))?(?:\\.[0-9]*)?(?:[eE][+-]?(?:[0-9]+))?$/);\n  },\n  min(str, val) {\n    const number = parseFloat(str);\n    return isNaN(number) || number >= val;\n  },\n  max(str, val) {\n    const number = parseFloat(str);\n    return isNaN(number) || number <= val;\n  },\n  not(str, pattern, modifiers) {\n    return this.notRegex(str, pattern, modifiers);\n  },\n  contains(str, elem) {\n    return !!elem && str.includes(elem);\n  },\n  notContains(str, elem) {\n    return !this.contains(str, elem);\n  },\n  is(str, pattern, modifiers) {\n    return this.regex(str, pattern, modifiers);\n  }\n};\nexports.extensions = extensions;\n\n// instance based validators\nvalidator.isImmutable = function(value, validatorArgs, field, modelInstance) {\n  return modelInstance.isNewRecord || modelInstance.dataValues[field] === modelInstance._previousDataValues[field];\n};\n\n// extra validators\nvalidator.notNull = function(val) {\n  return val !== null && val !== undefined;\n};\n\n// https://github.com/chriso/validator.js/blob/6.2.0/validator.js\n_.forEach(extensions, (extend, key) => {\n  validator[key] = extend;\n});\n\n// map isNull to isEmpty\n// https://github.com/chriso/validator.js/commit/e33d38a26ee2f9666b319adb67c7fc0d3dea7125\nvalidator.isNull = validator.isEmpty;\n\n// isDate removed in 7.0.0\n// https://github.com/chriso/validator.js/commit/095509fc707a4dc0e99f85131df1176ad6389fc9\nvalidator.isDate = function(dateString) {\n  // avoid http://momentjs.com/guides/#/warnings/js-date/\n  // by doing a preliminary check on `dateString`\n  const parsed = Date.parse(dateString);\n  if (isNaN(parsed)) {\n    // fail if we can't parse it\n    return false;\n  }\n  // otherwise convert to ISO 8601 as moment prefers\n  // http://momentjs.com/docs/#/parsing/string/\n  const date = new Date(parsed);\n  return moment(date.toISOString()).isValid();\n};\n\nexports.validator = validator;\n"]} \ No newline at end of file From 57fbac03effb549394fd20689225f6eadc461158 Mon Sep 17 00:00:00 2001 From: prih Date: Mon, 14 Dec 2020 23:16:56 +0200 Subject: [PATCH 3/8] fix: connection.close --- dist/dialects/sqlite/connection-manager.js | 10 ++++++++-- lib/dialects/sqlite/connection-manager.js | 16 +++++++++------- 2 files changed, 17 insertions(+), 9 deletions(-) diff --git a/dist/dialects/sqlite/connection-manager.js b/dist/dialects/sqlite/connection-manager.js index 8e5d486..f61d584 100644 --- a/dist/dialects/sqlite/connection-manager.js +++ b/dist/dialects/sqlite/connection-manager.js @@ -69,7 +69,13 @@ let ConnectionManager = /*#__PURE__*/function (_AbstractConnectionMa) { _createClass(ConnectionManager, [{ key: "_onProcessExit", value: function _onProcessExit() { - const promises = Object.getOwnPropertyNames(this.connections).map(connection => Promise.fromCallback(callback => this.connections[connection].close(callback))); + const promises = Object.getOwnPropertyNames(this.connections).map(connection => { + return Promise.fromCallback(callback => { + return this.connections[connection].then(db => { + db.close(callback); + }); + }); + }); return Promise.all(promises).then(_get(_getPrototypeOf(ConnectionManager.prototype), "_onProcessExit", this).bind(this)); } // Expose this as a method so that the parsing may be updated when the user has added additional, custom types @@ -141,4 +147,4 @@ let ConnectionManager = /*#__PURE__*/function (_AbstractConnectionMa) { module.exports = ConnectionManager; module.exports.ConnectionManager = ConnectionManager; module.exports.default = ConnectionManager; -//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../lib/dialects/sqlite/connection-manager.js"],"names":["AbstractConnectionManager","require","Promise","logger","debug","debugContext","dataTypes","sqlite","sequelizeErrors","parserStore","ConnectionManager","dialect","sequelize","connections","openDatabase","_loadDialectModule","options","database","dialectOptions","version","description","size","conn","refreshTypeParser","promises","Object","getOwnPropertyNames","map","connection","fromCallback","callback","close","all","then","bind","dataType","refresh","clear","uuid","resolve","reject","ConnectionError","Error","tap","config","password","exec","sql","escape","args","foreignKeys","force","undefined","module","exports","default"],"mappings":"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","sourcesContent":["\"use strict\";\n\nconst AbstractConnectionManager = require(\"../abstract/connection-manager\");\nconst Promise = require(\"../../promise\");\nconst { logger } = require(\"../../utils/logger\");\nconst debug = logger.debugContext(\"connection:sqlite\");\nconst dataTypes = require(\"../../data-types\").sqlite;\nconst sequelizeErrors = require(\"../../errors\");\nconst parserStore = require(\"../parserStore\")(\"sqlite\");\n\nclass ConnectionManager extends AbstractConnectionManager {\n  constructor(dialect, sequelize) {\n    super(dialect, sequelize);\n\n    this.connections = {};\n    const { openDatabase } = this._loadDialectModule();\n    this.openDatabase = () =>\n      openDatabase(\n        this.sequelize.options.database,\n        this.sequelize.options.dialectOptions.version || \"1.0\",\n        this.sequelize.options.dialectOptions.description ||\n          this.sequelize.options.database,\n        this.sequelize.options.dialectOptions.size || 4 * 1024 * 1024\n      );\n    this.conn = this.openDatabase();\n    this.refreshTypeParser(dataTypes);\n  }\n\n  _onProcessExit() {\n    const promises = Object.getOwnPropertyNames(\n      this.connections\n    ).map(connection =>\n      Promise.fromCallback(callback =>\n        this.connections[connection].close(callback)\n      )\n    );\n\n    return Promise.all(promises).then(super._onProcessExit.bind(this));\n  }\n\n  // Expose this as a method so that the parsing may be updated when the user has added additional, custom types\n  _refreshTypeParser(dataType) {\n    parserStore.refresh(dataType);\n  }\n\n  _clearTypeParser() {\n    parserStore.clear();\n  }\n\n  getConnection(options) {\n    options = options || {};\n    options.uuid = options.uuid || \"default\";\n\n    if (this.connections[options.uuid]) {\n      return Promise.resolve(this.connections[options.uuid]);\n    }\n\n    return new Promise((resolve, reject) => {\n      this.connections[options.uuid] = !this.conn\n        ? this.openDatabase()\n        : this.conn;\n      debug(`connection acquired ${options.uuid}`);\n      if (!this.connections[options.uuid])\n        return reject(\n          new sequelizeErrors.ConnectionError(\n            new Error(\"Database reference no found!\")\n          )\n        );\n      resolve(this.connections[options.uuid]);\n    }).tap(connection => {\n      if (this.sequelize.config.password) {\n        // Make it possible to define and use password for sqlite encryption plugin like sqlcipher\n        if (connection && connection.exec) {\n          connection.exec(\n            [\n              {\n                sql: `PRAGMA KEY=${this.sequelize.escape(\n                  this.sequelize.config.password\n                )};`,\n                args: []\n              }\n            ],\n            false,\n            () => {}\n          );\n        }\n      }\n      if (this.sequelize.options.foreignKeys !== false) {\n        // Make it possible to define and use foreign key constraints unless\n        // explicitly disallowed. It's still opt-in per relation\n        if (connection && connection.exec) {\n          connection.exec(\n            [{ sql: \"PRAGMA FOREIGN_KEYS=ON\", args: [] }],\n            false,\n            () => {}\n          );\n        }\n      }\n    });\n  }\n\n  releaseConnection(connection, force) {\n    if (force !== true) return;\n\n    if (connection.uuid) {\n      connection.close && connection.close();\n      this.conn = undefined;\n      debug(`connection released ${connection.uuid}`);\n      delete this.connections[connection.uuid];\n    }\n  }\n}\n\nmodule.exports = ConnectionManager;\nmodule.exports.ConnectionManager = ConnectionManager;\nmodule.exports.default = ConnectionManager;\n"]} \ No newline at end of file +//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../lib/dialects/sqlite/connection-manager.js"],"names":["AbstractConnectionManager","require","Promise","logger","debug","debugContext","dataTypes","sqlite","sequelizeErrors","parserStore","ConnectionManager","dialect","sequelize","connections","openDatabase","_loadDialectModule","options","database","dialectOptions","version","description","size","conn","refreshTypeParser","promises","Object","getOwnPropertyNames","map","connection","fromCallback","callback","then","db","close","all","bind","dataType","refresh","clear","uuid","resolve","reject","ConnectionError","Error","tap","config","password","exec","sql","escape","args","foreignKeys","force","undefined","module","exports","default"],"mappings":"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","sourcesContent":["\"use strict\";\n\nconst AbstractConnectionManager = require(\"../abstract/connection-manager\");\nconst Promise = require(\"../../promise\");\nconst { logger } = require(\"../../utils/logger\");\nconst debug = logger.debugContext(\"connection:sqlite\");\nconst dataTypes = require(\"../../data-types\").sqlite;\nconst sequelizeErrors = require(\"../../errors\");\nconst parserStore = require(\"../parserStore\")(\"sqlite\");\n\nclass ConnectionManager extends AbstractConnectionManager {\n  constructor(dialect, sequelize) {\n    super(dialect, sequelize);\n\n    this.connections = {};\n    const { openDatabase } = this._loadDialectModule();\n    this.openDatabase = () =>\n      openDatabase(\n        this.sequelize.options.database,\n        this.sequelize.options.dialectOptions.version || \"1.0\",\n        this.sequelize.options.dialectOptions.description ||\n          this.sequelize.options.database,\n        this.sequelize.options.dialectOptions.size || 4 * 1024 * 1024\n      );\n    this.conn = this.openDatabase();\n    this.refreshTypeParser(dataTypes);\n  }\n\n  _onProcessExit() {\n    const promises = Object\n      .getOwnPropertyNames(this.connections)\n      .map(connection => {\n        return Promise.fromCallback(callback => {\n          return this.connections[connection].then(db => {\n            db.close(callback);\n          });\n        });\n      });\n\n    return Promise.all(promises).then(super._onProcessExit.bind(this));\n  }\n\n  // Expose this as a method so that the parsing may be updated when the user has added additional, custom types\n  _refreshTypeParser(dataType) {\n    parserStore.refresh(dataType);\n  }\n\n  _clearTypeParser() {\n    parserStore.clear();\n  }\n\n  getConnection(options) {\n    options = options || {};\n    options.uuid = options.uuid || \"default\";\n\n    if (this.connections[options.uuid]) {\n      return Promise.resolve(this.connections[options.uuid]);\n    }\n\n    return new Promise((resolve, reject) => {\n      this.connections[options.uuid] = !this.conn\n        ? this.openDatabase()\n        : this.conn;\n      debug(`connection acquired ${options.uuid}`);\n      if (!this.connections[options.uuid])\n        return reject(\n          new sequelizeErrors.ConnectionError(\n            new Error(\"Database reference no found!\")\n          )\n        );\n      resolve(this.connections[options.uuid]);\n    }).tap(connection => {\n      if (this.sequelize.config.password) {\n        // Make it possible to define and use password for sqlite encryption plugin like sqlcipher\n        if (connection && connection.exec) {\n          connection.exec(\n            [\n              {\n                sql: `PRAGMA KEY=${this.sequelize.escape(\n                  this.sequelize.config.password\n                )};`,\n                args: []\n              }\n            ],\n            false,\n            () => {}\n          );\n        }\n      }\n      if (this.sequelize.options.foreignKeys !== false) {\n        // Make it possible to define and use foreign key constraints unless\n        // explicitly disallowed. It's still opt-in per relation\n        if (connection && connection.exec) {\n          connection.exec(\n            [{ sql: \"PRAGMA FOREIGN_KEYS=ON\", args: [] }],\n            false,\n            () => {}\n          );\n        }\n      }\n    });\n  }\n\n  releaseConnection(connection, force) {\n    if (force !== true) return;\n\n    if (connection.uuid) {\n      connection.close && connection.close();\n      this.conn = undefined;\n      debug(`connection released ${connection.uuid}`);\n      delete this.connections[connection.uuid];\n    }\n  }\n}\n\nmodule.exports = ConnectionManager;\nmodule.exports.ConnectionManager = ConnectionManager;\nmodule.exports.default = ConnectionManager;\n"]} \ No newline at end of file diff --git a/lib/dialects/sqlite/connection-manager.js b/lib/dialects/sqlite/connection-manager.js index 5ba5d7d..939f858 100644 --- a/lib/dialects/sqlite/connection-manager.js +++ b/lib/dialects/sqlite/connection-manager.js @@ -27,13 +27,15 @@ class ConnectionManager extends AbstractConnectionManager { } _onProcessExit() { - const promises = Object.getOwnPropertyNames( - this.connections - ).map(connection => - Promise.fromCallback(callback => - this.connections[connection].close(callback) - ) - ); + const promises = Object + .getOwnPropertyNames(this.connections) + .map(connection => { + return Promise.fromCallback(callback => { + return this.connections[connection].then(db => { + db.close(callback); + }); + }); + }); return Promise.all(promises).then(super._onProcessExit.bind(this)); } From 8c7898ffdba02d61934d9732dea442e01cb53e47 Mon Sep 17 00:00:00 2001 From: prih Date: Mon, 14 Dec 2020 23:59:02 +0200 Subject: [PATCH 4/8] . --- dist/dialects/sqlite/connection-manager.js | 12 +++++------- lib/dialects/sqlite/connection-manager.js | 12 ++++-------- 2 files changed, 9 insertions(+), 15 deletions(-) diff --git a/dist/dialects/sqlite/connection-manager.js b/dist/dialects/sqlite/connection-manager.js index f61d584..e0ed62e 100644 --- a/dist/dialects/sqlite/connection-manager.js +++ b/dist/dialects/sqlite/connection-manager.js @@ -69,13 +69,11 @@ let ConnectionManager = /*#__PURE__*/function (_AbstractConnectionMa) { _createClass(ConnectionManager, [{ key: "_onProcessExit", value: function _onProcessExit() { - const promises = Object.getOwnPropertyNames(this.connections).map(connection => { - return Promise.fromCallback(callback => { - return this.connections[connection].then(db => { - db.close(callback); - }); + const promises = [Promise.fromCallback(callback => { + return this.connections['default'].then(db => { + db.close(callback, callback); }); - }); + })]; return Promise.all(promises).then(_get(_getPrototypeOf(ConnectionManager.prototype), "_onProcessExit", this).bind(this)); } // Expose this as a method so that the parsing may be updated when the user has added additional, custom types @@ -147,4 +145,4 @@ let ConnectionManager = /*#__PURE__*/function (_AbstractConnectionMa) { module.exports = ConnectionManager; module.exports.ConnectionManager = ConnectionManager; module.exports.default = ConnectionManager; -//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../lib/dialects/sqlite/connection-manager.js"],"names":["AbstractConnectionManager","require","Promise","logger","debug","debugContext","dataTypes","sqlite","sequelizeErrors","parserStore","ConnectionManager","dialect","sequelize","connections","openDatabase","_loadDialectModule","options","database","dialectOptions","version","description","size","conn","refreshTypeParser","promises","Object","getOwnPropertyNames","map","connection","fromCallback","callback","then","db","close","all","bind","dataType","refresh","clear","uuid","resolve","reject","ConnectionError","Error","tap","config","password","exec","sql","escape","args","foreignKeys","force","undefined","module","exports","default"],"mappings":"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","sourcesContent":["\"use strict\";\n\nconst AbstractConnectionManager = require(\"../abstract/connection-manager\");\nconst Promise = require(\"../../promise\");\nconst { logger } = require(\"../../utils/logger\");\nconst debug = logger.debugContext(\"connection:sqlite\");\nconst dataTypes = require(\"../../data-types\").sqlite;\nconst sequelizeErrors = require(\"../../errors\");\nconst parserStore = require(\"../parserStore\")(\"sqlite\");\n\nclass ConnectionManager extends AbstractConnectionManager {\n  constructor(dialect, sequelize) {\n    super(dialect, sequelize);\n\n    this.connections = {};\n    const { openDatabase } = this._loadDialectModule();\n    this.openDatabase = () =>\n      openDatabase(\n        this.sequelize.options.database,\n        this.sequelize.options.dialectOptions.version || \"1.0\",\n        this.sequelize.options.dialectOptions.description ||\n          this.sequelize.options.database,\n        this.sequelize.options.dialectOptions.size || 4 * 1024 * 1024\n      );\n    this.conn = this.openDatabase();\n    this.refreshTypeParser(dataTypes);\n  }\n\n  _onProcessExit() {\n    const promises = Object\n      .getOwnPropertyNames(this.connections)\n      .map(connection => {\n        return Promise.fromCallback(callback => {\n          return this.connections[connection].then(db => {\n            db.close(callback);\n          });\n        });\n      });\n\n    return Promise.all(promises).then(super._onProcessExit.bind(this));\n  }\n\n  // Expose this as a method so that the parsing may be updated when the user has added additional, custom types\n  _refreshTypeParser(dataType) {\n    parserStore.refresh(dataType);\n  }\n\n  _clearTypeParser() {\n    parserStore.clear();\n  }\n\n  getConnection(options) {\n    options = options || {};\n    options.uuid = options.uuid || \"default\";\n\n    if (this.connections[options.uuid]) {\n      return Promise.resolve(this.connections[options.uuid]);\n    }\n\n    return new Promise((resolve, reject) => {\n      this.connections[options.uuid] = !this.conn\n        ? this.openDatabase()\n        : this.conn;\n      debug(`connection acquired ${options.uuid}`);\n      if (!this.connections[options.uuid])\n        return reject(\n          new sequelizeErrors.ConnectionError(\n            new Error(\"Database reference no found!\")\n          )\n        );\n      resolve(this.connections[options.uuid]);\n    }).tap(connection => {\n      if (this.sequelize.config.password) {\n        // Make it possible to define and use password for sqlite encryption plugin like sqlcipher\n        if (connection && connection.exec) {\n          connection.exec(\n            [\n              {\n                sql: `PRAGMA KEY=${this.sequelize.escape(\n                  this.sequelize.config.password\n                )};`,\n                args: []\n              }\n            ],\n            false,\n            () => {}\n          );\n        }\n      }\n      if (this.sequelize.options.foreignKeys !== false) {\n        // Make it possible to define and use foreign key constraints unless\n        // explicitly disallowed. It's still opt-in per relation\n        if (connection && connection.exec) {\n          connection.exec(\n            [{ sql: \"PRAGMA FOREIGN_KEYS=ON\", args: [] }],\n            false,\n            () => {}\n          );\n        }\n      }\n    });\n  }\n\n  releaseConnection(connection, force) {\n    if (force !== true) return;\n\n    if (connection.uuid) {\n      connection.close && connection.close();\n      this.conn = undefined;\n      debug(`connection released ${connection.uuid}`);\n      delete this.connections[connection.uuid];\n    }\n  }\n}\n\nmodule.exports = ConnectionManager;\nmodule.exports.ConnectionManager = ConnectionManager;\nmodule.exports.default = ConnectionManager;\n"]} \ No newline at end of file +//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../lib/dialects/sqlite/connection-manager.js"],"names":["AbstractConnectionManager","require","Promise","logger","debug","debugContext","dataTypes","sqlite","sequelizeErrors","parserStore","ConnectionManager","dialect","sequelize","connections","openDatabase","_loadDialectModule","options","database","dialectOptions","version","description","size","conn","refreshTypeParser","promises","fromCallback","callback","then","db","close","all","bind","dataType","refresh","clear","uuid","resolve","reject","ConnectionError","Error","tap","connection","config","password","exec","sql","escape","args","foreignKeys","force","undefined","module","exports","default"],"mappings":"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","sourcesContent":["\"use strict\";\n\nconst AbstractConnectionManager = require(\"../abstract/connection-manager\");\nconst Promise = require(\"../../promise\");\nconst { logger } = require(\"../../utils/logger\");\nconst debug = logger.debugContext(\"connection:sqlite\");\nconst dataTypes = require(\"../../data-types\").sqlite;\nconst sequelizeErrors = require(\"../../errors\");\nconst parserStore = require(\"../parserStore\")(\"sqlite\");\n\nclass ConnectionManager extends AbstractConnectionManager {\n  constructor(dialect, sequelize) {\n    super(dialect, sequelize);\n\n    this.connections = {};\n    const { openDatabase } = this._loadDialectModule();\n    this.openDatabase = () =>\n      openDatabase(\n        this.sequelize.options.database,\n        this.sequelize.options.dialectOptions.version || \"1.0\",\n        this.sequelize.options.dialectOptions.description ||\n          this.sequelize.options.database,\n        this.sequelize.options.dialectOptions.size || 4 * 1024 * 1024\n      );\n    this.conn = this.openDatabase();\n    this.refreshTypeParser(dataTypes);\n  }\n\n  _onProcessExit() {\n    const promises = [Promise.fromCallback(callback => {\n      return this.connections['default'].then(db => {\n        db.close(callback, callback);\n      });\n    })];\n\n    return Promise.all(promises).then(super._onProcessExit.bind(this));\n  }\n\n  // Expose this as a method so that the parsing may be updated when the user has added additional, custom types\n  _refreshTypeParser(dataType) {\n    parserStore.refresh(dataType);\n  }\n\n  _clearTypeParser() {\n    parserStore.clear();\n  }\n\n  getConnection(options) {\n    options = options || {};\n    options.uuid = options.uuid || \"default\";\n\n    if (this.connections[options.uuid]) {\n      return Promise.resolve(this.connections[options.uuid]);\n    }\n\n    return new Promise((resolve, reject) => {\n      this.connections[options.uuid] = !this.conn\n        ? this.openDatabase()\n        : this.conn;\n      debug(`connection acquired ${options.uuid}`);\n      if (!this.connections[options.uuid])\n        return reject(\n          new sequelizeErrors.ConnectionError(\n            new Error(\"Database reference no found!\")\n          )\n        );\n      resolve(this.connections[options.uuid]);\n    }).tap(connection => {\n      if (this.sequelize.config.password) {\n        // Make it possible to define and use password for sqlite encryption plugin like sqlcipher\n        if (connection && connection.exec) {\n          connection.exec(\n            [\n              {\n                sql: `PRAGMA KEY=${this.sequelize.escape(\n                  this.sequelize.config.password\n                )};`,\n                args: []\n              }\n            ],\n            false,\n            () => {}\n          );\n        }\n      }\n      if (this.sequelize.options.foreignKeys !== false) {\n        // Make it possible to define and use foreign key constraints unless\n        // explicitly disallowed. It's still opt-in per relation\n        if (connection && connection.exec) {\n          connection.exec(\n            [{ sql: \"PRAGMA FOREIGN_KEYS=ON\", args: [] }],\n            false,\n            () => {}\n          );\n        }\n      }\n    });\n  }\n\n  releaseConnection(connection, force) {\n    if (force !== true) return;\n\n    if (connection.uuid) {\n      connection.close && connection.close();\n      this.conn = undefined;\n      debug(`connection released ${connection.uuid}`);\n      delete this.connections[connection.uuid];\n    }\n  }\n}\n\nmodule.exports = ConnectionManager;\nmodule.exports.ConnectionManager = ConnectionManager;\nmodule.exports.default = ConnectionManager;\n"]} \ No newline at end of file diff --git a/lib/dialects/sqlite/connection-manager.js b/lib/dialects/sqlite/connection-manager.js index 939f858..ad9f56e 100644 --- a/lib/dialects/sqlite/connection-manager.js +++ b/lib/dialects/sqlite/connection-manager.js @@ -27,15 +27,11 @@ class ConnectionManager extends AbstractConnectionManager { } _onProcessExit() { - const promises = Object - .getOwnPropertyNames(this.connections) - .map(connection => { - return Promise.fromCallback(callback => { - return this.connections[connection].then(db => { - db.close(callback); - }); - }); + const promises = [Promise.fromCallback(callback => { + return this.connections['default'].then(db => { + db.close(callback, callback); }); + })]; return Promise.all(promises).then(super._onProcessExit.bind(this)); } From b0064d048ee51e7dfbe9af8ed55dfbfe13d6e044 Mon Sep 17 00:00:00 2001 From: prih Date: Tue, 15 Dec 2020 13:50:42 +0200 Subject: [PATCH 5/8] executeSql --- dist/dialects/sqlite/query.js | 82 +++++++++++++++++++++++++++-------- lib/dialects/sqlite/query.js | 52 +++++++++++++++++++++- 2 files changed, 115 insertions(+), 19 deletions(-) diff --git a/dist/dialects/sqlite/query.js b/dist/dialects/sqlite/query.js index ee64954..5cf57ed 100644 --- a/dist/dialects/sqlite/query.js +++ b/dist/dialects/sqlite/query.js @@ -319,14 +319,54 @@ let Query = /*#__PURE__*/function (_AbstractQuery) { resolve(); } } else { - conn.transaction(function (t) { + var successCallback = function (_, results) { + try { + complete(); // `self` is passed from sqlite, we have no control over this. + // eslint-disable-next-line no-invalid-this + + if (results.rowsAffected) { + try { + self[self.getInsertIdField()] = results.insertId; + } catch (e) { + delete self[self.getInsertIdField()]; + } + } + + self.changes = results.rowsAffected; + results = query.convertToArray(results); + resolve(query._handleQueryResponse(self, columnTypes, undefined, results)); + return; + } catch (error) { + debug(error); + reject(error); + } + }; // eslint-disable-next-line + + + var errorCallback = function (_, err) { + try { + complete(); // `self` is passed from sqlite, we have no control over this. + // eslint-disable-next-line no-invalid-this + + resolve(query._handleQueryResponse(self, columnTypes, err)); + } catch (error) { + reject(error); + } + }; + + if (typeof conn.exec === "function") { + parameters = parameters || []; + } else parameters = []; + + conn.executeSql(self.sql, parameters, successCallback, errorCallback); + /*conn.transaction(function(t) { // cannot use arrow function here because the function is bound to the statement // eslint-disable-next-line - var successCallback = function (_, results) { + var successCallback = function(_, results) { try { - complete(); // `self` is passed from sqlite, we have no control over this. + complete(); + // `self` is passed from sqlite, we have no control over this. // eslint-disable-next-line no-invalid-this - if (results.rowsAffected) { try { self[self.getInsertIdField()] = results.insertId; @@ -334,35 +374,43 @@ let Query = /*#__PURE__*/function (_AbstractQuery) { delete self[self.getInsertIdField()]; } } - self.changes = results.rowsAffected; results = query.convertToArray(results); - resolve(query._handleQueryResponse(self, columnTypes, undefined, results)); + resolve( + query._handleQueryResponse( + self, + columnTypes, + undefined, + results + ) + ); return; } catch (error) { debug(error); reject(error); } - }; // eslint-disable-next-line - - - var errorCallback = function (_, err) { + }; + // eslint-disable-next-line + var errorCallback = function(_, err) { try { - complete(); // `self` is passed from sqlite, we have no control over this. + complete(); + // `self` is passed from sqlite, we have no control over this. // eslint-disable-next-line no-invalid-this - resolve(query._handleQueryResponse(self, columnTypes, err)); } catch (error) { reject(error); } }; - if (typeof conn.exec === "function") { parameters = parameters || []; } else parameters = []; - - t.executeSql(self.sql, parameters, successCallback, errorCallback); - }); + t.executeSql( + self.sql, + parameters, + successCallback, + errorCallback + ); + });*/ } })); return null; @@ -654,4 +702,4 @@ let Query = /*#__PURE__*/function (_AbstractQuery) { module.exports = Query; module.exports.Query = Query; module.exports.default = Query; -//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../lib/dialects/sqlite/query.js"],"names":["_","require","Utils","Promise","AbstractQuery","QueryTypes","sequelizeErrors","parserStore","logger","debug","debugContext","getMethods","obj","properties","Set","currentObj","Object","getOwnPropertyNames","map","item","add","getPrototypeOf","keys","filter","Query","include","prefix","ret","_include","key","as","model","merge","_collectModels","metaData","columnTypes","err","results","sql","formatError","result","instance","isInsertQuery","handleInsertQuery","autoIncrementAttribute","primaryKeyAttribute","rawAttributes","startId","getInsertIdField","changes","i","push","field","isShowTablesQuery","row","name","isShowConstraintsQuery","parseConstraintsFromSql","isSelectQuery","options","raw","handleSelectQuery","prefixes","mapValues","value","includes","lastind","lastIndexOf","substr","tableName","getTableName","toString","replace","tableTypes","forOwn","attribute","prototype","hasOwnProperty","call","applyParsers","isShowOrDescribeQuery","handleShowIndexesQuery","Array","isArray","defaultValue","_result","dflt_value","undefined","type","allowNull","notnull","primaryKey","pk","BULKUPDATE","BULKDELETE","UPSERT","VERSION","version","RAW","isUpdateQuery","parameters","formatBindParameters","bind","dialect","skipUnescape","method","getDatabaseMethod","complete","_logQuery","query","self","conn","connection","resolve","executeSql","startsWith","reject","exec","args","executionError","convertToArray","_handleQueryResponse","error","transaction","t","successCallback","rowsAffected","insertId","e","errorCallback","tableNames","length","sqlCommands","sqlCmd","rows","forEach","index","table","columns","match","col","colName","colType","trim","split","then","constraints","referenceTableName","referenceTableKeys","updateAction","deleteAction","splice","constraintSql","referencesRegex","referenceConditions","removeTicks","columnNames","column","constraintCondition","constraint","constraintName","constraintType","indexOf","toUpperCase","parse","get","timezone","sequelize","code","message","ForeignKeyConstraintError","parent","fields","columnWithTable","errors","ValidationErrorItem","getUniqueConstraintErrorMessage","uniqueKeys","isEqual","msg","UniqueConstraintError","TimeoutError","DatabaseError","data","reverse","primary","unique","run","seqno","order","isBulkUpdateQuery","toLowerCase","array","_array","values","bindParam","v","skipValueReplace","k","module","exports","default"],"mappings":"AAAA;;;;;;;;;;;;;;;;;;;;;;AAEA,MAAMA,CAAC,GAAGC,OAAO,CAAC,QAAD,CAAjB;;AACA,MAAMC,KAAK,GAAGD,OAAO,CAAC,aAAD,CAArB;;AACA,MAAME,OAAO,GAAGF,OAAO,CAAC,eAAD,CAAvB;;AACA,MAAMG,aAAa,GAAGH,OAAO,CAAC,mBAAD,CAA7B;;AACA,MAAMI,UAAU,GAAGJ,OAAO,CAAC,mBAAD,CAA1B;;AACA,MAAMK,eAAe,GAAGL,OAAO,CAAC,cAAD,CAA/B;;AACA,MAAMM,WAAW,GAAGN,OAAO,CAAC,gBAAD,CAAP,CAA0B,QAA1B,CAApB;;AACA,MAAM;AAAEO,EAAAA;AAAF,IAAaP,OAAO,CAAC,oBAAD,CAA1B;;AAEA,MAAMQ,KAAK,GAAGD,MAAM,CAACE,YAAP,CAAoB,YAApB,CAAd;;AACA,MAAMC,UAAU,GAAGC,GAAG,IAAI;AACxB,MAAIC,UAAU,GAAG,IAAIC,GAAJ,EAAjB;AACA,MAAIC,UAAU,GAAGH,GAAjB;;AACA,KAAG;AACDI,IAAAA,MAAM,CAACC,mBAAP,CAA2BF,UAA3B,EAAuCG,GAAvC,CAA2CC,IAAI,IAAIN,UAAU,CAACO,GAAX,CAAeD,IAAf,CAAnD;AACD,GAFD,QAEUJ,UAAU,GAAGC,MAAM,CAACK,cAAP,CAAsBN,UAAtB,CAFvB;;AAGA,SAAO,CAAC,GAAGF,UAAU,CAACS,IAAX,EAAJ,EAAuBC,MAAvB,CAA8BJ,IAAI,IAAI,OAAOP,GAAG,CAACO,IAAD,CAAV,KAAqB,UAA3D,CAAP;AACD,CAPD;;IAQMK,K;;;;;;;;;;;;;uCACe;AACjB,aAAO,QAAP;AACD;AAED;AACF;AACA;AACA;AACA;AACA;AACA;AACA;;;;mCAyBiBC,O,EAASC,M,EAAQ;AAC9B,YAAMC,GAAG,GAAG,EAAZ;;AAEA,UAAIF,OAAJ,EAAa;AACX,aAAK,MAAMG,QAAX,IAAuBH,OAAvB,EAAgC;AAC9B,cAAII,GAAJ;;AACA,cAAI,CAACH,MAAL,EAAa;AACXG,YAAAA,GAAG,GAAGD,QAAQ,CAACE,EAAf;AACD,WAFD,MAEO;AACLD,YAAAA,GAAG,GAAI,GAAEH,MAAO,IAAGE,QAAQ,CAACE,EAAG,EAA/B;AACD;;AACDH,UAAAA,GAAG,CAACE,GAAD,CAAH,GAAWD,QAAQ,CAACG,KAApB;;AAEA,cAAIH,QAAQ,CAACH,OAAb,EAAsB;AACpBzB,YAAAA,CAAC,CAACgC,KAAF,CAAQL,GAAR,EAAa,KAAKM,cAAL,CAAoBL,QAAQ,CAACH,OAA7B,EAAsCI,GAAtC,CAAb;AACD;AACF;AACF;;AAED,aAAOF,GAAP;AACD;;;yCAEoBO,Q,EAAUC,W,EAAaC,G,EAAKC,O,EAAS;AACxD,UAAID,GAAJ,EAAS;AACPA,QAAAA,GAAG,CAACE,GAAJ,GAAU,KAAKA,GAAf;AACA,cAAM,KAAKC,WAAL,CAAiBH,GAAjB,CAAN;AACD;;AACD,UAAII,MAAM,GAAG,KAAKC,QAAlB,CALwD,CAMxD;;AACA,UAAI,KAAKC,aAAL,CAAmBL,OAAnB,EAA4BH,QAA5B,CAAJ,EAA2C;AACzC,aAAKS,iBAAL,CAAuBN,OAAvB,EAAgCH,QAAhC;;AACA,YAAI,CAAC,KAAKO,QAAV,EAAoB;AAClB;AACA;AACE;AACA,eAAKV,KAAL,IACA,KAAKA,KAAL,CAAWa,sBADX,IAEA,KAAKb,KAAL,CAAWa,sBAAX,KACE,KAAKb,KAAL,CAAWc,mBAHb,IAIA,KAAKd,KAAL,CAAWe,aAAX,CAAyB,KAAKf,KAAL,CAAWc,mBAApC,CANF,EAOE;AACA,kBAAME,OAAO,GACXb,QAAQ,CAAC,KAAKc,gBAAL,EAAD,CAAR,GAAoCd,QAAQ,CAACe,OAA7C,GAAuD,CADzD;AAGAT,YAAAA,MAAM,GAAG,EAAT;;AACA,iBAAK,IAAIU,CAAC,GAAGH,OAAb,EAAsBG,CAAC,GAAGH,OAAO,GAAGb,QAAQ,CAACe,OAA7C,EAAsDC,CAAC,EAAvD,EAA2D;AACzDV,cAAAA,MAAM,CAACW,IAAP,CAAY;AACV,iBAAC,KAAKpB,KAAL,CAAWe,aAAX,CAAyB,KAAKf,KAAL,CAAWc,mBAApC,EACEO,KADH,GACWF;AAFD,eAAZ;AAID;AACF,WAlBD,MAkBO;AACLV,YAAAA,MAAM,GAAGN,QAAQ,CAAC,KAAKc,gBAAL,EAAD,CAAjB;AACD;AACF;AACF;;AAED,UAAI,KAAKK,iBAAL,EAAJ,EAA8B;AAC5B,eAAOhB,OAAO,CAACnB,GAAR,CAAYoC,GAAG,IAAIA,GAAG,CAACC,IAAvB,CAAP;AACD;;AACD,UAAI,KAAKC,sBAAL,EAAJ,EAAmC;AACjChB,QAAAA,MAAM,GAAGH,OAAT;;AACA,YAAIA,OAAO,IAAIA,OAAO,CAAC,CAAD,CAAlB,IAAyBA,OAAO,CAAC,CAAD,CAAP,CAAWC,GAAxC,EAA6C;AAC3CE,UAAAA,MAAM,GAAG,KAAKiB,uBAAL,CAA6BpB,OAAO,CAAC,CAAD,CAAP,CAAWC,GAAxC,CAAT;AACD;;AACD,eAAOE,MAAP;AACD;;AACD,UAAI,KAAKkB,aAAL,EAAJ,EAA0B;AACxB,YAAI,KAAKC,OAAL,CAAaC,GAAjB,EAAsB;AACpB,iBAAO,KAAKC,iBAAL,CAAuBxB,OAAvB,CAAP;AACD,SAHuB,CAIxB;;;AACA,cAAMyB,QAAQ,GAAG,KAAK7B,cAAL,CAAoB,KAAK0B,OAAL,CAAalC,OAAjC,CAAjB;;AAEAY,QAAAA,OAAO,GAAGA,OAAO,CAACnB,GAAR,CAAYsB,MAAM,IAAI;AAC9B,iBAAOxC,CAAC,CAAC+D,SAAF,CAAYvB,MAAZ,EAAoB,CAACwB,KAAD,EAAQT,IAAR,KAAiB;AAC1C,gBAAIxB,KAAJ;;AACA,gBAAIwB,IAAI,CAACU,QAAL,CAAc,GAAd,CAAJ,EAAwB;AACtB,oBAAMC,OAAO,GAAGX,IAAI,CAACY,WAAL,CAAiB,GAAjB,CAAhB;AAEApC,cAAAA,KAAK,GAAG+B,QAAQ,CAACP,IAAI,CAACa,MAAL,CAAY,CAAZ,EAAeF,OAAf,CAAD,CAAhB;AAEAX,cAAAA,IAAI,GAAGA,IAAI,CAACa,MAAL,CAAYF,OAAO,GAAG,CAAtB,CAAP;AACD,aAND,MAMO;AACLnC,cAAAA,KAAK,GAAG,KAAK4B,OAAL,CAAa5B,KAArB;AACD;;AAED,kBAAMsC,SAAS,GAAGtC,KAAK,CACpBuC,YADe,GAEfC,QAFe,GAGfC,OAHe,CAGP,IAHO,EAGD,EAHC,CAAlB;AAIA,kBAAMC,UAAU,GAAGtC,WAAW,CAACkC,SAAD,CAAX,IAA0B,EAA7C;;AAEA,gBAAII,UAAU,IAAI,EAAElB,IAAI,IAAIkB,UAAV,CAAlB,EAAyC;AACvC;AACAzE,cAAAA,CAAC,CAAC0E,MAAF,CAAS3C,KAAK,CAACe,aAAf,EAA8B,CAAC6B,SAAD,EAAY9C,GAAZ,KAAoB;AAChD,oBAAI0B,IAAI,KAAK1B,GAAT,IAAgB8C,SAAS,CAACvB,KAA9B,EAAqC;AACnCG,kBAAAA,IAAI,GAAGoB,SAAS,CAACvB,KAAjB;AACA,yBAAO,KAAP;AACD;AACF,eALD;AAMD;;AAED,mBAAOpC,MAAM,CAAC4D,SAAP,CAAiBC,cAAjB,CAAgCC,IAAhC,CAAqCL,UAArC,EAAiDlB,IAAjD,IACH,KAAKwB,YAAL,CAAkBN,UAAU,CAAClB,IAAD,CAA5B,EAAoCS,KAApC,CADG,GAEHA,KAFJ;AAGD,WA/BM,CAAP;AAgCD,SAjCS,CAAV;AAmCA,eAAO,KAAKH,iBAAL,CAAuBxB,OAAvB,CAAP;AACD;;AACD,UAAI,KAAK2C,qBAAL,EAAJ,EAAkC;AAChC,eAAO3C,OAAP;AACD;;AACD,UAAI,KAAKC,GAAL,CAAS2B,QAAT,CAAkB,mBAAlB,CAAJ,EAA4C;AAC1C,eAAO,KAAKgB,sBAAL,CAA4B5C,OAA5B,CAAP;AACD;;AACD,UAAI,KAAKC,GAAL,CAAS2B,QAAT,CAAkB,mBAAlB,CAAJ,EAA4C;AAC1C,eAAO5B,OAAP;AACD;;AACD,UAAI,KAAKC,GAAL,CAAS2B,QAAT,CAAkB,mBAAlB,CAAJ,EAA4C;AAC1C;AACAzB,QAAAA,MAAM,GAAG,EAAT;;AAEA,YAAI0C,KAAK,CAACC,OAAN,CAAc9C,OAAd,CAAJ,EAA4B;AAC1B,cAAI+C,YAAJ;;AACA,eAAK,MAAMC,OAAX,IAAsBhD,OAAtB,EAA+B;AAC7B,gBAAIgD,OAAO,CAACC,UAAR,KAAuB,IAA3B,EAAiC;AAC/B;AACAF,cAAAA,YAAY,GAAGG,SAAf;AACD,aAHD,MAGO,IAAIF,OAAO,CAACC,UAAR,KAAuB,MAA3B,EAAmC;AACxC;AACAF,cAAAA,YAAY,GAAG,IAAf;AACD,aAHM,MAGA;AACLA,cAAAA,YAAY,GAAGC,OAAO,CAACC,UAAvB;AACD;;AAED9C,YAAAA,MAAM,CAAC6C,OAAO,CAAC9B,IAAT,CAAN,GAAuB;AACrBiC,cAAAA,IAAI,EAAEH,OAAO,CAACG,IADO;AAErBC,cAAAA,SAAS,EAAEJ,OAAO,CAACK,OAAR,KAAoB,CAFV;AAGrBN,cAAAA,YAHqB;AAIrBO,cAAAA,UAAU,EAAEN,OAAO,CAACO,EAAR,KAAe;AAJN,aAAvB;;AAOA,gBAAIpD,MAAM,CAAC6C,OAAO,CAAC9B,IAAT,CAAN,CAAqBiC,IAArB,KAA8B,YAAlC,EAAgD;AAC9ChD,cAAAA,MAAM,CAAC6C,OAAO,CAAC9B,IAAT,CAAN,CAAqB6B,YAArB,GAAoC;AAAE,qBAAK,KAAP;AAAc,qBAAK;AAAnB,gBAClC5C,MAAM,CAAC6C,OAAO,CAAC9B,IAAT,CAAN,CAAqB6B,YADa,CAApC;AAGD;;AAED,gBAAI,OAAO5C,MAAM,CAAC6C,OAAO,CAAC9B,IAAT,CAAN,CAAqB6B,YAA5B,KAA6C,QAAjD,EAA2D;AACzD5C,cAAAA,MAAM,CAAC6C,OAAO,CAAC9B,IAAT,CAAN,CAAqB6B,YAArB,GAAoC5C,MAAM,CACxC6C,OAAO,CAAC9B,IADgC,CAAN,CAElC6B,YAFkC,CAErBZ,OAFqB,CAEb,IAFa,EAEP,EAFO,CAApC;AAGD;AACF;AACF;;AAED,eAAOhC,MAAP;AACD;;AACD,UAAI,KAAKF,GAAL,CAAS2B,QAAT,CAAkB,sBAAlB,CAAJ,EAA+C;AAC7C,eAAO5B,OAAO,CAAC,CAAD,CAAd;AACD;;AACD,UAAI,KAAKC,GAAL,CAAS2B,QAAT,CAAkB,qBAAlB,CAAJ,EAA8C;AAC5C,eAAO5B,OAAP;AACD;;AACD,UAAI,KAAKC,GAAL,CAAS2B,QAAT,CAAkB,yBAAlB,CAAJ,EAAkD;AAChD,eAAO5B,OAAP;AACD;;AACD,UACE,CAAChC,UAAU,CAACwF,UAAZ,EAAwBxF,UAAU,CAACyF,UAAnC,EAA+C7B,QAA/C,CAAwD,KAAKN,OAAL,CAAa6B,IAArE,CADF,EAEE;AACA,eAAOtD,QAAQ,CAACe,OAAhB;AACD;;AACD,UAAI,KAAKU,OAAL,CAAa6B,IAAb,KAAsBnF,UAAU,CAAC0F,MAArC,EAA6C;AAC3C,eAAOR,SAAP;AACD;;AACD,UAAI,KAAK5B,OAAL,CAAa6B,IAAb,KAAsBnF,UAAU,CAAC2F,OAArC,EAA8C;AAC5C,eAAO3D,OAAO,CAAC,CAAD,CAAP,CAAW4D,OAAlB;AACD;;AACD,UAAI,KAAKtC,OAAL,CAAa6B,IAAb,KAAsBnF,UAAU,CAAC6F,GAArC,EAA0C;AACxC,eAAO,CAAC7D,OAAD,EAAUH,QAAV,CAAP;AACD;;AACD,UAAI,KAAKiE,aAAL,MAAwB,KAAKzD,aAAL,EAA5B,EAAkD;AAChD,eAAO,CAACF,MAAD,EAASN,QAAQ,CAACe,OAAlB,CAAP;AACD;;AACD,aAAOT,MAAP;AACD,K,CACD;;;;wBACIF,G,EAAK8D,U,EAAY;AACnB;AACA,WAAK9D,GAAL,GAAWlC,aAAa,CAACiG,oBAAd,CACT/D,GADS,EAET,KAAKqB,OAAL,CAAa2C,IAFJ,EAGT,KAAK3C,OAAL,CAAa4C,OAAb,IAAwB,QAHf,EAIT;AAAEC,QAAAA,YAAY,EAAE;AAAhB,OAJS,EAKT,CALS,CAAX;AAMA,YAAMC,MAAM,GAAG,KAAKC,iBAAL,EAAf;;AACA,YAAMC,QAAQ,GAAG,KAAKC,SAAL,CAAe,KAAKtE,GAApB,EAAyB7B,KAAzB,EAAgC2F,UAAhC,CAAjB;;AACA,YAAMS,KAAK,GAAG,IAAd;AACA,YAAMC,IAAI,GAAG,IAAb;AACA,YAAMC,IAAI,GAAG,KAAKC,UAAlB;AAEA,aAAO,IAAI7G,OAAJ,CAAY8G,OAAO,IAAI;AAC5B,cAAM9E,WAAW,GAAG,EAApB,CAD4B,CAE5B;;AACA,cAAM+E,UAAU,GAAG,MAAM;AACvB,cAAI5E,GAAG,CAAC6E,UAAJ,CAAe,KAAf,CAAJ,EAA2B;AACzB,mBAAOF,OAAO,EAAd;AACD;;AACDA,UAAAA,OAAO,CACL,IAAI9G,OAAJ,CAAY,CAAC8G,OAAD,EAAUG,MAAV,KAAqB;AAC/B,gBAAIX,MAAM,KAAK,MAAf,EAAuB;AACrB,kBAAI,OAAOM,IAAI,CAACM,IAAZ,KAAqB,UAAzB,EAAqC;AACnCN,gBAAAA,IAAI,CAACM,IAAL,CACE,CAAC;AAAE/E,kBAAAA,GAAG,EAAEwE,IAAI,CAACxE,GAAZ;AAAiBgF,kBAAAA,IAAI,EAAE;AAAvB,iBAAD,CADF,EAEE,KAFF,EAGE,CAACC,cAAD,EAAiBlF,OAAjB,KAA6B;AAC3B,sBAAI;AACFsE,oBAAAA,QAAQ,GADN,CAEF;;AACAtE,oBAAAA,OAAO,GAAGwE,KAAK,CAACW,cAAN,CAAqBnF,OAAO,CAAC,CAAD,CAA5B,CAAV,CAHE,CAIF;AACA;;AACA4E,oBAAAA,OAAO,CACLJ,KAAK,CAACY,oBAAN,CACEX,IADF,EAEE3E,WAFF,EAGEoF,cAHF,EAIElF,OAJF,CADK,CAAP;AAQA;AACD,mBAfD,CAeE,OAAOqF,KAAP,EAAc;AACdN,oBAAAA,MAAM,CAACM,KAAD,CAAN;AACD;AACF,iBAtBH;AAwBD,eAzBD,MAyBO;AACLT,gBAAAA,OAAO;AACR;AACF,aA7BD,MA6BO;AACLF,cAAAA,IAAI,CAACY,WAAL,CAAiB,UAASC,CAAT,EAAY;AAC3B;AACA;AACA,oBAAIC,eAAe,GAAG,UAAS7H,CAAT,EAAYqC,OAAZ,EAAqB;AACzC,sBAAI;AACFsE,oBAAAA,QAAQ,GADN,CAEF;AACA;;AACA,wBAAItE,OAAO,CAACyF,YAAZ,EAA0B;AACxB,0BAAI;AACFhB,wBAAAA,IAAI,CAACA,IAAI,CAAC9D,gBAAL,EAAD,CAAJ,GAAgCX,OAAO,CAAC0F,QAAxC;AACD,uBAFD,CAEE,OAAOC,CAAP,EAAU;AACV,+BAAOlB,IAAI,CAACA,IAAI,CAAC9D,gBAAL,EAAD,CAAX;AACD;AACF;;AACD8D,oBAAAA,IAAI,CAAC7D,OAAL,GAAeZ,OAAO,CAACyF,YAAvB;AACAzF,oBAAAA,OAAO,GAAGwE,KAAK,CAACW,cAAN,CAAqBnF,OAArB,CAAV;AACA4E,oBAAAA,OAAO,CACLJ,KAAK,CAACY,oBAAN,CACEX,IADF,EAEE3E,WAFF,EAGEoD,SAHF,EAIElD,OAJF,CADK,CAAP;AAQA;AACD,mBAtBD,CAsBE,OAAOqF,KAAP,EAAc;AACdjH,oBAAAA,KAAK,CAACiH,KAAD,CAAL;AACAN,oBAAAA,MAAM,CAACM,KAAD,CAAN;AACD;AACF,iBA3BD,CAH2B,CA+B3B;;;AACA,oBAAIO,aAAa,GAAG,UAASjI,CAAT,EAAYoC,GAAZ,EAAiB;AACnC,sBAAI;AACFuE,oBAAAA,QAAQ,GADN,CAEF;AACA;;AACAM,oBAAAA,OAAO,CAACJ,KAAK,CAACY,oBAAN,CAA2BX,IAA3B,EAAiC3E,WAAjC,EAA8CC,GAA9C,CAAD,CAAP;AACD,mBALD,CAKE,OAAOsF,KAAP,EAAc;AACdN,oBAAAA,MAAM,CAACM,KAAD,CAAN;AACD;AACF,iBATD;;AAUA,oBAAI,OAAOX,IAAI,CAACM,IAAZ,KAAqB,UAAzB,EAAqC;AACnCjB,kBAAAA,UAAU,GAAGA,UAAU,IAAI,EAA3B;AACD,iBAFD,MAEOA,UAAU,GAAG,EAAb;;AACPwB,gBAAAA,CAAC,CAACV,UAAF,CACEJ,IAAI,CAACxE,GADP,EAEE8D,UAFF,EAGEyB,eAHF,EAIEI,aAJF;AAMD,eAnDD;AAoDD;AACF,WApFD,CADK,CAAP;AAuFA,iBAAO,IAAP;AACD,SA5FD;;AA8FA,YAAIxB,MAAM,KAAK,KAAf,EAAsB;AACpB,cAAIyB,UAAU,GAAG,EAAjB;;AACA,cAAI,KAAKvE,OAAL,IAAgB,KAAKA,OAAL,CAAauE,UAAjC,EAA6C;AAC3CA,YAAAA,UAAU,GAAG,KAAKvE,OAAL,CAAauE,UAA1B;AACD,WAFD,MAEO,IAAI,gBAAgBb,IAAhB,CAAqB,KAAK/E,GAA1B,CAAJ,EAAoC;AACzC4F,YAAAA,UAAU,CAAC/E,IAAX,CAAgB,gBAAgBkE,IAAhB,CAAqB,KAAK/E,GAA1B,EAA+B,CAA/B,CAAhB;AACD,WANmB,CAQpB;;;AACA4F,UAAAA,UAAU,GAAGA,UAAU,CAAC3G,MAAX,CACX8C,SAAS,IACP,EAAEA,SAAS,IAAIlC,WAAf,KAA+BkC,SAAS,KAAK,eAFpC,CAAb;;AAIA,cAAI,CAAC6D,UAAU,CAACC,MAAhB,EAAwB;AACtB,mBAAOjB,UAAU,EAAjB;AACD;;AACD,iBAAO,IAAI/G,OAAJ,CAAY8G,OAAO,IAAI;AAC5B,gBAAI,OAAOF,IAAI,CAACM,IAAZ,KAAqB,UAAzB,EAAqC;AACnC,oBAAMe,WAAW,GAAGF,UAAU,CAAChH,GAAX,CAAemD,SAAS,IAAI;AAC9CA,gBAAAA,SAAS,GAAGA,SAAS,CAACG,OAAV,CAAkB,IAAlB,EAAwB,EAAxB,CAAZ;AACArC,gBAAAA,WAAW,CAACkC,SAAD,CAAX,GAAyB,EAAzB;AACA,uBAAO,CAAE,uBAAsBA,SAAU,KAAlC,EAAwCA,SAAxC,CAAP;AACD,eAJmB,CAApB;AAKA0C,cAAAA,IAAI,CAACM,IAAL,CACEe,WAAW,CAAClH,GAAZ,CAAgBmH,MAAM,KAAK;AACzB/F,gBAAAA,GAAG,EAAE+F,MAAM,CAAC,CAAD,CADc;AAEzBf,gBAAAA,IAAI,EAAE;AAFmB,eAAL,CAAtB,CADF,EAKE,KALF,EAME,CAAClF,GAAD,EAAMC,OAAN,KAAkB;AAChB,oBAAI,CAACD,GAAL,EAAU;AACR,uBAAK,IAAIc,CAAC,GAAG,CAAb,EAAgBA,CAAC,GAAGkF,WAAW,CAACD,MAAhC,EAAwCjF,CAAC,EAAzC,EAA6C;AAC3C,0BAAMmB,SAAS,GAAG+D,WAAW,CAAClF,CAAD,CAAX,CAAe,CAAf,CAAlB;;AACA,yBAAK,MAAMV,MAAX,IAAqBH,OAAO,CAACa,CAAD,CAAP,CAAWoF,IAAhC,EAAsC;AACpCnG,sBAAAA,WAAW,CAACkC,SAAD,CAAX,CAAuB7B,MAAM,CAACe,IAA9B,IAAsCf,MAAM,CAACgD,IAA7C;AACD;AACF;AACF;;AACDyB,gBAAAA,OAAO;AACR,eAhBH;AAkBD,aAxBD,MAwBO;AACLF,cAAAA,IAAI,CAACY,WAAL,CAAiB,UAASC,CAAT,EAAY;AAC3BM,gBAAAA,UAAU,CAACK,OAAX,CAAmB,CAAClE,SAAD,EAAYmE,KAAZ,KAAsB;AACvCZ,kBAAAA,CAAC,CAACV,UAAF,CACG,iDAAgD7C,SAAU,oBAD7D,EAEE,EAFF,EAGE,UAASrE,CAAT,EAAYwC,MAAZ,EAAoB;AAClB,0BAAMiG,KAAK,GAAGjG,MAAM,CAAC8F,IAAP,CAAYnH,IAAZ,CAAiB,CAAjB,CAAd;;AACA,wBACE,OAAOsH,KAAP,KAAiB,QAAjB,IACA,SAASA,KADT,IAEA,OAAOA,KAAK,CAACnG,GAAb,KAAqB,QAHvB,EAIE;AACAH,sBAAAA,WAAW,CAACkC,SAAD,CAAX,GAAyB,EAAzB,CADA,CAEA;;AACA,4BAAMqE,OAAO,GAAGD,KAAK,CAACnG,GAAN,CAAUqG,KAAV,CACd,oCADc,CAAhB,CAHA,CAMA;;AACA,2BAAK,MAAMC,GAAX,IAAkBF,OAAlB,EAA2B;AACzB,8BAAM,CAACG,OAAD,EAAUC,OAAV,IAAqBF,GAAG,CAC3BG,IADwB,GAExBvE,OAFwB,CAEhB,MAFgB,EAER,GAFQ,EAGxBA,OAHwB,CAGhB,IAHgB,EAGV,EAHU,EAIxBwE,KAJwB,CAIlB,GAJkB,CAA3B;AAKA7G,wBAAAA,WAAW,CAACkC,SAAD,CAAX,CAAuBwE,OAAvB,IAAkCC,OAAO,CAACC,IAAR,EAAlC;AACD;AACF,qBArBiB,CAsBlB;;;AACA,wBAAIP,KAAK,KAAKN,UAAU,CAACC,MAAX,GAAoB,CAAlC,EAAqClB,OAAO;AAC7C,mBA3BH,EA4BE,UAASjH,CAAT,EAAY0H,KAAZ,EAAmB;AACjB,wBAAIc,KAAK,KAAKN,UAAU,CAACC,MAAX,GAAoB,CAAlC,EAAqClB,OAAO;AAC7C,mBA9BH;AAgCD,iBAjCD;AAkCD,eAnCD;AAoCD;AACF,WA/DM,EA+DJgC,IA/DI,CA+DC/B,UA/DD,CAAP;AAgED;;AACD,eAAOA,UAAU,EAAjB;AACD,OAnLM,CAAP;AAoLD;;;4CAEuB5E,G,EAAK;AAC3B,UAAI4G,WAAW,GAAG5G,GAAG,CAAC0G,KAAJ,CAAU,aAAV,CAAlB;AACA,UAAIG,kBAAJ,EAAwBC,kBAAxB,EAA4CC,YAA5C,EAA0DC,YAA1D;AACAJ,MAAAA,WAAW,CAACK,MAAZ,CAAmB,CAAnB,EAAsB,CAAtB;AACAL,MAAAA,WAAW,GAAGA,WAAW,CAAChI,GAAZ,CAAgBsI,aAAa,IAAI;AAC7C;AACA,YAAIA,aAAa,CAACvF,QAAd,CAAuB,YAAvB,CAAJ,EAA0C;AACxC;AACAoF,UAAAA,YAAY,GAAGG,aAAa,CAACb,KAAd,CACb,gEADa,CAAf;AAGAW,UAAAA,YAAY,GAAGE,aAAa,CAACb,KAAd,CACb,gEADa,CAAf;;AAIA,cAAIU,YAAJ,EAAkB;AAChBA,YAAAA,YAAY,GAAGA,YAAY,CAAC,CAAD,CAA3B;AACD;;AAED,cAAIC,YAAJ,EAAkB;AAChBA,YAAAA,YAAY,GAAGA,YAAY,CAAC,CAAD,CAA3B;AACD;;AAED,gBAAMG,eAAe,GAAG,wDAAxB;AACA,gBAAMC,mBAAmB,GAAGF,aAAa,CACtCb,KADyB,CACnBc,eADmB,EACF,CADE,EAEzBT,KAFyB,CAEnB,GAFmB,CAA5B;AAGAG,UAAAA,kBAAkB,GAAGjJ,KAAK,CAACyJ,WAAN,CAAkBD,mBAAmB,CAAC,CAAD,CAArC,CAArB;AACA,cAAIE,WAAW,GAAGF,mBAAmB,CAAC,CAAD,CAArC;AACAE,UAAAA,WAAW,GAAGA,WAAW,CAACpF,OAAZ,CAAoB,QAApB,EAA8B,EAA9B,EAAkCwE,KAAlC,CAAwC,IAAxC,CAAd;AACAI,UAAAA,kBAAkB,GAAGQ,WAAW,CAAC1I,GAAZ,CAAgB2I,MAAM,IACzC3J,KAAK,CAACyJ,WAAN,CAAkBE,MAAlB,CADmB,CAArB;AAGD;;AAED,cAAMC,mBAAmB,GAAGN,aAAa,CAACb,KAAd,CAC1B,4CAD0B,EAE1B,CAF0B,CAA5B;AAGAa,QAAAA,aAAa,GAAGA,aAAa,CAAChF,OAAd,CAAsB,QAAtB,EAAgC,EAAhC,CAAhB;AACA,cAAMuF,UAAU,GAAGP,aAAa,CAACR,KAAd,CAAoB,GAApB,CAAnB;;AAEA,YAAIe,UAAU,CAAC,CAAD,CAAV,KAAkB,SAAlB,IAA+BA,UAAU,CAAC,CAAD,CAAV,KAAkB,SAArD,EAAgE;AAC9DA,UAAAA,UAAU,CAAC,CAAD,CAAV,IAAiB,MAAjB;AACD;;AAED,eAAO;AACLC,UAAAA,cAAc,EAAE9J,KAAK,CAACyJ,WAAN,CAAkBI,UAAU,CAAC,CAAD,CAA5B,CADX;AAELE,UAAAA,cAAc,EAAEF,UAAU,CAAC,CAAD,CAFrB;AAGLV,UAAAA,YAHK;AAILC,UAAAA,YAJK;AAKLhH,UAAAA,GAAG,EAAEA,GAAG,CAACkC,OAAJ,CAAY,IAAZ,EAAkB,GAAlB,CALA;AAKwB;AAC7BsF,UAAAA,mBANK;AAOLX,UAAAA,kBAPK;AAQLC,UAAAA;AARK,SAAP;AAUD,OAnDa,CAAd;AAqDA,aAAOF,WAAP;AACD;;;iCAEY1D,I,EAAMxB,K,EAAO;AACxB,UAAIwB,IAAI,CAACvB,QAAL,CAAc,GAAd,CAAJ,EAAwB;AACtB;AACAuB,QAAAA,IAAI,GAAGA,IAAI,CAACpB,MAAL,CAAY,CAAZ,EAAeoB,IAAI,CAAC0E,OAAL,CAAa,GAAb,CAAf,CAAP;AACD;;AACD1E,MAAAA,IAAI,GAAGA,IAAI,CAAChB,OAAL,CAAa,UAAb,EAAyB,EAAzB,EAA6BA,OAA7B,CAAqC,UAArC,EAAiD,EAAjD,CAAP;AACAgB,MAAAA,IAAI,GAAGA,IAAI,CAACuD,IAAL,GAAYoB,WAAZ,EAAP;AACA,YAAMC,KAAK,GAAG7J,WAAW,CAAC8J,GAAZ,CAAgB7E,IAAhB,CAAd;;AACA,UAAIxB,KAAK,KAAK,IAAV,IAAkBoG,KAAtB,EAA6B;AAC3B,eAAOA,KAAK,CAACpG,KAAD,EAAQ;AAAEsG,UAAAA,QAAQ,EAAE,KAAKC,SAAL,CAAe5G,OAAf,CAAuB2G;AAAnC,SAAR,CAAZ;AACD;;AACD,aAAOtG,KAAP;AACD;;;gCAEW5B,G,EAAK;AACf,cAAQA,GAAG,CAACoI,IAAZ;AACE,aAAK,mBAAL;AAA0B;AACxB,gBAAIpI,GAAG,CAACqI,OAAJ,CAAYxG,QAAZ,CAAqB,+BAArB,CAAJ,EAA2D;AACzD,qBAAO,IAAI3D,eAAe,CAACoK,yBAApB,CAA8C;AACnDC,gBAAAA,MAAM,EAAEvI;AAD2C,eAA9C,CAAP;AAGD;;AAED,gBAAIwI,MAAM,GAAG,EAAb,CAPwB,CASxB;;AACA,gBAAIjC,KAAK,GAAGvG,GAAG,CAACqI,OAAJ,CAAY9B,KAAZ,CAAkB,mBAAlB,CAAZ;;AACA,gBAAIA,KAAK,KAAK,IAAV,IAAkBA,KAAK,CAACR,MAAN,IAAgB,CAAtC,EAAyC;AACvCyC,cAAAA,MAAM,GAAGjC,KAAK,CAAC,CAAD,CAAL,CAASK,KAAT,CAAe,IAAf,CAAT;AACD,aAFD,MAEO;AACL;AACAL,cAAAA,KAAK,GAAGvG,GAAG,CAACqI,OAAJ,CAAY9B,KAAZ,CAAkB,gCAAlB,CAAR;;AACA,kBAAIA,KAAK,KAAK,IAAV,IAAkBA,KAAK,CAACR,MAAN,IAAgB,CAAtC,EAAyC;AACvCyC,gBAAAA,MAAM,GAAGjC,KAAK,CAAC,CAAD,CAAL,CACNK,KADM,CACA,IADA,EAEN9H,GAFM,CAEF2J,eAAe,IAAIA,eAAe,CAAC7B,KAAhB,CAAsB,GAAtB,EAA2B,CAA3B,CAFjB,CAAT;AAGD;AACF;;AAED,kBAAM8B,MAAM,GAAG,EAAf;AACA,gBAAIL,OAAO,GAAG,kBAAd;;AAEA,iBAAK,MAAMrH,KAAX,IAAoBwH,MAApB,EAA4B;AAC1BE,cAAAA,MAAM,CAAC3H,IAAP,CACE,IAAI7C,eAAe,CAACyK,mBAApB,CACE,KAAKC,+BAAL,CAAqC5H,KAArC,CADF,EAEE,kBAFF,EAEsB;AACpBA,cAAAA,KAHF,EAIE,KAAKX,QAAL,IAAiB,KAAKA,QAAL,CAAcW,KAAd,CAJnB,EAKE,KAAKX,QALP,EAME,YANF,CADF;AAUD;;AAED,gBAAI,KAAKV,KAAT,EAAgB;AACd/B,cAAAA,CAAC,CAAC0E,MAAF,CAAS,KAAK3C,KAAL,CAAWkJ,UAApB,EAAgClB,UAAU,IAAI;AAC5C,oBAAI/J,CAAC,CAACkL,OAAF,CAAUnB,UAAU,CAACa,MAArB,EAA6BA,MAA7B,KAAwC,CAAC,CAACb,UAAU,CAACoB,GAAzD,EAA8D;AAC5DV,kBAAAA,OAAO,GAAGV,UAAU,CAACoB,GAArB;AACA,yBAAO,KAAP;AACD;AACF,eALD;AAMD;;AAED,mBAAO,IAAI7K,eAAe,CAAC8K,qBAApB,CAA0C;AAC/CX,cAAAA,OAD+C;AAE/CK,cAAAA,MAF+C;AAG/CH,cAAAA,MAAM,EAAEvI,GAHuC;AAI/CwI,cAAAA;AAJ+C,aAA1C,CAAP;AAMD;;AACD,aAAK,aAAL;AACE,iBAAO,IAAItK,eAAe,CAAC+K,YAApB,CAAiCjJ,GAAjC,CAAP;;AAEF;AACE,iBAAO,IAAI9B,eAAe,CAACgL,aAApB,CAAkClJ,GAAlC,CAAP;AA5DJ;AA8DD;;;2CAEsBmJ,I,EAAM;AAC3B;AACA,aAAOpL,OAAO,CAACe,GAAR,CAAYqK,IAAI,CAACC,OAAL,EAAZ,EAA4BrK,IAAI,IAAI;AACzCA,QAAAA,IAAI,CAACyJ,MAAL,GAAc,EAAd;AACAzJ,QAAAA,IAAI,CAACsK,OAAL,GAAe,KAAf;AACAtK,QAAAA,IAAI,CAACuK,MAAL,GAAc,CAAC,CAACvK,IAAI,CAACuK,MAArB;AACAvK,QAAAA,IAAI,CAAC6I,cAAL,GAAsB7I,IAAI,CAACoC,IAA3B;AACA,eAAO,KAAKoI,GAAL,CAAU,uBAAsBxK,IAAI,CAACoC,IAAK,KAA1C,EAAgD0F,IAAhD,CAAqDP,OAAO,IAAI;AACrE,eAAK,MAAMmB,MAAX,IAAqBnB,OAArB,EAA8B;AAC5BvH,YAAAA,IAAI,CAACyJ,MAAL,CAAYf,MAAM,CAAC+B,KAAnB,IAA4B;AAC1BjH,cAAAA,SAAS,EAAEkF,MAAM,CAACtG,IADQ;AAE1B4E,cAAAA,MAAM,EAAE5C,SAFkB;AAG1BsG,cAAAA,KAAK,EAAEtG;AAHmB,aAA5B;AAKD;;AAED,iBAAOpE,IAAP;AACD,SAVM,CAAP;AAWD,OAhBM,CAAP;AAiBD;;;wCAEmB;AAClB,UACE,KAAKmB,GAAL,CAAS2B,QAAT,CAAkB,QAAlB,KACA,KAAK3B,GAAL,CAAS2B,QAAT,CAAkB,QAAlB,CADA,IAEA,KAAK3B,GAAL,CAAS2B,QAAT,CAAkB,UAAlB,CAFA,IAGA,KAAK3B,GAAL,CAAS2B,QAAT,CAAkB,aAAlB,CAJF,EAKE;AACA,eAAO,MAAP,CADA,CACe;AAChB;;AACD,UACE,KAAKvB,aAAL,MACA,KAAKyD,aAAL,EADA,IAEA,KAAK2F,iBAAL,EAFA,IAGA,KAAKxJ,GAAL,CAASyJ,WAAT,GAAuB9H,QAAvB,CAAgC,yBAAyB8H,WAAzB,EAAhC,CAHA,IAIA,KAAKpI,OAAL,CAAa6B,IAAb,KAAsBnF,UAAU,CAACyF,UALnC,EAME;AACA,eAAO,KAAP;AACD;;AACD,aAAO,KAAP;AACD;;;mCACczD,O,EAAS;AACtB,UAAI,CAACA,OAAO,CAACiG,IAAb,EAAmB,OAAO,EAAP;AACnB,UAAI,WAAWjG,OAAX,IAAsB,YAAYA,OAAO,CAACiG,IAA9C,EACE,OAAOjG,OAAO,CAAC2J,KAAR,IAAiB3J,OAAO,CAACiG,IAAR,CAAa2D,MAArC;AACF,UAAI,CAAC5J,OAAO,CAACiG,IAAR,CAAanH,IAAlB,EAAwB,OAAOkB,OAAO,CAACiG,IAAf;AACxB,YAAMiD,IAAI,GAAG,IAAIrG,KAAJ,CAAU7C,OAAO,CAACiG,IAAR,CAAaH,MAAvB,CAAb;;AACA,WAAK,IAAIjF,CAAC,GAAG,CAAb,EAAgBA,CAAC,GAAGb,OAAO,CAACiG,IAAR,CAAaH,MAAjC,EAAyCjF,CAAC,EAA1C,EAA8C;AAC5CqI,QAAAA,IAAI,CAACrI,CAAD,CAAJ,GAAUb,OAAO,CAACiG,IAAR,CAAanH,IAAb,CAAkB+B,CAAlB,CAAV;AACD;;AACD,aAAOqI,IAAP;AACD;;;yCAvlB2BjJ,G,EAAK4J,M,EAAQ3F,O,EAAS;AAChD,UAAI4F,SAAJ;;AACA,UAAIjH,KAAK,CAACC,OAAN,CAAc+G,MAAd,CAAJ,EAA2B;AACzBC,QAAAA,SAAS,GAAG,EAAZ;AACAD,QAAAA,MAAM,CAAC3D,OAAP,CAAe,CAAC6D,CAAD,EAAIlJ,CAAJ,KAAU;AACvBiJ,UAAAA,SAAS,CAAE,IAAGjJ,CAAC,GAAG,CAAE,EAAX,CAAT,GAAyBkJ,CAAzB;AACD,SAFD;AAGA9J,QAAAA,GAAG,GAAGlC,aAAa,CAACiG,oBAAd,CAAmC/D,GAAnC,EAAwC4J,MAAxC,EAAgD3F,OAAhD,EAAyD;AAC7D8F,UAAAA,gBAAgB,EAAE;AAD2C,SAAzD,EAEH,CAFG,CAAN;AAGD,OARD,MAQO;AACLF,QAAAA,SAAS,GAAG,EAAZ;;AACA,YAAI,OAAOD,MAAP,KAAkB,QAAtB,EAAgC;AAC9B,eAAK,MAAMI,CAAX,IAAgBtL,MAAM,CAACM,IAAP,CAAY4K,MAAZ,CAAhB,EAAqC;AACnCC,YAAAA,SAAS,CAAE,IAAGG,CAAE,EAAP,CAAT,GAAqBJ,MAAM,CAACI,CAAD,CAA3B;AACD;AACF;;AACDhK,QAAAA,GAAG,GAAGlC,aAAa,CAACiG,oBAAd,CAAmC/D,GAAnC,EAAwC4J,MAAxC,EAAgD3F,OAAhD,EAAyD;AAC7D8F,UAAAA,gBAAgB,EAAE;AAD2C,SAAzD,EAEH,CAFG,CAAN;AAGD;;AACD,aAAO,CAAC/J,GAAD,EAAM6J,SAAN,CAAP;AACD;;;;EAnCiB/L,a;;AAumBpBmM,MAAM,CAACC,OAAP,GAAiBhL,KAAjB;AACA+K,MAAM,CAACC,OAAP,CAAehL,KAAf,GAAuBA,KAAvB;AACA+K,MAAM,CAACC,OAAP,CAAeC,OAAf,GAAyBjL,KAAzB","sourcesContent":["\"use strict\";\n\nconst _ = require(\"lodash\");\nconst Utils = require(\"../../utils\");\nconst Promise = require(\"../../promise\");\nconst AbstractQuery = require(\"../abstract/query\");\nconst QueryTypes = require(\"../../query-types\");\nconst sequelizeErrors = require(\"../../errors\");\nconst parserStore = require(\"../parserStore\")(\"sqlite\");\nconst { logger } = require(\"../../utils/logger\");\n\nconst debug = logger.debugContext(\"sql:sqlite\");\nconst getMethods = obj => {\n  let properties = new Set();\n  let currentObj = obj;\n  do {\n    Object.getOwnPropertyNames(currentObj).map(item => properties.add(item));\n  } while ((currentObj = Object.getPrototypeOf(currentObj)));\n  return [...properties.keys()].filter(item => typeof obj[item] === \"function\");\n};\nclass Query extends AbstractQuery {\n  getInsertIdField() {\n    return \"lastID\";\n  }\n\n  /**\n   * rewrite query with parameters.\n   *\n   * @param {string} sql\n   * @param {Array|Object} values\n   * @param {string} dialect\n   * @private\n   */\n  static formatBindParameters(sql, values, dialect) {\n    let bindParam;\n    if (Array.isArray(values)) {\n      bindParam = {};\n      values.forEach((v, i) => {\n        bindParam[`$${i + 1}`] = v;\n      });\n      sql = AbstractQuery.formatBindParameters(sql, values, dialect, {\n        skipValueReplace: true\n      })[0];\n    } else {\n      bindParam = {};\n      if (typeof values === \"object\") {\n        for (const k of Object.keys(values)) {\n          bindParam[`$${k}`] = values[k];\n        }\n      }\n      sql = AbstractQuery.formatBindParameters(sql, values, dialect, {\n        skipValueReplace: true\n      })[0];\n    }\n    return [sql, bindParam];\n  }\n\n  _collectModels(include, prefix) {\n    const ret = {};\n\n    if (include) {\n      for (const _include of include) {\n        let key;\n        if (!prefix) {\n          key = _include.as;\n        } else {\n          key = `${prefix}.${_include.as}`;\n        }\n        ret[key] = _include.model;\n\n        if (_include.include) {\n          _.merge(ret, this._collectModels(_include.include, key));\n        }\n      }\n    }\n\n    return ret;\n  }\n\n  _handleQueryResponse(metaData, columnTypes, err, results) {\n    if (err) {\n      err.sql = this.sql;\n      throw this.formatError(err);\n    }\n    let result = this.instance;\n    // add the inserted row id to the instance\n    if (this.isInsertQuery(results, metaData)) {\n      this.handleInsertQuery(results, metaData);\n      if (!this.instance) {\n        // handle bulkCreate AI primary key\n        if (\n          /*  metaData.constructor.name === \"Statement\" && */\n          this.model &&\n          this.model.autoIncrementAttribute &&\n          this.model.autoIncrementAttribute ===\n            this.model.primaryKeyAttribute &&\n          this.model.rawAttributes[this.model.primaryKeyAttribute]\n        ) {\n          const startId =\n            metaData[this.getInsertIdField()] - metaData.changes + 1;\n\n          result = [];\n          for (let i = startId; i < startId + metaData.changes; i++) {\n            result.push({\n              [this.model.rawAttributes[this.model.primaryKeyAttribute]\n                .field]: i\n            });\n          }\n        } else {\n          result = metaData[this.getInsertIdField()];\n        }\n      }\n    }\n\n    if (this.isShowTablesQuery()) {\n      return results.map(row => row.name);\n    }\n    if (this.isShowConstraintsQuery()) {\n      result = results;\n      if (results && results[0] && results[0].sql) {\n        result = this.parseConstraintsFromSql(results[0].sql);\n      }\n      return result;\n    }\n    if (this.isSelectQuery()) {\n      if (this.options.raw) {\n        return this.handleSelectQuery(results);\n      }\n      // This is a map of prefix strings to models, e.g. user.projects -> Project model\n      const prefixes = this._collectModels(this.options.include);\n\n      results = results.map(result => {\n        return _.mapValues(result, (value, name) => {\n          let model;\n          if (name.includes(\".\")) {\n            const lastind = name.lastIndexOf(\".\");\n\n            model = prefixes[name.substr(0, lastind)];\n\n            name = name.substr(lastind + 1);\n          } else {\n            model = this.options.model;\n          }\n\n          const tableName = model\n            .getTableName()\n            .toString()\n            .replace(/`/g, \"\");\n          const tableTypes = columnTypes[tableName] || {};\n\n          if (tableTypes && !(name in tableTypes)) {\n            // The column is aliased\n            _.forOwn(model.rawAttributes, (attribute, key) => {\n              if (name === key && attribute.field) {\n                name = attribute.field;\n                return false;\n              }\n            });\n          }\n\n          return Object.prototype.hasOwnProperty.call(tableTypes, name)\n            ? this.applyParsers(tableTypes[name], value)\n            : value;\n        });\n      });\n\n      return this.handleSelectQuery(results);\n    }\n    if (this.isShowOrDescribeQuery()) {\n      return results;\n    }\n    if (this.sql.includes(\"PRAGMA INDEX_LIST\")) {\n      return this.handleShowIndexesQuery(results);\n    }\n    if (this.sql.includes(\"PRAGMA INDEX_INFO\")) {\n      return results;\n    }\n    if (this.sql.includes(\"PRAGMA TABLE_INFO\")) {\n      // this is the sqlite way of getting the metadata of a table\n      result = {};\n\n      if (Array.isArray(results)) {\n        let defaultValue;\n        for (const _result of results) {\n          if (_result.dflt_value === null) {\n            // Column schema omits any \"DEFAULT ...\"\n            defaultValue = undefined;\n          } else if (_result.dflt_value === \"NULL\") {\n            // Column schema is a \"DEFAULT NULL\"\n            defaultValue = null;\n          } else {\n            defaultValue = _result.dflt_value;\n          }\n\n          result[_result.name] = {\n            type: _result.type,\n            allowNull: _result.notnull === 0,\n            defaultValue,\n            primaryKey: _result.pk !== 0\n          };\n\n          if (result[_result.name].type === \"TINYINT(1)\") {\n            result[_result.name].defaultValue = { \"0\": false, \"1\": true }[\n              result[_result.name].defaultValue\n            ];\n          }\n\n          if (typeof result[_result.name].defaultValue === \"string\") {\n            result[_result.name].defaultValue = result[\n              _result.name\n            ].defaultValue.replace(/'/g, \"\");\n          }\n        }\n      }\n\n      return result;\n    }\n    if (this.sql.includes(\"PRAGMA foreign_keys;\")) {\n      return results[0];\n    }\n    if (this.sql.includes(\"PRAGMA foreign_keys\")) {\n      return results;\n    }\n    if (this.sql.includes(\"PRAGMA foreign_key_list\")) {\n      return results;\n    }\n    if (\n      [QueryTypes.BULKUPDATE, QueryTypes.BULKDELETE].includes(this.options.type)\n    ) {\n      return metaData.changes;\n    }\n    if (this.options.type === QueryTypes.UPSERT) {\n      return undefined;\n    }\n    if (this.options.type === QueryTypes.VERSION) {\n      return results[0].version;\n    }\n    if (this.options.type === QueryTypes.RAW) {\n      return [results, metaData];\n    }\n    if (this.isUpdateQuery() || this.isInsertQuery()) {\n      return [result, metaData.changes];\n    }\n    return result;\n  }\n  // websql : polyfill foreign key https://justatheory.com/2004/11/sqlite-foreign-key-triggers/\n  run(sql, parameters) {\n    // exec does not support bind parameter\n    this.sql = AbstractQuery.formatBindParameters(\n      sql,\n      this.options.bind,\n      this.options.dialect || \"sqlite\",\n      { skipUnescape: false }\n    )[0];\n    const method = this.getDatabaseMethod();\n    const complete = this._logQuery(this.sql, debug, parameters);\n    const query = this;\n    const self = this;\n    const conn = this.connection;\n\n    return new Promise(resolve => {\n      const columnTypes = {};\n      // eslint-disable-next-line\n      const executeSql = () => {\n        if (sql.startsWith(\"-- \")) {\n          return resolve();\n        }\n        resolve(\n          new Promise((resolve, reject) => {\n            if (method === \"exec\") {\n              if (typeof conn.exec === \"function\") {\n                conn.exec(\n                  [{ sql: self.sql, args: [] }],\n                  false,\n                  (executionError, results) => {\n                    try {\n                      complete();\n                      // TODO: Check return PRAGMA INDEX_LIST and INDEX_INFO\n                      results = query.convertToArray(results[0]);\n                      // `this` is passed from sqlite, we have no control over this.\n                      // eslint-disable-next-line no-invalid-this\n                      resolve(\n                        query._handleQueryResponse(\n                          self,\n                          columnTypes,\n                          executionError,\n                          results\n                        )\n                      );\n                      return;\n                    } catch (error) {\n                      reject(error);\n                    }\n                  }\n                );\n              } else {\n                resolve();\n              }\n            } else {\n              conn.transaction(function(t) {\n                // cannot use arrow function here because the function is bound to the statement\n                // eslint-disable-next-line\n                var successCallback = function(_, results) {\n                  try {\n                    complete();\n                    // `self` is passed from sqlite, we have no control over this.\n                    // eslint-disable-next-line no-invalid-this\n                    if (results.rowsAffected) {\n                      try {\n                        self[self.getInsertIdField()] = results.insertId;\n                      } catch (e) {\n                        delete self[self.getInsertIdField()];\n                      }\n                    }\n                    self.changes = results.rowsAffected;\n                    results = query.convertToArray(results);\n                    resolve(\n                      query._handleQueryResponse(\n                        self,\n                        columnTypes,\n                        undefined,\n                        results\n                      )\n                    );\n                    return;\n                  } catch (error) {\n                    debug(error);\n                    reject(error);\n                  }\n                };\n                // eslint-disable-next-line\n                var errorCallback = function(_, err) {\n                  try {\n                    complete();\n                    // `self` is passed from sqlite, we have no control over this.\n                    // eslint-disable-next-line no-invalid-this\n                    resolve(query._handleQueryResponse(self, columnTypes, err));\n                  } catch (error) {\n                    reject(error);\n                  }\n                };\n                if (typeof conn.exec === \"function\") {\n                  parameters = parameters || [];\n                } else parameters = [];\n                t.executeSql(\n                  self.sql,\n                  parameters,\n                  successCallback,\n                  errorCallback\n                );\n              });\n            }\n          })\n        );\n        return null;\n      };\n\n      if (method === \"all\") {\n        let tableNames = [];\n        if (this.options && this.options.tableNames) {\n          tableNames = this.options.tableNames;\n        } else if (/FROM `(.*?)`/i.exec(this.sql)) {\n          tableNames.push(/FROM `(.*?)`/i.exec(this.sql)[1]);\n        }\n\n        // If we already have the metadata for the table, there's no need to ask for it again\n        tableNames = tableNames.filter(\n          tableName =>\n            !(tableName in columnTypes) && tableName !== \"sqlite_master\"\n        );\n        if (!tableNames.length) {\n          return executeSql();\n        }\n        return new Promise(resolve => {\n          if (typeof conn.exec === \"function\") {\n            const sqlCommands = tableNames.map(tableName => {\n              tableName = tableName.replace(/`/g, \"\");\n              columnTypes[tableName] = {};\n              return [`PRAGMA table_info(\\`${tableName}\\`)`, tableName];\n            });\n            conn.exec(\n              sqlCommands.map(sqlCmd => ({\n                sql: sqlCmd[0],\n                args: []\n              })),\n              false,\n              (err, results) => {\n                if (!err) {\n                  for (let i = 0; i < sqlCommands.length; i++) {\n                    const tableName = sqlCommands[i][1];\n                    for (const result of results[i].rows) {\n                      columnTypes[tableName][result.name] = result.type;\n                    }\n                  }\n                }\n                resolve();\n              }\n            );\n          } else {\n            conn.transaction(function(t) {\n              tableNames.forEach((tableName, index) => {\n                t.executeSql(\n                  `SELECT sql FROM sqlite_master WHERE tbl_name='${tableName}' and type='table'`,\n                  [],\n                  function(_, result) {\n                    const table = result.rows.item(0);\n                    if (\n                      typeof table === \"object\" &&\n                      \"sql\" in table &&\n                      typeof table.sql === \"string\"\n                    ) {\n                      columnTypes[tableName] = {};\n                      //match column name with data types\n                      const columns = table.sql.match(\n                        /(`\\w+`)((\\s([A-Z]+)((\\(\\d+\\)))?))/g\n                      );\n                      // split column names with data type\n                      for (const col of columns) {\n                        const [colName, colType] = col\n                          .trim()\n                          .replace(/\\s+/g, \" \")\n                          .replace(/`/g, \"\")\n                          .split(\" \");\n                        columnTypes[tableName][colName] = colType.trim();\n                      }\n                    }\n                    //console.log(columnTypes)\n                    if (index === tableNames.length - 1) resolve();\n                  },\n                  function(_, error) {\n                    if (index === tableNames.length - 1) resolve();\n                  }\n                );\n              });\n            });\n          }\n        }).then(executeSql);\n      }\n      return executeSql();\n    });\n  }\n\n  parseConstraintsFromSql(sql) {\n    let constraints = sql.split(\"CONSTRAINT \");\n    let referenceTableName, referenceTableKeys, updateAction, deleteAction;\n    constraints.splice(0, 1);\n    constraints = constraints.map(constraintSql => {\n      //Parse foreign key snippets\n      if (constraintSql.includes(\"REFERENCES\")) {\n        //Parse out the constraint condition form sql string\n        updateAction = constraintSql.match(\n          /ON UPDATE (CASCADE|SET NULL|RESTRICT|NO ACTION|SET DEFAULT){1}/\n        );\n        deleteAction = constraintSql.match(\n          /ON DELETE (CASCADE|SET NULL|RESTRICT|NO ACTION|SET DEFAULT){1}/\n        );\n\n        if (updateAction) {\n          updateAction = updateAction[1];\n        }\n\n        if (deleteAction) {\n          deleteAction = deleteAction[1];\n        }\n\n        const referencesRegex = /REFERENCES.+\\((?:[^)(]+|\\((?:[^)(]+|\\([^)(]*\\))*\\))*\\)/;\n        const referenceConditions = constraintSql\n          .match(referencesRegex)[0]\n          .split(\" \");\n        referenceTableName = Utils.removeTicks(referenceConditions[1]);\n        let columnNames = referenceConditions[2];\n        columnNames = columnNames.replace(/\\(|\\)/g, \"\").split(\", \");\n        referenceTableKeys = columnNames.map(column =>\n          Utils.removeTicks(column)\n        );\n      }\n\n      const constraintCondition = constraintSql.match(\n        /\\((?:[^)(]+|\\((?:[^)(]+|\\([^)(]*\\))*\\))*\\)/\n      )[0];\n      constraintSql = constraintSql.replace(/\\(.+\\)/, \"\");\n      const constraint = constraintSql.split(\" \");\n\n      if (constraint[1] === \"PRIMARY\" || constraint[1] === \"FOREIGN\") {\n        constraint[1] += \" KEY\";\n      }\n\n      return {\n        constraintName: Utils.removeTicks(constraint[0]),\n        constraintType: constraint[1],\n        updateAction,\n        deleteAction,\n        sql: sql.replace(/\"/g, \"`\"), //Sqlite returns double quotes for table name\n        constraintCondition,\n        referenceTableName,\n        referenceTableKeys\n      };\n    });\n\n    return constraints;\n  }\n\n  applyParsers(type, value) {\n    if (type.includes(\"(\")) {\n      // Remove the length part\n      type = type.substr(0, type.indexOf(\"(\"));\n    }\n    type = type.replace(\"UNSIGNED\", \"\").replace(\"ZEROFILL\", \"\");\n    type = type.trim().toUpperCase();\n    const parse = parserStore.get(type);\n    if (value !== null && parse) {\n      return parse(value, { timezone: this.sequelize.options.timezone });\n    }\n    return value;\n  }\n\n  formatError(err) {\n    switch (err.code) {\n      case \"SQLITE_CONSTRAINT\": {\n        if (err.message.includes(\"FOREIGN KEY constraint failed\")) {\n          return new sequelizeErrors.ForeignKeyConstraintError({\n            parent: err\n          });\n        }\n\n        let fields = [];\n\n        // Sqlite pre 2.2 behavior - Error: SQLITE_CONSTRAINT: columns x, y are not unique\n        let match = err.message.match(/columns (.*?) are/);\n        if (match !== null && match.length >= 2) {\n          fields = match[1].split(\", \");\n        } else {\n          // Sqlite post 2.2 behavior - Error: SQLITE_CONSTRAINT: UNIQUE constraint failed: table.x, table.y\n          match = err.message.match(/UNIQUE constraint failed: (.*)/);\n          if (match !== null && match.length >= 2) {\n            fields = match[1]\n              .split(\", \")\n              .map(columnWithTable => columnWithTable.split(\".\")[1]);\n          }\n        }\n\n        const errors = [];\n        let message = \"Validation error\";\n\n        for (const field of fields) {\n          errors.push(\n            new sequelizeErrors.ValidationErrorItem(\n              this.getUniqueConstraintErrorMessage(field),\n              \"unique violation\", // sequelizeErrors.ValidationErrorItem.Origins.DB,\n              field,\n              this.instance && this.instance[field],\n              this.instance,\n              \"not_unique\"\n            )\n          );\n        }\n\n        if (this.model) {\n          _.forOwn(this.model.uniqueKeys, constraint => {\n            if (_.isEqual(constraint.fields, fields) && !!constraint.msg) {\n              message = constraint.msg;\n              return false;\n            }\n          });\n        }\n\n        return new sequelizeErrors.UniqueConstraintError({\n          message,\n          errors,\n          parent: err,\n          fields\n        });\n      }\n      case \"SQLITE_BUSY\":\n        return new sequelizeErrors.TimeoutError(err);\n\n      default:\n        return new sequelizeErrors.DatabaseError(err);\n    }\n  }\n\n  handleShowIndexesQuery(data) {\n    // Sqlite returns indexes so the one that was defined last is returned first. Lets reverse that!\n    return Promise.map(data.reverse(), item => {\n      item.fields = [];\n      item.primary = false;\n      item.unique = !!item.unique;\n      item.constraintName = item.name;\n      return this.run(`PRAGMA INDEX_INFO(\\`${item.name}\\`)`).then(columns => {\n        for (const column of columns) {\n          item.fields[column.seqno] = {\n            attribute: column.name,\n            length: undefined,\n            order: undefined\n          };\n        }\n\n        return item;\n      });\n    });\n  }\n\n  getDatabaseMethod() {\n    if (\n      this.sql.includes(\"PRAGMA\") ||\n      this.sql.includes(\"COMMIT\") ||\n      this.sql.includes(\"ROLLBACK\") ||\n      this.sql.includes(\"TRANSACTION\")\n    ) {\n      return \"exec\"; // Needed to run no-op transaction\n    }\n    if (\n      this.isInsertQuery() ||\n      this.isUpdateQuery() ||\n      this.isBulkUpdateQuery() ||\n      this.sql.toLowerCase().includes(\"CREATE TEMPORARY TABLE\".toLowerCase()) ||\n      this.options.type === QueryTypes.BULKDELETE\n    ) {\n      return \"run\";\n    }\n    return \"all\";\n  }\n  convertToArray(results) {\n    if (!results.rows) return [];\n    if (\"array\" in results || \"_array\" in results.rows)\n      return results.array || results.rows._array;\n    if (!results.rows.item) return results.rows;\n    const data = new Array(results.rows.length);\n    for (let i = 0; i < results.rows.length; i++) {\n      data[i] = results.rows.item(i);\n    }\n    return data;\n  }\n}\n\nmodule.exports = Query;\nmodule.exports.Query = Query;\nmodule.exports.default = Query;\n"]} \ No newline at end of file +//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../lib/dialects/sqlite/query.js"],"names":["_","require","Utils","Promise","AbstractQuery","QueryTypes","sequelizeErrors","parserStore","logger","debug","debugContext","getMethods","obj","properties","Set","currentObj","Object","getOwnPropertyNames","map","item","add","getPrototypeOf","keys","filter","Query","include","prefix","ret","_include","key","as","model","merge","_collectModels","metaData","columnTypes","err","results","sql","formatError","result","instance","isInsertQuery","handleInsertQuery","autoIncrementAttribute","primaryKeyAttribute","rawAttributes","startId","getInsertIdField","changes","i","push","field","isShowTablesQuery","row","name","isShowConstraintsQuery","parseConstraintsFromSql","isSelectQuery","options","raw","handleSelectQuery","prefixes","mapValues","value","includes","lastind","lastIndexOf","substr","tableName","getTableName","toString","replace","tableTypes","forOwn","attribute","prototype","hasOwnProperty","call","applyParsers","isShowOrDescribeQuery","handleShowIndexesQuery","Array","isArray","defaultValue","_result","dflt_value","undefined","type","allowNull","notnull","primaryKey","pk","BULKUPDATE","BULKDELETE","UPSERT","VERSION","version","RAW","isUpdateQuery","parameters","formatBindParameters","bind","dialect","skipUnescape","method","getDatabaseMethod","complete","_logQuery","query","self","conn","connection","resolve","executeSql","startsWith","reject","exec","args","executionError","convertToArray","_handleQueryResponse","error","successCallback","rowsAffected","insertId","e","errorCallback","tableNames","length","sqlCommands","sqlCmd","rows","transaction","t","forEach","index","table","columns","match","col","colName","colType","trim","split","then","constraints","referenceTableName","referenceTableKeys","updateAction","deleteAction","splice","constraintSql","referencesRegex","referenceConditions","removeTicks","columnNames","column","constraintCondition","constraint","constraintName","constraintType","indexOf","toUpperCase","parse","get","timezone","sequelize","code","message","ForeignKeyConstraintError","parent","fields","columnWithTable","errors","ValidationErrorItem","getUniqueConstraintErrorMessage","uniqueKeys","isEqual","msg","UniqueConstraintError","TimeoutError","DatabaseError","data","reverse","primary","unique","run","seqno","order","isBulkUpdateQuery","toLowerCase","array","_array","values","bindParam","v","skipValueReplace","k","module","exports","default"],"mappings":"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","sourcesContent":["\"use strict\";\n\nconst _ = require(\"lodash\");\nconst Utils = require(\"../../utils\");\nconst Promise = require(\"../../promise\");\nconst AbstractQuery = require(\"../abstract/query\");\nconst QueryTypes = require(\"../../query-types\");\nconst sequelizeErrors = require(\"../../errors\");\nconst parserStore = require(\"../parserStore\")(\"sqlite\");\nconst { logger } = require(\"../../utils/logger\");\n\nconst debug = logger.debugContext(\"sql:sqlite\");\nconst getMethods = obj => {\n  let properties = new Set();\n  let currentObj = obj;\n  do {\n    Object.getOwnPropertyNames(currentObj).map(item => properties.add(item));\n  } while ((currentObj = Object.getPrototypeOf(currentObj)));\n  return [...properties.keys()].filter(item => typeof obj[item] === \"function\");\n};\nclass Query extends AbstractQuery {\n  getInsertIdField() {\n    return \"lastID\";\n  }\n\n  /**\n   * rewrite query with parameters.\n   *\n   * @param {string} sql\n   * @param {Array|Object} values\n   * @param {string} dialect\n   * @private\n   */\n  static formatBindParameters(sql, values, dialect) {\n    let bindParam;\n    if (Array.isArray(values)) {\n      bindParam = {};\n      values.forEach((v, i) => {\n        bindParam[`$${i + 1}`] = v;\n      });\n      sql = AbstractQuery.formatBindParameters(sql, values, dialect, {\n        skipValueReplace: true\n      })[0];\n    } else {\n      bindParam = {};\n      if (typeof values === \"object\") {\n        for (const k of Object.keys(values)) {\n          bindParam[`$${k}`] = values[k];\n        }\n      }\n      sql = AbstractQuery.formatBindParameters(sql, values, dialect, {\n        skipValueReplace: true\n      })[0];\n    }\n    return [sql, bindParam];\n  }\n\n  _collectModels(include, prefix) {\n    const ret = {};\n\n    if (include) {\n      for (const _include of include) {\n        let key;\n        if (!prefix) {\n          key = _include.as;\n        } else {\n          key = `${prefix}.${_include.as}`;\n        }\n        ret[key] = _include.model;\n\n        if (_include.include) {\n          _.merge(ret, this._collectModels(_include.include, key));\n        }\n      }\n    }\n\n    return ret;\n  }\n\n  _handleQueryResponse(metaData, columnTypes, err, results) {\n    if (err) {\n      err.sql = this.sql;\n      throw this.formatError(err);\n    }\n    let result = this.instance;\n    // add the inserted row id to the instance\n    if (this.isInsertQuery(results, metaData)) {\n      this.handleInsertQuery(results, metaData);\n      if (!this.instance) {\n        // handle bulkCreate AI primary key\n        if (\n          /*  metaData.constructor.name === \"Statement\" && */\n          this.model &&\n          this.model.autoIncrementAttribute &&\n          this.model.autoIncrementAttribute ===\n            this.model.primaryKeyAttribute &&\n          this.model.rawAttributes[this.model.primaryKeyAttribute]\n        ) {\n          const startId =\n            metaData[this.getInsertIdField()] - metaData.changes + 1;\n\n          result = [];\n          for (let i = startId; i < startId + metaData.changes; i++) {\n            result.push({\n              [this.model.rawAttributes[this.model.primaryKeyAttribute]\n                .field]: i\n            });\n          }\n        } else {\n          result = metaData[this.getInsertIdField()];\n        }\n      }\n    }\n\n    if (this.isShowTablesQuery()) {\n      return results.map(row => row.name);\n    }\n    if (this.isShowConstraintsQuery()) {\n      result = results;\n      if (results && results[0] && results[0].sql) {\n        result = this.parseConstraintsFromSql(results[0].sql);\n      }\n      return result;\n    }\n    if (this.isSelectQuery()) {\n      if (this.options.raw) {\n        return this.handleSelectQuery(results);\n      }\n      // This is a map of prefix strings to models, e.g. user.projects -> Project model\n      const prefixes = this._collectModels(this.options.include);\n\n      results = results.map(result => {\n        return _.mapValues(result, (value, name) => {\n          let model;\n          if (name.includes(\".\")) {\n            const lastind = name.lastIndexOf(\".\");\n\n            model = prefixes[name.substr(0, lastind)];\n\n            name = name.substr(lastind + 1);\n          } else {\n            model = this.options.model;\n          }\n\n          const tableName = model\n            .getTableName()\n            .toString()\n            .replace(/`/g, \"\");\n          const tableTypes = columnTypes[tableName] || {};\n\n          if (tableTypes && !(name in tableTypes)) {\n            // The column is aliased\n            _.forOwn(model.rawAttributes, (attribute, key) => {\n              if (name === key && attribute.field) {\n                name = attribute.field;\n                return false;\n              }\n            });\n          }\n\n          return Object.prototype.hasOwnProperty.call(tableTypes, name)\n            ? this.applyParsers(tableTypes[name], value)\n            : value;\n        });\n      });\n\n      return this.handleSelectQuery(results);\n    }\n    if (this.isShowOrDescribeQuery()) {\n      return results;\n    }\n    if (this.sql.includes(\"PRAGMA INDEX_LIST\")) {\n      return this.handleShowIndexesQuery(results);\n    }\n    if (this.sql.includes(\"PRAGMA INDEX_INFO\")) {\n      return results;\n    }\n    if (this.sql.includes(\"PRAGMA TABLE_INFO\")) {\n      // this is the sqlite way of getting the metadata of a table\n      result = {};\n\n      if (Array.isArray(results)) {\n        let defaultValue;\n        for (const _result of results) {\n          if (_result.dflt_value === null) {\n            // Column schema omits any \"DEFAULT ...\"\n            defaultValue = undefined;\n          } else if (_result.dflt_value === \"NULL\") {\n            // Column schema is a \"DEFAULT NULL\"\n            defaultValue = null;\n          } else {\n            defaultValue = _result.dflt_value;\n          }\n\n          result[_result.name] = {\n            type: _result.type,\n            allowNull: _result.notnull === 0,\n            defaultValue,\n            primaryKey: _result.pk !== 0\n          };\n\n          if (result[_result.name].type === \"TINYINT(1)\") {\n            result[_result.name].defaultValue = { \"0\": false, \"1\": true }[\n              result[_result.name].defaultValue\n            ];\n          }\n\n          if (typeof result[_result.name].defaultValue === \"string\") {\n            result[_result.name].defaultValue = result[\n              _result.name\n            ].defaultValue.replace(/'/g, \"\");\n          }\n        }\n      }\n\n      return result;\n    }\n    if (this.sql.includes(\"PRAGMA foreign_keys;\")) {\n      return results[0];\n    }\n    if (this.sql.includes(\"PRAGMA foreign_keys\")) {\n      return results;\n    }\n    if (this.sql.includes(\"PRAGMA foreign_key_list\")) {\n      return results;\n    }\n    if (\n      [QueryTypes.BULKUPDATE, QueryTypes.BULKDELETE].includes(this.options.type)\n    ) {\n      return metaData.changes;\n    }\n    if (this.options.type === QueryTypes.UPSERT) {\n      return undefined;\n    }\n    if (this.options.type === QueryTypes.VERSION) {\n      return results[0].version;\n    }\n    if (this.options.type === QueryTypes.RAW) {\n      return [results, metaData];\n    }\n    if (this.isUpdateQuery() || this.isInsertQuery()) {\n      return [result, metaData.changes];\n    }\n    return result;\n  }\n  // websql : polyfill foreign key https://justatheory.com/2004/11/sqlite-foreign-key-triggers/\n  run(sql, parameters) {\n    // exec does not support bind parameter\n    this.sql = AbstractQuery.formatBindParameters(\n      sql,\n      this.options.bind,\n      this.options.dialect || \"sqlite\",\n      { skipUnescape: false }\n    )[0];\n    const method = this.getDatabaseMethod();\n    const complete = this._logQuery(this.sql, debug, parameters);\n    const query = this;\n    const self = this;\n    const conn = this.connection;\n\n    return new Promise(resolve => {\n      const columnTypes = {};\n      // eslint-disable-next-line\n      const executeSql = () => {\n        if (sql.startsWith(\"-- \")) {\n          return resolve();\n        }\n        resolve(\n          new Promise((resolve, reject) => {\n            if (method === \"exec\") {\n              if (typeof conn.exec === \"function\") {\n                conn.exec(\n                  [{ sql: self.sql, args: [] }],\n                  false,\n                  (executionError, results) => {\n                    try {\n                      complete();\n                      // TODO: Check return PRAGMA INDEX_LIST and INDEX_INFO\n                      results = query.convertToArray(results[0]);\n                      // `this` is passed from sqlite, we have no control over this.\n                      // eslint-disable-next-line no-invalid-this\n                      resolve(\n                        query._handleQueryResponse(\n                          self,\n                          columnTypes,\n                          executionError,\n                          results\n                        )\n                      );\n                      return;\n                    } catch (error) {\n                      reject(error);\n                    }\n                  }\n                );\n              } else {\n                resolve();\n              }\n            } else {\n              var successCallback = function(_, results) {\n                try {\n                  complete();\n                  // `self` is passed from sqlite, we have no control over this.\n                  // eslint-disable-next-line no-invalid-this\n                  if (results.rowsAffected) {\n                    try {\n                      self[self.getInsertIdField()] = results.insertId;\n                    } catch (e) {\n                      delete self[self.getInsertIdField()];\n                    }\n                  }\n                  self.changes = results.rowsAffected;\n                  results = query.convertToArray(results);\n                  resolve(\n                    query._handleQueryResponse(\n                      self,\n                      columnTypes,\n                      undefined,\n                      results\n                    )\n                  );\n                  return;\n                } catch (error) {\n                  debug(error);\n                  reject(error);\n                }\n              };\n              // eslint-disable-next-line\n              var errorCallback = function(_, err) {\n                try {\n                  complete();\n                  // `self` is passed from sqlite, we have no control over this.\n                  // eslint-disable-next-line no-invalid-this\n                  resolve(query._handleQueryResponse(self, columnTypes, err));\n                } catch (error) {\n                  reject(error);\n                }\n              };\n              if (typeof conn.exec === \"function\") {\n                parameters = parameters || [];\n              } else parameters = [];\n              conn.executeSql(\n                self.sql,\n                parameters,\n                successCallback,\n                errorCallback\n              );\n              /*conn.transaction(function(t) {\n                // cannot use arrow function here because the function is bound to the statement\n                // eslint-disable-next-line\n                var successCallback = function(_, results) {\n                  try {\n                    complete();\n                    // `self` is passed from sqlite, we have no control over this.\n                    // eslint-disable-next-line no-invalid-this\n                    if (results.rowsAffected) {\n                      try {\n                        self[self.getInsertIdField()] = results.insertId;\n                      } catch (e) {\n                        delete self[self.getInsertIdField()];\n                      }\n                    }\n                    self.changes = results.rowsAffected;\n                    results = query.convertToArray(results);\n                    resolve(\n                      query._handleQueryResponse(\n                        self,\n                        columnTypes,\n                        undefined,\n                        results\n                      )\n                    );\n                    return;\n                  } catch (error) {\n                    debug(error);\n                    reject(error);\n                  }\n                };\n                // eslint-disable-next-line\n                var errorCallback = function(_, err) {\n                  try {\n                    complete();\n                    // `self` is passed from sqlite, we have no control over this.\n                    // eslint-disable-next-line no-invalid-this\n                    resolve(query._handleQueryResponse(self, columnTypes, err));\n                  } catch (error) {\n                    reject(error);\n                  }\n                };\n                if (typeof conn.exec === \"function\") {\n                  parameters = parameters || [];\n                } else parameters = [];\n                t.executeSql(\n                  self.sql,\n                  parameters,\n                  successCallback,\n                  errorCallback\n                );\n              });*/\n            }\n          })\n        );\n        return null;\n      };\n\n      if (method === \"all\") {\n        let tableNames = [];\n        if (this.options && this.options.tableNames) {\n          tableNames = this.options.tableNames;\n        } else if (/FROM `(.*?)`/i.exec(this.sql)) {\n          tableNames.push(/FROM `(.*?)`/i.exec(this.sql)[1]);\n        }\n\n        // If we already have the metadata for the table, there's no need to ask for it again\n        tableNames = tableNames.filter(\n          tableName =>\n            !(tableName in columnTypes) && tableName !== \"sqlite_master\"\n        );\n        if (!tableNames.length) {\n          return executeSql();\n        }\n        return new Promise(resolve => {\n          if (typeof conn.exec === \"function\") {\n            const sqlCommands = tableNames.map(tableName => {\n              tableName = tableName.replace(/`/g, \"\");\n              columnTypes[tableName] = {};\n              return [`PRAGMA table_info(\\`${tableName}\\`)`, tableName];\n            });\n            conn.exec(\n              sqlCommands.map(sqlCmd => ({\n                sql: sqlCmd[0],\n                args: []\n              })),\n              false,\n              (err, results) => {\n                if (!err) {\n                  for (let i = 0; i < sqlCommands.length; i++) {\n                    const tableName = sqlCommands[i][1];\n                    for (const result of results[i].rows) {\n                      columnTypes[tableName][result.name] = result.type;\n                    }\n                  }\n                }\n                resolve();\n              }\n            );\n          } else {\n            conn.transaction(function(t) {\n              tableNames.forEach((tableName, index) => {\n                t.executeSql(\n                  `SELECT sql FROM sqlite_master WHERE tbl_name='${tableName}' and type='table'`,\n                  [],\n                  function(_, result) {\n                    const table = result.rows.item(0);\n                    if (\n                      typeof table === \"object\" &&\n                      \"sql\" in table &&\n                      typeof table.sql === \"string\"\n                    ) {\n                      columnTypes[tableName] = {};\n                      //match column name with data types\n                      const columns = table.sql.match(\n                        /(`\\w+`)((\\s([A-Z]+)((\\(\\d+\\)))?))/g\n                      );\n                      // split column names with data type\n                      for (const col of columns) {\n                        const [colName, colType] = col\n                          .trim()\n                          .replace(/\\s+/g, \" \")\n                          .replace(/`/g, \"\")\n                          .split(\" \");\n                        columnTypes[tableName][colName] = colType.trim();\n                      }\n                    }\n                    //console.log(columnTypes)\n                    if (index === tableNames.length - 1) resolve();\n                  },\n                  function(_, error) {\n                    if (index === tableNames.length - 1) resolve();\n                  }\n                );\n              });\n            });\n          }\n        }).then(executeSql);\n      }\n      return executeSql();\n    });\n  }\n\n  parseConstraintsFromSql(sql) {\n    let constraints = sql.split(\"CONSTRAINT \");\n    let referenceTableName, referenceTableKeys, updateAction, deleteAction;\n    constraints.splice(0, 1);\n    constraints = constraints.map(constraintSql => {\n      //Parse foreign key snippets\n      if (constraintSql.includes(\"REFERENCES\")) {\n        //Parse out the constraint condition form sql string\n        updateAction = constraintSql.match(\n          /ON UPDATE (CASCADE|SET NULL|RESTRICT|NO ACTION|SET DEFAULT){1}/\n        );\n        deleteAction = constraintSql.match(\n          /ON DELETE (CASCADE|SET NULL|RESTRICT|NO ACTION|SET DEFAULT){1}/\n        );\n\n        if (updateAction) {\n          updateAction = updateAction[1];\n        }\n\n        if (deleteAction) {\n          deleteAction = deleteAction[1];\n        }\n\n        const referencesRegex = /REFERENCES.+\\((?:[^)(]+|\\((?:[^)(]+|\\([^)(]*\\))*\\))*\\)/;\n        const referenceConditions = constraintSql\n          .match(referencesRegex)[0]\n          .split(\" \");\n        referenceTableName = Utils.removeTicks(referenceConditions[1]);\n        let columnNames = referenceConditions[2];\n        columnNames = columnNames.replace(/\\(|\\)/g, \"\").split(\", \");\n        referenceTableKeys = columnNames.map(column =>\n          Utils.removeTicks(column)\n        );\n      }\n\n      const constraintCondition = constraintSql.match(\n        /\\((?:[^)(]+|\\((?:[^)(]+|\\([^)(]*\\))*\\))*\\)/\n      )[0];\n      constraintSql = constraintSql.replace(/\\(.+\\)/, \"\");\n      const constraint = constraintSql.split(\" \");\n\n      if (constraint[1] === \"PRIMARY\" || constraint[1] === \"FOREIGN\") {\n        constraint[1] += \" KEY\";\n      }\n\n      return {\n        constraintName: Utils.removeTicks(constraint[0]),\n        constraintType: constraint[1],\n        updateAction,\n        deleteAction,\n        sql: sql.replace(/\"/g, \"`\"), //Sqlite returns double quotes for table name\n        constraintCondition,\n        referenceTableName,\n        referenceTableKeys\n      };\n    });\n\n    return constraints;\n  }\n\n  applyParsers(type, value) {\n    if (type.includes(\"(\")) {\n      // Remove the length part\n      type = type.substr(0, type.indexOf(\"(\"));\n    }\n    type = type.replace(\"UNSIGNED\", \"\").replace(\"ZEROFILL\", \"\");\n    type = type.trim().toUpperCase();\n    const parse = parserStore.get(type);\n    if (value !== null && parse) {\n      return parse(value, { timezone: this.sequelize.options.timezone });\n    }\n    return value;\n  }\n\n  formatError(err) {\n    switch (err.code) {\n      case \"SQLITE_CONSTRAINT\": {\n        if (err.message.includes(\"FOREIGN KEY constraint failed\")) {\n          return new sequelizeErrors.ForeignKeyConstraintError({\n            parent: err\n          });\n        }\n\n        let fields = [];\n\n        // Sqlite pre 2.2 behavior - Error: SQLITE_CONSTRAINT: columns x, y are not unique\n        let match = err.message.match(/columns (.*?) are/);\n        if (match !== null && match.length >= 2) {\n          fields = match[1].split(\", \");\n        } else {\n          // Sqlite post 2.2 behavior - Error: SQLITE_CONSTRAINT: UNIQUE constraint failed: table.x, table.y\n          match = err.message.match(/UNIQUE constraint failed: (.*)/);\n          if (match !== null && match.length >= 2) {\n            fields = match[1]\n              .split(\", \")\n              .map(columnWithTable => columnWithTable.split(\".\")[1]);\n          }\n        }\n\n        const errors = [];\n        let message = \"Validation error\";\n\n        for (const field of fields) {\n          errors.push(\n            new sequelizeErrors.ValidationErrorItem(\n              this.getUniqueConstraintErrorMessage(field),\n              \"unique violation\", // sequelizeErrors.ValidationErrorItem.Origins.DB,\n              field,\n              this.instance && this.instance[field],\n              this.instance,\n              \"not_unique\"\n            )\n          );\n        }\n\n        if (this.model) {\n          _.forOwn(this.model.uniqueKeys, constraint => {\n            if (_.isEqual(constraint.fields, fields) && !!constraint.msg) {\n              message = constraint.msg;\n              return false;\n            }\n          });\n        }\n\n        return new sequelizeErrors.UniqueConstraintError({\n          message,\n          errors,\n          parent: err,\n          fields\n        });\n      }\n      case \"SQLITE_BUSY\":\n        return new sequelizeErrors.TimeoutError(err);\n\n      default:\n        return new sequelizeErrors.DatabaseError(err);\n    }\n  }\n\n  handleShowIndexesQuery(data) {\n    // Sqlite returns indexes so the one that was defined last is returned first. Lets reverse that!\n    return Promise.map(data.reverse(), item => {\n      item.fields = [];\n      item.primary = false;\n      item.unique = !!item.unique;\n      item.constraintName = item.name;\n      return this.run(`PRAGMA INDEX_INFO(\\`${item.name}\\`)`).then(columns => {\n        for (const column of columns) {\n          item.fields[column.seqno] = {\n            attribute: column.name,\n            length: undefined,\n            order: undefined\n          };\n        }\n\n        return item;\n      });\n    });\n  }\n\n  getDatabaseMethod() {\n    if (\n      this.sql.includes(\"PRAGMA\") ||\n      this.sql.includes(\"COMMIT\") ||\n      this.sql.includes(\"ROLLBACK\") ||\n      this.sql.includes(\"TRANSACTION\")\n    ) {\n      return \"exec\"; // Needed to run no-op transaction\n    }\n    if (\n      this.isInsertQuery() ||\n      this.isUpdateQuery() ||\n      this.isBulkUpdateQuery() ||\n      this.sql.toLowerCase().includes(\"CREATE TEMPORARY TABLE\".toLowerCase()) ||\n      this.options.type === QueryTypes.BULKDELETE\n    ) {\n      return \"run\";\n    }\n    return \"all\";\n  }\n  convertToArray(results) {\n    if (!results.rows) return [];\n    if (\"array\" in results || \"_array\" in results.rows)\n      return results.array || results.rows._array;\n    if (!results.rows.item) return results.rows;\n    const data = new Array(results.rows.length);\n    for (let i = 0; i < results.rows.length; i++) {\n      data[i] = results.rows.item(i);\n    }\n    return data;\n  }\n}\n\nmodule.exports = Query;\nmodule.exports.Query = Query;\nmodule.exports.default = Query;\n"]} \ No newline at end of file diff --git a/lib/dialects/sqlite/query.js b/lib/dialects/sqlite/query.js index 2b2fe3f..dbf95c1 100644 --- a/lib/dialects/sqlite/query.js +++ b/lib/dialects/sqlite/query.js @@ -297,7 +297,55 @@ class Query extends AbstractQuery { resolve(); } } else { - conn.transaction(function(t) { + var successCallback = function(_, results) { + try { + complete(); + // `self` is passed from sqlite, we have no control over this. + // eslint-disable-next-line no-invalid-this + if (results.rowsAffected) { + try { + self[self.getInsertIdField()] = results.insertId; + } catch (e) { + delete self[self.getInsertIdField()]; + } + } + self.changes = results.rowsAffected; + results = query.convertToArray(results); + resolve( + query._handleQueryResponse( + self, + columnTypes, + undefined, + results + ) + ); + return; + } catch (error) { + debug(error); + reject(error); + } + }; + // eslint-disable-next-line + var errorCallback = function(_, err) { + try { + complete(); + // `self` is passed from sqlite, we have no control over this. + // eslint-disable-next-line no-invalid-this + resolve(query._handleQueryResponse(self, columnTypes, err)); + } catch (error) { + reject(error); + } + }; + if (typeof conn.exec === "function") { + parameters = parameters || []; + } else parameters = []; + conn.executeSql( + self.sql, + parameters, + successCallback, + errorCallback + ); + /*conn.transaction(function(t) { // cannot use arrow function here because the function is bound to the statement // eslint-disable-next-line var successCallback = function(_, results) { @@ -348,7 +396,7 @@ class Query extends AbstractQuery { successCallback, errorCallback ); - }); + });*/ } }) ); From 1b848b5ccfa156cb2982b162f2b24e10625dba10 Mon Sep 17 00:00:00 2001 From: prih Date: Tue, 15 Dec 2020 13:53:10 +0200 Subject: [PATCH 6/8] executeSql --- dist/dialects/sqlite/query.js | 68 ++++++++++++++++++++++++++--------- lib/dialects/sqlite/query.js | 38 ++++++++++++++++++-- 2 files changed, 87 insertions(+), 19 deletions(-) diff --git a/dist/dialects/sqlite/query.js b/dist/dialects/sqlite/query.js index 5cf57ed..689c548 100644 --- a/dist/dialects/sqlite/query.js +++ b/dist/dialects/sqlite/query.js @@ -456,29 +456,63 @@ let Query = /*#__PURE__*/function (_AbstractQuery) { resolve(); }); } else { - conn.transaction(function (t) { - tableNames.forEach((tableName, index) => { - t.executeSql(`SELECT sql FROM sqlite_master WHERE tbl_name='${tableName}' and type='table'`, [], function (_, result) { - const table = result.rows.item(0); + tableNames.forEach((tableName, index) => { + conn.executeSql(`SELECT sql FROM sqlite_master WHERE tbl_name='${tableName}' and type='table'`, [], function (_, result) { + const table = result.rows.item(0); - if (typeof table === "object" && "sql" in table && typeof table.sql === "string") { - columnTypes[tableName] = {}; //match column name with data types + if (typeof table === "object" && "sql" in table && typeof table.sql === "string") { + columnTypes[tableName] = {}; //match column name with data types - const columns = table.sql.match(/(`\w+`)((\s([A-Z]+)((\(\d+\)))?))/g); // split column names with data type + const columns = table.sql.match(/(`\w+`)((\s([A-Z]+)((\(\d+\)))?))/g); // split column names with data type - for (const col of columns) { - const [colName, colType] = col.trim().replace(/\s+/g, " ").replace(/`/g, "").split(" "); - columnTypes[tableName][colName] = colType.trim(); - } - } //console.log(columnTypes) + for (const col of columns) { + const [colName, colType] = col.trim().replace(/\s+/g, " ").replace(/`/g, "").split(" "); + columnTypes[tableName][colName] = colType.trim(); + } + } //console.log(columnTypes) - if (index === tableNames.length - 1) resolve(); - }, function (_, error) { - if (index === tableNames.length - 1) resolve(); - }); + if (index === tableNames.length - 1) resolve(); + }, function (_, error) { + if (index === tableNames.length - 1) resolve(); }); }); + /*conn.transaction(function(t) { + tableNames.forEach((tableName, index) => { + t.executeSql( + `SELECT sql FROM sqlite_master WHERE tbl_name='${tableName}' and type='table'`, + [], + function(_, result) { + const table = result.rows.item(0); + if ( + typeof table === "object" && + "sql" in table && + typeof table.sql === "string" + ) { + columnTypes[tableName] = {}; + //match column name with data types + const columns = table.sql.match( + /(`\w+`)((\s([A-Z]+)((\(\d+\)))?))/g + ); + // split column names with data type + for (const col of columns) { + const [colName, colType] = col + .trim() + .replace(/\s+/g, " ") + .replace(/`/g, "") + .split(" "); + columnTypes[tableName][colName] = colType.trim(); + } + } + //console.log(columnTypes) + if (index === tableNames.length - 1) resolve(); + }, + function(_, error) { + if (index === tableNames.length - 1) resolve(); + } + ); + }); + });*/ } }).then(executeSql); } @@ -702,4 +736,4 @@ let Query = /*#__PURE__*/function (_AbstractQuery) { module.exports = Query; module.exports.Query = Query; module.exports.default = Query; -//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../lib/dialects/sqlite/query.js"],"names":["_","require","Utils","Promise","AbstractQuery","QueryTypes","sequelizeErrors","parserStore","logger","debug","debugContext","getMethods","obj","properties","Set","currentObj","Object","getOwnPropertyNames","map","item","add","getPrototypeOf","keys","filter","Query","include","prefix","ret","_include","key","as","model","merge","_collectModels","metaData","columnTypes","err","results","sql","formatError","result","instance","isInsertQuery","handleInsertQuery","autoIncrementAttribute","primaryKeyAttribute","rawAttributes","startId","getInsertIdField","changes","i","push","field","isShowTablesQuery","row","name","isShowConstraintsQuery","parseConstraintsFromSql","isSelectQuery","options","raw","handleSelectQuery","prefixes","mapValues","value","includes","lastind","lastIndexOf","substr","tableName","getTableName","toString","replace","tableTypes","forOwn","attribute","prototype","hasOwnProperty","call","applyParsers","isShowOrDescribeQuery","handleShowIndexesQuery","Array","isArray","defaultValue","_result","dflt_value","undefined","type","allowNull","notnull","primaryKey","pk","BULKUPDATE","BULKDELETE","UPSERT","VERSION","version","RAW","isUpdateQuery","parameters","formatBindParameters","bind","dialect","skipUnescape","method","getDatabaseMethod","complete","_logQuery","query","self","conn","connection","resolve","executeSql","startsWith","reject","exec","args","executionError","convertToArray","_handleQueryResponse","error","successCallback","rowsAffected","insertId","e","errorCallback","tableNames","length","sqlCommands","sqlCmd","rows","transaction","t","forEach","index","table","columns","match","col","colName","colType","trim","split","then","constraints","referenceTableName","referenceTableKeys","updateAction","deleteAction","splice","constraintSql","referencesRegex","referenceConditions","removeTicks","columnNames","column","constraintCondition","constraint","constraintName","constraintType","indexOf","toUpperCase","parse","get","timezone","sequelize","code","message","ForeignKeyConstraintError","parent","fields","columnWithTable","errors","ValidationErrorItem","getUniqueConstraintErrorMessage","uniqueKeys","isEqual","msg","UniqueConstraintError","TimeoutError","DatabaseError","data","reverse","primary","unique","run","seqno","order","isBulkUpdateQuery","toLowerCase","array","_array","values","bindParam","v","skipValueReplace","k","module","exports","default"],"mappings":"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","sourcesContent":["\"use strict\";\n\nconst _ = require(\"lodash\");\nconst Utils = require(\"../../utils\");\nconst Promise = require(\"../../promise\");\nconst AbstractQuery = require(\"../abstract/query\");\nconst QueryTypes = require(\"../../query-types\");\nconst sequelizeErrors = require(\"../../errors\");\nconst parserStore = require(\"../parserStore\")(\"sqlite\");\nconst { logger } = require(\"../../utils/logger\");\n\nconst debug = logger.debugContext(\"sql:sqlite\");\nconst getMethods = obj => {\n  let properties = new Set();\n  let currentObj = obj;\n  do {\n    Object.getOwnPropertyNames(currentObj).map(item => properties.add(item));\n  } while ((currentObj = Object.getPrototypeOf(currentObj)));\n  return [...properties.keys()].filter(item => typeof obj[item] === \"function\");\n};\nclass Query extends AbstractQuery {\n  getInsertIdField() {\n    return \"lastID\";\n  }\n\n  /**\n   * rewrite query with parameters.\n   *\n   * @param {string} sql\n   * @param {Array|Object} values\n   * @param {string} dialect\n   * @private\n   */\n  static formatBindParameters(sql, values, dialect) {\n    let bindParam;\n    if (Array.isArray(values)) {\n      bindParam = {};\n      values.forEach((v, i) => {\n        bindParam[`$${i + 1}`] = v;\n      });\n      sql = AbstractQuery.formatBindParameters(sql, values, dialect, {\n        skipValueReplace: true\n      })[0];\n    } else {\n      bindParam = {};\n      if (typeof values === \"object\") {\n        for (const k of Object.keys(values)) {\n          bindParam[`$${k}`] = values[k];\n        }\n      }\n      sql = AbstractQuery.formatBindParameters(sql, values, dialect, {\n        skipValueReplace: true\n      })[0];\n    }\n    return [sql, bindParam];\n  }\n\n  _collectModels(include, prefix) {\n    const ret = {};\n\n    if (include) {\n      for (const _include of include) {\n        let key;\n        if (!prefix) {\n          key = _include.as;\n        } else {\n          key = `${prefix}.${_include.as}`;\n        }\n        ret[key] = _include.model;\n\n        if (_include.include) {\n          _.merge(ret, this._collectModels(_include.include, key));\n        }\n      }\n    }\n\n    return ret;\n  }\n\n  _handleQueryResponse(metaData, columnTypes, err, results) {\n    if (err) {\n      err.sql = this.sql;\n      throw this.formatError(err);\n    }\n    let result = this.instance;\n    // add the inserted row id to the instance\n    if (this.isInsertQuery(results, metaData)) {\n      this.handleInsertQuery(results, metaData);\n      if (!this.instance) {\n        // handle bulkCreate AI primary key\n        if (\n          /*  metaData.constructor.name === \"Statement\" && */\n          this.model &&\n          this.model.autoIncrementAttribute &&\n          this.model.autoIncrementAttribute ===\n            this.model.primaryKeyAttribute &&\n          this.model.rawAttributes[this.model.primaryKeyAttribute]\n        ) {\n          const startId =\n            metaData[this.getInsertIdField()] - metaData.changes + 1;\n\n          result = [];\n          for (let i = startId; i < startId + metaData.changes; i++) {\n            result.push({\n              [this.model.rawAttributes[this.model.primaryKeyAttribute]\n                .field]: i\n            });\n          }\n        } else {\n          result = metaData[this.getInsertIdField()];\n        }\n      }\n    }\n\n    if (this.isShowTablesQuery()) {\n      return results.map(row => row.name);\n    }\n    if (this.isShowConstraintsQuery()) {\n      result = results;\n      if (results && results[0] && results[0].sql) {\n        result = this.parseConstraintsFromSql(results[0].sql);\n      }\n      return result;\n    }\n    if (this.isSelectQuery()) {\n      if (this.options.raw) {\n        return this.handleSelectQuery(results);\n      }\n      // This is a map of prefix strings to models, e.g. user.projects -> Project model\n      const prefixes = this._collectModels(this.options.include);\n\n      results = results.map(result => {\n        return _.mapValues(result, (value, name) => {\n          let model;\n          if (name.includes(\".\")) {\n            const lastind = name.lastIndexOf(\".\");\n\n            model = prefixes[name.substr(0, lastind)];\n\n            name = name.substr(lastind + 1);\n          } else {\n            model = this.options.model;\n          }\n\n          const tableName = model\n            .getTableName()\n            .toString()\n            .replace(/`/g, \"\");\n          const tableTypes = columnTypes[tableName] || {};\n\n          if (tableTypes && !(name in tableTypes)) {\n            // The column is aliased\n            _.forOwn(model.rawAttributes, (attribute, key) => {\n              if (name === key && attribute.field) {\n                name = attribute.field;\n                return false;\n              }\n            });\n          }\n\n          return Object.prototype.hasOwnProperty.call(tableTypes, name)\n            ? this.applyParsers(tableTypes[name], value)\n            : value;\n        });\n      });\n\n      return this.handleSelectQuery(results);\n    }\n    if (this.isShowOrDescribeQuery()) {\n      return results;\n    }\n    if (this.sql.includes(\"PRAGMA INDEX_LIST\")) {\n      return this.handleShowIndexesQuery(results);\n    }\n    if (this.sql.includes(\"PRAGMA INDEX_INFO\")) {\n      return results;\n    }\n    if (this.sql.includes(\"PRAGMA TABLE_INFO\")) {\n      // this is the sqlite way of getting the metadata of a table\n      result = {};\n\n      if (Array.isArray(results)) {\n        let defaultValue;\n        for (const _result of results) {\n          if (_result.dflt_value === null) {\n            // Column schema omits any \"DEFAULT ...\"\n            defaultValue = undefined;\n          } else if (_result.dflt_value === \"NULL\") {\n            // Column schema is a \"DEFAULT NULL\"\n            defaultValue = null;\n          } else {\n            defaultValue = _result.dflt_value;\n          }\n\n          result[_result.name] = {\n            type: _result.type,\n            allowNull: _result.notnull === 0,\n            defaultValue,\n            primaryKey: _result.pk !== 0\n          };\n\n          if (result[_result.name].type === \"TINYINT(1)\") {\n            result[_result.name].defaultValue = { \"0\": false, \"1\": true }[\n              result[_result.name].defaultValue\n            ];\n          }\n\n          if (typeof result[_result.name].defaultValue === \"string\") {\n            result[_result.name].defaultValue = result[\n              _result.name\n            ].defaultValue.replace(/'/g, \"\");\n          }\n        }\n      }\n\n      return result;\n    }\n    if (this.sql.includes(\"PRAGMA foreign_keys;\")) {\n      return results[0];\n    }\n    if (this.sql.includes(\"PRAGMA foreign_keys\")) {\n      return results;\n    }\n    if (this.sql.includes(\"PRAGMA foreign_key_list\")) {\n      return results;\n    }\n    if (\n      [QueryTypes.BULKUPDATE, QueryTypes.BULKDELETE].includes(this.options.type)\n    ) {\n      return metaData.changes;\n    }\n    if (this.options.type === QueryTypes.UPSERT) {\n      return undefined;\n    }\n    if (this.options.type === QueryTypes.VERSION) {\n      return results[0].version;\n    }\n    if (this.options.type === QueryTypes.RAW) {\n      return [results, metaData];\n    }\n    if (this.isUpdateQuery() || this.isInsertQuery()) {\n      return [result, metaData.changes];\n    }\n    return result;\n  }\n  // websql : polyfill foreign key https://justatheory.com/2004/11/sqlite-foreign-key-triggers/\n  run(sql, parameters) {\n    // exec does not support bind parameter\n    this.sql = AbstractQuery.formatBindParameters(\n      sql,\n      this.options.bind,\n      this.options.dialect || \"sqlite\",\n      { skipUnescape: false }\n    )[0];\n    const method = this.getDatabaseMethod();\n    const complete = this._logQuery(this.sql, debug, parameters);\n    const query = this;\n    const self = this;\n    const conn = this.connection;\n\n    return new Promise(resolve => {\n      const columnTypes = {};\n      // eslint-disable-next-line\n      const executeSql = () => {\n        if (sql.startsWith(\"-- \")) {\n          return resolve();\n        }\n        resolve(\n          new Promise((resolve, reject) => {\n            if (method === \"exec\") {\n              if (typeof conn.exec === \"function\") {\n                conn.exec(\n                  [{ sql: self.sql, args: [] }],\n                  false,\n                  (executionError, results) => {\n                    try {\n                      complete();\n                      // TODO: Check return PRAGMA INDEX_LIST and INDEX_INFO\n                      results = query.convertToArray(results[0]);\n                      // `this` is passed from sqlite, we have no control over this.\n                      // eslint-disable-next-line no-invalid-this\n                      resolve(\n                        query._handleQueryResponse(\n                          self,\n                          columnTypes,\n                          executionError,\n                          results\n                        )\n                      );\n                      return;\n                    } catch (error) {\n                      reject(error);\n                    }\n                  }\n                );\n              } else {\n                resolve();\n              }\n            } else {\n              var successCallback = function(_, results) {\n                try {\n                  complete();\n                  // `self` is passed from sqlite, we have no control over this.\n                  // eslint-disable-next-line no-invalid-this\n                  if (results.rowsAffected) {\n                    try {\n                      self[self.getInsertIdField()] = results.insertId;\n                    } catch (e) {\n                      delete self[self.getInsertIdField()];\n                    }\n                  }\n                  self.changes = results.rowsAffected;\n                  results = query.convertToArray(results);\n                  resolve(\n                    query._handleQueryResponse(\n                      self,\n                      columnTypes,\n                      undefined,\n                      results\n                    )\n                  );\n                  return;\n                } catch (error) {\n                  debug(error);\n                  reject(error);\n                }\n              };\n              // eslint-disable-next-line\n              var errorCallback = function(_, err) {\n                try {\n                  complete();\n                  // `self` is passed from sqlite, we have no control over this.\n                  // eslint-disable-next-line no-invalid-this\n                  resolve(query._handleQueryResponse(self, columnTypes, err));\n                } catch (error) {\n                  reject(error);\n                }\n              };\n              if (typeof conn.exec === \"function\") {\n                parameters = parameters || [];\n              } else parameters = [];\n              conn.executeSql(\n                self.sql,\n                parameters,\n                successCallback,\n                errorCallback\n              );\n              /*conn.transaction(function(t) {\n                // cannot use arrow function here because the function is bound to the statement\n                // eslint-disable-next-line\n                var successCallback = function(_, results) {\n                  try {\n                    complete();\n                    // `self` is passed from sqlite, we have no control over this.\n                    // eslint-disable-next-line no-invalid-this\n                    if (results.rowsAffected) {\n                      try {\n                        self[self.getInsertIdField()] = results.insertId;\n                      } catch (e) {\n                        delete self[self.getInsertIdField()];\n                      }\n                    }\n                    self.changes = results.rowsAffected;\n                    results = query.convertToArray(results);\n                    resolve(\n                      query._handleQueryResponse(\n                        self,\n                        columnTypes,\n                        undefined,\n                        results\n                      )\n                    );\n                    return;\n                  } catch (error) {\n                    debug(error);\n                    reject(error);\n                  }\n                };\n                // eslint-disable-next-line\n                var errorCallback = function(_, err) {\n                  try {\n                    complete();\n                    // `self` is passed from sqlite, we have no control over this.\n                    // eslint-disable-next-line no-invalid-this\n                    resolve(query._handleQueryResponse(self, columnTypes, err));\n                  } catch (error) {\n                    reject(error);\n                  }\n                };\n                if (typeof conn.exec === \"function\") {\n                  parameters = parameters || [];\n                } else parameters = [];\n                t.executeSql(\n                  self.sql,\n                  parameters,\n                  successCallback,\n                  errorCallback\n                );\n              });*/\n            }\n          })\n        );\n        return null;\n      };\n\n      if (method === \"all\") {\n        let tableNames = [];\n        if (this.options && this.options.tableNames) {\n          tableNames = this.options.tableNames;\n        } else if (/FROM `(.*?)`/i.exec(this.sql)) {\n          tableNames.push(/FROM `(.*?)`/i.exec(this.sql)[1]);\n        }\n\n        // If we already have the metadata for the table, there's no need to ask for it again\n        tableNames = tableNames.filter(\n          tableName =>\n            !(tableName in columnTypes) && tableName !== \"sqlite_master\"\n        );\n        if (!tableNames.length) {\n          return executeSql();\n        }\n        return new Promise(resolve => {\n          if (typeof conn.exec === \"function\") {\n            const sqlCommands = tableNames.map(tableName => {\n              tableName = tableName.replace(/`/g, \"\");\n              columnTypes[tableName] = {};\n              return [`PRAGMA table_info(\\`${tableName}\\`)`, tableName];\n            });\n            conn.exec(\n              sqlCommands.map(sqlCmd => ({\n                sql: sqlCmd[0],\n                args: []\n              })),\n              false,\n              (err, results) => {\n                if (!err) {\n                  for (let i = 0; i < sqlCommands.length; i++) {\n                    const tableName = sqlCommands[i][1];\n                    for (const result of results[i].rows) {\n                      columnTypes[tableName][result.name] = result.type;\n                    }\n                  }\n                }\n                resolve();\n              }\n            );\n          } else {\n            conn.transaction(function(t) {\n              tableNames.forEach((tableName, index) => {\n                t.executeSql(\n                  `SELECT sql FROM sqlite_master WHERE tbl_name='${tableName}' and type='table'`,\n                  [],\n                  function(_, result) {\n                    const table = result.rows.item(0);\n                    if (\n                      typeof table === \"object\" &&\n                      \"sql\" in table &&\n                      typeof table.sql === \"string\"\n                    ) {\n                      columnTypes[tableName] = {};\n                      //match column name with data types\n                      const columns = table.sql.match(\n                        /(`\\w+`)((\\s([A-Z]+)((\\(\\d+\\)))?))/g\n                      );\n                      // split column names with data type\n                      for (const col of columns) {\n                        const [colName, colType] = col\n                          .trim()\n                          .replace(/\\s+/g, \" \")\n                          .replace(/`/g, \"\")\n                          .split(\" \");\n                        columnTypes[tableName][colName] = colType.trim();\n                      }\n                    }\n                    //console.log(columnTypes)\n                    if (index === tableNames.length - 1) resolve();\n                  },\n                  function(_, error) {\n                    if (index === tableNames.length - 1) resolve();\n                  }\n                );\n              });\n            });\n          }\n        }).then(executeSql);\n      }\n      return executeSql();\n    });\n  }\n\n  parseConstraintsFromSql(sql) {\n    let constraints = sql.split(\"CONSTRAINT \");\n    let referenceTableName, referenceTableKeys, updateAction, deleteAction;\n    constraints.splice(0, 1);\n    constraints = constraints.map(constraintSql => {\n      //Parse foreign key snippets\n      if (constraintSql.includes(\"REFERENCES\")) {\n        //Parse out the constraint condition form sql string\n        updateAction = constraintSql.match(\n          /ON UPDATE (CASCADE|SET NULL|RESTRICT|NO ACTION|SET DEFAULT){1}/\n        );\n        deleteAction = constraintSql.match(\n          /ON DELETE (CASCADE|SET NULL|RESTRICT|NO ACTION|SET DEFAULT){1}/\n        );\n\n        if (updateAction) {\n          updateAction = updateAction[1];\n        }\n\n        if (deleteAction) {\n          deleteAction = deleteAction[1];\n        }\n\n        const referencesRegex = /REFERENCES.+\\((?:[^)(]+|\\((?:[^)(]+|\\([^)(]*\\))*\\))*\\)/;\n        const referenceConditions = constraintSql\n          .match(referencesRegex)[0]\n          .split(\" \");\n        referenceTableName = Utils.removeTicks(referenceConditions[1]);\n        let columnNames = referenceConditions[2];\n        columnNames = columnNames.replace(/\\(|\\)/g, \"\").split(\", \");\n        referenceTableKeys = columnNames.map(column =>\n          Utils.removeTicks(column)\n        );\n      }\n\n      const constraintCondition = constraintSql.match(\n        /\\((?:[^)(]+|\\((?:[^)(]+|\\([^)(]*\\))*\\))*\\)/\n      )[0];\n      constraintSql = constraintSql.replace(/\\(.+\\)/, \"\");\n      const constraint = constraintSql.split(\" \");\n\n      if (constraint[1] === \"PRIMARY\" || constraint[1] === \"FOREIGN\") {\n        constraint[1] += \" KEY\";\n      }\n\n      return {\n        constraintName: Utils.removeTicks(constraint[0]),\n        constraintType: constraint[1],\n        updateAction,\n        deleteAction,\n        sql: sql.replace(/\"/g, \"`\"), //Sqlite returns double quotes for table name\n        constraintCondition,\n        referenceTableName,\n        referenceTableKeys\n      };\n    });\n\n    return constraints;\n  }\n\n  applyParsers(type, value) {\n    if (type.includes(\"(\")) {\n      // Remove the length part\n      type = type.substr(0, type.indexOf(\"(\"));\n    }\n    type = type.replace(\"UNSIGNED\", \"\").replace(\"ZEROFILL\", \"\");\n    type = type.trim().toUpperCase();\n    const parse = parserStore.get(type);\n    if (value !== null && parse) {\n      return parse(value, { timezone: this.sequelize.options.timezone });\n    }\n    return value;\n  }\n\n  formatError(err) {\n    switch (err.code) {\n      case \"SQLITE_CONSTRAINT\": {\n        if (err.message.includes(\"FOREIGN KEY constraint failed\")) {\n          return new sequelizeErrors.ForeignKeyConstraintError({\n            parent: err\n          });\n        }\n\n        let fields = [];\n\n        // Sqlite pre 2.2 behavior - Error: SQLITE_CONSTRAINT: columns x, y are not unique\n        let match = err.message.match(/columns (.*?) are/);\n        if (match !== null && match.length >= 2) {\n          fields = match[1].split(\", \");\n        } else {\n          // Sqlite post 2.2 behavior - Error: SQLITE_CONSTRAINT: UNIQUE constraint failed: table.x, table.y\n          match = err.message.match(/UNIQUE constraint failed: (.*)/);\n          if (match !== null && match.length >= 2) {\n            fields = match[1]\n              .split(\", \")\n              .map(columnWithTable => columnWithTable.split(\".\")[1]);\n          }\n        }\n\n        const errors = [];\n        let message = \"Validation error\";\n\n        for (const field of fields) {\n          errors.push(\n            new sequelizeErrors.ValidationErrorItem(\n              this.getUniqueConstraintErrorMessage(field),\n              \"unique violation\", // sequelizeErrors.ValidationErrorItem.Origins.DB,\n              field,\n              this.instance && this.instance[field],\n              this.instance,\n              \"not_unique\"\n            )\n          );\n        }\n\n        if (this.model) {\n          _.forOwn(this.model.uniqueKeys, constraint => {\n            if (_.isEqual(constraint.fields, fields) && !!constraint.msg) {\n              message = constraint.msg;\n              return false;\n            }\n          });\n        }\n\n        return new sequelizeErrors.UniqueConstraintError({\n          message,\n          errors,\n          parent: err,\n          fields\n        });\n      }\n      case \"SQLITE_BUSY\":\n        return new sequelizeErrors.TimeoutError(err);\n\n      default:\n        return new sequelizeErrors.DatabaseError(err);\n    }\n  }\n\n  handleShowIndexesQuery(data) {\n    // Sqlite returns indexes so the one that was defined last is returned first. Lets reverse that!\n    return Promise.map(data.reverse(), item => {\n      item.fields = [];\n      item.primary = false;\n      item.unique = !!item.unique;\n      item.constraintName = item.name;\n      return this.run(`PRAGMA INDEX_INFO(\\`${item.name}\\`)`).then(columns => {\n        for (const column of columns) {\n          item.fields[column.seqno] = {\n            attribute: column.name,\n            length: undefined,\n            order: undefined\n          };\n        }\n\n        return item;\n      });\n    });\n  }\n\n  getDatabaseMethod() {\n    if (\n      this.sql.includes(\"PRAGMA\") ||\n      this.sql.includes(\"COMMIT\") ||\n      this.sql.includes(\"ROLLBACK\") ||\n      this.sql.includes(\"TRANSACTION\")\n    ) {\n      return \"exec\"; // Needed to run no-op transaction\n    }\n    if (\n      this.isInsertQuery() ||\n      this.isUpdateQuery() ||\n      this.isBulkUpdateQuery() ||\n      this.sql.toLowerCase().includes(\"CREATE TEMPORARY TABLE\".toLowerCase()) ||\n      this.options.type === QueryTypes.BULKDELETE\n    ) {\n      return \"run\";\n    }\n    return \"all\";\n  }\n  convertToArray(results) {\n    if (!results.rows) return [];\n    if (\"array\" in results || \"_array\" in results.rows)\n      return results.array || results.rows._array;\n    if (!results.rows.item) return results.rows;\n    const data = new Array(results.rows.length);\n    for (let i = 0; i < results.rows.length; i++) {\n      data[i] = results.rows.item(i);\n    }\n    return data;\n  }\n}\n\nmodule.exports = Query;\nmodule.exports.Query = Query;\nmodule.exports.default = Query;\n"]} \ No newline at end of file +//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../lib/dialects/sqlite/query.js"],"names":["_","require","Utils","Promise","AbstractQuery","QueryTypes","sequelizeErrors","parserStore","logger","debug","debugContext","getMethods","obj","properties","Set","currentObj","Object","getOwnPropertyNames","map","item","add","getPrototypeOf","keys","filter","Query","include","prefix","ret","_include","key","as","model","merge","_collectModels","metaData","columnTypes","err","results","sql","formatError","result","instance","isInsertQuery","handleInsertQuery","autoIncrementAttribute","primaryKeyAttribute","rawAttributes","startId","getInsertIdField","changes","i","push","field","isShowTablesQuery","row","name","isShowConstraintsQuery","parseConstraintsFromSql","isSelectQuery","options","raw","handleSelectQuery","prefixes","mapValues","value","includes","lastind","lastIndexOf","substr","tableName","getTableName","toString","replace","tableTypes","forOwn","attribute","prototype","hasOwnProperty","call","applyParsers","isShowOrDescribeQuery","handleShowIndexesQuery","Array","isArray","defaultValue","_result","dflt_value","undefined","type","allowNull","notnull","primaryKey","pk","BULKUPDATE","BULKDELETE","UPSERT","VERSION","version","RAW","isUpdateQuery","parameters","formatBindParameters","bind","dialect","skipUnescape","method","getDatabaseMethod","complete","_logQuery","query","self","conn","connection","resolve","executeSql","startsWith","reject","exec","args","executionError","convertToArray","_handleQueryResponse","error","successCallback","rowsAffected","insertId","e","errorCallback","tableNames","length","sqlCommands","sqlCmd","rows","forEach","index","table","columns","match","col","colName","colType","trim","split","then","constraints","referenceTableName","referenceTableKeys","updateAction","deleteAction","splice","constraintSql","referencesRegex","referenceConditions","removeTicks","columnNames","column","constraintCondition","constraint","constraintName","constraintType","indexOf","toUpperCase","parse","get","timezone","sequelize","code","message","ForeignKeyConstraintError","parent","fields","columnWithTable","errors","ValidationErrorItem","getUniqueConstraintErrorMessage","uniqueKeys","isEqual","msg","UniqueConstraintError","TimeoutError","DatabaseError","data","reverse","primary","unique","run","seqno","order","isBulkUpdateQuery","toLowerCase","array","_array","values","bindParam","v","skipValueReplace","k","module","exports","default"],"mappings":"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","sourcesContent":["\"use strict\";\n\nconst _ = require(\"lodash\");\nconst Utils = require(\"../../utils\");\nconst Promise = require(\"../../promise\");\nconst AbstractQuery = require(\"../abstract/query\");\nconst QueryTypes = require(\"../../query-types\");\nconst sequelizeErrors = require(\"../../errors\");\nconst parserStore = require(\"../parserStore\")(\"sqlite\");\nconst { logger } = require(\"../../utils/logger\");\n\nconst debug = logger.debugContext(\"sql:sqlite\");\nconst getMethods = obj => {\n  let properties = new Set();\n  let currentObj = obj;\n  do {\n    Object.getOwnPropertyNames(currentObj).map(item => properties.add(item));\n  } while ((currentObj = Object.getPrototypeOf(currentObj)));\n  return [...properties.keys()].filter(item => typeof obj[item] === \"function\");\n};\nclass Query extends AbstractQuery {\n  getInsertIdField() {\n    return \"lastID\";\n  }\n\n  /**\n   * rewrite query with parameters.\n   *\n   * @param {string} sql\n   * @param {Array|Object} values\n   * @param {string} dialect\n   * @private\n   */\n  static formatBindParameters(sql, values, dialect) {\n    let bindParam;\n    if (Array.isArray(values)) {\n      bindParam = {};\n      values.forEach((v, i) => {\n        bindParam[`$${i + 1}`] = v;\n      });\n      sql = AbstractQuery.formatBindParameters(sql, values, dialect, {\n        skipValueReplace: true\n      })[0];\n    } else {\n      bindParam = {};\n      if (typeof values === \"object\") {\n        for (const k of Object.keys(values)) {\n          bindParam[`$${k}`] = values[k];\n        }\n      }\n      sql = AbstractQuery.formatBindParameters(sql, values, dialect, {\n        skipValueReplace: true\n      })[0];\n    }\n    return [sql, bindParam];\n  }\n\n  _collectModels(include, prefix) {\n    const ret = {};\n\n    if (include) {\n      for (const _include of include) {\n        let key;\n        if (!prefix) {\n          key = _include.as;\n        } else {\n          key = `${prefix}.${_include.as}`;\n        }\n        ret[key] = _include.model;\n\n        if (_include.include) {\n          _.merge(ret, this._collectModels(_include.include, key));\n        }\n      }\n    }\n\n    return ret;\n  }\n\n  _handleQueryResponse(metaData, columnTypes, err, results) {\n    if (err) {\n      err.sql = this.sql;\n      throw this.formatError(err);\n    }\n    let result = this.instance;\n    // add the inserted row id to the instance\n    if (this.isInsertQuery(results, metaData)) {\n      this.handleInsertQuery(results, metaData);\n      if (!this.instance) {\n        // handle bulkCreate AI primary key\n        if (\n          /*  metaData.constructor.name === \"Statement\" && */\n          this.model &&\n          this.model.autoIncrementAttribute &&\n          this.model.autoIncrementAttribute ===\n            this.model.primaryKeyAttribute &&\n          this.model.rawAttributes[this.model.primaryKeyAttribute]\n        ) {\n          const startId =\n            metaData[this.getInsertIdField()] - metaData.changes + 1;\n\n          result = [];\n          for (let i = startId; i < startId + metaData.changes; i++) {\n            result.push({\n              [this.model.rawAttributes[this.model.primaryKeyAttribute]\n                .field]: i\n            });\n          }\n        } else {\n          result = metaData[this.getInsertIdField()];\n        }\n      }\n    }\n\n    if (this.isShowTablesQuery()) {\n      return results.map(row => row.name);\n    }\n    if (this.isShowConstraintsQuery()) {\n      result = results;\n      if (results && results[0] && results[0].sql) {\n        result = this.parseConstraintsFromSql(results[0].sql);\n      }\n      return result;\n    }\n    if (this.isSelectQuery()) {\n      if (this.options.raw) {\n        return this.handleSelectQuery(results);\n      }\n      // This is a map of prefix strings to models, e.g. user.projects -> Project model\n      const prefixes = this._collectModels(this.options.include);\n\n      results = results.map(result => {\n        return _.mapValues(result, (value, name) => {\n          let model;\n          if (name.includes(\".\")) {\n            const lastind = name.lastIndexOf(\".\");\n\n            model = prefixes[name.substr(0, lastind)];\n\n            name = name.substr(lastind + 1);\n          } else {\n            model = this.options.model;\n          }\n\n          const tableName = model\n            .getTableName()\n            .toString()\n            .replace(/`/g, \"\");\n          const tableTypes = columnTypes[tableName] || {};\n\n          if (tableTypes && !(name in tableTypes)) {\n            // The column is aliased\n            _.forOwn(model.rawAttributes, (attribute, key) => {\n              if (name === key && attribute.field) {\n                name = attribute.field;\n                return false;\n              }\n            });\n          }\n\n          return Object.prototype.hasOwnProperty.call(tableTypes, name)\n            ? this.applyParsers(tableTypes[name], value)\n            : value;\n        });\n      });\n\n      return this.handleSelectQuery(results);\n    }\n    if (this.isShowOrDescribeQuery()) {\n      return results;\n    }\n    if (this.sql.includes(\"PRAGMA INDEX_LIST\")) {\n      return this.handleShowIndexesQuery(results);\n    }\n    if (this.sql.includes(\"PRAGMA INDEX_INFO\")) {\n      return results;\n    }\n    if (this.sql.includes(\"PRAGMA TABLE_INFO\")) {\n      // this is the sqlite way of getting the metadata of a table\n      result = {};\n\n      if (Array.isArray(results)) {\n        let defaultValue;\n        for (const _result of results) {\n          if (_result.dflt_value === null) {\n            // Column schema omits any \"DEFAULT ...\"\n            defaultValue = undefined;\n          } else if (_result.dflt_value === \"NULL\") {\n            // Column schema is a \"DEFAULT NULL\"\n            defaultValue = null;\n          } else {\n            defaultValue = _result.dflt_value;\n          }\n\n          result[_result.name] = {\n            type: _result.type,\n            allowNull: _result.notnull === 0,\n            defaultValue,\n            primaryKey: _result.pk !== 0\n          };\n\n          if (result[_result.name].type === \"TINYINT(1)\") {\n            result[_result.name].defaultValue = { \"0\": false, \"1\": true }[\n              result[_result.name].defaultValue\n            ];\n          }\n\n          if (typeof result[_result.name].defaultValue === \"string\") {\n            result[_result.name].defaultValue = result[\n              _result.name\n            ].defaultValue.replace(/'/g, \"\");\n          }\n        }\n      }\n\n      return result;\n    }\n    if (this.sql.includes(\"PRAGMA foreign_keys;\")) {\n      return results[0];\n    }\n    if (this.sql.includes(\"PRAGMA foreign_keys\")) {\n      return results;\n    }\n    if (this.sql.includes(\"PRAGMA foreign_key_list\")) {\n      return results;\n    }\n    if (\n      [QueryTypes.BULKUPDATE, QueryTypes.BULKDELETE].includes(this.options.type)\n    ) {\n      return metaData.changes;\n    }\n    if (this.options.type === QueryTypes.UPSERT) {\n      return undefined;\n    }\n    if (this.options.type === QueryTypes.VERSION) {\n      return results[0].version;\n    }\n    if (this.options.type === QueryTypes.RAW) {\n      return [results, metaData];\n    }\n    if (this.isUpdateQuery() || this.isInsertQuery()) {\n      return [result, metaData.changes];\n    }\n    return result;\n  }\n  // websql : polyfill foreign key https://justatheory.com/2004/11/sqlite-foreign-key-triggers/\n  run(sql, parameters) {\n    // exec does not support bind parameter\n    this.sql = AbstractQuery.formatBindParameters(\n      sql,\n      this.options.bind,\n      this.options.dialect || \"sqlite\",\n      { skipUnescape: false }\n    )[0];\n    const method = this.getDatabaseMethod();\n    const complete = this._logQuery(this.sql, debug, parameters);\n    const query = this;\n    const self = this;\n    const conn = this.connection;\n\n    return new Promise(resolve => {\n      const columnTypes = {};\n      // eslint-disable-next-line\n      const executeSql = () => {\n        if (sql.startsWith(\"-- \")) {\n          return resolve();\n        }\n        resolve(\n          new Promise((resolve, reject) => {\n            if (method === \"exec\") {\n              if (typeof conn.exec === \"function\") {\n                conn.exec(\n                  [{ sql: self.sql, args: [] }],\n                  false,\n                  (executionError, results) => {\n                    try {\n                      complete();\n                      // TODO: Check return PRAGMA INDEX_LIST and INDEX_INFO\n                      results = query.convertToArray(results[0]);\n                      // `this` is passed from sqlite, we have no control over this.\n                      // eslint-disable-next-line no-invalid-this\n                      resolve(\n                        query._handleQueryResponse(\n                          self,\n                          columnTypes,\n                          executionError,\n                          results\n                        )\n                      );\n                      return;\n                    } catch (error) {\n                      reject(error);\n                    }\n                  }\n                );\n              } else {\n                resolve();\n              }\n            } else {\n              var successCallback = function(_, results) {\n                try {\n                  complete();\n                  // `self` is passed from sqlite, we have no control over this.\n                  // eslint-disable-next-line no-invalid-this\n                  if (results.rowsAffected) {\n                    try {\n                      self[self.getInsertIdField()] = results.insertId;\n                    } catch (e) {\n                      delete self[self.getInsertIdField()];\n                    }\n                  }\n                  self.changes = results.rowsAffected;\n                  results = query.convertToArray(results);\n                  resolve(\n                    query._handleQueryResponse(\n                      self,\n                      columnTypes,\n                      undefined,\n                      results\n                    )\n                  );\n                  return;\n                } catch (error) {\n                  debug(error);\n                  reject(error);\n                }\n              };\n              // eslint-disable-next-line\n              var errorCallback = function(_, err) {\n                try {\n                  complete();\n                  // `self` is passed from sqlite, we have no control over this.\n                  // eslint-disable-next-line no-invalid-this\n                  resolve(query._handleQueryResponse(self, columnTypes, err));\n                } catch (error) {\n                  reject(error);\n                }\n              };\n              if (typeof conn.exec === \"function\") {\n                parameters = parameters || [];\n              } else parameters = [];\n              conn.executeSql(\n                self.sql,\n                parameters,\n                successCallback,\n                errorCallback\n              );\n              /*conn.transaction(function(t) {\n                // cannot use arrow function here because the function is bound to the statement\n                // eslint-disable-next-line\n                var successCallback = function(_, results) {\n                  try {\n                    complete();\n                    // `self` is passed from sqlite, we have no control over this.\n                    // eslint-disable-next-line no-invalid-this\n                    if (results.rowsAffected) {\n                      try {\n                        self[self.getInsertIdField()] = results.insertId;\n                      } catch (e) {\n                        delete self[self.getInsertIdField()];\n                      }\n                    }\n                    self.changes = results.rowsAffected;\n                    results = query.convertToArray(results);\n                    resolve(\n                      query._handleQueryResponse(\n                        self,\n                        columnTypes,\n                        undefined,\n                        results\n                      )\n                    );\n                    return;\n                  } catch (error) {\n                    debug(error);\n                    reject(error);\n                  }\n                };\n                // eslint-disable-next-line\n                var errorCallback = function(_, err) {\n                  try {\n                    complete();\n                    // `self` is passed from sqlite, we have no control over this.\n                    // eslint-disable-next-line no-invalid-this\n                    resolve(query._handleQueryResponse(self, columnTypes, err));\n                  } catch (error) {\n                    reject(error);\n                  }\n                };\n                if (typeof conn.exec === \"function\") {\n                  parameters = parameters || [];\n                } else parameters = [];\n                t.executeSql(\n                  self.sql,\n                  parameters,\n                  successCallback,\n                  errorCallback\n                );\n              });*/\n            }\n          })\n        );\n        return null;\n      };\n\n      if (method === \"all\") {\n        let tableNames = [];\n        if (this.options && this.options.tableNames) {\n          tableNames = this.options.tableNames;\n        } else if (/FROM `(.*?)`/i.exec(this.sql)) {\n          tableNames.push(/FROM `(.*?)`/i.exec(this.sql)[1]);\n        }\n\n        // If we already have the metadata for the table, there's no need to ask for it again\n        tableNames = tableNames.filter(\n          tableName =>\n            !(tableName in columnTypes) && tableName !== \"sqlite_master\"\n        );\n        if (!tableNames.length) {\n          return executeSql();\n        }\n        return new Promise(resolve => {\n          if (typeof conn.exec === \"function\") {\n            const sqlCommands = tableNames.map(tableName => {\n              tableName = tableName.replace(/`/g, \"\");\n              columnTypes[tableName] = {};\n              return [`PRAGMA table_info(\\`${tableName}\\`)`, tableName];\n            });\n            conn.exec(\n              sqlCommands.map(sqlCmd => ({\n                sql: sqlCmd[0],\n                args: []\n              })),\n              false,\n              (err, results) => {\n                if (!err) {\n                  for (let i = 0; i < sqlCommands.length; i++) {\n                    const tableName = sqlCommands[i][1];\n                    for (const result of results[i].rows) {\n                      columnTypes[tableName][result.name] = result.type;\n                    }\n                  }\n                }\n                resolve();\n              }\n            );\n          } else {\n            tableNames.forEach((tableName, index) => {\n              conn.executeSql(\n                `SELECT sql FROM sqlite_master WHERE tbl_name='${tableName}' and type='table'`,\n                [],\n                function(_, result) {\n                  const table = result.rows.item(0);\n                  if (\n                    typeof table === \"object\" &&\n                    \"sql\" in table &&\n                    typeof table.sql === \"string\"\n                  ) {\n                    columnTypes[tableName] = {};\n                    //match column name with data types\n                    const columns = table.sql.match(\n                      /(`\\w+`)((\\s([A-Z]+)((\\(\\d+\\)))?))/g\n                    );\n                    // split column names with data type\n                    for (const col of columns) {\n                      const [colName, colType] = col\n                        .trim()\n                        .replace(/\\s+/g, \" \")\n                        .replace(/`/g, \"\")\n                        .split(\" \");\n                      columnTypes[tableName][colName] = colType.trim();\n                    }\n                  }\n                  //console.log(columnTypes)\n                  if (index === tableNames.length - 1) resolve();\n                },\n                function(_, error) {\n                  if (index === tableNames.length - 1) resolve();\n                }\n              );\n            });\n            /*conn.transaction(function(t) {\n              tableNames.forEach((tableName, index) => {\n                t.executeSql(\n                  `SELECT sql FROM sqlite_master WHERE tbl_name='${tableName}' and type='table'`,\n                  [],\n                  function(_, result) {\n                    const table = result.rows.item(0);\n                    if (\n                      typeof table === \"object\" &&\n                      \"sql\" in table &&\n                      typeof table.sql === \"string\"\n                    ) {\n                      columnTypes[tableName] = {};\n                      //match column name with data types\n                      const columns = table.sql.match(\n                        /(`\\w+`)((\\s([A-Z]+)((\\(\\d+\\)))?))/g\n                      );\n                      // split column names with data type\n                      for (const col of columns) {\n                        const [colName, colType] = col\n                          .trim()\n                          .replace(/\\s+/g, \" \")\n                          .replace(/`/g, \"\")\n                          .split(\" \");\n                        columnTypes[tableName][colName] = colType.trim();\n                      }\n                    }\n                    //console.log(columnTypes)\n                    if (index === tableNames.length - 1) resolve();\n                  },\n                  function(_, error) {\n                    if (index === tableNames.length - 1) resolve();\n                  }\n                );\n              });\n            });*/\n          }\n        }).then(executeSql);\n      }\n      return executeSql();\n    });\n  }\n\n  parseConstraintsFromSql(sql) {\n    let constraints = sql.split(\"CONSTRAINT \");\n    let referenceTableName, referenceTableKeys, updateAction, deleteAction;\n    constraints.splice(0, 1);\n    constraints = constraints.map(constraintSql => {\n      //Parse foreign key snippets\n      if (constraintSql.includes(\"REFERENCES\")) {\n        //Parse out the constraint condition form sql string\n        updateAction = constraintSql.match(\n          /ON UPDATE (CASCADE|SET NULL|RESTRICT|NO ACTION|SET DEFAULT){1}/\n        );\n        deleteAction = constraintSql.match(\n          /ON DELETE (CASCADE|SET NULL|RESTRICT|NO ACTION|SET DEFAULT){1}/\n        );\n\n        if (updateAction) {\n          updateAction = updateAction[1];\n        }\n\n        if (deleteAction) {\n          deleteAction = deleteAction[1];\n        }\n\n        const referencesRegex = /REFERENCES.+\\((?:[^)(]+|\\((?:[^)(]+|\\([^)(]*\\))*\\))*\\)/;\n        const referenceConditions = constraintSql\n          .match(referencesRegex)[0]\n          .split(\" \");\n        referenceTableName = Utils.removeTicks(referenceConditions[1]);\n        let columnNames = referenceConditions[2];\n        columnNames = columnNames.replace(/\\(|\\)/g, \"\").split(\", \");\n        referenceTableKeys = columnNames.map(column =>\n          Utils.removeTicks(column)\n        );\n      }\n\n      const constraintCondition = constraintSql.match(\n        /\\((?:[^)(]+|\\((?:[^)(]+|\\([^)(]*\\))*\\))*\\)/\n      )[0];\n      constraintSql = constraintSql.replace(/\\(.+\\)/, \"\");\n      const constraint = constraintSql.split(\" \");\n\n      if (constraint[1] === \"PRIMARY\" || constraint[1] === \"FOREIGN\") {\n        constraint[1] += \" KEY\";\n      }\n\n      return {\n        constraintName: Utils.removeTicks(constraint[0]),\n        constraintType: constraint[1],\n        updateAction,\n        deleteAction,\n        sql: sql.replace(/\"/g, \"`\"), //Sqlite returns double quotes for table name\n        constraintCondition,\n        referenceTableName,\n        referenceTableKeys\n      };\n    });\n\n    return constraints;\n  }\n\n  applyParsers(type, value) {\n    if (type.includes(\"(\")) {\n      // Remove the length part\n      type = type.substr(0, type.indexOf(\"(\"));\n    }\n    type = type.replace(\"UNSIGNED\", \"\").replace(\"ZEROFILL\", \"\");\n    type = type.trim().toUpperCase();\n    const parse = parserStore.get(type);\n    if (value !== null && parse) {\n      return parse(value, { timezone: this.sequelize.options.timezone });\n    }\n    return value;\n  }\n\n  formatError(err) {\n    switch (err.code) {\n      case \"SQLITE_CONSTRAINT\": {\n        if (err.message.includes(\"FOREIGN KEY constraint failed\")) {\n          return new sequelizeErrors.ForeignKeyConstraintError({\n            parent: err\n          });\n        }\n\n        let fields = [];\n\n        // Sqlite pre 2.2 behavior - Error: SQLITE_CONSTRAINT: columns x, y are not unique\n        let match = err.message.match(/columns (.*?) are/);\n        if (match !== null && match.length >= 2) {\n          fields = match[1].split(\", \");\n        } else {\n          // Sqlite post 2.2 behavior - Error: SQLITE_CONSTRAINT: UNIQUE constraint failed: table.x, table.y\n          match = err.message.match(/UNIQUE constraint failed: (.*)/);\n          if (match !== null && match.length >= 2) {\n            fields = match[1]\n              .split(\", \")\n              .map(columnWithTable => columnWithTable.split(\".\")[1]);\n          }\n        }\n\n        const errors = [];\n        let message = \"Validation error\";\n\n        for (const field of fields) {\n          errors.push(\n            new sequelizeErrors.ValidationErrorItem(\n              this.getUniqueConstraintErrorMessage(field),\n              \"unique violation\", // sequelizeErrors.ValidationErrorItem.Origins.DB,\n              field,\n              this.instance && this.instance[field],\n              this.instance,\n              \"not_unique\"\n            )\n          );\n        }\n\n        if (this.model) {\n          _.forOwn(this.model.uniqueKeys, constraint => {\n            if (_.isEqual(constraint.fields, fields) && !!constraint.msg) {\n              message = constraint.msg;\n              return false;\n            }\n          });\n        }\n\n        return new sequelizeErrors.UniqueConstraintError({\n          message,\n          errors,\n          parent: err,\n          fields\n        });\n      }\n      case \"SQLITE_BUSY\":\n        return new sequelizeErrors.TimeoutError(err);\n\n      default:\n        return new sequelizeErrors.DatabaseError(err);\n    }\n  }\n\n  handleShowIndexesQuery(data) {\n    // Sqlite returns indexes so the one that was defined last is returned first. Lets reverse that!\n    return Promise.map(data.reverse(), item => {\n      item.fields = [];\n      item.primary = false;\n      item.unique = !!item.unique;\n      item.constraintName = item.name;\n      return this.run(`PRAGMA INDEX_INFO(\\`${item.name}\\`)`).then(columns => {\n        for (const column of columns) {\n          item.fields[column.seqno] = {\n            attribute: column.name,\n            length: undefined,\n            order: undefined\n          };\n        }\n\n        return item;\n      });\n    });\n  }\n\n  getDatabaseMethod() {\n    if (\n      this.sql.includes(\"PRAGMA\") ||\n      this.sql.includes(\"COMMIT\") ||\n      this.sql.includes(\"ROLLBACK\") ||\n      this.sql.includes(\"TRANSACTION\")\n    ) {\n      return \"exec\"; // Needed to run no-op transaction\n    }\n    if (\n      this.isInsertQuery() ||\n      this.isUpdateQuery() ||\n      this.isBulkUpdateQuery() ||\n      this.sql.toLowerCase().includes(\"CREATE TEMPORARY TABLE\".toLowerCase()) ||\n      this.options.type === QueryTypes.BULKDELETE\n    ) {\n      return \"run\";\n    }\n    return \"all\";\n  }\n  convertToArray(results) {\n    if (!results.rows) return [];\n    if (\"array\" in results || \"_array\" in results.rows)\n      return results.array || results.rows._array;\n    if (!results.rows.item) return results.rows;\n    const data = new Array(results.rows.length);\n    for (let i = 0; i < results.rows.length; i++) {\n      data[i] = results.rows.item(i);\n    }\n    return data;\n  }\n}\n\nmodule.exports = Query;\nmodule.exports.Query = Query;\nmodule.exports.default = Query;\n"]} \ No newline at end of file diff --git a/lib/dialects/sqlite/query.js b/lib/dialects/sqlite/query.js index dbf95c1..342a4d8 100644 --- a/lib/dialects/sqlite/query.js +++ b/lib/dialects/sqlite/query.js @@ -445,7 +445,41 @@ class Query extends AbstractQuery { } ); } else { - conn.transaction(function(t) { + tableNames.forEach((tableName, index) => { + conn.executeSql( + `SELECT sql FROM sqlite_master WHERE tbl_name='${tableName}' and type='table'`, + [], + function(_, result) { + const table = result.rows.item(0); + if ( + typeof table === "object" && + "sql" in table && + typeof table.sql === "string" + ) { + columnTypes[tableName] = {}; + //match column name with data types + const columns = table.sql.match( + /(`\w+`)((\s([A-Z]+)((\(\d+\)))?))/g + ); + // split column names with data type + for (const col of columns) { + const [colName, colType] = col + .trim() + .replace(/\s+/g, " ") + .replace(/`/g, "") + .split(" "); + columnTypes[tableName][colName] = colType.trim(); + } + } + //console.log(columnTypes) + if (index === tableNames.length - 1) resolve(); + }, + function(_, error) { + if (index === tableNames.length - 1) resolve(); + } + ); + }); + /*conn.transaction(function(t) { tableNames.forEach((tableName, index) => { t.executeSql( `SELECT sql FROM sqlite_master WHERE tbl_name='${tableName}' and type='table'`, @@ -480,7 +514,7 @@ class Query extends AbstractQuery { } ); }); - }); + });*/ } }).then(executeSql); } From 4d8e741295d80669a7f68200e2139c1b3424bcab Mon Sep 17 00:00:00 2001 From: prih Date: Tue, 15 Dec 2020 14:03:15 +0200 Subject: [PATCH 7/8] executeSql --- dist/dialects/sqlite/query.js | 10 +++++----- lib/dialects/sqlite/query.js | 8 ++++---- 2 files changed, 9 insertions(+), 9 deletions(-) diff --git a/dist/dialects/sqlite/query.js b/dist/dialects/sqlite/query.js index 689c548..d5b5aac 100644 --- a/dist/dialects/sqlite/query.js +++ b/dist/dialects/sqlite/query.js @@ -319,7 +319,7 @@ let Query = /*#__PURE__*/function (_AbstractQuery) { resolve(); } } else { - var successCallback = function (_, results) { + var successCallback = function (results) { try { complete(); // `self` is passed from sqlite, we have no control over this. // eslint-disable-next-line no-invalid-this @@ -343,7 +343,7 @@ let Query = /*#__PURE__*/function (_AbstractQuery) { }; // eslint-disable-next-line - var errorCallback = function (_, err) { + var errorCallback = function (err) { try { complete(); // `self` is passed from sqlite, we have no control over this. // eslint-disable-next-line no-invalid-this @@ -457,7 +457,7 @@ let Query = /*#__PURE__*/function (_AbstractQuery) { }); } else { tableNames.forEach((tableName, index) => { - conn.executeSql(`SELECT sql FROM sqlite_master WHERE tbl_name='${tableName}' and type='table'`, [], function (_, result) { + conn.executeSql(`SELECT sql FROM sqlite_master WHERE tbl_name='${tableName}' and type='table'`, [], function (result) { const table = result.rows.item(0); if (typeof table === "object" && "sql" in table && typeof table.sql === "string") { @@ -473,7 +473,7 @@ let Query = /*#__PURE__*/function (_AbstractQuery) { if (index === tableNames.length - 1) resolve(); - }, function (_, error) { + }, function (error) { if (index === tableNames.length - 1) resolve(); }); }); @@ -736,4 +736,4 @@ let Query = /*#__PURE__*/function (_AbstractQuery) { module.exports = Query; module.exports.Query = Query; module.exports.default = Query; -//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../lib/dialects/sqlite/query.js"],"names":["_","require","Utils","Promise","AbstractQuery","QueryTypes","sequelizeErrors","parserStore","logger","debug","debugContext","getMethods","obj","properties","Set","currentObj","Object","getOwnPropertyNames","map","item","add","getPrototypeOf","keys","filter","Query","include","prefix","ret","_include","key","as","model","merge","_collectModels","metaData","columnTypes","err","results","sql","formatError","result","instance","isInsertQuery","handleInsertQuery","autoIncrementAttribute","primaryKeyAttribute","rawAttributes","startId","getInsertIdField","changes","i","push","field","isShowTablesQuery","row","name","isShowConstraintsQuery","parseConstraintsFromSql","isSelectQuery","options","raw","handleSelectQuery","prefixes","mapValues","value","includes","lastind","lastIndexOf","substr","tableName","getTableName","toString","replace","tableTypes","forOwn","attribute","prototype","hasOwnProperty","call","applyParsers","isShowOrDescribeQuery","handleShowIndexesQuery","Array","isArray","defaultValue","_result","dflt_value","undefined","type","allowNull","notnull","primaryKey","pk","BULKUPDATE","BULKDELETE","UPSERT","VERSION","version","RAW","isUpdateQuery","parameters","formatBindParameters","bind","dialect","skipUnescape","method","getDatabaseMethod","complete","_logQuery","query","self","conn","connection","resolve","executeSql","startsWith","reject","exec","args","executionError","convertToArray","_handleQueryResponse","error","successCallback","rowsAffected","insertId","e","errorCallback","tableNames","length","sqlCommands","sqlCmd","rows","forEach","index","table","columns","match","col","colName","colType","trim","split","then","constraints","referenceTableName","referenceTableKeys","updateAction","deleteAction","splice","constraintSql","referencesRegex","referenceConditions","removeTicks","columnNames","column","constraintCondition","constraint","constraintName","constraintType","indexOf","toUpperCase","parse","get","timezone","sequelize","code","message","ForeignKeyConstraintError","parent","fields","columnWithTable","errors","ValidationErrorItem","getUniqueConstraintErrorMessage","uniqueKeys","isEqual","msg","UniqueConstraintError","TimeoutError","DatabaseError","data","reverse","primary","unique","run","seqno","order","isBulkUpdateQuery","toLowerCase","array","_array","values","bindParam","v","skipValueReplace","k","module","exports","default"],"mappings":"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","sourcesContent":["\"use strict\";\n\nconst _ = require(\"lodash\");\nconst Utils = require(\"../../utils\");\nconst Promise = require(\"../../promise\");\nconst AbstractQuery = require(\"../abstract/query\");\nconst QueryTypes = require(\"../../query-types\");\nconst sequelizeErrors = require(\"../../errors\");\nconst parserStore = require(\"../parserStore\")(\"sqlite\");\nconst { logger } = require(\"../../utils/logger\");\n\nconst debug = logger.debugContext(\"sql:sqlite\");\nconst getMethods = obj => {\n  let properties = new Set();\n  let currentObj = obj;\n  do {\n    Object.getOwnPropertyNames(currentObj).map(item => properties.add(item));\n  } while ((currentObj = Object.getPrototypeOf(currentObj)));\n  return [...properties.keys()].filter(item => typeof obj[item] === \"function\");\n};\nclass Query extends AbstractQuery {\n  getInsertIdField() {\n    return \"lastID\";\n  }\n\n  /**\n   * rewrite query with parameters.\n   *\n   * @param {string} sql\n   * @param {Array|Object} values\n   * @param {string} dialect\n   * @private\n   */\n  static formatBindParameters(sql, values, dialect) {\n    let bindParam;\n    if (Array.isArray(values)) {\n      bindParam = {};\n      values.forEach((v, i) => {\n        bindParam[`$${i + 1}`] = v;\n      });\n      sql = AbstractQuery.formatBindParameters(sql, values, dialect, {\n        skipValueReplace: true\n      })[0];\n    } else {\n      bindParam = {};\n      if (typeof values === \"object\") {\n        for (const k of Object.keys(values)) {\n          bindParam[`$${k}`] = values[k];\n        }\n      }\n      sql = AbstractQuery.formatBindParameters(sql, values, dialect, {\n        skipValueReplace: true\n      })[0];\n    }\n    return [sql, bindParam];\n  }\n\n  _collectModels(include, prefix) {\n    const ret = {};\n\n    if (include) {\n      for (const _include of include) {\n        let key;\n        if (!prefix) {\n          key = _include.as;\n        } else {\n          key = `${prefix}.${_include.as}`;\n        }\n        ret[key] = _include.model;\n\n        if (_include.include) {\n          _.merge(ret, this._collectModels(_include.include, key));\n        }\n      }\n    }\n\n    return ret;\n  }\n\n  _handleQueryResponse(metaData, columnTypes, err, results) {\n    if (err) {\n      err.sql = this.sql;\n      throw this.formatError(err);\n    }\n    let result = this.instance;\n    // add the inserted row id to the instance\n    if (this.isInsertQuery(results, metaData)) {\n      this.handleInsertQuery(results, metaData);\n      if (!this.instance) {\n        // handle bulkCreate AI primary key\n        if (\n          /*  metaData.constructor.name === \"Statement\" && */\n          this.model &&\n          this.model.autoIncrementAttribute &&\n          this.model.autoIncrementAttribute ===\n            this.model.primaryKeyAttribute &&\n          this.model.rawAttributes[this.model.primaryKeyAttribute]\n        ) {\n          const startId =\n            metaData[this.getInsertIdField()] - metaData.changes + 1;\n\n          result = [];\n          for (let i = startId; i < startId + metaData.changes; i++) {\n            result.push({\n              [this.model.rawAttributes[this.model.primaryKeyAttribute]\n                .field]: i\n            });\n          }\n        } else {\n          result = metaData[this.getInsertIdField()];\n        }\n      }\n    }\n\n    if (this.isShowTablesQuery()) {\n      return results.map(row => row.name);\n    }\n    if (this.isShowConstraintsQuery()) {\n      result = results;\n      if (results && results[0] && results[0].sql) {\n        result = this.parseConstraintsFromSql(results[0].sql);\n      }\n      return result;\n    }\n    if (this.isSelectQuery()) {\n      if (this.options.raw) {\n        return this.handleSelectQuery(results);\n      }\n      // This is a map of prefix strings to models, e.g. user.projects -> Project model\n      const prefixes = this._collectModels(this.options.include);\n\n      results = results.map(result => {\n        return _.mapValues(result, (value, name) => {\n          let model;\n          if (name.includes(\".\")) {\n            const lastind = name.lastIndexOf(\".\");\n\n            model = prefixes[name.substr(0, lastind)];\n\n            name = name.substr(lastind + 1);\n          } else {\n            model = this.options.model;\n          }\n\n          const tableName = model\n            .getTableName()\n            .toString()\n            .replace(/`/g, \"\");\n          const tableTypes = columnTypes[tableName] || {};\n\n          if (tableTypes && !(name in tableTypes)) {\n            // The column is aliased\n            _.forOwn(model.rawAttributes, (attribute, key) => {\n              if (name === key && attribute.field) {\n                name = attribute.field;\n                return false;\n              }\n            });\n          }\n\n          return Object.prototype.hasOwnProperty.call(tableTypes, name)\n            ? this.applyParsers(tableTypes[name], value)\n            : value;\n        });\n      });\n\n      return this.handleSelectQuery(results);\n    }\n    if (this.isShowOrDescribeQuery()) {\n      return results;\n    }\n    if (this.sql.includes(\"PRAGMA INDEX_LIST\")) {\n      return this.handleShowIndexesQuery(results);\n    }\n    if (this.sql.includes(\"PRAGMA INDEX_INFO\")) {\n      return results;\n    }\n    if (this.sql.includes(\"PRAGMA TABLE_INFO\")) {\n      // this is the sqlite way of getting the metadata of a table\n      result = {};\n\n      if (Array.isArray(results)) {\n        let defaultValue;\n        for (const _result of results) {\n          if (_result.dflt_value === null) {\n            // Column schema omits any \"DEFAULT ...\"\n            defaultValue = undefined;\n          } else if (_result.dflt_value === \"NULL\") {\n            // Column schema is a \"DEFAULT NULL\"\n            defaultValue = null;\n          } else {\n            defaultValue = _result.dflt_value;\n          }\n\n          result[_result.name] = {\n            type: _result.type,\n            allowNull: _result.notnull === 0,\n            defaultValue,\n            primaryKey: _result.pk !== 0\n          };\n\n          if (result[_result.name].type === \"TINYINT(1)\") {\n            result[_result.name].defaultValue = { \"0\": false, \"1\": true }[\n              result[_result.name].defaultValue\n            ];\n          }\n\n          if (typeof result[_result.name].defaultValue === \"string\") {\n            result[_result.name].defaultValue = result[\n              _result.name\n            ].defaultValue.replace(/'/g, \"\");\n          }\n        }\n      }\n\n      return result;\n    }\n    if (this.sql.includes(\"PRAGMA foreign_keys;\")) {\n      return results[0];\n    }\n    if (this.sql.includes(\"PRAGMA foreign_keys\")) {\n      return results;\n    }\n    if (this.sql.includes(\"PRAGMA foreign_key_list\")) {\n      return results;\n    }\n    if (\n      [QueryTypes.BULKUPDATE, QueryTypes.BULKDELETE].includes(this.options.type)\n    ) {\n      return metaData.changes;\n    }\n    if (this.options.type === QueryTypes.UPSERT) {\n      return undefined;\n    }\n    if (this.options.type === QueryTypes.VERSION) {\n      return results[0].version;\n    }\n    if (this.options.type === QueryTypes.RAW) {\n      return [results, metaData];\n    }\n    if (this.isUpdateQuery() || this.isInsertQuery()) {\n      return [result, metaData.changes];\n    }\n    return result;\n  }\n  // websql : polyfill foreign key https://justatheory.com/2004/11/sqlite-foreign-key-triggers/\n  run(sql, parameters) {\n    // exec does not support bind parameter\n    this.sql = AbstractQuery.formatBindParameters(\n      sql,\n      this.options.bind,\n      this.options.dialect || \"sqlite\",\n      { skipUnescape: false }\n    )[0];\n    const method = this.getDatabaseMethod();\n    const complete = this._logQuery(this.sql, debug, parameters);\n    const query = this;\n    const self = this;\n    const conn = this.connection;\n\n    return new Promise(resolve => {\n      const columnTypes = {};\n      // eslint-disable-next-line\n      const executeSql = () => {\n        if (sql.startsWith(\"-- \")) {\n          return resolve();\n        }\n        resolve(\n          new Promise((resolve, reject) => {\n            if (method === \"exec\") {\n              if (typeof conn.exec === \"function\") {\n                conn.exec(\n                  [{ sql: self.sql, args: [] }],\n                  false,\n                  (executionError, results) => {\n                    try {\n                      complete();\n                      // TODO: Check return PRAGMA INDEX_LIST and INDEX_INFO\n                      results = query.convertToArray(results[0]);\n                      // `this` is passed from sqlite, we have no control over this.\n                      // eslint-disable-next-line no-invalid-this\n                      resolve(\n                        query._handleQueryResponse(\n                          self,\n                          columnTypes,\n                          executionError,\n                          results\n                        )\n                      );\n                      return;\n                    } catch (error) {\n                      reject(error);\n                    }\n                  }\n                );\n              } else {\n                resolve();\n              }\n            } else {\n              var successCallback = function(_, results) {\n                try {\n                  complete();\n                  // `self` is passed from sqlite, we have no control over this.\n                  // eslint-disable-next-line no-invalid-this\n                  if (results.rowsAffected) {\n                    try {\n                      self[self.getInsertIdField()] = results.insertId;\n                    } catch (e) {\n                      delete self[self.getInsertIdField()];\n                    }\n                  }\n                  self.changes = results.rowsAffected;\n                  results = query.convertToArray(results);\n                  resolve(\n                    query._handleQueryResponse(\n                      self,\n                      columnTypes,\n                      undefined,\n                      results\n                    )\n                  );\n                  return;\n                } catch (error) {\n                  debug(error);\n                  reject(error);\n                }\n              };\n              // eslint-disable-next-line\n              var errorCallback = function(_, err) {\n                try {\n                  complete();\n                  // `self` is passed from sqlite, we have no control over this.\n                  // eslint-disable-next-line no-invalid-this\n                  resolve(query._handleQueryResponse(self, columnTypes, err));\n                } catch (error) {\n                  reject(error);\n                }\n              };\n              if (typeof conn.exec === \"function\") {\n                parameters = parameters || [];\n              } else parameters = [];\n              conn.executeSql(\n                self.sql,\n                parameters,\n                successCallback,\n                errorCallback\n              );\n              /*conn.transaction(function(t) {\n                // cannot use arrow function here because the function is bound to the statement\n                // eslint-disable-next-line\n                var successCallback = function(_, results) {\n                  try {\n                    complete();\n                    // `self` is passed from sqlite, we have no control over this.\n                    // eslint-disable-next-line no-invalid-this\n                    if (results.rowsAffected) {\n                      try {\n                        self[self.getInsertIdField()] = results.insertId;\n                      } catch (e) {\n                        delete self[self.getInsertIdField()];\n                      }\n                    }\n                    self.changes = results.rowsAffected;\n                    results = query.convertToArray(results);\n                    resolve(\n                      query._handleQueryResponse(\n                        self,\n                        columnTypes,\n                        undefined,\n                        results\n                      )\n                    );\n                    return;\n                  } catch (error) {\n                    debug(error);\n                    reject(error);\n                  }\n                };\n                // eslint-disable-next-line\n                var errorCallback = function(_, err) {\n                  try {\n                    complete();\n                    // `self` is passed from sqlite, we have no control over this.\n                    // eslint-disable-next-line no-invalid-this\n                    resolve(query._handleQueryResponse(self, columnTypes, err));\n                  } catch (error) {\n                    reject(error);\n                  }\n                };\n                if (typeof conn.exec === \"function\") {\n                  parameters = parameters || [];\n                } else parameters = [];\n                t.executeSql(\n                  self.sql,\n                  parameters,\n                  successCallback,\n                  errorCallback\n                );\n              });*/\n            }\n          })\n        );\n        return null;\n      };\n\n      if (method === \"all\") {\n        let tableNames = [];\n        if (this.options && this.options.tableNames) {\n          tableNames = this.options.tableNames;\n        } else if (/FROM `(.*?)`/i.exec(this.sql)) {\n          tableNames.push(/FROM `(.*?)`/i.exec(this.sql)[1]);\n        }\n\n        // If we already have the metadata for the table, there's no need to ask for it again\n        tableNames = tableNames.filter(\n          tableName =>\n            !(tableName in columnTypes) && tableName !== \"sqlite_master\"\n        );\n        if (!tableNames.length) {\n          return executeSql();\n        }\n        return new Promise(resolve => {\n          if (typeof conn.exec === \"function\") {\n            const sqlCommands = tableNames.map(tableName => {\n              tableName = tableName.replace(/`/g, \"\");\n              columnTypes[tableName] = {};\n              return [`PRAGMA table_info(\\`${tableName}\\`)`, tableName];\n            });\n            conn.exec(\n              sqlCommands.map(sqlCmd => ({\n                sql: sqlCmd[0],\n                args: []\n              })),\n              false,\n              (err, results) => {\n                if (!err) {\n                  for (let i = 0; i < sqlCommands.length; i++) {\n                    const tableName = sqlCommands[i][1];\n                    for (const result of results[i].rows) {\n                      columnTypes[tableName][result.name] = result.type;\n                    }\n                  }\n                }\n                resolve();\n              }\n            );\n          } else {\n            tableNames.forEach((tableName, index) => {\n              conn.executeSql(\n                `SELECT sql FROM sqlite_master WHERE tbl_name='${tableName}' and type='table'`,\n                [],\n                function(_, result) {\n                  const table = result.rows.item(0);\n                  if (\n                    typeof table === \"object\" &&\n                    \"sql\" in table &&\n                    typeof table.sql === \"string\"\n                  ) {\n                    columnTypes[tableName] = {};\n                    //match column name with data types\n                    const columns = table.sql.match(\n                      /(`\\w+`)((\\s([A-Z]+)((\\(\\d+\\)))?))/g\n                    );\n                    // split column names with data type\n                    for (const col of columns) {\n                      const [colName, colType] = col\n                        .trim()\n                        .replace(/\\s+/g, \" \")\n                        .replace(/`/g, \"\")\n                        .split(\" \");\n                      columnTypes[tableName][colName] = colType.trim();\n                    }\n                  }\n                  //console.log(columnTypes)\n                  if (index === tableNames.length - 1) resolve();\n                },\n                function(_, error) {\n                  if (index === tableNames.length - 1) resolve();\n                }\n              );\n            });\n            /*conn.transaction(function(t) {\n              tableNames.forEach((tableName, index) => {\n                t.executeSql(\n                  `SELECT sql FROM sqlite_master WHERE tbl_name='${tableName}' and type='table'`,\n                  [],\n                  function(_, result) {\n                    const table = result.rows.item(0);\n                    if (\n                      typeof table === \"object\" &&\n                      \"sql\" in table &&\n                      typeof table.sql === \"string\"\n                    ) {\n                      columnTypes[tableName] = {};\n                      //match column name with data types\n                      const columns = table.sql.match(\n                        /(`\\w+`)((\\s([A-Z]+)((\\(\\d+\\)))?))/g\n                      );\n                      // split column names with data type\n                      for (const col of columns) {\n                        const [colName, colType] = col\n                          .trim()\n                          .replace(/\\s+/g, \" \")\n                          .replace(/`/g, \"\")\n                          .split(\" \");\n                        columnTypes[tableName][colName] = colType.trim();\n                      }\n                    }\n                    //console.log(columnTypes)\n                    if (index === tableNames.length - 1) resolve();\n                  },\n                  function(_, error) {\n                    if (index === tableNames.length - 1) resolve();\n                  }\n                );\n              });\n            });*/\n          }\n        }).then(executeSql);\n      }\n      return executeSql();\n    });\n  }\n\n  parseConstraintsFromSql(sql) {\n    let constraints = sql.split(\"CONSTRAINT \");\n    let referenceTableName, referenceTableKeys, updateAction, deleteAction;\n    constraints.splice(0, 1);\n    constraints = constraints.map(constraintSql => {\n      //Parse foreign key snippets\n      if (constraintSql.includes(\"REFERENCES\")) {\n        //Parse out the constraint condition form sql string\n        updateAction = constraintSql.match(\n          /ON UPDATE (CASCADE|SET NULL|RESTRICT|NO ACTION|SET DEFAULT){1}/\n        );\n        deleteAction = constraintSql.match(\n          /ON DELETE (CASCADE|SET NULL|RESTRICT|NO ACTION|SET DEFAULT){1}/\n        );\n\n        if (updateAction) {\n          updateAction = updateAction[1];\n        }\n\n        if (deleteAction) {\n          deleteAction = deleteAction[1];\n        }\n\n        const referencesRegex = /REFERENCES.+\\((?:[^)(]+|\\((?:[^)(]+|\\([^)(]*\\))*\\))*\\)/;\n        const referenceConditions = constraintSql\n          .match(referencesRegex)[0]\n          .split(\" \");\n        referenceTableName = Utils.removeTicks(referenceConditions[1]);\n        let columnNames = referenceConditions[2];\n        columnNames = columnNames.replace(/\\(|\\)/g, \"\").split(\", \");\n        referenceTableKeys = columnNames.map(column =>\n          Utils.removeTicks(column)\n        );\n      }\n\n      const constraintCondition = constraintSql.match(\n        /\\((?:[^)(]+|\\((?:[^)(]+|\\([^)(]*\\))*\\))*\\)/\n      )[0];\n      constraintSql = constraintSql.replace(/\\(.+\\)/, \"\");\n      const constraint = constraintSql.split(\" \");\n\n      if (constraint[1] === \"PRIMARY\" || constraint[1] === \"FOREIGN\") {\n        constraint[1] += \" KEY\";\n      }\n\n      return {\n        constraintName: Utils.removeTicks(constraint[0]),\n        constraintType: constraint[1],\n        updateAction,\n        deleteAction,\n        sql: sql.replace(/\"/g, \"`\"), //Sqlite returns double quotes for table name\n        constraintCondition,\n        referenceTableName,\n        referenceTableKeys\n      };\n    });\n\n    return constraints;\n  }\n\n  applyParsers(type, value) {\n    if (type.includes(\"(\")) {\n      // Remove the length part\n      type = type.substr(0, type.indexOf(\"(\"));\n    }\n    type = type.replace(\"UNSIGNED\", \"\").replace(\"ZEROFILL\", \"\");\n    type = type.trim().toUpperCase();\n    const parse = parserStore.get(type);\n    if (value !== null && parse) {\n      return parse(value, { timezone: this.sequelize.options.timezone });\n    }\n    return value;\n  }\n\n  formatError(err) {\n    switch (err.code) {\n      case \"SQLITE_CONSTRAINT\": {\n        if (err.message.includes(\"FOREIGN KEY constraint failed\")) {\n          return new sequelizeErrors.ForeignKeyConstraintError({\n            parent: err\n          });\n        }\n\n        let fields = [];\n\n        // Sqlite pre 2.2 behavior - Error: SQLITE_CONSTRAINT: columns x, y are not unique\n        let match = err.message.match(/columns (.*?) are/);\n        if (match !== null && match.length >= 2) {\n          fields = match[1].split(\", \");\n        } else {\n          // Sqlite post 2.2 behavior - Error: SQLITE_CONSTRAINT: UNIQUE constraint failed: table.x, table.y\n          match = err.message.match(/UNIQUE constraint failed: (.*)/);\n          if (match !== null && match.length >= 2) {\n            fields = match[1]\n              .split(\", \")\n              .map(columnWithTable => columnWithTable.split(\".\")[1]);\n          }\n        }\n\n        const errors = [];\n        let message = \"Validation error\";\n\n        for (const field of fields) {\n          errors.push(\n            new sequelizeErrors.ValidationErrorItem(\n              this.getUniqueConstraintErrorMessage(field),\n              \"unique violation\", // sequelizeErrors.ValidationErrorItem.Origins.DB,\n              field,\n              this.instance && this.instance[field],\n              this.instance,\n              \"not_unique\"\n            )\n          );\n        }\n\n        if (this.model) {\n          _.forOwn(this.model.uniqueKeys, constraint => {\n            if (_.isEqual(constraint.fields, fields) && !!constraint.msg) {\n              message = constraint.msg;\n              return false;\n            }\n          });\n        }\n\n        return new sequelizeErrors.UniqueConstraintError({\n          message,\n          errors,\n          parent: err,\n          fields\n        });\n      }\n      case \"SQLITE_BUSY\":\n        return new sequelizeErrors.TimeoutError(err);\n\n      default:\n        return new sequelizeErrors.DatabaseError(err);\n    }\n  }\n\n  handleShowIndexesQuery(data) {\n    // Sqlite returns indexes so the one that was defined last is returned first. Lets reverse that!\n    return Promise.map(data.reverse(), item => {\n      item.fields = [];\n      item.primary = false;\n      item.unique = !!item.unique;\n      item.constraintName = item.name;\n      return this.run(`PRAGMA INDEX_INFO(\\`${item.name}\\`)`).then(columns => {\n        for (const column of columns) {\n          item.fields[column.seqno] = {\n            attribute: column.name,\n            length: undefined,\n            order: undefined\n          };\n        }\n\n        return item;\n      });\n    });\n  }\n\n  getDatabaseMethod() {\n    if (\n      this.sql.includes(\"PRAGMA\") ||\n      this.sql.includes(\"COMMIT\") ||\n      this.sql.includes(\"ROLLBACK\") ||\n      this.sql.includes(\"TRANSACTION\")\n    ) {\n      return \"exec\"; // Needed to run no-op transaction\n    }\n    if (\n      this.isInsertQuery() ||\n      this.isUpdateQuery() ||\n      this.isBulkUpdateQuery() ||\n      this.sql.toLowerCase().includes(\"CREATE TEMPORARY TABLE\".toLowerCase()) ||\n      this.options.type === QueryTypes.BULKDELETE\n    ) {\n      return \"run\";\n    }\n    return \"all\";\n  }\n  convertToArray(results) {\n    if (!results.rows) return [];\n    if (\"array\" in results || \"_array\" in results.rows)\n      return results.array || results.rows._array;\n    if (!results.rows.item) return results.rows;\n    const data = new Array(results.rows.length);\n    for (let i = 0; i < results.rows.length; i++) {\n      data[i] = results.rows.item(i);\n    }\n    return data;\n  }\n}\n\nmodule.exports = Query;\nmodule.exports.Query = Query;\nmodule.exports.default = Query;\n"]} \ No newline at end of file +//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../lib/dialects/sqlite/query.js"],"names":["_","require","Utils","Promise","AbstractQuery","QueryTypes","sequelizeErrors","parserStore","logger","debug","debugContext","getMethods","obj","properties","Set","currentObj","Object","getOwnPropertyNames","map","item","add","getPrototypeOf","keys","filter","Query","include","prefix","ret","_include","key","as","model","merge","_collectModels","metaData","columnTypes","err","results","sql","formatError","result","instance","isInsertQuery","handleInsertQuery","autoIncrementAttribute","primaryKeyAttribute","rawAttributes","startId","getInsertIdField","changes","i","push","field","isShowTablesQuery","row","name","isShowConstraintsQuery","parseConstraintsFromSql","isSelectQuery","options","raw","handleSelectQuery","prefixes","mapValues","value","includes","lastind","lastIndexOf","substr","tableName","getTableName","toString","replace","tableTypes","forOwn","attribute","prototype","hasOwnProperty","call","applyParsers","isShowOrDescribeQuery","handleShowIndexesQuery","Array","isArray","defaultValue","_result","dflt_value","undefined","type","allowNull","notnull","primaryKey","pk","BULKUPDATE","BULKDELETE","UPSERT","VERSION","version","RAW","isUpdateQuery","parameters","formatBindParameters","bind","dialect","skipUnescape","method","getDatabaseMethod","complete","_logQuery","query","self","conn","connection","resolve","executeSql","startsWith","reject","exec","args","executionError","convertToArray","_handleQueryResponse","error","successCallback","rowsAffected","insertId","e","errorCallback","tableNames","length","sqlCommands","sqlCmd","rows","forEach","index","table","columns","match","col","colName","colType","trim","split","then","constraints","referenceTableName","referenceTableKeys","updateAction","deleteAction","splice","constraintSql","referencesRegex","referenceConditions","removeTicks","columnNames","column","constraintCondition","constraint","constraintName","constraintType","indexOf","toUpperCase","parse","get","timezone","sequelize","code","message","ForeignKeyConstraintError","parent","fields","columnWithTable","errors","ValidationErrorItem","getUniqueConstraintErrorMessage","uniqueKeys","isEqual","msg","UniqueConstraintError","TimeoutError","DatabaseError","data","reverse","primary","unique","run","seqno","order","isBulkUpdateQuery","toLowerCase","array","_array","values","bindParam","v","skipValueReplace","k","module","exports","default"],"mappings":"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","sourcesContent":["\"use strict\";\n\nconst _ = require(\"lodash\");\nconst Utils = require(\"../../utils\");\nconst Promise = require(\"../../promise\");\nconst AbstractQuery = require(\"../abstract/query\");\nconst QueryTypes = require(\"../../query-types\");\nconst sequelizeErrors = require(\"../../errors\");\nconst parserStore = require(\"../parserStore\")(\"sqlite\");\nconst { logger } = require(\"../../utils/logger\");\n\nconst debug = logger.debugContext(\"sql:sqlite\");\nconst getMethods = obj => {\n  let properties = new Set();\n  let currentObj = obj;\n  do {\n    Object.getOwnPropertyNames(currentObj).map(item => properties.add(item));\n  } while ((currentObj = Object.getPrototypeOf(currentObj)));\n  return [...properties.keys()].filter(item => typeof obj[item] === \"function\");\n};\nclass Query extends AbstractQuery {\n  getInsertIdField() {\n    return \"lastID\";\n  }\n\n  /**\n   * rewrite query with parameters.\n   *\n   * @param {string} sql\n   * @param {Array|Object} values\n   * @param {string} dialect\n   * @private\n   */\n  static formatBindParameters(sql, values, dialect) {\n    let bindParam;\n    if (Array.isArray(values)) {\n      bindParam = {};\n      values.forEach((v, i) => {\n        bindParam[`$${i + 1}`] = v;\n      });\n      sql = AbstractQuery.formatBindParameters(sql, values, dialect, {\n        skipValueReplace: true\n      })[0];\n    } else {\n      bindParam = {};\n      if (typeof values === \"object\") {\n        for (const k of Object.keys(values)) {\n          bindParam[`$${k}`] = values[k];\n        }\n      }\n      sql = AbstractQuery.formatBindParameters(sql, values, dialect, {\n        skipValueReplace: true\n      })[0];\n    }\n    return [sql, bindParam];\n  }\n\n  _collectModels(include, prefix) {\n    const ret = {};\n\n    if (include) {\n      for (const _include of include) {\n        let key;\n        if (!prefix) {\n          key = _include.as;\n        } else {\n          key = `${prefix}.${_include.as}`;\n        }\n        ret[key] = _include.model;\n\n        if (_include.include) {\n          _.merge(ret, this._collectModels(_include.include, key));\n        }\n      }\n    }\n\n    return ret;\n  }\n\n  _handleQueryResponse(metaData, columnTypes, err, results) {\n    if (err) {\n      err.sql = this.sql;\n      throw this.formatError(err);\n    }\n    let result = this.instance;\n    // add the inserted row id to the instance\n    if (this.isInsertQuery(results, metaData)) {\n      this.handleInsertQuery(results, metaData);\n      if (!this.instance) {\n        // handle bulkCreate AI primary key\n        if (\n          /*  metaData.constructor.name === \"Statement\" && */\n          this.model &&\n          this.model.autoIncrementAttribute &&\n          this.model.autoIncrementAttribute ===\n            this.model.primaryKeyAttribute &&\n          this.model.rawAttributes[this.model.primaryKeyAttribute]\n        ) {\n          const startId =\n            metaData[this.getInsertIdField()] - metaData.changes + 1;\n\n          result = [];\n          for (let i = startId; i < startId + metaData.changes; i++) {\n            result.push({\n              [this.model.rawAttributes[this.model.primaryKeyAttribute]\n                .field]: i\n            });\n          }\n        } else {\n          result = metaData[this.getInsertIdField()];\n        }\n      }\n    }\n\n    if (this.isShowTablesQuery()) {\n      return results.map(row => row.name);\n    }\n    if (this.isShowConstraintsQuery()) {\n      result = results;\n      if (results && results[0] && results[0].sql) {\n        result = this.parseConstraintsFromSql(results[0].sql);\n      }\n      return result;\n    }\n    if (this.isSelectQuery()) {\n      if (this.options.raw) {\n        return this.handleSelectQuery(results);\n      }\n      // This is a map of prefix strings to models, e.g. user.projects -> Project model\n      const prefixes = this._collectModels(this.options.include);\n\n      results = results.map(result => {\n        return _.mapValues(result, (value, name) => {\n          let model;\n          if (name.includes(\".\")) {\n            const lastind = name.lastIndexOf(\".\");\n\n            model = prefixes[name.substr(0, lastind)];\n\n            name = name.substr(lastind + 1);\n          } else {\n            model = this.options.model;\n          }\n\n          const tableName = model\n            .getTableName()\n            .toString()\n            .replace(/`/g, \"\");\n          const tableTypes = columnTypes[tableName] || {};\n\n          if (tableTypes && !(name in tableTypes)) {\n            // The column is aliased\n            _.forOwn(model.rawAttributes, (attribute, key) => {\n              if (name === key && attribute.field) {\n                name = attribute.field;\n                return false;\n              }\n            });\n          }\n\n          return Object.prototype.hasOwnProperty.call(tableTypes, name)\n            ? this.applyParsers(tableTypes[name], value)\n            : value;\n        });\n      });\n\n      return this.handleSelectQuery(results);\n    }\n    if (this.isShowOrDescribeQuery()) {\n      return results;\n    }\n    if (this.sql.includes(\"PRAGMA INDEX_LIST\")) {\n      return this.handleShowIndexesQuery(results);\n    }\n    if (this.sql.includes(\"PRAGMA INDEX_INFO\")) {\n      return results;\n    }\n    if (this.sql.includes(\"PRAGMA TABLE_INFO\")) {\n      // this is the sqlite way of getting the metadata of a table\n      result = {};\n\n      if (Array.isArray(results)) {\n        let defaultValue;\n        for (const _result of results) {\n          if (_result.dflt_value === null) {\n            // Column schema omits any \"DEFAULT ...\"\n            defaultValue = undefined;\n          } else if (_result.dflt_value === \"NULL\") {\n            // Column schema is a \"DEFAULT NULL\"\n            defaultValue = null;\n          } else {\n            defaultValue = _result.dflt_value;\n          }\n\n          result[_result.name] = {\n            type: _result.type,\n            allowNull: _result.notnull === 0,\n            defaultValue,\n            primaryKey: _result.pk !== 0\n          };\n\n          if (result[_result.name].type === \"TINYINT(1)\") {\n            result[_result.name].defaultValue = { \"0\": false, \"1\": true }[\n              result[_result.name].defaultValue\n            ];\n          }\n\n          if (typeof result[_result.name].defaultValue === \"string\") {\n            result[_result.name].defaultValue = result[\n              _result.name\n            ].defaultValue.replace(/'/g, \"\");\n          }\n        }\n      }\n\n      return result;\n    }\n    if (this.sql.includes(\"PRAGMA foreign_keys;\")) {\n      return results[0];\n    }\n    if (this.sql.includes(\"PRAGMA foreign_keys\")) {\n      return results;\n    }\n    if (this.sql.includes(\"PRAGMA foreign_key_list\")) {\n      return results;\n    }\n    if (\n      [QueryTypes.BULKUPDATE, QueryTypes.BULKDELETE].includes(this.options.type)\n    ) {\n      return metaData.changes;\n    }\n    if (this.options.type === QueryTypes.UPSERT) {\n      return undefined;\n    }\n    if (this.options.type === QueryTypes.VERSION) {\n      return results[0].version;\n    }\n    if (this.options.type === QueryTypes.RAW) {\n      return [results, metaData];\n    }\n    if (this.isUpdateQuery() || this.isInsertQuery()) {\n      return [result, metaData.changes];\n    }\n    return result;\n  }\n  // websql : polyfill foreign key https://justatheory.com/2004/11/sqlite-foreign-key-triggers/\n  run(sql, parameters) {\n    // exec does not support bind parameter\n    this.sql = AbstractQuery.formatBindParameters(\n      sql,\n      this.options.bind,\n      this.options.dialect || \"sqlite\",\n      { skipUnescape: false }\n    )[0];\n    const method = this.getDatabaseMethod();\n    const complete = this._logQuery(this.sql, debug, parameters);\n    const query = this;\n    const self = this;\n    const conn = this.connection;\n\n    return new Promise(resolve => {\n      const columnTypes = {};\n      // eslint-disable-next-line\n      const executeSql = () => {\n        if (sql.startsWith(\"-- \")) {\n          return resolve();\n        }\n        resolve(\n          new Promise((resolve, reject) => {\n            if (method === \"exec\") {\n              if (typeof conn.exec === \"function\") {\n                conn.exec(\n                  [{ sql: self.sql, args: [] }],\n                  false,\n                  (executionError, results) => {\n                    try {\n                      complete();\n                      // TODO: Check return PRAGMA INDEX_LIST and INDEX_INFO\n                      results = query.convertToArray(results[0]);\n                      // `this` is passed from sqlite, we have no control over this.\n                      // eslint-disable-next-line no-invalid-this\n                      resolve(\n                        query._handleQueryResponse(\n                          self,\n                          columnTypes,\n                          executionError,\n                          results\n                        )\n                      );\n                      return;\n                    } catch (error) {\n                      reject(error);\n                    }\n                  }\n                );\n              } else {\n                resolve();\n              }\n            } else {\n              var successCallback = function(results) {\n                try {\n                  complete();\n                  // `self` is passed from sqlite, we have no control over this.\n                  // eslint-disable-next-line no-invalid-this\n                  if (results.rowsAffected) {\n                    try {\n                      self[self.getInsertIdField()] = results.insertId;\n                    } catch (e) {\n                      delete self[self.getInsertIdField()];\n                    }\n                  }\n                  self.changes = results.rowsAffected;\n                  results = query.convertToArray(results);\n                  resolve(\n                    query._handleQueryResponse(\n                      self,\n                      columnTypes,\n                      undefined,\n                      results\n                    )\n                  );\n                  return;\n                } catch (error) {\n                  debug(error);\n                  reject(error);\n                }\n              };\n              // eslint-disable-next-line\n              var errorCallback = function(err) {\n                try {\n                  complete();\n                  // `self` is passed from sqlite, we have no control over this.\n                  // eslint-disable-next-line no-invalid-this\n                  resolve(query._handleQueryResponse(self, columnTypes, err));\n                } catch (error) {\n                  reject(error);\n                }\n              };\n              if (typeof conn.exec === \"function\") {\n                parameters = parameters || [];\n              } else parameters = [];\n              conn.executeSql(\n                self.sql,\n                parameters,\n                successCallback,\n                errorCallback\n              );\n              /*conn.transaction(function(t) {\n                // cannot use arrow function here because the function is bound to the statement\n                // eslint-disable-next-line\n                var successCallback = function(_, results) {\n                  try {\n                    complete();\n                    // `self` is passed from sqlite, we have no control over this.\n                    // eslint-disable-next-line no-invalid-this\n                    if (results.rowsAffected) {\n                      try {\n                        self[self.getInsertIdField()] = results.insertId;\n                      } catch (e) {\n                        delete self[self.getInsertIdField()];\n                      }\n                    }\n                    self.changes = results.rowsAffected;\n                    results = query.convertToArray(results);\n                    resolve(\n                      query._handleQueryResponse(\n                        self,\n                        columnTypes,\n                        undefined,\n                        results\n                      )\n                    );\n                    return;\n                  } catch (error) {\n                    debug(error);\n                    reject(error);\n                  }\n                };\n                // eslint-disable-next-line\n                var errorCallback = function(_, err) {\n                  try {\n                    complete();\n                    // `self` is passed from sqlite, we have no control over this.\n                    // eslint-disable-next-line no-invalid-this\n                    resolve(query._handleQueryResponse(self, columnTypes, err));\n                  } catch (error) {\n                    reject(error);\n                  }\n                };\n                if (typeof conn.exec === \"function\") {\n                  parameters = parameters || [];\n                } else parameters = [];\n                t.executeSql(\n                  self.sql,\n                  parameters,\n                  successCallback,\n                  errorCallback\n                );\n              });*/\n            }\n          })\n        );\n        return null;\n      };\n\n      if (method === \"all\") {\n        let tableNames = [];\n        if (this.options && this.options.tableNames) {\n          tableNames = this.options.tableNames;\n        } else if (/FROM `(.*?)`/i.exec(this.sql)) {\n          tableNames.push(/FROM `(.*?)`/i.exec(this.sql)[1]);\n        }\n\n        // If we already have the metadata for the table, there's no need to ask for it again\n        tableNames = tableNames.filter(\n          tableName =>\n            !(tableName in columnTypes) && tableName !== \"sqlite_master\"\n        );\n        if (!tableNames.length) {\n          return executeSql();\n        }\n        return new Promise(resolve => {\n          if (typeof conn.exec === \"function\") {\n            const sqlCommands = tableNames.map(tableName => {\n              tableName = tableName.replace(/`/g, \"\");\n              columnTypes[tableName] = {};\n              return [`PRAGMA table_info(\\`${tableName}\\`)`, tableName];\n            });\n            conn.exec(\n              sqlCommands.map(sqlCmd => ({\n                sql: sqlCmd[0],\n                args: []\n              })),\n              false,\n              (err, results) => {\n                if (!err) {\n                  for (let i = 0; i < sqlCommands.length; i++) {\n                    const tableName = sqlCommands[i][1];\n                    for (const result of results[i].rows) {\n                      columnTypes[tableName][result.name] = result.type;\n                    }\n                  }\n                }\n                resolve();\n              }\n            );\n          } else {\n            tableNames.forEach((tableName, index) => {\n              conn.executeSql(\n                `SELECT sql FROM sqlite_master WHERE tbl_name='${tableName}' and type='table'`,\n                [],\n                function(result) {\n                  const table = result.rows.item(0);\n                  if (\n                    typeof table === \"object\" &&\n                    \"sql\" in table &&\n                    typeof table.sql === \"string\"\n                  ) {\n                    columnTypes[tableName] = {};\n                    //match column name with data types\n                    const columns = table.sql.match(\n                      /(`\\w+`)((\\s([A-Z]+)((\\(\\d+\\)))?))/g\n                    );\n                    // split column names with data type\n                    for (const col of columns) {\n                      const [colName, colType] = col\n                        .trim()\n                        .replace(/\\s+/g, \" \")\n                        .replace(/`/g, \"\")\n                        .split(\" \");\n                      columnTypes[tableName][colName] = colType.trim();\n                    }\n                  }\n                  //console.log(columnTypes)\n                  if (index === tableNames.length - 1) resolve();\n                },\n                function(error) {\n                  if (index === tableNames.length - 1) resolve();\n                }\n              );\n            });\n            /*conn.transaction(function(t) {\n              tableNames.forEach((tableName, index) => {\n                t.executeSql(\n                  `SELECT sql FROM sqlite_master WHERE tbl_name='${tableName}' and type='table'`,\n                  [],\n                  function(_, result) {\n                    const table = result.rows.item(0);\n                    if (\n                      typeof table === \"object\" &&\n                      \"sql\" in table &&\n                      typeof table.sql === \"string\"\n                    ) {\n                      columnTypes[tableName] = {};\n                      //match column name with data types\n                      const columns = table.sql.match(\n                        /(`\\w+`)((\\s([A-Z]+)((\\(\\d+\\)))?))/g\n                      );\n                      // split column names with data type\n                      for (const col of columns) {\n                        const [colName, colType] = col\n                          .trim()\n                          .replace(/\\s+/g, \" \")\n                          .replace(/`/g, \"\")\n                          .split(\" \");\n                        columnTypes[tableName][colName] = colType.trim();\n                      }\n                    }\n                    //console.log(columnTypes)\n                    if (index === tableNames.length - 1) resolve();\n                  },\n                  function(_, error) {\n                    if (index === tableNames.length - 1) resolve();\n                  }\n                );\n              });\n            });*/\n          }\n        }).then(executeSql);\n      }\n      return executeSql();\n    });\n  }\n\n  parseConstraintsFromSql(sql) {\n    let constraints = sql.split(\"CONSTRAINT \");\n    let referenceTableName, referenceTableKeys, updateAction, deleteAction;\n    constraints.splice(0, 1);\n    constraints = constraints.map(constraintSql => {\n      //Parse foreign key snippets\n      if (constraintSql.includes(\"REFERENCES\")) {\n        //Parse out the constraint condition form sql string\n        updateAction = constraintSql.match(\n          /ON UPDATE (CASCADE|SET NULL|RESTRICT|NO ACTION|SET DEFAULT){1}/\n        );\n        deleteAction = constraintSql.match(\n          /ON DELETE (CASCADE|SET NULL|RESTRICT|NO ACTION|SET DEFAULT){1}/\n        );\n\n        if (updateAction) {\n          updateAction = updateAction[1];\n        }\n\n        if (deleteAction) {\n          deleteAction = deleteAction[1];\n        }\n\n        const referencesRegex = /REFERENCES.+\\((?:[^)(]+|\\((?:[^)(]+|\\([^)(]*\\))*\\))*\\)/;\n        const referenceConditions = constraintSql\n          .match(referencesRegex)[0]\n          .split(\" \");\n        referenceTableName = Utils.removeTicks(referenceConditions[1]);\n        let columnNames = referenceConditions[2];\n        columnNames = columnNames.replace(/\\(|\\)/g, \"\").split(\", \");\n        referenceTableKeys = columnNames.map(column =>\n          Utils.removeTicks(column)\n        );\n      }\n\n      const constraintCondition = constraintSql.match(\n        /\\((?:[^)(]+|\\((?:[^)(]+|\\([^)(]*\\))*\\))*\\)/\n      )[0];\n      constraintSql = constraintSql.replace(/\\(.+\\)/, \"\");\n      const constraint = constraintSql.split(\" \");\n\n      if (constraint[1] === \"PRIMARY\" || constraint[1] === \"FOREIGN\") {\n        constraint[1] += \" KEY\";\n      }\n\n      return {\n        constraintName: Utils.removeTicks(constraint[0]),\n        constraintType: constraint[1],\n        updateAction,\n        deleteAction,\n        sql: sql.replace(/\"/g, \"`\"), //Sqlite returns double quotes for table name\n        constraintCondition,\n        referenceTableName,\n        referenceTableKeys\n      };\n    });\n\n    return constraints;\n  }\n\n  applyParsers(type, value) {\n    if (type.includes(\"(\")) {\n      // Remove the length part\n      type = type.substr(0, type.indexOf(\"(\"));\n    }\n    type = type.replace(\"UNSIGNED\", \"\").replace(\"ZEROFILL\", \"\");\n    type = type.trim().toUpperCase();\n    const parse = parserStore.get(type);\n    if (value !== null && parse) {\n      return parse(value, { timezone: this.sequelize.options.timezone });\n    }\n    return value;\n  }\n\n  formatError(err) {\n    switch (err.code) {\n      case \"SQLITE_CONSTRAINT\": {\n        if (err.message.includes(\"FOREIGN KEY constraint failed\")) {\n          return new sequelizeErrors.ForeignKeyConstraintError({\n            parent: err\n          });\n        }\n\n        let fields = [];\n\n        // Sqlite pre 2.2 behavior - Error: SQLITE_CONSTRAINT: columns x, y are not unique\n        let match = err.message.match(/columns (.*?) are/);\n        if (match !== null && match.length >= 2) {\n          fields = match[1].split(\", \");\n        } else {\n          // Sqlite post 2.2 behavior - Error: SQLITE_CONSTRAINT: UNIQUE constraint failed: table.x, table.y\n          match = err.message.match(/UNIQUE constraint failed: (.*)/);\n          if (match !== null && match.length >= 2) {\n            fields = match[1]\n              .split(\", \")\n              .map(columnWithTable => columnWithTable.split(\".\")[1]);\n          }\n        }\n\n        const errors = [];\n        let message = \"Validation error\";\n\n        for (const field of fields) {\n          errors.push(\n            new sequelizeErrors.ValidationErrorItem(\n              this.getUniqueConstraintErrorMessage(field),\n              \"unique violation\", // sequelizeErrors.ValidationErrorItem.Origins.DB,\n              field,\n              this.instance && this.instance[field],\n              this.instance,\n              \"not_unique\"\n            )\n          );\n        }\n\n        if (this.model) {\n          _.forOwn(this.model.uniqueKeys, constraint => {\n            if (_.isEqual(constraint.fields, fields) && !!constraint.msg) {\n              message = constraint.msg;\n              return false;\n            }\n          });\n        }\n\n        return new sequelizeErrors.UniqueConstraintError({\n          message,\n          errors,\n          parent: err,\n          fields\n        });\n      }\n      case \"SQLITE_BUSY\":\n        return new sequelizeErrors.TimeoutError(err);\n\n      default:\n        return new sequelizeErrors.DatabaseError(err);\n    }\n  }\n\n  handleShowIndexesQuery(data) {\n    // Sqlite returns indexes so the one that was defined last is returned first. Lets reverse that!\n    return Promise.map(data.reverse(), item => {\n      item.fields = [];\n      item.primary = false;\n      item.unique = !!item.unique;\n      item.constraintName = item.name;\n      return this.run(`PRAGMA INDEX_INFO(\\`${item.name}\\`)`).then(columns => {\n        for (const column of columns) {\n          item.fields[column.seqno] = {\n            attribute: column.name,\n            length: undefined,\n            order: undefined\n          };\n        }\n\n        return item;\n      });\n    });\n  }\n\n  getDatabaseMethod() {\n    if (\n      this.sql.includes(\"PRAGMA\") ||\n      this.sql.includes(\"COMMIT\") ||\n      this.sql.includes(\"ROLLBACK\") ||\n      this.sql.includes(\"TRANSACTION\")\n    ) {\n      return \"exec\"; // Needed to run no-op transaction\n    }\n    if (\n      this.isInsertQuery() ||\n      this.isUpdateQuery() ||\n      this.isBulkUpdateQuery() ||\n      this.sql.toLowerCase().includes(\"CREATE TEMPORARY TABLE\".toLowerCase()) ||\n      this.options.type === QueryTypes.BULKDELETE\n    ) {\n      return \"run\";\n    }\n    return \"all\";\n  }\n  convertToArray(results) {\n    if (!results.rows) return [];\n    if (\"array\" in results || \"_array\" in results.rows)\n      return results.array || results.rows._array;\n    if (!results.rows.item) return results.rows;\n    const data = new Array(results.rows.length);\n    for (let i = 0; i < results.rows.length; i++) {\n      data[i] = results.rows.item(i);\n    }\n    return data;\n  }\n}\n\nmodule.exports = Query;\nmodule.exports.Query = Query;\nmodule.exports.default = Query;\n"]} \ No newline at end of file diff --git a/lib/dialects/sqlite/query.js b/lib/dialects/sqlite/query.js index 342a4d8..6379a3e 100644 --- a/lib/dialects/sqlite/query.js +++ b/lib/dialects/sqlite/query.js @@ -297,7 +297,7 @@ class Query extends AbstractQuery { resolve(); } } else { - var successCallback = function(_, results) { + var successCallback = function(results) { try { complete(); // `self` is passed from sqlite, we have no control over this. @@ -326,7 +326,7 @@ class Query extends AbstractQuery { } }; // eslint-disable-next-line - var errorCallback = function(_, err) { + var errorCallback = function(err) { try { complete(); // `self` is passed from sqlite, we have no control over this. @@ -449,7 +449,7 @@ class Query extends AbstractQuery { conn.executeSql( `SELECT sql FROM sqlite_master WHERE tbl_name='${tableName}' and type='table'`, [], - function(_, result) { + function(result) { const table = result.rows.item(0); if ( typeof table === "object" && @@ -474,7 +474,7 @@ class Query extends AbstractQuery { //console.log(columnTypes) if (index === tableNames.length - 1) resolve(); }, - function(_, error) { + function(error) { if (index === tableNames.length - 1) resolve(); } ); From 3444a618354553e5bcfd0ed19df5191cc8485507 Mon Sep 17 00:00:00 2001 From: prih Date: Tue, 15 Dec 2020 15:15:01 +0200 Subject: [PATCH 8/8] . --- dist/dialects/sqlite/query.js | 148 ++++++++-------------------------- lib/dialects/sqlite/query.js | 90 +-------------------- 2 files changed, 37 insertions(+), 201 deletions(-) diff --git a/dist/dialects/sqlite/query.js b/dist/dialects/sqlite/query.js index d5b5aac..ee64954 100644 --- a/dist/dialects/sqlite/query.js +++ b/dist/dialects/sqlite/query.js @@ -319,54 +319,14 @@ let Query = /*#__PURE__*/function (_AbstractQuery) { resolve(); } } else { - var successCallback = function (results) { - try { - complete(); // `self` is passed from sqlite, we have no control over this. - // eslint-disable-next-line no-invalid-this - - if (results.rowsAffected) { - try { - self[self.getInsertIdField()] = results.insertId; - } catch (e) { - delete self[self.getInsertIdField()]; - } - } - - self.changes = results.rowsAffected; - results = query.convertToArray(results); - resolve(query._handleQueryResponse(self, columnTypes, undefined, results)); - return; - } catch (error) { - debug(error); - reject(error); - } - }; // eslint-disable-next-line - - - var errorCallback = function (err) { - try { - complete(); // `self` is passed from sqlite, we have no control over this. - // eslint-disable-next-line no-invalid-this - - resolve(query._handleQueryResponse(self, columnTypes, err)); - } catch (error) { - reject(error); - } - }; - - if (typeof conn.exec === "function") { - parameters = parameters || []; - } else parameters = []; - - conn.executeSql(self.sql, parameters, successCallback, errorCallback); - /*conn.transaction(function(t) { + conn.transaction(function (t) { // cannot use arrow function here because the function is bound to the statement // eslint-disable-next-line - var successCallback = function(_, results) { + var successCallback = function (_, results) { try { - complete(); - // `self` is passed from sqlite, we have no control over this. + complete(); // `self` is passed from sqlite, we have no control over this. // eslint-disable-next-line no-invalid-this + if (results.rowsAffected) { try { self[self.getInsertIdField()] = results.insertId; @@ -374,43 +334,35 @@ let Query = /*#__PURE__*/function (_AbstractQuery) { delete self[self.getInsertIdField()]; } } + self.changes = results.rowsAffected; results = query.convertToArray(results); - resolve( - query._handleQueryResponse( - self, - columnTypes, - undefined, - results - ) - ); + resolve(query._handleQueryResponse(self, columnTypes, undefined, results)); return; } catch (error) { debug(error); reject(error); } - }; - // eslint-disable-next-line - var errorCallback = function(_, err) { + }; // eslint-disable-next-line + + + var errorCallback = function (_, err) { try { - complete(); - // `self` is passed from sqlite, we have no control over this. + complete(); // `self` is passed from sqlite, we have no control over this. // eslint-disable-next-line no-invalid-this + resolve(query._handleQueryResponse(self, columnTypes, err)); } catch (error) { reject(error); } }; + if (typeof conn.exec === "function") { parameters = parameters || []; } else parameters = []; - t.executeSql( - self.sql, - parameters, - successCallback, - errorCallback - ); - });*/ + + t.executeSql(self.sql, parameters, successCallback, errorCallback); + }); } })); return null; @@ -456,63 +408,29 @@ let Query = /*#__PURE__*/function (_AbstractQuery) { resolve(); }); } else { - tableNames.forEach((tableName, index) => { - conn.executeSql(`SELECT sql FROM sqlite_master WHERE tbl_name='${tableName}' and type='table'`, [], function (result) { - const table = result.rows.item(0); + conn.transaction(function (t) { + tableNames.forEach((tableName, index) => { + t.executeSql(`SELECT sql FROM sqlite_master WHERE tbl_name='${tableName}' and type='table'`, [], function (_, result) { + const table = result.rows.item(0); - if (typeof table === "object" && "sql" in table && typeof table.sql === "string") { - columnTypes[tableName] = {}; //match column name with data types + if (typeof table === "object" && "sql" in table && typeof table.sql === "string") { + columnTypes[tableName] = {}; //match column name with data types - const columns = table.sql.match(/(`\w+`)((\s([A-Z]+)((\(\d+\)))?))/g); // split column names with data type + const columns = table.sql.match(/(`\w+`)((\s([A-Z]+)((\(\d+\)))?))/g); // split column names with data type - for (const col of columns) { - const [colName, colType] = col.trim().replace(/\s+/g, " ").replace(/`/g, "").split(" "); - columnTypes[tableName][colName] = colType.trim(); - } - } //console.log(columnTypes) + for (const col of columns) { + const [colName, colType] = col.trim().replace(/\s+/g, " ").replace(/`/g, "").split(" "); + columnTypes[tableName][colName] = colType.trim(); + } + } //console.log(columnTypes) - if (index === tableNames.length - 1) resolve(); - }, function (error) { - if (index === tableNames.length - 1) resolve(); + if (index === tableNames.length - 1) resolve(); + }, function (_, error) { + if (index === tableNames.length - 1) resolve(); + }); }); }); - /*conn.transaction(function(t) { - tableNames.forEach((tableName, index) => { - t.executeSql( - `SELECT sql FROM sqlite_master WHERE tbl_name='${tableName}' and type='table'`, - [], - function(_, result) { - const table = result.rows.item(0); - if ( - typeof table === "object" && - "sql" in table && - typeof table.sql === "string" - ) { - columnTypes[tableName] = {}; - //match column name with data types - const columns = table.sql.match( - /(`\w+`)((\s([A-Z]+)((\(\d+\)))?))/g - ); - // split column names with data type - for (const col of columns) { - const [colName, colType] = col - .trim() - .replace(/\s+/g, " ") - .replace(/`/g, "") - .split(" "); - columnTypes[tableName][colName] = colType.trim(); - } - } - //console.log(columnTypes) - if (index === tableNames.length - 1) resolve(); - }, - function(_, error) { - if (index === tableNames.length - 1) resolve(); - } - ); - }); - });*/ } }).then(executeSql); } @@ -736,4 +654,4 @@ let Query = /*#__PURE__*/function (_AbstractQuery) { module.exports = Query; module.exports.Query = Query; module.exports.default = Query; -//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../lib/dialects/sqlite/query.js"],"names":["_","require","Utils","Promise","AbstractQuery","QueryTypes","sequelizeErrors","parserStore","logger","debug","debugContext","getMethods","obj","properties","Set","currentObj","Object","getOwnPropertyNames","map","item","add","getPrototypeOf","keys","filter","Query","include","prefix","ret","_include","key","as","model","merge","_collectModels","metaData","columnTypes","err","results","sql","formatError","result","instance","isInsertQuery","handleInsertQuery","autoIncrementAttribute","primaryKeyAttribute","rawAttributes","startId","getInsertIdField","changes","i","push","field","isShowTablesQuery","row","name","isShowConstraintsQuery","parseConstraintsFromSql","isSelectQuery","options","raw","handleSelectQuery","prefixes","mapValues","value","includes","lastind","lastIndexOf","substr","tableName","getTableName","toString","replace","tableTypes","forOwn","attribute","prototype","hasOwnProperty","call","applyParsers","isShowOrDescribeQuery","handleShowIndexesQuery","Array","isArray","defaultValue","_result","dflt_value","undefined","type","allowNull","notnull","primaryKey","pk","BULKUPDATE","BULKDELETE","UPSERT","VERSION","version","RAW","isUpdateQuery","parameters","formatBindParameters","bind","dialect","skipUnescape","method","getDatabaseMethod","complete","_logQuery","query","self","conn","connection","resolve","executeSql","startsWith","reject","exec","args","executionError","convertToArray","_handleQueryResponse","error","successCallback","rowsAffected","insertId","e","errorCallback","tableNames","length","sqlCommands","sqlCmd","rows","forEach","index","table","columns","match","col","colName","colType","trim","split","then","constraints","referenceTableName","referenceTableKeys","updateAction","deleteAction","splice","constraintSql","referencesRegex","referenceConditions","removeTicks","columnNames","column","constraintCondition","constraint","constraintName","constraintType","indexOf","toUpperCase","parse","get","timezone","sequelize","code","message","ForeignKeyConstraintError","parent","fields","columnWithTable","errors","ValidationErrorItem","getUniqueConstraintErrorMessage","uniqueKeys","isEqual","msg","UniqueConstraintError","TimeoutError","DatabaseError","data","reverse","primary","unique","run","seqno","order","isBulkUpdateQuery","toLowerCase","array","_array","values","bindParam","v","skipValueReplace","k","module","exports","default"],"mappings":"AAAA;;;;;;;;;;;;;;;;;;;;;;AAEA,MAAMA,CAAC,GAAGC,OAAO,CAAC,QAAD,CAAjB;;AACA,MAAMC,KAAK,GAAGD,OAAO,CAAC,aAAD,CAArB;;AACA,MAAME,OAAO,GAAGF,OAAO,CAAC,eAAD,CAAvB;;AACA,MAAMG,aAAa,GAAGH,OAAO,CAAC,mBAAD,CAA7B;;AACA,MAAMI,UAAU,GAAGJ,OAAO,CAAC,mBAAD,CAA1B;;AACA,MAAMK,eAAe,GAAGL,OAAO,CAAC,cAAD,CAA/B;;AACA,MAAMM,WAAW,GAAGN,OAAO,CAAC,gBAAD,CAAP,CAA0B,QAA1B,CAApB;;AACA,MAAM;AAAEO,EAAAA;AAAF,IAAaP,OAAO,CAAC,oBAAD,CAA1B;;AAEA,MAAMQ,KAAK,GAAGD,MAAM,CAACE,YAAP,CAAoB,YAApB,CAAd;;AACA,MAAMC,UAAU,GAAGC,GAAG,IAAI;AACxB,MAAIC,UAAU,GAAG,IAAIC,GAAJ,EAAjB;AACA,MAAIC,UAAU,GAAGH,GAAjB;;AACA,KAAG;AACDI,IAAAA,MAAM,CAACC,mBAAP,CAA2BF,UAA3B,EAAuCG,GAAvC,CAA2CC,IAAI,IAAIN,UAAU,CAACO,GAAX,CAAeD,IAAf,CAAnD;AACD,GAFD,QAEUJ,UAAU,GAAGC,MAAM,CAACK,cAAP,CAAsBN,UAAtB,CAFvB;;AAGA,SAAO,CAAC,GAAGF,UAAU,CAACS,IAAX,EAAJ,EAAuBC,MAAvB,CAA8BJ,IAAI,IAAI,OAAOP,GAAG,CAACO,IAAD,CAAV,KAAqB,UAA3D,CAAP;AACD,CAPD;;IAQMK,K;;;;;;;;;;;;;uCACe;AACjB,aAAO,QAAP;AACD;AAED;AACF;AACA;AACA;AACA;AACA;AACA;AACA;;;;mCAyBiBC,O,EAASC,M,EAAQ;AAC9B,YAAMC,GAAG,GAAG,EAAZ;;AAEA,UAAIF,OAAJ,EAAa;AACX,aAAK,MAAMG,QAAX,IAAuBH,OAAvB,EAAgC;AAC9B,cAAII,GAAJ;;AACA,cAAI,CAACH,MAAL,EAAa;AACXG,YAAAA,GAAG,GAAGD,QAAQ,CAACE,EAAf;AACD,WAFD,MAEO;AACLD,YAAAA,GAAG,GAAI,GAAEH,MAAO,IAAGE,QAAQ,CAACE,EAAG,EAA/B;AACD;;AACDH,UAAAA,GAAG,CAACE,GAAD,CAAH,GAAWD,QAAQ,CAACG,KAApB;;AAEA,cAAIH,QAAQ,CAACH,OAAb,EAAsB;AACpBzB,YAAAA,CAAC,CAACgC,KAAF,CAAQL,GAAR,EAAa,KAAKM,cAAL,CAAoBL,QAAQ,CAACH,OAA7B,EAAsCI,GAAtC,CAAb;AACD;AACF;AACF;;AAED,aAAOF,GAAP;AACD;;;yCAEoBO,Q,EAAUC,W,EAAaC,G,EAAKC,O,EAAS;AACxD,UAAID,GAAJ,EAAS;AACPA,QAAAA,GAAG,CAACE,GAAJ,GAAU,KAAKA,GAAf;AACA,cAAM,KAAKC,WAAL,CAAiBH,GAAjB,CAAN;AACD;;AACD,UAAII,MAAM,GAAG,KAAKC,QAAlB,CALwD,CAMxD;;AACA,UAAI,KAAKC,aAAL,CAAmBL,OAAnB,EAA4BH,QAA5B,CAAJ,EAA2C;AACzC,aAAKS,iBAAL,CAAuBN,OAAvB,EAAgCH,QAAhC;;AACA,YAAI,CAAC,KAAKO,QAAV,EAAoB;AAClB;AACA;AACE;AACA,eAAKV,KAAL,IACA,KAAKA,KAAL,CAAWa,sBADX,IAEA,KAAKb,KAAL,CAAWa,sBAAX,KACE,KAAKb,KAAL,CAAWc,mBAHb,IAIA,KAAKd,KAAL,CAAWe,aAAX,CAAyB,KAAKf,KAAL,CAAWc,mBAApC,CANF,EAOE;AACA,kBAAME,OAAO,GACXb,QAAQ,CAAC,KAAKc,gBAAL,EAAD,CAAR,GAAoCd,QAAQ,CAACe,OAA7C,GAAuD,CADzD;AAGAT,YAAAA,MAAM,GAAG,EAAT;;AACA,iBAAK,IAAIU,CAAC,GAAGH,OAAb,EAAsBG,CAAC,GAAGH,OAAO,GAAGb,QAAQ,CAACe,OAA7C,EAAsDC,CAAC,EAAvD,EAA2D;AACzDV,cAAAA,MAAM,CAACW,IAAP,CAAY;AACV,iBAAC,KAAKpB,KAAL,CAAWe,aAAX,CAAyB,KAAKf,KAAL,CAAWc,mBAApC,EACEO,KADH,GACWF;AAFD,eAAZ;AAID;AACF,WAlBD,MAkBO;AACLV,YAAAA,MAAM,GAAGN,QAAQ,CAAC,KAAKc,gBAAL,EAAD,CAAjB;AACD;AACF;AACF;;AAED,UAAI,KAAKK,iBAAL,EAAJ,EAA8B;AAC5B,eAAOhB,OAAO,CAACnB,GAAR,CAAYoC,GAAG,IAAIA,GAAG,CAACC,IAAvB,CAAP;AACD;;AACD,UAAI,KAAKC,sBAAL,EAAJ,EAAmC;AACjChB,QAAAA,MAAM,GAAGH,OAAT;;AACA,YAAIA,OAAO,IAAIA,OAAO,CAAC,CAAD,CAAlB,IAAyBA,OAAO,CAAC,CAAD,CAAP,CAAWC,GAAxC,EAA6C;AAC3CE,UAAAA,MAAM,GAAG,KAAKiB,uBAAL,CAA6BpB,OAAO,CAAC,CAAD,CAAP,CAAWC,GAAxC,CAAT;AACD;;AACD,eAAOE,MAAP;AACD;;AACD,UAAI,KAAKkB,aAAL,EAAJ,EAA0B;AACxB,YAAI,KAAKC,OAAL,CAAaC,GAAjB,EAAsB;AACpB,iBAAO,KAAKC,iBAAL,CAAuBxB,OAAvB,CAAP;AACD,SAHuB,CAIxB;;;AACA,cAAMyB,QAAQ,GAAG,KAAK7B,cAAL,CAAoB,KAAK0B,OAAL,CAAalC,OAAjC,CAAjB;;AAEAY,QAAAA,OAAO,GAAGA,OAAO,CAACnB,GAAR,CAAYsB,MAAM,IAAI;AAC9B,iBAAOxC,CAAC,CAAC+D,SAAF,CAAYvB,MAAZ,EAAoB,CAACwB,KAAD,EAAQT,IAAR,KAAiB;AAC1C,gBAAIxB,KAAJ;;AACA,gBAAIwB,IAAI,CAACU,QAAL,CAAc,GAAd,CAAJ,EAAwB;AACtB,oBAAMC,OAAO,GAAGX,IAAI,CAACY,WAAL,CAAiB,GAAjB,CAAhB;AAEApC,cAAAA,KAAK,GAAG+B,QAAQ,CAACP,IAAI,CAACa,MAAL,CAAY,CAAZ,EAAeF,OAAf,CAAD,CAAhB;AAEAX,cAAAA,IAAI,GAAGA,IAAI,CAACa,MAAL,CAAYF,OAAO,GAAG,CAAtB,CAAP;AACD,aAND,MAMO;AACLnC,cAAAA,KAAK,GAAG,KAAK4B,OAAL,CAAa5B,KAArB;AACD;;AAED,kBAAMsC,SAAS,GAAGtC,KAAK,CACpBuC,YADe,GAEfC,QAFe,GAGfC,OAHe,CAGP,IAHO,EAGD,EAHC,CAAlB;AAIA,kBAAMC,UAAU,GAAGtC,WAAW,CAACkC,SAAD,CAAX,IAA0B,EAA7C;;AAEA,gBAAII,UAAU,IAAI,EAAElB,IAAI,IAAIkB,UAAV,CAAlB,EAAyC;AACvC;AACAzE,cAAAA,CAAC,CAAC0E,MAAF,CAAS3C,KAAK,CAACe,aAAf,EAA8B,CAAC6B,SAAD,EAAY9C,GAAZ,KAAoB;AAChD,oBAAI0B,IAAI,KAAK1B,GAAT,IAAgB8C,SAAS,CAACvB,KAA9B,EAAqC;AACnCG,kBAAAA,IAAI,GAAGoB,SAAS,CAACvB,KAAjB;AACA,yBAAO,KAAP;AACD;AACF,eALD;AAMD;;AAED,mBAAOpC,MAAM,CAAC4D,SAAP,CAAiBC,cAAjB,CAAgCC,IAAhC,CAAqCL,UAArC,EAAiDlB,IAAjD,IACH,KAAKwB,YAAL,CAAkBN,UAAU,CAAClB,IAAD,CAA5B,EAAoCS,KAApC,CADG,GAEHA,KAFJ;AAGD,WA/BM,CAAP;AAgCD,SAjCS,CAAV;AAmCA,eAAO,KAAKH,iBAAL,CAAuBxB,OAAvB,CAAP;AACD;;AACD,UAAI,KAAK2C,qBAAL,EAAJ,EAAkC;AAChC,eAAO3C,OAAP;AACD;;AACD,UAAI,KAAKC,GAAL,CAAS2B,QAAT,CAAkB,mBAAlB,CAAJ,EAA4C;AAC1C,eAAO,KAAKgB,sBAAL,CAA4B5C,OAA5B,CAAP;AACD;;AACD,UAAI,KAAKC,GAAL,CAAS2B,QAAT,CAAkB,mBAAlB,CAAJ,EAA4C;AAC1C,eAAO5B,OAAP;AACD;;AACD,UAAI,KAAKC,GAAL,CAAS2B,QAAT,CAAkB,mBAAlB,CAAJ,EAA4C;AAC1C;AACAzB,QAAAA,MAAM,GAAG,EAAT;;AAEA,YAAI0C,KAAK,CAACC,OAAN,CAAc9C,OAAd,CAAJ,EAA4B;AAC1B,cAAI+C,YAAJ;;AACA,eAAK,MAAMC,OAAX,IAAsBhD,OAAtB,EAA+B;AAC7B,gBAAIgD,OAAO,CAACC,UAAR,KAAuB,IAA3B,EAAiC;AAC/B;AACAF,cAAAA,YAAY,GAAGG,SAAf;AACD,aAHD,MAGO,IAAIF,OAAO,CAACC,UAAR,KAAuB,MAA3B,EAAmC;AACxC;AACAF,cAAAA,YAAY,GAAG,IAAf;AACD,aAHM,MAGA;AACLA,cAAAA,YAAY,GAAGC,OAAO,CAACC,UAAvB;AACD;;AAED9C,YAAAA,MAAM,CAAC6C,OAAO,CAAC9B,IAAT,CAAN,GAAuB;AACrBiC,cAAAA,IAAI,EAAEH,OAAO,CAACG,IADO;AAErBC,cAAAA,SAAS,EAAEJ,OAAO,CAACK,OAAR,KAAoB,CAFV;AAGrBN,cAAAA,YAHqB;AAIrBO,cAAAA,UAAU,EAAEN,OAAO,CAACO,EAAR,KAAe;AAJN,aAAvB;;AAOA,gBAAIpD,MAAM,CAAC6C,OAAO,CAAC9B,IAAT,CAAN,CAAqBiC,IAArB,KAA8B,YAAlC,EAAgD;AAC9ChD,cAAAA,MAAM,CAAC6C,OAAO,CAAC9B,IAAT,CAAN,CAAqB6B,YAArB,GAAoC;AAAE,qBAAK,KAAP;AAAc,qBAAK;AAAnB,gBAClC5C,MAAM,CAAC6C,OAAO,CAAC9B,IAAT,CAAN,CAAqB6B,YADa,CAApC;AAGD;;AAED,gBAAI,OAAO5C,MAAM,CAAC6C,OAAO,CAAC9B,IAAT,CAAN,CAAqB6B,YAA5B,KAA6C,QAAjD,EAA2D;AACzD5C,cAAAA,MAAM,CAAC6C,OAAO,CAAC9B,IAAT,CAAN,CAAqB6B,YAArB,GAAoC5C,MAAM,CACxC6C,OAAO,CAAC9B,IADgC,CAAN,CAElC6B,YAFkC,CAErBZ,OAFqB,CAEb,IAFa,EAEP,EAFO,CAApC;AAGD;AACF;AACF;;AAED,eAAOhC,MAAP;AACD;;AACD,UAAI,KAAKF,GAAL,CAAS2B,QAAT,CAAkB,sBAAlB,CAAJ,EAA+C;AAC7C,eAAO5B,OAAO,CAAC,CAAD,CAAd;AACD;;AACD,UAAI,KAAKC,GAAL,CAAS2B,QAAT,CAAkB,qBAAlB,CAAJ,EAA8C;AAC5C,eAAO5B,OAAP;AACD;;AACD,UAAI,KAAKC,GAAL,CAAS2B,QAAT,CAAkB,yBAAlB,CAAJ,EAAkD;AAChD,eAAO5B,OAAP;AACD;;AACD,UACE,CAAChC,UAAU,CAACwF,UAAZ,EAAwBxF,UAAU,CAACyF,UAAnC,EAA+C7B,QAA/C,CAAwD,KAAKN,OAAL,CAAa6B,IAArE,CADF,EAEE;AACA,eAAOtD,QAAQ,CAACe,OAAhB;AACD;;AACD,UAAI,KAAKU,OAAL,CAAa6B,IAAb,KAAsBnF,UAAU,CAAC0F,MAArC,EAA6C;AAC3C,eAAOR,SAAP;AACD;;AACD,UAAI,KAAK5B,OAAL,CAAa6B,IAAb,KAAsBnF,UAAU,CAAC2F,OAArC,EAA8C;AAC5C,eAAO3D,OAAO,CAAC,CAAD,CAAP,CAAW4D,OAAlB;AACD;;AACD,UAAI,KAAKtC,OAAL,CAAa6B,IAAb,KAAsBnF,UAAU,CAAC6F,GAArC,EAA0C;AACxC,eAAO,CAAC7D,OAAD,EAAUH,QAAV,CAAP;AACD;;AACD,UAAI,KAAKiE,aAAL,MAAwB,KAAKzD,aAAL,EAA5B,EAAkD;AAChD,eAAO,CAACF,MAAD,EAASN,QAAQ,CAACe,OAAlB,CAAP;AACD;;AACD,aAAOT,MAAP;AACD,K,CACD;;;;wBACIF,G,EAAK8D,U,EAAY;AACnB;AACA,WAAK9D,GAAL,GAAWlC,aAAa,CAACiG,oBAAd,CACT/D,GADS,EAET,KAAKqB,OAAL,CAAa2C,IAFJ,EAGT,KAAK3C,OAAL,CAAa4C,OAAb,IAAwB,QAHf,EAIT;AAAEC,QAAAA,YAAY,EAAE;AAAhB,OAJS,EAKT,CALS,CAAX;AAMA,YAAMC,MAAM,GAAG,KAAKC,iBAAL,EAAf;;AACA,YAAMC,QAAQ,GAAG,KAAKC,SAAL,CAAe,KAAKtE,GAApB,EAAyB7B,KAAzB,EAAgC2F,UAAhC,CAAjB;;AACA,YAAMS,KAAK,GAAG,IAAd;AACA,YAAMC,IAAI,GAAG,IAAb;AACA,YAAMC,IAAI,GAAG,KAAKC,UAAlB;AAEA,aAAO,IAAI7G,OAAJ,CAAY8G,OAAO,IAAI;AAC5B,cAAM9E,WAAW,GAAG,EAApB,CAD4B,CAE5B;;AACA,cAAM+E,UAAU,GAAG,MAAM;AACvB,cAAI5E,GAAG,CAAC6E,UAAJ,CAAe,KAAf,CAAJ,EAA2B;AACzB,mBAAOF,OAAO,EAAd;AACD;;AACDA,UAAAA,OAAO,CACL,IAAI9G,OAAJ,CAAY,CAAC8G,OAAD,EAAUG,MAAV,KAAqB;AAC/B,gBAAIX,MAAM,KAAK,MAAf,EAAuB;AACrB,kBAAI,OAAOM,IAAI,CAACM,IAAZ,KAAqB,UAAzB,EAAqC;AACnCN,gBAAAA,IAAI,CAACM,IAAL,CACE,CAAC;AAAE/E,kBAAAA,GAAG,EAAEwE,IAAI,CAACxE,GAAZ;AAAiBgF,kBAAAA,IAAI,EAAE;AAAvB,iBAAD,CADF,EAEE,KAFF,EAGE,CAACC,cAAD,EAAiBlF,OAAjB,KAA6B;AAC3B,sBAAI;AACFsE,oBAAAA,QAAQ,GADN,CAEF;;AACAtE,oBAAAA,OAAO,GAAGwE,KAAK,CAACW,cAAN,CAAqBnF,OAAO,CAAC,CAAD,CAA5B,CAAV,CAHE,CAIF;AACA;;AACA4E,oBAAAA,OAAO,CACLJ,KAAK,CAACY,oBAAN,CACEX,IADF,EAEE3E,WAFF,EAGEoF,cAHF,EAIElF,OAJF,CADK,CAAP;AAQA;AACD,mBAfD,CAeE,OAAOqF,KAAP,EAAc;AACdN,oBAAAA,MAAM,CAACM,KAAD,CAAN;AACD;AACF,iBAtBH;AAwBD,eAzBD,MAyBO;AACLT,gBAAAA,OAAO;AACR;AACF,aA7BD,MA6BO;AACL,kBAAIU,eAAe,GAAG,UAAStF,OAAT,EAAkB;AACtC,oBAAI;AACFsE,kBAAAA,QAAQ,GADN,CAEF;AACA;;AACA,sBAAItE,OAAO,CAACuF,YAAZ,EAA0B;AACxB,wBAAI;AACFd,sBAAAA,IAAI,CAACA,IAAI,CAAC9D,gBAAL,EAAD,CAAJ,GAAgCX,OAAO,CAACwF,QAAxC;AACD,qBAFD,CAEE,OAAOC,CAAP,EAAU;AACV,6BAAOhB,IAAI,CAACA,IAAI,CAAC9D,gBAAL,EAAD,CAAX;AACD;AACF;;AACD8D,kBAAAA,IAAI,CAAC7D,OAAL,GAAeZ,OAAO,CAACuF,YAAvB;AACAvF,kBAAAA,OAAO,GAAGwE,KAAK,CAACW,cAAN,CAAqBnF,OAArB,CAAV;AACA4E,kBAAAA,OAAO,CACLJ,KAAK,CAACY,oBAAN,CACEX,IADF,EAEE3E,WAFF,EAGEoD,SAHF,EAIElD,OAJF,CADK,CAAP;AAQA;AACD,iBAtBD,CAsBE,OAAOqF,KAAP,EAAc;AACdjH,kBAAAA,KAAK,CAACiH,KAAD,CAAL;AACAN,kBAAAA,MAAM,CAACM,KAAD,CAAN;AACD;AACF,eA3BD,CADK,CA6BL;;;AACA,kBAAIK,aAAa,GAAG,UAAS3F,GAAT,EAAc;AAChC,oBAAI;AACFuE,kBAAAA,QAAQ,GADN,CAEF;AACA;;AACAM,kBAAAA,OAAO,CAACJ,KAAK,CAACY,oBAAN,CAA2BX,IAA3B,EAAiC3E,WAAjC,EAA8CC,GAA9C,CAAD,CAAP;AACD,iBALD,CAKE,OAAOsF,KAAP,EAAc;AACdN,kBAAAA,MAAM,CAACM,KAAD,CAAN;AACD;AACF,eATD;;AAUA,kBAAI,OAAOX,IAAI,CAACM,IAAZ,KAAqB,UAAzB,EAAqC;AACnCjB,gBAAAA,UAAU,GAAGA,UAAU,IAAI,EAA3B;AACD,eAFD,MAEOA,UAAU,GAAG,EAAb;;AACPW,cAAAA,IAAI,CAACG,UAAL,CACEJ,IAAI,CAACxE,GADP,EAEE8D,UAFF,EAGEuB,eAHF,EAIEI,aAJF;AAMA;AACd;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACa;AACF,WApID,CADK,CAAP;AAuIA,iBAAO,IAAP;AACD,SA5ID;;AA8IA,YAAItB,MAAM,KAAK,KAAf,EAAsB;AACpB,cAAIuB,UAAU,GAAG,EAAjB;;AACA,cAAI,KAAKrE,OAAL,IAAgB,KAAKA,OAAL,CAAaqE,UAAjC,EAA6C;AAC3CA,YAAAA,UAAU,GAAG,KAAKrE,OAAL,CAAaqE,UAA1B;AACD,WAFD,MAEO,IAAI,gBAAgBX,IAAhB,CAAqB,KAAK/E,GAA1B,CAAJ,EAAoC;AACzC0F,YAAAA,UAAU,CAAC7E,IAAX,CAAgB,gBAAgBkE,IAAhB,CAAqB,KAAK/E,GAA1B,EAA+B,CAA/B,CAAhB;AACD,WANmB,CAQpB;;;AACA0F,UAAAA,UAAU,GAAGA,UAAU,CAACzG,MAAX,CACX8C,SAAS,IACP,EAAEA,SAAS,IAAIlC,WAAf,KAA+BkC,SAAS,KAAK,eAFpC,CAAb;;AAIA,cAAI,CAAC2D,UAAU,CAACC,MAAhB,EAAwB;AACtB,mBAAOf,UAAU,EAAjB;AACD;;AACD,iBAAO,IAAI/G,OAAJ,CAAY8G,OAAO,IAAI;AAC5B,gBAAI,OAAOF,IAAI,CAACM,IAAZ,KAAqB,UAAzB,EAAqC;AACnC,oBAAMa,WAAW,GAAGF,UAAU,CAAC9G,GAAX,CAAemD,SAAS,IAAI;AAC9CA,gBAAAA,SAAS,GAAGA,SAAS,CAACG,OAAV,CAAkB,IAAlB,EAAwB,EAAxB,CAAZ;AACArC,gBAAAA,WAAW,CAACkC,SAAD,CAAX,GAAyB,EAAzB;AACA,uBAAO,CAAE,uBAAsBA,SAAU,KAAlC,EAAwCA,SAAxC,CAAP;AACD,eAJmB,CAApB;AAKA0C,cAAAA,IAAI,CAACM,IAAL,CACEa,WAAW,CAAChH,GAAZ,CAAgBiH,MAAM,KAAK;AACzB7F,gBAAAA,GAAG,EAAE6F,MAAM,CAAC,CAAD,CADc;AAEzBb,gBAAAA,IAAI,EAAE;AAFmB,eAAL,CAAtB,CADF,EAKE,KALF,EAME,CAAClF,GAAD,EAAMC,OAAN,KAAkB;AAChB,oBAAI,CAACD,GAAL,EAAU;AACR,uBAAK,IAAIc,CAAC,GAAG,CAAb,EAAgBA,CAAC,GAAGgF,WAAW,CAACD,MAAhC,EAAwC/E,CAAC,EAAzC,EAA6C;AAC3C,0BAAMmB,SAAS,GAAG6D,WAAW,CAAChF,CAAD,CAAX,CAAe,CAAf,CAAlB;;AACA,yBAAK,MAAMV,MAAX,IAAqBH,OAAO,CAACa,CAAD,CAAP,CAAWkF,IAAhC,EAAsC;AACpCjG,sBAAAA,WAAW,CAACkC,SAAD,CAAX,CAAuB7B,MAAM,CAACe,IAA9B,IAAsCf,MAAM,CAACgD,IAA7C;AACD;AACF;AACF;;AACDyB,gBAAAA,OAAO;AACR,eAhBH;AAkBD,aAxBD,MAwBO;AACLe,cAAAA,UAAU,CAACK,OAAX,CAAmB,CAAChE,SAAD,EAAYiE,KAAZ,KAAsB;AACvCvB,gBAAAA,IAAI,CAACG,UAAL,CACG,iDAAgD7C,SAAU,oBAD7D,EAEE,EAFF,EAGE,UAAS7B,MAAT,EAAiB;AACf,wBAAM+F,KAAK,GAAG/F,MAAM,CAAC4F,IAAP,CAAYjH,IAAZ,CAAiB,CAAjB,CAAd;;AACA,sBACE,OAAOoH,KAAP,KAAiB,QAAjB,IACA,SAASA,KADT,IAEA,OAAOA,KAAK,CAACjG,GAAb,KAAqB,QAHvB,EAIE;AACAH,oBAAAA,WAAW,CAACkC,SAAD,CAAX,GAAyB,EAAzB,CADA,CAEA;;AACA,0BAAMmE,OAAO,GAAGD,KAAK,CAACjG,GAAN,CAAUmG,KAAV,CACd,oCADc,CAAhB,CAHA,CAMA;;AACA,yBAAK,MAAMC,GAAX,IAAkBF,OAAlB,EAA2B;AACzB,4BAAM,CAACG,OAAD,EAAUC,OAAV,IAAqBF,GAAG,CAC3BG,IADwB,GAExBrE,OAFwB,CAEhB,MAFgB,EAER,GAFQ,EAGxBA,OAHwB,CAGhB,IAHgB,EAGV,EAHU,EAIxBsE,KAJwB,CAIlB,GAJkB,CAA3B;AAKA3G,sBAAAA,WAAW,CAACkC,SAAD,CAAX,CAAuBsE,OAAvB,IAAkCC,OAAO,CAACC,IAAR,EAAlC;AACD;AACF,mBArBc,CAsBf;;;AACA,sBAAIP,KAAK,KAAKN,UAAU,CAACC,MAAX,GAAoB,CAAlC,EAAqChB,OAAO;AAC7C,iBA3BH,EA4BE,UAASS,KAAT,EAAgB;AACd,sBAAIY,KAAK,KAAKN,UAAU,CAACC,MAAX,GAAoB,CAAlC,EAAqChB,OAAO;AAC7C,iBA9BH;AAgCD,eAjCD;AAkCA;AACZ;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACW;AACF,WAjGM,EAiGJ8B,IAjGI,CAiGC7B,UAjGD,CAAP;AAkGD;;AACD,eAAOA,UAAU,EAAjB;AACD,OArQM,CAAP;AAsQD;;;4CAEuB5E,G,EAAK;AAC3B,UAAI0G,WAAW,GAAG1G,GAAG,CAACwG,KAAJ,CAAU,aAAV,CAAlB;AACA,UAAIG,kBAAJ,EAAwBC,kBAAxB,EAA4CC,YAA5C,EAA0DC,YAA1D;AACAJ,MAAAA,WAAW,CAACK,MAAZ,CAAmB,CAAnB,EAAsB,CAAtB;AACAL,MAAAA,WAAW,GAAGA,WAAW,CAAC9H,GAAZ,CAAgBoI,aAAa,IAAI;AAC7C;AACA,YAAIA,aAAa,CAACrF,QAAd,CAAuB,YAAvB,CAAJ,EAA0C;AACxC;AACAkF,UAAAA,YAAY,GAAGG,aAAa,CAACb,KAAd,CACb,gEADa,CAAf;AAGAW,UAAAA,YAAY,GAAGE,aAAa,CAACb,KAAd,CACb,gEADa,CAAf;;AAIA,cAAIU,YAAJ,EAAkB;AAChBA,YAAAA,YAAY,GAAGA,YAAY,CAAC,CAAD,CAA3B;AACD;;AAED,cAAIC,YAAJ,EAAkB;AAChBA,YAAAA,YAAY,GAAGA,YAAY,CAAC,CAAD,CAA3B;AACD;;AAED,gBAAMG,eAAe,GAAG,wDAAxB;AACA,gBAAMC,mBAAmB,GAAGF,aAAa,CACtCb,KADyB,CACnBc,eADmB,EACF,CADE,EAEzBT,KAFyB,CAEnB,GAFmB,CAA5B;AAGAG,UAAAA,kBAAkB,GAAG/I,KAAK,CAACuJ,WAAN,CAAkBD,mBAAmB,CAAC,CAAD,CAArC,CAArB;AACA,cAAIE,WAAW,GAAGF,mBAAmB,CAAC,CAAD,CAArC;AACAE,UAAAA,WAAW,GAAGA,WAAW,CAAClF,OAAZ,CAAoB,QAApB,EAA8B,EAA9B,EAAkCsE,KAAlC,CAAwC,IAAxC,CAAd;AACAI,UAAAA,kBAAkB,GAAGQ,WAAW,CAACxI,GAAZ,CAAgByI,MAAM,IACzCzJ,KAAK,CAACuJ,WAAN,CAAkBE,MAAlB,CADmB,CAArB;AAGD;;AAED,cAAMC,mBAAmB,GAAGN,aAAa,CAACb,KAAd,CAC1B,4CAD0B,EAE1B,CAF0B,CAA5B;AAGAa,QAAAA,aAAa,GAAGA,aAAa,CAAC9E,OAAd,CAAsB,QAAtB,EAAgC,EAAhC,CAAhB;AACA,cAAMqF,UAAU,GAAGP,aAAa,CAACR,KAAd,CAAoB,GAApB,CAAnB;;AAEA,YAAIe,UAAU,CAAC,CAAD,CAAV,KAAkB,SAAlB,IAA+BA,UAAU,CAAC,CAAD,CAAV,KAAkB,SAArD,EAAgE;AAC9DA,UAAAA,UAAU,CAAC,CAAD,CAAV,IAAiB,MAAjB;AACD;;AAED,eAAO;AACLC,UAAAA,cAAc,EAAE5J,KAAK,CAACuJ,WAAN,CAAkBI,UAAU,CAAC,CAAD,CAA5B,CADX;AAELE,UAAAA,cAAc,EAAEF,UAAU,CAAC,CAAD,CAFrB;AAGLV,UAAAA,YAHK;AAILC,UAAAA,YAJK;AAKL9G,UAAAA,GAAG,EAAEA,GAAG,CAACkC,OAAJ,CAAY,IAAZ,EAAkB,GAAlB,CALA;AAKwB;AAC7BoF,UAAAA,mBANK;AAOLX,UAAAA,kBAPK;AAQLC,UAAAA;AARK,SAAP;AAUD,OAnDa,CAAd;AAqDA,aAAOF,WAAP;AACD;;;iCAEYxD,I,EAAMxB,K,EAAO;AACxB,UAAIwB,IAAI,CAACvB,QAAL,CAAc,GAAd,CAAJ,EAAwB;AACtB;AACAuB,QAAAA,IAAI,GAAGA,IAAI,CAACpB,MAAL,CAAY,CAAZ,EAAeoB,IAAI,CAACwE,OAAL,CAAa,GAAb,CAAf,CAAP;AACD;;AACDxE,MAAAA,IAAI,GAAGA,IAAI,CAAChB,OAAL,CAAa,UAAb,EAAyB,EAAzB,EAA6BA,OAA7B,CAAqC,UAArC,EAAiD,EAAjD,CAAP;AACAgB,MAAAA,IAAI,GAAGA,IAAI,CAACqD,IAAL,GAAYoB,WAAZ,EAAP;AACA,YAAMC,KAAK,GAAG3J,WAAW,CAAC4J,GAAZ,CAAgB3E,IAAhB,CAAd;;AACA,UAAIxB,KAAK,KAAK,IAAV,IAAkBkG,KAAtB,EAA6B;AAC3B,eAAOA,KAAK,CAAClG,KAAD,EAAQ;AAAEoG,UAAAA,QAAQ,EAAE,KAAKC,SAAL,CAAe1G,OAAf,CAAuByG;AAAnC,SAAR,CAAZ;AACD;;AACD,aAAOpG,KAAP;AACD;;;gCAEW5B,G,EAAK;AACf,cAAQA,GAAG,CAACkI,IAAZ;AACE,aAAK,mBAAL;AAA0B;AACxB,gBAAIlI,GAAG,CAACmI,OAAJ,CAAYtG,QAAZ,CAAqB,+BAArB,CAAJ,EAA2D;AACzD,qBAAO,IAAI3D,eAAe,CAACkK,yBAApB,CAA8C;AACnDC,gBAAAA,MAAM,EAAErI;AAD2C,eAA9C,CAAP;AAGD;;AAED,gBAAIsI,MAAM,GAAG,EAAb,CAPwB,CASxB;;AACA,gBAAIjC,KAAK,GAAGrG,GAAG,CAACmI,OAAJ,CAAY9B,KAAZ,CAAkB,mBAAlB,CAAZ;;AACA,gBAAIA,KAAK,KAAK,IAAV,IAAkBA,KAAK,CAACR,MAAN,IAAgB,CAAtC,EAAyC;AACvCyC,cAAAA,MAAM,GAAGjC,KAAK,CAAC,CAAD,CAAL,CAASK,KAAT,CAAe,IAAf,CAAT;AACD,aAFD,MAEO;AACL;AACAL,cAAAA,KAAK,GAAGrG,GAAG,CAACmI,OAAJ,CAAY9B,KAAZ,CAAkB,gCAAlB,CAAR;;AACA,kBAAIA,KAAK,KAAK,IAAV,IAAkBA,KAAK,CAACR,MAAN,IAAgB,CAAtC,EAAyC;AACvCyC,gBAAAA,MAAM,GAAGjC,KAAK,CAAC,CAAD,CAAL,CACNK,KADM,CACA,IADA,EAEN5H,GAFM,CAEFyJ,eAAe,IAAIA,eAAe,CAAC7B,KAAhB,CAAsB,GAAtB,EAA2B,CAA3B,CAFjB,CAAT;AAGD;AACF;;AAED,kBAAM8B,MAAM,GAAG,EAAf;AACA,gBAAIL,OAAO,GAAG,kBAAd;;AAEA,iBAAK,MAAMnH,KAAX,IAAoBsH,MAApB,EAA4B;AAC1BE,cAAAA,MAAM,CAACzH,IAAP,CACE,IAAI7C,eAAe,CAACuK,mBAApB,CACE,KAAKC,+BAAL,CAAqC1H,KAArC,CADF,EAEE,kBAFF,EAEsB;AACpBA,cAAAA,KAHF,EAIE,KAAKX,QAAL,IAAiB,KAAKA,QAAL,CAAcW,KAAd,CAJnB,EAKE,KAAKX,QALP,EAME,YANF,CADF;AAUD;;AAED,gBAAI,KAAKV,KAAT,EAAgB;AACd/B,cAAAA,CAAC,CAAC0E,MAAF,CAAS,KAAK3C,KAAL,CAAWgJ,UAApB,EAAgClB,UAAU,IAAI;AAC5C,oBAAI7J,CAAC,CAACgL,OAAF,CAAUnB,UAAU,CAACa,MAArB,EAA6BA,MAA7B,KAAwC,CAAC,CAACb,UAAU,CAACoB,GAAzD,EAA8D;AAC5DV,kBAAAA,OAAO,GAAGV,UAAU,CAACoB,GAArB;AACA,yBAAO,KAAP;AACD;AACF,eALD;AAMD;;AAED,mBAAO,IAAI3K,eAAe,CAAC4K,qBAApB,CAA0C;AAC/CX,cAAAA,OAD+C;AAE/CK,cAAAA,MAF+C;AAG/CH,cAAAA,MAAM,EAAErI,GAHuC;AAI/CsI,cAAAA;AAJ+C,aAA1C,CAAP;AAMD;;AACD,aAAK,aAAL;AACE,iBAAO,IAAIpK,eAAe,CAAC6K,YAApB,CAAiC/I,GAAjC,CAAP;;AAEF;AACE,iBAAO,IAAI9B,eAAe,CAAC8K,aAApB,CAAkChJ,GAAlC,CAAP;AA5DJ;AA8DD;;;2CAEsBiJ,I,EAAM;AAC3B;AACA,aAAOlL,OAAO,CAACe,GAAR,CAAYmK,IAAI,CAACC,OAAL,EAAZ,EAA4BnK,IAAI,IAAI;AACzCA,QAAAA,IAAI,CAACuJ,MAAL,GAAc,EAAd;AACAvJ,QAAAA,IAAI,CAACoK,OAAL,GAAe,KAAf;AACApK,QAAAA,IAAI,CAACqK,MAAL,GAAc,CAAC,CAACrK,IAAI,CAACqK,MAArB;AACArK,QAAAA,IAAI,CAAC2I,cAAL,GAAsB3I,IAAI,CAACoC,IAA3B;AACA,eAAO,KAAKkI,GAAL,CAAU,uBAAsBtK,IAAI,CAACoC,IAAK,KAA1C,EAAgDwF,IAAhD,CAAqDP,OAAO,IAAI;AACrE,eAAK,MAAMmB,MAAX,IAAqBnB,OAArB,EAA8B;AAC5BrH,YAAAA,IAAI,CAACuJ,MAAL,CAAYf,MAAM,CAAC+B,KAAnB,IAA4B;AAC1B/G,cAAAA,SAAS,EAAEgF,MAAM,CAACpG,IADQ;AAE1B0E,cAAAA,MAAM,EAAE1C,SAFkB;AAG1BoG,cAAAA,KAAK,EAAEpG;AAHmB,aAA5B;AAKD;;AAED,iBAAOpE,IAAP;AACD,SAVM,CAAP;AAWD,OAhBM,CAAP;AAiBD;;;wCAEmB;AAClB,UACE,KAAKmB,GAAL,CAAS2B,QAAT,CAAkB,QAAlB,KACA,KAAK3B,GAAL,CAAS2B,QAAT,CAAkB,QAAlB,CADA,IAEA,KAAK3B,GAAL,CAAS2B,QAAT,CAAkB,UAAlB,CAFA,IAGA,KAAK3B,GAAL,CAAS2B,QAAT,CAAkB,aAAlB,CAJF,EAKE;AACA,eAAO,MAAP,CADA,CACe;AAChB;;AACD,UACE,KAAKvB,aAAL,MACA,KAAKyD,aAAL,EADA,IAEA,KAAKyF,iBAAL,EAFA,IAGA,KAAKtJ,GAAL,CAASuJ,WAAT,GAAuB5H,QAAvB,CAAgC,yBAAyB4H,WAAzB,EAAhC,CAHA,IAIA,KAAKlI,OAAL,CAAa6B,IAAb,KAAsBnF,UAAU,CAACyF,UALnC,EAME;AACA,eAAO,KAAP;AACD;;AACD,aAAO,KAAP;AACD;;;mCACczD,O,EAAS;AACtB,UAAI,CAACA,OAAO,CAAC+F,IAAb,EAAmB,OAAO,EAAP;AACnB,UAAI,WAAW/F,OAAX,IAAsB,YAAYA,OAAO,CAAC+F,IAA9C,EACE,OAAO/F,OAAO,CAACyJ,KAAR,IAAiBzJ,OAAO,CAAC+F,IAAR,CAAa2D,MAArC;AACF,UAAI,CAAC1J,OAAO,CAAC+F,IAAR,CAAajH,IAAlB,EAAwB,OAAOkB,OAAO,CAAC+F,IAAf;AACxB,YAAMiD,IAAI,GAAG,IAAInG,KAAJ,CAAU7C,OAAO,CAAC+F,IAAR,CAAaH,MAAvB,CAAb;;AACA,WAAK,IAAI/E,CAAC,GAAG,CAAb,EAAgBA,CAAC,GAAGb,OAAO,CAAC+F,IAAR,CAAaH,MAAjC,EAAyC/E,CAAC,EAA1C,EAA8C;AAC5CmI,QAAAA,IAAI,CAACnI,CAAD,CAAJ,GAAUb,OAAO,CAAC+F,IAAR,CAAajH,IAAb,CAAkB+B,CAAlB,CAAV;AACD;;AACD,aAAOmI,IAAP;AACD;;;yCAzqB2B/I,G,EAAK0J,M,EAAQzF,O,EAAS;AAChD,UAAI0F,SAAJ;;AACA,UAAI/G,KAAK,CAACC,OAAN,CAAc6G,MAAd,CAAJ,EAA2B;AACzBC,QAAAA,SAAS,GAAG,EAAZ;AACAD,QAAAA,MAAM,CAAC3D,OAAP,CAAe,CAAC6D,CAAD,EAAIhJ,CAAJ,KAAU;AACvB+I,UAAAA,SAAS,CAAE,IAAG/I,CAAC,GAAG,CAAE,EAAX,CAAT,GAAyBgJ,CAAzB;AACD,SAFD;AAGA5J,QAAAA,GAAG,GAAGlC,aAAa,CAACiG,oBAAd,CAAmC/D,GAAnC,EAAwC0J,MAAxC,EAAgDzF,OAAhD,EAAyD;AAC7D4F,UAAAA,gBAAgB,EAAE;AAD2C,SAAzD,EAEH,CAFG,CAAN;AAGD,OARD,MAQO;AACLF,QAAAA,SAAS,GAAG,EAAZ;;AACA,YAAI,OAAOD,MAAP,KAAkB,QAAtB,EAAgC;AAC9B,eAAK,MAAMI,CAAX,IAAgBpL,MAAM,CAACM,IAAP,CAAY0K,MAAZ,CAAhB,EAAqC;AACnCC,YAAAA,SAAS,CAAE,IAAGG,CAAE,EAAP,CAAT,GAAqBJ,MAAM,CAACI,CAAD,CAA3B;AACD;AACF;;AACD9J,QAAAA,GAAG,GAAGlC,aAAa,CAACiG,oBAAd,CAAmC/D,GAAnC,EAAwC0J,MAAxC,EAAgDzF,OAAhD,EAAyD;AAC7D4F,UAAAA,gBAAgB,EAAE;AAD2C,SAAzD,EAEH,CAFG,CAAN;AAGD;;AACD,aAAO,CAAC7J,GAAD,EAAM2J,SAAN,CAAP;AACD;;;;EAnCiB7L,a;;AAyrBpBiM,MAAM,CAACC,OAAP,GAAiB9K,KAAjB;AACA6K,MAAM,CAACC,OAAP,CAAe9K,KAAf,GAAuBA,KAAvB;AACA6K,MAAM,CAACC,OAAP,CAAeC,OAAf,GAAyB/K,KAAzB","sourcesContent":["\"use strict\";\n\nconst _ = require(\"lodash\");\nconst Utils = require(\"../../utils\");\nconst Promise = require(\"../../promise\");\nconst AbstractQuery = require(\"../abstract/query\");\nconst QueryTypes = require(\"../../query-types\");\nconst sequelizeErrors = require(\"../../errors\");\nconst parserStore = require(\"../parserStore\")(\"sqlite\");\nconst { logger } = require(\"../../utils/logger\");\n\nconst debug = logger.debugContext(\"sql:sqlite\");\nconst getMethods = obj => {\n  let properties = new Set();\n  let currentObj = obj;\n  do {\n    Object.getOwnPropertyNames(currentObj).map(item => properties.add(item));\n  } while ((currentObj = Object.getPrototypeOf(currentObj)));\n  return [...properties.keys()].filter(item => typeof obj[item] === \"function\");\n};\nclass Query extends AbstractQuery {\n  getInsertIdField() {\n    return \"lastID\";\n  }\n\n  /**\n   * rewrite query with parameters.\n   *\n   * @param {string} sql\n   * @param {Array|Object} values\n   * @param {string} dialect\n   * @private\n   */\n  static formatBindParameters(sql, values, dialect) {\n    let bindParam;\n    if (Array.isArray(values)) {\n      bindParam = {};\n      values.forEach((v, i) => {\n        bindParam[`$${i + 1}`] = v;\n      });\n      sql = AbstractQuery.formatBindParameters(sql, values, dialect, {\n        skipValueReplace: true\n      })[0];\n    } else {\n      bindParam = {};\n      if (typeof values === \"object\") {\n        for (const k of Object.keys(values)) {\n          bindParam[`$${k}`] = values[k];\n        }\n      }\n      sql = AbstractQuery.formatBindParameters(sql, values, dialect, {\n        skipValueReplace: true\n      })[0];\n    }\n    return [sql, bindParam];\n  }\n\n  _collectModels(include, prefix) {\n    const ret = {};\n\n    if (include) {\n      for (const _include of include) {\n        let key;\n        if (!prefix) {\n          key = _include.as;\n        } else {\n          key = `${prefix}.${_include.as}`;\n        }\n        ret[key] = _include.model;\n\n        if (_include.include) {\n          _.merge(ret, this._collectModels(_include.include, key));\n        }\n      }\n    }\n\n    return ret;\n  }\n\n  _handleQueryResponse(metaData, columnTypes, err, results) {\n    if (err) {\n      err.sql = this.sql;\n      throw this.formatError(err);\n    }\n    let result = this.instance;\n    // add the inserted row id to the instance\n    if (this.isInsertQuery(results, metaData)) {\n      this.handleInsertQuery(results, metaData);\n      if (!this.instance) {\n        // handle bulkCreate AI primary key\n        if (\n          /*  metaData.constructor.name === \"Statement\" && */\n          this.model &&\n          this.model.autoIncrementAttribute &&\n          this.model.autoIncrementAttribute ===\n            this.model.primaryKeyAttribute &&\n          this.model.rawAttributes[this.model.primaryKeyAttribute]\n        ) {\n          const startId =\n            metaData[this.getInsertIdField()] - metaData.changes + 1;\n\n          result = [];\n          for (let i = startId; i < startId + metaData.changes; i++) {\n            result.push({\n              [this.model.rawAttributes[this.model.primaryKeyAttribute]\n                .field]: i\n            });\n          }\n        } else {\n          result = metaData[this.getInsertIdField()];\n        }\n      }\n    }\n\n    if (this.isShowTablesQuery()) {\n      return results.map(row => row.name);\n    }\n    if (this.isShowConstraintsQuery()) {\n      result = results;\n      if (results && results[0] && results[0].sql) {\n        result = this.parseConstraintsFromSql(results[0].sql);\n      }\n      return result;\n    }\n    if (this.isSelectQuery()) {\n      if (this.options.raw) {\n        return this.handleSelectQuery(results);\n      }\n      // This is a map of prefix strings to models, e.g. user.projects -> Project model\n      const prefixes = this._collectModels(this.options.include);\n\n      results = results.map(result => {\n        return _.mapValues(result, (value, name) => {\n          let model;\n          if (name.includes(\".\")) {\n            const lastind = name.lastIndexOf(\".\");\n\n            model = prefixes[name.substr(0, lastind)];\n\n            name = name.substr(lastind + 1);\n          } else {\n            model = this.options.model;\n          }\n\n          const tableName = model\n            .getTableName()\n            .toString()\n            .replace(/`/g, \"\");\n          const tableTypes = columnTypes[tableName] || {};\n\n          if (tableTypes && !(name in tableTypes)) {\n            // The column is aliased\n            _.forOwn(model.rawAttributes, (attribute, key) => {\n              if (name === key && attribute.field) {\n                name = attribute.field;\n                return false;\n              }\n            });\n          }\n\n          return Object.prototype.hasOwnProperty.call(tableTypes, name)\n            ? this.applyParsers(tableTypes[name], value)\n            : value;\n        });\n      });\n\n      return this.handleSelectQuery(results);\n    }\n    if (this.isShowOrDescribeQuery()) {\n      return results;\n    }\n    if (this.sql.includes(\"PRAGMA INDEX_LIST\")) {\n      return this.handleShowIndexesQuery(results);\n    }\n    if (this.sql.includes(\"PRAGMA INDEX_INFO\")) {\n      return results;\n    }\n    if (this.sql.includes(\"PRAGMA TABLE_INFO\")) {\n      // this is the sqlite way of getting the metadata of a table\n      result = {};\n\n      if (Array.isArray(results)) {\n        let defaultValue;\n        for (const _result of results) {\n          if (_result.dflt_value === null) {\n            // Column schema omits any \"DEFAULT ...\"\n            defaultValue = undefined;\n          } else if (_result.dflt_value === \"NULL\") {\n            // Column schema is a \"DEFAULT NULL\"\n            defaultValue = null;\n          } else {\n            defaultValue = _result.dflt_value;\n          }\n\n          result[_result.name] = {\n            type: _result.type,\n            allowNull: _result.notnull === 0,\n            defaultValue,\n            primaryKey: _result.pk !== 0\n          };\n\n          if (result[_result.name].type === \"TINYINT(1)\") {\n            result[_result.name].defaultValue = { \"0\": false, \"1\": true }[\n              result[_result.name].defaultValue\n            ];\n          }\n\n          if (typeof result[_result.name].defaultValue === \"string\") {\n            result[_result.name].defaultValue = result[\n              _result.name\n            ].defaultValue.replace(/'/g, \"\");\n          }\n        }\n      }\n\n      return result;\n    }\n    if (this.sql.includes(\"PRAGMA foreign_keys;\")) {\n      return results[0];\n    }\n    if (this.sql.includes(\"PRAGMA foreign_keys\")) {\n      return results;\n    }\n    if (this.sql.includes(\"PRAGMA foreign_key_list\")) {\n      return results;\n    }\n    if (\n      [QueryTypes.BULKUPDATE, QueryTypes.BULKDELETE].includes(this.options.type)\n    ) {\n      return metaData.changes;\n    }\n    if (this.options.type === QueryTypes.UPSERT) {\n      return undefined;\n    }\n    if (this.options.type === QueryTypes.VERSION) {\n      return results[0].version;\n    }\n    if (this.options.type === QueryTypes.RAW) {\n      return [results, metaData];\n    }\n    if (this.isUpdateQuery() || this.isInsertQuery()) {\n      return [result, metaData.changes];\n    }\n    return result;\n  }\n  // websql : polyfill foreign key https://justatheory.com/2004/11/sqlite-foreign-key-triggers/\n  run(sql, parameters) {\n    // exec does not support bind parameter\n    this.sql = AbstractQuery.formatBindParameters(\n      sql,\n      this.options.bind,\n      this.options.dialect || \"sqlite\",\n      { skipUnescape: false }\n    )[0];\n    const method = this.getDatabaseMethod();\n    const complete = this._logQuery(this.sql, debug, parameters);\n    const query = this;\n    const self = this;\n    const conn = this.connection;\n\n    return new Promise(resolve => {\n      const columnTypes = {};\n      // eslint-disable-next-line\n      const executeSql = () => {\n        if (sql.startsWith(\"-- \")) {\n          return resolve();\n        }\n        resolve(\n          new Promise((resolve, reject) => {\n            if (method === \"exec\") {\n              if (typeof conn.exec === \"function\") {\n                conn.exec(\n                  [{ sql: self.sql, args: [] }],\n                  false,\n                  (executionError, results) => {\n                    try {\n                      complete();\n                      // TODO: Check return PRAGMA INDEX_LIST and INDEX_INFO\n                      results = query.convertToArray(results[0]);\n                      // `this` is passed from sqlite, we have no control over this.\n                      // eslint-disable-next-line no-invalid-this\n                      resolve(\n                        query._handleQueryResponse(\n                          self,\n                          columnTypes,\n                          executionError,\n                          results\n                        )\n                      );\n                      return;\n                    } catch (error) {\n                      reject(error);\n                    }\n                  }\n                );\n              } else {\n                resolve();\n              }\n            } else {\n              var successCallback = function(results) {\n                try {\n                  complete();\n                  // `self` is passed from sqlite, we have no control over this.\n                  // eslint-disable-next-line no-invalid-this\n                  if (results.rowsAffected) {\n                    try {\n                      self[self.getInsertIdField()] = results.insertId;\n                    } catch (e) {\n                      delete self[self.getInsertIdField()];\n                    }\n                  }\n                  self.changes = results.rowsAffected;\n                  results = query.convertToArray(results);\n                  resolve(\n                    query._handleQueryResponse(\n                      self,\n                      columnTypes,\n                      undefined,\n                      results\n                    )\n                  );\n                  return;\n                } catch (error) {\n                  debug(error);\n                  reject(error);\n                }\n              };\n              // eslint-disable-next-line\n              var errorCallback = function(err) {\n                try {\n                  complete();\n                  // `self` is passed from sqlite, we have no control over this.\n                  // eslint-disable-next-line no-invalid-this\n                  resolve(query._handleQueryResponse(self, columnTypes, err));\n                } catch (error) {\n                  reject(error);\n                }\n              };\n              if (typeof conn.exec === \"function\") {\n                parameters = parameters || [];\n              } else parameters = [];\n              conn.executeSql(\n                self.sql,\n                parameters,\n                successCallback,\n                errorCallback\n              );\n              /*conn.transaction(function(t) {\n                // cannot use arrow function here because the function is bound to the statement\n                // eslint-disable-next-line\n                var successCallback = function(_, results) {\n                  try {\n                    complete();\n                    // `self` is passed from sqlite, we have no control over this.\n                    // eslint-disable-next-line no-invalid-this\n                    if (results.rowsAffected) {\n                      try {\n                        self[self.getInsertIdField()] = results.insertId;\n                      } catch (e) {\n                        delete self[self.getInsertIdField()];\n                      }\n                    }\n                    self.changes = results.rowsAffected;\n                    results = query.convertToArray(results);\n                    resolve(\n                      query._handleQueryResponse(\n                        self,\n                        columnTypes,\n                        undefined,\n                        results\n                      )\n                    );\n                    return;\n                  } catch (error) {\n                    debug(error);\n                    reject(error);\n                  }\n                };\n                // eslint-disable-next-line\n                var errorCallback = function(_, err) {\n                  try {\n                    complete();\n                    // `self` is passed from sqlite, we have no control over this.\n                    // eslint-disable-next-line no-invalid-this\n                    resolve(query._handleQueryResponse(self, columnTypes, err));\n                  } catch (error) {\n                    reject(error);\n                  }\n                };\n                if (typeof conn.exec === \"function\") {\n                  parameters = parameters || [];\n                } else parameters = [];\n                t.executeSql(\n                  self.sql,\n                  parameters,\n                  successCallback,\n                  errorCallback\n                );\n              });*/\n            }\n          })\n        );\n        return null;\n      };\n\n      if (method === \"all\") {\n        let tableNames = [];\n        if (this.options && this.options.tableNames) {\n          tableNames = this.options.tableNames;\n        } else if (/FROM `(.*?)`/i.exec(this.sql)) {\n          tableNames.push(/FROM `(.*?)`/i.exec(this.sql)[1]);\n        }\n\n        // If we already have the metadata for the table, there's no need to ask for it again\n        tableNames = tableNames.filter(\n          tableName =>\n            !(tableName in columnTypes) && tableName !== \"sqlite_master\"\n        );\n        if (!tableNames.length) {\n          return executeSql();\n        }\n        return new Promise(resolve => {\n          if (typeof conn.exec === \"function\") {\n            const sqlCommands = tableNames.map(tableName => {\n              tableName = tableName.replace(/`/g, \"\");\n              columnTypes[tableName] = {};\n              return [`PRAGMA table_info(\\`${tableName}\\`)`, tableName];\n            });\n            conn.exec(\n              sqlCommands.map(sqlCmd => ({\n                sql: sqlCmd[0],\n                args: []\n              })),\n              false,\n              (err, results) => {\n                if (!err) {\n                  for (let i = 0; i < sqlCommands.length; i++) {\n                    const tableName = sqlCommands[i][1];\n                    for (const result of results[i].rows) {\n                      columnTypes[tableName][result.name] = result.type;\n                    }\n                  }\n                }\n                resolve();\n              }\n            );\n          } else {\n            tableNames.forEach((tableName, index) => {\n              conn.executeSql(\n                `SELECT sql FROM sqlite_master WHERE tbl_name='${tableName}' and type='table'`,\n                [],\n                function(result) {\n                  const table = result.rows.item(0);\n                  if (\n                    typeof table === \"object\" &&\n                    \"sql\" in table &&\n                    typeof table.sql === \"string\"\n                  ) {\n                    columnTypes[tableName] = {};\n                    //match column name with data types\n                    const columns = table.sql.match(\n                      /(`\\w+`)((\\s([A-Z]+)((\\(\\d+\\)))?))/g\n                    );\n                    // split column names with data type\n                    for (const col of columns) {\n                      const [colName, colType] = col\n                        .trim()\n                        .replace(/\\s+/g, \" \")\n                        .replace(/`/g, \"\")\n                        .split(\" \");\n                      columnTypes[tableName][colName] = colType.trim();\n                    }\n                  }\n                  //console.log(columnTypes)\n                  if (index === tableNames.length - 1) resolve();\n                },\n                function(error) {\n                  if (index === tableNames.length - 1) resolve();\n                }\n              );\n            });\n            /*conn.transaction(function(t) {\n              tableNames.forEach((tableName, index) => {\n                t.executeSql(\n                  `SELECT sql FROM sqlite_master WHERE tbl_name='${tableName}' and type='table'`,\n                  [],\n                  function(_, result) {\n                    const table = result.rows.item(0);\n                    if (\n                      typeof table === \"object\" &&\n                      \"sql\" in table &&\n                      typeof table.sql === \"string\"\n                    ) {\n                      columnTypes[tableName] = {};\n                      //match column name with data types\n                      const columns = table.sql.match(\n                        /(`\\w+`)((\\s([A-Z]+)((\\(\\d+\\)))?))/g\n                      );\n                      // split column names with data type\n                      for (const col of columns) {\n                        const [colName, colType] = col\n                          .trim()\n                          .replace(/\\s+/g, \" \")\n                          .replace(/`/g, \"\")\n                          .split(\" \");\n                        columnTypes[tableName][colName] = colType.trim();\n                      }\n                    }\n                    //console.log(columnTypes)\n                    if (index === tableNames.length - 1) resolve();\n                  },\n                  function(_, error) {\n                    if (index === tableNames.length - 1) resolve();\n                  }\n                );\n              });\n            });*/\n          }\n        }).then(executeSql);\n      }\n      return executeSql();\n    });\n  }\n\n  parseConstraintsFromSql(sql) {\n    let constraints = sql.split(\"CONSTRAINT \");\n    let referenceTableName, referenceTableKeys, updateAction, deleteAction;\n    constraints.splice(0, 1);\n    constraints = constraints.map(constraintSql => {\n      //Parse foreign key snippets\n      if (constraintSql.includes(\"REFERENCES\")) {\n        //Parse out the constraint condition form sql string\n        updateAction = constraintSql.match(\n          /ON UPDATE (CASCADE|SET NULL|RESTRICT|NO ACTION|SET DEFAULT){1}/\n        );\n        deleteAction = constraintSql.match(\n          /ON DELETE (CASCADE|SET NULL|RESTRICT|NO ACTION|SET DEFAULT){1}/\n        );\n\n        if (updateAction) {\n          updateAction = updateAction[1];\n        }\n\n        if (deleteAction) {\n          deleteAction = deleteAction[1];\n        }\n\n        const referencesRegex = /REFERENCES.+\\((?:[^)(]+|\\((?:[^)(]+|\\([^)(]*\\))*\\))*\\)/;\n        const referenceConditions = constraintSql\n          .match(referencesRegex)[0]\n          .split(\" \");\n        referenceTableName = Utils.removeTicks(referenceConditions[1]);\n        let columnNames = referenceConditions[2];\n        columnNames = columnNames.replace(/\\(|\\)/g, \"\").split(\", \");\n        referenceTableKeys = columnNames.map(column =>\n          Utils.removeTicks(column)\n        );\n      }\n\n      const constraintCondition = constraintSql.match(\n        /\\((?:[^)(]+|\\((?:[^)(]+|\\([^)(]*\\))*\\))*\\)/\n      )[0];\n      constraintSql = constraintSql.replace(/\\(.+\\)/, \"\");\n      const constraint = constraintSql.split(\" \");\n\n      if (constraint[1] === \"PRIMARY\" || constraint[1] === \"FOREIGN\") {\n        constraint[1] += \" KEY\";\n      }\n\n      return {\n        constraintName: Utils.removeTicks(constraint[0]),\n        constraintType: constraint[1],\n        updateAction,\n        deleteAction,\n        sql: sql.replace(/\"/g, \"`\"), //Sqlite returns double quotes for table name\n        constraintCondition,\n        referenceTableName,\n        referenceTableKeys\n      };\n    });\n\n    return constraints;\n  }\n\n  applyParsers(type, value) {\n    if (type.includes(\"(\")) {\n      // Remove the length part\n      type = type.substr(0, type.indexOf(\"(\"));\n    }\n    type = type.replace(\"UNSIGNED\", \"\").replace(\"ZEROFILL\", \"\");\n    type = type.trim().toUpperCase();\n    const parse = parserStore.get(type);\n    if (value !== null && parse) {\n      return parse(value, { timezone: this.sequelize.options.timezone });\n    }\n    return value;\n  }\n\n  formatError(err) {\n    switch (err.code) {\n      case \"SQLITE_CONSTRAINT\": {\n        if (err.message.includes(\"FOREIGN KEY constraint failed\")) {\n          return new sequelizeErrors.ForeignKeyConstraintError({\n            parent: err\n          });\n        }\n\n        let fields = [];\n\n        // Sqlite pre 2.2 behavior - Error: SQLITE_CONSTRAINT: columns x, y are not unique\n        let match = err.message.match(/columns (.*?) are/);\n        if (match !== null && match.length >= 2) {\n          fields = match[1].split(\", \");\n        } else {\n          // Sqlite post 2.2 behavior - Error: SQLITE_CONSTRAINT: UNIQUE constraint failed: table.x, table.y\n          match = err.message.match(/UNIQUE constraint failed: (.*)/);\n          if (match !== null && match.length >= 2) {\n            fields = match[1]\n              .split(\", \")\n              .map(columnWithTable => columnWithTable.split(\".\")[1]);\n          }\n        }\n\n        const errors = [];\n        let message = \"Validation error\";\n\n        for (const field of fields) {\n          errors.push(\n            new sequelizeErrors.ValidationErrorItem(\n              this.getUniqueConstraintErrorMessage(field),\n              \"unique violation\", // sequelizeErrors.ValidationErrorItem.Origins.DB,\n              field,\n              this.instance && this.instance[field],\n              this.instance,\n              \"not_unique\"\n            )\n          );\n        }\n\n        if (this.model) {\n          _.forOwn(this.model.uniqueKeys, constraint => {\n            if (_.isEqual(constraint.fields, fields) && !!constraint.msg) {\n              message = constraint.msg;\n              return false;\n            }\n          });\n        }\n\n        return new sequelizeErrors.UniqueConstraintError({\n          message,\n          errors,\n          parent: err,\n          fields\n        });\n      }\n      case \"SQLITE_BUSY\":\n        return new sequelizeErrors.TimeoutError(err);\n\n      default:\n        return new sequelizeErrors.DatabaseError(err);\n    }\n  }\n\n  handleShowIndexesQuery(data) {\n    // Sqlite returns indexes so the one that was defined last is returned first. Lets reverse that!\n    return Promise.map(data.reverse(), item => {\n      item.fields = [];\n      item.primary = false;\n      item.unique = !!item.unique;\n      item.constraintName = item.name;\n      return this.run(`PRAGMA INDEX_INFO(\\`${item.name}\\`)`).then(columns => {\n        for (const column of columns) {\n          item.fields[column.seqno] = {\n            attribute: column.name,\n            length: undefined,\n            order: undefined\n          };\n        }\n\n        return item;\n      });\n    });\n  }\n\n  getDatabaseMethod() {\n    if (\n      this.sql.includes(\"PRAGMA\") ||\n      this.sql.includes(\"COMMIT\") ||\n      this.sql.includes(\"ROLLBACK\") ||\n      this.sql.includes(\"TRANSACTION\")\n    ) {\n      return \"exec\"; // Needed to run no-op transaction\n    }\n    if (\n      this.isInsertQuery() ||\n      this.isUpdateQuery() ||\n      this.isBulkUpdateQuery() ||\n      this.sql.toLowerCase().includes(\"CREATE TEMPORARY TABLE\".toLowerCase()) ||\n      this.options.type === QueryTypes.BULKDELETE\n    ) {\n      return \"run\";\n    }\n    return \"all\";\n  }\n  convertToArray(results) {\n    if (!results.rows) return [];\n    if (\"array\" in results || \"_array\" in results.rows)\n      return results.array || results.rows._array;\n    if (!results.rows.item) return results.rows;\n    const data = new Array(results.rows.length);\n    for (let i = 0; i < results.rows.length; i++) {\n      data[i] = results.rows.item(i);\n    }\n    return data;\n  }\n}\n\nmodule.exports = Query;\nmodule.exports.Query = Query;\nmodule.exports.default = Query;\n"]} \ No newline at end of file +//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../lib/dialects/sqlite/query.js"],"names":["_","require","Utils","Promise","AbstractQuery","QueryTypes","sequelizeErrors","parserStore","logger","debug","debugContext","getMethods","obj","properties","Set","currentObj","Object","getOwnPropertyNames","map","item","add","getPrototypeOf","keys","filter","Query","include","prefix","ret","_include","key","as","model","merge","_collectModels","metaData","columnTypes","err","results","sql","formatError","result","instance","isInsertQuery","handleInsertQuery","autoIncrementAttribute","primaryKeyAttribute","rawAttributes","startId","getInsertIdField","changes","i","push","field","isShowTablesQuery","row","name","isShowConstraintsQuery","parseConstraintsFromSql","isSelectQuery","options","raw","handleSelectQuery","prefixes","mapValues","value","includes","lastind","lastIndexOf","substr","tableName","getTableName","toString","replace","tableTypes","forOwn","attribute","prototype","hasOwnProperty","call","applyParsers","isShowOrDescribeQuery","handleShowIndexesQuery","Array","isArray","defaultValue","_result","dflt_value","undefined","type","allowNull","notnull","primaryKey","pk","BULKUPDATE","BULKDELETE","UPSERT","VERSION","version","RAW","isUpdateQuery","parameters","formatBindParameters","bind","dialect","skipUnescape","method","getDatabaseMethod","complete","_logQuery","query","self","conn","connection","resolve","executeSql","startsWith","reject","exec","args","executionError","convertToArray","_handleQueryResponse","error","transaction","t","successCallback","rowsAffected","insertId","e","errorCallback","tableNames","length","sqlCommands","sqlCmd","rows","forEach","index","table","columns","match","col","colName","colType","trim","split","then","constraints","referenceTableName","referenceTableKeys","updateAction","deleteAction","splice","constraintSql","referencesRegex","referenceConditions","removeTicks","columnNames","column","constraintCondition","constraint","constraintName","constraintType","indexOf","toUpperCase","parse","get","timezone","sequelize","code","message","ForeignKeyConstraintError","parent","fields","columnWithTable","errors","ValidationErrorItem","getUniqueConstraintErrorMessage","uniqueKeys","isEqual","msg","UniqueConstraintError","TimeoutError","DatabaseError","data","reverse","primary","unique","run","seqno","order","isBulkUpdateQuery","toLowerCase","array","_array","values","bindParam","v","skipValueReplace","k","module","exports","default"],"mappings":"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","sourcesContent":["\"use strict\";\n\nconst _ = require(\"lodash\");\nconst Utils = require(\"../../utils\");\nconst Promise = require(\"../../promise\");\nconst AbstractQuery = require(\"../abstract/query\");\nconst QueryTypes = require(\"../../query-types\");\nconst sequelizeErrors = require(\"../../errors\");\nconst parserStore = require(\"../parserStore\")(\"sqlite\");\nconst { logger } = require(\"../../utils/logger\");\n\nconst debug = logger.debugContext(\"sql:sqlite\");\nconst getMethods = obj => {\n  let properties = new Set();\n  let currentObj = obj;\n  do {\n    Object.getOwnPropertyNames(currentObj).map(item => properties.add(item));\n  } while ((currentObj = Object.getPrototypeOf(currentObj)));\n  return [...properties.keys()].filter(item => typeof obj[item] === \"function\");\n};\nclass Query extends AbstractQuery {\n  getInsertIdField() {\n    return \"lastID\";\n  }\n\n  /**\n   * rewrite query with parameters.\n   *\n   * @param {string} sql\n   * @param {Array|Object} values\n   * @param {string} dialect\n   * @private\n   */\n  static formatBindParameters(sql, values, dialect) {\n    let bindParam;\n    if (Array.isArray(values)) {\n      bindParam = {};\n      values.forEach((v, i) => {\n        bindParam[`$${i + 1}`] = v;\n      });\n      sql = AbstractQuery.formatBindParameters(sql, values, dialect, {\n        skipValueReplace: true\n      })[0];\n    } else {\n      bindParam = {};\n      if (typeof values === \"object\") {\n        for (const k of Object.keys(values)) {\n          bindParam[`$${k}`] = values[k];\n        }\n      }\n      sql = AbstractQuery.formatBindParameters(sql, values, dialect, {\n        skipValueReplace: true\n      })[0];\n    }\n    return [sql, bindParam];\n  }\n\n  _collectModels(include, prefix) {\n    const ret = {};\n\n    if (include) {\n      for (const _include of include) {\n        let key;\n        if (!prefix) {\n          key = _include.as;\n        } else {\n          key = `${prefix}.${_include.as}`;\n        }\n        ret[key] = _include.model;\n\n        if (_include.include) {\n          _.merge(ret, this._collectModels(_include.include, key));\n        }\n      }\n    }\n\n    return ret;\n  }\n\n  _handleQueryResponse(metaData, columnTypes, err, results) {\n    if (err) {\n      err.sql = this.sql;\n      throw this.formatError(err);\n    }\n    let result = this.instance;\n    // add the inserted row id to the instance\n    if (this.isInsertQuery(results, metaData)) {\n      this.handleInsertQuery(results, metaData);\n      if (!this.instance) {\n        // handle bulkCreate AI primary key\n        if (\n          /*  metaData.constructor.name === \"Statement\" && */\n          this.model &&\n          this.model.autoIncrementAttribute &&\n          this.model.autoIncrementAttribute ===\n            this.model.primaryKeyAttribute &&\n          this.model.rawAttributes[this.model.primaryKeyAttribute]\n        ) {\n          const startId =\n            metaData[this.getInsertIdField()] - metaData.changes + 1;\n\n          result = [];\n          for (let i = startId; i < startId + metaData.changes; i++) {\n            result.push({\n              [this.model.rawAttributes[this.model.primaryKeyAttribute]\n                .field]: i\n            });\n          }\n        } else {\n          result = metaData[this.getInsertIdField()];\n        }\n      }\n    }\n\n    if (this.isShowTablesQuery()) {\n      return results.map(row => row.name);\n    }\n    if (this.isShowConstraintsQuery()) {\n      result = results;\n      if (results && results[0] && results[0].sql) {\n        result = this.parseConstraintsFromSql(results[0].sql);\n      }\n      return result;\n    }\n    if (this.isSelectQuery()) {\n      if (this.options.raw) {\n        return this.handleSelectQuery(results);\n      }\n      // This is a map of prefix strings to models, e.g. user.projects -> Project model\n      const prefixes = this._collectModels(this.options.include);\n\n      results = results.map(result => {\n        return _.mapValues(result, (value, name) => {\n          let model;\n          if (name.includes(\".\")) {\n            const lastind = name.lastIndexOf(\".\");\n\n            model = prefixes[name.substr(0, lastind)];\n\n            name = name.substr(lastind + 1);\n          } else {\n            model = this.options.model;\n          }\n\n          const tableName = model\n            .getTableName()\n            .toString()\n            .replace(/`/g, \"\");\n          const tableTypes = columnTypes[tableName] || {};\n\n          if (tableTypes && !(name in tableTypes)) {\n            // The column is aliased\n            _.forOwn(model.rawAttributes, (attribute, key) => {\n              if (name === key && attribute.field) {\n                name = attribute.field;\n                return false;\n              }\n            });\n          }\n\n          return Object.prototype.hasOwnProperty.call(tableTypes, name)\n            ? this.applyParsers(tableTypes[name], value)\n            : value;\n        });\n      });\n\n      return this.handleSelectQuery(results);\n    }\n    if (this.isShowOrDescribeQuery()) {\n      return results;\n    }\n    if (this.sql.includes(\"PRAGMA INDEX_LIST\")) {\n      return this.handleShowIndexesQuery(results);\n    }\n    if (this.sql.includes(\"PRAGMA INDEX_INFO\")) {\n      return results;\n    }\n    if (this.sql.includes(\"PRAGMA TABLE_INFO\")) {\n      // this is the sqlite way of getting the metadata of a table\n      result = {};\n\n      if (Array.isArray(results)) {\n        let defaultValue;\n        for (const _result of results) {\n          if (_result.dflt_value === null) {\n            // Column schema omits any \"DEFAULT ...\"\n            defaultValue = undefined;\n          } else if (_result.dflt_value === \"NULL\") {\n            // Column schema is a \"DEFAULT NULL\"\n            defaultValue = null;\n          } else {\n            defaultValue = _result.dflt_value;\n          }\n\n          result[_result.name] = {\n            type: _result.type,\n            allowNull: _result.notnull === 0,\n            defaultValue,\n            primaryKey: _result.pk !== 0\n          };\n\n          if (result[_result.name].type === \"TINYINT(1)\") {\n            result[_result.name].defaultValue = { \"0\": false, \"1\": true }[\n              result[_result.name].defaultValue\n            ];\n          }\n\n          if (typeof result[_result.name].defaultValue === \"string\") {\n            result[_result.name].defaultValue = result[\n              _result.name\n            ].defaultValue.replace(/'/g, \"\");\n          }\n        }\n      }\n\n      return result;\n    }\n    if (this.sql.includes(\"PRAGMA foreign_keys;\")) {\n      return results[0];\n    }\n    if (this.sql.includes(\"PRAGMA foreign_keys\")) {\n      return results;\n    }\n    if (this.sql.includes(\"PRAGMA foreign_key_list\")) {\n      return results;\n    }\n    if (\n      [QueryTypes.BULKUPDATE, QueryTypes.BULKDELETE].includes(this.options.type)\n    ) {\n      return metaData.changes;\n    }\n    if (this.options.type === QueryTypes.UPSERT) {\n      return undefined;\n    }\n    if (this.options.type === QueryTypes.VERSION) {\n      return results[0].version;\n    }\n    if (this.options.type === QueryTypes.RAW) {\n      return [results, metaData];\n    }\n    if (this.isUpdateQuery() || this.isInsertQuery()) {\n      return [result, metaData.changes];\n    }\n    return result;\n  }\n  // websql : polyfill foreign key https://justatheory.com/2004/11/sqlite-foreign-key-triggers/\n  run(sql, parameters) {\n    // exec does not support bind parameter\n    this.sql = AbstractQuery.formatBindParameters(\n      sql,\n      this.options.bind,\n      this.options.dialect || \"sqlite\",\n      { skipUnescape: false }\n    )[0];\n    const method = this.getDatabaseMethod();\n    const complete = this._logQuery(this.sql, debug, parameters);\n    const query = this;\n    const self = this;\n    const conn = this.connection;\n\n    return new Promise(resolve => {\n      const columnTypes = {};\n      // eslint-disable-next-line\n      const executeSql = () => {\n        if (sql.startsWith(\"-- \")) {\n          return resolve();\n        }\n        resolve(\n          new Promise((resolve, reject) => {\n            if (method === \"exec\") {\n              if (typeof conn.exec === \"function\") {\n                conn.exec(\n                  [{ sql: self.sql, args: [] }],\n                  false,\n                  (executionError, results) => {\n                    try {\n                      complete();\n                      // TODO: Check return PRAGMA INDEX_LIST and INDEX_INFO\n                      results = query.convertToArray(results[0]);\n                      // `this` is passed from sqlite, we have no control over this.\n                      // eslint-disable-next-line no-invalid-this\n                      resolve(\n                        query._handleQueryResponse(\n                          self,\n                          columnTypes,\n                          executionError,\n                          results\n                        )\n                      );\n                      return;\n                    } catch (error) {\n                      reject(error);\n                    }\n                  }\n                );\n              } else {\n                resolve();\n              }\n            } else {\n              conn.transaction(function(t) {\n                // cannot use arrow function here because the function is bound to the statement\n                // eslint-disable-next-line\n                var successCallback = function(_, results) {\n                  try {\n                    complete();\n                    // `self` is passed from sqlite, we have no control over this.\n                    // eslint-disable-next-line no-invalid-this\n                    if (results.rowsAffected) {\n                      try {\n                        self[self.getInsertIdField()] = results.insertId;\n                      } catch (e) {\n                        delete self[self.getInsertIdField()];\n                      }\n                    }\n                    self.changes = results.rowsAffected;\n                    results = query.convertToArray(results);\n                    resolve(\n                      query._handleQueryResponse(\n                        self,\n                        columnTypes,\n                        undefined,\n                        results\n                      )\n                    );\n                    return;\n                  } catch (error) {\n                    debug(error);\n                    reject(error);\n                  }\n                };\n                // eslint-disable-next-line\n                var errorCallback = function(_, err) {\n                  try {\n                    complete();\n                    // `self` is passed from sqlite, we have no control over this.\n                    // eslint-disable-next-line no-invalid-this\n                    resolve(query._handleQueryResponse(self, columnTypes, err));\n                  } catch (error) {\n                    reject(error);\n                  }\n                };\n                if (typeof conn.exec === \"function\") {\n                  parameters = parameters || [];\n                } else parameters = [];\n                t.executeSql(\n                  self.sql,\n                  parameters,\n                  successCallback,\n                  errorCallback\n                );\n              });\n            }\n          })\n        );\n        return null;\n      };\n\n      if (method === \"all\") {\n        let tableNames = [];\n        if (this.options && this.options.tableNames) {\n          tableNames = this.options.tableNames;\n        } else if (/FROM `(.*?)`/i.exec(this.sql)) {\n          tableNames.push(/FROM `(.*?)`/i.exec(this.sql)[1]);\n        }\n\n        // If we already have the metadata for the table, there's no need to ask for it again\n        tableNames = tableNames.filter(\n          tableName =>\n            !(tableName in columnTypes) && tableName !== \"sqlite_master\"\n        );\n        if (!tableNames.length) {\n          return executeSql();\n        }\n        return new Promise(resolve => {\n          if (typeof conn.exec === \"function\") {\n            const sqlCommands = tableNames.map(tableName => {\n              tableName = tableName.replace(/`/g, \"\");\n              columnTypes[tableName] = {};\n              return [`PRAGMA table_info(\\`${tableName}\\`)`, tableName];\n            });\n            conn.exec(\n              sqlCommands.map(sqlCmd => ({\n                sql: sqlCmd[0],\n                args: []\n              })),\n              false,\n              (err, results) => {\n                if (!err) {\n                  for (let i = 0; i < sqlCommands.length; i++) {\n                    const tableName = sqlCommands[i][1];\n                    for (const result of results[i].rows) {\n                      columnTypes[tableName][result.name] = result.type;\n                    }\n                  }\n                }\n                resolve();\n              }\n            );\n          } else {\n            conn.transaction(function(t) {\n              tableNames.forEach((tableName, index) => {\n                t.executeSql(\n                  `SELECT sql FROM sqlite_master WHERE tbl_name='${tableName}' and type='table'`,\n                  [],\n                  function(_, result) {\n                    const table = result.rows.item(0);\n                    if (\n                      typeof table === \"object\" &&\n                      \"sql\" in table &&\n                      typeof table.sql === \"string\"\n                    ) {\n                      columnTypes[tableName] = {};\n                      //match column name with data types\n                      const columns = table.sql.match(\n                        /(`\\w+`)((\\s([A-Z]+)((\\(\\d+\\)))?))/g\n                      );\n                      // split column names with data type\n                      for (const col of columns) {\n                        const [colName, colType] = col\n                          .trim()\n                          .replace(/\\s+/g, \" \")\n                          .replace(/`/g, \"\")\n                          .split(\" \");\n                        columnTypes[tableName][colName] = colType.trim();\n                      }\n                    }\n                    //console.log(columnTypes)\n                    if (index === tableNames.length - 1) resolve();\n                  },\n                  function(_, error) {\n                    if (index === tableNames.length - 1) resolve();\n                  }\n                );\n              });\n            });\n          }\n        }).then(executeSql);\n      }\n      return executeSql();\n    });\n  }\n\n  parseConstraintsFromSql(sql) {\n    let constraints = sql.split(\"CONSTRAINT \");\n    let referenceTableName, referenceTableKeys, updateAction, deleteAction;\n    constraints.splice(0, 1);\n    constraints = constraints.map(constraintSql => {\n      //Parse foreign key snippets\n      if (constraintSql.includes(\"REFERENCES\")) {\n        //Parse out the constraint condition form sql string\n        updateAction = constraintSql.match(\n          /ON UPDATE (CASCADE|SET NULL|RESTRICT|NO ACTION|SET DEFAULT){1}/\n        );\n        deleteAction = constraintSql.match(\n          /ON DELETE (CASCADE|SET NULL|RESTRICT|NO ACTION|SET DEFAULT){1}/\n        );\n\n        if (updateAction) {\n          updateAction = updateAction[1];\n        }\n\n        if (deleteAction) {\n          deleteAction = deleteAction[1];\n        }\n\n        const referencesRegex = /REFERENCES.+\\((?:[^)(]+|\\((?:[^)(]+|\\([^)(]*\\))*\\))*\\)/;\n        const referenceConditions = constraintSql\n          .match(referencesRegex)[0]\n          .split(\" \");\n        referenceTableName = Utils.removeTicks(referenceConditions[1]);\n        let columnNames = referenceConditions[2];\n        columnNames = columnNames.replace(/\\(|\\)/g, \"\").split(\", \");\n        referenceTableKeys = columnNames.map(column =>\n          Utils.removeTicks(column)\n        );\n      }\n\n      const constraintCondition = constraintSql.match(\n        /\\((?:[^)(]+|\\((?:[^)(]+|\\([^)(]*\\))*\\))*\\)/\n      )[0];\n      constraintSql = constraintSql.replace(/\\(.+\\)/, \"\");\n      const constraint = constraintSql.split(\" \");\n\n      if (constraint[1] === \"PRIMARY\" || constraint[1] === \"FOREIGN\") {\n        constraint[1] += \" KEY\";\n      }\n\n      return {\n        constraintName: Utils.removeTicks(constraint[0]),\n        constraintType: constraint[1],\n        updateAction,\n        deleteAction,\n        sql: sql.replace(/\"/g, \"`\"), //Sqlite returns double quotes for table name\n        constraintCondition,\n        referenceTableName,\n        referenceTableKeys\n      };\n    });\n\n    return constraints;\n  }\n\n  applyParsers(type, value) {\n    if (type.includes(\"(\")) {\n      // Remove the length part\n      type = type.substr(0, type.indexOf(\"(\"));\n    }\n    type = type.replace(\"UNSIGNED\", \"\").replace(\"ZEROFILL\", \"\");\n    type = type.trim().toUpperCase();\n    const parse = parserStore.get(type);\n    if (value !== null && parse) {\n      return parse(value, { timezone: this.sequelize.options.timezone });\n    }\n    return value;\n  }\n\n  formatError(err) {\n    switch (err.code) {\n      case \"SQLITE_CONSTRAINT\": {\n        if (err.message.includes(\"FOREIGN KEY constraint failed\")) {\n          return new sequelizeErrors.ForeignKeyConstraintError({\n            parent: err\n          });\n        }\n\n        let fields = [];\n\n        // Sqlite pre 2.2 behavior - Error: SQLITE_CONSTRAINT: columns x, y are not unique\n        let match = err.message.match(/columns (.*?) are/);\n        if (match !== null && match.length >= 2) {\n          fields = match[1].split(\", \");\n        } else {\n          // Sqlite post 2.2 behavior - Error: SQLITE_CONSTRAINT: UNIQUE constraint failed: table.x, table.y\n          match = err.message.match(/UNIQUE constraint failed: (.*)/);\n          if (match !== null && match.length >= 2) {\n            fields = match[1]\n              .split(\", \")\n              .map(columnWithTable => columnWithTable.split(\".\")[1]);\n          }\n        }\n\n        const errors = [];\n        let message = \"Validation error\";\n\n        for (const field of fields) {\n          errors.push(\n            new sequelizeErrors.ValidationErrorItem(\n              this.getUniqueConstraintErrorMessage(field),\n              \"unique violation\", // sequelizeErrors.ValidationErrorItem.Origins.DB,\n              field,\n              this.instance && this.instance[field],\n              this.instance,\n              \"not_unique\"\n            )\n          );\n        }\n\n        if (this.model) {\n          _.forOwn(this.model.uniqueKeys, constraint => {\n            if (_.isEqual(constraint.fields, fields) && !!constraint.msg) {\n              message = constraint.msg;\n              return false;\n            }\n          });\n        }\n\n        return new sequelizeErrors.UniqueConstraintError({\n          message,\n          errors,\n          parent: err,\n          fields\n        });\n      }\n      case \"SQLITE_BUSY\":\n        return new sequelizeErrors.TimeoutError(err);\n\n      default:\n        return new sequelizeErrors.DatabaseError(err);\n    }\n  }\n\n  handleShowIndexesQuery(data) {\n    // Sqlite returns indexes so the one that was defined last is returned first. Lets reverse that!\n    return Promise.map(data.reverse(), item => {\n      item.fields = [];\n      item.primary = false;\n      item.unique = !!item.unique;\n      item.constraintName = item.name;\n      return this.run(`PRAGMA INDEX_INFO(\\`${item.name}\\`)`).then(columns => {\n        for (const column of columns) {\n          item.fields[column.seqno] = {\n            attribute: column.name,\n            length: undefined,\n            order: undefined\n          };\n        }\n\n        return item;\n      });\n    });\n  }\n\n  getDatabaseMethod() {\n    if (\n      this.sql.includes(\"PRAGMA\") ||\n      this.sql.includes(\"COMMIT\") ||\n      this.sql.includes(\"ROLLBACK\") ||\n      this.sql.includes(\"TRANSACTION\")\n    ) {\n      return \"exec\"; // Needed to run no-op transaction\n    }\n    if (\n      this.isInsertQuery() ||\n      this.isUpdateQuery() ||\n      this.isBulkUpdateQuery() ||\n      this.sql.toLowerCase().includes(\"CREATE TEMPORARY TABLE\".toLowerCase()) ||\n      this.options.type === QueryTypes.BULKDELETE\n    ) {\n      return \"run\";\n    }\n    return \"all\";\n  }\n  convertToArray(results) {\n    if (!results.rows) return [];\n    if (\"array\" in results || \"_array\" in results.rows)\n      return results.array || results.rows._array;\n    if (!results.rows.item) return results.rows;\n    const data = new Array(results.rows.length);\n    for (let i = 0; i < results.rows.length; i++) {\n      data[i] = results.rows.item(i);\n    }\n    return data;\n  }\n}\n\nmodule.exports = Query;\nmodule.exports.Query = Query;\nmodule.exports.default = Query;\n"]} \ No newline at end of file diff --git a/lib/dialects/sqlite/query.js b/lib/dialects/sqlite/query.js index 6379a3e..2b2fe3f 100644 --- a/lib/dialects/sqlite/query.js +++ b/lib/dialects/sqlite/query.js @@ -297,55 +297,7 @@ class Query extends AbstractQuery { resolve(); } } else { - var successCallback = function(results) { - try { - complete(); - // `self` is passed from sqlite, we have no control over this. - // eslint-disable-next-line no-invalid-this - if (results.rowsAffected) { - try { - self[self.getInsertIdField()] = results.insertId; - } catch (e) { - delete self[self.getInsertIdField()]; - } - } - self.changes = results.rowsAffected; - results = query.convertToArray(results); - resolve( - query._handleQueryResponse( - self, - columnTypes, - undefined, - results - ) - ); - return; - } catch (error) { - debug(error); - reject(error); - } - }; - // eslint-disable-next-line - var errorCallback = function(err) { - try { - complete(); - // `self` is passed from sqlite, we have no control over this. - // eslint-disable-next-line no-invalid-this - resolve(query._handleQueryResponse(self, columnTypes, err)); - } catch (error) { - reject(error); - } - }; - if (typeof conn.exec === "function") { - parameters = parameters || []; - } else parameters = []; - conn.executeSql( - self.sql, - parameters, - successCallback, - errorCallback - ); - /*conn.transaction(function(t) { + conn.transaction(function(t) { // cannot use arrow function here because the function is bound to the statement // eslint-disable-next-line var successCallback = function(_, results) { @@ -396,7 +348,7 @@ class Query extends AbstractQuery { successCallback, errorCallback ); - });*/ + }); } }) ); @@ -445,41 +397,7 @@ class Query extends AbstractQuery { } ); } else { - tableNames.forEach((tableName, index) => { - conn.executeSql( - `SELECT sql FROM sqlite_master WHERE tbl_name='${tableName}' and type='table'`, - [], - function(result) { - const table = result.rows.item(0); - if ( - typeof table === "object" && - "sql" in table && - typeof table.sql === "string" - ) { - columnTypes[tableName] = {}; - //match column name with data types - const columns = table.sql.match( - /(`\w+`)((\s([A-Z]+)((\(\d+\)))?))/g - ); - // split column names with data type - for (const col of columns) { - const [colName, colType] = col - .trim() - .replace(/\s+/g, " ") - .replace(/`/g, "") - .split(" "); - columnTypes[tableName][colName] = colType.trim(); - } - } - //console.log(columnTypes) - if (index === tableNames.length - 1) resolve(); - }, - function(error) { - if (index === tableNames.length - 1) resolve(); - } - ); - }); - /*conn.transaction(function(t) { + conn.transaction(function(t) { tableNames.forEach((tableName, index) => { t.executeSql( `SELECT sql FROM sqlite_master WHERE tbl_name='${tableName}' and type='table'`, @@ -514,7 +432,7 @@ class Query extends AbstractQuery { } ); }); - });*/ + }); } }).then(executeSql); }