@uql/core 0.4.75 → 0.4.76

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.
@@ -313,20 +313,19 @@ class AbstractSqlDialect {
313
313
  }
314
314
  insert(entity, payload) {
315
315
  const meta = (0, entity_1.getMeta)(entity);
316
- payload = (0, util_1.getPersistables)(meta, payload, 'onInsert');
317
- 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]);
318
318
  const columns = keys.map((key) => this.escapeId(meta.fields[key].name));
319
- 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('), (');
320
320
  return `INSERT INTO ${this.escapeId(meta.name)} (${columns.join(', ')}) VALUES (${values})`;
321
321
  }
322
322
  update(entity, qm, payload, opts) {
323
323
  const meta = (0, entity_1.getMeta)(entity);
324
- payload = (0, util_1.getPersistable)(meta, payload, 'onUpdate');
325
- const values = (0, util_1.getKeys)(payload)
326
- .map((key) => `${this.escapeId(key)} = ${this.escape(payload[key])}`)
327
- .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(', ');
328
327
  const criteria = this.criteria(entity, qm, opts);
329
- return `UPDATE ${this.escapeId(meta.name)} SET ${values}${criteria}`;
328
+ return `UPDATE ${this.escapeId(meta.name)} SET ${entries}${criteria}`;
330
329
  }
331
330
  delete(entity, qm, opts = {}) {
332
331
  const meta = (0, entity_1.getMeta)(entity);
@@ -359,8 +358,11 @@ class AbstractSqlDialect {
359
358
  return escaped + suffix;
360
359
  }
361
360
  escape(value) {
361
+ if (value instanceof util_1.Raw) {
362
+ return (0, util_1.getRawValue)({ value, dialect: this });
363
+ }
362
364
  return (0, sqlstring_1.escape)(value);
363
365
  }
364
366
  }
365
367
  exports.AbstractSqlDialect = AbstractSqlDialect;
366
- //# 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 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    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":"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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 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 = 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"]}
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.75",
6
+ "version": "0.4.76",
7
7
  "main": "index.js",
8
8
  "types": "index.d.ts",
