@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.
- package/README.md +1 -1
- package/dialect/{baseSqlDialect.d.ts → abstractSqlDialect.d.ts} +1 -1
- package/dialect/abstractSqlDialect.js +367 -0
- package/dialect/index.d.ts +1 -1
- package/dialect/index.js +5 -5
- package/dialect/mysqlDialect.d.ts +2 -4
- package/dialect/mysqlDialect.js +3 -13
- package/dialect/postgresDialect.d.ts +2 -2
- package/dialect/postgresDialect.js +6 -6
- package/dialect/sqliteDialect.d.ts +4 -2
- package/dialect/sqliteDialect.js +12 -3
- package/entity/decorator/definition.js +21 -21
- package/entity/decorator/entity.js +2 -2
- package/entity/decorator/field.js +2 -2
- package/entity/decorator/id.js +2 -2
- package/entity/decorator/index.js +5 -5
- package/entity/decorator/relation.js +2 -2
- package/entity/index.js +2 -2
- package/index.js +2 -2
- package/options.js +3 -3
- package/package.json +6 -6
- package/querier/{baseQuerier.d.ts → abstractQuerier.d.ts} +4 -3
- package/querier/abstractQuerier.js +230 -0
- package/querier/abstractSqlQuerier.d.ts +27 -0
- package/querier/abstractSqlQuerier.js +88 -0
- package/querier/decorator/index.js +3 -3
- package/querier/decorator/transactional.js +4 -4
- package/querier/index.d.ts +2 -2
- package/querier/index.js +4 -4
- package/repository/{baseRepository.d.ts → genericRepository.d.ts} +1 -1
- package/repository/genericRepository.js +50 -0
- package/repository/index.d.ts +1 -1
- package/repository/index.js +2 -2
- package/type/entity.d.ts +14 -13
- package/type/entity.js +1 -7
- package/type/index.d.ts +1 -0
- package/type/index.js +9 -8
- package/type/options.d.ts +0 -4
- package/type/options.js +1 -1
- package/type/querier.d.ts +8 -91
- package/type/querier.js +1 -1
- package/type/querierPool.d.ts +2 -27
- package/type/querierPool.js +1 -1
- package/type/universalQuerier.d.ts +96 -0
- package/type/universalQuerier.js +3 -0
- package/util/dialect.util.js +5 -5
- package/util/index.js +6 -6
- package/util/sql.util.js +4 -4
- package/dialect/baseSqlDialect.js +0 -365
- package/querier/baseQuerier.js +0 -230
- package/querier/sqlQuerier.d.ts +0 -19
- package/querier/sqlQuerier.js +0 -91
- package/repository/baseRepository.js +0 -50
package/type/entity.js
CHANGED
|
@@ -2,10 +2,4 @@
|
|
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
3
|
exports.idKey = void 0;
|
|
4
4
|
exports.idKey = Symbol('idKey');
|
|
5
|
-
|
|
6
|
-
// export interface NamingStrategy {
|
|
7
|
-
// tableName<T>(entity: Type<T>): string;
|
|
8
|
-
// columnName<T>(entity: Type<T>, fieldName: string): string;
|
|
9
|
-
// referenceColumnName<T>(sourceEntity: Type<T>, targetEntity: string, fieldName: string): string;
|
|
10
|
-
// }
|
|
11
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZW50aXR5LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vc3JjL3R5cGUvZW50aXR5LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7OztBQWFhLFFBQUEsS0FBSyxHQUFHLE1BQU0sQ0FBQyxPQUFPLENBQUMsQ0FBQztBQXFGckMsT0FBTztBQUNQLG9DQUFvQztBQUNwQywyQ0FBMkM7QUFDM0MsK0RBQStEO0FBQy9ELG9HQUFvRztBQUNwRyxJQUFJIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgUXVlcnlSYXcsIFF1ZXJ5UmF3Rm5PcHRpb25zIH0gZnJvbSAnLi9xdWVyeSc7XG5pbXBvcnQgeyBTY2FsYXIsIFR5cGUgfSBmcm9tICcuL3V0aWxpdHknO1xuXG5leHBvcnQgdHlwZSBLZXk8RT4gPSB7XG4gIHJlYWRvbmx5IFtLIGluIGtleW9mIEVdOiBLICYgc3RyaW5nO1xufVtrZXlvZiBFICYgc3RyaW5nXTtcblxuZXhwb3J0IHR5cGUgRmllbGRLZXk8RT4gPSB7XG4gIHJlYWRvbmx5IFtLIGluIEtleTxFPl06IEVbS10gZXh0ZW5kcyBTY2FsYXIgPyBLIDogbmV2ZXI7XG59W0tleTxFPl07XG5cbmV4cG9ydCB0eXBlIEZpZWxkVmFsdWU8RT4gPSBFW0ZpZWxkS2V5PEU+XTtcblxuZXhwb3J0IGNvbnN0IGlkS2V5ID0gU3ltYm9sKCdpZEtleScpO1xuXG5leHBvcnQgdHlwZSBJZFZhbHVlPEU+ID0gRSBleHRlbmRzIHsgW2lkS2V5XT86IGluZmVyIFUgfVxuICA/IFVcbiAgOiBFIGV4dGVuZHMgeyBpZD86IGluZmVyIFUgfVxuICA/IFVcbiAgOiBFIGV4dGVuZHMgeyBfaWQ/OiBpbmZlciBVIH1cbiAgPyBVICYgc3RyaW5nXG4gIDogRmllbGRWYWx1ZTxFPjtcblxuZXhwb3J0IHR5cGUgUmVsYXRpb25LZXk8RT4gPSB7XG4gIHJlYWRvbmx5IFtLIGluIEtleTxFPl06IEVbS10gZXh0ZW5kcyBTY2FsYXIgPyBuZXZlciA6IEs7XG59W0tleTxFPl07XG5cbmV4cG9ydCB0eXBlIFJlbGF0aW9uVmFsdWU8RT4gPSBFW1JlbGF0aW9uS2V5PEU+XTtcblxuZXhwb3J0IHR5cGUgRW50aXR5T3B0aW9ucyA9IHtcbiAgcmVhZG9ubHkgbmFtZT86IHN0cmluZztcbiAgcmVhZG9ubHkgc29mdERlbGV0ZT86IGJvb2xlYW47XG59O1xuXG5leHBvcnQgdHlwZSBGaWVsZE9wdGlvbnMgPSB7XG4gIHJlYWRvbmx5IG5hbWU/OiBzdHJpbmc7XG4gIHJlYWRvbmx5IGlzSWQ/OiB0cnVlO1xuICByZWFkb25seSB0eXBlPzogYW55O1xuICByZWFkb25seSByZWZlcmVuY2U/OiBFbnRpdHlHZXR0ZXIgfCBSZWZlcmVuY2VPcHRpb25zO1xuICByZWFkb25seSB2aXJ0dWFsPzogUXVlcnlSYXc7XG4gIHJlYWRvbmx5IG9uSW5zZXJ0PzogT25GaWVsZENhbGxiYWNrO1xuICByZWFkb25seSBvblVwZGF0ZT86IE9uRmllbGRDYWxsYmFjaztcbiAgcmVhZG9ubHkgb25EZWxldGU/OiBPbkZpZWxkQ2FsbGJhY2s7XG59O1xuXG5leHBvcnQgdHlwZSBPbkZpZWxkQ2FsbGJhY2sgPSAob3B0cz86IFF1ZXJ5UmF3Rm5PcHRpb25zKSA9PiBTY2FsYXI7XG5cbmV4cG9ydCB0eXBlIEVudGl0eUdldHRlcjxFID0gYW55PiA9ICgpID0+IFR5cGU8RT47XG5cbmV4cG9ydCB0eXBlIFJlZmVyZW5jZU9wdGlvbnM8RSA9IGFueT4gPSB7IGVudGl0eTogRW50aXR5R2V0dGVyPEU+IH07XG5cbmV4cG9ydCB0eXBlIENhc2NhZGVUeXBlID0gJ3BlcnNpc3QnIHwgJ2RlbGV0ZSc7XG5cbmV4cG9ydCB0eXBlIFJlbGF0aW9uT3B0aW9uczxFID0gYW55PiA9IHtcbiAgZW50aXR5PzogRW50aXR5R2V0dGVyPEU+O1xuICByZWFkb25seSBjYXJkaW5hbGl0eT86IFJlbGF0aW9uQ2FyZGluYWxpdHk7XG4gIHJlYWRvbmx5IGNhc2NhZGU/OiBib29sZWFuIHwgQ2FzY2FkZVR5cGU7XG4gIG1hcHBlZEJ5PzogUmVsYXRpb25NYXBwZWRCeTxFPjtcbiAgdGhyb3VnaD86IEVudGl0eUdldHRlcjxSZWxhdGlvblZhbHVlPEU+PjtcbiAgcmVmZXJlbmNlcz86IFJlbGF0aW9uUmVmZXJlbmNlcztcbn07XG5cbnR5cGUgUmVsYXRpb25PcHRpb25zT3duZXI8RT4gPSBQaWNrPFJlbGF0aW9uT3B0aW9uczxFPiwgJ2VudGl0eScgfCAncmVmZXJlbmNlcycgfCAnY2FzY2FkZSc+O1xudHlwZSBSZWxhdGlvbk9wdGlvbnNJbnZlcnNlU2lkZTxFPiA9IFBpY2s8UmVsYXRpb25PcHRpb25zPEU+LCAnZW50aXR5JyB8ICdtYXBwZWRCeScgfCAnY2FzY2FkZSc+O1xudHlwZSBSZWxhdGlvbk9wdGlvbnNUaHJvdWdoT3duZXI8RT4gPSBQaWNrPFJlbGF0aW9uT3B0aW9uczxFPiwgJ2VudGl0eScgfCAndGhyb3VnaCcgfCAncmVmZXJlbmNlcycgfCAnY2FzY2FkZSc+O1xuXG5leHBvcnQgdHlwZSBSZWxhdGlvbktleU1hcDxFPiA9IHsgcmVhZG9ubHkgW0sgaW4gUmVsYXRpb25LZXk8RT5dOiBLIH07XG5cbmV4cG9ydCB0eXBlIFJlbGF0aW9uS2V5TWFwcGVyPEU+ID0gKGtleU1hcDogUmVsYXRpb25LZXlNYXA8RT4pID0+IFJlbGF0aW9uS2V5PEU+O1xuXG5leHBvcnQgdHlwZSBSZWxhdGlvblJlZmVyZW5jZXMgPSB7IGxvY2FsOiBzdHJpbmc7IGZvcmVpZ246IHN0cmluZyB9W107XG5cbmV4cG9ydCB0eXBlIFJlbGF0aW9uTWFwcGVkQnk8RT4gPSBSZWxhdGlvbktleTxFPiB8IFJlbGF0aW9uS2V5TWFwcGVyPEU+O1xuXG5leHBvcnQgdHlwZSBSZWxhdGlvbkNhcmRpbmFsaXR5ID0gJzExJyB8ICdtMScgfCAnMW0nIHwgJ21tJztcblxuZXhwb3J0IHR5cGUgUmVsYXRpb25PbmVUb09uZU9wdGlvbnM8RT4gPSBSZWxhdGlvbk9wdGlvbnNPd25lcjxFPiB8IFJlbGF0aW9uT3B0aW9uc0ludmVyc2VTaWRlPEU+O1xuXG5leHBvcnQgdHlwZSBSZWxhdGlvbk9uZVRvTWFueU9wdGlvbnM8RT4gPSBSZWxhdGlvbk9wdGlvbnNPd25lcjxFPiB8IFJlbGF0aW9uT3B0aW9uc0ludmVyc2VTaWRlPEU+IHwgUmVsYXRpb25PcHRpb25zVGhyb3VnaE93bmVyPEU+O1xuXG5leHBvcnQgdHlwZSBSZWxhdGlvbk1hbnlUb09uZU9wdGlvbnM8RT4gPSBSZWxhdGlvbk9wdGlvbnNPd25lcjxFPiB8IFJlbGF0aW9uT3B0aW9uc0ludmVyc2VTaWRlPEU+O1xuXG5leHBvcnQgdHlwZSBSZWxhdGlvbk1hbnlUb01hbnlPcHRpb25zPEU+ID0gUmVsYXRpb25PcHRpb25zVGhyb3VnaE93bmVyPEU+IHwgUmVsYXRpb25PcHRpb25zSW52ZXJzZVNpZGU8RT47XG5cbmV4cG9ydCB0eXBlIEVudGl0eU1ldGE8RT4gPSB7XG4gIHJlYWRvbmx5IGVudGl0eTogVHlwZTxFPjtcbiAgbmFtZTogc3RyaW5nO1xuICBpZD86IEZpZWxkS2V5PEU+O1xuICBzb2Z0RGVsZXRlPzogRmllbGRLZXk8RT47XG4gIGZpZWxkczoge1xuICAgIFtLIGluIEZpZWxkS2V5PEU+XT86IEZpZWxkT3B0aW9ucztcbiAgfTtcbiAgcmVsYXRpb25zOiB7XG4gICAgW0sgaW4gUmVsYXRpb25LZXk8RT5dPzogUmVsYXRpb25PcHRpb25zO1xuICB9O1xuICBwcm9jZXNzZWQ/OiBib29sZWFuO1xufTtcblxuLy8gVE9ET1xuLy8gZXhwb3J0IGludGVyZmFjZSBOYW1pbmdTdHJhdGVneSB7XG4vLyAgIHRhYmxlTmFtZTxUPihlbnRpdHk6IFR5cGU8VD4pOiBzdHJpbmc7XG4vLyAgIGNvbHVtbk5hbWU8VD4oZW50aXR5OiBUeXBlPFQ+LCBmaWVsZE5hbWU6IHN0cmluZyk6IHN0cmluZztcbi8vICAgcmVmZXJlbmNlQ29sdW1uTmFtZTxUPihzb3VyY2VFbnRpdHk6IFR5cGU8VD4sIHRhcmdldEVudGl0eTogc3RyaW5nLCBmaWVsZE5hbWU6IHN0cmluZyk6IHN0cmluZztcbi8vIH1cbiJdfQ==
|
|
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=
|
package/type/index.d.ts
CHANGED
package/type/index.js
CHANGED
|
@@ -1,11 +1,12 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
3
|
const tslib_1 = require("tslib");
|
|
4
|
-
tslib_1.__exportStar(require("./utility"), exports);
|
|
5
|
-
tslib_1.__exportStar(require("./options"), exports);
|
|
6
|
-
tslib_1.__exportStar(require("./entity"), exports);
|
|
7
|
-
tslib_1.__exportStar(require("./query"), exports);
|
|
8
|
-
tslib_1.__exportStar(require("./
|
|
9
|
-
tslib_1.__exportStar(require("./
|
|
10
|
-
tslib_1.__exportStar(require("./
|
|
11
|
-
|
|
4
|
+
(0, tslib_1.__exportStar)(require("./utility"), exports);
|
|
5
|
+
(0, tslib_1.__exportStar)(require("./options"), exports);
|
|
6
|
+
(0, tslib_1.__exportStar)(require("./entity"), exports);
|
|
7
|
+
(0, tslib_1.__exportStar)(require("./query"), exports);
|
|
8
|
+
(0, tslib_1.__exportStar)(require("./universalQuerier"), exports);
|
|
9
|
+
(0, tslib_1.__exportStar)(require("./querier"), exports);
|
|
10
|
+
(0, tslib_1.__exportStar)(require("./querierPool"), exports);
|
|
11
|
+
(0, tslib_1.__exportStar)(require("./repository"), exports);
|
|
12
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9zcmMvdHlwZS9pbmRleC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7QUFBQSx5REFBMEI7QUFDMUIseURBQTBCO0FBQzFCLHdEQUF5QjtBQUN6Qix1REFBd0I7QUFDeEIsa0VBQW1DO0FBQ25DLHlEQUEwQjtBQUMxQiw2REFBOEI7QUFDOUIsNERBQTZCIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0ICogZnJvbSAnLi91dGlsaXR5JztcbmV4cG9ydCAqIGZyb20gJy4vb3B0aW9ucyc7XG5leHBvcnQgKiBmcm9tICcuL2VudGl0eSc7XG5leHBvcnQgKiBmcm9tICcuL3F1ZXJ5JztcbmV4cG9ydCAqIGZyb20gJy4vdW5pdmVyc2FsUXVlcmllcic7XG5leHBvcnQgKiBmcm9tICcuL3F1ZXJpZXInO1xuZXhwb3J0ICogZnJvbSAnLi9xdWVyaWVyUG9vbCc7XG5leHBvcnQgKiBmcm9tICcuL3JlcG9zaXRvcnknO1xuIl19
|
package/type/options.d.ts
CHANGED
|
@@ -1,8 +1,4 @@
|
|
|
1
1
|
import { QuerierPool } from './querierPool';
|
|
2
|
-
/**
|
|
3
|
-
* logger function to print debug messages.
|
|
4
|
-
*/
|
|
5
|
-
export declare type Logger = (message: any, ...args: any[]) => any;
|
|
6
2
|
export declare type UqlOptions<T extends QuerierPool = QuerierPool> = {
|
|
7
3
|
/**
|
|
8
4
|
* the default querier-pool instance.
|
package/type/options.js
CHANGED
|
@@ -1,3 +1,3 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
3
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoib3B0aW9ucy5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy90eXBlL29wdGlvbnMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IFF1ZXJpZXJQb29sIH0gZnJvbSAnLi9xdWVyaWVyUG9vbCc7XG5cbmV4cG9ydCB0eXBlIFVxbE9wdGlvbnM8VCBleHRlbmRzIFF1ZXJpZXJQb29sID0gUXVlcmllclBvb2w+ID0ge1xuICAvKipcbiAgICogdGhlIGRlZmF1bHQgcXVlcmllci1wb29sIGluc3RhbmNlLlxuICAgKi9cbiAgcXVlcmllclBvb2w6IFQ7XG59O1xuIl19
|
package/type/querier.d.ts
CHANGED
|
@@ -1,99 +1,16 @@
|
|
|
1
1
|
import { Type } from './utility';
|
|
2
2
|
import { Query, QueryCriteria, QueryOne, QueryOptions, QuerySearch, QueryUnique } from './query';
|
|
3
|
-
import { Repository
|
|
3
|
+
import { Repository } from './repository';
|
|
4
4
|
import { IdValue } from './entity';
|
|
5
|
+
import { UniversalQuerier } from './universalQuerier';
|
|
5
6
|
/**
|
|
6
|
-
*
|
|
7
|
+
* logger function to debug queries.
|
|
7
8
|
*/
|
|
8
|
-
export
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
*/
|
|
14
|
-
count<E>(entity: Type<E>, qm?: QuerySearch<E>): Promise<any>;
|
|
15
|
-
/**
|
|
16
|
-
* obtains the record with the given primary key.
|
|
17
|
-
* @param entity the target entity
|
|
18
|
-
* @param id the primary key value
|
|
19
|
-
* @param qm the criteria options
|
|
20
|
-
*/
|
|
21
|
-
findOneById<E>(entity: Type<E>, id: IdValue<E>, qm?: QueryUnique<E>): Promise<any>;
|
|
22
|
-
/**
|
|
23
|
-
* obtains the first record matching the given search parameters.
|
|
24
|
-
* @param entity the target entity
|
|
25
|
-
* @param qm the criteria options
|
|
26
|
-
*/
|
|
27
|
-
findOne<E>(entity: Type<E>, qm: QueryOne<E>): Promise<any>;
|
|
28
|
-
/**
|
|
29
|
-
* obtains the records matching the given search parameters.
|
|
30
|
-
* @param entity the target entity
|
|
31
|
-
* @param qm the criteria options
|
|
32
|
-
*/
|
|
33
|
-
findMany<E>(entity: Type<E>, qm: Query<E>): Promise<any>;
|
|
34
|
-
/**
|
|
35
|
-
* obtains the records matching the given search parameters,
|
|
36
|
-
* also counts the number of matches ignoring pagination.
|
|
37
|
-
* @param entity the target entity
|
|
38
|
-
* @param qm the criteria options
|
|
39
|
-
*/
|
|
40
|
-
findManyAndCount<E>(entity: Type<E>, qm: Query<E>): Promise<any>;
|
|
41
|
-
/**
|
|
42
|
-
* inserts a record.
|
|
43
|
-
* @param entity the entity to persist on
|
|
44
|
-
* @param payload the data to be persisted
|
|
45
|
-
*/
|
|
46
|
-
insertOne<E>(entity: Type<E>, payload: E): Promise<any>;
|
|
47
|
-
/**
|
|
48
|
-
* Inserts many records.
|
|
49
|
-
* @param entity the entity to persist on
|
|
50
|
-
* @param payload the data to be persisted
|
|
51
|
-
*/
|
|
52
|
-
insertMany?<E>(entity: Type<E>, payload: E[]): Promise<any>;
|
|
53
|
-
/**
|
|
54
|
-
* updates a record partially.
|
|
55
|
-
* @param entity the entity to persist on
|
|
56
|
-
* @param id the primary key of the record to be updated
|
|
57
|
-
* @param payload the data to be persisted
|
|
58
|
-
*/
|
|
59
|
-
updateOneById<E>(entity: Type<E>, id: IdValue<E>, payload: E): Promise<any>;
|
|
60
|
-
/**
|
|
61
|
-
* updates many records partially.
|
|
62
|
-
* @param entity the entity to persist on
|
|
63
|
-
* @param qm the criteria to look for the records
|
|
64
|
-
* @param payload the data to be persisted
|
|
65
|
-
*/
|
|
66
|
-
updateMany?<E>(entity: Type<E>, qm: QueryCriteria<E>, payload: E): Promise<any>;
|
|
67
|
-
/**
|
|
68
|
-
* insert or update a record.
|
|
69
|
-
* @param entity the entity to persist on
|
|
70
|
-
* @param payload the data to be persisted
|
|
71
|
-
*/
|
|
72
|
-
saveOne<E>(entity: Type<E>, payload: E): Promise<any>;
|
|
73
|
-
/**
|
|
74
|
-
* Insert or update records.
|
|
75
|
-
* @param entity the entity to persist on
|
|
76
|
-
* @param payload the data to be persisted
|
|
77
|
-
*/
|
|
78
|
-
saveMany?<E>(entity: Type<E>, payload: E[]): Promise<any>;
|
|
79
|
-
/**
|
|
80
|
-
* delete or SoftDelete a record.
|
|
81
|
-
* @param entity the entity to persist on
|
|
82
|
-
* @param id the primary key of the record
|
|
83
|
-
*/
|
|
84
|
-
deleteOneById<E>(entity: Type<E>, id: IdValue<E>, opts?: QueryOptions): Promise<any>;
|
|
85
|
-
/**
|
|
86
|
-
* delete or SoftDelete records.
|
|
87
|
-
* @param entity the entity to persist on
|
|
88
|
-
* @param qm the criteria to look for the records
|
|
89
|
-
*/
|
|
90
|
-
deleteMany<E>(entity: Type<E>, qm: QueryCriteria<E>, opts?: QueryOptions): Promise<any>;
|
|
91
|
-
/**
|
|
92
|
-
* get a repository for the given entity.
|
|
93
|
-
* @param entity the entity to get the repository for
|
|
94
|
-
*/
|
|
95
|
-
getRepository<E>(entity: Type<E>): UniversalRepository<E>;
|
|
96
|
-
}
|
|
9
|
+
export declare type QuerierLogger = (message: any, ...args: any[]) => any;
|
|
10
|
+
/**
|
|
11
|
+
* Isolation levels for transactions.
|
|
12
|
+
*/
|
|
13
|
+
export declare type IsolationLevel = 'read uncommitted' | 'read committed' | 'repeteable read' | 'serializable';
|
|
97
14
|
export interface Querier extends UniversalQuerier {
|
|
98
15
|
count<E>(entity: Type<E>, qm?: QuerySearch<E>): Promise<number>;
|
|
99
16
|
findOneById<E>(entity: Type<E>, id: IdValue<E>, qm?: QueryUnique<E>): Promise<E>;
|
package/type/querier.js
CHANGED
|
@@ -1,3 +1,3 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
3
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicXVlcmllci5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy90eXBlL3F1ZXJpZXIudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IFR5cGUgfSBmcm9tICcuL3V0aWxpdHknO1xuaW1wb3J0IHsgUXVlcnksIFF1ZXJ5Q3JpdGVyaWEsIFF1ZXJ5T25lLCBRdWVyeU9wdGlvbnMsIFF1ZXJ5U2VhcmNoLCBRdWVyeVVuaXF1ZSB9IGZyb20gJy4vcXVlcnknO1xuaW1wb3J0IHsgUmVwb3NpdG9yeSB9IGZyb20gJy4vcmVwb3NpdG9yeSc7XG5pbXBvcnQgeyBJZFZhbHVlIH0gZnJvbSAnLi9lbnRpdHknO1xuaW1wb3J0IHsgVW5pdmVyc2FsUXVlcmllciB9IGZyb20gJy4vdW5pdmVyc2FsUXVlcmllcic7XG5cbi8qKlxuICogbG9nZ2VyIGZ1bmN0aW9uIHRvIGRlYnVnIHF1ZXJpZXMuXG4gKi9cbmV4cG9ydCB0eXBlIFF1ZXJpZXJMb2dnZXIgPSAobWVzc2FnZTogYW55LCAuLi5hcmdzOiBhbnlbXSkgPT4gYW55O1xuXG4vKipcbiAqIElzb2xhdGlvbiBsZXZlbHMgZm9yIHRyYW5zYWN0aW9ucy5cbiAqL1xuZXhwb3J0IHR5cGUgSXNvbGF0aW9uTGV2ZWwgPSAncmVhZCB1bmNvbW1pdHRlZCcgfCAncmVhZCBjb21taXR0ZWQnIHwgJ3JlcGV0ZWFibGUgcmVhZCcgfCAnc2VyaWFsaXphYmxlJztcblxuZXhwb3J0IGludGVyZmFjZSBRdWVyaWVyIGV4dGVuZHMgVW5pdmVyc2FsUXVlcmllciB7XG4gIGNvdW50PEU+KGVudGl0eTogVHlwZTxFPiwgcW0/OiBRdWVyeVNlYXJjaDxFPik6IFByb21pc2U8bnVtYmVyPjtcblxuICBmaW5kT25lQnlJZDxFPihlbnRpdHk6IFR5cGU8RT4sIGlkOiBJZFZhbHVlPEU+LCBxbT86IFF1ZXJ5VW5pcXVlPEU+KTogUHJvbWlzZTxFPjtcblxuICBmaW5kT25lPEU+KGVudGl0eTogVHlwZTxFPiwgcW06IFF1ZXJ5T25lPEU+KTogUHJvbWlzZTxFPjtcblxuICBmaW5kTWFueTxFPihlbnRpdHk6IFR5cGU8RT4sIHFtOiBRdWVyeTxFPik6IFByb21pc2U8RVtdPjtcblxuICBmaW5kTWFueUFuZENvdW50PEU+KGVudGl0eTogVHlwZTxFPiwgcW06IFF1ZXJ5PEU+KTogUHJvbWlzZTxbRVtdLCBudW1iZXJdPjtcblxuICBpbnNlcnRPbmU8RT4oZW50aXR5OiBUeXBlPEU+LCBwYXlsb2FkOiBFKTogUHJvbWlzZTxJZFZhbHVlPEU+PjtcblxuICBpbnNlcnRNYW55PEU+KGVudGl0eTogVHlwZTxFPiwgcGF5bG9hZDogRVtdKTogUHJvbWlzZTxJZFZhbHVlPEU+W10+O1xuXG4gIHVwZGF0ZU9uZUJ5SWQ8RT4oZW50aXR5OiBUeXBlPEU+LCBpZDogSWRWYWx1ZTxFPiwgcGF5bG9hZDogRSk6IFByb21pc2U8bnVtYmVyPjtcblxuICB1cGRhdGVNYW55PEU+KGVudGl0eTogVHlwZTxFPiwgcW06IFF1ZXJ5Q3JpdGVyaWE8RT4sIHBheWxvYWQ6IEUpOiBQcm9taXNlPG51bWJlcj47XG5cbiAgc2F2ZU9uZTxFPihlbnRpdHk6IFR5cGU8RT4sIHBheWxvYWQ6IEUpOiBQcm9taXNlPElkVmFsdWU8RT4+O1xuXG4gIHNhdmVNYW55PEU+KGVudGl0eTogVHlwZTxFPiwgcGF5bG9hZDogRVtdKTogUHJvbWlzZTxJZFZhbHVlPEU+W10+O1xuXG4gIGRlbGV0ZU9uZUJ5SWQ8RT4oZW50aXR5OiBUeXBlPEU+LCBpZDogSWRWYWx1ZTxFPiwgb3B0cz86IFF1ZXJ5T3B0aW9ucyk6IFByb21pc2U8bnVtYmVyPjtcblxuICBkZWxldGVNYW55PEU+KGVudGl0eTogVHlwZTxFPiwgcW06IFF1ZXJ5Q3JpdGVyaWE8RT4sIG9wdHM/OiBRdWVyeU9wdGlvbnMpOiBQcm9taXNlPG51bWJlcj47XG5cbiAgZ2V0UmVwb3NpdG9yeTxFPihlbnRpdHk6IFR5cGU8RT4pOiBSZXBvc2l0b3J5PEU+O1xuXG4gIC8qKlxuICAgKiB3aGV0aGVyIHRoaXMgcXVlcmllciBpcyBpbiBhIHRyYW5zYWN0aW9uIG9yIG5vdC5cbiAgICovXG4gIHJlYWRvbmx5IGhhc09wZW5UcmFuc2FjdGlvbjogYm9vbGVhbjtcblxuICAvKipcbiAgICogcnVuIHRoZSBnaXZlbiBjYWxsYmFjayBpbnNpZGUgYSB0cmFuc2FjdGlvbiBpbiB0aGlzIHF1ZXJpZXIuXG4gICAqL1xuICB0cmFuc2FjdGlvbjxUPihjYWxsYmFjazogKHF1ZXJpZXI/OiBUaGlzVHlwZTxRdWVyaWVyPikgPT4gUHJvbWlzZTxUPik6IFByb21pc2U8VD47XG5cbiAgLyoqXG4gICAqIHN0YXJ0cyBhIG5ldyB0cmFuc2FjdGlvbiBpbiB0aGlzIHF1ZXJpZXIuXG4gICAqL1xuICBiZWdpblRyYW5zYWN0aW9uKCk6IFByb21pc2U8dm9pZD47XG5cbiAgLyoqXG4gICAqIGNvbW1pdHMgdGhlIGN1cnJlbnRseSBhY3RpdmUgdHJhbnNhY3Rpb24gaW4gdGhpcyBxdWVyaWVyLlxuICAgKi9cbiAgY29tbWl0VHJhbnNhY3Rpb24oKTogUHJvbWlzZTx2b2lkPjtcblxuICAvKipcbiAgICogYWJvcnRzIHRoZSBjdXJyZW50bHkgYWN0aXZlIHRyYW5zYWN0aW9uIGluIHRoaXMgcXVlcmllci5cbiAgICovXG4gIHJvbGxiYWNrVHJhbnNhY3Rpb24oKTogUHJvbWlzZTx2b2lkPjtcblxuICAvKipcbiAgICogcmVsZWFzZSB0aGUgcXVlcmllciB0byB0aGUgcG9vbC5cbiAgICovXG4gIHJlbGVhc2UoKTogUHJvbWlzZTx2b2lkPjtcbn1cbiJdfQ==
|
package/type/querierPool.d.ts
CHANGED
|
@@ -1,29 +1,4 @@
|
|
|
1
|
-
import {
|
|
2
|
-
import { Querier } from './querier';
|
|
3
|
-
import { QueryUpdateResult } from './query';
|
|
4
|
-
/**
|
|
5
|
-
* querier connection.
|
|
6
|
-
*/
|
|
7
|
-
export declare type QuerierPoolConnection = {
|
|
8
|
-
/**
|
|
9
|
-
* find query.
|
|
10
|
-
* @param query the query
|
|
11
|
-
*/
|
|
12
|
-
all<T>(query: string): Promise<T[]>;
|
|
13
|
-
/**
|
|
14
|
-
* insert/update/delete query.
|
|
15
|
-
* @param query the query
|
|
16
|
-
*/
|
|
17
|
-
run(query: string): Promise<QueryUpdateResult>;
|
|
18
|
-
/**
|
|
19
|
-
* release the connection to the pool.
|
|
20
|
-
*/
|
|
21
|
-
release(): Promise<void>;
|
|
22
|
-
/**
|
|
23
|
-
* end the connection.
|
|
24
|
-
*/
|
|
25
|
-
end(): Promise<void>;
|
|
26
|
-
};
|
|
1
|
+
import { Querier, QuerierLogger } from './querier';
|
|
27
2
|
/**
|
|
28
3
|
* querier pool.
|
|
29
4
|
*/
|
|
@@ -31,7 +6,7 @@ export declare type QuerierPool<Q extends Querier = Querier> = {
|
|
|
31
6
|
/**
|
|
32
7
|
* logger function to print debug messages.
|
|
33
8
|
*/
|
|
34
|
-
logger?:
|
|
9
|
+
logger?: QuerierLogger;
|
|
35
10
|
/**
|
|
36
11
|
* get a querier from the pool.
|
|
37
12
|
*/
|
package/type/querierPool.js
CHANGED
|
@@ -1,3 +1,3 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
3
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicXVlcmllclBvb2wuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9zcmMvdHlwZS9xdWVyaWVyUG9vbC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgUXVlcmllciwgUXVlcmllckxvZ2dlciB9IGZyb20gJy4vcXVlcmllcic7XG5cbi8qKlxuICogcXVlcmllciBwb29sLlxuICovXG5leHBvcnQgdHlwZSBRdWVyaWVyUG9vbDxRIGV4dGVuZHMgUXVlcmllciA9IFF1ZXJpZXI+ID0ge1xuICAvKipcbiAgICogbG9nZ2VyIGZ1bmN0aW9uIHRvIHByaW50IGRlYnVnIG1lc3NhZ2VzLlxuICAgKi9cbiAgbG9nZ2VyPzogUXVlcmllckxvZ2dlcjtcblxuICAvKipcbiAgICogZ2V0IGEgcXVlcmllciBmcm9tIHRoZSBwb29sLlxuICAgKi9cbiAgZ2V0UXVlcmllcjogKCkgPT4gUHJvbWlzZTxRPjtcblxuICAvKipcbiAgICogZW5kIHRoZSBwb29sLlxuICAgKi9cbiAgZW5kKCk6IFByb21pc2U8dm9pZD47XG59O1xuIl19
|
|
@@ -0,0 +1,96 @@
|
|
|
1
|
+
import { Type } from './utility';
|
|
2
|
+
import { Query, QueryCriteria, QueryOne, QueryOptions, QuerySearch, QueryUnique } from './query';
|
|
3
|
+
import { UniversalRepository } from './repository';
|
|
4
|
+
import { IdValue } from './entity';
|
|
5
|
+
/**
|
|
6
|
+
* A `querier` allows to interact with the datasource to perform persistence operations on any entity.
|
|
7
|
+
*/
|
|
8
|
+
export interface UniversalQuerier {
|
|
9
|
+
/**
|
|
10
|
+
* counts the number of records matching the given search parameters.
|
|
11
|
+
* @param entity the target entity
|
|
12
|
+
* @param qm the search options
|
|
13
|
+
*/
|
|
14
|
+
count<E>(entity: Type<E>, qm?: QuerySearch<E>): Promise<any>;
|
|
15
|
+
/**
|
|
16
|
+
* obtains the record with the given primary key.
|
|
17
|
+
* @param entity the target entity
|
|
18
|
+
* @param id the primary key value
|
|
19
|
+
* @param qm the criteria options
|
|
20
|
+
*/
|
|
21
|
+
findOneById<E>(entity: Type<E>, id: IdValue<E>, qm?: QueryUnique<E>): Promise<any>;
|
|
22
|
+
/**
|
|
23
|
+
* obtains the first record matching the given search parameters.
|
|
24
|
+
* @param entity the target entity
|
|
25
|
+
* @param qm the criteria options
|
|
26
|
+
*/
|
|
27
|
+
findOne<E>(entity: Type<E>, qm: QueryOne<E>): Promise<any>;
|
|
28
|
+
/**
|
|
29
|
+
* obtains the records matching the given search parameters.
|
|
30
|
+
* @param entity the target entity
|
|
31
|
+
* @param qm the criteria options
|
|
32
|
+
*/
|
|
33
|
+
findMany<E>(entity: Type<E>, qm: Query<E>): Promise<any>;
|
|
34
|
+
/**
|
|
35
|
+
* obtains the records matching the given search parameters,
|
|
36
|
+
* also counts the number of matches ignoring pagination.
|
|
37
|
+
* @param entity the target entity
|
|
38
|
+
* @param qm the criteria options
|
|
39
|
+
*/
|
|
40
|
+
findManyAndCount<E>(entity: Type<E>, qm: Query<E>): Promise<any>;
|
|
41
|
+
/**
|
|
42
|
+
* inserts a record.
|
|
43
|
+
* @param entity the entity to persist on
|
|
44
|
+
* @param payload the data to be persisted
|
|
45
|
+
*/
|
|
46
|
+
insertOne<E>(entity: Type<E>, payload: E): Promise<any>;
|
|
47
|
+
/**
|
|
48
|
+
* Inserts many records.
|
|
49
|
+
* @param entity the entity to persist on
|
|
50
|
+
* @param payload the data to be persisted
|
|
51
|
+
*/
|
|
52
|
+
insertMany?<E>(entity: Type<E>, payload: E[]): Promise<any>;
|
|
53
|
+
/**
|
|
54
|
+
* updates a record partially.
|
|
55
|
+
* @param entity the entity to persist on
|
|
56
|
+
* @param id the primary key of the record to be updated
|
|
57
|
+
* @param payload the data to be persisted
|
|
58
|
+
*/
|
|
59
|
+
updateOneById<E>(entity: Type<E>, id: IdValue<E>, payload: E): Promise<any>;
|
|
60
|
+
/**
|
|
61
|
+
* updates many records partially.
|
|
62
|
+
* @param entity the entity to persist on
|
|
63
|
+
* @param qm the criteria to look for the records
|
|
64
|
+
* @param payload the data to be persisted
|
|
65
|
+
*/
|
|
66
|
+
updateMany?<E>(entity: Type<E>, qm: QueryCriteria<E>, payload: E): Promise<any>;
|
|
67
|
+
/**
|
|
68
|
+
* insert or update a record.
|
|
69
|
+
* @param entity the entity to persist on
|
|
70
|
+
* @param payload the data to be persisted
|
|
71
|
+
*/
|
|
72
|
+
saveOne<E>(entity: Type<E>, payload: E): Promise<any>;
|
|
73
|
+
/**
|
|
74
|
+
* Insert or update records.
|
|
75
|
+
* @param entity the entity to persist on
|
|
76
|
+
* @param payload the data to be persisted
|
|
77
|
+
*/
|
|
78
|
+
saveMany?<E>(entity: Type<E>, payload: E[]): Promise<any>;
|
|
79
|
+
/**
|
|
80
|
+
* delete or SoftDelete a record.
|
|
81
|
+
* @param entity the entity to persist on
|
|
82
|
+
* @param id the primary key of the record
|
|
83
|
+
*/
|
|
84
|
+
deleteOneById<E>(entity: Type<E>, id: IdValue<E>, opts?: QueryOptions): Promise<any>;
|
|
85
|
+
/**
|
|
86
|
+
* delete or SoftDelete records.
|
|
87
|
+
* @param entity the entity to persist on
|
|
88
|
+
* @param qm the criteria to look for the records
|
|
89
|
+
*/
|
|
90
|
+
deleteMany<E>(entity: Type<E>, qm: QueryCriteria<E>, opts?: QueryOptions): Promise<any>;
|
|
91
|
+
/**
|
|
92
|
+
* get a repository for the given entity.
|
|
93
|
+
* @param entity the entity to get the repository for
|
|
94
|
+
*/
|
|
95
|
+
getRepository<E>(entity: Type<E>): UniversalRepository<E>;
|
|
96
|
+
}
|
|
@@ -0,0 +1,3 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidW5pdmVyc2FsUXVlcmllci5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy90eXBlL3VuaXZlcnNhbFF1ZXJpZXIudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IFR5cGUgfSBmcm9tICcuL3V0aWxpdHknO1xuaW1wb3J0IHsgUXVlcnksIFF1ZXJ5Q3JpdGVyaWEsIFF1ZXJ5T25lLCBRdWVyeU9wdGlvbnMsIFF1ZXJ5U2VhcmNoLCBRdWVyeVVuaXF1ZSB9IGZyb20gJy4vcXVlcnknO1xuaW1wb3J0IHsgVW5pdmVyc2FsUmVwb3NpdG9yeSB9IGZyb20gJy4vcmVwb3NpdG9yeSc7XG5pbXBvcnQgeyBJZFZhbHVlIH0gZnJvbSAnLi9lbnRpdHknO1xuXG4vKipcbiAqIEEgYHF1ZXJpZXJgIGFsbG93cyB0byBpbnRlcmFjdCB3aXRoIHRoZSBkYXRhc291cmNlIHRvIHBlcmZvcm0gcGVyc2lzdGVuY2Ugb3BlcmF0aW9ucyBvbiBhbnkgZW50aXR5LlxuICovXG5leHBvcnQgaW50ZXJmYWNlIFVuaXZlcnNhbFF1ZXJpZXIge1xuICAvKipcbiAgICogY291bnRzIHRoZSBudW1iZXIgb2YgcmVjb3JkcyBtYXRjaGluZyB0aGUgZ2l2ZW4gc2VhcmNoIHBhcmFtZXRlcnMuXG4gICAqIEBwYXJhbSBlbnRpdHkgdGhlIHRhcmdldCBlbnRpdHlcbiAgICogQHBhcmFtIHFtIHRoZSBzZWFyY2ggb3B0aW9uc1xuICAgKi9cbiAgY291bnQ8RT4oZW50aXR5OiBUeXBlPEU+LCBxbT86IFF1ZXJ5U2VhcmNoPEU+KTogUHJvbWlzZTxhbnk+O1xuXG4gIC8qKlxuICAgKiBvYnRhaW5zIHRoZSByZWNvcmQgd2l0aCB0aGUgZ2l2ZW4gcHJpbWFyeSBrZXkuXG4gICAqIEBwYXJhbSBlbnRpdHkgdGhlIHRhcmdldCBlbnRpdHlcbiAgICogQHBhcmFtIGlkIHRoZSBwcmltYXJ5IGtleSB2YWx1ZVxuICAgKiBAcGFyYW0gcW0gdGhlIGNyaXRlcmlhIG9wdGlvbnNcbiAgICovXG4gIGZpbmRPbmVCeUlkPEU+KGVudGl0eTogVHlwZTxFPiwgaWQ6IElkVmFsdWU8RT4sIHFtPzogUXVlcnlVbmlxdWU8RT4pOiBQcm9taXNlPGFueT47XG5cbiAgLyoqXG4gICAqIG9idGFpbnMgdGhlIGZpcnN0IHJlY29yZCBtYXRjaGluZyB0aGUgZ2l2ZW4gc2VhcmNoIHBhcmFtZXRlcnMuXG4gICAqIEBwYXJhbSBlbnRpdHkgdGhlIHRhcmdldCBlbnRpdHlcbiAgICogQHBhcmFtIHFtIHRoZSBjcml0ZXJpYSBvcHRpb25zXG4gICAqL1xuICBmaW5kT25lPEU+KGVudGl0eTogVHlwZTxFPiwgcW06IFF1ZXJ5T25lPEU+KTogUHJvbWlzZTxhbnk+O1xuXG4gIC8qKlxuICAgKiBvYnRhaW5zIHRoZSByZWNvcmRzIG1hdGNoaW5nIHRoZSBnaXZlbiBzZWFyY2ggcGFyYW1ldGVycy5cbiAgICogQHBhcmFtIGVudGl0eSB0aGUgdGFyZ2V0IGVudGl0eVxuICAgKiBAcGFyYW0gcW0gdGhlIGNyaXRlcmlhIG9wdGlvbnNcbiAgICovXG4gIGZpbmRNYW55PEU+KGVudGl0eTogVHlwZTxFPiwgcW06IFF1ZXJ5PEU+KTogUHJvbWlzZTxhbnk+O1xuXG4gIC8qKlxuICAgKiBvYnRhaW5zIHRoZSByZWNvcmRzIG1hdGNoaW5nIHRoZSBnaXZlbiBzZWFyY2ggcGFyYW1ldGVycyxcbiAgICogYWxzbyBjb3VudHMgdGhlIG51bWJlciBvZiBtYXRjaGVzIGlnbm9yaW5nIHBhZ2luYXRpb24uXG4gICAqIEBwYXJhbSBlbnRpdHkgdGhlIHRhcmdldCBlbnRpdHlcbiAgICogQHBhcmFtIHFtIHRoZSBjcml0ZXJpYSBvcHRpb25zXG4gICAqL1xuICBmaW5kTWFueUFuZENvdW50PEU+KGVudGl0eTogVHlwZTxFPiwgcW06IFF1ZXJ5PEU+KTogUHJvbWlzZTxhbnk+O1xuXG4gIC8qKlxuICAgKiBpbnNlcnRzIGEgcmVjb3JkLlxuICAgKiBAcGFyYW0gZW50aXR5IHRoZSBlbnRpdHkgdG8gcGVyc2lzdCBvblxuICAgKiBAcGFyYW0gcGF5bG9hZCB0aGUgZGF0YSB0byBiZSBwZXJzaXN0ZWRcbiAgICovXG4gIGluc2VydE9uZTxFPihlbnRpdHk6IFR5cGU8RT4sIHBheWxvYWQ6IEUpOiBQcm9taXNlPGFueT47XG5cbiAgLyoqXG4gICAqIEluc2VydHMgbWFueSByZWNvcmRzLlxuICAgKiBAcGFyYW0gZW50aXR5IHRoZSBlbnRpdHkgdG8gcGVyc2lzdCBvblxuICAgKiBAcGFyYW0gcGF5bG9hZCB0aGUgZGF0YSB0byBiZSBwZXJzaXN0ZWRcbiAgICovXG4gIGluc2VydE1hbnk/PEU+KGVudGl0eTogVHlwZTxFPiwgcGF5bG9hZDogRVtdKTogUHJvbWlzZTxhbnk+O1xuXG4gIC8qKlxuICAgKiB1cGRhdGVzIGEgcmVjb3JkIHBhcnRpYWxseS5cbiAgICogQHBhcmFtIGVudGl0eSB0aGUgZW50aXR5IHRvIHBlcnNpc3Qgb25cbiAgICogQHBhcmFtIGlkIHRoZSBwcmltYXJ5IGtleSBvZiB0aGUgcmVjb3JkIHRvIGJlIHVwZGF0ZWRcbiAgICogQHBhcmFtIHBheWxvYWQgdGhlIGRhdGEgdG8gYmUgcGVyc2lzdGVkXG4gICAqL1xuICB1cGRhdGVPbmVCeUlkPEU+KGVudGl0eTogVHlwZTxFPiwgaWQ6IElkVmFsdWU8RT4sIHBheWxvYWQ6IEUpOiBQcm9taXNlPGFueT47XG5cbiAgLyoqXG4gICAqIHVwZGF0ZXMgbWFueSByZWNvcmRzIHBhcnRpYWxseS5cbiAgICogQHBhcmFtIGVudGl0eSB0aGUgZW50aXR5IHRvIHBlcnNpc3Qgb25cbiAgICogQHBhcmFtIHFtIHRoZSBjcml0ZXJpYSB0byBsb29rIGZvciB0aGUgcmVjb3Jkc1xuICAgKiBAcGFyYW0gcGF5bG9hZCB0aGUgZGF0YSB0byBiZSBwZXJzaXN0ZWRcbiAgICovXG4gIHVwZGF0ZU1hbnk/PEU+KGVudGl0eTogVHlwZTxFPiwgcW06IFF1ZXJ5Q3JpdGVyaWE8RT4sIHBheWxvYWQ6IEUpOiBQcm9taXNlPGFueT47XG5cbiAgLyoqXG4gICAqIGluc2VydCBvciB1cGRhdGUgYSByZWNvcmQuXG4gICAqIEBwYXJhbSBlbnRpdHkgdGhlIGVudGl0eSB0byBwZXJzaXN0IG9uXG4gICAqIEBwYXJhbSBwYXlsb2FkIHRoZSBkYXRhIHRvIGJlIHBlcnNpc3RlZFxuICAgKi9cbiAgc2F2ZU9uZTxFPihlbnRpdHk6IFR5cGU8RT4sIHBheWxvYWQ6IEUpOiBQcm9taXNlPGFueT47XG5cbiAgLyoqXG4gICAqIEluc2VydCBvciB1cGRhdGUgcmVjb3Jkcy5cbiAgICogQHBhcmFtIGVudGl0eSB0aGUgZW50aXR5IHRvIHBlcnNpc3Qgb25cbiAgICogQHBhcmFtIHBheWxvYWQgdGhlIGRhdGEgdG8gYmUgcGVyc2lzdGVkXG4gICAqL1xuICBzYXZlTWFueT88RT4oZW50aXR5OiBUeXBlPEU+LCBwYXlsb2FkOiBFW10pOiBQcm9taXNlPGFueT47XG5cbiAgLyoqXG4gICAqIGRlbGV0ZSBvciBTb2Z0RGVsZXRlIGEgcmVjb3JkLlxuICAgKiBAcGFyYW0gZW50aXR5IHRoZSBlbnRpdHkgdG8gcGVyc2lzdCBvblxuICAgKiBAcGFyYW0gaWQgdGhlIHByaW1hcnkga2V5IG9mIHRoZSByZWNvcmRcbiAgICovXG4gIGRlbGV0ZU9uZUJ5SWQ8RT4oZW50aXR5OiBUeXBlPEU+LCBpZDogSWRWYWx1ZTxFPiwgb3B0cz86IFF1ZXJ5T3B0aW9ucyk6IFByb21pc2U8YW55PjtcblxuICAvKipcbiAgICogZGVsZXRlIG9yIFNvZnREZWxldGUgcmVjb3Jkcy5cbiAgICogQHBhcmFtIGVudGl0eSB0aGUgZW50aXR5IHRvIHBlcnNpc3Qgb25cbiAgICogQHBhcmFtIHFtIHRoZSBjcml0ZXJpYSB0byBsb29rIGZvciB0aGUgcmVjb3Jkc1xuICAgKi9cbiAgZGVsZXRlTWFueTxFPihlbnRpdHk6IFR5cGU8RT4sIHFtOiBRdWVyeUNyaXRlcmlhPEU+LCBvcHRzPzogUXVlcnlPcHRpb25zKTogUHJvbWlzZTxhbnk+O1xuXG4gIC8qKlxuICAgKiBnZXQgYSByZXBvc2l0b3J5IGZvciB0aGUgZ2l2ZW4gZW50aXR5LlxuICAgKiBAcGFyYW0gZW50aXR5IHRoZSBlbnRpdHkgdG8gZ2V0IHRoZSByZXBvc2l0b3J5IGZvclxuICAgKi9cbiAgZ2V0UmVwb3NpdG9yeTxFPihlbnRpdHk6IFR5cGU8RT4pOiBVbml2ZXJzYWxSZXBvc2l0b3J5PEU+O1xufVxuIl19
|
package/util/dialect.util.js
CHANGED
|
@@ -21,7 +21,7 @@ function getPersistable(meta, payload, callbackKey) {
|
|
|
21
21
|
exports.getPersistable = getPersistable;
|
|
22
22
|
function getPersistables(meta, payload, callbackKey) {
|
|
23
23
|
const payloads = fillOnFields(meta, payload, callbackKey);
|
|
24
|
-
const persistableKeys = util_1.getKeys(payloads[0]).filter((key) => meta.fields[key]);
|
|
24
|
+
const persistableKeys = (0, util_1.getKeys)(payloads[0]).filter((key) => meta.fields[key]);
|
|
25
25
|
return payloads.map((it) => persistableKeys.reduce((acc, key) => {
|
|
26
26
|
acc[key] = it[key];
|
|
27
27
|
return acc;
|
|
@@ -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 = util_1.getKeys(meta.fields).filter((col) => meta.fields[col][callbackKey]);
|
|
33
|
+
const keys = (0, util_1.getKeys)(meta.fields).filter((col) => meta.fields[col][callbackKey]);
|
|
34
34
|
return payloads.map((it) => {
|
|
35
35
|
for (const key of keys) {
|
|
36
36
|
if (it[key] === undefined) {
|
|
@@ -41,7 +41,7 @@ function fillOnFields(meta, payload, callbackKey) {
|
|
|
41
41
|
});
|
|
42
42
|
}
|
|
43
43
|
function getPersistableRelations(meta, payload, action) {
|
|
44
|
-
const keys = util_1.getKeys(payload);
|
|
44
|
+
const keys = (0, util_1.getKeys)(payload);
|
|
45
45
|
return keys.filter((key) => {
|
|
46
46
|
const relOpts = meta.relations[key];
|
|
47
47
|
return relOpts && isCascadable(action, relOpts.cascade);
|
|
@@ -69,7 +69,7 @@ function getProjectKeys(project) {
|
|
|
69
69
|
if (Array.isArray(project)) {
|
|
70
70
|
return project;
|
|
71
71
|
}
|
|
72
|
-
return util_1.getKeys(project).filter((key) => project[key]);
|
|
72
|
+
return (0, util_1.getKeys)(project).filter((key) => project[key]);
|
|
73
73
|
}
|
|
74
74
|
function buildSortMap(sort) {
|
|
75
75
|
if (Array.isArray(sort)) {
|
|
@@ -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":"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","sourcesContent":["import {\n  EntityMeta,\n  FieldKey,\n  QueryProject,\n  CascadeType,\n  RelationKey,\n  FieldOptions,\n  Key,\n  QuerySort,\n  QuerySortMap,\n  QueryRawFnOptions,\n  QueryFilter,\n  QueryFilterMap,\n} from '@uql/core/type';\nimport { getKeys, Raw } from '@uql/core/util';\n\ntype CallbackKey = keyof Pick<FieldOptions, 'onInsert' | 'onUpdate' | 'onDelete'>;\n\nexport function getRawValue(opts: QueryRawFnOptions & { value: Raw; alias?: string; autoPrefixAlias?: boolean }) {\n  const { value, prefix = '', dialect, autoPrefixAlias } = opts;\n  const val = typeof value.value === 'function' ? value.value(opts) : prefix + value.value;\n  const alias = opts.alias ?? value.alias;\n  if (alias) {\n    const fullAlias = autoPrefixAlias ? prefix + alias : alias;\n    const escapedFullAlias = dialect.escapeId(fullAlias, true);\n    return `${val} ${escapedFullAlias}`;\n  }\n  return val;\n}\n\nexport function getPersistable<E>(meta: EntityMeta<E>, payload: E, callbackKey: CallbackKey): E {\n  return getPersistables(meta, payload, callbackKey)[0];\n}\n\nexport function getPersistables<E>(meta: EntityMeta<E>, payload: E | E[], callbackKey: CallbackKey): E[] {\n  const payloads = fillOnFields(meta, payload, callbackKey);\n  const persistableKeys = getKeys(payloads[0]).filter((key) => meta.fields[key]) as FieldKey<E>[];\n  return payloads.map((it) =>\n    persistableKeys.reduce((acc, key) => {\n      acc[key] = it[key];\n      return acc;\n    }, {} as E)\n  );\n}\n\nfunction fillOnFields<E>(meta: EntityMeta<E>, payload: E | E[], callbackKey: CallbackKey): E[] {\n  const payloads = Array.isArray(payload) ? payload : [payload];\n  const keys = getKeys(meta.fields).filter((col) => meta.fields[col][callbackKey]);\n  return payloads.map((it) => {\n    for (const key of keys) {\n      if (it[key] === undefined) {\n        it[key] = meta.fields[key][callbackKey]();\n      }\n    }\n    return it;\n  });\n}\n\nexport function getPersistableRelations<E>(meta: EntityMeta<E>, payload: E, action: CascadeType): RelationKey<E>[] {\n  const keys = getKeys(payload);\n  return keys.filter((key) => {\n    const relOpts = meta.relations[key as RelationKey<E>];\n    return relOpts && isCascadable(action, relOpts.cascade);\n  }) as RelationKey<E>[];\n}\n\nexport function isCascadable(action: CascadeType, configuration?: boolean | CascadeType): boolean {\n  if (typeof configuration === 'boolean') {\n    return configuration;\n  }\n  return configuration === action;\n}\n\nexport function getProjectRelationKeys<E>(meta: EntityMeta<E>, project: QueryProject<E>): RelationKey<E>[] {\n  const keys = getProjectKeys(project);\n  return keys.filter((key) => meta.relations[key as RelationKey<E>]) as RelationKey<E>[];\n}\n\nexport function isProjectingRelations<E>(meta: EntityMeta<E>, project: QueryProject<E>): boolean {\n  const keys = getProjectKeys(project);\n  return keys.some((key) => meta.relations[key as RelationKey<E>]);\n}\n\nfunction getProjectKeys<E>(project: QueryProject<E>): Key<E>[] {\n  if (Array.isArray(project)) {\n    return project as Key<E>[];\n  }\n  return getKeys(project).filter((key) => project[key]) as Key<E>[];\n}\n\nexport function buildSortMap<E>(sort: QuerySort<E>): QuerySortMap<E> {\n  if (Array.isArray(sort)) {\n    return sort.reduce((acc, it) => {\n      if (Array.isArray(it)) {\n        acc[it[0]] = it[1];\n      } else {\n        acc[it.field] = it.sort;\n      }\n      return acc;\n    }, {} as QuerySortMap<E>);\n  }\n  return sort as QuerySortMap<E>;\n}\n\nexport function augmentFilter<E>(meta: EntityMeta<E>, target: QueryFilter<E> = {}, source: QueryFilter<E> = {}): QueryFilter<E> {\n  const targetComparison = getQueryFilterAsMap(meta, target);\n  const sourceComparison = getQueryFilterAsMap(meta, source);\n  return {\n    ...targetComparison,\n    ...sourceComparison,\n  };\n}\n\nexport function getQueryFilterAsMap<E>(meta: EntityMeta<E>, filter: QueryFilter<E> = {}): QueryFilterMap<E> {\n  if (filter instanceof Raw) {\n    return { $and: [filter] } as QueryFilterMap<E>;\n  }\n  if (typeof filter !== 'object' || Array.isArray(filter) || typeof (filter as MongoId).toHexString === 'function') {\n    return {\n      [meta.id]: filter,\n    } as QueryFilterMap<E>;\n  }\n  return filter as QueryFilterMap<E>;\n}\n\ntype MongoId = {\n  readonly toHexString: Function;\n};\n"]}
|
|
110
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dialect.util.js","sourceRoot":"","sources":["../../src/util/dialect.util.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  EntityMeta,\n  FieldKey,\n  QueryProject,\n  CascadeType,\n  RelationKey,\n  FieldOptions,\n  Key,\n  QuerySort,\n  QuerySortMap,\n  QueryRawFnOptions,\n  QueryFilter,\n  QueryFilterMap,\n} from '@uql/core/type';\nimport { getKeys, Raw } from '@uql/core/util';\n\ntype CallbackKey = keyof Pick<FieldOptions, 'onInsert' | 'onUpdate' | 'onDelete'>;\n\nexport function getRawValue(opts: QueryRawFnOptions & { value: Raw; alias?: string; autoPrefixAlias?: boolean }) {\n  const { value, prefix = '', dialect, autoPrefixAlias } = opts;\n  const val = typeof value.value === 'function' ? value.value(opts) : prefix + value.value;\n  const alias = opts.alias ?? value.alias;\n  if (alias) {\n    const fullAlias = autoPrefixAlias ? prefix + alias : alias;\n    const escapedFullAlias = dialect.escapeId(fullAlias, true);\n    return `${val} ${escapedFullAlias}`;\n  }\n  return val;\n}\n\nexport function getPersistable<E>(meta: EntityMeta<E>, payload: E, callbackKey: CallbackKey): E {\n  return getPersistables(meta, payload, callbackKey)[0];\n}\n\nexport function getPersistables<E>(meta: EntityMeta<E>, payload: E | E[], callbackKey: CallbackKey): E[] {\n  const payloads = fillOnFields(meta, payload, callbackKey);\n  const persistableKeys = getKeys(payloads[0]).filter((key) => meta.fields[key]) as FieldKey<E>[];\n  return payloads.map((it) =>\n    persistableKeys.reduce((acc, key) => {\n      acc[key] = it[key];\n      return acc;\n    }, {} as E)\n  );\n}\n\nfunction fillOnFields<E>(meta: EntityMeta<E>, payload: E | E[], callbackKey: CallbackKey): E[] {\n  const payloads = Array.isArray(payload) ? payload : [payload];\n  const keys = getKeys(meta.fields).filter((col) => meta.fields[col][callbackKey]);\n  return payloads.map((it) => {\n    for (const key of keys) {\n      if (it[key] === undefined) {\n        it[key] = meta.fields[key][callbackKey]();\n      }\n    }\n    return it;\n  });\n}\n\nexport function getPersistableRelations<E>(meta: EntityMeta<E>, payload: E, action: CascadeType): RelationKey<E>[] {\n  const keys = getKeys(payload);\n  return keys.filter((key) => {\n    const relOpts = meta.relations[key as RelationKey<E>];\n    return relOpts && isCascadable(action, relOpts.cascade);\n  }) as RelationKey<E>[];\n}\n\nexport function isCascadable(action: CascadeType, configuration?: boolean | CascadeType): boolean {\n  if (typeof configuration === 'boolean') {\n    return configuration;\n  }\n  return configuration === action;\n}\n\nexport function getProjectRelationKeys<E>(meta: EntityMeta<E>, project: QueryProject<E>): RelationKey<E>[] {\n  const keys = getProjectKeys(project);\n  return keys.filter((key) => meta.relations[key as RelationKey<E>]) as RelationKey<E>[];\n}\n\nexport function isProjectingRelations<E>(meta: EntityMeta<E>, project: QueryProject<E>): boolean {\n  const keys = getProjectKeys(project);\n  return keys.some((key) => meta.relations[key as RelationKey<E>]);\n}\n\nfunction getProjectKeys<E>(project: QueryProject<E>): Key<E>[] {\n  if (Array.isArray(project)) {\n    return project as Key<E>[];\n  }\n  return getKeys(project).filter((key) => project[key]) as Key<E>[];\n}\n\nexport function buildSortMap<E>(sort: QuerySort<E>): QuerySortMap<E> {\n  if (Array.isArray(sort)) {\n    return sort.reduce((acc, it) => {\n      if (Array.isArray(it)) {\n        acc[it[0]] = it[1];\n      } else {\n        acc[it.field] = it.sort;\n      }\n      return acc;\n    }, {} as QuerySortMap<E>);\n  }\n  return sort as QuerySortMap<E>;\n}\n\nexport function augmentFilter<E>(meta: EntityMeta<E>, target: QueryFilter<E> = {}, source: QueryFilter<E> = {}): QueryFilter<E> {\n  const targetComparison = getQueryFilterAsMap(meta, target);\n  const sourceComparison = getQueryFilterAsMap(meta, source);\n  return {\n    ...targetComparison,\n    ...sourceComparison,\n  };\n}\n\nexport function getQueryFilterAsMap<E>(meta: EntityMeta<E>, filter: QueryFilter<E> = {}): QueryFilterMap<E> {\n  if (filter instanceof Raw) {\n    return { $and: [filter] } as QueryFilterMap<E>;\n  }\n  if (typeof filter !== 'object' || Array.isArray(filter) || typeof (filter as MongoId).toHexString === 'function') {\n    return {\n      [meta.id]: filter,\n    } as QueryFilterMap<E>;\n  }\n  return filter as QueryFilterMap<E>;\n}\n\ntype MongoId = {\n  readonly toHexString: Function;\n};\n"]}
|
package/util/index.js
CHANGED
|
@@ -1,9 +1,9 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
3
|
const tslib_1 = require("tslib");
|
|
4
|
-
tslib_1.__exportStar(require("./string.util"), exports);
|
|
5
|
-
tslib_1.__exportStar(require("./object.util"), exports);
|
|
6
|
-
tslib_1.__exportStar(require("./dialect.util"), exports);
|
|
7
|
-
tslib_1.__exportStar(require("./sql.util"), exports);
|
|
8
|
-
tslib_1.__exportStar(require("./raw"), exports);
|
|
9
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
4
|
+
(0, tslib_1.__exportStar)(require("./string.util"), exports);
|
|
5
|
+
(0, tslib_1.__exportStar)(require("./object.util"), exports);
|
|
6
|
+
(0, tslib_1.__exportStar)(require("./dialect.util"), exports);
|
|
7
|
+
(0, tslib_1.__exportStar)(require("./sql.util"), exports);
|
|
8
|
+
(0, tslib_1.__exportStar)(require("./raw"), exports);
|
|
9
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9zcmMvdXRpbC9pbmRleC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7QUFBQSw2REFBOEI7QUFDOUIsNkRBQThCO0FBQzlCLDhEQUErQjtBQUMvQiwwREFBMkI7QUFDM0IscURBQXNCIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0ICogZnJvbSAnLi9zdHJpbmcudXRpbCc7XG5leHBvcnQgKiBmcm9tICcuL29iamVjdC51dGlsJztcbmV4cG9ydCAqIGZyb20gJy4vZGlhbGVjdC51dGlsJztcbmV4cG9ydCAqIGZyb20gJy4vc3FsLnV0aWwnO1xuZXhwb3J0ICogZnJvbSAnLi9yYXcnO1xuIl19
|
package/util/sql.util.js
CHANGED
|
@@ -3,7 +3,7 @@ Object.defineProperty(exports, "__esModule", { value: true });
|
|
|
3
3
|
exports.unflatObjects = exports.flatObject = void 0;
|
|
4
4
|
const object_util_1 = require("./object.util");
|
|
5
5
|
function flatObject(obj, pre) {
|
|
6
|
-
return object_util_1.getKeys(obj).reduce((acc, key) => flatObjectEntry(acc, key, obj[key], typeof obj[key] === 'object' ? '' : pre), {});
|
|
6
|
+
return (0, object_util_1.getKeys)(obj).reduce((acc, key) => flatObjectEntry(acc, key, obj[key], typeof obj[key] === 'object' ? '' : pre), {});
|
|
7
7
|
}
|
|
8
8
|
exports.flatObject = flatObject;
|
|
9
9
|
function flatObjectEntry(map, key, val, pre) {
|
|
@@ -17,7 +17,7 @@ function unflatObjects(objects) {
|
|
|
17
17
|
return objects;
|
|
18
18
|
}
|
|
19
19
|
const attrsPaths = obtainAttrsPaths(objects[0]);
|
|
20
|
-
if (!object_util_1.hasKeys(attrsPaths)) {
|
|
20
|
+
if (!(0, object_util_1.hasKeys)(attrsPaths)) {
|
|
21
21
|
return objects;
|
|
22
22
|
}
|
|
23
23
|
return objects.map((row) => {
|
|
@@ -45,11 +45,11 @@ function unflatObjects(objects) {
|
|
|
45
45
|
}
|
|
46
46
|
exports.unflatObjects = unflatObjects;
|
|
47
47
|
function obtainAttrsPaths(row) {
|
|
48
|
-
return object_util_1.getKeys(row).reduce((acc, col) => {
|
|
48
|
+
return (0, object_util_1.getKeys)(row).reduce((acc, col) => {
|
|
49
49
|
if (col.includes('.')) {
|
|
50
50
|
acc[col] = col.split('.');
|
|
51
51
|
}
|
|
52
52
|
return acc;
|
|
53
53
|
}, {});
|
|
54
54
|
}
|
|
55
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
55
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3FsLnV0aWwuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9zcmMvdXRpbC9zcWwudXRpbC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7QUFBQSwrQ0FBaUQ7QUFFakQsU0FBZ0IsVUFBVSxDQUFJLEdBQU0sRUFBRSxHQUFZO0lBQ2hELE9BQU8sSUFBQSxxQkFBTyxFQUFDLEdBQUcsQ0FBQyxDQUFDLE1BQU0sQ0FBQyxDQUFDLEdBQUcsRUFBRSxHQUFHLEVBQUUsRUFBRSxDQUFDLGVBQWUsQ0FBQyxHQUFHLEVBQUUsR0FBRyxFQUFFLEdBQUcsQ0FBQyxHQUFHLENBQUMsRUFBRSxPQUFPLEdBQUcsQ0FBQyxHQUFHLENBQUMsS0FBSyxRQUFRLENBQUMsQ0FBQyxDQUFDLEVBQUUsQ0FBQyxDQUFDLENBQUMsR0FBRyxDQUFDLEVBQUUsRUFBTyxDQUFDLENBQUM7QUFDbEksQ0FBQztBQUZELGdDQUVDO0FBRUQsU0FBUyxlQUFlLENBQUksR0FBTSxFQUFFLEdBQVcsRUFBRSxHQUFRLEVBQUUsR0FBWTtJQUNyRSxNQUFNLE1BQU0sR0FBRyxHQUFHLENBQUMsQ0FBQyxDQUFDLEdBQUcsR0FBRyxJQUFJLEdBQUcsRUFBRSxDQUFDLENBQUMsQ0FBQyxHQUFHLENBQUM7SUFDM0MsT0FBTyxPQUFPLEdBQUcsS0FBSyxRQUFRO1FBQzVCLENBQUMsQ0FBQyxNQUFNLENBQUMsSUFBSSxDQUFDLEdBQUcsQ0FBQyxDQUFDLE1BQU0sQ0FBQyxDQUFDLEdBQUcsRUFBRSxJQUFJLEVBQUUsRUFBRSxDQUFDLGVBQWUsQ0FBQyxHQUFHLEVBQUUsSUFBSSxFQUFFLEdBQUcsQ0FBQyxJQUFJLENBQUMsRUFBRSxNQUFNLENBQUMsRUFBRSxHQUFHLENBQUM7UUFDNUYsQ0FBQyxDQUFDLEVBQUUsR0FBRyxHQUFHLEVBQUUsQ0FBQyxNQUFNLENBQUMsRUFBRSxHQUFHLEVBQUUsQ0FBQztBQUNoQyxDQUFDO0FBRUQsU0FBZ0IsYUFBYSxDQUFJLE9BQVk7SUFDM0MsSUFBSSxDQUFDLEtBQUssQ0FBQyxPQUFPLENBQUMsT0FBTyxDQUFDLElBQUksQ0FBQyxPQUFPLENBQUMsTUFBTSxFQUFFO1FBQzlDLE9BQU8sT0FBTyxDQUFDO0tBQ2hCO0lBRUQsTUFBTSxVQUFVLEdBQUcsZ0JBQWdCLENBQUMsT0FBTyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUM7SUFFaEQsSUFBSSxDQUFDLElBQUEscUJBQU8sRUFBQyxVQUFVLENBQUMsRUFBRTtRQUN4QixPQUFPLE9BQU8sQ0FBQztLQUNoQjtJQUVELE9BQU8sT0FBTyxDQUFDLEdBQUcsQ0FBQyxDQUFDLEdBQUcsRUFBRSxFQUFFO1FBQ3pCLE1BQU0sR0FBRyxHQUFHLEVBQU8sQ0FBQztRQUVwQixLQUFLLE1BQU0sR0FBRyxJQUFJLEdBQUcsRUFBRTtZQUNyQixJQUFJLEdBQUcsQ0FBQyxHQUFHLENBQUMsS0FBSyxJQUFJLEVBQUU7Z0JBQ3JCLFNBQVM7YUFDVjtZQUNELE1BQU0sUUFBUSxHQUFHLFVBQVUsQ0FBQyxHQUFHLENBQUMsQ0FBQztZQUNqQyxJQUFJLFFBQVEsRUFBRTtnQkFDWixNQUFNLE1BQU0sR0FBRyxRQUFRLENBQUMsS0FBSyxDQUFDLENBQUMsRUFBRSxDQUFDLENBQUMsQ0FBQyxDQUFDLE1BQU0sQ0FBQyxDQUFDLEdBQUcsRUFBRSxHQUFHLEVBQUUsRUFBRTtvQkFDdkQsSUFBSSxPQUFPLEdBQUcsQ0FBQyxHQUFHLENBQUMsS0FBSyxRQUFRLEVBQUU7d0JBQ2hDLEdBQUcsQ0FBQyxHQUFHLENBQUMsR0FBRyxFQUFFLENBQUM7cUJBQ2Y7b0JBQ0QsT0FBTyxHQUFHLENBQUMsR0FBRyxDQUFDLENBQUM7Z0JBQ2xCLENBQUMsRUFBRSxHQUFHLENBQUMsQ0FBQztnQkFDUixNQUFNLENBQUMsUUFBUSxDQUFDLFFBQVEsQ0FBQyxNQUFNLEdBQUcsQ0FBQyxDQUFDLENBQUMsR0FBRyxHQUFHLENBQUMsR0FBRyxDQUFDLENBQUM7YUFDbEQ7aUJBQU07Z0JBQ0wsR0FBRyxDQUFDLEdBQUcsQ0FBQyxHQUFHLEdBQUcsQ0FBQyxHQUFHLENBQUMsQ0FBQzthQUNyQjtTQUNGO1FBRUQsT0FBTyxHQUFHLENBQUM7SUFDYixDQUFDLENBQUMsQ0FBQztBQUNMLENBQUM7QUFsQ0Qsc0NBa0NDO0FBRUQsU0FBUyxnQkFBZ0IsQ0FBSSxHQUFNO0lBQ2pDLE9BQU8sSUFBQSxxQkFBTyxFQUFDLEdBQUcsQ0FBQyxDQUFDLE1BQU0sQ0FBQyxDQUFDLEdBQUcsRUFBRSxHQUFHLEVBQUUsRUFBRTtRQUN0QyxJQUFJLEdBQUcsQ0FBQyxRQUFRLENBQUMsR0FBRyxDQUFDLEVBQUU7WUFDckIsR0FBRyxDQUFDLEdBQUcsQ0FBQyxHQUFHLEdBQUcsQ0FBQyxLQUFLLENBQUMsR0FBRyxDQUFDLENBQUM7U0FDM0I7UUFDRCxPQUFPLEdBQUcsQ0FBQztJQUNiLENBQUMsRUFBRSxFQUErQixDQUFDLENBQUM7QUFDdEMsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IGhhc0tleXMsIGdldEtleXMgfSBmcm9tICcuL29iamVjdC51dGlsJztcblxuZXhwb3J0IGZ1bmN0aW9uIGZsYXRPYmplY3Q8RT4ob2JqOiBFLCBwcmU/OiBzdHJpbmcpOiBFIHtcbiAgcmV0dXJuIGdldEtleXMob2JqKS5yZWR1Y2UoKGFjYywga2V5KSA9PiBmbGF0T2JqZWN0RW50cnkoYWNjLCBrZXksIG9ialtrZXldLCB0eXBlb2Ygb2JqW2tleV0gPT09ICdvYmplY3QnID8gJycgOiBwcmUpLCB7fSBhcyBFKTtcbn1cblxuZnVuY3Rpb24gZmxhdE9iamVjdEVudHJ5PEU+KG1hcDogRSwga2V5OiBzdHJpbmcsIHZhbDogYW55LCBwcmU/OiBzdHJpbmcpOiBFIHtcbiAgY29uc3QgcHJlZml4ID0gcHJlID8gYCR7cHJlfS4ke2tleX1gIDoga2V5O1xuICByZXR1cm4gdHlwZW9mIHZhbCA9PT0gJ29iamVjdCdcbiAgICA/IE9iamVjdC5rZXlzKHZhbCkucmVkdWNlKChhY2MsIHByb3ApID0+IGZsYXRPYmplY3RFbnRyeShhY2MsIHByb3AsIHZhbFtwcm9wXSwgcHJlZml4KSwgbWFwKVxuICAgIDogeyAuLi5tYXAsIFtwcmVmaXhdOiB2YWwgfTtcbn1cblxuZXhwb3J0IGZ1bmN0aW9uIHVuZmxhdE9iamVjdHM8VD4ob2JqZWN0czogVFtdKTogVFtdIHtcbiAgaWYgKCFBcnJheS5pc0FycmF5KG9iamVjdHMpIHx8ICFvYmplY3RzLmxlbmd0aCkge1xuICAgIHJldHVybiBvYmplY3RzO1xuICB9XG5cbiAgY29uc3QgYXR0cnNQYXRocyA9IG9idGFpbkF0dHJzUGF0aHMob2JqZWN0c1swXSk7XG5cbiAgaWYgKCFoYXNLZXlzKGF0dHJzUGF0aHMpKSB7XG4gICAgcmV0dXJuIG9iamVjdHM7XG4gIH1cblxuICByZXR1cm4gb2JqZWN0cy5tYXAoKHJvdykgPT4ge1xuICAgIGNvbnN0IGR0byA9IHt9IGFzIFQ7XG5cbiAgICBmb3IgKGNvbnN0IGNvbCBpbiByb3cpIHtcbiAgICAgIGlmIChyb3dbY29sXSA9PT0gbnVsbCkge1xuICAgICAgICBjb250aW51ZTtcbiAgICAgIH1cbiAgICAgIGNvbnN0IGF0dHJQYXRoID0gYXR0cnNQYXRoc1tjb2xdO1xuICAgICAgaWYgKGF0dHJQYXRoKSB7XG4gICAgICAgIGNvbnN0IHRhcmdldCA9IGF0dHJQYXRoLnNsaWNlKDAsIC0xKS5yZWR1Y2UoKGFjYywga2V5KSA9PiB7XG4gICAgICAgICAgaWYgKHR5cGVvZiBhY2Nba2V5XSAhPT0gJ29iamVjdCcpIHtcbiAgICAgICAgICAgIGFjY1trZXldID0ge307XG4gICAgICAgICAgfVxuICAgICAgICAgIHJldHVybiBhY2Nba2V5XTtcbiAgICAgICAgfSwgZHRvKTtcbiAgICAgICAgdGFyZ2V0W2F0dHJQYXRoW2F0dHJQYXRoLmxlbmd0aCAtIDFdXSA9IHJvd1tjb2xdO1xuICAgICAgfSBlbHNlIHtcbiAgICAgICAgZHRvW2NvbF0gPSByb3dbY29sXTtcbiAgICAgIH1cbiAgICB9XG5cbiAgICByZXR1cm4gZHRvO1xuICB9KTtcbn1cblxuZnVuY3Rpb24gb2J0YWluQXR0cnNQYXRoczxUPihyb3c6IFQpIHtcbiAgcmV0dXJuIGdldEtleXMocm93KS5yZWR1Y2UoKGFjYywgY29sKSA9PiB7XG4gICAgaWYgKGNvbC5pbmNsdWRlcygnLicpKSB7XG4gICAgICBhY2NbY29sXSA9IGNvbC5zcGxpdCgnLicpO1xuICAgIH1cbiAgICByZXR1cm4gYWNjO1xuICB9LCB7fSBhcyB7IFtrOiBzdHJpbmddOiBzdHJpbmdbXSB9KTtcbn1cbiJdfQ==
|