@uql/core 0.4.68 → 0.4.74

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.
Files changed (53) hide show
  1. package/README.md +1 -1
  2. package/dialect/{baseSqlDialect.d.ts → abstractSqlDialect.d.ts} +1 -1
  3. package/dialect/abstractSqlDialect.js +367 -0
  4. package/dialect/index.d.ts +1 -1
  5. package/dialect/index.js +5 -5
  6. package/dialect/mysqlDialect.d.ts +2 -4
  7. package/dialect/mysqlDialect.js +3 -13
  8. package/dialect/postgresDialect.d.ts +2 -2
  9. package/dialect/postgresDialect.js +6 -6
  10. package/dialect/sqliteDialect.d.ts +4 -2
  11. package/dialect/sqliteDialect.js +12 -3
  12. package/entity/decorator/definition.js +21 -21
  13. package/entity/decorator/entity.js +2 -2
  14. package/entity/decorator/field.js +2 -2
  15. package/entity/decorator/id.js +2 -2
  16. package/entity/decorator/index.js +5 -5
  17. package/entity/decorator/relation.js +2 -2
  18. package/entity/index.js +2 -2
  19. package/index.js +2 -2
  20. package/options.js +3 -3
  21. package/package.json +6 -6
  22. package/querier/{baseQuerier.d.ts → abstractQuerier.d.ts} +4 -3
  23. package/querier/abstractQuerier.js +230 -0
  24. package/querier/abstractSqlQuerier.d.ts +27 -0
  25. package/querier/abstractSqlQuerier.js +88 -0
  26. package/querier/decorator/index.js +3 -3
  27. package/querier/decorator/transactional.js +4 -4
  28. package/querier/index.d.ts +2 -2
  29. package/querier/index.js +4 -4
  30. package/repository/{baseRepository.d.ts → genericRepository.d.ts} +1 -1
  31. package/repository/genericRepository.js +50 -0
  32. package/repository/index.d.ts +1 -1
  33. package/repository/index.js +2 -2
  34. package/type/entity.d.ts +14 -13
  35. package/type/entity.js +1 -7
  36. package/type/index.d.ts +1 -0
  37. package/type/index.js +9 -8
  38. package/type/options.d.ts +0 -4
  39. package/type/options.js +1 -1
  40. package/type/querier.d.ts +8 -91
  41. package/type/querier.js +1 -1
  42. package/type/querierPool.d.ts +2 -27
  43. package/type/querierPool.js +1 -1
  44. package/type/universalQuerier.d.ts +96 -0
  45. package/type/universalQuerier.js +3 -0
  46. package/util/dialect.util.js +5 -5
  47. package/util/index.js +6 -6
  48. package/util/sql.util.js +4 -4
  49. package/dialect/baseSqlDialect.js +0 -365
  50. package/querier/baseQuerier.js +0 -230
  51. package/querier/sqlQuerier.d.ts +0 -19
  52. package/querier/sqlQuerier.js +0 -91
  53. package/repository/baseRepository.js +0 -50