9
9
  "scripts": {
package/type/entity.d.ts CHANGED
@@ -34,7 +34,7 @@ export declare type FieldOptions = {
34
34
  readonly onUpdate?: OnFieldCallback;
35
35
  readonly onDelete?: OnFieldCallback;
36
36
  };
37
- export declare type OnFieldCallback = (opts?: QueryRawFnOptions) => Scalar;
37
+ export declare type OnFieldCallback = (opts?: QueryRawFnOptions) => Scalar | QueryRaw;
38
38
  export declare type EntityGetter<E = any> = () => Type<E>;
39
39
  export declare type ReferenceOptions<E = any> = {
40
40
  entity: EntityGetter<E>;
package/type/entity.js CHANGED
@@ -2,4 +2,4 @@
2
2
  Object.defineProperty(exports, "__esModule", { value: true });
3
3
  exports.idKey = void 0;
4
4
  exports.idKey = Symbol('idKey');
5
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZW50aXR5LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vc3JjL3R5cGUvZW50aXR5LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7OztBQUdhLFFBQUEsS0FBSyxHQUFHLE1BQU0sQ0FBQyxPQUFPLENBQUMsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IFF1ZXJ5UmF3LCBRdWVyeVJhd0ZuT3B0aW9ucyB9IGZyb20gJy4vcXVlcnknO1xuaW1wb3J0IHsgU2NhbGFyLCBUeXBlIH0gZnJvbSAnLi91dGlsaXR5JztcblxuZXhwb3J0IGNvbnN0IGlkS2V5ID0gU3ltYm9sKCdpZEtleScpO1xuXG5leHBvcnQgdHlwZSBLZXk8RT4gPSB7XG4gIHJlYWRvbmx5IFtLIGluIGtleW9mIEVdPzogSyAmIHN0cmluZztcbn1ba2V5b2YgRSAmIHN0cmluZ107XG5cbmV4cG9ydCB0eXBlIEZpZWxkS2V5PEU+ID0ge1xuICByZWFkb25seSBbSyBpbiBLZXk8RT5dPzogRVtLXSBleHRlbmRzIFNjYWxhciA/IEsgOiBuZXZlcjtcbn1bS2V5PEU+XTtcblxuZXhwb3J0IHR5cGUgRmllbGRWYWx1ZTxFPiA9IEVbRmllbGRLZXk8RT5dO1xuXG5leHBvcnQgdHlwZSBJZEtleTxFPiA9IEUgZXh0ZW5kcyB7IFtpZEtleV0/OiBpbmZlciBLIH1cbiAgPyBLICYgRmllbGRLZXk8RT5cbiAgOiBFIGV4dGVuZHMgeyBfaWQ/OiB1bmtub3duIH1cbiAgPyAnX2lkJyAmIEZpZWxkS2V5PEU+XG4gIDogRSBleHRlbmRzIHsgaWQ/OiB1bmtub3duIH1cbiAgPyAnaWQnICYgRmllbGRLZXk8RT5cbiAgOiBGaWVsZEtleTxFPjtcblxuZXhwb3J0IHR5cGUgSWRWYWx1ZTxFPiA9IEVbSWRLZXk8RT5dO1xuXG5leHBvcnQgdHlwZSBSZWxhdGlvbktleTxFPiA9IHtcbiAgcmVhZG9ubHkgW0sgaW4gS2V5PEU+XT86IEVbS10gZXh0ZW5kcyBTY2FsYXIgPyBuZXZlciA6IEs7XG59W0tleTxFPl07XG5cbmV4cG9ydCB0eXBlIFJlbGF0aW9uVmFsdWU8RT4gPSBFW1JlbGF0aW9uS2V5PEU+XTtcblxuZXhwb3J0IHR5cGUgRW50aXR5T3B0aW9ucyA9IHtcbiAgcmVhZG9ubHkgbmFtZT86IHN0cmluZztcbiAgcmVhZG9ubHkgc29mdERlbGV0ZT86IGJvb2xlYW47XG59O1xuXG5leHBvcnQgdHlwZSBGaWVsZE9wdGlvbnMgPSB7XG4gIHJlYWRvbmx5IG5hbWU/OiBzdHJpbmc7XG4gIHJlYWRvbmx5IGlzSWQ/OiB0cnVlO1xuICByZWFkb25seSB0eXBlPzogYW55O1xuICByZWFkb25seSByZWZlcmVuY2U/OiBFbnRpdHlHZXR0ZXIgfCBSZWZlcmVuY2VPcHRpb25zO1xuICByZWFkb25seSB2aXJ0dWFsPzogUXVlcnlSYXc7XG4gIHJlYWRvbmx5IG9uSW5zZXJ0PzogT25GaWVsZENhbGxiYWNrO1xuICByZWFkb25seSBvblVwZGF0ZT86IE9uRmllbGRDYWxsYmFjaztcbiAgcmVhZG9ubHkgb25EZWxldGU/OiBPbkZpZWxkQ2FsbGJhY2s7XG59O1xuXG5leHBvcnQgdHlwZSBPbkZpZWxkQ2FsbGJhY2sgPSAob3B0cz86IFF1ZXJ5UmF3Rm5PcHRpb25zKSA9PiBTY2FsYXI7XG5cbmV4cG9ydCB0eXBlIEVudGl0eUdldHRlcjxFID0gYW55PiA9ICgpID0+IFR5cGU8RT47XG5cbmV4cG9ydCB0eXBlIFJlZmVyZW5jZU9wdGlvbnM8RSA9IGFueT4gPSB7IGVudGl0eTogRW50aXR5R2V0dGVyPEU+IH07XG5cbmV4cG9ydCB0eXBlIENhc2NhZGVUeXBlID0gJ3BlcnNpc3QnIHwgJ2RlbGV0ZSc7XG5cbmV4cG9ydCB0eXBlIFJlbGF0aW9uT3B0aW9uczxFID0gYW55PiA9IHtcbiAgZW50aXR5PzogRW50aXR5R2V0dGVyPEU+O1xuICByZWFkb25seSBjYXJkaW5hbGl0eT86IFJlbGF0aW9uQ2FyZGluYWxpdHk7XG4gIHJlYWRvbmx5IGNhc2NhZGU/OiBib29sZWFuIHwgQ2FzY2FkZVR5cGU7XG4gIG1hcHBlZEJ5PzogUmVsYXRpb25NYXBwZWRCeTxFPjtcbiAgdGhyb3VnaD86IEVudGl0eUdldHRlcjxSZWxhdGlvblZhbHVlPEU+PjtcbiAgcmVmZXJlbmNlcz86IFJlbGF0aW9uUmVmZXJlbmNlcztcbn07XG5cbnR5cGUgUmVsYXRpb25PcHRpb25zT3duZXI8RT4gPSBQaWNrPFJlbGF0aW9uT3B0aW9uczxFPiwgJ2VudGl0eScgfCAncmVmZXJlbmNlcycgfCAnY2FzY2FkZSc+O1xudHlwZSBSZWxhdGlvbk9wdGlvbnNJbnZlcnNlU2lkZTxFPiA9IFBpY2s8UmVsYXRpb25PcHRpb25zPEU+LCAnZW50aXR5JyB8ICdtYXBwZWRCeScgfCAnY2FzY2FkZSc+O1xudHlwZSBSZWxhdGlvbk9wdGlvbnNUaHJvdWdoT3duZXI8RT4gPSBQaWNrPFJlbGF0aW9uT3B0aW9uczxFPiwgJ2VudGl0eScgfCAndGhyb3VnaCcgfCAncmVmZXJlbmNlcycgfCAnY2FzY2FkZSc+O1xuXG5leHBvcnQgdHlwZSBSZWxhdGlvbktleU1hcDxFPiA9IHsgcmVhZG9ubHkgW0sgaW4gUmVsYXRpb25LZXk8RT5dOiBLIH07XG5cbmV4cG9ydCB0eXBlIFJlbGF0aW9uS2V5TWFwcGVyPEU+ID0gKGtleU1hcDogUmVsYXRpb25LZXlNYXA8RT4pID0+IFJlbGF0aW9uS2V5PEU+O1xuXG5leHBvcnQgdHlwZSBSZWxhdGlvblJlZmVyZW5jZXMgPSB7IGxvY2FsOiBzdHJpbmc7IGZvcmVpZ246IHN0cmluZyB9W107XG5cbmV4cG9ydCB0eXBlIFJlbGF0aW9uTWFwcGVkQnk8RT4gPSBSZWxhdGlvbktleTxFPiB8IFJlbGF0aW9uS2V5TWFwcGVyPEU+O1xuXG5leHBvcnQgdHlwZSBSZWxhdGlvbkNhcmRpbmFsaXR5ID0gJzExJyB8ICdtMScgfCAnMW0nIHwgJ21tJztcblxuZXhwb3J0IHR5cGUgUmVsYXRpb25PbmVUb09uZU9wdGlvbnM8RT4gPSBSZWxhdGlvbk9wdGlvbnNPd25lcjxFPiB8IFJlbGF0aW9uT3B0aW9uc0ludmVyc2VTaWRlPEU+O1xuXG5leHBvcnQgdHlwZSBSZWxhdGlvbk9uZVRvTWFueU9wdGlvbnM8RT4gPSBSZWxhdGlvbk9wdGlvbnNPd25lcjxFPiB8IFJlbGF0aW9uT3B0aW9uc0ludmVyc2VTaWRlPEU+IHwgUmVsYXRpb25PcHRpb25zVGhyb3VnaE93bmVyPEU+O1xuXG5leHBvcnQgdHlwZSBSZWxhdGlvbk1hbnlUb09uZU9wdGlvbnM8RT4gPSBSZWxhdGlvbk9wdGlvbnNPd25lcjxFPiB8IFJlbGF0aW9uT3B0aW9uc0ludmVyc2VTaWRlPEU+O1xuXG5leHBvcnQgdHlwZSBSZWxhdGlvbk1hbnlUb01hbnlPcHRpb25zPEU+ID0gUmVsYXRpb25PcHRpb25zVGhyb3VnaE93bmVyPEU+IHwgUmVsYXRpb25PcHRpb25zSW52ZXJzZVNpZGU8RT47XG5cbmV4cG9ydCB0eXBlIEVudGl0eU1ldGE8RT4gPSB7XG4gIHJlYWRvbmx5IGVudGl0eTogVHlwZTxFPjtcbiAgbmFtZT86IHN0cmluZztcbiAgaWQ/OiBJZEtleTxFPjtcbiAgc29mdERlbGV0ZT86IEZpZWxkS2V5PEU+O1xuICBmaWVsZHM6IHtcbiAgICBbSyBpbiBGaWVsZEtleTxFPl0/OiBGaWVsZE9wdGlvbnM7XG4gIH07XG4gIHJlbGF0aW9uczoge1xuICAgIFtLIGluIFJlbGF0aW9uS2V5PEU+XT86IFJlbGF0aW9uT3B0aW9ucztcbiAgfTtcbiAgcHJvY2Vzc2VkPzogYm9vbGVhbjtcbn07XG4iXX0=
5
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZW50aXR5LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vc3JjL3R5cGUvZW50aXR5LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7OztBQUdhLFFBQUEsS0FBSyxHQUFHLE1BQU0sQ0FBQyxPQUFPLENBQUMsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IFF1ZXJ5UmF3LCBRdWVyeVJhd0ZuT3B0aW9ucyB9IGZyb20gJy4vcXVlcnknO1xuaW1wb3J0IHsgU2NhbGFyLCBUeXBlIH0gZnJvbSAnLi91dGlsaXR5JztcblxuZXhwb3J0IGNvbnN0IGlkS2V5ID0gU3ltYm9sKCdpZEtleScpO1xuXG5leHBvcnQgdHlwZSBLZXk8RT4gPSB7XG4gIHJlYWRvbmx5IFtLIGluIGtleW9mIEVdPzogSyAmIHN0cmluZztcbn1ba2V5b2YgRSAmIHN0cmluZ107XG5cbmV4cG9ydCB0eXBlIEZpZWxkS2V5PEU+ID0ge1xuICByZWFkb25seSBbSyBpbiBLZXk8RT5dPzogRVtLXSBleHRlbmRzIFNjYWxhciA/IEsgOiBuZXZlcjtcbn1bS2V5PEU+XTtcblxuZXhwb3J0IHR5cGUgRmllbGRWYWx1ZTxFPiA9IEVbRmllbGRLZXk8RT5dO1xuXG5leHBvcnQgdHlwZSBJZEtleTxFPiA9IEUgZXh0ZW5kcyB7IFtpZEtleV0/OiBpbmZlciBLIH1cbiAgPyBLICYgRmllbGRLZXk8RT5cbiAgOiBFIGV4dGVuZHMgeyBfaWQ/OiB1bmtub3duIH1cbiAgPyAnX2lkJyAmIEZpZWxkS2V5PEU+XG4gIDogRSBleHRlbmRzIHsgaWQ/OiB1bmtub3duIH1cbiAgPyAnaWQnICYgRmllbGRLZXk8RT5cbiAgOiBGaWVsZEtleTxFPjtcblxuZXhwb3J0IHR5cGUgSWRWYWx1ZTxFPiA9IEVbSWRLZXk8RT5dO1xuXG5leHBvcnQgdHlwZSBSZWxhdGlvbktleTxFPiA9IHtcbiAgcmVhZG9ubHkgW0sgaW4gS2V5PEU+XT86IEVbS10gZXh0ZW5kcyBTY2FsYXIgPyBuZXZlciA6IEs7XG59W0tleTxFPl07XG5cbmV4cG9ydCB0eXBlIFJlbGF0aW9uVmFsdWU8RT4gPSBFW1JlbGF0aW9uS2V5PEU+XTtcblxuZXhwb3J0IHR5cGUgRW50aXR5T3B0aW9ucyA9IHtcbiAgcmVhZG9ubHkgbmFtZT86IHN0cmluZztcbiAgcmVhZG9ubHkgc29mdERlbGV0ZT86IGJvb2xlYW47XG59O1xuXG5leHBvcnQgdHlwZSBGaWVsZE9wdGlvbnMgPSB7XG4gIHJlYWRvbmx5IG5hbWU/OiBzdHJpbmc7XG4gIHJlYWRvbmx5IGlzSWQ/OiB0cnVlO1xuICByZWFkb25seSB0eXBlPzogYW55O1xuICByZWFkb25seSByZWZlcmVuY2U/OiBFbnRpdHlHZXR0ZXIgfCBSZWZlcmVuY2VPcHRpb25zO1xuICByZWFkb25seSB2aXJ0dWFsPzogUXVlcnlSYXc7XG4gIHJlYWRvbmx5IG9uSW5zZXJ0PzogT25GaWVsZENhbGxiYWNrO1xuICByZWFkb25seSBvblVwZGF0ZT86IE9uRmllbGRDYWxsYmFjaztcbiAgcmVhZG9ubHkgb25EZWxldGU/OiBPbkZpZWxkQ2FsbGJhY2s7XG59O1xuXG5leHBvcnQgdHlwZSBPbkZpZWxkQ2FsbGJhY2sgPSAob3B0cz86IFF1ZXJ5UmF3Rm5PcHRpb25zKSA9PiBTY2FsYXIgfCBRdWVyeVJhdztcblxuZXhwb3J0IHR5cGUgRW50aXR5R2V0dGVyPEUgPSBhbnk+ID0gKCkgPT4gVHlwZTxFPjtcblxuZXhwb3J0IHR5cGUgUmVmZXJlbmNlT3B0aW9uczxFID0gYW55PiA9IHsgZW50aXR5OiBFbnRpdHlHZXR0ZXI8RT4gfTtcblxuZXhwb3J0IHR5cGUgQ2FzY2FkZVR5cGUgPSAncGVyc2lzdCcgfCAnZGVsZXRlJztcblxuZXhwb3J0IHR5cGUgUmVsYXRpb25PcHRpb25zPEUgPSBhbnk+ID0ge1xuICBlbnRpdHk/OiBFbnRpdHlHZXR0ZXI8RT47XG4gIHJlYWRvbmx5IGNhcmRpbmFsaXR5PzogUmVsYXRpb25DYXJkaW5hbGl0eTtcbiAgcmVhZG9ubHkgY2FzY2FkZT86IGJvb2xlYW4gfCBDYXNjYWRlVHlwZTtcbiAgbWFwcGVkQnk/OiBSZWxhdGlvbk1hcHBlZEJ5PEU+O1xuICB0aHJvdWdoPzogRW50aXR5R2V0dGVyPFJlbGF0aW9uVmFsdWU8RT4+O1xuICByZWZlcmVuY2VzPzogUmVsYXRpb25SZWZlcmVuY2VzO1xufTtcblxudHlwZSBSZWxhdGlvbk9wdGlvbnNPd25lcjxFPiA9IFBpY2s8UmVsYXRpb25PcHRpb25zPEU+LCAnZW50aXR5JyB8ICdyZWZlcmVuY2VzJyB8ICdjYXNjYWRlJz47XG50eXBlIFJlbGF0aW9uT3B0aW9uc0ludmVyc2VTaWRlPEU+ID0gUGljazxSZWxhdGlvbk9wdGlvbnM8RT4sICdlbnRpdHknIHwgJ21hcHBlZEJ5JyB8ICdjYXNjYWRlJz47XG50eXBlIFJlbGF0aW9uT3B0aW9uc1Rocm91Z2hPd25lcjxFPiA9IFBpY2s8UmVsYXRpb25PcHRpb25zPEU+LCAnZW50aXR5JyB8ICd0aHJvdWdoJyB8ICdyZWZlcmVuY2VzJyB8ICdjYXNjYWRlJz47XG5cbmV4cG9ydCB0eXBlIFJlbGF0aW9uS2V5TWFwPEU+ID0geyByZWFkb25seSBbSyBpbiBSZWxhdGlvbktleTxFPl06IEsgfTtcblxuZXhwb3J0IHR5cGUgUmVsYXRpb25LZXlNYXBwZXI8RT4gPSAoa2V5TWFwOiBSZWxhdGlvbktleU1hcDxFPikgPT4gUmVsYXRpb25LZXk8RT47XG5cbmV4cG9ydCB0eXBlIFJlbGF0aW9uUmVmZXJlbmNlcyA9IHsgbG9jYWw6IHN0cmluZzsgZm9yZWlnbjogc3RyaW5nIH1bXTtcblxuZXhwb3J0IHR5cGUgUmVsYXRpb25NYXBwZWRCeTxFPiA9IFJlbGF0aW9uS2V5PEU+IHwgUmVsYXRpb25LZXlNYXBwZXI8RT47XG5cbmV4cG9ydCB0eXBlIFJlbGF0aW9uQ2FyZGluYWxpdHkgPSAnMTEnIHwgJ20xJyB8ICcxbScgfCAnbW0nO1xuXG5leHBvcnQgdHlwZSBSZWxhdGlvbk9uZVRvT25lT3B0aW9uczxFPiA9IFJlbGF0aW9uT3B0aW9uc093bmVyPEU+IHwgUmVsYXRpb25PcHRpb25zSW52ZXJzZVNpZGU8RT47XG5cbmV4cG9ydCB0eXBlIFJlbGF0aW9uT25lVG9NYW55T3B0aW9uczxFPiA9IFJlbGF0aW9uT3B0aW9uc093bmVyPEU+IHwgUmVsYXRpb25PcHRpb25zSW52ZXJzZVNpZGU8RT4gfCBSZWxhdGlvbk9wdGlvbnNUaHJvdWdoT3duZXI8RT47XG5cbmV4cG9ydCB0eXBlIFJlbGF0aW9uTWFueVRvT25lT3B0aW9uczxFPiA9IFJlbGF0aW9uT3B0aW9uc093bmVyPEU+IHwgUmVsYXRpb25PcHRpb25zSW52ZXJzZVNpZGU8RT47XG5cbmV4cG9ydCB0eXBlIFJlbGF0aW9uTWFueVRvTWFueU9wdGlvbnM8RT4gPSBSZWxhdGlvbk9wdGlvbnNUaHJvdWdoT3duZXI8RT4gfCBSZWxhdGlvbk9wdGlvbnNJbnZlcnNlU2lkZTxFPjtcblxuZXhwb3J0IHR5cGUgRW50aXR5TWV0YTxFPiA9IHtcbiAgcmVhZG9ubHkgZW50aXR5OiBUeXBlPEU+O1xuICBuYW1lPzogc3RyaW5nO1xuICBpZD86IElkS2V5PEU+O1xuICBzb2Z0RGVsZXRlPzogRmllbGRLZXk8RT47XG4gIGZpZWxkczoge1xuICAgIFtLIGluIEZpZWxkS2V5PEU+XT86IEZpZWxkT3B0aW9ucztcbiAgfTtcbiAgcmVsYXRpb25zOiB7XG4gICAgW0sgaW4gUmVsYXRpb25LZXk8RT5dPzogUmVsYXRpb25PcHRpb25zO1xuICB9O1xuICBwcm9jZXNzZWQ/OiBib29sZWFuO1xufTtcbiJdfQ==
@@ -30,7 +30,7 @@ function getPersistables(meta, payload, callbackKey) {
30
30
  exports.getPersistables = getPersistables;
31
31
  function fillOnFields(meta, payload, callbackKey) {
32
32
  const payloads = Array.isArray(payload) ? payload : [payload];
33
- const keys = (0, util_1.getKeys)(meta.fields).filter((col) => meta.fields[col][callbackKey]);
33
+ const keys = (0, util_1.getKeys)(meta.fields).filter((key) => meta.fields[key][callbackKey]);
34
34
  return payloads.map((it) => {
35
35
  for (const key of keys) {
36
36
  if (it[key] === undefined) {
@@ -107,4 +107,4 @@ function getQueryFilterAsMap(meta, filter = {}) {
107
107
  return filter;
108
108
  }
109
109
  exports.getQueryFilterAsMap = getQueryFilterAsMap;
110
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dialect.util.js","sourceRoot":"","sources":["../../src/util/dialect.util.ts"],"names":[],"mappings":";;;AAcA,yCAA8C;AAI9C,SAAgB,WAAW,CAAC,IAAmF;;IAC7G,MAAM,EAAE,KAAK,EAAE,MAAM,GAAG,EAAE,EAAE,OAAO,EAAE,eAAe,EAAE,GAAG,IAAI,CAAC;IAC9D,MAAM,GAAG,GAAG,OAAO,KAAK,CAAC,KAAK,KAAK,UAAU,CAAC,CAAC,CAAC,KAAK,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,MAAM,GAAG,KAAK,CAAC,KAAK,CAAC;IACzF,MAAM,KAAK,GAAG,MAAA,IAAI,CAAC,KAAK,mCAAI,KAAK,CAAC,KAAK,CAAC;IACxC,IAAI,KAAK,EAAE;QACT,MAAM,SAAS,GAAG,eAAe,CAAC,CAAC,CAAC,MAAM,GAAG,KAAK,CAAC,CAAC,CAAC,KAAK,CAAC;QAC3D,MAAM,gBAAgB,GAAG,OAAO,CAAC,QAAQ,CAAC,SAAS,EAAE,IAAI,CAAC,CAAC;QAC3D,OAAO,GAAG,GAAG,IAAI,gBAAgB,EAAE,CAAC;KACrC;IACD,OAAO,GAAG,CAAC;AACb,CAAC;AAVD,kCAUC;AAED,SAAgB,cAAc,CAAI,IAAmB,EAAE,OAAU,EAAE,WAAwB;IACzF,OAAO,eAAe,CAAC,IAAI,EAAE,OAAO,EAAE,WAAW,CAAC,CAAC,CAAC,CAAC,CAAC;AACxD,CAAC;AAFD,wCAEC;AAED,SAAgB,eAAe,CAAI,IAAmB,EAAE,OAAgB,EAAE,WAAwB;IAChG,MAAM,QAAQ,GAAG,YAAY,CAAC,IAAI,EAAE,OAAO,EAAE,WAAW,CAAC,CAAC;IAC1D,MAAM,eAAe,GAAG,IAAA,cAAO,EAAC,QAAQ,CAAC,CAAC,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,GAAG,EAAE,EAAE,CAAC,IAAI,CAAC,MAAM,CAAC,GAAG,CAAC,CAAkB,CAAC;IAChG,OAAO,QAAQ,CAAC,GAAG,CAAC,CAAC,EAAE,EAAE,EAAE,CACzB,eAAe,CAAC,MAAM,CAAC,CAAC,GAAG,EAAE,GAAG,EAAE,EAAE;QAClC,GAAG,CAAC,GAAG,CAAC,GAAG,EAAE,CAAC,GAAG,CAAC,CAAC;QACnB,OAAO,GAAG,CAAC;IACb,CAAC,EAAE,EAAO,CAAC,CACZ,CAAC;AACJ,CAAC;AATD,0CASC;AAED,SAAS,YAAY,CAAI,IAAmB,EAAE,OAAgB,EAAE,WAAwB;IACtF,MAAM,QAAQ,GAAG,KAAK,CAAC,OAAO,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC,OAAO,CAAC,CAAC;IAC9D,MAAM,IAAI,GAAG,IAAA,cAAO,EAAC,IAAI,CAAC,MAAM,CAAC,CAAC,MAAM,CAAC,CAAC,GAAG,EAAE,EAAE,CAAC,IAAI,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC,WAAW,CAAC,CAAC,CAAC;IACjF,OAAO,QAAQ,CAAC,GAAG,CAAC,CAAC,EAAE,EAAE,EAAE;QACzB,KAAK,MAAM,GAAG,IAAI,IAAI,EAAE;YACtB,IAAI,EAAE,CAAC,GAAG,CAAC,KAAK,SAAS,EAAE;gBACzB,EAAE,CAAC,GAAG,CAAC,GAAG,IAAI,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC,WAAW,CAAC,EAAE,CAAC;aAC3C;SACF;QACD,OAAO,EAAE,CAAC;IACZ,CAAC,CAAC,CAAC;AACL,CAAC;AAED,SAAgB,uBAAuB,CAAI,IAAmB,EAAE,OAAU,EAAE,MAAmB;IAC7F,MAAM,IAAI,GAAG,IAAA,cAAO,EAAC,OAAO,CAAC,CAAC;IAC9B,OAAO,IAAI,CAAC,MAAM,CAAC,CAAC,GAAG,EAAE,EAAE;QACzB,MAAM,OAAO,GAAG,IAAI,CAAC,SAAS,CAAC,GAAqB,CAAC,CAAC;QACtD,OAAO,OAAO,IAAI,YAAY,CAAC,MAAM,EAAE,OAAO,CAAC,OAAO,CAAC,CAAC;IAC1D,CAAC,CAAqB,CAAC;AACzB,CAAC;AAND,0DAMC;AAED,SAAgB,YAAY,CAAC,MAAmB,EAAE,aAAqC;IACrF,IAAI,OAAO,aAAa,KAAK,SAAS,EAAE;QACtC,OAAO,aAAa,CAAC;KACtB;IACD,OAAO,aAAa,KAAK,MAAM,CAAC;AAClC,CAAC;AALD,oCAKC;AAED,SAAgB,sBAAsB,CAAI,IAAmB,EAAE,OAAwB;IACrF,MAAM,IAAI,GAAG,cAAc,CAAC,OAAO,CAAC,CAAC;IACrC,OAAO,IAAI,CAAC,MAAM,CAAC,CAAC,GAAG,EAAE,EAAE,CAAC,IAAI,CAAC,SAAS,CAAC,GAAqB,CAAC,CAAqB,CAAC;AACzF,CAAC;AAHD,wDAGC;AAED,SAAgB,qBAAqB,CAAI,IAAmB,EAAE,OAAwB;IACpF,MAAM,IAAI,GAAG,cAAc,CAAC,OAAO,CAAC,CAAC;IACrC,OAAO,IAAI,CAAC,IAAI,CAAC,CAAC,GAAG,EAAE,EAAE,CAAC,IAAI,CAAC,SAAS,CAAC,GAAqB,CAAC,CAAC,CAAC;AACnE,CAAC;AAHD,sDAGC;AAED,SAAS,cAAc,CAAI,OAAwB;IACjD,IAAI,KAAK,CAAC,OAAO,CAAC,OAAO,CAAC,EAAE;QAC1B,OAAO,OAAmB,CAAC;KAC5B;IACD,OAAO,IAAA,cAAO,EAAC,OAAO,CAAC,CAAC,MAAM,CAAC,CAAC,GAAG,EAAE,EAAE,CAAC,OAAO,CAAC,GAAG,CAAC,CAAa,CAAC;AACpE,CAAC;AAED,SAAgB,YAAY,CAAI,IAAkB;IAChD,IAAI,KAAK,CAAC,OAAO,CAAC,IAAI,CAAC,EAAE;QACvB,OAAO,IAAI,CAAC,MAAM,CAAC,CAAC,GAAG,EAAE,EAAE,EAAE,EAAE;YAC7B,IAAI,KAAK,CAAC,OAAO,CAAC,EAAE,CAAC,EAAE;gBACrB,GAAG,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,GAAG,EAAE,CAAC,CAAC,CAAC,CAAC;aACpB;iBAAM;gBACL,GAAG,CAAC,EAAE,CAAC,KAAK,CAAC,GAAG,EAAE,CAAC,IAAI,CAAC;aACzB;YACD,OAAO,GAAG,CAAC;QACb,CAAC,EAAE,EAAqB,CAAC,CAAC;KAC3B;IACD,OAAO,IAAuB,CAAC;AACjC,CAAC;AAZD,oCAYC;AAED,SAAgB,aAAa,CAAI,IAAmB,EAAE,SAAyB,EAAE,EAAE,SAAyB,EAAE;IAC5G,MAAM,gBAAgB,GAAG,mBAAmB,CAAC,IAAI,EAAE,MAAM,CAAC,CAAC;IAC3D,MAAM,gBAAgB,GAAG,mBAAmB,CAAC,IAAI,EAAE,MAAM,CAAC,CAAC;IAC3D,OAAO;QACL,GAAG,gBAAgB;QACnB,GAAG,gBAAgB;KACpB,CAAC;AACJ,CAAC;AAPD,sCAOC;AAED,SAAgB,mBAAmB,CAAI,IAAmB,EAAE,SAAyB,EAAE;IACrF,IAAI,MAAM,YAAY,UAAG,EAAE;QACzB,OAAO,EAAE,IAAI,EAAE,CAAC,MAAM,CAAC,EAAuB,CAAC;KAChD;IACD,IAAI,OAAO,MAAM,KAAK,QAAQ,IAAI,KAAK,CAAC,OAAO,CAAC,MAAM,CAAC,IAAI,OAAQ,MAAkB,CAAC,WAAW,KAAK,UAAU,EAAE;QAChH,OAAO;YACL,CAAC,IAAI,CAAC,EAAE,CAAC,EAAE,MAAM;SACG,CAAC;KACxB;IACD,OAAO,MAA2B,CAAC;AACrC,CAAC;AAVD,kDAUC","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"]}
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((key) => meta.fields[key][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"]}