@servicelabsco/nestjs-utility-services 1.1.14 → 1.1.16
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/app.controller.js +7 -24
- package/dist/app.controller.js.map +1 -1
- package/dist/app.module.js +2 -0
- package/dist/app.module.js.map +1 -1
- package/dist/app.service.js +8 -23
- package/dist/app.service.js.map +1 -1
- package/dist/auth/controllers/auth.controller.js +54 -75
- package/dist/auth/controllers/auth.controller.js.map +1 -1
- package/dist/auth/controllers/social.controller.js +7 -20
- package/dist/auth/controllers/social.controller.js.map +1 -1
- package/dist/auth/controllers/user.controller.js +6 -17
- package/dist/auth/controllers/user.controller.js.map +1 -1
- package/dist/auth/es6.classes.d.ts +2 -1
- package/dist/auth/es6.classes.js +2 -1
- package/dist/auth/es6.classes.js.map +1 -1
- package/dist/auth/middlewares/basic.auth.middleware.js +14 -25
- package/dist/auth/middlewares/basic.auth.middleware.js.map +1 -1
- package/dist/auth/middlewares/index.d.ts +1 -0
- package/dist/auth/middlewares/index.js +1 -0
- package/dist/auth/middlewares/index.js.map +1 -1
- package/dist/auth/middlewares/internal.middleware.d.ts +10 -0
- package/dist/auth/middlewares/internal.middleware.js +48 -0
- package/dist/auth/middlewares/internal.middleware.js.map +1 -0
- package/dist/auth/middlewares/jwt.middleware.js +19 -32
- package/dist/auth/middlewares/jwt.middleware.js.map +1 -1
- package/dist/auth/services/auth.service.js +42 -63
- package/dist/auth/services/auth.service.js.map +1 -1
- package/dist/auth/services/device.token.service.js +34 -47
- package/dist/auth/services/device.token.service.js.map +1 -1
- package/dist/auth/services/refresh.token.service.js +17 -30
- package/dist/auth/services/refresh.token.service.js.map +1 -1
- package/dist/auth/services/social.service.js +20 -33
- package/dist/auth/services/social.service.js.map +1 -1
- package/dist/auth/services/user.service.js +29 -46
- package/dist/auth/services/user.service.js.map +1 -1
- package/dist/auth/strategies/fb.strategy.js +8 -19
- package/dist/auth/strategies/fb.strategy.js.map +1 -1
- package/dist/auth/strategies/google.strategy.js +8 -19
- package/dist/auth/strategies/google.strategy.js.map +1 -1
- package/dist/cli.js +12 -23
- package/dist/cli.js.map +1 -1
- package/dist/common/guards/login.guard.js +5 -20
- package/dist/common/guards/login.guard.js.map +1 -1
- package/dist/common/libraries/base.migration.utility.js +106 -145
- package/dist/common/libraries/base.migration.utility.js.map +1 -1
- package/dist/common/libraries/common.entity.js +42 -63
- package/dist/common/libraries/common.entity.js.map +1 -1
- package/dist/common/libraries/common.job.d.ts +2 -0
- package/dist/common/libraries/common.job.js +46 -46
- package/dist/common/libraries/common.job.js.map +1 -1
- package/dist/common/libraries/common.mapper.job.js +20 -35
- package/dist/common/libraries/common.mapper.job.js.map +1 -1
- package/dist/common/libraries/common.subscriber.js +4 -17
- package/dist/common/libraries/common.subscriber.js.map +1 -1
- package/dist/common/libraries/data.manager.js +85 -112
- package/dist/common/libraries/data.manager.js.map +1 -1
- package/dist/common/libraries/list.manager.js +62 -85
- package/dist/common/libraries/list.manager.js.map +1 -1
- package/dist/common/libraries/migration.utility.js +10 -31
- package/dist/common/libraries/migration.utility.js.map +1 -1
- package/dist/common/libraries/platform.utility.js +2 -13
- package/dist/common/libraries/platform.utility.js.map +1 -1
- package/dist/common/libraries/record.manager.js +106 -127
- package/dist/common/libraries/record.manager.js.map +1 -1
- package/dist/common/libraries/report.data.manager.js +66 -93
- package/dist/common/libraries/report.data.manager.js.map +1 -1
- package/dist/common/libraries/report.list.manager.js +69 -92
- package/dist/common/libraries/report.list.manager.js.map +1 -1
- package/dist/common/libraries/reverse.migration.utility.js +4 -23
- package/dist/common/libraries/reverse.migration.utility.js.map +1 -1
- package/dist/common/libraries/seeder.utility.js +51 -70
- package/dist/common/libraries/seeder.utility.js.map +1 -1
- package/dist/console.js +4 -13
- package/dist/console.js.map +1 -1
- package/dist/main.js +15 -26
- package/dist/main.js.map +1 -1
- package/dist/migrations/1599567001962-AddUserSequence.js +3 -16
- package/dist/migrations/1599567001962-AddUserSequence.js.map +1 -1
- package/dist/migrations/1607944291609-AddUniqueIndexDeviceToken.js +7 -20
- package/dist/migrations/1607944291609-AddUniqueIndexDeviceToken.js.map +1 -1
- package/dist/platformUtility/commands/entity.generator.command.js +81 -108
- package/dist/platformUtility/commands/entity.generator.command.js.map +1 -1
- package/dist/platformUtility/commands/maintenance.command.js +16 -35
- package/dist/platformUtility/commands/maintenance.command.js.map +1 -1
- package/dist/platformUtility/commands/sqs.worker.command.js +49 -72
- package/dist/platformUtility/commands/sqs.worker.command.js.map +1 -1
- package/dist/platformUtility/commands/sync.class.command.js +14 -25
- package/dist/platformUtility/commands/sync.class.command.js.map +1 -1
- package/dist/platformUtility/consumers/event.consumer.js +21 -42
- package/dist/platformUtility/consumers/event.consumer.js.map +1 -1
- package/dist/platformUtility/consumers/job.consumer.js +8 -19
- package/dist/platformUtility/consumers/job.consumer.js.map +1 -1
- package/dist/platformUtility/controllers/queue.controller.js +47 -76
- package/dist/platformUtility/controllers/queue.controller.js.map +1 -1
- package/dist/platformUtility/jobs/record.watcher.job.js +5 -18
- package/dist/platformUtility/jobs/record.watcher.job.js.map +1 -1
- package/dist/platformUtility/jobs/test.job.js +1 -12
- package/dist/platformUtility/jobs/test.job.js.map +1 -1
- package/dist/platformUtility/libraries/process.common.mail.js +27 -44
- package/dist/platformUtility/libraries/process.common.mail.js.map +1 -1
- package/dist/platformUtility/libraries/process.postmark.mail.js +22 -37
- package/dist/platformUtility/libraries/process.postmark.mail.js.map +1 -1
- package/dist/platformUtility/services/audit.service.js +50 -67
- package/dist/platformUtility/services/audit.service.js.map +1 -1
- package/dist/platformUtility/services/cache.service.js +21 -36
- package/dist/platformUtility/services/cache.service.js.map +1 -1
- package/dist/platformUtility/services/dynamo.service.js +16 -29
- package/dist/platformUtility/services/dynamo.service.js.map +1 -1
- package/dist/platformUtility/services/fcm.notification.service.js +42 -63
- package/dist/platformUtility/services/fcm.notification.service.js.map +1 -1
- package/dist/platformUtility/services/mail.service.js +8 -19
- package/dist/platformUtility/services/mail.service.js.map +1 -1
- package/dist/platformUtility/services/queue.service.js +105 -158
- package/dist/platformUtility/services/queue.service.js.map +1 -1
- package/dist/platformUtility/services/remote.request.service.js +8 -19
- package/dist/platformUtility/services/remote.request.service.js.map +1 -1
- package/dist/platformUtility/services/sql.service.js +17 -38
- package/dist/platformUtility/services/sql.service.js.map +1 -1
- package/dist/platformUtility/services/sqs.service.js +39 -56
- package/dist/platformUtility/services/sqs.service.js.map +1 -1
- package/dist/platformUtility/services/startup.service.js +8 -21
- package/dist/platformUtility/services/startup.service.js.map +1 -1
- package/dist/platformUtility/subscribers/base.subscriber.js +6 -19
- package/dist/platformUtility/subscribers/base.subscriber.js.map +1 -1
- package/dist/system/commands/db.scanner.command.js +182 -221
- package/dist/system/commands/db.scanner.command.js.map +1 -1
- package/dist/system/commands/event.queue.command.js +30 -47
- package/dist/system/commands/event.queue.command.js.map +1 -1
- package/dist/system/commands/jobs.scanner.command.js +7 -18
- package/dist/system/commands/jobs.scanner.command.js.map +1 -1
- package/dist/system/commands/model.scanner.command.js +15 -30
- package/dist/system/commands/model.scanner.command.js.map +1 -1
- package/dist/system/commands/report.scanner.command.js +9 -20
- package/dist/system/commands/report.scanner.command.js.map +1 -1
- package/dist/system/commands/service.scanner.command.js +7 -18
- package/dist/system/commands/service.scanner.command.js.map +1 -1
- package/dist/system/commands/sync.all.command.js +13 -24
- package/dist/system/commands/sync.all.command.js.map +1 -1
- package/dist/system/controllers/base.controller.js +62 -87
- package/dist/system/controllers/base.controller.js.map +1 -1
- package/dist/system/controllers/data.controller.js +10 -23
- package/dist/system/controllers/data.controller.js.map +1 -1
- package/dist/system/controllers/form.controller.js +9 -20
- package/dist/system/controllers/form.controller.js.map +1 -1
- package/dist/system/controllers/menu.controller.js +4 -17
- package/dist/system/controllers/menu.controller.js.map +1 -1
- package/dist/system/controllers/preference.controller.js +51 -74
- package/dist/system/controllers/preference.controller.js.map +1 -1
- package/dist/system/controllers/report.controller.js +29 -46
- package/dist/system/controllers/report.controller.js.map +1 -1
- package/dist/system/controllers/upload.controller.js +11 -26
- package/dist/system/controllers/upload.controller.js.map +1 -1
- package/dist/system/controllers/user.preference.controller.js +9 -22
- package/dist/system/controllers/user.preference.controller.js.map +1 -1
- package/dist/system/es6.classes.d.ts +1 -1
- package/dist/system/jobs/clean.scheduled.event.job.js +3 -14
- package/dist/system/jobs/clean.scheduled.event.job.js.map +1 -1
- package/dist/system/jobs/column.mapper.job.js +18 -33
- package/dist/system/jobs/column.mapper.job.js.map +1 -1
- package/dist/system/jobs/model.scanner.job.js +106 -133
- package/dist/system/jobs/model.scanner.job.js.map +1 -1
- package/dist/system/jobs/property.job.js +5 -16
- package/dist/system/jobs/property.job.js.map +1 -1
- package/dist/system/jobs/relationship.mapper.job.js +18 -33
- package/dist/system/jobs/relationship.mapper.job.js.map +1 -1
- package/dist/system/jobs/report.column.sync.job.js +71 -94
- package/dist/system/jobs/report.column.sync.job.js.map +1 -1
- package/dist/system/jobs/scheduled.event.job.js +15 -28
- package/dist/system/jobs/scheduled.event.job.js.map +1 -1
- package/dist/system/jobs/scheduled.events.job.js +11 -22
- package/dist/system/jobs/scheduled.events.job.js.map +1 -1
- package/dist/system/jobs/user.group.member.job.js +56 -79
- package/dist/system/jobs/user.group.member.job.js.map +1 -1
- package/dist/system/jobs/user.group.permission.job.js +24 -39
- package/dist/system/jobs/user.group.permission.job.js.map +1 -1
- package/dist/system/jobs/user.group.role.job.js +24 -39
- package/dist/system/jobs/user.group.role.job.js.map +1 -1
- package/dist/system/libraries/business.rule.filter.validator.js +20 -37
- package/dist/system/libraries/business.rule.filter.validator.js.map +1 -1
- package/dist/system/libraries/business.rule.query.evaluator.js +24 -39
- package/dist/system/libraries/business.rule.query.evaluator.js.map +1 -1
- package/dist/system/libraries/column.manager.js +42 -61
- package/dist/system/libraries/column.manager.js.map +1 -1
- package/dist/system/libraries/model.sync.js +64 -87
- package/dist/system/libraries/model.sync.js.map +1 -1
- package/dist/system/libraries/security.rule.evaluator.js +13 -26
- package/dist/system/libraries/security.rule.evaluator.js.map +1 -1
- package/dist/system/services/business.rule.service.js +23 -36
- package/dist/system/services/business.rule.service.js.map +1 -1
- package/dist/system/services/client.script.service.js +17 -28
- package/dist/system/services/client.script.service.js.map +1 -1
- package/dist/system/services/column.service.js +12 -23
- package/dist/system/services/column.service.js.map +1 -1
- package/dist/system/services/comment.service.js +2 -13
- package/dist/system/services/comment.service.js.map +1 -1
- package/dist/system/services/common.service.js +27 -44
- package/dist/system/services/common.service.js.map +1 -1
- package/dist/system/services/document.service.js +3 -14
- package/dist/system/services/document.service.js.map +1 -1
- package/dist/system/services/event.detail.service.js +10 -21
- package/dist/system/services/event.detail.service.js.map +1 -1
- package/dist/system/services/event.queue.service.js +21 -34
- package/dist/system/services/event.queue.service.js.map +1 -1
- package/dist/system/services/form.service.js +6 -17
- package/dist/system/services/form.service.js.map +1 -1
- package/dist/system/services/list.service.js +20 -35
- package/dist/system/services/list.service.js.map +1 -1
- package/dist/system/services/menu.service.js +50 -69
- package/dist/system/services/menu.service.js.map +1 -1
- package/dist/system/services/model.service.js +60 -81
- package/dist/system/services/model.service.js.map +1 -1
- package/dist/system/services/preference.service.js +32 -53
- package/dist/system/services/preference.service.js.map +1 -1
- package/dist/system/services/property.service.js +23 -36
- package/dist/system/services/property.service.js.map +1 -1
- package/dist/system/services/report.service.js +19 -32
- package/dist/system/services/report.service.js.map +1 -1
- package/dist/system/services/scheduled.event.service.js +69 -90
- package/dist/system/services/scheduled.event.service.js.map +1 -1
- package/dist/system/services/security.rule.service.js +23 -40
- package/dist/system/services/security.rule.service.js.map +1 -1
- package/dist/system/services/ui.action.service.js +13 -24
- package/dist/system/services/ui.action.service.js.map +1 -1
- package/dist/system/services/upload.service.js +33 -48
- package/dist/system/services/upload.service.js.map +1 -1
- package/dist/system/services/user.preference.service.js +38 -57
- package/dist/system/services/user.preference.service.js.map +1 -1
- package/dist/system/subscribers/column.subscriber.js +4 -17
- package/dist/system/subscribers/column.subscriber.js.map +1 -1
- package/dist/system/subscribers/property.subscriber.js +4 -17
- package/dist/system/subscribers/property.subscriber.js.map +1 -1
- package/dist/system/subscribers/relationship.subscriber.js +4 -17
- package/dist/system/subscribers/relationship.subscriber.js.map +1 -1
- package/dist/system/subscribers/scheduled.event.subscriber.js +6 -19
- package/dist/system/subscribers/scheduled.event.subscriber.js.map +1 -1
- package/dist/system/subscribers/user.group.member.subscriber.js +4 -17
- package/dist/system/subscribers/user.group.member.subscriber.js.map +1 -1
- package/dist/system/subscribers/user.group.permission.subscriber.js +4 -17
- package/dist/system/subscribers/user.group.permission.subscriber.js.map +1 -1
- package/dist/system/subscribers/user.group.role.subscriber.js +4 -17
- package/dist/system/subscribers/user.group.role.subscriber.js.map +1 -1
- package/dist/worker.js +6 -17
- package/dist/worker.js.map +1 -1
- package/package.json +2 -1
@@ -8,15 +8,6 @@ var __decorate = (this && this.__decorate) || function (decorators, target, key,
|
|
8
8
|
var __metadata = (this && this.__metadata) || function (k, v) {
|
9
9
|
if (typeof Reflect === "object" && typeof Reflect.metadata === "function") return Reflect.metadata(k, v);
|
10
10
|
};
|
11
|
-
var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
|
12
|
-
function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
|
13
|
-
return new (P || (P = Promise))(function (resolve, reject) {
|
14
|
-
function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
|
15
|
-
function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
|
16
|
-
function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
|
17
|
-
step((generator = generator.apply(thisArg, _arguments || [])).next());
|
18
|
-
});
|
19
|
-
};
|
20
11
|
Object.defineProperty(exports, "__esModule", { value: true });
|
21
12
|
exports.CommonEntity = void 0;
|
22
13
|
const class_transformer_1 = require("class-transformer");
|
@@ -24,66 +15,54 @@ const typeorm_1 = require("typeorm");
|
|
24
15
|
const creator_entity_1 = require("../../auth/entities/creator.entity");
|
25
16
|
const date_util_1 = require("./date.util");
|
26
17
|
class CommonEntity extends typeorm_1.BaseEntity {
|
27
|
-
static firstOrNew(record) {
|
28
|
-
|
29
|
-
|
30
|
-
|
31
|
-
|
32
|
-
|
33
|
-
|
34
|
-
return (0, class_transformer_1.plainToInstance)(entity, record);
|
35
|
-
});
|
18
|
+
static async firstOrNew(record) {
|
19
|
+
const repository = this.getRepository();
|
20
|
+
const existingRecord = await repository.findOne({ where: record });
|
21
|
+
if (existingRecord)
|
22
|
+
return existingRecord;
|
23
|
+
const entity = repository.metadata.target;
|
24
|
+
return (0, class_transformer_1.plainToInstance)(entity, record);
|
36
25
|
}
|
37
|
-
static firstOrCreate(record) {
|
38
|
-
|
39
|
-
|
40
|
-
|
41
|
-
|
42
|
-
|
43
|
-
|
44
|
-
|
45
|
-
return data.save();
|
46
|
-
});
|
26
|
+
static async firstOrCreate(record) {
|
27
|
+
const repository = this.getRepository();
|
28
|
+
const existingRecord = await repository.findOne({ where: record });
|
29
|
+
if (existingRecord)
|
30
|
+
return existingRecord;
|
31
|
+
const entity = repository.metadata.target;
|
32
|
+
const data = (0, class_transformer_1.plainToInstance)(entity, record);
|
33
|
+
return data.save();
|
47
34
|
}
|
48
|
-
static first(id, options) {
|
49
|
-
|
50
|
-
|
51
|
-
|
52
|
-
return repository.findOne(condition);
|
53
|
-
});
|
35
|
+
static async first(id, options) {
|
36
|
+
const repository = this.getRepository();
|
37
|
+
const condition = Object.assign({ where: { id } }, options);
|
38
|
+
return repository.findOne(condition);
|
54
39
|
}
|
55
|
-
softDelete() {
|
56
|
-
|
57
|
-
|
58
|
-
|
59
|
-
return this;
|
60
|
-
});
|
40
|
+
async softDelete() {
|
41
|
+
this.deleted_at = date_util_1.DateUtil.getDateTime();
|
42
|
+
await this.save();
|
43
|
+
return this;
|
61
44
|
}
|
62
|
-
static softDelete(where) {
|
63
|
-
|
64
|
-
|
65
|
-
|
66
|
-
|
67
|
-
|
68
|
-
|
69
|
-
|
70
|
-
|
71
|
-
return
|
72
|
-
return res;
|
73
|
-
});
|
45
|
+
static async softDelete(where) {
|
46
|
+
const repository = this.getRepository();
|
47
|
+
const records = await repository.find({ where });
|
48
|
+
const promises = [];
|
49
|
+
records.forEach((record) => {
|
50
|
+
record.deleted_at = date_util_1.DateUtil.getDateTime();
|
51
|
+
promises.push(record.save());
|
52
|
+
});
|
53
|
+
return Promise.all(promises).then((res) => {
|
54
|
+
return res;
|
74
55
|
});
|
75
56
|
}
|
76
|
-
static destroy(where) {
|
77
|
-
|
78
|
-
|
79
|
-
|
80
|
-
|
81
|
-
|
82
|
-
|
83
|
-
|
84
|
-
return
|
85
|
-
return res;
|
86
|
-
});
|
57
|
+
static async destroy(where) {
|
58
|
+
const repository = this.getRepository();
|
59
|
+
const records = await repository.find({ where });
|
60
|
+
const promises = [];
|
61
|
+
records.forEach((record) => {
|
62
|
+
promises.push(record.remove());
|
63
|
+
});
|
64
|
+
return Promise.all(promises).then((res) => {
|
65
|
+
return res;
|
87
66
|
});
|
88
67
|
}
|
89
68
|
toJSON() {
|
@@ -1 +1 @@
|
|
1
|
-
{"version":3,"file":"common.entity.js","sourceRoot":"","sources":["../../../src/common/libraries/common.entity.ts"],"names":[],"mappings":"
|
1
|
+
{"version":3,"file":"common.entity.js","sourceRoot":"","sources":["../../../src/common/libraries/common.entity.ts"],"names":[],"mappings":"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"}
|
@@ -1,6 +1,7 @@
|
|
1
1
|
import { Job } from 'bull';
|
2
2
|
import { QueueOptionsDto } from '../../platformUtility/dtos/queue.options.dto';
|
3
3
|
import { QueueService } from '../../platformUtility/services/queue.service';
|
4
|
+
import { DatabaseEventDto } from '../dtos';
|
4
5
|
import { BaseJobInterface } from './base.job.interface';
|
5
6
|
export declare class CommonJob implements BaseJobInterface {
|
6
7
|
protected eventId: number;
|
@@ -10,4 +11,5 @@ export declare class CommonJob implements BaseJobInterface {
|
|
10
11
|
dispatch(data: any, options?: QueueOptionsDto, eventId?: number): Promise<any>;
|
11
12
|
delayedDispatch(data: any, options?: QueueOptionsDto, eventId?: number): Promise<any>;
|
12
13
|
handle(data: any, job?: Job): Promise<any>;
|
14
|
+
protected isColumnUpdated(event: DatabaseEventDto<any>, column: string | string[]): boolean;
|
13
15
|
}
|
@@ -1,13 +1,4 @@
|
|
1
1
|
"use strict";
|
2
|
-
var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
|
3
|
-
function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
|
4
|
-
return new (P || (P = Promise))(function (resolve, reject) {
|
5
|
-
function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
|
6
|
-
function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
|
7
|
-
function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
|
8
|
-
step((generator = generator.apply(thisArg, _arguments || [])).next());
|
9
|
-
});
|
10
|
-
};
|
11
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
12
3
|
exports.CommonJob = void 0;
|
13
4
|
const config = require("config");
|
@@ -18,45 +9,54 @@ class CommonJob {
|
|
18
9
|
this.mode = 'redis';
|
19
10
|
this.queue = 'generic.job.trigger';
|
20
11
|
}
|
21
|
-
dispatch(data, options, eventId) {
|
22
|
-
|
23
|
-
|
24
|
-
|
25
|
-
|
26
|
-
|
27
|
-
|
28
|
-
|
29
|
-
|
30
|
-
|
31
|
-
|
32
|
-
|
33
|
-
|
34
|
-
|
35
|
-
return this.queueService.sqsService.add(sqsQueue, payload);
|
36
|
-
});
|
12
|
+
async dispatch(data, options, eventId) {
|
13
|
+
const payload = {
|
14
|
+
job: hash_1.Hash.hashMD5(this.constructor.name),
|
15
|
+
payload: data,
|
16
|
+
name: this.constructor.name,
|
17
|
+
event_id: eventId,
|
18
|
+
};
|
19
|
+
options = options !== null && options !== void 0 ? options : {};
|
20
|
+
if (this.mode === 'redis')
|
21
|
+
return this.queueService.add(this.queue, payload, options);
|
22
|
+
const sqsQueue = config.get(`sqs.${this.mode}`);
|
23
|
+
if (!sqsQueue)
|
24
|
+
throw new operation_exception_1.OperationException(`Queue ${this.mode} is not defined in the system. please add is under sqs`);
|
25
|
+
return this.queueService.sqsService.add(sqsQueue, payload);
|
37
26
|
}
|
38
|
-
delayedDispatch(data, options, eventId) {
|
39
|
-
|
40
|
-
|
41
|
-
|
42
|
-
|
43
|
-
|
44
|
-
|
45
|
-
|
46
|
-
|
47
|
-
|
48
|
-
|
49
|
-
|
50
|
-
|
51
|
-
|
52
|
-
|
53
|
-
return this.queueService.sqsService.add(sqsQueue, payload);
|
54
|
-
});
|
27
|
+
async delayedDispatch(data, options, eventId) {
|
28
|
+
const payload = {
|
29
|
+
job: hash_1.Hash.hashMD5(this.constructor.name),
|
30
|
+
payload: data,
|
31
|
+
name: this.constructor.name,
|
32
|
+
event_id: eventId,
|
33
|
+
};
|
34
|
+
options = options !== null && options !== void 0 ? options : {};
|
35
|
+
options.delay = options.delay || 200;
|
36
|
+
if (this.mode === 'redis')
|
37
|
+
return this.queueService.add(this.queue, payload, options);
|
38
|
+
const sqsQueue = config.get(`sqs.${this.mode}`);
|
39
|
+
if (!sqsQueue)
|
40
|
+
throw new operation_exception_1.OperationException(`Queue ${this.mode} is not defined in the system. please add is under sqs`);
|
41
|
+
return this.queueService.sqsService.add(sqsQueue, payload);
|
55
42
|
}
|
56
|
-
handle(data, job) {
|
57
|
-
return
|
58
|
-
|
59
|
-
|
43
|
+
async handle(data, job) {
|
44
|
+
return data;
|
45
|
+
}
|
46
|
+
isColumnUpdated(event, column) {
|
47
|
+
var _a;
|
48
|
+
if (!((_a = event.databaseEntity) === null || _a === void 0 ? void 0 : _a.id))
|
49
|
+
return true;
|
50
|
+
if (!Array.isArray(column)) {
|
51
|
+
if (event.updatedColumns.indexOf(column) !== -1)
|
52
|
+
return true;
|
53
|
+
return false;
|
54
|
+
}
|
55
|
+
for (const item of column) {
|
56
|
+
if (event.updatedColumns.indexOf(item) !== -1)
|
57
|
+
return true;
|
58
|
+
}
|
59
|
+
return false;
|
60
60
|
}
|
61
61
|
}
|
62
62
|
exports.CommonJob = CommonJob;
|
@@ -1 +1 @@
|
|
1
|
-
{"version":3,"file":"common.job.js","sourceRoot":"","sources":["../../../src/common/libraries/common.job.ts"],"names":[],"mappings":"
|
1
|
+
{"version":3,"file":"common.job.js","sourceRoot":"","sources":["../../../src/common/libraries/common.job.ts"],"names":[],"mappings":"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"}
|
@@ -1,13 +1,4 @@
|
|
1
1
|
"use strict";
|
2
|
-
var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
|
3
|
-
function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
|
4
|
-
return new (P || (P = Promise))(function (resolve, reject) {
|
5
|
-
function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
|
6
|
-
function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
|
7
|
-
function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
|
8
|
-
step((generator = generator.apply(thisArg, _arguments || [])).next());
|
9
|
-
});
|
10
|
-
};
|
11
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
12
3
|
exports.CommonMapperJob = void 0;
|
13
4
|
const common_job_1 = require("./common.job");
|
@@ -17,34 +8,28 @@ class CommonMapperJob extends common_job_1.CommonJob {
|
|
17
8
|
this.mapping = {};
|
18
9
|
this.baseColumn = '';
|
19
10
|
}
|
20
|
-
handle(data) {
|
21
|
-
|
22
|
-
|
23
|
-
|
24
|
-
return this.addMapping(data);
|
25
|
-
});
|
11
|
+
async handle(data) {
|
12
|
+
if (data.deleted_at)
|
13
|
+
return this.removeMapping(data);
|
14
|
+
return this.addMapping(data);
|
26
15
|
}
|
27
|
-
addMapping(data) {
|
28
|
-
|
29
|
-
|
30
|
-
|
31
|
-
|
32
|
-
|
33
|
-
|
34
|
-
|
35
|
-
return mapping.entity.firstOrCreate(params);
|
36
|
-
});
|
16
|
+
async addMapping(data) {
|
17
|
+
const mapping = this.mapping[data.source_type];
|
18
|
+
if (!mapping)
|
19
|
+
return;
|
20
|
+
const params = {};
|
21
|
+
params[this.baseColumn] = data.id;
|
22
|
+
params[mapping.column] = data.source_id;
|
23
|
+
return mapping.entity.firstOrCreate(params);
|
37
24
|
}
|
38
|
-
removeMapping(data) {
|
39
|
-
|
40
|
-
|
41
|
-
|
42
|
-
|
43
|
-
|
44
|
-
|
45
|
-
|
46
|
-
return mapping.entity.destroy(params);
|
47
|
-
});
|
25
|
+
async removeMapping(data) {
|
26
|
+
const mapping = this.mapping[data.source_type];
|
27
|
+
if (!mapping)
|
28
|
+
return;
|
29
|
+
const params = {};
|
30
|
+
params[this.baseColumn] = data.id;
|
31
|
+
params[mapping.column] = data.source_id;
|
32
|
+
return mapping.entity.destroy(params);
|
48
33
|
}
|
49
34
|
}
|
50
35
|
exports.CommonMapperJob = CommonMapperJob;
|
@@ -1 +1 @@
|
|
1
|
-
{"version":3,"file":"common.mapper.job.js","sourceRoot":"","sources":["../../../src/common/libraries/common.mapper.job.ts"],"names":[],"mappings":"
|
1
|
+
{"version":3,"file":"common.mapper.job.js","sourceRoot":"","sources":["../../../src/common/libraries/common.mapper.job.ts"],"names":[],"mappings":";;;AAAA,6CAAyC;AASzC,MAAa,eAAmB,SAAQ,sBAAS;IAAjD;;QAMc,YAAO,GAAG,EAAE,CAAC;QAOb,eAAU,GAAG,EAAE,CAAC;IAiD9B,CAAC;IAzCG,KAAK,CAAC,MAAM,CAAC,IAAS;QAClB,IAAI,IAAI,CAAC,UAAU;YAAE,OAAO,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,CAAC;QAErD,OAAO,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,CAAC;IACjC,CAAC;IAQD,KAAK,CAAC,UAAU,CAAC,IAAS;QACtB,MAAM,OAAO,GAAG,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,WAAW,CAAC,CAAC;QAC/C,IAAI,CAAC,OAAO;YAAE,OAAO;QAErB,MAAM,MAAM,GAAG,EAAE,CAAC;QAElB,MAAM,CAAC,IAAI,CAAC,UAAU,CAAC,GAAG,IAAI,CAAC,EAAE,CAAC;QAClC,MAAM,CAAC,OAAO,CAAC,MAAM,CAAC,GAAG,IAAI,CAAC,SAAS,CAAC;QAExC,OAAO,OAAO,CAAC,MAAM,CAAC,aAAa,CAAC,MAAM,CAAC,CAAC;IAChD,CAAC;IAQD,KAAK,CAAC,aAAa,CAAC,IAAS;QACzB,MAAM,OAAO,GAAG,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,WAAW,CAAC,CAAC;QAC/C,IAAI,CAAC,OAAO;YAAE,OAAO;QAErB,MAAM,MAAM,GAAG,EAAE,CAAC;QAElB,MAAM,CAAC,IAAI,CAAC,UAAU,CAAC,GAAG,IAAI,CAAC,EAAE,CAAC;QAClC,MAAM,CAAC,OAAO,CAAC,MAAM,CAAC,GAAG,IAAI,CAAC,SAAS,CAAC;QAExC,OAAO,OAAO,CAAC,MAAM,CAAC,OAAO,CAAC,MAAM,CAAC,CAAC;IAC1C,CAAC;CACJ;AA9DD,0CA8DC"}
|
@@ -1,13 +1,4 @@
|
|
1
1
|
"use strict";
|
2
|
-
var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
|
3
|
-
function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
|
4
|
-
return new (P || (P = Promise))(function (resolve, reject) {
|
5
|
-
function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
|
6
|
-
function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
|
7
|
-
function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
|
8
|
-
step((generator = generator.apply(thisArg, _arguments || [])).next());
|
9
|
-
});
|
10
|
-
};
|
11
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
12
3
|
exports.CommonSubscriber = void 0;
|
13
4
|
const auth_1 = require("./auth");
|
@@ -43,9 +34,7 @@ class CommonSubscriber {
|
|
43
34
|
});
|
44
35
|
return updates;
|
45
36
|
}
|
46
|
-
afterRemove(event) {
|
47
|
-
return __awaiter(this, void 0, void 0, function* () {
|
48
|
-
});
|
37
|
+
async afterRemove(event) {
|
49
38
|
}
|
50
39
|
isColumnUpdated(event, column) {
|
51
40
|
const updates = this.getUpdatedRecords(event);
|
@@ -57,11 +46,9 @@ class CommonSubscriber {
|
|
57
46
|
return true;
|
58
47
|
return false;
|
59
48
|
}
|
60
|
-
commitTransaction(queryRunner) {
|
61
|
-
|
62
|
-
|
63
|
-
yield queryRunner.startTransaction();
|
64
|
-
});
|
49
|
+
async commitTransaction(queryRunner) {
|
50
|
+
await queryRunner.commitTransaction();
|
51
|
+
await queryRunner.startTransaction();
|
65
52
|
}
|
66
53
|
}
|
67
54
|
exports.CommonSubscriber = CommonSubscriber;
|
@@ -1 +1 @@
|
|
1
|
-
{"version":3,"file":"common.subscriber.js","sourceRoot":"","sources":["../../../src/common/libraries/common.subscriber.ts"],"names":[],"mappings":"
|
1
|
+
{"version":3,"file":"common.subscriber.js","sourceRoot":"","sources":["../../../src/common/libraries/common.subscriber.ts"],"names":[],"mappings":";;;AAEA,iCAA8B;AAS9B,MAAa,gBAAgB;IAQf,kBAAkB,CAAC,KAAK;QAC9B,OAAO;YACH,MAAM,EAAE,KAAK,CAAC,MAAM;YACpB,cAAc,EAAE,IAAI,CAAC,iBAAiB,CAAC,KAAK,CAAC;YAC7C,QAAQ,EAAE,IAAI,CAAC,WAAW,CAAC,KAAK,CAAC;YACjC,cAAc,EAAE,KAAK,CAAC,cAAc;YACpC,IAAI,EAAE,WAAI,CAAC,IAAI,EAAE;SACpB,CAAC;IACN,CAAC;IASS,kBAAkB,CAAC,KAAK;QAC9B,OAAO;YACH,MAAM,EAAE,KAAK,CAAC,MAAM;YACpB,QAAQ,EAAE,IAAI,CAAC,WAAW,CAAC,KAAK,CAAC;YACjC,IAAI,EAAE,WAAI,CAAC,IAAI,EAAE;YACjB,cAAc,EAAE,EAAE;SACrB,CAAC;IACN,CAAC;IASO,WAAW,CAAC,KAAK;QACrB,OAAO;YACH,SAAS,EAAE,KAAK,CAAC,QAAQ,CAAC,SAAS;YACnC,IAAI,EAAE,KAAK,CAAC,QAAQ,CAAC,IAAI;SAC5B,CAAC;IACN,CAAC;IASO,iBAAiB,CAAC,KAAK;QAC3B,MAAM,OAAO,GAAG,EAAE,CAAC;QAEnB,KAAK,CAAC,cAAc,CAAC,OAAO,CAAC,CAAC,MAAM,EAAE,EAAE;YACpC,IAAI,OAAO,CAAC,OAAO,CAAC,MAAM,CAAC,YAAY,CAAC,KAAK,CAAC,CAAC;gBAAE,OAAO,CAAC,IAAI,CAAC,MAAM,CAAC,YAAY,CAAC,CAAC;QACvF,CAAC,CAAC,CAAC;QAEH,OAAO,OAAO,CAAC;IACnB,CAAC;IAOD,KAAK,CAAC,WAAW,CAAC,KAAqB;IAEvC,CAAC;IAUD,eAAe,CAAC,KAAU,EAAE,MAAc;QACtC,MAAM,OAAO,GAAG,IAAI,CAAC,iBAAiB,CAAC,KAAK,CAAC,CAAC;QAC9C,MAAM,cAAc,GAAG,KAAK,CAAC,OAAO,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,CAAC,GAAG,MAAM,CAAC,CAAC,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC;QAEtE,OAAO,OAAO,CAAC,IAAI,CAAC,CAAC,IAAI,EAAE,EAAE,CAAC,cAAc,CAAC,QAAQ,CAAC,IAAI,CAAC,CAAC,CAAC;IACjE,CAAC;IASS,aAAa,CAAC,KAAK;QACzB,IAAI,KAAK,CAAC,MAAM,CAAC,UAAU;YAAE,OAAO,IAAI,CAAC;QAEzC,OAAO,KAAK,CAAC;IACjB,CAAC;IAQS,KAAK,CAAC,iBAAiB,CAAC,WAAwB;QACtD,MAAM,WAAW,CAAC,iBAAiB,EAAE,CAAC;QACtC,MAAM,WAAW,CAAC,gBAAgB,EAAE,CAAC;IACzC,CAAC;CACJ;AAhHD,4CAgHC"}
|