@mondomob/gae-node-nestjs 11.0.2 → 12.0.0-alpha-2
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/.claude/settings.local.json +7 -0
- package/CHANGELOG.md +0 -13
- package/mondomob-gae-node-nestjs-12.0.0-alpha-1.tgz +0 -0
- package/mondomob-gae-node-nestjs-12.0.0-alpha-2.tgz +0 -0
- package/package.json +12 -12
- package/server-start.js +72 -1
- package/dist/_test/mocks.d.ts +0 -9
- package/dist/_test/mocks.js +0 -27
- package/dist/_test/mocks.js.map +0 -1
- package/dist/_test/request-scope-test-utils.d.ts +0 -3
- package/dist/_test/request-scope-test-utils.js +0 -18
- package/dist/_test/request-scope-test-utils.js.map +0 -1
- package/dist/auth/auth-user.model.d.ts +0 -9
- package/dist/auth/auth-user.model.js +0 -33
- package/dist/auth/auth-user.model.js.map +0 -1
- package/dist/auth/auth.callbacks.d.ts +0 -8
- package/dist/auth/auth.callbacks.js +0 -5
- package/dist/auth/auth.callbacks.js.map +0 -1
- package/dist/auth/auth.configurer.d.ts +0 -35
- package/dist/auth/auth.configurer.js +0 -212
- package/dist/auth/auth.configurer.js.map +0 -1
- package/dist/auth/auth.controller.d.ts +0 -27
- package/dist/auth/auth.controller.js +0 -312
- package/dist/auth/auth.controller.js.map +0 -1
- package/dist/auth/auth.guard.d.ts +0 -16
- package/dist/auth/auth.guard.js +0 -127
- package/dist/auth/auth.guard.js.map +0 -1
- package/dist/auth/auth.listener.d.ts +0 -5
- package/dist/auth/auth.listener.js +0 -5
- package/dist/auth/auth.listener.js.map +0 -1
- package/dist/auth/auth.repository.d.ts +0 -52
- package/dist/auth/auth.repository.js +0 -79
- package/dist/auth/auth.repository.js.map +0 -1
- package/dist/auth/auth.resolver.d.ts +0 -13
- package/dist/auth/auth.resolver.js +0 -86
- package/dist/auth/auth.resolver.js.map +0 -1
- package/dist/auth/auth.service.d.ts +0 -35
- package/dist/auth/auth.service.js +0 -299
- package/dist/auth/auth.service.js.map +0 -1
- package/dist/auth/auth.task.controller.d.ts +0 -13
- package/dist/auth/auth.task.controller.js +0 -76
- package/dist/auth/auth.task.controller.js.map +0 -1
- package/dist/auth/auth.task.service.d.ts +0 -8
- package/dist/auth/auth.task.service.js +0 -26
- package/dist/auth/auth.task.service.js.map +0 -1
- package/dist/auth/csrf.interceptor.d.ts +0 -11
- package/dist/auth/csrf.interceptor.js +0 -38
- package/dist/auth/csrf.interceptor.js.map +0 -1
- package/dist/auth/invite-user.service.d.ts +0 -45
- package/dist/auth/invite-user.service.js +0 -215
- package/dist/auth/invite-user.service.js.map +0 -1
- package/dist/auth/invite.callbacks.d.ts +0 -6
- package/dist/auth/invite.callbacks.js +0 -5
- package/dist/auth/invite.callbacks.js.map +0 -1
- package/dist/auth/login-identifier.repository.d.ts +0 -13
- package/dist/auth/login-identifier.repository.js +0 -28
- package/dist/auth/login-identifier.repository.js.map +0 -1
- package/dist/auth/password-reset.service.d.ts +0 -15
- package/dist/auth/password-reset.service.js +0 -81
- package/dist/auth/password-reset.service.js.map +0 -1
- package/dist/auth/user.service.d.ts +0 -27
- package/dist/auth/user.service.js +0 -94
- package/dist/auth/user.service.js.map +0 -1
- package/dist/configuration.d.ts +0 -84
- package/dist/configuration.js +0 -5
- package/dist/configuration.js.map +0 -1
- package/dist/configure.d.ts +0 -40
- package/dist/configure.js +0 -85
- package/dist/configure.js.map +0 -1
- package/dist/context/context-middleware.d.ts +0 -15
- package/dist/context/context-middleware.js +0 -37
- package/dist/context/context-middleware.js.map +0 -1
- package/dist/context/context-request-scope.d.ts +0 -8
- package/dist/context/context-request-scope.js +0 -29
- package/dist/context/context-request-scope.js.map +0 -1
- package/dist/context/index.d.ts +0 -2
- package/dist/context/index.js +0 -9
- package/dist/context/index.js.map +0 -1
- package/dist/datastore/context.d.ts +0 -36
- package/dist/datastore/context.js +0 -27
- package/dist/datastore/context.js.map +0 -1
- package/dist/datastore/datastore.provider.d.ts +0 -8
- package/dist/datastore/datastore.provider.js +0 -30
- package/dist/datastore/datastore.provider.js.map +0 -1
- package/dist/datastore/filters.d.ts +0 -19
- package/dist/datastore/filters.js +0 -27
- package/dist/datastore/filters.js.map +0 -1
- package/dist/datastore/loader.d.ts +0 -50
- package/dist/datastore/loader.js +0 -147
- package/dist/datastore/loader.js.map +0 -1
- package/dist/datastore/node-datastore-session.d.ts +0 -17
- package/dist/datastore/node-datastore-session.js +0 -87
- package/dist/datastore/node-datastore-session.js.map +0 -1
- package/dist/datastore/repository.d.ts +0 -45
- package/dist/datastore/repository.js +0 -150
- package/dist/datastore/repository.js.map +0 -1
- package/dist/datastore/transactional.d.ts +0 -4
- package/dist/datastore/transactional.js +0 -13
- package/dist/datastore/transactional.js.map +0 -1
- package/dist/error/NonFatalError.d.ts +0 -3
- package/dist/error/NonFatalError.js +0 -11
- package/dist/error/NonFatalError.js.map +0 -1
- package/dist/filter.d.ts +0 -5
- package/dist/filter.js +0 -40
- package/dist/filter.js.map +0 -1
- package/dist/gcloud/logging.d.ts +0 -1
- package/dist/gcloud/logging.js +0 -5
- package/dist/gcloud/logging.js.map +0 -1
- package/dist/gcloud/storage.provider.d.ts +0 -12
- package/dist/gcloud/storage.provider.js +0 -41
- package/dist/gcloud/storage.provider.js.map +0 -1
- package/dist/gcloud/tasks.d.ts +0 -10
- package/dist/gcloud/tasks.js +0 -68
- package/dist/gcloud/tasks.js.map +0 -1
- package/dist/graphql/GraphQLMiddleware.d.ts +0 -0
- package/dist/graphql/GraphQLMiddleware.js +0 -2
- package/dist/graphql/GraphQLMiddleware.js.map +0 -1
- package/dist/index.d.ts +0 -28
- package/dist/index.js +0 -65
- package/dist/index.js.map +0 -1
- package/dist/logging/index.d.ts +0 -1
- package/dist/logging/index.js +0 -8
- package/dist/logging/index.js.map +0 -1
- package/dist/logging/logging-internal.d.ts +0 -2
- package/dist/logging/logging-internal.js +0 -20
- package/dist/logging/logging-internal.js.map +0 -1
- package/dist/logging/logging-request-scope.d.ts +0 -15
- package/dist/logging/logging-request-scope.js +0 -39
- package/dist/logging/logging-request-scope.js.map +0 -1
- package/dist/logging/logging.d.ts +0 -34
- package/dist/logging/logging.js +0 -55
- package/dist/logging/logging.js.map +0 -1
- package/dist/mail/gmail/gmail.configurer.d.ts +0 -15
- package/dist/mail/gmail/gmail.configurer.js +0 -59
- package/dist/mail/gmail/gmail.configurer.js.map +0 -1
- package/dist/mail/gmail/gmail.controller.d.ts +0 -9
- package/dist/mail/gmail/gmail.controller.js +0 -62
- package/dist/mail/gmail/gmail.controller.js.map +0 -1
- package/dist/mail/gmail/gmail.sender.d.ts +0 -12
- package/dist/mail/gmail/gmail.sender.js +0 -62
- package/dist/mail/gmail/gmail.sender.js.map +0 -1
- package/dist/mail/gmail/stored.credentials.repository.d.ts +0 -12
- package/dist/mail/gmail/stored.credentials.repository.js +0 -23
- package/dist/mail/gmail/stored.credentials.repository.js.map +0 -1
- package/dist/mail/mail-logging.sender.d.ts +0 -9
- package/dist/mail/mail-logging.sender.js +0 -42
- package/dist/mail/mail-logging.sender.js.map +0 -1
- package/dist/mail/mail-subject.sender.d.ts +0 -12
- package/dist/mail/mail-subject.sender.js +0 -33
- package/dist/mail/mail-subject.sender.js.map +0 -1
- package/dist/mail/mail-whitelist.sender.d.ts +0 -14
- package/dist/mail/mail-whitelist.sender.js +0 -59
- package/dist/mail/mail-whitelist.sender.js.map +0 -1
- package/dist/mail/mail.diverter.d.ts +0 -13
- package/dist/mail/mail.diverter.js +0 -65
- package/dist/mail/mail.diverter.js.map +0 -1
- package/dist/mail/mail.sender.d.ts +0 -6
- package/dist/mail/mail.sender.js +0 -5
- package/dist/mail/mail.sender.js.map +0 -1
- package/dist/mail/smtp/smtp.sender.d.ts +0 -10
- package/dist/mail/smtp/smtp.sender.js +0 -65
- package/dist/mail/smtp/smtp.sender.js.map +0 -1
- package/dist/mail-templates/base.d.ts +0 -2
- package/dist/mail-templates/base.js +0 -328
- package/dist/mail-templates/base.js.map +0 -1
- package/dist/mail-templates/invite.d.ts +0 -1
- package/dist/mail-templates/invite.js +0 -19
- package/dist/mail-templates/invite.js.map +0 -1
- package/dist/module.d.ts +0 -16
- package/dist/module.js +0 -136
- package/dist/module.js.map +0 -1
- package/dist/request-scope/index.d.ts +0 -2
- package/dist/request-scope/index.js +0 -9
- package/dist/request-scope/index.js.map +0 -1
- package/dist/request-scope/request-scope-interceptor.d.ts +0 -5
- package/dist/request-scope/request-scope-interceptor.js +0 -3
- package/dist/request-scope/request-scope-interceptor.js.map +0 -1
- package/dist/request-scope/request-scope.d.ts +0 -12
- package/dist/request-scope/request-scope.js +0 -79
- package/dist/request-scope/request-scope.js.map +0 -1
- package/dist/request-scope/request-scope.middleware.d.ts +0 -15
- package/dist/request-scope/request-scope.middleware.js +0 -53
- package/dist/request-scope/request-scope.middleware.js.map +0 -1
- package/dist/search/search.service.d.ts +0 -52
- package/dist/search/search.service.js +0 -90
- package/dist/search/search.service.js.map +0 -1
- package/dist/search/searchable.repository.d.ts +0 -36
- package/dist/search/searchable.repository.js +0 -95
- package/dist/search/searchable.repository.js.map +0 -1
- package/dist/types.d.ts +0 -3
- package/dist/types.js +0 -9
- package/dist/types.js.map +0 -1
- package/dist/util/arrays.d.ts +0 -1
- package/dist/util/arrays.js +0 -10
- package/dist/util/arrays.js.map +0 -1
- package/dist/util/guards.d.ts +0 -1
- package/dist/util/guards.js +0 -7
- package/dist/util/guards.js.map +0 -1
- package/dist/util/index.d.ts +0 -1
- package/dist/util/index.js +0 -5
- package/dist/util/index.js.map +0 -1
- package/dist/util/nestjs.d.ts +0 -9
- package/dist/util/nestjs.js +0 -9
- package/dist/util/nestjs.js.map +0 -1
- package/dist/util/types.d.ts +0 -4
- package/dist/util/types.js +0 -8
- package/dist/util/types.js.map +0 -1
- package/dist/validator.d.ts +0 -1
- package/dist/validator.js +0 -5
- package/dist/validator.js.map +0 -1
- package/mondomob-gae-node-nestjs-11.0.2-alpha.tgz +0 -0
- package/mondomob-gae-node-nestjs-11.0.2-alpha1.tgz +0 -0
|
@@ -1,53 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
var RequestScopeMiddleware_1;
|
|
3
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
4
|
-
exports.RequestScopeMiddleware = exports.REQUEST_SCOPE_INTERCEPTORS = exports._REQUEST_STORAGE_NAMESPACE_KEY = void 0;
|
|
5
|
-
const tslib_1 = require("tslib");
|
|
6
|
-
const cls_hooked_1 = require("cls-hooked");
|
|
7
|
-
const common_1 = require("@nestjs/common");
|
|
8
|
-
const logging_internal_1 = require("../logging/logging-internal");
|
|
9
|
-
const configuration_1 = require("../configuration");
|
|
10
|
-
exports._REQUEST_STORAGE_NAMESPACE_KEY = '_GAE_NODE_NESTJS_REQUEST_STORAGE';
|
|
11
|
-
exports.REQUEST_SCOPE_INTERCEPTORS = 'REQ_SCOPE_INTERCEPTORS';
|
|
12
|
-
let RequestScopeMiddleware = RequestScopeMiddleware_1 = class RequestScopeMiddleware {
|
|
13
|
-
constructor(configurationProvider, interceptors) {
|
|
14
|
-
var _a;
|
|
15
|
-
this.interceptors = interceptors;
|
|
16
|
-
RequestScopeMiddleware_1.enabled = !!((_a = configurationProvider.requestScope) === null || _a === void 0 ? void 0 : _a.enabled);
|
|
17
|
-
if (RequestScopeMiddleware_1.enabled) {
|
|
18
|
-
this.namespace = (0, cls_hooked_1.createNamespace)(exports._REQUEST_STORAGE_NAMESPACE_KEY);
|
|
19
|
-
const interceptorNames = interceptors.map(interceptor => ` - ${interceptor.name}`).join('\n');
|
|
20
|
-
logging_internal_1.defaultLogger.info(`RequestScopeMiddleware setup up with interceptors: \n${interceptorNames}`);
|
|
21
|
-
}
|
|
22
|
-
else {
|
|
23
|
-
logging_internal_1.defaultLogger.info('RequestScopeMiddleware disabled by config');
|
|
24
|
-
}
|
|
25
|
-
}
|
|
26
|
-
use(req, res, next) {
|
|
27
|
-
if (this.namespace) {
|
|
28
|
-
this.namespace.run(() => {
|
|
29
|
-
this.interceptors.forEach(interceptor => {
|
|
30
|
-
interceptor.intercept(req);
|
|
31
|
-
});
|
|
32
|
-
next();
|
|
33
|
-
});
|
|
34
|
-
}
|
|
35
|
-
else {
|
|
36
|
-
next();
|
|
37
|
-
}
|
|
38
|
-
}
|
|
39
|
-
static isEnabled() {
|
|
40
|
-
return RequestScopeMiddleware_1.enabled;
|
|
41
|
-
}
|
|
42
|
-
static isDisabled() {
|
|
43
|
-
return !RequestScopeMiddleware_1.isEnabled();
|
|
44
|
-
}
|
|
45
|
-
};
|
|
46
|
-
exports.RequestScopeMiddleware = RequestScopeMiddleware;
|
|
47
|
-
exports.RequestScopeMiddleware = RequestScopeMiddleware = RequestScopeMiddleware_1 = tslib_1.__decorate([
|
|
48
|
-
(0, common_1.Injectable)(),
|
|
49
|
-
tslib_1.__param(0, (0, common_1.Inject)(configuration_1.CONFIGURATION)),
|
|
50
|
-
tslib_1.__param(1, (0, common_1.Inject)(exports.REQUEST_SCOPE_INTERCEPTORS)),
|
|
51
|
-
tslib_1.__metadata("design:paramtypes", [Object, Array])
|
|
52
|
-
], RequestScopeMiddleware);
|
|
53
|
-
//# sourceMappingURL=request-scope.middleware.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"request-scope.middleware.js","sourceRoot":"","sources":["../../src/request-scope/request-scope.middleware.ts"],"names":[],"mappings":";;;;;AAAA,2CAAwD;AACxD,2CAAoE;AAGpE,kEAA4D;AAC5D,oDAAgE;AAEnD,QAAA,8BAA8B,GAAG,kCAAkC,CAAC;AACpE,QAAA,0BAA0B,GAAG,wBAAwB,CAAC;AAG5D,IAAM,sBAAsB,8BAA5B,MAAM,sBAAsB;IAIjC,YACyB,qBAAoC,EACN,YAAuC;;QAAvC,iBAAY,GAAZ,YAAY,CAA2B;QAG5F,wBAAsB,CAAC,OAAO,GAAG,CAAC,CAAC,CAAA,MAAA,qBAAqB,CAAC,YAAY,0CAAE,OAAO,CAAA,CAAC;QAC/E,IAAI,wBAAsB,CAAC,OAAO,EAAE,CAAC;YACnC,IAAI,CAAC,SAAS,GAAG,IAAA,4BAAe,EAAC,sCAA8B,CAAC,CAAC;YACjE,MAAM,gBAAgB,GAAG,YAAY,CAAC,GAAG,CAAC,WAAW,CAAC,EAAE,CAAC,QAAQ,WAAW,CAAC,IAAI,EAAE,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;YAChG,gCAAa,CAAC,IAAI,CAAC,wDAAwD,gBAAgB,EAAE,CAAC,CAAC;QACjG,CAAC;aAAM,CAAC;YACN,gCAAa,CAAC,IAAI,CAAC,2CAA2C,CAAC,CAAC;QAClE,CAAC;IACH,CAAC;IAED,GAAG,CAAC,GAAY,EAAE,GAAa,EAAE,IAAgB;QAC/C,IAAI,IAAI,CAAC,SAAS,EAAE,CAAC;YACnB,IAAI,CAAC,SAAS,CAAC,GAAG,CAAC,GAAG,EAAE;gBACtB,IAAI,CAAC,YAAY,CAAC,OAAO,CAAC,WAAW,CAAC,EAAE;oBACtC,WAAW,CAAC,SAAS,CAAC,GAAG,CAAC,CAAC;gBAC7B,CAAC,CAAC,CAAC;gBACH,IAAI,EAAE,CAAC;YACT,CAAC,CAAC,CAAC;QACL,CAAC;aAAM,CAAC;YACN,IAAI,EAAE,CAAC;QACT,CAAC;IACH,CAAC;IAED,MAAM,CAAC,SAAS;QACd,OAAO,wBAAsB,CAAC,OAAO,CAAC;IACxC,CAAC;IAED,MAAM,CAAC,UAAU;QACf,OAAO,CAAC,wBAAsB,CAAC,SAAS,EAAE,CAAC;IAC7C,CAAC;CACF,CAAA;AAvCY,wDAAsB;iCAAtB,sBAAsB;IADlC,IAAA,mBAAU,GAAE;IAMR,mBAAA,IAAA,eAAM,EAAC,6BAAa,CAAC,CAAA;IACrB,mBAAA,IAAA,eAAM,EAAC,kCAA0B,CAAC,CAAA;;GAN1B,sBAAsB,CAuClC"}
|
|
@@ -1,52 +0,0 @@
|
|
|
1
|
-
import fetch from 'node-fetch';
|
|
2
|
-
import { Configuration } from '../configuration';
|
|
3
|
-
interface IndexEntry {
|
|
4
|
-
id: string;
|
|
5
|
-
fields: {
|
|
6
|
-
[key: string]: object;
|
|
7
|
-
};
|
|
8
|
-
}
|
|
9
|
-
export interface Sort {
|
|
10
|
-
field: string;
|
|
11
|
-
descending?: boolean;
|
|
12
|
-
}
|
|
13
|
-
export interface Page {
|
|
14
|
-
limit: number;
|
|
15
|
-
offset: number;
|
|
16
|
-
}
|
|
17
|
-
export interface QueryResults {
|
|
18
|
-
resultCount: number;
|
|
19
|
-
limit: number;
|
|
20
|
-
offset: number;
|
|
21
|
-
ids: string[];
|
|
22
|
-
}
|
|
23
|
-
export interface SearchResults<T> {
|
|
24
|
-
resultCount: number;
|
|
25
|
-
limit: number;
|
|
26
|
-
offset: number;
|
|
27
|
-
results: ReadonlyArray<T> | undefined;
|
|
28
|
-
}
|
|
29
|
-
export declare type Operator = '=' | '!=' | '>' | '<' | '>=' | '<=';
|
|
30
|
-
export interface SearchFields {
|
|
31
|
-
[key: string]: string | string[] | Predicate | Predicate[];
|
|
32
|
-
}
|
|
33
|
-
export interface Predicate {
|
|
34
|
-
op: Operator;
|
|
35
|
-
value: string | string[] | number | Date;
|
|
36
|
-
}
|
|
37
|
-
export interface SearchPredicate extends Predicate {
|
|
38
|
-
field: string;
|
|
39
|
-
}
|
|
40
|
-
export declare class SearchService {
|
|
41
|
-
private readonly configuration;
|
|
42
|
-
private logger;
|
|
43
|
-
constructor(configuration: Configuration);
|
|
44
|
-
index(entityName: string, entries: IndexEntry[]): Promise<fetch.Response>;
|
|
45
|
-
delete(entityName: string, ...ids: string[]): Promise<fetch.Response>;
|
|
46
|
-
deleteAll(entityName: string): Promise<fetch.Response>;
|
|
47
|
-
query(entityName: string, fields: SearchFields, sort?: Sort, page?: Page): Promise<QueryResults>;
|
|
48
|
-
private post;
|
|
49
|
-
private normaliseFields;
|
|
50
|
-
private toSearchPredicate;
|
|
51
|
-
}
|
|
52
|
-
export {};
|
|
@@ -1,90 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.SearchService = void 0;
|
|
4
|
-
const tslib_1 = require("tslib");
|
|
5
|
-
const common_1 = require("@nestjs/common");
|
|
6
|
-
const node_fetch_1 = require("node-fetch");
|
|
7
|
-
const logging_1 = require("../logging");
|
|
8
|
-
const configuration_1 = require("../configuration");
|
|
9
|
-
const isPredicate = (value) => {
|
|
10
|
-
return value.op !== undefined;
|
|
11
|
-
};
|
|
12
|
-
const isPredicateArray = (value) => {
|
|
13
|
-
return Array.isArray(value) && value.length > 0 && isPredicate(value[0]);
|
|
14
|
-
};
|
|
15
|
-
let SearchService = class SearchService {
|
|
16
|
-
constructor(configuration) {
|
|
17
|
-
this.configuration = configuration;
|
|
18
|
-
this.logger = (0, logging_1.createLogger)('search-service');
|
|
19
|
-
}
|
|
20
|
-
index(entityName, entries) {
|
|
21
|
-
this.logger.info(`Indexing ${entries.length} ${entityName} entities`);
|
|
22
|
-
return this.post('/index', {
|
|
23
|
-
entityName,
|
|
24
|
-
entries,
|
|
25
|
-
});
|
|
26
|
-
}
|
|
27
|
-
delete(entityName, ...ids) {
|
|
28
|
-
return this.post('/delete', {
|
|
29
|
-
entityName,
|
|
30
|
-
ids,
|
|
31
|
-
});
|
|
32
|
-
}
|
|
33
|
-
deleteAll(entityName) {
|
|
34
|
-
return this.post('/deleteAll', {
|
|
35
|
-
entityName,
|
|
36
|
-
});
|
|
37
|
-
}
|
|
38
|
-
async query(entityName, fields, sort, page) {
|
|
39
|
-
const resp = await this.post('/query', {
|
|
40
|
-
entityName,
|
|
41
|
-
fields: this.normaliseFields(fields),
|
|
42
|
-
sort,
|
|
43
|
-
page,
|
|
44
|
-
});
|
|
45
|
-
const queryResults = await resp.json();
|
|
46
|
-
this.logger.info(`Query returned ${queryResults.ids.length} ids of total ${queryResults.resultCount}`);
|
|
47
|
-
return queryResults;
|
|
48
|
-
}
|
|
49
|
-
post(path, body) {
|
|
50
|
-
if (!this.configuration.searchServiceEndpoint) {
|
|
51
|
-
throw new Error('searchServiceEndpoint must be configured in order to use the SearchService');
|
|
52
|
-
}
|
|
53
|
-
return (0, node_fetch_1.default)(this.configuration.searchServiceEndpoint + path, {
|
|
54
|
-
method: 'POST',
|
|
55
|
-
body: JSON.stringify(body),
|
|
56
|
-
});
|
|
57
|
-
}
|
|
58
|
-
normaliseFields(fields) {
|
|
59
|
-
return Object.keys(fields).reduce((result, key) => {
|
|
60
|
-
const field = fields[key];
|
|
61
|
-
if (isPredicateArray(field)) {
|
|
62
|
-
field.forEach(predicate => result.push(this.toSearchPredicate(key, predicate)));
|
|
63
|
-
}
|
|
64
|
-
else {
|
|
65
|
-
result.push(this.toSearchPredicate(key, field));
|
|
66
|
-
}
|
|
67
|
-
return result;
|
|
68
|
-
}, []);
|
|
69
|
-
}
|
|
70
|
-
toSearchPredicate(fieldName, input) {
|
|
71
|
-
return isPredicate(input)
|
|
72
|
-
? {
|
|
73
|
-
field: fieldName,
|
|
74
|
-
op: input.op,
|
|
75
|
-
value: input.value,
|
|
76
|
-
}
|
|
77
|
-
: {
|
|
78
|
-
field: fieldName,
|
|
79
|
-
op: '=',
|
|
80
|
-
value: input,
|
|
81
|
-
};
|
|
82
|
-
}
|
|
83
|
-
};
|
|
84
|
-
exports.SearchService = SearchService;
|
|
85
|
-
exports.SearchService = SearchService = tslib_1.__decorate([
|
|
86
|
-
(0, common_1.Injectable)(),
|
|
87
|
-
tslib_1.__param(0, (0, common_1.Inject)(configuration_1.CONFIGURATION)),
|
|
88
|
-
tslib_1.__metadata("design:paramtypes", [Object])
|
|
89
|
-
], SearchService);
|
|
90
|
-
//# sourceMappingURL=search.service.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"search.service.js","sourceRoot":"","sources":["../../src/search/search.service.ts"],"names":[],"mappings":"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"}
|
|
@@ -1,36 +0,0 @@
|
|
|
1
|
-
import { Datastore } from '@google-cloud/datastore';
|
|
2
|
-
import * as t from 'io-ts';
|
|
3
|
-
import { Context } from '../datastore/context';
|
|
4
|
-
import { Index } from '../datastore/loader';
|
|
5
|
-
import { Repository, RepositoryOptions } from '../datastore/repository';
|
|
6
|
-
import { Omit } from '../util/types';
|
|
7
|
-
import { Page, SearchFields, SearchResults, SearchService, Sort } from './search.service';
|
|
8
|
-
interface SearchableRepositoryOptions<T extends {
|
|
9
|
-
id: any;
|
|
10
|
-
}> extends RepositoryOptions<T> {
|
|
11
|
-
searchIndex: Index<Omit<T, 'id'>>;
|
|
12
|
-
}
|
|
13
|
-
export declare class SearchableRepository<T extends {
|
|
14
|
-
id: string;
|
|
15
|
-
}> extends Repository<T> {
|
|
16
|
-
protected readonly searchService: SearchService;
|
|
17
|
-
protected readonly options: SearchableRepositoryOptions<T>;
|
|
18
|
-
private baseLogger;
|
|
19
|
-
constructor(datastore: Datastore, searchService: SearchService, kind: string, validator: t.Type<T>, options: SearchableRepositoryOptions<T>);
|
|
20
|
-
save(context: Context, entities: T): Promise<T>;
|
|
21
|
-
save(context: Context, entities: ReadonlyArray<T>): Promise<ReadonlyArray<T>>;
|
|
22
|
-
update(context: Context, entities: T): Promise<T>;
|
|
23
|
-
update(context: Context, entities: ReadonlyArray<T>): Promise<ReadonlyArray<T>>;
|
|
24
|
-
insert(context: Context, entities: T): Promise<T>;
|
|
25
|
-
insert(context: Context, entities: ReadonlyArray<T>): Promise<ReadonlyArray<T>>;
|
|
26
|
-
upsert(context: Context, entities: T): Promise<T>;
|
|
27
|
-
upsert(context: Context, entities: ReadonlyArray<T>): Promise<ReadonlyArray<T>>;
|
|
28
|
-
delete(context: Context, ...ids: string[]): Promise<void>;
|
|
29
|
-
deleteAll(context: Context): Promise<void>;
|
|
30
|
-
search(context: Context, searchFields: SearchFields, sort?: Sort): Promise<readonly T[]>;
|
|
31
|
-
searchWithPagination(context: Context, searchFields: SearchFields, sort?: Sort, page?: Page): Promise<SearchResults<T>>;
|
|
32
|
-
reindex(context: Context, operation?: (input: T) => T | Promise<T>): Promise<readonly T[]>;
|
|
33
|
-
private index;
|
|
34
|
-
private fetchResults;
|
|
35
|
-
}
|
|
36
|
-
export {};
|
|
@@ -1,95 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.SearchableRepository = void 0;
|
|
4
|
-
const repository_1 = require("../datastore/repository");
|
|
5
|
-
const types_1 = require("../util/types");
|
|
6
|
-
const logging_1 = require("../logging");
|
|
7
|
-
class SearchableRepository extends repository_1.Repository {
|
|
8
|
-
constructor(datastore, searchService, kind, validator, options) {
|
|
9
|
-
super(datastore, kind, validator, options);
|
|
10
|
-
this.searchService = searchService;
|
|
11
|
-
this.options = options;
|
|
12
|
-
this.baseLogger = (0, logging_1.createLogger)('searchable-repository');
|
|
13
|
-
}
|
|
14
|
-
async save(context, entities) {
|
|
15
|
-
const savedEntities = await super.save(context, entities);
|
|
16
|
-
await this.index(savedEntities);
|
|
17
|
-
return savedEntities;
|
|
18
|
-
}
|
|
19
|
-
async update(context, entities) {
|
|
20
|
-
const savedEntities = await super.update(context, entities);
|
|
21
|
-
await this.index(savedEntities);
|
|
22
|
-
return savedEntities;
|
|
23
|
-
}
|
|
24
|
-
async insert(context, entities) {
|
|
25
|
-
const savedEntities = await super.insert(context, entities);
|
|
26
|
-
await this.index(savedEntities);
|
|
27
|
-
return savedEntities;
|
|
28
|
-
}
|
|
29
|
-
async upsert(context, entities) {
|
|
30
|
-
const savedEntities = await super.upsert(context, entities);
|
|
31
|
-
await this.index(savedEntities);
|
|
32
|
-
return savedEntities;
|
|
33
|
-
}
|
|
34
|
-
async delete(context, ...ids) {
|
|
35
|
-
await super.delete(context, ...ids);
|
|
36
|
-
await this.searchService.delete(this.kind, ...ids);
|
|
37
|
-
}
|
|
38
|
-
async deleteAll(context) {
|
|
39
|
-
await super.deleteAll(context);
|
|
40
|
-
await this.searchService.deleteAll(this.kind);
|
|
41
|
-
}
|
|
42
|
-
async search(context, searchFields, sort) {
|
|
43
|
-
const queryResults = await this.searchService.query(this.kind, searchFields, sort);
|
|
44
|
-
const requests = await this.fetchResults(context, queryResults.ids);
|
|
45
|
-
return requests;
|
|
46
|
-
}
|
|
47
|
-
async searchWithPagination(context, searchFields, sort, page) {
|
|
48
|
-
const queryResults = await this.searchService.query(this.kind, searchFields, sort, page);
|
|
49
|
-
const requests = await this.fetchResults(context, queryResults.ids);
|
|
50
|
-
return {
|
|
51
|
-
resultCount: queryResults.resultCount,
|
|
52
|
-
limit: queryResults.limit,
|
|
53
|
-
offset: queryResults.offset,
|
|
54
|
-
results: requests,
|
|
55
|
-
};
|
|
56
|
-
}
|
|
57
|
-
async reindex(context, operation = input => input) {
|
|
58
|
-
const [allEntities] = await this.query(context);
|
|
59
|
-
this.baseLogger.info(`Saving ${allEntities.length} searchable entities`);
|
|
60
|
-
const batchSize = 100;
|
|
61
|
-
const allUpdatedEntities = [];
|
|
62
|
-
for (let i = 0; i < allEntities.length; i += batchSize) {
|
|
63
|
-
const batchOfEntities = allEntities.slice(i, i + batchSize);
|
|
64
|
-
const updatedEntities = await Promise.all(batchOfEntities.map(operation));
|
|
65
|
-
this.baseLogger.info(`Saving batch of ${batchOfEntities.length} updated searchable entities`);
|
|
66
|
-
const batchUpdatedEntities = await this.update(context, updatedEntities);
|
|
67
|
-
allUpdatedEntities.push(...batchUpdatedEntities);
|
|
68
|
-
}
|
|
69
|
-
return allUpdatedEntities;
|
|
70
|
-
}
|
|
71
|
-
index(entities) {
|
|
72
|
-
const entitiesArr = (0, types_1.asArray)(entities);
|
|
73
|
-
const entries = entitiesArr.map((entity) => {
|
|
74
|
-
const fields = Object.keys(this.options.searchIndex).reduce((obj, fieldName) => {
|
|
75
|
-
obj[fieldName] = entity[fieldName];
|
|
76
|
-
return obj;
|
|
77
|
-
}, {});
|
|
78
|
-
return {
|
|
79
|
-
id: entity.id,
|
|
80
|
-
fields,
|
|
81
|
-
};
|
|
82
|
-
});
|
|
83
|
-
return this.searchService.index(this.kind, entries);
|
|
84
|
-
}
|
|
85
|
-
async fetchResults(context, ids) {
|
|
86
|
-
const results = await this.get(context, ids);
|
|
87
|
-
if (results && results.some(result => !result)) {
|
|
88
|
-
this.baseLogger.warn('Search results contained at least one null value - search index likely out of sync with datastore');
|
|
89
|
-
return results.filter(result => !!result);
|
|
90
|
-
}
|
|
91
|
-
return results;
|
|
92
|
-
}
|
|
93
|
-
}
|
|
94
|
-
exports.SearchableRepository = SearchableRepository;
|
|
95
|
-
//# sourceMappingURL=searchable.repository.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"searchable.repository.js","sourceRoot":"","sources":["../../src/search/searchable.repository.ts"],"names":[],"mappings":"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"}
|
package/dist/types.d.ts
DELETED
package/dist/types.js
DELETED
|
@@ -1,9 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.nullable = void 0;
|
|
4
|
-
const tslib_1 = require("tslib");
|
|
5
|
-
const iots = require("io-ts");
|
|
6
|
-
tslib_1.__exportStar(require("io-ts"), exports);
|
|
7
|
-
const nullable = (type) => iots.union([type, iots.null]);
|
|
8
|
-
exports.nullable = nullable;
|
|
9
|
-
//# sourceMappingURL=types.js.map
|
package/dist/types.js.map
DELETED
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"types.js","sourceRoot":"","sources":["../src/types.ts"],"names":[],"mappings":";;;;AAAA,8BAA8B;AAG9B,gDAAsB;AACf,MAAM,QAAQ,GAAG,CAAI,IAAkB,EAAE,EAAE,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC,IAAI,EAAE,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC;AAApE,QAAA,QAAQ,YAA4D"}
|
package/dist/util/arrays.d.ts
DELETED
|
@@ -1 +0,0 @@
|
|
|
1
|
-
export declare const unique: <T>(src: T[] | ReadonlyArray<T>, ...newValues: T[]) => T[];
|
package/dist/util/arrays.js
DELETED
|
@@ -1,10 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.unique = void 0;
|
|
4
|
-
const unique = (src, ...newValues) => {
|
|
5
|
-
const set = new Set(src);
|
|
6
|
-
newValues.forEach(val => set.add(val));
|
|
7
|
-
return Array.from(set);
|
|
8
|
-
};
|
|
9
|
-
exports.unique = unique;
|
|
10
|
-
//# sourceMappingURL=arrays.js.map
|
package/dist/util/arrays.js.map
DELETED
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"arrays.js","sourceRoot":"","sources":["../../src/util/arrays.ts"],"names":[],"mappings":";;;AAAO,MAAM,MAAM,GAAG,CAAI,GAA2B,EAAE,GAAG,SAAc,EAAO,EAAE;IAC/E,MAAM,GAAG,GAAG,IAAI,GAAG,CAAC,GAAG,CAAC,CAAC;IACzB,SAAS,CAAC,OAAO,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,CAAC,GAAG,CAAC,GAAG,CAAC,CAAC,CAAC;IACvC,OAAO,KAAK,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;AACzB,CAAC,CAAC;AAJW,QAAA,MAAM,UAIjB"}
|
package/dist/util/guards.d.ts
DELETED
|
@@ -1 +0,0 @@
|
|
|
1
|
-
export declare const isEmpty: <T>(value: T | null | undefined) => value is null | undefined;
|
package/dist/util/guards.js
DELETED
package/dist/util/guards.js.map
DELETED
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"guards.js","sourceRoot":"","sources":["../../src/util/guards.ts"],"names":[],"mappings":";;;AAAA,4BAA4B;AAErB,MAAM,OAAO,GAAG,CAAI,KAA2B,EAA6B,EAAE,CAAC,CAAC,CAAC,OAAO,CAAC,KAAK,CAAC,CAAC;AAA1F,QAAA,OAAO,WAAmF"}
|
package/dist/util/index.d.ts
DELETED
|
@@ -1 +0,0 @@
|
|
|
1
|
-
export * from './nestjs';
|
package/dist/util/index.js
DELETED
package/dist/util/index.js.map
DELETED
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/util/index.ts"],"names":[],"mappings":";;;AAAA,mDAAyB"}
|
package/dist/util/nestjs.d.ts
DELETED
|
@@ -1,9 +0,0 @@
|
|
|
1
|
-
import { ExecutionContext } from '@nestjs/common';
|
|
2
|
-
import { Request } from 'express';
|
|
3
|
-
import { Context } from '../datastore/context';
|
|
4
|
-
interface RequestWithSessionAndContext extends Request {
|
|
5
|
-
session: any;
|
|
6
|
-
context: Context;
|
|
7
|
-
}
|
|
8
|
-
export declare const getRequestFromExecutionContext: (context: ExecutionContext) => RequestWithSessionAndContext;
|
|
9
|
-
export {};
|
package/dist/util/nestjs.js
DELETED
|
@@ -1,9 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.getRequestFromExecutionContext = void 0;
|
|
4
|
-
const graphql_1 = require("@nestjs/graphql");
|
|
5
|
-
const getRequestFromExecutionContext = (context) => (context.getType() === 'graphql'
|
|
6
|
-
? graphql_1.GqlExecutionContext.create(context).getContext().request
|
|
7
|
-
: context.switchToHttp().getRequest());
|
|
8
|
-
exports.getRequestFromExecutionContext = getRequestFromExecutionContext;
|
|
9
|
-
//# sourceMappingURL=nestjs.js.map
|
package/dist/util/nestjs.js.map
DELETED
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"nestjs.js","sourceRoot":"","sources":["../../src/util/nestjs.ts"],"names":[],"mappings":";;;AAEA,6CAAsE;AAW/D,MAAM,8BAA8B,GAAG,CAAC,OAAyB,EAAgC,EAAE,CACxG,CAAC,OAAO,CAAC,OAAO,EAAkB,KAAK,SAAS;IAC9C,CAAC,CAAC,6BAAmB,CAAC,MAAM,CAAC,OAAO,CAAC,CAAC,UAAU,EAAW,CAAC,OAAO;IACnE,CAAC,CAAC,OAAO,CAAC,YAAY,EAAE,CAAC,UAAU,EAAE,CAAiC,CAAC;AAH9D,QAAA,8BAA8B,kCAGgC"}
|
package/dist/util/types.d.ts
DELETED
package/dist/util/types.js
DELETED
|
@@ -1,8 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.asPromise = exports.asArray = void 0;
|
|
4
|
-
const asArray = (input) => (Array.isArray(input) ? input : [input]);
|
|
5
|
-
exports.asArray = asArray;
|
|
6
|
-
const asPromise = (src) => (src instanceof Promise ? src : Promise.resolve(src));
|
|
7
|
-
exports.asPromise = asPromise;
|
|
8
|
-
//# sourceMappingURL=types.js.map
|
package/dist/util/types.js.map
DELETED
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"types.js","sourceRoot":"","sources":["../../src/util/types.ts"],"names":[],"mappings":";;;AAGO,MAAM,OAAO,GAAG,CAAI,KAAmB,EAAY,EAAE,CAAC,CAAC,KAAK,CAAC,OAAO,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,KAAK,CAAC,CAAa,CAAC;AAArG,QAAA,OAAO,WAA8F;AAE3G,MAAM,SAAS,GAAG,CAAI,GAAmB,EAAc,EAAE,CAAC,CAAC,GAAG,YAAY,OAAO,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,OAAO,CAAC,OAAO,CAAC,GAAG,CAAC,CAAC,CAAC;AAA1G,QAAA,SAAS,aAAiG"}
|
package/dist/validator.d.ts
DELETED
|
@@ -1 +0,0 @@
|
|
|
1
|
-
export * from 'io-ts';
|
package/dist/validator.js
DELETED
package/dist/validator.js.map
DELETED
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"validator.js","sourceRoot":"","sources":["../src/validator.ts"],"names":[],"mappings":";;;AAGA,gDAAsB"}
|
|
Binary file
|
|
Binary file
|