@campxdev/server-shared 1.5.8 → 1.5.10
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/common/config/mongo.config.d.ts +1 -0
- package/dist/common/config/mongo.config.d.ts.map +1 -1
- package/dist/common/config/mongo.config.js +2 -3
- package/dist/common/config/mongo.config.js.map +1 -1
- package/dist/data-imports-manager/data-import-consumer.module.d.ts +21 -0
- package/dist/data-imports-manager/data-import-consumer.module.d.ts.map +1 -0
- package/dist/data-imports-manager/data-import-consumer.module.js +141 -0
- package/dist/data-imports-manager/data-import-consumer.module.js.map +1 -0
- package/dist/data-imports-manager/data-import-manager.module.d.ts +3 -0
- package/dist/data-imports-manager/data-import-manager.module.d.ts.map +1 -0
- package/dist/data-imports-manager/data-import-manager.module.js +25 -0
- package/dist/data-imports-manager/data-import-manager.module.js.map +1 -0
- package/dist/data-imports-manager/data-import-manager.service.d.ts +78 -0
- package/dist/data-imports-manager/data-import-manager.service.d.ts.map +1 -0
- package/dist/data-imports-manager/data-import-manager.service.js +120 -0
- package/dist/data-imports-manager/data-import-manager.service.js.map +1 -0
- package/dist/data-imports-manager/data-import.resource.d.ts +15 -0
- package/dist/data-imports-manager/data-import.resource.d.ts.map +1 -0
- package/dist/data-imports-manager/data-import.resource.js +87 -0
- package/dist/data-imports-manager/data-import.resource.js.map +1 -0
- package/dist/data-imports-manager/index.d.ts +4 -0
- package/dist/data-imports-manager/index.d.ts.map +1 -0
- package/dist/data-imports-manager/index.js +20 -0
- package/dist/data-imports-manager/index.js.map +1 -0
- package/dist/domain/index.d.ts +3 -0
- package/dist/domain/index.d.ts.map +1 -1
- package/dist/domain/index.js +3 -0
- package/dist/domain/index.js.map +1 -1
- package/dist/domain/modules/shared-domain.module.d.ts.map +1 -1
- package/dist/domain/modules/shared-domain.module.js +9 -1
- package/dist/domain/modules/shared-domain.module.js.map +1 -1
- package/dist/domain/mongodb-repositories/mongodb-data-imports.repository.d.ts +42 -0
- package/dist/domain/mongodb-repositories/mongodb-data-imports.repository.d.ts.map +1 -0
- package/dist/domain/mongodb-repositories/mongodb-data-imports.repository.js +66 -0
- package/dist/domain/mongodb-repositories/mongodb-data-imports.repository.js.map +1 -0
- package/dist/domain/repositories/data-import.repository.d.ts +13 -0
- package/dist/domain/repositories/data-import.repository.d.ts.map +1 -0
- package/dist/domain/repositories/data-import.repository.js +7 -0
- package/dist/domain/repositories/data-import.repository.js.map +1 -0
- package/dist/domain/schemas/admission.schema.d.ts.map +1 -1
- package/dist/domain/schemas/admission.schema.js +2 -0
- package/dist/domain/schemas/admission.schema.js.map +1 -1
- package/dist/domain/schemas/data-import.schema.d.ts +60 -0
- package/dist/domain/schemas/data-import.schema.d.ts.map +1 -0
- package/dist/domain/schemas/data-import.schema.js +87 -0
- package/dist/domain/schemas/data-import.schema.js.map +1 -0
- package/dist/index.d.ts +1 -0
- package/dist/index.d.ts.map +1 -1
- package/dist/index.js +1 -0
- package/dist/index.js.map +1 -1
- package/dist/media/managers/aws.manager.d.ts +3 -0
- package/dist/media/managers/aws.manager.d.ts.map +1 -1
- package/dist/media/managers/aws.manager.js +12 -0
- package/dist/media/managers/aws.manager.js.map +1 -1
- package/dist/media/managers/media-records-manager.d.ts +1 -0
- package/dist/media/managers/media-records-manager.d.ts.map +1 -1
- package/dist/media/managers/media-records-manager.js +3 -0
- package/dist/media/managers/media-records-manager.js.map +1 -1
- package/dist/permissions/app-permissions/exams-permissions.d.ts +108 -0
- package/dist/permissions/app-permissions/exams-permissions.d.ts.map +1 -1
- package/dist/permissions/app-permissions/exams-permissions.js +128 -0
- package/dist/permissions/app-permissions/exams-permissions.js.map +1 -1
- package/dist/permissions/permissions.d.ts +216 -0
- package/dist/permissions/permissions.d.ts.map +1 -1
- package/dist/request-store/request-store.d.ts +2 -1
- package/dist/request-store/request-store.d.ts.map +1 -1
- package/dist/request-store/request-store.js +3 -1
- package/dist/request-store/request-store.js.map +1 -1
- package/dist/utils/constants.d.ts +7 -0
- package/dist/utils/constants.d.ts.map +1 -1
- package/dist/utils/constants.js +8 -1
- package/dist/utils/constants.js.map +1 -1
- package/dist/utils/utils.d.ts +2 -0
- package/dist/utils/utils.d.ts.map +1 -1
- package/dist/utils/utils.js +20 -1
- package/dist/utils/utils.js.map +1 -1
- package/package.json +6 -2
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"mongo.config.d.ts","sourceRoot":"","sources":["../../../src/common/config/mongo.config.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,aAAa,EAAE,MAAM,gBAAgB,CAAC;AAE/C,eAAO,MAAM,aAAa,kBAAmB,aAAa
|
|
1
|
+
{"version":3,"file":"mongo.config.d.ts","sourceRoot":"","sources":["../../../src/common/config/mongo.config.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,aAAa,EAAE,MAAM,gBAAgB,CAAC;AAE/C,eAAO,MAAM,aAAa,kBAAmB,aAAa;;;CAYzD,CAAC;AAEF,eAAO,MAAM,WAAW;;CAsBvB,CAAC"}
|
|
@@ -10,9 +10,8 @@ const mongoConfigV1 = (configService) => {
|
|
|
10
10
|
const AUTH = `${username}:${password}`;
|
|
11
11
|
const DB = `${DB_HOST}/${DB_NAME}`;
|
|
12
12
|
const MONGO_URI = `mongodb+srv://${AUTH}@${DB}?retryWrites=true&w=majority`;
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
};
|
|
13
|
+
const AUTO_INDEX = configService.get('MONGO_DB_AUTO_INDEX') === 'true';
|
|
14
|
+
return { MONGO_URI, AUTO_INDEX };
|
|
16
15
|
};
|
|
17
16
|
exports.mongoConfigV1 = mongoConfigV1;
|
|
18
17
|
const mongoConfig = () => {
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"mongo.config.js","sourceRoot":"","sources":["../../../src/common/config/mongo.config.ts"],"names":[],"mappings":";;;AAAA,2CAA8D;AAGvD,MAAM,aAAa,GAAG,CAAC,aAA4B,EAAE,EAAE;IAC5D,MAAM,QAAQ,GAAG,kBAAkB,CAAC,aAAa,CAAC,GAAG,CAAC,mBAAmB,CAAC,IAAI,EAAE,CAAC,CAAC;IAClF,MAAM,QAAQ,GAAG,kBAAkB,CAAC,aAAa,CAAC,GAAG,CAAC,mBAAmB,CAAC,IAAI,EAAE,CAAC,CAAC;IAClF,MAAM,OAAO,GAAG,aAAa,CAAC,GAAG,CAAC,eAAe,CAAC,IAAI,EAAE,CAAC;IACzD,MAAM,OAAO,GAAG,aAAa,CAAC,GAAG,CAAC,eAAe,CAAC,IAAI,EAAE,CAAC;IACzD,MAAM,IAAI,GAAG,GAAG,QAAQ,IAAI,QAAQ,EAAE,CAAC;IACvC,MAAM,EAAE,GAAG,GAAG,OAAO,IAAI,OAAO,EAAE,CAAC;IACnC,MAAM,SAAS,GAAG,iBAAiB,IAAI,IAAI,EAAE,8BAA8B,CAAC;IAE5E,
|
|
1
|
+
{"version":3,"file":"mongo.config.js","sourceRoot":"","sources":["../../../src/common/config/mongo.config.ts"],"names":[],"mappings":";;;AAAA,2CAA8D;AAGvD,MAAM,aAAa,GAAG,CAAC,aAA4B,EAAE,EAAE;IAC5D,MAAM,QAAQ,GAAG,kBAAkB,CAAC,aAAa,CAAC,GAAG,CAAC,mBAAmB,CAAC,IAAI,EAAE,CAAC,CAAC;IAClF,MAAM,QAAQ,GAAG,kBAAkB,CAAC,aAAa,CAAC,GAAG,CAAC,mBAAmB,CAAC,IAAI,EAAE,CAAC,CAAC;IAClF,MAAM,OAAO,GAAG,aAAa,CAAC,GAAG,CAAC,eAAe,CAAC,IAAI,EAAE,CAAC;IACzD,MAAM,OAAO,GAAG,aAAa,CAAC,GAAG,CAAC,eAAe,CAAC,IAAI,EAAE,CAAC;IACzD,MAAM,IAAI,GAAG,GAAG,QAAQ,IAAI,QAAQ,EAAE,CAAC;IACvC,MAAM,EAAE,GAAG,GAAG,OAAO,IAAI,OAAO,EAAE,CAAC;IACnC,MAAM,SAAS,GAAG,iBAAiB,IAAI,IAAI,EAAE,8BAA8B,CAAC;IAE5E,MAAM,UAAU,GAAG,aAAa,CAAC,GAAG,CAAC,qBAAqB,CAAC,KAAK,MAAM,CAAC;IAEvE,OAAO,EAAE,SAAS,EAAE,UAAU,EAAE,CAAC;AACnC,CAAC,CAAC;AAZW,QAAA,aAAa,iBAYxB;AAEK,MAAM,WAAW,GAAG,GAAG,EAAE;IAC9B,IACE,CAAC,OAAO,CAAC,GAAG,CAAC,iBAAiB;QAC9B,CAAC,OAAO,CAAC,GAAG,CAAC,iBAAiB;QAC9B,CAAC,OAAO,CAAC,GAAG,CAAC,aAAa;QAC1B,CAAC,OAAO,CAAC,GAAG,CAAC,aAAa,EAC1B,CAAC;QACD,MAAM,IAAI,qCAA4B,CACpC,kGAAkG,CACnG,CAAC;IACJ,CAAC;IACD,MAAM,QAAQ,GAAG,kBAAkB,CAAC,OAAO,CAAC,GAAG,CAAC,iBAAiB,CAAC,CAAC;IACnE,MAAM,QAAQ,GAAG,kBAAkB,CAAC,OAAO,CAAC,GAAG,CAAC,iBAAiB,CAAC,CAAC;IACnE,MAAM,OAAO,GAAG,OAAO,CAAC,GAAG,CAAC,aAAa,CAAC;IAC1C,MAAM,OAAO,GAAG,OAAO,CAAC,GAAG,CAAC,aAAa,CAAC;IAC1C,MAAM,IAAI,GAAG,GAAG,QAAQ,IAAI,QAAQ,EAAE,CAAC;IACvC,MAAM,EAAE,GAAG,GAAG,OAAO,IAAI,OAAO,EAAE,CAAC;IACnC,MAAM,SAAS,GAAG,iBAAiB,IAAI,IAAI,EAAE,8BAA8B,CAAC;IAE5E,OAAO;QACL,SAAS;KACV,CAAC;AACJ,CAAC,CAAC;AAtBW,QAAA,WAAW,eAsBtB"}
|
|
@@ -0,0 +1,21 @@
|
|
|
1
|
+
import { Message, SQSClient } from '@aws-sdk/client-sqs';
|
|
2
|
+
import { DynamicModule } from '@nestjs/common';
|
|
3
|
+
export declare class DataImportConsumerService {
|
|
4
|
+
readonly queueName: string;
|
|
5
|
+
readonly queueUrl: string;
|
|
6
|
+
private readonly sqsClient;
|
|
7
|
+
private readonly interval;
|
|
8
|
+
private readonly visibilityTimeout;
|
|
9
|
+
constructor(queueName: string, queueUrl: string, sqsClient: SQSClient, interval?: number, visibilityTimeout?: number);
|
|
10
|
+
processMessage<T>(message: Message, process: (body: Record<string, any>) => Promise<T> | T): Promise<T>;
|
|
11
|
+
}
|
|
12
|
+
export declare class DataImportConsumerModule {
|
|
13
|
+
static forRoot(props: {
|
|
14
|
+
queueName: string;
|
|
15
|
+
name: string;
|
|
16
|
+
envQueueKey?: string;
|
|
17
|
+
timerInterval?: number;
|
|
18
|
+
visibilityTimeout?: number;
|
|
19
|
+
}): DynamicModule;
|
|
20
|
+
}
|
|
21
|
+
//# sourceMappingURL=data-import-consumer.module.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"data-import-consumer.module.d.ts","sourceRoot":"","sources":["../../src/data-imports-manager/data-import-consumer.module.ts"],"names":[],"mappings":"AAAA,OAAO,EAGL,OAAO,EACP,SAAS,EACV,MAAM,qBAAqB,CAAC;AAC7B,OAAO,EAAE,aAAa,EAAwC,MAAM,gBAAgB,CAAC;AAIrF,qBAAa,yBAAyB;aAElB,SAAS,EAAE,MAAM;aACjB,QAAQ,EAAE,MAAM;IAChC,OAAO,CAAC,QAAQ,CAAC,SAAS;IAC1B,OAAO,CAAC,QAAQ,CAAC,QAAQ;IACzB,OAAO,CAAC,QAAQ,CAAC,iBAAiB;gBAJlB,SAAS,EAAE,MAAM,EACjB,QAAQ,EAAE,MAAM,EACf,SAAS,EAAE,SAAS,EACpB,QAAQ,GAAE,MAAW,EACrB,iBAAiB,GAAE,MAAW;IAG3C,cAAc,CAAC,CAAC,EACpB,OAAO,EAAE,OAAO,EAChB,OAAO,EAAE,CAAC,IAAI,EAAE,MAAM,CAAC,MAAM,EAAE,GAAG,CAAC,KAAK,OAAO,CAAC,CAAC,CAAC,GAAG,CAAC;CAkCzD;AAED,qBACa,wBAAwB;IACnC,MAAM,CAAC,OAAO,CAAC,KAAK,EAAE;QACpB,SAAS,EAAE,MAAM,CAAC;QAClB,IAAI,EAAE,MAAM,CAAC;QACb,WAAW,CAAC,EAAE,MAAM,CAAC;QACrB,aAAa,CAAC,EAAE,MAAM,CAAC;QACvB,iBAAiB,CAAC,EAAE,MAAM,CAAC;KAC5B,GAAG,aAAa;CAmDlB"}
|
|
@@ -0,0 +1,141 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {
|
|
3
|
+
var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
|
|
4
|
+
if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
|
|
5
|
+
else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
|
|
6
|
+
return c > 3 && r && Object.defineProperty(target, key, r), r;
|
|
7
|
+
};
|
|
8
|
+
var DataImportConsumerModule_1;
|
|
9
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
10
|
+
exports.DataImportConsumerModule = exports.DataImportConsumerService = void 0;
|
|
11
|
+
const client_sqs_1 = require("@aws-sdk/client-sqs");
|
|
12
|
+
const common_1 = require("@nestjs/common");
|
|
13
|
+
const config_1 = require("@nestjs/config");
|
|
14
|
+
const nestjs_sqs_1 = require("@ssut/nestjs-sqs");
|
|
15
|
+
class DataImportConsumerService {
|
|
16
|
+
constructor(queueName, queueUrl, sqsClient, interval = 25, visibilityTimeout = 40) {
|
|
17
|
+
this.queueName = queueName;
|
|
18
|
+
this.queueUrl = queueUrl;
|
|
19
|
+
this.sqsClient = sqsClient;
|
|
20
|
+
this.interval = interval;
|
|
21
|
+
this.visibilityTimeout = visibilityTimeout;
|
|
22
|
+
}
|
|
23
|
+
async processMessage(message, process) {
|
|
24
|
+
console.log('Received message:', message);
|
|
25
|
+
const timer = setInterval(async () => {
|
|
26
|
+
const changeMessageVisibilityCommand = new client_sqs_1.ChangeMessageVisibilityCommand({
|
|
27
|
+
QueueUrl: this.queueUrl,
|
|
28
|
+
ReceiptHandle: message.ReceiptHandle,
|
|
29
|
+
VisibilityTimeout: this.visibilityTimeout,
|
|
30
|
+
});
|
|
31
|
+
try {
|
|
32
|
+
await this.sqsClient.send(changeMessageVisibilityCommand);
|
|
33
|
+
console.log('Visibility timeout updated successfully');
|
|
34
|
+
}
|
|
35
|
+
catch (err) {
|
|
36
|
+
console.log('error updating Visibility timeout', err);
|
|
37
|
+
}
|
|
38
|
+
}, 1000 * this.interval);
|
|
39
|
+
let body = {};
|
|
40
|
+
try {
|
|
41
|
+
body = JSON.parse(message.Body);
|
|
42
|
+
}
|
|
43
|
+
catch (error) {
|
|
44
|
+
console.error('error', error);
|
|
45
|
+
}
|
|
46
|
+
try {
|
|
47
|
+
return await process(body);
|
|
48
|
+
}
|
|
49
|
+
catch (error) {
|
|
50
|
+
console.error('error', error);
|
|
51
|
+
}
|
|
52
|
+
finally {
|
|
53
|
+
clearInterval(timer);
|
|
54
|
+
}
|
|
55
|
+
}
|
|
56
|
+
}
|
|
57
|
+
exports.DataImportConsumerService = DataImportConsumerService;
|
|
58
|
+
let DataImportConsumerModule = DataImportConsumerModule_1 = class DataImportConsumerModule {
|
|
59
|
+
static forRoot(props) {
|
|
60
|
+
let queueUrl = '';
|
|
61
|
+
let client;
|
|
62
|
+
return {
|
|
63
|
+
module: DataImportConsumerModule_1,
|
|
64
|
+
imports: [
|
|
65
|
+
nestjs_sqs_1.SqsModule.registerAsync({
|
|
66
|
+
inject: [config_1.ConfigService],
|
|
67
|
+
useFactory: async (configService) => {
|
|
68
|
+
const result = await generateQueue({
|
|
69
|
+
configService,
|
|
70
|
+
queueName: props.queueName,
|
|
71
|
+
envQueueKey: props.envQueueKey,
|
|
72
|
+
});
|
|
73
|
+
queueUrl = result.queueUrl;
|
|
74
|
+
client = result.client;
|
|
75
|
+
return {
|
|
76
|
+
consumers: configService.get('DISABLE_QUEUE') != true
|
|
77
|
+
? [
|
|
78
|
+
{
|
|
79
|
+
name: props.name,
|
|
80
|
+
queueUrl: queueUrl,
|
|
81
|
+
batchSize: 10,
|
|
82
|
+
region: configService.get('AWS_REGION'),
|
|
83
|
+
},
|
|
84
|
+
]
|
|
85
|
+
: [],
|
|
86
|
+
};
|
|
87
|
+
},
|
|
88
|
+
}),
|
|
89
|
+
],
|
|
90
|
+
providers: [
|
|
91
|
+
{
|
|
92
|
+
provide: DataImportConsumerService,
|
|
93
|
+
useFactory: () => {
|
|
94
|
+
return new DataImportConsumerService(props.queueName, queueUrl, client, props.timerInterval, props.visibilityTimeout);
|
|
95
|
+
},
|
|
96
|
+
},
|
|
97
|
+
],
|
|
98
|
+
exports: [nestjs_sqs_1.SqsModule, DataImportConsumerService],
|
|
99
|
+
};
|
|
100
|
+
}
|
|
101
|
+
};
|
|
102
|
+
exports.DataImportConsumerModule = DataImportConsumerModule;
|
|
103
|
+
exports.DataImportConsumerModule = DataImportConsumerModule = DataImportConsumerModule_1 = __decorate([
|
|
104
|
+
(0, common_1.Module)({})
|
|
105
|
+
], DataImportConsumerModule);
|
|
106
|
+
async function generateQueue(props) {
|
|
107
|
+
const { configService } = props;
|
|
108
|
+
let queueName = props.queueName;
|
|
109
|
+
if (props.envQueueKey && configService.get(props.envQueueKey)) {
|
|
110
|
+
queueName = configService.get(props.envQueueKey);
|
|
111
|
+
}
|
|
112
|
+
const accessKey = configService.get('AWS_ACCESS_KEY_ID');
|
|
113
|
+
const secretAccessKey = configService.get('AWS_SECRET_ACCESS_KEY');
|
|
114
|
+
const region = configService.get('AWS_REGION');
|
|
115
|
+
const sqsClient = new client_sqs_1.SQSClient({
|
|
116
|
+
region: region,
|
|
117
|
+
credentials: {
|
|
118
|
+
accessKeyId: accessKey,
|
|
119
|
+
secretAccessKey: secretAccessKey,
|
|
120
|
+
},
|
|
121
|
+
});
|
|
122
|
+
const command = new client_sqs_1.CreateQueueCommand({
|
|
123
|
+
QueueName: queueName,
|
|
124
|
+
Attributes: {
|
|
125
|
+
VisibilityTimeout: '30',
|
|
126
|
+
FifoQueue: 'true',
|
|
127
|
+
},
|
|
128
|
+
});
|
|
129
|
+
try {
|
|
130
|
+
const result = await sqsClient.send(command);
|
|
131
|
+
return {
|
|
132
|
+
client: sqsClient,
|
|
133
|
+
queueUrl: result.QueueUrl,
|
|
134
|
+
};
|
|
135
|
+
}
|
|
136
|
+
catch (err) {
|
|
137
|
+
console.error('Queue Creation field', err);
|
|
138
|
+
throw new common_1.UnprocessableEntityException('Unable to create queue');
|
|
139
|
+
}
|
|
140
|
+
}
|
|
141
|
+
//# sourceMappingURL=data-import-consumer.module.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"data-import-consumer.module.js","sourceRoot":"","sources":["../../src/data-imports-manager/data-import-consumer.module.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"data-import-manager.module.d.ts","sourceRoot":"","sources":["../../src/data-imports-manager/data-import-manager.module.ts"],"names":[],"mappings":"AAMA,qBAKa,uBAAuB;CAAG"}
|
|
@@ -0,0 +1,25 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {
|
|
3
|
+
var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
|
|
4
|
+
if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
|
|
5
|
+
else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
|
|
6
|
+
return c > 3 && r && Object.defineProperty(target, key, r), r;
|
|
7
|
+
};
|
|
8
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
9
|
+
exports.DataImportManagerModule = void 0;
|
|
10
|
+
const common_1 = require("@nestjs/common");
|
|
11
|
+
const domain_1 = require("../domain");
|
|
12
|
+
const media_1 = require("../media");
|
|
13
|
+
const data_import_manager_service_1 = require("./data-import-manager.service");
|
|
14
|
+
const data_import_resource_1 = require("./data-import.resource");
|
|
15
|
+
let DataImportManagerModule = class DataImportManagerModule {
|
|
16
|
+
};
|
|
17
|
+
exports.DataImportManagerModule = DataImportManagerModule;
|
|
18
|
+
exports.DataImportManagerModule = DataImportManagerModule = __decorate([
|
|
19
|
+
(0, common_1.Module)({
|
|
20
|
+
imports: [domain_1.SharedDomainModule, media_1.MediaModule],
|
|
21
|
+
providers: [data_import_resource_1.DataImportResource, data_import_manager_service_1.DataImportManagerService],
|
|
22
|
+
exports: [data_import_manager_service_1.DataImportManagerService],
|
|
23
|
+
})
|
|
24
|
+
], DataImportManagerModule);
|
|
25
|
+
//# sourceMappingURL=data-import-manager.module.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"data-import-manager.module.js","sourceRoot":"","sources":["../../src/data-imports-manager/data-import-manager.module.ts"],"names":[],"mappings":";;;;;;;;;AAAA,2CAAwC;AACxC,sCAA+C;AAC/C,oCAAuC;AACvC,+EAAyE;AACzE,iEAA4D;AAOrD,IAAM,uBAAuB,GAA7B,MAAM,uBAAuB;CAAG,CAAA;AAA1B,0DAAuB;kCAAvB,uBAAuB;IALnC,IAAA,eAAM,EAAC;QACN,OAAO,EAAE,CAAC,2BAAkB,EAAE,mBAAW,CAAC;QAC1C,SAAS,EAAE,CAAC,yCAAkB,EAAE,sDAAwB,CAAC;QACzD,OAAO,EAAE,CAAC,sDAAwB,CAAC;KACpC,CAAC;GACW,uBAAuB,CAAG"}
|
|
@@ -0,0 +1,78 @@
|
|
|
1
|
+
/// <reference types="node" />
|
|
2
|
+
import { DataImport, GlobalDataImportRepository } from '../domain';
|
|
3
|
+
import { DataImportResource } from './data-import.resource';
|
|
4
|
+
export type DataImportFieldDetails = {
|
|
5
|
+
requiredForCreate: boolean;
|
|
6
|
+
requiredForUpdate: boolean;
|
|
7
|
+
validation: (value: unknown | null, required: boolean) => {
|
|
8
|
+
value: unknown | null;
|
|
9
|
+
errors: string[];
|
|
10
|
+
};
|
|
11
|
+
};
|
|
12
|
+
export type DataImportField = DataImportFieldDetails & {
|
|
13
|
+
name: string;
|
|
14
|
+
};
|
|
15
|
+
export type DataImportFields<T> = {
|
|
16
|
+
[key in keyof Required<T>]: DataImportFieldDetails;
|
|
17
|
+
};
|
|
18
|
+
export type DataImportFieldError = {
|
|
19
|
+
index: number;
|
|
20
|
+
field: string;
|
|
21
|
+
messages: string[];
|
|
22
|
+
};
|
|
23
|
+
export type DataImportValidationResult<T> = {
|
|
24
|
+
fields: Array<DataImportFieldDetails & {
|
|
25
|
+
name: string;
|
|
26
|
+
}>;
|
|
27
|
+
data: Array<T>;
|
|
28
|
+
errors: Array<DataImportFieldError>;
|
|
29
|
+
};
|
|
30
|
+
export declare function getFile(url: string): Promise<Buffer>;
|
|
31
|
+
export declare function getDataFields<T extends Object>(validations: DataImportFields<T>): DataImportField[];
|
|
32
|
+
export declare function validateData<T>(props: {
|
|
33
|
+
fields: Array<DataImportFieldDetails & {
|
|
34
|
+
name: string;
|
|
35
|
+
}>;
|
|
36
|
+
docData: Array<T>;
|
|
37
|
+
importType: string;
|
|
38
|
+
}): {
|
|
39
|
+
data: T[];
|
|
40
|
+
errors: DataImportFieldError[];
|
|
41
|
+
fields: (DataImportFieldDetails & {
|
|
42
|
+
name: string;
|
|
43
|
+
})[];
|
|
44
|
+
};
|
|
45
|
+
export declare function validateFileData<T>(props: {
|
|
46
|
+
doc: DataImport;
|
|
47
|
+
forced: boolean;
|
|
48
|
+
fields: DataImportField[];
|
|
49
|
+
}): Promise<{
|
|
50
|
+
fields: (DataImportFieldDetails & {
|
|
51
|
+
name: string;
|
|
52
|
+
})[];
|
|
53
|
+
data: T[];
|
|
54
|
+
errors: DataImportFieldError[];
|
|
55
|
+
}>;
|
|
56
|
+
export interface IDataImportService<T> {
|
|
57
|
+
fieldValidations(): DataImportFields<T>;
|
|
58
|
+
fields(): Array<DataImportField>;
|
|
59
|
+
validate(doc: DataImport, forced?: boolean): Promise<{
|
|
60
|
+
success: boolean;
|
|
61
|
+
data: T[];
|
|
62
|
+
}>;
|
|
63
|
+
import(doc: DataImport): Promise<any>;
|
|
64
|
+
}
|
|
65
|
+
export interface DataImportHandler {
|
|
66
|
+
getFields(type: string): Promise<DataImportField[]>;
|
|
67
|
+
validateDataImport(id: string): Promise<void>;
|
|
68
|
+
queueUrl(): Promise<string>;
|
|
69
|
+
}
|
|
70
|
+
export declare class DataImportManagerService {
|
|
71
|
+
private readonly dataImportRepo;
|
|
72
|
+
readonly dataImportResource: DataImportResource;
|
|
73
|
+
constructor(dataImportRepo: GlobalDataImportRepository, dataImportResource: DataImportResource);
|
|
74
|
+
updateFileData(id: string, data: DataImportValidationResult<any>): Promise<void>;
|
|
75
|
+
failImport(id: string, error?: string): Promise<void>;
|
|
76
|
+
completeImport(id: string): Promise<void>;
|
|
77
|
+
}
|
|
78
|
+
//# sourceMappingURL=data-import-manager.service.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"data-import-manager.service.d.ts","sourceRoot":"","sources":["../../src/data-imports-manager/data-import-manager.service.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,120 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {
|
|
3
|
+
var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
|
|
4
|
+
if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
|
|
5
|
+
else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
|
|
6
|
+
return c > 3 && r && Object.defineProperty(target, key, r), r;
|
|
7
|
+
};
|
|
8
|
+
var __metadata = (this && this.__metadata) || function (k, v) {
|
|
9
|
+
if (typeof Reflect === "object" && typeof Reflect.metadata === "function") return Reflect.metadata(k, v);
|
|
10
|
+
};
|
|
11
|
+
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
12
|
+
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
13
|
+
};
|
|
14
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
15
|
+
exports.DataImportManagerService = exports.validateFileData = exports.validateData = exports.getDataFields = exports.getFile = void 0;
|
|
16
|
+
const common_1 = require("@nestjs/common");
|
|
17
|
+
const axios_1 = __importDefault(require("axios"));
|
|
18
|
+
const domain_1 = require("../domain");
|
|
19
|
+
const utils_1 = require("../utils");
|
|
20
|
+
const data_import_resource_1 = require("./data-import.resource");
|
|
21
|
+
async function getFile(url) {
|
|
22
|
+
const file = await axios_1.default.get(url, { responseType: 'arraybuffer' });
|
|
23
|
+
return file.data;
|
|
24
|
+
}
|
|
25
|
+
exports.getFile = getFile;
|
|
26
|
+
function getDataFields(validations) {
|
|
27
|
+
return Object.entries(validations).map(([name, value]) => {
|
|
28
|
+
return {
|
|
29
|
+
name: name,
|
|
30
|
+
...value,
|
|
31
|
+
};
|
|
32
|
+
});
|
|
33
|
+
}
|
|
34
|
+
exports.getDataFields = getDataFields;
|
|
35
|
+
function validateData(props) {
|
|
36
|
+
const { fields, docData, importType } = props;
|
|
37
|
+
const errors = [];
|
|
38
|
+
const data = [];
|
|
39
|
+
const headers = {};
|
|
40
|
+
docData.forEach((item, index) => {
|
|
41
|
+
const fieldErrors = [];
|
|
42
|
+
const validatedDataItem = {};
|
|
43
|
+
fields.forEach((field) => {
|
|
44
|
+
const value = item[field.name];
|
|
45
|
+
const required = importType === domain_1.DataImportImportTypes.INSERT
|
|
46
|
+
? field.requiredForCreate
|
|
47
|
+
: field.requiredForUpdate;
|
|
48
|
+
const { value: validatedValue, errors: validatedErrors } = field.validation(value, required);
|
|
49
|
+
validatedDataItem[field.name] = validatedValue;
|
|
50
|
+
if (validatedErrors.length) {
|
|
51
|
+
fieldErrors.push({
|
|
52
|
+
index: index,
|
|
53
|
+
field: field.name,
|
|
54
|
+
messages: validatedErrors,
|
|
55
|
+
});
|
|
56
|
+
}
|
|
57
|
+
if (validatedValue || required || validatedErrors.length) {
|
|
58
|
+
headers[field.name] = field;
|
|
59
|
+
}
|
|
60
|
+
});
|
|
61
|
+
errors.push(...fieldErrors);
|
|
62
|
+
data.push(validatedDataItem);
|
|
63
|
+
});
|
|
64
|
+
return { data: data, errors: errors, fields: Object.values(headers) };
|
|
65
|
+
}
|
|
66
|
+
exports.validateData = validateData;
|
|
67
|
+
async function validateFileData(props) {
|
|
68
|
+
const { doc, forced, fields } = props;
|
|
69
|
+
if (!doc.uploadedFile) {
|
|
70
|
+
throw new common_1.BadRequestException('No file uploaded');
|
|
71
|
+
}
|
|
72
|
+
if (doc.status === domain_1.DataImportStatus.COMPLETED) {
|
|
73
|
+
throw new common_1.BadRequestException('Data already imported');
|
|
74
|
+
}
|
|
75
|
+
if (doc.status === domain_1.DataImportStatus.IN_PROGRESS && !forced) {
|
|
76
|
+
throw new common_1.BadRequestException('Data import already in progress');
|
|
77
|
+
}
|
|
78
|
+
const fileBuffer = await getFile(doc.uploadedFile.url);
|
|
79
|
+
const docData = await (0, utils_1.xlsxBufferToJson)(fileBuffer);
|
|
80
|
+
const fileValidationRes = validateData({
|
|
81
|
+
docData: docData,
|
|
82
|
+
fields: fields,
|
|
83
|
+
importType: doc.importType,
|
|
84
|
+
});
|
|
85
|
+
if (forced && fileValidationRes.data.length === 0) {
|
|
86
|
+
throw new common_1.BadRequestException('No data to import');
|
|
87
|
+
}
|
|
88
|
+
return {
|
|
89
|
+
fields: fileValidationRes.fields,
|
|
90
|
+
data: fileValidationRes.data,
|
|
91
|
+
errors: fileValidationRes.errors,
|
|
92
|
+
};
|
|
93
|
+
}
|
|
94
|
+
exports.validateFileData = validateFileData;
|
|
95
|
+
let DataImportManagerService = class DataImportManagerService {
|
|
96
|
+
constructor(dataImportRepo, dataImportResource) {
|
|
97
|
+
this.dataImportRepo = dataImportRepo;
|
|
98
|
+
this.dataImportResource = dataImportResource;
|
|
99
|
+
}
|
|
100
|
+
async updateFileData(id, data) {
|
|
101
|
+
const fileData = await this.dataImportResource.uploadFileData({
|
|
102
|
+
typeId: id,
|
|
103
|
+
data: data,
|
|
104
|
+
});
|
|
105
|
+
await this.dataImportRepo.updateUploadedData(id, fileData);
|
|
106
|
+
}
|
|
107
|
+
async failImport(id, error) {
|
|
108
|
+
await this.dataImportRepo.failImport(id, error);
|
|
109
|
+
}
|
|
110
|
+
async completeImport(id) {
|
|
111
|
+
await this.dataImportRepo.completeImport(id);
|
|
112
|
+
}
|
|
113
|
+
};
|
|
114
|
+
exports.DataImportManagerService = DataImportManagerService;
|
|
115
|
+
exports.DataImportManagerService = DataImportManagerService = __decorate([
|
|
116
|
+
(0, common_1.Injectable)(),
|
|
117
|
+
__metadata("design:paramtypes", [domain_1.GlobalDataImportRepository,
|
|
118
|
+
data_import_resource_1.DataImportResource])
|
|
119
|
+
], DataImportManagerService);
|
|
120
|
+
//# sourceMappingURL=data-import-manager.service.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"data-import-manager.service.js","sourceRoot":"","sources":["../../src/data-imports-manager/data-import-manager.service.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,15 @@
|
|
|
1
|
+
/// <reference types="multer" />
|
|
2
|
+
import { MediaRecordsManager } from '../media';
|
|
3
|
+
export declare class DataImportResource {
|
|
4
|
+
private readonly manager;
|
|
5
|
+
constructor(manager: MediaRecordsManager);
|
|
6
|
+
uploadFile(props: {
|
|
7
|
+
file: Express.Multer.File;
|
|
8
|
+
typeId: string;
|
|
9
|
+
}): Promise<import("..").MediaRecord>;
|
|
10
|
+
uploadFileData(props: {
|
|
11
|
+
typeId: string;
|
|
12
|
+
data: any;
|
|
13
|
+
}): Promise<import("..").MediaRecord>;
|
|
14
|
+
}
|
|
15
|
+
//# sourceMappingURL=data-import.resource.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"data-import.resource.d.ts","sourceRoot":"","sources":["../../src/data-imports-manager/data-import.resource.ts"],"names":[],"mappings":";AACA,OAAO,EAAE,mBAAmB,EAAE,MAAM,UAAU,CAAC;AAQ/C,qBACa,kBAAkB;IACjB,OAAO,CAAC,QAAQ,CAAC,OAAO;gBAAP,OAAO,EAAE,mBAAmB;IAEnD,UAAU,CAAC,KAAK,EAAE;QAAE,IAAI,EAAE,OAAO,CAAC,MAAM,CAAC,IAAI,CAAC;QAAC,MAAM,EAAE,MAAM,CAAA;KAAE;IAqC/D,cAAc,CAAC,KAAK,EAAE;QAAE,MAAM,EAAE,MAAM,CAAC;QAAC,IAAI,EAAE,GAAG,CAAA;KAAE;CA6B1D"}
|
|
@@ -0,0 +1,87 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {
|
|
3
|
+
var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
|
|
4
|
+
if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
|
|
5
|
+
else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
|
|
6
|
+
return c > 3 && r && Object.defineProperty(target, key, r), r;
|
|
7
|
+
};
|
|
8
|
+
var __metadata = (this && this.__metadata) || function (k, v) {
|
|
9
|
+
if (typeof Reflect === "object" && typeof Reflect.metadata === "function") return Reflect.metadata(k, v);
|
|
10
|
+
};
|
|
11
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
12
|
+
exports.DataImportResource = void 0;
|
|
13
|
+
const common_1 = require("@nestjs/common");
|
|
14
|
+
const media_1 = require("../media");
|
|
15
|
+
const request_store_1 = require("../request-store");
|
|
16
|
+
const utils_1 = require("../utils");
|
|
17
|
+
const type = 'data-imports';
|
|
18
|
+
const subtype = 'files';
|
|
19
|
+
const dataSubtype = 'file-data';
|
|
20
|
+
let DataImportResource = class DataImportResource {
|
|
21
|
+
constructor(manager) {
|
|
22
|
+
this.manager = manager;
|
|
23
|
+
}
|
|
24
|
+
async uploadFile(props) {
|
|
25
|
+
const { file, typeId } = props;
|
|
26
|
+
if (!file) {
|
|
27
|
+
throw new common_1.BadRequestException('File is required');
|
|
28
|
+
}
|
|
29
|
+
const fileExtension = file.originalname.split('.').pop();
|
|
30
|
+
const fileName = `${(0, utils_1.generateId)()}.${fileExtension}`;
|
|
31
|
+
if (![`csv`, `xlsx`].includes(fileExtension.toLowerCase())) {
|
|
32
|
+
throw new common_1.BadRequestException('Invalid file type');
|
|
33
|
+
}
|
|
34
|
+
const previous = await this.manager.findMany({
|
|
35
|
+
type: type,
|
|
36
|
+
subtype: subtype,
|
|
37
|
+
typeId: typeId,
|
|
38
|
+
});
|
|
39
|
+
const result = await this.manager.uploadToS3bucket({
|
|
40
|
+
type: type,
|
|
41
|
+
subtype: subtype,
|
|
42
|
+
key: `${(0, request_store_1.getTenantDetails)().subDomain}/${type}/${subtype}/${typeId}/${fileName}`,
|
|
43
|
+
file: file,
|
|
44
|
+
typeId: typeId,
|
|
45
|
+
addContentDispositionName: true,
|
|
46
|
+
});
|
|
47
|
+
try {
|
|
48
|
+
await this.manager.deleteMany(previous);
|
|
49
|
+
}
|
|
50
|
+
catch (err) {
|
|
51
|
+
console.error('Error deleting previous file', err);
|
|
52
|
+
}
|
|
53
|
+
return result;
|
|
54
|
+
}
|
|
55
|
+
async uploadFileData(props) {
|
|
56
|
+
const fileName = `${(0, utils_1.generateId)()}.json`;
|
|
57
|
+
const previous = await this.manager.findMany({
|
|
58
|
+
type: type,
|
|
59
|
+
subtype: dataSubtype,
|
|
60
|
+
typeId: props.typeId,
|
|
61
|
+
});
|
|
62
|
+
const result = await this.manager.uploadBufferToS3bucket({
|
|
63
|
+
type: type,
|
|
64
|
+
subtype: dataSubtype,
|
|
65
|
+
key: `${(0, request_store_1.getTenantDetails)().subDomain}/${type}/${subtype}/${props.typeId}/${fileName}`,
|
|
66
|
+
buffer: Buffer.from(JSON.stringify(props.data)),
|
|
67
|
+
mimetype: 'application/json',
|
|
68
|
+
originalname: 'data.json',
|
|
69
|
+
typeId: props.typeId,
|
|
70
|
+
});
|
|
71
|
+
try {
|
|
72
|
+
if (previous) {
|
|
73
|
+
await this.manager.deleteMany(previous);
|
|
74
|
+
}
|
|
75
|
+
}
|
|
76
|
+
catch (err) {
|
|
77
|
+
console.error('Error deleting previous file', err);
|
|
78
|
+
}
|
|
79
|
+
return result;
|
|
80
|
+
}
|
|
81
|
+
};
|
|
82
|
+
exports.DataImportResource = DataImportResource;
|
|
83
|
+
exports.DataImportResource = DataImportResource = __decorate([
|
|
84
|
+
(0, common_1.Injectable)(),
|
|
85
|
+
__metadata("design:paramtypes", [media_1.MediaRecordsManager])
|
|
86
|
+
], DataImportResource);
|
|
87
|
+
//# sourceMappingURL=data-import.resource.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"data-import.resource.js","sourceRoot":"","sources":["../../src/data-imports-manager/data-import.resource.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/data-imports-manager/index.ts"],"names":[],"mappings":"AAAA,cAAc,+BAA+B,CAAC;AAC9C,cAAc,8BAA8B,CAAC;AAC7C,cAAc,+BAA+B,CAAC"}
|
|
@@ -0,0 +1,20 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
|
|
3
|
+
if (k2 === undefined) k2 = k;
|
|
4
|
+
var desc = Object.getOwnPropertyDescriptor(m, k);
|
|
5
|
+
if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
|
|
6
|
+
desc = { enumerable: true, get: function() { return m[k]; } };
|
|
7
|
+
}
|
|
8
|
+
Object.defineProperty(o, k2, desc);
|
|
9
|
+
}) : (function(o, m, k, k2) {
|
|
10
|
+
if (k2 === undefined) k2 = k;
|
|
11
|
+
o[k2] = m[k];
|
|
12
|
+
}));
|
|
13
|
+
var __exportStar = (this && this.__exportStar) || function(m, exports) {
|
|
14
|
+
for (var p in m) if (p !== "default" && !Object.prototype.hasOwnProperty.call(exports, p)) __createBinding(exports, m, p);
|
|
15
|
+
};
|
|
16
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
17
|
+
__exportStar(require("./data-import-consumer.module"), exports);
|
|
18
|
+
__exportStar(require("./data-import-manager.module"), exports);
|
|
19
|
+
__exportStar(require("./data-import-manager.service"), exports);
|
|
20
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/data-imports-manager/index.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;AAAA,gEAA8C;AAC9C,+DAA6C;AAC7C,gEAA8C"}
|
package/dist/domain/index.d.ts
CHANGED
|
@@ -1,8 +1,11 @@
|
|
|
1
1
|
export * from './entities/media-object.entity';
|
|
2
2
|
export * from './modules/db-connection.module';
|
|
3
3
|
export * from './modules/shared-domain.module';
|
|
4
|
+
export * from './mongodb-repositories/mongodb-data-imports.repository';
|
|
4
5
|
export * from './mongodb-repositories/mongodb-media-record.repository';
|
|
6
|
+
export * from './repositories/data-import.repository';
|
|
5
7
|
export * from './repositories/media-record.repository';
|
|
8
|
+
export * from './schemas/data-import.schema';
|
|
6
9
|
export * from './schemas/media-record.schema';
|
|
7
10
|
export * from './entities/profile-permission.entity';
|
|
8
11
|
export * from './entities/profile.entity';
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/domain/index.ts"],"names":[],"mappings":"AAAA,cAAc,gCAAgC,CAAC;AAC/C,cAAc,gCAAgC,CAAC;AAC/C,cAAc,gCAAgC,CAAC;AAC/C,cAAc,wDAAwD,CAAC;AACvE,cAAc,wCAAwC,CAAC;AACvD,cAAc,+BAA+B,CAAC;AAG9C,cAAc,sCAAsC,CAAC;AACrD,cAAc,2BAA2B,CAAC;AAC1C,cAAc,2BAA2B,CAAC;AAC1C,cAAc,wBAAwB,CAAC;AACvC,cAAc,4BAA4B,CAAC;AAC3C,cAAc,yBAAyB,CAAC;AACxC,cAAc,+BAA+B,CAAC;AAC9C,cAAc,8BAA8B,CAAC;AAC7C,cAAc,0BAA0B,CAAC;AACzC,cAAc,wBAAwB,CAAC;AACvC,cAAc,2BAA2B,CAAC;AAC1C,cAAc,8BAA8B,CAAC;AAC7C,cAAc,yBAAyB,CAAC"}
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/domain/index.ts"],"names":[],"mappings":"AAAA,cAAc,gCAAgC,CAAC;AAC/C,cAAc,gCAAgC,CAAC;AAC/C,cAAc,gCAAgC,CAAC;AAC/C,cAAc,wDAAwD,CAAC;AACvE,cAAc,wDAAwD,CAAC;AACvE,cAAc,uCAAuC,CAAC;AACtD,cAAc,wCAAwC,CAAC;AACvD,cAAc,8BAA8B,CAAC;AAC7C,cAAc,+BAA+B,CAAC;AAG9C,cAAc,sCAAsC,CAAC;AACrD,cAAc,2BAA2B,CAAC;AAC1C,cAAc,2BAA2B,CAAC;AAC1C,cAAc,wBAAwB,CAAC;AACvC,cAAc,4BAA4B,CAAC;AAC3C,cAAc,yBAAyB,CAAC;AACxC,cAAc,+BAA+B,CAAC;AAC9C,cAAc,8BAA8B,CAAC;AAC7C,cAAc,0BAA0B,CAAC;AACzC,cAAc,wBAAwB,CAAC;AACvC,cAAc,2BAA2B,CAAC;AAC1C,cAAc,8BAA8B,CAAC;AAC7C,cAAc,yBAAyB,CAAC"}
|