@@ -0,0 +1,230 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.AbstractQuerier = void 0;
4
+ const repository_1 = require("@uql/core/repository");
5
+ const util_1 = require("@uql/core/util");
6
+ const entity_1 = require("@uql/core/entity");
7
+ class AbstractQuerier {
8
+ findOneById(entity, id, qm = {}) {
9
+ return this.findOne(entity, { ...qm, $filter: id });
10
+ }
11
+ async findOne(entity, qm) {
12
+ const rows = await this.findMany(entity, { ...qm, $limit: 1 });
13
+ return rows[0];
14
+ }
15
+ findManyAndCount(entity, qm) {
16
+ return Promise.all([this.findMany(entity, qm), this.count(entity, qm)]);
17
+ }
18
+ async insertOne(entity, payload) {
19
+ const [id] = await this.insertMany(entity, [payload]);
20
+ return id;
21
+ }
22
+ updateOneById(entity, id, payload) {
23
+ return this.updateMany(entity, { $filter: id }, payload);
24
+ }
25
+ deleteOneById(entity, id, opts) {
26
+ return this.deleteMany(entity, { $filter: id }, opts);
27
+ }
28
+ async saveOne(entity, payload) {
29
+ const [id] = await this.saveMany(entity, [payload]);
30
+ return id;
31
+ }
32
+ async saveMany(entity, payload) {
33
+ const meta = (0, entity_1.getMeta)(entity);
34
+ const ids = [];
35
+ const updates = [];
36
+ const inserts = [];
37
+ for (const it of payload) {
38
+ if (it[meta.id]) {
39
+ if ((0, util_1.getKeys)(it).length === 1) {
40
+ ids.push(it[meta.id]);
41
+ }
42
+ else {
43
+ updates.push(it);
44
+ }
45
+ }
46
+ else {
47
+ inserts.push(it);
48
+ }
49
+ }
50
+ return Promise.all([
51
+ ...ids,
52
+ ...(inserts.length ? await this.insertMany(entity, inserts) : []),
53
+ ...updates.map(async (it) => {
54
+ const { [meta.id]: id, ...data } = it;
55
+ await this.updateOneById(entity, id, data);
56
+ return id;
57
+ }),
58
+ ]);
59
+ }
60
+ async findToManyRelations(entity, payload, project) {
61
+ const meta = (0, entity_1.getMeta)(entity);
62
+ const relations = (0, util_1.getProjectRelationKeys)(meta, project);
63
+ for (const relKey of relations) {
64
+ const relOpts = meta.relations[relKey];
65
+ const relEntity = relOpts.entity();
66
+ const relProject = (0, util_1.clone)(project[relKey]);
67
+ const relQuery = relProject === true || relProject === undefined ? {} : Array.isArray(relProject) ? { $project: relProject } : relProject;
68
+ const ids = payload.map((it) => it[meta.id]);
69
+ if (relOpts.through) {
70
+ const localField = relOpts.references[0].local;
71
+ const throughEntity = relOpts.through();
72
+ const throughMeta = (0, entity_1.getMeta)(throughEntity);
73
+ const targetRelKey = Object.keys(throughMeta.relations).find((key) => throughMeta.relations[key].references.some(({ local }) => local === relOpts.references[1].local));
74
+ const throughFounds = await this.findMany(throughEntity, {
75
+ $project: {
76
+ [localField]: true,
77
+ [targetRelKey]: {
78
+ ...relQuery,
79
+ $required: true,
80
+ },
81
+ },
82
+ $filter: {
83
+ [localField]: ids,
84
+ },
85
+ });
86
+ const founds = throughFounds.map((it) => ({ ...it[targetRelKey], [localField]: it[localField] }));
87
+ this.putChildrenInParents(payload, founds, meta.id, localField, relKey);
88
+ }
89
+ else if (relOpts.cardinality === '1m') {
90
+ const foreignField = relOpts.references[0].foreign;
91
+ if (relQuery.$project) {
92
+ if (Array.isArray(relQuery.$project)) {
93
+ if (!relQuery.$project.includes(foreignField)) {
94
+ relQuery.$project.push(foreignField);
95
+ }
96
+ }
97
+ else if (!relQuery.$project[foreignField]) {
98
+ relQuery.$project[foreignField] = true;
99
+ }
100
+ }
101
+ relQuery.$filter = { [foreignField]: ids };
102
+ const founds = await this.findMany(relEntity, relQuery);
103
+ this.putChildrenInParents(payload, founds, meta.id, foreignField, relKey);
104
+ }
105
+ }
106
+ }
107
+ putChildrenInParents(parents, children, parentIdKey, referenceKey, relKey) {
108
+ const childrenByParentMap = children.reduce((acc, child) => {
109
+ const parenId = child[referenceKey];
110
+ if (!acc[parenId]) {
111
+ acc[parenId] = [];
112
+ }
113
+ acc[parenId].push(child);
114
+ return acc;
115
+ }, {});
116
+ for (const parent of parents) {
117
+ const parentId = parent[parentIdKey];
118
+ parent[relKey] = childrenByParentMap[parentId];
119
+ }
120
+ }
121
+ async insertRelations(entity, payload) {
122
+ const meta = (0, entity_1.getMeta)(entity);
123
+ await Promise.all(payload.map((it) => {
124
+ const relKeys = (0, util_1.getPersistableRelations)(meta, it, 'persist');
125
+ if (!relKeys.length) {
126
+ return;
127
+ }
128
+ return Promise.all(relKeys.map((relKey) => this.saveRelation(entity, it, relKey)));
129
+ }));
130
+ }
131
+ async updateRelations(entity, criteria, payload) {
132
+ const meta = (0, entity_1.getMeta)(entity);
133
+ const relKeys = (0, util_1.getPersistableRelations)(meta, payload, 'persist');
134
+ if (!relKeys.length) {
135
+ return;
136
+ }
137
+ const founds = await this.findMany(entity, {
138
+ ...criteria,
139
+ $project: [meta.id],
140
+ });
141
+ const ids = founds.map((found) => found[meta.id]);
142
+ await Promise.all(ids.map((id) => Promise.all(relKeys.map((relKey) => this.saveRelation(entity, { ...payload, [meta.id]: id }, relKey, true)))));
143
+ }
144
+ async deleteRelations(entity, ids, opts) {
145
+ const meta = (0, entity_1.getMeta)(entity);
146
+ const relKeys = (0, util_1.getPersistableRelations)(meta, meta.relations, 'delete');
147
+ for (const relKey of relKeys) {
148
+ const relOpts = meta.relations[relKey];
149
+ const relEntity = relOpts.entity();
150
+ const localField = relOpts.references[0].local;
151
+ if (relOpts.through) {
152
+ const throughEntity = relOpts.through();
153
+ await this.deleteMany(throughEntity, { $filter: { [localField]: ids } }, opts);
154
+ return;
155
+ }
156
+ await this.deleteMany(relEntity, { [localField]: ids }, opts);
157
+ }
158
+ }
159
+ async saveRelation(entity, payload, relKey, isUpdate) {
160
+ const meta = (0, entity_1.getMeta)(entity);
161
+ const id = payload[meta.id];
162
+ const { entity: entityGetter, cardinality, references, through } = meta.relations[relKey];
163
+ const relEntity = entityGetter();
164
+ const relPayload = payload[relKey];
165
+ if (cardinality === '1m' || cardinality === 'mm') {
166
+ if (through) {
167
+ const localField = references[0].local;
168
+ const throughEntity = through();
169
+ if (isUpdate) {
170
+ await this.deleteMany(throughEntity, { $filter: { [localField]: id } });
171
+ }
172
+ if (relPayload) {
173
+ const savedIds = await this.saveMany(relEntity, relPayload);
174
+ const throughBodies = savedIds.map((relId) => ({
175
+ [references[0].local]: id,
176
+ [references[1].local]: relId,
177
+ }));
178
+ await this.insertMany(throughEntity, throughBodies);
179
+ }
180
+ return;
181
+ }
182
+ const foreignField = references[0].foreign;
183
+ if (isUpdate) {
184
+ await this.deleteMany(relEntity, { $filter: { [foreignField]: id } });
185
+ }
186
+ if (relPayload) {
187
+ for (const it of relPayload) {
188
+ it[foreignField] = id;
189
+ }
190
+ await this.saveMany(relEntity, relPayload);
191
+ }
192
+ return;
193
+ }
194
+ if (cardinality === '11') {
195
+ const foreignField = references[0].foreign;
196
+ if (relPayload === null) {
197
+ await this.deleteMany(relEntity, { $filter: { [foreignField]: id } });
198
+ return;
199
+ }
200
+ await this.saveOne(relEntity, { ...relPayload, [foreignField]: id });
201
+ return;
202
+ }
203
+ if (cardinality === 'm1' && relPayload) {
204
+ const localField = references[0].local;
205
+ const referenceId = await this.insertOne(relEntity, relPayload);
206
+ await this.updateOneById(entity, id, { [localField]: referenceId });
207
+ return;
208
+ }
209
+ }
210
+ getRepository(entity) {
211
+ return new repository_1.GenericRepository(entity, this);
212
+ }
213
+ async transaction(callback) {
214
+ try {
215
+ await this.beginTransaction();
216
+ const res = await callback(this);
217
+ await this.commitTransaction();
218
+ return res;
219
+ }
220
+ catch (err) {
221
+ await this.rollbackTransaction();
222
+ throw err;
223
+ }
224
+ finally {
225
+ await this.release();
226
+ }
227
+ }
228
+ }
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 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"]}
@@ -0,0 +1,27 @@
1
+ import { Query, Type, QueryCriteria, QueryOptions, QueryUpdateResult } from '@uql/core/type';
2
+ import { AbstractSqlDialect } from '@uql/core/dialect';
3
+ import { AbstractQuerier } from './abstractQuerier';
4
+ export declare abstract class AbstractSqlQuerier extends AbstractQuerier {
5
+ readonly dialect: AbstractSqlDialect;
6
+ private hasPendingTransaction?;
7
+ constructor(dialect: AbstractSqlDialect);
8
+ /**
9
+ * read query.
10
+ * @param query the query
11
+ */
12
+ abstract all<T>(query: string): Promise<T[]>;
13
+ /**
14
+ * insert/update/delete/ddl query.
15
+ * @param query the query
16
+ */
17
+ abstract run(query: string): Promise<QueryUpdateResult>;
18
+ count<E>(entity: Type<E>, qm?: QueryCriteria<E>): Promise<number>;
19
+ findMany<E>(entity: Type<E>, qm: Query<E>): Promise<E[]>;
20
+ insertMany<E>(entity: Type<E>, payload: E[]): Promise<E[import("@uql/core/type").IdKey<E>][]>;
21
+ updateMany<E>(entity: Type<E>, qm: QueryCriteria<E>, payload: E): Promise<number>;
22
+ deleteMany<E>(entity: Type<E>, qm: QueryCriteria<E>, opts?: QueryOptions): Promise<number>;
23
+ get hasOpenTransaction(): boolean;
24
+ beginTransaction(): Promise<void>;
25
+ commitTransaction(): Promise<void>;
26
+ rollbackTransaction(): Promise<void>;
27
+ }
@@ -0,0 +1,88 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.AbstractSqlQuerier = void 0;
4
+ const entity_1 = require("@uql/core/entity");
5
+ const util_1 = require("@uql/core/util");
6
+ const abstractQuerier_1 = require("./abstractQuerier");
7
+ class AbstractSqlQuerier extends abstractQuerier_1.AbstractQuerier {
8
+ constructor(dialect) {
9
+ super();
10
+ this.dialect = dialect;
11
+ }
12
+ async count(entity, qm) {
13
+ const query = await this.dialect.count(entity, qm);
14
+ const res = await this.all(query);
15
+ return Number(res[0].count);
16
+ }
17
+ async findMany(entity, qm) {
18
+ const query = this.dialect.find(entity, qm);
19
+ const res = await this.all(query);
20
+ const founds = (0, util_1.unflatObjects)(res);
21
+ await this.findToManyRelations(entity, founds, qm.$project);
22
+ return founds;
23
+ }
24
+ async insertMany(entity, payload) {
25
+ payload = (0, util_1.clone)(payload);
26
+ const query = this.dialect.insert(entity, payload);
27
+ const { firstId } = await this.run(query);
28
+ const meta = (0, entity_1.getMeta)(entity);
29
+ const ids = payload.map((it, index) => {
30
+ var _a;
31
+ var _b;
32
+ (_a = it[_b = meta.id]) !== null && _a !== void 0 ? _a : (it[_b] = firstId + index);
33
+ return it[meta.id];
34
+ });
35
+ await this.insertRelations(entity, payload);
36
+ return ids;
37
+ }
38
+ async updateMany(entity, qm, payload) {
39
+ payload = (0, util_1.clone)(payload);
40
+ const query = this.dialect.update(entity, qm, payload);
41
+ const { changes } = await this.run(query);
42
+ await this.updateRelations(entity, qm, payload);
43
+ return changes;
44
+ }
45
+ async deleteMany(entity, qm, opts) {
46
+ const meta = (0, entity_1.getMeta)(entity);
47
+ const findQuery = await this.dialect.find(entity, { ...qm, $project: [meta.id] });
48
+ const founds = await this.all(findQuery);
49
+ if (!founds.length) {
50
+ return 0;
51
+ }
52
+ const ids = founds.map((it) => it[meta.id]);
53
+ const query = this.dialect.delete(entity, { $filter: ids }, opts);
54
+ const { changes } = await this.run(query);
55
+ await this.deleteRelations(entity, ids, opts);
56
+ return changes;
57
+ }
58
+ get hasOpenTransaction() {
59
+ return this.hasPendingTransaction;
60
+ }
61
+ async beginTransaction( /*isolationLevel?: IsolationLevel*/) {
62
+ if (this.hasPendingTransaction) {
63
+ throw TypeError('pending transaction');
64
+ }
65
+ // TODO
66
+ // if (isolationLevel) {
67
+ // await this.run(`SET TRANSACTION ISOLATION LEVEL ${isolationLevel}`);
68
+ // }
69
+ await this.run(this.dialect.beginTransactionCommand);
70
+ this.hasPendingTransaction = true;
71
+ }
72
+ async commitTransaction() {
73
+ if (!this.hasPendingTransaction) {
74
+ throw TypeError('not a pending transaction');
75
+ }
76
+ await this.run('COMMIT');
77
+ this.hasPendingTransaction = undefined;
78
+ }
79
+ async rollbackTransaction() {
80
+ if (!this.hasPendingTransaction) {
81
+ throw TypeError('not a pending transaction');
82
+ }
83
+ await this.run('ROLLBACK');
84
+ this.hasPendingTransaction = undefined;
85
+ }
86
+ }
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 = 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"]}
@@ -1,6 +1,6 @@
1
1
  "use strict";
