@goatlab/fluent 0.7.39 → 0.7.40
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/dist/BaseConnector.d.ts +112 -0
- package/dist/BaseConnector.js +343 -0
- package/dist/BaseConnector.js.map +1 -0
- package/dist/Fluent.d.ts +11 -0
- package/dist/Fluent.js +27 -0
- package/dist/Fluent.js.map +1 -0
- package/dist/FluentConnectorInterface.d.ts +17 -0
- package/dist/FluentConnectorInterface.js +3 -0
- package/dist/FluentConnectorInterface.js.map +1 -0
- package/dist/FluentEntity.d.ts +7 -0
- package/dist/FluentEntity.js +29 -0
- package/dist/FluentEntity.js.map +1 -0
- package/dist/TypeOrmConnector/TypeOrmConnector.d.ts +123 -0
- package/dist/TypeOrmConnector/TypeOrmConnector.js +760 -0
- package/dist/TypeOrmConnector/TypeOrmConnector.js.map +1 -0
- package/dist/TypeOrmConnector/queryBuilder/mongodb/getMongoBaseAggregations.d.ts +12 -0
- package/dist/TypeOrmConnector/queryBuilder/mongodb/getMongoBaseAggregations.js +167 -0
- package/dist/TypeOrmConnector/queryBuilder/mongodb/getMongoBaseAggregations.js.map +1 -0
- package/dist/TypeOrmConnector/queryBuilder/mongodb/getMongoFindAggregatedQuery.d.ts +11 -0
- package/dist/TypeOrmConnector/queryBuilder/mongodb/getMongoFindAggregatedQuery.js +52 -0
- package/dist/TypeOrmConnector/queryBuilder/mongodb/getMongoFindAggregatedQuery.js.map +1 -0
- package/dist/TypeOrmConnector/queryBuilder/mongodb/getMongoOrderBy.d.ts +4 -0
- package/dist/TypeOrmConnector/queryBuilder/mongodb/getMongoOrderBy.js +20 -0
- package/dist/TypeOrmConnector/queryBuilder/mongodb/getMongoOrderBy.js.map +1 -0
- package/dist/TypeOrmConnector/queryBuilder/mongodb/getMongoSelect.d.ts +7 -0
- package/dist/TypeOrmConnector/queryBuilder/mongodb/getMongoSelect.js +19 -0
- package/dist/TypeOrmConnector/queryBuilder/mongodb/getMongoSelect.js.map +1 -0
- package/dist/TypeOrmConnector/queryBuilder/mongodb/getMongoWhere.d.ts +11 -0
- package/dist/TypeOrmConnector/queryBuilder/mongodb/getMongoWhere.js +173 -0
- package/dist/TypeOrmConnector/queryBuilder/mongodb/getMongoWhere.js.map +1 -0
- package/dist/TypeOrmConnector/queryBuilder/sql/getQueryBuilderWhere.d.ts +13 -0
- package/dist/TypeOrmConnector/queryBuilder/sql/getQueryBuilderWhere.js +207 -0
- package/dist/TypeOrmConnector/queryBuilder/sql/getQueryBuilderWhere.js.map +1 -0
- package/dist/TypeOrmConnector/queryBuilder/sql/getTypeOrmWhere.d.ts +11 -0
- package/dist/TypeOrmConnector/queryBuilder/sql/getTypeOrmWhere.js +214 -0
- package/dist/TypeOrmConnector/queryBuilder/sql/getTypeOrmWhere.js.map +1 -0
- package/dist/TypeOrmConnector/util/clearEmpties.d.ts +7 -0
- package/dist/TypeOrmConnector/util/clearEmpties.js +33 -0
- package/dist/TypeOrmConnector/util/clearEmpties.js.map +1 -0
- package/dist/TypeOrmConnector/util/extractConditions.d.ts +12 -0
- package/dist/TypeOrmConnector/util/extractConditions.js +89 -0
- package/dist/TypeOrmConnector/util/extractConditions.js.map +1 -0
- package/dist/TypeOrmConnector/util/extractInclude.d.ts +2 -0
- package/dist/TypeOrmConnector/util/extractInclude.js +26 -0
- package/dist/TypeOrmConnector/util/extractInclude.js.map +1 -0
- package/dist/TypeOrmConnector/util/extractMetadataFromKeys.d.ts +12 -0
- package/dist/TypeOrmConnector/util/extractMetadataFromKeys.js +49 -0
- package/dist/TypeOrmConnector/util/extractMetadataFromKeys.js.map +1 -0
- package/dist/TypeOrmConnector/util/extractOrderBy.d.ts +2 -0
- package/dist/TypeOrmConnector/util/extractOrderBy.js +24 -0
- package/dist/TypeOrmConnector/util/extractOrderBy.js.map +1 -0
- package/dist/TypeOrmConnector/util/getRelationsFromModelGenerator.d.ts +19 -0
- package/dist/TypeOrmConnector/util/getRelationsFromModelGenerator.js +27 -0
- package/dist/TypeOrmConnector/util/getRelationsFromModelGenerator.js.map +1 -0
- package/dist/TypeOrmConnector/util/getSelectedKeysFromRawSql.d.ts +6 -0
- package/dist/TypeOrmConnector/util/getSelectedKeysFromRawSql.js +29 -0
- package/dist/TypeOrmConnector/util/getSelectedKeysFromRawSql.js.map +1 -0
- package/dist/TypeOrmConnector/util/isAnyObject.d.ts +1 -0
- package/dist/TypeOrmConnector/util/isAnyObject.js +8 -0
- package/dist/TypeOrmConnector/util/isAnyObject.js.map +1 -0
- package/dist/TypeOrmConnector/util/nestQueryResults.d.ts +2 -0
- package/dist/TypeOrmConnector/util/nestQueryResults.js +38 -0
- package/dist/TypeOrmConnector/util/nestQueryResults.js.map +1 -0
- package/dist/core/Loopback/build-schema.d.ts +148 -0
- package/dist/core/Loopback/build-schema.js +443 -0
- package/dist/core/Loopback/build-schema.js.map +1 -0
- package/dist/core/Loopback/common-types.d.ts +96 -0
- package/dist/core/Loopback/common-types.js +24 -0
- package/dist/core/Loopback/common-types.js.map +1 -0
- package/dist/core/Loopback/json-to-schema.d.ts +41 -0
- package/dist/core/Loopback/json-to-schema.js +113 -0
- package/dist/core/Loopback/json-to-schema.js.map +1 -0
- package/dist/core/Loopback/metadata.d.ts +16 -0
- package/dist/core/Loopback/metadata.js +49 -0
- package/dist/core/Loopback/metadata.js.map +1 -0
- package/dist/core/Loopback/model.d.ts +233 -0
- package/dist/core/Loopback/model.js +387 -0
- package/dist/core/Loopback/model.js.map +1 -0
- package/dist/core/Loopback/query.d.ts +394 -0
- package/dist/core/Loopback/query.js +482 -0
- package/dist/core/Loopback/query.js.map +1 -0
- package/dist/core/Loopback/relation.types.d.ts +141 -0
- package/dist/core/Loopback/relation.types.js +18 -0
- package/dist/core/Loopback/relation.types.js.map +1 -0
- package/dist/core/Loopback/type-resolver.d.ts +42 -0
- package/dist/core/Loopback/type-resolver.js +60 -0
- package/dist/core/Loopback/type-resolver.js.map +1 -0
- package/dist/core/Loopback/type.d.ts +38 -0
- package/dist/core/Loopback/type.js +7 -0
- package/dist/core/Loopback/type.js.map +1 -0
- package/dist/core/Nestjs/applyDecorators.d.ts +10 -0
- package/dist/core/Nestjs/applyDecorators.js +26 -0
- package/dist/core/Nestjs/applyDecorators.js.map +1 -0
- package/dist/core/Nestjs/types/common.d.ts +16 -0
- package/dist/core/Nestjs/types/common.js +38 -0
- package/dist/core/Nestjs/types/common.js.map +1 -0
- package/dist/core/Nestjs/types/decorators/api-hide-property.decorator.d.ts +1 -0
- package/dist/core/Nestjs/types/decorators/api-hide-property.decorator.js +8 -0
- package/dist/core/Nestjs/types/decorators/api-hide-property.decorator.js.map +1 -0
- package/dist/core/Nestjs/types/decorators/api-property.decorator.d.ts +27 -0
- package/dist/core/Nestjs/types/decorators/api-property.decorator.js +66 -0
- package/dist/core/Nestjs/types/decorators/api-property.decorator.js.map +1 -0
- package/dist/core/Nestjs/types/decorators/apply-is-optional.decorator.d.ts +5 -0
- package/dist/core/Nestjs/types/decorators/apply-is-optional.decorator.js +136 -0
- package/dist/core/Nestjs/types/decorators/apply-is-optional.decorator.js.map +1 -0
- package/dist/core/Nestjs/types/decorators/args-type.decorator.d.ts +4 -0
- package/dist/core/Nestjs/types/decorators/args-type.decorator.js +24 -0
- package/dist/core/Nestjs/types/decorators/args-type.decorator.js.map +1 -0
- package/dist/core/Nestjs/types/decorators/create-property.decorator.d.ts +2 -0
- package/dist/core/Nestjs/types/decorators/create-property.decorator.js +55 -0
- package/dist/core/Nestjs/types/decorators/create-property.decorator.js.map +1 -0
- package/dist/core/Nestjs/types/decorators/directive.decorator.d.ts +4 -0
- package/dist/core/Nestjs/types/decorators/directive.decorator.js +39 -0
- package/dist/core/Nestjs/types/decorators/directive.decorator.js.map +1 -0
- package/dist/core/Nestjs/types/decorators/extensions.decorator.d.ts +4 -0
- package/dist/core/Nestjs/types/decorators/extensions.decorator.js +28 -0
- package/dist/core/Nestjs/types/decorators/extensions.decorator.js.map +1 -0
- package/dist/core/Nestjs/types/decorators/field.decorator.d.ts +48 -0
- package/dist/core/Nestjs/types/decorators/field.decorator.js +63 -0
- package/dist/core/Nestjs/types/decorators/field.decorator.js.map +1 -0
- package/dist/core/Nestjs/types/decorators/input-type.decorator.d.ts +25 -0
- package/dist/core/Nestjs/types/decorators/input-type.decorator.js +29 -0
- package/dist/core/Nestjs/types/decorators/input-type.decorator.js.map +1 -0
- package/dist/core/Nestjs/types/decorators/interface-type.decorator.d.ts +33 -0
- package/dist/core/Nestjs/types/decorators/interface-type.decorator.js +35 -0
- package/dist/core/Nestjs/types/decorators/interface-type.decorator.js.map +1 -0
- package/dist/core/Nestjs/types/decorators/partial-type.helper.d.ts +3 -0
- package/dist/core/Nestjs/types/decorators/partial-type.helper.js +46 -0
- package/dist/core/Nestjs/types/decorators/partial-type.helper.js.map +1 -0
- package/dist/core/Nestjs/types/errors/cannot-determine-host-type.error.d.ts +3 -0
- package/dist/core/Nestjs/types/errors/cannot-determine-host-type.error.js +10 -0
- package/dist/core/Nestjs/types/errors/cannot-determine-host-type.error.js.map +1 -0
- package/dist/core/Nestjs/types/errors/directive-parsing.error.d.ts +3 -0
- package/dist/core/Nestjs/types/errors/directive-parsing.error.js +10 -0
- package/dist/core/Nestjs/types/errors/directive-parsing.error.js.map +1 -0
- package/dist/core/Nestjs/types/errors/unable-to-find-fields.error.d.ts +3 -0
- package/dist/core/Nestjs/types/errors/unable-to-find-fields.error.js +10 -0
- package/dist/core/Nestjs/types/errors/unable-to-find-fields.error.js.map +1 -0
- package/dist/core/Nestjs/types/errors/undefined-type.error.d.ts +3 -0
- package/dist/core/Nestjs/types/errors/undefined-type.error.js +11 -0
- package/dist/core/Nestjs/types/errors/undefined-type.error.js.map +1 -0
- package/dist/core/Nestjs/types/interfaces/add-class-type-metadata.util.d.ts +3 -0
- package/dist/core/Nestjs/types/interfaces/add-class-type-metadata.util.js +11 -0
- package/dist/core/Nestjs/types/interfaces/add-class-type-metadata.util.js.map +1 -0
- package/dist/core/Nestjs/types/interfaces/base-type-options.interface.d.ts +11 -0
- package/dist/core/Nestjs/types/interfaces/base-type-options.interface.js +3 -0
- package/dist/core/Nestjs/types/interfaces/base-type-options.interface.js.map +1 -0
- package/dist/core/Nestjs/types/interfaces/class-decorator-factory.interface.d.ts +5 -0
- package/dist/core/Nestjs/types/interfaces/class-decorator-factory.interface.js +3 -0
- package/dist/core/Nestjs/types/interfaces/class-decorator-factory.interface.js.map +1 -0
- package/dist/core/Nestjs/types/interfaces/complexity.interface.d.ts +11 -0
- package/dist/core/Nestjs/types/interfaces/complexity.interface.js +3 -0
- package/dist/core/Nestjs/types/interfaces/complexity.interface.js.map +1 -0
- package/dist/core/Nestjs/types/interfaces/field-middleware.interface.d.ts +15 -0
- package/dist/core/Nestjs/types/interfaces/field-middleware.interface.js +3 -0
- package/dist/core/Nestjs/types/interfaces/field-middleware.interface.js.map +1 -0
- package/dist/core/Nestjs/types/interfaces/open-api-spec.interface.d.ts +239 -0
- package/dist/core/Nestjs/types/interfaces/open-api-spec.interface.js +7 -0
- package/dist/core/Nestjs/types/interfaces/open-api-spec.interface.js.map +1 -0
- package/dist/core/Nestjs/types/interfaces/resolve-type-fn.interface.d.ts +2 -0
- package/dist/core/Nestjs/types/interfaces/resolve-type-fn.interface.js +3 -0
- package/dist/core/Nestjs/types/interfaces/resolve-type-fn.interface.js.map +1 -0
- package/dist/core/Nestjs/types/interfaces/return-type-func.interface.d.ts +5 -0
- package/dist/core/Nestjs/types/interfaces/return-type-func.interface.js +3 -0
- package/dist/core/Nestjs/types/interfaces/return-type-func.interface.js.map +1 -0
- package/dist/core/Nestjs/types/interfaces/schema-object-metadata.interface.d.ts +9 -0
- package/dist/core/Nestjs/types/interfaces/schema-object-metadata.interface.js +3 -0
- package/dist/core/Nestjs/types/interfaces/schema-object-metadata.interface.js.map +1 -0
- package/dist/core/Nestjs/types/interfaces/type-options.interface.d.ts +5 -0
- package/dist/core/Nestjs/types/interfaces/type-options.interface.js +3 -0
- package/dist/core/Nestjs/types/interfaces/type-options.interface.js.map +1 -0
- package/dist/core/Nestjs/types/lazy-metadata.storage.d.ts +15 -0
- package/dist/core/Nestjs/types/lazy-metadata.storage.js +68 -0
- package/dist/core/Nestjs/types/lazy-metadata.storage.js.map +1 -0
- package/dist/core/Nestjs/types/metadata/class.metadata.d.ts +11 -0
- package/dist/core/Nestjs/types/metadata/class.metadata.js +3 -0
- package/dist/core/Nestjs/types/metadata/class.metadata.js.map +1 -0
- package/dist/core/Nestjs/types/metadata/directive.metadata.d.ts +8 -0
- package/dist/core/Nestjs/types/metadata/directive.metadata.js +3 -0
- package/dist/core/Nestjs/types/metadata/directive.metadata.js.map +1 -0
- package/dist/core/Nestjs/types/metadata/enum.metadata.d.ts +11 -0
- package/dist/core/Nestjs/types/metadata/enum.metadata.js +3 -0
- package/dist/core/Nestjs/types/metadata/enum.metadata.js.map +1 -0
- package/dist/core/Nestjs/types/metadata/extensions.metadata.d.ts +8 -0
- package/dist/core/Nestjs/types/metadata/extensions.metadata.js +3 -0
- package/dist/core/Nestjs/types/metadata/extensions.metadata.js.map +1 -0
- package/dist/core/Nestjs/types/metadata/index.d.ts +8 -0
- package/dist/core/Nestjs/types/metadata/index.js +12 -0
- package/dist/core/Nestjs/types/metadata/index.js.map +1 -0
- package/dist/core/Nestjs/types/metadata/interface.metadata.d.ts +6 -0
- package/dist/core/Nestjs/types/metadata/interface.metadata.js +3 -0
- package/dist/core/Nestjs/types/metadata/interface.metadata.js.map +1 -0
- package/dist/core/Nestjs/types/metadata/object-type.metadata.d.ts +4 -0
- package/dist/core/Nestjs/types/metadata/object-type.metadata.js +3 -0
- package/dist/core/Nestjs/types/metadata/object-type.metadata.js.map +1 -0
- package/dist/core/Nestjs/types/metadata/param.metadata.d.ts +18 -0
- package/dist/core/Nestjs/types/metadata/param.metadata.js +3 -0
- package/dist/core/Nestjs/types/metadata/param.metadata.js.map +1 -0
- package/dist/core/Nestjs/types/metadata/property.metadata.d.ts +20 -0
- package/dist/core/Nestjs/types/metadata/property.metadata.js +3 -0
- package/dist/core/Nestjs/types/metadata/property.metadata.js.map +1 -0
- package/dist/core/Nestjs/types/metadata/resolver.metadata.d.ts +34 -0
- package/dist/core/Nestjs/types/metadata/resolver.metadata.js +3 -0
- package/dist/core/Nestjs/types/metadata/resolver.metadata.js.map +1 -0
- package/dist/core/Nestjs/types/metadata/union.metadata.d.ts +9 -0
- package/dist/core/Nestjs/types/metadata/union.metadata.js +3 -0
- package/dist/core/Nestjs/types/metadata/union.metadata.js.map +1 -0
- package/dist/core/Nestjs/types/object-type.decorator.d.ts +32 -0
- package/dist/core/Nestjs/types/object-type.decorator.js +33 -0
- package/dist/core/Nestjs/types/object-type.decorator.js.map +1 -0
- package/dist/core/Nestjs/types/omit-type.d.ts +2 -0
- package/dist/core/Nestjs/types/omit-type.js +34 -0
- package/dist/core/Nestjs/types/omit-type.js.map +1 -0
- package/dist/core/Nestjs/types/reflection.utils.d.ts +15 -0
- package/dist/core/Nestjs/types/reflection.utils.js +65 -0
- package/dist/core/Nestjs/types/reflection.utils.js.map +1 -0
- package/dist/core/Nestjs/types/set-metadata.decorator.d.ts +20 -0
- package/dist/core/Nestjs/types/set-metadata.decorator.js +33 -0
- package/dist/core/Nestjs/types/set-metadata.decorator.js.map +1 -0
- package/dist/core/Nestjs/types/type-metadata.storage.d.ts +73 -0
- package/dist/core/Nestjs/types/type-metadata.storage.js +351 -0
- package/dist/core/Nestjs/types/type-metadata.storage.js.map +1 -0
- package/dist/core/Nestjs/types/utils/enum.utils.d.ts +3 -0
- package/dist/core/Nestjs/types/utils/enum.utils.js +31 -0
- package/dist/core/Nestjs/types/utils/enum.utils.js.map +1 -0
- package/dist/core/Nestjs/types/utils/get-fields-and-decorator.util.d.ts +13 -0
- package/dist/core/Nestjs/types/utils/get-fields-and-decorator.util.js +72 -0
- package/dist/core/Nestjs/types/utils/get-fields-and-decorator.util.js.map +1 -0
- package/dist/core/Nestjs/types/utils/mapped-types.utils.d.ts +2 -0
- package/dist/core/Nestjs/types/utils/mapped-types.utils.js +38 -0
- package/dist/core/Nestjs/types/utils/mapped-types.utils.js.map +1 -0
- package/dist/core/Nestjs/types/utils/model-properties-accessor.d.ts +6 -0
- package/dist/core/Nestjs/types/utils/model-properties-accessor.js +37 -0
- package/dist/core/Nestjs/types/utils/model-properties-accessor.js.map +1 -0
- package/dist/core/Nestjs/types/utils/type-helpers.utils.d.ts +2 -0
- package/dist/core/Nestjs/types/utils/type-helpers.utils.js +16 -0
- package/dist/core/Nestjs/types/utils/type-helpers.utils.js.map +1 -0
- package/dist/core/types.d.ts +23 -0
- package/dist/core/types.js +31 -0
- package/dist/core/types.js.map +1 -0
- package/dist/decorators.d.ts +92 -0
- package/dist/decorators.js +162 -0
- package/dist/decorators.js.map +1 -0
- package/dist/generatorDatasource.d.ts +2 -0
- package/dist/generatorDatasource.js +13 -0
- package/dist/generatorDatasource.js.map +1 -0
- package/dist/index.d.ts +30 -0
- package/dist/index.js +50 -0
- package/dist/index.js.map +1 -0
- package/dist/loadRelations.d.ts +12 -0
- package/dist/loadRelations.js +139 -0
- package/dist/loadRelations.js.map +1 -0
- package/dist/outputKeys.d.ts +2 -0
- package/dist/outputKeys.js +18 -0
- package/dist/outputKeys.js.map +1 -0
- package/dist/tsconfig.tsbuildinfo +1 -0
- package/dist/types.d.ts +104 -0
- package/dist/types.js +23 -0
- package/dist/types.js.map +1 -0
- package/package.json +47 -23
|
@@ -0,0 +1,482 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.FilterBuilder = exports.WhereBuilder = void 0;
|
|
4
|
+
exports.isFilter = isFilter;
|
|
5
|
+
exports.filterTemplate = filterTemplate;
|
|
6
|
+
/* eslint-disable @typescript-eslint/no-explicit-any */
|
|
7
|
+
const nonWhereFields = ['fields', 'order', 'limit', 'skip', 'offset', 'include'];
|
|
8
|
+
const filterFields = ['where', ...nonWhereFields];
|
|
9
|
+
/**
|
|
10
|
+
* TypeGuard for Filter
|
|
11
|
+
* @param candidate
|
|
12
|
+
*/
|
|
13
|
+
function isFilter(candidate) {
|
|
14
|
+
if (typeof candidate !== 'object')
|
|
15
|
+
return false;
|
|
16
|
+
for (const key in candidate) {
|
|
17
|
+
if (!filterFields.includes(key)) {
|
|
18
|
+
return false;
|
|
19
|
+
}
|
|
20
|
+
}
|
|
21
|
+
return true;
|
|
22
|
+
}
|
|
23
|
+
/**
|
|
24
|
+
* A builder for Where object. It provides fluent APIs to add clauses such as
|
|
25
|
+
* `and`, `or`, and other operators.
|
|
26
|
+
*
|
|
27
|
+
* @example
|
|
28
|
+
* ```ts
|
|
29
|
+
* const whereBuilder = new WhereBuilder();
|
|
30
|
+
* const where = whereBuilder
|
|
31
|
+
* .eq('a', 1)
|
|
32
|
+
* .and({x: 'x'}, {y: {gt: 1}})
|
|
33
|
+
* .and({b: 'b'}, {c: {lt: 1}})
|
|
34
|
+
* .or({d: 'd'}, {e: {neq: 1}})
|
|
35
|
+
* .build();
|
|
36
|
+
* ```
|
|
37
|
+
*/
|
|
38
|
+
class WhereBuilder {
|
|
39
|
+
constructor(w) {
|
|
40
|
+
this.where = w ?? {};
|
|
41
|
+
}
|
|
42
|
+
add(w) {
|
|
43
|
+
for (const k of Object.keys(w)) {
|
|
44
|
+
if (k in this.where) {
|
|
45
|
+
// Found conflicting keys, create an `and` operator to join the existing
|
|
46
|
+
// conditions with the new one
|
|
47
|
+
const where = { and: [this.where, w] };
|
|
48
|
+
this.where = where;
|
|
49
|
+
return this;
|
|
50
|
+
}
|
|
51
|
+
}
|
|
52
|
+
// Merge the where items
|
|
53
|
+
this.where = Object.assign(this.where, w);
|
|
54
|
+
return this;
|
|
55
|
+
}
|
|
56
|
+
/**
|
|
57
|
+
* @deprecated
|
|
58
|
+
* Starting from TypeScript 3.2, we don't have to cast any more. This method
|
|
59
|
+
* should be considered as `deprecated`.
|
|
60
|
+
*
|
|
61
|
+
* Cast an `and`, `or`, or condition clause to Where
|
|
62
|
+
* @param clause - And/Or/Condition clause
|
|
63
|
+
*/
|
|
64
|
+
cast(clause) {
|
|
65
|
+
return clause;
|
|
66
|
+
}
|
|
67
|
+
/**
|
|
68
|
+
* Add an `and` clause.
|
|
69
|
+
* @param w - One or more where objects
|
|
70
|
+
*/
|
|
71
|
+
and(...w) {
|
|
72
|
+
let clauses = [];
|
|
73
|
+
w.forEach(where => {
|
|
74
|
+
clauses = clauses.concat(Array.isArray(where) ? where : [where]);
|
|
75
|
+
});
|
|
76
|
+
return this.add({ and: clauses });
|
|
77
|
+
}
|
|
78
|
+
/**
|
|
79
|
+
* Add an `or` clause.
|
|
80
|
+
* @param w - One or more where objects
|
|
81
|
+
*/
|
|
82
|
+
or(...w) {
|
|
83
|
+
let clauses = [];
|
|
84
|
+
w.forEach(where => {
|
|
85
|
+
clauses = clauses.concat(Array.isArray(where) ? where : [where]);
|
|
86
|
+
});
|
|
87
|
+
return this.add({ or: clauses });
|
|
88
|
+
}
|
|
89
|
+
/**
|
|
90
|
+
* Add an `=` condition
|
|
91
|
+
* @param key - Property name
|
|
92
|
+
* @param val - Property value
|
|
93
|
+
*/
|
|
94
|
+
eq(key, val) {
|
|
95
|
+
const w = {};
|
|
96
|
+
w[key] = val;
|
|
97
|
+
return this.add(w);
|
|
98
|
+
}
|
|
99
|
+
/**
|
|
100
|
+
* Add a `!=` condition
|
|
101
|
+
* @param key - Property name
|
|
102
|
+
* @param val - Property value
|
|
103
|
+
*/
|
|
104
|
+
neq(key, val) {
|
|
105
|
+
const w = {};
|
|
106
|
+
w[key] = { neq: val };
|
|
107
|
+
return this.add(w);
|
|
108
|
+
}
|
|
109
|
+
/**
|
|
110
|
+
* Add a `>` condition
|
|
111
|
+
* @param key - Property name
|
|
112
|
+
* @param val - Property value
|
|
113
|
+
*/
|
|
114
|
+
gt(key, val) {
|
|
115
|
+
const w = {};
|
|
116
|
+
w[key] = { gt: val };
|
|
117
|
+
return this.add(w);
|
|
118
|
+
}
|
|
119
|
+
/**
|
|
120
|
+
* Add a `>=` condition
|
|
121
|
+
* @param key - Property name
|
|
122
|
+
* @param val - Property value
|
|
123
|
+
*/
|
|
124
|
+
gte(key, val) {
|
|
125
|
+
const w = {};
|
|
126
|
+
w[key] = { gte: val };
|
|
127
|
+
return this.add(w);
|
|
128
|
+
}
|
|
129
|
+
/**
|
|
130
|
+
* Add a `<` condition
|
|
131
|
+
* @param key - Property name
|
|
132
|
+
* @param val - Property value
|
|
133
|
+
*/
|
|
134
|
+
lt(key, val) {
|
|
135
|
+
const w = {};
|
|
136
|
+
w[key] = { lt: val };
|
|
137
|
+
return this.add(w);
|
|
138
|
+
}
|
|
139
|
+
/**
|
|
140
|
+
* Add a `<=` condition
|
|
141
|
+
* @param key - Property name
|
|
142
|
+
* @param val - Property value
|
|
143
|
+
*/
|
|
144
|
+
lte(key, val) {
|
|
145
|
+
const w = {};
|
|
146
|
+
w[key] = { lte: val };
|
|
147
|
+
return this.add(w);
|
|
148
|
+
}
|
|
149
|
+
/**
|
|
150
|
+
* Add a `inq` condition
|
|
151
|
+
* @param key - Property name
|
|
152
|
+
* @param val - An array of property values
|
|
153
|
+
*/
|
|
154
|
+
inq(key, val) {
|
|
155
|
+
const w = {};
|
|
156
|
+
w[key] = { inq: val };
|
|
157
|
+
return this.add(w);
|
|
158
|
+
}
|
|
159
|
+
/**
|
|
160
|
+
* Add a `nin` condition
|
|
161
|
+
* @param key - Property name
|
|
162
|
+
* @param val - An array of property values
|
|
163
|
+
*/
|
|
164
|
+
nin(key, val) {
|
|
165
|
+
const w = {};
|
|
166
|
+
w[key] = { nin: val };
|
|
167
|
+
return this.add(w);
|
|
168
|
+
}
|
|
169
|
+
/**
|
|
170
|
+
* Add a `between` condition
|
|
171
|
+
* @param key - Property name
|
|
172
|
+
* @param val1 - Property value lower bound
|
|
173
|
+
* @param val2 - Property value upper bound
|
|
174
|
+
*/
|
|
175
|
+
between(key, val1, val2) {
|
|
176
|
+
const w = {};
|
|
177
|
+
w[key] = { between: [val1, val2] };
|
|
178
|
+
return this.add(w);
|
|
179
|
+
}
|
|
180
|
+
/**
|
|
181
|
+
* Add a `exists` condition
|
|
182
|
+
* @param key - Property name
|
|
183
|
+
* @param val - Exists or not
|
|
184
|
+
*/
|
|
185
|
+
exists(key, val) {
|
|
186
|
+
const w = {};
|
|
187
|
+
w[key] = { exists: !!val || val == null };
|
|
188
|
+
return this.add(w);
|
|
189
|
+
}
|
|
190
|
+
/**
|
|
191
|
+
* Add a where object. For conflicting keys with the existing where object,
|
|
192
|
+
* create an `and` clause.
|
|
193
|
+
* @param where - Where filter
|
|
194
|
+
*/
|
|
195
|
+
impose(where) {
|
|
196
|
+
if (!this.where) {
|
|
197
|
+
this.where = where || {};
|
|
198
|
+
}
|
|
199
|
+
else {
|
|
200
|
+
this.add(where);
|
|
201
|
+
}
|
|
202
|
+
return this;
|
|
203
|
+
}
|
|
204
|
+
/**
|
|
205
|
+
* Add a `like` condition
|
|
206
|
+
* @param key - Property name
|
|
207
|
+
* @param val - Regexp condition
|
|
208
|
+
*/
|
|
209
|
+
like(key, val) {
|
|
210
|
+
const w = {};
|
|
211
|
+
w[key] = { like: val };
|
|
212
|
+
return this.add(w);
|
|
213
|
+
}
|
|
214
|
+
/**
|
|
215
|
+
* Add a `nlike` condition
|
|
216
|
+
* @param key - Property name
|
|
217
|
+
* @param val - Regexp condition
|
|
218
|
+
*/
|
|
219
|
+
nlike(key, val) {
|
|
220
|
+
const w = {};
|
|
221
|
+
w[key] = { nlike: val };
|
|
222
|
+
return this.add(w);
|
|
223
|
+
}
|
|
224
|
+
/**
|
|
225
|
+
* Add a `ilike` condition
|
|
226
|
+
* @param key - Property name
|
|
227
|
+
* @param val - Regexp condition
|
|
228
|
+
*/
|
|
229
|
+
ilike(key, val) {
|
|
230
|
+
const w = {};
|
|
231
|
+
w[key] = { ilike: val };
|
|
232
|
+
return this.add(w);
|
|
233
|
+
}
|
|
234
|
+
/**
|
|
235
|
+
* Add a `nilike` condition
|
|
236
|
+
* @param key - Property name
|
|
237
|
+
* @param val - Regexp condition
|
|
238
|
+
*/
|
|
239
|
+
nilike(key, val) {
|
|
240
|
+
const w = {};
|
|
241
|
+
w[key] = { nilike: val };
|
|
242
|
+
return this.add(w);
|
|
243
|
+
}
|
|
244
|
+
/**
|
|
245
|
+
* Add a `regexp` condition
|
|
246
|
+
* @param key - Property name
|
|
247
|
+
* @param val - Regexp condition
|
|
248
|
+
*/
|
|
249
|
+
regexp(key, val) {
|
|
250
|
+
const w = {};
|
|
251
|
+
w[key] = { regexp: val };
|
|
252
|
+
return this.add(w);
|
|
253
|
+
}
|
|
254
|
+
/**
|
|
255
|
+
* Get the where object
|
|
256
|
+
*/
|
|
257
|
+
build() {
|
|
258
|
+
return this.where;
|
|
259
|
+
}
|
|
260
|
+
}
|
|
261
|
+
exports.WhereBuilder = WhereBuilder;
|
|
262
|
+
/**
|
|
263
|
+
* A builder for Filter. It provides fleunt APIs to add clauses such as
|
|
264
|
+
* `fields`, `order`, `where`, `limit`, `offset`, and `include`.
|
|
265
|
+
*
|
|
266
|
+
* @example
|
|
267
|
+
* ```ts
|
|
268
|
+
* const filterBuilder = new FilterBuilder();
|
|
269
|
+
* const filter = filterBuilder
|
|
270
|
+
* .fields('id', 'a', 'b')
|
|
271
|
+
* .limit(10)
|
|
272
|
+
* .offset(0)
|
|
273
|
+
* .order(['a ASC', 'b DESC'])
|
|
274
|
+
* .where({id: 1})
|
|
275
|
+
* .build();
|
|
276
|
+
* ```
|
|
277
|
+
*/
|
|
278
|
+
class FilterBuilder {
|
|
279
|
+
constructor(f) {
|
|
280
|
+
this.filter = f ?? {};
|
|
281
|
+
}
|
|
282
|
+
/**
|
|
283
|
+
* Set `limit`
|
|
284
|
+
* @param limit - Maximum number of records to be returned
|
|
285
|
+
*/
|
|
286
|
+
limit(limit) {
|
|
287
|
+
if (!(limit >= 1)) {
|
|
288
|
+
throw new Error(`Limit ${limit} must a positive number`);
|
|
289
|
+
}
|
|
290
|
+
this.filter.limit = limit;
|
|
291
|
+
return this;
|
|
292
|
+
}
|
|
293
|
+
/**
|
|
294
|
+
* Set `offset`
|
|
295
|
+
* @param offset - Offset of the number of records to be returned
|
|
296
|
+
*/
|
|
297
|
+
offset(offset) {
|
|
298
|
+
this.filter.offset = offset;
|
|
299
|
+
return this;
|
|
300
|
+
}
|
|
301
|
+
/**
|
|
302
|
+
* Alias to `offset`
|
|
303
|
+
* @param skip
|
|
304
|
+
*/
|
|
305
|
+
skip(skip) {
|
|
306
|
+
return this.offset(skip);
|
|
307
|
+
}
|
|
308
|
+
/**
|
|
309
|
+
* Describe what fields to be included/excluded
|
|
310
|
+
* @param f - A field name to be included, an array of field names to be
|
|
311
|
+
* included, or an Fields object for the inclusion/exclusion
|
|
312
|
+
*/
|
|
313
|
+
fields(...f) {
|
|
314
|
+
if (!this.filter.fields) {
|
|
315
|
+
this.filter.fields = {};
|
|
316
|
+
}
|
|
317
|
+
else if (Array.isArray(this.filter.fields)) {
|
|
318
|
+
this.filter.fields = this.filter.fields.reduce((prev, current) => ({ ...prev, [current]: true }), {});
|
|
319
|
+
}
|
|
320
|
+
const { fields } = this.filter;
|
|
321
|
+
for (const field of f) {
|
|
322
|
+
if (Array.isArray(field)) {
|
|
323
|
+
field.forEach(i => (fields[i] = true));
|
|
324
|
+
}
|
|
325
|
+
else if (typeof field === 'string') {
|
|
326
|
+
fields[field] = true;
|
|
327
|
+
}
|
|
328
|
+
else {
|
|
329
|
+
Object.assign(fields, field);
|
|
330
|
+
}
|
|
331
|
+
}
|
|
332
|
+
return this;
|
|
333
|
+
}
|
|
334
|
+
validateOrder(order) {
|
|
335
|
+
if (!(order.match(/^[^\s]+( (ASC|DESC))?$/))) {
|
|
336
|
+
throw new Error(`Invalid order: ${order}`);
|
|
337
|
+
}
|
|
338
|
+
}
|
|
339
|
+
/**
|
|
340
|
+
* Describe the sorting order
|
|
341
|
+
* @param o - A field name with optional direction, an array of field names,
|
|
342
|
+
* or an Order object for the field/direction pairs
|
|
343
|
+
*/
|
|
344
|
+
order(...o) {
|
|
345
|
+
if (!this.filter.order) {
|
|
346
|
+
this.filter.order = [];
|
|
347
|
+
}
|
|
348
|
+
o.forEach(order => {
|
|
349
|
+
if (typeof order === 'string') {
|
|
350
|
+
this.validateOrder(order);
|
|
351
|
+
if (!order.endsWith(' ASC') && !order.endsWith(' DESC')) {
|
|
352
|
+
order += ' ASC';
|
|
353
|
+
}
|
|
354
|
+
this.filter.order.push(order);
|
|
355
|
+
return this;
|
|
356
|
+
}
|
|
357
|
+
if (Array.isArray(order)) {
|
|
358
|
+
order.forEach(this.validateOrder);
|
|
359
|
+
order = order.map(i => {
|
|
360
|
+
if (!i.endsWith(' ASC') && !i.endsWith(' DESC')) {
|
|
361
|
+
i += ' ASC';
|
|
362
|
+
}
|
|
363
|
+
return i;
|
|
364
|
+
});
|
|
365
|
+
this.filter.order = this.filter.order.concat(order);
|
|
366
|
+
return this;
|
|
367
|
+
}
|
|
368
|
+
// tslint:disable-next-line: forin
|
|
369
|
+
for (const i in order) {
|
|
370
|
+
this.filter.order.push(`${i} ${order[i]}`);
|
|
371
|
+
}
|
|
372
|
+
});
|
|
373
|
+
return this;
|
|
374
|
+
}
|
|
375
|
+
/**
|
|
376
|
+
* Declare `include`
|
|
377
|
+
* @param i - A relation name, an array of relation names, or an `Inclusion`
|
|
378
|
+
* object for the relation/scope definitions
|
|
379
|
+
*/
|
|
380
|
+
include(...i) {
|
|
381
|
+
if (this.filter.include == null) {
|
|
382
|
+
this.filter.include = [];
|
|
383
|
+
}
|
|
384
|
+
for (const include of i) {
|
|
385
|
+
if (typeof include === 'string') {
|
|
386
|
+
this.filter.include.push({ relation: include });
|
|
387
|
+
}
|
|
388
|
+
else if (Array.isArray(include)) {
|
|
389
|
+
for (const inc of include)
|
|
390
|
+
this.filter.include.push({ relation: inc });
|
|
391
|
+
}
|
|
392
|
+
else {
|
|
393
|
+
this.filter.include.push(include);
|
|
394
|
+
}
|
|
395
|
+
}
|
|
396
|
+
return this;
|
|
397
|
+
}
|
|
398
|
+
/**
|
|
399
|
+
* Declare a where clause
|
|
400
|
+
* @param w - Where object
|
|
401
|
+
*/
|
|
402
|
+
where(w) {
|
|
403
|
+
this.filter.where = w;
|
|
404
|
+
return this;
|
|
405
|
+
}
|
|
406
|
+
/**
|
|
407
|
+
* Add a Filter or Where constraint object. If it is a filter object, create
|
|
408
|
+
* an `and` clause for conflicting keys with its where object. For any other
|
|
409
|
+
* properties, throw an error. If it's not a Filter, coerce it to a filter,
|
|
410
|
+
* and carry out the same logic.
|
|
411
|
+
*
|
|
412
|
+
* @param constraint - a constraint object to merge with own filter object
|
|
413
|
+
*/
|
|
414
|
+
impose(constraint) {
|
|
415
|
+
if (!this.filter) {
|
|
416
|
+
// if constraint is a Where, turn into a Filter
|
|
417
|
+
if (!isFilter(constraint)) {
|
|
418
|
+
constraint = { where: constraint };
|
|
419
|
+
}
|
|
420
|
+
this.filter = constraint || {};
|
|
421
|
+
}
|
|
422
|
+
else {
|
|
423
|
+
if (isFilter(constraint)) {
|
|
424
|
+
// throw error if imposed Filter has non-where fields
|
|
425
|
+
for (const key of Object.keys(constraint)) {
|
|
426
|
+
if (nonWhereFields.includes(key)) {
|
|
427
|
+
throw new Error('merging strategy for selection, pagination, and sorting not implemented');
|
|
428
|
+
}
|
|
429
|
+
}
|
|
430
|
+
}
|
|
431
|
+
this.filter.where = isFilter(constraint)
|
|
432
|
+
? new WhereBuilder(this.filter.where).impose(constraint.where).build()
|
|
433
|
+
: new WhereBuilder(this.filter.where).impose(constraint).build();
|
|
434
|
+
}
|
|
435
|
+
return this;
|
|
436
|
+
}
|
|
437
|
+
/**
|
|
438
|
+
* Return the filter object
|
|
439
|
+
*/
|
|
440
|
+
build() {
|
|
441
|
+
return this.filter;
|
|
442
|
+
}
|
|
443
|
+
}
|
|
444
|
+
exports.FilterBuilder = FilterBuilder;
|
|
445
|
+
/**
|
|
446
|
+
* Get nested properties by path
|
|
447
|
+
* @param value - Value of an object
|
|
448
|
+
* @param path - Path to the property
|
|
449
|
+
*/
|
|
450
|
+
function getDeepProperty(value, path) {
|
|
451
|
+
const props = path.split('.');
|
|
452
|
+
for (const p of props) {
|
|
453
|
+
value = value[p];
|
|
454
|
+
if (value == null) {
|
|
455
|
+
return null;
|
|
456
|
+
}
|
|
457
|
+
}
|
|
458
|
+
return value;
|
|
459
|
+
}
|
|
460
|
+
function filterTemplate(strings, ...keys) {
|
|
461
|
+
return function filter(ctx) {
|
|
462
|
+
const tokens = [strings[0]];
|
|
463
|
+
keys.forEach((key, i) => {
|
|
464
|
+
if (typeof key === 'object' ||
|
|
465
|
+
typeof key === 'boolean' ||
|
|
466
|
+
typeof key === 'number') {
|
|
467
|
+
tokens.push(JSON.stringify(key), strings[i + 1]);
|
|
468
|
+
return;
|
|
469
|
+
}
|
|
470
|
+
const value = getDeepProperty(ctx, key);
|
|
471
|
+
tokens.push(JSON.stringify(value), strings[i + 1]);
|
|
472
|
+
});
|
|
473
|
+
const result = tokens.join('');
|
|
474
|
+
try {
|
|
475
|
+
return JSON.parse(result);
|
|
476
|
+
}
|
|
477
|
+
catch (e) {
|
|
478
|
+
throw new Error(`Invalid JSON: ${result}`);
|
|
479
|
+
}
|
|
480
|
+
};
|
|
481
|
+
}
|
|
482
|
+
//# sourceMappingURL=query.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"query.js","sourceRoot":"","sources":["../../../src/core/Loopback/query.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,141 @@
|
|
|
1
|
+
import { InclusionFilter } from './query';
|
|
2
|
+
import { Options } from './common-types';
|
|
3
|
+
import { Entity } from './model';
|
|
4
|
+
import { TypeResolver } from './type-resolver';
|
|
5
|
+
export declare enum RelationType {
|
|
6
|
+
belongsTo = "belongsTo",
|
|
7
|
+
hasOne = "hasOne",
|
|
8
|
+
hasMany = "hasMany",
|
|
9
|
+
embedsOne = "embedsOne",
|
|
10
|
+
embedsMany = "embedsMany",
|
|
11
|
+
referencesOne = "referencesOne",
|
|
12
|
+
referencesMany = "referencesMany"
|
|
13
|
+
}
|
|
14
|
+
export interface RelationDefinitionBase {
|
|
15
|
+
/**
|
|
16
|
+
* The type of the relation, must be one of RelationType values.
|
|
17
|
+
*/
|
|
18
|
+
type: RelationType;
|
|
19
|
+
/**
|
|
20
|
+
* True for relations targeting multiple instances (e.g. HasMany),
|
|
21
|
+
* false for relations with a single target (e.g. BelongsTo, HasOne).
|
|
22
|
+
* This property is needed by OpenAPI/JSON Schema generator.
|
|
23
|
+
*/
|
|
24
|
+
targetsMany: boolean;
|
|
25
|
+
/**
|
|
26
|
+
* The relation name, typically matching the name of the accessor property
|
|
27
|
+
* defined on the source model. For example "orders" or "customer".
|
|
28
|
+
*/
|
|
29
|
+
name: string;
|
|
30
|
+
/**
|
|
31
|
+
* The source model of this relation.
|
|
32
|
+
*
|
|
33
|
+
* E.g. when a Customer has many Order instances, then Customer is the source.
|
|
34
|
+
*/
|
|
35
|
+
source: typeof Entity;
|
|
36
|
+
/**
|
|
37
|
+
* The target model of this relation.
|
|
38
|
+
*
|
|
39
|
+
* E.g. when a Customer has many Order instances, then Order is the target.
|
|
40
|
+
*/
|
|
41
|
+
target: TypeResolver<Entity, typeof Entity>;
|
|
42
|
+
}
|
|
43
|
+
/**
|
|
44
|
+
* HasManyDefinition defines one-to-many relations and also possible defines
|
|
45
|
+
* many-to-many relations with through models.
|
|
46
|
+
*/
|
|
47
|
+
export interface HasManyDefinition extends RelationDefinitionBase {
|
|
48
|
+
type: RelationType.hasMany;
|
|
49
|
+
targetsMany: true;
|
|
50
|
+
/**
|
|
51
|
+
* keyTo: The foreign key used by the target model for this relation.
|
|
52
|
+
* keyFrom: The source key used by the source model for this relation.
|
|
53
|
+
*
|
|
54
|
+
* E.g. when a Customer has many Order instances, then keyTo is "customerId".
|
|
55
|
+
* Note that "customerId" is the default FK assumed by the framework, users
|
|
56
|
+
* can provide a custom FK name by setting "keyTo".
|
|
57
|
+
* And Customer.id is keyFrom. keyFrom defaults to the id property of a model.
|
|
58
|
+
* Users can provide a custom source key name by setting "keyTo".
|
|
59
|
+
*
|
|
60
|
+
*/
|
|
61
|
+
keyTo?: string;
|
|
62
|
+
keyFrom?: string;
|
|
63
|
+
/**
|
|
64
|
+
* Description of the through model of the hasManyThrough relation.
|
|
65
|
+
*
|
|
66
|
+
* A `hasManyThrough` relation defines a many-to-many connection with another model.
|
|
67
|
+
* This relation indicates that the declaring model can be matched with zero or more
|
|
68
|
+
* instances of another model by proceeding through a third model.
|
|
69
|
+
*
|
|
70
|
+
* E.g a Category has many Products, and a Product can have many Categories.
|
|
71
|
+
* CategoryProductLink can be the through model.
|
|
72
|
+
* Such a through model has information of foreign keys of the source model(Category) and the target model(Product).
|
|
73
|
+
*
|
|
74
|
+
* Warning: The hasManyThrough interface is experimental and is subject to change.
|
|
75
|
+
* If backwards-incompatible changes are made, a new major version may not be
|
|
76
|
+
* released.
|
|
77
|
+
*/
|
|
78
|
+
through?: {
|
|
79
|
+
/**
|
|
80
|
+
* The through model of this relation.
|
|
81
|
+
*
|
|
82
|
+
* E.g. when a Category has many CategoryProductLink instances and a Product has many CategoryProductLink instances,
|
|
83
|
+
* then CategoryProductLink is through.
|
|
84
|
+
*/
|
|
85
|
+
model: TypeResolver<Entity, typeof Entity>;
|
|
86
|
+
/**
|
|
87
|
+
* The foreign key of the source model defined in the through model, e.g. CategoryProductLink#categoryId
|
|
88
|
+
*/
|
|
89
|
+
keyFrom?: string;
|
|
90
|
+
/**
|
|
91
|
+
* The foreign key of the target model defined in the through model, e.g. CategoryProductLink#productId
|
|
92
|
+
*/
|
|
93
|
+
keyTo?: string;
|
|
94
|
+
};
|
|
95
|
+
}
|
|
96
|
+
export interface BelongsToDefinition extends RelationDefinitionBase {
|
|
97
|
+
type: RelationType.belongsTo;
|
|
98
|
+
targetsMany: false;
|
|
99
|
+
keyFrom?: string;
|
|
100
|
+
keyTo?: string;
|
|
101
|
+
}
|
|
102
|
+
export interface HasOneDefinition extends RelationDefinitionBase {
|
|
103
|
+
type: RelationType.hasOne;
|
|
104
|
+
targetsMany: false;
|
|
105
|
+
/**
|
|
106
|
+
* keyTo: The foreign key used by the target model for this relation.
|
|
107
|
+
* keyFrom: The source key used by the source model for this relation.
|
|
108
|
+
*
|
|
109
|
+
* E.g. when a Customer has one Address instance, then keyTo is "customerId".
|
|
110
|
+
* Note that "customerId" is the default FK assumed by the framework, users
|
|
111
|
+
* can provide a custom FK name by setting "keyTo".
|
|
112
|
+
* And Customer.id is keyFrom. keyFrom defaults to the id property of a model.
|
|
113
|
+
* Users can provide a custom source key name by setting "keyTo".
|
|
114
|
+
*/
|
|
115
|
+
keyTo?: string;
|
|
116
|
+
keyFrom?: string;
|
|
117
|
+
}
|
|
118
|
+
/**
|
|
119
|
+
* A union type describing all possible Relation metadata objects.
|
|
120
|
+
*/
|
|
121
|
+
export type RelationMetadata = HasManyDefinition | BelongsToDefinition | HasOneDefinition | RelationDefinitionBase;
|
|
122
|
+
/**
|
|
123
|
+
* @returns An array of resolved values, the items must be ordered in the same
|
|
124
|
+
* way as `sourceEntities`. The resolved value can be one of:
|
|
125
|
+
* - `undefined` when no target model(s) were found
|
|
126
|
+
* - `Entity` for relations targeting a single model
|
|
127
|
+
* - `Entity[]` for relations targeting multiple models
|
|
128
|
+
*/
|
|
129
|
+
export type InclusionResolver<S extends Entity, T extends Entity> = (
|
|
130
|
+
/**
|
|
131
|
+
* List of source models as returned by the first database query.
|
|
132
|
+
*/
|
|
133
|
+
sourceEntities: S[],
|
|
134
|
+
/**
|
|
135
|
+
* Inclusion requested by the user (e.g. scope constraints to apply).
|
|
136
|
+
*/
|
|
137
|
+
inclusion: InclusionFilter,
|
|
138
|
+
/**
|
|
139
|
+
* Generic options object, e.g. carrying the Transaction object.
|
|
140
|
+
*/
|
|
141
|
+
options?: Options) => Promise<(T | undefined)[] | (T[] | undefined)[]>;
|
|
@@ -0,0 +1,18 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
// Copyright IBM Corp. 2018,2020. All Rights Reserved.
|
|
3
|
+
// Node module: @loopback/repository
|
|
4
|
+
// This file is licensed under the MIT License.
|
|
5
|
+
// License text available at https://opensource.org/licenses/MIT
|
|
6
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
7
|
+
exports.RelationType = void 0;
|
|
8
|
+
var RelationType;
|
|
9
|
+
(function (RelationType) {
|
|
10
|
+
RelationType["belongsTo"] = "belongsTo";
|
|
11
|
+
RelationType["hasOne"] = "hasOne";
|
|
12
|
+
RelationType["hasMany"] = "hasMany";
|
|
13
|
+
RelationType["embedsOne"] = "embedsOne";
|
|
14
|
+
RelationType["embedsMany"] = "embedsMany";
|
|
15
|
+
RelationType["referencesOne"] = "referencesOne";
|
|
16
|
+
RelationType["referencesMany"] = "referencesMany";
|
|
17
|
+
})(RelationType || (exports.RelationType = RelationType = {}));
|
|
18
|
+
//# sourceMappingURL=relation.types.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"relation.types.js","sourceRoot":"","sources":["../../../src/core/Loopback/relation.types.ts"],"names":[],"mappings":";AAAA,sDAAsD;AACtD,oCAAoC;AACpC,+CAA+C;AAC/C,gEAAgE;;;AAOhE,IAAY,YAQX;AARD,WAAY,YAAY;IACtB,uCAAuB,CAAA;IACvB,iCAAiB,CAAA;IACjB,mCAAmB,CAAA;IACnB,uCAAuB,CAAA;IACvB,yCAAyB,CAAA;IACzB,+CAA+B,CAAA;IAC/B,iDAAiC,CAAA;AACnC,CAAC,EARW,YAAY,4BAAZ,YAAY,QAQvB"}
|