@imaginamossas/farmabien-common 1.0.1 → 1.0.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/dist/decorators/current-user.decorator.d.ts +9 -0
- package/dist/decorators/current-user.decorator.js +34 -0
- package/dist/decorators/current-user.decorator.js.map +1 -0
- package/dist/decorators/index.js +21 -0
- package/dist/decorators/index.js.map +1 -0
- package/dist/decorators/public.decorator.d.ts +2 -0
- package/dist/decorators/public.decorator.js +8 -0
- package/dist/decorators/public.decorator.js.map +1 -0
- package/dist/decorators/query-runner.decorator.d.ts +1 -0
- package/dist/decorators/query-runner.decorator.js +13 -0
- package/dist/decorators/query-runner.decorator.js.map +1 -0
- package/dist/decorators/request-id.decorator.d.ts +8 -0
- package/dist/decorators/request-id.decorator.js +15 -0
- package/dist/decorators/request-id.decorator.js.map +1 -0
- package/dist/dto/commons.dto.d.ts +5 -0
- package/dist/dto/commons.dto.js +10 -0
- package/dist/dto/commons.dto.js.map +1 -0
- package/dist/dto/index.js +20 -0
- package/dist/dto/index.js.map +1 -0
- package/dist/dto/profile.dto.d.ts +28 -0
- package/dist/dto/profile.dto.js +171 -0
- package/dist/dto/profile.dto.js.map +1 -0
- package/dist/dto/response-data.dto.d.ts +5 -0
- package/dist/dto/response-data.dto.js +37 -0
- package/dist/dto/response-data.dto.js.map +1 -0
- package/dist/entities/base.entity.d.ts +5 -0
- package/dist/entities/base.entity.js +43 -0
- package/dist/entities/base.entity.js.map +1 -0
- package/dist/entities/customer.entity.d.ts +21 -0
- package/dist/entities/customer.entity.js +111 -0
- package/dist/entities/customer.entity.js.map +1 -0
- package/dist/entities/customers.providers.entity.d.ts +11 -0
- package/dist/entities/customers.providers.entity.js +61 -0
- package/dist/entities/customers.providers.entity.js.map +1 -0
- package/dist/entities/email-verification-token.entity.d.ts +14 -0
- package/dist/entities/email-verification-token.entity.js +69 -0
- package/dist/entities/email-verification-token.entity.js.map +1 -0
- package/{src/entities/index.ts → dist/entities/index.d.ts} +1 -1
- package/dist/entities/index.js +21 -0
- package/dist/entities/index.js.map +1 -0
- package/dist/entities/providers.code.entity.d.ts +5 -0
- package/dist/entities/providers.code.entity.js +31 -0
- package/dist/entities/providers.code.entity.js.map +1 -0
- package/dist/enums/gender.enum.d.ts +5 -0
- package/dist/enums/gender.enum.js +10 -0
- package/dist/enums/gender.enum.js.map +1 -0
- package/dist/enums/id-type.enum.d.ts +6 -0
- package/dist/enums/id-type.enum.js +11 -0
- package/dist/enums/id-type.enum.js.map +1 -0
- package/dist/enums/index.js +19 -0
- package/dist/enums/index.js.map +1 -0
- package/dist/filters/app.exception.d.ts +7 -0
- package/dist/filters/app.exception.js +35 -0
- package/dist/filters/app.exception.js.map +1 -0
- package/dist/filters/custom.exception.filter.d.ts +8 -0
- package/dist/filters/custom.exception.filter.js +95 -0
- package/dist/filters/custom.exception.filter.js.map +1 -0
- package/dist/filters/index.js +19 -0
- package/dist/filters/index.js.map +1 -0
- package/dist/guards/api-key.guard.d.ts +8 -0
- package/dist/guards/api-key.guard.js +58 -0
- package/dist/guards/api-key.guard.js.map +1 -0
- package/dist/guards/index.js +19 -0
- package/dist/guards/index.js.map +1 -0
- package/dist/guards/jwt-auth.guard.d.ts +17 -0
- package/dist/guards/jwt-auth.guard.js +97 -0
- package/dist/guards/jwt-auth.guard.js.map +1 -0
- package/dist/index.js +28 -0
- package/dist/index.js.map +1 -0
- package/dist/interceptors/index.js +18 -0
- package/dist/interceptors/index.js.map +1 -0
- package/dist/interceptors/logging.interceptor.d.ts +13 -0
- package/dist/interceptors/logging.interceptor.js +91 -0
- package/dist/interceptors/logging.interceptor.js.map +1 -0
- package/dist/middlewares/index.js +18 -0
- package/dist/middlewares/index.js.map +1 -0
- package/dist/middlewares/request-id.middleware.d.ts +9 -0
- package/dist/middlewares/request-id.middleware.js +37 -0
- package/dist/middlewares/request-id.middleware.js.map +1 -0
- package/dist/queues/commons/src/commons.module.d.ts +2 -0
- package/dist/queues/commons/src/commons.module.js +26 -0
- package/dist/queues/commons/src/commons.module.js.map +1 -0
- package/dist/queues/commons/src/commons.service.d.ts +2 -0
- package/dist/queues/commons/src/commons.service.js +17 -0
- package/dist/queues/commons/src/commons.service.js.map +1 -0
- package/dist/queues/commons/src/index.js +19 -0
- package/dist/queues/commons/src/index.js.map +1 -0
- package/dist/queues/index.d.ts +4 -0
- package/dist/queues/index.js +21 -0
- package/dist/queues/index.js.map +1 -0
- package/dist/queues/outbox/src/index.js +22 -0
- package/dist/queues/outbox/src/index.js.map +1 -0
- package/dist/queues/outbox/src/outbox-event.entity.d.ts +17 -0
- package/dist/queues/outbox/src/outbox-event.entity.js +76 -0
- package/dist/queues/outbox/src/outbox-event.entity.js.map +1 -0
- package/dist/queues/outbox/src/outbox.dispatcher.d.ts +10 -0
- package/dist/queues/outbox/src/outbox.dispatcher.js +52 -0
- package/dist/queues/outbox/src/outbox.dispatcher.js.map +1 -0
- package/dist/queues/outbox/src/outbox.interfaces.d.ts +8 -0
- package/dist/queues/outbox/src/outbox.interfaces.js +3 -0
- package/dist/queues/outbox/src/outbox.interfaces.js.map +1 -0
- package/dist/queues/outbox/src/outbox.module.d.ts +2 -0
- package/dist/queues/outbox/src/outbox.module.js +24 -0
- package/dist/queues/outbox/src/outbox.module.js.map +1 -0
- package/dist/queues/outbox/src/outbox.service.d.ts +12 -0
- package/dist/queues/outbox/src/outbox.service.js +73 -0
- package/dist/queues/outbox/src/outbox.service.js.map +1 -0
- package/{src/queues/sns-publisher/src/index.ts → dist/queues/sns-publisher/src/index.d.ts} +0 -2
- package/dist/queues/sns-publisher/src/index.js +20 -0
- package/dist/queues/sns-publisher/src/index.js.map +1 -0
- package/dist/queues/sns-publisher/src/sns-publisher.module.d.ts +5 -0
- package/dist/queues/sns-publisher/src/sns-publisher.module.js +43 -0
- package/dist/queues/sns-publisher/src/sns-publisher.module.js.map +1 -0
- package/dist/queues/sns-publisher/src/sns-publisher.service.d.ts +10 -0
- package/dist/queues/sns-publisher/src/sns-publisher.service.js +88 -0
- package/dist/queues/sns-publisher/src/sns-publisher.service.js.map +1 -0
- package/dist/queues/sns-publisher/src/sns.catalog.d.ts +22 -0
- package/dist/queues/sns-publisher/src/sns.catalog.js +28 -0
- package/dist/queues/sns-publisher/src/sns.catalog.js.map +1 -0
- package/dist/queues/sns-publisher/src/sns.constants.d.ts +2 -0
- package/dist/queues/sns-publisher/src/sns.constants.js +6 -0
- package/dist/queues/sns-publisher/src/sns.constants.js.map +1 -0
- package/dist/queues/sns-publisher/src/sns.interfaces.d.ts +28 -0
- package/dist/queues/sns-publisher/src/sns.interfaces.js +3 -0
- package/dist/queues/sns-publisher/src/sns.interfaces.js.map +1 -0
- package/dist/queues/sqs-consumer/src/index.d.ts +6 -0
- package/dist/queues/sqs-consumer/src/index.js +19 -0
- package/dist/queues/sqs-consumer/src/index.js.map +1 -0
- package/dist/queues/sqs-consumer/src/interfaces/message-handler.interface.d.ts +10 -0
- package/dist/queues/sqs-consumer/src/interfaces/message-handler.interface.js +5 -0
- package/dist/queues/sqs-consumer/src/interfaces/message-handler.interface.js.map +1 -0
- package/dist/queues/sqs-consumer/src/interfaces/sqs-consumer.interfaces.d.ts +48 -0
- package/dist/queues/sqs-consumer/src/interfaces/sqs-consumer.interfaces.js +11 -0
- package/dist/queues/sqs-consumer/src/interfaces/sqs-consumer.interfaces.js.map +1 -0
- package/dist/queues/sqs-consumer/src/services/sqs-message-validator.service.d.ts +16 -0
- package/dist/queues/sqs-consumer/src/services/sqs-message-validator.service.js +123 -0
- package/dist/queues/sqs-consumer/src/services/sqs-message-validator.service.js.map +1 -0
- package/dist/queues/sqs-consumer/src/services/sqs-polling.service.d.ts +37 -0
- package/dist/queues/sqs-consumer/src/services/sqs-polling.service.js +259 -0
- package/dist/queues/sqs-consumer/src/services/sqs-polling.service.js.map +1 -0
- package/dist/queues/sqs-consumer/src/sqs-consumer.constants.d.ts +5 -0
- package/dist/queues/sqs-consumer/src/sqs-consumer.constants.js +9 -0
- package/dist/queues/sqs-consumer/src/sqs-consumer.constants.js.map +1 -0
- package/dist/queues/sqs-consumer/src/sqs-consumer.module.d.ts +11 -0
- package/dist/queues/sqs-consumer/src/sqs-consumer.module.js +126 -0
- package/dist/queues/sqs-consumer/src/sqs-consumer.module.js.map +1 -0
- package/dist/services/contextual-logger.service.d.ts +15 -0
- package/dist/services/contextual-logger.service.js +69 -0
- package/dist/services/contextual-logger.service.js.map +1 -0
- package/dist/services/index.js +20 -0
- package/dist/services/index.js.map +1 -0
- package/dist/services/password.service.d.ts +10 -0
- package/dist/services/password.service.js +54 -0
- package/dist/services/password.service.js.map +1 -0
- package/dist/services/uuid.service.d.ts +6 -0
- package/dist/services/uuid.service.js +47 -0
- package/dist/services/uuid.service.js.map +1 -0
- package/dist/tsconfig.tsbuildinfo +1 -0
- package/dist/utils/index.js +18 -0
- package/dist/utils/index.js.map +1 -0
- package/dist/utils/safe-date.transformer.d.ts +1 -0
- package/dist/utils/safe-date.transformer.js +59 -0
- package/dist/utils/safe-date.transformer.js.map +1 -0
- package/package.json +22 -23
- package/.nvmrc +0 -1
- package/.prettierrc +0 -10
- package/eslint.config.mjs +0 -28
- package/src/decorators/current-user.decorator.ts +0 -50
- package/src/decorators/public.decorator.ts +0 -22
- package/src/decorators/query-runner.decorator.ts +0 -38
- package/src/decorators/request-id.decorator.ts +0 -51
- package/src/dto/commons.dto.ts +0 -5
- package/src/dto/profile.dto.ts +0 -161
- package/src/dto/response-data.dto.ts +0 -28
- package/src/entities/base.entity.ts +0 -30
- package/src/entities/customer.entity.ts +0 -70
- package/src/entities/customers.providers.entity.ts +0 -34
- package/src/entities/email-verification-token.entity.ts +0 -50
- package/src/entities/providers.code.entity.ts +0 -11
- package/src/enums/gender.enum.ts +0 -26
- package/src/enums/id-type.enum.ts +0 -32
- package/src/filters/app.exception.ts +0 -58
- package/src/filters/custom.exception.filter.ts +0 -131
- package/src/guards/api-key.guard.ts +0 -74
- package/src/guards/jwt-auth.guard.ts +0 -99
- package/src/interceptors/logging.interceptor.ts +0 -133
- package/src/middlewares/request-id.middleware.ts +0 -46
- package/src/queues/commons/src/commons.module.ts +0 -13
- package/src/queues/commons/src/commons.service.spec.ts +0 -18
- package/src/queues/commons/src/commons.service.ts +0 -4
- package/src/queues/commons/tsconfig.lib.json +0 -9
- package/src/queues/index.ts +0 -4
- package/src/queues/outbox/src/outbox-event.entity.ts +0 -43
- package/src/queues/outbox/src/outbox.dispatcher.ts +0 -39
- package/src/queues/outbox/src/outbox.interfaces.ts +0 -10
- package/src/queues/outbox/src/outbox.module.ts +0 -12
- package/src/queues/outbox/src/outbox.service.ts +0 -74
- package/src/queues/sns-publisher/src/sns-publisher.module.ts +0 -34
- package/src/queues/sns-publisher/src/sns-publisher.service.ts +0 -99
- package/src/queues/sns-publisher/src/sns.catalog.ts +0 -30
- package/src/queues/sns-publisher/src/sns.constants.ts +0 -4
- package/src/queues/sns-publisher/src/sns.interfaces.ts +0 -53
- package/src/queues/sqs-consumer/src/index.ts +0 -64
- package/src/queues/sqs-consumer/src/interfaces/message-handler.interface.ts +0 -69
- package/src/queues/sqs-consumer/src/interfaces/sqs-consumer.interfaces.ts +0 -195
- package/src/queues/sqs-consumer/src/services/__tests__/sqs-message-validator.service.spec.ts +0 -130
- package/src/queues/sqs-consumer/src/services/__tests__/sqs-polling.service.spec.ts +0 -294
- package/src/queues/sqs-consumer/src/services/sqs-message-validator.service.ts +0 -239
- package/src/queues/sqs-consumer/src/services/sqs-polling.service.ts +0 -419
- package/src/queues/sqs-consumer/src/sqs-consumer.constants.ts +0 -20
- package/src/queues/sqs-consumer/src/sqs-consumer.module.ts +0 -203
- package/src/services/contextual-logger.service.ts +0 -163
- package/src/services/password.service.ts +0 -70
- package/src/services/uuid.service.ts +0 -75
- package/src/utils/safe-date.transformer.ts +0 -100
- package/tsconfig.build.json +0 -4
- package/tsconfig.json +0 -31
- /package/{src/decorators/index.ts → dist/decorators/index.d.ts} +0 -0
- /package/{src/dto/index.ts → dist/dto/index.d.ts} +0 -0
- /package/{src/enums/index.ts → dist/enums/index.d.ts} +0 -0
- /package/{src/filters/index.ts → dist/filters/index.d.ts} +0 -0
- /package/{src/guards/index.ts → dist/guards/index.d.ts} +0 -0
- /package/{src/index.ts → dist/index.d.ts} +0 -0
- /package/{src/interceptors/index.ts → dist/interceptors/index.d.ts} +0 -0
- /package/{src/middlewares/index.ts → dist/middlewares/index.d.ts} +0 -0
- /package/{src/queues/commons/src/index.ts → dist/queues/commons/src/index.d.ts} +0 -0
- /package/{src/queues/outbox/src/index.ts → dist/queues/outbox/src/index.d.ts} +0 -0
- /package/{src/services/index.ts → dist/services/index.d.ts} +0 -0
- /package/{src/utils/index.ts → dist/utils/index.d.ts} +0 -0
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
import { BaseEntity } from './base.entity';
|
|
2
|
+
import { Customer } from './customer.entity';
|
|
3
|
+
import { ProvidersCode } from './providers.code.entity';
|
|
4
|
+
export declare class CustomerProvider extends BaseEntity {
|
|
5
|
+
customerProviderId: number;
|
|
6
|
+
customerId: number;
|
|
7
|
+
providerId: string;
|
|
8
|
+
providerCustomerId: string | null;
|
|
9
|
+
customer: Customer;
|
|
10
|
+
provider: ProvidersCode;
|
|
11
|
+
}
|
|
@@ -0,0 +1,61 @@
|
|
|
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.CustomerProvider = void 0;
|
|
13
|
+
const base_entity_1 = require("./base.entity");
|
|
14
|
+
const typeorm_1 = require("typeorm");
|
|
15
|
+
const customer_entity_1 = require("./customer.entity");
|
|
16
|
+
const providers_code_entity_1 = require("./providers.code.entity");
|
|
17
|
+
let CustomerProvider = class CustomerProvider extends base_entity_1.BaseEntity {
|
|
18
|
+
customerProviderId;
|
|
19
|
+
customerId;
|
|
20
|
+
providerId;
|
|
21
|
+
providerCustomerId;
|
|
22
|
+
customer;
|
|
23
|
+
provider;
|
|
24
|
+
};
|
|
25
|
+
exports.CustomerProvider = CustomerProvider;
|
|
26
|
+
__decorate([
|
|
27
|
+
(0, typeorm_1.PrimaryGeneratedColumn)({ name: 'customer_provider_id' }),
|
|
28
|
+
__metadata("design:type", Number)
|
|
29
|
+
], CustomerProvider.prototype, "customerProviderId", void 0);
|
|
30
|
+
__decorate([
|
|
31
|
+
(0, typeorm_1.Column)({ name: 'customer_id', nullable: false }),
|
|
32
|
+
__metadata("design:type", Number)
|
|
33
|
+
], CustomerProvider.prototype, "customerId", void 0);
|
|
34
|
+
__decorate([
|
|
35
|
+
(0, typeorm_1.Column)({ type: 'char', length: 2, name: 'provider_id', nullable: false }),
|
|
36
|
+
__metadata("design:type", String)
|
|
37
|
+
], CustomerProvider.prototype, "providerId", void 0);
|
|
38
|
+
__decorate([
|
|
39
|
+
(0, typeorm_1.Column)({ type: 'varchar', length: 255, nullable: true }),
|
|
40
|
+
__metadata("design:type", Object)
|
|
41
|
+
], CustomerProvider.prototype, "providerCustomerId", void 0);
|
|
42
|
+
__decorate([
|
|
43
|
+
(0, typeorm_1.ManyToOne)(() => customer_entity_1.Customer, { onDelete: 'CASCADE' }),
|
|
44
|
+
(0, typeorm_1.JoinColumn)({ name: 'customer_id' }),
|
|
45
|
+
__metadata("design:type", customer_entity_1.Customer)
|
|
46
|
+
], CustomerProvider.prototype, "customer", void 0);
|
|
47
|
+
__decorate([
|
|
48
|
+
(0, typeorm_1.ManyToOne)(() => providers_code_entity_1.ProvidersCode, { onDelete: 'RESTRICT' }),
|
|
49
|
+
(0, typeorm_1.JoinColumn)({ name: 'provider_id' }),
|
|
50
|
+
__metadata("design:type", providers_code_entity_1.ProvidersCode)
|
|
51
|
+
], CustomerProvider.prototype, "provider", void 0);
|
|
52
|
+
exports.CustomerProvider = CustomerProvider = __decorate([
|
|
53
|
+
(0, typeorm_1.Entity)('customer_providers'),
|
|
54
|
+
(0, typeorm_1.Index)('idx_customer_providers_customer', ['customerId']),
|
|
55
|
+
(0, typeorm_1.Index)('idx_customer_providers_provider', ['providerId']),
|
|
56
|
+
(0, typeorm_1.Index)('idx_customer_providers_provider_customer', ['providerId', 'providerCustomerId'], {
|
|
57
|
+
unique: true,
|
|
58
|
+
where: 'provider_customer_id IS NOT NULL',
|
|
59
|
+
})
|
|
60
|
+
], CustomerProvider);
|
|
61
|
+
//# sourceMappingURL=customers.providers.entity.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"customers.providers.entity.js","sourceRoot":"","sources":["../../src/entities/customers.providers.entity.ts"],"names":[],"mappings":";;;;;;;;;;;;AAAA,+CAA2C;AAC3C,qCAA+F;AAC/F,uDAA6C;AAC7C,mEAAwD;AASjD,IAAM,gBAAgB,GAAtB,MAAM,gBAAiB,SAAQ,wBAAU;IAE9C,kBAAkB,CAAS;IAG3B,UAAU,CAAS;IAGnB,UAAU,CAAS;IAGnB,kBAAkB,CAAgB;IAKlC,QAAQ,CAAW;IAInB,QAAQ,CAAgB;CACzB,CAAA;AArBY,4CAAgB;AAE3B;IADC,IAAA,gCAAsB,EAAC,EAAE,IAAI,EAAE,sBAAsB,EAAE,CAAC;;4DAC9B;AAG3B;IADC,IAAA,gBAAM,EAAC,EAAE,IAAI,EAAE,aAAa,EAAE,QAAQ,EAAE,KAAK,EAAE,CAAC;;oDAC9B;AAGnB;IADC,IAAA,gBAAM,EAAC,EAAE,IAAI,EAAE,MAAM,EAAE,MAAM,EAAE,CAAC,EAAE,IAAI,EAAE,aAAa,EAAE,QAAQ,EAAE,KAAK,EAAE,CAAC;;oDACvD;AAGnB;IADC,IAAA,gBAAM,EAAC,EAAE,IAAI,EAAE,SAAS,EAAE,MAAM,EAAE,GAAG,EAAE,QAAQ,EAAE,IAAI,EAAE,CAAC;;4DACvB;AAKlC;IAFC,IAAA,mBAAS,EAAC,GAAG,EAAE,CAAC,0BAAQ,EAAE,EAAE,QAAQ,EAAE,SAAS,EAAE,CAAC;IAClD,IAAA,oBAAU,EAAC,EAAE,IAAI,EAAE,aAAa,EAAE,CAAC;8BAC1B,0BAAQ;kDAAC;AAInB;IAFC,IAAA,mBAAS,EAAC,GAAG,EAAE,CAAC,qCAAa,EAAE,EAAE,QAAQ,EAAE,UAAU,EAAE,CAAC;IACxD,IAAA,oBAAU,EAAC,EAAE,IAAI,EAAE,aAAa,EAAE,CAAC;8BAC1B,qCAAa;kDAAC;2BApBb,gBAAgB;IAP5B,IAAA,gBAAM,EAAC,oBAAoB,CAAC;IAC5B,IAAA,eAAK,EAAC,iCAAiC,EAAE,CAAC,YAAY,CAAC,CAAC;IACxD,IAAA,eAAK,EAAC,iCAAiC,EAAE,CAAC,YAAY,CAAC,CAAC;IACxD,IAAA,eAAK,EAAC,0CAA0C,EAAE,CAAC,YAAY,EAAE,oBAAoB,CAAC,EAAE;QACvF,MAAM,EAAE,IAAI;QACZ,KAAK,EAAE,kCAAkC;KAC1C,CAAC;GACW,gBAAgB,CAqB5B"}
|
|
@@ -0,0 +1,14 @@
|
|
|
1
|
+
import { BaseEntity } from './base.entity';
|
|
2
|
+
import { Customer } from './customer.entity';
|
|
3
|
+
export declare class EmailVerificationToken extends BaseEntity {
|
|
4
|
+
id: number;
|
|
5
|
+
customerId: number;
|
|
6
|
+
token: string;
|
|
7
|
+
expiresAt: Date;
|
|
8
|
+
usedAt?: Date;
|
|
9
|
+
sendAt: Date;
|
|
10
|
+
customer: Customer;
|
|
11
|
+
get isExpired(): boolean;
|
|
12
|
+
get isUsed(): boolean;
|
|
13
|
+
get isValid(): boolean;
|
|
14
|
+
}
|
|
@@ -0,0 +1,69 @@
|
|
|
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.EmailVerificationToken = void 0;
|
|
13
|
+
const base_entity_1 = require("./base.entity");
|
|
14
|
+
const typeorm_1 = require("typeorm");
|
|
15
|
+
const customer_entity_1 = require("./customer.entity");
|
|
16
|
+
let EmailVerificationToken = class EmailVerificationToken extends base_entity_1.BaseEntity {
|
|
17
|
+
id;
|
|
18
|
+
customerId;
|
|
19
|
+
token;
|
|
20
|
+
expiresAt;
|
|
21
|
+
usedAt;
|
|
22
|
+
sendAt;
|
|
23
|
+
customer;
|
|
24
|
+
get isExpired() {
|
|
25
|
+
return new Date() > this.expiresAt;
|
|
26
|
+
}
|
|
27
|
+
get isUsed() {
|
|
28
|
+
return this.usedAt !== null && this.usedAt !== undefined;
|
|
29
|
+
}
|
|
30
|
+
get isValid() {
|
|
31
|
+
return !this.isExpired && !this.isUsed;
|
|
32
|
+
}
|
|
33
|
+
};
|
|
34
|
+
exports.EmailVerificationToken = EmailVerificationToken;
|
|
35
|
+
__decorate([
|
|
36
|
+
(0, typeorm_1.PrimaryGeneratedColumn)({ name: 'id' }),
|
|
37
|
+
__metadata("design:type", Number)
|
|
38
|
+
], EmailVerificationToken.prototype, "id", void 0);
|
|
39
|
+
__decorate([
|
|
40
|
+
(0, typeorm_1.Column)({ name: 'customer_id', type: 'bigint' }),
|
|
41
|
+
__metadata("design:type", Number)
|
|
42
|
+
], EmailVerificationToken.prototype, "customerId", void 0);
|
|
43
|
+
__decorate([
|
|
44
|
+
(0, typeorm_1.Column)({ type: 'varchar', length: 255 }),
|
|
45
|
+
__metadata("design:type", String)
|
|
46
|
+
], EmailVerificationToken.prototype, "token", void 0);
|
|
47
|
+
__decorate([
|
|
48
|
+
(0, typeorm_1.Column)({ name: 'expires_at', type: 'timestamp' }),
|
|
49
|
+
__metadata("design:type", Date)
|
|
50
|
+
], EmailVerificationToken.prototype, "expiresAt", void 0);
|
|
51
|
+
__decorate([
|
|
52
|
+
(0, typeorm_1.Column)({ name: 'used_at', type: 'timestamp', nullable: true }),
|
|
53
|
+
__metadata("design:type", Date)
|
|
54
|
+
], EmailVerificationToken.prototype, "usedAt", void 0);
|
|
55
|
+
__decorate([
|
|
56
|
+
(0, typeorm_1.Column)({ name: 'send_at', type: 'timestamp' }),
|
|
57
|
+
__metadata("design:type", Date)
|
|
58
|
+
], EmailVerificationToken.prototype, "sendAt", void 0);
|
|
59
|
+
__decorate([
|
|
60
|
+
(0, typeorm_1.ManyToOne)(() => customer_entity_1.Customer, { onDelete: 'CASCADE' }),
|
|
61
|
+
(0, typeorm_1.JoinColumn)({ name: 'customer_id' }),
|
|
62
|
+
__metadata("design:type", customer_entity_1.Customer)
|
|
63
|
+
], EmailVerificationToken.prototype, "customer", void 0);
|
|
64
|
+
exports.EmailVerificationToken = EmailVerificationToken = __decorate([
|
|
65
|
+
(0, typeorm_1.Entity)('email_verification_tokens'),
|
|
66
|
+
(0, typeorm_1.Index)('idx_email_verification_tokens_customer_id', ['customerId']),
|
|
67
|
+
(0, typeorm_1.Index)('idx_email_verification_tokens_token', ['token'])
|
|
68
|
+
], EmailVerificationToken);
|
|
69
|
+
//# sourceMappingURL=email-verification-token.entity.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"email-verification-token.entity.js","sourceRoot":"","sources":["../../src/entities/email-verification-token.entity.ts"],"names":[],"mappings":";;;;;;;;;;;;AAAA,+CAA2C;AAC3C,qCAA+F;AAC/F,uDAA6C;AAStC,IAAM,sBAAsB,GAA5B,MAAM,sBAAuB,SAAQ,wBAAU;IAEpD,EAAE,CAAS;IAGX,UAAU,CAAS;IAGnB,KAAK,CAAS;IAGd,SAAS,CAAO;IAGhB,MAAM,CAAQ;IAGd,MAAM,CAAO;IAKb,QAAQ,CAAW;IAGnB,IAAI,SAAS;QACX,OAAO,IAAI,IAAI,EAAE,GAAG,IAAI,CAAC,SAAS,CAAC;IACrC,CAAC;IAGD,IAAI,MAAM;QACR,OAAO,IAAI,CAAC,MAAM,KAAK,IAAI,IAAI,IAAI,CAAC,MAAM,KAAK,SAAS,CAAC;IAC3D,CAAC;IAGD,IAAI,OAAO;QACT,OAAO,CAAC,IAAI,CAAC,SAAS,IAAI,CAAC,IAAI,CAAC,MAAM,CAAC;IACzC,CAAC;CACF,CAAA;AAtCY,wDAAsB;AAEjC;IADC,IAAA,gCAAsB,EAAC,EAAE,IAAI,EAAE,IAAI,EAAE,CAAC;;kDAC5B;AAGX;IADC,IAAA,gBAAM,EAAC,EAAE,IAAI,EAAE,aAAa,EAAE,IAAI,EAAE,QAAQ,EAAE,CAAC;;0DAC7B;AAGnB;IADC,IAAA,gBAAM,EAAC,EAAE,IAAI,EAAE,SAAS,EAAE,MAAM,EAAE,GAAG,EAAE,CAAC;;qDAC3B;AAGd;IADC,IAAA,gBAAM,EAAC,EAAE,IAAI,EAAE,YAAY,EAAE,IAAI,EAAE,WAAW,EAAE,CAAC;8BACvC,IAAI;yDAAC;AAGhB;IADC,IAAA,gBAAM,EAAC,EAAE,IAAI,EAAE,SAAS,EAAE,IAAI,EAAE,WAAW,EAAE,QAAQ,EAAE,IAAI,EAAE,CAAC;8BACtD,IAAI;sDAAC;AAGd;IADC,IAAA,gBAAM,EAAC,EAAE,IAAI,EAAE,SAAS,EAAE,IAAI,EAAE,WAAW,EAAE,CAAC;8BACvC,IAAI;sDAAC;AAKb;IAFC,IAAA,mBAAS,EAAC,GAAG,EAAE,CAAC,0BAAQ,EAAE,EAAE,QAAQ,EAAE,SAAS,EAAE,CAAC;IAClD,IAAA,oBAAU,EAAC,EAAE,IAAI,EAAE,aAAa,EAAE,CAAC;8BAC1B,0BAAQ;wDAAC;iCAtBR,sBAAsB;IAHlC,IAAA,gBAAM,EAAC,2BAA2B,CAAC;IACnC,IAAA,eAAK,EAAC,2CAA2C,EAAE,CAAC,YAAY,CAAC,CAAC;IAClE,IAAA,eAAK,EAAC,qCAAqC,EAAE,CAAC,OAAO,CAAC,CAAC;GAC3C,sBAAsB,CAsClC"}
|
|
@@ -0,0 +1,21 @@
|
|
|
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("./customer.entity"), exports);
|
|
18
|
+
__exportStar(require("./customers.providers.entity"), exports);
|
|
19
|
+
__exportStar(require("./email-verification-token.entity"), exports);
|
|
20
|
+
__exportStar(require("./providers.code.entity"), exports);
|
|
21
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/entities/index.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;AAAA,oDAAiC;AACjC,+DAA6C;AAC7C,oEAAkD;AAClD,0DAAwC"}
|
|
@@ -0,0 +1,31 @@
|
|
|
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.ProvidersCode = void 0;
|
|
13
|
+
const base_entity_1 = require("./base.entity");
|
|
14
|
+
const typeorm_1 = require("typeorm");
|
|
15
|
+
let ProvidersCode = class ProvidersCode extends base_entity_1.BaseEntity {
|
|
16
|
+
providerId;
|
|
17
|
+
providerName;
|
|
18
|
+
};
|
|
19
|
+
exports.ProvidersCode = ProvidersCode;
|
|
20
|
+
__decorate([
|
|
21
|
+
(0, typeorm_1.PrimaryColumn)({ type: 'char', length: 2, name: 'provider_id' }),
|
|
22
|
+
__metadata("design:type", String)
|
|
23
|
+
], ProvidersCode.prototype, "providerId", void 0);
|
|
24
|
+
__decorate([
|
|
25
|
+
(0, typeorm_1.Column)({ type: 'varchar', length: 100 }),
|
|
26
|
+
__metadata("design:type", String)
|
|
27
|
+
], ProvidersCode.prototype, "providerName", void 0);
|
|
28
|
+
exports.ProvidersCode = ProvidersCode = __decorate([
|
|
29
|
+
(0, typeorm_1.Entity)('providers_code')
|
|
30
|
+
], ProvidersCode);
|
|
31
|
+
//# sourceMappingURL=providers.code.entity.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"providers.code.entity.js","sourceRoot":"","sources":["../../src/entities/providers.code.entity.ts"],"names":[],"mappings":";;;;;;;;;;;;AAAA,+CAA2C;AAC3C,qCAAwD;AAGjD,IAAM,aAAa,GAAnB,MAAM,aAAc,SAAQ,wBAAU;IAE3C,UAAU,CAAS;IAGnB,YAAY,CAAS;CACtB,CAAA;AANY,sCAAa;AAExB;IADC,IAAA,uBAAa,EAAC,EAAE,IAAI,EAAE,MAAM,EAAE,MAAM,EAAE,CAAC,EAAE,IAAI,EAAE,aAAa,EAAE,CAAC;;iDAC7C;AAGnB;IADC,IAAA,gBAAM,EAAC,EAAE,IAAI,EAAE,SAAS,EAAE,MAAM,EAAE,GAAG,EAAE,CAAC;;mDACpB;wBALV,aAAa;IADzB,IAAA,gBAAM,EAAC,gBAAgB,CAAC;GACZ,aAAa,CAMzB"}
|
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.Gender = void 0;
|
|
4
|
+
var Gender;
|
|
5
|
+
(function (Gender) {
|
|
6
|
+
Gender["M"] = "M";
|
|
7
|
+
Gender["F"] = "F";
|
|
8
|
+
Gender["O"] = "O";
|
|
9
|
+
})(Gender || (exports.Gender = Gender = {}));
|
|
10
|
+
//# sourceMappingURL=gender.enum.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"gender.enum.js","sourceRoot":"","sources":["../../src/enums/gender.enum.ts"],"names":[],"mappings":";;;AAOA,IAAY,MAkBX;AAlBD,WAAY,MAAM;IAKhB,iBAAO,CAAA;IAMP,iBAAO,CAAA;IAMP,iBAAO,CAAA;AACT,CAAC,EAlBW,MAAM,sBAAN,MAAM,QAkBjB"}
|
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.IdType = void 0;
|
|
4
|
+
var IdType;
|
|
5
|
+
(function (IdType) {
|
|
6
|
+
IdType["CC"] = "CC";
|
|
7
|
+
IdType["CE"] = "CE";
|
|
8
|
+
IdType["PA"] = "PA";
|
|
9
|
+
IdType["CI"] = "CI";
|
|
10
|
+
})(IdType || (exports.IdType = IdType = {}));
|
|
11
|
+
//# sourceMappingURL=id-type.enum.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"id-type.enum.js","sourceRoot":"","sources":["../../src/enums/id-type.enum.ts"],"names":[],"mappings":";;;AAOA,IAAY,MAwBX;AAxBD,WAAY,MAAM;IAKhB,mBAAS,CAAA;IAMT,mBAAS,CAAA;IAMT,mBAAS,CAAA;IAMT,mBAAS,CAAA;AACX,CAAC,EAxBW,MAAM,sBAAN,MAAM,QAwBjB"}
|
|
@@ -0,0 +1,19 @@
|
|
|
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("./gender.enum"), exports);
|
|
18
|
+
__exportStar(require("./id-type.enum"), exports);
|
|
19
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/enums/index.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;AAAA,gDAA8B;AAC9B,iDAA+B"}
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
import { HttpException, HttpStatus } from '@nestjs/common';
|
|
2
|
+
export declare class AppException extends HttpException {
|
|
3
|
+
static readonly statusMap: Record<string, HttpStatus>;
|
|
4
|
+
readonly key: string;
|
|
5
|
+
readonly meta?: Record<string, unknown>;
|
|
6
|
+
constructor(key: string, meta?: Record<string, unknown>);
|
|
7
|
+
}
|
|
@@ -0,0 +1,35 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.AppException = void 0;
|
|
4
|
+
const common_1 = require("@nestjs/common");
|
|
5
|
+
class AppException extends common_1.HttpException {
|
|
6
|
+
static statusMap = {
|
|
7
|
+
'error.customer.emailAlreadyExists': common_1.HttpStatus.CONFLICT,
|
|
8
|
+
'error.customer.phoneAlreadyExists': common_1.HttpStatus.CONFLICT,
|
|
9
|
+
'error.customer.idNumberAlreadyExists': common_1.HttpStatus.CONFLICT,
|
|
10
|
+
'error.customer.notFound': common_1.HttpStatus.NOT_FOUND,
|
|
11
|
+
'error.customer.invalidPasswordStrength': common_1.HttpStatus.BAD_REQUEST,
|
|
12
|
+
'error.customer.registrationFailed': common_1.HttpStatus.BAD_REQUEST,
|
|
13
|
+
'error.customer.TenantIdInvalid': common_1.HttpStatus.UNAUTHORIZED,
|
|
14
|
+
'error.email.sendFailed': common_1.HttpStatus.INTERNAL_SERVER_ERROR,
|
|
15
|
+
'error.email.invalidCredentials': common_1.HttpStatus.INTERNAL_SERVER_ERROR,
|
|
16
|
+
'error.email.invalidRecipient': common_1.HttpStatus.BAD_REQUEST,
|
|
17
|
+
'error.email.invalidSender': common_1.HttpStatus.BAD_REQUEST,
|
|
18
|
+
'error.email.messageRejected': common_1.HttpStatus.BAD_REQUEST,
|
|
19
|
+
'error.email.notConfigured': common_1.HttpStatus.SERVICE_UNAVAILABLE,
|
|
20
|
+
'error.sqs.connectionFailed': common_1.HttpStatus.SERVICE_UNAVAILABLE,
|
|
21
|
+
'error.sqs.invalidMessage': common_1.HttpStatus.BAD_REQUEST,
|
|
22
|
+
'error.unexpected': common_1.HttpStatus.INTERNAL_SERVER_ERROR,
|
|
23
|
+
'error.validation': common_1.HttpStatus.BAD_REQUEST,
|
|
24
|
+
};
|
|
25
|
+
key;
|
|
26
|
+
meta;
|
|
27
|
+
constructor(key, meta) {
|
|
28
|
+
const status = AppException.statusMap[key] ?? common_1.HttpStatus.INTERNAL_SERVER_ERROR;
|
|
29
|
+
super(key, status);
|
|
30
|
+
this.key = key;
|
|
31
|
+
this.meta = meta;
|
|
32
|
+
}
|
|
33
|
+
}
|
|
34
|
+
exports.AppException = AppException;
|
|
35
|
+
//# sourceMappingURL=app.exception.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"app.exception.js","sourceRoot":"","sources":["../../src/filters/app.exception.ts"],"names":[],"mappings":";;;AAAA,2CAA2D;AAc3D,MAAa,YAAa,SAAQ,sBAAa;IAK7C,MAAM,CAAU,SAAS,GAA+B;QAEtD,mCAAmC,EAAE,mBAAU,CAAC,QAAQ;QACxD,mCAAmC,EAAE,mBAAU,CAAC,QAAQ;QACxD,sCAAsC,EAAE,mBAAU,CAAC,QAAQ;QAC3D,yBAAyB,EAAE,mBAAU,CAAC,SAAS;QAC/C,wCAAwC,EAAE,mBAAU,CAAC,WAAW;QAChE,mCAAmC,EAAE,mBAAU,CAAC,WAAW;QAC3D,gCAAgC,EAAE,mBAAU,CAAC,YAAY;QAEzD,wBAAwB,EAAE,mBAAU,CAAC,qBAAqB;QAC1D,gCAAgC,EAAE,mBAAU,CAAC,qBAAqB;QAClE,8BAA8B,EAAE,mBAAU,CAAC,WAAW;QACtD,2BAA2B,EAAE,mBAAU,CAAC,WAAW;QACnD,6BAA6B,EAAE,mBAAU,CAAC,WAAW;QACrD,2BAA2B,EAAE,mBAAU,CAAC,mBAAmB;QAG3D,4BAA4B,EAAE,mBAAU,CAAC,mBAAmB;QAC5D,0BAA0B,EAAE,mBAAU,CAAC,WAAW;QAGlD,kBAAkB,EAAE,mBAAU,CAAC,qBAAqB;QACpD,kBAAkB,EAAE,mBAAU,CAAC,WAAW;KAC3C,CAAC;IAEO,GAAG,CAAS;IACZ,IAAI,CAA2B;IAExC,YAAY,GAAW,EAAE,IAA8B;QACrD,MAAM,MAAM,GAAG,YAAY,CAAC,SAAS,CAAC,GAAG,CAAC,IAAI,mBAAU,CAAC,qBAAqB,CAAC;QAG/E,KAAK,CAAC,GAAG,EAAE,MAAM,CAAC,CAAC;QAEnB,IAAI,CAAC,GAAG,GAAG,GAAG,CAAC;QACf,IAAI,CAAC,IAAI,GAAG,IAAI,CAAC;IACnB,CAAC;;AA1CH,oCA2CC"}
|
|
@@ -0,0 +1,8 @@
|
|
|
1
|
+
import { ExceptionFilter, ArgumentsHost } from '@nestjs/common';
|
|
2
|
+
import { I18nService } from 'nestjs-i18n';
|
|
3
|
+
export declare class CustomExceptionFilter implements ExceptionFilter {
|
|
4
|
+
private readonly i18n;
|
|
5
|
+
private readonly logger;
|
|
6
|
+
constructor(i18n: I18nService);
|
|
7
|
+
catch(exception: unknown, host: ArgumentsHost): Promise<void>;
|
|
8
|
+
}
|
|
@@ -0,0 +1,95 @@
|
|
|
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 CustomExceptionFilter_1;
|
|
12
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
13
|
+
exports.CustomExceptionFilter = void 0;
|
|
14
|
+
const common_1 = require("@nestjs/common");
|
|
15
|
+
const nestjs_i18n_1 = require("nestjs-i18n");
|
|
16
|
+
const app_exception_1 = require("./app.exception");
|
|
17
|
+
let CustomExceptionFilter = CustomExceptionFilter_1 = class CustomExceptionFilter {
|
|
18
|
+
i18n;
|
|
19
|
+
logger = new common_1.Logger(CustomExceptionFilter_1.name);
|
|
20
|
+
constructor(i18n) {
|
|
21
|
+
this.i18n = i18n;
|
|
22
|
+
}
|
|
23
|
+
async catch(exception, host) {
|
|
24
|
+
const ctx = host.switchToHttp();
|
|
25
|
+
const response = ctx.getResponse();
|
|
26
|
+
const request = ctx.getRequest();
|
|
27
|
+
const requestId = request['requestId'];
|
|
28
|
+
const lang = nestjs_i18n_1.I18nContext.current()?.lang || request.headers['accept-language'] || 'es';
|
|
29
|
+
let status = common_1.HttpStatus.INTERNAL_SERVER_ERROR;
|
|
30
|
+
let message = 'Internal server error';
|
|
31
|
+
let code;
|
|
32
|
+
let details;
|
|
33
|
+
if (exception instanceof app_exception_1.AppException) {
|
|
34
|
+
status = exception.getStatus();
|
|
35
|
+
code = exception.key;
|
|
36
|
+
try {
|
|
37
|
+
message = await this.i18n.t(`i18n.${code}`, {
|
|
38
|
+
lang,
|
|
39
|
+
args: exception.meta || {},
|
|
40
|
+
});
|
|
41
|
+
}
|
|
42
|
+
catch {
|
|
43
|
+
this.logger.warn(`i18n translation failed for key: ${code}`);
|
|
44
|
+
message = code;
|
|
45
|
+
}
|
|
46
|
+
}
|
|
47
|
+
else if (exception instanceof common_1.HttpException) {
|
|
48
|
+
status = exception.getStatus();
|
|
49
|
+
const exceptionResponse = exception.getResponse();
|
|
50
|
+
if (typeof exceptionResponse === 'string') {
|
|
51
|
+
message = exceptionResponse;
|
|
52
|
+
}
|
|
53
|
+
else {
|
|
54
|
+
const exRes = exceptionResponse;
|
|
55
|
+
message = Array.isArray(exRes.message)
|
|
56
|
+
? exRes.message.join(', ')
|
|
57
|
+
: exRes.message || message;
|
|
58
|
+
details = exRes;
|
|
59
|
+
}
|
|
60
|
+
}
|
|
61
|
+
else {
|
|
62
|
+
const err = exception;
|
|
63
|
+
this.logger.error(`[${requestId || 'no-request-id'}] Unhandled exception: ${err?.message || 'Unknown error'}`, err?.stack);
|
|
64
|
+
try {
|
|
65
|
+
message = await this.i18n.t('i18n.error.unexpected', { lang });
|
|
66
|
+
code = 'error.unexpected';
|
|
67
|
+
}
|
|
68
|
+
catch {
|
|
69
|
+
message = 'Internal server error';
|
|
70
|
+
}
|
|
71
|
+
}
|
|
72
|
+
if (status >= 500) {
|
|
73
|
+
this.logger.error(`[${requestId || 'no-request-id'}] ${request.method} ${request.url} - ${status} - ${message}`);
|
|
74
|
+
}
|
|
75
|
+
else {
|
|
76
|
+
this.logger.warn(`[${requestId || 'no-request-id'}] ${request.method} ${request.url} - ${status} - ${message}`);
|
|
77
|
+
}
|
|
78
|
+
response.status(status).json({
|
|
79
|
+
statusCode: status,
|
|
80
|
+
timestamp: new Date().toISOString(),
|
|
81
|
+
path: request.url,
|
|
82
|
+
requestId,
|
|
83
|
+
message,
|
|
84
|
+
code,
|
|
85
|
+
...(details && process.env.NODE_ENV !== 'production' ? { details } : {}),
|
|
86
|
+
});
|
|
87
|
+
}
|
|
88
|
+
};
|
|
89
|
+
exports.CustomExceptionFilter = CustomExceptionFilter;
|
|
90
|
+
exports.CustomExceptionFilter = CustomExceptionFilter = CustomExceptionFilter_1 = __decorate([
|
|
91
|
+
(0, common_1.Catch)(),
|
|
92
|
+
(0, common_1.Injectable)(),
|
|
93
|
+
__metadata("design:paramtypes", [nestjs_i18n_1.I18nService])
|
|
94
|
+
], CustomExceptionFilter);
|
|
95
|
+
//# sourceMappingURL=custom.exception.filter.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"custom.exception.filter.js","sourceRoot":"","sources":["../../src/filters/custom.exception.filter.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,19 @@
|
|
|
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("./app.exception"), exports);
|
|
18
|
+
__exportStar(require("./custom.exception.filter"), exports);
|
|
19
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/filters/index.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;AAAA,kDAAgC;AAChC,4DAA0C"}
|
|
@@ -0,0 +1,8 @@
|
|
|
1
|
+
import { CanActivate, ExecutionContext } from '@nestjs/common';
|
|
2
|
+
import { Reflector } from '@nestjs/core';
|
|
3
|
+
export declare class ApiKeyGuard implements CanActivate {
|
|
4
|
+
private readonly reflector;
|
|
5
|
+
private readonly logger;
|
|
6
|
+
constructor(reflector: Reflector);
|
|
7
|
+
canActivate(context: ExecutionContext): boolean;
|
|
8
|
+
}
|
|
@@ -0,0 +1,58 @@
|
|
|
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 ApiKeyGuard_1;
|
|
12
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
13
|
+
exports.ApiKeyGuard = void 0;
|
|
14
|
+
const common_1 = require("@nestjs/common");
|
|
15
|
+
const core_1 = require("@nestjs/core");
|
|
16
|
+
const public_decorator_1 = require("../decorators/public.decorator");
|
|
17
|
+
let ApiKeyGuard = ApiKeyGuard_1 = class ApiKeyGuard {
|
|
18
|
+
reflector;
|
|
19
|
+
logger = new common_1.Logger(ApiKeyGuard_1.name);
|
|
20
|
+
constructor(reflector) {
|
|
21
|
+
this.reflector = reflector;
|
|
22
|
+
}
|
|
23
|
+
canActivate(context) {
|
|
24
|
+
const request = context.switchToHttp().getRequest();
|
|
25
|
+
if (request.method === 'OPTIONS') {
|
|
26
|
+
return true;
|
|
27
|
+
}
|
|
28
|
+
const isPublic = this.reflector.getAllAndOverride(public_decorator_1.IS_PUBLIC_KEY, [
|
|
29
|
+
context.getHandler(),
|
|
30
|
+
context.getClass(),
|
|
31
|
+
]);
|
|
32
|
+
if (isPublic) {
|
|
33
|
+
return true;
|
|
34
|
+
}
|
|
35
|
+
const apiKeyFromHeader = request.headers['x-api-key'] ??
|
|
36
|
+
request.headers['api-key'];
|
|
37
|
+
if (!apiKeyFromHeader) {
|
|
38
|
+
this.logger.warn(`Missing API Key for ${request.method} ${request.path}`);
|
|
39
|
+
throw new common_1.UnauthorizedException('API Key is required');
|
|
40
|
+
}
|
|
41
|
+
const envApiKey = process.env.X_API_KEY;
|
|
42
|
+
if (!envApiKey) {
|
|
43
|
+
this.logger.error('X_API_KEY environment variable is not configured');
|
|
44
|
+
throw new common_1.UnauthorizedException('API Key validation is not configured');
|
|
45
|
+
}
|
|
46
|
+
if (apiKeyFromHeader !== envApiKey) {
|
|
47
|
+
this.logger.warn(`Invalid API Key attempt for ${request.method} ${request.path}`);
|
|
48
|
+
throw new common_1.UnauthorizedException('Invalid API Key');
|
|
49
|
+
}
|
|
50
|
+
return true;
|
|
51
|
+
}
|
|
52
|
+
};
|
|
53
|
+
exports.ApiKeyGuard = ApiKeyGuard;
|
|
54
|
+
exports.ApiKeyGuard = ApiKeyGuard = ApiKeyGuard_1 = __decorate([
|
|
55
|
+
(0, common_1.Injectable)(),
|
|
56
|
+
__metadata("design:paramtypes", [core_1.Reflector])
|
|
57
|
+
], ApiKeyGuard);
|
|
58
|
+
//# sourceMappingURL=api-key.guard.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"api-key.guard.js","sourceRoot":"","sources":["../../src/guards/api-key.guard.ts"],"names":[],"mappings":";;;;;;;;;;;;;AAAA,2CAMwB;AACxB,uCAAyC;AAEzC,qEAA+D;AAgBxD,IAAM,WAAW,mBAAjB,MAAM,WAAW;IAGO;IAFZ,MAAM,GAAG,IAAI,eAAM,CAAC,aAAW,CAAC,IAAI,CAAC,CAAC;IAEvD,YAA6B,SAAoB;QAApB,cAAS,GAAT,SAAS,CAAW;IAAG,CAAC;IAErD,WAAW,CAAC,OAAyB;QACnC,MAAM,OAAO,GAAG,OAAO,CAAC,YAAY,EAAE,CAAC,UAAU,EAAW,CAAC;QAG7D,IAAI,OAAO,CAAC,MAAM,KAAK,SAAS,EAAE,CAAC;YACjC,OAAO,IAAI,CAAC;QACd,CAAC;QAGD,MAAM,QAAQ,GAAG,IAAI,CAAC,SAAS,CAAC,iBAAiB,CAAU,gCAAa,EAAE;YACxE,OAAO,CAAC,UAAU,EAAE;YACpB,OAAO,CAAC,QAAQ,EAAE;SACnB,CAAC,CAAC;QAEH,IAAI,QAAQ,EAAE,CAAC;YACb,OAAO,IAAI,CAAC;QACd,CAAC;QAGD,MAAM,gBAAgB,GACnB,OAAO,CAAC,OAAO,CAAC,WAAW,CAAwB;YACnD,OAAO,CAAC,OAAO,CAAC,SAAS,CAAwB,CAAC;QAErD,IAAI,CAAC,gBAAgB,EAAE,CAAC;YACtB,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,uBAAuB,OAAO,CAAC,MAAM,IAAI,OAAO,CAAC,IAAI,EAAE,CAAC,CAAC;YAC1E,MAAM,IAAI,8BAAqB,CAAC,qBAAqB,CAAC,CAAC;QACzD,CAAC;QAGD,MAAM,SAAS,GAAG,OAAO,CAAC,GAAG,CAAC,SAAS,CAAC;QAExC,IAAI,CAAC,SAAS,EAAE,CAAC;YACf,IAAI,CAAC,MAAM,CAAC,KAAK,CAAC,kDAAkD,CAAC,CAAC;YACtE,MAAM,IAAI,8BAAqB,CAAC,sCAAsC,CAAC,CAAC;QAC1E,CAAC;QAED,IAAI,gBAAgB,KAAK,SAAS,EAAE,CAAC;YACnC,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,+BAA+B,OAAO,CAAC,MAAM,IAAI,OAAO,CAAC,IAAI,EAAE,CAAC,CAAC;YAClF,MAAM,IAAI,8BAAqB,CAAC,iBAAiB,CAAC,CAAC;QACrD,CAAC;QAED,OAAO,IAAI,CAAC;IACd,CAAC;CACF,CAAA;AAhDY,kCAAW;sBAAX,WAAW;IADvB,IAAA,mBAAU,GAAE;qCAI6B,gBAAS;GAHtC,WAAW,CAgDvB"}
|
|
@@ -0,0 +1,19 @@
|
|
|
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("./api-key.guard"), exports);
|
|
18
|
+
__exportStar(require("./jwt-auth.guard"), exports);
|
|
19
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/guards/index.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;AAAA,kDAAgC;AAChC,mDAAiC"}
|
|
@@ -0,0 +1,17 @@
|
|
|
1
|
+
import { CanActivate, ExecutionContext } from '@nestjs/common';
|
|
2
|
+
import { ConfigService } from '@nestjs/config';
|
|
3
|
+
import { Reflector } from '@nestjs/core';
|
|
4
|
+
export declare class JwtAuthGuard implements CanActivate {
|
|
5
|
+
private readonly configService;
|
|
6
|
+
private readonly reflector;
|
|
7
|
+
private readonly logger;
|
|
8
|
+
private readonly jwtSecret;
|
|
9
|
+
constructor(configService: ConfigService, reflector: Reflector);
|
|
10
|
+
canActivate(context: ExecutionContext): boolean;
|
|
11
|
+
private isPublicRoute;
|
|
12
|
+
private extractToken;
|
|
13
|
+
private isValidAuthHeader;
|
|
14
|
+
private parseBearer;
|
|
15
|
+
private validateToken;
|
|
16
|
+
private handleTokenError;
|
|
17
|
+
}
|