2
2
  Object.defineProperty(exports, "__esModule", { value: true });
3
3
  const tslib_1 = require("tslib");
4
- tslib_1.__exportStar(require("./injectQuerier"), exports);
5
- tslib_1.__exportStar(require("./transactional"), exports);
6
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi9zcmMvcXVlcmllci9kZWNvcmF0b3IvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7O0FBQUEsMERBQWdDO0FBQ2hDLDBEQUFnQyIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCAqIGZyb20gJy4vaW5qZWN0UXVlcmllcic7XG5leHBvcnQgKiBmcm9tICcuL3RyYW5zYWN0aW9uYWwnO1xuIl19
4
+ (0, tslib_1.__exportStar)(require("./injectQuerier"), exports);
5
+ (0, tslib_1.__exportStar)(require("./transactional"), exports);
6
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi9zcmMvcXVlcmllci9kZWNvcmF0b3IvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7O0FBQUEsK0RBQWdDO0FBQ2hDLCtEQUFnQyIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCAqIGZyb20gJy4vaW5qZWN0UXVlcmllcic7XG5leHBvcnQgKiBmcm9tICcuL3RyYW5zYWN0aW9uYWwnO1xuIl19
@@ -7,9 +7,9 @@ function Transactional({ propagation = 'required', querierPool, } = {}) {
7
7
  return (target, key, propDescriptor) => {
8
8
  const theClass = target.constructor;
9
9
  const originalMethod = propDescriptor.value;
10
- const injectedQuerierIndex = injectQuerier_1.getInjectedQuerierIndex(theClass, key);
10
+ const injectedQuerierIndex = (0, injectQuerier_1.getInjectedQuerierIndex)(theClass, key);
11
11
  if (injectedQuerierIndex === undefined) {
12
- throw new TypeError(`missing decorator @InjectQuerier() in '${target.constructor.name}.${key}'`);
12
+ throw TypeError(`missing decorator @InjectQuerier() in '${target.constructor.name}.${key}'`);
13
13
  }
14
14
  propDescriptor.value = async function func(...args) {
15
15
  const params = [...args];
@@ -20,7 +20,7 @@ function Transactional({ propagation = 'required', querierPool, } = {}) {
20
20
  }
21
21
  else {
22
22
  isOwnTransaction = true;
23
- const pool = querierPool !== null && querierPool !== void 0 ? querierPool : options_1.getQuerierPool();
23
+ const pool = querierPool !== null && querierPool !== void 0 ? querierPool : (0, options_1.getQuerierPool)();
24
24
  querier = await pool.getQuerier();
25
25
  params[injectedQuerierIndex] = querier;
26
26
  }
@@ -49,4 +49,4 @@ function Transactional({ propagation = 'required', querierPool, } = {}) {
49
49
  };
50
50
  }
51
51
  exports.Transactional = Transactional;
52
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidHJhbnNhY3Rpb25hbC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9xdWVyaWVyL2RlY29yYXRvci90cmFuc2FjdGlvbmFsLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7OztBQUFBLCtDQUFtRDtBQUVuRCxtREFBMEQ7QUFFMUQsU0FBZ0IsYUFBYSxDQUFDLEVBQzVCLFdBQVcsR0FBRyxVQUFVLEVBQ3hCLFdBQVcsTUFJVCxFQUFFO0lBQ0osT0FBTyxDQUFDLE1BQWMsRUFBRSxHQUFXLEVBQUUsY0FBa0MsRUFBUSxFQUFFO1FBQy9FLE1BQU0sUUFBUSxHQUFHLE1BQU0sQ0FBQyxXQUF3QixDQUFDO1FBQ2pELE1BQU0sY0FBYyxHQUFHLGNBQWMsQ0FBQyxLQUFLLENBQUM7UUFDNUMsTUFBTSxvQkFBb0IsR0FBRyx1Q0FBdUIsQ0FBQyxRQUFRLEVBQUUsR0FBRyxDQUFDLENBQUM7UUFFcEUsSUFBSSxvQkFBb0IsS0FBSyxTQUFTLEVBQUU7WUFDdEMsTUFBTSxJQUFJLFNBQVMsQ0FBQywwQ0FBMEMsTUFBTSxDQUFDLFdBQVcsQ0FBQyxJQUFJLElBQUksR0FBRyxHQUFHLENBQUMsQ0FBQztTQUNsRztRQUVELGNBQWMsQ0FBQyxLQUFLLEdBQUcsS0FBSyxVQUFVLElBQUksQ0FBZSxHQUFHLElBQVc7WUFDckUsTUFBTSxNQUFNLEdBQUcsQ0FBQyxHQUFHLElBQUksQ0FBQyxDQUFDO1lBQ3pCLElBQUksZ0JBQXlCLENBQUM7WUFDOUIsSUFBSSxPQUFnQixDQUFDO1lBRXJCLElBQUksTUFBTSxDQUFDLG9CQUFvQixDQUFDLEVBQUU7Z0JBQ2hDLE9BQU8sR0FBRyxNQUFNLENBQUMsb0JBQW9CLENBQUMsQ0FBQzthQUN4QztpQkFBTTtnQkFDTCxnQkFBZ0IsR0FBRyxJQUFJLENBQUM7Z0JBQ3hCLE1BQU0sSUFBSSxHQUFHLFdBQVcsYUFBWCxXQUFXLGNBQVgsV0FBVyxHQUFJLHdCQUFjLEVBQUUsQ0FBQztnQkFDN0MsT0FBTyxHQUFHLE1BQU0sSUFBSSxDQUFDLFVBQVUsRUFBRSxDQUFDO2dCQUNsQyxNQUFNLENBQUMsb0JBQW9CLENBQUMsR0FBRyxPQUFPLENBQUM7YUFDeEM7WUFFRCxJQUFJO2dCQUNGLElBQUksV0FBVyxLQUFLLFVBQVUsSUFBSSxDQUFDLE9BQU8sQ0FBQyxrQkFBa0IsRUFBRTtvQkFDN0QsTUFBTSxPQUFPLENBQUMsZ0JBQWdCLEVBQUUsQ0FBQztpQkFDbEM7Z0JBQ0QsTUFBTSxJQUFJLEdBQUcsTUFBTSxjQUFjLENBQUMsS0FBSyxDQUFDLElBQUksRUFBRSxNQUFNLENBQUMsQ0FBQztnQkFDdEQsSUFBSSxnQkFBZ0IsSUFBSSxPQUFPLENBQUMsa0JBQWtCLEVBQUU7b0JBQ2xELE1BQU0sT0FBTyxDQUFDLGlCQUFpQixFQUFFLENBQUM7aUJBQ25DO2dCQUNELE9BQU8sSUFBSSxDQUFDO2FBQ2I7WUFBQyxPQUFPLEdBQUcsRUFBRTtnQkFDWixJQUFJLGdCQUFnQixJQUFJLE9BQU8sQ0FBQyxrQkFBa0IsRUFBRTtvQkFDbEQsTUFBTSxPQUFPLENBQUMsbUJBQW1CLEVBQUUsQ0FBQztpQkFDckM7Z0JBQ0QsTUFBTSxHQUFHLENBQUM7YUFDWDtvQkFBUztnQkFDUixJQUFJLGdCQUFnQixFQUFFO29CQUNwQixNQUFNLE9BQU8sQ0FBQyxPQUFPLEVBQUUsQ0FBQztpQkFDekI7YUFDRjtRQUNILENBQUMsQ0FBQztJQUNKLENBQUMsQ0FBQztBQUNKLENBQUM7QUFuREQsc0NBbURDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgZ2V0UXVlcmllclBvb2wgfSBmcm9tICdAdXFsL2NvcmUvb3B0aW9ucyc7XG5pbXBvcnQgeyBRdWVyaWVyLCBRdWVyaWVyUG9vbCwgVHlwZSB9IGZyb20gJ0B1cWwvY29yZS90eXBlJztcbmltcG9ydCB7IGdldEluamVjdGVkUXVlcmllckluZGV4IH0gZnJvbSAnLi9pbmplY3RRdWVyaWVyJztcblxuZXhwb3J0IGZ1bmN0aW9uIFRyYW5zYWN0aW9uYWwoe1xuICBwcm9wYWdhdGlvbiA9ICdyZXF1aXJlZCcsXG4gIHF1ZXJpZXJQb29sLFxufToge1xuICByZWFkb25seSBwcm9wYWdhdGlvbj86ICdzdXBwb3J0ZWQnIHwgJ3JlcXVpcmVkJztcbiAgcmVhZG9ubHkgcXVlcmllclBvb2w/OiBRdWVyaWVyUG9vbDtcbn0gPSB7fSkge1xuICByZXR1cm4gKHRhcmdldDogb2JqZWN0LCBrZXk6IHN0cmluZywgcHJvcERlc2NyaXB0b3I6IFByb3BlcnR5RGVzY3JpcHRvcik6IHZvaWQgPT4ge1xuICAgIGNvbnN0IHRoZUNsYXNzID0gdGFyZ2V0LmNvbnN0cnVjdG9yIGFzIFR5cGU8YW55PjtcbiAgICBjb25zdCBvcmlnaW5hbE1ldGhvZCA9IHByb3BEZXNjcmlwdG9yLnZhbHVlO1xuICAgIGNvbnN0IGluamVjdGVkUXVlcmllckluZGV4ID0gZ2V0SW5qZWN0ZWRRdWVyaWVySW5kZXgodGhlQ2xhc3MsIGtleSk7XG5cbiAgICBpZiAoaW5qZWN0ZWRRdWVyaWVySW5kZXggPT09IHVuZGVmaW5lZCkge1xuICAgICAgdGhyb3cgbmV3IFR5cGVFcnJvcihgbWlzc2luZyBkZWNvcmF0b3IgQEluamVjdFF1ZXJpZXIoKSBpbiAnJHt0YXJnZXQuY29uc3RydWN0b3IubmFtZX0uJHtrZXl9J2ApO1xuICAgIH1cblxuICAgIHByb3BEZXNjcmlwdG9yLnZhbHVlID0gYXN5bmMgZnVuY3Rpb24gZnVuYyh0aGlzOiBvYmplY3QsIC4uLmFyZ3M6IGFueVtdKSB7XG4gICAgICBjb25zdCBwYXJhbXMgPSBbLi4uYXJnc107XG4gICAgICBsZXQgaXNPd25UcmFuc2FjdGlvbjogYm9vbGVhbjtcbiAgICAgIGxldCBxdWVyaWVyOiBRdWVyaWVyO1xuXG4gICAgICBpZiAocGFyYW1zW2luamVjdGVkUXVlcmllckluZGV4XSkge1xuICAgICAgICBxdWVyaWVyID0gcGFyYW1zW2luamVjdGVkUXVlcmllckluZGV4XTtcbiAgICAgIH0gZWxzZSB7XG4gICAgICAgIGlzT3duVHJhbnNhY3Rpb24gPSB0cnVlO1xuICAgICAgICBjb25zdCBwb29sID0gcXVlcmllclBvb2wgPz8gZ2V0UXVlcmllclBvb2woKTtcbiAgICAgICAgcXVlcmllciA9IGF3YWl0IHBvb2wuZ2V0UXVlcmllcigpO1xuICAgICAgICBwYXJhbXNbaW5qZWN0ZWRRdWVyaWVySW5kZXhdID0gcXVlcmllcjtcbiAgICAgIH1cblxuICAgICAgdHJ5IHtcbiAgICAgICAgaWYgKHByb3BhZ2F0aW9uID09PSAncmVxdWlyZWQnICYmICFxdWVyaWVyLmhhc09wZW5UcmFuc2FjdGlvbikge1xuICAgICAgICAgIGF3YWl0IHF1ZXJpZXIuYmVnaW5UcmFuc2FjdGlvbigpO1xuICAgICAgICB9XG4gICAgICAgIGNvbnN0IHJlc3AgPSBhd2FpdCBvcmlnaW5hbE1ldGhvZC5hcHBseSh0aGlzLCBwYXJhbXMpO1xuICAgICAgICBpZiAoaXNPd25UcmFuc2FjdGlvbiAmJiBxdWVyaWVyLmhhc09wZW5UcmFuc2FjdGlvbikge1xuICAgICAgICAgIGF3YWl0IHF1ZXJpZXIuY29tbWl0VHJhbnNhY3Rpb24oKTtcbiAgICAgICAgfVxuICAgICAgICByZXR1cm4gcmVzcDtcbiAgICAgIH0gY2F0Y2ggKGVycikge1xuICAgICAgICBpZiAoaXNPd25UcmFuc2FjdGlvbiAmJiBxdWVyaWVyLmhhc09wZW5UcmFuc2FjdGlvbikge1xuICAgICAgICAgIGF3YWl0IHF1ZXJpZXIucm9sbGJhY2tUcmFuc2FjdGlvbigpO1xuICAgICAgICB9XG4gICAgICAgIHRocm93IGVycjtcbiAgICAgIH0gZmluYWxseSB7XG4gICAgICAgIGlmIChpc093blRyYW5zYWN0aW9uKSB7XG4gICAgICAgICAgYXdhaXQgcXVlcmllci5yZWxlYXNlKCk7XG4gICAgICAgIH1cbiAgICAgIH1cbiAgICB9O1xuICB9O1xufVxuIl19
52
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidHJhbnNhY3Rpb25hbC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9xdWVyaWVyL2RlY29yYXRvci90cmFuc2FjdGlvbmFsLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7OztBQUFBLCtDQUFtRDtBQUVuRCxtREFBMEQ7QUFFMUQsU0FBZ0IsYUFBYSxDQUFDLEVBQzVCLFdBQVcsR0FBRyxVQUFVLEVBQ3hCLFdBQVcsTUFJVCxFQUFFO0lBQ0osT0FBTyxDQUFDLE1BQWMsRUFBRSxHQUFXLEVBQUUsY0FBa0MsRUFBUSxFQUFFO1FBQy9FLE1BQU0sUUFBUSxHQUFHLE1BQU0sQ0FBQyxXQUF3QixDQUFDO1FBQ2pELE1BQU0sY0FBYyxHQUFHLGNBQWMsQ0FBQyxLQUFLLENBQUM7UUFDNUMsTUFBTSxvQkFBb0IsR0FBRyxJQUFBLHVDQUF1QixFQUFDLFFBQVEsRUFBRSxHQUFHLENBQUMsQ0FBQztRQUVwRSxJQUFJLG9CQUFvQixLQUFLLFNBQVMsRUFBRTtZQUN0QyxNQUFNLFNBQVMsQ0FBQywwQ0FBMEMsTUFBTSxDQUFDLFdBQVcsQ0FBQyxJQUFJLElBQUksR0FBRyxHQUFHLENBQUMsQ0FBQztTQUM5RjtRQUVELGNBQWMsQ0FBQyxLQUFLLEdBQUcsS0FBSyxVQUFVLElBQUksQ0FBZSxHQUFHLElBQVc7WUFDckUsTUFBTSxNQUFNLEdBQUcsQ0FBQyxHQUFHLElBQUksQ0FBQyxDQUFDO1lBQ3pCLElBQUksZ0JBQXlCLENBQUM7WUFDOUIsSUFBSSxPQUFnQixDQUFDO1lBRXJCLElBQUksTUFBTSxDQUFDLG9CQUFvQixDQUFDLEVBQUU7Z0JBQ2hDLE9BQU8sR0FBRyxNQUFNLENBQUMsb0JBQW9CLENBQUMsQ0FBQzthQUN4QztpQkFBTTtnQkFDTCxnQkFBZ0IsR0FBRyxJQUFJLENBQUM7Z0JBQ3hCLE1BQU0sSUFBSSxHQUFHLFdBQVcsYUFBWCxXQUFXLGNBQVgsV0FBVyxHQUFJLElBQUEsd0JBQWMsR0FBRSxDQUFDO2dCQUM3QyxPQUFPLEdBQUcsTUFBTSxJQUFJLENBQUMsVUFBVSxFQUFFLENBQUM7Z0JBQ2xDLE1BQU0sQ0FBQyxvQkFBb0IsQ0FBQyxHQUFHLE9BQU8sQ0FBQzthQUN4QztZQUVELElBQUk7Z0JBQ0YsSUFBSSxXQUFXLEtBQUssVUFBVSxJQUFJLENBQUMsT0FBTyxDQUFDLGtCQUFrQixFQUFFO29CQUM3RCxNQUFNLE9BQU8sQ0FBQyxnQkFBZ0IsRUFBRSxDQUFDO2lCQUNsQztnQkFDRCxNQUFNLElBQUksR0FBRyxNQUFNLGNBQWMsQ0FBQyxLQUFLLENBQUMsSUFBSSxFQUFFLE1BQU0sQ0FBQyxDQUFDO2dCQUN0RCxJQUFJLGdCQUFnQixJQUFJLE9BQU8sQ0FBQyxrQkFBa0IsRUFBRTtvQkFDbEQsTUFBTSxPQUFPLENBQUMsaUJBQWlCLEVBQUUsQ0FBQztpQkFDbkM7Z0JBQ0QsT0FBTyxJQUFJLENBQUM7YUFDYjtZQUFDLE9BQU8sR0FBRyxFQUFFO2dCQUNaLElBQUksZ0JBQWdCLElBQUksT0FBTyxDQUFDLGtCQUFrQixFQUFFO29CQUNsRCxNQUFNLE9BQU8sQ0FBQyxtQkFBbUIsRUFBRSxDQUFDO2lCQUNyQztnQkFDRCxNQUFNLEdBQUcsQ0FBQzthQUNYO29CQUFTO2dCQUNSLElBQUksZ0JBQWdCLEVBQUU7b0JBQ3BCLE1BQU0sT0FBTyxDQUFDLE9BQU8sRUFBRSxDQUFDO2lCQUN6QjthQUNGO1FBQ0gsQ0FBQyxDQUFDO0lBQ0osQ0FBQyxDQUFDO0FBQ0osQ0FBQztBQW5ERCxzQ0FtREMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBnZXRRdWVyaWVyUG9vbCB9IGZyb20gJ0B1cWwvY29yZS9vcHRpb25zJztcbmltcG9ydCB7IFF1ZXJpZXIsIFF1ZXJpZXJQb29sLCBUeXBlIH0gZnJvbSAnQHVxbC9jb3JlL3R5cGUnO1xuaW1wb3J0IHsgZ2V0SW5qZWN0ZWRRdWVyaWVySW5kZXggfSBmcm9tICcuL2luamVjdFF1ZXJpZXInO1xuXG5leHBvcnQgZnVuY3Rpb24gVHJhbnNhY3Rpb25hbCh7XG4gIHByb3BhZ2F0aW9uID0gJ3JlcXVpcmVkJyxcbiAgcXVlcmllclBvb2wsXG59OiB7XG4gIHJlYWRvbmx5IHByb3BhZ2F0aW9uPzogJ3N1cHBvcnRlZCcgfCAncmVxdWlyZWQnO1xuICByZWFkb25seSBxdWVyaWVyUG9vbD86IFF1ZXJpZXJQb29sO1xufSA9IHt9KSB7XG4gIHJldHVybiAodGFyZ2V0OiBvYmplY3QsIGtleTogc3RyaW5nLCBwcm9wRGVzY3JpcHRvcjogUHJvcGVydHlEZXNjcmlwdG9yKTogdm9pZCA9PiB7XG4gICAgY29uc3QgdGhlQ2xhc3MgPSB0YXJnZXQuY29uc3RydWN0b3IgYXMgVHlwZTxhbnk+O1xuICAgIGNvbnN0IG9yaWdpbmFsTWV0aG9kID0gcHJvcERlc2NyaXB0b3IudmFsdWU7XG4gICAgY29uc3QgaW5qZWN0ZWRRdWVyaWVySW5kZXggPSBnZXRJbmplY3RlZFF1ZXJpZXJJbmRleCh0aGVDbGFzcywga2V5KTtcblxuICAgIGlmIChpbmplY3RlZFF1ZXJpZXJJbmRleCA9PT0gdW5kZWZpbmVkKSB7XG4gICAgICB0aHJvdyBUeXBlRXJyb3IoYG1pc3NpbmcgZGVjb3JhdG9yIEBJbmplY3RRdWVyaWVyKCkgaW4gJyR7dGFyZ2V0LmNvbnN0cnVjdG9yLm5hbWV9LiR7a2V5fSdgKTtcbiAgICB9XG5cbiAgICBwcm9wRGVzY3JpcHRvci52YWx1ZSA9IGFzeW5jIGZ1bmN0aW9uIGZ1bmModGhpczogb2JqZWN0LCAuLi5hcmdzOiBhbnlbXSkge1xuICAgICAgY29uc3QgcGFyYW1zID0gWy4uLmFyZ3NdO1xuICAgICAgbGV0IGlzT3duVHJhbnNhY3Rpb246IGJvb2xlYW47XG4gICAgICBsZXQgcXVlcmllcjogUXVlcmllcjtcblxuICAgICAgaWYgKHBhcmFtc1tpbmplY3RlZFF1ZXJpZXJJbmRleF0pIHtcbiAgICAgICAgcXVlcmllciA9IHBhcmFtc1tpbmplY3RlZFF1ZXJpZXJJbmRleF07XG4gICAgICB9IGVsc2Uge1xuICAgICAgICBpc093blRyYW5zYWN0aW9uID0gdHJ1ZTtcbiAgICAgICAgY29uc3QgcG9vbCA9IHF1ZXJpZXJQb29sID8/IGdldFF1ZXJpZXJQb29sKCk7XG4gICAgICAgIHF1ZXJpZXIgPSBhd2FpdCBwb29sLmdldFF1ZXJpZXIoKTtcbiAgICAgICAgcGFyYW1zW2luamVjdGVkUXVlcmllckluZGV4XSA9IHF1ZXJpZXI7XG4gICAgICB9XG5cbiAgICAgIHRyeSB7XG4gICAgICAgIGlmIChwcm9wYWdhdGlvbiA9PT0gJ3JlcXVpcmVkJyAmJiAhcXVlcmllci5oYXNPcGVuVHJhbnNhY3Rpb24pIHtcbiAgICAgICAgICBhd2FpdCBxdWVyaWVyLmJlZ2luVHJhbnNhY3Rpb24oKTtcbiAgICAgICAgfVxuICAgICAgICBjb25zdCByZXNwID0gYXdhaXQgb3JpZ2luYWxNZXRob2QuYXBwbHkodGhpcywgcGFyYW1zKTtcbiAgICAgICAgaWYgKGlzT3duVHJhbnNhY3Rpb24gJiYgcXVlcmllci5oYXNPcGVuVHJhbnNhY3Rpb24pIHtcbiAgICAgICAgICBhd2FpdCBxdWVyaWVyLmNvbW1pdFRyYW5zYWN0aW9uKCk7XG4gICAgICAgIH1cbiAgICAgICAgcmV0dXJuIHJlc3A7XG4gICAgICB9IGNhdGNoIChlcnIpIHtcbiAgICAgICAgaWYgKGlzT3duVHJhbnNhY3Rpb24gJiYgcXVlcmllci5oYXNPcGVuVHJhbnNhY3Rpb24pIHtcbiAgICAgICAgICBhd2FpdCBxdWVyaWVyLnJvbGxiYWNrVHJhbnNhY3Rpb24oKTtcbiAgICAgICAgfVxuICAgICAgICB0aHJvdyBlcnI7XG4gICAgICB9IGZpbmFsbHkge1xuICAgICAgICBpZiAoaXNPd25UcmFuc2FjdGlvbikge1xuICAgICAgICAgIGF3YWl0IHF1ZXJpZXIucmVsZWFzZSgpO1xuICAgICAgICB9XG4gICAgICB9XG4gICAgfTtcbiAgfTtcbn1cbiJdfQ==
@@ -1,3 +1,3 @@
1
- export * from './baseQuerier';
2
- export * from './sqlQuerier';
1
+ export * from './abstractQuerier';
2
+ export * from './abstractSqlQuerier';
3
3
  export * from './decorator';
package/querier/index.js CHANGED
@@ -1,7 +1,7 @@
1
1
  "use strict";
2
2
  Object.defineProperty(exports, "__esModule", { value: true });
3
3
  const tslib_1 = require("tslib");
4
- tslib_1.__exportStar(require("./baseQuerier"), exports);
5
- tslib_1.__exportStar(require("./sqlQuerier"), exports);
6
- tslib_1.__exportStar(require("./decorator"), exports);
7
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9zcmMvcXVlcmllci9pbmRleC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7QUFBQSx3REFBOEI7QUFDOUIsdURBQTZCO0FBQzdCLHNEQUE0QiIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCAqIGZyb20gJy4vYmFzZVF1ZXJpZXInO1xuZXhwb3J0ICogZnJvbSAnLi9zcWxRdWVyaWVyJztcbmV4cG9ydCAqIGZyb20gJy4vZGVjb3JhdG9yJztcbiJdfQ==
4
+ (0, tslib_1.__exportStar)(require("./abstractQuerier"), exports);
5
+ (0, tslib_1.__exportStar)(require("./abstractSqlQuerier"), exports);
6
+ (0, tslib_1.__exportStar)(require("./decorator"), exports);
7
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9zcmMvcXVlcmllci9pbmRleC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7QUFBQSxpRUFBa0M7QUFDbEMsb0VBQXFDO0FBQ3JDLDJEQUE0QiIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCAqIGZyb20gJy4vYWJzdHJhY3RRdWVyaWVyJztcbmV4cG9ydCAqIGZyb20gJy4vYWJzdHJhY3RTcWxRdWVyaWVyJztcbmV4cG9ydCAqIGZyb20gJy4vZGVjb3JhdG9yJztcbiJdfQ==
@@ -1,5 +1,5 @@
1
1
  import { IdValue, Querier, Query, QueryCriteria, QueryOne, QueryOptions, QuerySearch, QueryUnique, Repository, Type } from '@uql/core/type';
2
- export declare class BaseRepository<E> implements Repository<E> {
2
+ export declare class GenericRepository<E> implements Repository<E> {
3
3
  readonly entity: Type<E>;
4
4
  readonly querier: Querier;
5
5
  constructor(entity: Type<E>, querier: Querier);
@@ -0,0 +1,50 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.GenericRepository = void 0;
4
+ class GenericRepository {
5
+ constructor(entity, querier) {
6
+ this.entity = entity;
7
+ this.querier = querier;
8
+ }
9
+ count(qm) {
10
+ return this.querier.count(this.entity, qm);
11
+ }
12
+ findOneById(id, qm) {
13
+ return this.querier.findOneById(this.entity, id, qm);
14
+ }
15
+ findOne(qm) {
16
+ return this.querier.findOne(this.entity, qm);
17
+ }
18
+ findMany(qm) {
19
+ return this.querier.findMany(this.entity, qm);
20
+ }
21
+ findManyAndCount(qm) {
22
+ return this.querier.findManyAndCount(this.entity, qm);
23
+ }
24
+ insertOne(payload) {
25
+ return this.querier.insertOne(this.entity, payload);
26
+ }
27
+ insertMany(payload) {
28
+ return this.querier.insertMany(this.entity, payload);
29
+ }
30
+ updateOneById(id, payload) {
31
+ return this.querier.updateOneById(this.entity, id, payload);
32
+ }
33
+ updateMany(qm, payload) {
34
+ return this.querier.updateMany(this.entity, qm, payload);
35
+ }
36
+ saveOne(payload) {
37
+ return this.querier.saveOne(this.entity, payload);
38
+ }
39
+ saveMany(payload) {
40
+ return this.querier.saveMany(this.entity, payload);
41
+ }
42
+ deleteOneById(id, opts) {
43
+ return this.querier.deleteOneById(this.entity, id, opts);
44
+ }
45
+ deleteMany(qm, opts) {
46
+ return this.querier.deleteMany(this.entity, qm, opts);
47
+ }
48
+ }
49
+ exports.GenericRepository = GenericRepository;
50
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZ2VuZXJpY1JlcG9zaXRvcnkuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9zcmMvcmVwb3NpdG9yeS9nZW5lcmljUmVwb3NpdG9yeS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7QUFFQSxNQUFhLGlCQUFpQjtJQUM1QixZQUFxQixNQUFlLEVBQVcsT0FBZ0I7UUFBMUMsV0FBTSxHQUFOLE1BQU0sQ0FBUztRQUFXLFlBQU8sR0FBUCxPQUFPLENBQVM7SUFBRyxDQUFDO0lBRW5FLEtBQUssQ0FBQyxFQUFrQjtRQUN0QixPQUFPLElBQUksQ0FBQyxPQUFPLENBQUMsS0FBSyxDQUFDLElBQUksQ0FBQyxNQUFNLEVBQUUsRUFBRSxDQUFDLENBQUM7SUFDN0MsQ0FBQztJQUVELFdBQVcsQ0FBQyxFQUFjLEVBQUUsRUFBbUI7UUFDN0MsT0FBTyxJQUFJLENBQUMsT0FBTyxDQUFDLFdBQVcsQ0FBQyxJQUFJLENBQUMsTUFBTSxFQUFFLEVBQUUsRUFBRSxFQUFFLENBQUMsQ0FBQztJQUN2RCxDQUFDO0lBRUQsT0FBTyxDQUFDLEVBQWU7UUFDckIsT0FBTyxJQUFJLENBQUMsT0FBTyxDQUFDLE9BQU8sQ0FBQyxJQUFJLENBQUMsTUFBTSxFQUFFLEVBQUUsQ0FBQyxDQUFDO0lBQy9DLENBQUM7SUFFRCxRQUFRLENBQUMsRUFBWTtRQUNuQixPQUFPLElBQUksQ0FBQyxPQUFPLENBQUMsUUFBUSxDQUFDLElBQUksQ0FBQyxNQUFNLEVBQUUsRUFBRSxDQUFDLENBQUM7SUFDaEQsQ0FBQztJQUVELGdCQUFnQixDQUFDLEVBQVk7UUFDM0IsT0FBTyxJQUFJLENBQUMsT0FBTyxDQUFDLGdCQUFnQixDQUFDLElBQUksQ0FBQyxNQUFNLEVBQUUsRUFBRSxDQUFDLENBQUM7SUFDeEQsQ0FBQztJQUVELFNBQVMsQ0FBQyxPQUFVO1FBQ2xCLE9BQU8sSUFBSSxDQUFDLE9BQU8sQ0FBQyxTQUFTLENBQUMsSUFBSSxDQUFDLE1BQU0sRUFBRSxPQUFPLENBQUMsQ0FBQztJQUN0RCxDQUFDO0lBRUQsVUFBVSxDQUFDLE9BQVk7UUFDckIsT0FBTyxJQUFJLENBQUMsT0FBTyxDQUFDLFVBQVUsQ0FBQyxJQUFJLENBQUMsTUFBTSxFQUFFLE9BQU8sQ0FBQyxDQUFDO0lBQ3ZELENBQUM7SUFFRCxhQUFhLENBQUMsRUFBYyxFQUFFLE9BQVU7UUFDdEMsT0FBTyxJQUFJLENBQUMsT0FBTyxDQUFDLGFBQWEsQ0FBQyxJQUFJLENBQUMsTUFBTSxFQUFFLEVBQUUsRUFBRSxPQUFPLENBQUMsQ0FBQztJQUM5RCxDQUFDO0lBRUQsVUFBVSxDQUFDLEVBQW9CLEVBQUUsT0FBVTtRQUN6QyxPQUFPLElBQUksQ0FBQyxPQUFPLENBQUMsVUFBVSxDQUFDLElBQUksQ0FBQyxNQUFNLEVBQUUsRUFBRSxFQUFFLE9BQU8sQ0FBQyxDQUFDO0lBQzNELENBQUM7SUFFRCxPQUFPLENBQUMsT0FBVTtRQUNoQixPQUFPLElBQUksQ0FBQyxPQUFPLENBQUMsT0FBTyxDQUFDLElBQUksQ0FBQyxNQUFNLEVBQUUsT0FBTyxDQUFDLENBQUM7SUFDcEQsQ0FBQztJQUVELFFBQVEsQ0FBQyxPQUFZO1FBQ25CLE9BQU8sSUFBSSxDQUFDLE9BQU8sQ0FBQyxRQUFRLENBQUMsSUFBSSxDQUFDLE1BQU0sRUFBRSxPQUFPLENBQUMsQ0FBQztJQUNyRCxDQUFDO0lBRUQsYUFBYSxDQUFDLEVBQWMsRUFBRSxJQUFtQjtRQUMvQyxPQUFPLElBQUksQ0FBQyxPQUFPLENBQUMsYUFBYSxDQUFDLElBQUksQ0FBQyxNQUFNLEVBQUUsRUFBRSxFQUFFLElBQUksQ0FBQyxDQUFDO0lBQzNELENBQUM7SUFFRCxVQUFVLENBQUMsRUFBb0IsRUFBRSxJQUFtQjtRQUNsRCxPQUFPLElBQUksQ0FBQyxPQUFPLENBQUMsVUFBVSxDQUFDLElBQUksQ0FBQyxNQUFNLEVBQUUsRUFBRSxFQUFFLElBQUksQ0FBQyxDQUFDO0lBQ3hELENBQUM7Q0FDRjtBQXRERCw4Q0FzREMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBJZFZhbHVlLCBRdWVyaWVyLCBRdWVyeSwgUXVlcnlDcml0ZXJpYSwgUXVlcnlPbmUsIFF1ZXJ5T3B0aW9ucywgUXVlcnlTZWFyY2gsIFF1ZXJ5VW5pcXVlLCBSZXBvc2l0b3J5LCBUeXBlIH0gZnJvbSAnQHVxbC9jb3JlL3R5cGUnO1xuXG5leHBvcnQgY2xhc3MgR2VuZXJpY1JlcG9zaXRvcnk8RT4gaW1wbGVtZW50cyBSZXBvc2l0b3J5PEU+IHtcbiAgY29uc3RydWN0b3IocmVhZG9ubHkgZW50aXR5OiBUeXBlPEU+LCByZWFkb25seSBxdWVyaWVyOiBRdWVyaWVyKSB7fVxuXG4gIGNvdW50KHFtOiBRdWVyeVNlYXJjaDxFPikge1xuICAgIHJldHVybiB0aGlzLnF1ZXJpZXIuY291bnQodGhpcy5lbnRpdHksIHFtKTtcbiAgfVxuXG4gIGZpbmRPbmVCeUlkKGlkOiBJZFZhbHVlPEU+LCBxbT86IFF1ZXJ5VW5pcXVlPEU+KSB7XG4gICAgcmV0dXJuIHRoaXMucXVlcmllci5maW5kT25lQnlJZCh0aGlzLmVudGl0eSwgaWQsIHFtKTtcbiAgfVxuXG4gIGZpbmRPbmUocW06IFF1ZXJ5T25lPEU+KSB7XG4gICAgcmV0dXJuIHRoaXMucXVlcmllci5maW5kT25lKHRoaXMuZW50aXR5LCBxbSk7XG4gIH1cblxuICBmaW5kTWFueShxbTogUXVlcnk8RT4pIHtcbiAgICByZXR1cm4gdGhpcy5xdWVyaWVyLmZpbmRNYW55KHRoaXMuZW50aXR5LCBxbSk7XG4gIH1cblxuICBmaW5kTWFueUFuZENvdW50KHFtOiBRdWVyeTxFPikge1xuICAgIHJldHVybiB0aGlzLnF1ZXJpZXIuZmluZE1hbnlBbmRDb3VudCh0aGlzLmVudGl0eSwgcW0pO1xuICB9XG5cbiAgaW5zZXJ0T25lKHBheWxvYWQ6IEUpIHtcbiAgICByZXR1cm4gdGhpcy5xdWVyaWVyLmluc2VydE9uZSh0aGlzLmVudGl0eSwgcGF5bG9hZCk7XG4gIH1cblxuICBpbnNlcnRNYW55KHBheWxvYWQ6IEVbXSkge1xuICAgIHJldHVybiB0aGlzLnF1ZXJpZXIuaW5zZXJ0TWFueSh0aGlzLmVudGl0eSwgcGF5bG9hZCk7XG4gIH1cblxuICB1cGRhdGVPbmVCeUlkKGlkOiBJZFZhbHVlPEU+LCBwYXlsb2FkOiBFKSB7XG4gICAgcmV0dXJuIHRoaXMucXVlcmllci51cGRhdGVPbmVCeUlkKHRoaXMuZW50aXR5LCBpZCwgcGF5bG9hZCk7XG4gIH1cblxuICB1cGRhdGVNYW55KHFtOiBRdWVyeUNyaXRlcmlhPEU+LCBwYXlsb2FkOiBFKSB7XG4gICAgcmV0dXJuIHRoaXMucXVlcmllci51cGRhdGVNYW55KHRoaXMuZW50aXR5LCBxbSwgcGF5bG9hZCk7XG4gIH1cblxuICBzYXZlT25lKHBheWxvYWQ6IEUpIHtcbiAgICByZXR1cm4gdGhpcy5xdWVyaWVyLnNhdmVPbmUodGhpcy5lbnRpdHksIHBheWxvYWQpO1xuICB9XG5cbiAgc2F2ZU1hbnkocGF5bG9hZDogRVtdKSB7XG4gICAgcmV0dXJuIHRoaXMucXVlcmllci5zYXZlTWFueSh0aGlzLmVudGl0eSwgcGF5bG9hZCk7XG4gIH1cblxuICBkZWxldGVPbmVCeUlkKGlkOiBJZFZhbHVlPEU+LCBvcHRzPzogUXVlcnlPcHRpb25zKSB7XG4gICAgcmV0dXJuIHRoaXMucXVlcmllci5kZWxldGVPbmVCeUlkKHRoaXMuZW50aXR5LCBpZCwgb3B0cyk7XG4gIH1cblxuICBkZWxldGVNYW55KHFtOiBRdWVyeUNyaXRlcmlhPEU+LCBvcHRzPzogUXVlcnlPcHRpb25zKSB7XG4gICAgcmV0dXJuIHRoaXMucXVlcmllci5kZWxldGVNYW55KHRoaXMuZW50aXR5LCBxbSwgb3B0cyk7XG4gIH1cbn1cbiJdfQ==
@@ -1 +1 @@
1
- export * from './baseRepository';
1
+ export * from './genericRepository';
@@ -1,5 +1,5 @@
1
1
  "use strict";
2
2
  Object.defineProperty(exports, "__esModule", { value: true });
3
3
  const tslib_1 = require("tslib");
4
- tslib_1.__exportStar(require("./baseRepository"), exports);
5
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9zcmMvcmVwb3NpdG9yeS9pbmRleC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7QUFBQSwyREFBaUMiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgKiBmcm9tICcuL2Jhc2VSZXBvc2l0b3J5JztcbiJdfQ==
4
+ (0, tslib_1.__exportStar)(require("./genericRepository"), exports);
5
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9zcmMvcmVwb3NpdG9yeS9pbmRleC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7QUFBQSxtRUFBb0MiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgKiBmcm9tICcuL2dlbmVyaWNSZXBvc2l0b3J5JztcbiJdfQ==
package/type/entity.d.ts CHANGED
@@ -1,22 +1,23 @@
1
1
  import { QueryRaw, QueryRawFnOptions } 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 idKey: unique symbol;
11
- export declare type IdValue<E> = E extends {
12
- [idKey]?: 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 = {
@@ -66,8 +67,8 @@ export declare type RelationManyToOneOptions<E> = RelationOptionsOwner<E> | Rela
66
67
  export declare type RelationManyToManyOptions<E> = RelationOptionsThroughOwner<E> | RelationOptionsInverseSide<E>;
67
68
  export declare type EntityMeta<E> = {
68
69
  readonly entity: Type<E>;
69
- name: string;
70
- id?: FieldKey<E>;
70
+ name?: string;
71
+ id?: IdKey<E>;
71
72
  softDelete?: FieldKey<E>;
72
73
  fields: {
73
74
  [K in FieldKey<E>]?: FieldOptions;