@uql/core 0.4.73 → 0.4.77

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -1,9 +1,9 @@
1
1
  import { QueryFilter, Query, Scalar, QueryFilterFieldOperatorMap, QuerySort, QueryPager, FieldKey, QueryProject, Type, QueryCriteria, QueryOptions, QueryDialect, QueryFilterOptions, QueryComparisonOptions, QueryFilterMap, QuerySearch, QueryProjectOptions } from '@uql/core/type';
2
2
  export declare abstract class AbstractSqlDialect implements QueryDialect {
3
- readonly beginTransactionCommand: string;
4
3
  readonly escapeIdChar: '`' | '"';
4
+ readonly beginTransactionCommand: string;
5
5
  readonly escapeIdRegex: RegExp;
6
- constructor(beginTransactionCommand: string, escapeIdChar: '`' | '"');
6
+ constructor(escapeIdChar: '`' | '"', beginTransactionCommand: string);
7
7
  criteria<E>(entity: Type<E>, qm: Query<E>, opts?: QueryOptions): string;
8
8
  projectFields<E>(entity: Type<E>, project: QueryProject<E>, opts?: QueryProjectOptions): string;
9
9
  projectRelations<E>(entity: Type<E>, project?: QueryProject<E>, { prefix }?: {
@@ -5,9 +5,9 @@ const sqlstring_1 = require("sqlstring");
5
5
  const entity_1 = require("@uql/core/entity");
6
6
  const util_1 = require("@uql/core/util");
7
7
  class AbstractSqlDialect {
8
- constructor(beginTransactionCommand, escapeIdChar) {
9
- this.beginTransactionCommand = beginTransactionCommand;
8
+ constructor(escapeIdChar, beginTransactionCommand) {
10
9
  this.escapeIdChar = escapeIdChar;
10
+ this.beginTransactionCommand = beginTransactionCommand;
11
11
  this.escapeIdRegex = RegExp(escapeIdChar, 'g');
12
12
  }
13
13
  criteria(entity, qm, opts = {}) {
@@ -163,10 +163,9 @@ class AbstractSqlDialect {
163
163
  return `${comparisonKey} = ${val.value}`;
164
164
  }
165
165
  if (key === '$text') {
166
- const meta = (0, entity_1.getMeta)(entity);
167
166
  const search = val;
168
167
  const fields = search.$fields.map((field) => { var _a, _b; return this.escapeId((_b = (_a = meta.fields[field]) === null || _a === void 0 ? void 0 : _a.name) !== null && _b !== void 0 ? _b : field); });
169
- return `MATCH(${fields.join(', ')}) AGAINST(${this.escape(search.$value)})`;
168
+ return `${this.escapeId(meta.name)} MATCH {${fields.join(' ')}} : ${this.escape(search.$value)}`;
170
169
  }
171
170
  if (key === '$and' || key === '$or' || key === '$not' || key === '$nor') {
172
171
  const negateOperatorMap = {
@@ -314,27 +313,26 @@ class AbstractSqlDialect {
314
313
  }
315
314
  insert(entity, payload) {
316
315
  const meta = (0, entity_1.getMeta)(entity);
317
- payload = (0, util_1.getPersistables)(meta, payload, 'onInsert');
318
- const keys = (0, util_1.getKeys)(payload[0]);
316
+ const records = (0, util_1.getPersistables)(meta, payload, 'onInsert');
317
+ const keys = (0, util_1.getKeys)(records[0]);
319
318
  const columns = keys.map((key) => this.escapeId(meta.fields[key].name));
320
- const values = payload.map((it) => keys.map((key) => this.escape(it[key])).join(', ')).join('), (');
319
+ const values = records.map((record) => keys.map((key) => this.escape(record[key])).join(', ')).join('), (');
321
320
  return `INSERT INTO ${this.escapeId(meta.name)} (${columns.join(', ')}) VALUES (${values})`;
322
321
  }
323
322
  update(entity, qm, payload, opts) {
324
323
  const meta = (0, entity_1.getMeta)(entity);
325
- payload = (0, util_1.getPersistable)(meta, payload, 'onUpdate');
326
- const values = (0, util_1.getKeys)(payload)
327
- .map((key) => `${this.escapeId(key)} = ${this.escape(payload[key])}`)
328
- .join(', ');
324
+ const record = (0, util_1.getPersistable)(meta, payload, 'onUpdate');
325
+ const keys = (0, util_1.getKeys)(record);
326
+ const entries = keys.map((key) => `${this.escapeId(key)} = ${this.escape(payload[key])}`).join(', ');
329
327
  const criteria = this.criteria(entity, qm, opts);
330
- return `UPDATE ${this.escapeId(meta.name)} SET ${values}${criteria}`;
328
+ return `UPDATE ${this.escapeId(meta.name)} SET ${entries}${criteria}`;
331
329
  }
332
330
  delete(entity, qm, opts = {}) {
333
331
  const meta = (0, entity_1.getMeta)(entity);
334
332
  if (opts.softDelete || opts.softDelete === undefined) {
335
333
  if (meta.softDelete) {
336
334
  const criteria = this.criteria(entity, qm, opts);
337
- const value = meta.fields[meta.softDelete].onDelete();
335
+ const value = (0, util_1.getFieldCallbackValue)(meta.fields[meta.softDelete].onDelete);
338
336
  return `UPDATE ${this.escapeId(meta.name)} SET ${this.escapeId(meta.softDelete)} = ${this.escape(value)}${criteria}`;
339
337
  }
340
338
  else if (opts.softDelete) {
@@ -360,8 +358,11 @@ class AbstractSqlDialect {
360
358
  return escaped + suffix;
361
359
  }
362
360
  escape(value) {
361
+ if (value instanceof util_1.Raw) {
362
+ return (0, util_1.getRawValue)({ value, dialect: this });
363
+ }
363
364
  return (0, sqlstring_1.escape)(value);
364
365
  }
365
366
  }
366
367
  exports.AbstractSqlDialect = AbstractSqlDialect;
367
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"abstractSqlDialect.js","sourceRoot":"","sources":["../../src/dialect/abstractSqlDialect.ts"],"names":[],"mappings":"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","sourcesContent":["import { escape } from 'sqlstring';\nimport { getMeta } from '@uql/core/entity';\nimport {\n  getPersistable,\n  getProjectRelationKeys,\n  getPersistables,\n  isProjectingRelations,\n  getKeys,\n  hasKeys,\n  buildSortMap,\n  flatObject,\n  getRawValue,\n  raw,\n  Raw,\n  getQueryFilterAsMap,\n} from '@uql/core/util';\n\nimport {\n  QueryFilter,\n  Query,\n  Scalar,\n  QueryFilterFieldOperatorMap,\n  QuerySort,\n  QueryPager,\n  QueryTextSearchOptions,\n  FieldKey,\n  QueryProject,\n  Type,\n  QueryCriteria,\n  QueryProjectArray,\n  QueryOptions,\n  QueryDialect,\n  QueryFilterOptions,\n  QueryComparisonOptions,\n  QueryFilterMap,\n  QuerySearch,\n  QueryProjectOptions,\n  QuerySortDirection,\n  QueryFilterLogical,\n} from '@uql/core/type';\n\nexport abstract class AbstractSqlDialect implements QueryDialect {\n  readonly escapeIdRegex: RegExp;\n\n  constructor(readonly beginTransactionCommand: string, readonly escapeIdChar: '`' | '\"') {\n    this.escapeIdRegex = RegExp(escapeIdChar, 'g');\n  }\n\n  criteria<E>(entity: Type<E>, qm: Query<E>, opts: QueryOptions = {}): string {\n    const meta = getMeta(entity);\n    const prefix = opts.prefix ?? (opts.autoPrefix || isProjectingRelations(meta, qm.$project)) ? meta.name : undefined;\n    const where = this.where<E>(entity, qm.$filter, { ...opts, prefix });\n    const group = this.group<E>(entity, qm.$group, { ...opts, prefix });\n    const having = this.where<E>(entity, qm.$having, { ...opts, prefix, clause: 'HAVING' });\n    const sort = this.sort<E>(entity, qm.$sort, { ...opts, prefix });\n    const pager = this.pager(qm);\n    return where + group + having + sort + pager;\n  }\n\n  projectFields<E>(entity: Type<E>, project: QueryProject<E>, opts: QueryProjectOptions = {}): string {\n    const meta = getMeta(entity);\n    const prefix = opts.prefix ? opts.prefix + '.' : '';\n    const escapedPrefix = this.escapeId(opts.prefix, true, true);\n\n    let fields: QueryProjectArray<E>;\n\n    if (project) {\n      if (Array.isArray(project)) {\n        fields = project;\n      } else {\n        const positiveProjectKeys = getKeys(project).filter((key) => project[key]);\n        fields = positiveProjectKeys.length\n          ? positiveProjectKeys.map((key) => {\n              const val = project[key];\n              if (val instanceof Raw) {\n                return raw(val.value, key);\n              }\n              return key as FieldKey<E>;\n            })\n          : (getKeys(meta.fields).filter((key) => !(key in project)) as FieldKey<E>[]);\n      }\n      fields = fields.filter((key) => key instanceof Raw || meta.fields[key as FieldKey<E>]);\n      if (!fields.length || (opts.prefix && !fields.includes(meta.id))) {\n        fields = [meta.id, ...fields];\n      }\n    } else {\n      fields = getKeys(meta.fields) as FieldKey<E>[];\n    }\n\n    return fields\n      .map((key) => {\n        if (key instanceof Raw) {\n          return getRawValue({\n            value: key,\n            dialect: this,\n            prefix,\n            escapedPrefix,\n            autoPrefixAlias: opts.autoPrefixAlias,\n          });\n        }\n\n        const field = meta.fields[key as FieldKey<E>];\n\n        if (field.virtual) {\n          return getRawValue({\n            value: field.virtual,\n            alias: key as string,\n            dialect: this,\n            prefix,\n            escapedPrefix,\n            autoPrefixAlias: opts.autoPrefixAlias,\n          });\n        }\n\n        const name = field?.name ?? (key as FieldKey<E>);\n        const fieldPath = `${escapedPrefix}${this.escapeId(name)}`;\n\n        return !opts.autoPrefixAlias && (name === key || !field) ? fieldPath : `${fieldPath} ${this.escapeId((prefix + key) as FieldKey<E>, true)}`;\n      })\n      .join(', ');\n  }\n\n  projectRelations<E>(entity: Type<E>, project: QueryProject<E> = {}, { prefix }: { prefix?: string } = {}): { fields: string; tables: string } {\n    const meta = getMeta(entity);\n    const relations = getProjectRelationKeys(meta, project);\n    const isProjectArray = Array.isArray(project);\n    let fields = '';\n    let tables = '';\n\n    for (const key of relations) {\n      const relOpts = meta.relations[key];\n\n      if (relOpts.cardinality === '1m' || relOpts.cardinality === 'mm') {\n        // '1m' and 'mm' should be resolved in a higher layer because they will need multiple queries\n        continue;\n      }\n\n      const joinRelAlias = prefix ? prefix + '.' + key : key;\n      const relEntity = relOpts.entity();\n      const relProject = project[key as string];\n      const relQuery = isProjectArray ? {} : Array.isArray(relProject) ? { $project: relProject } : relProject;\n\n      const relColumns = this.projectFields(relEntity, relQuery.$project, {\n        prefix: joinRelAlias,\n        autoPrefixAlias: true,\n      });\n\n      fields += ', ' + relColumns;\n\n      const { fields: subColumns, tables: subTables } = this.projectRelations(relEntity, relQuery.$project, {\n        prefix: joinRelAlias,\n      });\n\n      fields += subColumns;\n\n      const relMeta = getMeta(relEntity);\n      const relEntityName = this.escapeId(relMeta.name);\n      const relPath = prefix ? this.escapeId(prefix, true) : this.escapeId(meta.name);\n      const joinType = relQuery.$required ? 'INNER' : 'LEFT';\n      const joinAlias = this.escapeId(joinRelAlias, true);\n\n      tables += ` ${joinType} JOIN ${relEntityName} ${joinAlias} ON `;\n      tables += relOpts.references.map((it) => `${joinAlias}.${this.escapeId(it.foreign)} = ${relPath}.${this.escapeId(it.local)}`).join(' AND ');\n\n      if (relQuery.$filter) {\n        const filter = this.where(relEntity, relQuery.$filter, { prefix: key, clause: false });\n        tables += ` AND ${filter}`;\n      }\n\n      tables += subTables;\n    }\n\n    return { fields, tables };\n  }\n\n  select<E>(entity: Type<E>, qm: Query<E>, opts: QueryOptions = {}): string {\n    const meta = getMeta(entity);\n    const prefix = opts.prefix ?? (opts.autoPrefix || isProjectingRelations(meta, qm.$project)) ? meta.name : undefined;\n\n    const fields = this.projectFields(entity, qm.$project, { prefix });\n    const { fields: relationFields, tables } = this.projectRelations(entity, qm.$project);\n\n    return `SELECT ${fields}${relationFields} FROM ${this.escapeId(meta.name)}${tables}`;\n  }\n\n  where<E>(entity: Type<E>, filter: QueryFilter<E> = {}, opts: QueryFilterOptions = {}): string {\n    const meta = getMeta(entity);\n    const { usePrecedence, clause = 'WHERE', softDelete } = opts;\n\n    filter = getQueryFilterAsMap(meta, filter);\n\n    if (meta.softDelete && (softDelete || softDelete === undefined) && clause !== 'HAVING' && !filter[meta.softDelete as string]) {\n      filter[meta.softDelete as string] = null;\n    }\n\n    const entries = Object.entries(filter);\n\n    if (!entries.length) {\n      return '';\n    }\n\n    const options = { ...opts, usePrecedence: entries.length > 1 };\n\n    let sql = entries.map(([key, val]) => this.compare(entity, key as keyof QueryFilterMap<E>, val as any, options)).join(` AND `);\n\n    if (usePrecedence) {\n      sql = `(${sql})`;\n    }\n\n    return clause ? ` ${clause} ${sql}` : sql;\n  }\n\n  compare<E, K extends keyof QueryFilterMap<E>>(entity: Type<E>, key: K, val: QueryFilterMap<E>[K], opts?: QueryComparisonOptions): string {\n    const meta = getMeta(entity);\n\n    if (val instanceof Raw) {\n      if (key === '$exists' || key === '$nexists') {\n        const value = val as Raw;\n        const query = getRawValue({\n          value,\n          dialect: this,\n          prefix: meta.name,\n          escapedPrefix: this.escapeId(meta.name, false, true),\n        });\n        return `${key === '$exists' ? 'EXISTS' : 'NOT EXISTS'} (${query})`;\n      }\n      const comparisonKey = this.getComparisonKey(entity, key as FieldKey<E>, opts);\n      return `${comparisonKey} = ${val.value}`;\n    }\n\n    if (key === '$text') {\n      const meta = getMeta(entity);\n      const search = val as QueryTextSearchOptions<E>;\n      const fields = search.$fields.map((field) => this.escapeId(meta.fields[field]?.name ?? field));\n      return `MATCH(${fields.join(', ')}) AGAINST(${this.escape(search.$value)})`;\n    }\n\n    if (key === '$and' || key === '$or' || key === '$not' || key === '$nor') {\n      const negateOperatorMap = {\n        $not: '$and',\n        $nor: '$or',\n      } as const;\n\n      const op: '$and' | '$or' = negateOperatorMap[key as string] ?? key;\n      const negate = key in negateOperatorMap ? 'NOT ' : '';\n\n      const values = val as QueryFilterLogical<E>;\n      const hasManyItems = values.length > 1;\n      const logicalComparison = values\n        .map((filterEntry) => {\n          if (filterEntry instanceof Raw) {\n            return getRawValue({\n              value: filterEntry,\n              dialect: this,\n              prefix: opts.prefix,\n              escapedPrefix: this.escapeId(opts.prefix, true, true),\n            });\n          }\n          return this.where(entity, filterEntry, {\n            prefix: opts.prefix,\n            usePrecedence: hasManyItems && !Array.isArray(filterEntry) && getKeys(filterEntry).length > 1,\n            clause: false,\n          });\n        })\n        .join(op === '$or' ? ' OR ' : ' AND ');\n\n      return (opts.usePrecedence || negate) && hasManyItems ? `${negate}(${logicalComparison})` : `${negate}${logicalComparison}`;\n    }\n\n    const value = Array.isArray(val) ? { $in: val } : typeof val === 'object' && val !== null ? val : { $eq: val };\n    const operators = getKeys(value) as (keyof QueryFilterFieldOperatorMap<E>)[];\n    const comparisons = operators.map((op) => this.compareFieldOperator(entity, key as FieldKey<E>, op, value[op], opts)).join(' AND ');\n\n    return operators.length > 1 ? `(${comparisons})` : comparisons;\n  }\n\n  compareFieldOperator<E, K extends keyof QueryFilterFieldOperatorMap<E>>(\n    entity: Type<E>,\n    key: FieldKey<E>,\n    op: K,\n    val: QueryFilterFieldOperatorMap<E>[K],\n    opts?: QueryOptions\n  ): string {\n    const comparisonKey = this.getComparisonKey(entity, key, opts);\n    switch (op) {\n      case '$eq':\n        return val === null ? `${comparisonKey} IS NULL` : `${comparisonKey} = ${this.escape(val)}`;\n      case '$ne':\n        return val === null ? `${comparisonKey} IS NOT NULL` : `${comparisonKey} <> ${this.escape(val)}`;\n      case '$not':\n        return this.compare(entity, '$not', [{ [key]: val }] as any, opts);\n      case '$gt':\n        return `${comparisonKey} > ${this.escape(val)}`;\n      case '$gte':\n        return `${comparisonKey} >= ${this.escape(val)}`;\n      case '$lt':\n        return `${comparisonKey} < ${this.escape(val)}`;\n      case '$lte':\n        return `${comparisonKey} <= ${this.escape(val)}`;\n      case '$startsWith':\n        return `${comparisonKey} LIKE ${this.escape(`${val}%`)}`;\n      case '$istartsWith':\n        return `LOWER(${comparisonKey}) LIKE ${this.escape((val as string).toLowerCase() + '%')}`;\n      case '$endsWith':\n        return `${comparisonKey} LIKE ${this.escape(`%${val}`)}`;\n      case '$iendsWith':\n        return `LOWER(${comparisonKey}) LIKE ${this.escape('%' + (val as string).toLowerCase())}`;\n      case '$includes':\n        return `${comparisonKey} LIKE ${this.escape(`%${val}%`)}`;\n      case '$iincludes':\n        return `LOWER(${comparisonKey}) LIKE ${this.escape('%' + (val as string).toLowerCase() + '%')}`;\n      case '$ilike':\n        return `LOWER(${comparisonKey}) LIKE ${this.escape((val as string).toLowerCase())}`;\n      case '$like':\n        return `${comparisonKey} LIKE ${this.escape(val)}`;\n      case '$in':\n        return `${comparisonKey} IN (${this.escape(val)})`;\n      case '$nin':\n        return `${comparisonKey} NOT IN (${this.escape(val)})`;\n      case '$regex':\n        return `${comparisonKey} REGEXP ${this.escape(val)}`;\n      default:\n        throw TypeError(`unknown operator: ${op}`);\n    }\n  }\n\n  getComparisonKey<E>(entity: Type<E>, key: FieldKey<E>, { prefix }: QueryOptions = {}): Scalar {\n    const meta = getMeta(entity);\n    const escapedPrefix = this.escapeId(prefix, true, true);\n    const field = meta.fields[key];\n\n    if (field?.virtual) {\n      return getRawValue({\n        value: field.virtual,\n        dialect: this,\n        prefix,\n        escapedPrefix,\n      });\n    }\n\n    return escapedPrefix + this.escapeId(field?.name ?? key);\n  }\n\n  group<E>(entity: Type<E>, fields: readonly FieldKey<E>[], opts: QueryOptions = {}): string {\n    if (!fields?.length) {\n      return '';\n    }\n    const meta = getMeta(entity);\n    const names = fields.map((key) => this.escapeId(meta.fields[key]?.name ?? key)).join(', ');\n    return ` GROUP BY ${names}`;\n  }\n\n  sort<E>(entity: Type<E>, sort: QuerySort<E>, { prefix }: QueryOptions = {}): string {\n    const sortMap = buildSortMap(sort);\n    if (!hasKeys(sortMap)) {\n      return '';\n    }\n    const meta = getMeta(entity);\n    const flattenedSort = flatObject(sortMap, prefix);\n    const directionMap = { 1: '', asc: '', '-1': ' DESC', desc: ' DESC' } as const;\n    const order = Object.entries(flattenedSort)\n      .map(([key, sort]) => {\n        const name = meta.fields[key]?.name ?? key;\n        const direction = directionMap[sort as QuerySortDirection];\n        return this.escapeId(name) + direction;\n      })\n      .join(', ');\n    return ` ORDER BY ${order}`;\n  }\n\n  pager(opts: QueryPager): string {\n    let sql = '';\n    if (opts.$limit) {\n      sql += ` LIMIT ${Number(opts.$limit)}`;\n    }\n    if (opts.$skip !== undefined) {\n      sql += ` OFFSET ${Number(opts.$skip)}`;\n    }\n    return sql;\n  }\n\n  count<E>(entity: Type<E>, qm: QuerySearch<E>, opts?: QueryOptions): string {\n    const search: Query<E> = {\n      ...qm,\n      $project: [raw('COUNT(*)', 'count')],\n    };\n\n    delete search.$sort;\n    delete search.$skip;\n    delete search.$limit;\n\n    const select = this.select<E>(entity, search);\n    const criteria = this.criteria(entity, search, opts);\n\n    return select + criteria;\n  }\n\n  find<E>(entity: Type<E>, qm: Query<E>, opts?: QueryOptions): string {\n    const select = this.select<E>(entity, qm, opts);\n    const criteria = this.criteria(entity, qm, opts);\n    return select + criteria;\n  }\n\n  insert<E>(entity: Type<E>, payload: E | E[]): string {\n    const meta = getMeta(entity);\n    payload = getPersistables(meta, payload, 'onInsert');\n    const keys = getKeys(payload[0]);\n    const columns = keys.map((key) => this.escapeId(meta.fields[key].name));\n    const values = payload.map((it) => keys.map((key) => this.escape(it[key])).join(', ')).join('), (');\n    return `INSERT INTO ${this.escapeId(meta.name)} (${columns.join(', ')}) VALUES (${values})`;\n  }\n\n  update<E>(entity: Type<E>, qm: QueryCriteria<E>, payload: E, opts?: QueryOptions): string {\n    const meta = getMeta(entity);\n    payload = getPersistable(meta, payload, 'onUpdate');\n    const values = getKeys(payload)\n      .map((key) => `${this.escapeId(key)} = ${this.escape(payload[key])}`)\n      .join(', ');\n    const criteria = this.criteria(entity, qm, opts);\n    return `UPDATE ${this.escapeId(meta.name)} SET ${values}${criteria}`;\n  }\n\n  delete<E>(entity: Type<E>, qm: QueryCriteria<E>, opts: QueryOptions = {}): string {\n    const meta = getMeta(entity);\n\n    if (opts.softDelete || opts.softDelete === undefined) {\n      if (meta.softDelete) {\n        const criteria = this.criteria(entity, qm, opts);\n        const value = meta.fields[meta.softDelete].onDelete();\n        return `UPDATE ${this.escapeId(meta.name)} SET ${this.escapeId(meta.softDelete)} = ${this.escape(value)}${criteria}`;\n      } else if (opts.softDelete) {\n        throw TypeError(`'${meta.name}' has not enabled 'softDelete'`);\n      }\n    }\n\n    const criteria = this.criteria(entity, qm, opts);\n\n    return `DELETE FROM ${this.escapeId(meta.name)}${criteria}`;\n  }\n\n  escapeId(val: string, forbidQualified?: boolean, addDot?: boolean): string {\n    if (!val) {\n      return '';\n    }\n\n    if (!forbidQualified && val.includes('.')) {\n      return val\n        .split('.')\n        .map((it) => this.escapeId(it))\n        .join('.');\n    }\n\n    // sourced from 'escapeId' function here https://github.com/mysqljs/sqlstring/blob/master/lib/SqlString.js\n    const escaped = this.escapeIdChar + val.replace(this.escapeIdRegex, this.escapeIdChar + this.escapeIdChar) + this.escapeIdChar;\n\n    const suffix = addDot ? '.' : '';\n\n    return escaped + suffix;\n  }\n\n  escape(value: any): Scalar {\n    return escape(value);\n  }\n}\n"]}
368
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"abstractSqlDialect.js","sourceRoot":"","sources":["../../src/dialect/abstractSqlDialect.ts"],"names":[],"mappings":";;;AAAA,yCAAmC;AACnC,6CAA2C;AAC3C,yCAcwB;AA0BxB,MAAsB,kBAAkB;IAGtC,YAAqB,YAAuB,EAAW,uBAA+B;QAAjE,iBAAY,GAAZ,YAAY,CAAW;QAAW,4BAAuB,GAAvB,uBAAuB,CAAQ;QACpF,IAAI,CAAC,aAAa,GAAG,MAAM,CAAC,YAAY,EAAE,GAAG,CAAC,CAAC;IACjD,CAAC;IAED,QAAQ,CAAI,MAAe,EAAE,EAAY,EAAE,OAAqB,EAAE;;QAChE,MAAM,IAAI,GAAG,IAAA,gBAAO,EAAC,MAAM,CAAC,CAAC;QAC7B,MAAM,MAAM,GAAG,CAAA,MAAA,IAAI,CAAC,MAAM,mCAAI,CAAC,IAAI,CAAC,UAAU,IAAI,IAAA,4BAAqB,EAAC,IAAI,EAAE,EAAE,CAAC,QAAQ,CAAC,CAAC,EAAC,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC,SAAS,CAAC;QACpH,MAAM,KAAK,GAAG,IAAI,CAAC,KAAK,CAAI,MAAM,EAAE,EAAE,CAAC,OAAO,EAAE,EAAE,GAAG,IAAI,EAAE,MAAM,EAAE,CAAC,CAAC;QACrE,MAAM,KAAK,GAAG,IAAI,CAAC,KAAK,CAAI,MAAM,EAAE,EAAE,CAAC,MAAM,EAAE,EAAE,GAAG,IAAI,EAAE,MAAM,EAAE,CAAC,CAAC;QACpE,MAAM,MAAM,GAAG,IAAI,CAAC,KAAK,CAAI,MAAM,EAAE,EAAE,CAAC,OAAO,EAAE,EAAE,GAAG,IAAI,EAAE,MAAM,EAAE,MAAM,EAAE,QAAQ,EAAE,CAAC,CAAC;QACxF,MAAM,IAAI,GAAG,IAAI,CAAC,IAAI,CAAI,MAAM,EAAE,EAAE,CAAC,KAAK,EAAE,EAAE,GAAG,IAAI,EAAE,MAAM,EAAE,CAAC,CAAC;QACjE,MAAM,KAAK,GAAG,IAAI,CAAC,KAAK,CAAC,EAAE,CAAC,CAAC;QAC7B,OAAO,KAAK,GAAG,KAAK,GAAG,MAAM,GAAG,IAAI,GAAG,KAAK,CAAC;IAC/C,CAAC;IAED,aAAa,CAAI,MAAe,EAAE,OAAwB,EAAE,OAA4B,EAAE;QACxF,MAAM,IAAI,GAAG,IAAA,gBAAO,EAAC,MAAM,CAAC,CAAC;QAC7B,MAAM,MAAM,GAAG,IAAI,CAAC,MAAM,CAAC,CAAC,CAAC,IAAI,CAAC,MAAM,GAAG,GAAG,CAAC,CAAC,CAAC,EAAE,CAAC;QACpD,MAAM,aAAa,GAAG,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,MAAM,EAAE,IAAI,EAAE,IAAI,CAAC,CAAC;QAE7D,IAAI,MAA4B,CAAC;QAEjC,IAAI,OAAO,EAAE;YACX,IAAI,KAAK,CAAC,OAAO,CAAC,OAAO,CAAC,EAAE;gBAC1B,MAAM,GAAG,OAAO,CAAC;aAClB;iBAAM;gBACL,MAAM,mBAAmB,GAAG,IAAA,cAAO,EAAC,OAAO,CAAC,CAAC,MAAM,CAAC,CAAC,GAAG,EAAE,EAAE,CAAC,OAAO,CAAC,GAAG,CAAC,CAAC,CAAC;gBAC3E,MAAM,GAAG,mBAAmB,CAAC,MAAM;oBACjC,CAAC,CAAC,mBAAmB,CAAC,GAAG,CAAC,CAAC,GAAG,EAAE,EAAE;wBAC9B,MAAM,GAAG,GAAG,OAAO,CAAC,GAAG,CAAC,CAAC;wBACzB,IAAI,GAAG,YAAY,UAAG,EAAE;4BACtB,OAAO,IAAA,UAAG,EAAC,GAAG,CAAC,KAAK,EAAE,GAAG,CAAC,CAAC;yBAC5B;wBACD,OAAO,GAAkB,CAAC;oBAC5B,CAAC,CAAC;oBACJ,CAAC,CAAE,IAAA,cAAO,EAAC,IAAI,CAAC,MAAM,CAAC,CAAC,MAAM,CAAC,CAAC,GAAG,EAAE,EAAE,CAAC,CAAC,CAAC,GAAG,IAAI,OAAO,CAAC,CAAmB,CAAC;aAChF;YACD,MAAM,GAAG,MAAM,CAAC,MAAM,CAAC,CAAC,GAAG,EAAE,EAAE,CAAC,GAAG,YAAY,UAAG,IAAI,IAAI,CAAC,MAAM,CAAC,GAAkB,CAAC,CAAC,CAAC;YACvF,IAAI,CAAC,MAAM,CAAC,MAAM,IAAI,CAAC,IAAI,CAAC,MAAM,IAAI,CAAC,MAAM,CAAC,QAAQ,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC,EAAE;gBAChE,MAAM,GAAG,CAAC,IAAI,CAAC,EAAE,EAAE,GAAG,MAAM,CAAC,CAAC;aAC/B;SACF;aAAM;YACL,MAAM,GAAG,IAAA,cAAO,EAAC,IAAI,CAAC,MAAM,CAAkB,CAAC;SAChD;QAED,OAAO,MAAM;aACV,GAAG,CAAC,CAAC,GAAG,EAAE,EAAE;;YACX,IAAI,GAAG,YAAY,UAAG,EAAE;gBACtB,OAAO,IAAA,kBAAW,EAAC;oBACjB,KAAK,EAAE,GAAG;oBACV,OAAO,EAAE,IAAI;oBACb,MAAM;oBACN,aAAa;oBACb,eAAe,EAAE,IAAI,CAAC,eAAe;iBACtC,CAAC,CAAC;aACJ;YAED,MAAM,KAAK,GAAG,IAAI,CAAC,MAAM,CAAC,GAAkB,CAAC,CAAC;YAE9C,IAAI,KAAK,CAAC,OAAO,EAAE;gBACjB,OAAO,IAAA,kBAAW,EAAC;oBACjB,KAAK,EAAE,KAAK,CAAC,OAAO;oBACpB,KAAK,EAAE,GAAa;oBACpB,OAAO,EAAE,IAAI;oBACb,MAAM;oBACN,aAAa;oBACb,eAAe,EAAE,IAAI,CAAC,eAAe;iBACtC,CAAC,CAAC;aACJ;YAED,MAAM,IAAI,GAAG,MAAA,KAAK,aAAL,KAAK,uBAAL,KAAK,CAAE,IAAI,mCAAK,GAAmB,CAAC;YACjD,MAAM,SAAS,GAAG,GAAG,aAAa,GAAG,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,EAAE,CAAC;YAE3D,OAAO,CAAC,IAAI,CAAC,eAAe,IAAI,CAAC,IAAI,KAAK,GAAG,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC,CAAC,GAAG,SAAS,IAAI,IAAI,CAAC,QAAQ,CAAC,CAAC,MAAM,GAAG,GAAG,CAAgB,EAAE,IAAI,CAAC,EAAE,CAAC;QAC9I,CAAC,CAAC;aACD,IAAI,CAAC,IAAI,CAAC,CAAC;IAChB,CAAC;IAED,gBAAgB,CAAI,MAAe,EAAE,UAA2B,EAAE,EAAE,EAAE,MAAM,KAA0B,EAAE;QACtG,MAAM,IAAI,GAAG,IAAA,gBAAO,EAAC,MAAM,CAAC,CAAC;QAC7B,MAAM,SAAS,GAAG,IAAA,6BAAsB,EAAC,IAAI,EAAE,OAAO,CAAC,CAAC;QACxD,MAAM,cAAc,GAAG,KAAK,CAAC,OAAO,CAAC,OAAO,CAAC,CAAC;QAC9C,IAAI,MAAM,GAAG,EAAE,CAAC;QAChB,IAAI,MAAM,GAAG,EAAE,CAAC;QAEhB,KAAK,MAAM,GAAG,IAAI,SAAS,EAAE;YAC3B,MAAM,OAAO,GAAG,IAAI,CAAC,SAAS,CAAC,GAAG,CAAC,CAAC;YAEpC,IAAI,OAAO,CAAC,WAAW,KAAK,IAAI,IAAI,OAAO,CAAC,WAAW,KAAK,IAAI,EAAE;gBAChE,6FAA6F;gBAC7F,SAAS;aACV;YAED,MAAM,YAAY,GAAG,MAAM,CAAC,CAAC,CAAC,MAAM,GAAG,GAAG,GAAG,GAAG,CAAC,CAAC,CAAC,GAAG,CAAC;YACvD,MAAM,SAAS,GAAG,OAAO,CAAC,MAAM,EAAE,CAAC;YACnC,MAAM,UAAU,GAAG,OAAO,CAAC,GAAa,CAAC,CAAC;YAC1C,MAAM,QAAQ,GAAG,cAAc,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,KAAK,CAAC,OAAO,CAAC,UAAU,CAAC,CAAC,CAAC,CAAC,EAAE,QAAQ,EAAE,UAAU,EAAE,CAAC,CAAC,CAAC,UAAU,CAAC;YAEzG,MAAM,UAAU,GAAG,IAAI,CAAC,aAAa,CAAC,SAAS,EAAE,QAAQ,CAAC,QAAQ,EAAE;gBAClE,MAAM,EAAE,YAAY;gBACpB,eAAe,EAAE,IAAI;aACtB,CAAC,CAAC;YAEH,MAAM,IAAI,IAAI,GAAG,UAAU,CAAC;YAE5B,MAAM,EAAE,MAAM,EAAE,UAAU,EAAE,MAAM,EAAE,SAAS,EAAE,GAAG,IAAI,CAAC,gBAAgB,CAAC,SAAS,EAAE,QAAQ,CAAC,QAAQ,EAAE;gBACpG,MAAM,EAAE,YAAY;aACrB,CAAC,CAAC;YAEH,MAAM,IAAI,UAAU,CAAC;YAErB,MAAM,OAAO,GAAG,IAAA,gBAAO,EAAC,SAAS,CAAC,CAAC;YACnC,MAAM,aAAa,GAAG,IAAI,CAAC,QAAQ,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC;YAClD,MAAM,OAAO,GAAG,MAAM,CAAC,CAAC,CAAC,IAAI,CAAC,QAAQ,CAAC,MAAM,EAAE,IAAI,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;YAChF,MAAM,QAAQ,GAAG,QAAQ,CAAC,SAAS,CAAC,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,MAAM,CAAC;YACvD,MAAM,SAAS,GAAG,IAAI,CAAC,QAAQ,CAAC,YAAY,EAAE,IAAI,CAAC,CAAC;YAEpD,MAAM,IAAI,IAAI,QAAQ,SAAS,aAAa,IAAI,SAAS,MAAM,CAAC;YAChE,MAAM,IAAI,OAAO,CAAC,UAAU,CAAC,GAAG,CAAC,CAAC,EAAE,EAAE,EAAE,CAAC,GAAG,SAAS,IAAI,IAAI,CAAC,QAAQ,CAAC,EAAE,CAAC,OAAO,CAAC,MAAM,OAAO,IAAI,IAAI,CAAC,QAAQ,CAAC,EAAE,CAAC,KAAK,CAAC,EAAE,CAAC,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC;YAE5I,IAAI,QAAQ,CAAC,OAAO,EAAE;gBACpB,MAAM,MAAM,GAAG,IAAI,CAAC,KAAK,CAAC,SAAS,EAAE,QAAQ,CAAC,OAAO,EAAE,EAAE,MAAM,EAAE,GAAG,EAAE,MAAM,EAAE,KAAK,EAAE,CAAC,CAAC;gBACvF,MAAM,IAAI,QAAQ,MAAM,EAAE,CAAC;aAC5B;YAED,MAAM,IAAI,SAAS,CAAC;SACrB;QAED,OAAO,EAAE,MAAM,EAAE,MAAM,EAAE,CAAC;IAC5B,CAAC;IAED,MAAM,CAAI,MAAe,EAAE,EAAY,EAAE,OAAqB,EAAE;;QAC9D,MAAM,IAAI,GAAG,IAAA,gBAAO,EAAC,MAAM,CAAC,CAAC;QAC7B,MAAM,MAAM,GAAG,CAAA,MAAA,IAAI,CAAC,MAAM,mCAAI,CAAC,IAAI,CAAC,UAAU,IAAI,IAAA,4BAAqB,EAAC,IAAI,EAAE,EAAE,CAAC,QAAQ,CAAC,CAAC,EAAC,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC,SAAS,CAAC;QAEpH,MAAM,MAAM,GAAG,IAAI,CAAC,aAAa,CAAC,MAAM,EAAE,EAAE,CAAC,QAAQ,EAAE,EAAE,MAAM,EAAE,CAAC,CAAC;QACnE,MAAM,EAAE,MAAM,EAAE,cAAc,EAAE,MAAM,EAAE,GAAG,IAAI,CAAC,gBAAgB,CAAC,MAAM,EAAE,EAAE,CAAC,QAAQ,CAAC,CAAC;QAEtF,OAAO,UAAU,MAAM,GAAG,cAAc,SAAS,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,IAAI,CAAC,GAAG,MAAM,EAAE,CAAC;IACvF,CAAC;IAED,KAAK,CAAI,MAAe,EAAE,SAAyB,EAAE,EAAE,OAA2B,EAAE;QAClF,MAAM,IAAI,GAAG,IAAA,gBAAO,EAAC,MAAM,CAAC,CAAC;QAC7B,MAAM,EAAE,aAAa,EAAE,MAAM,GAAG,OAAO,EAAE,UAAU,EAAE,GAAG,IAAI,CAAC;QAE7D,MAAM,GAAG,IAAA,0BAAmB,EAAC,IAAI,EAAE,MAAM,CAAC,CAAC;QAE3C,IAAI,IAAI,CAAC,UAAU,IAAI,CAAC,UAAU,IAAI,UAAU,KAAK,SAAS,CAAC,IAAI,MAAM,KAAK,QAAQ,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,UAAoB,CAAC,EAAE;YAC5H,MAAM,CAAC,IAAI,CAAC,UAAoB,CAAC,GAAG,IAAI,CAAC;SAC1C;QAED,MAAM,OAAO,GAAG,MAAM,CAAC,OAAO,CAAC,MAAM,CAAC,CAAC;QAEvC,IAAI,CAAC,OAAO,CAAC,MAAM,EAAE;YACnB,OAAO,EAAE,CAAC;SACX;QAED,MAAM,OAAO,GAAG,EAAE,GAAG,IAAI,EAAE,aAAa,EAAE,OAAO,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC;QAE/D,IAAI,GAAG,GAAG,OAAO,CAAC,GAAG,CAAC,CAAC,CAAC,GAAG,EAAE,GAAG,CAAC,EAAE,EAAE,CAAC,IAAI,CAAC,OAAO,CAAC,MAAM,EAAE,GAA8B,EAAE,GAAU,EAAE,OAAO,CAAC,CAAC,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC;QAE/H,IAAI,aAAa,EAAE;YACjB,GAAG,GAAG,IAAI,GAAG,GAAG,CAAC;SAClB;QAED,OAAO,MAAM,CAAC,CAAC,CAAC,IAAI,MAAM,IAAI,GAAG,EAAE,CAAC,CAAC,CAAC,GAAG,CAAC;IAC5C,CAAC;IAED,OAAO,CAAuC,MAAe,EAAE,GAAM,EAAE,GAAyB,EAAE,IAA6B;;QAC7H,MAAM,IAAI,GAAG,IAAA,gBAAO,EAAC,MAAM,CAAC,CAAC;QAE7B,IAAI,GAAG,YAAY,UAAG,EAAE;YACtB,IAAI,GAAG,KAAK,SAAS,IAAI,GAAG,KAAK,UAAU,EAAE;gBAC3C,MAAM,KAAK,GAAG,GAAU,CAAC;gBACzB,MAAM,KAAK,GAAG,IAAA,kBAAW,EAAC;oBACxB,KAAK;oBACL,OAAO,EAAE,IAAI;oBACb,MAAM,EAAE,IAAI,CAAC,IAAI;oBACjB,aAAa,EAAE,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,IAAI,EAAE,KAAK,EAAE,IAAI,CAAC;iBACrD,CAAC,CAAC;gBACH,OAAO,GAAG,GAAG,KAAK,SAAS,CAAC,CAAC,CAAC,QAAQ,CAAC,CAAC,CAAC,YAAY,KAAK,KAAK,GAAG,CAAC;aACpE;YACD,MAAM,aAAa,GAAG,IAAI,CAAC,gBAAgB,CAAC,MAAM,EAAE,GAAkB,EAAE,IAAI,CAAC,CAAC;YAC9E,OAAO,GAAG,aAAa,MAAM,GAAG,CAAC,KAAK,EAAE,CAAC;SAC1C;QAED,IAAI,GAAG,KAAK,OAAO,EAAE;YACnB,MAAM,MAAM,GAAG,GAAgC,CAAC;YAChD,MAAM,MAAM,GAAG,MAAM,CAAC,OAAO,CAAC,GAAG,CAAC,CAAC,KAAK,EAAE,EAAE,eAAC,OAAA,IAAI,CAAC,QAAQ,CAAC,MAAA,MAAA,IAAI,CAAC,MAAM,CAAC,KAAK,CAAC,0CAAE,IAAI,mCAAI,KAAK,CAAC,CAAA,EAAA,CAAC,CAAC;YAC/F,OAAO,GAAG,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,IAAI,CAAC,WAAW,MAAM,CAAC,IAAI,CAAC,GAAG,CAAC,OAAO,IAAI,CAAC,MAAM,CAAC,MAAM,CAAC,MAAM,CAAC,EAAE,CAAC;SAClG;QAED,IAAI,GAAG,KAAK,MAAM,IAAI,GAAG,KAAK,KAAK,IAAI,GAAG,KAAK,MAAM,IAAI,GAAG,KAAK,MAAM,EAAE;YACvE,MAAM,iBAAiB,GAAG;gBACxB,IAAI,EAAE,MAAM;gBACZ,IAAI,EAAE,KAAK;aACH,CAAC;YAEX,MAAM,EAAE,GAAmB,MAAA,iBAAiB,CAAC,GAAa,CAAC,mCAAI,GAAG,CAAC;YACnE,MAAM,MAAM,GAAG,GAAG,IAAI,iBAAiB,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,CAAC;YAEtD,MAAM,MAAM,GAAG,GAA4B,CAAC;YAC5C,MAAM,YAAY,GAAG,MAAM,CAAC,MAAM,GAAG,CAAC,CAAC;YACvC,MAAM,iBAAiB,GAAG,MAAM;iBAC7B,GAAG,CAAC,CAAC,WAAW,EAAE,EAAE;gBACnB,IAAI,WAAW,YAAY,UAAG,EAAE;oBAC9B,OAAO,IAAA,kBAAW,EAAC;wBACjB,KAAK,EAAE,WAAW;wBAClB,OAAO,EAAE,IAAI;wBACb,MAAM,EAAE,IAAI,CAAC,MAAM;wBACnB,aAAa,EAAE,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,MAAM,EAAE,IAAI,EAAE,IAAI,CAAC;qBACtD,CAAC,CAAC;iBACJ;gBACD,OAAO,IAAI,CAAC,KAAK,CAAC,MAAM,EAAE,WAAW,EAAE;oBACrC,MAAM,EAAE,IAAI,CAAC,MAAM;oBACnB,aAAa,EAAE,YAAY,IAAI,CAAC,KAAK,CAAC,OAAO,CAAC,WAAW,CAAC,IAAI,IAAA,cAAO,EAAC,WAAW,CAAC,CAAC,MAAM,GAAG,CAAC;oBAC7F,MAAM,EAAE,KAAK;iBACd,CAAC,CAAC;YACL,CAAC,CAAC;iBACD,IAAI,CAAC,EAAE,KAAK,KAAK,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,OAAO,CAAC,CAAC;YAEzC,OAAO,CAAC,IAAI,CAAC,aAAa,IAAI,MAAM,CAAC,IAAI,YAAY,CAAC,CAAC,CAAC,GAAG,MAAM,IAAI,iBAAiB,GAAG,CAAC,CAAC,CAAC,GAAG,MAAM,GAAG,iBAAiB,EAAE,CAAC;SAC7H;QAED,MAAM,KAAK,GAAG,KAAK,CAAC,OAAO,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,EAAE,GAAG,EAAE,GAAG,EAAE,CAAC,CAAC,CAAC,OAAO,GAAG,KAAK,QAAQ,IAAI,GAAG,KAAK,IAAI,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,GAAG,EAAE,GAAG,EAAE,CAAC;QAC/G,MAAM,SAAS,GAAG,IAAA,cAAO,EAAC,KAAK,CAA6C,CAAC;QAC7E,MAAM,WAAW,GAAG,SAAS,CAAC,GAAG,CAAC,CAAC,EAAE,EAAE,EAAE,CAAC,IAAI,CAAC,oBAAoB,CAAC,MAAM,EAAE,GAAkB,EAAE,EAAE,EAAE,KAAK,CAAC,EAAE,CAAC,EAAE,IAAI,CAAC,CAAC,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC;QAEpI,OAAO,SAAS,CAAC,MAAM,GAAG,CAAC,CAAC,CAAC,CAAC,IAAI,WAAW,GAAG,CAAC,CAAC,CAAC,WAAW,CAAC;IACjE,CAAC;IAED,oBAAoB,CAClB,MAAe,EACf,GAAgB,EAChB,EAAK,EACL,GAAsC,EACtC,IAAmB;QAEnB,MAAM,aAAa,GAAG,IAAI,CAAC,gBAAgB,CAAC,MAAM,EAAE,GAAG,EAAE,IAAI,CAAC,CAAC;QAC/D,QAAQ,EAAE,EAAE;YACV,KAAK,KAAK;gBACR,OAAO,GAAG,KAAK,IAAI,CAAC,CAAC,CAAC,GAAG,aAAa,UAAU,CAAC,CAAC,CAAC,GAAG,aAAa,MAAM,IAAI,CAAC,MAAM,CAAC,GAAG,CAAC,EAAE,CAAC;YAC9F,KAAK,KAAK;gBACR,OAAO,GAAG,KAAK,IAAI,CAAC,CAAC,CAAC,GAAG,aAAa,cAAc,CAAC,CAAC,CAAC,GAAG,aAAa,OAAO,IAAI,CAAC,MAAM,CAAC,GAAG,CAAC,EAAE,CAAC;YACnG,KAAK,MAAM;gBACT,OAAO,IAAI,CAAC,OAAO,CAAC,MAAM,EAAE,MAAM,EAAE,CAAC,EAAE,CAAC,GAAG,CAAC,EAAE,GAAG,EAAE,CAAQ,EAAE,IAAI,CAAC,CAAC;YACrE,KAAK,KAAK;gBACR,OAAO,GAAG,aAAa,MAAM,IAAI,CAAC,MAAM,CAAC,GAAG,CAAC,EAAE,CAAC;YAClD,KAAK,MAAM;gBACT,OAAO,GAAG,aAAa,OAAO,IAAI,CAAC,MAAM,CAAC,GAAG,CAAC,EAAE,CAAC;YACnD,KAAK,KAAK;gBACR,OAAO,GAAG,aAAa,MAAM,IAAI,CAAC,MAAM,CAAC,GAAG,CAAC,EAAE,CAAC;YAClD,KAAK,MAAM;gBACT,OAAO,GAAG,aAAa,OAAO,IAAI,CAAC,MAAM,CAAC,GAAG,CAAC,EAAE,CAAC;YACnD,KAAK,aAAa;gBAChB,OAAO,GAAG,aAAa,SAAS,IAAI,CAAC,MAAM,CAAC,GAAG,GAAG,GAAG,CAAC,EAAE,CAAC;YAC3D,KAAK,cAAc;gBACjB,OAAO,SAAS,aAAa,UAAU,IAAI,CAAC,MAAM,CAAE,GAAc,CAAC,WAAW,EAAE,GAAG,GAAG,CAAC,EAAE,CAAC;YAC5F,KAAK,WAAW;gBACd,OAAO,GAAG,aAAa,SAAS,IAAI,CAAC,MAAM,CAAC,IAAI,GAAG,EAAE,CAAC,EAAE,CAAC;YAC3D,KAAK,YAAY;gBACf,OAAO,SAAS,aAAa,UAAU,IAAI,CAAC,MAAM,CAAC,GAAG,GAAI,GAAc,CAAC,WAAW,EAAE,CAAC,EAAE,CAAC;YAC5F,KAAK,WAAW;gBACd,OAAO,GAAG,aAAa,SAAS,IAAI,CAAC,MAAM,CAAC,IAAI,GAAG,GAAG,CAAC,EAAE,CAAC;YAC5D,KAAK,YAAY;gBACf,OAAO,SAAS,aAAa,UAAU,IAAI,CAAC,MAAM,CAAC,GAAG,GAAI,GAAc,CAAC,WAAW,EAAE,GAAG,GAAG,CAAC,EAAE,CAAC;YAClG,KAAK,QAAQ;gBACX,OAAO,SAAS,aAAa,UAAU,IAAI,CAAC,MAAM,CAAE,GAAc,CAAC,WAAW,EAAE,CAAC,EAAE,CAAC;YACtF,KAAK,OAAO;gBACV,OAAO,GAAG,aAAa,SAAS,IAAI,CAAC,MAAM,CAAC,GAAG,CAAC,EAAE,CAAC;YACrD,KAAK,KAAK;gBACR,OAAO,GAAG,aAAa,QAAQ,IAAI,CAAC,MAAM,CAAC,GAAG,CAAC,GAAG,CAAC;YACrD,KAAK,MAAM;gBACT,OAAO,GAAG,aAAa,YAAY,IAAI,CAAC,MAAM,CAAC,GAAG,CAAC,GAAG,CAAC;YACzD,KAAK,QAAQ;gBACX,OAAO,GAAG,aAAa,WAAW,IAAI,CAAC,MAAM,CAAC,GAAG,CAAC,EAAE,CAAC;YACvD;gBACE,MAAM,SAAS,CAAC,qBAAqB,EAAE,EAAE,CAAC,CAAC;SAC9C;IACH,CAAC;IAED,gBAAgB,CAAI,MAAe,EAAE,GAAgB,EAAE,EAAE,MAAM,KAAmB,EAAE;;QAClF,MAAM,IAAI,GAAG,IAAA,gBAAO,EAAC,MAAM,CAAC,CAAC;QAC7B,MAAM,aAAa,GAAG,IAAI,CAAC,QAAQ,CAAC,MAAM,EAAE,IAAI,EAAE,IAAI,CAAC,CAAC;QACxD,MAAM,KAAK,GAAG,IAAI,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC;QAE/B,IAAI,KAAK,aAAL,KAAK,uBAAL,KAAK,CAAE,OAAO,EAAE;YAClB,OAAO,IAAA,kBAAW,EAAC;gBACjB,KAAK,EAAE,KAAK,CAAC,OAAO;gBACpB,OAAO,EAAE,IAAI;gBACb,MAAM;gBACN,aAAa;aACd,CAAC,CAAC;SACJ;QAED,OAAO,aAAa,GAAG,IAAI,CAAC,QAAQ,CAAC,MAAA,KAAK,aAAL,KAAK,uBAAL,KAAK,CAAE,IAAI,mCAAI,GAAG,CAAC,CAAC;IAC3D,CAAC;IAED,KAAK,CAAI,MAAe,EAAE,MAA8B,EAAE,OAAqB,EAAE;QAC/E,IAAI,CAAC,CAAA,MAAM,aAAN,MAAM,uBAAN,MAAM,CAAE,MAAM,CAAA,EAAE;YACnB,OAAO,EAAE,CAAC;SACX;QACD,MAAM,IAAI,GAAG,IAAA,gBAAO,EAAC,MAAM,CAAC,CAAC;QAC7B,MAAM,KAAK,GAAG,MAAM,CAAC,GAAG,CAAC,CAAC,GAAG,EAAE,EAAE,eAAC,OAAA,IAAI,CAAC,QAAQ,CAAC,MAAA,MAAA,IAAI,CAAC,MAAM,CAAC,GAAG,CAAC,0CAAE,IAAI,mCAAI,GAAG,CAAC,CAAA,EAAA,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;QAC3F,OAAO,aAAa,KAAK,EAAE,CAAC;IAC9B,CAAC;IAED,IAAI,CAAI,MAAe,EAAE,IAAkB,EAAE,EAAE,MAAM,KAAmB,EAAE;QACxE,MAAM,OAAO,GAAG,IAAA,mBAAY,EAAC,IAAI,CAAC,CAAC;QACnC,IAAI,CAAC,IAAA,cAAO,EAAC,OAAO,CAAC,EAAE;YACrB,OAAO,EAAE,CAAC;SACX;QACD,MAAM,IAAI,GAAG,IAAA,gBAAO,EAAC,MAAM,CAAC,CAAC;QAC7B,MAAM,aAAa,GAAG,IAAA,iBAAU,EAAC,OAAO,EAAE,MAAM,CAAC,CAAC;QAClD,MAAM,YAAY,GAAG,EAAE,CAAC,EAAE,EAAE,EAAE,GAAG,EAAE,EAAE,EAAE,IAAI,EAAE,OAAO,EAAE,IAAI,EAAE,OAAO,EAAW,CAAC;QAC/E,MAAM,KAAK,GAAG,MAAM,CAAC,OAAO,CAAC,aAAa,CAAC;aACxC,GAAG,CAAC,CAAC,CAAC,GAAG,EAAE,IAAI,CAAC,EAAE,EAAE;;YACnB,MAAM,IAAI,GAAG,MAAA,MAAA,IAAI,CAAC,MAAM,CAAC,GAAG,CAAC,0CAAE,IAAI,mCAAI,GAAG,CAAC;YAC3C,MAAM,SAAS,GAAG,YAAY,CAAC,IAA0B,CAAC,CAAC;YAC3D,OAAO,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,GAAG,SAAS,CAAC;QACzC,CAAC,CAAC;aACD,IAAI,CAAC,IAAI,CAAC,CAAC;QACd,OAAO,aAAa,KAAK,EAAE,CAAC;IAC9B,CAAC;IAED,KAAK,CAAC,IAAgB;QACpB,IAAI,GAAG,GAAG,EAAE,CAAC;QACb,IAAI,IAAI,CAAC,MAAM,EAAE;YACf,GAAG,IAAI,UAAU,MAAM,CAAC,IAAI,CAAC,MAAM,CAAC,EAAE,CAAC;SACxC;QACD,IAAI,IAAI,CAAC,KAAK,KAAK,SAAS,EAAE;YAC5B,GAAG,IAAI,WAAW,MAAM,CAAC,IAAI,CAAC,KAAK,CAAC,EAAE,CAAC;SACxC;QACD,OAAO,GAAG,CAAC;IACb,CAAC;IAED,KAAK,CAAI,MAAe,EAAE,EAAkB,EAAE,IAAmB;QAC/D,MAAM,MAAM,GAAa;YACvB,GAAG,EAAE;YACL,QAAQ,EAAE,CAAC,IAAA,UAAG,EAAC,UAAU,EAAE,OAAO,CAAC,CAAC;SACrC,CAAC;QAEF,OAAO,MAAM,CAAC,KAAK,CAAC;QACpB,OAAO,MAAM,CAAC,KAAK,CAAC;QACpB,OAAO,MAAM,CAAC,MAAM,CAAC;QAErB,MAAM,MAAM,GAAG,IAAI,CAAC,MAAM,CAAI,MAAM,EAAE,MAAM,CAAC,CAAC;QAC9C,MAAM,QAAQ,GAAG,IAAI,CAAC,QAAQ,CAAC,MAAM,EAAE,MAAM,EAAE,IAAI,CAAC,CAAC;QAErD,OAAO,MAAM,GAAG,QAAQ,CAAC;IAC3B,CAAC;IAED,IAAI,CAAI,MAAe,EAAE,EAAY,EAAE,IAAmB;QACxD,MAAM,MAAM,GAAG,IAAI,CAAC,MAAM,CAAI,MAAM,EAAE,EAAE,EAAE,IAAI,CAAC,CAAC;QAChD,MAAM,QAAQ,GAAG,IAAI,CAAC,QAAQ,CAAC,MAAM,EAAE,EAAE,EAAE,IAAI,CAAC,CAAC;QACjD,OAAO,MAAM,GAAG,QAAQ,CAAC;IAC3B,CAAC;IAED,MAAM,CAAI,MAAe,EAAE,OAAgB;QACzC,MAAM,IAAI,GAAG,IAAA,gBAAO,EAAC,MAAM,CAAC,CAAC;QAC7B,MAAM,OAAO,GAAG,IAAA,sBAAe,EAAC,IAAI,EAAE,OAAO,EAAE,UAAU,CAAC,CAAC;QAC3D,MAAM,IAAI,GAAG,IAAA,cAAO,EAAC,OAAO,CAAC,CAAC,CAAC,CAAC,CAAC;QACjC,MAAM,OAAO,GAAG,IAAI,CAAC,GAAG,CAAC,CAAC,GAAG,EAAE,EAAE,CAAC,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC;QACxE,MAAM,MAAM,GAAG,OAAO,CAAC,GAAG,CAAC,CAAC,MAAM,EAAE,EAAE,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC,GAAG,EAAE,EAAE,CAAC,IAAI,CAAC,MAAM,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;QAC5G,OAAO,eAAe,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,IAAI,CAAC,KAAK,OAAO,CAAC,IAAI,CAAC,IAAI,CAAC,aAAa,MAAM,GAAG,CAAC;IAC9F,CAAC;IAED,MAAM,CAAI,MAAe,EAAE,EAAoB,EAAE,OAAU,EAAE,IAAmB;QAC9E,MAAM,IAAI,GAAG,IAAA,gBAAO,EAAC,MAAM,CAAC,CAAC;QAC7B,MAAM,MAAM,GAAG,IAAA,qBAAc,EAAC,IAAI,EAAE,OAAO,EAAE,UAAU,CAAC,CAAC;QACzD,MAAM,IAAI,GAAG,IAAA,cAAO,EAAC,MAAM,CAAC,CAAC;QAC7B,MAAM,OAAO,GAAG,IAAI,CAAC,GAAG,CAAC,CAAC,GAAG,EAAE,EAAE,CAAC,GAAG,IAAI,CAAC,QAAQ,CAAC,GAAG,CAAC,MAAM,IAAI,CAAC,MAAM,CAAC,OAAO,CAAC,GAAG,CAAC,CAAC,EAAE,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;QACrG,MAAM,QAAQ,GAAG,IAAI,CAAC,QAAQ,CAAC,MAAM,EAAE,EAAE,EAAE,IAAI,CAAC,CAAC;QACjD,OAAO,UAAU,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,IAAI,CAAC,QAAQ,OAAO,GAAG,QAAQ,EAAE,CAAC;IACxE,CAAC;IAED,MAAM,CAAI,MAAe,EAAE,EAAoB,EAAE,OAAqB,EAAE;QACtE,MAAM,IAAI,GAAG,IAAA,gBAAO,EAAC,MAAM,CAAC,CAAC;QAE7B,IAAI,IAAI,CAAC,UAAU,IAAI,IAAI,CAAC,UAAU,KAAK,SAAS,EAAE;YACpD,IAAI,IAAI,CAAC,UAAU,EAAE;gBACnB,MAAM,QAAQ,GAAG,IAAI,CAAC,QAAQ,CAAC,MAAM,EAAE,EAAE,EAAE,IAAI,CAAC,CAAC;gBACjD,MAAM,KAAK,GAAG,IAAA,4BAAqB,EAAC,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC,QAAQ,CAAC,CAAC;gBAC3E,OAAO,UAAU,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,IAAI,CAAC,QAAQ,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,UAAU,CAAC,MAAM,IAAI,CAAC,MAAM,CAAC,KAAK,CAAC,GAAG,QAAQ,EAAE,CAAC;aACtH;iBAAM,IAAI,IAAI,CAAC,UAAU,EAAE;gBAC1B,MAAM,SAAS,CAAC,IAAI,IAAI,CAAC,IAAI,gCAAgC,CAAC,CAAC;aAChE;SACF;QAED,MAAM,QAAQ,GAAG,IAAI,CAAC,QAAQ,CAAC,MAAM,EAAE,EAAE,EAAE,IAAI,CAAC,CAAC;QAEjD,OAAO,eAAe,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,IAAI,CAAC,GAAG,QAAQ,EAAE,CAAC;IAC9D,CAAC;IAED,QAAQ,CAAC,GAAW,EAAE,eAAyB,EAAE,MAAgB;QAC/D,IAAI,CAAC,GAAG,EAAE;YACR,OAAO,EAAE,CAAC;SACX;QAED,IAAI,CAAC,eAAe,IAAI,GAAG,CAAC,QAAQ,CAAC,GAAG,CAAC,EAAE;YACzC,OAAO,GAAG;iBACP,KAAK,CAAC,GAAG,CAAC;iBACV,GAAG,CAAC,CAAC,EAAE,EAAE,EAAE,CAAC,IAAI,CAAC,QAAQ,CAAC,EAAE,CAAC,CAAC;iBAC9B,IAAI,CAAC,GAAG,CAAC,CAAC;SACd;QAED,0GAA0G;QAC1G,MAAM,OAAO,GAAG,IAAI,CAAC,YAAY,GAAG,GAAG,CAAC,OAAO,CAAC,IAAI,CAAC,aAAa,EAAE,IAAI,CAAC,YAAY,GAAG,IAAI,CAAC,YAAY,CAAC,GAAG,IAAI,CAAC,YAAY,CAAC;QAE/H,MAAM,MAAM,GAAG,MAAM,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,CAAC;QAEjC,OAAO,OAAO,GAAG,MAAM,CAAC;IAC1B,CAAC;IAED,MAAM,CAAC,KAAU;QACf,IAAI,KAAK,YAAY,UAAG,EAAE;YACxB,OAAO,IAAA,kBAAW,EAAC,EAAE,KAAK,EAAE,OAAO,EAAE,IAAI,EAAE,CAAC,CAAC;SAC9C;QACD,OAAO,IAAA,kBAAM,EAAC,KAAK,CAAC,CAAC;IACvB,CAAC;CACF;AAvaD,gDAuaC","sourcesContent":["import { escape } from 'sqlstring';\nimport { getMeta } from '@uql/core/entity';\nimport {\n  getPersistable,\n  getProjectRelationKeys,\n  getPersistables,\n  isProjectingRelations,\n  getKeys,\n  hasKeys,\n  buildSortMap,\n  flatObject,\n  getRawValue,\n  raw,\n  Raw,\n  getQueryFilterAsMap,\n  getFieldCallbackValue,\n} from '@uql/core/util';\n\nimport {\n  QueryFilter,\n  Query,\n  Scalar,\n  QueryFilterFieldOperatorMap,\n  QuerySort,\n  QueryPager,\n  QueryTextSearchOptions,\n  FieldKey,\n  QueryProject,\n  Type,\n  QueryCriteria,\n  QueryProjectArray,\n  QueryOptions,\n  QueryDialect,\n  QueryFilterOptions,\n  QueryComparisonOptions,\n  QueryFilterMap,\n  QuerySearch,\n  QueryProjectOptions,\n  QuerySortDirection,\n  QueryFilterLogical,\n} from '@uql/core/type';\n\nexport abstract class AbstractSqlDialect implements QueryDialect {\n  readonly escapeIdRegex: RegExp;\n\n  constructor(readonly escapeIdChar: '`' | '\"', readonly beginTransactionCommand: string) {\n    this.escapeIdRegex = RegExp(escapeIdChar, 'g');\n  }\n\n  criteria<E>(entity: Type<E>, qm: Query<E>, opts: QueryOptions = {}): string {\n    const meta = getMeta(entity);\n    const prefix = opts.prefix ?? (opts.autoPrefix || isProjectingRelations(meta, qm.$project)) ? meta.name : undefined;\n    const where = this.where<E>(entity, qm.$filter, { ...opts, prefix });\n    const group = this.group<E>(entity, qm.$group, { ...opts, prefix });\n    const having = this.where<E>(entity, qm.$having, { ...opts, prefix, clause: 'HAVING' });\n    const sort = this.sort<E>(entity, qm.$sort, { ...opts, prefix });\n    const pager = this.pager(qm);\n    return where + group + having + sort + pager;\n  }\n\n  projectFields<E>(entity: Type<E>, project: QueryProject<E>, opts: QueryProjectOptions = {}): string {\n    const meta = getMeta(entity);\n    const prefix = opts.prefix ? opts.prefix + '.' : '';\n    const escapedPrefix = this.escapeId(opts.prefix, true, true);\n\n    let fields: QueryProjectArray<E>;\n\n    if (project) {\n      if (Array.isArray(project)) {\n        fields = project;\n      } else {\n        const positiveProjectKeys = getKeys(project).filter((key) => project[key]);\n        fields = positiveProjectKeys.length\n          ? positiveProjectKeys.map((key) => {\n              const val = project[key];\n              if (val instanceof Raw) {\n                return raw(val.value, key);\n              }\n              return key as FieldKey<E>;\n            })\n          : (getKeys(meta.fields).filter((key) => !(key in project)) as FieldKey<E>[]);\n      }\n      fields = fields.filter((key) => key instanceof Raw || meta.fields[key as FieldKey<E>]);\n      if (!fields.length || (opts.prefix && !fields.includes(meta.id))) {\n        fields = [meta.id, ...fields];\n      }\n    } else {\n      fields = getKeys(meta.fields) as FieldKey<E>[];\n    }\n\n    return fields\n      .map((key) => {\n        if (key instanceof Raw) {\n          return getRawValue({\n            value: key,\n            dialect: this,\n            prefix,\n            escapedPrefix,\n            autoPrefixAlias: opts.autoPrefixAlias,\n          });\n        }\n\n        const field = meta.fields[key as FieldKey<E>];\n\n        if (field.virtual) {\n          return getRawValue({\n            value: field.virtual,\n            alias: key as string,\n            dialect: this,\n            prefix,\n            escapedPrefix,\n            autoPrefixAlias: opts.autoPrefixAlias,\n          });\n        }\n\n        const name = field?.name ?? (key as FieldKey<E>);\n        const fieldPath = `${escapedPrefix}${this.escapeId(name)}`;\n\n        return !opts.autoPrefixAlias && (name === key || !field) ? fieldPath : `${fieldPath} ${this.escapeId((prefix + key) as FieldKey<E>, true)}`;\n      })\n      .join(', ');\n  }\n\n  projectRelations<E>(entity: Type<E>, project: QueryProject<E> = {}, { prefix }: { prefix?: string } = {}): { fields: string; tables: string } {\n    const meta = getMeta(entity);\n    const relations = getProjectRelationKeys(meta, project);\n    const isProjectArray = Array.isArray(project);\n    let fields = '';\n    let tables = '';\n\n    for (const key of relations) {\n      const relOpts = meta.relations[key];\n\n      if (relOpts.cardinality === '1m' || relOpts.cardinality === 'mm') {\n        // '1m' and 'mm' should be resolved in a higher layer because they will need multiple queries\n        continue;\n      }\n\n      const joinRelAlias = prefix ? prefix + '.' + key : key;\n      const relEntity = relOpts.entity();\n      const relProject = project[key as string];\n      const relQuery = isProjectArray ? {} : Array.isArray(relProject) ? { $project: relProject } : relProject;\n\n      const relColumns = this.projectFields(relEntity, relQuery.$project, {\n        prefix: joinRelAlias,\n        autoPrefixAlias: true,\n      });\n\n      fields += ', ' + relColumns;\n\n      const { fields: subColumns, tables: subTables } = this.projectRelations(relEntity, relQuery.$project, {\n        prefix: joinRelAlias,\n      });\n\n      fields += subColumns;\n\n      const relMeta = getMeta(relEntity);\n      const relEntityName = this.escapeId(relMeta.name);\n      const relPath = prefix ? this.escapeId(prefix, true) : this.escapeId(meta.name);\n      const joinType = relQuery.$required ? 'INNER' : 'LEFT';\n      const joinAlias = this.escapeId(joinRelAlias, true);\n\n      tables += ` ${joinType} JOIN ${relEntityName} ${joinAlias} ON `;\n      tables += relOpts.references.map((it) => `${joinAlias}.${this.escapeId(it.foreign)} = ${relPath}.${this.escapeId(it.local)}`).join(' AND ');\n\n      if (relQuery.$filter) {\n        const filter = this.where(relEntity, relQuery.$filter, { prefix: key, clause: false });\n        tables += ` AND ${filter}`;\n      }\n\n      tables += subTables;\n    }\n\n    return { fields, tables };\n  }\n\n  select<E>(entity: Type<E>, qm: Query<E>, opts: QueryOptions = {}): string {\n    const meta = getMeta(entity);\n    const prefix = opts.prefix ?? (opts.autoPrefix || isProjectingRelations(meta, qm.$project)) ? meta.name : undefined;\n\n    const fields = this.projectFields(entity, qm.$project, { prefix });\n    const { fields: relationFields, tables } = this.projectRelations(entity, qm.$project);\n\n    return `SELECT ${fields}${relationFields} FROM ${this.escapeId(meta.name)}${tables}`;\n  }\n\n  where<E>(entity: Type<E>, filter: QueryFilter<E> = {}, opts: QueryFilterOptions = {}): string {\n    const meta = getMeta(entity);\n    const { usePrecedence, clause = 'WHERE', softDelete } = opts;\n\n    filter = getQueryFilterAsMap(meta, filter);\n\n    if (meta.softDelete && (softDelete || softDelete === undefined) && clause !== 'HAVING' && !filter[meta.softDelete as string]) {\n      filter[meta.softDelete as string] = null;\n    }\n\n    const entries = Object.entries(filter);\n\n    if (!entries.length) {\n      return '';\n    }\n\n    const options = { ...opts, usePrecedence: entries.length > 1 };\n\n    let sql = entries.map(([key, val]) => this.compare(entity, key as keyof QueryFilterMap<E>, val as any, options)).join(` AND `);\n\n    if (usePrecedence) {\n      sql = `(${sql})`;\n    }\n\n    return clause ? ` ${clause} ${sql}` : sql;\n  }\n\n  compare<E, K extends keyof QueryFilterMap<E>>(entity: Type<E>, key: K, val: QueryFilterMap<E>[K], opts?: QueryComparisonOptions): string {\n    const meta = getMeta(entity);\n\n    if (val instanceof Raw) {\n      if (key === '$exists' || key === '$nexists') {\n        const value = val as Raw;\n        const query = getRawValue({\n          value,\n          dialect: this,\n          prefix: meta.name,\n          escapedPrefix: this.escapeId(meta.name, false, true),\n        });\n        return `${key === '$exists' ? 'EXISTS' : 'NOT EXISTS'} (${query})`;\n      }\n      const comparisonKey = this.getComparisonKey(entity, key as FieldKey<E>, opts);\n      return `${comparisonKey} = ${val.value}`;\n    }\n\n    if (key === '$text') {\n      const search = val as QueryTextSearchOptions<E>;\n      const fields = search.$fields.map((field) => this.escapeId(meta.fields[field]?.name ?? field));\n      return `${this.escapeId(meta.name)} MATCH {${fields.join(' ')}} : ${this.escape(search.$value)}`;\n    }\n\n    if (key === '$and' || key === '$or' || key === '$not' || key === '$nor') {\n      const negateOperatorMap = {\n        $not: '$and',\n        $nor: '$or',\n      } as const;\n\n      const op: '$and' | '$or' = negateOperatorMap[key as string] ?? key;\n      const negate = key in negateOperatorMap ? 'NOT ' : '';\n\n      const values = val as QueryFilterLogical<E>;\n      const hasManyItems = values.length > 1;\n      const logicalComparison = values\n        .map((filterEntry) => {\n          if (filterEntry instanceof Raw) {\n            return getRawValue({\n              value: filterEntry,\n              dialect: this,\n              prefix: opts.prefix,\n              escapedPrefix: this.escapeId(opts.prefix, true, true),\n            });\n          }\n          return this.where(entity, filterEntry, {\n            prefix: opts.prefix,\n            usePrecedence: hasManyItems && !Array.isArray(filterEntry) && getKeys(filterEntry).length > 1,\n            clause: false,\n          });\n        })\n        .join(op === '$or' ? ' OR ' : ' AND ');\n\n      return (opts.usePrecedence || negate) && hasManyItems ? `${negate}(${logicalComparison})` : `${negate}${logicalComparison}`;\n    }\n\n    const value = Array.isArray(val) ? { $in: val } : typeof val === 'object' && val !== null ? val : { $eq: val };\n    const operators = getKeys(value) as (keyof QueryFilterFieldOperatorMap<E>)[];\n    const comparisons = operators.map((op) => this.compareFieldOperator(entity, key as FieldKey<E>, op, value[op], opts)).join(' AND ');\n\n    return operators.length > 1 ? `(${comparisons})` : comparisons;\n  }\n\n  compareFieldOperator<E, K extends keyof QueryFilterFieldOperatorMap<E>>(\n    entity: Type<E>,\n    key: FieldKey<E>,\n    op: K,\n    val: QueryFilterFieldOperatorMap<E>[K],\n    opts?: QueryOptions\n  ): string {\n    const comparisonKey = this.getComparisonKey(entity, key, opts);\n    switch (op) {\n      case '$eq':\n        return val === null ? `${comparisonKey} IS NULL` : `${comparisonKey} = ${this.escape(val)}`;\n      case '$ne':\n        return val === null ? `${comparisonKey} IS NOT NULL` : `${comparisonKey} <> ${this.escape(val)}`;\n      case '$not':\n        return this.compare(entity, '$not', [{ [key]: val }] as any, opts);\n      case '$gt':\n        return `${comparisonKey} > ${this.escape(val)}`;\n      case '$gte':\n        return `${comparisonKey} >= ${this.escape(val)}`;\n      case '$lt':\n        return `${comparisonKey} < ${this.escape(val)}`;\n      case '$lte':\n        return `${comparisonKey} <= ${this.escape(val)}`;\n      case '$startsWith':\n        return `${comparisonKey} LIKE ${this.escape(`${val}%`)}`;\n      case '$istartsWith':\n        return `LOWER(${comparisonKey}) LIKE ${this.escape((val as string).toLowerCase() + '%')}`;\n      case '$endsWith':\n        return `${comparisonKey} LIKE ${this.escape(`%${val}`)}`;\n      case '$iendsWith':\n        return `LOWER(${comparisonKey}) LIKE ${this.escape('%' + (val as string).toLowerCase())}`;\n      case '$includes':\n        return `${comparisonKey} LIKE ${this.escape(`%${val}%`)}`;\n      case '$iincludes':\n        return `LOWER(${comparisonKey}) LIKE ${this.escape('%' + (val as string).toLowerCase() + '%')}`;\n      case '$ilike':\n        return `LOWER(${comparisonKey}) LIKE ${this.escape((val as string).toLowerCase())}`;\n      case '$like':\n        return `${comparisonKey} LIKE ${this.escape(val)}`;\n      case '$in':\n        return `${comparisonKey} IN (${this.escape(val)})`;\n      case '$nin':\n        return `${comparisonKey} NOT IN (${this.escape(val)})`;\n      case '$regex':\n        return `${comparisonKey} REGEXP ${this.escape(val)}`;\n      default:\n        throw TypeError(`unknown operator: ${op}`);\n    }\n  }\n\n  getComparisonKey<E>(entity: Type<E>, key: FieldKey<E>, { prefix }: QueryOptions = {}): Scalar {\n    const meta = getMeta(entity);\n    const escapedPrefix = this.escapeId(prefix, true, true);\n    const field = meta.fields[key];\n\n    if (field?.virtual) {\n      return getRawValue({\n        value: field.virtual,\n        dialect: this,\n        prefix,\n        escapedPrefix,\n      });\n    }\n\n    return escapedPrefix + this.escapeId(field?.name ?? key);\n  }\n\n  group<E>(entity: Type<E>, fields: readonly FieldKey<E>[], opts: QueryOptions = {}): string {\n    if (!fields?.length) {\n      return '';\n    }\n    const meta = getMeta(entity);\n    const names = fields.map((key) => this.escapeId(meta.fields[key]?.name ?? key)).join(', ');\n    return ` GROUP BY ${names}`;\n  }\n\n  sort<E>(entity: Type<E>, sort: QuerySort<E>, { prefix }: QueryOptions = {}): string {\n    const sortMap = buildSortMap(sort);\n    if (!hasKeys(sortMap)) {\n      return '';\n    }\n    const meta = getMeta(entity);\n    const flattenedSort = flatObject(sortMap, prefix);\n    const directionMap = { 1: '', asc: '', '-1': ' DESC', desc: ' DESC' } as const;\n    const order = Object.entries(flattenedSort)\n      .map(([key, sort]) => {\n        const name = meta.fields[key]?.name ?? key;\n        const direction = directionMap[sort as QuerySortDirection];\n        return this.escapeId(name) + direction;\n      })\n      .join(', ');\n    return ` ORDER BY ${order}`;\n  }\n\n  pager(opts: QueryPager): string {\n    let sql = '';\n    if (opts.$limit) {\n      sql += ` LIMIT ${Number(opts.$limit)}`;\n    }\n    if (opts.$skip !== undefined) {\n      sql += ` OFFSET ${Number(opts.$skip)}`;\n    }\n    return sql;\n  }\n\n  count<E>(entity: Type<E>, qm: QuerySearch<E>, opts?: QueryOptions): string {\n    const search: Query<E> = {\n      ...qm,\n      $project: [raw('COUNT(*)', 'count')],\n    };\n\n    delete search.$sort;\n    delete search.$skip;\n    delete search.$limit;\n\n    const select = this.select<E>(entity, search);\n    const criteria = this.criteria(entity, search, opts);\n\n    return select + criteria;\n  }\n\n  find<E>(entity: Type<E>, qm: Query<E>, opts?: QueryOptions): string {\n    const select = this.select<E>(entity, qm, opts);\n    const criteria = this.criteria(entity, qm, opts);\n    return select + criteria;\n  }\n\n  insert<E>(entity: Type<E>, payload: E | E[]): string {\n    const meta = getMeta(entity);\n    const records = getPersistables(meta, payload, 'onInsert');\n    const keys = getKeys(records[0]);\n    const columns = keys.map((key) => this.escapeId(meta.fields[key].name));\n    const values = records.map((record) => keys.map((key) => this.escape(record[key])).join(', ')).join('), (');\n    return `INSERT INTO ${this.escapeId(meta.name)} (${columns.join(', ')}) VALUES (${values})`;\n  }\n\n  update<E>(entity: Type<E>, qm: QueryCriteria<E>, payload: E, opts?: QueryOptions): string {\n    const meta = getMeta(entity);\n    const record = getPersistable(meta, payload, 'onUpdate');\n    const keys = getKeys(record);\n    const entries = keys.map((key) => `${this.escapeId(key)} = ${this.escape(payload[key])}`).join(', ');\n    const criteria = this.criteria(entity, qm, opts);\n    return `UPDATE ${this.escapeId(meta.name)} SET ${entries}${criteria}`;\n  }\n\n  delete<E>(entity: Type<E>, qm: QueryCriteria<E>, opts: QueryOptions = {}): string {\n    const meta = getMeta(entity);\n\n    if (opts.softDelete || opts.softDelete === undefined) {\n      if (meta.softDelete) {\n        const criteria = this.criteria(entity, qm, opts);\n        const value = getFieldCallbackValue(meta.fields[meta.softDelete].onDelete);\n        return `UPDATE ${this.escapeId(meta.name)} SET ${this.escapeId(meta.softDelete)} = ${this.escape(value)}${criteria}`;\n      } else if (opts.softDelete) {\n        throw TypeError(`'${meta.name}' has not enabled 'softDelete'`);\n      }\n    }\n\n    const criteria = this.criteria(entity, qm, opts);\n\n    return `DELETE FROM ${this.escapeId(meta.name)}${criteria}`;\n  }\n\n  escapeId(val: string, forbidQualified?: boolean, addDot?: boolean): string {\n    if (!val) {\n      return '';\n    }\n\n    if (!forbidQualified && val.includes('.')) {\n      return val\n        .split('.')\n        .map((it) => this.escapeId(it))\n        .join('.');\n    }\n\n    // sourced from 'escapeId' function here https://github.com/mysqljs/sqlstring/blob/master/lib/SqlString.js\n    const escaped = this.escapeIdChar + val.replace(this.escapeIdRegex, this.escapeIdChar + this.escapeIdChar) + this.escapeIdChar;\n\n    const suffix = addDot ? '.' : '';\n\n    return escaped + suffix;\n  }\n\n  escape(value: any): Scalar {\n    if (value instanceof Raw) {\n      return getRawValue({ value, dialect: this });\n    }\n    return escape(value);\n  }\n}\n"]}
@@ -1,4 +1,6 @@
1
+ import { QueryComparisonOptions, QueryFilterMap, Type } from '../type';
1
2
  import { AbstractSqlDialect } from './abstractSqlDialect';
2
3
  export declare class MySqlDialect extends AbstractSqlDialect {
3
4
  constructor();
5
+ compare<E, K extends keyof QueryFilterMap<E>>(entity: Type<E>, key: K, val: QueryFilterMap<E>[K], opts?: QueryComparisonOptions): string;
4
6
  }
@@ -1,11 +1,21 @@
1
1
  "use strict";
2
2
  Object.defineProperty(exports, "__esModule", { value: true });
3
3
  exports.MySqlDialect = void 0;
4
+ const entity_1 = require("../entity");
4
5
  const abstractSqlDialect_1 = require("./abstractSqlDialect");
5
6
  class MySqlDialect extends abstractSqlDialect_1.AbstractSqlDialect {
6
7
  constructor() {
7
- super('START TRANSACTION', '`');
8
+ super('`', 'START TRANSACTION');
9
+ }
10
+ compare(entity, key, val, opts) {
11
+ if (key === '$text') {
12
+ const meta = (0, entity_1.getMeta)(entity);
13
+ const search = val;
14
+ const fields = search.$fields.map((field) => { var _a, _b; return this.escapeId((_b = (_a = meta.fields[field]) === null || _a === void 0 ? void 0 : _a.name) !== null && _b !== void 0 ? _b : field); });
15
+ return `MATCH(${fields.join(', ')}) AGAINST(${this.escape(search.$value)})`;
16
+ }
17
+ return super.compare(entity, key, val, opts);
8
18
  }
9
19
  }
10
20
  exports.MySqlDialect = MySqlDialect;
11
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibXlzcWxEaWFsZWN0LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vc3JjL2RpYWxlY3QvbXlzcWxEaWFsZWN0LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7OztBQUFBLDZEQUEwRDtBQUUxRCxNQUFhLFlBQWEsU0FBUSx1Q0FBa0I7SUFDbEQ7UUFDRSxLQUFLLENBQUMsbUJBQW1CLEVBQUUsR0FBRyxDQUFDLENBQUM7SUFDbEMsQ0FBQztDQUNGO0FBSkQsb0NBSUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBBYnN0cmFjdFNxbERpYWxlY3QgfSBmcm9tICcuL2Fic3RyYWN0U3FsRGlhbGVjdCc7XG5cbmV4cG9ydCBjbGFzcyBNeVNxbERpYWxlY3QgZXh0ZW5kcyBBYnN0cmFjdFNxbERpYWxlY3Qge1xuICBjb25zdHJ1Y3RvcigpIHtcbiAgICBzdXBlcignU1RBUlQgVFJBTlNBQ1RJT04nLCAnYCcpO1xuICB9XG59XG4iXX0=
21
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibXlzcWxEaWFsZWN0LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vc3JjL2RpYWxlY3QvbXlzcWxEaWFsZWN0LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7OztBQUFBLHNDQUFvQztBQUVwQyw2REFBMEQ7QUFFMUQsTUFBYSxZQUFhLFNBQVEsdUNBQWtCO0lBQ2xEO1FBQ0UsS0FBSyxDQUFDLEdBQUcsRUFBRSxtQkFBbUIsQ0FBQyxDQUFDO0lBQ2xDLENBQUM7SUFFUSxPQUFPLENBQXVDLE1BQWUsRUFBRSxHQUFNLEVBQUUsR0FBeUIsRUFBRSxJQUE2QjtRQUN0SSxJQUFJLEdBQUcsS0FBSyxPQUFPLEVBQUU7WUFDbkIsTUFBTSxJQUFJLEdBQUcsSUFBQSxnQkFBTyxFQUFDLE1BQU0sQ0FBQyxDQUFDO1lBQzdCLE1BQU0sTUFBTSxHQUFHLEdBQWdDLENBQUM7WUFDaEQsTUFBTSxNQUFNLEdBQUcsTUFBTSxDQUFDLE9BQU8sQ0FBQyxHQUFHLENBQUMsQ0FBQyxLQUFLLEVBQUUsRUFBRSxlQUFDLE9BQUEsSUFBSSxDQUFDLFFBQVEsQ0FBQyxNQUFBLE1BQUEsSUFBSSxDQUFDLE1BQU0sQ0FBQyxLQUFLLENBQUMsMENBQUUsSUFBSSxtQ0FBSSxLQUFLLENBQUMsQ0FBQSxFQUFBLENBQUMsQ0FBQztZQUMvRixPQUFPLFNBQVMsTUFBTSxDQUFDLElBQUksQ0FBQyxJQUFJLENBQUMsYUFBYSxJQUFJLENBQUMsTUFBTSxDQUFDLE1BQU0sQ0FBQyxNQUFNLENBQUMsR0FBRyxDQUFDO1NBQzdFO1FBQ0QsT0FBTyxLQUFLLENBQUMsT0FBTyxDQUFDLE1BQU0sRUFBRSxHQUFHLEVBQUUsR0FBRyxFQUFFLElBQUksQ0FBQyxDQUFDO0lBQy9DLENBQUM7Q0FDRjtBQWRELG9DQWNDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgZ2V0TWV0YSB9IGZyb20gJy4uL2VudGl0eSc7XG5pbXBvcnQgeyBRdWVyeUNvbXBhcmlzb25PcHRpb25zLCBRdWVyeUZpbHRlck1hcCwgUXVlcnlUZXh0U2VhcmNoT3B0aW9ucywgVHlwZSB9IGZyb20gJy4uL3R5cGUnO1xuaW1wb3J0IHsgQWJzdHJhY3RTcWxEaWFsZWN0IH0gZnJvbSAnLi9hYnN0cmFjdFNxbERpYWxlY3QnO1xuXG5leHBvcnQgY2xhc3MgTXlTcWxEaWFsZWN0IGV4dGVuZHMgQWJzdHJhY3RTcWxEaWFsZWN0IHtcbiAgY29uc3RydWN0b3IoKSB7XG4gICAgc3VwZXIoJ2AnLCAnU1RBUlQgVFJBTlNBQ1RJT04nKTtcbiAgfVxuXG4gIG92ZXJyaWRlIGNvbXBhcmU8RSwgSyBleHRlbmRzIGtleW9mIFF1ZXJ5RmlsdGVyTWFwPEU+PihlbnRpdHk6IFR5cGU8RT4sIGtleTogSywgdmFsOiBRdWVyeUZpbHRlck1hcDxFPltLXSwgb3B0cz86IFF1ZXJ5Q29tcGFyaXNvbk9wdGlvbnMpOiBzdHJpbmcge1xuICAgIGlmIChrZXkgPT09ICckdGV4dCcpIHtcbiAgICAgIGNvbnN0IG1ldGEgPSBnZXRNZXRhKGVudGl0eSk7XG4gICAgICBjb25zdCBzZWFyY2ggPSB2YWwgYXMgUXVlcnlUZXh0U2VhcmNoT3B0aW9uczxFPjtcbiAgICAgIGNvbnN0IGZpZWxkcyA9IHNlYXJjaC4kZmllbGRzLm1hcCgoZmllbGQpID0+IHRoaXMuZXNjYXBlSWQobWV0YS5maWVsZHNbZmllbGRdPy5uYW1lID8/IGZpZWxkKSk7XG4gICAgICByZXR1cm4gYE1BVENIKCR7ZmllbGRzLmpvaW4oJywgJyl9KSBBR0FJTlNUKCR7dGhpcy5lc2NhcGUoc2VhcmNoLiR2YWx1ZSl9KWA7XG4gICAgfVxuICAgIHJldHVybiBzdXBlci5jb21wYXJlKGVudGl0eSwga2V5LCB2YWwsIG9wdHMpO1xuICB9XG59XG4iXX0=
@@ -5,7 +5,7 @@ const entity_1 = require("@uql/core/entity");
5
5
  const abstractSqlDialect_1 = require("./abstractSqlDialect");
6
6
  class PostgresDialect extends abstractSqlDialect_1.AbstractSqlDialect {
7
7
  constructor() {
8
- super('BEGIN TRANSACTION', '"');
8
+ super('"', 'BEGIN TRANSACTION');
9
9
  }
10
10
  insert(entity, payload) {
11
11
  const sql = super.insert(entity, payload);
@@ -41,4 +41,4 @@ class PostgresDialect extends abstractSqlDialect_1.AbstractSqlDialect {
41
41
  }
42
42
  }
43
43
  exports.PostgresDialect = PostgresDialect;
44
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicG9zdGdyZXNEaWFsZWN0LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vc3JjL2RpYWxlY3QvcG9zdGdyZXNEaWFsZWN0LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7OztBQUFBLDZDQUEyQztBQVUzQyw2REFBMEQ7QUFFMUQsTUFBYSxlQUFnQixTQUFRLHVDQUFrQjtJQUNyRDtRQUNFLEtBQUssQ0FBQyxtQkFBbUIsRUFBRSxHQUFHLENBQUMsQ0FBQztJQUNsQyxDQUFDO0lBRVEsTUFBTSxDQUFJLE1BQWUsRUFBRSxPQUFnQjtRQUNsRCxNQUFNLEdBQUcsR0FBRyxLQUFLLENBQUMsTUFBTSxDQUFDLE1BQU0sRUFBRSxPQUFPLENBQUMsQ0FBQztRQUMxQyxNQUFNLElBQUksR0FBRyxJQUFBLGdCQUFPLEVBQUMsTUFBTSxDQUFDLENBQUM7UUFDN0IsTUFBTSxNQUFNLEdBQUcsSUFBSSxDQUFDLE1BQU0sQ0FBQyxJQUFJLENBQUMsRUFBRSxDQUFDLENBQUMsSUFBSSxDQUFDO1FBQ3pDLE9BQU8sR0FBRyxHQUFHLGNBQWMsSUFBSSxDQUFDLFFBQVEsQ0FBQyxNQUFNLENBQUMsSUFBSSxJQUFJLENBQUMsUUFBUSxDQUFDLElBQUksQ0FBQyxFQUFFLENBQUM7SUFDNUUsQ0FBQztJQUVRLE9BQU8sQ0FBdUMsTUFBZSxFQUFFLEdBQU0sRUFBRSxHQUF5QixFQUFFLElBQTZCO1FBQ3RJLElBQUksR0FBRyxLQUFLLE9BQU8sRUFBRTtZQUNuQixNQUFNLElBQUksR0FBRyxJQUFBLGdCQUFPLEVBQUMsTUFBTSxDQUFDLENBQUM7WUFDN0IsTUFBTSxNQUFNLEdBQUcsR0FBZ0MsQ0FBQztZQUNoRCxNQUFNLE1BQU0sR0FBRyxNQUFNLENBQUMsT0FBTyxDQUFDLEdBQUcsQ0FBQyxDQUFDLEtBQUssRUFBRSxFQUFFLGVBQUMsT0FBQSxJQUFJLENBQUMsUUFBUSxDQUFDLE1BQUEsTUFBQSxJQUFJLENBQUMsTUFBTSxDQUFDLEtBQUssQ0FBQywwQ0FBRSxJQUFJLG1DQUFJLEtBQUssQ0FBQyxDQUFBLEVBQUEsQ0FBQyxDQUFDLElBQUksQ0FBQyxhQUFhLENBQUMsQ0FBQztZQUNuSCxPQUFPLGVBQWUsTUFBTSxtQkFBbUIsSUFBSSxDQUFDLE1BQU0sQ0FBQyxNQUFNLENBQUMsTUFBTSxDQUFDLEdBQUcsQ0FBQztTQUM5RTtRQUNELE9BQU8sS0FBSyxDQUFDLE9BQU8sQ0FBQyxNQUFNLEVBQUUsR0FBRyxFQUFFLEdBQUcsRUFBRSxJQUFJLENBQUMsQ0FBQztJQUMvQyxDQUFDO0lBRVEsb0JBQW9CLENBQzNCLE1BQWUsRUFDZixHQUFnQixFQUNoQixFQUFLLEVBQ0wsR0FBc0MsRUFDdEMsSUFBbUI7UUFFbkIsTUFBTSxhQUFhLEdBQUcsSUFBSSxDQUFDLGdCQUFnQixDQUFDLE1BQU0sRUFBRSxHQUFHLEVBQUUsSUFBSSxDQUFDLENBQUM7UUFDL0QsUUFBUSxFQUFFLEVBQUU7WUFDVixLQUFLLGNBQWM7Z0JBQ2pCLE9BQU8sR0FBRyxhQUFhLFVBQVUsSUFBSSxDQUFDLE1BQU0sQ0FBQyxHQUFHLEdBQUcsR0FBRyxDQUFDLEVBQUUsQ0FBQztZQUM1RCxLQUFLLFlBQVk7Z0JBQ2YsT0FBTyxHQUFHLGFBQWEsVUFBVSxJQUFJLENBQUMsTUFBTSxDQUFDLElBQUksR0FBRyxFQUFFLENBQUMsRUFBRSxDQUFDO1lBQzVELEtBQUssWUFBWTtnQkFDZixPQUFPLEdBQUcsYUFBYSxVQUFVLElBQUksQ0FBQyxNQUFNLENBQUMsSUFBSSxHQUFHLEdBQUcsQ0FBQyxFQUFFLENBQUM7WUFDN0QsS0FBSyxRQUFRO2dCQUNYLE9BQU8sR0FBRyxhQUFhLFVBQVUsSUFBSSxDQUFDLE1BQU0sQ0FBQyxHQUFHLENBQUMsRUFBRSxDQUFDO1lBQ3RELEtBQUssUUFBUTtnQkFDWCxPQUFPLEdBQUcsYUFBYSxNQUFNLElBQUksQ0FBQyxNQUFNLENBQUMsR0FBRyxDQUFDLEVBQUUsQ0FBQztZQUNsRDtnQkFDRSxPQUFPLEtBQUssQ0FBQyxvQkFBb0IsQ0FBQyxNQUFNLEVBQUUsR0FBRyxFQUFFLEVBQUUsRUFBRSxHQUFHLEVBQUUsSUFBSSxDQUFDLENBQUM7U0FDakU7SUFDSCxDQUFDO0NBQ0Y7QUE3Q0QsMENBNkNDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgZ2V0TWV0YSB9IGZyb20gJ0B1cWwvY29yZS9lbnRpdHknO1xuaW1wb3J0IHtcbiAgUXVlcnlDb21wYXJpc29uT3B0aW9ucyxcbiAgUXVlcnlGaWx0ZXJNYXAsXG4gIFF1ZXJ5T3B0aW9ucyxcbiAgUXVlcnlGaWx0ZXJGaWVsZE9wZXJhdG9yTWFwLFxuICBRdWVyeVRleHRTZWFyY2hPcHRpb25zLFxuICBUeXBlLFxuICBGaWVsZEtleSxcbn0gZnJvbSAnQHVxbC9jb3JlL3R5cGUnO1xuaW1wb3J0IHsgQWJzdHJhY3RTcWxEaWFsZWN0IH0gZnJvbSAnLi9hYnN0cmFjdFNxbERpYWxlY3QnO1xuXG5leHBvcnQgY2xhc3MgUG9zdGdyZXNEaWFsZWN0IGV4dGVuZHMgQWJzdHJhY3RTcWxEaWFsZWN0IHtcbiAgY29uc3RydWN0b3IoKSB7XG4gICAgc3VwZXIoJ0JFR0lOIFRSQU5TQUNUSU9OJywgJ1wiJyk7XG4gIH1cblxuICBvdmVycmlkZSBpbnNlcnQ8RT4oZW50aXR5OiBUeXBlPEU+LCBwYXlsb2FkOiBFIHwgRVtdKTogc3RyaW5nIHtcbiAgICBjb25zdCBzcWwgPSBzdXBlci5pbnNlcnQoZW50aXR5LCBwYXlsb2FkKTtcbiAgICBjb25zdCBtZXRhID0gZ2V0TWV0YShlbnRpdHkpO1xuICAgIGNvbnN0IGlkTmFtZSA9IG1ldGEuZmllbGRzW21ldGEuaWRdLm5hbWU7XG4gICAgcmV0dXJuIGAke3NxbH0gUkVUVVJOSU5HICR7dGhpcy5lc2NhcGVJZChpZE5hbWUpfSAke3RoaXMuZXNjYXBlSWQoJ2lkJyl9YDtcbiAgfVxuXG4gIG92ZXJyaWRlIGNvbXBhcmU8RSwgSyBleHRlbmRzIGtleW9mIFF1ZXJ5RmlsdGVyTWFwPEU+PihlbnRpdHk6IFR5cGU8RT4sIGtleTogSywgdmFsOiBRdWVyeUZpbHRlck1hcDxFPltLXSwgb3B0cz86IFF1ZXJ5Q29tcGFyaXNvbk9wdGlvbnMpOiBzdHJpbmcge1xuICAgIGlmIChrZXkgPT09ICckdGV4dCcpIHtcbiAgICAgIGNvbnN0IG1ldGEgPSBnZXRNZXRhKGVudGl0eSk7XG4gICAgICBjb25zdCBzZWFyY2ggPSB2YWwgYXMgUXVlcnlUZXh0U2VhcmNoT3B0aW9uczxFPjtcbiAgICAgIGNvbnN0IGZpZWxkcyA9IHNlYXJjaC4kZmllbGRzLm1hcCgoZmllbGQpID0+IHRoaXMuZXNjYXBlSWQobWV0YS5maWVsZHNbZmllbGRdPy5uYW1lID8/IGZpZWxkKSkuam9pbihgIHx8ICcgJyB8fCBgKTtcbiAgICAgIHJldHVybiBgdG9fdHN2ZWN0b3IoJHtmaWVsZHN9KSBAQCB0b190c3F1ZXJ5KCR7dGhpcy5lc2NhcGUoc2VhcmNoLiR2YWx1ZSl9KWA7XG4gICAgfVxuICAgIHJldHVybiBzdXBlci5jb21wYXJlKGVudGl0eSwga2V5LCB2YWwsIG9wdHMpO1xuICB9XG5cbiAgb3ZlcnJpZGUgY29tcGFyZUZpZWxkT3BlcmF0b3I8RSwgSyBleHRlbmRzIGtleW9mIFF1ZXJ5RmlsdGVyRmllbGRPcGVyYXRvck1hcDxFPj4oXG4gICAgZW50aXR5OiBUeXBlPEU+LFxuICAgIGtleTogRmllbGRLZXk8RT4sXG4gICAgb3A6IEssXG4gICAgdmFsOiBRdWVyeUZpbHRlckZpZWxkT3BlcmF0b3JNYXA8RT5bS10sXG4gICAgb3B0cz86IFF1ZXJ5T3B0aW9uc1xuICApOiBzdHJpbmcge1xuICAgIGNvbnN0IGNvbXBhcmlzb25LZXkgPSB0aGlzLmdldENvbXBhcmlzb25LZXkoZW50aXR5LCBrZXksIG9wdHMpO1xuICAgIHN3aXRjaCAob3ApIHtcbiAgICAgIGNhc2UgJyRpc3RhcnRzV2l0aCc6XG4gICAgICAgIHJldHVybiBgJHtjb21wYXJpc29uS2V5fSBJTElLRSAke3RoaXMuZXNjYXBlKGAke3ZhbH0lYCl9YDtcbiAgICAgIGNhc2UgJyRpZW5kc1dpdGgnOlxuICAgICAgICByZXR1cm4gYCR7Y29tcGFyaXNvbktleX0gSUxJS0UgJHt0aGlzLmVzY2FwZShgJSR7dmFsfWApfWA7XG4gICAgICBjYXNlICckaWluY2x1ZGVzJzpcbiAgICAgICAgcmV0dXJuIGAke2NvbXBhcmlzb25LZXl9IElMSUtFICR7dGhpcy5lc2NhcGUoYCUke3ZhbH0lYCl9YDtcbiAgICAgIGNhc2UgJyRpbGlrZSc6XG4gICAgICAgIHJldHVybiBgJHtjb21wYXJpc29uS2V5fSBJTElLRSAke3RoaXMuZXNjYXBlKHZhbCl9YDtcbiAgICAgIGNhc2UgJyRyZWdleCc6XG4gICAgICAgIHJldHVybiBgJHtjb21wYXJpc29uS2V5fSB+ICR7dGhpcy5lc2NhcGUodmFsKX1gO1xuICAgICAgZGVmYXVsdDpcbiAgICAgICAgcmV0dXJuIHN1cGVyLmNvbXBhcmVGaWVsZE9wZXJhdG9yKGVudGl0eSwga2V5LCBvcCwgdmFsLCBvcHRzKTtcbiAgICB9XG4gIH1cbn1cbiJdfQ==
44
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicG9zdGdyZXNEaWFsZWN0LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vc3JjL2RpYWxlY3QvcG9zdGdyZXNEaWFsZWN0LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7OztBQUFBLDZDQUEyQztBQVUzQyw2REFBMEQ7QUFFMUQsTUFBYSxlQUFnQixTQUFRLHVDQUFrQjtJQUNyRDtRQUNFLEtBQUssQ0FBQyxHQUFHLEVBQUUsbUJBQW1CLENBQUMsQ0FBQztJQUNsQyxDQUFDO0lBRVEsTUFBTSxDQUFJLE1BQWUsRUFBRSxPQUFnQjtRQUNsRCxNQUFNLEdBQUcsR0FBRyxLQUFLLENBQUMsTUFBTSxDQUFDLE1BQU0sRUFBRSxPQUFPLENBQUMsQ0FBQztRQUMxQyxNQUFNLElBQUksR0FBRyxJQUFBLGdCQUFPLEVBQUMsTUFBTSxDQUFDLENBQUM7UUFDN0IsTUFBTSxNQUFNLEdBQUcsSUFBSSxDQUFDLE1BQU0sQ0FBQyxJQUFJLENBQUMsRUFBRSxDQUFDLENBQUMsSUFBSSxDQUFDO1FBQ3pDLE9BQU8sR0FBRyxHQUFHLGNBQWMsSUFBSSxDQUFDLFFBQVEsQ0FBQyxNQUFNLENBQUMsSUFBSSxJQUFJLENBQUMsUUFBUSxDQUFDLElBQUksQ0FBQyxFQUFFLENBQUM7SUFDNUUsQ0FBQztJQUVRLE9BQU8sQ0FBdUMsTUFBZSxFQUFFLEdBQU0sRUFBRSxHQUF5QixFQUFFLElBQTZCO1FBQ3RJLElBQUksR0FBRyxLQUFLLE9BQU8sRUFBRTtZQUNuQixNQUFNLElBQUksR0FBRyxJQUFBLGdCQUFPLEVBQUMsTUFBTSxDQUFDLENBQUM7WUFDN0IsTUFBTSxNQUFNLEdBQUcsR0FBZ0MsQ0FBQztZQUNoRCxNQUFNLE1BQU0sR0FBRyxNQUFNLENBQUMsT0FBTyxDQUFDLEdBQUcsQ0FBQyxDQUFDLEtBQUssRUFBRSxFQUFFLGVBQUMsT0FBQSxJQUFJLENBQUMsUUFBUSxDQUFDLE1BQUEsTUFBQSxJQUFJLENBQUMsTUFBTSxDQUFDLEtBQUssQ0FBQywwQ0FBRSxJQUFJLG1DQUFJLEtBQUssQ0FBQyxDQUFBLEVBQUEsQ0FBQyxDQUFDLElBQUksQ0FBQyxhQUFhLENBQUMsQ0FBQztZQUNuSCxPQUFPLGVBQWUsTUFBTSxtQkFBbUIsSUFBSSxDQUFDLE1BQU0sQ0FBQyxNQUFNLENBQUMsTUFBTSxDQUFDLEdBQUcsQ0FBQztTQUM5RTtRQUNELE9BQU8sS0FBSyxDQUFDLE9BQU8sQ0FBQyxNQUFNLEVBQUUsR0FBRyxFQUFFLEdBQUcsRUFBRSxJQUFJLENBQUMsQ0FBQztJQUMvQyxDQUFDO0lBRVEsb0JBQW9CLENBQzNCLE1BQWUsRUFDZixHQUFnQixFQUNoQixFQUFLLEVBQ0wsR0FBc0MsRUFDdEMsSUFBbUI7UUFFbkIsTUFBTSxhQUFhLEdBQUcsSUFBSSxDQUFDLGdCQUFnQixDQUFDLE1BQU0sRUFBRSxHQUFHLEVBQUUsSUFBSSxDQUFDLENBQUM7UUFDL0QsUUFBUSxFQUFFLEVBQUU7WUFDVixLQUFLLGNBQWM7Z0JBQ2pCLE9BQU8sR0FBRyxhQUFhLFVBQVUsSUFBSSxDQUFDLE1BQU0sQ0FBQyxHQUFHLEdBQUcsR0FBRyxDQUFDLEVBQUUsQ0FBQztZQUM1RCxLQUFLLFlBQVk7Z0JBQ2YsT0FBTyxHQUFHLGFBQWEsVUFBVSxJQUFJLENBQUMsTUFBTSxDQUFDLElBQUksR0FBRyxFQUFFLENBQUMsRUFBRSxDQUFDO1lBQzVELEtBQUssWUFBWTtnQkFDZixPQUFPLEdBQUcsYUFBYSxVQUFVLElBQUksQ0FBQyxNQUFNLENBQUMsSUFBSSxHQUFHLEdBQUcsQ0FBQyxFQUFFLENBQUM7WUFDN0QsS0FBSyxRQUFRO2dCQUNYLE9BQU8sR0FBRyxhQUFhLFVBQVUsSUFBSSxDQUFDLE1BQU0sQ0FBQyxHQUFHLENBQUMsRUFBRSxDQUFDO1lBQ3RELEtBQUssUUFBUTtnQkFDWCxPQUFPLEdBQUcsYUFBYSxNQUFNLElBQUksQ0FBQyxNQUFNLENBQUMsR0FBRyxDQUFDLEVBQUUsQ0FBQztZQUNsRDtnQkFDRSxPQUFPLEtBQUssQ0FBQyxvQkFBb0IsQ0FBQyxNQUFNLEVBQUUsR0FBRyxFQUFFLEVBQUUsRUFBRSxHQUFHLEVBQUUsSUFBSSxDQUFDLENBQUM7U0FDakU7SUFDSCxDQUFDO0NBQ0Y7QUE3Q0QsMENBNkNDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgZ2V0TWV0YSB9IGZyb20gJ0B1cWwvY29yZS9lbnRpdHknO1xuaW1wb3J0IHtcbiAgUXVlcnlDb21wYXJpc29uT3B0aW9ucyxcbiAgUXVlcnlGaWx0ZXJNYXAsXG4gIFF1ZXJ5T3B0aW9ucyxcbiAgUXVlcnlGaWx0ZXJGaWVsZE9wZXJhdG9yTWFwLFxuICBRdWVyeVRleHRTZWFyY2hPcHRpb25zLFxuICBUeXBlLFxuICBGaWVsZEtleSxcbn0gZnJvbSAnQHVxbC9jb3JlL3R5cGUnO1xuaW1wb3J0IHsgQWJzdHJhY3RTcWxEaWFsZWN0IH0gZnJvbSAnLi9hYnN0cmFjdFNxbERpYWxlY3QnO1xuXG5leHBvcnQgY2xhc3MgUG9zdGdyZXNEaWFsZWN0IGV4dGVuZHMgQWJzdHJhY3RTcWxEaWFsZWN0IHtcbiAgY29uc3RydWN0b3IoKSB7XG4gICAgc3VwZXIoJ1wiJywgJ0JFR0lOIFRSQU5TQUNUSU9OJyk7XG4gIH1cblxuICBvdmVycmlkZSBpbnNlcnQ8RT4oZW50aXR5OiBUeXBlPEU+LCBwYXlsb2FkOiBFIHwgRVtdKTogc3RyaW5nIHtcbiAgICBjb25zdCBzcWwgPSBzdXBlci5pbnNlcnQoZW50aXR5LCBwYXlsb2FkKTtcbiAgICBjb25zdCBtZXRhID0gZ2V0TWV0YShlbnRpdHkpO1xuICAgIGNvbnN0IGlkTmFtZSA9IG1ldGEuZmllbGRzW21ldGEuaWRdLm5hbWU7XG4gICAgcmV0dXJuIGAke3NxbH0gUkVUVVJOSU5HICR7dGhpcy5lc2NhcGVJZChpZE5hbWUpfSAke3RoaXMuZXNjYXBlSWQoJ2lkJyl9YDtcbiAgfVxuXG4gIG92ZXJyaWRlIGNvbXBhcmU8RSwgSyBleHRlbmRzIGtleW9mIFF1ZXJ5RmlsdGVyTWFwPEU+PihlbnRpdHk6IFR5cGU8RT4sIGtleTogSywgdmFsOiBRdWVyeUZpbHRlck1hcDxFPltLXSwgb3B0cz86IFF1ZXJ5Q29tcGFyaXNvbk9wdGlvbnMpOiBzdHJpbmcge1xuICAgIGlmIChrZXkgPT09ICckdGV4dCcpIHtcbiAgICAgIGNvbnN0IG1ldGEgPSBnZXRNZXRhKGVudGl0eSk7XG4gICAgICBjb25zdCBzZWFyY2ggPSB2YWwgYXMgUXVlcnlUZXh0U2VhcmNoT3B0aW9uczxFPjtcbiAgICAgIGNvbnN0IGZpZWxkcyA9IHNlYXJjaC4kZmllbGRzLm1hcCgoZmllbGQpID0+IHRoaXMuZXNjYXBlSWQobWV0YS5maWVsZHNbZmllbGRdPy5uYW1lID8/IGZpZWxkKSkuam9pbihgIHx8ICcgJyB8fCBgKTtcbiAgICAgIHJldHVybiBgdG9fdHN2ZWN0b3IoJHtmaWVsZHN9KSBAQCB0b190c3F1ZXJ5KCR7dGhpcy5lc2NhcGUoc2VhcmNoLiR2YWx1ZSl9KWA7XG4gICAgfVxuICAgIHJldHVybiBzdXBlci5jb21wYXJlKGVudGl0eSwga2V5LCB2YWwsIG9wdHMpO1xuICB9XG5cbiAgb3ZlcnJpZGUgY29tcGFyZUZpZWxkT3BlcmF0b3I8RSwgSyBleHRlbmRzIGtleW9mIFF1ZXJ5RmlsdGVyRmllbGRPcGVyYXRvck1hcDxFPj4oXG4gICAgZW50aXR5OiBUeXBlPEU+LFxuICAgIGtleTogRmllbGRLZXk8RT4sXG4gICAgb3A6IEssXG4gICAgdmFsOiBRdWVyeUZpbHRlckZpZWxkT3BlcmF0b3JNYXA8RT5bS10sXG4gICAgb3B0cz86IFF1ZXJ5T3B0aW9uc1xuICApOiBzdHJpbmcge1xuICAgIGNvbnN0IGNvbXBhcmlzb25LZXkgPSB0aGlzLmdldENvbXBhcmlzb25LZXkoZW50aXR5LCBrZXksIG9wdHMpO1xuICAgIHN3aXRjaCAob3ApIHtcbiAgICAgIGNhc2UgJyRpc3RhcnRzV2l0aCc6XG4gICAgICAgIHJldHVybiBgJHtjb21wYXJpc29uS2V5fSBJTElLRSAke3RoaXMuZXNjYXBlKGAke3ZhbH0lYCl9YDtcbiAgICAgIGNhc2UgJyRpZW5kc1dpdGgnOlxuICAgICAgICByZXR1cm4gYCR7Y29tcGFyaXNvbktleX0gSUxJS0UgJHt0aGlzLmVzY2FwZShgJSR7dmFsfWApfWA7XG4gICAgICBjYXNlICckaWluY2x1ZGVzJzpcbiAgICAgICAgcmV0dXJuIGAke2NvbXBhcmlzb25LZXl9IElMSUtFICR7dGhpcy5lc2NhcGUoYCUke3ZhbH0lYCl9YDtcbiAgICAgIGNhc2UgJyRpbGlrZSc6XG4gICAgICAgIHJldHVybiBgJHtjb21wYXJpc29uS2V5fSBJTElLRSAke3RoaXMuZXNjYXBlKHZhbCl9YDtcbiAgICAgIGNhc2UgJyRyZWdleCc6XG4gICAgICAgIHJldHVybiBgJHtjb21wYXJpc29uS2V5fSB+ICR7dGhpcy5lc2NhcGUodmFsKX1gO1xuICAgICAgZGVmYXVsdDpcbiAgICAgICAgcmV0dXJuIHN1cGVyLmNvbXBhcmVGaWVsZE9wZXJhdG9yKGVudGl0eSwga2V5LCBvcCwgdmFsLCBvcHRzKTtcbiAgICB9XG4gIH1cbn1cbiJdfQ==
@@ -1,6 +1,4 @@
1
- import { QueryComparisonOptions, QueryFilterMap, Type } from '../type';
2
1
  import { AbstractSqlDialect } from './abstractSqlDialect';
3
2
  export declare class SqliteDialect extends AbstractSqlDialect {
4
3
  constructor();
5
- compare<E, K extends keyof QueryFilterMap<E>>(entity: Type<E>, key: K, val: QueryFilterMap<E>[K], opts?: QueryComparisonOptions): string;
6
4
  }
@@ -1,20 +1,11 @@
1
1
  "use strict";
2
2
  Object.defineProperty(exports, "__esModule", { value: true });
3
3
  exports.SqliteDialect = void 0;
4
- const entity_1 = require("../entity");
5
4
  const abstractSqlDialect_1 = require("./abstractSqlDialect");
6
5
  class SqliteDialect extends abstractSqlDialect_1.AbstractSqlDialect {
7
6
  constructor() {
8
- super('BEGIN TRANSACTION', '`');
9
- }
10
- compare(entity, key, val, opts) {
11
- if (key === '$text') {
12
- const meta = (0, entity_1.getMeta)(entity);
13
- const search = val;
14
- return `${this.escapeId(meta.name)} MATCH ${this.escape(search.$value)}`;
15
- }
16
- return super.compare(entity, key, val, opts);
7
+ super('`', 'BEGIN TRANSACTION');
17
8
  }
18
9
  }
19
10
  exports.SqliteDialect = SqliteDialect;
20
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3FsaXRlRGlhbGVjdC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9kaWFsZWN0L3NxbGl0ZURpYWxlY3QudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7O0FBQUEsc0NBQW9DO0FBRXBDLDZEQUEwRDtBQUUxRCxNQUFhLGFBQWMsU0FBUSx1Q0FBa0I7SUFDbkQ7UUFDRSxLQUFLLENBQUMsbUJBQW1CLEVBQUUsR0FBRyxDQUFDLENBQUM7SUFDbEMsQ0FBQztJQUVRLE9BQU8sQ0FBdUMsTUFBZSxFQUFFLEdBQU0sRUFBRSxHQUF5QixFQUFFLElBQTZCO1FBQ3RJLElBQUksR0FBRyxLQUFLLE9BQU8sRUFBRTtZQUNuQixNQUFNLElBQUksR0FBRyxJQUFBLGdCQUFPLEVBQUMsTUFBTSxDQUFDLENBQUM7WUFDN0IsTUFBTSxNQUFNLEdBQUcsR0FBZ0MsQ0FBQztZQUNoRCxPQUFPLEdBQUcsSUFBSSxDQUFDLFFBQVEsQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUFDLFVBQVUsSUFBSSxDQUFDLE1BQU0sQ0FBQyxNQUFNLENBQUMsTUFBTSxDQUFDLEVBQUUsQ0FBQztTQUMxRTtRQUNELE9BQU8sS0FBSyxDQUFDLE9BQU8sQ0FBQyxNQUFNLEVBQUUsR0FBRyxFQUFFLEdBQUcsRUFBRSxJQUFJLENBQUMsQ0FBQztJQUMvQyxDQUFDO0NBQ0Y7QUFiRCxzQ0FhQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IGdldE1ldGEgfSBmcm9tICcuLi9lbnRpdHknO1xuaW1wb3J0IHsgUXVlcnlDb21wYXJpc29uT3B0aW9ucywgUXVlcnlGaWx0ZXJNYXAsIFF1ZXJ5VGV4dFNlYXJjaE9wdGlvbnMsIFR5cGUgfSBmcm9tICcuLi90eXBlJztcbmltcG9ydCB7IEFic3RyYWN0U3FsRGlhbGVjdCB9IGZyb20gJy4vYWJzdHJhY3RTcWxEaWFsZWN0JztcblxuZXhwb3J0IGNsYXNzIFNxbGl0ZURpYWxlY3QgZXh0ZW5kcyBBYnN0cmFjdFNxbERpYWxlY3Qge1xuICBjb25zdHJ1Y3RvcigpIHtcbiAgICBzdXBlcignQkVHSU4gVFJBTlNBQ1RJT04nLCAnYCcpO1xuICB9XG5cbiAgb3ZlcnJpZGUgY29tcGFyZTxFLCBLIGV4dGVuZHMga2V5b2YgUXVlcnlGaWx0ZXJNYXA8RT4+KGVudGl0eTogVHlwZTxFPiwga2V5OiBLLCB2YWw6IFF1ZXJ5RmlsdGVyTWFwPEU+W0tdLCBvcHRzPzogUXVlcnlDb21wYXJpc29uT3B0aW9ucyk6IHN0cmluZyB7XG4gICAgaWYgKGtleSA9PT0gJyR0ZXh0Jykge1xuICAgICAgY29uc3QgbWV0YSA9IGdldE1ldGEoZW50aXR5KTtcbiAgICAgIGNvbnN0IHNlYXJjaCA9IHZhbCBhcyBRdWVyeVRleHRTZWFyY2hPcHRpb25zPEU+O1xuICAgICAgcmV0dXJuIGAke3RoaXMuZXNjYXBlSWQobWV0YS5uYW1lKX0gTUFUQ0ggJHt0aGlzLmVzY2FwZShzZWFyY2guJHZhbHVlKX1gO1xuICAgIH1cbiAgICByZXR1cm4gc3VwZXIuY29tcGFyZShlbnRpdHksIGtleSwgdmFsLCBvcHRzKTtcbiAgfVxufVxuIl19
11
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3FsaXRlRGlhbGVjdC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9kaWFsZWN0L3NxbGl0ZURpYWxlY3QudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7O0FBQUEsNkRBQTBEO0FBRTFELE1BQWEsYUFBYyxTQUFRLHVDQUFrQjtJQUNuRDtRQUNFLEtBQUssQ0FBQyxHQUFHLEVBQUUsbUJBQW1CLENBQUMsQ0FBQztJQUNsQyxDQUFDO0NBQ0Y7QUFKRCxzQ0FJQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IEFic3RyYWN0U3FsRGlhbGVjdCB9IGZyb20gJy4vYWJzdHJhY3RTcWxEaWFsZWN0JztcblxuZXhwb3J0IGNsYXNzIFNxbGl0ZURpYWxlY3QgZXh0ZW5kcyBBYnN0cmFjdFNxbERpYWxlY3Qge1xuICBjb25zdHJ1Y3RvcigpIHtcbiAgICBzdXBlcignYCcsICdCRUdJTiBUUkFOU0FDVElPTicpO1xuICB9XG59XG4iXX0=
@@ -23,7 +23,7 @@ function defineField(entity, key, opts = {}) {
23
23
  exports.defineField = defineField;
24
24
  function defineId(entity, key, opts) {
25
25
  const meta = ensureMeta(entity);
26
- const id = getId(meta);
26
+ const id = getIdKey(meta);
27
27
  if (id) {
28
28
  throw TypeError(`'${entity.name}' must have a single field decorated with @Id`);
29
29
  }
@@ -63,7 +63,7 @@ function defineEntity(entity, opts = {}) {
63
63
  extendMeta(meta, parentMeta);
64
64
  proto = Object.getPrototypeOf(proto);
65
65
  }
66
- const id = getId(meta);
66
+ const id = getIdKey(meta);
67
67
  if (!id) {
68
68
  throw TypeError(`'${entity.name}' must have one field decorated with @Id`);
69
69
  }
@@ -184,15 +184,15 @@ function getRelationKeyMap(meta) {
184
184
  return acc;
185
185
  }, {});
186
186
  }
187
- function getId(meta) {
187
+ function getIdKey(meta) {
188
188
  const id = (0, util_1.getKeys)(meta.fields).find((key) => { var _a; return (_a = meta.fields[key]) === null || _a === void 0 ? void 0 : _a.isId; });
189
189
  return id;
190
190
  }
191
191
  function extendMeta(target, source) {
192
192
  const sourceFields = { ...source.fields };
193
- const targetId = getId(target);
193
+ const targetId = getIdKey(target);
194
194
  if (targetId) {
195
- const sourceId = getId(source);
195
+ const sourceId = getIdKey(source);
196
196
  if (sourceId) {
197
197
  delete sourceFields[sourceId];
198
198
  }
@@ -222,4 +222,4 @@ function isValidEntityType(type) {
222
222
  type !== Object);
223
223
  }
224
224
  exports.isValidEntityType = isValidEntityType;
225
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"definition.js","sourceRoot":"","sources":["../../../src/entity/decorator/definition.ts"],"names":[],"mappings":"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","sourcesContent":["import 'reflect-metadata';\nimport { hasKeys, lowerFirst, getKeys, upperFirst } from '@uql/core/util';\nimport {\n  RelationOptions,\n  FieldOptions,\n  EntityOptions,\n  EntityMeta,\n  Type,\n  RelationKeyMap,\n  ReferenceOptions,\n  RelationKey,\n  FieldKey,\n} from '@uql/core/type';\n\nconst holder = globalThis;\nconst metaKey = '@uql/core/entity/decorator';\nconst metas: Map<Type<any>, EntityMeta<any>> = holder[metaKey] ?? new Map();\nholder[metaKey] = metas;\n\nexport function defineField<E>(entity: Type<E>, key: string, opts: FieldOptions = {}): EntityMeta<E> {\n  const meta = ensureMeta(entity);\n  if (!opts.type) {\n    const type = inferType(entity, key);\n    opts = { ...opts, type };\n  }\n  if (typeof opts.reference === 'function') {\n    opts = { ...opts, reference: { entity: opts.reference } };\n  }\n  meta.fields[key] = { ...meta.fields[key], ...{ name: key, ...opts } };\n  return meta;\n}\n\nexport function defineId<E>(entity: Type<E>, key: string, opts: FieldOptions): EntityMeta<E> {\n  const meta = ensureMeta(entity);\n  const id = getId(meta);\n  if (id) {\n    throw TypeError(`'${entity.name}' must have a single field decorated with @Id`);\n  }\n  return defineField(entity, key, { ...opts, isId: true });\n}\n\nexport function defineRelation<E>(entity: Type<E>, key: string, opts: RelationOptions<E>): EntityMeta<E> {\n  if (!opts.entity) {\n    const inferredType = inferEntityType(entity, key);\n    opts.entity = () => inferredType;\n  }\n  const meta = ensureMeta(entity);\n  meta.relations[key] = { ...meta.relations[key], ...opts };\n  return meta;\n}\n\nexport function defineEntity<E>(entity: Type<E>, opts: EntityOptions = {}): EntityMeta<E> {\n  const meta = ensureMeta(entity);\n\n  if (!hasKeys(meta.fields)) {\n    throw TypeError(`'${entity.name}' must have fields`);\n  }\n\n  const onDeleteKeys = getKeys(meta.fields).filter((key) => meta.fields[key].onDelete) as FieldKey<E>[];\n\n  if (onDeleteKeys.length > 1) {\n    throw TypeError(`'${entity.name}' must have one field with 'onDelete' as maximum`);\n  }\n\n  if (opts.softDelete) {\n    if (!onDeleteKeys.length) {\n      throw TypeError(`'${entity.name}' must have one field with 'onDelete' to enable 'softDelete'`);\n    }\n    meta.softDelete = onDeleteKeys[0];\n  }\n\n  meta.name = opts.name ?? entity.name;\n  let proto: FunctionConstructor = Object.getPrototypeOf(entity.prototype);\n\n  while (proto.constructor !== Object) {\n    const parentMeta = ensureMeta(proto.constructor as Type<E>);\n    extendMeta(meta, parentMeta);\n    proto = Object.getPrototypeOf(proto);\n  }\n\n  const id = getId(meta);\n  if (!id) {\n    throw TypeError(`'${entity.name}' must have one field decorated with @Id`);\n  }\n  meta.id = id;\n\n  return meta;\n}\n\nexport function getEntities(): Type<any>[] {\n  return [...metas.entries()].reduce((acc, [key, val]) => {\n    if (val.id) {\n      acc.push(key);\n    }\n    return acc;\n  }, []);\n}\n\nfunction ensureMeta<E>(entity: Type<E>): EntityMeta<E> {\n  let meta = metas.get(entity);\n  if (meta) {\n    return meta;\n  }\n  meta = { entity, fields: {}, relations: {} };\n  metas.set(entity, meta);\n  return meta;\n}\n\nexport function getMeta<E>(entity: Type<E>): EntityMeta<E> {\n  const meta = metas.get(entity);\n  if (!meta) {\n    throw TypeError(`'${entity.name}' is not an entity`);\n  }\n  if (meta.processed) {\n    return meta;\n  }\n  meta.processed = true;\n  return fillRelations(meta);\n}\n\nfunction fillRelations<E>(meta: EntityMeta<E>): EntityMeta<E> {\n  for (const relKey in meta.relations) {\n    const relOpts = meta.relations[relKey as RelationKey<E>];\n\n    if (relOpts.references) {\n      // references were manually specified\n      continue;\n    }\n\n    if (relOpts.mappedBy) {\n      fillInverseSideRelations(relOpts);\n      continue;\n    }\n\n    const relEntity = relOpts.entity();\n    const relMeta = ensureMeta(relEntity);\n\n    if (relOpts.cardinality === 'mm') {\n      const idName = meta.fields[meta.id].name;\n      const relIdName = relMeta.fields[relMeta.id].name;\n      const source = lowerFirst(meta.name) + upperFirst(idName);\n      const target = lowerFirst(relMeta.name) + upperFirst(relIdName);\n      relOpts.references = [\n        { local: source, foreign: meta.id },\n        { local: target, foreign: relMeta.id },\n      ];\n    } else {\n      relOpts.references = [{ local: `${relKey}Id`, foreign: relMeta.id }];\n    }\n\n    if (relOpts.through) {\n      fillThroughRelations(relOpts.through());\n    }\n  }\n\n  return meta;\n}\n\nfunction fillInverseSideRelations<E>(relOpts: RelationOptions<E>): void {\n  const relEntity = relOpts.entity();\n  const relMeta = getMeta(relEntity);\n  relOpts.mappedBy = getMappedByRelationKey(relOpts);\n\n  // reversing references here makes the SQL generation simpler (no need to check for `mappedBy`)\n  const { cardinality, references, through } = relMeta.relations[relOpts.mappedBy];\n  if (cardinality === '11' || cardinality === 'm1') {\n    relOpts.references = references.map(({ local, foreign }) => ({\n      local: foreign,\n      foreign: local,\n    }));\n  } else {\n    relOpts.references = references.slice().reverse();\n    relOpts.through = through;\n  }\n}\n\nfunction fillThroughRelations<E>(entity: Type<E>): void {\n  const meta = ensureMeta(entity);\n  meta.relations = getKeys(meta.fields).reduce((relations, key) => {\n    const { reference } = meta.fields[key];\n    if (reference) {\n      const relEntityGetter = (reference as ReferenceOptions).entity;\n      const relEntity = relEntityGetter();\n      const relMeta = ensureMeta(relEntity);\n      const relKey = key.slice(0, -relMeta.id.length);\n      const relOpts: RelationOptions = {\n        cardinality: 'm1',\n        entity: relEntityGetter,\n        references: [{ local: key, foreign: relMeta.id }],\n      };\n      relations[relKey] = relOpts;\n    }\n    return relations;\n  }, {});\n}\n\nfunction getMappedByRelationKey<E>(relOpts: RelationOptions<E>): RelationKey<E> {\n  if (typeof relOpts.mappedBy === 'function') {\n    const relEntity = relOpts.entity();\n    const relMeta = ensureMeta(relEntity);\n    const keyMap = getRelationKeyMap(relMeta);\n    return relOpts.mappedBy(keyMap);\n  }\n  return relOpts.mappedBy;\n}\n\nfunction getRelationKeyMap<E>(meta: EntityMeta<E>): RelationKeyMap<E> {\n  return getKeys(meta.relations).reduce((acc, key) => {\n    acc[key] = key;\n    return acc;\n  }, {} as RelationKeyMap<E>);\n}\n\nfunction getId<E>(meta: EntityMeta<E>): FieldKey<E> {\n  const id = getKeys(meta.fields).find((key) => meta.fields[key]?.isId);\n  return id as FieldKey<E>;\n}\n\nfunction extendMeta<E>(target: EntityMeta<E>, source: EntityMeta<E>): void {\n  const sourceFields = { ...source.fields };\n  const targetId = getId(target);\n  if (targetId) {\n    const sourceId = getId(source);\n    if (sourceId) {\n      delete sourceFields[sourceId];\n    }\n  }\n  target.fields = { ...sourceFields, ...target.fields };\n  target.relations = { ...source.relations, ...target.relations };\n}\n\nfunction inferType<E>(entity: Type<E>, key: string): any {\n  return Reflect.getMetadata('design:type', entity.prototype, key);\n}\n\nfunction inferEntityType<E>(entity: Type<E>, key: string): Type<any> {\n  const inferredType = inferType(entity, key);\n  const isValidType = isValidEntityType(inferredType);\n  if (!isValidType) {\n    throw TypeError(`'${entity.name}.${key}' type was auto-inferred with invalid type '${inferredType?.name}'`);\n  }\n  return inferredType;\n}\n\nexport function isValidEntityType(type: any): type is Type<any> {\n  return (\n    typeof type === 'function' &&\n    type !== Boolean &&\n    type !== String &&\n    type !== Number &&\n    type !== BigInt &&\n    type !== Date &&\n    type !== Symbol &&\n    type !== Object\n  );\n}\n"]}
225
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"definition.js","sourceRoot":"","sources":["../../../src/entity/decorator/definition.ts"],"names":[],"mappings":"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","sourcesContent":["import 'reflect-metadata';\nimport { hasKeys, lowerFirst, getKeys, upperFirst } from '@uql/core/util';\nimport {\n  RelationOptions,\n  FieldOptions,\n  EntityOptions,\n  EntityMeta,\n  Type,\n  RelationKeyMap,\n  ReferenceOptions,\n  RelationKey,\n  FieldKey,\n  IdKey,\n} from '@uql/core/type';\n\nconst holder = globalThis;\nconst metaKey = '@uql/core/entity/decorator';\nconst metas: Map<Type<any>, EntityMeta<any>> = holder[metaKey] ?? new Map();\nholder[metaKey] = metas;\n\nexport function defineField<E>(entity: Type<E>, key: string, opts: FieldOptions = {}): EntityMeta<E> {\n  const meta = ensureMeta(entity);\n  if (!opts.type) {\n    const type = inferType(entity, key);\n    opts = { ...opts, type };\n  }\n  if (typeof opts.reference === 'function') {\n    opts = { ...opts, reference: { entity: opts.reference } };\n  }\n  meta.fields[key] = { ...meta.fields[key], ...{ name: key, ...opts } };\n  return meta;\n}\n\nexport function defineId<E>(entity: Type<E>, key: string, opts: FieldOptions): EntityMeta<E> {\n  const meta = ensureMeta(entity);\n  const id = getIdKey(meta);\n  if (id) {\n    throw TypeError(`'${entity.name}' must have a single field decorated with @Id`);\n  }\n  return defineField(entity, key, { ...opts, isId: true });\n}\n\nexport function defineRelation<E>(entity: Type<E>, key: string, opts: RelationOptions<E>): EntityMeta<E> {\n  if (!opts.entity) {\n    const inferredType = inferEntityType(entity, key);\n    opts.entity = () => inferredType;\n  }\n  const meta = ensureMeta(entity);\n  meta.relations[key] = { ...meta.relations[key], ...opts };\n  return meta;\n}\n\nexport function defineEntity<E>(entity: Type<E>, opts: EntityOptions = {}): EntityMeta<E> {\n  const meta = ensureMeta(entity);\n\n  if (!hasKeys(meta.fields)) {\n    throw TypeError(`'${entity.name}' must have fields`);\n  }\n\n  const onDeleteKeys = getKeys(meta.fields).filter((key) => meta.fields[key].onDelete) as FieldKey<E>[];\n\n  if (onDeleteKeys.length > 1) {\n    throw TypeError(`'${entity.name}' must have one field with 'onDelete' as maximum`);\n  }\n\n  if (opts.softDelete) {\n    if (!onDeleteKeys.length) {\n      throw TypeError(`'${entity.name}' must have one field with 'onDelete' to enable 'softDelete'`);\n    }\n    meta.softDelete = onDeleteKeys[0];\n  }\n\n  meta.name = opts.name ?? entity.name;\n  let proto: FunctionConstructor = Object.getPrototypeOf(entity.prototype);\n\n  while (proto.constructor !== Object) {\n    const parentMeta = ensureMeta(proto.constructor as Type<E>);\n    extendMeta(meta, parentMeta);\n    proto = Object.getPrototypeOf(proto);\n  }\n\n  const id = getIdKey(meta);\n  if (!id) {\n    throw TypeError(`'${entity.name}' must have one field decorated with @Id`);\n  }\n  meta.id = id;\n\n  return meta;\n}\n\nexport function getEntities(): Type<any>[] {\n  return [...metas.entries()].reduce((acc, [key, val]) => {\n    if (val.id) {\n      acc.push(key);\n    }\n    return acc;\n  }, []);\n}\n\nfunction ensureMeta<E>(entity: Type<E>): EntityMeta<E> {\n  let meta = metas.get(entity);\n  if (meta) {\n    return meta;\n  }\n  meta = { entity, fields: {}, relations: {} };\n  metas.set(entity, meta);\n  return meta;\n}\n\nexport function getMeta<E>(entity: Type<E>): EntityMeta<E> {\n  const meta = metas.get(entity);\n  if (!meta) {\n    throw TypeError(`'${entity.name}' is not an entity`);\n  }\n  if (meta.processed) {\n    return meta;\n  }\n  meta.processed = true;\n  return fillRelations(meta);\n}\n\nfunction fillRelations<E>(meta: EntityMeta<E>): EntityMeta<E> {\n  for (const relKey in meta.relations) {\n    const relOpts = meta.relations[relKey as RelationKey<E>];\n\n    if (relOpts.references) {\n      // references were manually specified\n      continue;\n    }\n\n    if (relOpts.mappedBy) {\n      fillInverseSideRelations(relOpts);\n      continue;\n    }\n\n    const relEntity = relOpts.entity();\n    const relMeta = ensureMeta(relEntity);\n\n    if (relOpts.cardinality === 'mm') {\n      const idName = meta.fields[meta.id].name;\n      const relIdName = relMeta.fields[relMeta.id].name;\n      const source = lowerFirst(meta.name) + upperFirst(idName);\n      const target = lowerFirst(relMeta.name) + upperFirst(relIdName);\n      relOpts.references = [\n        { local: source, foreign: meta.id },\n        { local: target, foreign: relMeta.id },\n      ];\n    } else {\n      relOpts.references = [{ local: `${relKey}Id`, foreign: relMeta.id }];\n    }\n\n    if (relOpts.through) {\n      fillThroughRelations(relOpts.through());\n    }\n  }\n\n  return meta;\n}\n\nfunction fillInverseSideRelations<E>(relOpts: RelationOptions<E>): void {\n  const relEntity = relOpts.entity();\n  const relMeta = getMeta(relEntity);\n  relOpts.mappedBy = getMappedByRelationKey(relOpts);\n\n  // reversing references here makes the SQL generation simpler (no need to check for `mappedBy`)\n  const { cardinality, references, through } = relMeta.relations[relOpts.mappedBy];\n  if (cardinality === '11' || cardinality === 'm1') {\n    relOpts.references = references.map(({ local, foreign }) => ({\n      local: foreign,\n      foreign: local,\n    }));\n  } else {\n    relOpts.references = references.slice().reverse();\n    relOpts.through = through;\n  }\n}\n\nfunction fillThroughRelations<E>(entity: Type<E>): void {\n  const meta = ensureMeta(entity);\n  meta.relations = getKeys(meta.fields).reduce((relations, key) => {\n    const { reference } = meta.fields[key];\n    if (reference) {\n      const relEntityGetter = (reference as ReferenceOptions).entity;\n      const relEntity = relEntityGetter();\n      const relMeta = ensureMeta(relEntity);\n      const relKey = key.slice(0, -relMeta.id.length);\n      const relOpts: RelationOptions = {\n        cardinality: 'm1',\n        entity: relEntityGetter,\n        references: [{ local: key, foreign: relMeta.id }],\n      };\n      relations[relKey] = relOpts;\n    }\n    return relations;\n  }, {});\n}\n\nfunction getMappedByRelationKey<E>(relOpts: RelationOptions<E>): RelationKey<E> {\n  if (typeof relOpts.mappedBy === 'function') {\n    const relEntity = relOpts.entity();\n    const relMeta = ensureMeta(relEntity);\n    const keyMap = getRelationKeyMap(relMeta);\n    return relOpts.mappedBy(keyMap);\n  }\n  return relOpts.mappedBy;\n}\n\nfunction getRelationKeyMap<E>(meta: EntityMeta<E>): RelationKeyMap<E> {\n  return getKeys(meta.relations).reduce((acc, key) => {\n    acc[key] = key;\n    return acc;\n  }, {} as RelationKeyMap<E>);\n}\n\nfunction getIdKey<E>(meta: EntityMeta<E>): IdKey<E> {\n  const id = getKeys(meta.fields).find((key) => meta.fields[key]?.isId);\n  return id as IdKey<E>;\n}\n\nfunction extendMeta<E>(target: EntityMeta<E>, source: EntityMeta<E>): void {\n  const sourceFields = { ...source.fields };\n  const targetId = getIdKey(target);\n  if (targetId) {\n    const sourceId = getIdKey(source);\n    if (sourceId) {\n      delete sourceFields[sourceId];\n    }\n  }\n  target.fields = { ...sourceFields, ...target.fields };\n  target.relations = { ...source.relations, ...target.relations };\n}\n\nfunction inferType<E>(entity: Type<E>, key: string): any {\n  return Reflect.getMetadata('design:type', entity.prototype, key);\n}\n\nfunction inferEntityType<E>(entity: Type<E>, key: string): Type<any> {\n  const inferredType = inferType(entity, key);\n  const isValidType = isValidEntityType(inferredType);\n  if (!isValidType) {\n    throw TypeError(`'${entity.name}.${key}' type was auto-inferred with invalid type '${inferredType?.name}'`);\n  }\n  return inferredType;\n}\n\nexport function isValidEntityType(type: any): type is Type<any> {\n  return (\n    typeof type === 'function' &&\n    type !== Boolean &&\n    type !== String &&\n    type !== Number &&\n    type !== BigInt &&\n    type !== Date &&\n    type !== Symbol &&\n    type !== Object\n  );\n}\n"]}
package/package.json CHANGED
@@ -3,7 +3,7 @@
3
3
  "homepage": "https://uql.io",
4
4
  "description": "flexible and efficient ORM, with declarative JSON syntax and smart type-safety",
5
5
  "license": "MIT",
6
- "version": "0.4.73",
6
+ "version": "0.4.77",
7
7
  "main": "index.js",
8
8
  "types": "index.d.ts",
9
9
  "scripts": {
@@ -18,12 +18,12 @@
18
18
  "tslib": "^2.3.1"
19
19
  },
20
20
  "devDependencies": {
21
- "@types/node": "^16.10.1",
21
+ "@types/node": "^17.0.18",
22
22
  "@types/sqlstring": "^2.3.0",
23
- "@types/uuid": "^8.3.1",
23
+ "@types/uuid": "^8.3.4",
24
24
  "copyfiles": "^2.4.1",
25
25
  "rimraf": "^3.0.2",
26
- "typescript": "^4.4.3",
26
+ "typescript": "^4.5.5",
27
27
  "uuid": "^8.3.2"
28
28
  },
29
29
  "author": "Roger Padilla",
@@ -11,8 +11,8 @@ export declare abstract class AbstractQuerier implements Querier {
11
11
  abstract updateMany<E>(entity: Type<E>, qm: QueryCriteria<E>, payload: E): Promise<number>;
12
12
  deleteOneById<E>(entity: Type<E>, id: IdValue<E>, opts?: QueryOptions): Promise<number>;
13
13
  abstract deleteMany<E>(entity: Type<E>, qm: QueryCriteria<E>, opts?: QueryOptions): Promise<number>;
14
- saveOne<E>(entity: Type<E>, payload: E): Promise<IdValue<E>>;
15
- saveMany<E>(entity: Type<E>, payload: E[]): Promise<IdValue<E>[]>;
14
+ saveOne<E>(entity: Type<E>, payload: E): Promise<IdValue<E> | E[import("@uql/core/type").IdKey<E>]>;
15
+ saveMany<E>(entity: Type<E>, payload: E[]): Promise<(Awaited<IdValue<E>> | Awaited<E[import("@uql/core/type").IdKey<E>]>)[]>;
16
16
  protected findToManyRelations<E>(entity: Type<E>, payload: E[], project: QueryProject<E>): Promise<void>;
17
17
  protected putChildrenInParents<E>(parents: E[], children: E[], parentIdKey: string, referenceKey: string, relKey: string): void;
18
18
  protected insertRelations<E>(entity: Type<E>, payload: E[]): Promise<void>;
@@ -227,4 +227,4 @@ class AbstractQuerier {
227
227
  }
228
228
  }
229
229
  exports.AbstractQuerier = AbstractQuerier;
230
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"abstractQuerier.js","sourceRoot":"","sources":["../../src/querier/abstractQuerier.ts"],"names":[],"mappings":"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","sourcesContent":["import { GenericRepository } from '@uql/core/repository';\nimport { clone, getKeys, getProjectRelationKeys, getPersistableRelations } from '@uql/core/util';\nimport { getMeta } from '@uql/core/entity';\nimport {\n  IdValue,\n  Querier,\n  Query,\n  QueryCriteria,\n  QueryOne,\n  QueryOptions,\n  QueryProject,\n  QuerySearch,\n  QueryUnique,\n  RelationKey,\n  RelationValue,\n  Repository,\n  Type,\n} from '@uql/core/type';\n\nexport abstract class AbstractQuerier implements Querier {\n  abstract count<E>(entity: Type<E>, qm?: QuerySearch<E>): Promise<number>;\n\n  findOneById<E>(entity: Type<E>, id: IdValue<E>, qm: QueryUnique<E> = {}) {\n    return this.findOne(entity, { ...qm, $filter: id });\n  }\n\n  async findOne<E>(entity: Type<E>, qm: QueryOne<E>) {\n    const rows = await this.findMany(entity, { ...qm, $limit: 1 });\n    return rows[0];\n  }\n\n  abstract findMany<E>(entity: Type<E>, qm: Query<E>): Promise<E[]>;\n\n  findManyAndCount<E>(entity: Type<E>, qm: Query<E>) {\n    return Promise.all([this.findMany(entity, qm), this.count(entity, qm)]);\n  }\n\n  async insertOne<E>(entity: Type<E>, payload: E) {\n    const [id] = await this.insertMany(entity, [payload]);\n    return id;\n  }\n\n  abstract insertMany<E>(entity: Type<E>, payload: E[]): Promise<IdValue<E>[]>;\n\n  updateOneById<E>(entity: Type<E>, id: IdValue<E>, payload: E) {\n    return this.updateMany(entity, { $filter: id }, payload);\n  }\n\n  abstract updateMany<E>(entity: Type<E>, qm: QueryCriteria<E>, payload: E): Promise<number>;\n\n  deleteOneById<E>(entity: Type<E>, id: IdValue<E>, opts?: QueryOptions) {\n    return this.deleteMany(entity, { $filter: id }, opts);\n  }\n\n  abstract deleteMany<E>(entity: Type<E>, qm: QueryCriteria<E>, opts?: QueryOptions): Promise<number>;\n\n  async saveOne<E>(entity: Type<E>, payload: E) {\n    const [id] = await this.saveMany(entity, [payload]);\n    return id;\n  }\n\n  async saveMany<E>(entity: Type<E>, payload: E[]) {\n    const meta = getMeta(entity);\n    const ids: IdValue<E>[] = [];\n    const updates: E[] = [];\n    const inserts: E[] = [];\n\n    for (const it of payload) {\n      if (it[meta.id]) {\n        if (getKeys(it).length === 1) {\n          ids.push(it[meta.id]);\n        } else {\n          updates.push(it);\n        }\n      } else {\n        inserts.push(it);\n      }\n    }\n\n    return Promise.all([\n      ...ids,\n      ...(inserts.length ? await this.insertMany(entity, inserts) : []),\n      ...updates.map(async (it) => {\n        const { [meta.id]: id, ...data } = it;\n        await this.updateOneById(entity, id, data);\n        return id;\n      }),\n    ]);\n  }\n\n  protected async findToManyRelations<E>(entity: Type<E>, payload: E[], project: QueryProject<E>) {\n    const meta = getMeta(entity);\n    const relations = getProjectRelationKeys(meta, project);\n\n    for (const relKey of relations) {\n      const relOpts = meta.relations[relKey];\n      const relEntity = relOpts.entity();\n      const relProject = clone(project[relKey as string]);\n      const relQuery: Query<any> =\n        relProject === true || relProject === undefined ? {} : Array.isArray(relProject) ? { $project: relProject } : relProject;\n      const ids: IdValue<E>[] = payload.map((it) => it[meta.id]);\n\n      if (relOpts.through) {\n        const localField = relOpts.references[0].local;\n        const throughEntity = relOpts.through();\n        const throughMeta = getMeta(throughEntity);\n        const targetRelKey = Object.keys(throughMeta.relations).find((key) =>\n          throughMeta.relations[key].references.some(({ local }) => local === relOpts.references[1].local)\n        );\n        const throughFounds = await this.findMany(throughEntity, {\n          $project: {\n            [localField]: true,\n            [targetRelKey]: {\n              ...relQuery,\n              $required: true,\n            },\n          },\n          $filter: {\n            [localField]: ids,\n          },\n        });\n        const founds = throughFounds.map((it) => ({ ...it[targetRelKey], [localField]: it[localField] }));\n        this.putChildrenInParents(payload, founds, meta.id, localField, relKey);\n      } else if (relOpts.cardinality === '1m') {\n        const foreignField = relOpts.references[0].foreign;\n        if (relQuery.$project) {\n          if (Array.isArray(relQuery.$project)) {\n            if (!relQuery.$project.includes(foreignField)) {\n              relQuery.$project.push(foreignField);\n            }\n          } else if (!relQuery.$project[foreignField]) {\n            relQuery.$project[foreignField] = true;\n          }\n        }\n        relQuery.$filter = { [foreignField]: ids };\n        const founds = await this.findMany(relEntity, relQuery);\n        this.putChildrenInParents(payload, founds, meta.id, foreignField, relKey);\n      }\n    }\n  }\n\n  protected putChildrenInParents<E>(parents: E[], children: E[], parentIdKey: string, referenceKey: string, relKey: string): void {\n    const childrenByParentMap = children.reduce((acc, child) => {\n      const parenId = child[referenceKey];\n      if (!acc[parenId]) {\n        acc[parenId] = [];\n      }\n      acc[parenId].push(child);\n      return acc;\n    }, {});\n\n    for (const parent of parents) {\n      const parentId = parent[parentIdKey];\n      parent[relKey] = childrenByParentMap[parentId];\n    }\n  }\n\n  protected async insertRelations<E>(entity: Type<E>, payload: E[]) {\n    const meta = getMeta(entity);\n    await Promise.all(\n      payload.map((it) => {\n        const relKeys = getPersistableRelations(meta, it, 'persist');\n        if (!relKeys.length) {\n          return;\n        }\n        return Promise.all(relKeys.map((relKey) => this.saveRelation(entity, it, relKey)));\n      })\n    );\n  }\n\n  protected async updateRelations<E>(entity: Type<E>, criteria: QueryCriteria<E>, payload: E) {\n    const meta = getMeta(entity);\n    const relKeys = getPersistableRelations(meta, payload, 'persist');\n\n    if (!relKeys.length) {\n      return;\n    }\n\n    const founds = await this.findMany(entity, {\n      ...criteria,\n      $project: [meta.id],\n    });\n\n    const ids: IdValue<E>[] = founds.map((found) => found[meta.id]);\n\n    await Promise.all(ids.map((id) => Promise.all(relKeys.map((relKey) => this.saveRelation(entity, { ...payload, [meta.id]: id }, relKey, true)))));\n  }\n\n  protected async deleteRelations<E>(entity: Type<E>, ids: IdValue<E>[], opts?: QueryOptions) {\n    const meta = getMeta(entity);\n    const relKeys = getPersistableRelations(meta, meta.relations as E, 'delete');\n\n    for (const relKey of relKeys) {\n      const relOpts = meta.relations[relKey];\n      const relEntity = relOpts.entity();\n      const localField = relOpts.references[0].local;\n      if (relOpts.through) {\n        const throughEntity = relOpts.through();\n        await this.deleteMany(throughEntity, { $filter: { [localField]: ids } }, opts);\n        return;\n      }\n      await this.deleteMany(relEntity, { [localField]: ids }, opts);\n    }\n  }\n\n  protected async saveRelation<E>(entity: Type<E>, payload: E, relKey: RelationKey<E>, isUpdate?: boolean) {\n    const meta = getMeta(entity);\n    const id = payload[meta.id];\n    const { entity: entityGetter, cardinality, references, through } = meta.relations[relKey];\n    const relEntity = entityGetter();\n    const relPayload = payload[relKey] as RelationValue<E>[];\n\n    if (cardinality === '1m' || cardinality === 'mm') {\n      if (through) {\n        const localField = references[0].local;\n\n        const throughEntity = through();\n        if (isUpdate) {\n          await this.deleteMany(throughEntity, { $filter: { [localField]: id } });\n        }\n        if (relPayload) {\n          const savedIds = await this.saveMany(relEntity, relPayload);\n          const throughBodies = savedIds.map((relId) => ({\n            [references[0].local]: id,\n            [references[1].local]: relId,\n          }));\n          await this.insertMany(throughEntity, throughBodies);\n        }\n        return;\n      }\n      const foreignField = references[0].foreign;\n      if (isUpdate) {\n        await this.deleteMany(relEntity, { $filter: { [foreignField]: id } });\n      }\n      if (relPayload) {\n        for (const it of relPayload) {\n          it[foreignField] = id;\n        }\n        await this.saveMany(relEntity, relPayload);\n      }\n      return;\n    }\n\n    if (cardinality === '11') {\n      const foreignField = references[0].foreign;\n      if (relPayload === null) {\n        await this.deleteMany(relEntity, { $filter: { [foreignField]: id } });\n        return;\n      }\n      await this.saveOne(relEntity, { ...relPayload, [foreignField]: id });\n      return;\n    }\n\n    if (cardinality === 'm1' && relPayload) {\n      const localField = references[0].local;\n      const referenceId = await this.insertOne(relEntity, relPayload);\n      await this.updateOneById(entity, id, { [localField]: referenceId });\n      return;\n    }\n  }\n\n  getRepository<E>(entity: Type<E>): Repository<E> {\n    return new GenericRepository(entity, this);\n  }\n\n  abstract readonly hasOpenTransaction: boolean;\n\n  async transaction<T>(callback: (querier?: ThisType<Querier>) => Promise<T>) {\n    try {\n      await this.beginTransaction();\n      const res = await callback(this);\n      await this.commitTransaction();\n      return res;\n    } catch (err) {\n      await this.rollbackTransaction();\n      throw err;\n    } finally {\n      await this.release();\n    }\n  }\n\n  abstract beginTransaction(): Promise<void>;\n\n  abstract commitTransaction(): Promise<void>;\n\n  abstract rollbackTransaction(): Promise<void>;\n\n  abstract release(): Promise<void>;\n\n  abstract end(): Promise<void>;\n}\n"]}
230
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"abstractQuerier.js","sourceRoot":"","sources":["../../src/querier/abstractQuerier.ts"],"names":[],"mappings":"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","sourcesContent":["import { GenericRepository } from '@uql/core/repository';\nimport { clone, getKeys, getProjectRelationKeys, getPersistableRelations } from '@uql/core/util';\nimport { getMeta } from '@uql/core/entity';\nimport {\n  IdValue,\n  Querier,\n  Query,\n  QueryCriteria,\n  QueryOne,\n  QueryOptions,\n  QueryProject,\n  QuerySearch,\n  QueryUnique,\n  RelationKey,\n  RelationValue,\n  Repository,\n  Type,\n} from '@uql/core/type';\n\nexport abstract class AbstractQuerier implements Querier {\n  abstract count<E>(entity: Type<E>, qm?: QuerySearch<E>): Promise<number>;\n\n  findOneById<E>(entity: Type<E>, id: IdValue<E>, qm: QueryUnique<E> = {}) {\n    return this.findOne(entity, { ...qm, $filter: id });\n  }\n\n  async findOne<E>(entity: Type<E>, qm: QueryOne<E>) {\n    const rows = await this.findMany(entity, { ...qm, $limit: 1 });\n    return rows[0];\n  }\n\n  abstract findMany<E>(entity: Type<E>, qm: Query<E>): Promise<E[]>;\n\n  findManyAndCount<E>(entity: Type<E>, qm: Query<E>) {\n    return Promise.all([this.findMany(entity, qm), this.count(entity, qm)]);\n  }\n\n  async insertOne<E>(entity: Type<E>, payload: E) {\n    const [id] = await this.insertMany(entity, [payload]);\n    return id;\n  }\n\n  abstract insertMany<E>(entity: Type<E>, payload: E[]): Promise<IdValue<E>[]>;\n\n  updateOneById<E>(entity: Type<E>, id: IdValue<E>, payload: E) {\n    return this.updateMany(entity, { $filter: id }, payload);\n  }\n\n  abstract updateMany<E>(entity: Type<E>, qm: QueryCriteria<E>, payload: E): Promise<number>;\n\n  deleteOneById<E>(entity: Type<E>, id: IdValue<E>, opts?: QueryOptions) {\n    return this.deleteMany(entity, { $filter: id }, opts);\n  }\n\n  abstract deleteMany<E>(entity: Type<E>, qm: QueryCriteria<E>, opts?: QueryOptions): Promise<number>;\n\n  async saveOne<E>(entity: Type<E>, payload: E) {\n    const [id] = await this.saveMany(entity, [payload]);\n    return id;\n  }\n\n  async saveMany<E>(entity: Type<E>, payload: E[]) {\n    const meta = getMeta(entity);\n    const ids: IdValue<E>[] = [];\n    const updates: E[] = [];\n    const inserts: E[] = [];\n\n    for (const it of payload) {\n      if (it[meta.id]) {\n        if (getKeys(it).length === 1) {\n          ids.push(it[meta.id]);\n        } else {\n          updates.push(it);\n        }\n      } else {\n        inserts.push(it);\n      }\n    }\n\n    return Promise.all([\n      ...ids,\n      ...(inserts.length ? await this.insertMany(entity, inserts) : []),\n      ...updates.map(async (it) => {\n        const { [meta.id]: id, ...data } = it;\n        await this.updateOneById(entity, id, data as E);\n        return id;\n      }),\n    ]);\n  }\n\n  protected async findToManyRelations<E>(entity: Type<E>, payload: E[], project: QueryProject<E>) {\n    const meta = getMeta(entity);\n    const relations = getProjectRelationKeys(meta, project);\n\n    for (const relKey of relations) {\n      const relOpts = meta.relations[relKey];\n      const relEntity = relOpts.entity();\n      const relProject = clone(project[relKey as string]);\n      const relQuery: Query<any> =\n        relProject === true || relProject === undefined ? {} : Array.isArray(relProject) ? { $project: relProject } : relProject;\n      const ids = payload.map((it) => it[meta.id]);\n\n      if (relOpts.through) {\n        const localField = relOpts.references[0].local;\n        const throughEntity = relOpts.through();\n        const throughMeta = getMeta(throughEntity);\n        const targetRelKey = Object.keys(throughMeta.relations).find((key) =>\n          throughMeta.relations[key].references.some(({ local }) => local === relOpts.references[1].local)\n        );\n        const throughFounds = await this.findMany(throughEntity, {\n          $project: {\n            [localField]: true,\n            [targetRelKey]: {\n              ...relQuery,\n              $required: true,\n            },\n          },\n          $filter: {\n            [localField]: ids,\n          },\n        });\n        const founds = throughFounds.map((it) => ({ ...it[targetRelKey], [localField]: it[localField] }));\n        this.putChildrenInParents(payload, founds, meta.id, localField, relKey);\n      } else if (relOpts.cardinality === '1m') {\n        const foreignField = relOpts.references[0].foreign;\n        if (relQuery.$project) {\n          if (Array.isArray(relQuery.$project)) {\n            if (!relQuery.$project.includes(foreignField)) {\n              relQuery.$project.push(foreignField);\n            }\n          } else if (!relQuery.$project[foreignField]) {\n            relQuery.$project[foreignField] = true;\n          }\n        }\n        relQuery.$filter = { [foreignField]: ids };\n        const founds = await this.findMany(relEntity, relQuery);\n        this.putChildrenInParents(payload, founds, meta.id, foreignField, relKey);\n      }\n    }\n  }\n\n  protected putChildrenInParents<E>(parents: E[], children: E[], parentIdKey: string, referenceKey: string, relKey: string): void {\n    const childrenByParentMap = children.reduce((acc, child) => {\n      const parenId = child[referenceKey];\n      if (!acc[parenId]) {\n        acc[parenId] = [];\n      }\n      acc[parenId].push(child);\n      return acc;\n    }, {});\n\n    for (const parent of parents) {\n      const parentId = parent[parentIdKey];\n      parent[relKey] = childrenByParentMap[parentId];\n    }\n  }\n\n  protected async insertRelations<E>(entity: Type<E>, payload: E[]) {\n    const meta = getMeta(entity);\n    await Promise.all(\n      payload.map((it) => {\n        const relKeys = getPersistableRelations(meta, it, 'persist');\n        if (!relKeys.length) {\n          return;\n        }\n        return Promise.all(relKeys.map((relKey) => this.saveRelation(entity, it, relKey)));\n      })\n    );\n  }\n\n  protected async updateRelations<E>(entity: Type<E>, criteria: QueryCriteria<E>, payload: E) {\n    const meta = getMeta(entity);\n    const relKeys = getPersistableRelations(meta, payload, 'persist');\n\n    if (!relKeys.length) {\n      return;\n    }\n\n    const founds = await this.findMany(entity, {\n      ...criteria,\n      $project: [meta.id],\n    });\n\n    const ids = founds.map((found) => found[meta.id]);\n\n    await Promise.all(ids.map((id) => Promise.all(relKeys.map((relKey) => this.saveRelation(entity, { ...payload, [meta.id]: id }, relKey, true)))));\n  }\n\n  protected async deleteRelations<E>(entity: Type<E>, ids: IdValue<E>[], opts?: QueryOptions) {\n    const meta = getMeta(entity);\n    const relKeys = getPersistableRelations(meta, meta.relations as E, 'delete');\n\n    for (const relKey of relKeys) {\n      const relOpts = meta.relations[relKey];\n      const relEntity = relOpts.entity();\n      const localField = relOpts.references[0].local;\n      if (relOpts.through) {\n        const throughEntity = relOpts.through();\n        await this.deleteMany(throughEntity, { $filter: { [localField]: ids } }, opts);\n        return;\n      }\n      await this.deleteMany(relEntity, { [localField]: ids }, opts);\n    }\n  }\n\n  protected async saveRelation<E>(entity: Type<E>, payload: E, relKey: RelationKey<E>, isUpdate?: boolean) {\n    const meta = getMeta(entity);\n    const id = payload[meta.id];\n    const { entity: entityGetter, cardinality, references, through } = meta.relations[relKey];\n    const relEntity = entityGetter();\n    const relPayload = payload[relKey] as unknown as RelationValue<E>[];\n\n    if (cardinality === '1m' || cardinality === 'mm') {\n      if (through) {\n        const localField = references[0].local;\n\n        const throughEntity = through();\n        if (isUpdate) {\n          await this.deleteMany(throughEntity, { $filter: { [localField]: id } });\n        }\n        if (relPayload) {\n          const savedIds = await this.saveMany(relEntity, relPayload);\n          const throughBodies = savedIds.map((relId) => ({\n            [references[0].local]: id,\n            [references[1].local]: relId,\n          }));\n          await this.insertMany(throughEntity, throughBodies);\n        }\n        return;\n      }\n      const foreignField = references[0].foreign;\n      if (isUpdate) {\n        await this.deleteMany(relEntity, { $filter: { [foreignField]: id } });\n      }\n      if (relPayload) {\n        for (const it of relPayload) {\n          it[foreignField] = id;\n        }\n        await this.saveMany(relEntity, relPayload);\n      }\n      return;\n    }\n\n    if (cardinality === '11') {\n      const foreignField = references[0].foreign;\n      if (relPayload === null) {\n        await this.deleteMany(relEntity, { $filter: { [foreignField]: id } });\n        return;\n      }\n      await this.saveOne(relEntity, { ...relPayload, [foreignField]: id });\n      return;\n    }\n\n    if (cardinality === 'm1' && relPayload) {\n      const localField = references[0].local;\n      const referenceId = await this.insertOne(relEntity, relPayload);\n      await this.updateOneById(entity, id, { [localField]: referenceId });\n      return;\n    }\n  }\n\n  getRepository<E>(entity: Type<E>): Repository<E> {\n    return new GenericRepository(entity, this);\n  }\n\n  abstract readonly hasOpenTransaction: boolean;\n\n  async transaction<T>(callback: (querier?: ThisType<Querier>) => Promise<T>) {\n    try {\n      await this.beginTransaction();\n      const res = await callback(this);\n      await this.commitTransaction();\n      return res;\n    } catch (err) {\n      await this.rollbackTransaction();\n      throw err;\n    } finally {\n      await this.release();\n    }\n  }\n\n  abstract beginTransaction(): Promise<void>;\n\n  abstract commitTransaction(): Promise<void>;\n\n  abstract rollbackTransaction(): Promise<void>;\n\n  abstract release(): Promise<void>;\n\n  abstract end(): Promise<void>;\n}\n"]}
@@ -1,4 +1,4 @@
1
- import { Query, Type, QueryCriteria, QueryOptions, IdValue, QueryUpdateResult } from '@uql/core/type';
1
+ import { Query, Type, QueryCriteria, QueryOptions, QueryUpdateResult } from '@uql/core/type';
2
2
  import { AbstractSqlDialect } from '@uql/core/dialect';
3
3
  import { AbstractQuerier } from './abstractQuerier';
4
4
  export declare abstract class AbstractSqlQuerier extends AbstractQuerier {
@@ -17,7 +17,7 @@ export declare abstract class AbstractSqlQuerier extends AbstractQuerier {
17
17
  abstract run(query: string): Promise<QueryUpdateResult>;
18
18
  count<E>(entity: Type<E>, qm?: QueryCriteria<E>): Promise<number>;
19
19
  findMany<E>(entity: Type<E>, qm: Query<E>): Promise<E[]>;
20
- insertMany<E>(entity: Type<E>, payload: E[]): Promise<IdValue<E>[]>;
20
+ insertMany<E>(entity: Type<E>, payload: E[]): Promise<E[import("@uql/core/type").IdKey<E>][]>;
21
21
  updateMany<E>(entity: Type<E>, qm: QueryCriteria<E>, payload: E): Promise<number>;
22
22
  deleteMany<E>(entity: Type<E>, qm: QueryCriteria<E>, opts?: QueryOptions): Promise<number>;
23
23
  get hasOpenTransaction(): boolean;
@@ -85,4 +85,4 @@ class AbstractSqlQuerier extends abstractQuerier_1.AbstractQuerier {
85
85
  }
86
86
  }
87
87
  exports.AbstractSqlQuerier = AbstractSqlQuerier;
88
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"abstractSqlQuerier.js","sourceRoot":"","sources":["../../src/querier/abstractSqlQuerier.ts"],"names":[],"mappings":"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","sourcesContent":["import { getMeta } from '@uql/core/entity';\nimport { Query, Type, QueryCriteria, QueryOptions, IdValue, QueryUpdateResult, IsolationLevel } from '@uql/core/type';\nimport { unflatObjects, clone } from '@uql/core/util';\nimport { AbstractSqlDialect } from '@uql/core/dialect';\n\nimport { AbstractQuerier } from './abstractQuerier';\n\nexport abstract class AbstractSqlQuerier extends AbstractQuerier {\n  private hasPendingTransaction?: boolean;\n\n  constructor(readonly dialect: AbstractSqlDialect) {\n    super();\n  }\n\n  /**\n   * read query.\n   * @param query the query\n   */\n  abstract all<T>(query: string): Promise<T[]>;\n\n  /**\n   * insert/update/delete/ddl query.\n   * @param query the query\n   */\n  abstract run(query: string): Promise<QueryUpdateResult>;\n\n  override async count<E>(entity: Type<E>, qm?: QueryCriteria<E>) {\n    const query = await this.dialect.count(entity, qm);\n    const res: any = await this.all<E>(query);\n    return Number(res[0].count);\n  }\n\n  override async findMany<E>(entity: Type<E>, qm: Query<E>) {\n    const query = this.dialect.find(entity, qm);\n    const res = await this.all<E>(query);\n    const founds = unflatObjects(res);\n    await this.findToManyRelations(entity, founds, qm.$project);\n    return founds;\n  }\n\n  override async insertMany<E>(entity: Type<E>, payload: E[]) {\n    payload = clone(payload);\n    const query = this.dialect.insert(entity, payload);\n    const { firstId } = await this.run(query);\n    const meta = getMeta(entity);\n    const ids: IdValue<E>[] = payload.map((it, index) => {\n      it[meta.id as string] ??= firstId + index;\n      return it[meta.id];\n    });\n    await this.insertRelations(entity, payload);\n    return ids;\n  }\n\n  override async updateMany<E>(entity: Type<E>, qm: QueryCriteria<E>, payload: E) {\n    payload = clone(payload);\n    const query = this.dialect.update(entity, qm, payload);\n    const { changes } = await this.run(query);\n    await this.updateRelations(entity, qm, payload);\n    return changes;\n  }\n\n  override async deleteMany<E>(entity: Type<E>, qm: QueryCriteria<E>, opts?: QueryOptions) {\n    const meta = getMeta(entity);\n    const findQuery = await this.dialect.find(entity, { ...qm, $project: [meta.id] });\n    const founds = await this.all<E>(findQuery);\n    if (!founds.length) {\n      return 0;\n    }\n    const ids: IdValue<E>[] = founds.map((it) => it[meta.id]);\n    const query = this.dialect.delete(entity, { $filter: ids }, opts);\n    const { changes } = await this.run(query);\n    await this.deleteRelations(entity, ids, opts);\n    return changes;\n  }\n\n  override get hasOpenTransaction() {\n    return this.hasPendingTransaction;\n  }\n\n  override async beginTransaction(/*isolationLevel?: IsolationLevel*/) {\n    if (this.hasPendingTransaction) {\n      throw TypeError('pending transaction');\n    }\n    // TODO\n    // if (isolationLevel) {\n    //   await this.run(`SET TRANSACTION ISOLATION LEVEL ${isolationLevel}`);\n    // }\n    await this.run(this.dialect.beginTransactionCommand);\n    this.hasPendingTransaction = true;\n  }\n\n  override async commitTransaction() {\n    if (!this.hasPendingTransaction) {\n      throw TypeError('not a pending transaction');\n    }\n    await this.run('COMMIT');\n    this.hasPendingTransaction = undefined;\n  }\n\n  override async rollbackTransaction() {\n    if (!this.hasPendingTransaction) {\n      throw TypeError('not a pending transaction');\n    }\n    await this.run('ROLLBACK');\n    this.hasPendingTransaction = undefined;\n  }\n}\n"]}
88
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"abstractSqlQuerier.js","sourceRoot":"","sources":["../../src/querier/abstractSqlQuerier.ts"],"names":[],"mappings":"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","sourcesContent":["import { getMeta } from '@uql/core/entity';\nimport { Query, Type, QueryCriteria, QueryOptions, IdValue, QueryUpdateResult, IsolationLevel } from '@uql/core/type';\nimport { unflatObjects, clone } from '@uql/core/util';\nimport { AbstractSqlDialect } from '@uql/core/dialect';\n\nimport { AbstractQuerier } from './abstractQuerier';\n\nexport abstract class AbstractSqlQuerier extends AbstractQuerier {\n  private hasPendingTransaction?: boolean;\n\n  constructor(readonly dialect: AbstractSqlDialect) {\n    super();\n  }\n\n  /**\n   * read query.\n   * @param query the query\n   */\n  abstract all<T>(query: string): Promise<T[]>;\n\n  /**\n   * insert/update/delete/ddl query.\n   * @param query the query\n   */\n  abstract run(query: string): Promise<QueryUpdateResult>;\n\n  override async count<E>(entity: Type<E>, qm?: QueryCriteria<E>) {\n    const query = await this.dialect.count(entity, qm);\n    const res: any = await this.all<E>(query);\n    return Number(res[0].count);\n  }\n\n  override async findMany<E>(entity: Type<E>, qm: Query<E>) {\n    const query = this.dialect.find(entity, qm);\n    const res = await this.all<E>(query);\n    const founds = unflatObjects(res);\n    await this.findToManyRelations(entity, founds, qm.$project);\n    return founds;\n  }\n\n  override async insertMany<E>(entity: Type<E>, payload: E[]) {\n    payload = clone(payload);\n    const query = this.dialect.insert(entity, payload);\n    const { firstId } = await this.run(query);\n    const meta = getMeta(entity);\n    const ids = payload.map((it, index) => {\n      it[meta.id as string] ??= firstId + index;\n      return it[meta.id];\n    });\n    await this.insertRelations(entity, payload);\n    return ids;\n  }\n\n  override async updateMany<E>(entity: Type<E>, qm: QueryCriteria<E>, payload: E) {\n    payload = clone(payload);\n    const query = this.dialect.update(entity, qm, payload);\n    const { changes } = await this.run(query);\n    await this.updateRelations(entity, qm, payload);\n    return changes;\n  }\n\n  override async deleteMany<E>(entity: Type<E>, qm: QueryCriteria<E>, opts?: QueryOptions) {\n    const meta = getMeta(entity);\n    const findQuery = await this.dialect.find(entity, { ...qm, $project: [meta.id] });\n    const founds = await this.all<E>(findQuery);\n    if (!founds.length) {\n      return 0;\n    }\n    const ids = founds.map((it) => it[meta.id]);\n    const query = this.dialect.delete(entity, { $filter: ids }, opts);\n    const { changes } = await this.run(query);\n    await this.deleteRelations(entity, ids, opts);\n    return changes;\n  }\n\n  override get hasOpenTransaction() {\n    return this.hasPendingTransaction;\n  }\n\n  override async beginTransaction(/*isolationLevel?: IsolationLevel*/) {\n    if (this.hasPendingTransaction) {\n      throw TypeError('pending transaction');\n    }\n    // TODO\n    // if (isolationLevel) {\n    //   await this.run(`SET TRANSACTION ISOLATION LEVEL ${isolationLevel}`);\n    // }\n    await this.run(this.dialect.beginTransactionCommand);\n    this.hasPendingTransaction = true;\n  }\n\n  override async commitTransaction() {\n    if (!this.hasPendingTransaction) {\n      throw TypeError('not a pending transaction');\n    }\n    await this.run('COMMIT');\n    this.hasPendingTransaction = undefined;\n  }\n\n  override async rollbackTransaction() {\n    if (!this.hasPendingTransaction) {\n      throw TypeError('not a pending transaction');\n    }\n    await this.run('ROLLBACK');\n    this.hasPendingTransaction = undefined;\n  }\n}\n"]}
package/type/entity.d.ts CHANGED
@@ -1,22 +1,23 @@
1
- import { QueryRaw, QueryRawFnOptions } from './query';
1
+ import { QueryRaw } from './query';
2
2
  import { Scalar, Type } from './utility';
3
+ export declare const idKey: unique symbol;
3
4
  export declare type Key<E> = {
4
- readonly [K in keyof E]: K & string;
5
+ readonly [K in keyof E]?: K & string;
5
6
  }[keyof E & string];
6
7
  export declare type FieldKey<E> = {
7
- readonly [K in Key<E>]: E[K] extends Scalar ? K : never;
8
+ readonly [K in Key<E>]?: E[K] extends Scalar ? K : never;
8
9
  }[Key<E>];
9
10
  export declare type FieldValue<E> = E[FieldKey<E>];
10
- export declare const idType: unique symbol;
11
- export declare type IdValue<E> = E extends {
12
- [idType]?: infer U;
13
- } ? U : E extends {
14
- id?: infer U;
15
- } ? U : E extends {
16
- _id?: infer U;
17
- } ? U & string : FieldValue<E>;
11
+ export declare type IdKey<E> = E extends {
12
+ [idKey]?: infer K;
13
+ } ? K & FieldKey<E> : E extends {
14
+ _id?: unknown;
15
+ } ? '_id' & FieldKey<E> : E extends {
16
+ id?: unknown;
17
+ } ? 'id' & FieldKey<E> : FieldKey<E>;
18
+ export declare type IdValue<E> = E[IdKey<E>];
18
19
  export declare type RelationKey<E> = {
19
- readonly [K in Key<E>]: E[K] extends Scalar ? never : K;
20
+ readonly [K in Key<E>]?: E[K] extends Scalar ? never : K;
20
21
  }[Key<E>];
21
22
  export declare type RelationValue<E> = E[RelationKey<E>];
22
23
  export declare type EntityOptions = {
@@ -33,7 +34,7 @@ export declare type FieldOptions = {
33
34
  readonly onUpdate?: OnFieldCallback;
34
35
  readonly onDelete?: OnFieldCallback;
35
36
  };
36
- export declare type OnFieldCallback = (opts?: QueryRawFnOptions) => Scalar;
37
+ export declare type OnFieldCallback = Scalar | QueryRaw | (() => Scalar | QueryRaw);
37
38
  export declare type EntityGetter<E = any> = () => Type<E>;
38
39
  export declare type ReferenceOptions<E = any> = {
39
40
  entity: EntityGetter<E>;
@@ -67,7 +68,7 @@ export declare type RelationManyToManyOptions<E> = RelationOptionsThroughOwner<E
67
68
  export declare type EntityMeta<E> = {
68
69
  readonly entity: Type<E>;
69
70
  name?: string;
70
- id?: FieldKey<E>;
71
+ id?: IdKey<E>;
71
72
  softDelete?: FieldKey<E>;
72
73
  fields: {
73
74
  [K in FieldKey<E>]?: FieldOptions;
package/type/entity.js CHANGED
@@ -1,5 +1,5 @@
1
1
  "use strict";
2
2
  Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.idType = void 0;
4
- exports.idType = Symbol('idType');
5
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZW50aXR5LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vc3JjL3R5cGUvZW50aXR5LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7OztBQWFhLFFBQUEsTUFBTSxHQUFHLE1BQU0sQ0FBQyxRQUFRLENBQUMsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IFF1ZXJ5UmF3LCBRdWVyeVJhd0ZuT3B0aW9ucyB9IGZyb20gJy4vcXVlcnknO1xuaW1wb3J0IHsgU2NhbGFyLCBUeXBlIH0gZnJvbSAnLi91dGlsaXR5JztcblxuZXhwb3J0IHR5cGUgS2V5PEU+ID0ge1xuICByZWFkb25seSBbSyBpbiBrZXlvZiBFXTogSyAmIHN0cmluZztcbn1ba2V5b2YgRSAmIHN0cmluZ107XG5cbmV4cG9ydCB0eXBlIEZpZWxkS2V5PEU+ID0ge1xuICByZWFkb25seSBbSyBpbiBLZXk8RT5dOiBFW0tdIGV4dGVuZHMgU2NhbGFyID8gSyA6IG5ldmVyO1xufVtLZXk8RT5dO1xuXG5leHBvcnQgdHlwZSBGaWVsZFZhbHVlPEU+ID0gRVtGaWVsZEtleTxFPl07XG5cbmV4cG9ydCBjb25zdCBpZFR5cGUgPSBTeW1ib2woJ2lkVHlwZScpO1xuXG5leHBvcnQgdHlwZSBJZFZhbHVlPEU+ID0gRSBleHRlbmRzIHsgW2lkVHlwZV0/OiBpbmZlciBVIH1cbiAgPyBVXG4gIDogRSBleHRlbmRzIHsgaWQ/OiBpbmZlciBVIH1cbiAgPyBVXG4gIDogRSBleHRlbmRzIHsgX2lkPzogaW5mZXIgVSB9XG4gID8gVSAmIHN0cmluZ1xuICA6IEZpZWxkVmFsdWU8RT47XG5cbmV4cG9ydCB0eXBlIFJlbGF0aW9uS2V5PEU+ID0ge1xuICByZWFkb25seSBbSyBpbiBLZXk8RT5dOiBFW0tdIGV4dGVuZHMgU2NhbGFyID8gbmV2ZXIgOiBLO1xufVtLZXk8RT5dO1xuXG5leHBvcnQgdHlwZSBSZWxhdGlvblZhbHVlPEU+ID0gRVtSZWxhdGlvbktleTxFPl07XG5cbmV4cG9ydCB0eXBlIEVudGl0eU9wdGlvbnMgPSB7XG4gIHJlYWRvbmx5IG5hbWU/OiBzdHJpbmc7XG4gIHJlYWRvbmx5IHNvZnREZWxldGU/OiBib29sZWFuO1xufTtcblxuZXhwb3J0IHR5cGUgRmllbGRPcHRpb25zID0ge1xuICByZWFkb25seSBuYW1lPzogc3RyaW5nO1xuICByZWFkb25seSBpc0lkPzogdHJ1ZTtcbiAgcmVhZG9ubHkgdHlwZT86IGFueTtcbiAgcmVhZG9ubHkgcmVmZXJlbmNlPzogRW50aXR5R2V0dGVyIHwgUmVmZXJlbmNlT3B0aW9ucztcbiAgcmVhZG9ubHkgdmlydHVhbD86IFF1ZXJ5UmF3O1xuICByZWFkb25seSBvbkluc2VydD86IE9uRmllbGRDYWxsYmFjaztcbiAgcmVhZG9ubHkgb25VcGRhdGU/OiBPbkZpZWxkQ2FsbGJhY2s7XG4gIHJlYWRvbmx5IG9uRGVsZXRlPzogT25GaWVsZENhbGxiYWNrO1xufTtcblxuZXhwb3J0IHR5cGUgT25GaWVsZENhbGxiYWNrID0gKG9wdHM/OiBRdWVyeVJhd0ZuT3B0aW9ucykgPT4gU2NhbGFyO1xuXG5leHBvcnQgdHlwZSBFbnRpdHlHZXR0ZXI8RSA9IGFueT4gPSAoKSA9PiBUeXBlPEU+O1xuXG5leHBvcnQgdHlwZSBSZWZlcmVuY2VPcHRpb25zPEUgPSBhbnk+ID0geyBlbnRpdHk6IEVudGl0eUdldHRlcjxFPiB9O1xuXG5leHBvcnQgdHlwZSBDYXNjYWRlVHlwZSA9ICdwZXJzaXN0JyB8ICdkZWxldGUnO1xuXG5leHBvcnQgdHlwZSBSZWxhdGlvbk9wdGlvbnM8RSA9IGFueT4gPSB7XG4gIGVudGl0eT86IEVudGl0eUdldHRlcjxFPjtcbiAgcmVhZG9ubHkgY2FyZGluYWxpdHk/OiBSZWxhdGlvbkNhcmRpbmFsaXR5O1xuICByZWFkb25seSBjYXNjYWRlPzogYm9vbGVhbiB8IENhc2NhZGVUeXBlO1xuICBtYXBwZWRCeT86IFJlbGF0aW9uTWFwcGVkQnk8RT47XG4gIHRocm91Z2g/OiBFbnRpdHlHZXR0ZXI8UmVsYXRpb25WYWx1ZTxFPj47XG4gIHJlZmVyZW5jZXM/OiBSZWxhdGlvblJlZmVyZW5jZXM7XG59O1xuXG50eXBlIFJlbGF0aW9uT3B0aW9uc093bmVyPEU+ID0gUGljazxSZWxhdGlvbk9wdGlvbnM8RT4sICdlbnRpdHknIHwgJ3JlZmVyZW5jZXMnIHwgJ2Nhc2NhZGUnPjtcbnR5cGUgUmVsYXRpb25PcHRpb25zSW52ZXJzZVNpZGU8RT4gPSBQaWNrPFJlbGF0aW9uT3B0aW9uczxFPiwgJ2VudGl0eScgfCAnbWFwcGVkQnknIHwgJ2Nhc2NhZGUnPjtcbnR5cGUgUmVsYXRpb25PcHRpb25zVGhyb3VnaE93bmVyPEU+ID0gUGljazxSZWxhdGlvbk9wdGlvbnM8RT4sICdlbnRpdHknIHwgJ3Rocm91Z2gnIHwgJ3JlZmVyZW5jZXMnIHwgJ2Nhc2NhZGUnPjtcblxuZXhwb3J0IHR5cGUgUmVsYXRpb25LZXlNYXA8RT4gPSB7IHJlYWRvbmx5IFtLIGluIFJlbGF0aW9uS2V5PEU+XTogSyB9O1xuXG5leHBvcnQgdHlwZSBSZWxhdGlvbktleU1hcHBlcjxFPiA9IChrZXlNYXA6IFJlbGF0aW9uS2V5TWFwPEU+KSA9PiBSZWxhdGlvbktleTxFPjtcblxuZXhwb3J0IHR5cGUgUmVsYXRpb25SZWZlcmVuY2VzID0geyBsb2NhbDogc3RyaW5nOyBmb3JlaWduOiBzdHJpbmcgfVtdO1xuXG5leHBvcnQgdHlwZSBSZWxhdGlvbk1hcHBlZEJ5PEU+ID0gUmVsYXRpb25LZXk8RT4gfCBSZWxhdGlvbktleU1hcHBlcjxFPjtcblxuZXhwb3J0IHR5cGUgUmVsYXRpb25DYXJkaW5hbGl0eSA9ICcxMScgfCAnbTEnIHwgJzFtJyB8ICdtbSc7XG5cbmV4cG9ydCB0eXBlIFJlbGF0aW9uT25lVG9PbmVPcHRpb25zPEU+ID0gUmVsYXRpb25PcHRpb25zT3duZXI8RT4gfCBSZWxhdGlvbk9wdGlvbnNJbnZlcnNlU2lkZTxFPjtcblxuZXhwb3J0IHR5cGUgUmVsYXRpb25PbmVUb01hbnlPcHRpb25zPEU+ID0gUmVsYXRpb25PcHRpb25zT3duZXI8RT4gfCBSZWxhdGlvbk9wdGlvbnNJbnZlcnNlU2lkZTxFPiB8IFJlbGF0aW9uT3B0aW9uc1Rocm91Z2hPd25lcjxFPjtcblxuZXhwb3J0IHR5cGUgUmVsYXRpb25NYW55VG9PbmVPcHRpb25zPEU+ID0gUmVsYXRpb25PcHRpb25zT3duZXI8RT4gfCBSZWxhdGlvbk9wdGlvbnNJbnZlcnNlU2lkZTxFPjtcblxuZXhwb3J0IHR5cGUgUmVsYXRpb25NYW55VG9NYW55T3B0aW9uczxFPiA9IFJlbGF0aW9uT3B0aW9uc1Rocm91Z2hPd25lcjxFPiB8IFJlbGF0aW9uT3B0aW9uc0ludmVyc2VTaWRlPEU+O1xuXG5leHBvcnQgdHlwZSBFbnRpdHlNZXRhPEU+ID0ge1xuICByZWFkb25seSBlbnRpdHk6IFR5cGU8RT47XG4gIG5hbWU/OiBzdHJpbmc7XG4gIGlkPzogRmllbGRLZXk8RT47XG4gIHNvZnREZWxldGU/OiBGaWVsZEtleTxFPjtcbiAgZmllbGRzOiB7XG4gICAgW0sgaW4gRmllbGRLZXk8RT5dPzogRmllbGRPcHRpb25zO1xuICB9O1xuICByZWxhdGlvbnM6IHtcbiAgICBbSyBpbiBSZWxhdGlvbktleTxFPl0/OiBSZWxhdGlvbk9wdGlvbnM7XG4gIH07XG4gIHByb2Nlc3NlZD86IGJvb2xlYW47XG59O1xuIl19
3
+ exports.idKey = void 0;
4
+ exports.idKey = Symbol('idKey');
5
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZW50aXR5LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vc3JjL3R5cGUvZW50aXR5LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7OztBQUdhLFFBQUEsS0FBSyxHQUFHLE1BQU0sQ0FBQyxPQUFPLENBQUMsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IFF1ZXJ5UmF3LCBRdWVyeVJhd0ZuT3B0aW9ucyB9IGZyb20gJy4vcXVlcnknO1xuaW1wb3J0IHsgU2NhbGFyLCBUeXBlIH0gZnJvbSAnLi91dGlsaXR5JztcblxuZXhwb3J0IGNvbnN0IGlkS2V5ID0gU3ltYm9sKCdpZEtleScpO1xuXG5leHBvcnQgdHlwZSBLZXk8RT4gPSB7XG4gIHJlYWRvbmx5IFtLIGluIGtleW9mIEVdPzogSyAmIHN0cmluZztcbn1ba2V5b2YgRSAmIHN0cmluZ107XG5cbmV4cG9ydCB0eXBlIEZpZWxkS2V5PEU+ID0ge1xuICByZWFkb25seSBbSyBpbiBLZXk8RT5dPzogRVtLXSBleHRlbmRzIFNjYWxhciA/IEsgOiBuZXZlcjtcbn1bS2V5PEU+XTtcblxuZXhwb3J0IHR5cGUgRmllbGRWYWx1ZTxFPiA9IEVbRmllbGRLZXk8RT5dO1xuXG5leHBvcnQgdHlwZSBJZEtleTxFPiA9IEUgZXh0ZW5kcyB7IFtpZEtleV0/OiBpbmZlciBLIH1cbiAgPyBLICYgRmllbGRLZXk8RT5cbiAgOiBFIGV4dGVuZHMgeyBfaWQ/OiB1bmtub3duIH1cbiAgPyAnX2lkJyAmIEZpZWxkS2V5PEU+XG4gIDogRSBleHRlbmRzIHsgaWQ/OiB1bmtub3duIH1cbiAgPyAnaWQnICYgRmllbGRLZXk8RT5cbiAgOiBGaWVsZEtleTxFPjtcblxuZXhwb3J0IHR5cGUgSWRWYWx1ZTxFPiA9IEVbSWRLZXk8RT5dO1xuXG5leHBvcnQgdHlwZSBSZWxhdGlvbktleTxFPiA9IHtcbiAgcmVhZG9ubHkgW0sgaW4gS2V5PEU+XT86IEVbS10gZXh0ZW5kcyBTY2FsYXIgPyBuZXZlciA6IEs7XG59W0tleTxFPl07XG5cbmV4cG9ydCB0eXBlIFJlbGF0aW9uVmFsdWU8RT4gPSBFW1JlbGF0aW9uS2V5PEU+XTtcblxuZXhwb3J0IHR5cGUgRW50aXR5T3B0aW9ucyA9IHtcbiAgcmVhZG9ubHkgbmFtZT86IHN0cmluZztcbiAgcmVhZG9ubHkgc29mdERlbGV0ZT86IGJvb2xlYW47XG59O1xuXG5leHBvcnQgdHlwZSBGaWVsZE9wdGlvbnMgPSB7XG4gIHJlYWRvbmx5IG5hbWU/OiBzdHJpbmc7XG4gIHJlYWRvbmx5IGlzSWQ/OiB0cnVlO1xuICByZWFkb25seSB0eXBlPzogYW55O1xuICByZWFkb25seSByZWZlcmVuY2U/OiBFbnRpdHlHZXR0ZXIgfCBSZWZlcmVuY2VPcHRpb25zO1xuICByZWFkb25seSB2aXJ0dWFsPzogUXVlcnlSYXc7XG4gIHJlYWRvbmx5IG9uSW5zZXJ0PzogT25GaWVsZENhbGxiYWNrO1xuICByZWFkb25seSBvblVwZGF0ZT86IE9uRmllbGRDYWxsYmFjaztcbiAgcmVhZG9ubHkgb25EZWxldGU/OiBPbkZpZWxkQ2FsbGJhY2s7XG59O1xuXG5leHBvcnQgdHlwZSBPbkZpZWxkQ2FsbGJhY2sgPSBTY2FsYXIgfCBRdWVyeVJhdyB8ICgoKSA9PiBTY2FsYXIgfCBRdWVyeVJhdyk7XG5cbmV4cG9ydCB0eXBlIEVudGl0eUdldHRlcjxFID0gYW55PiA9ICgpID0+IFR5cGU8RT47XG5cbmV4cG9ydCB0eXBlIFJlZmVyZW5jZU9wdGlvbnM8RSA9IGFueT4gPSB7IGVudGl0eTogRW50aXR5R2V0dGVyPEU+IH07XG5cbmV4cG9ydCB0eXBlIENhc2NhZGVUeXBlID0gJ3BlcnNpc3QnIHwgJ2RlbGV0ZSc7XG5cbmV4cG9ydCB0eXBlIFJlbGF0aW9uT3B0aW9uczxFID0gYW55PiA9IHtcbiAgZW50aXR5PzogRW50aXR5R2V0dGVyPEU+O1xuICByZWFkb25seSBjYXJkaW5hbGl0eT86IFJlbGF0aW9uQ2FyZGluYWxpdHk7XG4gIHJlYWRvbmx5IGNhc2NhZGU/OiBib29sZWFuIHwgQ2FzY2FkZVR5cGU7XG4gIG1hcHBlZEJ5PzogUmVsYXRpb25NYXBwZWRCeTxFPjtcbiAgdGhyb3VnaD86IEVudGl0eUdldHRlcjxSZWxhdGlvblZhbHVlPEU+PjtcbiAgcmVmZXJlbmNlcz86IFJlbGF0aW9uUmVmZXJlbmNlcztcbn07XG5cbnR5cGUgUmVsYXRpb25PcHRpb25zT3duZXI8RT4gPSBQaWNrPFJlbGF0aW9uT3B0aW9uczxFPiwgJ2VudGl0eScgfCAncmVmZXJlbmNlcycgfCAnY2FzY2FkZSc+O1xudHlwZSBSZWxhdGlvbk9wdGlvbnNJbnZlcnNlU2lkZTxFPiA9IFBpY2s8UmVsYXRpb25PcHRpb25zPEU+LCAnZW50aXR5JyB8ICdtYXBwZWRCeScgfCAnY2FzY2FkZSc+O1xudHlwZSBSZWxhdGlvbk9wdGlvbnNUaHJvdWdoT3duZXI8RT4gPSBQaWNrPFJlbGF0aW9uT3B0aW9uczxFPiwgJ2VudGl0eScgfCAndGhyb3VnaCcgfCAncmVmZXJlbmNlcycgfCAnY2FzY2FkZSc+O1xuXG5leHBvcnQgdHlwZSBSZWxhdGlvbktleU1hcDxFPiA9IHsgcmVhZG9ubHkgW0sgaW4gUmVsYXRpb25LZXk8RT5dOiBLIH07XG5cbmV4cG9ydCB0eXBlIFJlbGF0aW9uS2V5TWFwcGVyPEU+ID0gKGtleU1hcDogUmVsYXRpb25LZXlNYXA8RT4pID0+IFJlbGF0aW9uS2V5PEU+O1xuXG5leHBvcnQgdHlwZSBSZWxhdGlvblJlZmVyZW5jZXMgPSB7IGxvY2FsOiBzdHJpbmc7IGZvcmVpZ246IHN0cmluZyB9W107XG5cbmV4cG9ydCB0eXBlIFJlbGF0aW9uTWFwcGVkQnk8RT4gPSBSZWxhdGlvbktleTxFPiB8IFJlbGF0aW9uS2V5TWFwcGVyPEU+O1xuXG5leHBvcnQgdHlwZSBSZWxhdGlvbkNhcmRpbmFsaXR5ID0gJzExJyB8ICdtMScgfCAnMW0nIHwgJ21tJztcblxuZXhwb3J0IHR5cGUgUmVsYXRpb25PbmVUb09uZU9wdGlvbnM8RT4gPSBSZWxhdGlvbk9wdGlvbnNPd25lcjxFPiB8IFJlbGF0aW9uT3B0aW9uc0ludmVyc2VTaWRlPEU+O1xuXG5leHBvcnQgdHlwZSBSZWxhdGlvbk9uZVRvTWFueU9wdGlvbnM8RT4gPSBSZWxhdGlvbk9wdGlvbnNPd25lcjxFPiB8IFJlbGF0aW9uT3B0aW9uc0ludmVyc2VTaWRlPEU+IHwgUmVsYXRpb25PcHRpb25zVGhyb3VnaE93bmVyPEU+O1xuXG5leHBvcnQgdHlwZSBSZWxhdGlvbk1hbnlUb09uZU9wdGlvbnM8RT4gPSBSZWxhdGlvbk9wdGlvbnNPd25lcjxFPiB8IFJlbGF0aW9uT3B0aW9uc0ludmVyc2VTaWRlPEU+O1xuXG5leHBvcnQgdHlwZSBSZWxhdGlvbk1hbnlUb01hbnlPcHRpb25zPEU+ID0gUmVsYXRpb25PcHRpb25zVGhyb3VnaE93bmVyPEU+IHwgUmVsYXRpb25PcHRpb25zSW52ZXJzZVNpZGU8RT47XG5cbmV4cG9ydCB0eXBlIEVudGl0eU1ldGE8RT4gPSB7XG4gIHJlYWRvbmx5IGVudGl0eTogVHlwZTxFPjtcbiAgbmFtZT86IHN0cmluZztcbiAgaWQ/OiBJZEtleTxFPjtcbiAgc29mdERlbGV0ZT86IEZpZWxkS2V5PEU+O1xuICBmaWVsZHM6IHtcbiAgICBbSyBpbiBGaWVsZEtleTxFPl0/OiBGaWVsZE9wdGlvbnM7XG4gIH07XG4gIHJlbGF0aW9uczoge1xuICAgIFtLIGluIFJlbGF0aW9uS2V5PEU+XT86IFJlbGF0aW9uT3B0aW9ucztcbiAgfTtcbiAgcHJvY2Vzc2VkPzogYm9vbGVhbjtcbn07XG4iXX0=
@@ -1,4 +1,4 @@
1
- import { EntityMeta, QueryProject, CascadeType, RelationKey, FieldOptions, QuerySort, QuerySortMap, QueryRawFnOptions, QueryFilter, QueryFilterMap } from '@uql/core/type';
1
+ import { EntityMeta, QueryProject, CascadeType, RelationKey, FieldOptions, QuerySort, QuerySortMap, QueryRawFnOptions, QueryFilter, QueryFilterMap, OnFieldCallback } from '@uql/core/type';
2
2
  import { Raw } from '@uql/core/util';
3
3
  declare type CallbackKey = keyof Pick<FieldOptions, 'onInsert' | 'onUpdate' | 'onDelete'>;
4
4
  export declare function getRawValue(opts: QueryRawFnOptions & {
@@ -8,6 +8,7 @@ export declare function getRawValue(opts: QueryRawFnOptions & {
8
8
  }): import("@uql/core/type").Scalar;
9
9
  export declare function getPersistable<E>(meta: EntityMeta<E>, payload: E, callbackKey: CallbackKey): E;
10
10
  export declare function getPersistables<E>(meta: EntityMeta<E>, payload: E | E[], callbackKey: CallbackKey): E[];
11
+ export declare function getFieldCallbackValue(val: OnFieldCallback): import("@uql/core/type").Scalar | import("@uql/core/type").QueryRaw;
11
12
  export declare function getPersistableRelations<E>(meta: EntityMeta<E>, payload: E, action: CascadeType): RelationKey<E>[];
12
13
  export declare function isCascadable(action: CascadeType, configuration?: boolean | CascadeType): boolean;
13
14
  export declare function getProjectRelationKeys<E>(meta: EntityMeta<E>, project: QueryProject<E>): RelationKey<E>[];
@@ -1,6 +1,6 @@
1
1
  "use strict";
2
2
  Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.getQueryFilterAsMap = exports.augmentFilter = exports.buildSortMap = exports.isProjectingRelations = exports.getProjectRelationKeys = exports.isCascadable = exports.getPersistableRelations = exports.getPersistables = exports.getPersistable = exports.getRawValue = void 0;
3
+ exports.getQueryFilterAsMap = exports.augmentFilter = exports.buildSortMap = exports.isProjectingRelations = exports.getProjectRelationKeys = exports.isCascadable = exports.getPersistableRelations = exports.getFieldCallbackValue = exports.getPersistables = exports.getPersistable = exports.getRawValue = void 0;
4
4
  const util_1 = require("@uql/core/util");
5
5
  function getRawValue(opts) {
6
6
  var _a;
@@ -28,13 +28,17 @@ function getPersistables(meta, payload, callbackKey) {
28
28
  }, {}));
29
29
  }
30
30
  exports.getPersistables = getPersistables;
31
+ function getFieldCallbackValue(val) {
32
+ return typeof val === 'function' ? val() : val;
33
+ }
34
+ exports.getFieldCallbackValue = getFieldCallbackValue;
31
35
  function fillOnFields(meta, payload, callbackKey) {
32
36
  const payloads = Array.isArray(payload) ? payload : [payload];
33
- const keys = (0, util_1.getKeys)(meta.fields).filter((col) => meta.fields[col][callbackKey]);
37
+ const keys = (0, util_1.getKeys)(meta.fields).filter((key) => meta.fields[key][callbackKey]);
34
38
  return payloads.map((it) => {
35
39
  for (const key of keys) {
36
40
  if (it[key] === undefined) {
37
- it[key] = meta.fields[key][callbackKey]();
41
+ it[key] = getFieldCallbackValue(meta.fields[key][callbackKey]);
38
42
  }
39
43
  }
40
44
  return it;
@@ -107,4 +111,4 @@ function getQueryFilterAsMap(meta, filter = {}) {
107
111
  return filter;
108
112
  }
109
113
  exports.getQueryFilterAsMap = getQueryFilterAsMap;
110
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dialect.util.js","sourceRoot":"","sources":["../../src/util/dialect.util.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  EntityMeta,\n  FieldKey,\n  QueryProject,\n  CascadeType,\n  RelationKey,\n  FieldOptions,\n  Key,\n  QuerySort,\n  QuerySortMap,\n  QueryRawFnOptions,\n  QueryFilter,\n  QueryFilterMap,\n} from '@uql/core/type';\nimport { getKeys, Raw } from '@uql/core/util';\n\ntype CallbackKey = keyof Pick<FieldOptions, 'onInsert' | 'onUpdate' | 'onDelete'>;\n\nexport function getRawValue(opts: QueryRawFnOptions & { value: Raw; alias?: string; autoPrefixAlias?: boolean }) {\n  const { value, prefix = '', dialect, autoPrefixAlias } = opts;\n  const val = typeof value.value === 'function' ? value.value(opts) : prefix + value.value;\n  const alias = opts.alias ?? value.alias;\n  if (alias) {\n    const fullAlias = autoPrefixAlias ? prefix + alias : alias;\n    const escapedFullAlias = dialect.escapeId(fullAlias, true);\n    return `${val} ${escapedFullAlias}`;\n  }\n  return val;\n}\n\nexport function getPersistable<E>(meta: EntityMeta<E>, payload: E, callbackKey: CallbackKey): E {\n  return getPersistables(meta, payload, callbackKey)[0];\n}\n\nexport function getPersistables<E>(meta: EntityMeta<E>, payload: E | E[], callbackKey: CallbackKey): E[] {\n  const payloads = fillOnFields(meta, payload, callbackKey);\n  const persistableKeys = getKeys(payloads[0]).filter((key) => meta.fields[key]) as FieldKey<E>[];\n  return payloads.map((it) =>\n    persistableKeys.reduce((acc, key) => {\n      acc[key] = it[key];\n      return acc;\n    }, {} as E)\n  );\n}\n\nfunction fillOnFields<E>(meta: EntityMeta<E>, payload: E | E[], callbackKey: CallbackKey): E[] {\n  const payloads = Array.isArray(payload) ? payload : [payload];\n  const keys = getKeys(meta.fields).filter((col) => meta.fields[col][callbackKey]);\n  return payloads.map((it) => {\n    for (const key of keys) {\n      if (it[key] === undefined) {\n        it[key] = meta.fields[key][callbackKey]();\n      }\n    }\n    return it;\n  });\n}\n\nexport function getPersistableRelations<E>(meta: EntityMeta<E>, payload: E, action: CascadeType): RelationKey<E>[] {\n  const keys = getKeys(payload);\n  return keys.filter((key) => {\n    const relOpts = meta.relations[key as RelationKey<E>];\n    return relOpts && isCascadable(action, relOpts.cascade);\n  }) as RelationKey<E>[];\n}\n\nexport function isCascadable(action: CascadeType, configuration?: boolean | CascadeType): boolean {\n  if (typeof configuration === 'boolean') {\n    return configuration;\n  }\n  return configuration === action;\n}\n\nexport function getProjectRelationKeys<E>(meta: EntityMeta<E>, project: QueryProject<E>): RelationKey<E>[] {\n  const keys = getProjectKeys(project);\n  return keys.filter((key) => meta.relations[key as RelationKey<E>]) as RelationKey<E>[];\n}\n\nexport function isProjectingRelations<E>(meta: EntityMeta<E>, project: QueryProject<E>): boolean {\n  const keys = getProjectKeys(project);\n  return keys.some((key) => meta.relations[key as RelationKey<E>]);\n}\n\nfunction getProjectKeys<E>(project: QueryProject<E>): Key<E>[] {\n  if (Array.isArray(project)) {\n    return project as Key<E>[];\n  }\n  return getKeys(project).filter((key) => project[key]) as Key<E>[];\n}\n\nexport function buildSortMap<E>(sort: QuerySort<E>): QuerySortMap<E> {\n  if (Array.isArray(sort)) {\n    return sort.reduce((acc, it) => {\n      if (Array.isArray(it)) {\n        acc[it[0]] = it[1];\n      } else {\n        acc[it.field] = it.sort;\n      }\n      return acc;\n    }, {} as QuerySortMap<E>);\n  }\n  return sort as QuerySortMap<E>;\n}\n\nexport function augmentFilter<E>(meta: EntityMeta<E>, target: QueryFilter<E> = {}, source: QueryFilter<E> = {}): QueryFilter<E> {\n  const targetComparison = getQueryFilterAsMap(meta, target);\n  const sourceComparison = getQueryFilterAsMap(meta, source);\n  return {\n    ...targetComparison,\n    ...sourceComparison,\n  };\n}\n\nexport function getQueryFilterAsMap<E>(meta: EntityMeta<E>, filter: QueryFilter<E> = {}): QueryFilterMap<E> {\n  if (filter instanceof Raw) {\n    return { $and: [filter] } as QueryFilterMap<E>;\n  }\n  if (typeof filter !== 'object' || Array.isArray(filter) || typeof (filter as MongoId).toHexString === 'function') {\n    return {\n      [meta.id]: filter,\n    } as QueryFilterMap<E>;\n  }\n  return filter as QueryFilterMap<E>;\n}\n\ntype MongoId = {\n  readonly toHexString: Function;\n};\n"]}
114
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dialect.util.js","sourceRoot":"","sources":["../../src/util/dialect.util.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  EntityMeta,\n  FieldKey,\n  QueryProject,\n  CascadeType,\n  RelationKey,\n  FieldOptions,\n  Key,\n  QuerySort,\n  QuerySortMap,\n  QueryRawFnOptions,\n  QueryFilter,\n  QueryFilterMap,\n  OnFieldCallback,\n} from '@uql/core/type';\nimport { getKeys, Raw } from '@uql/core/util';\n\ntype CallbackKey = keyof Pick<FieldOptions, 'onInsert' | 'onUpdate' | 'onDelete'>;\n\nexport function getRawValue(opts: QueryRawFnOptions & { value: Raw; alias?: string; autoPrefixAlias?: boolean }) {\n  const { value, prefix = '', dialect, autoPrefixAlias } = opts;\n  const val = typeof value.value === 'function' ? value.value(opts) : prefix + value.value;\n  const alias = opts.alias ?? value.alias;\n  if (alias) {\n    const fullAlias = autoPrefixAlias ? prefix + alias : alias;\n    const escapedFullAlias = dialect.escapeId(fullAlias, true);\n    return `${val} ${escapedFullAlias}`;\n  }\n  return val;\n}\n\nexport function getPersistable<E>(meta: EntityMeta<E>, payload: E, callbackKey: CallbackKey): E {\n  return getPersistables(meta, payload, callbackKey)[0];\n}\n\nexport function getPersistables<E>(meta: EntityMeta<E>, payload: E | E[], callbackKey: CallbackKey): E[] {\n  const payloads = fillOnFields(meta, payload, callbackKey);\n  const persistableKeys = getKeys(payloads[0]).filter((key) => meta.fields[key]) as FieldKey<E>[];\n  return payloads.map((it) =>\n    persistableKeys.reduce((acc, key) => {\n      acc[key] = it[key];\n      return acc;\n    }, {} as E)\n  );\n}\n\nexport function getFieldCallbackValue(val: OnFieldCallback) {\n  return typeof val === 'function' ? val() : val;\n}\n\nfunction fillOnFields<E>(meta: EntityMeta<E>, payload: E | E[], callbackKey: CallbackKey): E[] {\n  const payloads = Array.isArray(payload) ? payload : [payload];\n  const keys = getKeys(meta.fields).filter((key) => meta.fields[key][callbackKey]);\n  return payloads.map((it) => {\n    for (const key of keys) {\n      if (it[key] === undefined) {\n        it[key] = getFieldCallbackValue(meta.fields[key][callbackKey]);\n      }\n    }\n    return it;\n  });\n}\n\nexport function getPersistableRelations<E>(meta: EntityMeta<E>, payload: E, action: CascadeType): RelationKey<E>[] {\n  const keys = getKeys(payload);\n  return keys.filter((key) => {\n    const relOpts = meta.relations[key as RelationKey<E>];\n    return relOpts && isCascadable(action, relOpts.cascade);\n  }) as RelationKey<E>[];\n}\n\nexport function isCascadable(action: CascadeType, configuration?: boolean | CascadeType): boolean {\n  if (typeof configuration === 'boolean') {\n    return configuration;\n  }\n  return configuration === action;\n}\n\nexport function getProjectRelationKeys<E>(meta: EntityMeta<E>, project: QueryProject<E>): RelationKey<E>[] {\n  const keys = getProjectKeys(project);\n  return keys.filter((key) => meta.relations[key as RelationKey<E>]) as RelationKey<E>[];\n}\n\nexport function isProjectingRelations<E>(meta: EntityMeta<E>, project: QueryProject<E>): boolean {\n  const keys = getProjectKeys(project);\n  return keys.some((key) => meta.relations[key as RelationKey<E>]);\n}\n\nfunction getProjectKeys<E>(project: QueryProject<E>): Key<E>[] {\n  if (Array.isArray(project)) {\n    return project as Key<E>[];\n  }\n  return getKeys(project).filter((key) => project[key]) as Key<E>[];\n}\n\nexport function buildSortMap<E>(sort: QuerySort<E>): QuerySortMap<E> {\n  if (Array.isArray(sort)) {\n    return sort.reduce((acc, it) => {\n      if (Array.isArray(it)) {\n        acc[it[0]] = it[1];\n      } else {\n        acc[it.field] = it.sort;\n      }\n      return acc;\n    }, {} as QuerySortMap<E>);\n  }\n  return sort as QuerySortMap<E>;\n}\n\nexport function augmentFilter<E>(meta: EntityMeta<E>, target: QueryFilter<E> = {}, source: QueryFilter<E> = {}): QueryFilter<E> {\n  const targetComparison = getQueryFilterAsMap(meta, target);\n  const sourceComparison = getQueryFilterAsMap(meta, source);\n  return {\n    ...targetComparison,\n    ...sourceComparison,\n  };\n}\n\nexport function getQueryFilterAsMap<E>(meta: EntityMeta<E>, filter: QueryFilter<E> = {}): QueryFilterMap<E> {\n  if (filter instanceof Raw) {\n    return { $and: [filter] } as QueryFilterMap<E>;\n  }\n  if (typeof filter !== 'object' || Array.isArray(filter) || typeof (filter as MongoId).toHexString === 'function') {\n    return {\n      [meta.id]: filter,\n    } as QueryFilterMap<E>;\n  }\n  return filter as QueryFilterMap<E>;\n}\n\ntype MongoId = {\n  readonly toHexString: Function;\n};\n"]}